From a010ce7e6768ac1301cd53c821c05e9fcce03dcb Mon Sep 17 00:00:00 2001 From: Jeff Hitchcock Date: Tue, 11 Jun 2024 13:26:36 -0700 Subject: [PATCH] [#3696] Fix Item Choice replacement with dropped items --- .../applications/advancement/item-choice-flow.mjs | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/module/applications/advancement/item-choice-flow.mjs b/module/applications/advancement/item-choice-flow.mjs index 41b868b39f..612212a9c0 100644 --- a/module/applications/advancement/item-choice-flow.mjs +++ b/module/applications/advancement/item-choice-flow.mjs @@ -79,7 +79,13 @@ export default class ItemChoiceFlow extends ItemGrantFlow { context.noReplacement = !this.advancement.actor.items.has(this.replacement); if ( context.replaceable && !context.noReplacement ) max++; if ( this.selected.size > max ) { - this.selected = new Set(Array.from(this.selected).slice(0, max)); + const [kept, lost] = Array.from(Array.from(this.selected).entries()).reduce(([kept, lost], [index, value]) => { + if ( index < max ) kept.push(value); + else lost.push(value); + return [kept, lost]; + }, [[], []]); + this.selected = new Set(kept); + this.dropped = this.dropped.filter(i => !lost.includes(i.uuid)); } context.choices = { max, current: this.selected.size, full: this.selected.size >= max }; @@ -164,7 +170,10 @@ export default class ItemChoiceFlow extends ItemGrantFlow { /** @inheritdoc */ async _onDrop(event) { - if ( this.selected.size >= this.advancement.configuration.choices[this.level].count ) return false; + const levelConfig = this.advancement.configuration.choices[this.level]; + let max = levelConfig.count ?? 0; + if ( levelConfig.replacement && this.advancement.actor.items.has(this.replacement) ) max++; + if ( this.selected.size >= max ) return false; // Try to extract the data let data;