@carefirst/library 2.0.4 → 2.0.5

Sign up to get free protection for your applications and to get access to all the features.
@@ -1 +1 @@
1
- {"version":3,"file":"carefirst-library.mjs","sources":["../../../../projects/carefirst/library/src/lib/directives/button-loader.directive.ts","../../../../projects/carefirst/library/src/lib/utils/attribute.util.ts","../../../../projects/carefirst/library/src/lib/components/page/page.component.ts","../../../../projects/carefirst/library/src/lib/components/page/page.component.html","../../../../projects/carefirst/library/src/lib/interfaces/icon.interface.ts","../../../../projects/carefirst/library/src/lib/components/icon/icon.component.ts","../../../../projects/carefirst/library/src/lib/components/icon/icon.component.html","../../../../projects/carefirst/library/src/lib/components/button/button.component.ts","../../../../projects/carefirst/library/src/lib/components/button/button.component.html","../../../../projects/carefirst/library/src/lib/components/spacer/spacer.component.ts","../../../../projects/carefirst/library/src/lib/components/spacer/spacer.component.html","../../../../projects/carefirst/library/src/lib/components/notification/notification.component.ts","../../../../projects/carefirst/library/src/lib/components/notification/notification.component.html","../../../../projects/carefirst/library/src/lib/components/alert/alert.component.ts","../../../../projects/carefirst/library/src/lib/components/alert/alert.component.html","../../../../projects/carefirst/library/src/lib/components/logo/logo.component.ts","../../../../projects/carefirst/library/src/lib/components/logo/logo.component.html","../../../../projects/carefirst/library/src/lib/components/calendar/calendar.component.ts","../../../../projects/carefirst/library/src/lib/components/calendar/calendar.component.html","../../../../projects/carefirst/library/src/lib/components/form-validation/form-validation.component.ts","../../../../projects/carefirst/library/src/lib/components/form-validation/form-validation.component.html","../../../../projects/carefirst/library/src/lib/components/form-input/form-input.component.ts","../../../../projects/carefirst/library/src/lib/components/form-input/form-input.component.html","../../../../projects/carefirst/library/src/lib/components/form-input-select/form-input-select.component.ts","../../../../projects/carefirst/library/src/lib/components/form-input-select/form-input-select.component.html","../../../../projects/carefirst/library/src/lib/components/form-input-text-area/form-input-text-area.component.ts","../../../../projects/carefirst/library/src/lib/components/form-input-text-area/form-input-text-area.component.html","../../../../projects/carefirst/library/src/lib/components/chat-bubble/chat-bubble.component.ts","../../../../projects/carefirst/library/src/lib/components/chat-bubble/chat-bubble.component.html","../../../../projects/carefirst/library/src/lib/components/badge/badge.component.ts","../../../../projects/carefirst/library/src/lib/components/badge/badge.component.html","../../../../projects/carefirst/library/src/lib/components/spinner/spinner.component.ts","../../../../projects/carefirst/library/src/lib/components/spinner/spinner.component.html","../../../../projects/carefirst/library/src/lib/components/verification-code/verification-code.component.ts","../../../../projects/carefirst/library/src/lib/components/verification-code/verification-code.component.html","../../../../projects/carefirst/library/src/lib/library.module.ts","../../../../projects/carefirst/library/src/lib/utils/form-validators-utility.ts","../../../../projects/carefirst/library/src/lib/interfaces/spacer.interface.ts"],"sourcesContent":["/**\n * Button Loader Directive\n *\n * @file button-loader.directive\n * @description HTML directive used to disable a button while loading\n * @author Jacques Coetzee\n * @since 2022 - 07 - 22\n * @usage Add to any HTML tag: *cfButtonLoader=\"true\"\n */\n\nimport { Component, Directive, Input, Renderer2, TemplateRef, ViewContainerRef, ElementRef } from '@angular/core';\n\n@Directive({\n selector: '[cfButtonLoader]',\n})\nexport class ButtonLoaderDirective {\n /**----------------------------------------------------------------\n * @name Constructor\n */\n constructor(\n private templateRef: TemplateRef<HTMLElement>,\n private renderer: Renderer2,\n private viewContainer: ViewContainerRef,\n private elementRef: ElementRef<HTMLElement>\n ) {}\n\n /**----------------------------------------------------------------\n * @name cfButtonLoader\n * @description Displays a loading overlay and disables a button\n * @param {boolean} loading\n */\n @Input() set cfButtonLoader(loading: boolean) {\n //--- Clear HTML container\n this.viewContainer.clear();\n //--- Reattach element as child\n this.viewContainer.createEmbeddedView(this.templateRef);\n if (loading) {\n //--- Add loading spinner\n this.viewContainer.createComponent(SpinnerComponent);\n //--- Set parent container position to relative\n this.renderer.setStyle(this.elementRef.nativeElement.parentElement, 'position', 'relative');\n }\n }\n}\n\n/**==================================================================\n * @class SpinnerComponent\n * @description The spinner component used to render an ion-spinner on the button\n * @author Jacques Coetzee\n * @since 2022 - 07 - 22\n * ===== */\n\n@Component({\n template: '<div class=\"loading-spinner\"></div>',\n styles: [\n `\n @keyframes spinner {\n to {\n transform: rotate(360deg);\n }\n }\n\n .loading-spinner {\n position: absolute;\n top: calc(50% - 1em);\n left: calc(50% - 1em);\n width: 2em;\n height: 2em;\n border-radius: 50%;\n border: 3px solid var(--cf-app-system-color-outline);\n border-top-color: var(--cf-app-color-accent);\n animation: spinner 1s linear infinite;\n }\n `,\n ],\n})\nclass SpinnerComponent {}\n","/**\n * Attribute Utility\n *\n * @file attribute.util\n * @description Contains various utility functions pertaining to attribute handling\n * @author Jacques Coetzee\n * @since 2023 - 11 - 08\n */\n\nimport type { SimpleChanges } from '@angular/core';\n\n/**----------------------------------------------------------------\n * @name checkTruthAttribute\n * @description Check whether an attribute is either just available or specifically set to boolean value\n * @param {SimpleChanges} changes\n * @param {string} attribute\n * @param {boolean} curVal\n * @returns {boolean}\n */\nexport function checkTruthAttribute(changes: SimpleChanges, attribute: string, curVal: boolean): boolean {\n if (!(attribute in changes)) return curVal;\n const valueChanged = changes[attribute]?.currentValue;\n if (typeof valueChanged === 'boolean') {\n return valueChanged;\n } else if (typeof valueChanged === 'string' && ['true', ''].includes(valueChanged)) {\n return true;\n }\n return false;\n}\n\n/**----------------------------------------------------------------\n * @name validateStringValue\n * @description Validate whether an attribute is set and contains a specific string option\n * @param {SimpleChanges} changes\n * @param {string} attribute\n * @param {string[]} options\n * @param {T | undefined} curVal\n * @returns {string | undefined} Returns correct string value or undefined if either not available or not in list\n */\nexport function validateStringValue<T>(changes: SimpleChanges, attribute: string, options: T[], curVal: T | undefined): T | undefined {\n if (!(attribute in changes)) return curVal;\n const valueChanged = changes[attribute]?.currentValue;\n if (valueChanged && options.includes(valueChanged)) {\n return valueChanged as T;\n }\n return undefined;\n}\n\n/**----------------------------------------------------------------\n * @name validateNumberValue\n * @description Validate whether an attribute is set and contains a specific number value\n * @param {SimpleChanges} changes\n * @param {string} attribute\n * @param {number | undefined} curVal\n * @returns {number | undefined} Returns correct number value or undefined if either not available or not a number\n */\nexport function validateNumberValue(changes: SimpleChanges, attribute: string, curVal: number | undefined): number | undefined {\n if (!(attribute in changes)) return curVal;\n const valueChanged = changes[attribute]?.currentValue;\n if (typeof valueChanged === 'number' && valueChanged >= 0) {\n return valueChanged;\n } else if (typeof valueChanged === 'string' && +valueChanged >= 0) {\n return +valueChanged;\n }\n return undefined;\n}\n","/**\n * CareFirst Library - Page\n *\n * @file page.component\n * @description Contains all the logic for generating a basic CareFirst Page structure\n * @author Jacques Coetzee\n * @since 2023 - 11 - 07\n * @usage <cf-page %centerH% %centerV% %dark% style=\"--cf-page-inline-padding: 16px; --cf-page-max-width: 1300px; --footer-bg-color: transparent\">CONTENT</cf-page>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\nimport { checkTruthAttribute } from '../../utils/attribute.util';\n\n@Component({\n selector: 'cf-page',\n templateUrl: './page.component.html',\n styleUrls: ['./page.component.scss'],\n})\nexport class PageComponent implements OnChanges {\n @Input() centerH?: boolean | string | undefined;\n @Input() centerV?: boolean | string | undefined;\n @Input() dark?: boolean | string | undefined;\n\n //--- Local variables\n inputCenterH = false;\n inputCenterV = false;\n inputDark = false;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Center H\n this.inputCenterH = checkTruthAttribute(changes, 'centerH', this.inputCenterH);\n //--- Center V\n this.inputCenterV = checkTruthAttribute(changes, 'centerV', this.inputCenterV);\n //--- Dark\n this.inputDark = checkTruthAttribute(changes, 'dark', this.inputDark);\n }\n}\n","<ion-content class=\"ion-page cf-page\" [ngClass]=\"{ 'bg-dark': inputDark }\">\n <div class=\"main-page\">\n <div class=\"spacing\" [ngClass]=\"{ 'center-h': inputCenterH, 'center-v': inputCenterV }\">\n <div class=\"content\">\n <ng-content></ng-content>\n </div>\n </div>\n <div id=\"footer\">\n <div class=\"content\">\n <ng-content select=\"[footer]\"></ng-content>\n </div>\n </div>\n </div>\n</ion-content>\n","/**==============================================\n * @interface IconsT\n * @description Short description\n */\nexport const iconsC = [\n 'home',\n 'cog',\n 'profile',\n 'scan',\n 'person',\n 'appointment',\n 'clock',\n 'calendar',\n 'email',\n 'phone',\n 'sign-out',\n 'sign-in',\n 'close',\n 'check-mark',\n 'rating-star-blank',\n 'rating-star-filled',\n 'back-arrow',\n 'lock',\n 'show-password',\n 'hide-password',\n 'circle-check',\n 'circle-alert',\n 'direction-switch',\n 'chat-bubbles',\n 'phone-down',\n 'mic',\n 'no-mic',\n 'button-forward-arrow',\n 'button-check-box',\n 'social-media-whatsapp',\n 'social-media-facebook',\n 'social-media-linkedin',\n 'social-media-instagram',\n 'social-media-google-mail',\n 'instant-video-service',\n 'instant-telephonic-service',\n 'scheduled-video-service',\n 'scheduled-telephonic-service',\n 'vital-scan-service',\n 'open-back-arrow',\n 'open-forward-arrow',\n 'open-up-arrow',\n 'open-down-arrow',\n 'single-document',\n 'lightning',\n 'microsoft-365',\n 'user-dependent',\n 'plus',\n] as const;\nexport type IconsT = (typeof iconsC)[number];\n\n/**==============================================\n * @interface IconColorT\n * @description All available colors in CSS classes\n */\nexport const iconColorC = ['primary', 'secondary', 'success', 'warning', 'error', 'white', 'accent'] as const;\nexport type IconColorT = (typeof iconColorC)[number];\n","/**\n * CareFirst Library - Icon\n *\n * @file icon.component\n * @description Contains all the logic for generating a CareFirst Icon\n * @author Jacques Coetzee\n * @since 2023 - 11 - 07\n * @usage <cf-icon %icon=\"IconsT\"% %iconColor=\"'primary' | 'secondary' | 'success' | 'warning' | 'error' | 'white'\"%></cf-icon>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\nimport { validateStringValue } from '../../utils/attribute.util';\nimport { iconsC, type IconColorT, type IconsT, iconColorC } from '../../interfaces/icon.interface';\n\n@Component({\n selector: 'cf-icon',\n templateUrl: './icon.component.html',\n styleUrls: ['./icon.component.scss'],\n})\nexport class IconComponent implements OnChanges {\n @Input() icon!: IconsT;\n @Input() height?: number;\n @Input() iconColor?: IconColorT;\n\n //--- Local variables\n inputIcon: typeof this.icon | undefined = undefined;\n inputColor: typeof this.iconColor | undefined = undefined;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Type\n this.inputIcon = validateStringValue<IconsT>(changes, 'icon', iconsC.slice(), this.inputIcon);\n //--- Color\n this.inputColor = validateStringValue<IconColorT>(changes, 'iconColor', iconColorC.slice(), this.inputColor);\n }\n}\n","<div class=\"app-icon-container\" [ngStyle]=\"{ height: (this.height || 20) + 'px' }\" [ngClass]=\"iconColor\">\n <!-- person -->\n <svg *ngIf=\"inputIcon === 'person'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <circle cx=\"10\" cy=\"5\" r=\"4\" stroke-width=\"1.5\" />\n <path d=\"M2 19C3 10 17 10 18 19\" stroke-width=\"1.5\" stroke-linecap=\"round\" />\n </svg>\n <!-- appointment -->\n <svg\n *ngIf=\"inputIcon === 'appointment'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n style=\"stroke-width: 1.5; stroke-linecap: round\">\n <rect width=\"16\" height=\"16\" x=\"2\" y=\"3\" rx=\"2\" ry=\"2\" />\n <line x1=\"6\" y1=\"1\" x2=\"6\" y2=\"3\" />\n <line x1=\"14\" y1=\"1\" x2=\"14\" y2=\"3\" />\n <line x1=\"2\" y1=\"7\" x2=\"18\" y2=\"7\" />\n <line x1=\"6\" y1=\"11\" x2=\"14\" y2=\"11\" />\n </svg>\n <!-- clock -->\n <svg *ngIf=\"inputIcon === 'clock'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <circle cx=\"10\" cy=\"10\" r=\"9\" stroke-width=\"1.5\" />\n <path d=\"M10 6L10 10L13 13\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- calendar -->\n <svg *ngIf=\"inputIcon === 'calendar'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 22 20\" fill=\"none\">\n <path\n d=\"M1 6.50508H21M4.01099 2.50004V2C4.01099 1.72386 4.23484 1.5 4.51099 1.5H17.4878C17.7639 1.5 17.9878 1.72386 17.9878 2V2.50004M4.98834 9.00006H5.03295M4.96603 12.1079H5.01064M4.94379 15.2158H4.9884M9.03296 9.00006H9.07757M9.01065 12.1079H9.05526M8.98834 15.2158H9.03295M13.0776 9.00006H13.1222M13.0553 12.1079H13.0999M13.033 15.2158H13.0776M17.1222 9.00006H17.1668M17.0999 12.1079H17.1445M17.0776 15.2158H17.1222M3 18.5H19C20.1046 18.5 21 17.6046 21 16.5V4.5C21 3.39543 20.1046 2.5 19 2.5H3C1.89543 2.5 1 3.39543 1 4.5V16.5C1 17.6046 1.89543 18.5 3 18.5Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- email -->\n <svg *ngIf=\"inputIcon === 'email'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 16\" fill=\"none\">\n <path\n d=\"M2 2L10.2286 8L17.9999 2M19 4.19995V11.8C19 12.9201 19.0002 13.4802 18.7822 13.908C18.5905 14.2844 18.2841 14.5902 17.9078 14.782C17.48 15 16.9203 15 15.8002 15H4.2002C3.08009 15 2.51962 15 2.0918 14.782C1.71547 14.5902 1.40973 14.2844 1.21799 13.908C1 13.4802 1 12.9201 1 11.8V4.19995C1 3.07985 1 2.51986 1.21799 2.09204C1.40973 1.71572 1.71547 1.40973 2.0918 1.21799C2.51962 1 3.08009 1 4.2002 1H15.8002C16.9203 1 17.48 1 17.9078 1.21799C18.2841 1.40973 18.5905 1.71572 18.7822 2.09204C19.0002 2.51986 19 3.07985 19 4.19995Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- phone -->\n <svg *ngIf=\"inputIcon === 'phone'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 22 22\" fill=\"none\">\n <path\n d=\"M20.97 17.33C20.97 17.69 20.89 18.06 20.72 18.42C20.55 18.78 20.33 19.12 20.04 19.44C19.55 19.98 19.01 20.37 18.4 20.62C17.8 20.87 17.15 21 16.45 21C15.43 21 14.34 20.76 13.19 20.27C12.04 19.78 10.89 19.12 9.75 18.29C8.6 17.45 7.51 16.52 6.47 15.49C5.44 14.45 4.51 13.36 3.68 12.22C2.86 11.08 2.2 9.94 1.72 8.81C1.24 7.67 1 6.58 1 5.54C1 4.86 1.12 4.21 1.36 3.61C1.6 3 1.98 2.44 2.51 1.94C3.15 1.31 3.85 1 4.59 1C4.87 1 5.15 1.06 5.4 1.18C5.66 1.3 5.89 1.48 6.07 1.74L8.39 5.01C8.57 5.26 8.7 5.49 8.79 5.71C8.88 5.92 8.93 6.13 8.93 6.32C8.93 6.56 8.86 6.8 8.72 7.03C8.59 7.26 8.4 7.5 8.16 7.74L7.4 8.53C7.29 8.64 7.24 8.77 7.24 8.93C7.24 9.01 7.25 9.08 7.27 9.16C7.3 9.24 7.33 9.3 7.35 9.36C7.53 9.69 7.84 10.12 8.28 10.64C8.73 11.16 9.21 11.69 9.73 12.22C10.27 12.75 10.79 13.24 11.32 13.69C11.84 14.13 12.27 14.43 12.61 14.61C12.66 14.63 12.72 14.66 12.79 14.69C12.87 14.72 12.95 14.73 13.04 14.73C13.21 14.73 13.34 14.67 13.45 14.56L14.21 13.81C14.46 13.56 14.7 13.37 14.93 13.25C15.16 13.11 15.39 13.04 15.64 13.04C15.83 13.04 16.03 13.08 16.25 13.17C16.47 13.26 16.7 13.39 16.95 13.56L20.26 15.91C20.52 16.09 20.7 16.3 20.81 16.55C20.91 16.8 20.97 17.05 20.97 17.33Z\"\n stroke-width=\"1.5\"\n stroke-miterlimit=\"10\" />\n <path d=\"M14 1C17 1 21 4 21 8\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path d=\"M14 4C16 4 18 6 18 8\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- home -->\n <svg *ngIf=\"inputIcon === 'home'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M1.97409 6.39868L9.14434 1.56272C9.64904 1.22233 10.3094 1.22072 10.8158 1.55865L18.0692 6.39951C18.6251 6.77052 18.959 7.39471 18.959 8.06306V19H12.0095V13.0287C12.0095 11.9177 11.1089 11.0171 9.99786 11.0171C8.88685 11.0171 7.9862 11.9177 7.9862 13.0287V19H1.09241V8.0568C1.09241 7.3919 1.42285 6.77047 1.97409 6.39868Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- cog -->\n <svg *ngIf=\"inputIcon === 'cog'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 18 18\" fill=\"none\">\n <path\n d=\"M10.4014 0.7771C10.6692 0.7771 10.9258 0.884538 11.1138 1.07535L12.4463 2.4281C12.5731 2.55681 12.7323 2.64876 12.9072 2.6942L14.745 3.1718C15.0042 3.23917 15.2255 3.4077 15.3595 3.63965L16.7608 6.06688C16.8947 6.29883 16.93 6.5748 16.8587 6.83298L16.3535 8.66333C16.3054 8.83748 16.3054 9.02139 16.3535 9.19553L16.8587 11.0259C16.93 11.2841 16.8947 11.56 16.7608 11.792L15.3595 14.2192C15.2255 14.4512 15.0042 14.6197 14.745 14.6871L12.9072 15.1647C12.7323 15.2101 12.5731 15.3021 12.4463 15.4308L11.1138 16.7835C10.9258 16.9743 10.6692 17.0818 10.4014 17.0818H7.59865C7.33082 17.0818 7.07418 16.9743 6.88623 16.7835L5.55373 15.4308C5.42695 15.3021 5.26768 15.2101 5.09283 15.1647L3.25506 14.6871C2.99584 14.6197 2.77448 14.4512 2.64056 14.2192L1.2392 11.792C1.10529 11.56 1.07001 11.2841 1.14128 11.0259L1.64655 9.19553C1.69462 9.02139 1.69462 8.83748 1.64655 8.66333L1.14128 6.83298C1.07001 6.5748 1.10529 6.29883 1.2392 6.06688L2.64056 3.63965C2.77448 3.4077 2.99584 3.23917 3.25506 3.1718L5.09283 2.6942C5.26768 2.64876 5.42695 2.55681 5.55373 2.4281L6.88623 1.07535C7.07418 0.884538 7.33082 0.7771 7.59865 0.7771H10.4014Z\"\n stroke-width=\"1.5\" />\n <path\n d=\"M12.1179 8.92943C12.1179 10.6114 10.7544 11.9748 9.07247 11.9748C7.39054 11.9748 6.02706 10.6114 6.02706 8.92943C6.02706 7.2475 7.39054 5.88402 9.07247 5.88402C10.7544 5.88402 12.1179 7.2475 12.1179 8.92943Z\"\n stroke-width=\"1.5\" />\n </svg>\n <!-- profile -->\n <svg *ngIf=\"inputIcon === 'profile'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M15 18.9294C15 16.168 12.7614 13.9294 10 13.9294C7.23858 13.9294 5 16.168 5 18.9294M10 10.9294C8.34315 10.9294 7 9.5863 7 7.92944C7 6.27259 8.34315 4.92944 10 4.92944C11.6569 4.92944 13 6.27259 13 7.92944C13 9.5863 11.6569 10.9294 10 10.9294ZM19 4.12939V15.7294C19 16.8495 19.0002 17.4097 18.7822 17.8375C18.5905 18.2138 18.2841 18.5197 17.9078 18.7114C17.48 18.9294 16.9203 18.9294 15.8002 18.9294H4.2002C3.08009 18.9294 2.51962 18.9294 2.0918 18.7114C1.71547 18.5197 1.40973 18.2138 1.21799 17.8375C1 17.4097 1 16.8495 1 15.7294V4.12939C1 3.00929 1 2.44931 1.21799 2.02148C1.40973 1.64516 1.71547 1.33918 2.0918 1.14743C2.51962 0.929443 3.08009 0.929443 4.2002 0.929443H15.8002C16.9203 0.929443 17.48 0.929443 17.9078 1.14743C18.2841 1.33918 18.5905 1.64516 18.7822 2.02148C19.0002 2.44931 19 3.00929 19 4.12939Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- scan -->\n <svg *ngIf=\"inputIcon === 'scan'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M1 5V2C1 1.44772 1.44772 1 2 1H5M1 15V18C1 18.5523 1.44772 19 2 19H5M19 5V2C19 1.44772 18.5523 1 18 1H15M19 15V18C19 18.5523 18.5523 19 18 19H15M2 10H18\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- sign-out -->\n <svg *ngIf=\"inputIcon === 'sign-out'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M7.80053 9.94781H17.7201M15.708 7.4576L18.9408 9.93332L15.708 12.4013M14.9327 4.89544V2.99078C14.9327 1.88621 14.0373 0.990784 12.9327 0.990784H3.05328C1.94871 0.990784 1.05328 1.88621 1.05328 2.99078V16.9978C1.05328 18.1024 1.94871 18.9978 3.05328 18.9978H12.9327C14.0373 18.9978 14.9327 18.1024 14.9327 16.9978V14.9943\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- sign-in -->\n <svg *ngIf=\"inputIcon === 'sign-in'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M1.07129 10.0204H10.9908M8.97873 7.53022L12.2115 10.0059L8.97873 12.4739M4.03967 7.11697V3.06152C4.03967 1.95695 4.9351 1.06152 6.03967 1.06152H16.9409C18.0454 1.06152 18.9409 1.95695 18.9409 3.06152V17.0685C18.9409 18.1731 18.0454 19.0685 16.9409 19.0685H6.03967C4.9351 19.0685 4.03967 18.1731 4.03967 17.0685V13.1326\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- close -->\n <svg *ngIf=\"inputIcon === 'close'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 14 14\" fill=\"none\">\n <path d=\"M1.37749 12.6423L12.6705 1.3492M12.6705 12.6423L1.37749 1.3492\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- rating-star-blank -->\n <svg *ngIf=\"inputIcon === 'rating-star-blank'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 32 31\" fill=\"none\">\n <path\n d=\"M15.2481 1.90951C15.55 1.27691 16.4504 1.27691 16.7523 1.90951L20.6057 9.98487C20.7271 10.2395 20.9692 10.4153 21.2488 10.4522L30.1197 11.6215C30.8146 11.7131 31.0929 12.5695 30.5845 13.0521L24.0952 19.2123C23.8906 19.4065 23.7981 19.691 23.8495 19.9684L25.4786 28.7665C25.6063 29.4557 24.8778 29.985 24.2617 29.6506L16.3977 25.3825C16.1498 25.2479 15.8506 25.2479 15.6027 25.3825L7.73866 29.6506C7.12262 29.985 6.39413 29.4557 6.52175 28.7665L8.15088 19.9684C8.20225 19.691 8.1098 19.4065 7.90521 19.2123L1.41584 13.0521C0.907481 12.5695 1.18574 11.7131 1.88066 11.6215L10.7515 10.4522C11.0312 10.4153 11.2732 10.2395 11.3947 9.98487L15.2481 1.90951Z\"\n stroke-width=\"1.5\" />\n </svg>\n <!-- rating-star-filled -->\n <svg\n *ngIf=\"inputIcon === 'rating-star-filled'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 32 31\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M15.2481 1.90951C15.55 1.27691 16.4504 1.27691 16.7523 1.90951L20.6057 9.98487C20.7271 10.2395 20.9692 10.4153 21.2488 10.4522L30.1197 11.6215C30.8146 11.7131 31.0929 12.5695 30.5845 13.0521L24.0952 19.2123C23.8906 19.4065 23.7981 19.691 23.8495 19.9684L25.4786 28.7665C25.6063 29.4557 24.8778 29.985 24.2617 29.6506L16.3977 25.3825C16.1498 25.2479 15.8506 25.2479 15.6027 25.3825L7.73866 29.6506C7.12262 29.985 6.39413 29.4557 6.52175 28.7665L8.15088 19.9684C8.20225 19.691 8.1098 19.4065 7.90521 19.2123L1.41584 13.0521C0.907481 12.5695 1.18574 11.7131 1.88066 11.6215L10.7515 10.4522C11.0312 10.4153 11.2732 10.2395 11.3947 9.98487L15.2481 1.90951Z\"\n stroke-width=\"1.5\" />\n </svg>\n <!-- check-mark -->\n <svg *ngIf=\"inputIcon === 'check-mark'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M1 10L7 16L19 4\" stroke-width=\"1.7\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- back-arrow -->\n <svg *ngIf=\"inputIcon === 'back-arrow'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M6.5 5L1 10L6.5 15M1 10L19 10\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- lock -->\n <svg *ngIf=\"inputIcon === 'lock'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 25 27\" style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M12.5 13C11.6595 13.0003 10.8472 13.303 10.2115 13.8529C9.57579 14.4027 9.1592 15.163 9.03785 15.9947C8.9165 16.8264 9.0985 17.674 9.55058 18.3825C10.0027 19.0911 10.6946 19.6133 11.5 19.8538V22C11.5 22.2652 11.6054 22.5196 11.7929 22.7071C11.9804 22.8946 12.2348 23 12.5 23C12.7652 23 13.0196 22.8946 13.2071 22.7071C13.3946 22.5196 13.5 22.2652 13.5 22V19.8538C14.3054 19.6133 14.9973 19.0911 15.4494 18.3825C15.9015 17.674 16.0835 16.8264 15.9622 15.9947C15.8408 15.163 15.4242 14.4027 14.7885 13.8529C14.1528 13.303 13.3405 13.0003 12.5 13ZM12.5 18C12.2033 18 11.9133 17.912 11.6666 17.7472C11.42 17.5824 11.2277 17.3481 11.1142 17.074C11.0006 16.7999 10.9709 16.4983 11.0288 16.2074C11.0867 15.9164 11.2296 15.6491 11.4393 15.4393C11.6491 15.2296 11.9164 15.0867 12.2074 15.0288C12.4983 14.9709 12.7999 15.0007 13.074 15.1142C13.3481 15.2277 13.5824 15.42 13.7472 15.6666C13.912 15.9133 14 16.2033 14 16.5C14 16.8978 13.842 17.2794 13.5607 17.5607C13.2794 17.842 12.8978 18 12.5 18ZM22.5 9H18.5V6C18.5 4.4087 17.8679 2.88258 16.7426 1.75736C15.6174 0.632141 14.0913 0 12.5 0C10.9087 0 9.38258 0.632141 8.25736 1.75736C7.13214 2.88258 6.5 4.4087 6.5 6V9H2.5C1.96957 9 1.46086 9.21071 1.08579 9.58579C0.710714 9.96086 0.5 10.4696 0.5 11V25C0.5 25.5304 0.710714 26.0391 1.08579 26.4142C1.46086 26.7893 1.96957 27 2.5 27H22.5C23.0304 27 23.5391 26.7893 23.9142 26.4142C24.2893 26.0391 24.5 25.5304 24.5 25V11C24.5 10.4696 24.2893 9.96086 23.9142 9.58579C23.5391 9.21071 23.0304 9 22.5 9ZM8.5 6C8.5 4.93913 8.92143 3.92172 9.67157 3.17157C10.4217 2.42143 11.4391 2 12.5 2C13.5609 2 14.5783 2.42143 15.3284 3.17157C16.0786 3.92172 16.5 4.93913 16.5 6V9H8.5V6ZM22.5 25H2.5V11H22.5V25Z\" />\n </svg>\n <!-- show-password -->\n <svg *ngIf=\"inputIcon === 'show-password'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <ellipse cx=\"10\" cy=\"10\" rx=\"9\" ry=\"4\" stroke-width=\"1\" />\n <circle cx=\"10\" cy=\"10\" r=\"2.5\" stroke-width=\"1\" />\n </svg>\n <!-- hide-password -->\n <svg *ngIf=\"inputIcon === 'hide-password'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <ellipse cx=\"10\" cy=\"10\" rx=\"9\" ry=\"4\" stroke-width=\"1\" />\n <circle cx=\"10\" cy=\"10\" r=\"2.5\" stroke-width=\"1\" />\n <line x1=\"1\" y1=\"4\" x2=\"19\" y2=\"16\" stroke-width=\"1\" stroke-linecap=\"round\" />\n </svg>\n <!-- circle-check -->\n <svg *ngIf=\"inputIcon === 'circle-check'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <circle cx=\"10\" cy=\"10\" r=\"9\" stroke-width=\"1.5\" />\n <path d=\"M5.5 11L9 14L14.5 7.5\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- circle-alert -->\n <svg *ngIf=\"inputIcon === 'circle-alert'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M10.0002 19.1666C15.0418 19.1666 19.1668 15.0416 19.1668 9.99998C19.1668 4.95831 15.0418 0.833313 10.0002 0.833313C4.9585 0.833313 0.833496 4.95831 0.833496 9.99998C0.833496 15.0416 4.9585 19.1666 10.0002 19.1666Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <path d=\"M10 6.33331V10.9166\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path d=\"M9.99512 13.6667H10.0034\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- direction-switch -->\n <svg *ngIf=\"inputIcon === 'direction-switch'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 18 18\" fill=\"none\">\n <path\n d=\"M15.3805 4.2C14.7138 3.13333 12.5005 1 8.98046 1C4.58046 1 0.980469 3.8 0.980469 8.99999M12.9805 5H16.1804V1.8M2.67738 13.8C3.34405 14.8667 5.55738 17 9.07738 17C13.4774 17 17.0774 14.2 17.0774 9M5.07738 13H1.87739V16.2\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- chat-bubbles -->\n <svg\n *ngIf=\"inputIcon === 'chat-bubbles'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\">\n <path d=\"M 1 19 V 7 S 1 5 3 5 H 13 S 15 5 15 7 V 15 S 15 17 13 17 H 3.5 Z\" />\n <path d=\"M 4 9 H 12 M 4 13 H 12\" />\n <path d=\"M 3 5 V 3 S 3 1 5 1 H 17 S 19 1 19 3 V 15 L 16.5 13 15 13\" />\n </svg>\n <!-- phone-down -->\n <svg *ngIf=\"inputIcon === 'phone-down'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 -8 29 29\" style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M22.6589 11.7706C23.4866 12.1253 24.4468 11.9404 25.0836 11.3036L27.2257 9.16151C28.0404 8.34676 28.0404 7.02577 27.2257 6.21102C20.3003 -0.714333 9.072 -0.714112 2.14665 6.21124C1.3319 7.02599 1.33198 8.34672 2.14673 9.16146L4.28896 11.3035C4.9257 11.9403 5.88596 12.1251 6.71364 11.7704L9.58644 10.5392C10.3299 10.2206 10.8388 9.52027 10.912 8.71471L11.0005 7.74261C11.1036 6.60831 12.0546 5.7398 13.1936 5.73979L16.1789 5.73968C17.3179 5.73968 18.2687 6.60846 18.3719 7.74277L18.4602 8.71468C18.5335 9.52024 19.0425 10.2207 19.786 10.5393L22.6589 11.7706Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- mic -->\n <svg\n *ngIf=\"inputIcon === 'mic'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n stroke-width=\"1\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\">\n <path d=\"M 6 5 C 6 0 14 0 14 5 V 9 C 14 14 6 14 6 9 V 5 M 6 5 H 8 M 6 7 H 8 M 6 9 H 8 M 14 5 H 12 M 14 7 H 12 M 14 9 H 12\" />\n <path d=\"M 4 9 C 4 17 16 17 16 9 \" />\n <path d=\"M 9 15 V 18 H 7 S 5 18 5 19.7 H 15 S 15 18 13 18 H 11 V 15\" />\n </svg>\n <!-- no-mic -->\n <svg\n *ngIf=\"inputIcon === 'no-mic'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n stroke-width=\"1\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\">\n <path d=\"M 6 5 C 6 0 14 0 14 5 V 9 C 14 14 6 14 6 9 V 5 M 6 5 H 8 M 6 7 H 8 M 6 9 H 8 M 14 5 H 12 M 14 7 H 12 M 14 9 H 12\" />\n <path d=\"M 4 9 C 4 17 16 17 16 9 \" />\n <path d=\"M 9 15 V 18 H 7 S 5 18 5 19.7 H 15 S 15 18 13 18 H 11 V 15\" />\n <line x1=\"1\" y1=\"1\" x2=\"19\" y2=\"19\" />\n </svg>\n <!-- Button Icons -->\n <!-- button-forward-arrow -->\n <svg *ngIf=\"inputIcon === 'button-forward-arrow'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 25 25\" fill=\"none\">\n <path d=\"M5.5 12.5H19.5\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path d=\"M12.5 5.5L19.5 12.5L12.5 19.5\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- button-check-box -->\n <svg *ngIf=\"inputIcon === 'button-check-box'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <rect x=\"1\" y=\"1\" rx=\"4\" ry=\"4\" width=\"18\" height=\"18\" stroke-width=\"1.5\" />\n <path d=\"M5 11L9 14L15 6\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- Social Media Icons -->\n <!-- social-media-whatsapp -->\n <svg\n *ngIf=\"inputIcon === 'social-media-whatsapp'\"\n viewBox=\"-1 -1 27 27\"\n xmlns=\"http://www.w3.org/2000/svg\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M18.2273 14.9814C17.9163 14.8265 16.3871 14.0777 16.102 13.9743C15.8169 13.871 15.6096 13.8195 15.4022 14.1293C15.1949 14.4391 14.5988 15.1364 14.4174 15.343C14.236 15.5495 14.0545 15.5755 13.7436 15.4204C13.4325 15.2655 12.4303 14.9387 11.2423 13.884C10.3178 13.0633 9.69351 12.0497 9.51211 11.7398C9.33066 11.4299 9.49273 11.2624 9.64844 11.108C9.78843 10.9693 9.95952 10.7465 10.115 10.5657C10.2706 10.385 10.3224 10.2558 10.426 10.0494C10.5297 9.84273 10.4779 9.66201 10.4 9.50709C10.3224 9.35217 9.70034 7.82853 9.44116 7.20866C9.18867 6.60517 8.93227 6.6869 8.74136 6.67733C8.56016 6.66839 8.35254 6.66649 8.14526 6.66649C7.93794 6.66649 7.60093 6.74395 7.31582 7.05374C7.03076 7.36363 6.22729 8.11257 6.22729 9.63606C6.22729 11.1597 7.34175 12.6315 7.49727 12.8381C7.65278 13.0448 9.69043 16.1712 12.8105 17.512C13.5525 17.831 14.1319 18.0214 14.5836 18.1641C15.3287 18.3997 16.0067 18.3665 16.5426 18.2867C17.1402 18.1979 18.3828 17.538 18.642 16.815C18.9011 16.0918 18.9011 15.4721 18.8234 15.343C18.7457 15.2138 18.5383 15.1364 18.2273 14.9814ZM12.5523 22.693H12.5481C10.6916 22.6923 8.8707 22.1959 7.28223 21.2578L6.90439 21.0346L2.98867 22.0569L4.03384 18.2573L3.78789 17.8677C2.7522 16.2284 2.20518 14.3336 2.20601 12.3881C2.2083 6.711 6.84956 2.09234 12.5564 2.09234C15.3198 2.09326 17.9175 3.16569 19.8709 5.11195C21.8243 7.05816 22.8994 9.64514 22.8983 12.3964C22.8959 18.0739 18.2547 22.693 12.5523 22.693ZM21.3576 3.63307C19.0074 1.2915 15.8821 0.00136065 12.5521 0C5.69111 0 0.10708 5.55698 0.104297 12.3873C0.103418 14.5707 0.676563 16.7018 1.76592 18.5806L0 25L6.59868 23.2773C8.41685 24.2643 10.4639 24.7845 12.5472 24.7852H12.5523C19.4126 24.7852 24.9972 19.2276 25 12.3972C25.0013 9.08708 23.7077 5.97465 21.3576 3.63307Z\" />\n </svg>\n <!-- social-media-facebook -->\n <svg\n *ngIf=\"inputIcon === 'social-media-facebook'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"-1 -1 27 27\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M25 12.5764C25 5.63064 19.4036 0 12.5 0C5.59644 0 0 5.63064 0 12.5764C0 18.8536 4.57109 24.0565 10.5469 25V16.2118H7.37305V12.5764H10.5469V9.80566C10.5469 6.6537 12.413 4.91265 15.2683 4.91265C16.6359 4.91265 18.0664 5.15829 18.0664 5.15829V8.25326H16.4902C14.9374 8.25326 14.4531 9.22267 14.4531 10.2172V12.5764H17.9199L17.3657 16.2118H14.4531V25C20.429 24.0565 25 18.8536 25 12.5764Z\" />\n </svg>\n <!-- social-media-linkedin -->\n <svg\n *ngIf=\"inputIcon === 'social-media-linkedin'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 25 25\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M23.3696 0H1.63043C0.733696 0 0 0.733696 0 1.63043V23.3696C0 24.2663 0.733696 25 1.63043 25H23.3696C24.2663 25 25 24.2663 25 23.3696V1.63043C25 0.733696 24.2663 0 23.3696 0ZM3.39674 4.75543C3.83152 4.32065 4.42935 4.07609 5.02717 4.07609C5.625 4.07609 6.22283 4.32065 6.65761 4.75543C7.09239 5.19022 7.33696 5.76087 7.33696 6.38587C7.33696 7.01087 7.09239 7.6087 6.63043 8.04348C6.19565 8.45109 5.625 8.69565 5.05435 8.69565C5.02717 8.69565 5.02717 8.69565 5 8.69565C4.42935 8.72283 3.83152 8.47826 3.39674 8.04348C2.96196 7.6087 2.71739 7.01087 2.71739 6.38587C2.71739 5.76087 2.96196 5.19022 3.39674 4.75543ZM7.33696 21.4946C7.33696 21.9293 6.95652 22.2826 6.52174 22.2826H3.53261C3.09783 22.2826 2.71739 21.9022 2.71739 21.4674V11.6848C2.71739 11.2228 3.07065 10.8696 3.50543 10.8696H6.52174C6.95652 10.8696 7.33696 11.25 7.33696 11.6848V21.4946ZM22.2826 21.7391C22.2826 22.0109 22.0109 22.2826 21.7391 22.2826H18.2065C17.9348 22.2826 17.663 22.0109 17.663 21.7391V15.6522C17.663 15.163 17.5543 14.7826 17.2826 14.538C16.9837 14.2391 16.5761 14.0489 16.1413 14.0761C15.2446 14.0761 14.1033 14.837 14.1033 15.6793V21.8207C14.1033 22.1196 13.8043 22.3098 13.5598 22.3098H10.0272C9.78261 22.3098 9.4837 22.1196 9.4837 21.8207V11.3859C9.4837 11.087 9.78261 10.8696 10.0272 10.8696H13.288C13.5598 10.8696 13.8315 11.1413 13.8315 11.413V11.8207C14.5652 11.0598 16.0326 10.5978 17.0924 10.5978H17.663C19.8098 10.5978 22.2826 12.2826 22.2826 14.4565V21.7391Z\" />\n </svg>\n <!-- social-media-instagram -->\n <svg\n *ngIf=\"inputIcon === 'social-media-instagram'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 25 25\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M12.5 0C9.1052 0 8.67952 0.0143895 7.34627 0.0752221C6.01579 0.135956 5.10712 0.347233 4.31198 0.656259C3.48999 0.975705 2.7929 1.40312 2.09798 2.09803C1.40307 2.79294 0.975655 3.49004 0.656209 4.31203C0.347183 5.10712 0.135906 6.01579 0.0751725 7.34627C0.0143398 8.67952 0 9.1052 0 12.5C0 15.8948 0.0143398 16.3205 0.0751725 17.6537C0.135906 18.9842 0.347183 19.8929 0.656209 20.688C0.975655 21.51 1.40307 22.2071 2.09798 22.902C2.7929 23.5969 3.48999 24.0243 4.31198 24.3438C5.10712 24.6528 6.01579 24.8641 7.34627 24.9248C8.67952 24.9856 9.1052 25 12.5 25C15.8948 25 16.3205 24.9856 17.6537 24.9248C18.9842 24.8641 19.8929 24.6528 20.688 24.3438C21.51 24.0243 22.2071 23.5969 22.902 22.902C23.5969 22.2071 24.0243 21.51 24.3438 20.688C24.6528 19.8929 24.8641 18.9842 24.9248 17.6537C24.9856 16.3205 25 15.8948 25 12.5C25 9.1052 24.9856 8.67952 24.9248 7.34627C24.8641 6.01579 24.6528 5.10712 24.3438 4.31203C24.0243 3.49004 23.5969 2.79294 22.902 2.09803C22.2071 1.40312 21.51 0.975705 20.688 0.656259C19.8929 0.347233 18.9842 0.135956 17.6537 0.0752221C16.3205 0.0143895 15.8948 0 12.5 0ZM12.5 2.2523C15.8376 2.2523 16.233 2.265 17.5511 2.32514C18.7698 2.38076 19.4317 2.5844 19.8721 2.75553C20.4556 2.98229 20.872 3.25321 21.3094 3.6906C21.7468 4.12799 22.0177 4.54444 22.2445 5.12786C22.4157 5.56832 22.6193 6.23019 22.6749 7.44893C22.735 8.767 22.7478 9.16236 22.7478 12.5C22.7478 15.8376 22.735 16.233 22.6749 17.5511C22.6193 18.7698 22.4157 19.4317 22.2445 19.8721C22.0177 20.4556 21.7468 20.872 21.3094 21.3094C20.872 21.7468 20.4556 22.0177 19.8721 22.2445C19.4317 22.4157 18.7698 22.6193 17.5511 22.6749C16.2332 22.735 15.8379 22.7478 12.5 22.7478C9.16212 22.7478 8.76685 22.735 7.44893 22.6749C6.23019 22.6193 5.56832 22.4157 5.12786 22.2445C4.54439 22.0177 4.12799 21.7468 3.69055 21.3094C3.25316 20.872 2.98224 20.4556 2.75553 19.8721C2.58435 19.4317 2.38071 18.7698 2.32509 17.5511C2.26495 16.233 2.25225 15.8376 2.25225 12.5C2.25225 9.16236 2.26495 8.767 2.32509 7.44893C2.38071 6.23019 2.58435 5.56832 2.75553 5.12786C2.98224 4.54444 3.25316 4.12799 3.69055 3.6906C4.12799 3.25321 4.54439 2.98229 5.12786 2.75553C5.56832 2.5844 6.23019 2.38076 7.44893 2.32514C8.767 2.265 9.16236 2.2523 12.5 2.2523Z\" />\n <path\n d=\"M12.5 16.6666C10.1988 16.6666 8.3333 14.8012 8.3333 12.5C8.3333 10.1988 10.1988 8.3333 12.5 8.3333C14.8012 8.3333 16.6666 10.1988 16.6666 12.5C16.6666 14.8012 14.8012 16.6666 12.5 16.6666ZM12.5 6.08105C8.95488 6.08105 6.08105 8.95488 6.08105 12.5C6.08105 16.0451 8.95488 18.9189 12.5 18.9189C16.0451 18.9189 18.9189 16.0451 18.9189 12.5C18.9189 8.95488 16.0451 6.08105 12.5 6.08105Z\" />\n <path\n d=\"M20.6726 5.82761C20.6726 6.65605 20.001 7.32759 19.1726 7.32759C18.3442 7.32759 17.6726 6.65605 17.6726 5.82761C17.6726 4.99918 18.3442 4.32764 19.1726 4.32764C20.001 4.32764 20.6726 4.99918 20.6726 5.82761Z\" />\n </svg>\n <!-- social-media-google-mail -->\n <svg\n *ngIf=\"inputIcon === 'social-media-google-mail'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 22 17\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <g clip-path=\"url(#clip0_1282_2376)\">\n <path\n d=\"M0.000141144 15.7966C0.11293 16.0839 0.234306 16.3624 0.46389 16.5802C0.745003 16.8469 1.06848 16.9971 1.45093 16.9982C2.54561 17.0012 3.64028 17.0006 4.73553 17.0006C5.01607 17.0006 5.02466 16.9923 5.02466 16.7033C5.02523 14.0175 5.02523 11.3318 5.02523 8.646C5.02523 8.55181 5.02523 8.45761 5.02523 8.36106C5.13745 8.35282 5.18726 8.42523 5.24623 8.47115C7.09034 9.89116 8.93446 11.3106 10.7728 12.7388C10.9412 12.8695 11.0511 12.863 11.216 12.7353C13.0549 11.3082 14.8991 9.88821 16.7426 8.46762C16.7981 8.42464 16.8577 8.33692 16.9195 8.36342C17.0054 8.39933 16.9607 8.50706 16.9607 8.58242C16.963 11.2682 16.9625 13.9539 16.9625 16.6397C16.9625 16.9976 16.963 16.9982 17.3003 16.9982C18.352 16.9982 19.4043 17.0006 20.456 16.9971C21.3549 16.9941 21.991 16.3336 21.9916 15.4046C21.9927 12.4762 21.9916 9.54734 21.9921 6.61903C21.9933 5.22022 21.9893 3.822 22.0001 2.42378C22.0076 1.45297 21.6017 0.724131 20.7772 0.283176C19.9333 -0.168375 19.0997 -0.0718245 18.3348 0.515134C16.7581 1.72555 15.1859 2.94244 13.612 4.15639C12.8048 4.77867 11.9946 5.39742 11.1937 6.02795C11.0391 6.14922 10.9377 6.14275 10.786 6.025C8.90641 4.56732 7.02221 3.11671 5.13859 1.66491C4.62904 1.27223 4.11777 0.882497 3.6065 0.492173C2.31259 -0.495706 0.49538 0.14777 0.0631199 1.74616C0.0459442 1.80974 0.0213261 1.87038 -0.000429153 1.93278C0.000143051 6.55368 0.000141144 11.1752 0.000141144 15.7966Z\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1282_2376\">\n <rect width=\"22\" height=\"17\" transform=\"matrix(-1 0 0 1 22 0)\" />\n </clipPath>\n </defs>\n </svg>\n <!-- Instant Video Service -->\n <svg\n *ngIf=\"inputIcon === 'instant-video-service'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 80 80\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"m40.2,3.08c-7.13-.08-13,5.67-13.05,12.82-.05,7.01,5.53,12.88,12.7,13.01,7.13.14,13.01-5.56,13.12-12.75.12-7.11-5.61-13-12.77-13.08Zm-.15,21.93c-4.88.04-8.97-4.01-9-8.92-.04-5.01,3.96-9.07,8.97-9.11,4.94-.03,9.03,3.99,9.06,8.9.03,5.07-3.95,9.09-9.03,9.13Z\" />\n <g>\n <g>\n <path\n d=\"m45.29,62.33c.4.41.4,1.06,0,1.46l-4.21,4.2c-.19.19-.45.3-.72.3s-.54-.11-.73-.3l-4.2-4.2c-.4-.4-.4-1.05,0-1.46.4-.4,1.05-.4,1.46,0l3.47,3.48,3.47-3.48c.4-.4,1.05-.4,1.46,0Z\" />\n <path\n d=\"m35.43,59.61c-.4-.4-.4-1.05,0-1.45.4-.4,1.04-.4,1.45,0h.01l3.47,3.48,3.47-3.48h.01c.4-.4,1.04-.4,1.45,0,.4.4.4,1.05,0,1.45l-4.21,4.21c-.2.2-.46.3-.72.3s-.53-.1-.73-.3l-4.2-4.21Z\" />\n <path\n d=\"m66.36,45.57c-.2-1.35-.47-2.69-.94-3.98-.9-2.46-2.37-4.55-4.19-6.41-1.51-1.53-3.2-2.84-5.02-3.98-1.43-.88-2.9-1.67-4.45-2.31-.75-.3-1.63-.13-2.14.47-.72.83-1.61,1.43-2.58,1.92-2.68,1.36-5.52,1.86-8.51,1.57-2.05-.19-4-.77-5.81-1.77-.76-.42-1.49-.9-2.06-1.56-.63-.73-1.43-.96-2.33-.61-.73.28-1.46.57-2.17.91-2.97,1.42-5.61,3.3-7.8,5.77-1.77,1.99-3.1,4.23-3.89,6.77-.69,2.24-.95,4.56-1.1,6.89-.12,1.96-.12,3.92-.04,5.88.04,1.16.87,1.97,2.02,1.97h10.78c-.57,1.58-.89,3.28-.89,5.06,0,8.14,6.62,14.76,14.77,14.76s14.76-6.62,14.76-14.76c0-1.78-.31-3.48-.89-5.06h10.75c1.07,0,1.9-.75,1.97-1.81.07-1.1.12-2.2.13-3.31.03-2.14-.07-4.28-.37-6.41Zm-26.35,27.85c-6.22,0-11.27-5.05-11.27-11.26,0-1.82.43-3.54,1.2-5.06.77-1.53,1.88-2.87,3.24-3.9,1.89-1.45,4.26-2.31,6.83-2.31s4.93.86,6.82,2.31c1.36,1.03,2.47,2.37,3.24,3.9.77,1.52,1.2,3.24,1.2,5.06,0,6.21-5.05,11.26-11.26,11.26Zm22.82-20.43c0,.16-.06.21-.22.21-1.53-.01-3.05,0-4.57,0h-6.31c-2.69-3.53-6.94-5.81-11.72-5.81s-9.04,2.28-11.73,5.81h-11.12c.02-1.02.03-2,.07-2.98.06-1.44.21-2.87.42-4.3.45-3.04,1.72-5.67,3.8-7.93,1.98-2.15,4.36-3.75,7.02-4.94.08-.04.15-.07.25.01,1.89,1.55,4.06,2.54,6.41,3.14,4.48,1.14,8.85.77,13.06-1.14,1.12-.51,2.17-1.13,3.12-1.92.11-.09.2-.09.33-.03,2.15,1.08,4.16,2.37,5.95,3.99,1.58,1.42,2.91,3.03,3.81,4.97.5,1.08.79,2.22.99,3.39.38,2.25.47,4.53.44,6.81,0,.24-.01.48,0,.72Z\" />\n </g>\n <path\n d=\"m45.29,63.79l-4.21,4.2c-.19.19-.45.3-.72.3s-.54-.11-.73-.3l-4.2-4.2c-.4-.4-.4-1.05,0-1.46.4-.4,1.05-.4,1.46,0l3.47,3.48,3.47-3.48c.4-.4,1.05-.4,1.46,0,.4.41.4,1.06,0,1.46Z\" />\n <path\n d=\"m45.29,59.61l-4.21,4.21c-.2.2-.46.3-.72.3s-.53-.1-.73-.3l-4.2-4.21c-.4-.4-.4-1.05,0-1.45.4-.4,1.04-.4,1.45,0h.01l3.47,3.48,3.47-3.48h.01c.4-.4,1.04-.4,1.45,0,.4.4.4,1.05,0,1.45Z\" />\n </g>\n </svg>\n <!-- Instant Telephonic Service -->\n <svg\n *ngIf=\"inputIcon === 'instant-telephonic-service'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 80 80\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <g>\n <path\n d=\"m62.18,23.77c-.04-.46-.08-.93-.13-1.39-.04-.32-.09-.64-.14-.95-.68-3.53-2.34-6.52-5-8.94-2.04-1.85-4.4-3.08-7.08-3.71-1.2-.28-2.41-.41-3.65-.41-.92,0-1.62.76-1.55,1.66.07.84.74,1.42,1.63,1.45.64.02,1.27.05,1.89.14,2.86.44,5.31,1.72,7.33,3.81,1.5,1.56,2.55,3.4,3.13,5.49.32,1.13.46,2.29.47,3.45,0,.83.61,1.46,1.44,1.53.75.08,1.48-.47,1.62-1.25.05-.28,0-.58,0-.88h.04Z\" />\n <path\n d=\"m54.95,24.18c.03.7-.23,1.24-.84,1.55-.57.29-1.12.23-1.64-.15-.34-.25-.57-.59-.59-1.01-.03-.65-.25-1.23-.55-1.79-.78-1.43-1.81-2.63-3.21-3.49-.62-.38-1.29-.61-2.04-.62-.8-.02-1.46-.76-1.44-1.57.02-.84.7-1.52,1.54-1.52,1.11,0,2.14.3,3.11.82,2.07,1.11,3.59,2.78,4.73,4.82.44.79.77,1.63.9,2.54.02.15.03.29.04.42Z\" />\n </g>\n <g>\n <g>\n <path\n d=\"m43.17,57.56c.39.4.39,1.02,0,1.41l-4.06,4.05c-.18.18-.43.29-.69.29s-.52-.11-.7-.29l-4.05-4.05c-.39-.39-.39-1.01,0-1.41.39-.39,1.01-.39,1.41,0l3.35,3.36,3.35-3.36c.39-.39,1.01-.39,1.41,0Z\" />\n <path\n d=\"m33.66,54.94c-.39-.39-.39-1.01,0-1.4.39-.39,1-.39,1.4,0h0l3.35,3.36,3.35-3.36h0c.39-.39,1-.39,1.4,0,.39.39.39,1.01,0,1.4l-4.06,4.06c-.19.19-.44.29-.69.29s-.51-.1-.7-.29l-4.05-4.06Z\" />\n <path\n d=\"m59.99,39.41c-2.01-1.41-4-2.84-6.01-4.25-.73-.53-1.47-1.06-2.3-1.44-.92-.42-1.86-.62-2.86-.43-.91.16-1.71.59-2.39,1.18-.77.66-1.49,1.39-2.21,2.08-.1.09-.16.11-.26.05-.25-.16-.51-.31-.75-.47-1.03-.7-1.96-1.54-2.88-2.38-1.8-1.63-3.47-3.39-5.03-5.25-.5-.61-.93-1.26-1.39-1.9-.1-.14-.08-.23.05-.36.41-.41.8-.83,1.21-1.24.54-.55,1.03-1.13,1.43-1.79.7-1.16.87-2.38.45-3.67-.25-.77-.65-1.48-1.12-2.14-1.6-2.26-3.2-4.51-4.8-6.77-.67-.95-1.54-1.6-2.63-1.96-1.5-.48-2.96-.32-4.4.26-1.06.43-1.96,1.12-2.78,1.92-1.32,1.28-2.3,2.78-2.87,4.52-.67,1.98-.75,4.01-.48,6.07.24,1.83.77,3.6,1.5,5.3.89,2.06,1.98,4.02,3.23,5.87,2.38,3.55,5.16,6.76,8.29,9.67.67.63,1.34,1.23,2.04,1.82-5.36,2.04-9.17,7.23-9.17,13.31,0,7.85,6.39,14.24,14.25,14.24s14.24-6.39,14.24-14.24c0-1.64-.28-3.21-.78-4.67.55-.04,1.1-.07,1.64-.15,2.93-.44,5.3-1.85,7.13-4.18,1.04-1.34,1.77-2.83,1.8-4.56.04-1.82-.58-3.34-2.11-4.43Zm-21.91,28.85c-6,0-10.87-4.87-10.87-10.86,0-5.38,3.93-9.86,9.07-10.72.59-.11,1.19-.15,1.8-.15,4.17,0,7.78,2.35,9.61,5.81.8,1.51,1.25,3.23,1.25,5.06,0,5.99-4.87,10.86-10.86,10.86Zm20.01-22.08c-1.38,1.94-3.26,3.08-5.62,3.38-.84.11-1.68.11-2.5.02-2.55-3.87-6.93-6.42-11.89-6.42-.41,0-.83.02-1.24.06-.68-.52-1.33-1.07-1.99-1.63-1.54-1.31-3.01-2.7-4.38-4.19-2.64-2.86-5.04-5.89-6.92-9.32-.86-1.57-1.6-3.19-2.08-4.92-.35-1.25-.56-2.53-.56-3.83,0-1.66.35-3.23,1.23-4.65.71-1.14,1.62-2.1,2.82-2.75.78-.42,1.61-.6,2.49-.37.46.13.84.4,1.12.79,1.61,2.27,3.22,4.53,4.82,6.81.27.38.47.81.68,1.23.19.4.15.8-.11,1.16-.27.39-.54.76-.85,1.1-.55.6-1.14,1.16-1.69,1.76-.79.86-.91,1.87-.55,2.94.3.9.88,1.64,1.46,2.37,1.44,1.83,3.03,3.55,4.71,5.17,1.16,1.12,2.34,2.22,3.63,3.2.69.53,1.41,1.01,2.19,1.4.99.48,2.4.44,3.4-.6.59-.62,1.22-1.22,1.85-1.8.26-.24.59-.43.91-.63.3-.19.64-.2.97-.1.58.18,1.08.5,1.57.85,2.2,1.56,4.38,3.13,6.59,4.67.7.49.92,1.16.87,1.95-.05.88-.42,1.64-.92,2.34Z\" />\n </g>\n <path\n d=\"m43.17,58.97l-4.06,4.05c-.18.18-.43.29-.69.29s-.52-.11-.7-.29l-4.05-4.05c-.39-.39-.39-1.01,0-1.41.39-.39,1.01-.39,1.41,0l3.35,3.36,3.35-3.36c.39-.39,1.01-.39,1.41,0,.39.4.39,1.02,0,1.41Z\" />\n <path\n d=\"m43.17,54.94l-4.06,4.06c-.19.19-.44.29-.69.29s-.51-.1-.7-.29l-4.05-4.06c-.39-.39-.39-1.01,0-1.4.39-.39,1-.39,1.4,0h0l3.35,3.36,3.35-3.36h0c.39-.39,1-.39,1.4,0,.39.39.39,1.01,0,1.4Z\" />\n </g>\n </svg>\n <!-- Scheduled Video Service -->\n <svg\n *ngIf=\"inputIcon === 'scheduled-video-service'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 80 80\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"m40.2,2.31c-7.34-.09-13.37,5.83-13.43,13.19-.05,7.2,5.69,13.24,13.07,13.38,7.33.14,13.38-5.73,13.49-13.12.12-7.32-5.77-13.38-13.13-13.45Zm-.16,22.55c-5.02.04-9.22-4.12-9.26-9.17-.04-5.15,4.08-9.34,9.23-9.37,5.08-.03,9.29,4.1,9.32,9.15.03,5.21-4.06,9.35-9.29,9.39Z\" />\n <g>\n <path\n d=\"m67.1,46.01c-.2-1.39-.48-2.77-.97-4.1-.92-2.52-2.43-4.67-4.3-6.58-1.55-1.58-3.3-2.92-5.17-4.1-1.46-.91-2.98-1.72-4.58-2.37-.77-.32-1.67-.14-2.19.47-.75.86-1.66,1.48-2.66,1.98-2.76,1.4-5.68,1.91-8.75,1.62-2.12-.2-4.12-.79-5.98-1.82-.78-.44-1.53-.93-2.12-1.61-.65-.75-1.47-.99-2.39-.63-.75.29-1.51.59-2.24.94-3.05,1.47-5.76,3.4-8.02,5.94-1.82,2.04-3.19,4.34-4,6.96-.71,2.31-.98,4.69-1.13,7.08-.12,2.02-.13,4.04-.05,6.06.05,1.18.9,2.02,2.08,2.02h11.53c-.57,1.58-.89,3.28-.89,5.06,0,8.14,6.63,14.76,14.77,14.76s14.76-6.62,14.76-14.76c0-1.78-.31-3.48-.89-5.06h11.41c1.1,0,1.96-.77,2.03-1.86.08-1.14.12-2.27.14-3.4.03-2.21-.07-4.41-.39-6.6Zm-27.06,28.18c-6.21,0-11.27-5.05-11.27-11.26,0-1.82.43-3.54,1.2-5.06.8-1.59,1.97-2.97,3.4-4.01,1.87-1.39,4.17-2.2,6.67-2.2s4.81.82,6.68,2.2c1.42,1.05,2.58,2.42,3.38,4.01.77,1.52,1.2,3.24,1.2,5.06,0,6.21-5.05,11.26-11.26,11.26Zm23.43-20.55c0,.17-.06.22-.23.22-1.56-.01-3.13,0-4.7,0h-6.86c-2.7-3.47-6.91-5.7-11.64-5.7s-8.94,2.23-11.64,5.7h-11.91c.03-1.05.03-2.06.08-3.07.06-1.48.21-2.95.43-4.42.46-3.13,1.77-5.83,3.91-8.15,2.04-2.22,4.48-3.86,7.22-5.09.09-.04.15-.07.25.01,1.95,1.6,4.18,2.62,6.61,3.23,4.6,1.17,9.09.79,13.43-1.17,1.15-.52,2.22-1.17,3.2-1.97.12-.1.2-.1.34-.03,2.22,1.1,4.28,2.44,6.12,4.1,1.63,1.46,3,3.11,3.92,5.11.52,1.11.82,2.29,1.02,3.49.39,2.32.48,4.65.46,7-.01.25-.02.49-.01.74Z\" />\n <path\n d=\"m45.97,63.99c0,.56-.44,1-1,1h-5.99c-.55,0-1-.44-1-1,0-.03,0-.07.01-.1-.01-.03-.01-.07-.01-.11v-7.27c0-.56.45-1,1-1s1,.44,1,1v6.48h4.99c.56,0,1,.45,1,1Z\" />\n </g>\n </svg>\n <!-- Scheduled Telephonic Service -->\n <svg\n *ngIf=\"inputIcon === 'scheduled-telephonic-service'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 80 80\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <g>\n <path\n d=\"m62.18,23.77c-.04-.46-.08-.93-.13-1.39-.04-.32-.09-.64-.14-.95-.68-3.53-2.34-6.52-5-8.94-2.04-1.85-4.4-3.08-7.08-3.71-1.2-.28-2.41-.41-3.65-.41-.92,0-1.62.76-1.55,1.66.07.84.74,1.42,1.63,1.45.64.02,1.27.05,1.89.14,2.86.44,5.31,1.72,7.33,3.81,1.5,1.56,2.55,3.4,3.13,5.49.32,1.13.46,2.29.47,3.45,0,.83.61,1.46,1.44,1.53.75.08,1.48-.47,1.62-1.25.05-.28,0-.58,0-.88h.04Z\" />\n <path\n d=\"m54.95,24.18c.03.7-.23,1.24-.84,1.55-.57.29-1.12.23-1.64-.15-.34-.25-.57-.59-.59-1.01-.03-.65-.25-1.23-.55-1.79-.78-1.43-1.81-2.63-3.21-3.49-.62-.38-1.29-.61-2.04-.62-.8-.02-1.46-.76-1.44-1.57.02-.84.7-1.52,1.54-1.52,1.11,0,2.14.3,3.11.82,2.07,1.11,3.59,2.78,4.73,4.82.44.79.77,1.63.9,2.54.02.15.03.29.04.42Z\" />\n </g>\n <g>\n <path\n d=\"m59.99,39.41c-2.01-1.41-4-2.84-6.01-4.25-.73-.53-1.47-1.06-2.3-1.44-.92-.42-1.86-.62-2.86-.43-.91.16-1.71.59-2.39,1.18-.77.66-1.49,1.39-2.21,2.08-.1.09-.16.11-.26.05-.25-.16-.51-.31-.75-.47-1.03-.7-1.96-1.54-2.88-2.38-1.8-1.63-3.47-3.39-5.03-5.25-.5-.61-.93-1.26-1.39-1.9-.1-.14-.08-.23.05-.36.41-.41.8-.83,1.21-1.24.54-.55,1.03-1.13,1.43-1.79.7-1.16.87-2.38.45-3.67-.25-.77-.65-1.48-1.12-2.14-1.6-2.26-3.2-4.51-4.8-6.77-.67-.95-1.54-1.6-2.63-1.96-1.5-.48-2.96-.32-4.4.26-1.06.43-1.96,1.12-2.78,1.92-1.32,1.28-2.3,2.78-2.87,4.52-.67,1.98-.75,4.01-.48,6.07.24,1.83.77,3.6,1.5,5.3.89,2.06,1.98,4.02,3.23,5.87,2.38,3.55,5.16,6.76,8.29,9.67.68.63,1.36,1.24,2.05,1.83-5.34,2.05-9.15,7.23-9.15,13.3,0,7.85,6.39,14.24,14.25,14.24s14.24-6.39,14.24-14.24c0-1.64-.28-3.21-.79-4.67.54-.04,1.08-.07,1.61-.15,2.93-.44,5.3-1.85,7.13-4.18,1.04-1.34,1.77-2.83,1.8-4.56.04-1.82-.58-3.34-2.11-4.43Zm-21.88,28.85c-5.99,0-10.87-4.87-10.87-10.86,0-5.37,3.92-9.84,9.04-10.72.59-.11,1.21-.15,1.83-.15,4.17,0,7.79,2.36,9.62,5.82.79,1.51,1.24,3.23,1.24,5.05,0,5.99-4.87,10.86-10.86,10.86Zm19.98-22.08c-1.38,1.94-3.26,3.08-5.62,3.38-.83.11-1.64.11-2.45.02-2.56-3.87-6.93-6.42-11.9-6.42-.43,0-.86.02-1.28.07-.68-.53-1.33-1.08-1.99-1.64-1.54-1.31-3.01-2.7-4.38-4.19-2.64-2.86-5.04-5.89-6.92-9.32-.86-1.57-1.6-3.19-2.08-4.92-.35-1.25-.56-2.53-.56-3.83,0-1.66.35-3.23,1.23-4.65.71-1.14,1.62-2.1,2.82-2.75.78-.42,1.61-.6,2.49-.37.46.13.84.4,1.12.79,1.61,2.27,3.22,4.53,4.82,6.81.27.38.47.81.68,1.23.19.4.15.8-.11,1.16-.27.39-.54.76-.85,1.1-.55.6-1.14,1.16-1.69,1.76-.79.86-.91,1.87-.55,2.94.3.9.88,1.64,1.46,2.37,1.44,1.83,3.03,3.55,4.71,5.17,1.16,1.12,2.34,2.22,3.63,3.2.69.53,1.41,1.01,2.19,1.4.99.48,2.4.44,3.4-.6.59-.62,1.22-1.22,1.85-1.8.26-.24.59-.43.91-.63.3-.19.64-.2.97-.1.58.18,1.08.5,1.57.85,2.2,1.56,4.38,3.13,6.59,4.67.7.49.92,1.16.87,1.95-.05.88-.42,1.64-.92,2.34Z\" />\n <path\n d=\"m43.84,58.42c0,.54-.42.96-.96.96h-5.78c-.53,0-.96-.42-.96-.96,0-.03,0-.07,0-.1,0-.03,0-.07,0-.11v-7.01c0-.54.43-.96.96-.96s.96.42.96.96v6.25h4.81c.54,0,.96.43.96.96Z\" />\n </g>\n </svg>\n <!-- Vital Scan Service -->\n <svg\n *ngIf=\"inputIcon === 'vital-scan-service'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 80 80\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <g>\n <path\n d=\"m69.5,31c-1.38,0-2.5-1.12-2.5-2.5v-13.5s-13.5,0-13.5,0h0c-1.38,0-2.5-1.12-2.5-2.5s1.12-2.5,2.5-2.5h16s0,0,0,0h0c1.38,0,2.5,1.12,2.5,2.5,0,.03,0,.06,0,.09v15.91c0,1.38-1.12,2.5-2.5,2.5h0Z\" />\n <path\n d=\"m69.5,70h-16c-1.38,0-2.5-1.12-2.5-2.5s1.12-2.5,2.5-2.5h13.5s0-13.5,0-13.5c0-1.38,1.12-2.5,2.5-2.5h0c1.38,0,2.5,1.12,2.5,2.5v15.88s0,.08,0,.12c0,1.38-1.12,2.5-2.5,2.5Z\" />\n <path\n d=\"m10.5,49c1.38,0,2.5,1.12,2.5,2.5v13.5s13.5,0,13.5,0h0c1.38,0,2.5,1.12,2.5,2.5s-1.12,2.5-2.5,2.5h-16s0,0,0,0h0c-1.38,0-2.5-1.12-2.5-2.5,0-.03,0-.06,0-.09v-15.91c0-1.38,1.12-2.5,2.5-2.5h0Z\" />\n <path\n d=\"m10.5,10h16c1.38,0,2.5,1.12,2.5,2.5s-1.12,2.5-2.5,2.5h-13.5s0,13.5,0,13.5c0,1.38-1.12,2.5-2.5,2.5h0c-1.38,0-2.5-1.12-2.5-2.5v-15.88s0-.08,0-.12c0-1.38,1.12-2.5,2.5-2.5Z\" />\n </g>\n <path\n d=\"m66.91,41.79c0,.99-.83,1.79-1.85,1.79h0s-7.04,0-7.04,0c-1.08,0-2.17-.03-3.25,0-1.07.04-1.76-.42-2.2-1.38-.38-.83-.82-1.63-1.37-2.72-.87,2.89-1.65,5.48-2.43,8.06-.53,1.75-1.06,3.5-1.57,5.25-.27.92-.83,1.54-1.82,1.52-1.05-.02-1.57-.68-1.79-1.68-1.18-5.51-2.37-11.02-3.55-16.53-.04-.17-.09-.33-.22-.84-.22.66-.35,1.02-.46,1.38-.97,3.53-1.94,7.05-2.89,10.58-.26.97-.74,1.67-1.79,1.7-1.12.03-1.62-.7-1.9-1.71-.61-2.23-1.27-4.45-1.92-6.67-.07-.24-.17-.47-.32-.91-.52,1.03-.87,1.93-1.41,2.7-.35.5-.97,1.14-1.49,1.16-4.15.09-8.31.05-12.52.05-.06,0-.13,0-.19,0-1.02,0-1.85-.8-1.85-1.79s.83-1.79,1.85-1.79h0s1.17,0,1.17,0c3.1,0,6.2-.02,9.31.02.7,0,1.07-.22,1.36-.85.79-1.69,1.66-3.34,2.48-5.02.41-.85.98-1.43,1.99-1.31.94.11,1.38.75,1.62,1.63.51,1.87,1.07,3.73,1.7,5.92.22-.72.37-1.14.49-1.58,1.05-3.81,2.1-7.63,3.12-11.45.27-1.02.77-1.74,1.89-1.7,1.11.04,1.57.79,1.79,1.82,1.16,5.48,2.35,10.95,3.53,16.42.08.36.17.71.32,1.34,1.07-3.54,2.05-6.82,3.04-10.1.11-.36.2-.77.34-1.05.3-.59,1.01-1.14,1.56-1.18.55-.04,1.39.44,1.69.94,1,1.7,1.85,3.5,2.68,5.29.32.69.72.89,1.45.88,2.83-.05,5.67-.02,8.58-.02h0s0,0,0,0c1.02,0,1.85.8,1.85,1.79Z\" />\n </svg>\n <!-- open-back-arrow -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'open-back-arrow'\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M14 3 L6 10 L14 17\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- open-forward-arrow -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'open-forward-arrow'\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M6 3 L14 10 L6 17\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- open-up-arrow -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'open-up-arrow'\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M3 14 L10 6 L17 14\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- open-down-arrow -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'open-down-arrow'\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M3 6 L10 14 L17 6\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- Single Document -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'single-document'\" viewBox=\"0 0 18 22\" fill=\"none\">\n <path\n d=\"M11 1H2.5C1.67157 1 1 1.67157 1 2.5V19.5C1 20.3284 1.67157 21 2.5 21H15.5C16.3284 21 17 20.3284 17 19.5V7M11 1L17 7M11 1V5.5C11 6.32843 11.6716 7 12.5 7H17M4 14H12M4 17H9\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- Lightning -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'lightning'\" viewBox=\"0 0 14 22\" fill=\"none\">\n <path\n d=\"M1.23099 11.6824L8.99999 1V10H12.6072C12.7707 10 12.8651 10.1854 12.769 10.3176L4.99999 21V12H1.39274C1.22928 12 1.13485 11.8146 1.23099 11.6824Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- Microsoft 365 -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'microsoft-365'\" fill=\"none\" viewBox=\"4 2 40 44\" style=\"stroke: none\">\n <path\n d=\"M20.0842 3.02588L19.8595 3.16179C19.5021 3.37799 19.1654 3.61972 18.8512 3.88385L19.4993 3.42798H25L26 11L21 16L16 19.4754V23.4829C16 26.2819 17.4629 28.8774 19.8574 30.3268L25.1211 33.5129L14 40.0002H11.8551L7.85737 37.5804C5.46286 36.131 4 33.5355 4 30.7365V17.2606C4 14.4607 5.46379 11.8645 7.85952 10.4154L19.8595 3.15687C19.9339 3.11189 20.0088 3.06823 20.0842 3.02588Z\"\n fill=\"url(#paint0_radial_2994_8373)\" />\n <path\n d=\"M20.0842 3.02588L19.8595 3.16179C19.5021 3.37799 19.1654 3.61972 18.8512 3.88385L19.4993 3.42798H25L26 11L21 16L16 19.4754V23.4829C16 26.2819 17.4629 28.8774 19.8574 30.3268L25.1211 33.5129L14 40.0002H11.8551L7.85737 37.5804C5.46286 36.131 4 33.5355 4 30.7365V17.2606C4 14.4607 5.46379 11.8645 7.85952 10.4154L19.8595 3.15687C19.9339 3.11189 20.0088 3.06823 20.0842 3.02588Z\"\n fill=\"url(#paint1_linear_2994_8373)\" />\n <path\n d=\"M32 19V23.4803C32 26.2793 30.5371 28.8748 28.1426 30.3242L16.1426 37.5878C13.6878 39.0737 10.6335 39.1273 8.1355 37.7487L19.8573 44.844C22.4039 46.3855 25.5959 46.3855 28.1426 44.844L40.1426 37.5803C42.5371 36.1309 43.9999 33.5354 43.9999 30.7364V27.5L42.9999 26L32 19Z\"\n fill=\"url(#paint2_radial_2994_8373)\" />\n <path\n d=\"M32 19V23.4803C32 26.2793 30.5371 28.8748 28.1426 30.3242L16.1426 37.5878C13.6878 39.0737 10.6335 39.1273 8.1355 37.7487L19.8573 44.844C22.4039 46.3855 25.5959 46.3855 28.1426 44.844L40.1426 37.5803C42.5371 36.1309 43.9999 33.5354 43.9999 30.7364V27.5L42.9999 26L32 19Z\"\n fill=\"url(#paint3_linear_2994_8373)\" />\n <path\n d=\"M40.1405 10.4153L28.1405 3.15678C25.6738 1.66471 22.6021 1.61849 20.0979 3.01811L19.8595 3.16231C17.4638 4.61143 16 7.20757 16 10.0075V19.4914L19.8595 17.1568C22.4051 15.6171 25.5949 15.6171 28.1405 17.1568L40.1405 24.4153C42.4613 25.8192 43.9076 28.2994 43.9957 30.9985C43.9986 30.9113 44 30.824 44 30.7364V17.2605C44 14.4606 42.5362 11.8644 40.1405 10.4153Z\"\n fill=\"url(#paint4_radial_2994_8373)\" />\n <path\n d=\"M40.1405 10.4153L28.1405 3.15678C25.6738 1.66471 22.6021 1.61849 20.0979 3.01811L19.8595 3.16231C17.4638 4.61143 16 7.20757 16 10.0075V19.4914L19.8595 17.1568C22.4051 15.6171 25.5949 15.6171 28.1405 17.1568L40.1405 24.4153C42.4613 25.8192 43.9076 28.2994 43.9957 30.9985C43.9986 30.9113 44 30.824 44 30.7364V17.2605C44 14.4606 42.5362 11.8644 40.1405 10.4153Z\"\n fill=\"url(#paint5_linear_2994_8373)\" />\n <path d=\"M4.00428 30.9984C4.00428 30.9984 4.00428 30.9984 4.00428 30.9984Z\" fill=\"url(#paint6_radial_2994_8373)\" />\n <path d=\"M4.00428 30.9984C4.00428 30.9984 4.00428 30.9984 4.00428 30.9984Z\" fill=\"url(#paint7_linear_2994_8373)\" />\n <defs>\n <radialGradient\n id=\"paint0_radial_2994_8373\"\n cx=\"0\"\n cy=\"0\"\n r=\"1\"\n gradientUnits=\"userSpaceOnUse\"\n gradientTransform=\"translate(17.4186 10.6383) rotate(110.528) scale(33.3657 58.1966)\">\n <stop offset=\"0.06441\" stop-color=\"#AE7FE2\" />\n <stop offset=\"1\" stop-color=\"#0078D4\" />\n </radialGradient>\n <linearGradient id=\"paint1_linear_2994_8373\" x1=\"17.5119\" y1=\"37.8685\" x2=\"12.7513\" y2=\"29.6347\" gradientUnits=\"userSpaceOnUse\">\n <stop offset=\"0\" stop-color=\"#114A8B\" />\n <stop offset=\"1\" stop-color=\"#0078D4\" stop-opacity=\"0\" />\n </linearGradient>\n <radialGradient\n id=\"paint2_radial_2994_8373\"\n cx=\"0\"\n cy=\"0\"\n r=\"1\"\n gradientUnits=\"userSpaceOnUse\"\n gradientTransform=\"translate(10.4299 36.3511) rotate(-8.36717) scale(31.0503 20.5108)\">\n <stop offset=\"0.133928\" stop-color=\"#D59DFF\" />\n <stop offset=\"1\" stop-color=\"#5E438F\" />\n </radialGradient>\n <linearGradient id=\"paint3_linear_2994_8373\" x1=\"40.3566\" y1=\"25.3768\" x2=\"35.2552\" y2=\"32.6916\" gradientUnits=\"userSpaceOnUse\">\n <stop offset=\"0\" stop-color=\"#493474\" />\n <stop offset=\"1\" stop-color=\"#8C66BA\" stop-opacity=\"0\" />\n </linearGradient>\n <radialGradient\n id=\"paint4_radial_2994_8373\"\n cx=\"0\"\n cy=\"0\"\n r=\"1\"\n gradientUnits=\"userSpaceOnUse\"\n gradientTransform=\"translate(41.0552 26.504) rotate(-165.772) scale(24.9228 41.9552)\">\n <stop offset=\"0.0584996\" stop-color=\"#50E6FF\" />\n <stop offset=\"1\" stop-color=\"#436DCD\" />\n </radialGradient>\n <linearGradient id=\"paint5_linear_2994_8373\" x1=\"16.9758\" y1=\"3.05655\" x2=\"24.4868\" y2=\"3.05655\" gradientUnits=\"userSpaceOnUse\">\n <stop offset=\"0\" stop-color=\"#2D3F80\" />\n <stop offset=\"1\" stop-color=\"#436DCD\" stop-opacity=\"0\" />\n </linearGradient>\n <radialGradient\n id=\"paint6_radial_2994_8373\"\n cx=\"0\"\n cy=\"0\"\n r=\"1\"\n gradientUnits=\"userSpaceOnUse\"\n gradientTransform=\"translate(41.0552 26.504) rotate(-165.772) scale(24.9228 41.9552)\">\n <stop offset=\"0.0584996\" stop-color=\"#50E6FF\" />\n <stop offset=\"1\" stop-color=\"#436DCD\" />\n </radialGradient>\n <linearGradient id=\"paint7_linear_2994_8373\" x1=\"16.9758\" y1=\"3.05655\" x2=\"24.4868\" y2=\"3.05655\" gradientUnits=\"userSpaceOnUse\">\n <stop offset=\"0\" stop-color=\"#2D3F80\" />\n <stop offset=\"1\" stop-color=\"#436DCD\" stop-opacity=\"0\" />\n </linearGradient>\n </defs>\n </svg>\n <!-- user-dependent -->\n <svg *ngIf=\"icon === 'user-dependent'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 23 23\" fill=\"none\">\n <path\n d=\"M15.65 20.2C15.65 17.87 13.33 15.97 10.46 15.97C7.59 15.97 5.27 17.86 5.27 20.2M14.2 3.73999C13.06 3.25999 11.81 3 10.5 3C5.25 3 1 7.25 1 12.5C1 17.75 5.25 22 10.5 22C15.75 22 20 17.75 20 12.5C20 11.19 19.73 9.92998 19.25 8.78998M14.2 3.73999C14.07 4.13999 14 4.56 14 5C14 5.75 14.21 6.46 14.58 7.06C14.78 7.4 15.04 7.70997 15.34 7.96997C16.04 8.60997 16.97 9 18 9C18.44 9 18.86 8.92998 19.25 8.78998M14.2 3.73999C14.39 3.15999 14.71 2.64002 15.13 2.21002C15.86 1.46002 16.88 1 18 1C19.18 1 20.25 1.51002 20.97 2.33002C21.61 3.04002 22 3.98 22 5C22 5.32 21.96 5.62999 21.88 5.92999C21.79 6.32999 21.63 6.72 21.42 7.06C20.94 7.87 20.17 8.49998 19.25 8.78998M19.49 4.97998H16.51M18 3.52002V6.51001M13.27 10.92C13.27 12.4719 12.0119 13.73 10.46 13.73C8.90808 13.73 7.65 12.4719 7.65 10.92C7.65 9.36806 8.90808 8.10999 10.46 8.10999C12.0119 8.10999 13.27 9.36806 13.27 10.92Z\"\n stroke-width=\"1.5\"\n stroke-miterlimit=\"10\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- plus -->\n <svg *ngIf=\"icon === 'plus'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 15 14\" fill=\"none\">\n <path d=\"M1.52881 6.99686H13.5069M7.51786 12.9859V1.00781\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n</div>\n","/**\n * CareFirst Library - Button\n *\n * @file button.component\n * @description Contains all the logic for generating a CareFirst Button\n * @author Jacques Coetzee\n * @since 2023 - 11 - 07\n * @usage <cf-btn type=\"'primary' | 'secondary' | 'tertiary'\" fontSize=\"'small' | 'large'\" %customColor=\"var() | hex\"% %disabled% %alert% %action% %snug%>TEXT</cf-btn>\n */\n\nimport { Component, Input, type SimpleChanges, type OnChanges, HostBinding } from '@angular/core';\nimport { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';\nimport { iconsC, type IconsT } from '../../interfaces/icon.interface';\n\n@Component({\n selector: 'cf-btn',\n templateUrl: './button.component.html',\n styleUrls: ['./button.component.scss'],\n})\nexport class ButtonComponent implements OnChanges {\n @Input() type: 'primary' | 'secondary' | 'tertiary' = 'primary';\n @Input() disabled?: boolean | string | undefined;\n @Input() alert?: boolean | string | undefined;\n @Input() action?: boolean | string | undefined;\n @Input() snug?: boolean | string | undefined;\n @Input() accent?: boolean | string | undefined;\n @Input() fontSize?: 'small' | 'large';\n @Input() iconStart?: IconsT | undefined;\n @Input() iconEnd?: IconsT | undefined;\n @Input() loading?: boolean | string | undefined;\n @Input() customColor?: string | undefined;\n\n @HostBinding('style.pointer-events') get parentEvents(): string {\n if (this.disabled) {\n return 'none';\n }\n return 'auto';\n }\n\n //--- Local variables\n inputType: typeof this.type = 'primary';\n inputFontSize: typeof this.fontSize | undefined = undefined;\n inputDisabled = false;\n inputAlert = false;\n inputAction = false;\n inputSnug = false;\n inputAccent = false;\n inputIconStart: typeof this.iconStart | undefined = undefined;\n inputIconEnd: typeof this.iconEnd | undefined = undefined;\n inputLoading = false;\n inputCustomColor = '';\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Type\n this.inputType =\n validateStringValue<'primary' | 'secondary' | 'tertiary'>(changes, 'type', ['primary', 'secondary', 'tertiary'], this.inputType) || 'primary';\n //--- Font Size\n this.inputFontSize = validateStringValue<'small' | 'large'>(changes, 'fontSize', ['small', 'large'], this.inputFontSize);\n //--- Disabled\n this.inputDisabled = checkTruthAttribute(changes, 'disabled', this.inputDisabled);\n //--- Alert\n this.inputAlert = checkTruthAttribute(changes, 'alert', this.inputAlert);\n //--- Action\n this.inputAction = checkTruthAttribute(changes, 'action', this.inputAction);\n //--- Snug\n this.inputSnug = checkTruthAttribute(changes, 'snug', this.inputSnug);\n //--- Accent\n this.inputAccent = checkTruthAttribute(changes, 'accent', this.inputAccent);\n //--- Icon Start\n this.inputIconStart = validateStringValue<IconsT>(changes, 'iconStart', iconsC.slice(), this.inputIconStart);\n //--- Icon Start\n this.inputIconEnd = validateStringValue<IconsT>(changes, 'iconEnd', iconsC.slice(), this.inputIconEnd);\n //--- Loading\n this.inputLoading = checkTruthAttribute(changes, 'loading', this.inputLoading);\n //--- Custom color\n if (changes['customColor']?.currentValue) this.inputCustomColor = this.checkCustomColor(changes['customColor'].currentValue);\n }\n\n /**----------------------------------------------------------------\n * @name checkCustomColor\n * @description Check if the custom color is valid\n * @param {string} color\n * @returns {string}\n */\n checkCustomColor(color: string): string {\n //--- Check for a css variable\n if (color.startsWith('var')) return color;\n //--- Check hex\n if (color.startsWith('#') && (color.length === 4 || color.length === 7) && color.split('').every((char) => char.match(/[#0-9a-fA-F]+/)))\n return color;\n return '';\n }\n}\n","<ion-button\n [style]=\"'--custom-color: ' + inputCustomColor\"\n [ngClass]=\"{\n 'cf-button-primary': inputType === 'primary',\n 'cf-button-secondary': inputType === 'secondary',\n 'cf-button-tertiary': inputType === 'tertiary',\n 'text-large': inputFontSize === 'large',\n 'text-small': inputFontSize === 'small',\n alert: inputAlert,\n action: inputAction,\n snug: inputSnug,\n accent: inputAccent\n }\"\n mode=\"md\"\n [disabled]=\"inputDisabled\">\n <cf-icon *ngIf=\"inputIconStart\" [icon]=\"inputIconStart\" style=\"--cf-svg-overwrite-stroke-color: var(--button-text-color)\"></cf-icon>\n <p *cfButtonLoader=\"inputLoading\">\n <ng-content></ng-content>\n </p>\n <cf-icon *ngIf=\"inputIconEnd\" [icon]=\"inputIconEnd\" style=\"--cf-svg-overwrite-stroke-color: var(--button-text-color)\"></cf-icon>\n</ion-button>\n","/**\n * CareFirst Library - Spacer\n *\n * @file spacer.component\n * @description Contains all the logic for generating a CareFirst Div Spacer\n * @author Jacques Coetzee\n * @since 2023 - 11 - 07\n * @usage <cf-spacer %default=\"\"% %mobile=\"\"% %desktop=\"\"%>CONTENT</cf-spacer>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\nimport { validateNumberValue } from '../../utils/attribute.util';\nimport type { SpacerNumberT, SpacerStringT } from '../../interfaces/spacer.interface';\n\n@Component({\n selector: 'cf-spacer',\n templateUrl: './spacer.component.html',\n styleUrls: ['./spacer.component.scss'],\n})\nexport class SpacerComponent implements OnChanges {\n @Input() default?: SpacerStringT | SpacerNumberT | undefined;\n @Input() mobile?: SpacerStringT | SpacerNumberT | undefined;\n @Input() desktop?: SpacerStringT | SpacerNumberT | undefined;\n\n //--- Local variables\n inputDefault: number | undefined = undefined;\n inputMobile: number | undefined = undefined;\n inputDesktop: number | undefined = undefined;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Default\n this.inputDefault = validateNumberValue(changes, 'default', this.inputDefault);\n //--- Mobile\n this.inputMobile = validateNumberValue(changes, 'mobile', this.inputMobile);\n //--- Desktop\n this.inputDesktop = validateNumberValue(changes, 'desktop', this.inputDesktop);\n }\n}\n","<!-- Mobile Only OR Default -->\n<div *ngIf=\"inputMobile || inputDefault\" class=\"mobile-only\" [ngStyle]=\"{ height: (inputMobile || inputDefault || 0) + 'px' }\"> </div>\n<!-- Desktop Only OR Default-->\n<div *ngIf=\"inputDesktop || inputDefault\" class=\"desktop-only\" [ngStyle]=\"{ height: (inputDesktop || inputDefault || 0) + 'px' }\"> </div>\n","/**\n * CareFirst Library - Notification\n *\n * @file notification.component\n * @description Contains all the logic for generating a CareFirst Notification\n * @author Arno Jansen van Vuuren\n * @since 2023 - 11 - 27\n * @usage <cf-notification [data]=\"{heading, status, %message%, %canClose%, %button%}\" (buttonClick)=\"\"></cf-notification>\n */\n\nimport { Component, Input, Output, EventEmitter } from '@angular/core';\n//--- Interfaces\nimport type { NotificationPayloadI } from '../../interfaces/notification.interface';\n\n@Component({\n selector: 'cf-notification',\n templateUrl: './notification.component.html',\n styleUrls: ['./notification.component.scss'],\n})\nexport class NotificationComponent {\n @Input() data?: NotificationPayloadI | undefined;\n @Output() buttonClick = new EventEmitter<Required<NotificationPayloadI>['button']['buttonClickIdentifier']>();\n}\n","<div *ngIf=\"data\">\n <cf-spacer mobile=\"16\" desktop=\"32\"></cf-spacer>\n <ion-grid>\n <ion-row class=\"ion-justify-content-center\">\n <ion-col size=\"12\" size-md=\"6\">\n <div [ngClass]=\"data.status\" id=\"notification-container\">\n <ion-grid>\n <ion-row>\n <ion-col class=\"ion-align-self-center ion-text-start\">\n <p class=\"body-medium bold\">{{ data.heading }}</p>\n </ion-col>\n <ion-col size=\"auto\">\n <cf-icon icon=\"close\" *ngIf=\"data.canClose\" (click)=\"data = undefined\" [height]=\"10\" [iconColor]=\"data.status\"></cf-icon>\n </ion-col>\n <ion-col *ngIf=\"data.message\" size=\"12\">\n <cf-spacer default=\"8\"></cf-spacer>\n <p class=\"body-small\">{{ data.message }}</p>\n </ion-col>\n <ion-col *ngIf=\"data.button?.buttonHeading\">\n <cf-spacer default=\"8\"></cf-spacer>\n <p class=\"body-medium bold\">{{ data.button?.buttonHeading }}</p>\n </ion-col>\n <ion-col size=\"12\">\n <ng-content></ng-content>\n </ion-col>\n <ion-col size=\"12\" *ngIf=\"data.button\">\n <cf-spacer default=\"8\"></cf-spacer>\n <cf-btn type=\"primary\" fontSize=\"large\" action snug (click)=\"buttonClick.emit(data.button.buttonClickIdentifier)\">{{\n data.button.buttonText\n }}</cf-btn>\n </ion-col>\n </ion-row>\n </ion-grid>\n </div>\n </ion-col>\n </ion-row>\n </ion-grid>\n <cf-spacer mobile=\"16\" desktop=\"32\"></cf-spacer>\n</div>\n","/**\n * CareFirst Library Alert\n *\n * @file alert.component\n * @description Contains all the logic for generating a CareFirst Alert\n * @author Arno Jansen van Vuuren\n * @since 2023 - 11 - 30\n * @usage <cf-alert data=\"{heading, message, buttonTrue, buttonFalse}\" (alertEvent)></cf-alert>\n */\n\nimport { Component, Input, Output, type OnChanges, type SimpleChanges, EventEmitter } from '@angular/core';\nimport { AlertController } from '@ionic/angular';\nimport type { AlertDataI, AlertEventI } from '../../interfaces/alert.interface';\n\n@Component({\n selector: 'cf-alert',\n templateUrl: './alert.component.html',\n styleUrl: './alert.component.scss',\n})\nexport class AlertComponent implements OnChanges {\n @Input() data: AlertDataI | undefined = undefined;\n @Output() alertEvent = new EventEmitter<AlertEventI>();\n\n /**----------------------------------------------------------------\n * @name constructor\n */\n constructor(private readonly alertController: AlertController) {}\n\n /**----------------------------------------------------------------\n * @name ngOnchange\n * @description Update various values on component input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n const val = changes['data']?.currentValue as typeof this.data;\n if (val) this.showAlert(val);\n }\n\n /**----------------------------------------------------------------\n * @name showAlert\n * @description Show\n * @param {AlertDataI} data\n * @returns {Promise<void>}\n */\n async showAlert(data: AlertDataI): Promise<void> {\n const alert = await this.alertController.create({\n header: data.heading,\n message: data.message,\n cssClass: 'care-first-alert',\n mode: 'md',\n backdropDismiss: false,\n buttons: [\n {\n text: data.buttonFalse || 'Cancel',\n handler: () => {\n this.alertEvent.emit({ identifier: data.alertIdentifier, status: false });\n alert.dismiss();\n },\n cssClass: 'alert-button-cancel',\n },\n {\n text: data.buttonTrue || 'OK',\n handler: () => {\n this.alertEvent.emit({ identifier: data.alertIdentifier, status: true });\n alert.dismiss();\n },\n cssClass: 'alert-button-confirm',\n },\n ],\n });\n alert.present();\n }\n}\n","","/**\n * CareFirst Library Logo\n *\n * @file logo.component\n * @description Contains all the logic for generating a CareFirst Logo\n * @author Arno Jansen van Vuuren\n * @since 2023 - 11 - 30\n * @usage <cf-logo type=\"vertical | horizontal\" %height%></cf-logo>\n */\n\nimport { Component, Input } from '@angular/core';\n\n@Component({\n selector: 'cf-logo',\n templateUrl: './logo.component.html',\n styleUrl: './logo.component.scss',\n})\nexport class LogoComponent {\n @Input() type!: 'horizontal' | 'vertical';\n @Input() height: number = 50;\n}\n","<div class=\"img-container\" [style]=\"height ? 'height: ' + height + 'px' : ''\">\n <img\n *ngIf=\"type === 'horizontal'\"\n src=\"\"\n alt=\"Care Fist Logo\" />\n <img\n *ngIf=\"type === 'vertical'\"\n src=\"\"\n alt=\"Care Fist Logo\" />\n</div>\n","/**\n * CareFirst Library Calendar\n *\n * @file calendar.component\n * @description Contains all the logic for generating a CareFirst Calendar\n * @author Arno Jansen van Vuuren\n * @since 2023 - 12 - 01\n * @usage <cf-calendar %displayTime% %color%=\"success | accent\" %min% %max%></cf-calendar>\n */\n\nimport { Component, EventEmitter, Input, Output, type OnChanges, type SimpleChanges } from '@angular/core';\nimport dayjs from 'dayjs';\n//--- Utils\nimport { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';\n\n@Component({\n selector: 'cf-calendar',\n templateUrl: './calendar.component.html',\n styleUrl: './calendar.component.scss',\n})\nexport class CalendarComponent implements OnChanges {\n @Input() displayTime?: boolean | string | undefined;\n @Input() color?: 'success' | 'accent';\n @Input() min?: string | undefined = undefined;\n @Input() max?: string | undefined = undefined;\n @Output() value = new EventEmitter<string>();\n\n //--- Local variables\n inputTime = false;\n inputColor: typeof this.color = 'accent';\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on component input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Display Time\n this.inputTime = checkTruthAttribute(changes, 'displayTime', this.inputTime);\n //--- Color\n this.inputColor = validateStringValue<'success' | 'accent'>(changes, 'color', ['success', 'accent'], this.inputColor) || 'accent';\n }\n\n /**----------------------------------------------------------------\n * @name setValue\n * @description Emit the selected date value\n * @param {string | string[] | null | undefined} value\n * @returns {void}\n */\n setValue(value: string | string[] | null | undefined): void {\n if (typeof value === 'string') this.value.emit(dayjs(value).format('YYYY-MM-DD' + (this.inputTime ? ' HH:mm' : '')));\n }\n}\n","<ion-datetime\n [class]=\"inputColor\"\n mode=\"ios\"\n firstDayOfWeek=\"1\"\n [min]=\"min\"\n [max]=\"max\"\n [presentation]=\"inputTime ? 'date-time' : 'date'\"\n (ionChange)=\"setValue($event.detail.value)\">\n</ion-datetime>\n","/**\n * CareFirst Library Form Validation Feedback\n *\n * @file form-validation.component\n * @description Contains all the logic for generating CareFirst Form Validation Feedback\n * @author Arno Jansen van Vuuren\n * @since 2023 - 12 - 05\n * @usage <cf-form-validation [control]=\"formName.get('controlName')\"></cf-form-validation>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\n//--- Interfaces\nimport type { FormControl } from '@angular/forms';\n\n@Component({\n selector: 'cf-form-validation',\n templateUrl: './form-validation.component.html',\n styleUrl: './form-validation.component.scss',\n})\nexport class FormValidationComponent implements OnChanges {\n //--- Receive form control\n @Input() control!: FormControl | null;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Detect changes to input values\n * @param {SimpleChanges} changes\n */\n ngOnChanges(changes: SimpleChanges): void {\n if (changes['control'] && changes['control'].currentValue) {\n this.control = changes['control'].currentValue;\n }\n }\n}\n","<div *ngIf=\"control?.dirty && control?.errors\" class=\"form-valid-feedback\">\n <div *ngFor=\"let error of this.control?.errors | keyvalue\">\n <p class=\"body-medium\" *ngIf=\"error.key === 'email'\">*Invalid email format</p>\n <p class=\"body-medium\" *ngIf=\"error.key === 'minlength'\">*Length required: {{ error.value.requiredLength - error.value.actualLength }}</p>\n <p class=\"body-medium\" *ngIf=\"error.key === 'maxlength'\">*Max Length: {{ error.value.requiredLength }}</p>\n <p class=\"body-medium\" *ngIf=\"error.key === 'errorMessage'\">*{{ error.value }}</p>\n </div>\n</div>\n","/**\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 label=\"Label Name\" %labelPlacement% %inputMode% %noClearButton% %textCenter% %min% %max% %autoCapitalize% %type% %[(value)]=\"twoWayComs\"% %(valueChange)=\"currentValueEvent\"% %[control]%=\"formName.controls.controlName\"></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';\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: number | string = 'none';\n @Input() max: number | string = 'none';\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\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\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}\n","<!-- ngModel -->\n<ion-input\n *ngIf=\"!control\"\n [ngClass]=\"{ 'text-center': inputTextCenter, 'grey-background': inputGreyBackground }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"!inputClear\"\n [autocapitalize]=\"autoCapitalize\"\n mode=\"md\"\n [inputmode]=\"localInputMode\"\n [min]=\"min\"\n [max]=\"max\"\n [maxlength]=\"maxLength || null\"\n [type]=\"type\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n [value]=\"value\"></ion-input>\n<!-- Form Control -->\n<ion-input\n *ngIf=\"control\"\n [ngClass]=\"{ 'text-center': inputTextCenter, 'grey-background': inputGreyBackground }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"!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]=\"type\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"></ion-input>\n<cf-form-validation *ngIf=\"control\" [control]=\"control\"></cf-form-validation>\n","/**\n * Carefirst Library Form Input Select\n *\n * @file form-input-select.component\n * @description Contains all the logic for generating a CareFirst Select\n * @author Arno Jansen van Vuuren\n * @since 2023 - 12 - 14\n * @usage <cf-form-input-select label=\"Label Name\" [options]=\"[{ displayName: string; value: string | number | boolean | null | undefined }]\" %labelPlacement% %(valueChange)=\"currentValue\"% %[(value)]=\"twoWayComs\"% %[control]%=\"formName.controls.controlName\"></cf-form-input-select>\n * disable input by disabling the form control\n */\n\nimport { Component, EventEmitter, Input, Output, type OnChanges, type SimpleChanges } from '@angular/core';\nimport { FormControl } from '@angular/forms';\n//--- Utils\nimport { validateStringValue } from '../../utils/attribute.util';\n//--- Interfaces\nimport type { FormInputSelectOptionsI } from '../../interfaces/input.interface';\n\n/**==============================================\n * @interface inputSelectC\n * @description Define available input select values\n */\nconst inputSelectC = {\n labelPlacement: ['fixed', 'floating', 'stacked', 'start', 'end'],\n} as const;\n\n@Component({\n selector: 'cf-form-input-select',\n templateUrl: './form-input-select.component.html',\n styleUrl: './form-input-select.component.scss',\n})\nexport class FormInputSelectComponent<T> implements OnChanges {\n @Input() label!: string;\n @Input() options!: FormInputSelectOptionsI<T>[];\n @Input() labelPlacement?: (typeof inputSelectC.labelPlacement)[number];\n @Input() placeholder?: string | undefined;\n @Input() control?: FormControl | null;\n\n //--- ngModel\n @Input() value: FormInputSelectOptionsI<T>['value'] | undefined;\n @Output() valueChange = new EventEmitter<typeof this.value>();\n\n //--- Local variables\n inputLabelPlacement: typeof this.labelPlacement;\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 inputSelectC.labelPlacement)[number]>(\n changes,\n 'labelPlacement',\n inputSelectC.labelPlacement.slice(),\n this.inputLabelPlacement\n ) || 'floating';\n }\n}\n","<!-- ngModel -->\n<ion-select\n *ngIf=\"!control\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n mode=\"md\"\n interface=\"popover\"\n (ionChange)=\"valueChange.emit($event.detail.value ?? undefined)\"\n [value]=\"value\">\n <ion-select-option *ngFor=\"let option of options\" [value]=\"option.value\">{{ option.displayName }}</ion-select-option>\n</ion-select>\n<!-- Form Control -->\n<ion-select\n *ngIf=\"control\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n mode=\"md\"\n interface=\"popover\"\n [formControl]=\"control\"\n (ionChange)=\"valueChange.emit($event.detail.value ?? undefined)\">\n <ion-select-option *ngFor=\"let option of options\" [value]=\"option.value\">{{ option.displayName }}</ion-select-option>\n</ion-select>\n<cf-form-validation *ngIf=\"control\" [control]=\"control\"></cf-form-validation>\n","/**\n * Carefirst Library Form Input Text Area\n *\n * @file form-input-text-area.component\n * @description Contains all the logic for generating a CareFirst Form Input Text Area\n * @author Arno Jansen van Vuuren\n * @since 2023 - 12 - 18\n * @usage <cf-form-input-text-area label=\"Label Name\" %labelPlacement% %textCenter% %autoCapitalize% %(valueChange)=\"currentValue\"% %[(value)]=\"twoWayComs\"% %[control]%=\"formName.controls.controlName\"></cf-form-input-text-area>\n * disable input by disabling the form control\n */\n\nimport { Component, EventEmitter, Input, Output, type OnChanges, type SimpleChanges } from '@angular/core';\nimport type { FormControl } from '@angular/forms';\n//--- Utils\nimport { validateStringValue, checkTruthAttribute } from '../../utils/attribute.util';\n\n/**==============================================\n * @interface inputTextAreaC\n * @description Define available input values\n */\nconst inputTextAreaC = {\n labelPlacement: ['fixed', 'floating', 'stacked', 'start', 'end'],\n autoCapitalize: ['off', 'none', 'on', 'sentences', 'words', 'characters'],\n} as const;\n\n@Component({\n selector: 'cf-form-input-text-area',\n templateUrl: './form-input-text-area.component.html',\n styleUrl: './form-input-text-area.component.scss',\n})\nexport class FormInputTextAreaComponent implements OnChanges {\n @Input() label!: string;\n @Input() labelPlacement?: (typeof inputTextAreaC.labelPlacement)[number];\n @Input() placeholder?: string | undefined;\n @Input() autoCapitalize?: (typeof inputTextAreaC.autoCapitalize)[number];\n @Input() control?: FormControl | null;\n @Input() textCenter?: boolean | string | undefined;\n @Input() minHeight?: string | 'none' = 'none';\n @Input() maxHeight?: string | 'none' = 'none';\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 = true;\n inputTextCenter = false;\n inputAutoCapitalize: typeof this.autoCapitalize;\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 inputTextAreaC.labelPlacement)[number]>(\n changes,\n 'labelPlacement',\n inputTextAreaC.labelPlacement.slice(),\n this.inputLabelPlacement\n ) || 'floating';\n //--- Text Center\n this.inputTextCenter = checkTruthAttribute(changes, 'textCenter', this.inputTextCenter);\n //--- Auto Capitalize\n this.inputAutoCapitalize =\n validateStringValue<(typeof inputTextAreaC.autoCapitalize)[number]>(\n changes,\n 'autoCapitalize',\n inputTextAreaC.autoCapitalize.slice(),\n this.inputAutoCapitalize\n ) || 'none';\n }\n}\n","<!-- ngModel -->\n<ion-textarea\n [style]=\"'min-height: ' + minHeight + '; max-height: ' + maxHeight\"\n *ngIf=\"!control\"\n [placeholder]=\"placeholder\"\n [ngClass]=\"{ 'text-center': inputTextCenter }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n fill=\"outline\"\n [autocapitalize]=\"autoCapitalize\"\n [autoGrow]=\"true\"\n mode=\"md\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n [value]=\"value\"></ion-textarea>\n<!-- Form Control -->\n<ion-textarea\n [style]=\"'min-height: ' + minHeight + '; max-height: ' + maxHeight\"\n *ngIf=\"control\"\n [placeholder]=\"placeholder\"\n [ngClass]=\"{ 'text-center': inputTextCenter }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n fill=\"outline\"\n [autocapitalize]=\"autoCapitalize\"\n [autoGrow]=\"true\"\n mode=\"md\"\n [formControl]=\"control\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"></ion-textarea>\n<cf-form-validation *ngIf=\"control\" [control]=\"control\"></cf-form-validation>\n","/**\n * CareFirst Chat Bubble\n *\n * @file chat-bubble.component\n * @description Contains all the logic for generating a CareFirst Chat Bubble\n * @author Jacques Coetzee\n * @since 2024 - 02 - 22\n * @usage <cf-chat-bubble type=\"outgoing | incoming\" date=\"string\" message=\"string\"></cf-chat-bubble>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\n//--- Utils\nimport { validateStringValue } from '../../utils/attribute.util';\n\n@Component({\n selector: 'cf-chat-bubble',\n templateUrl: './chat-bubble.component.html',\n styleUrl: './chat-bubble.component.scss',\n})\nexport class ChatBubbleComponent implements OnChanges {\n @Input() type: 'outgoing' | 'incoming' = 'outgoing';\n @Input() date: string = '';\n @Input() message: string = '';\n\n //--- Local variables\n inputType: typeof this.type = 'incoming';\n inputDate: typeof this.date = '';\n inputMessage: typeof this.message = '';\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Type\n this.inputType = validateStringValue<typeof this.type>(changes, 'type', ['incoming', 'outgoing'], this.inputType) || 'outgoing';\n //--- Date\n this.inputDate = changes['date']?.currentValue || '';\n //--- Message\n this.inputMessage = changes['message']?.currentValue || '';\n }\n}\n","<div id=\"container\" [ngClass]=\"inputType\">\n <div id=\"message\">\n <p class=\"body-extra-small\">{{ inputDate }}</p>\n <cf-spacer default=\"4\"></cf-spacer>\n <div id=\"bubble\">\n <p class=\"body-extra-small\">{{ inputMessage }}</p>\n </div>\n </div>\n</div>\n","/**\n * CareFirst Chat Badge\n *\n * @file badge.component\n * @description Contains all the logic for generating a CareFirst Chat Badge\n * @author Jacques Coetzee\n * @since 2024 - 02 - 22\n * @usage <cf-badge type=\"BadgeTypeT\" %icon%=\"IconsT\"></cf-badge>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\n//--- Utils\nimport { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';\n//--- Interfaces\nimport { iconsC, type IconsT } from '../../interfaces/icon.interface';\n\n/**==============================================\n * @interface BadgeTypeT\n * @description Types of badges available\n */\nconst badgeTypeC = [\n 'primary',\n 'white',\n 'success',\n 'alert',\n 'accent',\n 'warning',\n 'disabled',\n 'feedback-success',\n 'feedback-error',\n 'feedback-warning',\n 'feedback-busy',\n] as const;\ntype BadgeTypeT = (typeof badgeTypeC)[number];\n\n/**==============================================\n * @name BadgeComponent\n * */\n@Component({\n selector: 'cf-badge',\n templateUrl: './badge.component.html',\n styleUrl: './badge.component.scss',\n})\nexport class BadgeComponent implements OnChanges {\n @Input() type: BadgeTypeT = 'primary';\n @Input() icon?: IconsT | undefined;\n @Input() small?: boolean | string | undefined;\n @Input() large?: boolean | string | undefined;\n\n //--- Local variables\n inputType: typeof this.type = 'primary';\n inputIcon: typeof this.icon | undefined = undefined;\n fontsize = 12;\n inputSmall = false;\n inputLarge = false;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Type\n this.inputType = validateStringValue<BadgeTypeT>(changes, 'type', badgeTypeC.slice(), this.inputType) || 'primary';\n //--- Icon Start\n this.inputIcon = validateStringValue<IconsT>(changes, 'icon', iconsC.slice(), this.inputIcon);\n //--- Small Badge\n this.inputSmall = checkTruthAttribute(changes, 'small', this.inputSmall);\n if (this.inputSmall) this.fontsize = 10;\n //--- Large Badge\n this.inputLarge = checkTruthAttribute(changes, 'large', this.inputLarge);\n if (this.inputLarge) this.fontsize = 16;\n }\n}\n","<div [className]=\"'cf-badge-' + inputType\" [ngClass]=\"{ small: inputSmall, large: inputLarge }\">\n <cf-icon *ngIf=\"inputIcon && inputType !== 'feedback-busy'\" [icon]=\"inputIcon\" [height]=\"fontsize\"></cf-icon>\n <ion-spinner *ngIf=\"inputType === 'feedback-busy'\"></ion-spinner>\n <p><ng-content></ng-content></p>\n</div>\n","/**\n * CareFirst Library - Spinner\n *\n * @file spinner.component\n * @description Contains all the logic for generating a CareFirst Spinner\n * @author Jacques Coetzee\n * @since 2024 - 02 - 23\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\nimport { validateNumberValue } from '../../utils/attribute.util';\n\n@Component({\n selector: 'cf-spinner',\n templateUrl: './spinner.component.html',\n styleUrl: './spinner.component.scss',\n})\nexport class SpinnerComponent implements OnChanges {\n @Input() size: number | string = 20;\n\n //--- Local variables\n inputSize: number = 20;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Size\n this.inputSize = validateNumberValue(changes, 'size', this.inputSize) || this.inputSize;\n }\n}\n","<div id=\"spinner\" [style]=\"'font-size: ' + inputSize + 'px'\"></div>\n","/**\n * Carefirst library - Verification Code Input\n *\n * @file verification-code.component\n * @description Contains all the logic for generating a CareFirst Verification Code Input\n * @author Arno Jansen van Vuuren\n * @since 2024 - 03 - 07\n * @usage <cf-verification-code\n valueToVerify=`string`\n (outcome)=`omits code value`\n (resendClickEvent)=`resend click event`\n [status]=`BehaviorSubject<'initial' | 'invalid'>`>\n </cf-verification-code>\n */\n\nimport { Component, EventEmitter, Input, Output, ViewChild, type OnChanges, type SimpleChanges } from '@angular/core';\n//--- Interface\nimport type { BehaviorSubject, Subscription } from 'rxjs';\nimport type { InputCustomEvent, IonInput } from '@ionic/angular';\nimport type { CfCodeInputUserFeedbackMessagesI } from '../../interfaces/verification-code.interface';\n\n@Component({\n selector: 'cf-verification-code',\n templateUrl: './verification-code.component.html',\n styleUrl: './verification-code.component.scss',\n})\nexport class VerificationCodeComponent implements OnChanges {\n @Input() valueToVerify!: string;\n @Input() status!: BehaviorSubject<'initial' | 'invalid'>;\n @Input() userFeedbackMessages?: CfCodeInputUserFeedbackMessagesI;\n\n @Output() outcome = new EventEmitter<string>();\n @Output() resendClickEvent = new EventEmitter<true>();\n\n @ViewChild(`input1`) myInput1?: IonInput;\n @ViewChild('input2') myInput2?: IonInput;\n @ViewChild('input3') myInput3?: IonInput;\n @ViewChild('input4') myInput4?: IonInput;\n @ViewChild('input5') myInput5?: IonInput;\n\n //--- HTML variables\n validationCodeError = false;\n verificationCodeInputArr: (number | null)[] = [null, null, null, null, null];\n loading = false;\n commsSentCount = 0;\n validationCode: string | undefined;\n\n statusSub$?: Subscription;\n\n /**----------------------------------------------------------------\n * @name constructor\n */\n constructor() {}\n\n /**----------------------------------------------------------------\n * @name ionViewWillEnter\n * @description Update various values on component initialization\n * @returns {void}\n */\n ionViewDidEnter(): void {\n this.commsSentCount = 0;\n }\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Value to verify\n if (\n changes['valueToVerify']?.currentValue !== changes['valueToVerify']?.previousValue ||\n changes['code']?.currentValue !== changes['code']?.previousValue\n ) {\n this.commsSentCount = 0;\n this.validationCodeError = false;\n this.resetAllInputFields();\n }\n\n //--- Status display\n if (changes['status']) {\n this.statusSub$ = (changes['status'].currentValue as BehaviorSubject<'initial' | 'invalid'>).subscribe((stat) => {\n if (stat === 'invalid') {\n this.validationCodeError = true;\n }\n this.resetAllInputFields();\n this.setFocusToNext(0);\n });\n }\n }\n\n /**----------------------------------------------------------------\n * @name resendVerificationCode\n * @description Resend a verification code\n * @returns {void}\n */\n resendVerificationCode(): void {\n this.commsSentCount++;\n this.resendClickEvent.emit(true);\n }\n\n /**----------------------------------------------------------------\n * @name formulateAndCheckVerificationCode\n * @description Handle inputs associated with the verification code and do call once code is complete\n * @param {InputCustomEvent} event\n * @param {number} index\n * @returns {void}\n */\n formulateAndCheckVerificationCode(event: InputCustomEvent, index: number): void {\n const value = event.detail.value;\n if (!value || !(typeof value === 'string') || !(+value < 10)) {\n this.clearCodeInput(index);\n return;\n }\n\n this.setFocusToNext(index);\n this.verificationCodeInputArr[index - 1] = +value;\n this.validationCodeError = false;\n\n //--- Check if code completed\n if (this.verificationCodeInputArr.every((val) => val !== null)) {\n this.validationCode = this.verificationCodeInputArr.join('');\n this.outcome.emit(this.validationCode);\n }\n }\n\n /**----------------------------------------------------------------\n * @name resetAllInputFields\n * @description Reset all input fields\n * @returns {void}\n */\n private resetAllInputFields(): void {\n this.clearCodeInput(1);\n this.clearCodeInput(2);\n this.clearCodeInput(3);\n this.clearCodeInput(4);\n this.clearCodeInput(5);\n this.verificationCodeInputArr.fill(null);\n }\n\n /**----------------------------------------------------------------\n * @name setFocusToNext\n * @description Set the focus to the next input\n * @param {number} currentIndex\n * @returns {void}\n */\n private setFocusToNext(currentIndex: number): void {\n if (currentIndex === 5) return;\n currentIndex === 0\n ? this.myInput1?.setFocus()\n : currentIndex === 1\n ? this.myInput2?.setFocus()\n : currentIndex === 2\n ? this.myInput3?.setFocus()\n : currentIndex === 3\n ? this.myInput4?.setFocus()\n : this.myInput5?.setFocus();\n }\n\n /**----------------------------------------------------------------\n * @name clearCodeInput\n * @description Clear a code input on invalid key\n * @param {number} index\n * @returns {void}\n */\n private clearCodeInput(index: number): void {\n switch (index) {\n case 1:\n if (this.myInput1) this.myInput1.value = null;\n break;\n case 2:\n if (this.myInput2) this.myInput2.value = null;\n break;\n case 3:\n if (this.myInput3) this.myInput3.value = null;\n break;\n case 4:\n if (this.myInput4) this.myInput4.value = null;\n break;\n case 5:\n if (this.myInput5) this.myInput5.value = null;\n break;\n }\n }\n\n /**----------------------------------------------------------------\n * @name ionViewWillLeave\n * @description Unsubscribe on component leave\n * @returns {void}\n */\n ionViewWillLeave(): void {\n this.statusSub$?.unsubscribe();\n }\n}\n","<ion-grid>\n <!-- Input boxes for verification code 5 numeric digits -->\n <ion-row class=\"ion-justify-content-center\">\n <ion-col *ngIf=\"validationCodeError\" size=\"auto\">\n <p\n class=\"body-small error ion-text-center\"\n *ngFor=\"let string of userFeedbackMessages?.error?.errorMessage || ['Invalid Code - Please Retry']\"\n >{{ string }}</p\n >\n <cf-spacer default=\"16\"></cf-spacer>\n </ion-col>\n </ion-row>\n <ion-row class=\"ion-justify-content-center\">\n <ion-col size=\"auto\">\n <div class=\"single-container\" [ngClass]=\"{ error: validationCodeError }\">\n <ion-input\n #input1\n class=\"single-digit-input ion-text-center\"\n [disabled]=\"loading\"\n fill=\"outline\"\n maxlength=\"1\"\n clearOnEdit=\"true\"\n inputmode=\"numeric\"\n mode=\"md\"\n (ionInput)=\"formulateAndCheckVerificationCode($event, 1)\"></ion-input>\n <ion-input\n #input2\n class=\"single-digit-input ion-text-center\"\n [disabled]=\"loading\"\n fill=\"outline\"\n maxlength=\"1\"\n clearOnEdit=\"true\"\n inputmode=\"numeric\"\n mode=\"md\"\n (ionInput)=\"formulateAndCheckVerificationCode($event, 2)\"></ion-input>\n <ion-input\n #input3\n class=\"single-digit-input ion-text-center\"\n [disabled]=\"loading\"\n fill=\"outline\"\n maxlength=\"1\"\n clearOnEdit=\"true\"\n inputmode=\"numeric\"\n (ionInput)=\"formulateAndCheckVerificationCode($event, 3)\"></ion-input>\n <ion-input\n #input4\n class=\"single-digit-input ion-text-center\"\n [disabled]=\"loading\"\n fill=\"outline\"\n maxlength=\"1\"\n clearOnEdit=\"true\"\n inputmode=\"numeric\"\n mode=\"md\"\n (ionInput)=\"formulateAndCheckVerificationCode($event, 4)\"></ion-input>\n <ion-input\n #input5\n class=\"single-digit-input ion-text-center\"\n [disabled]=\"loading\"\n fill=\"outline\"\n maxlength=\"1\"\n clearOnEdit=\"true\"\n inputmode=\"numeric\"\n mode=\"md\"\n (ionInput)=\"formulateAndCheckVerificationCode($event, 5)\"></ion-input>\n </div>\n </ion-col>\n </ion-row>\n <ion-row class=\"ion-justify-content-center\">\n <ion-col size=\"auto\">\n <cf-spacer default=\"16\"></cf-spacer>\n <ng-container *ngIf=\"!loading\">\n <button *ngIf=\"commsSentCount < 3\" (click)=\"resendVerificationCode()\" style=\"background-color: transparent\">\n <ng-container *ngIf=\"validationCodeError\">\n <p class=\"body-small ion-text-center\" *ngFor=\"let string of userFeedbackMessages?.error?.resend || ['Resend Code']\">\n {{ string }}\n </p>\n </ng-container>\n <ng-container *ngIf=\"!validationCodeError\">\n <p\n class=\"body-small ion-text-center\"\n *ngFor=\"let string of userFeedbackMessages?.standardResend || ['Didn`t get a code? Please resend the code']\">\n {{ string }}\n </p>\n </ng-container>\n </button>\n <ng-container *ngIf=\"commsSentCount >= 3\">\n <p\n class=\"body-small ion-text-center\"\n *ngFor=\"let string of userFeedbackMessages?.limitReached || ['Still struggling with your code?', 'Please contact support for assistance']\"\n >{{ string }}</p\n >\n </ng-container>\n </ng-container>\n </ion-col>\n </ion-row>\n <ion-row class=\"ion-justify-content-center\">\n <ion-col size=\"auto\">\n <cf-spinner [size]=\"50\" [ngClass]=\"{ 'block-hidden': !loading }\"></cf-spinner>\n </ion-col>\n </ion-row>\n</ion-grid>\n","import { CUSTOM_ELEMENTS_SCHEMA, NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n//--- Modules\nimport { IonicModule } from '@ionic/angular';\nimport { ReactiveFormsModule } from '@angular/forms';\n//--- Directives\nimport { ButtonLoaderDirective } from './directives/button-loader.directive';\n//--- Components\nimport { PageComponent } from './components/page/page.component';\nimport { ButtonComponent } from './components/button/button.component';\nimport { SpacerComponent } from './components/spacer/spacer.component';\nimport { IconComponent } from './components/icon/icon.component';\nimport { NotificationComponent } from './components/notification/notification.component';\nimport { AlertComponent } from './components/alert/alert.component';\nimport { LogoComponent } from './components/logo/logo.component';\nimport { CalendarComponent } from './components/calendar/calendar.component';\nimport { FormValidationComponent } from './components/form-validation/form-validation.component';\nimport { FormInputComponent } from './components/form-input/form-input.component';\nimport { FormInputSelectComponent } from './components/form-input-select/form-input-select.component';\nimport { FormInputTextAreaComponent } from './components/form-input-text-area/form-input-text-area.component';\nimport { ChatBubbleComponent } from './components/chat-bubble/chat-bubble.component';\nimport { BadgeComponent } from './components/badge/badge.component';\nimport { SpinnerComponent } from './components/spinner/spinner.component';\nimport { VerificationCodeComponent } from './components/verification-code/verification-code.component';\n\n@NgModule({\n declarations: [\n PageComponent,\n ButtonComponent,\n SpacerComponent,\n IconComponent,\n ButtonLoaderDirective,\n NotificationComponent,\n AlertComponent,\n LogoComponent,\n CalendarComponent,\n FormValidationComponent,\n FormInputComponent,\n FormInputSelectComponent,\n FormInputTextAreaComponent,\n ChatBubbleComponent,\n BadgeComponent,\n SpinnerComponent,\n VerificationCodeComponent,\n ],\n\n imports: [IonicModule, CommonModule, ReactiveFormsModule],\n exports: [\n PageComponent,\n ButtonComponent,\n SpacerComponent,\n IconComponent,\n ButtonLoaderDirective,\n NotificationComponent,\n AlertComponent,\n LogoComponent,\n CalendarComponent,\n FormValidationComponent,\n FormInputComponent,\n FormInputSelectComponent,\n FormInputTextAreaComponent,\n ChatBubbleComponent,\n BadgeComponent,\n SpinnerComponent,\n VerificationCodeComponent,\n ],\n schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class CareFirstLibraryModule {}\n","/**\n * Form validators\n *\n * @file form-validators\n * @description Various form validators\n * @author Jacques Coetzee\n * @since 2022 - 01 - 20\n * @usage Display \"errorMessage\" key value as validator response message\n */\n\nimport { AbstractControl } from '@angular/forms';\nimport passwordValidator from 'password-validator';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\ndayjs.extend(customParseFormat);\n//--- Interfaces\nimport type { ValidationErrors, ValidatorFn } from '@angular/forms';\n\nexport class CFPFormValidators {\n /**----------------------------------------------------------------\n * @name checkPSWRetype\n * @description Check if passwords match\n * @param {string} controlNameToCheckAgainst\n * @returns {ValidatorFn}\n * @usage FormValidators.compareTo('password')\n */\n static compareTo(controlNameToCheckAgainst: string): ValidatorFn {\n return (control: AbstractControl): ValidationErrors | null => {\n //--- Compare controls\n const controlToCheckTo: AbstractControl | null = control?.parent?.get(controlNameToCheckAgainst) || null;\n\n //--- Check primary control value\n if (!controlToCheckTo?.value) return { errorMessage: `Password Required` };\n //--- Check secondary control value\n else if (!control.value) return { errorMessage: `Password confirmation required` };\n //--- Compare controls\n else if (control.value && control?.value !== controlToCheckTo?.value) return { errorMessage: `Passwords do not match` };\n\n return null;\n };\n }\n\n /**----------------------------------------------------------------\n * @name asPassword\n * @description Validate control as password\n * @returns {ValidatorFn}\n * @usage FormValidators.asPassword()\n */\n static asPassword(): ValidatorFn {\n return (control: AbstractControl): ValidationErrors | null => {\n const schema = new passwordValidator();\n\n //--- Setup password requirements\n schema\n //--- Minimum length 8\n .is()\n .min(8, 'Minimum of 8 characters')\n //--- Maximum length 50\n .is()\n .max(30, 'Maximum of 30 characters')\n //--- Must have uppercase letters\n .has()\n .uppercase(undefined, 'At least one UPPERCASE character')\n //--- Must have lowercase letters\n .has()\n .lowercase(undefined, 'At least one lowercase character')\n //--- Must have at least 1 digits\n .has()\n .digits(undefined, 'At least one digit')\n //--- Special characters\n .has()\n .symbols(undefined, 'At least one special character');\n\n //--- Validate string\n const inValid = schema.validate(control.value, { details: true }) as {\n validation: string;\n message: string;\n arguments?: number;\n }[];\n\n const returnResponse: { [key: string]: unknown } = {};\n inValid.forEach((error) => {\n returnResponse['password-' + error.validation] = error.message;\n });\n return inValid.length ? returnResponse : null;\n };\n }\n\n /**----------------------------------------------------------------\n * @name asEmail\n * @description Validate control as email\n * @param {true} canBeEmpty\n * @returns {ValidatorFn}\n * @usage FormValidators.asEmail(true?)\n */\n static asEmail(canBeEmpty?: true): ValidatorFn {\n return (control: AbstractControl): ValidationErrors | null => {\n let setErrors = null;\n const emailRegEx = new RegExp('^[\\\\w-.]+@[\\\\w]+\\\\.[\\\\w]+');\n\n //--- Check if email can be empty\n if (canBeEmpty && (control.value === null || control.value === '')) {\n return null;\n }\n\n //--- Test RegExp\n if (!(control.value && emailRegEx.test(control.value))) {\n setErrors = { errorMessage: `Not a valid email address` };\n }\n\n return setErrors;\n };\n }\n\n /**----------------------------------------------------------------\n * @name isIn\n * @description Validate control value is part of a given list\n * @param {string | number[]} list\n * @returns {ValidatorFn}\n * @usage FormValidators.isIn()\n */\n static isIn(list: (string | number)[]): ValidatorFn {\n return (control: AbstractControl): ValidationErrors | null => {\n if (!list.includes(control.value)) return { errorMessage: 'Control value not part of eligible values' };\n return null;\n };\n }\n\n /**----------------------------------------------------------------\n * @name isSAIDNumber\n * @description Validate control value is a valid RSA ID Number\n * @param {true} canBeEmpty\n * @returns {ValidatorFn}\n * @usage FormValidators.isSAIDNumber(true?)\n */\n static isSAIDNumber(canBeEmpty?: true): ValidatorFn {\n return (control: AbstractControl): ValidationErrors | null => {\n const validateDate = (): boolean => {\n if (typeof control.value !== 'string' || control.value.length < 6) return false;\n const month = control.value.slice(2, 4);\n const day = control.value.slice(4, 6);\n if (+month < 0 && +month > 13) return false;\n if (+day < 0 && +day > 31) return false;\n if (!dayjs(control.value.slice(0, 6), 'YYMMDD', true).isValid()) return false;\n return true;\n };\n\n const checksum = (): boolean => {\n if (typeof control.value !== 'string' || control.value.length !== 13) return false;\n let nSum = 0; //--- Total sum of all the values\n let isSecond = false; //--- To double every other value\n //--- Start from the end\n for (let i = control.value.length - 1; i >= 0; i--) {\n const val: string | undefined = control.value[i];\n if (!val) return false;\n //--- Get numerical value from ascii string\n let d: number = val.charCodeAt(0) - '0'.charCodeAt(0);\n //--- Double every other value\n if (isSecond == true) d = d * 2;\n //--- Sum the total of the doubled values if available\n nSum += Math.floor(d / 10);\n nSum += d % 10;\n //--- Inverse second to determine every other index value\n isSecond = !isSecond;\n }\n //--- Return the modulus 10 of the summation\n return nSum % 10 == 0;\n };\n\n let error: string | null = null;\n if (canBeEmpty && (!control.value || control.value?.length === 0)) return null;\n //--- string\n else if (typeof control.value !== 'string') error = 'Invalid RSA ID Number';\n //--- Length = 13\n else if (control.value.length !== 13) error = `Length required: ${13 - control.value.length}`;\n //--- Validate date\n else if (!validateDate()) error = `Invalid date of birth`;\n //--- Citizenship\n else if (!['0', '1'].includes(control.value.slice(10, 11))) error = `Invalid citizenship value`;\n //--- Checksum\n else if (!checksum()) error = `Invalid RSA ID number checksum`;\n\n return error ? { errorMessage: error } : null;\n };\n }\n}\n","/**==============================================\n * @description Available Spacer Values\n */\nexport const spacerNumberArray = [4, 8, 12, 16, 24, 32, 38, 48, 72] as const;\nexport type SpacerNumberT = (typeof spacerNumberArray)[number];\nexport type SpacerStringT = `${SpacerNumberT}`;\n"],"names":["SpinnerComponent","i1","i3.IconComponent","i4.ButtonLoaderDirective","i3.ButtonComponent","i4.SpacerComponent","i5.IconComponent","i4.FormValidationComponent","i2.SpacerComponent","i3.SpacerComponent","i4.SpinnerComponent"],"mappings":"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"}
1
+ {"version":3,"file":"carefirst-library.mjs","sources":["../../../../projects/carefirst/library/src/lib/directives/button-loader.directive.ts","../../../../projects/carefirst/library/src/lib/utils/attribute.util.ts","../../../../projects/carefirst/library/src/lib/components/page/page.component.ts","../../../../projects/carefirst/library/src/lib/components/page/page.component.html","../../../../projects/carefirst/library/src/lib/interfaces/icon.interface.ts","../../../../projects/carefirst/library/src/lib/components/icon/icon.component.ts","../../../../projects/carefirst/library/src/lib/components/icon/icon.component.html","../../../../projects/carefirst/library/src/lib/components/button/button.component.ts","../../../../projects/carefirst/library/src/lib/components/button/button.component.html","../../../../projects/carefirst/library/src/lib/components/spacer/spacer.component.ts","../../../../projects/carefirst/library/src/lib/components/spacer/spacer.component.html","../../../../projects/carefirst/library/src/lib/components/notification/notification.component.ts","../../../../projects/carefirst/library/src/lib/components/notification/notification.component.html","../../../../projects/carefirst/library/src/lib/components/alert/alert.component.ts","../../../../projects/carefirst/library/src/lib/components/alert/alert.component.html","../../../../projects/carefirst/library/src/lib/components/logo/logo.component.ts","../../../../projects/carefirst/library/src/lib/components/logo/logo.component.html","../../../../projects/carefirst/library/src/lib/components/calendar/calendar.component.ts","../../../../projects/carefirst/library/src/lib/components/calendar/calendar.component.html","../../../../projects/carefirst/library/src/lib/components/form-validation/form-validation.component.ts","../../../../projects/carefirst/library/src/lib/components/form-validation/form-validation.component.html","../../../../projects/carefirst/library/src/lib/components/form-input/form-input.component.ts","../../../../projects/carefirst/library/src/lib/components/form-input/form-input.component.html","../../../../projects/carefirst/library/src/lib/components/form-input-select/form-input-select.component.ts","../../../../projects/carefirst/library/src/lib/components/form-input-select/form-input-select.component.html","../../../../projects/carefirst/library/src/lib/components/form-input-text-area/form-input-text-area.component.ts","../../../../projects/carefirst/library/src/lib/components/form-input-text-area/form-input-text-area.component.html","../../../../projects/carefirst/library/src/lib/components/chat-bubble/chat-bubble.component.ts","../../../../projects/carefirst/library/src/lib/components/chat-bubble/chat-bubble.component.html","../../../../projects/carefirst/library/src/lib/components/badge/badge.component.ts","../../../../projects/carefirst/library/src/lib/components/badge/badge.component.html","../../../../projects/carefirst/library/src/lib/components/spinner/spinner.component.ts","../../../../projects/carefirst/library/src/lib/components/spinner/spinner.component.html","../../../../projects/carefirst/library/src/lib/components/verification-code/verification-code.component.ts","../../../../projects/carefirst/library/src/lib/components/verification-code/verification-code.component.html","../../../../projects/carefirst/library/src/lib/library.module.ts","../../../../projects/carefirst/library/src/lib/utils/form-validators-utility.ts","../../../../projects/carefirst/library/src/lib/interfaces/spacer.interface.ts"],"sourcesContent":["/**\n * Button Loader Directive\n *\n * @file button-loader.directive\n * @description HTML directive used to disable a button while loading\n * @author Jacques Coetzee\n * @since 2022 - 07 - 22\n * @usage Add to any HTML tag: *cfButtonLoader=\"true\"\n */\n\nimport { Component, Directive, Input, Renderer2, TemplateRef, ViewContainerRef, ElementRef } from '@angular/core';\n\n@Directive({\n selector: '[cfButtonLoader]',\n})\nexport class ButtonLoaderDirective {\n /**----------------------------------------------------------------\n * @name Constructor\n */\n constructor(\n private templateRef: TemplateRef<HTMLElement>,\n private renderer: Renderer2,\n private viewContainer: ViewContainerRef,\n private elementRef: ElementRef<HTMLElement>\n ) {}\n\n /**----------------------------------------------------------------\n * @name cfButtonLoader\n * @description Displays a loading overlay and disables a button\n * @param {boolean} loading\n */\n @Input() set cfButtonLoader(loading: boolean) {\n //--- Clear HTML container\n this.viewContainer.clear();\n //--- Reattach element as child\n this.viewContainer.createEmbeddedView(this.templateRef);\n if (loading) {\n //--- Add loading spinner\n this.viewContainer.createComponent(SpinnerComponent);\n //--- Set parent container position to relative\n this.renderer.setStyle(this.elementRef.nativeElement.parentElement, 'position', 'relative');\n }\n }\n}\n\n/**==================================================================\n * @class SpinnerComponent\n * @description The spinner component used to render an ion-spinner on the button\n * @author Jacques Coetzee\n * @since 2022 - 07 - 22\n * ===== */\n\n@Component({\n template: '<div class=\"loading-spinner\"></div>',\n styles: [\n `\n @keyframes spinner {\n to {\n transform: rotate(360deg);\n }\n }\n\n .loading-spinner {\n position: absolute;\n top: calc(50% - 1em);\n left: calc(50% - 1em);\n width: 2em;\n height: 2em;\n border-radius: 50%;\n border: 3px solid var(--cf-app-system-color-outline);\n border-top-color: var(--cf-app-color-accent);\n animation: spinner 1s linear infinite;\n }\n `,\n ],\n})\nclass SpinnerComponent {}\n","/**\n * Attribute Utility\n *\n * @file attribute.util\n * @description Contains various utility functions pertaining to attribute handling\n * @author Jacques Coetzee\n * @since 2023 - 11 - 08\n */\n\nimport type { SimpleChanges } from '@angular/core';\n\n/**----------------------------------------------------------------\n * @name checkTruthAttribute\n * @description Check whether an attribute is either just available or specifically set to boolean value\n * @param {SimpleChanges} changes\n * @param {string} attribute\n * @param {boolean} curVal\n * @returns {boolean}\n */\nexport function checkTruthAttribute(changes: SimpleChanges, attribute: string, curVal: boolean): boolean {\n if (!(attribute in changes)) return curVal;\n const valueChanged = changes[attribute]?.currentValue;\n if (typeof valueChanged === 'boolean') {\n return valueChanged;\n } else if (typeof valueChanged === 'string' && ['true', ''].includes(valueChanged)) {\n return true;\n }\n return false;\n}\n\n/**----------------------------------------------------------------\n * @name validateStringValue\n * @description Validate whether an attribute is set and contains a specific string option\n * @param {SimpleChanges} changes\n * @param {string} attribute\n * @param {string[]} options\n * @param {T | undefined} curVal\n * @returns {string | undefined} Returns correct string value or undefined if either not available or not in list\n */\nexport function validateStringValue<T>(changes: SimpleChanges, attribute: string, options: T[], curVal: T | undefined): T | undefined {\n if (!(attribute in changes)) return curVal;\n const valueChanged = changes[attribute]?.currentValue;\n if (valueChanged && options.includes(valueChanged)) {\n return valueChanged as T;\n }\n return undefined;\n}\n\n/**----------------------------------------------------------------\n * @name validateNumberValue\n * @description Validate whether an attribute is set and contains a specific number value\n * @param {SimpleChanges} changes\n * @param {string} attribute\n * @param {number | undefined} curVal\n * @returns {number | undefined} Returns correct number value or undefined if either not available or not a number\n */\nexport function validateNumberValue(changes: SimpleChanges, attribute: string, curVal: number | undefined): number | undefined {\n if (!(attribute in changes)) return curVal;\n const valueChanged = changes[attribute]?.currentValue;\n if (typeof valueChanged === 'number' && valueChanged >= 0) {\n return valueChanged;\n } else if (typeof valueChanged === 'string' && +valueChanged >= 0) {\n return +valueChanged;\n }\n return undefined;\n}\n","/**\n * CareFirst Library - Page\n *\n * @file page.component\n * @description Contains all the logic for generating a basic CareFirst Page structure\n * @author Jacques Coetzee\n * @since 2023 - 11 - 07\n * @usage <cf-page %centerH% %centerV% %dark% style=\"%--cf-page-inline-padding: 16px%; %--cf-page-max-width: 1300px%; %--footer-bg-color: transparent%\">\n * CONTENT\n * %<ng-container cf-page-buttons></ng-container>%\n * %<ng-container cf-page-footer></ng-container>%\n * </cf-page>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\nimport { checkTruthAttribute } from '../../utils/attribute.util';\n\n@Component({\n selector: 'cf-page',\n templateUrl: './page.component.html',\n styleUrls: ['./page.component.scss'],\n})\nexport class PageComponent implements OnChanges {\n @Input() centerH?: boolean | string | undefined;\n @Input() centerV?: boolean | string | undefined;\n @Input() dark?: boolean | string | undefined;\n\n //--- Local variables\n inputCenterH = false;\n inputCenterV = false;\n inputDark = false;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Center H\n this.inputCenterH = checkTruthAttribute(changes, 'centerH', this.inputCenterH);\n //--- Center V\n this.inputCenterV = checkTruthAttribute(changes, 'centerV', this.inputCenterV);\n //--- Dark\n this.inputDark = checkTruthAttribute(changes, 'dark', this.inputDark);\n }\n}\n","<ion-content class=\"ion-page cf-page\" [ngClass]=\"{ 'bg-dark': inputDark }\">\n <div class=\"main-page\">\n <div id=\"spacing\" [ngClass]=\"{ 'center-h': inputCenterH, 'center-v': inputCenterV }\">\n <div class=\"content\">\n <ng-content></ng-content>\n </div>\n <div id=\"page-buttons\" class=\"content\">\n <ng-content select=\"[cf-page-buttons]\"></ng-content>\n </div>\n </div>\n <div id=\"footer\">\n <div class=\"content\">\n <ng-content select=\"[cf-page-footer]\"></ng-content>\n </div>\n </div>\n </div>\n</ion-content>\n","/**==============================================\n * @interface IconsT\n * @description Short description\n */\nexport const iconsC = [\n 'home',\n 'cog',\n 'profile',\n 'scan',\n 'person',\n 'appointment',\n 'clock',\n 'calendar',\n 'email',\n 'phone',\n 'sign-out',\n 'sign-in',\n 'close',\n 'check-mark',\n 'rating-star-blank',\n 'rating-star-filled',\n 'back-arrow',\n 'lock',\n 'show-password',\n 'hide-password',\n 'circle-check',\n 'circle-alert',\n 'direction-switch',\n 'chat-bubbles',\n 'phone-down',\n 'mic',\n 'no-mic',\n 'button-forward-arrow',\n 'button-check-box',\n 'social-media-whatsapp',\n 'social-media-facebook',\n 'social-media-linkedin',\n 'social-media-instagram',\n 'social-media-google-mail',\n 'instant-video-service',\n 'instant-telephonic-service',\n 'scheduled-video-service',\n 'scheduled-telephonic-service',\n 'vital-scan-service',\n 'open-back-arrow',\n 'open-forward-arrow',\n 'open-up-arrow',\n 'open-down-arrow',\n 'single-document',\n 'lightning',\n 'microsoft-365',\n 'user-dependent',\n 'plus',\n] as const;\nexport type IconsT = (typeof iconsC)[number];\n\n/**==============================================\n * @interface IconColorT\n * @description All available colors in CSS classes\n */\nexport const iconColorC = ['primary', 'secondary', 'success', 'warning', 'error', 'white', 'accent'] as const;\nexport type IconColorT = (typeof iconColorC)[number];\n","/**\n * CareFirst Library - Icon\n *\n * @file icon.component\n * @description Contains all the logic for generating a CareFirst Icon\n * @author Jacques Coetzee\n * @since 2023 - 11 - 07\n * @usage <cf-icon %icon=\"IconsT\"% %iconColor=\"'primary' | 'secondary' | 'success' | 'warning' | 'error' | 'white'\"%></cf-icon>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\nimport { validateStringValue } from '../../utils/attribute.util';\nimport { iconsC, type IconColorT, type IconsT, iconColorC } from '../../interfaces/icon.interface';\n\n@Component({\n selector: 'cf-icon',\n templateUrl: './icon.component.html',\n styleUrls: ['./icon.component.scss'],\n})\nexport class IconComponent implements OnChanges {\n @Input() icon!: IconsT;\n @Input() height?: number;\n @Input() iconColor?: IconColorT;\n\n //--- Local variables\n inputIcon: typeof this.icon | undefined = undefined;\n inputColor: typeof this.iconColor | undefined = undefined;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Type\n this.inputIcon = validateStringValue<IconsT>(changes, 'icon', iconsC.slice(), this.inputIcon);\n //--- Color\n this.inputColor = validateStringValue<IconColorT>(changes, 'iconColor', iconColorC.slice(), this.inputColor);\n }\n}\n","<div class=\"app-icon-container\" [ngStyle]=\"{ height: (this.height || 20) + 'px' }\" [ngClass]=\"iconColor\">\n <!-- person -->\n <svg *ngIf=\"inputIcon === 'person'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <circle cx=\"10\" cy=\"5\" r=\"4\" stroke-width=\"1.5\" />\n <path d=\"M2 19C3 10 17 10 18 19\" stroke-width=\"1.5\" stroke-linecap=\"round\" />\n </svg>\n <!-- appointment -->\n <svg\n *ngIf=\"inputIcon === 'appointment'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n style=\"stroke-width: 1.5; stroke-linecap: round\">\n <rect width=\"16\" height=\"16\" x=\"2\" y=\"3\" rx=\"2\" ry=\"2\" />\n <line x1=\"6\" y1=\"1\" x2=\"6\" y2=\"3\" />\n <line x1=\"14\" y1=\"1\" x2=\"14\" y2=\"3\" />\n <line x1=\"2\" y1=\"7\" x2=\"18\" y2=\"7\" />\n <line x1=\"6\" y1=\"11\" x2=\"14\" y2=\"11\" />\n </svg>\n <!-- clock -->\n <svg *ngIf=\"inputIcon === 'clock'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <circle cx=\"10\" cy=\"10\" r=\"9\" stroke-width=\"1.5\" />\n <path d=\"M10 6L10 10L13 13\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- calendar -->\n <svg *ngIf=\"inputIcon === 'calendar'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 22 20\" fill=\"none\">\n <path\n d=\"M1 6.50508H21M4.01099 2.50004V2C4.01099 1.72386 4.23484 1.5 4.51099 1.5H17.4878C17.7639 1.5 17.9878 1.72386 17.9878 2V2.50004M4.98834 9.00006H5.03295M4.96603 12.1079H5.01064M4.94379 15.2158H4.9884M9.03296 9.00006H9.07757M9.01065 12.1079H9.05526M8.98834 15.2158H9.03295M13.0776 9.00006H13.1222M13.0553 12.1079H13.0999M13.033 15.2158H13.0776M17.1222 9.00006H17.1668M17.0999 12.1079H17.1445M17.0776 15.2158H17.1222M3 18.5H19C20.1046 18.5 21 17.6046 21 16.5V4.5C21 3.39543 20.1046 2.5 19 2.5H3C1.89543 2.5 1 3.39543 1 4.5V16.5C1 17.6046 1.89543 18.5 3 18.5Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- email -->\n <svg *ngIf=\"inputIcon === 'email'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 16\" fill=\"none\">\n <path\n d=\"M2 2L10.2286 8L17.9999 2M19 4.19995V11.8C19 12.9201 19.0002 13.4802 18.7822 13.908C18.5905 14.2844 18.2841 14.5902 17.9078 14.782C17.48 15 16.9203 15 15.8002 15H4.2002C3.08009 15 2.51962 15 2.0918 14.782C1.71547 14.5902 1.40973 14.2844 1.21799 13.908C1 13.4802 1 12.9201 1 11.8V4.19995C1 3.07985 1 2.51986 1.21799 2.09204C1.40973 1.71572 1.71547 1.40973 2.0918 1.21799C2.51962 1 3.08009 1 4.2002 1H15.8002C16.9203 1 17.48 1 17.9078 1.21799C18.2841 1.40973 18.5905 1.71572 18.7822 2.09204C19.0002 2.51986 19 3.07985 19 4.19995Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- phone -->\n <svg *ngIf=\"inputIcon === 'phone'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 22 22\" fill=\"none\">\n <path\n d=\"M20.97 17.33C20.97 17.69 20.89 18.06 20.72 18.42C20.55 18.78 20.33 19.12 20.04 19.44C19.55 19.98 19.01 20.37 18.4 20.62C17.8 20.87 17.15 21 16.45 21C15.43 21 14.34 20.76 13.19 20.27C12.04 19.78 10.89 19.12 9.75 18.29C8.6 17.45 7.51 16.52 6.47 15.49C5.44 14.45 4.51 13.36 3.68 12.22C2.86 11.08 2.2 9.94 1.72 8.81C1.24 7.67 1 6.58 1 5.54C1 4.86 1.12 4.21 1.36 3.61C1.6 3 1.98 2.44 2.51 1.94C3.15 1.31 3.85 1 4.59 1C4.87 1 5.15 1.06 5.4 1.18C5.66 1.3 5.89 1.48 6.07 1.74L8.39 5.01C8.57 5.26 8.7 5.49 8.79 5.71C8.88 5.92 8.93 6.13 8.93 6.32C8.93 6.56 8.86 6.8 8.72 7.03C8.59 7.26 8.4 7.5 8.16 7.74L7.4 8.53C7.29 8.64 7.24 8.77 7.24 8.93C7.24 9.01 7.25 9.08 7.27 9.16C7.3 9.24 7.33 9.3 7.35 9.36C7.53 9.69 7.84 10.12 8.28 10.64C8.73 11.16 9.21 11.69 9.73 12.22C10.27 12.75 10.79 13.24 11.32 13.69C11.84 14.13 12.27 14.43 12.61 14.61C12.66 14.63 12.72 14.66 12.79 14.69C12.87 14.72 12.95 14.73 13.04 14.73C13.21 14.73 13.34 14.67 13.45 14.56L14.21 13.81C14.46 13.56 14.7 13.37 14.93 13.25C15.16 13.11 15.39 13.04 15.64 13.04C15.83 13.04 16.03 13.08 16.25 13.17C16.47 13.26 16.7 13.39 16.95 13.56L20.26 15.91C20.52 16.09 20.7 16.3 20.81 16.55C20.91 16.8 20.97 17.05 20.97 17.33Z\"\n stroke-width=\"1.5\"\n stroke-miterlimit=\"10\" />\n <path d=\"M14 1C17 1 21 4 21 8\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path d=\"M14 4C16 4 18 6 18 8\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- home -->\n <svg *ngIf=\"inputIcon === 'home'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M1.97409 6.39868L9.14434 1.56272C9.64904 1.22233 10.3094 1.22072 10.8158 1.55865L18.0692 6.39951C18.6251 6.77052 18.959 7.39471 18.959 8.06306V19H12.0095V13.0287C12.0095 11.9177 11.1089 11.0171 9.99786 11.0171C8.88685 11.0171 7.9862 11.9177 7.9862 13.0287V19H1.09241V8.0568C1.09241 7.3919 1.42285 6.77047 1.97409 6.39868Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- cog -->\n <svg *ngIf=\"inputIcon === 'cog'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 18 18\" fill=\"none\">\n <path\n d=\"M10.4014 0.7771C10.6692 0.7771 10.9258 0.884538 11.1138 1.07535L12.4463 2.4281C12.5731 2.55681 12.7323 2.64876 12.9072 2.6942L14.745 3.1718C15.0042 3.23917 15.2255 3.4077 15.3595 3.63965L16.7608 6.06688C16.8947 6.29883 16.93 6.5748 16.8587 6.83298L16.3535 8.66333C16.3054 8.83748 16.3054 9.02139 16.3535 9.19553L16.8587 11.0259C16.93 11.2841 16.8947 11.56 16.7608 11.792L15.3595 14.2192C15.2255 14.4512 15.0042 14.6197 14.745 14.6871L12.9072 15.1647C12.7323 15.2101 12.5731 15.3021 12.4463 15.4308L11.1138 16.7835C10.9258 16.9743 10.6692 17.0818 10.4014 17.0818H7.59865C7.33082 17.0818 7.07418 16.9743 6.88623 16.7835L5.55373 15.4308C5.42695 15.3021 5.26768 15.2101 5.09283 15.1647L3.25506 14.6871C2.99584 14.6197 2.77448 14.4512 2.64056 14.2192L1.2392 11.792C1.10529 11.56 1.07001 11.2841 1.14128 11.0259L1.64655 9.19553C1.69462 9.02139 1.69462 8.83748 1.64655 8.66333L1.14128 6.83298C1.07001 6.5748 1.10529 6.29883 1.2392 6.06688L2.64056 3.63965C2.77448 3.4077 2.99584 3.23917 3.25506 3.1718L5.09283 2.6942C5.26768 2.64876 5.42695 2.55681 5.55373 2.4281L6.88623 1.07535C7.07418 0.884538 7.33082 0.7771 7.59865 0.7771H10.4014Z\"\n stroke-width=\"1.5\" />\n <path\n d=\"M12.1179 8.92943C12.1179 10.6114 10.7544 11.9748 9.07247 11.9748C7.39054 11.9748 6.02706 10.6114 6.02706 8.92943C6.02706 7.2475 7.39054 5.88402 9.07247 5.88402C10.7544 5.88402 12.1179 7.2475 12.1179 8.92943Z\"\n stroke-width=\"1.5\" />\n </svg>\n <!-- profile -->\n <svg *ngIf=\"inputIcon === 'profile'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M15 18.9294C15 16.168 12.7614 13.9294 10 13.9294C7.23858 13.9294 5 16.168 5 18.9294M10 10.9294C8.34315 10.9294 7 9.5863 7 7.92944C7 6.27259 8.34315 4.92944 10 4.92944C11.6569 4.92944 13 6.27259 13 7.92944C13 9.5863 11.6569 10.9294 10 10.9294ZM19 4.12939V15.7294C19 16.8495 19.0002 17.4097 18.7822 17.8375C18.5905 18.2138 18.2841 18.5197 17.9078 18.7114C17.48 18.9294 16.9203 18.9294 15.8002 18.9294H4.2002C3.08009 18.9294 2.51962 18.9294 2.0918 18.7114C1.71547 18.5197 1.40973 18.2138 1.21799 17.8375C1 17.4097 1 16.8495 1 15.7294V4.12939C1 3.00929 1 2.44931 1.21799 2.02148C1.40973 1.64516 1.71547 1.33918 2.0918 1.14743C2.51962 0.929443 3.08009 0.929443 4.2002 0.929443H15.8002C16.9203 0.929443 17.48 0.929443 17.9078 1.14743C18.2841 1.33918 18.5905 1.64516 18.7822 2.02148C19.0002 2.44931 19 3.00929 19 4.12939Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- scan -->\n <svg *ngIf=\"inputIcon === 'scan'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M1 5V2C1 1.44772 1.44772 1 2 1H5M1 15V18C1 18.5523 1.44772 19 2 19H5M19 5V2C19 1.44772 18.5523 1 18 1H15M19 15V18C19 18.5523 18.5523 19 18 19H15M2 10H18\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- sign-out -->\n <svg *ngIf=\"inputIcon === 'sign-out'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M7.80053 9.94781H17.7201M15.708 7.4576L18.9408 9.93332L15.708 12.4013M14.9327 4.89544V2.99078C14.9327 1.88621 14.0373 0.990784 12.9327 0.990784H3.05328C1.94871 0.990784 1.05328 1.88621 1.05328 2.99078V16.9978C1.05328 18.1024 1.94871 18.9978 3.05328 18.9978H12.9327C14.0373 18.9978 14.9327 18.1024 14.9327 16.9978V14.9943\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- sign-in -->\n <svg *ngIf=\"inputIcon === 'sign-in'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M1.07129 10.0204H10.9908M8.97873 7.53022L12.2115 10.0059L8.97873 12.4739M4.03967 7.11697V3.06152C4.03967 1.95695 4.9351 1.06152 6.03967 1.06152H16.9409C18.0454 1.06152 18.9409 1.95695 18.9409 3.06152V17.0685C18.9409 18.1731 18.0454 19.0685 16.9409 19.0685H6.03967C4.9351 19.0685 4.03967 18.1731 4.03967 17.0685V13.1326\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- close -->\n <svg *ngIf=\"inputIcon === 'close'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 14 14\" fill=\"none\">\n <path d=\"M1.37749 12.6423L12.6705 1.3492M12.6705 12.6423L1.37749 1.3492\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- rating-star-blank -->\n <svg *ngIf=\"inputIcon === 'rating-star-blank'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 32 31\" fill=\"none\">\n <path\n d=\"M15.2481 1.90951C15.55 1.27691 16.4504 1.27691 16.7523 1.90951L20.6057 9.98487C20.7271 10.2395 20.9692 10.4153 21.2488 10.4522L30.1197 11.6215C30.8146 11.7131 31.0929 12.5695 30.5845 13.0521L24.0952 19.2123C23.8906 19.4065 23.7981 19.691 23.8495 19.9684L25.4786 28.7665C25.6063 29.4557 24.8778 29.985 24.2617 29.6506L16.3977 25.3825C16.1498 25.2479 15.8506 25.2479 15.6027 25.3825L7.73866 29.6506C7.12262 29.985 6.39413 29.4557 6.52175 28.7665L8.15088 19.9684C8.20225 19.691 8.1098 19.4065 7.90521 19.2123L1.41584 13.0521C0.907481 12.5695 1.18574 11.7131 1.88066 11.6215L10.7515 10.4522C11.0312 10.4153 11.2732 10.2395 11.3947 9.98487L15.2481 1.90951Z\"\n stroke-width=\"1.5\" />\n </svg>\n <!-- rating-star-filled -->\n <svg\n *ngIf=\"inputIcon === 'rating-star-filled'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 32 31\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M15.2481 1.90951C15.55 1.27691 16.4504 1.27691 16.7523 1.90951L20.6057 9.98487C20.7271 10.2395 20.9692 10.4153 21.2488 10.4522L30.1197 11.6215C30.8146 11.7131 31.0929 12.5695 30.5845 13.0521L24.0952 19.2123C23.8906 19.4065 23.7981 19.691 23.8495 19.9684L25.4786 28.7665C25.6063 29.4557 24.8778 29.985 24.2617 29.6506L16.3977 25.3825C16.1498 25.2479 15.8506 25.2479 15.6027 25.3825L7.73866 29.6506C7.12262 29.985 6.39413 29.4557 6.52175 28.7665L8.15088 19.9684C8.20225 19.691 8.1098 19.4065 7.90521 19.2123L1.41584 13.0521C0.907481 12.5695 1.18574 11.7131 1.88066 11.6215L10.7515 10.4522C11.0312 10.4153 11.2732 10.2395 11.3947 9.98487L15.2481 1.90951Z\"\n stroke-width=\"1.5\" />\n </svg>\n <!-- check-mark -->\n <svg *ngIf=\"inputIcon === 'check-mark'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M1 10L7 16L19 4\" stroke-width=\"1.7\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- back-arrow -->\n <svg *ngIf=\"inputIcon === 'back-arrow'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M6.5 5L1 10L6.5 15M1 10L19 10\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- lock -->\n <svg *ngIf=\"inputIcon === 'lock'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 25 27\" style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M12.5 13C11.6595 13.0003 10.8472 13.303 10.2115 13.8529C9.57579 14.4027 9.1592 15.163 9.03785 15.9947C8.9165 16.8264 9.0985 17.674 9.55058 18.3825C10.0027 19.0911 10.6946 19.6133 11.5 19.8538V22C11.5 22.2652 11.6054 22.5196 11.7929 22.7071C11.9804 22.8946 12.2348 23 12.5 23C12.7652 23 13.0196 22.8946 13.2071 22.7071C13.3946 22.5196 13.5 22.2652 13.5 22V19.8538C14.3054 19.6133 14.9973 19.0911 15.4494 18.3825C15.9015 17.674 16.0835 16.8264 15.9622 15.9947C15.8408 15.163 15.4242 14.4027 14.7885 13.8529C14.1528 13.303 13.3405 13.0003 12.5 13ZM12.5 18C12.2033 18 11.9133 17.912 11.6666 17.7472C11.42 17.5824 11.2277 17.3481 11.1142 17.074C11.0006 16.7999 10.9709 16.4983 11.0288 16.2074C11.0867 15.9164 11.2296 15.6491 11.4393 15.4393C11.6491 15.2296 11.9164 15.0867 12.2074 15.0288C12.4983 14.9709 12.7999 15.0007 13.074 15.1142C13.3481 15.2277 13.5824 15.42 13.7472 15.6666C13.912 15.9133 14 16.2033 14 16.5C14 16.8978 13.842 17.2794 13.5607 17.5607C13.2794 17.842 12.8978 18 12.5 18ZM22.5 9H18.5V6C18.5 4.4087 17.8679 2.88258 16.7426 1.75736C15.6174 0.632141 14.0913 0 12.5 0C10.9087 0 9.38258 0.632141 8.25736 1.75736C7.13214 2.88258 6.5 4.4087 6.5 6V9H2.5C1.96957 9 1.46086 9.21071 1.08579 9.58579C0.710714 9.96086 0.5 10.4696 0.5 11V25C0.5 25.5304 0.710714 26.0391 1.08579 26.4142C1.46086 26.7893 1.96957 27 2.5 27H22.5C23.0304 27 23.5391 26.7893 23.9142 26.4142C24.2893 26.0391 24.5 25.5304 24.5 25V11C24.5 10.4696 24.2893 9.96086 23.9142 9.58579C23.5391 9.21071 23.0304 9 22.5 9ZM8.5 6C8.5 4.93913 8.92143 3.92172 9.67157 3.17157C10.4217 2.42143 11.4391 2 12.5 2C13.5609 2 14.5783 2.42143 15.3284 3.17157C16.0786 3.92172 16.5 4.93913 16.5 6V9H8.5V6ZM22.5 25H2.5V11H22.5V25Z\" />\n </svg>\n <!-- show-password -->\n <svg *ngIf=\"inputIcon === 'show-password'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <ellipse cx=\"10\" cy=\"10\" rx=\"9\" ry=\"4\" stroke-width=\"1\" />\n <circle cx=\"10\" cy=\"10\" r=\"2.5\" stroke-width=\"1\" />\n </svg>\n <!-- hide-password -->\n <svg *ngIf=\"inputIcon === 'hide-password'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <ellipse cx=\"10\" cy=\"10\" rx=\"9\" ry=\"4\" stroke-width=\"1\" />\n <circle cx=\"10\" cy=\"10\" r=\"2.5\" stroke-width=\"1\" />\n <line x1=\"1\" y1=\"4\" x2=\"19\" y2=\"16\" stroke-width=\"1\" stroke-linecap=\"round\" />\n </svg>\n <!-- circle-check -->\n <svg *ngIf=\"inputIcon === 'circle-check'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <circle cx=\"10\" cy=\"10\" r=\"9\" stroke-width=\"1.5\" />\n <path d=\"M5.5 11L9 14L14.5 7.5\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- circle-alert -->\n <svg *ngIf=\"inputIcon === 'circle-alert'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path\n d=\"M10.0002 19.1666C15.0418 19.1666 19.1668 15.0416 19.1668 9.99998C19.1668 4.95831 15.0418 0.833313 10.0002 0.833313C4.9585 0.833313 0.833496 4.95831 0.833496 9.99998C0.833496 15.0416 4.9585 19.1666 10.0002 19.1666Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n <path d=\"M10 6.33331V10.9166\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path d=\"M9.99512 13.6667H10.0034\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- direction-switch -->\n <svg *ngIf=\"inputIcon === 'direction-switch'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 18 18\" fill=\"none\">\n <path\n d=\"M15.3805 4.2C14.7138 3.13333 12.5005 1 8.98046 1C4.58046 1 0.980469 3.8 0.980469 8.99999M12.9805 5H16.1804V1.8M2.67738 13.8C3.34405 14.8667 5.55738 17 9.07738 17C13.4774 17 17.0774 14.2 17.0774 9M5.07738 13H1.87739V16.2\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- chat-bubbles -->\n <svg\n *ngIf=\"inputIcon === 'chat-bubbles'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\">\n <path d=\"M 1 19 V 7 S 1 5 3 5 H 13 S 15 5 15 7 V 15 S 15 17 13 17 H 3.5 Z\" />\n <path d=\"M 4 9 H 12 M 4 13 H 12\" />\n <path d=\"M 3 5 V 3 S 3 1 5 1 H 17 S 19 1 19 3 V 15 L 16.5 13 15 13\" />\n </svg>\n <!-- phone-down -->\n <svg *ngIf=\"inputIcon === 'phone-down'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 -8 29 29\" style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M22.6589 11.7706C23.4866 12.1253 24.4468 11.9404 25.0836 11.3036L27.2257 9.16151C28.0404 8.34676 28.0404 7.02577 27.2257 6.21102C20.3003 -0.714333 9.072 -0.714112 2.14665 6.21124C1.3319 7.02599 1.33198 8.34672 2.14673 9.16146L4.28896 11.3035C4.9257 11.9403 5.88596 12.1251 6.71364 11.7704L9.58644 10.5392C10.3299 10.2206 10.8388 9.52027 10.912 8.71471L11.0005 7.74261C11.1036 6.60831 12.0546 5.7398 13.1936 5.73979L16.1789 5.73968C17.3179 5.73968 18.2687 6.60846 18.3719 7.74277L18.4602 8.71468C18.5335 9.52024 19.0425 10.2207 19.786 10.5393L22.6589 11.7706Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- mic -->\n <svg\n *ngIf=\"inputIcon === 'mic'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n stroke-width=\"1\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\">\n <path d=\"M 6 5 C 6 0 14 0 14 5 V 9 C 14 14 6 14 6 9 V 5 M 6 5 H 8 M 6 7 H 8 M 6 9 H 8 M 14 5 H 12 M 14 7 H 12 M 14 9 H 12\" />\n <path d=\"M 4 9 C 4 17 16 17 16 9 \" />\n <path d=\"M 9 15 V 18 H 7 S 5 18 5 19.7 H 15 S 15 18 13 18 H 11 V 15\" />\n </svg>\n <!-- no-mic -->\n <svg\n *ngIf=\"inputIcon === 'no-mic'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 20 20\"\n fill=\"none\"\n stroke-width=\"1\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\">\n <path d=\"M 6 5 C 6 0 14 0 14 5 V 9 C 14 14 6 14 6 9 V 5 M 6 5 H 8 M 6 7 H 8 M 6 9 H 8 M 14 5 H 12 M 14 7 H 12 M 14 9 H 12\" />\n <path d=\"M 4 9 C 4 17 16 17 16 9 \" />\n <path d=\"M 9 15 V 18 H 7 S 5 18 5 19.7 H 15 S 15 18 13 18 H 11 V 15\" />\n <line x1=\"1\" y1=\"1\" x2=\"19\" y2=\"19\" />\n </svg>\n <!-- Button Icons -->\n <!-- button-forward-arrow -->\n <svg *ngIf=\"inputIcon === 'button-forward-arrow'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 25 25\" fill=\"none\">\n <path d=\"M5.5 12.5H19.5\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n <path d=\"M12.5 5.5L19.5 12.5L12.5 19.5\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- button-check-box -->\n <svg *ngIf=\"inputIcon === 'button-check-box'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 20 20\" fill=\"none\">\n <rect x=\"1\" y=\"1\" rx=\"4\" ry=\"4\" width=\"18\" height=\"18\" stroke-width=\"1.5\" />\n <path d=\"M5 11L9 14L15 6\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- Social Media Icons -->\n <!-- social-media-whatsapp -->\n <svg\n *ngIf=\"inputIcon === 'social-media-whatsapp'\"\n viewBox=\"-1 -1 27 27\"\n xmlns=\"http://www.w3.org/2000/svg\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M18.2273 14.9814C17.9163 14.8265 16.3871 14.0777 16.102 13.9743C15.8169 13.871 15.6096 13.8195 15.4022 14.1293C15.1949 14.4391 14.5988 15.1364 14.4174 15.343C14.236 15.5495 14.0545 15.5755 13.7436 15.4204C13.4325 15.2655 12.4303 14.9387 11.2423 13.884C10.3178 13.0633 9.69351 12.0497 9.51211 11.7398C9.33066 11.4299 9.49273 11.2624 9.64844 11.108C9.78843 10.9693 9.95952 10.7465 10.115 10.5657C10.2706 10.385 10.3224 10.2558 10.426 10.0494C10.5297 9.84273 10.4779 9.66201 10.4 9.50709C10.3224 9.35217 9.70034 7.82853 9.44116 7.20866C9.18867 6.60517 8.93227 6.6869 8.74136 6.67733C8.56016 6.66839 8.35254 6.66649 8.14526 6.66649C7.93794 6.66649 7.60093 6.74395 7.31582 7.05374C7.03076 7.36363 6.22729 8.11257 6.22729 9.63606C6.22729 11.1597 7.34175 12.6315 7.49727 12.8381C7.65278 13.0448 9.69043 16.1712 12.8105 17.512C13.5525 17.831 14.1319 18.0214 14.5836 18.1641C15.3287 18.3997 16.0067 18.3665 16.5426 18.2867C17.1402 18.1979 18.3828 17.538 18.642 16.815C18.9011 16.0918 18.9011 15.4721 18.8234 15.343C18.7457 15.2138 18.5383 15.1364 18.2273 14.9814ZM12.5523 22.693H12.5481C10.6916 22.6923 8.8707 22.1959 7.28223 21.2578L6.90439 21.0346L2.98867 22.0569L4.03384 18.2573L3.78789 17.8677C2.7522 16.2284 2.20518 14.3336 2.20601 12.3881C2.2083 6.711 6.84956 2.09234 12.5564 2.09234C15.3198 2.09326 17.9175 3.16569 19.8709 5.11195C21.8243 7.05816 22.8994 9.64514 22.8983 12.3964C22.8959 18.0739 18.2547 22.693 12.5523 22.693ZM21.3576 3.63307C19.0074 1.2915 15.8821 0.00136065 12.5521 0C5.69111 0 0.10708 5.55698 0.104297 12.3873C0.103418 14.5707 0.676563 16.7018 1.76592 18.5806L0 25L6.59868 23.2773C8.41685 24.2643 10.4639 24.7845 12.5472 24.7852H12.5523C19.4126 24.7852 24.9972 19.2276 25 12.3972C25.0013 9.08708 23.7077 5.97465 21.3576 3.63307Z\" />\n </svg>\n <!-- social-media-facebook -->\n <svg\n *ngIf=\"inputIcon === 'social-media-facebook'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"-1 -1 27 27\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M25 12.5764C25 5.63064 19.4036 0 12.5 0C5.59644 0 0 5.63064 0 12.5764C0 18.8536 4.57109 24.0565 10.5469 25V16.2118H7.37305V12.5764H10.5469V9.80566C10.5469 6.6537 12.413 4.91265 15.2683 4.91265C16.6359 4.91265 18.0664 5.15829 18.0664 5.15829V8.25326H16.4902C14.9374 8.25326 14.4531 9.22267 14.4531 10.2172V12.5764H17.9199L17.3657 16.2118H14.4531V25C20.429 24.0565 25 18.8536 25 12.5764Z\" />\n </svg>\n <!-- social-media-linkedin -->\n <svg\n *ngIf=\"inputIcon === 'social-media-linkedin'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 25 25\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M23.3696 0H1.63043C0.733696 0 0 0.733696 0 1.63043V23.3696C0 24.2663 0.733696 25 1.63043 25H23.3696C24.2663 25 25 24.2663 25 23.3696V1.63043C25 0.733696 24.2663 0 23.3696 0ZM3.39674 4.75543C3.83152 4.32065 4.42935 4.07609 5.02717 4.07609C5.625 4.07609 6.22283 4.32065 6.65761 4.75543C7.09239 5.19022 7.33696 5.76087 7.33696 6.38587C7.33696 7.01087 7.09239 7.6087 6.63043 8.04348C6.19565 8.45109 5.625 8.69565 5.05435 8.69565C5.02717 8.69565 5.02717 8.69565 5 8.69565C4.42935 8.72283 3.83152 8.47826 3.39674 8.04348C2.96196 7.6087 2.71739 7.01087 2.71739 6.38587C2.71739 5.76087 2.96196 5.19022 3.39674 4.75543ZM7.33696 21.4946C7.33696 21.9293 6.95652 22.2826 6.52174 22.2826H3.53261C3.09783 22.2826 2.71739 21.9022 2.71739 21.4674V11.6848C2.71739 11.2228 3.07065 10.8696 3.50543 10.8696H6.52174C6.95652 10.8696 7.33696 11.25 7.33696 11.6848V21.4946ZM22.2826 21.7391C22.2826 22.0109 22.0109 22.2826 21.7391 22.2826H18.2065C17.9348 22.2826 17.663 22.0109 17.663 21.7391V15.6522C17.663 15.163 17.5543 14.7826 17.2826 14.538C16.9837 14.2391 16.5761 14.0489 16.1413 14.0761C15.2446 14.0761 14.1033 14.837 14.1033 15.6793V21.8207C14.1033 22.1196 13.8043 22.3098 13.5598 22.3098H10.0272C9.78261 22.3098 9.4837 22.1196 9.4837 21.8207V11.3859C9.4837 11.087 9.78261 10.8696 10.0272 10.8696H13.288C13.5598 10.8696 13.8315 11.1413 13.8315 11.413V11.8207C14.5652 11.0598 16.0326 10.5978 17.0924 10.5978H17.663C19.8098 10.5978 22.2826 12.2826 22.2826 14.4565V21.7391Z\" />\n </svg>\n <!-- social-media-instagram -->\n <svg\n *ngIf=\"inputIcon === 'social-media-instagram'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 25 25\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"M12.5 0C9.1052 0 8.67952 0.0143895 7.34627 0.0752221C6.01579 0.135956 5.10712 0.347233 4.31198 0.656259C3.48999 0.975705 2.7929 1.40312 2.09798 2.09803C1.40307 2.79294 0.975655 3.49004 0.656209 4.31203C0.347183 5.10712 0.135906 6.01579 0.0751725 7.34627C0.0143398 8.67952 0 9.1052 0 12.5C0 15.8948 0.0143398 16.3205 0.0751725 17.6537C0.135906 18.9842 0.347183 19.8929 0.656209 20.688C0.975655 21.51 1.40307 22.2071 2.09798 22.902C2.7929 23.5969 3.48999 24.0243 4.31198 24.3438C5.10712 24.6528 6.01579 24.8641 7.34627 24.9248C8.67952 24.9856 9.1052 25 12.5 25C15.8948 25 16.3205 24.9856 17.6537 24.9248C18.9842 24.8641 19.8929 24.6528 20.688 24.3438C21.51 24.0243 22.2071 23.5969 22.902 22.902C23.5969 22.2071 24.0243 21.51 24.3438 20.688C24.6528 19.8929 24.8641 18.9842 24.9248 17.6537C24.9856 16.3205 25 15.8948 25 12.5C25 9.1052 24.9856 8.67952 24.9248 7.34627C24.8641 6.01579 24.6528 5.10712 24.3438 4.31203C24.0243 3.49004 23.5969 2.79294 22.902 2.09803C22.2071 1.40312 21.51 0.975705 20.688 0.656259C19.8929 0.347233 18.9842 0.135956 17.6537 0.0752221C16.3205 0.0143895 15.8948 0 12.5 0ZM12.5 2.2523C15.8376 2.2523 16.233 2.265 17.5511 2.32514C18.7698 2.38076 19.4317 2.5844 19.8721 2.75553C20.4556 2.98229 20.872 3.25321 21.3094 3.6906C21.7468 4.12799 22.0177 4.54444 22.2445 5.12786C22.4157 5.56832 22.6193 6.23019 22.6749 7.44893C22.735 8.767 22.7478 9.16236 22.7478 12.5C22.7478 15.8376 22.735 16.233 22.6749 17.5511C22.6193 18.7698 22.4157 19.4317 22.2445 19.8721C22.0177 20.4556 21.7468 20.872 21.3094 21.3094C20.872 21.7468 20.4556 22.0177 19.8721 22.2445C19.4317 22.4157 18.7698 22.6193 17.5511 22.6749C16.2332 22.735 15.8379 22.7478 12.5 22.7478C9.16212 22.7478 8.76685 22.735 7.44893 22.6749C6.23019 22.6193 5.56832 22.4157 5.12786 22.2445C4.54439 22.0177 4.12799 21.7468 3.69055 21.3094C3.25316 20.872 2.98224 20.4556 2.75553 19.8721C2.58435 19.4317 2.38071 18.7698 2.32509 17.5511C2.26495 16.233 2.25225 15.8376 2.25225 12.5C2.25225 9.16236 2.26495 8.767 2.32509 7.44893C2.38071 6.23019 2.58435 5.56832 2.75553 5.12786C2.98224 4.54444 3.25316 4.12799 3.69055 3.6906C4.12799 3.25321 4.54439 2.98229 5.12786 2.75553C5.56832 2.5844 6.23019 2.38076 7.44893 2.32514C8.767 2.265 9.16236 2.2523 12.5 2.2523Z\" />\n <path\n d=\"M12.5 16.6666C10.1988 16.6666 8.3333 14.8012 8.3333 12.5C8.3333 10.1988 10.1988 8.3333 12.5 8.3333C14.8012 8.3333 16.6666 10.1988 16.6666 12.5C16.6666 14.8012 14.8012 16.6666 12.5 16.6666ZM12.5 6.08105C8.95488 6.08105 6.08105 8.95488 6.08105 12.5C6.08105 16.0451 8.95488 18.9189 12.5 18.9189C16.0451 18.9189 18.9189 16.0451 18.9189 12.5C18.9189 8.95488 16.0451 6.08105 12.5 6.08105Z\" />\n <path\n d=\"M20.6726 5.82761C20.6726 6.65605 20.001 7.32759 19.1726 7.32759C18.3442 7.32759 17.6726 6.65605 17.6726 5.82761C17.6726 4.99918 18.3442 4.32764 19.1726 4.32764C20.001 4.32764 20.6726 4.99918 20.6726 5.82761Z\" />\n </svg>\n <!-- social-media-google-mail -->\n <svg\n *ngIf=\"inputIcon === 'social-media-google-mail'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 22 17\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <g clip-path=\"url(#clip0_1282_2376)\">\n <path\n d=\"M0.000141144 15.7966C0.11293 16.0839 0.234306 16.3624 0.46389 16.5802C0.745003 16.8469 1.06848 16.9971 1.45093 16.9982C2.54561 17.0012 3.64028 17.0006 4.73553 17.0006C5.01607 17.0006 5.02466 16.9923 5.02466 16.7033C5.02523 14.0175 5.02523 11.3318 5.02523 8.646C5.02523 8.55181 5.02523 8.45761 5.02523 8.36106C5.13745 8.35282 5.18726 8.42523 5.24623 8.47115C7.09034 9.89116 8.93446 11.3106 10.7728 12.7388C10.9412 12.8695 11.0511 12.863 11.216 12.7353C13.0549 11.3082 14.8991 9.88821 16.7426 8.46762C16.7981 8.42464 16.8577 8.33692 16.9195 8.36342C17.0054 8.39933 16.9607 8.50706 16.9607 8.58242C16.963 11.2682 16.9625 13.9539 16.9625 16.6397C16.9625 16.9976 16.963 16.9982 17.3003 16.9982C18.352 16.9982 19.4043 17.0006 20.456 16.9971C21.3549 16.9941 21.991 16.3336 21.9916 15.4046C21.9927 12.4762 21.9916 9.54734 21.9921 6.61903C21.9933 5.22022 21.9893 3.822 22.0001 2.42378C22.0076 1.45297 21.6017 0.724131 20.7772 0.283176C19.9333 -0.168375 19.0997 -0.0718245 18.3348 0.515134C16.7581 1.72555 15.1859 2.94244 13.612 4.15639C12.8048 4.77867 11.9946 5.39742 11.1937 6.02795C11.0391 6.14922 10.9377 6.14275 10.786 6.025C8.90641 4.56732 7.02221 3.11671 5.13859 1.66491C4.62904 1.27223 4.11777 0.882497 3.6065 0.492173C2.31259 -0.495706 0.49538 0.14777 0.0631199 1.74616C0.0459442 1.80974 0.0213261 1.87038 -0.000429153 1.93278C0.000143051 6.55368 0.000141144 11.1752 0.000141144 15.7966Z\" />\n </g>\n <defs>\n <clipPath id=\"clip0_1282_2376\">\n <rect width=\"22\" height=\"17\" transform=\"matrix(-1 0 0 1 22 0)\" />\n </clipPath>\n </defs>\n </svg>\n <!-- Instant Video Service -->\n <svg\n *ngIf=\"inputIcon === 'instant-video-service'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 80 80\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"m40.2,3.08c-7.13-.08-13,5.67-13.05,12.82-.05,7.01,5.53,12.88,12.7,13.01,7.13.14,13.01-5.56,13.12-12.75.12-7.11-5.61-13-12.77-13.08Zm-.15,21.93c-4.88.04-8.97-4.01-9-8.92-.04-5.01,3.96-9.07,8.97-9.11,4.94-.03,9.03,3.99,9.06,8.9.03,5.07-3.95,9.09-9.03,9.13Z\" />\n <g>\n <g>\n <path\n d=\"m45.29,62.33c.4.41.4,1.06,0,1.46l-4.21,4.2c-.19.19-.45.3-.72.3s-.54-.11-.73-.3l-4.2-4.2c-.4-.4-.4-1.05,0-1.46.4-.4,1.05-.4,1.46,0l3.47,3.48,3.47-3.48c.4-.4,1.05-.4,1.46,0Z\" />\n <path\n d=\"m35.43,59.61c-.4-.4-.4-1.05,0-1.45.4-.4,1.04-.4,1.45,0h.01l3.47,3.48,3.47-3.48h.01c.4-.4,1.04-.4,1.45,0,.4.4.4,1.05,0,1.45l-4.21,4.21c-.2.2-.46.3-.72.3s-.53-.1-.73-.3l-4.2-4.21Z\" />\n <path\n d=\"m66.36,45.57c-.2-1.35-.47-2.69-.94-3.98-.9-2.46-2.37-4.55-4.19-6.41-1.51-1.53-3.2-2.84-5.02-3.98-1.43-.88-2.9-1.67-4.45-2.31-.75-.3-1.63-.13-2.14.47-.72.83-1.61,1.43-2.58,1.92-2.68,1.36-5.52,1.86-8.51,1.57-2.05-.19-4-.77-5.81-1.77-.76-.42-1.49-.9-2.06-1.56-.63-.73-1.43-.96-2.33-.61-.73.28-1.46.57-2.17.91-2.97,1.42-5.61,3.3-7.8,5.77-1.77,1.99-3.1,4.23-3.89,6.77-.69,2.24-.95,4.56-1.1,6.89-.12,1.96-.12,3.92-.04,5.88.04,1.16.87,1.97,2.02,1.97h10.78c-.57,1.58-.89,3.28-.89,5.06,0,8.14,6.62,14.76,14.77,14.76s14.76-6.62,14.76-14.76c0-1.78-.31-3.48-.89-5.06h10.75c1.07,0,1.9-.75,1.97-1.81.07-1.1.12-2.2.13-3.31.03-2.14-.07-4.28-.37-6.41Zm-26.35,27.85c-6.22,0-11.27-5.05-11.27-11.26,0-1.82.43-3.54,1.2-5.06.77-1.53,1.88-2.87,3.24-3.9,1.89-1.45,4.26-2.31,6.83-2.31s4.93.86,6.82,2.31c1.36,1.03,2.47,2.37,3.24,3.9.77,1.52,1.2,3.24,1.2,5.06,0,6.21-5.05,11.26-11.26,11.26Zm22.82-20.43c0,.16-.06.21-.22.21-1.53-.01-3.05,0-4.57,0h-6.31c-2.69-3.53-6.94-5.81-11.72-5.81s-9.04,2.28-11.73,5.81h-11.12c.02-1.02.03-2,.07-2.98.06-1.44.21-2.87.42-4.3.45-3.04,1.72-5.67,3.8-7.93,1.98-2.15,4.36-3.75,7.02-4.94.08-.04.15-.07.25.01,1.89,1.55,4.06,2.54,6.41,3.14,4.48,1.14,8.85.77,13.06-1.14,1.12-.51,2.17-1.13,3.12-1.92.11-.09.2-.09.33-.03,2.15,1.08,4.16,2.37,5.95,3.99,1.58,1.42,2.91,3.03,3.81,4.97.5,1.08.79,2.22.99,3.39.38,2.25.47,4.53.44,6.81,0,.24-.01.48,0,.72Z\" />\n </g>\n <path\n d=\"m45.29,63.79l-4.21,4.2c-.19.19-.45.3-.72.3s-.54-.11-.73-.3l-4.2-4.2c-.4-.4-.4-1.05,0-1.46.4-.4,1.05-.4,1.46,0l3.47,3.48,3.47-3.48c.4-.4,1.05-.4,1.46,0,.4.41.4,1.06,0,1.46Z\" />\n <path\n d=\"m45.29,59.61l-4.21,4.21c-.2.2-.46.3-.72.3s-.53-.1-.73-.3l-4.2-4.21c-.4-.4-.4-1.05,0-1.45.4-.4,1.04-.4,1.45,0h.01l3.47,3.48,3.47-3.48h.01c.4-.4,1.04-.4,1.45,0,.4.4.4,1.05,0,1.45Z\" />\n </g>\n </svg>\n <!-- Instant Telephonic Service -->\n <svg\n *ngIf=\"inputIcon === 'instant-telephonic-service'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 80 80\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <g>\n <path\n d=\"m62.18,23.77c-.04-.46-.08-.93-.13-1.39-.04-.32-.09-.64-.14-.95-.68-3.53-2.34-6.52-5-8.94-2.04-1.85-4.4-3.08-7.08-3.71-1.2-.28-2.41-.41-3.65-.41-.92,0-1.62.76-1.55,1.66.07.84.74,1.42,1.63,1.45.64.02,1.27.05,1.89.14,2.86.44,5.31,1.72,7.33,3.81,1.5,1.56,2.55,3.4,3.13,5.49.32,1.13.46,2.29.47,3.45,0,.83.61,1.46,1.44,1.53.75.08,1.48-.47,1.62-1.25.05-.28,0-.58,0-.88h.04Z\" />\n <path\n d=\"m54.95,24.18c.03.7-.23,1.24-.84,1.55-.57.29-1.12.23-1.64-.15-.34-.25-.57-.59-.59-1.01-.03-.65-.25-1.23-.55-1.79-.78-1.43-1.81-2.63-3.21-3.49-.62-.38-1.29-.61-2.04-.62-.8-.02-1.46-.76-1.44-1.57.02-.84.7-1.52,1.54-1.52,1.11,0,2.14.3,3.11.82,2.07,1.11,3.59,2.78,4.73,4.82.44.79.77,1.63.9,2.54.02.15.03.29.04.42Z\" />\n </g>\n <g>\n <g>\n <path\n d=\"m43.17,57.56c.39.4.39,1.02,0,1.41l-4.06,4.05c-.18.18-.43.29-.69.29s-.52-.11-.7-.29l-4.05-4.05c-.39-.39-.39-1.01,0-1.41.39-.39,1.01-.39,1.41,0l3.35,3.36,3.35-3.36c.39-.39,1.01-.39,1.41,0Z\" />\n <path\n d=\"m33.66,54.94c-.39-.39-.39-1.01,0-1.4.39-.39,1-.39,1.4,0h0l3.35,3.36,3.35-3.36h0c.39-.39,1-.39,1.4,0,.39.39.39,1.01,0,1.4l-4.06,4.06c-.19.19-.44.29-.69.29s-.51-.1-.7-.29l-4.05-4.06Z\" />\n <path\n d=\"m59.99,39.41c-2.01-1.41-4-2.84-6.01-4.25-.73-.53-1.47-1.06-2.3-1.44-.92-.42-1.86-.62-2.86-.43-.91.16-1.71.59-2.39,1.18-.77.66-1.49,1.39-2.21,2.08-.1.09-.16.11-.26.05-.25-.16-.51-.31-.75-.47-1.03-.7-1.96-1.54-2.88-2.38-1.8-1.63-3.47-3.39-5.03-5.25-.5-.61-.93-1.26-1.39-1.9-.1-.14-.08-.23.05-.36.41-.41.8-.83,1.21-1.24.54-.55,1.03-1.13,1.43-1.79.7-1.16.87-2.38.45-3.67-.25-.77-.65-1.48-1.12-2.14-1.6-2.26-3.2-4.51-4.8-6.77-.67-.95-1.54-1.6-2.63-1.96-1.5-.48-2.96-.32-4.4.26-1.06.43-1.96,1.12-2.78,1.92-1.32,1.28-2.3,2.78-2.87,4.52-.67,1.98-.75,4.01-.48,6.07.24,1.83.77,3.6,1.5,5.3.89,2.06,1.98,4.02,3.23,5.87,2.38,3.55,5.16,6.76,8.29,9.67.67.63,1.34,1.23,2.04,1.82-5.36,2.04-9.17,7.23-9.17,13.31,0,7.85,6.39,14.24,14.25,14.24s14.24-6.39,14.24-14.24c0-1.64-.28-3.21-.78-4.67.55-.04,1.1-.07,1.64-.15,2.93-.44,5.3-1.85,7.13-4.18,1.04-1.34,1.77-2.83,1.8-4.56.04-1.82-.58-3.34-2.11-4.43Zm-21.91,28.85c-6,0-10.87-4.87-10.87-10.86,0-5.38,3.93-9.86,9.07-10.72.59-.11,1.19-.15,1.8-.15,4.17,0,7.78,2.35,9.61,5.81.8,1.51,1.25,3.23,1.25,5.06,0,5.99-4.87,10.86-10.86,10.86Zm20.01-22.08c-1.38,1.94-3.26,3.08-5.62,3.38-.84.11-1.68.11-2.5.02-2.55-3.87-6.93-6.42-11.89-6.42-.41,0-.83.02-1.24.06-.68-.52-1.33-1.07-1.99-1.63-1.54-1.31-3.01-2.7-4.38-4.19-2.64-2.86-5.04-5.89-6.92-9.32-.86-1.57-1.6-3.19-2.08-4.92-.35-1.25-.56-2.53-.56-3.83,0-1.66.35-3.23,1.23-4.65.71-1.14,1.62-2.1,2.82-2.75.78-.42,1.61-.6,2.49-.37.46.13.84.4,1.12.79,1.61,2.27,3.22,4.53,4.82,6.81.27.38.47.81.68,1.23.19.4.15.8-.11,1.16-.27.39-.54.76-.85,1.1-.55.6-1.14,1.16-1.69,1.76-.79.86-.91,1.87-.55,2.94.3.9.88,1.64,1.46,2.37,1.44,1.83,3.03,3.55,4.71,5.17,1.16,1.12,2.34,2.22,3.63,3.2.69.53,1.41,1.01,2.19,1.4.99.48,2.4.44,3.4-.6.59-.62,1.22-1.22,1.85-1.8.26-.24.59-.43.91-.63.3-.19.64-.2.97-.1.58.18,1.08.5,1.57.85,2.2,1.56,4.38,3.13,6.59,4.67.7.49.92,1.16.87,1.95-.05.88-.42,1.64-.92,2.34Z\" />\n </g>\n <path\n d=\"m43.17,58.97l-4.06,4.05c-.18.18-.43.29-.69.29s-.52-.11-.7-.29l-4.05-4.05c-.39-.39-.39-1.01,0-1.41.39-.39,1.01-.39,1.41,0l3.35,3.36,3.35-3.36c.39-.39,1.01-.39,1.41,0,.39.4.39,1.02,0,1.41Z\" />\n <path\n d=\"m43.17,54.94l-4.06,4.06c-.19.19-.44.29-.69.29s-.51-.1-.7-.29l-4.05-4.06c-.39-.39-.39-1.01,0-1.4.39-.39,1-.39,1.4,0h0l3.35,3.36,3.35-3.36h0c.39-.39,1-.39,1.4,0,.39.39.39,1.01,0,1.4Z\" />\n </g>\n </svg>\n <!-- Scheduled Video Service -->\n <svg\n *ngIf=\"inputIcon === 'scheduled-video-service'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 80 80\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <path\n d=\"m40.2,2.31c-7.34-.09-13.37,5.83-13.43,13.19-.05,7.2,5.69,13.24,13.07,13.38,7.33.14,13.38-5.73,13.49-13.12.12-7.32-5.77-13.38-13.13-13.45Zm-.16,22.55c-5.02.04-9.22-4.12-9.26-9.17-.04-5.15,4.08-9.34,9.23-9.37,5.08-.03,9.29,4.1,9.32,9.15.03,5.21-4.06,9.35-9.29,9.39Z\" />\n <g>\n <path\n d=\"m67.1,46.01c-.2-1.39-.48-2.77-.97-4.1-.92-2.52-2.43-4.67-4.3-6.58-1.55-1.58-3.3-2.92-5.17-4.1-1.46-.91-2.98-1.72-4.58-2.37-.77-.32-1.67-.14-2.19.47-.75.86-1.66,1.48-2.66,1.98-2.76,1.4-5.68,1.91-8.75,1.62-2.12-.2-4.12-.79-5.98-1.82-.78-.44-1.53-.93-2.12-1.61-.65-.75-1.47-.99-2.39-.63-.75.29-1.51.59-2.24.94-3.05,1.47-5.76,3.4-8.02,5.94-1.82,2.04-3.19,4.34-4,6.96-.71,2.31-.98,4.69-1.13,7.08-.12,2.02-.13,4.04-.05,6.06.05,1.18.9,2.02,2.08,2.02h11.53c-.57,1.58-.89,3.28-.89,5.06,0,8.14,6.63,14.76,14.77,14.76s14.76-6.62,14.76-14.76c0-1.78-.31-3.48-.89-5.06h11.41c1.1,0,1.96-.77,2.03-1.86.08-1.14.12-2.27.14-3.4.03-2.21-.07-4.41-.39-6.6Zm-27.06,28.18c-6.21,0-11.27-5.05-11.27-11.26,0-1.82.43-3.54,1.2-5.06.8-1.59,1.97-2.97,3.4-4.01,1.87-1.39,4.17-2.2,6.67-2.2s4.81.82,6.68,2.2c1.42,1.05,2.58,2.42,3.38,4.01.77,1.52,1.2,3.24,1.2,5.06,0,6.21-5.05,11.26-11.26,11.26Zm23.43-20.55c0,.17-.06.22-.23.22-1.56-.01-3.13,0-4.7,0h-6.86c-2.7-3.47-6.91-5.7-11.64-5.7s-8.94,2.23-11.64,5.7h-11.91c.03-1.05.03-2.06.08-3.07.06-1.48.21-2.95.43-4.42.46-3.13,1.77-5.83,3.91-8.15,2.04-2.22,4.48-3.86,7.22-5.09.09-.04.15-.07.25.01,1.95,1.6,4.18,2.62,6.61,3.23,4.6,1.17,9.09.79,13.43-1.17,1.15-.52,2.22-1.17,3.2-1.97.12-.1.2-.1.34-.03,2.22,1.1,4.28,2.44,6.12,4.1,1.63,1.46,3,3.11,3.92,5.11.52,1.11.82,2.29,1.02,3.49.39,2.32.48,4.65.46,7-.01.25-.02.49-.01.74Z\" />\n <path\n d=\"m45.97,63.99c0,.56-.44,1-1,1h-5.99c-.55,0-1-.44-1-1,0-.03,0-.07.01-.1-.01-.03-.01-.07-.01-.11v-7.27c0-.56.45-1,1-1s1,.44,1,1v6.48h4.99c.56,0,1,.45,1,1Z\" />\n </g>\n </svg>\n <!-- Scheduled Telephonic Service -->\n <svg\n *ngIf=\"inputIcon === 'scheduled-telephonic-service'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 80 80\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <g>\n <path\n d=\"m62.18,23.77c-.04-.46-.08-.93-.13-1.39-.04-.32-.09-.64-.14-.95-.68-3.53-2.34-6.52-5-8.94-2.04-1.85-4.4-3.08-7.08-3.71-1.2-.28-2.41-.41-3.65-.41-.92,0-1.62.76-1.55,1.66.07.84.74,1.42,1.63,1.45.64.02,1.27.05,1.89.14,2.86.44,5.31,1.72,7.33,3.81,1.5,1.56,2.55,3.4,3.13,5.49.32,1.13.46,2.29.47,3.45,0,.83.61,1.46,1.44,1.53.75.08,1.48-.47,1.62-1.25.05-.28,0-.58,0-.88h.04Z\" />\n <path\n d=\"m54.95,24.18c.03.7-.23,1.24-.84,1.55-.57.29-1.12.23-1.64-.15-.34-.25-.57-.59-.59-1.01-.03-.65-.25-1.23-.55-1.79-.78-1.43-1.81-2.63-3.21-3.49-.62-.38-1.29-.61-2.04-.62-.8-.02-1.46-.76-1.44-1.57.02-.84.7-1.52,1.54-1.52,1.11,0,2.14.3,3.11.82,2.07,1.11,3.59,2.78,4.73,4.82.44.79.77,1.63.9,2.54.02.15.03.29.04.42Z\" />\n </g>\n <g>\n <path\n d=\"m59.99,39.41c-2.01-1.41-4-2.84-6.01-4.25-.73-.53-1.47-1.06-2.3-1.44-.92-.42-1.86-.62-2.86-.43-.91.16-1.71.59-2.39,1.18-.77.66-1.49,1.39-2.21,2.08-.1.09-.16.11-.26.05-.25-.16-.51-.31-.75-.47-1.03-.7-1.96-1.54-2.88-2.38-1.8-1.63-3.47-3.39-5.03-5.25-.5-.61-.93-1.26-1.39-1.9-.1-.14-.08-.23.05-.36.41-.41.8-.83,1.21-1.24.54-.55,1.03-1.13,1.43-1.79.7-1.16.87-2.38.45-3.67-.25-.77-.65-1.48-1.12-2.14-1.6-2.26-3.2-4.51-4.8-6.77-.67-.95-1.54-1.6-2.63-1.96-1.5-.48-2.96-.32-4.4.26-1.06.43-1.96,1.12-2.78,1.92-1.32,1.28-2.3,2.78-2.87,4.52-.67,1.98-.75,4.01-.48,6.07.24,1.83.77,3.6,1.5,5.3.89,2.06,1.98,4.02,3.23,5.87,2.38,3.55,5.16,6.76,8.29,9.67.68.63,1.36,1.24,2.05,1.83-5.34,2.05-9.15,7.23-9.15,13.3,0,7.85,6.39,14.24,14.25,14.24s14.24-6.39,14.24-14.24c0-1.64-.28-3.21-.79-4.67.54-.04,1.08-.07,1.61-.15,2.93-.44,5.3-1.85,7.13-4.18,1.04-1.34,1.77-2.83,1.8-4.56.04-1.82-.58-3.34-2.11-4.43Zm-21.88,28.85c-5.99,0-10.87-4.87-10.87-10.86,0-5.37,3.92-9.84,9.04-10.72.59-.11,1.21-.15,1.83-.15,4.17,0,7.79,2.36,9.62,5.82.79,1.51,1.24,3.23,1.24,5.05,0,5.99-4.87,10.86-10.86,10.86Zm19.98-22.08c-1.38,1.94-3.26,3.08-5.62,3.38-.83.11-1.64.11-2.45.02-2.56-3.87-6.93-6.42-11.9-6.42-.43,0-.86.02-1.28.07-.68-.53-1.33-1.08-1.99-1.64-1.54-1.31-3.01-2.7-4.38-4.19-2.64-2.86-5.04-5.89-6.92-9.32-.86-1.57-1.6-3.19-2.08-4.92-.35-1.25-.56-2.53-.56-3.83,0-1.66.35-3.23,1.23-4.65.71-1.14,1.62-2.1,2.82-2.75.78-.42,1.61-.6,2.49-.37.46.13.84.4,1.12.79,1.61,2.27,3.22,4.53,4.82,6.81.27.38.47.81.68,1.23.19.4.15.8-.11,1.16-.27.39-.54.76-.85,1.1-.55.6-1.14,1.16-1.69,1.76-.79.86-.91,1.87-.55,2.94.3.9.88,1.64,1.46,2.37,1.44,1.83,3.03,3.55,4.71,5.17,1.16,1.12,2.34,2.22,3.63,3.2.69.53,1.41,1.01,2.19,1.4.99.48,2.4.44,3.4-.6.59-.62,1.22-1.22,1.85-1.8.26-.24.59-.43.91-.63.3-.19.64-.2.97-.1.58.18,1.08.5,1.57.85,2.2,1.56,4.38,3.13,6.59,4.67.7.49.92,1.16.87,1.95-.05.88-.42,1.64-.92,2.34Z\" />\n <path\n d=\"m43.84,58.42c0,.54-.42.96-.96.96h-5.78c-.53,0-.96-.42-.96-.96,0-.03,0-.07,0-.1,0-.03,0-.07,0-.11v-7.01c0-.54.43-.96.96-.96s.96.42.96.96v6.25h4.81c.54,0,.96.43.96.96Z\" />\n </g>\n </svg>\n <!-- Vital Scan Service -->\n <svg\n *ngIf=\"inputIcon === 'vital-scan-service'\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 80 80\"\n style=\"fill: var(--cf-svg-fill-with-stroke-color)\">\n <g>\n <path\n d=\"m69.5,31c-1.38,0-2.5-1.12-2.5-2.5v-13.5s-13.5,0-13.5,0h0c-1.38,0-2.5-1.12-2.5-2.5s1.12-2.5,2.5-2.5h16s0,0,0,0h0c1.38,0,2.5,1.12,2.5,2.5,0,.03,0,.06,0,.09v15.91c0,1.38-1.12,2.5-2.5,2.5h0Z\" />\n <path\n d=\"m69.5,70h-16c-1.38,0-2.5-1.12-2.5-2.5s1.12-2.5,2.5-2.5h13.5s0-13.5,0-13.5c0-1.38,1.12-2.5,2.5-2.5h0c1.38,0,2.5,1.12,2.5,2.5v15.88s0,.08,0,.12c0,1.38-1.12,2.5-2.5,2.5Z\" />\n <path\n d=\"m10.5,49c1.38,0,2.5,1.12,2.5,2.5v13.5s13.5,0,13.5,0h0c1.38,0,2.5,1.12,2.5,2.5s-1.12,2.5-2.5,2.5h-16s0,0,0,0h0c-1.38,0-2.5-1.12-2.5-2.5,0-.03,0-.06,0-.09v-15.91c0-1.38,1.12-2.5,2.5-2.5h0Z\" />\n <path\n d=\"m10.5,10h16c1.38,0,2.5,1.12,2.5,2.5s-1.12,2.5-2.5,2.5h-13.5s0,13.5,0,13.5c0,1.38-1.12,2.5-2.5,2.5h0c-1.38,0-2.5-1.12-2.5-2.5v-15.88s0-.08,0-.12c0-1.38,1.12-2.5,2.5-2.5Z\" />\n </g>\n <path\n d=\"m66.91,41.79c0,.99-.83,1.79-1.85,1.79h0s-7.04,0-7.04,0c-1.08,0-2.17-.03-3.25,0-1.07.04-1.76-.42-2.2-1.38-.38-.83-.82-1.63-1.37-2.72-.87,2.89-1.65,5.48-2.43,8.06-.53,1.75-1.06,3.5-1.57,5.25-.27.92-.83,1.54-1.82,1.52-1.05-.02-1.57-.68-1.79-1.68-1.18-5.51-2.37-11.02-3.55-16.53-.04-.17-.09-.33-.22-.84-.22.66-.35,1.02-.46,1.38-.97,3.53-1.94,7.05-2.89,10.58-.26.97-.74,1.67-1.79,1.7-1.12.03-1.62-.7-1.9-1.71-.61-2.23-1.27-4.45-1.92-6.67-.07-.24-.17-.47-.32-.91-.52,1.03-.87,1.93-1.41,2.7-.35.5-.97,1.14-1.49,1.16-4.15.09-8.31.05-12.52.05-.06,0-.13,0-.19,0-1.02,0-1.85-.8-1.85-1.79s.83-1.79,1.85-1.79h0s1.17,0,1.17,0c3.1,0,6.2-.02,9.31.02.7,0,1.07-.22,1.36-.85.79-1.69,1.66-3.34,2.48-5.02.41-.85.98-1.43,1.99-1.31.94.11,1.38.75,1.62,1.63.51,1.87,1.07,3.73,1.7,5.92.22-.72.37-1.14.49-1.58,1.05-3.81,2.1-7.63,3.12-11.45.27-1.02.77-1.74,1.89-1.7,1.11.04,1.57.79,1.79,1.82,1.16,5.48,2.35,10.95,3.53,16.42.08.36.17.71.32,1.34,1.07-3.54,2.05-6.82,3.04-10.1.11-.36.2-.77.34-1.05.3-.59,1.01-1.14,1.56-1.18.55-.04,1.39.44,1.69.94,1,1.7,1.85,3.5,2.68,5.29.32.69.72.89,1.45.88,2.83-.05,5.67-.02,8.58-.02h0s0,0,0,0c1.02,0,1.85.8,1.85,1.79Z\" />\n </svg>\n <!-- open-back-arrow -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'open-back-arrow'\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M14 3 L6 10 L14 17\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- open-forward-arrow -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'open-forward-arrow'\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M6 3 L14 10 L6 17\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- open-up-arrow -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'open-up-arrow'\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M3 14 L10 6 L17 14\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- open-down-arrow -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'open-down-arrow'\" viewBox=\"0 0 20 20\" fill=\"none\">\n <path d=\"M3 6 L10 14 L17 6\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n <!-- Single Document -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'single-document'\" viewBox=\"0 0 18 22\" fill=\"none\">\n <path\n d=\"M11 1H2.5C1.67157 1 1 1.67157 1 2.5V19.5C1 20.3284 1.67157 21 2.5 21H15.5C16.3284 21 17 20.3284 17 19.5V7M11 1L17 7M11 1V5.5C11 6.32843 11.6716 7 12.5 7H17M4 14H12M4 17H9\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- Lightning -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'lightning'\" viewBox=\"0 0 14 22\" fill=\"none\">\n <path\n d=\"M1.23099 11.6824L8.99999 1V10H12.6072C12.7707 10 12.8651 10.1854 12.769 10.3176L4.99999 21V12H1.39274C1.22928 12 1.13485 11.8146 1.23099 11.6824Z\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- Microsoft 365 -->\n <svg xmlns=\"http://www.w3.org/2000/svg\" *ngIf=\"icon === 'microsoft-365'\" fill=\"none\" viewBox=\"4 2 40 44\" style=\"stroke: none\">\n <path\n d=\"M20.0842 3.02588L19.8595 3.16179C19.5021 3.37799 19.1654 3.61972 18.8512 3.88385L19.4993 3.42798H25L26 11L21 16L16 19.4754V23.4829C16 26.2819 17.4629 28.8774 19.8574 30.3268L25.1211 33.5129L14 40.0002H11.8551L7.85737 37.5804C5.46286 36.131 4 33.5355 4 30.7365V17.2606C4 14.4607 5.46379 11.8645 7.85952 10.4154L19.8595 3.15687C19.9339 3.11189 20.0088 3.06823 20.0842 3.02588Z\"\n fill=\"url(#paint0_radial_2994_8373)\" />\n <path\n d=\"M20.0842 3.02588L19.8595 3.16179C19.5021 3.37799 19.1654 3.61972 18.8512 3.88385L19.4993 3.42798H25L26 11L21 16L16 19.4754V23.4829C16 26.2819 17.4629 28.8774 19.8574 30.3268L25.1211 33.5129L14 40.0002H11.8551L7.85737 37.5804C5.46286 36.131 4 33.5355 4 30.7365V17.2606C4 14.4607 5.46379 11.8645 7.85952 10.4154L19.8595 3.15687C19.9339 3.11189 20.0088 3.06823 20.0842 3.02588Z\"\n fill=\"url(#paint1_linear_2994_8373)\" />\n <path\n d=\"M32 19V23.4803C32 26.2793 30.5371 28.8748 28.1426 30.3242L16.1426 37.5878C13.6878 39.0737 10.6335 39.1273 8.1355 37.7487L19.8573 44.844C22.4039 46.3855 25.5959 46.3855 28.1426 44.844L40.1426 37.5803C42.5371 36.1309 43.9999 33.5354 43.9999 30.7364V27.5L42.9999 26L32 19Z\"\n fill=\"url(#paint2_radial_2994_8373)\" />\n <path\n d=\"M32 19V23.4803C32 26.2793 30.5371 28.8748 28.1426 30.3242L16.1426 37.5878C13.6878 39.0737 10.6335 39.1273 8.1355 37.7487L19.8573 44.844C22.4039 46.3855 25.5959 46.3855 28.1426 44.844L40.1426 37.5803C42.5371 36.1309 43.9999 33.5354 43.9999 30.7364V27.5L42.9999 26L32 19Z\"\n fill=\"url(#paint3_linear_2994_8373)\" />\n <path\n d=\"M40.1405 10.4153L28.1405 3.15678C25.6738 1.66471 22.6021 1.61849 20.0979 3.01811L19.8595 3.16231C17.4638 4.61143 16 7.20757 16 10.0075V19.4914L19.8595 17.1568C22.4051 15.6171 25.5949 15.6171 28.1405 17.1568L40.1405 24.4153C42.4613 25.8192 43.9076 28.2994 43.9957 30.9985C43.9986 30.9113 44 30.824 44 30.7364V17.2605C44 14.4606 42.5362 11.8644 40.1405 10.4153Z\"\n fill=\"url(#paint4_radial_2994_8373)\" />\n <path\n d=\"M40.1405 10.4153L28.1405 3.15678C25.6738 1.66471 22.6021 1.61849 20.0979 3.01811L19.8595 3.16231C17.4638 4.61143 16 7.20757 16 10.0075V19.4914L19.8595 17.1568C22.4051 15.6171 25.5949 15.6171 28.1405 17.1568L40.1405 24.4153C42.4613 25.8192 43.9076 28.2994 43.9957 30.9985C43.9986 30.9113 44 30.824 44 30.7364V17.2605C44 14.4606 42.5362 11.8644 40.1405 10.4153Z\"\n fill=\"url(#paint5_linear_2994_8373)\" />\n <path d=\"M4.00428 30.9984C4.00428 30.9984 4.00428 30.9984 4.00428 30.9984Z\" fill=\"url(#paint6_radial_2994_8373)\" />\n <path d=\"M4.00428 30.9984C4.00428 30.9984 4.00428 30.9984 4.00428 30.9984Z\" fill=\"url(#paint7_linear_2994_8373)\" />\n <defs>\n <radialGradient\n id=\"paint0_radial_2994_8373\"\n cx=\"0\"\n cy=\"0\"\n r=\"1\"\n gradientUnits=\"userSpaceOnUse\"\n gradientTransform=\"translate(17.4186 10.6383) rotate(110.528) scale(33.3657 58.1966)\">\n <stop offset=\"0.06441\" stop-color=\"#AE7FE2\" />\n <stop offset=\"1\" stop-color=\"#0078D4\" />\n </radialGradient>\n <linearGradient id=\"paint1_linear_2994_8373\" x1=\"17.5119\" y1=\"37.8685\" x2=\"12.7513\" y2=\"29.6347\" gradientUnits=\"userSpaceOnUse\">\n <stop offset=\"0\" stop-color=\"#114A8B\" />\n <stop offset=\"1\" stop-color=\"#0078D4\" stop-opacity=\"0\" />\n </linearGradient>\n <radialGradient\n id=\"paint2_radial_2994_8373\"\n cx=\"0\"\n cy=\"0\"\n r=\"1\"\n gradientUnits=\"userSpaceOnUse\"\n gradientTransform=\"translate(10.4299 36.3511) rotate(-8.36717) scale(31.0503 20.5108)\">\n <stop offset=\"0.133928\" stop-color=\"#D59DFF\" />\n <stop offset=\"1\" stop-color=\"#5E438F\" />\n </radialGradient>\n <linearGradient id=\"paint3_linear_2994_8373\" x1=\"40.3566\" y1=\"25.3768\" x2=\"35.2552\" y2=\"32.6916\" gradientUnits=\"userSpaceOnUse\">\n <stop offset=\"0\" stop-color=\"#493474\" />\n <stop offset=\"1\" stop-color=\"#8C66BA\" stop-opacity=\"0\" />\n </linearGradient>\n <radialGradient\n id=\"paint4_radial_2994_8373\"\n cx=\"0\"\n cy=\"0\"\n r=\"1\"\n gradientUnits=\"userSpaceOnUse\"\n gradientTransform=\"translate(41.0552 26.504) rotate(-165.772) scale(24.9228 41.9552)\">\n <stop offset=\"0.0584996\" stop-color=\"#50E6FF\" />\n <stop offset=\"1\" stop-color=\"#436DCD\" />\n </radialGradient>\n <linearGradient id=\"paint5_linear_2994_8373\" x1=\"16.9758\" y1=\"3.05655\" x2=\"24.4868\" y2=\"3.05655\" gradientUnits=\"userSpaceOnUse\">\n <stop offset=\"0\" stop-color=\"#2D3F80\" />\n <stop offset=\"1\" stop-color=\"#436DCD\" stop-opacity=\"0\" />\n </linearGradient>\n <radialGradient\n id=\"paint6_radial_2994_8373\"\n cx=\"0\"\n cy=\"0\"\n r=\"1\"\n gradientUnits=\"userSpaceOnUse\"\n gradientTransform=\"translate(41.0552 26.504) rotate(-165.772) scale(24.9228 41.9552)\">\n <stop offset=\"0.0584996\" stop-color=\"#50E6FF\" />\n <stop offset=\"1\" stop-color=\"#436DCD\" />\n </radialGradient>\n <linearGradient id=\"paint7_linear_2994_8373\" x1=\"16.9758\" y1=\"3.05655\" x2=\"24.4868\" y2=\"3.05655\" gradientUnits=\"userSpaceOnUse\">\n <stop offset=\"0\" stop-color=\"#2D3F80\" />\n <stop offset=\"1\" stop-color=\"#436DCD\" stop-opacity=\"0\" />\n </linearGradient>\n </defs>\n </svg>\n <!-- user-dependent -->\n <svg *ngIf=\"icon === 'user-dependent'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 23 23\" fill=\"none\">\n <path\n d=\"M15.65 20.2C15.65 17.87 13.33 15.97 10.46 15.97C7.59 15.97 5.27 17.86 5.27 20.2M14.2 3.73999C13.06 3.25999 11.81 3 10.5 3C5.25 3 1 7.25 1 12.5C1 17.75 5.25 22 10.5 22C15.75 22 20 17.75 20 12.5C20 11.19 19.73 9.92998 19.25 8.78998M14.2 3.73999C14.07 4.13999 14 4.56 14 5C14 5.75 14.21 6.46 14.58 7.06C14.78 7.4 15.04 7.70997 15.34 7.96997C16.04 8.60997 16.97 9 18 9C18.44 9 18.86 8.92998 19.25 8.78998M14.2 3.73999C14.39 3.15999 14.71 2.64002 15.13 2.21002C15.86 1.46002 16.88 1 18 1C19.18 1 20.25 1.51002 20.97 2.33002C21.61 3.04002 22 3.98 22 5C22 5.32 21.96 5.62999 21.88 5.92999C21.79 6.32999 21.63 6.72 21.42 7.06C20.94 7.87 20.17 8.49998 19.25 8.78998M19.49 4.97998H16.51M18 3.52002V6.51001M13.27 10.92C13.27 12.4719 12.0119 13.73 10.46 13.73C8.90808 13.73 7.65 12.4719 7.65 10.92C7.65 9.36806 8.90808 8.10999 10.46 8.10999C12.0119 8.10999 13.27 9.36806 13.27 10.92Z\"\n stroke-width=\"1.5\"\n stroke-miterlimit=\"10\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\" />\n </svg>\n <!-- plus -->\n <svg *ngIf=\"icon === 'plus'\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 15 14\" fill=\"none\">\n <path d=\"M1.52881 6.99686H13.5069M7.51786 12.9859V1.00781\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n</div>\n","/**\n * CareFirst Library - Button\n *\n * @file button.component\n * @description Contains all the logic for generating a CareFirst Button\n * @author Jacques Coetzee\n * @since 2023 - 11 - 07\n * @usage <cf-btn type=\"'primary' | 'secondary' | 'tertiary'\" fontSize=\"'small' | 'large'\" %customColor=\"var() | hex\"% %disabled% %alert% %action% %snug%>TEXT</cf-btn>\n */\n\nimport { Component, Input, type SimpleChanges, type OnChanges, HostBinding } from '@angular/core';\nimport { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';\nimport { iconsC, type IconsT } from '../../interfaces/icon.interface';\n\n@Component({\n selector: 'cf-btn',\n templateUrl: './button.component.html',\n styleUrls: ['./button.component.scss'],\n})\nexport class ButtonComponent implements OnChanges {\n @Input() type: 'primary' | 'secondary' | 'tertiary' = 'primary';\n @Input() disabled?: boolean | string | undefined;\n @Input() alert?: boolean | string | undefined;\n @Input() action?: boolean | string | undefined;\n @Input() snug?: boolean | string | undefined;\n @Input() accent?: boolean | string | undefined;\n @Input() fontSize?: 'small' | 'large';\n @Input() iconStart?: IconsT | undefined;\n @Input() iconEnd?: IconsT | undefined;\n @Input() loading?: boolean | string | undefined;\n @Input() customColor?: string | undefined;\n\n @HostBinding('style.pointer-events') get parentEvents(): string {\n if (this.disabled) {\n return 'none';\n }\n return 'auto';\n }\n\n //--- Local variables\n inputType: typeof this.type = 'primary';\n inputFontSize: typeof this.fontSize | undefined = undefined;\n inputDisabled = false;\n inputAlert = false;\n inputAction = false;\n inputSnug = false;\n inputAccent = false;\n inputIconStart: typeof this.iconStart | undefined = undefined;\n inputIconEnd: typeof this.iconEnd | undefined = undefined;\n inputLoading = false;\n inputCustomColor = '';\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Type\n this.inputType =\n validateStringValue<'primary' | 'secondary' | 'tertiary'>(changes, 'type', ['primary', 'secondary', 'tertiary'], this.inputType) || 'primary';\n //--- Font Size\n this.inputFontSize = validateStringValue<'small' | 'large'>(changes, 'fontSize', ['small', 'large'], this.inputFontSize);\n //--- Disabled\n this.inputDisabled = checkTruthAttribute(changes, 'disabled', this.inputDisabled);\n //--- Alert\n this.inputAlert = checkTruthAttribute(changes, 'alert', this.inputAlert);\n //--- Action\n this.inputAction = checkTruthAttribute(changes, 'action', this.inputAction);\n //--- Snug\n this.inputSnug = checkTruthAttribute(changes, 'snug', this.inputSnug);\n //--- Accent\n this.inputAccent = checkTruthAttribute(changes, 'accent', this.inputAccent);\n //--- Icon Start\n this.inputIconStart = validateStringValue<IconsT>(changes, 'iconStart', iconsC.slice(), this.inputIconStart);\n //--- Icon Start\n this.inputIconEnd = validateStringValue<IconsT>(changes, 'iconEnd', iconsC.slice(), this.inputIconEnd);\n //--- Loading\n this.inputLoading = checkTruthAttribute(changes, 'loading', this.inputLoading);\n //--- Custom color\n if (changes['customColor']?.currentValue) this.inputCustomColor = this.checkCustomColor(changes['customColor'].currentValue);\n }\n\n /**----------------------------------------------------------------\n * @name checkCustomColor\n * @description Check if the custom color is valid\n * @param {string} color\n * @returns {string}\n */\n checkCustomColor(color: string): string {\n //--- Check for a css variable\n if (color.startsWith('var')) return color;\n //--- Check hex\n if (color.startsWith('#') && (color.length === 4 || color.length === 7) && color.split('').every((char) => char.match(/[#0-9a-fA-F]+/)))\n return color;\n return '';\n }\n}\n","<ion-button\n [style]=\"'--custom-color: ' + inputCustomColor\"\n [ngClass]=\"{\n 'cf-button-primary': inputType === 'primary',\n 'cf-button-secondary': inputType === 'secondary',\n 'cf-button-tertiary': inputType === 'tertiary',\n 'text-large': inputFontSize === 'large',\n 'text-small': inputFontSize === 'small',\n alert: inputAlert,\n action: inputAction,\n snug: inputSnug,\n accent: inputAccent\n }\"\n mode=\"md\"\n [disabled]=\"inputDisabled\">\n <cf-icon *ngIf=\"inputIconStart\" [icon]=\"inputIconStart\" style=\"--cf-svg-overwrite-stroke-color: var(--button-text-color)\"></cf-icon>\n <p *cfButtonLoader=\"inputLoading\">\n <ng-content></ng-content>\n </p>\n <cf-icon *ngIf=\"inputIconEnd\" [icon]=\"inputIconEnd\" style=\"--cf-svg-overwrite-stroke-color: var(--button-text-color)\"></cf-icon>\n</ion-button>\n","/**\n * CareFirst Library - Spacer\n *\n * @file spacer.component\n * @description Contains all the logic for generating a CareFirst Div Spacer\n * @author Jacques Coetzee\n * @since 2023 - 11 - 07\n * @usage <cf-spacer %default=\"\"% %mobile=\"\"% %desktop=\"\"%>CONTENT</cf-spacer>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\nimport { validateNumberValue } from '../../utils/attribute.util';\nimport type { SpacerNumberT, SpacerStringT } from '../../interfaces/spacer.interface';\n\n@Component({\n selector: 'cf-spacer',\n templateUrl: './spacer.component.html',\n styleUrls: ['./spacer.component.scss'],\n})\nexport class SpacerComponent implements OnChanges {\n @Input() default?: SpacerStringT | SpacerNumberT | undefined;\n @Input() mobile?: SpacerStringT | SpacerNumberT | undefined;\n @Input() desktop?: SpacerStringT | SpacerNumberT | undefined;\n\n //--- Local variables\n inputDefault: number | undefined = undefined;\n inputMobile: number | undefined = undefined;\n inputDesktop: number | undefined = undefined;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Default\n this.inputDefault = validateNumberValue(changes, 'default', this.inputDefault);\n //--- Mobile\n this.inputMobile = validateNumberValue(changes, 'mobile', this.inputMobile);\n //--- Desktop\n this.inputDesktop = validateNumberValue(changes, 'desktop', this.inputDesktop);\n }\n}\n","<!-- Mobile Only OR Default -->\n<div *ngIf=\"inputMobile || inputDefault\" class=\"mobile-only\" [ngStyle]=\"{ height: (inputMobile || inputDefault || 0) + 'px' }\"> </div>\n<!-- Desktop Only OR Default-->\n<div *ngIf=\"inputDesktop || inputDefault\" class=\"desktop-only\" [ngStyle]=\"{ height: (inputDesktop || inputDefault || 0) + 'px' }\"> </div>\n","/**\n * CareFirst Library - Notification\n *\n * @file notification.component\n * @description Contains all the logic for generating a CareFirst Notification\n * @author Arno Jansen van Vuuren\n * @since 2023 - 11 - 27\n * @usage <cf-notification [data]=\"{heading, status, %message%, %canClose%, %button%}\" (buttonClick)=\"\"></cf-notification>\n */\n\nimport { Component, Input, Output, EventEmitter } from '@angular/core';\n//--- Interfaces\nimport type { NotificationPayloadI } from '../../interfaces/notification.interface';\n\n@Component({\n selector: 'cf-notification',\n templateUrl: './notification.component.html',\n styleUrls: ['./notification.component.scss'],\n})\nexport class NotificationComponent {\n @Input() data?: NotificationPayloadI | undefined;\n @Output() buttonClick = new EventEmitter<Required<NotificationPayloadI>['button']['buttonClickIdentifier']>();\n}\n","<div *ngIf=\"data\">\n <cf-spacer mobile=\"16\" desktop=\"32\"></cf-spacer>\n <ion-grid>\n <ion-row class=\"ion-justify-content-center\">\n <ion-col size=\"12\" size-md=\"6\">\n <div [ngClass]=\"data.status\" id=\"notification-container\">\n <ion-grid>\n <ion-row>\n <ion-col class=\"ion-align-self-center ion-text-start\">\n <p class=\"body-medium bold\">{{ data.heading }}</p>\n </ion-col>\n <ion-col size=\"auto\">\n <cf-icon icon=\"close\" *ngIf=\"data.canClose\" (click)=\"data = undefined\" [height]=\"10\" [iconColor]=\"data.status\"></cf-icon>\n </ion-col>\n <ion-col *ngIf=\"data.message\" size=\"12\">\n <cf-spacer default=\"8\"></cf-spacer>\n <p class=\"body-small\">{{ data.message }}</p>\n </ion-col>\n <ion-col *ngIf=\"data.button?.buttonHeading\">\n <cf-spacer default=\"8\"></cf-spacer>\n <p class=\"body-medium bold\">{{ data.button?.buttonHeading }}</p>\n </ion-col>\n <ion-col size=\"12\">\n <ng-content></ng-content>\n </ion-col>\n <ion-col size=\"12\" *ngIf=\"data.button\">\n <cf-spacer default=\"8\"></cf-spacer>\n <cf-btn type=\"primary\" fontSize=\"large\" action snug (click)=\"buttonClick.emit(data.button.buttonClickIdentifier)\">{{\n data.button.buttonText\n }}</cf-btn>\n </ion-col>\n </ion-row>\n </ion-grid>\n </div>\n </ion-col>\n </ion-row>\n </ion-grid>\n <cf-spacer mobile=\"16\" desktop=\"32\"></cf-spacer>\n</div>\n","/**\n * CareFirst Library Alert\n *\n * @file alert.component\n * @description Contains all the logic for generating a CareFirst Alert\n * @author Arno Jansen van Vuuren\n * @since 2023 - 11 - 30\n * @usage <cf-alert data=\"{heading, message, buttonTrue, buttonFalse}\" (alertEvent)></cf-alert>\n */\n\nimport { Component, Input, Output, type OnChanges, type SimpleChanges, EventEmitter } from '@angular/core';\nimport { AlertController } from '@ionic/angular';\nimport type { AlertDataI, AlertEventI } from '../../interfaces/alert.interface';\n\n@Component({\n selector: 'cf-alert',\n templateUrl: './alert.component.html',\n styleUrl: './alert.component.scss',\n})\nexport class AlertComponent implements OnChanges {\n @Input() data: AlertDataI | undefined = undefined;\n @Output() alertEvent = new EventEmitter<AlertEventI>();\n\n /**----------------------------------------------------------------\n * @name constructor\n */\n constructor(private readonly alertController: AlertController) {}\n\n /**----------------------------------------------------------------\n * @name ngOnchange\n * @description Update various values on component input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n const val = changes['data']?.currentValue as typeof this.data;\n if (val) this.showAlert(val);\n }\n\n /**----------------------------------------------------------------\n * @name showAlert\n * @description Show\n * @param {AlertDataI} data\n * @returns {Promise<void>}\n */\n async showAlert(data: AlertDataI): Promise<void> {\n const alert = await this.alertController.create({\n header: data.heading,\n message: data.message,\n cssClass: 'care-first-alert',\n mode: 'md',\n backdropDismiss: false,\n buttons: [\n {\n text: data.buttonFalse || 'Cancel',\n handler: () => {\n this.alertEvent.emit({ identifier: data.alertIdentifier, status: false });\n alert.dismiss();\n },\n cssClass: 'alert-button-cancel',\n },\n {\n text: data.buttonTrue || 'OK',\n handler: () => {\n this.alertEvent.emit({ identifier: data.alertIdentifier, status: true });\n alert.dismiss();\n },\n cssClass: 'alert-button-confirm',\n },\n ],\n });\n alert.present();\n }\n}\n","","/**\n * CareFirst Library Logo\n *\n * @file logo.component\n * @description Contains all the logic for generating a CareFirst Logo\n * @author Arno Jansen van Vuuren\n * @since 2023 - 11 - 30\n * @usage <cf-logo type=\"vertical | horizontal\" %height%></cf-logo>\n */\n\nimport { Component, Input } from '@angular/core';\n\n@Component({\n selector: 'cf-logo',\n templateUrl: './logo.component.html',\n styleUrl: './logo.component.scss',\n})\nexport class LogoComponent {\n @Input() type!: 'horizontal' | 'vertical';\n @Input() height: number = 50;\n}\n","<div class=\"img-container\" [style]=\"height ? 'height: ' + height + 'px' : ''\">\n <img\n *ngIf=\"type === 'horizontal'\"\n src=\"\"\n alt=\"Care Fist Logo\" />\n <img\n *ngIf=\"type === 'vertical'\"\n src=\"\"\n alt=\"Care Fist Logo\" />\n</div>\n","/**\n * CareFirst Library Calendar\n *\n * @file calendar.component\n * @description Contains all the logic for generating a CareFirst Calendar\n * @author Arno Jansen van Vuuren\n * @since 2023 - 12 - 01\n * @usage <cf-calendar %displayTime% %color%=\"success | accent\" %min% %max%></cf-calendar>\n */\n\nimport { Component, EventEmitter, Input, Output, type OnChanges, type SimpleChanges } from '@angular/core';\nimport dayjs from 'dayjs';\n//--- Utils\nimport { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';\n\n@Component({\n selector: 'cf-calendar',\n templateUrl: './calendar.component.html',\n styleUrl: './calendar.component.scss',\n})\nexport class CalendarComponent implements OnChanges {\n @Input() displayTime?: boolean | string | undefined;\n @Input() color?: 'success' | 'accent';\n @Input() min?: string | undefined = undefined;\n @Input() max?: string | undefined = undefined;\n @Output() value = new EventEmitter<string>();\n\n //--- Local variables\n inputTime = false;\n inputColor: typeof this.color = 'accent';\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on component input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Display Time\n this.inputTime = checkTruthAttribute(changes, 'displayTime', this.inputTime);\n //--- Color\n this.inputColor = validateStringValue<'success' | 'accent'>(changes, 'color', ['success', 'accent'], this.inputColor) || 'accent';\n }\n\n /**----------------------------------------------------------------\n * @name setValue\n * @description Emit the selected date value\n * @param {string | string[] | null | undefined} value\n * @returns {void}\n */\n setValue(value: string | string[] | null | undefined): void {\n if (typeof value === 'string') this.value.emit(dayjs(value).format('YYYY-MM-DD' + (this.inputTime ? ' HH:mm' : '')));\n }\n}\n","<ion-datetime\n [class]=\"inputColor\"\n mode=\"ios\"\n firstDayOfWeek=\"1\"\n [min]=\"min\"\n [max]=\"max\"\n [presentation]=\"inputTime ? 'date-time' : 'date'\"\n (ionChange)=\"setValue($event.detail.value)\">\n</ion-datetime>\n","/**\n * CareFirst Library Form Validation Feedback\n *\n * @file form-validation.component\n * @description Contains all the logic for generating CareFirst Form Validation Feedback\n * @author Arno Jansen van Vuuren\n * @since 2023 - 12 - 05\n * @usage <cf-form-validation [control]=\"formName.get('controlName')\"></cf-form-validation>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\n//--- Interfaces\nimport type { FormControl } from '@angular/forms';\n\n@Component({\n selector: 'cf-form-validation',\n templateUrl: './form-validation.component.html',\n styleUrl: './form-validation.component.scss',\n})\nexport class FormValidationComponent implements OnChanges {\n //--- Receive form control\n @Input() control!: FormControl | null;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Detect changes to input values\n * @param {SimpleChanges} changes\n */\n ngOnChanges(changes: SimpleChanges): void {\n if (changes['control'] && changes['control'].currentValue) {\n this.control = changes['control'].currentValue;\n }\n }\n}\n","<div *ngIf=\"control?.dirty && control?.errors\" class=\"form-valid-feedback\">\n <div *ngFor=\"let error of this.control?.errors | keyvalue\">\n <p class=\"body-medium\" *ngIf=\"error.key === 'email'\">*Invalid email format</p>\n <p class=\"body-medium\" *ngIf=\"error.key === 'minlength'\">*Length required: {{ error.value.requiredLength - error.value.actualLength }}</p>\n <p class=\"body-medium\" *ngIf=\"error.key === 'maxlength'\">*Max Length: {{ error.value.requiredLength }}</p>\n <p class=\"body-medium\" *ngIf=\"error.key === 'errorMessage'\">*{{ error.value }}</p>\n </div>\n</div>\n","/**\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 label=\"Label Name\" %labelPlacement% %inputMode% %noClearButton% %textCenter% %min% %max% %autoCapitalize% %type% %[(value)]=\"twoWayComs\"% %(valueChange)=\"currentValueEvent\"% %[control]%=\"formName.controls.controlName\"></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';\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: number | string = 'none';\n @Input() max: number | string = 'none';\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\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\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}\n","<!-- ngModel -->\n<ion-input\n *ngIf=\"!control\"\n [ngClass]=\"{ 'text-center': inputTextCenter, 'grey-background': inputGreyBackground }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"!inputClear\"\n [autocapitalize]=\"autoCapitalize\"\n mode=\"md\"\n [inputmode]=\"localInputMode\"\n [min]=\"min\"\n [max]=\"max\"\n [maxlength]=\"maxLength || null\"\n [type]=\"type\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n [value]=\"value\"></ion-input>\n<!-- Form Control -->\n<ion-input\n *ngIf=\"control\"\n [ngClass]=\"{ 'text-center': inputTextCenter, 'grey-background': inputGreyBackground }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n [clearInput]=\"!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]=\"type\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"></ion-input>\n<cf-form-validation *ngIf=\"control\" [control]=\"control\"></cf-form-validation>\n","/**\n * Carefirst Library Form Input Select\n *\n * @file form-input-select.component\n * @description Contains all the logic for generating a CareFirst Select\n * @author Arno Jansen van Vuuren\n * @since 2023 - 12 - 14\n * @usage <cf-form-input-select label=\"Label Name\" [options]=\"[{ displayName: string; value: string | number | boolean | null | undefined }]\" %labelPlacement% %(valueChange)=\"currentValue\"% %[(value)]=\"twoWayComs\"% %[control]%=\"formName.controls.controlName\"></cf-form-input-select>\n * disable input by disabling the form control\n */\n\nimport { Component, EventEmitter, Input, Output, type OnChanges, type SimpleChanges } from '@angular/core';\nimport { FormControl } from '@angular/forms';\n//--- Utils\nimport { validateStringValue } from '../../utils/attribute.util';\n//--- Interfaces\nimport type { FormInputSelectOptionsI } from '../../interfaces/input.interface';\n\n/**==============================================\n * @interface inputSelectC\n * @description Define available input select values\n */\nconst inputSelectC = {\n labelPlacement: ['fixed', 'floating', 'stacked', 'start', 'end'],\n} as const;\n\n@Component({\n selector: 'cf-form-input-select',\n templateUrl: './form-input-select.component.html',\n styleUrl: './form-input-select.component.scss',\n})\nexport class FormInputSelectComponent<T> implements OnChanges {\n @Input() label!: string;\n @Input() options!: FormInputSelectOptionsI<T>[];\n @Input() labelPlacement?: (typeof inputSelectC.labelPlacement)[number];\n @Input() placeholder?: string | undefined;\n @Input() control?: FormControl | null;\n\n //--- ngModel\n @Input() value: FormInputSelectOptionsI<T>['value'] | undefined;\n @Output() valueChange = new EventEmitter<typeof this.value>();\n\n //--- Local variables\n inputLabelPlacement: typeof this.labelPlacement;\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 inputSelectC.labelPlacement)[number]>(\n changes,\n 'labelPlacement',\n inputSelectC.labelPlacement.slice(),\n this.inputLabelPlacement\n ) || 'floating';\n }\n}\n","<!-- ngModel -->\n<ion-select\n *ngIf=\"!control\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n mode=\"md\"\n interface=\"popover\"\n (ionChange)=\"valueChange.emit($event.detail.value ?? undefined)\"\n [value]=\"value\">\n <ion-select-option *ngFor=\"let option of options\" [value]=\"option.value\">{{ option.displayName }}</ion-select-option>\n</ion-select>\n<!-- Form Control -->\n<ion-select\n *ngIf=\"control\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n [placeholder]=\"placeholder\"\n fill=\"outline\"\n mode=\"md\"\n interface=\"popover\"\n [formControl]=\"control\"\n (ionChange)=\"valueChange.emit($event.detail.value ?? undefined)\">\n <ion-select-option *ngFor=\"let option of options\" [value]=\"option.value\">{{ option.displayName }}</ion-select-option>\n</ion-select>\n<cf-form-validation *ngIf=\"control\" [control]=\"control\"></cf-form-validation>\n","/**\n * Carefirst Library Form Input Text Area\n *\n * @file form-input-text-area.component\n * @description Contains all the logic for generating a CareFirst Form Input Text Area\n * @author Arno Jansen van Vuuren\n * @since 2023 - 12 - 18\n * @usage <cf-form-input-text-area label=\"Label Name\" %labelPlacement% %textCenter% %autoCapitalize% %(valueChange)=\"currentValue\"% %[(value)]=\"twoWayComs\"% %[control]%=\"formName.controls.controlName\"></cf-form-input-text-area>\n * disable input by disabling the form control\n */\n\nimport { Component, EventEmitter, Input, Output, type OnChanges, type SimpleChanges } from '@angular/core';\nimport type { FormControl } from '@angular/forms';\n//--- Utils\nimport { validateStringValue, checkTruthAttribute } from '../../utils/attribute.util';\n\n/**==============================================\n * @interface inputTextAreaC\n * @description Define available input values\n */\nconst inputTextAreaC = {\n labelPlacement: ['fixed', 'floating', 'stacked', 'start', 'end'],\n autoCapitalize: ['off', 'none', 'on', 'sentences', 'words', 'characters'],\n} as const;\n\n@Component({\n selector: 'cf-form-input-text-area',\n templateUrl: './form-input-text-area.component.html',\n styleUrl: './form-input-text-area.component.scss',\n})\nexport class FormInputTextAreaComponent implements OnChanges {\n @Input() label!: string;\n @Input() labelPlacement?: (typeof inputTextAreaC.labelPlacement)[number];\n @Input() placeholder?: string | undefined;\n @Input() autoCapitalize?: (typeof inputTextAreaC.autoCapitalize)[number];\n @Input() control?: FormControl | null;\n @Input() textCenter?: boolean | string | undefined;\n @Input() minHeight?: string | 'none' = 'none';\n @Input() maxHeight?: string | 'none' = 'none';\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 = true;\n inputTextCenter = false;\n inputAutoCapitalize: typeof this.autoCapitalize;\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 inputTextAreaC.labelPlacement)[number]>(\n changes,\n 'labelPlacement',\n inputTextAreaC.labelPlacement.slice(),\n this.inputLabelPlacement\n ) || 'floating';\n //--- Text Center\n this.inputTextCenter = checkTruthAttribute(changes, 'textCenter', this.inputTextCenter);\n //--- Auto Capitalize\n this.inputAutoCapitalize =\n validateStringValue<(typeof inputTextAreaC.autoCapitalize)[number]>(\n changes,\n 'autoCapitalize',\n inputTextAreaC.autoCapitalize.slice(),\n this.inputAutoCapitalize\n ) || 'none';\n }\n}\n","<!-- ngModel -->\n<ion-textarea\n [style]=\"'min-height: ' + minHeight + '; max-height: ' + maxHeight\"\n *ngIf=\"!control\"\n [placeholder]=\"placeholder\"\n [ngClass]=\"{ 'text-center': inputTextCenter }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n fill=\"outline\"\n [autocapitalize]=\"autoCapitalize\"\n [autoGrow]=\"true\"\n mode=\"md\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"\n [value]=\"value\"></ion-textarea>\n<!-- Form Control -->\n<ion-textarea\n [style]=\"'min-height: ' + minHeight + '; max-height: ' + maxHeight\"\n *ngIf=\"control\"\n [placeholder]=\"placeholder\"\n [ngClass]=\"{ 'text-center': inputTextCenter }\"\n [label]=\"label\"\n [labelPlacement]=\"inputLabelPlacement\"\n fill=\"outline\"\n [autocapitalize]=\"autoCapitalize\"\n [autoGrow]=\"true\"\n mode=\"md\"\n [formControl]=\"control\"\n (ionInput)=\"valueChange.emit($event.detail.value ?? undefined)\"></ion-textarea>\n<cf-form-validation *ngIf=\"control\" [control]=\"control\"></cf-form-validation>\n","/**\n * CareFirst Chat Bubble\n *\n * @file chat-bubble.component\n * @description Contains all the logic for generating a CareFirst Chat Bubble\n * @author Jacques Coetzee\n * @since 2024 - 02 - 22\n * @usage <cf-chat-bubble type=\"outgoing | incoming\" date=\"string\" message=\"string\"></cf-chat-bubble>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\n//--- Utils\nimport { validateStringValue } from '../../utils/attribute.util';\n\n@Component({\n selector: 'cf-chat-bubble',\n templateUrl: './chat-bubble.component.html',\n styleUrl: './chat-bubble.component.scss',\n})\nexport class ChatBubbleComponent implements OnChanges {\n @Input() type: 'outgoing' | 'incoming' = 'outgoing';\n @Input() date: string = '';\n @Input() message: string = '';\n\n //--- Local variables\n inputType: typeof this.type = 'incoming';\n inputDate: typeof this.date = '';\n inputMessage: typeof this.message = '';\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Type\n this.inputType = validateStringValue<typeof this.type>(changes, 'type', ['incoming', 'outgoing'], this.inputType) || 'outgoing';\n //--- Date\n this.inputDate = changes['date']?.currentValue || '';\n //--- Message\n this.inputMessage = changes['message']?.currentValue || '';\n }\n}\n","<div id=\"container\" [ngClass]=\"inputType\">\n <div id=\"message\">\n <p class=\"body-extra-small\">{{ inputDate }}</p>\n <cf-spacer default=\"4\"></cf-spacer>\n <div id=\"bubble\">\n <p class=\"body-extra-small\">{{ inputMessage }}</p>\n </div>\n </div>\n</div>\n","/**\n * CareFirst Chat Badge\n *\n * @file badge.component\n * @description Contains all the logic for generating a CareFirst Chat Badge\n * @author Jacques Coetzee\n * @since 2024 - 02 - 22\n * @usage <cf-badge type=\"BadgeTypeT\" %icon%=\"IconsT\"></cf-badge>\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\n//--- Utils\nimport { checkTruthAttribute, validateStringValue } from '../../utils/attribute.util';\n//--- Interfaces\nimport { iconsC, type IconsT } from '../../interfaces/icon.interface';\n\n/**==============================================\n * @interface BadgeTypeT\n * @description Types of badges available\n */\nconst badgeTypeC = [\n 'primary',\n 'white',\n 'success',\n 'alert',\n 'accent',\n 'warning',\n 'disabled',\n 'feedback-success',\n 'feedback-error',\n 'feedback-warning',\n 'feedback-busy',\n] as const;\ntype BadgeTypeT = (typeof badgeTypeC)[number];\n\n/**==============================================\n * @name BadgeComponent\n * */\n@Component({\n selector: 'cf-badge',\n templateUrl: './badge.component.html',\n styleUrl: './badge.component.scss',\n})\nexport class BadgeComponent implements OnChanges {\n @Input() type: BadgeTypeT = 'primary';\n @Input() icon?: IconsT | undefined;\n @Input() small?: boolean | string | undefined;\n @Input() large?: boolean | string | undefined;\n\n //--- Local variables\n inputType: typeof this.type = 'primary';\n inputIcon: typeof this.icon | undefined = undefined;\n fontsize = 12;\n inputSmall = false;\n inputLarge = false;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Type\n this.inputType = validateStringValue<BadgeTypeT>(changes, 'type', badgeTypeC.slice(), this.inputType) || 'primary';\n //--- Icon Start\n this.inputIcon = validateStringValue<IconsT>(changes, 'icon', iconsC.slice(), this.inputIcon);\n //--- Small Badge\n this.inputSmall = checkTruthAttribute(changes, 'small', this.inputSmall);\n if (this.inputSmall) this.fontsize = 10;\n //--- Large Badge\n this.inputLarge = checkTruthAttribute(changes, 'large', this.inputLarge);\n if (this.inputLarge) this.fontsize = 16;\n }\n}\n","<div [className]=\"'cf-badge-' + inputType\" [ngClass]=\"{ small: inputSmall, large: inputLarge }\">\n <cf-icon *ngIf=\"inputIcon && inputType !== 'feedback-busy'\" [icon]=\"inputIcon\" [height]=\"fontsize\"></cf-icon>\n <ion-spinner *ngIf=\"inputType === 'feedback-busy'\"></ion-spinner>\n <p><ng-content></ng-content></p>\n</div>\n","/**\n * CareFirst Library - Spinner\n *\n * @file spinner.component\n * @description Contains all the logic for generating a CareFirst Spinner\n * @author Jacques Coetzee\n * @since 2024 - 02 - 23\n */\n\nimport { Component, Input, type OnChanges, type SimpleChanges } from '@angular/core';\nimport { validateNumberValue } from '../../utils/attribute.util';\n\n@Component({\n selector: 'cf-spinner',\n templateUrl: './spinner.component.html',\n styleUrl: './spinner.component.scss',\n})\nexport class SpinnerComponent implements OnChanges {\n @Input() size: number | string = 20;\n\n //--- Local variables\n inputSize: number = 20;\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Size\n this.inputSize = validateNumberValue(changes, 'size', this.inputSize) || this.inputSize;\n }\n}\n","<div id=\"spinner\" [style]=\"'font-size: ' + inputSize + 'px'\"></div>\n","/**\n * Carefirst library - Verification Code Input\n *\n * @file verification-code.component\n * @description Contains all the logic for generating a CareFirst Verification Code Input\n * @author Arno Jansen van Vuuren\n * @since 2024 - 03 - 07\n * @usage <cf-verification-code\n valueToVerify=`string`\n (outcome)=`omits code value`\n (resendClickEvent)=`resend click event`\n [status]=`BehaviorSubject<'initial' | 'invalid'>`>\n </cf-verification-code>\n */\n\nimport { Component, EventEmitter, Input, Output, ViewChild, type OnChanges, type SimpleChanges } from '@angular/core';\n//--- Interface\nimport type { BehaviorSubject, Subscription } from 'rxjs';\nimport type { InputCustomEvent, IonInput } from '@ionic/angular';\nimport type { CfCodeInputUserFeedbackMessagesI } from '../../interfaces/verification-code.interface';\n\n@Component({\n selector: 'cf-verification-code',\n templateUrl: './verification-code.component.html',\n styleUrl: './verification-code.component.scss',\n})\nexport class VerificationCodeComponent implements OnChanges {\n @Input() valueToVerify!: string;\n @Input() status!: BehaviorSubject<'initial' | 'invalid'>;\n @Input() userFeedbackMessages?: CfCodeInputUserFeedbackMessagesI;\n\n @Output() outcome = new EventEmitter<string>();\n @Output() resendClickEvent = new EventEmitter<true>();\n\n @ViewChild(`input1`) myInput1?: IonInput;\n @ViewChild('input2') myInput2?: IonInput;\n @ViewChild('input3') myInput3?: IonInput;\n @ViewChild('input4') myInput4?: IonInput;\n @ViewChild('input5') myInput5?: IonInput;\n\n //--- HTML variables\n validationCodeError = false;\n verificationCodeInputArr: (number | null)[] = [null, null, null, null, null];\n loading = false;\n commsSentCount = 0;\n validationCode: string | undefined;\n\n statusSub$?: Subscription;\n\n /**----------------------------------------------------------------\n * @name constructor\n */\n constructor() {}\n\n /**----------------------------------------------------------------\n * @name ionViewWillEnter\n * @description Update various values on component initialization\n * @returns {void}\n */\n ionViewDidEnter(): void {\n this.commsSentCount = 0;\n }\n\n /**----------------------------------------------------------------\n * @name ngOnChanges\n * @description Update various values on input changes\n * @returns {void}\n */\n ngOnChanges(changes: SimpleChanges): void {\n //--- Value to verify\n if (\n changes['valueToVerify']?.currentValue !== changes['valueToVerify']?.previousValue ||\n changes['code']?.currentValue !== changes['code']?.previousValue\n ) {\n this.commsSentCount = 0;\n this.validationCodeError = false;\n this.resetAllInputFields();\n }\n\n //--- Status display\n if (changes['status']) {\n this.statusSub$ = (changes['status'].currentValue as BehaviorSubject<'initial' | 'invalid'>).subscribe((stat) => {\n if (stat === 'invalid') {\n this.validationCodeError = true;\n }\n this.resetAllInputFields();\n this.setFocusToNext(0);\n });\n }\n }\n\n /**----------------------------------------------------------------\n * @name resendVerificationCode\n * @description Resend a verification code\n * @returns {void}\n */\n resendVerificationCode(): void {\n this.commsSentCount++;\n this.resendClickEvent.emit(true);\n }\n\n /**----------------------------------------------------------------\n * @name formulateAndCheckVerificationCode\n * @description Handle inputs associated with the verification code and do call once code is complete\n * @param {InputCustomEvent} event\n * @param {number} index\n * @returns {void}\n */\n formulateAndCheckVerificationCode(event: InputCustomEvent, index: number): void {\n const value = event.detail.value;\n if (!value || !(typeof value === 'string') || !(+value < 10)) {\n this.clearCodeInput(index);\n return;\n }\n\n this.setFocusToNext(index);\n this.verificationCodeInputArr[index - 1] = +value;\n this.validationCodeError = false;\n\n //--- Check if code completed\n if (this.verificationCodeInputArr.every((val) => val !== null)) {\n this.validationCode = this.verificationCodeInputArr.join('');\n this.outcome.emit(this.validationCode);\n }\n }\n\n /**----------------------------------------------------------------\n * @name resetAllInputFields\n * @description Reset all input fields\n * @returns {void}\n */\n private resetAllInputFields(): void {\n this.clearCodeInput(1);\n this.clearCodeInput(2);\n this.clearCodeInput(3);\n this.clearCodeInput(4);\n this.clearCodeInput(5);\n this.verificationCodeInputArr.fill(null);\n }\n\n /**----------------------------------------------------------------\n * @name setFocusToNext\n * @description Set the focus to the next input\n * @param {number} currentIndex\n * @returns {void}\n */\n private setFocusToNext(currentIndex: number): void {\n if (currentIndex === 5) return;\n currentIndex === 0\n ? this.myInput1?.setFocus()\n : currentIndex === 1\n ? this.myInput2?.setFocus()\n : currentIndex === 2\n ? this.myInput3?.setFocus()\n : currentIndex === 3\n ? this.myInput4?.setFocus()\n : this.myInput5?.setFocus();\n }\n\n /**----------------------------------------------------------------\n * @name clearCodeInput\n * @description Clear a code input on invalid key\n * @param {number} index\n * @returns {void}\n */\n private clearCodeInput(index: number): void {\n switch (index) {\n case 1:\n if (this.myInput1) this.myInput1.value = null;\n break;\n case 2:\n if (this.myInput2) this.myInput2.value = null;\n break;\n case 3:\n if (this.myInput3) this.myInput3.value = null;\n break;\n case 4:\n if (this.myInput4) this.myInput4.value = null;\n break;\n case 5:\n if (this.myInput5) this.myInput5.value = null;\n break;\n }\n }\n\n /**----------------------------------------------------------------\n * @name ionViewWillLeave\n * @description Unsubscribe on component leave\n * @returns {void}\n */\n ionViewWillLeave(): void {\n this.statusSub$?.unsubscribe();\n }\n}\n","<ion-grid>\n <!-- Input boxes for verification code 5 numeric digits -->\n <ion-row class=\"ion-justify-content-center\">\n <ion-col *ngIf=\"validationCodeError\" size=\"auto\">\n <p\n class=\"body-small error ion-text-center\"\n *ngFor=\"let string of userFeedbackMessages?.error?.errorMessage || ['Invalid Code - Please Retry']\"\n >{{ string }}</p\n >\n <cf-spacer default=\"16\"></cf-spacer>\n </ion-col>\n </ion-row>\n <ion-row class=\"ion-justify-content-center\">\n <ion-col size=\"auto\">\n <div class=\"single-container\" [ngClass]=\"{ error: validationCodeError }\">\n <ion-input\n #input1\n class=\"single-digit-input ion-text-center\"\n [disabled]=\"loading\"\n fill=\"outline\"\n maxlength=\"1\"\n clearOnEdit=\"true\"\n inputmode=\"numeric\"\n mode=\"md\"\n (ionInput)=\"formulateAndCheckVerificationCode($event, 1)\"></ion-input>\n <ion-input\n #input2\n class=\"single-digit-input ion-text-center\"\n [disabled]=\"loading\"\n fill=\"outline\"\n maxlength=\"1\"\n clearOnEdit=\"true\"\n inputmode=\"numeric\"\n mode=\"md\"\n (ionInput)=\"formulateAndCheckVerificationCode($event, 2)\"></ion-input>\n <ion-input\n #input3\n class=\"single-digit-input ion-text-center\"\n [disabled]=\"loading\"\n fill=\"outline\"\n maxlength=\"1\"\n clearOnEdit=\"true\"\n inputmode=\"numeric\"\n (ionInput)=\"formulateAndCheckVerificationCode($event, 3)\"></ion-input>\n <ion-input\n #input4\n class=\"single-digit-input ion-text-center\"\n [disabled]=\"loading\"\n fill=\"outline\"\n maxlength=\"1\"\n clearOnEdit=\"true\"\n inputmode=\"numeric\"\n mode=\"md\"\n (ionInput)=\"formulateAndCheckVerificationCode($event, 4)\"></ion-input>\n <ion-input\n #input5\n class=\"single-digit-input ion-text-center\"\n [disabled]=\"loading\"\n fill=\"outline\"\n maxlength=\"1\"\n clearOnEdit=\"true\"\n inputmode=\"numeric\"\n mode=\"md\"\n (ionInput)=\"formulateAndCheckVerificationCode($event, 5)\"></ion-input>\n </div>\n </ion-col>\n </ion-row>\n <ion-row class=\"ion-justify-content-center\">\n <ion-col size=\"auto\">\n <cf-spacer default=\"16\"></cf-spacer>\n <ng-container *ngIf=\"!loading\">\n <button *ngIf=\"commsSentCount < 3\" (click)=\"resendVerificationCode()\" style=\"background-color: transparent\">\n <ng-container *ngIf=\"validationCodeError\">\n <p class=\"body-small ion-text-center\" *ngFor=\"let string of userFeedbackMessages?.error?.resend || ['Resend Code']\">\n {{ string }}\n </p>\n </ng-container>\n <ng-container *ngIf=\"!validationCodeError\">\n <p\n class=\"body-small ion-text-center\"\n *ngFor=\"let string of userFeedbackMessages?.standardResend || ['Didn`t get a code? Please resend the code']\">\n {{ string }}\n </p>\n </ng-container>\n </button>\n <ng-container *ngIf=\"commsSentCount >= 3\">\n <p\n class=\"body-small ion-text-center\"\n *ngFor=\"let string of userFeedbackMessages?.limitReached || ['Still struggling with your code?', 'Please contact support for assistance']\"\n >{{ string }}</p\n >\n </ng-container>\n </ng-container>\n </ion-col>\n </ion-row>\n <ion-row class=\"ion-justify-content-center\">\n <ion-col size=\"auto\">\n <cf-spinner [size]=\"50\" [ngClass]=\"{ 'block-hidden': !loading }\"></cf-spinner>\n </ion-col>\n </ion-row>\n</ion-grid>\n","import { CUSTOM_ELEMENTS_SCHEMA, NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n//--- Modules\nimport { IonicModule } from '@ionic/angular';\nimport { ReactiveFormsModule } from '@angular/forms';\n//--- Directives\nimport { ButtonLoaderDirective } from './directives/button-loader.directive';\n//--- Components\nimport { PageComponent } from './components/page/page.component';\nimport { ButtonComponent } from './components/button/button.component';\nimport { SpacerComponent } from './components/spacer/spacer.component';\nimport { IconComponent } from './components/icon/icon.component';\nimport { NotificationComponent } from './components/notification/notification.component';\nimport { AlertComponent } from './components/alert/alert.component';\nimport { LogoComponent } from './components/logo/logo.component';\nimport { CalendarComponent } from './components/calendar/calendar.component';\nimport { FormValidationComponent } from './components/form-validation/form-validation.component';\nimport { FormInputComponent } from './components/form-input/form-input.component';\nimport { FormInputSelectComponent } from './components/form-input-select/form-input-select.component';\nimport { FormInputTextAreaComponent } from './components/form-input-text-area/form-input-text-area.component';\nimport { ChatBubbleComponent } from './components/chat-bubble/chat-bubble.component';\nimport { BadgeComponent } from './components/badge/badge.component';\nimport { SpinnerComponent } from './components/spinner/spinner.component';\nimport { VerificationCodeComponent } from './components/verification-code/verification-code.component';\n\n@NgModule({\n declarations: [\n PageComponent,\n ButtonComponent,\n SpacerComponent,\n IconComponent,\n ButtonLoaderDirective,\n NotificationComponent,\n AlertComponent,\n LogoComponent,\n CalendarComponent,\n FormValidationComponent,\n FormInputComponent,\n FormInputSelectComponent,\n FormInputTextAreaComponent,\n ChatBubbleComponent,\n BadgeComponent,\n SpinnerComponent,\n VerificationCodeComponent,\n ],\n\n imports: [IonicModule, CommonModule, ReactiveFormsModule],\n exports: [\n PageComponent,\n ButtonComponent,\n SpacerComponent,\n IconComponent,\n ButtonLoaderDirective,\n NotificationComponent,\n AlertComponent,\n LogoComponent,\n CalendarComponent,\n FormValidationComponent,\n FormInputComponent,\n FormInputSelectComponent,\n FormInputTextAreaComponent,\n ChatBubbleComponent,\n BadgeComponent,\n SpinnerComponent,\n VerificationCodeComponent,\n ],\n schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class CareFirstLibraryModule {}\n","/**\n * Form validators\n *\n * @file form-validators\n * @description Various form validators\n * @author Jacques Coetzee\n * @since 2022 - 01 - 20\n * @usage Display \"errorMessage\" key value as validator response message\n */\n\nimport { AbstractControl } from '@angular/forms';\nimport passwordValidator from 'password-validator';\nimport dayjs from 'dayjs';\nimport customParseFormat from 'dayjs/plugin/customParseFormat';\ndayjs.extend(customParseFormat);\n//--- Interfaces\nimport type { ValidationErrors, ValidatorFn } from '@angular/forms';\n\nexport class CFPFormValidators {\n /**----------------------------------------------------------------\n * @name checkPSWRetype\n * @description Check if passwords match\n * @param {string} controlNameToCheckAgainst\n * @returns {ValidatorFn}\n * @usage FormValidators.compareTo('password')\n */\n static compareTo(controlNameToCheckAgainst: string): ValidatorFn {\n return (control: AbstractControl): ValidationErrors | null => {\n //--- Compare controls\n const controlToCheckTo: AbstractControl | null = control?.parent?.get(controlNameToCheckAgainst) || null;\n\n //--- Check primary control value\n if (!controlToCheckTo?.value) return { errorMessage: `Password Required` };\n //--- Check secondary control value\n else if (!control.value) return { errorMessage: `Password confirmation required` };\n //--- Compare controls\n else if (control.value && control?.value !== controlToCheckTo?.value) return { errorMessage: `Passwords do not match` };\n\n return null;\n };\n }\n\n /**----------------------------------------------------------------\n * @name asPassword\n * @description Validate control as password\n * @returns {ValidatorFn}\n * @usage FormValidators.asPassword()\n */\n static asPassword(): ValidatorFn {\n return (control: AbstractControl): ValidationErrors | null => {\n const schema = new passwordValidator();\n\n //--- Setup password requirements\n schema\n //--- Minimum length 8\n .is()\n .min(8, 'Minimum of 8 characters')\n //--- Maximum length 50\n .is()\n .max(30, 'Maximum of 30 characters')\n //--- Must have uppercase letters\n .has()\n .uppercase(undefined, 'At least one UPPERCASE character')\n //--- Must have lowercase letters\n .has()\n .lowercase(undefined, 'At least one lowercase character')\n //--- Must have at least 1 digits\n .has()\n .digits(undefined, 'At least one digit')\n //--- Special characters\n .has()\n .symbols(undefined, 'At least one special character');\n\n //--- Validate string\n const inValid = schema.validate(control.value, { details: true }) as {\n validation: string;\n message: string;\n arguments?: number;\n }[];\n\n const returnResponse: { [key: string]: unknown } = {};\n inValid.forEach((error) => {\n returnResponse['password-' + error.validation] = error.message;\n });\n return inValid.length ? returnResponse : null;\n };\n }\n\n /**----------------------------------------------------------------\n * @name asEmail\n * @description Validate control as email\n * @param {true} canBeEmpty\n * @returns {ValidatorFn}\n * @usage FormValidators.asEmail(true?)\n */\n static asEmail(canBeEmpty?: true): ValidatorFn {\n return (control: AbstractControl): ValidationErrors | null => {\n let setErrors = null;\n const emailRegEx = new RegExp('^[\\\\w-.]+@[\\\\w]+\\\\.[\\\\w]+');\n\n //--- Check if email can be empty\n if (canBeEmpty && (control.value === null || control.value === '')) {\n return null;\n }\n\n //--- Test RegExp\n if (!(control.value && emailRegEx.test(control.value))) {\n setErrors = { errorMessage: `Not a valid email address` };\n }\n\n return setErrors;\n };\n }\n\n /**----------------------------------------------------------------\n * @name isIn\n * @description Validate control value is part of a given list\n * @param {string | number[]} list\n * @returns {ValidatorFn}\n * @usage FormValidators.isIn()\n */\n static isIn(list: (string | number)[]): ValidatorFn {\n return (control: AbstractControl): ValidationErrors | null => {\n if (!list.includes(control.value)) return { errorMessage: 'Control value not part of eligible values' };\n return null;\n };\n }\n\n /**----------------------------------------------------------------\n * @name isSAIDNumber\n * @description Validate control value is a valid RSA ID Number\n * @param {true} canBeEmpty\n * @returns {ValidatorFn}\n * @usage FormValidators.isSAIDNumber(true?)\n */\n static isSAIDNumber(canBeEmpty?: true): ValidatorFn {\n return (control: AbstractControl): ValidationErrors | null => {\n const validateDate = (): boolean => {\n if (typeof control.value !== 'string' || control.value.length < 6) return false;\n const month = control.value.slice(2, 4);\n const day = control.value.slice(4, 6);\n if (+month < 0 && +month > 13) return false;\n if (+day < 0 && +day > 31) return false;\n if (!dayjs(control.value.slice(0, 6), 'YYMMDD', true).isValid()) return false;\n return true;\n };\n\n const checksum = (): boolean => {\n if (typeof control.value !== 'string' || control.value.length !== 13) return false;\n let nSum = 0; //--- Total sum of all the values\n let isSecond = false; //--- To double every other value\n //--- Start from the end\n for (let i = control.value.length - 1; i >= 0; i--) {\n const val: string | undefined = control.value[i];\n if (!val) return false;\n //--- Get numerical value from ascii string\n let d: number = val.charCodeAt(0) - '0'.charCodeAt(0);\n //--- Double every other value\n if (isSecond == true) d = d * 2;\n //--- Sum the total of the doubled values if available\n nSum += Math.floor(d / 10);\n nSum += d % 10;\n //--- Inverse second to determine every other index value\n isSecond = !isSecond;\n }\n //--- Return the modulus 10 of the summation\n return nSum % 10 == 0;\n };\n\n let error: string | null = null;\n if (canBeEmpty && (!control.value || control.value?.length === 0)) return null;\n //--- string\n else if (typeof control.value !== 'string') error = 'Invalid RSA ID Number';\n //--- Length = 13\n else if (control.value.length !== 13) error = `Length required: ${13 - control.value.length}`;\n //--- Validate date\n else if (!validateDate()) error = `Invalid date of birth`;\n //--- Citizenship\n else if (!['0', '1'].includes(control.value.slice(10, 11))) error = `Invalid citizenship value`;\n //--- Checksum\n else if (!checksum()) error = `Invalid RSA ID number checksum`;\n\n return error ? { errorMessage: error } : null;\n };\n }\n}\n","/**==============================================\n * @description Available Spacer Values\n */\nexport const spacerNumberArray = [4, 8, 12, 16, 24, 32, 38, 48, 72] as const;\nexport type SpacerNumberT = (typeof spacerNumberArray)[number];\nexport type SpacerStringT = `${SpacerNumberT}`;\n"],"names":["SpinnerComponent","i1","i3.IconComponent","i4.ButtonLoaderDirective","i3.ButtonComponent","i4.SpacerComponent","i5.IconComponent","i4.FormValidationComponent","i2.SpacerComponent","i3.SpacerComponent","i4.SpinnerComponent"],"mappings":"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"}