Scripting Helpers is winding down operations and is now read-only. More info→
Ad
Log in to vote
0

My Tycoon data won't save with a script?

Asked by 6 years ago

I made a script, but the GUI won't show up for some odd reason. Here's the code: local DataStore = game:GetService("DataStoreService"):GetDataStore('DataStoreSave01') local ReplicatedStorage = game:GetService("ReplicatedStorage") local Events = ReplicatedStorage:WaitForChild('Events') local ServerToClient = Events:WaitForChild('ServerToClient') local DataLoaded = Events:WaitForChild('DataLoaded')

local Objects = {}
local TeamColor = script.Parent.TeamColor.Value
local Settings = require(script.Parent.Parent.Parent.Settings)
local Money = script.Parent.CurrencyToCollect
local Debris = game:GetService('Debris')
local Stealing = Settings.StealSettings
local CanSteal = true -- don't change or else you won't be able to steal currency

script.Parent.Essentials.Spawn.TeamColor = TeamColor
script.Parent.Essentials.Spawn.BrickColor = TeamColor

function Sound(part,id)
    if part:FindFirstChild('Sound') then
        return
    else
        local Sound = Instance.new('Sound',part)
        Sound.SoundId = "rbxassetid://"..tostring(id)
        Sound:Play()
        delay(Sound.TimeLength, function()
            Sound:Destroy()
        end)
    end
end

--Parts that fall into the collector(s) get processed
for i,v in pairs(script.Parent.Essentials:GetChildren()) do
    if v.Name == "PartCollector" then
        v.Touched:connect(function(Part)
            if Part:FindFirstChild('Cash') then
                Money.Value = Money.Value + Part.Cash.Value
                Debris:AddItem(Part,0.1)
            end
        end)
    end
end

--Player Touched Collector processor
deb = false
script.Parent.Essentials.Giver.Touched:connect(function(hit)
    local player = game.Players:GetPlayerFromCharacter(hit.Parent)
    if player ~= nil then
        if script.Parent.Owner.Value == player then
            if hit.Parent:FindFirstChild("Humanoid") then
                if hit.Parent.Humanoid.Health > 0 then
                    if deb == false then
                        deb = true
                        script.Parent.Essentials.Giver.BrickColor = BrickColor.new("Bright red")
                        local Stats = game.ServerStorage.PlayerMoney:FindFirstChild(player.Name)
                        if Stats ~= nil then 
                        Sound(script.Parent.Essentials, Settings.Sounds.Collect)
                        Stats.Value = Stats.Value + Money.Value
                        Money.Value = 0
                        wait(1)
                        script.Parent.Essentials.Giver.BrickColor = BrickColor.new("Sea green")
                        deb = false
                        end
                    end
                end
            end
        elseif Stealing.Stealing then -- if player isn't owner and stealing is on
            if CanSteal == true then
                CanSteal = false
                delay(Stealing.PlayerProtection, function()
                    CanSteal = true
                end)
                if hit.Parent:FindFirstChild("Humanoid") then
                    if hit.Parent.Humanoid.Health > 0 then
                        local Stats = game.ServerStorage.PlayerMoney:FindFirstChild(player.Name)
                        if Stats ~= nil then
                            local Difference = math.floor(Money.Value * Stealing.StealPrecent)
                            Sound(script.Parent.Essentials, Settings.Sounds.Collect)
                            Stats.Value = Stats.Value + Difference
                            Money.Value = Money.Value - Difference
                        end
                    end
                end
            else
                Sound(script.Parent.Essentials, Settings.Sounds.Error)
            end
        end
    end
end)

script.Parent:WaitForChild("Buttons")
for i,v in pairs(script.Parent.Buttons:GetChildren()) do
    spawn(function()
    if v:FindFirstChild("Head") then

        local ThingMade = script.Parent.Purchases:WaitForChild(v.Object.Value)
        if ThingMade ~= nil then
            Objects[ThingMade.Name] = ThingMade:Clone()
            ThingMade:Destroy()
        else
            --//Button doesn't have object, remove it
            error('Object missing for button: '..v.Name..', button has been removed')
            v.Head.CanCollide = false
            v.Head.Transparency = 1
        end

        if v:FindFirstChild("Dependency") then --// if button needs something unlocked before it pops up
            v.Head.CanCollide = false
            v.Head.Transparency = 1
            v.Head.BillboardGui.Enabled = false
            coroutine.resume(coroutine.create(function()
                if script.Parent.PurchasedObjects:WaitForChild(v.Dependency.Value) then
                    if Settings['ButtonsFadeIn'] and v.Purchased.Value == false then
                        for i=1,20 do
                            wait(Settings['FadeInTime']/20)
                            v.Head.Transparency = v.Head.Transparency - 0.05
                        end
                    end
                    v.Head.CanCollide = true
                    v.Head.BillboardGui.Enabled = true
                    v.Head.Transparency = 0
                end
            end))
        end

        v.Head.Touched:connect(function(hit)
            local player = game.Players:GetPlayerFromCharacter(hit.Parent)
            if v.Head.CanCollide == true then
                if player ~= nil then
                    if script.Parent.Owner.Value == player then
                        if hit.Parent:FindFirstChild("Humanoid") then
                            if hit.Parent.Humanoid.Health > 0 then
                                local PlayerStats = game.ServerStorage.PlayerMoney:FindFirstChild(player.Name)
                                if PlayerStats ~= nil then
                                    if (v:FindFirstChild('Gamepass')) and (v.Gamepass.Value >= 1) then
                                        if game:GetService("MarketplaceService"):PlayerOwnsAsset(player,v.Gamepass.Value) then
                                            Purchase({[1] = v.Price.Value,[2] = v,[3] = PlayerStats})
                                        else
                                            game:GetService('MarketplaceService'):PromptPurchase(player,v.Gamepass.Value)
                                        end
                                    elseif (v:FindFirstChild('DevProduct')) and (v.DevProduct.Value >= 1) then
                                        game:GetService('MarketplaceService'):PromptProductPurchase(player,v.DevProduct.Value)
                                    elseif PlayerStats.Value >= v.Price.Value then
                                        Purchase({[1] = v.Price.Value,[2] = v,[3] = PlayerStats})
                                        Sound(v, Settings.Sounds.Purchase)
                                    else
                                        Sound(v, Settings.Sounds.ErrorBuy)
                                    end
                                end
                            end
                        end
                    end
                end
            end
        end)
        end
    end)
end

function Purchase(tbl)
    local cost = tbl[1]
    local item = tbl[2]
    local stats = tbl[3]
    stats.Value = stats.Value - cost
    Objects[item.Object.Value].Parent = script.Parent.PurchasedObjects
    item:FindFirstChild('Purchased').Value = true
    item.Head.BillboardGui.Enabled = false

    if Settings['ButtonsFadeOut'] then
        item.Head.CanCollide = false
        coroutine.resume(coroutine.create(function()
            for i=1,20 do
                wait(Settings['FadeOutTime']/20)
                item.Head.Transparency = item.Head.Transparency + 0.05
            end
        end))
    else
        item.Head.CanCollide = false
        item.Head.Transparency = 1
    end
end

function Create(tab)
    local x = Instance.new('Model')
    Instance.new('NumberValue',x).Value = tab[1]
    x.Value.Name = "Cost"
    Instance.new('ObjectValue',x).Value = tab[2]
    x.Value.Name = "Button"
    local Obj = Instance.new('ObjectValue',x)
    Obj.Name = "Stats"
    Obj.Value = tab[3]
    x.Parent = script.Parent.BuyObject
end

--// This was very rushed and is inefficent; if you plan on making something like this don't use a child added listener.
script.Parent:WaitForChild('BuyObject').ChildAdded:connect(function(child)
    local tab = {}
    tab[1] = child.Cost.Value
    tab[2] = child.Button.Value
    tab[3] = child.Stats.Value
    Purchase(tab)
    wait(10)
    child:Destroy()
end)

game.Players.PlayerAdded:Connect(function(Player) while Player.Team == game:GetService('Teams')['For Hire'] do wait() end if Player.Team == game:GetService('Teams')[script.Parent.Name] then local Data = DataStore:GetAsync(Player.UserId)

    if Data then
        local Response = ServerToClient:InvokeClient(Player)

        if Response == 'LoadData' then
            local Buttons = Data[1]
            local Cash = Data[2]

            local PlayerData = game:GetService("ServerStorage"):WaitForChild('PlayerMoney'):WaitForChild(Player.Name)

            for i,v in pairs(Buttons) do
                local ToBuyButton = script.Parent:WaitForChild('Buttons'):WaitForChild(v)

                Purchase({ToBuyButton:FindFirstChild('Price').Value, ToBuyButton, PlayerData})
            end

            PlayerData.Value = Cash
            DataLoaded:FireClient(Player)
        end
    end
end

end)

0
Over 200 lines of code theCJarmy7 1293 — 6y
0
Please, explain better. As you may understand, we aren't here for just reading tons of lines of codes without even knowing if there are errors in the script, where is it located and so on. Be more exact, we've got better things to do rather than reading tons of LUA. Aimarekin 345 — 6y

Answer this question