You've already forked ComfyFactorio
mirror of
https://github.com/ComfyFactory/ComfyFactorio.git
synced 2026-04-26 21:02:59 +02:00
936 lines
27 KiB
Lua
936 lines
27 KiB
Lua
-- This file is part of thesixthroc's Pirate Ship softmod, licensed under GPLv3 and stored at https://github.com/ComfyFactory/ComfyFactorio and https://github.com/danielmartin0/ComfyFactorio-Pirates.
|
|
|
|
local Memory = require("maps.pirates.memory")
|
|
local Common = require("maps.pirates.common")
|
|
local CoreData = require("maps.pirates.coredata")
|
|
-- local Utils = require 'maps.pirates.utils_local'
|
|
local Math = require("maps.pirates.math")
|
|
-- local Surfaces = require 'maps.pirates.surfaces.surfaces'
|
|
local Roles = require("maps.pirates.roles.roles")
|
|
local Crew = require("maps.pirates.crew")
|
|
local Progression = require("maps.pirates.progression")
|
|
-- local Structures = require 'maps.pirates.structures.structures'
|
|
local _inspect = require("utils.inspect").inspect
|
|
local Boats = require("maps.pirates.structures.boats.boats")
|
|
local GuiCommon = require("maps.pirates.gui.common")
|
|
-- local Server = require 'utils.server'
|
|
local Public = {}
|
|
|
|
local window_name = "runs"
|
|
|
|
local function flow_add_proposal_slider(flow, name, displayname, indices_count, starting_index, tooltip)
|
|
local flow2, flow3, flow4
|
|
|
|
flow2 = flow.add({
|
|
name = name,
|
|
type = "flow",
|
|
direction = "vertical",
|
|
})
|
|
flow2.style.horizontal_align = "left"
|
|
flow2.style.width = 130
|
|
|
|
flow3 = flow2.add({
|
|
type = "label",
|
|
caption = displayname,
|
|
})
|
|
flow3.style.font = "default-semibold"
|
|
flow3.style.height = 20
|
|
flow3.style.margin = 0
|
|
flow3.style.padding = 0
|
|
flow3.style.top_padding = -4
|
|
flow3.style.bottom_margin = 0
|
|
flow3.style.font_color = GuiCommon.subsection_header_font_color
|
|
flow3.tooltip = tooltip
|
|
|
|
flow3 = flow2.add({
|
|
name = name,
|
|
type = "flow",
|
|
direction = "vertical",
|
|
})
|
|
flow3.style.horizontal_align = "center"
|
|
flow3.style.width = 130
|
|
|
|
flow4 = flow3.add({
|
|
name = "slider",
|
|
type = "slider",
|
|
value_step = 1,
|
|
minimum_value = 1,
|
|
maximum_value = indices_count,
|
|
value = starting_index,
|
|
discrete_values = true,
|
|
discrete_slider = true,
|
|
})
|
|
flow4.style.width = 100
|
|
flow4.style.margin = 0
|
|
flow4.tooltip = tooltip
|
|
|
|
flow4 = flow3.add({
|
|
name = "readoff_text",
|
|
type = "label",
|
|
caption = "",
|
|
})
|
|
flow4.style.font = "default-listbox"
|
|
flow4.style.height = 20
|
|
flow4.style.margin = 0
|
|
flow4.style.padding = 0
|
|
flow4.style.top_padding = 0
|
|
flow4.style.bottom_margin = 16
|
|
flow4.tooltip = tooltip
|
|
|
|
flow2 = flow.add({
|
|
name = name .. "_readoff_icon",
|
|
type = "sprite-button",
|
|
enabled = false,
|
|
})
|
|
flow2.style.width = 48
|
|
flow2.style.height = 48
|
|
flow2.tooltip = tooltip
|
|
|
|
return flow2
|
|
end
|
|
|
|
-- commented out for luacheck:
|
|
-- local function flow_add_proposal_switch(flow, name, displayname, starting_position, tooltip)
|
|
-- local flow2, flow3, flow4
|
|
|
|
-- flow2 = flow.add({
|
|
-- name = name,
|
|
-- type = 'flow',
|
|
-- direction = 'vertical',
|
|
-- })
|
|
-- flow2.style.horizontal_align = 'left'
|
|
-- flow2.style.width = 130
|
|
|
|
-- flow3 = flow2.add({
|
|
-- type = 'label',
|
|
-- caption = displayname,
|
|
-- })
|
|
-- flow3.style.font = 'default-semibold'
|
|
-- flow3.style.height = 20
|
|
-- flow3.style.margin = 0
|
|
-- flow3.style.padding = 0
|
|
-- flow3.style.top_padding = -4
|
|
-- flow3.style.bottom_margin = 0
|
|
-- flow3.style.font_color = GuiCommon.subsection_header_font_color
|
|
-- flow3.tooltip = tooltip
|
|
|
|
-- flow3 = flow2.add({
|
|
-- name = name,
|
|
-- type = 'flow',
|
|
-- direction = 'vertical',
|
|
-- })
|
|
-- flow3.style.horizontal_align = 'center'
|
|
-- flow3.style.width = 130
|
|
|
|
-- flow4 = flow3.add({
|
|
-- name = 'switch',
|
|
-- type = 'switch',
|
|
-- switch_state = starting_position,
|
|
-- })
|
|
-- -- flow4.style.width = 80
|
|
-- -- flow4.style.height = 40
|
|
-- flow4.style.margin = 0
|
|
-- flow4.tooltip = tooltip
|
|
|
|
-- flow4 = flow3.add({
|
|
-- name = 'readoff_text',
|
|
-- type = 'label',
|
|
-- caption = '',
|
|
-- })
|
|
-- flow4.style.font = 'default-listbox'
|
|
-- flow4.style.height = 20
|
|
-- flow4.style.margin = 0
|
|
-- flow4.style.padding = 0
|
|
-- flow4.style.top_padding = 0
|
|
-- flow4.style.bottom_margin = 16
|
|
-- flow4.tooltip = tooltip
|
|
|
|
-- flow2 = flow.add({
|
|
-- name = name .. '_readoff_icon',
|
|
-- type = 'sprite-button',
|
|
-- enabled = false,
|
|
-- })
|
|
-- flow2.style.width = 48
|
|
-- flow2.style.height = 48
|
|
-- flow2.tooltip = tooltip
|
|
|
|
-- return flow2
|
|
-- end
|
|
|
|
function Public.toggle_window(player)
|
|
local window
|
|
local flow, flow2, flow3, flow4, flow5, flow6
|
|
|
|
--*** OVERALL FLOW ***--
|
|
if player.gui.screen[window_name .. "_piratewindow"] then
|
|
player.gui.screen[window_name .. "_piratewindow"].destroy()
|
|
return
|
|
end
|
|
|
|
window = GuiCommon.new_window(player, window_name)
|
|
window.caption = { "pirates.gui_runs_play" }
|
|
|
|
flow = window.add({
|
|
type = "scroll-pane",
|
|
name = "scroll_pane",
|
|
direction = "vertical",
|
|
horizontal_scroll_policy = "never",
|
|
vertical_scroll_policy = "auto-and-reserve-space",
|
|
})
|
|
flow.style.maximal_height = 500
|
|
flow.style.bottom_margin = 10
|
|
|
|
--*** ONGOING RUNS ***--
|
|
|
|
flow2 = GuiCommon.flow_add_section(flow, "ongoing_runs", { "pirates.gui_runs_ongoing_runs" })
|
|
|
|
flow3 = flow2.add({
|
|
name = "helpful_tip",
|
|
type = "label",
|
|
caption = { "pirates.gui_runs_ongoing_runs_helpful_tip" },
|
|
})
|
|
flow3.style.font_color = { r = 0.90, g = 0.90, b = 0.90 }
|
|
flow3.style.single_line = false
|
|
flow3.style.maximal_width = 160
|
|
|
|
flow3 = flow2.add({
|
|
name = "ongoing_runs_listbox",
|
|
type = "list-box",
|
|
})
|
|
flow3.style.margin = 2
|
|
flow3.style.right_margin = 5
|
|
flow3.style.horizontally_stretchable = true
|
|
|
|
flow3 = flow2.add({
|
|
name = "join_protected_crew_info",
|
|
type = "label",
|
|
caption = { "pirates.gui_join_protected_run_info" },
|
|
visible = false,
|
|
})
|
|
flow3.style.single_line = false
|
|
|
|
flow3 = flow2.add({
|
|
name = "join_private_crew_info",
|
|
type = "label",
|
|
caption = { "pirates.gui_join_private_run_info" },
|
|
visible = false,
|
|
})
|
|
flow3.style.single_line = false
|
|
|
|
flow3 = flow2.add({
|
|
name = "password",
|
|
type = "textfield",
|
|
text = "",
|
|
visible = false,
|
|
})
|
|
flow3.style.width = 150
|
|
flow3.style.height = 24
|
|
flow3.style.top_margin = -3
|
|
flow3.style.bottom_margin = 3
|
|
|
|
flow3 = flow2.add({
|
|
name = "flow_buttons",
|
|
type = "flow",
|
|
direction = "horizontal",
|
|
})
|
|
|
|
flow4 = flow3.add({
|
|
name = "join_crew",
|
|
type = "button",
|
|
caption = { "pirates.gui_runs_ongoing_runs_join_crew" },
|
|
})
|
|
flow4.style.minimal_width = 95
|
|
flow4.style.font = "default-bold"
|
|
flow4.style.font_color = { r = 0.10, g = 0.10, b = 0.10 }
|
|
|
|
flow3 = flow2.add({
|
|
name = "wait_to_join",
|
|
type = "label",
|
|
})
|
|
flow3.style.left_margin = 5
|
|
|
|
flow3 = flow2.add({
|
|
name = "leaving_prompt",
|
|
type = "label",
|
|
caption = { "pirates.gui_runs_ongoing_runs_hop_on_board" },
|
|
})
|
|
flow3.style.left_margin = 5
|
|
|
|
-- PROPOSALS --
|
|
|
|
flow2 = GuiCommon.flow_add_section(flow, "proposals", { "pirates.gui_runs_proposals" })
|
|
flow2.style.horizontal_align = "center"
|
|
|
|
flow3 = flow2.add({
|
|
name = "proposals_listbox",
|
|
type = "list-box",
|
|
})
|
|
flow3.style.margin = 2
|
|
flow3.style.right_margin = 5
|
|
flow3.style.horizontally_stretchable = true
|
|
|
|
flow3 = flow2.add({
|
|
name = "flow_buttons",
|
|
type = "flow",
|
|
direction = "horizontal",
|
|
})
|
|
|
|
flow4 = flow3.add({
|
|
name = "abandon_proposal",
|
|
type = "button",
|
|
caption = { "pirates.gui_runs_proposals_abandon_proposal" },
|
|
})
|
|
flow4.style.minimal_width = 150
|
|
flow4.style.font = "default-bold"
|
|
flow4.style.font_color = { r = 0.10, g = 0.10, b = 0.10 }
|
|
flow4.style.bottom_margin = 4
|
|
flow4.style.top_margin = 4
|
|
|
|
-- PROPOSAL MAKER --
|
|
|
|
flow3 = GuiCommon.flow_add_subpanel(flow2, "proposal_maker")
|
|
|
|
flow4 = flow3.add({
|
|
name = "body",
|
|
type = "flow",
|
|
direction = "vertical",
|
|
})
|
|
flow4.style.horizontal_align = "center"
|
|
flow4.style.vertical_align = "center"
|
|
|
|
flow5 = flow4.add({
|
|
type = "label",
|
|
caption = { "pirates.gui_runs_proposal_maker_run_name" },
|
|
})
|
|
flow5.style.font = "default-semibold"
|
|
|
|
flow5 = flow4.add({
|
|
name = "namefield",
|
|
type = "textfield",
|
|
caption = { "pirates.gui_runs_proposal_maker_run_name_2" },
|
|
text = "",
|
|
})
|
|
flow5.style.width = 150
|
|
flow5.style.height = 24
|
|
flow5.style.top_margin = -3
|
|
|
|
-- CREW SETTINGS --
|
|
|
|
flow5 = flow4.add({
|
|
name = "settings",
|
|
type = "flow",
|
|
direction = "vertical",
|
|
})
|
|
flow5.style.horizontal_align = "left"
|
|
flow5.style.bottom_margin = 5
|
|
|
|
flow5.add({
|
|
name = "protected_checkbox",
|
|
type = "checkbox",
|
|
caption = { "pirates.gui_runs_proposal_maker_protected" },
|
|
state = false,
|
|
tooltip = { "pirates.gui_runs_proposal_maker_protected_tooltip" },
|
|
})
|
|
|
|
flow5.add({
|
|
name = "private_checkbox",
|
|
type = "checkbox",
|
|
caption = { "pirates.gui_runs_proposal_maker_private" },
|
|
state = false,
|
|
tooltip = { "pirates.gui_runs_proposal_maker_private_tooltip" },
|
|
})
|
|
|
|
flow5.add({
|
|
name = "blueprints_disabled_checkbox",
|
|
type = "checkbox",
|
|
caption = { "pirates.gui_runs_proposal_maker_blueprints_disabled" },
|
|
state = false,
|
|
})
|
|
|
|
flow6 = flow5.add({
|
|
name = "password_label",
|
|
type = "label",
|
|
caption = { "pirates.gui_runs_proposal_maker_password" },
|
|
})
|
|
flow6.style.font = "default-semibold"
|
|
|
|
flow6 = flow5.add({
|
|
name = "password",
|
|
type = "textfield",
|
|
text = "",
|
|
})
|
|
flow6.style.width = 150
|
|
flow6.style.height = 24
|
|
flow6.style.top_margin = -3
|
|
flow6.style.bottom_margin = 3
|
|
|
|
flow6 = flow5.add({
|
|
name = "confirm_password_label",
|
|
type = "label",
|
|
caption = { "pirates.gui_runs_proposal_maker_confirm_password" },
|
|
})
|
|
flow6.style.font = "default-semibold"
|
|
|
|
flow6 = flow5.add({
|
|
name = "confirm_password",
|
|
type = "textfield",
|
|
text = "",
|
|
})
|
|
flow6.style.width = 150
|
|
flow6.style.height = 24
|
|
flow6.style.top_margin = -3
|
|
flow6.style.bottom_margin = 3
|
|
|
|
-- CREW SIZE LIMIT SLIDER --
|
|
|
|
flow5 = flow4.add({
|
|
name = "capacity_options",
|
|
type = "table",
|
|
column_count = 2,
|
|
})
|
|
flow5.style.width = 200
|
|
flow5.style.margin = 0
|
|
|
|
flow_add_proposal_slider(
|
|
flow5,
|
|
"capacity",
|
|
{ "pirates.gui_runs_proposal_maker_capacity" },
|
|
#CoreData.capacity_options,
|
|
5,
|
|
{ "pirates.capacity_tooltip" }
|
|
)
|
|
-- flow_add_proposal_slider(flow5, 'difficulty', 'Difficulty', #CoreData.difficulty_options, 2, {'pirates.difficulty_tooltip'})
|
|
-- flow_add_proposal_switch(flow5, 'mode', 'Mode', 'left', {'pirates.mode_tooltip'})
|
|
|
|
flow5.visible = false --maybe will bring this back for the speedrun ship?
|
|
|
|
flow5 = flow4.add({
|
|
name = "propose_crew",
|
|
type = "button",
|
|
caption = { "pirates.gui_runs_proposal_maker_propose" },
|
|
})
|
|
flow5.style.minimal_width = 75
|
|
flow5.style.font = "default-bold"
|
|
flow5.style.font_color = { r = 0.10, g = 0.10, b = 0.10 }
|
|
|
|
-- LAUNCH YOUR PROPOSAL --
|
|
|
|
flow3 = flow2.add({
|
|
name = "flow_proposal_launch",
|
|
type = "flow",
|
|
direction = "vertical",
|
|
})
|
|
|
|
flow4 = flow3.add({
|
|
name = "proposal_crew_count_capped",
|
|
type = "label",
|
|
caption = { "pirates.gui_runs_launch_error_2" },
|
|
})
|
|
flow4.style.single_line = false
|
|
|
|
flow4 = flow3.add({
|
|
name = "proposal_insufficient_sloops",
|
|
type = "label",
|
|
caption = { "pirates.gui_runs_launch_error_4" },
|
|
})
|
|
flow4.style.single_line = false
|
|
|
|
flow4 = flow3.add({
|
|
name = "launch_crew",
|
|
type = "button",
|
|
caption = { "pirates.gui_runs_launch" },
|
|
})
|
|
flow4.style.minimal_width = 150
|
|
flow4.style.font = "default-bold"
|
|
flow4.style.font_color = { r = 0.10, g = 0.10, b = 0.10 }
|
|
|
|
GuiCommon.flow_add_close_button(window, window_name .. "_piratebutton")
|
|
end
|
|
|
|
-- function Public.regular_update(player)
|
|
|
|
-- end
|
|
|
|
function Public.full_update(player)
|
|
if Public.regular_update then
|
|
Public.regular_update(player)
|
|
end
|
|
local global_memory = Memory.get_global_memory()
|
|
local memory = Memory.get_crew_memory()
|
|
|
|
local window = player.gui.screen["runs_piratewindow"]
|
|
if not window then
|
|
return
|
|
end
|
|
local flow = window.scroll_pane
|
|
local playercrew_status = GuiCommon.crew_overall_state_bools(player.index)
|
|
if not playercrew_status then
|
|
return
|
|
end
|
|
|
|
local ongoing_runs = flow.ongoing_runs
|
|
ongoing_runs.visible = (#global_memory.crew_active_ids > 0)
|
|
|
|
if ongoing_runs.visible then
|
|
local wrappedmemories = {}
|
|
for _, mem in pairs(global_memory.crew_memories) do
|
|
local count = (mem.crewstatus == Crew.enum.LEAVING_INITIAL_DOCK) and Boats.players_on_boat_count(mem.boat)
|
|
or #mem.crewplayerindices
|
|
|
|
local crew_info = {
|
|
"",
|
|
"[font=scenario-message-dialog]",
|
|
mem.name .. " (",
|
|
{
|
|
"pirates.player_count_description",
|
|
count,
|
|
},
|
|
")[/font] — [item=",
|
|
CoreData.difficulty_options[mem.difficulty_option].icon,
|
|
"], [item=rail]",
|
|
mem.overworldx or 0,
|
|
", [entity=small-biter]",
|
|
string.format("%.0f", (mem.evolution_factor or 0) * 100),
|
|
"%",
|
|
}
|
|
|
|
if mem.run_is_private then
|
|
table.insert(crew_info, ", ")
|
|
table.insert(crew_info, { "pirates.run_condition_private_2" })
|
|
end
|
|
if mem.run_is_protected then
|
|
table.insert(crew_info, ", ")
|
|
table.insert(crew_info, { "pirates.run_condition_captain_protected_2" })
|
|
end
|
|
if mem.run_has_blueprints_disabled then
|
|
table.insert(crew_info, ", ")
|
|
table.insert(crew_info, { "pirates.run_condition_blueprints_disabled_2" })
|
|
end
|
|
|
|
local crew_info_with_id = {
|
|
"pirates.second_element",
|
|
mem.id,
|
|
crew_info,
|
|
}
|
|
|
|
table.insert(wrappedmemories, crew_info_with_id)
|
|
end
|
|
GuiCommon.update_listbox(ongoing_runs.body.ongoing_runs_listbox, wrappedmemories)
|
|
|
|
local selected_index = ongoing_runs.body.ongoing_runs_listbox.selected_index
|
|
local selected_crew = selected_index ~= 0
|
|
and global_memory.crew_memories[tonumber(ongoing_runs.body.ongoing_runs_listbox.get_item(selected_index)[2])]
|
|
|
|
if playercrew_status.leaving or playercrew_status.adventuring then
|
|
selected_crew = false
|
|
end
|
|
|
|
local can_join = selected_crew and selected_crew.crewstatus == Crew.enum.ADVENTURING
|
|
|
|
ongoing_runs.body.helpful_tip.visible = not (playercrew_status.leaving or playercrew_status.adventuring)
|
|
ongoing_runs.body.flow_buttons.visible = can_join
|
|
ongoing_runs.body.flow_buttons.join_crew.visible = can_join
|
|
and selected_crew
|
|
and not (
|
|
selected_crew.crewstatus == Crew.enum.LEAVING_INITIAL_DOCK
|
|
or #selected_crew.crewplayerindices >= selected_crew.capacity
|
|
or (
|
|
selected_crew.tempbanned_from_joining_data
|
|
and selected_crew.tempbanned_from_joining_data[player.index]
|
|
and game.tick
|
|
< selected_crew.tempbanned_from_joining_data[player.index] + Common.ban_from_rejoining_crew_ticks
|
|
)
|
|
)
|
|
|
|
local show_wait_message = can_join
|
|
and selected_crew
|
|
and selected_crew.tempbanned_from_joining_data
|
|
and selected_crew.tempbanned_from_joining_data[player.index]
|
|
and game.tick
|
|
< selected_crew.tempbanned_from_joining_data[player.index] + Common.ban_from_rejoining_crew_ticks
|
|
ongoing_runs.body.wait_to_join.visible = show_wait_message and true or false
|
|
|
|
if show_wait_message then
|
|
local wait_time = selected_crew
|
|
and Math.ceil(
|
|
(
|
|
selected_crew.tempbanned_from_joining_data[player.index]
|
|
- (game.tick - Common.ban_from_rejoining_crew_ticks)
|
|
) / 60
|
|
)
|
|
or 0
|
|
ongoing_runs.body.wait_to_join.caption = { "pirates.gui_runs_wait_to_join", tostring(wait_time) }
|
|
end
|
|
|
|
ongoing_runs.body.leaving_prompt.visible = playercrew_status.leaving
|
|
ongoing_runs.body.join_protected_crew_info.visible = selected_crew and selected_crew.run_is_protected
|
|
ongoing_runs.body.join_private_crew_info.visible = selected_crew and selected_crew.run_is_private
|
|
ongoing_runs.body.password.visible = selected_crew and selected_crew.run_is_private
|
|
|
|
if selected_crew then
|
|
if ongoing_runs.body.join_protected_crew_info.visible then
|
|
ongoing_runs.body.join_protected_crew_info.caption = { "pirates.gui_join_protected_run_info" }
|
|
end
|
|
if ongoing_runs.body.join_private_crew_info.visible then
|
|
ongoing_runs.body.join_private_crew_info.caption = { "pirates.gui_join_private_run_info" }
|
|
end
|
|
end
|
|
end
|
|
|
|
local proposals = flow.proposals
|
|
proposals.visible = (memory.crewstatus == nil and not playercrew_status.leaving)
|
|
|
|
if proposals.visible then
|
|
local wrappedproposals = {}
|
|
for _, proposal in pairs(global_memory.crewproposals) do
|
|
local proposal_info = {
|
|
"",
|
|
"[font=scenario-message-dialog]",
|
|
proposal.name .. "[/font]",
|
|
}
|
|
if proposal.run_is_private or proposal.run_is_protected or proposal.run_has_blueprints_disabled then
|
|
local i = 0
|
|
table.insert(proposal_info, " — ")
|
|
if proposal.run_is_private then
|
|
table.insert(proposal_info, { "pirates.run_condition_private_2" })
|
|
i = i + 1
|
|
end
|
|
if proposal.run_is_protected then
|
|
if i > 0 then
|
|
table.insert(proposal_info, ", ")
|
|
end
|
|
table.insert(proposal_info, { "pirates.run_condition_captain_protected_2" })
|
|
i = i + 1
|
|
end
|
|
if proposal.run_has_blueprints_disabled then
|
|
if i > 0 then
|
|
table.insert(proposal_info, ", ")
|
|
end
|
|
table.insert(proposal_info, { "pirates.run_condition_blueprints_disabled_2" })
|
|
-- i = i + 1
|
|
end
|
|
end
|
|
table.insert(wrappedproposals, proposal_info)
|
|
end
|
|
GuiCommon.update_listbox(proposals.body.proposals_listbox, wrappedproposals)
|
|
|
|
proposals.body.proposals_listbox.visible = not playercrew_status.leaving and #global_memory.crewproposals > 0
|
|
proposals.body.flow_buttons.abandon_proposal.visible = not playercrew_status.leaving
|
|
and playercrew_status.created_crew
|
|
and playercrew_status.proposing
|
|
and #global_memory.crewproposals > 0
|
|
proposals.body.proposal_maker.visible = not playercrew_status.leaving and not playercrew_status.created_crew
|
|
proposals.body.flow_proposal_launch.proposal_insufficient_sloops.visible = playercrew_status.sloops_full
|
|
proposals.body.flow_proposal_launch.proposal_crew_count_capped.visible = playercrew_status.crew_count_capped
|
|
proposals.body.flow_proposal_launch.launch_crew.visible = playercrew_status.proposal_can_launch
|
|
|
|
if proposals.body.proposal_maker.visible then
|
|
local capacity_slider = proposals.body.proposal_maker.body.capacity_options.capacity.capacity
|
|
local capacity_option = CoreData.capacity_options[capacity_slider.slider.slider_value]
|
|
capacity_slider.readoff_text.caption = capacity_option.text == "∞"
|
|
and { "pirates.gui_runs_proposal_maker_no_limit" }
|
|
or capacity_option.text
|
|
proposals.body.proposal_maker.body.capacity_options.capacity_readoff_icon.sprite = capacity_option.icon
|
|
|
|
local is_private = proposals.body.proposal_maker.body.settings.private_checkbox.state
|
|
proposals.body.proposal_maker.body.settings.password_label.visible = is_private
|
|
proposals.body.proposal_maker.body.settings.password.visible = is_private
|
|
proposals.body.proposal_maker.body.settings.confirm_password_label.visible = is_private
|
|
proposals.body.proposal_maker.body.settings.confirm_password.visible = is_private
|
|
end
|
|
end
|
|
end
|
|
|
|
function Public.click(event)
|
|
if not event.element then
|
|
return
|
|
end
|
|
if not event.element.valid then
|
|
return
|
|
end
|
|
|
|
local player = game.players[event.element.player_index]
|
|
|
|
local eventname = event.element.name
|
|
|
|
if not player.gui.screen[window_name .. "_piratewindow"] then
|
|
return
|
|
end
|
|
local flow = player.gui.screen[window_name .. "_piratewindow"].scroll_pane
|
|
|
|
local global_memory = Memory.get_global_memory()
|
|
-- local memory = Memory.get_crew_memory()
|
|
|
|
if eventname == "join_crew" then
|
|
local listbox = flow.ongoing_runs.body.ongoing_runs_listbox
|
|
|
|
-- It was observed that "listbox.get_item(listbox.selected_index)" can produce "Index out of range error"
|
|
-- This is to prevent that error.
|
|
if listbox.selected_index >= 1 and listbox.selected_index <= #listbox.items then
|
|
local crewid = tonumber(listbox.get_item(listbox.selected_index)[2])
|
|
|
|
Memory.set_working_id(crewid)
|
|
local memory = Memory.get_crew_memory()
|
|
|
|
-- If run is private
|
|
if memory.run_is_private then
|
|
if memory.private_run_password == flow.ongoing_runs.body.password.text then
|
|
Crew.join_crew(player)
|
|
flow.ongoing_runs.body.join_private_crew_info.visible = false
|
|
flow.ongoing_runs.body.password.visible = false
|
|
|
|
if memory.run_is_protected and (not Roles.captain_exists()) then
|
|
Common.notify_player_expected(player, { "pirates.player_joins_protected_run_with_no_captain" })
|
|
Common.notify_player_expected(player, { "pirates.create_new_crew_tip" })
|
|
end
|
|
else
|
|
Common.notify_player_error(player, { "pirates.gui_join_private_run_error_wrong_password" })
|
|
end
|
|
else
|
|
Crew.join_crew(player)
|
|
|
|
if memory.run_is_protected and (not Roles.captain_exists()) then
|
|
Common.notify_player_expected(player, { "pirates.player_joins_protected_run_with_no_captain" })
|
|
Common.notify_player_expected(player, { "pirates.create_new_crew_tip" })
|
|
end
|
|
end
|
|
|
|
return
|
|
end
|
|
end
|
|
|
|
if eventname == "propose_crew" then
|
|
if #global_memory.crew_active_ids >= global_memory.active_crews_cap_in_memory then
|
|
Common.notify_player_error(player, { "pirates.gui_runs_launch_error_5" })
|
|
return
|
|
end
|
|
|
|
-- Count private runs
|
|
local private_run_count = 0
|
|
for _, id in pairs(global_memory.crew_active_ids) do
|
|
if global_memory.crew_memories[id].run_is_private then
|
|
private_run_count = private_run_count + 1
|
|
end
|
|
end
|
|
|
|
-- Count protected but not private runs
|
|
local protected_but_not_private_run_count = 0
|
|
for _, id in pairs(global_memory.crew_active_ids) do
|
|
if
|
|
global_memory.crew_memories[id].run_is_protected
|
|
and not global_memory.crew_memories[id].run_is_private
|
|
then
|
|
protected_but_not_private_run_count = protected_but_not_private_run_count + 1
|
|
end
|
|
end
|
|
|
|
local run_has_blueprints_disabled =
|
|
flow.proposals.body.proposal_maker.body.settings.blueprints_disabled_checkbox.state
|
|
local run_is_protected = flow.proposals.body.proposal_maker.body.settings.protected_checkbox.state
|
|
local run_is_private = flow.proposals.body.proposal_maker.body.settings.private_checkbox.state
|
|
if run_is_private then
|
|
-- Make sure private run can be created
|
|
if private_run_count >= global_memory.private_run_cap then
|
|
Common.notify_player_error(player, { "pirates.gui_runs_proposal_maker_error_private_run_limit" })
|
|
return
|
|
end
|
|
|
|
-- check if the player created any other private runs
|
|
for _, id in pairs(global_memory.crew_active_ids) do
|
|
if
|
|
global_memory.crew_memories[id].run_is_private
|
|
and global_memory.crew_memories[id].created_by_player == player.index
|
|
then
|
|
Common.notify_player_error(player, { "pirates.gui_runs_proposal_maker_error_two_private_runs" })
|
|
return
|
|
end
|
|
end
|
|
|
|
-- Check if passwords match
|
|
if
|
|
flow.proposals.body.proposal_maker.body.settings.password.text
|
|
~= flow.proposals.body.proposal_maker.body.settings.confirm_password.text
|
|
then
|
|
Common.notify_player_error(
|
|
player,
|
|
{ "pirates.gui_runs_proposal_maker_error_private_run_password_no_match" }
|
|
)
|
|
return
|
|
end
|
|
|
|
-- Check if passwords aren't empty
|
|
if flow.proposals.body.proposal_maker.body.settings.password.text == "" then
|
|
Common.notify_player_error(
|
|
player,
|
|
{ "pirates.gui_runs_proposal_maker_error_private_run_password_empty" }
|
|
)
|
|
return
|
|
end
|
|
elseif run_is_protected then
|
|
-- Make sure protected run can be created
|
|
if protected_but_not_private_run_count >= global_memory.protected_but_not_private_run_cap then
|
|
Common.notify_player_error(player, { "pirates.gui_runs_proposal_maker_error_protected_run_limit" })
|
|
return
|
|
end
|
|
|
|
-- check if the player created any other protected runs
|
|
for _, id in pairs(global_memory.crew_active_ids) do
|
|
if
|
|
global_memory.crew_memories[id].run_is_protected
|
|
and global_memory.crew_memories[id].created_by_player == player.index
|
|
then
|
|
Common.notify_player_error(player, { "pirates.gui_runs_proposal_maker_error_two_protected_runs" })
|
|
return
|
|
end
|
|
end
|
|
end
|
|
|
|
-- Check if they created at least two other runs
|
|
local player_run_count = 0
|
|
for _, id in pairs(global_memory.crew_active_ids) do
|
|
if global_memory.crew_memories[id].created_by_player == player.index then
|
|
player_run_count = player_run_count + 1
|
|
end
|
|
end
|
|
if player_run_count >= 2 then
|
|
Common.notify_player_error(player, { "pirates.gui_runs_proposal_maker_error_three_runs" })
|
|
return
|
|
end
|
|
|
|
local private_run_password = flow.proposals.body.proposal_maker.body.settings.password.text
|
|
local proposal_name = flow.proposals.body.proposal_maker.body.namefield.text
|
|
|
|
local capacity_option =
|
|
flow.proposals.body.proposal_maker.body.capacity_options.capacity.capacity.slider.slider_value
|
|
local difficulty_option = 2
|
|
|
|
if (not proposal_name) or (proposal_name == "") then
|
|
proposal_name = "NoName"
|
|
end
|
|
|
|
-- make name unique
|
|
-- local unique, changed = true, false
|
|
-- local check_unique = function(name)
|
|
-- unique = true
|
|
-- for _, proposal in pairs(global_memory.crewproposals) do
|
|
-- if name == proposal.name then
|
|
-- unique = false
|
|
-- changed = true
|
|
-- break
|
|
-- end
|
|
-- end
|
|
-- end
|
|
-- local i = 0
|
|
-- check_unique()
|
|
-- while i < 10 and not unique do
|
|
-- check_unique(proposal_name .. i)
|
|
-- i = i + 1
|
|
-- end
|
|
-- if not unique then return end
|
|
-- if changed then proposal_name = proposal_name .. i end
|
|
|
|
local unique = true
|
|
for _, proposal in pairs(global_memory.crewproposals) do
|
|
if proposal_name == proposal.name then
|
|
unique = false
|
|
break
|
|
end
|
|
end
|
|
|
|
if not unique then
|
|
return
|
|
end
|
|
|
|
local proposal = {
|
|
name = proposal_name,
|
|
difficulty_option = difficulty_option,
|
|
capacity_option = capacity_option,
|
|
-- mode_option = mode_option,
|
|
created_by_player = player.index,
|
|
run_is_protected = run_is_protected,
|
|
run_is_private = run_is_private,
|
|
run_has_blueprints_disabled = run_has_blueprints_disabled,
|
|
private_run_password = private_run_password,
|
|
}
|
|
|
|
global_memory.crewproposals[#global_memory.crewproposals + 1] = proposal
|
|
|
|
if run_is_private then
|
|
Common.notify_lobby({
|
|
"pirates.proposal_propose_private",
|
|
player.name,
|
|
proposal_name,
|
|
CoreData.capacity_options[capacity_option].text3,
|
|
})
|
|
else
|
|
Common.notify_lobby({
|
|
"pirates.proposal_propose",
|
|
player.name,
|
|
proposal_name,
|
|
CoreData.capacity_options[capacity_option].text3,
|
|
})
|
|
end
|
|
|
|
-- local message = player.name .. ' proposed the run ' .. proposal_name .. ' (difficulty ' .. CoreData.difficulty_options[difficulty_option].text .. ', capacity ' .. CoreData.capacity_options[capacity_option].text3 .. ').'
|
|
return
|
|
end
|
|
|
|
if eventname == "abandon_proposal" then
|
|
Crew.player_abandon_proposal(player)
|
|
return
|
|
end
|
|
|
|
if eventname == "launch_crew" then
|
|
if GuiCommon.crew_overall_state_bools(player.index).proposal_can_launch then --double check
|
|
for k, proposal in pairs(global_memory.crewproposals) do
|
|
if proposal.created_by_player == player.index then
|
|
-- Make sure private run can be created
|
|
if proposal.run_is_private then
|
|
-- NOTE: I didn't want to add this check in "proposal_can_launch", because different error message would get displayed (I think?).
|
|
local private_run_count = 0
|
|
for _, id in pairs(global_memory.crew_active_ids) do
|
|
if global_memory.crew_memories[id].run_is_private then
|
|
private_run_count = private_run_count + 1
|
|
end
|
|
end
|
|
|
|
if private_run_count >= global_memory.private_run_cap then
|
|
Common.notify_player_error(
|
|
player,
|
|
{ "pirates.gui_runs_proposal_maker_error_private_run_limit" }
|
|
)
|
|
return
|
|
end
|
|
elseif proposal.run_is_protected then
|
|
local protected_but_not_private_run_count = 0
|
|
for _, id in pairs(global_memory.crew_active_ids) do
|
|
if
|
|
global_memory.crew_memories[id].run_is_protected
|
|
and not global_memory.crew_memories[id].run_is_private
|
|
then
|
|
protected_but_not_private_run_count = protected_but_not_private_run_count + 1
|
|
end
|
|
end
|
|
|
|
if protected_but_not_private_run_count >= global_memory.protected_but_not_private_run_cap then
|
|
Common.notify_player_error(
|
|
player,
|
|
{ "pirates.gui_runs_proposal_maker_error_protected_run_limit" }
|
|
)
|
|
return
|
|
end
|
|
end
|
|
|
|
Crew.initialise_crew(proposal, player.character.position)
|
|
global_memory.crewproposals[k] = nil
|
|
Progression.set_off_from_starting_dock()
|
|
|
|
return
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
return Public
|