updated code for better functionality part 3

This commit is contained in:
Zerino 2024-11-17 13:00:12 -03:00
parent 7122135ebc
commit b6abd43345
3 changed files with 33 additions and 26 deletions

View File

@ -73,6 +73,9 @@ local RESOURCE_OPTIONS = {
local handVisibility = {} local handVisibility = {}
local blurseVisibility = {} local blurseVisibility = {}
-- track cards' settings
cardSetting = {}
--------------------------------------------------------- ---------------------------------------------------------
-- data for tokens -- data for tokens
--------------------------------------------------------- ---------------------------------------------------------
@ -206,14 +209,7 @@ function tryObjectEnterContainer(container, object)
if object.hasTag("Minicard") and container.hasTag("Minicard") then if object.hasTag("Minicard") and container.hasTag("Minicard") then
return false return false
elseif object.getName() ~= "Atlach-Nacha" and next(object.getAttachments()) ~= nil then elseif object.getName() ~= "Atlach-Nacha" and next(object.getAttachments()) ~= nil then
local removedTokens = object.removeAttachments() handleTokenDetaching({ card = object })
if object.is_face_down then
for _, token in ipairs(removedTokens) do
--token.setRotation(token.getRotation() + Vector(0, 0, 180))
local sizeY = object.getBounds().size.y
token.setPosition(token.getPosition() + Vector(0, 2 * sizeY, 0))
end
end
end end
playAreaApi.tryObjectEnterContainer(container, object) playAreaApi.tryObjectEnterContainer(container, object)
@ -315,7 +311,15 @@ function onPlayerAction(player, action, targets)
end end
if #pickedCards < 6 then if #pickedCards < 6 then
for _, pickedCard in ipairs(pickedCards) do for _, pickedCard in ipairs(pickedCards) do
local searchResult = searchLib.onObject(pickedCard, "isTileOrToken") local searchResult = searchLib.onObject(pickedCard, "isTileOrToken", 0.95)
if pickedCard.is_face_down and next(searchResult) ~= nil then
cardSetting[pickedCard] = {
hideFacedown = pickedCard.hide_when_face_down,
tooltip = pickedCard.tooltip
}
pickedCard.hide_when_face_down = false
pickedCard.tooltip = false
end
for _, token in ipairs(searchResult) do for _, token in ipairs(searchResult) do
if not token.locked then if not token.locked then
pickedCard.addAttachment(token) pickedCard.addAttachment(token)
@ -324,7 +328,7 @@ function onPlayerAction(player, action, targets)
Wait.condition( Wait.condition(
function() function()
if pickedCard ~= nil then if pickedCard ~= nil then
pickedCard.removeAttachments() handleTokenDetaching({ card = pickedCard })
end end
end, end,
function() function()
@ -2871,3 +2875,20 @@ function tableContains(thisTable, thisElement)
end end
return false return false
end end
function handleTokenDetaching(params)
local pickedCard = params["card"]
if cardSetting[pickedCard] ~= nil then
local pickedCardSetting = cardSetting[pickedCard]
pickedCard.hide_when_face_down = pickedCardSetting["hideFacedown"]
pickedCard.tooltip = pickedCardSetting["tooltip"]
cardSetting[pickedCard] = nil
end
local removedTokens = pickedCard.removeAttachments()
for _, token in ipairs(removedTokens) do
if token.getPosition().y < pickedCard.getPosition().y then
local posY = pickedCard.getPosition().y + 0.05
token.setPosition(token.getPosition():setAt("y", posY))
end
end
end

View File

@ -98,14 +98,7 @@ function onCollisionEnter(collisionInfo)
-- reset spawned tokens and remove tokens from cards in encounter deck / discard area -- reset spawned tokens and remove tokens from cards in encounter deck / discard area
Wait.frames(function() tokenSpawnTrackerApi.resetTokensSpawned(object) end, 1) Wait.frames(function() tokenSpawnTrackerApi.resetTokensSpawned(object) end, 1)
if next(object.getAttachments()) ~= nil then if next(object.getAttachments()) ~= nil then
local removedTokens = object.removeAttachments() Global.call("handleTokenDetaching", { card = object })
if object.is_face_down then
for _, token in ipairs(removedTokens) do
--token.setRotation(token.getRotation() + Vector(0, 0, 180))
local sizeY = object.getBounds().size.y
token.setPosition(token.getPosition() + Vector(0, 2 * sizeY, 0))
end
end
end end
removeTokensFromObject(object) removeTokensFromObject(object)

View File

@ -1275,14 +1275,7 @@ function onCollisionEnter(collisionInfo)
elseif inArea(localCardPos, DECK_DISCARD_AREA) then elseif inArea(localCardPos, DECK_DISCARD_AREA) then
if next(object.getAttachments()) ~= nil then if next(object.getAttachments()) ~= nil then
local removedTokens = object.removeAttachments() Global.call("handleTokenDetaching", { card = object })
if object.is_face_down then
for _, token in ipairs(removedTokens) do
--token.setRotation(token.getRotation() + Vector(0, 0, 180))
local sizeY = object.getBounds().size.y
token.setPosition(token.getPosition() + Vector(0, 2 * sizeY, 0))
end
end
end end
tokenSpawnTrackerApi.resetTokensSpawned(object) tokenSpawnTrackerApi.resetTokensSpawned(object)
removeTokensFromObject(object) removeTokensFromObject(object)