@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.
- package/dist/{arrayUtils.d.cts → arrayUtils.d.mts} +24 -23
- package/dist/arrayUtils.mjs +249 -0
- package/dist/assertions-qMxfVhSu.mjs +207 -0
- package/dist/{assertions.d.ts → assertions.d.mts} +4 -3
- package/dist/assertions.mjs +3 -0
- package/dist/asyncQueue.d.mts +497 -0
- package/dist/asyncQueue.mjs +757 -0
- package/dist/{awaitDebounce.d.cts → awaitDebounce.d.mts} +11 -6
- package/dist/awaitDebounce.mjs +54 -0
- package/dist/{cache.d.ts → cache.d.mts} +76 -68
- package/dist/cache.mjs +355 -0
- package/dist/castValues-DfICShCc.mjs +19 -0
- package/dist/{castValues.d.cts → castValues.d.mts} +3 -2
- package/dist/castValues.mjs +3 -0
- package/dist/{concurrentCalls.d.ts → concurrentCalls.d.mts} +74 -65
- package/dist/concurrentCalls.mjs +295 -0
- package/dist/consoleFmt.d.mts +55 -0
- package/dist/consoleFmt.mjs +63 -0
- package/dist/conversions-DTmwEMIu.mjs +12 -0
- package/dist/conversions.d.mts +4 -0
- package/dist/conversions.mjs +3 -0
- package/dist/createThrottleController.d.mts +18 -0
- package/dist/createThrottleController.mjs +40 -0
- package/dist/debounce.d.mts +47 -0
- package/dist/debounce.mjs +117 -0
- package/dist/dedent.d.mts +74 -0
- package/dist/dedent.mjs +80 -0
- package/dist/deepEqual-C7EZEixx.mjs +78 -0
- package/dist/{deepEqual.d.cts → deepEqual.d.mts} +3 -2
- package/dist/deepEqual.mjs +3 -0
- package/dist/{deepReplaceValues.d.cts → deepReplaceValues.d.mts} +4 -3
- package/dist/deepReplaceValues.mjs +61 -0
- package/dist/diffParser.d.mts +63 -0
- package/dist/diffParser.mjs +410 -0
- package/dist/enhancedMap.d.mts +21 -0
- package/dist/enhancedMap.mjs +69 -0
- package/dist/exhaustiveMatch.d.mts +10 -0
- package/dist/exhaustiveMatch.mjs +48 -0
- package/dist/{filterObjectOrArrayKeys.d.cts → filterObjectOrArrayKeys.d.mts} +15 -8
- package/dist/filterObjectOrArrayKeys.mjs +497 -0
- package/dist/{getAutoIncrementId.d.cts → getAutoIncrementId.d.mts} +9 -5
- package/dist/getAutoIncrementId.mjs +53 -0
- package/dist/{getCompositeKey.d.cts → getCompositeKey.d.mts} +3 -2
- package/dist/getCompositeKey.mjs +50 -0
- package/dist/{getValueStableKey.d.cts → getValueStableKey.d.mts} +5 -3
- package/dist/getValueStableKey.mjs +17 -0
- package/dist/{hash.d.cts → hash.d.mts} +3 -2
- package/dist/hash.mjs +28 -0
- package/dist/interpolate.d.mts +17 -0
- package/dist/interpolate.mjs +28 -0
- package/dist/{iteratorUtils.d.cts → iteratorUtils.d.mts} +5 -4
- package/dist/iteratorUtils.mjs +39 -0
- package/dist/keepPrevIfUnchanged.d.mts +12 -0
- package/dist/keepPrevIfUnchanged.mjs +9 -0
- package/dist/keyedMap.d.mts +76 -0
- package/dist/keyedMap.mjs +139 -0
- package/dist/keyedSet.d.mts +77 -0
- package/dist/keyedSet.mjs +129 -0
- package/dist/{levenshtein.d.cts → levenshtein.d.mts} +3 -2
- package/dist/levenshtein.mjs +121 -0
- package/dist/main.d.mts +4 -0
- package/dist/main.mjs +7 -0
- package/dist/matchPath.d.mts +50 -0
- package/dist/matchPath.mjs +81 -0
- package/dist/mathUtils-BDP1lM_z.mjs +81 -0
- package/dist/{mathUtils.d.cts → mathUtils.d.mts} +3 -2
- package/dist/mathUtils.mjs +3 -0
- package/dist/{mutationUtils.d.cts → mutationUtils.d.mts} +6 -5
- package/dist/mutationUtils.mjs +44 -0
- package/dist/{objUtils.d.ts → objUtils.d.mts} +8 -6
- package/dist/objUtils.mjs +115 -0
- package/dist/parallelAsyncCalls.d.mts +83 -0
- package/dist/parallelAsyncCalls.mjs +121 -0
- package/dist/partialEqual.d.mts +139 -0
- package/dist/partialEqual.mjs +1055 -0
- package/dist/promiseUtils.d.mts +9 -0
- package/dist/promiseUtils.mjs +17 -0
- package/dist/regexUtils.d.mts +18 -0
- package/dist/regexUtils.mjs +34 -0
- package/dist/{retryOnError.d.cts → retryOnError.d.mts} +38 -37
- package/dist/retryOnError.mjs +91 -0
- package/dist/{runShellCmd.d.ts → runShellCmd.d.mts} +24 -15
- package/dist/runShellCmd.mjs +151 -0
- package/dist/{safeJson.d.cts → safeJson.d.mts} +3 -2
- package/dist/safeJson.mjs +30 -0
- package/dist/{saferTyping.d.cts → saferTyping.d.mts} +4 -3
- package/dist/saferTyping.mjs +45 -0
- package/dist/serializeXML.d.mts +23 -0
- package/dist/serializeXML.mjs +74 -0
- package/dist/{shallowEqual.d.cts → shallowEqual.d.mts} +3 -2
- package/dist/shallowEqual.mjs +54 -0
- package/dist/sleep.d.mts +4 -0
- package/dist/sleep.mjs +7 -0
- package/dist/stringUtils-DjhWOiYn.mjs +113 -0
- package/dist/{stringUtils.d.cts → stringUtils.d.mts} +3 -2
- package/dist/stringUtils.mjs +3 -0
- package/dist/{testUtils.d.ts → testUtils.d.mts} +83 -52
- package/dist/testUtils.mjs +310 -0
- package/dist/{throttle.d.ts → throttle.d.mts} +18 -17
- package/dist/throttle.mjs +102 -0
- package/dist/time-sr2lhQRw.mjs +67 -0
- package/dist/{time.d.ts → time.d.mts} +8 -7
- package/dist/time.mjs +3 -0
- package/dist/{timers.d.cts → timers.d.mts} +22 -13
- package/dist/timers.mjs +220 -0
- package/dist/{tsResult.d.cts → tsResult.d.mts} +52 -48
- package/dist/tsResult.mjs +142 -0
- package/dist/typeGuards-B1mzA-Rz.mjs +128 -0
- package/dist/{typeGuards.d.cts → typeGuards.d.mts} +3 -2
- package/dist/typeGuards.mjs +3 -0
- package/dist/{typeUtils.d.ts → typeUtils.d.mts} +13 -34
- package/dist/typeUtils.mjs +1 -0
- package/dist/{typedStrings.d.cts → typedStrings.d.mts} +5 -4
- package/dist/typedStrings.mjs +131 -0
- package/dist/typingFnUtils-Bb8drgKF.mjs +101 -0
- package/dist/{typingFnUtils.d.cts → typingFnUtils.d.mts} +13 -22
- package/dist/typingFnUtils.mjs +3 -0
- package/dist/{typingTestUtils.d.cts → typingTestUtils.d.mts} +11 -15
- package/dist/typingTestUtils.mjs +80 -0
- package/dist/typingUtils.d.mts +20 -0
- package/dist/typingUtils.mjs +1 -0
- package/dist/yamlStringify.d.mts +17 -0
- package/dist/yamlStringify.mjs +189 -0
- package/package.json +65 -234
- package/dist/arrayUtils.cjs +0 -229
- package/dist/arrayUtils.d.ts +0 -171
- package/dist/arrayUtils.js +0 -42
- package/dist/assertions.cjs +0 -107
- package/dist/assertions.d.cts +0 -192
- package/dist/assertions.js +0 -25
- package/dist/asyncQueue.cjs +0 -672
- package/dist/asyncQueue.d.cts +0 -488
- package/dist/asyncQueue.d.ts +0 -488
- package/dist/asyncQueue.js +0 -631
- package/dist/awaitDebounce.cjs +0 -106
- package/dist/awaitDebounce.d.ts +0 -41
- package/dist/awaitDebounce.js +0 -28
- package/dist/cache.cjs +0 -367
- package/dist/cache.d.cts +0 -228
- package/dist/cache.js +0 -19
- package/dist/castValues.cjs +0 -50
- package/dist/castValues.d.ts +0 -4
- package/dist/castValues.js +0 -8
- package/dist/chunk-5DZT3Z5Z.js +0 -8
- package/dist/chunk-6FBIEPWU.js +0 -96
- package/dist/chunk-6FIBVC2P.js +0 -56
- package/dist/chunk-7CQPOM5I.js +0 -100
- package/dist/chunk-B6DNOZCP.js +0 -369
- package/dist/chunk-BM4PYVOX.js +0 -109
- package/dist/chunk-C2SVCIWE.js +0 -57
- package/dist/chunk-CCUPDGSZ.js +0 -132
- package/dist/chunk-DBOWTYR4.js +0 -49
- package/dist/chunk-DFXNVEH6.js +0 -14
- package/dist/chunk-DX2524CZ.js +0 -314
- package/dist/chunk-GMJTLFM6.js +0 -60
- package/dist/chunk-IATIXMCE.js +0 -20
- package/dist/chunk-II4R3VVX.js +0 -25
- package/dist/chunk-JF2MDHOJ.js +0 -40
- package/dist/chunk-JQFUKJU5.js +0 -71
- package/dist/chunk-MI4UE2PQ.js +0 -561
- package/dist/chunk-PUKVXYYL.js +0 -52
- package/dist/chunk-QQS7I7ZL.js +0 -16
- package/dist/chunk-VAAMRG4K.js +0 -20
- package/dist/chunk-WFQJUJTC.js +0 -182
- package/dist/chunk-ZXIKIA5B.js +0 -178
- package/dist/concurrentCalls.cjs +0 -406
- package/dist/concurrentCalls.d.cts +0 -116
- package/dist/concurrentCalls.js +0 -346
- package/dist/consoleFmt.cjs +0 -85
- package/dist/consoleFmt.d.cts +0 -54
- package/dist/consoleFmt.d.ts +0 -54
- package/dist/consoleFmt.js +0 -60
- package/dist/conversions.cjs +0 -44
- package/dist/conversions.d.cts +0 -3
- package/dist/conversions.d.ts +0 -3
- package/dist/conversions.js +0 -6
- package/dist/createThrottleController.cjs +0 -193
- package/dist/createThrottleController.d.cts +0 -13
- package/dist/createThrottleController.d.ts +0 -13
- package/dist/createThrottleController.js +0 -61
- package/dist/debounce.cjs +0 -157
- package/dist/debounce.d.cts +0 -46
- package/dist/debounce.d.ts +0 -46
- package/dist/debounce.js +0 -8
- package/dist/dedent.cjs +0 -104
- package/dist/dedent.d.cts +0 -73
- package/dist/dedent.d.ts +0 -73
- package/dist/dedent.js +0 -79
- package/dist/deepEqual.cjs +0 -96
- package/dist/deepEqual.d.ts +0 -21
- package/dist/deepEqual.js +0 -8
- package/dist/deepReplaceValues.cjs +0 -87
- package/dist/deepReplaceValues.d.ts +0 -27
- package/dist/deepReplaceValues.js +0 -7
- package/dist/enhancedMap.cjs +0 -131
- package/dist/enhancedMap.d.cts +0 -20
- package/dist/enhancedMap.d.ts +0 -20
- package/dist/enhancedMap.js +0 -10
- package/dist/exhaustiveMatch.cjs +0 -66
- package/dist/exhaustiveMatch.d.cts +0 -9
- package/dist/exhaustiveMatch.d.ts +0 -9
- package/dist/exhaustiveMatch.js +0 -40
- package/dist/filterObjectOrArrayKeys.cjs +0 -619
- package/dist/filterObjectOrArrayKeys.d.ts +0 -88
- package/dist/filterObjectOrArrayKeys.js +0 -9
- package/dist/getAutoIncrementId.cjs +0 -44
- package/dist/getAutoIncrementId.d.ts +0 -46
- package/dist/getAutoIncrementId.js +0 -18
- package/dist/getCompositeKey.cjs +0 -86
- package/dist/getCompositeKey.d.ts +0 -11
- package/dist/getCompositeKey.js +0 -8
- package/dist/getValueStableKey.cjs +0 -89
- package/dist/getValueStableKey.d.ts +0 -15
- package/dist/getValueStableKey.js +0 -11
- package/dist/hash.cjs +0 -57
- package/dist/hash.d.ts +0 -7
- package/dist/hash.js +0 -32
- package/dist/interpolate.cjs +0 -88
- package/dist/interpolate.d.cts +0 -11
- package/dist/interpolate.d.ts +0 -11
- package/dist/interpolate.js +0 -46
- package/dist/iteratorUtils.cjs +0 -73
- package/dist/iteratorUtils.d.ts +0 -10
- package/dist/iteratorUtils.js +0 -44
- package/dist/keepPrevIfUnchanged.cjs +0 -102
- package/dist/keepPrevIfUnchanged.d.cts +0 -7
- package/dist/keepPrevIfUnchanged.d.ts +0 -7
- package/dist/keepPrevIfUnchanged.js +0 -7
- package/dist/levenshtein.cjs +0 -180
- package/dist/levenshtein.d.ts +0 -5
- package/dist/levenshtein.js +0 -153
- package/dist/main.cjs +0 -32
- package/dist/main.d.cts +0 -3
- package/dist/main.d.ts +0 -3
- package/dist/main.js +0 -7
- package/dist/matchPath.cjs +0 -155
- package/dist/matchPath.d.cts +0 -53
- package/dist/matchPath.d.ts +0 -53
- package/dist/matchPath.js +0 -108
- package/dist/mathUtils.cjs +0 -81
- package/dist/mathUtils.d.ts +0 -54
- package/dist/mathUtils.js +0 -22
- package/dist/mutationUtils.cjs +0 -153
- package/dist/mutationUtils.d.ts +0 -15
- package/dist/mutationUtils.js +0 -55
- package/dist/objUtils.cjs +0 -242
- package/dist/objUtils.d.cts +0 -28
- package/dist/objUtils.js +0 -38
- package/dist/parallelAsyncCalls.cjs +0 -162
- package/dist/parallelAsyncCalls.d.cts +0 -82
- package/dist/parallelAsyncCalls.d.ts +0 -82
- package/dist/parallelAsyncCalls.js +0 -126
- package/dist/partialEqual.cjs +0 -1196
- package/dist/partialEqual.d.cts +0 -141
- package/dist/partialEqual.d.ts +0 -141
- package/dist/partialEqual.js +0 -1168
- package/dist/promiseUtils.cjs +0 -38
- package/dist/promiseUtils.d.cts +0 -8
- package/dist/promiseUtils.d.ts +0 -8
- package/dist/promiseUtils.js +0 -6
- package/dist/regexUtils.cjs +0 -60
- package/dist/regexUtils.d.cts +0 -17
- package/dist/regexUtils.d.ts +0 -17
- package/dist/regexUtils.js +0 -33
- package/dist/retryOnError.cjs +0 -130
- package/dist/retryOnError.d.ts +0 -83
- package/dist/retryOnError.js +0 -101
- package/dist/runShellCmd.cjs +0 -127
- package/dist/runShellCmd.d.cts +0 -90
- package/dist/runShellCmd.js +0 -98
- package/dist/safeJson.cjs +0 -45
- package/dist/safeJson.d.ts +0 -16
- package/dist/safeJson.js +0 -8
- package/dist/saferTyping.cjs +0 -52
- package/dist/saferTyping.d.ts +0 -47
- package/dist/saferTyping.js +0 -23
- package/dist/serializeXML.cjs +0 -154
- package/dist/serializeXML.d.cts +0 -22
- package/dist/serializeXML.d.ts +0 -22
- package/dist/serializeXML.js +0 -116
- package/dist/shallowEqual.cjs +0 -88
- package/dist/shallowEqual.d.ts +0 -4
- package/dist/shallowEqual.js +0 -63
- package/dist/sleep.cjs +0 -32
- package/dist/sleep.d.cts +0 -3
- package/dist/sleep.d.ts +0 -3
- package/dist/sleep.js +0 -6
- package/dist/stringUtils.cjs +0 -155
- package/dist/stringUtils.d.ts +0 -55
- package/dist/stringUtils.js +0 -50
- package/dist/testUtils.cjs +0 -1490
- package/dist/testUtils.d.cts +0 -133
- package/dist/testUtils.js +0 -359
- package/dist/throttle.cjs +0 -282
- package/dist/throttle.d.cts +0 -98
- package/dist/throttle.js +0 -38
- package/dist/time.cjs +0 -152
- package/dist/time.d.cts +0 -25
- package/dist/time.js +0 -38
- package/dist/timers.cjs +0 -194
- package/dist/timers.d.ts +0 -121
- package/dist/timers.js +0 -156
- package/dist/tsResult.cjs +0 -226
- package/dist/tsResult.d.ts +0 -114
- package/dist/tsResult.js +0 -180
- package/dist/typeGuards.cjs +0 -70
- package/dist/typeGuards.d.ts +0 -111
- package/dist/typeGuards.js +0 -18
- package/dist/typeUtils.cjs +0 -18
- package/dist/typeUtils.d.cts +0 -61
- package/dist/typeUtils.js +0 -0
- package/dist/typedStrings.cjs +0 -90
- package/dist/typedStrings.d.ts +0 -163
- package/dist/typedStrings.js +0 -57
- package/dist/typingFnUtils.cjs +0 -96
- package/dist/typingFnUtils.d.ts +0 -100
- package/dist/typingFnUtils.js +0 -30
- package/dist/typingTestUtils.cjs +0 -52
- package/dist/typingTestUtils.d.ts +0 -79
- package/dist/typingTestUtils.js +0 -27
- package/dist/typingUtils.cjs +0 -18
- package/dist/typingUtils.d.cts +0 -35
- package/dist/typingUtils.d.ts +0 -35
- package/dist/typingUtils.js +0 -0
- package/dist/yamlStringify.cjs +0 -423
- package/dist/yamlStringify.d.cts +0 -10
- package/dist/yamlStringify.d.ts +0 -10
- package/dist/yamlStringify.js +0 -9
package/dist/chunk-WFQJUJTC.js
DELETED
|
@@ -1,182 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
isFunction
|
|
3
|
-
} from "./chunk-C2SVCIWE.js";
|
|
4
|
-
|
|
5
|
-
// src/arrayUtils.ts
|
|
6
|
-
function filterAndMap(array, mapFilter) {
|
|
7
|
-
const result = [];
|
|
8
|
-
let i = -1;
|
|
9
|
-
for (const item of array) {
|
|
10
|
-
i += 1;
|
|
11
|
-
const filterResult = mapFilter(item, i);
|
|
12
|
-
if (filterResult !== false) {
|
|
13
|
-
result.push(filterResult);
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
return result;
|
|
17
|
-
}
|
|
18
|
-
function sortBy(arr, sortByValue, props = "asc") {
|
|
19
|
-
const order = Array.isArray(props) || typeof props === "string" ? props : props.order ?? "asc";
|
|
20
|
-
return [...arr].sort((a, b) => {
|
|
21
|
-
const _aPriority = sortByValue(a);
|
|
22
|
-
const _bPriority = sortByValue(b);
|
|
23
|
-
const aPriority = Array.isArray(_aPriority) ? _aPriority : [_aPriority];
|
|
24
|
-
const bPriority = Array.isArray(_bPriority) ? _bPriority : [_bPriority];
|
|
25
|
-
for (let i = 0; i < aPriority.length; i++) {
|
|
26
|
-
const levelOrder = typeof order === "string" ? order : order[i] ?? "asc";
|
|
27
|
-
const aP = aPriority[i] ?? 0;
|
|
28
|
-
const bP = bPriority[i] ?? 0;
|
|
29
|
-
if (aP === bP) {
|
|
30
|
-
continue;
|
|
31
|
-
}
|
|
32
|
-
if (bP === Infinity || aP === -Infinity || aP < bP) {
|
|
33
|
-
return levelOrder === "asc" ? -1 : 1;
|
|
34
|
-
}
|
|
35
|
-
if (aP === Infinity || bP === -Infinity || aP > bP) {
|
|
36
|
-
return levelOrder === "asc" ? 1 : -1;
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
return 0;
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
function getAscIndexOrder(index) {
|
|
43
|
-
return index === -1 ? Infinity : index ?? Infinity;
|
|
44
|
-
}
|
|
45
|
-
function arrayWithPrev(array) {
|
|
46
|
-
return array.map((item, i) => [item, array[i - 1] ?? null]);
|
|
47
|
-
}
|
|
48
|
-
function arrayWithPrevAndIndex(array) {
|
|
49
|
-
return array.map((item, i) => ({
|
|
50
|
-
item,
|
|
51
|
-
prev: array[i - 1] ?? null,
|
|
52
|
-
index: i
|
|
53
|
-
}));
|
|
54
|
-
}
|
|
55
|
-
function isInArray(value, oneOf) {
|
|
56
|
-
for (let i = 0; i < oneOf.length; i++) {
|
|
57
|
-
if (oneOf[i] === value) {
|
|
58
|
-
return true;
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
return false;
|
|
62
|
-
}
|
|
63
|
-
function isInArrayWithoutNarrowing(value, oneOf) {
|
|
64
|
-
return oneOf.includes(value);
|
|
65
|
-
}
|
|
66
|
-
function looseIsInArray(value, array) {
|
|
67
|
-
return array.includes(value);
|
|
68
|
-
}
|
|
69
|
-
function findAfterIndex(array, index, predicate) {
|
|
70
|
-
for (let i = index + 1; i < array.length; i++) {
|
|
71
|
-
if (predicate(array[i])) {
|
|
72
|
-
return array[i];
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
return void 0;
|
|
76
|
-
}
|
|
77
|
-
function findBeforeIndex(array, index, predicate) {
|
|
78
|
-
let indexToUse = index;
|
|
79
|
-
if (indexToUse >= array.length) {
|
|
80
|
-
indexToUse = array.length;
|
|
81
|
-
}
|
|
82
|
-
for (let i = indexToUse - 1; i >= 0; i--) {
|
|
83
|
-
if (predicate(array[i])) {
|
|
84
|
-
return array[i];
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
return void 0;
|
|
88
|
-
}
|
|
89
|
-
function rejectArrayUndefinedValues(array) {
|
|
90
|
-
return array.filter((item) => item !== void 0);
|
|
91
|
-
}
|
|
92
|
-
function hasDuplicates(array, getKey = (item) => item) {
|
|
93
|
-
const seen = /* @__PURE__ */ new Set();
|
|
94
|
-
for (const item of array) {
|
|
95
|
-
const key = getKey(item);
|
|
96
|
-
if (seen.has(key)) {
|
|
97
|
-
return true;
|
|
98
|
-
}
|
|
99
|
-
seen.add(key);
|
|
100
|
-
}
|
|
101
|
-
return false;
|
|
102
|
-
}
|
|
103
|
-
function rejectDuplicates(array, getKey = (item) => item) {
|
|
104
|
-
const seen = /* @__PURE__ */ new Set();
|
|
105
|
-
const result = [];
|
|
106
|
-
for (const item of array) {
|
|
107
|
-
const key = getKey(item);
|
|
108
|
-
if (seen.has(key)) {
|
|
109
|
-
continue;
|
|
110
|
-
}
|
|
111
|
-
seen.add(key);
|
|
112
|
-
result.push(item);
|
|
113
|
-
}
|
|
114
|
-
return result;
|
|
115
|
-
}
|
|
116
|
-
function truncateArray(array, maxLength, appendIfTruncated) {
|
|
117
|
-
const truncate = array.length > maxLength;
|
|
118
|
-
const result = truncate ? [...array.slice(0, maxLength)] : array;
|
|
119
|
-
if (truncate && appendIfTruncated) {
|
|
120
|
-
if (isFunction(appendIfTruncated)) {
|
|
121
|
-
return [...result, appendIfTruncated(array.length - maxLength)];
|
|
122
|
-
}
|
|
123
|
-
return [...result, appendIfTruncated];
|
|
124
|
-
}
|
|
125
|
-
return result;
|
|
126
|
-
}
|
|
127
|
-
function findAndMap(array, predicate) {
|
|
128
|
-
for (const item of array) {
|
|
129
|
-
const value = predicate(item);
|
|
130
|
-
if (value !== false) return value;
|
|
131
|
-
}
|
|
132
|
-
return void 0;
|
|
133
|
-
}
|
|
134
|
-
function arrayOps(array) {
|
|
135
|
-
return {
|
|
136
|
-
filterAndMap: (mapFilter) => filterAndMap(array, mapFilter),
|
|
137
|
-
sortBy: (sortByValue, props) => sortBy(array, sortByValue, props),
|
|
138
|
-
rejectDuplicates: (getKey) => rejectDuplicates(array, getKey),
|
|
139
|
-
findAndMap: (predicate) => findAndMap(array, predicate)
|
|
140
|
-
};
|
|
141
|
-
}
|
|
142
|
-
function intersperse(array, separator) {
|
|
143
|
-
const result = [];
|
|
144
|
-
for (let i = 0; i < array.length; i++) {
|
|
145
|
-
result.push(array[i]);
|
|
146
|
-
if (i < array.length - 1) {
|
|
147
|
-
result.push(separator);
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
return result;
|
|
151
|
-
}
|
|
152
|
-
function repeat(value, count, separator) {
|
|
153
|
-
const result = [];
|
|
154
|
-
for (let i = 0; i < count; i++) {
|
|
155
|
-
result.push(value);
|
|
156
|
-
if (separator !== void 0 && i < count - 1) {
|
|
157
|
-
result.push(separator);
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
return result;
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
export {
|
|
164
|
-
filterAndMap,
|
|
165
|
-
sortBy,
|
|
166
|
-
getAscIndexOrder,
|
|
167
|
-
arrayWithPrev,
|
|
168
|
-
arrayWithPrevAndIndex,
|
|
169
|
-
isInArray,
|
|
170
|
-
isInArrayWithoutNarrowing,
|
|
171
|
-
looseIsInArray,
|
|
172
|
-
findAfterIndex,
|
|
173
|
-
findBeforeIndex,
|
|
174
|
-
rejectArrayUndefinedValues,
|
|
175
|
-
hasDuplicates,
|
|
176
|
-
rejectDuplicates,
|
|
177
|
-
truncateArray,
|
|
178
|
-
findAndMap,
|
|
179
|
-
arrayOps,
|
|
180
|
-
intersperse,
|
|
181
|
-
repeat
|
|
182
|
-
};
|
package/dist/chunk-ZXIKIA5B.js
DELETED
|
@@ -1,178 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
typedObjectEntries
|
|
3
|
-
} from "./chunk-GMJTLFM6.js";
|
|
4
|
-
import {
|
|
5
|
-
sortBy
|
|
6
|
-
} from "./chunk-WFQJUJTC.js";
|
|
7
|
-
|
|
8
|
-
// src/objUtils.ts
|
|
9
|
-
import { Result } from "t-result";
|
|
10
|
-
function objectTypedEntries(obj) {
|
|
11
|
-
return Object.entries(obj);
|
|
12
|
-
}
|
|
13
|
-
function pick(obj, keys) {
|
|
14
|
-
const result = {};
|
|
15
|
-
for (const key of keys) {
|
|
16
|
-
result[key] = obj[key];
|
|
17
|
-
}
|
|
18
|
-
return result;
|
|
19
|
-
}
|
|
20
|
-
function mapArrToObj(array, mapper) {
|
|
21
|
-
return Object.fromEntries(array.map(mapper));
|
|
22
|
-
}
|
|
23
|
-
var mapArrayToObject = mapArrToObj;
|
|
24
|
-
function mapObjToObj(obj, mapper) {
|
|
25
|
-
return Object.fromEntries(
|
|
26
|
-
objectTypedEntries(obj).map(([key, value]) => mapper(key, value))
|
|
27
|
-
);
|
|
28
|
-
}
|
|
29
|
-
var mapObjectToObject = mapObjToObj;
|
|
30
|
-
function omit(obj, keys) {
|
|
31
|
-
const result = {};
|
|
32
|
-
for (const key of Object.keys(obj)) {
|
|
33
|
-
if (!keys.includes(key)) {
|
|
34
|
-
result[key] = obj[key];
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
return result;
|
|
38
|
-
}
|
|
39
|
-
function looseGetObjectProperty(obj, key) {
|
|
40
|
-
return obj[key];
|
|
41
|
-
}
|
|
42
|
-
function rejectObjUndefinedValues(obj) {
|
|
43
|
-
const result = {};
|
|
44
|
-
for (const key in obj) {
|
|
45
|
-
if (obj[key] !== void 0) {
|
|
46
|
-
result[key] = obj[key];
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
return result;
|
|
50
|
-
}
|
|
51
|
-
function filterObjectKeys(obj, predicate) {
|
|
52
|
-
return Object.fromEntries(
|
|
53
|
-
Object.entries(obj).filter(
|
|
54
|
-
([key, value]) => predicate(key, value)
|
|
55
|
-
)
|
|
56
|
-
);
|
|
57
|
-
}
|
|
58
|
-
function sortObjectKeys(obj, sortByFn, options) {
|
|
59
|
-
return Object.fromEntries(
|
|
60
|
-
sortBy(typedObjectEntries(obj), sortByFn, options)
|
|
61
|
-
);
|
|
62
|
-
}
|
|
63
|
-
function getValueFromPath(obj, path) {
|
|
64
|
-
if (!path.trim()) {
|
|
65
|
-
return Result.err(new Error("Path cannot be empty"));
|
|
66
|
-
}
|
|
67
|
-
const segments = parsePath(path);
|
|
68
|
-
let current = obj;
|
|
69
|
-
for (let i = 0; i < segments.length; i++) {
|
|
70
|
-
const segment = segments[i];
|
|
71
|
-
if (!segment) {
|
|
72
|
-
return Result.err(new Error("Invalid empty segment in path"));
|
|
73
|
-
}
|
|
74
|
-
if (current == null) {
|
|
75
|
-
return Result.err(
|
|
76
|
-
new Error(`Cannot access property '${segment}' on null or undefined`)
|
|
77
|
-
);
|
|
78
|
-
}
|
|
79
|
-
if (isNumericString(segment)) {
|
|
80
|
-
if (!Array.isArray(current)) {
|
|
81
|
-
return Result.err(
|
|
82
|
-
new Error(
|
|
83
|
-
`Cannot access array index '${segment}' on non-array value`
|
|
84
|
-
)
|
|
85
|
-
);
|
|
86
|
-
}
|
|
87
|
-
const index = parseInt(segment, 10);
|
|
88
|
-
if (index < 0 || index >= current.length) {
|
|
89
|
-
return Result.err(new Error(`Array index '${index}' out of bounds`));
|
|
90
|
-
}
|
|
91
|
-
current = current[index];
|
|
92
|
-
} else {
|
|
93
|
-
if (typeof current !== "object" || current === null) {
|
|
94
|
-
return Result.err(
|
|
95
|
-
new Error(`Cannot access property '${segment}' on non-object value`)
|
|
96
|
-
);
|
|
97
|
-
}
|
|
98
|
-
if (!(segment in current)) {
|
|
99
|
-
return Result.err(new Error(`Property '${segment}' not found`));
|
|
100
|
-
}
|
|
101
|
-
current = current[segment];
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
return Result.ok(current);
|
|
105
|
-
}
|
|
106
|
-
function parsePath(path) {
|
|
107
|
-
const segments = [];
|
|
108
|
-
let current = "";
|
|
109
|
-
let inBrackets = false;
|
|
110
|
-
for (let i = 0; i < path.length; i++) {
|
|
111
|
-
const char = path[i];
|
|
112
|
-
if (char === "[") {
|
|
113
|
-
if (current) {
|
|
114
|
-
segments.push(current);
|
|
115
|
-
current = "";
|
|
116
|
-
}
|
|
117
|
-
inBrackets = true;
|
|
118
|
-
} else if (char === "]") {
|
|
119
|
-
if (inBrackets && current) {
|
|
120
|
-
segments.push(current);
|
|
121
|
-
current = "";
|
|
122
|
-
}
|
|
123
|
-
inBrackets = false;
|
|
124
|
-
} else if (char === "." && !inBrackets) {
|
|
125
|
-
if (current) {
|
|
126
|
-
segments.push(current);
|
|
127
|
-
current = "";
|
|
128
|
-
}
|
|
129
|
-
} else {
|
|
130
|
-
current += char;
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
if (current) {
|
|
134
|
-
segments.push(current);
|
|
135
|
-
}
|
|
136
|
-
return segments;
|
|
137
|
-
}
|
|
138
|
-
function isNumericString(str) {
|
|
139
|
-
return /^\d+$/.test(str);
|
|
140
|
-
}
|
|
141
|
-
function getObjPropertyOrInsert(obj, prop, insertValue) {
|
|
142
|
-
if (obj[prop] === void 0) {
|
|
143
|
-
obj[prop] = insertValue();
|
|
144
|
-
}
|
|
145
|
-
return obj[prop];
|
|
146
|
-
}
|
|
147
|
-
function addPrefixToObjKeys(obj, prefix) {
|
|
148
|
-
const newObj = {};
|
|
149
|
-
for (const [key, value] of Object.entries(obj)) {
|
|
150
|
-
newObj[`${prefix}${key}`] = value;
|
|
151
|
-
}
|
|
152
|
-
return newObj;
|
|
153
|
-
}
|
|
154
|
-
function addSuffixToObjKeys(obj, suffix) {
|
|
155
|
-
const newObj = {};
|
|
156
|
-
for (const [key, value] of Object.entries(obj)) {
|
|
157
|
-
newObj[`${key}${suffix}`] = value;
|
|
158
|
-
}
|
|
159
|
-
return newObj;
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
export {
|
|
163
|
-
objectTypedEntries,
|
|
164
|
-
pick,
|
|
165
|
-
mapArrToObj,
|
|
166
|
-
mapArrayToObject,
|
|
167
|
-
mapObjToObj,
|
|
168
|
-
mapObjectToObject,
|
|
169
|
-
omit,
|
|
170
|
-
looseGetObjectProperty,
|
|
171
|
-
rejectObjUndefinedValues,
|
|
172
|
-
filterObjectKeys,
|
|
173
|
-
sortObjectKeys,
|
|
174
|
-
getValueFromPath,
|
|
175
|
-
getObjPropertyOrInsert,
|
|
176
|
-
addPrefixToObjKeys,
|
|
177
|
-
addSuffixToObjKeys
|
|
178
|
-
};
|