@openmrs/ngx-formentry 3.0.1-pre.38 → 3.0.1-pre.44
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/bundles/openmrs-ngx-formentry.umd.js +11525 -10873
- package/bundles/openmrs-ngx-formentry.umd.js.map +1 -1
- package/components/afe-ng-select.component.d.ts +3 -0
- package/components/appointments-overview/appointments-overview.component.d.ts +3 -0
- package/components/check-box/checkbox.component.d.ts +3 -0
- package/components/check-box/checkbox.module.d.ts +7 -0
- package/components/custom-component-wrapper/custom-component-wrapper..module.d.ts +7 -0
- package/components/custom-component-wrapper/custom-component-wrapper.component.d.ts +3 -0
- package/components/custom-control-wrapper/custom-control-wrapper..module.d.ts +8 -0
- package/components/custom-control-wrapper/custom-control-wrapper.component.d.ts +3 -0
- package/components/date-time-picker/date-picker/date-picker.component.d.ts +3 -0
- package/components/date-time-picker/date-time-picker.component.d.ts +3 -0
- package/components/date-time-picker/date-time-picker.module.d.ts +11 -3
- package/components/date-time-picker/index.d.ts +8 -0
- package/components/date-time-picker/picker-modal/modal.component.d.ts +3 -0
- package/components/date-time-picker/pipes/moment.pipe.d.ts +3 -0
- package/components/date-time-picker/time-picker/time-picker.component.d.ts +3 -0
- package/components/file-upload/file-upload.component.d.ts +3 -0
- package/components/file-upload/file-upload.module.d.ts +10 -0
- package/components/file-upload/secure.pipe.d.ts +3 -0
- package/components/input/input.directive.d.ts +3 -0
- package/components/input/input.module.d.ts +9 -0
- package/components/input/label.component.d.ts +3 -0
- package/components/input/text-area.directive.d.ts +3 -0
- package/components/ngx-datetime-picker/ngx-datetime-picker.component.d.ts +3 -0
- package/components/ngx-datetime-picker/ngx-datetime-picker.module.d.ts +9 -3
- package/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time-adapter.class.d.ts +3 -3
- package/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time.module.d.ts +8 -3
- package/components/ngx-pick-datetime/lib/date-time/calendar-body.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/calendar-month-view.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/calendar-multi-year-view.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/calendar-year-view.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/calendar.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-inline.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker-container.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker-input.directive.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker-intl.service.d.ts +3 -3
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker-trigger.directive.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time.class.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time.module.d.ts +21 -3
- package/components/ngx-pick-datetime/lib/date-time/numberedFixLen.pipe.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/timer-box.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/date-time/timer.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/dialog/dialog-container.component.d.ts +3 -0
- package/components/ngx-pick-datetime/lib/dialog/dialog.module.d.ts +9 -3
- package/components/ngx-pick-datetime/lib/dialog/dialog.service.d.ts +3 -0
- package/components/ngx-remote-select/ngx-remote-select.component.d.ts +3 -0
- package/components/ngx-remote-select/ngx-remote-select.module.d.ts +8 -0
- package/components/ngx-tabset/components/ngx-tab-set.component.d.ts +3 -0
- package/components/ngx-tabset/components/tab.component.d.ts +3 -0
- package/components/ngx-tabset/directives/hover-class.directive.d.ts +3 -0
- package/components/ngx-tabset/modules/ngx-tabset.module.d.ts +8 -0
- package/components/number-input/number-input.component.d.ts +3 -0
- package/components/number-input/number-input.module.d.ts +7 -0
- package/components/select/optgroup.directive.d.ts +3 -0
- package/components/select/option.directive.d.ts +3 -0
- package/components/select/select.component.d.ts +3 -0
- package/components/select/select.module.d.ts +9 -0
- package/esm2015/components/afe-ng-select.component.js +37 -19
- package/esm2015/components/appointments-overview/appointments-overview.component.js +15 -12
- package/esm2015/components/check-box/checkbox.component.js +31 -19
- package/esm2015/components/check-box/checkbox.module.js +13 -8
- package/esm2015/components/custom-component-wrapper/custom-component-wrapper..module.js +15 -10
- package/esm2015/components/custom-component-wrapper/custom-component-wrapper.component.js +17 -11
- package/esm2015/components/custom-control-wrapper/custom-control-wrapper..module.js +15 -10
- package/esm2015/components/custom-control-wrapper/custom-control-wrapper.component.js +27 -17
- package/esm2015/components/date-time-picker/date-picker/date-picker.component.js +27 -17
- package/esm2015/components/date-time-picker/date-time-picker.component.js +40 -24
- package/esm2015/components/date-time-picker/date-time-picker.module.js +34 -21
- package/esm2015/components/date-time-picker/index.js +9 -0
- package/esm2015/components/date-time-picker/picker-modal/modal.component.js +16 -14
- package/esm2015/components/date-time-picker/pipes/moment.pipe.js +8 -4
- package/esm2015/components/date-time-picker/time-picker/time-picker.component.js +29 -18
- package/esm2015/components/file-upload/file-upload.component.js +34 -22
- package/esm2015/components/file-upload/file-upload.module.js +31 -16
- package/esm2015/components/file-upload/secure.pipe.js +12 -11
- package/esm2015/components/input/input.directive.js +41 -17
- package/esm2015/components/input/input.module.js +13 -8
- package/esm2015/components/input/label.component.js +109 -22
- package/esm2015/components/input/text-area.directive.js +28 -13
- package/esm2015/components/ngx-datetime-picker/ngx-datetime-picker.component.js +40 -22
- package/esm2015/components/ngx-datetime-picker/ngx-datetime-picker.module.js +28 -15
- package/esm2015/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time-adapter.class.js +14 -11
- package/esm2015/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time.module.js +26 -17
- package/esm2015/components/ngx-pick-datetime/lib/date-time/calendar-body.component.js +35 -28
- package/esm2015/components/ngx-pick-datetime/lib/date-time/calendar-month-view.component.js +55 -34
- package/esm2015/components/ngx-pick-datetime/lib/date-time/calendar-multi-year-view.component.js +48 -33
- package/esm2015/components/ngx-pick-datetime/lib/date-time/calendar-year-view.component.js +52 -33
- package/esm2015/components/ngx-pick-datetime/lib/date-time/calendar.component.js +62 -39
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-inline.component.js +55 -33
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker-container.component.js +46 -35
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker-input.directive.js +53 -38
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker-intl.service.js +7 -5
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker-trigger.directive.js +19 -17
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker.component.js +57 -36
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time.class.js +31 -18
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time.module.js +59 -34
- package/esm2015/components/ngx-pick-datetime/lib/date-time/numberedFixLen.pipe.js +10 -6
- package/esm2015/components/ngx-pick-datetime/lib/date-time/timer-box.component.js +46 -30
- package/esm2015/components/ngx-pick-datetime/lib/date-time/timer.component.js +43 -33
- package/esm2015/components/ngx-pick-datetime/lib/dialog/dialog-container.component.js +78 -50
- package/esm2015/components/ngx-pick-datetime/lib/dialog/dialog.module.js +15 -10
- package/esm2015/components/ngx-pick-datetime/lib/dialog/dialog.service.js +24 -13
- package/esm2015/components/ngx-remote-select/ngx-remote-select.component.js +39 -25
- package/esm2015/components/ngx-remote-select/ngx-remote-select.module.js +14 -9
- package/esm2015/components/ngx-tabset/components/ngx-tab-set.component.js +27 -16
- package/esm2015/components/ngx-tabset/components/tab.component.js +28 -17
- package/esm2015/components/ngx-tabset/directives/hover-class.directive.js +19 -14
- package/esm2015/components/ngx-tabset/modules/ngx-tabset.module.js +13 -8
- package/esm2015/components/number-input/number-input.component.js +68 -38
- package/esm2015/components/number-input/number-input.module.js +14 -9
- package/esm2015/components/select/optgroup.directive.js +14 -10
- package/esm2015/components/select/option.directive.js +14 -10
- package/esm2015/components/select/select.component.js +187 -35
- package/esm2015/components/select/select.module.js +13 -8
- package/esm2015/form-entry/data-sources/data-sources.js +7 -5
- package/esm2015/form-entry/directives/collapse.directive.js +48 -29
- package/esm2015/form-entry/directives/historical-value-directive.js +20 -15
- package/esm2015/form-entry/error-renderer/error-renderer.component.js +17 -15
- package/esm2015/form-entry/expression-runner/expression-runner.js +7 -4
- package/esm2015/form-entry/form-entry.module.js +131 -62
- package/esm2015/form-entry/form-factory/control-relations.factory.js +7 -5
- package/esm2015/form-entry/form-factory/form-control.service.js +10 -9
- package/esm2015/form-entry/form-factory/form.factory.js +10 -9
- package/esm2015/form-entry/form-factory/hiders-disablers.factory.js +10 -9
- package/esm2015/form-entry/form-factory/question.factory.js +7 -5
- package/esm2015/form-entry/form-factory/show-messages.factory.js +9 -8
- package/esm2015/form-entry/form-factory/validation.factory.js +7 -5
- package/esm2015/form-entry/form-renderer/form-renderer.component.js +77 -21
- package/esm2015/form-entry/helpers/historical-expression-helper-service.js +7 -5
- package/esm2015/form-entry/helpers/historical-field-helper-service.js +7 -4
- package/esm2015/form-entry/helpers/js-expression-helper.js +7 -4
- package/esm2015/form-entry/pipes/time-ago.pipe.js +11 -11
- package/esm2015/form-entry/services/debug-mode.service.js +7 -5
- package/esm2015/form-entry/services/form-errors.service.js +7 -4
- package/esm2015/form-entry/services/form-schema-compiler.service.js +7 -5
- package/esm2015/form-entry/services/historical-encounter-data.service.js +7 -5
- package/esm2015/form-entry/value-adapters/encounter.adapter.js +9 -8
- package/esm2015/form-entry/value-adapters/obs-adapter-helper.js +7 -5
- package/esm2015/form-entry/value-adapters/obs.adapter.js +8 -7
- package/esm2015/form-entry/value-adapters/order.adapter.js +7 -4
- package/esm2015/form-entry/value-adapters/person-attribute.adapter.js +7 -5
- package/esm2015/lib/index.js +10 -1
- package/esm2015/openmrs-ngx-formentry.js +1 -71
- package/esm2015/shared.module.js +14 -9
- package/fesm2015/openmrs-ngx-formentry.js +10574 -9718
- package/fesm2015/openmrs-ngx-formentry.js.map +1 -1
- package/form-entry/data-sources/data-sources.d.ts +3 -0
- package/form-entry/directives/collapse.directive.d.ts +3 -0
- package/form-entry/directives/historical-value-directive.d.ts +3 -0
- package/form-entry/error-renderer/error-renderer.component.d.ts +3 -0
- package/form-entry/expression-runner/expression-runner.d.ts +3 -0
- package/form-entry/form-entry.module.d.ts +26 -0
- package/form-entry/form-factory/control-relations.factory.d.ts +3 -0
- package/form-entry/form-factory/form-control.service.d.ts +3 -0
- package/form-entry/form-factory/form.factory.d.ts +3 -0
- package/form-entry/form-factory/hiders-disablers.factory.d.ts +3 -0
- package/form-entry/form-factory/question.factory.d.ts +3 -0
- package/form-entry/form-factory/show-messages.factory.d.ts +3 -0
- package/form-entry/form-factory/validation.factory.d.ts +3 -0
- package/form-entry/form-renderer/form-renderer.component.d.ts +8 -0
- package/form-entry/helpers/historical-expression-helper-service.d.ts +3 -0
- package/form-entry/helpers/historical-field-helper-service.d.ts +3 -0
- package/form-entry/helpers/js-expression-helper.d.ts +3 -0
- package/form-entry/pipes/time-ago.pipe.d.ts +3 -0
- package/form-entry/services/debug-mode.service.d.ts +3 -0
- package/form-entry/services/form-errors.service.d.ts +3 -0
- package/form-entry/services/form-schema-compiler.service.d.ts +3 -0
- package/form-entry/services/historical-encounter-data.service.d.ts +3 -0
- package/form-entry/value-adapters/encounter.adapter.d.ts +3 -0
- package/form-entry/value-adapters/obs-adapter-helper.d.ts +3 -0
- package/form-entry/value-adapters/obs.adapter.d.ts +3 -0
- package/form-entry/value-adapters/order.adapter.d.ts +3 -0
- package/form-entry/value-adapters/person-attribute.adapter.d.ts +3 -0
- package/lib/index.d.ts +9 -0
- package/openmrs-ngx-formentry.d.ts +1 -80
- package/package.json +2 -3
- package/shared.module.d.ts +6 -0
- package/bundles/openmrs-ngx-formentry.umd.min.js +0 -17
- package/bundles/openmrs-ngx-formentry.umd.min.js.map +0 -1
- package/openmrs-ngx-formentry.metadata.json +0 -1
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
/* eslint-disable @angular-eslint/component-class-suffix */
|
|
2
2
|
import { Component, ElementRef, Input, Output, HostListener, EventEmitter, TemplateRef, ViewChild } from '@angular/core';
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
4
6
|
/**
|
|
5
7
|
* `ibm-select` provides a styled `select` component.
|
|
6
8
|
*
|
|
@@ -124,10 +126,141 @@ export class Select {
|
|
|
124
126
|
* Tracks the total number of selects instantiated. Used to generate unique IDs
|
|
125
127
|
*/
|
|
126
128
|
Select.selectCount = 0;
|
|
127
|
-
Select
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
129
|
+
Select.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: Select, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
130
|
+
Select.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: Select, selector: "ibm-select", inputs: { display: "display", label: "label", helperText: "helperText", invalidText: "invalidText", warn: "warn", warnText: "warnText", id: "id", size: "size", disabled: "disabled", skeleton: "skeleton", invalid: "invalid", theme: "theme", ariaLabel: "ariaLabel", value: "value" }, outputs: { valueChange: "valueChange" }, host: { listeners: { "focusout": "focusOut()" } }, providers: [
|
|
131
|
+
{
|
|
132
|
+
provide: NG_VALUE_ACCESSOR,
|
|
133
|
+
useExisting: Select,
|
|
134
|
+
multi: true
|
|
135
|
+
}
|
|
136
|
+
], viewQueries: [{ propertyName: "select", first: true, predicate: ["select"], descendants: true }], ngImport: i0, template: `
|
|
137
|
+
<div class="cds--form-item">
|
|
138
|
+
<ng-template [ngIf]="skeleton">
|
|
139
|
+
<div *ngIf="label" class="cds--label cds--skeleton"></div>
|
|
140
|
+
<div class="cds--select cds--skeleton"></div>
|
|
141
|
+
</ng-template>
|
|
142
|
+
<div
|
|
143
|
+
*ngIf="!skeleton"
|
|
144
|
+
class="cds--select"
|
|
145
|
+
[ngClass]="{
|
|
146
|
+
'cds--select--inline': display === 'inline',
|
|
147
|
+
'cds--select--light': theme === 'light',
|
|
148
|
+
'cds--select--invalid': invalid,
|
|
149
|
+
'cds--select--warning': warn,
|
|
150
|
+
'cds--select--disabled': disabled
|
|
151
|
+
}"
|
|
152
|
+
>
|
|
153
|
+
<label *ngIf="label" [for]="id" class="cds--label">
|
|
154
|
+
<ng-container *ngIf="!isTemplate(label)">{{ label }}</ng-container>
|
|
155
|
+
<ng-template
|
|
156
|
+
*ngIf="isTemplate(label)"
|
|
157
|
+
[ngTemplateOutlet]="label"
|
|
158
|
+
></ng-template>
|
|
159
|
+
</label>
|
|
160
|
+
<div *ngIf="helperText" class="cds--form__helper-text">
|
|
161
|
+
<ng-container *ngIf="!isTemplate(helperText)">{{
|
|
162
|
+
helperText
|
|
163
|
+
}}</ng-container>
|
|
164
|
+
<ng-template
|
|
165
|
+
*ngIf="isTemplate(helperText)"
|
|
166
|
+
[ngTemplateOutlet]="helperText"
|
|
167
|
+
></ng-template>
|
|
168
|
+
</div>
|
|
169
|
+
<div
|
|
170
|
+
*ngIf="display === 'inline'; else noInline"
|
|
171
|
+
class="cds--select-input--inline__wrapper"
|
|
172
|
+
>
|
|
173
|
+
<ng-container *ngTemplateOutlet="noInline"></ng-container>
|
|
174
|
+
</div>
|
|
175
|
+
</div>
|
|
176
|
+
</div>
|
|
177
|
+
|
|
178
|
+
<!-- select element: dynamically projected based on 'display' variant -->
|
|
179
|
+
<ng-template #noInline>
|
|
180
|
+
<div
|
|
181
|
+
class="cds--select-input__wrapper extend"
|
|
182
|
+
[attr.data-invalid]="invalid ? true : null"
|
|
183
|
+
>
|
|
184
|
+
<select
|
|
185
|
+
#select
|
|
186
|
+
[attr.id]="id"
|
|
187
|
+
[attr.aria-label]="ariaLabel"
|
|
188
|
+
[disabled]="disabled"
|
|
189
|
+
(change)="onChange($event)"
|
|
190
|
+
[attr.aria-invalid]="invalid ? 'true' : null"
|
|
191
|
+
class="cds--select-input"
|
|
192
|
+
[ngClass]="{
|
|
193
|
+
'cds--select-input--xl': size === 'xl',
|
|
194
|
+
'cds--select-input--sm': size === 'sm'
|
|
195
|
+
}"
|
|
196
|
+
>
|
|
197
|
+
<ng-content></ng-content>
|
|
198
|
+
</select>
|
|
199
|
+
<svg
|
|
200
|
+
focusable="false"
|
|
201
|
+
preserveAspectRatio="xMidYMid meet"
|
|
202
|
+
style="will-change: transform;"
|
|
203
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
204
|
+
class="cds--select__arrow"
|
|
205
|
+
width="16"
|
|
206
|
+
height="16"
|
|
207
|
+
viewBox="0 0 16 16"
|
|
208
|
+
aria-hidden="true"
|
|
209
|
+
>
|
|
210
|
+
<path d="M8 11L3 6 3.7 5.3 8 9.6 12.3 5.3 13 6z"></path>
|
|
211
|
+
</svg>
|
|
212
|
+
<svg
|
|
213
|
+
*ngIf="invalid"
|
|
214
|
+
focusable="false"
|
|
215
|
+
preserveAspectRatio="xMidYMid meet"
|
|
216
|
+
style="will-change: transform;"
|
|
217
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
218
|
+
class="cds--text-input__invalid-icon"
|
|
219
|
+
width="16"
|
|
220
|
+
height="16"
|
|
221
|
+
viewBox="0 0 16 16"
|
|
222
|
+
aria-hidden="true"
|
|
223
|
+
>
|
|
224
|
+
<path
|
|
225
|
+
d="M8,1C4.2,1,1,4.2,1,8s3.2,7,7,7s7-3.1,7-7S11.9,1,8,1z M7.5,4h1v5h-1C7.5,9,7.5,4,7.5,4z M8,12.2 c-0.4,0-0.8-0.4-0.8-0.8s0.3-0.8,0.8-0.8c0.4,0,0.8,0.4,0.8,0.8S8.4,12.2,8,12.2z"
|
|
226
|
+
></path>
|
|
227
|
+
<path
|
|
228
|
+
d="M7.5,4h1v5h-1C7.5,9,7.5,4,7.5,4z M8,12.2c-0.4,0-0.8-0.4-0.8-0.8s0.3-0.8,0.8-0.8 c0.4,0,0.8,0.4,0.8,0.8S8.4,12.2,8,12.2z"
|
|
229
|
+
data-icon-path="inner-path"
|
|
230
|
+
opacity="0"
|
|
231
|
+
></path>
|
|
232
|
+
</svg>
|
|
233
|
+
</div>
|
|
234
|
+
<div
|
|
235
|
+
*ngIf="invalid && invalidText && !warn"
|
|
236
|
+
role="alert"
|
|
237
|
+
class="cds--form-requirement"
|
|
238
|
+
aria-live="polite"
|
|
239
|
+
>
|
|
240
|
+
<ng-container *ngIf="!isTemplate(invalidText)">{{
|
|
241
|
+
invalidText
|
|
242
|
+
}}</ng-container>
|
|
243
|
+
<ng-template
|
|
244
|
+
*ngIf="isTemplate(invalidText)"
|
|
245
|
+
[ngTemplateOutlet]="invalidText"
|
|
246
|
+
></ng-template>
|
|
247
|
+
</div>
|
|
248
|
+
<div *ngIf="!invalid && warn" class="cds--form-requirement">
|
|
249
|
+
<ng-container *ngIf="!isTemplate(warnText)">{{
|
|
250
|
+
warnText
|
|
251
|
+
}}</ng-container>
|
|
252
|
+
<ng-template
|
|
253
|
+
*ngIf="isTemplate(warnText)"
|
|
254
|
+
[ngTemplateOutlet]="warnText"
|
|
255
|
+
></ng-template>
|
|
256
|
+
</div>
|
|
257
|
+
</ng-template>
|
|
258
|
+
`, isInline: true, styles: ["\n .cds--select--inline .cds--form__helper-text {\n order: 4;\n }\n\n .cds--select--inline:not(.cds--select--invalid) .cds--form__helper-text {\n margin-top: 0;\n }\n .cds--select-input__wrapper {\n min-width: 16rem;\n }\n "], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
|
|
259
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: Select, decorators: [{
|
|
260
|
+
type: Component,
|
|
261
|
+
args: [{
|
|
262
|
+
selector: 'ibm-select',
|
|
263
|
+
template: `
|
|
131
264
|
<div class="cds--form-item">
|
|
132
265
|
<ng-template [ngIf]="skeleton">
|
|
133
266
|
<div *ngIf="label" class="cds--label cds--skeleton"></div>
|
|
@@ -250,14 +383,8 @@ Select.decorators = [
|
|
|
250
383
|
</div>
|
|
251
384
|
</ng-template>
|
|
252
385
|
`,
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
provide: NG_VALUE_ACCESSOR,
|
|
256
|
-
useExisting: Select,
|
|
257
|
-
multi: true
|
|
258
|
-
}
|
|
259
|
-
],
|
|
260
|
-
styles: [`
|
|
386
|
+
styles: [
|
|
387
|
+
`
|
|
261
388
|
.cds--select--inline .cds--form__helper-text {
|
|
262
389
|
order: 4;
|
|
263
390
|
}
|
|
@@ -268,26 +395,51 @@ Select.decorators = [
|
|
|
268
395
|
.cds--select-input__wrapper {
|
|
269
396
|
min-width: 16rem;
|
|
270
397
|
}
|
|
271
|
-
`
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-formentry/src/components/select/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-class-suffix */\nimport {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Input,\n  Output,\n  HostListener,\n  EventEmitter,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n/**\n * `ibm-select` provides a styled `select` component.\n *\n * [See demo](../../?path=/story/select--basic)\n *\n * Example:\n *\n * ```\n * <ibm-select [(ngModel)]=\"model\">\n *     <option value=\"default\" disabled selected hidden>Choose an option</option>\n *     <option value=\"option1\">Option 1</option>\n *    <option value=\"option2\">Option 2</option>\n *     <option value=\"option3\">Option 3</option>\n * </ibm-select>\n *    ```\n *\n * <example-url>../../iframe.html?id=select--basic</example-url>\n */\n@Component({\n  selector: 'ibm-select',\n  template: `\n    <div class=\"cds--form-item\">\n      <ng-template [ngIf]=\"skeleton\">\n        <div *ngIf=\"label\" class=\"cds--label cds--skeleton\"></div>\n        <div class=\"cds--select cds--skeleton\"></div>\n      </ng-template>\n      <div\n        *ngIf=\"!skeleton\"\n        class=\"cds--select\"\n        [ngClass]=\"{\n          'cds--select--inline': display === 'inline',\n          'cds--select--light': theme === 'light',\n          'cds--select--invalid': invalid,\n          'cds--select--warning': warn,\n          'cds--select--disabled': disabled\n        }\"\n      >\n        <label *ngIf=\"label\" [for]=\"id\" class=\"cds--label\">\n          <ng-container *ngIf=\"!isTemplate(label)\">{{ label }}</ng-container>\n          <ng-template\n            *ngIf=\"isTemplate(label)\"\n            [ngTemplateOutlet]=\"label\"\n          ></ng-template>\n        </label>\n        <div *ngIf=\"helperText\" class=\"cds--form__helper-text\">\n          <ng-container *ngIf=\"!isTemplate(helperText)\">{{\n            helperText\n          }}</ng-container>\n          <ng-template\n            *ngIf=\"isTemplate(helperText)\"\n            [ngTemplateOutlet]=\"helperText\"\n          ></ng-template>\n        </div>\n        <div\n          *ngIf=\"display === 'inline'; else noInline\"\n          class=\"cds--select-input--inline__wrapper\"\n        >\n          <ng-container *ngTemplateOutlet=\"noInline\"></ng-container>\n        </div>\n      </div>\n    </div>\n\n    <!-- select element: dynamically projected based on 'display' variant -->\n    <ng-template #noInline>\n      <div\n        class=\"cds--select-input__wrapper extend\"\n        [attr.data-invalid]=\"invalid ? true : null\"\n      >\n        <select\n          #select\n          [attr.id]=\"id\"\n          [attr.aria-label]=\"ariaLabel\"\n          [disabled]=\"disabled\"\n          (change)=\"onChange($event)\"\n          [attr.aria-invalid]=\"invalid ? 'true' : null\"\n          class=\"cds--select-input\"\n          [ngClass]=\"{\n            'cds--select-input--xl': size === 'xl',\n            'cds--select-input--sm': size === 'sm'\n          }\"\n        >\n          <ng-content></ng-content>\n        </select>\n        <svg\n          focusable=\"false\"\n          preserveAspectRatio=\"xMidYMid meet\"\n          style=\"will-change: transform;\"\n          xmlns=\"http://www.w3.org/2000/svg\"\n          class=\"cds--select__arrow\"\n          width=\"16\"\n          height=\"16\"\n          viewBox=\"0 0 16 16\"\n          aria-hidden=\"true\"\n        >\n          <path d=\"M8 11L3 6 3.7 5.3 8 9.6 12.3 5.3 13 6z\"></path>\n        </svg>\n        <svg\n          *ngIf=\"invalid\"\n          focusable=\"false\"\n          preserveAspectRatio=\"xMidYMid meet\"\n          style=\"will-change: transform;\"\n          xmlns=\"http://www.w3.org/2000/svg\"\n          class=\"cds--text-input__invalid-icon\"\n          width=\"16\"\n          height=\"16\"\n          viewBox=\"0 0 16 16\"\n          aria-hidden=\"true\"\n        >\n          <path\n            d=\"M8,1C4.2,1,1,4.2,1,8s3.2,7,7,7s7-3.1,7-7S11.9,1,8,1z M7.5,4h1v5h-1C7.5,9,7.5,4,7.5,4z M8,12.2    c-0.4,0-0.8-0.4-0.8-0.8s0.3-0.8,0.8-0.8c0.4,0,0.8,0.4,0.8,0.8S8.4,12.2,8,12.2z\"\n          ></path>\n          <path\n            d=\"M7.5,4h1v5h-1C7.5,9,7.5,4,7.5,4z M8,12.2c-0.4,0-0.8-0.4-0.8-0.8s0.3-0.8,0.8-0.8    c0.4,0,0.8,0.4,0.8,0.8S8.4,12.2,8,12.2z\"\n            data-icon-path=\"inner-path\"\n            opacity=\"0\"\n          ></path>\n        </svg>\n      </div>\n      <div\n        *ngIf=\"invalid && invalidText && !warn\"\n        role=\"alert\"\n        class=\"cds--form-requirement\"\n        aria-live=\"polite\"\n      >\n        <ng-container *ngIf=\"!isTemplate(invalidText)\">{{\n          invalidText\n        }}</ng-container>\n        <ng-template\n          *ngIf=\"isTemplate(invalidText)\"\n          [ngTemplateOutlet]=\"invalidText\"\n        ></ng-template>\n      </div>\n      <div *ngIf=\"!invalid && warn\" class=\"cds--form-requirement\">\n        <ng-container *ngIf=\"!isTemplate(warnText)\">{{\n          warnText\n        }}</ng-container>\n        <ng-template\n          *ngIf=\"isTemplate(warnText)\"\n          [ngTemplateOutlet]=\"warnText\"\n        ></ng-template>\n      </div>\n    </ng-template>\n  `,\n  styles: [\n    `\n      .cds--select--inline .cds--form__helper-text {\n        order: 4;\n      }\n\n      .cds--select--inline:not(.cds--select--invalid) .cds--form__helper-text {\n        margin-top: 0;\n      }\n      .cds--select-input__wrapper {\n        min-width: 16rem;\n      }\n    `\n  ],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: Select,\n      multi: true\n    }\n  ]\n})\nexport class Select implements ControlValueAccessor, AfterViewInit {\n  /**\n   * Tracks the total number of selects instantiated. Used to generate unique IDs\n   */\n  static selectCount = 0;\n\n  /**\n   * `inline` or `default` select displays\n   */\n  @Input() display: 'inline' | 'default' = 'default';\n  /**\n   * Label for the select. Appears above the input.\n   */\n  @Input() label: string | TemplateRef<any>;\n  /**\n   * Optional helper text that appears under the label.\n   */\n  @Input() helperText: string | TemplateRef<any>;\n  /**\n   * Sets the invalid text.\n   */\n  @Input() invalidText: string | TemplateRef<any>;\n  /**\n   * Set to `true` to show a warning (contents set by warningText)\n   */\n  @Input() warn = false;\n  /**\n   * Sets the warning text\n   */\n  @Input() warnText: string | TemplateRef<any>;\n  /**\n   * Sets the unique ID. Defaults to `select-${total count of selects instantiated}`\n   */\n  @Input() id = `select-${Select.selectCount++}`;\n  /**\n   * Number input field render size\n   */\n  @Input() size: 'sm' | 'md' | 'xl' = 'md';\n  /**\n   * Set to true to disable component.\n   */\n  @Input() disabled = false;\n  /**\n   * Set to true for a loading select.\n   */\n  @Input() skeleton = false;\n  /**\n   * Set to `true` for an invalid select component.\n   */\n  @Input() invalid = false;\n\n  /**\n   * `light` or `dark` select theme\n   */\n  @Input() theme: 'light' | 'dark' = 'dark';\n  @Input() ariaLabel: string;\n\n  @Output() valueChange = new EventEmitter();\n\n  // @ts-ignore\n  @ViewChild('select', { static: false }) select: ElementRef;\n\n  @Input() set value(v) {\n    this._value = v;\n    if (this.select) {\n      this.select.nativeElement.value = this._value;\n    }\n  }\n\n  get value() {\n    return this._value;\n  }\n\n  protected _value;\n\n  ngAfterViewInit() {\n    if (\n      this.value !== undefined &&\n      this.value !== null &&\n      this.select &&\n      this.select.nativeElement.value !== this.value\n    ) {\n      this.select.nativeElement.value = this.value;\n    }\n  }\n\n  /**\n   * Receives a value from the model.\n   */\n  writeValue(obj: any) {\n    this.value = obj;\n  }\n\n  /**\n   * Registers a listener that notifies the model when the control updates\n   */\n  registerOnChange(fn: any) {\n    this.onChangeHandler = fn;\n  }\n\n  /**\n   * Registers a listener that notifies the model when the control is blurred\n   */\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler = fn;\n  }\n\n  /**\n   * Sets the disabled state through the model\n   */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  /**\n   * Handles the change event from the `select`.\n   * Sends events to the change handler and emits a `selected` event.\n   */\n  onChange(event) {\n    this.value = event.target.value;\n    this.onChangeHandler(event.target.value);\n    this.valueChange.emit(event.target.value);\n  }\n\n  /**\n   * Listens for the host blurring, and notifies the model\n   */\n  @HostListener('focusout')\n  focusOut() {\n    this.onTouchedHandler();\n  }\n\n  public isTemplate(value) {\n    return value instanceof TemplateRef;\n  }\n\n  /**\n   * placeholder declarations. Replaced by the functions provided to `registerOnChange` and `registerOnTouched`\n   */\n  protected onChangeHandler = (_: any) => {};\n  protected onTouchedHandler = () => {};\n}\n"]}
|
|
398
|
+
`
|
|
399
|
+
],
|
|
400
|
+
providers: [
|
|
401
|
+
{
|
|
402
|
+
provide: NG_VALUE_ACCESSOR,
|
|
403
|
+
useExisting: Select,
|
|
404
|
+
multi: true
|
|
405
|
+
}
|
|
406
|
+
]
|
|
407
|
+
}]
|
|
408
|
+
}], propDecorators: { display: [{
|
|
409
|
+
type: Input
|
|
410
|
+
}], label: [{
|
|
411
|
+
type: Input
|
|
412
|
+
}], helperText: [{
|
|
413
|
+
type: Input
|
|
414
|
+
}], invalidText: [{
|
|
415
|
+
type: Input
|
|
416
|
+
}], warn: [{
|
|
417
|
+
type: Input
|
|
418
|
+
}], warnText: [{
|
|
419
|
+
type: Input
|
|
420
|
+
}], id: [{
|
|
421
|
+
type: Input
|
|
422
|
+
}], size: [{
|
|
423
|
+
type: Input
|
|
424
|
+
}], disabled: [{
|
|
425
|
+
type: Input
|
|
426
|
+
}], skeleton: [{
|
|
427
|
+
type: Input
|
|
428
|
+
}], invalid: [{
|
|
429
|
+
type: Input
|
|
430
|
+
}], theme: [{
|
|
431
|
+
type: Input
|
|
432
|
+
}], ariaLabel: [{
|
|
433
|
+
type: Input
|
|
434
|
+
}], valueChange: [{
|
|
435
|
+
type: Output
|
|
436
|
+
}], select: [{
|
|
437
|
+
type: ViewChild,
|
|
438
|
+
args: ['select', { static: false }]
|
|
439
|
+
}], value: [{
|
|
440
|
+
type: Input
|
|
441
|
+
}], focusOut: [{
|
|
442
|
+
type: HostListener,
|
|
443
|
+
args: ['focusout']
|
|
444
|
+
}] } });
|
|
445
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-formentry/src/components/select/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-class-suffix */\nimport {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Input,\n  Output,\n  HostListener,\n  EventEmitter,\n  TemplateRef,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n/**\n * `ibm-select` provides a styled `select` component.\n *\n * [See demo](../../?path=/story/select--basic)\n *\n * Example:\n *\n * ```\n * <ibm-select [(ngModel)]=\"model\">\n *     <option value=\"default\" disabled selected hidden>Choose an option</option>\n *     <option value=\"option1\">Option 1</option>\n *    <option value=\"option2\">Option 2</option>\n *     <option value=\"option3\">Option 3</option>\n * </ibm-select>\n *    ```\n *\n * <example-url>../../iframe.html?id=select--basic</example-url>\n */\n@Component({\n  selector: 'ibm-select',\n  template: `\n    <div class=\"cds--form-item\">\n      <ng-template [ngIf]=\"skeleton\">\n        <div *ngIf=\"label\" class=\"cds--label cds--skeleton\"></div>\n        <div class=\"cds--select cds--skeleton\"></div>\n      </ng-template>\n      <div\n        *ngIf=\"!skeleton\"\n        class=\"cds--select\"\n        [ngClass]=\"{\n          'cds--select--inline': display === 'inline',\n          'cds--select--light': theme === 'light',\n          'cds--select--invalid': invalid,\n          'cds--select--warning': warn,\n          'cds--select--disabled': disabled\n        }\"\n      >\n        <label *ngIf=\"label\" [for]=\"id\" class=\"cds--label\">\n          <ng-container *ngIf=\"!isTemplate(label)\">{{ label }}</ng-container>\n          <ng-template\n            *ngIf=\"isTemplate(label)\"\n            [ngTemplateOutlet]=\"label\"\n          ></ng-template>\n        </label>\n        <div *ngIf=\"helperText\" class=\"cds--form__helper-text\">\n          <ng-container *ngIf=\"!isTemplate(helperText)\">{{\n            helperText\n          }}</ng-container>\n          <ng-template\n            *ngIf=\"isTemplate(helperText)\"\n            [ngTemplateOutlet]=\"helperText\"\n          ></ng-template>\n        </div>\n        <div\n          *ngIf=\"display === 'inline'; else noInline\"\n          class=\"cds--select-input--inline__wrapper\"\n        >\n          <ng-container *ngTemplateOutlet=\"noInline\"></ng-container>\n        </div>\n      </div>\n    </div>\n\n    <!-- select element: dynamically projected based on 'display' variant -->\n    <ng-template #noInline>\n      <div\n        class=\"cds--select-input__wrapper extend\"\n        [attr.data-invalid]=\"invalid ? true : null\"\n      >\n        <select\n          #select\n          [attr.id]=\"id\"\n          [attr.aria-label]=\"ariaLabel\"\n          [disabled]=\"disabled\"\n          (change)=\"onChange($event)\"\n          [attr.aria-invalid]=\"invalid ? 'true' : null\"\n          class=\"cds--select-input\"\n          [ngClass]=\"{\n            'cds--select-input--xl': size === 'xl',\n            'cds--select-input--sm': size === 'sm'\n          }\"\n        >\n          <ng-content></ng-content>\n        </select>\n        <svg\n          focusable=\"false\"\n          preserveAspectRatio=\"xMidYMid meet\"\n          style=\"will-change: transform;\"\n          xmlns=\"http://www.w3.org/2000/svg\"\n          class=\"cds--select__arrow\"\n          width=\"16\"\n          height=\"16\"\n          viewBox=\"0 0 16 16\"\n          aria-hidden=\"true\"\n        >\n          <path d=\"M8 11L3 6 3.7 5.3 8 9.6 12.3 5.3 13 6z\"></path>\n        </svg>\n        <svg\n          *ngIf=\"invalid\"\n          focusable=\"false\"\n          preserveAspectRatio=\"xMidYMid meet\"\n          style=\"will-change: transform;\"\n          xmlns=\"http://www.w3.org/2000/svg\"\n          class=\"cds--text-input__invalid-icon\"\n          width=\"16\"\n          height=\"16\"\n          viewBox=\"0 0 16 16\"\n          aria-hidden=\"true\"\n        >\n          <path\n            d=\"M8,1C4.2,1,1,4.2,1,8s3.2,7,7,7s7-3.1,7-7S11.9,1,8,1z M7.5,4h1v5h-1C7.5,9,7.5,4,7.5,4z M8,12.2    c-0.4,0-0.8-0.4-0.8-0.8s0.3-0.8,0.8-0.8c0.4,0,0.8,0.4,0.8,0.8S8.4,12.2,8,12.2z\"\n          ></path>\n          <path\n            d=\"M7.5,4h1v5h-1C7.5,9,7.5,4,7.5,4z M8,12.2c-0.4,0-0.8-0.4-0.8-0.8s0.3-0.8,0.8-0.8    c0.4,0,0.8,0.4,0.8,0.8S8.4,12.2,8,12.2z\"\n            data-icon-path=\"inner-path\"\n            opacity=\"0\"\n          ></path>\n        </svg>\n      </div>\n      <div\n        *ngIf=\"invalid && invalidText && !warn\"\n        role=\"alert\"\n        class=\"cds--form-requirement\"\n        aria-live=\"polite\"\n      >\n        <ng-container *ngIf=\"!isTemplate(invalidText)\">{{\n          invalidText\n        }}</ng-container>\n        <ng-template\n          *ngIf=\"isTemplate(invalidText)\"\n          [ngTemplateOutlet]=\"invalidText\"\n        ></ng-template>\n      </div>\n      <div *ngIf=\"!invalid && warn\" class=\"cds--form-requirement\">\n        <ng-container *ngIf=\"!isTemplate(warnText)\">{{\n          warnText\n        }}</ng-container>\n        <ng-template\n          *ngIf=\"isTemplate(warnText)\"\n          [ngTemplateOutlet]=\"warnText\"\n        ></ng-template>\n      </div>\n    </ng-template>\n  `,\n  styles: [\n    `\n      .cds--select--inline .cds--form__helper-text {\n        order: 4;\n      }\n\n      .cds--select--inline:not(.cds--select--invalid) .cds--form__helper-text {\n        margin-top: 0;\n      }\n      .cds--select-input__wrapper {\n        min-width: 16rem;\n      }\n    `\n  ],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: Select,\n      multi: true\n    }\n  ]\n})\nexport class Select implements ControlValueAccessor, AfterViewInit {\n  /**\n   * Tracks the total number of selects instantiated. Used to generate unique IDs\n   */\n  static selectCount = 0;\n\n  /**\n   * `inline` or `default` select displays\n   */\n  @Input() display: 'inline' | 'default' = 'default';\n  /**\n   * Label for the select. Appears above the input.\n   */\n  @Input() label: string | TemplateRef<any>;\n  /**\n   * Optional helper text that appears under the label.\n   */\n  @Input() helperText: string | TemplateRef<any>;\n  /**\n   * Sets the invalid text.\n   */\n  @Input() invalidText: string | TemplateRef<any>;\n  /**\n   * Set to `true` to show a warning (contents set by warningText)\n   */\n  @Input() warn = false;\n  /**\n   * Sets the warning text\n   */\n  @Input() warnText: string | TemplateRef<any>;\n  /**\n   * Sets the unique ID. Defaults to `select-${total count of selects instantiated}`\n   */\n  @Input() id = `select-${Select.selectCount++}`;\n  /**\n   * Number input field render size\n   */\n  @Input() size: 'sm' | 'md' | 'xl' = 'md';\n  /**\n   * Set to true to disable component.\n   */\n  @Input() disabled = false;\n  /**\n   * Set to true for a loading select.\n   */\n  @Input() skeleton = false;\n  /**\n   * Set to `true` for an invalid select component.\n   */\n  @Input() invalid = false;\n\n  /**\n   * `light` or `dark` select theme\n   */\n  @Input() theme: 'light' | 'dark' = 'dark';\n  @Input() ariaLabel: string;\n\n  @Output() valueChange = new EventEmitter();\n\n  // @ts-ignore\n  @ViewChild('select', { static: false }) select: ElementRef;\n\n  @Input() set value(v) {\n    this._value = v;\n    if (this.select) {\n      this.select.nativeElement.value = this._value;\n    }\n  }\n\n  get value() {\n    return this._value;\n  }\n\n  protected _value;\n\n  ngAfterViewInit() {\n    if (\n      this.value !== undefined &&\n      this.value !== null &&\n      this.select &&\n      this.select.nativeElement.value !== this.value\n    ) {\n      this.select.nativeElement.value = this.value;\n    }\n  }\n\n  /**\n   * Receives a value from the model.\n   */\n  writeValue(obj: any) {\n    this.value = obj;\n  }\n\n  /**\n   * Registers a listener that notifies the model when the control updates\n   */\n  registerOnChange(fn: any) {\n    this.onChangeHandler = fn;\n  }\n\n  /**\n   * Registers a listener that notifies the model when the control is blurred\n   */\n  registerOnTouched(fn: any) {\n    this.onTouchedHandler = fn;\n  }\n\n  /**\n   * Sets the disabled state through the model\n   */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  /**\n   * Handles the change event from the `select`.\n   * Sends events to the change handler and emits a `selected` event.\n   */\n  onChange(event) {\n    this.value = event.target.value;\n    this.onChangeHandler(event.target.value);\n    this.valueChange.emit(event.target.value);\n  }\n\n  /**\n   * Listens for the host blurring, and notifies the model\n   */\n  @HostListener('focusout')\n  focusOut() {\n    this.onTouchedHandler();\n  }\n\n  public isTemplate(value) {\n    return value instanceof TemplateRef;\n  }\n\n  /**\n   * placeholder declarations. Replaced by the functions provided to `registerOnChange` and `registerOnTouched`\n   */\n  protected onChangeHandler = (_: any) => {};\n  protected onTouchedHandler = () => {};\n}\n"]}
|
|
@@ -6,13 +6,18 @@ import { CommonModule } from '@angular/common';
|
|
|
6
6
|
import { Select } from './select.component';
|
|
7
7
|
import { Option } from './option.directive';
|
|
8
8
|
import { OptGroup } from './optgroup.directive';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
9
10
|
export class SelectModule {
|
|
10
11
|
}
|
|
11
|
-
SelectModule
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
]
|
|
18
|
-
|
|
12
|
+
SelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: SelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
|
+
SelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: SelectModule, declarations: [Select, Option, OptGroup], imports: [CommonModule, FormsModule], exports: [Select, Option, OptGroup] });
|
|
14
|
+
SelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: SelectModule, imports: [[CommonModule, FormsModule]] });
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: SelectModule, decorators: [{
|
|
16
|
+
type: NgModule,
|
|
17
|
+
args: [{
|
|
18
|
+
declarations: [Select, Option, OptGroup],
|
|
19
|
+
exports: [Select, Option, OptGroup],
|
|
20
|
+
imports: [CommonModule, FormsModule]
|
|
21
|
+
}]
|
|
22
|
+
}] });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1mb3JtZW50cnkvc3JjL2NvbXBvbmVudHMvc2VsZWN0L3NlbGVjdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsVUFBVTtBQUNWLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxVQUFVO0FBQ1YsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUM1QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0FBT2hELE1BQU0sT0FBTyxZQUFZOzswR0FBWixZQUFZOzJHQUFaLFlBQVksaUJBSlIsTUFBTSxFQUFFLE1BQU0sRUFBRSxRQUFRLGFBRTdCLFlBQVksRUFBRSxXQUFXLGFBRHpCLE1BQU0sRUFBRSxNQUFNLEVBQUUsUUFBUTsyR0FHdkIsWUFBWSxZQUZkLENBQUMsWUFBWSxFQUFFLFdBQVcsQ0FBQzs0RkFFekIsWUFBWTtrQkFMeEIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxNQUFNLEVBQUUsTUFBTSxFQUFFLFFBQVEsQ0FBQztvQkFDeEMsT0FBTyxFQUFFLENBQUMsTUFBTSxFQUFFLE1BQU0sRUFBRSxRQUFRLENBQUM7b0JBQ25DLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLENBQUM7aUJBQ3JDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gbW9kdWxlc1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuLy8gaW1wb3J0c1xuaW1wb3J0IHsgU2VsZWN0IH0gZnJvbSAnLi9zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IE9wdGlvbiB9IGZyb20gJy4vb3B0aW9uLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBPcHRHcm91cCB9IGZyb20gJy4vb3B0Z3JvdXAuZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU2VsZWN0LCBPcHRpb24sIE9wdEdyb3VwXSxcbiAgZXhwb3J0czogW1NlbGVjdCwgT3B0aW9uLCBPcHRHcm91cF0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEZvcm1zTW9kdWxlXVxufSlcbmV4cG9ydCBjbGFzcyBTZWxlY3RNb2R1bGUge31cbiJdfQ==
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
2
3
|
export class DataSources {
|
|
3
4
|
constructor() {
|
|
4
5
|
this._dataSources = {};
|
|
@@ -23,8 +24,9 @@ export class DataSources {
|
|
|
23
24
|
delete this._dataSources[key];
|
|
24
25
|
}
|
|
25
26
|
}
|
|
26
|
-
DataSources
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
27
|
+
DataSources.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: DataSources, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
28
|
+
DataSources.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: DataSources });
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: DataSources, decorators: [{
|
|
30
|
+
type: Injectable
|
|
31
|
+
}], ctorParameters: function () { return []; } });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1zb3VyY2VzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWZvcm1lbnRyeS9zcmMvZm9ybS1lbnRyeS9kYXRhLXNvdXJjZXMvZGF0YS1zb3VyY2VzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRzNDLE1BQU0sT0FBTyxXQUFXO0lBRXRCO1FBRFEsaUJBQVksR0FBUSxFQUFFLENBQUM7SUFDaEIsQ0FBQztJQUVoQixJQUFJLFdBQVc7UUFDYixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDM0IsQ0FBQztJQUVELGtCQUFrQixDQUFDLEdBQVcsRUFBRSxVQUFlLEVBQUUsTUFBTSxHQUFHLEtBQUs7UUFDN0QsSUFBSSxNQUFNLEVBQUU7WUFDVix3Q0FBd0M7WUFDeEMsS0FBSyxNQUFNLENBQUMsSUFBSSxVQUFVLEVBQUU7Z0JBQzFCLGdEQUFnRDtnQkFDaEQsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUMsRUFBRSxVQUFVLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUM7YUFDbEQ7U0FDRjtRQUNELElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUN6QixPQUFPLENBQUMsSUFBSSxDQUFDLG1DQUFtQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1NBQ3hEO1FBQ0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsR0FBRyxVQUFVLENBQUM7SUFDdEMsQ0FBQztJQUVELGVBQWUsQ0FBQyxHQUFXO1FBQ3pCLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNoQyxDQUFDOzt5R0F4QlUsV0FBVzs2R0FBWCxXQUFXOzRGQUFYLFdBQVc7a0JBRHZCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBEYXRhU291cmNlcyB7XG4gIHByaXZhdGUgX2RhdGFTb3VyY2VzOiBhbnkgPSB7fTtcbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIGdldCBkYXRhU291cmNlcygpOiBhbnkge1xuICAgIHJldHVybiB0aGlzLl9kYXRhU291cmNlcztcbiAgfVxuXG4gIHJlZ2lzdGVyRGF0YVNvdXJjZShrZXk6IHN0cmluZywgZGF0YVNvdXJjZTogYW55LCB1bldyYXAgPSBmYWxzZSkge1xuICAgIGlmICh1bldyYXApIHtcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBndWFyZC1mb3ItaW5cbiAgICAgIGZvciAoY29uc3QgbyBpbiBkYXRhU291cmNlKSB7XG4gICAgICAgIC8vIGNvbnNvbGUubG9nKCdyZWdpc3RlcmluZycsIG8sIGRhdGFTb3VyY2Vbb10pO1xuICAgICAgICB0aGlzLnJlZ2lzdGVyRGF0YVNvdXJjZShvLCBkYXRhU291cmNlW29dLCBmYWxzZSk7XG4gICAgICB9XG4gICAgfVxuICAgIGlmICh0aGlzLmRhdGFTb3VyY2VzW2tleV0pIHtcbiAgICAgIGNvbnNvbGUud2FybignT3ZlcnJpZGluZyByZWdpc3RlcmVkIGRhdGEgc291cmNlJywga2V5KTtcbiAgICB9XG4gICAgdGhpcy5fZGF0YVNvdXJjZXNba2V5XSA9IGRhdGFTb3VyY2U7XG4gIH1cblxuICBjbGVhckRhdGFTb3VyY2Uoa2V5OiBzdHJpbmcpIHtcbiAgICBkZWxldGUgdGhpcy5fZGF0YVNvdXJjZXNba2V5XTtcbiAgfVxufVxuIl19
|
|
@@ -2,6 +2,8 @@
|
|
|
2
2
|
import { AnimationBuilder } from '@angular/animations';
|
|
3
3
|
import { Directive, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2 } from '@angular/core';
|
|
4
4
|
import { collapseAnimation, expandAnimation } from './collapse-animations';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/animations";
|
|
5
7
|
export class CollapseDirective {
|
|
6
8
|
constructor(_el, _renderer, _builder) {
|
|
7
9
|
this._el = _el;
|
|
@@ -126,32 +128,49 @@ export class CollapseDirective {
|
|
|
126
128
|
return (callback) => { var _a; return (_a = this._player) === null || _a === void 0 ? void 0 : _a.onDone(callback); };
|
|
127
129
|
}
|
|
128
130
|
}
|
|
129
|
-
CollapseDirective
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
]
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
]
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collapse.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-formentry/src/form-entry/directives/collapse.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/no-host-metadata-property */\nimport {\n  AnimationBuilder,\n  AnimationFactory,\n  AnimationPlayer\n} from '@angular/animations';\n\nimport {\n  AfterViewChecked,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  Output,\n  Renderer2\n} from '@angular/core';\n\nimport { collapseAnimation, expandAnimation } from './collapse-animations';\n\n@Directive({\n  selector: '[collapse]',\n  exportAs: 'bs-collapse',\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    '[class.collapse]': 'true'\n  }\n})\nexport class CollapseDirective implements AfterViewChecked {\n  /** This event fires as soon as content collapses */\n  @Output() collapsed: EventEmitter<CollapseDirective> = new EventEmitter();\n  /** This event fires when collapsing is started */\n  @Output() collapses: EventEmitter<CollapseDirective> = new EventEmitter();\n  /** This event fires as soon as content becomes visible */\n  @Output() expanded: EventEmitter<CollapseDirective> = new EventEmitter();\n  /** This event fires when expansion is started */\n  @Output() expands: EventEmitter<CollapseDirective> = new EventEmitter();\n  // shown\n  @HostBinding('class.in')\n  @HostBinding('class.show')\n  @HostBinding('attr.aria-expanded')\n  isExpanded = true;\n  collapseNewValue = true;\n  // hidden\n  @HostBinding('attr.aria-hidden') isCollapsed = false;\n  // stale state\n  @HostBinding('class.collapse') isCollapse = true;\n  // animation state\n  @HostBinding('class.collapsing') isCollapsing = false;\n\n  @Input()\n  set display(value: string) {\n    if (!this.isAnimated) {\n      this._renderer.setStyle(this._el.nativeElement, 'display', value);\n\n      return;\n    }\n\n    this._display = value;\n\n    if (value === 'none') {\n      this.hide();\n\n      return;\n    }\n\n    this.show();\n  }\n  /** turn on/off animation */\n  @Input() isAnimated = false;\n  /** A flag indicating visibility of content (shown or hidden) */\n  @Input()\n  set collapse(value: boolean) {\n    this.collapseNewValue = value;\n    if (!this._player || this._isAnimationDone) {\n      this.isExpanded = value;\n      this.toggle();\n    }\n  }\n\n  get collapse(): boolean {\n    return this.isExpanded;\n  }\n\n  private _display = 'block';\n  private _isAnimationDone?: boolean;\n  private _player?: AnimationPlayer;\n  private _stylesLoaded = false;\n\n  private _COLLAPSE_ACTION_NAME = 'collapse';\n  private _EXPAND_ACTION_NAME = 'expand';\n\n  private readonly _factoryCollapseAnimation: AnimationFactory;\n  private readonly _factoryExpandAnimation: AnimationFactory;\n\n  constructor(\n    private _el: ElementRef,\n    private _renderer: Renderer2,\n    _builder: AnimationBuilder\n  ) {\n    this._factoryCollapseAnimation = _builder.build(collapseAnimation);\n    this._factoryExpandAnimation = _builder.build(expandAnimation);\n  }\n\n  ngAfterViewChecked(): void {\n    this._stylesLoaded = true;\n\n    if (!this._player || !this._isAnimationDone) {\n      return;\n    }\n\n    this._player.reset();\n    this._renderer.setStyle(this._el.nativeElement, 'height', '*');\n  }\n\n  /** allows to manually toggle content visibility */\n  toggle(): void {\n    if (this.isExpanded) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  /** allows to manually hide content */\n  hide(): void {\n    this.isCollapsing = true;\n    this.isExpanded = false;\n    this.isCollapsed = true;\n    this.isCollapsing = false;\n\n    this.collapses.emit(this);\n\n    this._isAnimationDone = false;\n\n    this.animationRun(\n      this.isAnimated,\n      this._COLLAPSE_ACTION_NAME\n    )(() => {\n      this._isAnimationDone = true;\n      if (this.collapseNewValue !== this.isCollapsed && this.isAnimated) {\n        this.show();\n\n        return;\n      }\n      this.collapsed.emit(this);\n      this._renderer.setStyle(this._el.nativeElement, 'display', 'none');\n    });\n  }\n  /** allows to manually show collapsed content */\n  show(): void {\n    this._renderer.setStyle(this._el.nativeElement, 'display', this._display);\n\n    this.isCollapsing = true;\n    this.isExpanded = true;\n    this.isCollapsed = false;\n    this.isCollapsing = false;\n\n    this.expands.emit(this);\n\n    this._isAnimationDone = false;\n    this.animationRun(\n      this.isAnimated,\n      this._EXPAND_ACTION_NAME\n    )(() => {\n      this._isAnimationDone = true;\n      if (this.collapseNewValue !== this.isCollapsed && this.isAnimated) {\n        this.hide();\n\n        return;\n      }\n      this.expanded.emit(this);\n      this._renderer.removeStyle(this._el.nativeElement, 'overflow');\n    });\n  }\n\n  animationRun(isAnimated: boolean, action: string) {\n    if (!isAnimated || !this._stylesLoaded) {\n      return (callback: () => void) => callback();\n    }\n\n    this._renderer.setStyle(this._el.nativeElement, 'overflow', 'hidden');\n    this._renderer.addClass(this._el.nativeElement, 'collapse');\n\n    const factoryAnimation =\n      action === this._EXPAND_ACTION_NAME\n        ? this._factoryExpandAnimation\n        : this._factoryCollapseAnimation;\n\n    if (this._player) {\n      this._player.destroy();\n    }\n\n    this._player = factoryAnimation.create(this._el.nativeElement);\n    this._player.play();\n\n    return (callback: () => void) => this._player?.onDone(callback);\n  }\n}\n"]}
|
|
131
|
+
CollapseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: CollapseDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.AnimationBuilder }], target: i0.ɵɵFactoryTarget.Directive });
|
|
132
|
+
CollapseDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: CollapseDirective, selector: "[collapse]", inputs: { display: "display", isAnimated: "isAnimated", collapse: "collapse" }, outputs: { collapsed: "collapsed", collapses: "collapses", expanded: "expanded", expands: "expands" }, host: { properties: { "class.collapse": "this.isCollapse", "class.in": "this.isExpanded", "class.show": "this.isExpanded", "attr.aria-expanded": "this.isExpanded", "attr.aria-hidden": "this.isCollapsed", "class.collapsing": "this.isCollapsing" } }, exportAs: ["bs-collapse"], ngImport: i0 });
|
|
133
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: CollapseDirective, decorators: [{
|
|
134
|
+
type: Directive,
|
|
135
|
+
args: [{
|
|
136
|
+
selector: '[collapse]',
|
|
137
|
+
exportAs: 'bs-collapse',
|
|
138
|
+
// eslint-disable-next-line @angular-eslint/no-host-metadata-property
|
|
139
|
+
host: {
|
|
140
|
+
'[class.collapse]': 'true'
|
|
141
|
+
}
|
|
142
|
+
}]
|
|
143
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.AnimationBuilder }]; }, propDecorators: { collapsed: [{
|
|
144
|
+
type: Output
|
|
145
|
+
}], collapses: [{
|
|
146
|
+
type: Output
|
|
147
|
+
}], expanded: [{
|
|
148
|
+
type: Output
|
|
149
|
+
}], expands: [{
|
|
150
|
+
type: Output
|
|
151
|
+
}], isExpanded: [{
|
|
152
|
+
type: HostBinding,
|
|
153
|
+
args: ['class.in']
|
|
154
|
+
}, {
|
|
155
|
+
type: HostBinding,
|
|
156
|
+
args: ['class.show']
|
|
157
|
+
}, {
|
|
158
|
+
type: HostBinding,
|
|
159
|
+
args: ['attr.aria-expanded']
|
|
160
|
+
}], isCollapsed: [{
|
|
161
|
+
type: HostBinding,
|
|
162
|
+
args: ['attr.aria-hidden']
|
|
163
|
+
}], isCollapse: [{
|
|
164
|
+
type: HostBinding,
|
|
165
|
+
args: ['class.collapse']
|
|
166
|
+
}], isCollapsing: [{
|
|
167
|
+
type: HostBinding,
|
|
168
|
+
args: ['class.collapsing']
|
|
169
|
+
}], display: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], isAnimated: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], collapse: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}] } });
|
|
176
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collapse.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-formentry/src/form-entry/directives/collapse.directive.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/no-host-metadata-property */\nimport {\n  AnimationBuilder,\n  AnimationFactory,\n  AnimationPlayer\n} from '@angular/animations';\n\nimport {\n  AfterViewChecked,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  Output,\n  Renderer2\n} from '@angular/core';\n\nimport { collapseAnimation, expandAnimation } from './collapse-animations';\n\n@Directive({\n  selector: '[collapse]',\n  exportAs: 'bs-collapse',\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    '[class.collapse]': 'true'\n  }\n})\nexport class CollapseDirective implements AfterViewChecked {\n  /** This event fires as soon as content collapses */\n  @Output() collapsed: EventEmitter<CollapseDirective> = new EventEmitter();\n  /** This event fires when collapsing is started */\n  @Output() collapses: EventEmitter<CollapseDirective> = new EventEmitter();\n  /** This event fires as soon as content becomes visible */\n  @Output() expanded: EventEmitter<CollapseDirective> = new EventEmitter();\n  /** This event fires when expansion is started */\n  @Output() expands: EventEmitter<CollapseDirective> = new EventEmitter();\n  // shown\n  @HostBinding('class.in')\n  @HostBinding('class.show')\n  @HostBinding('attr.aria-expanded')\n  isExpanded = true;\n  collapseNewValue = true;\n  // hidden\n  @HostBinding('attr.aria-hidden') isCollapsed = false;\n  // stale state\n  @HostBinding('class.collapse') isCollapse = true;\n  // animation state\n  @HostBinding('class.collapsing') isCollapsing = false;\n\n  @Input()\n  set display(value: string) {\n    if (!this.isAnimated) {\n      this._renderer.setStyle(this._el.nativeElement, 'display', value);\n\n      return;\n    }\n\n    this._display = value;\n\n    if (value === 'none') {\n      this.hide();\n\n      return;\n    }\n\n    this.show();\n  }\n  /** turn on/off animation */\n  @Input() isAnimated = false;\n  /** A flag indicating visibility of content (shown or hidden) */\n  @Input()\n  set collapse(value: boolean) {\n    this.collapseNewValue = value;\n    if (!this._player || this._isAnimationDone) {\n      this.isExpanded = value;\n      this.toggle();\n    }\n  }\n\n  get collapse(): boolean {\n    return this.isExpanded;\n  }\n\n  private _display = 'block';\n  private _isAnimationDone?: boolean;\n  private _player?: AnimationPlayer;\n  private _stylesLoaded = false;\n\n  private _COLLAPSE_ACTION_NAME = 'collapse';\n  private _EXPAND_ACTION_NAME = 'expand';\n\n  private readonly _factoryCollapseAnimation: AnimationFactory;\n  private readonly _factoryExpandAnimation: AnimationFactory;\n\n  constructor(\n    private _el: ElementRef,\n    private _renderer: Renderer2,\n    _builder: AnimationBuilder\n  ) {\n    this._factoryCollapseAnimation = _builder.build(collapseAnimation);\n    this._factoryExpandAnimation = _builder.build(expandAnimation);\n  }\n\n  ngAfterViewChecked(): void {\n    this._stylesLoaded = true;\n\n    if (!this._player || !this._isAnimationDone) {\n      return;\n    }\n\n    this._player.reset();\n    this._renderer.setStyle(this._el.nativeElement, 'height', '*');\n  }\n\n  /** allows to manually toggle content visibility */\n  toggle(): void {\n    if (this.isExpanded) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  /** allows to manually hide content */\n  hide(): void {\n    this.isCollapsing = true;\n    this.isExpanded = false;\n    this.isCollapsed = true;\n    this.isCollapsing = false;\n\n    this.collapses.emit(this);\n\n    this._isAnimationDone = false;\n\n    this.animationRun(\n      this.isAnimated,\n      this._COLLAPSE_ACTION_NAME\n    )(() => {\n      this._isAnimationDone = true;\n      if (this.collapseNewValue !== this.isCollapsed && this.isAnimated) {\n        this.show();\n\n        return;\n      }\n      this.collapsed.emit(this);\n      this._renderer.setStyle(this._el.nativeElement, 'display', 'none');\n    });\n  }\n  /** allows to manually show collapsed content */\n  show(): void {\n    this._renderer.setStyle(this._el.nativeElement, 'display', this._display);\n\n    this.isCollapsing = true;\n    this.isExpanded = true;\n    this.isCollapsed = false;\n    this.isCollapsing = false;\n\n    this.expands.emit(this);\n\n    this._isAnimationDone = false;\n    this.animationRun(\n      this.isAnimated,\n      this._EXPAND_ACTION_NAME\n    )(() => {\n      this._isAnimationDone = true;\n      if (this.collapseNewValue !== this.isCollapsed && this.isAnimated) {\n        this.hide();\n\n        return;\n      }\n      this.expanded.emit(this);\n      this._renderer.removeStyle(this._el.nativeElement, 'overflow');\n    });\n  }\n\n  animationRun(isAnimated: boolean, action: string) {\n    if (!isAnimated || !this._stylesLoaded) {\n      return (callback: () => void) => callback();\n    }\n\n    this._renderer.setStyle(this._el.nativeElement, 'overflow', 'hidden');\n    this._renderer.addClass(this._el.nativeElement, 'collapse');\n\n    const factoryAnimation =\n      action === this._EXPAND_ACTION_NAME\n        ? this._factoryExpandAnimation\n        : this._factoryCollapseAnimation;\n\n    if (this._player) {\n      this._player.destroy();\n    }\n\n    this._player = factoryAnimation.create(this._el.nativeElement);\n    this._player.play();\n\n    return (callback: () => void) => this._player?.onDone(callback);\n  }\n}\n"]}
|
|
@@ -2,6 +2,8 @@ import { Directive, HostListener, Input, Output, EventEmitter } from '@angular/c
|
|
|
2
2
|
import { HistoricalFieldHelperService } from '../helpers/historical-field-helper-service';
|
|
3
3
|
import * as _ from 'lodash';
|
|
4
4
|
import { NodeBase } from '../form-factory/form-node';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../helpers/historical-field-helper-service";
|
|
5
7
|
export class HistoricalValueDirective {
|
|
6
8
|
constructor(historicalFieldHelper) {
|
|
7
9
|
this.historicalFieldHelper = historicalFieldHelper;
|
|
@@ -49,18 +51,21 @@ export class HistoricalValueDirective {
|
|
|
49
51
|
}
|
|
50
52
|
}
|
|
51
53
|
}
|
|
52
|
-
HistoricalValueDirective
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
];
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
54
|
+
HistoricalValueDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HistoricalValueDirective, deps: [{ token: i1.HistoricalFieldHelperService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
55
|
+
HistoricalValueDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: HistoricalValueDirective, selector: "[node]", inputs: { _node: "_node", node: "node" }, outputs: { _nodeChange: "_nodeChange" }, host: { listeners: { "click": "setValue($event)" } }, ngImport: i0 });
|
|
56
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HistoricalValueDirective, decorators: [{
|
|
57
|
+
type: Directive,
|
|
58
|
+
args: [{
|
|
59
|
+
selector: `[node]`
|
|
60
|
+
}]
|
|
61
|
+
}], ctorParameters: function () { return [{ type: i1.HistoricalFieldHelperService }]; }, propDecorators: { _node: [{
|
|
62
|
+
type: Input
|
|
63
|
+
}], _nodeChange: [{
|
|
64
|
+
type: Output
|
|
65
|
+
}], setValue: [{
|
|
66
|
+
type: HostListener,
|
|
67
|
+
args: ['click', ['$event']]
|
|
68
|
+
}], node: [{
|
|
69
|
+
type: Input
|
|
70
|
+
}] } });
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlzdG9yaWNhbC12YWx1ZS1kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtZm9ybWVudHJ5L3NyYy9mb3JtLWVudHJ5L2RpcmVjdGl2ZXMvaGlzdG9yaWNhbC12YWx1ZS1kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sRUFDTixZQUFZLEVBQ2IsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDMUYsT0FBTyxLQUFLLENBQUMsTUFBTSxRQUFRLENBQUM7QUFDNUIsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7QUFLckQsTUFBTSxPQUFPLHdCQUF3QjtJQU1uQyxZQUFvQixxQkFBbUQ7UUFBbkQsMEJBQXFCLEdBQXJCLHFCQUFxQixDQUE4QjtRQUo3RCxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7SUFJdUIsQ0FBQztJQUczRSxRQUFRLENBQUMsQ0FBQztRQUNSLElBQUksQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLEtBQUssY0FBYyxFQUFFO1lBQ3BDLElBQ0UsSUFBSSxDQUFDLEtBQUs7Z0JBQ1YsQ0FBQyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQztvQkFDN0QsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLGFBQWEsRUFBRSxTQUFTLENBQUMsQ0FBQyxFQUNwRTtnQkFDQSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQ3pCLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLG1CQUFtQixDQUFDLEtBQUssQ0FDOUMsQ0FBQztnQkFFRixJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FDakIsaUJBQWlCLENBQ2xCLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUM7Z0JBQzVDLENBQUMsQ0FBQyxlQUFlLEVBQUUsQ0FBQztnQkFDcEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO2FBQ25DO1NBQ0Y7SUFDSCxDQUFDO0lBQ08sYUFBYSxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNYLE9BQU8sSUFBSSxDQUFDO1NBQ2I7YUFBTTtZQUNMLE9BQU8sS0FBSyxDQUFDO1NBQ2Q7SUFDSCxDQUFDO0lBQ0QsSUFDSSxJQUFJLENBQUMsSUFBYztRQUNyQixJQUFJLElBQUksRUFBRTtZQUNSLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1lBQ2xCLElBQ0UsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMscUJBQXFCO2dCQUN6QyxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUMsRUFDdkQ7Z0JBQ0EsTUFBTSxPQUFPLEdBQVEsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQztnQkFDN0MsSUFDRSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxhQUFhLEtBQUssUUFBUTtvQkFDOUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsYUFBYSxLQUFLLGNBQWM7b0JBQ3BELElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLGFBQWEsS0FBSyxlQUFlLEVBQ3JEO29CQUNBLE9BQU8sQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLHFCQUFxQixDQUFDLHlCQUF5QixDQUNqRSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFDbkIsT0FBTyxFQUNQLE9BQU8sQ0FDUixDQUFDO29CQUNGLE9BQU8sQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUMsU0FBUyxDQUFDO29CQUVsRSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLE9BQU8sQ0FBQztpQkFDcEQ7cUJBQU0sSUFBSSxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUMsRUFBRTtvQkFDbEUsT0FBTyxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxLQUFLLENBQUM7b0JBQzdELE9BQU8sQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsbUJBQW1CLENBQUMsU0FBUyxDQUFDO29CQUVsRSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLE9BQU8sQ0FBQztpQkFDcEQ7YUFDRjtTQUNGO0lBQ0gsQ0FBQzs7c0hBakVVLHdCQUF3QjswR0FBeEIsd0JBQXdCOzRGQUF4Qix3QkFBd0I7a0JBSHBDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFFBQVE7aUJBQ25CO21IQUVVLEtBQUs7c0JBQWIsS0FBSztnQkFDSSxXQUFXO3NCQUFwQixNQUFNO2dCQU9QLFFBQVE7c0JBRFAsWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUM7Z0JBNEI3QixJQUFJO3NCQURQLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBEaXJlY3RpdmUsXG4gIEhvc3RMaXN0ZW5lcixcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgRXZlbnRFbWl0dGVyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBIaXN0b3JpY2FsRmllbGRIZWxwZXJTZXJ2aWNlIH0gZnJvbSAnLi4vaGVscGVycy9oaXN0b3JpY2FsLWZpZWxkLWhlbHBlci1zZXJ2aWNlJztcbmltcG9ydCAqIGFzIF8gZnJvbSAnbG9kYXNoJztcbmltcG9ydCB7IE5vZGVCYXNlIH0gZnJvbSAnLi4vZm9ybS1mYWN0b3J5L2Zvcm0tbm9kZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogYFtub2RlXWBcbn0pXG5leHBvcnQgY2xhc3MgSGlzdG9yaWNhbFZhbHVlRGlyZWN0aXZlIHtcbiAgQElucHV0KCkgX25vZGU6IE5vZGVCYXNlO1xuICBAT3V0cHV0KCkgX25vZGVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPE9iamVjdD4oKTtcblxuICBoaXN0b3JpY2FsRGlzcGxheTogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaGlzdG9yaWNhbEZpZWxkSGVscGVyOiBIaXN0b3JpY2FsRmllbGRIZWxwZXJTZXJ2aWNlKSB7fVxuXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJywgWyckZXZlbnQnXSlcbiAgc2V0VmFsdWUoZSkge1xuICAgIGlmIChlLnRhcmdldC5uYW1lID09PSAnaGlzdG9yeVZhbHVlJykge1xuICAgICAgaWYgKFxuICAgICAgICB0aGlzLl9ub2RlICYmXG4gICAgICAgICghdGhpcy5jb21wYXJlU3RyaW5nKHRoaXMuX25vZGUucXVlc3Rpb24ucmVuZGVyaW5nVHlwZSwgJ3BhZ2UnKSB8fFxuICAgICAgICAgICF0aGlzLmNvbXBhcmVTdHJpbmcodGhpcy5fbm9kZS5xdWVzdGlvbi5yZW5kZXJpbmdUeXBlLCAnc2VjdGlvbicpKVxuICAgICAgKSB7XG4gICAgICAgIHRoaXMuX25vZGUuY29udHJvbC5zZXRWYWx1ZShcbiAgICAgICAgICB0aGlzLl9ub2RlLnF1ZXN0aW9uLmhpc3RvcmljYWxEYXRhVmFsdWUudmFsdWVcbiAgICAgICAgKTtcblxuICAgICAgICB0aGlzLl9ub2RlLnF1ZXN0aW9uW1xuICAgICAgICAgICdoaXN0b3JpY2FsVmFsdWUnXG4gICAgICAgIF0gPSB0aGlzLl9ub2RlLnF1ZXN0aW9uLmhpc3RvcmljYWxEYXRhVmFsdWU7XG4gICAgICAgIGUuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgIHRoaXMuX25vZGVDaGFuZ2UuZW1pdCh0aGlzLl9ub2RlKTtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgcHJpdmF0ZSBjb21wYXJlU3RyaW5nKGEsIGIpIHtcbiAgICBpZiAoYSA9PT0gYikge1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cbiAgQElucHV0KClcbiAgc2V0IG5vZGUobm9kZTogTm9kZUJhc2UpIHtcbiAgICBpZiAobm9kZSkge1xuICAgICAgdGhpcy5fbm9kZSA9IG5vZGU7XG4gICAgICBpZiAoXG4gICAgICAgIHRoaXMuX25vZGUucXVlc3Rpb24uZW5hYmxlSGlzdG9yaWNhbFZhbHVlICYmXG4gICAgICAgICFfLmlzVW5kZWZpbmVkKHRoaXMuX25vZGUucXVlc3Rpb24uaGlzdG9yaWNhbERhdGFWYWx1ZSlcbiAgICAgICkge1xuICAgICAgICBjb25zdCBkaXNwbGF5OiBhbnkgPSB7IHRleHQ6ICcnLCBfZGF0ZTogJycgfTtcbiAgICAgICAgaWYgKFxuICAgICAgICAgIHRoaXMuX25vZGUucXVlc3Rpb24ucmVuZGVyaW5nVHlwZSA9PT0gJ3NlbGVjdCcgfHxcbiAgICAgICAgICB0aGlzLl9ub2RlLnF1ZXN0aW9uLnJlbmRlcmluZ1R5cGUgPT09ICdtdWx0aS1zZWxlY3QnIHx8XG4gICAgICAgICAgdGhpcy5fbm9kZS5xdWVzdGlvbi5yZW5kZXJpbmdUeXBlID09PSAnc2luZ2xlLXNlbGVjdCdcbiAgICAgICAgKSB7XG4gICAgICAgICAgZGlzcGxheS50ZXh0ID0gdGhpcy5oaXN0b3JpY2FsRmllbGRIZWxwZXIuZ2V0RGlzcGxheVRleHRGcm9tT3B0aW9ucyhcbiAgICAgICAgICAgIHRoaXMuX25vZGUucXVlc3Rpb24sXG4gICAgICAgICAgICAndmFsdWUnLFxuICAgICAgICAgICAgJ2xhYmVsJ1xuICAgICAgICAgICk7XG4gICAgICAgICAgZGlzcGxheS5fZGF0ZSA9IHRoaXMuX25vZGUucXVlc3Rpb24uaGlzdG9yaWNhbERhdGFWYWx1ZS52YWx1ZURhdGU7XG5cbiAgICAgICAgICB0aGlzLl9ub2RlLnF1ZXN0aW9uWydoaXN0b3JpY2FsRGlzcGxheSddID0gZGlzcGxheTtcbiAgICAgICAgfSBlbHNlIGlmICghXy5pc1VuZGVmaW5lZCh0aGlzLl9ub2RlLnF1ZXN0aW9uLmhpc3RvcmljYWxEYXRhVmFsdWUpKSB7XG4gICAgICAgICAgZGlzcGxheS50ZXh0ID0gdGhpcy5fbm9kZS5xdWVzdGlvbi5oaXN0b3JpY2FsRGF0YVZhbHVlLnZhbHVlO1xuICAgICAgICAgIGRpc3BsYXkuX2RhdGUgPSB0aGlzLl9ub2RlLnF1ZXN0aW9uLmhpc3RvcmljYWxEYXRhVmFsdWUudmFsdWVEYXRlO1xuXG4gICAgICAgICAgdGhpcy5fbm9kZS5xdWVzdGlvblsnaGlzdG9yaWNhbERpc3BsYXknXSA9IGRpc3BsYXk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cbn1cbiJdfQ==
|