@kontur.candy/tools 2.112.0 → 2.113.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/CHANGELOG.md +13 -0
- package/distr/Common/CandyApiClient/CandyApiClient.js +7 -11
- package/distr/Common/CandyApiClient/CandyApiClientContext.js +26 -0
- package/distr/Common/CandyApiClient/DigestApiClient/Decorators/DigestApiClientWithCache.js +60 -0
- package/distr/Common/CandyApiClient/DigestApiClient/Decorators/DigestApiClientWithDebouncedBatching.js +51 -0
- package/distr/Common/CandyApiClient/DigestApiClient/DigestApiClient.js +50 -0
- package/distr/Common/CandyApiClient/DigestApiClient/Fakes/Data/TaxRebate1152026.js +90 -0
- package/distr/Common/CandyApiClient/DigestApiClient/Fakes/FakeDigestApiClient.js +56 -0
- package/distr/Common/CandyApiClient/DigestApiClient/Fakes/FakePicklists.js +12 -0
- package/distr/Common/CandyApiClient/{Types/Picklist/DigestRequest.js → DigestApiClient/IDigestApiClient.js} +0 -0
- package/distr/Common/CandyApiClient/DigestApiClient/React/DigestApiClientContext.js +26 -0
- package/distr/Common/CandyApiClient/DigestApiClient/TestDigestApiClient.js +25 -0
- package/distr/Common/CandyApiClient/DigestApiClient/Types/DigestQueryFilter.js +24 -0
- package/distr/Common/CandyApiClient/{Types/Picklist/PicklistServerResponses.js → DigestApiClient/Types/DigestRequest.js} +0 -0
- package/distr/Common/CandyApiClient/DigestApiClient/Types/DigestResponse.js +6 -0
- package/distr/Common/CandyApiClient/FakeCandyApiClient.js +7 -42
- package/distr/Common/EndPoints.js +4 -2
- package/distr/Common/HttpClient/AuthenticationMode.js +25 -15
- package/distr/Common/IterableUtils.js +14 -8
- package/distr/Tools/src/BuildTasks/EngineVersionUtils.js +4 -4
- package/distr/Tools/src/LocalServerFrontEndDist/index.js +2899 -332
- package/distr/Tools/src/LocalServerFrontEndDist/index.js.map +1 -1
- package/package.json +1 -1
- package/distr/Common/CandyApiClient/Types/Picklist/PicklistQueryFilter.js +0 -24
|
@@ -234,12 +234,15 @@ class IterUtils {
|
|
|
234
234
|
return minValue;
|
|
235
235
|
}
|
|
236
236
|
|
|
237
|
-
static *range(
|
|
237
|
+
static *range(inStartOrCount, inItemCount) {
|
|
238
|
+
const start = inItemCount === undefined ? 0 : inStartOrCount;
|
|
239
|
+
const itemCount = inItemCount === undefined ? inStartOrCount : inItemCount;
|
|
240
|
+
|
|
238
241
|
if (itemCount < 0) {
|
|
239
242
|
throw new _Errors.InvalidArgumentError("itemCount", "itemCount must be a non negative number");
|
|
240
243
|
}
|
|
241
244
|
|
|
242
|
-
for (let i =
|
|
245
|
+
for (let i = start; i < start + itemCount; i++) {
|
|
243
246
|
yield i;
|
|
244
247
|
}
|
|
245
248
|
}
|
|
@@ -290,14 +293,17 @@ class IterUtils {
|
|
|
290
293
|
}
|
|
291
294
|
}
|
|
292
295
|
|
|
293
|
-
static distinctBy(items, idSelector) {
|
|
294
|
-
const
|
|
296
|
+
static *distinctBy(items, idSelector) {
|
|
297
|
+
const set = new Set();
|
|
295
298
|
|
|
296
299
|
for (const item of items) {
|
|
297
|
-
|
|
298
|
-
}
|
|
300
|
+
const id = idSelector(item);
|
|
299
301
|
|
|
300
|
-
|
|
302
|
+
if (!set.has(id)) {
|
|
303
|
+
set.add(id);
|
|
304
|
+
yield item;
|
|
305
|
+
}
|
|
306
|
+
}
|
|
301
307
|
}
|
|
302
308
|
|
|
303
309
|
}
|
|
@@ -305,4 +311,4 @@ class IterUtils {
|
|
|
305
311
|
exports.IterUtils = IterUtils;
|
|
306
312
|
IterUtils.count = count;
|
|
307
313
|
IterUtils.concat = concat;
|
|
308
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../Common/IterableUtils.ts"],"names":["reverseArray","array","i","length","toAsyncIterator","generator","AsyncIterator","from","findLast","items","condition","result","item","concat","iterables","iterableItem","iterateValues","obj","key","Object","prototype","hasOwnProperty","call","iterateKeys","iterateEntries","count","_item","EmptySingleElement","Symbol","for","NoValueMarker","IterUtils","isEmpty","iterable","sortBy","selector","sort","aItem","bItem","leftValue","rightValue","last","Array","isArray","lastItem","first","firstItem","single","singleAssertMessage","Error","singleElement","index","skipLast","skipCount","prevItems","fill","resultItem","currentIndex","minBy","compareFunc","minValue","InvalidArgumentError","minByOrUndefined","undefined","range","itemCount","intersperse","intersperseFn","flatMap","x","zip","iterators","map","it","Iterator","hasUndoneIterators","resultEntry","iterator","push","resultValue","next","done","value","distinctBy","idSelector"],"mappings":"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","sourcesContent":["import { MinLengthArray, reject } from \"./TypingUtils\";\nimport { CompareFunc } from \"./Comparers\";\nimport { InvalidArgumentError } from \"./Errors\";\n\nexport function* reverseArray<T>(array: readonly T[]): IterableIterator<T> {\n    for (let i = array.length - 1; i >= 0; i--) {\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        yield array[i]!;\n    }\n}\n\nexport function toAsyncIterator<T>(generator: () => AsyncGenerator<T>): AsyncIterableIterator<T> {\n    return AsyncIterator.from(generator());\n}\n\nexport function findLast<T>(items: Iterable<T>, condition: (item: T) => boolean): T | undefined {\n    let result: T | undefined;\n    for (const item of items) {\n        if (condition(item)) {\n            result = item;\n        }\n    }\n    return result;\n}\n\nexport function* concat<T>(...iterables: Array<Iterable<T>>): IterableIterator<T> {\n    for (const iterableItem of iterables) {\n        yield* iterableItem;\n    }\n}\n\nexport function* iterateValues<TK extends string | symbol | number, TV>(obj: { [key in TK]: TV }): Iterable<TV> {\n    for (const key in obj) {\n        if (Object.prototype.hasOwnProperty.call(obj, key)) {\n            yield obj[key];\n        }\n    }\n}\n\nexport function iterateKeys<TO>(obj: Readonly<TO>): Iterable<Extract<keyof TO, string>>;\nexport function iterateKeys<TV>(obj: Readonly<{ [key: string]: TV }>): Iterable<string>;\nexport function iterateKeys(obj: Readonly<{}>): Iterable<string>;\nexport function* iterateKeys<TK extends string | symbol | number>(obj: { [key in TK]: unknown }): Iterable<TK> {\n    for (const key in obj) {\n        if (Object.prototype.hasOwnProperty.call(obj, key)) {\n            yield key;\n        }\n    }\n}\n\nexport function iterateEntries<TO>(obj: Readonly<TO>): Iterable<[Extract<keyof TO, string>, TO[keyof TO]]>;\nexport function iterateEntries<TV>(obj: Readonly<{ [key: string]: TV }>): Iterable<[string, TV]>;\nexport function iterateEntries(obj: Readonly<{}>): Iterable<[string, unknown]>;\nexport function* iterateEntries<TV>(obj: Readonly<{ [key: string]: TV }>): Iterable<[string, TV]> {\n    for (const key in obj) {\n        if (Object.prototype.hasOwnProperty.call(obj, key)) {\n            // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n            yield [key, obj[key]!];\n        }\n    }\n}\n\nexport function count<T>(items: Iterable<T>): number {\n    let result = 0;\n    for (const _item of items) {\n        result++;\n    }\n    return result;\n}\n\nconst EmptySingleElement = Symbol.for(\"EmptySingleElement\");\nconst NoValueMarker = Symbol.for(\"NoValueMarker\");\n\nexport class IterUtils {\n    public static count = count;\n    public static concat = concat;\n\n    public static isEmpty<T>(iterable: Iterable<T>): boolean {\n        for (const _item of iterable) {\n            return false;\n        }\n        return true;\n    }\n\n    public static sortBy<T>(items: readonly T[], selector: (item: T) => string): T[] {\n        const result = [...items];\n        result.sort((aItem, bItem) => {\n            const leftValue = selector(aItem);\n            const rightValue = selector(bItem);\n            if (leftValue === rightValue) {\n                return 0;\n            } else if (leftValue < rightValue) {\n                return -1;\n            } else {\n                return 1;\n            }\n        });\n        return result;\n    }\n\n    public static last<T>(items: MinLengthArray<T, 1>): T;\n    public static last<T>(items: Iterable<T> | readonly T[]): undefined | T;\n    public static last<T>(items: Iterable<T> | readonly T[]): undefined | T {\n        if (Array.isArray(items)) {\n            return items[items.length - 1];\n        }\n        let lastItem: T | undefined;\n        for (const item of items) {\n            lastItem = item;\n        }\n        return lastItem;\n    }\n\n    public static first<T>(items: MinLengthArray<T, 1>): T;\n    public static first<T>(items: Iterable<T> | readonly T[]): undefined | T;\n    public static first<T>(items: Iterable<T> | readonly T[]): undefined | T {\n        if (Array.isArray(items)) {\n            return items[0];\n        }\n        let firstItem: T | undefined;\n        for (const item of items) {\n            firstItem = item;\n            break;\n        }\n        return firstItem;\n    }\n\n    public static single<T>(items: readonly T[] | Iterable<T>, singleAssertMessage?: string): T {\n        if (Array.isArray(items)) {\n            if (items.length !== 1) {\n                throw new Error(\n                    singleAssertMessage ?? `Sequence must contain exactly single element, but got ${items.length}`\n                );\n            }\n            return items[0] ?? reject();\n        } else {\n            let singleElement: T | typeof EmptySingleElement = EmptySingleElement;\n            for (const item of items) {\n                if (singleElement !== EmptySingleElement) {\n                    throw new Error(\n                        singleAssertMessage ?? `Sequence must contain exactly single element, but got at least 2`\n                    );\n                }\n                singleElement = item;\n            }\n            if (singleElement === EmptySingleElement) {\n                throw new Error(singleAssertMessage ?? \"Sequence must contain exactly single element, but got 0\");\n            }\n            return singleElement;\n        }\n    }\n\n    public static *iterateEntries<T>(items: readonly T[] | T[] | Iterable<T>): Iterable<[number, T]> {\n        let index = 0;\n        for (const item of items) {\n            yield [index, item];\n            index++;\n        }\n    }\n\n    public static *skipLast<T>(items: Iterable<T>, skipCount: number): Iterable<T> {\n        if (skipCount === 0) {\n            yield* items;\n            return;\n        }\n        const prevItems: Array<T | typeof EmptySingleElement> = new Array(skipCount).fill(EmptySingleElement);\n        let resultItem: T | typeof EmptySingleElement = EmptySingleElement;\n        let currentIndex = 0;\n        for (const item of items) {\n            // @ts-expect-error В общем, строка выше гарантирует длину массива\n            resultItem = prevItems[currentIndex];\n            prevItems[currentIndex] = item;\n            currentIndex = (currentIndex + 1) % skipCount;\n            if (resultItem != EmptySingleElement) {\n                yield resultItem;\n            }\n        }\n    }\n\n    public static minBy<T>(items: readonly T[] | T[] | Iterable<T>, compareFunc: CompareFunc<T>): T {\n        let minValue: typeof NoValueMarker | T = NoValueMarker;\n        for (const item of items) {\n            if (minValue === NoValueMarker) {\n                minValue = item;\n            } else if (compareFunc(item, minValue) === -1) {\n                minValue = item;\n            }\n        }\n        if (minValue === NoValueMarker) {\n            throw new InvalidArgumentError(\"items\", \"Items should be not empty list\");\n        }\n        return minValue;\n    }\n\n    public static minByOrUndefined<T>(\n        items: readonly T[] | T[] | Iterable<T>,\n        compareFunc: CompareFunc<T>\n    ): T | undefined {\n        let minValue: typeof NoValueMarker | T = NoValueMarker;\n        for (const item of items) {\n            if (minValue === NoValueMarker) {\n                minValue = item;\n            } else if (compareFunc(item, minValue) === -1) {\n                minValue = item;\n            }\n        }\n        if (minValue === NoValueMarker) {\n            return undefined;\n        }\n        return minValue;\n    }\n\n    public static *range(itemCount: number): Iterable<number> {\n        if (itemCount < 0) {\n            throw new InvalidArgumentError(\"itemCount\", \"itemCount must be a non negative number\");\n        }\n        for (let i = 0; i < itemCount; i++) {\n            yield i;\n        }\n    }\n\n    /**\n     * @summary Вставляет между элементами массива заданный элемент и возвращает новый массив\n     */\n    public static intersperse<TI, TS>(items: TI[], item: TS): Array<TI | TS> {\n        return this.intersperseFn(items, () => item);\n    }\n\n    /**\n     * @summary Вставляет между элементами массива элемент, создаваемый функцией, и возвращает новый массив\n     */\n    public static intersperseFn<TI, TS>(items: TI[], item: (nextItem: TI, index: number) => TS): Array<TI | TS> {\n        return items.flatMap((x, index) => (index === 0 ? [x] : [item(x, index), x]));\n    }\n\n    public static zip<T1, T2>(items1: Iterable<T1>, items2: Iterable<T2>): Iterable<[T1 | undefined, T2 | undefined]>;\n    public static *zip(...iterables: Array<Iterable<unknown>>): Iterable<unknown[]> {\n        const iterators: Array<Iterator<unknown> | typeof NoValueMarker> = iterables.map(it => Iterator.from(it));\n        let hasUndoneIterators = true;\n        while (hasUndoneIterators) {\n            const resultEntry = [];\n            hasUndoneIterators = false;\n            for (const [i, iterator] of this.iterateEntries(iterators)) {\n                if (iterator === NoValueMarker) {\n                    resultEntry.push(undefined);\n                } else {\n                    const resultValue = iterator.next();\n                    if (resultValue.done) {\n                        resultEntry.push(undefined);\n                        iterators[i] = NoValueMarker;\n                    } else {\n                        resultEntry.push(resultValue.value);\n                        hasUndoneIterators = true;\n                    }\n                }\n            }\n            if (hasUndoneIterators) {\n                yield resultEntry;\n            }\n        }\n    }\n\n    public static distinctBy<T>(items: Iterable<T>, idSelector: (item: T) => string): T[] {\n        const map: { [hash: string]: T } = {};\n        for (const item of items) {\n            map[idSelector(item)] = item;\n        }\n        return [...iterateValues(map)];\n    }\n}\n"]}
|
|
314
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../Common/IterableUtils.ts"],"names":["reverseArray","array","i","length","toAsyncIterator","generator","AsyncIterator","from","findLast","items","condition","result","item","concat","iterables","iterableItem","iterateValues","obj","key","Object","prototype","hasOwnProperty","call","iterateKeys","iterateEntries","count","_item","EmptySingleElement","Symbol","for","NoValueMarker","IterUtils","isEmpty","iterable","sortBy","selector","sort","aItem","bItem","leftValue","rightValue","last","Array","isArray","lastItem","first","firstItem","single","singleAssertMessage","Error","singleElement","index","skipLast","skipCount","prevItems","fill","resultItem","currentIndex","minBy","compareFunc","minValue","InvalidArgumentError","minByOrUndefined","undefined","range","inStartOrCount","inItemCount","start","itemCount","intersperse","intersperseFn","flatMap","x","zip","iterators","map","it","Iterator","hasUndoneIterators","resultEntry","iterator","push","resultValue","next","done","value","distinctBy","idSelector","set","Set","id","has","add"],"mappings":"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","sourcesContent":["import { MinLengthArray, reject } from \"./TypingUtils\";\nimport { CompareFunc } from \"./Comparers\";\nimport { InvalidArgumentError } from \"./Errors\";\n\nexport function* reverseArray<T>(array: readonly T[]): IterableIterator<T> {\n    for (let i = array.length - 1; i >= 0; i--) {\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n        yield array[i]!;\n    }\n}\n\nexport function toAsyncIterator<T>(generator: () => AsyncGenerator<T>): AsyncIterableIterator<T> {\n    return AsyncIterator.from(generator());\n}\n\nexport function findLast<T>(items: Iterable<T>, condition: (item: T) => boolean): T | undefined {\n    let result: T | undefined;\n    for (const item of items) {\n        if (condition(item)) {\n            result = item;\n        }\n    }\n    return result;\n}\n\nexport function* concat<T>(...iterables: Array<Iterable<T>>): IterableIterator<T> {\n    for (const iterableItem of iterables) {\n        yield* iterableItem;\n    }\n}\n\nexport function* iterateValues<TK extends string | symbol | number, TV>(obj: { [key in TK]: TV }): Iterable<TV> {\n    for (const key in obj) {\n        if (Object.prototype.hasOwnProperty.call(obj, key)) {\n            yield obj[key];\n        }\n    }\n}\n\nexport function iterateKeys<TO>(obj: Readonly<TO>): Iterable<Extract<keyof TO, string>>;\nexport function iterateKeys<TV>(obj: Readonly<{ [key: string]: TV }>): Iterable<string>;\nexport function iterateKeys(obj: Readonly<{}>): Iterable<string>;\nexport function* iterateKeys<TK extends string | symbol | number>(obj: { [key in TK]: unknown }): Iterable<TK> {\n    for (const key in obj) {\n        if (Object.prototype.hasOwnProperty.call(obj, key)) {\n            yield key;\n        }\n    }\n}\n\nexport function iterateEntries<TO>(obj: Readonly<TO>): Iterable<[Extract<keyof TO, string>, TO[keyof TO]]>;\nexport function iterateEntries<TV>(obj: Readonly<{ [key: string]: TV }>): Iterable<[string, TV]>;\nexport function iterateEntries(obj: Readonly<{}>): Iterable<[string, unknown]>;\nexport function* iterateEntries<TV>(obj: Readonly<{ [key: string]: TV }>): Iterable<[string, TV]> {\n    for (const key in obj) {\n        if (Object.prototype.hasOwnProperty.call(obj, key)) {\n            // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n            yield [key, obj[key]!];\n        }\n    }\n}\n\nexport function count<T>(items: Iterable<T>): number {\n    let result = 0;\n    for (const _item of items) {\n        result++;\n    }\n    return result;\n}\n\nconst EmptySingleElement = Symbol.for(\"EmptySingleElement\");\nconst NoValueMarker = Symbol.for(\"NoValueMarker\");\n\nexport class IterUtils {\n    public static count = count;\n    public static concat = concat;\n\n    public static isEmpty<T>(iterable: Iterable<T>): boolean {\n        for (const _item of iterable) {\n            return false;\n        }\n        return true;\n    }\n\n    public static sortBy<T>(items: readonly T[], selector: (item: T) => string): T[] {\n        const result = [...items];\n        result.sort((aItem, bItem) => {\n            const leftValue = selector(aItem);\n            const rightValue = selector(bItem);\n            if (leftValue === rightValue) {\n                return 0;\n            } else if (leftValue < rightValue) {\n                return -1;\n            } else {\n                return 1;\n            }\n        });\n        return result;\n    }\n\n    public static last<T>(items: MinLengthArray<T, 1>): T;\n    public static last<T>(items: Iterable<T> | readonly T[]): undefined | T;\n    public static last<T>(items: Iterable<T> | readonly T[]): undefined | T {\n        if (Array.isArray(items)) {\n            return items[items.length - 1];\n        }\n        let lastItem: T | undefined;\n        for (const item of items) {\n            lastItem = item;\n        }\n        return lastItem;\n    }\n\n    public static first<T>(items: MinLengthArray<T, 1>): T;\n    public static first<T>(items: Iterable<T> | readonly T[]): undefined | T;\n    public static first<T>(items: Iterable<T> | readonly T[]): undefined | T {\n        if (Array.isArray(items)) {\n            return items[0];\n        }\n        let firstItem: T | undefined;\n        for (const item of items) {\n            firstItem = item;\n            break;\n        }\n        return firstItem;\n    }\n\n    public static single<T>(items: readonly T[] | Iterable<T>, singleAssertMessage?: string): T {\n        if (Array.isArray(items)) {\n            if (items.length !== 1) {\n                throw new Error(\n                    singleAssertMessage ?? `Sequence must contain exactly single element, but got ${items.length}`\n                );\n            }\n            return items[0] ?? reject();\n        } else {\n            let singleElement: T | typeof EmptySingleElement = EmptySingleElement;\n            for (const item of items) {\n                if (singleElement !== EmptySingleElement) {\n                    throw new Error(\n                        singleAssertMessage ?? `Sequence must contain exactly single element, but got at least 2`\n                    );\n                }\n                singleElement = item;\n            }\n            if (singleElement === EmptySingleElement) {\n                throw new Error(singleAssertMessage ?? \"Sequence must contain exactly single element, but got 0\");\n            }\n            return singleElement;\n        }\n    }\n\n    public static *iterateEntries<T>(items: readonly T[] | T[] | Iterable<T>): Iterable<[number, T]> {\n        let index = 0;\n        for (const item of items) {\n            yield [index, item];\n            index++;\n        }\n    }\n\n    public static *skipLast<T>(items: Iterable<T>, skipCount: number): Iterable<T> {\n        if (skipCount === 0) {\n            yield* items;\n            return;\n        }\n        const prevItems: Array<T | typeof EmptySingleElement> = new Array(skipCount).fill(EmptySingleElement);\n        let resultItem: T | typeof EmptySingleElement = EmptySingleElement;\n        let currentIndex = 0;\n        for (const item of items) {\n            // @ts-expect-error В общем, строка выше гарантирует длину массива\n            resultItem = prevItems[currentIndex];\n            prevItems[currentIndex] = item;\n            currentIndex = (currentIndex + 1) % skipCount;\n            if (resultItem != EmptySingleElement) {\n                yield resultItem;\n            }\n        }\n    }\n\n    public static minBy<T>(items: readonly T[] | T[] | Iterable<T>, compareFunc: CompareFunc<T>): T {\n        let minValue: typeof NoValueMarker | T = NoValueMarker;\n        for (const item of items) {\n            if (minValue === NoValueMarker) {\n                minValue = item;\n            } else if (compareFunc(item, minValue) === -1) {\n                minValue = item;\n            }\n        }\n        if (minValue === NoValueMarker) {\n            throw new InvalidArgumentError(\"items\", \"Items should be not empty list\");\n        }\n        return minValue;\n    }\n\n    public static minByOrUndefined<T>(\n        items: readonly T[] | T[] | Iterable<T>,\n        compareFunc: CompareFunc<T>\n    ): T | undefined {\n        let minValue: typeof NoValueMarker | T = NoValueMarker;\n        for (const item of items) {\n            if (minValue === NoValueMarker) {\n                minValue = item;\n            } else if (compareFunc(item, minValue) === -1) {\n                minValue = item;\n            }\n        }\n        if (minValue === NoValueMarker) {\n            return undefined;\n        }\n        return minValue;\n    }\n\n    public static range(itemCount: number): Iterable<number>;\n    public static range(start: number, itemCount: number): Iterable<number>;\n    public static *range(inStartOrCount: number, inItemCount?: number): Iterable<number> {\n        const start = inItemCount === undefined ? 0 : inStartOrCount;\n        const itemCount = inItemCount === undefined ? inStartOrCount : inItemCount;\n        if (itemCount < 0) {\n            throw new InvalidArgumentError(\"itemCount\", \"itemCount must be a non negative number\");\n        }\n        for (let i = start; i < start + itemCount; i++) {\n            yield i;\n        }\n    }\n\n    /**\n     * @summary Вставляет между элементами массива заданный элемент и возвращает новый массив\n     */\n    public static intersperse<TI, TS>(items: TI[], item: TS): Array<TI | TS> {\n        return this.intersperseFn(items, () => item);\n    }\n\n    /**\n     * @summary Вставляет между элементами массива элемент, создаваемый функцией, и возвращает новый массив\n     */\n    public static intersperseFn<TI, TS>(items: TI[], item: (nextItem: TI, index: number) => TS): Array<TI | TS> {\n        return items.flatMap((x, index) => (index === 0 ? [x] : [item(x, index), x]));\n    }\n\n    public static zip<T1, T2>(items1: Iterable<T1>, items2: Iterable<T2>): Iterable<[T1 | undefined, T2 | undefined]>;\n    public static *zip(...iterables: Array<Iterable<unknown>>): Iterable<unknown[]> {\n        const iterators: Array<Iterator<unknown> | typeof NoValueMarker> = iterables.map(it => Iterator.from(it));\n        let hasUndoneIterators = true;\n        while (hasUndoneIterators) {\n            const resultEntry = [];\n            hasUndoneIterators = false;\n            for (const [i, iterator] of this.iterateEntries(iterators)) {\n                if (iterator === NoValueMarker) {\n                    resultEntry.push(undefined);\n                } else {\n                    const resultValue = iterator.next();\n                    if (resultValue.done) {\n                        resultEntry.push(undefined);\n                        iterators[i] = NoValueMarker;\n                    } else {\n                        resultEntry.push(resultValue.value);\n                        hasUndoneIterators = true;\n                    }\n                }\n            }\n            if (hasUndoneIterators) {\n                yield resultEntry;\n            }\n        }\n    }\n\n    public static *distinctBy<T>(items: Iterable<T>, idSelector: (item: T) => string): Iterable<T> {\n        const set = new Set<string>();\n        for (const item of items) {\n            const id = idSelector(item);\n            if (!set.has(id)) {\n                set.add(id);\n                yield item;\n            }\n        }\n    }\n}\n"]}
|
|
@@ -7,7 +7,7 @@ exports.EngineVersionUtils = void 0;
|
|
|
7
7
|
|
|
8
8
|
class EngineVersionUtils {
|
|
9
9
|
static extractVersionFromEngineFileName(engineFileName) {
|
|
10
|
-
const regex = /^candy_v(\d+)_(\d+)_(\d+)(_([\w\d_]+?)_(
|
|
10
|
+
const regex = /^candy_v(\d+)_(\d+)_(\d+)(?:_([\w\d_]+?)_([^_\.]+))?(?:\.(?:[\d\w-]+))?(?:\.test)?(?:\.min)?(?:(?:\.js)|(?:\.css))(?:\.map)?$/;
|
|
11
11
|
const match = regex.exec(engineFileName);
|
|
12
12
|
|
|
13
13
|
if (match == undefined) {
|
|
@@ -17,8 +17,8 @@ class EngineVersionUtils {
|
|
|
17
17
|
const major = match[1];
|
|
18
18
|
const minor = match[2];
|
|
19
19
|
const patch = match[3];
|
|
20
|
-
const preId = match[
|
|
21
|
-
const prereleaseNumber = match[
|
|
20
|
+
const preId = match[4];
|
|
21
|
+
const prereleaseNumber = match[5];
|
|
22
22
|
let result = `${major}.${minor}.${patch}`;
|
|
23
23
|
|
|
24
24
|
if (preId != undefined) {
|
|
@@ -35,4 +35,4 @@ class EngineVersionUtils {
|
|
|
35
35
|
}
|
|
36
36
|
|
|
37
37
|
exports.EngineVersionUtils = EngineVersionUtils;
|
|
38
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9CdWlsZFRhc2tzL0VuZ2luZVZlcnNpb25VdGlscy50cyJdLCJuYW1lcyI6WyJFbmdpbmVWZXJzaW9uVXRpbHMiLCJleHRyYWN0VmVyc2lvbkZyb21FbmdpbmVGaWxlTmFtZSIsImVuZ2luZUZpbGVOYW1lIiwicmVnZXgiLCJtYXRjaCIsImV4ZWMiLCJ1bmRlZmluZWQiLCJFcnJvciIsIm1ham9yIiwibWlub3IiLCJwYXRjaCIsInByZUlkIiwicHJlcmVsZWFzZU51bWJlciIsInJlc3VsdCIsInJlcGxhY2UiLCJlbmdpbmVWZXJzaW9uVG9OYW1lIiwiZW5naW5lVmVyc2lvbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFPLE1BQU1BLGtCQUFOLENBQXlCO0FBQ2tCLFNBQWhDQyxnQ0FBZ0MsQ0FBQ0MsY0FBRCxFQUFpQztBQUMzRSxVQUFNQyxLQUFLLEdBQ1AsK0hBREo7QUFFQSxVQUFNQyxLQUFLLEdBQUdELEtBQUssQ0FBQ0UsSUFBTixDQUFXSCxjQUFYLENBQWQ7O0FBQ0EsUUFBSUUsS0FBSyxJQUFJRSxTQUFiLEVBQXdCO0FBQ3BCLFlBQU0sSUFBSUMsS0FBSixDQUFXLHVDQUFzQ0wsY0FBZSxHQUFoRSxDQUFOO0FBQ0g7O0FBQ0QsVUFBTU0sS0FBSyxHQUFHSixLQUFLLENBQUMsQ0FBRCxDQUFuQjtBQUNBLFVBQU1LLEtBQUssR0FBR0wsS0FBSyxDQUFDLENBQUQsQ0FBbkI7QUFDQSxVQUFNTSxLQUFLLEdBQUdOLEtBQUssQ0FBQyxDQUFELENBQW5CO0FBQ0EsVUFBTU8sS0FBSyxHQUFHUCxLQUFLLENBQUMsQ0FBRCxDQUFuQjtBQUNBLFVBQU1RLGdCQUFnQixHQUFHUixLQUFLLENBQUMsQ0FBRCxDQUE5QjtBQUNBLFFBQUlTLE1BQU0sR0FBSSxHQUFFTCxLQUFNLElBQUdDLEtBQU0sSUFBR0MsS0FBTSxFQUF4Qzs7QUFDQSxRQUFJQyxLQUFLLElBQUlMLFNBQWIsRUFBd0I7QUFDcEJPLE1BQUFBLE1BQU0sSUFBSyxJQUFHRixLQUFLLENBQUNHLE9BQU4sQ0FBYyxJQUFkLEVBQW9CLEdBQXBCLENBQXlCLElBQUdGLGdCQUFpQixFQUEzRDtBQUNIOztBQUNELFdBQU9DLE1BQVA7QUFDSDs7QUFFZ0MsU0FBbkJFLG1CQUFtQixDQUFDQyxhQUFELEVBQWdDO0FBQzdELFdBQVEsSUFBR0EsYUFBYSxDQUFDRixPQUFkLENBQXNCLFVBQXRCLEVBQWtDLEdBQWxDLENBQXVDLEVBQWxEO0FBQ0g7O0FBdEIyQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBFbmdpbmVWZXJzaW9uVXRpbHMge1xuICAgIHB1YmxpYyBzdGF0aWMgZXh0cmFjdFZlcnNpb25Gcm9tRW5naW5lRmlsZU5hbWUoZW5naW5lRmlsZU5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgICAgIGNvbnN0IHJlZ2V4ID1cbiAgICAgICAgICAgIC9eY2FuZHlfdihcXGQrKV8oXFxkKylfKFxcZCspKD86XyhbXFx3XFxkX10rPylfKFteX1xcLl0rKSk/KD86XFwuKD86W1xcZFxcdy1dKykpPyg/OlxcLnRlc3QpPyg/OlxcLm1pbik/KD86KD86XFwuanMpfCg/OlxcLmNzcykpKD86XFwubWFwKT8kLztcbiAgICAgICAgY29uc3QgbWF0Y2ggPSByZWdleC5leGVjKGVuZ2luZUZpbGVOYW1lKTtcbiAgICAgICAgaWYgKG1hdGNoID09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBDYW5ub3QgZXh0cmFjdCBlbmdpbmUgdmVyc2lvbiBmcm9tICcke2VuZ2luZUZpbGVOYW1lfSdgKTtcbiAgICAgICAgfVxuICAgICAgICBjb25zdCBtYWpvciA9IG1hdGNoWzFdO1xuICAgICAgICBjb25zdCBtaW5vciA9IG1hdGNoWzJdO1xuICAgICAgICBjb25zdCBwYXRjaCA9IG1hdGNoWzNdO1xuICAgICAgICBjb25zdCBwcmVJZCA9IG1hdGNoWzRdO1xuICAgICAgICBjb25zdCBwcmVyZWxlYXNlTnVtYmVyID0gbWF0Y2hbNV07XG4gICAgICAgIGxldCByZXN1bHQgPSBgJHttYWpvcn0uJHttaW5vcn0uJHtwYXRjaH1gO1xuICAgICAgICBpZiAocHJlSWQgIT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICByZXN1bHQgKz0gYC0ke3ByZUlkLnJlcGxhY2UoL18vZywgXCItXCIpfS4ke3ByZXJlbGVhc2VOdW1iZXJ9YDtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gcmVzdWx0O1xuICAgIH1cblxuICAgIHB1YmxpYyBzdGF0aWMgZW5naW5lVmVyc2lvblRvTmFtZShlbmdpbmVWZXJzaW9uOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gYHYke2VuZ2luZVZlcnNpb24ucmVwbGFjZSgvW1xcLlxcLV0vZ2ksIFwiX1wiKX1gO1xuICAgIH1cbn1cbiJdfQ==
|