@leanix/components 0.4.65 → 0.4.67

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 (90) hide show
  1. package/esm2022/index.mjs +1 -2
  2. package/esm2022/lib/core-ui/components/badge/badge.component.mjs +4 -4
  3. package/esm2022/lib/core-ui/components/banner/banner.component.mjs +3 -3
  4. package/esm2022/lib/core-ui/components/button/button.component.mjs +5 -5
  5. package/esm2022/lib/core-ui/components/button-group/button-group.component.mjs +3 -3
  6. package/esm2022/lib/core-ui/components/card/card.component.mjs +3 -3
  7. package/esm2022/lib/core-ui/components/collapsible/collapsible.component.mjs +5 -5
  8. package/esm2022/lib/core-ui/components/colored-label/colored-label.component.mjs +5 -5
  9. package/esm2022/lib/core-ui/components/ellipsis/ellipsis.component.mjs +5 -5
  10. package/esm2022/lib/core-ui/components/file-download-button/file-download-button.component.mjs +7 -6
  11. package/esm2022/lib/core-ui/components/icon-scale/icon-scale.component.mjs +4 -4
  12. package/esm2022/lib/core-ui/components/spinner/spinner.component.mjs +3 -3
  13. package/esm2022/lib/core-ui/components/table/table-header/table-header.component.mjs +4 -4
  14. package/esm2022/lib/core-ui/components/table/table.component.mjs +4 -3
  15. package/esm2022/lib/core-ui/components/tiny-spinner/tiny-spinner.component.mjs +3 -3
  16. package/esm2022/lib/core-ui/core-ui.module.mjs +12 -10
  17. package/esm2022/lib/core-ui/directives/after-view-init.directive.mjs +6 -3
  18. package/esm2022/lib/core-ui/directives/autoclose.directive.mjs +7 -4
  19. package/esm2022/lib/core-ui/directives/autofocus.directive.mjs +6 -3
  20. package/esm2022/lib/core-ui/linkify/linkify.pipe.mjs +6 -3
  21. package/esm2022/lib/core-ui/linkify/unlinkify.pipe.mjs +6 -3
  22. package/esm2022/lib/core-ui/pipes/br.pipe.mjs +4 -3
  23. package/esm2022/lib/core-ui/pipes/contrast-color.pipe.mjs +4 -3
  24. package/esm2022/lib/core-ui/pipes/custom-date.pipe.mjs +4 -3
  25. package/esm2022/lib/core-ui/pipes/highlight-range.pipe.mjs +6 -3
  26. package/esm2022/lib/core-ui/pipes/highlight-term.pipe.mjs +6 -3
  27. package/esm2022/lib/core-ui/pipes/lx-is-uuid.pipe.mjs +4 -3
  28. package/esm2022/lib/core-ui/pipes/lx-time-ago.pipe.mjs +7 -3
  29. package/esm2022/lib/core-ui/pipes/lx-translate.pipe.mjs +4 -3
  30. package/esm2022/lib/core-ui/pipes/markdown.pipe.mjs +6 -3
  31. package/esm2022/lib/core-ui/pipes/nbsp.pipe.mjs +6 -3
  32. package/esm2022/lib/core-ui/pipes/sort.pipe.mjs +6 -3
  33. package/esm2022/lib/core-ui/pipes/translation-after.pipe.mjs +4 -3
  34. package/esm2022/lib/core-ui/pipes/translation-before.pipe.mjs +4 -3
  35. package/esm2022/lib/core-ui/pipes/translation-between.pipe.mjs +4 -3
  36. package/esm2022/lib/core-ui/pipes/unescape-curly-braces.pipe.mjs +4 -3
  37. package/esm2022/lib/core-ui/tooltip/tooltip.component.mjs +4 -4
  38. package/esm2022/lib/core-ui/tooltip/tooltip.directive.mjs +4 -3
  39. package/esm2022/lib/forms-ui/components/basic-dropdown-item/basic-dropdown-item.component.mjs +3 -3
  40. package/esm2022/lib/forms-ui/components/breadcrumb/breadcrumb.component.mjs +3 -3
  41. package/esm2022/lib/forms-ui/components/currency/currency-input.component.mjs +3 -3
  42. package/esm2022/lib/forms-ui/components/date-input/date-input.component.mjs +3 -3
  43. package/esm2022/lib/forms-ui/components/options-dropdown/options-dropdown.component.mjs +2 -2
  44. package/esm2022/lib/forms-ui/components/picker/picker.component.mjs +1 -1
  45. package/esm2022/lib/forms-ui/components/picker-option/picker-option.component.mjs +1 -1
  46. package/esm2022/lib/forms-ui/directives/contenteditable.directive.mjs +1 -1
  47. package/esm2022/lib/forms-ui/directives/mark-invalid.directive.mjs +1 -1
  48. package/fesm2022/leanix-components.mjs +200 -166
  49. package/fesm2022/leanix-components.mjs.map +1 -1
  50. package/index.d.ts +0 -1
  51. package/lib/core-ui/components/badge/badge.component.d.ts +1 -1
  52. package/lib/core-ui/components/banner/banner.component.d.ts +1 -1
  53. package/lib/core-ui/components/button/button.component.d.ts +1 -1
  54. package/lib/core-ui/components/button-group/button-group.component.d.ts +1 -1
  55. package/lib/core-ui/components/card/card.component.d.ts +1 -1
  56. package/lib/core-ui/components/collapsible/collapsible.component.d.ts +1 -1
  57. package/lib/core-ui/components/colored-label/colored-label.component.d.ts +1 -1
  58. package/lib/core-ui/components/ellipsis/ellipsis.component.d.ts +1 -1
  59. package/lib/core-ui/components/file-download-button/file-download-button.component.d.ts +1 -1
  60. package/lib/core-ui/components/icon-scale/icon-scale.component.d.ts +1 -1
  61. package/lib/core-ui/components/spinner/spinner.component.d.ts +1 -1
  62. package/lib/core-ui/components/table/table-header/table-header.component.d.ts +1 -1
  63. package/lib/core-ui/components/table/table.component.d.ts +1 -1
  64. package/lib/core-ui/components/tiny-spinner/tiny-spinner.component.d.ts +1 -1
  65. package/lib/core-ui/core-ui.module.d.ts +37 -38
  66. package/lib/core-ui/directives/after-view-init.directive.d.ts +1 -1
  67. package/lib/core-ui/directives/autoclose.directive.d.ts +1 -1
  68. package/lib/core-ui/directives/autofocus.directive.d.ts +1 -1
  69. package/lib/core-ui/linkify/linkify.pipe.d.ts +1 -1
  70. package/lib/core-ui/linkify/unlinkify.pipe.d.ts +1 -1
  71. package/lib/core-ui/pipes/br.pipe.d.ts +1 -1
  72. package/lib/core-ui/pipes/contrast-color.pipe.d.ts +1 -1
  73. package/lib/core-ui/pipes/custom-date.pipe.d.ts +1 -1
  74. package/lib/core-ui/pipes/highlight-range.pipe.d.ts +1 -1
  75. package/lib/core-ui/pipes/highlight-term.pipe.d.ts +1 -1
  76. package/lib/core-ui/pipes/lx-is-uuid.pipe.d.ts +1 -1
  77. package/lib/core-ui/pipes/lx-time-ago.pipe.d.ts +1 -1
  78. package/lib/core-ui/pipes/lx-translate.pipe.d.ts +1 -1
  79. package/lib/core-ui/pipes/markdown.pipe.d.ts +1 -1
  80. package/lib/core-ui/pipes/nbsp.pipe.d.ts +1 -1
  81. package/lib/core-ui/pipes/sort.pipe.d.ts +1 -1
  82. package/lib/core-ui/pipes/translation-after.pipe.d.ts +1 -1
  83. package/lib/core-ui/pipes/translation-before.pipe.d.ts +1 -1
  84. package/lib/core-ui/pipes/translation-between.pipe.d.ts +1 -1
  85. package/lib/core-ui/pipes/unescape-curly-braces.pipe.d.ts +1 -1
  86. package/lib/core-ui/tooltip/tooltip.component.d.ts +1 -1
  87. package/lib/core-ui/tooltip/tooltip.directive.d.ts +1 -1
  88. package/package.json +1 -1
  89. package/esm2022/lib/core-ui/tooltip/tooltip.module.mjs +0 -20
  90. package/lib/core-ui/tooltip/tooltip.module.d.ts +0 -10
@@ -42,12 +42,13 @@ export class TranslationBeforePipe {
42
42
  return getTranslationParts(this.translateService, translationKey, cutMarkAndParams)[0];
43
43
  }
44
44
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TranslationBeforePipe, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Pipe }); }
45
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.0.2", ngImport: i0, type: TranslationBeforePipe, name: "lxTranslationBefore" }); }
45
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.0.2", ngImport: i0, type: TranslationBeforePipe, isStandalone: true, name: "lxTranslationBefore" }); }
46
46
  }
47
47
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TranslationBeforePipe, decorators: [{
48
48
  type: Pipe,
49
49
  args: [{
50
- name: 'lxTranslationBefore'
50
+ name: 'lxTranslationBefore',
51
+ standalone: true
51
52
  }]
52
53
  }], ctorParameters: () => [{ type: i1.TranslateService }] });
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRpb24tYmVmb3JlLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3BpcGVzL3RyYW5zbGF0aW9uLWJlZm9yZS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBRXBELE9BQU8sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sV0FBVyxDQUFDOzs7QUFFM0MsTUFBTSxVQUFVLG1CQUFtQixDQUNqQyxnQkFBa0MsRUFDbEMsY0FBaUMsRUFDakMsZ0JBQXdDO0lBRXhDLGNBQWMsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQztJQUNyRixNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDO0lBQ25GLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ3RFLE1BQU0sV0FBVyxHQUFHLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxjQUFjLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDckUsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLFdBQVcsRUFBRSxLQUFLLE9BQU8sSUFBSSxDQUFDLENBQUM7SUFDbkQsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtRQUN0QixPQUFPLENBQUMsS0FBSyxDQUFDLE1BQU0sT0FBTyxxQkFBcUIsV0FBVyxjQUFjLGNBQWMsSUFBSSxDQUFDLENBQUM7S0FDOUY7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUlILE1BQU0sT0FBTyxxQkFBcUI7SUFDaEMsWUFBb0IsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFBRyxDQUFDO0lBRTFEOzs7OztPQUtHO0lBQ0gsU0FBUyxDQUFDLGNBQWlDLEVBQUUsZ0JBQXdDO1FBQ25GLE9BQU8sbUJBQW1CLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLGNBQWMsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBRSxDQUFDO0lBQzFGLENBQUM7OEdBWFUscUJBQXFCOzRHQUFyQixxQkFBcUI7OzJGQUFyQixxQkFBcUI7a0JBSGpDLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLHFCQUFxQjtpQkFDNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQgeyBpc0FycmF5LCBzcGxpdCB9IGZyb20gJ2xvZGFzaC1lcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRUcmFuc2xhdGlvblBhcnRzKFxuICB0cmFuc2xhdGVTZXJ2aWNlOiBUcmFuc2xhdGVTZXJ2aWNlLFxuICB0cmFuc2xhdGlvbktleTogc3RyaW5nIHwgc3RyaW5nW10sXG4gIGN1dE1hcmtBbmRQYXJhbXM6IHN0cmluZyB8IFtzdHJpbmcsIGFueV1cbik6IHN0cmluZ1tdIHtcbiAgdHJhbnNsYXRpb25LZXkgPSBpc0FycmF5KHRyYW5zbGF0aW9uS2V5KSA/IHRyYW5zbGF0aW9uS2V5LmpvaW4oJy4nKSA6IHRyYW5zbGF0aW9uS2V5O1xuICBjb25zdCBjdXRNYXJrID0gaXNBcnJheShjdXRNYXJrQW5kUGFyYW1zKSA/IGN1dE1hcmtBbmRQYXJhbXNbMF0gOiBjdXRNYXJrQW5kUGFyYW1zO1xuICBjb25zdCBwYXJhbXMgPSBpc0FycmF5KGN1dE1hcmtBbmRQYXJhbXMpID8gY3V0TWFya0FuZFBhcmFtc1sxXSA6IG51bGw7XG4gIGNvbnN0IHRyYW5zbGF0aW9uID0gdHJhbnNsYXRlU2VydmljZS5pbnN0YW50KHRyYW5zbGF0aW9uS2V5LCBwYXJhbXMpO1xuICBjb25zdCBwYXJ0cyA9IHNwbGl0KHRyYW5zbGF0aW9uLCBgW1ske2N1dE1hcmt9XV1gKTtcbiAgaWYgKHBhcnRzLmxlbmd0aCA9PT0gMSkge1xuICAgIGNvbnNvbGUuZXJyb3IoYCdbWyR7Y3V0TWFya31dXScgbm90IGZvdW5kIGluICcke3RyYW5zbGF0aW9ufScgZm9yIGtleSAnJHt0cmFuc2xhdGlvbktleX0nLmApO1xuICB9XG4gIHJldHVybiBwYXJ0cztcbn1cblxuLyoqXG4gKiBUcmFuc2xhdGVzIHRoZSBnaXZlbiBpMThuLWtleSAoaW5zdGFudGx5KSBhbmQgcmV0dXJucyB0aGUgcGFydCBvZiB0aGUgdHJhbnNsYXRpb25cbiAqIHByZWNlZGluZyB0aGUgY3V0LW1hcmsgc3RyaW5nICdbWzxjdXRNYXJrPl1dJy5cbiAqIE5COiBVc2Ugbm9ybWFsIGludGVycG9sYXRpb25zIHJhdGhlciB0aGFuIGN1dC1tYXJrcyB3aGVuZXZlciB0aGUgY29udGVudCBpcyB0ZXh0LCBldmVuIGlmIGl0IGNvbWVzIGZyb20gYW5vdGhlciBwaXBlLlxuICogQGV4YW1wbGVcbiAqIHt7ICdzb21lLnRleHQnIHwgbHhUcmFuc2xhdGlvbkJlZm9yZTonbGluaycgfX1cbiAqICAgPGE+e3snc29tZS5saW5rTGFiZWwnIHwgdHJhbnNsYXRlfX08L2E+XG4gKiB7eyAnc29tZS50ZXh0JyB8IGx4VHJhbnNsYXRpb25BZnRlcjonbGluaycgfX1cbiAqXG4gKiB7eyAnc29tZS50ZXh0V2l0aE90aGVySW50ZXJwb2xhdGlvbnMnIHwgbHhUcmFuc2xhdGlvbkJlZm9yZTpbJ2xpbmsnLCBwYXJhbXNdIH19XG4gKiAgIDxhPnt7J3NvbWUubGlua0xhYmVsJyB8IHRyYW5zbGF0ZX19PC9hPlxuICoge3sgJ3NvbWUudGV4dFdpdGhPdGhlckludGVycG9sYXRpb25zJyB8IGx4VHJhbnNsYXRpb25BZnRlcjpbJ2xpbmsnLCBwYXJhbXNdIH19XG4gKiBAc2VlIFRyYW5zbGF0aW9uQWZ0ZXJQaXBlXG4gKiBAc2VlIFRyYW5zbGF0aW9uQmV0d2VlblBpcGVcbiAqL1xuQFBpcGUoe1xuICBuYW1lOiAnbHhUcmFuc2xhdGlvbkJlZm9yZSdcbn0pXG5leHBvcnQgY2xhc3MgVHJhbnNsYXRpb25CZWZvcmVQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSkge31cblxuICAvKipcbiAgICogQHBhcmFtIHtzdHJpbmd8c3RyaW5nW119IHRyYW5zbGF0aW9uS2V5IGkxOG4ga2V5IG9yIGFycmF5IG9mIGl0cyBzZWdtZW50c1xuICAgKiBAcGFyYW0geyhzdHJpbmd8W3N0cmluZywgYW55XSl9IGN1dE1hcmtBbmRQYXJhbXMgZWl0aGVyIGp1c3QgdGhlIGN1dC1tYXJrIHRvIHNwbGl0IGJ5IG9yXG4gICAqICAgYW4gYXJyYXkgb2YgY3V0LW1hcmsgc3RyaW5nIGFuZCB0cmFuc2xhdGlvbiBwYXJhbXNcbiAgICogQHJldHVybnMge3N0cmluZ31cbiAgICovXG4gIHRyYW5zZm9ybSh0cmFuc2xhdGlvbktleTogc3RyaW5nIHwgc3RyaW5nW10sIGN1dE1hcmtBbmRQYXJhbXM6IHN0cmluZyB8IFtzdHJpbmcsIGFueV0pOiBzdHJpbmcge1xuICAgIHJldHVybiBnZXRUcmFuc2xhdGlvblBhcnRzKHRoaXMudHJhbnNsYXRlU2VydmljZSwgdHJhbnNsYXRpb25LZXksIGN1dE1hcmtBbmRQYXJhbXMpWzBdITtcbiAgfVxufVxuIl19
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRpb24tYmVmb3JlLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3BpcGVzL3RyYW5zbGF0aW9uLWJlZm9yZS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBRXBELE9BQU8sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sV0FBVyxDQUFDOzs7QUFFM0MsTUFBTSxVQUFVLG1CQUFtQixDQUNqQyxnQkFBa0MsRUFDbEMsY0FBaUMsRUFDakMsZ0JBQXdDO0lBRXhDLGNBQWMsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQztJQUNyRixNQUFNLE9BQU8sR0FBRyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDO0lBQ25GLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ3RFLE1BQU0sV0FBVyxHQUFHLGdCQUFnQixDQUFDLE9BQU8sQ0FBQyxjQUFjLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDckUsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLFdBQVcsRUFBRSxLQUFLLE9BQU8sSUFBSSxDQUFDLENBQUM7SUFDbkQsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtRQUN0QixPQUFPLENBQUMsS0FBSyxDQUFDLE1BQU0sT0FBTyxxQkFBcUIsV0FBVyxjQUFjLGNBQWMsSUFBSSxDQUFDLENBQUM7S0FDOUY7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUM7QUFFRDs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUtILE1BQU0sT0FBTyxxQkFBcUI7SUFDaEMsWUFBb0IsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFBRyxDQUFDO0lBRTFEOzs7OztPQUtHO0lBQ0gsU0FBUyxDQUFDLGNBQWlDLEVBQUUsZ0JBQXdDO1FBQ25GLE9BQU8sbUJBQW1CLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLGNBQWMsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBRSxDQUFDO0lBQzFGLENBQUM7OEdBWFUscUJBQXFCOzRHQUFyQixxQkFBcUI7OzJGQUFyQixxQkFBcUI7a0JBSmpDLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLHFCQUFxQjtvQkFDM0IsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgaXNBcnJheSwgc3BsaXQgfSBmcm9tICdsb2Rhc2gtZXMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0VHJhbnNsYXRpb25QYXJ0cyhcbiAgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSxcbiAgdHJhbnNsYXRpb25LZXk6IHN0cmluZyB8IHN0cmluZ1tdLFxuICBjdXRNYXJrQW5kUGFyYW1zOiBzdHJpbmcgfCBbc3RyaW5nLCBhbnldXG4pOiBzdHJpbmdbXSB7XG4gIHRyYW5zbGF0aW9uS2V5ID0gaXNBcnJheSh0cmFuc2xhdGlvbktleSkgPyB0cmFuc2xhdGlvbktleS5qb2luKCcuJykgOiB0cmFuc2xhdGlvbktleTtcbiAgY29uc3QgY3V0TWFyayA9IGlzQXJyYXkoY3V0TWFya0FuZFBhcmFtcykgPyBjdXRNYXJrQW5kUGFyYW1zWzBdIDogY3V0TWFya0FuZFBhcmFtcztcbiAgY29uc3QgcGFyYW1zID0gaXNBcnJheShjdXRNYXJrQW5kUGFyYW1zKSA/IGN1dE1hcmtBbmRQYXJhbXNbMV0gOiBudWxsO1xuICBjb25zdCB0cmFuc2xhdGlvbiA9IHRyYW5zbGF0ZVNlcnZpY2UuaW5zdGFudCh0cmFuc2xhdGlvbktleSwgcGFyYW1zKTtcbiAgY29uc3QgcGFydHMgPSBzcGxpdCh0cmFuc2xhdGlvbiwgYFtbJHtjdXRNYXJrfV1dYCk7XG4gIGlmIChwYXJ0cy5sZW5ndGggPT09IDEpIHtcbiAgICBjb25zb2xlLmVycm9yKGAnW1ske2N1dE1hcmt9XV0nIG5vdCBmb3VuZCBpbiAnJHt0cmFuc2xhdGlvbn0nIGZvciBrZXkgJyR7dHJhbnNsYXRpb25LZXl9Jy5gKTtcbiAgfVxuICByZXR1cm4gcGFydHM7XG59XG5cbi8qKlxuICogVHJhbnNsYXRlcyB0aGUgZ2l2ZW4gaTE4bi1rZXkgKGluc3RhbnRseSkgYW5kIHJldHVybnMgdGhlIHBhcnQgb2YgdGhlIHRyYW5zbGF0aW9uXG4gKiBwcmVjZWRpbmcgdGhlIGN1dC1tYXJrIHN0cmluZyAnW1s8Y3V0TWFyaz5dXScuXG4gKiBOQjogVXNlIG5vcm1hbCBpbnRlcnBvbGF0aW9ucyByYXRoZXIgdGhhbiBjdXQtbWFya3Mgd2hlbmV2ZXIgdGhlIGNvbnRlbnQgaXMgdGV4dCwgZXZlbiBpZiBpdCBjb21lcyBmcm9tIGFub3RoZXIgcGlwZS5cbiAqIEBleGFtcGxlXG4gKiB7eyAnc29tZS50ZXh0JyB8IGx4VHJhbnNsYXRpb25CZWZvcmU6J2xpbmsnIH19XG4gKiAgIDxhPnt7J3NvbWUubGlua0xhYmVsJyB8IHRyYW5zbGF0ZX19PC9hPlxuICoge3sgJ3NvbWUudGV4dCcgfCBseFRyYW5zbGF0aW9uQWZ0ZXI6J2xpbmsnIH19XG4gKlxuICoge3sgJ3NvbWUudGV4dFdpdGhPdGhlckludGVycG9sYXRpb25zJyB8IGx4VHJhbnNsYXRpb25CZWZvcmU6WydsaW5rJywgcGFyYW1zXSB9fVxuICogICA8YT57eydzb21lLmxpbmtMYWJlbCcgfCB0cmFuc2xhdGV9fTwvYT5cbiAqIHt7ICdzb21lLnRleHRXaXRoT3RoZXJJbnRlcnBvbGF0aW9ucycgfCBseFRyYW5zbGF0aW9uQWZ0ZXI6WydsaW5rJywgcGFyYW1zXSB9fVxuICogQHNlZSBUcmFuc2xhdGlvbkFmdGVyUGlwZVxuICogQHNlZSBUcmFuc2xhdGlvbkJldHdlZW5QaXBlXG4gKi9cbkBQaXBlKHtcbiAgbmFtZTogJ2x4VHJhbnNsYXRpb25CZWZvcmUnLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIFRyYW5zbGF0aW9uQmVmb3JlUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRyYW5zbGF0ZVNlcnZpY2U6IFRyYW5zbGF0ZVNlcnZpY2UpIHt9XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7c3RyaW5nfHN0cmluZ1tdfSB0cmFuc2xhdGlvbktleSBpMThuIGtleSBvciBhcnJheSBvZiBpdHMgc2VnbWVudHNcbiAgICogQHBhcmFtIHsoc3RyaW5nfFtzdHJpbmcsIGFueV0pfSBjdXRNYXJrQW5kUGFyYW1zIGVpdGhlciBqdXN0IHRoZSBjdXQtbWFyayB0byBzcGxpdCBieSBvclxuICAgKiAgIGFuIGFycmF5IG9mIGN1dC1tYXJrIHN0cmluZyBhbmQgdHJhbnNsYXRpb24gcGFyYW1zXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9XG4gICAqL1xuICB0cmFuc2Zvcm0odHJhbnNsYXRpb25LZXk6IHN0cmluZyB8IHN0cmluZ1tdLCBjdXRNYXJrQW5kUGFyYW1zOiBzdHJpbmcgfCBbc3RyaW5nLCBhbnldKTogc3RyaW5nIHtcbiAgICByZXR1cm4gZ2V0VHJhbnNsYXRpb25QYXJ0cyh0aGlzLnRyYW5zbGF0ZVNlcnZpY2UsIHRyYW5zbGF0aW9uS2V5LCBjdXRNYXJrQW5kUGFyYW1zKVswXSE7XG4gIH1cbn1cbiJdfQ==
@@ -56,12 +56,13 @@ export class TranslationBetweenPipe {
56
56
  return getTranslationBetween(this.translateService, translationKey, cutMarksAndParams);
57
57
  }
58
58
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TranslationBetweenPipe, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Pipe }); }
59
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.0.2", ngImport: i0, type: TranslationBetweenPipe, name: "lxTranslationBetween" }); }
59
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.0.2", ngImport: i0, type: TranslationBetweenPipe, isStandalone: true, name: "lxTranslationBetween" }); }
60
60
  }
61
61
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TranslationBetweenPipe, decorators: [{
62
62
  type: Pipe,
63
63
  args: [{
64
- name: 'lxTranslationBetween'
64
+ name: 'lxTranslationBetween',
65
+ standalone: true
65
66
  }]
66
67
  }], ctorParameters: () => [{ type: i1.TranslateService }] });
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRpb24tYmV0d2Vlbi5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvY29yZS11aS9waXBlcy90cmFuc2xhdGlvbi1iZXR3ZWVuLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFFcEQsT0FBTyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxXQUFXLENBQUM7OztBQUUzQyxTQUFTLHFCQUFxQixDQUM1QixnQkFBa0MsRUFDbEMsY0FBaUMsRUFDakMsaUJBQTJEO0lBRTNELGNBQWMsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQztJQUNyRixNQUFNLFFBQVEsR0FBRyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQy9DLE1BQU0sTUFBTSxHQUFHLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQztJQUM1QyxNQUFNLFdBQVcsR0FBRyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3JFLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxXQUFXLEVBQUUsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hELElBQUksTUFBTSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDdkIsT0FBTyxDQUFDLEtBQUssQ0FBQyxNQUFNLFFBQVEsQ0FBQyxDQUFDLENBQUMscUJBQXFCLFdBQVcsY0FBYyxjQUFjLElBQUksQ0FBQyxDQUFDO1FBQ2pHLE9BQU8sV0FBVyxDQUFDO0tBQ3BCO1NBQU07UUFDTCxNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN0RCxJQUFJLE1BQU0sQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQ3ZCLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxRQUFRLENBQUMsQ0FBQyxDQUFDLHFCQUFxQixXQUFXLGNBQWMsUUFBUSxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsY0FBYyxJQUFJLENBQUMsQ0FBQztZQUM1SCxPQUFPLFdBQVcsQ0FBQztTQUNwQjtRQUNELE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBRSxDQUFDO0tBQ25CO0FBQ0gsQ0FBQztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CRztBQUlILE1BQU0sT0FBTyxzQkFBc0I7SUFDakMsWUFBb0IsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFBRyxDQUFDO0lBRTFEOzs7OztPQUtHO0lBQ0gsU0FBUyxDQUFDLGNBQWlDLEVBQUUsaUJBQTJEO1FBQ3RHLE9BQU8scUJBQXFCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLGNBQWMsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO0lBQ3pGLENBQUM7OEdBWFUsc0JBQXNCOzRHQUF0QixzQkFBc0I7OzJGQUF0QixzQkFBc0I7a0JBSGxDLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLHNCQUFzQjtpQkFDN0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQgeyBpc0FycmF5LCBzcGxpdCB9IGZyb20gJ2xvZGFzaC1lcyc7XG5cbmZ1bmN0aW9uIGdldFRyYW5zbGF0aW9uQmV0d2VlbihcbiAgdHJhbnNsYXRlU2VydmljZTogVHJhbnNsYXRlU2VydmljZSxcbiAgdHJhbnNsYXRpb25LZXk6IHN0cmluZyB8IHN0cmluZ1tdLFxuICBjdXRNYXJrc0FuZFBhcmFtczogW3N0cmluZywgc3RyaW5nXSB8IFtzdHJpbmcsIHN0cmluZywgYW55XVxuKTogc3RyaW5nIHtcbiAgdHJhbnNsYXRpb25LZXkgPSBpc0FycmF5KHRyYW5zbGF0aW9uS2V5KSA/IHRyYW5zbGF0aW9uS2V5LmpvaW4oJy4nKSA6IHRyYW5zbGF0aW9uS2V5O1xuICBjb25zdCBjdXRNYXJrcyA9IGN1dE1hcmtzQW5kUGFyYW1zLnNsaWNlKDAsIDIpO1xuICBjb25zdCBwYXJhbXMgPSBjdXRNYXJrc0FuZFBhcmFtc1syXSB8fCBudWxsO1xuICBjb25zdCB0cmFuc2xhdGlvbiA9IHRyYW5zbGF0ZVNlcnZpY2UuaW5zdGFudCh0cmFuc2xhdGlvbktleSwgcGFyYW1zKTtcbiAgY29uc3QgcGFydHMxID0gc3BsaXQodHJhbnNsYXRpb24sIGBbWyR7Y3V0TWFya3NbMF19XV1gKTtcbiAgaWYgKHBhcnRzMS5sZW5ndGggPT09IDEpIHtcbiAgICBjb25zb2xlLmVycm9yKGAnW1ske2N1dE1hcmtzWzBdfV1dJyBub3QgZm91bmQgaW4gJyR7dHJhbnNsYXRpb259JyBmb3Iga2V5ICcke3RyYW5zbGF0aW9uS2V5fScuYCk7XG4gICAgcmV0dXJuIHRyYW5zbGF0aW9uO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IHBhcnRzMiA9IHNwbGl0KHBhcnRzMVsxXSwgYFtbJHtjdXRNYXJrc1sxXX1dXWApO1xuICAgIGlmIChwYXJ0czIubGVuZ3RoID09PSAxKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGAnW1ske2N1dE1hcmtzWzFdfV1dJyBub3QgZm91bmQgaW4gJyR7dHJhbnNsYXRpb259JyBhZnRlciAnW1ske2N1dE1hcmtzWzBdfV1dJyBmb3Iga2V5ICcke3RyYW5zbGF0aW9uS2V5fScuYCk7XG4gICAgICByZXR1cm4gdHJhbnNsYXRpb247XG4gICAgfVxuICAgIHJldHVybiBwYXJ0czJbMF0hO1xuICB9XG59XG5cbi8qKlxuICogVHJhbnNsYXRlcyB0aGUgZ2l2ZW4gaTE4bi1rZXkgKGluc3RhbnRseSkgYW5kIHJldHVybnMgdGhlIHBhcnQgb2YgdGhlIHRyYW5zbGF0aW9uXG4gKiBiZXR3ZWVuIHRoZSB0d28gY3V0LW1hcmsgc3RyaW5ncyAnW1s8Y3V0TWFyaz5dXScuXG4gKiBOQjogVGhpcyBwaXBlIHNob3VsZCBiZSB1c2VkIHZlcnkgcmFyZWx5LCBhcyBpdCBmaXhlcyB0aGUgb3JkZXIgb2YgY3V0LW1hcmtzLCB3aGljaCBtYXkgbWFrZVxuICogdGhlbSB1bnRyYW5zbGF0ZWFibGUgaW4gc29tZSBsYW5ndWFnZXMuIEl0IGFsc28gbWFrZXMgdGhlIHRlbXBsYXRlIGhhcmRlciB0byByZWFkLlxuICogVXNlIG5vcm1hbCBpbnRlcnBvbGF0aW9ucyByYXRoZXIgdGhhbiBjdXQtbWFya3Mgd2hlbmV2ZXIgdGhlIGNvbnRlbnQgaXMgdGV4dCwgZXZlbiBpZiBpdCBjb21lcyBmcm9tIGFub3RoZXIgcGlwZS5cbiAqIEBleGFtcGxlXG4gKiB7eyAnc29tZS50ZXh0JyB8IGx4VHJhbnNsYXRpb25CZWZvcmU6J2xpbmsnIH19XG4gKiAgIDxhPnt7J3NvbWUubGlua0xhYmVsJyB8IHRyYW5zbGF0ZX19PC9hPlxuICoge3sgJ3NvbWUudGV4dCcgfCBseFRyYW5zbGF0aW9uQmV0d2VlbjpbJ2xpbmsnLCAndXNlckxpbmsnXSB9fVxuICogICA8YT57eydzb21lLnVzZXJOYW1lJyB8IHRyYW5zbGF0ZX19PC9hPlxuICoge3sgJ3NvbWUudGV4dCcgfCBseFRyYW5zbGF0aW9uQWZ0ZXI6J3VzZXJMaW5rJyB9fVxuICpcbiAqIHt7ICdzb21lLnRleHRXaXRoT3RoZXJJbnRlcnBvbGF0aW9ucycgfCBseFRyYW5zbGF0aW9uQmVmb3JlOlsnbGluaycsIHBhcmFtc10gfX1cbiAqICAgPGE+e3snc29tZS5saW5rTGFiZWwnIHwgdHJhbnNsYXRlfX08L2E+XG4gKiB7eyAnc29tZS50ZXh0V2l0aE90aGVySW50ZXJwb2xhdGlvbnMnIHwgbHhUcmFuc2xhdGlvbkJldHdlZW46WydsaW5rJywgJ3VzZXJMaW5rJywgcGFyYW1zXSB9fVxuICogICA8YT57eydzb21lLnVzZXJOYW1lJyB8IHRyYW5zbGF0ZX19PC9hPlxuICoge3sgJ3NvbWUudGV4dFdpdGhPdGhlckludGVycG9sYXRpb25zJyB8IGx4VHJhbnNsYXRpb25BZnRlcjpbJ3VzZXJMaW5rJywgcGFyYW1zXSB9fVxuICogQHNlZSBUcmFuc2xhdGlvbkJlZm9yZVBpcGVcbiAqIEBzZWUgVHJhbnNsYXRpb25BZmVyUGlwZVxuICovXG5AUGlwZSh7XG4gIG5hbWU6ICdseFRyYW5zbGF0aW9uQmV0d2Vlbidcbn0pXG5leHBvcnQgY2xhc3MgVHJhbnNsYXRpb25CZXR3ZWVuUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRyYW5zbGF0ZVNlcnZpY2U6IFRyYW5zbGF0ZVNlcnZpY2UpIHt9XG5cbiAgLyoqXG4gICAqIEBwYXJhbSB7c3RyaW5nfHN0cmluZ1tdfSB0cmFuc2xhdGlvbktleSBpMThuIGtleSBvciBhcnJheSBvZiBpdHMgc2VnbWVudHNcbiAgICogQHBhcmFtIHsoW3N0cmluZywgc3RyaW5nXXxbc3RyaW5nLCBzdHJpbmcsIGFueV0pfSBpbnRlcnBvbGF0aW9uc0FuZFBhcmFtcyBlaXRoZXIganVzdCB0aGUgaW50ZXJwb2xhdGlvbiBzdHJpbmcgdG8gc3BsaXQgYnkgb3JcbiAgICogICBhbiBhcnJheSBvZiBpbnRlcnBvbGF0aW9uIHN0cmluZyBhbmQgdHJhbnNsYXRpb24gcGFyYW1zXG4gICAqIEByZXR1cm5zIHtzdHJpbmd9XG4gICAqL1xuICB0cmFuc2Zvcm0odHJhbnNsYXRpb25LZXk6IHN0cmluZyB8IHN0cmluZ1tdLCBjdXRNYXJrc0FuZFBhcmFtczogW3N0cmluZywgc3RyaW5nXSB8IFtzdHJpbmcsIHN0cmluZywgYW55XSk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGdldFRyYW5zbGF0aW9uQmV0d2Vlbih0aGlzLnRyYW5zbGF0ZVNlcnZpY2UsIHRyYW5zbGF0aW9uS2V5LCBjdXRNYXJrc0FuZFBhcmFtcyk7XG4gIH1cbn1cbiJdfQ==
68
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRpb24tYmV0d2Vlbi5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvY29yZS11aS9waXBlcy90cmFuc2xhdGlvbi1iZXR3ZWVuLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFFcEQsT0FBTyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxXQUFXLENBQUM7OztBQUUzQyxTQUFTLHFCQUFxQixDQUM1QixnQkFBa0MsRUFDbEMsY0FBaUMsRUFDakMsaUJBQTJEO0lBRTNELGNBQWMsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQztJQUNyRixNQUFNLFFBQVEsR0FBRyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQy9DLE1BQU0sTUFBTSxHQUFHLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQztJQUM1QyxNQUFNLFdBQVcsR0FBRyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3JFLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxXQUFXLEVBQUUsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hELElBQUksTUFBTSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDdkIsT0FBTyxDQUFDLEtBQUssQ0FBQyxNQUFNLFFBQVEsQ0FBQyxDQUFDLENBQUMscUJBQXFCLFdBQVcsY0FBYyxjQUFjLElBQUksQ0FBQyxDQUFDO1FBQ2pHLE9BQU8sV0FBVyxDQUFDO0tBQ3BCO1NBQU07UUFDTCxNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN0RCxJQUFJLE1BQU0sQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFO1lBQ3ZCLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxRQUFRLENBQUMsQ0FBQyxDQUFDLHFCQUFxQixXQUFXLGNBQWMsUUFBUSxDQUFDLENBQUMsQ0FBQyxnQkFBZ0IsY0FBYyxJQUFJLENBQUMsQ0FBQztZQUM1SCxPQUFPLFdBQVcsQ0FBQztTQUNwQjtRQUNELE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBRSxDQUFDO0tBQ25CO0FBQ0gsQ0FBQztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9CRztBQUtILE1BQU0sT0FBTyxzQkFBc0I7SUFDakMsWUFBb0IsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFBRyxDQUFDO0lBRTFEOzs7OztPQUtHO0lBQ0gsU0FBUyxDQUFDLGNBQWlDLEVBQUUsaUJBQTJEO1FBQ3RHLE9BQU8scUJBQXFCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLGNBQWMsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO0lBQ3pGLENBQUM7OEdBWFUsc0JBQXNCOzRHQUF0QixzQkFBc0I7OzJGQUF0QixzQkFBc0I7a0JBSmxDLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLHNCQUFzQjtvQkFDNUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgaXNBcnJheSwgc3BsaXQgfSBmcm9tICdsb2Rhc2gtZXMnO1xuXG5mdW5jdGlvbiBnZXRUcmFuc2xhdGlvbkJldHdlZW4oXG4gIHRyYW5zbGF0ZVNlcnZpY2U6IFRyYW5zbGF0ZVNlcnZpY2UsXG4gIHRyYW5zbGF0aW9uS2V5OiBzdHJpbmcgfCBzdHJpbmdbXSxcbiAgY3V0TWFya3NBbmRQYXJhbXM6IFtzdHJpbmcsIHN0cmluZ10gfCBbc3RyaW5nLCBzdHJpbmcsIGFueV1cbik6IHN0cmluZyB7XG4gIHRyYW5zbGF0aW9uS2V5ID0gaXNBcnJheSh0cmFuc2xhdGlvbktleSkgPyB0cmFuc2xhdGlvbktleS5qb2luKCcuJykgOiB0cmFuc2xhdGlvbktleTtcbiAgY29uc3QgY3V0TWFya3MgPSBjdXRNYXJrc0FuZFBhcmFtcy5zbGljZSgwLCAyKTtcbiAgY29uc3QgcGFyYW1zID0gY3V0TWFya3NBbmRQYXJhbXNbMl0gfHwgbnVsbDtcbiAgY29uc3QgdHJhbnNsYXRpb24gPSB0cmFuc2xhdGVTZXJ2aWNlLmluc3RhbnQodHJhbnNsYXRpb25LZXksIHBhcmFtcyk7XG4gIGNvbnN0IHBhcnRzMSA9IHNwbGl0KHRyYW5zbGF0aW9uLCBgW1ske2N1dE1hcmtzWzBdfV1dYCk7XG4gIGlmIChwYXJ0czEubGVuZ3RoID09PSAxKSB7XG4gICAgY29uc29sZS5lcnJvcihgJ1tbJHtjdXRNYXJrc1swXX1dXScgbm90IGZvdW5kIGluICcke3RyYW5zbGF0aW9ufScgZm9yIGtleSAnJHt0cmFuc2xhdGlvbktleX0nLmApO1xuICAgIHJldHVybiB0cmFuc2xhdGlvbjtcbiAgfSBlbHNlIHtcbiAgICBjb25zdCBwYXJ0czIgPSBzcGxpdChwYXJ0czFbMV0sIGBbWyR7Y3V0TWFya3NbMV19XV1gKTtcbiAgICBpZiAocGFydHMyLmxlbmd0aCA9PT0gMSkge1xuICAgICAgY29uc29sZS5lcnJvcihgJ1tbJHtjdXRNYXJrc1sxXX1dXScgbm90IGZvdW5kIGluICcke3RyYW5zbGF0aW9ufScgYWZ0ZXIgJ1tbJHtjdXRNYXJrc1swXX1dXScgZm9yIGtleSAnJHt0cmFuc2xhdGlvbktleX0nLmApO1xuICAgICAgcmV0dXJuIHRyYW5zbGF0aW9uO1xuICAgIH1cbiAgICByZXR1cm4gcGFydHMyWzBdITtcbiAgfVxufVxuXG4vKipcbiAqIFRyYW5zbGF0ZXMgdGhlIGdpdmVuIGkxOG4ta2V5IChpbnN0YW50bHkpIGFuZCByZXR1cm5zIHRoZSBwYXJ0IG9mIHRoZSB0cmFuc2xhdGlvblxuICogYmV0d2VlbiB0aGUgdHdvIGN1dC1tYXJrIHN0cmluZ3MgJ1tbPGN1dE1hcms+XV0nLlxuICogTkI6IFRoaXMgcGlwZSBzaG91bGQgYmUgdXNlZCB2ZXJ5IHJhcmVseSwgYXMgaXQgZml4ZXMgdGhlIG9yZGVyIG9mIGN1dC1tYXJrcywgd2hpY2ggbWF5IG1ha2VcbiAqIHRoZW0gdW50cmFuc2xhdGVhYmxlIGluIHNvbWUgbGFuZ3VhZ2VzLiBJdCBhbHNvIG1ha2VzIHRoZSB0ZW1wbGF0ZSBoYXJkZXIgdG8gcmVhZC5cbiAqIFVzZSBub3JtYWwgaW50ZXJwb2xhdGlvbnMgcmF0aGVyIHRoYW4gY3V0LW1hcmtzIHdoZW5ldmVyIHRoZSBjb250ZW50IGlzIHRleHQsIGV2ZW4gaWYgaXQgY29tZXMgZnJvbSBhbm90aGVyIHBpcGUuXG4gKiBAZXhhbXBsZVxuICoge3sgJ3NvbWUudGV4dCcgfCBseFRyYW5zbGF0aW9uQmVmb3JlOidsaW5rJyB9fVxuICogICA8YT57eydzb21lLmxpbmtMYWJlbCcgfCB0cmFuc2xhdGV9fTwvYT5cbiAqIHt7ICdzb21lLnRleHQnIHwgbHhUcmFuc2xhdGlvbkJldHdlZW46WydsaW5rJywgJ3VzZXJMaW5rJ10gfX1cbiAqICAgPGE+e3snc29tZS51c2VyTmFtZScgfCB0cmFuc2xhdGV9fTwvYT5cbiAqIHt7ICdzb21lLnRleHQnIHwgbHhUcmFuc2xhdGlvbkFmdGVyOid1c2VyTGluaycgfX1cbiAqXG4gKiB7eyAnc29tZS50ZXh0V2l0aE90aGVySW50ZXJwb2xhdGlvbnMnIHwgbHhUcmFuc2xhdGlvbkJlZm9yZTpbJ2xpbmsnLCBwYXJhbXNdIH19XG4gKiAgIDxhPnt7J3NvbWUubGlua0xhYmVsJyB8IHRyYW5zbGF0ZX19PC9hPlxuICoge3sgJ3NvbWUudGV4dFdpdGhPdGhlckludGVycG9sYXRpb25zJyB8IGx4VHJhbnNsYXRpb25CZXR3ZWVuOlsnbGluaycsICd1c2VyTGluaycsIHBhcmFtc10gfX1cbiAqICAgPGE+e3snc29tZS51c2VyTmFtZScgfCB0cmFuc2xhdGV9fTwvYT5cbiAqIHt7ICdzb21lLnRleHRXaXRoT3RoZXJJbnRlcnBvbGF0aW9ucycgfCBseFRyYW5zbGF0aW9uQWZ0ZXI6Wyd1c2VyTGluaycsIHBhcmFtc10gfX1cbiAqIEBzZWUgVHJhbnNsYXRpb25CZWZvcmVQaXBlXG4gKiBAc2VlIFRyYW5zbGF0aW9uQWZlclBpcGVcbiAqL1xuQFBpcGUoe1xuICBuYW1lOiAnbHhUcmFuc2xhdGlvbkJldHdlZW4nLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIFRyYW5zbGF0aW9uQmV0d2VlblBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSB0cmFuc2xhdGVTZXJ2aWNlOiBUcmFuc2xhdGVTZXJ2aWNlKSB7fVxuXG4gIC8qKlxuICAgKiBAcGFyYW0ge3N0cmluZ3xzdHJpbmdbXX0gdHJhbnNsYXRpb25LZXkgaTE4biBrZXkgb3IgYXJyYXkgb2YgaXRzIHNlZ21lbnRzXG4gICAqIEBwYXJhbSB7KFtzdHJpbmcsIHN0cmluZ118W3N0cmluZywgc3RyaW5nLCBhbnldKX0gaW50ZXJwb2xhdGlvbnNBbmRQYXJhbXMgZWl0aGVyIGp1c3QgdGhlIGludGVycG9sYXRpb24gc3RyaW5nIHRvIHNwbGl0IGJ5IG9yXG4gICAqICAgYW4gYXJyYXkgb2YgaW50ZXJwb2xhdGlvbiBzdHJpbmcgYW5kIHRyYW5zbGF0aW9uIHBhcmFtc1xuICAgKiBAcmV0dXJucyB7c3RyaW5nfVxuICAgKi9cbiAgdHJhbnNmb3JtKHRyYW5zbGF0aW9uS2V5OiBzdHJpbmcgfCBzdHJpbmdbXSwgY3V0TWFya3NBbmRQYXJhbXM6IFtzdHJpbmcsIHN0cmluZ10gfCBbc3RyaW5nLCBzdHJpbmcsIGFueV0pOiBzdHJpbmcge1xuICAgIHJldHVybiBnZXRUcmFuc2xhdGlvbkJldHdlZW4odGhpcy50cmFuc2xhdGVTZXJ2aWNlLCB0cmFuc2xhdGlvbktleSwgY3V0TWFya3NBbmRQYXJhbXMpO1xuICB9XG59XG4iXX0=
@@ -5,12 +5,13 @@ export class UnescapeCurlyBracesPipe {
5
5
  return input.replace(/\\([{}])/g, '$1');
6
6
  }
7
7
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: UnescapeCurlyBracesPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
8
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.0.2", ngImport: i0, type: UnescapeCurlyBracesPipe, name: "lxUnescapeCurlyBraces" }); }
8
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.0.2", ngImport: i0, type: UnescapeCurlyBracesPipe, isStandalone: true, name: "lxUnescapeCurlyBraces" }); }
9
9
  }
10
10
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: UnescapeCurlyBracesPipe, decorators: [{
11
11
  type: Pipe,
12
12
  args: [{
13
- name: 'lxUnescapeCurlyBraces'
13
+ name: 'lxUnescapeCurlyBraces',
14
+ standalone: true
14
15
  }]
15
16
  }] });
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5lc2NhcGUtY3VybHktYnJhY2VzLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3BpcGVzL3VuZXNjYXBlLWN1cmx5LWJyYWNlcy5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQUtwRCxNQUFNLE9BQU8sdUJBQXVCO0lBQ2xDLFNBQVMsQ0FBQyxLQUFhO1FBQ3JCLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDMUMsQ0FBQzs4R0FIVSx1QkFBdUI7NEdBQXZCLHVCQUF1Qjs7MkZBQXZCLHVCQUF1QjtrQkFIbkMsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsdUJBQXVCO2lCQUM5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQFBpcGUoe1xuICBuYW1lOiAnbHhVbmVzY2FwZUN1cmx5QnJhY2VzJ1xufSlcbmV4cG9ydCBjbGFzcyBVbmVzY2FwZUN1cmx5QnJhY2VzUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0oaW5wdXQ6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGlucHV0LnJlcGxhY2UoL1xcXFwoW3t9XSkvZywgJyQxJyk7XG4gIH1cbn1cbiJdfQ==
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5lc2NhcGUtY3VybHktYnJhY2VzLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3BpcGVzL3VuZXNjYXBlLWN1cmx5LWJyYWNlcy5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQU1wRCxNQUFNLE9BQU8sdUJBQXVCO0lBQ2xDLFNBQVMsQ0FBQyxLQUFhO1FBQ3JCLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDMUMsQ0FBQzs4R0FIVSx1QkFBdUI7NEdBQXZCLHVCQUF1Qjs7MkZBQXZCLHVCQUF1QjtrQkFKbkMsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsdUJBQXVCO29CQUM3QixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ2x4VW5lc2NhcGVDdXJseUJyYWNlcycsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgVW5lc2NhcGVDdXJseUJyYWNlc1BpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgdHJhbnNmb3JtKGlucHV0OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBpbnB1dC5yZXBsYWNlKC9cXFxcKFt7fV0pL2csICckMScpO1xuICB9XG59XG4iXX0=
@@ -1,6 +1,6 @@
1
+ import { NgClass, NgIf } from '@angular/common';
1
2
  import { Component, Input } from '@angular/core';
2
3
  import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/common";
4
4
  export class TooltipComponent {
5
5
  constructor() {
6
6
  this.content = '';
@@ -11,11 +11,11 @@ export class TooltipComponent {
11
11
  };
12
12
  }
13
13
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TooltipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
14
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: TooltipComponent, selector: "lx-tooltip", inputs: { content: "content", isHtmlContent: "isHtmlContent", position: "position" }, ngImport: i0, template: "<div *ngIf=\"!isHtmlContent; else htmlTooltip\" [ngClass]=\"['x-' + position.x, 'y-' + position.y]\">{{ content }}</div>\n<ng-template #htmlTooltip>\n <div [innerHtml]=\"content\" [ngClass]=\"['x-' + position.x, 'y-' + position.y]\"></div>\n</ng-template>\n", styles: [":host{display:block;position:relative;margin:5px}div{background-color:#292929;color:#fff;border:0 solid transparent;border-radius:5px;opacity:1;font-size:11px;font-weight:400;text-shadow:0 1px black;text-align:left;word-wrap:break-word;line-height:16px;max-width:280px;min-width:50px;padding:6px 10px;overflow:hidden}.y-bottom:after,.y-top:after,.x-left:after,.x-right:after{content:\" \";position:absolute;border-width:5px;border-style:solid;border-color:#292929 transparent transparent transparent}.y-top:after{top:100%;margin-left:-5px}.y-bottom:after{top:0;margin-left:-5px;transform-origin:center top;transform:rotate(180deg)}.y-center:after{top:50%;margin-left:-5px;margin-top:-10px}.y-top.x-center:after,.y-bottom.x-center:after{left:50%}.y-top.x-left:after,.y-bottom.x-left:after{right:10px}.y-top.x-right:after,.y-bottom.x-right:after{left:10px}.y-center.x-right:after{left:0;transform-origin:left center;transform:rotate(90deg)}.y-center.x-left:after{left:100%;transform-origin:right center;transform:rotate(-90deg)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: TooltipComponent, isStandalone: true, selector: "lx-tooltip", inputs: { content: "content", isHtmlContent: "isHtmlContent", position: "position" }, ngImport: i0, template: "<div *ngIf=\"!isHtmlContent; else htmlTooltip\" [ngClass]=\"['x-' + position.x, 'y-' + position.y]\">{{ content }}</div>\n<ng-template #htmlTooltip>\n <div [innerHtml]=\"content\" [ngClass]=\"['x-' + position.x, 'y-' + position.y]\"></div>\n</ng-template>\n", styles: [":host{display:block;position:relative;margin:5px}div{background-color:#292929;color:#fff;border:0 solid transparent;border-radius:5px;opacity:1;font-size:11px;font-weight:400;text-shadow:0 1px black;text-align:left;word-wrap:break-word;line-height:16px;max-width:280px;min-width:50px;padding:6px 10px;overflow:hidden}.y-bottom:after,.y-top:after,.x-left:after,.x-right:after{content:\" \";position:absolute;border-width:5px;border-style:solid;border-color:#292929 transparent transparent transparent}.y-top:after{top:100%;margin-left:-5px}.y-bottom:after{top:0;margin-left:-5px;transform-origin:center top;transform:rotate(180deg)}.y-center:after{top:50%;margin-left:-5px;margin-top:-10px}.y-top.x-center:after,.y-bottom.x-center:after{left:50%}.y-top.x-left:after,.y-bottom.x-left:after{right:10px}.y-top.x-right:after,.y-bottom.x-right:after{left:10px}.y-center.x-right:after{left:0;transform-origin:left center;transform:rotate(90deg)}.y-center.x-left:after{left:100%;transform-origin:right center;transform:rotate(-90deg)}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
15
15
  }
16
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TooltipComponent, decorators: [{
17
17
  type: Component,
18
- args: [{ selector: 'lx-tooltip', template: "<div *ngIf=\"!isHtmlContent; else htmlTooltip\" [ngClass]=\"['x-' + position.x, 'y-' + position.y]\">{{ content }}</div>\n<ng-template #htmlTooltip>\n <div [innerHtml]=\"content\" [ngClass]=\"['x-' + position.x, 'y-' + position.y]\"></div>\n</ng-template>\n", styles: [":host{display:block;position:relative;margin:5px}div{background-color:#292929;color:#fff;border:0 solid transparent;border-radius:5px;opacity:1;font-size:11px;font-weight:400;text-shadow:0 1px black;text-align:left;word-wrap:break-word;line-height:16px;max-width:280px;min-width:50px;padding:6px 10px;overflow:hidden}.y-bottom:after,.y-top:after,.x-left:after,.x-right:after{content:\" \";position:absolute;border-width:5px;border-style:solid;border-color:#292929 transparent transparent transparent}.y-top:after{top:100%;margin-left:-5px}.y-bottom:after{top:0;margin-left:-5px;transform-origin:center top;transform:rotate(180deg)}.y-center:after{top:50%;margin-left:-5px;margin-top:-10px}.y-top.x-center:after,.y-bottom.x-center:after{left:50%}.y-top.x-left:after,.y-bottom.x-left:after{right:10px}.y-top.x-right:after,.y-bottom.x-right:after{left:10px}.y-center.x-right:after{left:0;transform-origin:left center;transform:rotate(90deg)}.y-center.x-left:after{left:100%;transform-origin:right center;transform:rotate(-90deg)}\n"] }]
18
+ args: [{ selector: 'lx-tooltip', standalone: true, imports: [NgIf, NgClass], template: "<div *ngIf=\"!isHtmlContent; else htmlTooltip\" [ngClass]=\"['x-' + position.x, 'y-' + position.y]\">{{ content }}</div>\n<ng-template #htmlTooltip>\n <div [innerHtml]=\"content\" [ngClass]=\"['x-' + position.x, 'y-' + position.y]\"></div>\n</ng-template>\n", styles: [":host{display:block;position:relative;margin:5px}div{background-color:#292929;color:#fff;border:0 solid transparent;border-radius:5px;opacity:1;font-size:11px;font-weight:400;text-shadow:0 1px black;text-align:left;word-wrap:break-word;line-height:16px;max-width:280px;min-width:50px;padding:6px 10px;overflow:hidden}.y-bottom:after,.y-top:after,.x-left:after,.x-right:after{content:\" \";position:absolute;border-width:5px;border-style:solid;border-color:#292929 transparent transparent transparent}.y-top:after{top:100%;margin-left:-5px}.y-bottom:after{top:0;margin-left:-5px;transform-origin:center top;transform:rotate(180deg)}.y-center:after{top:50%;margin-left:-5px;margin-top:-10px}.y-top.x-center:after,.y-bottom.x-center:after{left:50%}.y-top.x-left:after,.y-bottom.x-left:after{right:10px}.y-top.x-right:after,.y-bottom.x-right:after{left:10px}.y-center.x-right:after{left:0;transform-origin:left center;transform:rotate(90deg)}.y-center.x-left:after{left:100%;transform-origin:right center;transform:rotate(-90deg)}\n"] }]
19
19
  }], propDecorators: { content: [{
20
20
  type: Input
21
21
  }], isHtmlContent: [{
@@ -23,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
23
23
  }], position: [{
24
24
  type: Input
25
25
  }] } });
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3Rvb2x0aXAvdG9vbHRpcC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3Rvb2x0aXAvdG9vbHRpcC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBUWpELE1BQU0sT0FBTyxnQkFBZ0I7SUFMN0I7UUFNVyxZQUFPLEdBQUcsRUFBRSxDQUFDO1FBQ2Isa0JBQWEsR0FBWSxLQUFLLENBQUM7UUFDL0IsYUFBUSxHQUFvQjtZQUNuQyxDQUFDLEVBQUUsUUFBUTtZQUNYLENBQUMsRUFBRSxLQUFLO1NBQ1QsQ0FBQztLQUNIOzhHQVBZLGdCQUFnQjtrR0FBaEIsZ0JBQWdCLHdJQ1I3QixvUUFJQTs7MkZESWEsZ0JBQWdCO2tCQUw1QixTQUFTOytCQUNFLFlBQVk7OEJBS2IsT0FBTztzQkFBZixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRvb2x0aXBQb3NpdGlvbiB9IGZyb20gJy4vdG9vbHRpcC1wb3NpdGlvbi5pbnRlcmZhY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdseC10b29sdGlwJyxcbiAgc3R5bGVVcmxzOiBbJy4vdG9vbHRpcC5jb21wb25lbnQuc2NzcyddLFxuICB0ZW1wbGF0ZVVybDogJy4vdG9vbHRpcC5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgVG9vbHRpcENvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGNvbnRlbnQgPSAnJztcbiAgQElucHV0KCkgaXNIdG1sQ29udGVudDogYm9vbGVhbiA9IGZhbHNlO1xuICBASW5wdXQoKSBwb3NpdGlvbjogVG9vbHRpcFBvc2l0aW9uID0ge1xuICAgIHg6ICdjZW50ZXInLFxuICAgIHk6ICd0b3AnXG4gIH07XG59XG4iLCI8ZGl2ICpuZ0lmPVwiIWlzSHRtbENvbnRlbnQ7IGVsc2UgaHRtbFRvb2x0aXBcIiBbbmdDbGFzc109XCJbJ3gtJyArIHBvc2l0aW9uLngsICd5LScgKyBwb3NpdGlvbi55XVwiPnt7IGNvbnRlbnQgfX08L2Rpdj5cbjxuZy10ZW1wbGF0ZSAjaHRtbFRvb2x0aXA+XG4gIDxkaXYgW2lubmVySHRtbF09XCJjb250ZW50XCIgW25nQ2xhc3NdPVwiWyd4LScgKyBwb3NpdGlvbi54LCAneS0nICsgcG9zaXRpb24ueV1cIj48L2Rpdj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3Rvb2x0aXAvdG9vbHRpcC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9jb3JlLXVpL3Rvb2x0aXAvdG9vbHRpcC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVVqRCxNQUFNLE9BQU8sZ0JBQWdCO0lBUDdCO1FBUVcsWUFBTyxHQUFHLEVBQUUsQ0FBQztRQUNiLGtCQUFhLEdBQVksS0FBSyxDQUFDO1FBQy9CLGFBQVEsR0FBb0I7WUFDbkMsQ0FBQyxFQUFFLFFBQVE7WUFDWCxDQUFDLEVBQUUsS0FBSztTQUNULENBQUM7S0FDSDs4R0FQWSxnQkFBZ0I7a0dBQWhCLGdCQUFnQiw0SkNYN0Isb1FBSUEsOGpDREtZLElBQUksNkZBQUUsT0FBTzs7MkZBRVosZ0JBQWdCO2tCQVA1QixTQUFTOytCQUNFLFlBQVksY0FHVixJQUFJLFdBQ1AsQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDOzhCQUdmLE9BQU87c0JBQWYsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ0NsYXNzLCBOZ0lmIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRvb2x0aXBQb3NpdGlvbiB9IGZyb20gJy4vdG9vbHRpcC1wb3NpdGlvbi5pbnRlcmZhY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdseC10b29sdGlwJyxcbiAgc3R5bGVVcmxzOiBbJy4vdG9vbHRpcC5jb21wb25lbnQuc2NzcyddLFxuICB0ZW1wbGF0ZVVybDogJy4vdG9vbHRpcC5jb21wb25lbnQuaHRtbCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtOZ0lmLCBOZ0NsYXNzXVxufSlcbmV4cG9ydCBjbGFzcyBUb29sdGlwQ29tcG9uZW50IHtcbiAgQElucHV0KCkgY29udGVudCA9ICcnO1xuICBASW5wdXQoKSBpc0h0bWxDb250ZW50OiBib29sZWFuID0gZmFsc2U7XG4gIEBJbnB1dCgpIHBvc2l0aW9uOiBUb29sdGlwUG9zaXRpb24gPSB7XG4gICAgeDogJ2NlbnRlcicsXG4gICAgeTogJ3RvcCdcbiAgfTtcbn1cbiIsIjxkaXYgKm5nSWY9XCIhaXNIdG1sQ29udGVudDsgZWxzZSBodG1sVG9vbHRpcFwiIFtuZ0NsYXNzXT1cIlsneC0nICsgcG9zaXRpb24ueCwgJ3ktJyArIHBvc2l0aW9uLnldXCI+e3sgY29udGVudCB9fTwvZGl2PlxuPG5nLXRlbXBsYXRlICNodG1sVG9vbHRpcD5cbiAgPGRpdiBbaW5uZXJIdG1sXT1cImNvbnRlbnRcIiBbbmdDbGFzc109XCJbJ3gtJyArIHBvc2l0aW9uLngsICd5LScgKyBwb3NpdGlvbi55XVwiPjwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
@@ -70,12 +70,13 @@ export class TooltipDirective {
70
70
  this.overlayRef?.dispose();
71
71
  }
72
72
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TooltipDirective, deps: [{ token: i1.OverlayPositionBuilder }, { token: i0.ElementRef }, { token: i1.Overlay }], target: i0.ɵɵFactoryTarget.Directive }); }
73
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.2", type: TooltipDirective, selector: "[lxTooltip]", inputs: { content: ["lxTooltip", "content"], lxTooltipPosition: "lxTooltipPosition", lxTooltipDelay: "lxTooltipDelay", lxTooltipIsHtmlContent: "lxTooltipIsHtmlContent" }, host: { listeners: { "mouseenter": "show()", "focus": "show()", "mouseleave": "hide()", "click": "hide()", "blur": "hide()" } }, usesOnChanges: true, ngImport: i0 }); }
73
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.2", type: TooltipDirective, isStandalone: true, selector: "[lxTooltip]", inputs: { content: ["lxTooltip", "content"], lxTooltipPosition: "lxTooltipPosition", lxTooltipDelay: "lxTooltipDelay", lxTooltipIsHtmlContent: "lxTooltipIsHtmlContent" }, host: { listeners: { "mouseenter": "show()", "focus": "show()", "mouseleave": "hide()", "click": "hide()", "blur": "hide()" } }, usesOnChanges: true, ngImport: i0 }); }
74
74
  }
75
75
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: TooltipDirective, decorators: [{
76
76
  type: Directive,
77
77
  args: [{
78
- selector: '[lxTooltip]'
78
+ selector: '[lxTooltip]',
79
+ standalone: true
79
80
  }]
80
81
  }], ctorParameters: () => [{ type: i1.OverlayPositionBuilder }, { type: i0.ElementRef }, { type: i1.Overlay }], propDecorators: { content: [{
81
82
  type: Input,
@@ -102,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
102
103
  type: HostListener,
103
104
  args: ['blur']
104
105
  }] } });
105
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/core-ui/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayPositionBuilder, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, Directive, ElementRef, HostListener, Input, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';\nimport { toCdkPosition } from './to-cdk-position.function';\nimport { isValidX, isValidY, TooltipPosition } from './tooltip-position.interface';\nimport { TooltipComponent } from './tooltip.component';\n\n@Directive({\n  selector: '[lxTooltip]'\n})\nexport class TooltipDirective implements OnChanges, OnDestroy {\n  @Input('lxTooltip') content?: string | null;\n  @Input() set lxTooltipPosition(value: { x: string; y: string } | undefined) {\n    this.position = {\n      x: value && isValidX(value.x) ? value.x : 'center',\n      y: value && isValidY(value.y) ? value.y : 'top'\n    };\n  }\n  private position: TooltipPosition = {\n    x: 'center',\n    y: 'top'\n  };\n  @Input() lxTooltipDelay?: number;\n  @Input() lxTooltipIsHtmlContent: boolean = false;\n\n  private overlayRef?: OverlayRef;\n  private tooltipRef?: ComponentRef<TooltipComponent>;\n  private mouseOrFocusOnHost: boolean = false;\n\n  get positionStrategy() {\n    return this.overlayPositionBuilder.flexibleConnectedTo(this.elementRef).withPositions([toCdkPosition(this.position)]);\n  }\n\n  constructor(private overlayPositionBuilder: OverlayPositionBuilder, private elementRef: ElementRef, private overlay: Overlay) {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.overlayRef && changes['lxTooltipPosition']) {\n      this.overlayRef.updatePositionStrategy(this.positionStrategy);\n    }\n    if (this.tooltipRef) {\n      if (changes['lxTooltipPosition']) {\n        this.tooltipRef.instance.position = this.position;\n      }\n      if (changes['lxTooltipIsHtmlContent']) {\n        this.tooltipRef.instance.isHtmlContent = this.lxTooltipIsHtmlContent;\n      }\n      if (changes['content']) {\n        if (this.content) {\n          this.tooltipRef.instance.content = this.content;\n          this.overlayRef?.updatePosition();\n        } else {\n          this.overlayRef?.detach();\n        }\n      }\n    }\n  }\n\n  @HostListener('mouseenter')\n  @HostListener('focus')\n  show() {\n    this.mouseOrFocusOnHost = true;\n    setTimeout(() => {\n      if (!this.overlayRef?.hasAttached() && this.mouseOrFocusOnHost && this.content) {\n        this.overlayRef = this.overlay.create({ positionStrategy: this.positionStrategy });\n        const tooltipPortal = new ComponentPortal(TooltipComponent);\n        this.tooltipRef = this.overlayRef.attach(tooltipPortal);\n        this.tooltipRef.instance.content = this.content;\n        this.tooltipRef.instance.isHtmlContent = this.lxTooltipIsHtmlContent;\n        this.tooltipRef.instance.position = this.position;\n      }\n    }, this.lxTooltipDelay ?? 90);\n  }\n\n  ngOnDestroy() {\n    this.mouseOrFocusOnHost = false;\n    this.overlayRef?.dispose();\n  }\n\n  @HostListener('mouseleave')\n  @HostListener('click')\n  @HostListener('blur')\n  hide() {\n    this.mouseOrFocusOnHost = false;\n    this.overlayRef?.dispose();\n  }\n}\n"]}
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/core-ui/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayPositionBuilder, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, Directive, ElementRef, HostListener, Input, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';\nimport { toCdkPosition } from './to-cdk-position.function';\nimport { TooltipPosition, isValidX, isValidY } from './tooltip-position.interface';\nimport { TooltipComponent } from './tooltip.component';\n\n@Directive({\n  selector: '[lxTooltip]',\n  standalone: true\n})\nexport class TooltipDirective implements OnChanges, OnDestroy {\n  @Input('lxTooltip') content?: string | null;\n  @Input() set lxTooltipPosition(value: { x: string; y: string } | undefined) {\n    this.position = {\n      x: value && isValidX(value.x) ? value.x : 'center',\n      y: value && isValidY(value.y) ? value.y : 'top'\n    };\n  }\n  private position: TooltipPosition = {\n    x: 'center',\n    y: 'top'\n  };\n  @Input() lxTooltipDelay?: number;\n  @Input() lxTooltipIsHtmlContent: boolean = false;\n\n  private overlayRef?: OverlayRef;\n  private tooltipRef?: ComponentRef<TooltipComponent>;\n  private mouseOrFocusOnHost: boolean = false;\n\n  get positionStrategy() {\n    return this.overlayPositionBuilder.flexibleConnectedTo(this.elementRef).withPositions([toCdkPosition(this.position)]);\n  }\n\n  constructor(\n    private overlayPositionBuilder: OverlayPositionBuilder,\n    private elementRef: ElementRef,\n    private overlay: Overlay\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (this.overlayRef && changes['lxTooltipPosition']) {\n      this.overlayRef.updatePositionStrategy(this.positionStrategy);\n    }\n    if (this.tooltipRef) {\n      if (changes['lxTooltipPosition']) {\n        this.tooltipRef.instance.position = this.position;\n      }\n      if (changes['lxTooltipIsHtmlContent']) {\n        this.tooltipRef.instance.isHtmlContent = this.lxTooltipIsHtmlContent;\n      }\n      if (changes['content']) {\n        if (this.content) {\n          this.tooltipRef.instance.content = this.content;\n          this.overlayRef?.updatePosition();\n        } else {\n          this.overlayRef?.detach();\n        }\n      }\n    }\n  }\n\n  @HostListener('mouseenter')\n  @HostListener('focus')\n  show() {\n    this.mouseOrFocusOnHost = true;\n    setTimeout(() => {\n      if (!this.overlayRef?.hasAttached() && this.mouseOrFocusOnHost && this.content) {\n        this.overlayRef = this.overlay.create({ positionStrategy: this.positionStrategy });\n        const tooltipPortal = new ComponentPortal(TooltipComponent);\n        this.tooltipRef = this.overlayRef.attach(tooltipPortal);\n        this.tooltipRef.instance.content = this.content;\n        this.tooltipRef.instance.isHtmlContent = this.lxTooltipIsHtmlContent;\n        this.tooltipRef.instance.position = this.position;\n      }\n    }, this.lxTooltipDelay ?? 90);\n  }\n\n  ngOnDestroy() {\n    this.mouseOrFocusOnHost = false;\n    this.overlayRef?.dispose();\n  }\n\n  @HostListener('mouseleave')\n  @HostListener('click')\n  @HostListener('blur')\n  hide() {\n    this.mouseOrFocusOnHost = false;\n    this.overlayRef?.dispose();\n  }\n}\n"]}
@@ -11,11 +11,11 @@ export class BasicDropdownItemComponent {
11
11
  return !!this.description;
12
12
  }
13
13
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: BasicDropdownItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
14
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: BasicDropdownItemComponent, selector: "lx-basic-dropdown-item", inputs: { label: "label", description: "description", highlightTerm: "highlightTerm", labelFontWeight: "labelFontWeight", descriptionFontStyle: "descriptionFontStyle", descriptionStyleOptions: "descriptionStyleOptions" }, host: { properties: { "class.hasDescription": "this.hasDescription" } }, ngImport: i0, template: "<div [class.boldLabel]=\"labelFontWeight === 'bold'\" [innerHtml]=\"label | lxHighlightTerm : highlightTerm\"></div>\n<div\n class=\"optionDescription\"\n [style.font-style]=\"descriptionFontStyle\"\n [ngClass]=\"{ maxTextLines: descriptionStyleOptions?.maxLines }\"\n [style.-webkit-line-clamp]=\"descriptionStyleOptions?.maxLines || 'inherit'\"\n>\n {{ description }}\n</div>\n", styles: [":host{display:block;padding:2px 0}:host.hasDescription{padding:4px 0}.boldLabel{font-weight:700}.optionDescription{padding-top:2px;color:#61779d;font-size:11px}.optionDescription.maxTextLines{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:inherit;-webkit-box-orient:vertical}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i2.HighlightTermPipe, name: "lxHighlightTerm" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: BasicDropdownItemComponent, selector: "lx-basic-dropdown-item", inputs: { label: "label", description: "description", highlightTerm: "highlightTerm", labelFontWeight: "labelFontWeight", descriptionFontStyle: "descriptionFontStyle", descriptionStyleOptions: "descriptionStyleOptions" }, host: { properties: { "class.hasDescription": "this.hasDescription" } }, ngImport: i0, template: "<div [class.boldLabel]=\"labelFontWeight === 'bold'\" [innerHtml]=\"label | lxHighlightTerm: highlightTerm\"></div>\n<div\n class=\"optionDescription\"\n [style.font-style]=\"descriptionFontStyle\"\n [ngClass]=\"{ maxTextLines: descriptionStyleOptions?.maxLines }\"\n [style.-webkit-line-clamp]=\"descriptionStyleOptions?.maxLines || 'inherit'\"\n>\n {{ description }}\n</div>\n", styles: [":host{display:block;padding:2px 0}:host.hasDescription{padding:4px 0}.boldLabel{font-weight:700}.optionDescription{padding-top:2px;color:#61779d;font-size:11px}.optionDescription.maxTextLines{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:inherit;-webkit-box-orient:vertical}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i2.HighlightTermPipe, name: "lxHighlightTerm" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
15
15
  }
16
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: BasicDropdownItemComponent, decorators: [{
17
17
  type: Component,
18
- args: [{ selector: 'lx-basic-dropdown-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class.boldLabel]=\"labelFontWeight === 'bold'\" [innerHtml]=\"label | lxHighlightTerm : highlightTerm\"></div>\n<div\n class=\"optionDescription\"\n [style.font-style]=\"descriptionFontStyle\"\n [ngClass]=\"{ maxTextLines: descriptionStyleOptions?.maxLines }\"\n [style.-webkit-line-clamp]=\"descriptionStyleOptions?.maxLines || 'inherit'\"\n>\n {{ description }}\n</div>\n", styles: [":host{display:block;padding:2px 0}:host.hasDescription{padding:4px 0}.boldLabel{font-weight:700}.optionDescription{padding-top:2px;color:#61779d;font-size:11px}.optionDescription.maxTextLines{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:inherit;-webkit-box-orient:vertical}\n"] }]
18
+ args: [{ selector: 'lx-basic-dropdown-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div [class.boldLabel]=\"labelFontWeight === 'bold'\" [innerHtml]=\"label | lxHighlightTerm: highlightTerm\"></div>\n<div\n class=\"optionDescription\"\n [style.font-style]=\"descriptionFontStyle\"\n [ngClass]=\"{ maxTextLines: descriptionStyleOptions?.maxLines }\"\n [style.-webkit-line-clamp]=\"descriptionStyleOptions?.maxLines || 'inherit'\"\n>\n {{ description }}\n</div>\n", styles: [":host{display:block;padding:2px 0}:host.hasDescription{padding:4px 0}.boldLabel{font-weight:700}.optionDescription{padding-top:2px;color:#61779d;font-size:11px}.optionDescription.maxTextLines{overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:inherit;-webkit-box-orient:vertical}\n"] }]
19
19
  }], propDecorators: { label: [{
20
20
  type: Input
21
21
  }], description: [{
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
32
32
  type: HostBinding,
33
33
  args: ['class.hasDescription']
34
34
  }] } });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzaWMtZHJvcGRvd24taXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2Jhc2ljLWRyb3Bkb3duLWl0ZW0vYmFzaWMtZHJvcGRvd24taXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2Jhc2ljLWRyb3Bkb3duLWl0ZW0vYmFzaWMtZHJvcGRvd24taXRlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFRdkYsTUFBTSxPQUFPLDBCQUEwQjtJQU52QztRQVVXLG9CQUFlLEdBQXNCLE1BQU0sQ0FBQztRQUM1Qyx5QkFBb0IsR0FBd0IsUUFBUSxDQUFDO0tBTy9EO0lBSkMsSUFDSSxjQUFjO1FBQ2hCLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDNUIsQ0FBQzs4R0FYVSwwQkFBMEI7a0dBQTFCLDBCQUEwQixxV0NSdkMsa1lBU0E7OzJGRERhLDBCQUEwQjtrQkFOdEMsU0FBUzsrQkFDRSx3QkFBd0IsbUJBR2pCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxvQkFBb0I7c0JBQTVCLEtBQUs7Z0JBQ0csdUJBQXVCO3NCQUEvQixLQUFLO2dCQUdGLGNBQWM7c0JBRGpCLFdBQVc7dUJBQUMsc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2x4LWJhc2ljLWRyb3Bkb3duLWl0ZW0nLFxuICB0ZW1wbGF0ZVVybDogJ2Jhc2ljLWRyb3Bkb3duLWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnYmFzaWMtZHJvcGRvd24taXRlbS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBCYXNpY0Ryb3Bkb3duSXRlbUNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGxhYmVsITogc3RyaW5nO1xuICBASW5wdXQoKSBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgQElucHV0KCkgaGlnaGxpZ2h0VGVybT86IHN0cmluZztcbiAgQElucHV0KCkgbGFiZWxGb250V2VpZ2h0OiAnYm9sZCcgfCAnbm9ybWFsJyA9ICdib2xkJztcbiAgQElucHV0KCkgZGVzY3JpcHRpb25Gb250U3R5bGU6ICdpdGFsaWMnIHwgJ25vcm1hbCcgPSAnbm9ybWFsJztcbiAgQElucHV0KCkgZGVzY3JpcHRpb25TdHlsZU9wdGlvbnM/OiB7IG1heExpbmVzPzogbnVtYmVyIH07XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5oYXNEZXNjcmlwdGlvbicpXG4gIGdldCBoYXNEZXNjcmlwdGlvbigpIHtcbiAgICByZXR1cm4gISF0aGlzLmRlc2NyaXB0aW9uO1xuICB9XG59XG4iLCI8ZGl2IFtjbGFzcy5ib2xkTGFiZWxdPVwibGFiZWxGb250V2VpZ2h0ID09PSAnYm9sZCdcIiBbaW5uZXJIdG1sXT1cImxhYmVsIHwgbHhIaWdobGlnaHRUZXJtIDogaGlnaGxpZ2h0VGVybVwiPjwvZGl2PlxuPGRpdlxuICBjbGFzcz1cIm9wdGlvbkRlc2NyaXB0aW9uXCJcbiAgW3N0eWxlLmZvbnQtc3R5bGVdPVwiZGVzY3JpcHRpb25Gb250U3R5bGVcIlxuICBbbmdDbGFzc109XCJ7IG1heFRleHRMaW5lczogZGVzY3JpcHRpb25TdHlsZU9wdGlvbnM/Lm1heExpbmVzIH1cIlxuICBbc3R5bGUuLXdlYmtpdC1saW5lLWNsYW1wXT1cImRlc2NyaXB0aW9uU3R5bGVPcHRpb25zPy5tYXhMaW5lcyB8fCAnaW5oZXJpdCdcIlxuPlxuICB7eyBkZXNjcmlwdGlvbiB9fVxuPC9kaXY+XG4iXX0=
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzaWMtZHJvcGRvd24taXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2Jhc2ljLWRyb3Bkb3duLWl0ZW0vYmFzaWMtZHJvcGRvd24taXRlbS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2Jhc2ljLWRyb3Bkb3duLWl0ZW0vYmFzaWMtZHJvcGRvd24taXRlbS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFRdkYsTUFBTSxPQUFPLDBCQUEwQjtJQU52QztRQVVXLG9CQUFlLEdBQXNCLE1BQU0sQ0FBQztRQUM1Qyx5QkFBb0IsR0FBd0IsUUFBUSxDQUFDO0tBTy9EO0lBSkMsSUFDSSxjQUFjO1FBQ2hCLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUM7SUFDNUIsQ0FBQzs4R0FYVSwwQkFBMEI7a0dBQTFCLDBCQUEwQixxV0NSdkMsaVlBU0E7OzJGRERhLDBCQUEwQjtrQkFOdEMsU0FBUzsrQkFDRSx3QkFBd0IsbUJBR2pCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxvQkFBb0I7c0JBQTVCLEtBQUs7Z0JBQ0csdUJBQXVCO3NCQUEvQixLQUFLO2dCQUdGLGNBQWM7c0JBRGpCLFdBQVc7dUJBQUMsc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2x4LWJhc2ljLWRyb3Bkb3duLWl0ZW0nLFxuICB0ZW1wbGF0ZVVybDogJ2Jhc2ljLWRyb3Bkb3duLWl0ZW0uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnYmFzaWMtZHJvcGRvd24taXRlbS5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBCYXNpY0Ryb3Bkb3duSXRlbUNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGxhYmVsITogc3RyaW5nO1xuICBASW5wdXQoKSBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgQElucHV0KCkgaGlnaGxpZ2h0VGVybT86IHN0cmluZztcbiAgQElucHV0KCkgbGFiZWxGb250V2VpZ2h0OiAnYm9sZCcgfCAnbm9ybWFsJyA9ICdib2xkJztcbiAgQElucHV0KCkgZGVzY3JpcHRpb25Gb250U3R5bGU6ICdpdGFsaWMnIHwgJ25vcm1hbCcgPSAnbm9ybWFsJztcbiAgQElucHV0KCkgZGVzY3JpcHRpb25TdHlsZU9wdGlvbnM/OiB7IG1heExpbmVzPzogbnVtYmVyIH07XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5oYXNEZXNjcmlwdGlvbicpXG4gIGdldCBoYXNEZXNjcmlwdGlvbigpIHtcbiAgICByZXR1cm4gISF0aGlzLmRlc2NyaXB0aW9uO1xuICB9XG59XG4iLCI8ZGl2IFtjbGFzcy5ib2xkTGFiZWxdPVwibGFiZWxGb250V2VpZ2h0ID09PSAnYm9sZCdcIiBbaW5uZXJIdG1sXT1cImxhYmVsIHwgbHhIaWdobGlnaHRUZXJtOiBoaWdobGlnaHRUZXJtXCI+PC9kaXY+XG48ZGl2XG4gIGNsYXNzPVwib3B0aW9uRGVzY3JpcHRpb25cIlxuICBbc3R5bGUuZm9udC1zdHlsZV09XCJkZXNjcmlwdGlvbkZvbnRTdHlsZVwiXG4gIFtuZ0NsYXNzXT1cInsgbWF4VGV4dExpbmVzOiBkZXNjcmlwdGlvblN0eWxlT3B0aW9ucz8ubWF4TGluZXMgfVwiXG4gIFtzdHlsZS4td2Via2l0LWxpbmUtY2xhbXBdPVwiZGVzY3JpcHRpb25TdHlsZU9wdGlvbnM/Lm1heExpbmVzIHx8ICdpbmhlcml0J1wiXG4+XG4gIHt7IGRlc2NyaXB0aW9uIH19XG48L2Rpdj5cbiJdfQ==
@@ -36,12 +36,12 @@ export class BreadcrumbComponent {
36
36
  return !!breadcrumb.breadcrumbs;
37
37
  }
38
38
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: BreadcrumbComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
39
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: BreadcrumbComponent, selector: "lx-breadcrumb", inputs: { breadcrumbs: "breadcrumbs" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"breadcrumbs\">\n <ng-container *ngFor=\"let breadcrumb of viewBreadcrumbs\">\n <ng-container *ngIf=\"isEllipsedBreadcrumb(breadcrumb)\">\n <lx-cdk-options-dropdown [align]=\"'right'\" class=\"dropdownContainer\">\n <a class=\"step\" href=\"\" lxKeyboardActionSource (click)=\"(false)\">...</a>\n <lx-option\n *ngFor=\"let ellipsedBreadcrumbs of breadcrumb.breadcrumbs\"\n [hasSelectedState]=\"false\"\n (select)=\"ellipsedBreadcrumbs.onClick?.(ellipsedBreadcrumbs)\"\n >\n {{ ellipsedBreadcrumbs.label }}\n </lx-option>\n </lx-cdk-options-dropdown>\n <span class=\"arrow\">&gt;</span>\n </ng-container>\n <ng-container *ngIf=\"!isEllipsedBreadcrumb(breadcrumb)\">\n <a class=\"step\" href=\"\" (click)=\"breadcrumb.onClick?.(breadcrumb); false\">{{ breadcrumb.label }}</a>\n <span class=\"arrow\">&gt;</span>\n </ng-container>\n </ng-container>\n</div>\n", styles: [".breadcrumbs{line-height:20px;font-weight:500}.breadcrumbs .step{color:var(--01-ui-colors-dark-gray);cursor:pointer}.breadcrumbs .arrow{margin:0 12px;color:var(--01-ui-colors-dark-gray)}.breadcrumbs .arrow:last-child{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.KeyboardActionSourceDirective, selector: "[lxKeyboardActionSource]", exportAs: ["keyboardActionSource"] }, { kind: "component", type: i3.OptionComponent, selector: "lx-option", inputs: ["selected", "isHighlighted", "disabled", "value", "hasSelectedState", "selectIcon"], outputs: ["select", "highlight", "selectedClick"] }, { kind: "component", type: i4.CdkOptionsDropdownComponent, selector: "lx-cdk-options-dropdown", inputs: ["align", "closeOnScroll", "disabled", "maxHeight"] }] }); }
39
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: BreadcrumbComponent, selector: "lx-breadcrumb", inputs: { breadcrumbs: "breadcrumbs" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"breadcrumbs\">\n <ng-container *ngFor=\"let breadcrumb of viewBreadcrumbs\">\n <ng-container *ngIf=\"isEllipsedBreadcrumb(breadcrumb)\">\n <lx-cdk-options-dropdown [align]=\"'right'\" class=\"dropdownContainer\">\n <a class=\"step\" href=\"\" lxKeyboardActionSource (click)=\"(false)\">...</a>\n <lx-option\n *ngFor=\"let ellipsedBreadcrumbs of breadcrumb.breadcrumbs\"\n [hasSelectedState]=\"false\"\n (select)=\"ellipsedBreadcrumbs.onClick?.(ellipsedBreadcrumbs)\"\n >\n {{ ellipsedBreadcrumbs.label }}\n </lx-option>\n </lx-cdk-options-dropdown>\n <span class=\"arrow\">&gt;</span>\n </ng-container>\n <ng-container *ngIf=\"!isEllipsedBreadcrumb(breadcrumb)\">\n <a class=\"step\" href=\"\" (click)=\"breadcrumb.onClick?.(breadcrumb); (false)\">{{ breadcrumb.label }}</a>\n <span class=\"arrow\">&gt;</span>\n </ng-container>\n </ng-container>\n</div>\n", styles: [".breadcrumbs{line-height:20px;font-weight:500}.breadcrumbs .step{color:var(--01-ui-colors-dark-gray);cursor:pointer}.breadcrumbs .arrow{margin:0 12px;color:var(--01-ui-colors-dark-gray)}.breadcrumbs .arrow:last-child{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.KeyboardActionSourceDirective, selector: "[lxKeyboardActionSource]", exportAs: ["keyboardActionSource"] }, { kind: "component", type: i3.OptionComponent, selector: "lx-option", inputs: ["selected", "isHighlighted", "disabled", "value", "hasSelectedState", "selectIcon"], outputs: ["select", "highlight", "selectedClick"] }, { kind: "component", type: i4.CdkOptionsDropdownComponent, selector: "lx-cdk-options-dropdown", inputs: ["align", "closeOnScroll", "disabled", "maxHeight"] }] }); }
40
40
  }
41
41
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: BreadcrumbComponent, decorators: [{
42
42
  type: Component,
43
- args: [{ selector: 'lx-breadcrumb', template: "<div class=\"breadcrumbs\">\n <ng-container *ngFor=\"let breadcrumb of viewBreadcrumbs\">\n <ng-container *ngIf=\"isEllipsedBreadcrumb(breadcrumb)\">\n <lx-cdk-options-dropdown [align]=\"'right'\" class=\"dropdownContainer\">\n <a class=\"step\" href=\"\" lxKeyboardActionSource (click)=\"(false)\">...</a>\n <lx-option\n *ngFor=\"let ellipsedBreadcrumbs of breadcrumb.breadcrumbs\"\n [hasSelectedState]=\"false\"\n (select)=\"ellipsedBreadcrumbs.onClick?.(ellipsedBreadcrumbs)\"\n >\n {{ ellipsedBreadcrumbs.label }}\n </lx-option>\n </lx-cdk-options-dropdown>\n <span class=\"arrow\">&gt;</span>\n </ng-container>\n <ng-container *ngIf=\"!isEllipsedBreadcrumb(breadcrumb)\">\n <a class=\"step\" href=\"\" (click)=\"breadcrumb.onClick?.(breadcrumb); false\">{{ breadcrumb.label }}</a>\n <span class=\"arrow\">&gt;</span>\n </ng-container>\n </ng-container>\n</div>\n", styles: [".breadcrumbs{line-height:20px;font-weight:500}.breadcrumbs .step{color:var(--01-ui-colors-dark-gray);cursor:pointer}.breadcrumbs .arrow{margin:0 12px;color:var(--01-ui-colors-dark-gray)}.breadcrumbs .arrow:last-child{display:none}\n"] }]
43
+ args: [{ selector: 'lx-breadcrumb', template: "<div class=\"breadcrumbs\">\n <ng-container *ngFor=\"let breadcrumb of viewBreadcrumbs\">\n <ng-container *ngIf=\"isEllipsedBreadcrumb(breadcrumb)\">\n <lx-cdk-options-dropdown [align]=\"'right'\" class=\"dropdownContainer\">\n <a class=\"step\" href=\"\" lxKeyboardActionSource (click)=\"(false)\">...</a>\n <lx-option\n *ngFor=\"let ellipsedBreadcrumbs of breadcrumb.breadcrumbs\"\n [hasSelectedState]=\"false\"\n (select)=\"ellipsedBreadcrumbs.onClick?.(ellipsedBreadcrumbs)\"\n >\n {{ ellipsedBreadcrumbs.label }}\n </lx-option>\n </lx-cdk-options-dropdown>\n <span class=\"arrow\">&gt;</span>\n </ng-container>\n <ng-container *ngIf=\"!isEllipsedBreadcrumb(breadcrumb)\">\n <a class=\"step\" href=\"\" (click)=\"breadcrumb.onClick?.(breadcrumb); (false)\">{{ breadcrumb.label }}</a>\n <span class=\"arrow\">&gt;</span>\n </ng-container>\n </ng-container>\n</div>\n", styles: [".breadcrumbs{line-height:20px;font-weight:500}.breadcrumbs .step{color:var(--01-ui-colors-dark-gray);cursor:pointer}.breadcrumbs .arrow{margin:0 12px;color:var(--01-ui-colors-dark-gray)}.breadcrumbs .arrow:last-child{display:none}\n"] }]
44
44
  }], propDecorators: { breadcrumbs: [{
45
45
  type: Input
46
46
  }] } });
47
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2JyZWFkY3J1bWIvYnJlYWRjcnVtYi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2JyZWFkY3J1bWIvYnJlYWRjcnVtYi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBNEIsTUFBTSxlQUFlLENBQUM7Ozs7OztBQW1CM0UsTUFBTSxPQUFPLG1CQUFtQjtJQUxoQztRQU1XLGdCQUFXLEdBQWlCLEVBQUUsQ0FBQztRQUV4QyxvQkFBZSxHQUFxQixFQUFFLENBQUM7S0EyQnhDO0lBekJDLFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxhQUFhLENBQUMsRUFBRTtZQUMxQixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUMsZUFBZSxFQUFFLFVBQVUsRUFBRSxFQUFFO2dCQUM3RSxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRTtvQkFDeEIsZ0VBQWdFO29CQUNoRSxlQUFlLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2lCQUNsQztxQkFBTTtvQkFDTCxvRkFBb0Y7b0JBQ3BGLE1BQU0sY0FBYyxHQUFHLGVBQWUsQ0FBQyxlQUFlLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO29CQUNuRSxJQUFJLGNBQWMsSUFBSSxJQUFJLENBQUMsb0JBQW9CLENBQUMsY0FBYyxDQUFDLEVBQUU7d0JBQy9ELGNBQWMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO3FCQUM3Qzt5QkFBTTt3QkFDTCxlQUFlLENBQUMsSUFBSSxDQUFDOzRCQUNuQixXQUFXLEVBQUUsQ0FBQyxVQUFVLENBQUM7eUJBQzFCLENBQUMsQ0FBQztxQkFDSjtpQkFDRjtnQkFDRCxPQUFPLGVBQWUsQ0FBQztZQUN6QixDQUFDLEVBQUUsRUFBc0IsQ0FBQyxDQUFDO1NBQzVCO0lBQ0gsQ0FBQztJQUVELG9CQUFvQixDQUFDLFVBQTBCO1FBQzdDLE9BQU8sQ0FBQyxDQUFFLFVBQWlDLENBQUMsV0FBVyxDQUFDO0lBQzFELENBQUM7OEdBN0JVLG1CQUFtQjtrR0FBbkIsbUJBQW1CLGtIQ25CaEMsNDhCQXFCQTs7MkZERmEsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNFLGVBQWU7OEJBS2hCLFdBQVc7c0JBQW5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBCcmVhZGNydW1iIHtcbiAgbGFiZWw6IHN0cmluZztcbiAgZWxsaXBzZWQ/OiBib29sZWFuO1xuICBvbkNsaWNrPzogKGJyZWFkY3J1bWI6IEJyZWFkY3J1bWIpID0+IHZvaWQ7XG59XG5cbmludGVyZmFjZSBFbGxpcHNlZEJyZWFkY3J1bWIge1xuICBicmVhZGNydW1iczogQnJlYWRjcnVtYltdO1xufVxuXG50eXBlIFZpZXdCcmVhZGNydW1iID0gQnJlYWRjcnVtYiB8IEVsbGlwc2VkQnJlYWRjcnVtYjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtYnJlYWRjcnVtYicsXG4gIHRlbXBsYXRlVXJsOiAnLi9icmVhZGNydW1iLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYnJlYWRjcnVtYi5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEJyZWFkY3J1bWJDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICBASW5wdXQoKSBicmVhZGNydW1iczogQnJlYWRjcnVtYltdID0gW107XG5cbiAgdmlld0JyZWFkY3J1bWJzOiBWaWV3QnJlYWRjcnVtYltdID0gW107XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xuICAgIGlmIChjaGFuZ2VzWydicmVhZGNydW1icyddKSB7XG4gICAgICB0aGlzLnZpZXdCcmVhZGNydW1icyA9IHRoaXMuYnJlYWRjcnVtYnMucmVkdWNlKCh2aWV3QnJlYWRjcnVtYnMsIGJyZWFkY3J1bWIpID0+IHtcbiAgICAgICAgaWYgKCFicmVhZGNydW1iLmVsbGlwc2VkKSB7XG4gICAgICAgICAgLy8gQXBwZW5kIG5vcm1hbCBicmVhZGNydW1icyB0byB0aGUgZW5kIG9mIHZpZXcgYnJlYWRjcnVtYiBhcnJheVxuICAgICAgICAgIHZpZXdCcmVhZGNydW1icy5wdXNoKGJyZWFkY3J1bWIpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIC8vIFJlZHVjZSBjb25zZWN1dGl2ZSBlbGxpcHNlZCBicmVhZGNydW1icyBpbnRvIG9uZSBlbnRyeSBhbmQgc2hvdyBkcm9wZG93biBvZiB0aGVzZVxuICAgICAgICAgIGNvbnN0IGxhc3RCcmVhZGNydW1iID0gdmlld0JyZWFkY3J1bWJzW3ZpZXdCcmVhZGNydW1icy5sZW5ndGggLSAxXTtcbiAgICAgICAgICBpZiAobGFzdEJyZWFkY3J1bWIgJiYgdGhpcy5pc0VsbGlwc2VkQnJlYWRjcnVtYihsYXN0QnJlYWRjcnVtYikpIHtcbiAgICAgICAgICAgIGxhc3RCcmVhZGNydW1iLmJyZWFkY3J1bWJzLnB1c2goYnJlYWRjcnVtYik7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHZpZXdCcmVhZGNydW1icy5wdXNoKHtcbiAgICAgICAgICAgICAgYnJlYWRjcnVtYnM6IFticmVhZGNydW1iXVxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiB2aWV3QnJlYWRjcnVtYnM7XG4gICAgICB9LCBbXSBhcyBWaWV3QnJlYWRjcnVtYltdKTtcbiAgICB9XG4gIH1cblxuICBpc0VsbGlwc2VkQnJlYWRjcnVtYihicmVhZGNydW1iOiBWaWV3QnJlYWRjcnVtYik6IGJyZWFkY3J1bWIgaXMgRWxsaXBzZWRCcmVhZGNydW1iIHtcbiAgICByZXR1cm4gISEoYnJlYWRjcnVtYiBhcyBFbGxpcHNlZEJyZWFkY3J1bWIpLmJyZWFkY3J1bWJzO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiYnJlYWRjcnVtYnNcIj5cbiAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgYnJlYWRjcnVtYiBvZiB2aWV3QnJlYWRjcnVtYnNcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiaXNFbGxpcHNlZEJyZWFkY3J1bWIoYnJlYWRjcnVtYilcIj5cbiAgICAgIDxseC1jZGstb3B0aW9ucy1kcm9wZG93biBbYWxpZ25dPVwiJ3JpZ2h0J1wiIGNsYXNzPVwiZHJvcGRvd25Db250YWluZXJcIj5cbiAgICAgICAgPGEgY2xhc3M9XCJzdGVwXCIgaHJlZj1cIlwiIGx4S2V5Ym9hcmRBY3Rpb25Tb3VyY2UgKGNsaWNrKT1cIihmYWxzZSlcIj4uLi48L2E+XG4gICAgICAgIDxseC1vcHRpb25cbiAgICAgICAgICAqbmdGb3I9XCJsZXQgZWxsaXBzZWRCcmVhZGNydW1icyBvZiBicmVhZGNydW1iLmJyZWFkY3J1bWJzXCJcbiAgICAgICAgICBbaGFzU2VsZWN0ZWRTdGF0ZV09XCJmYWxzZVwiXG4gICAgICAgICAgKHNlbGVjdCk9XCJlbGxpcHNlZEJyZWFkY3J1bWJzLm9uQ2xpY2s/LihlbGxpcHNlZEJyZWFkY3J1bWJzKVwiXG4gICAgICAgID5cbiAgICAgICAgICB7eyBlbGxpcHNlZEJyZWFkY3J1bWJzLmxhYmVsIH19XG4gICAgICAgIDwvbHgtb3B0aW9uPlxuICAgICAgPC9seC1jZGstb3B0aW9ucy1kcm9wZG93bj5cbiAgICAgIDxzcGFuIGNsYXNzPVwiYXJyb3dcIj4mZ3Q7PC9zcGFuPlxuICAgIDwvbmctY29udGFpbmVyPlxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIhaXNFbGxpcHNlZEJyZWFkY3J1bWIoYnJlYWRjcnVtYilcIj5cbiAgICAgIDxhIGNsYXNzPVwic3RlcFwiIGhyZWY9XCJcIiAoY2xpY2spPVwiYnJlYWRjcnVtYi5vbkNsaWNrPy4oYnJlYWRjcnVtYik7IGZhbHNlXCI+e3sgYnJlYWRjcnVtYi5sYWJlbCB9fTwvYT5cbiAgICAgIDxzcGFuIGNsYXNzPVwiYXJyb3dcIj4mZ3Q7PC9zcGFuPlxuICAgIDwvbmctY29udGFpbmVyPlxuICA8L25nLWNvbnRhaW5lcj5cbjwvZGl2PlxuIl19
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2JyZWFkY3J1bWIvYnJlYWRjcnVtYi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9jb21wb25lbnRzL2JyZWFkY3J1bWIvYnJlYWRjcnVtYi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBNEIsTUFBTSxlQUFlLENBQUM7Ozs7OztBQW1CM0UsTUFBTSxPQUFPLG1CQUFtQjtJQUxoQztRQU1XLGdCQUFXLEdBQWlCLEVBQUUsQ0FBQztRQUV4QyxvQkFBZSxHQUFxQixFQUFFLENBQUM7S0EyQnhDO0lBekJDLFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxhQUFhLENBQUMsRUFBRTtZQUMxQixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUMsZUFBZSxFQUFFLFVBQVUsRUFBRSxFQUFFO2dCQUM3RSxJQUFJLENBQUMsVUFBVSxDQUFDLFFBQVEsRUFBRTtvQkFDeEIsZ0VBQWdFO29CQUNoRSxlQUFlLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2lCQUNsQztxQkFBTTtvQkFDTCxvRkFBb0Y7b0JBQ3BGLE1BQU0sY0FBYyxHQUFHLGVBQWUsQ0FBQyxlQUFlLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO29CQUNuRSxJQUFJLGNBQWMsSUFBSSxJQUFJLENBQUMsb0JBQW9CLENBQUMsY0FBYyxDQUFDLEVBQUU7d0JBQy9ELGNBQWMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO3FCQUM3Qzt5QkFBTTt3QkFDTCxlQUFlLENBQUMsSUFBSSxDQUFDOzRCQUNuQixXQUFXLEVBQUUsQ0FBQyxVQUFVLENBQUM7eUJBQzFCLENBQUMsQ0FBQztxQkFDSjtpQkFDRjtnQkFDRCxPQUFPLGVBQWUsQ0FBQztZQUN6QixDQUFDLEVBQUUsRUFBc0IsQ0FBQyxDQUFDO1NBQzVCO0lBQ0gsQ0FBQztJQUVELG9CQUFvQixDQUFDLFVBQTBCO1FBQzdDLE9BQU8sQ0FBQyxDQUFFLFVBQWlDLENBQUMsV0FBVyxDQUFDO0lBQzFELENBQUM7OEdBN0JVLG1CQUFtQjtrR0FBbkIsbUJBQW1CLGtIQ25CaEMsODhCQXFCQTs7MkZERmEsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNFLGVBQWU7OEJBS2hCLFdBQVc7c0JBQW5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBCcmVhZGNydW1iIHtcbiAgbGFiZWw6IHN0cmluZztcbiAgZWxsaXBzZWQ/OiBib29sZWFuO1xuICBvbkNsaWNrPzogKGJyZWFkY3J1bWI6IEJyZWFkY3J1bWIpID0+IHZvaWQ7XG59XG5cbmludGVyZmFjZSBFbGxpcHNlZEJyZWFkY3J1bWIge1xuICBicmVhZGNydW1iczogQnJlYWRjcnVtYltdO1xufVxuXG50eXBlIFZpZXdCcmVhZGNydW1iID0gQnJlYWRjcnVtYiB8IEVsbGlwc2VkQnJlYWRjcnVtYjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbHgtYnJlYWRjcnVtYicsXG4gIHRlbXBsYXRlVXJsOiAnLi9icmVhZGNydW1iLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYnJlYWRjcnVtYi5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEJyZWFkY3J1bWJDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICBASW5wdXQoKSBicmVhZGNydW1iczogQnJlYWRjcnVtYltdID0gW107XG5cbiAgdmlld0JyZWFkY3J1bWJzOiBWaWV3QnJlYWRjcnVtYltdID0gW107XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xuICAgIGlmIChjaGFuZ2VzWydicmVhZGNydW1icyddKSB7XG4gICAgICB0aGlzLnZpZXdCcmVhZGNydW1icyA9IHRoaXMuYnJlYWRjcnVtYnMucmVkdWNlKCh2aWV3QnJlYWRjcnVtYnMsIGJyZWFkY3J1bWIpID0+IHtcbiAgICAgICAgaWYgKCFicmVhZGNydW1iLmVsbGlwc2VkKSB7XG4gICAgICAgICAgLy8gQXBwZW5kIG5vcm1hbCBicmVhZGNydW1icyB0byB0aGUgZW5kIG9mIHZpZXcgYnJlYWRjcnVtYiBhcnJheVxuICAgICAgICAgIHZpZXdCcmVhZGNydW1icy5wdXNoKGJyZWFkY3J1bWIpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIC8vIFJlZHVjZSBjb25zZWN1dGl2ZSBlbGxpcHNlZCBicmVhZGNydW1icyBpbnRvIG9uZSBlbnRyeSBhbmQgc2hvdyBkcm9wZG93biBvZiB0aGVzZVxuICAgICAgICAgIGNvbnN0IGxhc3RCcmVhZGNydW1iID0gdmlld0JyZWFkY3J1bWJzW3ZpZXdCcmVhZGNydW1icy5sZW5ndGggLSAxXTtcbiAgICAgICAgICBpZiAobGFzdEJyZWFkY3J1bWIgJiYgdGhpcy5pc0VsbGlwc2VkQnJlYWRjcnVtYihsYXN0QnJlYWRjcnVtYikpIHtcbiAgICAgICAgICAgIGxhc3RCcmVhZGNydW1iLmJyZWFkY3J1bWJzLnB1c2goYnJlYWRjcnVtYik7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHZpZXdCcmVhZGNydW1icy5wdXNoKHtcbiAgICAgICAgICAgICAgYnJlYWRjcnVtYnM6IFticmVhZGNydW1iXVxuICAgICAgICAgICAgfSk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiB2aWV3QnJlYWRjcnVtYnM7XG4gICAgICB9LCBbXSBhcyBWaWV3QnJlYWRjcnVtYltdKTtcbiAgICB9XG4gIH1cblxuICBpc0VsbGlwc2VkQnJlYWRjcnVtYihicmVhZGNydW1iOiBWaWV3QnJlYWRjcnVtYik6IGJyZWFkY3J1bWIgaXMgRWxsaXBzZWRCcmVhZGNydW1iIHtcbiAgICByZXR1cm4gISEoYnJlYWRjcnVtYiBhcyBFbGxpcHNlZEJyZWFkY3J1bWIpLmJyZWFkY3J1bWJzO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiYnJlYWRjcnVtYnNcIj5cbiAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgYnJlYWRjcnVtYiBvZiB2aWV3QnJlYWRjcnVtYnNcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiaXNFbGxpcHNlZEJyZWFkY3J1bWIoYnJlYWRjcnVtYilcIj5cbiAgICAgIDxseC1jZGstb3B0aW9ucy1kcm9wZG93biBbYWxpZ25dPVwiJ3JpZ2h0J1wiIGNsYXNzPVwiZHJvcGRvd25Db250YWluZXJcIj5cbiAgICAgICAgPGEgY2xhc3M9XCJzdGVwXCIgaHJlZj1cIlwiIGx4S2V5Ym9hcmRBY3Rpb25Tb3VyY2UgKGNsaWNrKT1cIihmYWxzZSlcIj4uLi48L2E+XG4gICAgICAgIDxseC1vcHRpb25cbiAgICAgICAgICAqbmdGb3I9XCJsZXQgZWxsaXBzZWRCcmVhZGNydW1icyBvZiBicmVhZGNydW1iLmJyZWFkY3J1bWJzXCJcbiAgICAgICAgICBbaGFzU2VsZWN0ZWRTdGF0ZV09XCJmYWxzZVwiXG4gICAgICAgICAgKHNlbGVjdCk9XCJlbGxpcHNlZEJyZWFkY3J1bWJzLm9uQ2xpY2s/LihlbGxpcHNlZEJyZWFkY3J1bWJzKVwiXG4gICAgICAgID5cbiAgICAgICAgICB7eyBlbGxpcHNlZEJyZWFkY3J1bWJzLmxhYmVsIH19XG4gICAgICAgIDwvbHgtb3B0aW9uPlxuICAgICAgPC9seC1jZGstb3B0aW9ucy1kcm9wZG93bj5cbiAgICAgIDxzcGFuIGNsYXNzPVwiYXJyb3dcIj4mZ3Q7PC9zcGFuPlxuICAgIDwvbmctY29udGFpbmVyPlxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCIhaXNFbGxpcHNlZEJyZWFkY3J1bWIoYnJlYWRjcnVtYilcIj5cbiAgICAgIDxhIGNsYXNzPVwic3RlcFwiIGhyZWY9XCJcIiAoY2xpY2spPVwiYnJlYWRjcnVtYi5vbkNsaWNrPy4oYnJlYWRjcnVtYik7IChmYWxzZSlcIj57eyBicmVhZGNydW1iLmxhYmVsIH19PC9hPlxuICAgICAgPHNwYW4gY2xhc3M9XCJhcnJvd1wiPiZndDs8L3NwYW4+XG4gICAgPC9uZy1jb250YWluZXI+XG4gIDwvbmctY29udGFpbmVyPlxuPC9kaXY+XG4iXX0=
@@ -100,7 +100,7 @@ export class CurrencyInputComponent {
100
100
  useExisting: forwardRef(() => CurrencyInputComponent),
101
101
  multi: true
102
102
  }
103
- ], viewQueries: [{ propertyName: "currencyInput", first: true, predicate: ["currencyInput"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n <input\n [attr.disabled]=\"disabled ? true : null\"\n *ngIf=\"!showCurrencyInput\"\n type=\"text\"\n class=\"form-control currencyDisplayValue\"\n placeholder=\"{{ placeholder }}\"\n [lxMarkInvalid]=\"markInvalid\"\n [value]=\"dataValue$ | async | number : format\"\n (focus)=\"focusCurrencyInput()\"\n />\n <input\n autocomplete=\"off\"\n [attr.disabled]=\"disabled ? true : null\"\n [class.hideInput]=\"!showCurrencyInput\"\n type=\"text\"\n inputmode=\"numeric\"\n class=\"form-control currencyInput\"\n name=\"inputAmount\"\n #currencyInput\n placeholder=\"{{ placeholder }}\"\n [ngModel]=\"dataValue$ | async\"\n (blur)=\"onBlur()\"\n (ngModelChange)=\"valueChanged($event)\"\n />\n <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n {{ (dataValue$ | async | number : format) || placeholder }}\n <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n", styles: [".container{width:100%!important;padding:0}.labelContainer{width:5%!important;min-width:40px}input{width:100%}.hideInput{display:none}.placeholder{color:#99a5bb}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.CurrencySymbolComponent, selector: "lx-currency-symbol", inputs: ["code"] }, { kind: "directive", type: i4.MarkInvalidDirective, selector: "[lxMarkInvalid]", inputs: ["lxMarkInvalid"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.DecimalPipe, name: "number" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
103
+ ], viewQueries: [{ propertyName: "currencyInput", first: true, predicate: ["currencyInput"], descendants: true }], ngImport: i0, template: "<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n <input\n [attr.disabled]=\"disabled ? true : null\"\n *ngIf=\"!showCurrencyInput\"\n type=\"text\"\n class=\"form-control currencyDisplayValue\"\n placeholder=\"{{ placeholder }}\"\n [lxMarkInvalid]=\"markInvalid\"\n [value]=\"dataValue$ | async | number: format\"\n (focus)=\"focusCurrencyInput()\"\n />\n <input\n autocomplete=\"off\"\n [attr.disabled]=\"disabled ? true : null\"\n [class.hideInput]=\"!showCurrencyInput\"\n type=\"text\"\n inputmode=\"numeric\"\n class=\"form-control currencyInput\"\n name=\"inputAmount\"\n #currencyInput\n placeholder=\"{{ placeholder }}\"\n [ngModel]=\"dataValue$ | async\"\n (blur)=\"onBlur()\"\n (ngModelChange)=\"valueChanged($event)\"\n />\n <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n {{ (dataValue$ | async | number: format) || placeholder }}\n <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n", styles: [".container{width:100%!important;padding:0}.labelContainer{width:5%!important;min-width:40px}input{width:100%}.hideInput{display:none}.placeholder{color:#99a5bb}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.CurrencySymbolComponent, selector: "lx-currency-symbol", inputs: ["code"] }, { kind: "directive", type: i4.MarkInvalidDirective, selector: "[lxMarkInvalid]", inputs: ["lxMarkInvalid"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.DecimalPipe, name: "number" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
104
104
  }
105
105
  __decorate([
106
106
  Observe('data')
@@ -113,7 +113,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
113
113
  useExisting: forwardRef(() => CurrencyInputComponent),
114
114
  multi: true
115
115
  }
116
- ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n <input\n [attr.disabled]=\"disabled ? true : null\"\n *ngIf=\"!showCurrencyInput\"\n type=\"text\"\n class=\"form-control currencyDisplayValue\"\n placeholder=\"{{ placeholder }}\"\n [lxMarkInvalid]=\"markInvalid\"\n [value]=\"dataValue$ | async | number : format\"\n (focus)=\"focusCurrencyInput()\"\n />\n <input\n autocomplete=\"off\"\n [attr.disabled]=\"disabled ? true : null\"\n [class.hideInput]=\"!showCurrencyInput\"\n type=\"text\"\n inputmode=\"numeric\"\n class=\"form-control currencyInput\"\n name=\"inputAmount\"\n #currencyInput\n placeholder=\"{{ placeholder }}\"\n [ngModel]=\"dataValue$ | async\"\n (blur)=\"onBlur()\"\n (ngModelChange)=\"valueChanged($event)\"\n />\n <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n {{ (dataValue$ | async | number : format) || placeholder }}\n <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n", styles: [".container{width:100%!important;padding:0}.labelContainer{width:5%!important;min-width:40px}input{width:100%}.hideInput{display:none}.placeholder{color:#99a5bb}\n"] }]
116
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n <input\n [attr.disabled]=\"disabled ? true : null\"\n *ngIf=\"!showCurrencyInput\"\n type=\"text\"\n class=\"form-control currencyDisplayValue\"\n placeholder=\"{{ placeholder }}\"\n [lxMarkInvalid]=\"markInvalid\"\n [value]=\"dataValue$ | async | number: format\"\n (focus)=\"focusCurrencyInput()\"\n />\n <input\n autocomplete=\"off\"\n [attr.disabled]=\"disabled ? true : null\"\n [class.hideInput]=\"!showCurrencyInput\"\n type=\"text\"\n inputmode=\"numeric\"\n class=\"form-control currencyInput\"\n name=\"inputAmount\"\n #currencyInput\n placeholder=\"{{ placeholder }}\"\n [ngModel]=\"dataValue$ | async\"\n (blur)=\"onBlur()\"\n (ngModelChange)=\"valueChanged($event)\"\n />\n <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n {{ (dataValue$ | async | number: format) || placeholder }}\n <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n", styles: [".container{width:100%!important;padding:0}.labelContainer{width:5%!important;min-width:40px}input{width:100%}.hideInput{display:none}.placeholder{color:#99a5bb}\n"] }]
117
117
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { code: [{
118
118
  type: Input
119
119
  }], decimalSeparator: [{
@@ -142,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImpor
142
142
  type: ViewChild,
143
143
  args: ['currencyInput']
144
144
  }] } });
145
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.html"],"names":[],"mappings":";AAAA,OAAO,EAEL,uBAAuB,EAEvB,SAAS,EAET,YAAY,EACZ,UAAU,EACV,KAAK,EAGL,MAAM,EACN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,SAAS,EAAc,aAAa,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACrE,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;;;;;;AAoBlD,MAAM,OAAO,sBAAsB;IAqBjC,IAAY,iBAAiB;QAC3B,OAAO,IAAI,CAAC,mBAAmB,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,WAAW,IAAI,CAAC,gBAAgB,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;IAChH,CAAC;IAID,YAAoB,cAAiC;QAAjC,mBAAc,GAAd,cAAc,CAAmB;QAzBrC,qBAAgB,GAAqB,GAAG,CAAC;QAEzC,SAAI,GAAW,CAAC,CAAC;QAGjB,aAAQ,GAAY,KAAK,CAAC;QAC1B,SAAI,GAAsB,MAAM,CAAC;QAEjC,iBAAY,GAAyB,OAAO,CAAC;QAC7C,WAAM,GAAW,OAAO,CAAC;QAChC,gBAAW,GAAG,KAAK,CAAC;QAEZ,gBAAW,GAAG,IAAI,YAAY,EAAW,CAAC;QAC1C,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QAGvD,sBAAiB,GAAY,KAAK,CAAC;QACnC,eAAU,GAAG,IAAI,aAAa,EAAU,CAAC;QAMhC,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;IAEc,CAAC;IAEzD,QAAQ;QACN,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACzE,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,SAAS,CAAgB,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,UAAU,CAAC;iBACnE,IAAI,CACH,MAAM,CAAC,CAAC,aAAa,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC,EAC9D,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC3B;iBACA,SAAS,CAAC,CAAC,aAAa,EAAE,EAAE;gBAC3B,aAAa,CAAC,cAAc,EAAE,CAAC;YACjC,CAAC,CAAC,CAAC;SACN;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,YAAY,CAAC,KAAsB;QACjC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,MAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;YACnE,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,gBAAgB,CAAW,CAAC;SAC5D;QACD,2DAA2D;QAC3D,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;QACpC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QACzC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC3D,CAAC;IAED,eAAe,CAAC,KAAoB;QAClC,IAAI,IAAI,CAAC,mBAAmB,KAAK,QAAQ,IAAI,KAAK,CAAC,GAAG,KAAK,IAAI,CAAC,gBAAgB,EAAE;YAChF,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;SACxE;QACD,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACjD,CAAC;IAED,eAAe,CAAC,SAAiB,IAAG,CAAC;IAErC,UAAU,CAAC,QAAgB;QACzB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACjC,CAAC;IACD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;IAED,iBAAiB,CAAC,GAAQ,IAAG,CAAC;IAE9B,gBAAgB,CAAC,QAAiB;QAChC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAEO,UAAU,CAAC,KAAa,EAAE,IAAY;QAC5C,MAAM,eAAe,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;QACrD,IAAI,eAAe,GAAG,CAAC,EAAE;YACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,eAAe,EAAE,CAAC,EAAE,EAAE;gBACxC,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;aACjC;SACF;QACD,MAAM,WAAW,GAAG,UAAU,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;QAC1E,OAAO,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC;IACjD,CAAC;IAEO,kBAAkB,CAAC,KAAa;QACtC,OAAO,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5D,CAAC;8GA5GU,sBAAsB;kGAAtB,sBAAsB,iXATtB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;gBACrD,KAAK,EAAE,IAAI;aACZ;SACF,0IClCH,gnDAsCA;;ADI2B;IAAxB,OAAO,CAAS,MAAM,CAAC;qDAA4B;2FALzC,sBAAsB;kBAblC,SAAS;+BACE,mBAAmB,aAGlB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACZ;qBACF,mBACgB,uBAAuB,CAAC,MAAM;sFAG/B,IAAI;sBAAnB,KAAK;gBACU,gBAAgB;sBAA/B,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACmB,KAAK,MAEd,QAAQ;sBAAvB,KAAK;gBACU,IAAI;sBAAnB,KAAK;gBACU,mBAAmB;sBAAlC,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,MAAM;sBAArB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAEW,WAAW;sBAA3B,MAAM;gBACU,QAAQ;sBAAxB,MAAM;gBAE6B,aAAa;sBAAhD,SAAS;uBAAC,eAAe","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { fromEvent, Observable, ReplaySubject, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { Observe } from '../../../shared/observe';\n\nexport type CurrencyInputMode = 'view' | 'edit';\nexport type CurrencyIconPosition = 'first' | 'end' | 'none';\n\nexport type DecimalSeparator = ',' | '.';\n\n@Component({\n  selector: 'lx-currency-input',\n  templateUrl: 'currency-input.component.html',\n  styleUrls: ['currency-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CurrencyInputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CurrencyInputComponent implements AfterViewInit, OnDestroy, ControlValueAccessor, OnInit {\n  @Input() public code!: string | null;\n  @Input() public decimalSeparator: DecimalSeparator = '.';\n  @Input() public placeholder!: string;\n  @Input() public data: number = 0;\n  @Observe<number>('data') data$!: Observable<number>;\n\n  @Input() public disabled: boolean = false;\n  @Input() public mode: CurrencyInputMode = 'edit';\n  @Input() public fieldDefinitionType!: 'DOUBLE' | 'INTEGER';\n  @Input() public iconPosition: CurrencyIconPosition = 'first';\n  @Input() public format: string = '1.2-2';\n  @Input() markInvalid = false;\n\n  @Output() public onFocusLost = new EventEmitter<boolean>();\n  @Output() public onChange = new EventEmitter<number>();\n\n  @ViewChild('currencyInput') private currencyInput!: ElementRef<HTMLInputElement>;\n  showCurrencyInput: boolean = false;\n  dataValue$ = new ReplaySubject<number>();\n\n  private get allowedCharacters() {\n    return this.fieldDefinitionType === 'DOUBLE' ? new RegExp(`[0-9\\e\\\\${this.decimalSeparator}\\]`) : /[0-9\\e\\\\]/;\n  }\n\n  readonly destroyed$ = new Subject<void>();\n\n  constructor(private changeDetector: ChangeDetectorRef) {}\n\n  ngOnInit() {\n    this.data$.pipe(takeUntil(this.destroyed$)).subscribe(this.dataValue$);\n  }\n\n  ngAfterViewInit() {\n    if (this.currencyInput) {\n      fromEvent<KeyboardEvent>(this.currencyInput.nativeElement, 'keypress')\n        .pipe(\n          filter((keyboardEvent) => this.shouldRejectKey(keyboardEvent)),\n          takeUntil(this.destroyed$)\n        )\n        .subscribe((keyboardEvent) => {\n          keyboardEvent.preventDefault();\n        });\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  valueChanged(value: string | number) {\n    if (typeof value === 'string') {\n      const invalidSeparator = this.decimalSeparator === '.' ? ',' : '.';\n      value = this.parseInput(value, invalidSeparator) as number;\n    }\n    // fix copy & paste string values being interpreted wrongly\n    this.dataValue$.next(value);\n    this.onChange.emit(value);\n    this.propagateChange(value);\n  }\n\n  onBlur() {\n    this.showCurrencyInput = false;\n    this.onFocusLost.emit(true);\n  }\n\n  focusCurrencyInput() {\n    this.showCurrencyInput = true;\n    this.changeDetector.detectChanges();\n    this.currencyInput.nativeElement.focus();\n    this.currencyInput.nativeElement.setSelectionRange(0, 0);\n  }\n\n  shouldRejectKey(event: KeyboardEvent) {\n    if (this.fieldDefinitionType === 'DOUBLE' && event.key === this.decimalSeparator) {\n      return this.containsSeparators(this.currencyInput.nativeElement.value);\n    }\n    return !this.allowedCharacters.test(event.key);\n  }\n\n  propagateChange(_newValue: number) {}\n\n  writeValue(newValue: number) {\n    this.dataValue$.next(newValue);\n  }\n  registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(_fn: any) {}\n\n  setDisabledState(disabled: boolean) {\n    this.disabled = disabled;\n  }\n\n  private parseInput(value: string, char: string) {\n    const countOccurences = value.split(char).length - 1;\n    if (countOccurences > 1) {\n      for (let i = 0; i < countOccurences; i++) {\n        value = value.replace(char, '');\n      }\n    }\n    const parsedValue = parseFloat(value.replace(',', '.').replace(/ /g, ''));\n    return isNaN(parsedValue) ? null : parsedValue;\n  }\n\n  private containsSeparators(value: string) {\n    return value.indexOf(',') > -1 || value.indexOf('.') > -1;\n  }\n}\n","<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n  <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n  <input\n    [attr.disabled]=\"disabled ? true : null\"\n    *ngIf=\"!showCurrencyInput\"\n    type=\"text\"\n    class=\"form-control currencyDisplayValue\"\n    placeholder=\"{{ placeholder }}\"\n    [lxMarkInvalid]=\"markInvalid\"\n    [value]=\"dataValue$ | async | number : format\"\n    (focus)=\"focusCurrencyInput()\"\n  />\n  <input\n    autocomplete=\"off\"\n    [attr.disabled]=\"disabled ? true : null\"\n    [class.hideInput]=\"!showCurrencyInput\"\n    type=\"text\"\n    inputmode=\"numeric\"\n    class=\"form-control currencyInput\"\n    name=\"inputAmount\"\n    #currencyInput\n    placeholder=\"{{ placeholder }}\"\n    [ngModel]=\"dataValue$ | async\"\n    (blur)=\"onBlur()\"\n    (ngModelChange)=\"valueChanged($event)\"\n  />\n  <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n  <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n  <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n  {{ (dataValue$ | async | number : format) || placeholder }}\n  <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/currency/currency-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { fromEvent, Observable, ReplaySubject, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { Observe } from '../../../shared/observe';\n\nexport type CurrencyInputMode = 'view' | 'edit';\nexport type CurrencyIconPosition = 'first' | 'end' | 'none';\n\nexport type DecimalSeparator = ',' | '.';\n\n@Component({\n  selector: 'lx-currency-input',\n  templateUrl: 'currency-input.component.html',\n  styleUrls: ['currency-input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CurrencyInputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CurrencyInputComponent implements AfterViewInit, OnDestroy, ControlValueAccessor, OnInit {\n  @Input() public code!: string | null;\n  @Input() public decimalSeparator: DecimalSeparator = '.';\n  @Input() public placeholder!: string;\n  @Input() public data: number = 0;\n  @Observe<number>('data') data$!: Observable<number>;\n\n  @Input() public disabled: boolean = false;\n  @Input() public mode: CurrencyInputMode = 'edit';\n  @Input() public fieldDefinitionType!: 'DOUBLE' | 'INTEGER';\n  @Input() public iconPosition: CurrencyIconPosition = 'first';\n  @Input() public format: string = '1.2-2';\n  @Input() markInvalid = false;\n\n  @Output() public onFocusLost = new EventEmitter<boolean>();\n  @Output() public onChange = new EventEmitter<number>();\n\n  @ViewChild('currencyInput') private currencyInput!: ElementRef<HTMLInputElement>;\n  showCurrencyInput: boolean = false;\n  dataValue$ = new ReplaySubject<number>();\n\n  private get allowedCharacters() {\n    return this.fieldDefinitionType === 'DOUBLE' ? new RegExp(`[0-9\\e\\\\${this.decimalSeparator}\\]`) : /[0-9\\e\\\\]/;\n  }\n\n  readonly destroyed$ = new Subject<void>();\n\n  constructor(private changeDetector: ChangeDetectorRef) {}\n\n  ngOnInit() {\n    this.data$.pipe(takeUntil(this.destroyed$)).subscribe(this.dataValue$);\n  }\n\n  ngAfterViewInit() {\n    if (this.currencyInput) {\n      fromEvent<KeyboardEvent>(this.currencyInput.nativeElement, 'keypress')\n        .pipe(\n          filter((keyboardEvent) => this.shouldRejectKey(keyboardEvent)),\n          takeUntil(this.destroyed$)\n        )\n        .subscribe((keyboardEvent) => {\n          keyboardEvent.preventDefault();\n        });\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next();\n  }\n\n  valueChanged(value: string | number) {\n    if (typeof value === 'string') {\n      const invalidSeparator = this.decimalSeparator === '.' ? ',' : '.';\n      value = this.parseInput(value, invalidSeparator) as number;\n    }\n    // fix copy & paste string values being interpreted wrongly\n    this.dataValue$.next(value);\n    this.onChange.emit(value);\n    this.propagateChange(value);\n  }\n\n  onBlur() {\n    this.showCurrencyInput = false;\n    this.onFocusLost.emit(true);\n  }\n\n  focusCurrencyInput() {\n    this.showCurrencyInput = true;\n    this.changeDetector.detectChanges();\n    this.currencyInput.nativeElement.focus();\n    this.currencyInput.nativeElement.setSelectionRange(0, 0);\n  }\n\n  shouldRejectKey(event: KeyboardEvent) {\n    if (this.fieldDefinitionType === 'DOUBLE' && event.key === this.decimalSeparator) {\n      return this.containsSeparators(this.currencyInput.nativeElement.value);\n    }\n    return !this.allowedCharacters.test(event.key);\n  }\n\n  propagateChange(_newValue: number) {}\n\n  writeValue(newValue: number) {\n    this.dataValue$.next(newValue);\n  }\n  registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(_fn: any) {}\n\n  setDisabledState(disabled: boolean) {\n    this.disabled = disabled;\n  }\n\n  private parseInput(value: string, char: string) {\n    const countOccurences = value.split(char).length - 1;\n    if (countOccurences > 1) {\n      for (let i = 0; i < countOccurences; i++) {\n        value = value.replace(char, '');\n      }\n    }\n    const parsedValue = parseFloat(value.replace(',', '.').replace(/ /g, ''));\n    return isNaN(parsedValue) ? null : parsedValue;\n  }\n\n  private containsSeparators(value: string) {\n    return value.indexOf(',') > -1 || value.indexOf('.') > -1;\n  }\n}\n","<div *ngIf=\"mode === 'edit'\" class=\"container input-group\">\n  <div *ngIf=\"iconPosition === 'first'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n  <input\n    [attr.disabled]=\"disabled ? true : null\"\n    *ngIf=\"!showCurrencyInput\"\n    type=\"text\"\n    class=\"form-control currencyDisplayValue\"\n    placeholder=\"{{ placeholder }}\"\n    [lxMarkInvalid]=\"markInvalid\"\n    [value]=\"dataValue$ | async | number: format\"\n    (focus)=\"focusCurrencyInput()\"\n  />\n  <input\n    autocomplete=\"off\"\n    [attr.disabled]=\"disabled ? true : null\"\n    [class.hideInput]=\"!showCurrencyInput\"\n    type=\"text\"\n    inputmode=\"numeric\"\n    class=\"form-control currencyInput\"\n    name=\"inputAmount\"\n    #currencyInput\n    placeholder=\"{{ placeholder }}\"\n    [ngModel]=\"dataValue$ | async\"\n    (blur)=\"onBlur()\"\n    (ngModelChange)=\"valueChanged($event)\"\n  />\n  <div *ngIf=\"iconPosition === 'end'\" class=\"labelContainer input-group-addon\">\n    <lx-currency-symbol [code]=\"code\"></lx-currency-symbol>\n  </div>\n</div>\n<span *ngIf=\"mode === 'view'\" [class.placeholder]=\"(dataValue$ | async) === null && placeholder\">\n  <!-- Not using Angular 2 currency pipe since a lot of currency symbols are missing: https://github.com/angular/angular/issues/6724 -->\n  <lx-currency-symbol *ngIf=\"iconPosition === 'first'\" [code]=\"code\"></lx-currency-symbol>\n  {{ (dataValue$ | async | number: format) || placeholder }}\n  <lx-currency-symbol *ngIf=\"iconPosition === 'end'\" [code]=\"code\"></lx-currency-symbol>\n</span>\n"]}