Updated clean up helper
This commit is contained in:
parent
d3ff9b61f2
commit
bb45eda845
@ -17,7 +17,7 @@ local tokenSpawnTrackerApi = require("core/token/TokenSpawnTrackerApi")
|
|||||||
local IGNORE_TAG = "CleanUpHelper_ignore"
|
local IGNORE_TAG = "CleanUpHelper_ignore"
|
||||||
|
|
||||||
-- colors and order for following tables
|
-- colors and order for following tables
|
||||||
local COLORS = { "White", "Orange", "Green", "Red", "Mythos" }
|
local COLORS = { "White", "Orange", "Green", "Red" }
|
||||||
local campaignLog
|
local campaignLog
|
||||||
local RESET_VALUES = {}
|
local RESET_VALUES = {}
|
||||||
local loadingFailedBefore = false
|
local loadingFailedBefore = false
|
||||||
@ -153,9 +153,9 @@ function updateCounters()
|
|||||||
playermatApi.updateCounter("All", "ClickableClueCounter", 0)
|
playermatApi.updateCounter("All", "ClickableClueCounter", 0)
|
||||||
playermatApi.resetSkillTracker("All")
|
playermatApi.resetSkillTracker("All")
|
||||||
|
|
||||||
for i = 1, 4 do
|
for i, color in ipairs(COLORS) do
|
||||||
playermatApi.updateCounter(COLORS[i], "DamageCounter", RESET_VALUES.Damage[i])
|
playermatApi.updateCounter(color, "DamageCounter", RESET_VALUES.Damage[i])
|
||||||
playermatApi.updateCounter(COLORS[i], "HorrorCounter", RESET_VALUES.Horror[i])
|
playermatApi.updateCounter(color, "HorrorCounter", RESET_VALUES.Horror[i])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -269,15 +269,16 @@ end
|
|||||||
-- discard all hand objects
|
-- discard all hand objects
|
||||||
function discardHands()
|
function discardHands()
|
||||||
if not getOptionValue() then return end
|
if not getOptionValue() then return end
|
||||||
for i = 1, 4 do
|
for _, color in ipairs(COLORS) do
|
||||||
local trash = guidReferenceApi.getObjectByOwnerAndType(COLORS[i], "Trash")
|
local trash = guidReferenceApi.getObjectByOwnerAndType(color, "Trash")
|
||||||
if trash == nil then return end
|
if trash then
|
||||||
local hand = Player[playermatApi.getPlayerColor(COLORS[i])].getHandObjects()
|
local hand = Player[playermatApi.getPlayerColor(color)].getHandObjects()
|
||||||
for j = #hand, 1, -1 do
|
for j = #hand, 1, -1 do
|
||||||
trash.putObject(hand[j])
|
trash.putObject(hand[j])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
-- maybe ignore cards / decks on the tekelili helper
|
-- maybe ignore cards / decks on the tekelili helper
|
||||||
function maybeIgnoreTekeliliCards()
|
function maybeIgnoreTekeliliCards()
|
||||||
@ -329,53 +330,56 @@ end
|
|||||||
function tidyPlayerMatCoroutine()
|
function tidyPlayerMatCoroutine()
|
||||||
local tekeliliHelper = getTekeliliHelper()
|
local tekeliliHelper = getTekeliliHelper()
|
||||||
|
|
||||||
for i = 1, 5 do
|
if getOptionValue() then
|
||||||
-- only continue for playermat (1-4) if option enabled
|
for _, color in ipairs(COLORS) do
|
||||||
if getOptionValue() or i == 5 then
|
|
||||||
-- delay for animation purpose
|
-- delay for animation purpose
|
||||||
for k = 1, 30 do
|
for k = 1, 20 do
|
||||||
coroutine.yield(0)
|
coroutine.yield(0)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- get respective trash
|
-- get respective trash
|
||||||
local trash = guidReferenceApi.getObjectByOwnerAndType(COLORS[i], "Trash")
|
local trash = guidReferenceApi.getObjectByOwnerAndType(color, "Trash")
|
||||||
if trash == nil then
|
if trash == nil then
|
||||||
printToAll("Trashcan for " .. COLORS[i] .. " playermat could not be found! Skipping this playermat.", "Yellow")
|
printToAll("Trashcan for " .. color .. " playermat could not be found! Skipping this playermat.", "Yellow")
|
||||||
goto continue
|
goto continue
|
||||||
end
|
end
|
||||||
|
|
||||||
-- maybe store tekelili cards
|
-- maybe store tekelili cards
|
||||||
if tekeliliHelper and i ~= 5 then
|
if tekeliliHelper then
|
||||||
tekeliliHelper.call("storeTekelili", COLORS[i])
|
tekeliliHelper.call("storeTekelili", color)
|
||||||
end
|
end
|
||||||
|
|
||||||
local objList
|
-- remove objects (with exceptions)
|
||||||
if i < 5 then
|
for _, obj in ipairs(playermatApi.searchAroundPlayermat(color)) do
|
||||||
objList = playermatApi.searchAroundPlayermat(COLORS[i])
|
maybeTrashObject(obj, trash)
|
||||||
else
|
|
||||||
-- Victory Display + Mythos Area
|
|
||||||
objList = searchLib.inArea({ -2, 2, 10 }, { 0, 270, 0 }, { 55, 1, 13.5 })
|
|
||||||
end
|
end
|
||||||
|
|
||||||
for _, obj in ipairs(objList) do
|
-- reset "activeInvestigatorId" and "...class"
|
||||||
-- ignore these elements
|
local mat = guidReferenceApi.getObjectByOwnerAndType(color, "Playermat")
|
||||||
if obj.hasTag(IGNORE_TAG) == false
|
mat.setVar("activeInvestigatorId", "00000")
|
||||||
and obj.hasTag("UniversalToken") == false
|
mat.setVar("activeInvestigatorClass", "Neutral")
|
||||||
and obj.hasTag("chaosBag") == false
|
mat.call("updateTexture")
|
||||||
and (obj.locked == false or obj.hasTag("Investigator"))
|
|
||||||
and obj.interactable == true then
|
for k = 1, 10 do
|
||||||
trash.putObject(obj)
|
coroutine.yield(0)
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
-- maybe respawn tekelili cards
|
-- maybe respawn tekelili cards
|
||||||
if tekeliliHelper and i ~= 5 then
|
if tekeliliHelper then
|
||||||
tekeliliHelper.call("spawnStoredTekelili", COLORS[i])
|
tekeliliHelper.call("spawnStoredTekelili", color)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
::continue::
|
::continue::
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- mythos area cleanup
|
||||||
|
local trash = guidReferenceApi.getObjectByOwnerAndType("Mythos", "Trash")
|
||||||
|
if trash then
|
||||||
|
for _, obj in ipairs(searchLib.inArea({ -2, 2, 10 }, { 0, 270, 0 }, { 55, 1, 13.5 })) do
|
||||||
|
maybeTrashObject(obj, trash)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
-- maybe remove ignore tag from cards / decks on the tekelili helper
|
-- maybe remove ignore tag from cards / decks on the tekelili helper
|
||||||
if tekeliliHelper then
|
if tekeliliHelper then
|
||||||
local searchResult = searchLib.onObject(tekeliliHelper, "isCardOrDeck")
|
local searchResult = searchLib.onObject(tekeliliHelper, "isCardOrDeck")
|
||||||
@ -384,12 +388,6 @@ function tidyPlayerMatCoroutine()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- reset "activeInvestigatorId"
|
|
||||||
local playerMats = guidReferenceApi.getObjectsByType("Playermat")
|
|
||||||
for _, mat in pairs(playerMats) do
|
|
||||||
mat.setVar("activeInvestigatorId", "00000")
|
|
||||||
end
|
|
||||||
|
|
||||||
-- reset spawned data
|
-- reset spawned data
|
||||||
tokenSpawnTrackerApi.resetAll()
|
tokenSpawnTrackerApi.resetAll()
|
||||||
local datahelper = guidReferenceApi.getObjectByOwnerAndType("Mythos", "DataHelper")
|
local datahelper = guidReferenceApi.getObjectByOwnerAndType("Mythos", "DataHelper")
|
||||||
@ -410,6 +408,16 @@ function getTekeliliHelper()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function maybeTrashObject(obj, trash)
|
||||||
|
if not obj.hasTag(IGNORE_TAG)
|
||||||
|
and (not obj.hasTag("UniversalToken") or obj.getScale().x < 0.4)
|
||||||
|
and not obj.hasTag("chaosBag")
|
||||||
|
and (not obj.locked or obj.hasTag("Investigator"))
|
||||||
|
and obj.interactable then
|
||||||
|
trash.putObject(obj)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
-- get value with respect to override value
|
-- get value with respect to override value
|
||||||
function getOptionValue()
|
function getOptionValue()
|
||||||
-- don't clean up playermats if playing a prelude from the list
|
-- don't clean up playermats if playing a prelude from the list
|
||||||
|
Loading…
x
Reference in New Issue
Block a user