@decaf-ts/for-angular 0.0.17 → 0.0.19
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/assets/i18n/en.json +3 -73
- package/assets/i18n/pt.json +5 -74
- package/components/crud-field/crud-field.component.d.ts +12 -3
- package/components/crud-form/crud-form.component.d.ts +36 -14
- package/components/empty-state/empty-state.component.d.ts +9 -10
- package/components/fieldset/fieldset.component.d.ts +9 -0
- package/components/filter/filter.component.d.ts +11 -2
- package/engine/NgxBaseComponent.d.ts +39 -39
- package/engine/NgxCrudFormField.d.ts +2 -1
- package/engine/NgxRenderingEngine.d.ts +44 -16
- package/engine/interfaces.d.ts +10 -0
- package/engine/types.d.ts +8 -0
- package/esm2022/components/crud-field/crud-field.component.mjs +23 -3
- package/esm2022/components/crud-form/crud-form.component.mjs +33 -18
- package/esm2022/components/empty-state/empty-state.component.mjs +11 -10
- package/esm2022/components/fieldset/fieldset.component.mjs +7 -4
- package/esm2022/components/filter/filter.component.mjs +16 -6
- package/esm2022/components/layout/layout.component.mjs +3 -3
- package/esm2022/components/list-item/list-item.component.mjs +4 -4
- package/esm2022/components/pagination/pagination.component.mjs +6 -6
- package/esm2022/engine/NgxBaseComponent.mjs +48 -53
- package/esm2022/engine/NgxCrudFormField.mjs +1 -1
- package/esm2022/engine/NgxRenderingEngine.mjs +20 -4
- package/esm2022/engine/interfaces.mjs +1 -1
- package/esm2022/engine/types.mjs +1 -1
- package/esm2022/helpers/utils.mjs +49 -32
- package/esm2022/i18n/Loader.mjs +82 -0
- package/fesm2022/decaf-ts-for-angular.mjs +288 -134
- package/fesm2022/decaf-ts-for-angular.mjs.map +1 -1
- package/helpers/utils.d.ts +42 -17
- package/i18n/Loader.d.ts +48 -0
- package/package.json +10 -1
|
@@ -190,20 +190,16 @@ export function isNotUndefined(prop) {
|
|
|
190
190
|
* @memberOf module:for-angular
|
|
191
191
|
*/
|
|
192
192
|
export function getLocaleFromClassName(instance, suffix) {
|
|
193
|
-
if (typeof instance !==
|
|
194
|
-
instance =
|
|
195
|
-
instance.name || instance?.constructor?.name;
|
|
193
|
+
if (typeof instance !== Primitives.STRING)
|
|
194
|
+
instance = instance.name || instance?.constructor?.name;
|
|
196
195
|
let name = instance;
|
|
197
196
|
if (suffix)
|
|
198
197
|
name = `${instance}${suffix.charAt(0).toUpperCase() + suffix.slice(1)}`;
|
|
199
|
-
name = name
|
|
200
|
-
.replace(/_|-/g, '')
|
|
201
|
-
.replace(/(?:^\w|[A-Z]|\b\w)/g, (word, index) => {
|
|
198
|
+
name = name.replace(/_|-/g, '').replace(/(?:^\w|[A-Z]|\b\w)/g, (word, index) => {
|
|
202
199
|
if (index > 1)
|
|
203
200
|
word = '.' + word;
|
|
204
201
|
return word.toLowerCase();
|
|
205
|
-
})
|
|
206
|
-
.split('.');
|
|
202
|
+
}).split('.');
|
|
207
203
|
if (name.length < 3)
|
|
208
204
|
return name.reverse().join('.');
|
|
209
205
|
const preffix = name[name.length - 1];
|
|
@@ -211,27 +207,6 @@ export function getLocaleFromClassName(instance, suffix) {
|
|
|
211
207
|
name = name.join('_');
|
|
212
208
|
return `${preffix}.${name}`;
|
|
213
209
|
}
|
|
214
|
-
/**
|
|
215
|
-
* @description Generates a localized string by combining locale and phrase
|
|
216
|
-
* @summary This utility function creates a properly formatted locale string by combining
|
|
217
|
-
* a locale identifier with a phrase. It handles edge cases such as empty phrases,
|
|
218
|
-
* missing locales, and phrases that already include the locale prefix. This function
|
|
219
|
-
* is useful for ensuring consistent formatting of localized strings throughout the application.
|
|
220
|
-
*
|
|
221
|
-
* @param {string} locale - The locale identifier (e.g., 'en', 'fr')
|
|
222
|
-
* @param {string | undefined} phrase - The phrase to localize
|
|
223
|
-
* @return {string} The formatted locale string, or empty string if phrase is undefined
|
|
224
|
-
*
|
|
225
|
-
* @function generateLocaleFromString
|
|
226
|
-
* @memberOf module:for-angular
|
|
227
|
-
*/
|
|
228
|
-
export function generateLocaleFromString(locale, phrase) {
|
|
229
|
-
if (!phrase)
|
|
230
|
-
return '';
|
|
231
|
-
if (!locale || phrase.includes(`${locale}.`))
|
|
232
|
-
return phrase;
|
|
233
|
-
return `${locale}.${phrase}`;
|
|
234
|
-
}
|
|
235
210
|
/**
|
|
236
211
|
* @description Retrieves the current locale language
|
|
237
212
|
* @summary This utility function gets the current locale language based on the user's browser settings.
|
|
@@ -402,18 +377,60 @@ export function dataMapper(data, mapper, props) {
|
|
|
402
377
|
const item = itemMapper(curr, mapper, props);
|
|
403
378
|
const hasValues = [...new Set(Object.values(item))].filter((value) => value).length >
|
|
404
379
|
0;
|
|
405
|
-
// caso o item filtrado não possua nenhum valor, passar o objeto original
|
|
406
380
|
accum.push(hasValues ? item : curr);
|
|
407
381
|
return accum;
|
|
408
382
|
}, []);
|
|
409
383
|
}
|
|
384
|
+
/**
|
|
385
|
+
* @description Removes focus from the currently active DOM element
|
|
386
|
+
* @summary This utility function blurs the currently focused element in the document,
|
|
387
|
+
* effectively removing focus traps that might prevent proper navigation or keyboard
|
|
388
|
+
* interaction. It safely accesses the document's activeElement and calls blur() if
|
|
389
|
+
* an element is currently focused. This is useful for accessibility and user experience
|
|
390
|
+
* improvements, particularly when closing modals or dialogs.
|
|
391
|
+
*
|
|
392
|
+
* @return {void}
|
|
393
|
+
*
|
|
394
|
+
* @function removeFocusTrap
|
|
395
|
+
* @memberOf module:for-angular
|
|
396
|
+
*/
|
|
410
397
|
export function removeFocusTrap() {
|
|
411
398
|
const doc = getWindowDocument();
|
|
412
399
|
if (doc?.activeElement)
|
|
413
400
|
doc.activeElement?.blur();
|
|
414
401
|
}
|
|
415
|
-
|
|
402
|
+
/**
|
|
403
|
+
* @description Cleans and normalizes whitespace in a string value
|
|
404
|
+
* @summary This utility function trims leading and trailing whitespace from a string
|
|
405
|
+
* and replaces multiple consecutive whitespace characters with a single space.
|
|
406
|
+
* Optionally converts the result to lowercase for consistent text processing.
|
|
407
|
+
* This is useful for normalizing user input, search terms, or data sanitization.
|
|
408
|
+
*
|
|
409
|
+
* @param {string} value - The string value to clean and normalize
|
|
410
|
+
* @param {boolean} [lowercase=false] - Whether to convert the result to lowercase
|
|
411
|
+
* @return {string} The cleaned and normalized string
|
|
412
|
+
*
|
|
413
|
+
* @function cleanSpaces
|
|
414
|
+
* @memberOf module:for-angular
|
|
415
|
+
*/
|
|
416
|
+
export function cleanSpaces(value = "", lowercase = false) {
|
|
416
417
|
value = `${value}`.trim().replace(/\s+/g, ' ');
|
|
417
418
|
return lowercase ? value.toLowerCase() : value;
|
|
418
419
|
}
|
|
419
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/lib/helpers/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { isDevMode } from '@angular/core';\nimport { InjectableRegistryImp, InjectablesRegistry } from '@decaf-ts/injectable-decorators';\nimport { Primitives } from '@decaf-ts/decorator-validation';\nimport { KeyValue, StringOrBoolean, } from '../engine/types';\nimport { FunctionLike } from '../engine/types';\nimport { getLogger } from '../for-angular.module';\n\nlet injectableRegistry: InjectablesRegistry;\n\n/**\n * @description Retrieves the singleton instance of the injectables registry\n * @summary This function implements the singleton pattern for the InjectablesRegistry.\n * It returns the existing registry instance if one exists, or creates a new instance\n * if none exists. The registry is used to store and retrieve injectable dependencies\n * throughout the application.\n *\n * @return {InjectablesRegistry} The singleton injectables registry instance\n *\n * @function getInjectablesRegistry\n * @memberOf module:for-angular\n */\nexport function getInjectablesRegistry(): InjectablesRegistry {\n  if (!injectableRegistry)\n    injectableRegistry = new InjectableRegistryImp();\n  return injectableRegistry;\n}\n\n/**\n * @description Determines if the application is running in development mode\n * @summary This function checks whether the application is currently running in a development\n * environment. It uses Angular's isDevMode() function and also checks the window context\n * and hostname against the provided context parameter. This is useful for enabling\n * development-specific features or logging.\n *\n * @param {string} [context='localhost'] - The context string to check against the current environment\n * @return {boolean} True if the application is running in development mode, false otherwise\n *\n * @function isDevelopmentMode\n * @memberOf module:for-angular\n */\nexport function isDevelopmentMode(context: string = 'localhost'): boolean {\n  if (!context)\n    return isDevMode();\n  const win = getWindow();\n  return (\n    isDevMode() ||\n    win?.['env']?.['CONTEXT'].toLowerCase() !== context.toLowerCase() ||\n    win?.['location']?.hostname?.includes(context)\n  );\n}\n\n/**\n * @description Dispatches a custom event to the document window\n * @summary This function creates and dispatches a custom event to the browser window.\n * It's useful for cross-component communication or for triggering application-wide events.\n * The function allows specifying the event name, detail data, and additional event properties.\n *\n * @param {string} name - The name of the custom event to dispatch\n * @param {unknown} detail - The data to include in the event's detail property\n * @param {object} [props] - Optional additional properties for the custom event\n * @return {void}\n *\n * @function windowEventEmitter\n * @memberOf module:for-angular\n */\nexport function windowEventEmitter(\n  name: string,\n  detail: unknown,\n  props?: object\n): void {\n  const data = Object.assign(\n    {\n      bubbles: true,\n      composed: true,\n      cancelable: false,\n      detail: detail,\n    },\n    props || {}\n  );\n  (getWindow() as Window).dispatchEvent(new CustomEvent(name, data));\n}\n/**\n * @description Retrieves a property from the window's document object\n * @summary This function provides a safe way to access properties on the window's document object.\n * It uses the getWindowDocument function to get a reference to the document, then accesses\n * the specified property. This is useful for browser environment interactions that need\n * to access document properties.\n *\n * @param {string} key - The name of the property to retrieve from the document object\n * @return {any} The value of the specified property, or undefined if the document or property doesn't exist\n *\n * @function getOnWindowDocument\n * @memberOf module:for-angular\n */\nexport function getOnWindowDocument(key: string): Document | undefined {\n  const doc = getWindowDocument()?.[key as keyof Document];\n  return doc instanceof Document ?\n    doc : undefined;\n}\n\n/**\n * @description Retrieves the document object from the window\n * @summary This function provides a safe way to access the document object from the window.\n * It uses the getOnWindow function to retrieve the 'document' property from the window object.\n * This is useful for browser environment interactions that need access to the document.\n *\n * @return {Document | undefined} The window's document object, or undefined if it doesn't exist\n *\n * @function getWindowDocument\n * @memberOf module:for-angular\n */\nexport function getWindowDocument(): Document | undefined {\n  return getOnWindow('document') as Document;\n}\n\n/**\n * @description Retrieves a property from the window object\n * @summary This function provides a safe way to access properties on the window object.\n * It uses the getWindow function to get a reference to the window, then accesses\n * the specified property. This is useful for browser environment interactions that need\n * to access window properties or APIs.\n *\n * @param {string} key - The name of the property to retrieve from the window object\n * @return {unknown | undefined} The value of the specified property, or undefined if the window or property doesn't exist\n *\n * @function getOnWindow\n * @memberOf module:for-angular\n */\nexport function getOnWindow(key: string): unknown | undefined {\n  return getWindow()?.[key];\n}\n\n/**\n * @description Sets a property on the window object\n * @summary This function provides a way to set properties on the window object.\n * It uses the getWindow function to get a reference to the window, then sets\n * the specified property to the provided value. This is useful for storing\n * global data or functions that need to be accessible across the application.\n *\n * @param {string} key - The name of the property to set on the window object\n * @param {any} value - The value to assign to the property\n * @return {void}\n *\n * @function setOnWindow\n * @memberOf module:for-angular\n */\nexport function setOnWindow(key: string, value: unknown): void {\n  getWindow()[key] = value;\n}\n\n/**\n * @description Retrieves the global window object\n * @summary This function provides a safe way to access the global window object.\n * It uses globalThis to ensure compatibility across different JavaScript environments.\n * This is the core function used by other window-related utility functions to\n * access the window object.\n *\n * @return {Window} The global window object\n *\n * @function getWindow\n * @memberOf module:for-angular\n */\nexport function getWindow(): Window & KeyValue {\n  return (globalThis as KeyValue)?.['window'] as Window & KeyValue;\n}\n\n/**\n * @description Retrieves the width of the browser window\n * @summary This function provides a convenient way to get the current width of the browser window.\n * It uses the getOnWindow function to access the 'innerWidth' property of the window object.\n * This is useful for responsive design implementations and viewport-based calculations.\n *\n * @return {number | undefined} The current width of the browser window in pixels\n *\n * @function getWindowWidth\n * @memberOf module:for-angular\n */\nexport function getWindowWidth(): number {\n  return getOnWindow('innerWidth') as number || 0;\n}\n\n/**\n * @description Checks if a value is  not undefined\n * @summary This utility function determines whether a given value is not undefined.\n * It's a simple wrapper that makes code more readable when checking for defined values.\n * The function is particularly useful for checking StringOrBoolean properties that might be undefined.\n *\n * @param {StringOrBoolean | undefined} prop - The property to check\n * @return {boolean} True if the property is not undefined, false otherwise\n *\n * @function isNotUndefined\n * @memberOf module:for-angular\n */\nexport function isNotUndefined(prop: StringOrBoolean | undefined): boolean {\n  return (prop !== undefined) as boolean;\n}\n\n/**\n * @description Generates a locale string from a class name or instance\n * @summary This utility function converts a class name or instance into a locale string\n * that can be used for internationalization purposes. It handles different input types\n * (string, function, or object) and applies formatting rules to generate a consistent\n * locale identifier. For short names (less than 3 parts), it reverses the dot-separated\n * string. For longer names, it uses the last part as a prefix and joins the rest with\n * underscores.\n *\n * @param {string|FunctionLike|object} instance - The input to generate the locale from (class name, constructor, or instance)\n * @param {string} [suffix] - Optional string to append to the instance name before processing\n * @return {string} A formatted locale string derived from the input\n *\n * @function getLocaleFromClassName\n * @memberOf module:for-angular\n */\nexport function getLocaleFromClassName(\n  instance: string | FunctionLike | object,\n  suffix?: string\n): string {\n  if (typeof instance !== 'string')\n    instance =\n      (instance as FunctionLike).name || (instance as object)?.constructor?.name;\n\n  let name: string | string[] = instance;\n\n  if (suffix) name = `${instance}${suffix.charAt(0).toUpperCase() + suffix.slice(1)}`;\n\n  name = name\n    .replace(/_|-/g, '')\n    .replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (word: string, index: number) => {\n      if (index > 1) word = '.' + word;\n      return word.toLowerCase();\n    })\n    .split('.');\n\n  if (name.length < 3)\n    return name.reverse().join('.');\n\n  const preffix = name[name.length - 1];\n  name.pop();\n  name = name.join('_');\n  return `${preffix}.${name}`;\n\n\n}\n\n/**\n * @description Generates a localized string by combining locale and phrase\n * @summary This utility function creates a properly formatted locale string by combining\n * a locale identifier with a phrase. It handles edge cases such as empty phrases,\n * missing locales, and phrases that already include the locale prefix. This function\n * is useful for ensuring consistent formatting of localized strings throughout the application.\n *\n * @param {string} locale - The locale identifier (e.g., 'en', 'fr')\n * @param {string | undefined} phrase - The phrase to localize\n * @return {string} The formatted locale string, or empty string if phrase is undefined\n *\n * @function generateLocaleFromString\n * @memberOf module:for-angular\n */\nexport function generateLocaleFromString(\n  locale: string,\n  phrase: string | undefined\n): string {\n  if (!phrase) return '';\n  if (!locale || phrase.includes(`${locale}.`)) return phrase;\n  return `${locale}.${phrase}`;\n}\n\n\n/**\n * @description Retrieves the current locale language\n * @summary This utility function gets the current locale language based on the user's browser settings.\n * It provides a consistent way to access the user's language preference throughout the application.\n * The function returns the browser's navigator.language value, defaulting to 'en' if not available.\n *\n * @return {string} The current locale language (e.g., 'en', 'fr')\n *\n * @function getLocaleLanguage\n * @memberOf module:for-angular\n */\nexport function getLocaleLanguage(): string {\n  const win = getWindow();\n  return (win as Window).navigator.language || \"en\";\n  // return win?.[WINDOW_KEYS.LANGUAGE_SELECTED] || (win.navigator.language || '').split('-')[0] || \"en\";\n}\n\n\n\n/**\n * @description Generates a random string or number of specified length\n * @summary This utility function creates a random string of a specified length.\n * It can generate either alphanumeric strings (including uppercase and lowercase letters)\n * or numeric-only strings. This is useful for creating random IDs, temporary passwords,\n * or other random identifiers throughout the application.\n *\n * @param {number} [length=8] - The length of the random value to generate\n * @param {boolean} [onlyNumbers=false] - Whether to generate only numeric characters\n * @return {string} A randomly generated string of the specified length and character set\n *\n * @function generateRandomValue\n * @memberOf module:for-angular\n */\nexport function generateRandomValue(length: number = 8, onlyNumbers: boolean = false): string {\n  const chars = onlyNumbers\n    ? '0123456789'\n    : 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n  let result = '';\n  for (let i = 0; i < length; i++)\n    result += chars.charAt(Math.floor(Math.random() * chars.length));\n\n  return result;\n}\n\n\n/**\n * Converts a string representation of a boolean or a boolean value to a boolean type.\n *\n * @export\n * @param {('true' | 'false' | boolean)} prop - The value to convert. Can be the string 'true', 'false', or a boolean.\n * @returns {boolean} The boolean representation of the input value. Returns true if the input is the string 'true' or boolean true, false otherwise.\n */\nexport function stringToBoolean(prop: 'true' | 'false' | boolean): boolean {\n  if(typeof prop === 'string')\n    prop = prop.toLowerCase() === 'true' ? true : false;\n  return prop;\n}\n\n\n/**\n * Checks if a value is a valid Date object\n *\n * @param {(string | Date | number)} date - The value to check. Can be a Date object, a timestamp number, or a date string\n * @return {boolean} Returns true if the value is a valid Date object (not NaN), otherwise false\n */\nexport function isValidDate(date: string | Date | number): boolean {\n  try {\n    return (date instanceof Date && !isNaN(date as unknown as number)) || (() => {\n      const testRegex = new RegExp(/^\\d{4}-\\d{2}-\\d{2}$/).test(date as string)\n      if(typeof date !== Primitives.STRING || !(date as string)?.includes('T') && !testRegex)\n         return false;\n\n     date = (date as string).split('T')[0];\n    if(!new RegExp(/^\\d{4}-\\d{2}-\\d{2}$/).test(date))\n      return false;\n\n    return !!(new Date(date));\n   })();\n  } catch(error: unknown) {\n    getLogger(isValidDate).error(error as Error | string);\n    return false;\n  }\n}\n\n/**\n * Formats a date into a localized string representation\n *\n * @param {(string | Date | number)} date - The date to format. Can be a Date object, a timestamp number, or a date string\n * @param {string} [locale] - The locale to use for formatting. If not provided, the system's locale will be used\n * @return {(Date | string)} A formatted date string in the format DD/MM/YYYY according to the specified locale,\n *                           or the original input as a string if the date is invalid\n */\nexport function formatDate(date: string | Date | number, locale?: string | undefined): Date | string {\n\n  if(!locale)\n    locale = getLocaleLanguage();\n\n  if(typeof date === 'string' || typeof date === 'number')\n    date = new Date(typeof date === 'string' ? date.replace(/\\//g, '-') : date);\n\n  if(!isValidDate(date))\n    return `${date}` as string;\n  const r = date.toLocaleString(locale, {\n      year: \"numeric\",\n      day: \"2-digit\",\n      month: '2-digit'\n  });\n\n\n  return r;\n}\n\n/**\n * Attempts to parse a date string, Date object, or number into a valid Date object\n *\n * @param {(string | Date | number)} date - The date to parse. Can be a Date object, a timestamp number,\n *                                         or a date string in the format \"DD/MM/YYYY HH:MM:SS:MS\"\n * @return {(Date | null)} A valid Date object if parsing is successful, or null if the date is invalid\n *                         or doesn't match the expected format\n */\nexport function parseToValidDate(date: string | Date | number): Date | null {\n  if(isValidDate(date))\n    return date as Date;\n\n  if(!`${date}`.includes('/'))\n    return null;\n\n  const [dateString, timeString] = (date as string).split(' ');\n  const [day, month, year] = dateString.split('/').map(Number);\n  const [hours, minutes, seconds, milliseconds] = timeString.split(':').map(Number);\n  date = new Date(year, month - 1, day, hours, minutes, seconds, milliseconds);\n\n  if(!isValidDate(date)) {\n    console.warn('parseToValidDate - Invalid date format', date);\n    return null;\n  }\n\n  return date;\n}\n\n\n/**\n * Maps an item object using a provided mapper object and optional additional properties.\n *\n * @param {KeyValue} item - The source object to be mapped.\n * @param {KeyValue} mapper - An object that defines the mapping rules. Keys represent the new property names,\n *                            and values represent the path to the corresponding values in the source object.\n * @param {KeyValue} [props] - Optional additional properties to be included in the mapped object.\n * @returns {KeyValue} A new object with properties mapped according to the mapper object and including any additional properties.\n */\nexport function itemMapper(item: KeyValue, mapper: KeyValue, props?: KeyValue): KeyValue {\n  return Object.entries(mapper).reduce((accum: KeyValue, [key, value]) => {\n    const arrayValue = (value as string).split('.');\n    if (!value) {\n      accum[key] = value;\n    } else {\n      if (arrayValue.length === 1) {\n        accum[key] = item?.[value as string] || (value !== key ? value : \"\");\n      } else {\n        let val;\n\n        for (const _value of arrayValue)\n          val = !val\n            ? item[_value]\n            : (typeof val === 'string' ? JSON.parse(val) : val)[_value];\n\n        if (isValidDate(new Date(val))) val = `${formatDate(val)}`;\n\n        accum[key] = val === null || val === undefined ? value : val;\n      }\n    }\n    return Object.assign({}, props || {}, accum);\n  }, {});\n}\n\n/**\n * Maps an array of data objects using a provided mapper object.\n *\n * @template T - The type of the resulting mapped items.\n * @param {any[]} data - The array of data objects to be mapped.\n * @param {KeyValue} mapper - An object that defines the mapping rules.\n * @param {KeyValue} [props] - Additional properties to be included in the mapped items.\n *\n * @returns {T[]} - The array of mapped items. If an item in the original array does not have any non-null values after mapping,\n * the original item is returned instead.\n */\nexport function dataMapper<T>(data: T[], mapper: KeyValue, props?: KeyValue): T[] {\n  if (!data || !data.length) return [];\n  return data.reduce((accum: T[], curr) => {\n    const item = itemMapper(curr as KeyValue, mapper, props) as T;\n    const hasValues =\n      [...new Set(Object.values(item as T[]))].filter((value) => value).length >\n      0;\n    // caso o item filtrado não possua nenhum valor, passar o objeto original\n    accum.push(hasValues ? item : curr);\n    return accum;\n  }, []);\n}\n\n\nexport function removeFocusTrap(): void {\n  const doc = getWindowDocument();\n  if(doc?.activeElement)\n    (doc.activeElement as HTMLElement)?.blur();\n}\n\nexport function cleanSpaces(value: string, lowercase = false): string {\n  value = `${value}`.trim().replace(/\\s+/g, ' ');\n  return lowercase ? value.toLowerCase() : value;\n}\n"]}
|
|
420
|
+
/**
|
|
421
|
+
* @description Determines if the user's system is currently in dark mode
|
|
422
|
+
* @summary This function checks the user's color scheme preference using the CSS media query
|
|
423
|
+
* '(prefers-color-scheme: dark)'. It returns a boolean indicating whether the system is
|
|
424
|
+
* currently set to dark mode. This is useful for implementing theme-aware functionality
|
|
425
|
+
* and adjusting UI elements based on the user's preferred color scheme.
|
|
426
|
+
*
|
|
427
|
+
* @return {Promise<boolean>} True if the system is in dark mode, false otherwise
|
|
428
|
+
*
|
|
429
|
+
* @function isDarkMode
|
|
430
|
+
* @memberOf module:for-angular
|
|
431
|
+
*/
|
|
432
|
+
export async function isDarkMode() {
|
|
433
|
+
const { matches } = getWindow().matchMedia('(prefers-color-scheme: dark)');
|
|
434
|
+
return matches;
|
|
435
|
+
}
|
|
436
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../src/lib/helpers/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { isDevMode } from '@angular/core';\nimport { InjectableRegistryImp, InjectablesRegistry } from '@decaf-ts/injectable-decorators';\nimport { Primitives } from '@decaf-ts/decorator-validation';\nimport { KeyValue, StringOrBoolean, } from '../engine/types';\nimport { FunctionLike } from '../engine/types';\nimport { getLogger } from '../for-angular.module';\n\nlet injectableRegistry: InjectablesRegistry;\n\n/**\n * @description Retrieves the singleton instance of the injectables registry\n * @summary This function implements the singleton pattern for the InjectablesRegistry.\n * It returns the existing registry instance if one exists, or creates a new instance\n * if none exists. The registry is used to store and retrieve injectable dependencies\n * throughout the application.\n *\n * @return {InjectablesRegistry} The singleton injectables registry instance\n *\n * @function getInjectablesRegistry\n * @memberOf module:for-angular\n */\nexport function getInjectablesRegistry(): InjectablesRegistry {\n  if (!injectableRegistry)\n    injectableRegistry = new InjectableRegistryImp();\n  return injectableRegistry;\n}\n\n/**\n * @description Determines if the application is running in development mode\n * @summary This function checks whether the application is currently running in a development\n * environment. It uses Angular's isDevMode() function and also checks the window context\n * and hostname against the provided context parameter. This is useful for enabling\n * development-specific features or logging.\n *\n * @param {string} [context='localhost'] - The context string to check against the current environment\n * @return {boolean} True if the application is running in development mode, false otherwise\n *\n * @function isDevelopmentMode\n * @memberOf module:for-angular\n */\nexport function isDevelopmentMode(context: string = 'localhost'): boolean {\n  if (!context)\n    return isDevMode();\n  const win = getWindow();\n  return (\n    isDevMode() ||\n    win?.['env']?.['CONTEXT'].toLowerCase() !== context.toLowerCase() ||\n    win?.['location']?.hostname?.includes(context)\n  );\n}\n\n/**\n * @description Dispatches a custom event to the document window\n * @summary This function creates and dispatches a custom event to the browser window.\n * It's useful for cross-component communication or for triggering application-wide events.\n * The function allows specifying the event name, detail data, and additional event properties.\n *\n * @param {string} name - The name of the custom event to dispatch\n * @param {unknown} detail - The data to include in the event's detail property\n * @param {object} [props] - Optional additional properties for the custom event\n * @return {void}\n *\n * @function windowEventEmitter\n * @memberOf module:for-angular\n */\nexport function windowEventEmitter(\n  name: string,\n  detail: unknown,\n  props?: object\n): void {\n  const data = Object.assign(\n    {\n      bubbles: true,\n      composed: true,\n      cancelable: false,\n      detail: detail,\n    },\n    props || {}\n  );\n  (getWindow() as Window).dispatchEvent(new CustomEvent(name, data));\n}\n/**\n * @description Retrieves a property from the window's document object\n * @summary This function provides a safe way to access properties on the window's document object.\n * It uses the getWindowDocument function to get a reference to the document, then accesses\n * the specified property. This is useful for browser environment interactions that need\n * to access document properties.\n *\n * @param {string} key - The name of the property to retrieve from the document object\n * @return {any} The value of the specified property, or undefined if the document or property doesn't exist\n *\n * @function getOnWindowDocument\n * @memberOf module:for-angular\n */\nexport function getOnWindowDocument(key: string): Document | undefined {\n  const doc = getWindowDocument()?.[key as keyof Document];\n  return doc instanceof Document ?\n    doc : undefined;\n}\n\n/**\n * @description Retrieves the document object from the window\n * @summary This function provides a safe way to access the document object from the window.\n * It uses the getOnWindow function to retrieve the 'document' property from the window object.\n * This is useful for browser environment interactions that need access to the document.\n *\n * @return {Document | undefined} The window's document object, or undefined if it doesn't exist\n *\n * @function getWindowDocument\n * @memberOf module:for-angular\n */\nexport function getWindowDocument(): Document | undefined {\n  return getOnWindow('document') as Document;\n}\n\n/**\n * @description Retrieves a property from the window object\n * @summary This function provides a safe way to access properties on the window object.\n * It uses the getWindow function to get a reference to the window, then accesses\n * the specified property. This is useful for browser environment interactions that need\n * to access window properties or APIs.\n *\n * @param {string} key - The name of the property to retrieve from the window object\n * @return {unknown | undefined} The value of the specified property, or undefined if the window or property doesn't exist\n *\n * @function getOnWindow\n * @memberOf module:for-angular\n */\nexport function getOnWindow(key: string): unknown | undefined {\n  return getWindow()?.[key];\n}\n\n/**\n * @description Sets a property on the window object\n * @summary This function provides a way to set properties on the window object.\n * It uses the getWindow function to get a reference to the window, then sets\n * the specified property to the provided value. This is useful for storing\n * global data or functions that need to be accessible across the application.\n *\n * @param {string} key - The name of the property to set on the window object\n * @param {any} value - The value to assign to the property\n * @return {void}\n *\n * @function setOnWindow\n * @memberOf module:for-angular\n */\nexport function setOnWindow(key: string, value: unknown): void {\n  getWindow()[key] = value;\n}\n\n/**\n * @description Retrieves the global window object\n * @summary This function provides a safe way to access the global window object.\n * It uses globalThis to ensure compatibility across different JavaScript environments.\n * This is the core function used by other window-related utility functions to\n * access the window object.\n *\n * @return {Window} The global window object\n *\n * @function getWindow\n * @memberOf module:for-angular\n */\nexport function getWindow(): Window & KeyValue {\n  return (globalThis as KeyValue)?.['window'] as Window & KeyValue;\n}\n\n/**\n * @description Retrieves the width of the browser window\n * @summary This function provides a convenient way to get the current width of the browser window.\n * It uses the getOnWindow function to access the 'innerWidth' property of the window object.\n * This is useful for responsive design implementations and viewport-based calculations.\n *\n * @return {number | undefined} The current width of the browser window in pixels\n *\n * @function getWindowWidth\n * @memberOf module:for-angular\n */\nexport function getWindowWidth(): number {\n  return getOnWindow('innerWidth') as number || 0;\n}\n\n/**\n * @description Checks if a value is  not undefined\n * @summary This utility function determines whether a given value is not undefined.\n * It's a simple wrapper that makes code more readable when checking for defined values.\n * The function is particularly useful for checking StringOrBoolean properties that might be undefined.\n *\n * @param {StringOrBoolean | undefined} prop - The property to check\n * @return {boolean} True if the property is not undefined, false otherwise\n *\n * @function isNotUndefined\n * @memberOf module:for-angular\n */\nexport function isNotUndefined(prop: StringOrBoolean | undefined): boolean {\n  return (prop !== undefined) as boolean;\n}\n\n/**\n * @description Generates a locale string from a class name or instance\n * @summary This utility function converts a class name or instance into a locale string\n * that can be used for internationalization purposes. It handles different input types\n * (string, function, or object) and applies formatting rules to generate a consistent\n * locale identifier. For short names (less than 3 parts), it reverses the dot-separated\n * string. For longer names, it uses the last part as a prefix and joins the rest with\n * underscores.\n *\n * @param {string|FunctionLike|object} instance - The input to generate the locale from (class name, constructor, or instance)\n * @param {string} [suffix] - Optional string to append to the instance name before processing\n * @return {string} A formatted locale string derived from the input\n *\n * @function getLocaleFromClassName\n * @memberOf module:for-angular\n */\nexport function getLocaleFromClassName(\n  instance: string | FunctionLike | KeyValue,\n  suffix?: string\n): string {\n  if (typeof instance !== Primitives.STRING)\n    instance = (instance as FunctionLike).name || (instance as object)?.constructor?.name;\n\n  let name: string | string[] = instance as string;\n\n  if (suffix)\n    name = `${instance}${suffix.charAt(0).toUpperCase() + suffix.slice(1)}`;\n\n  name = name.replace(/_|-/g, '').replace(/(?:^\\w|[A-Z]|\\b\\w)/g, (word: string, index: number) => {\n      if (index > 1) word = '.' + word;\n      return word.toLowerCase();\n    }).split('.');\n\n  if (name.length < 3)\n    return name.reverse().join('.');\n\n  const preffix = name[name.length - 1];\n  name.pop();\n  name = name.join('_');\n  return `${preffix}.${name}`;\n}\n\n\n\n/**\n * @description Retrieves the current locale language\n * @summary This utility function gets the current locale language based on the user's browser settings.\n * It provides a consistent way to access the user's language preference throughout the application.\n * The function returns the browser's navigator.language value, defaulting to 'en' if not available.\n *\n * @return {string} The current locale language (e.g., 'en', 'fr')\n *\n * @function getLocaleLanguage\n * @memberOf module:for-angular\n */\nexport function getLocaleLanguage(): string {\n  const win = getWindow();\n  return (win as Window).navigator.language || \"en\";\n  // return win?.[WINDOW_KEYS.LANGUAGE_SELECTED] || (win.navigator.language || '').split('-')[0] || \"en\";\n}\n\n\n\n/**\n * @description Generates a random string or number of specified length\n * @summary This utility function creates a random string of a specified length.\n * It can generate either alphanumeric strings (including uppercase and lowercase letters)\n * or numeric-only strings. This is useful for creating random IDs, temporary passwords,\n * or other random identifiers throughout the application.\n *\n * @param {number} [length=8] - The length of the random value to generate\n * @param {boolean} [onlyNumbers=false] - Whether to generate only numeric characters\n * @return {string} A randomly generated string of the specified length and character set\n *\n * @function generateRandomValue\n * @memberOf module:for-angular\n */\nexport function generateRandomValue(length: number = 8, onlyNumbers: boolean = false): string {\n  const chars = onlyNumbers\n    ? '0123456789'\n    : 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n  let result = '';\n  for (let i = 0; i < length; i++)\n    result += chars.charAt(Math.floor(Math.random() * chars.length));\n\n  return result;\n}\n\n\n/**\n * Converts a string representation of a boolean or a boolean value to a boolean type.\n *\n * @export\n * @param {('true' | 'false' | boolean)} prop - The value to convert. Can be the string 'true', 'false', or a boolean.\n * @returns {boolean} The boolean representation of the input value. Returns true if the input is the string 'true' or boolean true, false otherwise.\n */\nexport function stringToBoolean(prop: 'true' | 'false' | boolean): boolean {\n  if(typeof prop === 'string')\n    prop = prop.toLowerCase() === 'true' ? true : false;\n  return prop;\n}\n\n\n/**\n * Checks if a value is a valid Date object\n *\n * @param {(string | Date | number)} date - The value to check. Can be a Date object, a timestamp number, or a date string\n * @return {boolean} Returns true if the value is a valid Date object (not NaN), otherwise false\n */\nexport function isValidDate(date: string | Date | number): boolean {\n  try {\n    return (date instanceof Date && !isNaN(date as unknown as number)) || (() => {\n      const testRegex = new RegExp(/^\\d{4}-\\d{2}-\\d{2}$/).test(date as string)\n      if(typeof date !== Primitives.STRING || !(date as string)?.includes('T') && !testRegex)\n         return false;\n\n     date = (date as string).split('T')[0];\n    if(!new RegExp(/^\\d{4}-\\d{2}-\\d{2}$/).test(date))\n      return false;\n\n    return !!(new Date(date));\n   })();\n  } catch(error: unknown) {\n    getLogger(isValidDate).error(error as Error | string);\n    return false;\n  }\n}\n\n/**\n * Formats a date into a localized string representation\n *\n * @param {(string | Date | number)} date - The date to format. Can be a Date object, a timestamp number, or a date string\n * @param {string} [locale] - The locale to use for formatting. If not provided, the system's locale will be used\n * @return {(Date | string)} A formatted date string in the format DD/MM/YYYY according to the specified locale,\n *                           or the original input as a string if the date is invalid\n */\nexport function formatDate(date: string | Date | number, locale?: string | undefined): Date | string {\n\n  if(!locale)\n    locale = getLocaleLanguage();\n\n  if(typeof date === 'string' || typeof date === 'number')\n    date = new Date(typeof date === 'string' ? date.replace(/\\//g, '-') : date);\n\n  if(!isValidDate(date))\n    return `${date}` as string;\n  const r = date.toLocaleString(locale, {\n      year: \"numeric\",\n      day: \"2-digit\",\n      month: '2-digit'\n  });\n\n\n  return r;\n}\n\n/**\n * Attempts to parse a date string, Date object, or number into a valid Date object\n *\n * @param {(string | Date | number)} date - The date to parse. Can be a Date object, a timestamp number,\n *                                         or a date string in the format \"DD/MM/YYYY HH:MM:SS:MS\"\n * @return {(Date | null)} A valid Date object if parsing is successful, or null if the date is invalid\n *                         or doesn't match the expected format\n */\nexport function parseToValidDate(date: string | Date | number): Date | null {\n  if(isValidDate(date))\n    return date as Date;\n\n  if(!`${date}`.includes('/'))\n    return null;\n\n  const [dateString, timeString] = (date as string).split(' ');\n  const [day, month, year] = dateString.split('/').map(Number);\n  const [hours, minutes, seconds, milliseconds] = timeString.split(':').map(Number);\n  date = new Date(year, month - 1, day, hours, minutes, seconds, milliseconds);\n\n  if(!isValidDate(date)) {\n    console.warn('parseToValidDate - Invalid date format', date);\n    return null;\n  }\n\n  return date;\n}\n\n\n/**\n * Maps an item object using a provided mapper object and optional additional properties.\n *\n * @param {KeyValue} item - The source object to be mapped.\n * @param {KeyValue} mapper - An object that defines the mapping rules. Keys represent the new property names,\n *                            and values represent the path to the corresponding values in the source object.\n * @param {KeyValue} [props] - Optional additional properties to be included in the mapped object.\n * @returns {KeyValue} A new object with properties mapped according to the mapper object and including any additional properties.\n */\nexport function itemMapper(item: KeyValue, mapper: KeyValue, props?: KeyValue): KeyValue {\n  return Object.entries(mapper).reduce((accum: KeyValue, [key, value]) => {\n    const arrayValue = (value as string).split('.');\n    if (!value) {\n      accum[key] = value;\n    } else {\n      if (arrayValue.length === 1) {\n        accum[key] = item?.[value as string] || (value !== key ? value : \"\");\n      } else {\n        let val;\n\n        for (const _value of arrayValue)\n          val = !val\n            ? item[_value]\n            : (typeof val === 'string' ? JSON.parse(val) : val)[_value];\n\n        if (isValidDate(new Date(val))) val = `${formatDate(val)}`;\n\n        accum[key] = val === null || val === undefined ? value : val;\n      }\n    }\n    return Object.assign({}, props || {}, accum);\n  }, {});\n}\n\n/**\n * Maps an array of data objects using a provided mapper object.\n *\n * @template T - The type of the resulting mapped items.\n * @param {any[]} data - The array of data objects to be mapped.\n * @param {KeyValue} mapper - An object that defines the mapping rules.\n * @param {KeyValue} [props] - Additional properties to be included in the mapped items.\n *\n * @returns {T[]} - The array of mapped items. If an item in the original array does not have any non-null values after mapping,\n * the original item is returned instead.\n */\nexport function dataMapper<T>(data: T[], mapper: KeyValue, props?: KeyValue): T[] {\n  if (!data || !data.length) return [];\n  return data.reduce((accum: T[], curr) => {\n    const item = itemMapper(curr as KeyValue, mapper, props) as T;\n    const hasValues =\n      [...new Set(Object.values(item as T[]))].filter((value) => value).length >\n      0;\n    accum.push(hasValues ? item : curr);\n    return accum;\n  }, []);\n}\n\n/**\n * @description Removes focus from the currently active DOM element\n * @summary This utility function blurs the currently focused element in the document,\n * effectively removing focus traps that might prevent proper navigation or keyboard\n * interaction. It safely accesses the document's activeElement and calls blur() if\n * an element is currently focused. This is useful for accessibility and user experience\n * improvements, particularly when closing modals or dialogs.\n *\n * @return {void}\n *\n * @function removeFocusTrap\n * @memberOf module:for-angular\n */\nexport function removeFocusTrap(): void {\n  const doc = getWindowDocument();\n  if(doc?.activeElement)\n    (doc.activeElement as HTMLElement)?.blur();\n}\n\n/**\n * @description Cleans and normalizes whitespace in a string value\n * @summary This utility function trims leading and trailing whitespace from a string\n * and replaces multiple consecutive whitespace characters with a single space.\n * Optionally converts the result to lowercase for consistent text processing.\n * This is useful for normalizing user input, search terms, or data sanitization.\n *\n * @param {string} value - The string value to clean and normalize\n * @param {boolean} [lowercase=false] - Whether to convert the result to lowercase\n * @return {string} The cleaned and normalized string\n *\n * @function cleanSpaces\n * @memberOf module:for-angular\n */\nexport function cleanSpaces(value: string = \"\", lowercase: boolean = false): string {\n  value = `${value}`.trim().replace(/\\s+/g, ' ');\n  return lowercase ? value.toLowerCase() : value;\n}\n\n\n/**\n * @description Determines if the user's system is currently in dark mode\n * @summary This function checks the user's color scheme preference using the CSS media query\n * '(prefers-color-scheme: dark)'. It returns a boolean indicating whether the system is\n * currently set to dark mode. This is useful for implementing theme-aware functionality\n * and adjusting UI elements based on the user's preferred color scheme.\n *\n * @return {Promise<boolean>} True if the system is in dark mode, false otherwise\n *\n * @function isDarkMode\n * @memberOf module:for-angular\n */\nexport async function isDarkMode(): Promise<boolean> {\n  const {matches} = getWindow().matchMedia('(prefers-color-scheme: dark)');\n  return matches;\n}\n"]}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { TranslateHttpLoader } from '@ngx-translate/http-loader';
|
|
2
|
+
import { forkJoin } from 'rxjs';
|
|
3
|
+
import { map } from 'rxjs/operators';
|
|
4
|
+
import { inject, InjectionToken } from '@angular/core';
|
|
5
|
+
import { cleanSpaces, getLocaleFromClassName } from '../helpers';
|
|
6
|
+
export class I18nLoader {
|
|
7
|
+
static loadFromHttp(http) {
|
|
8
|
+
function getSuffix() {
|
|
9
|
+
const today = new Date();
|
|
10
|
+
return `.json?version=${today.getFullYear()}${today.getMonth()}${today.getDay()}`;
|
|
11
|
+
}
|
|
12
|
+
return new (class extends TranslateHttpLoader {
|
|
13
|
+
getTranslation(lang) {
|
|
14
|
+
const res = super.getTranslation(lang);
|
|
15
|
+
return res;
|
|
16
|
+
}
|
|
17
|
+
})(http, './assets/i18n/', getSuffix());
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
export function getLocaleContext(clazz, suffix) {
|
|
21
|
+
return getLocaleFromClassName(clazz, suffix);
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* @description Generates a localized string by combining locale and phrase
|
|
25
|
+
* @summary This utility function creates a properly formatted locale string by combining
|
|
26
|
+
* a locale identifier with a phrase. It handles edge cases such as empty phrases,
|
|
27
|
+
* missing locales, and phrases that already include the locale prefix. This function
|
|
28
|
+
* is useful for ensuring consistent formatting of localized strings throughout the application.
|
|
29
|
+
*
|
|
30
|
+
* @param {string} locale - The locale identifier (e.g., 'en', 'fr')
|
|
31
|
+
* @param {string | undefined} phrase - The phrase to localize
|
|
32
|
+
* @return {string} The formatted locale string, or empty string if phrase is undefined
|
|
33
|
+
*
|
|
34
|
+
* @function generateLocaleFromString
|
|
35
|
+
* @memberOf module:for-angular
|
|
36
|
+
*/
|
|
37
|
+
export function getLocaleContextByKey(locale, phrase) {
|
|
38
|
+
if (!phrase)
|
|
39
|
+
return locale;
|
|
40
|
+
if (!locale || phrase.includes(`${locale}.`))
|
|
41
|
+
return phrase;
|
|
42
|
+
const parts = phrase.split(' ');
|
|
43
|
+
return `${locale}.${cleanSpaces(parts.join('.'), true)}`;
|
|
44
|
+
}
|
|
45
|
+
export const I18N_CONFIG_TOKEN = new InjectionToken('I18N_CONFIG_TOKEN');
|
|
46
|
+
export function I18nLoaderFactory(http) {
|
|
47
|
+
const { resources, versionedSuffix } = inject(I18N_CONFIG_TOKEN, { optional: true }) ?? getI18nLoaderFactoryProviderConfig().useValue;
|
|
48
|
+
return new MultiI18nLoader(http, resources, versionedSuffix);
|
|
49
|
+
}
|
|
50
|
+
export function getI18nLoaderFactoryProviderConfig(resources = [], versionedSuffix = false) {
|
|
51
|
+
if (!Array.isArray(resources))
|
|
52
|
+
resources = [resources];
|
|
53
|
+
return {
|
|
54
|
+
provide: I18N_CONFIG_TOKEN,
|
|
55
|
+
useValue: { resources: [
|
|
56
|
+
{ prefix: './assets/i18n/', suffix: '.json' },
|
|
57
|
+
...resources
|
|
58
|
+
], versionedSuffix }
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
export class MultiI18nLoader {
|
|
62
|
+
constructor(http, resources = [], versionedSuffix = false) {
|
|
63
|
+
this.http = http;
|
|
64
|
+
this.resources = resources;
|
|
65
|
+
this.versionedSuffix = versionedSuffix;
|
|
66
|
+
}
|
|
67
|
+
getSuffix(suffix) {
|
|
68
|
+
if (!this.versionedSuffix)
|
|
69
|
+
return suffix;
|
|
70
|
+
const today = new Date();
|
|
71
|
+
return `${suffix}?version=${today.getFullYear()}${today.getMonth()}${today.getDay()}`;
|
|
72
|
+
}
|
|
73
|
+
getTranslation(lang) {
|
|
74
|
+
const requests = this.resources.map(config => this.http.get(`${config.prefix}${lang}${this.getSuffix(config.suffix)}`));
|
|
75
|
+
return forkJoin(requests).pipe(map(responseArray => {
|
|
76
|
+
return responseArray.reduce((acc, current) => {
|
|
77
|
+
return { ...acc, ...current };
|
|
78
|
+
}, {});
|
|
79
|
+
}));
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Loader.js","sourceRoot":"","sources":["../../../../src/lib/i18n/Loader.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { TranslateLoader, TranslationObject } from '@ngx-translate/core';\nimport { TranslateHttpLoader } from '@ngx-translate/http-loader';\nimport { forkJoin, Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport {I18nResourceConfig} from '../engine/interfaces';\nimport { inject, InjectionToken } from '@angular/core';\nimport { FunctionLike } from '../engine';\nimport { cleanSpaces, getLocaleFromClassName } from '../helpers';\nexport class I18nLoader {\n  static loadFromHttp(http: HttpClient): TranslateLoader {\n    function getSuffix() {\n      const today = new Date();\n      return `.json?version=${today.getFullYear()}${today.getMonth()}${today.getDay()}` as string;\n    }\n\n    return new (class extends TranslateHttpLoader {\n      override getTranslation(lang: string): Observable<TranslationObject> {\n        const res = super.getTranslation(lang);\n        return res;\n      }\n    })(http, './assets/i18n/', getSuffix());\n  }\n}\n\n\nexport function getLocaleContext(clazz: FunctionLike | object | string, suffix?: string): string {\n  return getLocaleFromClassName(clazz, suffix);\n}\n\n/**\n * @description Generates a localized string by combining locale and phrase\n * @summary This utility function creates a properly formatted locale string by combining\n * a locale identifier with a phrase. It handles edge cases such as empty phrases,\n * missing locales, and phrases that already include the locale prefix. This function\n * is useful for ensuring consistent formatting of localized strings throughout the application.\n *\n * @param {string} locale - The locale identifier (e.g., 'en', 'fr')\n * @param {string | undefined} phrase - The phrase to localize\n * @return {string} The formatted locale string, or empty string if phrase is undefined\n *\n * @function generateLocaleFromString\n * @memberOf module:for-angular\n */\nexport function getLocaleContextByKey(\n  locale: string,\n  phrase: string | undefined\n): string {\n  if (!phrase)\n    return locale;\n  if (!locale || phrase.includes(`${locale}.`))\n    return phrase;\n  const parts = phrase.split(' ');\n  return `${locale}.${cleanSpaces(parts.join('.'), true)}`;\n}\n\nexport const I18N_CONFIG_TOKEN = new InjectionToken<{resources: I18nResourceConfig[]; versionedSuffix: false}>('I18N_CONFIG_TOKEN');\n\nexport function I18nLoaderFactory(http: HttpClient): TranslateLoader {\n  const {resources, versionedSuffix} = inject(I18N_CONFIG_TOKEN, { optional: true }) ?? getI18nLoaderFactoryProviderConfig().useValue;\n  return new MultiI18nLoader(http, resources, versionedSuffix);\n}\n\nexport function getI18nLoaderFactoryProviderConfig(resources: I18nResourceConfig | I18nResourceConfig[] = [], versionedSuffix: boolean = false) {\n  if(!Array.isArray(resources))\n    resources = [resources];\n  return {\n    provide: I18N_CONFIG_TOKEN,\n    useValue: { resources: [\n      { prefix: './assets/i18n/', suffix: '.json' },\n      ...resources\n    ], versionedSuffix}\n  }\n}\n\nexport class MultiI18nLoader implements I18nLoader {\n  constructor(private http: HttpClient, private resources: I18nResourceConfig[] = [], private versionedSuffix: boolean = false) {}\n\n  private getSuffix(suffix: string): string {\n    if(!this.versionedSuffix)\n      return suffix;\n    const today = new Date();\n    return `${suffix}?version=${today.getFullYear()}${today.getMonth()}${today.getDay()}` as string;\n  }\n\n  getTranslation(lang: string): Observable<TranslationObject> {\n    const requests = this.resources.map(config =>\n      this.http.get(`${config.prefix}${lang}${this.getSuffix(config.suffix)}`)\n    );\n\n    return forkJoin(requests).pipe(\n      map(responseArray => {\n        return responseArray.reduce((acc, current) => {\n          return { ...acc, ...current };\n        }, {});\n      })\n    );\n  }\n}\n"]}
|