@festo-ui/angular 5.1.0 → 6.0.0-dev.198
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{esm2020 → esm2022}/lib/components/accordion/accordion-header/accordion-header.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/accordion/accordion-item/accordion-item-body/accordion-item-body.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/accordion/accordion-item/accordion-item-header/accordion-item-header.component.mjs +4 -4
- package/esm2022/lib/components/accordion/accordion-item/accordion-item.component.mjs +148 -0
- package/esm2022/lib/components/accordion/accordion.component.mjs +59 -0
- package/{esm2020 → esm2022}/lib/components/breadcrumb/breadcrumb.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/buttons/button/button.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/buttons/link-button/link-button.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/chips/chip/chip.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/chips/chip-container/chip-container.component.mjs +4 -4
- package/esm2022/lib/components/components.module.mjs +207 -0
- package/{esm2020 → esm2022}/lib/components/loading-indicator/loading-indicator.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/mobile-flyout/mobile-flyout-item/mobile-flyout-item.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/components/mobile-flyout/mobile-flyout-page/mobile-flyout-page.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/mobile-flyout/mobile-flyout.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/pagination/pagination.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/popovers/legend/legend.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/popovers/legend/legend.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/popovers/popover/popover.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/popovers/popover-content/popover-content.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/popovers/popover-content/popover-content.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/popovers/popover-menu/popover-menu.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/popovers/popover.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/popovers/tooltip/tooltip.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/progress/progress.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/scroll/scrollable.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/search-input/search-input.component.mjs +4 -4
- package/esm2022/lib/components/sidebar-overlay/sidebar-overlay.component.mjs +59 -0
- package/{esm2020 → esm2022}/lib/components/snackbar/snackbar-container.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/snackbar/snackbar-container.directive.mjs +5 -5
- package/esm2022/lib/components/snackbar/snackbar.component.mjs +81 -0
- package/esm2022/lib/components/snackbar/snackbar.module.mjs +24 -0
- package/{esm2020 → esm2022}/lib/components/snackbar/snackbar.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/stepper-horizontal/step-horizontal/step-horizontal.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/stepper-horizontal/stepper-horizontal.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/stepper-vertical/step-vertical/step-vertical.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/stepper-vertical/stepper-vertical.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/table-header-cell/table-header-cell.directive.mjs +4 -4
- package/esm2022/lib/components/tabs/tab-pane/tab-pane.component.mjs +34 -0
- package/esm2022/lib/components/tabs/tabs.component.mjs +459 -0
- package/{esm2020 → esm2022}/lib/directives/click-outside.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/festo-angular.module.mjs +5 -5
- package/esm2022/lib/forms/checkbox/checkbox.component.mjs +154 -0
- package/{esm2020 → esm2022}/lib/forms/color-indicator/color-indicator.component.mjs +4 -4
- package/esm2022/lib/forms/color-picker/color-picker.component.mjs +292 -0
- package/{esm2020 → esm2022}/lib/forms/date-picker/date-picker.component.mjs +12 -12
- package/{esm2020 → esm2022}/lib/forms/date-range-picker/date-range-picker.component.mjs +12 -12
- package/{esm2020 → esm2022}/lib/forms/flatpickr/flatpickr.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/forms.module.mjs +62 -62
- package/esm2022/lib/forms/radio/radio.component.mjs +350 -0
- package/{esm2020 → esm2022}/lib/forms/segment/segment-control/segment-control.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/segment/segment.component.mjs +11 -11
- package/{esm2020 → esm2022}/lib/forms/select/chip-text.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/select/select-option/select-option.component.mjs +4 -4
- package/esm2022/lib/forms/select/select.component.mjs +275 -0
- package/esm2022/lib/forms/slider/slider.component.mjs +113 -0
- package/esm2022/lib/forms/switch/switch.component.mjs +121 -0
- package/esm2022/lib/forms/text-area/text-area.component.mjs +187 -0
- package/esm2022/lib/forms/text-editor/text-editor.component.mjs +308 -0
- package/esm2022/lib/forms/text-input/text-input.component.mjs +208 -0
- package/{esm2020 → esm2022}/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/time-picker/time-picker.component.mjs +11 -11
- package/{esm2020 → esm2022}/lib/forms/unique-selection-dispatcher.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/value-accessor-base.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modals/alert/alert.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modals/confirm/confirm.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modals/custom-modal/custom-modal.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modals/image-gallery/image-gallery.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modals/modal.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modals/modals.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modals/prompt/prompt.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/pipes/safe-html.pipe.mjs +5 -5
- package/{fesm2020 → fesm2022}/festo-ui-angular.mjs +512 -520
- package/{fesm2020 → fesm2022}/festo-ui-angular.mjs.map +1 -1
- package/lib/components/accordion/accordion.component.d.ts +1 -1
- package/lib/components/breadcrumb/breadcrumb.component.d.ts +1 -1
- package/lib/components/buttons/button/button.component.d.ts +1 -1
- package/lib/components/buttons/link-button/link-button.component.d.ts +1 -1
- package/lib/components/chips/chip/chip.component.d.ts +1 -1
- package/lib/components/chips/chip-container/chip-container.component.d.ts +1 -1
- package/lib/components/loading-indicator/loading-indicator.component.d.ts +1 -1
- package/lib/components/mobile-flyout/mobile-flyout-item/mobile-flyout-item.component.d.ts +1 -1
- package/lib/components/mobile-flyout/mobile-flyout-page/mobile-flyout-page.component.d.ts +1 -1
- package/lib/components/pagination/pagination.component.d.ts +1 -1
- package/lib/components/popovers/legend/legend.component.d.ts +1 -1
- package/lib/components/popovers/popover-content/popover-content.component.d.ts +1 -1
- package/lib/components/popovers/popover-menu/popover-menu.component.d.ts +1 -1
- package/lib/components/popovers/tooltip/tooltip.directive.d.ts +1 -1
- package/lib/components/progress/progress.component.d.ts +1 -1
- package/lib/components/scroll/scrollable.directive.d.ts +1 -1
- package/lib/components/search-input/search-input.component.d.ts +1 -1
- package/lib/components/sidebar-overlay/sidebar-overlay.component.d.ts +1 -1
- package/lib/components/snackbar/snackbar-container.component.d.ts +1 -1
- package/lib/components/snackbar/snackbar-container.directive.d.ts +1 -1
- package/lib/components/snackbar/snackbar.component.d.ts +1 -1
- package/lib/components/stepper-horizontal/step-horizontal/step-horizontal.component.d.ts +1 -1
- package/lib/components/stepper-horizontal/stepper-horizontal.component.d.ts +1 -1
- package/lib/components/stepper-vertical/step-vertical/step-vertical.component.d.ts +1 -1
- package/lib/components/stepper-vertical/stepper-vertical.component.d.ts +1 -1
- package/lib/components/table-header-cell/table-header-cell.directive.d.ts +1 -1
- package/lib/components/tabs/tab-pane/tab-pane.component.d.ts +1 -1
- package/lib/components/tabs/tabs.component.d.ts +1 -1
- package/lib/forms/checkbox/checkbox.component.d.ts +1 -1
- package/lib/forms/color-indicator/color-indicator.component.d.ts +1 -1
- package/lib/forms/color-picker/color-picker.component.d.ts +1 -1
- package/lib/forms/date-picker/date-picker.component.d.ts +1 -1
- package/lib/forms/date-range-picker/date-range-picker.component.d.ts +1 -1
- package/lib/forms/flatpickr/flatpickr.component.d.ts +1 -1
- package/lib/forms/radio/radio.component.d.ts +6 -6
- package/lib/forms/segment/segment-control/segment-control.component.d.ts +1 -1
- package/lib/forms/segment/segment.component.d.ts +1 -1
- package/lib/forms/select/select-option/select-option.component.d.ts +1 -1
- package/lib/forms/select/select.component.d.ts +6 -5
- package/lib/forms/slider/slider.component.d.ts +1 -1
- package/lib/forms/switch/switch.component.d.ts +1 -1
- package/lib/forms/text-area/text-area.component.d.ts +1 -1
- package/lib/forms/text-editor/text-editor.component.d.ts +1 -1
- package/lib/forms/text-input/text-input.component.d.ts +1 -1
- package/lib/forms/time-picker/time-picker-dropdown/time-picker-dropdown.component.d.ts +1 -1
- package/lib/forms/time-picker/time-picker.component.d.ts +1 -1
- package/lib/forms/value-accessor-base.d.ts +1 -1
- package/lib/modals/alert/alert.component.d.ts +1 -1
- package/lib/modals/confirm/confirm.component.d.ts +1 -1
- package/lib/modals/custom-modal/custom-modal.component.d.ts +1 -1
- package/lib/modals/image-gallery/image-gallery.component.d.ts +1 -1
- package/lib/modals/prompt/prompt.component.d.ts +1 -1
- package/package.json +17 -23
- package/esm2020/lib/components/accordion/accordion-item/accordion-item.component.mjs +0 -148
- package/esm2020/lib/components/accordion/accordion.component.mjs +0 -59
- package/esm2020/lib/components/components.module.mjs +0 -218
- package/esm2020/lib/components/sidebar-overlay/sidebar-overlay.component.mjs +0 -59
- package/esm2020/lib/components/snackbar/snackbar.component.mjs +0 -81
- package/esm2020/lib/components/snackbar/snackbar.module.mjs +0 -24
- package/esm2020/lib/components/tabs/tab-pane/tab-pane.component.mjs +0 -34
- package/esm2020/lib/components/tabs/tabs.component.mjs +0 -459
- package/esm2020/lib/forms/checkbox/checkbox.component.mjs +0 -154
- package/esm2020/lib/forms/color-picker/color-picker.component.mjs +0 -292
- package/esm2020/lib/forms/radio/radio.component.mjs +0 -350
- package/esm2020/lib/forms/select/select.component.mjs +0 -273
- package/esm2020/lib/forms/slider/slider.component.mjs +0 -113
- package/esm2020/lib/forms/switch/switch.component.mjs +0 -121
- package/esm2020/lib/forms/text-area/text-area.component.mjs +0 -187
- package/esm2020/lib/forms/text-editor/text-editor.component.mjs +0 -308
- package/esm2020/lib/forms/text-input/text-input.component.mjs +0 -208
- package/fesm2015/festo-ui-angular.mjs +0 -6504
- package/fesm2015/festo-ui-angular.mjs.map +0 -1
- /package/{esm2020 → esm2022}/festo-ui-angular.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/accordion/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/popovers/popover-ref.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/popovers/popover.defaults.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/popovers/popover.models.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/scroll/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/snackbar/snackbar.models.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/forms/color-picker/color-helper.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modals/index.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
|
@@ -0,0 +1,275 @@
|
|
|
1
|
+
import { takeUntil } from 'rxjs/operators';
|
|
2
|
+
import { Component, Input, HostBinding, ViewEncapsulation, Inject, forwardRef, ViewChild, ContentChildren, Output, EventEmitter } from '@angular/core';
|
|
3
|
+
import { CommonModule, DOCUMENT } from '@angular/common';
|
|
4
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
5
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
6
|
+
import { FngSelectOptionComponent } from './select-option/select-option.component';
|
|
7
|
+
import { FngChipTextPipe } from './chip-text.pipe';
|
|
8
|
+
import { OverlayModule } from '@angular/cdk/overlay';
|
|
9
|
+
import { Subject } from 'rxjs';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/common";
|
|
12
|
+
import * as i2 from "@angular/cdk/overlay";
|
|
13
|
+
export class FngSelectComponent {
|
|
14
|
+
static { this.nextId = 0; }
|
|
15
|
+
get disabled() {
|
|
16
|
+
return this._disabled;
|
|
17
|
+
}
|
|
18
|
+
set disabled(value) {
|
|
19
|
+
this._disabled = coerceBooleanProperty(value);
|
|
20
|
+
}
|
|
21
|
+
get required() {
|
|
22
|
+
return this._required;
|
|
23
|
+
}
|
|
24
|
+
set required(value) {
|
|
25
|
+
this._required = coerceBooleanProperty(value);
|
|
26
|
+
}
|
|
27
|
+
get value() {
|
|
28
|
+
return this._value;
|
|
29
|
+
}
|
|
30
|
+
set value(value) {
|
|
31
|
+
if (this.multiple === true) {
|
|
32
|
+
const index = this._value.indexOf(value);
|
|
33
|
+
if (index === -1) {
|
|
34
|
+
this._value.push(value);
|
|
35
|
+
this.checked.set(value, 'checked');
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
this._value.splice(index, 1);
|
|
39
|
+
this.checked.set(value, null);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
this._value = value;
|
|
44
|
+
}
|
|
45
|
+
if (this.onChange != null) {
|
|
46
|
+
this.onChange(this.value);
|
|
47
|
+
}
|
|
48
|
+
this.fngChange.emit(this.value);
|
|
49
|
+
}
|
|
50
|
+
constructor(document, renderer, cd) {
|
|
51
|
+
this.document = document;
|
|
52
|
+
this.renderer = renderer;
|
|
53
|
+
this.cd = cd;
|
|
54
|
+
this._disabled = false;
|
|
55
|
+
this._required = false;
|
|
56
|
+
this.touched = false;
|
|
57
|
+
this.id = `input-control-${++FngSelectComponent.nextId}`;
|
|
58
|
+
this.multiple = false;
|
|
59
|
+
this.size = 0;
|
|
60
|
+
this.options = [];
|
|
61
|
+
this.label = '';
|
|
62
|
+
this.hideLabel = false;
|
|
63
|
+
this.hint = '';
|
|
64
|
+
this.fngChange = new EventEmitter();
|
|
65
|
+
this.selectPanelClasses = ['fng-select-panel'];
|
|
66
|
+
this.showOptions = false;
|
|
67
|
+
this.empty = false;
|
|
68
|
+
this.checked = new Map();
|
|
69
|
+
this.hasProjectedOptions = false;
|
|
70
|
+
this.projectedHtml = [];
|
|
71
|
+
this.complete = new Subject();
|
|
72
|
+
this.body = this.document.body;
|
|
73
|
+
}
|
|
74
|
+
ngAfterContentInit() {
|
|
75
|
+
// observe if any of the projected content (fng-select-option) changes
|
|
76
|
+
this.fngSelectOptions?.changes.pipe(takeUntil(this.complete)).subscribe(_ => {
|
|
77
|
+
// if content changes init again
|
|
78
|
+
this.options = [];
|
|
79
|
+
this.projectedHtml = [];
|
|
80
|
+
this.initProjectedOptions();
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
ngOnInit() {
|
|
84
|
+
if (this.size != null) {
|
|
85
|
+
this.selectPanelClasses.push('fng-select-panel-options-' + this.size);
|
|
86
|
+
}
|
|
87
|
+
if (this.multiple === true) {
|
|
88
|
+
this._value = [];
|
|
89
|
+
this.selectPanelClasses.push('fng-select-panel-multiple');
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
ngAfterViewInit() {
|
|
93
|
+
this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;
|
|
94
|
+
this.initProjectedOptions();
|
|
95
|
+
}
|
|
96
|
+
ngOnDestroy() {
|
|
97
|
+
this.complete.next(true);
|
|
98
|
+
this.complete.unsubscribe();
|
|
99
|
+
}
|
|
100
|
+
registerOnChange(fn) {
|
|
101
|
+
this.onChange = fn;
|
|
102
|
+
}
|
|
103
|
+
registerOnTouched(fn) {
|
|
104
|
+
this.onTouched = fn;
|
|
105
|
+
}
|
|
106
|
+
setDisabledState(shouldDisable) {
|
|
107
|
+
this.disabled = shouldDisable;
|
|
108
|
+
}
|
|
109
|
+
writeValue(value) {
|
|
110
|
+
if (value === undefined) {
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
if (this.multiple === true) {
|
|
114
|
+
this._value = value;
|
|
115
|
+
// clear any previous state of overlay panel
|
|
116
|
+
this.checked.clear();
|
|
117
|
+
// set checkmarks in overlay panel, so that it is displayed correctly when user opens it
|
|
118
|
+
value?.forEach((v) => {
|
|
119
|
+
this.checked.set(v, 'checked');
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
this._value = value;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
getOptionText(index) {
|
|
127
|
+
if (this.options[index] && this.optionsTextKey && this.options[index][this.optionsTextKey] != null) {
|
|
128
|
+
return this.options[index][this.optionsTextKey];
|
|
129
|
+
}
|
|
130
|
+
return undefined;
|
|
131
|
+
}
|
|
132
|
+
getOptionValue(index) {
|
|
133
|
+
// if set to true the complete option object is returned as value
|
|
134
|
+
if (this.optionObjectAsValue === true) {
|
|
135
|
+
return this.options[index];
|
|
136
|
+
}
|
|
137
|
+
// try to access standard property 'value'
|
|
138
|
+
const v = this.options[index]['value'];
|
|
139
|
+
if (v !== undefined) {
|
|
140
|
+
return v;
|
|
141
|
+
}
|
|
142
|
+
// try to map the value to a property of the option by given key
|
|
143
|
+
if (this.options[index] && this.optionsValueKey && this.options[index][this.optionsValueKey] != null) {
|
|
144
|
+
return this.options[index][this.optionsValueKey];
|
|
145
|
+
}
|
|
146
|
+
return undefined;
|
|
147
|
+
}
|
|
148
|
+
removeChip(event, chip) {
|
|
149
|
+
event.stopPropagation();
|
|
150
|
+
if (!this._disabled) {
|
|
151
|
+
this.markAsTouched();
|
|
152
|
+
this.value = chip;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
onOpenedChange(isOpen) {
|
|
156
|
+
if (isOpen) {
|
|
157
|
+
this.renderer.addClass(this.body, 'fng-select-panel-open');
|
|
158
|
+
}
|
|
159
|
+
else {
|
|
160
|
+
this.renderer.removeClass(this.body, 'fng-select-panel-open');
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
close() {
|
|
164
|
+
this.showOptions = false;
|
|
165
|
+
this.isEmpty();
|
|
166
|
+
}
|
|
167
|
+
toggle() {
|
|
168
|
+
if (false === this.disabled) {
|
|
169
|
+
this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;
|
|
170
|
+
this.showOptions = !this.showOptions;
|
|
171
|
+
this.onOpenedChange(this.showOptions);
|
|
172
|
+
this.isEmpty();
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
select(value, event) {
|
|
176
|
+
if (!this._disabled) {
|
|
177
|
+
this.markAsTouched();
|
|
178
|
+
event.stopPropagation();
|
|
179
|
+
this.value = value;
|
|
180
|
+
if (this.multiple !== true) {
|
|
181
|
+
// closes overlay panel
|
|
182
|
+
this.toggle();
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
markAsTouched() {
|
|
187
|
+
if (!this.touched) {
|
|
188
|
+
if (this.onTouched != null) {
|
|
189
|
+
this.onTouched();
|
|
190
|
+
}
|
|
191
|
+
this.touched = true;
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
initProjectedOptions() {
|
|
195
|
+
if (this.fngSelectOptions?.length) {
|
|
196
|
+
this.hasProjectedOptions = true;
|
|
197
|
+
this.fngSelectOptions.forEach(component => {
|
|
198
|
+
component.update().then(el => {
|
|
199
|
+
if (el) {
|
|
200
|
+
this.options.push({ value: component.value, text: el.textContent?.trim() });
|
|
201
|
+
this.projectedHtml.push(el.innerHTML);
|
|
202
|
+
this.cd.detectChanges();
|
|
203
|
+
}
|
|
204
|
+
});
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
this.cd.detectChanges();
|
|
208
|
+
}
|
|
209
|
+
isEmpty() {
|
|
210
|
+
if (!this.showOptions && (!this._value || '' === this._value)) {
|
|
211
|
+
this.empty = true;
|
|
212
|
+
}
|
|
213
|
+
else {
|
|
214
|
+
this.empty = false;
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngSelectComponent, deps: [{ token: DOCUMENT }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
218
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: FngSelectComponent, isStandalone: true, selector: "fng-select", inputs: { disabled: "disabled", required: "required", multiple: "multiple", size: "size", options: "options", optionsValueKey: "optionsValueKey", optionsTextKey: "optionsTextKey", optionObjectAsValue: "optionObjectAsValue", error: "error", label: "label", hideLabel: "hideLabel", hint: "hint", resetOption: "resetOption" }, outputs: { fngChange: "fngChange" }, host: { properties: { "id": "this.id" } }, providers: [
|
|
219
|
+
{
|
|
220
|
+
provide: NG_VALUE_ACCESSOR,
|
|
221
|
+
useExisting: forwardRef(() => FngSelectComponent),
|
|
222
|
+
multi: true
|
|
223
|
+
}
|
|
224
|
+
], queries: [{ propertyName: "fngSelectOptions", predicate: FngSelectOptionComponent }], viewQueries: [{ propertyName: "elementRef", first: true, predicate: ["div"], descendants: true }], ngImport: i0, template: "<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n <div\n class=\"fwe-select\"\n (click)=\"toggle()\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n [class.fwe-focus]=\"showOptions\"\n [class.fwe-required]=\"required\"\n [class.fwe-disabled]=\"disabled\"\n [class.fwe-pty]=\"empty\"\n >\n <div class=\"fwe-select-content\">\n <ng-container *ngIf=\"!multiple; else chips\">\n {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n </ng-container>\n <ng-template #chips>\n <div class=\"fwe-chip-container\">\n <div\n *ngFor=\"let v of value\"\n class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n [style.max-width.px]=\"triggerWidth\"\n [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n >\n {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n <ng-template\n cdkConnectedOverlay\n cdkConnectedOverlayHasBackdrop\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n [cdkConnectedOverlayOpen]=\"showOptions\"\n [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n (backdropClick)=\"close()\"\n >\n <div class=\"fng-select-panel-wrap\">\n <ul class=\"fwe-select-options-container\">\n <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n <li\n class=\"fwe-select-option\"\n *ngFor=\"let option of options; let i = index\"\n (click)=\"select(getOptionValue(i), $event)\"\n [title]=\"getOptionText(i) || option?.text\"\n >\n <span class=\"fwe-select-option-content\">\n <span\n *ngIf=\"multiple\"\n class=\"fng-select-pseudo-checkbox\"\n [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n ></span>\n <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n </span>\n </li>\n </ul>\n </div>\n </ng-template>\n <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n <div class=\"fwe-select-description\" *ngIf=\"hint\">\n {{ hint }}\n </div>\n <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n {{ error }}\n </div>\n</div>\n<div class=\"fwe-d-none\">\n <ng-content></ng-content>\n</div>\n", styles: [".fng-select-panel-open .fng-select-panel{opacity:1!important}fng-select{width:auto}fng-select.ng-invalid:not(.ng-pristine) .fwe-select:hover{border-color:var(--fwe-red)}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-invalid{display:block}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-description{display:none}.fng-select-panel{opacity:0!important}.fng-select-panel.fng-select-panel-options-3 .fwe-select-options-container{max-height:162px}.fng-select-panel.fng-select-panel-options-4 .fwe-select-options-container{max-height:210px}.fng-select-panel.fng-select-panel-options-5 .fwe-select-options-container{max-height:258px}.fng-select-panel.fng-select-panel-options-6 .fwe-select-options-container{max-height:306px}.fng-select-panel.fng-select-panel-options-7 .fwe-select-options-container{max-height:354px}.fng-select-panel.fng-select-panel-options-8 .fwe-select-options-container{max-height:402px}.fng-select-panel.fng-select-panel-options-9 .fwe-select-options-container{max-height:450px}.fng-select-panel.fng-select-panel-options-10 .fwe-select-options-container{max-height:498px}.fng-select-panel .fwe-select-options-container{scrollbar-width:thin;scrollbar-color:var(--fwe-control-scrollbar) var(--fwe-gray-100)}@media (pointer: fine){.fng-select-panel .fwe-select-options-container::-webkit-scrollbar{width:14px}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-track{background:transparent}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-thumb{overflow:visible;background-color:var(--fwe-control-scrollbar);border:3px solid rgba(242,243,245,0);-webkit-background-clip:padding-box;background-clip:padding-box;border-radius:8px}}.fng-select-panel-wrap{flex-basis:100%}.fwe-select-options-container{position:relative;top:4px;left:0;max-height:258px;min-width:calc(100% + 0px)!important;max-width:280px;overflow:auto;font-size:var(--fwe-font-size-base);background-color:var(--fwe-white);border-radius:4px;padding:8px;margin:0;border:1px solid var(--fwe-gray-200);box-shadow:0 1px 4px #00000029;list-style:none;outline:0}.fwe-select-options-container .fwe-select-option{position:relative;line-height:24px;padding:12px 8px;min-height:24px;cursor:pointer}.fwe-select-options-container .fwe-select-option:hover{background-color:var(--fwe-gray-100)}.fwe-select-options-container .fwe-select-option:last-child{border-bottom:none}.fwe-select-options-container .fwe-select-option .fwe-select-option-content{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;line-height:24px;min-height:24px}.fng-select-pseudo-checkbox{width:16px;height:16px;border-radius:2px;cursor:pointer;display:inline-block;vertical-align:middle;box-sizing:border-box;position:relative;flex-shrink:0;color:var(--fwe-control-border);border:1px solid;transition:none;margin-right:12px;top:-1px}.fng-select-pseudo-checkbox:after{color:var(--fwe-white);position:absolute;display:block;opacity:0;content:\"\";border-bottom:2px solid currentColor;transition:opacity 90ms cubic-bezier(0,0,.2,.1)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked{background:var(--fwe-caerul);border:1px solid var(--fwe-caerul)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked:after{top:3px;left:2px;width:8px;height:3px;border-left:2px solid currentColor;transform:rotate(-45deg);opacity:1;box-sizing:content-box}.chip-text-truncate{display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chip-removable:after{position:absolute;right:5px;top:4px;color:var(--fwe-text);font-family:var(--fwe-font-family-icons-16);font-size:var(--fwe-font-size-base);content:\"\\ea1c\";line-height:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fwe-select-wrapper{display:flex;width:inherit;min-width:48px}.fwe-select-wrapper:before{bottom:unset;top:24px}.fwe-select-wrapper.fng-hide-label{margin-top:18px}.fwe-select-wrapper.fng-hide-label:before{top:6px}.fwe-select-wrapper.fwe-disabled:before{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select{cursor:pointer;height:unset;min-height:33px}.fwe-select-wrapper .fwe-select .fwe-select-content{padding-right:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.5rem}.fwe-select-wrapper .fwe-select.fwe-required:not(.fwe-disabled)~.fwe-select-label:after{position:relative;left:3px;display:inline-block;content:\"*\"}.fwe-select-wrapper .fwe-select.fwe-disabled{cursor:default;border-color:var(--fwe-control-disabled)!important}.fwe-select-wrapper .fwe-select.fwe-disabled~.fwe-select-label{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-select-content{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip{color:var(--fwe-text-disabled);border:1px solid var(--fwe-control-disabled);pointer-events:none}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip .chip-removable:after{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select-label:empty~.fwe-select-options-container,.fwe-select-wrapper .fwe-select-label.fwe-sr-only~.fwe-select-options-container{top:38px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: FngChipTextPipe, name: "fngChipText" }, { kind: "ngmodule", type: OverlayModule }, { kind: "directive", type: i2.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush", "cdkConnectedOverlayDisposeOnNavigation"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: i2.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
225
|
+
}
|
|
226
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngSelectComponent, decorators: [{
|
|
227
|
+
type: Component,
|
|
228
|
+
args: [{ standalone: true, imports: [CommonModule, FngChipTextPipe, FngSelectOptionComponent, OverlayModule], selector: 'fng-select', encapsulation: ViewEncapsulation.None, providers: [
|
|
229
|
+
{
|
|
230
|
+
provide: NG_VALUE_ACCESSOR,
|
|
231
|
+
useExisting: forwardRef(() => FngSelectComponent),
|
|
232
|
+
multi: true
|
|
233
|
+
}
|
|
234
|
+
], template: "<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n <div\n class=\"fwe-select\"\n (click)=\"toggle()\"\n cdkOverlayOrigin\n #trigger=\"cdkOverlayOrigin\"\n [class.fwe-focus]=\"showOptions\"\n [class.fwe-required]=\"required\"\n [class.fwe-disabled]=\"disabled\"\n [class.fwe-pty]=\"empty\"\n >\n <div class=\"fwe-select-content\">\n <ng-container *ngIf=\"!multiple; else chips\">\n {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n </ng-container>\n <ng-template #chips>\n <div class=\"fwe-chip-container\">\n <div\n *ngFor=\"let v of value\"\n class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n [style.max-width.px]=\"triggerWidth\"\n [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n >\n {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n </div>\n </div>\n </ng-template>\n </div>\n </div>\n <ng-template\n cdkConnectedOverlay\n cdkConnectedOverlayHasBackdrop\n cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n [cdkConnectedOverlayOpen]=\"showOptions\"\n [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n (backdropClick)=\"close()\"\n >\n <div class=\"fng-select-panel-wrap\">\n <ul class=\"fwe-select-options-container\">\n <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n <li\n class=\"fwe-select-option\"\n *ngFor=\"let option of options; let i = index\"\n (click)=\"select(getOptionValue(i), $event)\"\n [title]=\"getOptionText(i) || option?.text\"\n >\n <span class=\"fwe-select-option-content\">\n <span\n *ngIf=\"multiple\"\n class=\"fng-select-pseudo-checkbox\"\n [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n ></span>\n <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n </span>\n </li>\n </ul>\n </div>\n </ng-template>\n <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n <div class=\"fwe-select-description\" *ngIf=\"hint\">\n {{ hint }}\n </div>\n <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n {{ error }}\n </div>\n</div>\n<div class=\"fwe-d-none\">\n <ng-content></ng-content>\n</div>\n", styles: [".fng-select-panel-open .fng-select-panel{opacity:1!important}fng-select{width:auto}fng-select.ng-invalid:not(.ng-pristine) .fwe-select:hover{border-color:var(--fwe-red)}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-invalid{display:block}fng-select.ng-invalid:not(.ng-pristine) .fwe-select.fwe-required~.fwe-select-description{display:none}.fng-select-panel{opacity:0!important}.fng-select-panel.fng-select-panel-options-3 .fwe-select-options-container{max-height:162px}.fng-select-panel.fng-select-panel-options-4 .fwe-select-options-container{max-height:210px}.fng-select-panel.fng-select-panel-options-5 .fwe-select-options-container{max-height:258px}.fng-select-panel.fng-select-panel-options-6 .fwe-select-options-container{max-height:306px}.fng-select-panel.fng-select-panel-options-7 .fwe-select-options-container{max-height:354px}.fng-select-panel.fng-select-panel-options-8 .fwe-select-options-container{max-height:402px}.fng-select-panel.fng-select-panel-options-9 .fwe-select-options-container{max-height:450px}.fng-select-panel.fng-select-panel-options-10 .fwe-select-options-container{max-height:498px}.fng-select-panel .fwe-select-options-container{scrollbar-width:thin;scrollbar-color:var(--fwe-control-scrollbar) var(--fwe-gray-100)}@media (pointer: fine){.fng-select-panel .fwe-select-options-container::-webkit-scrollbar{width:14px}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-track{background:transparent}.fng-select-panel .fwe-select-options-container::-webkit-scrollbar-thumb{overflow:visible;background-color:var(--fwe-control-scrollbar);border:3px solid rgba(242,243,245,0);-webkit-background-clip:padding-box;background-clip:padding-box;border-radius:8px}}.fng-select-panel-wrap{flex-basis:100%}.fwe-select-options-container{position:relative;top:4px;left:0;max-height:258px;min-width:calc(100% + 0px)!important;max-width:280px;overflow:auto;font-size:var(--fwe-font-size-base);background-color:var(--fwe-white);border-radius:4px;padding:8px;margin:0;border:1px solid var(--fwe-gray-200);box-shadow:0 1px 4px #00000029;list-style:none;outline:0}.fwe-select-options-container .fwe-select-option{position:relative;line-height:24px;padding:12px 8px;min-height:24px;cursor:pointer}.fwe-select-options-container .fwe-select-option:hover{background-color:var(--fwe-gray-100)}.fwe-select-options-container .fwe-select-option:last-child{border-bottom:none}.fwe-select-options-container .fwe-select-option .fwe-select-option-content{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;line-height:24px;min-height:24px}.fng-select-pseudo-checkbox{width:16px;height:16px;border-radius:2px;cursor:pointer;display:inline-block;vertical-align:middle;box-sizing:border-box;position:relative;flex-shrink:0;color:var(--fwe-control-border);border:1px solid;transition:none;margin-right:12px;top:-1px}.fng-select-pseudo-checkbox:after{color:var(--fwe-white);position:absolute;display:block;opacity:0;content:\"\";border-bottom:2px solid currentColor;transition:opacity 90ms cubic-bezier(0,0,.2,.1)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked{background:var(--fwe-caerul);border:1px solid var(--fwe-caerul)}.fng-select-pseudo-checkbox.fng-select-pseudo-checkbox-checked:after{top:3px;left:2px;width:8px;height:3px;border-left:2px solid currentColor;transform:rotate(-45deg);opacity:1;box-sizing:content-box}.chip-text-truncate{display:inline-block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chip-removable:after{position:absolute;right:5px;top:4px;color:var(--fwe-text);font-family:var(--fwe-font-family-icons-16);font-size:var(--fwe-font-size-base);content:\"\\ea1c\";line-height:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fwe-select-wrapper{display:flex;width:inherit;min-width:48px}.fwe-select-wrapper:before{bottom:unset;top:24px}.fwe-select-wrapper.fng-hide-label{margin-top:18px}.fwe-select-wrapper.fng-hide-label:before{top:6px}.fwe-select-wrapper.fwe-disabled:before{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select{cursor:pointer;height:unset;min-height:33px}.fwe-select-wrapper .fwe-select .fwe-select-content{padding-right:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.5rem}.fwe-select-wrapper .fwe-select.fwe-required:not(.fwe-disabled)~.fwe-select-label:after{position:relative;left:3px;display:inline-block;content:\"*\"}.fwe-select-wrapper .fwe-select.fwe-disabled{cursor:default;border-color:var(--fwe-control-disabled)!important}.fwe-select-wrapper .fwe-select.fwe-disabled~.fwe-select-label{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-select-content{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip{color:var(--fwe-text-disabled);border:1px solid var(--fwe-control-disabled);pointer-events:none}.fwe-select-wrapper .fwe-select.fwe-disabled .fwe-chip .chip-removable:after{color:var(--fwe-text-disabled)}.fwe-select-wrapper .fwe-select-label:empty~.fwe-select-options-container,.fwe-select-wrapper .fwe-select-label.fwe-sr-only~.fwe-select-options-container{top:38px}\n"] }]
|
|
235
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
236
|
+
type: Inject,
|
|
237
|
+
args: [DOCUMENT]
|
|
238
|
+
}] }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }], propDecorators: { disabled: [{
|
|
239
|
+
type: Input
|
|
240
|
+
}], required: [{
|
|
241
|
+
type: Input
|
|
242
|
+
}], id: [{
|
|
243
|
+
type: HostBinding
|
|
244
|
+
}], multiple: [{
|
|
245
|
+
type: Input
|
|
246
|
+
}], size: [{
|
|
247
|
+
type: Input
|
|
248
|
+
}], options: [{
|
|
249
|
+
type: Input
|
|
250
|
+
}], optionsValueKey: [{
|
|
251
|
+
type: Input
|
|
252
|
+
}], optionsTextKey: [{
|
|
253
|
+
type: Input
|
|
254
|
+
}], optionObjectAsValue: [{
|
|
255
|
+
type: Input
|
|
256
|
+
}], error: [{
|
|
257
|
+
type: Input
|
|
258
|
+
}], label: [{
|
|
259
|
+
type: Input
|
|
260
|
+
}], hideLabel: [{
|
|
261
|
+
type: Input
|
|
262
|
+
}], hint: [{
|
|
263
|
+
type: Input
|
|
264
|
+
}], resetOption: [{
|
|
265
|
+
type: Input
|
|
266
|
+
}], fngSelectOptions: [{
|
|
267
|
+
type: ContentChildren,
|
|
268
|
+
args: [FngSelectOptionComponent]
|
|
269
|
+
}], elementRef: [{
|
|
270
|
+
type: ViewChild,
|
|
271
|
+
args: ['div']
|
|
272
|
+
}], fngChange: [{
|
|
273
|
+
type: Output
|
|
274
|
+
}] } });
|
|
275
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/forms/select/select.component.ts","../../../../../../projects/angular/src/lib/forms/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { takeUntil } from 'rxjs/operators';\nimport {\n  Component,\n  Input,\n  HostBinding,\n  OnInit,\n  ViewEncapsulation,\n  Renderer2,\n  Inject,\n  forwardRef,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  QueryList,\n  ContentChildren,\n  Output,\n  EventEmitter,\n  ChangeDetectorRef,\n  AfterContentInit\n} from '@angular/core';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { FngSelectOptionComponent } from './select-option/select-option.component';\nimport { FngChipTextPipe } from './chip-text.pipe';\nimport { OverlayModule } from '@angular/cdk/overlay';\nimport { Subject } from 'rxjs';\n\nexport interface FngSelectOption {\n  value: any;\n  text: string;\n}\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, FngChipTextPipe, FngSelectOptionComponent, OverlayModule],\n  selector: 'fng-select',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FngSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class FngSelectComponent implements ControlValueAccessor, OnInit, AfterViewInit, AfterContentInit {\n  static nextId = 0;\n\n  protected _disabled = false;\n  protected _required = false;\n  protected _value: any;\n  protected body: HTMLElement;\n\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n  }\n\n  @Input()\n  get required(): boolean {\n    return this._required;\n  }\n  set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  set value(value: any) {\n    if (this.multiple === true) {\n      const index = this._value.indexOf(value);\n      if (index === -1) {\n        this._value.push(value);\n        this.checked.set(value, 'checked');\n      } else {\n        this._value.splice(index, 1);\n        this.checked.set(value, null);\n      }\n    } else {\n      this._value = value;\n    }\n\n    if (this.onChange != null) {\n      this.onChange(this.value);\n    }\n    this.fngChange.emit(this.value);\n  }\n\n  onChange: ((_: any) => void) | undefined;\n  onTouched: (() => void) | undefined;\n\n  touched = false;\n\n  @HostBinding()\n  id = `input-control-${++FngSelectComponent.nextId}`;\n\n  @Input() multiple: boolean = false;\n  @Input() size: number = 0;\n  @Input() options: any[] = [];\n  @Input() optionsValueKey: string | undefined;\n  @Input() optionsTextKey: string | undefined;\n  @Input() optionObjectAsValue: boolean | undefined;\n  @Input() error: string | undefined;\n  @Input() label = '';\n  @Input() hideLabel = false;\n  @Input() hint = '';\n  @Input() resetOption: string | undefined;\n  @ContentChildren(FngSelectOptionComponent) fngSelectOptions: QueryList<FngSelectOptionComponent> | undefined;\n  @ViewChild('div') elementRef: ElementRef | undefined;\n  @Output() fngChange = new EventEmitter<any>();\n\n  selectPanelClasses: string[] = ['fng-select-panel'];\n  showOptions = false;\n  empty: boolean = false;\n  triggerWidth: any;\n  checked = new Map();\n  hasProjectedOptions = false;\n  projectedHtml: any[] = [];\n  protected complete: Subject<boolean> = new Subject();\n\n  constructor(@Inject(DOCUMENT) protected document: any, protected renderer: Renderer2, public cd: ChangeDetectorRef) {\n    this.body = (this.document as Document).body;\n  }\n  ngAfterContentInit(): void {\n    // observe if any of the projected content (fng-select-option) changes\n    this.fngSelectOptions?.changes.pipe(takeUntil(this.complete)).subscribe(_ => {\n      // if content changes init again\n      this.options = [];\n      this.projectedHtml = [];\n      this.initProjectedOptions();\n    });\n  }\n\n  ngOnInit(): void {\n    if (this.size != null) {\n      this.selectPanelClasses.push('fng-select-panel-options-' + this.size);\n    }\n\n    if (this.multiple === true) {\n      this._value = [];\n      this.selectPanelClasses.push('fng-select-panel-multiple');\n    }\n  }\n\n  ngAfterViewInit(): void {\n    this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;\n    this.initProjectedOptions();\n  }\n\n  ngOnDestroy(): void {\n    this.complete.next(true);\n    this.complete.unsubscribe();\n  }\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(shouldDisable: boolean): void {\n    this.disabled = shouldDisable;\n  }\n\n  writeValue(value: any | null): void {\n    if (value === undefined) {\n      return;\n    }\n\n    if (this.multiple === true) {\n      this._value = value;\n\n      // clear any previous state of overlay panel\n      this.checked.clear();\n\n      // set checkmarks in overlay panel, so that it is displayed correctly when user opens it\n      value?.forEach((v: any) => {\n        this.checked.set(v, 'checked');\n      });\n    } else {\n      this._value = value;\n    }\n  }\n\n  getOptionText(index: number) {\n    if (this.options[index] && this.optionsTextKey && this.options[index][this.optionsTextKey] != null) {\n      return this.options[index][this.optionsTextKey];\n    }\n    return undefined;\n  }\n\n  getOptionValue(index: number) {\n    // if set to true the complete option object is returned as value\n    if (this.optionObjectAsValue === true) {\n      return this.options[index];\n    }\n\n    // try to access standard property 'value'\n    const v = this.options[index]['value'];\n\n    if (v !== undefined) {\n      return v;\n    }\n\n    // try to map the value to a property of the option by given key\n    if (this.options[index] && this.optionsValueKey && this.options[index][this.optionsValueKey] != null) {\n      return this.options[index][this.optionsValueKey];\n    }\n    return undefined;\n  }\n\n  removeChip(event: any, chip: string) {\n    event.stopPropagation();\n    if (!this._disabled) {\n      this.markAsTouched();\n      this.value = chip;\n    }\n  }\n\n  onOpenedChange(isOpen: boolean) {\n    if (isOpen) {\n      this.renderer.addClass(this.body, 'fng-select-panel-open');\n    } else {\n      this.renderer.removeClass(this.body, 'fng-select-panel-open');\n    }\n  }\n\n  close() {\n    this.showOptions = false;\n    this.isEmpty();\n  }\n\n  toggle() {\n    if (false === this.disabled) {\n      this.triggerWidth = this.elementRef?.nativeElement?.getBoundingClientRect()?.width;\n      this.showOptions = !this.showOptions;\n      this.onOpenedChange(this.showOptions);\n      this.isEmpty();\n    }\n  }\n\n  select(value: any, event: Event) {\n    if (!this._disabled) {\n      this.markAsTouched();\n      event.stopPropagation();\n      this.value = value;\n\n      if (this.multiple !== true) {\n        // closes overlay panel\n        this.toggle();\n      }\n    }\n  }\n\n  markAsTouched() {\n    if (!this.touched) {\n      if (this.onTouched != null) {\n        this.onTouched();\n      }\n      this.touched = true;\n    }\n  }\n\n  initProjectedOptions() {\n    if (this.fngSelectOptions?.length) {\n      this.hasProjectedOptions = true;\n      this.fngSelectOptions.forEach(component => {\n        component.update().then(el => {\n          if (el) {\n            this.options.push({ value: component.value, text: el.textContent?.trim() });\n            this.projectedHtml.push(el.innerHTML);\n            this.cd.detectChanges();\n          }\n        });\n      });\n    }\n    this.cd.detectChanges();\n  }\n\n  isEmpty() {\n    if (!this.showOptions && (!this._value || '' === this._value)) {\n      this.empty = true;\n    } else {\n      this.empty = false;\n    }\n  }\n}\n","<div #div class=\"fwe-select-wrapper\" [class.fwe-disabled]=\"disabled\" [class.fng-hide-label]=\"hideLabel\">\n  <div\n    class=\"fwe-select\"\n    (click)=\"toggle()\"\n    cdkOverlayOrigin\n    #trigger=\"cdkOverlayOrigin\"\n    [class.fwe-focus]=\"showOptions\"\n    [class.fwe-required]=\"required\"\n    [class.fwe-disabled]=\"disabled\"\n    [class.fwe-pty]=\"empty\"\n  >\n    <div class=\"fwe-select-content\">\n      <ng-container *ngIf=\"!multiple; else chips\">\n        {{ value != null && value | fngChipText: options:optionsValueKey:optionsTextKey }}\n      </ng-container>\n      <ng-template #chips>\n        <div class=\"fwe-chip-container\">\n          <div\n            *ngFor=\"let v of value\"\n            class=\"fwe-chip chip-text-truncate fwe-pr-4\"\n            [style.max-width.px]=\"triggerWidth\"\n            [title]=\"v | fngChipText: options:optionsValueKey:optionsTextKey\"\n          >\n            {{ v | fngChipText: options:optionsValueKey:optionsTextKey }}\n            <span class=\"chip-removable\" (click)=\"removeChip($event, v)\"></span>\n          </div>\n        </div>\n      </ng-template>\n    </div>\n  </div>\n  <ng-template\n    cdkConnectedOverlay\n    cdkConnectedOverlayHasBackdrop\n    cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n    [cdkConnectedOverlayOrigin]=\"trigger\"\n    [cdkConnectedOverlayMinWidth]=\"triggerWidth\"\n    [cdkConnectedOverlayOpen]=\"showOptions\"\n    [cdkConnectedOverlayPanelClass]=\"selectPanelClasses\"\n    (backdropClick)=\"close()\"\n  >\n    <div class=\"fng-select-panel-wrap\">\n      <ul class=\"fwe-select-options-container\">\n        <li class=\"fwe-select-option\" *ngIf=\"resetOption != null && !multiple\" (click)=\"select(null, $event)\">{{ resetOption }}</li>\n        <li\n          class=\"fwe-select-option\"\n          *ngFor=\"let option of options; let i = index\"\n          (click)=\"select(getOptionValue(i), $event)\"\n          [title]=\"getOptionText(i) || option?.text\"\n        >\n          <span class=\"fwe-select-option-content\">\n            <span\n              *ngIf=\"multiple\"\n              class=\"fng-select-pseudo-checkbox\"\n              [ngClass]=\"{ 'fng-select-pseudo-checkbox-checked': checked.get(getOptionValue(i)) === 'checked' }\"\n            ></span>\n            <span *ngIf=\"hasProjectedOptions; else defaultTemplate\" [innerHTML]=\"projectedHtml[i]\"></span>\n            <ng-template #defaultTemplate>{{ getOptionText(i) || option?.text }}</ng-template>\n          </span>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n  <label class=\"fwe-select-label\" [for]=\"id\" [class.fwe-sr-only]=\"hideLabel\">{{ label }}</label>\n  <div class=\"fwe-select-description\" *ngIf=\"hint\">\n    {{ hint }}\n  </div>\n  <div class=\"fwe-select-invalid\" *ngIf=\"error\">\n    {{ error }}\n  </div>\n</div>\n<div class=\"fwe-d-none\">\n  <ng-content></ng-content>\n</div>\n"]}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { Component, forwardRef, ViewEncapsulation, Input, HostListener } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';
|
|
4
|
+
import { Subscription, Subject } from 'rxjs';
|
|
5
|
+
import { debounceTime } from 'rxjs/operators';
|
|
6
|
+
import { CommonModule } from '@angular/common';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/common";
|
|
9
|
+
export class FngSliderComponent {
|
|
10
|
+
get disabled() {
|
|
11
|
+
return this.innerDisabled;
|
|
12
|
+
}
|
|
13
|
+
set disabled(value) {
|
|
14
|
+
this.innerDisabled = coerceBooleanProperty(value);
|
|
15
|
+
}
|
|
16
|
+
get value() {
|
|
17
|
+
return this.innerValue;
|
|
18
|
+
}
|
|
19
|
+
set value(value) {
|
|
20
|
+
this.innerValue = coerceNumberProperty(value);
|
|
21
|
+
if (this.onChange != null) {
|
|
22
|
+
this.onChange(value);
|
|
23
|
+
}
|
|
24
|
+
if (this.onTouched != null) {
|
|
25
|
+
this.onTouched();
|
|
26
|
+
}
|
|
27
|
+
this.updateValuePosition();
|
|
28
|
+
}
|
|
29
|
+
constructor(elementRef) {
|
|
30
|
+
this.elementRef = elementRef;
|
|
31
|
+
this.large = false;
|
|
32
|
+
this.min = 0;
|
|
33
|
+
this.max = 100;
|
|
34
|
+
this.step = 0;
|
|
35
|
+
this.left = 0;
|
|
36
|
+
this.innerDisabled = false;
|
|
37
|
+
this.innerValue = 0;
|
|
38
|
+
this.resizeSub = new Subscription();
|
|
39
|
+
this.resizeSubject = new Subject();
|
|
40
|
+
}
|
|
41
|
+
onResize() {
|
|
42
|
+
this.resizeSubject.next(true);
|
|
43
|
+
}
|
|
44
|
+
ngAfterViewInit() {
|
|
45
|
+
this.resizeSub.add(this.resizeSubject.pipe(debounceTime(25)).subscribe(() => this.updateValuePosition()));
|
|
46
|
+
}
|
|
47
|
+
ngOnDestroy() {
|
|
48
|
+
this.resizeSub.unsubscribe();
|
|
49
|
+
}
|
|
50
|
+
writeValue(value) {
|
|
51
|
+
this.innerValue = coerceNumberProperty(value);
|
|
52
|
+
this.updateValuePosition();
|
|
53
|
+
}
|
|
54
|
+
registerOnChange(fn) {
|
|
55
|
+
this.onChange = fn;
|
|
56
|
+
}
|
|
57
|
+
registerOnTouched(fn) {
|
|
58
|
+
this.onTouched = fn;
|
|
59
|
+
}
|
|
60
|
+
setDisabledState(isDisabled) {
|
|
61
|
+
this.disabled = isDisabled;
|
|
62
|
+
}
|
|
63
|
+
onInput(event) {
|
|
64
|
+
this.value = coerceNumberProperty(event.target.value);
|
|
65
|
+
}
|
|
66
|
+
updateValuePosition() {
|
|
67
|
+
if (this.elementRef != null && this.elementRef.nativeElement != null) {
|
|
68
|
+
const bcr = this.elementRef.nativeElement.getBoundingClientRect();
|
|
69
|
+
const diff = this.max - this.min;
|
|
70
|
+
this.left = ((this.value - this.min) / diff) * (bcr.width - 16);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngSliderComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
74
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: FngSliderComponent, isStandalone: true, selector: "fng-slider", inputs: { label: "label", large: "large", min: "min", max: "max", step: "step", digitsInfo: "digitsInfo", locale: "locale", disabled: "disabled", value: "value" }, host: { listeners: { "window:resize": "onResize()" } }, providers: [
|
|
75
|
+
{
|
|
76
|
+
provide: NG_VALUE_ACCESSOR,
|
|
77
|
+
useExisting: forwardRef(() => FngSliderComponent),
|
|
78
|
+
multi: true
|
|
79
|
+
}
|
|
80
|
+
], ngImport: i0, template: "<label class=\"fwe-slider\" [class.fwe-slider-lg]=\"large\" [class.fng-slider-label]=\"label != null\">\n <span *ngIf=\"label\">{{ label }}</span>\n <input\n type=\"range\"\n class=\"fwe-slider-input\"\n [disabled]=\"disabled\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n [attr.step]=\"step\"\n autocomplete=\"off\"\n [value]=\"value\"\n (input)=\"onInput($event)\"\n />\n <span *ngIf=\"left != null\" class=\"fng-slider-value\" [style.left]=\"left + 'px'\">{{ value | number: digitsInfo:locale }}</span>\n</label>\n", styles: ["label.fwe-slider{display:block;height:56px;position:relative}label.fwe-slider.fng-slider-label{height:83px}label.fwe-slider .fng-slider-value{color:var(--fwe-text);font-size:var(--fwe-font-size-base);margin-bottom:0;position:absolute;bottom:0;-webkit-user-select:none;user-select:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.DecimalPipe, name: "number" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
81
|
+
}
|
|
82
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FngSliderComponent, decorators: [{
|
|
83
|
+
type: Component,
|
|
84
|
+
args: [{ standalone: true, imports: [CommonModule], selector: 'fng-slider', providers: [
|
|
85
|
+
{
|
|
86
|
+
provide: NG_VALUE_ACCESSOR,
|
|
87
|
+
useExisting: forwardRef(() => FngSliderComponent),
|
|
88
|
+
multi: true
|
|
89
|
+
}
|
|
90
|
+
], encapsulation: ViewEncapsulation.None, template: "<label class=\"fwe-slider\" [class.fwe-slider-lg]=\"large\" [class.fng-slider-label]=\"label != null\">\n <span *ngIf=\"label\">{{ label }}</span>\n <input\n type=\"range\"\n class=\"fwe-slider-input\"\n [disabled]=\"disabled\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n [attr.step]=\"step\"\n autocomplete=\"off\"\n [value]=\"value\"\n (input)=\"onInput($event)\"\n />\n <span *ngIf=\"left != null\" class=\"fng-slider-value\" [style.left]=\"left + 'px'\">{{ value | number: digitsInfo:locale }}</span>\n</label>\n", styles: ["label.fwe-slider{display:block;height:56px;position:relative}label.fwe-slider.fng-slider-label{height:83px}label.fwe-slider .fng-slider-value{color:var(--fwe-text);font-size:var(--fwe-font-size-base);margin-bottom:0;position:absolute;bottom:0;-webkit-user-select:none;user-select:none}\n"] }]
|
|
91
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { label: [{
|
|
92
|
+
type: Input
|
|
93
|
+
}], large: [{
|
|
94
|
+
type: Input
|
|
95
|
+
}], min: [{
|
|
96
|
+
type: Input
|
|
97
|
+
}], max: [{
|
|
98
|
+
type: Input
|
|
99
|
+
}], step: [{
|
|
100
|
+
type: Input
|
|
101
|
+
}], digitsInfo: [{
|
|
102
|
+
type: Input
|
|
103
|
+
}], locale: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], disabled: [{
|
|
106
|
+
type: Input
|
|
107
|
+
}], value: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}], onResize: [{
|
|
110
|
+
type: HostListener,
|
|
111
|
+
args: ['window:resize']
|
|
112
|
+
}] } });
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../../projects/angular/src/lib/forms/slider/slider.component.ts","../../../../../../projects/angular/src/lib/forms/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import { OnDestroy, Component, forwardRef, ViewEncapsulation, Input, ElementRef, AfterViewInit, HostListener } from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\nimport { coerceBooleanProperty, coerceNumberProperty } from '@angular/cdk/coercion';\nimport { Subscription, Subject } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport { CommonModule } from '@angular/common';\n\n@Component({\n  standalone: true,\n  imports: [CommonModule],\n  selector: 'fng-slider',\n  templateUrl: './slider.component.html',\n  styleUrls: ['./slider.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => FngSliderComponent),\n      multi: true\n    }\n  ],\n  encapsulation: ViewEncapsulation.None\n})\nexport class FngSliderComponent implements AfterViewInit, OnDestroy, ControlValueAccessor {\n  @Input() label: string | undefined;\n  @Input() large = false;\n\n  @Input()\n  min = 0;\n\n  @Input()\n  max = 100;\n\n  @Input()\n  step: number = 0;\n\n  @Input()\n  digitsInfo: string | undefined;\n\n  @Input()\n  locale: string | undefined;\n\n  left: number = 0;\n\n  protected innerDisabled = false;\n  get disabled(): boolean {\n    return this.innerDisabled;\n  }\n  @Input()\n  set disabled(value: boolean) {\n    this.innerDisabled = coerceBooleanProperty(value);\n  }\n\n  protected innerValue: number = 0;\n  get value(): number {\n    return this.innerValue;\n  }\n\n  @Input()\n  set value(value: number) {\n    this.innerValue = coerceNumberProperty(value);\n    if (this.onChange != null) {\n      this.onChange(value);\n    }\n    if (this.onTouched != null) {\n      this.onTouched();\n    }\n    this.updateValuePosition();\n  }\n\n  private resizeSub = new Subscription();\n  private resizeSubject = new Subject<boolean>();\n\n  constructor(private elementRef: ElementRef) {}\n\n  onChange: ((value: number) => void) | undefined;\n\n  onTouched: (() => void) | undefined;\n\n  @HostListener('window:resize') onResize() {\n    this.resizeSubject.next(true);\n  }\n\n  ngAfterViewInit() {\n    this.resizeSub.add(this.resizeSubject.pipe(debounceTime(25)).subscribe(() => this.updateValuePosition()));\n  }\n\n  ngOnDestroy() {\n    this.resizeSub.unsubscribe();\n  }\n\n  writeValue(value: any): void {\n    this.innerValue = coerceNumberProperty(value);\n    this.updateValuePosition();\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  onInput(event: any) {\n    this.value = coerceNumberProperty((event.target as HTMLInputElement).value);\n  }\n\n  updateValuePosition() {\n    if (this.elementRef != null && this.elementRef.nativeElement != null) {\n      const bcr = (this.elementRef.nativeElement as HTMLElement).getBoundingClientRect();\n      const diff = this.max - this.min;\n      this.left = ((this.value - this.min) / diff) * (bcr.width - 16);\n    }\n  }\n}\n","<label class=\"fwe-slider\" [class.fwe-slider-lg]=\"large\" [class.fng-slider-label]=\"label != null\">\n  <span *ngIf=\"label\">{{ label }}</span>\n  <input\n    type=\"range\"\n    class=\"fwe-slider-input\"\n    [disabled]=\"disabled\"\n    [attr.min]=\"min\"\n    [attr.max]=\"max\"\n    [attr.step]=\"step\"\n    autocomplete=\"off\"\n    [value]=\"value\"\n    (input)=\"onInput($event)\"\n  />\n  <span *ngIf=\"left != null\" class=\"fng-slider-value\" [style.left]=\"left + 'px'\">{{ value | number: digitsInfo:locale }}</span>\n</label>\n"]}
|