@sarasanalytics-com/design-system 0.0.74 → 0.0.76
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/card/menu-card/menu-card.component.mjs +2 -2
- package/esm2022/lib/form-input/form-input.component.mjs +19 -11
- package/esm2022/utils/validators.mjs +15 -3
- package/fesm2022/sarasanalytics-com-design-system.mjs +32 -12
- package/fesm2022/sarasanalytics-com-design-system.mjs.map +1 -1
- package/package.json +1 -1
- package/utils/validators.d.ts +1 -1
|
@@ -48,7 +48,7 @@ export class MenuCardComponent extends FieldType {
|
|
|
48
48
|
actionHandler(button, event) {
|
|
49
49
|
event.stopPropagation();
|
|
50
50
|
event.preventDefault();
|
|
51
|
-
this.onButtonClickEvent.next(button);
|
|
51
|
+
this.onButtonClickEvent.next({ category: this.selectedStep, button: button });
|
|
52
52
|
}
|
|
53
53
|
showSources(sourceType) {
|
|
54
54
|
this.onFooterClickEvent.emit(sourceType);
|
|
@@ -74,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
|
|
|
74
74
|
}], onFooterClickEvent: [{
|
|
75
75
|
type: Output
|
|
76
76
|
}] } });
|
|
77
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-card.component.js","sourceRoot":"","sources":["../../../../../../projects/component-library/src/lib/card/menu-card/menu-card.component.ts","../../../../../../projects/component-library/src/lib/card/menu-card/menu-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { GuideCardComponent } from '../guide-card/guide-card.component';\nimport { FieldType, } from '@ngx-formly/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { CardComponent } from '../card.component';\nimport { CardCustomHeaderComponent } from '../card-custom-header/card-custom-header.component';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { ChipsComponent } from '../../chips/chips.component';\nimport { IconComponent } from '../../icon/icon.component';\nimport { ButtonComponent } from '../../button/button.component';\nimport { CardTitleActionsComponent } from '../card-title-actions/card-title-actions.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { find as _find } from 'lodash'\nimport { MessageBannerComponent } from '../../message-banner/message-banner.component';\n@Component({\n  selector: 'sa-menu-card',\n  standalone: true,\n  imports: [ChipsComponent, CommonModule, GuideCardComponent, FormsModule, ReactiveFormsModule, FormlyModule, CardComponent, CardCustomHeaderComponent, IconComponent, MatExpansionModule, ButtonComponent, CardTitleActionsComponent, MatTooltipModule, MessageBannerComponent],\n  templateUrl: './menu-card.component.html',\n  styleUrl: './menu-card.component.css'\n})\nexport class MenuCardComponent extends FieldType {\n  @Input() title: string = 'Categories:';\n  @Input() steps: any[];\n  @Input() footerDetails: any;\n  @Output() onButtonClickEvent = new EventEmitter<any>();\n  @Output() onCardClickEvent = new EventEmitter<any>();\n  @Output() onFooterClickEvent = new EventEmitter<any>();\n  selectedStep: any;\n  selectedGuideStep: any | null = null;\n  customClassWrapper = 'menuCardSourceContainer'\n\n  ngOnInit() {\n    this.selectedStep = _find(this.steps, { isSelected: true })\n  }\n\n  onStepChanged(event) {\n    this.selectedStep = event;\n  }\n\n  onCardClick(source: any, button: any, event: Event) {\n    event.stopPropagation();\n    event.preventDefault();\n    this.onCardClickEvent.emit({ category: this.selectedStep, source: source, button: button })\n  }\n\n  onAdvancedFeaturesOpened() {\n    this.selectedStep.advancedFeaturesExpanded = true;\n  }\n\n  onAdvancedFeaturesClosed() {\n    this.selectedStep.advancedFeaturesExpanded = false;\n  }\n\n  actionHandler(button: any, event: Event) {\n    event.stopPropagation();\n    event.preventDefault();\n    this.onButtonClickEvent.next(button);\n  }\n\n  showSources(sourceType: any) {\n    this.onFooterClickEvent.emit(sourceType);\n    //console.log(sourceType)\n    this.onStepChanged(sourceType)\n  }\n}\n","<div class=\"menu-card-container\">\n    <div class=\"left-card-container\">\n        <sa-guide-card [title]=\"'Categories:'\" [steps]=\"steps\" [selectable]=\"true\"\n            (onStepClicked)=\"onStepChanged($event)\" [selectedStep]=\"selectedStep\"></sa-guide-card>\n        <div class=\"card-footer-container\">\n            <span class=\"horizontal-line\"></span>\n            <ng-container *ngFor=\"let footerDetail of footerDetails\">\n                <div (click)=\"showSources(footerDetail)\" class=\"footer\"\n                    [ngClass]=\"footerDetail === selectedStep ? 'selected-step' : 'other-step'\">\n                    <span class=\"footer-text\">\n                        {{footerDetail?.title}}\n                        <ng-container *ngIf=\"footerDetail?.count\">\n                            <span>({{footerDetail?.count}})</span>\n                        </ng-container>\n                    </span>\n                </div>\n            </ng-container>\n        </div>\n    </div>\n\n    <div class=\"right-card-container\">\n        @if(selectedStep?.messageContent){\n        <div class=\"message-container\">\n            <sa-message-banner [type]=\"'info'\">\n                <div class=\"message-content\" [innerHtml]=\"selectedStep?.messageContent\">\n                </div>\n            </sa-message-banner>\n        </div>\n        }\n        <div class=\"heading-container\">\n            <span class=\"heading-style\">{{selectedStep?.sourcesHeading || 'Available Sources'}}:</span>\n        </div>\n        <div *ngIf=\"selectedStep?.sourcesList\" class=\"cards-container\">\n            <ng-container *ngFor=\"let source of selectedStep.sourcesList\">\n                <ng-container\n                    *ngTemplateOutlet=\"cardTemplate; context: { source: source, selectedStep: selectedStep, actionButton: selectedStep?.actionButton }\">\n                </ng-container>\n            </ng-container>\n        </div>\n        <!-- for advanced options -->\n        <div *ngIf=\"selectedStep?.advancedSourcesList && selectedStep.advancedSourcesList.length > 0\"\n            class=\"menu-card-advanced-features-section\">\n\n            <mat-expansion-panel hideToggle [expanded]=\"selectedStep?.advancedFeaturesExpanded || false\"\n                (opened)=\"onAdvancedFeaturesOpened()\" (closed)=\"onAdvancedFeaturesClosed()\"\n                class=\"menuAdvancedAccordion\">\n                <mat-expansion-panel-header>\n                    <mat-panel-title>\n                        <div class=\"panel-container\">\n                            @if(!selectedStep?.advancedFeaturesExpanded){\n                            <span class=\"d-flex align-center source-icon\">\n                                <sa-icon [icon]=\"selectedStep?.advancedFeatureCollapsedIcon || 'rightChevronOutlined'\"\n                                    class=\"d-flex\" customClass=\"colored-icon\" size=\"20\"></sa-icon>\n                            </span>\n                            }@else{\n                            <span class=\"d-flex align-center\">\n                                <sa-icon [icon]=\"selectedStep?.advancedFeatureExpandedIcon || 'downChevronOutlined'\"\n                                    class=\"d-flex\" size=\"20\"></sa-icon>\n                            </span>\n                            }\n                            <span class=\"advanced-title\">{{ selectedStep?.advancedFeatureTitle }}</span>\n                        </div>\n                    </mat-panel-title>\n                </mat-expansion-panel-header>\n                <div class=\"expansion-container\">\n                    @if(selectedStep?.advancedFeatureDisclaimer){\n                    <div class=\"disclaimer-container\">\n                        <sa-message-banner [type]=\"'disclaimer'\">\n                            <div class=\"disclaimer-content\">\n                                @if(selectedStep?.advancedFeatureDisclaimerTooltip){\n                                <span class=\"tooltip-container\">\n                                    <sa-icon icon=\"infoCircleOutlined\"\n                                        [matTooltip]=\"selectedStep?.advancedFeatureDisclaimerTooltip\" customClass=\"info-icon\"\n                                        class=\"tooltip-icon\"></sa-icon>\n                                </span>\n                                }\n                                <span class=\"disclaimer-style\">{{selectedStep?.advancedFeatureDisclaimer}}</span>\n                            </div>\n                            @if(selectedStep?.advancedFeatureDisclaimerButtons) {\n                            <div class=\"disclaimer-buttons-container\">\n                                <ng-container *ngFor=\"let button of selectedStep.advancedFeatureDisclaimerButtons\">\n                                    <sa-button [text]=\"button.text\" [type]=\"button.type\" [size]=\"button.size\"\n                                        [state]=\"button.state\" [iconPosition]=\"button.iconPosition\" [icon]=\"button.icon\"\n                                        [buttonIconSize]=\"button.buttonIconSize\"\n                                        (click)=\"actionHandler(button, $event)\"></sa-button>\n                                </ng-container>\n                            </div>\n                            }\n                        </sa-message-banner>\n                    </div>\n                    }\n                    <div class=\"cards-container\">\n                        <ng-container *ngFor=\"let source of selectedStep?.advancedSourcesList\">\n                            <ng-container\n                                *ngTemplateOutlet=\"cardTemplate; context: { source: source, selectedStep: selectedStep, actionButton: selectedStep?.actionButton }\">\n                            </ng-container>\n                        </ng-container>\n                    </div>\n                </div>\n            </mat-expansion-panel>\n        </div>\n    </div>\n</div>\n\n<ng-template #cardTemplate let-source=\"source\" let-selectedStep=\"selectedStep\" let-actionButton=\"actionButton\">\n    <sa-card [column]=\"false\" [showCardHeader]=\"true\" [showCardBody]=\"false\"\n        [width]=\"selectedStep.sourcesCardWidth || '471px'\" [showHeaderBodyDivider]=\"false\"\n        [customWrapperClass]=\"selectedStep.customWrapperClass || customClassWrapper\"\n        class=\"{{source.disabled ? 'disabled-card': 'enabled-card'}}\">\n        <sa-card-title-header>\n            <div class=\"sa-card-accordion-title-container\">\n                <div class=\"sa-menu-card-title-icon-container\">\n                    <div class=\"sa-menu-card-custom-title\">\n                        <ng-container *ngIf=\"source.logoUrl\">\n                            <sa-icon [icon]=\"source.logoUrl\" class=\"d-flex\" [customClass]=\"'auto-dimensions'\"></sa-icon>\n                        </ng-container>\n                        <span [matTooltip]=\"source?.tooltip\">\n                            {{source?.name}}\n                            <ng-container *ngIf=\"source?.count\">\n                                <span>({{source.count}})</span>\n                            </ng-container>\n                        </span>\n                        <ng-container *ngIf=\"source?.chipData\">\n                            <span>\n                                <sa-chip [type]=\"source?.chipData.type\" [state]=\"source?.chipData.state\"\n                                    [filling]=\"source?.chipData.filling\" [text]=\"source?.chipData.text\"\n                                    [iconPosition]='source?.chipData.iconPosition'\n                                    [iconPath]=\"source?.chipData.iconPath\">\n                                </sa-chip>\n                            </span>\n                        </ng-container>\n                    </div>\n                </div>\n                <ng-container\n                    *ngIf=\"!source.disabled && (selectedStep?.actionButton && (selectedStep?.showActionActionButton ? actionButton : null)) as button\">\n                    <div class=\"sa-card-titleIcon no-margin\">\n                        <sa-card-title-actions>\n                            <sa-button [text]=\"button.text\" [type]=\"button.type\" [size]=\"button.size\"\n                                [state]=\"button.state\" [iconPosition]=\"button.iconPosition\" [icon]=\"button.icon\"\n                                [buttonIconSize]=\"button.buttonIconSize\" (click)=\"onCardClick(source, button, $event)\">\n                            </sa-button>\n                        </sa-card-title-actions>\n                    </div>\n                </ng-container>\n            </div>\n        </sa-card-title-header>\n    </sa-card>\n</ng-template>"]}
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-card.component.js","sourceRoot":"","sources":["../../../../../../projects/component-library/src/lib/card/menu-card/menu-card.component.ts","../../../../../../projects/component-library/src/lib/card/menu-card/menu-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { GuideCardComponent } from '../guide-card/guide-card.component';\nimport { FieldType, } from '@ngx-formly/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { CardComponent } from '../card.component';\nimport { CardCustomHeaderComponent } from '../card-custom-header/card-custom-header.component';\nimport { MatExpansionModule } from '@angular/material/expansion';\nimport { ChipsComponent } from '../../chips/chips.component';\nimport { IconComponent } from '../../icon/icon.component';\nimport { ButtonComponent } from '../../button/button.component';\nimport { CardTitleActionsComponent } from '../card-title-actions/card-title-actions.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { find as _find } from 'lodash'\nimport { MessageBannerComponent } from '../../message-banner/message-banner.component';\n@Component({\n  selector: 'sa-menu-card',\n  standalone: true,\n  imports: [ChipsComponent, CommonModule, GuideCardComponent, FormsModule, ReactiveFormsModule, FormlyModule, CardComponent, CardCustomHeaderComponent, IconComponent, MatExpansionModule, ButtonComponent, CardTitleActionsComponent, MatTooltipModule, MessageBannerComponent],\n  templateUrl: './menu-card.component.html',\n  styleUrl: './menu-card.component.css'\n})\nexport class MenuCardComponent extends FieldType {\n  @Input() title: string = 'Categories:';\n  @Input() steps: any[];\n  @Input() footerDetails: any;\n  @Output() onButtonClickEvent = new EventEmitter<any>();\n  @Output() onCardClickEvent = new EventEmitter<any>();\n  @Output() onFooterClickEvent = new EventEmitter<any>();\n  selectedStep: any;\n  selectedGuideStep: any | null = null;\n  customClassWrapper = 'menuCardSourceContainer'\n\n  ngOnInit() {\n    this.selectedStep = _find(this.steps, { isSelected: true })\n  }\n\n  onStepChanged(event) {\n    this.selectedStep = event;\n  }\n\n  onCardClick(source: any, button: any, event: Event) {\n    event.stopPropagation();\n    event.preventDefault();\n    this.onCardClickEvent.emit({ category: this.selectedStep, source: source, button: button })\n  }\n\n  onAdvancedFeaturesOpened() {\n    this.selectedStep.advancedFeaturesExpanded = true;\n  }\n\n  onAdvancedFeaturesClosed() {\n    this.selectedStep.advancedFeaturesExpanded = false;\n  }\n\n  actionHandler(button: any, event: Event) {\n    event.stopPropagation();\n    event.preventDefault();\n    this.onButtonClickEvent.next({ category: this.selectedStep, button: button });\n  }\n\n  showSources(sourceType: any) {\n    this.onFooterClickEvent.emit(sourceType);\n    //console.log(sourceType)\n    this.onStepChanged(sourceType)\n  }\n}\n","<div class=\"menu-card-container\">\n    <div class=\"left-card-container\">\n        <sa-guide-card [title]=\"'Categories:'\" [steps]=\"steps\" [selectable]=\"true\"\n            (onStepClicked)=\"onStepChanged($event)\" [selectedStep]=\"selectedStep\"></sa-guide-card>\n        <div class=\"card-footer-container\">\n            <span class=\"horizontal-line\"></span>\n            <ng-container *ngFor=\"let footerDetail of footerDetails\">\n                <div (click)=\"showSources(footerDetail)\" class=\"footer\"\n                    [ngClass]=\"footerDetail === selectedStep ? 'selected-step' : 'other-step'\">\n                    <span class=\"footer-text\">\n                        {{footerDetail?.title}}\n                        <ng-container *ngIf=\"footerDetail?.count\">\n                            <span>({{footerDetail?.count}})</span>\n                        </ng-container>\n                    </span>\n                </div>\n            </ng-container>\n        </div>\n    </div>\n\n    <div class=\"right-card-container\">\n        @if(selectedStep?.messageContent){\n        <div class=\"message-container\">\n            <sa-message-banner [type]=\"'info'\">\n                <div class=\"message-content\" [innerHtml]=\"selectedStep?.messageContent\">\n                </div>\n            </sa-message-banner>\n        </div>\n        }\n        <div class=\"heading-container\">\n            <span class=\"heading-style\">{{selectedStep?.sourcesHeading || 'Available Sources'}}:</span>\n        </div>\n        <div *ngIf=\"selectedStep?.sourcesList\" class=\"cards-container\">\n            <ng-container *ngFor=\"let source of selectedStep.sourcesList\">\n                <ng-container\n                    *ngTemplateOutlet=\"cardTemplate; context: { source: source, selectedStep: selectedStep, actionButton: selectedStep?.actionButton }\">\n                </ng-container>\n            </ng-container>\n        </div>\n        <!-- for advanced options -->\n        <div *ngIf=\"selectedStep?.advancedSourcesList && selectedStep.advancedSourcesList.length > 0\"\n            class=\"menu-card-advanced-features-section\">\n\n            <mat-expansion-panel hideToggle [expanded]=\"selectedStep?.advancedFeaturesExpanded || false\"\n                (opened)=\"onAdvancedFeaturesOpened()\" (closed)=\"onAdvancedFeaturesClosed()\"\n                class=\"menuAdvancedAccordion\">\n                <mat-expansion-panel-header>\n                    <mat-panel-title>\n                        <div class=\"panel-container\">\n                            @if(!selectedStep?.advancedFeaturesExpanded){\n                            <span class=\"d-flex align-center source-icon\">\n                                <sa-icon [icon]=\"selectedStep?.advancedFeatureCollapsedIcon || 'rightChevronOutlined'\"\n                                    class=\"d-flex\" customClass=\"colored-icon\" size=\"20\"></sa-icon>\n                            </span>\n                            }@else{\n                            <span class=\"d-flex align-center\">\n                                <sa-icon [icon]=\"selectedStep?.advancedFeatureExpandedIcon || 'downChevronOutlined'\"\n                                    class=\"d-flex\" size=\"20\"></sa-icon>\n                            </span>\n                            }\n                            <span class=\"advanced-title\">{{ selectedStep?.advancedFeatureTitle }}</span>\n                        </div>\n                    </mat-panel-title>\n                </mat-expansion-panel-header>\n                <div class=\"expansion-container\">\n                    @if(selectedStep?.advancedFeatureDisclaimer){\n                    <div class=\"disclaimer-container\">\n                        <sa-message-banner [type]=\"'disclaimer'\">\n                            <div class=\"disclaimer-content\">\n                                @if(selectedStep?.advancedFeatureDisclaimerTooltip){\n                                <span class=\"tooltip-container\">\n                                    <sa-icon icon=\"infoCircleOutlined\"\n                                        [matTooltip]=\"selectedStep?.advancedFeatureDisclaimerTooltip\" customClass=\"info-icon\"\n                                        class=\"tooltip-icon\"></sa-icon>\n                                </span>\n                                }\n                                <span class=\"disclaimer-style\">{{selectedStep?.advancedFeatureDisclaimer}}</span>\n                            </div>\n                            @if(selectedStep?.advancedFeatureDisclaimerButtons) {\n                            <div class=\"disclaimer-buttons-container\">\n                                <ng-container *ngFor=\"let button of selectedStep.advancedFeatureDisclaimerButtons\">\n                                    <sa-button [text]=\"button.text\" [type]=\"button.type\" [size]=\"button.size\"\n                                        [state]=\"button.state\" [iconPosition]=\"button.iconPosition\" [icon]=\"button.icon\"\n                                        [buttonIconSize]=\"button.buttonIconSize\"\n                                        (click)=\"actionHandler(button, $event)\"></sa-button>\n                                </ng-container>\n                            </div>\n                            }\n                        </sa-message-banner>\n                    </div>\n                    }\n                    <div class=\"cards-container\">\n                        <ng-container *ngFor=\"let source of selectedStep?.advancedSourcesList\">\n                            <ng-container\n                                *ngTemplateOutlet=\"cardTemplate; context: { source: source, selectedStep: selectedStep, actionButton: selectedStep?.actionButton }\">\n                            </ng-container>\n                        </ng-container>\n                    </div>\n                </div>\n            </mat-expansion-panel>\n        </div>\n    </div>\n</div>\n\n<ng-template #cardTemplate let-source=\"source\" let-selectedStep=\"selectedStep\" let-actionButton=\"actionButton\">\n    <sa-card [column]=\"false\" [showCardHeader]=\"true\" [showCardBody]=\"false\"\n        [width]=\"selectedStep.sourcesCardWidth || '471px'\" [showHeaderBodyDivider]=\"false\"\n        [customWrapperClass]=\"selectedStep.customWrapperClass || customClassWrapper\"\n        class=\"{{source.disabled ? 'disabled-card': 'enabled-card'}}\">\n        <sa-card-title-header>\n            <div class=\"sa-card-accordion-title-container\">\n                <div class=\"sa-menu-card-title-icon-container\">\n                    <div class=\"sa-menu-card-custom-title\">\n                        <ng-container *ngIf=\"source.logoUrl\">\n                            <sa-icon [icon]=\"source.logoUrl\" class=\"d-flex\" [customClass]=\"'auto-dimensions'\"></sa-icon>\n                        </ng-container>\n                        <span [matTooltip]=\"source?.tooltip\">\n                            {{source?.name}}\n                            <ng-container *ngIf=\"source?.count\">\n                                <span>({{source.count}})</span>\n                            </ng-container>\n                        </span>\n                        <ng-container *ngIf=\"source?.chipData\">\n                            <span>\n                                <sa-chip [type]=\"source?.chipData.type\" [state]=\"source?.chipData.state\"\n                                    [filling]=\"source?.chipData.filling\" [text]=\"source?.chipData.text\"\n                                    [iconPosition]='source?.chipData.iconPosition'\n                                    [iconPath]=\"source?.chipData.iconPath\">\n                                </sa-chip>\n                            </span>\n                        </ng-container>\n                    </div>\n                </div>\n                <ng-container\n                    *ngIf=\"!source.disabled && (selectedStep?.actionButton && (selectedStep?.showActionActionButton ? actionButton : null)) as button\">\n                    <div class=\"sa-card-titleIcon no-margin\">\n                        <sa-card-title-actions>\n                            <sa-button [text]=\"button.text\" [type]=\"button.type\" [size]=\"button.size\"\n                                [state]=\"button.state\" [iconPosition]=\"button.iconPosition\" [icon]=\"button.icon\"\n                                [buttonIconSize]=\"button.buttonIconSize\" (click)=\"onCardClick(source, button, $event)\">\n                            </sa-button>\n                        </sa-card-title-actions>\n                    </div>\n                </ng-container>\n            </div>\n        </sa-card-title-header>\n    </sa-card>\n</ng-template>"]}
|
|
@@ -6,7 +6,7 @@ import { CommonModule } from '@angular/common';
|
|
|
6
6
|
import { getValidationMessage, } from '../../utils/validators';
|
|
7
7
|
import { IconComponent } from '../icon/icon.component';
|
|
8
8
|
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
9
|
-
import { set as _set } from 'lodash';
|
|
9
|
+
import { set as _set, get as _get } from 'lodash';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
11
|
import * as i1 from "@angular/common";
|
|
12
12
|
import * as i2 from "@angular/forms";
|
|
@@ -58,14 +58,17 @@ export class FormInputComponent extends FieldType {
|
|
|
58
58
|
});
|
|
59
59
|
}
|
|
60
60
|
setValidators() {
|
|
61
|
-
this.validators = this.params?.validators || [];
|
|
61
|
+
this.validators = this.params?.validators || this.predefinedValidators[this.type] || [];
|
|
62
62
|
this.asyncValidators = this.params?.asyncValidators || [];
|
|
63
|
-
this.
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
63
|
+
if (!_get(this.field, 'validators.validation', null)) {
|
|
64
|
+
this.formControl?.setValidators([
|
|
65
|
+
...(this.type ? this.predefinedValidators[this.type] || [] : []),
|
|
66
|
+
...(this.validators),
|
|
67
|
+
]);
|
|
68
|
+
}
|
|
69
|
+
if (this.asyncValidators) {
|
|
68
70
|
this.formControl?.setAsyncValidators(this.asyncValidators);
|
|
71
|
+
}
|
|
69
72
|
}
|
|
70
73
|
/*
|
|
71
74
|
Assuming dependent field is a single select dropdown
|
|
@@ -104,8 +107,10 @@ export class FormInputComponent extends FieldType {
|
|
|
104
107
|
!this.formControl.pending) {
|
|
105
108
|
this.inputState = 'invalid';
|
|
106
109
|
this.inputErrorText =
|
|
107
|
-
getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input'
|
|
108
|
-
|
|
110
|
+
getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input', {
|
|
111
|
+
field: this.field,
|
|
112
|
+
nativeValidationObject: this.field.validation,
|
|
113
|
+
}) || `invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`;
|
|
109
114
|
}
|
|
110
115
|
else {
|
|
111
116
|
this.inputState = defaultInputState;
|
|
@@ -194,7 +199,10 @@ export class FormInputComponent extends FieldType {
|
|
|
194
199
|
}*/
|
|
195
200
|
getFormSupportText() {
|
|
196
201
|
if (this.formControl.invalid && this.formControl.touched) {
|
|
197
|
-
return (getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input'
|
|
202
|
+
return (getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input', {
|
|
203
|
+
field: this.field,
|
|
204
|
+
nativeValidationObject: _get(this.field, 'validation'),
|
|
205
|
+
}) ||
|
|
198
206
|
`invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`);
|
|
199
207
|
}
|
|
200
208
|
else {
|
|
@@ -238,4 +246,4 @@ export var IInputEventType;
|
|
|
238
246
|
IInputEventType["STATE_CHANGE"] = "STATE_CHANGE";
|
|
239
247
|
IInputEventType["ICON_CLICK"] = "ICON_CLICK";
|
|
240
248
|
})(IInputEventType || (IInputEventType = {}));
|
|
241
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/form-input/form-input.component.ts","../../../../../projects/component-library/src/lib/form-input/form-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild } from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { FieldType, FieldTypeConfig } from '@ngx-formly/core';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { CommonModule } from '@angular/common';\nimport {\n  getValidationMessage,\n  phoneNumberValidator,\n} from '../../utils/validators';\nimport { IconComponent } from '../icon/icon.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { set as _set } from 'lodash';\n@Component({\n  selector: 'sa-input',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    FormlyModule,\n    IconComponent,\n    MatTooltipModule\n  ],\n  templateUrl: './form-input.component.html',\n  styleUrl: './form-input.component.css',\n})\nexport class FormInputComponent extends FieldType<FieldTypeConfig> {\n  @ViewChild('formInput') formInput!: ElementRef;\n\n  @Input('icon') icon: IInputIcon;\n\n  pretext: string;\n\n  inputState = 'idle';\n  inputVal = '';\n  params: IInputParam | null;\n  dependent: AbstractControl<any, any> | null;\n  dependentVal: any = null;\n  // dynamicIcon: DynamicIcon | null;\n  // icon: IInputIcon | null;\n\n  type: string = '';\n  validators: any[];\n  asyncValidators: any[];\n\n  inputErrorText: string = 'invalid input';\n\n  showEmailIcon: boolean = false;\n  disabled: boolean = false;\n\n  private suppressOnBlur = false;\n\n  constructor() {\n    super();\n  }\n\n  ngOnInit() {\n    this.inputVal =\n      this.field.props['value'] || this.model[this.key as string] || '';\n    this.disabled = this.field.props.disabled || false;\n    this.formControl?.setValue(this.inputVal);\n\n    this.params = this.field.props['params'];\n    this.icon = this.field.props['icon'] || {};\n    this.type = this.params?.type || '';\n\n    // this.dynamicIcon = this.field.props['dynamicIcon'];\n    this.setValidators();\n    this.setDependents();\n\n    this.formControl.statusChanges.subscribe((state) => {\n      if (this.type === 'email') {\n        if (!!this.inputVal && !this.formControl.touched) {\n          this.formControl.markAsTouched();\n        }\n        this.showEmailIcon =\n          state === 'VALID' ||\n          (state === 'INVALID' &&\n            this.formControl.hasError('invalid') &&\n            !!this.formControl.value);\n      }\n    });\n    this.formControl.valueChanges.subscribe((val) => {\n      _set(this.formInput, 'nativeElement.value', val);\n    });\n  }\n\n  setValidators() {\n    this.validators = this.params?.validators || [];\n    this.asyncValidators = this.params?.asyncValidators || [];\n    this.formControl?.setValidators([\n      ...(this.type ? this.predefinedValidators[this.type] || [] : []),\n      ...this.validators,\n    ]);\n    if (this.asyncValidators)\n      this.formControl?.setAsyncValidators(this.asyncValidators);\n  }\n\n  /*\n    Assuming dependent field is a single select dropdown\n  */\n  setDependents() {\n    if (this.params?.dependent) {\n      this.dependent = this.form.get([this.params?.dependent]);\n\n      this.dependentVal = this.getDependentVal(this.dependent.value);\n      if (this.type === 'tel') {\n        this.pretext = this.dependentVal?.dial_code;\n      }\n\n      this.dependent?.valueChanges.subscribe((val) => {\n        this.dependentVal = this.getDependentVal(val);\n        this.formControl.reset();\n        this.formControl.setValue(this.inputVal);\n        if (this.type === 'tel') {\n          this.pretext = this.dependentVal?.dial_code;\n        }\n      });\n    }\n  }\n  getDependentVal(value: any) {\n    let dependentValue: any;\n    if (Array.isArray(value)) {\n      dependentValue = value.length ? value[0] : null;\n    } else {\n      dependentValue = value;\n    }\n    return dependentValue;\n  }\n\n  checkValidity(defaultInputState = 'focus') {\n    if (\n      this.formControl &&\n      !this.formControl.valid &&\n      this.formControl.touched &&\n      !this.formControl.pending\n    ) {\n      this.inputState = 'invalid';\n      this.inputErrorText =\n        getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input') ||\n        `invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`\n    } else {\n      this.inputState = defaultInputState;\n    }\n  }\n\n  onFocus() {\n    if (this.formControl.valid) this.inputState = 'focus';\n  }\n  onBlur() {\n    setTimeout(() => {\n      if (!this.suppressOnBlur) {\n        this.formControl.markAsTouched();\n        this.checkValidity('idle');\n      }\n      this.suppressOnBlur = false;\n    }, 200);\n  }\n\n  onInput(event: any) {\n    if (this.params?.type === 'tel') {\n      this.inputVal = this.inputVal.replace(/[^0-9()+\\- ]/g, '');\n      this.inputVal = this.hyphenatePhoneNumber();\n    }\n    if (this.params?.type === 'percentage') {\n      let value = this.inputVal.replace(/[^0-9.]/g, '');\n      this.inputVal = value ? `${value}%` : '';\n    }\n    this.formControl?.setValue(this.inputVal);\n    this.checkValidity();\n    /*if (this.params?.eventListener) {\n      this.params?.eventListener({\n        type: IInputEventType.INPUT_CHANGE,\n        value: this.inputVal,\n        formControl: this.formControl\n      } as IInputEvent).then(this.onFieldCallback.bind(this));\n    }*/\n  }\n\n  hyphenatePhoneNumber() {\n    let newStr = '';\n    let i = 0;\n    let hyphenatedCount = 1;\n    const value = this.inputVal.replaceAll('-', '');\n    for (; i < value.length; i++) {\n      newStr = newStr + value.charAt(i);\n      if (!(hyphenatedCount % 3)) {\n        if (!((i + 1) % 10) && i + 1 < value.length) {\n          newStr = newStr + '-';\n          hyphenatedCount++;\n        }\n      } else if (\n        !((i + 1 - Math.floor(hyphenatedCount / 3)) % 3) &&\n        i + 1 < value.length\n      ) {\n        newStr = newStr + '-';\n        hyphenatedCount++;\n      }\n    }\n\n    return newStr;\n  }\n\n  onInputFieldClick(event: any = 'input') {\n    if (\n      event === 'input' ||\n      event.target.classList.contains('sa-input-field')\n    ) {\n      this.formInput.nativeElement.focus();\n      if (this.params?.type !== 'email')\n        setTimeout(() => {\n          this.formInput.nativeElement.setSelectionRange(\n            this.inputVal.length,\n            this.inputVal.length,\n          );\n        }, 10);\n    }\n  }\n\n  inputIconClick() {\n    if (this.params?.type === 'password') {\n      this.suppressOnBlur = true;\n      if (this.type === 'password') {\n        this.type = 'text';\n        this.icon.name = 'eyeOff';\n      } else {\n        this.type = 'password';\n        this.icon.name = 'eyeOutlined';\n      }\n      this.onInputFieldClick();\n    }\n  }\n\n  /*onFieldCallback(param: IInputParam) {\n    this.icon = param.icon || this.icon;\n    this.checkValidity();\n  }*/\n\n  getFormSupportText() {\n    if (this.formControl.invalid && this.formControl.touched) {\n      return (\n        getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input') ||\n        `invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`\n      );\n    } else {\n      return this.params?.supportText || '';\n    }\n  }\n\n  predefinedValidators: any = {\n    email: [Validators.email, Validators.required],\n    password: [Validators.required],\n    tel: [Validators.pattern('^[0-9 +\\\\-()]*$')],\n  };\n\n  getLabelFieldGap(): string {\n    if (this.props?.['bigLabel']) {\n      return 'var(--medium-20px)';\n    } else if (this.props?.['label']) {\n      return 'var(--small-4px)';\n    } else {\n      return '0px'; // No gap\n    }\n  }\n}\n\nexport interface IInputIcon {\n  name: string;\n  show?: boolean;\n  color?: string;\n  size?: string;\n}\n\nexport interface IInputParam {\n  validators?: any[];\n  asyncValidators?: any[];\n  supportText?: string;\n  placeholder?: string;\n  type?: string;\n  dependent?: string;\n  eventListener?: Function;\n  icon?: IInputIcon;\n  errors?: { [key: string]: any };\n  className?: string;\n}\nexport interface IInputEvent {\n  type: IInputEventType;\n  value: string;\n  callBack: any;\n  formControl: FormControl;\n}\nexport enum IInputEventType {\n  INPUT_CHANGE = 'INPUT_CHANGE',\n  STATE_CHANGE = 'STATE_CHANGE',\n  ICON_CLICK = 'ICON_CLICK',\n}\n","<div class=\"sa-input-container {{props?.['inputContainerClass']}}\" [ngStyle]=\"{'gap': getLabelFieldGap()}\">\n    @if (!!props?.['bigLabel'] || !!props?.['bigDescription']) {\n    <div class=\"sa-input-big-label-container\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        <h2 class=\"sa-input-big-label\">\n            {{props?.['bigLabel']}}\n        </h2>\n        <p class=\"sa-input-big-description\">\n            {{props?.['bigDescription']}}\n        </p>\n    </div>\n    }\n\n    @if(!!props?.['label']){\n    <div class=\"sa-input-label-container\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        <div class=\"sa-input-label-tooltip-container\">\n            <span class=\"sa-input-label\">\n                {{props?.['label']}}\n            </span>\n            @if(!!props?.['tooltip']){\n            <span class=\"tooltip-container\">\n                <sa-icon [icon]=\"props?.['tooltipIcon'] || 'infoCircleOutlined'\" customClass=\"info-icon\"\n                    [matTooltip]=\"props?.['tooltip']\" matTooltipClass=\"custom-tooltip\" class=\"tooltip-icon d-flex\"\n                    [size]=\"props?.['tooltipIconSize'] || '20'\"></sa-icon>\n            </span>\n            }\n        </div>\n        @if(!!props?.['description']) {\n        <p class=\"sa-input-description\">\n            {{props?.['description']}}\n        </p>\n        }\n    </div>\n    }\n    <div class=\"sa-input\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        @if((pretext || (!!inputVal?.length && (!!params?.placeholder || !!props?.placeholder))) && props?.['showTag']\n        !== false){\n        <span class=\"sa-input-tag\">{{params?.placeholder || props?.placeholder}}</span>\n        }\n        <div class=\"sa-input-field\" [ngClass]=\"formControl.invalid && formControl.touched ? 'invalid' : 'idle' \"\n            (click)=\"onInputFieldClick($event)\">\n            @if(pretext){\n            <div class=\"sa-input-pretext\">\n                {{pretext}}\n            </div>\n            }\n\n            <input\n                [ngClass]=\"(!!inputVal && (params?.type === 'password' || props?.type === 'password') && icon.name !== 'eyeOff') ? 'masked' : ''\"\n                matInput [type]=\"type\" value=\"\" [pattern]=\"type==='tel' ? '[0-9]' : '' \"\n                [disabled]=\"field.props.disabled || false\"\n                [placeholder]=\"!pretext && props?.placeholder || params?.placeholder || ''\" (focus)=\"onFocus()\"\n                (blur)=\"onBlur()\" (input)=\"onInput($event)\" [(ngModel)]=\"inputVal\" #formInput />\n\n            @if(params?.type === 'password'){\n            <sa-icon class=\"flex\" icon=\"eyeOutlined\" [size]=\"icon.size || '24'\" (click)=\"inputIconClick()\"\n                [ngClass]=\"!icon.name || icon.name === 'eyeOutlined' ? '' : 'hide'\"></sa-icon>\n            <sa-icon class=\"flex\" icon=\"eyeOff\" [size]=\"icon.size || '24'\" (click)=\"inputIconClick()\"\n                [ngClass]=\"icon.name === 'eyeOff' ? '' : 'hide'\"></sa-icon>\n            }@else if(params?.type === 'email' && icon.show){\n            <sa-icon class=\"flex\" [icon]=\"icon.name || 'checkCircleOutlined'\" [size]=\"icon.size || '24'\"\n                (click)=\"inputIconClick()\" [ngClass]=\"showEmailIcon ? '' : 'hide'\"></sa-icon>\n            }\n            @else if(icon?.name){\n            <sa-icon class=\"d-flex\" [icon]=\"icon.name\" [size]=\"icon?.size || '24'\" [color]=\"icon?.color || ''\"\n                [ngClass]=\"icon?.show ? '' : 'hide'\"></sa-icon>\n            }\n        </div>\n    </div>\n    @if((!formControl.valid) || (params?.supportText)){\n        <div class=\"support-label\"\n        [ngClass]=\"[\n        formControl.invalid && formControl.touched ? 'invalid' : 'idle',\n        formControl.invalid && formControl.touched ? params?.className : ''\n      ]\">\n            <!-- {{!formControl.valid ? inputErrorText : params.supportText}} -->\n            {{getFormSupportText()}}\n        </div>\n        }\n</div>"]}
|
|
249
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-input.component.js","sourceRoot":"","sources":["../../../../../projects/component-library/src/lib/form-input/form-input.component.ts","../../../../../projects/component-library/src/lib/form-input/form-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild } from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { FormlyModule } from '@ngx-formly/core';\nimport { FieldType, FieldTypeConfig } from '@ngx-formly/core';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { CommonModule } from '@angular/common';\nimport {\n  getValidationMessage,\n  phoneNumberValidator,\n} from '../../utils/validators';\nimport { IconComponent } from '../icon/icon.component';\nimport { MatTooltipModule } from '@angular/material/tooltip';\nimport { set as _set, get as _get } from 'lodash';\n@Component({\n  selector: 'sa-input',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule,\n    FormlyModule,\n    IconComponent,\n    MatTooltipModule\n  ],\n  templateUrl: './form-input.component.html',\n  styleUrl: './form-input.component.css',\n})\nexport class FormInputComponent extends FieldType<FieldTypeConfig> {\n  @ViewChild('formInput') formInput!: ElementRef;\n\n  @Input('icon') icon: IInputIcon;\n\n  pretext: string;\n\n  inputState = 'idle';\n  inputVal = '';\n  params: IInputParam | null;\n  dependent: AbstractControl<any, any> | null;\n  dependentVal: any = null;\n  // dynamicIcon: DynamicIcon | null;\n  // icon: IInputIcon | null;\n\n  type: string = '';\n  validators: any[];\n  asyncValidators: any[];\n\n  inputErrorText: string = 'invalid input';\n\n  showEmailIcon: boolean = false;\n  disabled: boolean = false;\n\n  private suppressOnBlur = false;\n\n  constructor() {\n    super();\n  }\n\n  ngOnInit() {\n    this.inputVal =\n      this.field.props['value'] || this.model[this.key as string] || '';\n    this.disabled = this.field.props.disabled || false;\n    this.formControl?.setValue(this.inputVal);\n\n    this.params = this.field.props['params'];\n    this.icon = this.field.props['icon'] || {};\n    this.type = this.params?.type || '';\n\n    // this.dynamicIcon = this.field.props['dynamicIcon'];\n    this.setValidators();\n    this.setDependents();\n\n    this.formControl.statusChanges.subscribe((state) => {\n      if (this.type === 'email') {\n        if (!!this.inputVal && !this.formControl.touched) {\n          this.formControl.markAsTouched();\n        }\n        this.showEmailIcon =\n          state === 'VALID' ||\n          (state === 'INVALID' &&\n            this.formControl.hasError('invalid') &&\n            !!this.formControl.value);\n      }\n    });\n    this.formControl.valueChanges.subscribe((val) => {\n      _set(this.formInput, 'nativeElement.value', val);\n    });\n  }\n\n  setValidators() {\n    this.validators = this.params?.validators || this.predefinedValidators[this.type] || [];\n    this.asyncValidators = this.params?.asyncValidators || [];\n    if(!_get(this.field, 'validators.validation', null)) {\n      this.formControl?.setValidators([\n        ...(this.type ? this.predefinedValidators[this.type] || [] : []),\n        ...(this.validators),\n      ]);\n    }\n    if (this.asyncValidators) {\n      this.formControl?.setAsyncValidators(this.asyncValidators);\n    }\n  }\n\n  /*\n    Assuming dependent field is a single select dropdown\n  */\n  setDependents() {\n    if (this.params?.dependent) {\n      this.dependent = this.form.get([this.params?.dependent]);\n\n      this.dependentVal = this.getDependentVal(this.dependent.value);\n      if (this.type === 'tel') {\n        this.pretext = this.dependentVal?.dial_code;\n      }\n\n      this.dependent?.valueChanges.subscribe((val) => {\n        this.dependentVal = this.getDependentVal(val);\n        this.formControl.reset();\n        this.formControl.setValue(this.inputVal);\n        if (this.type === 'tel') {\n          this.pretext = this.dependentVal?.dial_code;\n        }\n      });\n    }\n  }\n  getDependentVal(value: any) {\n    let dependentValue: any;\n    if (Array.isArray(value)) {\n      dependentValue = value.length ? value[0] : null;\n    } else {\n      dependentValue = value;\n    }\n    return dependentValue;\n  }\n\n  checkValidity(defaultInputState = 'focus') {\n    if (\n      this.formControl &&\n      !this.formControl.valid &&\n      this.formControl.touched &&\n      !this.formControl.pending\n    ) {\n      this.inputState = 'invalid';\n      this.inputErrorText =\n        getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input', {\n          field: this.field,\n          nativeValidationObject: this.field.validation,\n        }) || `invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`\n    } else {\n      this.inputState = defaultInputState;\n    }\n  }\n\n  onFocus() {\n    if (this.formControl.valid) this.inputState = 'focus';\n  }\n  onBlur() {\n    setTimeout(() => {\n      if (!this.suppressOnBlur) {\n        this.formControl.markAsTouched();\n        this.checkValidity('idle');\n      }\n      this.suppressOnBlur = false;\n    }, 200);\n  }\n\n  onInput(event: any) {\n    if (this.params?.type === 'tel') {\n      this.inputVal = this.inputVal.replace(/[^0-9()+\\- ]/g, '');\n      this.inputVal = this.hyphenatePhoneNumber();\n    }\n    if (this.params?.type === 'percentage') {\n      let value = this.inputVal.replace(/[^0-9.]/g, '');\n      this.inputVal = value ? `${value}%` : '';\n    }\n    this.formControl?.setValue(this.inputVal);\n    this.checkValidity();\n    /*if (this.params?.eventListener) {\n      this.params?.eventListener({\n        type: IInputEventType.INPUT_CHANGE,\n        value: this.inputVal,\n        formControl: this.formControl\n      } as IInputEvent).then(this.onFieldCallback.bind(this));\n    }*/\n  }\n\n  hyphenatePhoneNumber() {\n    let newStr = '';\n    let i = 0;\n    let hyphenatedCount = 1;\n    const value = this.inputVal.replaceAll('-', '');\n    for (; i < value.length; i++) {\n      newStr = newStr + value.charAt(i);\n      if (!(hyphenatedCount % 3)) {\n        if (!((i + 1) % 10) && i + 1 < value.length) {\n          newStr = newStr + '-';\n          hyphenatedCount++;\n        }\n      } else if (\n        !((i + 1 - Math.floor(hyphenatedCount / 3)) % 3) &&\n        i + 1 < value.length\n      ) {\n        newStr = newStr + '-';\n        hyphenatedCount++;\n      }\n    }\n\n    return newStr;\n  }\n\n  onInputFieldClick(event: any = 'input') {\n    if (\n      event === 'input' ||\n      event.target.classList.contains('sa-input-field')\n    ) {\n      this.formInput.nativeElement.focus();\n      if (this.params?.type !== 'email')\n        setTimeout(() => {\n          this.formInput.nativeElement.setSelectionRange(\n            this.inputVal.length,\n            this.inputVal.length,\n          );\n        }, 10);\n    }\n  }\n\n  inputIconClick() {\n    if (this.params?.type === 'password') {\n      this.suppressOnBlur = true;\n      if (this.type === 'password') {\n        this.type = 'text';\n        this.icon.name = 'eyeOff';\n      } else {\n        this.type = 'password';\n        this.icon.name = 'eyeOutlined';\n      }\n      this.onInputFieldClick();\n    }\n  }\n\n  /*onFieldCallback(param: IInputParam) {\n    this.icon = param.icon || this.icon;\n    this.checkValidity();\n  }*/\n\n  getFormSupportText() {\n    if (this.formControl.invalid && this.formControl.touched) {\n      return (\n        getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input',{\n          field: this.field,\n          nativeValidationObject: _get(this.field, 'validation'),\n        }) ||\n        `invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`\n      );\n    } else {\n      return this.params?.supportText || '';\n    }\n  }\n\n  predefinedValidators: any = {\n    email: [Validators.email, Validators.required],\n    password: [Validators.required],\n    tel: [Validators.pattern('^[0-9 +\\\\-()]*$')],\n  };\n\n  getLabelFieldGap(): string {\n    if (this.props?.['bigLabel']) {\n      return 'var(--medium-20px)';\n    } else if (this.props?.['label']) {\n      return 'var(--small-4px)';\n    } else {\n      return '0px'; // No gap\n    }\n  }\n}\n\nexport interface IInputIcon {\n  name: string;\n  show?: boolean;\n  color?: string;\n  size?: string;\n}\n\nexport interface IInputParam {\n  validators?: any[];\n  asyncValidators?: any[];\n  supportText?: string;\n  placeholder?: string;\n  type?: string;\n  dependent?: string;\n  eventListener?: Function;\n  icon?: IInputIcon;\n  errors?: { [key: string]: any };\n  className?: string;\n}\nexport interface IInputEvent {\n  type: IInputEventType;\n  value: string;\n  callBack: any;\n  formControl: FormControl;\n}\nexport enum IInputEventType {\n  INPUT_CHANGE = 'INPUT_CHANGE',\n  STATE_CHANGE = 'STATE_CHANGE',\n  ICON_CLICK = 'ICON_CLICK',\n}\n","<div class=\"sa-input-container {{props?.['inputContainerClass']}}\" [ngStyle]=\"{'gap': getLabelFieldGap()}\">\n    @if (!!props?.['bigLabel'] || !!props?.['bigDescription']) {\n    <div class=\"sa-input-big-label-container\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        <h2 class=\"sa-input-big-label\">\n            {{props?.['bigLabel']}}\n        </h2>\n        <p class=\"sa-input-big-description\">\n            {{props?.['bigDescription']}}\n        </p>\n    </div>\n    }\n\n    @if(!!props?.['label']){\n    <div class=\"sa-input-label-container\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        <div class=\"sa-input-label-tooltip-container\">\n            <span class=\"sa-input-label\">\n                {{props?.['label']}}\n            </span>\n            @if(!!props?.['tooltip']){\n            <span class=\"tooltip-container\">\n                <sa-icon [icon]=\"props?.['tooltipIcon'] || 'infoCircleOutlined'\" customClass=\"info-icon\"\n                    [matTooltip]=\"props?.['tooltip']\" matTooltipClass=\"custom-tooltip\" class=\"tooltip-icon d-flex\"\n                    [size]=\"props?.['tooltipIconSize'] || '20'\"></sa-icon>\n            </span>\n            }\n        </div>\n        @if(!!props?.['description']) {\n        <p class=\"sa-input-description\">\n            {{props?.['description']}}\n        </p>\n        }\n    </div>\n    }\n    <div class=\"sa-input\" [ngClass]=\"disabled ? 'disabled' : '' \">\n        @if((pretext || (!!inputVal?.length && (!!params?.placeholder || !!props?.placeholder))) && props?.['showTag']\n        !== false){\n        <span class=\"sa-input-tag\">{{params?.placeholder || props?.placeholder}}</span>\n        }\n        <div class=\"sa-input-field\" [ngClass]=\"formControl.invalid && formControl.touched ? 'invalid' : 'idle' \"\n            (click)=\"onInputFieldClick($event)\">\n            @if(pretext){\n            <div class=\"sa-input-pretext\">\n                {{pretext}}\n            </div>\n            }\n\n            <input\n                [ngClass]=\"(!!inputVal && (params?.type === 'password' || props?.type === 'password') && icon.name !== 'eyeOff') ? 'masked' : ''\"\n                matInput [type]=\"type\" value=\"\" [pattern]=\"type==='tel' ? '[0-9]' : '' \"\n                [disabled]=\"field.props.disabled || false\"\n                [placeholder]=\"!pretext && props?.placeholder || params?.placeholder || ''\" (focus)=\"onFocus()\"\n                (blur)=\"onBlur()\" (input)=\"onInput($event)\" [(ngModel)]=\"inputVal\" #formInput />\n\n            @if(params?.type === 'password'){\n            <sa-icon class=\"flex\" icon=\"eyeOutlined\" [size]=\"icon.size || '24'\" (click)=\"inputIconClick()\"\n                [ngClass]=\"!icon.name || icon.name === 'eyeOutlined' ? '' : 'hide'\"></sa-icon>\n            <sa-icon class=\"flex\" icon=\"eyeOff\" [size]=\"icon.size || '24'\" (click)=\"inputIconClick()\"\n                [ngClass]=\"icon.name === 'eyeOff' ? '' : 'hide'\"></sa-icon>\n            }@else if(params?.type === 'email' && icon.show){\n            <sa-icon class=\"flex\" [icon]=\"icon.name || 'checkCircleOutlined'\" [size]=\"icon.size || '24'\"\n                (click)=\"inputIconClick()\" [ngClass]=\"showEmailIcon ? '' : 'hide'\"></sa-icon>\n            }\n            @else if(icon?.name){\n            <sa-icon class=\"d-flex\" [icon]=\"icon.name\" [size]=\"icon?.size || '24'\" [color]=\"icon?.color || ''\"\n                [ngClass]=\"icon?.show ? '' : 'hide'\"></sa-icon>\n            }\n        </div>\n    </div>\n    @if((!formControl.valid) || (params?.supportText)){\n        <div class=\"support-label\"\n        [ngClass]=\"[\n        formControl.invalid && formControl.touched ? 'invalid' : 'idle',\n        formControl.invalid && formControl.touched ? params?.className : ''\n      ]\">\n            <!-- {{!formControl.valid ? inputErrorText : params.supportText}} -->\n            {{getFormSupportText()}}\n        </div>\n        }\n</div>"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { get as _get, find as _find, has as _has, keys as _keys, startCase as _startCase } from 'lodash';
|
|
2
2
|
export function phoneNumberValidator(dependent) {
|
|
3
3
|
return (control) => {
|
|
4
4
|
const dependentFormControl = dependent ? control.parent?.get(dependent) : null;
|
|
@@ -69,8 +69,20 @@ export function workEmailValidation(): AsyncValidatorFn {
|
|
|
69
69
|
);
|
|
70
70
|
};
|
|
71
71
|
}*/
|
|
72
|
-
export function getValidationMessage(errors, placeholder = 'Input') {
|
|
72
|
+
export function getValidationMessage(errors, placeholder = 'Input', additionalProperties) {
|
|
73
|
+
const messages = _get(additionalProperties, 'nativeValidationObject.messages', {});
|
|
74
|
+
const field = _get(additionalProperties, 'field', {});
|
|
73
75
|
if (errors) {
|
|
76
|
+
// Check if any key in errors matches with messages using lodash
|
|
77
|
+
const matchingKey = _find(_keys(errors), key => _has(messages, key));
|
|
78
|
+
if (matchingKey && messages[matchingKey]) {
|
|
79
|
+
// If message is a function, execute it with errors and nativeValidationObject
|
|
80
|
+
if (typeof messages[matchingKey] === 'function') {
|
|
81
|
+
return messages[matchingKey](errors[matchingKey], field);
|
|
82
|
+
}
|
|
83
|
+
return messages[matchingKey];
|
|
84
|
+
}
|
|
85
|
+
// Fall back to default messages
|
|
74
86
|
if (errors['minlength']) {
|
|
75
87
|
return `Minimum ${errors['minlength']['requiredLength']} characters required`;
|
|
76
88
|
}
|
|
@@ -115,4 +127,4 @@ export function numberRangeValidator(range, type = null) {
|
|
|
115
127
|
export const requiredValidatorMessage = (error, field) => {
|
|
116
128
|
return `${_startCase(_get(field, 'props.label'))} is required.`;
|
|
117
129
|
};
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../../projects/component-library/src/utils/validators.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, AsyncValidatorFn, ValidationErrors, ValidatorFn } from '@angular/forms';\nimport { catchError, debounceTime, delay, distinctUntilChanged, map, Observable, of, Subject, switchMap } from 'rxjs';\nimport { FormlyFieldConfig } from '@ngx-formly/core';\nimport { startCase as _startCase, get as _get } from 'lodash'\n\nexport function phoneNumberValidator(dependent?: string): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n        const dependentFormControl = dependent ? control.parent?.get(dependent) : null;\n        if (dependentFormControl && !!dependentFormControl.value?.length) {\n            console.log('validator', dependentFormControl.value);\n\n            if (dependentFormControl.value[0].id === 0) {\n                if (!/^\\+1[2-9]\\d{2}[2-9]\\d{6}$/.test(control.value)) {\n                    return { invalid: 'invalid phone number' };\n                }\n            }\n        }\n        return null;\n    }\n}\n\nexport const customEmailValidator = (\n    control: AbstractControl\n): { [key: string]: string } | null => {\n    const email = control.value;\n    // Replace the regular expression with the pattern you want to use.\n\n    const emailPattern = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,4}$/;\n\n    if (emailPattern.test(email) && isWorkEmail(email)) {\n        return null; // Valid email\n    } else {\n        return {\n            invalid:\n                'Please use a work email; personal emails (e.g., @gmail, @yahoo) are not accepted.',\n        }; // Invalid email\n    }\n};\nconst isWorkEmail = (email: string): boolean => {\n    const invalidEmailHosts: string[] = ['gmail', 'yahoo', 'hotmail'];\n    if (email) {\n        let [userName, domainName] = email.split('@');\n        for (let i = 0; i < invalidEmailHosts.length; i++) {\n            let re = new RegExp(`.*${invalidEmailHosts[i]}\\..*`);\n            if (re.test(domainName)) {\n                return false;\n            }\n        }\n        return true;\n    }\n    return false;\n}\n/*\nexport function workEmailValidation(): AsyncValidatorFn {\n    return (control: AbstractControl): Observable<ValidationErrors | null> => {\n        if (!control.value) {\n            return of(null); // No value to validate\n        }\n\n        !control.pending && control.markAsPending();\n        // !control.touched && control.markAsTouched();\n        // return of({ invalid: 'Enter your work email' });\n        return of(null);\n        return new Observable((ob) => {\n            setTimeout(() => {\n                if (control.value === 'sairaj@gmail.com')\n                    return ob.next(null)\n                return ob.next({ invalid: 'This is not a workemail' });\n            }, 500)\n        });\n\n        return of(control.value).pipe(\n            delay(500), // Simulate network delay\n\n            map(value => {\n                return of({ invalid: 'This is not a workemail' })//existingUsernames.includes(username) ? { usernameTaken: true } : null;\n            })\n            // catchError(() => of(null)) // Handle any errors\n        );\n    };\n}*/\nexport function getValidationMessage(errors: any, placeholder: string = 'Input'): string {\n    if (errors) {\n        if (errors['minlength']) {\n            return `Minimum ${errors['minlength']['requiredLength']} characters required`;\n        } else if (errors['maxlength']) {\n            return `Maximum of ${errors['maxlength']['requiredLength']} characters accepted`;\n        } else if (errors['required']) {\n            return `${placeholder} cannot be empty`;\n        } else if (errors['invalid']) {\n            return errors['invalid'];\n        } else if (errors['email']) {\n            return 'Enter a valid email';\n        } else if (errors['pattern']) {\n            return 'Enter a valid phone number';\n        } else {\n            return `Invalid ${placeholder}`;\n        }\n    }\n    return `Invalid ${placeholder}`;\n}\n\nexport function numberRangeValidator(range: { min: number; max: number }, type = null): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n        let value = control.value;\n\n        if (type === 'percentage' && typeof value === 'string') {\n            value = value.replace('%', '');\n        }\n\n        // Convert to a number if it's not null or undefined\n        const numericValue = value !== null && value !== undefined ? parseFloat(value) : NaN;\n\n        // Check if the value is a valid number and within the range\n        if (isNaN(numericValue) || numericValue < range.min || numericValue > range.max) {\n            return {\n                invalid: `Please enter a valid number between ${range.min} and ${range.max}`\n            };\n        }\n\n        return null;\n    }\n}\n\nexport const requiredValidatorMessage = (error: any, field: FormlyFieldConfig) => {\n    return `${_startCase(_get(field, 'props.label'))} is required.`;\n}"]}
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../../projects/component-library/src/utils/validators.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, AsyncValidatorFn, ValidationErrors, ValidatorFn } from '@angular/forms';\nimport { catchError, debounceTime, delay, distinctUntilChanged, map, Observable, of, Subject, switchMap } from 'rxjs';\nimport { get as _get, find as _find, has as _has, keys as _keys, startCase as _startCase } from 'lodash';\nimport { FormlyFieldConfig } from '@ngx-formly/core';\n\nexport function phoneNumberValidator(dependent?: string): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n        const dependentFormControl = dependent ? control.parent?.get(dependent) : null;\n        if (dependentFormControl && !!dependentFormControl.value?.length) {\n            console.log('validator', dependentFormControl.value);\n\n            if (dependentFormControl.value[0].id === 0) {\n                if (!/^\\+1[2-9]\\d{2}[2-9]\\d{6}$/.test(control.value)) {\n                    return { invalid: 'invalid phone number' };\n                }\n            }\n        }\n        return null;\n    }\n}\n\nexport const customEmailValidator = (\n    control: AbstractControl\n): { [key: string]: string } | null => {\n    const email = control.value;\n    // Replace the regular expression with the pattern you want to use.\n\n    const emailPattern = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,4}$/;\n\n    if (emailPattern.test(email) && isWorkEmail(email)) {\n        return null; // Valid email\n    } else {\n        return {\n            invalid:\n                'Please use a work email; personal emails (e.g., @gmail, @yahoo) are not accepted.',\n        }; // Invalid email\n    }\n};\nconst isWorkEmail = (email: string): boolean => {\n    const invalidEmailHosts: string[] = ['gmail', 'yahoo', 'hotmail'];\n    if (email) {\n        let [userName, domainName] = email.split('@');\n        for (let i = 0; i < invalidEmailHosts.length; i++) {\n            let re = new RegExp(`.*${invalidEmailHosts[i]}\\..*`);\n            if (re.test(domainName)) {\n                return false;\n            }\n        }\n        return true;\n    }\n    return false;\n}\n/*\nexport function workEmailValidation(): AsyncValidatorFn {\n    return (control: AbstractControl): Observable<ValidationErrors | null> => {\n        if (!control.value) {\n            return of(null); // No value to validate\n        }\n\n        !control.pending && control.markAsPending();\n        // !control.touched && control.markAsTouched();\n        // return of({ invalid: 'Enter your work email' });\n        return of(null);\n        return new Observable((ob) => {\n            setTimeout(() => {\n                if (control.value === 'sairaj@gmail.com')\n                    return ob.next(null)\n                return ob.next({ invalid: 'This is not a workemail' });\n            }, 500)\n        });\n\n        return of(control.value).pipe(\n            delay(500), // Simulate network delay\n\n            map(value => {\n                return of({ invalid: 'This is not a workemail' })//existingUsernames.includes(username) ? { usernameTaken: true } : null;\n            })\n            // catchError(() => of(null)) // Handle any errors\n        );\n    };\n}*/\nexport function getValidationMessage(errors: any, placeholder: string = 'Input', additionalProperties?: any): string {\n    const messages = _get(additionalProperties, 'nativeValidationObject.messages', {});\n    const field = _get(additionalProperties, 'field', {});\n    \n    if (errors) {\n        // Check if any key in errors matches with messages using lodash\n        const matchingKey = _find(_keys(errors), key => _has(messages, key));\n        if (matchingKey && messages[matchingKey]) {\n            // If message is a function, execute it with errors and nativeValidationObject\n            if (typeof messages[matchingKey] === 'function') {\n                return messages[matchingKey](errors[matchingKey], field);\n            }\n            return messages[matchingKey];\n        }\n        \n        // Fall back to default messages\n        if (errors['minlength']) {\n            return `Minimum ${errors['minlength']['requiredLength']} characters required`;\n        } else if (errors['maxlength']) {\n            return `Maximum of ${errors['maxlength']['requiredLength']} characters accepted`;\n        } else if (errors['required']) {\n            return `${placeholder} cannot be empty`;\n        } else if (errors['invalid']) {\n            return errors['invalid'];\n        } else if (errors['email']) {\n            return 'Enter a valid email';\n        } else if (errors['pattern']) {\n            return 'Enter a valid phone number';\n        } else {\n            return `Invalid ${placeholder}`;\n        }\n    }\n    return `Invalid ${placeholder}`;\n}\n\nexport function numberRangeValidator(range: { min: number; max: number }, type = null): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null => {\n        let value = control.value;\n\n        if (type === 'percentage' && typeof value === 'string') {\n            value = value.replace('%', '');\n        }\n\n        // Convert to a number if it's not null or undefined\n        const numericValue = value !== null && value !== undefined ? parseFloat(value) : NaN;\n\n        // Check if the value is a valid number and within the range\n        if (isNaN(numericValue) || numericValue < range.min || numericValue > range.max) {\n            return {\n                invalid: `Please enter a valid number between ${range.min} and ${range.max}`\n            };\n        }\n\n        return null;\n    }\n}\n\nexport const requiredValidatorMessage = (error: any, field: FormlyFieldConfig) => {\n    return `${_startCase(_get(field, 'props.label'))} is required.`;\n}"]}
|
|
@@ -14,7 +14,7 @@ import * as i5 from '@angular/material/expansion';
|
|
|
14
14
|
import { MatExpansionModule } from '@angular/material/expansion';
|
|
15
15
|
import * as i2$3 from '@ngx-formly/core';
|
|
16
16
|
import { FieldType, FormlyModule } from '@ngx-formly/core';
|
|
17
|
-
import { get, filter, includes, replace, toString, map, isUndefined, first, find, words, startCase, set } from 'lodash';
|
|
17
|
+
import { get, filter, includes, replace, toString, map, isUndefined, first, find, words, keys, has, startCase, set } from 'lodash';
|
|
18
18
|
import { debounceTime, takeUntil } from 'rxjs/operators';
|
|
19
19
|
import { Subject, isObservable, of } from 'rxjs';
|
|
20
20
|
import * as i2$2 from '@angular/material/core';
|
|
@@ -905,7 +905,7 @@ class MenuCardComponent extends FieldType {
|
|
|
905
905
|
actionHandler(button, event) {
|
|
906
906
|
event.stopPropagation();
|
|
907
907
|
event.preventDefault();
|
|
908
|
-
this.onButtonClickEvent.next(button);
|
|
908
|
+
this.onButtonClickEvent.next({ category: this.selectedStep, button: button });
|
|
909
909
|
}
|
|
910
910
|
showSources(sourceType) {
|
|
911
911
|
this.onFooterClickEvent.emit(sourceType);
|
|
@@ -1237,8 +1237,20 @@ export function workEmailValidation(): AsyncValidatorFn {
|
|
|
1237
1237
|
);
|
|
1238
1238
|
};
|
|
1239
1239
|
}*/
|
|
1240
|
-
function getValidationMessage(errors, placeholder = 'Input') {
|
|
1240
|
+
function getValidationMessage(errors, placeholder = 'Input', additionalProperties) {
|
|
1241
|
+
const messages = get(additionalProperties, 'nativeValidationObject.messages', {});
|
|
1242
|
+
const field = get(additionalProperties, 'field', {});
|
|
1241
1243
|
if (errors) {
|
|
1244
|
+
// Check if any key in errors matches with messages using lodash
|
|
1245
|
+
const matchingKey = find(keys(errors), key => has(messages, key));
|
|
1246
|
+
if (matchingKey && messages[matchingKey]) {
|
|
1247
|
+
// If message is a function, execute it with errors and nativeValidationObject
|
|
1248
|
+
if (typeof messages[matchingKey] === 'function') {
|
|
1249
|
+
return messages[matchingKey](errors[matchingKey], field);
|
|
1250
|
+
}
|
|
1251
|
+
return messages[matchingKey];
|
|
1252
|
+
}
|
|
1253
|
+
// Fall back to default messages
|
|
1242
1254
|
if (errors['minlength']) {
|
|
1243
1255
|
return `Minimum ${errors['minlength']['requiredLength']} characters required`;
|
|
1244
1256
|
}
|
|
@@ -1331,14 +1343,17 @@ class FormInputComponent extends FieldType {
|
|
|
1331
1343
|
});
|
|
1332
1344
|
}
|
|
1333
1345
|
setValidators() {
|
|
1334
|
-
this.validators = this.params?.validators || [];
|
|
1346
|
+
this.validators = this.params?.validators || this.predefinedValidators[this.type] || [];
|
|
1335
1347
|
this.asyncValidators = this.params?.asyncValidators || [];
|
|
1336
|
-
this.
|
|
1337
|
-
|
|
1338
|
-
|
|
1339
|
-
|
|
1340
|
-
|
|
1348
|
+
if (!get(this.field, 'validators.validation', null)) {
|
|
1349
|
+
this.formControl?.setValidators([
|
|
1350
|
+
...(this.type ? this.predefinedValidators[this.type] || [] : []),
|
|
1351
|
+
...(this.validators),
|
|
1352
|
+
]);
|
|
1353
|
+
}
|
|
1354
|
+
if (this.asyncValidators) {
|
|
1341
1355
|
this.formControl?.setAsyncValidators(this.asyncValidators);
|
|
1356
|
+
}
|
|
1342
1357
|
}
|
|
1343
1358
|
/*
|
|
1344
1359
|
Assuming dependent field is a single select dropdown
|
|
@@ -1377,8 +1392,10 @@ class FormInputComponent extends FieldType {
|
|
|
1377
1392
|
!this.formControl.pending) {
|
|
1378
1393
|
this.inputState = 'invalid';
|
|
1379
1394
|
this.inputErrorText =
|
|
1380
|
-
getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input'
|
|
1381
|
-
|
|
1395
|
+
getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input', {
|
|
1396
|
+
field: this.field,
|
|
1397
|
+
nativeValidationObject: this.field.validation,
|
|
1398
|
+
}) || `invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`;
|
|
1382
1399
|
}
|
|
1383
1400
|
else {
|
|
1384
1401
|
this.inputState = defaultInputState;
|
|
@@ -1467,7 +1484,10 @@ class FormInputComponent extends FieldType {
|
|
|
1467
1484
|
}*/
|
|
1468
1485
|
getFormSupportText() {
|
|
1469
1486
|
if (this.formControl.invalid && this.formControl.touched) {
|
|
1470
|
-
return (getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input'
|
|
1487
|
+
return (getValidationMessage(this.formControl.errors, this.params?.placeholder || this.field.props?.label || 'Input', {
|
|
1488
|
+
field: this.field,
|
|
1489
|
+
nativeValidationObject: get(this.field, 'validation'),
|
|
1490
|
+
}) ||
|
|
1471
1491
|
`invalid ${this.params?.placeholder || this.field.props?.label || 'input'}`);
|
|
1472
1492
|
}
|
|
1473
1493
|
else {
|