@leanix/components 0.4.531 → 0.4.533

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 (157) hide show
  1. package/fesm2022/leanix-components.mjs +365 -365
  2. package/fesm2022/leanix-components.mjs.map +1 -1
  3. package/lib/core-ui/tooltip/tooltip.directive.d.ts +1 -1
  4. package/lib/forms-ui/components/keyboard-select.directive.d.ts +1 -1
  5. package/lib/forms-ui/models/base-select.directive.d.ts +1 -1
  6. package/lib/tab-ui/components/tab-group/tab-group.component.d.ts +1 -1
  7. package/package.json +10 -14
  8. package/esm2022/index.mjs +0 -145
  9. package/esm2022/leanix-components.mjs +0 -5
  10. package/esm2022/lib/core-ui/components/avatar/avatar.component.mjs +0 -40
  11. package/esm2022/lib/core-ui/components/avatar/avatar.helpers.mjs +0 -49
  12. package/esm2022/lib/core-ui/components/avatar/avatar.model.mjs +0 -33
  13. package/esm2022/lib/core-ui/components/avatar-group/avatar-group.component.mjs +0 -75
  14. package/esm2022/lib/core-ui/components/badge/badge.component.mjs +0 -58
  15. package/esm2022/lib/core-ui/components/banner/banner.component.mjs +0 -68
  16. package/esm2022/lib/core-ui/components/banner/banner.models.mjs +0 -12
  17. package/esm2022/lib/core-ui/components/button/button.component.mjs +0 -179
  18. package/esm2022/lib/core-ui/components/button-group/button-group.component.mjs +0 -28
  19. package/esm2022/lib/core-ui/components/card/card.component.mjs +0 -26
  20. package/esm2022/lib/core-ui/components/collapsible/collapsible.component.mjs +0 -52
  21. package/esm2022/lib/core-ui/components/counter/counter.component.mjs +0 -30
  22. package/esm2022/lib/core-ui/components/ellipsis/ellipsis.component.mjs +0 -143
  23. package/esm2022/lib/core-ui/components/empty-state/empty-state.component.mjs +0 -41
  24. package/esm2022/lib/core-ui/components/icon-scale/icon-scale.component.mjs +0 -36
  25. package/esm2022/lib/core-ui/components/skeleton/skeleton.component.mjs +0 -44
  26. package/esm2022/lib/core-ui/components/spinner/spinner.component.mjs +0 -26
  27. package/esm2022/lib/core-ui/components/stepper/stepper.component.mjs +0 -70
  28. package/esm2022/lib/core-ui/components/table/table-header/table-header.component.mjs +0 -128
  29. package/esm2022/lib/core-ui/components/table/table.component.mjs +0 -77
  30. package/esm2022/lib/core-ui/components/tiny-spinner/tiny-spinner.component.mjs +0 -14
  31. package/esm2022/lib/core-ui/components/tokenizer/token/token.component.mjs +0 -20
  32. package/esm2022/lib/core-ui/components/tokenizer/tokenizer-overflow-popover/tokenizer-overflow-popover.component.mjs +0 -44
  33. package/esm2022/lib/core-ui/components/tokenizer/tokenizer.component.mjs +0 -149
  34. package/esm2022/lib/core-ui/core-ui.constants.mjs +0 -240
  35. package/esm2022/lib/core-ui/core-ui.module.mjs +0 -206
  36. package/esm2022/lib/core-ui/directives/after-view-init.directive.mjs +0 -33
  37. package/esm2022/lib/core-ui/directives/autoclose-group.service.mjs +0 -39
  38. package/esm2022/lib/core-ui/directives/autoclose.directive.mjs +0 -43
  39. package/esm2022/lib/core-ui/directives/autofocus.directive.mjs +0 -36
  40. package/esm2022/lib/core-ui/functions/core-css.helpers.mjs +0 -52
  41. package/esm2022/lib/core-ui/functions/highlight-text.function.mjs +0 -80
  42. package/esm2022/lib/core-ui/linkify/linkify.pipe.mjs +0 -146
  43. package/esm2022/lib/core-ui/linkify/unlinkify.pipe.mjs +0 -51
  44. package/esm2022/lib/core-ui/pipes/br.pipe.mjs +0 -24
  45. package/esm2022/lib/core-ui/pipes/contrast-color.pipe.mjs +0 -21
  46. package/esm2022/lib/core-ui/pipes/custom-date.pipe.mjs +0 -28
  47. package/esm2022/lib/core-ui/pipes/display-avatars.pipe.mjs +0 -37
  48. package/esm2022/lib/core-ui/pipes/highlight-range.pipe.mjs +0 -29
  49. package/esm2022/lib/core-ui/pipes/highlight-term.pipe.mjs +0 -57
  50. package/esm2022/lib/core-ui/pipes/lx-is-uuid.pipe.mjs +0 -22
  51. package/esm2022/lib/core-ui/pipes/lx-time-ago.pipe.mjs +0 -29
  52. package/esm2022/lib/core-ui/pipes/lx-translate.pipe.mjs +0 -50
  53. package/esm2022/lib/core-ui/pipes/markdown.pipe.mjs +0 -32
  54. package/esm2022/lib/core-ui/pipes/nbsp.pipe.mjs +0 -17
  55. package/esm2022/lib/core-ui/pipes/sort.pipe.mjs +0 -55
  56. package/esm2022/lib/core-ui/pipes/translation-after.pipe.mjs +0 -29
  57. package/esm2022/lib/core-ui/pipes/translation-before.pipe.mjs +0 -54
  58. package/esm2022/lib/core-ui/pipes/translation-between.pipe.mjs +0 -68
  59. package/esm2022/lib/core-ui/pipes/unescape-curly-braces.pipe.mjs +0 -17
  60. package/esm2022/lib/core-ui/services/resize-observer.service.mjs +0 -112
  61. package/esm2022/lib/core-ui/tooltip/to-cdk-position.function.mjs +0 -74
  62. package/esm2022/lib/core-ui/tooltip/tooltip-position.interface.mjs +0 -7
  63. package/esm2022/lib/core-ui/tooltip/tooltip.component.mjs +0 -26
  64. package/esm2022/lib/core-ui/tooltip/tooltip.directive.mjs +0 -117
  65. package/esm2022/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.mjs +0 -139
  66. package/esm2022/lib/forms-ui/components/basic-dropdown-item/basic-dropdown-item.component.mjs +0 -38
  67. package/esm2022/lib/forms-ui/components/breadcrumb/breadcrumb.component.mjs +0 -55
  68. package/esm2022/lib/forms-ui/components/cdk-options-dropdown/cdk-options-dropdown.component.mjs +0 -215
  69. package/esm2022/lib/forms-ui/components/cdk-options-sub-dropdown/cdk-options-sub-dropdown.component.mjs +0 -135
  70. package/esm2022/lib/forms-ui/components/currency/currency-input.component.mjs +0 -159
  71. package/esm2022/lib/forms-ui/components/currency/currency-symbol-map.constant.mjs +0 -105
  72. package/esm2022/lib/forms-ui/components/currency/currency-symbol.component.mjs +0 -24
  73. package/esm2022/lib/forms-ui/components/date-input/date-input.component.mjs +0 -347
  74. package/esm2022/lib/forms-ui/components/date-picker-ui/date-formatter.mjs +0 -8
  75. package/esm2022/lib/forms-ui/components/date-picker-ui/datepicker-inner.component.mjs +0 -312
  76. package/esm2022/lib/forms-ui/components/date-picker-ui/datepicker-ui.module.mjs +0 -20
  77. package/esm2022/lib/forms-ui/components/date-picker-ui/datepicker.component.mjs +0 -206
  78. package/esm2022/lib/forms-ui/components/date-picker-ui/datepicker.config.mjs +0 -29
  79. package/esm2022/lib/forms-ui/components/date-picker-ui/daypicker.component.mjs +0 -319
  80. package/esm2022/lib/forms-ui/components/date-picker-ui/isBs3.mjs +0 -2
  81. package/esm2022/lib/forms-ui/components/date-picker-ui/monthpicker.component.mjs +0 -149
  82. package/esm2022/lib/forms-ui/components/date-picker-ui/yearpicker.component.mjs +0 -151
  83. package/esm2022/lib/forms-ui/components/drag-and-drop-list/constants.mjs +0 -5
  84. package/esm2022/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list-item/drag-and-drop-list-item.component.mjs +0 -49
  85. package/esm2022/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.component.mjs +0 -120
  86. package/esm2022/lib/forms-ui/components/drag-and-drop-list/drag-and-drop-list.module.mjs +0 -39
  87. package/esm2022/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-item/keyboard-sortable-item.directive.mjs +0 -137
  88. package/esm2022/lib/forms-ui/components/drag-and-drop-list/keyboard-sortable-list/keyboard-sortable-list.directive.mjs +0 -38
  89. package/esm2022/lib/forms-ui/components/error-message/error-message.component.mjs +0 -16
  90. package/esm2022/lib/forms-ui/components/expanded-dropdown/expanded-dropdown.component.mjs +0 -26
  91. package/esm2022/lib/forms-ui/components/form-error/form-error.component.mjs +0 -44
  92. package/esm2022/lib/forms-ui/components/icon/icon.component.mjs +0 -45
  93. package/esm2022/lib/forms-ui/components/input/input.component.mjs +0 -48
  94. package/esm2022/lib/forms-ui/components/keyboard-select.directive.mjs +0 -126
  95. package/esm2022/lib/forms-ui/components/multi-select/multi-select-selection/multi-select-selection.component.mjs +0 -28
  96. package/esm2022/lib/forms-ui/components/multi-select/multi-select.component.mjs +0 -318
  97. package/esm2022/lib/forms-ui/components/option/option.component.mjs +0 -99
  98. package/esm2022/lib/forms-ui/components/option-group/option-group.component.mjs +0 -29
  99. package/esm2022/lib/forms-ui/components/option-group-dropdown/option-group-dropdown.component.mjs +0 -123
  100. package/esm2022/lib/forms-ui/components/options-dropdown/options-dropdown.component.mjs +0 -297
  101. package/esm2022/lib/forms-ui/components/options-sub-dropdown/options-sub-dropdown.component.mjs +0 -94
  102. package/esm2022/lib/forms-ui/components/picker/picker-trigger.directive.mjs +0 -47
  103. package/esm2022/lib/forms-ui/components/picker/picker.component.mjs +0 -218
  104. package/esm2022/lib/forms-ui/components/picker-option/picker-option.component.mjs +0 -118
  105. package/esm2022/lib/forms-ui/components/pill-item/pill-item.component.mjs +0 -33
  106. package/esm2022/lib/forms-ui/components/pill-list/pill-list.component.mjs +0 -58
  107. package/esm2022/lib/forms-ui/components/responsive-input/responsive-input.component.mjs +0 -101
  108. package/esm2022/lib/forms-ui/components/select-list/select-list.component.mjs +0 -178
  109. package/esm2022/lib/forms-ui/components/single-select/single-select.component.mjs +0 -290
  110. package/esm2022/lib/forms-ui/components/sorting-dropdown/sorting-dropdown.component.mjs +0 -71
  111. package/esm2022/lib/forms-ui/components/sorting-dropdown-trigger/sorting-dropdown-trigger.component.mjs +0 -21
  112. package/esm2022/lib/forms-ui/components/switch/switch.component.mjs +0 -51
  113. package/esm2022/lib/forms-ui/directives/contenteditable.directive.mjs +0 -130
  114. package/esm2022/lib/forms-ui/directives/form-error.directive.mjs +0 -121
  115. package/esm2022/lib/forms-ui/directives/form-submit.directive.mjs +0 -29
  116. package/esm2022/lib/forms-ui/directives/keyboard-action-source.directive.mjs +0 -63
  117. package/esm2022/lib/forms-ui/directives/mark-invalid.directive.mjs +0 -39
  118. package/esm2022/lib/forms-ui/directives/max-length-counter.directive.mjs +0 -131
  119. package/esm2022/lib/forms-ui/directives/select-dropdown.directive.mjs +0 -32
  120. package/esm2022/lib/forms-ui/directives/selectable-item.directive.mjs +0 -34
  121. package/esm2022/lib/forms-ui/directives/selected-option.directive.mjs +0 -27
  122. package/esm2022/lib/forms-ui/forms-ui.module.mjs +0 -270
  123. package/esm2022/lib/forms-ui/helpers/key-codes.constants.mjs +0 -13
  124. package/esm2022/lib/forms-ui/helpers/keyboard-navigation.helpers.mjs +0 -38
  125. package/esm2022/lib/forms-ui/models/base-select.directive.mjs +0 -183
  126. package/esm2022/lib/forms-ui/models/dropdown-item.interface.mjs +0 -2
  127. package/esm2022/lib/forms-ui/models/single-select-padding.interface.mjs +0 -2
  128. package/esm2022/lib/forms-ui/models/sorting.interface.mjs +0 -7
  129. package/esm2022/lib/forms-ui/pipes/filter-selection.pipe.mjs +0 -33
  130. package/esm2022/lib/forms-ui/pipes/filter-term.pipe.mjs +0 -29
  131. package/esm2022/lib/forms-ui/pipes/format-number.pipe.mjs +0 -66
  132. package/esm2022/lib/forms-ui/validators/date-in-foreseeable-future.validator.mjs +0 -26
  133. package/esm2022/lib/forms-ui/validators/string-not-in-array.validator.mjs +0 -30
  134. package/esm2022/lib/modal-ui/components/modal/modal.component.mjs +0 -264
  135. package/esm2022/lib/modal-ui/components/modal-footer/modal-footer.component.mjs +0 -16
  136. package/esm2022/lib/modal-ui/components/modal-header/modal-header.component.mjs +0 -19
  137. package/esm2022/lib/modal-ui/directives/modal-content.directive.mjs +0 -14
  138. package/esm2022/lib/modal-ui/modal.constants.mjs +0 -18
  139. package/esm2022/lib/modal-ui/modal.module.mjs +0 -47
  140. package/esm2022/lib/popover-ui/components/popover/popover.component.mjs +0 -228
  141. package/esm2022/lib/popover-ui/directives/popover-click.directive.mjs +0 -52
  142. package/esm2022/lib/popover-ui/directives/popover-content.directive.mjs +0 -17
  143. package/esm2022/lib/popover-ui/directives/popover-hover.directive.mjs +0 -88
  144. package/esm2022/lib/popover-ui/popover-ui.module.mjs +0 -21
  145. package/esm2022/lib/shared/date-helpers.mjs +0 -35
  146. package/esm2022/lib/shared/html-helpers.function.mjs +0 -34
  147. package/esm2022/lib/shared/misc-helpers.mjs +0 -24
  148. package/esm2022/lib/shared/observe.mjs +0 -40
  149. package/esm2022/lib/tab-ui/components/tab/tab.component.mjs +0 -118
  150. package/esm2022/lib/tab-ui/components/tab-group/tab-group-key-codes.enum.mjs +0 -12
  151. package/esm2022/lib/tab-ui/components/tab-group/tab-group.component.mjs +0 -150
  152. package/esm2022/lib/tab-ui/tab-ui.module.mjs +0 -20
  153. package/esm2022/ui5/icons/lx-icons.json +0 -177
  154. package/esm2022/ui5/icons/register-icons.mjs +0 -14
  155. package/esm2022/ui5/index.mjs +0 -8
  156. package/esm2022/ui5/leanix-components-ui5.mjs +0 -5
  157. package/esm2022/ui5/ui5.provider.mjs +0 -29
@@ -1,130 +0,0 @@
1
- import { Directive, EventEmitter, HostListener, Input, Output, SecurityContext } from '@angular/core';
2
- import { intersection, isNil } from 'lodash-es';
3
- import { NbspPipe } from '../../core-ui/pipes/nbsp.pipe';
4
- import { trimHtml } from '../../shared/html-helpers.function';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/platform-browser";
7
- // First version based on https://stackoverflow.com/a/41253897/6813271
8
- export class ContenteditableDirective {
9
- constructor(elRef, sanitizer) {
10
- this.elRef = elRef;
11
- this.sanitizer = sanitizer;
12
- this.lxContenteditableModelChange = new EventEmitter();
13
- /** Allow (sanitized) html */
14
- this.lxContenteditableHtml = false;
15
- this.lxContenteditableHtmlPaste = true;
16
- this.emittedValue = null;
17
- }
18
- ngOnChanges(changes) {
19
- if (changes['lxContenteditableModel']) {
20
- // On init: if lxContenteditableModel is empty, read from DOM in case the element has content
21
- if (changes['lxContenteditableModel'].isFirstChange() && !this.lxContenteditableModel) {
22
- // Prevent Exp.HasChanged: Don't read and emit value from DOM during change detection
23
- setTimeout(() => {
24
- this.onInput(true);
25
- });
26
- }
27
- this.refreshView();
28
- }
29
- }
30
- onInput(initialInlineData = false) {
31
- let value = this.elRef.nativeElement[this.getProperty()];
32
- value = this.cleanContent(value, initialInlineData);
33
- this.emittedValue = value;
34
- this.lxContenteditableModelChange.emit(value);
35
- }
36
- /**
37
- * @param event {ClipboardEvent}
38
- */
39
- onPaste(event) {
40
- const clipboardEvent = event;
41
- this.onInput();
42
- // For text-only contenteditable, remove pasted HTML.
43
- if (!this.lxContenteditableHtml || !this.lxContenteditableHtmlPaste) {
44
- let isHtml = true;
45
- // TODO: Use beforepaste event. See https://www.lucidchart.com/techblog/2014/12/02/definitive-guide-copying-pasting-javascript/.
46
- if (clipboardEvent.clipboardData && clipboardEvent.clipboardData.types) {
47
- const types = [].slice.apply(clipboardEvent.clipboardData.types);
48
- isHtml = intersection(types, ['text/html', 'com.apple.webarchive']).length > 0;
49
- }
50
- if (isHtml) {
51
- // 1 tick wait is required for DOM update
52
- setTimeout(() => {
53
- // Cursor will be lost
54
- // The lint disabling here should be clearified. See if and how this directive is needed.
55
- this.elRef.nativeElement.innerHTML = this.sanitizer.sanitize(SecurityContext.HTML, this.elRef.nativeElement.innerText.replace(/\n/g, '<br />'));
56
- });
57
- }
58
- }
59
- }
60
- onDrop(event) {
61
- this.onInput();
62
- // For text-only contenteditable, don't allow drop content.
63
- if (!this.lxContenteditableHtml || !this.lxContenteditableHtmlPaste) {
64
- event.preventDefault();
65
- event.stopPropagation();
66
- return false;
67
- }
68
- return false;
69
- }
70
- cleanContent(value, initialInlineData = false) {
71
- if (this.lxContenteditableHtml === 'trim' || (this.lxContenteditableHtml && initialInlineData)) {
72
- value = trimHtml(value);
73
- }
74
- else if (initialInlineData && !this.lxContenteditableHtml && value) {
75
- value = value.replace(/^[\n\s]+/, '');
76
- value = value.replace(/[\n\s]+$/, '');
77
- }
78
- // Some browsers like Chrome insert nbsp; when using contentEditable attribute
79
- return new NbspPipe().transform(value);
80
- }
81
- refreshView() {
82
- if (!isNil(this.lxContenteditableModel)) {
83
- const newContent = this.cleanContent(this.lxContenteditableModel);
84
- // Only refresh if content changed to avoid cursor loss
85
- // (as ngOnChanges can be triggered an additional time by onInput())
86
- if (this.emittedValue === null || this.emittedValue !== newContent) {
87
- this.elRef.nativeElement[this.getProperty()] = this.sanitize(newContent);
88
- }
89
- }
90
- }
91
- getProperty() {
92
- return this.lxContenteditableHtml ? 'innerHTML' : 'innerText';
93
- }
94
- sanitize(content) {
95
- return this.lxContenteditableHtml ? this.sanitizer.sanitize(SecurityContext.HTML, content) : content;
96
- }
97
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ContenteditableDirective, deps: [{ token: i0.ElementRef }, { token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Directive }); }
98
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: ContenteditableDirective, isStandalone: true, selector: "[lxContenteditableModel]", inputs: { lxContenteditableModel: "lxContenteditableModel", lxContenteditableHtml: "lxContenteditableHtml", lxContenteditableHtmlPaste: "lxContenteditableHtmlPaste" }, outputs: { lxContenteditableModelChange: "lxContenteditableModelChange" }, host: { listeners: { "input": "onInput()", "blur": "onInput()", "keyup": "onInput()", "paste": "onPaste($event)", "drop": "onDrop($event)" } }, usesOnChanges: true, ngImport: i0 }); }
99
- }
100
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: ContenteditableDirective, decorators: [{
101
- type: Directive,
102
- args: [{
103
- selector: '[lxContenteditableModel]',
104
- standalone: true
105
- }]
106
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.DomSanitizer }], propDecorators: { lxContenteditableModel: [{
107
- type: Input
108
- }], lxContenteditableModelChange: [{
109
- type: Output
110
- }], lxContenteditableHtml: [{
111
- type: Input
112
- }], lxContenteditableHtmlPaste: [{
113
- type: Input
114
- }], onInput: [{
115
- type: HostListener,
116
- args: ['input']
117
- }, {
118
- type: HostListener,
119
- args: ['blur']
120
- }, {
121
- type: HostListener,
122
- args: ['keyup']
123
- }], onPaste: [{
124
- type: HostListener,
125
- args: ['paste', ['$event']]
126
- }], onDrop: [{
127
- type: HostListener,
128
- args: ['drop', ['$event']]
129
- }] } });
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contenteditable.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/forms-ui/directives/contenteditable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostListener, Input, OnChanges, Output, SecurityContext, SimpleChanges } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { intersection, isNil } from 'lodash-es';\nimport { NbspPipe } from '../../core-ui/pipes/nbsp.pipe';\nimport { trimHtml } from '../../shared/html-helpers.function';\n\n// First version based on https://stackoverflow.com/a/41253897/6813271\n@Directive({\n  selector: '[lxContenteditableModel]',\n  standalone: true\n})\nexport class ContenteditableDirective implements OnChanges {\n  /** Model */\n  @Input() lxContenteditableModel!: string;\n  @Output() lxContenteditableModelChange = new EventEmitter<string>();\n  /** Allow (sanitized) html */\n  @Input() lxContenteditableHtml: boolean | 'trim' = false;\n  @Input() lxContenteditableHtmlPaste: boolean = true;\n\n  private emittedValue: string | null = null;\n\n  constructor(\n    private elRef: ElementRef<HTMLElement>,\n    private sanitizer: DomSanitizer\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['lxContenteditableModel']) {\n      // On init: if lxContenteditableModel is empty, read from DOM in case the element has content\n      if (changes['lxContenteditableModel'].isFirstChange() && !this.lxContenteditableModel) {\n        // Prevent Exp.HasChanged: Don't read and emit value from DOM during change detection\n        setTimeout(() => {\n          this.onInput(true);\n        });\n      }\n      this.refreshView();\n    }\n  }\n\n  @HostListener('input')\n  @HostListener('blur')\n  @HostListener('keyup')\n  onInput(initialInlineData = false) {\n    let value = this.elRef.nativeElement[this.getProperty()] as string;\n    value = this.cleanContent(value, initialInlineData);\n    this.emittedValue = value;\n    this.lxContenteditableModelChange.emit(value);\n  }\n\n  /**\n   * @param event {ClipboardEvent}\n   */\n  @HostListener('paste', ['$event']) onPaste(event: any) {\n    const clipboardEvent = event as ClipboardEvent;\n    this.onInput();\n    // For text-only contenteditable, remove pasted HTML.\n    if (!this.lxContenteditableHtml || !this.lxContenteditableHtmlPaste) {\n      let isHtml: boolean = true;\n      // TODO: Use beforepaste event. See https://www.lucidchart.com/techblog/2014/12/02/definitive-guide-copying-pasting-javascript/.\n      if (clipboardEvent.clipboardData && clipboardEvent.clipboardData.types) {\n        const types = [].slice.apply(clipboardEvent.clipboardData.types);\n        isHtml = intersection(types, ['text/html', 'com.apple.webarchive']).length > 0;\n      }\n      if (isHtml) {\n        // 1 tick wait is required for DOM update\n        setTimeout(() => {\n          // Cursor will be lost\n          // The lint disabling here should be clearified. See if and how this directive is needed.\n          this.elRef.nativeElement.innerHTML = this.sanitizer.sanitize(\n            SecurityContext.HTML,\n            this.elRef.nativeElement.innerText.replace(/\\n/g, '<br />')\n          )!;\n        });\n      }\n    }\n  }\n\n  @HostListener('drop', ['$event']) onDrop(event: MouseEvent) {\n    this.onInput();\n    // For text-only contenteditable, don't allow drop content.\n    if (!this.lxContenteditableHtml || !this.lxContenteditableHtmlPaste) {\n      event.preventDefault();\n      event.stopPropagation();\n      return false;\n    }\n\n    return false;\n  }\n\n  private cleanContent(value: string, initialInlineData = false): string {\n    if (this.lxContenteditableHtml === 'trim' || (this.lxContenteditableHtml && initialInlineData)) {\n      value = trimHtml(value);\n    } else if (initialInlineData && !this.lxContenteditableHtml && value) {\n      value = value.replace(/^[\\n\\s]+/, '');\n      value = value.replace(/[\\n\\s]+$/, '');\n    }\n    // Some browsers like Chrome insert nbsp; when using contentEditable attribute\n    return new NbspPipe().transform(value);\n  }\n\n  private refreshView() {\n    if (!isNil(this.lxContenteditableModel)) {\n      const newContent = this.cleanContent(this.lxContenteditableModel);\n      // Only refresh if content changed to avoid cursor loss\n      // (as ngOnChanges can be triggered an additional time by onInput())\n      if (this.emittedValue === null || this.emittedValue !== newContent) {\n        this.elRef.nativeElement[this.getProperty()] = this.sanitize(newContent)!;\n      }\n    }\n  }\n\n  private getProperty(): 'innerHTML' | 'innerText' {\n    return this.lxContenteditableHtml ? 'innerHTML' : 'innerText';\n  }\n\n  private sanitize(content: string): string | null {\n    return this.lxContenteditableHtml ? this.sanitizer.sanitize(SecurityContext.HTML, content) : content;\n  }\n}\n"]}
@@ -1,121 +0,0 @@
1
- import { Directive, Host, Inject, InjectionToken, Input, Optional, Self } from '@angular/core';
2
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
- import { curry } from 'lodash-es';
4
- import { combineLatest, of } from 'rxjs';
5
- import { map, startWith } from 'rxjs/operators';
6
- import { ErrorMessageComponent } from '../components/error-message/error-message.component';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@ngx-translate/core";
9
- import * as i2 from "@angular/forms";
10
- import * as i3 from "./form-submit.directive";
11
- export const FORM_CONTROL_ERROR_NAMESPACE = new InjectionToken('FORM_CONTROL_ERROR_NAMESPACE');
12
- export const FORM_CONTROL_ERROR_DISPLAY_STRATEGY = new InjectionToken('FORM_CONTROL_ERROR_DISPLAY_STRATEGY');
13
- export const provideFormControlErrorNamespace = (namespace) => ({
14
- provide: FORM_CONTROL_ERROR_NAMESPACE,
15
- useValue: namespace
16
- });
17
- export const provideFormControlErrorDisplayStrategy = (fn) => ({
18
- provide: FORM_CONTROL_ERROR_DISPLAY_STRATEGY,
19
- useValue: fn
20
- });
21
- export class FormErrorDirective {
22
- get control() {
23
- return this.ngControl?.control || this.ctrl || null;
24
- }
25
- get name() {
26
- return this.ngControl?.name || this.controlName;
27
- }
28
- get formSubmitted() {
29
- return this.formSubmitDirective ? this.formSubmitDirective.submitted$ : of(undefined);
30
- }
31
- constructor(viewContainer, componentFactoryResolver, translateService, destroyRef, ngControl, formSubmitDirective, namespace, strategy) {
32
- this.viewContainer = viewContainer;
33
- this.componentFactoryResolver = componentFactoryResolver;
34
- this.translateService = translateService;
35
- this.destroyRef = destroyRef;
36
- this.ngControl = ngControl;
37
- this.formSubmitDirective = formSubmitDirective;
38
- this.namespace = namespace;
39
- this.strategy = strategy;
40
- }
41
- ngOnInit() {
42
- const control = this.control;
43
- if (isAbstractControl(control)) {
44
- combineLatest([control.valueChanges.pipe(startWith(control.value)), this.formSubmitted])
45
- .pipe(map(([, submitted]) => submitted), map(resolveStrategy(this.strategy, control)), takeUntilDestroyed(this.destroyRef))
46
- .subscribe((display) => {
47
- const { errors } = control;
48
- if (errors && display) {
49
- const firstErrorKey = Object.keys(errors)[0];
50
- const translationKey = this.buildTranslationKey(firstErrorKey);
51
- this.setError(translationKey);
52
- }
53
- else if (this.ref) {
54
- this.setError();
55
- }
56
- });
57
- }
58
- }
59
- buildTranslationKey(errorKey) {
60
- if (this.control) {
61
- return `${this.namespace || 'form'}.errors.${this.name ? `${this.name}.` : ''}${errorKey}`;
62
- }
63
- else {
64
- return '';
65
- }
66
- }
67
- setError(key) {
68
- if (!this.ref) {
69
- const factory = this.componentFactoryResolver.resolveComponentFactory(ErrorMessageComponent);
70
- this.ref = this.viewContainer.createComponent(factory);
71
- }
72
- if (key) {
73
- this.translateService
74
- .get(key)
75
- .pipe(takeUntilDestroyed(this.destroyRef))
76
- .subscribe((message) => {
77
- if (this.ref) {
78
- this.ref.instance.dynamicErrorMessage.set(message);
79
- }
80
- });
81
- }
82
- else {
83
- this.ref.instance.dynamicErrorMessage.set('');
84
- }
85
- }
86
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: FormErrorDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ComponentFactoryResolver }, { token: i1.TranslateService }, { token: i0.DestroyRef }, { token: i2.NgControl, optional: true, self: true }, { token: i3.FormSubmitDirective, host: true, optional: true }, { token: FORM_CONTROL_ERROR_NAMESPACE, optional: true }, { token: FORM_CONTROL_ERROR_DISPLAY_STRATEGY, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
87
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: FormErrorDirective, isStandalone: true, selector: "[lxFormError]", inputs: { ctrl: ["lxFormError", "ctrl"], controlName: "controlName" }, ngImport: i0 }); }
88
- }
89
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: FormErrorDirective, decorators: [{
90
- type: Directive,
91
- args: [{
92
- selector: '[lxFormError]',
93
- standalone: true
94
- }]
95
- }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ComponentFactoryResolver }, { type: i1.TranslateService }, { type: i0.DestroyRef }, { type: i2.NgControl, decorators: [{
96
- type: Optional
97
- }, {
98
- type: Self
99
- }] }, { type: i3.FormSubmitDirective, decorators: [{
100
- type: Optional
101
- }, {
102
- type: Host
103
- }] }, { type: undefined, decorators: [{
104
- type: Optional
105
- }, {
106
- type: Inject,
107
- args: [FORM_CONTROL_ERROR_NAMESPACE]
108
- }] }, { type: undefined, decorators: [{
109
- type: Optional
110
- }, {
111
- type: Inject,
112
- args: [FORM_CONTROL_ERROR_DISPLAY_STRATEGY]
113
- }] }], propDecorators: { ctrl: [{
114
- type: Input,
115
- args: ['lxFormError']
116
- }], controlName: [{
117
- type: Input
118
- }] } });
119
- const isAbstractControl = (ctrl) => !!ctrl;
120
- const resolveStrategy = curry((strategy, control, submitted) => strategy ? strategy({ control, submitted }) : true);
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-error.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/forms-ui/directives/form-error.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentFactoryResolver,\n  ComponentRef,\n  DestroyRef,\n  Directive,\n  Host,\n  Inject,\n  InjectionToken,\n  Input,\n  OnInit,\n  Optional,\n  Self,\n  ViewContainerRef\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { AbstractControl, NgControl } from '@angular/forms';\nimport { TranslateService } from '@ngx-translate/core';\nimport { curry } from 'lodash-es';\nimport { Observable, combineLatest, of } from 'rxjs';\nimport { map, startWith } from 'rxjs/operators';\nimport { ErrorMessageComponent } from '../components/error-message/error-message.component';\nimport { FormSubmitDirective } from './form-submit.directive';\n\nexport type FormControlErrorDisplayStrategy = (obj: { control: AbstractControl; submitted?: boolean }) => boolean;\n\nexport const FORM_CONTROL_ERROR_NAMESPACE = new InjectionToken<string>('FORM_CONTROL_ERROR_NAMESPACE');\nexport const FORM_CONTROL_ERROR_DISPLAY_STRATEGY = new InjectionToken<FormControlErrorDisplayStrategy>(\n  'FORM_CONTROL_ERROR_DISPLAY_STRATEGY'\n);\n\nexport const provideFormControlErrorNamespace = (namespace: string) => ({\n  provide: FORM_CONTROL_ERROR_NAMESPACE,\n  useValue: namespace\n});\n\nexport const provideFormControlErrorDisplayStrategy = (fn: FormControlErrorDisplayStrategy) => ({\n  provide: FORM_CONTROL_ERROR_DISPLAY_STRATEGY,\n  useValue: fn\n});\n\n@Directive({\n  selector: '[lxFormError]',\n  standalone: true\n})\nexport class FormErrorDirective implements OnInit {\n  @Input('lxFormError') ctrl?: AbstractControl | '';\n  @Input() controlName?: string;\n  private ref?: ComponentRef<ErrorMessageComponent>;\n\n  private get control(): AbstractControl | null | undefined {\n    return this.ngControl?.control || this.ctrl || null;\n  }\n\n  private get name(): string | number | null | undefined {\n    return this.ngControl?.name || this.controlName;\n  }\n\n  private get formSubmitted(): Observable<boolean | undefined> {\n    return this.formSubmitDirective ? this.formSubmitDirective.submitted$ : of(undefined);\n  }\n\n  constructor(\n    private viewContainer: ViewContainerRef,\n    private componentFactoryResolver: ComponentFactoryResolver,\n    private translateService: TranslateService,\n    private destroyRef: DestroyRef,\n    @Optional() @Self() private ngControl?: NgControl,\n    @Optional() @Host() private formSubmitDirective?: FormSubmitDirective,\n    @Optional() @Inject(FORM_CONTROL_ERROR_NAMESPACE) private namespace?: string,\n    @Optional() @Inject(FORM_CONTROL_ERROR_DISPLAY_STRATEGY) private strategy?: FormControlErrorDisplayStrategy\n  ) {}\n\n  ngOnInit() {\n    const control = this.control;\n    if (isAbstractControl(control)) {\n      combineLatest([control.valueChanges.pipe(startWith(control.value)), this.formSubmitted])\n        .pipe(\n          map(([, submitted]) => submitted),\n          map(resolveStrategy(this.strategy, control)),\n          takeUntilDestroyed(this.destroyRef)\n        )\n        .subscribe((display) => {\n          const { errors } = control;\n          if (errors && display) {\n            const firstErrorKey = Object.keys(errors)[0];\n            const translationKey = this.buildTranslationKey(firstErrorKey!);\n            this.setError(translationKey);\n          } else if (this.ref) {\n            this.setError();\n          }\n        });\n    }\n  }\n\n  private buildTranslationKey(errorKey: string) {\n    if (this.control) {\n      return `${this.namespace || 'form'}.errors.${this.name ? `${this.name}.` : ''}${errorKey}`;\n    } else {\n      return '';\n    }\n  }\n\n  private setError(key?: string) {\n    if (!this.ref) {\n      const factory = this.componentFactoryResolver.resolveComponentFactory(ErrorMessageComponent);\n      this.ref = this.viewContainer.createComponent(factory);\n    }\n    if (key) {\n      this.translateService\n        .get(key)\n        .pipe(takeUntilDestroyed(this.destroyRef))\n        .subscribe((message) => {\n          if (this.ref) {\n            this.ref.instance.dynamicErrorMessage.set(message);\n          }\n        });\n    } else {\n      this.ref.instance.dynamicErrorMessage.set('');\n    }\n  }\n}\n\nconst isAbstractControl = (ctrl: AbstractControl | null | undefined): ctrl is AbstractControl => !!ctrl;\nconst resolveStrategy = curry(\n  (strategy: FormControlErrorDisplayStrategy | undefined, control: AbstractControl, submitted: boolean | undefined) =>\n    strategy ? strategy({ control, submitted }) : true\n);\n"]}
@@ -1,29 +0,0 @@
1
- import { Directive } from '@angular/core';
2
- import { BehaviorSubject, fromEvent } from 'rxjs';
3
- import { take } from 'rxjs/operators';
4
- import * as i0 from "@angular/core";
5
- export class FormSubmitDirective {
6
- constructor(elementRef) {
7
- this.elementRef = elementRef;
8
- this.submitted$ = new BehaviorSubject(false);
9
- this.subscription = fromEvent(this.elementRef.nativeElement, 'submit')
10
- .pipe(take(1))
11
- .subscribe(() => this.submitted$.next(true));
12
- }
13
- ngOnDestroy() {
14
- if (this.subscription) {
15
- this.subscription.unsubscribe();
16
- }
17
- }
18
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: FormSubmitDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
19
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: FormSubmitDirective, isStandalone: true, selector: "form", ngImport: i0 }); }
20
- }
21
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: FormSubmitDirective, decorators: [{
22
- type: Directive,
23
- args: [{
24
- // eslint-disable-next-line @angular-eslint/directive-selector
25
- selector: 'form',
26
- standalone: true
27
- }]
28
- }], ctorParameters: () => [{ type: i0.ElementRef }] });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1zdWJtaXQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3NyYy9saWIvZm9ybXMtdWkvZGlyZWN0aXZlcy9mb3JtLXN1Ym1pdC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBeUIsTUFBTSxlQUFlLENBQUM7QUFDakUsT0FBTyxFQUFFLGVBQWUsRUFBZ0IsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFPdEMsTUFBTSxPQUFPLG1CQUFtQjtJQUk5QixZQUFvQixVQUFzQjtRQUF0QixlQUFVLEdBQVYsVUFBVSxDQUFZO1FBSDFDLGVBQVUsR0FBRyxJQUFJLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUl0QyxJQUFJLENBQUMsWUFBWSxHQUFHLFNBQVMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsRUFBRSxRQUFRLENBQUM7YUFDbkUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNiLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDdEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNsQyxDQUFDO0lBQ0gsQ0FBQzs4R0FkVSxtQkFBbUI7a0dBQW5CLG1CQUFtQjs7MkZBQW5CLG1CQUFtQjtrQkFML0IsU0FBUzttQkFBQztvQkFDVCw4REFBOEQ7b0JBQzlELFFBQVEsRUFBRSxNQUFNO29CQUNoQixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBTdWJzY3JpcHRpb24sIGZyb21FdmVudCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgdGFrZSB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuQERpcmVjdGl2ZSh7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvZGlyZWN0aXZlLXNlbGVjdG9yXG4gIHNlbGVjdG9yOiAnZm9ybScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgRm9ybVN1Ym1pdERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gIHN1Ym1pdHRlZCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0KGZhbHNlKTtcbiAgcHJpdmF0ZSBzdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHtcbiAgICB0aGlzLnN1YnNjcmlwdGlvbiA9IGZyb21FdmVudCh0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ3N1Ym1pdCcpXG4gICAgICAucGlwZSh0YWtlKDEpKVxuICAgICAgLnN1YnNjcmliZSgoKSA9PiB0aGlzLnN1Ym1pdHRlZCQubmV4dCh0cnVlKSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICBpZiAodGhpcy5zdWJzY3JpcHRpb24pIHtcbiAgICAgIHRoaXMuc3Vic2NyaXB0aW9uLnVuc3Vic2NyaWJlKCk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -1,63 +0,0 @@
1
- import { Directive } from '@angular/core';
2
- import { Subject, fromEvent } from 'rxjs';
3
- import { filter, map, takeUntil } from 'rxjs/operators';
4
- import { KeyboardSelectAction } from '../components/keyboard-select.directive';
5
- import { ARROW_DOWN, ARROW_LEFT, ARROW_RIGHT, ARROW_UP, END, ENTER, ESCAPE, HOME, TAB } from '../helpers/key-codes.constants';
6
- import * as i0 from "@angular/core";
7
- export class KeyboardActionSourceDirective {
8
- constructor(element) {
9
- this.element = element;
10
- this.dontEmit = false;
11
- this.destroyed$ = new Subject();
12
- this.keyboardActions$ = fromEvent(this.element.nativeElement, 'keydown').pipe(filter((_event) => !this.dontEmit), map((event) => {
13
- switch (event.keyCode) {
14
- case ARROW_UP:
15
- event.preventDefault();
16
- return KeyboardSelectAction.PREV;
17
- case ARROW_DOWN:
18
- event.preventDefault();
19
- return KeyboardSelectAction.NEXT;
20
- case ARROW_LEFT:
21
- event.preventDefault();
22
- return KeyboardSelectAction.LEFT;
23
- case ARROW_RIGHT:
24
- event.preventDefault();
25
- return KeyboardSelectAction.RIGHT;
26
- case HOME:
27
- event.preventDefault();
28
- return KeyboardSelectAction.FIRST;
29
- case END:
30
- event.preventDefault();
31
- return KeyboardSelectAction.LAST;
32
- case ENTER:
33
- event.preventDefault();
34
- return KeyboardSelectAction.EXECUTE;
35
- case ESCAPE:
36
- case TAB:
37
- return KeyboardSelectAction.CLOSE;
38
- default:
39
- return null;
40
- }
41
- }), takeUntil(this.destroyed$));
42
- }
43
- blur() {
44
- this.element.nativeElement.blur();
45
- }
46
- ngOnDestroy() {
47
- this.destroyed$.next();
48
- }
49
- nativeElement() {
50
- return this.element?.nativeElement;
51
- }
52
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: KeyboardActionSourceDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
53
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: KeyboardActionSourceDirective, isStandalone: true, selector: "[lxKeyboardActionSource]", exportAs: ["keyboardActionSource"], ngImport: i0 }); }
54
- }
55
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: KeyboardActionSourceDirective, decorators: [{
56
- type: Directive,
57
- args: [{
58
- exportAs: 'keyboardActionSource',
59
- selector: '[lxKeyboardActionSource]',
60
- standalone: true
61
- }]
62
- }], ctorParameters: () => [{ type: i0.ElementRef }] });
63
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5Ym9hcmQtYWN0aW9uLXNvdXJjZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvc3JjL2xpYi9mb3Jtcy11aS9kaXJlY3RpdmVzL2tleWJvYXJkLWFjdGlvbi1zb3VyY2UuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXlCLE1BQU0sZUFBZSxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQy9FLE9BQU8sRUFBRSxVQUFVLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxNQUFNLGdDQUFnQyxDQUFDOztBQU85SCxNQUFNLE9BQU8sNkJBQTZCO0lBd0N4QyxZQUFvQixPQUFnQztRQUFoQyxZQUFPLEdBQVAsT0FBTyxDQUF5QjtRQXZDN0MsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUVmLGVBQVUsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO1FBRW5DLHFCQUFnQixHQUFHLFNBQVMsQ0FBZ0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsU0FBUyxDQUFDLENBQUMsSUFBSSxDQUM1RixNQUFNLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUNsQyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUNaLFFBQVEsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDO2dCQUN0QixLQUFLLFFBQVE7b0JBQ1gsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO29CQUN2QixPQUFPLG9CQUFvQixDQUFDLElBQUksQ0FBQztnQkFDbkMsS0FBSyxVQUFVO29CQUNiLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztvQkFDdkIsT0FBTyxvQkFBb0IsQ0FBQyxJQUFJLENBQUM7Z0JBQ25DLEtBQUssVUFBVTtvQkFDYixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7b0JBQ3ZCLE9BQU8sb0JBQW9CLENBQUMsSUFBSSxDQUFDO2dCQUNuQyxLQUFLLFdBQVc7b0JBQ2QsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO29CQUN2QixPQUFPLG9CQUFvQixDQUFDLEtBQUssQ0FBQztnQkFDcEMsS0FBSyxJQUFJO29CQUNQLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztvQkFDdkIsT0FBTyxvQkFBb0IsQ0FBQyxLQUFLLENBQUM7Z0JBQ3BDLEtBQUssR0FBRztvQkFDTixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7b0JBQ3ZCLE9BQU8sb0JBQW9CLENBQUMsSUFBSSxDQUFDO2dCQUNuQyxLQUFLLEtBQUs7b0JBQ1IsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO29CQUN2QixPQUFPLG9CQUFvQixDQUFDLE9BQU8sQ0FBQztnQkFDdEMsS0FBSyxNQUFNLENBQUM7Z0JBQ1osS0FBSyxHQUFHO29CQUNOLE9BQU8sb0JBQW9CLENBQUMsS0FBSyxDQUFDO2dCQUNwQztvQkFDRSxPQUFPLElBQUksQ0FBQztZQUNoQixDQUFDO1FBQ0gsQ0FBQyxDQUFDLEVBQ0YsU0FBUyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FDM0IsQ0FBQztJQUVxRCxDQUFDO0lBRXhELElBQUk7UUFDRixJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNwQyxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELGFBQWE7UUFDWCxPQUFPLElBQUksQ0FBQyxPQUFPLEVBQUUsYUFBYSxDQUFDO0lBQ3JDLENBQUM7OEdBcERVLDZCQUE2QjtrR0FBN0IsNkJBQTZCOzsyRkFBN0IsNkJBQTZCO2tCQUx6QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQkFBc0I7b0JBQ2hDLFFBQVEsRUFBRSwwQkFBMEI7b0JBQ3BDLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdWJqZWN0LCBmcm9tRXZlbnQgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IGZpbHRlciwgbWFwLCB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBLZXlib2FyZFNlbGVjdEFjdGlvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMva2V5Ym9hcmQtc2VsZWN0LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBBUlJPV19ET1dOLCBBUlJPV19MRUZULCBBUlJPV19SSUdIVCwgQVJST1dfVVAsIEVORCwgRU5URVIsIEVTQ0FQRSwgSE9NRSwgVEFCIH0gZnJvbSAnLi4vaGVscGVycy9rZXktY29kZXMuY29uc3RhbnRzJztcblxuQERpcmVjdGl2ZSh7XG4gIGV4cG9ydEFzOiAna2V5Ym9hcmRBY3Rpb25Tb3VyY2UnLFxuICBzZWxlY3RvcjogJ1tseEtleWJvYXJkQWN0aW9uU291cmNlXScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgS2V5Ym9hcmRBY3Rpb25Tb3VyY2VEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuICBwdWJsaWMgZG9udEVtaXQgPSBmYWxzZTtcblxuICByZWFkb25seSBkZXN0cm95ZWQkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICBwdWJsaWMga2V5Ym9hcmRBY3Rpb25zJCA9IGZyb21FdmVudDxLZXlib2FyZEV2ZW50Pih0aGlzLmVsZW1lbnQubmF0aXZlRWxlbWVudCwgJ2tleWRvd24nKS5waXBlKFxuICAgIGZpbHRlcigoX2V2ZW50KSA9PiAhdGhpcy5kb250RW1pdCksXG4gICAgbWFwKChldmVudCkgPT4ge1xuICAgICAgc3dpdGNoIChldmVudC5rZXlDb2RlKSB7XG4gICAgICAgIGNhc2UgQVJST1dfVVA6XG4gICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICByZXR1cm4gS2V5Ym9hcmRTZWxlY3RBY3Rpb24uUFJFVjtcbiAgICAgICAgY2FzZSBBUlJPV19ET1dOOlxuICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgcmV0dXJuIEtleWJvYXJkU2VsZWN0QWN0aW9uLk5FWFQ7XG4gICAgICAgIGNhc2UgQVJST1dfTEVGVDpcbiAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgIHJldHVybiBLZXlib2FyZFNlbGVjdEFjdGlvbi5MRUZUO1xuICAgICAgICBjYXNlIEFSUk9XX1JJR0hUOlxuICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgcmV0dXJuIEtleWJvYXJkU2VsZWN0QWN0aW9uLlJJR0hUO1xuICAgICAgICBjYXNlIEhPTUU6XG4gICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICByZXR1cm4gS2V5Ym9hcmRTZWxlY3RBY3Rpb24uRklSU1Q7XG4gICAgICAgIGNhc2UgRU5EOlxuICAgICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgICAgcmV0dXJuIEtleWJvYXJkU2VsZWN0QWN0aW9uLkxBU1Q7XG4gICAgICAgIGNhc2UgRU5URVI6XG4gICAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICByZXR1cm4gS2V5Ym9hcmRTZWxlY3RBY3Rpb24uRVhFQ1VURTtcbiAgICAgICAgY2FzZSBFU0NBUEU6XG4gICAgICAgIGNhc2UgVEFCOlxuICAgICAgICAgIHJldHVybiBLZXlib2FyZFNlbGVjdEFjdGlvbi5DTE9TRTtcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICByZXR1cm4gbnVsbDtcbiAgICAgIH1cbiAgICB9KSxcbiAgICB0YWtlVW50aWwodGhpcy5kZXN0cm95ZWQkKVxuICApO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudDogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4pIHt9XG5cbiAgYmx1cigpIHtcbiAgICB0aGlzLmVsZW1lbnQubmF0aXZlRWxlbWVudC5ibHVyKCk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmRlc3Ryb3llZCQubmV4dCgpO1xuICB9XG5cbiAgbmF0aXZlRWxlbWVudCgpOiBIVE1MRWxlbWVudCB7XG4gICAgcmV0dXJuIHRoaXMuZWxlbWVudD8ubmF0aXZlRWxlbWVudDtcbiAgfVxufVxuIl19
@@ -1,39 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { Directive, Input } from '@angular/core';
3
- import { Subject } from 'rxjs';
4
- import { takeUntil } from 'rxjs/operators';
5
- import { getCssVariable } from '../../shared/misc-helpers';
6
- import { Observe } from '../../shared/observe';
7
- import * as i0 from "@angular/core";
8
- export class MarkInvalidDirective {
9
- constructor(element, renderer) {
10
- this.element = element;
11
- this.renderer = renderer;
12
- this.lxMarkInvalid = false;
13
- this.destroyed$ = new Subject();
14
- }
15
- ngOnInit() {
16
- this.lxMarkInvalid$.pipe(takeUntil(this.destroyed$)).subscribe((invalid) => {
17
- const border = invalid ? `1px solid ${getCssVariable('--lx-color-danger')}` : '';
18
- this.renderer.setStyle(this.element.nativeElement, 'border', border);
19
- });
20
- }
21
- ngOnDestroy() {
22
- this.destroyed$.next();
23
- }
24
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: MarkInvalidDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
25
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: MarkInvalidDirective, isStandalone: true, selector: "[lxMarkInvalid]", inputs: { lxMarkInvalid: "lxMarkInvalid" }, ngImport: i0 }); }
26
- }
27
- __decorate([
28
- Observe('lxMarkInvalid')
29
- ], MarkInvalidDirective.prototype, "lxMarkInvalid$", void 0);
30
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: MarkInvalidDirective, decorators: [{
31
- type: Directive,
32
- args: [{
33
- selector: '[lxMarkInvalid]',
34
- standalone: true
35
- }]
36
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { lxMarkInvalid: [{
37
- type: Input
38
- }], lxMarkInvalid$: [] } });
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFyay1pbnZhbGlkLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9zcmMvbGliL2Zvcm1zLXVpL2RpcmVjdGl2ZXMvbWFyay1pbnZhbGlkLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQWdDLE1BQU0sZUFBZSxDQUFDO0FBQzNGLE9BQU8sRUFBYyxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDM0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0FBTS9DLE1BQU0sT0FBTyxvQkFBb0I7SUFNL0IsWUFDVSxPQUFnQyxFQUNoQyxRQUFtQjtRQURuQixZQUFPLEdBQVAsT0FBTyxDQUF5QjtRQUNoQyxhQUFRLEdBQVIsUUFBUSxDQUFXO1FBUHBCLGtCQUFhLEdBQVksS0FBSyxDQUFDO1FBRy9CLGVBQVUsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO0lBS3ZDLENBQUM7SUFFSixRQUFRO1FBQ04sSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFO1lBQ3pFLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxDQUFDLENBQUMsYUFBYSxjQUFjLENBQUMsbUJBQW1CLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDakYsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3ZFLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3pCLENBQUM7OEdBcEJVLG9CQUFvQjtrR0FBcEIsb0JBQW9COztBQUVMO0lBQXpCLE9BQU8sQ0FBQyxlQUFlLENBQUM7NERBQXNDOzJGQUZwRCxvQkFBb0I7a0JBSmhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsVUFBVSxFQUFFLElBQUk7aUJBQ2pCO3VHQUVVLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ29CLGNBQWMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0LCBPbkRlc3Ryb3ksIE9uSW5pdCwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBnZXRDc3NWYXJpYWJsZSB9IGZyb20gJy4uLy4uL3NoYXJlZC9taXNjLWhlbHBlcnMnO1xuaW1wb3J0IHsgT2JzZXJ2ZSB9IGZyb20gJy4uLy4uL3NoYXJlZC9vYnNlcnZlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2x4TWFya0ludmFsaWRdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBNYXJrSW52YWxpZERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgQElucHV0KCkgbHhNYXJrSW52YWxpZDogYm9vbGVhbiA9IGZhbHNlO1xuICBAT2JzZXJ2ZSgnbHhNYXJrSW52YWxpZCcpIGx4TWFya0ludmFsaWQkITogT2JzZXJ2YWJsZTxib29sZWFuPjtcblxuICByZWFkb25seSBkZXN0cm95ZWQkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGVsZW1lbnQ6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LFxuICAgIHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMlxuICApIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5seE1hcmtJbnZhbGlkJC5waXBlKHRha2VVbnRpbCh0aGlzLmRlc3Ryb3llZCQpKS5zdWJzY3JpYmUoKGludmFsaWQpID0+IHtcbiAgICAgIGNvbnN0IGJvcmRlciA9IGludmFsaWQgPyBgMXB4IHNvbGlkICR7Z2V0Q3NzVmFyaWFibGUoJy0tbHgtY29sb3ItZGFuZ2VyJyl9YCA6ICcnO1xuICAgICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZSh0aGlzLmVsZW1lbnQubmF0aXZlRWxlbWVudCwgJ2JvcmRlcicsIGJvcmRlcik7XG4gICAgfSk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmRlc3Ryb3llZCQubmV4dCgpO1xuICB9XG59XG4iXX0=
@@ -1,131 +0,0 @@
1
- import { Directive, Input, Self } from '@angular/core';
2
- import { FormControl, Validators } from '@angular/forms';
3
- import { Subject } from 'rxjs';
4
- import { takeUntil } from 'rxjs/operators';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/forms";
7
- export class MaxLengthCounterDirective {
8
- constructor(el, renderer, ngControl) {
9
- this.el = el;
10
- this.renderer = renderer;
11
- this.ngControl = ngControl;
12
- this.lxMaxLengthCounter = null;
13
- this.counterElement = null;
14
- this.destroy$ = new Subject();
15
- }
16
- ngOnInit() {
17
- this.setupMaxLengthValidation();
18
- this.connectCounter();
19
- this.updateCounter();
20
- this.subscribeToValueChanges();
21
- this.setupInputRestriction();
22
- this.checkForInitialOversize();
23
- }
24
- ngOnDestroy() {
25
- this.destroy$.next();
26
- this.destroy$.complete();
27
- }
28
- setupMaxLengthValidation() {
29
- const maxLength = this.getMaxLength();
30
- const control = this.ngControl.control;
31
- if (maxLength !== null && control) {
32
- const validators = control.validator ? [control.validator, Validators.maxLength(maxLength)] : Validators.maxLength(maxLength);
33
- control.setValidators(validators);
34
- control.updateValueAndValidity();
35
- }
36
- }
37
- getMaxLength() {
38
- if (this.lxMaxLengthCounter) {
39
- return this.lxMaxLengthCounter;
40
- }
41
- const control = this.ngControl.control;
42
- const validatorFn = control?.validator;
43
- const errors = validatorFn?.(new FormControl({ length: Infinity }));
44
- const requiredLength = errors?.['maxlength']['requiredLength'];
45
- this.lxMaxLengthCounter = requiredLength ? requiredLength.toString() : null;
46
- if (this.lxMaxLengthCounter === null) {
47
- console.warn('lxMaxLength directive is used without a value or a control with a maxLength validator');
48
- }
49
- return requiredLength;
50
- }
51
- connectCounter() {
52
- this.el.nativeElement.classList.add('lx-max-length-counter-input');
53
- if (this.lxMaxLengthCounterRef) {
54
- this.counterElement = this.lxMaxLengthCounterRef;
55
- }
56
- else {
57
- this.createCounter();
58
- }
59
- }
60
- createCounter() {
61
- this.counterElement = this.renderer.createElement('span');
62
- this.renderer.addClass(this.counterElement, 'lx-max-length-counter');
63
- const nextSibling = this.el.nativeElement.nextSibling;
64
- if (nextSibling) {
65
- this.renderer.insertBefore(this.el.nativeElement.parentNode, this.counterElement, nextSibling);
66
- }
67
- else {
68
- this.renderer.appendChild(this.el.nativeElement.parentNode, this.counterElement);
69
- }
70
- this.destroy$.subscribe(() => {
71
- this.renderer.removeChild(this.el.nativeElement.parentNode, this.counterElement);
72
- });
73
- }
74
- updateCounter() {
75
- if (this.counterElement) {
76
- const currentLength = this.ngControl.value ? this.ngControl.value.length : 0;
77
- const maxLength = this.getMaxLength();
78
- this.renderer.setProperty(this.counterElement, 'textContent', `${currentLength} / ${maxLength}`);
79
- }
80
- }
81
- subscribeToValueChanges() {
82
- const control = this.ngControl.control;
83
- if (control) {
84
- control.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {
85
- this.updateCounter();
86
- });
87
- }
88
- }
89
- setupInputRestriction() {
90
- const maxLength = this.getMaxLength();
91
- if (maxLength !== null) {
92
- this.renderer.listen(this.el.nativeElement, 'beforeinput', (event) => {
93
- const input = event.target;
94
- const selectionStart = input.selectionStart || 0;
95
- const selectionEnd = input.selectionEnd || 0;
96
- const newValue = input.value.slice(0, selectionStart) + (event.data || '') + input.value.slice(selectionEnd);
97
- // Prevent input if the new value exceeds the max length and grows
98
- if (newValue.length > maxLength && newValue.length > input.value.length) {
99
- event.preventDefault();
100
- }
101
- });
102
- this.renderer.listen(this.el.nativeElement, 'input', () => {
103
- this.updateCounter();
104
- });
105
- }
106
- }
107
- checkForInitialOversize() {
108
- const maxLength = this.getMaxLength();
109
- const value = this.ngControl.value;
110
- if (maxLength !== null && value && value.length > maxLength) {
111
- this.ngControl.control?.markAsDirty({ onlySelf: true });
112
- this.ngControl.control?.updateValueAndValidity({ onlySelf: true });
113
- }
114
- }
115
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: MaxLengthCounterDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.NgControl, self: true }], target: i0.ɵɵFactoryTarget.Directive }); }
116
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: MaxLengthCounterDirective, isStandalone: true, selector: "[lxMaxLengthCounter]", inputs: { lxMaxLengthCounter: "lxMaxLengthCounter", lxMaxLengthCounterRef: "lxMaxLengthCounterRef" }, ngImport: i0 }); }
117
- }
118
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: MaxLengthCounterDirective, decorators: [{
119
- type: Directive,
120
- args: [{
121
- selector: '[lxMaxLengthCounter]',
122
- standalone: true
123
- }]
124
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.NgControl, decorators: [{
125
- type: Self
126
- }] }], propDecorators: { lxMaxLengthCounter: [{
127
- type: Input
128
- }], lxMaxLengthCounterRef: [{
129
- type: Input
130
- }] } });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"max-length-counter.directive.js","sourceRoot":"","sources":["../../../../../../../libs/components/src/lib/forms-ui/directives/max-length-counter.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnDestroy, OnInit, Renderer2, Self } from '@angular/core';\nimport { FormControl, NgControl, Validators } from '@angular/forms';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\n@Directive({\n  selector: '[lxMaxLengthCounter]',\n  standalone: true\n})\nexport class MaxLengthCounterDirective implements OnInit, OnDestroy {\n  @Input() lxMaxLengthCounter: number | null = null;\n  @Input() lxMaxLengthCounterRef?: HTMLSpanElement;\n  private counterElement: HTMLElement | null = null;\n\n  private destroy$ = new Subject<void>();\n\n  constructor(\n    private el: ElementRef,\n    private renderer: Renderer2,\n    @Self() private ngControl: NgControl\n  ) {}\n\n  ngOnInit() {\n    this.setupMaxLengthValidation();\n    this.connectCounter();\n    this.updateCounter();\n    this.subscribeToValueChanges();\n    this.setupInputRestriction();\n    this.checkForInitialOversize();\n  }\n\n  ngOnDestroy() {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  private setupMaxLengthValidation() {\n    const maxLength = this.getMaxLength();\n    const control = this.ngControl.control;\n\n    if (maxLength !== null && control) {\n      const validators = control.validator ? [control.validator, Validators.maxLength(maxLength)] : Validators.maxLength(maxLength);\n      control.setValidators(validators);\n      control.updateValueAndValidity();\n    }\n  }\n\n  private getMaxLength(): number | null {\n    if (this.lxMaxLengthCounter) {\n      return this.lxMaxLengthCounter;\n    }\n    const control = this.ngControl.control;\n    const validatorFn = control?.validator;\n    const errors = validatorFn?.(new FormControl({ length: Infinity }));\n    const requiredLength = errors?.['maxlength']['requiredLength'];\n    this.lxMaxLengthCounter = requiredLength ? requiredLength.toString() : null;\n    if (this.lxMaxLengthCounter === null) {\n      console.warn('lxMaxLength directive is used without a value or a control with a maxLength validator');\n    }\n    return requiredLength;\n  }\n\n  private connectCounter() {\n    this.el.nativeElement.classList.add('lx-max-length-counter-input');\n    if (this.lxMaxLengthCounterRef) {\n      this.counterElement = this.lxMaxLengthCounterRef;\n    } else {\n      this.createCounter();\n    }\n  }\n\n  private createCounter() {\n    this.counterElement = this.renderer.createElement('span');\n    this.renderer.addClass(this.counterElement, 'lx-max-length-counter');\n    const nextSibling = this.el.nativeElement.nextSibling;\n    if (nextSibling) {\n      this.renderer.insertBefore(this.el.nativeElement.parentNode, this.counterElement, nextSibling);\n    } else {\n      this.renderer.appendChild(this.el.nativeElement.parentNode, this.counterElement);\n    }\n    this.destroy$.subscribe(() => {\n      this.renderer.removeChild(this.el.nativeElement.parentNode, this.counterElement);\n    });\n  }\n\n  private updateCounter() {\n    if (this.counterElement) {\n      const currentLength = this.ngControl.value ? this.ngControl.value.length : 0;\n      const maxLength = this.getMaxLength();\n      this.renderer.setProperty(this.counterElement, 'textContent', `${currentLength} / ${maxLength}`);\n    }\n  }\n\n  private subscribeToValueChanges() {\n    const control = this.ngControl.control;\n    if (control) {\n      control.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {\n        this.updateCounter();\n      });\n    }\n  }\n\n  private setupInputRestriction() {\n    const maxLength = this.getMaxLength();\n    if (maxLength !== null) {\n      this.renderer.listen(this.el.nativeElement, 'beforeinput', (event: InputEvent) => {\n        const input = event.target as HTMLInputElement;\n        const selectionStart = input.selectionStart || 0;\n        const selectionEnd = input.selectionEnd || 0;\n        const newValue = input.value.slice(0, selectionStart) + (event.data || '') + input.value.slice(selectionEnd);\n\n        // Prevent input if the new value exceeds the max length and grows\n        if (newValue.length > maxLength && newValue.length > input.value.length) {\n          event.preventDefault();\n        }\n      });\n\n      this.renderer.listen(this.el.nativeElement, 'input', () => {\n        this.updateCounter();\n      });\n    }\n  }\n  private checkForInitialOversize() {\n    const maxLength = this.getMaxLength();\n    const value = this.ngControl.value;\n    if (maxLength !== null && value && value.length > maxLength) {\n      this.ngControl.control?.markAsDirty({ onlySelf: true });\n      this.ngControl.control?.updateValueAndValidity({ onlySelf: true });\n    }\n  }\n}\n"]}