2023-09-26 10:14:37 -04:00
local allCardsBagApi = require("playercards/AllCardsBagApi")
2021-10-06 23:37:31 -04:00
local INPUT_FIELD_HEIGHT = 340
local INPUT_FIELD_WIDTH = 1500
2022-10-25 03:36:45 -04:00
local FIELD_COLOR = { 0.9, 0.7, 0.5 }
2021-10-06 23:37:31 -04:00
2022-10-25 03:36:45 -04:00
local PRIVATE_TOGGLE_LABELS = {}
2021-10-06 23:37:31 -04:00
PRIVATE_TOGGLE_LABELS[true] = "Private"
PRIVATE_TOGGLE_LABELS[false] = "Published"
2022-10-25 03:36:45 -04:00
local UPGRADED_TOGGLE_LABELS = {}
2021-10-06 23:37:31 -04:00
UPGRADED_TOGGLE_LABELS[true] = "Upgraded"
UPGRADED_TOGGLE_LABELS[false] = "Specific"
2022-10-25 03:36:45 -04:00
local LOAD_INVESTIGATOR_TOGGLE_LABELS = {}
2021-10-06 23:37:31 -04:00
LOAD_INVESTIGATOR_TOGGLE_LABELS[true] = "Yes"
LOAD_INVESTIGATOR_TOGGLE_LABELS[false] = "No"
local redDeckId = ""
local orangeDeckId = ""
local whiteDeckId = ""
local greenDeckId = ""
2022-10-25 03:36:45 -04:00
2021-10-06 23:37:31 -04:00
local privateDeck = true
local loadNewestDeck = true
local loadInvestigators = false
2022-10-25 03:36:45 -04:00
-- Returns a table with the full state of the UI, including options and deck IDs.
-- This can be used to persist via onSave(), or provide values for a load operation
2021-10-06 23:37:31 -04:00
-- Table values:
-- redDeck: Deck ID to load for the red player
-- orangeDeck: Deck ID to load for the orange player
-- whiteDeck: Deck ID to load for the white player
-- greenDeck: Deck ID to load for the green player
-- private: True to load a private deck, false to load a public deck
-- loadNewest: True if the most upgraded version of the deck should be loaded
-- investigators: True if investigator cards should be spawned
function getUiState()
return {
redDeck = redDeckId,
orangeDeck = orangeDeckId,
whiteDeck = whiteDeckId,
greenDeck = greenDeckId,
private = privateDeck,
loadNewest = loadNewestDeck,
2022-10-25 03:36:45 -04:00
investigators = loadInvestigators
2021-10-06 23:37:31 -04:00
}
end
2023-06-18 14:07:24 -04:00
-- Updates the state of the UI based on the provided table. Any values not provided will be left the same.
2023-09-26 10:14:37 -04:00
---@param uiStateTable Table of values to update on importer
2023-06-18 14:07:24 -04:00
-- Table values:
-- redDeck: Deck ID to load for the red player
-- orangeDeck: Deck ID to load for the orange player
-- whiteDeck: Deck ID to load for the white player
-- greenDeck: Deck ID to load for the green player
-- private: True to load a private deck, false to load a public deck
-- loadNewest: True if the most upgraded version of the deck should be loaded
-- investigators: True if investigator cards should be spawned
function setUiState(uiStateTable)
2023-09-30 14:09:00 -04:00
self.clearButtons()
self.clearInputs()
initializeUi(uiStateTable)
2023-06-18 14:07:24 -04:00
end
2022-10-25 03:36:45 -04:00
-- Sets up the UI for the deck loader, populating fields from the given save state table decoded from onLoad()
2021-10-06 23:37:31 -04:00
function initializeUi(savedUiState)
2022-10-25 03:36:45 -04:00
if savedUiState ~= nil then
2021-10-06 23:37:31 -04:00
redDeckId = savedUiState.redDeck
orangeDeckId = savedUiState.orangeDeck
whiteDeckId = savedUiState.whiteDeck
greenDeckId = savedUiState.greenDeck
privateDeck = savedUiState.private
loadNewestDeck = savedUiState.loadNewest
loadInvestigators = savedUiState.investigators
end
makeOptionToggles()
makeDeckIdFields()
makeBuildButton()
end
function makeOptionToggles()
2022-10-25 03:36:45 -04:00
-- common parameters
2021-10-06 23:37:31 -04:00
local checkbox_parameters = {}
checkbox_parameters.function_owner = self
checkbox_parameters.width = INPUT_FIELD_WIDTH
checkbox_parameters.height = INPUT_FIELD_HEIGHT
2022-10-25 03:36:45 -04:00
checkbox_parameters.scale = { 0.1, 0.1, 0.1 }
2021-10-06 23:37:31 -04:00
checkbox_parameters.font_size = 240
2022-10-25 03:36:45 -04:00
checkbox_parameters.hover_color = { 0.4, 0.6, 0.8 }
2021-10-06 23:37:31 -04:00
checkbox_parameters.color = FIELD_COLOR
2022-10-25 03:36:45 -04:00
-- public / private deck
checkbox_parameters.click_function = "publicPrivateChanged"
checkbox_parameters.position = { 0.25, 0.1, -0.102 }
checkbox_parameters.tooltip = "Published or private deck?\n\nPLEASE USE A PRIVATE DECK IF JUST FOR TTS TO AVOID FLOODING ARKHAMDB PUBLISHED DECK LISTS!"
checkbox_parameters.label = PRIVATE_TOGGLE_LABELS[privateDeck]
2021-10-06 23:37:31 -04:00
self.createButton(checkbox_parameters)
2022-10-25 03:36:45 -04:00
-- load upgraded?
2021-10-06 23:37:31 -04:00
checkbox_parameters.click_function = "loadUpgradedChanged"
2022-10-25 03:36:45 -04:00
checkbox_parameters.position = { 0.25, 0.1, -0.01 }
checkbox_parameters.tooltip = "Load newest upgrade or exact deck?"
2021-10-06 23:37:31 -04:00
checkbox_parameters.label = UPGRADED_TOGGLE_LABELS[loadNewestDeck]
self.createButton(checkbox_parameters)
2022-10-25 03:36:45 -04:00
-- load investigators?
2021-10-06 23:37:31 -04:00
checkbox_parameters.click_function = "loadInvestigatorsChanged"
2022-10-25 03:36:45 -04:00
checkbox_parameters.position = { 0.25, 0.1, 0.081 }
2021-10-06 23:37:31 -04:00
checkbox_parameters.tooltip = "Spawn investigator cards?"
checkbox_parameters.label = LOAD_INVESTIGATOR_TOGGLE_LABELS[loadInvestigators]
self.createButton(checkbox_parameters)
end
-- Create the four deck ID entry fields
function makeDeckIdFields()
local input_parameters = {}
-- Parameters common to all entry fields
input_parameters.function_owner = self
2022-10-25 03:36:45 -04:00
input_parameters.scale = { 0.1, 0.1, 0.1 }
2021-10-06 23:37:31 -04:00
input_parameters.width = INPUT_FIELD_WIDTH
input_parameters.height = INPUT_FIELD_HEIGHT
input_parameters.font_size = 320
input_parameters.tooltip = "Deck ID from ArkhamDB URL of the deck\nPublic URL: 'https://arkhamdb.com/decklist/view/101/knowledge-overwhelming-solo-deck-1.0' = '101'\nPrivate URL: 'https://arkhamdb.com/deck/view/102' = '102'"
input_parameters.alignment = 3 -- Center
input_parameters.color = FIELD_COLOR
2022-10-25 03:36:45 -04:00
input_parameters.font_color = { 0, 0, 0 }
2021-10-06 23:37:31 -04:00
input_parameters.validation = 2 -- Integer
-- Green
input_parameters.input_function = "greenDeckChanged"
2022-10-25 03:36:45 -04:00
input_parameters.position = { -0.166, 0.1, 0.385 }
input_parameters.value = greenDeckId
2021-10-06 23:37:31 -04:00
self.createInput(input_parameters)
-- Red
input_parameters.input_function = "redDeckChanged"
2022-10-25 03:36:45 -04:00
input_parameters.position = { 0.171, 0.1, 0.385 }
input_parameters.value = redDeckId
2021-10-06 23:37:31 -04:00
self.createInput(input_parameters)
-- White
input_parameters.input_function = "whiteDeckChanged"
2022-10-25 03:36:45 -04:00
input_parameters.position = { -0.166, 0.1, 0.474 }
input_parameters.value = whiteDeckId
2021-10-06 23:37:31 -04:00
self.createInput(input_parameters)
-- Orange
input_parameters.input_function = "orangeDeckChanged"
2022-10-25 03:36:45 -04:00
input_parameters.position = { 0.171, 0.1, 0.474 }
input_parameters.value = orangeDeckId
2021-10-06 23:37:31 -04:00
self.createInput(input_parameters)
end
2022-10-25 03:36:45 -04:00
-- Create the Build All button. This is a transparent button which covers the Build All portion of the background graphic
2021-10-06 23:37:31 -04:00
function makeBuildButton()
local button_parameters = {}
button_parameters.click_function = "loadDecks"
button_parameters.function_owner = self
2022-10-25 03:36:45 -04:00
button_parameters.position = { 0, 0.1, 0.71 }
2021-10-06 23:37:31 -04:00
button_parameters.width = 320
button_parameters.height = 30
2022-10-25 03:36:45 -04:00
button_parameters.color = { 0, 0, 0, 0 }
2021-10-06 23:37:31 -04:00
button_parameters.tooltip = "Click to build all four decks!"
self.createButton(button_parameters)
end
2022-10-25 03:36:45 -04:00
-- Event handlers for deck ID change
function redDeckChanged(_, _, inputValue) redDeckId = inputValue end
function orangeDeckChanged(_, _, inputValue) orangeDeckId = inputValue end
function whiteDeckChanged(_, _, inputValue) whiteDeckId = inputValue end
function greenDeckChanged(_, _, inputValue) greenDeckId = inputValue end
-- Event handlers for toggle buttons
2021-10-06 23:37:31 -04:00
function publicPrivateChanged()
privateDeck = not privateDeck
2022-10-25 03:36:45 -04:00
self.editButton { index = 0, label = PRIVATE_TOGGLE_LABELS[privateDeck] }
2021-10-06 23:37:31 -04:00
end
function loadUpgradedChanged()
loadNewestDeck = not loadNewestDeck
2022-10-25 03:36:45 -04:00
self.editButton { index = 1, label = UPGRADED_TOGGLE_LABELS[loadNewestDeck] }
2021-10-06 23:37:31 -04:00
end
function loadInvestigatorsChanged()
loadInvestigators = not loadInvestigators
2022-10-25 03:36:45 -04:00
self.editButton { index = 2, label = LOAD_INVESTIGATOR_TOGGLE_LABELS[loadInvestigators] }
2021-10-06 23:37:31 -04:00
end
function loadDecks()
-- testLoadLotsOfDecks()
-- Method in DeckImporterMain, visible due to inclusion
2023-08-09 12:37:45 -04:00
local indexReady = allCardsBagApi.isIndexReady()
2021-10-06 23:37:31 -04:00
if (not indexReady) then
broadcastToAll("Still loading player cards, please try again in a few seconds", {0.9, 0.2, 0.2})
return
end
if (redDeckId ~= nil and redDeckId ~= "") then
buildDeck("Red", redDeckId)
end
if (orangeDeckId ~= nil and orangeDeckId ~= "") then
buildDeck("Orange", orangeDeckId)
end
if (whiteDeckId ~= nil and whiteDeckId ~= "") then
buildDeck("White", whiteDeckId)
end
if (greenDeckId ~= nil and greenDeckId ~= "") then
buildDeck("Green", greenDeckId)
end
end