@bcgov/nr-ngx-component-lib 0.0.1

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 (82) hide show
  1. package/components/button/button.component.d.ts +22 -0
  2. package/components/cell-content/cell-content.component.d.ts +12 -0
  3. package/components/device-view/device-view.component.d.ts +12 -0
  4. package/components/expansion-panel/expansion-panel.component.d.ts +26 -0
  5. package/components/filter-container/filter-container.component.d.ts +7 -0
  6. package/components/filter-date/filter-date.component.d.ts +12 -0
  7. package/components/filter-search/filter-search.component.d.ts +18 -0
  8. package/components/filter-select/filter-select.component.d.ts +63 -0
  9. package/components/filters-panel/filters-panel.component.d.ts +13 -0
  10. package/components/form-field/form-field.component.d.ts +13 -0
  11. package/components/form-layout/form-layout.component.d.ts +5 -0
  12. package/components/gap/gap.component.d.ts +9 -0
  13. package/components/page-container/page-container.component.d.ts +5 -0
  14. package/components/page-header/page-header.component.d.ts +6 -0
  15. package/components/row-list-desktop/row-list-desktop.component.d.ts +5 -0
  16. package/components/row-list-mobile/row-list-mobile.component.d.ts +5 -0
  17. package/components/row-list-pagination/row-list-pagination.component.d.ts +31 -0
  18. package/components/row-list-sorting/row-list-sorting.component.d.ts +18 -0
  19. package/components/snackbar/snackbar.component.d.ts +15 -0
  20. package/directives/configuration-subscriber.base.d.ts +14 -0
  21. package/directives/row-list.base.d.ts +55 -0
  22. package/esm2022/bcgov-nr-ngx-component-lib.mjs +5 -0
  23. package/esm2022/components/button/button.component.mjs +69 -0
  24. package/esm2022/components/cell-content/cell-content.component.mjs +34 -0
  25. package/esm2022/components/device-view/device-view.component.mjs +34 -0
  26. package/esm2022/components/expansion-panel/expansion-panel.component.mjs +144 -0
  27. package/esm2022/components/filter-container/filter-container.component.mjs +20 -0
  28. package/esm2022/components/filter-date/filter-date.component.mjs +43 -0
  29. package/esm2022/components/filter-search/filter-search.component.mjs +52 -0
  30. package/esm2022/components/filter-select/filter-select.component.mjs +269 -0
  31. package/esm2022/components/filters-panel/filters-panel.component.mjs +39 -0
  32. package/esm2022/components/form-field/form-field.component.mjs +103 -0
  33. package/esm2022/components/form-layout/form-layout.component.mjs +11 -0
  34. package/esm2022/components/gap/gap.component.mjs +21 -0
  35. package/esm2022/components/page-container/page-container.component.mjs +11 -0
  36. package/esm2022/components/page-header/page-header.component.mjs +19 -0
  37. package/esm2022/components/row-list-desktop/row-list-desktop.component.mjs +11 -0
  38. package/esm2022/components/row-list-mobile/row-list-mobile.component.mjs +11 -0
  39. package/esm2022/components/row-list-pagination/row-list-pagination.component.mjs +106 -0
  40. package/esm2022/components/row-list-sorting/row-list-sorting.component.mjs +44 -0
  41. package/esm2022/components/snackbar/snackbar.component.mjs +26 -0
  42. package/esm2022/directives/configuration-subscriber.base.mjs +28 -0
  43. package/esm2022/directives/row-list.base.mjs +150 -0
  44. package/esm2022/nr-ngx-component-lib.module.mjs +227 -0
  45. package/esm2022/public-api.mjs +33 -0
  46. package/esm2022/services/configuration.service.mjs +38 -0
  47. package/esm2022/services/page-state.service.mjs +28 -0
  48. package/esm2022/services/snackbar-util.service.mjs +69 -0
  49. package/esm2022/utils/code-table.util.mjs +23 -0
  50. package/esm2022/utils/date.util.mjs +15 -0
  51. package/esm2022/utils/filter.util.mjs +25 -0
  52. package/esm2022/utils/row-list.util.mjs +44 -0
  53. package/fesm2022/bcgov-nr-ngx-component-lib.mjs +1617 -0
  54. package/fesm2022/bcgov-nr-ngx-component-lib.mjs.map +1 -0
  55. package/index.d.ts +5 -0
  56. package/nr-ngx-component-lib.module.d.ts +46 -0
  57. package/package.json +22 -0
  58. package/public-api.d.ts +29 -0
  59. package/services/configuration.service.d.ts +16 -0
  60. package/services/page-state.service.d.ts +9 -0
  61. package/services/snackbar-util.service.d.ts +16 -0
  62. package/styles/bc-sans/FONTLOG_README.txt +30 -0
  63. package/styles/bc-sans/LICENSE_OFL.txt +94 -0
  64. package/styles/bc-sans/css/BCSans.css +28 -0
  65. package/styles/bc-sans/fonts/BCSans-Bold.woff +0 -0
  66. package/styles/bc-sans/fonts/BCSans-Bold.woff2 +0 -0
  67. package/styles/bc-sans/fonts/BCSans-BoldItalic.woff +0 -0
  68. package/styles/bc-sans/fonts/BCSans-BoldItalic.woff2 +0 -0
  69. package/styles/bc-sans/fonts/BCSans-Italic.woff +0 -0
  70. package/styles/bc-sans/fonts/BCSans-Italic.woff2 +0 -0
  71. package/styles/bc-sans/fonts/BCSans-Regular.woff +0 -0
  72. package/styles/bc-sans/fonts/BCSans-Regular.woff2 +0 -0
  73. package/styles/global.scss +34 -0
  74. package/styles/include/mat-button.scss +71 -0
  75. package/styles/include/mat-checkbox.scss +44 -0
  76. package/styles/include/mat-icon.scss +30 -0
  77. package/styles/include/mat-radio-button.scss +19 -0
  78. package/styles/material.scss +40 -0
  79. package/utils/code-table.util.d.ts +12 -0
  80. package/utils/date.util.d.ts +14 -0
  81. package/utils/filter.util.d.ts +4 -0
  82. package/utils/row-list.util.d.ts +16 -0
@@ -0,0 +1,269 @@
1
+ import { Overlay } from "@angular/cdk/overlay";
2
+ import { TemplatePortal } from "@angular/cdk/portal";
3
+ import { booleanAttribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, inject, Input, numberAttribute, Output, ViewChild, ViewContainerRef } from "@angular/core";
4
+ import { FormControl } from "@angular/forms";
5
+ import { fromEvent } from "rxjs";
6
+ import { filter } from "rxjs/operators";
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/forms";
9
+ import * as i2 from "@angular/material/button";
10
+ import * as i3 from "@angular/material/form-field";
11
+ import * as i4 from "@angular/material/icon";
12
+ import * as i5 from "@angular/material/input";
13
+ import * as i6 from "@angular/material/list";
14
+ import * as i7 from "@angular/material/tooltip";
15
+ /**
16
+ * A filter select component that allows users to select multiple options from a list.
17
+ *
18
+ * Features:
19
+ * - Multi-select with optional maximum selection limit
20
+ * - Search/filter functionality
21
+ * - Tooltips for long descriptions
22
+ * - Summary display of selected items
23
+ */
24
+ export class FilterSelectComponent {
25
+ constructor() {
26
+ this.placeholder = 'Filter...';
27
+ this.selectMax = 0;
28
+ this.tooltips = true;
29
+ this.summary = true;
30
+ this.clear = true;
31
+ this.valueChange = new EventEmitter();
32
+ this.floatLabel = 'auto';
33
+ this.isFiltered = false;
34
+ this.isOpen = false;
35
+ this.hasValue = false;
36
+ this.selection = new FormControl();
37
+ this.match = (o) => true;
38
+ this.changeDetectorRef = inject(ChangeDetectorRef);
39
+ this.overlay = inject(Overlay);
40
+ this.viewContainerRef = inject(ViewContainerRef);
41
+ }
42
+ ngOnChanges(changes) {
43
+ if (this.isOpen)
44
+ return;
45
+ if (changes.options) {
46
+ let pv = JSON.stringify(changes.options.previousValue);
47
+ let cv = JSON.stringify(changes.options.currentValue);
48
+ if (pv != cv) {
49
+ this.selection.setValue(null);
50
+ this.setInputToSelection();
51
+ this.setFilter();
52
+ }
53
+ }
54
+ if (changes.value) {
55
+ let pv = JSON.stringify(changes.value.previousValue);
56
+ let cv = JSON.stringify(changes.value.currentValue);
57
+ if (pv != cv) {
58
+ if (this.value) {
59
+ this.hasValue = this.value.length > 0;
60
+ this.selection.setValue(this.value);
61
+ if (this.selectMax > 1 && this.value.length >= this.selectMax) {
62
+ this.selection.disable();
63
+ }
64
+ else {
65
+ this.selection.enable();
66
+ }
67
+ }
68
+ else {
69
+ this.hasValue = false;
70
+ this.selection.setValue(null);
71
+ this.selection.enable();
72
+ }
73
+ this.setFilter();
74
+ this.setInputToSelection();
75
+ this.changeDetectorRef.detectChanges();
76
+ }
77
+ }
78
+ }
79
+ get single() {
80
+ return this.selectMax == 1;
81
+ }
82
+ emitValueChange() {
83
+ this.hasValue = (this.selection.value || []).length > 0;
84
+ this.valueChange.emit(this.selection.value || []);
85
+ }
86
+ open() {
87
+ if (this.isOpen)
88
+ return;
89
+ this.isOpen = true;
90
+ this.floatLabel = 'always';
91
+ this.inputValue = '';
92
+ // Create overlay
93
+ const positionStrategy = this.overlay
94
+ .position()
95
+ .flexibleConnectedTo(this.trigger)
96
+ .withPositions([
97
+ {
98
+ originX: 'start',
99
+ originY: 'bottom',
100
+ overlayX: 'start',
101
+ overlayY: 'top',
102
+ offsetY: 0
103
+ },
104
+ {
105
+ originX: 'start',
106
+ originY: 'top',
107
+ overlayX: 'start',
108
+ overlayY: 'bottom',
109
+ offsetY: 0
110
+ }
111
+ ])
112
+ .withPush(false);
113
+ const scrollStrategy = this.overlay.scrollStrategies.reposition();
114
+ this.overlayRef = this.overlay.create({
115
+ positionStrategy,
116
+ scrollStrategy,
117
+ hasBackdrop: false,
118
+ maxWidth: this.trigger.nativeElement.offsetWidth * 2,
119
+ minWidth: this.trigger.nativeElement.offsetWidth,
120
+ maxHeight: 300,
121
+ });
122
+ // Attach template
123
+ const portal = new TemplatePortal(this.overlayTemplate, this.viewContainerRef);
124
+ this.overlayRef.attach(portal);
125
+ // Listen to document clicks after a small delay to avoid closing immediately
126
+ setTimeout(() => {
127
+ this.clickSubscription = fromEvent(document, 'click')
128
+ .pipe(filter((event) => {
129
+ const clickTarget = event.target;
130
+ const triggerEl = this.trigger.nativeElement;
131
+ const overlayEl = this.overlayRef?.overlayElement;
132
+ // Only close if click is outside both trigger and overlay
133
+ return !triggerEl.contains(clickTarget)
134
+ && !overlayEl?.contains(clickTarget);
135
+ }))
136
+ .subscribe(() => {
137
+ this.close();
138
+ });
139
+ });
140
+ // Focus input after overlay is attached
141
+ setTimeout(() => {
142
+ this.filterInput?.nativeElement.focus();
143
+ // prevent list from scrolling when selection changes
144
+ this.overlayRef.overlayElement.children[0].scroll(0, 1);
145
+ });
146
+ this.setFilter();
147
+ this.openingValue = JSON.stringify(this.selection.value);
148
+ }
149
+ close() {
150
+ if (!this.isOpen)
151
+ return;
152
+ this.isOpen = false;
153
+ this.setInputToSelection();
154
+ this.floatLabel = 'auto';
155
+ if (this.clickSubscription) {
156
+ this.clickSubscription.unsubscribe();
157
+ this.clickSubscription = null;
158
+ }
159
+ if (this.overlayRef) {
160
+ this.overlayRef.dispose();
161
+ this.overlayRef = null;
162
+ }
163
+ this.changeDetectorRef.detectChanges();
164
+ let closingValue = JSON.stringify(this.selection.value);
165
+ if (this.openingValue != closingValue)
166
+ this.emitValueChange();
167
+ }
168
+ setInputToSelection() {
169
+ this.inputValue = this.selection?.value?.map(c => this.descriptionForCode(c)).join(', ') || null;
170
+ }
171
+ onInput(ev) {
172
+ this.setFilter(ev?.target?.value);
173
+ }
174
+ setFilter(text) {
175
+ let t = text?.trim().toLowerCase();
176
+ if (t) {
177
+ this.isFiltered = true;
178
+ this.match = (option) => option.description.toLowerCase().includes(t);
179
+ }
180
+ else {
181
+ this.isFiltered = false;
182
+ this.match = (o) => true;
183
+ }
184
+ this.changeDetectorRef.detectChanges();
185
+ }
186
+ matchesFilter(option) {
187
+ return this.match(option);
188
+ }
189
+ onSelectionChange(ev) {
190
+ if (this.single) {
191
+ this.close();
192
+ }
193
+ else {
194
+ this.filterInput?.nativeElement.focus();
195
+ }
196
+ if (this.selectMax > 1) {
197
+ if (this.selection.value.length >= this.selectMax) {
198
+ this.selection.disable();
199
+ }
200
+ else {
201
+ this.selection.enable();
202
+ }
203
+ }
204
+ this.changeDetectorRef.detectChanges();
205
+ }
206
+ onUpperSelectionChange(ev) {
207
+ setTimeout(() => {
208
+ let codes = this.selection.value.filter(c => c != ev.options[0].value);
209
+ this.selection.setValue(codes);
210
+ this.onSelectionChange(ev);
211
+ });
212
+ }
213
+ onCancelClick() {
214
+ this.selection.setValue(null);
215
+ this.selection.enable();
216
+ this.setInputToSelection();
217
+ this.emitValueChange();
218
+ }
219
+ onInputFocus() {
220
+ this.open();
221
+ }
222
+ descriptionForCode(code) {
223
+ return this.options.find(o => o.code == code)?.description;
224
+ }
225
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FilterSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
226
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: FilterSelectComponent, selector: "nrcl-filter-select", inputs: { label: "label", placeholder: "placeholder", hint: "hint", options: "options", value: "value", selectMax: ["selectMax", "selectMax", numberAttribute], tooltips: ["tooltips", "tooltips", booleanAttribute], summary: ["summary", "summary", booleanAttribute], clear: ["clear", "clear", booleanAttribute] }, outputs: { valueChange: "valueChange" }, host: { properties: { "class.has-value": "hasValue", "class.is-open": "isOpen", "class.is-closed": "!isOpen" } }, viewQueries: [{ propertyName: "trigger", first: true, predicate: ["trigger"], descendants: true, read: ElementRef }, { propertyName: "filterInput", first: true, predicate: ["filterInput"], descendants: true }, { propertyName: "overlayTemplate", first: true, predicate: ["overlayTemplate"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<mat-form-field #trigger\n [floatLabel]=\"floatLabel\"\n appearance=\"outline\"\n subscriptSizing=\"dynamic\"\n>\n @if ( label ) {\n <mat-label>{{ label }}</mat-label>\n }\n\n <input class=\"filter-input\" #searchInput\n matInput \n [placeholder]=\"placeholder\" \n [value]=\"inputValue\"\n (input)=\"onInput( $event )\"\n (keydown.escape)=\"close()\"\n (focus)=\"onInputFocus()\"\n [matTooltip]=\"inputValue\"\n >\n\n @if ( isOpen ) {\n <mat-icon matSuffix>arrow_drop_up</mat-icon>\n }\n @else if ( selection?.value?.length > 0 && clear ) {\n <button class=\"cancel\"\n mat-icon-button\n matSuffix\n (click)=\"onCancelClick($event); $event.stopPropagation()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n }\n @else {\n <mat-icon matSuffix>arrow_drop_down</mat-icon>\n } \n\n @if ( hint ) {\n <mat-hint>{{ hint }}</mat-hint>\n }\n</mat-form-field> \n\n<ng-template #overlayTemplate>\n <div class=\"filter-select-options\" [class.multiple]=\"!single\" [class.single]=\"single\">\n @if ( !isFiltered && !single && summary ) {\n @if ( selection?.value?.length > 0 && selection?.value?.length < options?.length ) {\n <div class=\"selection-overview\">\n <div class=\"summary\">{{ selection?.value?.length }} selected of {{ options?.length }}</div>\n\n <mat-selection-list\n (selectionChange)=\"onUpperSelectionChange( $event )\"\n >\n @for ( code of selection?.value; track code ) {\n <mat-list-option \n [value]=\"code\" \n togglePosition=\"before\"\n selected\n [matTooltip]=\"tooltips ? descriptionForCode( code ) : null\"\n matTooltipPosition=\"after\"\n >\n {{ descriptionForCode( code ) }}\n </mat-list-option>\n }\n </mat-selection-list>\n </div>\n }\n\n @if ( selection?.value?.length == options?.length ) {\n <div class=\"selection-overview\">\n <div class=\"summary\">All options selected</div>\n </div>\n }\n }\n\n <mat-selection-list\n [formControl]=\"selection\"\n (selectionChange)=\"onSelectionChange( $event )\"\n [multiple]=\"!single\"\n hideSingleSelectionIndicator\n >\n @for ( option of options; track option ) {\n <mat-list-option [class.hide]=\"!matchesFilter( option )\"\n [value]=\"option.code\" \n togglePosition=\"before\" \n [matTooltip]=\"tooltips ? option.description : null\"\n matTooltipPosition=\"after\" \n >\n {{ option.description }}\n </mat-list-option>\n }\n </mat-selection-list>\n </div>\n</ng-template>\n", styles: ["::ng-deep :root{--nrcl-filter-select-width: var( --nrcl-filter-width-default )}:host{--mat-form-field-container-height: calc( var( --nrcl-filter-height-default ) - 4px );--mat-form-field-container-vertical-padding: 10px;--mat-form-field-container-text-size: 15px;--mdc-outlined-text-field-focus-label-text-color: black;--mdc-outlined-text-field-hover-label-text-color: black;width:var(--nrcl-filter-select-width, var(--nrcl-filter-width-default));display:block}:host ::ng-deep .material-icons{font-family:Material Symbols Outlined;font-feature-settings:\"liga\"}:host ::ng-deep .mat-icon{width:var(--nrcl-icon-size);height:var(--nrcl-icon-size);font-size:var(--nrcl-icon-size);line-height:var(--nrcl-icon-size)}:host ::ng-deep button.mat-mdc-fab>.mat-icon,:host ::ng-deep button.mat-mdc-raised-button>.mat-icon,:host ::ng-deep button.mat-mdc-button>.mat-icon,:host ::ng-deep button.mat-mdc-icon-button>.mat-icon,:host ::ng-deep button.mat-mdc-outlined-button>.mat-icon,:host ::ng-deep button.mat-mdc-unelevated-button>.mat-icon,:host ::ng-deep button.mat-mdc-mini-fab .mat-mdc-menu-item>.mat-icon{width:var(--nrcl-icon-size);height:var(--nrcl-icon-size);font-size:var(--nrcl-icon-size);line-height:var(--nrcl-icon-size)}:host.has-value{--mdc-outlined-text-field-label-text-color: black}:host ::ng-deep .mat-mdc-form-field{width:100%}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper{background-color:#fff;height:var(--nrcl-filter-height-default);cursor:pointer}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-infix{width:var(--nrcl-filter-select-width, var(--nrcl-filter-width-default))}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-infix .filter-input{cursor:pointer}:host.is-open ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-infix .filter-input{cursor:text}:host .cancel{padding:0;width:36px;height:36px;display:flex;justify-content:center;align-items:center;cursor:default}::ng-deep .filter-select-options{--mdc-list-list-item-selected-container-color: #007bff;font-family:var(--nrcl-font-family);overflow-x:hidden;overflow-y:auto;padding:0;background:#fff;color:#000;border:1px solid #aaa;border-radius:4px;font-size:var(--nrcl-font-size);pointer-events:all;box-shadow:0 4px 5px #00000026;display:block;width:100%}::ng-deep .filter-select-options .selection-overview{background-color:#eee;border-bottom:1px solid black}::ng-deep .filter-select-options .selection-overview .summary{padding-top:4px;padding-left:4px;font-size:14px;color:#000000bc;font-family:var(--nrcl-font-family)}::ng-deep .filter-select-options .mat-mdc-selection-list{padding-top:0;padding-bottom:0}::ng-deep .filter-select-options .mat-mdc-selection-list .mat-mdc-list-option{height:30px;font-size:var(--nrcl-font-size);padding-left:4px;padding-right:8px}::ng-deep .filter-select-options .mat-mdc-selection-list .mat-mdc-list-option.hide{display:none}::ng-deep .filter-select-options .mat-mdc-selection-list .mat-mdc-list-option .mdc-list-item__start{margin:0;padding:0 8px}::ng-deep .filter-select-options .mat-mdc-selection-list .mat-mdc-list-option .mdc-list-item__primary-text{flex-grow:1;font-size:var(--nrcl-font-size)}::ng-deep .filter-select-options .mat-mdc-selection-list .mat-mdc-list-option.mdc-list-item--selected .mdc-list-item__primary-text{color:#fff}::ng-deep .filter-select-options.single .mat-mdc-selection-list .mat-mdc-list-option{padding-left:12px}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i6.MatSelectionList, selector: "mat-selection-list", inputs: ["color", "compareWith", "multiple", "hideSingleSelectionIndicator", "disabled"], outputs: ["selectionChange"], exportAs: ["matSelectionList"] }, { kind: "component", type: i6.MatListOption, selector: "mat-list-option", inputs: ["togglePosition", "checkboxPosition", "color", "value", "selected"], outputs: ["selectedChange"], exportAs: ["matListOption"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
227
+ }
228
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FilterSelectComponent, decorators: [{
229
+ type: Component,
230
+ args: [{ selector: "nrcl-filter-select", changeDetection: ChangeDetectionStrategy.OnPush, host: {
231
+ '[class.has-value]': "hasValue",
232
+ '[class.is-open]': "isOpen",
233
+ '[class.is-closed]': "!isOpen"
234
+ }, template: "<mat-form-field #trigger\n [floatLabel]=\"floatLabel\"\n appearance=\"outline\"\n subscriptSizing=\"dynamic\"\n>\n @if ( label ) {\n <mat-label>{{ label }}</mat-label>\n }\n\n <input class=\"filter-input\" #searchInput\n matInput \n [placeholder]=\"placeholder\" \n [value]=\"inputValue\"\n (input)=\"onInput( $event )\"\n (keydown.escape)=\"close()\"\n (focus)=\"onInputFocus()\"\n [matTooltip]=\"inputValue\"\n >\n\n @if ( isOpen ) {\n <mat-icon matSuffix>arrow_drop_up</mat-icon>\n }\n @else if ( selection?.value?.length > 0 && clear ) {\n <button class=\"cancel\"\n mat-icon-button\n matSuffix\n (click)=\"onCancelClick($event); $event.stopPropagation()\"\n >\n <mat-icon>close</mat-icon>\n </button>\n }\n @else {\n <mat-icon matSuffix>arrow_drop_down</mat-icon>\n } \n\n @if ( hint ) {\n <mat-hint>{{ hint }}</mat-hint>\n }\n</mat-form-field> \n\n<ng-template #overlayTemplate>\n <div class=\"filter-select-options\" [class.multiple]=\"!single\" [class.single]=\"single\">\n @if ( !isFiltered && !single && summary ) {\n @if ( selection?.value?.length > 0 && selection?.value?.length < options?.length ) {\n <div class=\"selection-overview\">\n <div class=\"summary\">{{ selection?.value?.length }} selected of {{ options?.length }}</div>\n\n <mat-selection-list\n (selectionChange)=\"onUpperSelectionChange( $event )\"\n >\n @for ( code of selection?.value; track code ) {\n <mat-list-option \n [value]=\"code\" \n togglePosition=\"before\"\n selected\n [matTooltip]=\"tooltips ? descriptionForCode( code ) : null\"\n matTooltipPosition=\"after\"\n >\n {{ descriptionForCode( code ) }}\n </mat-list-option>\n }\n </mat-selection-list>\n </div>\n }\n\n @if ( selection?.value?.length == options?.length ) {\n <div class=\"selection-overview\">\n <div class=\"summary\">All options selected</div>\n </div>\n }\n }\n\n <mat-selection-list\n [formControl]=\"selection\"\n (selectionChange)=\"onSelectionChange( $event )\"\n [multiple]=\"!single\"\n hideSingleSelectionIndicator\n >\n @for ( option of options; track option ) {\n <mat-list-option [class.hide]=\"!matchesFilter( option )\"\n [value]=\"option.code\" \n togglePosition=\"before\" \n [matTooltip]=\"tooltips ? option.description : null\"\n matTooltipPosition=\"after\" \n >\n {{ option.description }}\n </mat-list-option>\n }\n </mat-selection-list>\n </div>\n</ng-template>\n", styles: ["::ng-deep :root{--nrcl-filter-select-width: var( --nrcl-filter-width-default )}:host{--mat-form-field-container-height: calc( var( --nrcl-filter-height-default ) - 4px );--mat-form-field-container-vertical-padding: 10px;--mat-form-field-container-text-size: 15px;--mdc-outlined-text-field-focus-label-text-color: black;--mdc-outlined-text-field-hover-label-text-color: black;width:var(--nrcl-filter-select-width, var(--nrcl-filter-width-default));display:block}:host ::ng-deep .material-icons{font-family:Material Symbols Outlined;font-feature-settings:\"liga\"}:host ::ng-deep .mat-icon{width:var(--nrcl-icon-size);height:var(--nrcl-icon-size);font-size:var(--nrcl-icon-size);line-height:var(--nrcl-icon-size)}:host ::ng-deep button.mat-mdc-fab>.mat-icon,:host ::ng-deep button.mat-mdc-raised-button>.mat-icon,:host ::ng-deep button.mat-mdc-button>.mat-icon,:host ::ng-deep button.mat-mdc-icon-button>.mat-icon,:host ::ng-deep button.mat-mdc-outlined-button>.mat-icon,:host ::ng-deep button.mat-mdc-unelevated-button>.mat-icon,:host ::ng-deep button.mat-mdc-mini-fab .mat-mdc-menu-item>.mat-icon{width:var(--nrcl-icon-size);height:var(--nrcl-icon-size);font-size:var(--nrcl-icon-size);line-height:var(--nrcl-icon-size)}:host.has-value{--mdc-outlined-text-field-label-text-color: black}:host ::ng-deep .mat-mdc-form-field{width:100%}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper{background-color:#fff;height:var(--nrcl-filter-height-default);cursor:pointer}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-infix{width:var(--nrcl-filter-select-width, var(--nrcl-filter-width-default))}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-infix .filter-input{cursor:pointer}:host.is-open ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-infix .filter-input{cursor:text}:host .cancel{padding:0;width:36px;height:36px;display:flex;justify-content:center;align-items:center;cursor:default}::ng-deep .filter-select-options{--mdc-list-list-item-selected-container-color: #007bff;font-family:var(--nrcl-font-family);overflow-x:hidden;overflow-y:auto;padding:0;background:#fff;color:#000;border:1px solid #aaa;border-radius:4px;font-size:var(--nrcl-font-size);pointer-events:all;box-shadow:0 4px 5px #00000026;display:block;width:100%}::ng-deep .filter-select-options .selection-overview{background-color:#eee;border-bottom:1px solid black}::ng-deep .filter-select-options .selection-overview .summary{padding-top:4px;padding-left:4px;font-size:14px;color:#000000bc;font-family:var(--nrcl-font-family)}::ng-deep .filter-select-options .mat-mdc-selection-list{padding-top:0;padding-bottom:0}::ng-deep .filter-select-options .mat-mdc-selection-list .mat-mdc-list-option{height:30px;font-size:var(--nrcl-font-size);padding-left:4px;padding-right:8px}::ng-deep .filter-select-options .mat-mdc-selection-list .mat-mdc-list-option.hide{display:none}::ng-deep .filter-select-options .mat-mdc-selection-list .mat-mdc-list-option .mdc-list-item__start{margin:0;padding:0 8px}::ng-deep .filter-select-options .mat-mdc-selection-list .mat-mdc-list-option .mdc-list-item__primary-text{flex-grow:1;font-size:var(--nrcl-font-size)}::ng-deep .filter-select-options .mat-mdc-selection-list .mat-mdc-list-option.mdc-list-item--selected .mdc-list-item__primary-text{color:#fff}::ng-deep .filter-select-options.single .mat-mdc-selection-list .mat-mdc-list-option{padding-left:12px}\n"] }]
235
+ }], propDecorators: { label: [{
236
+ type: Input
237
+ }], placeholder: [{
238
+ type: Input
239
+ }], hint: [{
240
+ type: Input
241
+ }], options: [{
242
+ type: Input
243
+ }], value: [{
244
+ type: Input
245
+ }], selectMax: [{
246
+ type: Input,
247
+ args: [{ transform: numberAttribute }]
248
+ }], tooltips: [{
249
+ type: Input,
250
+ args: [{ transform: booleanAttribute }]
251
+ }], summary: [{
252
+ type: Input,
253
+ args: [{ transform: booleanAttribute }]
254
+ }], clear: [{
255
+ type: Input,
256
+ args: [{ transform: booleanAttribute }]
257
+ }], valueChange: [{
258
+ type: Output
259
+ }], trigger: [{
260
+ type: ViewChild,
261
+ args: ['trigger', { read: ElementRef }]
262
+ }], filterInput: [{
263
+ type: ViewChild,
264
+ args: ['filterInput']
265
+ }], overlayTemplate: [{
266
+ type: ViewChild,
267
+ args: ['overlayTemplate']
268
+ }] } });
269
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-select.component.js","sourceRoot":"","sources":["../../../../../projects/nr-ngx-component-lib/src/components/filter-select/filter-select.component.ts","../../../../../projects/nr-ngx-component-lib/src/components/filter-select/filter-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from \"@angular/cdk/overlay\";\nimport { TemplatePortal } from \"@angular/cdk/portal\";\nimport {\n    booleanAttribute,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    numberAttribute,\n    OnChanges,\n    Output,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef\n} from \"@angular/core\";\nimport { FormControl } from \"@angular/forms\";\nimport { MatSelectionListChange } from \"@angular/material/list\";\nimport { fromEvent } from \"rxjs\";\nimport { filter } from \"rxjs/operators\";\nimport { CodeDescription } from \"../../utils/code-table.util\";\n\n\n/**\n * A filter select component that allows users to select multiple options from a list.\n *\n * Features:\n * - Multi-select with optional maximum selection limit\n * - Search/filter functionality\n * - Tooltips for long descriptions\n * - Summary display of selected items\n */\n@Component( {\n    selector: \"nrcl-filter-select\",\n    templateUrl: \"./filter-select.component.html\",\n    styleUrl: \"./filter-select.component.scss\",\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class.has-value]': \"hasValue\",\n        '[class.is-open]': \"isOpen\",\n        '[class.is-closed]': \"!isOpen\"\n    }\n} )\nexport class FilterSelectComponent implements OnChanges {\n    @Input() label\n    @Input() placeholder = 'Filter...'\n    @Input() hint\n    @Input() options: CodeDescription[]\n    @Input() value: string[]\n    @Input( { transform: numberAttribute } ) selectMax = 0\n    @Input( { transform: booleanAttribute } ) tooltips = true\n    @Input( { transform: booleanAttribute } ) summary = true\n    @Input( { transform: booleanAttribute } ) clear = true\n\n    @Output() valueChange = new EventEmitter<string[]>();\n\n    floatLabel = 'auto'\n    inputValue\n    openingValue\n    isFiltered = false\n    isOpen = false\n    hasValue = false\n    overlayRef: OverlayRef\n    selection = new FormControl()\n    match: ( option: CodeDescription ) => boolean = ( o ) => true\n    clickSubscription\n\n    changeDetectorRef = inject( ChangeDetectorRef )\n    overlay = inject( Overlay )\n    viewContainerRef = inject( ViewContainerRef )\n\n    @ViewChild( 'trigger', { read: ElementRef } ) trigger!: ElementRef\n    @ViewChild( 'filterInput' ) filterInput!: ElementRef\n    @ViewChild( 'overlayTemplate' ) overlayTemplate!: TemplateRef<any>\n\n    ngOnChanges( changes: SimpleChanges ): void {\n        if ( this.isOpen ) return\n\n        if ( changes.options ) {\n            let pv = JSON.stringify( changes.options.previousValue )\n            let cv = JSON.stringify( changes.options.currentValue )\n            if ( pv != cv ) {\n                this.selection.setValue( null )\n                this.setInputToSelection()\n                this.setFilter()\n            }\n        }\n\n        if ( changes.value ) {\n            let pv = JSON.stringify( changes.value.previousValue )\n            let cv = JSON.stringify( changes.value.currentValue )\n            if ( pv != cv ) {\n                if ( this.value ) {\n                    this.hasValue = this.value.length > 0\n                    this.selection.setValue( this.value )\n                    if ( this.selectMax > 1 && this.value.length >= this.selectMax ) {\n                        this.selection.disable()\n                    }\n                    else {\n                        this.selection.enable()\n                    }\n                }\n                else {\n                    this.hasValue = false\n                    this.selection.setValue( null )\n                    this.selection.enable()\n                }\n\n                this.setFilter()\n                this.setInputToSelection()\n                this.changeDetectorRef.detectChanges()\n            }\n        }\n    }\n\n    get single() {\n        return this.selectMax == 1\n    }\n\n    emitValueChange() {\n        this.hasValue = ( this.selection.value || [] ).length > 0\n        this.valueChange.emit( this.selection.value || [] )\n    }\n\n    open() {\n        if ( this.isOpen ) return\n\n        this.isOpen = true\n        this.floatLabel = 'always'\n        this.inputValue = ''\n\n        // Create overlay\n        const positionStrategy = this.overlay\n            .position()\n            .flexibleConnectedTo( this.trigger )\n            .withPositions( [\n                {\n                    originX: 'start',\n                    originY: 'bottom',\n                    overlayX: 'start',\n                    overlayY: 'top',\n                    offsetY: 0\n                },\n                {\n                    originX: 'start',\n                    originY: 'top',\n                    overlayX: 'start',\n                    overlayY: 'bottom',\n                    offsetY: 0\n                }\n            ] )\n            .withPush( false )\n\n        const scrollStrategy = this.overlay.scrollStrategies.reposition()\n\n        this.overlayRef = this.overlay.create( {\n            positionStrategy,\n            scrollStrategy,\n            hasBackdrop: false,\n            maxWidth: this.trigger.nativeElement.offsetWidth * 2,\n            minWidth: this.trigger.nativeElement.offsetWidth,\n            maxHeight: 300,\n        } )\n\n        // Attach template\n        const portal = new TemplatePortal( this.overlayTemplate, this.viewContainerRef )\n        this.overlayRef.attach( portal )\n\n        // Listen to document clicks after a small delay to avoid closing immediately\n        setTimeout( () => {\n            this.clickSubscription = fromEvent<MouseEvent>( document, 'click' )\n                .pipe( filter( ( event: MouseEvent ) => {\n                    const clickTarget = event.target as HTMLElement\n                    const triggerEl = this.trigger.nativeElement\n                    const overlayEl = this.overlayRef?.overlayElement\n\n                    // Only close if click is outside both trigger and overlay\n                    return !triggerEl.contains(clickTarget)\n                        && !overlayEl?.contains(clickTarget)\n                } ) )\n                .subscribe( () => {\n                    this.close()\n                } )\n        } )\n\n        // Focus input after overlay is attached\n        setTimeout( () => {\n            this.filterInput?.nativeElement.focus();\n\n            // prevent list from scrolling when selection changes\n            this.overlayRef.overlayElement.children[0].scroll( 0, 1 )\n        } )\n\n        this.setFilter()\n\n        this.openingValue = JSON.stringify( this.selection.value )\n    }\n\n    close() {\n        if ( !this.isOpen ) return\n\n        this.isOpen = false\n        this.setInputToSelection()\n        this.floatLabel = 'auto'\n\n        if ( this.clickSubscription ) {\n            this.clickSubscription.unsubscribe()\n            this.clickSubscription = null\n        }\n\n        if ( this.overlayRef ) {\n            this.overlayRef.dispose()\n            this.overlayRef = null\n        }\n\n        this.changeDetectorRef.detectChanges()\n\n        let closingValue = JSON.stringify( this.selection.value )\n        if ( this.openingValue != closingValue )\n            this.emitValueChange()\n    }\n\n    setInputToSelection() {\n        this.inputValue = this.selection?.value?.map( c => this.descriptionForCode( c ) ).join( ', ' ) || null\n    }\n\n    onInput( ev?) {\n        this.setFilter( ev?.target?.value )\n    }\n\n    setFilter( text?: string ) {\n        let t = text?.trim().toLowerCase()\n\n        if ( t ) {\n            this.isFiltered = true\n            this.match = ( option ) => option.description.toLowerCase().includes( t )\n        }\n        else {\n            this.isFiltered = false\n            this.match = ( o ) => true\n        }\n\n        this.changeDetectorRef.detectChanges()\n    }\n\n    matchesFilter( option: CodeDescription ) {\n        return this.match( option )\n    }\n\n    onSelectionChange( ev ) {\n        if ( this.single ) {\n            this.close()\n        }\n        else {\n            this.filterInput?.nativeElement.focus()\n        }\n\n        if ( this.selectMax > 1 ) {\n            if ( this.selection.value.length >= this.selectMax ) {\n                this.selection.disable()\n            }\n            else {\n                this.selection.enable()\n            }\n        }\n\n        this.changeDetectorRef.detectChanges()\n    }\n\n    onUpperSelectionChange( ev: MatSelectionListChange ) {\n        setTimeout(() => {\n            let codes = this.selection.value.filter( c => c != ev.options[ 0 ].value )\n            this.selection.setValue( codes )\n\n            this.onSelectionChange( ev )\n        })\n    }\n\n    onCancelClick() {\n        this.selection.setValue( null )\n        this.selection.enable()\n        this.setInputToSelection()\n        this.emitValueChange()\n    }\n\n    onInputFocus() {\n        this.open()\n    }\n\n    descriptionForCode( code: string ): string {\n        return this.options.find( o => o.code == code )?.description\n    }\n}\n","<mat-form-field #trigger\n    [floatLabel]=\"floatLabel\"\n    appearance=\"outline\"\n    subscriptSizing=\"dynamic\"\n>\n    @if ( label ) {\n        <mat-label>{{ label }}</mat-label>\n    }\n\n    <input class=\"filter-input\" #searchInput\n        matInput \n        [placeholder]=\"placeholder\" \n        [value]=\"inputValue\"\n        (input)=\"onInput( $event )\"\n        (keydown.escape)=\"close()\"\n        (focus)=\"onInputFocus()\"\n        [matTooltip]=\"inputValue\"\n    >\n\n    @if ( isOpen ) {\n        <mat-icon matSuffix>arrow_drop_up</mat-icon>\n    }\n    @else if ( selection?.value?.length > 0 && clear ) {\n        <button class=\"cancel\"\n            mat-icon-button\n            matSuffix\n            (click)=\"onCancelClick($event); $event.stopPropagation()\"\n        >\n            <mat-icon>close</mat-icon>\n        </button>\n    }\n    @else {\n        <mat-icon matSuffix>arrow_drop_down</mat-icon>\n    }                \n\n    @if ( hint ) {\n        <mat-hint>{{ hint }}</mat-hint>\n    }\n</mat-form-field>        \n\n<ng-template #overlayTemplate>\n    <div class=\"filter-select-options\" [class.multiple]=\"!single\" [class.single]=\"single\">\n        @if ( !isFiltered && !single && summary ) {\n            @if ( selection?.value?.length > 0 && selection?.value?.length < options?.length ) {\n                <div class=\"selection-overview\">\n                    <div class=\"summary\">{{ selection?.value?.length }} selected of {{ options?.length }}</div>\n\n                    <mat-selection-list\n                        (selectionChange)=\"onUpperSelectionChange( $event )\"\n                    >\n                        @for ( code of selection?.value; track code ) {\n                            <mat-list-option \n                                [value]=\"code\" \n                                togglePosition=\"before\"\n                                selected\n                                [matTooltip]=\"tooltips ? descriptionForCode( code ) : null\"\n                                matTooltipPosition=\"after\"\n                            >\n                                {{ descriptionForCode( code ) }}\n                            </mat-list-option>\n                        }\n                    </mat-selection-list>\n                </div>\n            }\n\n            @if ( selection?.value?.length == options?.length ) {\n                <div class=\"selection-overview\">\n                    <div class=\"summary\">All options selected</div>\n                </div>\n            }\n        }\n\n        <mat-selection-list\n            [formControl]=\"selection\"\n            (selectionChange)=\"onSelectionChange( $event )\"\n            [multiple]=\"!single\"\n            hideSingleSelectionIndicator\n        >\n            @for ( option of options; track option ) {\n                <mat-list-option [class.hide]=\"!matchesFilter( option )\"\n                    [value]=\"option.code\" \n                    togglePosition=\"before\"                    \n                    [matTooltip]=\"tooltips ? option.description : null\"\n                    matTooltipPosition=\"after\"                    \n                >\n                    {{ option.description }}\n                </mat-list-option>\n            }\n        </mat-selection-list>\n    </div>\n</ng-template>\n"]}
@@ -0,0 +1,39 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/material/button";
4
+ import * as i2 from "@angular/material/icon";
5
+ import * as i3 from "../device-view/device-view.component";
6
+ export class FiltersPanelComponent {
7
+ constructor() {
8
+ this.showClear = true;
9
+ this.showFilters = true;
10
+ this.clearFilters = new EventEmitter();
11
+ this.showFiltersChange = new EventEmitter();
12
+ }
13
+ onClearClick() {
14
+ this.clearFilters.emit();
15
+ }
16
+ onHideClick() {
17
+ this.showFilters = false;
18
+ this.showFiltersChange.emit(false);
19
+ }
20
+ onShowClick() {
21
+ this.showFilters = true;
22
+ this.showFiltersChange.emit(true);
23
+ }
24
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FiltersPanelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
25
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: FiltersPanelComponent, selector: "nrcl-filters-panel", inputs: { showClear: "showClear", showFilters: "showFilters" }, outputs: { clearFilters: "clearFilters", showFiltersChange: "showFiltersChange" }, ngImport: i0, template: "@if ( showFilters ) {\n <ng-content></ng-content>\n}\n\n<div class=\"actions\">\n <nrcl-mobile-view>\n @if ( showFilters ) {\n <button mat-stroked-button class=\"hide\"\n (click)=\"onHideClick()\"\n >\n <mat-icon>expand_less</mat-icon>\n Hide Filters\n </button>\n }\n @else {\n <button mat-stroked-button class=\"show\"\n (click)=\"onShowClick()\"\n >\n <mat-icon>expand_more</mat-icon>\n Show Filters\n </button>\n }\n </nrcl-mobile-view>\n\n <div class=\"spacer\"></div> \n\n @if ( showClear && showFilters ) {\n <button mat-stroked-button class=\"clear\"\n (click)=\"onClearClick()\"\n >\n <mat-icon>filter_list_off</mat-icon>\n Clear\n </button>\n }\n</div>\n", styles: [":host{display:flex;flex-flow:row wrap;gap:8px;position:relative;border:1px solid #c6c8cb;padding:8px;background-color:#f2f2f2}:host ::ng-deep .material-icons{font-family:Material Symbols Outlined;font-feature-settings:\"liga\"}:host ::ng-deep .mat-icon{width:var(--nrcl-icon-size);height:var(--nrcl-icon-size);font-size:var(--nrcl-icon-size);line-height:var(--nrcl-icon-size)}:host ::ng-deep button.mat-mdc-fab>.mat-icon,:host ::ng-deep button.mat-mdc-raised-button>.mat-icon,:host ::ng-deep button.mat-mdc-button>.mat-icon,:host ::ng-deep button.mat-mdc-icon-button>.mat-icon,:host ::ng-deep button.mat-mdc-outlined-button>.mat-icon,:host ::ng-deep button.mat-mdc-unelevated-button>.mat-icon,:host ::ng-deep button.mat-mdc-mini-fab .mat-mdc-menu-item>.mat-icon{width:var(--nrcl-icon-size);height:var(--nrcl-icon-size);font-size:var(--nrcl-icon-size);line-height:var(--nrcl-icon-size)}:host ::ng-deep button.mat-mdc-fab,:host ::ng-deep button.mat-mdc-raised-button,:host ::ng-deep button.mat-mdc-button,:host ::ng-deep button.mat-mdc-icon-button,:host ::ng-deep button.mat-mdc-outlined-button,:host ::ng-deep button.mat-mdc-unelevated-button,:host ::ng-deep button.mat-mdc-mini-fab .mat-mdc-menu-item{font-family:var(--nrcl-font-family);font-size:var(--nrcl-font-size);white-space:nowrap;font-weight:500}:host ::ng-deep button.mat-mdc-fab[disabled],:host ::ng-deep button.mat-mdc-raised-button[disabled],:host ::ng-deep button.mat-mdc-button[disabled],:host ::ng-deep button.mat-mdc-icon-button[disabled],:host ::ng-deep button.mat-mdc-outlined-button[disabled],:host ::ng-deep button.mat-mdc-unelevated-button[disabled],:host ::ng-deep button.mat-mdc-mini-fab .mat-mdc-menu-item[disabled]{border:1px solid #d7d7d7!important}:host ::ng-deep button.primary.mat-mdc-fab:not([disabled]),:host ::ng-deep button.primary.mat-mdc-raised-button:not([disabled]),:host ::ng-deep button.primary.mat-mdc-button:not([disabled]),:host ::ng-deep button.primary.mat-mdc-icon-button:not([disabled]),:host ::ng-deep button.primary.mat-mdc-outlined-button:not([disabled]),:host ::ng-deep button.primary.mat-mdc-unelevated-button:not([disabled]),:host ::ng-deep button.primary.mat-mdc-mini-fab .mat-mdc-menu-item:not([disabled]){background-color:var(--nrcl-button-primary-background-color);color:var(--nrcl-button-primary-foreground-color)}:host ::ng-deep button.primary.mat-mdc-fab:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-raised-button:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-button:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-icon-button:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-outlined-button:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-unelevated-button:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-mini-fab .mat-mdc-menu-item:not([disabled]).intermediate-action{background-color:#2e7940}:host ::ng-deep button.primary.mat-mdc-fab:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-raised-button:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-button:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-icon-button:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-outlined-button:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-unelevated-button:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-mini-fab .mat-mdc-menu-item:not([disabled]):hover{background-color:var(--nrcl-button-primary-hover-background-color)}:host ::ng-deep button.mat-mdc-fab,:host ::ng-deep button.mat-mdc-raised-button{background-color:#aaa;color:#fff;font-family:var(--nrcl-font-family);font-size:var(--nrcl-font-size);box-shadow:none!important;border:1px solid #003366}:host ::ng-deep button.mat-mdc-fab:not([class*=mat-elevation-z]),:host ::ng-deep button.mat-mdc-raised-button:not([class*=mat-elevation-z]){box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f!important}:host ::ng-deep button.mdc-button.right-side-icon{display:flex}:host ::ng-deep button.mdc-button.right-side-icon mat-icon{order:1;margin-left:8px;margin-right:-4px}:host .actions{flex-grow:1;flex-direction:row;justify-content:flex-end;align-items:flex-end;width:unset;display:flex}:host .actions button{height:40px}:host .actions .spacer{flex-grow:1}:host-context(.nrcl-device-mobile) :host{display:grid;grid-template-columns:1fr 1fr}:host-context(.nrcl-device-mobile) :host .actions{grid-column:1/span 2}:host-context(.nrcl-device-mobile) :host ::ng-deep nrcl-filter-search{--nrcl-filter-search-width: auto;grid-row:1;grid-column:1/span 2}:host-context(.nrcl-device-mobile) :host ::ng-deep nrcl-filter-select{--nrcl-filter-select-width: auto}:host-context(.nrcl-device-mobile) :host ::ng-deep nrcl-filter-date{--nrcl-filter-date-width: auto}:host-context(.nrcl-device-mobile) :host ::ng-deep nrcl-filter-container{--nrcl-filter-container-width: auto}\n"], dependencies: [{ kind: "component", type: i1.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MobileViewComponent, selector: "nrcl-mobile-view" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
26
+ }
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FiltersPanelComponent, decorators: [{
28
+ type: Component,
29
+ args: [{ selector: "nrcl-filters-panel", changeDetection: ChangeDetectionStrategy.OnPush, template: "@if ( showFilters ) {\n <ng-content></ng-content>\n}\n\n<div class=\"actions\">\n <nrcl-mobile-view>\n @if ( showFilters ) {\n <button mat-stroked-button class=\"hide\"\n (click)=\"onHideClick()\"\n >\n <mat-icon>expand_less</mat-icon>\n Hide Filters\n </button>\n }\n @else {\n <button mat-stroked-button class=\"show\"\n (click)=\"onShowClick()\"\n >\n <mat-icon>expand_more</mat-icon>\n Show Filters\n </button>\n }\n </nrcl-mobile-view>\n\n <div class=\"spacer\"></div> \n\n @if ( showClear && showFilters ) {\n <button mat-stroked-button class=\"clear\"\n (click)=\"onClearClick()\"\n >\n <mat-icon>filter_list_off</mat-icon>\n Clear\n </button>\n }\n</div>\n", styles: [":host{display:flex;flex-flow:row wrap;gap:8px;position:relative;border:1px solid #c6c8cb;padding:8px;background-color:#f2f2f2}:host ::ng-deep .material-icons{font-family:Material Symbols Outlined;font-feature-settings:\"liga\"}:host ::ng-deep .mat-icon{width:var(--nrcl-icon-size);height:var(--nrcl-icon-size);font-size:var(--nrcl-icon-size);line-height:var(--nrcl-icon-size)}:host ::ng-deep button.mat-mdc-fab>.mat-icon,:host ::ng-deep button.mat-mdc-raised-button>.mat-icon,:host ::ng-deep button.mat-mdc-button>.mat-icon,:host ::ng-deep button.mat-mdc-icon-button>.mat-icon,:host ::ng-deep button.mat-mdc-outlined-button>.mat-icon,:host ::ng-deep button.mat-mdc-unelevated-button>.mat-icon,:host ::ng-deep button.mat-mdc-mini-fab .mat-mdc-menu-item>.mat-icon{width:var(--nrcl-icon-size);height:var(--nrcl-icon-size);font-size:var(--nrcl-icon-size);line-height:var(--nrcl-icon-size)}:host ::ng-deep button.mat-mdc-fab,:host ::ng-deep button.mat-mdc-raised-button,:host ::ng-deep button.mat-mdc-button,:host ::ng-deep button.mat-mdc-icon-button,:host ::ng-deep button.mat-mdc-outlined-button,:host ::ng-deep button.mat-mdc-unelevated-button,:host ::ng-deep button.mat-mdc-mini-fab .mat-mdc-menu-item{font-family:var(--nrcl-font-family);font-size:var(--nrcl-font-size);white-space:nowrap;font-weight:500}:host ::ng-deep button.mat-mdc-fab[disabled],:host ::ng-deep button.mat-mdc-raised-button[disabled],:host ::ng-deep button.mat-mdc-button[disabled],:host ::ng-deep button.mat-mdc-icon-button[disabled],:host ::ng-deep button.mat-mdc-outlined-button[disabled],:host ::ng-deep button.mat-mdc-unelevated-button[disabled],:host ::ng-deep button.mat-mdc-mini-fab .mat-mdc-menu-item[disabled]{border:1px solid #d7d7d7!important}:host ::ng-deep button.primary.mat-mdc-fab:not([disabled]),:host ::ng-deep button.primary.mat-mdc-raised-button:not([disabled]),:host ::ng-deep button.primary.mat-mdc-button:not([disabled]),:host ::ng-deep button.primary.mat-mdc-icon-button:not([disabled]),:host ::ng-deep button.primary.mat-mdc-outlined-button:not([disabled]),:host ::ng-deep button.primary.mat-mdc-unelevated-button:not([disabled]),:host ::ng-deep button.primary.mat-mdc-mini-fab .mat-mdc-menu-item:not([disabled]){background-color:var(--nrcl-button-primary-background-color);color:var(--nrcl-button-primary-foreground-color)}:host ::ng-deep button.primary.mat-mdc-fab:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-raised-button:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-button:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-icon-button:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-outlined-button:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-unelevated-button:not([disabled]).intermediate-action,:host ::ng-deep button.primary.mat-mdc-mini-fab .mat-mdc-menu-item:not([disabled]).intermediate-action{background-color:#2e7940}:host ::ng-deep button.primary.mat-mdc-fab:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-raised-button:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-button:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-icon-button:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-outlined-button:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-unelevated-button:not([disabled]):hover,:host ::ng-deep button.primary.mat-mdc-mini-fab .mat-mdc-menu-item:not([disabled]):hover{background-color:var(--nrcl-button-primary-hover-background-color)}:host ::ng-deep button.mat-mdc-fab,:host ::ng-deep button.mat-mdc-raised-button{background-color:#aaa;color:#fff;font-family:var(--nrcl-font-family);font-size:var(--nrcl-font-size);box-shadow:none!important;border:1px solid #003366}:host ::ng-deep button.mat-mdc-fab:not([class*=mat-elevation-z]),:host ::ng-deep button.mat-mdc-raised-button:not([class*=mat-elevation-z]){box-shadow:0 3px 1px -2px #0003,0 2px 2px #00000024,0 1px 5px #0000001f!important}:host ::ng-deep button.mdc-button.right-side-icon{display:flex}:host ::ng-deep button.mdc-button.right-side-icon mat-icon{order:1;margin-left:8px;margin-right:-4px}:host .actions{flex-grow:1;flex-direction:row;justify-content:flex-end;align-items:flex-end;width:unset;display:flex}:host .actions button{height:40px}:host .actions .spacer{flex-grow:1}:host-context(.nrcl-device-mobile) :host{display:grid;grid-template-columns:1fr 1fr}:host-context(.nrcl-device-mobile) :host .actions{grid-column:1/span 2}:host-context(.nrcl-device-mobile) :host ::ng-deep nrcl-filter-search{--nrcl-filter-search-width: auto;grid-row:1;grid-column:1/span 2}:host-context(.nrcl-device-mobile) :host ::ng-deep nrcl-filter-select{--nrcl-filter-select-width: auto}:host-context(.nrcl-device-mobile) :host ::ng-deep nrcl-filter-date{--nrcl-filter-date-width: auto}:host-context(.nrcl-device-mobile) :host ::ng-deep nrcl-filter-container{--nrcl-filter-container-width: auto}\n"] }]
30
+ }], propDecorators: { showClear: [{
31
+ type: Input
32
+ }], showFilters: [{
33
+ type: Input
34
+ }], clearFilters: [{
35
+ type: Output
36
+ }], showFiltersChange: [{
37
+ type: Output
38
+ }] } });
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVycy1wYW5lbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uci1uZ3gtY29tcG9uZW50LWxpYi9zcmMvY29tcG9uZW50cy9maWx0ZXJzLXBhbmVsL2ZpbHRlcnMtcGFuZWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnItbmd4LWNvbXBvbmVudC1saWIvc3JjL2NvbXBvbmVudHMvZmlsdGVycy1wYW5lbC9maWx0ZXJzLXBhbmVsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBQ0wsTUFBTSxFQUNULE1BQU0sZUFBZSxDQUFDOzs7OztBQVF2QixNQUFNLE9BQU8scUJBQXFCO0lBTmxDO1FBT2EsY0FBUyxHQUFHLElBQUksQ0FBQTtRQUNoQixnQkFBVyxHQUFHLElBQUksQ0FBQTtRQUVqQixpQkFBWSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUE7UUFDakMsc0JBQWlCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQTtLQWU1RDtJQWJHLFlBQVk7UUFDUixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksRUFBRSxDQUFBO0lBQzVCLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUE7UUFDeEIsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBRSxLQUFLLENBQUUsQ0FBQTtJQUN4QyxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFBO1FBQ3ZCLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxJQUFJLENBQUUsSUFBSSxDQUFFLENBQUE7SUFDdkMsQ0FBQzsrR0FuQlEscUJBQXFCO21HQUFyQixxQkFBcUIsNk1DZGxDLGk2QkFtQ0E7OzRGRHJCYSxxQkFBcUI7a0JBTmpDLFNBQVM7K0JBQ0ksb0JBQW9CLG1CQUdiLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFFSSxZQUFZO3NCQUFyQixNQUFNO2dCQUNHLGlCQUFpQjtzQkFBMUIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBJbnB1dCxcbiAgICBPdXRwdXRcbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQENvbXBvbmVudCgge1xuICAgIHNlbGVjdG9yOiBcIm5yY2wtZmlsdGVycy1wYW5lbFwiLFxuICAgIHRlbXBsYXRlVXJsOiBcIi4vZmlsdGVycy1wYW5lbC5jb21wb25lbnQuaHRtbFwiLFxuICAgIHN0eWxlVXJsOiBcIi4vZmlsdGVycy1wYW5lbC5jb21wb25lbnQuc2Nzc1wiLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSApXG5leHBvcnQgY2xhc3MgRmlsdGVyc1BhbmVsQ29tcG9uZW50IHtcbiAgICBASW5wdXQoKSBzaG93Q2xlYXIgPSB0cnVlXG4gICAgQElucHV0KCkgc2hvd0ZpbHRlcnMgPSB0cnVlXG5cbiAgICBAT3V0cHV0KCkgY2xlYXJGaWx0ZXJzID0gbmV3IEV2ZW50RW1pdHRlcigpXG4gICAgQE91dHB1dCgpIHNob3dGaWx0ZXJzQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpXG5cbiAgICBvbkNsZWFyQ2xpY2soKSB7XG4gICAgICAgIHRoaXMuY2xlYXJGaWx0ZXJzLmVtaXQoKVxuICAgIH1cblxuICAgIG9uSGlkZUNsaWNrKCkge1xuICAgICAgICB0aGlzLnNob3dGaWx0ZXJzID0gZmFsc2VcbiAgICAgICAgdGhpcy5zaG93RmlsdGVyc0NoYW5nZS5lbWl0KCBmYWxzZSApXG4gICAgfVxuXG4gICAgb25TaG93Q2xpY2soKSB7XG4gICAgICAgIHRoaXMuc2hvd0ZpbHRlcnMgPSB0cnVlXG4gICAgICAgIHRoaXMuc2hvd0ZpbHRlcnNDaGFuZ2UuZW1pdCggdHJ1ZSApXG4gICAgfVxufVxuIiwiQGlmICggc2hvd0ZpbHRlcnMgKSB7XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxufVxuXG48ZGl2IGNsYXNzPVwiYWN0aW9uc1wiPlxuICAgIDxucmNsLW1vYmlsZS12aWV3PlxuICAgICAgICBAaWYgKCBzaG93RmlsdGVycyApIHtcbiAgICAgICAgICAgIDxidXR0b24gbWF0LXN0cm9rZWQtYnV0dG9uIGNsYXNzPVwiaGlkZVwiXG4gICAgICAgICAgICAgICAgKGNsaWNrKT1cIm9uSGlkZUNsaWNrKClcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIDxtYXQtaWNvbj5leHBhbmRfbGVzczwvbWF0LWljb24+XG4gICAgICAgICAgICAgICAgSGlkZSBGaWx0ZXJzXG4gICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgfVxuICAgICAgICBAZWxzZSB7XG4gICAgICAgICAgICA8YnV0dG9uIG1hdC1zdHJva2VkLWJ1dHRvbiBjbGFzcz1cInNob3dcIlxuICAgICAgICAgICAgICAgIChjbGljayk9XCJvblNob3dDbGljaygpXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICA8bWF0LWljb24+ZXhwYW5kX21vcmU8L21hdC1pY29uPlxuICAgICAgICAgICAgICAgIFNob3cgRmlsdGVyc1xuICAgICAgICAgICAgPC9idXR0b24+XG4gICAgICAgIH1cbiAgICA8L25yY2wtbW9iaWxlLXZpZXc+XG5cbiAgICA8ZGl2IGNsYXNzPVwic3BhY2VyXCI+PC9kaXY+ICAgICAgICBcblxuICAgIEBpZiAoIHNob3dDbGVhciAmJiBzaG93RmlsdGVycyApIHtcbiAgICAgICAgPGJ1dHRvbiBtYXQtc3Ryb2tlZC1idXR0b24gY2xhc3M9XCJjbGVhclwiXG4gICAgICAgICAgICAoY2xpY2spPVwib25DbGVhckNsaWNrKClcIlxuICAgICAgICA+XG4gICAgICAgICAgICA8bWF0LWljb24+ZmlsdGVyX2xpc3Rfb2ZmPC9tYXQtaWNvbj5cbiAgICAgICAgICAgIENsZWFyXG4gICAgICAgIDwvYnV0dG9uPlxuICAgIH1cbjwvZGl2PlxuIl19
@@ -0,0 +1,103 @@
1
+ import { booleanAttribute, ChangeDetectionStrategy, Component, ElementRef, inject, Input, Renderer2 } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class FormFieldComponent {
4
+ constructor() {
5
+ this.element = inject(ElementRef);
6
+ this.renderer = inject(Renderer2);
7
+ }
8
+ ngOnChanges(changes) {
9
+ if (changes.readonly) {
10
+ if (this.readonly) {
11
+ makeFormFieldReadonly(this.renderer, this.element.nativeElement);
12
+ }
13
+ else {
14
+ makeFormFieldNotReadonly(this.renderer, this.element.nativeElement);
15
+ }
16
+ }
17
+ }
18
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
19
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.14", type: FormFieldComponent, selector: "nrcl-form-field", inputs: { required: ["required", "required", booleanAttribute], readonly: ["readonly", "readonly", booleanAttribute] }, host: { properties: { "class.required": "required", "class.readonly": "readonly" } }, usesOnChanges: true, ngImport: i0, template: "<ng-content></ng-content>", isInline: true, styles: [":host ::ng-deep .mat-mdc-form-field{width:100%;font-family:var(--nrcl-font-family)}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper{padding-left:0;padding-right:0;background-color:unset}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-form-field-infix{font-size:var(--nrcl-font-size);padding-bottom:2px;line-height:20px;min-height:50px;width:unset}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-form-field-infix .mat-mdc-form-field-required-marker{display:none}:host ::ng-deep .mat-mdc-form-field-subscript-wrapper .mat-mdc-form-field-error-wrapper,:host ::ng-deep .mat-mdc-form-field-subscript-wrapper .mat-mdc-form-field-hint-wrapper{padding:0}:host.required ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-form-field-infix .mdc-floating-label :after{color:red;content:\" *\"}:host.readonly ::ng-deep .mat-mdc-form-field{cursor:not-allowed}:host.readonly ::ng-deep .mat-mdc-form-field [readonly=true]{color:#0000008c;cursor:not-allowed}:host.readonly ::ng-deep .mat-mdc-form-field .mdc-line-ripple:before{border-style:dashed;border-width:1px;border-color:#00000021}:host.readonly ::ng-deep .mat-mdc-form-field mat-error{display:none}:host.readonly ::ng-deep .mat-mdc-form-field input,:host.readonly ::ng-deep .mat-mdc-form-field textarea{cursor:not-allowed}:host.readonly ::ng-deep .mat-mdc-form-field .select-read-only-cursor{cursor:not-allowed;pointer-events:none}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
20
+ }
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormFieldComponent, decorators: [{
22
+ type: Component,
23
+ args: [{ selector: "nrcl-form-field", template: "<ng-content></ng-content>", changeDetection: ChangeDetectionStrategy.OnPush, host: {
24
+ '[class.required]': "required",
25
+ '[class.readonly]': "readonly",
26
+ }, styles: [":host ::ng-deep .mat-mdc-form-field{width:100%;font-family:var(--nrcl-font-family)}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper{padding-left:0;padding-right:0;background-color:unset}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-form-field-infix{font-size:var(--nrcl-font-size);padding-bottom:2px;line-height:20px;min-height:50px;width:unset}:host ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-form-field-infix .mat-mdc-form-field-required-marker{display:none}:host ::ng-deep .mat-mdc-form-field-subscript-wrapper .mat-mdc-form-field-error-wrapper,:host ::ng-deep .mat-mdc-form-field-subscript-wrapper .mat-mdc-form-field-hint-wrapper{padding:0}:host.required ::ng-deep .mat-mdc-form-field .mat-mdc-text-field-wrapper .mat-mdc-form-field-flex .mat-mdc-form-field-infix .mdc-floating-label :after{color:red;content:\" *\"}:host.readonly ::ng-deep .mat-mdc-form-field{cursor:not-allowed}:host.readonly ::ng-deep .mat-mdc-form-field [readonly=true]{color:#0000008c;cursor:not-allowed}:host.readonly ::ng-deep .mat-mdc-form-field .mdc-line-ripple:before{border-style:dashed;border-width:1px;border-color:#00000021}:host.readonly ::ng-deep .mat-mdc-form-field mat-error{display:none}:host.readonly ::ng-deep .mat-mdc-form-field input,:host.readonly ::ng-deep .mat-mdc-form-field textarea{cursor:not-allowed}:host.readonly ::ng-deep .mat-mdc-form-field .select-read-only-cursor{cursor:not-allowed;pointer-events:none}\n"] }]
27
+ }], propDecorators: { required: [{
28
+ type: Input,
29
+ args: [{ transform: booleanAttribute }]
30
+ }], readonly: [{
31
+ type: Input,
32
+ args: [{ transform: booleanAttribute }]
33
+ }] } });
34
+ function makeFormFieldReadonly(renderer, formFieldEl) {
35
+ let editableElements;
36
+ //make input element readonly
37
+ let inputHtmlElement;
38
+ editableElements = formFieldEl.getElementsByTagName('input');
39
+ if (editableElements && editableElements.length) {
40
+ inputHtmlElement = editableElements[0];
41
+ setTimeout(() => {
42
+ renderer.setAttribute(inputHtmlElement, "readonly", "readonly");
43
+ });
44
+ }
45
+ //make textarea element readonly
46
+ let textareaHtmlElement;
47
+ editableElements = formFieldEl.getElementsByTagName('textarea');
48
+ if (editableElements && editableElements.length) {
49
+ textareaHtmlElement = editableElements[0];
50
+ setTimeout(() => {
51
+ renderer.setAttribute(textareaHtmlElement, "readonly", "readonly");
52
+ });
53
+ }
54
+ //make select element readonly
55
+ let selectHtmlElement;
56
+ editableElements = formFieldEl.getElementsByTagName('select');
57
+ if (editableElements && editableElements.length) {
58
+ selectHtmlElement = editableElements[0];
59
+ setTimeout(() => {
60
+ renderer.addClass(selectHtmlElement, "select-read-only-cursor");
61
+ renderer.setAttribute(selectHtmlElement, "readonly", "readonly");
62
+ for (let i = 0; i < selectHtmlElement.options.length; i++) {
63
+ selectHtmlElement.options[i].disabled = true;
64
+ }
65
+ });
66
+ }
67
+ }
68
+ function makeFormFieldNotReadonly(renderer, formFieldEl) {
69
+ // renderer.removeClass(formFieldEl, "readonly");
70
+ let editableElements;
71
+ //make input element readonly
72
+ let inputHtmlElement;
73
+ editableElements = formFieldEl.getElementsByTagName('input');
74
+ if (editableElements && editableElements.length) {
75
+ inputHtmlElement = editableElements[0];
76
+ setTimeout(() => {
77
+ renderer.removeAttribute(inputHtmlElement, "readonly");
78
+ });
79
+ }
80
+ //make textarea element readonly
81
+ let textareaHtmlElement;
82
+ editableElements = formFieldEl.getElementsByTagName('textarea');
83
+ if (editableElements && editableElements.length) {
84
+ textareaHtmlElement = editableElements[0];
85
+ setTimeout(() => {
86
+ renderer.removeAttribute(textareaHtmlElement, "readonly");
87
+ });
88
+ }
89
+ //make select element readonly
90
+ let selectHtmlElement;
91
+ editableElements = formFieldEl.getElementsByTagName('select');
92
+ if (editableElements && editableElements.length) {
93
+ selectHtmlElement = editableElements[0];
94
+ setTimeout(() => {
95
+ renderer.removeClass(selectHtmlElement, "select-read-only-cursor");
96
+ renderer.removeAttribute(selectHtmlElement, "readonly");
97
+ for (let i = 0; i < selectHtmlElement.options.length; i++) {
98
+ selectHtmlElement.options[i].disabled = undefined;
99
+ }
100
+ });
101
+ }
102
+ }
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.component.js","sourceRoot":"","sources":["../../../../../projects/nr-ngx-component-lib/src/components/form-field/form-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    booleanAttribute,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    inject,\n    Input,\n    OnChanges,\n    Renderer2,\n    SimpleChanges\n} from \"@angular/core\";\n\n@Component({\n    selector: \"nrcl-form-field\",\n    template: \"<ng-content></ng-content>\",\n    styleUrl: \"./form-field.component.scss\",\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class.required]': \"required\",\n        '[class.readonly]': \"readonly\",\n    }\n})\nexport class FormFieldComponent implements OnChanges {\n    @Input( { transform: booleanAttribute } ) required\n    @Input( { transform: booleanAttribute } ) readonly\n\n    element = inject( ElementRef )\n    renderer = inject( Renderer2 )\n\n    ngOnChanges( changes: SimpleChanges ): void {\n        if ( changes.readonly ) {\n            if ( this.readonly ) {\n                makeFormFieldReadonly( this.renderer, this.element.nativeElement )\n            }\n            else {\n                makeFormFieldNotReadonly( this.renderer, this.element.nativeElement )\n            }\n        }\n    }\n}\n\nfunction makeFormFieldReadonly(renderer: Renderer2, formFieldEl: HTMLElement) {\n    let editableElements;\n    //make input element readonly\n    let inputHtmlElement: HTMLInputElement;\n    editableElements = formFieldEl.getElementsByTagName('input');\n    if (editableElements && editableElements.length) {\n        inputHtmlElement = editableElements[0];\n        setTimeout(() => {\n            renderer.setAttribute(inputHtmlElement, \"readonly\", \"readonly\");\n        });\n    }\n\n    //make textarea element readonly\n    let textareaHtmlElement: HTMLTextAreaElement;\n    editableElements = formFieldEl.getElementsByTagName('textarea');\n    if (editableElements && editableElements.length) {\n        textareaHtmlElement = editableElements[0];\n        setTimeout(() => {\n            renderer.setAttribute(textareaHtmlElement, \"readonly\", \"readonly\");\n        });\n    }\n\n    //make select element readonly\n    let selectHtmlElement: HTMLSelectElement;\n    editableElements = formFieldEl.getElementsByTagName('select');\n    if (editableElements && editableElements.length) {\n        selectHtmlElement = editableElements[0];\n        setTimeout(() => {\n            renderer.addClass(selectHtmlElement, \"select-read-only-cursor\");\n            renderer.setAttribute(selectHtmlElement, \"readonly\", \"readonly\");\n            for (let i = 0; i < selectHtmlElement.options.length; i++) {\n                selectHtmlElement.options[i].disabled = true;\n            }\n        });\n    }\n}\n\nfunction makeFormFieldNotReadonly(renderer: Renderer2, formFieldEl: HTMLElement) {\n    // renderer.removeClass(formFieldEl, \"readonly\");\n    let editableElements;\n    //make input element readonly\n    let inputHtmlElement: HTMLInputElement;\n    editableElements = formFieldEl.getElementsByTagName('input');\n    if (editableElements && editableElements.length) {\n        inputHtmlElement = editableElements[0];\n        setTimeout(() => {\n            renderer.removeAttribute(inputHtmlElement, \"readonly\");\n        });\n    }\n\n    //make textarea element readonly\n    let textareaHtmlElement: HTMLTextAreaElement;\n    editableElements = formFieldEl.getElementsByTagName('textarea');\n    if (editableElements && editableElements.length) {\n        textareaHtmlElement = editableElements[0];\n        setTimeout(() => {\n            renderer.removeAttribute(textareaHtmlElement, \"readonly\");\n        });\n    }\n\n    //make select element readonly\n    let selectHtmlElement: HTMLSelectElement;\n    editableElements = formFieldEl.getElementsByTagName('select');\n    if (editableElements && editableElements.length) {\n        selectHtmlElement = editableElements[0];\n        setTimeout(() => {\n            renderer.removeClass(selectHtmlElement, \"select-read-only-cursor\");\n            renderer.removeAttribute(selectHtmlElement, \"readonly\");\n            for (let i = 0; i < selectHtmlElement.options.length; i++) {\n                selectHtmlElement.options[i].disabled = undefined;\n            }\n        });\n    }\n}"]}
@@ -0,0 +1,11 @@
1
+ import { ChangeDetectionStrategy, Component } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class FormLayoutComponent {
4
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormLayoutComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormLayoutComponent, selector: "nrcl-form-layout", ngImport: i0, template: "<ng-content></ng-content>", isInline: true, styles: [":host{display:grid;gap:var(--nrcl-gutter-space);grid-template-columns:repeat(var(--nrcl-form-layout-columns),1fr)}:host>::ng-deep [layoutwidth=\"2\"]{grid-column:span 2}:host>::ng-deep [layoutwidth=full]{grid-column:span var(--nrcl-form-layout-columns)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
6
+ }
7
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormLayoutComponent, decorators: [{
8
+ type: Component,
9
+ args: [{ selector: "nrcl-form-layout", template: "<ng-content></ng-content>", changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:grid;gap:var(--nrcl-gutter-space);grid-template-columns:repeat(var(--nrcl-form-layout-columns),1fr)}:host>::ng-deep [layoutwidth=\"2\"]{grid-column:span 2}:host>::ng-deep [layoutwidth=full]{grid-column:span var(--nrcl-form-layout-columns)}\n"] }]
10
+ }] });
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1sYXlvdXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnItbmd4LWNvbXBvbmVudC1saWIvc3JjL2NvbXBvbmVudHMvZm9ybS1sYXlvdXQvZm9ybS1sYXlvdXQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNaLE1BQU0sZUFBZSxDQUFDOztBQVF2QixNQUFNLE9BQU8sbUJBQW1COytHQUFuQixtQkFBbUI7bUdBQW5CLG1CQUFtQix3REFKbEIsMkJBQTJCOzs0RkFJNUIsbUJBQW1CO2tCQU4vQixTQUFTOytCQUNJLGtCQUFrQixZQUNsQiwyQkFBMkIsbUJBRXBCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENvbXBvbmVudFxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogXCJucmNsLWZvcm0tbGF5b3V0XCIsXG4gICAgdGVtcGxhdGU6IFwiPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlwiLFxuICAgIHN0eWxlVXJsOiBcIi4vZm9ybS1sYXlvdXQuY29tcG9uZW50LnNjc3NcIixcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBGb3JtTGF5b3V0Q29tcG9uZW50IHtcbn1cbiJdfQ==
@@ -0,0 +1,21 @@
1
+ import { booleanAttribute, Component, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class GapComponent {
4
+ constructor() {
5
+ this.horizontal = false;
6
+ this.vertical = false;
7
+ }
8
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: GapComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.14", type: GapComponent, selector: "nrcl-gap", inputs: { horizontal: ["horizontal", "horizontal", booleanAttribute], vertical: ["vertical", "vertical", booleanAttribute] }, ngImport: i0, template: '', isInline: true, styles: [":host{display:block}:host[horizontal]{width:var(--nrcl-gutter-space)}:host[vertical]{height:var(--nrcl-gutter-space)}\n"] }); }
10
+ }
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: GapComponent, decorators: [{
12
+ type: Component,
13
+ args: [{ selector: 'nrcl-gap', template: '', styles: [":host{display:block}:host[horizontal]{width:var(--nrcl-gutter-space)}:host[vertical]{height:var(--nrcl-gutter-space)}\n"] }]
14
+ }], propDecorators: { horizontal: [{
15
+ type: Input,
16
+ args: [{ transform: booleanAttribute }]
17
+ }], vertical: [{
18
+ type: Input,
19
+ args: [{ transform: booleanAttribute }]
20
+ }] } });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2FwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25yLW5neC1jb21wb25lbnQtbGliL3NyYy9jb21wb25lbnRzL2dhcC9nYXAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQU9uRSxNQUFNLE9BQU8sWUFBWTtJQUx6QjtRQU04QyxlQUFVLEdBQUcsS0FBSyxDQUFBO1FBQ2xCLGFBQVEsR0FBRyxLQUFLLENBQUE7S0FDN0Q7K0dBSFksWUFBWTttR0FBWixZQUFZLDJFQUNBLGdCQUFnQixzQ0FDaEIsZ0JBQWdCLDZCQUwzQixFQUFFOzs0RkFHSCxZQUFZO2tCQUx4QixTQUFTOytCQUNJLFVBQVUsWUFDVixFQUFFOzhCQUk4QixVQUFVO3NCQUFuRCxLQUFLO3VCQUFFLEVBQUUsU0FBUyxFQUFFLGdCQUFnQixFQUFFO2dCQUNHLFFBQVE7c0JBQWpELEtBQUs7dUJBQUUsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBib29sZWFuQXR0cmlidXRlLCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoIHtcbiAgICBzZWxlY3RvcjogJ25yY2wtZ2FwJyxcbiAgICB0ZW1wbGF0ZTogJycsXG4gICAgc3R5bGVVcmw6ICcuL2dhcC5jb21wb25lbnQuc2NzcycsXG59IClcbmV4cG9ydCBjbGFzcyBHYXBDb21wb25lbnQge1xuICAgIEBJbnB1dCggeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSApIGhvcml6b250YWwgPSBmYWxzZVxuICAgIEBJbnB1dCggeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSApIHZlcnRpY2FsID0gZmFsc2Vcbn1cbiJdfQ==
@@ -0,0 +1,11 @@
1
+ import { ChangeDetectionStrategy, Component } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class PageContainerComponent {
4
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PageContainerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: PageContainerComponent, selector: "nrcl-page-container", ngImport: i0, template: "<ng-content></ng-content>\n", styles: [":host{display:flex;flex-direction:column;box-sizing:border-box;width:100%;height:100%;padding-left:var(--nrcl-gutter-space);padding-right:var(--nrcl-gutter-space)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
6
+ }
7
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: PageContainerComponent, decorators: [{
8
+ type: Component,
9
+ args: [{ selector: "nrcl-page-container", changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>\n", styles: [":host{display:flex;flex-direction:column;box-sizing:border-box;width:100%;height:100%;padding-left:var(--nrcl-gutter-space);padding-right:var(--nrcl-gutter-space)}\n"] }]
10
+ }] });
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1jb250YWluZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnItbmd4LWNvbXBvbmVudC1saWIvc3JjL2NvbXBvbmVudHMvcGFnZS1jb250YWluZXIvcGFnZS1jb250YWluZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnItbmd4LWNvbXBvbmVudC1saWIvc3JjL2NvbXBvbmVudHMvcGFnZS1jb250YWluZXIvcGFnZS1jb250YWluZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILHVCQUF1QixFQUN2QixTQUFTLEVBQ1osTUFBTSxlQUFlLENBQUM7O0FBUXZCLE1BQU0sT0FBTyxzQkFBc0I7K0dBQXRCLHNCQUFzQjttR0FBdEIsc0JBQXNCLDJEQ1huQyw2QkFDQTs7NEZEVWEsc0JBQXNCO2tCQU5sQyxTQUFTOytCQUNJLHFCQUFxQixtQkFHZCx1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDb21wb25lbnRcbn0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQENvbXBvbmVudCgge1xuICAgIHNlbGVjdG9yOiBcIm5yY2wtcGFnZS1jb250YWluZXJcIixcbiAgICB0ZW1wbGF0ZVVybDogXCIuL3BhZ2UtY29udGFpbmVyLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc3R5bGVVcmw6IFwiLi9wYWdlLWNvbnRhaW5lci5jb21wb25lbnQuc2Nzc1wiLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSApXG5leHBvcnQgY2xhc3MgUGFnZUNvbnRhaW5lckNvbXBvbmVudCB7fVxuIiwiPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuIl19