Merge pull request #1020 from argonui/early-pick-up

Fixed picking up a card while it is falling
This commit is contained in:
Chr1Z 2024-11-21 01:03:39 +01:00 committed by GitHub
commit 71cd5886f7
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 25 additions and 6 deletions

View File

@ -186,6 +186,12 @@ function onObjectDrop(_, object)
end end
end end
function onObjectRotate(object, _, flip, _, _, oldFlip)
if flip ~= oldFlip then
stopTokenTransformUpdating(object)
end
end
-- Event hook for any object search. When chaos tokens are manipulated while the chaos bag -- Event hook for any object search. When chaos tokens are manipulated while the chaos bag
-- container is being searched, a TTS bug can cause tokens to duplicate or vanish. We lock the -- container is being searched, a TTS bug can cause tokens to duplicate or vanish. We lock the
-- chaos bag during search operations to avoid this. -- chaos bag during search operations to avoid this.
@ -2877,8 +2883,6 @@ function moveCardWithTokens(params)
Wait.condition( Wait.condition(
function() stopTokenTransformUpdating(card) end, function() stopTokenTransformUpdating(card) end,
function() function()
if card.held_by_color ~= nil then return true end
if card ~= nil and cardTokens[card] ~= nil and #cardTokens[card] ~= 0 then if card ~= nil and cardTokens[card] ~= nil and #cardTokens[card] ~= 0 then
updateTokenTransform(card) updateTokenTransform(card)
return card.resting and not card.isSmoothMoving() return card.resting and not card.isSmoothMoving()
@ -2890,10 +2894,6 @@ function moveCardWithTokens(params)
end end
function storeTokenTransform(card) function storeTokenTransform(card)
if cardTokens[card] ~= nil then
stopTokenTransformUpdating(card)
end
cardTokens[card] = {} cardTokens[card] = {}
local cardRot = card.getRotation() local cardRot = card.getRotation()
for _, token in ipairs(searchLib.onObject(card, "isTileOrToken", 0.95)) do for _, token in ipairs(searchLib.onObject(card, "isTileOrToken", 0.95)) do
@ -2923,6 +2923,7 @@ function updateTokenTransform(card)
end end
function stopTokenTransformUpdating(card) function stopTokenTransformUpdating(card)
if cardTokens[card] == nil then return end
for _, tokenData in ipairs(cardTokens[card] or {}) do for _, tokenData in ipairs(cardTokens[card] or {}) do
if tokenData.token ~= nil then if tokenData.token ~= nil then
tokenData.token.locked = false tokenData.token.locked = false
@ -2932,6 +2933,10 @@ function stopTokenTransformUpdating(card)
card.use_hands = true card.use_hands = true
end end
function unregisterCard(card)
cardTokens[card] = nil
end
function unregisterTokenFromCard(params) function unregisterTokenFromCard(params)
local card = params.card local card = params.card
local token = params.token local token = params.token

View File

@ -9,3 +9,17 @@ function emptyTrash()
self.takeObject().destruct() self.takeObject().destruct()
end end
end end
function onObjectLeaveContainer(container, object)
if container == self then
object.locked = false
if object.type == "Card" then
object.use_hands = true
end
if object.type == "Card" or object.type == "Deck" then
Global.call("unregisterCard", object)
end
end
end