@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.
Files changed (33) hide show
  1. package/README.md +9 -0
  2. package/esm2022/index.mjs +11 -0
  3. package/esm2022/lib/components/input/input.component.mjs +55 -0
  4. package/esm2022/lib/components/overlay/overlay-toggle.directive.mjs +57 -0
  5. package/esm2022/lib/components/overlay/overlay.component.mjs +106 -0
  6. package/esm2022/lib/components/select/select.component.mjs +69 -0
  7. package/esm2022/lib/components/select-options/select-options.component.mjs +58 -0
  8. package/esm2022/lib/components/textarea/textarea.component.mjs +45 -0
  9. package/esm2022/lib/components/time-picker/time-picker.component.mjs +65 -0
  10. package/esm2022/lib/components/time-picker/time-picker.directive.mjs +114 -0
  11. package/esm2022/lib/components/time-picker/time-picker.model.mjs +2 -0
  12. package/esm2022/lib/components/time-picker-overlay/picker-toggle.mjs +24 -0
  13. package/esm2022/lib/components/time-picker-overlay/time-picker-overlay.component.mjs +114 -0
  14. package/esm2022/lib/directives/number-rotation.directive.mjs +102 -0
  15. package/esm2022/lib/ngil-ui-form.module.mjs +68 -0
  16. package/esm2022/ngil-form-inputs.mjs +5 -0
  17. package/fesm2022/ngil-form-inputs.mjs +813 -0
  18. package/fesm2022/ngil-form-inputs.mjs.map +1 -0
  19. package/index.d.ts +10 -0
  20. package/lib/components/input/input.component.d.ts +14 -0
  21. package/lib/components/overlay/overlay-toggle.directive.d.ts +16 -0
  22. package/lib/components/overlay/overlay.component.d.ts +22 -0
  23. package/lib/components/select/select.component.d.ts +16 -0
  24. package/lib/components/select-options/select-options.component.d.ts +17 -0
  25. package/lib/components/textarea/textarea.component.d.ts +12 -0
  26. package/lib/components/time-picker/time-picker.component.d.ts +19 -0
  27. package/lib/components/time-picker/time-picker.directive.d.ts +28 -0
  28. package/lib/components/time-picker/time-picker.model.d.ts +5 -0
  29. package/lib/components/time-picker-overlay/picker-toggle.d.ts +8 -0
  30. package/lib/components/time-picker-overlay/time-picker-overlay.component.d.ts +26 -0
  31. package/lib/directives/number-rotation.directive.d.ts +26 -0
  32. package/lib/ngil-ui-form.module.d.ts +20 -0
  33. 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==