@decaf-ts/for-angular 0.0.16 → 0.0.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (65) hide show
  1. package/assets/i18n/en.json +9 -69
  2. package/assets/i18n/pt.json +80 -0
  3. package/assets/icons/icon-128.webp +0 -0
  4. package/assets/icons/icon-192.webp +0 -0
  5. package/assets/icons/icon-256.webp +0 -0
  6. package/assets/icons/icon-48.webp +0 -0
  7. package/assets/icons/icon-512.webp +0 -0
  8. package/assets/icons/icon-72.webp +0 -0
  9. package/assets/icons/icon-96.webp +0 -0
  10. package/assets/images/apple-touch-icon.png +0 -0
  11. package/assets/images/favicon.png +0 -0
  12. package/assets/images/favicon.svg +29 -0
  13. package/components/component-renderer/component-renderer.component.d.ts +5 -4
  14. package/components/crud-field/crud-field.component.d.ts +186 -22
  15. package/components/crud-form/crud-form.component.d.ts +194 -8
  16. package/components/empty-state/empty-state.component.d.ts +9 -10
  17. package/components/fieldset/fieldset.component.d.ts +383 -36
  18. package/components/filter/filter.component.d.ts +11 -2
  19. package/components/list/list.component.d.ts +1 -1
  20. package/components/list-item/list-item.component.d.ts +2 -2
  21. package/components/model-renderer/model-renderer.component.d.ts +1 -5
  22. package/directives/collapsable.directive.d.ts +1 -0
  23. package/engine/NgxBaseComponent.d.ts +43 -43
  24. package/engine/NgxCrudFormField.d.ts +7 -3
  25. package/engine/NgxFormService.d.ts +113 -12
  26. package/engine/NgxRenderingEngine.d.ts +178 -25
  27. package/engine/constants.d.ts +11 -6
  28. package/engine/decorators.d.ts +2 -2
  29. package/engine/index.d.ts +4 -2
  30. package/engine/interfaces.d.ts +271 -0
  31. package/engine/types.d.ts +11 -206
  32. package/esm2022/components/component-renderer/component-renderer.component.mjs +13 -11
  33. package/esm2022/components/crud-field/crud-field.component.mjs +213 -8
  34. package/esm2022/components/crud-form/crud-form.component.mjs +133 -13
  35. package/esm2022/components/empty-state/empty-state.component.mjs +13 -12
  36. package/esm2022/components/fieldset/fieldset.component.mjs +485 -43
  37. package/esm2022/components/filter/filter.component.mjs +16 -6
  38. package/esm2022/components/layout/layout.component.mjs +3 -3
  39. package/esm2022/components/list/list.component.mjs +4 -5
  40. package/esm2022/components/list-item/list-item.component.mjs +10 -10
  41. package/esm2022/components/model-renderer/model-renderer.component.mjs +9 -8
  42. package/esm2022/components/pagination/pagination.component.mjs +7 -7
  43. package/esm2022/components/searchbar/searchbar.component.mjs +3 -3
  44. package/esm2022/directives/collapsable.directive.mjs +3 -2
  45. package/esm2022/engine/NgxBaseComponent.mjs +64 -63
  46. package/esm2022/engine/NgxCrudFormField.mjs +14 -4
  47. package/esm2022/engine/NgxFormService.mjs +239 -27
  48. package/esm2022/engine/NgxRenderingEngine.mjs +218 -46
  49. package/esm2022/engine/ValidatorFactory.mjs +6 -4
  50. package/esm2022/engine/constants.mjs +14 -9
  51. package/esm2022/engine/decorators.mjs +6 -6
  52. package/esm2022/engine/index.mjs +5 -3
  53. package/esm2022/engine/interfaces.mjs +4 -0
  54. package/esm2022/engine/types.mjs +1 -3
  55. package/esm2022/helpers/utils.mjs +53 -32
  56. package/esm2022/i18n/Loader.mjs +82 -0
  57. package/fesm2022/decaf-ts-for-angular.mjs +3030 -2097
  58. package/fesm2022/decaf-ts-for-angular.mjs.map +1 -1
  59. package/helpers/utils.d.ts +42 -16
  60. package/i18n/Loader.d.ts +48 -0
  61. package/package.json +11 -1
  62. package/engine/NgxRenderingEngine2.d.ts +0 -250
  63. package/esm2022/engine/NgxRenderingEngine2.mjs +0 -332
  64. package/esm2022/interfaces.mjs +0 -2
  65. package/interfaces.d.ts +0 -28
@@ -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"]}