@carefirst/library 4.5.0 → 4.5.1

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.
@@ -32,18 +32,24 @@ export class FormInputStringDateComponent {
32
32
  if (!this.dateTextInput)
33
33
  return;
34
34
  let newValue = event.detail.value.slice(0, 10).replace(/[^\d]/g, '');
35
+ if (newValue.length !== 8) {
36
+ this.customErrorMessage = 'This given date length is not valid';
37
+ }
35
38
  newValue = newValue.replace(/^(\d{4})(\d{2})(\d{1,2})/, '$1-$2-$3').replace(/^(\d{4})(\d{1,2})/, '$1-$2') + '';
36
- if (this.control)
37
- this.control.setValue(newValue);
38
- else
39
- this.dateTextInput.value = newValue;
40
- this.valueChange.emit(newValue);
41
39
  if (!dayjs(new Date(newValue)).isValid()) {
42
40
  this.customErrorMessage = 'This given date is not valid';
43
41
  }
44
42
  if ((this.minDate && dayjs(new Date(newValue)).isBefore(this.minDate)) || (this.maxDate && dayjs(new Date(newValue)).isAfter(this.maxDate))) {
45
43
  this.customErrorMessage = 'The given date is not within the valid parameters';
46
44
  }
45
+ if (this.control) {
46
+ this.control.setValue(newValue);
47
+ this.control.setErrors(this.customErrorMessage ? { errorMessage: this.customErrorMessage } : null);
48
+ }
49
+ else {
50
+ this.dateTextInput.value = newValue;
51
+ this.valueChange.emit(this.customErrorMessage ? undefined : newValue);
52
+ }
47
53
  }
48
54
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: FormInputStringDateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
49
55
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: FormInputStringDateComponent, selector: "cf-form-input-string-date", inputs: { label: "label", minDate: "minDate", maxDate: "maxDate", labelPlacement: "labelPlacement", placeholder: "placeholder", noClearButton: "noClearButton", control: "control", customErrorMessage: "customErrorMessage", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "dateTextInput", first: true, predicate: ["dateTextInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<!-- ngModel -->\n<ion-input\n #dateTextInput\n *ngIf=\"!control\"\n [ngClass]=\"{ error: !!customErrorMessage }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"!inputClear\"\n mode=\"md\"\n [min]=\"minDate\"\n [max]=\"maxDate\"\n (ionInput)=\"formatDate($event)\"\n [value]=\"value\"></ion-input>\n<!-- Form Control -->\n<ion-input\n #dateTextInput\n *ngIf=\"control\"\n [ngClass]=\"{ error: !!customErrorMessage }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"!inputClear\"\n mode=\"md\"\n [formControl]=\"control\"\n [min]=\"minDate\"\n [max]=\"maxDate\"\n (ionInput)=\"formatDate($event)\">\n</ion-input>\n<cf-form-validation *ngIf=\"control || customErrorMessage\" [customErrorMessage]=\"customErrorMessage\" [control]=\"control || null\"></cf-form-validation>\n", styles: ["::ng-deep ion-input.error .label-text{color:var(--cf-app-system-color-error)}ion-input{font-family:Roboto,sans-serif;font-weight:400;font-style:normal;font-size:1.6rem;color:var(--cf-app-text-color-default);text-align:start;--border-radius: 8px !important;--highlight-color-focused: var(--cf-app-color-primary);--highlight-color-invalid: var(--cf-app-system-color-error);--highlight-color-valid: var(--cf-app-color-primary)}ion-input.error{--border-color: var(--cf-app-system-color-error);--highlight-color-focused: var(--cf-app-system-color-error);--highlight-color-valid: var(--cf-app-system-color-error)}\n"], dependencies: [{ kind: "component", type: i1.IonInput, selector: "ion-input", inputs: ["autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "clearInputIcon", "clearOnEdit", "color", "counter", "counterFormatter", "debounce", "disabled", "enterkeyhint", "errorText", "fill", "helperText", "inputmode", "label", "labelPlacement", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "shape", "spellcheck", "step", "type", "value"] }, { kind: "directive", type: i1.TextValueAccessor, selector: "ion-input:not([type=number]),ion-textarea,ion-searchbar" }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i4.FormValidationComponent, selector: "cf-form-validation", inputs: ["control", "customErrorMessage"] }] });
@@ -75,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
75
81
  }], valueChange: [{
76
82
  type: Output
77
83
  }] } });
78
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input-string-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/carefirst/library/src/lib/components/form-input-string-date/form-input-string-date.component.ts","../../../../../../../projects/carefirst/library/src/lib/components/form-input-string-date/form-input-string-date.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * Carefirst Library Form Input\n *\n * @file          form-input-string-date.component\n * @description   Contains all the logic for generating a CareFirst Form Input String Date Field\n * @author        Anton de Swardt\n * @since         2024 - 11 - 26\n * @usage         <cf-form-input-string-date\n *                  label=\"Label Name\"\n *                  %labelPlacement%\n *                  %noClearButton%\n *                  %minDate%\n *                  %maxDate%\n *                  %[(value)]=\"twoWayComs\"%\n *                  %(valueChange)=\"currentValueEvent\"%\n *                  %[control]%=\"formName.controls.controlName\"\n *                  %[customErrorMessage]%=\"errorMessage\"\n *                ></cf-form-input-string-date>\n *                disable input by disabling the form control\n */\n\nimport { Component, Input, Output, type OnChanges, type SimpleChanges, EventEmitter, ViewChild } from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport dayjs from 'dayjs';\nimport type { IonInput } from '@ionic/angular';\n//--- Utils\nimport { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';\n//--- Interfaces\nimport { inputsC } from '../../interfaces/internal.interface';\n\n@Component({\n  selector: 'cf-form-input-string-date',\n  templateUrl: './form-input-string-date.component.html',\n  styleUrl: './form-input-string-date.component.scss',\n})\nexport class FormInputStringDateComponent implements OnChanges {\n  @ViewChild('dateTextInput') dateTextInput?: IonInput;\n  @Input() label!: string;\n  @Input() minDate: string | Date | undefined;\n  @Input() maxDate: string | Date | undefined;\n  @Input() labelPlacement?: (typeof inputsC.labelPlacement)[number];\n  @Input() placeholder?: string = 'YYYY-MM-DD';\n  @Input() noClearButton?: boolean | string | undefined;\n  @Input() control?: FormControl | null;\n  @Input() customErrorMessage: string | null = null;\n\n  //--- ngModel\n  @Input() value: string | undefined;\n  @Output() valueChange = new EventEmitter<typeof this.value>();\n\n  //--- Local variables\n  inputLabelPlacement: typeof this.labelPlacement;\n  inputClear = false;\n\n  /**----------------------------------------------------------------\n   * @name          ngOnChanges\n   * @description   Detect changes to input values\n   * @param         {SimpleChanges} changes\n   */\n  ngOnChanges(changes: SimpleChanges): void {\n    //--- Label Placement\n    this.inputLabelPlacement =\n      validateStringValue<(typeof inputsC.labelPlacement)[number]>(\n        changes,\n        'labelPlacement',\n        inputsC.labelPlacement.slice(),\n        this.inputLabelPlacement\n      ) || 'floating';\n    //--- Clear Button\n    this.inputClear = checkTruthAttribute(changes, 'noClearButton', this.inputClear);\n  }\n\n  /**----------------------------------------------------------------\n   * @name          formatDate\n   * @description   Format the date with hyphens\n   * @param         {CustomEvent} event\n   */\n  formatDate(event: CustomEvent): void {\n    //--- Clear error messages\n    this.customErrorMessage = null;\n    if (!this.dateTextInput) return;\n    //--- Remove all non numeric characters\n    let newValue = event.detail.value.slice(0, 10).replace(/[^\\d]/g, '');\n    //--- Add \"-\" to format string into (YYYY-MM-D and YYYY-MM-DD) OR (YYYY-M and YYYY-MM)\n    newValue = newValue.replace(/^(\\d{4})(\\d{2})(\\d{1,2})/, '$1-$2-$3').replace(/^(\\d{4})(\\d{1,2})/, '$1-$2') + '';\n    //--- Set new value\n    if (this.control) this.control.setValue(newValue);\n    else this.dateTextInput.value = newValue;\n    this.valueChange.emit(newValue);\n    //--- Check date for errors\n    if (!dayjs(new Date(newValue)).isValid()) {\n      this.customErrorMessage = 'This given date is not valid';\n    }\n    if ((this.minDate && dayjs(new Date(newValue)).isBefore(this.minDate)) || (this.maxDate && dayjs(new Date(newValue)).isAfter(this.maxDate))) {\n      this.customErrorMessage = 'The given date is not within the valid parameters';\n    }\n  }\n}\n","<!-- ngModel -->\n<ion-input\n  #dateTextInput\n  *ngIf=\"!control\"\n  [ngClass]=\"{ error: !!customErrorMessage }\"\n  [label]=\"label\"\n  [labelPlacement]=\"inputLabelPlacement\"\n  [placeholder]=\"placeholder\"\n  fill=\"outline\"\n  [clearInput]=\"!inputClear\"\n  mode=\"md\"\n  [min]=\"minDate\"\n  [max]=\"maxDate\"\n  (ionInput)=\"formatDate($event)\"\n  [value]=\"value\"></ion-input>\n<!-- Form Control -->\n<ion-input\n  #dateTextInput\n  *ngIf=\"control\"\n  [ngClass]=\"{ error: !!customErrorMessage }\"\n  [label]=\"label\"\n  [labelPlacement]=\"inputLabelPlacement\"\n  [placeholder]=\"placeholder\"\n  fill=\"outline\"\n  [clearInput]=\"!inputClear\"\n  mode=\"md\"\n  [formControl]=\"control\"\n  [min]=\"minDate\"\n  [max]=\"maxDate\"\n  (ionInput)=\"formatDate($event)\">\n</ion-input>\n<cf-form-validation *ngIf=\"control || customErrorMessage\" [customErrorMessage]=\"customErrorMessage\" [control]=\"control || null\"></cf-form-validation>\n"]}
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input-string-date.component.js","sourceRoot":"","sources":["../../../../../../../projects/carefirst/library/src/lib/components/form-input-string-date/form-input-string-date.component.ts","../../../../../../../projects/carefirst/library/src/lib/components/form-input-string-date/form-input-string-date.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * Carefirst Library Form Input\n *\n * @file          form-input-string-date.component\n * @description   Contains all the logic for generating a CareFirst Form Input String Date Field\n * @author        Anton de Swardt\n * @since         2024 - 11 - 26\n * @usage         <cf-form-input-string-date\n *                  label=\"Label Name\"\n *                  %labelPlacement%\n *                  %noClearButton%\n *                  %minDate%\n *                  %maxDate%\n *                  %[(value)]=\"twoWayComs\"%\n *                  %(valueChange)=\"currentValueEvent\"%\n *                  %[control]%=\"formName.controls.controlName\"\n *                  %[customErrorMessage]%=\"errorMessage\"\n *                ></cf-form-input-string-date>\n *                disable input by disabling the form control\n */\n\nimport { Component, Input, Output, type OnChanges, type SimpleChanges, EventEmitter, ViewChild } from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport dayjs from 'dayjs';\nimport type { IonInput } from '@ionic/angular';\n//--- Utils\nimport { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';\n//--- Interfaces\nimport { inputsC } from '../../interfaces/internal.interface';\n\n@Component({\n  selector: 'cf-form-input-string-date',\n  templateUrl: './form-input-string-date.component.html',\n  styleUrl: './form-input-string-date.component.scss',\n})\nexport class FormInputStringDateComponent implements OnChanges {\n  @ViewChild('dateTextInput') dateTextInput?: IonInput;\n  @Input() label!: string;\n  @Input() minDate: string | Date | undefined;\n  @Input() maxDate: string | Date | undefined;\n  @Input() labelPlacement?: (typeof inputsC.labelPlacement)[number];\n  @Input() placeholder?: string = 'YYYY-MM-DD';\n  @Input() noClearButton?: boolean | string | undefined;\n  @Input() control?: FormControl | null;\n  @Input() customErrorMessage: string | null = null;\n\n  //--- ngModel\n  @Input() value: string | undefined;\n  @Output() valueChange = new EventEmitter<typeof this.value>();\n\n  //--- Local variables\n  inputLabelPlacement: typeof this.labelPlacement;\n  inputClear = false;\n\n  /**----------------------------------------------------------------\n   * @name          ngOnChanges\n   * @description   Detect changes to input values\n   * @param         {SimpleChanges} changes\n   */\n  ngOnChanges(changes: SimpleChanges): void {\n    //--- Label Placement\n    this.inputLabelPlacement =\n      validateStringValue<(typeof inputsC.labelPlacement)[number]>(\n        changes,\n        'labelPlacement',\n        inputsC.labelPlacement.slice(),\n        this.inputLabelPlacement\n      ) || 'floating';\n    //--- Clear Button\n    this.inputClear = checkTruthAttribute(changes, 'noClearButton', this.inputClear);\n  }\n\n  /**----------------------------------------------------------------\n   * @name          formatDate\n   * @description   Format the date with hyphens\n   * @param         {CustomEvent} event\n   */\n  formatDate(event: CustomEvent): void {\n    //--- Clear error messages\n    this.customErrorMessage = null;\n    if (!this.dateTextInput) return;\n    //--- Remove all non numeric characters\n    let newValue = event.detail.value.slice(0, 10).replace(/[^\\d]/g, '');\n    //--- Check date length\n    if (newValue.length !== 8) {\n      this.customErrorMessage = 'This given date length is not valid';\n    }\n    //--- Add \"-\" to format string into (YYYY-MM-D and YYYY-MM-DD) OR (YYYY-M and YYYY-MM)\n    newValue = newValue.replace(/^(\\d{4})(\\d{2})(\\d{1,2})/, '$1-$2-$3').replace(/^(\\d{4})(\\d{1,2})/, '$1-$2') + '';\n    //--- Check date for errors\n    if (!dayjs(new Date(newValue)).isValid()) {\n      this.customErrorMessage = 'This given date is not valid';\n    }\n    if ((this.minDate && dayjs(new Date(newValue)).isBefore(this.minDate)) || (this.maxDate && dayjs(new Date(newValue)).isAfter(this.maxDate))) {\n      this.customErrorMessage = 'The given date is not within the valid parameters';\n    }\n    //--- Set new value\n    if (this.control) {\n      this.control.setValue(newValue);\n      this.control.setErrors(this.customErrorMessage ? { errorMessage: this.customErrorMessage } : null);\n    } else {\n      this.dateTextInput.value = newValue;\n      this.valueChange.emit(this.customErrorMessage ? undefined : newValue);\n    }\n  }\n}\n","<!-- ngModel -->\n<ion-input\n  #dateTextInput\n  *ngIf=\"!control\"\n  [ngClass]=\"{ error: !!customErrorMessage }\"\n  [label]=\"label\"\n  [labelPlacement]=\"inputLabelPlacement\"\n  [placeholder]=\"placeholder\"\n  fill=\"outline\"\n  [clearInput]=\"!inputClear\"\n  mode=\"md\"\n  [min]=\"minDate\"\n  [max]=\"maxDate\"\n  (ionInput)=\"formatDate($event)\"\n  [value]=\"value\"></ion-input>\n<!-- Form Control -->\n<ion-input\n  #dateTextInput\n  *ngIf=\"control\"\n  [ngClass]=\"{ error: !!customErrorMessage }\"\n  [label]=\"label\"\n  [labelPlacement]=\"inputLabelPlacement\"\n  [placeholder]=\"placeholder\"\n  fill=\"outline\"\n  [clearInput]=\"!inputClear\"\n  mode=\"md\"\n  [formControl]=\"control\"\n  [min]=\"minDate\"\n  [max]=\"maxDate\"\n  (ionInput)=\"formatDate($event)\">\n</ion-input>\n<cf-form-validation *ngIf=\"control || customErrorMessage\" [customErrorMessage]=\"customErrorMessage\" [control]=\"control || null\"></cf-form-validation>\n"]}
@@ -1220,18 +1220,24 @@ class FormInputStringDateComponent {
1220
1220
  if (!this.dateTextInput)
1221
1221
  return;
1222
1222
  let newValue = event.detail.value.slice(0, 10).replace(/[^\d]/g, '');
1223
+ if (newValue.length !== 8) {
1224
+ this.customErrorMessage = 'This given date length is not valid';
1225
+ }
1223
1226
  newValue = newValue.replace(/^(\d{4})(\d{2})(\d{1,2})/, '$1-$2-$3').replace(/^(\d{4})(\d{1,2})/, '$1-$2') + '';
1224
- if (this.control)
1225
- this.control.setValue(newValue);
1226
- else
1227
- this.dateTextInput.value = newValue;
1228
- this.valueChange.emit(newValue);
1229
1227
  if (!dayjs(new Date(newValue)).isValid()) {
1230
1228
  this.customErrorMessage = 'This given date is not valid';
1231
1229
  }
1232
1230
  if ((this.minDate && dayjs(new Date(newValue)).isBefore(this.minDate)) || (this.maxDate && dayjs(new Date(newValue)).isAfter(this.maxDate))) {
1233
1231
  this.customErrorMessage = 'The given date is not within the valid parameters';
1234
1232
  }
1233
+ if (this.control) {
1234
+ this.control.setValue(newValue);
1235
+ this.control.setErrors(this.customErrorMessage ? { errorMessage: this.customErrorMessage } : null);
1236
+ }
1237
+ else {
1238
+ this.dateTextInput.value = newValue;
1239
+ this.valueChange.emit(this.customErrorMessage ? undefined : newValue);
1240
+ }
1235
1241
  }
1236
1242
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: FormInputStringDateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
1237
1243
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: FormInputStringDateComponent, selector: "cf-form-input-string-date", inputs: { label: "label", minDate: "minDate", maxDate: "maxDate", labelPlacement: "labelPlacement", placeholder: "placeholder", noClearButton: "noClearButton", control: "control", customErrorMessage: "customErrorMessage", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "dateTextInput", first: true, predicate: ["dateTextInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<!-- ngModel -->\n<ion-input\n #dateTextInput\n *ngIf=\"!control\"\n [ngClass]=\"{ error: !!customErrorMessage }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"!inputClear\"\n mode=\"md\"\n [min]=\"minDate\"\n [max]=\"maxDate\"\n (ionInput)=\"formatDate($event)\"\n [value]=\"value\"></ion-input>\n<!-- Form Control -->\n<ion-input\n #dateTextInput\n *ngIf=\"control\"\n [ngClass]=\"{ error: !!customErrorMessage }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"!inputClear\"\n mode=\"md\"\n [formControl]=\"control\"\n [min]=\"minDate\"\n [max]=\"maxDate\"\n (ionInput)=\"formatDate($event)\">\n</ion-input>\n<cf-form-validation *ngIf=\"control || customErrorMessage\" [customErrorMessage]=\"customErrorMessage\" [control]=\"control || null\"></cf-form-validation>\n", styles: ["::ng-deep ion-input.error .label-text{color:var(--cf-app-system-color-error)}ion-input{font-family:Roboto,sans-serif;font-weight:400;font-style:normal;font-size:1.6rem;color:var(--cf-app-text-color-default);text-align:start;--border-radius: 8px !important;--highlight-color-focused: var(--cf-app-color-primary);--highlight-color-invalid: var(--cf-app-system-color-error);--highlight-color-valid: var(--cf-app-color-primary)}ion-input.error{--border-color: var(--cf-app-system-color-error);--highlight-color-focused: var(--cf-app-system-color-error);--highlight-color-valid: var(--cf-app-system-color-error)}\n"], dependencies: [{ kind: "component", type: i1.IonInput, selector: "ion-input", inputs: ["autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "clearInputIcon", "clearOnEdit", "color", "counter", "counterFormatter", "debounce", "disabled", "enterkeyhint", "errorText", "fill", "helperText", "inputmode", "label", "labelPlacement", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "shape", "spellcheck", "step", "type", "value"] }, { kind: "directive", type: i1.TextValueAccessor, selector: "ion-input:not([type=number]),ion-textarea,ion-searchbar" }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: FormValidationComponent, selector: "cf-form-validation", inputs: ["control", "customErrorMessage"] }] });