@ls-stack/utils 3.63.0 → 3.66.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 (328) hide show
  1. package/dist/{arrayUtils.d.cts → arrayUtils.d.mts} +24 -23
  2. package/dist/arrayUtils.mjs +249 -0
  3. package/dist/assertions-qMxfVhSu.mjs +207 -0
  4. package/dist/{assertions.d.ts → assertions.d.mts} +4 -3
  5. package/dist/assertions.mjs +3 -0
  6. package/dist/asyncQueue.d.mts +497 -0
  7. package/dist/asyncQueue.mjs +757 -0
  8. package/dist/{awaitDebounce.d.cts → awaitDebounce.d.mts} +11 -6
  9. package/dist/awaitDebounce.mjs +54 -0
  10. package/dist/{cache.d.ts → cache.d.mts} +76 -68
  11. package/dist/cache.mjs +355 -0
  12. package/dist/castValues-DfICShCc.mjs +19 -0
  13. package/dist/{castValues.d.cts → castValues.d.mts} +3 -2
  14. package/dist/castValues.mjs +3 -0
  15. package/dist/{concurrentCalls.d.ts → concurrentCalls.d.mts} +74 -65
  16. package/dist/concurrentCalls.mjs +295 -0
  17. package/dist/consoleFmt.d.mts +55 -0
  18. package/dist/consoleFmt.mjs +63 -0
  19. package/dist/conversions-DTmwEMIu.mjs +12 -0
  20. package/dist/conversions.d.mts +4 -0
  21. package/dist/conversions.mjs +3 -0
  22. package/dist/createThrottleController.d.mts +18 -0
  23. package/dist/createThrottleController.mjs +40 -0
  24. package/dist/debounce.d.mts +47 -0
  25. package/dist/debounce.mjs +117 -0
  26. package/dist/dedent.d.mts +74 -0
  27. package/dist/dedent.mjs +80 -0
  28. package/dist/deepEqual-C7EZEixx.mjs +78 -0
  29. package/dist/{deepEqual.d.cts → deepEqual.d.mts} +3 -2
  30. package/dist/deepEqual.mjs +3 -0
  31. package/dist/{deepReplaceValues.d.cts → deepReplaceValues.d.mts} +4 -3
  32. package/dist/deepReplaceValues.mjs +61 -0
  33. package/dist/diffParser.d.mts +63 -0
  34. package/dist/diffParser.mjs +410 -0
  35. package/dist/enhancedMap.d.mts +21 -0
  36. package/dist/enhancedMap.mjs +69 -0
  37. package/dist/exhaustiveMatch.d.mts +10 -0
  38. package/dist/exhaustiveMatch.mjs +48 -0
  39. package/dist/{filterObjectOrArrayKeys.d.cts → filterObjectOrArrayKeys.d.mts} +15 -8
  40. package/dist/filterObjectOrArrayKeys.mjs +497 -0
  41. package/dist/{getAutoIncrementId.d.cts → getAutoIncrementId.d.mts} +9 -5
  42. package/dist/getAutoIncrementId.mjs +53 -0
  43. package/dist/{getCompositeKey.d.cts → getCompositeKey.d.mts} +3 -2
  44. package/dist/getCompositeKey.mjs +50 -0
  45. package/dist/{getValueStableKey.d.cts → getValueStableKey.d.mts} +5 -3
  46. package/dist/getValueStableKey.mjs +17 -0
  47. package/dist/{hash.d.cts → hash.d.mts} +3 -2
  48. package/dist/hash.mjs +28 -0
  49. package/dist/interpolate.d.mts +17 -0
  50. package/dist/interpolate.mjs +28 -0
  51. package/dist/{iteratorUtils.d.cts → iteratorUtils.d.mts} +5 -4
  52. package/dist/iteratorUtils.mjs +39 -0
  53. package/dist/keepPrevIfUnchanged.d.mts +12 -0
  54. package/dist/keepPrevIfUnchanged.mjs +9 -0
  55. package/dist/keyedMap.d.mts +76 -0
  56. package/dist/keyedMap.mjs +139 -0
  57. package/dist/keyedSet.d.mts +77 -0
  58. package/dist/keyedSet.mjs +129 -0
  59. package/dist/{levenshtein.d.cts → levenshtein.d.mts} +3 -2
  60. package/dist/levenshtein.mjs +121 -0
  61. package/dist/main.d.mts +4 -0
  62. package/dist/main.mjs +7 -0
  63. package/dist/matchPath.d.mts +50 -0
  64. package/dist/matchPath.mjs +81 -0
  65. package/dist/mathUtils-BDP1lM_z.mjs +81 -0
  66. package/dist/{mathUtils.d.cts → mathUtils.d.mts} +3 -2
  67. package/dist/mathUtils.mjs +3 -0
  68. package/dist/{mutationUtils.d.cts → mutationUtils.d.mts} +6 -5
  69. package/dist/mutationUtils.mjs +44 -0
  70. package/dist/{objUtils.d.ts → objUtils.d.mts} +8 -6
  71. package/dist/objUtils.mjs +115 -0
  72. package/dist/parallelAsyncCalls.d.mts +83 -0
  73. package/dist/parallelAsyncCalls.mjs +121 -0
  74. package/dist/partialEqual.d.mts +139 -0
  75. package/dist/partialEqual.mjs +1055 -0
  76. package/dist/promiseUtils.d.mts +9 -0
  77. package/dist/promiseUtils.mjs +17 -0
  78. package/dist/regexUtils.d.mts +18 -0
  79. package/dist/regexUtils.mjs +34 -0
  80. package/dist/{retryOnError.d.cts → retryOnError.d.mts} +38 -37
  81. package/dist/retryOnError.mjs +91 -0
  82. package/dist/{runShellCmd.d.ts → runShellCmd.d.mts} +24 -15
  83. package/dist/runShellCmd.mjs +151 -0
  84. package/dist/{safeJson.d.cts → safeJson.d.mts} +3 -2
  85. package/dist/safeJson.mjs +30 -0
  86. package/dist/{saferTyping.d.cts → saferTyping.d.mts} +4 -3
  87. package/dist/saferTyping.mjs +45 -0
  88. package/dist/serializeXML.d.mts +23 -0
  89. package/dist/serializeXML.mjs +74 -0
  90. package/dist/{shallowEqual.d.cts → shallowEqual.d.mts} +3 -2
  91. package/dist/shallowEqual.mjs +54 -0
  92. package/dist/sleep.d.mts +4 -0
  93. package/dist/sleep.mjs +7 -0
  94. package/dist/stringUtils-DjhWOiYn.mjs +113 -0
  95. package/dist/{stringUtils.d.cts → stringUtils.d.mts} +3 -2
  96. package/dist/stringUtils.mjs +3 -0
  97. package/dist/{testUtils.d.ts → testUtils.d.mts} +83 -52
  98. package/dist/testUtils.mjs +310 -0
  99. package/dist/{throttle.d.ts → throttle.d.mts} +18 -17
  100. package/dist/throttle.mjs +102 -0
  101. package/dist/time-sr2lhQRw.mjs +67 -0
  102. package/dist/{time.d.ts → time.d.mts} +8 -7
  103. package/dist/time.mjs +3 -0
  104. package/dist/{timers.d.cts → timers.d.mts} +22 -13
  105. package/dist/timers.mjs +220 -0
  106. package/dist/{tsResult.d.cts → tsResult.d.mts} +52 -48
  107. package/dist/tsResult.mjs +142 -0
  108. package/dist/typeGuards-B1mzA-Rz.mjs +128 -0
  109. package/dist/{typeGuards.d.cts → typeGuards.d.mts} +3 -2
  110. package/dist/typeGuards.mjs +3 -0
  111. package/dist/{typeUtils.d.ts → typeUtils.d.mts} +13 -34
  112. package/dist/typeUtils.mjs +1 -0
  113. package/dist/{typedStrings.d.cts → typedStrings.d.mts} +5 -4
  114. package/dist/typedStrings.mjs +131 -0
  115. package/dist/typingFnUtils-Bb8drgKF.mjs +101 -0
  116. package/dist/{typingFnUtils.d.cts → typingFnUtils.d.mts} +13 -22
  117. package/dist/typingFnUtils.mjs +3 -0
  118. package/dist/{typingTestUtils.d.cts → typingTestUtils.d.mts} +11 -15
  119. package/dist/typingTestUtils.mjs +80 -0
  120. package/dist/typingUtils.d.mts +20 -0
  121. package/dist/typingUtils.mjs +1 -0
  122. package/dist/yamlStringify.d.mts +17 -0
  123. package/dist/yamlStringify.mjs +189 -0
  124. package/package.json +65 -234
  125. package/dist/arrayUtils.cjs +0 -229
  126. package/dist/arrayUtils.d.ts +0 -171
  127. package/dist/arrayUtils.js +0 -42
  128. package/dist/assertions.cjs +0 -107
  129. package/dist/assertions.d.cts +0 -192
  130. package/dist/assertions.js +0 -25
  131. package/dist/asyncQueue.cjs +0 -672
  132. package/dist/asyncQueue.d.cts +0 -488
  133. package/dist/asyncQueue.d.ts +0 -488
  134. package/dist/asyncQueue.js +0 -631
  135. package/dist/awaitDebounce.cjs +0 -106
  136. package/dist/awaitDebounce.d.ts +0 -41
  137. package/dist/awaitDebounce.js +0 -28
  138. package/dist/cache.cjs +0 -367
  139. package/dist/cache.d.cts +0 -228
  140. package/dist/cache.js +0 -19
  141. package/dist/castValues.cjs +0 -50
  142. package/dist/castValues.d.ts +0 -4
  143. package/dist/castValues.js +0 -8
  144. package/dist/chunk-5DZT3Z5Z.js +0 -8
  145. package/dist/chunk-6FBIEPWU.js +0 -96
  146. package/dist/chunk-6FIBVC2P.js +0 -56
  147. package/dist/chunk-7CQPOM5I.js +0 -100
  148. package/dist/chunk-B6DNOZCP.js +0 -369
  149. package/dist/chunk-BM4PYVOX.js +0 -109
  150. package/dist/chunk-C2SVCIWE.js +0 -57
  151. package/dist/chunk-CCUPDGSZ.js +0 -132
  152. package/dist/chunk-DBOWTYR4.js +0 -49
  153. package/dist/chunk-DFXNVEH6.js +0 -14
  154. package/dist/chunk-DX2524CZ.js +0 -314
  155. package/dist/chunk-GMJTLFM6.js +0 -60
  156. package/dist/chunk-IATIXMCE.js +0 -20
  157. package/dist/chunk-II4R3VVX.js +0 -25
  158. package/dist/chunk-JF2MDHOJ.js +0 -40
  159. package/dist/chunk-JQFUKJU5.js +0 -71
  160. package/dist/chunk-MI4UE2PQ.js +0 -561
  161. package/dist/chunk-PUKVXYYL.js +0 -52
  162. package/dist/chunk-QQS7I7ZL.js +0 -16
  163. package/dist/chunk-VAAMRG4K.js +0 -20
  164. package/dist/chunk-WFQJUJTC.js +0 -182
  165. package/dist/chunk-ZXIKIA5B.js +0 -178
  166. package/dist/concurrentCalls.cjs +0 -406
  167. package/dist/concurrentCalls.d.cts +0 -116
  168. package/dist/concurrentCalls.js +0 -346
  169. package/dist/consoleFmt.cjs +0 -85
  170. package/dist/consoleFmt.d.cts +0 -54
  171. package/dist/consoleFmt.d.ts +0 -54
  172. package/dist/consoleFmt.js +0 -60
  173. package/dist/conversions.cjs +0 -44
  174. package/dist/conversions.d.cts +0 -3
  175. package/dist/conversions.d.ts +0 -3
  176. package/dist/conversions.js +0 -6
  177. package/dist/createThrottleController.cjs +0 -193
  178. package/dist/createThrottleController.d.cts +0 -13
  179. package/dist/createThrottleController.d.ts +0 -13
  180. package/dist/createThrottleController.js +0 -61
  181. package/dist/debounce.cjs +0 -157
  182. package/dist/debounce.d.cts +0 -46
  183. package/dist/debounce.d.ts +0 -46
  184. package/dist/debounce.js +0 -8
  185. package/dist/dedent.cjs +0 -104
  186. package/dist/dedent.d.cts +0 -73
  187. package/dist/dedent.d.ts +0 -73
  188. package/dist/dedent.js +0 -79
  189. package/dist/deepEqual.cjs +0 -96
  190. package/dist/deepEqual.d.ts +0 -21
  191. package/dist/deepEqual.js +0 -8
  192. package/dist/deepReplaceValues.cjs +0 -87
  193. package/dist/deepReplaceValues.d.ts +0 -27
  194. package/dist/deepReplaceValues.js +0 -7
  195. package/dist/enhancedMap.cjs +0 -131
  196. package/dist/enhancedMap.d.cts +0 -20
  197. package/dist/enhancedMap.d.ts +0 -20
  198. package/dist/enhancedMap.js +0 -10
  199. package/dist/exhaustiveMatch.cjs +0 -66
  200. package/dist/exhaustiveMatch.d.cts +0 -9
  201. package/dist/exhaustiveMatch.d.ts +0 -9
  202. package/dist/exhaustiveMatch.js +0 -40
  203. package/dist/filterObjectOrArrayKeys.cjs +0 -619
  204. package/dist/filterObjectOrArrayKeys.d.ts +0 -88
  205. package/dist/filterObjectOrArrayKeys.js +0 -9
  206. package/dist/getAutoIncrementId.cjs +0 -44
  207. package/dist/getAutoIncrementId.d.ts +0 -46
  208. package/dist/getAutoIncrementId.js +0 -18
  209. package/dist/getCompositeKey.cjs +0 -86
  210. package/dist/getCompositeKey.d.ts +0 -11
  211. package/dist/getCompositeKey.js +0 -8
  212. package/dist/getValueStableKey.cjs +0 -89
  213. package/dist/getValueStableKey.d.ts +0 -15
  214. package/dist/getValueStableKey.js +0 -11
  215. package/dist/hash.cjs +0 -57
  216. package/dist/hash.d.ts +0 -7
  217. package/dist/hash.js +0 -32
  218. package/dist/interpolate.cjs +0 -88
  219. package/dist/interpolate.d.cts +0 -11
  220. package/dist/interpolate.d.ts +0 -11
  221. package/dist/interpolate.js +0 -46
  222. package/dist/iteratorUtils.cjs +0 -73
  223. package/dist/iteratorUtils.d.ts +0 -10
  224. package/dist/iteratorUtils.js +0 -44
  225. package/dist/keepPrevIfUnchanged.cjs +0 -102
  226. package/dist/keepPrevIfUnchanged.d.cts +0 -7
  227. package/dist/keepPrevIfUnchanged.d.ts +0 -7
  228. package/dist/keepPrevIfUnchanged.js +0 -7
  229. package/dist/levenshtein.cjs +0 -180
  230. package/dist/levenshtein.d.ts +0 -5
  231. package/dist/levenshtein.js +0 -153
  232. package/dist/main.cjs +0 -32
  233. package/dist/main.d.cts +0 -3
  234. package/dist/main.d.ts +0 -3
  235. package/dist/main.js +0 -7
  236. package/dist/matchPath.cjs +0 -155
  237. package/dist/matchPath.d.cts +0 -53
  238. package/dist/matchPath.d.ts +0 -53
  239. package/dist/matchPath.js +0 -108
  240. package/dist/mathUtils.cjs +0 -81
  241. package/dist/mathUtils.d.ts +0 -54
  242. package/dist/mathUtils.js +0 -22
  243. package/dist/mutationUtils.cjs +0 -153
  244. package/dist/mutationUtils.d.ts +0 -15
  245. package/dist/mutationUtils.js +0 -55
  246. package/dist/objUtils.cjs +0 -242
  247. package/dist/objUtils.d.cts +0 -28
  248. package/dist/objUtils.js +0 -38
  249. package/dist/parallelAsyncCalls.cjs +0 -162
  250. package/dist/parallelAsyncCalls.d.cts +0 -82
  251. package/dist/parallelAsyncCalls.d.ts +0 -82
  252. package/dist/parallelAsyncCalls.js +0 -126
  253. package/dist/partialEqual.cjs +0 -1196
  254. package/dist/partialEqual.d.cts +0 -141
  255. package/dist/partialEqual.d.ts +0 -141
  256. package/dist/partialEqual.js +0 -1168
  257. package/dist/promiseUtils.cjs +0 -38
  258. package/dist/promiseUtils.d.cts +0 -8
  259. package/dist/promiseUtils.d.ts +0 -8
  260. package/dist/promiseUtils.js +0 -6
  261. package/dist/regexUtils.cjs +0 -60
  262. package/dist/regexUtils.d.cts +0 -17
  263. package/dist/regexUtils.d.ts +0 -17
  264. package/dist/regexUtils.js +0 -33
  265. package/dist/retryOnError.cjs +0 -130
  266. package/dist/retryOnError.d.ts +0 -83
  267. package/dist/retryOnError.js +0 -101
  268. package/dist/runShellCmd.cjs +0 -127
  269. package/dist/runShellCmd.d.cts +0 -90
  270. package/dist/runShellCmd.js +0 -98
  271. package/dist/safeJson.cjs +0 -45
  272. package/dist/safeJson.d.ts +0 -16
  273. package/dist/safeJson.js +0 -8
  274. package/dist/saferTyping.cjs +0 -52
  275. package/dist/saferTyping.d.ts +0 -47
  276. package/dist/saferTyping.js +0 -23
  277. package/dist/serializeXML.cjs +0 -154
  278. package/dist/serializeXML.d.cts +0 -22
  279. package/dist/serializeXML.d.ts +0 -22
  280. package/dist/serializeXML.js +0 -116
  281. package/dist/shallowEqual.cjs +0 -88
  282. package/dist/shallowEqual.d.ts +0 -4
  283. package/dist/shallowEqual.js +0 -63
  284. package/dist/sleep.cjs +0 -32
  285. package/dist/sleep.d.cts +0 -3
  286. package/dist/sleep.d.ts +0 -3
  287. package/dist/sleep.js +0 -6
  288. package/dist/stringUtils.cjs +0 -155
  289. package/dist/stringUtils.d.ts +0 -55
  290. package/dist/stringUtils.js +0 -50
  291. package/dist/testUtils.cjs +0 -1490
  292. package/dist/testUtils.d.cts +0 -133
  293. package/dist/testUtils.js +0 -359
  294. package/dist/throttle.cjs +0 -282
  295. package/dist/throttle.d.cts +0 -98
  296. package/dist/throttle.js +0 -38
  297. package/dist/time.cjs +0 -152
  298. package/dist/time.d.cts +0 -25
  299. package/dist/time.js +0 -38
  300. package/dist/timers.cjs +0 -194
  301. package/dist/timers.d.ts +0 -121
  302. package/dist/timers.js +0 -156
  303. package/dist/tsResult.cjs +0 -226
  304. package/dist/tsResult.d.ts +0 -114
  305. package/dist/tsResult.js +0 -180
  306. package/dist/typeGuards.cjs +0 -70
  307. package/dist/typeGuards.d.ts +0 -111
  308. package/dist/typeGuards.js +0 -18
  309. package/dist/typeUtils.cjs +0 -18
  310. package/dist/typeUtils.d.cts +0 -61
  311. package/dist/typeUtils.js +0 -0
  312. package/dist/typedStrings.cjs +0 -90
  313. package/dist/typedStrings.d.ts +0 -163
  314. package/dist/typedStrings.js +0 -57
  315. package/dist/typingFnUtils.cjs +0 -96
  316. package/dist/typingFnUtils.d.ts +0 -100
  317. package/dist/typingFnUtils.js +0 -30
  318. package/dist/typingTestUtils.cjs +0 -52
  319. package/dist/typingTestUtils.d.ts +0 -79
  320. package/dist/typingTestUtils.js +0 -27
  321. package/dist/typingUtils.cjs +0 -18
  322. package/dist/typingUtils.d.cts +0 -35
  323. package/dist/typingUtils.d.ts +0 -35
  324. package/dist/typingUtils.js +0 -0
  325. package/dist/yamlStringify.cjs +0 -423
  326. package/dist/yamlStringify.d.cts +0 -10
  327. package/dist/yamlStringify.d.ts +0 -10
  328. package/dist/yamlStringify.js +0 -9
@@ -1,561 +0,0 @@
1
- import {
2
- sortBy
3
- } from "./chunk-WFQJUJTC.js";
4
- import {
5
- isPlainObject
6
- } from "./chunk-JF2MDHOJ.js";
7
-
8
- // src/filterObjectOrArrayKeys.ts
9
- var ID_PROP_REGEXP = /^(id_|key_|id-|key-)|(_id|_key|-id|-key)$/i;
10
- function filterObjectOrArrayKeys(objOrArray, {
11
- filterKeys,
12
- rejectKeys,
13
- rejectEmptyObjectsInArray = true,
14
- sortKeys = "simpleValuesFirst",
15
- sortPatterns
16
- }) {
17
- function getNestedValue(obj, path) {
18
- const parts = path.split(".");
19
- let current = obj;
20
- for (const part of parts) {
21
- if (current == null || typeof current !== "object") {
22
- return void 0;
23
- }
24
- current = current[part];
25
- }
26
- return current;
27
- }
28
- function evaluateCondition(item, condition) {
29
- const value = getNestedValue(item, condition.property);
30
- let valueStr = String(value);
31
- if (condition.caseInsensitive) {
32
- valueStr = valueStr.toLowerCase();
33
- }
34
- const processValue = (v) => condition.caseInsensitive ? v.toLowerCase() : v;
35
- switch (condition.operator) {
36
- case "=":
37
- return condition.values.some((v) => valueStr === processValue(v));
38
- case "!=":
39
- return condition.values.every((v) => valueStr !== processValue(v));
40
- case "*=":
41
- return condition.values.some((v) => valueStr.includes(processValue(v)));
42
- case "!*=":
43
- return condition.values.every(
44
- (v) => !valueStr.includes(processValue(v))
45
- );
46
- case "^=":
47
- return condition.values.some(
48
- (v) => valueStr.startsWith(processValue(v))
49
- );
50
- case "!^=":
51
- return condition.values.every(
52
- (v) => !valueStr.startsWith(processValue(v))
53
- );
54
- case "$=":
55
- return condition.values.some((v) => valueStr.endsWith(processValue(v)));
56
- case "!$=":
57
- return condition.values.every(
58
- (v) => !valueStr.endsWith(processValue(v))
59
- );
60
- default:
61
- return false;
62
- }
63
- }
64
- const toArray = (v) => v === void 0 ? [] : Array.isArray(v) ? v : [v];
65
- const filterPatternsRaw = toArray(filterKeys);
66
- const rejectPatternsRaw = toArray(rejectKeys);
67
- const hasFilters = filterPatternsRaw.length > 0;
68
- const hasRejects = rejectPatternsRaw.length > 0;
69
- const expandedFilterPatterns = filterPatternsRaw.flatMap(expandPatterns);
70
- const expandedRejectPatterns = rejectPatternsRaw.flatMap(expandPatterns);
71
- const { filterOnlyPatterns, combinedPatterns } = separateFilterPatterns(
72
- expandedFilterPatterns
73
- );
74
- const filterPatterns = filterOnlyPatterns.map(parsePattern);
75
- const rejectPatterns = expandedRejectPatterns.map(parsePattern);
76
- const sortPatternsRaw = toArray(sortPatterns);
77
- const expandedSortPatterns = sortPatternsRaw.flatMap(expandPatterns);
78
- const sortPatternsParsed = expandedSortPatterns.map(parsePattern);
79
- let dataToProcess = objOrArray;
80
- if (combinedPatterns.length > 0) {
81
- const groupedByFilter = /* @__PURE__ */ new Map();
82
- for (const { filterPart, fieldPart } of combinedPatterns) {
83
- if (!groupedByFilter.has(filterPart)) {
84
- groupedByFilter.set(filterPart, []);
85
- }
86
- groupedByFilter.get(filterPart).push(fieldPart);
87
- }
88
- const combinedResult = Array.isArray(objOrArray) ? [] : {};
89
- for (const [filterPart, fieldParts] of groupedByFilter) {
90
- const filteredResult = filterObjectOrArrayKeys(objOrArray, {
91
- filterKeys: [filterPart],
92
- rejectKeys,
93
- rejectEmptyObjectsInArray
94
- });
95
- const fieldSelectedResult = filterObjectOrArrayKeys(filteredResult, {
96
- filterKeys: fieldParts,
97
- rejectEmptyObjectsInArray
98
- });
99
- if (Array.isArray(combinedResult) && Array.isArray(fieldSelectedResult)) {
100
- combinedResult.push(...fieldSelectedResult);
101
- } else if (!Array.isArray(combinedResult) && !Array.isArray(fieldSelectedResult)) {
102
- Object.assign(combinedResult, fieldSelectedResult);
103
- }
104
- }
105
- if (filterOnlyPatterns.length === 0) {
106
- return combinedResult;
107
- }
108
- dataToProcess = combinedResult;
109
- }
110
- function matchPath(path, pattern, value) {
111
- function rec(pi, pti) {
112
- if (pti >= pattern.length) return pi === path.length;
113
- const pt = pattern[pti];
114
- if (pt.type === "WILDCARD_ANY") {
115
- if (rec(pi, pti + 1)) return true;
116
- if (pi < path.length) return rec(pi + 1, pti);
117
- return false;
118
- }
119
- if (pt.type === "WILDCARD_ONE") {
120
- let j = pi;
121
- let sawKey = false;
122
- while (j < path.length) {
123
- if (path[j].type === "KEY") sawKey = true;
124
- if (sawKey && rec(j, pti + 1)) return true;
125
- j += 1;
126
- }
127
- return false;
128
- }
129
- if (pi >= path.length) return false;
130
- const ct = path[pi];
131
- switch (pt.type) {
132
- case "KEY":
133
- if (ct.type === "KEY" && ct.name === pt.name)
134
- return rec(pi + 1, pti + 1);
135
- if (ct.type === "INDEX") return rec(pi + 1, pti);
136
- return false;
137
- case "INDEX":
138
- if (ct.type === "INDEX" && ct.index === pt.index)
139
- return rec(pi + 1, pti + 1);
140
- return false;
141
- case "INDEX_ANY":
142
- if (ct.type === "INDEX") return rec(pi + 1, pti + 1);
143
- return false;
144
- case "INDEX_RANGE":
145
- if (ct.type === "INDEX") {
146
- const okLower = ct.index >= pt.start;
147
- const okUpper = pt.end === null ? true : ct.index <= pt.end;
148
- if (okLower && okUpper) return rec(pi + 1, pti + 1);
149
- }
150
- return false;
151
- case "INDEX_FILTER":
152
- if (ct.type === "INDEX" && value !== void 0) {
153
- const results = pt.conditions.map(
154
- (cond) => evaluateCondition(value, cond)
155
- );
156
- const matches = pt.logic === "AND" ? results.every((r) => r) : results.some((r) => r);
157
- if (matches) return rec(pi + 1, pti + 1);
158
- }
159
- return false;
160
- }
161
- }
162
- return rec(0, 0);
163
- }
164
- const matchesAnyFilter = (path, value) => filterPatterns.some((p) => matchPath(path, p, value));
165
- const matchesAnyReject = (path, value) => rejectPatterns.some((p) => matchPath(path, p, value));
166
- function getSortPriority(path) {
167
- for (let i = 0; i < sortPatternsParsed.length; i++) {
168
- if (matchPath(path, sortPatternsParsed[i])) {
169
- return i;
170
- }
171
- }
172
- return sortPatternsParsed.length;
173
- }
174
- function applySortKeys(keys, obj, sortOrder) {
175
- if (sortOrder === "asc") {
176
- return [...keys].sort();
177
- }
178
- if (sortOrder === "desc") {
179
- return [...keys].sort().reverse();
180
- }
181
- return sortBy(
182
- sortBy(keys, (k) => k),
183
- (key) => {
184
- const value = obj[key];
185
- if (value !== void 0 && value !== null) {
186
- if (Array.isArray(value) && value.length === 0) return 0;
187
- if (isPlainObject(value)) {
188
- const objLength = Object.keys(value).length;
189
- return 1.99 + objLength * -1e-3;
190
- }
191
- if (Array.isArray(value)) {
192
- const allItemsArePrimitives = value.every(
193
- (item) => typeof item === "string" || typeof item === "number" || typeof item === "boolean" || item === null || item === void 0
194
- );
195
- if (allItemsArePrimitives) {
196
- return 1.9 + value.length * -1e-3;
197
- } else {
198
- return 1.5 + value.length * -0.01;
199
- }
200
- }
201
- if (key === "id" || key === "key") return 5;
202
- if (ID_PROP_REGEXP.test(key)) return 4.5;
203
- if (typeof value === "boolean") return 4;
204
- if (typeof value === "number") return 3.5;
205
- if (typeof value === "string" && value.length < 20) return 3;
206
- return 2;
207
- }
208
- return 0;
209
- },
210
- "desc"
211
- );
212
- }
213
- function sortKeysWithPatterns(keys_, obj, currentPath) {
214
- if (!sortKeys && sortPatternsParsed.length === 0) {
215
- return keys_;
216
- }
217
- let keysToSort = keys_;
218
- if (sortKeys) {
219
- keysToSort = applySortKeys(keysToSort, obj, sortKeys);
220
- }
221
- const sortedKeys = [...keysToSort].sort((a, b) => {
222
- const pathA = currentPath.concat({ type: "KEY", name: a });
223
- const pathB = currentPath.concat({ type: "KEY", name: b });
224
- const priorityA = getSortPriority(pathA);
225
- const priorityB = getSortPriority(pathB);
226
- if (priorityA !== priorityB) {
227
- return priorityA - priorityB;
228
- }
229
- if (sortKeys === "desc") {
230
- return b.localeCompare(a);
231
- }
232
- if (sortKeys === "asc") {
233
- return a.localeCompare(b);
234
- }
235
- return 0;
236
- });
237
- return sortedKeys;
238
- }
239
- const build = (value, path, allowedByFilter, stack2, isRoot, parentIsArray) => {
240
- if (Array.isArray(value)) {
241
- if (stack2.has(value)) {
242
- throw new TypeError("Circular references are not supported");
243
- }
244
- stack2.add(value);
245
- const out = [];
246
- const includeAllChildren = allowedByFilter || !hasFilters;
247
- for (let index = 0; index < value.length; index += 1) {
248
- const childPath = path.concat({ type: "INDEX", index });
249
- const child = value[index];
250
- if (hasRejects && matchesAnyReject(childPath, child)) continue;
251
- const directInclude = hasFilters ? matchesAnyFilter(childPath, child) : true;
252
- const childAllowed = includeAllChildren || directInclude;
253
- if (isPlainObject(child) || Array.isArray(child)) {
254
- const builtChild = build(
255
- child,
256
- childPath,
257
- childAllowed,
258
- stack2,
259
- false,
260
- true
261
- );
262
- if (builtChild !== void 0) {
263
- out.push(builtChild);
264
- }
265
- } else {
266
- if (childAllowed) {
267
- out.push(child);
268
- }
269
- }
270
- }
271
- stack2.delete(value);
272
- const filteredOut = rejectEmptyObjectsInArray ? out.filter(
273
- (item) => !(isPlainObject(item) && Object.keys(item).length === 0)
274
- ) : out;
275
- if (filteredOut.length === 0 && !allowedByFilter && !isRoot)
276
- return void 0;
277
- return filteredOut;
278
- }
279
- if (isPlainObject(value)) {
280
- if (stack2.has(value)) {
281
- throw new TypeError("Circular references are not supported");
282
- }
283
- stack2.add(value);
284
- const result = {};
285
- const includeAllChildren = allowedByFilter || !hasFilters;
286
- const sortedKeys = sortKeysWithPatterns(Object.keys(value), value, path);
287
- for (const key of sortedKeys) {
288
- const childPath = path.concat({ type: "KEY", name: key });
289
- if (hasRejects && matchesAnyReject(childPath)) continue;
290
- const val = value[key];
291
- const directInclude = hasFilters ? matchesAnyFilter(childPath) : true;
292
- const childAllowed = includeAllChildren || directInclude;
293
- if (isPlainObject(val) || Array.isArray(val)) {
294
- const builtChild = build(
295
- val,
296
- childPath,
297
- childAllowed,
298
- stack2,
299
- false,
300
- false
301
- );
302
- if (builtChild === void 0) {
303
- continue;
304
- }
305
- if (Array.isArray(builtChild) && builtChild.length === 0 && !childAllowed) {
306
- continue;
307
- }
308
- if (isPlainObject(builtChild) && Object.keys(builtChild).length === 0 && !childAllowed) {
309
- continue;
310
- }
311
- result[key] = builtChild;
312
- } else {
313
- if (childAllowed) {
314
- result[key] = val;
315
- }
316
- }
317
- }
318
- stack2.delete(value);
319
- if (Object.keys(result).length === 0 && !allowedByFilter && !isRoot) {
320
- if (parentIsArray && !rejectEmptyObjectsInArray) {
321
- return {};
322
- }
323
- return void 0;
324
- }
325
- return result;
326
- }
327
- return allowedByFilter || !hasFilters ? value : void 0;
328
- };
329
- const startPath = [];
330
- const initialAllowed = !hasFilters;
331
- const stack = /* @__PURE__ */ new WeakSet();
332
- const built = build(
333
- dataToProcess,
334
- startPath,
335
- initialAllowed,
336
- stack,
337
- true,
338
- false
339
- );
340
- if (built === void 0) return Array.isArray(dataToProcess) ? [] : {};
341
- return built;
342
- }
343
- function parseFilterConditions(filterContent) {
344
- const conditions = [];
345
- let logic = "AND";
346
- const caseInsensitive = filterContent.startsWith("i");
347
- const content = caseInsensitive ? filterContent.slice(1) : filterContent;
348
- const hasAnd = content.includes("&&");
349
- const hasOr = content.includes(" || ");
350
- if (hasAnd && hasOr) {
351
- throw new Error(
352
- "Mixing && and || operators in the same filter is not supported. Use separate filter patterns instead."
353
- );
354
- }
355
- const andGroups = content.split("&&").map((s) => s.trim());
356
- for (const andGroup of andGroups) {
357
- if (andGroup.includes(" || ")) {
358
- logic = "OR";
359
- const orConditions = andGroup.split(" || ").map((s) => s.trim());
360
- for (const orCondition of orConditions) {
361
- const parsed = parseSingleCondition(orCondition, caseInsensitive);
362
- if (parsed) {
363
- conditions.push(parsed);
364
- }
365
- }
366
- } else {
367
- const parsed = parseSingleCondition(andGroup, caseInsensitive);
368
- if (parsed) {
369
- conditions.push(parsed);
370
- }
371
- }
372
- }
373
- if (conditions.length === 0) {
374
- return null;
375
- }
376
- return {
377
- type: "INDEX_FILTER",
378
- conditions,
379
- logic
380
- };
381
- }
382
- function parseSingleCondition(condition, caseInsensitive = false) {
383
- const cleanCondition = condition.startsWith("%") ? condition.slice(1) : condition;
384
- let operator = null;
385
- let operatorIndex = -1;
386
- let operatorLength = 0;
387
- const operators = [
388
- ["!*=", "!*="],
389
- ["!^=", "!^="],
390
- ["!$=", "!$="],
391
- ["!=", "!="],
392
- ["*=", "*="],
393
- ["^=", "^="],
394
- ["$=", "$="],
395
- ["=", "="]
396
- ];
397
- for (const [op, opType] of operators) {
398
- const index = cleanCondition.indexOf(op);
399
- if (index !== -1) {
400
- operator = opType;
401
- operatorIndex = index;
402
- operatorLength = op.length;
403
- break;
404
- }
405
- }
406
- if (operator === null || operatorIndex === -1) {
407
- return null;
408
- }
409
- const property = cleanCondition.slice(0, operatorIndex).trim();
410
- const valueStr = cleanCondition.slice(operatorIndex + operatorLength).trim();
411
- const values = [];
412
- if (valueStr.includes(" | ")) {
413
- const parts = valueStr.split(" | ");
414
- for (const part of parts) {
415
- const trimmed = part.trim();
416
- const value = trimmed.startsWith('"') && trimmed.endsWith('"') ? trimmed.slice(1, -1) : trimmed;
417
- values.push(value);
418
- }
419
- } else {
420
- const trimmed = valueStr.trim();
421
- const value = trimmed.startsWith('"') && trimmed.endsWith('"') ? trimmed.slice(1, -1) : trimmed;
422
- values.push(value);
423
- }
424
- return {
425
- property,
426
- operator,
427
- values,
428
- caseInsensitive
429
- };
430
- }
431
- function separateFilterPatterns(patterns) {
432
- const filterOnlyPatterns = [];
433
- const combinedPatterns = [];
434
- for (const pattern of patterns) {
435
- const filterMatch = pattern.match(/^(.+\[[i%][^[\]]*\])\.(.+)$/);
436
- if (filterMatch?.[1] && filterMatch[2]) {
437
- const filterPart = filterMatch[1];
438
- const fieldPart = filterMatch[2];
439
- const baseArrayPath = filterPart.replace(/\[[i%][^[\]]*\]/, "[*]");
440
- combinedPatterns.push({
441
- filterPart,
442
- fieldPart: `${baseArrayPath}.${fieldPart}`
443
- });
444
- } else {
445
- filterOnlyPatterns.push(pattern);
446
- }
447
- }
448
- return { filterOnlyPatterns, combinedPatterns };
449
- }
450
- function expandPatterns(pattern) {
451
- function expandSingle(str) {
452
- const start = str.indexOf("(");
453
- if (start === -1) {
454
- return [str];
455
- }
456
- const end = str.indexOf(")", start);
457
- if (end === -1) {
458
- return [str];
459
- }
460
- const before = str.slice(0, start);
461
- const inside = str.slice(start + 1, end);
462
- const after = str.slice(end + 1);
463
- if (!inside.includes("|")) {
464
- return expandSingle(before + inside + after);
465
- }
466
- const options = inside.split("|").filter((option) => option.trim().length > 0);
467
- const results = [];
468
- for (const option of options) {
469
- const newStr = before + option + after;
470
- results.push(...expandSingle(newStr));
471
- }
472
- return results;
473
- }
474
- return expandSingle(pattern);
475
- }
476
- function parsePattern(pattern) {
477
- const tokens = [];
478
- let i = 0;
479
- const n = pattern.length;
480
- const pushKey = (name) => {
481
- if (name.length === 0) return;
482
- tokens.push({ type: "KEY", name });
483
- };
484
- while (i < n) {
485
- const ch = pattern[i];
486
- if (ch === ".") {
487
- i += 1;
488
- continue;
489
- }
490
- if (ch === "[") {
491
- const end = pattern.indexOf("]", i + 1);
492
- const inside = end === -1 ? pattern.slice(i + 1) : pattern.slice(i + 1, end);
493
- if (inside.startsWith("%") || inside.startsWith("i%")) {
494
- let filterContent;
495
- if (inside.startsWith("i%")) {
496
- filterContent = `i${inside.slice(2)}`;
497
- } else if (inside.startsWith("%")) {
498
- filterContent = inside.slice(1);
499
- } else {
500
- filterContent = inside;
501
- }
502
- const filterToken = parseFilterConditions(filterContent);
503
- if (filterToken) {
504
- tokens.push(filterToken);
505
- }
506
- } else if (inside === "*") {
507
- tokens.push({ type: "INDEX_ANY" });
508
- } else if (inside.includes("-")) {
509
- const parts = inside.split("-");
510
- const startStr = parts[0] ?? "";
511
- const endStr = parts[1] ?? "";
512
- const start = parseInt(startStr, 10);
513
- const endNum = endStr === "*" ? null : parseInt(endStr, 10);
514
- tokens.push({
515
- type: "INDEX_RANGE",
516
- start,
517
- end: endNum === null || Number.isFinite(endNum) ? endNum : null
518
- });
519
- } else if (inside.length > 0) {
520
- const idx = parseInt(inside, 10);
521
- tokens.push({ type: "INDEX", index: idx });
522
- }
523
- i = end === -1 ? n : end + 1;
524
- continue;
525
- }
526
- if (ch === "*") {
527
- if (pattern[i + 1] === "*") {
528
- tokens.push({ type: "WILDCARD_ANY" });
529
- i += 2;
530
- let j2 = i;
531
- while (j2 < n) {
532
- const c = pattern[j2];
533
- if (c === "." || c === "[") break;
534
- j2 += 1;
535
- }
536
- if (j2 > i) {
537
- pushKey(pattern.slice(i, j2));
538
- i = j2;
539
- }
540
- continue;
541
- } else {
542
- tokens.push({ type: "WILDCARD_ONE" });
543
- i += 1;
544
- continue;
545
- }
546
- }
547
- let j = i;
548
- while (j < n) {
549
- const c = pattern[j];
550
- if (c === "." || c === "[") break;
551
- j += 1;
552
- }
553
- pushKey(pattern.slice(i, j));
554
- i = j;
555
- }
556
- return tokens;
557
- }
558
-
559
- export {
560
- filterObjectOrArrayKeys
561
- };
@@ -1,52 +0,0 @@
1
- import {
2
- isPlainObject
3
- } from "./chunk-JF2MDHOJ.js";
4
-
5
- // src/deepReplaceValues.ts
6
- function applyValueReplacements(value, replaceValues, visited, currentPath) {
7
- function processValue(val, path) {
8
- const replacement = replaceValues(val, path);
9
- if (replacement !== false) {
10
- return replacement.newValue;
11
- }
12
- if (Array.isArray(val)) {
13
- if (visited.has(val)) {
14
- throw new Error("Circular reference detected in array");
15
- }
16
- visited.add(val);
17
- try {
18
- return val.map((item, index) => {
19
- const itemPath = path ? `${path}[${index}]` : `[${index}]`;
20
- return processValue(item, itemPath);
21
- });
22
- } finally {
23
- visited.delete(val);
24
- }
25
- }
26
- if (isPlainObject(val)) {
27
- if (visited.has(val)) {
28
- throw new Error("Circular reference detected in object");
29
- }
30
- visited.add(val);
31
- try {
32
- const result = {};
33
- for (const [key, itemValue] of Object.entries(val)) {
34
- const itemPath = path ? `${path}.${key}` : key;
35
- result[key] = processValue(itemValue, itemPath);
36
- }
37
- return result;
38
- } finally {
39
- visited.delete(val);
40
- }
41
- }
42
- return val;
43
- }
44
- return processValue(value, currentPath);
45
- }
46
- function deepReplaceValues(value, replaceValues) {
47
- return applyValueReplacements(value, replaceValues, /* @__PURE__ */ new Set(), "");
48
- }
49
-
50
- export {
51
- deepReplaceValues
52
- };
@@ -1,16 +0,0 @@
1
- import {
2
- deepEqual
3
- } from "./chunk-JQFUKJU5.js";
4
-
5
- // src/keepPrevIfUnchanged.ts
6
- function keepPrevIfUnchanged({
7
- prev,
8
- newValue,
9
- equalityFn = deepEqual
10
- }) {
11
- return equalityFn(prev, newValue) ? prev : newValue;
12
- }
13
-
14
- export {
15
- keepPrevIfUnchanged
16
- };
@@ -1,20 +0,0 @@
1
- // src/safeJson.ts
2
- function safeJsonStringify(value) {
3
- try {
4
- return JSON.stringify(value);
5
- } catch (_) {
6
- return void 0;
7
- }
8
- }
9
- function safeJsonParse(value) {
10
- try {
11
- return JSON.parse(value);
12
- } catch (_) {
13
- return void 0;
14
- }
15
- }
16
-
17
- export {
18
- safeJsonStringify,
19
- safeJsonParse
20
- };