@ngil/form-inputs 0.2.0 → 5.0.0
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/fesm2022/ngil-form-inputs.mjs +82 -227
- package/fesm2022/ngil-form-inputs.mjs.map +1 -1
- package/package.json +6 -8
- package/types/ngil-form-inputs.d.ts +166 -0
- package/esm2022/index.mjs +0 -11
- package/esm2022/lib/components/input/input.component.mjs +0 -55
- package/esm2022/lib/components/overlay/overlay-toggle.directive.mjs +0 -57
- package/esm2022/lib/components/overlay/overlay.component.mjs +0 -106
- package/esm2022/lib/components/select/select.component.mjs +0 -69
- package/esm2022/lib/components/select-options/select-options.component.mjs +0 -58
- package/esm2022/lib/components/textarea/textarea.component.mjs +0 -45
- package/esm2022/lib/components/time-picker/time-picker.component.mjs +0 -65
- package/esm2022/lib/components/time-picker/time-picker.directive.mjs +0 -114
- package/esm2022/lib/components/time-picker/time-picker.model.mjs +0 -2
- package/esm2022/lib/components/time-picker-overlay/picker-toggle.mjs +0 -24
- package/esm2022/lib/components/time-picker-overlay/time-picker-overlay.component.mjs +0 -114
- package/esm2022/lib/directives/number-rotation.directive.mjs +0 -102
- package/esm2022/lib/ngil-ui-form.module.mjs +0 -68
- package/esm2022/ngil-form-inputs.mjs +0 -5
- package/index.d.ts +0 -10
- package/lib/components/input/input.component.d.ts +0 -14
- package/lib/components/overlay/overlay-toggle.directive.d.ts +0 -16
- package/lib/components/overlay/overlay.component.d.ts +0 -22
- package/lib/components/select/select.component.d.ts +0 -16
- package/lib/components/select-options/select-options.component.d.ts +0 -17
- package/lib/components/textarea/textarea.component.d.ts +0 -12
- package/lib/components/time-picker/time-picker.component.d.ts +0 -19
- package/lib/components/time-picker/time-picker.directive.d.ts +0 -28
- package/lib/components/time-picker/time-picker.model.d.ts +0 -5
- package/lib/components/time-picker-overlay/picker-toggle.d.ts +0 -8
- package/lib/components/time-picker-overlay/time-picker-overlay.component.d.ts +0 -26
- package/lib/directives/number-rotation.directive.d.ts +0 -26
- package/lib/ngil-ui-form.module.d.ts +0 -20
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
import { Directive, ElementRef, EventEmitter, HostListener, Input, Optional, Output } from '@angular/core';
|
|
2
|
-
import { NgControl } from '@angular/forms';
|
|
3
|
-
import { Subject } from 'rxjs';
|
|
4
|
-
import { takeUntil } from 'rxjs/operators';
|
|
5
|
-
import { NgilInputComponent } from '../input/input.component';
|
|
6
|
-
import { NgilTimePickerOverlayComponent } from '../time-picker-overlay/time-picker-overlay.component';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "../input/input.component";
|
|
9
|
-
import * as i2 from "@angular/forms";
|
|
10
|
-
export class TimePickerDirective {
|
|
11
|
-
constructor(elementRef, inputComponent, ngControl) {
|
|
12
|
-
this.elementRef = elementRef;
|
|
13
|
-
this.inputComponent = inputComponent;
|
|
14
|
-
this.ngControl = ngControl;
|
|
15
|
-
this.changed = new EventEmitter();
|
|
16
|
-
this.destroy$ = new Subject();
|
|
17
|
-
this.onKeyDown = (event) => {
|
|
18
|
-
if (isNaN(+event.key) && event.key !== ':' && event.key.length === 1) {
|
|
19
|
-
event.preventDefault();
|
|
20
|
-
}
|
|
21
|
-
};
|
|
22
|
-
this.onInput = (event) => {
|
|
23
|
-
const value = this.getTimePickerValue(event.target.value);
|
|
24
|
-
this.picker?.setValue({
|
|
25
|
-
hour: +value.hour,
|
|
26
|
-
minute: +value.minute || 0,
|
|
27
|
-
second: +value.second || 0
|
|
28
|
-
});
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
ngOnInit() {
|
|
32
|
-
this.ngControl?.control?.setValidators([this.timeValidator()]);
|
|
33
|
-
}
|
|
34
|
-
timeValidator() {
|
|
35
|
-
return (control) => {
|
|
36
|
-
const value = this.getTimePickerValue(control.value);
|
|
37
|
-
if (this.itemHasError(value.hour, 23)) {
|
|
38
|
-
return {
|
|
39
|
-
invalidHour: true
|
|
40
|
-
};
|
|
41
|
-
}
|
|
42
|
-
if (this.itemHasError(value.minute, 59)) {
|
|
43
|
-
return {
|
|
44
|
-
invalidMinute: true
|
|
45
|
-
};
|
|
46
|
-
}
|
|
47
|
-
if (this.itemHasError(value.second, 59)) {
|
|
48
|
-
return {
|
|
49
|
-
invalidSecond: true
|
|
50
|
-
};
|
|
51
|
-
}
|
|
52
|
-
return null;
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
itemHasError(value, max, min = 0) {
|
|
56
|
-
if (value && (value.length > 2 || +value > max || +value < min)) {
|
|
57
|
-
return true;
|
|
58
|
-
}
|
|
59
|
-
return false;
|
|
60
|
-
}
|
|
61
|
-
getTimePickerValue(value) {
|
|
62
|
-
const split = value?.split(':');
|
|
63
|
-
return {
|
|
64
|
-
hour: split ? split[0] : '00',
|
|
65
|
-
minute: split ? split[1] : '00',
|
|
66
|
-
second: split ? split[2] : '00'
|
|
67
|
-
};
|
|
68
|
-
}
|
|
69
|
-
ngAfterViewInit() {
|
|
70
|
-
if (this.picker) {
|
|
71
|
-
this.picker.origin = this.elementRef;
|
|
72
|
-
this.picker.valueChanges$.pipe(takeUntil(this.destroy$)).subscribe(value => {
|
|
73
|
-
this.setInputText(value);
|
|
74
|
-
this.changed.emit(value);
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
setInputText(value) {
|
|
79
|
-
const text = [this.getItemText(value.hour), this.getItemText(value.minute), this.getItemText(value.second)].join(':');
|
|
80
|
-
this.inputComponent?.control.setValue(text);
|
|
81
|
-
this.elementRef.nativeElement.value = text;
|
|
82
|
-
this.ngControl?.control?.setValue(text);
|
|
83
|
-
}
|
|
84
|
-
getItemText(value) {
|
|
85
|
-
return value.toString().padStart(2, '0');
|
|
86
|
-
}
|
|
87
|
-
ngOnDestroy() {
|
|
88
|
-
this.destroy$.next();
|
|
89
|
-
this.destroy$.complete();
|
|
90
|
-
}
|
|
91
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: TimePickerDirective, deps: [{ token: i0.ElementRef }, { token: i1.NgilInputComponent, optional: true }, { token: i2.NgControl, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
92
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.2", type: TimePickerDirective, selector: "[ngilTimePicker]", inputs: { picker: "picker" }, outputs: { changed: "changed" }, host: { listeners: { "keydown": "onKeyDown($event)", "input": "onInput($event)" } }, ngImport: i0 }); }
|
|
93
|
-
}
|
|
94
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: TimePickerDirective, decorators: [{
|
|
95
|
-
type: Directive,
|
|
96
|
-
args: [{
|
|
97
|
-
selector: '[ngilTimePicker]'
|
|
98
|
-
}]
|
|
99
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NgilInputComponent, decorators: [{
|
|
100
|
-
type: Optional
|
|
101
|
-
}] }, { type: i2.NgControl, decorators: [{
|
|
102
|
-
type: Optional
|
|
103
|
-
}] }], propDecorators: { picker: [{
|
|
104
|
-
type: Input
|
|
105
|
-
}], changed: [{
|
|
106
|
-
type: Output
|
|
107
|
-
}], onKeyDown: [{
|
|
108
|
-
type: HostListener,
|
|
109
|
-
args: ['keydown', ['$event']]
|
|
110
|
-
}], onInput: [{
|
|
111
|
-
type: HostListener,
|
|
112
|
-
args: ['input', ['$event']]
|
|
113
|
-
}] } });
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.directive.js","sourceRoot":"","sources":["../../../../../../../../../libs/ngil/ui/form-inputs/src/lib/components/time-picker/time-picker.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output\r\n} from '@angular/core';\r\nimport { AbstractControl, NgControl, ValidationErrors, ValidatorFn } from '@angular/forms';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { NgilInputComponent } from '../input/input.component';\r\nimport { NgilTimePickerOverlayComponent } from '../time-picker-overlay/time-picker-overlay.component';\r\nimport { TimePickerValue } from './time-picker.model';\r\n\r\n@Directive({\r\n  selector: '[ngilTimePicker]'\r\n})\r\nexport class TimePickerDirective implements AfterViewInit, OnDestroy, OnInit {\r\n  @Input() picker?: NgilTimePickerOverlayComponent;\r\n\r\n  @Output() changed = new EventEmitter<TimePickerValue>();\r\n\r\n  protected readonly destroy$ = new Subject<void>();\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  onKeyDown = (event: KeyboardEvent): void => {\r\n    if (isNaN(+event.key) && event.key !== ':' && event.key.length === 1) {\r\n      event.preventDefault();\r\n    }\r\n  };\r\n\r\n  @HostListener('input', ['$event']) onInput = (event: InputEvent): void => {\r\n    const value = this.getTimePickerValue((event.target as HTMLInputElement).value);\r\n    this.picker?.setValue({\r\n      hour: +value.hour,\r\n      minute: +value.minute || 0,\r\n      second: +value.second || 0\r\n    });\r\n  };\r\n\r\n  constructor(\r\n    private readonly elementRef: ElementRef<HTMLInputElement>,\r\n    @Optional() private readonly inputComponent?: NgilInputComponent,\r\n    @Optional() private readonly ngControl?: NgControl\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.ngControl?.control?.setValidators([this.timeValidator()]);\r\n  }\r\n\r\n  private timeValidator(): ValidatorFn {\r\n    return (control: AbstractControl): ValidationErrors | null => {\r\n      const value = this.getTimePickerValue(control.value);\r\n      if (this.itemHasError(value.hour, 23)) {\r\n        return {\r\n          invalidHour: true\r\n        };\r\n      }\r\n\r\n      if (this.itemHasError(value.minute, 59)) {\r\n        return {\r\n          invalidMinute: true\r\n        };\r\n      }\r\n\r\n      if (this.itemHasError(value.second, 59)) {\r\n        return {\r\n          invalidSecond: true\r\n        };\r\n      }\r\n\r\n      return null;\r\n    };\r\n  }\r\n\r\n  private itemHasError(value: string, max: number, min = 0) {\r\n    if (value && (value.length > 2 || +value > max || +value < min)) {\r\n      return true;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  private getTimePickerValue(value: string | null) {\r\n    const split = value?.split(':');\r\n\r\n    return {\r\n      hour: split ? split[0] : '00',\r\n      minute: split ? split[1] : '00',\r\n      second: split ? split[2] : '00'\r\n    };\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.picker) {\r\n      this.picker.origin = this.elementRef;\r\n      this.picker.valueChanges$.pipe(takeUntil(this.destroy$)).subscribe(value => {\r\n        this.setInputText(value);\r\n        this.changed.emit(value);\r\n      });\r\n    }\r\n  }\r\n\r\n  private setInputText(value: TimePickerValue): void {\r\n    const text = [this.getItemText(value.hour), this.getItemText(value.minute), this.getItemText(value.second)].join(\r\n      ':'\r\n    );\r\n    this.inputComponent?.control.setValue(text);\r\n    this.elementRef.nativeElement.value = text;\r\n    this.ngControl?.control?.setValue(text);\r\n  }\r\n\r\n  private getItemText(value: number) {\r\n    return value.toString().padStart(2, '0');\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n}\r\n"]}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1waWNrZXIubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL25naWwvdWkvZm9ybS1pbnB1dHMvc3JjL2xpYi9jb21wb25lbnRzL3RpbWUtcGlja2VyL3RpbWUtcGlja2VyLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFRpbWVQaWNrZXJWYWx1ZSB7XHJcbiAgaG91cjogbnVtYmVyO1xyXG4gIG1pbnV0ZTogbnVtYmVyO1xyXG4gIHNlY29uZDogbnVtYmVyO1xyXG59XHJcbiJdfQ==
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, HostListener, Input, ViewEncapsulation } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class PickerToggleComponent {
|
|
4
|
-
constructor() {
|
|
5
|
-
this.onClick = (event) => {
|
|
6
|
-
if (!this.picker?.isOpen) {
|
|
7
|
-
this.picker?.open();
|
|
8
|
-
}
|
|
9
|
-
event.stopPropagation();
|
|
10
|
-
};
|
|
11
|
-
}
|
|
12
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: PickerToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.2", type: PickerToggleComponent, selector: "ngil-picker-toggle", inputs: { picker: "picker" }, host: { listeners: { "click": "onClick($event)" } }, ngImport: i0, template: "<button class=\"toggle-button\" type=\"button\">\r\n <svg\r\n class=\"mat-datepicker-toggle-default-icon\"\r\n viewBox=\"0 0 24 24\"\r\n width=\"24px\"\r\n height=\"24px\"\r\n fill=\"currentColor\"\r\n focusable=\"false\"\r\n >\r\n <path\r\n d=\"M19 3h-1V1h-2v2H8V1H6v2H5c-1.11 0-1.99.9-1.99 2L3 19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H5V8h14v11zM7 10h5v5H7z\"\r\n />\r\n </svg>\r\n</button>\r\n", styles: [".toggle-button{display:flex;background:none;border:none;padding:0}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
14
|
-
}
|
|
15
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: PickerToggleComponent, decorators: [{
|
|
16
|
-
type: Component,
|
|
17
|
-
args: [{ selector: 'ngil-picker-toggle', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<button class=\"toggle-button\" type=\"button\">\r\n <svg\r\n class=\"mat-datepicker-toggle-default-icon\"\r\n viewBox=\"0 0 24 24\"\r\n width=\"24px\"\r\n height=\"24px\"\r\n fill=\"currentColor\"\r\n focusable=\"false\"\r\n >\r\n <path\r\n d=\"M19 3h-1V1h-2v2H8V1H6v2H5c-1.11 0-1.99.9-1.99 2L3 19c0 1.1.89 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H5V8h14v11zM7 10h5v5H7z\"\r\n />\r\n </svg>\r\n</button>\r\n", styles: [".toggle-button{display:flex;background:none;border:none;padding:0}\n"] }]
|
|
18
|
-
}], propDecorators: { picker: [{
|
|
19
|
-
type: Input
|
|
20
|
-
}], onClick: [{
|
|
21
|
-
type: HostListener,
|
|
22
|
-
args: ['click', ['$event']]
|
|
23
|
-
}] } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlja2VyLXRvZ2dsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmdpbC91aS9mb3JtLWlucHV0cy9zcmMvbGliL2NvbXBvbmVudHMvdGltZS1waWNrZXItb3ZlcmxheS9waWNrZXItdG9nZ2xlLnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9uZ2lsL3VpL2Zvcm0taW5wdXRzL3NyYy9saWIvY29tcG9uZW50cy90aW1lLXBpY2tlci1vdmVybGF5L3BpY2tlci10b2dnbGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBVTNHLE1BQU0sT0FBTyxxQkFBcUI7SUFQbEM7UUFVcUMsWUFBTyxHQUFHLENBQUMsS0FBWSxFQUFFLEVBQUU7WUFDNUQsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsTUFBTSxFQUFFLENBQUM7Z0JBQ3pCLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUM7WUFDdEIsQ0FBQztZQUNELEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUMxQixDQUFDLENBQUM7S0FDSDs4R0FUWSxxQkFBcUI7a0dBQXJCLHFCQUFxQiw2SUNWbEMsZ2NBY0E7OzJGREphLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDRSxvQkFBb0IsaUJBR2YsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTTs4QkFHdEMsTUFBTTtzQkFBZCxLQUFLO2dCQUU2QixPQUFPO3NCQUF6QyxZQUFZO3VCQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE5naWxUaW1lUGlja2VyT3ZlcmxheUNvbXBvbmVudCB9IGZyb20gJy4vdGltZS1waWNrZXItb3ZlcmxheS5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICduZ2lsLXBpY2tlci10b2dnbGUnLFxyXG4gIHRlbXBsYXRlVXJsOiAncGlja2VyLXRvZ2dsZS5odG1sJyxcclxuICBzdHlsZVVybHM6IFsncGlja2VyLXRvZ2dsZS5zY3NzJ10sXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUGlja2VyVG9nZ2xlQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBwaWNrZXI6IE5naWxUaW1lUGlja2VyT3ZlcmxheUNvbXBvbmVudCB8IHVuZGVmaW5lZDtcclxuXHJcbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snLCBbJyRldmVudCddKSBvbkNsaWNrID0gKGV2ZW50OiBFdmVudCkgPT4ge1xyXG4gICAgaWYgKCF0aGlzLnBpY2tlcj8uaXNPcGVuKSB7XHJcbiAgICAgIHRoaXMucGlja2VyPy5vcGVuKCk7XHJcbiAgICB9XHJcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcclxuICB9O1xyXG59XHJcbiIsIjxidXR0b24gY2xhc3M9XCJ0b2dnbGUtYnV0dG9uXCIgdHlwZT1cImJ1dHRvblwiPlxyXG4gIDxzdmdcclxuICAgIGNsYXNzPVwibWF0LWRhdGVwaWNrZXItdG9nZ2xlLWRlZmF1bHQtaWNvblwiXHJcbiAgICB2aWV3Qm94PVwiMCAwIDI0IDI0XCJcclxuICAgIHdpZHRoPVwiMjRweFwiXHJcbiAgICBoZWlnaHQ9XCIyNHB4XCJcclxuICAgIGZpbGw9XCJjdXJyZW50Q29sb3JcIlxyXG4gICAgZm9jdXNhYmxlPVwiZmFsc2VcIlxyXG4gID5cclxuICAgIDxwYXRoXHJcbiAgICAgIGQ9XCJNMTkgM2gtMVYxaC0ydjJIOFYxSDZ2Mkg1Yy0xLjExIDAtMS45OS45LTEuOTkgMkwzIDE5YzAgMS4xLjg5IDIgMiAyaDE0YzEuMSAwIDItLjkgMi0yVjVjMC0xLjEtLjktMi0yLTJ6bTAgMTZINVY4aDE0djExek03IDEwaDV2NUg3elwiXHJcbiAgICAvPlxyXG4gIDwvc3ZnPlxyXG48L2J1dHRvbj5cclxuIl19
|
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
import { Overlay } from '@angular/cdk/overlay';
|
|
2
|
-
import { ComponentPortal } from '@angular/cdk/portal';
|
|
3
|
-
import { Component } from '@angular/core';
|
|
4
|
-
import { Subject } from 'rxjs';
|
|
5
|
-
import { takeUntil } from 'rxjs/operators';
|
|
6
|
-
import { NgilTimePickerComponent } from '../time-picker/time-picker.component';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "@angular/cdk/overlay";
|
|
9
|
-
export class NgilTimePickerOverlayComponent {
|
|
10
|
-
constructor(overlay) {
|
|
11
|
-
this.overlay = overlay;
|
|
12
|
-
this.valueChanges$ = new Subject();
|
|
13
|
-
this.isOpen = false;
|
|
14
|
-
this.value = { hour: 0, minute: 0, second: 0 };
|
|
15
|
-
this.destroy$ = new Subject();
|
|
16
|
-
this.contentComponent = NgilTimePickerComponent;
|
|
17
|
-
}
|
|
18
|
-
ngOnDestroy() {
|
|
19
|
-
this.destroy$.next();
|
|
20
|
-
this.destroy$.complete();
|
|
21
|
-
}
|
|
22
|
-
open() {
|
|
23
|
-
this.overlayRef = this.overlay.create({
|
|
24
|
-
positionStrategy: this.getStrategy(),
|
|
25
|
-
hasBackdrop: true,
|
|
26
|
-
backdropClass: 'cdk-overlay-transparent-backdrop'
|
|
27
|
-
});
|
|
28
|
-
const portal = new ComponentPortal(this.contentComponent);
|
|
29
|
-
const componentRef = this.overlayRef.attach(portal);
|
|
30
|
-
this.componentInstance = componentRef.instance;
|
|
31
|
-
this.componentInstance.writeValue(this.value);
|
|
32
|
-
this.componentInstance.formGroup.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {
|
|
33
|
-
const value = this.componentInstance?.formGroup.getRawValue();
|
|
34
|
-
this.valueChanges$.next({
|
|
35
|
-
hour: value?.hour ?? 0,
|
|
36
|
-
minute: value?.minute ?? 0,
|
|
37
|
-
second: value?.second ?? 0
|
|
38
|
-
});
|
|
39
|
-
});
|
|
40
|
-
this.overlayRef
|
|
41
|
-
.backdropClick()
|
|
42
|
-
.pipe(takeUntil(this.destroy$))
|
|
43
|
-
.subscribe(() => {
|
|
44
|
-
this.close();
|
|
45
|
-
});
|
|
46
|
-
this.isOpen = true;
|
|
47
|
-
}
|
|
48
|
-
close() {
|
|
49
|
-
this.destroyOverlay();
|
|
50
|
-
}
|
|
51
|
-
destroyOverlay() {
|
|
52
|
-
this.destroy$.next();
|
|
53
|
-
this.componentInstance?.ngOnDestroy();
|
|
54
|
-
this.overlayRef?.dispose();
|
|
55
|
-
this.componentInstance = undefined;
|
|
56
|
-
this.overlayRef = undefined;
|
|
57
|
-
this.isOpen = false;
|
|
58
|
-
}
|
|
59
|
-
setValue(value) {
|
|
60
|
-
this.value = value;
|
|
61
|
-
if (this.componentInstance) {
|
|
62
|
-
this.componentInstance.writeValue(this.value);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
getStrategy() {
|
|
66
|
-
const primaryX = 'start';
|
|
67
|
-
const secondaryX = primaryX === 'start' ? 'end' : 'start';
|
|
68
|
-
const primaryY = 'top';
|
|
69
|
-
const secondaryY = 'bottom';
|
|
70
|
-
if (!this.origin) {
|
|
71
|
-
return undefined;
|
|
72
|
-
}
|
|
73
|
-
const strategy = this.overlay
|
|
74
|
-
.position()
|
|
75
|
-
.flexibleConnectedTo(this.origin)
|
|
76
|
-
.withPositions([
|
|
77
|
-
{
|
|
78
|
-
originX: primaryX,
|
|
79
|
-
originY: secondaryY,
|
|
80
|
-
overlayX: primaryX,
|
|
81
|
-
overlayY: primaryY
|
|
82
|
-
},
|
|
83
|
-
{
|
|
84
|
-
originX: primaryX,
|
|
85
|
-
originY: primaryY,
|
|
86
|
-
overlayX: primaryX,
|
|
87
|
-
overlayY: secondaryY
|
|
88
|
-
},
|
|
89
|
-
{
|
|
90
|
-
originX: secondaryX,
|
|
91
|
-
originY: secondaryY,
|
|
92
|
-
overlayX: secondaryX,
|
|
93
|
-
overlayY: primaryY
|
|
94
|
-
},
|
|
95
|
-
{
|
|
96
|
-
originX: secondaryX,
|
|
97
|
-
originY: primaryY,
|
|
98
|
-
overlayX: secondaryX,
|
|
99
|
-
overlayY: secondaryY
|
|
100
|
-
}
|
|
101
|
-
]);
|
|
102
|
-
return strategy;
|
|
103
|
-
}
|
|
104
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: NgilTimePickerOverlayComponent, deps: [{ token: i1.Overlay }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
105
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.2", type: NgilTimePickerOverlayComponent, selector: "ngil-time-picker-overlay", ngImport: i0, template: '', isInline: true }); }
|
|
106
|
-
}
|
|
107
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: NgilTimePickerOverlayComponent, decorators: [{
|
|
108
|
-
type: Component,
|
|
109
|
-
args: [{
|
|
110
|
-
selector: 'ngil-time-picker-overlay',
|
|
111
|
-
template: ''
|
|
112
|
-
}]
|
|
113
|
-
}], ctorParameters: () => [{ type: i1.Overlay }] });
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker-overlay.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/ngil/ui/form-inputs/src/lib/components/time-picker-overlay/time-picker-overlay.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { ComponentPortal } from '@angular/cdk/portal';\r\nimport { Component, ElementRef, OnDestroy } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { NgilTimePickerComponent } from '../time-picker/time-picker.component';\r\nimport { TimePickerValue } from '../time-picker/time-picker.model';\r\n\r\n@Component({\r\n  selector: 'ngil-time-picker-overlay',\r\n  template: ''\r\n})\r\nexport class NgilTimePickerOverlayComponent implements OnDestroy {\r\n  origin?: ElementRef<HTMLInputElement>;\r\n  valueChanges$ = new Subject<TimePickerValue>();\r\n  isOpen = false;\r\n\r\n  protected value: TimePickerValue = { hour: 0, minute: 0, second: 0 };\r\n  protected readonly destroy$ = new Subject<void>();\r\n  protected contentComponent = NgilTimePickerComponent;\r\n  protected componentInstance: undefined | NgilTimePickerComponent;\r\n  private overlayRef?: OverlayRef;\r\n\r\n  constructor(private readonly overlay: Overlay) {}\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  open() {\r\n    this.overlayRef = this.overlay.create({\r\n      positionStrategy: this.getStrategy(),\r\n      hasBackdrop: true,\r\n      backdropClass: 'cdk-overlay-transparent-backdrop'\r\n    });\r\n    const portal = new ComponentPortal(this.contentComponent);\r\n    const componentRef = this.overlayRef.attach(portal);\r\n    this.componentInstance = componentRef.instance;\r\n    this.componentInstance.writeValue(this.value);\r\n\r\n    this.componentInstance.formGroup.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {\r\n      const value = this.componentInstance?.formGroup.getRawValue();\r\n      this.valueChanges$.next({\r\n        hour: value?.hour ?? 0,\r\n        minute: value?.minute ?? 0,\r\n        second: value?.second ?? 0\r\n      });\r\n    });\r\n\r\n    this.overlayRef\r\n      .backdropClick()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(() => {\r\n        this.close();\r\n      });\r\n\r\n    this.isOpen = true;\r\n  }\r\n\r\n  close(): void {\r\n    this.destroyOverlay();\r\n  }\r\n\r\n  private destroyOverlay() {\r\n    this.destroy$.next();\r\n    this.componentInstance?.ngOnDestroy();\r\n    this.overlayRef?.dispose();\r\n    this.componentInstance = undefined;\r\n    this.overlayRef = undefined;\r\n    this.isOpen = false;\r\n  }\r\n\r\n  setValue(value: TimePickerValue): void {\r\n    this.value = value;\r\n\r\n    if (this.componentInstance) {\r\n      this.componentInstance.writeValue(this.value);\r\n    }\r\n  }\r\n\r\n  private getStrategy() {\r\n    const primaryX = 'start';\r\n    const secondaryX = primaryX === 'start' ? 'end' : 'start';\r\n    const primaryY = 'top';\r\n    const secondaryY = 'bottom';\r\n\r\n    if (!this.origin) {\r\n      return undefined;\r\n    }\r\n\r\n    const strategy = this.overlay\r\n      .position()\r\n      .flexibleConnectedTo(this.origin)\r\n      .withPositions([\r\n        {\r\n          originX: primaryX,\r\n          originY: secondaryY,\r\n          overlayX: primaryX,\r\n          overlayY: primaryY\r\n        },\r\n        {\r\n          originX: primaryX,\r\n          originY: primaryY,\r\n          overlayX: primaryX,\r\n          overlayY: secondaryY\r\n        },\r\n        {\r\n          originX: secondaryX,\r\n          originY: secondaryY,\r\n          overlayX: secondaryX,\r\n          overlayY: primaryY\r\n        },\r\n        {\r\n          originX: secondaryX,\r\n          originY: primaryY,\r\n          overlayX: secondaryX,\r\n          overlayY: secondaryY\r\n        }\r\n      ]);\r\n\r\n    return strategy;\r\n  }\r\n}\r\n"]}
|
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
import { Directive, ElementRef, HostListener, Input } from '@angular/core';
|
|
2
|
-
import { NgControl } from '@angular/forms';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/forms";
|
|
5
|
-
export class NumberRotationDirective {
|
|
6
|
-
get length() {
|
|
7
|
-
return this.max.toString().length;
|
|
8
|
-
}
|
|
9
|
-
constructor(elementRef, ngControl) {
|
|
10
|
-
this.elementRef = elementRef;
|
|
11
|
-
this.ngControl = ngControl;
|
|
12
|
-
this.min = 0;
|
|
13
|
-
this.max = 10;
|
|
14
|
-
this.onKeyDown = (event) => {
|
|
15
|
-
this.onKeyDownEvent(event);
|
|
16
|
-
};
|
|
17
|
-
this.onInput = (event) => {
|
|
18
|
-
let value = event.target.value;
|
|
19
|
-
if (+value > this.max) {
|
|
20
|
-
value = value.slice(this.length);
|
|
21
|
-
}
|
|
22
|
-
this.setValue(+value);
|
|
23
|
-
};
|
|
24
|
-
this.onUp = () => {
|
|
25
|
-
const value = +this.elementRef.nativeElement.value;
|
|
26
|
-
this.setValue(value + 1);
|
|
27
|
-
};
|
|
28
|
-
this.onDown = () => {
|
|
29
|
-
const value = +this.elementRef.nativeElement.value;
|
|
30
|
-
this.setValue(value - 1);
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
ngOnInit() {
|
|
34
|
-
this.elementRef.nativeElement.value = this.elementRef.nativeElement.value.toString().padStart(this.length, '0');
|
|
35
|
-
}
|
|
36
|
-
ngAfterViewInit() {
|
|
37
|
-
this.buttonUp?.addEventListener('click', this.onUp);
|
|
38
|
-
this.buttonDown?.addEventListener('click', this.onDown);
|
|
39
|
-
}
|
|
40
|
-
onKeyDownEvent(event) {
|
|
41
|
-
if (!this.isKeyValid(event.key)) {
|
|
42
|
-
event.preventDefault();
|
|
43
|
-
return;
|
|
44
|
-
}
|
|
45
|
-
if (event.key === 'ArrowUp') {
|
|
46
|
-
event.preventDefault();
|
|
47
|
-
this.onUp();
|
|
48
|
-
}
|
|
49
|
-
if (event.key === 'ArrowDown') {
|
|
50
|
-
event.preventDefault();
|
|
51
|
-
this.onDown();
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
isKeyValid(key) {
|
|
55
|
-
if (key.length !== 1 || !isNaN(+key)) {
|
|
56
|
-
return true;
|
|
57
|
-
}
|
|
58
|
-
return false;
|
|
59
|
-
}
|
|
60
|
-
setValue(value) {
|
|
61
|
-
if (value < this.min) {
|
|
62
|
-
this.setInputValue(this.max);
|
|
63
|
-
}
|
|
64
|
-
else if (value > this.max) {
|
|
65
|
-
this.setInputValue(this.min);
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
this.setInputValue(value);
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
setInputValue(value) {
|
|
72
|
-
this.ngControl.control?.setValue(value);
|
|
73
|
-
this.elementRef.nativeElement.value = value.toString().padStart(this.length, '0');
|
|
74
|
-
}
|
|
75
|
-
ngOnDestroy() {
|
|
76
|
-
this.buttonUp?.removeEventListener('click', this.onUp);
|
|
77
|
-
this.buttonDown?.removeEventListener('click', this.onDown);
|
|
78
|
-
}
|
|
79
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: NumberRotationDirective, deps: [{ token: i0.ElementRef }, { token: i1.NgControl }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
80
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.2", type: NumberRotationDirective, selector: "input[ngilNumberRotation]", inputs: { min: "min", max: "max", buttonUp: "buttonUp", buttonDown: "buttonDown" }, host: { listeners: { "keydown": "onKeyDown($event)", "input": "onInput($event)" } }, ngImport: i0 }); }
|
|
81
|
-
}
|
|
82
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: NumberRotationDirective, decorators: [{
|
|
83
|
-
type: Directive,
|
|
84
|
-
args: [{
|
|
85
|
-
selector: 'input[ngilNumberRotation]'
|
|
86
|
-
}]
|
|
87
|
-
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.NgControl }], propDecorators: { min: [{
|
|
88
|
-
type: Input
|
|
89
|
-
}], max: [{
|
|
90
|
-
type: Input
|
|
91
|
-
}], buttonUp: [{
|
|
92
|
-
type: Input
|
|
93
|
-
}], buttonDown: [{
|
|
94
|
-
type: Input
|
|
95
|
-
}], onKeyDown: [{
|
|
96
|
-
type: HostListener,
|
|
97
|
-
args: ['keydown', ['$event']]
|
|
98
|
-
}], onInput: [{
|
|
99
|
-
type: HostListener,
|
|
100
|
-
args: ['input', ['$event']]
|
|
101
|
-
}] } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLXJvdGF0aW9uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmdpbC91aS9mb3JtLWlucHV0cy9zcmMvbGliL2RpcmVjdGl2ZXMvbnVtYmVyLXJvdGF0aW9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWlCLFNBQVMsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDN0csT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7QUFLM0MsTUFBTSxPQUFPLHVCQUF1QjtJQU1sQyxJQUFJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLENBQUMsTUFBTSxDQUFDO0lBQ3BDLENBQUM7SUFnQkQsWUFBNkIsVUFBd0MsRUFBbUIsU0FBb0I7UUFBL0UsZUFBVSxHQUFWLFVBQVUsQ0FBOEI7UUFBbUIsY0FBUyxHQUFULFNBQVMsQ0FBVztRQXZCbkcsUUFBRyxHQUFHLENBQUMsQ0FBQztRQUNSLFFBQUcsR0FBRyxFQUFFLENBQUM7UUFTbEIsY0FBUyxHQUFHLENBQUMsS0FBb0IsRUFBUSxFQUFFO1lBQ3pDLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDN0IsQ0FBQyxDQUFDO1FBR0YsWUFBTyxHQUFHLENBQUMsS0FBaUIsRUFBUSxFQUFFO1lBQ3BDLElBQUksS0FBSyxHQUFJLEtBQUssQ0FBQyxNQUEyQixDQUFDLEtBQUssQ0FBQztZQUNyRCxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztnQkFDdEIsS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ25DLENBQUM7WUFDRCxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsS0FBSyxD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QUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN2RCxJQUFJLENBQUMsVUFBVSxFQUFFLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDN0QsQ0FBQzs4R0F4RlUsdUJBQXVCO2tHQUF2Qix1QkFBdUI7OzJGQUF2Qix1QkFBdUI7a0JBSG5DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDJCQUEyQjtpQkFDdEM7dUdBRVUsR0FBRztzQkFBWCxLQUFLO2dCQUNHLEdBQUc7c0JBQVgsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBT04sU0FBUztzQkFEUixZQUFZO3VCQUFDLFNBQVMsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFNbkMsT0FBTztzQkFETixZQUFZO3VCQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFmdGVyVmlld0luaXQsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBJbnB1dCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTmdDb250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdpbnB1dFtuZ2lsTnVtYmVyUm90YXRpb25dJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgTnVtYmVyUm90YXRpb25EaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3ksIE9uSW5pdCB7XHJcbiAgQElucHV0KCkgbWluID0gMDtcclxuICBASW5wdXQoKSBtYXggPSAxMDtcclxuICBASW5wdXQoKSBidXR0b25VcD86IEhUTUxFbGVtZW50O1xyXG4gIEBJbnB1dCgpIGJ1dHRvbkRvd24/OiBIVE1MRWxlbWVudDtcclxuXHJcbiAgZ2V0IGxlbmd0aCgpOiBudW1iZXIge1xyXG4gICAgcmV0dXJuIHRoaXMubWF4LnRvU3RyaW5nKCkubGVuZ3RoO1xyXG4gIH1cclxuXHJcbiAgQEhvc3RMaXN0ZW5lcigna2V5ZG93bicsIFsnJGV2ZW50J10pXHJcbiAgb25LZXlEb3duID0gKGV2ZW50OiBLZXlib2FyZEV2ZW50KTogdm9pZCA9PiB7XHJcbiAgICB0aGlzLm9uS2V5RG93bkV2ZW50KGV2ZW50KTtcclxuICB9O1xyXG5cclxuICBASG9zdExpc3RlbmVyKCdpbnB1dCcsIFsnJGV2ZW50J10pXHJcbiAgb25JbnB1dCA9IChldmVudDogSW5wdXRFdmVudCk6IHZvaWQgPT4ge1xyXG4gICAgbGV0IHZhbHVlID0gKGV2ZW50LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50KS52YWx1ZTtcclxuICAgIGlmICgrdmFsdWUgPiB0aGlzLm1heCkge1xyXG4gICAgICB2YWx1ZSA9IHZhbHVlLnNsaWNlKHRoaXMubGVuZ3RoKTtcclxuICAgIH1cclxuICAgIHRoaXMuc2V0VmFsdWUoK3ZhbHVlKTtcclxuICB9O1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTElucHV0RWxlbWVudD4sIHByaXZhdGUgcmVhZG9ubHkgbmdDb250cm9sOiBOZ0NvbnRyb2wpIHt9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQudmFsdWUgPSB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC52YWx1ZS50b1N0cmluZygpLnBhZFN0YXJ0KHRoaXMubGVuZ3RoLCAnMCcpO1xyXG4gIH1cclxuXHJcbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy5idXR0b25VcD8uYWRkRXZlbnRMaXN0ZW5lcignY2xpY2snLCB0aGlzLm9uVXApO1xyXG4gICAgdGhpcy5idXR0b25Eb3duPy5hZGRFdmVudExpc3RlbmVyKCdjbGljaycsIHRoaXMub25Eb3duKTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgb25LZXlEb3duRXZlbnQoZXZlbnQ6IEtleWJvYXJkRXZlbnQpOiB2b2lkIHtcclxuICAgIGlmICghdGhpcy5pc0tleVZhbGlkKGV2ZW50LmtleSkpIHtcclxuICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcclxuICAgICAgcmV0dXJuO1xyXG4gICAgfVxyXG5cclxuICAgIGlmIChldmVudC5rZXkgPT09ICdBcnJvd1VwJykge1xyXG4gICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgICB0aGlzLm9uVXAoKTtcclxuICAgIH1cclxuXHJcbiAgICBpZiAoZXZlbnQua2V5ID09PSAnQXJyb3dEb3duJykge1xyXG4gICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgICB0aGlzLm9uRG93bigpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBpc0tleVZhbGlkKGtleTogc3RyaW5nKTogYm9vbGVhbiB7XHJcbiAgICBpZiAoa2V5Lmxlbmd0aCAhPT0gMSB8fCAhaXNOYU4oK2tleSkpIHtcclxuICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBvblVwID0gKCk6IHZvaWQgPT4ge1xyXG4gICAgY29uc3QgdmFsdWUgPSArdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQudmFsdWU7XHJcbiAgICB0aGlzLnNldFZhbHVlKHZhbHVlICsgMSk7XHJcbiAgfTtcclxuXHJcbiAgcHJpdmF0ZSBvbkRvd24gPSAoKTogdm9pZCA9PiB7XHJcbiAgICBjb25zdCB2YWx1ZSA9ICt0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC52YWx1ZTtcclxuICAgIHRoaXMuc2V0VmFsdWUodmFsdWUgLSAxKTtcclxuICB9O1xyXG5cclxuICBwcml2YXRlIHNldFZhbHVlKHZhbHVlOiBudW1iZXIpOiB2b2lkIHtcclxuICAgIGlmICh2YWx1ZSA8IHRoaXMubWluKSB7XHJcbiAgICAgIHRoaXMuc2V0SW5wdXRWYWx1ZSh0aGlzLm1heCk7XHJcbiAgICB9IGVsc2UgaWYgKHZhbHVlID4gdGhpcy5tYXgpIHtcclxuICAgICAgdGhpcy5zZXRJbnB1dFZhbHVlKHRoaXMubWluKTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMuc2V0SW5wdXRWYWx1ZSh2YWx1ZSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHNldElucHV0VmFsdWUodmFsdWU6IG51bWJlcikge1xyXG4gICAgdGhpcy5uZ0NvbnRyb2wuY29udHJvbD8uc2V0VmFsdWUodmFsdWUpO1xyXG4gICAgdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQudmFsdWUgPSB2YWx1ZS50b1N0cmluZygpLnBhZFN0YXJ0KHRoaXMubGVuZ3RoLCAnMCcpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICB0aGlzLmJ1dHRvblVwPy5yZW1vdmVFdmVudExpc3RlbmVyKCdjbGljaycsIHRoaXMub25VcCk7XHJcbiAgICB0aGlzLmJ1dHRvbkRvd24/LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ2NsaWNrJywgdGhpcy5vbkRvd24pO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
import { OverlayModule } from '@angular/cdk/overlay';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { NgModule } from '@angular/core';
|
|
4
|
-
import { ReactiveFormsModule } from '@angular/forms';
|
|
5
|
-
import { NgilInputComponent } from './components/input/input.component';
|
|
6
|
-
import { OverlayToggleDirective } from './components/overlay/overlay-toggle.directive';
|
|
7
|
-
import { NgilOverlayComponent } from './components/overlay/overlay.component';
|
|
8
|
-
import { NgilSelectOptionsComponent } from './components/select-options/select-options.component';
|
|
9
|
-
import { NgilSelectComponent } from './components/select/select.component';
|
|
10
|
-
import { NgilTextareaComponent } from './components/textarea/textarea.component';
|
|
11
|
-
import { PickerToggleComponent } from './components/time-picker-overlay/picker-toggle';
|
|
12
|
-
import { NgilTimePickerOverlayComponent } from './components/time-picker-overlay/time-picker-overlay.component';
|
|
13
|
-
import { NgilTimePickerComponent } from './components/time-picker/time-picker.component';
|
|
14
|
-
import { TimePickerDirective } from './components/time-picker/time-picker.directive';
|
|
15
|
-
import { NumberRotationDirective } from './directives/number-rotation.directive';
|
|
16
|
-
import * as i0 from "@angular/core";
|
|
17
|
-
export class NgilUiFormModule {
|
|
18
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: NgilUiFormModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
19
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.2", ngImport: i0, type: NgilUiFormModule, declarations: [NgilInputComponent,
|
|
20
|
-
NgilTimePickerComponent,
|
|
21
|
-
NgilTimePickerOverlayComponent,
|
|
22
|
-
PickerToggleComponent,
|
|
23
|
-
NumberRotationDirective,
|
|
24
|
-
TimePickerDirective,
|
|
25
|
-
NgilSelectComponent,
|
|
26
|
-
NgilTextareaComponent,
|
|
27
|
-
NgilSelectOptionsComponent,
|
|
28
|
-
NgilOverlayComponent,
|
|
29
|
-
OverlayToggleDirective], imports: [CommonModule, ReactiveFormsModule, OverlayModule], exports: [NgilInputComponent,
|
|
30
|
-
NgilSelectComponent,
|
|
31
|
-
NgilTextareaComponent,
|
|
32
|
-
NgilTimePickerComponent,
|
|
33
|
-
NgilTimePickerOverlayComponent,
|
|
34
|
-
PickerToggleComponent,
|
|
35
|
-
NumberRotationDirective,
|
|
36
|
-
TimePickerDirective] }); }
|
|
37
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: NgilUiFormModule, imports: [CommonModule, ReactiveFormsModule, OverlayModule] }); }
|
|
38
|
-
}
|
|
39
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: NgilUiFormModule, decorators: [{
|
|
40
|
-
type: NgModule,
|
|
41
|
-
args: [{
|
|
42
|
-
imports: [CommonModule, ReactiveFormsModule, OverlayModule],
|
|
43
|
-
declarations: [
|
|
44
|
-
NgilInputComponent,
|
|
45
|
-
NgilTimePickerComponent,
|
|
46
|
-
NgilTimePickerOverlayComponent,
|
|
47
|
-
PickerToggleComponent,
|
|
48
|
-
NumberRotationDirective,
|
|
49
|
-
TimePickerDirective,
|
|
50
|
-
NgilSelectComponent,
|
|
51
|
-
NgilTextareaComponent,
|
|
52
|
-
NgilSelectOptionsComponent,
|
|
53
|
-
NgilOverlayComponent,
|
|
54
|
-
OverlayToggleDirective
|
|
55
|
-
],
|
|
56
|
-
exports: [
|
|
57
|
-
NgilInputComponent,
|
|
58
|
-
NgilSelectComponent,
|
|
59
|
-
NgilTextareaComponent,
|
|
60
|
-
NgilTimePickerComponent,
|
|
61
|
-
NgilTimePickerOverlayComponent,
|
|
62
|
-
PickerToggleComponent,
|
|
63
|
-
NumberRotationDirective,
|
|
64
|
-
TimePickerDirective
|
|
65
|
-
]
|
|
66
|
-
}]
|
|
67
|
-
}] });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdpbC11aS1mb3JtLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmdpbC91aS9mb3JtLWlucHV0cy9zcmMvbGliL25naWwtdWktZm9ybS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3ZGLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHNEQUFzRCxDQUFDO0FBQ2xHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3ZGLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLGdFQUFnRSxDQUFDO0FBQ2hILE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3pGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3JGLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDOztBQTRCakYsTUFBTSxPQUFPLGdCQUFnQjs4R0FBaEIsZ0JBQWdCOytHQUFoQixnQkFBZ0IsaUJBdkJ6QixrQkFBa0I7WUFDbEIsdUJBQXVCO1lBQ3ZCLDhCQUE4QjtZQUM5QixxQkFBcUI7WUFDckIsdUJBQXVCO1lBQ3ZCLG1CQUFtQjtZQUNuQixtQkFBbUI7WUFDbkIscUJBQXFCO1lBQ3JCLDBCQUEwQjtZQUMxQixvQkFBb0I7WUFDcEIsc0JBQXNCLGFBWmQsWUFBWSxFQUFFLG1CQUFtQixFQUFFLGFBQWEsYUFleEQsa0JBQWtCO1lBQ2xCLG1CQUFtQjtZQUNuQixxQkFBcUI7WUFDckIsdUJBQXVCO1lBQ3ZCLDhCQUE4QjtZQUM5QixxQkFBcUI7WUFDckIsdUJBQXVCO1lBQ3ZCLG1CQUFtQjsrR0FHVixnQkFBZ0IsWUF6QmpCLFlBQVksRUFBRSxtQkFBbUIsRUFBRSxhQUFhOzsyRkF5Qi9DLGdCQUFnQjtrQkExQjVCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLG1CQUFtQixFQUFFLGFBQWEsQ0FBQztvQkFDM0QsWUFBWSxFQUFFO3dCQUNaLGtCQUFrQjt3QkFDbEIsdUJBQXVCO3dCQUN2Qiw4QkFBOEI7d0JBQzlCLHFCQUFxQjt3QkFDckIsdUJBQXVCO3dCQUN2QixtQkFBbUI7d0JBQ25CLG1CQUFtQjt3QkFDbkIscUJBQXFCO3dCQUNyQiwwQkFBMEI7d0JBQzFCLG9CQUFvQjt3QkFDcEIsc0JBQXNCO3FCQUN2QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1Asa0JBQWtCO3dCQUNsQixtQkFBbUI7d0JBQ25CLHFCQUFxQjt3QkFDckIsdUJBQXVCO3dCQUN2Qiw4QkFBOEI7d0JBQzlCLHFCQUFxQjt3QkFDckIsdUJBQXVCO3dCQUN2QixtQkFBbUI7cUJBQ3BCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3ZlcmxheU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgTmdpbElucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2lucHV0L2lucHV0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE92ZXJsYXlUb2dnbGVEaXJlY3RpdmUgfSBmcm9tICcuL2NvbXBvbmVudHMvb3ZlcmxheS9vdmVybGF5LXRvZ2dsZS5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBOZ2lsT3ZlcmxheUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9vdmVybGF5L292ZXJsYXkuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTmdpbFNlbGVjdE9wdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvc2VsZWN0LW9wdGlvbnMvc2VsZWN0LW9wdGlvbnMuY29tcG9uZW50JztcclxuaW1wb3J0IHsgTmdpbFNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE5naWxUZXh0YXJlYUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90ZXh0YXJlYS90ZXh0YXJlYS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBQaWNrZXJUb2dnbGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvdGltZS1waWNrZXItb3ZlcmxheS9waWNrZXItdG9nZ2xlJztcclxuaW1wb3J0IHsgTmdpbFRpbWVQaWNrZXJPdmVybGF5Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3RpbWUtcGlja2VyLW92ZXJsYXkvdGltZS1waWNrZXItb3ZlcmxheS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBOZ2lsVGltZVBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy90aW1lLXBpY2tlci90aW1lLXBpY2tlci5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBUaW1lUGlja2VyRGlyZWN0aXZlIH0gZnJvbSAnLi9jb21wb25lbnRzL3RpbWUtcGlja2VyL3RpbWUtcGlja2VyLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IE51bWJlclJvdGF0aW9uRGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzL251bWJlci1yb3RhdGlvbi5kaXJlY3RpdmUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlLCBPdmVybGF5TW9kdWxlXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIE5naWxJbnB1dENvbXBvbmVudCxcclxuICAgIE5naWxUaW1lUGlja2VyQ29tcG9uZW50LFxyXG4gICAgTmdpbFRpbWVQaWNrZXJPdmVybGF5Q29tcG9uZW50LFxyXG4gICAgUGlja2VyVG9nZ2xlQ29tcG9uZW50LFxyXG4gICAgTnVtYmVyUm90YXRpb25EaXJlY3RpdmUsXHJcbiAgICBUaW1lUGlja2VyRGlyZWN0aXZlLFxyXG4gICAgTmdpbFNlbGVjdENvbXBvbmVudCxcclxuICAgIE5naWxUZXh0YXJlYUNvbXBvbmVudCxcclxuICAgIE5naWxTZWxlY3RPcHRpb25zQ29tcG9uZW50LFxyXG4gICAgTmdpbE92ZXJsYXlDb21wb25lbnQsXHJcbiAgICBPdmVybGF5VG9nZ2xlRGlyZWN0aXZlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBOZ2lsSW5wdXRDb21wb25lbnQsXHJcbiAgICBOZ2lsU2VsZWN0Q29tcG9uZW50LFxyXG4gICAgTmdpbFRleHRhcmVhQ29tcG9uZW50LFxyXG4gICAgTmdpbFRpbWVQaWNrZXJDb21wb25lbnQsXHJcbiAgICBOZ2lsVGltZVBpY2tlck92ZXJsYXlDb21wb25lbnQsXHJcbiAgICBQaWNrZXJUb2dnbGVDb21wb25lbnQsXHJcbiAgICBOdW1iZXJSb3RhdGlvbkRpcmVjdGl2ZSxcclxuICAgIFRpbWVQaWNrZXJEaXJlY3RpdmVcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBOZ2lsVWlGb3JtTW9kdWxlIHt9XHJcbiJdfQ==
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Generated bundle index. Do not edit.
|
|
3
|
-
*/
|
|
4
|
-
export * from './index';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdpbC1mb3JtLWlucHV0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmdpbC91aS9mb3JtLWlucHV0cy9zcmMvbmdpbC1mb3JtLWlucHV0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
package/index.d.ts
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
export * from './lib/components/input/input.component';
|
|
2
|
-
export * from './lib/components/select/select.component';
|
|
3
|
-
export * from './lib/components/textarea/textarea.component';
|
|
4
|
-
export * from './lib/components/time-picker-overlay/picker-toggle';
|
|
5
|
-
export * from './lib/components/time-picker-overlay/time-picker-overlay.component';
|
|
6
|
-
export * from './lib/components/time-picker/time-picker.component';
|
|
7
|
-
export * from './lib/components/time-picker/time-picker.directive';
|
|
8
|
-
export * from './lib/components/time-picker/time-picker.model';
|
|
9
|
-
export * from './lib/directives/number-rotation.directive';
|
|
10
|
-
export * from './lib/ngil-ui-form.module';
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { AfterViewInit, EventEmitter } from '@angular/core';
|
|
2
|
-
import { FormControl } from '@angular/forms';
|
|
3
|
-
import { AbstractInputComponent } from '@ngil/form-cva';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class NgilInputComponent extends AbstractInputComponent<string | number> implements AfterViewInit {
|
|
6
|
-
type: string;
|
|
7
|
-
changed: EventEmitter<string | number>;
|
|
8
|
-
control: FormControl<any>;
|
|
9
|
-
ngAfterViewInit(): void;
|
|
10
|
-
writeValue(value: string | number): void;
|
|
11
|
-
onChangeInput(value: string | number): void;
|
|
12
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NgilInputComponent, never>;
|
|
13
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NgilInputComponent, "ngil-input", never, { "type": { "alias": "type"; "required": false; }; }, { "changed": "changed"; }, never, ["[labelPrefix]", "[labelSuffix]", "[prefix]", "[suffix]", "[hint]"], false, never>;
|
|
14
|
-
}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { ElementRef, OnInit } from '@angular/core';
|
|
2
|
-
import { NgilOverlayComponent } from './overlay.component';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export declare class OverlayToggleDirective implements OnInit {
|
|
5
|
-
private readonly elementRef;
|
|
6
|
-
set ngilOverlayToggle(overlay: NgilOverlayComponent);
|
|
7
|
-
private overlay;
|
|
8
|
-
set isOverlayOrigin(isOrigin: boolean);
|
|
9
|
-
private isOrigin;
|
|
10
|
-
constructor(elementRef: ElementRef<HTMLInputElement>);
|
|
11
|
-
ngOnInit(): void;
|
|
12
|
-
private setOverlayOrigin;
|
|
13
|
-
onClick: (event: Event) => void;
|
|
14
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<OverlayToggleDirective, never>;
|
|
15
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<OverlayToggleDirective, "[ngilOverlayToggle]", ["ngilOverlayToggle"], { "ngilOverlayToggle": { "alias": "ngilOverlayToggle"; "required": false; }; "isOverlayOrigin": { "alias": "isOverlayOrigin"; "required": false; }; }, {}, never, never, false, never>;
|
|
16
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { Overlay, OverlayConfig } from '@angular/cdk/overlay';
|
|
2
|
-
import { ElementRef, OnDestroy } from '@angular/core';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export declare class NgilOverlayComponent implements OnDestroy {
|
|
5
|
-
private readonly overlay;
|
|
6
|
-
el?: ElementRef;
|
|
7
|
-
overwriteConfig: Partial<OverlayConfig>;
|
|
8
|
-
private readonly destroy$;
|
|
9
|
-
private readonly maxHeight;
|
|
10
|
-
private overlayRef?;
|
|
11
|
-
origin?: ElementRef<HTMLInputElement>;
|
|
12
|
-
isOpened: boolean;
|
|
13
|
-
constructor(overlay: Overlay);
|
|
14
|
-
open(): void;
|
|
15
|
-
private getOverlayConfig;
|
|
16
|
-
private getStrategy;
|
|
17
|
-
close(): void;
|
|
18
|
-
toggle(): void;
|
|
19
|
-
ngOnDestroy(): void;
|
|
20
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NgilOverlayComponent, never>;
|
|
21
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NgilOverlayComponent, "ngil-overlay", never, { "overwriteConfig": { "alias": "overwriteConfig"; "required": false; }; }, {}, never, ["*"], false, never>;
|
|
22
|
-
}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { AbstractInputComponent } from '@ngil/form-cva';
|
|
2
|
-
import { NgilOverlayComponent } from '../overlay/overlay.component';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export declare class NgilSelectComponent<T> extends AbstractInputComponent<T | T[]> {
|
|
5
|
-
overlay?: NgilOverlayComponent;
|
|
6
|
-
multiple: boolean;
|
|
7
|
-
items: T[];
|
|
8
|
-
displayKey?: keyof T;
|
|
9
|
-
value: T | T[] | null;
|
|
10
|
-
get displayValue(): string | T | NonNullable<T>[keyof T] | null;
|
|
11
|
-
writeValue(value: T): void;
|
|
12
|
-
onItemSelected(item: T | T[]): void;
|
|
13
|
-
isArray(item: T | T[]): item is T[];
|
|
14
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NgilSelectComponent<any>, never>;
|
|
15
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NgilSelectComponent<any>, "ngil-select", never, { "multiple": { "alias": "multiple"; "required": false; }; "items": { "alias": "items"; "required": false; }; "displayKey": { "alias": "displayKey"; "required": false; }; }, {}, never, ["[suffix]"], false, never>;
|
|
16
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import { EventEmitter, OnDestroy } from '@angular/core';
|
|
2
|
-
import { Subject } from 'rxjs';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
export declare class NgilSelectOptionsComponent<T> implements OnDestroy {
|
|
5
|
-
selectedItems: T | T[] | null;
|
|
6
|
-
items: T[];
|
|
7
|
-
displayKey?: keyof T;
|
|
8
|
-
multiple: boolean;
|
|
9
|
-
display: boolean;
|
|
10
|
-
itemSelected: EventEmitter<T | T[]>;
|
|
11
|
-
protected readonly destroy$: Subject<void>;
|
|
12
|
-
onItemSelected(item: T): void;
|
|
13
|
-
isSelected(item: T): boolean;
|
|
14
|
-
ngOnDestroy(): void;
|
|
15
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NgilSelectOptionsComponent<any>, never>;
|
|
16
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NgilSelectOptionsComponent<any>, "ngil-select-options", never, { "selectedItems": { "alias": "selectedItems"; "required": false; }; "items": { "alias": "items"; "required": false; }; "displayKey": { "alias": "displayKey"; "required": false; }; "multiple": { "alias": "multiple"; "required": false; }; "display": { "alias": "display"; "required": false; }; }, { "itemSelected": "itemSelected"; }, never, never, false, never>;
|
|
17
|
-
}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { AfterViewInit } from '@angular/core';
|
|
2
|
-
import { FormControl } from '@angular/forms';
|
|
3
|
-
import { AbstractInputComponent } from '@ngil/form-cva';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class NgilTextareaComponent extends AbstractInputComponent<string> implements AfterViewInit {
|
|
6
|
-
control: FormControl<any>;
|
|
7
|
-
ngAfterViewInit(): void;
|
|
8
|
-
writeValue(value: string): void;
|
|
9
|
-
onChangeInput(value: string): void;
|
|
10
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NgilTextareaComponent, never>;
|
|
11
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<NgilTextareaComponent, "ngil-textarea", never, {}, {}, never, ["[suffix]"], false, never>;
|
|
12
|
-
}
|