@ngil/form-inputs 0.1.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/README.md +9 -0
- package/esm2022/index.mjs +11 -0
- package/esm2022/lib/components/input/input.component.mjs +55 -0
- package/esm2022/lib/components/overlay/overlay-toggle.directive.mjs +57 -0
- package/esm2022/lib/components/overlay/overlay.component.mjs +106 -0
- package/esm2022/lib/components/select/select.component.mjs +69 -0
- package/esm2022/lib/components/select-options/select-options.component.mjs +58 -0
- package/esm2022/lib/components/textarea/textarea.component.mjs +45 -0
- package/esm2022/lib/components/time-picker/time-picker.component.mjs +65 -0
- package/esm2022/lib/components/time-picker/time-picker.directive.mjs +114 -0
- package/esm2022/lib/components/time-picker/time-picker.model.mjs +2 -0
- package/esm2022/lib/components/time-picker-overlay/picker-toggle.mjs +24 -0
- package/esm2022/lib/components/time-picker-overlay/time-picker-overlay.component.mjs +114 -0
- package/esm2022/lib/directives/number-rotation.directive.mjs +102 -0
- package/esm2022/lib/ngil-ui-form.module.mjs +68 -0
- package/esm2022/ngil-form-inputs.mjs +5 -0
- package/fesm2022/ngil-form-inputs.mjs +813 -0
- package/fesm2022/ngil-form-inputs.mjs.map +1 -0
- package/index.d.ts +10 -0
- package/lib/components/input/input.component.d.ts +14 -0
- package/lib/components/overlay/overlay-toggle.directive.d.ts +16 -0
- package/lib/components/overlay/overlay.component.d.ts +22 -0
- package/lib/components/select/select.component.d.ts +16 -0
- package/lib/components/select-options/select-options.component.d.ts +17 -0
- package/lib/components/textarea/textarea.component.d.ts +12 -0
- package/lib/components/time-picker/time-picker.component.d.ts +19 -0
- package/lib/components/time-picker/time-picker.directive.d.ts +28 -0
- package/lib/components/time-picker/time-picker.model.d.ts +5 -0
- package/lib/components/time-picker-overlay/picker-toggle.d.ts +8 -0
- package/lib/components/time-picker-overlay/time-picker-overlay.component.d.ts +26 -0
- package/lib/directives/number-rotation.directive.d.ts +26 -0
- package/lib/ngil-ui-form.module.d.ts +20 -0
- package/package.json +32 -0
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { FormControl, FormGroup, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { AbstractInputComponent } from '@ngil/form-cva';
|
|
4
|
+
import { takeUntil } from 'rxjs/operators';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "@angular/forms";
|
|
8
|
+
import * as i3 from "../../directives/number-rotation.directive";
|
|
9
|
+
export class NgilTimePickerComponent extends AbstractInputComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments);
|
|
12
|
+
this.defaultValue = { hour: 0, minute: 0, second: 0 };
|
|
13
|
+
this.value = '';
|
|
14
|
+
this.formGroup = new FormGroup({
|
|
15
|
+
hour: new FormControl(this.defaultValue.hour, { nonNullable: true }),
|
|
16
|
+
minute: new FormControl(this.defaultValue.minute, { nonNullable: true }),
|
|
17
|
+
second: new FormControl(this.defaultValue.second, { nonNullable: true })
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
ngAfterViewInit() {
|
|
21
|
+
this.listenValueChanges();
|
|
22
|
+
}
|
|
23
|
+
listenValueChanges() {
|
|
24
|
+
this.formGroup.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {
|
|
25
|
+
if (this.onChange) {
|
|
26
|
+
const value = this.formGroup.getRawValue();
|
|
27
|
+
this.onChange({
|
|
28
|
+
hour: value.hour ?? this.defaultValue.hour,
|
|
29
|
+
minute: value.minute ?? this.defaultValue.minute,
|
|
30
|
+
second: value.second ?? this.defaultValue.second
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
writeValue(value) {
|
|
36
|
+
if (value) {
|
|
37
|
+
this.formGroup.setValue({
|
|
38
|
+
...this.defaultValue,
|
|
39
|
+
...value
|
|
40
|
+
}, { emitEvent: false });
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
this.formGroup.reset(this.defaultValue, { emitEvent: false });
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: NgilTimePickerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
47
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.2", type: NgilTimePickerComponent, selector: "ngil-time-picker", providers: [
|
|
48
|
+
{
|
|
49
|
+
provide: NG_VALUE_ACCESSOR,
|
|
50
|
+
useExisting: NgilTimePickerComponent,
|
|
51
|
+
multi: true
|
|
52
|
+
}
|
|
53
|
+
], usesInheritance: true, ngImport: i0, template: "<form [formGroup]=\"formGroup\" class=\"ngil-time-picker\">\r\n <div class=\"ngil-time-picker__field\">\r\n <button #hourButtonUp class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowUp\"></ng-container>\r\n </button>\r\n <input\r\n ngilNumberRotation\r\n class=\"ngil-time-picker__input\"\r\n formControlName=\"hour\"\r\n [buttonUp]=\"hourButtonUp\"\r\n [buttonDown]=\"hourButtonDown\"\r\n [max]=\"23\"\r\n [min]=\"0\"\r\n (blur)=\"onBlur()\"\r\n />\r\n <button #hourButtonDown class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowDown\"></ng-container>\r\n </button>\r\n </div>\r\n\r\n <span>:</span>\r\n\r\n <div class=\"ngil-time-picker__field\">\r\n <button #minuteButtonUp class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowUp\"></ng-container>\r\n </button>\r\n <input\r\n ngilNumberRotation\r\n class=\"ngil-time-picker__input\"\r\n formControlName=\"minute\"\r\n [buttonUp]=\"minuteButtonUp\"\r\n [buttonDown]=\"minuteButtonDown\"\r\n [max]=\"59\"\r\n [min]=\"0\"\r\n (blur)=\"onBlur()\"\r\n />\r\n <button #minuteButtonDown class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowDown\"></ng-container>\r\n </button>\r\n </div>\r\n\r\n <span>:</span>\r\n\r\n <div class=\"ngil-time-picker__field\">\r\n <button #secondButtonUp class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowUp\"></ng-container>\r\n </button>\r\n <input\r\n ngilNumberRotation\r\n class=\"ngil-time-picker__input\"\r\n formControlName=\"second\"\r\n [buttonUp]=\"secondButtonUp\"\r\n [buttonDown]=\"secondButtonDown\"\r\n [max]=\"59\"\r\n [min]=\"0\"\r\n (blur)=\"onBlur()\"\r\n />\r\n <button #secondButtonDown class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowDown\"></ng-container>\r\n </button>\r\n </div>\r\n</form>\r\n\r\n<ng-template #arrowUp>\r\n <svg\r\n _ngcontent-vre-c235=\"\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n viewBox=\"0 0 100 100\"\r\n xml:space=\"preserve\"\r\n class=\"ngil-time-picker__arrow\"\r\n >\r\n <polyline\r\n _ngcontent-vre-c235=\"\"\r\n fill=\"none\"\r\n stroke=\"#000000\"\r\n stroke-width=\"10\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"\r\n points=\"10, 75 50, 25 90, 75\"\r\n ></polyline>\r\n </svg>\r\n</ng-template>\r\n\r\n<ng-template #arrowDown>\r\n <svg\r\n _ngcontent-vre-c235=\"\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n viewBox=\"0 0 100 100\"\r\n xml:space=\"preserve\"\r\n class=\"ngil-time-picker__arrow\"\r\n >\r\n <polyline\r\n _ngcontent-vre-c235=\"\"\r\n fill=\"none\"\r\n stroke=\"#000000\"\r\n stroke-width=\"10\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"\r\n points=\"10, 25 50, 75 90, 25\"\r\n ></polyline>\r\n </svg>\r\n</ng-template>\r\n", styles: [".ngil-time-picker{display:flex;align-items:center;background:#fff;border:1px solid #000;gap:.5rem;padding:.5rem}.ngil-time-picker__field{width:25px;position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}.ngil-time-picker__input{width:calc(100% - 7px);padding:3px;text-align:center}.ngil-time-picker__button{background:none;border:none;position:relative;display:flex}.ngil-time-picker__arrow{width:18px;height:18px;cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i3.NumberRotationDirective, selector: "input[ngilNumberRotation]", inputs: ["min", "max", "buttonUp", "buttonDown"] }] }); }
|
|
54
|
+
}
|
|
55
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: NgilTimePickerComponent, decorators: [{
|
|
56
|
+
type: Component,
|
|
57
|
+
args: [{ selector: 'ngil-time-picker', providers: [
|
|
58
|
+
{
|
|
59
|
+
provide: NG_VALUE_ACCESSOR,
|
|
60
|
+
useExisting: NgilTimePickerComponent,
|
|
61
|
+
multi: true
|
|
62
|
+
}
|
|
63
|
+
], template: "<form [formGroup]=\"formGroup\" class=\"ngil-time-picker\">\r\n <div class=\"ngil-time-picker__field\">\r\n <button #hourButtonUp class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowUp\"></ng-container>\r\n </button>\r\n <input\r\n ngilNumberRotation\r\n class=\"ngil-time-picker__input\"\r\n formControlName=\"hour\"\r\n [buttonUp]=\"hourButtonUp\"\r\n [buttonDown]=\"hourButtonDown\"\r\n [max]=\"23\"\r\n [min]=\"0\"\r\n (blur)=\"onBlur()\"\r\n />\r\n <button #hourButtonDown class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowDown\"></ng-container>\r\n </button>\r\n </div>\r\n\r\n <span>:</span>\r\n\r\n <div class=\"ngil-time-picker__field\">\r\n <button #minuteButtonUp class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowUp\"></ng-container>\r\n </button>\r\n <input\r\n ngilNumberRotation\r\n class=\"ngil-time-picker__input\"\r\n formControlName=\"minute\"\r\n [buttonUp]=\"minuteButtonUp\"\r\n [buttonDown]=\"minuteButtonDown\"\r\n [max]=\"59\"\r\n [min]=\"0\"\r\n (blur)=\"onBlur()\"\r\n />\r\n <button #minuteButtonDown class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowDown\"></ng-container>\r\n </button>\r\n </div>\r\n\r\n <span>:</span>\r\n\r\n <div class=\"ngil-time-picker__field\">\r\n <button #secondButtonUp class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowUp\"></ng-container>\r\n </button>\r\n <input\r\n ngilNumberRotation\r\n class=\"ngil-time-picker__input\"\r\n formControlName=\"second\"\r\n [buttonUp]=\"secondButtonUp\"\r\n [buttonDown]=\"secondButtonDown\"\r\n [max]=\"59\"\r\n [min]=\"0\"\r\n (blur)=\"onBlur()\"\r\n />\r\n <button #secondButtonDown class=\"ngil-time-picker__button\">\r\n <ng-container *ngTemplateOutlet=\"arrowDown\"></ng-container>\r\n </button>\r\n </div>\r\n</form>\r\n\r\n<ng-template #arrowUp>\r\n <svg\r\n _ngcontent-vre-c235=\"\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n viewBox=\"0 0 100 100\"\r\n xml:space=\"preserve\"\r\n class=\"ngil-time-picker__arrow\"\r\n >\r\n <polyline\r\n _ngcontent-vre-c235=\"\"\r\n fill=\"none\"\r\n stroke=\"#000000\"\r\n stroke-width=\"10\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"\r\n points=\"10, 75 50, 25 90, 75\"\r\n ></polyline>\r\n </svg>\r\n</ng-template>\r\n\r\n<ng-template #arrowDown>\r\n <svg\r\n _ngcontent-vre-c235=\"\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n viewBox=\"0 0 100 100\"\r\n xml:space=\"preserve\"\r\n class=\"ngil-time-picker__arrow\"\r\n >\r\n <polyline\r\n _ngcontent-vre-c235=\"\"\r\n fill=\"none\"\r\n stroke=\"#000000\"\r\n stroke-width=\"10\"\r\n stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\"\r\n points=\"10, 25 50, 75 90, 25\"\r\n ></polyline>\r\n </svg>\r\n</ng-template>\r\n", styles: [".ngil-time-picker{display:flex;align-items:center;background:#fff;border:1px solid #000;gap:.5rem;padding:.5rem}.ngil-time-picker__field{width:25px;position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}.ngil-time-picker__input{width:calc(100% - 7px);padding:3px;text-align:center}.ngil-time-picker__button{background:none;border:none;position:relative;display:flex}.ngil-time-picker__arrow{width:18px;height:18px;cursor:pointer}\n"] }]
|
|
64
|
+
}] });
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/ngil/ui/form-inputs/src/lib/components/time-picker/time-picker.component.ts","../../../../../../../../../libs/ngil/ui/form-inputs/src/lib/components/time-picker/time-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAC3E,OAAO,EAAE,sBAAsB,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;;AAe3C,MAAM,OAAO,uBAAwB,SAAQ,sBAAuC;IAZpF;;QAaU,iBAAY,GAAoB,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;QAE1E,UAAK,GAAG,EAAE,CAAC;QACX,cAAS,GAAG,IAAI,SAAS,CAAC;YACxB,IAAI,EAAE,IAAI,WAAW,CAAS,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;YAC5E,MAAM,EAAE,IAAI,WAAW,CAAS,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;YAChF,MAAM,EAAE,IAAI,WAAW,CAAS,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC;SACjF,CAAC,CAAC;KAgCJ;IA9BC,eAAe;QACb,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAES,kBAAkB;QAC1B,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACxE,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;gBAC3C,IAAI,CAAC,QAAQ,CAAC;oBACZ,IAAI,EAAE,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI;oBAC1C,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM;oBAChD,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM;iBACjD,CAAC,CAAC;YACL,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,UAAU,CAAC,KAAsB;QAC/B,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,SAAS,CAAC,QAAQ,CACrB;gBACE,GAAG,IAAI,CAAC,YAAY;gBACpB,GAAG,KAAK;aACT,EACD,EAAE,SAAS,EAAE,KAAK,EAAE,CACrB,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QAChE,CAAC;IACH,CAAC;8GAvCU,uBAAuB;kGAAvB,uBAAuB,2CARvB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,uBAAuB;gBACpC,KAAK,EAAE,IAAI;aACZ;SACF,iDChBH,gpGAwGA;;2FDtFa,uBAAuB;kBAZnC,SAAS;+BACE,kBAAkB,aAGjB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,yBAAyB;4BACpC,KAAK,EAAE,IAAI;yBACZ;qBACF","sourcesContent":["import { AfterViewInit, Component } from '@angular/core';\r\nimport { FormControl, FormGroup, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { AbstractInputComponent } from '@ngil/form-cva';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { TimePickerValue } from './time-picker.model';\r\n\r\n@Component({\r\n  selector: 'ngil-time-picker',\r\n  templateUrl: './time-picker.component.html',\r\n  styleUrls: ['./time-picker.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: NgilTimePickerComponent,\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class NgilTimePickerComponent extends AbstractInputComponent<TimePickerValue> implements AfterViewInit {\r\n  private defaultValue: TimePickerValue = { hour: 0, minute: 0, second: 0 };\r\n\r\n  value = '';\r\n  formGroup = new FormGroup({\r\n    hour: new FormControl<number>(this.defaultValue.hour, { nonNullable: true }),\r\n    minute: new FormControl<number>(this.defaultValue.minute, { nonNullable: true }),\r\n    second: new FormControl<number>(this.defaultValue.second, { nonNullable: true })\r\n  });\r\n\r\n  ngAfterViewInit(): void {\r\n    this.listenValueChanges();\r\n  }\r\n\r\n  protected listenValueChanges(): void {\r\n    this.formGroup.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {\r\n      if (this.onChange) {\r\n        const value = this.formGroup.getRawValue();\r\n        this.onChange({\r\n          hour: value.hour ?? this.defaultValue.hour,\r\n          minute: value.minute ?? this.defaultValue.minute,\r\n          second: value.second ?? this.defaultValue.second\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  writeValue(value: TimePickerValue): void {\r\n    if (value) {\r\n      this.formGroup.setValue(\r\n        {\r\n          ...this.defaultValue,\r\n          ...value\r\n        },\r\n        { emitEvent: false }\r\n      );\r\n    } else {\r\n      this.formGroup.reset(this.defaultValue, { emitEvent: false });\r\n    }\r\n  }\r\n}\r\n","<form [formGroup]=\"formGroup\" class=\"ngil-time-picker\">\r\n  <div class=\"ngil-time-picker__field\">\r\n    <button #hourButtonUp class=\"ngil-time-picker__button\">\r\n      <ng-container *ngTemplateOutlet=\"arrowUp\"></ng-container>\r\n    </button>\r\n    <input\r\n      ngilNumberRotation\r\n      class=\"ngil-time-picker__input\"\r\n      formControlName=\"hour\"\r\n      [buttonUp]=\"hourButtonUp\"\r\n      [buttonDown]=\"hourButtonDown\"\r\n      [max]=\"23\"\r\n      [min]=\"0\"\r\n      (blur)=\"onBlur()\"\r\n    />\r\n    <button #hourButtonDown class=\"ngil-time-picker__button\">\r\n      <ng-container *ngTemplateOutlet=\"arrowDown\"></ng-container>\r\n    </button>\r\n  </div>\r\n\r\n  <span>:</span>\r\n\r\n  <div class=\"ngil-time-picker__field\">\r\n    <button #minuteButtonUp class=\"ngil-time-picker__button\">\r\n      <ng-container *ngTemplateOutlet=\"arrowUp\"></ng-container>\r\n    </button>\r\n    <input\r\n      ngilNumberRotation\r\n      class=\"ngil-time-picker__input\"\r\n      formControlName=\"minute\"\r\n      [buttonUp]=\"minuteButtonUp\"\r\n      [buttonDown]=\"minuteButtonDown\"\r\n      [max]=\"59\"\r\n      [min]=\"0\"\r\n      (blur)=\"onBlur()\"\r\n    />\r\n    <button #minuteButtonDown class=\"ngil-time-picker__button\">\r\n      <ng-container *ngTemplateOutlet=\"arrowDown\"></ng-container>\r\n    </button>\r\n  </div>\r\n\r\n  <span>:</span>\r\n\r\n  <div class=\"ngil-time-picker__field\">\r\n    <button #secondButtonUp class=\"ngil-time-picker__button\">\r\n      <ng-container *ngTemplateOutlet=\"arrowUp\"></ng-container>\r\n    </button>\r\n    <input\r\n      ngilNumberRotation\r\n      class=\"ngil-time-picker__input\"\r\n      formControlName=\"second\"\r\n      [buttonUp]=\"secondButtonUp\"\r\n      [buttonDown]=\"secondButtonDown\"\r\n      [max]=\"59\"\r\n      [min]=\"0\"\r\n      (blur)=\"onBlur()\"\r\n    />\r\n    <button #secondButtonDown class=\"ngil-time-picker__button\">\r\n      <ng-container *ngTemplateOutlet=\"arrowDown\"></ng-container>\r\n    </button>\r\n  </div>\r\n</form>\r\n\r\n<ng-template #arrowUp>\r\n  <svg\r\n    _ngcontent-vre-c235=\"\"\r\n    xmlns=\"http://www.w3.org/2000/svg\"\r\n    xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n    viewBox=\"0 0 100 100\"\r\n    xml:space=\"preserve\"\r\n    class=\"ngil-time-picker__arrow\"\r\n  >\r\n    <polyline\r\n      _ngcontent-vre-c235=\"\"\r\n      fill=\"none\"\r\n      stroke=\"#000000\"\r\n      stroke-width=\"10\"\r\n      stroke-linecap=\"round\"\r\n      stroke-linejoin=\"round\"\r\n      points=\"10, 75 50, 25 90, 75\"\r\n    ></polyline>\r\n  </svg>\r\n</ng-template>\r\n\r\n<ng-template #arrowDown>\r\n  <svg\r\n    _ngcontent-vre-c235=\"\"\r\n    xmlns=\"http://www.w3.org/2000/svg\"\r\n    xmlns:xlink=\"http://www.w3.org/1999/xlink\"\r\n    viewBox=\"0 0 100 100\"\r\n    xml:space=\"preserve\"\r\n    class=\"ngil-time-picker__arrow\"\r\n  >\r\n    <polyline\r\n      _ngcontent-vre-c235=\"\"\r\n      fill=\"none\"\r\n      stroke=\"#000000\"\r\n      stroke-width=\"10\"\r\n      stroke-linecap=\"round\"\r\n      stroke-linejoin=\"round\"\r\n      points=\"10, 25 50, 75 90, 25\"\r\n    ></polyline>\r\n  </svg>\r\n</ng-template>\r\n"]}
|
|
@@ -0,0 +1,114 @@
|
|
|
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"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1waWNrZXIubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL25naWwvdWkvZm9ybS1pbnB1dHMvc3JjL2xpYi9jb21wb25lbnRzL3RpbWUtcGlja2VyL3RpbWUtcGlja2VyLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIFRpbWVQaWNrZXJWYWx1ZSB7XHJcbiAgaG91cjogbnVtYmVyO1xyXG4gIG1pbnV0ZTogbnVtYmVyO1xyXG4gIHNlY29uZDogbnVtYmVyO1xyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,24 @@
|
|
|
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{background:none;border:none}\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{background:none;border:none}\n"] }]
|
|
18
|
+
}], propDecorators: { picker: [{
|
|
19
|
+
type: Input
|
|
20
|
+
}], onClick: [{
|
|
21
|
+
type: HostListener,
|
|
22
|
+
args: ['click', ['$event']]
|
|
23
|
+
}] } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlja2VyLXRvZ2dsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmdpbC91aS9mb3JtLWlucHV0cy9zcmMvbGliL2NvbXBvbmVudHMvdGltZS1waWNrZXItb3ZlcmxheS9waWNrZXItdG9nZ2xlLnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9uZ2lsL3VpL2Zvcm0taW5wdXRzL3NyYy9saWIvY29tcG9uZW50cy90aW1lLXBpY2tlci1vdmVybGF5L3BpY2tlci10b2dnbGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBVTNHLE1BQU0sT0FBTyxxQkFBcUI7SUFQbEM7UUFVcUMsWUFBTyxHQUFHLENBQUMsS0FBWSxFQUFFLEVBQUU7WUFDNUQsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsTUFBTSxFQUFFLENBQUM7Z0JBQ3pCLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUM7WUFDdEIsQ0FBQztZQUNELEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUMxQixDQUFDLENBQUM7S0FDSDs4R0FUWSxxQkFBcUI7a0dBQXJCLHFCQUFxQiw2SUNWbEMsZ2NBY0E7OzJGREphLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDRSxvQkFBb0IsaUJBR2YsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTTs4QkFHdEMsTUFBTTtzQkFBZCxLQUFLO2dCQUU2QixPQUFPO3NCQUF6QyxZQUFZO3VCQUFDLE9BQU8sRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEhvc3RMaXN0ZW5lciwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE5naWxUaW1lUGlja2VyT3ZlcmxheUNvbXBvbmVudCB9IGZyb20gJy4vdGltZS1waWNrZXItb3ZlcmxheS5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICduZ2lsLXBpY2tlci10b2dnbGUnLFxyXG4gIHRlbXBsYXRlVXJsOiAncGlja2VyLXRvZ2dsZS5odG1sJyxcclxuICBzdHlsZVVybHM6IFsncGlja2VyLXRvZ2dsZS5zY3NzJ10sXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUGlja2VyVG9nZ2xlQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBwaWNrZXI6IE5naWxUaW1lUGlja2VyT3ZlcmxheUNvbXBvbmVudCB8IHVuZGVmaW5lZDtcclxuXHJcbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snLCBbJyRldmVudCddKSBvbkNsaWNrID0gKGV2ZW50OiBFdmVudCkgPT4ge1xyXG4gICAgaWYgKCF0aGlzLnBpY2tlcj8uaXNPcGVuKSB7XHJcbiAgICAgIHRoaXMucGlja2VyPy5vcGVuKCk7XHJcbiAgICB9XHJcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcclxuICB9O1xyXG59XHJcbiIsIjxidXR0b24gY2xhc3M9XCJ0b2dnbGUtYnV0dG9uXCIgdHlwZT1cImJ1dHRvblwiPlxyXG4gIDxzdmdcclxuICAgIGNsYXNzPVwibWF0LWRhdGVwaWNrZXItdG9nZ2xlLWRlZmF1bHQtaWNvblwiXHJcbiAgICB2aWV3Qm94PVwiMCAwIDI0IDI0XCJcclxuICAgIHdpZHRoPVwiMjRweFwiXHJcbiAgICBoZWlnaHQ9XCIyNHB4XCJcclxuICAgIGZpbGw9XCJjdXJyZW50Q29sb3JcIlxyXG4gICAgZm9jdXNhYmxlPVwiZmFsc2VcIlxyXG4gID5cclxuICAgIDxwYXRoXHJcbiAgICAgIGQ9XCJNMTkgM2gtMVYxaC0ydjJIOFYxSDZ2Mkg1Yy0xLjExIDAtMS45OS45LTEuOTkgMkwzIDE5YzAgMS4xLjg5IDIgMiAyaDE0YzEuMSAwIDItLjkgMi0yVjVjMC0xLjEtLjktMi0yLTJ6bTAgMTZINVY4aDE0djExek03IDEwaDV2NUg3elwiXHJcbiAgICAvPlxyXG4gIDwvc3ZnPlxyXG48L2J1dHRvbj5cclxuIl19
|
|
@@ -0,0 +1,114 @@
|
|
|
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"]}
|
|
@@ -0,0 +1,102 @@
|
|
|
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=
|
|
@@ -0,0 +1,68 @@
|
|
|
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==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdpbC1mb3JtLWlucHV0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbmdpbC91aS9mb3JtLWlucHV0cy9zcmMvbmdpbC1mb3JtLWlucHV0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|