@hmcts/ccd-case-ui-toolkit 7.2.50-srt-rc3 → 7.2.50-srt-rc4

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 (20) hide show
  1. package/esm2022/lib/components/form/date-input/date-input.component.mjs +19 -56
  2. package/esm2022/lib/shared/components/case-editor/case-edit-form/case-edit-form.component.mjs +3 -24
  3. package/esm2022/lib/shared/components/case-editor/case-edit-page/case-edit-page.component.mjs +2 -4
  4. package/esm2022/lib/shared/components/palette/datetime-picker/datetime-picker.component.mjs +10 -41
  5. package/esm2022/lib/shared/services/form/field-type-sanitiser.mjs +1 -2
  6. package/esm2022/lib/shared/services/form/form-value.service.mjs +1 -58
  7. package/fesm2022/hmcts-ccd-case-ui-toolkit.mjs +30 -179
  8. package/fesm2022/hmcts-ccd-case-ui-toolkit.mjs.map +1 -1
  9. package/lib/components/form/date-input/date-input.component.d.ts +0 -4
  10. package/lib/components/form/date-input/date-input.component.d.ts.map +1 -1
  11. package/lib/shared/components/case-editor/case-edit-form/case-edit-form.component.d.ts +0 -1
  12. package/lib/shared/components/case-editor/case-edit-form/case-edit-form.component.d.ts.map +1 -1
  13. package/lib/shared/components/case-editor/case-edit-page/case-edit-page.component.d.ts.map +1 -1
  14. package/lib/shared/components/palette/datetime-picker/datetime-picker.component.d.ts +0 -2
  15. package/lib/shared/components/palette/datetime-picker/datetime-picker.component.d.ts.map +1 -1
  16. package/lib/shared/services/form/field-type-sanitiser.d.ts +0 -1
  17. package/lib/shared/services/form/field-type-sanitiser.d.ts.map +1 -1
  18. package/lib/shared/services/form/form-value.service.d.ts +0 -2
  19. package/lib/shared/services/form/form-value.service.d.ts.map +1 -1
  20. package/package.json +1 -1
@@ -101,40 +101,20 @@ export class DateInputComponent {
101
101
  writeValue(obj) {
102
102
  if (obj) {
103
103
  this.rawValue = this.removeMilliseconds(obj);
104
- this.getLocalDateTimeString(this.rawValue);
105
- }
106
- }
107
- getLocalDateTimeString(dateInput) {
108
- const date = new Date(dateInput);
109
- if (isNaN(date.getTime())) {
110
- // Not a valid date
111
- this.year = this.displayYear = '';
112
- this.month = this.displayMonth = '';
113
- this.day = this.displayDay = '';
114
- this.hour = this.displayHour = '';
115
- this.minute = this.displayMinute = '';
116
- this.second = this.displaySecond = '';
117
- return;
118
- }
119
- const localDate = this.getOffsetDate(date);
120
- this.year = this.displayYear = String(localDate.getFullYear());
121
- this.month = this.displayMonth = this.padZero(localDate.getMonth() + 1);
122
- this.day = this.displayDay = this.padZero(localDate.getDate());
123
- if (dateInput.includes('T')) {
124
- this.hour = this.displayHour = this.padZero(localDate.getHours());
125
- this.minute = this.displayMinute = this.padZero(localDate.getMinutes());
126
- this.second = this.displaySecond = this.padZero(localDate.getSeconds());
127
- }
128
- else {
129
- this.hour = this.displayHour = '';
130
- this.minute = this.displayMinute = '';
131
- this.second = this.displaySecond = '';
104
+ // needs to handle also partial dates, e.g. -05-2016 (missing day)
105
+ const [datePart, timePart] = this.rawValue.split('T');
106
+ const dateValues = datePart.split('-');
107
+ this.year = this.displayYear = dateValues[0] || '';
108
+ this.month = this.displayMonth = dateValues[1] || '';
109
+ this.day = this.displayDay = dateValues[2] || '';
110
+ if (timePart) {
111
+ const timeParts = timePart.split(':');
112
+ this.hour = this.displayHour = timeParts[0] || '';
113
+ this.minute = this.displayMinute = timeParts[1] || '';
114
+ this.second = this.displaySecond = timeParts[2] || '';
115
+ }
132
116
  }
133
117
  }
134
- getOffsetDate(date) {
135
- const localOffset = -date.getTimezoneOffset() / 60;
136
- return new Date(date.getTime() + localOffset * 3600 * 1000);
137
- }
138
118
  validate(control) {
139
119
  if (this.mandatory && !this.viewValue()) {
140
120
  return {
@@ -162,42 +142,42 @@ export class DateInputComponent {
162
142
  dayChange(value) {
163
143
  // get value from input
164
144
  this.day = value;
165
- this.rawValue = this.isDateFormat(this.viewValue()) && this.viewValue().includes('T') ? this.convertToUTC(this.viewValue()) : this.viewValue();
145
+ this.rawValue = this.viewValue();
166
146
  // update the form
167
147
  this.propagateChange(this.rawValue);
168
148
  }
169
149
  monthChange(value) {
170
150
  // get value from input
171
151
  this.month = value;
172
- this.rawValue = this.isDateFormat(this.viewValue()) && this.viewValue().includes('T') ? this.convertToUTC(this.viewValue()) : this.viewValue();
152
+ this.rawValue = this.viewValue();
173
153
  // update the form
174
154
  this.propagateChange(this.rawValue);
175
155
  }
176
156
  yearChange(value) {
177
157
  // get value from input
178
158
  this.year = value;
179
- this.rawValue = this.isDateFormat(this.viewValue()) && this.viewValue().includes('T') ? this.convertToUTC(this.viewValue()) : this.viewValue();
159
+ this.rawValue = this.viewValue();
180
160
  // update the form
181
161
  this.propagateChange(this.rawValue);
182
162
  }
183
163
  hourChange(value) {
184
164
  // get value from input
185
165
  this.hour = value;
186
- this.rawValue = this.isDateFormat(this.viewValue()) ? this.convertToUTC(this.viewValue()) : this.viewValue();
166
+ this.rawValue = this.viewValue();
187
167
  // update the form
188
168
  this.propagateChange(this.rawValue);
189
169
  }
190
170
  minuteChange(value) {
191
171
  // get value from input
192
172
  this.minute = value;
193
- this.rawValue = this.isDateFormat(this.viewValue()) ? this.convertToUTC(this.viewValue()) : this.viewValue();
173
+ this.rawValue = this.viewValue();
194
174
  // update the form
195
175
  this.propagateChange(this.rawValue);
196
176
  }
197
177
  secondChange(value) {
198
178
  // get value from input
199
179
  this.second = value;
200
- this.rawValue = this.isDateFormat(this.viewValue()) ? this.convertToUTC(this.viewValue()) : this.viewValue();
180
+ this.rawValue = this.viewValue();
201
181
  // update the form
202
182
  this.propagateChange(this.rawValue);
203
183
  }
@@ -232,23 +212,6 @@ export class DateInputComponent {
232
212
  secondId() {
233
213
  return this.id + '-second';
234
214
  }
235
- // convert the dates to UTC before sending to the backend
236
- convertToUTC(input) {
237
- if (!input)
238
- return null;
239
- const date = new Date(input);
240
- const year = date.getUTCFullYear();
241
- const month = this.padZero(date.getUTCMonth() + 1);
242
- const day = this.padZero(date.getUTCDate());
243
- const hour = this.padZero(date.getUTCHours());
244
- const minute = this.padZero(date.getUTCMinutes());
245
- const second = this.padZero(date.getUTCSeconds());
246
- const ms = date.getUTCMilliseconds().toString().padStart(3, '0');
247
- return `${year}-${month}-${day}T${hour}:${minute}:${second}.${ms}`;
248
- }
249
- padZero(value) {
250
- return value.toString().padStart(2, '0');
251
- }
252
215
  viewValue() {
253
216
  if (this.day || this.month || this.year || this.hour || this.minute || this.second) {
254
217
  const date = [
@@ -381,4 +344,4 @@ export class DateInputComponent {
381
344
  type: Input
382
345
  }] }); })();
383
346
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(DateInputComponent, { className: "DateInputComponent", filePath: "lib/components/form/date-input/date-input.component.ts", lineNumber: 20 }); })();
384
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ccd-case-ui-toolkit/src/lib/components/form/date-input/date-input.component.ts","../../../../../../../projects/ccd-case-ui-toolkit/src/lib/components/form/date-input/date-input.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnDestroy, OnInit } from '@angular/core';\nimport { AbstractControl, ControlValueAccessor, FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from '@angular/forms';\n\n@Component({\n  selector: 'cut-date-input',\n  templateUrl: './date-input.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DateInputComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DateInputComponent),\n      multi: true\n    }\n  ],\n})\nexport class DateInputComponent implements ControlValueAccessor, Validator, OnInit, OnDestroy {\n  @Input()\n  public id: string;\n\n  @Input()\n  public mandatory: boolean;\n\n  @Input()\n  public isDateTime: boolean;\n\n  @Input()\n  public formControl: FormControl;\n\n  @Input()\n  public isInvalid: boolean;\n\n  public isTouched = false;\n  public displayDay: string = null;\n  public displayMonth: string = null;\n  public displayYear: string = null;\n\n  public displayHour: string = null;\n  public displayMinute: string = null;\n  public displaySecond: string = null;\n  // Works with\n  // 2018-04-09T08:02:27.542\n  // 2018-04-09T08:02:27.542Z\n  // 2018-04-09T08:02:27.542+01:00\n  private readonly DATE_FORMAT =\n    /^(19|20)\\d{2}-?(\\d\\d)-?(\\d\\d)(?:T(\\d\\d)(?::?(\\d\\d)(?::?(\\d\\d)(?:\\.(\\d+))?)?)?(Z|([+-])(\\d\\d):?(\\d\\d))?|Z)?$/;\n  //    year - month -  day     T   HH     :   MM      :  SS       .000        Z or +     01 :   00\n  private propagateChange: (_: any) => {};\n  private rawValue = '';\n  private day: string;\n  private month: string;\n  private year: string;\n  private hour: string;\n  private minute: string;\n  private second: string;\n\n  public ngOnInit() {\n    if (this.mandatory && this.isDateTime) {\n      this.displayHour = '00';\n      this.displayMinute = '00';\n      this.displaySecond = '00';\n      this.hour = '00';\n      this.minute = '00';\n      this.second = '00';\n    }\n  }\n\n  public writeValue(obj: string): void { // 2018-04-09T08:02:27.542\n    if (obj) {\n      this.rawValue = this.removeMilliseconds(obj);\n      this.getLocalDateTimeString(this.rawValue);\n    }\n  }\n\n  private getLocalDateTimeString(dateInput: string): void {\n    const date = new Date(dateInput);\n    if (isNaN(date.getTime())) {\n      // Not a valid date\n      this.year = this.displayYear = '';\n      this.month = this.displayMonth = '';\n      this.day = this.displayDay = '';\n      this.hour = this.displayHour = '';\n      this.minute = this.displayMinute = '';\n      this.second = this.displaySecond = '';\n      return;\n    }\n\n    const localDate = this.getOffsetDate(date);\n    this.year = this.displayYear = String(localDate.getFullYear());\n    this.month = this.displayMonth = this.padZero(localDate.getMonth() + 1);\n    this.day = this.displayDay = this.padZero(localDate.getDate());\n\n    if (dateInput.includes('T')) {\n      this.hour = this.displayHour = this.padZero(localDate.getHours());\n      this.minute = this.displayMinute = this.padZero(localDate.getMinutes());\n      this.second = this.displaySecond = this.padZero(localDate.getSeconds());\n    } else {\n      this.hour = this.displayHour = '';\n      this.minute = this.displayMinute = '';\n      this.second = this.displaySecond = '';\n    }\n  }\n\n  private getOffsetDate(date: Date): Date {\n    const localOffset = - date.getTimezoneOffset() / 60;\n    return new Date(date.getTime() + localOffset * 3600 * 1000);\n  }\n\n  public validate(control: AbstractControl): ValidationErrors {\n    if (this.mandatory && !this.viewValue()) {\n      return {\n        required: 'This field is required'\n      };\n    }\n    if (control.value && !this.isDateFormat(this.getValueForValidation(control))) {\n      return {\n        pattern: 'Date is not valid'\n      };\n    }\n    return undefined;\n  }\n\n  public registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  public registerOnTouched(fn: any): void {\n    // Do nothing.\n  }\n\n  public ngOnDestroy() {\n    this.validate = (control: AbstractControl): ValidationErrors => {\n      return undefined;\n    };\n  }\n\n  public dayChange(value: string) {\n    // get value from input\n    this.day = value;\n\n    this.rawValue = this.isDateFormat(this.viewValue()) && this.viewValue().includes('T') ? this.convertToUTC(this.viewValue()) : this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n  }\n\n  public monthChange(value: string) {\n    // get value from input\n    this.month = value;\n\n    this.rawValue = this.isDateFormat(this.viewValue()) && this.viewValue().includes('T') ? this.convertToUTC(this.viewValue()) : this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n\n  }\n\n  public yearChange(value: string) {\n    // get value from input\n    this.year = value;\n\n    this.rawValue = this.isDateFormat(this.viewValue()) && this.viewValue().includes('T') ? this.convertToUTC(this.viewValue()) : this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n  }\n\n  public hourChange(value: string) {\n    // get value from input\n    this.hour = value;\n\n    this.rawValue = this.isDateFormat(this.viewValue()) ? this.convertToUTC(this.viewValue()) : this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n  }\n\n  public minuteChange(value: string) {\n    // get value from input\n    this.minute = value;\n\n    this.rawValue = this.isDateFormat(this.viewValue()) ? this.convertToUTC(this.viewValue()) : this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n\n  }\n\n  public secondChange(value: string) {\n    // get value from input\n    this.second = value;\n\n    this.rawValue = this.isDateFormat(this.viewValue()) ? this.convertToUTC(this.viewValue()) : this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n  }\n\n  public inputFocus() {\n    this.isTouched = false;\n    this.touch();\n  }\n\n  public touch() {\n    if (this.isTouched) {\n      this.formControl.markAsTouched();\n      this.propagateChange(this.rawValue);\n    } else {\n      this.formControl.markAsUntouched();\n    }\n  }\n\n  public dayId() {\n    return this.id + '-day';\n  }\n\n  public monthId() {\n    return this.id + '-month';\n  }\n\n  public yearId() {\n    return this.id + '-year';\n  }\n\n  public hourId() {\n    return this.id + '-hour';\n  }\n\n  public minuteId() {\n    return this.id + '-minute';\n  }\n\n  public secondId() {\n    return this.id + '-second';\n  }\n\n  // convert the dates to UTC before sending to the backend\n  private convertToUTC(input: string): string | null {\n    if (!input) return null;\n\n    const date = new Date(input);\n\n    const year = date.getUTCFullYear();\n    const month = this.padZero(date.getUTCMonth() + 1);\n    const day = this.padZero(date.getUTCDate());\n    const hour = this.padZero(date.getUTCHours());\n    const minute = this.padZero(date.getUTCMinutes());\n    const second = this.padZero(date.getUTCSeconds());\n    const ms = date.getUTCMilliseconds().toString().padStart(3, '0');\n\n    return `${year}-${month}-${day}T${hour}:${minute}:${second}.${ms}`;\n  }\n\n  private padZero(value: number): string {\n    return value.toString().padStart(2, '0');\n  }\n\n  private viewValue(): string {\n    if (this.day || this.month || this.year || this.hour || this.minute || this.second) {\n      const date = [\n        this.year ? this.year : '',\n        this.month ? this.pad(this.month) : '',\n        this.day ? this.pad(this.day) : ''\n      ].join('-');\n      if (this.isDateTime) {\n        const time = [\n          this.hour ? this.pad(this.hour) : '',\n          this.minute ? this.pad(this.minute) : '',\n          this.second ? this.pad(this.second) : ''\n        ].join(':');\n        return `${date}T${time}.000`;\n      } else {\n        return date;\n      }\n    }\n    return null;\n  }\n\n  private isDateFormat(val: any): boolean {\n    return this.DATE_FORMAT.test(val);\n  }\n\n  private pad(num: any, padNum = 2): string {\n    const val = num !== undefined ? num.toString() : '';\n    return val.length >= padNum ? val : new Array(padNum - val.length + 1).join('0') + val;\n  }\n\n  private getValueForValidation(control: any) {\n    if (this.isDateTime) {\n      return control.value;\n    } else {\n      return control.value.replace(/Z.*/, 'T00:00:00Z');\n    }\n  }\n\n  private removeMilliseconds(dateTime: string): string {\n    return dateTime.replace(/\\..*/, '');\n  }\n}\n","<div class=\"form-date\">\n  <div class=\"form-group form-group-day\">\n    <span class=\"form-label\" [attr.id]=\"'day-label-'+dayId()\">{{'Day' | rpxTranslate}}</span>\n    <input #dayInput\n           class=\"form-control\"\n           [id]=\"dayId()\"\n           [name]=\"dayId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'day-label-'+dayId()\"\n           [value]=\"displayDay\"\n           (change)=\"dayChange(dayInput.value)\"\n           (keyup)=\"dayChange(dayInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n\n  <div class=\"form-group form-group-month\">\n    <span class=\"form-label\" [attr.id]=\"'month-label-'+ monthId()\">{{'Month' | rpxTranslate}}</span>\n    <input #monthInput\n           class=\"form-control\"\n           [id]=\"monthId()\"\n           [name]=\"monthId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'month-label-'+ monthId()\"\n           [value]=\"displayMonth\"\n           (change)=\"monthChange(monthInput.value)\"\n           (keyup)=\"monthChange(monthInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n\n  <div class=\"form-group form-group-year\">\n    <span class=\"form-label\" [attr.id]=\"'year-label-'+ yearId()\">{{'Year' | rpxTranslate}}</span>\n    <input #yearInput\n           class=\"form-control\"\n           [id]=\"yearId()\"\n           [name]=\"yearId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'year-label-'+ yearId()\"\n           [value]=\"displayYear\"\n           (change)=\"yearChange(yearInput.value)\"\n           (keyup)=\"yearChange(yearInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n\n  <div class=\"form-group form-group-hour\" *ngIf=\"isDateTime\">\n    <span class=\"form-label\" [attr.id]=\"'hour-label-'+ hourId()\">{{'Hour' | rpxTranslate}}</span>\n    <input #hourInput\n           class=\"form-control\"\n           [id]=\"hourId()\"\n           [name]=\"hourId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'hour-label-'+ hourId()\"\n           [value]=\"displayHour\"\n           (input)=\"hourChange(hourInput.value)\"\n           (keyup)=\"hourChange(hourInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n\n  <div class=\"form-group form-group-minute\" *ngIf=\"isDateTime\">\n    <span class=\"form-label\" [attr.id]=\"'minute-label-'+ hourId()\">{{'Minute' | rpxTranslate}}</span>\n    <input #minuteInput\n           class=\"form-control\"\n           [id]=\"minuteId()\"\n           [name]=\"minuteId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'minute-label-'+ minuteId()\"\n           [value]=\"displayMinute\"\n           (input)=\"minuteChange(minuteInput.value)\"\n           (keyup)=\"minuteChange(minuteInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n\n  <div class=\"form-group form-group-second\" *ngIf=\"isDateTime\">\n    <span class=\"form-label\" [attr.id]=\"'second-label-'+ secondId()\">{{'Second' | rpxTranslate}}</span>\n    <input #secondInput\n           class=\"form-control\"\n           [id]=\"secondId()\"\n           [name]=\"secondId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'second-label-'+ secondId()\"\n           [value]=\"displaySecond\"\n           (input)=\"secondChange(secondInput.value)\"\n           (keyup)=\"secondChange(secondInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n</div>\n"]}
347
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/ccd-case-ui-toolkit/src/lib/components/form/date-input/date-input.component.ts","../../../../../../../projects/ccd-case-ui-toolkit/src/lib/components/form/date-input/date-input.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAqB,MAAM,eAAe,CAAC;AAChF,OAAO,EAAyC,WAAW,EAAE,aAAa,EAAE,iBAAiB,EAA+B,MAAM,gBAAgB,CAAC;;;;;;;ICoD/I,AADF,+BAA2D,cACI;IAAA,YAAyB;;IAAA,iBAAO;IAC7F,oCAYqD;IAD9C,AADA,AADA,sNAAS,qCAA2B,KAAC,yMAC5B,qCAA2B,KAAC,iKAC5B,mBAAY,KAAC;IAE/B,AAbE,iBAYqD,EACjD;;;IAdqB,cAAmC;;IAAC,cAAyB;IAAzB,kDAAyB;IAG/E,eAAe;IAUf,AAJA,AALA,AADA,oCAAe,yBACE,6BAKI,yDAIwB;;;;;IAIpD,AADF,+BAA6D,cACI;IAAA,YAA2B;;IAAA,iBAAO;IACjG,oCAYqD;IAD9C,AADA,AADA,wNAAS,yCAA+B,KAAC,2MAChC,yCAA+B,KAAC,iKAChC,mBAAY,KAAC;IAE/B,AAbE,iBAYqD,EACjD;;;IAdqB,cAAqC;;IAAC,cAA2B;IAA3B,oDAA2B;IAGnF,eAAiB;IAUjB,AAJA,AALA,AADA,sCAAiB,2BACE,+BAKI,yDAIsB;;;;;IAIpD,AADF,+BAA6D,cACM;IAAA,YAA2B;;IAAA,iBAAO;IACnG,oCAYqD;IAD9C,AADA,AADA,0NAAS,0CAA+B,KAAC,6MAChC,0CAA+B,KAAC,kKAChC,mBAAY,KAAC;IAE/B,AAbE,iBAYqD,EACjD;;;IAdqB,cAAuC;;IAAC,cAA2B;IAA3B,oDAA2B;IAGrF,eAAiB;IAUjB,AAJA,AALA,AADA,sCAAiB,2BACE,+BAKI,yDAIsB;;;ADjFxD,MAAM,OAAO,kBAAkB;IAEtB,EAAE,CAAS;IAGX,SAAS,CAAU;IAGnB,UAAU,CAAU;IAGpB,WAAW,CAAc;IAGzB,SAAS,CAAU;IAEnB,SAAS,GAAG,KAAK,CAAC;IAClB,UAAU,GAAW,IAAI,CAAC;IAC1B,YAAY,GAAW,IAAI,CAAC;IAC5B,WAAW,GAAW,IAAI,CAAC;IAE3B,WAAW,GAAW,IAAI,CAAC;IAC3B,aAAa,GAAW,IAAI,CAAC;IAC7B,aAAa,GAAW,IAAI,CAAC;IACpC,aAAa;IACb,0BAA0B;IAC1B,2BAA2B;IAC3B,gCAAgC;IACf,WAAW,GAC1B,6GAA6G,CAAC;IAChH,iGAAiG;IACzF,eAAe,CAAiB;IAChC,QAAQ,GAAG,EAAE,CAAC;IACd,GAAG,CAAS;IACZ,KAAK,CAAS;IACd,IAAI,CAAS;IACb,IAAI,CAAS;IACb,MAAM,CAAS;IACf,MAAM,CAAS;IAEhB,QAAQ;QACb,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACtC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAC1B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QACrB,CAAC;IACH,CAAC;IAEM,UAAU,CAAC,GAAW;QAC3B,IAAI,GAAG,EAAE,CAAC;YACR,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;YAC7C,kEAAkE;YAClE,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACtD,MAAM,UAAU,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACvC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YACnD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,GAAG,UAAU,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YACrD,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YACjD,IAAI,QAAQ,EAAE,CAAC;gBACb,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBACtC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;gBAClD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;gBACtD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YACxD,CAAC;QACH,CAAC;IACH,CAAC;IAEM,QAAQ,CAAC,OAAwB;QACtC,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;YACxC,OAAO;gBACL,QAAQ,EAAE,wBAAwB;aACnC,CAAC;QACJ,CAAC;QACD,IAAI,OAAO,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;YAC7E,OAAO;gBACL,OAAO,EAAE,mBAAmB;aAC7B,CAAC;QACJ,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAEM,gBAAgB,CAAC,EAAO;QAC7B,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;IAEM,iBAAiB,CAAC,EAAO;QAC9B,cAAc;IAChB,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,QAAQ,GAAG,CAAC,OAAwB,EAAoB,EAAE;YAC7D,OAAO,SAAS,CAAC;QACnB,CAAC,CAAC;IACJ,CAAC;IAEM,SAAS,CAAC,KAAa;QAC5B,uBAAuB;QACvB,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC;QAEjB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAEjC,kBAAkB;QAClB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC;IAEM,WAAW,CAAC,KAAa;QAC9B,uBAAuB;QACvB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAEjC,kBAAkB;QAClB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAEtC,CAAC;IAEM,UAAU,CAAC,KAAa;QAC7B,uBAAuB;QACvB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAElB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAEjC,kBAAkB;QAClB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC;IAEM,UAAU,CAAC,KAAa;QAC7B,uBAAuB;QACvB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;QAElB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAEjC,kBAAkB;QAClB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC;IAEM,YAAY,CAAC,KAAa;QAC/B,uBAAuB;QACvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QAEpB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAEjC,kBAAkB;QAClB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAEtC,CAAC;IAEM,YAAY,CAAC,KAAa;QAC/B,uBAAuB;QACvB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QAEpB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAEjC,kBAAkB;QAClB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAEM,KAAK;QACV,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,CAAC;YACjC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC;QACrC,CAAC;IACH,CAAC;IAEM,KAAK;QACV,OAAO,IAAI,CAAC,EAAE,GAAG,MAAM,CAAC;IAC1B,CAAC;IAEM,OAAO;QACZ,OAAO,IAAI,CAAC,EAAE,GAAG,QAAQ,CAAC;IAC5B,CAAC;IAEM,MAAM;QACX,OAAO,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC;IAC3B,CAAC;IAEM,MAAM;QACX,OAAO,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC;IAC3B,CAAC;IAEM,QAAQ;QACb,OAAO,IAAI,CAAC,EAAE,GAAG,SAAS,CAAC;IAC7B,CAAC;IAEM,QAAQ;QACb,OAAO,IAAI,CAAC,EAAE,GAAG,SAAS,CAAC;IAC7B,CAAC;IAEO,SAAS;QACf,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACnF,MAAM,IAAI,GAAG;gBACX,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;gBAC1B,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;gBACtC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;aACnC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACZ,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;gBACpB,MAAM,IAAI,GAAG;oBACX,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE;oBACpC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE;oBACxC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE;iBACzC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBACZ,OAAO,GAAG,IAAI,IAAI,IAAI,MAAM,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACN,OAAO,IAAI,CAAC;YACd,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,YAAY,CAAC,GAAQ;QAC3B,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACpC,CAAC;IAEO,GAAG,CAAC,GAAQ,EAAE,MAAM,GAAG,CAAC;QAC9B,MAAM,GAAG,GAAG,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACpD,OAAO,GAAG,CAAC,MAAM,IAAI,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;IACzF,CAAC;IAEO,qBAAqB,CAAC,OAAY;QACxC,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,OAAO,OAAO,CAAC,KAAK,CAAC;QACvB,CAAC;aAAM,CAAC;YACN,OAAO,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;QACpD,CAAC;IACH,CAAC;IAEO,kBAAkB,CAAC,QAAgB;QACzC,OAAO,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IACtC,CAAC;4GA7OU,kBAAkB;6DAAlB,kBAAkB,gMAblB;gBACT;oBACE,OAAO,EAAE,iBAAiB;oBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;oBACjD,KAAK,EAAE,IAAI;iBACZ;gBACD;oBACE,OAAO,EAAE,aAAa;oBACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;oBACjD,KAAK,EAAE,IAAI;iBACZ;aACF;;YCfC,AADF,AADF,8BAAuB,aACkB,cACqB;YAAA,YAAwB;;YAAA,iBAAO;YACzF,mCAYqD;YAD9C,AADA,AADA,6KAAU,gCAAyB,KAAC,8JAC3B,gCAAyB,KAAC,uHAC1B,gBAAY,KAAC;YAE/B,AAbE,iBAYqD,EACjD;YAGJ,AADF,+BAAyC,cACwB;YAAA,YAA0B;;YAAA,iBAAO;YAChG,oCAYqD;YAD9C,AADA,AADA,iLAAU,oCAA6B,KAAC,kKAC/B,oCAA6B,KAAC,wHAC9B,gBAAY,KAAC;YAE/B,AAbE,iBAYqD,EACjD;YAGJ,AADF,gCAAwC,eACuB;YAAA,aAAyB;;YAAA,iBAAO;YAC7F,oCAYqD;YAD9C,AADA,AADA,gLAAU,kCAA2B,KAAC,iKAC7B,kCAA2B,KAAC,wHAC5B,gBAAY,KAAC;YAE/B,AAbE,iBAYqD,EACjD;YAoCN,AAjBA,AAjBA,uEAA2D,0DAiBE,0DAiBA;YAgB/D,iBAAM;;YApGuB,eAAgC;;YAAC,cAAwB;YAAxB,kDAAwB;YAG3E,eAAc;YAUd,AAJA,AALA,AADA,gCAAc,qBACE,yBAKI,uDAIyB;;YAI3B,eAAqC;;YAAC,cAA0B;YAA1B,qDAA0B;YAGlF,eAAgB;YAUhB,AAJA,AALA,AADA,kCAAgB,uBACE,2BAKI,uDAIuB;;YAI3B,eAAmC;;YAAC,cAAyB;YAAzB,oDAAyB;YAG/E,eAAe;YAUf,AAJA,AALA,AADA,iCAAe,sBACE,0BAKI,uDAIwB;;YAGb,eAAgB;YAAhB,qCAAgB;YAiBd,cAAgB;YAAhB,qCAAgB;YAiBhB,cAAgB;YAAhB,qCAAgB;;;iFDnEhD,kBAAkB;cAhB9B,SAAS;2BACE,gBAAgB,aAEf;oBACT;wBACE,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;wBACjD,KAAK,EAAE,IAAI;qBACZ;oBACD;wBACE,OAAO,EAAE,aAAa;wBACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;wBACjD,KAAK,EAAE,IAAI;qBACZ;iBACF;gBAIM,EAAE;kBADR,KAAK;YAIC,SAAS;kBADf,KAAK;YAIC,UAAU;kBADhB,KAAK;YAIC,WAAW;kBADjB,KAAK;YAIC,SAAS;kBADf,KAAK;;kFAbK,kBAAkB","sourcesContent":["import { Component, forwardRef, Input, OnDestroy, OnInit } from '@angular/core';\nimport { AbstractControl, ControlValueAccessor, FormControl, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from '@angular/forms';\n\n@Component({\n  selector: 'cut-date-input',\n  templateUrl: './date-input.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DateInputComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DateInputComponent),\n      multi: true\n    }\n  ],\n})\nexport class DateInputComponent implements ControlValueAccessor, Validator, OnInit, OnDestroy {\n  @Input()\n  public id: string;\n\n  @Input()\n  public mandatory: boolean;\n\n  @Input()\n  public isDateTime: boolean;\n\n  @Input()\n  public formControl: FormControl;\n\n  @Input()\n  public isInvalid: boolean;\n\n  public isTouched = false;\n  public displayDay: string = null;\n  public displayMonth: string = null;\n  public displayYear: string = null;\n\n  public displayHour: string = null;\n  public displayMinute: string = null;\n  public displaySecond: string = null;\n  // Works with\n  // 2018-04-09T08:02:27.542\n  // 2018-04-09T08:02:27.542Z\n  // 2018-04-09T08:02:27.542+01:00\n  private readonly DATE_FORMAT =\n    /^(19|20)\\d{2}-?(\\d\\d)-?(\\d\\d)(?:T(\\d\\d)(?::?(\\d\\d)(?::?(\\d\\d)(?:\\.(\\d+))?)?)?(Z|([+-])(\\d\\d):?(\\d\\d))?|Z)?$/;\n  //    year - month -  day     T   HH     :   MM      :  SS       .000        Z or +     01 :   00\n  private propagateChange: (_: any) => {};\n  private rawValue = '';\n  private day: string;\n  private month: string;\n  private year: string;\n  private hour: string;\n  private minute: string;\n  private second: string;\n\n  public ngOnInit() {\n    if (this.mandatory && this.isDateTime) {\n      this.displayHour = '00';\n      this.displayMinute = '00';\n      this.displaySecond = '00';\n      this.hour = '00';\n      this.minute = '00';\n      this.second = '00';\n    }\n  }\n\n  public writeValue(obj: string): void { // 2018-04-09T08:02:27.542\n    if (obj) {\n      this.rawValue = this.removeMilliseconds(obj);\n      // needs to handle also partial dates, e.g. -05-2016 (missing day)\n      const [datePart, timePart] = this.rawValue.split('T');\n      const dateValues = datePart.split('-');\n      this.year = this.displayYear = dateValues[0] || '';\n      this.month = this.displayMonth = dateValues[1] || '';\n      this.day = this.displayDay = dateValues[2] || '';\n      if (timePart) {\n        const timeParts = timePart.split(':');\n        this.hour = this.displayHour = timeParts[0] || '';\n        this.minute = this.displayMinute = timeParts[1] || '';\n        this.second = this.displaySecond = timeParts[2] || '';\n      }\n    }\n  }\n\n  public validate(control: AbstractControl): ValidationErrors {\n    if (this.mandatory && !this.viewValue()) {\n      return {\n        required: 'This field is required'\n      };\n    }\n    if (control.value && !this.isDateFormat(this.getValueForValidation(control))) {\n      return {\n        pattern: 'Date is not valid'\n      };\n    }\n    return undefined;\n  }\n\n  public registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  public registerOnTouched(fn: any): void {\n    // Do nothing.\n  }\n\n  public ngOnDestroy() {\n    this.validate = (control: AbstractControl): ValidationErrors => {\n      return undefined;\n    };\n  }\n\n  public dayChange(value: string) {\n    // get value from input\n    this.day = value;\n\n    this.rawValue = this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n  }\n\n  public monthChange(value: string) {\n    // get value from input\n    this.month = value;\n\n    this.rawValue = this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n\n  }\n\n  public yearChange(value: string) {\n    // get value from input\n    this.year = value;\n\n    this.rawValue = this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n  }\n\n  public hourChange(value: string) {\n    // get value from input\n    this.hour = value;\n\n    this.rawValue = this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n  }\n\n  public minuteChange(value: string) {\n    // get value from input\n    this.minute = value;\n\n    this.rawValue = this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n\n  }\n\n  public secondChange(value: string) {\n    // get value from input\n    this.second = value;\n\n    this.rawValue = this.viewValue();\n\n    // update the form\n    this.propagateChange(this.rawValue);\n  }\n\n  public inputFocus() {\n    this.isTouched = false;\n    this.touch();\n  }\n\n  public touch() {\n    if (this.isTouched) {\n      this.formControl.markAsTouched();\n      this.propagateChange(this.rawValue);\n    } else {\n      this.formControl.markAsUntouched();\n    }\n  }\n\n  public dayId() {\n    return this.id + '-day';\n  }\n\n  public monthId() {\n    return this.id + '-month';\n  }\n\n  public yearId() {\n    return this.id + '-year';\n  }\n\n  public hourId() {\n    return this.id + '-hour';\n  }\n\n  public minuteId() {\n    return this.id + '-minute';\n  }\n\n  public secondId() {\n    return this.id + '-second';\n  }\n\n  private viewValue(): string {\n    if (this.day || this.month || this.year || this.hour || this.minute || this.second) {\n      const date = [\n        this.year ? this.year : '',\n        this.month ? this.pad(this.month) : '',\n        this.day ? this.pad(this.day) : ''\n      ].join('-');\n      if (this.isDateTime) {\n        const time = [\n          this.hour ? this.pad(this.hour) : '',\n          this.minute ? this.pad(this.minute) : '',\n          this.second ? this.pad(this.second) : ''\n        ].join(':');\n        return `${date}T${time}.000`;\n      } else {\n        return date;\n      }\n    }\n    return null;\n  }\n\n  private isDateFormat(val: any): boolean {\n    return this.DATE_FORMAT.test(val);\n  }\n\n  private pad(num: any, padNum = 2): string {\n    const val = num !== undefined ? num.toString() : '';\n    return val.length >= padNum ? val : new Array(padNum - val.length + 1).join('0') + val;\n  }\n\n  private getValueForValidation(control: any) {\n    if (this.isDateTime) {\n      return control.value;\n    } else {\n      return control.value.replace(/Z.*/, 'T00:00:00Z');\n    }\n  }\n\n  private removeMilliseconds(dateTime: string): string {\n    return dateTime.replace(/\\..*/, '');\n  }\n}","<div class=\"form-date\">\n  <div class=\"form-group form-group-day\">\n    <span class=\"form-label\" [attr.id]=\"'day-label-'+dayId()\">{{'Day' | rpxTranslate}}</span>\n    <input #dayInput\n           class=\"form-control\"\n           [id]=\"dayId()\"\n           [name]=\"dayId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'day-label-'+dayId()\"\n           [value]=\"displayDay\"\n           (change)=\"dayChange(dayInput.value)\"\n           (keyup)=\"dayChange(dayInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n\n  <div class=\"form-group form-group-month\">\n    <span class=\"form-label\" [attr.id]=\"'month-label-'+ monthId()\">{{'Month' | rpxTranslate}}</span>\n    <input #monthInput\n           class=\"form-control\"\n           [id]=\"monthId()\"\n           [name]=\"monthId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'month-label-'+ monthId()\"\n           [value]=\"displayMonth\"\n           (change)=\"monthChange(monthInput.value)\"\n           (keyup)=\"monthChange(monthInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n\n  <div class=\"form-group form-group-year\">\n    <span class=\"form-label\" [attr.id]=\"'year-label-'+ yearId()\">{{'Year' | rpxTranslate}}</span>\n    <input #yearInput\n           class=\"form-control\"\n           [id]=\"yearId()\"\n           [name]=\"yearId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'year-label-'+ yearId()\"\n           [value]=\"displayYear\"\n           (change)=\"yearChange(yearInput.value)\"\n           (keyup)=\"yearChange(yearInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n\n  <div class=\"form-group form-group-hour\" *ngIf=\"isDateTime\">\n    <span class=\"form-label\" [attr.id]=\"'hour-label-'+ hourId()\">{{'Hour' | rpxTranslate}}</span>\n    <input #hourInput\n           class=\"form-control\"\n           [id]=\"hourId()\"\n           [name]=\"hourId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'hour-label-'+ hourId()\"\n           [value]=\"displayHour\"\n           (input)=\"hourChange(hourInput.value)\"\n           (keyup)=\"hourChange(hourInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n\n  <div class=\"form-group form-group-minute\" *ngIf=\"isDateTime\">\n    <span class=\"form-label\" [attr.id]=\"'minute-label-'+ hourId()\">{{'Minute' | rpxTranslate}}</span>\n    <input #minuteInput\n           class=\"form-control\"\n           [id]=\"minuteId()\"\n           [name]=\"minuteId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'minute-label-'+ minuteId()\"\n           [value]=\"displayMinute\"\n           (input)=\"minuteChange(minuteInput.value)\"\n           (keyup)=\"minuteChange(minuteInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n\n  <div class=\"form-group form-group-second\" *ngIf=\"isDateTime\">\n    <span class=\"form-label\" [attr.id]=\"'second-label-'+ secondId()\">{{'Second' | rpxTranslate}}</span>\n    <input #secondInput\n           class=\"form-control\"\n           [id]=\"secondId()\"\n           [name]=\"secondId()\"\n           type=\"text\"\n           pattern=\"[0-9]*\"\n           inputmode=\"numeric\"\n           [attr.aria-labelledby]=\"'second-label-'+ secondId()\"\n           [value]=\"displaySecond\"\n           (input)=\"secondChange(secondInput.value)\"\n           (keyup)=\"secondChange(secondInput.value)\"\n           (focus)=\"inputFocus()\"\n           [ngClass]=\"{'govuk-input--error': isInvalid}\">\n  </div>\n</div>\n"]}
@@ -112,29 +112,8 @@ export class CaseEditFormComponent {
112
112
  this.initial = JSON.stringify(this.formValueService.sanitise(this.formGroup.value));
113
113
  }
114
114
  detectChangesAndEmit(changes) {
115
- const current = this.formValueService.sanitise(changes);
116
- const isEqual = this.deepEqual(this.initial, current);
117
- this.valuesChanged.emit(!isEqual);
118
- }
119
- deepEqual(obj1, obj2) {
120
- // Simple deep equality check
121
- if (obj1 === obj2) {
122
- return true;
123
- }
124
- if (typeof obj1 !== 'object' || typeof obj2 !== 'object' || obj1 == null || obj2 == null) {
125
- return false;
126
- }
127
- const keys1 = Object.keys(obj1);
128
- const keys2 = Object.keys(obj2);
129
- if (keys1.length !== keys2.length) {
130
- return false;
131
- }
132
- for (const key of keys1) {
133
- if (!this.deepEqual(obj1[key], obj2[key])) {
134
- return false;
135
- }
136
- }
137
- return true;
115
+ const current = JSON.stringify(this.formValueService.sanitise(changes));
116
+ this.initial !== current ? this.valuesChanged.emit(true) : this.valuesChanged.emit(false);
138
117
  }
139
118
  static ɵfac = function CaseEditFormComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || CaseEditFormComponent)(i0.ɵɵdirectiveInject(i1.FormValueService)); };
140
119
  static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: CaseEditFormComponent, selectors: [["ccd-case-edit-form"]], inputs: { fields: "fields", formGroup: "formGroup", caseFields: "caseFields", pageChangeSubject: "pageChangeSubject" }, outputs: { valuesChanged: "valuesChanged" }, decls: 1, vars: 1, consts: [["CompoundRow", ""], ["ccdConditionalShowForm", "", 3, "formGroup", "caseFields", "contextFields", 4, "ngFor", "ngForOf"], ["ccdConditionalShowForm", "", 3, "formGroup", "caseFields", "contextFields"], ["ccdLabelSubstitutor", "", 3, "caseField", "formGroup", "contextFields"], [3, "ngSwitch"], [3, "caseField", "caseFields", "withLabel", "formGroup", 4, "ngSwitchCase"], [4, "ngSwitchCase"], [3, "caseField", "caseFields", "withLabel", "formGroup"], [4, "ngIf", "ngIfElse"], [3, "caseField", "caseFields", "formGroup", "idPrefix", "hidden"]], template: function CaseEditFormComponent_Template(rf, ctx) { if (rf & 1) {
@@ -158,4 +137,4 @@ export class CaseEditFormComponent {
158
137
  type: Output
159
138
  }] }); })();
160
139
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(CaseEditFormComponent, { className: "CaseEditFormComponent", filePath: "lib/shared/components/case-editor/case-edit-form/case-edit-form.component.ts", lineNumber: 12 }); })();
161
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"case-edit-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit-form/case-edit-form.component.ts","../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit-form/case-edit-form.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, OnDestroy, Output } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { Subject, Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport { CaseField } from '../../../domain/definition/case-field.model';\nimport { FormValueService } from '../../../services/form/form-value.service';\n\n@Component({\n  selector: 'ccd-case-edit-form',\n  templateUrl: 'case-edit-form.html'\n})\nexport class CaseEditFormComponent implements OnDestroy, AfterViewInit {\n\n  @Input()\n  public fields: CaseField[] = [];\n  @Input()\n  public formGroup: FormGroup;\n  @Input()\n  public caseFields: CaseField[] = [];\n  @Input()\n  public pageChangeSubject: Subject<boolean> = new Subject();\n  @Output()\n  public valuesChanged: EventEmitter<any> = new EventEmitter();\n\n  public initial: any;\n  public pageChangeSubscription: Subscription;\n  public formGroupChangeSubscription: Subscription;\n\n  constructor(private readonly formValueService: FormValueService) { }\n\n  public ngOnDestroy(): void {\n    if (this.pageChangeSubscription) {\n      this.pageChangeSubscription.unsubscribe();\n    }\n    if (this.formGroupChangeSubscription) {\n      this.formGroupChangeSubscription.unsubscribe();\n    }\n  }\n\n  // We need the below un/subscribe complexity as we do not have proper page component per page with its AfterViewInit hook\n  // being called on each page load. This is done for \"Cancel and return\" modal from RDM-2302.\n  public ngAfterViewInit(): void {\n    this.retrieveInitialFormValues();\n    this.pageChangeSubscription = this.pageChangeSubject.subscribe(() => {\n      if (this.formGroupChangeSubscription) {\n        this.formGroupChangeSubscription.unsubscribe();\n      }\n      // Timeout is required for the form to be rendered before subscription to form changes and initial form values retrieval.\n      setTimeout(() => {\n        this.subscribeToFormChanges();\n        this.retrieveInitialFormValues();\n      });\n    });\n    this.subscribeToFormChanges();\n  }\n\n  public subscribeToFormChanges() {\n    this.formGroupChangeSubscription = this.formGroup.valueChanges\n      .pipe(\n        debounceTime(200)\n      )\n      .subscribe(_ => this.detectChangesAndEmit(_));\n  }\n\n  public retrieveInitialFormValues() {\n    this.initial = JSON.stringify(this.formValueService.sanitise(this.formGroup.value));\n  }\n\n  public detectChangesAndEmit(changes) {\n    const current = this.formValueService.sanitise(changes);\n    const isEqual = this.deepEqual(this.initial, current);\n    this.valuesChanged.emit(!isEqual);\n  }\n\n  private deepEqual(obj1: any, obj2: any): boolean {\n    // Simple deep equality check\n    if (obj1 === obj2) {\n      return true;\n    }\n    if (typeof obj1 !== 'object' || typeof obj2 !== 'object' || obj1 == null || obj2 == null) {\n      return false;\n    }\n    const keys1 = Object.keys(obj1);\n    const keys2 = Object.keys(obj2);\n    if (keys1.length !== keys2.length) {\n      return false;\n    }\n    for (const key of keys1) {\n      if (!this.deepEqual(obj1[key], obj2[key])) {\n        return false;\n      }\n    }\n    return true;\n  }\n}\n","<ng-container ccdConditionalShowForm [formGroup]=\"formGroup\" [caseFields]=\"fields\" [contextFields]=\"caseFields\"\n              *ngFor=\"let field of fields\">\n\n  <div ccdLabelSubstitutor [caseField]=\"field\" [formGroup]=\"formGroup\" [contextFields]=\"caseFields\">\n    <ng-container [ngSwitch]=\"field | ccdIsReadOnlyAndNotCollection\">\n\n      <ccd-field-read *ngSwitchCase=\"true\" [caseField]=\"field\" [caseFields]=\"caseFields\" [withLabel]=\"true\"\n                      [formGroup]=\"formGroup\" [attr.field_id]=\"field.id\"\n                      [attr.field_type]=\"field.field_type.type\"></ccd-field-read>\n      <ng-container *ngSwitchCase=\"false\">\n\n        <ng-container *ngIf=\"!(field | ccdIsCompound); else CompoundRow\">\n          <ccd-field-write [caseField]=\"field\"\n                           [caseFields]=\"caseFields\"\n                           [formGroup]=\"formGroup\"\n                           [idPrefix]=\"\"\n                           [hidden]=\"field.hidden\"\n                           [attr.field_id]=\"field.id\"\n                           [attr.field_type]=\"field.field_type.type\">\n          </ccd-field-write>\n        </ng-container>\n\n        <ng-template #CompoundRow>\n          <ccd-field-write [caseField]=\"field\"\n                           [caseFields]=\"caseFields\"\n                           [formGroup]=\"formGroup\"\n                           [idPrefix]=\"field.id + '_'\"\n                           [hidden]=\"field.hidden\"\n                           [attr.field_id]=\"field.id\"\n                           [attr.field_type]=\"field.field_type.type\"></ccd-field-write>\n        </ng-template>\n      </ng-container>\n    </ng-container>\n  </div>\n</ng-container>\n"]}
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"case-edit-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit-form/case-edit-form.component.ts","../../../../../../../../projects/ccd-case-ui-toolkit/src/lib/shared/components/case-editor/case-edit-form/case-edit-form.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, OnDestroy, Output } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\nimport { Subject, Subscription } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport { CaseField } from '../../../domain/definition/case-field.model';\nimport { FormValueService } from '../../../services/form/form-value.service';\n\n@Component({\n  selector: 'ccd-case-edit-form',\n  templateUrl: 'case-edit-form.html'\n})\nexport class CaseEditFormComponent implements OnDestroy, AfterViewInit {\n\n  @Input()\n  public fields: CaseField[] = [];\n  @Input()\n  public formGroup: FormGroup;\n  @Input()\n  public caseFields: CaseField[] = [];\n  @Input()\n  public pageChangeSubject: Subject<boolean> = new Subject();\n  @Output()\n  public valuesChanged: EventEmitter<any> = new EventEmitter();\n\n  public initial: any;\n  public pageChangeSubscription: Subscription;\n  public formGroupChangeSubscription: Subscription;\n\n  constructor(private readonly formValueService: FormValueService) { }\n\n  public ngOnDestroy(): void {\n    if (this.pageChangeSubscription) {\n      this.pageChangeSubscription.unsubscribe();\n    }\n    if (this.formGroupChangeSubscription) {\n      this.formGroupChangeSubscription.unsubscribe();\n    }\n  }\n\n  // We need the below un/subscribe complexity as we do not have proper page component per page with its AfterViewInit hook\n  // being called on each page load. This is done for \"Cancel and return\" modal from RDM-2302.\n  public ngAfterViewInit(): void {\n    this.retrieveInitialFormValues();\n    this.pageChangeSubscription = this.pageChangeSubject.subscribe(() => {\n      if (this.formGroupChangeSubscription) {\n        this.formGroupChangeSubscription.unsubscribe();\n      }\n      // Timeout is required for the form to be rendered before subscription to form changes and initial form values retrieval.\n      setTimeout(() => {\n        this.subscribeToFormChanges();\n        this.retrieveInitialFormValues();\n      });\n    });\n    this.subscribeToFormChanges();\n  }\n\n  public subscribeToFormChanges() {\n    this.formGroupChangeSubscription = this.formGroup.valueChanges\n      .pipe(\n        debounceTime(200)\n      )\n      .subscribe(_ => this.detectChangesAndEmit(_));\n  }\n\n  public retrieveInitialFormValues() {\n    this.initial = JSON.stringify(this.formValueService.sanitise(this.formGroup.value));\n  }\n\n  public detectChangesAndEmit(changes) {\n    const current = JSON.stringify(this.formValueService.sanitise(changes));\n    this.initial !== current ? this.valuesChanged.emit(true) : this.valuesChanged.emit(false);\n  }\n}","<ng-container ccdConditionalShowForm [formGroup]=\"formGroup\" [caseFields]=\"fields\" [contextFields]=\"caseFields\"\n              *ngFor=\"let field of fields\">\n\n  <div ccdLabelSubstitutor [caseField]=\"field\" [formGroup]=\"formGroup\" [contextFields]=\"caseFields\">\n    <ng-container [ngSwitch]=\"field | ccdIsReadOnlyAndNotCollection\">\n\n      <ccd-field-read *ngSwitchCase=\"true\" [caseField]=\"field\" [caseFields]=\"caseFields\" [withLabel]=\"true\"\n                      [formGroup]=\"formGroup\" [attr.field_id]=\"field.id\"\n                      [attr.field_type]=\"field.field_type.type\"></ccd-field-read>\n      <ng-container *ngSwitchCase=\"false\">\n\n        <ng-container *ngIf=\"!(field | ccdIsCompound); else CompoundRow\">\n          <ccd-field-write [caseField]=\"field\"\n                           [caseFields]=\"caseFields\"\n                           [formGroup]=\"formGroup\"\n                           [idPrefix]=\"\"\n                           [hidden]=\"field.hidden\"\n                           [attr.field_id]=\"field.id\"\n                           [attr.field_type]=\"field.field_type.type\">\n          </ccd-field-write>\n        </ng-container>\n\n        <ng-template #CompoundRow>\n          <ccd-field-write [caseField]=\"field\"\n                           [caseFields]=\"caseFields\"\n                           [formGroup]=\"formGroup\"\n                           [idPrefix]=\"field.id + '_'\"\n                           [hidden]=\"field.hidden\"\n                           [attr.field_id]=\"field.id\"\n                           [attr.field_type]=\"field.field_type.type\"></ccd-field-write>\n        </ng-template>\n      </ng-container>\n    </ng-container>\n  </div>\n</ng-container>\n"]}