@carefirst/library 4.6.3 → 4.6.4
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.
- package/esm2022/lib/components/form-input-currency/form-input-currency.component.mjs +2 -3
- package/esm2022/lib/components/form-input-string-date/form-input-string-date.component.mjs +7 -7
- package/fesm2022/carefirst-library.mjs +7 -8
- package/fesm2022/carefirst-library.mjs.map +1 -1
- package/package.json +1 -1
@@ -41,12 +41,11 @@ export class FormInputCurrencyComponent {
|
|
41
41
|
}
|
42
42
|
if (this.control) {
|
43
43
|
this.control.setValue(newValue);
|
44
|
-
this.control.setErrors(this.customErrorMessage ? { errorMessage: this.customErrorMessage } : null);
|
45
44
|
}
|
46
45
|
else {
|
47
46
|
this.currencyTextInput.value = newValue;
|
47
|
+
this.valueChange.emit(newValue);
|
48
48
|
}
|
49
|
-
this.valueChange.emit(this.customErrorMessage ? undefined : newValue);
|
50
49
|
}
|
51
50
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormInputCurrencyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
52
51
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormInputCurrencyComponent, selector: "cf-form-input-currency", inputs: { label: "label", labelPlacement: "labelPlacement", placeholder: "placeholder", noClearButton: "noClearButton", control: "control", customErrorMessage: "customErrorMessage", currency: "currency", showCurrency: "showCurrency", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "currencyTextInput", first: true, predicate: ["currencyTextInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<!-- ngModel -->\n<ion-input\n #currencyTextInput\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 (ionInput)=\"checkValue($event)\"\n [value]=\"value\"></ion-input>\n<!-- Form Control -->\n<ion-input\n #currencyTextInput\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 (ionInput)=\"checkValue($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"] }] });
|
@@ -78,4 +77,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
78
77
|
}], valueChange: [{
|
79
78
|
type: Output
|
80
79
|
}] } });
|
81
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input-currency.component.js","sourceRoot":"","sources":["../../../../../../../projects/carefirst/library/src/lib/components/form-input-currency/form-input-currency.component.ts","../../../../../../../projects/carefirst/library/src/lib/components/form-input-currency/form-input-currency.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * Carefirst Library Currency Form Input\n *\n * @file          form-input-currency.component\n * @description   Contains all the logic for generating a CareFirst Form Input Currency Field\n * @author        Jacques Coetzee\n * @since         2025 - 01 - 10\n * @usage         <cf-form-input-currency\n *                  label=\"Label Name\"\n *                  %labelPlacement%\n *                  %noClearButton%\n *                  %[(value)]=\"twoWayComs\"%\n *                  %(valueChange)=\"currentValueEvent\"%\n *                  %[control]%=\"formName.controls.controlName\"\n *                  %[customErrorMessage]%=\"errorMessage\"\n *                ></cf-form-input-currency>\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 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-currency',\n  templateUrl: './form-input-currency.component.html',\n  styleUrl: './form-input-currency.component.scss',\n})\nexport class FormInputCurrencyComponent implements OnChanges {\n  @ViewChild('currencyTextInput') currencyTextInput?: IonInput;\n  //--- Input Field\n  @Input() label!: string;\n  @Input() labelPlacement?: (typeof inputsC.labelPlacement)[number];\n  @Input() placeholder?: string;\n  @Input() noClearButton?: boolean | string | undefined;\n  @Input() control?: FormControl | null;\n  @Input() customErrorMessage: string | null = null;\n  //--- Currency\n  @Input() currency?: string = 'R';\n  @Input() showCurrency: boolean = true;\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  inputShowCurrency = true;\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    //--- Show Currency\n    this.inputShowCurrency = checkTruthAttribute(changes, 'showCurrency', this.inputShowCurrency);\n  }\n\n  /**----------------------------------------------------------------\n   * @name          checkValue\n   * @description   Check the content of the input field\n   * @param         {CustomEvent} event\n   */\n  checkValue(event: CustomEvent): void {\n    //--- Clear error messages\n    if (!this.currencyTextInput) return;\n\n    //--- Remove all non numeric characters\n    let newValue: string = event.detail.value.replace(/[^\\d\\.]/g, '');\n\n    //--- Remove duplicate dot\n    const parts = newValue.split('.');\n    const cents = parts.slice(1).join('').slice(0, 2);\n    if (parts.length > 1) newValue = [parts[0], cents].join('.');\n\n    //--- Add currency\n    if (this.showCurrency && newValue) {\n      newValue = `${this.currency} ${newValue}`;\n    }\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.currencyTextInput.value = newValue;\n    }\n\n    this.valueChange.emit(this.customErrorMessage ? undefined : newValue);\n  }\n}\n","<!-- ngModel -->\n<ion-input\n  #currencyTextInput\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  (ionInput)=\"checkValue($event)\"\n  [value]=\"value\"></ion-input>\n<!-- Form Control -->\n<ion-input\n  #currencyTextInput\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  (ionInput)=\"checkValue($event)\">\n</ion-input>\n<cf-form-validation *ngIf=\"control || customErrorMessage\" [customErrorMessage]=\"customErrorMessage\" [control]=\"control || null\"></cf-form-validation>\n"]}
|
80
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input-currency.component.js","sourceRoot":"","sources":["../../../../../../../projects/carefirst/library/src/lib/components/form-input-currency/form-input-currency.component.ts","../../../../../../../projects/carefirst/library/src/lib/components/form-input-currency/form-input-currency.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * Carefirst Library Currency Form Input\n *\n * @file          form-input-currency.component\n * @description   Contains all the logic for generating a CareFirst Form Input Currency Field\n * @author        Jacques Coetzee\n * @since         2025 - 01 - 10\n * @usage         <cf-form-input-currency\n *                  label=\"Label Name\"\n *                  %labelPlacement%\n *                  %noClearButton%\n *                  %[(value)]=\"twoWayComs\"%\n *                  %(valueChange)=\"currentValueEvent\"%\n *                  %[control]%=\"formName.controls.controlName\"\n *                  %[customErrorMessage]%=\"errorMessage\"\n *                ></cf-form-input-currency>\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 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-currency',\n  templateUrl: './form-input-currency.component.html',\n  styleUrl: './form-input-currency.component.scss',\n})\nexport class FormInputCurrencyComponent implements OnChanges {\n  @ViewChild('currencyTextInput') currencyTextInput?: IonInput;\n  //--- Input Field\n  @Input() label!: string;\n  @Input() labelPlacement?: (typeof inputsC.labelPlacement)[number];\n  @Input() placeholder?: string;\n  @Input() noClearButton?: boolean | string | undefined;\n  @Input() control?: FormControl | null;\n  @Input() customErrorMessage: string | null = null;\n  //--- Currency\n  @Input() currency?: string = 'R';\n  @Input() showCurrency: boolean = true;\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  inputShowCurrency = true;\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    //--- Show Currency\n    this.inputShowCurrency = checkTruthAttribute(changes, 'showCurrency', this.inputShowCurrency);\n  }\n\n  /**----------------------------------------------------------------\n   * @name          checkValue\n   * @description   Check the content of the input field\n   * @param         {CustomEvent} event\n   */\n  checkValue(event: CustomEvent): void {\n    //--- Clear error messages\n    if (!this.currencyTextInput) return;\n\n    //--- Remove all non numeric characters\n    let newValue: string = event.detail.value.replace(/[^\\d\\.]/g, '');\n\n    //--- Remove duplicate dot\n    const parts = newValue.split('.');\n    const cents = parts.slice(1).join('').slice(0, 2);\n    if (parts.length > 1) newValue = [parts[0], cents].join('.');\n\n    //--- Add currency\n    if (this.showCurrency && newValue) {\n      newValue = `${this.currency} ${newValue}`;\n    }\n\n    //--- Set new value\n    if (this.control) {\n      this.control.setValue(newValue);\n    } else {\n      this.currencyTextInput.value = newValue;\n      this.valueChange.emit(newValue);\n    }\n  }\n}\n","<!-- ngModel -->\n<ion-input\n  #currencyTextInput\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  (ionInput)=\"checkValue($event)\"\n  [value]=\"value\"></ion-input>\n<!-- Form Control -->\n<ion-input\n  #currencyTextInput\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  (ionInput)=\"checkValue($event)\">\n</ion-input>\n<cf-form-validation *ngIf=\"control || customErrorMessage\" [customErrorMessage]=\"customErrorMessage\" [control]=\"control || null\"></cf-form-validation>\n"]}
|
@@ -28,27 +28,27 @@ export class FormInputStringDateComponent {
|
|
28
28
|
this.inputClear = checkTruthAttribute(changes, 'noClearButton', this.inputClear);
|
29
29
|
}
|
30
30
|
formatDate(event) {
|
31
|
-
|
31
|
+
let dateErrors = null;
|
32
32
|
if (!this.dateTextInput)
|
33
33
|
return;
|
34
34
|
let newValue = event.detail.value.slice(0, 10).replace(/[^\d]/g, '');
|
35
35
|
if (newValue.length !== 8) {
|
36
|
-
|
36
|
+
dateErrors = 'This given date length is not valid';
|
37
37
|
}
|
38
38
|
newValue = newValue.replace(/^(\d{4})(\d{2})(\d{1,2})/, '$1-$2-$3').replace(/^(\d{4})(\d{1,2})/, '$1-$2') + '';
|
39
39
|
if (!dayjs(new Date(newValue)).isValid()) {
|
40
|
-
|
40
|
+
dateErrors = 'This given date is not valid';
|
41
41
|
}
|
42
42
|
if ((this.minDate && dayjs(new Date(newValue)).isBefore(this.minDate)) || (this.maxDate && dayjs(new Date(newValue)).isAfter(this.maxDate))) {
|
43
|
-
|
43
|
+
dateErrors = 'The given date is not within the valid parameters';
|
44
44
|
}
|
45
45
|
if (this.control) {
|
46
46
|
this.control.setValue(newValue);
|
47
|
-
this.control.setErrors(
|
47
|
+
this.control.setErrors(dateErrors ? { errorMessage: dateErrors } : null);
|
48
48
|
}
|
49
49
|
else {
|
50
50
|
this.dateTextInput.value = newValue;
|
51
|
-
this.valueChange.emit(
|
51
|
+
this.valueChange.emit(newValue);
|
52
52
|
}
|
53
53
|
}
|
54
54
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormInputStringDateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
@@ -81,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
81
81
|
}], valueChange: [{
|
82
82
|
type: Output
|
83
83
|
}] } });
|
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"]}
|
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":"AAqBA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAsC,YAAY,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACtH,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAEtF,OAAO,EAAE,OAAO,EAAE,MAAM,qCAAqC,CAAC;;;;;;AAO9D,MAAM,OAAO,4BAA4B;IACX,aAAa,CAAY;IAC5C,KAAK,CAAU;IACf,OAAO,CAA4B;IACnC,OAAO,CAA4B;IACnC,cAAc,CAA2C;IACzD,WAAW,GAAY,YAAY,CAAC;IACpC,aAAa,CAAgC;IAC7C,OAAO,CAAsB;IAC7B,kBAAkB,GAAkB,IAAI,CAAC;IAGzC,KAAK,CAAqB;IACzB,WAAW,GAAG,IAAI,YAAY,EAAqB,CAAC;IAG9D,mBAAmB,CAA6B;IAChD,UAAU,GAAG,KAAK,CAAC;IAOnB,WAAW,CAAC,OAAsB;QAEhC,IAAI,CAAC,mBAAmB;YACtB,mBAAmB,CACjB,OAAO,EACP,gBAAgB,EAChB,OAAO,CAAC,cAAc,CAAC,KAAK,EAAE,EAC9B,IAAI,CAAC,mBAAmB,CACzB,IAAI,UAAU,CAAC;QAElB,IAAI,CAAC,UAAU,GAAG,mBAAmB,CAAC,OAAO,EAAE,eAAe,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IACnF,CAAC;IAOD,UAAU,CAAC,KAAkB;QAE3B,IAAI,UAAU,GAAkB,IAAI,CAAC;QACrC,IAAI,CAAC,IAAI,CAAC,aAAa;YAAE,OAAO;QAEhC,IAAI,QAAQ,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QAErE,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC1B,UAAU,GAAG,qCAAqC,CAAC;QACrD,CAAC;QAED,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC,0BAA0B,EAAE,UAAU,CAAC,CAAC,OAAO,CAAC,mBAAmB,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC;QAE/G,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC;YACzC,UAAU,GAAG,8BAA8B,CAAC;QAC9C,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,KAAK,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,KAAK,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;YAC5I,UAAU,GAAG,mDAAmD,CAAC;QACnE,CAAC;QAED,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;YAChC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAC3E,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,QAAQ,CAAC;YACpC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;wGArEU,4BAA4B;4FAA5B,4BAA4B,+dCnCzC,u8BAgCA;;4FDGa,4BAA4B;kBALxC,SAAS;+BACE,2BAA2B;8BAKT,aAAa;sBAAxC,SAAS;uBAAC,eAAe;gBACjB,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBAGG,KAAK;sBAAb,KAAK;gBACI,WAAW;sBAApB,MAAM","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    let dateErrors: string | null = 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      dateErrors = '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      dateErrors = '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      dateErrors = '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(dateErrors ? { errorMessage: dateErrors } : null);\n    } else {\n      this.dateTextInput.value = newValue;\n      this.valueChange.emit(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"]}
|
@@ -1241,27 +1241,27 @@ class FormInputStringDateComponent {
|
|
1241
1241
|
this.inputClear = checkTruthAttribute(changes, 'noClearButton', this.inputClear);
|
1242
1242
|
}
|
1243
1243
|
formatDate(event) {
|
1244
|
-
|
1244
|
+
let dateErrors = null;
|
1245
1245
|
if (!this.dateTextInput)
|
1246
1246
|
return;
|
1247
1247
|
let newValue = event.detail.value.slice(0, 10).replace(/[^\d]/g, '');
|
1248
1248
|
if (newValue.length !== 8) {
|
1249
|
-
|
1249
|
+
dateErrors = 'This given date length is not valid';
|
1250
1250
|
}
|
1251
1251
|
newValue = newValue.replace(/^(\d{4})(\d{2})(\d{1,2})/, '$1-$2-$3').replace(/^(\d{4})(\d{1,2})/, '$1-$2') + '';
|
1252
1252
|
if (!dayjs(new Date(newValue)).isValid()) {
|
1253
|
-
|
1253
|
+
dateErrors = 'This given date is not valid';
|
1254
1254
|
}
|
1255
1255
|
if ((this.minDate && dayjs(new Date(newValue)).isBefore(this.minDate)) || (this.maxDate && dayjs(new Date(newValue)).isAfter(this.maxDate))) {
|
1256
|
-
|
1256
|
+
dateErrors = 'The given date is not within the valid parameters';
|
1257
1257
|
}
|
1258
1258
|
if (this.control) {
|
1259
1259
|
this.control.setValue(newValue);
|
1260
|
-
this.control.setErrors(
|
1260
|
+
this.control.setErrors(dateErrors ? { errorMessage: dateErrors } : null);
|
1261
1261
|
}
|
1262
1262
|
else {
|
1263
1263
|
this.dateTextInput.value = newValue;
|
1264
|
-
this.valueChange.emit(
|
1264
|
+
this.valueChange.emit(newValue);
|
1265
1265
|
}
|
1266
1266
|
}
|
1267
1267
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormInputStringDateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
@@ -1329,12 +1329,11 @@ class FormInputCurrencyComponent {
|
|
1329
1329
|
}
|
1330
1330
|
if (this.control) {
|
1331
1331
|
this.control.setValue(newValue);
|
1332
|
-
this.control.setErrors(this.customErrorMessage ? { errorMessage: this.customErrorMessage } : null);
|
1333
1332
|
}
|
1334
1333
|
else {
|
1335
1334
|
this.currencyTextInput.value = newValue;
|
1335
|
+
this.valueChange.emit(newValue);
|
1336
1336
|
}
|
1337
|
-
this.valueChange.emit(this.customErrorMessage ? undefined : newValue);
|
1338
1337
|
}
|
1339
1338
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormInputCurrencyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
1340
1339
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormInputCurrencyComponent, selector: "cf-form-input-currency", inputs: { label: "label", labelPlacement: "labelPlacement", placeholder: "placeholder", noClearButton: "noClearButton", control: "control", customErrorMessage: "customErrorMessage", currency: "currency", showCurrency: "showCurrency", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "currencyTextInput", first: true, predicate: ["currencyTextInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<!-- ngModel -->\n<ion-input\n #currencyTextInput\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 (ionInput)=\"checkValue($event)\"\n [value]=\"value\"></ion-input>\n<!-- Form Control -->\n<ion-input\n #currencyTextInput\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 (ionInput)=\"checkValue($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"] }] });
|