2022-12-28 02:57:43 -08:00
|
|
|
local tokenManager = require("core/token/TokenManager")
|
2022-12-28 13:08:48 -08:00
|
|
|
|
2022-11-12 11:46:05 +01:00
|
|
|
---------------------------------------------------------
|
|
|
|
-- general setup
|
|
|
|
---------------------------------------------------------
|
|
|
|
|
2021-10-06 20:37:31 -07:00
|
|
|
-- set true to enable debug logging
|
|
|
|
DEBUG = false
|
|
|
|
|
2022-11-12 11:46:05 +01:00
|
|
|
-- we use this to turn off collision handling until onLoad() is complete
|
2021-10-06 20:37:31 -07:00
|
|
|
COLLISION_ENABLED = false
|
|
|
|
|
2022-12-12 18:56:04 -08:00
|
|
|
local SHIFT_OFFSETS = {
|
|
|
|
left = { x = 0.00, y = 0, z = 7.67 },
|
|
|
|
right = { x = 0.00, y = 0, z = -7.67 },
|
|
|
|
up = { x = 6.54, y = 0, z = 0.00 },
|
|
|
|
down = { x = -6.54, y = 0, z = 0.00 }
|
|
|
|
}
|
|
|
|
local SHIFT_EXCLUSION = {
|
|
|
|
["b7b45b"] = true,
|
|
|
|
["f182ee"] = true,
|
|
|
|
["721ba2"] = true
|
|
|
|
}
|
|
|
|
|
2022-11-24 13:38:29 -08:00
|
|
|
local INVESTIGATOR_COUNTER_GUID = "f182ee"
|
2022-12-12 18:56:04 -08:00
|
|
|
local PLAY_AREA_ZONE_GUID = "a2f932"
|
|
|
|
|
2022-12-15 00:29:56 -08:00
|
|
|
local currentScenario
|
2022-11-13 01:12:01 +01:00
|
|
|
|
2022-11-12 11:46:05 +01:00
|
|
|
---------------------------------------------------------
|
|
|
|
-- general code
|
|
|
|
---------------------------------------------------------
|
2021-10-06 20:37:31 -07:00
|
|
|
|
2022-12-15 00:29:56 -08:00
|
|
|
function onSave()
|
|
|
|
return JSON.encode({
|
|
|
|
currentScenario = currentScenario
|
|
|
|
})
|
|
|
|
end
|
2021-10-06 20:37:31 -07:00
|
|
|
|
2022-12-15 00:29:56 -08:00
|
|
|
function onLoad(saveState)
|
2022-11-12 11:46:05 +01:00
|
|
|
-- records locations we have spawned clues for
|
2022-12-15 00:29:56 -08:00
|
|
|
local saveData = JSON.decode(saveState) or {}
|
|
|
|
currentScenario = saveData.currentScenario
|
2021-10-06 20:37:31 -07:00
|
|
|
|
2022-11-12 11:46:05 +01:00
|
|
|
self.interactable = DEBUG
|
|
|
|
Wait.time(function() COLLISION_ENABLED = true end, 1)
|
2021-10-06 20:37:31 -07:00
|
|
|
end
|
|
|
|
|
2022-11-12 11:46:05 +01:00
|
|
|
function log(message)
|
|
|
|
if DEBUG then print(message) end
|
2021-10-06 20:37:31 -07:00
|
|
|
end
|
|
|
|
|
2022-12-28 02:57:43 -08:00
|
|
|
-- Called by Custom Data Helpers to push their location data into the Data Helper. This adds the
|
|
|
|
-- data to the local token manager instance.
|
|
|
|
---@param args Table Single-value array holding the GUID of the Custom Data Helper making the call
|
2021-10-06 20:37:31 -07:00
|
|
|
function updateLocations(args)
|
2022-12-28 02:57:43 -08:00
|
|
|
local customDataHelper = getObjectFromGUID(args[1])
|
|
|
|
if customDataHelper ~= nil then
|
|
|
|
tokenManager.addLocationData(customDataHelper.getTable("LOCATIONS_DATA"))
|
2022-11-12 11:46:05 +01:00
|
|
|
end
|
2021-10-06 20:37:31 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
function onCollisionEnter(collision_info)
|
2022-11-12 11:46:05 +01:00
|
|
|
if not COLLISION_ENABLED then return end
|
2021-10-06 20:37:31 -07:00
|
|
|
|
2022-11-12 11:46:05 +01:00
|
|
|
-- check if we should spawn clues here and do so according to playercount
|
2022-12-28 02:57:43 -08:00
|
|
|
local card = collision_info.collision_object
|
|
|
|
if shouldSpawnTokens(card) then
|
|
|
|
tokenManager.spawnForCard(card)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
function shouldSpawnTokens(card)
|
|
|
|
local metadata = JSON.decode(card.getGMNotes())
|
|
|
|
if metadata == nil then
|
|
|
|
return tokenManager.hasLocationData(card) ~= nil
|
2021-10-06 20:37:31 -07:00
|
|
|
end
|
2022-12-28 02:57:43 -08:00
|
|
|
return metadata.type == "Location"
|
|
|
|
or metadata.type == "Enemy"
|
|
|
|
or metadata.type == "Treachery"
|
|
|
|
or metadata.weakness
|
2021-10-06 20:37:31 -07:00
|
|
|
end
|
2022-11-24 11:58:57 -08:00
|
|
|
|
2022-12-13 02:15:16 -08:00
|
|
|
-- Move all contents on the play area (cards, tokens, etc) one slot in the given direction. Certain
|
|
|
|
-- fixed objects will be ignored, as will anything the player has tagged with
|
|
|
|
-- 'displacement_excluded'
|
2022-12-12 18:56:04 -08:00
|
|
|
---@param playerColor Color of the player requesting the shift. Used solely to send an error
|
|
|
|
--- message in the unlikely case that the scripting zone has been deleted
|
|
|
|
function shiftContentsUp(playerColor)
|
|
|
|
shiftContents(playerColor, "up")
|
|
|
|
end
|
|
|
|
|
|
|
|
function shiftContentsDown(playerColor)
|
|
|
|
shiftContents(playerColor, "down")
|
|
|
|
end
|
|
|
|
|
|
|
|
function shiftContentsLeft(playerColor)
|
|
|
|
shiftContents(playerColor, "left")
|
|
|
|
end
|
|
|
|
|
|
|
|
function shiftContentsRight(playerColor)
|
|
|
|
shiftContents(playerColor, "right")
|
|
|
|
end
|
|
|
|
|
|
|
|
function shiftContents(playerColor, direction)
|
|
|
|
local zone = getObjectFromGUID(PLAY_AREA_ZONE_GUID)
|
|
|
|
if not zone then
|
|
|
|
broadcastToColor("Scripting zone couldn't be found.", playerColor, "Red")
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
for _, object in ipairs(zone.getObjects()) do
|
|
|
|
if not (SHIFT_EXCLUSION[object.getGUID()] or object.hasTag("displacement_excluded")) then
|
|
|
|
object.translate(SHIFT_OFFSETS[direction])
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
-- Returns the current value of the investigator counter from the playmat
|
|
|
|
---@return Integer. Number of investigators currently set on the counter
|
2022-11-24 11:58:57 -08:00
|
|
|
function getInvestigatorCount()
|
2022-12-12 18:56:04 -08:00
|
|
|
local investigatorCounter = getObjectFromGUID("f182ee")
|
2022-11-24 11:58:57 -08:00
|
|
|
return investigatorCounter.getVar("val")
|
|
|
|
end
|
2022-12-12 18:56:04 -08:00
|
|
|
|
|
|
|
-- Reset the play area's tracking of which cards have had tokens spawned.
|
|
|
|
function resetSpawnedCards()
|
|
|
|
spawnedLocationGUIDs = {}
|
|
|
|
end
|
2022-12-15 00:29:56 -08:00
|
|
|
|
|
|
|
function onScenarioChanged(scenarioName)
|
|
|
|
currentScenario = scenarioName
|
|
|
|
end
|