@carefirst/library 4.0.3 → 4.1.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -2,18 +2,13 @@ import { Component, Input, Output, EventEmitter } from '@angular/core';
2
2
  import { FormControl } from '@angular/forms';
3
3
  import { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';
4
4
  import { CFPFormValidators } from '../../utils/form-validators-utility';
5
+ import { inputsC } from '../../interfaces/internal.interface';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@ionic/angular";
7
8
  import * as i2 from "@angular/common";
8
9
  import * as i3 from "@angular/forms";
9
10
  import * as i4 from "../icon/icon.component";
10
11
  import * as i5 from "../form-validation/form-validation.component";
11
- const inputsC = {
12
- labelPlacement: ['fixed', 'floating', 'stacked', 'start', 'end'],
13
- inputMode: ['text', 'email', 'numeric', 'tel', 'decimal', 'url', 'search'],
14
- autoCapitalize: ['off', 'none', 'on', 'sentences', 'words', 'characters'],
15
- type: ['date', 'datetime-local', 'email', 'month', 'number', 'password', 'search', 'tel', 'text', 'time', 'url', 'week'],
16
- };
17
12
  export class FormInputComponent {
18
13
  label;
19
14
  min;
@@ -103,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
103
98
  }], valueChange: [{
104
99
  type: Output
105
100
  }] } });
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/carefirst/library/src/lib/components/form-input/form-input.component.ts","../../../../../../../projects/carefirst/library/src/lib/components/form-input/form-input.component.html"],"names":[],"mappings":"AAyBA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAsC,YAAY,EAAE,MAAM,eAAe,CAAC;AAC3G,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACtF,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;;;;;;;AAMxE,MAAM,OAAO,GAAG;IACd,cAAc,EAAE,CAAC,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,CAAC;IAChE,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,CAAC;IAC1E,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,YAAY,CAAC;IACzE,IAAI,EAAE,CAAC,MAAM,EAAE,gBAAgB,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC;CAChH,CAAC;AAOX,MAAM,OAAO,kBAAkB;IACpB,KAAK,CAAU;IACf,GAAG,CAA8B;IACjC,GAAG,CAA8B;IACjC,cAAc,CAA2C;IACzD,WAAW,CAAsB;IACjC,SAAS,CAAsC;IAC/C,cAAc,CAA2C;IACzD,IAAI,CAAiC;IACrC,aAAa,CAAgC;IAC7C,OAAO,CAAsB;IAC7B,UAAU,CAAgC;IAC1C,SAAS,CAAmB;IAC5B,cAAc,CAAgC;IAC9C,kBAAkB,GAAkB,IAAI,CAAC;IAGzC,KAAK,CAAqB;IACzB,WAAW,GAAG,IAAI,YAAY,EAAqB,CAAC;IAG9D,mBAAmB,CAA6B;IAChD,cAAc,CAAwB;IACtC,UAAU,GAAG,KAAK,CAAC;IACnB,eAAe,GAAG,KAAK,CAAC;IACxB,SAAS,CAAmB;IAC5B,mBAAmB,CAA6B;IAChD,mBAAmB,GAAG,KAAK,CAAC;IAC5B,YAAY,GAAG,KAAK,CAAC;IACrB,gBAAgB,GAAkB,IAAI,CAAC;IACvC,gBAAgB,GAAkB,IAAI,CAAC;IAOvC,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,cAAc;YACjB,mBAAmB,CAAqC,OAAO,EAAE,WAAW,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,MAAM,CAAC;QAE1I,IAAI,CAAC,UAAU,GAAG,mBAAmB,CAAC,OAAO,EAAE,eAAe,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAEjF,IAAI,CAAC,eAAe,GAAG,mBAAmB,CAAC,OAAO,EAAE,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAExF,IAAI,CAAC,SAAS,GAAG,mBAAmB,CAAgC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,MAAM,CAAC;QAErI,IAAI,CAAC,mBAAmB;YACtB,mBAAmB,CACjB,OAAO,EACP,gBAAgB,EAChB,OAAO,CAAC,cAAc,CAAC,KAAK,EAAE,EAC9B,IAAI,CAAC,mBAAmB,CACzB,IAAI,MAAM,CAAC;QAEd,IAAI,CAAC,mBAAmB,GAAG,mBAAmB,CAAC,OAAO,EAAE,gBAAgB,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;QAIpG,IAAI,IAAI,CAAC,SAAS,KAAK,MAAM,EAAE,CAAC;YAC9B,IAAI,OAAO,CAAC,KAAK,CAAC,EAAE,YAAY,IAAI,OAAO,CAAC,KAAK,CAAC,EAAE,YAAY,EAAE,CAAC;gBAEjE,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC;gBAC7F,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC;gBAE7F,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAgB,IAAI,IAAI,EAAE,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,CAAC,CAAC;YAC3H,CAAC;QACH,CAAC;IACH,CAAC;IAOD,kBAAkB;QAChB,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;QACvC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC;IACvE,CAAC;uGAvFU,kBAAkB;2FAAlB,kBAAkB,+eC/C/B,+8DAuDA;;2FDRa,kBAAkB;kBAL9B,SAAS;+BACE,eAAe;8BAKhB,KAAK;sBAAb,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBAGG,KAAK;sBAAb,KAAK;gBACI,WAAW;sBAApB,MAAM","sourcesContent":["/**\n * Carefirst Library Form Input\n *\n * @file          form-input.component\n * @description   Contains all the logic for generating a CareFirst Form Input Field\n * @author        Arno Jansen van Vuuren\n * @since         2023 - 12 - 14\n * @usage         <cf-form-input\n *                  label=\"Label Name\"\n *                  %labelPlacement%\n *                  %inputMode%\n *                  %noClearButton%\n *                  %textCenter%\n *                  %min%\n *                  %max%\n *                  %autoCapitalize%\n *                  %type%\n *                  %[(value)]=\"twoWayComs\"%\n *                  %(valueChange)=\"currentValueEvent\"%\n *                  %[control]%=\"formName.controls.controlName\"\n *                  %[customErrorMessage]%=\"errorMessage\"\n *                ></cf-form-input>\n *                disable input by disabling the form control\n */\n\nimport { Component, Input, Output, type OnChanges, type SimpleChanges, EventEmitter } from '@angular/core';\nimport { FormControl } from '@angular/forms';\n//--- Utils\nimport { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';\nimport { CFPFormValidators } from '../../utils/form-validators-utility';\n\n/**==============================================\n * @interface     inputsC\n * @description   Define available input values\n */\nconst inputsC = {\n  labelPlacement: ['fixed', 'floating', 'stacked', 'start', 'end'],\n  inputMode: ['text', 'email', 'numeric', 'tel', 'decimal', 'url', 'search'],\n  autoCapitalize: ['off', 'none', 'on', 'sentences', 'words', 'characters'],\n  type: ['date', 'datetime-local', 'email', 'month', 'number', 'password', 'search', 'tel', 'text', 'time', 'url', 'week'],\n} as const;\n\n@Component({\n  selector: 'cf-form-input',\n  templateUrl: './form-input.component.html',\n  styleUrl: './form-input.component.scss',\n})\nexport class FormInputComponent implements OnChanges {\n  @Input() label!: string;\n  @Input() min: string | number | undefined;\n  @Input() max: string | number | undefined;\n  @Input() labelPlacement?: (typeof inputsC.labelPlacement)[number];\n  @Input() placeholder?: string | undefined;\n  @Input() inputmode?: (typeof inputsC.inputMode)[number];\n  @Input() autoCapitalize?: (typeof inputsC.autoCapitalize)[number];\n  @Input() type?: (typeof inputsC.type)[number];\n  @Input() noClearButton?: boolean | string | undefined;\n  @Input() control?: FormControl | null;\n  @Input() textCenter?: boolean | string | undefined;\n  @Input() maxLength?: number | string;\n  @Input() greyBackground?: boolean | string | undefined;\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  localInputMode: typeof this.inputmode;\n  inputClear = false;\n  inputTextCenter = false;\n  inputType: typeof this.type;\n  inputAutoCapitalize: typeof this.autoCapitalize;\n  inputGreyBackground = false;\n  showPassword = false;\n  dateValidatorMin: string | null = null;\n  dateValidatorMax: string | null = null;\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    //--- Input Type (keyboard)\n    this.localInputMode =\n      validateStringValue<(typeof inputsC.inputMode)[number]>(changes, 'inputmode', inputsC.inputMode.slice(), this.localInputMode) || 'text';\n    //--- Clear Button\n    this.inputClear = checkTruthAttribute(changes, 'noClearButton', this.inputClear);\n    //--- Text Center\n    this.inputTextCenter = checkTruthAttribute(changes, 'textCenter', this.inputTextCenter);\n    //--- Type\n    this.inputType = validateStringValue<(typeof inputsC.type)[number]>(changes, 'type', inputsC.type.slice(), this.inputType) || 'text';\n    //--- Auto Capitalize\n    this.inputAutoCapitalize =\n      validateStringValue<(typeof inputsC.autoCapitalize)[number]>(\n        changes,\n        'autoCapitalize',\n        inputsC.autoCapitalize.slice(),\n        this.inputAutoCapitalize\n      ) || 'none';\n    //--- Grey Background\n    this.inputGreyBackground = checkTruthAttribute(changes, 'greyBackground', this.inputGreyBackground);\n\n    //---<> adding multiple validators\n    //--- Automatically add isValidDate validator when input is a date type and has either a min or a max value\n    if (this.inputType === 'date') {\n      if (changes['min']?.currentValue || changes['max']?.currentValue) {\n        //--- Update min max input\n        this.dateValidatorMin = changes['min'] ? changes['min'].currentValue : this.dateValidatorMin;\n        this.dateValidatorMax = changes['max'] ? changes['max'].currentValue : this.dateValidatorMax;\n        //--- Add new validator\n        this.control?.addValidators(CFPFormValidators.isValidDate(this.dateValidatorMin || null, this.dateValidatorMax || null));\n      }\n    }\n  }\n\n  /**----------------------------------------------------------------\n   * @name          togglePasswordShow\n   * @description   Toggle if password is showing or hidden\n   * @returns       {void}\n   */\n  togglePasswordShow(): void {\n    this.showPassword = !this.showPassword;\n    this.inputType = this.inputType === 'password' ? 'text' : 'password';\n  }\n}\n","<!-- ngModel -->\n<ion-input\n  #normalInput\n  *ngIf=\"!control\"\n  [ngClass]=\"{ 'text-center': inputTextCenter, 'grey-background': inputGreyBackground, error: !!customErrorMessage }\"\n  [label]=\"label\"\n  [labelPlacement]=\"inputLabelPlacement\"\n  [placeholder]=\"placeholder\"\n  fill=\"outline\"\n  [clearInput]=\"type === 'password' ? false : !inputClear\"\n  [autocapitalize]=\"autoCapitalize\"\n  mode=\"md\"\n  [inputmode]=\"localInputMode\"\n  [min]=\"min\"\n  [max]=\"max\"\n  [maxlength]=\"maxLength || null\"\n  [type]=\"inputType\"\n  (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n  [value]=\"value\">\n  <cf-icon\n    slot=\"end\"\n    style=\"cursor: pointer\"\n    *ngIf=\"normalInput.value && type === 'password'\"\n    [icon]=\"showPassword ? 'hide-password' : 'show-password'\"\n    [height]=\"24\"\n    (click)=\"togglePasswordShow()\"></cf-icon\n></ion-input>\n<!-- Form Control -->\n<ion-input\n  #formControlInput\n  *ngIf=\"control\"\n  [ngClass]=\"{ 'text-center': inputTextCenter, 'grey-background': inputGreyBackground, error: !!customErrorMessage }\"\n  [label]=\"label\"\n  [labelPlacement]=\"inputLabelPlacement\"\n  [placeholder]=\"placeholder\"\n  fill=\"outline\"\n  [clearInput]=\"type === 'password' ? false : !inputClear\"\n  [autocapitalize]=\"autoCapitalize\"\n  mode=\"md\"\n  [inputmode]=\"localInputMode\"\n  [formControl]=\"control\"\n  [min]=\"min\"\n  [max]=\"max\"\n  [maxlength]=\"maxLength || null\"\n  [type]=\"inputType\"\n  (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\">\n  <cf-icon\n    slot=\"end\"\n    style=\"cursor: pointer\"\n    *ngIf=\"formControlInput.value && type === 'password'\"\n    [icon]=\"showPassword ? 'hide-password' : 'show-password'\"\n    [height]=\"24\"\n    (click)=\"togglePasswordShow()\"></cf-icon>\n</ion-input>\n<cf-form-validation *ngIf=\"control || customErrorMessage\" [customErrorMessage]=\"customErrorMessage\" [control]=\"control || null\"></cf-form-validation>\n"]}
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input.component.js","sourceRoot":"","sources":["../../../../../../../projects/carefirst/library/src/lib/components/form-input/form-input.component.ts","../../../../../../../projects/carefirst/library/src/lib/components/form-input/form-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/**\n * Carefirst Library Form Input\n *\n * @file          form-input.component\n * @description   Contains all the logic for generating a CareFirst Form Input Field\n * @author        Arno Jansen van Vuuren\n * @since         2023 - 12 - 14\n * @usage         <cf-form-input\n *                  label=\"Label Name\"\n *                  %labelPlacement%\n *                  %inputMode%\n *                  %noClearButton%\n *                  %textCenter%\n *                  %min%\n *                  %max%\n *                  %autoCapitalize%\n *                  %type%\n *                  %[(value)]=\"twoWayComs\"%\n *                  %(valueChange)=\"currentValueEvent\"%\n *                  %[control]%=\"formName.controls.controlName\"\n *                  %[customErrorMessage]%=\"errorMessage\"\n *                ></cf-form-input>\n *                disable input by disabling the form control\n */\n\nimport { Component, Input, Output, type OnChanges, type SimpleChanges, EventEmitter } from '@angular/core';\nimport { FormControl } from '@angular/forms';\n//--- Utils\nimport { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';\nimport { CFPFormValidators } from '../../utils/form-validators-utility';\n//--- Interfaces\nimport { inputsC } from '../../interfaces/internal.interface';\n\n@Component({\n  selector: 'cf-form-input',\n  templateUrl: './form-input.component.html',\n  styleUrl: './form-input.component.scss',\n})\nexport class FormInputComponent implements OnChanges {\n  @Input() label!: string;\n  @Input() min: string | number | undefined;\n  @Input() max: string | number | undefined;\n  @Input() labelPlacement?: (typeof inputsC.labelPlacement)[number];\n  @Input() placeholder?: string | undefined;\n  @Input() inputmode?: (typeof inputsC.inputMode)[number];\n  @Input() autoCapitalize?: (typeof inputsC.autoCapitalize)[number];\n  @Input() type?: (typeof inputsC.type)[number];\n  @Input() noClearButton?: boolean | string | undefined;\n  @Input() control?: FormControl | null;\n  @Input() textCenter?: boolean | string | undefined;\n  @Input() maxLength?: number | string;\n  @Input() greyBackground?: boolean | string | undefined;\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  localInputMode: typeof this.inputmode;\n  inputClear = false;\n  inputTextCenter = false;\n  inputType: typeof this.type;\n  inputAutoCapitalize: typeof this.autoCapitalize;\n  inputGreyBackground = false;\n  showPassword = false;\n  dateValidatorMin: string | null = null;\n  dateValidatorMax: string | null = null;\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    //--- Input Type (keyboard)\n    this.localInputMode =\n      validateStringValue<(typeof inputsC.inputMode)[number]>(changes, 'inputmode', inputsC.inputMode.slice(), this.localInputMode) || 'text';\n    //--- Clear Button\n    this.inputClear = checkTruthAttribute(changes, 'noClearButton', this.inputClear);\n    //--- Text Center\n    this.inputTextCenter = checkTruthAttribute(changes, 'textCenter', this.inputTextCenter);\n    //--- Type\n    this.inputType = validateStringValue<(typeof inputsC.type)[number]>(changes, 'type', inputsC.type.slice(), this.inputType) || 'text';\n    //--- Auto Capitalize\n    this.inputAutoCapitalize =\n      validateStringValue<(typeof inputsC.autoCapitalize)[number]>(\n        changes,\n        'autoCapitalize',\n        inputsC.autoCapitalize.slice(),\n        this.inputAutoCapitalize\n      ) || 'none';\n    //--- Grey Background\n    this.inputGreyBackground = checkTruthAttribute(changes, 'greyBackground', this.inputGreyBackground);\n\n    //---<> adding multiple validators\n    //--- Automatically add isValidDate validator when input is a date type and has either a min or a max value\n    if (this.inputType === 'date') {\n      if (changes['min']?.currentValue || changes['max']?.currentValue) {\n        //--- Update min max input\n        this.dateValidatorMin = changes['min'] ? changes['min'].currentValue : this.dateValidatorMin;\n        this.dateValidatorMax = changes['max'] ? changes['max'].currentValue : this.dateValidatorMax;\n        //--- Add new validator\n        this.control?.addValidators(CFPFormValidators.isValidDate(this.dateValidatorMin || null, this.dateValidatorMax || null));\n      }\n    }\n  }\n\n  /**----------------------------------------------------------------\n   * @name          togglePasswordShow\n   * @description   Toggle if password is showing or hidden\n   * @returns       {void}\n   */\n  togglePasswordShow(): void {\n    this.showPassword = !this.showPassword;\n    this.inputType = this.inputType === 'password' ? 'text' : 'password';\n  }\n}\n","<!-- ngModel -->\n<ion-input\n  #normalInput\n  *ngIf=\"!control\"\n  [ngClass]=\"{ 'text-center': inputTextCenter, 'grey-background': inputGreyBackground, error: !!customErrorMessage }\"\n  [label]=\"label\"\n  [labelPlacement]=\"inputLabelPlacement\"\n  [placeholder]=\"placeholder\"\n  fill=\"outline\"\n  [clearInput]=\"type === 'password' ? false : !inputClear\"\n  [autocapitalize]=\"autoCapitalize\"\n  mode=\"md\"\n  [inputmode]=\"localInputMode\"\n  [min]=\"min\"\n  [max]=\"max\"\n  [maxlength]=\"maxLength || null\"\n  [type]=\"inputType\"\n  (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n  [value]=\"value\">\n  <cf-icon\n    slot=\"end\"\n    style=\"cursor: pointer\"\n    *ngIf=\"normalInput.value && type === 'password'\"\n    [icon]=\"showPassword ? 'hide-password' : 'show-password'\"\n    [height]=\"24\"\n    (click)=\"togglePasswordShow()\"></cf-icon\n></ion-input>\n<!-- Form Control -->\n<ion-input\n  #formControlInput\n  *ngIf=\"control\"\n  [ngClass]=\"{ 'text-center': inputTextCenter, 'grey-background': inputGreyBackground, error: !!customErrorMessage }\"\n  [label]=\"label\"\n  [labelPlacement]=\"inputLabelPlacement\"\n  [placeholder]=\"placeholder\"\n  fill=\"outline\"\n  [clearInput]=\"type === 'password' ? false : !inputClear\"\n  [autocapitalize]=\"autoCapitalize\"\n  mode=\"md\"\n  [inputmode]=\"localInputMode\"\n  [formControl]=\"control\"\n  [min]=\"min\"\n  [max]=\"max\"\n  [maxlength]=\"maxLength || null\"\n  [type]=\"inputType\"\n  (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\">\n  <cf-icon\n    slot=\"end\"\n    style=\"cursor: pointer\"\n    *ngIf=\"formControlInput.value && type === 'password'\"\n    [icon]=\"showPassword ? 'hide-password' : 'show-password'\"\n    [height]=\"24\"\n    (click)=\"togglePasswordShow()\"></cf-icon>\n</ion-input>\n<cf-form-validation *ngIf=\"control || customErrorMessage\" [customErrorMessage]=\"customErrorMessage\" [control]=\"control || null\"></cf-form-validation>\n"]}
@@ -0,0 +1,67 @@
1
+ import { Component, Input, Output, EventEmitter } from '@angular/core';
2
+ import { validateStringValue, checkTruthAttribute } from '../../utils/attribute.util';
3
+ import { inputsC } from '../../interfaces/internal.interface';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@ionic/angular";
6
+ import * as i2 from "@angular/common";
7
+ import * as i3 from "@angular/forms";
8
+ import * as i4 from "../icon/icon.component";
9
+ import * as i5 from "../form-validation/form-validation.component";
10
+ export class FormInputSearchComponent {
11
+ label;
12
+ labelPlacement;
13
+ placeholder;
14
+ autoCapitalize;
15
+ clearButton;
16
+ control;
17
+ textCenter;
18
+ customErrorMessage = null;
19
+ debounce;
20
+ searchButtonTrigger = new EventEmitter();
21
+ value;
22
+ valueChange = new EventEmitter(undefined);
23
+ inputLabelPlacement;
24
+ inputClear = false;
25
+ inputTextCenter = false;
26
+ inputAutoCapitalize;
27
+ showPassword = false;
28
+ ngOnChanges(changes) {
29
+ this.inputLabelPlacement =
30
+ validateStringValue(changes, 'labelPlacement', inputsC.labelPlacement.slice(), this.inputLabelPlacement) || 'floating';
31
+ this.inputClear = checkTruthAttribute(changes, 'noClearButton', this.inputClear);
32
+ this.inputTextCenter = checkTruthAttribute(changes, 'textCenter', this.inputTextCenter);
33
+ this.inputAutoCapitalize =
34
+ validateStringValue(changes, 'autoCapitalize', inputsC.autoCapitalize.slice(), this.inputAutoCapitalize) || 'none';
35
+ }
36
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: FormInputSearchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
37
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: FormInputSearchComponent, selector: "cf-form-input-search", inputs: { label: "label", labelPlacement: "labelPlacement", placeholder: "placeholder", autoCapitalize: "autoCapitalize", clearButton: "clearButton", control: "control", textCenter: "textCenter", customErrorMessage: "customErrorMessage", debounce: "debounce", value: "value" }, outputs: { searchButtonTrigger: "searchButtonTrigger", valueChange: "valueChange" }, usesOnChanges: true, ngImport: i0, template: "<!-- ngModel -->\n<ion-input\n #normalInput\n *ngIf=\"!control\"\n [ngClass]=\"{ 'text-center': inputTextCenter, error: !!customErrorMessage }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"inputClear\"\n [autocapitalize]=\"autoCapitalize\"\n mode=\"md\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n [value]=\"value\"\n [debounce]=\"debounce\">\n <cf-icon slot=\"end\" style=\"cursor: pointer\" icon=\"search\" [height]=\"24\" (click)=\"searchButtonTrigger.emit()\"></cf-icon>\n</ion-input>\n<!-- Form Control -->\n<ion-input\n #formControlInput\n *ngIf=\"control\"\n [ngClass]=\"{ 'text-center': inputTextCenter, error: !!customErrorMessage }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"inputClear\"\n [autocapitalize]=\"autoCapitalize\"\n mode=\"md\"\n [formControl]=\"control\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n [debounce]=\"debounce\">\n <cf-icon slot=\"end\" style=\"cursor: pointer\" icon=\"search\" [height]=\"24\" (click)=\"searchButtonTrigger.emit()\"></cf-icon>\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.text-center{text-align:center}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.IconComponent, selector: "cf-icon", inputs: ["icon", "height", "heightMobile", "heightDesktop", "iconColor"] }, { kind: "component", type: i5.FormValidationComponent, selector: "cf-form-validation", inputs: ["control", "customErrorMessage"] }] });
38
+ }
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: FormInputSearchComponent, decorators: [{
40
+ type: Component,
41
+ args: [{ selector: 'cf-form-input-search', template: "<!-- ngModel -->\n<ion-input\n #normalInput\n *ngIf=\"!control\"\n [ngClass]=\"{ 'text-center': inputTextCenter, error: !!customErrorMessage }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"inputClear\"\n [autocapitalize]=\"autoCapitalize\"\n mode=\"md\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n [value]=\"value\"\n [debounce]=\"debounce\">\n <cf-icon slot=\"end\" style=\"cursor: pointer\" icon=\"search\" [height]=\"24\" (click)=\"searchButtonTrigger.emit()\"></cf-icon>\n</ion-input>\n<!-- Form Control -->\n<ion-input\n #formControlInput\n *ngIf=\"control\"\n [ngClass]=\"{ 'text-center': inputTextCenter, error: !!customErrorMessage }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"inputClear\"\n [autocapitalize]=\"autoCapitalize\"\n mode=\"md\"\n [formControl]=\"control\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n [debounce]=\"debounce\">\n <cf-icon slot=\"end\" style=\"cursor: pointer\" icon=\"search\" [height]=\"24\" (click)=\"searchButtonTrigger.emit()\"></cf-icon>\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.text-center{text-align:center}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"] }]
42
+ }], propDecorators: { label: [{
43
+ type: Input
44
+ }], labelPlacement: [{
45
+ type: Input
46
+ }], placeholder: [{
47
+ type: Input
48
+ }], autoCapitalize: [{
49
+ type: Input
50
+ }], clearButton: [{
51
+ type: Input
52
+ }], control: [{
53
+ type: Input
54
+ }], textCenter: [{
55
+ type: Input
56
+ }], customErrorMessage: [{
57
+ type: Input
58
+ }], debounce: [{
59
+ type: Input
60
+ }], searchButtonTrigger: [{
61
+ type: Output
62
+ }], value: [{
63
+ type: Input
64
+ }], valueChange: [{
65
+ type: Output
66
+ }] } });
67
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input-search.component.js","sourceRoot":"","sources":["../../../../../../../projects/carefirst/library/src/lib/components/form-input-search/form-input-search.component.ts","../../../../../../../projects/carefirst/library/src/lib/components/form-input-search/form-input-search.component.html"],"names":[],"mappings":"AAqBA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAsC,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAG3G,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAEtF,OAAO,EAAE,OAAO,EAAE,MAAM,qCAAqC,CAAC;;;;;;;AAO9D,MAAM,OAAO,wBAAwB;IAC1B,KAAK,CAAU;IACf,cAAc,CAA2C;IACzD,WAAW,CAAsB;IACjC,cAAc,CAA2C;IACzD,WAAW,CAAgC;IAC3C,OAAO,CAAsB;IAC7B,UAAU,CAAgC;IAC1C,kBAAkB,GAAkB,IAAI,CAAC;IACzC,QAAQ,CAAsB;IAC7B,mBAAmB,GAAG,IAAI,YAAY,EAAsB,CAAC;IAG9D,KAAK,CAAqB;IACzB,WAAW,GAAG,IAAI,YAAY,CAAoB,SAAS,CAAC,CAAC;IAGvE,mBAAmB,CAA6B;IAChD,UAAU,GAAG,KAAK,CAAC;IACnB,eAAe,GAAG,KAAK,CAAC;IACxB,mBAAmB,CAA6B;IAChD,YAAY,GAAG,KAAK,CAAC;IAOrB,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;QAGlB,IAAI,CAAC,UAAU,GAAG,mBAAmB,CAAC,OAAO,EAAE,eAAe,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;QAEjF,IAAI,CAAC,eAAe,GAAG,mBAAmB,CAAC,OAAO,EAAE,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAExF,IAAI,CAAC,mBAAmB;YACtB,mBAAmB,CACjB,OAAO,EACP,gBAAgB,EAChB,OAAO,CAAC,cAAc,CAAC,KAAK,EAAE,EAC9B,IAAI,CAAC,mBAAmB,CACzB,IAAI,MAAM,CAAC;IAChB,CAAC;uGAlDU,wBAAwB;2FAAxB,wBAAwB,4bCjCrC,k4CAmCA;;2FDFa,wBAAwB;kBALpC,SAAS;+BACE,sBAAsB;8BAKvB,KAAK;sBAAb,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACI,mBAAmB;sBAA5B,MAAM;gBAGE,KAAK;sBAAb,KAAK;gBACI,WAAW;sBAApB,MAAM","sourcesContent":["/**\n * Carefirst Library Form Input Search\n *\n * @file          form-input-search.component\n * @description   Contains all the logic for generating a CareFirst Form Input Search Field\n * @author        Arno Jansen van Vuuren\n * @since         2024 - 09 - 25\n * @usage         <cf-form-input-search\n *                  label=\"Label Name\"\n *                  %labelPlacement%\n *                  %clearButton%\n *                  %textCenter%\n *                  %autoCapitalize%\n *                  %[(value)]=\"twoWayComs\"%\n *                  %(valueChange)=\"currentValueEvent\"%\n *                  %[control]%=\"formName.controls.controlName\"\n *                  %[customErrorMessage]%=\"errorMessage\"\n *                ></cf-form-input-search>\n *                disable input by disabling the form control\n */\n\nimport { Component, Input, type SimpleChanges, type OnChanges, Output, EventEmitter } from '@angular/core';\nimport type { FormControl } from '@angular/forms';\n//--- Utils\nimport { validateStringValue, checkTruthAttribute } from '../../utils/attribute.util';\n//--- Interfaces\nimport { inputsC } from '../../interfaces/internal.interface';\n\n@Component({\n  selector: 'cf-form-input-search',\n  templateUrl: './form-input-search.component.html',\n  styleUrl: './form-input-search.component.scss',\n})\nexport class FormInputSearchComponent implements OnChanges {\n  @Input() label!: string;\n  @Input() labelPlacement?: (typeof inputsC.labelPlacement)[number];\n  @Input() placeholder?: string | undefined;\n  @Input() autoCapitalize?: (typeof inputsC.autoCapitalize)[number];\n  @Input() clearButton?: boolean | string | undefined;\n  @Input() control?: FormControl | null;\n  @Input() textCenter?: boolean | string | undefined;\n  @Input() customErrorMessage: string | null = null;\n  @Input() debounce?: number | undefined;\n  @Output() searchButtonTrigger = new EventEmitter<string | undefined>();\n\n  //--- ngModel\n  @Input() value: string | undefined;\n  @Output() valueChange = new EventEmitter<typeof this.value>(undefined);\n\n  //--- Local variables\n  inputLabelPlacement: typeof this.labelPlacement;\n  inputClear = false;\n  inputTextCenter = false;\n  inputAutoCapitalize: typeof this.autoCapitalize;\n  showPassword = 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\n    //--- Clear Button\n    this.inputClear = checkTruthAttribute(changes, 'noClearButton', this.inputClear);\n    //--- Text Center\n    this.inputTextCenter = checkTruthAttribute(changes, 'textCenter', this.inputTextCenter);\n    //--- Auto Capitalize\n    this.inputAutoCapitalize =\n      validateStringValue<(typeof inputsC.autoCapitalize)[number]>(\n        changes,\n        'autoCapitalize',\n        inputsC.autoCapitalize.slice(),\n        this.inputAutoCapitalize\n      ) || 'none';\n  }\n}\n","<!-- ngModel -->\n<ion-input\n  #normalInput\n  *ngIf=\"!control\"\n  [ngClass]=\"{ 'text-center': inputTextCenter, error: !!customErrorMessage }\"\n  [label]=\"label\"\n  [labelPlacement]=\"inputLabelPlacement\"\n  [placeholder]=\"placeholder\"\n  fill=\"outline\"\n  [clearInput]=\"inputClear\"\n  [autocapitalize]=\"autoCapitalize\"\n  mode=\"md\"\n  (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n  [value]=\"value\"\n  [debounce]=\"debounce\">\n  <cf-icon slot=\"end\" style=\"cursor: pointer\" icon=\"search\" [height]=\"24\" (click)=\"searchButtonTrigger.emit()\"></cf-icon>\n</ion-input>\n<!-- Form Control -->\n<ion-input\n  #formControlInput\n  *ngIf=\"control\"\n  [ngClass]=\"{ 'text-center': inputTextCenter, error: !!customErrorMessage }\"\n  [label]=\"label\"\n  [labelPlacement]=\"inputLabelPlacement\"\n  [placeholder]=\"placeholder\"\n  fill=\"outline\"\n  [clearInput]=\"inputClear\"\n  [autocapitalize]=\"autoCapitalize\"\n  mode=\"md\"\n  [formControl]=\"control\"\n  (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n  [debounce]=\"debounce\">\n  <cf-icon slot=\"end\" style=\"cursor: pointer\" icon=\"search\" [height]=\"24\" (click)=\"searchButtonTrigger.emit()\"></cf-icon>\n</ion-input>\n<cf-form-validation *ngIf=\"control || customErrorMessage\" [customErrorMessage]=\"customErrorMessage\" [control]=\"control || null\"></cf-form-validation>\n"]}