@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,31 +1,29 @@
1
- // src/string/truncate.ts
2
- var truncate = (text, length = 30) => text.length > length ? text.slice(0, length) + "..." : text;
1
+ //#region src/string/truncate.ts
2
+ const truncate = (text, length = 30) => text.length > length ? text.slice(0, length) + "..." : text;
3
+ /**
4
+ * Replace part of given text with ellipsis following the rules below:
5
+ *
6
+ * - Remove chars just before the last word, as long as the last word is under 15 chars
7
+ * - Otherwise preserve the last 5 chars of the name and remove chars before that
8
+ */
3
9
  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("");
10
+ const chars = [];
11
+ const segmenter = new Intl.Segmenter(void 0, { granularity: "grapheme" });
12
+ for (const { segment } of segmenter.segment(text)) chars.push(segment);
13
+ if (chars.length <= maxLength) return text;
14
+ const lastWordIndex = chars.findLastIndex((ch) => ch.match(/^\s+$/)) + 1;
15
+ const lastWord = chars.slice(lastWordIndex);
16
+ const ellipsis = "…";
17
+ const ellipsisLength = 1;
18
+ if (lastWord.length < 15) {
19
+ const charsToRemove = chars.length - maxLength + ellipsisLength;
20
+ const indexBeforeLastWord = lastWordIndex;
21
+ const keepLength = indexBeforeLastWord - charsToRemove;
22
+ if (keepLength > 0) return chars.slice(0, keepLength).join("") + ellipsis + chars.slice(indexBeforeLastWord).join("");
23
+ }
24
+ return chars.slice(0, maxLength - 5 - ellipsisLength).join("") + ellipsis + chars.slice(-5).join("");
26
25
  }
27
- export {
28
- truncate,
29
- truncateBeforeLast
30
- };
26
+
27
+ //#endregion
28
+ export { truncate, truncateBeforeLast };
31
29
  //# sourceMappingURL=truncate.js.map
@@ -1 +1 @@
1
- {"version":3,"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":";AAAO,IAAM,WAAW,CAAC,MAAc,SAAS,OAC/C,KAAK,SAAS,SAAS,KAAK,MAAM,GAAG,MAAM,IAAI,QAAQ;AAQjD,SAAS,mBAAmB,MAAc,WAA2B;AAC3E,QAAM,QAAkB,CAAC;AAEzB,QAAM,YAAY,IAAI,KAAK,UAAU,QAAW,EAAE,aAAa,WAAW,CAAC;AAE3E,aAAW,EAAE,QAAQ,KAAK,UAAU,QAAQ,IAAI,GAAG;AAClD,UAAM,KAAK,OAAO;AAAA,EACnB;AAEA,MAAI,MAAM,UAAU,WAAW;AAC9B,WAAO;AAAA,EACR;AAEA,QAAM,sBAAsB,MAAM,cAAc,CAAC,OAAO,GAAG,MAAM,OAAO,CAAC;AACzE,QAAM,gBAAgB,sBAAsB;AAC5C,QAAM,WAAW,MAAM,MAAM,aAAa;AAC1C,QAAM,WAAW;AACjB,QAAM,iBAAiB,SAAS;AAEhC,MAAI,SAAS,SAAS,IAAI;AACzB,UAAM,gBAAgB,MAAM,SAAS,YAAY;AACjD,UAAM,sBAAsB;AAC5B,UAAM,aAAa,sBAAsB;AAEzC,QAAI,aAAa,GAAG;AACnB,aACC,MAAM,MAAM,GAAG,UAAU,EAAE,KAAK,EAAE,IAAI,WAAW,MAAM,MAAM,mBAAmB,EAAE,KAAK,EAAE;AAAA,IAE3F;AAAA,EACD;AAEA,SACC,MAAM,MAAM,GAAG,YAAY,IAAI,cAAc,EAAE,KAAK,EAAE,IAAI,WAAW,MAAM,MAAM,EAAE,EAAE,KAAK,EAAE;AAE9F;","names":[]}
1
+ {"version":3,"file":"truncate.js","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"}
package/package.json CHANGED
@@ -1,11 +1,11 @@
1
1
  {
2
2
  "name": "@n8n/utils",
3
3
  "type": "module",
4
- "version": "1.17.0",
4
+ "version": "1.18.0",
5
5
  "files": [
6
6
  "dist",
7
- "LICENSE_EE.md",
8
- "LICENSE.md"
7
+ "LICENSE.md",
8
+ "LICENSE_EE.md"
9
9
  ],
10
10
  "exports": {
11
11
  "./dist/*": {
@@ -22,12 +22,12 @@
22
22
  "devDependencies": {
23
23
  "@testing-library/jest-dom": "^6.6.3",
24
24
  "@testing-library/user-event": "^14.6.1",
25
- "tsup": "^8.5.0",
25
+ "tsdown": "^0.15.6",
26
26
  "typescript": "5.9.2",
27
- "vite": "^6.3.5",
27
+ "vite": "npm:rolldown-vite@latest",
28
28
  "vitest": "^3.1.3",
29
- "@n8n/typescript-config": "1.3.0",
30
29
  "@n8n/eslint-config": "0.0.1",
30
+ "@n8n/typescript-config": "1.3.0",
31
31
  "@n8n/vitest-config": "1.5.0"
32
32
  },
33
33
  "license": "SEE LICENSE IN LICENSE.md",
@@ -41,8 +41,8 @@
41
41
  "url": "git+https://github.com/n8n-io/n8n.git"
42
42
  },
43
43
  "scripts": {
44
- "dev": "vite",
45
- "build": "tsup",
44
+ "dev": "tsdown --watch",
45
+ "build": "tsdown",
46
46
  "preview": "vite preview",
47
47
  "typecheck": "tsc --noEmit",
48
48
  "test": "vitest run",