mirror of
https://github.com/Refactorio/RedMew.git
synced 2025-01-18 03:21:47 +02:00
Merge pull request #617 from iltar/fish-market-new-gui
Fish market with new GUI and stack limit
This commit is contained in:
commit
75274a8c87
13
config.lua
13
config.lua
@ -16,6 +16,14 @@ global.config = {
|
||||
-- New Scenario Features, appears in the "What's new" tab
|
||||
new_info_key = 'Nothing is new. The world is at peace',
|
||||
},
|
||||
-- saves players' lives if they have a small-plane in their inventory, also adds the small-plane to the market and must therefor be loaded first
|
||||
train_saviour = {
|
||||
enabled = true,
|
||||
},
|
||||
-- Adds the infinite storage chest to the market and adds a custom GUI to it. Also has to be loaded first due to adding a market item
|
||||
infinite_storage_chest = {
|
||||
enabled = false,
|
||||
},
|
||||
-- adds a command to scale UPS and movement speed. Use with caution as it might break scenarios that modify movement speed
|
||||
performance = {
|
||||
enabled = true,
|
||||
@ -52,7 +60,6 @@ global.config = {
|
||||
-- adds a fish market
|
||||
fish_market = {
|
||||
enabled = true,
|
||||
market_item = market_item,
|
||||
},
|
||||
-- adds anti-nuke griefing
|
||||
nuke_control = {
|
||||
@ -181,10 +188,6 @@ global.config = {
|
||||
donator_messages = {
|
||||
enabled = true,
|
||||
},
|
||||
-- saves players' lives if they have a small-plane in their inventory, also adds the small-plan to the market
|
||||
train_saviour = {
|
||||
enabled = true,
|
||||
},
|
||||
player_colors = {
|
||||
enabled = true,
|
||||
},
|
||||
|
@ -17,6 +17,12 @@ require 'features.player_create'
|
||||
require 'features.user_groups'
|
||||
|
||||
-- Feature modules, each can be disabled safely
|
||||
if config.train_saviour.enabled then
|
||||
require 'features.train_saviour'
|
||||
end
|
||||
if config.infinite_storage_chest.enabled then
|
||||
require 'features.infinite_storage_chest'
|
||||
end
|
||||
if config.autodeconstruct.enabled then
|
||||
require 'features.autodeconstruct'
|
||||
end
|
||||
@ -35,9 +41,6 @@ end
|
||||
if config.donator_messages.enabled then
|
||||
require 'features.donator_messages'
|
||||
end
|
||||
if config.train_saviour.enabled then
|
||||
require 'features.train_saviour'
|
||||
end
|
||||
if config.fish_market.enabled then
|
||||
require 'features.fish_market'
|
||||
end
|
||||
|
@ -1,24 +1,30 @@
|
||||
--[[
|
||||
Hello there script explorer!
|
||||
|
||||
With this you can add a "Fish Market" to your World
|
||||
You can earn fish by killing alot of biters or by mining wood, ores, rocks.
|
||||
To spawn the market, do "/market" in your chat ingame as the games host.
|
||||
It will spawn a few tiles north of the current position where your character is.
|
||||
|
||||
---MewMew---
|
||||
|
||||
--]]
|
||||
local Event = require 'utils.event'
|
||||
local Token = require 'utils.token'
|
||||
local Task = require 'utils.task'
|
||||
local PlayerStats = require 'features.player_stats'
|
||||
local Game = require 'utils.game'
|
||||
local Command = require 'utils.command'
|
||||
|
||||
local Market_items = require 'resources.market_items'
|
||||
local market_item = Market_items.market_item
|
||||
local Retailer = require 'features.retailer'
|
||||
local market_items = require 'resources.market_items'
|
||||
local fish_market_bonus_message = require 'resources.fish_messages'
|
||||
local pairs = pairs
|
||||
local random = math.random
|
||||
local format = string.format
|
||||
local get_random = table.get_random
|
||||
|
||||
local running_speed_boost_messages = {
|
||||
'%s found the lost Dragon Scroll and got a lv.1 speed boost!',
|
||||
'Guided by Master Oogway, %s got a lv.2 speed boost!',
|
||||
'Kung Fu Master %s defended the village and was awarded a lv.3 speed boost!',
|
||||
'Travelled at the speed of light. %s saw a black hole. Oops.',
|
||||
}
|
||||
|
||||
local mining_speed_boost_messages = {
|
||||
'%s is going on a tree harvest!',
|
||||
'In search of a sharper axe, %s got a lv.2 mining boost!',
|
||||
'Wood fiend, %s, has picked up a massive chain saw and is awarded a lv.3 mining boost!',
|
||||
'Better learn to control that saw, %s, chopped off their legs. Oops.',
|
||||
}
|
||||
|
||||
local function spawn_market(_, player)
|
||||
local surface = player.surface
|
||||
@ -27,29 +33,24 @@ local function spawn_market(_, player)
|
||||
local pos = player.position
|
||||
pos.y = pos.y - 4
|
||||
|
||||
local market = surface.create_entity {name = 'market', position = pos}
|
||||
local market = surface.create_entity({name = 'market', position = pos})
|
||||
market.destructible = false
|
||||
player.print("Market added. To remove it, highlight it with your cursor and run the command /sc game.player.selected.destroy()")
|
||||
|
||||
for _, item in ipairs(Market_items) do
|
||||
market.add_market_item(item)
|
||||
Retailer.add_market('fish_market', market)
|
||||
|
||||
for _, prototype in pairs(market_items) do
|
||||
Retailer.set_item('fish_market', prototype)
|
||||
end
|
||||
|
||||
force.add_chart_tag(
|
||||
surface,
|
||||
{
|
||||
icon = {type = 'item', name = market_item},
|
||||
position = pos,
|
||||
text = 'Market'
|
||||
}
|
||||
)
|
||||
force.add_chart_tag(surface, {icon = {type = 'item', name = 'coin'}, position = pos, text = 'Market'})
|
||||
end
|
||||
|
||||
local function fish_earned(event, amount)
|
||||
local player_index = event.player_index
|
||||
local player = Game.get_player_by_index(player_index)
|
||||
|
||||
local stack = {name = market_item, count = amount}
|
||||
local stack = {name = 'coin', count = amount}
|
||||
local inserted = player.insert(stack)
|
||||
|
||||
local diff = amount - inserted
|
||||
@ -58,29 +59,23 @@ local function fish_earned(event, amount)
|
||||
player.surface.spill_item_stack(player.position, stack, true)
|
||||
end
|
||||
|
||||
local fish = PlayerStats.get_coin_earned(player_index)
|
||||
fish = fish + amount
|
||||
PlayerStats.set_coin_earned(player_index, fish)
|
||||
PlayerStats.change_coin_earned(player_index, amount)
|
||||
|
||||
if fish % 70 == 0 then
|
||||
if player and player.valid then
|
||||
local message = table.get_random(fish_market_bonus_message, true)
|
||||
player.print(message)
|
||||
end
|
||||
if PlayerStats.get_coin_earned(player_index) % 70 == 0 and player and player.valid then
|
||||
local message = get_random(fish_market_bonus_message, true)
|
||||
player.print(message)
|
||||
end
|
||||
end
|
||||
|
||||
local function pre_player_mined_item(event)
|
||||
if event.entity.type == 'simple-entity' then -- Cheap check for rock, may have other side effects
|
||||
local type = event.entity.type
|
||||
if type == 'simple-entity' then -- Cheap check for rock, may have other side effects
|
||||
fish_earned(event, 10)
|
||||
return
|
||||
end
|
||||
|
||||
if event.entity.type == 'tree' then
|
||||
local x = math.random(1, 4)
|
||||
if x == 1 then
|
||||
fish_earned(event, 4)
|
||||
end
|
||||
if type == 'tree' and random(1, 4) == 1 then
|
||||
fish_earned(event, 4)
|
||||
end
|
||||
end
|
||||
|
||||
@ -92,13 +87,9 @@ local entity_drop_amount = {
|
||||
['big-worm-turret'] = {low = 10, high = 20}
|
||||
}
|
||||
|
||||
local spill_items =
|
||||
Token.register(
|
||||
function(data)
|
||||
local stack = {name = market_item, count = data.count}
|
||||
data.surface.spill_item_stack(data.position, stack, true)
|
||||
end
|
||||
)
|
||||
local spill_items = Token.register(function(data)
|
||||
data.surface.spill_item_stack(data.position, {name = 'coin', count = data.count}, true)
|
||||
end)
|
||||
|
||||
local function fish_drop_entity_died(event)
|
||||
local entity = event.entity
|
||||
@ -111,20 +102,19 @@ local function fish_drop_entity_died(event)
|
||||
return
|
||||
end
|
||||
|
||||
local count = math.random(bounds.low, bounds.high)
|
||||
local count = random(bounds.low, bounds.high)
|
||||
|
||||
if count > 0 then
|
||||
Task.set_timeout_in_ticks(1, spill_items, {count = count, surface = entity.surface, position = entity.position})
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
local function reset_player_running_speed(player)
|
||||
player.character_running_speed_modifier = global.player_speed_boost_records[player.index].pre_boost_modifier
|
||||
global.player_speed_boost_records[player.index] = nil
|
||||
end
|
||||
|
||||
local function boost_player_running_speed(player, market)
|
||||
local function boost_player_running_speed(player)
|
||||
if global.player_speed_boost_records == nil then
|
||||
global.player_speed_boost_records = {}
|
||||
end
|
||||
@ -133,26 +123,21 @@ local function boost_player_running_speed(player, market)
|
||||
global.player_speed_boost_records[player.index] = {
|
||||
start_tick = game.tick,
|
||||
pre_boost_modifier = player.character_running_speed_modifier,
|
||||
boost_lvl = 0
|
||||
boost_lvl = 0,
|
||||
}
|
||||
end
|
||||
local boost_msg = {
|
||||
[1] = '%s found the lost Dragon Scroll and got a lv.1 speed boost!',
|
||||
[2] = 'Guided by Master Oogway, %s got a lv.2 speed boost!',
|
||||
[3] = 'Kungfu Master %s defended the village and was awarded a lv.3 speed boost!',
|
||||
[4] = 'Travelled at the speed of light. %s saw a blackhole. Oops.'
|
||||
}
|
||||
|
||||
global.player_speed_boost_records[player.index].boost_lvl = 1 + global.player_speed_boost_records[player.index].boost_lvl
|
||||
player.character_running_speed_modifier = 1 + player.character_running_speed_modifier
|
||||
|
||||
if global.player_speed_boost_records[player.index].boost_lvl >= 4 then
|
||||
game.print(string.format(boost_msg[global.player_speed_boost_records[player.index].boost_lvl], player.name))
|
||||
game.print(format(running_speed_boost_messages[global.player_speed_boost_records[player.index].boost_lvl], player.name))
|
||||
reset_player_running_speed(player)
|
||||
player.character.die(player.force, market)
|
||||
player.character.die(player.force, player.character)
|
||||
return
|
||||
end
|
||||
|
||||
player.print(string.format(boost_msg[global.player_speed_boost_records[player.index].boost_lvl], player.name))
|
||||
player.print(format(running_speed_boost_messages[global.player_speed_boost_records[player.index].boost_lvl], player.name))
|
||||
end
|
||||
|
||||
local function reset_player_mining_speed(player)
|
||||
@ -160,7 +145,7 @@ local function reset_player_mining_speed(player)
|
||||
global.player_mining_boost_records[player.index] = nil
|
||||
end
|
||||
|
||||
local function boost_player_mining_speed(player, market)
|
||||
local function boost_player_mining_speed(player)
|
||||
if global.player_mining_boost_records == nil then
|
||||
global.player_mining_boost_records = {}
|
||||
end
|
||||
@ -169,62 +154,33 @@ local function boost_player_mining_speed(player, market)
|
||||
global.player_mining_boost_records[player.index] = {
|
||||
start_tick = game.tick,
|
||||
pre_mining_boost_modifier = player.character_mining_speed_modifier,
|
||||
boost_lvl = 0
|
||||
boost_lvl = 0,
|
||||
}
|
||||
end
|
||||
local boost_msg = {
|
||||
[1] = '%s is going on a tree harvest!',
|
||||
[2] = 'In search of a sharper axe, %s got a lv.2 mining boost!',
|
||||
[3] = 'Wood fiend, %s, has picked up a massive chain saw and is awarded a lv.3 mining boost!',
|
||||
[4] = 'Better learn to control that saw, %s, chopped off their legs. Oops.'
|
||||
}
|
||||
global.player_mining_boost_records[player.index].boost_lvl = 1 + global.player_mining_boost_records[player.index].boost_lvl
|
||||
player.character_mining_speed_modifier = 1 + player.character_mining_speed_modifier
|
||||
|
||||
if global.player_mining_boost_records[player.index].boost_lvl >= 4 then
|
||||
game.print(string.format(boost_msg[global.player_mining_boost_records[player.index].boost_lvl], player.name))
|
||||
game.print(format(mining_speed_boost_messages[global.player_mining_boost_records[player.index].boost_lvl], player.name))
|
||||
reset_player_mining_speed(player)
|
||||
player.character.die(player.force, market)
|
||||
player.character.die(player.force, player.character)
|
||||
return
|
||||
end
|
||||
|
||||
player.print(string.format(boost_msg[global.player_mining_boost_records[player.index].boost_lvl], player.name))
|
||||
player.print(format(mining_speed_boost_messages[global.player_mining_boost_records[player.index].boost_lvl], player.name))
|
||||
end
|
||||
|
||||
local function market_item_purchased(event)
|
||||
local market = event.market
|
||||
if not market or not market.valid then
|
||||
local function on_market_purchase(event)
|
||||
local item_name = event.item.name
|
||||
if item_name == 'temporary-running-speed-bonus' then
|
||||
boost_player_running_speed(event.player)
|
||||
return
|
||||
end
|
||||
|
||||
local offer_index = event.offer_index
|
||||
local player_index = event.player_index
|
||||
|
||||
-- cost
|
||||
local market_item = market.get_market_items()[offer_index]
|
||||
local fish_cost = market_item.price[1].amount * event.count
|
||||
|
||||
PlayerStats.change_coin_spent(player_index, fish_cost)
|
||||
|
||||
if event.offer_index == 1 then -- Temporary speed bonus
|
||||
local player = Game.get_player_by_index(player_index)
|
||||
boost_player_running_speed(player, market)
|
||||
if item_name == 'temporary-mining-speed-bonus' then
|
||||
boost_player_mining_speed(event.player)
|
||||
return
|
||||
end
|
||||
|
||||
if event.offer_index == 2 then -- Temporary mining bonus
|
||||
local player = Game.get_player_by_index(player_index)
|
||||
boost_player_mining_speed(player, market)
|
||||
end
|
||||
|
||||
if event.offer_index == 3 then -- train saviour item
|
||||
local player = Game.get_player_by_index(player_index)
|
||||
local train_savior_item = Market_items[offer_index].item
|
||||
player.insert {name = train_savior_item, count = event.count}
|
||||
end
|
||||
end
|
||||
|
||||
if not global.pet_command_rotation then
|
||||
global.pet_command_rotation = 1
|
||||
end
|
||||
|
||||
local function on_180_ticks()
|
||||
@ -255,8 +211,7 @@ local function on_180_ticks()
|
||||
end
|
||||
|
||||
local function fish_player_crafted_item(event)
|
||||
local x = math.random(1, 50)
|
||||
if x == 1 then
|
||||
if random(1, 50) == 1 then
|
||||
fish_earned(event, 1)
|
||||
end
|
||||
end
|
||||
@ -269,26 +224,17 @@ local function player_created(event)
|
||||
end
|
||||
|
||||
local count = global.config.player_rewards.info_player_reward and 1 or 10
|
||||
player.insert {name = market_item, count = count}
|
||||
player.insert({name = 'coin', count = count})
|
||||
end
|
||||
|
||||
local function init()
|
||||
Command.add(
|
||||
'market',
|
||||
{
|
||||
description = 'Places a market near you.',
|
||||
admin_only = true
|
||||
},
|
||||
spawn_market
|
||||
)
|
||||
Command.add('market', {
|
||||
description = 'Places a market near you.',
|
||||
admin_only = true,
|
||||
}, spawn_market)
|
||||
|
||||
Event.on_nth_tick(180, on_180_ticks)
|
||||
Event.add(defines.events.on_pre_player_mined_item, pre_player_mined_item)
|
||||
Event.add(defines.events.on_entity_died, fish_drop_entity_died)
|
||||
Event.add(defines.events.on_market_item_purchased, market_item_purchased)
|
||||
Event.add(defines.events.on_player_crafted_item, fish_player_crafted_item)
|
||||
Event.add(defines.events.on_player_created, player_created)
|
||||
end
|
||||
|
||||
Event.on_init(init)
|
||||
Event.on_load(init)
|
||||
Event.on_nth_tick(180, on_180_ticks)
|
||||
Event.add(defines.events.on_pre_player_mined_item, pre_player_mined_item)
|
||||
Event.add(defines.events.on_entity_died, fish_drop_entity_died)
|
||||
Event.add(Retailer.events.on_market_purchase, on_market_purchase)
|
||||
Event.add(defines.events.on_player_crafted_item, fish_player_crafted_item)
|
||||
Event.add(defines.events.on_player_created, player_created)
|
||||
|
@ -250,4 +250,4 @@ Gui.on_custom_close(
|
||||
)
|
||||
|
||||
local market_items = require 'resources.market_items'
|
||||
table.insert(market_items, {price = {{market_items.market_item, 100}}, offer = {type = 'give-item', item = 'infinity-chest'}})
|
||||
table.insert(market_items, {price = 100, name = 'infinity-chest', description = 'Stores unlimited quantity of items for up to 48 different item types'})
|
@ -93,10 +93,8 @@ local memory = {
|
||||
market_gui_refresh_scheduled = {},
|
||||
}
|
||||
|
||||
Global.register({
|
||||
memory = memory,
|
||||
}, function (tbl)
|
||||
memory = tbl.memory
|
||||
Global.register(memory, function (tbl)
|
||||
memory = tbl
|
||||
end)
|
||||
|
||||
local function schedule_market_gui_refresh(group_name)
|
||||
@ -165,10 +163,12 @@ local function redraw_market_items(data)
|
||||
end
|
||||
|
||||
for i, item in pairs(market_items) do
|
||||
local stack_limit = item.stack_limit
|
||||
local stack_count = stack_limit ~= -1 and stack_limit < count and item.stack_limit or count
|
||||
local price = item.price
|
||||
local tooltip = {'', item.name_label, format('\nprice: %.2f', price)}
|
||||
local description = item.description
|
||||
local total_price = ceil(price * count)
|
||||
local total_price = ceil(price * stack_count)
|
||||
local disabled = item.disabled == true
|
||||
local message
|
||||
if total_price == 1 then
|
||||
@ -187,19 +187,19 @@ local function redraw_market_items(data)
|
||||
if disabled then
|
||||
insert(tooltip, '\n\n' .. (item.disabled_reason or 'Not available'))
|
||||
elseif is_missing_coins then
|
||||
insert(tooltip, '\n\n' .. format('Missing %d coins to buy %d', missing_coins, count))
|
||||
insert(tooltip, '\n\n' .. format('Missing %d coins to buy %d', missing_coins, stack_count))
|
||||
end
|
||||
|
||||
local button = grid.add({type = 'flow'}).add({
|
||||
type = 'sprite-button',
|
||||
name = item_button_name,
|
||||
sprite = item.sprite,
|
||||
number = count,
|
||||
number = stack_count,
|
||||
tooltip = tooltip,
|
||||
})
|
||||
button.style = 'slot_button'
|
||||
|
||||
Gui.set_data(button, {index = i, data = data})
|
||||
Gui.set_data(button, {index = i, data = data, stack_count = stack_count})
|
||||
|
||||
local label = grid.add({type = 'label', caption = message})
|
||||
local label_style = label.style
|
||||
@ -406,6 +406,7 @@ Gui.on_click(item_button_name, function (event)
|
||||
local element = event.element
|
||||
local button_data = Gui.get_data(element)
|
||||
local data = button_data.data
|
||||
local stack_count = button_data.stack_count
|
||||
|
||||
local item = data.market_items[button_data.index]
|
||||
|
||||
@ -421,9 +422,8 @@ Gui.on_click(item_button_name, function (event)
|
||||
|
||||
local name = item.name
|
||||
local price = item.price
|
||||
local count = data.count
|
||||
|
||||
local cost = ceil(price * count)
|
||||
local cost = ceil(price * stack_count)
|
||||
local coin_count = player.get_item_count('coin')
|
||||
|
||||
if cost > coin_count then
|
||||
@ -432,8 +432,8 @@ Gui.on_click(item_button_name, function (event)
|
||||
end
|
||||
|
||||
if item.type == 'item' then
|
||||
local inserted = player.insert({name = name, count = count})
|
||||
if inserted < count then
|
||||
local inserted = player.insert({name = name, count = stack_count})
|
||||
if inserted < stack_count then
|
||||
player.print('Insufficient inventory space')
|
||||
if inserted > 0 then
|
||||
player.remove_item({name = name, count = inserted})
|
||||
@ -451,7 +451,7 @@ Gui.on_click(item_button_name, function (event)
|
||||
|
||||
raise_event(Retailer.events.on_market_purchase, {
|
||||
item = item,
|
||||
count = count,
|
||||
count = stack_count,
|
||||
player = player,
|
||||
})
|
||||
end)
|
||||
@ -483,6 +483,10 @@ function Retailer.set_item(group_name, prototype)
|
||||
prototype.sprite = prototype.sprite or 'item/' .. item_name
|
||||
prototype.type = prototype.type or 'item'
|
||||
|
||||
if not prototype.stack_limit then
|
||||
prototype.stack_limit = -1
|
||||
end
|
||||
|
||||
memory.items[group_name][item_name] = prototype
|
||||
|
||||
schedule_market_gui_refresh(group_name)
|
||||
|
@ -1,5 +1,5 @@
|
||||
local Event = require 'utils.event'
|
||||
local Market_items = require 'resources.market_items'
|
||||
local market_items = require 'resources.market_items'
|
||||
local Global = require 'utils.global'
|
||||
local Donators = require 'resources.donators'
|
||||
local UserGroups = require 'features.user_groups'
|
||||
@ -9,17 +9,19 @@ local train_perk_flag = Donators.donator_perk_flags.train
|
||||
local saviour_token_name = 'small-plane' -- item name for what saves players
|
||||
local saviour_timeout = 180 -- number of ticks players are train immune after getting hit (roughly)
|
||||
|
||||
table.insert(Market_items, 3, {price = {{Market_items.market_item, 100}}, offer = {type = 'nothing', effect_description = 'Train Immunity (+1 ' .. saviour_token_name .. ')\nEach ' .. saviour_token_name .. ' in your inventory will save you\nfrom being killed by a train once\n\nPrice: 100 ' .. Market_items.market_item .. 's'}, item = saviour_token_name})
|
||||
table.insert(market_items, 3, {
|
||||
price = 100,
|
||||
name = saviour_token_name,
|
||||
name_label = 'Train Immunity (1x use)',
|
||||
description = 'Each ' .. saviour_token_name .. ' in your inventory will save you from being killed by a train once.',
|
||||
})
|
||||
|
||||
local remove_stack = {name = saviour_token_name, count = 1}
|
||||
|
||||
local saved_players = {}
|
||||
Global.register(
|
||||
saved_players,
|
||||
function(tbl)
|
||||
saved_players = tbl
|
||||
end
|
||||
)
|
||||
|
||||
Global.register(saved_players, function(tbl)
|
||||
saved_players = tbl
|
||||
end)
|
||||
|
||||
local train_names = {
|
||||
['locomotive'] = true,
|
||||
@ -80,17 +82,8 @@ local function on_pre_death(event)
|
||||
|
||||
player.remove_item(remove_stack)
|
||||
saved_players[player_index] = game_tick
|
||||
|
||||
save_player(player)
|
||||
|
||||
game.print(
|
||||
table.concat {
|
||||
player_name,
|
||||
' has been saved from a train death. Their ',
|
||||
saviour_token_name,
|
||||
' survival item has been consumed.'
|
||||
}
|
||||
)
|
||||
game.print(player_name .. ' has been saved from a train death. One of their Train Immunity items has been consumed.')
|
||||
end
|
||||
|
||||
Event.add(defines.events.on_pre_player_died, on_pre_death)
|
||||
|
@ -1,228 +0,0 @@
|
||||
local Event = require 'utils.event'
|
||||
local Token = require 'utils.token'
|
||||
local Task = require 'utils.task'
|
||||
local PlayerStats = require 'features.player_stats'
|
||||
local Game = require 'utils.game'
|
||||
local Utils = require 'utils.core'
|
||||
local Command = require 'utils.command'
|
||||
|
||||
local market_items = require 'resources.market_items'
|
||||
|
||||
for _, item in ipairs(market_items) do
|
||||
local price = item.price[1]
|
||||
price[1] = 'raw-wood'
|
||||
price[2] = price[2] * 4
|
||||
end
|
||||
|
||||
market_items[1].offer.effect_description = 'Temporary speed bonus - Price 40 Wood'
|
||||
market_items[2].offer.effect_description = 'Temporary mining bonus - Price 40 Wood'
|
||||
|
||||
table.insert(market_items, {price = {{'raw-wood', 4}}, offer = {type = 'give-item', item = 'raw-fish'}})
|
||||
|
||||
local function spawn_market(_, player)
|
||||
local surface = game.player.surface
|
||||
local force = player.force
|
||||
|
||||
local pos = player.position
|
||||
pos.y = pos.y - 4
|
||||
|
||||
local market = surface.create_entity {name = 'market', position = pos}
|
||||
market.destructible = false
|
||||
|
||||
for _, item in ipairs(market_items) do
|
||||
market.add_market_item(item)
|
||||
end
|
||||
|
||||
force.add_chart_tag(
|
||||
surface,
|
||||
{
|
||||
icon = {type = 'item', name = 'raw-wood'},
|
||||
position = pos,
|
||||
text = 'Market'
|
||||
}
|
||||
)
|
||||
end
|
||||
|
||||
local entity_drop_amount = {
|
||||
--[[['small-biter'] = {low = -62, high = 1},
|
||||
['small-spitter'] = {low = -62, high = 1},
|
||||
['medium-biter'] = {low = -14, high = 1},
|
||||
['medium-spitter'] = {low = -14, high = 1},
|
||||
['big-biter'] = {low = -2, high = 1},
|
||||
['big-spitter'] = {low = -2, high = 1},
|
||||
['behemoth-biter'] = {low = 1, high = 1},
|
||||
['behemoth-spitter'] = {low = 1, high = 1}, ]]
|
||||
['biter-spawner'] = {low = 5, high = 15},
|
||||
['spitter-spawner'] = {low = 5, high = 15},
|
||||
['small-worm-turret'] = {low = 2, high = 8},
|
||||
['medium-worm-turret'] = {low = 5, high = 15},
|
||||
['big-worm-turret'] = {low = 10, high = 20}
|
||||
}
|
||||
|
||||
local spill_items =
|
||||
Token.register(
|
||||
function(data)
|
||||
local stack = {name = 'raw-wood', count = data.count * 4}
|
||||
data.surface.spill_item_stack(data.position, stack, true)
|
||||
end
|
||||
)
|
||||
|
||||
local function wood_drop_entity_died(event)
|
||||
local entity = event.entity
|
||||
if not entity or not entity.valid then
|
||||
return
|
||||
end
|
||||
|
||||
local bounds = entity_drop_amount[entity.name]
|
||||
if not bounds then
|
||||
return
|
||||
end
|
||||
|
||||
local count = math.random(bounds.low, bounds.high)
|
||||
|
||||
if count > 0 then
|
||||
Task.set_timeout_in_ticks(1, spill_items, {count = count, surface = entity.surface, position = entity.position})
|
||||
end
|
||||
end
|
||||
|
||||
local function reset_player_runningspeed(player)
|
||||
player.character_running_speed_modifier = global.player_speed_boost_records[player.index].pre_boost_modifier
|
||||
global.player_speed_boost_records[player.index] = nil
|
||||
end
|
||||
|
||||
local function boost_player_runningspeed(player, market)
|
||||
if global.player_speed_boost_records == nil then
|
||||
global.player_speed_boost_records = {}
|
||||
end
|
||||
|
||||
if global.player_speed_boost_records[player.index] == nil then
|
||||
global.player_speed_boost_records[player.index] = {
|
||||
start_tick = game.tick,
|
||||
pre_boost_modifier = player.character_running_speed_modifier,
|
||||
boost_lvl = 0
|
||||
}
|
||||
end
|
||||
local boost_msg = {
|
||||
[1] = '%s found the lost Dragon Scroll and got a lv.1 speed boost!',
|
||||
[2] = 'Guided by Master Oogway, %s got a lv.2 speed boost!',
|
||||
[3] = 'Kungfu Master %s defended the village and was awarded a lv.3 speed boost!',
|
||||
[4] = 'Travelled at the speed of light. %s saw a blackhole. Oops.'
|
||||
}
|
||||
global.player_speed_boost_records[player.index].boost_lvl = 1 + global.player_speed_boost_records[player.index].boost_lvl
|
||||
player.character_running_speed_modifier = 1 + player.character_running_speed_modifier
|
||||
game.print(string.format(boost_msg[global.player_speed_boost_records[player.index].boost_lvl], player.name))
|
||||
if global.player_speed_boost_records[player.index].boost_lvl >= 4 then
|
||||
reset_player_runningspeed(player)
|
||||
player.character.die(player.force, market)
|
||||
end
|
||||
end
|
||||
|
||||
local function reset_player_miningspeed(player)
|
||||
player.character_mining_speed_modifier = global.player_mining_boost_records[player.index].pre_mining_boost_modifier
|
||||
global.player_mining_boost_records[player.index] = nil
|
||||
end
|
||||
|
||||
local function boost_player_miningspeed(player, market)
|
||||
if global.player_mining_boost_records == nil then
|
||||
global.player_mining_boost_records = {}
|
||||
end
|
||||
|
||||
if global.player_mining_boost_records[player.index] == nil then
|
||||
global.player_mining_boost_records[player.index] = {
|
||||
start_tick = game.tick,
|
||||
pre_mining_boost_modifier = player.character_mining_speed_modifier,
|
||||
boost_lvl = 0
|
||||
}
|
||||
end
|
||||
local boost_msg = {
|
||||
[1] = '%s is going on a tree harvest!',
|
||||
[2] = 'In search of a sharper axe, %s got a lv.2 mining boost!',
|
||||
[3] = 'Wood fiend, %s, has picked up a massive chain saw and is awarded a lv.3 mining boost!',
|
||||
[4] = 'Better learn to control that saw, %s, chopped off their legs. Oops.'
|
||||
}
|
||||
global.player_mining_boost_records[player.index].boost_lvl = 1 + global.player_mining_boost_records[player.index].boost_lvl
|
||||
player.character_mining_speed_modifier = 1 + player.character_mining_speed_modifier
|
||||
game.print(string.format(boost_msg[global.player_mining_boost_records[player.index].boost_lvl], player.name))
|
||||
if global.player_mining_boost_records[player.index].boost_lvl >= 4 then
|
||||
reset_player_miningspeed(player)
|
||||
player.character.die(player.force, market)
|
||||
end
|
||||
end
|
||||
|
||||
local function market_item_purchased(event)
|
||||
local market = event.market
|
||||
if not market or not market.valid then
|
||||
return
|
||||
end
|
||||
|
||||
local offer_index = event.offer_index
|
||||
local player_index = event.player_index
|
||||
|
||||
-- cost
|
||||
local market_item = market.get_market_items()[offer_index]
|
||||
local cost = market_item.price[1].amount * event.count
|
||||
|
||||
PlayerStats.change_fish_spent(player_index, cost)
|
||||
|
||||
if event.offer_index == 1 then -- Temporary speed bonus
|
||||
local player = Game.get_player_by_index(player_index)
|
||||
boost_player_runningspeed(player, market)
|
||||
end
|
||||
|
||||
if event.offer_index == 2 then -- Temporary mining bonus
|
||||
local player = Game.get_player_by_index(player_index)
|
||||
boost_player_miningspeed(player, market)
|
||||
end
|
||||
end
|
||||
|
||||
if not global.pet_command_rotation then
|
||||
global.pet_command_rotation = 1
|
||||
end
|
||||
|
||||
local function on_180_ticks()
|
||||
if game.tick % 900 == 0 then
|
||||
if global.player_speed_boost_records then
|
||||
for k, v in pairs(global.player_speed_boost_records) do
|
||||
if game.tick - v.start_tick > 3000 then
|
||||
reset_player_runningspeed(Game.get_player_by_index(k))
|
||||
end
|
||||
end
|
||||
end
|
||||
if global.player_mining_boost_records then
|
||||
for k, v in pairs(global.player_mining_boost_records) do
|
||||
if game.tick - v.start_tick > 6000 then
|
||||
reset_player_miningspeed(Game.get_player_by_index(k))
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local function player_mined_entity(event)
|
||||
local buffer = event.buffer
|
||||
|
||||
if not buffer or not buffer.valid then
|
||||
return
|
||||
end
|
||||
|
||||
local count = buffer.get_item_count('raw-wood')
|
||||
|
||||
if count > 0 then
|
||||
PlayerStats.change_fish_earned(event.player_index, count)
|
||||
end
|
||||
end
|
||||
|
||||
Command.add(
|
||||
'market',
|
||||
{
|
||||
description = 'Places a market near you.',
|
||||
admin_only = true
|
||||
},
|
||||
spawn_market
|
||||
)
|
||||
|
||||
Event.on_nth_tick(180, on_180_ticks)
|
||||
|
||||
Event.add(defines.events.on_entity_died, wood_drop_entity_died)
|
||||
Event.add(defines.events.on_market_item_purchased, market_item_purchased)
|
||||
Event.add(defines.events.on_player_mined_entity, player_mined_entity)
|
@ -3,6 +3,8 @@ local Perlin = require 'map_gen.shared.perlin_noise'
|
||||
local Event = require 'utils.event'
|
||||
local Global = require 'utils.global'
|
||||
local math = require "utils.math"
|
||||
local match = string.match
|
||||
local remove = table.remove
|
||||
|
||||
local oil_seed
|
||||
local uranium_seed
|
||||
@ -34,8 +36,11 @@ Global.register_init(
|
||||
)
|
||||
|
||||
local market_items = require 'resources.market_items'
|
||||
table.remove(market_items, 13)
|
||||
table.remove(market_items, 9)
|
||||
for i = #market_items, 1, -1 do
|
||||
if match(market_items[i].name, 'flamethrower') then
|
||||
remove(market_items, i)
|
||||
end
|
||||
end
|
||||
|
||||
Event.add(
|
||||
defines.events.on_research_finished,
|
||||
|
@ -1,11 +1,17 @@
|
||||
local b = require 'map_gen.shared.builders'
|
||||
local Event = require 'utils.event'
|
||||
local Perlin = require 'map_gen.shared.perlin_noise'
|
||||
local match = string.match
|
||||
local remove = table.remove
|
||||
|
||||
local enemy_seed = 420420
|
||||
|
||||
local market_items = require 'resources.market_items'
|
||||
table.remove(market_items, 8)
|
||||
for i = #market_items, 1, -1 do
|
||||
if match(market_items[i].name, 'flamethrower') then
|
||||
remove(market_items, i)
|
||||
end
|
||||
end
|
||||
|
||||
Event.add(
|
||||
defines.events.on_research_finished,
|
||||
|
@ -144,7 +144,6 @@ local terrain_modules = {
|
||||
--require 'map_gen.misc.terraforming' -- prevents players from building on non-terraformed tiles
|
||||
--require 'map_gen.misc.car_body' -- gives players cars instead of characters
|
||||
--require 'map_gen.misc.naughty_words' -- admonishes players for cursing
|
||||
--require 'map_gen.misc.infinite_storage_chest'
|
||||
|
||||
if #entity_modules > 0 then
|
||||
shape = shape or b.full_shape
|
||||
|
@ -1,111 +1,84 @@
|
||||
local market_item = global.config.fish_market.market_item or 'coin'
|
||||
|
||||
return {
|
||||
market_item = market_item,
|
||||
{
|
||||
price = {{market_item, 10}},
|
||||
offer = {type = 'nothing', effect_description = 'Temporary speed bonus \nIncreases running speed by one level \nfor a short period \n\nPrice: 10 ' .. market_item..'s'}
|
||||
name = 'temporary-running-speed-bonus',
|
||||
name_label = 'Temporary running speed bonus',
|
||||
type = 'temporary-buff',
|
||||
description = 'Increases running speed by one level for a short period',
|
||||
sprite = 'technology/exoskeleton-equipment',
|
||||
stack_limit = 1,
|
||||
price = 10,
|
||||
},
|
||||
{
|
||||
price = {{market_item, 10}},
|
||||
offer = {type = 'nothing', effect_description = 'Temporary mining bonus \nIncreases manual mining speed by one level \nfor a short period \n\nPrice: 10 ' .. market_item..'s'}
|
||||
name = 'temporary-mining-speed-bonus',
|
||||
name_label = 'Temporary mining speed bonus',
|
||||
type = 'temporary-buff',
|
||||
description = 'Increases manual mining speed by one level for a short period',
|
||||
sprite = 'technology/mining-productivity-1',
|
||||
stack_limit = 1,
|
||||
price = 10,
|
||||
},
|
||||
{price = {{market_item, 2}}, offer = {type = 'give-item', item = 'raw-fish'}},
|
||||
{price = {{market_item, 1}}, offer = {type = 'give-item', item = 'rail', count = 2}},
|
||||
{price = {{market_item, 2}}, offer = {type = 'give-item', item = 'rail-signal'}},
|
||||
{price = {{market_item, 2}}, offer = {type = 'give-item', item = 'rail-chain-signal'}},
|
||||
{price = {{market_item, 15}}, offer = {type = 'give-item', item = 'train-stop'}},
|
||||
{price = {{market_item, 75}}, offer = {type = 'give-item', item = 'locomotive'}},
|
||||
{price = {{market_item, 30}}, offer = {type = 'give-item', item = 'cargo-wagon'}},
|
||||
{price = {{market_item, 1}}, offer = {type = 'give-item', item = 'red-wire', count = 2}},
|
||||
{price = {{market_item, 1}}, offer = {type = 'give-item', item = 'green-wire', count = 2}},
|
||||
{price = {{market_item, 3}}, offer = {type = 'give-item', item = 'decider-combinator'}},
|
||||
{price = {{market_item, 3}}, offer = {type = 'give-item', item = 'arithmetic-combinator'}},
|
||||
{price = {{market_item, 3}}, offer = {type = 'give-item', item = 'constant-combinator'}},
|
||||
{price = {{market_item, 7}}, offer = {type = 'give-item', item = 'programmable-speaker'}},
|
||||
{price = {{market_item, 15}}, offer = {type = 'give-item', item = 'steel-axe'}},
|
||||
{price = {{market_item, 15}}, offer = {type = 'give-item', item = 'submachine-gun'}},
|
||||
{price = {{market_item, 15}}, offer = {type = 'give-item', item = 'shotgun'}},
|
||||
{price = {{market_item, 250}}, offer = {type = 'give-item', item = 'combat-shotgun'}},
|
||||
{price = {{market_item, 25}}, offer = {type = 'give-item', item = 'railgun'}},
|
||||
{price = {{market_item, 250}}, offer = {type = 'give-item', item = 'flamethrower'}},
|
||||
{price = {{market_item, 175}}, offer = {type = 'give-item', item = 'rocket-launcher'}},
|
||||
{price = {{market_item, 250}}, offer = {type = 'give-item', item = 'tank-cannon'}},
|
||||
{price = {{market_item, 750}}, offer = {type = 'give-item', item = 'tank-machine-gun'}},
|
||||
{price = {{market_item, 75}}, offer = {type = 'give-item', item = 'tank-flamethrower'}},
|
||||
{price = {{market_item, 2500}}, offer = {type = 'give-item', item = 'artillery-wagon-cannon'}},
|
||||
{price = {{market_item, 1}}, offer = {type = 'give-item', item = 'firearm-magazine'}},
|
||||
{price = {{market_item, 5}}, offer = {type = 'give-item', item = 'piercing-rounds-magazine'}},
|
||||
{price = {{market_item, 20}}, offer = {type = 'give-item', item = 'uranium-rounds-magazine'}},
|
||||
{price = {{market_item, 2}}, offer = {type = 'give-item', item = 'shotgun-shell'}},
|
||||
{price = {{market_item, 10}}, offer = {type = 'give-item', item = 'piercing-shotgun-shell'}},
|
||||
{price = {{market_item, 5}}, offer = {type = 'give-item', item = 'railgun-dart'}},
|
||||
{price = {{market_item, 25}}, offer = {type = 'give-item', item = 'flamethrower-ammo'}},
|
||||
{price = {{market_item, 15}}, offer = {type = 'give-item', item = 'rocket'}},
|
||||
{price = {{market_item, 25}}, offer = {type = 'give-item', item = 'explosive-rocket'}},
|
||||
{price = {{market_item, 2500}}, offer = {type = 'give-item', item = 'atomic-bomb'}},
|
||||
{price = {{market_item, 20}}, offer = {type = 'give-item', item = 'cannon-shell'}},
|
||||
{price = {{market_item, 30}}, offer = {type = 'give-item', item = 'explosive-cannon-shell'}},
|
||||
{price = {{market_item, 75}}, offer = {type = 'give-item', item = 'explosive-uranium-cannon-shell'}},
|
||||
{price = {{market_item, 100}}, offer = {type = 'give-item', item = 'artillery-shell'}},
|
||||
{price = {{market_item, 3}}, offer = {type = 'give-item', item = 'land-mine'}},
|
||||
{price = {{market_item, 5}}, offer = {type = 'give-item', item = 'grenade'}},
|
||||
{price = {{market_item, 35}}, offer = {type = 'give-item', item = 'cluster-grenade'}},
|
||||
{price = {{market_item, 5}}, offer = {type = 'give-item', item = 'defender-capsule'}},
|
||||
--{price = {{market_item, 15}}, offer = {type = 'give-item', item = 'distractor-capsule'}}, Removed so we dont have 51 items and they are useless anyways
|
||||
{price = {{market_item, 75}}, offer = {type = 'give-item', item = 'destroyer-capsule'}},
|
||||
{price = {{market_item, 35}}, offer = {type = 'give-item', item = 'poison-capsule'}},
|
||||
{price = {{market_item, 35}}, offer = {type = 'give-item', item = 'slowdown-capsule'}},
|
||||
{price = {{market_item, 50}}, offer = {type = 'give-item', item = 'artillery-targeting-remote'}},
|
||||
{price = {{market_item, 1000}}, offer = {type = 'give-item', item = 'artillery-turret'}},
|
||||
{price = {{market_item, 350}}, offer = {type = 'give-item', item = 'modular-armor'}},
|
||||
{price = {{market_item, 875}}, offer = {type = 'give-item', item = 'power-armor'}},
|
||||
{price = {{market_item, 40}}, offer = {type = 'give-item', item = 'solar-panel-equipment'}},
|
||||
{price = {{market_item, 875}}, offer = {type = 'give-item', item = 'fusion-reactor-equipment'}},
|
||||
{price = {{market_item, 100}}, offer = {type = 'give-item', item = 'battery-equipment'}},
|
||||
{price = {{market_item, 625}}, offer = {type = 'give-item', item = 'battery-mk2-equipment'}},
|
||||
{price = {{market_item, 250}}, offer = {type = 'give-item', item = 'belt-immunity-equipment'}},
|
||||
{price = {{market_item, 100}}, offer = {type = 'give-item', item = 'night-vision-equipment'}},
|
||||
{price = {{market_item, 150}}, offer = {type = 'give-item', item = 'exoskeleton-equipment'}},
|
||||
{price = {{market_item, 250}}, offer = {type = 'give-item', item = 'personal-roboport-equipment'}},
|
||||
{price = {{market_item, 25}}, offer = {type = 'give-item', item = 'construction-robot'}},
|
||||
{price = {{market_item, 350}}, offer = {type = 'give-item', item = 'energy-shield-equipment'}},
|
||||
{price = {{market_item, 750}}, offer = {type = 'give-item', item = 'personal-laser-defense-equipment'}},
|
||||
{price = {{market_item, 1}}, offer = {type = 'give-item', item = 'refined-hazard-concrete'}},
|
||||
{price = {{market_item, 75}}, offer = {type = 'give-item', item = 'loader'}},
|
||||
{price = {{market_item, 150}}, offer = {type = 'give-item', item = 'fast-loader'}},
|
||||
{price = {{market_item, 225}}, offer = {type = 'give-item', item = 'express-loader'}}
|
||||
--[[ {price = {{market_item, 5}}, offer = {type = 'give-item', item = 'science-pack-1'}},
|
||||
{price = {{market_item, 10}}, offer = {type = 'give-item', item = 'science-pack-2'}},
|
||||
{price = {{market_item, 15}}, offer = {type = 'give-item', item = 'science-pack-3'}},
|
||||
{price = {{market_item, 15}}, offer = {type = 'give-item', item = 'military-science-pack'}},
|
||||
{price = {{market_item, 20}}, offer = {type = 'give-item', item = 'production-science-pack'}},
|
||||
{price = {{market_item, 25}}, offer = {type = 'give-item', item = 'high-tech-science-pack'}}, ]]
|
||||
|
||||
|
||||
--[[ {price = {{market_item, 3}}, offer = {type = 'give-item', item = 'piercing-rounds-magazine'}},
|
||||
{price = {{market_item, 2}}, offer = {type = 'give-item', item = 'grenade'}},
|
||||
{price = {{market_item, 1}}, offer = {type = 'give-item', item = 'land-mine'}},
|
||||
{price = {{market_item, 1}}, offer = {type = 'give-item', item = 'solid-fuel'}},
|
||||
{price = {{market_item, 15}}, offer = {type = 'give-item', item = 'steel-axe'}},
|
||||
{price = {{market_item, 125}}, offer = {type = 'give-item', item = 'rocket-launcher'}},
|
||||
{price = {{market_item, 15}}, offer = {type = 'give-item', item = 'rocket'}},
|
||||
{price = {{market_item, 20}}, offer = {type = 'give-item', item = 'explosive-rocket'}},
|
||||
{price = {{market_item, 2500}}, offer = {type = 'give-item', item = 'atomic-bomb'}},
|
||||
{price = {{market_item, 25}}, offer = {type = 'give-item', item = 'railgun'}},
|
||||
{price = {{market_item, 10}}, offer = {type = 'give-item', item = 'railgun-dart', count = 10}},
|
||||
{price = {{market_item, 100}}, offer = {type = 'give-item', item = 'loader'}},
|
||||
{price = {{market_item, 175}}, offer = {type = 'give-item', item = 'fast-loader'}},
|
||||
{price = {{market_item, 250}}, offer = {type = 'give-item', item = 'express-loader'}},
|
||||
{price = {{market_item, 500}}, offer = {type = 'give-item', item = 'belt-immunity-equipment'}},
|
||||
{price = {{market_item, 100}}, offer = {type = 'give-item', item = 'night-vision-equipment'}},
|
||||
{price = {{market_item, 200}}, offer = {type = 'give-item', item = 'modular-armor'}},
|
||||
{price = {{market_item, 500}}, offer = {type = 'give-item', item = 'power-armor'}},
|
||||
{price = {{market_item, 150}}, offer = {type = 'give-item', item = 'personal-roboport-equipment'}},
|
||||
{price = {{market_item, 50}}, offer = {type = 'give-item', item = 'construction-robot', count = 10}},
|
||||
{price = {{market_item, 50}}, offer = {type = 'give-item', item = 'solar-panel-equipment', count = 1}},
|
||||
{price = {{market_item, 50}}, offer = {type = 'give-item', item = 'battery-equipment', count = 1}},
|
||||
{price = {{market_item, 750}}, offer = {type = 'give-item', item = 'battery-mk2-equipment', count = 1}},
|
||||
{price = {{market_item, 1000}}, offer = {type = 'give-item', item = 'fusion-reactor-equipment', count = 1}},
|
||||
{price = {{market_item, 100}}, offer = {type = 'give-item', item = 'exoskeleton-equipment'}} ]]
|
||||
{price = 2, name = 'raw-fish'},
|
||||
{price = 0.95, name = 'rail'},
|
||||
{price = 2, name = 'rail-signal'},
|
||||
{price = 2, name = 'rail-chain-signal'},
|
||||
{price = 15, name = 'train-stop'},
|
||||
{price = 75, name = 'locomotive'},
|
||||
{price = 30, name = 'cargo-wagon'},
|
||||
{price = 0.95, name = 'red-wire'},
|
||||
{price = 0.95, name = 'green-wire'},
|
||||
{price = 3, name = 'decider-combinator'},
|
||||
{price = 3, name = 'arithmetic-combinator'},
|
||||
{price = 3, name = 'constant-combinator'},
|
||||
{price = 7, name = 'programmable-speaker'},
|
||||
{price = 15, name = 'steel-axe'},
|
||||
{price = 15, name = 'submachine-gun'},
|
||||
{price = 15, name = 'shotgun'},
|
||||
{price = 250, name = 'combat-shotgun'},
|
||||
{price = 25, name = 'railgun'},
|
||||
{price = 250, name = 'flamethrower'},
|
||||
{price = 175, name = 'rocket-launcher'},
|
||||
{price = 250, name = 'tank-cannon'},
|
||||
{price = 750, name = 'tank-machine-gun'},
|
||||
{price = 75, name = 'tank-flamethrower'},
|
||||
{price = 2500, name = 'artillery-wagon-cannon'},
|
||||
{price = 1, name = 'firearm-magazine'},
|
||||
{price = 5, name = 'piercing-rounds-magazine'},
|
||||
{price = 20, name = 'uranium-rounds-magazine'},
|
||||
{price = 2, name = 'shotgun-shell'},
|
||||
{price = 10, name = 'piercing-shotgun-shell'},
|
||||
{price = 5, name = 'railgun-dart'},
|
||||
{price = 25, name = 'flamethrower-ammo'},
|
||||
{price = 15, name = 'rocket'},
|
||||
{price = 25, name = 'explosive-rocket'},
|
||||
{price = 2500, name = 'atomic-bomb'},
|
||||
{price = 20, name = 'cannon-shell'},
|
||||
{price = 30, name = 'explosive-cannon-shell'},
|
||||
{price = 75, name = 'explosive-uranium-cannon-shell'},
|
||||
{price = 100, name = 'artillery-shell'},
|
||||
{price = 3, name = 'land-mine'},
|
||||
{price = 5, name = 'grenade'},
|
||||
{price = 35, name = 'cluster-grenade'},
|
||||
{price = 5, name = 'defender-capsule'},
|
||||
{price = 75, name = 'destroyer-capsule'},
|
||||
{price = 35, name = 'poison-capsule'},
|
||||
{price = 35, name = 'slowdown-capsule'},
|
||||
{price = 50, name = 'artillery-targeting-remote'},
|
||||
{price = 1000, name = 'artillery-turret'},
|
||||
{price = 350, name = 'modular-armor'},
|
||||
{price = 875, name = 'power-armor'},
|
||||
{price = 40, name = 'solar-panel-equipment'},
|
||||
{price = 875, name = 'fusion-reactor-equipment'},
|
||||
{price = 100, name = 'battery-equipment'},
|
||||
{price = 625, name = 'battery-mk2-equipment'},
|
||||
{price = 250, name = 'belt-immunity-equipment'},
|
||||
{price = 100, name = 'night-vision-equipment'},
|
||||
{price = 150, name = 'exoskeleton-equipment'},
|
||||
{price = 250, name = 'personal-roboport-equipment'},
|
||||
{price = 25, name = 'construction-robot'},
|
||||
{price = 350, name = 'energy-shield-equipment'},
|
||||
{price = 750, name = 'personal-laser-defense-equipment'},
|
||||
{price = 1, name = 'refined-hazard-concrete'},
|
||||
{price = 75, name = 'loader'},
|
||||
{price = 150, name = 'fast-loader'},
|
||||
{price = 225, name = 'express-loader'},
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user