From 7039ea0d698db75f49b3313c67f1ba928db84eef Mon Sep 17 00:00:00 2001 From: Tom-TBT Date: Wed, 4 Sep 2024 09:23:16 +0200 Subject: [PATCH] prevent duplicate token count per image --- src/AutoTagForm.jsx | 21 ++++++++++----------- 1 file changed, 10 insertions(+), 11 deletions(-) diff --git a/src/AutoTagForm.jsx b/src/AutoTagForm.jsx index f7787c7..2713db1 100644 --- a/src/AutoTagForm.jsx +++ b/src/AutoTagForm.jsx @@ -107,21 +107,21 @@ export default class AutoTagForm extends React.Component { const escapedString = this.state.separators.replace(/[-\/\\^$*+?.()|[\]{}]/g, '\\$&'); const regexPattern = RegExp(`[${escapedString}]+`); - let imageTokens = new Set(); - let tokens = image.clientPath.split(regexPattern); - tokens.forEach(value => - imageTokens.add(this.addOrUpdateToken(tagValuesMap, tokenMap, value)) - ); + const allTokens = new Set(); + // Split and add tokens from image.clientPath + image.clientPath.split(regexPattern).forEach(value => allTokens.add(value)); + // Split and add tokens from image.name + image.name.split(regexPattern).forEach(value => allTokens.add(value)); - tokens = image.name.split(regexPattern); // Splitting on brackets too - tokens.forEach(value => + // Process each unique token + let imageTokens = new Set(); + allTokens.forEach(value => imageTokens.add(this.addOrUpdateToken(tagValuesMap, tokenMap, value)) ); // Return the set of tokens that are present on this image return imageTokens; - } loadFromServer(imageIds) { @@ -258,7 +258,6 @@ export default class AutoTagForm extends React.Component { images.forEach(image => { // Find the tokens on each image, updating the tokenMap in place image.tokens = this.tokensInName(image, tagValuesMap, tokenMap); - console.log(image.tokens); // Check any tokens that exist on this image by default image.checkedTokens = new Set(image.tokens); @@ -694,11 +693,11 @@ export default class AutoTagForm extends React.Component { // Filter out any tokens that do not meet the requirements // Requirements for inclusion: // 1) Matches an existing tag value - // 2) Is present on required number of images AND Is not numbers and/or symbols only + // 2) Is present on required number of images let tokenMap = new Map([...this.state.tokenMap].filter(kv => { let token = kv[1]; - return ( + token.possible.size > 0 || ( token.count >= this.state.requiredTokenCardinality &&