ecabs-components 0.0.16 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/base/directives/date-mask.directive.mjs +67 -0
- package/{esm2020 → esm2022}/lib/base/directives/date-mask.directive.module.mjs +5 -5
- package/esm2022/lib/base/directives/digits-only.directive.mjs +133 -0
- package/{esm2020 → esm2022}/lib/base/directives/digits-only.directive.module.mjs +5 -5
- package/esm2022/lib/base/directives/number-border.directive.mjs +58 -0
- package/{esm2020 → esm2022}/lib/base/directives/number-border.directive.module.mjs +5 -5
- package/esm2022/lib/base/element-base.mjs +105 -0
- package/esm2022/lib/base/element-wrapper/element-wrapper.component.mjs +56 -0
- package/esm2022/lib/base/element-wrapper/element-wrapper.module.mjs +52 -0
- package/esm2022/lib/base/hint/hint.component.mjs +21 -0
- package/esm2022/lib/base/hint/hint.module.mjs +20 -0
- package/esm2022/lib/base/validation/validation.component.mjs +75 -0
- package/esm2022/lib/base/validation/validation.module.mjs +20 -0
- package/esm2022/lib/ecabs-breadcrumb/ecabs-breadcrumb.component.mjs +17 -0
- package/{esm2020 → esm2022}/lib/ecabs-breadcrumb/ecabs-breadcrumb.module.mjs +5 -5
- package/esm2022/lib/ecabs-buttons/ecabs-buttons.component.mjs +67 -0
- package/esm2022/lib/ecabs-buttons/ecabs-buttons.module.mjs +21 -0
- package/esm2022/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.mjs +90 -0
- package/{esm2020 → esm2022}/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.module.mjs +15 -15
- package/esm2022/lib/ecabs-date-picker/components/ecabs-date-picker-header/ecabs-date-picker-header.component.mjs +15 -0
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.component.mjs +89 -0
- package/esm2022/lib/ecabs-date-picker/ecabs-date-picker.module.mjs +48 -0
- package/esm2022/lib/ecabs-date-time-picker/components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component.mjs +15 -0
- package/esm2022/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.mjs +186 -0
- package/esm2022/lib/ecabs-date-time-picker/ecabs-date-time-picker.module.mjs +64 -0
- package/esm2022/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.mjs +32 -0
- package/esm2022/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.module.mjs +20 -0
- package/esm2022/lib/ecabs-dialog-message/ecabs-dialog-message.component.mjs +29 -0
- package/esm2022/lib/ecabs-dialog-message/ecabs-dialog-message.module.mjs +20 -0
- package/{esm2020 → esm2022}/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.component.mjs +7 -4
- package/{esm2020 → esm2022}/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.module.mjs +5 -5
- package/esm2022/lib/ecabs-expansion-panel/ecabs-expansion-panel.component.mjs +85 -0
- package/esm2022/lib/ecabs-expansion-panel/ecabs-expansion-panel.module.mjs +24 -0
- package/esm2022/lib/ecabs-increment/ecabs-increment.component.mjs +83 -0
- package/esm2022/lib/ecabs-increment/ecabs-increment.module.mjs +23 -0
- package/esm2022/lib/ecabs-input/ecabs-input.component.mjs +88 -0
- package/esm2022/lib/ecabs-input/ecabs-input.module.mjs +22 -0
- package/esm2022/lib/ecabs-language-selector/ecabs-language-selector.component.mjs +51 -0
- package/esm2022/lib/ecabs-language-selector/ecabs-language-selector.module.mjs +35 -0
- package/esm2022/lib/ecabs-loading/ecabs-loading.component.mjs +22 -0
- package/{esm2020 → esm2022}/lib/ecabs-loading/ecabs-loading.module.mjs +5 -5
- package/esm2022/lib/ecabs-loading/spinner/spinner.component.mjs +14 -0
- package/esm2022/lib/ecabs-note/ecabs-note.component.mjs +28 -0
- package/{esm2020 → esm2022}/lib/ecabs-note/ecabs-note.module.mjs +5 -5
- package/esm2022/lib/ecabs-phone/ecabs-phone.component.mjs +111 -0
- package/{esm2020 → esm2022}/lib/ecabs-phone/ecabs-phone.module.mjs +6 -6
- package/esm2022/lib/ecabs-picker-header/ecabs-picker-header.component.mjs +53 -0
- package/esm2022/lib/ecabs-picker-header/ecabs-picker-header.module.mjs +22 -0
- package/esm2022/lib/ecabs-radio-button-list/ecabs-radio-button-list.component.mjs +68 -0
- package/{esm2020 → esm2022}/lib/ecabs-radio-button-list/ecabs-radio-button-list.module.mjs +12 -12
- package/esm2022/lib/ecabs-select/ecabs-select.component.mjs +227 -0
- package/esm2022/lib/ecabs-select/ecabs-select.module.mjs +60 -0
- package/esm2022/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.component.mjs +19 -0
- package/{esm2020 → esm2022}/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.module.mjs +7 -7
- package/esm2022/lib/ecabs-table/ecabs-table.component.mjs +48 -0
- package/{esm2020 → esm2022}/lib/ecabs-table/ecabs-table.module.mjs +12 -12
- package/esm2022/lib/ecabs-textarea/ecabs-textarea.component.mjs +65 -0
- package/{esm2020 → esm2022}/lib/ecabs-textarea/ecabs-textarea.module.mjs +5 -5
- package/esm2022/lib/ecabs-timepicker/componets/ecabs-time-list-panel/ecabs-time-list-panel.component.mjs +144 -0
- package/esm2022/lib/ecabs-timepicker/ecabs-timepicker.component.mjs +322 -0
- package/{esm2020 → esm2022}/lib/ecabs-timepicker/ecabs-timepicker.module.mjs +5 -5
- package/esm2022/lib/ecabs-timepicker/ecabs-timepicker.service.mjs +29 -0
- package/esm2022/lib/models/language.models.mjs +2 -0
- package/esm2022/lib/services/ecabs-components.service.mjs +31 -0
- package/esm2022/public-api.mjs +51 -0
- package/fesm2022/ecabs-components.mjs +3047 -0
- package/fesm2022/ecabs-components.mjs.map +1 -0
- package/lib/base/directives/date-mask.directive.d.ts +1 -1
- package/lib/base/directives/digits-only.directive.d.ts +1 -1
- package/lib/base/directives/number-border.directive.d.ts +1 -1
- package/lib/base/element-base.d.ts +1 -1
- package/lib/base/element-wrapper/element-wrapper.component.d.ts +1 -1
- package/lib/base/element-wrapper/element-wrapper.module.d.ts +4 -4
- package/lib/base/hint/hint.component.d.ts +1 -1
- package/lib/base/hint/hint.module.d.ts +2 -2
- package/lib/base/validation/validation.component.d.ts +1 -1
- package/lib/base/validation/validation.module.d.ts +2 -2
- package/lib/ecabs-breadcrumb/ecabs-breadcrumb.component.d.ts +1 -1
- package/lib/ecabs-buttons/ecabs-buttons.component.d.ts +1 -1
- package/lib/ecabs-buttons/ecabs-buttons.module.d.ts +2 -2
- package/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.d.ts +1 -1
- package/lib/ecabs-date-picker/components/ecabs-date-picker-header/ecabs-date-picker-header.component.d.ts +1 -1
- package/lib/ecabs-date-picker/ecabs-date-picker.component.d.ts +1 -1
- package/lib/ecabs-date-picker/ecabs-date-picker.module.d.ts +2 -2
- package/lib/ecabs-date-time-picker/components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component.d.ts +1 -1
- package/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.d.ts +1 -1
- package/lib/ecabs-date-time-picker/ecabs-date-time-picker.module.d.ts +2 -2
- package/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.d.ts +1 -1
- package/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.module.d.ts +2 -2
- package/lib/ecabs-dialog-message/ecabs-dialog-message.component.d.ts +1 -1
- package/lib/ecabs-dialog-message/ecabs-dialog-message.module.d.ts +2 -2
- package/lib/ecabs-empty-placeholder/ecabs-empty-placeholder.component.d.ts +1 -1
- package/lib/ecabs-expansion-panel/ecabs-expansion-panel.component.d.ts +1 -1
- package/lib/ecabs-expansion-panel/ecabs-expansion-panel.module.d.ts +3 -3
- package/lib/ecabs-increment/ecabs-increment.component.d.ts +1 -1
- package/lib/ecabs-increment/ecabs-increment.module.d.ts +2 -2
- package/lib/ecabs-input/ecabs-input.component.d.ts +1 -1
- package/lib/ecabs-input/ecabs-input.module.d.ts +2 -2
- package/lib/ecabs-language-selector/ecabs-language-selector.component.d.ts +17 -0
- package/lib/ecabs-language-selector/ecabs-language-selector.module.d.ts +11 -0
- package/lib/ecabs-loading/ecabs-loading.component.d.ts +1 -1
- package/lib/ecabs-loading/spinner/spinner.component.d.ts +1 -1
- package/lib/ecabs-note/ecabs-note.component.d.ts +1 -1
- package/lib/ecabs-phone/ecabs-phone.component.d.ts +1 -1
- package/lib/ecabs-picker-header/ecabs-picker-header.component.d.ts +1 -1
- package/lib/ecabs-picker-header/ecabs-picker-header.module.d.ts +2 -2
- package/lib/ecabs-radio-button-list/ecabs-radio-button-list.component.d.ts +1 -1
- package/lib/ecabs-select/ecabs-select.component.d.ts +1 -1
- package/lib/ecabs-select/ecabs-select.module.d.ts +4 -4
- package/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.component.d.ts +1 -1
- package/lib/ecabs-table/ecabs-table.component.d.ts +1 -1
- package/lib/ecabs-textarea/ecabs-textarea.component.d.ts +1 -1
- package/lib/ecabs-timepicker/componets/ecabs-time-list-panel/ecabs-time-list-panel.component.d.ts +1 -1
- package/lib/ecabs-timepicker/ecabs-timepicker.component.d.ts +1 -1
- package/lib/models/language.models.d.ts +4 -0
- package/lib/models/timepicker.models.d.ts +1 -1
- package/package.json +12 -17
- package/public-api.d.ts +2 -0
- package/styles/material/overrides/_form.scss +97 -0
- package/styles/material/overrides/_phone.scss +1 -1
- package/styles/material/overrides/_select.scss +12 -6
- package/styles/material/overrides/_table.scss +2 -2
- package/styles/material/overrides/_toggle.scss +3 -3
- package/styles/scss/modules/_form.scss +12 -0
- package/styles/scss/modules/_select.scss +6 -2
- package/esm2020/lib/base/directives/date-mask.directive.mjs +0 -65
- package/esm2020/lib/base/directives/digits-only.directive.mjs +0 -130
- package/esm2020/lib/base/directives/number-border.directive.mjs +0 -54
- package/esm2020/lib/base/element-base.mjs +0 -100
- package/esm2020/lib/base/element-wrapper/element-wrapper.component.mjs +0 -53
- package/esm2020/lib/base/element-wrapper/element-wrapper.module.mjs +0 -52
- package/esm2020/lib/base/hint/hint.component.mjs +0 -21
- package/esm2020/lib/base/hint/hint.module.mjs +0 -20
- package/esm2020/lib/base/validation/validation.component.mjs +0 -70
- package/esm2020/lib/base/validation/validation.module.mjs +0 -20
- package/esm2020/lib/ecabs-breadcrumb/ecabs-breadcrumb.component.mjs +0 -16
- package/esm2020/lib/ecabs-buttons/ecabs-buttons.component.mjs +0 -65
- package/esm2020/lib/ecabs-buttons/ecabs-buttons.module.mjs +0 -21
- package/esm2020/lib/ecabs-checkbox-toggle/ecabs-checkbox-toggle.component.mjs +0 -85
- package/esm2020/lib/ecabs-date-picker/components/ecabs-date-picker-header/ecabs-date-picker-header.component.mjs +0 -17
- package/esm2020/lib/ecabs-date-picker/ecabs-date-picker.component.mjs +0 -85
- package/esm2020/lib/ecabs-date-picker/ecabs-date-picker.module.mjs +0 -48
- package/esm2020/lib/ecabs-date-time-picker/components/ecabs-date-time-picker-header/ecabs-date-time-picker-header.component.mjs +0 -17
- package/esm2020/lib/ecabs-date-time-picker/ecabs-date-time-picker.component.mjs +0 -179
- package/esm2020/lib/ecabs-date-time-picker/ecabs-date-time-picker.module.mjs +0 -64
- package/esm2020/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.component.mjs +0 -28
- package/esm2020/lib/ecabs-dialog-confirm/ecabs-dialog-confirm.module.mjs +0 -20
- package/esm2020/lib/ecabs-dialog-message/ecabs-dialog-message.component.mjs +0 -25
- package/esm2020/lib/ecabs-dialog-message/ecabs-dialog-message.module.mjs +0 -20
- package/esm2020/lib/ecabs-expansion-panel/ecabs-expansion-panel.component.mjs +0 -76
- package/esm2020/lib/ecabs-expansion-panel/ecabs-expansion-panel.module.mjs +0 -24
- package/esm2020/lib/ecabs-increment/ecabs-increment.component.mjs +0 -78
- package/esm2020/lib/ecabs-increment/ecabs-increment.module.mjs +0 -23
- package/esm2020/lib/ecabs-input/ecabs-input.component.mjs +0 -81
- package/esm2020/lib/ecabs-input/ecabs-input.module.mjs +0 -22
- package/esm2020/lib/ecabs-loading/ecabs-loading.component.mjs +0 -24
- package/esm2020/lib/ecabs-loading/spinner/spinner.component.mjs +0 -16
- package/esm2020/lib/ecabs-note/ecabs-note.component.mjs +0 -30
- package/esm2020/lib/ecabs-phone/ecabs-phone.component.mjs +0 -104
- package/esm2020/lib/ecabs-picker-header/ecabs-picker-header.component.mjs +0 -50
- package/esm2020/lib/ecabs-picker-header/ecabs-picker-header.module.mjs +0 -22
- package/esm2020/lib/ecabs-radio-button-list/ecabs-radio-button-list.component.mjs +0 -65
- package/esm2020/lib/ecabs-select/ecabs-select.component.mjs +0 -222
- package/esm2020/lib/ecabs-select/ecabs-select.module.mjs +0 -60
- package/esm2020/lib/ecabs-table/ecabs-table-filter-wrapper/ecabs-table-filter-wrapper.component.mjs +0 -17
- package/esm2020/lib/ecabs-table/ecabs-table.component.mjs +0 -43
- package/esm2020/lib/ecabs-textarea/ecabs-textarea.component.mjs +0 -62
- package/esm2020/lib/ecabs-timepicker/componets/ecabs-time-list-panel/ecabs-time-list-panel.component.mjs +0 -137
- package/esm2020/lib/ecabs-timepicker/ecabs-timepicker.component.mjs +0 -312
- package/esm2020/lib/ecabs-timepicker/ecabs-timepicker.service.mjs +0 -31
- package/esm2020/lib/services/ecabs-components.service.mjs +0 -32
- package/esm2020/public-api.mjs +0 -49
- package/fesm2015/ecabs-components.mjs +0 -2881
- package/fesm2015/ecabs-components.mjs.map +0 -1
- package/fesm2020/ecabs-components.mjs +0 -2868
- package/fesm2020/ecabs-components.mjs.map +0 -1
- /package/{esm2020 → esm2022}/ecabs-components.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/base/consts/date-mask.consts.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/ecabs-timepicker/config.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/bread-crumb.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/timepicker.models.mjs +0 -0
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
5
|
+
import { MatLegacyInputModule } from '@angular/material/legacy-input';
|
|
6
|
+
import { DigitsOnlyDirectivesModule } from '../base/directives/digits-only.directive.module';
|
|
7
|
+
import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
|
|
8
|
+
import { EcabsIncrementComponent } from './ecabs-increment.component';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export class EcabsIncrementModule {
|
|
11
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsIncrementModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
12
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.1", ngImport: i0, type: EcabsIncrementModule, declarations: [EcabsIncrementComponent], imports: [CommonModule, MatLegacyInputModule, MatIconModule, ElementWrapperModule, FormsModule, DigitsOnlyDirectivesModule], exports: [EcabsIncrementComponent] });
|
|
13
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsIncrementModule, imports: [CommonModule, MatLegacyInputModule, MatIconModule, ElementWrapperModule, FormsModule, DigitsOnlyDirectivesModule] });
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsIncrementModule, decorators: [{
|
|
16
|
+
type: NgModule,
|
|
17
|
+
args: [{
|
|
18
|
+
declarations: [EcabsIncrementComponent],
|
|
19
|
+
imports: [CommonModule, MatLegacyInputModule, MatIconModule, ElementWrapperModule, FormsModule, DigitsOnlyDirectivesModule],
|
|
20
|
+
exports: [EcabsIncrementComponent],
|
|
21
|
+
}]
|
|
22
|
+
}] });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtaW5jcmVtZW50Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1pbmNyZW1lbnQvZWNhYnMtaW5jcmVtZW50Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ3RFLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBRTdGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3RGLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDOztBQU90RSxNQUFNLE9BQU8sb0JBQW9CO3VHQUFwQixvQkFBb0I7d0dBQXBCLG9CQUFvQixpQkFKZix1QkFBdUIsYUFDNUIsWUFBWSxFQUFFLG9CQUFvQixFQUFFLGFBQWEsRUFBRSxvQkFBb0IsRUFBRSxXQUFXLEVBQUUsMEJBQTBCLGFBQ2hILHVCQUF1Qjt3R0FFdkIsb0JBQW9CLFlBSHBCLFlBQVksRUFBRSxvQkFBb0IsRUFBRSxhQUFhLEVBQUUsb0JBQW9CLEVBQUUsV0FBVyxFQUFFLDBCQUEwQjs7MkZBR2hILG9CQUFvQjtrQkFMaEMsUUFBUTttQkFBRTtvQkFDVCxZQUFZLEVBQUUsQ0FBRSx1QkFBdUIsQ0FBRTtvQkFDekMsT0FBTyxFQUFFLENBQUUsWUFBWSxFQUFFLG9CQUFvQixFQUFFLGFBQWEsRUFBRSxvQkFBb0IsRUFBRSxXQUFXLEVBQUUsMEJBQTBCLENBQUU7b0JBQzdILE9BQU8sRUFBRSxDQUFFLHVCQUF1QixDQUFFO2lCQUNyQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcbmltcG9ydCB7IE1hdExlZ2FjeUlucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbGVnYWN5LWlucHV0JztcclxuaW1wb3J0IHsgRGlnaXRzT25seURpcmVjdGl2ZXNNb2R1bGUgfSBmcm9tICcuLi9iYXNlL2RpcmVjdGl2ZXMvZGlnaXRzLW9ubHkuZGlyZWN0aXZlLm1vZHVsZSc7XHJcblxyXG5pbXBvcnQgeyBFbGVtZW50V3JhcHBlck1vZHVsZSB9IGZyb20gJy4uL2Jhc2UvZWxlbWVudC13cmFwcGVyL2VsZW1lbnQtd3JhcHBlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBFY2Fic0luY3JlbWVudENvbXBvbmVudCB9IGZyb20gJy4vZWNhYnMtaW5jcmVtZW50LmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoIHtcclxuICBkZWNsYXJhdGlvbnM6IFsgRWNhYnNJbmNyZW1lbnRDb21wb25lbnQgXSxcclxuICBpbXBvcnRzOiBbIENvbW1vbk1vZHVsZSwgTWF0TGVnYWN5SW5wdXRNb2R1bGUsIE1hdEljb25Nb2R1bGUsIEVsZW1lbnRXcmFwcGVyTW9kdWxlLCBGb3Jtc01vZHVsZSwgRGlnaXRzT25seURpcmVjdGl2ZXNNb2R1bGUgXSxcclxuICBleHBvcnRzOiBbIEVjYWJzSW5jcmVtZW50Q29tcG9uZW50IF0sXHJcbn0gKVxyXG5leHBvcnQgY2xhc3MgRWNhYnNJbmNyZW1lbnRNb2R1bGUgeyB9XHJcbiJdfQ==
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { NgControl, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import ElementBaseComponent from '../base/element-base';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "../base/element-wrapper/element-wrapper.component";
|
|
7
|
+
import * as i3 from "@angular/forms";
|
|
8
|
+
import * as i4 from "../base/directives/digits-only.directive";
|
|
9
|
+
export class EcabsInputComponent extends ElementBaseComponent {
|
|
10
|
+
injector;
|
|
11
|
+
digitsOnly;
|
|
12
|
+
allowDecimal;
|
|
13
|
+
allowHyphen;
|
|
14
|
+
max;
|
|
15
|
+
step;
|
|
16
|
+
onblur = new EventEmitter();
|
|
17
|
+
val;
|
|
18
|
+
get value() {
|
|
19
|
+
return this.val;
|
|
20
|
+
}
|
|
21
|
+
set value(val) {
|
|
22
|
+
if (val !== undefined && this.val !== val) {
|
|
23
|
+
this.val = val;
|
|
24
|
+
this.onChange(val);
|
|
25
|
+
this.onTouch(val);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
constructor(injector) {
|
|
29
|
+
super();
|
|
30
|
+
this.injector = injector;
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
if (this.type === 'number') {
|
|
34
|
+
this.digitsOnly = true;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
ngAfterViewInit() {
|
|
38
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
39
|
+
if (ngControl) {
|
|
40
|
+
this.control = ngControl.control;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
onChange = () => { };
|
|
44
|
+
onTouch = () => { };
|
|
45
|
+
writeValue(value) {
|
|
46
|
+
this.value = value;
|
|
47
|
+
}
|
|
48
|
+
registerOnChange(fn) {
|
|
49
|
+
this.onChange = fn;
|
|
50
|
+
}
|
|
51
|
+
registerOnTouched(fn) {
|
|
52
|
+
this.onTouch = fn;
|
|
53
|
+
}
|
|
54
|
+
blurChange(e) {
|
|
55
|
+
this.onblur.emit(e);
|
|
56
|
+
}
|
|
57
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsInputComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
58
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.1", type: EcabsInputComponent, selector: "ecabs-input", inputs: { digitsOnly: "digitsOnly", allowDecimal: "allowDecimal", allowHyphen: "allowHyphen", max: "max", step: "step" }, outputs: { onblur: "onblur" }, providers: [
|
|
59
|
+
{
|
|
60
|
+
provide: NG_VALUE_ACCESSOR,
|
|
61
|
+
useExisting: EcabsInputComponent,
|
|
62
|
+
multi: true,
|
|
63
|
+
},
|
|
64
|
+
], usesInheritance: true, ngImport: i0, template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper\">\r\n <input\r\n appDigitsOnly\r\n [digitsOnly]=\"digitsOnly\"\r\n [decimal]=\"allowDecimal\"\r\n [allowHyphen]=\"allowHyphen\"\r\n class=\"form-field__input\"\r\n [type]=\"type\"\r\n [id]=\"name\"\r\n [(ngModel)]=\"value\"\r\n [placeholder]=\"placeholder\"\r\n (blur)=\"onTouch()\"\r\n [disabled]=\"disabled\"\r\n [maxlength]=\"maxLength\"\r\n [max]=\"max\"\r\n [step]=\"step\"\r\n (blur)=\"blurChange($event)\"\r\n />\r\n\r\n <div class=\"form-field__input--suffix\" *ngIf=\"type !== 'number'\">\r\n <ng-content select=\"mat-icon\"></ng-content>\r\n <ng-content select=\".suffix\"></ng-content>\r\n </div>\r\n </div>\r\n</app-element-wrapper>\r\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.DigitsOnlyDirective, selector: "[appDigitsOnly]", inputs: ["digitsOnly", "allowHyphen", "decimal", "decimalSeparator", "unit"] }] });
|
|
65
|
+
}
|
|
66
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsInputComponent, decorators: [{
|
|
67
|
+
type: Component,
|
|
68
|
+
args: [{ selector: 'ecabs-input', providers: [
|
|
69
|
+
{
|
|
70
|
+
provide: NG_VALUE_ACCESSOR,
|
|
71
|
+
useExisting: EcabsInputComponent,
|
|
72
|
+
multi: true,
|
|
73
|
+
},
|
|
74
|
+
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <div class=\"form-field__input--wrapper\">\r\n <input\r\n appDigitsOnly\r\n [digitsOnly]=\"digitsOnly\"\r\n [decimal]=\"allowDecimal\"\r\n [allowHyphen]=\"allowHyphen\"\r\n class=\"form-field__input\"\r\n [type]=\"type\"\r\n [id]=\"name\"\r\n [(ngModel)]=\"value\"\r\n [placeholder]=\"placeholder\"\r\n (blur)=\"onTouch()\"\r\n [disabled]=\"disabled\"\r\n [maxlength]=\"maxLength\"\r\n [max]=\"max\"\r\n [step]=\"step\"\r\n (blur)=\"blurChange($event)\"\r\n />\r\n\r\n <div class=\"form-field__input--suffix\" *ngIf=\"type !== 'number'\">\r\n <ng-content select=\"mat-icon\"></ng-content>\r\n <ng-content select=\".suffix\"></ng-content>\r\n </div>\r\n </div>\r\n</app-element-wrapper>\r\n" }]
|
|
75
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { digitsOnly: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}], allowDecimal: [{
|
|
78
|
+
type: Input
|
|
79
|
+
}], allowHyphen: [{
|
|
80
|
+
type: Input
|
|
81
|
+
}], max: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}], step: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}], onblur: [{
|
|
86
|
+
type: Output
|
|
87
|
+
}] } });
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtaW5wdXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLWlucHV0L2VjYWJzLWlucHV0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1pbnB1dC9lY2Ficy1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlCLFNBQVMsRUFBRSxZQUFZLEVBQVksS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4RyxPQUFPLEVBQTRDLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3hHLE9BQU8sb0JBQW9CLE1BQU0sc0JBQXNCLENBQUM7Ozs7OztBQWF4RCxNQUFNLE9BQU8sbUJBQ1gsU0FBUSxvQkFBb0I7SUE4QlI7SUExQnBCLFVBQVUsQ0FBVztJQUdyQixZQUFZLENBQVc7SUFHdkIsV0FBVyxDQUFXO0lBRWIsR0FBRyxDQUFVO0lBQ2IsSUFBSSxDQUFVO0lBRWIsTUFBTSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFDM0MsR0FBRyxDQUFtQjtJQUV0QixJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUM7SUFDbEIsQ0FBQztJQUVELElBQUksS0FBSyxDQUFDLEdBQUc7UUFDWCxJQUFJLEdBQUcsS0FBSyxTQUFTLElBQUksSUFBSSxDQUFDLEdBQUcsS0FBSyxHQUFHLEVBQUU7WUFDekMsSUFBSSxDQUFDLEdBQUcsR0FBRyxHQUFHLENBQUM7WUFDZixJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ25CLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7U0FDbkI7SUFDSCxDQUFDO0lBRUQsWUFBb0IsUUFBa0I7UUFDcEMsS0FBSyxFQUFFLENBQUM7UUFEVSxhQUFRLEdBQVIsUUFBUSxDQUFVO0lBRXRDLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxJQUFJLENBQUMsSUFBSSxLQUFLLFFBQVEsRUFBRTtZQUMxQixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztTQUN4QjtJQUNILENBQUM7SUFFRCxlQUFlO1FBQ2IsTUFBTSxTQUFTLEdBQWMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBYyxDQUFDO1FBQzdFLElBQUksU0FBUyxFQUFFO1lBQ2IsSUFBSSxDQUFDLE9BQU8sR0FBRyxTQUFTLENBQUMsT0FBNkIsQ0FBQztTQUN4RDtJQUNILENBQUM7SUFFRCxRQUFRLEdBQVEsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO0lBRXpCLE9BQU8sR0FBUSxHQUFHLEVBQUUsR0FBRSxDQUFDLENBQUM7SUFFeEIsVUFBVSxDQUFDLEtBQVU7UUFDbkIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7SUFDckIsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQU87UUFDdEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDdkIsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDcEIsQ0FBQztJQUVELFVBQVUsQ0FBQyxDQUFLO1FBQ2QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdEIsQ0FBQzt1R0FsRVUsbUJBQW1COzJGQUFuQixtQkFBbUIsK0xBUm5CO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLG1CQUFtQjtnQkFDaEMsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLGlEQ2JILHEwQkEwQkE7OzJGRFhhLG1CQUFtQjtrQkFYL0IsU0FBUzsrQkFDRSxhQUFhLGFBRVo7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxxQkFBcUI7NEJBQ2hDLEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGOytGQU9ELFVBQVU7c0JBRFQsS0FBSztnQkFJTixZQUFZO3NCQURYLEtBQUs7Z0JBSU4sV0FBVztzQkFEVixLQUFLO2dCQUdHLEdBQUc7c0JBQVgsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBRUksTUFBTTtzQkFBZixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEluamVjdG9yLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3IsIFVudHlwZWRGb3JtQ29udHJvbCwgTmdDb250cm9sLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IEVsZW1lbnRCYXNlQ29tcG9uZW50IGZyb20gJy4uL2Jhc2UvZWxlbWVudC1iYXNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnZWNhYnMtaW5wdXQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9lY2Ficy1pbnB1dC5jb21wb25lbnQuaHRtbCcsXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgICB1c2VFeGlzdGluZzogRWNhYnNJbnB1dENvbXBvbmVudCxcclxuICAgICAgbXVsdGk6IHRydWUsXHJcbiAgICB9LFxyXG4gIF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBFY2Fic0lucHV0Q29tcG9uZW50XHJcbiAgZXh0ZW5kcyBFbGVtZW50QmFzZUNvbXBvbmVudFxyXG4gIGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3IsIEFmdGVyVmlld0luaXQsIE9uSW5pdFxyXG57XHJcbiAgQElucHV0KClcclxuICBkaWdpdHNPbmx5ITogYm9vbGVhbjtcclxuXHJcbiAgQElucHV0KClcclxuICBhbGxvd0RlY2ltYWwhOiBib29sZWFuO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIGFsbG93SHlwaGVuITogYm9vbGVhbjtcclxuXHJcbiAgQElucHV0KCkgbWF4ITogbnVtYmVyO1xyXG4gIEBJbnB1dCgpIHN0ZXAhOiBudW1iZXI7XHJcblxyXG4gIEBPdXRwdXQoKSBvbmJsdXIgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuICB2YWwhOiBzdHJpbmcgfCBudW1iZXI7XHJcblxyXG4gIGdldCB2YWx1ZSgpOiBzdHJpbmcgfCBudW1iZXIge1xyXG4gICAgcmV0dXJuIHRoaXMudmFsO1xyXG4gIH1cclxuXHJcbiAgc2V0IHZhbHVlKHZhbCkge1xyXG4gICAgaWYgKHZhbCAhPT0gdW5kZWZpbmVkICYmIHRoaXMudmFsICE9PSB2YWwpIHtcclxuICAgICAgdGhpcy52YWwgPSB2YWw7XHJcbiAgICAgIHRoaXMub25DaGFuZ2UodmFsKTtcclxuICAgICAgdGhpcy5vblRvdWNoKHZhbCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGluamVjdG9yOiBJbmplY3Rvcikge1xyXG4gICAgc3VwZXIoKTtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgaWYgKHRoaXMudHlwZSA9PT0gJ251bWJlcicpIHtcclxuICAgICAgdGhpcy5kaWdpdHNPbmx5ID0gdHJ1ZTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpOiB2b2lkIHtcclxuICAgIGNvbnN0IG5nQ29udHJvbDogTmdDb250cm9sID0gdGhpcy5pbmplY3Rvci5nZXQoTmdDb250cm9sLCBudWxsKSBhcyBOZ0NvbnRyb2w7XHJcbiAgICBpZiAobmdDb250cm9sKSB7XHJcbiAgICAgIHRoaXMuY29udHJvbCA9IG5nQ29udHJvbC5jb250cm9sIGFzIFVudHlwZWRGb3JtQ29udHJvbDtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIG9uQ2hhbmdlOiBhbnkgPSAoKSA9PiB7fTtcclxuXHJcbiAgb25Ub3VjaDogYW55ID0gKCkgPT4ge307XHJcblxyXG4gIHdyaXRlVmFsdWUodmFsdWU6IGFueSk6IHZvaWQge1xyXG4gICAgdGhpcy52YWx1ZSA9IHZhbHVlO1xyXG4gIH1cclxuXHJcbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLm9uQ2hhbmdlID0gZm47XHJcbiAgfVxyXG5cclxuICByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KTogdm9pZCB7XHJcbiAgICB0aGlzLm9uVG91Y2ggPSBmbjtcclxuICB9XHJcblxyXG4gIGJsdXJDaGFuZ2UoZTphbnkpOiB2b2lkIHtcclxuICAgIHRoaXMub25ibHVyLmVtaXQoZSk7XHJcbiAgfVxyXG59XHJcbiIsIjxhcHAtZWxlbWVudC13cmFwcGVyIFtkYXRhXT1cImdldERhdGEoKVwiPlxyXG4gIDxkaXYgY2xhc3M9XCJmb3JtLWZpZWxkX19pbnB1dC0td3JhcHBlclwiPlxyXG4gICAgPGlucHV0XHJcbiAgICAgIGFwcERpZ2l0c09ubHlcclxuICAgICAgW2RpZ2l0c09ubHldPVwiZGlnaXRzT25seVwiXHJcbiAgICAgIFtkZWNpbWFsXT1cImFsbG93RGVjaW1hbFwiXHJcbiAgICAgIFthbGxvd0h5cGhlbl09XCJhbGxvd0h5cGhlblwiXHJcbiAgICAgIGNsYXNzPVwiZm9ybS1maWVsZF9faW5wdXRcIlxyXG4gICAgICBbdHlwZV09XCJ0eXBlXCJcclxuICAgICAgW2lkXT1cIm5hbWVcIlxyXG4gICAgICBbKG5nTW9kZWwpXT1cInZhbHVlXCJcclxuICAgICAgW3BsYWNlaG9sZGVyXT1cInBsYWNlaG9sZGVyXCJcclxuICAgICAgKGJsdXIpPVwib25Ub3VjaCgpXCJcclxuICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcclxuICAgICAgW21heGxlbmd0aF09XCJtYXhMZW5ndGhcIlxyXG4gICAgICBbbWF4XT1cIm1heFwiXHJcbiAgICAgIFtzdGVwXT1cInN0ZXBcIlxyXG4gICAgICAoYmx1cik9XCJibHVyQ2hhbmdlKCRldmVudClcIlxyXG4gICAgLz5cclxuXHJcbiAgICA8ZGl2IGNsYXNzPVwiZm9ybS1maWVsZF9faW5wdXQtLXN1ZmZpeFwiICpuZ0lmPVwidHlwZSAhPT0gJ251bWJlcidcIj5cclxuICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwibWF0LWljb25cIj48L25nLWNvbnRlbnQ+XHJcbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIi5zdWZmaXhcIj48L25nLWNvbnRlbnQ+XHJcbiAgICA8L2Rpdj5cclxuICA8L2Rpdj5cclxuPC9hcHAtZWxlbWVudC13cmFwcGVyPlxyXG4iXX0=
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { EcabsInputComponent } from './ecabs-input.component';
|
|
4
|
+
import { MatLegacyInputModule } from '@angular/material/legacy-input';
|
|
5
|
+
import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
|
|
6
|
+
import { FormsModule } from '@angular/forms';
|
|
7
|
+
import { DigitsOnlyDirectivesModule } from '../base/directives/digits-only.directive.module';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export class EcabsInputModule {
|
|
10
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.1", ngImport: i0, type: EcabsInputModule, declarations: [EcabsInputComponent], imports: [CommonModule, MatLegacyInputModule, ElementWrapperModule, FormsModule, DigitsOnlyDirectivesModule], exports: [EcabsInputComponent] });
|
|
12
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsInputModule, imports: [CommonModule, MatLegacyInputModule, ElementWrapperModule, FormsModule, DigitsOnlyDirectivesModule] });
|
|
13
|
+
}
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsInputModule, decorators: [{
|
|
15
|
+
type: NgModule,
|
|
16
|
+
args: [{
|
|
17
|
+
declarations: [EcabsInputComponent],
|
|
18
|
+
imports: [CommonModule, MatLegacyInputModule, ElementWrapperModule, FormsModule, DigitsOnlyDirectivesModule],
|
|
19
|
+
exports: [EcabsInputComponent],
|
|
20
|
+
}]
|
|
21
|
+
}] });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtaW5wdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLWlucHV0L2VjYWJzLWlucHV0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN0RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUN0RixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0saURBQWlELENBQUM7O0FBTzdGLE1BQU0sT0FBTyxnQkFBZ0I7dUdBQWhCLGdCQUFnQjt3R0FBaEIsZ0JBQWdCLGlCQUpYLG1CQUFtQixhQUN4QixZQUFZLEVBQUUsb0JBQW9CLEVBQUUsb0JBQW9CLEVBQUUsV0FBVyxFQUFFLDBCQUEwQixhQUNqRyxtQkFBbUI7d0dBRW5CLGdCQUFnQixZQUhoQixZQUFZLEVBQUUsb0JBQW9CLEVBQUUsb0JBQW9CLEVBQUUsV0FBVyxFQUFFLDBCQUEwQjs7MkZBR2pHLGdCQUFnQjtrQkFMNUIsUUFBUTttQkFBRTtvQkFDVCxZQUFZLEVBQUUsQ0FBRSxtQkFBbUIsQ0FBRTtvQkFDckMsT0FBTyxFQUFFLENBQUUsWUFBWSxFQUFFLG9CQUFvQixFQUFFLG9CQUFvQixFQUFFLFdBQVcsRUFBRSwwQkFBMEIsQ0FBRTtvQkFDOUcsT0FBTyxFQUFFLENBQUUsbUJBQW1CLENBQUU7aUJBQ2pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRWNhYnNJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vZWNhYnMtaW5wdXQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0TGVnYWN5SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9sZWdhY3ktaW5wdXQnO1xyXG5pbXBvcnQgeyBFbGVtZW50V3JhcHBlck1vZHVsZSB9IGZyb20gJy4uL2Jhc2UvZWxlbWVudC13cmFwcGVyL2VsZW1lbnQtd3JhcHBlci5tb2R1bGUnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgRGlnaXRzT25seURpcmVjdGl2ZXNNb2R1bGUgfSBmcm9tICcuLi9iYXNlL2RpcmVjdGl2ZXMvZGlnaXRzLW9ubHkuZGlyZWN0aXZlLm1vZHVsZSc7XHJcblxyXG5ATmdNb2R1bGUoIHtcclxuICBkZWNsYXJhdGlvbnM6IFsgRWNhYnNJbnB1dENvbXBvbmVudCBdLFxyXG4gIGltcG9ydHM6IFsgQ29tbW9uTW9kdWxlLCBNYXRMZWdhY3lJbnB1dE1vZHVsZSwgRWxlbWVudFdyYXBwZXJNb2R1bGUsIEZvcm1zTW9kdWxlLCBEaWdpdHNPbmx5RGlyZWN0aXZlc01vZHVsZSBdLFxyXG4gIGV4cG9ydHM6IFsgRWNhYnNJbnB1dENvbXBvbmVudCBdLFxyXG59IClcclxuZXhwb3J0IGNsYXNzIEVjYWJzSW5wdXRNb2R1bGUgeyB9XHJcbiJdfQ==
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@angular/material/form-field";
|
|
5
|
+
import * as i3 from "@angular/material/select";
|
|
6
|
+
import * as i4 from "@angular/material/core";
|
|
7
|
+
import * as i5 from "@angular/forms";
|
|
8
|
+
export class EcabsLanguageSelectorComponent {
|
|
9
|
+
languages = [];
|
|
10
|
+
currentLanguage;
|
|
11
|
+
languageChanged = new EventEmitter();
|
|
12
|
+
selectedLang;
|
|
13
|
+
ngOnChanges() {
|
|
14
|
+
this.selectedLang = this.currentLanguage;
|
|
15
|
+
}
|
|
16
|
+
toggleLang() {
|
|
17
|
+
return this.matchSelected() ? this.languageChanged.emit(this.matchSelected()) : undefined;
|
|
18
|
+
}
|
|
19
|
+
matchSelected() {
|
|
20
|
+
return this.languages?.find((lang) => lang.iso_code === this.selectedLang);
|
|
21
|
+
}
|
|
22
|
+
standardLang(code) {
|
|
23
|
+
return this.standardise(code);
|
|
24
|
+
}
|
|
25
|
+
flagClass(lang) {
|
|
26
|
+
return `fi fi-${lang?.slice(-2).toLowerCase()}`;
|
|
27
|
+
}
|
|
28
|
+
standardise(code) {
|
|
29
|
+
if (!code) {
|
|
30
|
+
return undefined;
|
|
31
|
+
}
|
|
32
|
+
const lang = new Intl.DisplayNames([code], {
|
|
33
|
+
type: 'language',
|
|
34
|
+
languageDisplay: 'standard',
|
|
35
|
+
});
|
|
36
|
+
return lang.of(code);
|
|
37
|
+
}
|
|
38
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsLanguageSelectorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
39
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.1", type: EcabsLanguageSelectorComponent, selector: "ecabs-language-selector", inputs: { languages: "languages", currentLanguage: "currentLanguage" }, outputs: { languageChanged: "languageChanged" }, usesOnChanges: true, ngImport: i0, template: "<mat-form-field>\r\n\t<mat-select class=\"capitalize\" [(ngModel)]=\"selectedLang\" name=\"language\" (ngModelChange)=\"toggleLang()\"\r\n\t\t\t\t\t\t\tpanelClass=\"wide-select\">\r\n\t\t<mat-select-trigger>\r\n\t\t\t<div class=\"flex items-center\">\r\n\t\t\t\t<span [ngClass]=\"flagClass(matchSelected()?.iso_code)\"></span>\r\n\t\t\t\t<div class=\"ml-2\">{{standardLang(matchSelected()?.iso_code)}}</div>\r\n\t\t\t</div>\r\n\t\t</mat-select-trigger>\r\n\t\t<mat-option class=\"capitalize\" *ngFor=\"let lang of languages\" [value]=\"lang.iso_code\">\r\n\t\t\t<div class=\"flex items-center\">\r\n\t\t\t\t<span [ngClass]=\"flagClass(lang?.iso_code)\"></span>\r\n\t\t\t\t<div class=\"ml-2\">{{standardLang(lang?.iso_code)}}</div>\r\n\t\t\t</div>\r\n\t\t</mat-option>\r\n\t</mat-select>\r\n</mat-form-field>\r\n", styles: [":host::ng-deep .mat-mdc-select{padding:0;border:0}:host::ng-deep .mat-mdc-select .mat-mdc-select-arrow-wrapper{display:none}:host::ng-deep .mat-mdc-select,:host::ng-deep .mat-mdc-select .mdc-list-item{font-size:12px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i3.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator"], exportAs: ["matSelect"] }, { kind: "directive", type: i3.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i4.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
40
|
+
}
|
|
41
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsLanguageSelectorComponent, decorators: [{
|
|
42
|
+
type: Component,
|
|
43
|
+
args: [{ selector: 'ecabs-language-selector', template: "<mat-form-field>\r\n\t<mat-select class=\"capitalize\" [(ngModel)]=\"selectedLang\" name=\"language\" (ngModelChange)=\"toggleLang()\"\r\n\t\t\t\t\t\t\tpanelClass=\"wide-select\">\r\n\t\t<mat-select-trigger>\r\n\t\t\t<div class=\"flex items-center\">\r\n\t\t\t\t<span [ngClass]=\"flagClass(matchSelected()?.iso_code)\"></span>\r\n\t\t\t\t<div class=\"ml-2\">{{standardLang(matchSelected()?.iso_code)}}</div>\r\n\t\t\t</div>\r\n\t\t</mat-select-trigger>\r\n\t\t<mat-option class=\"capitalize\" *ngFor=\"let lang of languages\" [value]=\"lang.iso_code\">\r\n\t\t\t<div class=\"flex items-center\">\r\n\t\t\t\t<span [ngClass]=\"flagClass(lang?.iso_code)\"></span>\r\n\t\t\t\t<div class=\"ml-2\">{{standardLang(lang?.iso_code)}}</div>\r\n\t\t\t</div>\r\n\t\t</mat-option>\r\n\t</mat-select>\r\n</mat-form-field>\r\n", styles: [":host::ng-deep .mat-mdc-select{padding:0;border:0}:host::ng-deep .mat-mdc-select .mat-mdc-select-arrow-wrapper{display:none}:host::ng-deep .mat-mdc-select,:host::ng-deep .mat-mdc-select .mdc-list-item{font-size:12px}\n"] }]
|
|
44
|
+
}], propDecorators: { languages: [{
|
|
45
|
+
type: Input
|
|
46
|
+
}], currentLanguage: [{
|
|
47
|
+
type: Input
|
|
48
|
+
}], languageChanged: [{
|
|
49
|
+
type: Output
|
|
50
|
+
}] } });
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtbGFuZ3VhZ2Utc2VsZWN0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLWxhbmd1YWdlLXNlbGVjdG9yL2VjYWJzLWxhbmd1YWdlLXNlbGVjdG9yLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1sYW5ndWFnZS1zZWxlY3Rvci9lY2Ficy1sYW5ndWFnZS1zZWxlY3Rvci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQWEsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7O0FBUWxGLE1BQU0sT0FBTyw4QkFBOEI7SUFFekMsU0FBUyxHQUFxQixFQUFFLENBQUM7SUFHakMsZUFBZSxDQUFTO0lBR3hCLGVBQWUsR0FBaUMsSUFBSSxZQUFZLEVBQWtCLENBQUM7SUFFbkYsWUFBWSxDQUFTO0lBRXJCLFdBQVc7UUFDVCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUM7SUFDM0MsQ0FBQztJQUVELFVBQVU7UUFDUixPQUFPLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUUsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFFLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUM5RixDQUFDO0lBRUQsYUFBYTtRQUNYLE9BQU8sSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUUsQ0FBRSxJQUFJLEVBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLEtBQUssSUFBSSxDQUFDLFlBQVksQ0FBRSxDQUFDO0lBQ2pGLENBQUM7SUFFRCxZQUFZLENBQUUsSUFBWTtRQUN4QixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUUsSUFBSSxDQUFFLENBQUM7SUFDbEMsQ0FBQztJQUVELFNBQVMsQ0FBRSxJQUFZO1FBQ3JCLE9BQU8sU0FBVSxJQUFJLEVBQUUsS0FBSyxDQUFFLENBQUMsQ0FBQyxDQUFFLENBQUMsV0FBVyxFQUFHLEVBQUUsQ0FBQztJQUN0RCxDQUFDO0lBRU8sV0FBVyxDQUFFLElBQVk7UUFDL0IsSUFBSyxDQUFDLElBQUksRUFBRztZQUNYLE9BQU8sU0FBUyxDQUFDO1NBQ2xCO1FBQ0QsTUFBTSxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFFLENBQUUsSUFBSSxDQUFFLEVBQUU7WUFDNUMsSUFBSSxFQUFFLFVBQVU7WUFDaEIsZUFBZSxFQUFFLFVBQVU7U0FDNUIsQ0FBRSxDQUFDO1FBQ0osT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFFLElBQUksQ0FBRSxDQUFDO0lBQ3pCLENBQUM7dUdBekNVLDhCQUE4QjsyRkFBOUIsOEJBQThCLDZNQ1IzQyw2eUJBaUJBOzsyRkRUYSw4QkFBOEI7a0JBTDFDLFNBQVM7K0JBQ0UseUJBQXlCOzhCQU1uQyxTQUFTO3NCQURSLEtBQUs7Z0JBSU4sZUFBZTtzQkFEZCxLQUFLO2dCQUlOLGVBQWU7c0JBRGQsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25DaGFuZ2VzLCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU3RhbmRhcmRMb2NhbGUgfSBmcm9tICcuLi9tb2RlbHMvbGFuZ3VhZ2UubW9kZWxzJztcclxuXHJcbkBDb21wb25lbnQoIHtcclxuICBzZWxlY3RvcjogJ2VjYWJzLWxhbmd1YWdlLXNlbGVjdG9yJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZWNhYnMtbGFuZ3VhZ2Utc2VsZWN0b3IuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWyAnLi9lY2Ficy1sYW5ndWFnZS1zZWxlY3Rvci5jb21wb25lbnQuc2NzcycgXSxcclxufSApXHJcbmV4cG9ydCBjbGFzcyBFY2Fic0xhbmd1YWdlU2VsZWN0b3JDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xyXG4gIEBJbnB1dCgpXHJcbiAgbGFuZ3VhZ2VzOiBTdGFuZGFyZExvY2FsZVtdID0gW107XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgY3VycmVudExhbmd1YWdlOiBzdHJpbmc7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIGxhbmd1YWdlQ2hhbmdlZDogRXZlbnRFbWl0dGVyPFN0YW5kYXJkTG9jYWxlPiA9IG5ldyBFdmVudEVtaXR0ZXI8U3RhbmRhcmRMb2NhbGU+KCk7XHJcblxyXG4gIHNlbGVjdGVkTGFuZzogc3RyaW5nO1xyXG5cclxuICBuZ09uQ2hhbmdlcygpOiB2b2lkIHtcclxuICAgIHRoaXMuc2VsZWN0ZWRMYW5nID0gdGhpcy5jdXJyZW50TGFuZ3VhZ2U7XHJcbiAgfVxyXG5cclxuICB0b2dnbGVMYW5nKCk6IHZvaWQge1xyXG4gICAgcmV0dXJuIHRoaXMubWF0Y2hTZWxlY3RlZCgpID8gdGhpcy5sYW5ndWFnZUNoYW5nZWQuZW1pdCggdGhpcy5tYXRjaFNlbGVjdGVkKCkgKSA6IHVuZGVmaW5lZDtcclxuICB9XHJcblxyXG4gIG1hdGNoU2VsZWN0ZWQoKTogU3RhbmRhcmRMb2NhbGUge1xyXG4gICAgcmV0dXJuIHRoaXMubGFuZ3VhZ2VzPy5maW5kKCAoIGxhbmcgKSA9PiBsYW5nLmlzb19jb2RlID09PSB0aGlzLnNlbGVjdGVkTGFuZyApO1xyXG4gIH1cclxuXHJcbiAgc3RhbmRhcmRMYW5nKCBjb2RlOiBzdHJpbmcgKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLnN0YW5kYXJkaXNlKCBjb2RlICk7XHJcbiAgfVxyXG5cclxuICBmbGFnQ2xhc3MoIGxhbmc6IHN0cmluZyApOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIGBmaSBmaS0keyBsYW5nPy5zbGljZSggLTIgKS50b0xvd2VyQ2FzZSgpIH1gO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBzdGFuZGFyZGlzZSggY29kZTogc3RyaW5nICk6IHN0cmluZyB7XHJcbiAgICBpZiAoICFjb2RlICkge1xyXG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xyXG4gICAgfVxyXG4gICAgY29uc3QgbGFuZyA9IG5ldyBJbnRsLkRpc3BsYXlOYW1lcyggWyBjb2RlIF0sIHtcclxuICAgICAgdHlwZTogJ2xhbmd1YWdlJyxcclxuICAgICAgbGFuZ3VhZ2VEaXNwbGF5OiAnc3RhbmRhcmQnLFxyXG4gICAgfSApO1xyXG4gICAgcmV0dXJuIGxhbmcub2YoIGNvZGUgKTtcclxuICB9XHJcbn1cclxuIiwiPG1hdC1mb3JtLWZpZWxkPlxyXG5cdDxtYXQtc2VsZWN0IGNsYXNzPVwiY2FwaXRhbGl6ZVwiIFsobmdNb2RlbCldPVwic2VsZWN0ZWRMYW5nXCIgbmFtZT1cImxhbmd1YWdlXCIgKG5nTW9kZWxDaGFuZ2UpPVwidG9nZ2xlTGFuZygpXCJcclxuXHRcdFx0XHRcdFx0XHRwYW5lbENsYXNzPVwid2lkZS1zZWxlY3RcIj5cclxuXHRcdDxtYXQtc2VsZWN0LXRyaWdnZXI+XHJcblx0XHRcdDxkaXYgY2xhc3M9XCJmbGV4IGl0ZW1zLWNlbnRlclwiPlxyXG5cdFx0XHRcdDxzcGFuIFtuZ0NsYXNzXT1cImZsYWdDbGFzcyhtYXRjaFNlbGVjdGVkKCk/Lmlzb19jb2RlKVwiPjwvc3Bhbj5cclxuXHRcdFx0XHQ8ZGl2IGNsYXNzPVwibWwtMlwiPnt7c3RhbmRhcmRMYW5nKG1hdGNoU2VsZWN0ZWQoKT8uaXNvX2NvZGUpfX08L2Rpdj5cclxuXHRcdFx0PC9kaXY+XHJcblx0XHQ8L21hdC1zZWxlY3QtdHJpZ2dlcj5cclxuXHRcdDxtYXQtb3B0aW9uIGNsYXNzPVwiY2FwaXRhbGl6ZVwiICpuZ0Zvcj1cImxldCBsYW5nIG9mIGxhbmd1YWdlc1wiIFt2YWx1ZV09XCJsYW5nLmlzb19jb2RlXCI+XHJcblx0XHRcdDxkaXYgY2xhc3M9XCJmbGV4IGl0ZW1zLWNlbnRlclwiPlxyXG5cdFx0XHRcdDxzcGFuIFtuZ0NsYXNzXT1cImZsYWdDbGFzcyhsYW5nPy5pc29fY29kZSlcIj48L3NwYW4+XHJcblx0XHRcdFx0PGRpdiBjbGFzcz1cIm1sLTJcIj57e3N0YW5kYXJkTGFuZyhsYW5nPy5pc29fY29kZSl9fTwvZGl2PlxyXG5cdFx0XHQ8L2Rpdj5cclxuXHRcdDwvbWF0LW9wdGlvbj5cclxuXHQ8L21hdC1zZWxlY3Q+XHJcbjwvbWF0LWZvcm0tZmllbGQ+XHJcbiJdfQ==
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { EcabsLanguageSelectorComponent } from './ecabs-language-selector.component';
|
|
4
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
5
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
6
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class EcabsLanguageSelectorModule {
|
|
9
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsLanguageSelectorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.1", ngImport: i0, type: EcabsLanguageSelectorModule, declarations: [EcabsLanguageSelectorComponent], imports: [CommonModule,
|
|
11
|
+
MatSelectModule,
|
|
12
|
+
MatFormFieldModule,
|
|
13
|
+
FormsModule,
|
|
14
|
+
ReactiveFormsModule], exports: [EcabsLanguageSelectorComponent] });
|
|
15
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsLanguageSelectorModule, imports: [CommonModule,
|
|
16
|
+
MatSelectModule,
|
|
17
|
+
MatFormFieldModule,
|
|
18
|
+
FormsModule,
|
|
19
|
+
ReactiveFormsModule] });
|
|
20
|
+
}
|
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsLanguageSelectorModule, decorators: [{
|
|
22
|
+
type: NgModule,
|
|
23
|
+
args: [{
|
|
24
|
+
declarations: [EcabsLanguageSelectorComponent],
|
|
25
|
+
imports: [
|
|
26
|
+
CommonModule,
|
|
27
|
+
MatSelectModule,
|
|
28
|
+
MatFormFieldModule,
|
|
29
|
+
FormsModule,
|
|
30
|
+
ReactiveFormsModule
|
|
31
|
+
],
|
|
32
|
+
exports: [EcabsLanguageSelectorComponent],
|
|
33
|
+
}]
|
|
34
|
+
}] });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtbGFuZ3VhZ2Utc2VsZWN0b3IubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLWxhbmd1YWdlLXNlbGVjdG9yL2VjYWJzLWxhbmd1YWdlLXNlbGVjdG9yLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNyRixPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDOztBQWFsRSxNQUFNLE9BQU8sMkJBQTJCO3VHQUEzQiwyQkFBMkI7d0dBQTNCLDJCQUEyQixpQkFWdEIsOEJBQThCLGFBRTVDLFlBQVk7WUFDWixlQUFlO1lBQ2Ysa0JBQWtCO1lBQ2xCLFdBQVc7WUFDWCxtQkFBbUIsYUFFViw4QkFBOEI7d0dBRTlCLDJCQUEyQixZQVJwQyxZQUFZO1lBQ1osZUFBZTtZQUNmLGtCQUFrQjtZQUNsQixXQUFXO1lBQ1gsbUJBQW1COzsyRkFJViwyQkFBMkI7a0JBWHZDLFFBQVE7bUJBQUU7b0JBQ1QsWUFBWSxFQUFFLENBQUUsOEJBQThCLENBQUU7b0JBQ2hELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGVBQWU7d0JBQ2Ysa0JBQWtCO3dCQUNsQixXQUFXO3dCQUNYLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFLENBQUUsOEJBQThCLENBQUU7aUJBQzVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRWNhYnNMYW5ndWFnZVNlbGVjdG9yQ29tcG9uZW50IH0gZnJvbSAnLi9lY2Ficy1sYW5ndWFnZS1zZWxlY3Rvci5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTWF0U2VsZWN0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2VsZWN0JztcclxuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XHJcblxyXG5ATmdNb2R1bGUoIHtcclxuICBkZWNsYXJhdGlvbnM6IFsgRWNhYnNMYW5ndWFnZVNlbGVjdG9yQ29tcG9uZW50IF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgTWF0U2VsZWN0TW9kdWxlLFxyXG4gICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbIEVjYWJzTGFuZ3VhZ2VTZWxlY3RvckNvbXBvbmVudCBdLFxyXG59IClcclxuZXhwb3J0IGNsYXNzIEVjYWJzTGFuZ3VhZ2VTZWxlY3Rvck1vZHVsZSB7IH1cclxuIl19
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "./spinner/spinner.component";
|
|
5
|
+
export class EcabsLoadingComponent {
|
|
6
|
+
loading = false;
|
|
7
|
+
backgroundColor = 'white';
|
|
8
|
+
size = 'medium';
|
|
9
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsLoadingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
10
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.1", type: EcabsLoadingComponent, selector: "ecabs-loading", inputs: { loading: "loading", backgroundColor: "backgroundColor", size: "size" }, ngImport: i0, template: "<div\r\n class=\"flex absolute left-0 top-0 right-0 bottom-0 z-50 items-center justify-center\"\r\n [ngStyle]=\"{ backgroundColor: backgroundColor }\"\r\n *ngIf=\"loading\"\r\n>\r\n <ecabs-loading-spinner [size]=\"size\" *ngIf=\"loading\"></ecabs-loading-spinner>\r\n</div>\r\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.EcabsSpinnerComponent, selector: "ecabs-loading-spinner", inputs: ["size"] }] });
|
|
11
|
+
}
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsLoadingComponent, decorators: [{
|
|
13
|
+
type: Component,
|
|
14
|
+
args: [{ selector: 'ecabs-loading', template: "<div\r\n class=\"flex absolute left-0 top-0 right-0 bottom-0 z-50 items-center justify-center\"\r\n [ngStyle]=\"{ backgroundColor: backgroundColor }\"\r\n *ngIf=\"loading\"\r\n>\r\n <ecabs-loading-spinner [size]=\"size\" *ngIf=\"loading\"></ecabs-loading-spinner>\r\n</div>\r\n" }]
|
|
15
|
+
}], propDecorators: { loading: [{
|
|
16
|
+
type: Input
|
|
17
|
+
}], backgroundColor: [{
|
|
18
|
+
type: Input
|
|
19
|
+
}], size: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}] } });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtbG9hZGluZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvZWNhYnMtbG9hZGluZy9lY2Ficy1sb2FkaW5nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1sb2FkaW5nL2VjYWJzLWxvYWRpbmcuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFNakQsTUFBTSxPQUFPLHFCQUFxQjtJQUN2QixPQUFPLEdBQUcsS0FBSyxDQUFDO0lBQ2hCLGVBQWUsR0FBRyxPQUFPLENBQUM7SUFDMUIsSUFBSSxHQUFnQyxRQUFRLENBQUM7dUdBSDNDLHFCQUFxQjsyRkFBckIscUJBQXFCLHVJQ05sQywyUkFPQTs7MkZERGEscUJBQXFCO2tCQUpqQyxTQUFTOytCQUNFLGVBQWU7OEJBSWhCLE9BQU87c0JBQWYsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoIHtcclxuICBzZWxlY3RvcjogJ2VjYWJzLWxvYWRpbmcnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9lY2Ficy1sb2FkaW5nLmNvbXBvbmVudC5odG1sJyxcclxufSApXHJcbmV4cG9ydCBjbGFzcyBFY2Fic0xvYWRpbmdDb21wb25lbnQge1xyXG4gIEBJbnB1dCgpIGxvYWRpbmcgPSBmYWxzZTtcclxuICBASW5wdXQoKSBiYWNrZ3JvdW5kQ29sb3IgPSAnd2hpdGUnO1xyXG4gIEBJbnB1dCgpIHNpemU6ICdsYXJnZScgfCAnbWVkaXVtJyB8ICd0aW55JyA9ICdtZWRpdW0nO1xyXG59XHJcbiIsIjxkaXZcclxuICBjbGFzcz1cImZsZXggYWJzb2x1dGUgbGVmdC0wIHRvcC0wIHJpZ2h0LTAgYm90dG9tLTAgei01MCBpdGVtcy1jZW50ZXIganVzdGlmeS1jZW50ZXJcIlxyXG4gIFtuZ1N0eWxlXT1cInsgYmFja2dyb3VuZENvbG9yOiBiYWNrZ3JvdW5kQ29sb3IgfVwiXHJcbiAgKm5nSWY9XCJsb2FkaW5nXCJcclxuPlxyXG4gIDxlY2Ficy1sb2FkaW5nLXNwaW5uZXIgW3NpemVdPVwic2l6ZVwiICpuZ0lmPVwibG9hZGluZ1wiPjwvZWNhYnMtbG9hZGluZy1zcGlubmVyPlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -4,11 +4,11 @@ import { EcabsLoadingComponent } from './ecabs-loading.component';
|
|
|
4
4
|
import { EcabsSpinnerComponent } from './spinner/spinner.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class EcabsLoadingModule {
|
|
7
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsLoadingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.1", ngImport: i0, type: EcabsLoadingModule, declarations: [EcabsLoadingComponent, EcabsSpinnerComponent], imports: [CommonModule], exports: [EcabsLoadingComponent, EcabsSpinnerComponent] });
|
|
9
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsLoadingModule, imports: [CommonModule] });
|
|
7
10
|
}
|
|
8
|
-
|
|
9
|
-
EcabsLoadingModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: EcabsLoadingModule, declarations: [EcabsLoadingComponent, EcabsSpinnerComponent], imports: [CommonModule], exports: [EcabsLoadingComponent, EcabsSpinnerComponent] });
|
|
10
|
-
EcabsLoadingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: EcabsLoadingModule, imports: [CommonModule] });
|
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: EcabsLoadingModule, decorators: [{
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsLoadingModule, decorators: [{
|
|
12
12
|
type: NgModule,
|
|
13
13
|
args: [{
|
|
14
14
|
declarations: [EcabsLoadingComponent, EcabsSpinnerComponent],
|
|
@@ -16,4 +16,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
16
16
|
exports: [EcabsLoadingComponent, EcabsSpinnerComponent],
|
|
17
17
|
}]
|
|
18
18
|
}] });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtbG9hZGluZy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvZWNhYnMtbG9hZGluZy9lY2Ficy1sb2FkaW5nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNsRSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7QUFPcEUsTUFBTSxPQUFPLGtCQUFrQjt1R0FBbEIsa0JBQWtCO3dHQUFsQixrQkFBa0IsaUJBSmQscUJBQXFCLEVBQUUscUJBQXFCLGFBQ2pELFlBQVksYUFDWixxQkFBcUIsRUFBRSxxQkFBcUI7d0dBRTNDLGtCQUFrQixZQUhuQixZQUFZOzsyRkFHWCxrQkFBa0I7a0JBTDlCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMscUJBQXFCLEVBQUUscUJBQXFCLENBQUM7b0JBQzVELE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsT0FBTyxFQUFFLENBQUMscUJBQXFCLEVBQUUscUJBQXFCLENBQUM7aUJBQ3hEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRWNhYnNMb2FkaW5nQ29tcG9uZW50IH0gZnJvbSAnLi9lY2Ficy1sb2FkaW5nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEVjYWJzU3Bpbm5lckNvbXBvbmVudCB9IGZyb20gJy4vc3Bpbm5lci9zcGlubmVyLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW0VjYWJzTG9hZGluZ0NvbXBvbmVudCwgRWNhYnNTcGlubmVyQ29tcG9uZW50XSxcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcclxuICBleHBvcnRzOiBbRWNhYnNMb2FkaW5nQ29tcG9uZW50LCBFY2Fic1NwaW5uZXJDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgRWNhYnNMb2FkaW5nTW9kdWxlIHt9XHJcbiJdfQ==
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class EcabsSpinnerComponent {
|
|
4
|
+
size = 'medium';
|
|
5
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsSpinnerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.1", type: EcabsSpinnerComponent, selector: "ecabs-loading-spinner", inputs: { size: "size" }, ngImport: i0, template: "<div class=\"loadingio-spinner-rolling {{ size }}\">\r\n <div class=\"ldio-inner\">\r\n <div></div>\r\n </div>\r\n</div>\r\n", styles: [":host{line-height:0}@keyframes ldio-inner{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.loadingio-spinner-rolling{width:27px;height:27px;display:inline-block;overflow:hidden;background:none}.loadingio-spinner-rolling .ldio-inner{width:100%;height:100%;position:relative;transform:translateZ(0) scale(1);-webkit-backface-visibility:hidden;backface-visibility:hidden;transform-origin:0 0}.loadingio-spinner-rolling .ldio-inner div{position:absolute;width:9px;height:9px;border:4px solid #85a2b6;border-top-color:transparent;border-radius:50%;animation:ldio-inner 1s linear infinite;top:14px;left:14px;box-sizing:content-box}.loadingio-spinner-rolling.medium{width:40px;height:40px}.loadingio-spinner-rolling.medium .ldio-inner div{width:20px;height:20px;border-width:6px;top:19px;left:19px}.loadingio-spinner-rolling.large{width:60px;height:60px}.loadingio-spinner-rolling.large .ldio-inner div{width:35px;height:35px;border-width:9px;top:29px;left:29px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
7
|
+
}
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsSpinnerComponent, decorators: [{
|
|
9
|
+
type: Component,
|
|
10
|
+
args: [{ selector: 'ecabs-loading-spinner', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"loadingio-spinner-rolling {{ size }}\">\r\n <div class=\"ldio-inner\">\r\n <div></div>\r\n </div>\r\n</div>\r\n", styles: [":host{line-height:0}@keyframes ldio-inner{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}.loadingio-spinner-rolling{width:27px;height:27px;display:inline-block;overflow:hidden;background:none}.loadingio-spinner-rolling .ldio-inner{width:100%;height:100%;position:relative;transform:translateZ(0) scale(1);-webkit-backface-visibility:hidden;backface-visibility:hidden;transform-origin:0 0}.loadingio-spinner-rolling .ldio-inner div{position:absolute;width:9px;height:9px;border:4px solid #85a2b6;border-top-color:transparent;border-radius:50%;animation:ldio-inner 1s linear infinite;top:14px;left:14px;box-sizing:content-box}.loadingio-spinner-rolling.medium{width:40px;height:40px}.loadingio-spinner-rolling.medium .ldio-inner div{width:20px;height:20px;border-width:6px;top:19px;left:19px}.loadingio-spinner-rolling.large{width:60px;height:60px}.loadingio-spinner-rolling.large .ldio-inner div{width:35px;height:35px;border-width:9px;top:29px;left:29px}\n"] }]
|
|
11
|
+
}], propDecorators: { size: [{
|
|
12
|
+
type: Input
|
|
13
|
+
}] } });
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Bpbm5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvZWNhYnMtbG9hZGluZy9zcGlubmVyL3NwaW5uZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLWxvYWRpbmcvc3Bpbm5lci9zcGlubmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVExRSxNQUFNLE9BQU8scUJBQXFCO0lBQ3ZCLElBQUksR0FBZ0MsUUFBUSxDQUFDO3VHQUQzQyxxQkFBcUI7MkZBQXJCLHFCQUFxQix1RkNSbEMsbUlBS0E7OzJGREdhLHFCQUFxQjtrQkFOakMsU0FBUzsrQkFDRSx1QkFBdUIsbUJBR2hCLHVCQUF1QixDQUFDLE1BQU07OEJBR3RDLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2VjYWJzLWxvYWRpbmctc3Bpbm5lcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3NwaW5uZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3NwaW5uZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxufSlcclxuZXhwb3J0IGNsYXNzIEVjYWJzU3Bpbm5lckNvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgc2l6ZTogJ2xhcmdlJyB8ICdtZWRpdW0nIHwgJ3RpbnknID0gJ21lZGl1bSc7XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImxvYWRpbmdpby1zcGlubmVyLXJvbGxpbmcge3sgc2l6ZSB9fVwiPlxyXG4gIDxkaXYgY2xhc3M9XCJsZGlvLWlubmVyXCI+XHJcbiAgICA8ZGl2PjwvZGl2PlxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@angular/material/icon";
|
|
5
|
+
export class NoteComponent {
|
|
6
|
+
type = 'default';
|
|
7
|
+
get classByType() {
|
|
8
|
+
switch (this.type) {
|
|
9
|
+
case 'warn':
|
|
10
|
+
return 'note--warn';
|
|
11
|
+
case 'danger':
|
|
12
|
+
return 'note--danger';
|
|
13
|
+
case 'success':
|
|
14
|
+
return 'note--success';
|
|
15
|
+
default:
|
|
16
|
+
return 'note--default';
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: NoteComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
20
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.1", type: NoteComponent, selector: "ecabs-note", inputs: { type: "type" }, ngImport: i0, template: "<ng-container>\r\n <div class=\"flex flex-row px-2 py-4 note\" [ngClass]=\"classByType\">\r\n <div>\r\n <mat-icon>info_outline</mat-icon>\r\n </div>\r\n <div class=\"ml-4\">\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [":root{--color-black: #07080d;--color-white: #ffffff;--color-white-opacity-05: rgba(0, 0, 0, .05);--color-gray-100: #f5f6f9;--color-gray-200: #f8f9f9;--color-gray-300: #d9d9d9;--color-gray-400: #a6a6a6;--color-gray-500: #6b6d73;--color-brand-dark: #193273;--color-brand-dark-rgb: 25, 50, 115;--color-brand-light: #325FDA;--color-brand-light2: #e7efff;--color-brand-light-rgb: 50, 95, 218;--color-brand-300: #e7efff;--color-brand-300-rgb: 231, 239, 255;--color-error: #df3838;--color-error-opacity: #fbe4e4;--color-error-rgb: 223, 56, 56;--color-notification: #f4d04f;--color-notification-rgb: 244, 208, 79;--color-warn: #f2994a;--color-warn-rgb: 242, 153, 74;--color-info: #325fda;--color-info-rgb: 50, 95, 218;--color-warning: #f2994a;--color-warning-opacity: #fdf0e4;--color-success: #25bd3d;--color-success--opacity: #e8f8e5;--color-success-rgb: 37, 189, 61;--color-allocation-started: #E8F8E5;--color-allocation-scheduled: #FDF0E4;--color-allocation-ended: #FBE4E4;--color-allocation-sick: #E7EFFF;--color-allocation-no-show: #EAE5FF;--color-allocation-unavailable: #F2F2F2;--cropper-outline-color: rgba(0, 0, 0, .5)}.note{border-radius:.25rem}.note .mat-icon{color:inherit}.note--danger{color:var(--color-error);background-color:var(--color-error-opacity)}.note--warn{background-color:var(--color-warning-opacity);color:var(--color-warn)}.note--success{background-color:rgba(var(--color-success-rgb),.06);color:var(--color-success)}.note--default{background-color:rgba(var(--color-info-rgb),.06);color:var(--color-info)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] });
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: NoteComponent, decorators: [{
|
|
23
|
+
type: Component,
|
|
24
|
+
args: [{ selector: 'ecabs-note', template: "<ng-container>\r\n <div class=\"flex flex-row px-2 py-4 note\" [ngClass]=\"classByType\">\r\n <div>\r\n <mat-icon>info_outline</mat-icon>\r\n </div>\r\n <div class=\"ml-4\">\r\n <ng-content></ng-content>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [":root{--color-black: #07080d;--color-white: #ffffff;--color-white-opacity-05: rgba(0, 0, 0, .05);--color-gray-100: #f5f6f9;--color-gray-200: #f8f9f9;--color-gray-300: #d9d9d9;--color-gray-400: #a6a6a6;--color-gray-500: #6b6d73;--color-brand-dark: #193273;--color-brand-dark-rgb: 25, 50, 115;--color-brand-light: #325FDA;--color-brand-light2: #e7efff;--color-brand-light-rgb: 50, 95, 218;--color-brand-300: #e7efff;--color-brand-300-rgb: 231, 239, 255;--color-error: #df3838;--color-error-opacity: #fbe4e4;--color-error-rgb: 223, 56, 56;--color-notification: #f4d04f;--color-notification-rgb: 244, 208, 79;--color-warn: #f2994a;--color-warn-rgb: 242, 153, 74;--color-info: #325fda;--color-info-rgb: 50, 95, 218;--color-warning: #f2994a;--color-warning-opacity: #fdf0e4;--color-success: #25bd3d;--color-success--opacity: #e8f8e5;--color-success-rgb: 37, 189, 61;--color-allocation-started: #E8F8E5;--color-allocation-scheduled: #FDF0E4;--color-allocation-ended: #FBE4E4;--color-allocation-sick: #E7EFFF;--color-allocation-no-show: #EAE5FF;--color-allocation-unavailable: #F2F2F2;--cropper-outline-color: rgba(0, 0, 0, .5)}.note{border-radius:.25rem}.note .mat-icon{color:inherit}.note--danger{color:var(--color-error);background-color:var(--color-error-opacity)}.note--warn{background-color:var(--color-warning-opacity);color:var(--color-warn)}.note--success{background-color:rgba(var(--color-success-rgb),.06);color:var(--color-success)}.note--default{background-color:rgba(var(--color-info-rgb),.06);color:var(--color-info)}\n"] }]
|
|
25
|
+
}], propDecorators: { type: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}] } });
|
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtbm90ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvZWNhYnMtbm90ZS9lY2Ficy1ub3RlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VjYWJzLWNvbXBvbmVudHMvc3JjL2xpYi9lY2Ficy1ub3RlL2VjYWJzLW5vdGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFPakQsTUFBTSxPQUFPLGFBQWE7SUFFeEIsSUFBSSxHQUE4QyxTQUFTLENBQUM7SUFFNUQsSUFBSSxXQUFXO1FBQ2IsUUFBUyxJQUFJLENBQUMsSUFBSSxFQUFHO1lBQ25CLEtBQUssTUFBTTtnQkFDVCxPQUFPLFlBQVksQ0FBQztZQUV0QixLQUFLLFFBQVE7Z0JBQ1gsT0FBTyxjQUFjLENBQUM7WUFFeEIsS0FBSyxTQUFTO2dCQUNaLE9BQU8sZUFBZSxDQUFDO1lBRXpCO2dCQUNFLE9BQU8sZUFBZSxDQUFDO1NBQzFCO0lBQ0gsQ0FBQzt1R0FsQlUsYUFBYTsyRkFBYixhQUFhLDRFQ1AxQixrUkFVQTs7MkZESGEsYUFBYTtrQkFMekIsU0FBUzsrQkFDRSxZQUFZOzhCQU10QixJQUFJO3NCQURILEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KCB7XHJcbiAgc2VsZWN0b3I6ICdlY2Ficy1ub3RlJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZWNhYnMtbm90ZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbICcuL2VjYWJzLW5vdGUuY29tcG9uZW50LnNjc3MnIF0sXHJcbn0gKVxyXG5leHBvcnQgY2xhc3MgTm90ZUNvbXBvbmVudCB7XHJcbiAgQElucHV0KClcclxuICB0eXBlOiAnZGVmYXVsdCcgfCAnZGFuZ2VyJyB8ICd3YXJuJyB8ICdzdWNjZXNzJyA9ICdkZWZhdWx0JztcclxuXHJcbiAgZ2V0IGNsYXNzQnlUeXBlKCk6IHN0cmluZyB7XHJcbiAgICBzd2l0Y2ggKCB0aGlzLnR5cGUgKSB7XHJcbiAgICAgIGNhc2UgJ3dhcm4nOlxyXG4gICAgICAgIHJldHVybiAnbm90ZS0td2Fybic7XHJcblxyXG4gICAgICBjYXNlICdkYW5nZXInOlxyXG4gICAgICAgIHJldHVybiAnbm90ZS0tZGFuZ2VyJztcclxuXHJcbiAgICAgIGNhc2UgJ3N1Y2Nlc3MnOlxyXG4gICAgICAgIHJldHVybiAnbm90ZS0tc3VjY2Vzcyc7XHJcblxyXG4gICAgICBkZWZhdWx0OlxyXG4gICAgICAgIHJldHVybiAnbm90ZS0tZGVmYXVsdCc7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiIsIjxuZy1jb250YWluZXI+XHJcbiAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1yb3cgcHgtMiBweS00IG5vdGVcIiBbbmdDbGFzc109XCJjbGFzc0J5VHlwZVwiPlxyXG4gICAgPGRpdj5cclxuICAgICAgPG1hdC1pY29uPmluZm9fb3V0bGluZTwvbWF0LWljb24+XHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJtbC00XCI+XHJcbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuICAgIDwvZGl2PlxyXG4gIDwvZGl2PlxyXG48L25nLWNvbnRhaW5lcj5cclxuIl19
|
|
@@ -4,11 +4,11 @@ import { MatIconModule } from '@angular/material/icon';
|
|
|
4
4
|
import { NoteComponent } from './ecabs-note.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class NoteModule {
|
|
7
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: NoteModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.1", ngImport: i0, type: NoteModule, declarations: [NoteComponent], imports: [CommonModule, MatIconModule], exports: [NoteComponent] });
|
|
9
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: NoteModule, imports: [CommonModule, MatIconModule] });
|
|
7
10
|
}
|
|
8
|
-
|
|
9
|
-
NoteModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: NoteModule, declarations: [NoteComponent], imports: [CommonModule, MatIconModule], exports: [NoteComponent] });
|
|
10
|
-
NoteModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NoteModule, imports: [CommonModule, MatIconModule] });
|
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: NoteModule, decorators: [{
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: NoteModule, decorators: [{
|
|
12
12
|
type: NgModule,
|
|
13
13
|
args: [{
|
|
14
14
|
declarations: [NoteComponent],
|
|
@@ -16,4 +16,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
16
16
|
exports: [NoteComponent],
|
|
17
17
|
}]
|
|
18
18
|
}] });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtbm90ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lY2Ficy1jb21wb25lbnRzL3NyYy9saWIvZWNhYnMtbm90ZS9lY2Ficy1ub3RlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU92RCxNQUFNLE9BQU8sVUFBVTt1R0FBVixVQUFVO3dHQUFWLFVBQVUsaUJBSkwsYUFBYSxhQUNsQixZQUFZLEVBQUUsYUFBYSxhQUMzQixhQUFhO3dHQUViLFVBQVUsWUFIVixZQUFZLEVBQUUsYUFBYTs7MkZBRzNCLFVBQVU7a0JBTHRCLFFBQVE7bUJBQUU7b0JBQ1QsWUFBWSxFQUFFLENBQUUsYUFBYSxDQUFFO29CQUMvQixPQUFPLEVBQUUsQ0FBRSxZQUFZLEVBQUUsYUFBYSxDQUFFO29CQUN4QyxPQUFPLEVBQUUsQ0FBRSxhQUFhLENBQUU7aUJBQzNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBOb3RlQ29tcG9uZW50IH0gZnJvbSAnLi9lY2Ficy1ub3RlLmNvbXBvbmVudCc7XHJcblxyXG5ATmdNb2R1bGUoIHtcclxuICBkZWNsYXJhdGlvbnM6IFsgTm90ZUNvbXBvbmVudCBdLFxyXG4gIGltcG9ydHM6IFsgQ29tbW9uTW9kdWxlLCBNYXRJY29uTW9kdWxlIF0sXHJcbiAgZXhwb3J0czogWyBOb3RlQ29tcG9uZW50IF0sXHJcbn0gKVxyXG5leHBvcnQgY2xhc3MgTm90ZU1vZHVsZSB7IH1cclxuIl19
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { Component, HostListener, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { UntypedFormControl, UntypedFormGroup, NG_VALUE_ACCESSOR, Validators, NgControl, } from '@angular/forms';
|
|
3
|
+
import ElementBaseComponent from '../base/element-base';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "../base/element-wrapper/element-wrapper.component";
|
|
7
|
+
import * as i3 from "@angular/forms";
|
|
8
|
+
import * as i4 from "ngx-mat-intl-tel-input";
|
|
9
|
+
export class EcabsPhoneComponent extends ElementBaseComponent {
|
|
10
|
+
injector;
|
|
11
|
+
preferredCountries;
|
|
12
|
+
enablePlaceholder;
|
|
13
|
+
enableSearch = true;
|
|
14
|
+
useOnlyDisabledClass = false;
|
|
15
|
+
required;
|
|
16
|
+
phoneInput;
|
|
17
|
+
phoneForm;
|
|
18
|
+
phoneSub;
|
|
19
|
+
prohibitedCharacters = ['-'];
|
|
20
|
+
get value() {
|
|
21
|
+
return this.phoneForm.get('phone')?.value;
|
|
22
|
+
}
|
|
23
|
+
set value(val) {
|
|
24
|
+
if (val !== undefined && this.value !== val) {
|
|
25
|
+
this.phoneForm.setValue({ phone: val });
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
constructor(injector) {
|
|
29
|
+
super();
|
|
30
|
+
this.injector = injector;
|
|
31
|
+
}
|
|
32
|
+
onInput(event) {
|
|
33
|
+
if (this.prohibitedCharacters.includes(event.key)) {
|
|
34
|
+
event.preventDefault();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
ngOnInit() {
|
|
38
|
+
this.phoneForm = new UntypedFormGroup({
|
|
39
|
+
phone: new UntypedFormControl(undefined, this.required ? [Validators.required] : []),
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
ngAfterViewInit() {
|
|
43
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
44
|
+
if (ngControl) {
|
|
45
|
+
this.control = ngControl.control;
|
|
46
|
+
}
|
|
47
|
+
this.phoneSub = this.phoneForm.valueChanges.subscribe((formVal) => {
|
|
48
|
+
this.value = formVal?.phone;
|
|
49
|
+
this.onChange(this.value);
|
|
50
|
+
this.onTouch(this.value);
|
|
51
|
+
this.control.setErrors(this.phoneForm.get('phone').errors);
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
onChange = () => { };
|
|
55
|
+
onTouch = () => { };
|
|
56
|
+
writeValue(value) {
|
|
57
|
+
this.value = value;
|
|
58
|
+
}
|
|
59
|
+
registerOnChange(fn) {
|
|
60
|
+
this.onChange = fn;
|
|
61
|
+
}
|
|
62
|
+
registerOnTouched(fn) {
|
|
63
|
+
this.onTouch = fn;
|
|
64
|
+
}
|
|
65
|
+
ngOnDestroy() {
|
|
66
|
+
this.phoneSub?.unsubscribe();
|
|
67
|
+
}
|
|
68
|
+
reset() {
|
|
69
|
+
this.phoneInput.reset();
|
|
70
|
+
}
|
|
71
|
+
onBlur() {
|
|
72
|
+
this.control.setErrors(this.phoneForm.get('phone').errors);
|
|
73
|
+
this.onTouch(this.value);
|
|
74
|
+
this.onChange(this.value);
|
|
75
|
+
}
|
|
76
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsPhoneComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
77
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.1", type: EcabsPhoneComponent, selector: "ecabs-phone", inputs: { preferredCountries: "preferredCountries", enablePlaceholder: "enablePlaceholder", enableSearch: "enableSearch", useOnlyDisabledClass: "useOnlyDisabledClass", required: "required" }, host: { listeners: { "keypress": "onInput($event)" } }, providers: [
|
|
78
|
+
{
|
|
79
|
+
provide: NG_VALUE_ACCESSOR,
|
|
80
|
+
useExisting: EcabsPhoneComponent,
|
|
81
|
+
multi: true,
|
|
82
|
+
},
|
|
83
|
+
], viewQueries: [{ propertyName: "phoneInput", first: true, predicate: ["phoneInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<app-element-wrapper [data]=\"getData()\">\r\n <form #f=\"ngForm\" [formGroup]=\"phoneForm\">\r\n <ngx-mat-intl-tel-input\r\n (focusout)=\"onBlur()\"\r\n [ngClass]=\"{ error: phoneForm.invalid && (phoneForm.dirty || phoneForm.touched) }\"\r\n #phoneInput\r\n [preferredCountries]=\"preferredCountries\"\r\n [enablePlaceholder]=\"enablePlaceholder\"\r\n [enableSearch]=\"enableSearch\"\r\n [disabled]=\"disabled\"\r\n [formControlName]=\"'phone'\"\r\n name=\"phone\"\r\n [inputPlaceholder]=\"placeholder\"\r\n >\r\n </ngx-mat-intl-tel-input>\r\n </form>\r\n</app-element-wrapper>\r\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.ElementWrapperComponent, selector: "app-element-wrapper", inputs: ["data", "showCloseIcon", "focusedFlag", "showPassword", "control"], outputs: ["showHidePassword", "clear", "increase", "decrease"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i4.NgxMatIntlTelInputComponent, selector: "ngx-mat-intl-tel-input", inputs: ["preferredCountries", "enablePlaceholder", "inputPlaceholder", "cssClass", "name", "onlyCountries", "errorStateMatcher", "enableSearch", "searchPlaceholder", "describedBy", "format", "placeholder", "required", "disabled"], outputs: ["countryChanged"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] });
|
|
84
|
+
}
|
|
85
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsPhoneComponent, decorators: [{
|
|
86
|
+
type: Component,
|
|
87
|
+
args: [{ selector: 'ecabs-phone', providers: [
|
|
88
|
+
{
|
|
89
|
+
provide: NG_VALUE_ACCESSOR,
|
|
90
|
+
useExisting: EcabsPhoneComponent,
|
|
91
|
+
multi: true,
|
|
92
|
+
},
|
|
93
|
+
], template: "<app-element-wrapper [data]=\"getData()\">\r\n <form #f=\"ngForm\" [formGroup]=\"phoneForm\">\r\n <ngx-mat-intl-tel-input\r\n (focusout)=\"onBlur()\"\r\n [ngClass]=\"{ error: phoneForm.invalid && (phoneForm.dirty || phoneForm.touched) }\"\r\n #phoneInput\r\n [preferredCountries]=\"preferredCountries\"\r\n [enablePlaceholder]=\"enablePlaceholder\"\r\n [enableSearch]=\"enableSearch\"\r\n [disabled]=\"disabled\"\r\n [formControlName]=\"'phone'\"\r\n name=\"phone\"\r\n [inputPlaceholder]=\"placeholder\"\r\n >\r\n </ngx-mat-intl-tel-input>\r\n </form>\r\n</app-element-wrapper>\r\n" }]
|
|
94
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { preferredCountries: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], enablePlaceholder: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], enableSearch: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], useOnlyDisabledClass: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], required: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], phoneInput: [{
|
|
105
|
+
type: ViewChild,
|
|
106
|
+
args: ['phoneInput']
|
|
107
|
+
}], onInput: [{
|
|
108
|
+
type: HostListener,
|
|
109
|
+
args: ['keypress', ['$event']]
|
|
110
|
+
}] } });
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecabs-phone.component.js","sourceRoot":"","sources":["../../../../../projects/ecabs-components/src/lib/ecabs-phone/ecabs-phone.component.ts","../../../../../projects/ecabs-components/src/lib/ecabs-phone/ecabs-phone.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,YAAY,EAAY,KAAK,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAC;AACtH,OAAO,EAEL,kBAAkB,EAClB,gBAAgB,EAChB,iBAAiB,EACjB,UAAU,EACV,SAAS,GACV,MAAM,gBAAgB,CAAC;AAExB,OAAO,oBAAoB,MAAM,sBAAsB,CAAC;;;;;;AAaxD,MAAM,OAAO,mBACX,SAAQ,oBAAoB;IAyBE;IAvBrB,kBAAkB,CAAY;IAC9B,iBAAiB,CAAW;IAC5B,YAAY,GAAY,IAAI,CAAC;IAC7B,oBAAoB,GAAG,KAAK,CAAC;IACrB,QAAQ,CAAU;IAGnC,UAAU,CAA+B;IAEzC,SAAS,CAAmB;IAC5B,QAAQ,CAAO;IACf,oBAAoB,GAAG,CAAE,GAAG,CAAE,CAAC;IAE/B,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAE,OAAO,CAAE,EAAE,KAAK,CAAC;IAC9C,CAAC;IAED,IAAI,KAAK,CAAE,GAAG;QACZ,IAAK,GAAG,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,KAAK,GAAG,EAAG;YAC7C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAE,EAAE,KAAK,EAAE,GAAG,EAAE,CAAE,CAAC;SAC3C;IACH,CAAC;IAED,YAA8B,QAAkB;QAC9C,KAAK,EAAE,CAAC;QADoB,aAAQ,GAAR,QAAQ,CAAU;IAEhD,CAAC;IAEyC,OAAO,CAAE,KAAoB;QACrE,IAAK,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAE,KAAK,CAAC,GAAG,CAAE,EAAG;YACrD,KAAK,CAAC,cAAc,EAAE,CAAC;SACxB;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,GAAG,IAAI,gBAAgB,CAAE;YACrC,KAAK,EAAE,IAAI,kBAAkB,CAAE,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAE,UAAU,CAAC,QAAQ,CAAE,CAAC,CAAC,CAAC,EAAE,CAAE;SACzF,CAAE,CAAC;IACN,CAAC;IAED,eAAe;QACb,MAAM,SAAS,GAAc,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAE,SAAS,EAAE,IAAI,CAAE,CAAC;QAClE,IAAK,SAAS,EAAG;YACf,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAA6B,CAAC;SACxD;QAED,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,SAAS,CAAE,CAAE,OAAO,EAAG,EAAE;YACnE,IAAI,CAAC,KAAK,GAAG,OAAO,EAAE,KAAK,CAAC;YAC5B,IAAI,CAAC,QAAQ,CAAE,IAAI,CAAC,KAAK,CAAE,CAAC;YAC5B,IAAI,CAAC,OAAO,CAAE,IAAI,CAAC,KAAK,CAAE,CAAC;YAC3B,IAAI,CAAC,OAAO,CAAC,SAAS,CAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAE,OAAO,CAAE,CAAC,MAAM,CAAE,CAAC;QACjE,CAAC,CAAE,CAAC;IACN,CAAC;IAED,QAAQ,GAAQ,GAAS,EAAE,GAAG,CAAC,CAAC;IAChC,OAAO,GAAQ,GAAS,EAAE,GAAG,CAAC,CAAC;IAE/B,UAAU,CAAE,KAAU;QACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAED,gBAAgB,CAAE,EAAO;QACvB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAE,EAAO;QACxB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,EAAE,WAAW,EAAE,CAAC;IAC/B,CAAC;IAED,KAAK;QACH,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;IAC1B,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,OAAO,CAAC,SAAS,CAAE,IAAI,CAAC,SAAS,CAAC,GAAG,CAAE,OAAO,CAAE,CAAC,MAAM,CAAE,CAAC;QAC/D,IAAI,CAAC,OAAO,CAAE,IAAI,CAAC,KAAK,CAAE,CAAC;QAC3B,IAAI,CAAC,QAAQ,CAAE,IAAI,CAAC,KAAK,CAAE,CAAC;IAC9B,CAAC;uGAnFU,mBAAmB;2FAAnB,mBAAmB,8RARnB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,mBAAmB;gBAChC,KAAK,EAAE,IAAI;aACZ;SACF,2JCrBH,+pBAiBA;;2FDMa,mBAAmB;kBAX/B,SAAS;+BACE,aAAa,aAEZ;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,qBAAqB;4BAChC,KAAK,EAAE,IAAI;yBACZ;qBACF;+FAKQ,kBAAkB;sBAA1B,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACW,QAAQ;sBAAxB,KAAK;gBAGN,UAAU;sBADT,SAAS;uBAAE,YAAY;gBAqBkB,OAAO;sBAAhD,YAAY;uBAAE,UAAU,EAAE,CAAE,QAAQ,CAAE","sourcesContent":["import { AfterViewInit, Component, HostListener, Injector, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  UntypedFormControl,\r\n  UntypedFormGroup,\r\n  NG_VALUE_ACCESSOR,\r\n  Validators,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { NgxMatIntlTelInputComponent } from 'ngx-mat-intl-tel-input';\r\nimport ElementBaseComponent from '../base/element-base';\r\n\r\n@Component( {\r\n  selector: 'ecabs-phone',\r\n  templateUrl: './ecabs-phone.component.html',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: EcabsPhoneComponent,\r\n      multi: true,\r\n    },\r\n  ],\r\n} )\r\nexport class EcabsPhoneComponent\r\n  extends ElementBaseComponent\r\n  implements ControlValueAccessor, AfterViewInit, OnDestroy, OnInit {\r\n  @Input() preferredCountries!: string[];\r\n  @Input() enablePlaceholder!: boolean;\r\n  @Input() enableSearch: boolean = true;\r\n  @Input() useOnlyDisabledClass = false;\r\n  @Input() declare required: boolean;\r\n\r\n  @ViewChild( 'phoneInput' )\r\n  phoneInput!: NgxMatIntlTelInputComponent;\r\n\r\n  phoneForm: UntypedFormGroup;\r\n  phoneSub!: any;\r\n  prohibitedCharacters = [ '-' ];\r\n\r\n  get value(): any {\r\n    return this.phoneForm.get( 'phone' )?.value;\r\n  }\r\n\r\n  set value( val ) {\r\n    if ( val !== undefined && this.value !== val ) {\r\n      this.phoneForm.setValue( { phone: val } );\r\n    }\r\n  }\r\n\r\n  constructor( private readonly injector: Injector ) {\r\n    super();\r\n  }\r\n\r\n  @HostListener( 'keypress', [ '$event' ] ) onInput( event: KeyboardEvent ): void {\r\n    if ( this.prohibitedCharacters.includes( event.key ) ) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.phoneForm = new UntypedFormGroup( {\r\n      phone: new UntypedFormControl( undefined, this.required ? [ Validators.required ] : [] ),\r\n    } );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    const ngControl: NgControl = this.injector.get( NgControl, null );\r\n    if ( ngControl ) {\r\n      this.control = ngControl.control as UntypedFormControl;\r\n    }\r\n\r\n    this.phoneSub = this.phoneForm.valueChanges.subscribe( ( formVal ) => {\r\n      this.value = formVal?.phone;\r\n      this.onChange( this.value );\r\n      this.onTouch( this.value );\r\n      this.control.setErrors( this.phoneForm.get( 'phone' ).errors );\r\n    } );\r\n  }\r\n\r\n  onChange: any = (): void => { };\r\n  onTouch: any = (): void => { };\r\n\r\n  writeValue( value: any ): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange( fn: any ): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched( fn: any ): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.phoneSub?.unsubscribe();\r\n  }\r\n\r\n  reset(): void {\r\n    this.phoneInput.reset();\r\n  }\r\n\r\n  onBlur(): void {\r\n    this.control.setErrors( this.phoneForm.get( 'phone' ).errors );\r\n    this.onTouch( this.value );\r\n    this.onChange( this.value );\r\n  }\r\n}\r\n","<app-element-wrapper [data]=\"getData()\">\r\n  <form #f=\"ngForm\" [formGroup]=\"phoneForm\">\r\n      <ngx-mat-intl-tel-input\r\n        (focusout)=\"onBlur()\"\r\n        [ngClass]=\"{ error: phoneForm.invalid && (phoneForm.dirty || phoneForm.touched) }\"\r\n        #phoneInput\r\n        [preferredCountries]=\"preferredCountries\"\r\n        [enablePlaceholder]=\"enablePlaceholder\"\r\n        [enableSearch]=\"enableSearch\"\r\n        [disabled]=\"disabled\"\r\n        [formControlName]=\"'phone'\"\r\n        name=\"phone\"\r\n        [inputPlaceholder]=\"placeholder\"\r\n      >\r\n      </ngx-mat-intl-tel-input>\r\n  </form>\r\n</app-element-wrapper>\r\n"]}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
3
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
-
import { MatInputModule } from '@angular/material/input';
|
|
5
4
|
import { NgxMatIntlTelInputComponent } from 'ngx-mat-intl-tel-input';
|
|
6
5
|
import { ElementWrapperModule } from '../base/element-wrapper/element-wrapper.module';
|
|
7
6
|
import { EcabsPhoneComponent } from './ecabs-phone.component';
|
|
7
|
+
import { MatInputModule } from '@angular/material/input';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
export class EcabsPhoneModule {
|
|
10
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsPhoneModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.1", ngImport: i0, type: EcabsPhoneModule, declarations: [EcabsPhoneComponent], imports: [CommonModule, MatInputModule, ElementWrapperModule, FormsModule, NgxMatIntlTelInputComponent, ReactiveFormsModule], exports: [EcabsPhoneComponent] });
|
|
12
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsPhoneModule, imports: [CommonModule, MatInputModule, ElementWrapperModule, FormsModule, NgxMatIntlTelInputComponent, ReactiveFormsModule] });
|
|
10
13
|
}
|
|
11
|
-
|
|
12
|
-
EcabsPhoneModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: EcabsPhoneModule, declarations: [EcabsPhoneComponent], imports: [CommonModule, MatInputModule, ElementWrapperModule, FormsModule, NgxMatIntlTelInputComponent, ReactiveFormsModule], exports: [EcabsPhoneComponent] });
|
|
13
|
-
EcabsPhoneModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: EcabsPhoneModule, imports: [CommonModule, MatInputModule, ElementWrapperModule, FormsModule, NgxMatIntlTelInputComponent, ReactiveFormsModule] });
|
|
14
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: EcabsPhoneModule, decorators: [{
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.1", ngImport: i0, type: EcabsPhoneModule, decorators: [{
|
|
15
15
|
type: NgModule,
|
|
16
16
|
args: [{
|
|
17
17
|
declarations: [EcabsPhoneComponent],
|
|
@@ -19,4 +19,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
19
19
|
exports: [EcabsPhoneComponent],
|
|
20
20
|
}]
|
|
21
21
|
}] });
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWNhYnMtcGhvbmUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWNhYnMtY29tcG9uZW50cy9zcmMvbGliL2VjYWJzLXBob25lL2VjYWJzLXBob25lLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFckUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDdEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQU96RCxNQUFNLE9BQU8sZ0JBQWdCO3VHQUFoQixnQkFBZ0I7d0dBQWhCLGdCQUFnQixpQkFKWCxtQkFBbUIsYUFDeEIsWUFBWSxFQUFFLGNBQWMsRUFBRSxvQkFBb0IsRUFBRSxXQUFXLEVBQUUsMkJBQTJCLEVBQUUsbUJBQW1CLGFBQ2pILG1CQUFtQjt3R0FFbkIsZ0JBQWdCLFlBSGhCLFlBQVksRUFBRSxjQUFjLEVBQUUsb0JBQW9CLEVBQUUsV0FBVyxFQUFFLDJCQUEyQixFQUFFLG1CQUFtQjs7MkZBR2pILGdCQUFnQjtrQkFMNUIsUUFBUTttQkFBRTtvQkFDVCxZQUFZLEVBQUUsQ0FBRSxtQkFBbUIsQ0FBRTtvQkFDckMsT0FBTyxFQUFFLENBQUUsWUFBWSxFQUFFLGNBQWMsRUFBRSxvQkFBb0IsRUFBRSxXQUFXLEVBQUUsMkJBQTJCLEVBQUUsbUJBQW1CLENBQUU7b0JBQzlILE9BQU8sRUFBRSxDQUFFLG1CQUFtQixDQUFFO2lCQUNqQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBOZ3hNYXRJbnRsVGVsSW5wdXRDb21wb25lbnQgfSBmcm9tICduZ3gtbWF0LWludGwtdGVsLWlucHV0JztcclxuXHJcbmltcG9ydCB7IEVsZW1lbnRXcmFwcGVyTW9kdWxlIH0gZnJvbSAnLi4vYmFzZS9lbGVtZW50LXdyYXBwZXIvZWxlbWVudC13cmFwcGVyLm1vZHVsZSc7XHJcbmltcG9ydCB7IEVjYWJzUGhvbmVDb21wb25lbnQgfSBmcm9tICcuL2VjYWJzLXBob25lLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdElucHV0TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaW5wdXQnO1xyXG5cclxuQE5nTW9kdWxlKCB7XHJcbiAgZGVjbGFyYXRpb25zOiBbIEVjYWJzUGhvbmVDb21wb25lbnQgXSxcclxuICBpbXBvcnRzOiBbIENvbW1vbk1vZHVsZSwgTWF0SW5wdXRNb2R1bGUsIEVsZW1lbnRXcmFwcGVyTW9kdWxlLCBGb3Jtc01vZHVsZSwgTmd4TWF0SW50bFRlbElucHV0Q29tcG9uZW50LCBSZWFjdGl2ZUZvcm1zTW9kdWxlIF0sXHJcbiAgZXhwb3J0czogWyBFY2Fic1Bob25lQ29tcG9uZW50IF0sXHJcbn0gKVxyXG5leHBvcnQgY2xhc3MgRWNhYnNQaG9uZU1vZHVsZSB7IH1cclxuIl19
|