ca-components 1.0.78 → 1.0.80
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/ca-components.module.mjs +16 -4
- package/esm2022/lib/components/ca-activity-log-list/ca-activity-log-list.component.mjs +1 -1
- package/esm2022/lib/components/ca-app-tooltip-v2/ca-app-tooltip-v2.component.mjs +1 -1
- package/esm2022/lib/components/ca-filters/components/ca-dispatcher-filter/ca-dispatcher-filter.component.mjs +2 -2
- package/esm2022/lib/components/ca-filters/components/ca-money-filter/ca-money-filter.component.mjs +2 -2
- package/esm2022/lib/components/ca-filters/components/ca-state-filter/ca-state-filter.component.mjs +2 -2
- package/esm2022/lib/components/ca-filters/components/ca-trailer-type-filter/ca-trailer-type-filter.component.mjs +1 -1
- package/esm2022/lib/components/ca-filters/components/ca-truck-type-filter/ca-truck-type-filter.component.mjs +1 -1
- package/esm2022/lib/components/ca-filters/components/ca-user-filter/ca-user-filter.component.mjs +2 -2
- package/esm2022/lib/components/ca-input/base-classes/ca-input-base-helpres.mjs +237 -0
- package/esm2022/lib/components/ca-input/base-classes/ca-input-base.mjs +1020 -0
- package/esm2022/lib/components/ca-input/base-classes/ca-input-event-manager.mjs +24 -0
- package/esm2022/lib/components/ca-input/ca-input.component.mjs +53 -163
- package/esm2022/lib/components/ca-input/components/ca-input-clear/ca-input-clear.component.mjs +4 -4
- package/esm2022/lib/components/ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component.mjs +11 -17
- package/esm2022/lib/components/ca-input/config/ca-input.config.mjs +1 -1
- package/esm2022/lib/components/ca-input/directives/caps-lock.directive.mjs +50 -0
- package/esm2022/lib/components/ca-input/directives/index.mjs +5 -1
- package/esm2022/lib/components/ca-input/directives/input-max-value.directive.mjs +53 -0
- package/esm2022/lib/components/ca-input/directives/min-max-value.directive.mjs +1 -1
- package/esm2022/lib/components/ca-input/directives/price_format.directive.mjs +41 -0
- package/esm2022/lib/components/ca-input/directives/restrict-input.directive.mjs +98 -0
- package/esm2022/lib/components/ca-input/enums/input-text-transform.enum.mjs +9 -0
- package/esm2022/lib/components/ca-input/input-test/input-test.component.mjs +175 -0
- package/esm2022/lib/components/ca-input/pipes/input-container-class.pipe.mjs +16 -16
- package/esm2022/lib/components/ca-input/pipes/input-datetime-picker-class.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/pipes/input-error.pipe.mjs +18 -15
- package/esm2022/lib/components/ca-input/pipes/input-pattern.pipe.mjs +322 -0
- package/esm2022/lib/components/ca-input/services/index.mjs +1 -2
- package/esm2022/lib/components/ca-input/utils/constants/input-constants.mjs +102 -1
- package/esm2022/lib/components/ca-input-address-dropdown/ca-input-address-dropdown.component.mjs +2 -2
- package/esm2022/lib/components/ca-input-datetime-picker/ca-input-datetime-picker.component.mjs +809 -0
- package/esm2022/lib/components/ca-input-dropdown/ca-input-dropdown.component.mjs +18 -18
- package/esm2022/lib/components/ca-rating-review/ca-rating-review.component.mjs +2 -2
- package/esm2022/lib/components/ca-rating-review/components/ca-ratings-reviews-popup/ca-ratings-reviews-popup.component.mjs +1 -1
- package/esm2022/lib/components/ca-upload-files/components/ca-upload-file/ca-upload-file.component.mjs +1 -1
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/ca-components.mjs +7690 -7171
- package/fesm2022/ca-components.mjs.map +1 -1
- package/lib/ca-components.module.d.ts +32 -30
- package/lib/components/ca-filters/ca-filter.component.d.ts +2 -2
- package/lib/components/ca-input/base-classes/ca-input-base-helpres.d.ts +29 -0
- package/lib/components/ca-input/base-classes/ca-input-base.d.ts +82 -0
- package/lib/components/ca-input/base-classes/ca-input-event-manager.d.ts +16 -0
- package/lib/components/ca-input/ca-input.component.d.ts +30 -48
- package/lib/components/ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component.d.ts +3 -7
- package/lib/components/ca-input/config/ca-input.config.d.ts +10 -1
- package/lib/components/ca-input/directives/caps-lock.directive.d.ts +14 -0
- package/lib/components/ca-input/directives/index.d.ts +4 -0
- package/lib/components/ca-input/directives/input-max-value.directive.d.ts +12 -0
- package/lib/components/ca-input/directives/price_format.directive.d.ts +11 -0
- package/lib/components/ca-input/directives/restrict-input.directive.d.ts +15 -0
- package/lib/components/ca-input/enums/input-text-transform.enum.d.ts +6 -0
- package/lib/components/ca-input/input-test/input-test.component.d.ts +47 -0
- package/lib/components/ca-input/pipes/input-container-class.pipe.d.ts +3 -3
- package/lib/components/ca-input/pipes/input-datetime-picker-class.pipe.d.ts +1 -1
- package/lib/components/ca-input/pipes/input-pattern.pipe.d.ts +25 -0
- package/lib/components/ca-input/services/index.d.ts +0 -1
- package/lib/components/ca-input/utils/constants/input-constants.d.ts +11 -0
- package/lib/components/ca-input-datetime-picker/ca-input-datetime-picker.component.d.ts +99 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/esm2022/lib/components/ca-input/components/ca-input-datetime-picker/ca-input-datetime-picker.component.mjs +0 -100
- package/esm2022/lib/components/ca-input/services/ca-input-state.service.mjs +0 -2173
- package/lib/components/ca-input/components/ca-input-datetime-picker/ca-input-datetime-picker.component.d.ts +0 -48
- package/lib/components/ca-input/services/ca-input-state.service.d.ts +0 -196
package/esm2022/lib/components/ca-input/components/ca-input-clear/ca-input-clear.component.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
3
3
|
import { FormsModule, ReactiveFormsModule, } from '@angular/forms';
|
|
4
4
|
// modules
|
|
5
5
|
import { AngularSvgIconModule } from 'angular-svg-icon';
|
|
@@ -31,11 +31,11 @@ export class CaInputClearComponent {
|
|
|
31
31
|
// Pipes
|
|
32
32
|
InputClearClassPipe, name: "inputClearClass" }, { kind: "component", type:
|
|
33
33
|
// Components
|
|
34
|
-
CaAppTooltipV2Component, selector: "mainCaTooltip, [mainCaTooltip]", inputs: ["mainCaTooltip", "position", "openTooltipDelay", "tooltipBackground", "tooltipColor", "tooltipTextAlign", "tooltipMarginTop", "disableTooltip"] }] }); }
|
|
34
|
+
CaAppTooltipV2Component, selector: "mainCaTooltip, [mainCaTooltip]", inputs: ["mainCaTooltip", "position", "openTooltipDelay", "tooltipBackground", "tooltipColor", "tooltipTextAlign", "tooltipMarginTop", "disableTooltip"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
35
35
|
}
|
|
36
36
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaInputClearComponent, decorators: [{
|
|
37
37
|
type: Component,
|
|
38
|
-
args: [{ selector: 'app-ca-input-clear', standalone: true, imports: [
|
|
38
|
+
args: [{ selector: 'app-ca-input-clear', encapsulation: ViewEncapsulation.None, standalone: true, imports: [
|
|
39
39
|
// Module
|
|
40
40
|
CommonModule,
|
|
41
41
|
AngularSvgIconModule,
|
|
@@ -63,4 +63,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
63
63
|
}], clearInputClick: [{
|
|
64
64
|
type: Output
|
|
65
65
|
}] } });
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2EtaW5wdXQtY2xlYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtaW5wdXQvY29tcG9uZW50cy9jYS1pbnB1dC1jbGVhci9jYS1pbnB1dC1jbGVhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1pbnB1dC9jb21wb25lbnRzL2NhLWlucHV0LWNsZWFyL2NhLWlucHV0LWNsZWFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFGLE9BQU8sRUFFTCxXQUFXLEVBQ1gsbUJBQW1CLEdBQ3BCLE1BQU0sZ0JBQWdCLENBQUM7QUFNeEIsVUFBVTtBQUNWLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUV2RCxRQUFRO0FBQ1IsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRWxELFVBQVU7QUFDVixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRTdDLGFBQWE7QUFDYixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQzs7Ozs7QUF3QmpHLE1BQU0sT0FBTyxxQkFBcUI7SUFVaEM7UUFGVSxvQkFBZSxHQUF3QixJQUFJLFlBQVksRUFBUyxDQUFDO0lBRTVELENBQUM7SUFFVCxVQUFVLENBQUMsS0FBWTtRQUM1QixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRU0sVUFBVSxDQUFDLFlBQXlDO1FBQ3pELE9BQU8sY0FBYyxDQUFDLFlBQVksQ0FBVyxDQUFDO0lBQ2hELENBQUM7K0dBbEJVLHFCQUFxQjttR0FBckIscUJBQXFCLDJWQy9DbEMscXlCQW1DQTtnQkRGSSxTQUFTO2dCQUNULFlBQVksNEhBQ1osb0JBQW9CLGdPQUNwQixXQUFXLDhCQUNYLG1CQUFtQiw4QkFFbkIsU0FBUztnQkFDVCxRQUFRO2dCQUNSLG1CQUFtQjtnQkFFbkIsYUFBYTtnQkFDYix1QkFBdUI7OzRGQUdkLHFCQUFxQjtrQkFyQmpDLFNBQVM7K0JBQ0Usb0JBQW9CLGlCQUdmLGlCQUFpQixDQUFDLElBQUksY0FDekIsSUFBSSxXQUNQO3dCQUNQLFNBQVM7d0JBQ1QsWUFBWTt3QkFDWixvQkFBb0I7d0JBQ3BCLFdBQVc7d0JBQ1gsbUJBQW1CO3dCQUNuQixvQkFBb0I7d0JBQ3BCLFNBQVM7d0JBQ1QsUUFBUTt3QkFDUixtQkFBbUI7d0JBRW5CLGFBQWE7d0JBQ2IsdUJBQXVCO3FCQUN4Qjt3REFHUSxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLDBCQUEwQjtzQkFBbEMsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUVJLGVBQWU7c0JBQXhCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBBYnN0cmFjdENvbnRyb2wsXG4gIEZvcm1zTW9kdWxlLFxuICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxufSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbi8vIG1vZGVsc1xuaW1wb3J0IHsgSUNhSW5wdXQgfSBmcm9tICcuLi8uLi9jb25maWcnO1xuaW1wb3J0IHsgTGFiZWxDb2xvciB9IGZyb20gJy4uLy4uL21vZGVscyc7XG5cbi8vIG1vZHVsZXNcbmltcG9ydCB7IEFuZ3VsYXJTdmdJY29uTW9kdWxlIH0gZnJvbSAnYW5ndWxhci1zdmctaWNvbic7XG5pbXBvcnQgeyBOZ2JNb2R1bGUgfSBmcm9tICdAbmctYm9vdHN0cmFwL25nLWJvb3RzdHJhcCc7XG5cbi8vIHBpcGVzXG5pbXBvcnQgeyBJbnB1dENsZWFyQ2xhc3NQaXBlIH0gZnJvbSAnLi4vLi4vcGlwZXMnO1xuXG4vLyBoZWxwZXJzXG5pbXBvcnQgeyBJbnB1dFN2Z1JvdXRlcyB9IGZyb20gJy4uLy4uL3V0aWxzJztcblxuLy8gY29tcG9uZW50c1xuaW1wb3J0IHsgQ2FBcHBUb29sdGlwVjJDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi9jYS1hcHAtdG9vbHRpcC12Mi9jYS1hcHAtdG9vbHRpcC12Mi5jb21wb25lbnQnO1xuXG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1jYS1pbnB1dC1jbGVhcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9jYS1pbnB1dC1jbGVhci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NhLWlucHV0LWNsZWFyLmNvbXBvbmVudC5zY3NzJ10sXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtcbiAgICAvLyBNb2R1bGVcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgQW5ndWxhclN2Z0ljb25Nb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBBbmd1bGFyU3ZnSWNvbk1vZHVsZSxcbiAgICBOZ2JNb2R1bGUsXG4gICAgLy8gUGlwZXNcbiAgICBJbnB1dENsZWFyQ2xhc3NQaXBlLFxuXG4gICAgLy8gQ29tcG9uZW50c1xuICAgIENhQXBwVG9vbHRpcFYyQ29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBDYUlucHV0Q2xlYXJDb21wb25lbnQge1xuICBASW5wdXQoKSBpbnB1dENvbmZpZyE6IElDYUlucHV0O1xuICBASW5wdXQoKSBnZXRTdXBlckNvbnRyb2whOiBBYnN0cmFjdENvbnRyb2w8YW55LCBhbnk+IHwgbnVsbDtcbiAgQElucHV0KCkgaXNGb2N1c0lucHV0ITogYm9vbGVhbjtcbiAgQElucHV0KCkgaW5jb3JyZWN0VmFsdWUhOiBib29sZWFuO1xuICBASW5wdXQoKSBzZWxlY3RlZERyb3Bkb3duTGFiZWxDb2xvciE6IExhYmVsQ29sb3IgfCBudWxsO1xuICBASW5wdXQoKSB0ZW1wbGF0ZSE6IHN0cmluZztcblxuICBAT3V0cHV0KCkgY2xlYXJJbnB1dENsaWNrOiBFdmVudEVtaXR0ZXI8RXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxFdmVudD4oKTtcblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgcHVibGljIGNsZWFySW5wdXQoZXZlbnQ6IEV2ZW50KTogdm9pZCB7XG4gICAgdGhpcy5jbGVhcklucHV0Q2xpY2suZW1pdChldmVudCk7XG4gIH1cblxuICBwdWJsaWMgZ2V0U3ZnUGF0aChwcm9wZXJ0eU5hbWU6IGtleW9mIHR5cGVvZiBJbnB1dFN2Z1JvdXRlcyk6IHN0cmluZyB7XG4gICAgcmV0dXJuIElucHV0U3ZnUm91dGVzW3Byb3BlcnR5TmFtZV0gYXMgc3RyaW5nO1xuICB9XG59XG4iLCI8ZGl2XG4gIGNsYXNzPVwiaW5wdXQtY2xlYXIge3sgaW5wdXRDb25maWcuY3VzdG9tQ2xhc3MgfX1cIlxuICBbbmdDbGFzc109XCJcbiAgICBnZXRTdXBlckNvbnRyb2xcbiAgICAgIHwgaW5wdXRDbGVhckNsYXNzXG4gICAgICAgIDogaXNGb2N1c0lucHV0XG4gICAgICAgIDogaW5wdXRDb25maWdcbiAgICAgICAgOiBpbmNvcnJlY3RWYWx1ZVxuICAgICAgICA6ICEhc2VsZWN0ZWREcm9wZG93bkxhYmVsQ29sb3JcbiAgICAgICAgOiB0ZW1wbGF0ZVxuICAgICAgICA6IGdldFN1cGVyQ29udHJvbD8udmFsdWVcbiAgXCJcbiAgbmdiVG9vbHRpcFxuICBbbWFpbkNhVG9vbHRpcF09XCJcbiAgICBpbnB1dENvbmZpZy5pbmNvcnJlY3RJbnB1dFxuICAgICAgPyAnTWFyayBJbmNvcnJlY3QnXG4gICAgICA6IGlucHV0Q29uZmlnLnJlbW92ZUlucHV0XG4gICAgICA/ICdSZW1vdmUnXG4gICAgICA6ICdDbGVhcidcbiAgXCJcbiAgW3Rvb2x0aXBCYWNrZ3JvdW5kXT1cIlxuICAgIGlucHV0Q29uZmlnLmluY29ycmVjdElucHV0ID8gJyNlZjUzNTAnIDogJyMyRjJGMkYnXG4gIFwiXG4gIHBvc2l0aW9uPVwidG9wXCJcbiAgKGNsaWNrKT1cImNsZWFySW5wdXQoJGV2ZW50KVwiXG4+XG4gIDxzdmctaWNvblxuICAgIFtzcmNdPVwiXG4gICAgICBpbnB1dENvbmZpZy5yZW1vdmVJbnB1dFxuICAgICAgICA/IGdldFN2Z1BhdGgoJ3JlbW92ZUlucHV0U3ZnJylcbiAgICAgICAgOiBnZXRTdmdQYXRoKCd4Q2xlYXJTdmcnKVxuICAgIFwiXG4gICAgY2xhc3M9XCJpbnB1dC1jbGVhci14XCJcbiAgPjwvc3ZnLWljb24+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -11,21 +11,15 @@ import { InputPlaceholderIconClassPipe } from '../../pipes';
|
|
|
11
11
|
// directive
|
|
12
12
|
import { HoverSvgDirective } from '../../../../directives/hover-svg-directives';
|
|
13
13
|
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "
|
|
15
|
-
import * as i2 from "
|
|
16
|
-
import * as i3 from "
|
|
17
|
-
import * as i4 from "@ng-bootstrap/ng-bootstrap";
|
|
14
|
+
import * as i1 from "@angular/common";
|
|
15
|
+
import * as i2 from "angular-svg-icon";
|
|
16
|
+
import * as i3 from "@ng-bootstrap/ng-bootstrap";
|
|
18
17
|
export class CaInputPlaceholderIconComponent {
|
|
19
|
-
constructor(
|
|
20
|
-
this.inputStateService = inputStateService;
|
|
18
|
+
constructor() {
|
|
21
19
|
this.onPopoverShownEmitter = new EventEmitter();
|
|
22
20
|
this.onPopoverHiddenEmitter = new EventEmitter();
|
|
23
21
|
this.onPlaceholderIconEventEmitter = new EventEmitter();
|
|
24
22
|
}
|
|
25
|
-
ngOnInit() { }
|
|
26
|
-
ngAfterViewInit() {
|
|
27
|
-
this.inputStateService.setViewChildsPopover(this.t2, this.ngbMainPopover);
|
|
28
|
-
}
|
|
29
23
|
onPopoverShown() {
|
|
30
24
|
this.onPopoverShownEmitter.emit(true);
|
|
31
25
|
}
|
|
@@ -35,10 +29,10 @@ export class CaInputPlaceholderIconComponent {
|
|
|
35
29
|
onPlaceholderIconEvent(event) {
|
|
36
30
|
this.onPlaceholderIconEventEmitter.emit(event);
|
|
37
31
|
}
|
|
38
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaInputPlaceholderIconComponent, deps: [
|
|
39
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CaInputPlaceholderIconComponent, isStandalone: true, selector: "app-ca-input-placeholder-icon", inputs: { inputConfig: "inputConfig", getSuperControl: "getSuperControl", isFocusInput: "isFocusInput", isTouchedInput: "isTouchedInput", selectedDropdownLabelColor: "selectedDropdownLabelColor", isEditInput: "isEditInput", dateTimePopover: "dateTimePopover" }, outputs: { onPopoverShownEmitter: "onPopoverShownEmitter", onPopoverHiddenEmitter: "onPopoverHiddenEmitter", onPlaceholderIconEventEmitter: "onPlaceholderIconEventEmitter" }, viewQueries: [{ propertyName: "t2", first: true, predicate: ["t2"], descendants: true }, { propertyName: "ngbMainPopover", first: true, predicate: NgbPopover, descendants: true }], ngImport: i0, template: "<div\n #t2=\"ngbPopover\"\n [ngbPopover]=\"dateTimePopover\"\n [disablePopover]=\"\n (inputConfig.name !== 'datepicker' &&\n inputConfig.name !== 'timepicker' &&\n inputConfig.name !== 'datepickerBankCard') ||\n inputConfig.isDisabled!\n \"\n [placement]=\"['left', 'left-top']\"\n [popoverClass]=\"'datetimepopovermain'\"\n autoClose=\"outside\"\n [container]=\"'body'\"\n class=\"input-icon {{ inputConfig.customClass }}\"\n [ngClass]=\"\n getSuperControl\n | inputPlaceholderIconClass\n : isFocusInput\n : inputConfig\n : selectedDropdownLabelColor\n : isTouchedInput\n : isEditInput\n : getSuperControl?.value\n \"\n ngbTooltip\n [mainCaTooltip]=\"'Change Color'\"\n [tooltipBackground]=\"'#424242'\"\n [disableTooltip]=\"!isEditInput\"\n position=\"bottom\"\n (shown)=\"onPopoverShown()\"\n (hidden)=\"onPopoverHidden()\"\n (click)=\"onPlaceholderIconEvent($event)\"\n [ngStyle]=\"{ opacity: inputConfig.isIconHidden ? '0' : {} }\"\n>\n <svg-icon\n appHoverSvg\n [stretch]=\"true\"\n [fill]=\"\n inputConfig.dropdownLabel || selectedDropdownLabelColor\n ? selectedDropdownLabelColor?.code || '#b7b7b7'\n : null\n \"\n [fillHover]=\"\n (inputConfig.dropdownLabel || selectedDropdownLabelColor) && isEditInput\n ? selectedDropdownLabelColor?.hoverCode || null\n : null\n \"\n [src]=\"(inputConfig.placeholderIcon! | caSvg: 'input') ?? ''\"\n ></svg-icon>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type:
|
|
32
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaInputPlaceholderIconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
33
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CaInputPlaceholderIconComponent, isStandalone: true, selector: "app-ca-input-placeholder-icon", inputs: { inputConfig: "inputConfig", getSuperControl: "getSuperControl", isFocusInput: "isFocusInput", isTouchedInput: "isTouchedInput", selectedDropdownLabelColor: "selectedDropdownLabelColor", isEditInput: "isEditInput", dateTimePopover: "dateTimePopover" }, outputs: { onPopoverShownEmitter: "onPopoverShownEmitter", onPopoverHiddenEmitter: "onPopoverHiddenEmitter", onPlaceholderIconEventEmitter: "onPlaceholderIconEventEmitter" }, viewQueries: [{ propertyName: "t2", first: true, predicate: ["t2"], descendants: true }, { propertyName: "ngbMainPopover", first: true, predicate: NgbPopover, descendants: true }], ngImport: i0, template: "<div\n #t2=\"ngbPopover\"\n [ngbPopover]=\"dateTimePopover\"\n [disablePopover]=\"\n (inputConfig.name !== 'datepicker' &&\n inputConfig.name !== 'timepicker' &&\n inputConfig.name !== 'datepickerBankCard') ||\n inputConfig.isDisabled!\n \"\n [placement]=\"['left', 'left-top']\"\n [popoverClass]=\"'datetimepopovermain'\"\n autoClose=\"outside\"\n [container]=\"'body'\"\n class=\"input-icon {{ inputConfig.customClass }}\"\n [ngClass]=\"\n getSuperControl\n | inputPlaceholderIconClass\n : isFocusInput\n : inputConfig\n : selectedDropdownLabelColor\n : isTouchedInput\n : isEditInput\n : getSuperControl?.value\n \"\n ngbTooltip\n [mainCaTooltip]=\"'Change Color'\"\n [tooltipBackground]=\"'#424242'\"\n [disableTooltip]=\"!isEditInput\"\n position=\"bottom\"\n (shown)=\"onPopoverShown()\"\n (hidden)=\"onPopoverHidden()\"\n (click)=\"onPlaceholderIconEvent($event)\"\n [ngStyle]=\"{ opacity: inputConfig.isIconHidden ? '0' : {} }\"\n>\n <svg-icon\n appHoverSvg\n [stretch]=\"true\"\n [fill]=\"\n inputConfig.dropdownLabel || selectedDropdownLabelColor\n ? selectedDropdownLabelColor?.code || '#b7b7b7'\n : null\n \"\n [fillHover]=\"\n (inputConfig.dropdownLabel || selectedDropdownLabelColor) && isEditInput\n ? selectedDropdownLabelColor?.hoverCode || null\n : null\n \"\n [src]=\"(inputConfig.placeholderIcon! | caSvg : 'input') ?? ''\"\n ></svg-icon>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type:
|
|
40
34
|
// modules
|
|
41
|
-
CommonModule }, { kind: "directive", type:
|
|
35
|
+
CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: AngularSvgIconModule }, { kind: "component", type: i2.SvgIconComponent, selector: "svg-icon", inputs: ["src", "name", "stretch", "applyClass", "applyCss", "svgClass", "class", "viewBox", "svgAriaLabel", "svgStyle"] }, { kind: "ngmodule", type: NgbModule }, { kind: "directive", type: i3.NgbPopover, selector: "[ngbPopover]", inputs: ["animation", "autoClose", "ngbPopover", "popoverTitle", "placement", "popperOptions", "triggers", "positionTarget", "container", "disablePopover", "popoverClass", "popoverContext", "openDelay", "closeDelay"], outputs: ["shown", "hidden"], exportAs: ["ngbPopover"] }, { kind: "directive", type: i3.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "tooltipContext", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "component", type:
|
|
42
36
|
// components
|
|
43
37
|
CaAppTooltipV2Component, selector: "mainCaTooltip, [mainCaTooltip]", inputs: ["mainCaTooltip", "position", "openTooltipDelay", "tooltipBackground", "tooltipColor", "tooltipTextAlign", "tooltipMarginTop", "disableTooltip"] }, { kind: "pipe", type:
|
|
44
38
|
// pipes
|
|
@@ -59,9 +53,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
59
53
|
InputPlaceholderIconClassPipe,
|
|
60
54
|
CaSvgPipe,
|
|
61
55
|
// directive
|
|
62
|
-
HoverSvgDirective
|
|
63
|
-
], template: "<div\n #t2=\"ngbPopover\"\n [ngbPopover]=\"dateTimePopover\"\n [disablePopover]=\"\n (inputConfig.name !== 'datepicker' &&\n inputConfig.name !== 'timepicker' &&\n inputConfig.name !== 'datepickerBankCard') ||\n inputConfig.isDisabled!\n \"\n [placement]=\"['left', 'left-top']\"\n [popoverClass]=\"'datetimepopovermain'\"\n autoClose=\"outside\"\n [container]=\"'body'\"\n class=\"input-icon {{ inputConfig.customClass }}\"\n [ngClass]=\"\n getSuperControl\n | inputPlaceholderIconClass\n : isFocusInput\n : inputConfig\n : selectedDropdownLabelColor\n : isTouchedInput\n : isEditInput\n : getSuperControl?.value\n \"\n ngbTooltip\n [mainCaTooltip]=\"'Change Color'\"\n [tooltipBackground]=\"'#424242'\"\n [disableTooltip]=\"!isEditInput\"\n position=\"bottom\"\n (shown)=\"onPopoverShown()\"\n (hidden)=\"onPopoverHidden()\"\n (click)=\"onPlaceholderIconEvent($event)\"\n [ngStyle]=\"{ opacity: inputConfig.isIconHidden ? '0' : {} }\"\n>\n <svg-icon\n appHoverSvg\n [stretch]=\"true\"\n [fill]=\"\n inputConfig.dropdownLabel || selectedDropdownLabelColor\n ? selectedDropdownLabelColor?.code || '#b7b7b7'\n : null\n \"\n [fillHover]=\"\n (inputConfig.dropdownLabel || selectedDropdownLabelColor) && isEditInput\n ? selectedDropdownLabelColor?.hoverCode || null\n : null\n \"\n [src]=\"(inputConfig.placeholderIcon! | caSvg: 'input') ?? ''\"\n ></svg-icon>\n</div>\n" }]
|
|
64
|
-
}], ctorParameters: () => [
|
|
56
|
+
HoverSvgDirective,
|
|
57
|
+
], template: "<div\n #t2=\"ngbPopover\"\n [ngbPopover]=\"dateTimePopover\"\n [disablePopover]=\"\n (inputConfig.name !== 'datepicker' &&\n inputConfig.name !== 'timepicker' &&\n inputConfig.name !== 'datepickerBankCard') ||\n inputConfig.isDisabled!\n \"\n [placement]=\"['left', 'left-top']\"\n [popoverClass]=\"'datetimepopovermain'\"\n autoClose=\"outside\"\n [container]=\"'body'\"\n class=\"input-icon {{ inputConfig.customClass }}\"\n [ngClass]=\"\n getSuperControl\n | inputPlaceholderIconClass\n : isFocusInput\n : inputConfig\n : selectedDropdownLabelColor\n : isTouchedInput\n : isEditInput\n : getSuperControl?.value\n \"\n ngbTooltip\n [mainCaTooltip]=\"'Change Color'\"\n [tooltipBackground]=\"'#424242'\"\n [disableTooltip]=\"!isEditInput\"\n position=\"bottom\"\n (shown)=\"onPopoverShown()\"\n (hidden)=\"onPopoverHidden()\"\n (click)=\"onPlaceholderIconEvent($event)\"\n [ngStyle]=\"{ opacity: inputConfig.isIconHidden ? '0' : {} }\"\n>\n <svg-icon\n appHoverSvg\n [stretch]=\"true\"\n [fill]=\"\n inputConfig.dropdownLabel || selectedDropdownLabelColor\n ? selectedDropdownLabelColor?.code || '#b7b7b7'\n : null\n \"\n [fillHover]=\"\n (inputConfig.dropdownLabel || selectedDropdownLabelColor) && isEditInput\n ? selectedDropdownLabelColor?.hoverCode || null\n : null\n \"\n [src]=\"(inputConfig.placeholderIcon! | caSvg : 'input') ?? ''\"\n ></svg-icon>\n</div>\n" }]
|
|
58
|
+
}], ctorParameters: () => [], propDecorators: { inputConfig: [{
|
|
65
59
|
type: Input
|
|
66
60
|
}], getSuperControl: [{
|
|
67
61
|
type: Input
|
|
@@ -88,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
88
82
|
type: ViewChild,
|
|
89
83
|
args: [NgbPopover]
|
|
90
84
|
}] } });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2EtaW5wdXQtcGxhY2Vob2xkZXItaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1pbnB1dC9jb21wb25lbnRzL2NhLWlucHV0LXBsYWNlaG9sZGVyLWljb24vY2EtaW5wdXQtcGxhY2Vob2xkZXItaWNvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1pbnB1dC9jb21wb25lbnRzL2NhLWlucHV0LXBsYWNlaG9sZGVyLWljb24vY2EtaW5wdXQtcGxhY2Vob2xkZXItaWNvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUVMLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUVMLE1BQU0sRUFFTixTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUM7QUFPdkIsVUFBVTtBQUNWLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFFbkUsYUFBYTtBQUNiLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHdEQUF3RCxDQUFDO0FBRWpHLFFBQVE7QUFDUixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDMUQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRTVELFlBQVk7QUFDWixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQzs7Ozs7QUF3QmhGLE1BQU0sT0FBTywrQkFBK0I7SUFnQjFDO1FBUFUsMEJBQXFCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUNwRCwyQkFBc0IsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDO1FBQ3JELGtDQUE2QixHQUFHLElBQUksWUFBWSxFQUFTLENBQUM7SUFLckQsQ0FBQztJQUVULGNBQWM7UUFDbkIsSUFBSSxDQUFDLHFCQUFxQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRU0sZUFBZTtRQUNwQixJQUFJLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3pDLENBQUM7SUFFTSxzQkFBc0IsQ0FBQyxLQUFZO1FBQ3hDLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakQsQ0FBQzsrR0E1QlUsK0JBQStCO21HQUEvQiwrQkFBK0IseW9CQWMvQixVQUFVLGdEQ25FdkIsNitDQWtEQTtnQkRiSSxVQUFVO2dCQUNWLFlBQVksaU5BQ1osb0JBQW9CLGdPQUNwQixTQUFTO2dCQUVULGFBQWE7Z0JBQ2IsdUJBQXVCO2dCQUV2QixRQUFRO2dCQUNSLDZCQUE2Qiw2REFDN0IsU0FBUztnQkFFVCxZQUFZO2dCQUNaLGlCQUFpQjs7NEZBR1IsK0JBQStCO2tCQXRCM0MsU0FBUzsrQkFDRSwrQkFBK0IsY0FHN0IsSUFBSSxXQUNQO3dCQUNQLFVBQVU7d0JBQ1YsWUFBWTt3QkFDWixvQkFBb0I7d0JBQ3BCLFNBQVM7d0JBRVQsYUFBYTt3QkFDYix1QkFBdUI7d0JBRXZCLFFBQVE7d0JBQ1IsNkJBQTZCO3dCQUM3QixTQUFTO3dCQUVULFlBQVk7d0JBQ1osaUJBQWlCO3FCQUNsQjt3REFHUSxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLDBCQUEwQjtzQkFBbEMsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBRUkscUJBQXFCO3NCQUE5QixNQUFNO2dCQUNHLHNCQUFzQjtzQkFBL0IsTUFBTTtnQkFDRyw2QkFBNkI7c0JBQXRDLE1BQU07Z0JBRVUsRUFBRTtzQkFBbEIsU0FBUzt1QkFBQyxJQUFJO2dCQUNRLGNBQWM7c0JBQXBDLFNBQVM7dUJBQUMsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICBBZnRlclZpZXdJbml0LFxuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9uSW5pdCxcbiAgT3V0cHV0LFxuICBUZW1wbGF0ZVJlZixcbiAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0Q29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuLy8gbW9kZWxzXG5pbXBvcnQgeyBJQ2FJbnB1dCB9IGZyb20gJy4uLy4uL2NvbmZpZy9jYS1pbnB1dC5jb25maWcnO1xuaW1wb3J0IHsgTGFiZWxDb2xvciB9IGZyb20gJy4uLy4uL21vZGVscy9sYWJlbC1jb2xvci5tb2RlbCc7XG5cbi8vIG1vZHVsZXNcbmltcG9ydCB7IEFuZ3VsYXJTdmdJY29uTW9kdWxlIH0gZnJvbSAnYW5ndWxhci1zdmctaWNvbic7XG5pbXBvcnQgeyBOZ2JNb2R1bGUsIE5nYlBvcG92ZXIgfSBmcm9tICdAbmctYm9vdHN0cmFwL25nLWJvb3RzdHJhcCc7XG5cbi8vIGNvbXBvbmVudHNcbmltcG9ydCB7IENhQXBwVG9vbHRpcFYyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vY2EtYXBwLXRvb2x0aXAtdjIvY2EtYXBwLXRvb2x0aXAtdjIuY29tcG9uZW50JztcblxuLy8gcGlwZXNcbmltcG9ydCB7IENhU3ZnUGlwZSB9IGZyb20gJy4uLy4uLy4uLy4uL3BpcGVzL2NhLXN2Zy5waXBlJztcbmltcG9ydCB7IElucHV0UGxhY2Vob2xkZXJJY29uQ2xhc3NQaXBlIH0gZnJvbSAnLi4vLi4vcGlwZXMnO1xuXG4vLyBkaXJlY3RpdmVcbmltcG9ydCB7IEhvdmVyU3ZnRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vLi4vLi4vZGlyZWN0aXZlcy9ob3Zlci1zdmctZGlyZWN0aXZlcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1jYS1pbnB1dC1wbGFjZWhvbGRlci1pY29uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NhLWlucHV0LXBsYWNlaG9sZGVyLWljb24uY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jYS1pbnB1dC1wbGFjZWhvbGRlci1pY29uLmNvbXBvbmVudC5zY3NzJ10sXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtcbiAgICAvLyBtb2R1bGVzXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEFuZ3VsYXJTdmdJY29uTW9kdWxlLFxuICAgIE5nYk1vZHVsZSxcblxuICAgIC8vIGNvbXBvbmVudHNcbiAgICBDYUFwcFRvb2x0aXBWMkNvbXBvbmVudCxcblxuICAgIC8vIHBpcGVzXG4gICAgSW5wdXRQbGFjZWhvbGRlckljb25DbGFzc1BpcGUsXG4gICAgQ2FTdmdQaXBlLFxuXG4gICAgLy8gZGlyZWN0aXZlXG4gICAgSG92ZXJTdmdEaXJlY3RpdmUsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIENhSW5wdXRQbGFjZWhvbGRlckljb25Db21wb25lbnQge1xuICBASW5wdXQoKSBpbnB1dENvbmZpZyE6IElDYUlucHV0O1xuICBASW5wdXQoKSBnZXRTdXBlckNvbnRyb2whOiBBYnN0cmFjdENvbnRyb2w8YW55LCBhbnk+IHwgbnVsbDtcbiAgQElucHV0KCkgaXNGb2N1c0lucHV0ITogYm9vbGVhbjtcbiAgQElucHV0KCkgaXNUb3VjaGVkSW5wdXQhOiBib29sZWFuO1xuICBASW5wdXQoKSBzZWxlY3RlZERyb3Bkb3duTGFiZWxDb2xvciE6IExhYmVsQ29sb3IgfCBudWxsO1xuICBASW5wdXQoKSBpc0VkaXRJbnB1dCE6IGJvb2xlYW47XG4gIEBJbnB1dCgpIGRhdGVUaW1lUG9wb3ZlciE6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgQE91dHB1dCgpIG9uUG9wb3ZlclNob3duRW1pdHRlciA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcbiAgQE91dHB1dCgpIG9uUG9wb3ZlckhpZGRlbkVtaXR0ZXIgPSBuZXcgRXZlbnRFbWl0dGVyPGJvb2xlYW4+KCk7XG4gIEBPdXRwdXQoKSBvblBsYWNlaG9sZGVySWNvbkV2ZW50RW1pdHRlciA9IG5ldyBFdmVudEVtaXR0ZXI8RXZlbnQ+KCk7XG5cbiAgQFZpZXdDaGlsZCgndDInKSB0MiE6IE5nYlBvcG92ZXI7XG4gIEBWaWV3Q2hpbGQoTmdiUG9wb3ZlcikgbmdiTWFpblBvcG92ZXIhOiBOZ2JQb3BvdmVyO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBwdWJsaWMgb25Qb3BvdmVyU2hvd24oKTogdm9pZCB7XG4gICAgdGhpcy5vblBvcG92ZXJTaG93bkVtaXR0ZXIuZW1pdCh0cnVlKTtcbiAgfVxuXG4gIHB1YmxpYyBvblBvcG92ZXJIaWRkZW4oKTogdm9pZCB7XG4gICAgdGhpcy5vblBvcG92ZXJIaWRkZW5FbWl0dGVyLmVtaXQodHJ1ZSk7XG4gIH1cblxuICBwdWJsaWMgb25QbGFjZWhvbGRlckljb25FdmVudChldmVudDogRXZlbnQpOiB2b2lkIHtcbiAgICB0aGlzLm9uUGxhY2Vob2xkZXJJY29uRXZlbnRFbWl0dGVyLmVtaXQoZXZlbnQpO1xuICB9XG59XG4iLCI8ZGl2XG4gICN0Mj1cIm5nYlBvcG92ZXJcIlxuICBbbmdiUG9wb3Zlcl09XCJkYXRlVGltZVBvcG92ZXJcIlxuICBbZGlzYWJsZVBvcG92ZXJdPVwiXG4gICAgKGlucHV0Q29uZmlnLm5hbWUgIT09ICdkYXRlcGlja2VyJyAmJlxuICAgICAgaW5wdXRDb25maWcubmFtZSAhPT0gJ3RpbWVwaWNrZXInICYmXG4gICAgICBpbnB1dENvbmZpZy5uYW1lICE9PSAnZGF0ZXBpY2tlckJhbmtDYXJkJykgfHxcbiAgICBpbnB1dENvbmZpZy5pc0Rpc2FibGVkIVxuICBcIlxuICBbcGxhY2VtZW50XT1cIlsnbGVmdCcsICdsZWZ0LXRvcCddXCJcbiAgW3BvcG92ZXJDbGFzc109XCInZGF0ZXRpbWVwb3BvdmVybWFpbidcIlxuICBhdXRvQ2xvc2U9XCJvdXRzaWRlXCJcbiAgW2NvbnRhaW5lcl09XCInYm9keSdcIlxuICBjbGFzcz1cImlucHV0LWljb24ge3sgaW5wdXRDb25maWcuY3VzdG9tQ2xhc3MgfX1cIlxuICBbbmdDbGFzc109XCJcbiAgICBnZXRTdXBlckNvbnRyb2xcbiAgICAgIHwgaW5wdXRQbGFjZWhvbGRlckljb25DbGFzc1xuICAgICAgICA6IGlzRm9jdXNJbnB1dFxuICAgICAgICA6IGlucHV0Q29uZmlnXG4gICAgICAgIDogc2VsZWN0ZWREcm9wZG93bkxhYmVsQ29sb3JcbiAgICAgICAgOiBpc1RvdWNoZWRJbnB1dFxuICAgICAgICA6IGlzRWRpdElucHV0XG4gICAgICAgIDogZ2V0U3VwZXJDb250cm9sPy52YWx1ZVxuICBcIlxuICBuZ2JUb29sdGlwXG4gIFttYWluQ2FUb29sdGlwXT1cIidDaGFuZ2UgQ29sb3InXCJcbiAgW3Rvb2x0aXBCYWNrZ3JvdW5kXT1cIicjNDI0MjQyJ1wiXG4gIFtkaXNhYmxlVG9vbHRpcF09XCIhaXNFZGl0SW5wdXRcIlxuICBwb3NpdGlvbj1cImJvdHRvbVwiXG4gIChzaG93bik9XCJvblBvcG92ZXJTaG93bigpXCJcbiAgKGhpZGRlbik9XCJvblBvcG92ZXJIaWRkZW4oKVwiXG4gIChjbGljayk9XCJvblBsYWNlaG9sZGVySWNvbkV2ZW50KCRldmVudClcIlxuICBbbmdTdHlsZV09XCJ7IG9wYWNpdHk6IGlucHV0Q29uZmlnLmlzSWNvbkhpZGRlbiA/ICcwJyA6IHt9IH1cIlxuPlxuICA8c3ZnLWljb25cbiAgICBhcHBIb3ZlclN2Z1xuICAgIFtzdHJldGNoXT1cInRydWVcIlxuICAgIFtmaWxsXT1cIlxuICAgICAgaW5wdXRDb25maWcuZHJvcGRvd25MYWJlbCB8fCBzZWxlY3RlZERyb3Bkb3duTGFiZWxDb2xvclxuICAgICAgICA/IHNlbGVjdGVkRHJvcGRvd25MYWJlbENvbG9yPy5jb2RlIHx8ICcjYjdiN2I3J1xuICAgICAgICA6IG51bGxcbiAgICBcIlxuICAgIFtmaWxsSG92ZXJdPVwiXG4gICAgICAoaW5wdXRDb25maWcuZHJvcGRvd25MYWJlbCB8fCBzZWxlY3RlZERyb3Bkb3duTGFiZWxDb2xvcikgJiYgaXNFZGl0SW5wdXRcbiAgICAgICAgPyBzZWxlY3RlZERyb3Bkb3duTGFiZWxDb2xvcj8uaG92ZXJDb2RlIHx8IG51bGxcbiAgICAgICAgOiBudWxsXG4gICAgXCJcbiAgICBbc3JjXT1cIihpbnB1dENvbmZpZy5wbGFjZWhvbGRlckljb24hIHwgY2FTdmcgOiAnaW5wdXQnKSA/PyAnJ1wiXG4gID48L3N2Zy1pY29uPlxuPC9kaXY+XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2EtaW5wdXQuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtaW5wdXQvY29uZmlnL2NhLWlucHV0LmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJTXVsdGlwbGVJbnB1dCB7XG4gIGlkPzogbnVtYmVyO1xuICB2YWx1ZTogc3RyaW5nIHwgbnVtYmVyO1xuICBzZWNvbmRfdmFsdWU/OiBzdHJpbmcgfCBudW1iZXI7XG4gIGxvZ29OYW1lPzogc3RyaW5nO1xuICBpc0ltZz86IGJvb2xlYW47XG4gIGlzU3ZnPzogYm9vbGVhbjtcbiAgZm9sZGVyPzogc3RyaW5nO1xuICBzdWJGb2xkZXI/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input.config.js","sourceRoot":"","sources":["../../../../../../../projects/ca-components/src/lib/components/ca-input/config/ca-input.config.ts"],"names":[],"mappings":"","sourcesContent":["export interface IMultipleInput {\n  id?: number;\n  value: string | number;\n  second_value?: string | number;\n  logoName?: string;\n  isImg?: boolean;\n  isSvg?: boolean;\n  folder?: string;\n  subFolder?: string;\n  logoType?: string;\n  isOwner?: boolean;\n  isProgressBar?: boolean;\n  isCounter?: boolean;\n}\n\nexport interface ICaInputDateTimePicker {\n  name: string;\n  isIconHidden?: boolean;\n  customClass?: string; // - 'datetimeclass' -> date/time pickers, 'datetimeclass dark -> date/time pickers dark\n  isDisabled?: boolean;\n  isFutureDateDisabled?: boolean; // disabled future dates\n  expiredDateInvalid?: boolean; // accept only dates that didn't expire\n  isFromDate?: boolean;\n}\n\nexport interface ICaInput {\n  id?: number; // only for form array to indefier element\n  name: string;\n  type: string;\n  label?: string;\n  labelInInput?: boolean;\n  placeholder?: string; // only for dropdown, otherwise placeholder is label !!!\n  placeholderIcon?: string;\n  placeholderIconRightSide?: string;\n  isPlaceHolderIconRightSideDynamicColor?: boolean;\n  placeholderIconFolllowTextOnRightSide?: string;\n  placeholderIconColor?: string;\n  placeholderText?: string;\n  placeholderInsteadOfLabel?: boolean;\n  inputCursorOnRightSide?: boolean;\n  isRequired?: boolean;\n  isDisabled?: boolean;\n  pattern?: string;\n  autocomplete?: string;\n  showCount?: boolean;\n  minLength?: number;\n  maxLength?: number;\n  min?: number;\n  max?: number;\n  step?: number; // step for input type=\"number\";\n  mask?: string; // only for phone type of input\n  textTransform?: 'capitalize' | 'uppercase' | 'lowercase' | 'capitalizedcase';\n  textAlign?: string | 'center';\n  blackInput?: boolean; // has only black background && input clear, no validations\n  blueInput?: boolean;\n  incorrectInput?: boolean;\n  dangerMark?: boolean;\n  autoFocus?: boolean;\n  hideClear?: boolean;\n  hideRequiredCheck?: boolean;\n  hideErrorMessage?: boolean;\n  hideDangerMark?: boolean;\n  hideDropdownArrow?: boolean;\n  requiredLabel?: boolean;\n  errorInsideInput?: boolean;\n  removeInput?: boolean;\n  readOnly?: boolean;\n  thousandSeparator?: boolean; // type of input must be 'text'\n  priceSeparator?: boolean;\n  priceSeparatorLimitation?: number; // 7 - 999,999.00 ; 6 - 99,000.00 ; 5 - 9,000.00 itd... (must including and comma)\n  loadingSpinner?: {\n    size?: string; // small, big\n    color?: string; // black, gray, white, blueLight, blueDark\n    isLoading?: boolean;\n  };\n  addressFlag?: string; // added text in right corner and this flag will be disabled clear button, invalid danger mark\n  customClass?: string; // - 'datetimeclass' -> date/time pickers, 'datetimeclass dark -> date/time pickers dark\n  isIconInput?: boolean; // display icon instead of regular input\n  isValidIcon?: boolean; // display icon instead of regular input\n  inputIcon?: string; // display icon instead of regular input\n\n  // ***************** Multiple Inputs & Labels *****************\n  multipleInputValues?: {\n    options: IMultipleInput[];\n    customClass: string;\n  };\n  multipleLabel?: {\n    labels: string[]; // ['Driver', 'Truck #', 'Trailer #']\n    customClass: string;\n  };\n  isInputBackgroundRemoved?: boolean;\n  isBlueText?: boolean;\n\n  // ***************** Input Actions (confirm-cancel buttons) *****************\n  commands?: {\n    active?: boolean;\n    type?: string; // examples:  'increment-decrement', 'confirm-cancel'\n    firstCommand?: {\n      popup?: {\n        name?: string;\n        backgroundColor?: string;\n      };\n      name?: string;\n      svg?: string;\n    };\n    secondCommand?: {\n      popup?: {\n        name?: string;\n        backgroundColor?: string;\n      };\n      name?: string;\n      svg?: string;\n    };\n    thirdCommand?: {\n      popup?: {\n        name?: string;\n        backgroundColor?: string;\n      };\n      name?: string;\n      svg?: string;\n    };\n    setTimeout?: number; // if must keep focus on input\n    blueCommands?: boolean;\n  };\n  defaultValue?: string; // default input value for Reset command\n\n  // ***************** DROPDOWNS *****************\n\n  // Pure Dropdown\n  isDropdown?: boolean;\n  dropdownWidthClass?: string; // Look in ta-input-drodown.scss for implementation class (width of dropdowns)\n  dropdownImageInput?: {\n    withText: boolean;\n    svg: boolean;\n    image: boolean;\n    url: string;\n    nameInitialsInsteadUrl?: string; // if url does not exist, but must render initials of name\n    template?: string; // truck, trailer...\n    color?: string; // colors store in backe-end dynamicly\n    class?: string; // colors store in front-end\n    remove?: boolean; // remove svg in focus mode and when user are typing\n  } | null;\n  isInvalidSearchInDropdown?: boolean;\n  selectedDropdown?: boolean;\n  mergeDropdownBodyWithInput?: boolean;\n  hideAllItemsInInputDropdown?: boolean;\n  isBlueDropdown?: boolean;\n  isItemSelected?: boolean;\n  isDisplayingCustomPeriodRange?: boolean;\n  isUsingCustomPeriodRange?: boolean;\n\n  // Address Dropdown\n  isDispatchLocationDropdown?: boolean;\n\n  // Label dropdown\n  dropdownLabel?: boolean;\n  dropdownLabelNew?: boolean;\n\n  // MultiSelect Dropdown\n  multiselectDropdown?: boolean;\n  multiSelectDropdownActive?: boolean;\n  multiSelectItemRange?: boolean;\n\n  // DateTime Picker\n  isFromDate?: boolean;\n  hideColorValidations?: boolean; // regular color for inputs, no blue validation\n  expiredDateInvalid?: boolean; // accept only dates that didn't expire\n  isFutureDateDisabled?: boolean; // disabled future dates\n  fixedPlacholder?: string;\n  statusStyle?: boolean;\n  isIconHidden?: boolean;\n  isRemovedIconMovedOnLeft?: boolean;\n  removeLeadingZero?: boolean;\n  negativeLeadingZero?: boolean;\n  isHoverRow?: boolean;\n  minutesGapFive?: boolean;\n}\n"]}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { Directive, EventEmitter, HostListener, Output, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class CapsLockDirective {
|
|
4
|
+
constructor(el) {
|
|
5
|
+
this.el = el;
|
|
6
|
+
this.capsLockStatus = new EventEmitter(); // ✅ Emit true/false
|
|
7
|
+
this.capsLockDetected = false;
|
|
8
|
+
}
|
|
9
|
+
onKeyDown(event) {
|
|
10
|
+
const capsLockOn = event.getModifierState?.('CapsLock');
|
|
11
|
+
this.capsLockStatus.emit(capsLockOn); // Emit true when Caps Lock is ON
|
|
12
|
+
this.capsLockDetected = capsLockOn;
|
|
13
|
+
}
|
|
14
|
+
onKeyUP(event) {
|
|
15
|
+
const capsLockOn = event.getModifierState?.('CapsLock');
|
|
16
|
+
this.capsLockStatus.emit(capsLockOn); // Emit true when Caps Lock is ON
|
|
17
|
+
this.capsLockDetected = capsLockOn;
|
|
18
|
+
}
|
|
19
|
+
onFocus() {
|
|
20
|
+
// Simulate a key press to check if Caps Lock is on
|
|
21
|
+
this.capsLockStatus.emit(this.capsLockDetected);
|
|
22
|
+
}
|
|
23
|
+
onBlur() {
|
|
24
|
+
this.capsLockStatus.emit(false); // Hide message when input loses focus
|
|
25
|
+
}
|
|
26
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CapsLockDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
27
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CapsLockDirective, isStandalone: true, selector: "[appCapsLock]", outputs: { capsLockStatus: "capsLockStatus" }, host: { listeners: { "keydown": "onKeyDown($event)", "keyup": "onKeyUP($event)", "focus": "onFocus()", "blur": "onBlur()" } }, ngImport: i0 }); }
|
|
28
|
+
}
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CapsLockDirective, decorators: [{
|
|
30
|
+
type: Directive,
|
|
31
|
+
args: [{
|
|
32
|
+
selector: '[appCapsLock]',
|
|
33
|
+
standalone: true,
|
|
34
|
+
}]
|
|
35
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { capsLockStatus: [{
|
|
36
|
+
type: Output
|
|
37
|
+
}], onKeyDown: [{
|
|
38
|
+
type: HostListener,
|
|
39
|
+
args: ['keydown', ['$event']]
|
|
40
|
+
}], onKeyUP: [{
|
|
41
|
+
type: HostListener,
|
|
42
|
+
args: ['keyup', ['$event']]
|
|
43
|
+
}], onFocus: [{
|
|
44
|
+
type: HostListener,
|
|
45
|
+
args: ['focus']
|
|
46
|
+
}], onBlur: [{
|
|
47
|
+
type: HostListener,
|
|
48
|
+
args: ['blur']
|
|
49
|
+
}] } });
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2Fwcy1sb2NrLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWlucHV0L2RpcmVjdGl2ZXMvY2Fwcy1sb2NrLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsU0FBUyxFQUVULFlBQVksRUFDWixZQUFZLEVBQ1osTUFBTSxHQUNULE1BQU0sZUFBZSxDQUFDOztBQU12QixNQUFNLE9BQU8saUJBQWlCO0lBSzFCLFlBQW9CLEVBQWM7UUFBZCxPQUFFLEdBQUYsRUFBRSxDQUFZO1FBSnhCLG1CQUFjLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQyxDQUFDLG9CQUFvQjtRQUVwRSxxQkFBZ0IsR0FBRyxLQUFLLENBQUM7SUFFSSxDQUFDO0lBR3RDLFNBQVMsQ0FBQyxLQUFvQjtRQUMxQixNQUFNLFVBQVUsR0FBRyxLQUFLLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUN4RCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLGlDQUFpQztRQUN2RSxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsVUFBVSxDQUFDO0lBQ3ZDLENBQUM7SUFHRCxPQUFPLENBQUMsS0FBb0I7UUFDeEIsTUFBTSxVQUFVLEdBQUcsS0FBSyxDQUFDLGdCQUFnQixFQUFFLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDeEQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxpQ0FBaUM7UUFDdkUsSUFBSSxDQUFDLGdCQUFnQixHQUFHLFVBQVUsQ0FBQztJQUN2QyxDQUFDO0lBR0QsT0FBTztRQUNILG1EQUFtRDtRQUNuRCxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUNwRCxDQUFDO0lBR0QsTUFBTTtRQUNGLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsc0NBQXNDO0lBQzNFLENBQUM7K0dBOUJRLGlCQUFpQjttR0FBakIsaUJBQWlCOzs0RkFBakIsaUJBQWlCO2tCQUo3QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxlQUFlO29CQUN6QixVQUFVLEVBQUUsSUFBSTtpQkFDbkI7K0VBRWEsY0FBYztzQkFBdkIsTUFBTTtnQkFPUCxTQUFTO3NCQURSLFlBQVk7dUJBQUMsU0FBUyxFQUFFLENBQUMsUUFBUSxDQUFDO2dCQVFuQyxPQUFPO3NCQUROLFlBQVk7dUJBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDO2dCQVFqQyxPQUFPO3NCQUROLFlBQVk7dUJBQUMsT0FBTztnQkFPckIsTUFBTTtzQkFETCxZQUFZO3VCQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIERpcmVjdGl2ZSxcbiAgICBFbGVtZW50UmVmLFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBIb3N0TGlzdGVuZXIsXG4gICAgT3V0cHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbYXBwQ2Fwc0xvY2tdJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBDYXBzTG9ja0RpcmVjdGl2ZSB7XG4gICAgQE91dHB1dCgpIGNhcHNMb2NrU3RhdHVzID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpOyAvLyDinIUgRW1pdCB0cnVlL2ZhbHNlXG5cbiAgICBwcml2YXRlIGNhcHNMb2NrRGV0ZWN0ZWQgPSBmYWxzZTtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYpIHt9XG5cbiAgICBASG9zdExpc3RlbmVyKCdrZXlkb3duJywgWyckZXZlbnQnXSlcbiAgICBvbktleURvd24oZXZlbnQ6IEtleWJvYXJkRXZlbnQpIHtcbiAgICAgICAgY29uc3QgY2Fwc0xvY2tPbiA9IGV2ZW50LmdldE1vZGlmaWVyU3RhdGU/LignQ2Fwc0xvY2snKTtcbiAgICAgICAgdGhpcy5jYXBzTG9ja1N0YXR1cy5lbWl0KGNhcHNMb2NrT24pOyAvLyBFbWl0IHRydWUgd2hlbiBDYXBzIExvY2sgaXMgT05cbiAgICAgICAgdGhpcy5jYXBzTG9ja0RldGVjdGVkID0gY2Fwc0xvY2tPbjtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCdrZXl1cCcsIFsnJGV2ZW50J10pXG4gICAgb25LZXlVUChldmVudDogS2V5Ym9hcmRFdmVudCkge1xuICAgICAgICBjb25zdCBjYXBzTG9ja09uID0gZXZlbnQuZ2V0TW9kaWZpZXJTdGF0ZT8uKCdDYXBzTG9jaycpO1xuICAgICAgICB0aGlzLmNhcHNMb2NrU3RhdHVzLmVtaXQoY2Fwc0xvY2tPbik7IC8vIEVtaXQgdHJ1ZSB3aGVuIENhcHMgTG9jayBpcyBPTlxuICAgICAgICB0aGlzLmNhcHNMb2NrRGV0ZWN0ZWQgPSBjYXBzTG9ja09uO1xuICAgIH1cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2ZvY3VzJylcbiAgICBvbkZvY3VzKCkge1xuICAgICAgICAvLyBTaW11bGF0ZSBhIGtleSBwcmVzcyB0byBjaGVjayBpZiBDYXBzIExvY2sgaXMgb25cbiAgICAgICAgdGhpcy5jYXBzTG9ja1N0YXR1cy5lbWl0KHRoaXMuY2Fwc0xvY2tEZXRlY3RlZCk7XG4gICAgfVxuXG4gICAgQEhvc3RMaXN0ZW5lcignYmx1cicpXG4gICAgb25CbHVyKCkge1xuICAgICAgICB0aGlzLmNhcHNMb2NrU3RhdHVzLmVtaXQoZmFsc2UpOyAvLyBIaWRlIG1lc3NhZ2Ugd2hlbiBpbnB1dCBsb3NlcyBmb2N1c1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -1,2 +1,6 @@
|
|
|
1
1
|
export * from './min-max-value.directive';
|
|
2
|
-
|
|
2
|
+
export * from './caps-lock.directive';
|
|
3
|
+
export * from './input-max-value.directive';
|
|
4
|
+
export * from './price_format.directive';
|
|
5
|
+
export * from './restrict-input.directive';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1pbnB1dC9kaXJlY3RpdmVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyw0QkFBNEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbWluLW1heC12YWx1ZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9jYXBzLWxvY2suZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vaW5wdXQtbWF4LXZhbHVlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3ByaWNlX2Zvcm1hdC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9yZXN0cmljdC1pbnB1dC5kaXJlY3RpdmUnOyJdfQ==
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { Directive, HostListener, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class MaxValueDirective {
|
|
4
|
+
constructor(el) {
|
|
5
|
+
this.el = el;
|
|
6
|
+
}
|
|
7
|
+
onInput(event) {
|
|
8
|
+
if (!this.appMaxValue)
|
|
9
|
+
return;
|
|
10
|
+
const input = event.target;
|
|
11
|
+
let value = input.value;
|
|
12
|
+
// Remove thousands separators (`,`) before parsing
|
|
13
|
+
let numericValue = parseFloat(value.replace(/,/g, ''));
|
|
14
|
+
//If value exceeds the max, revert to max value
|
|
15
|
+
if (!isNaN(numericValue) && numericValue > this.appMaxValue) {
|
|
16
|
+
input.value = this.formatNumber(this.appMaxValue);
|
|
17
|
+
event.preventDefault();
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
onBlur(event) {
|
|
21
|
+
const input = event.target;
|
|
22
|
+
let numericValue = parseFloat(input.value.replace(/,/g, ''));
|
|
23
|
+
const dotIndex = input.value.indexOf('.');
|
|
24
|
+
if (!isNaN(numericValue) && dotIndex > 0) {
|
|
25
|
+
input.value = this.formatNumber(numericValue); // Format correctly on blur
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
// Helper function to format number with thousands separator
|
|
29
|
+
formatNumber(value) {
|
|
30
|
+
return value.toLocaleString('en-US', {
|
|
31
|
+
minimumFractionDigits: 2,
|
|
32
|
+
maximumFractionDigits: 2,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaxValueDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
36
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: MaxValueDirective, isStandalone: true, selector: "[appMaxValue]", inputs: { appMaxValue: "appMaxValue" }, host: { listeners: { "applyMaxValueDirective": "onInput($event)", "blur": "onBlur($event)" } }, ngImport: i0 }); }
|
|
37
|
+
}
|
|
38
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MaxValueDirective, decorators: [{
|
|
39
|
+
type: Directive,
|
|
40
|
+
args: [{
|
|
41
|
+
selector: '[appMaxValue]',
|
|
42
|
+
standalone: true,
|
|
43
|
+
}]
|
|
44
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { appMaxValue: [{
|
|
45
|
+
type: Input
|
|
46
|
+
}], onInput: [{
|
|
47
|
+
type: HostListener,
|
|
48
|
+
args: ['applyMaxValueDirective', ['$event']]
|
|
49
|
+
}], onBlur: [{
|
|
50
|
+
type: HostListener,
|
|
51
|
+
args: ['blur', ['$event']]
|
|
52
|
+
}] } });
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtbWF4LXZhbHVlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWlucHV0L2RpcmVjdGl2ZXMvaW5wdXQtbWF4LXZhbHVlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTTNFLE1BQU0sT0FBTyxpQkFBaUI7SUFHMUIsWUFBb0IsRUFBYztRQUFkLE9BQUUsR0FBRixFQUFFLENBQVk7SUFBRyxDQUFDO0lBR3RDLE9BQU8sQ0FBQyxLQUFZO1FBQ2hCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVztZQUFFLE9BQU87UUFFOUIsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLE1BQTBCLENBQUM7UUFDL0MsSUFBSSxLQUFLLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQztRQUV4QixtREFBbUQ7UUFDbkQsSUFBSSxZQUFZLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFFdkQsK0NBQStDO1FBQy9DLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLElBQUksWUFBWSxHQUFHLElBQUksQ0FBQyxXQUFZLEVBQUUsQ0FBQztZQUMzRCxLQUFLLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFdBQVksQ0FBQyxDQUFDO1lBQ25ELEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUMzQixDQUFDO0lBQ0wsQ0FBQztJQUdELE1BQU0sQ0FBQyxLQUFZO1FBQ2YsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLE1BQTBCLENBQUM7UUFDL0MsSUFBSSxZQUFZLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBRTdELE1BQU0sUUFBUSxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRTFDLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxDQUFDLElBQUksUUFBUSxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ3ZDLEtBQUssQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLDJCQUEyQjtRQUM5RSxDQUFDO0lBQ0wsQ0FBQztJQUVELDREQUE0RDtJQUNwRCxZQUFZLENBQUMsS0FBYTtRQUM5QixPQUFPLEtBQUssQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFO1lBQ2pDLHFCQUFxQixFQUFFLENBQUM7WUFDeEIscUJBQXFCLEVBQUUsQ0FBQztTQUMzQixDQUFDLENBQUM7SUFDUCxDQUFDOytHQXhDUSxpQkFBaUI7bUdBQWpCLGlCQUFpQjs7NEZBQWpCLGlCQUFpQjtrQkFKN0IsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsZUFBZTtvQkFDekIsVUFBVSxFQUFFLElBQUk7aUJBQ25COytFQUVZLFdBQVc7c0JBQW5CLEtBQUs7Z0JBS04sT0FBTztzQkFETixZQUFZO3VCQUFDLHdCQUF3QixFQUFFLENBQUMsUUFBUSxDQUFDO2dCQWtCbEQsTUFBTTtzQkFETCxZQUFZO3VCQUFDLE1BQU0sRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1thcHBNYXhWYWx1ZV0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIE1heFZhbHVlRGlyZWN0aXZlIHtcbiAgICBASW5wdXQoKSBhcHBNYXhWYWx1ZT86IG51bWJlcjsgLy8gTWF4IGFsbG93ZWQgdmFsdWVcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYpIHt9XG5cbiAgICBASG9zdExpc3RlbmVyKCdhcHBseU1heFZhbHVlRGlyZWN0aXZlJywgWyckZXZlbnQnXSlcbiAgICBvbklucHV0KGV2ZW50OiBFdmVudCk6IHZvaWQge1xuICAgICAgICBpZiAoIXRoaXMuYXBwTWF4VmFsdWUpIHJldHVybjtcblxuICAgICAgICBjb25zdCBpbnB1dCA9IGV2ZW50LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50O1xuICAgICAgICBsZXQgdmFsdWUgPSBpbnB1dC52YWx1ZTtcblxuICAgICAgICAvLyBSZW1vdmUgdGhvdXNhbmRzIHNlcGFyYXRvcnMgKGAsYCkgYmVmb3JlIHBhcnNpbmdcbiAgICAgICAgbGV0IG51bWVyaWNWYWx1ZSA9IHBhcnNlRmxvYXQodmFsdWUucmVwbGFjZSgvLC9nLCAnJykpO1xuXG4gICAgICAgIC8vSWYgdmFsdWUgZXhjZWVkcyB0aGUgbWF4LCByZXZlcnQgdG8gbWF4IHZhbHVlXG4gICAgICAgIGlmICghaXNOYU4obnVtZXJpY1ZhbHVlKSAmJiBudW1lcmljVmFsdWUgPiB0aGlzLmFwcE1heFZhbHVlISkge1xuICAgICAgICAgICAgaW5wdXQudmFsdWUgPSB0aGlzLmZvcm1hdE51bWJlcih0aGlzLmFwcE1heFZhbHVlISk7XG4gICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgQEhvc3RMaXN0ZW5lcignYmx1cicsIFsnJGV2ZW50J10pXG4gICAgb25CbHVyKGV2ZW50OiBFdmVudCk6IHZvaWQge1xuICAgICAgICBjb25zdCBpbnB1dCA9IGV2ZW50LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50O1xuICAgICAgICBsZXQgbnVtZXJpY1ZhbHVlID0gcGFyc2VGbG9hdChpbnB1dC52YWx1ZS5yZXBsYWNlKC8sL2csICcnKSk7XG5cbiAgICAgICAgY29uc3QgZG90SW5kZXggPSBpbnB1dC52YWx1ZS5pbmRleE9mKCcuJyk7XG5cbiAgICAgICAgaWYgKCFpc05hTihudW1lcmljVmFsdWUpICYmIGRvdEluZGV4ID4gMCkge1xuICAgICAgICAgICAgaW5wdXQudmFsdWUgPSB0aGlzLmZvcm1hdE51bWJlcihudW1lcmljVmFsdWUpOyAvLyBGb3JtYXQgY29ycmVjdGx5IG9uIGJsdXJcbiAgICAgICAgfVxuICAgIH1cblxuICAgIC8vIEhlbHBlciBmdW5jdGlvbiB0byBmb3JtYXQgbnVtYmVyIHdpdGggdGhvdXNhbmRzIHNlcGFyYXRvclxuICAgIHByaXZhdGUgZm9ybWF0TnVtYmVyKHZhbHVlOiBudW1iZXIpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gdmFsdWUudG9Mb2NhbGVTdHJpbmcoJ2VuLVVTJywge1xuICAgICAgICAgICAgbWluaW11bUZyYWN0aW9uRGlnaXRzOiAyLFxuICAgICAgICAgICAgbWF4aW11bUZyYWN0aW9uRGlnaXRzOiAyLFxuICAgICAgICB9KTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -38,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
38
38
|
type: HostListener,
|
|
39
39
|
args: ['document:keypress', ['$event']]
|
|
40
40
|
}] } });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWluLW1heC12YWx1ZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jYS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jYS1pbnB1dC9kaXJlY3RpdmVzL21pbi1tYXgtdmFsdWUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBTzNFLE1BQU0sT0FBTyxvQkFBb0I7SUFJN0IsWUFDWSxFQUFjLEVBQ2QscUJBQTRDO1FBRDVDLE9BQUUsR0FBRixFQUFFLENBQVk7UUFDZCwwQkFBcUIsR0FBckIscUJBQXFCLENBQXVCO0lBQ3JELENBQUM7SUFHSixVQUFVLENBQUMsS0FBb0I7UUFDM0IsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBZSxDQUFDO1FBQ3ZELE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxHQUFHLENBQUM7UUFDekIsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsY0FBYyxDQUFDO1FBRTdELE1BQU0sUUFBUSxHQUNWLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLGVBQWUsQ0FBQztZQUNsQyxNQUFNO1lBQ04sUUFBUSxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUNwQyxNQUFNLFlBQVksR0FBRyxVQUFVLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUUzRCxJQUFJLFlBQVksR0FBRyxJQUFJLENBQUMsUUFBUTtZQUFFLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN6RCxJQUFJLFlBQVksR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDL0IsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMscUJBQXFCLENBQUMsU0FBUyxDQUM5RCxJQUFJLENBQUMsUUFBUSxDQUNoQixDQUFDO1FBQ04sQ0FBQztJQUNMLENBQUM7K0dBNUJRLG9CQUFvQjttR0FBcEIsb0JBQW9COzs0RkFBcEIsb0JBQW9CO2tCQUpoQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFVBQVUsRUFBRSxJQUFJO2lCQUNuQjttSEFFWSxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBUU4sVUFBVTtzQkFEVCxZQUFZO3VCQUFDLG1CQUFtQixFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0TGlzdGVuZXIsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaG91c2FuZFNlcGFyYXRvclBpcGUgfSBmcm9tICcuLi8uLi8uLi9waXBlcy90aG91c2FuZC1zZXBhcmF0b3IucGlwZSc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2FwcE1pbk1heFZhbHVlXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgTWluTWF4VmFsdWVEaXJlY3RpdmUge1xuICAgIEBJbnB1dCgpIG1pblZhbHVlITogbnVtYmVyO1xuICAgIEBJbnB1dCgpIG1heFZhbHVlITogbnVtYmVyO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgZWw6IEVsZW1lbnRSZWYsXG4gICAgICAgIHByaXZhdGUgdGhvdXNhbmRTZXBhcmF0b3JQaXBlOiBUaG91c2FuZFNlcGFyYXRvclBpcGVcbiAgICApIHt9XG5cbiAgICBASG9zdExpc3RlbmVyKCdkb2N1bWVudDprZXlwcmVzcycsIFsnJGV2ZW50J10pXG4gICAgb25LZXlQcmVzcyhldmVudDogS2V5Ym9hcmRFdmVudCkge1xuICAgICAgICBjb25zdCBvbGRWYWx1ZSA9IHRoaXMuZWwubmF0aXZlRWxlbWVudC52YWx1ZSBhcyBzdHJpbmc7XG4gICAgICAgIGNvbnN0IG5ld0tleSA9IGV2ZW50LmtleTtcbiAgICAgICAgY29uc3QgY3VycmVudFBvc2l0aW9uID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50LnNlbGVjdGlvblN0YXJ0O1xuXG4gICAgICAgIGNvbnN0IG5ld1ZhbHVlID1cbiAgICAgICAgICAgIG9sZFZhbHVlLnNsaWNlKDAsIGN1cnJlbnRQb3NpdGlvbikgK1xuICAgICAgICAgICAgbmV3S2V5ICtcbiAgICAgICAgICAgIG9sZFZhbHVlLnNsaWNlKGN1cnJlbnRQb3NpdGlvbik7XG4gICAgICAgIGNvbnN0IGN1cnJlbnRWYWx1ZSA9IHBhcnNlRmxvYXQobmV3VmFsdWUucmVwbGFjZSgnLCcsICcnKSk7XG5cbiAgICAgICAgaWYgKGN1cnJlbnRWYWx1ZSA8IHRoaXMubWluVmFsdWUpIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgIGlmIChjdXJyZW50VmFsdWUgPiB0aGlzLm1heFZhbHVlKSB7XG4gICAgICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAgICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LnZhbHVlID0gdGhpcy50aG91c2FuZFNlcGFyYXRvclBpcGUudHJhbnNmb3JtKFxuICAgICAgICAgICAgICAgIHRoaXMubWF4VmFsdWVcbiAgICAgICAgICAgICk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { Directive, HostListener, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class PriceFormatDirective {
|
|
4
|
+
constructor(el) {
|
|
5
|
+
this.el = el;
|
|
6
|
+
this.priceSeparator = false; // Default is false
|
|
7
|
+
}
|
|
8
|
+
onInput(event) {
|
|
9
|
+
if (!this.priceSeparator)
|
|
10
|
+
return; // Skip if disabled
|
|
11
|
+
let input = this.el.nativeElement;
|
|
12
|
+
let value = input.value;
|
|
13
|
+
// Allow only numbers and one dot (.)
|
|
14
|
+
value = value.replace(/[^0-9.]/g, '');
|
|
15
|
+
const [integerPart, decimalPart] = value.split('.');
|
|
16
|
+
// Ensure decimal part is limited to two places
|
|
17
|
+
if (decimalPart && decimalPart.length > 2) {
|
|
18
|
+
value = integerPart + '.' + decimalPart.substring(0, 2);
|
|
19
|
+
}
|
|
20
|
+
// Apply thousands separator formatting
|
|
21
|
+
input.value = this.formatWithCommas(value);
|
|
22
|
+
}
|
|
23
|
+
formatWithCommas(value) {
|
|
24
|
+
return value.replace(/\B(?=(\d{3})+(?!\d))/g, ','); // Format whole number
|
|
25
|
+
}
|
|
26
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PriceFormatDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
27
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: PriceFormatDirective, isStandalone: true, selector: "[priceFormat]", inputs: { priceSeparator: "priceSeparator" }, host: { listeners: { "input": "onInput($event)" } }, ngImport: i0 }); }
|
|
28
|
+
}
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PriceFormatDirective, decorators: [{
|
|
30
|
+
type: Directive,
|
|
31
|
+
args: [{
|
|
32
|
+
selector: '[priceFormat]',
|
|
33
|
+
standalone: true,
|
|
34
|
+
}]
|
|
35
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { priceSeparator: [{
|
|
36
|
+
type: Input
|
|
37
|
+
}], onInput: [{
|
|
38
|
+
type: HostListener,
|
|
39
|
+
args: ['input', ['$event']]
|
|
40
|
+
}] } });
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJpY2VfZm9ybWF0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWlucHV0L2RpcmVjdGl2ZXMvcHJpY2VfZm9ybWF0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTTNFLE1BQU0sT0FBTyxvQkFBb0I7SUFDN0IsWUFBb0IsRUFBYztRQUFkLE9BQUUsR0FBRixFQUFFLENBQVk7UUFDekIsbUJBQWMsR0FBYSxLQUFLLENBQUMsQ0FBQyxtQkFBbUI7SUFEekIsQ0FBQztJQUl0QyxPQUFPLENBQUMsS0FBWTtRQUNoQixJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWM7WUFBRSxPQUFPLENBQUMsbUJBQW1CO1FBRXJELElBQUksS0FBSyxHQUFHLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDO1FBQ2xDLElBQUksS0FBSyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUM7UUFFeEIscUNBQXFDO1FBQ3JDLEtBQUssR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLFVBQVUsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUV0QyxNQUFNLENBQUMsV0FBVyxFQUFFLFdBQVcsQ0FBQyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFFcEQsK0NBQStDO1FBQy9DLElBQUksV0FBVyxJQUFJLFdBQVcsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDeEMsS0FBSyxHQUFHLFdBQVcsR0FBRyxHQUFHLEdBQUcsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDNUQsQ0FBQztRQUVELHVDQUF1QztRQUN2QyxLQUFLLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRU8sZ0JBQWdCLENBQUMsS0FBYTtRQUNsQyxPQUFPLEtBQUssQ0FBQyxPQUFPLENBQUMsdUJBQXVCLEVBQUUsR0FBRyxDQUFDLENBQUMsQ0FBQyxzQkFBc0I7SUFDOUUsQ0FBQzsrR0EzQlEsb0JBQW9CO21HQUFwQixvQkFBb0I7OzRGQUFwQixvQkFBb0I7a0JBSmhDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGVBQWU7b0JBQ3pCLFVBQVUsRUFBRSxJQUFJO2lCQUNuQjsrRUFHWSxjQUFjO3NCQUF0QixLQUFLO2dCQUdOLE9BQU87c0JBRE4sWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3RMaXN0ZW5lciwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbcHJpY2VGb3JtYXRdJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBQcmljZUZvcm1hdERpcmVjdGl2ZSB7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBlbDogRWxlbWVudFJlZikge31cbiAgICBASW5wdXQoKSBwcmljZVNlcGFyYXRvcj86IGJvb2xlYW4gPSBmYWxzZTsgLy8gRGVmYXVsdCBpcyBmYWxzZVxuXG4gICAgQEhvc3RMaXN0ZW5lcignaW5wdXQnLCBbJyRldmVudCddKVxuICAgIG9uSW5wdXQoZXZlbnQ6IEV2ZW50KTogdm9pZCB7XG4gICAgICAgIGlmICghdGhpcy5wcmljZVNlcGFyYXRvcikgcmV0dXJuOyAvLyBTa2lwIGlmIGRpc2FibGVkXG5cbiAgICAgICAgbGV0IGlucHV0ID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50O1xuICAgICAgICBsZXQgdmFsdWUgPSBpbnB1dC52YWx1ZTtcblxuICAgICAgICAvLyBBbGxvdyBvbmx5IG51bWJlcnMgYW5kIG9uZSBkb3QgKC4pXG4gICAgICAgIHZhbHVlID0gdmFsdWUucmVwbGFjZSgvW14wLTkuXS9nLCAnJyk7XG5cbiAgICAgICAgY29uc3QgW2ludGVnZXJQYXJ0LCBkZWNpbWFsUGFydF0gPSB2YWx1ZS5zcGxpdCgnLicpO1xuXG4gICAgICAgIC8vIEVuc3VyZSBkZWNpbWFsIHBhcnQgaXMgbGltaXRlZCB0byB0d28gcGxhY2VzXG4gICAgICAgIGlmIChkZWNpbWFsUGFydCAmJiBkZWNpbWFsUGFydC5sZW5ndGggPiAyKSB7XG4gICAgICAgICAgICB2YWx1ZSA9IGludGVnZXJQYXJ0ICsgJy4nICsgZGVjaW1hbFBhcnQuc3Vic3RyaW5nKDAsIDIpO1xuICAgICAgICB9XG5cbiAgICAgICAgLy8gQXBwbHkgdGhvdXNhbmRzIHNlcGFyYXRvciBmb3JtYXR0aW5nXG4gICAgICAgIGlucHV0LnZhbHVlID0gdGhpcy5mb3JtYXRXaXRoQ29tbWFzKHZhbHVlKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGZvcm1hdFdpdGhDb21tYXModmFsdWU6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiB2YWx1ZS5yZXBsYWNlKC9cXEIoPz0oXFxkezN9KSsoPyFcXGQpKS9nLCAnLCcpOyAvLyBGb3JtYXQgd2hvbGUgbnVtYmVyXG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
import { Directive, HostListener, Input, } from '@angular/core';
|
|
2
|
+
import { InputPatternPipe } from '../pipes/input-pattern.pipe';
|
|
3
|
+
import { InputTransformStringEnum } from '../enums/input-text-transform.enum';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class RestrictInputDirective {
|
|
6
|
+
constructor(el, injector) {
|
|
7
|
+
this.el = el;
|
|
8
|
+
this.injector = injector;
|
|
9
|
+
this.lastValidInputValue = '';
|
|
10
|
+
this.inputPatternPipe = this.injector.get(InputPatternPipe); // Inject pipe manually
|
|
11
|
+
}
|
|
12
|
+
onInput(event) {
|
|
13
|
+
let inputValue = this.el.nativeElement.value;
|
|
14
|
+
const maxLength = this.restrictInput.maxLength;
|
|
15
|
+
const configName = this.restrictInput.priceSeparator
|
|
16
|
+
? 'price-separator'
|
|
17
|
+
: this.restrictInput.name.toLowerCase();
|
|
18
|
+
const { regex, restrictConsecutiveDots, restrictMultipeDots, restrictConsecutiveSpaces, isDecimalAndDotOnly, } = this.inputPatternPipe.transform(configName);
|
|
19
|
+
// Prevent first space character
|
|
20
|
+
if (inputValue.startsWith(' ')) {
|
|
21
|
+
inputValue = inputValue.trimStart(); // Remove leading space
|
|
22
|
+
}
|
|
23
|
+
// Allow dots but dont allow on first place...
|
|
24
|
+
const dotIndex = inputValue.indexOf('.');
|
|
25
|
+
if (dotIndex == 0) {
|
|
26
|
+
inputValue = '';
|
|
27
|
+
}
|
|
28
|
+
const inputValueToTestWithRegex = isDecimalAndDotOnly
|
|
29
|
+
? inputValue.replace(/[^0-9.]/g, '')
|
|
30
|
+
: inputValue;
|
|
31
|
+
if (regex.test(inputValueToTestWithRegex)) {
|
|
32
|
+
if (maxLength) {
|
|
33
|
+
// Allow only numbers and one dot (.)
|
|
34
|
+
const tempLengthValue = isDecimalAndDotOnly
|
|
35
|
+
? inputValue.replace(/[^0-9.]/g, '')
|
|
36
|
+
: inputValue;
|
|
37
|
+
const [integerPart, decimalPart] = tempLengthValue.split('.');
|
|
38
|
+
// Ensure integer part respects maxLength (excluding thousand separators)
|
|
39
|
+
if (integerPart.length > maxLength) {
|
|
40
|
+
inputValue =
|
|
41
|
+
integerPart.substring(0, maxLength) +
|
|
42
|
+
(decimalPart ? '.' + decimalPart : '');
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
// Save last valid value
|
|
46
|
+
this.lastValidInputValue = inputValue;
|
|
47
|
+
if (restrictConsecutiveSpaces) {
|
|
48
|
+
inputValue = inputValue.replace(/\s{2,}/g, ' '); // Replace consecutive spaces with a single space
|
|
49
|
+
}
|
|
50
|
+
if (restrictConsecutiveDots) {
|
|
51
|
+
inputValue = inputValue.replace(/\.{2,}/g, '.'); // Replace consecutive dots with a single dot
|
|
52
|
+
}
|
|
53
|
+
if (restrictMultipeDots) {
|
|
54
|
+
inputValue = inputValue.replace(/^([^.]*)\.(.*)$/, (m, p1, p2) => p1 + '.' + p2.replace(/\./g, ''));
|
|
55
|
+
}
|
|
56
|
+
this.el.nativeElement.value = inputValue;
|
|
57
|
+
// 🔥 Manually trigger max Directive because current one needs to be done first
|
|
58
|
+
this.el.nativeElement.dispatchEvent(new Event('applyMaxValueDirective'));
|
|
59
|
+
const transformText = this.getTextTransformation(inputValue, this.restrictInput?.textTransform);
|
|
60
|
+
if (transformText)
|
|
61
|
+
this.el.nativeElement.value = transformText;
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
// If entered is not passing regEx then the input value will be last saved...
|
|
65
|
+
this.el.nativeElement.value = this.lastValidInputValue;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
getTextTransformation(value, textTransform) {
|
|
69
|
+
switch (textTransform) {
|
|
70
|
+
case InputTransformStringEnum.CAPITALIZE:
|
|
71
|
+
return (value.charAt(0).toUpperCase() +
|
|
72
|
+
value.substring(1).toLowerCase());
|
|
73
|
+
case InputTransformStringEnum.UPPERCASE:
|
|
74
|
+
return value.toLocaleUpperCase('en-US');
|
|
75
|
+
case InputTransformStringEnum.CAPITALIZED_CASE:
|
|
76
|
+
const capitalizedCaseWords = value.replace(/(^\w{1})|(\s+\w{1})/g, (letter) => letter.toUpperCase());
|
|
77
|
+
return capitalizedCaseWords;
|
|
78
|
+
default:
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RestrictInputDirective, deps: [{ token: i0.ElementRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
83
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: RestrictInputDirective, isStandalone: true, selector: "[restrictInput]", inputs: { restrictInput: "restrictInput" }, host: { listeners: { "input": "onInput($event)" } }, providers: [InputPatternPipe], ngImport: i0 }); }
|
|
84
|
+
}
|
|
85
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RestrictInputDirective, decorators: [{
|
|
86
|
+
type: Directive,
|
|
87
|
+
args: [{
|
|
88
|
+
selector: '[restrictInput]',
|
|
89
|
+
standalone: true,
|
|
90
|
+
providers: [InputPatternPipe], // Provide the pipe so it can be injected
|
|
91
|
+
}]
|
|
92
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Injector }], propDecorators: { restrictInput: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], onInput: [{
|
|
95
|
+
type: HostListener,
|
|
96
|
+
args: ['input', ['$event']]
|
|
97
|
+
}] } });
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restrict-input.directive.js","sourceRoot":"","sources":["../../../../../../../projects/ca-components/src/lib/components/ca-input/directives/restrict-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    HostListener,\n    Injector,\n    Input,\n} from '@angular/core';\nimport { InputPatternPipe } from '../pipes/input-pattern.pipe';\nimport { ICaInput } from '../config';\nimport { InputTransformStringEnum } from '../enums/input-text-transform.enum';\n\n@Directive({\n    selector: '[restrictInput]',\n    standalone: true,\n    providers: [InputPatternPipe], // Provide the pipe so it can be injected\n})\nexport class RestrictInputDirective {\n    @Input() restrictInput!: ICaInput;\n    private inputPatternPipe!: InputPatternPipe;\n\n    private lastValidInputValue: string = '';\n\n    constructor(\n        private el: ElementRef,\n        private injector: Injector\n    ) {\n        this.inputPatternPipe = this.injector.get(InputPatternPipe); // Inject pipe manually\n    }\n\n    @HostListener('input', ['$event'])\n    onInput(event: InputEvent): void {\n        let inputValue = this.el.nativeElement.value;\n\n        const maxLength = this.restrictInput.maxLength;\n        const configName = this.restrictInput.priceSeparator\n            ? 'price-separator'\n            : this.restrictInput.name.toLowerCase();\n        const {\n            regex,\n            restrictConsecutiveDots,\n            restrictMultipeDots,\n            restrictConsecutiveSpaces,\n            isDecimalAndDotOnly,\n        } = this.inputPatternPipe.transform(configName);\n\n        // Prevent first space character\n        if (inputValue.startsWith(' ')) {\n            inputValue = inputValue.trimStart(); // Remove leading space\n        }\n\n        // Allow dots but dont allow on first place...\n        const dotIndex = inputValue.indexOf('.');\n        if (dotIndex == 0) {\n            inputValue = '';\n        }\n\n        const inputValueToTestWithRegex = isDecimalAndDotOnly\n            ? inputValue.replace(/[^0-9.]/g, '')\n            : inputValue;\n\n        if (regex.test(inputValueToTestWithRegex)) {\n            if (maxLength) {\n                // Allow only numbers and one dot (.)\n                const tempLengthValue = isDecimalAndDotOnly\n                    ? inputValue.replace(/[^0-9.]/g, '')\n                    : inputValue;\n\n                const [integerPart, decimalPart] = tempLengthValue.split('.');\n\n                // Ensure integer part respects maxLength (excluding thousand separators)\n                if (integerPart.length > maxLength!) {\n                    inputValue =\n                        integerPart.substring(0, maxLength) +\n                        (decimalPart ? '.' + decimalPart : '');\n                }\n            }\n            // Save last valid value\n            this.lastValidInputValue = inputValue;\n\n            if (restrictConsecutiveSpaces) {\n                inputValue = inputValue.replace(/\\s{2,}/g, ' '); // Replace consecutive spaces with a single space\n            }\n\n            if (restrictConsecutiveDots) {\n                inputValue = inputValue.replace(/\\.{2,}/g, '.'); // Replace consecutive dots with a single dot\n            }\n\n            if (restrictMultipeDots) {\n                inputValue = inputValue.replace(\n                    /^([^.]*)\\.(.*)$/,\n                    (m: any, p1: any, p2: any) =>\n                        p1 + '.' + p2.replace(/\\./g, '')\n                );\n            }\n\n            this.el.nativeElement.value = inputValue;\n\n            // 🔥 Manually trigger max Directive because current one needs to be done first\n            this.el.nativeElement.dispatchEvent(\n                new Event('applyMaxValueDirective')\n            );\n\n            const transformText = this.getTextTransformation(\n                inputValue,\n                this.restrictInput?.textTransform as InputTransformStringEnum\n            );\n\n            if (transformText) this.el.nativeElement.value = transformText;\n        } else {\n            // If entered is not passing regEx then the input value will be last saved...\n            this.el.nativeElement.value = this.lastValidInputValue;\n        }\n    }\n\n    private getTextTransformation(\n        value: string,\n        textTransform: InputTransformStringEnum | undefined\n    ): string | undefined {\n        switch (textTransform) {\n            case InputTransformStringEnum.CAPITALIZE:\n                return (\n                    value.charAt(0).toUpperCase() +\n                    value.substring(1).toLowerCase()\n                );\n            case InputTransformStringEnum.UPPERCASE:\n                return value.toLocaleUpperCase('en-US');\n            case InputTransformStringEnum.CAPITALIZED_CASE:\n                const capitalizedCaseWords = value.replace(\n                    /(^\\w{1})|(\\s+\\w{1})/g,\n                    (letter: string) => letter.toUpperCase()\n                );\n                return capitalizedCaseWords;\n            default:\n                return;\n        }\n    }\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export var InputTransformStringEnum;
|
|
2
|
+
(function (InputTransformStringEnum) {
|
|
3
|
+
InputTransformStringEnum["CAPITALIZE"] = "capitalize";
|
|
4
|
+
InputTransformStringEnum["UPPERCASE"] = "uppercase";
|
|
5
|
+
InputTransformStringEnum["CAPITALIZED_CASE"] = "capitalizedcase";
|
|
6
|
+
InputTransformStringEnum["LOWERCASE"] = "lowercase";
|
|
7
|
+
})(InputTransformStringEnum || (InputTransformStringEnum = {}));
|
|
8
|
+
;
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtdGV4dC10cmFuc2Zvcm0uZW51bS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWlucHV0L2VudW1zL2lucHV0LXRleHQtdHJhbnNmb3JtLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFOLElBQVksd0JBS1g7QUFMRCxXQUFZLHdCQUF3QjtJQUNoQyxxREFBeUIsQ0FBQTtJQUN6QixtREFBdUIsQ0FBQTtJQUN2QixnRUFBb0MsQ0FBQTtJQUNwQyxtREFBdUIsQ0FBQTtBQUMzQixDQUFDLEVBTFcsd0JBQXdCLEtBQXhCLHdCQUF3QixRQUtuQztBQUFBLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBJbnB1dFRyYW5zZm9ybVN0cmluZ0VudW0ge1xuICAgIENBUElUQUxJWkUgPSAnY2FwaXRhbGl6ZScsXG4gICAgVVBQRVJDQVNFID0gJ3VwcGVyY2FzZScsXG4gICAgQ0FQSVRBTElaRURfQ0FTRSA9ICdjYXBpdGFsaXplZGNhc2UnLFxuICAgIExPV0VSQ0FTRSA9ICdsb3dlcmNhc2UnXG59OyJdfQ==
|