vcomply-workflow-engine 3.4.27 → 3.4.28

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 (39) hide show
  1. package/esm2020/lib/constants/time.constants.mjs +2 -0
  2. package/esm2020/lib/log-an-issue/log-an-issue.component.mjs +29 -12
  3. package/esm2020/lib/sharedComponents/frequency/frequency-annual/frequency-annual.component.mjs +4 -3
  4. package/esm2020/lib/sharedComponents/frequency/frequency-biannual/frequency-biannual.component.mjs +4 -3
  5. package/esm2020/lib/sharedComponents/frequency/frequency-daily/frequency-daily.component.mjs +4 -3
  6. package/esm2020/lib/sharedComponents/frequency/frequency-monthly/frequency-monthly.component.mjs +4 -3
  7. package/esm2020/lib/sharedComponents/frequency/frequency-on-completion-of/frequency-on-completion-of.component.mjs +17 -8
  8. package/esm2020/lib/sharedComponents/frequency/frequency-one-time/frequency-one-time.component.mjs +15 -6
  9. package/esm2020/lib/sharedComponents/frequency/frequency-ongoing/frequency-ongoing.component.mjs +4 -3
  10. package/esm2020/lib/sharedComponents/frequency/frequency-quarterly/frequency-quarterly.component.mjs +4 -3
  11. package/esm2020/lib/sharedComponents/frequency/frequency-random/frequency-random.component.mjs +3 -2
  12. package/esm2020/lib/sharedComponents/frequency/frequency-top/frequency-top.component.mjs +14 -6
  13. package/esm2020/lib/sharedComponents/frequency/frequency-weekly/frequency-weekly.component.mjs +4 -3
  14. package/esm2020/lib/sharedComponents/frequency/frequency.service.mjs +3 -2
  15. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-one-time/frequency-dialog-one-time.component.mjs +3 -3
  16. package/esm2020/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.mjs +5 -3
  17. package/esm2020/lib/ui-kit/time-picker/constants/constant.mjs +5 -0
  18. package/esm2020/lib/ui-kit/time-picker/time-picker/time-picker.component.mjs +194 -0
  19. package/esm2020/lib/ui-kit/time-picker/time-picker.module.mjs +24 -0
  20. package/esm2020/lib/workflow-compliance/workflow-compliance.component.mjs +8 -7
  21. package/esm2020/lib/workflow-engine.module.mjs +7 -3
  22. package/esm2020/lib/workflow-policy/workflow-policy.component.mjs +5 -4
  23. package/esm2020/lib/workflow-services/log-issue.service.mjs +39 -140
  24. package/fesm2015/vcomply-workflow-engine.mjs +369 -221
  25. package/fesm2015/vcomply-workflow-engine.mjs.map +1 -1
  26. package/fesm2020/vcomply-workflow-engine.mjs +351 -202
  27. package/fesm2020/vcomply-workflow-engine.mjs.map +1 -1
  28. package/lib/constants/time.constants.d.ts +1 -0
  29. package/lib/log-an-issue/log-an-issue.component.d.ts +2 -3
  30. package/lib/sharedComponents/frequency/frequency-on-completion-of/frequency-on-completion-of.component.d.ts +2 -0
  31. package/lib/sharedComponents/frequency/frequency-one-time/frequency-one-time.component.d.ts +2 -0
  32. package/lib/sharedComponents/frequency/frequency-top/frequency-top.component.d.ts +2 -0
  33. package/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.d.ts +1 -0
  34. package/lib/ui-kit/time-picker/constants/constant.d.ts +4 -0
  35. package/lib/ui-kit/time-picker/time-picker/time-picker.component.d.ts +25 -0
  36. package/lib/ui-kit/time-picker/time-picker.module.d.ts +8 -0
  37. package/lib/workflow-engine.module.d.ts +2 -1
  38. package/lib/workflow-services/log-issue.service.d.ts +0 -1
  39. package/package.json +2 -2
@@ -1,5 +1,6 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import moment from 'moment/moment';
3
+ import { DEFAULT_TIME } from '../../../constants/time.constants';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@angular/forms";
5
6
  import * as i2 from "@angular/common";
@@ -18,6 +19,7 @@ export class FrequencyDialogTopComponent {
18
19
  this.todayDate = new Date();
19
20
  this.dateObjectData = new Date();
20
21
  this.timeData = '11:00 pm';
22
+ this.DEFAULT_TIME = DEFAULT_TIME;
21
23
  }
22
24
  ngOnInit() { }
23
25
  enterValueFirst(event, actionType) {
@@ -97,10 +99,10 @@ export class FrequencyDialogTopComponent {
97
99
  }
98
100
  }
99
101
  FrequencyDialogTopComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FrequencyDialogTopComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
100
- FrequencyDialogTopComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FrequencyDialogTopComponent, selector: "app-frequency-dialog-top", inputs: { occurrenceFirst: "occurrenceFirst", id: "id", inputTime: "inputTime", frequencyType: "frequencyType", yearlyDay: "yearlyDay" }, outputs: { valueChangedFirst: "valueChangedFirst", nextDisable: "nextDisable", timeChanged: "timeChanged", yearlyDateChanged: "yearlyDateChanged" }, ngImport: i0, template: "<!-- <div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">Every</div>\r\n <input type=\"number\" value=\"1\" />\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">week by</div>\r\n <input type=\"number\" value=\"1\" *ngIf=\"false\" />\r\n <div *ngIf=\"false\" class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n <div class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\">\r\n <input type=\"text\" readonly aria-label=\"12hr format\" [ngxTimepicker]=\"dailyTime\" placeholder=\"11:59 PM\">\r\n <i class=\"icons vx-fs-12 vx-txt-blue\">&#xe955;</i>\r\n <ngx-material-timepicker #dailyTime></ngx-material-timepicker>\r\n </div>\r\n</div> -->\r\n\r\n\r\n<div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">{{id === 0 || id === 1 || id === 5 ? 'Every' : 'Day'}}</div>\r\n <input type=\"number\"\r\n [id]=\"'occurrence' + id\"\r\n [(ngModel)]=\"occurrenceFirst\"\r\n class=\"day-counter\"\r\n onkeydown=\"return event.keyCode !== 190\" min=\"0\" oninput=\"this.value = Math.abs(this.value)\"\r\n (focusout) = \"enterValueFirst($event, 'occurrenceFirst')\" />\r\n <div *ngIf=\"frequencyType === 1\" class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">{{ occurrenceFirst > 1 ? 'weeks' : 'week' }} by </div>\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\" *ngIf=\"id !== 0 && id !== 1 && id !== 5\">by</div>\r\n <ng-container *ngIf=\"frequencyType === 2\">\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">{{ occurrenceFirst > 1 ? 'years' : 'year' }} on day</div>\r\n <input type=\"number\" type=\"number\" [id]=\"'occurrence-day' + id\" [(ngModel)]=\"yearlyDay\" (focusout)=\"enterYearDay($event)\" onkeydown=\"return event.keyCode !== 190\" min=\"0\" oninput=\"this.value = Math.abs(this.value)\" />\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n </ng-container>\r\n <div class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\">\r\n <input type=\"text\" [id]=\"'time-picker-input-top'+id\" [(ngModel)]=\"inputTime\" readonly aria-label=\"12hr format\" placeholder=\"11:59 PM\">\r\n <!-- <i class=\"icons vx-fs-12 vx-txt-blue\">&#xe955;</i> -->\r\n <ngx-material-timepicker [id]=\"'time-picker-top'+id\" [hoursOnly]=\"true\" (timeChanged)=\"onTimeChanged($event)\" #dailyTime></ngx-material-timepicker>\r\n </div>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .frequency-dialog-top input[type=number]{background:transparent;border-radius:0;border:none;border-bottom:1px solid #dbdbdb;color:#161b2f;font-size:13px;height:1.5rem;width:3rem;text-align:center;outline:none}::ng-deep .frequency-dialog-top input[type=number]::-webkit-outer-spin-button,::ng-deep .frequency-dialog-top input[type=number]::-webkit-inner-spin-button{-moz-appearance:none;-webkit-appearance:none;margin:0}::ng-deep .frequency-dialog-top .time-picker{border-radius:.25rem;border:1px solid #dbdbdb;height:2rem;width:6.25rem;position:relative}::ng-deep .frequency-dialog-top .time-picker input{background:transparent;border-radius:0;border:none;color:#161b2f;font-size:13px;margin:0!important;padding:0 0 0 .75rem;position:absolute;top:0;left:0;height:100%;width:100%;cursor:pointer}::ng-deep .frequency-dialog-top .time-picker input::placeholder{color:#161b2f}::ng-deep .frequency-dialog-top .time-picker input:focus{outline:none}\n"], dependencies: [{ kind: "directive", type: i1.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: i1.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.NgxMaterialTimepickerComponent, selector: "ngx-material-timepicker", inputs: ["ESC", "hoursOnly", "ngxMaterialTimepickerTheme", "format", "minutesGap", "cancelBtnTmpl", "editableHintTmpl", "confirmBtnTmpl", "enableKeyboardInput", "preventOverlayClick", "disableAnimation", "appendToInput", "defaultTime", "timepickerClass", "theme", "min", "max"], outputs: ["timeSet", "opened", "closed", "hourSelected", "timeChanged"] }] });
102
+ FrequencyDialogTopComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: FrequencyDialogTopComponent, selector: "app-frequency-dialog-top", inputs: { occurrenceFirst: "occurrenceFirst", id: "id", inputTime: "inputTime", frequencyType: "frequencyType", yearlyDay: "yearlyDay" }, outputs: { valueChangedFirst: "valueChangedFirst", nextDisable: "nextDisable", timeChanged: "timeChanged", yearlyDateChanged: "yearlyDateChanged" }, ngImport: i0, template: "<div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">\r\n {{ id === 0 || id === 1 || id === 5 ? \"Every\" : \"Day\" }}\r\n </div>\r\n <input\r\n type=\"number\"\r\n [id]=\"'occurrence' + id\"\r\n [(ngModel)]=\"occurrenceFirst\"\r\n class=\"day-counter\"\r\n onkeydown=\"return event.keyCode !== 190\"\r\n min=\"0\"\r\n oninput=\"this.value = Math.abs(this.value)\"\r\n (focusout)=\"enterValueFirst($event, 'occurrenceFirst')\"\r\n />\r\n <div\r\n *ngIf=\"frequencyType === 1\"\r\n class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\"\r\n >\r\n {{ occurrenceFirst > 1 ? \"weeks\" : \"week\" }} by\r\n </div>\r\n <div\r\n class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\"\r\n *ngIf=\"id !== 0 && id !== 1 && id !== 5\"\r\n >\r\n by\r\n </div>\r\n <ng-container *ngIf=\"frequencyType === 2\">\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">\r\n {{ occurrenceFirst > 1 ? \"years\" : \"year\" }} on day\r\n </div>\r\n <input\r\n type=\"number\"\r\n type=\"number\"\r\n [id]=\"'occurrence-day' + id\"\r\n [(ngModel)]=\"yearlyDay\"\r\n (focusout)=\"enterYearDay($event)\"\r\n onkeydown=\"return event.keyCode !== 190\"\r\n min=\"0\"\r\n oninput=\"this.value = Math.abs(this.value)\"\r\n />\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n </ng-container>\r\n <div class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\">\r\n <input\r\n type=\"text\"\r\n [id]=\"'time-picker-input-top' + id\"\r\n [(ngModel)]=\"inputTime\"\r\n readonly\r\n aria-label=\"12hr format\"\r\n [placeholder]=\"DEFAULT_TIME\"\r\n />\r\n <ngx-material-timepicker\r\n [id]=\"'time-picker-top' + id\"\r\n [hoursOnly]=\"true\"\r\n (timeChanged)=\"onTimeChanged($event)\"\r\n #dailyTime\r\n ></ngx-material-timepicker>\r\n </div>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .frequency-dialog-top input[type=number]{background:transparent;border-radius:0;border:none;border-bottom:1px solid #dbdbdb;color:#161b2f;font-size:13px;height:1.5rem;width:3rem;text-align:center;outline:none}::ng-deep .frequency-dialog-top input[type=number]::-webkit-outer-spin-button,::ng-deep .frequency-dialog-top input[type=number]::-webkit-inner-spin-button{-moz-appearance:none;-webkit-appearance:none;margin:0}::ng-deep .frequency-dialog-top .time-picker{border-radius:.25rem;border:1px solid #dbdbdb;height:2rem;width:6.25rem;position:relative}::ng-deep .frequency-dialog-top .time-picker input{background:transparent;border-radius:0;border:none;color:#161b2f;font-size:13px;margin:0!important;padding:0 0 0 .75rem;position:absolute;top:0;left:0;height:100%;width:100%;cursor:pointer}::ng-deep .frequency-dialog-top .time-picker input::placeholder{color:#161b2f}::ng-deep .frequency-dialog-top .time-picker input:focus{outline:none}\n"], dependencies: [{ kind: "directive", type: i1.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: i1.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.NgxMaterialTimepickerComponent, selector: "ngx-material-timepicker", inputs: ["ESC", "hoursOnly", "ngxMaterialTimepickerTheme", "format", "minutesGap", "cancelBtnTmpl", "editableHintTmpl", "confirmBtnTmpl", "enableKeyboardInput", "preventOverlayClick", "disableAnimation", "appendToInput", "defaultTime", "timepickerClass", "theme", "min", "max"], outputs: ["timeSet", "opened", "closed", "hourSelected", "timeChanged"] }] });
101
103
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: FrequencyDialogTopComponent, decorators: [{
102
104
  type: Component,
103
- args: [{ selector: 'app-frequency-dialog-top', template: "<!-- <div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">Every</div>\r\n <input type=\"number\" value=\"1\" />\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">week by</div>\r\n <input type=\"number\" value=\"1\" *ngIf=\"false\" />\r\n <div *ngIf=\"false\" class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n <div class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\">\r\n <input type=\"text\" readonly aria-label=\"12hr format\" [ngxTimepicker]=\"dailyTime\" placeholder=\"11:59 PM\">\r\n <i class=\"icons vx-fs-12 vx-txt-blue\">&#xe955;</i>\r\n <ngx-material-timepicker #dailyTime></ngx-material-timepicker>\r\n </div>\r\n</div> -->\r\n\r\n\r\n<div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">{{id === 0 || id === 1 || id === 5 ? 'Every' : 'Day'}}</div>\r\n <input type=\"number\"\r\n [id]=\"'occurrence' + id\"\r\n [(ngModel)]=\"occurrenceFirst\"\r\n class=\"day-counter\"\r\n onkeydown=\"return event.keyCode !== 190\" min=\"0\" oninput=\"this.value = Math.abs(this.value)\"\r\n (focusout) = \"enterValueFirst($event, 'occurrenceFirst')\" />\r\n <div *ngIf=\"frequencyType === 1\" class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">{{ occurrenceFirst > 1 ? 'weeks' : 'week' }} by </div>\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\" *ngIf=\"id !== 0 && id !== 1 && id !== 5\">by</div>\r\n <ng-container *ngIf=\"frequencyType === 2\">\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">{{ occurrenceFirst > 1 ? 'years' : 'year' }} on day</div>\r\n <input type=\"number\" type=\"number\" [id]=\"'occurrence-day' + id\" [(ngModel)]=\"yearlyDay\" (focusout)=\"enterYearDay($event)\" onkeydown=\"return event.keyCode !== 190\" min=\"0\" oninput=\"this.value = Math.abs(this.value)\" />\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n </ng-container>\r\n <div class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\">\r\n <input type=\"text\" [id]=\"'time-picker-input-top'+id\" [(ngModel)]=\"inputTime\" readonly aria-label=\"12hr format\" placeholder=\"11:59 PM\">\r\n <!-- <i class=\"icons vx-fs-12 vx-txt-blue\">&#xe955;</i> -->\r\n <ngx-material-timepicker [id]=\"'time-picker-top'+id\" [hoursOnly]=\"true\" (timeChanged)=\"onTimeChanged($event)\" #dailyTime></ngx-material-timepicker>\r\n </div>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .frequency-dialog-top input[type=number]{background:transparent;border-radius:0;border:none;border-bottom:1px solid #dbdbdb;color:#161b2f;font-size:13px;height:1.5rem;width:3rem;text-align:center;outline:none}::ng-deep .frequency-dialog-top input[type=number]::-webkit-outer-spin-button,::ng-deep .frequency-dialog-top input[type=number]::-webkit-inner-spin-button{-moz-appearance:none;-webkit-appearance:none;margin:0}::ng-deep .frequency-dialog-top .time-picker{border-radius:.25rem;border:1px solid #dbdbdb;height:2rem;width:6.25rem;position:relative}::ng-deep .frequency-dialog-top .time-picker input{background:transparent;border-radius:0;border:none;color:#161b2f;font-size:13px;margin:0!important;padding:0 0 0 .75rem;position:absolute;top:0;left:0;height:100%;width:100%;cursor:pointer}::ng-deep .frequency-dialog-top .time-picker input::placeholder{color:#161b2f}::ng-deep .frequency-dialog-top .time-picker input:focus{outline:none}\n"] }]
105
+ args: [{ selector: 'app-frequency-dialog-top', template: "<div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">\r\n {{ id === 0 || id === 1 || id === 5 ? \"Every\" : \"Day\" }}\r\n </div>\r\n <input\r\n type=\"number\"\r\n [id]=\"'occurrence' + id\"\r\n [(ngModel)]=\"occurrenceFirst\"\r\n class=\"day-counter\"\r\n onkeydown=\"return event.keyCode !== 190\"\r\n min=\"0\"\r\n oninput=\"this.value = Math.abs(this.value)\"\r\n (focusout)=\"enterValueFirst($event, 'occurrenceFirst')\"\r\n />\r\n <div\r\n *ngIf=\"frequencyType === 1\"\r\n class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\"\r\n >\r\n {{ occurrenceFirst > 1 ? \"weeks\" : \"week\" }} by\r\n </div>\r\n <div\r\n class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\"\r\n *ngIf=\"id !== 0 && id !== 1 && id !== 5\"\r\n >\r\n by\r\n </div>\r\n <ng-container *ngIf=\"frequencyType === 2\">\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">\r\n {{ occurrenceFirst > 1 ? \"years\" : \"year\" }} on day\r\n </div>\r\n <input\r\n type=\"number\"\r\n type=\"number\"\r\n [id]=\"'occurrence-day' + id\"\r\n [(ngModel)]=\"yearlyDay\"\r\n (focusout)=\"enterYearDay($event)\"\r\n onkeydown=\"return event.keyCode !== 190\"\r\n min=\"0\"\r\n oninput=\"this.value = Math.abs(this.value)\"\r\n />\r\n <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n </ng-container>\r\n <div class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\">\r\n <input\r\n type=\"text\"\r\n [id]=\"'time-picker-input-top' + id\"\r\n [(ngModel)]=\"inputTime\"\r\n readonly\r\n aria-label=\"12hr format\"\r\n [placeholder]=\"DEFAULT_TIME\"\r\n />\r\n <ngx-material-timepicker\r\n [id]=\"'time-picker-top' + id\"\r\n [hoursOnly]=\"true\"\r\n (timeChanged)=\"onTimeChanged($event)\"\r\n #dailyTime\r\n ></ngx-material-timepicker>\r\n </div>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .frequency-dialog-top input[type=number]{background:transparent;border-radius:0;border:none;border-bottom:1px solid #dbdbdb;color:#161b2f;font-size:13px;height:1.5rem;width:3rem;text-align:center;outline:none}::ng-deep .frequency-dialog-top input[type=number]::-webkit-outer-spin-button,::ng-deep .frequency-dialog-top input[type=number]::-webkit-inner-spin-button{-moz-appearance:none;-webkit-appearance:none;margin:0}::ng-deep .frequency-dialog-top .time-picker{border-radius:.25rem;border:1px solid #dbdbdb;height:2rem;width:6.25rem;position:relative}::ng-deep .frequency-dialog-top .time-picker input{background:transparent;border-radius:0;border:none;color:#161b2f;font-size:13px;margin:0!important;padding:0 0 0 .75rem;position:absolute;top:0;left:0;height:100%;width:100%;cursor:pointer}::ng-deep .frequency-dialog-top .time-picker input::placeholder{color:#161b2f}::ng-deep .frequency-dialog-top .time-picker input:focus{outline:none}\n"] }]
104
106
  }], ctorParameters: function () { return []; }, propDecorators: { occurrenceFirst: [{
105
107
  type: Input
106
108
  }], id: [{
@@ -120,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
120
122
  }], yearlyDateChanged: [{
121
123
  type: Output
122
124
  }] } });
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-dialog-top.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport moment from 'moment/moment';\r\n\r\n@Component({\r\n  selector: 'app-frequency-dialog-top',\r\n  templateUrl: './frequency-dialog-top.component.html',\r\n  styleUrls: ['./frequency-dialog-top.component.less'],\r\n})\r\nexport class FrequencyDialogTopComponent implements OnInit {\r\n  @Input() occurrenceFirst = 0;\r\n  @Input() id = 0; // 0 = Daily, 1: weekly, 5: Annually\r\n  @Input() inputTime = '11:00 pm';\r\n  @Input() frequencyType = 0; // 0 = days, 1 = weeks & 2 = years\r\n  @Input() yearlyDay = new Date().getDate();\r\n\r\n  @Output() valueChangedFirst: EventEmitter<any> = new EventEmitter();\r\n  @Output() nextDisable: EventEmitter<any> = new EventEmitter();\r\n  @Output() timeChanged: EventEmitter<any> = new EventEmitter();\r\n  @Output() yearlyDateChanged: EventEmitter<any> = new EventEmitter();\r\n\r\n  todayDate = new Date();\r\n  dateObjectData = new Date();\r\n  timeData = '11:00 pm';\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  enterValueFirst(event: any, actionType: string) {\r\n    if (this.id !== 0 && this.id !== 1 && this.id !== 5) {\r\n      this.enterValue(this.occurrenceFirst, actionType);\r\n      return;\r\n    }\r\n    if (\r\n      !Number.isNaN(Number(this.occurrenceFirst)) &&\r\n      this.occurrenceFirst !== 0 &&\r\n      Number(this.occurrenceFirst) > 0\r\n    ) {\r\n      this.occurrenceFirst = Number(this.occurrenceFirst);\r\n      this.valueChangedFirst.emit({\r\n        type: actionType,\r\n        value: Number(this.occurrenceFirst),\r\n        pageName: '',\r\n      });\r\n    } else {\r\n      this.occurrenceFirst = 1;\r\n    }\r\n  }\r\n\r\n  enterValue(event: any, actionType: any) {\r\n    if (\r\n      !Number.isNaN(Number(event)) &&\r\n      event !== 0 &&\r\n      Number(event) > 0 &&\r\n      Number(event) < 32\r\n    ) {\r\n      this.occurrenceFirst = Number(event);\r\n      this.valueChangedFirst.emit({\r\n        type: actionType,\r\n        value: Number(event),\r\n        pageName: '',\r\n      });\r\n    } else {\r\n      this.occurrenceFirst = new Date().getDate();\r\n    }\r\n  }\r\n\r\n  getToday(): string {\r\n    return moment(Date.now()).format('YYYY-MM-DD HH:mm:ss')?.split(' ')[0];\r\n  }\r\n\r\n  onTimeChanged(event: string) {\r\n    try {\r\n      this.timeData = event;\r\n      if (typeof this.dateObjectData == 'object') {\r\n        this.dateObjectData = moment(this.dateObjectData).toDate();\r\n      }\r\n      let timeStamp = moment(\r\n        this.dateObjectData.getDate() +\r\n          '-' +\r\n          (this.dateObjectData.getMonth() + 1) +\r\n          '-' +\r\n          this.dateObjectData.getFullYear() +\r\n          ' ' +\r\n          this.timeData,\r\n        'DD-MM-YYYY hh:mm a'\r\n      ).unix();\r\n      if (Date.now() / 1000 > timeStamp) {\r\n        this.nextDisable.emit(true);\r\n      } else {\r\n        this.nextDisable.emit(false);\r\n      }\r\n      this.timeChanged.emit(event);\r\n    } catch (e) {\r\n      console.error(e);\r\n    }\r\n  }\r\n\r\n  enterYearDay(event: any) {\r\n    if (\r\n      !Number.isNaN(Number(this.yearlyDay)) &&\r\n      this.yearlyDay !== 0 &&\r\n      Number(this.yearlyDay) > 0 &&\r\n      Number(this.yearlyDay) < 32\r\n    ) {\r\n      //this.yearlyDay = Number(event.target.value);\r\n      this.yearlyDateChanged.emit(this.yearlyDay);\r\n    } else {\r\n      this.yearlyDay = new Date().getDate();\r\n    }\r\n  }\r\n}\r\n","<!-- <div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n    <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">Every</div>\r\n    <input type=\"number\" value=\"1\" />\r\n    <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">week by</div>\r\n    <input type=\"number\" value=\"1\" *ngIf=\"false\" />\r\n    <div *ngIf=\"false\" class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n    <div class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\">\r\n        <input type=\"text\" readonly aria-label=\"12hr format\" [ngxTimepicker]=\"dailyTime\" placeholder=\"11:59 PM\">\r\n        <i class=\"icons vx-fs-12 vx-txt-blue\">&#xe955;</i>\r\n        <ngx-material-timepicker #dailyTime></ngx-material-timepicker>\r\n    </div>\r\n</div> -->\r\n\r\n\r\n<div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n    <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">{{id === 0 || id === 1 || id === 5 ? 'Every' : 'Day'}}</div>\r\n    <input type=\"number\"\r\n        [id]=\"'occurrence' + id\"\r\n        [(ngModel)]=\"occurrenceFirst\"\r\n        class=\"day-counter\"\r\n        onkeydown=\"return event.keyCode !== 190\" min=\"0\" oninput=\"this.value = Math.abs(this.value)\"\r\n        (focusout) = \"enterValueFirst($event, 'occurrenceFirst')\" />\r\n    <div *ngIf=\"frequencyType === 1\" class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">{{ occurrenceFirst > 1 ? 'weeks' : 'week' }} by  </div>\r\n    <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\" *ngIf=\"id !== 0 && id !== 1 && id !== 5\">by</div>\r\n    <ng-container  *ngIf=\"frequencyType === 2\">\r\n        <div  class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">{{ occurrenceFirst > 1 ? 'years' : 'year' }} on day</div>\r\n        <input type=\"number\" type=\"number\" [id]=\"'occurrence-day' + id\" [(ngModel)]=\"yearlyDay\" (focusout)=\"enterYearDay($event)\"  onkeydown=\"return event.keyCode !== 190\" min=\"0\" oninput=\"this.value = Math.abs(this.value)\" />\r\n        <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n    </ng-container>\r\n    <div class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\">\r\n        <input type=\"text\" [id]=\"'time-picker-input-top'+id\" [(ngModel)]=\"inputTime\" readonly aria-label=\"12hr format\"  placeholder=\"11:59 PM\">\r\n        <!-- <i class=\"icons vx-fs-12 vx-txt-blue\">&#xe955;</i> -->\r\n        <ngx-material-timepicker [id]=\"'time-picker-top'+id\" [hoursOnly]=\"true\" (timeChanged)=\"onTimeChanged($event)\" #dailyTime></ngx-material-timepicker>\r\n    </div>\r\n</div>\r\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frequency-dialog-top.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/frequency-dialog/frequency-dialog-top/frequency-dialog-top.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport moment from 'moment/moment';\r\nimport { DEFAULT_TIME } from '../../../constants/time.constants';\r\n\r\n@Component({\r\n  selector: 'app-frequency-dialog-top',\r\n  templateUrl: './frequency-dialog-top.component.html',\r\n  styleUrls: ['./frequency-dialog-top.component.less'],\r\n})\r\nexport class FrequencyDialogTopComponent implements OnInit {\r\n  @Input() occurrenceFirst = 0;\r\n  @Input() id = 0; // 0 = Daily, 1: weekly, 5: Annually\r\n  @Input() inputTime = '11:00 pm';\r\n  @Input() frequencyType = 0; // 0 = days, 1 = weeks & 2 = years\r\n  @Input() yearlyDay = new Date().getDate();\r\n\r\n  @Output() valueChangedFirst: EventEmitter<any> = new EventEmitter();\r\n  @Output() nextDisable: EventEmitter<any> = new EventEmitter();\r\n  @Output() timeChanged: EventEmitter<any> = new EventEmitter();\r\n  @Output() yearlyDateChanged: EventEmitter<any> = new EventEmitter();\r\n\r\n  todayDate = new Date();\r\n  dateObjectData = new Date();\r\n  timeData = '11:00 pm';\r\n  DEFAULT_TIME = DEFAULT_TIME;\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {}\r\n\r\n  enterValueFirst(event: any, actionType: string) {\r\n    if (this.id !== 0 && this.id !== 1 && this.id !== 5) {\r\n      this.enterValue(this.occurrenceFirst, actionType);\r\n      return;\r\n    }\r\n    if (\r\n      !Number.isNaN(Number(this.occurrenceFirst)) &&\r\n      this.occurrenceFirst !== 0 &&\r\n      Number(this.occurrenceFirst) > 0\r\n    ) {\r\n      this.occurrenceFirst = Number(this.occurrenceFirst);\r\n      this.valueChangedFirst.emit({\r\n        type: actionType,\r\n        value: Number(this.occurrenceFirst),\r\n        pageName: '',\r\n      });\r\n    } else {\r\n      this.occurrenceFirst = 1;\r\n    }\r\n  }\r\n\r\n  enterValue(event: any, actionType: any) {\r\n    if (\r\n      !Number.isNaN(Number(event)) &&\r\n      event !== 0 &&\r\n      Number(event) > 0 &&\r\n      Number(event) < 32\r\n    ) {\r\n      this.occurrenceFirst = Number(event);\r\n      this.valueChangedFirst.emit({\r\n        type: actionType,\r\n        value: Number(event),\r\n        pageName: '',\r\n      });\r\n    } else {\r\n      this.occurrenceFirst = new Date().getDate();\r\n    }\r\n  }\r\n\r\n  getToday(): string {\r\n    return moment(Date.now()).format('YYYY-MM-DD HH:mm:ss')?.split(' ')[0];\r\n  }\r\n\r\n  onTimeChanged(event: string) {\r\n    try {\r\n      this.timeData = event;\r\n      if (typeof this.dateObjectData == 'object') {\r\n        this.dateObjectData = moment(this.dateObjectData).toDate();\r\n      }\r\n      let timeStamp = moment(\r\n        this.dateObjectData.getDate() +\r\n          '-' +\r\n          (this.dateObjectData.getMonth() + 1) +\r\n          '-' +\r\n          this.dateObjectData.getFullYear() +\r\n          ' ' +\r\n          this.timeData,\r\n        'DD-MM-YYYY hh:mm a'\r\n      ).unix();\r\n      if (Date.now() / 1000 > timeStamp) {\r\n        this.nextDisable.emit(true);\r\n      } else {\r\n        this.nextDisable.emit(false);\r\n      }\r\n      this.timeChanged.emit(event);\r\n    } catch (e) {\r\n      console.error(e);\r\n    }\r\n  }\r\n\r\n  enterYearDay(event: any) {\r\n    if (\r\n      !Number.isNaN(Number(this.yearlyDay)) &&\r\n      this.yearlyDay !== 0 &&\r\n      Number(this.yearlyDay) > 0 &&\r\n      Number(this.yearlyDay) < 32\r\n    ) {\r\n      //this.yearlyDay = Number(event.target.value);\r\n      this.yearlyDateChanged.emit(this.yearlyDay);\r\n    } else {\r\n      this.yearlyDay = new Date().getDate();\r\n    }\r\n  }\r\n}\r\n","<div class=\"frequency-dialog-top vx-p-3 vx-d-flex vx-align-center\">\r\n  <div class=\"vx-fs-13 vx-paragraph-txt vx-mr-3\">\r\n    {{ id === 0 || id === 1 || id === 5 ? \"Every\" : \"Day\" }}\r\n  </div>\r\n  <input\r\n    type=\"number\"\r\n    [id]=\"'occurrence' + id\"\r\n    [(ngModel)]=\"occurrenceFirst\"\r\n    class=\"day-counter\"\r\n    onkeydown=\"return event.keyCode !== 190\"\r\n    min=\"0\"\r\n    oninput=\"this.value = Math.abs(this.value)\"\r\n    (focusout)=\"enterValueFirst($event, 'occurrenceFirst')\"\r\n  />\r\n  <div\r\n    *ngIf=\"frequencyType === 1\"\r\n    class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\"\r\n  >\r\n    {{ occurrenceFirst > 1 ? \"weeks\" : \"week\" }} by\r\n  </div>\r\n  <div\r\n    class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\"\r\n    *ngIf=\"id !== 0 && id !== 1 && id !== 5\"\r\n  >\r\n    by\r\n  </div>\r\n  <ng-container *ngIf=\"frequencyType === 2\">\r\n    <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">\r\n      {{ occurrenceFirst > 1 ? \"years\" : \"year\" }} on day\r\n    </div>\r\n    <input\r\n      type=\"number\"\r\n      type=\"number\"\r\n      [id]=\"'occurrence-day' + id\"\r\n      [(ngModel)]=\"yearlyDay\"\r\n      (focusout)=\"enterYearDay($event)\"\r\n      onkeydown=\"return event.keyCode !== 190\"\r\n      min=\"0\"\r\n      oninput=\"this.value = Math.abs(this.value)\"\r\n    />\r\n    <div class=\"vx-fs-13 vx-paragraph-txt vx-ml-3 vx-mr-3\">by</div>\r\n  </ng-container>\r\n  <div class=\"time-picker vx-d-flex vx-align-center vx-justify-end vx-pr-3\">\r\n    <input\r\n      type=\"text\"\r\n      [id]=\"'time-picker-input-top' + id\"\r\n      [(ngModel)]=\"inputTime\"\r\n      readonly\r\n      aria-label=\"12hr format\"\r\n      [placeholder]=\"DEFAULT_TIME\"\r\n    />\r\n    <ngx-material-timepicker\r\n      [id]=\"'time-picker-top' + id\"\r\n      [hoursOnly]=\"true\"\r\n      (timeChanged)=\"onTimeChanged($event)\"\r\n      #dailyTime\r\n    ></ngx-material-timepicker>\r\n  </div>\r\n</div>\r\n"]}
@@ -0,0 +1,5 @@
1
+ export const HOURS = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12];
2
+ export const MINUTES = ['', '', '00', '30', ''];
3
+ export const AM_PM = ['', '', 'AM', 'PM', ''];
4
+ export const TIME_VARIABLE = ['HOURS', 'MINUTES', 'MERIDIEM'];
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uc3RhbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi91aS1raXQvdGltZS1waWNrZXIvY29uc3RhbnRzL2NvbnN0YW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLEtBQUssR0FBYSxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUM7QUFDdkUsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFhLENBQUMsRUFBRSxFQUFFLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0FBQzFELE1BQU0sQ0FBQyxNQUFNLEtBQUssR0FBYSxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQztBQUN4RCxNQUFNLENBQUMsTUFBTSxhQUFhLEdBQUcsQ0FBQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IEhPVVJTOiBudW1iZXJbXSA9IFsxLCAyLCAzLCA0LCA1LCA2LCA3LCA4LCA5LCAxMCwgMTEsIDEyXTtcclxuZXhwb3J0IGNvbnN0IE1JTlVURVM6IHN0cmluZ1tdID0gWycnLCAnJywgJzAwJywgJzMwJywgJyddO1xyXG5leHBvcnQgY29uc3QgQU1fUE06IHN0cmluZ1tdID0gWycnLCAnJywgJ0FNJywgJ1BNJywgJyddO1xyXG5leHBvcnQgY29uc3QgVElNRV9WQVJJQUJMRSA9IFsnSE9VUlMnLCAnTUlOVVRFUycsICdNRVJJRElFTSddO1xyXG4iXX0=
@@ -0,0 +1,194 @@
1
+ import { Component, EventEmitter, Input } from '@angular/core';
2
+ import { AM_PM, MINUTES, TIME_VARIABLE } from '../constants/constant';
3
+ import { DEFAULT_TIME } from '../../../constants/time.constants';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ export class TimePickerComponent {
7
+ constructor() {
8
+ this.MINUTES = MINUTES;
9
+ this.AM_PM = AM_PM;
10
+ this.hourArray = [9, 10, 11, 12, 13];
11
+ this.TIME_VARIABLE = TIME_VARIABLE; //['HOURS', 'MINUTES', 'MERIDIEM']
12
+ this.defaultSelectedTime = '';
13
+ this.onTimeSelection = new EventEmitter();
14
+ }
15
+ set defaultTime(inputTime) {
16
+ if (!inputTime) {
17
+ inputTime = DEFAULT_TIME;
18
+ }
19
+ this.defaultSelectedTime = inputTime;
20
+ const timeDetails = inputTime.split(' ');
21
+ const time = timeDetails[0].split(':');
22
+ console.log('time ===>', time);
23
+ this.selectedTime = {
24
+ HOURS: parseInt(time[0]),
25
+ MINUTES: time[1],
26
+ MERIDIEM: timeDetails[1]?.toUpperCase(),
27
+ };
28
+ this.setDefault();
29
+ }
30
+ onScroll(event, type) {
31
+ const scrollStatus = this.getScrollDirection(event);
32
+ switch (type) {
33
+ case this.TIME_VARIABLE[0]:
34
+ this.hourArray = this.handleMouseWheelEvent(this.hourArray, scrollStatus);
35
+ break;
36
+ case this.TIME_VARIABLE[1]:
37
+ this.setMinutes(scrollStatus);
38
+ break;
39
+ case this.TIME_VARIABLE[2]:
40
+ this.setMeridiem(scrollStatus);
41
+ break;
42
+ }
43
+ }
44
+ onValueSelect(value, type) {
45
+ if (value) {
46
+ this.selectedTime[type] = value;
47
+ this.setDefault();
48
+ }
49
+ }
50
+ handleMouseWheelEvent(currentValues, direction) {
51
+ const maxValue = 12;
52
+ const minValue = 1;
53
+ const maxElements = 5;
54
+ if (direction === 'up') {
55
+ let nextValues = [];
56
+ for (let i = 0; i < maxElements; i++) {
57
+ let nextValue = currentValues[0] - 1 + i;
58
+ if (nextValue < minValue) {
59
+ nextValue = maxValue + nextValue;
60
+ }
61
+ nextValues.push(nextValue);
62
+ }
63
+ return nextValues;
64
+ }
65
+ if (direction === 'down') {
66
+ let nextValues = [];
67
+ for (let i = 0; i < maxElements; i++) {
68
+ let nextValue = currentValues[0] + 1 + i;
69
+ if (nextValue > maxValue) {
70
+ nextValue = nextValue - maxValue;
71
+ }
72
+ nextValues.push(nextValue);
73
+ }
74
+ return nextValues;
75
+ }
76
+ return currentValues;
77
+ }
78
+ onCloseTimePicker(actionType) {
79
+ const time = this.selectedTime.HOURS +
80
+ ':' +
81
+ this.selectedTime.MINUTES +
82
+ ' ' +
83
+ this.selectedTime.MERIDIEM;
84
+ this.onTimeSelection.emit({
85
+ actionType: actionType,
86
+ selectedValue: actionType === 'ok' ? time : this.defaultSelectedTime,
87
+ });
88
+ }
89
+ getScrollDirection(event) {
90
+ if (event.deltaY < 0) {
91
+ return 'up';
92
+ }
93
+ else {
94
+ return 'down';
95
+ }
96
+ }
97
+ setMinutes(type) {
98
+ if (type === 'up') {
99
+ const index = this.MINUTES.indexOf('00');
100
+ if (index === 1) {
101
+ this.MINUTES.unshift('');
102
+ this.MINUTES.pop();
103
+ }
104
+ }
105
+ else {
106
+ const index = this.MINUTES.indexOf('00');
107
+ if (index === 2) {
108
+ this.MINUTES.shift();
109
+ this.MINUTES.push('');
110
+ }
111
+ }
112
+ this.findSelectedValue(TIME_VARIABLE[1], this.MINUTES);
113
+ }
114
+ setMeridiem(type) {
115
+ if (type === 'up') {
116
+ const index = this.AM_PM.indexOf('AM');
117
+ if (index === 1) {
118
+ this.AM_PM.unshift('');
119
+ this.AM_PM.pop();
120
+ }
121
+ }
122
+ else {
123
+ const index = this.AM_PM.indexOf('AM');
124
+ if (index === 2) {
125
+ this.AM_PM.shift();
126
+ this.AM_PM.push('');
127
+ }
128
+ }
129
+ this.findSelectedValue(TIME_VARIABLE[2], this.AM_PM);
130
+ }
131
+ findSelectedValue(type, array) {
132
+ this.selectedTime[type] = array[2];
133
+ }
134
+ setDefault() {
135
+ const defaultHours = this.selectedTime.HOURS;
136
+ const defaultMinutes = this.selectedTime.MINUTES;
137
+ const defaultMeridiem = this.selectedTime.MERIDIEM;
138
+ this.hourArray[2] = defaultHours;
139
+ this.setHoursToDefault(defaultHours);
140
+ if (defaultMinutes === '30') {
141
+ this.MINUTES[2] = defaultMinutes;
142
+ this.MINUTES[1] = '00';
143
+ this.MINUTES[3] = '';
144
+ }
145
+ else {
146
+ this.MINUTES[1] = '';
147
+ this.MINUTES[2] = '00';
148
+ this.MINUTES[3] = '30';
149
+ }
150
+ if (defaultMeridiem === 'PM') {
151
+ this.AM_PM[2] = defaultMeridiem;
152
+ this.AM_PM[1] = 'AM';
153
+ this.AM_PM[3] = '';
154
+ // this.setMeridiem('up');
155
+ }
156
+ else {
157
+ this.AM_PM[1] = '';
158
+ this.AM_PM[2] = 'AM';
159
+ this.AM_PM[3] = 'PM';
160
+ }
161
+ }
162
+ setHoursToDefault(defaultHours) {
163
+ let prevIndex = 2;
164
+ let nextIndex = 1;
165
+ this.hourArray = this.hourArray.map((value, index) => {
166
+ value = defaultHours;
167
+ if (index < 2) {
168
+ value = value - prevIndex;
169
+ if (value < 1) {
170
+ value = 12 + value;
171
+ }
172
+ prevIndex--;
173
+ }
174
+ else if (index > 2) {
175
+ value = value + nextIndex;
176
+ if (value > 12) {
177
+ value = value - 12;
178
+ }
179
+ nextIndex++;
180
+ }
181
+ return value;
182
+ });
183
+ }
184
+ }
185
+ TimePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TimePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
186
+ TimePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TimePickerComponent, selector: "app-time-picker", inputs: { defaultTime: ["time", "defaultTime"] }, outputs: { onTimeSelection: "onTimeSelection" }, ngImport: i0, template: "<div class=\"timePicker\">\r\n <div class=\"vx-d-flex vx-align-center vx-justify-center\">\r\n <div class=\"timePicker-inner vx-d-flex vx-align-center vx-p-3\">\r\n <div class=\"timePicker-column\" #hour_column>\r\n <div\r\n *ngFor=\"let eachHour of hourArray; let i = index\"\r\n class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1\"\r\n [class.active]=\"i === 2\"\r\n (mousewheel)=\"onScroll($event, TIME_VARIABLE[0])\"\r\n [id]=\"'hour_column_' + (i + 1)\"\r\n (click)=\"onValueSelect(eachHour, TIME_VARIABLE[0])\"\r\n >\r\n <ng-container *ngIf=\"eachHour > 0 && eachHour < 13\">\r\n {{ eachHour }}\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"timePicker-column\" #minutes_column>\r\n <div\r\n *ngFor=\"let eachMinutes of MINUTES; let i = index\"\r\n class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1\"\r\n [class.active]=\"i === 2\"\r\n [id]=\"'minutes_column_' + (i + 1)\"\r\n (mousewheel)=\"onScroll($event, TIME_VARIABLE[1])\"\r\n (click)=\"onValueSelect(eachMinutes, TIME_VARIABLE[1])\"\r\n >\r\n {{ eachMinutes }}\r\n </div>\r\n </div>\r\n <div class=\"timePicker-column\" #meridiem_column>\r\n <div\r\n *ngFor=\"let eachMeridiem of AM_PM; let i = index\"\r\n class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1 vx-tt-uppercase\"\r\n [class.active]=\"i === 2\"\r\n [id]=\"'meridiem_column_' + (i + 1)\"\r\n (mousewheel)=\"onScroll($event, TIME_VARIABLE[2])\"\r\n (click)=\"onValueSelect(eachMeridiem, TIME_VARIABLE[2])\"\r\n >\r\n {{ eachMeridiem }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div\r\n class=\"timePicker-bottom vx-d-flex vx-align-center vx-justify-between vx-p-2\"\r\n >\r\n <button\r\n (click)=\"onCloseTimePicker('cancel')\"\r\n class=\"cancel-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-lh-6\"\r\n >\r\n CANCEL\r\n </button>\r\n <button\r\n (click)=\"onCloseTimePicker('ok')\"\r\n class=\"ok-btn vx-fs-11 vx-fw-500 vx-txt-white vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-lh-6\"\r\n >\r\n OK\r\n </button>\r\n </div>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/header/header.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/button/button.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/popover/popover.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .timePicker{background:#fff;border-radius:.25rem;box-shadow:0 1px 6px #1c5bd140;width:11.25rem}::ng-deep .timePicker-column{display:flex;flex-flow:column nowrap;justify-content:space-between;align-items:center;max-height:12rem;overflow:hidden;overflow-y:auto}::ng-deep .timePicker-column::-webkit-scrollbar{display:none}::ng-deep .timePicker-no{cursor:pointer;display:flex;justify-content:center;align-items:center;width:2.5rem;min-height:2rem}::ng-deep .timePicker-no.active{background:#f1f1f1;border-radius:.125rem;color:#1e5dd3}::ng-deep .timePicker-bottom{background:#f8f8f8;border-top:1px solid #f1f1f1}::ng-deep .timePicker-bottom button{border-radius:.125rem;height:1.5rem;width:calc(50% - .125rem)}::ng-deep .timePicker-bottom button.cancel-btn{background:#fff;border:1px solid #dbdbdb}::ng-deep .timePicker-bottom button.ok-btn{background:#1e5dd3;border:1px solid #1e5dd3}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
187
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TimePickerComponent, decorators: [{
188
+ type: Component,
189
+ args: [{ selector: 'app-time-picker', outputs: ['onTimeSelection'], template: "<div class=\"timePicker\">\r\n <div class=\"vx-d-flex vx-align-center vx-justify-center\">\r\n <div class=\"timePicker-inner vx-d-flex vx-align-center vx-p-3\">\r\n <div class=\"timePicker-column\" #hour_column>\r\n <div\r\n *ngFor=\"let eachHour of hourArray; let i = index\"\r\n class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1\"\r\n [class.active]=\"i === 2\"\r\n (mousewheel)=\"onScroll($event, TIME_VARIABLE[0])\"\r\n [id]=\"'hour_column_' + (i + 1)\"\r\n (click)=\"onValueSelect(eachHour, TIME_VARIABLE[0])\"\r\n >\r\n <ng-container *ngIf=\"eachHour > 0 && eachHour < 13\">\r\n {{ eachHour }}\r\n </ng-container>\r\n </div>\r\n </div>\r\n <div class=\"timePicker-column\" #minutes_column>\r\n <div\r\n *ngFor=\"let eachMinutes of MINUTES; let i = index\"\r\n class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1\"\r\n [class.active]=\"i === 2\"\r\n [id]=\"'minutes_column_' + (i + 1)\"\r\n (mousewheel)=\"onScroll($event, TIME_VARIABLE[1])\"\r\n (click)=\"onValueSelect(eachMinutes, TIME_VARIABLE[1])\"\r\n >\r\n {{ eachMinutes }}\r\n </div>\r\n </div>\r\n <div class=\"timePicker-column\" #meridiem_column>\r\n <div\r\n *ngFor=\"let eachMeridiem of AM_PM; let i = index\"\r\n class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1 vx-tt-uppercase\"\r\n [class.active]=\"i === 2\"\r\n [id]=\"'meridiem_column_' + (i + 1)\"\r\n (mousewheel)=\"onScroll($event, TIME_VARIABLE[2])\"\r\n (click)=\"onValueSelect(eachMeridiem, TIME_VARIABLE[2])\"\r\n >\r\n {{ eachMeridiem }}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n <div\r\n class=\"timePicker-bottom vx-d-flex vx-align-center vx-justify-between vx-p-2\"\r\n >\r\n <button\r\n (click)=\"onCloseTimePicker('cancel')\"\r\n class=\"cancel-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-lh-6\"\r\n >\r\n CANCEL\r\n </button>\r\n <button\r\n (click)=\"onCloseTimePicker('ok')\"\r\n class=\"ok-btn vx-fs-11 vx-fw-500 vx-txt-white vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-lh-6\"\r\n >\r\n OK\r\n </button>\r\n </div>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/header/header.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/button/button.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/popover/popover.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .timePicker{background:#fff;border-radius:.25rem;box-shadow:0 1px 6px #1c5bd140;width:11.25rem}::ng-deep .timePicker-column{display:flex;flex-flow:column nowrap;justify-content:space-between;align-items:center;max-height:12rem;overflow:hidden;overflow-y:auto}::ng-deep .timePicker-column::-webkit-scrollbar{display:none}::ng-deep .timePicker-no{cursor:pointer;display:flex;justify-content:center;align-items:center;width:2.5rem;min-height:2rem}::ng-deep .timePicker-no.active{background:#f1f1f1;border-radius:.125rem;color:#1e5dd3}::ng-deep .timePicker-bottom{background:#f8f8f8;border-top:1px solid #f1f1f1}::ng-deep .timePicker-bottom button{border-radius:.125rem;height:1.5rem;width:calc(50% - .125rem)}::ng-deep .timePicker-bottom button.cancel-btn{background:#fff;border:1px solid #dbdbdb}::ng-deep .timePicker-bottom button.ok-btn{background:#1e5dd3;border:1px solid #1e5dd3}\n"] }]
190
+ }], ctorParameters: function () { return []; }, propDecorators: { defaultTime: [{
191
+ type: Input,
192
+ args: ['time']
193
+ }] } });
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/ui-kit/time-picker/time-picker/time-picker.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/ui-kit/time-picker/time-picker/time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input } from '@angular/core';\r\nimport { AM_PM, MINUTES, TIME_VARIABLE } from '../constants/constant';\r\nimport { DEFAULT_TIME } from '../../../constants/time.constants';\r\n\r\n@Component({\r\n  selector: 'app-time-picker',\r\n  templateUrl: './time-picker.component.html',\r\n  styleUrls: ['./time-picker.component.less'],\r\n  outputs: ['onTimeSelection'],\r\n})\r\nexport class TimePickerComponent {\r\n  public MINUTES: string[] = MINUTES;\r\n  public AM_PM: string[] = AM_PM;\r\n  private selectedTime: any;\r\n  public hourArray: number[] = [9, 10, 11, 12, 13];\r\n  public TIME_VARIABLE = TIME_VARIABLE; //['HOURS', 'MINUTES', 'MERIDIEM']\r\n  private defaultSelectedTime: string = '';\r\n  @Input('time') set defaultTime(inputTime: string) {\r\n    if (!inputTime) {\r\n      inputTime = DEFAULT_TIME;\r\n    }\r\n    this.defaultSelectedTime = inputTime;\r\n    const timeDetails = inputTime.split(' ');\r\n    const time = timeDetails[0].split(':');\r\n    console.log('time ===>', time);\r\n    this.selectedTime = {\r\n      HOURS: parseInt(time[0]),\r\n      MINUTES: time[1],\r\n      MERIDIEM: timeDetails[1]?.toUpperCase(),\r\n    };\r\n    this.setDefault();\r\n  }\r\n  onTimeSelection: EventEmitter<any> = new EventEmitter();\r\n\r\n  constructor() {}\r\n\r\n  onScroll(event: any, type: any): void {\r\n    const scrollStatus = this.getScrollDirection(event);\r\n\r\n    switch (type) {\r\n      case this.TIME_VARIABLE[0]:\r\n        this.hourArray = this.handleMouseWheelEvent(\r\n          this.hourArray,\r\n          scrollStatus\r\n        );\r\n        break;\r\n      case this.TIME_VARIABLE[1]:\r\n        this.setMinutes(scrollStatus);\r\n        break;\r\n      case this.TIME_VARIABLE[2]:\r\n        this.setMeridiem(scrollStatus);\r\n        break;\r\n    }\r\n  }\r\n\r\n  onValueSelect(value: string | number, type: string): void {\r\n    if (value) {\r\n      this.selectedTime[type] = value;\r\n      this.setDefault();\r\n    }\r\n  }\r\n\r\n  handleMouseWheelEvent(\r\n    currentValues: number[],\r\n    direction: 'up' | 'down'\r\n  ): number[] {\r\n    const maxValue = 12;\r\n    const minValue = 1;\r\n    const maxElements = 5;\r\n\r\n    if (direction === 'up') {\r\n      let nextValues = [];\r\n      for (let i = 0; i < maxElements; i++) {\r\n        let nextValue = currentValues[0] - 1 + i;\r\n        if (nextValue < minValue) {\r\n          nextValue = maxValue + nextValue;\r\n        }\r\n        nextValues.push(nextValue);\r\n      }\r\n      return nextValues;\r\n    }\r\n\r\n    if (direction === 'down') {\r\n      let nextValues = [];\r\n      for (let i = 0; i < maxElements; i++) {\r\n        let nextValue = currentValues[0] + 1 + i;\r\n        if (nextValue > maxValue) {\r\n          nextValue = nextValue - maxValue;\r\n        }\r\n        nextValues.push(nextValue);\r\n      }\r\n      return nextValues;\r\n    }\r\n    return currentValues;\r\n  }\r\n\r\n  onCloseTimePicker(actionType: 'cancel' | 'ok'): void {\r\n    const time =\r\n      this.selectedTime.HOURS +\r\n      ':' +\r\n      this.selectedTime.MINUTES +\r\n      ' ' +\r\n      this.selectedTime.MERIDIEM;\r\n    this.onTimeSelection.emit({\r\n      actionType: actionType,\r\n      selectedValue: actionType === 'ok' ? time : this.defaultSelectedTime,\r\n    });\r\n  }\r\n\r\n  private getScrollDirection(event: any): 'up' | 'down' {\r\n    if (event.deltaY < 0) {\r\n      return 'up';\r\n    } else {\r\n      return 'down';\r\n    }\r\n  }\r\n\r\n  private setMinutes(type: 'up' | 'down') {\r\n    if (type === 'up') {\r\n      const index = this.MINUTES.indexOf('00');\r\n      if (index === 1) {\r\n        this.MINUTES.unshift('');\r\n        this.MINUTES.pop();\r\n      }\r\n    } else {\r\n      const index = this.MINUTES.indexOf('00');\r\n      if (index === 2) {\r\n        this.MINUTES.shift();\r\n        this.MINUTES.push('');\r\n      }\r\n    }\r\n    this.findSelectedValue(TIME_VARIABLE[1], this.MINUTES);\r\n  }\r\n\r\n  private setMeridiem(type: 'up' | 'down') {\r\n    if (type === 'up') {\r\n      const index = this.AM_PM.indexOf('AM');\r\n      if (index === 1) {\r\n        this.AM_PM.unshift('');\r\n        this.AM_PM.pop();\r\n      }\r\n    } else {\r\n      const index = this.AM_PM.indexOf('AM');\r\n      if (index === 2) {\r\n        this.AM_PM.shift();\r\n        this.AM_PM.push('');\r\n      }\r\n    }\r\n\r\n    this.findSelectedValue(TIME_VARIABLE[2], this.AM_PM);\r\n  }\r\n\r\n  private findSelectedValue(type: string, array: Array<any>) {\r\n    this.selectedTime[type] = array[2];\r\n  }\r\n\r\n  private setDefault(): void {\r\n    const defaultHours = this.selectedTime.HOURS;\r\n    const defaultMinutes = this.selectedTime.MINUTES;\r\n    const defaultMeridiem = this.selectedTime.MERIDIEM;\r\n    this.hourArray[2] = defaultHours;\r\n    this.setHoursToDefault(defaultHours);\r\n    if (defaultMinutes === '30') {\r\n      this.MINUTES[2] = defaultMinutes;\r\n      this.MINUTES[1] = '00';\r\n      this.MINUTES[3] = '';\r\n    } else {\r\n      this.MINUTES[1] = '';\r\n      this.MINUTES[2] = '00';\r\n      this.MINUTES[3] = '30';\r\n    }\r\n\r\n    if (defaultMeridiem === 'PM') {\r\n      this.AM_PM[2] = defaultMeridiem;\r\n      this.AM_PM[1] = 'AM';\r\n      this.AM_PM[3] = '';\r\n      // this.setMeridiem('up');\r\n    } else {\r\n      this.AM_PM[1] = '';\r\n      this.AM_PM[2] = 'AM';\r\n      this.AM_PM[3] = 'PM';\r\n    }\r\n  }\r\n\r\n  private setHoursToDefault(defaultHours: number): void {\r\n    let prevIndex = 2;\r\n    let nextIndex = 1;\r\n    this.hourArray = this.hourArray.map((value: number, index: number) => {\r\n      value = defaultHours;\r\n      if (index < 2) {\r\n        value = value - prevIndex;\r\n        if (value < 1) {\r\n          value = 12 + value;\r\n        }\r\n        prevIndex--;\r\n      } else if (index > 2) {\r\n        value = value + nextIndex;\r\n        if (value > 12) {\r\n          value = value - 12;\r\n        }\r\n        nextIndex++;\r\n      }\r\n\r\n      return value;\r\n    });\r\n  }\r\n}\r\n","<div class=\"timePicker\">\r\n  <div class=\"vx-d-flex vx-align-center vx-justify-center\">\r\n    <div class=\"timePicker-inner vx-d-flex vx-align-center vx-p-3\">\r\n      <div class=\"timePicker-column\" #hour_column>\r\n        <div\r\n          *ngFor=\"let eachHour of hourArray; let i = index\"\r\n          class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1\"\r\n          [class.active]=\"i === 2\"\r\n          (mousewheel)=\"onScroll($event, TIME_VARIABLE[0])\"\r\n          [id]=\"'hour_column_' + (i + 1)\"\r\n          (click)=\"onValueSelect(eachHour, TIME_VARIABLE[0])\"\r\n        >\r\n          <ng-container *ngIf=\"eachHour > 0 && eachHour < 13\">\r\n            {{ eachHour }}\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n      <div class=\"timePicker-column\" #minutes_column>\r\n        <div\r\n          *ngFor=\"let eachMinutes of MINUTES; let i = index\"\r\n          class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1\"\r\n          [class.active]=\"i === 2\"\r\n          [id]=\"'minutes_column_' + (i + 1)\"\r\n          (mousewheel)=\"onScroll($event, TIME_VARIABLE[1])\"\r\n          (click)=\"onValueSelect(eachMinutes, TIME_VARIABLE[1])\"\r\n        >\r\n          {{ eachMinutes }}\r\n        </div>\r\n      </div>\r\n      <div class=\"timePicker-column\" #meridiem_column>\r\n        <div\r\n          *ngFor=\"let eachMeridiem of AM_PM; let i = index\"\r\n          class=\"timePicker-no vx-paragraph-txt vx-fs-14 vx-fw-500 vx-ml-1 vx-mr-1 vx-tt-uppercase\"\r\n          [class.active]=\"i === 2\"\r\n          [id]=\"'meridiem_column_' + (i + 1)\"\r\n          (mousewheel)=\"onScroll($event, TIME_VARIABLE[2])\"\r\n          (click)=\"onValueSelect(eachMeridiem, TIME_VARIABLE[2])\"\r\n        >\r\n          {{ eachMeridiem }}\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div\r\n    class=\"timePicker-bottom vx-d-flex vx-align-center vx-justify-between vx-p-2\"\r\n  >\r\n    <button\r\n      (click)=\"onCloseTimePicker('cancel')\"\r\n      class=\"cancel-btn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-lh-6\"\r\n    >\r\n      CANCEL\r\n    </button>\r\n    <button\r\n      (click)=\"onCloseTimePicker('ok')\"\r\n      class=\"ok-btn vx-fs-11 vx-fw-500 vx-txt-white vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-justify-center vx-lh-6\"\r\n    >\r\n      OK\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
@@ -0,0 +1,24 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { TimePickerComponent } from './time-picker/time-picker.component';
4
+ import * as i0 from "@angular/core";
5
+ export class TimePickerModule {
6
+ }
7
+ TimePickerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TimePickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
+ TimePickerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: TimePickerModule, declarations: [TimePickerComponent], imports: [CommonModule], exports: [TimePickerComponent] });
9
+ TimePickerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TimePickerModule, imports: [CommonModule] });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TimePickerModule, decorators: [{
11
+ type: NgModule,
12
+ args: [{
13
+ declarations: [
14
+ TimePickerComponent
15
+ ],
16
+ imports: [
17
+ CommonModule
18
+ ],
19
+ exports: [
20
+ TimePickerComponent
21
+ ]
22
+ }]
23
+ }] });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS1waWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdngtd29ya2Zsb3ctZW5naW5lL3NyYy9saWIvdWkta2l0L3RpbWUtcGlja2VyL3RpbWUtcGlja2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQzs7QUFlMUUsTUFBTSxPQUFPLGdCQUFnQjs7NkdBQWhCLGdCQUFnQjs4R0FBaEIsZ0JBQWdCLGlCQVR6QixtQkFBbUIsYUFHbkIsWUFBWSxhQUdaLG1CQUFtQjs4R0FHVixnQkFBZ0IsWUFOekIsWUFBWTsyRkFNSCxnQkFBZ0I7a0JBWDVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7cUJBQ2I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLG1CQUFtQjtxQkFDcEI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBUaW1lUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi90aW1lLXBpY2tlci90aW1lLXBpY2tlci5jb21wb25lbnQnO1xyXG5cclxuXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgVGltZVBpY2tlckNvbXBvbmVudFxyXG4gIF0sXHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBUaW1lUGlja2VyQ29tcG9uZW50XHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgVGltZVBpY2tlck1vZHVsZSB7IH1cclxuIl19