UNPKG

@versatiledatakit/shared

Version:

Versatile Data Kit Shared library enables reusability of shared features like: NgRx Redux, Error Handlers, Utils, Generic Components, etc.

386 lines • 43.5 kB
/* * Copyright 2023-2025 Broadcom * SPDX-License-Identifier: Apache-2.0 */ /* eslint-disable @typescript-eslint/no-explicit-any */ import { cloneDeep, isEqual } from 'lodash'; import { v4 as uuidv4 } from 'uuid'; /** * ** Utility Class for Collections. */ export class CollectionsUtil { /** * ** Check if value is of type undefined. */ static isUndefined(value) { return typeof value === 'undefined'; } /** * ** Check if value has value null. */ static isNull(value) { return value === null; } /** * ** Check if value is undefined or null. */ static isNil(value) { return CollectionsUtil.isNull(value) || CollectionsUtil.isUndefined(value); } /** * ** Check if value is defined (opposite of isNil). * * - Not null. * - Not undefined. */ static isDefined(value) { return !CollectionsUtil.isNull(value) && !CollectionsUtil.isUndefined(value); } /** * ** Check if value T is of type Number. */ static isNumber(num) { return typeof num === 'number'; } /** * ** Check if value T is of type String. */ static isString(str) { return typeof str === 'string'; } /** * ** Check if value T is of type Boolean. */ static isBoolean(bool) { return typeof bool === 'boolean'; } /** * ** Check if value is Primitive. * * - String, Number, Boolean, null or undefined. */ static isPrimitive(value) { return (CollectionsUtil.isString(value) || CollectionsUtil.isBoolean(value) || CollectionsUtil.isNumber(value) || CollectionsUtil.isUndefined(value)); } /** * ** Check if value is NaN. */ static isNaN(value) { return Number.isNaN(value); } /** * ** Check if value is of type Date. */ static isDate(value) { return value instanceof Date; } /** * ** Check if value is Primitive or Date. * * - String, Number, Boolean, null, undefined or Date. */ static isPrimitiveOrDate(value) { return CollectionsUtil.isPrimitive(value) || CollectionsUtil.isDate(value); } /** * ** Check if value T is a reference that points to function (Class/Method). */ // eslint-disable-next-line static isFunction(value) { return typeof value === 'function'; } /** * ** Check if value T is of type Object. */ static isObject(obj) { return typeof obj === 'object'; } /** * ** Check if value T is instance of Array. */ static isArray(arr) { return arr instanceof Array; } /** * ** Check if value T is not instance of Array or there are no elements in Array. */ static isArrayEmpty(arr) { return !CollectionsUtil.isArray(arr) || arr.length === 0; } /** * ** Returns new Array where items will be filtered by reference and will leave distinct values. */ static uniqueArray(arr) { return arr.filter((value, index, self) => { return self.indexOf(value) === index; }); } /** * ** Check if value is Map. */ static isMap(obj) { return obj instanceof Map; } /** * ** Check if value is WeakMap. */ static isWeakMap(obj) { return obj instanceof WeakMap; } /** * ** Check if value is Set. */ static isSet(obj) { return obj instanceof Set; } /** * ** Check if value T is of type String and has length bigger than 0 after whitespace trim. */ static isStringWithContent(str) { return CollectionsUtil.isString(str) && str.trim().length > 0; } /** * ** Check if value is Collection (literal Object, Array, Map, WeakMap or Set). */ static isCollection(obj) { return (CollectionsUtil.isArray(obj) || CollectionsUtil.isMap(obj) || CollectionsUtil.isWeakMap(obj) || CollectionsUtil.isSet(obj) || CollectionsUtil.isLiteralObject(obj)); } /** * ** Check if value is of type Object and not null. */ static isObjectNotNull(obj) { return CollectionsUtil.isObject(obj) && !CollectionsUtil.isNull(obj); } /** * ** Check if some variable is of type Boolean and is true. */ static isBooleanAndTrue(bool) { return CollectionsUtil.isBoolean(bool) && bool; } /** * ** Check if value is literal Object or null. * * - Not an Array, Map, WeakMap or Set. */ static isLiteralObjectOrNull(obj) { return (CollectionsUtil.isObject(obj) && !CollectionsUtil.isArray(obj) && !CollectionsUtil.isMap(obj) && !CollectionsUtil.isWeakMap(obj) && !CollectionsUtil.isSet(obj)); } /** * ** Check if provided value is literal Object. * * - Not and Array, Map, WeakMap, Set or null. */ static isLiteralObject(obj) { return CollectionsUtil.isLiteralObjectOrNull(obj) && !CollectionsUtil.isNull(obj); } /** * ** Check if value is Object and has properties. */ static isObjectWithProperties(obj) { return CollectionsUtil.isObjectNotNull(obj) && Object.keys(obj).length > 0; } /** * ** Return current Date in ISO string format. */ static dateISO() { return new Date().toISOString(); } /** * ** Return current Date milliseconds from 1970. */ static dateNow() { return Date.now(); } /** * ** Performs deep comparison between two values to determine if the are equivalent. */ static isEqual(value1, value2) { return isEqual(value1, value2); } /** * ** Create recursive deep cloned value from provided one. */ static cloneDeep(value) { return cloneDeep(value); } /** * ** Generate UUID that meats RFC4122 compliance. */ static generateUUID() { // eslint-disable-next-line @typescript-eslint/no-unsafe-call return uuidv4(); } /** * ** Generate Object UUID that meats RFC4122 compliance and also has Class name identifier inside. * * <br/> * <i>pattern</i>: * <p> * <Class Name><strong>_</strong><UUID RFC4122> * </p> */ static generateObjectUUID(className) { return `${className}_${CollectionsUtil.generateUUID()}`; } /** * ** Creates random string. */ static generateRandomString() { return (Math.random() + 1).toString(36).substring(2); } /** * ** Iterates own enumerable properties in Object. * * - use Object.keys method for extraction, and executes provided iteratorFn. * - if iteratorFn returns false or -1 it will break iteration. * - all other return values continue until last property. * * - flag as third parameter is optional: * - Without flag or with flag and has value 'plainObject, method will iterate only through literal Objects. * - With flag and has value 'objectLookLike', method will try to iterate through everything * that passes type value === 'object' (literal Object, Array, Map, Set, WeakMap, etc..). */ static iterateObject(obj, iteratorFn, flag = 'plainObject') { if (!CollectionsUtil.isFunction(iteratorFn)) { return null; } if (flag === 'objectLookLike') { if (!CollectionsUtil.isObjectNotNull(obj)) { return null; } } else { if (!CollectionsUtil.isLiteralObject(obj)) { return null; } } const objectKeys = Object.keys(obj); for (const key of objectKeys) { const resultOfIteratorFn = iteratorFn(obj[key], key, obj); if (resultOfIteratorFn === false || resultOfIteratorFn === -1) { break; } } return obj; } /** * ** Check if value is Literal Object and has properties. */ static isLiteralObjectWithProperties(obj) { return CollectionsUtil.isLiteralObject(obj) && Object.keys(obj).length > 0; } /** * ** Iterates over object properties and return Array of its values. */ static objectValues(obj) { const _result = []; CollectionsUtil.iterateObject(obj, (value) => { _result.push(value); }); return _result; } /** * ** Transform given Map to Object. */ static transformMapToObject(map) { const obj = {}; map.forEach((value, key) => (obj[key] = value)); return obj; } /** * ** Transform given Object to Map. */ static transformObjectToMap(obj) { const map = new Map(); CollectionsUtil.iterateObject(obj, (value, key) => { map.set(key, value); }); return map; } /** * ** Iterates over object properties and return Array of its keys/values in pairs. * <p> * - Returns Array of subArrays that have 2 elements each, first element key and second element value. */ static objectPairs(obj) { if (!CollectionsUtil.isLiteralObject(obj)) { return []; } return Object.entries(obj); } /** * ** Return own property Descriptor from provided object/function. */ static getObjectPropertyDescriptor(obj, key) { if (!((CollectionsUtil.isFunction(obj) || CollectionsUtil.isObject(obj)) && CollectionsUtil.isString(key))) { return null; } return Object.getOwnPropertyDescriptor(obj, key); } /** * ** Iterates own enumerable properties (statics) of Function (Class). * * - use Object.getOwnPropertyDescriptors method for extraction, and executes provided iteratorFn. * - if iteratorFn returns false or -1 will break iteration. * - all other return values means continue until last property. */ static iterateClassStatics(fn, iteratorFn) { if (!CollectionsUtil.isFunction(fn) || !CollectionsUtil.isFunction(iteratorFn)) { return null; } const descriptors = Object.getOwnPropertyDescriptors(fn); CollectionsUtil.iterateObject(descriptors, (descriptor, key) => iteratorFn(descriptor, key, fn)); return fn; } /** * ** Check if two Maps are Equal. * * - They are equal if they have same references. * - They are equal if they have same keys and same values for compared keys. */ static areMapsEqual(m1, m2) { const evaluateDeepComparison = () => { for (const [key, val] of m1) { const compareVal = m2.get(key); if (CollectionsUtil.isMap(val)) { if (!CollectionsUtil.areMapsEqual(val, compareVal)) { return false; } continue; } if (!CollectionsUtil.isEqual(val, compareVal) || (CollectionsUtil.isUndefined(compareVal) && !m2.has(key))) { return false; } } return true; }; return CollectionsUtil.isMap(m1) && CollectionsUtil.isMap(m2) && (m1 === m2 || (m1.size === m2.size && evaluateDeepComparison())); } /** * @inheritDoc */ static interpolateString(target, ...replacers) { let response = target; replacers.forEach((replacer) => { if (CollectionsUtil.isString(replacer)) { response = response.replace('%s', replacer); } else { response = response.replace(replacer.searchValue, replacer.replaceValue); } }); return response; } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collections-util.js","sourceRoot":"","sources":["../../../../../../projects/shared/src/lib/utils/collections/collections-util.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2023-2025 Broadcom\n * SPDX-License-Identifier: Apache-2.0\n */\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n\nimport { cloneDeep, isEqual } from 'lodash';\n\nimport { v4 as uuidv4 } from 'uuid';\n\nimport { Replacer } from '../../common';\n\nimport { Collections, IteratorFnResult, LiteralObjectOrNull, Nil, ObjectIterator, Primitives, PrimitivesDate, Subtract } from '../model';\n\n/**\n * ** Utility Class for Collections.\n */\nexport class CollectionsUtil {\n    /**\n     * ** Check if value is of type undefined.\n     */\n    static isUndefined(value: any): value is undefined {\n        return typeof value === 'undefined';\n    }\n\n    /**\n     * ** Check if value has value null.\n     */\n    static isNull(value: any): value is null {\n        return value === null;\n    }\n\n    /**\n     * ** Check if value is undefined or null.\n     */\n    static isNil(value: any): value is Nil {\n        return CollectionsUtil.isNull(value) || CollectionsUtil.isUndefined(value);\n    }\n\n    /**\n     * ** Check if value is defined (opposite of isNil).\n     *\n     *     - Not null.\n     *     - Not undefined.\n     */\n    static isDefined<T>(value: T): boolean {\n        return !CollectionsUtil.isNull(value) && !CollectionsUtil.isUndefined(value);\n    }\n\n    /**\n     * ** Check if value T is of type Number.\n     */\n    static isNumber<T extends number>(num: T | any): num is number {\n        return typeof num === 'number';\n    }\n\n    /**\n     * ** Check if value T is of type String.\n     */\n    static isString<T extends string>(str: T | any): str is string {\n        return typeof str === 'string';\n    }\n\n    /**\n     * ** Check if value T is of type Boolean.\n     */\n    static isBoolean<T extends boolean>(bool: T | any): bool is boolean {\n        return typeof bool === 'boolean';\n    }\n\n    /**\n     * ** Check if value is Primitive.\n     *\n     *     - String, Number, Boolean, null or undefined.\n     */\n    static isPrimitive(value: any): value is Primitives | Nil {\n        return (\n            CollectionsUtil.isString(value) ||\n            CollectionsUtil.isBoolean(value) ||\n            CollectionsUtil.isNumber(value) ||\n            CollectionsUtil.isUndefined(value)\n        );\n    }\n\n    /**\n     * ** Check if value is NaN.\n     */\n    static isNaN<T extends number>(value: T | any): boolean {\n        return Number.isNaN(value);\n    }\n\n    /**\n     * ** Check if value is of type Date.\n     */\n    static isDate(value: any): value is Date {\n        return value instanceof Date;\n    }\n\n    /**\n     * ** Check if value is Primitive or Date.\n     *\n     *     - String, Number, Boolean, null, undefined or Date.\n     */\n    static isPrimitiveOrDate<T extends PrimitivesDate>(value: T | any): value is Primitives | Nil | Date {\n        return CollectionsUtil.isPrimitive(value) || CollectionsUtil.isDate(value);\n    }\n\n    /**\n     *  ** Check if value T is a reference that points to function (Class/Method).\n     */\n    // eslint-disable-next-line\n    static isFunction<T extends (...args: any[]) => any>(value: T | any): value is (...args: any[]) => any {\n        return typeof value === 'function';\n    }\n\n    /**\n     * ** Check if value T is of type Object.\n     */\n    static isObject<T extends Record<string, unknown>>(obj: T | any): obj is Record<string, unknown> {\n        return typeof obj === 'object';\n    }\n\n    /**\n     * ** Check if value T is instance of Array.\n     */\n    static isArray<T>(arr: T | any): arr is T extends any[] ? T : any[] {\n        return arr instanceof Array;\n    }\n\n    /**\n     * ** Check if value T is not instance of Array or there are no elements in Array.\n     */\n    static isArrayEmpty<T>(arr: T | any): boolean {\n        return !CollectionsUtil.isArray(arr) || arr.length === 0;\n    }\n\n    /**\n     * ** Returns new Array where items will be filtered by reference and will leave distinct values.\n     */\n    static uniqueArray<T extends any[]>(arr: T): T {\n        return arr.filter((value, index, self) => {\n            return self.indexOf(value) === index;\n        }) as T;\n    }\n\n    /**\n     * ** Check if value is Map.\n     */\n    static isMap(obj: Map<any, any> | any): obj is Map<any, any> {\n        return obj instanceof Map;\n    }\n\n    /**\n     * ** Check if value is WeakMap.\n     */\n    static isWeakMap(obj: WeakMap<any, any> | any): obj is WeakMap<any, any> {\n        return obj instanceof WeakMap;\n    }\n\n    /**\n     * ** Check if value is Set.\n     */\n    static isSet(obj: Set<any> | any): obj is Set<any> {\n        return obj instanceof Set;\n    }\n\n    /**\n     * ** Check if value T is of type String and has length bigger than 0 after whitespace trim.\n     */\n    static isStringWithContent<T extends string>(str: T | any): str is string {\n        return CollectionsUtil.isString(str) && str.trim().length > 0;\n    }\n\n    /**\n     * ** Check if value is Collection (literal Object, Array, Map, WeakMap or Set).\n     */\n    static isCollection(obj: Collections | any): obj is Collections {\n        return (\n            CollectionsUtil.isArray(obj) ||\n            CollectionsUtil.isMap(obj) ||\n            CollectionsUtil.isWeakMap(obj) ||\n            CollectionsUtil.isSet(obj) ||\n            CollectionsUtil.isLiteralObject(obj)\n        );\n    }\n\n    /**\n     * ** Check if value is of type Object and not null.\n     */\n    static isObjectNotNull<T extends Record<string, unknown>>(\n        obj: T | any\n    ): obj is Record<string, unknown> & Subtract<Record<string, unknown>, null> {\n        return CollectionsUtil.isObject<T>(obj) && !CollectionsUtil.isNull(obj);\n    }\n\n    /**\n     * ** Check if some variable is of type Boolean and is true.\n     */\n    static isBooleanAndTrue(bool: boolean | any): boolean {\n        return CollectionsUtil.isBoolean(bool) && bool;\n    }\n\n    /**\n     * ** Check if value is literal Object or null.\n     *\n     *     - Not an Array, Map, WeakMap or Set.\n     */\n    static isLiteralObjectOrNull<T extends Record<string, unknown>>(obj: T | any): obj is LiteralObjectOrNull {\n        return (\n            CollectionsUtil.isObject(obj) &&\n            !CollectionsUtil.isArray(obj) &&\n            !CollectionsUtil.isMap(obj) &&\n            !CollectionsUtil.isWeakMap(obj) &&\n            !CollectionsUtil.isSet(obj)\n        );\n    }\n\n    /**\n     * ** Check if provided value is literal Object.\n     *\n     *     - Not and Array, Map, WeakMap, Set or null.\n     */\n    static isLiteralObject<T extends Record<string, unknown>>(obj: T | any): boolean {\n        return CollectionsUtil.isLiteralObjectOrNull(obj) && !CollectionsUtil.isNull(obj);\n    }\n\n    /**\n     * ** Check if value is Object and has properties.\n     */\n    static isObjectWithProperties<T extends Record<string, unknown>>(obj: T | any): boolean {\n        return CollectionsUtil.isObjectNotNull(obj) && Object.keys(obj).length > 0;\n    }\n\n    /**\n     * ** Return current Date in ISO string format.\n     */\n    static dateISO(): string {\n        return new Date().toISOString();\n    }\n\n    /**\n     * ** Return current Date milliseconds from 1970.\n     */\n    static dateNow(): number {\n        return Date.now();\n    }\n\n    /**\n     * ** Performs deep comparison between two values to determine if the are equivalent.\n     */\n    static isEqual(value1: any, value2: any): boolean {\n        return isEqual(value1, value2);\n    }\n\n    /**\n     * ** Create recursive deep cloned value from provided one.\n     */\n    static cloneDeep<T>(value: T): T {\n        return cloneDeep(value);\n    }\n\n    /**\n     * ** Generate UUID that meats RFC4122 compliance.\n     */\n    static generateUUID(): string {\n        // eslint-disable-next-line @typescript-eslint/no-unsafe-call\n        return uuidv4() as string;\n    }\n\n    /**\n     * ** Generate Object UUID that meats RFC4122 compliance and also has Class name identifier inside.\n     *\n     * <br/>\n     * <i>pattern</i>:\n     * <p>\n     *     <Class Name><strong>_</strong><UUID RFC4122>\n     * </p>\n     */\n    static generateObjectUUID(className: string): string {\n        return `${className}_${CollectionsUtil.generateUUID()}`;\n    }\n\n    /**\n     * ** Creates random string.\n     */\n    static generateRandomString(): string {\n        return (Math.random() + 1).toString(36).substring(2);\n    }\n\n    /**\n     * ** Iterates own enumerable properties in Object.\n     *\n     *     - use Object.keys method for extraction, and executes provided iteratorFn.\n     *     - if iteratorFn returns false or -1 it will break iteration.\n     *     - all other return values continue until last property.\n     *\n     *     - flag as third parameter is optional:\n     *          - Without flag or with flag and has value 'plainObject, method will iterate only through literal Objects.\n     *          - With flag and has value 'objectLookLike', method will try to iterate through everything\n     *                  that passes type value === 'object' (literal Object, Array, Map, Set, WeakMap, etc..).\n     */\n    static iterateObject<T extends Record<string, unknown>>(\n        obj: T,\n        iteratorFn: ObjectIterator<T, IteratorFnResult>,\n        flag: 'plainObject' | 'objectLookLike' = 'plainObject'\n    ): T | null {\n        if (!CollectionsUtil.isFunction(iteratorFn)) {\n            return null;\n        }\n\n        if (flag === 'objectLookLike') {\n            if (!CollectionsUtil.isObjectNotNull(obj)) {\n                return null;\n            }\n        } else {\n            if (!CollectionsUtil.isLiteralObject(obj)) {\n                return null;\n            }\n        }\n\n        const objectKeys = Object.keys(obj);\n        for (const key of objectKeys) {\n            const resultOfIteratorFn = iteratorFn(obj[key] as T[keyof T], key, obj);\n            if (resultOfIteratorFn === false || resultOfIteratorFn === -1) {\n                break;\n            }\n        }\n\n        return obj;\n    }\n\n    /**\n     * ** Check if value is Literal Object and has properties.\n     */\n    static isLiteralObjectWithProperties<T extends Record<string, unknown>>(obj: T | unknown): boolean {\n        return CollectionsUtil.isLiteralObject<T>(obj) && Object.keys(obj).length > 0;\n    }\n\n    /**\n     * ** Iterates over object properties and return Array of its values.\n     */\n    static objectValues<T extends Record<string, any>>(obj: T | null | undefined): Array<T[keyof T]> {\n        const _result: Array<T[keyof T]> = [];\n\n        CollectionsUtil.iterateObject(obj, (value) => {\n            _result.push(value);\n        });\n\n        return _result;\n    }\n\n    /**\n     * ** Transform given Map to Object.\n     */\n    static transformMapToObject<T extends Map<string, unknown>>(map: T): { [key: string]: unknown } {\n        const obj: { [key: string]: any } = {};\n\n        map.forEach((value, key) => (obj[key] = value));\n\n        return obj;\n    }\n\n    /**\n     * ** Transform given Object to Map.\n     */\n    static transformObjectToMap<T extends { [key: string]: any }>(obj: T): Map<string, any> {\n        const map = new Map<string, any>();\n\n        CollectionsUtil.iterateObject(obj, (value, key) => {\n            map.set(key, value);\n        });\n\n        return map;\n    }\n\n    /**\n     * ** Iterates over object properties and return Array of its keys/values in pairs.\n     * <p>\n     *     - Returns Array of subArrays that have 2 elements each, first element key and second element value.\n     */\n    static objectPairs<T extends Record<keyof T, T[keyof T]>>(obj: T | null | undefined): Array<[keyof T, T[keyof T]]> {\n        if (!CollectionsUtil.isLiteralObject(obj)) {\n            return [];\n        }\n\n        return Object.entries(obj) as Array<[keyof T, T[keyof T]]>;\n    }\n\n    /**\n     * ** Return own property Descriptor from provided object/function.\n     */\n    static getObjectPropertyDescriptor<T extends Record<string, any>>(obj: T, key: string): PropertyDescriptor {\n        if (!((CollectionsUtil.isFunction(obj) || CollectionsUtil.isObject(obj)) && CollectionsUtil.isString(key))) {\n            return null;\n        }\n\n        return Object.getOwnPropertyDescriptor(obj, key);\n    }\n\n    /**\n     * ** Iterates own enumerable properties (statics) of Function (Class).\n     *\n     *     - use Object.getOwnPropertyDescriptors method for extraction, and executes provided iteratorFn.\n     *     - if iteratorFn returns false or -1 will break iteration.\n     *     - all other return values means continue until last property.\n     */\n    static iterateClassStatics<T extends Record<string, any>>(\n        fn: T,\n        iteratorFn: (descriptor: PropertyDescriptor, key: string, fn: T) => IteratorFnResult\n    ) {\n        if (!CollectionsUtil.isFunction(fn) || !CollectionsUtil.isFunction(iteratorFn)) {\n            return null;\n        }\n\n        const descriptors = Object.getOwnPropertyDescriptors(fn);\n        CollectionsUtil.iterateObject(descriptors, (descriptor: PropertyDescriptor, key) => iteratorFn(descriptor, key, fn));\n\n        return fn;\n    }\n\n    /**\n     * ** Check if two Maps are Equal.\n     *\n     *   - They are equal if they have same references.\n     *   - They are equal if they have same keys and same values for compared keys.\n     */\n    static areMapsEqual(m1: Map<unknown, unknown>, m2: Map<unknown, unknown>): boolean {\n        const evaluateDeepComparison = () => {\n            for (const [key, val] of m1) {\n                const compareVal = m2.get(key);\n\n                if (CollectionsUtil.isMap(val)) {\n                    if (!CollectionsUtil.areMapsEqual(val, compareVal as Map<unknown, unknown>)) {\n                        return false;\n                    }\n\n                    continue;\n                }\n\n                if (!CollectionsUtil.isEqual(val, compareVal) || (CollectionsUtil.isUndefined(compareVal) && !m2.has(key))) {\n                    return false;\n                }\n            }\n\n            return true;\n        };\n\n        return CollectionsUtil.isMap(m1) && CollectionsUtil.isMap(m2) && (m1 === m2 || (m1.size === m2.size && evaluateDeepComparison()));\n    }\n\n    /**\n     * ** Interpolate string and replace while iterating through provided strings.\n     *\n     *      - Replacers are strings that are replaced on every place where %s is found starting from index 0.\n     */\n    static interpolateString(target: string, ...replacers: string[]): string;\n    /**\n     * ** Interpolate text and replace while iterating through provided replacers.\n     *\n     *      - Replacers are objects ofType {@link Replacer} that are iterates and consumes,\n     *              searchValue is matcher and replaceValue is value that is placed on match.\n     */\n    static interpolateString(target: string, ...replacers: Array<Replacer<string>>): string;\n    /**\n     * @inheritDoc\n     */\n    static interpolateString(target: string, ...replacers: string[] | Array<Replacer<string>>): string {\n        let response = target;\n\n        replacers.forEach((replacer: string | Replacer<string>) => {\n            if (CollectionsUtil.isString(replacer)) {\n                response = response.replace('%s', replacer);\n            } else {\n                response = response.replace(replacer.searchValue, replacer.replaceValue);\n            }\n        });\n\n        return response;\n    }\n}\n"]}