cloud-ide-element 0.0.1 → 1.0.2
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/README.md +271 -24
- package/esm2022/lib/components/confirmation-modal/confirmation-modal.component.mjs +182 -0
- package/esm2022/lib/components/data-grid/data-grid.component.mjs +1363 -0
- package/esm2022/lib/components/data-grid/data-grid.types.mjs +37 -0
- package/esm2022/lib/components/dropdown/dropdown.component.mjs +396 -0
- package/esm2022/lib/components/global-notifications/global-notifications.component.mjs +30 -0
- package/esm2022/lib/components/json-editor/json-editor.component.mjs +521 -0
- package/esm2022/lib/components/skeleton-loader/skeleton-loader.component.mjs +33 -0
- package/esm2022/lib/components/toast-notification/toast-notification.component.mjs +152 -0
- package/esm2022/lib/elements/button/cide-ele-button.component.mjs +249 -0
- package/esm2022/lib/elements/file-input/file-input.component.mjs +83 -0
- package/esm2022/lib/elements/icon/icon.component.mjs +5 -3
- package/esm2022/lib/elements/input/input.component.mjs +34 -20
- package/esm2022/lib/elements/select/select.component.mjs +471 -0
- package/esm2022/lib/elements/tab/cide-ele-tab.component.mjs +74 -0
- package/esm2022/lib/elements/textarea/textarea.component.mjs +157 -0
- package/esm2022/lib/services/confirmation.service.mjs +151 -0
- package/esm2022/lib/services/dropdown-manager.service.mjs +93 -0
- package/esm2022/lib/services/notification.service.mjs +196 -0
- package/esm2022/lib/utils/directives/resizer/resizer.directive.mjs +231 -0
- package/esm2022/lib/utils/directives/tooltip/tooltip.directive.mjs +294 -0
- package/esm2022/lib/utils/services/elements/elements.service.mjs +9 -7
- package/esm2022/public-api.mjs +23 -2
- package/fesm2022/cloud-ide-element.mjs +4646 -47
- package/fesm2022/cloud-ide-element.mjs.map +1 -1
- package/lib/components/confirmation-modal/confirmation-modal.component.d.ts +16 -0
- package/lib/components/data-grid/data-grid.component.d.ts +244 -0
- package/lib/components/data-grid/data-grid.types.d.ts +146 -0
- package/lib/components/dropdown/dropdown.component.d.ts +75 -0
- package/lib/components/global-notifications/global-notifications.component.d.ts +5 -0
- package/lib/components/json-editor/json-editor.component.d.ts +116 -0
- package/lib/components/skeleton-loader/skeleton-loader.component.d.ts +11 -0
- package/lib/components/toast-notification/toast-notification.component.d.ts +13 -0
- package/lib/elements/button/cide-ele-button.component.d.ts +85 -0
- package/lib/elements/file-input/file-input.component.d.ts +25 -0
- package/lib/elements/input/input.component.d.ts +7 -4
- package/lib/elements/select/select.component.d.ts +91 -0
- package/lib/elements/tab/cide-ele-tab.component.d.ts +26 -0
- package/lib/elements/textarea/textarea.component.d.ts +47 -0
- package/lib/services/confirmation.service.d.ts +65 -0
- package/lib/services/dropdown-manager.service.d.ts +22 -0
- package/lib/services/notification.service.d.ts +81 -0
- package/lib/utils/directives/resizer/resizer.directive.d.ts +44 -0
- package/lib/utils/directives/tooltip/tooltip.directive.d.ts +43 -0
- package/package.json +30 -4
- package/public-api.d.ts +18 -1
- package/src/lib/assets/css/cide-ele-style.scss +85 -0
- package/src/lib/assets/css/cide-ele-variable.scss +336 -0
- package/esm2022/lib/elements/button/button.component.mjs +0 -60
- package/lib/elements/button/button.component.d.ts +0 -27
|
@@ -9,11 +9,13 @@ export class CideIconComponent {
|
|
|
9
9
|
this.toolTip = "";
|
|
10
10
|
}
|
|
11
11
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideIconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
12
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: CideIconComponent, isStandalone: true, selector: "cide-ele-icon", inputs: { size: "size", type: "type", toolTip: "toolTip" }, ngImport: i0, template: "<button class=\"cide-icon tw-m-1 tw-
|
|
12
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: CideIconComponent, isStandalone: true, selector: "cide-ele-icon", inputs: { size: "size", type: "type", toolTip: "toolTip" }, host: { properties: { "class.mpro-icon-field": "type === 'box'" } }, ngImport: i0, template: "<button class=\"cide-icon tw-m-1 tw-inline-block tw-outline-none tw-relative\" [ngClass]=\"{\r\n 'tw-h-[23px] tw-w-[23px]': (size === 'sm'), \r\n 'tw-h-[19px] tw-w-[19px] !tw-m-[2px]': (size === 'xs'), \r\n 'tw-h-[14px] tw-w-[14px] !tw-m-[1px] cide-icon-2xs': (size === '2xs'), \r\n 'tw-h-[11px] tw-w-[11px] !tw-m-[1px] cide-icon-3xs': (size === '3xs'), \r\n 'tw-rounded-2xl' : (type === 'round'), 'tw-rounded-[0.2rem]' : (type === 'box') , \r\n 'tw-h-[15px] tw-w-[15px] none-type !tw-m-0': (type === 'none'),\r\n 'cide-tooltip': (toolTip),\r\n }\">\r\n <span class=\"cide-tooltip-content\">{{toolTip}}</span>\r\n\r\n <span class=\"material-symbols-outlined tw-absolute tw-top-0 tw-left-0 tw-right-0 tw-bottom-0\"\r\n [ngClass]=\"{'tw-text-[25px] -tw-ml-[1.5px] -tw-mt-[1px]': (size === 'sm'), 'tw-text-[18px] -tw-ml-[0.5px] tw-mt-[0.5px]' : (size === 'xs'), 'tw-text-[15px] -tw-ml-[0.5px] tw-mt-[0px] tw-block' : (size === '2xs'), 'tw-text-[11px] -tw-ml-[0px] tw-mt-[0px] tw-block' : (size === '3xs')}\"><ng-content></ng-content></span>\r\n</button>", styles: [":host{display:inline-flex;align-items:center;justify-content:center;font-size:inherit;color:inherit}:host(.mpro-icon-field),:host-context(.mpro-icon-field){position:relative;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;color:#374151;border-radius:.4rem;margin:0 2px}:host(.mpro-icon-field):before,:host-context(.mpro-icon-field):before{content:\"\";position:absolute;inset:0;background-color:#3b82f61a;border-radius:.5rem;opacity:0;transform:scale(.8);transition:all .2s cubic-bezier(.4,0,.2,1)}:host(.mpro-icon-field):hover:before,:host-context(.mpro-icon-field):hover:before{opacity:1;transform:scale(1)}:host(.mpro-icon-field):hover,:host-context(.mpro-icon-field):hover{color:#3b82f6}:host(.mpro-icon-field):active,:host-context(.mpro-icon-field):active{transform:scale(.95)}:host(.mpro-icon-field) .header-tooltip,:host-context(.mpro-icon-field) .header-tooltip{position:absolute;bottom:-26px;left:50%;transform:translate(-50%);background-color:#374151e6;color:#fff;padding:.25rem .6rem;border-radius:.25rem;font-size:.7rem;white-space:nowrap;opacity:0;pointer-events:none;transition:all .2s cubic-bezier(.4,0,.2,1);z-index:1000;box-shadow:0 2px 5px #0003;letter-spacing:.01em;will-change:transform,opacity}:host(.mpro-icon-field) .header-tooltip:before,:host-context(.mpro-icon-field) .header-tooltip:before{content:\"\";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border-width:5px;border-style:solid;border-color:transparent transparent rgba(55,65,81,.9) transparent}:host(.mpro-icon-field):hover .header-tooltip,:host-context(.mpro-icon-field):hover .header-tooltip{opacity:1;transform:translate(-50%) translateY(0)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
|
|
13
13
|
}
|
|
14
14
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideIconComponent, decorators: [{
|
|
15
15
|
type: Component,
|
|
16
|
-
args: [{ selector: 'cide-ele-icon', standalone: true, imports: [CommonModule],
|
|
16
|
+
args: [{ selector: 'cide-ele-icon', standalone: true, imports: [CommonModule], host: {
|
|
17
|
+
'[class.mpro-icon-field]': "type === 'box'"
|
|
18
|
+
}, template: "<button class=\"cide-icon tw-m-1 tw-inline-block tw-outline-none tw-relative\" [ngClass]=\"{\r\n 'tw-h-[23px] tw-w-[23px]': (size === 'sm'), \r\n 'tw-h-[19px] tw-w-[19px] !tw-m-[2px]': (size === 'xs'), \r\n 'tw-h-[14px] tw-w-[14px] !tw-m-[1px] cide-icon-2xs': (size === '2xs'), \r\n 'tw-h-[11px] tw-w-[11px] !tw-m-[1px] cide-icon-3xs': (size === '3xs'), \r\n 'tw-rounded-2xl' : (type === 'round'), 'tw-rounded-[0.2rem]' : (type === 'box') , \r\n 'tw-h-[15px] tw-w-[15px] none-type !tw-m-0': (type === 'none'),\r\n 'cide-tooltip': (toolTip),\r\n }\">\r\n <span class=\"cide-tooltip-content\">{{toolTip}}</span>\r\n\r\n <span class=\"material-symbols-outlined tw-absolute tw-top-0 tw-left-0 tw-right-0 tw-bottom-0\"\r\n [ngClass]=\"{'tw-text-[25px] -tw-ml-[1.5px] -tw-mt-[1px]': (size === 'sm'), 'tw-text-[18px] -tw-ml-[0.5px] tw-mt-[0.5px]' : (size === 'xs'), 'tw-text-[15px] -tw-ml-[0.5px] tw-mt-[0px] tw-block' : (size === '2xs'), 'tw-text-[11px] -tw-ml-[0px] tw-mt-[0px] tw-block' : (size === '3xs')}\"><ng-content></ng-content></span>\r\n</button>", styles: [":host{display:inline-flex;align-items:center;justify-content:center;font-size:inherit;color:inherit}:host(.mpro-icon-field),:host-context(.mpro-icon-field){position:relative;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;color:#374151;border-radius:.4rem;margin:0 2px}:host(.mpro-icon-field):before,:host-context(.mpro-icon-field):before{content:\"\";position:absolute;inset:0;background-color:#3b82f61a;border-radius:.5rem;opacity:0;transform:scale(.8);transition:all .2s cubic-bezier(.4,0,.2,1)}:host(.mpro-icon-field):hover:before,:host-context(.mpro-icon-field):hover:before{opacity:1;transform:scale(1)}:host(.mpro-icon-field):hover,:host-context(.mpro-icon-field):hover{color:#3b82f6}:host(.mpro-icon-field):active,:host-context(.mpro-icon-field):active{transform:scale(.95)}:host(.mpro-icon-field) .header-tooltip,:host-context(.mpro-icon-field) .header-tooltip{position:absolute;bottom:-26px;left:50%;transform:translate(-50%);background-color:#374151e6;color:#fff;padding:.25rem .6rem;border-radius:.25rem;font-size:.7rem;white-space:nowrap;opacity:0;pointer-events:none;transition:all .2s cubic-bezier(.4,0,.2,1);z-index:1000;box-shadow:0 2px 5px #0003;letter-spacing:.01em;will-change:transform,opacity}:host(.mpro-icon-field) .header-tooltip:before,:host-context(.mpro-icon-field) .header-tooltip:before{content:\"\";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border-width:5px;border-style:solid;border-color:transparent transparent rgba(55,65,81,.9) transparent}:host(.mpro-icon-field):hover .header-tooltip,:host-context(.mpro-icon-field):hover .header-tooltip{opacity:1;transform:translate(-50%) translateY(0)}\n"] }]
|
|
17
19
|
}], propDecorators: { size: [{
|
|
18
20
|
type: Input
|
|
19
21
|
}], type: [{
|
|
@@ -21,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
21
23
|
}], toolTip: [{
|
|
22
24
|
type: Input
|
|
23
25
|
}] } });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbG91ZC1pZGUtZWxlbWVudC9zcmMvbGliL2VsZW1lbnRzL2ljb24vaWNvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbG91ZC1pZGUtZWxlbWVudC9zcmMvbGliL2VsZW1lbnRzL2ljb24vaWNvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQWFqRCxNQUFNLE9BQU8saUJBQWlCO0lBVjlCO1FBV1csU0FBSSxHQUFjLElBQUksQ0FBQztRQUN2QixTQUFJLEdBQWEsT0FBTyxDQUFDO1FBQ3pCLFlBQU8sR0FBVyxFQUFFLENBQUM7S0FDL0I7OEdBSlksaUJBQWlCO2tHQUFqQixpQkFBaUIsME1DZDlCLHFtQ0FhUyw0dURETkcsWUFBWTs7MkZBT1gsaUJBQWlCO2tCQVY3QixTQUFTOytCQUNFLGVBQWUsY0FDYixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsUUFHakI7d0JBQ0oseUJBQXlCLEVBQUUsZ0JBQWdCO3FCQUM1Qzs4QkFHUSxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgaWNvblR5cGUsIHRoZW1lU2l6ZSB9IGZyb20gJ2Nsb3VkLWlkZS1sbXMtbW9kZWwnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdjaWRlLWVsZS1pY29uJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9pY29uLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vaWNvbi5jb21wb25lbnQuY3NzJyxcclxuICBob3N0OiB7XHJcbiAgICAnW2NsYXNzLm1wcm8taWNvbi1maWVsZF0nOiBcInR5cGUgPT09ICdib3gnXCJcclxuICB9XHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDaWRlSWNvbkNvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgc2l6ZTogdGhlbWVTaXplID0gXCJ4c1wiO1xyXG4gIEBJbnB1dCgpIHR5cGU6IGljb25UeXBlID0gXCJyb3VuZFwiO1xyXG4gIEBJbnB1dCgpIHRvb2xUaXA6IHN0cmluZyA9IFwiXCI7XHJcbn1cclxuIiwiPGJ1dHRvbiBjbGFzcz1cImNpZGUtaWNvbiB0dy1tLTEgdHctaW5saW5lLWJsb2NrIHR3LW91dGxpbmUtbm9uZSB0dy1yZWxhdGl2ZVwiIFtuZ0NsYXNzXT1cIntcclxuICAgICAgICAndHctaC1bMjNweF0gdHctdy1bMjNweF0nOiAoc2l6ZSA9PT0gJ3NtJyksIFxyXG4gICAgICAgICd0dy1oLVsxOXB4XSB0dy13LVsxOXB4XSAhdHctbS1bMnB4XSc6IChzaXplID09PSAneHMnKSwgXHJcbiAgICAgICAgJ3R3LWgtWzE0cHhdIHR3LXctWzE0cHhdICF0dy1tLVsxcHhdIGNpZGUtaWNvbi0yeHMnOiAoc2l6ZSA9PT0gJzJ4cycpLCBcclxuICAgICAgICAndHctaC1bMTFweF0gdHctdy1bMTFweF0gIXR3LW0tWzFweF0gY2lkZS1pY29uLTN4cyc6IChzaXplID09PSAnM3hzJyksIFxyXG4gICAgICAgICd0dy1yb3VuZGVkLTJ4bCcgOiAodHlwZSA9PT0gJ3JvdW5kJyksICd0dy1yb3VuZGVkLVswLjJyZW1dJyA6ICh0eXBlID09PSAnYm94JykgLCBcclxuICAgICAgICAndHctaC1bMTVweF0gdHctdy1bMTVweF0gbm9uZS10eXBlICF0dy1tLTAnOiAodHlwZSA9PT0gJ25vbmUnKSxcclxuICAgICAgICAnY2lkZS10b29sdGlwJzogKHRvb2xUaXApLFxyXG4gICAgICAgIH1cIj5cclxuICAgIDxzcGFuIGNsYXNzPVwiY2lkZS10b29sdGlwLWNvbnRlbnRcIj57e3Rvb2xUaXB9fTwvc3Bhbj5cclxuXHJcbiAgICA8c3BhbiBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWQgdHctYWJzb2x1dGUgdHctdG9wLTAgdHctbGVmdC0wIHR3LXJpZ2h0LTAgdHctYm90dG9tLTBcIlxyXG4gICAgICAgIFtuZ0NsYXNzXT1cInsndHctdGV4dC1bMjVweF0gLXR3LW1sLVsxLjVweF0gLXR3LW10LVsxcHhdJzogKHNpemUgPT09ICdzbScpLCAndHctdGV4dC1bMThweF0gLXR3LW1sLVswLjVweF0gdHctbXQtWzAuNXB4XScgOiAgKHNpemUgPT09ICd4cycpLCAndHctdGV4dC1bMTVweF0gLXR3LW1sLVswLjVweF0gdHctbXQtWzBweF0gdHctYmxvY2snIDogIChzaXplID09PSAnMnhzJyksICAndHctdGV4dC1bMTFweF0gLXR3LW1sLVswcHhdIHR3LW10LVswcHhdIHR3LWJsb2NrJyA6ICAoc2l6ZSA9PT0gJzN4cycpfVwiPjxuZy1jb250ZW50PjwvbmctY29udGVudD48L3NwYW4+XHJcbjwvYnV0dG9uPiJdfQ==
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
-
import { Component, EventEmitter, Input, Output, forwardRef } from '@angular/core';
|
|
2
|
+
import { Component, EventEmitter, Input, Output, forwardRef, inject } from '@angular/core';
|
|
3
3
|
import { FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
4
|
import { CapitalizePipe } from '../../utils/pipes/capitalize/capitalize.pipe';
|
|
5
|
+
import { CideElementsService } from '../../utils/services/elements/elements.service';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "
|
|
7
|
-
import * as i2 from "
|
|
8
|
-
import * as i3 from "@angular/common";
|
|
9
|
-
import * as i4 from "@angular/forms";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "@angular/forms";
|
|
10
9
|
export class CideInputComponent {
|
|
11
|
-
constructor(
|
|
12
|
-
|
|
13
|
-
this.
|
|
10
|
+
constructor() {
|
|
11
|
+
// Modern Angular v20 dependency injection pattern
|
|
12
|
+
this.capitalizePipe = inject(CapitalizePipe);
|
|
13
|
+
this.elementService = inject(CideElementsService);
|
|
14
14
|
/*=======Set custom controls inputs to set components=========*/
|
|
15
15
|
/**
|
|
16
16
|
* @description to se the visual of control like solid control offerd by material design or outline with a border
|
|
@@ -54,7 +54,7 @@ export class CideInputComponent {
|
|
|
54
54
|
/** @description auto complete type to help reader what is the type of value */
|
|
55
55
|
this.autocomplete = "off";
|
|
56
56
|
/** @description type of control */
|
|
57
|
-
this.type = '';
|
|
57
|
+
this.type = 'text';
|
|
58
58
|
/** @description width of control, default width is 100% */
|
|
59
59
|
this.width = '100%';
|
|
60
60
|
/** @description uniq id of control, used to differenciat the value also prevent value should not effect another values */
|
|
@@ -62,6 +62,10 @@ export class CideInputComponent {
|
|
|
62
62
|
/** @description to get input value using one way binding like: [ngModel] or by two way binding [(ngModel)] */
|
|
63
63
|
this.ngModel = '';
|
|
64
64
|
this.option = ["anksuh", "bhure"];
|
|
65
|
+
/** @description min value for number type control */
|
|
66
|
+
this.min = 0;
|
|
67
|
+
/** @description max value for number type control */
|
|
68
|
+
this.max = 0;
|
|
65
69
|
/**
|
|
66
70
|
* @description
|
|
67
71
|
* Holds the size of the component like Small, Extra small, Large
|
|
@@ -107,6 +111,7 @@ export class CideInputComponent {
|
|
|
107
111
|
this.onTouched = () => { };
|
|
108
112
|
/** @description Function to call when the input is need to Validate to tell Angular somthing is changed (in case of some input dipendent validation). */
|
|
109
113
|
this.onValidate = () => { };
|
|
114
|
+
// Modern Angular v20 pattern: Use constructor for initialization only
|
|
110
115
|
// Validate control
|
|
111
116
|
this.onValidate();
|
|
112
117
|
}
|
|
@@ -143,8 +148,9 @@ export class CideInputComponent {
|
|
|
143
148
|
/** @description when form control change from model side this method is implemented */
|
|
144
149
|
writeValue(value) {
|
|
145
150
|
if (!this.isNgModel) {
|
|
146
|
-
|
|
147
|
-
this.
|
|
151
|
+
const ngModel = this.autoCapitalizeByOption(value, this.type);
|
|
152
|
+
console.log('writeValue', this.ngModel, ngModel);
|
|
153
|
+
this.ngModel = ngModel;
|
|
148
154
|
}
|
|
149
155
|
}
|
|
150
156
|
/** @description Allows Angular to register a function to call when the model changes. */
|
|
@@ -186,6 +192,7 @@ export class CideInputComponent {
|
|
|
186
192
|
this.isControlValid(target?.value);
|
|
187
193
|
const updatedValue = this.processValue(target?.value, this.type);
|
|
188
194
|
this.ngModel = updatedValue;
|
|
195
|
+
this.ngModelChange?.emit(updatedValue);
|
|
189
196
|
// console.log(target)
|
|
190
197
|
this.onChange(updatedValue);
|
|
191
198
|
}
|
|
@@ -304,6 +311,9 @@ export class CideInputComponent {
|
|
|
304
311
|
this.trailingIconInternal = 'visibility_off';
|
|
305
312
|
}
|
|
306
313
|
}
|
|
314
|
+
else {
|
|
315
|
+
this.typeInternal = this.type;
|
|
316
|
+
}
|
|
307
317
|
}
|
|
308
318
|
/**
|
|
309
319
|
* Method to generate Random String
|
|
@@ -352,12 +362,12 @@ export class CideInputComponent {
|
|
|
352
362
|
this.isTrailingIconAllwedClick = true;
|
|
353
363
|
}
|
|
354
364
|
else {
|
|
355
|
-
this.typeInternal =
|
|
365
|
+
this.typeInternal = this.type;
|
|
356
366
|
this.trailingIconInternal = this.trailingIcon;
|
|
357
367
|
}
|
|
358
368
|
}
|
|
359
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideInputComponent, deps: [
|
|
360
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: CideInputComponent, isStandalone: true, selector: "cide-ele-input", inputs: { fill: "fill", label: "label", labelHide: "labelHide", disabled: "disabled", clearInput: "clearInput", labelPlacement: "labelPlacement", labelDir: "labelDir", placeholder: "placeholder", leadingIcon: "leadingIcon", trailingIcon: "trailingIcon", helperText: "helperText", helperTextCollapse: "helperTextCollapse", hideHelperAndErrorText: "hideHelperAndErrorText", errorText: "errorText", maxlength: "maxlength", minlength: "minlength", required: "required", autocapitalize: "autocapitalize", autocomplete: "autocomplete", type: "type", width: "width", id: "id", ngModel: "ngModel", option: "option", size: "size" }, outputs: { ngModelChange: "ngModelChange" }, providers: [
|
|
369
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
370
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: CideInputComponent, isStandalone: true, selector: "cide-ele-input", inputs: { fill: "fill", label: "label", labelHide: "labelHide", disabled: "disabled", clearInput: "clearInput", labelPlacement: "labelPlacement", labelDir: "labelDir", placeholder: "placeholder", leadingIcon: "leadingIcon", trailingIcon: "trailingIcon", helperText: "helperText", helperTextCollapse: "helperTextCollapse", hideHelperAndErrorText: "hideHelperAndErrorText", errorText: "errorText", maxlength: "maxlength", minlength: "minlength", required: "required", autocapitalize: "autocapitalize", autocomplete: "autocomplete", type: "type", width: "width", id: "id", ngModel: "ngModel", option: "option", min: "min", max: "max", size: "size" }, outputs: { ngModelChange: "ngModelChange" }, providers: [
|
|
361
371
|
{
|
|
362
372
|
provide: NG_VALUE_ACCESSOR,
|
|
363
373
|
useExisting: forwardRef(() => CideInputComponent),
|
|
@@ -370,11 +380,11 @@ export class CideInputComponent {
|
|
|
370
380
|
useExisting: forwardRef(() => CideInputComponent),
|
|
371
381
|
},
|
|
372
382
|
CapitalizePipe
|
|
373
|
-
], usesOnChanges: true, ngImport: i0, template: "<div class=\"cide-input\">\r\n <!------------------------------------------TEXT | PASSWORD------------------------------------------>\r\n <div *ngIf=\"type === 'text' || type === 'password'\">\r\n <div class=\"tw-w-full tw-relative\" [ngStyle]=\"{ width: width }\" [ngClass]=\"{\r\n 'cide-element-size-xxs': (size === '2xs'),\r\n 'cide-element-size-xs': (size === 'xs'),\r\n 'cide-element-size-sm': (size === 'sm'),\r\n 'cide-element-size-md': (size === 'md'),\r\n 'cide-element-size-lg': (size === 'lg'),\r\n 'cide-element-leading-icon': leadingIcon,\r\n 'cide-element-trailing-icon': trailingIconInternal,\r\n 'cide-element-clear-input': clearInput,\r\n 'cide-element-input-label-floating': (labelPlacement === 'floating'),\r\n 'cide-element-input-label-start': (labelDir === 'start'),\r\n 'cide-element-input-label-end': (labelDir === 'end'),\r\n 'cide-element-input-label-fixed': (labelPlacement === 'fixed'),\r\n 'cide-element-input-label-less': (!label || labelHide),\r\n 'cide-element-style-outline': (fill === 'outline'),\r\n 'cide-element-style-solid': (fill === 'solid'),\r\n 'cide-element-style-standard': (fill === 'standard'),\r\n }\">\r\n <!-- label -->\r\n <label [for]=\"id\" class=\"cide-input-label\" *ngIf=\"label && !labelHide\">{{label}}</label>\r\n\r\n <!-- all one line elemets which dose not affect with label and error text -->\r\n <div class=\"cide-element-input-wrapper\">\r\n <!-- Leading Icon -->\r\n <span class=\"cide-input-leading-icon-wrapper\" *ngIf=\"leadingIcon\">\r\n <span\r\n class=\"cide-input-leading-icon material-symbols-outlined tw-text-center\">{{leadingIcon}}</span>\r\n </span>\r\n\r\n <!-- Traling icon -->\r\n <span class=\"tw-absolute cide-input-trailing-icon -tw-bottom-1 tw-select-none tw-right-0\"\r\n *ngIf=\"trailingIconInternal\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"\r\n [ngClass]=\"{'tw-cursor-pointer': isTrailingIconAllwedClick}\" [attr.tabindex]=\"false\"\r\n (click)=\"trailingIconClick()\" (keyup)=\"trailingIconClick()\">{{trailingIconInternal}}</span>\r\n </span>\r\n\r\n <!-- Clear -->\r\n <button class=\"cide-input-clear\"\r\n *ngIf=\"clearInput && ngModel\" (click)=\"ClearInputValue()\">\r\n <span class=\"cide-input-clear-icon material-symbols-outlined\">close</span>\r\n </button>\r\n\r\n <!-- Input -->\r\n <input [placeholder]=\"placeholder\" [id]=\"id\"\r\n [ngClass]=\"[((label && labelPlacement === 'fixed') ? 'tw-rounded-e-md tw-rounded-es-md' : 'tw-rounded-md '), (!leadingIcon ? 'tw-pl-1' : ''), (trailingIconInternal ? 'tw-pr-8': ''), (!trailingIconInternal ? 'tw-pr-1' : ''), ((size === 'md') ? 'tw-h-8 tw-pt-0.5 tw-pb-0' : (size === 'sm' ? 'tw-h-7' : '')), (labelHide ? '!tw-mt-0' : '')]\"\r\n [(ngModel)]=\"ngModel\" [type]=\"typeInternal\" (input)=\"upDateValue($event)\" (focus)=\"focusControl()\"\r\n [autocomplete]=\"autocomplete\"\r\n class=\"tw-m-0 tw-w-full tw-bg-transparent tw-overflow-hidden tw-border-solid tw-p-0 cide-input-input tw-outline-none\" />\r\n </div>\r\n <!-- error text / helper text -->\r\n <span *ngIf=\"(errorText || helperText || !helperTextCollapse) && !hideHelperAndErrorText\"\r\n class=\"cide-input-help-error-text\">{{\r\n isValid\r\n ? helperText : (errorText ?\r\n (isTouched ? errorText : helperText)\r\n : helperText)}}</span>\r\n </div>\r\n </div>\r\n\r\n <!-- Input with tralling icon -->\r\n <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n <div class=\"tw-w-fullh-full tw-relative\">\r\n <label\r\n class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n <span class=\"tw-absolute -tw-bottom-px tw-right-0 -tw-z-10 tw-text-gray-400\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n </span>\r\n <input\r\n class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-1 tw-pr-8 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n value=\"Ankush Bhure\" />\r\n </div>\r\n </div> -->\r\n\r\n <!-- Input with leading icon -->\r\n <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n <div class=\"tw-w-fullh-full tw-relative\">\r\n <label\r\n class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n <span class=\"tw-absolute -tw-bottom-px tw-left-0 -tw-z-10 tw-text-gray-400\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n </span>\r\n <input\r\n class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-8 tw-pr-1 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n value=\"Ankush Bhure\" />\r\n </div>\r\n </div> -->\r\n\r\n <!------------------------------------------CHECKBOX------------------------------------------>\r\n <div *ngIf=\"type === 'checkbox'\" class=\"tw-flex\">\r\n <div class=\"cide-checkbox tw-relative\">\r\n <input [checked]=\"ngModel\" [value]=\"ngModel\" [id]=\"idRandom\" [type]=\"type\"\r\n class=\"tw-absolute tw-left-0 tw-invisible\" (click)=\"updateValueCheckBox(!ngModel); focusControl()\"\r\n [autocomplete]=\"autocomplete\" />\r\n <label class=\"cide-checkbox-label tw-cursor-pointer\" [for]=\"idRandom\">\r\n <span class=\"tw-border-2 tw-border-solid tw-relative tw-rounded-md\">\r\n <svg width=\"12px\" height=\"10px\" class=\"tw-absolute\">\r\n <use xlink:href=\"#sdfwiorfklasfjjalfjwerwr\"></use>\r\n </svg>\r\n </span>\r\n <span class=\"tw-text-sm tw-pl-2 tw-leading-[18px] tw-select-none tw-cursor-pointer\"\r\n *ngIf=\"!labelHide\">{{label}}</span>\r\n </label>\r\n <svg class=\"tw-absolute tw-h-0 tw-w-0 tw-select-none tw-pointer-events-none\">\r\n <!-- Element hidden and its xpath is used to display inside SVG -->\r\n <symbol id=\"sdfwiorfklasfjjalfjwerwr\" viewbox=\"0 0 12 10\">\r\n <polyline points=\"1.5 6 4.5 9 10.5 1\"></polyline>\r\n </symbol>\r\n </svg>\r\n </div>\r\n </div>\r\n\r\n <!-------------------------------------------SELECT------------------------------------------->\r\n <div *ngIf=\"type === 'select'\">sas\r\n <div class=\"tw-relative\">\r\n <div class=\"tw-absolute\">\r\n @for (item of option; track $index) {\r\n <div class=\"tw-w-full\">\r\n {{item}}\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".cide-element-style-standard .cide-input-input{border-color:transparent}.cide-element-input-wrapper{position:relative}.cide-input-label{color:var(--cide-input-label-color);-webkit-user-select:none;user-select:none;display:block}.cide-input-help-error-text{color:var(--cide-input-color-help-error-text);width:100%;display:block;margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:.125rem;padding-right:.125rem}.cide-input-leading-icon{color:var(--cide-input-leading-icon-color)}.cide-input-clear{color:var(--cide-input-clear-color);z-index:10;cursor:pointer;position:absolute;outline-width:0px;right:0;top:0}.cide-input-clear:hover{color:var(--cide-input-clear-color-hover)}.cide-input-trailing-icon{color:var(--cide-input-trailing-icon-color)}.cide-input-input{color:var(--cide-input-text-color);border-color:var(--cide-input-border)}.cide-input-input:hover{color:var(--cide-input-text-color-hover);border-color:var(--cide-input-border-hover)}.cide-input-input:focus{color:var(--cide-input-text-color-active);border-color:var(--cide-input-border-active)}.cide-element-input-label-floating .cide-input-label{position:absolute;z-index:1;margin-left:8px;margin-right:8px;background-color:#fff;padding:0 2px}.cide-element-input-label-floating .cide-element-input-label-start{left:0}.cide-element-input-label-floating .cide-element-input-label-start{right:0}.cide-element-input-label-fixed{margin-bottom:0}.cide-element-input-label-fixed .cide-element-input-label-start{text-align:start}.cide-element-input-label-fixed .cide-element-input-label-end{text-align:end}.ng-touched.ng-invalid>.cide-input .cide-input-clear{color:var(--cide-input-clear-color-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-clear:hover{color:var(--cide-input-clear-color-hover-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-leading-icon{color:var(--cide-input-leading-icon-color-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-help-error-text{color:var(--cide-input-color-help-error-text-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-trailing-icon{color:var(--cide-input-trailing-icon-color-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-label{color:var(--cide-input-label-color-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-input{color:var(--cide-input-text-color-invalid);border-color:var(--cide-input-border-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-input:hover{color:var(--cide-input-text-color-hover-invalid);border-color:var(--cide-input-border-hover-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-input:focus{color:var(--cide-input-text-color-active-invalid);border-color:var(--cide-input-border-active-invalid)}.cide-element-size-xxs .cide-input-input{height:var(--cide-element-size-xxs);font-size:var(--cide-input-size-xxs);border-width:var(--cide-input-border-size-xxs)}.cide-element-size-xxs .cide-input-label{font-size:var(--cide-input-label-size-xxs);line-height:var(--cide-input-label-size-xxs)}.cide-element-size-xxs .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-xxs);height:calc(var(--cide-input-error-helper-size-xxs) + 2px);line-height:var(--cide-input-error-helper-size-xxs)}.cide-element-size-xxs .cide-input-clear{top:var(--cide-input-border-size-xxs);width:var(--cide-element-size-xxs);height:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs) * 2)}.cide-element-size-xxs .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-xxs) + var(--cide-input-size-xxs) / 2);line-height:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs) * 2)}.cide-element-size-xxs .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-xxs);width:var(--cide-element-size-xxs);height:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs) * 2)}.cide-element-size-xxs .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-xxs) + var(--cide-input-size-xxs) / 2);line-height:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs) * 2)}.cide-element-size-xxs.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-xxs) / 2)}.cide-element-size-xxs.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-xxs) / 2 - var(--cide-input-label-size-xxs))}.cide-element-size-xxs.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs))}.cide-element-size-xxs.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs))}.cide-element-size-xxs.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-xxs)}.cide-element-size-xs .cide-input-input{height:var(--cide-element-size-xs);font-size:var(--cide-input-size-xs);border-width:var(--cide-input-border-size-xs)}.cide-element-size-xs .cide-input-label{font-size:var(--cide-input-label-size-xs);line-height:var(--cide-input-label-size-xs)}.cide-element-size-xs .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-xs);height:calc(var(--cide-input-error-helper-size-xs) + 2px);line-height:var(--cide-input-error-helper-size-xs)}.cide-element-size-xs .cide-input-clear{top:var(--cide-input-border-size-xs);width:var(--cide-element-size-xs);height:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs) * 2)}.cide-element-size-xs .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-xs) + var(--cide-input-size-xs) / 2);line-height:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs) * 2)}.cide-element-size-xs .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-xs);width:var(--cide-element-size-xs);height:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs) * 2)}.cide-element-size-xs .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-xs) + var(--cide-input-size-xs) / 2);line-height:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs) * 2)}.cide-element-size-xs.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-xs) / 2)}.cide-element-size-xs.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-xs) / 2 - var(--cide-input-label-size-xs))}.cide-element-size-xs.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs))}.cide-element-size-xs.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs))}.cide-element-size-xs.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-xs)}.cide-element-size-sm .cide-input-input{height:var(--cide-element-size-sm);font-size:var(--cide-input-size-sm);border-width:var(--cide-input-border-size-sm)}.cide-element-size-sm .cide-input-label{font-size:var(--cide-input-label-size-sm);line-height:var(--cide-input-label-size-sm)}.cide-element-size-sm .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-sm);height:calc(var(--cide-input-error-helper-size-sm) + 2px);line-height:var(--cide-input-error-helper-size-sm)}.cide-element-size-sm .cide-input-clear{top:var(--cide-input-border-size-sm);width:var(--cide-element-size-sm);height:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm) * 2)}.cide-element-size-sm .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-sm) + var(--cide-input-size-sm) / 2);line-height:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm) * 2)}.cide-element-size-sm .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-sm);width:var(--cide-element-size-sm);height:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm) * 2)}.cide-element-size-sm .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-sm) + var(--cide-input-size-sm) / 2);line-height:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm) * 2)}.cide-element-size-sm.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-sm) / 2)}.cide-element-size-sm.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-sm) / 2 - var(--cide-input-label-size-sm))}.cide-element-size-sm.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm))}.cide-element-size-sm.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm))}.cide-element-size-sm.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-sm)}.cide-element-size-md .cide-input-input{height:var(--cide-element-size-md);font-size:var(--cide-input-size-md);border-width:var(--cide-input-border-size-md)}.cide-element-size-md .cide-input-label{font-size:var(--cide-input-label-size-md);line-height:var(--cide-input-label-size-md)}.cide-element-size-md .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-md);height:calc(var(--cide-input-error-helper-size-md) + 2px);line-height:var(--cide-input-error-helper-size-md)}.cide-element-size-md .cide-input-clear{top:var(--cide-input-border-size-md);width:var(--cide-element-size-md);height:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md) * 2)}.cide-element-size-md .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-md) + var(--cide-input-size-md) / 2);line-height:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md) * 2)}.cide-element-size-md .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-md);width:var(--cide-element-size-md);height:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md) * 2)}.cide-element-size-md .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-md) + var(--cide-input-size-md) / 2);line-height:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md) * 2)}.cide-element-size-md.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-md) / 2)}.cide-element-size-md.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-md) / 2 - var(--cide-input-label-size-md))}.cide-element-size-md.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md))}.cide-element-size-md.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md))}.cide-element-size-md.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-md)}.cide-element-size-lg .cide-input-input{height:var(--cide-element-size-lg);font-size:var(--cide-input-size-lg);border-width:var(--cide-input-border-size-lg)}.cide-element-size-lg .cide-input-label{font-size:var(--cide-input-label-size-lg);line-height:var(--cide-input-label-size-lg)}.cide-element-size-lg .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-lg);height:calc(var(--cide-input-error-helper-size-lg) + 2px);line-height:var(--cide-input-error-helper-size-lg)}.cide-element-size-lg .cide-input-clear{top:var(--cide-input-border-size-lg);width:var(--cide-element-size-lg);height:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg) * 2)}.cide-element-size-lg .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-lg) + var(--cide-input-size-lg) / 2);line-height:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg) * 2)}.cide-element-size-lg .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-lg);width:var(--cide-element-size-lg);height:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg) * 2)}.cide-element-size-lg .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-lg) + var(--cide-input-size-lg) / 2);line-height:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg) * 2)}.cide-element-size-lg.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-lg) / 2)}.cide-element-size-lg.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-lg) / 2 - var(--cide-input-label-size-lg))}.cide-element-size-lg.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg))}.cide-element-size-lg.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg))}.cide-element-size-lg.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-lg)}.cide-element-size-xl .cide-input-input{height:var(--cide-element-size-xl);font-size:var(--cide-input-size-xl);border-width:var(--cide-input-border-size-xl)}.cide-element-size-xl .cide-input-label{font-size:var(--cide-input-label-size-xl);line-height:var(--cide-input-label-size-xl)}.cide-element-size-xl .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-xl);height:calc(var(--cide-input-error-helper-size-xl) + 2px);line-height:var(--cide-input-error-helper-size-xl)}.cide-element-size-xl .cide-input-clear{top:var(--cide-input-border-size-xl);width:var(--cide-element-size-xl);height:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl) * 2)}.cide-element-size-xl .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-xl) + var(--cide-input-size-xl) / 2);line-height:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl) * 2)}.cide-element-size-xl .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-xl);width:var(--cide-element-size-xl);height:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl) * 2)}.cide-element-size-xl .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-xl) + var(--cide-input-size-xl) / 2);line-height:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl) * 2)}.cide-element-size-xl.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-xl) / 2)}.cide-element-size-xl.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-xl) / 2 - var(--cide-input-label-size-xl))}.cide-element-size-xl.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl))}.cide-element-size-xl.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl))}.cide-element-size-xl.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-xl)}.cide-input-leading-icon-wrapper{position:absolute;bottom:0;left:0;z-index:-10;text-align:center}\n"], dependencies: [{ kind: "ngmodule", type:
|
|
383
|
+
], usesOnChanges: true, ngImport: i0, template: "<div class=\"cide-input\">\r\n <!------------------------------------------TEXT | PASSWORD------------------------------------------>\r\n <div *ngIf=\"type === 'text' || type === 'number' || type === 'password'\">\r\n <div class=\"tw-w-full tw-relative\" [ngStyle]=\"{ width: width }\" [ngClass]=\"{\r\n 'cide-element-size-xxs': (size === '2xs'),\r\n 'cide-element-size-xs': (size === 'xs'),\r\n 'cide-element-size-sm': (size === 'sm'),\r\n 'cide-element-size-md': (size === 'md'),\r\n 'cide-element-size-lg': (size === 'lg'),\r\n 'cide-element-leading-icon': leadingIcon,\r\n 'cide-element-trailing-icon': trailingIconInternal,\r\n 'cide-element-clear-input': clearInput,\r\n 'cide-element-input-label-floating': (labelPlacement === 'floating'),\r\n 'cide-element-input-label-start': (labelDir === 'start'),\r\n 'cide-element-input-label-end': (labelDir === 'end'),\r\n 'cide-element-input-label-fixed': (labelPlacement === 'fixed'),\r\n 'cide-element-input-label-less': (!label || labelHide),\r\n 'cide-element-style-outline': (fill === 'outline'),\r\n 'cide-element-style-solid': (fill === 'solid'),\r\n 'cide-element-style-standard': (fill === 'standard'),\r\n 'cide-element-input-number': (type === 'number')\r\n }\">\r\n <!-- label -->\r\n <label [for]=\"id\" class=\"cide-input-label\" *ngIf=\"label && !labelHide\">{{label}}</label>\r\n\r\n <!-- all one line elemets which dose not affect with label and error text -->\r\n <div class=\"cide-element-input-wrapper\">\r\n <!-- Leading Icon -->\r\n <span class=\"cide-input-leading-icon-wrapper\" *ngIf=\"leadingIcon\">\r\n <span\r\n class=\"cide-input-leading-icon material-symbols-outlined tw-text-center\">{{leadingIcon}}</span>\r\n </span>\r\n\r\n <!-- Traling icon -->\r\n <span class=\"tw-absolute cide-input-trailing-icon -tw-bottom-1 tw-select-none tw-right-0\"\r\n *ngIf=\"trailingIconInternal\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"\r\n [ngClass]=\"{'tw-cursor-pointer': isTrailingIconAllwedClick}\" [attr.tabindex]=\"false\"\r\n (click)=\"trailingIconClick()\" (keyup)=\"trailingIconClick()\">{{trailingIconInternal}}</span>\r\n </span>\r\n\r\n <!-- Clear -->\r\n <button class=\"cide-input-clear\"\r\n *ngIf=\"clearInput && ngModel\" (click)=\"ClearInputValue()\">\r\n <span class=\"cide-input-clear-icon material-symbols-outlined\">close</span>\r\n </button>\r\n\r\n <!-- Input -->\r\n <input [placeholder]=\"placeholder\" [id]=\"id\"\r\n [ngClass]=\"[((label && labelPlacement === 'fixed') ? 'tw-rounded-e-md tw-rounded-es-md' : 'tw-rounded-md '), (!leadingIcon ? 'tw-pl-1' : ''), (trailingIconInternal ? 'tw-pr-8': ''), (!trailingIconInternal ? 'tw-pr-1' : ''), ((size === 'md') ? 'tw-h-8 tw-pt-0.5 tw-pb-0' : (size === 'sm' ? 'tw-h-7' : '')), (labelHide ? '!tw-mt-0' : '')]\"\r\n [(ngModel)]=\"ngModel\" [type]=\"typeInternal\" (input)=\"upDateValue($event)\" (focus)=\"focusControl()\"\r\n [autocomplete]=\"autocomplete\" [min]=\"min\" [max]=\"max\"\r\n class=\"tw-m-0 tw-w-full tw-bg-transparent tw-overflow-hidden tw-border-solid tw-p-0 cide-input-input tw-outline-none\" />\r\n </div>\r\n <!-- error text / helper text -->\r\n <span *ngIf=\"(errorText || helperText || !helperTextCollapse) && !hideHelperAndErrorText\"\r\n class=\"cide-input-help-error-text\">{{\r\n isValid\r\n ? helperText : (errorText ?\r\n (isTouched ? errorText : helperText)\r\n : helperText)}}</span>\r\n </div>\r\n </div>\r\n\r\n <!-- Input with tralling icon -->\r\n <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n <div class=\"tw-w-fullh-full tw-relative\">\r\n <label\r\n class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n <span class=\"tw-absolute -tw-bottom-px tw-right-0 -tw-z-10 tw-text-gray-400\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n </span>\r\n <input\r\n class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-1 tw-pr-8 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n value=\"Ankush Bhure\" />\r\n </div>\r\n </div> -->\r\n\r\n <!-- Input with leading icon -->\r\n <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n <div class=\"tw-w-fullh-full tw-relative\">\r\n <label\r\n class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n <span class=\"tw-absolute -tw-bottom-px tw-left-0 -tw-z-10 tw-text-gray-400\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n </span>\r\n <input\r\n class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-8 tw-pr-1 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n value=\"Ankush Bhure\" />\r\n </div>\r\n </div> -->\r\n\r\n <!------------------------------------------CHECKBOX------------------------------------------>\r\n <div *ngIf=\"type === 'checkbox'\" class=\"tw-flex\">\r\n <div class=\"cide-checkbox tw-relative\">\r\n <input [checked]=\"ngModel\" [value]=\"ngModel\" [id]=\"idRandom\" [type]=\"type\"\r\n class=\"tw-absolute tw-left-0 tw-invisible\" (click)=\"updateValueCheckBox(!ngModel); focusControl()\"\r\n [autocomplete]=\"autocomplete\" />\r\n <label class=\"cide-checkbox-label tw-cursor-pointer\" [for]=\"idRandom\">\r\n <span class=\"tw-border-2 tw-border-solid tw-relative tw-rounded-md\">\r\n <svg width=\"12px\" height=\"10px\" class=\"tw-absolute\">\r\n <use xlink:href=\"#sdfwiorfklasfjjalfjwerwr\"></use>\r\n </svg>\r\n </span>\r\n <span class=\"tw-text-sm tw-pl-2 tw-leading-[18px] tw-select-none tw-cursor-pointer\"\r\n *ngIf=\"!labelHide\">{{label}}</span>\r\n </label>\r\n <svg class=\"tw-absolute tw-h-0 tw-w-0 tw-select-none tw-pointer-events-none\">\r\n <!-- Element hidden and its xpath is used to display inside SVG -->\r\n <symbol id=\"sdfwiorfklasfjjalfjwerwr\" viewbox=\"0 0 12 10\">\r\n <polyline points=\"1.5 6 4.5 9 10.5 1\"></polyline>\r\n </symbol>\r\n </svg>\r\n </div>\r\n </div>\r\n\r\n <!-------------------------------------------SELECT------------------------------------------->\r\n <div *ngIf=\"type === 'select'\">sas\r\n <div class=\"tw-relative\">\r\n <div class=\"tw-absolute\">\r\n @for (item of option; track $index) {\r\n <div class=\"tw-w-full\">\r\n {{item}}\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [""], dependencies: [{ kind: "ngmodule", type:
|
|
374
384
|
// directives
|
|
375
|
-
CommonModule }, { kind: "directive", type:
|
|
385
|
+
CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type:
|
|
376
386
|
// for ngModel
|
|
377
|
-
FormsModule }, { kind: "directive", type:
|
|
387
|
+
FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
|
378
388
|
}
|
|
379
389
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideInputComponent, decorators: [{
|
|
380
390
|
type: Component,
|
|
@@ -396,8 +406,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
396
406
|
useExisting: forwardRef(() => CideInputComponent),
|
|
397
407
|
},
|
|
398
408
|
CapitalizePipe
|
|
399
|
-
], template: "<div class=\"cide-input\">\r\n <!------------------------------------------TEXT | PASSWORD------------------------------------------>\r\n <div *ngIf=\"type === 'text' || type === 'password'\">\r\n <div class=\"tw-w-full tw-relative\" [ngStyle]=\"{ width: width }\" [ngClass]=\"{\r\n 'cide-element-size-xxs': (size === '2xs'),\r\n 'cide-element-size-xs': (size === 'xs'),\r\n 'cide-element-size-sm': (size === 'sm'),\r\n 'cide-element-size-md': (size === 'md'),\r\n 'cide-element-size-lg': (size === 'lg'),\r\n 'cide-element-leading-icon': leadingIcon,\r\n 'cide-element-trailing-icon': trailingIconInternal,\r\n 'cide-element-clear-input': clearInput,\r\n 'cide-element-input-label-floating': (labelPlacement === 'floating'),\r\n 'cide-element-input-label-start': (labelDir === 'start'),\r\n 'cide-element-input-label-end': (labelDir === 'end'),\r\n 'cide-element-input-label-fixed': (labelPlacement === 'fixed'),\r\n 'cide-element-input-label-less': (!label || labelHide),\r\n 'cide-element-style-outline': (fill === 'outline'),\r\n 'cide-element-style-solid': (fill === 'solid'),\r\n 'cide-element-style-standard': (fill === 'standard'),\r\n }\">\r\n <!-- label -->\r\n <label [for]=\"id\" class=\"cide-input-label\" *ngIf=\"label && !labelHide\">{{label}}</label>\r\n\r\n <!-- all one line elemets which dose not affect with label and error text -->\r\n <div class=\"cide-element-input-wrapper\">\r\n <!-- Leading Icon -->\r\n <span class=\"cide-input-leading-icon-wrapper\" *ngIf=\"leadingIcon\">\r\n <span\r\n class=\"cide-input-leading-icon material-symbols-outlined tw-text-center\">{{leadingIcon}}</span>\r\n </span>\r\n\r\n <!-- Traling icon -->\r\n <span class=\"tw-absolute cide-input-trailing-icon -tw-bottom-1 tw-select-none tw-right-0\"\r\n *ngIf=\"trailingIconInternal\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"\r\n [ngClass]=\"{'tw-cursor-pointer': isTrailingIconAllwedClick}\" [attr.tabindex]=\"false\"\r\n (click)=\"trailingIconClick()\" (keyup)=\"trailingIconClick()\">{{trailingIconInternal}}</span>\r\n </span>\r\n\r\n <!-- Clear -->\r\n <button class=\"cide-input-clear\"\r\n *ngIf=\"clearInput && ngModel\" (click)=\"ClearInputValue()\">\r\n <span class=\"cide-input-clear-icon material-symbols-outlined\">close</span>\r\n </button>\r\n\r\n <!-- Input -->\r\n <input [placeholder]=\"placeholder\" [id]=\"id\"\r\n [ngClass]=\"[((label && labelPlacement === 'fixed') ? 'tw-rounded-e-md tw-rounded-es-md' : 'tw-rounded-md '), (!leadingIcon ? 'tw-pl-1' : ''), (trailingIconInternal ? 'tw-pr-8': ''), (!trailingIconInternal ? 'tw-pr-1' : ''), ((size === 'md') ? 'tw-h-8 tw-pt-0.5 tw-pb-0' : (size === 'sm' ? 'tw-h-7' : '')), (labelHide ? '!tw-mt-0' : '')]\"\r\n [(ngModel)]=\"ngModel\" [type]=\"typeInternal\" (input)=\"upDateValue($event)\" (focus)=\"focusControl()\"\r\n [autocomplete]=\"autocomplete\"\r\n class=\"tw-m-0 tw-w-full tw-bg-transparent tw-overflow-hidden tw-border-solid tw-p-0 cide-input-input tw-outline-none\" />\r\n </div>\r\n <!-- error text / helper text -->\r\n <span *ngIf=\"(errorText || helperText || !helperTextCollapse) && !hideHelperAndErrorText\"\r\n class=\"cide-input-help-error-text\">{{\r\n isValid\r\n ? helperText : (errorText ?\r\n (isTouched ? errorText : helperText)\r\n : helperText)}}</span>\r\n </div>\r\n </div>\r\n\r\n <!-- Input with tralling icon -->\r\n <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n <div class=\"tw-w-fullh-full tw-relative\">\r\n <label\r\n class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n <span class=\"tw-absolute -tw-bottom-px tw-right-0 -tw-z-10 tw-text-gray-400\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n </span>\r\n <input\r\n class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-1 tw-pr-8 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n value=\"Ankush Bhure\" />\r\n </div>\r\n </div> -->\r\n\r\n <!-- Input with leading icon -->\r\n <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n <div class=\"tw-w-fullh-full tw-relative\">\r\n <label\r\n class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n <span class=\"tw-absolute -tw-bottom-px tw-left-0 -tw-z-10 tw-text-gray-400\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n </span>\r\n <input\r\n class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-8 tw-pr-1 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n value=\"Ankush Bhure\" />\r\n </div>\r\n </div> -->\r\n\r\n <!------------------------------------------CHECKBOX------------------------------------------>\r\n <div *ngIf=\"type === 'checkbox'\" class=\"tw-flex\">\r\n <div class=\"cide-checkbox tw-relative\">\r\n <input [checked]=\"ngModel\" [value]=\"ngModel\" [id]=\"idRandom\" [type]=\"type\"\r\n class=\"tw-absolute tw-left-0 tw-invisible\" (click)=\"updateValueCheckBox(!ngModel); focusControl()\"\r\n [autocomplete]=\"autocomplete\" />\r\n <label class=\"cide-checkbox-label tw-cursor-pointer\" [for]=\"idRandom\">\r\n <span class=\"tw-border-2 tw-border-solid tw-relative tw-rounded-md\">\r\n <svg width=\"12px\" height=\"10px\" class=\"tw-absolute\">\r\n <use xlink:href=\"#sdfwiorfklasfjjalfjwerwr\"></use>\r\n </svg>\r\n </span>\r\n <span class=\"tw-text-sm tw-pl-2 tw-leading-[18px] tw-select-none tw-cursor-pointer\"\r\n *ngIf=\"!labelHide\">{{label}}</span>\r\n </label>\r\n <svg class=\"tw-absolute tw-h-0 tw-w-0 tw-select-none tw-pointer-events-none\">\r\n <!-- Element hidden and its xpath is used to display inside SVG -->\r\n <symbol id=\"sdfwiorfklasfjjalfjwerwr\" viewbox=\"0 0 12 10\">\r\n <polyline points=\"1.5 6 4.5 9 10.5 1\"></polyline>\r\n </symbol>\r\n </svg>\r\n </div>\r\n </div>\r\n\r\n <!-------------------------------------------SELECT------------------------------------------->\r\n <div *ngIf=\"type === 'select'\">sas\r\n <div class=\"tw-relative\">\r\n <div class=\"tw-absolute\">\r\n @for (item of option; track $index) {\r\n <div class=\"tw-w-full\">\r\n {{item}}\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".cide-element-style-standard .cide-input-input{border-color:transparent}.cide-element-input-wrapper{position:relative}.cide-input-label{color:var(--cide-input-label-color);-webkit-user-select:none;user-select:none;display:block}.cide-input-help-error-text{color:var(--cide-input-color-help-error-text);width:100%;display:block;margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:.125rem;padding-right:.125rem}.cide-input-leading-icon{color:var(--cide-input-leading-icon-color)}.cide-input-clear{color:var(--cide-input-clear-color);z-index:10;cursor:pointer;position:absolute;outline-width:0px;right:0;top:0}.cide-input-clear:hover{color:var(--cide-input-clear-color-hover)}.cide-input-trailing-icon{color:var(--cide-input-trailing-icon-color)}.cide-input-input{color:var(--cide-input-text-color);border-color:var(--cide-input-border)}.cide-input-input:hover{color:var(--cide-input-text-color-hover);border-color:var(--cide-input-border-hover)}.cide-input-input:focus{color:var(--cide-input-text-color-active);border-color:var(--cide-input-border-active)}.cide-element-input-label-floating .cide-input-label{position:absolute;z-index:1;margin-left:8px;margin-right:8px;background-color:#fff;padding:0 2px}.cide-element-input-label-floating .cide-element-input-label-start{left:0}.cide-element-input-label-floating .cide-element-input-label-start{right:0}.cide-element-input-label-fixed{margin-bottom:0}.cide-element-input-label-fixed .cide-element-input-label-start{text-align:start}.cide-element-input-label-fixed .cide-element-input-label-end{text-align:end}.ng-touched.ng-invalid>.cide-input .cide-input-clear{color:var(--cide-input-clear-color-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-clear:hover{color:var(--cide-input-clear-color-hover-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-leading-icon{color:var(--cide-input-leading-icon-color-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-help-error-text{color:var(--cide-input-color-help-error-text-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-trailing-icon{color:var(--cide-input-trailing-icon-color-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-label{color:var(--cide-input-label-color-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-input{color:var(--cide-input-text-color-invalid);border-color:var(--cide-input-border-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-input:hover{color:var(--cide-input-text-color-hover-invalid);border-color:var(--cide-input-border-hover-invalid)}.ng-touched.ng-invalid>.cide-input .cide-input-input:focus{color:var(--cide-input-text-color-active-invalid);border-color:var(--cide-input-border-active-invalid)}.cide-element-size-xxs .cide-input-input{height:var(--cide-element-size-xxs);font-size:var(--cide-input-size-xxs);border-width:var(--cide-input-border-size-xxs)}.cide-element-size-xxs .cide-input-label{font-size:var(--cide-input-label-size-xxs);line-height:var(--cide-input-label-size-xxs)}.cide-element-size-xxs .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-xxs);height:calc(var(--cide-input-error-helper-size-xxs) + 2px);line-height:var(--cide-input-error-helper-size-xxs)}.cide-element-size-xxs .cide-input-clear{top:var(--cide-input-border-size-xxs);width:var(--cide-element-size-xxs);height:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs) * 2)}.cide-element-size-xxs .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-xxs) + var(--cide-input-size-xxs) / 2);line-height:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs) * 2)}.cide-element-size-xxs .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-xxs);width:var(--cide-element-size-xxs);height:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs) * 2)}.cide-element-size-xxs .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-xxs) + var(--cide-input-size-xxs) / 2);line-height:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs) * 2)}.cide-element-size-xxs.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-xxs) / 2)}.cide-element-size-xxs.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-xxs) / 2 - var(--cide-input-label-size-xxs))}.cide-element-size-xxs.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs))}.cide-element-size-xxs.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-xxs) - var(--cide-input-border-size-xxs))}.cide-element-size-xxs.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-xxs)}.cide-element-size-xs .cide-input-input{height:var(--cide-element-size-xs);font-size:var(--cide-input-size-xs);border-width:var(--cide-input-border-size-xs)}.cide-element-size-xs .cide-input-label{font-size:var(--cide-input-label-size-xs);line-height:var(--cide-input-label-size-xs)}.cide-element-size-xs .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-xs);height:calc(var(--cide-input-error-helper-size-xs) + 2px);line-height:var(--cide-input-error-helper-size-xs)}.cide-element-size-xs .cide-input-clear{top:var(--cide-input-border-size-xs);width:var(--cide-element-size-xs);height:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs) * 2)}.cide-element-size-xs .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-xs) + var(--cide-input-size-xs) / 2);line-height:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs) * 2)}.cide-element-size-xs .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-xs);width:var(--cide-element-size-xs);height:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs) * 2)}.cide-element-size-xs .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-xs) + var(--cide-input-size-xs) / 2);line-height:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs) * 2)}.cide-element-size-xs.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-xs) / 2)}.cide-element-size-xs.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-xs) / 2 - var(--cide-input-label-size-xs))}.cide-element-size-xs.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs))}.cide-element-size-xs.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-xs) - var(--cide-input-border-size-xs))}.cide-element-size-xs.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-xs)}.cide-element-size-sm .cide-input-input{height:var(--cide-element-size-sm);font-size:var(--cide-input-size-sm);border-width:var(--cide-input-border-size-sm)}.cide-element-size-sm .cide-input-label{font-size:var(--cide-input-label-size-sm);line-height:var(--cide-input-label-size-sm)}.cide-element-size-sm .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-sm);height:calc(var(--cide-input-error-helper-size-sm) + 2px);line-height:var(--cide-input-error-helper-size-sm)}.cide-element-size-sm .cide-input-clear{top:var(--cide-input-border-size-sm);width:var(--cide-element-size-sm);height:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm) * 2)}.cide-element-size-sm .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-sm) + var(--cide-input-size-sm) / 2);line-height:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm) * 2)}.cide-element-size-sm .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-sm);width:var(--cide-element-size-sm);height:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm) * 2)}.cide-element-size-sm .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-sm) + var(--cide-input-size-sm) / 2);line-height:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm) * 2)}.cide-element-size-sm.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-sm) / 2)}.cide-element-size-sm.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-sm) / 2 - var(--cide-input-label-size-sm))}.cide-element-size-sm.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm))}.cide-element-size-sm.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-sm) - var(--cide-input-border-size-sm))}.cide-element-size-sm.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-sm)}.cide-element-size-md .cide-input-input{height:var(--cide-element-size-md);font-size:var(--cide-input-size-md);border-width:var(--cide-input-border-size-md)}.cide-element-size-md .cide-input-label{font-size:var(--cide-input-label-size-md);line-height:var(--cide-input-label-size-md)}.cide-element-size-md .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-md);height:calc(var(--cide-input-error-helper-size-md) + 2px);line-height:var(--cide-input-error-helper-size-md)}.cide-element-size-md .cide-input-clear{top:var(--cide-input-border-size-md);width:var(--cide-element-size-md);height:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md) * 2)}.cide-element-size-md .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-md) + var(--cide-input-size-md) / 2);line-height:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md) * 2)}.cide-element-size-md .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-md);width:var(--cide-element-size-md);height:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md) * 2)}.cide-element-size-md .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-md) + var(--cide-input-size-md) / 2);line-height:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md) * 2)}.cide-element-size-md.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-md) / 2)}.cide-element-size-md.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-md) / 2 - var(--cide-input-label-size-md))}.cide-element-size-md.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md))}.cide-element-size-md.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-md) - var(--cide-input-border-size-md))}.cide-element-size-md.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-md)}.cide-element-size-lg .cide-input-input{height:var(--cide-element-size-lg);font-size:var(--cide-input-size-lg);border-width:var(--cide-input-border-size-lg)}.cide-element-size-lg .cide-input-label{font-size:var(--cide-input-label-size-lg);line-height:var(--cide-input-label-size-lg)}.cide-element-size-lg .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-lg);height:calc(var(--cide-input-error-helper-size-lg) + 2px);line-height:var(--cide-input-error-helper-size-lg)}.cide-element-size-lg .cide-input-clear{top:var(--cide-input-border-size-lg);width:var(--cide-element-size-lg);height:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg) * 2)}.cide-element-size-lg .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-lg) + var(--cide-input-size-lg) / 2);line-height:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg) * 2)}.cide-element-size-lg .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-lg);width:var(--cide-element-size-lg);height:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg) * 2)}.cide-element-size-lg .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-lg) + var(--cide-input-size-lg) / 2);line-height:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg) * 2)}.cide-element-size-lg.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-lg) / 2)}.cide-element-size-lg.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-lg) / 2 - var(--cide-input-label-size-lg))}.cide-element-size-lg.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg))}.cide-element-size-lg.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-lg) - var(--cide-input-border-size-lg))}.cide-element-size-lg.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-lg)}.cide-element-size-xl .cide-input-input{height:var(--cide-element-size-xl);font-size:var(--cide-input-size-xl);border-width:var(--cide-input-border-size-xl)}.cide-element-size-xl .cide-input-label{font-size:var(--cide-input-label-size-xl);line-height:var(--cide-input-label-size-xl)}.cide-element-size-xl .cide-input-help-error-text{font-size:var(--cide-input-error-helper-size-xl);height:calc(var(--cide-input-error-helper-size-xl) + 2px);line-height:var(--cide-input-error-helper-size-xl)}.cide-element-size-xl .cide-input-clear{top:var(--cide-input-border-size-xl);width:var(--cide-element-size-xl);height:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl) * 2)}.cide-element-size-xl .cide-input-clear .cide-input-clear-icon{font-size:calc(var(--cide-input-size-xl) + var(--cide-input-size-xl) / 2);line-height:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl) * 2)}.cide-element-size-xl .cide-input-leading-icon-wrapper{top:var(--cide-input-border-size-xl);width:var(--cide-element-size-xl);height:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl) * 2)}.cide-element-size-xl .cide-input-leading-icon-wrapper .cide-input-leading-icon{font-size:calc(var(--cide-input-size-xl) + var(--cide-input-size-xl) / 2);line-height:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl) * 2)}.cide-element-size-xl.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-element-input-wrapper{margin-top:calc(var(--cide-input-label-size-xl) / 2)}.cide-element-size-xl.cide-element-input-label-floating:not(.cide-element-input-label-less) .cide-input-label{top:calc(var(--cide-input-label-size-xl) / 2 - var(--cide-input-label-size-xl))}.cide-element-size-xl.cide-element-leading-icon .cide-input-input{padding-left:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl))}.cide-element-size-xl.cide-element-clear-input .cide-input-input{padding-right:calc(var(--cide-element-size-xl) - var(--cide-input-border-size-xl))}.cide-element-size-xl.cide-element-trailing-icon .cide-input-clear{right:var(--cide-element-size-xl)}.cide-input-leading-icon-wrapper{position:absolute;bottom:0;left:0;z-index:-10;text-align:center}\n"] }]
|
|
400
|
-
}], ctorParameters: () => [
|
|
409
|
+
], template: "<div class=\"cide-input\">\r\n <!------------------------------------------TEXT | PASSWORD------------------------------------------>\r\n <div *ngIf=\"type === 'text' || type === 'number' || type === 'password'\">\r\n <div class=\"tw-w-full tw-relative\" [ngStyle]=\"{ width: width }\" [ngClass]=\"{\r\n 'cide-element-size-xxs': (size === '2xs'),\r\n 'cide-element-size-xs': (size === 'xs'),\r\n 'cide-element-size-sm': (size === 'sm'),\r\n 'cide-element-size-md': (size === 'md'),\r\n 'cide-element-size-lg': (size === 'lg'),\r\n 'cide-element-leading-icon': leadingIcon,\r\n 'cide-element-trailing-icon': trailingIconInternal,\r\n 'cide-element-clear-input': clearInput,\r\n 'cide-element-input-label-floating': (labelPlacement === 'floating'),\r\n 'cide-element-input-label-start': (labelDir === 'start'),\r\n 'cide-element-input-label-end': (labelDir === 'end'),\r\n 'cide-element-input-label-fixed': (labelPlacement === 'fixed'),\r\n 'cide-element-input-label-less': (!label || labelHide),\r\n 'cide-element-style-outline': (fill === 'outline'),\r\n 'cide-element-style-solid': (fill === 'solid'),\r\n 'cide-element-style-standard': (fill === 'standard'),\r\n 'cide-element-input-number': (type === 'number')\r\n }\">\r\n <!-- label -->\r\n <label [for]=\"id\" class=\"cide-input-label\" *ngIf=\"label && !labelHide\">{{label}}</label>\r\n\r\n <!-- all one line elemets which dose not affect with label and error text -->\r\n <div class=\"cide-element-input-wrapper\">\r\n <!-- Leading Icon -->\r\n <span class=\"cide-input-leading-icon-wrapper\" *ngIf=\"leadingIcon\">\r\n <span\r\n class=\"cide-input-leading-icon material-symbols-outlined tw-text-center\">{{leadingIcon}}</span>\r\n </span>\r\n\r\n <!-- Traling icon -->\r\n <span class=\"tw-absolute cide-input-trailing-icon -tw-bottom-1 tw-select-none tw-right-0\"\r\n *ngIf=\"trailingIconInternal\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"\r\n [ngClass]=\"{'tw-cursor-pointer': isTrailingIconAllwedClick}\" [attr.tabindex]=\"false\"\r\n (click)=\"trailingIconClick()\" (keyup)=\"trailingIconClick()\">{{trailingIconInternal}}</span>\r\n </span>\r\n\r\n <!-- Clear -->\r\n <button class=\"cide-input-clear\"\r\n *ngIf=\"clearInput && ngModel\" (click)=\"ClearInputValue()\">\r\n <span class=\"cide-input-clear-icon material-symbols-outlined\">close</span>\r\n </button>\r\n\r\n <!-- Input -->\r\n <input [placeholder]=\"placeholder\" [id]=\"id\"\r\n [ngClass]=\"[((label && labelPlacement === 'fixed') ? 'tw-rounded-e-md tw-rounded-es-md' : 'tw-rounded-md '), (!leadingIcon ? 'tw-pl-1' : ''), (trailingIconInternal ? 'tw-pr-8': ''), (!trailingIconInternal ? 'tw-pr-1' : ''), ((size === 'md') ? 'tw-h-8 tw-pt-0.5 tw-pb-0' : (size === 'sm' ? 'tw-h-7' : '')), (labelHide ? '!tw-mt-0' : '')]\"\r\n [(ngModel)]=\"ngModel\" [type]=\"typeInternal\" (input)=\"upDateValue($event)\" (focus)=\"focusControl()\"\r\n [autocomplete]=\"autocomplete\" [min]=\"min\" [max]=\"max\"\r\n class=\"tw-m-0 tw-w-full tw-bg-transparent tw-overflow-hidden tw-border-solid tw-p-0 cide-input-input tw-outline-none\" />\r\n </div>\r\n <!-- error text / helper text -->\r\n <span *ngIf=\"(errorText || helperText || !helperTextCollapse) && !hideHelperAndErrorText\"\r\n class=\"cide-input-help-error-text\">{{\r\n isValid\r\n ? helperText : (errorText ?\r\n (isTouched ? errorText : helperText)\r\n : helperText)}}</span>\r\n </div>\r\n </div>\r\n\r\n <!-- Input with tralling icon -->\r\n <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n <div class=\"tw-w-fullh-full tw-relative\">\r\n <label\r\n class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n <span class=\"tw-absolute -tw-bottom-px tw-right-0 -tw-z-10 tw-text-gray-400\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n </span>\r\n <input\r\n class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-1 tw-pr-8 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n value=\"Ankush Bhure\" />\r\n </div>\r\n </div> -->\r\n\r\n <!-- Input with leading icon -->\r\n <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n <div class=\"tw-w-fullh-full tw-relative\">\r\n <label\r\n class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n <span class=\"tw-absolute -tw-bottom-px tw-left-0 -tw-z-10 tw-text-gray-400\">\r\n <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n </span>\r\n <input\r\n class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-8 tw-pr-1 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n value=\"Ankush Bhure\" />\r\n </div>\r\n </div> -->\r\n\r\n <!------------------------------------------CHECKBOX------------------------------------------>\r\n <div *ngIf=\"type === 'checkbox'\" class=\"tw-flex\">\r\n <div class=\"cide-checkbox tw-relative\">\r\n <input [checked]=\"ngModel\" [value]=\"ngModel\" [id]=\"idRandom\" [type]=\"type\"\r\n class=\"tw-absolute tw-left-0 tw-invisible\" (click)=\"updateValueCheckBox(!ngModel); focusControl()\"\r\n [autocomplete]=\"autocomplete\" />\r\n <label class=\"cide-checkbox-label tw-cursor-pointer\" [for]=\"idRandom\">\r\n <span class=\"tw-border-2 tw-border-solid tw-relative tw-rounded-md\">\r\n <svg width=\"12px\" height=\"10px\" class=\"tw-absolute\">\r\n <use xlink:href=\"#sdfwiorfklasfjjalfjwerwr\"></use>\r\n </svg>\r\n </span>\r\n <span class=\"tw-text-sm tw-pl-2 tw-leading-[18px] tw-select-none tw-cursor-pointer\"\r\n *ngIf=\"!labelHide\">{{label}}</span>\r\n </label>\r\n <svg class=\"tw-absolute tw-h-0 tw-w-0 tw-select-none tw-pointer-events-none\">\r\n <!-- Element hidden and its xpath is used to display inside SVG -->\r\n <symbol id=\"sdfwiorfklasfjjalfjwerwr\" viewbox=\"0 0 12 10\">\r\n <polyline points=\"1.5 6 4.5 9 10.5 1\"></polyline>\r\n </symbol>\r\n </svg>\r\n </div>\r\n </div>\r\n\r\n <!-------------------------------------------SELECT------------------------------------------->\r\n <div *ngIf=\"type === 'select'\">sas\r\n <div class=\"tw-relative\">\r\n <div class=\"tw-absolute\">\r\n @for (item of option; track $index) {\r\n <div class=\"tw-w-full\">\r\n {{item}}\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n</div>" }]
|
|
410
|
+
}], ctorParameters: () => [], propDecorators: { fill: [{
|
|
401
411
|
type: Input
|
|
402
412
|
}], label: [{
|
|
403
413
|
type: Input
|
|
@@ -445,9 +455,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
445
455
|
type: Input
|
|
446
456
|
}], option: [{
|
|
447
457
|
type: Input
|
|
458
|
+
}], min: [{
|
|
459
|
+
type: Input
|
|
460
|
+
}], max: [{
|
|
461
|
+
type: Input
|
|
448
462
|
}], size: [{
|
|
449
463
|
type: Input
|
|
450
464
|
}], ngModelChange: [{
|
|
451
465
|
type: Output
|
|
452
466
|
}] } });
|
|
453
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/cloud-ide-element/src/lib/elements/input/input.component.ts","../../../../../../projects/cloud-ide-element/src/lib/elements/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, forwardRef } from '@angular/core';\r\nimport { AbstractControl, ControlValueAccessor, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from '@angular/forms';\r\nimport { CapitalizePipe } from '../../utils/pipes/capitalize/capitalize.pipe';\r\nimport { CideElementsService } from '../../utils/services/elements/elements.service';\r\nimport { autocapitalizeType, autocompleteType, controlType, elementStyleType, inputType, labelDirType, labelPlacementType, themeSize } from 'cloud-ide-lms-model';\r\n\r\n/** @description type to register error related to control */\r\nexport type ErrorValidationStatus = {\r\n  maxlength?: string,\r\n  minlength?: string,\r\n  required?: string,\r\n}\r\nexport type ValidationStatus = {\r\n  validation: ErrorValidationStatus,\r\n  status: boolean\r\n}\r\n\r\n@Component({\r\n  selector: 'cide-ele-input',\r\n  standalone: true,\r\n  templateUrl: './input.component.html',\r\n  styleUrl: './input.component.scss',\r\n  imports: [\r\n    // directives\r\n    CommonModule,\r\n    // for ngModel\r\n    FormsModule\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => CideInputComponent),\r\n      multi: true\r\n    },\r\n    /** @description to apply validations  */\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      multi: true,\r\n      useExisting: forwardRef(() => CideInputComponent),\r\n    },\r\n    CapitalizePipe\r\n  ]\r\n})\r\n\r\nexport class CideInputComponent implements ControlValueAccessor, Validator, OnChanges, OnInit {\r\n\r\n  constructor(public capitalizePipe: CapitalizePipe, private elementService: CideElementsService) {\r\n    // Validate control\r\n    this.onValidate();\r\n  }\r\n  /*=======Set custom controls inputs to set components=========*/\r\n\r\n  /** \r\n   * @description to se the visual of control like solid control offerd by material design or outline with a border\r\n   * @options solid | outline | standard\r\n   */\r\n  @Input() fill: elementStyleType = 'outline';\r\n  /** @description Lable of control (Title), Like Name, Email */\r\n  @Input() label: string = \"\";\r\n  /** @description to hide and show label */\r\n  @Input() labelHide: boolean = false;\r\n  /** @description is control Editable or Disabled */\r\n  @Input() disabled: boolean = false;\r\n  /** @description Is Clear Input Cross button is visible or not */\r\n  @Input() clearInput: boolean = false;\r\n  /** @description Position of Label 'floating' | 'fixed' */\r\n  @Input() labelPlacement: labelPlacementType = \"fixed\";\r\n  /** @description Lable direction from start of contrl or end of control */\r\n  @Input() labelDir: labelDirType = \"start\";\r\n  /** @description Place holder for control to display if there is no value */\r\n  @Input() placeholder: string = \"\";\r\n  /** @description it is to set leading icon, at the start of control  */\r\n  @Input() leadingIcon: string = \"\";\r\n  /** @description it is to set trailing icon, at the end of control, for password type control eye is the trailing icon  */\r\n  @Input() trailingIcon: string = \"\";\r\n  /** @description to display below the control for suggestion, if there is any error then error will bw the first to shoe in place of help text */\r\n  @Input() helperText: string = \"\";\r\n  /** @description default true to collapse when there is no help text or error text, if false then element area in DOM will be reserved never detroy  */\r\n  @Input() helperTextCollapse: boolean = true;\r\n  /** @description show and hide helper text its forecfull */\r\n  @Input() hideHelperAndErrorText: boolean = false;\r\n  /** @description if found any error in control the error thext will be used to display error message, if there is help text still error text is having higher priority then helptext */\r\n  @Input() errorText: string = \"\";\r\n  /** @description maxlength for control */\r\n  @Input() maxlength: number = 0;\r\n  /** @description minlength for control */\r\n  @Input() minlength: number = 0;\r\n  /** @description is control is required or not input type is true | false */\r\n  @Input() required: boolean = false;\r\n  /** @description Auto capatalization for the value and applicable to word or to complete sentance */\r\n  @Input() autocapitalize: autocapitalizeType = \"off\";\r\n  /** @description auto complete type to help reader what is the type of value */\r\n  @Input() autocomplete: autocompleteType = \"off\";\r\n  /** @description type of control */\r\n  @Input() type: controlType = '';\r\n  /** @description width of control, default width is 100% */\r\n  @Input() width: string = '100%';\r\n  /** @description uniq id of control, used to differenciat the value also prevent value should not effect another values */\r\n  @Input() id: string = '';\r\n  /** @description to get input value using one way binding like: [ngModel] or by two way binding [(ngModel)] */\r\n  @Input() ngModel: inputType = '';\r\n  @Input() option: string[] = [\"anksuh\", \"bhure\"]\r\n  /**\r\n   * @description\r\n   * Holds the size of the component like Small, Extra small, Large\r\n   * by Default it takes small size\r\n   * or the size set by the project setup service\r\n   * or it will beset for individual component\r\n   * \r\n   * Size Appled \r\n   * Component level then setup service then finally default md\r\n   *  Options: \"2xs\" | \"\"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | \"xxl\" \r\n   */\r\n  @Input() size: themeSize = \"sm\";\r\n  /** @description to set return value using one way binding like: (ngModelChanges) or by two way binding [(ngModel)] */\r\n  @Output() ngModelChange: EventEmitter<inputType> = new EventEmitter<inputType>();\r\n\r\n  /*\r\n      internal Properties for input\r\n  */\r\n  /** @description is vale need to read from ngModel or from value(need to implement), it is detected and maild fals on value chnages */\r\n  public isNgModel: boolean = this.ngModel ? true : false;\r\n  /** @description this is to set control value is valid or not, set by us inside validate callbck method called by angular  */\r\n  public isValid: boolean = true;\r\n  /** @description when control is touched then the will maid true by the us to check it is touched or not, when we will set this true we will call the onTouched callback method of angualr to inform angular that somthis is changed and control is touched */\r\n  public isTouched: boolean = false;\r\n  /** @description we will take type of control in type but is may be not exactly which input's type so we need to get type and set actule type to our input, also when type is set password but in calse view in textt then inuut type need to change to text */\r\n  public typeInternal: \"text\" | \"password\" = \"text\";\r\n  /** @description if traling is set the it is assigned by it, but some case tarling icon not as it is set need tro be changed at runtime, like password visibility hide and show */\r\n  public trailingIconInternal: string = \"\";\r\n\r\n  /* \r\n      Properties connected with trailingIconInternal \r\n  */\r\n  public isTrailingIconAllwedClick: boolean = false;\r\n\r\n  // Properties connected with id\r\n  public idRandom: string = this.randomString();\r\n\r\n  // ==================================METHODS FOR CUSTOM FORM COMPONENT=============================\r\n  // FOR ANGULAR CALLED BY UI\r\n\r\n  /** \r\n   * @description Function to call when the HTML Chnage to tell Angular somthing is changed.\r\n   * @field value : inputType\r\n   */\r\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n  private onChange = (value: inputType) => { };\r\n\r\n  /** @description Function to call when the input is touched (clciked) to tell Angular somthing is changed. */\r\n  onTouched = () => { };\r\n\r\n  /** @description Function to call when the input is need to Validate to tell Angular somthing is changed (in case of some input dipendent validation). */\r\n  onValidate = () => { };\r\n\r\n  /**\r\n   * @description\r\n   * Method that performs synchronous validation against the provided control.\r\n   * Exicuted by Angular\r\n   *\r\n   * @param control The control to validate against.\r\n   *\r\n   * @returns A map of validation errors if validation fails,\r\n   * otherwise null.\r\n   */\r\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n  validate(control: AbstractControl): ValidationErrors | null {\r\n    const validation_error = this.isControlValid(this.ngModel);\r\n    if (validation_error?.status) {\r\n      return validation_error;\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n  /**\r\n   * @description\r\n   * Registers a callback function to call when the validator inputs change.\r\n   * Exicuted by Angular\r\n   *\r\n   * @param fn The callback function\r\n   */\r\n  registerOnValidatorChange?(fn: () => void): void {\r\n    this.onValidate = fn;\r\n  }\r\n\r\n  /** @description when form control change from model side this method is implemented  */\r\n  writeValue(value: inputType): void {\r\n    if (!this.isNgModel) {\r\n      this.ngModel = this.autoCapitalizeByOption(value, this.type);\r\n      this.ngModelChange?.emit(value);\r\n    }\r\n  }\r\n  /** @description Allows Angular to register a function to call when the model changes. */\r\n  // Save the function as a property to call later here.\r\n  registerOnChange(fn: (value: inputType) => void): void {\r\n    this.onChange = fn;\r\n  }\r\n  /** @description Allows Angular to register a function to call when the input has been touched. */\r\n  // Save the function as a property to call later here.\r\n  registerOnTouched(fn: () => void): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  //==========================================================================\r\n\r\n  /*\r\n    Methods for input\r\n*/\r\n\r\n  /** @description Detect wether input propertires canged or not */\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes?.['value']) {\r\n      this.isNgModel = true;\r\n      this.ngModel = this.processValue(this.ngModel, this.type);\r\n    }\r\n    if (this.isValidValueAndType(this.ngModel, this.type) || this.isTouched) {\r\n      this.isControlValid(this.ngModel);\r\n    }\r\n\r\n    // Ditect type change\r\n    if (changes?.['type']) {\r\n      this.detectTypeChange();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.id) {\r\n      this.getControlData();\r\n    }\r\n  }\r\n\r\n  /** @description custom method run when HTML changes, we call method registerd by angular to detect change */\r\n  upDateValue(value: { target: { value: inputType } } | Event) {\r\n    const target = value.target as HTMLInputElement | { value: inputType };\r\n    this.isControlValid(target?.value);\r\n    const updatedValue = this.processValue(target?.value, this.type);\r\n    this.ngModel = updatedValue;\r\n    // console.log(target)\r\n    this.onChange(updatedValue);\r\n  }\r\n\r\n  /**\r\n   * @description method applicable in case of control type checkbox\r\n   * \r\n   * @param value boolean | string\r\n   */\r\n  updateValueCheckBox(value: string | boolean) {\r\n    // Convert string to boolean\r\n    this.ngModel = !this.ngModel;\r\n    value = (typeof value === 'boolean') ? value : (value === 'true' ? true : false);\r\n    this.ngModelChange?.emit(value);\r\n    this.onChange(value);\r\n  }\r\n\r\n  /** @description clear the value */\r\n  ClearInputValue() {\r\n    if (this.type == \"text\") {\r\n      this.upDateValue({ target: { value: \"\" } });\r\n    }\r\n  }\r\n\r\n  /** @description when HTML is focuesd */\r\n  focusControl() {\r\n    this.isTouched = true;\r\n    this.onTouched();\r\n    this.onValidate();\r\n  }\r\n\r\n  /** @description If control value need to be processed, like UPPERCASE */\r\n  processValue(value: inputType, type: controlType) {\r\n    value = this.autoCapitalizeByOption(value, type);\r\n    return value;\r\n  }\r\n\r\n  /** @description for capitalization */\r\n  autoCapitalizeByOption(value: inputType, type: controlType) {\r\n    if (type == 'text') {\r\n      if (this.autocapitalize == \"on\") {\r\n        return this.capitalizePipe?.transform(value as string, 'allUpperCase');\r\n      }\r\n      if (this.autocapitalize == \"words\") {\r\n        return this.capitalizePipe?.transform(value as string, 'titleCase');\r\n      }\r\n      if (this.autocapitalize == \"sentences\") {\r\n        return this.capitalizePipe?.transform(value as string, \"sentenceCase\");\r\n      }\r\n    }\r\n    return value;\r\n  }\r\n\r\n  /** @description It is used to return the value is valid or not */\r\n  isValidValueAndType(value: inputType, type: controlType) {\r\n    if (type == 'text') {\r\n      if (typeof (value) == 'string') {\r\n        if (value?.length > 0) {\r\n          return true;\r\n        } else {\r\n          return false;\r\n        }\r\n      } else {\r\n        return false;\r\n      }\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  /** @description to check control is valid or not */\r\n  isControlValid(value: inputType): ValidationStatus {\r\n    const validation_status: ValidationStatus = {\r\n      validation: {},\r\n      status: false\r\n    };\r\n\r\n    if (this.required) {\r\n      if (!value) {\r\n        validation_status.status = true;\r\n        validation_status.validation.required = `required!`;\r\n      }\r\n    }\r\n\r\n    if (this.type == 'text') {\r\n      if (typeof (value) == 'string') {\r\n        if (this.maxlength > 0) {\r\n          if (value?.length > this.maxlength) {\r\n            validation_status.status = true;\r\n            validation_status.validation.maxlength = `maximum length is ${this.maxlength}!`;\r\n          }\r\n        }\r\n        if (this.minlength > 0) {\r\n          if (value?.length < this.minlength) {\r\n            validation_status.status = true;\r\n            validation_status.validation.minlength = `minimum length is ${this.minlength}!`;\r\n          }\r\n        }\r\n      } else {\r\n        validation_status.status = true;\r\n        validation_status.validation.required = `required!`;\r\n      }\r\n    }\r\n    this.isValid = !validation_status.status;\r\n    this.errorText = Object.values(validation_status.validation).at(0) || ''\r\n    return validation_status;\r\n  }\r\n\r\n  /** @description Allows Angular to disable the input. */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  /** @description Method for trailing Icon Click */\r\n  trailingIconClick() {\r\n    if (this.type === 'password') {\r\n      if (this.typeInternal === 'password') {\r\n        this.typeInternal = 'text';\r\n        this.trailingIconInternal = 'visibility';\r\n      } else {\r\n        this.typeInternal = 'password';\r\n        this.trailingIconInternal = 'visibility_off';\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Method to generate Random String\r\n   * @param setupPrarameter { lenght: number, prefix: string }\r\n   * default lenght is 10, prefox is \"\"\r\n   * @returns string\r\n   */\r\n  randomString(setupPrarameter: { lenght: number, prefix: string } = { lenght: 10, prefix: \"\" }): string {\r\n    //variable consisting alphabets in small and capital letter  \r\n    const characters = \"ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz\";\r\n    //loop to select a new character in each iteration  \r\n    let random_string = setupPrarameter?.prefix || \"\";\r\n    for (let i = 0; i < setupPrarameter?.lenght; i++) {\r\n      const rnum = Math.floor(Math.random() * characters.length);\r\n      random_string += characters.substring(rnum, rnum + 1);\r\n    }\r\n    //return the generated string  \r\n    return random_string;\r\n  }\r\n\r\n  async getControlData() {\r\n    const cide_element_data = await this.elementService?.getElementData({ sype_key: this.id });\r\n    if (cide_element_data) {\r\n      this.label = cide_element_data?.sype_label as string;\r\n      this.labelPlacement = (cide_element_data?.sype_label_placement || 'floating') as labelPlacementType;\r\n      this.type = (cide_element_data?.sype_type || 'text') as controlType;\r\n      this.required = (cide_element_data?.sype_required || false) as boolean;\r\n      this.size = (cide_element_data?.sype_size || 'md') as themeSize;\r\n      this.helperTextCollapse = (cide_element_data?.sype_helper_text_collapse || false) as boolean;\r\n      this.maxlength = (cide_element_data?.sype_max_length) as number;\r\n      this.minlength = (cide_element_data?.sype_min_length) as number;\r\n      this.leadingIcon = (cide_element_data?.sype_leading_icon) as string;\r\n      this.labelHide = (cide_element_data?.sype_label_hide) as boolean;\r\n      this.hideHelperAndErrorText = (cide_element_data?.sype_hide_helper_and_error_text) as boolean;\r\n      this.detectTypeChange();\r\n      // Validate control\r\n      this.onValidate();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @description use to detact the change in type if changes done this method is ued to run\r\n   */\r\n  detectTypeChange() {\r\n    if (this.type === 'password') {\r\n      this.typeInternal = \"password\";\r\n      this.trailingIconInternal = \"visibility_off\";\r\n      this.isTrailingIconAllwedClick = true;\r\n    } else {\r\n      this.typeInternal = \"text\";\r\n      this.trailingIconInternal = this.trailingIcon;\r\n    }\r\n  }\r\n}\r\n","<div class=\"cide-input\">\r\n    <!------------------------------------------TEXT | PASSWORD------------------------------------------>\r\n    <div *ngIf=\"type === 'text' || type === 'password'\">\r\n        <div class=\"tw-w-full tw-relative\" [ngStyle]=\"{ width: width }\" [ngClass]=\"{\r\n                'cide-element-size-xxs': (size === '2xs'),\r\n                'cide-element-size-xs': (size === 'xs'),\r\n                'cide-element-size-sm': (size === 'sm'),\r\n                'cide-element-size-md': (size === 'md'),\r\n                'cide-element-size-lg': (size === 'lg'),\r\n                'cide-element-leading-icon': leadingIcon,\r\n                'cide-element-trailing-icon': trailingIconInternal,\r\n                'cide-element-clear-input': clearInput,\r\n                'cide-element-input-label-floating': (labelPlacement === 'floating'),\r\n                'cide-element-input-label-start': (labelDir === 'start'),\r\n                'cide-element-input-label-end': (labelDir === 'end'),\r\n                'cide-element-input-label-fixed': (labelPlacement === 'fixed'),\r\n                'cide-element-input-label-less': (!label || labelHide),\r\n                'cide-element-style-outline': (fill === 'outline'),\r\n                'cide-element-style-solid': (fill === 'solid'),\r\n                'cide-element-style-standard': (fill === 'standard'),\r\n            }\">\r\n            <!-- label -->\r\n            <label [for]=\"id\" class=\"cide-input-label\" *ngIf=\"label && !labelHide\">{{label}}</label>\r\n\r\n            <!-- all one line elemets which dose not affect with label and error text -->\r\n            <div class=\"cide-element-input-wrapper\">\r\n                <!-- Leading Icon -->\r\n                <span class=\"cide-input-leading-icon-wrapper\" *ngIf=\"leadingIcon\">\r\n                    <span\r\n                        class=\"cide-input-leading-icon material-symbols-outlined tw-text-center\">{{leadingIcon}}</span>\r\n                </span>\r\n\r\n                <!-- Traling icon -->\r\n                <span class=\"tw-absolute cide-input-trailing-icon -tw-bottom-1 tw-select-none tw-right-0\"\r\n                    *ngIf=\"trailingIconInternal\">\r\n                    <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"\r\n                        [ngClass]=\"{'tw-cursor-pointer': isTrailingIconAllwedClick}\" [attr.tabindex]=\"false\"\r\n                        (click)=\"trailingIconClick()\" (keyup)=\"trailingIconClick()\">{{trailingIconInternal}}</span>\r\n                </span>\r\n\r\n                <!-- Clear -->\r\n                <button class=\"cide-input-clear\"\r\n                    *ngIf=\"clearInput && ngModel\" (click)=\"ClearInputValue()\">\r\n                    <span class=\"cide-input-clear-icon material-symbols-outlined\">close</span>\r\n                </button>\r\n\r\n                <!-- Input -->\r\n                <input [placeholder]=\"placeholder\" [id]=\"id\"\r\n                    [ngClass]=\"[((label && labelPlacement === 'fixed') ? 'tw-rounded-e-md tw-rounded-es-md' : 'tw-rounded-md '), (!leadingIcon ? 'tw-pl-1' : ''), (trailingIconInternal ? 'tw-pr-8': ''), (!trailingIconInternal ? 'tw-pr-1' : ''), ((size === 'md') ? 'tw-h-8 tw-pt-0.5 tw-pb-0' : (size === 'sm' ? 'tw-h-7' : '')), (labelHide ? '!tw-mt-0' : '')]\"\r\n                    [(ngModel)]=\"ngModel\" [type]=\"typeInternal\" (input)=\"upDateValue($event)\" (focus)=\"focusControl()\"\r\n                    [autocomplete]=\"autocomplete\"\r\n                    class=\"tw-m-0 tw-w-full tw-bg-transparent tw-overflow-hidden tw-border-solid tw-p-0 cide-input-input tw-outline-none\" />\r\n            </div>\r\n            <!-- error text / helper text -->\r\n            <span *ngIf=\"(errorText || helperText || !helperTextCollapse) && !hideHelperAndErrorText\"\r\n                class=\"cide-input-help-error-text\">{{\r\n                isValid\r\n                ? helperText : (errorText ?\r\n                (isTouched ? errorText : helperText)\r\n                : helperText)}}</span>\r\n        </div>\r\n    </div>\r\n\r\n    <!-- Input with tralling icon -->\r\n    <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n        <div class=\"tw-w-fullh-full tw-relative\">\r\n            <label\r\n                class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n            <span class=\"tw-absolute -tw-bottom-px tw-right-0 -tw-z-10 tw-text-gray-400\">\r\n                <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n            </span>\r\n            <input\r\n                class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-1 tw-pr-8 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n                value=\"Ankush Bhure\" />\r\n        </div>\r\n    </div> -->\r\n\r\n    <!-- Input with leading icon -->\r\n    <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n        <div class=\"tw-w-fullh-full tw-relative\">\r\n            <label\r\n                class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n            <span class=\"tw-absolute -tw-bottom-px tw-left-0 -tw-z-10 tw-text-gray-400\">\r\n                <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n            </span>\r\n            <input\r\n                class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-8 tw-pr-1 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n                value=\"Ankush Bhure\" />\r\n        </div>\r\n    </div> -->\r\n\r\n    <!------------------------------------------CHECKBOX------------------------------------------>\r\n    <div *ngIf=\"type === 'checkbox'\" class=\"tw-flex\">\r\n        <div class=\"cide-checkbox tw-relative\">\r\n            <input [checked]=\"ngModel\" [value]=\"ngModel\" [id]=\"idRandom\" [type]=\"type\"\r\n                class=\"tw-absolute tw-left-0 tw-invisible\" (click)=\"updateValueCheckBox(!ngModel); focusControl()\"\r\n                [autocomplete]=\"autocomplete\" />\r\n            <label class=\"cide-checkbox-label tw-cursor-pointer\" [for]=\"idRandom\">\r\n                <span class=\"tw-border-2 tw-border-solid tw-relative tw-rounded-md\">\r\n                    <svg width=\"12px\" height=\"10px\" class=\"tw-absolute\">\r\n                        <use xlink:href=\"#sdfwiorfklasfjjalfjwerwr\"></use>\r\n                    </svg>\r\n                </span>\r\n                <span class=\"tw-text-sm tw-pl-2 tw-leading-[18px] tw-select-none tw-cursor-pointer\"\r\n                    *ngIf=\"!labelHide\">{{label}}</span>\r\n            </label>\r\n            <svg class=\"tw-absolute tw-h-0 tw-w-0 tw-select-none tw-pointer-events-none\">\r\n                <!-- Element hidden and its xpath is used to display inside SVG -->\r\n                <symbol id=\"sdfwiorfklasfjjalfjwerwr\" viewbox=\"0 0 12 10\">\r\n                    <polyline points=\"1.5 6 4.5 9 10.5 1\"></polyline>\r\n                </symbol>\r\n            </svg>\r\n        </div>\r\n    </div>\r\n\r\n    <!-------------------------------------------SELECT------------------------------------------->\r\n    <div *ngIf=\"type === 'select'\">sas\r\n        <div class=\"tw-relative\">\r\n            <div class=\"tw-absolute\">\r\n                @for (item of option; track $index) {\r\n                <div class=\"tw-w-full\">\r\n                    {{item}}\r\n                </div>\r\n                }\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
467
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/cloud-ide-element/src/lib/elements/input/input.component.ts","../../../../../../projects/cloud-ide-element/src/lib/elements/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, forwardRef, inject } from '@angular/core';\r\nimport { AbstractControl, ControlValueAccessor, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from '@angular/forms';\r\nimport { CapitalizePipe } from '../../utils/pipes/capitalize/capitalize.pipe';\r\nimport { CideElementsService } from '../../utils/services/elements/elements.service';\r\nimport { autocapitalizeType, autocompleteType, controlType, elementStyleType, inputType, labelDirType, labelPlacementType, themeSize } from 'cloud-ide-lms-model';\r\n\r\n/** @description type to register error related to control */\r\nexport type ErrorValidationStatus = {\r\n  maxlength?: string,\r\n  minlength?: string,\r\n  required?: string,\r\n}\r\nexport type ValidationStatus = {\r\n  validation: ErrorValidationStatus,\r\n  status: boolean\r\n}\r\n\r\n@Component({\r\n  selector: 'cide-ele-input',\r\n  standalone: true,\r\n  templateUrl: './input.component.html',\r\n  styleUrl: './input.component.scss',\r\n  imports: [\r\n    // directives\r\n    CommonModule,\r\n    // for ngModel\r\n    FormsModule\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => CideInputComponent),\r\n      multi: true\r\n    },\r\n    /** @description to apply validations  */\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      multi: true,\r\n      useExisting: forwardRef(() => CideInputComponent),\r\n    },\r\n    CapitalizePipe\r\n  ]\r\n})\r\n\r\nexport class CideInputComponent implements ControlValueAccessor, Validator, OnChanges, OnInit {\r\n\r\n  // Modern Angular v20 dependency injection pattern\r\n  public capitalizePipe = inject(CapitalizePipe);\r\n  private elementService = inject(CideElementsService);\r\n\r\n  constructor() {\r\n    // Modern Angular v20 pattern: Use constructor for initialization only\r\n    // Validate control\r\n    this.onValidate();\r\n  }\r\n  /*=======Set custom controls inputs to set components=========*/\r\n\r\n  /** \r\n   * @description to se the visual of control like solid control offerd by material design or outline with a border\r\n   * @options solid | outline | standard\r\n   */\r\n  @Input() fill: elementStyleType = 'outline';\r\n  /** @description Lable of control (Title), Like Name, Email */\r\n  @Input() label: string = \"\";\r\n  /** @description to hide and show label */\r\n  @Input() labelHide: boolean = false;\r\n  /** @description is control Editable or Disabled */\r\n  @Input() disabled: boolean = false;\r\n  /** @description Is Clear Input Cross button is visible or not */\r\n  @Input() clearInput: boolean = false;\r\n  /** @description Position of Label 'floating' | 'fixed' */\r\n  @Input() labelPlacement: labelPlacementType = \"fixed\";\r\n  /** @description Lable direction from start of contrl or end of control */\r\n  @Input() labelDir: labelDirType = \"start\";\r\n  /** @description Place holder for control to display if there is no value */\r\n  @Input() placeholder: string = \"\";\r\n  /** @description it is to set leading icon, at the start of control  */\r\n  @Input() leadingIcon: string = \"\";\r\n  /** @description it is to set trailing icon, at the end of control, for password type control eye is the trailing icon  */\r\n  @Input() trailingIcon: string = \"\";\r\n  /** @description to display below the control for suggestion, if there is any error then error will bw the first to shoe in place of help text */\r\n  @Input() helperText: string = \"\";\r\n  /** @description default true to collapse when there is no help text or error text, if false then element area in DOM will be reserved never detroy  */\r\n  @Input() helperTextCollapse: boolean = true;\r\n  /** @description show and hide helper text its forecfull */\r\n  @Input() hideHelperAndErrorText: boolean = false;\r\n  /** @description if found any error in control the error thext will be used to display error message, if there is help text still error text is having higher priority then helptext */\r\n  @Input() errorText: string = \"\";\r\n  /** @description maxlength for control */\r\n  @Input() maxlength: number = 0;\r\n  /** @description minlength for control */\r\n  @Input() minlength: number = 0;\r\n  /** @description is control is required or not input type is true | false */\r\n  @Input() required: boolean = false;\r\n  /** @description Auto capatalization for the value and applicable to word or to complete sentance */\r\n  @Input() autocapitalize: autocapitalizeType = \"off\";\r\n  /** @description auto complete type to help reader what is the type of value */\r\n  @Input() autocomplete: autocompleteType = \"off\";\r\n  /** @description type of control */\r\n  @Input() type: controlType = 'text';\r\n  /** @description width of control, default width is 100% */\r\n  @Input() width: string = '100%';\r\n  /** @description uniq id of control, used to differenciat the value also prevent value should not effect another values */\r\n  @Input() id: string = '';\r\n  /** @description to get input value using one way binding like: [ngModel] or by two way binding [(ngModel)] */\r\n  @Input() ngModel: inputType = '';\r\n  @Input() option: string[] = [\"anksuh\", \"bhure\"];\r\n  /** @description min value for number type control */\r\n  @Input() min: number = 0;\r\n  /** @description max value for number type control */\r\n  @Input() max: number = 0;\r\n  /**\r\n   * @description\r\n   * Holds the size of the component like Small, Extra small, Large\r\n   * by Default it takes small size\r\n   * or the size set by the project setup service\r\n   * or it will beset for individual component\r\n   * \r\n   * Size Appled \r\n   * Component level then setup service then finally default md\r\n   *  Options: \"2xs\" | \"\"xs\" | \"sm\" | \"md\" | \"lg\" | \"xl\" | \"xxl\" \r\n   */\r\n  @Input() size: themeSize = \"sm\";\r\n  /** @description to set return value using one way binding like: (ngModelChanges) or by two way binding [(ngModel)] */\r\n  @Output() ngModelChange: EventEmitter<inputType> = new EventEmitter<inputType>();\r\n\r\n  /*\r\n      internal Properties for input\r\n  */\r\n  /** @description is vale need to read from ngModel or from value(need to implement), it is detected and maild fals on value chnages */\r\n  public isNgModel: boolean = this.ngModel ? true : false;\r\n  /** @description this is to set control value is valid or not, set by us inside validate callbck method called by angular  */\r\n  public isValid: boolean = true;\r\n  /** @description when control is touched then the will maid true by the us to check it is touched or not, when we will set this true we will call the onTouched callback method of angualr to inform angular that somthis is changed and control is touched */\r\n  public isTouched: boolean = false;\r\n  /** @description we will take type of control in type but is may be not exactly which input's type so we need to get type and set actule type to our input, also when type is set password but in calse view in textt then inuut type need to change to text */\r\n  public typeInternal: controlType = \"text\";\r\n  /** @description if traling is set the it is assigned by it, but some case tarling icon not as it is set need tro be changed at runtime, like password visibility hide and show */\r\n  public trailingIconInternal: string = \"\";\r\n\r\n  /* \r\n      Properties connected with trailingIconInternal \r\n  */\r\n  public isTrailingIconAllwedClick: boolean = false;\r\n\r\n  // Properties connected with id\r\n  public idRandom: string = this.randomString();\r\n\r\n  // ==================================METHODS FOR CUSTOM FORM COMPONENT=============================\r\n  // FOR ANGULAR CALLED BY UI\r\n\r\n  /** \r\n   * @description Function to call when the HTML Chnage to tell Angular somthing is changed.\r\n   * @field value : inputType\r\n   */\r\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n  private onChange = (value: inputType) => { };\r\n\r\n  /** @description Function to call when the input is touched (clciked) to tell Angular somthing is changed. */\r\n  onTouched = () => { };\r\n\r\n  /** @description Function to call when the input is need to Validate to tell Angular somthing is changed (in case of some input dipendent validation). */\r\n  onValidate = () => { };\r\n\r\n  /**\r\n   * @description\r\n   * Method that performs synchronous validation against the provided control.\r\n   * Exicuted by Angular\r\n   *\r\n   * @param control The control to validate against.\r\n   *\r\n   * @returns A map of validation errors if validation fails,\r\n   * otherwise null.\r\n   */\r\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n  validate(control: AbstractControl): ValidationErrors | null {\r\n    const validation_error = this.isControlValid(this.ngModel);\r\n    if (validation_error?.status) {\r\n      return validation_error;\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n  /**\r\n   * @description\r\n   * Registers a callback function to call when the validator inputs change.\r\n   * Exicuted by Angular\r\n   *\r\n   * @param fn The callback function\r\n   */\r\n  registerOnValidatorChange?(fn: () => void): void {\r\n    this.onValidate = fn;\r\n  }\r\n\r\n  /** @description when form control change from model side this method is implemented  */\r\n  writeValue(value: inputType): void {\r\n    if (!this.isNgModel) {\r\n      const ngModel = this.autoCapitalizeByOption(value, this.type);\r\n      console.log('writeValue', this.ngModel, ngModel);\r\n      this.ngModel = ngModel;\r\n    }\r\n  }\r\n  /** @description Allows Angular to register a function to call when the model changes. */\r\n  // Save the function as a property to call later here.\r\n  registerOnChange(fn: (value: inputType) => void): void {\r\n    this.onChange = fn;\r\n  }\r\n  /** @description Allows Angular to register a function to call when the input has been touched. */\r\n  // Save the function as a property to call later here.\r\n  registerOnTouched(fn: () => void): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  //==========================================================================\r\n\r\n  /*\r\n    Methods for input\r\n*/\r\n\r\n  /** @description Detect wether input propertires canged or not */\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes?.['value']) {\r\n      this.isNgModel = true;\r\n      this.ngModel = this.processValue(this.ngModel, this.type);\r\n    }\r\n    if (this.isValidValueAndType(this.ngModel, this.type) || this.isTouched) {\r\n      this.isControlValid(this.ngModel);\r\n    }\r\n\r\n    // Ditect type change\r\n    if (changes?.['type']) {\r\n      this.detectTypeChange();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.id) {\r\n      this.getControlData();\r\n    }\r\n  }\r\n\r\n  /** @description custom method run when HTML changes, we call method registerd by angular to detect change */\r\n  upDateValue(value: { target: { value: inputType } } | Event) {\r\n    const target = value.target as HTMLInputElement | { value: inputType };\r\n    this.isControlValid(target?.value);\r\n    const updatedValue = this.processValue(target?.value, this.type);\r\n    this.ngModel = updatedValue;\r\n    this.ngModelChange?.emit(updatedValue);\r\n    // console.log(target)\r\n    this.onChange(updatedValue);\r\n  }\r\n\r\n  /**\r\n   * @description method applicable in case of control type checkbox\r\n   * \r\n   * @param value boolean | string\r\n   */\r\n  updateValueCheckBox(value: string | boolean) {\r\n    // Convert string to boolean\r\n    this.ngModel = !this.ngModel;\r\n    value = (typeof value === 'boolean') ? value : (value === 'true' ? true : false);\r\n    this.ngModelChange?.emit(value);\r\n    this.onChange(value);\r\n  }\r\n\r\n  /** @description clear the value */\r\n  ClearInputValue() {\r\n    if (this.type == \"text\") {\r\n      this.upDateValue({ target: { value: \"\" } });\r\n    }\r\n  }\r\n\r\n  /** @description when HTML is focuesd */\r\n  focusControl() {\r\n    this.isTouched = true;\r\n    this.onTouched();\r\n    this.onValidate();\r\n  }\r\n\r\n  /** @description If control value need to be processed, like UPPERCASE */\r\n  processValue(value: inputType, type: controlType) {\r\n    value = this.autoCapitalizeByOption(value, type);\r\n    return value;\r\n  }\r\n\r\n  /** @description for capitalization */\r\n  autoCapitalizeByOption(value: inputType, type: controlType) {\r\n    if (type == 'text') {\r\n      if (this.autocapitalize == \"on\") {\r\n        return this.capitalizePipe?.transform(value as string, 'allUpperCase');\r\n      }\r\n      if (this.autocapitalize == \"words\") {\r\n        return this.capitalizePipe?.transform(value as string, 'titleCase');\r\n      }\r\n      if (this.autocapitalize == \"sentences\") {\r\n        return this.capitalizePipe?.transform(value as string, \"sentenceCase\");\r\n      }\r\n    }\r\n    return value;\r\n  }\r\n\r\n  /** @description It is used to return the value is valid or not */\r\n  isValidValueAndType(value: inputType, type: controlType) {\r\n    if (type == 'text') {\r\n      if (typeof (value) == 'string') {\r\n        if (value?.length > 0) {\r\n          return true;\r\n        } else {\r\n          return false;\r\n        }\r\n      } else {\r\n        return false;\r\n      }\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  /** @description to check control is valid or not */\r\n  isControlValid(value: inputType): ValidationStatus {\r\n    const validation_status: ValidationStatus = {\r\n      validation: {},\r\n      status: false\r\n    };\r\n\r\n    if (this.required) {\r\n      if (!value) {\r\n        validation_status.status = true;\r\n        validation_status.validation.required = `required!`;\r\n      }\r\n    }\r\n\r\n    if (this.type == 'text') {\r\n      if (typeof (value) == 'string') {\r\n        if (this.maxlength > 0) {\r\n          if (value?.length > this.maxlength) {\r\n            validation_status.status = true;\r\n            validation_status.validation.maxlength = `maximum length is ${this.maxlength}!`;\r\n          }\r\n        }\r\n        if (this.minlength > 0) {\r\n          if (value?.length < this.minlength) {\r\n            validation_status.status = true;\r\n            validation_status.validation.minlength = `minimum length is ${this.minlength}!`;\r\n          }\r\n        }\r\n      } else {\r\n        validation_status.status = true;\r\n        validation_status.validation.required = `required!`;\r\n      }\r\n    }\r\n    this.isValid = !validation_status.status;\r\n    this.errorText = Object.values(validation_status.validation).at(0) || ''\r\n    return validation_status;\r\n  }\r\n\r\n  /** @description Allows Angular to disable the input. */\r\n  setDisabledState(isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  /** @description Method for trailing Icon Click */\r\n  trailingIconClick() {\r\n    if (this.type === 'password') {\r\n      if (this.typeInternal === 'password') {\r\n        this.typeInternal = 'text';\r\n        this.trailingIconInternal = 'visibility';\r\n      } else {\r\n        this.typeInternal = 'password';\r\n        this.trailingIconInternal = 'visibility_off';\r\n      }\r\n    }else {\r\n      this.typeInternal = this.type;\r\n    }\r\n\r\n  }\r\n\r\n  /**\r\n   * Method to generate Random String\r\n   * @param setupPrarameter { lenght: number, prefix: string }\r\n   * default lenght is 10, prefox is \"\"\r\n   * @returns string\r\n   */\r\n  randomString(setupPrarameter: { lenght: number, prefix: string } = { lenght: 10, prefix: \"\" }): string {\r\n    //variable consisting alphabets in small and capital letter  \r\n    const characters = \"ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz\";\r\n    //loop to select a new character in each iteration  \r\n    let random_string = setupPrarameter?.prefix || \"\";\r\n    for (let i = 0; i < setupPrarameter?.lenght; i++) {\r\n      const rnum = Math.floor(Math.random() * characters.length);\r\n      random_string += characters.substring(rnum, rnum + 1);\r\n    }\r\n    //return the generated string  \r\n    return random_string;\r\n  }\r\n\r\n  async getControlData() {\r\n    const cide_element_data = await this.elementService?.getElementData({ sype_key: this.id });\r\n    if (cide_element_data) {\r\n      this.label = cide_element_data?.sype_label as string;\r\n      this.labelPlacement = (cide_element_data?.sype_label_placement || 'floating') as labelPlacementType;\r\n      this.type = (cide_element_data?.sype_type || 'text') as controlType;\r\n      this.required = (cide_element_data?.sype_required || false) as boolean;\r\n      this.size = (cide_element_data?.sype_size || 'md') as themeSize;\r\n      this.helperTextCollapse = (cide_element_data?.sype_helper_text_collapse || false) as boolean;\r\n      this.maxlength = (cide_element_data?.sype_max_length) as number;\r\n      this.minlength = (cide_element_data?.sype_min_length) as number;\r\n      this.leadingIcon = (cide_element_data?.sype_leading_icon) as string;\r\n      this.labelHide = (cide_element_data?.sype_label_hide) as boolean;\r\n      this.hideHelperAndErrorText = (cide_element_data?.sype_hide_helper_and_error_text) as boolean;\r\n      this.detectTypeChange();\r\n      // Validate control\r\n      this.onValidate();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * @description use to detact the change in type if changes done this method is ued to run\r\n   */\r\n  detectTypeChange() {\r\n    if (this.type === 'password') {\r\n      this.typeInternal = \"password\";\r\n      this.trailingIconInternal = \"visibility_off\";\r\n      this.isTrailingIconAllwedClick = true;\r\n    } else {\r\n      this.typeInternal = this.type;\r\n      this.trailingIconInternal = this.trailingIcon;\r\n    }\r\n  }\r\n}\r\n","<div class=\"cide-input\">\r\n    <!------------------------------------------TEXT | PASSWORD------------------------------------------>\r\n    <div *ngIf=\"type === 'text' || type === 'number' || type === 'password'\">\r\n        <div class=\"tw-w-full tw-relative\" [ngStyle]=\"{ width: width }\" [ngClass]=\"{\r\n                'cide-element-size-xxs': (size === '2xs'),\r\n                'cide-element-size-xs': (size === 'xs'),\r\n                'cide-element-size-sm': (size === 'sm'),\r\n                'cide-element-size-md': (size === 'md'),\r\n                'cide-element-size-lg': (size === 'lg'),\r\n                'cide-element-leading-icon': leadingIcon,\r\n                'cide-element-trailing-icon': trailingIconInternal,\r\n                'cide-element-clear-input': clearInput,\r\n                'cide-element-input-label-floating': (labelPlacement === 'floating'),\r\n                'cide-element-input-label-start': (labelDir === 'start'),\r\n                'cide-element-input-label-end': (labelDir === 'end'),\r\n                'cide-element-input-label-fixed': (labelPlacement === 'fixed'),\r\n                'cide-element-input-label-less': (!label || labelHide),\r\n                'cide-element-style-outline': (fill === 'outline'),\r\n                'cide-element-style-solid': (fill === 'solid'),\r\n                'cide-element-style-standard': (fill === 'standard'),\r\n                'cide-element-input-number': (type === 'number')\r\n            }\">\r\n            <!-- label -->\r\n            <label [for]=\"id\" class=\"cide-input-label\" *ngIf=\"label && !labelHide\">{{label}}</label>\r\n\r\n            <!-- all one line elemets which dose not affect with label and error text -->\r\n            <div class=\"cide-element-input-wrapper\">\r\n                <!-- Leading Icon -->\r\n                <span class=\"cide-input-leading-icon-wrapper\" *ngIf=\"leadingIcon\">\r\n                    <span\r\n                        class=\"cide-input-leading-icon material-symbols-outlined tw-text-center\">{{leadingIcon}}</span>\r\n                </span>\r\n\r\n                <!-- Traling icon -->\r\n                <span class=\"tw-absolute cide-input-trailing-icon -tw-bottom-1 tw-select-none tw-right-0\"\r\n                    *ngIf=\"trailingIconInternal\">\r\n                    <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"\r\n                        [ngClass]=\"{'tw-cursor-pointer': isTrailingIconAllwedClick}\" [attr.tabindex]=\"false\"\r\n                        (click)=\"trailingIconClick()\" (keyup)=\"trailingIconClick()\">{{trailingIconInternal}}</span>\r\n                </span>\r\n\r\n                <!-- Clear -->\r\n                <button class=\"cide-input-clear\"\r\n                    *ngIf=\"clearInput && ngModel\" (click)=\"ClearInputValue()\">\r\n                    <span class=\"cide-input-clear-icon material-symbols-outlined\">close</span>\r\n                </button>\r\n\r\n                <!-- Input -->\r\n                <input [placeholder]=\"placeholder\" [id]=\"id\"\r\n                    [ngClass]=\"[((label && labelPlacement === 'fixed') ? 'tw-rounded-e-md tw-rounded-es-md' : 'tw-rounded-md '), (!leadingIcon ? 'tw-pl-1' : ''), (trailingIconInternal ? 'tw-pr-8': ''), (!trailingIconInternal ? 'tw-pr-1' : ''), ((size === 'md') ? 'tw-h-8 tw-pt-0.5 tw-pb-0' : (size === 'sm' ? 'tw-h-7' : '')), (labelHide ? '!tw-mt-0' : '')]\"\r\n                    [(ngModel)]=\"ngModel\" [type]=\"typeInternal\" (input)=\"upDateValue($event)\" (focus)=\"focusControl()\"\r\n                    [autocomplete]=\"autocomplete\" [min]=\"min\" [max]=\"max\"\r\n                    class=\"tw-m-0 tw-w-full tw-bg-transparent tw-overflow-hidden tw-border-solid tw-p-0 cide-input-input tw-outline-none\" />\r\n            </div>\r\n            <!-- error text / helper text -->\r\n            <span *ngIf=\"(errorText || helperText || !helperTextCollapse) && !hideHelperAndErrorText\"\r\n                class=\"cide-input-help-error-text\">{{\r\n                isValid\r\n                ? helperText : (errorText ?\r\n                (isTouched ? errorText : helperText)\r\n                : helperText)}}</span>\r\n        </div>\r\n    </div>\r\n\r\n    <!-- Input with tralling icon -->\r\n    <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n        <div class=\"tw-w-fullh-full tw-relative\">\r\n            <label\r\n                class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n            <span class=\"tw-absolute -tw-bottom-px tw-right-0 -tw-z-10 tw-text-gray-400\">\r\n                <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n            </span>\r\n            <input\r\n                class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-1 tw-pr-8 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n                value=\"Ankush Bhure\" />\r\n        </div>\r\n    </div> -->\r\n\r\n    <!-- Input with leading icon -->\r\n    <!-- <div class=\"tw-inline-block tw-h-12 tw-w-64\">\r\n        <div class=\"tw-w-fullh-full tw-relative\">\r\n            <label\r\n                class=\"tw-absolute -tw-top-1/3 tw-mx-2 tw-bg-white tw-px-0.5 tw-py-0 tw-text-sm tw-leading-4 tw-text-gray-700\">Name</label>\r\n            <span class=\"tw-absolute -tw-bottom-px tw-left-0 -tw-z-10 tw-text-gray-400\">\r\n                <span class=\"material-symbols-outlined tw-w-8 tw-text-center !tw-text-2xl\"> person </span>\r\n            </span>\r\n            <input\r\n                class=\"tw-m-0 tw-h-8 tw-w-full tw-overflow-hidden tw-rounded-md tw-border-2 tw-border-solid tw-border-gray-300 tw-bg-transparent tw-p-0 tw-pb-0.5 tw-pl-8 tw-pr-1 tw-text-sm tw-text-gray-600 tw-outline-none hover:tw-border-blue-400 focus:tw-border-blue-400 focus:tw-text-gray-950\"\r\n                value=\"Ankush Bhure\" />\r\n        </div>\r\n    </div> -->\r\n\r\n    <!------------------------------------------CHECKBOX------------------------------------------>\r\n    <div *ngIf=\"type === 'checkbox'\" class=\"tw-flex\">\r\n        <div class=\"cide-checkbox tw-relative\">\r\n            <input [checked]=\"ngModel\" [value]=\"ngModel\" [id]=\"idRandom\" [type]=\"type\"\r\n                class=\"tw-absolute tw-left-0 tw-invisible\" (click)=\"updateValueCheckBox(!ngModel); focusControl()\"\r\n                [autocomplete]=\"autocomplete\" />\r\n            <label class=\"cide-checkbox-label tw-cursor-pointer\" [for]=\"idRandom\">\r\n                <span class=\"tw-border-2 tw-border-solid tw-relative tw-rounded-md\">\r\n                    <svg width=\"12px\" height=\"10px\" class=\"tw-absolute\">\r\n                        <use xlink:href=\"#sdfwiorfklasfjjalfjwerwr\"></use>\r\n                    </svg>\r\n                </span>\r\n                <span class=\"tw-text-sm tw-pl-2 tw-leading-[18px] tw-select-none tw-cursor-pointer\"\r\n                    *ngIf=\"!labelHide\">{{label}}</span>\r\n            </label>\r\n            <svg class=\"tw-absolute tw-h-0 tw-w-0 tw-select-none tw-pointer-events-none\">\r\n                <!-- Element hidden and its xpath is used to display inside SVG -->\r\n                <symbol id=\"sdfwiorfklasfjjalfjwerwr\" viewbox=\"0 0 12 10\">\r\n                    <polyline points=\"1.5 6 4.5 9 10.5 1\"></polyline>\r\n                </symbol>\r\n            </svg>\r\n        </div>\r\n    </div>\r\n\r\n    <!-------------------------------------------SELECT------------------------------------------->\r\n    <div *ngIf=\"type === 'select'\">sas\r\n        <div class=\"tw-relative\">\r\n            <div class=\"tw-absolute\">\r\n                @for (item of option; track $index) {\r\n                <div class=\"tw-w-full\">\r\n                    {{item}}\r\n                </div>\r\n                }\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|