mis-crystal-design-system 14.0.60 → 14.0.61-dayjs

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 (38) hide show
  1. package/daterangepicker_v2/models/drp-config.model.d.ts +1 -0
  2. package/daterangepicker_v2/tz-drp-container/tz-drp-container.component.d.ts +1 -1
  3. package/dynamic-form/dynamic-form.component.d.ts +0 -1
  4. package/esm2020/datepicker_v2/tz-dp-container/tz-dp-container.component.mjs +24 -14
  5. package/esm2020/daterangepicker_v2/models/drp-config.model.mjs +1 -1
  6. package/esm2020/daterangepicker_v2/tz-daterangepicker.directive.mjs +3 -2
  7. package/esm2020/daterangepicker_v2/tz-drp-container/tz-drp-container.component.mjs +50 -35
  8. package/esm2020/dynamic-form/dynamic-form.component.mjs +11 -6
  9. package/esm2020/specificdatepicker/tz-sdp-container/tz-sdp-container.component.mjs +55 -41
  10. package/esm2020/timepicker/timepicker.component.mjs +54 -48
  11. package/esm2020/timerangepicker/timerangepicker.component.mjs +46 -42
  12. package/fesm2015/mis-crystal-design-system-datepicker_v2.mjs +23 -13
  13. package/fesm2015/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
  14. package/fesm2015/mis-crystal-design-system-daterangepicker_v2.mjs +60 -43
  15. package/fesm2015/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
  16. package/fesm2015/mis-crystal-design-system-dynamic-form.mjs +10 -4
  17. package/fesm2015/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
  18. package/fesm2015/mis-crystal-design-system-specificdatepicker.mjs +54 -40
  19. package/fesm2015/mis-crystal-design-system-specificdatepicker.mjs.map +1 -1
  20. package/fesm2015/mis-crystal-design-system-timepicker.mjs +53 -47
  21. package/fesm2015/mis-crystal-design-system-timepicker.mjs.map +1 -1
  22. package/fesm2015/mis-crystal-design-system-timerangepicker.mjs +45 -41
  23. package/fesm2015/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
  24. package/fesm2020/mis-crystal-design-system-datepicker_v2.mjs +23 -13
  25. package/fesm2020/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
  26. package/fesm2020/mis-crystal-design-system-daterangepicker_v2.mjs +51 -34
  27. package/fesm2020/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
  28. package/fesm2020/mis-crystal-design-system-dynamic-form.mjs +10 -4
  29. package/fesm2020/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
  30. package/fesm2020/mis-crystal-design-system-specificdatepicker.mjs +54 -40
  31. package/fesm2020/mis-crystal-design-system-specificdatepicker.mjs.map +1 -1
  32. package/fesm2020/mis-crystal-design-system-timepicker.mjs +53 -47
  33. package/fesm2020/mis-crystal-design-system-timepicker.mjs.map +1 -1
  34. package/fesm2020/mis-crystal-design-system-timerangepicker.mjs +45 -41
  35. package/fesm2020/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
  36. package/package.json +1 -1
  37. package/specificdatepicker/tz-sdp-container/tz-sdp-container.component.d.ts +1 -1
  38. package/timepicker/timepicker.component.d.ts +2 -2
@@ -1,5 +1,7 @@
1
1
  import { Component, Input, Output, EventEmitter } from "@angular/core";
2
- import moment from "moment-timezone";
2
+ import dayjs from 'dayjs';
3
+ import timezone from 'dayjs/plugin/timezone';
4
+ import utc from 'dayjs/plugin/utc';
3
5
  import * as i0 from "@angular/core";
4
6
  import * as i1 from "@angular/common";
5
7
  import * as i2 from "mis-crystal-design-system/timepicker";
@@ -9,14 +11,16 @@ function TimeRangePickerComponent_p_2_Template(rf, ctx) { if (rf & 1) {
9
11
  i0.ɵɵelementEnd();
10
12
  } }
11
13
  const _c0 = function (a0, a1) { return { "flexDirection": a0, "gap": a1 }; };
14
+ dayjs.extend(utc);
15
+ dayjs.extend(timezone);
12
16
  export class TimeRangePickerComponent {
13
17
  constructor(cdr) {
14
18
  this.cdr = cdr;
15
19
  this.inputWidth = "100px";
16
20
  this.height = "46px";
17
21
  this.timezone = "Asia/Kolkata";
18
- this.startDateEpoch = moment().tz(this.timezone).valueOf();
19
- this.endDateEpoch = moment().tz(this.timezone).valueOf();
22
+ this.startDateEpoch = dayjs().tz(this.timezone).valueOf();
23
+ this.endDateEpoch = dayjs().tz(this.timezone).valueOf();
20
24
  this.clockFormat = 12;
21
25
  this.interval = 15;
22
26
  this.showTooltip = true;
@@ -25,51 +29,51 @@ export class TimeRangePickerComponent {
25
29
  this.disableStartTime = false;
26
30
  this.disableEndTime = false;
27
31
  this.timeRangeEmitter = new EventEmitter();
28
- this.firstIntervalForStartPicker = moment().valueOf();
29
- this.firstIntervalForEndPicker = moment().valueOf();
32
+ this.firstIntervalForStartPicker = dayjs().valueOf();
33
+ this.firstIntervalForEndPicker = dayjs().valueOf();
30
34
  this.rangeValidity = true;
31
35
  this.triggerChange = true;
32
36
  }
33
37
  ngOnInit() { }
34
38
  ngOnChanges() {
35
39
  this.timeFormat = this.clockFormat === 12 ? "hh:mm a" : "HH:mm";
36
- moment.tz.setDefault(this.timezone);
37
- this.startDate = moment(this.startDateEpoch).format("DD-MM-YYYY");
38
- this.endDate = moment(this.endDateEpoch).format("DD-MM-YYYY");
39
- this.currDate = moment().format("DD-MM-YYYY");
40
+ dayjs.tz.setDefault(this.timezone);
41
+ this.startDate = dayjs(this.startDateEpoch).format("DD-MM-YYYY");
42
+ this.endDate = dayjs(this.endDateEpoch).format("DD-MM-YYYY");
43
+ this.currDate = dayjs().format("DD-MM-YYYY");
40
44
  this.setFirstIntervals();
41
45
  }
42
46
  // calculate the first interval of the picker
43
47
  setFirstIntervals() {
44
- const minutes = moment().minutes();
48
+ const minutes = dayjs().minute();
45
49
  const offset = this.interval - (minutes % this.interval);
46
50
  // start date, 22 MAY === current date, 22 MAY
47
51
  if (this.startDate === this.currDate) {
48
- const currentTime = moment().valueOf();
52
+ const currentTime = dayjs().valueOf();
49
53
  // start date, 22 MAY === current date, 22 MAY === end date, 22 MAY
50
54
  if (this.startDate === this.endDate) {
51
55
  // current time is in last interval
52
- if (currentTime >= moment(this.startDateEpoch).endOf("d").subtract(this.interval, "m").valueOf()) {
56
+ if (currentTime >= dayjs(this.startDateEpoch).endOf("d").subtract(this.interval, "m").valueOf()) {
53
57
  this.firstIntervalForStartPicker = currentTime;
54
- this.firstIntervalForEndPicker = moment(this.endDateEpoch).endOf("d").valueOf();
58
+ this.firstIntervalForEndPicker = dayjs(this.endDateEpoch).endOf("d").valueOf();
55
59
  }
56
60
  // current time isn't in last interval
57
61
  else {
58
- this.firstIntervalForStartPicker = moment().add(offset, "m").valueOf();
59
- this.firstIntervalForEndPicker = moment().add(offset, "m").add(this.interval, "m").valueOf();
62
+ this.firstIntervalForStartPicker = dayjs().add(offset, "m").valueOf();
63
+ this.firstIntervalForEndPicker = dayjs().add(offset, "m").add(this.interval, "m").valueOf();
60
64
  }
61
65
  }
62
66
  // start date, 22 MAY === current date, 22 MAY !== end date, 30 MAY
63
67
  else {
64
68
  // current time is in last interval
65
- if (currentTime >= moment(this.startDateEpoch).endOf("d").subtract(this.interval, "m").valueOf()) {
69
+ if (currentTime >= dayjs(this.startDateEpoch).endOf("d").subtract(this.interval, "m").valueOf()) {
66
70
  this.firstIntervalForStartPicker = currentTime;
67
- this.firstIntervalForEndPicker = moment(this.endDateEpoch).endOf("d").valueOf();
71
+ this.firstIntervalForEndPicker = dayjs(this.endDateEpoch).endOf("d").valueOf();
68
72
  }
69
73
  // current time isn't in last interval
70
74
  else {
71
- this.firstIntervalForStartPicker = moment().add(offset, "m").valueOf();
72
- this.firstIntervalForEndPicker = moment(this.endDateEpoch).valueOf();
75
+ this.firstIntervalForStartPicker = dayjs().add(offset, "m").valueOf();
76
+ this.firstIntervalForEndPicker = dayjs(this.endDateEpoch).valueOf();
73
77
  }
74
78
  }
75
79
  }
@@ -77,13 +81,13 @@ export class TimeRangePickerComponent {
77
81
  else {
78
82
  // start date === end Date
79
83
  if (this.startDate === this.endDate) {
80
- this.firstIntervalForStartPicker = moment(this.startDateEpoch).startOf("d").valueOf();
81
- this.firstIntervalForEndPicker = moment(this.endDateEpoch).add(this.interval, "m").valueOf();
84
+ this.firstIntervalForStartPicker = dayjs(this.startDateEpoch).startOf("d").valueOf();
85
+ this.firstIntervalForEndPicker = dayjs(this.endDateEpoch).add(this.interval, "m").valueOf();
82
86
  }
83
87
  // start date !== end date
84
88
  else {
85
- this.firstIntervalForStartPicker = moment(this.startDateEpoch).startOf("d").valueOf();
86
- this.firstIntervalForEndPicker = moment(this.startDateEpoch).startOf("d").valueOf();
89
+ this.firstIntervalForStartPicker = dayjs(this.startDateEpoch).startOf("d").valueOf();
90
+ this.firstIntervalForEndPicker = dayjs(this.startDateEpoch).startOf("d").valueOf();
87
91
  }
88
92
  }
89
93
  if (this.givenStartTime)
@@ -92,13 +96,13 @@ export class TimeRangePickerComponent {
92
96
  this.firstIntervalForEndPicker = this.givenEndTime;
93
97
  this.startTime = {
94
98
  valid: true,
95
- time: moment(this.firstIntervalForStartPicker).format(this.timeFormat),
96
- epoch: moment(this.firstIntervalForStartPicker).valueOf()
99
+ time: dayjs(this.firstIntervalForStartPicker).format(this.timeFormat),
100
+ epoch: dayjs(this.firstIntervalForStartPicker).valueOf()
97
101
  };
98
102
  this.endTime = {
99
103
  valid: true,
100
- time: moment(this.firstIntervalForEndPicker).format(this.timeFormat),
101
- epoch: moment(this.firstIntervalForEndPicker).valueOf()
104
+ time: dayjs(this.firstIntervalForEndPicker).format(this.timeFormat),
105
+ epoch: dayjs(this.firstIntervalForEndPicker).valueOf()
102
106
  };
103
107
  }
104
108
  emitTimeRange(data) {
@@ -112,16 +116,16 @@ export class TimeRangePickerComponent {
112
116
  // and the start time >= end time
113
117
  // update the first interval of end picker according to the time set in start picker
114
118
  if (this.startDate === this.endDate) {
115
- let minutes = moment(this.startTime.time, this.timeFormat).minutes();
119
+ let minutes = dayjs(this.startTime.time, this.timeFormat).minute();
116
120
  let offset = this.interval - (minutes % this.interval);
117
- this.firstIntervalForEndPicker = moment(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`)
121
+ this.firstIntervalForEndPicker = dayjs(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`)
118
122
  .add(offset, "m")
119
123
  .valueOf();
120
124
  // if the first interval == 12:00am, set it as 11:59pm
121
- const intervalAsString = moment(this.firstIntervalForEndPicker).format(this.timeFormat);
122
- const endOfDayAsString = moment(moment(`${this.startDate}`, `DD-MM-YYYY ${this.timeFormat}`).endOf("d").add(1, "m")).format(this.timeFormat);
125
+ const intervalAsString = dayjs(this.firstIntervalForEndPicker).format(this.timeFormat);
126
+ const endOfDayAsString = dayjs(dayjs(`${this.startDate}`, `DD-MM-YYYY ${this.timeFormat}`).endOf("d").add(1, "m")).format(this.timeFormat);
123
127
  if (intervalAsString === endOfDayAsString) {
124
- this.firstIntervalForEndPicker = moment(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`).endOf("d").valueOf();
128
+ this.firstIntervalForEndPicker = dayjs(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`).endOf("d").valueOf();
125
129
  }
126
130
  }
127
131
  else {
@@ -132,8 +136,8 @@ export class TimeRangePickerComponent {
132
136
  valid: validity && this.rangeValidity,
133
137
  startTime: this.startTime.time,
134
138
  endTime: this.endTime.time,
135
- startEpoch: moment(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf(),
136
- endEpoch: moment(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf()
139
+ startEpoch: dayjs(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf(),
140
+ endEpoch: dayjs(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf()
137
141
  });
138
142
  }
139
143
  this.triggerChange = !this.triggerChange;
@@ -146,15 +150,15 @@ export class TimeRangePickerComponent {
146
150
  valid: validity && this.rangeValidity,
147
151
  startTime: this.startTime.time,
148
152
  endTime: this.endTime.time,
149
- startEpoch: moment(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf(),
150
- endEpoch: moment(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf()
153
+ startEpoch: dayjs(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf(),
154
+ endEpoch: dayjs(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf()
151
155
  });
152
156
  }
153
157
  checkTimeValidity(time, date) {
154
158
  const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;
155
159
  const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;
156
160
  const RE = this.clockFormat === 12 ? RE12 : RE24;
157
- const timeMoment = moment(`${moment(date).format("DD-MM-YYYY")} ${time}`, `'DD-MM-YYYY' ${this.timeFormat}`);
161
+ const timedayjs = dayjs(`${dayjs(date).format("DD-MM-YYYY")} ${time}`, `'DD-MM-YYYY' ${this.timeFormat}`);
158
162
  let flag = false;
159
163
  // if the first interval is set to the start of the day
160
164
  // then we don't check its validity against the current time
@@ -162,16 +166,16 @@ export class TimeRangePickerComponent {
162
166
  flag = time.match(RE) ? true : false;
163
167
  }
164
168
  else {
165
- flag = time.match(RE) && timeMoment.diff(moment(), "m") >= 0 ? true : false;
169
+ flag = time.match(RE) && timedayjs.diff(dayjs(), "m") >= 0 ? true : false;
166
170
  }
167
171
  return flag;
168
172
  }
169
173
  // validates end picker's input according to the start picker's input
170
174
  rangeValidation(validity) {
171
175
  if (validity && this.startDate === this.endDate) {
172
- const startMoment = moment(this.startTime.time, this.timeFormat);
173
- const endMoment = moment(this.endTime.time, this.timeFormat);
174
- this.rangeValidity = endMoment.diff(startMoment, "m") >= 1 ? true : false;
176
+ const startdayjs = dayjs(this.startTime.time, this.timeFormat);
177
+ const enddayjs = dayjs(this.endTime.time, this.timeFormat);
178
+ this.rangeValidity = enddayjs.diff(startdayjs, "m") >= 1 ? true : false;
175
179
  this.cdr.detectChanges();
176
180
  }
177
181
  }
@@ -230,4 +234,4 @@ TimeRangePickerComponent.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: Ti
230
234
  }], timeRangeEmitter: [{
231
235
  type: Output
232
236
  }] }); })();
233
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timerangepicker.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/timerangepicker/timerangepicker.component.ts","../../../../projects/mis-components/timerangepicker/timerangepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ChangeDetectorRef, Output, EventEmitter } from \"@angular/core\";\nimport moment from \"moment-timezone\";\nimport { ITimeRange, ITime, TDirection } from \"./timerange.namespace\";\n\n@Component({\n  selector: \"mis-timerangepicker\",\n  templateUrl: \"./timerangepicker.component.html\",\n  styleUrls: [\"./timerangepicker.component.scss\"]\n})\nexport class TimeRangePickerComponent {\n  @Input() inputWidth: string = \"100px\";\n  @Input() dropdownWidth?: string;\n  @Input() height: string = \"46px\";\n  @Input() timezone: string = \"Asia/Kolkata\";\n  @Input() startDateEpoch: number = moment().tz(this.timezone).valueOf();\n  @Input() endDateEpoch: number = moment().tz(this.timezone).valueOf();\n  @Input() givenStartTime: number;\n  @Input() givenEndTime: number;\n  @Input() clockFormat: number = 12;\n  @Input() interval: number = 15;\n  @Input() showTooltip: boolean = true;\n  @Input() direction: TDirection = 'row';\n  @Input() gap: string = '1rem';\n  @Input() disableStartTime: boolean = false;\n  @Input() disableEndTime: boolean = false;\n  @Output() timeRangeEmitter = new EventEmitter<ITimeRange>();\n\n  startDate!: string;\n  endDate!: string;\n  currDate!: string;\n  timeFormat!: string;\n  firstIntervalForStartPicker: number = moment().valueOf();\n  firstIntervalForEndPicker: number = moment().valueOf();\n  startTime!: ITime;\n  endTime!: ITime;\n  rangeValidity: boolean = true;\n  triggerChange: boolean = true;\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngOnInit() {}\n\n  ngOnChanges() {\n    this.timeFormat = this.clockFormat === 12 ? \"hh:mm a\" : \"HH:mm\";\n    moment.tz.setDefault(this.timezone);\n    this.startDate = moment(this.startDateEpoch).format(\"DD-MM-YYYY\");\n    this.endDate = moment(this.endDateEpoch).format(\"DD-MM-YYYY\");\n    this.currDate = moment().format(\"DD-MM-YYYY\");\n    this.setFirstIntervals();\n  }\n\n  // calculate the first interval of the picker\n  setFirstIntervals(): void {\n    const minutes = moment().minutes();\n    const offset = this.interval - (minutes % this.interval);\n\n    // start date, 22 MAY ===  current date, 22 MAY\n    if( this.startDate === this.currDate ){\n      const currentTime = moment().valueOf();\n\n      // start date, 22 MAY  === current date, 22 MAY === end date, 22 MAY\n      if(this.startDate === this.endDate){\n\n        // current time is in last interval\n        if( currentTime >= moment(this.startDateEpoch).endOf(\"d\").subtract(this.interval,\"m\").valueOf()){\n          this.firstIntervalForStartPicker = currentTime;\n          this.firstIntervalForEndPicker =  moment(this.endDateEpoch).endOf(\"d\").valueOf();\n        }\n        // current time isn't in last interval\n        else {\n          this.firstIntervalForStartPicker = moment().add(offset, \"m\").valueOf();\n          this.firstIntervalForEndPicker =  moment().add(offset, \"m\").add(this.interval, \"m\").valueOf();\n        }\n      } \n      // start date, 22 MAY === current date, 22 MAY !== end date, 30 MAY\n      else {\n        // current time is in last interval\n        if( currentTime >= moment(this.startDateEpoch).endOf(\"d\").subtract(this.interval,\"m\").valueOf()){\n          this.firstIntervalForStartPicker = currentTime;\n          this.firstIntervalForEndPicker =  moment(this.endDateEpoch).endOf(\"d\").valueOf();\n        }\n        // current time isn't in last interval\n        else {\n          this.firstIntervalForStartPicker = moment().add(offset, \"m\").valueOf();\n          this.firstIntervalForEndPicker =  moment(this.endDateEpoch).valueOf();\n        }\n      }\n    }\n    // start date, 30 MAY !== current date, 22 MAY\n    else {\n      // start date === end Date\n      if( this.startDate === this.endDate){\n        this.firstIntervalForStartPicker = moment(this.startDateEpoch).startOf(\"d\").valueOf();\n        this.firstIntervalForEndPicker =  moment(this.endDateEpoch).add(this.interval, \"m\").valueOf();\n      } \n      // start date !== end date\n      else {\n        this.firstIntervalForStartPicker = moment(this.startDateEpoch).startOf(\"d\").valueOf();\n        this.firstIntervalForEndPicker =  moment(this.startDateEpoch).startOf(\"d\").valueOf();\n      }\n\n    }\n\n    if(this.givenStartTime)\n      this.firstIntervalForStartPicker = this.givenStartTime;\n   \n    if(this.givenEndTime)\n      this.firstIntervalForEndPicker = this.givenEndTime;\n      \n    this.startTime = {\n      valid: true,\n      time: moment(this.firstIntervalForStartPicker).format(this.timeFormat),\n      epoch: moment(this.firstIntervalForStartPicker).valueOf()\n    };\n\n    this.endTime = {\n      valid: true,\n      time: moment(this.firstIntervalForEndPicker).format(this.timeFormat),\n      epoch: moment(this.firstIntervalForEndPicker).valueOf()\n    };\n  }\n\n  emitTimeRange(data: ITimeRange): void {\n    this.timeRangeEmitter.emit(data);\n  }\n\n  //handlers catch the emitted values and run validation\n  startPickerHandler(time: ITime): void {\n    this.startTime = time;\n    this.rangeValidity = true;\n    // if the start time changes and the start date is the same as the end date\n    // and the start time >=  end time\n    // update the first interval of end picker according to the time set in start picker\n    if (this.startDate === this.endDate) {\n      let minutes = moment(this.startTime.time, this.timeFormat).minutes();\n      let offset = this.interval - (minutes % this.interval);\n      this.firstIntervalForEndPicker = moment(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`)\n        .add(offset, \"m\")\n        .valueOf();\n\n      // if the first interval == 12:00am, set it as 11:59pm\n      const intervalAsString = moment(this.firstIntervalForEndPicker).format(this.timeFormat);\n      const endOfDayAsString = moment(moment(`${this.startDate}`, `DD-MM-YYYY ${this.timeFormat}`).endOf(\"d\").add(1, \"m\")).format(this.timeFormat);\n      if (intervalAsString === endOfDayAsString) {\n        this.firstIntervalForEndPicker = moment(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`).endOf(\"d\").valueOf();\n      }\n\n    } else {\n        const validity =\n        this.checkTimeValidity(this.startTime.time.trim(), this.startDateEpoch) &&\n        this.checkTimeValidity(this.endTime.time.trim(), this.endDateEpoch);\n\n        this.rangeValidation(validity);\n        this.emitTimeRange({\n          valid: validity && this.rangeValidity,\n          startTime: this.startTime.time,\n          endTime: this.endTime.time,\n          startEpoch: moment(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf(),\n          endEpoch: moment(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf()\n        });\n    }\n\n    this.triggerChange = !this.triggerChange;\n  }\n\n  endPickerHandler(time: ITime): void {\n    this.endTime = time;\n\n    const validity =\n      this.checkTimeValidity(this.startTime.time.trim(), this.startDateEpoch) && this.checkTimeValidity(this.endTime.time.trim(), this.endDateEpoch);\n\n    this.rangeValidation(validity);\n    this.emitTimeRange({\n      valid: validity && this.rangeValidity,\n      startTime: this.startTime.time,\n      endTime: this.endTime.time,\n      startEpoch: moment(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf(),\n      endEpoch: moment(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf()\n    });\n  }\n\n  checkTimeValidity(time: string, date: number): boolean {\n    const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;\n    const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;\n    const RE = this.clockFormat === 12 ? RE12 : RE24;\n\n    const timeMoment = moment(`${moment(date).format(\"DD-MM-YYYY\")} ${time}`, `'DD-MM-YYYY' ${this.timeFormat}`);\n    let flag: boolean = false;\n\n    // if the first interval is set to the start of the day\n    // then we don't check its validity against the current time\n    if ((this.givenStartTime && this.givenEndTime) || (this.startDate !== this.endDate && this.startDate !== this.currDate)) {\n      flag = time.match(RE) ? true : false;\n    } else {\n      flag = time.match(RE) && timeMoment.diff(moment(), \"m\") >= 0 ? true : false;\n    }\n\n    return flag;\n  }\n\n  // validates end picker's input according to the start picker's input\n  rangeValidation(validity: boolean) {\n    if (validity && this.startDate === this.endDate) {\n      const startMoment = moment(this.startTime.time, this.timeFormat);\n      const endMoment = moment(this.endTime.time, this.timeFormat);\n      this.rangeValidity = endMoment.diff(startMoment, \"m\") >= 1 ? true : false;\n      this.cdr.detectChanges();\n    }\n  }\n}\n","<div class=\"rangepicker-container\" [ngStyle]=\"{'flexDirection': direction, 'gap': gap}\">\n  <mis-timepicker\n    [clockFormat]=\"clockFormat\"\n    [interval]=\"interval\"\n    [dateAsEpoch]=\"startDateEpoch\"\n    [firstInterval]=\"firstIntervalForStartPicker\"\n    (timeEmitter)=\"startPickerHandler($event)\"\n    [timezone]=\"timezone\"\n    [height]=\"height\"\n    [inputWidth]=\"inputWidth\"\n    [dropdownWidth]=\"dropdownWidth\"\n    [showTooltip]=\"showTooltip\"\n    [givenTime]=\"givenStartTime\"\n    [disable]=\"disableStartTime\"\n  ></mis-timepicker>\n  <p *ngIf=\"direction === 'row'\">-</p>\n  <mis-timepicker\n    [clockFormat]=\"clockFormat\"\n    [interval]=\"interval\"\n    [dateAsEpoch]=\"endDateEpoch\"\n    [firstInterval]=\"firstIntervalForEndPicker\"\n    (timeEmitter)=\"endPickerHandler($event)\"\n    [rangeValidity]=\"rangeValidity\"\n    [timezone]=\"timezone\"\n    [height]=\"height\"\n    [inputWidth]=\"inputWidth\"\n    [dropdownWidth]=\"dropdownWidth\"\n    [showTooltip]=\"showTooltip\"\n    [givenTime]=\"givenEndTime\"\n    [triggerChange]=\"triggerChange\"\n    [disable]=\"disableEndTime\"\n  ></mis-timepicker>\n</div>\n"]}
237
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timerangepicker.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/timerangepicker/timerangepicker.component.ts","../../../../projects/mis-components/timerangepicker/timerangepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ChangeDetectorRef, Output, EventEmitter } from \"@angular/core\";\nimport { ITimeRange, ITime, TDirection } from \"./timerange.namespace\";\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\n@Component({\n  selector: \"mis-timerangepicker\",\n  templateUrl: \"./timerangepicker.component.html\",\n  styleUrls: [\"./timerangepicker.component.scss\"]\n})\nexport class TimeRangePickerComponent {\n  @Input() inputWidth: string = \"100px\";\n  @Input() dropdownWidth?: string;\n  @Input() height: string = \"46px\";\n  @Input() timezone: string = \"Asia/Kolkata\";\n  @Input() startDateEpoch: number = dayjs().tz(this.timezone).valueOf();\n  @Input() endDateEpoch: number = dayjs().tz(this.timezone).valueOf();\n  @Input() givenStartTime: number;\n  @Input() givenEndTime: number;\n  @Input() clockFormat: number = 12;\n  @Input() interval: number = 15;\n  @Input() showTooltip: boolean = true;\n  @Input() direction: TDirection = 'row';\n  @Input() gap: string = '1rem';\n  @Input() disableStartTime: boolean = false;\n  @Input() disableEndTime: boolean = false;\n  @Output() timeRangeEmitter = new EventEmitter<ITimeRange>();\n\n  startDate!: string;\n  endDate!: string;\n  currDate!: string;\n  timeFormat!: string;\n  firstIntervalForStartPicker: number = dayjs().valueOf();\n  firstIntervalForEndPicker: number = dayjs().valueOf();\n  startTime!: ITime;\n  endTime!: ITime;\n  rangeValidity: boolean = true;\n  triggerChange: boolean = true;\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngOnInit() {}\n\n  ngOnChanges() {\n    this.timeFormat = this.clockFormat === 12 ? \"hh:mm a\" : \"HH:mm\";\n    dayjs.tz.setDefault(this.timezone);\n    this.startDate = dayjs(this.startDateEpoch).format(\"DD-MM-YYYY\");\n    this.endDate = dayjs(this.endDateEpoch).format(\"DD-MM-YYYY\");\n    this.currDate = dayjs().format(\"DD-MM-YYYY\");\n    this.setFirstIntervals();\n  }\n\n  // calculate the first interval of the picker\n  setFirstIntervals(): void {\n    const minutes = dayjs().minute();\n    const offset = this.interval - (minutes % this.interval);\n\n    // start date, 22 MAY ===  current date, 22 MAY\n    if( this.startDate === this.currDate ){\n      const currentTime = dayjs().valueOf();\n\n      // start date, 22 MAY  === current date, 22 MAY === end date, 22 MAY\n      if(this.startDate === this.endDate){\n\n        // current time is in last interval\n        if( currentTime >= dayjs(this.startDateEpoch).endOf(\"d\").subtract(this.interval,\"m\").valueOf()){\n          this.firstIntervalForStartPicker = currentTime;\n          this.firstIntervalForEndPicker =  dayjs(this.endDateEpoch).endOf(\"d\").valueOf();\n        }\n        // current time isn't in last interval\n        else {\n          this.firstIntervalForStartPicker = dayjs().add(offset, \"m\").valueOf();\n          this.firstIntervalForEndPicker =  dayjs().add(offset, \"m\").add(this.interval, \"m\").valueOf();\n        }\n      } \n      // start date, 22 MAY === current date, 22 MAY !== end date, 30 MAY\n      else {\n        // current time is in last interval\n        if( currentTime >= dayjs(this.startDateEpoch).endOf(\"d\").subtract(this.interval,\"m\").valueOf()){\n          this.firstIntervalForStartPicker = currentTime;\n          this.firstIntervalForEndPicker =  dayjs(this.endDateEpoch).endOf(\"d\").valueOf();\n        }\n        // current time isn't in last interval\n        else {\n          this.firstIntervalForStartPicker = dayjs().add(offset, \"m\").valueOf();\n          this.firstIntervalForEndPicker =  dayjs(this.endDateEpoch).valueOf();\n        }\n      }\n    }\n    // start date, 30 MAY !== current date, 22 MAY\n    else {\n      // start date === end Date\n      if( this.startDate === this.endDate){\n        this.firstIntervalForStartPicker = dayjs(this.startDateEpoch).startOf(\"d\").valueOf();\n        this.firstIntervalForEndPicker =  dayjs(this.endDateEpoch).add(this.interval, \"m\").valueOf();\n      } \n      // start date !== end date\n      else {\n        this.firstIntervalForStartPicker = dayjs(this.startDateEpoch).startOf(\"d\").valueOf();\n        this.firstIntervalForEndPicker =  dayjs(this.startDateEpoch).startOf(\"d\").valueOf();\n      }\n\n    }\n\n    if(this.givenStartTime)\n      this.firstIntervalForStartPicker = this.givenStartTime;\n   \n    if(this.givenEndTime)\n      this.firstIntervalForEndPicker = this.givenEndTime;\n      \n    this.startTime = {\n      valid: true,\n      time: dayjs(this.firstIntervalForStartPicker).format(this.timeFormat),\n      epoch: dayjs(this.firstIntervalForStartPicker).valueOf()\n    };\n\n    this.endTime = {\n      valid: true,\n      time: dayjs(this.firstIntervalForEndPicker).format(this.timeFormat),\n      epoch: dayjs(this.firstIntervalForEndPicker).valueOf()\n    };\n  }\n\n  emitTimeRange(data: ITimeRange): void {\n    this.timeRangeEmitter.emit(data);\n  }\n\n  //handlers catch the emitted values and run validation\n  startPickerHandler(time: ITime): void {\n    this.startTime = time;\n    this.rangeValidity = true;\n    // if the start time changes and the start date is the same as the end date\n    // and the start time >=  end time\n    // update the first interval of end picker according to the time set in start picker\n    if (this.startDate === this.endDate) {\n      let minutes = dayjs(this.startTime.time, this.timeFormat).minute();\n      let offset = this.interval - (minutes % this.interval);\n      this.firstIntervalForEndPicker = dayjs(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`)\n        .add(offset, \"m\")\n        .valueOf();\n\n      // if the first interval == 12:00am, set it as 11:59pm\n      const intervalAsString = dayjs(this.firstIntervalForEndPicker).format(this.timeFormat);\n      const endOfDayAsString = dayjs(dayjs(`${this.startDate}`, `DD-MM-YYYY ${this.timeFormat}`).endOf(\"d\").add(1, \"m\")).format(this.timeFormat);\n      if (intervalAsString === endOfDayAsString) {\n        this.firstIntervalForEndPicker = dayjs(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`).endOf(\"d\").valueOf();\n      }\n\n    } else {\n        const validity =\n        this.checkTimeValidity(this.startTime.time.trim(), this.startDateEpoch) &&\n        this.checkTimeValidity(this.endTime.time.trim(), this.endDateEpoch);\n\n        this.rangeValidation(validity);\n        this.emitTimeRange({\n          valid: validity && this.rangeValidity,\n          startTime: this.startTime.time,\n          endTime: this.endTime.time,\n          startEpoch: dayjs(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf(),\n          endEpoch: dayjs(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf()\n        });\n    }\n\n    this.triggerChange = !this.triggerChange;\n  }\n\n  endPickerHandler(time: ITime): void {\n    this.endTime = time;\n\n    const validity =\n      this.checkTimeValidity(this.startTime.time.trim(), this.startDateEpoch) && this.checkTimeValidity(this.endTime.time.trim(), this.endDateEpoch);\n\n    this.rangeValidation(validity);\n    this.emitTimeRange({\n      valid: validity && this.rangeValidity,\n      startTime: this.startTime.time,\n      endTime: this.endTime.time,\n      startEpoch: dayjs(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf(),\n      endEpoch: dayjs(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`).valueOf()\n    });\n  }\n\n  checkTimeValidity(time: string, date: number): boolean {\n    const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;\n    const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;\n    const RE = this.clockFormat === 12 ? RE12 : RE24;\n\n    const timedayjs = dayjs(`${dayjs(date).format(\"DD-MM-YYYY\")} ${time}`, `'DD-MM-YYYY' ${this.timeFormat}`);\n    let flag: boolean = false;\n\n    // if the first interval is set to the start of the day\n    // then we don't check its validity against the current time\n    if ((this.givenStartTime && this.givenEndTime) || (this.startDate !== this.endDate && this.startDate !== this.currDate)) {\n      flag = time.match(RE) ? true : false;\n    } else {\n      flag = time.match(RE) && timedayjs.diff(dayjs(), \"m\") >= 0 ? true : false;\n    }\n\n    return flag;\n  }\n\n  // validates end picker's input according to the start picker's input\n  rangeValidation(validity: boolean) {\n    if (validity && this.startDate === this.endDate) {\n      const startdayjs = dayjs(this.startTime.time, this.timeFormat);\n      const enddayjs = dayjs(this.endTime.time, this.timeFormat);\n      this.rangeValidity = enddayjs.diff(startdayjs, \"m\") >= 1 ? true : false;\n      this.cdr.detectChanges();\n    }\n  }\n}\n","<div class=\"rangepicker-container\" [ngStyle]=\"{'flexDirection': direction, 'gap': gap}\">\n  <mis-timepicker\n    [clockFormat]=\"clockFormat\"\n    [interval]=\"interval\"\n    [dateAsEpoch]=\"startDateEpoch\"\n    [firstInterval]=\"firstIntervalForStartPicker\"\n    (timeEmitter)=\"startPickerHandler($event)\"\n    [timezone]=\"timezone\"\n    [height]=\"height\"\n    [inputWidth]=\"inputWidth\"\n    [dropdownWidth]=\"dropdownWidth\"\n    [showTooltip]=\"showTooltip\"\n    [givenTime]=\"givenStartTime\"\n    [disable]=\"disableStartTime\"\n  ></mis-timepicker>\n  <p *ngIf=\"direction === 'row'\">-</p>\n  <mis-timepicker\n    [clockFormat]=\"clockFormat\"\n    [interval]=\"interval\"\n    [dateAsEpoch]=\"endDateEpoch\"\n    [firstInterval]=\"firstIntervalForEndPicker\"\n    (timeEmitter)=\"endPickerHandler($event)\"\n    [rangeValidity]=\"rangeValidity\"\n    [timezone]=\"timezone\"\n    [height]=\"height\"\n    [inputWidth]=\"inputWidth\"\n    [dropdownWidth]=\"dropdownWidth\"\n    [showTooltip]=\"showTooltip\"\n    [givenTime]=\"givenEndTime\"\n    [triggerChange]=\"triggerChange\"\n    [disable]=\"disableEndTime\"\n  ></mis-timepicker>\n</div>\n"]}
@@ -1,6 +1,11 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { InjectionToken, Component, Inject, HostListener, EventEmitter, Injector, Directive, Self, Optional, Input, Output, NgModule } from '@angular/core';
3
- import { parseZone, tz } from 'moment-timezone';
3
+ import dayjs, { tz } from 'dayjs';
4
+ import timezone from 'dayjs/plugin/timezone';
5
+ import utc from 'dayjs/plugin/utc';
6
+ import isSameOrAfter from 'dayjs/plugin/isSameOrAfter';
7
+ import isSameOrBefore from 'dayjs/plugin/isSameOrBefore';
8
+ import customParseFormat from 'dayjs/plugin/customParseFormat';
4
9
  import * as i1 from 'mis-crystal-design-system/toast';
5
10
  import { ToastModule } from 'mis-crystal-design-system/toast';
6
11
  import * as i2 from '@angular/common';
@@ -132,12 +137,17 @@ function TzDpContainerComponent_div_16_Template(rf, ctx) {
132
137
  }
133
138
  }
134
139
  const _c3 = function (a0) { return { "disabled-month": a0 }; };
140
+ dayjs.extend(utc);
141
+ dayjs.extend(timezone);
142
+ dayjs.extend(customParseFormat);
143
+ dayjs.extend(isSameOrAfter);
144
+ dayjs.extend(isSameOrBefore);
135
145
  class TzDpContainerComponent {
136
146
  constructor(data, toast) {
137
147
  var _a, _b, _c, _d;
138
148
  this.toast = toast;
139
149
  this.parseZoneInstance = (...args) => {
140
- return parseZone(...args);
150
+ return dayjs(...args);
141
151
  };
142
152
  this.rawWeekDays = ["SUN", "MON", "TUE", "WED", "THU", "FRI", "SAT"];
143
153
  this.weekDays = [];
@@ -148,7 +158,7 @@ class TzDpContainerComponent {
148
158
  this.data = data;
149
159
  if ((_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a.dpConfig) === null || _b === void 0 ? void 0 : _b.timezone) {
150
160
  this.parseZoneInstance = (...args) => {
151
- return tz(args[0], args[1], this.data.dpConfig.timezone);
161
+ return tz(args[0], args[1] || 'DD/MM/YYYY', this.data.dpConfig.timezone);
152
162
  };
153
163
  }
154
164
  this.currentMonthNumber = this.parseZoneInstance().month();
@@ -170,7 +180,7 @@ class TzDpContainerComponent {
170
180
  this.calculateMinMaxDays();
171
181
  }
172
182
  currentDateInstance() {
173
- const selectedDate = parseZone(this.data.date, this.data.dpConfig.format);
183
+ const selectedDate = dayjs(this.data.date, this.data.dpConfig.format);
174
184
  if (selectedDate.isValid()) {
175
185
  this.currentYearNumber = selectedDate.year();
176
186
  this.currentMonthNumber = selectedDate.month();
@@ -180,17 +190,17 @@ class TzDpContainerComponent {
180
190
  }
181
191
  calculateMinMaxDays() {
182
192
  const currentInstance = this.parseZoneInstance().year(this.currentYearNumber).month(this.currentMonthNumber);
183
- const minDate = this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format);
193
+ const minDate = !!this.data.dpConfig.minDate ? this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format) : dayjs('invalid');
184
194
  if (minDate.isValid()) {
185
195
  this.isPreviousMonthDisabled = minDate.isSameOrAfter(currentInstance, "month");
186
196
  }
187
- const maxDate = this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format);
197
+ const maxDate = !!this.data.dpConfig.maxDate ? this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format) : dayjs('invalid');
188
198
  if (maxDate.isValid()) {
189
199
  this.isNextMonthDisabled = maxDate.isSameOrBefore(currentInstance, "month");
190
200
  }
191
201
  }
192
202
  navigateMonth(direction) {
193
- let thisMonth = parseZone().year(this.currentYearNumber).month(this.currentMonthNumber);
203
+ let thisMonth = dayjs().year(this.currentYearNumber).month(this.currentMonthNumber);
194
204
  if (direction === "NEXT") {
195
205
  thisMonth = thisMonth.add(1, "month");
196
206
  }
@@ -206,16 +216,16 @@ class TzDpContainerComponent {
206
216
  generateDates(month, currentYearNumber) {
207
217
  var _a;
208
218
  let dates = [];
209
- const daysInMonth = parseZone().year(currentYearNumber).month(month).daysInMonth();
219
+ const daysInMonth = dayjs().year(currentYearNumber).month(month).daysInMonth();
210
220
  for (let currentDate = 1; currentDate <= daysInMonth; currentDate++) {
211
221
  const date = this.parseZoneInstance().year(currentYearNumber).month(month).date(currentDate);
212
222
  const dateString = date.format(this.data.dpConfig.format);
213
223
  let isDisabledDay = this.data.datesDisabled.some(d => d === dateString);
214
- const minDate = this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format);
224
+ const minDate = !!this.data.dpConfig.minDate ? this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format) : dayjs('invalid');
215
225
  if (!isDisabledDay && minDate.isValid()) {
216
226
  isDisabledDay = minDate.isAfter(date, "day");
217
227
  }
218
- const maxDate = this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format);
228
+ const maxDate = !!this.data.dpConfig.maxDate ? this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format) : dayjs('invalid');
219
229
  if (!isDisabledDay && maxDate.isValid()) {
220
230
  isDisabledDay = maxDate.isBefore(date, "day");
221
231
  }
@@ -236,8 +246,8 @@ class TzDpContainerComponent {
236
246
  }
237
247
  selectDay(day) {
238
248
  this.currentSelection = this.parseZoneInstance().year(this.currentYearNumber).month(this.currentMonthNumber).date(day.date);
239
- const maxDate = this.parseZoneInstance(this.data.dpConfig.maxDate).endOf("day");
240
- const minDate = this.parseZoneInstance(this.data.dpConfig.minDate).startOf("day");
249
+ const maxDate = !!this.data.dpConfig.maxDate ? this.parseZoneInstance(this.data.dpConfig.maxDate).endOf("day") : dayjs('invalid');
250
+ const minDate = !!this.data.dpConfig.maxDate ? this.parseZoneInstance(this.data.dpConfig.minDate).startOf("day") : dayjs('invalid');
241
251
  this.allowBookingOnDisabledDay = this.data.allowBookingOnDisabledDay;
242
252
  if (day.date <= 0)
243
253
  return;
@@ -253,7 +263,7 @@ class TzDpContainerComponent {
253
263
  }
254
264
  applyDate(day) {
255
265
  if (day || this.localSelectedDate) {
256
- this.data.dateChange(parseZone()
266
+ this.data.dateChange(dayjs()
257
267
  .year(this.currentYearNumber)
258
268
  .month(this.currentMonthNumber)
259
269
  .date(day ? day.date : this.localSelectedDate.date)