@n8n/utils 1.17.0 → 1.18.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/dist/assert.cjs +7 -5
  2. package/dist/assert.cjs.map +1 -1
  3. package/dist/assert.d.cts +3 -1
  4. package/dist/assert.d.ts +3 -1
  5. package/dist/assert.js +8 -7
  6. package/dist/assert.js.map +1 -1
  7. package/dist/event-bus.cjs +39 -35
  8. package/dist/event-bus.cjs.map +1 -1
  9. package/dist/event-bus.d.cts +9 -9
  10. package/dist/event-bus.d.ts +9 -9
  11. package/dist/event-bus.js +40 -37
  12. package/dist/event-bus.js.map +1 -1
  13. package/dist/event-queue.cjs +36 -25
  14. package/dist/event-queue.cjs.map +1 -1
  15. package/dist/event-queue.d.cts +4 -2
  16. package/dist/event-queue.d.ts +4 -2
  17. package/dist/event-queue.js +37 -27
  18. package/dist/event-queue.js.map +1 -1
  19. package/dist/number/smartDecimal.cjs +7 -10
  20. package/dist/number/smartDecimal.cjs.map +1 -1
  21. package/dist/number/smartDecimal.d.cts +3 -1
  22. package/dist/number/smartDecimal.d.ts +3 -1
  23. package/dist/number/smartDecimal.js +8 -12
  24. package/dist/number/smartDecimal.js.map +1 -1
  25. package/dist/retry.cjs +35 -26
  26. package/dist/retry.cjs.map +1 -1
  27. package/dist/retry.d.cts +3 -1
  28. package/dist/retry.d.ts +3 -1
  29. package/dist/retry.js +36 -28
  30. package/dist/retry.js.map +1 -1
  31. package/dist/search/reRankSearchResults.cjs +15 -17
  32. package/dist/search/reRankSearchResults.cjs.map +1 -1
  33. package/dist/search/reRankSearchResults.d.cts +8 -6
  34. package/dist/search/reRankSearchResults.d.ts +8 -6
  35. package/dist/search/reRankSearchResults.js +16 -19
  36. package/dist/search/reRankSearchResults.js.map +1 -1
  37. package/dist/search/sublimeSearch.cjs +161 -186
  38. package/dist/search/sublimeSearch.cjs.map +1 -1
  39. package/dist/search/sublimeSearch.d.cts +9 -7
  40. package/dist/search/sublimeSearch.d.ts +9 -7
  41. package/dist/search/sublimeSearch.js +160 -187
  42. package/dist/search/sublimeSearch.js.map +1 -1
  43. package/dist/sort/sortByProperty.cjs +9 -8
  44. package/dist/sort/sortByProperty.cjs.map +1 -1
  45. package/dist/sort/sortByProperty.d.cts +3 -1
  46. package/dist/sort/sortByProperty.d.ts +3 -1
  47. package/dist/sort/sortByProperty.js +10 -10
  48. package/dist/sort/sortByProperty.js.map +1 -1
  49. package/dist/string/truncate.cjs +27 -27
  50. package/dist/string/truncate.cjs.map +1 -1
  51. package/dist/string/truncate.d.cts +3 -1
  52. package/dist/string/truncate.d.ts +3 -1
  53. package/dist/string/truncate.js +26 -28
  54. package/dist/string/truncate.js.map +1 -1
  55. package/package.json +8 -8
@@ -1,198 +1,171 @@
1
- // src/search/sublimeSearch.ts
2
- var SEQUENTIAL_BONUS = 60;
3
- var SEPARATOR_BONUS = 38;
4
- var CAMEL_BONUS = 30;
5
- var FIRST_LETTER_BONUS = 15;
6
- var LEADING_LETTER_PENALTY = -20;
7
- var MAX_LEADING_LETTER_PENALTY = -200;
8
- var UNMATCHED_LETTER_PENALTY = -5;
9
- var DEFAULT_KEYS = [
10
- { key: "properties.displayName", weight: 1.3 },
11
- { key: "properties.codex.alias", weight: 1 }
12
- ];
1
+ //#region src/search/sublimeSearch.ts
2
+ const SEQUENTIAL_BONUS = 60;
3
+ const SEPARATOR_BONUS = 38;
4
+ const CAMEL_BONUS = 30;
5
+ const FIRST_LETTER_BONUS = 15;
6
+ const LEADING_LETTER_PENALTY = -20;
7
+ const MAX_LEADING_LETTER_PENALTY = -200;
8
+ const UNMATCHED_LETTER_PENALTY = -5;
9
+ const DEFAULT_KEYS = [{
10
+ key: "properties.displayName",
11
+ weight: 1.3
12
+ }, {
13
+ key: "properties.codex.alias",
14
+ weight: 1
15
+ }];
16
+ /**
17
+ * Returns true if each character in pattern is found sequentially within target
18
+ * @param {*} pattern string
19
+ * @param {*} target string
20
+ */
13
21
  function fuzzyMatchSimple(pattern, target) {
14
- let patternIdx = 0;
15
- let strIdx = 0;
16
- while (patternIdx < pattern.length && strIdx < target.length) {
17
- const patternChar = pattern.charAt(patternIdx).toLowerCase();
18
- const targetChar = target.charAt(strIdx).toLowerCase();
19
- if (patternChar === targetChar) {
20
- patternIdx++;
21
- }
22
- ++strIdx;
23
- }
24
- return pattern.length !== 0 && target.length !== 0 && patternIdx === pattern.length;
22
+ let patternIdx = 0;
23
+ let strIdx = 0;
24
+ while (patternIdx < pattern.length && strIdx < target.length) {
25
+ if (pattern.charAt(patternIdx).toLowerCase() === target.charAt(strIdx).toLowerCase()) patternIdx++;
26
+ ++strIdx;
27
+ }
28
+ return pattern.length !== 0 && target.length !== 0 && patternIdx === pattern.length;
25
29
  }
26
30
  function fuzzyMatchRecursive(pattern, target, patternCurIndex, targetCurrIndex, targetMatches, matches, maxMatches, nextMatch, recursionCount, recursionLimit) {
27
- let outScore = 0;
28
- if (++recursionCount >= recursionLimit) {
29
- return { matched: false, outScore };
30
- }
31
- if (patternCurIndex === pattern.length || targetCurrIndex === target.length) {
32
- return { matched: false, outScore };
33
- }
34
- let recursiveMatch = false;
35
- let bestRecursiveMatches = [];
36
- let bestRecursiveScore = 0;
37
- let firstMatch = true;
38
- while (patternCurIndex < pattern.length && targetCurrIndex < target.length) {
39
- if (pattern[patternCurIndex].toLowerCase() === target[targetCurrIndex].toLowerCase()) {
40
- if (nextMatch >= maxMatches) {
41
- return { matched: false, outScore };
42
- }
43
- if (firstMatch && targetMatches) {
44
- matches = [...targetMatches];
45
- firstMatch = false;
46
- }
47
- const recursiveMatches = [];
48
- const recursiveResult = fuzzyMatchRecursive(
49
- pattern,
50
- target,
51
- patternCurIndex,
52
- targetCurrIndex + 1,
53
- matches,
54
- recursiveMatches,
55
- maxMatches,
56
- nextMatch,
57
- recursionCount,
58
- recursionLimit
59
- );
60
- const recursiveScore = recursiveResult.outScore;
61
- if (recursiveResult.matched) {
62
- if (!recursiveMatch || recursiveScore > bestRecursiveScore) {
63
- bestRecursiveMatches = [...recursiveMatches];
64
- bestRecursiveScore = recursiveScore;
65
- }
66
- recursiveMatch = true;
67
- }
68
- matches[nextMatch++] = targetCurrIndex;
69
- ++patternCurIndex;
70
- }
71
- ++targetCurrIndex;
72
- }
73
- const matched = patternCurIndex === pattern.length;
74
- if (matched) {
75
- outScore = 100;
76
- if (!target.toLowerCase().startsWith("n8n")) {
77
- let penalty = LEADING_LETTER_PENALTY * matches[0];
78
- penalty = penalty < MAX_LEADING_LETTER_PENALTY ? MAX_LEADING_LETTER_PENALTY : penalty;
79
- outScore += penalty;
80
- }
81
- const unmatched = target.length - nextMatch;
82
- outScore += UNMATCHED_LETTER_PENALTY * unmatched;
83
- for (let i = 0; i < nextMatch; i++) {
84
- const currIdx = matches[i];
85
- if (i > 0) {
86
- const prevIdx = matches[i - 1];
87
- if (currIdx === prevIdx + 1) {
88
- outScore += SEQUENTIAL_BONUS;
89
- }
90
- }
91
- if (currIdx > 0) {
92
- const neighbor = target[currIdx - 1];
93
- const curr = target[currIdx];
94
- if (neighbor !== neighbor.toUpperCase() && curr !== curr.toLowerCase()) {
95
- outScore += CAMEL_BONUS;
96
- }
97
- const isNeighbourSeparator = neighbor === "_" || neighbor === " ";
98
- if (isNeighbourSeparator) {
99
- outScore += SEPARATOR_BONUS;
100
- }
101
- } else {
102
- outScore += FIRST_LETTER_BONUS;
103
- }
104
- }
105
- if (recursiveMatch && (!matched || bestRecursiveScore > outScore)) {
106
- matches = [...bestRecursiveMatches];
107
- outScore = bestRecursiveScore;
108
- return { matched: true, outScore };
109
- } else if (matched) {
110
- return { matched: true, outScore };
111
- } else {
112
- return { matched: false, outScore };
113
- }
114
- }
115
- return { matched: false, outScore };
31
+ let outScore = 0;
32
+ if (++recursionCount >= recursionLimit) return {
33
+ matched: false,
34
+ outScore
35
+ };
36
+ if (patternCurIndex === pattern.length || targetCurrIndex === target.length) return {
37
+ matched: false,
38
+ outScore
39
+ };
40
+ let recursiveMatch = false;
41
+ let bestRecursiveMatches = [];
42
+ let bestRecursiveScore = 0;
43
+ let firstMatch = true;
44
+ while (patternCurIndex < pattern.length && targetCurrIndex < target.length) {
45
+ if (pattern[patternCurIndex].toLowerCase() === target[targetCurrIndex].toLowerCase()) {
46
+ if (nextMatch >= maxMatches) return {
47
+ matched: false,
48
+ outScore
49
+ };
50
+ if (firstMatch && targetMatches) {
51
+ matches = [...targetMatches];
52
+ firstMatch = false;
53
+ }
54
+ const recursiveMatches = [];
55
+ const recursiveResult = fuzzyMatchRecursive(pattern, target, patternCurIndex, targetCurrIndex + 1, matches, recursiveMatches, maxMatches, nextMatch, recursionCount, recursionLimit);
56
+ const recursiveScore = recursiveResult.outScore;
57
+ if (recursiveResult.matched) {
58
+ if (!recursiveMatch || recursiveScore > bestRecursiveScore) {
59
+ bestRecursiveMatches = [...recursiveMatches];
60
+ bestRecursiveScore = recursiveScore;
61
+ }
62
+ recursiveMatch = true;
63
+ }
64
+ matches[nextMatch++] = targetCurrIndex;
65
+ ++patternCurIndex;
66
+ }
67
+ ++targetCurrIndex;
68
+ }
69
+ const matched = patternCurIndex === pattern.length;
70
+ if (matched) {
71
+ outScore = 100;
72
+ if (!target.toLowerCase().startsWith("n8n")) {
73
+ let penalty = LEADING_LETTER_PENALTY * matches[0];
74
+ penalty = penalty < MAX_LEADING_LETTER_PENALTY ? MAX_LEADING_LETTER_PENALTY : penalty;
75
+ outScore += penalty;
76
+ }
77
+ const unmatched = target.length - nextMatch;
78
+ outScore += UNMATCHED_LETTER_PENALTY * unmatched;
79
+ for (let i = 0; i < nextMatch; i++) {
80
+ const currIdx = matches[i];
81
+ if (i > 0) {
82
+ if (currIdx === matches[i - 1] + 1) outScore += SEQUENTIAL_BONUS;
83
+ }
84
+ if (currIdx > 0) {
85
+ const neighbor = target[currIdx - 1];
86
+ const curr = target[currIdx];
87
+ if (neighbor !== neighbor.toUpperCase() && curr !== curr.toLowerCase()) outScore += CAMEL_BONUS;
88
+ if (neighbor === "_" || neighbor === " ") outScore += SEPARATOR_BONUS;
89
+ } else outScore += FIRST_LETTER_BONUS;
90
+ }
91
+ if (recursiveMatch && (!matched || bestRecursiveScore > outScore)) {
92
+ matches = [...bestRecursiveMatches];
93
+ outScore = bestRecursiveScore;
94
+ return {
95
+ matched: true,
96
+ outScore
97
+ };
98
+ } else if (matched) return {
99
+ matched: true,
100
+ outScore
101
+ };
102
+ else return {
103
+ matched: false,
104
+ outScore
105
+ };
106
+ }
107
+ return {
108
+ matched: false,
109
+ outScore
110
+ };
116
111
  }
112
+ /**
113
+ * Does a fuzzy search to find pattern inside a string.
114
+ * @param {*} pattern string pattern to search for
115
+ * @param {*} target string string which is being searched
116
+ * @returns [boolean, number] a boolean which tells if pattern was
117
+ * found or not and a search score
118
+ */
117
119
  function fuzzyMatch(pattern, target) {
118
- const recursionCount = 0;
119
- const recursionLimit = 5;
120
- const matches = [];
121
- const maxMatches = 256;
122
- return fuzzyMatchRecursive(
123
- pattern,
124
- target,
125
- 0,
126
- 0,
127
- null,
128
- matches,
129
- maxMatches,
130
- 0,
131
- recursionCount,
132
- recursionLimit
133
- );
120
+ return fuzzyMatchRecursive(pattern, target, 0, 0, null, [], 256, 0, 0, 5);
134
121
  }
135
122
  function getValue(obj, prop) {
136
- if (obj.hasOwnProperty(prop)) {
137
- return obj[prop];
138
- }
139
- const segments = prop.split(".");
140
- let result = obj;
141
- let i = 0;
142
- while (result && i < segments.length) {
143
- const key = segments[i];
144
- result = result[key];
145
- i++;
146
- }
147
- return result;
123
+ if (obj.hasOwnProperty(prop)) return obj[prop];
124
+ const segments = prop.split(".");
125
+ let result = obj;
126
+ let i = 0;
127
+ while (result && i < segments.length) {
128
+ const key = segments[i];
129
+ result = result[key];
130
+ i++;
131
+ }
132
+ return result;
148
133
  }
149
134
  function sublimeSearch(filter, data, keys = DEFAULT_KEYS) {
150
- const results = data.reduce((accu, item) => {
151
- let values = [];
152
- keys.forEach(({ key, weight }) => {
153
- const value = getValue(item, key);
154
- if (Array.isArray(value)) {
155
- values = values.concat(value.map((v) => ({ value: v, weight })));
156
- } else if (typeof value === "string") {
157
- values.push({
158
- value,
159
- weight
160
- });
161
- }
162
- });
163
- const itemMatch = values.reduce(
164
- (result, { value, weight }) => {
165
- if (!fuzzyMatchSimple(filter, value)) {
166
- return result;
167
- }
168
- const match = fuzzyMatch(filter, value);
169
- match.outScore *= weight;
170
- const { matched, outScore } = match;
171
- if (!result && matched) {
172
- return match;
173
- }
174
- if (matched && result && outScore > result.outScore) {
175
- return match;
176
- }
177
- return result;
178
- },
179
- null
180
- );
181
- if (itemMatch) {
182
- accu.push({
183
- score: itemMatch.outScore,
184
- item
185
- });
186
- }
187
- return accu;
188
- }, []);
189
- results.sort((a, b) => {
190
- return b.score - a.score;
191
- });
192
- return results;
135
+ const results = data.reduce((accu, item) => {
136
+ let values = [];
137
+ keys.forEach(({ key, weight }) => {
138
+ const value = getValue(item, key);
139
+ if (Array.isArray(value)) values = values.concat(value.map((v) => ({
140
+ value: v,
141
+ weight
142
+ })));
143
+ else if (typeof value === "string") values.push({
144
+ value,
145
+ weight
146
+ });
147
+ });
148
+ const itemMatch = values.reduce((result, { value, weight }) => {
149
+ if (!fuzzyMatchSimple(filter, value)) return result;
150
+ const match = fuzzyMatch(filter, value);
151
+ match.outScore *= weight;
152
+ const { matched, outScore } = match;
153
+ if (!result && matched) return match;
154
+ if (matched && result && outScore > result.outScore) return match;
155
+ return result;
156
+ }, null);
157
+ if (itemMatch) accu.push({
158
+ score: itemMatch.outScore,
159
+ item
160
+ });
161
+ return accu;
162
+ }, []);
163
+ results.sort((a, b) => {
164
+ return b.score - a.score;
165
+ });
166
+ return results;
193
167
  }
194
- export {
195
- DEFAULT_KEYS,
196
- sublimeSearch
197
- };
168
+
169
+ //#endregion
170
+ export { DEFAULT_KEYS, sublimeSearch };
198
171
  //# sourceMappingURL=sublimeSearch.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/search/sublimeSearch.ts"],"sourcesContent":["/*\n * Constants and utility functions used for searching for node types in node creator component\n * based on https://github.com/forrestthewoods/lib_fts/blob/master/code/fts_fuzzy_match.js\n */\n\nconst SEQUENTIAL_BONUS = 60; // bonus for adjacent matches\nconst SEPARATOR_BONUS = 38; // bonus if match occurs after a separator\nconst CAMEL_BONUS = 30; // bonus if match is uppercase and prev is lower\nconst FIRST_LETTER_BONUS = 15; // bonus if the first letter is matched\n\nconst LEADING_LETTER_PENALTY = -20; // penalty applied for every letter in str before the first match\nconst MAX_LEADING_LETTER_PENALTY = -200; // maximum penalty for leading letters\nconst UNMATCHED_LETTER_PENALTY = -5;\n\nexport const DEFAULT_KEYS = [\n\t{ key: 'properties.displayName', weight: 1.3 },\n\t{ key: 'properties.codex.alias', weight: 1 },\n];\n\n/**\n * Returns true if each character in pattern is found sequentially within target\n * @param {*} pattern string\n * @param {*} target string\n */\nfunction fuzzyMatchSimple(pattern: string, target: string): boolean {\n\tlet patternIdx = 0;\n\tlet strIdx = 0;\n\n\twhile (patternIdx < pattern.length && strIdx < target.length) {\n\t\tconst patternChar = pattern.charAt(patternIdx).toLowerCase();\n\t\tconst targetChar = target.charAt(strIdx).toLowerCase();\n\t\tif (patternChar === targetChar) {\n\t\t\tpatternIdx++;\n\t\t}\n\t\t++strIdx;\n\t}\n\n\treturn pattern.length !== 0 && target.length !== 0 && patternIdx === pattern.length;\n}\n\nfunction fuzzyMatchRecursive(\n\tpattern: string,\n\ttarget: string,\n\tpatternCurIndex: number,\n\ttargetCurrIndex: number,\n\ttargetMatches: null | number[],\n\tmatches: number[],\n\tmaxMatches: number,\n\tnextMatch: number,\n\trecursionCount: number,\n\trecursionLimit: number,\n): { matched: boolean; outScore: number } {\n\tlet outScore = 0;\n\n\t// Return if recursion limit is reached.\n\tif (++recursionCount >= recursionLimit) {\n\t\treturn { matched: false, outScore };\n\t}\n\n\t// Return if we reached ends of strings.\n\tif (patternCurIndex === pattern.length || targetCurrIndex === target.length) {\n\t\treturn { matched: false, outScore };\n\t}\n\n\t// Recursion params\n\tlet recursiveMatch = false;\n\tlet bestRecursiveMatches: number[] = [];\n\tlet bestRecursiveScore = 0;\n\n\t// Loop through pattern and str looking for a match.\n\tlet firstMatch = true;\n\twhile (patternCurIndex < pattern.length && targetCurrIndex < target.length) {\n\t\t// Match found.\n\t\tif (pattern[patternCurIndex].toLowerCase() === target[targetCurrIndex].toLowerCase()) {\n\t\t\tif (nextMatch >= maxMatches) {\n\t\t\t\treturn { matched: false, outScore };\n\t\t\t}\n\n\t\t\tif (firstMatch && targetMatches) {\n\t\t\t\tmatches = [...targetMatches];\n\t\t\t\tfirstMatch = false;\n\t\t\t}\n\n\t\t\tconst recursiveMatches: number[] = [];\n\t\t\tconst recursiveResult = fuzzyMatchRecursive(\n\t\t\t\tpattern,\n\t\t\t\ttarget,\n\t\t\t\tpatternCurIndex,\n\t\t\t\ttargetCurrIndex + 1,\n\t\t\t\tmatches,\n\t\t\t\trecursiveMatches,\n\t\t\t\tmaxMatches,\n\t\t\t\tnextMatch,\n\t\t\t\trecursionCount,\n\t\t\t\trecursionLimit,\n\t\t\t);\n\n\t\t\tconst recursiveScore = recursiveResult.outScore;\n\t\t\tif (recursiveResult.matched) {\n\t\t\t\t// Pick best recursive score.\n\t\t\t\tif (!recursiveMatch || recursiveScore > bestRecursiveScore) {\n\t\t\t\t\tbestRecursiveMatches = [...recursiveMatches];\n\t\t\t\t\tbestRecursiveScore = recursiveScore;\n\t\t\t\t}\n\t\t\t\trecursiveMatch = true;\n\t\t\t}\n\n\t\t\tmatches[nextMatch++] = targetCurrIndex;\n\t\t\t++patternCurIndex;\n\t\t}\n\t\t++targetCurrIndex;\n\t}\n\n\tconst matched = patternCurIndex === pattern.length;\n\n\tif (matched) {\n\t\toutScore = 100;\n\n\t\t// Apply leading letter penalty (if not n8n-prefixed)\n\t\tif (!target.toLowerCase().startsWith('n8n')) {\n\t\t\tlet penalty = LEADING_LETTER_PENALTY * matches[0];\n\t\t\tpenalty = penalty < MAX_LEADING_LETTER_PENALTY ? MAX_LEADING_LETTER_PENALTY : penalty;\n\t\t\toutScore += penalty;\n\t\t}\n\n\t\t//Apply unmatched penalty\n\t\tconst unmatched = target.length - nextMatch;\n\t\toutScore += UNMATCHED_LETTER_PENALTY * unmatched;\n\n\t\t// Apply ordering bonuses\n\t\tfor (let i = 0; i < nextMatch; i++) {\n\t\t\tconst currIdx = matches[i];\n\n\t\t\tif (i > 0) {\n\t\t\t\tconst prevIdx = matches[i - 1];\n\t\t\t\tif (currIdx === prevIdx + 1) {\n\t\t\t\t\toutScore += SEQUENTIAL_BONUS;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Check for bonuses based on neighbor character value.\n\t\t\tif (currIdx > 0) {\n\t\t\t\t// Camel case\n\t\t\t\tconst neighbor = target[currIdx - 1];\n\t\t\t\tconst curr = target[currIdx];\n\t\t\t\tif (neighbor !== neighbor.toUpperCase() && curr !== curr.toLowerCase()) {\n\t\t\t\t\toutScore += CAMEL_BONUS;\n\t\t\t\t}\n\t\t\t\tconst isNeighbourSeparator = neighbor === '_' || neighbor === ' ';\n\t\t\t\tif (isNeighbourSeparator) {\n\t\t\t\t\toutScore += SEPARATOR_BONUS;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// First letter\n\t\t\t\toutScore += FIRST_LETTER_BONUS;\n\t\t\t}\n\t\t}\n\n\t\t// Return best result\n\t\tif (recursiveMatch && (!matched || bestRecursiveScore > outScore)) {\n\t\t\t// Recursive score is better than \"this\"\n\t\t\tmatches = [...bestRecursiveMatches];\n\t\t\toutScore = bestRecursiveScore;\n\t\t\treturn { matched: true, outScore };\n\t\t} else if (matched) {\n\t\t\t// \"this\" score is better than recursive\n\t\t\treturn { matched: true, outScore };\n\t\t} else {\n\t\t\treturn { matched: false, outScore };\n\t\t}\n\t}\n\treturn { matched: false, outScore };\n}\n\n/**\n * Does a fuzzy search to find pattern inside a string.\n * @param {*} pattern string pattern to search for\n * @param {*} target string string which is being searched\n * @returns [boolean, number] a boolean which tells if pattern was\n * found or not and a search score\n */\nfunction fuzzyMatch(pattern: string, target: string): { matched: boolean; outScore: number } {\n\tconst recursionCount = 0;\n\tconst recursionLimit = 5;\n\tconst matches: number[] = [];\n\tconst maxMatches = 256;\n\n\treturn fuzzyMatchRecursive(\n\t\tpattern,\n\t\ttarget,\n\t\t0 /* patternCurIndex */,\n\t\t0 /* strCurrIndex */,\n\t\tnull /* srcMatces */,\n\t\tmatches,\n\t\tmaxMatches,\n\t\t0 /* nextMatch */,\n\t\trecursionCount,\n\t\trecursionLimit,\n\t);\n}\n\n// prop = 'key'\n// prop = 'key1.key2'\n// prop = ['key1', 'key2']\nfunction getValue<T extends object>(obj: T, prop: string): unknown {\n\tif (obj.hasOwnProperty(prop)) {\n\t\treturn obj[prop as keyof T];\n\t}\n\n\tconst segments = prop.split('.');\n\n\tlet result = obj;\n\tlet i = 0;\n\twhile (result && i < segments.length) {\n\t\tconst key = segments[i] as keyof T;\n\t\tresult = result[key] as T;\n\t\ti++;\n\t}\n\treturn result;\n}\n\nexport function sublimeSearch<T extends object>(\n\tfilter: string,\n\tdata: readonly T[],\n\tkeys: Array<{ key: string; weight: number }> = DEFAULT_KEYS,\n): Array<{ score: number; item: T }> {\n\tconst results = data.reduce((accu: Array<{ score: number; item: T }>, item: T) => {\n\t\tlet values: Array<{ value: string; weight: number }> = [];\n\t\tkeys.forEach(({ key, weight }) => {\n\t\t\tconst value = getValue(item, key);\n\t\t\tif (Array.isArray(value)) {\n\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\tvalues = values.concat(value.map((v) => ({ value: v, weight })));\n\t\t\t} else if (typeof value === 'string') {\n\t\t\t\tvalues.push({\n\t\t\t\t\tvalue,\n\t\t\t\t\tweight,\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\n\t\t// for each item, check every key and get maximum score\n\t\tconst itemMatch = values.reduce(\n\t\t\t(\n\t\t\t\tresult: null | { matched: boolean; outScore: number },\n\t\t\t\t{ value, weight }: { value: string; weight: number },\n\t\t\t) => {\n\t\t\t\tif (!fuzzyMatchSimple(filter, value)) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tconst match = fuzzyMatch(filter, value);\n\t\t\t\tmatch.outScore *= weight;\n\n\t\t\t\tconst { matched, outScore } = match;\n\t\t\t\tif (!result && matched) {\n\t\t\t\t\treturn match;\n\t\t\t\t}\n\t\t\t\tif (matched && result && outScore > result.outScore) {\n\t\t\t\t\treturn match;\n\t\t\t\t}\n\t\t\t\treturn result;\n\t\t\t},\n\t\t\tnull,\n\t\t);\n\n\t\tif (itemMatch) {\n\t\t\taccu.push({\n\t\t\t\tscore: itemMatch.outScore,\n\t\t\t\titem,\n\t\t\t});\n\t\t}\n\n\t\treturn accu;\n\t}, []);\n\n\tresults.sort((a, b) => {\n\t\treturn b.score - a.score;\n\t});\n\n\treturn results;\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"file":"sublimeSearch.js","names":["bestRecursiveMatches: number[]","recursiveMatches: number[]","values: Array<{ value: string; weight: number }>"],"sources":["../../src/search/sublimeSearch.ts"],"sourcesContent":["/*\n * Constants and utility functions used for searching for node types in node creator component\n * based on https://github.com/forrestthewoods/lib_fts/blob/master/code/fts_fuzzy_match.js\n */\n\nconst SEQUENTIAL_BONUS = 60; // bonus for adjacent matches\nconst SEPARATOR_BONUS = 38; // bonus if match occurs after a separator\nconst CAMEL_BONUS = 30; // bonus if match is uppercase and prev is lower\nconst FIRST_LETTER_BONUS = 15; // bonus if the first letter is matched\n\nconst LEADING_LETTER_PENALTY = -20; // penalty applied for every letter in str before the first match\nconst MAX_LEADING_LETTER_PENALTY = -200; // maximum penalty for leading letters\nconst UNMATCHED_LETTER_PENALTY = -5;\n\nexport const DEFAULT_KEYS = [\n\t{ key: 'properties.displayName', weight: 1.3 },\n\t{ key: 'properties.codex.alias', weight: 1 },\n];\n\n/**\n * Returns true if each character in pattern is found sequentially within target\n * @param {*} pattern string\n * @param {*} target string\n */\nfunction fuzzyMatchSimple(pattern: string, target: string): boolean {\n\tlet patternIdx = 0;\n\tlet strIdx = 0;\n\n\twhile (patternIdx < pattern.length && strIdx < target.length) {\n\t\tconst patternChar = pattern.charAt(patternIdx).toLowerCase();\n\t\tconst targetChar = target.charAt(strIdx).toLowerCase();\n\t\tif (patternChar === targetChar) {\n\t\t\tpatternIdx++;\n\t\t}\n\t\t++strIdx;\n\t}\n\n\treturn pattern.length !== 0 && target.length !== 0 && patternIdx === pattern.length;\n}\n\nfunction fuzzyMatchRecursive(\n\tpattern: string,\n\ttarget: string,\n\tpatternCurIndex: number,\n\ttargetCurrIndex: number,\n\ttargetMatches: null | number[],\n\tmatches: number[],\n\tmaxMatches: number,\n\tnextMatch: number,\n\trecursionCount: number,\n\trecursionLimit: number,\n): { matched: boolean; outScore: number } {\n\tlet outScore = 0;\n\n\t// Return if recursion limit is reached.\n\tif (++recursionCount >= recursionLimit) {\n\t\treturn { matched: false, outScore };\n\t}\n\n\t// Return if we reached ends of strings.\n\tif (patternCurIndex === pattern.length || targetCurrIndex === target.length) {\n\t\treturn { matched: false, outScore };\n\t}\n\n\t// Recursion params\n\tlet recursiveMatch = false;\n\tlet bestRecursiveMatches: number[] = [];\n\tlet bestRecursiveScore = 0;\n\n\t// Loop through pattern and str looking for a match.\n\tlet firstMatch = true;\n\twhile (patternCurIndex < pattern.length && targetCurrIndex < target.length) {\n\t\t// Match found.\n\t\tif (pattern[patternCurIndex].toLowerCase() === target[targetCurrIndex].toLowerCase()) {\n\t\t\tif (nextMatch >= maxMatches) {\n\t\t\t\treturn { matched: false, outScore };\n\t\t\t}\n\n\t\t\tif (firstMatch && targetMatches) {\n\t\t\t\tmatches = [...targetMatches];\n\t\t\t\tfirstMatch = false;\n\t\t\t}\n\n\t\t\tconst recursiveMatches: number[] = [];\n\t\t\tconst recursiveResult = fuzzyMatchRecursive(\n\t\t\t\tpattern,\n\t\t\t\ttarget,\n\t\t\t\tpatternCurIndex,\n\t\t\t\ttargetCurrIndex + 1,\n\t\t\t\tmatches,\n\t\t\t\trecursiveMatches,\n\t\t\t\tmaxMatches,\n\t\t\t\tnextMatch,\n\t\t\t\trecursionCount,\n\t\t\t\trecursionLimit,\n\t\t\t);\n\n\t\t\tconst recursiveScore = recursiveResult.outScore;\n\t\t\tif (recursiveResult.matched) {\n\t\t\t\t// Pick best recursive score.\n\t\t\t\tif (!recursiveMatch || recursiveScore > bestRecursiveScore) {\n\t\t\t\t\tbestRecursiveMatches = [...recursiveMatches];\n\t\t\t\t\tbestRecursiveScore = recursiveScore;\n\t\t\t\t}\n\t\t\t\trecursiveMatch = true;\n\t\t\t}\n\n\t\t\tmatches[nextMatch++] = targetCurrIndex;\n\t\t\t++patternCurIndex;\n\t\t}\n\t\t++targetCurrIndex;\n\t}\n\n\tconst matched = patternCurIndex === pattern.length;\n\n\tif (matched) {\n\t\toutScore = 100;\n\n\t\t// Apply leading letter penalty (if not n8n-prefixed)\n\t\tif (!target.toLowerCase().startsWith('n8n')) {\n\t\t\tlet penalty = LEADING_LETTER_PENALTY * matches[0];\n\t\t\tpenalty = penalty < MAX_LEADING_LETTER_PENALTY ? MAX_LEADING_LETTER_PENALTY : penalty;\n\t\t\toutScore += penalty;\n\t\t}\n\n\t\t//Apply unmatched penalty\n\t\tconst unmatched = target.length - nextMatch;\n\t\toutScore += UNMATCHED_LETTER_PENALTY * unmatched;\n\n\t\t// Apply ordering bonuses\n\t\tfor (let i = 0; i < nextMatch; i++) {\n\t\t\tconst currIdx = matches[i];\n\n\t\t\tif (i > 0) {\n\t\t\t\tconst prevIdx = matches[i - 1];\n\t\t\t\tif (currIdx === prevIdx + 1) {\n\t\t\t\t\toutScore += SEQUENTIAL_BONUS;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Check for bonuses based on neighbor character value.\n\t\t\tif (currIdx > 0) {\n\t\t\t\t// Camel case\n\t\t\t\tconst neighbor = target[currIdx - 1];\n\t\t\t\tconst curr = target[currIdx];\n\t\t\t\tif (neighbor !== neighbor.toUpperCase() && curr !== curr.toLowerCase()) {\n\t\t\t\t\toutScore += CAMEL_BONUS;\n\t\t\t\t}\n\t\t\t\tconst isNeighbourSeparator = neighbor === '_' || neighbor === ' ';\n\t\t\t\tif (isNeighbourSeparator) {\n\t\t\t\t\toutScore += SEPARATOR_BONUS;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// First letter\n\t\t\t\toutScore += FIRST_LETTER_BONUS;\n\t\t\t}\n\t\t}\n\n\t\t// Return best result\n\t\tif (recursiveMatch && (!matched || bestRecursiveScore > outScore)) {\n\t\t\t// Recursive score is better than \"this\"\n\t\t\tmatches = [...bestRecursiveMatches];\n\t\t\toutScore = bestRecursiveScore;\n\t\t\treturn { matched: true, outScore };\n\t\t} else if (matched) {\n\t\t\t// \"this\" score is better than recursive\n\t\t\treturn { matched: true, outScore };\n\t\t} else {\n\t\t\treturn { matched: false, outScore };\n\t\t}\n\t}\n\treturn { matched: false, outScore };\n}\n\n/**\n * Does a fuzzy search to find pattern inside a string.\n * @param {*} pattern string pattern to search for\n * @param {*} target string string which is being searched\n * @returns [boolean, number] a boolean which tells if pattern was\n * found or not and a search score\n */\nfunction fuzzyMatch(pattern: string, target: string): { matched: boolean; outScore: number } {\n\tconst recursionCount = 0;\n\tconst recursionLimit = 5;\n\tconst matches: number[] = [];\n\tconst maxMatches = 256;\n\n\treturn fuzzyMatchRecursive(\n\t\tpattern,\n\t\ttarget,\n\t\t0 /* patternCurIndex */,\n\t\t0 /* strCurrIndex */,\n\t\tnull /* srcMatces */,\n\t\tmatches,\n\t\tmaxMatches,\n\t\t0 /* nextMatch */,\n\t\trecursionCount,\n\t\trecursionLimit,\n\t);\n}\n\n// prop = 'key'\n// prop = 'key1.key2'\n// prop = ['key1', 'key2']\nfunction getValue<T extends object>(obj: T, prop: string): unknown {\n\tif (obj.hasOwnProperty(prop)) {\n\t\treturn obj[prop as keyof T];\n\t}\n\n\tconst segments = prop.split('.');\n\n\tlet result = obj;\n\tlet i = 0;\n\twhile (result && i < segments.length) {\n\t\tconst key = segments[i] as keyof T;\n\t\tresult = result[key] as T;\n\t\ti++;\n\t}\n\treturn result;\n}\n\nexport function sublimeSearch<T extends object>(\n\tfilter: string,\n\tdata: readonly T[],\n\tkeys: Array<{ key: string; weight: number }> = DEFAULT_KEYS,\n): Array<{ score: number; item: T }> {\n\tconst results = data.reduce((accu: Array<{ score: number; item: T }>, item: T) => {\n\t\tlet values: Array<{ value: string; weight: number }> = [];\n\t\tkeys.forEach(({ key, weight }) => {\n\t\t\tconst value = getValue(item, key);\n\t\t\tif (Array.isArray(value)) {\n\t\t\t\t// eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n\t\t\t\tvalues = values.concat(value.map((v) => ({ value: v, weight })));\n\t\t\t} else if (typeof value === 'string') {\n\t\t\t\tvalues.push({\n\t\t\t\t\tvalue,\n\t\t\t\t\tweight,\n\t\t\t\t});\n\t\t\t}\n\t\t});\n\n\t\t// for each item, check every key and get maximum score\n\t\tconst itemMatch = values.reduce(\n\t\t\t(\n\t\t\t\tresult: null | { matched: boolean; outScore: number },\n\t\t\t\t{ value, weight }: { value: string; weight: number },\n\t\t\t) => {\n\t\t\t\tif (!fuzzyMatchSimple(filter, value)) {\n\t\t\t\t\treturn result;\n\t\t\t\t}\n\n\t\t\t\tconst match = fuzzyMatch(filter, value);\n\t\t\t\tmatch.outScore *= weight;\n\n\t\t\t\tconst { matched, outScore } = match;\n\t\t\t\tif (!result && matched) {\n\t\t\t\t\treturn match;\n\t\t\t\t}\n\t\t\t\tif (matched && result && outScore > result.outScore) {\n\t\t\t\t\treturn match;\n\t\t\t\t}\n\t\t\t\treturn result;\n\t\t\t},\n\t\t\tnull,\n\t\t);\n\n\t\tif (itemMatch) {\n\t\t\taccu.push({\n\t\t\t\tscore: itemMatch.outScore,\n\t\t\t\titem,\n\t\t\t});\n\t\t}\n\n\t\treturn accu;\n\t}, []);\n\n\tresults.sort((a, b) => {\n\t\treturn b.score - a.score;\n\t});\n\n\treturn results;\n}\n"],"mappings":"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"}
@@ -1,12 +1,13 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/sort/sortByProperty.ts
2
- var sortByProperty = (property, arr, order = "asc") => arr.sort((a, b) => {
3
- const result = String(a[property]).localeCompare(String(b[property]), void 0, {
4
- numeric: true,
5
- sensitivity: "base"
6
- });
7
- return order === "asc" ? result : -result;
8
- });
9
1
 
2
+ //#region src/sort/sortByProperty.ts
3
+ const sortByProperty = (property, arr, order = "asc") => arr.sort((a, b) => {
4
+ const result = String(a[property]).localeCompare(String(b[property]), void 0, {
5
+ numeric: true,
6
+ sensitivity: "base"
7
+ });
8
+ return order === "asc" ? result : -result;
9
+ });
10
10
 
11
+ //#endregion
11
12
  exports.sortByProperty = sortByProperty;
12
13
  //# sourceMappingURL=sortByProperty.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["/home/runner/work/n8n/n8n/packages/@n8n/utils/dist/sort/sortByProperty.cjs","../../src/sort/sortByProperty.ts"],"names":[],"mappings":"AAAA;ACAO,IAAM,eAAA,EAAiB,CAC7B,QAAA,EACA,GAAA,EACA,MAAA,EAAwB,KAAA,EAAA,GAExB,GAAA,CAAI,IAAA,CAAK,CAAC,CAAA,EAAG,CAAA,EAAA,GAAM;AAClB,EAAA,MAAM,OAAA,EAAS,MAAA,CAAO,CAAA,CAAE,QAAQ,CAAC,CAAA,CAAE,aAAA,CAAc,MAAA,CAAO,CAAA,CAAE,QAAQ,CAAC,CAAA,EAAG,KAAA,CAAA,EAAW;AAAA,IAChF,OAAA,EAAS,IAAA;AAAA,IACT,WAAA,EAAa;AAAA,EACd,CAAC,CAAA;AACD,EAAA,OAAO,MAAA,IAAU,MAAA,EAAQ,OAAA,EAAS,CAAC,MAAA;AACpC,CAAC,CAAA;ADHF;AACE;AACF,wCAAC","file":"/home/runner/work/n8n/n8n/packages/@n8n/utils/dist/sort/sortByProperty.cjs","sourcesContent":[null,"export const sortByProperty = <T>(\n\tproperty: keyof T,\n\tarr: T[],\n\torder: 'asc' | 'desc' = 'asc',\n): T[] =>\n\tarr.sort((a, b) => {\n\t\tconst result = String(a[property]).localeCompare(String(b[property]), undefined, {\n\t\t\tnumeric: true,\n\t\t\tsensitivity: 'base',\n\t\t});\n\t\treturn order === 'asc' ? result : -result;\n\t});\n"]}
1
+ {"version":3,"file":"sortByProperty.cjs","names":[],"sources":["../../src/sort/sortByProperty.ts"],"sourcesContent":["export const sortByProperty = <T>(\n\tproperty: keyof T,\n\tarr: T[],\n\torder: 'asc' | 'desc' = 'asc',\n): T[] =>\n\tarr.sort((a, b) => {\n\t\tconst result = String(a[property]).localeCompare(String(b[property]), undefined, {\n\t\t\tnumeric: true,\n\t\t\tsensitivity: 'base',\n\t\t});\n\t\treturn order === 'asc' ? result : -result;\n\t});\n"],"mappings":";;AAAA,MAAa,kBACZ,UACA,KACA,QAAwB,UAExB,IAAI,MAAM,GAAG,MAAM;CAClB,MAAM,SAAS,OAAO,EAAE,UAAU,CAAC,cAAc,OAAO,EAAE,UAAU,EAAE,QAAW;EAChF,SAAS;EACT,aAAa;EACb,CAAC;AACF,QAAO,UAAU,QAAQ,SAAS,CAAC;EAClC"}
@@ -1,3 +1,5 @@
1
+ //#region src/sort/sortByProperty.d.ts
1
2
  declare const sortByProperty: <T>(property: keyof T, arr: T[], order?: "asc" | "desc") => T[];
2
-
3
+ //#endregion
3
4
  export { sortByProperty };
5
+ //# sourceMappingURL=sortByProperty.d.cts.map
@@ -1,3 +1,5 @@
1
+ //#region src/sort/sortByProperty.d.ts
1
2
  declare const sortByProperty: <T>(property: keyof T, arr: T[], order?: "asc" | "desc") => T[];
2
-
3
+ //#endregion
3
4
  export { sortByProperty };
5
+ //# sourceMappingURL=sortByProperty.d.ts.map
@@ -1,12 +1,12 @@
1
- // src/sort/sortByProperty.ts
2
- var sortByProperty = (property, arr, order = "asc") => arr.sort((a, b) => {
3
- const result = String(a[property]).localeCompare(String(b[property]), void 0, {
4
- numeric: true,
5
- sensitivity: "base"
6
- });
7
- return order === "asc" ? result : -result;
1
+ //#region src/sort/sortByProperty.ts
2
+ const sortByProperty = (property, arr, order = "asc") => arr.sort((a, b) => {
3
+ const result = String(a[property]).localeCompare(String(b[property]), void 0, {
4
+ numeric: true,
5
+ sensitivity: "base"
6
+ });
7
+ return order === "asc" ? result : -result;
8
8
  });
9
- export {
10
- sortByProperty
11
- };
9
+
10
+ //#endregion
11
+ export { sortByProperty };
12
12
  //# sourceMappingURL=sortByProperty.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/sort/sortByProperty.ts"],"sourcesContent":["export const sortByProperty = <T>(\n\tproperty: keyof T,\n\tarr: T[],\n\torder: 'asc' | 'desc' = 'asc',\n): T[] =>\n\tarr.sort((a, b) => {\n\t\tconst result = String(a[property]).localeCompare(String(b[property]), undefined, {\n\t\t\tnumeric: true,\n\t\t\tsensitivity: 'base',\n\t\t});\n\t\treturn order === 'asc' ? result : -result;\n\t});\n"],"mappings":";AAAO,IAAM,iBAAiB,CAC7B,UACA,KACA,QAAwB,UAExB,IAAI,KAAK,CAAC,GAAG,MAAM;AAClB,QAAM,SAAS,OAAO,EAAE,QAAQ,CAAC,EAAE,cAAc,OAAO,EAAE,QAAQ,CAAC,GAAG,QAAW;AAAA,IAChF,SAAS;AAAA,IACT,aAAa;AAAA,EACd,CAAC;AACD,SAAO,UAAU,QAAQ,SAAS,CAAC;AACpC,CAAC;","names":[]}
1
+ {"version":3,"file":"sortByProperty.js","names":[],"sources":["../../src/sort/sortByProperty.ts"],"sourcesContent":["export const sortByProperty = <T>(\n\tproperty: keyof T,\n\tarr: T[],\n\torder: 'asc' | 'desc' = 'asc',\n): T[] =>\n\tarr.sort((a, b) => {\n\t\tconst result = String(a[property]).localeCompare(String(b[property]), undefined, {\n\t\t\tnumeric: true,\n\t\t\tsensitivity: 'base',\n\t\t});\n\t\treturn order === 'asc' ? result : -result;\n\t});\n"],"mappings":";AAAA,MAAa,kBACZ,UACA,KACA,QAAwB,UAExB,IAAI,MAAM,GAAG,MAAM;CAClB,MAAM,SAAS,OAAO,EAAE,UAAU,CAAC,cAAc,OAAO,EAAE,UAAU,EAAE,QAAW;EAChF,SAAS;EACT,aAAa;EACb,CAAC;AACF,QAAO,UAAU,QAAQ,SAAS,CAAC;EAClC"}
@@ -1,31 +1,31 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/string/truncate.ts
2
- var truncate = (text, length = 30) => text.length > length ? text.slice(0, length) + "..." : text;
1
+
2
+ //#region src/string/truncate.ts
3
+ const truncate = (text, length = 30) => text.length > length ? text.slice(0, length) + "..." : text;
4
+ /**
5
+ * Replace part of given text with ellipsis following the rules below:
6
+ *
7
+ * - Remove chars just before the last word, as long as the last word is under 15 chars
8
+ * - Otherwise preserve the last 5 chars of the name and remove chars before that
9
+ */
3
10
  function truncateBeforeLast(text, maxLength) {
4
- const chars = [];
5
- const segmenter = new Intl.Segmenter(void 0, { granularity: "grapheme" });
6
- for (const { segment } of segmenter.segment(text)) {
7
- chars.push(segment);
8
- }
9
- if (chars.length <= maxLength) {
10
- return text;
11
- }
12
- const lastWhitespaceIndex = chars.findLastIndex((ch) => ch.match(/^\s+$/));
13
- const lastWordIndex = lastWhitespaceIndex + 1;
14
- const lastWord = chars.slice(lastWordIndex);
15
- const ellipsis = "\u2026";
16
- const ellipsisLength = ellipsis.length;
17
- if (lastWord.length < 15) {
18
- const charsToRemove = chars.length - maxLength + ellipsisLength;
19
- const indexBeforeLastWord = lastWordIndex;
20
- const keepLength = indexBeforeLastWord - charsToRemove;
21
- if (keepLength > 0) {
22
- return chars.slice(0, keepLength).join("") + ellipsis + chars.slice(indexBeforeLastWord).join("");
23
- }
24
- }
25
- return chars.slice(0, maxLength - 5 - ellipsisLength).join("") + ellipsis + chars.slice(-5).join("");
11
+ const chars = [];
12
+ const segmenter = new Intl.Segmenter(void 0, { granularity: "grapheme" });
13
+ for (const { segment } of segmenter.segment(text)) chars.push(segment);
14
+ if (chars.length <= maxLength) return text;
15
+ const lastWordIndex = chars.findLastIndex((ch) => ch.match(/^\s+$/)) + 1;
16
+ const lastWord = chars.slice(lastWordIndex);
17
+ const ellipsis = "…";
18
+ const ellipsisLength = 1;
19
+ if (lastWord.length < 15) {
20
+ const charsToRemove = chars.length - maxLength + ellipsisLength;
21
+ const indexBeforeLastWord = lastWordIndex;
22
+ const keepLength = indexBeforeLastWord - charsToRemove;
23
+ if (keepLength > 0) return chars.slice(0, keepLength).join("") + ellipsis + chars.slice(indexBeforeLastWord).join("");
24
+ }
25
+ return chars.slice(0, maxLength - 5 - ellipsisLength).join("") + ellipsis + chars.slice(-5).join("");
26
26
  }
27
27
 
28
-
29
-
30
- exports.truncate = truncate; exports.truncateBeforeLast = truncateBeforeLast;
28
+ //#endregion
29
+ exports.truncate = truncate;
30
+ exports.truncateBeforeLast = truncateBeforeLast;
31
31
  //# sourceMappingURL=truncate.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["/home/runner/work/n8n/n8n/packages/@n8n/utils/dist/string/truncate.cjs","../../src/string/truncate.ts"],"names":[],"mappings":"AAAA;ACAO,IAAM,SAAA,EAAW,CAAC,IAAA,EAAc,OAAA,EAAS,EAAA,EAAA,GAC/C,IAAA,CAAK,OAAA,EAAS,OAAA,EAAS,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,MAAM,EAAA,EAAI,MAAA,EAAQ,IAAA;AAQjD,SAAS,kBAAA,CAAmB,IAAA,EAAc,SAAA,EAA2B;AAC3E,EAAA,MAAM,MAAA,EAAkB,CAAC,CAAA;AAEzB,EAAA,MAAM,UAAA,EAAY,IAAI,IAAA,CAAK,SAAA,CAAU,KAAA,CAAA,EAAW,EAAE,WAAA,EAAa,WAAW,CAAC,CAAA;AAE3E,EAAA,IAAA,CAAA,MAAW,EAAE,QAAQ,EAAA,GAAK,SAAA,CAAU,OAAA,CAAQ,IAAI,CAAA,EAAG;AAClD,IAAA,KAAA,CAAM,IAAA,CAAK,OAAO,CAAA;AAAA,EACnB;AAEA,EAAA,GAAA,CAAI,KAAA,CAAM,OAAA,GAAU,SAAA,EAAW;AAC9B,IAAA,OAAO,IAAA;AAAA,EACR;AAEA,EAAA,MAAM,oBAAA,EAAsB,KAAA,CAAM,aAAA,CAAc,CAAC,EAAA,EAAA,GAAO,EAAA,CAAG,KAAA,CAAM,OAAO,CAAC,CAAA;AACzE,EAAA,MAAM,cAAA,EAAgB,oBAAA,EAAsB,CAAA;AAC5C,EAAA,MAAM,SAAA,EAAW,KAAA,CAAM,KAAA,CAAM,aAAa,CAAA;AAC1C,EAAA,MAAM,SAAA,EAAW,QAAA;AACjB,EAAA,MAAM,eAAA,EAAiB,QAAA,CAAS,MAAA;AAEhC,EAAA,GAAA,CAAI,QAAA,CAAS,OAAA,EAAS,EAAA,EAAI;AACzB,IAAA,MAAM,cAAA,EAAgB,KAAA,CAAM,OAAA,EAAS,UAAA,EAAY,cAAA;AACjD,IAAA,MAAM,oBAAA,EAAsB,aAAA;AAC5B,IAAA,MAAM,WAAA,EAAa,oBAAA,EAAsB,aAAA;AAEzC,IAAA,GAAA,CAAI,WAAA,EAAa,CAAA,EAAG;AACnB,MAAA,OACC,KAAA,CAAM,KAAA,CAAM,CAAA,EAAG,UAAU,CAAA,CAAE,IAAA,CAAK,EAAE,EAAA,EAAI,SAAA,EAAW,KAAA,CAAM,KAAA,CAAM,mBAAmB,CAAA,CAAE,IAAA,CAAK,EAAE,CAAA;AAAA,IAE3F;AAAA,EACD;AAEA,EAAA,OACC,KAAA,CAAM,KAAA,CAAM,CAAA,EAAG,UAAA,EAAY,EAAA,EAAI,cAAc,CAAA,CAAE,IAAA,CAAK,EAAE,EAAA,EAAI,SAAA,EAAW,KAAA,CAAM,KAAA,CAAM,CAAA,CAAE,CAAA,CAAE,IAAA,CAAK,EAAE,CAAA;AAE9F;ADjBA;AACE;AACA;AACF,6EAAC","file":"/home/runner/work/n8n/n8n/packages/@n8n/utils/dist/string/truncate.cjs","sourcesContent":[null,"export const truncate = (text: string, length = 30): string =>\n\ttext.length > length ? text.slice(0, length) + '...' : text;\n\n/**\n * Replace part of given text with ellipsis following the rules below:\n *\n * - Remove chars just before the last word, as long as the last word is under 15 chars\n * - Otherwise preserve the last 5 chars of the name and remove chars before that\n */\nexport function truncateBeforeLast(text: string, maxLength: number): string {\n\tconst chars: string[] = [];\n\n\tconst segmenter = new Intl.Segmenter(undefined, { granularity: 'grapheme' });\n\n\tfor (const { segment } of segmenter.segment(text)) {\n\t\tchars.push(segment);\n\t}\n\n\tif (chars.length <= maxLength) {\n\t\treturn text;\n\t}\n\n\tconst lastWhitespaceIndex = chars.findLastIndex((ch) => ch.match(/^\\s+$/));\n\tconst lastWordIndex = lastWhitespaceIndex + 1;\n\tconst lastWord = chars.slice(lastWordIndex);\n\tconst ellipsis = '…';\n\tconst ellipsisLength = ellipsis.length;\n\n\tif (lastWord.length < 15) {\n\t\tconst charsToRemove = chars.length - maxLength + ellipsisLength;\n\t\tconst indexBeforeLastWord = lastWordIndex;\n\t\tconst keepLength = indexBeforeLastWord - charsToRemove;\n\n\t\tif (keepLength > 0) {\n\t\t\treturn (\n\t\t\t\tchars.slice(0, keepLength).join('') + ellipsis + chars.slice(indexBeforeLastWord).join('')\n\t\t\t);\n\t\t}\n\t}\n\n\treturn (\n\t\tchars.slice(0, maxLength - 5 - ellipsisLength).join('') + ellipsis + chars.slice(-5).join('')\n\t);\n}\n"]}
1
+ {"version":3,"file":"truncate.cjs","names":["chars: string[]"],"sources":["../../src/string/truncate.ts"],"sourcesContent":["export const truncate = (text: string, length = 30): string =>\n\ttext.length > length ? text.slice(0, length) + '...' : text;\n\n/**\n * Replace part of given text with ellipsis following the rules below:\n *\n * - Remove chars just before the last word, as long as the last word is under 15 chars\n * - Otherwise preserve the last 5 chars of the name and remove chars before that\n */\nexport function truncateBeforeLast(text: string, maxLength: number): string {\n\tconst chars: string[] = [];\n\n\tconst segmenter = new Intl.Segmenter(undefined, { granularity: 'grapheme' });\n\n\tfor (const { segment } of segmenter.segment(text)) {\n\t\tchars.push(segment);\n\t}\n\n\tif (chars.length <= maxLength) {\n\t\treturn text;\n\t}\n\n\tconst lastWhitespaceIndex = chars.findLastIndex((ch) => ch.match(/^\\s+$/));\n\tconst lastWordIndex = lastWhitespaceIndex + 1;\n\tconst lastWord = chars.slice(lastWordIndex);\n\tconst ellipsis = '…';\n\tconst ellipsisLength = ellipsis.length;\n\n\tif (lastWord.length < 15) {\n\t\tconst charsToRemove = chars.length - maxLength + ellipsisLength;\n\t\tconst indexBeforeLastWord = lastWordIndex;\n\t\tconst keepLength = indexBeforeLastWord - charsToRemove;\n\n\t\tif (keepLength > 0) {\n\t\t\treturn (\n\t\t\t\tchars.slice(0, keepLength).join('') + ellipsis + chars.slice(indexBeforeLastWord).join('')\n\t\t\t);\n\t\t}\n\t}\n\n\treturn (\n\t\tchars.slice(0, maxLength - 5 - ellipsisLength).join('') + ellipsis + chars.slice(-5).join('')\n\t);\n}\n"],"mappings":";;AAAA,MAAa,YAAY,MAAc,SAAS,OAC/C,KAAK,SAAS,SAAS,KAAK,MAAM,GAAG,OAAO,GAAG,QAAQ;;;;;;;AAQxD,SAAgB,mBAAmB,MAAc,WAA2B;CAC3E,MAAMA,QAAkB,EAAE;CAE1B,MAAM,YAAY,IAAI,KAAK,UAAU,QAAW,EAAE,aAAa,YAAY,CAAC;AAE5E,MAAK,MAAM,EAAE,aAAa,UAAU,QAAQ,KAAK,CAChD,OAAM,KAAK,QAAQ;AAGpB,KAAI,MAAM,UAAU,UACnB,QAAO;CAIR,MAAM,gBADsB,MAAM,eAAe,OAAO,GAAG,MAAM,QAAQ,CAAC,GAC9B;CAC5C,MAAM,WAAW,MAAM,MAAM,cAAc;CAC3C,MAAM,WAAW;CACjB,MAAM,iBAAiB;AAEvB,KAAI,SAAS,SAAS,IAAI;EACzB,MAAM,gBAAgB,MAAM,SAAS,YAAY;EACjD,MAAM,sBAAsB;EAC5B,MAAM,aAAa,sBAAsB;AAEzC,MAAI,aAAa,EAChB,QACC,MAAM,MAAM,GAAG,WAAW,CAAC,KAAK,GAAG,GAAG,WAAW,MAAM,MAAM,oBAAoB,CAAC,KAAK,GAAG;;AAK7F,QACC,MAAM,MAAM,GAAG,YAAY,IAAI,eAAe,CAAC,KAAK,GAAG,GAAG,WAAW,MAAM,MAAM,GAAG,CAAC,KAAK,GAAG"}
@@ -1,4 +1,6 @@
1
+ //#region src/string/truncate.d.ts
1
2
  declare const truncate: (text: string, length?: number) => string;
2
3
  declare function truncateBeforeLast(text: string, maxLength: number): string;
3
-
4
+ //#endregion
4
5
  export { truncate, truncateBeforeLast };
6
+ //# sourceMappingURL=truncate.d.cts.map
@@ -1,4 +1,6 @@
1
+ //#region src/string/truncate.d.ts
1
2
  declare const truncate: (text: string, length?: number) => string;
2
3
  declare function truncateBeforeLast(text: string, maxLength: number): string;
3
-
4
+ //#endregion
4
5
  export { truncate, truncateBeforeLast };
6
+ //# sourceMappingURL=truncate.d.ts.map