@sapphire-ion/framework 1.2.59 → 1.2.61
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/carousel/carousel-image/carousel-image.component.mjs +3 -3
- package/esm2022/lib/components/carousel/carousel-item/carousel-item.component.mjs +3 -3
- package/esm2022/lib/components/carousel/carousel.component.mjs +3 -3
- package/esm2022/lib/components/carousel/carousel.module.mjs +4 -4
- package/esm2022/lib/components/carousel/i-carousel-item.component.mjs +3 -3
- package/esm2022/lib/components/content-block/content-block.component.mjs +3 -3
- package/esm2022/lib/components/default/default-list/abstract-list.mjs +3 -3
- package/esm2022/lib/components/default/default-list/default-list.component.mjs +3 -3
- package/esm2022/lib/components/default/default-list/header-list/header-list.component.mjs +3 -3
- package/esm2022/lib/components/default/default-list/list.mjs +3 -3
- package/esm2022/lib/components/default/default-pagination/default-pagination.component.mjs +3 -3
- package/esm2022/lib/components/default/default-table/default-table.component.mjs +3 -3
- package/esm2022/lib/components/default/default-table/th-filter/th-filter.component.mjs +3 -3
- package/esm2022/lib/components/default/default-view/abstract-view.mjs +3 -3
- package/esm2022/lib/components/default/default-view/default-view.component.mjs +3 -3
- package/esm2022/lib/components/default/default-view/header-view/header-view.component.mjs +11 -18
- package/esm2022/lib/components/default/default-view/view.mjs +3 -3
- package/esm2022/lib/components/default/default.module.mjs +4 -4
- package/esm2022/lib/components/default-page/default.page.mjs +3 -3
- package/esm2022/lib/components/drag-drop-file/drag-drop-file.directive.mjs +3 -3
- package/esm2022/lib/components/drag-drop-file/drag-drop-file.module.mjs +4 -4
- package/esm2022/lib/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.mjs +3 -3
- package/esm2022/lib/components/drawer/default-drawer-end/default-drawer-end.component.mjs +3 -3
- package/esm2022/lib/components/drawer/drawer-group/drawer-group.component.mjs +3 -3
- package/esm2022/lib/components/drawer/drawer.component.mjs +3 -3
- package/esm2022/lib/components/filter/filter.component.mjs +3 -3
- package/esm2022/lib/components/http-responses-pages/forbidden-403/forbidden-403.component.mjs +3 -3
- package/esm2022/lib/components/image/image.component.mjs +3 -3
- package/esm2022/lib/components/info-popover/info-popover.component.mjs +3 -3
- package/esm2022/lib/components/inputs/custom-input.mjs +3 -3
- package/esm2022/lib/components/inputs/input-bool/input-bool.component.mjs +3 -3
- package/esm2022/lib/components/inputs/input-cep/input-cep.component.mjs +3 -3
- package/esm2022/lib/components/inputs/input-color/input-color.component.mjs +3 -3
- package/esm2022/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.mjs +3 -3
- package/esm2022/lib/components/inputs/input-date/input-date.component.mjs +27 -7
- package/esm2022/lib/components/inputs/input-date/input-date.configuration.mjs +5 -2
- package/esm2022/lib/components/inputs/input-decimal/input-decimal.component.mjs +42 -9
- package/esm2022/lib/components/inputs/input-file/download-button/download-button.component.mjs +3 -3
- package/esm2022/lib/components/inputs/input-file/input-file.component.mjs +3 -3
- package/esm2022/lib/components/inputs/input-icon/input-icon.component.mjs +3 -3
- package/esm2022/lib/components/inputs/input-select/directives/sion-label-template.directive.mjs +3 -3
- package/esm2022/lib/components/inputs/input-select/directives/sion-option-template.directive.mjs +3 -3
- package/esm2022/lib/components/inputs/input-select/directives/sion-placeholder-template.directive.mjs +3 -3
- package/esm2022/lib/components/inputs/input-select/input-select.component.mjs +13 -10
- package/esm2022/lib/components/inputs/input-select/input.select.configuration.mjs +7 -3
- package/esm2022/lib/components/inputs/input-string/input-string.component.mjs +3 -3
- package/esm2022/lib/components/inputs/input-telefone/input-telefone.component.mjs +3 -3
- package/esm2022/lib/components/inputs/input-textarea/input-textarea.component.mjs +3 -3
- package/esm2022/lib/components/inputs/inputs.module.mjs +4 -4
- package/esm2022/lib/components/loading/loading.component.mjs +3 -3
- package/esm2022/lib/components/login/login-admin/login-admin.component.mjs +3 -3
- package/esm2022/lib/components/login/login.component.mjs +3 -3
- package/esm2022/lib/components/main-content/main-content.component.mjs +3 -3
- package/esm2022/lib/components/popover/sion-popover/sion-popover.component.mjs +3 -3
- package/esm2022/lib/components/popover/sion-popover.module.mjs +4 -4
- package/esm2022/lib/components/sion-card/sion-card.component.mjs +3 -3
- package/esm2022/lib/components/stepper/step/step.component.mjs +3 -3
- package/esm2022/lib/components/stepper/stepper.component.mjs +3 -3
- package/esm2022/lib/components/stepper/stepper.module.mjs +4 -4
- package/esm2022/lib/components/tabs/tab/tab.component.mjs +3 -3
- package/esm2022/lib/components/tabs/tabs/tabs.component.mjs +3 -3
- package/esm2022/lib/components/tabs/tabs.module.mjs +4 -4
- package/esm2022/lib/components/text-tooltip/text-tooltip.component.mjs +3 -3
- package/esm2022/lib/components/tooltip/tooltip.component.mjs +3 -3
- package/esm2022/lib/core.module.mjs +4 -4
- package/esm2022/lib/directives/ng-var.directive.mjs +3 -3
- package/esm2022/lib/guards/auth.guard.mjs +3 -3
- package/esm2022/lib/guards/error.interceptor.mjs +3 -3
- package/esm2022/lib/guards/token.interceptor.mjs +3 -3
- package/esm2022/lib/index.mjs +2 -1
- package/esm2022/lib/pipes/secure.pipe.mjs +3 -3
- package/esm2022/lib/services/auth.service.mjs +3 -3
- package/esm2022/lib/services/environment.service.mjs +3 -3
- package/esm2022/lib/services/generic.service.mjs +3 -3
- package/esm2022/lib/services/modal-focus-trap.service.mjs +3 -3
- package/esm2022/lib/services/navigation-context.service.mjs +100 -0
- package/esm2022/lib/services/popover-focus-trap.service.mjs +3 -3
- package/esm2022/lib/services/route/route.provider.service.mjs +3 -3
- package/esm2022/lib/services/usuario.service.mjs +3 -3
- package/esm2022/lib/services/utils.service.mjs +3 -3
- package/esm2022/lib/services/web/api-url-provider.service.mjs +3 -3
- package/esm2022/lib/services/web/http.ativo.service.mjs +3 -3
- package/esm2022/lib/services/web/http.service.mjs +11 -6
- package/esm2022/lib/services/web/storage.service.mjs +3 -3
- package/fesm2022/sapphire-ion-framework.mjs +437 -283
- package/fesm2022/sapphire-ion-framework.mjs.map +1 -1
- package/lib/components/default/default-view/header-view/header-view.component.d.ts +3 -1
- package/lib/components/inputs/input-date/input-date.configuration.d.ts +5 -1
- package/lib/components/inputs/input-decimal/input-decimal.component.d.ts +4 -3
- package/lib/components/inputs/input-select/input-select.component.d.ts +1 -1
- package/lib/components/inputs/input-select/input.select.configuration.d.ts +6 -1
- package/lib/index.d.ts +1 -0
- package/lib/services/navigation-context.service.d.ts +14 -0
- package/package.json +1 -1
- package/themes/components/inputs/input-decimal/input-decimal.component.scss +1 -1
|
@@ -92,15 +92,35 @@ export class InputDateComponent extends CustomInput {
|
|
|
92
92
|
this.SetValue(m);
|
|
93
93
|
}
|
|
94
94
|
SetValueFromMoment(value) {
|
|
95
|
+
if (!value) {
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
95
98
|
if (this.presentation === DatePresentation.Time) {
|
|
96
|
-
const formatted = value
|
|
99
|
+
const formatted = value.format('HH:mm');
|
|
97
100
|
this.value.set(formatted);
|
|
98
101
|
this.readableValue = formatted;
|
|
99
102
|
this.propagateChange(formatted);
|
|
103
|
+
return;
|
|
100
104
|
}
|
|
101
|
-
|
|
102
|
-
|
|
105
|
+
if (this.configuration().setHourMoment && this.presentation == DatePresentation.DateTime) {
|
|
106
|
+
const now = moment();
|
|
107
|
+
// Se ainda não existe momentValue OU hora/minuto zerados
|
|
108
|
+
const aplicarHoraAtual = !this.momentValue ||
|
|
109
|
+
(this.momentValue.hour() == 0 && this.momentValue.minute() == 0);
|
|
110
|
+
if (aplicarHoraAtual) {
|
|
111
|
+
value = value.clone()
|
|
112
|
+
.hour(now.hour())
|
|
113
|
+
.minute(now.minute())
|
|
114
|
+
.second(0);
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
// mantém hora já escolhida anteriormente
|
|
118
|
+
value = value.clone()
|
|
119
|
+
.hour(this.hour ? Number(this.hour) : value.hour())
|
|
120
|
+
.minute(this.minute ? Number(this.minute) : value.minute());
|
|
121
|
+
}
|
|
103
122
|
}
|
|
123
|
+
this.SetValue(value.format(InputDateComponent.FormatISO));
|
|
104
124
|
}
|
|
105
125
|
/**
|
|
106
126
|
* @param obj String in ISO format (YYYY-MM-DDThh:mm:ss)
|
|
@@ -190,13 +210,13 @@ export class InputDateComponent extends CustomInput {
|
|
|
190
210
|
this.momentValue.set('minute', Number(event));
|
|
191
211
|
this.SetValueFromMoment(this.momentValue);
|
|
192
212
|
}
|
|
193
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
194
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.
|
|
213
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: InputDateComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
214
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: InputDateComponent, selector: "input-date, input-date-time, input-time", inputs: { configuration: { classPropertyName: "configuration", publicName: "configuration", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "window:resize": "onResize($event)", "keydown": "onKeyDown($event)" } }, providers: [
|
|
195
215
|
...InputProviderFactory.GetProviders(InputDateComponent),
|
|
196
216
|
{ provide: CustomInput, useExisting: forwardRef(() => InputDateComponent) },
|
|
197
217
|
], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "inputContainer", first: true, predicate: ["inputContainer"], descendants: true }, { propertyName: "calendar", first: true, predicate: ["calendar"], descendants: true }, { propertyName: "datetime", first: true, predicate: IonDatetime, descendants: true }, { propertyName: "popover", first: true, predicate: SIonPopoverComponent, descendants: true }, { propertyName: "modal", first: true, predicate: IonModal, descendants: true }], usesInheritance: true, ngImport: i0, template: "<div \r\n #inputContainer\r\n class=\"input-container\" \r\n (click)=\"setFocus($event)\"\r\n [class.required]=\"required()\" \r\n [class.submitted]=\"submitted()\" \r\n [class.invalid]=\"invalid\" \r\n [class.disabled]=\"disabled() || loading()\"\r\n [class.loading]=\"loading()\"\r\n>\r\n <div class=\"input-label\"> \r\n <span class=\"truncate\">\r\n {{label()}} \r\n </span>\r\n </div>\r\n \r\n <input #input\r\n [ngModel]=\"readableValue\" \r\n (ngModelChange)=\"SetValueFromReadable($event);\"\r\n [maskito]=\"options\"\r\n [disabled]=\"disabled() || loading()\"\r\n (blur)=\"blur.emit($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n />\r\n <ion-button *ngIf=\"configuration().clearable && readableValue\" tabindex=\"-1\" class=\"absolute right-8 bottom-1\" \r\n (click)=\"ClearValue($event)\" color=\"medium\" size=\"small\" fill=\"clear\" style=\"--border-radius: .5rem\"\r\n >\r\n <ion-icon name=\"close\" slot=\"icon-only\"></ion-icon>\r\n </ion-button>\r\n \r\n <ion-button tabindex=\"-1\" class=\"absolute right-2 bottom-1\" (click)=\"Present($event)\" color=\"medium\" size=\"small\" fill=\"clear\" style=\"--border-radius: .5rem\">\r\n <ion-icon [name]=\"presentation == DatePresentation.Time ? 'time' : 'calendar'\" slot=\"icon-only\"></ion-icon>\r\n </ion-button>\r\n\r\n <div class=\"loading-container\" [class.loading]=\"loading()\">\r\n <ion-spinner></ion-spinner>\r\n </div>\r\n</div>\r\n\r\n@if (interface() == DateInterfaces.Popover) {\r\n <sion-popover\r\n #popover \r\n [anchor]=\"inputContainer\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"datetimeTemplate;\"></ng-container>\r\n </sion-popover>\r\n}\r\n@else {\r\n <ion-modal \r\n #modal\r\n [class.time]=\"presentation == DatePresentation.Time\" \r\n [class.date]=\"presentation == DatePresentation.Date\" \r\n [class.datetime]=\"presentation == DatePresentation.DateTime\"\r\n >\r\n <ng-template>\r\n <ng-container *ngTemplateOutlet=\"datetimeTemplate;\"></ng-container>\r\n </ng-template>\r\n </ion-modal>\r\n}\r\n\r\n\r\n<ng-template #datetimeTemplate>\r\n <div class=\"flex items-center justify-center bg-[--ion-color-light] rounded-xl\" tabindex=\"-1\">\r\n \r\n @if ([DatePresentation.DateTime, DatePresentation.Date].includes(presentation)) {\r\n <mat-calendar #calendar class=\"w-72 text-dark\" \r\n [(selected)]=\"momentValue\" \r\n (selectedChange)=\"SetValueFromMoment($event)\"\r\n ></mat-calendar>\r\n }\r\n @if ([DatePresentation.DateTime, DatePresentation.Time].includes(presentation)) {\r\n <div class=\"flex h-full mask-y/30 items-center justify-center\">\r\n <ion-picker>\r\n <ion-picker-column (ionChange)=\"OnChangeHour($event.target.value.toString())\" [value]=\"hour\">\r\n @for (item of lstHours; track $index) {\r\n <ion-picker-column-option [value]=\"item\">{{item}}</ion-picker-column-option>\r\n }\r\n </ion-picker-column>\r\n <ion-picker-column (ionChange)=\"OnChangeMinute($event.target.value.toString())\" [value]=\"minute\">\r\n @for (item of lstMinutes; track $index) {\r\n <ion-picker-column-option [value]=\"item\">{{item}}</ion-picker-column-option>\r\n }\r\n </ion-picker-column>\r\n </ion-picker>\r\n </div>\r\n }\r\n\r\n </div>\r\n</ng-template>\r\n", styles: [".input-container{position:relative!important}.input-container input{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}ion-picker{height:100%;--fade-background-rgb: transparent}ion-modal{--width: fit-content;--height: fit-content}\n", "@property --input-color{syntax: \"<color>\"; initial-value: transparent; inherits: false;}.input-container{position:relative;--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));cursor:text;border-radius:.75rem;padding:.25rem .75rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition:--input-color .2s ease-in-out,box-shadow .2s ease-in-out,opacity .2s ease-in-out,filter .2s ease-in-out;--color: var(--ion-color-dark);--input-color: var(--input-background, var(--ion-color-step-250));--shadow: 0 3px 4px -1px rgb(0 0 0 / .1);--inset-shadow: var(--input-color) 0px 1.75px 2px 0px inset;--focused-shadow: 0 0 1px 2px color-mix(in srgb, var(--ion-color-medium) 35%, transparent);box-shadow:var(--inset-shadow),var(--shadow);will-change:box-shadow,filter opacity;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;background:radial-gradient(ellipse at 0px top,hsl(from var(--input-color) h s l/.5),hsl(from var(--input-color) h s l/.4)),hsl(from var(--ion-color-light) h s l/.8)}.input-container:hover{--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container:focus-within,.input-container:focus,.input-container.manual-focus{box-shadow:var(--inset-shadow),var(--shadow),var(--focused-shadow);--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container .input-label{pointer-events:none;display:flex;height:1rem;width:100%;min-width:0px;max-width:100%;align-items:center;justify-content:flex-start;gap:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;line-height:1rem;color:var(--color)}.input-container input,.input-container textarea{height:1.5rem;width:100%;border-radius:.375rem;background-color:transparent;font-size:.875rem;line-height:1.25rem;color:var(--ion-color-dark);outline:2px solid transparent;outline-offset:2px}.input-container.loading{cursor:wait!important}.input-container.required .input-label:after{content:\"*\";color:var(--ion-color-danger);vertical-align:bottom}.input-container.submitted.invalid{--input-color: color-mix(in srgb, var(--ion-color-danger) 50%, transparent)}.input-container.disabled{cursor:not-allowed;opacity:.5;--tw-brightness: brightness(1);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container.disabled *{pointer-events:none}.loading-container{position:absolute;pointer-events:none;width:100%;height:100%;top:0;left:0;display:flex;justify-content:end;align-items:center;padding-right:.5rem;will-change:opacity;transition:opacity .2s ease-in-out;overflow:hidden;opacity:0;z-index:10}.loading-container ion-spinner{will-change:auto;transition:transform .2s ease-in-out;transform:translateY(-100%)}.loading-container.loading{opacity:1}.loading-container.loading ion-spinner{transform:translateY(0)}ion-modal::part(content){border-radius:.75rem;border:1px solid var(--ion-color-step-250)}\n"], dependencies: [{ kind: "component", type: i1.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i1.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i1.IonPicker, selector: "ion-picker", inputs: ["mode"] }, { kind: "component", type: i1.IonPickerColumn, selector: "ion-picker-column", inputs: ["color", "disabled", "mode", "value"] }, { kind: "component", type: i1.IonPickerColumnOption, selector: "ion-picker-column-option", inputs: ["color", "disabled", "value"] }, { kind: "component", type: i1.IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }, { kind: "component", type: i1.IonModal, selector: "ion-modal" }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.MaskitoDirective, selector: "[maskito]", inputs: ["maskito", "maskitoElement"] }, { kind: "component", type: i5.SIonPopoverComponent, selector: "sion-popover", inputs: ["fill", "arrow", "flip", "placement", "height", "width", "anchor"], outputs: ["onWillPresent", "onDidPresent", "onWillDismiss", "onDidDismiss"] }, { kind: "component", type: i6.MatCalendar, selector: "mat-calendar", inputs: ["headerComponent", "startAt", "startView", "selected", "minDate", "maxDate", "dateFilter", "dateClass", "comparisonStart", "comparisonEnd", "startDateAccessibleName", "endDateAccessibleName"], outputs: ["selectedChange", "yearSelected", "monthSelected", "viewChanged", "_userSelection", "_userDragDrop"], exportAs: ["matCalendar"] }] }); }
|
|
198
218
|
}
|
|
199
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
219
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: InputDateComponent, decorators: [{
|
|
200
220
|
type: Component,
|
|
201
221
|
args: [{ selector: 'input-date, input-date-time, input-time', providers: [
|
|
202
222
|
...InputProviderFactory.GetProviders(InputDateComponent),
|
|
@@ -240,4 +260,4 @@ var DateInterfaces;
|
|
|
240
260
|
})(DateInterfaces || (DateInterfaces = {}));
|
|
241
261
|
const lstHours = Array.from(Array(24).keys()).map(i => i.toString().padStart(2, '0'));
|
|
242
262
|
const lstMinutes = Array.from(Array(60).keys()).map(i => i.toString().padStart(2, '0'));
|
|
243
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/inputs/input-date/input-date.component.ts","../../../../../../src/lib/components/inputs/input-date/input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, ElementRef, forwardRef, HostListener, input, InputSignal, OnInit, Signal, signal, ViewChild, WritableSignal } from '@angular/core';\r\nimport { maskitoDateTimeOptionsGenerator } from '@maskito/kit';\r\nimport { maskitoDateOptionsGenerator } from '@maskito/kit';\r\nimport { maskitoTimeOptionsGenerator } from '@maskito/kit';\r\nimport { MaskitoOptions } from '@maskito/core';\r\nimport moment, { Moment } from 'moment';\r\n\r\nimport { InputDateConfiguration } from './input-date.configuration';\r\nimport { InputProviderFactory } from '../input-provider-factory';\r\nimport { CustomInput } from '../custom-input';\r\nimport { IonDatetime, IonModal, IonPopover } from '@ionic/angular';\r\nimport { SIonPopoverComponent } from '../../popover/sion-popover/sion-popover.component';\r\nimport { MatCalendar, MatDatepicker } from '@angular/material/datepicker';\r\n\r\n\r\n@Component({\r\n  selector: 'input-date, input-date-time, input-time',\r\n  templateUrl: './input-date.component.html',\r\n  styleUrls: ['./input-date.component.scss', '../inputs.scss'],\r\n  providers: [\r\n    ...InputProviderFactory.GetProviders(InputDateComponent),\r\n    { provide: CustomInput, useExisting: forwardRef(() => InputDateComponent) },\r\n  ],\r\n})\r\nexport class InputDateComponent extends CustomInput<string> {\r\n  static FormatISO = 'YYYY-MM-DDTHH:mm:ss';\r\n  \r\n  configuration: InputSignal<InputDateConfiguration> = input<InputDateConfiguration>(new InputDateConfiguration());\r\n  @ViewChild('input') input: ElementRef<HTMLInputElement>;\r\n  @ViewChild('inputContainer') inputContainer: ElementRef<HTMLDivElement>;\r\n  override setFocus(event: MouseEvent | null): void {\r\n    if(this.input && (event == null || event.target == this.inputContainer.nativeElement)) { this.input.nativeElement.focus(); }      \r\n  }\r\n  \r\n  options: MaskitoOptions;\r\n  // Formato do input html (string)\r\n  momentFormat: 'DD/MM/YYYY HH:mm' | 'DD/MM/YYYY' | 'HH:mm' = 'DD/MM/YYYY HH:mm';\r\n\r\n\r\n  //Handle input interface\r\n  windowSize: WritableSignal<number> = signal<number>(window.innerWidth);\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize(event: any) { this.windowSize.set(window.innerWidth); }\r\n  interface: Signal<DateInterfaces> = computed<DateInterfaces>(() => {\r\n    return this.windowSize() > window.innerHeight ? DateInterfaces.Popover : DateInterfaces.Modal;\r\n  });\r\n  DateInterfaces = DateInterfaces;\r\n\r\n\r\n  constructor(\r\n    override elementRef: ElementRef\r\n  ) { \r\n    super(); \r\n    const presentation = (this.elementRef.nativeElement.tagName.toLowerCase() as string).replace('input-', '');\r\n    this.presentation = {\r\n      'date-time': DatePresentation.DateTime,\r\n      'date': DatePresentation.Date,\r\n      'time': DatePresentation.Time,\r\n    }[presentation] ?? DatePresentation.DateTime;\r\n\r\n    if(this.presentation == DatePresentation.DateTime){ \r\n      this.momentFormat = 'DD/MM/YYYY HH:mm';\r\n      this.options = maskitoDateTimeOptionsGenerator({\r\n        dateMode: 'dd/mm/yyyy',\r\n        timeMode: 'HH:MM',\r\n        dateSeparator: '/',\r\n        dateTimeSeparator: ' ',\r\n        timeStep: 1,\r\n      });\r\n    } else\r\n    if(this.presentation == DatePresentation.Date) {\r\n      this.momentFormat = 'DD/MM/YYYY';\r\n      this.options = maskitoDateOptionsGenerator({ mode: 'dd/mm/yyyy', separator: '/'});\r\n    } else\r\n    if(this.presentation == DatePresentation.Time) {\r\n      this.momentFormat = 'HH:mm'; \r\n      this.options = maskitoTimeOptionsGenerator({\r\n        mode: 'HH:MM',\r\n        step: 1,\r\n      });\r\n    }\r\n  }\r\n  \r\n  @HostListener('keydown', ['$event'])\r\n  onKeyDown(event: KeyboardEvent) {\r\n    if (this.presentation === DatePresentation.Time && event.target === this.input?.nativeElement) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  \r\n  ClearValue(event?: MouseEvent) {\r\n    if (event) {\r\n      event.stopPropagation(); // impede de abrir o calendário ao clicar no clear\r\n    }\r\n    this.value.set(null);\r\n    this.momentValue = undefined;\r\n    this.readableValue = '';\r\n    this.hour = '00';\r\n    this.minute = '00';\r\n    this.propagateChange(null);\r\n  }\r\n\r\n  public presentation: DatePresentation = DatePresentation.DateTime;\r\n  \r\n  readableValue: string = '';\r\n  SetValueFromReadable(value: string): void {\r\n    const m = moment(value, this.momentFormat, true).format(InputDateComponent.FormatISO);  \r\n    this.SetValue(m);\r\n  }\r\n  SetValueFromMoment(value: moment.Moment | null): void {\r\n    if (this.presentation === DatePresentation.Time) {\r\n      const formatted = value?.format('HH:mm');\r\n      this.value.set(formatted);\r\n      this.readableValue = formatted;\r\n      this.propagateChange(formatted);\r\n    } else {\r\n      this.SetValue(value.format(InputDateComponent.FormatISO));\r\n    }\r\n  }\r\n\r\n  @ViewChild('calendar') calendar: MatCalendar<moment.Moment>;\r\n  /**\r\n   * @param obj String in ISO format (YYYY-MM-DDThh:mm:ss)\r\n   */\r\n  override SetValue(obj: string): void {\r\n    this.value.set(obj);\r\n\r\n    if(this.value()){\r\n      this.momentValue   = moment(this.value(), InputDateComponent.FormatISO, true);\r\n      this.readableValue = this.momentValue.format(this.momentFormat.toString());\r\n\r\n      if(this.calendar){\r\n        this.calendar.activeDate = this.momentValue; // set the active date to the selected date\r\n        this.calendar.updateTodaysDate(); // update calendar state\r\n      }\r\n      if(this.momentValue){\r\n        this.hour   = this.momentValue.get('hour').toString().padStart(2,'0');\r\n        this.minute = this.momentValue.get('minute').toString().padStart(2,'0');\r\n      }\r\n    }\r\n    \r\n    this.runValidation();\r\n    if(this.momentValue.isValid()){\r\n      this.propagateChange(obj);\r\n    } else{\r\n      this.propagateChange(null);\r\n    }\r\n  }\r\n\r\n  momentValue?: moment.Moment;\r\n\r\n  @ViewChild(IonDatetime) datetime: IonDatetime;\r\n  \r\n  override writeValue(obj?: string): void | Promise<void> {\r\n    this.value.set(obj);\r\n  \r\n    if (this.value()) {\r\n      if (this.presentation === DatePresentation.Time) {\r\n        this.readableValue = moment(this.value(), 'HH:mm', true).format('HH:mm');\r\n      \r\n        // cria momentValue se quiser manipular hora/minuto depois\r\n        this.momentValue = moment(this.readableValue, 'HH:mm', true);\r\n      \r\n        this.hour   = this.momentValue.get('hour').toString().padStart(2,'0');\r\n        this.minute = this.momentValue.get('minute').toString().padStart(2,'0');\r\n      } else {\r\n        this.momentValue   = moment(this.value(), InputDateComponent.FormatISO, true);\r\n        this.readableValue = this.momentValue.format(this.momentFormat.toString());\r\n        \r\n        if (this.calendar) {\r\n          this.calendar.activeDate = this.momentValue;\r\n          this.calendar.updateTodaysDate();\r\n        }\r\n        if (this.momentValue) {\r\n          this.hour   = this.momentValue.get('hour').toString().padStart(2,'0');\r\n          this.minute = this.momentValue.get('minute').toString().padStart(2,'0');\r\n        }\r\n      }\r\n    }\r\n    this.runValidation();\r\n  }\r\n\r\n\r\n  @ViewChild(SIonPopoverComponent) popover: SIonPopoverComponent;\r\n  @ViewChild(IonModal) modal: IonModal;\r\n  async Present(event: MouseEvent) {\r\n    if(this.interface() == DateInterfaces.Popover){\r\n      return this.popover.present(event);\r\n    } else {\r\n      return this.modal.present();\r\n    }\r\n  }\r\n\r\n  async Dismiss() {\r\n    if(this.popover){\r\n      this.popover.dismiss();\r\n    }\r\n    if(this.modal){\r\n      this.modal.dismiss();\r\n    }\r\n  }\r\n\r\n  DatePresentation = DatePresentation;\r\n\r\n  lstHours = lstHours;\r\n  lstMinutes = lstMinutes;\r\n\r\n  hour  : string = '00';\r\n  minute: string = '00';\r\n\r\n  OnChangeHour(event: string) {\r\n    if (event == this.hour) { return; }\r\n    this.hour = event;\r\n  \r\n    if (!this.momentValue) {\r\n      this.momentValue = moment().startOf('day'); // cria um moment base\r\n    }\r\n  \r\n    this.momentValue.set('hour', Number(event));\r\n    this.SetValueFromMoment(this.momentValue);\r\n  }\r\n  \r\n  OnChangeMinute(event: string) {\r\n    if (event == this.minute) { return; }\r\n    this.minute = event;\r\n  \r\n    if (!this.momentValue) {\r\n      this.momentValue = moment().startOf('day');\r\n    }\r\n  \r\n    this.momentValue.set('minute', Number(event));\r\n    this.SetValueFromMoment(this.momentValue);\r\n  }\r\n}\r\n\r\n\r\nenum DatePresentation {\r\n  DateTime = 1,\r\n  Date     = 2,\r\n  Time     = 3\r\n}\r\nenum DateInterfaces{\r\n  Popover = 1,\r\n  Modal   = 2,\r\n}\r\n\r\nconst lstHours = Array.from(Array(24).keys()).map(i => i.toString().padStart(2,'0'));\r\nconst lstMinutes = Array.from(Array(60).keys()).map(i => i.toString().padStart(2,'0'));","<div \r\n  #inputContainer\r\n  class=\"input-container\" \r\n  (click)=\"setFocus($event)\"\r\n  [class.required]=\"required()\" \r\n  [class.submitted]=\"submitted()\" \r\n  [class.invalid]=\"invalid\" \r\n  [class.disabled]=\"disabled() || loading()\"\r\n  [class.loading]=\"loading()\"\r\n>\r\n  <div class=\"input-label\"> \r\n    <span class=\"truncate\">\r\n      {{label()}} \r\n    </span>\r\n  </div>\r\n  \r\n  <input #input\r\n    [ngModel]=\"readableValue\" \r\n    (ngModelChange)=\"SetValueFromReadable($event);\"\r\n    [maskito]=\"options\"\r\n    [disabled]=\"disabled() || loading()\"\r\n    (blur)=\"blur.emit($event)\"\r\n    (keydown)=\"onKeyDown($event)\"\r\n  />\r\n  <ion-button  *ngIf=\"configuration().clearable && readableValue\" tabindex=\"-1\" class=\"absolute right-8 bottom-1\" \r\n                (click)=\"ClearValue($event)\" color=\"medium\" size=\"small\" fill=\"clear\" style=\"--border-radius: .5rem\"\r\n  >\r\n    <ion-icon name=\"close\" slot=\"icon-only\"></ion-icon>\r\n  </ion-button>\r\n  \r\n  <ion-button tabindex=\"-1\" class=\"absolute right-2 bottom-1\" (click)=\"Present($event)\" color=\"medium\" size=\"small\" fill=\"clear\" style=\"--border-radius: .5rem\">\r\n    <ion-icon [name]=\"presentation == DatePresentation.Time ? 'time' : 'calendar'\" slot=\"icon-only\"></ion-icon>\r\n  </ion-button>\r\n\r\n  <div class=\"loading-container\" [class.loading]=\"loading()\">\r\n    <ion-spinner></ion-spinner>\r\n  </div>\r\n</div>\r\n\r\n@if (interface() == DateInterfaces.Popover) {\r\n  <sion-popover\r\n    #popover \r\n    [anchor]=\"inputContainer\"\r\n  >\r\n    <ng-container *ngTemplateOutlet=\"datetimeTemplate;\"></ng-container>\r\n  </sion-popover>\r\n}\r\n@else {\r\n  <ion-modal \r\n    #modal\r\n    [class.time]=\"presentation == DatePresentation.Time\" \r\n    [class.date]=\"presentation == DatePresentation.Date\" \r\n    [class.datetime]=\"presentation == DatePresentation.DateTime\"\r\n  >\r\n    <ng-template>\r\n      <ng-container *ngTemplateOutlet=\"datetimeTemplate;\"></ng-container>\r\n    </ng-template>\r\n  </ion-modal>\r\n}\r\n\r\n\r\n<ng-template #datetimeTemplate>\r\n  <div class=\"flex items-center justify-center bg-[--ion-color-light] rounded-xl\" tabindex=\"-1\">\r\n    \r\n    @if ([DatePresentation.DateTime, DatePresentation.Date].includes(presentation)) {\r\n      <mat-calendar #calendar class=\"w-72 text-dark\" \r\n        [(selected)]=\"momentValue\" \r\n        (selectedChange)=\"SetValueFromMoment($event)\"\r\n      ></mat-calendar>\r\n    }\r\n    @if ([DatePresentation.DateTime, DatePresentation.Time].includes(presentation)) {\r\n      <div class=\"flex h-full mask-y/30 items-center justify-center\">\r\n        <ion-picker>\r\n          <ion-picker-column (ionChange)=\"OnChangeHour($event.target.value.toString())\" [value]=\"hour\">\r\n            @for (item of lstHours; track $index) {\r\n              <ion-picker-column-option [value]=\"item\">{{item}}</ion-picker-column-option>\r\n            }\r\n          </ion-picker-column>\r\n          <ion-picker-column (ionChange)=\"OnChangeMinute($event.target.value.toString())\" [value]=\"minute\">\r\n            @for (item of lstMinutes; track $index) {\r\n              <ion-picker-column-option [value]=\"item\">{{item}}</ion-picker-column-option>\r\n            }\r\n          </ion-picker-column>\r\n        </ion-picker>\r\n      </div>\r\n    }\r\n\r\n  </div>\r\n</ng-template>\r\n"]}
|
|
263
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-date.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/inputs/input-date/input-date.component.ts","../../../../../../src/lib/components/inputs/input-date/input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, ElementRef, forwardRef, HostListener, input, InputSignal, OnInit, Signal, signal, ViewChild, WritableSignal } from '@angular/core';\r\nimport { maskitoDateTimeOptionsGenerator } from '@maskito/kit';\r\nimport { maskitoDateOptionsGenerator } from '@maskito/kit';\r\nimport { maskitoTimeOptionsGenerator } from '@maskito/kit';\r\nimport { MaskitoOptions } from '@maskito/core';\r\nimport moment, { Moment } from 'moment';\r\n\r\nimport { InputDateConfiguration } from './input-date.configuration';\r\nimport { InputProviderFactory } from '../input-provider-factory';\r\nimport { CustomInput } from '../custom-input';\r\nimport { IonDatetime, IonModal, IonPopover } from '@ionic/angular';\r\nimport { SIonPopoverComponent } from '../../popover/sion-popover/sion-popover.component';\r\nimport { MatCalendar, MatDatepicker } from '@angular/material/datepicker';\r\n\r\n\r\n@Component({\r\n  selector: 'input-date, input-date-time, input-time',\r\n  templateUrl: './input-date.component.html',\r\n  styleUrls: ['./input-date.component.scss', '../inputs.scss'],\r\n  providers: [\r\n    ...InputProviderFactory.GetProviders(InputDateComponent),\r\n    { provide: CustomInput, useExisting: forwardRef(() => InputDateComponent) },\r\n  ],\r\n})\r\nexport class InputDateComponent extends CustomInput<string> {\r\n  static FormatISO = 'YYYY-MM-DDTHH:mm:ss';\r\n  \r\n  configuration: InputSignal<InputDateConfiguration> = input<InputDateConfiguration>(new InputDateConfiguration());\r\n  @ViewChild('input') input: ElementRef<HTMLInputElement>;\r\n  @ViewChild('inputContainer') inputContainer: ElementRef<HTMLDivElement>;\r\n  override setFocus(event: MouseEvent | null): void {\r\n    if(this.input && (event == null || event.target == this.inputContainer.nativeElement)) { this.input.nativeElement.focus(); }      \r\n  }\r\n  \r\n  options: MaskitoOptions;\r\n  // Formato do input html (string)\r\n  momentFormat: 'DD/MM/YYYY HH:mm' | 'DD/MM/YYYY' | 'HH:mm' = 'DD/MM/YYYY HH:mm';\r\n\r\n\r\n  //Handle input interface\r\n  windowSize: WritableSignal<number> = signal<number>(window.innerWidth);\r\n  @HostListener('window:resize', ['$event'])\r\n  onResize(event: any) { this.windowSize.set(window.innerWidth); }\r\n  interface: Signal<DateInterfaces> = computed<DateInterfaces>(() => {\r\n    return this.windowSize() > window.innerHeight ? DateInterfaces.Popover : DateInterfaces.Modal;\r\n  });\r\n  DateInterfaces = DateInterfaces;\r\n\r\n\r\n  constructor(\r\n    override elementRef: ElementRef\r\n  ) { \r\n    super(); \r\n    const presentation = (this.elementRef.nativeElement.tagName.toLowerCase() as string).replace('input-', '');\r\n    this.presentation = {\r\n      'date-time': DatePresentation.DateTime,\r\n      'date': DatePresentation.Date,\r\n      'time': DatePresentation.Time,\r\n    }[presentation] ?? DatePresentation.DateTime;\r\n\r\n    if(this.presentation == DatePresentation.DateTime){ \r\n      this.momentFormat = 'DD/MM/YYYY HH:mm';\r\n      this.options = maskitoDateTimeOptionsGenerator({\r\n        dateMode: 'dd/mm/yyyy',\r\n        timeMode: 'HH:MM',\r\n        dateSeparator: '/',\r\n        dateTimeSeparator: ' ',\r\n        timeStep: 1,\r\n      });\r\n    } else\r\n    if(this.presentation == DatePresentation.Date) {\r\n      this.momentFormat = 'DD/MM/YYYY';\r\n      this.options = maskitoDateOptionsGenerator({ mode: 'dd/mm/yyyy', separator: '/'});\r\n    } else\r\n    if(this.presentation == DatePresentation.Time) {\r\n      this.momentFormat = 'HH:mm'; \r\n      this.options = maskitoTimeOptionsGenerator({\r\n        mode: 'HH:MM',\r\n        step: 1,\r\n      });\r\n    }\r\n  }\r\n  \r\n  @HostListener('keydown', ['$event'])\r\n  onKeyDown(event: KeyboardEvent) {\r\n    if (this.presentation === DatePresentation.Time && event.target === this.input?.nativeElement) {\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  \r\n  ClearValue(event?: MouseEvent) {\r\n    if (event) {\r\n      event.stopPropagation(); // impede de abrir o calendário ao clicar no clear\r\n    }\r\n    this.value.set(null);\r\n    this.momentValue = undefined;\r\n    this.readableValue = '';\r\n    this.hour = '00';\r\n    this.minute = '00';\r\n    this.propagateChange(null);\r\n  }\r\n\r\n  public presentation: DatePresentation = DatePresentation.DateTime;\r\n  \r\n  readableValue: string = '';\r\n  SetValueFromReadable(value: string): void {\r\n    const m = moment(value, this.momentFormat, true).format(InputDateComponent.FormatISO);  \r\n    this.SetValue(m);\r\n  }\r\n  SetValueFromMoment(value: moment.Moment | null): void {\r\n    if (!value) { return; }\r\n    if (this.presentation === DatePresentation.Time) {\r\n      const formatted = value.format('HH:mm');\r\n      this.value.set(formatted);\r\n      this.readableValue = formatted;\r\n      this.propagateChange(formatted);\r\n      return;\r\n    }\r\n    if (this.configuration().setHourMoment && this.presentation == DatePresentation.DateTime) {\r\n      const now = moment();\r\n\r\n      // Se ainda não existe momentValue OU hora/minuto zerados\r\n      const aplicarHoraAtual =\r\n        !this.momentValue ||\r\n        (this.momentValue.hour() == 0 && this.momentValue.minute() == 0);\r\n\r\n      if (aplicarHoraAtual) {\r\n        value = value.clone()\r\n          .hour(now.hour())\r\n          .minute(now.minute())\r\n          .second(0);\r\n      } else {\r\n        // mantém hora já escolhida anteriormente\r\n        value = value.clone()\r\n          .hour(this.hour ? Number(this.hour) : value.hour())\r\n          .minute(this.minute ? Number(this.minute) : value.minute());\r\n      }\r\n    }\r\n    this.SetValue(value.format(InputDateComponent.FormatISO));\r\n  }\r\n\r\n  @ViewChild('calendar') calendar: MatCalendar<moment.Moment>;\r\n  /**\r\n   * @param obj String in ISO format (YYYY-MM-DDThh:mm:ss)\r\n   */\r\n  override SetValue(obj: string): void {\r\n    this.value.set(obj);\r\n\r\n    if(this.value()){\r\n      this.momentValue   = moment(this.value(), InputDateComponent.FormatISO, true);\r\n      this.readableValue = this.momentValue.format(this.momentFormat.toString());\r\n\r\n      if(this.calendar){\r\n        this.calendar.activeDate = this.momentValue; // set the active date to the selected date\r\n        this.calendar.updateTodaysDate(); // update calendar state\r\n      }\r\n      if(this.momentValue){\r\n        this.hour   = this.momentValue.get('hour').toString().padStart(2,'0');\r\n        this.minute = this.momentValue.get('minute').toString().padStart(2,'0');\r\n      }\r\n    }\r\n    \r\n    this.runValidation();\r\n    if(this.momentValue.isValid()){\r\n      this.propagateChange(obj);\r\n    } else{\r\n      this.propagateChange(null);\r\n    }\r\n  }\r\n\r\n  momentValue?: moment.Moment;\r\n\r\n  @ViewChild(IonDatetime) datetime: IonDatetime;\r\n  \r\n  override writeValue(obj?: string): void | Promise<void> {\r\n    this.value.set(obj);\r\n  \r\n    if (this.value()) {\r\n      if (this.presentation === DatePresentation.Time) {\r\n        this.readableValue = moment(this.value(), 'HH:mm', true).format('HH:mm');\r\n      \r\n        // cria momentValue se quiser manipular hora/minuto depois\r\n        this.momentValue = moment(this.readableValue, 'HH:mm', true);\r\n      \r\n        this.hour   = this.momentValue.get('hour').toString().padStart(2,'0');\r\n        this.minute = this.momentValue.get('minute').toString().padStart(2,'0');\r\n      } else {\r\n        this.momentValue   = moment(this.value(), InputDateComponent.FormatISO, true);\r\n        this.readableValue = this.momentValue.format(this.momentFormat.toString());\r\n        \r\n        if (this.calendar) {\r\n          this.calendar.activeDate = this.momentValue;\r\n          this.calendar.updateTodaysDate();\r\n        }\r\n        if (this.momentValue) {\r\n          this.hour   = this.momentValue.get('hour').toString().padStart(2,'0');\r\n          this.minute = this.momentValue.get('minute').toString().padStart(2,'0');\r\n        }\r\n      }\r\n    }\r\n    this.runValidation();\r\n  }\r\n\r\n\r\n  @ViewChild(SIonPopoverComponent) popover: SIonPopoverComponent;\r\n  @ViewChild(IonModal) modal: IonModal;\r\n  async Present(event: MouseEvent) {\r\n    if(this.interface() == DateInterfaces.Popover){\r\n      return this.popover.present(event);\r\n    } else {\r\n      return this.modal.present();\r\n    }\r\n  }\r\n\r\n  async Dismiss() {\r\n    if(this.popover){\r\n      this.popover.dismiss();\r\n    }\r\n    if(this.modal){\r\n      this.modal.dismiss();\r\n    }\r\n  }\r\n\r\n  DatePresentation = DatePresentation;\r\n\r\n  lstHours = lstHours;\r\n  lstMinutes = lstMinutes;\r\n\r\n  hour  : string = '00';\r\n  minute: string = '00';\r\n\r\n  OnChangeHour(event: string) {\r\n    if (event == this.hour) { return; }\r\n    this.hour = event;\r\n  \r\n    if (!this.momentValue) {\r\n      this.momentValue = moment().startOf('day'); // cria um moment base\r\n    }\r\n  \r\n    this.momentValue.set('hour', Number(event));\r\n    this.SetValueFromMoment(this.momentValue);\r\n  }\r\n  \r\n  OnChangeMinute(event: string) {\r\n    if (event == this.minute) { return; }\r\n    this.minute = event;\r\n  \r\n    if (!this.momentValue) {\r\n      this.momentValue = moment().startOf('day');\r\n    }\r\n  \r\n    this.momentValue.set('minute', Number(event));\r\n    this.SetValueFromMoment(this.momentValue);\r\n  }\r\n}\r\n\r\n\r\nenum DatePresentation {\r\n  DateTime = 1,\r\n  Date     = 2,\r\n  Time     = 3\r\n}\r\nenum DateInterfaces{\r\n  Popover = 1,\r\n  Modal   = 2,\r\n}\r\n\r\nconst lstHours = Array.from(Array(24).keys()).map(i => i.toString().padStart(2,'0'));\r\nconst lstMinutes = Array.from(Array(60).keys()).map(i => i.toString().padStart(2,'0'));","<div \r\n  #inputContainer\r\n  class=\"input-container\" \r\n  (click)=\"setFocus($event)\"\r\n  [class.required]=\"required()\" \r\n  [class.submitted]=\"submitted()\" \r\n  [class.invalid]=\"invalid\" \r\n  [class.disabled]=\"disabled() || loading()\"\r\n  [class.loading]=\"loading()\"\r\n>\r\n  <div class=\"input-label\"> \r\n    <span class=\"truncate\">\r\n      {{label()}} \r\n    </span>\r\n  </div>\r\n  \r\n  <input #input\r\n    [ngModel]=\"readableValue\" \r\n    (ngModelChange)=\"SetValueFromReadable($event);\"\r\n    [maskito]=\"options\"\r\n    [disabled]=\"disabled() || loading()\"\r\n    (blur)=\"blur.emit($event)\"\r\n    (keydown)=\"onKeyDown($event)\"\r\n  />\r\n  <ion-button  *ngIf=\"configuration().clearable && readableValue\" tabindex=\"-1\" class=\"absolute right-8 bottom-1\" \r\n                (click)=\"ClearValue($event)\" color=\"medium\" size=\"small\" fill=\"clear\" style=\"--border-radius: .5rem\"\r\n  >\r\n    <ion-icon name=\"close\" slot=\"icon-only\"></ion-icon>\r\n  </ion-button>\r\n  \r\n  <ion-button tabindex=\"-1\" class=\"absolute right-2 bottom-1\" (click)=\"Present($event)\" color=\"medium\" size=\"small\" fill=\"clear\" style=\"--border-radius: .5rem\">\r\n    <ion-icon [name]=\"presentation == DatePresentation.Time ? 'time' : 'calendar'\" slot=\"icon-only\"></ion-icon>\r\n  </ion-button>\r\n\r\n  <div class=\"loading-container\" [class.loading]=\"loading()\">\r\n    <ion-spinner></ion-spinner>\r\n  </div>\r\n</div>\r\n\r\n@if (interface() == DateInterfaces.Popover) {\r\n  <sion-popover\r\n    #popover \r\n    [anchor]=\"inputContainer\"\r\n  >\r\n    <ng-container *ngTemplateOutlet=\"datetimeTemplate;\"></ng-container>\r\n  </sion-popover>\r\n}\r\n@else {\r\n  <ion-modal \r\n    #modal\r\n    [class.time]=\"presentation == DatePresentation.Time\" \r\n    [class.date]=\"presentation == DatePresentation.Date\" \r\n    [class.datetime]=\"presentation == DatePresentation.DateTime\"\r\n  >\r\n    <ng-template>\r\n      <ng-container *ngTemplateOutlet=\"datetimeTemplate;\"></ng-container>\r\n    </ng-template>\r\n  </ion-modal>\r\n}\r\n\r\n\r\n<ng-template #datetimeTemplate>\r\n  <div class=\"flex items-center justify-center bg-[--ion-color-light] rounded-xl\" tabindex=\"-1\">\r\n    \r\n    @if ([DatePresentation.DateTime, DatePresentation.Date].includes(presentation)) {\r\n      <mat-calendar #calendar class=\"w-72 text-dark\" \r\n        [(selected)]=\"momentValue\" \r\n        (selectedChange)=\"SetValueFromMoment($event)\"\r\n      ></mat-calendar>\r\n    }\r\n    @if ([DatePresentation.DateTime, DatePresentation.Time].includes(presentation)) {\r\n      <div class=\"flex h-full mask-y/30 items-center justify-center\">\r\n        <ion-picker>\r\n          <ion-picker-column (ionChange)=\"OnChangeHour($event.target.value.toString())\" [value]=\"hour\">\r\n            @for (item of lstHours; track $index) {\r\n              <ion-picker-column-option [value]=\"item\">{{item}}</ion-picker-column-option>\r\n            }\r\n          </ion-picker-column>\r\n          <ion-picker-column (ionChange)=\"OnChangeMinute($event.target.value.toString())\" [value]=\"minute\">\r\n            @for (item of lstMinutes; track $index) {\r\n              <ion-picker-column-option [value]=\"item\">{{item}}</ion-picker-column-option>\r\n            }\r\n          </ion-picker-column>\r\n        </ion-picker>\r\n      </div>\r\n    }\r\n\r\n  </div>\r\n</ng-template>\r\n"]}
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
export class InputDateConfiguration {
|
|
2
2
|
constructor(
|
|
3
3
|
/** Habilita o botão de limpar os dados */
|
|
4
|
-
clearable = false
|
|
4
|
+
clearable = false,
|
|
5
|
+
/** Caso o Input for DateTime, pode inserir o parametro para setar hora do momento atual */
|
|
6
|
+
setHourMoment = false) {
|
|
5
7
|
this.clearable = clearable;
|
|
8
|
+
this.setHourMoment = setHourMoment;
|
|
6
9
|
}
|
|
7
10
|
}
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtZGF0ZS5jb25maWd1cmF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2lucHV0cy9pbnB1dC1kYXRlL2lucHV0LWRhdGUuY29uZmlndXJhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDO0lBQ0UsMkNBQTJDO0lBQ3BDLFlBQXFCLEtBQUs7SUFDakMsMkZBQTJGO0lBQ3BGLGdCQUF5QixLQUFLO1FBRjlCLGNBQVMsR0FBVCxTQUFTLENBQWlCO1FBRTFCLGtCQUFhLEdBQWIsYUFBYSxDQUFpQjtJQUNyQyxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgSW5wdXREYXRlQ29uZmlndXJhdGlvbntcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIC8qKiBIYWJpbGl0YSBvIGJvdMOjbyBkZSBsaW1wYXIgb3MgZGFkb3MgICovXHJcbiAgICBwdWJsaWMgY2xlYXJhYmxlOiBib29sZWFuID0gZmFsc2UsXHJcbiAgICAvKiogQ2FzbyBvIElucHV0IGZvciBEYXRlVGltZSwgcG9kZSBpbnNlcmlyIG8gcGFyYW1ldHJvIHBhcmEgc2V0YXIgaG9yYSBkbyBtb21lbnRvIGF0dWFsICovXHJcbiAgICBwdWJsaWMgc2V0SG91ck1vbWVudDogYm9vbGVhbiA9IGZhbHNlXHJcbiAgKXt9XHJcbn0iXX0=
|
|
@@ -20,7 +20,18 @@ export class InputDecimalComponent extends CustomInput {
|
|
|
20
20
|
this.configuration = model();
|
|
21
21
|
this.digitsInfo = computed(() => `1.${this.configuration().precision}-${this.configuration().precision}`);
|
|
22
22
|
this.divider = computed(() => Math.pow(10, this.configuration().precision));
|
|
23
|
-
this.
|
|
23
|
+
this.placeholder = computed(() => {
|
|
24
|
+
const selector = this.elementRef.nativeElement.tagName.toLowerCase().split('-').at(-1);
|
|
25
|
+
if (selector == "number") {
|
|
26
|
+
return `0`;
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
const zeros = '0'.repeat(this.configuration().precision);
|
|
30
|
+
return `0,${zeros}`;
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
this.value.set(null);
|
|
34
|
+
this.valueString = '';
|
|
24
35
|
const selector = this.elementRef.nativeElement.tagName.toLowerCase().split('-').at(-1);
|
|
25
36
|
if (selector == "number" && !this.configuration()) {
|
|
26
37
|
this.configuration.set(new InputNumberConfiguration());
|
|
@@ -38,12 +49,22 @@ export class InputDecimalComponent extends CustomInput {
|
|
|
38
49
|
}
|
|
39
50
|
writeValue(obj) {
|
|
40
51
|
this.value.set(obj);
|
|
41
|
-
|
|
52
|
+
if (!obj) {
|
|
53
|
+
this.valueString = '';
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
this.SetValueString();
|
|
57
|
+
}
|
|
42
58
|
this.runValidation();
|
|
43
59
|
}
|
|
44
60
|
SetValue(obj) {
|
|
45
61
|
this.value.set(obj);
|
|
46
|
-
|
|
62
|
+
if (!obj) {
|
|
63
|
+
this.valueString = '';
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
this.SetValueString();
|
|
67
|
+
}
|
|
47
68
|
this.runValidation();
|
|
48
69
|
this.propagateChange(obj);
|
|
49
70
|
}
|
|
@@ -167,6 +188,12 @@ export class InputDecimalComponent extends CustomInput {
|
|
|
167
188
|
const isNumber = lstNumbers.includes(previousChar);
|
|
168
189
|
const f = atLeft.slice(0, atLeft.length - (isNumber ? 1 : 2)) + atRight;
|
|
169
190
|
const CurrentValue = this.SanitizeValue(f);
|
|
191
|
+
if (f === '' || Sanitize(f) === '') {
|
|
192
|
+
this.SetValue(null);
|
|
193
|
+
await Timeout(0);
|
|
194
|
+
this.input.nativeElement.setSelectionRange(0, 0);
|
|
195
|
+
return;
|
|
196
|
+
}
|
|
170
197
|
//[ Handle Set Cursor Position]
|
|
171
198
|
this.SetValue(CurrentValue);
|
|
172
199
|
await Timeout(0);
|
|
@@ -182,6 +209,12 @@ export class InputDecimalComponent extends CustomInput {
|
|
|
182
209
|
const isNumber = lstNumbers.includes(nextChar);
|
|
183
210
|
const f = atLeft + atRight.slice(isNumber ? 1 : 2);
|
|
184
211
|
const CurrentValue = this.SanitizeValue(f);
|
|
212
|
+
if (f === '' || Sanitize(f) === '') {
|
|
213
|
+
this.SetValue(null);
|
|
214
|
+
await Timeout(0);
|
|
215
|
+
this.input.nativeElement.setSelectionRange(0, 0);
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
185
218
|
//[ Handle Set Cursor Position]
|
|
186
219
|
this.SetValue(CurrentValue);
|
|
187
220
|
var pos = selectionStart;
|
|
@@ -208,18 +241,18 @@ export class InputDecimalComponent extends CustomInput {
|
|
|
208
241
|
return;
|
|
209
242
|
}
|
|
210
243
|
}
|
|
211
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
212
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.
|
|
244
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: InputDecimalComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
245
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.14", type: InputDecimalComponent, selector: "input-decimal, input-number, input-currency, input-percentage", inputs: { configuration: { classPropertyName: "configuration", publicName: "configuration", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { configuration: "configurationChange" }, host: { listeners: { "paste": "onPaste($event)" } }, providers: [
|
|
213
246
|
...InputProviderFactory.GetProviders(InputDecimalComponent),
|
|
214
247
|
{ provide: CustomInput, useExisting: forwardRef(() => InputDecimalComponent) },
|
|
215
|
-
], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "inputContainer", first: true, predicate: ["inputContainer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div \r\n #inputContainer\r\n class=\"input-container\" \r\n (click)=\"setFocus($event)\"\r\n [class.required]=\"required()\" \r\n [class.submitted]=\"submitted()\" \r\n [class.invalid]=\"invalid\" \r\n [class.disabled]=\"disabled() || loading()\"\r\n [class.loading]=\"loading()\"\r\n>\r\n <div class=\"input-label\"> \r\n <span class=\"truncate\">\r\n {{label()}} \r\n </span>\r\n </div>\r\n\r\n <div class=\"decimal-input-container text-dark\">\r\n <span *ngIf=\"configuration().prefix\" slot=\"start\">{{configuration().prefix}}</span>\r\n <input #input\r\n inputmode=\"numeric\"\r\n [value]=\"valueString\" \r\n (keydown)=\"onKeyDown($event)\"\r\n [disabled]=\"disabled() || loading()\"\r\n (blur)=\"blur.emit($event)\"\r\n />\r\n <span *ngIf=\"configuration().sufix\" slot=\"end\" >{{configuration().sufix}}</span>\r\n </div>\r\n <div class=\"loading-container\" [class.loading]=\"loading()\">\r\n <ion-spinner></ion-spinner>\r\n </div>\r\n</div>", styles: ["input{text-align:right;width:100%}.decimal-input-container{display:flex;width:100%;align-items:center;justify-content:center;gap:.25rem}.decimal-input-container span{flex-shrink:0}\n", "@property --input-color{syntax: \"<color>\"; initial-value: transparent; inherits: false;}.input-container{position:relative;--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));cursor:text;border-radius:.75rem;padding:.25rem .75rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition:--input-color .2s ease-in-out,box-shadow .2s ease-in-out,opacity .2s ease-in-out,filter .2s ease-in-out;--color: var(--ion-color-dark);--input-color: var(--input-background, var(--ion-color-step-250));--shadow: 0 3px 4px -1px rgb(0 0 0 / .1);--inset-shadow: var(--input-color) 0px 1.75px 2px 0px inset;--focused-shadow: 0 0 1px 2px color-mix(in srgb, var(--ion-color-medium) 35%, transparent);box-shadow:var(--inset-shadow),var(--shadow);will-change:box-shadow,filter opacity;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;background:radial-gradient(ellipse at 0px top,hsl(from var(--input-color) h s l/.5),hsl(from var(--input-color) h s l/.4)),hsl(from var(--ion-color-light) h s l/.8)}.input-container:hover{--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container:focus-within,.input-container:focus,.input-container.manual-focus{box-shadow:var(--inset-shadow),var(--shadow),var(--focused-shadow);--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container .input-label{pointer-events:none;display:flex;height:1rem;width:100%;min-width:0px;max-width:100%;align-items:center;justify-content:flex-start;gap:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;line-height:1rem;color:var(--color)}.input-container input,.input-container textarea{height:1.5rem;width:100%;border-radius:.375rem;background-color:transparent;font-size:.875rem;line-height:1.25rem;color:var(--ion-color-dark);outline:2px solid transparent;outline-offset:2px}.input-container.loading{cursor:wait!important}.input-container.required .input-label:after{content:\"*\";color:var(--ion-color-danger);vertical-align:bottom}.input-container.submitted.invalid{--input-color: color-mix(in srgb, var(--ion-color-danger) 50%, transparent)}.input-container.disabled{cursor:not-allowed;opacity:.5;--tw-brightness: brightness(1);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container.disabled *{pointer-events:none}.loading-container{position:absolute;pointer-events:none;width:100%;height:100%;top:0;left:0;display:flex;justify-content:end;align-items:center;padding-right:.5rem;will-change:opacity;transition:opacity .2s ease-in-out;overflow:hidden;opacity:0;z-index:10}.loading-container ion-spinner{will-change:auto;transition:transform .2s ease-in-out;transform:translateY(-100%)}.loading-container.loading{opacity:1}.loading-container.loading ion-spinner{transform:translateY(0)}ion-modal::part(content){border-radius:.75rem;border:1px solid var(--ion-color-step-250)}\n"], dependencies: [{ kind: "component", type: i1.IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
248
|
+
], viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }, { propertyName: "inputContainer", first: true, predicate: ["inputContainer"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div \r\n #inputContainer\r\n class=\"input-container\" \r\n (click)=\"setFocus($event)\"\r\n [class.required]=\"required()\" \r\n [class.submitted]=\"submitted()\" \r\n [class.invalid]=\"invalid\" \r\n [class.disabled]=\"disabled() || loading()\"\r\n [class.loading]=\"loading()\"\r\n>\r\n <div class=\"input-label\"> \r\n <span class=\"truncate\">\r\n {{label()}} \r\n </span>\r\n </div>\r\n\r\n <div class=\"decimal-input-container text-dark\">\r\n <span *ngIf=\"configuration().prefix\" slot=\"start\">{{configuration().prefix}}</span>\r\n <input #input\r\n inputmode=\"numeric\"\r\n [attr.placeholder]=\"!valueString ? placeholder() : null\"\r\n [value]=\"valueString\" \r\n (keydown)=\"onKeyDown($event)\"\r\n [disabled]=\"disabled() || loading()\"\r\n (blur)=\"blur.emit($event)\"\r\n />\r\n <span *ngIf=\"configuration().sufix\" slot=\"end\" >{{configuration().sufix}}</span>\r\n </div>\r\n <div class=\"loading-container\" [class.loading]=\"loading()\">\r\n <ion-spinner></ion-spinner>\r\n </div>\r\n</div>", styles: ["input{text-align:right;width:100%}.decimal-input-container{display:flex;width:100%;align-items:center;justify-content:center;gap:.25rem}.decimal-input-container span{flex-shrink:0}\n", "@property --input-color{syntax: \"<color>\"; initial-value: transparent; inherits: false;}.input-container{position:relative;--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));cursor:text;border-radius:.75rem;padding:.25rem .75rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition:--input-color .2s ease-in-out,box-shadow .2s ease-in-out,opacity .2s ease-in-out,filter .2s ease-in-out;--color: var(--ion-color-dark);--input-color: var(--input-background, var(--ion-color-step-250));--shadow: 0 3px 4px -1px rgb(0 0 0 / .1);--inset-shadow: var(--input-color) 0px 1.75px 2px 0px inset;--focused-shadow: 0 0 1px 2px color-mix(in srgb, var(--ion-color-medium) 35%, transparent);box-shadow:var(--inset-shadow),var(--shadow);will-change:box-shadow,filter opacity;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;background:radial-gradient(ellipse at 0px top,hsl(from var(--input-color) h s l/.5),hsl(from var(--input-color) h s l/.4)),hsl(from var(--ion-color-light) h s l/.8)}.input-container:hover{--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container:focus-within,.input-container:focus,.input-container.manual-focus{box-shadow:var(--inset-shadow),var(--shadow),var(--focused-shadow);--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container .input-label{pointer-events:none;display:flex;height:1rem;width:100%;min-width:0px;max-width:100%;align-items:center;justify-content:flex-start;gap:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;line-height:1rem;color:var(--color)}.input-container input,.input-container textarea{height:1.5rem;width:100%;border-radius:.375rem;background-color:transparent;font-size:.875rem;line-height:1.25rem;color:var(--ion-color-dark);outline:2px solid transparent;outline-offset:2px}.input-container.loading{cursor:wait!important}.input-container.required .input-label:after{content:\"*\";color:var(--ion-color-danger);vertical-align:bottom}.input-container.submitted.invalid{--input-color: color-mix(in srgb, var(--ion-color-danger) 50%, transparent)}.input-container.disabled{cursor:not-allowed;opacity:.5;--tw-brightness: brightness(1);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container.disabled *{pointer-events:none}.loading-container{position:absolute;pointer-events:none;width:100%;height:100%;top:0;left:0;display:flex;justify-content:end;align-items:center;padding-right:.5rem;will-change:opacity;transition:opacity .2s ease-in-out;overflow:hidden;opacity:0;z-index:10}.loading-container ion-spinner{will-change:auto;transition:transform .2s ease-in-out;transform:translateY(-100%)}.loading-container.loading{opacity:1}.loading-container.loading ion-spinner{transform:translateY(0)}ion-modal::part(content){border-radius:.75rem;border:1px solid var(--ion-color-step-250)}\n"], dependencies: [{ kind: "component", type: i1.IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
216
249
|
}
|
|
217
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
250
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: InputDecimalComponent, decorators: [{
|
|
218
251
|
type: Component,
|
|
219
252
|
args: [{ selector: 'input-decimal, input-number, input-currency, input-percentage', providers: [
|
|
220
253
|
...InputProviderFactory.GetProviders(InputDecimalComponent),
|
|
221
254
|
{ provide: CustomInput, useExisting: forwardRef(() => InputDecimalComponent) },
|
|
222
|
-
], template: "<div \r\n #inputContainer\r\n class=\"input-container\" \r\n (click)=\"setFocus($event)\"\r\n [class.required]=\"required()\" \r\n [class.submitted]=\"submitted()\" \r\n [class.invalid]=\"invalid\" \r\n [class.disabled]=\"disabled() || loading()\"\r\n [class.loading]=\"loading()\"\r\n>\r\n <div class=\"input-label\"> \r\n <span class=\"truncate\">\r\n {{label()}} \r\n </span>\r\n </div>\r\n\r\n <div class=\"decimal-input-container text-dark\">\r\n <span *ngIf=\"configuration().prefix\" slot=\"start\">{{configuration().prefix}}</span>\r\n <input #input\r\n inputmode=\"numeric\"\r\n [value]=\"valueString\" \r\n (keydown)=\"onKeyDown($event)\"\r\n [disabled]=\"disabled() || loading()\"\r\n (blur)=\"blur.emit($event)\"\r\n />\r\n <span *ngIf=\"configuration().sufix\" slot=\"end\" >{{configuration().sufix}}</span>\r\n </div>\r\n <div class=\"loading-container\" [class.loading]=\"loading()\">\r\n <ion-spinner></ion-spinner>\r\n </div>\r\n</div>", styles: ["input{text-align:right;width:100%}.decimal-input-container{display:flex;width:100%;align-items:center;justify-content:center;gap:.25rem}.decimal-input-container span{flex-shrink:0}\n", "@property --input-color{syntax: \"<color>\"; initial-value: transparent; inherits: false;}.input-container{position:relative;--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));cursor:text;border-radius:.75rem;padding:.25rem .75rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition:--input-color .2s ease-in-out,box-shadow .2s ease-in-out,opacity .2s ease-in-out,filter .2s ease-in-out;--color: var(--ion-color-dark);--input-color: var(--input-background, var(--ion-color-step-250));--shadow: 0 3px 4px -1px rgb(0 0 0 / .1);--inset-shadow: var(--input-color) 0px 1.75px 2px 0px inset;--focused-shadow: 0 0 1px 2px color-mix(in srgb, var(--ion-color-medium) 35%, transparent);box-shadow:var(--inset-shadow),var(--shadow);will-change:box-shadow,filter opacity;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;background:radial-gradient(ellipse at 0px top,hsl(from var(--input-color) h s l/.5),hsl(from var(--input-color) h s l/.4)),hsl(from var(--ion-color-light) h s l/.8)}.input-container:hover{--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container:focus-within,.input-container:focus,.input-container.manual-focus{box-shadow:var(--inset-shadow),var(--shadow),var(--focused-shadow);--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container .input-label{pointer-events:none;display:flex;height:1rem;width:100%;min-width:0px;max-width:100%;align-items:center;justify-content:flex-start;gap:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;line-height:1rem;color:var(--color)}.input-container input,.input-container textarea{height:1.5rem;width:100%;border-radius:.375rem;background-color:transparent;font-size:.875rem;line-height:1.25rem;color:var(--ion-color-dark);outline:2px solid transparent;outline-offset:2px}.input-container.loading{cursor:wait!important}.input-container.required .input-label:after{content:\"*\";color:var(--ion-color-danger);vertical-align:bottom}.input-container.submitted.invalid{--input-color: color-mix(in srgb, var(--ion-color-danger) 50%, transparent)}.input-container.disabled{cursor:not-allowed;opacity:.5;--tw-brightness: brightness(1);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container.disabled *{pointer-events:none}.loading-container{position:absolute;pointer-events:none;width:100%;height:100%;top:0;left:0;display:flex;justify-content:end;align-items:center;padding-right:.5rem;will-change:opacity;transition:opacity .2s ease-in-out;overflow:hidden;opacity:0;z-index:10}.loading-container ion-spinner{will-change:auto;transition:transform .2s ease-in-out;transform:translateY(-100%)}.loading-container.loading{opacity:1}.loading-container.loading ion-spinner{transform:translateY(0)}ion-modal::part(content){border-radius:.75rem;border:1px solid var(--ion-color-step-250)}\n"] }]
|
|
255
|
+
], template: "<div \r\n #inputContainer\r\n class=\"input-container\" \r\n (click)=\"setFocus($event)\"\r\n [class.required]=\"required()\" \r\n [class.submitted]=\"submitted()\" \r\n [class.invalid]=\"invalid\" \r\n [class.disabled]=\"disabled() || loading()\"\r\n [class.loading]=\"loading()\"\r\n>\r\n <div class=\"input-label\"> \r\n <span class=\"truncate\">\r\n {{label()}} \r\n </span>\r\n </div>\r\n\r\n <div class=\"decimal-input-container text-dark\">\r\n <span *ngIf=\"configuration().prefix\" slot=\"start\">{{configuration().prefix}}</span>\r\n <input #input\r\n inputmode=\"numeric\"\r\n [attr.placeholder]=\"!valueString ? placeholder() : null\"\r\n [value]=\"valueString\" \r\n (keydown)=\"onKeyDown($event)\"\r\n [disabled]=\"disabled() || loading()\"\r\n (blur)=\"blur.emit($event)\"\r\n />\r\n <span *ngIf=\"configuration().sufix\" slot=\"end\" >{{configuration().sufix}}</span>\r\n </div>\r\n <div class=\"loading-container\" [class.loading]=\"loading()\">\r\n <ion-spinner></ion-spinner>\r\n </div>\r\n</div>", styles: ["input{text-align:right;width:100%}.decimal-input-container{display:flex;width:100%;align-items:center;justify-content:center;gap:.25rem}.decimal-input-container span{flex-shrink:0}\n", "@property --input-color{syntax: \"<color>\"; initial-value: transparent; inherits: false;}.input-container{position:relative;--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));cursor:text;border-radius:.75rem;padding:.25rem .75rem;--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition:--input-color .2s ease-in-out,box-shadow .2s ease-in-out,opacity .2s ease-in-out,filter .2s ease-in-out;--color: var(--ion-color-dark);--input-color: var(--input-background, var(--ion-color-step-250));--shadow: 0 3px 4px -1px rgb(0 0 0 / .1);--inset-shadow: var(--input-color) 0px 1.75px 2px 0px inset;--focused-shadow: 0 0 1px 2px color-mix(in srgb, var(--ion-color-medium) 35%, transparent);box-shadow:var(--inset-shadow),var(--shadow);will-change:box-shadow,filter opacity;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;background:radial-gradient(ellipse at 0px top,hsl(from var(--input-color) h s l/.5),hsl(from var(--input-color) h s l/.4)),hsl(from var(--ion-color-light) h s l/.8)}.input-container:hover{--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container:focus-within,.input-container:focus,.input-container.manual-focus{box-shadow:var(--inset-shadow),var(--shadow),var(--focused-shadow);--tw-brightness: brightness(.9);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container .input-label{pointer-events:none;display:flex;height:1rem;width:100%;min-width:0px;max-width:100%;align-items:center;justify-content:flex-start;gap:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;line-height:1rem;color:var(--color)}.input-container input,.input-container textarea{height:1.5rem;width:100%;border-radius:.375rem;background-color:transparent;font-size:.875rem;line-height:1.25rem;color:var(--ion-color-dark);outline:2px solid transparent;outline-offset:2px}.input-container.loading{cursor:wait!important}.input-container.required .input-label:after{content:\"*\";color:var(--ion-color-danger);vertical-align:bottom}.input-container.submitted.invalid{--input-color: color-mix(in srgb, var(--ion-color-danger) 50%, transparent)}.input-container.disabled{cursor:not-allowed;opacity:.5;--tw-brightness: brightness(1);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.input-container.disabled *{pointer-events:none}.loading-container{position:absolute;pointer-events:none;width:100%;height:100%;top:0;left:0;display:flex;justify-content:end;align-items:center;padding-right:.5rem;will-change:opacity;transition:opacity .2s ease-in-out;overflow:hidden;opacity:0;z-index:10}.loading-container ion-spinner{will-change:auto;transition:transform .2s ease-in-out;transform:translateY(-100%)}.loading-container.loading{opacity:1}.loading-container.loading ion-spinner{transform:translateY(0)}ion-modal::part(content){border-radius:.75rem;border:1px solid var(--ion-color-step-250)}\n"] }]
|
|
223
256
|
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { input: [{
|
|
224
257
|
type: ViewChild,
|
|
225
258
|
args: ['input']
|
|
@@ -240,4 +273,4 @@ const Sanitize = ((v) => {
|
|
|
240
273
|
const lstNumbers = ["0", "1", "2", "3", "4", "5", "6", "7", "8", "9"];
|
|
241
274
|
const lstIgnoreNotPrevent = ["Tab", "CapsLock", "Shift", "Control", "Alt", "ArrowRight", "ArrowUp", "ArrowDown", "ArrowLeft"];
|
|
242
275
|
const lstEspecialCases = ["Backspace", "Delete"];
|
|
243
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-decimal.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/inputs/input-decimal/input-decimal.component.ts","../../../../../../src/lib/components/inputs/input-decimal/input-decimal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,YAAY,EAAE,KAAK,EAAuB,SAAS,EAAE,MAAM,eAAe,CAAC;AACjI,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,0BAA0B,EAAE,yBAAyB,EAAE,wBAAwB,EAAE,4BAA4B,EAAE,MAAM,+BAA+B,CAAC;AAC9J,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,iCAAiC,CAAC;;;;AAW1D,MAAM,OAAO,qBAAsB,SAAQ,WAAmB;IAQnD,QAAQ,CAAC,KAAwB;QACxC,IAAG,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;YACnE,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YACjC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAC/F,CAAC;IACH,CAAC;IACD,YACW,UAAsB;QAE/B,KAAK,EAAE,CAAC;QAFC,eAAU,GAAV,UAAU,CAAY;QAbjC,kBAAa,GAA2C,KAAK,EAA6B,CAAC;QAC3F,eAAU,GAAmB,QAAQ,CAAC,GAAG,EAAE,CAAC,KAAK,IAAI,CAAC,aAAa,EAAE,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,SAAS,EAAE,CAAC,CAAC;QACrH,YAAO,GAAmB,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,CAAC,aAAa,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC;QAcrF,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAClB,MAAM,QAAQ,GAAW,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/F,IAAG,QAAQ,IAAI,QAAQ,IAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,EAAC,CAAC;YAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,wBAAwB,EAAE,CAAC,CAAC;QAAK,CAAC;aACpH,IAAG,QAAQ,IAAI,SAAS,IAAO,CAAC,IAAI,CAAC,aAAa,EAAE,EAAC,CAAC;YAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,yBAAyB,EAAE,CAAC,CAAC;QAAI,CAAC;aACpH,IAAG,QAAQ,IAAI,UAAU,IAAM,CAAC,IAAI,CAAC,aAAa,EAAE,EAAC,CAAC;YAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,0BAA0B,EAAE,CAAC,CAAC;QAAG,CAAC;aACpH,IAAG,QAAQ,IAAI,YAAY,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,EAAC,CAAC;YAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,4BAA4B,EAAE,CAAC,CAAC;QAAC,CAAC;QACpH,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEQ,UAAU,CAAC,GAAW;QAC7B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACpB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IACQ,QAAQ,CAAC,GAAW;QAC3B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QACpB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;IACD,cAAc;QACZ,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;IAC5E,CAAC;IAKD,OAAO,CAAC,KAAqB;QAC3B,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,aAAa,GAAG,KAAK,CAAC,aAAa,IAAI,MAAM,CAAC,eAAe,CAAC,CAAC;QACnE,IAAI,UAAU,GAAM,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAElD,MAAM,CAAC,GAAG,UAAU,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAC9D,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEpB,IAAG,MAAM,CAAC,CAAC,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,EAAC,CAAC;YAC3B,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QACnB,CAAC;QACD,KAAK,CAAC,cAAc,EAAE,CAAC;IACzB,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,KAAoB;QAClC,MAAM,KAAK,GAAW,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC;QAErD,MAAM,cAAc,GAAW,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC;QACvE,MAAM,YAAY,GAAa,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,YAAY,CAAC;QAErE,MAAM,MAAM,GAAI,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,cAAc,CAAC,CAAC;QAC/C,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QACxD,IAAG,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAC,CAAC;YAC5B,OAAO,MAAM,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;QAChG,CAAC;aACD,IAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAC,CAAC;YACjC,OAAO,MAAM,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;QAC9F,CAAC;aACD,IAAG,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAC,CAAC;YACvC,OAAO,MAAM,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;QAChG,CAAC;aACD,IAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,EAAC,CAAC;YAClD,OAAO;QACT,CAAC;aACD,IAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,EAAC,CAAC;YAClD,OAAO;QACT,CAAC;aACD,IAAG,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,OAAO,EAAC,CAAC;YAClD,OAAO;QACT,CAAC;aACD,IAAG,mBAAmB,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAC,CAAC;YAC1C,OAAO;QACT,CAAC;aAAI,CAAC;YACJ,KAAK,CAAC,cAAc,EAAE,CAAC;QACzB,CAAC;IACH,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,KAAoB,EAAE,cAAsB,EAAE,YAAoB,EAAE,KAAa,EAAE,MAAc,EAAE,OAAe;QACrI,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,QAAQ,GAAG,CAAC,cAAc,IAAI,CAAC,IAAI,YAAY,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAChF,sDAAsD;QACtD,IAAI,CAAC,CAAC;QACN,IAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAC,CAAC;YACxB,CAAC,GAAG,KAAK,CAAC,GAAG,GAAG,MAAM,GAAG,OAAO,CAAC;QACnC,CAAC;aAAI,CAAC;YACJ,CAAC,GAAG,CAAC,MAAM,GAAG,OAAO,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;QACzC,CAAC;QAED,IAAG,CAAC,IAAI,GAAG,EAAC,CAAC;YACX,IAAG,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAC,CAAC;gBACtB,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YAC7B,CAAC;iBACG,CAAC;gBACH,CAAC,GAAG,IAAI,KAAK,EAAE,CAAC;YAClB,CAAC;QACH,CAAC;QAED,MAAM,YAAY,GAAW,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QACnD,IAAG,YAAY,IAAI,IAAI,CAAC,KAAK,EAAE,EAAC,CAAC;YAAC,OAAO;QAAC,CAAC;QAE3C,+BAA+B;QAC/B,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;QAC5B,MAAM,MAAM,GAAG,cAAc,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC;QAEjG,2JAA2J;QAC3J,MAAM,OAAO,CAAC,CAAC,CAAC,CAAC;QACjB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAC3D,IAAG,QAAQ,EAAC,CAAC;YACX,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAC/F,CAAC;QACD,OAAO;IACT,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,KAAoB,EAAE,cAAsB,EAAE,YAAoB,EAAE,KAAa,EAAE,MAAc,EAAE,OAAe;QACnI,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,QAAQ,GAAG,CAAC,cAAc,IAAI,CAAC,IAAI,YAAY,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAChF,sDAAsD;QACtD,MAAM,CAAC,GAAG,MAAM,GAAG,KAAK,CAAC,GAAG,GAAG,OAAO,CAAC;QACvC,MAAM,YAAY,GAAW,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QACnD,IAAG,YAAY,IAAI,IAAI,CAAC,KAAK,EAAE,EAAC,CAAC;YAAC,OAAO;QAAC,CAAC;QAC3C,IAAG,YAAY,GAAG,eAAe,EAAC,CAAC;YAAC,OAAO;QAAC,CAAC;QAE7C,+BAA+B;QAC/B,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;QAC5B,MAAM,WAAW,GAAG,cAAc,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC;QAEtG,2JAA2J;QAC3J,MAAM,OAAO,CAAC,CAAC,CAAC,CAAC;QACjB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACrE,IAAG,QAAQ,EAAC,CAAC;YACX,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;QAC/F,CAAC;QACD,OAAO;IACT,CAAC;IAED,aAAa,CAAC,CAAS;QACrB,IAAI,YAAY,GAAW,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;QAChE,IAAG,YAAY,IAAI,eAAe,EAAC,CAAC;YAClC,OAAO,IAAI,CAAC,KAAK,EAAE,CAAC;QACtB,CAAC;QACD,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,KAAoB,EAAE,cAAsB,EAAE,YAAoB,EAAE,KAAa,EAAE,MAAc,EAAE,OAAe;QACrI,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAG,cAAc,IAAI,YAAY,EAAC,CAAC;YACjC,IAAG,KAAK,CAAC,GAAG,IAAI,WAAW,EAAC,CAAC;gBAC3B,IAAG,cAAc,IAAK,YAAY,IAAI,cAAc,IAAI,CAAC,EAAC,CAAC;oBACzD,OAAO;gBACT,CAAC;gBAED,MAAM,YAAY,GAAW,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC3C,MAAM,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;gBACnD,MAAM,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC;gBACxE,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;gBAE3C,+BAA+B;gBAC/B,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;gBAC5B,MAAM,OAAO,CAAC,CAAC,CAAC,CAAC;gBACjB,IAAI,GAAG,GAAG,QAAQ,CAAC,CAAC,CAAC,cAAc,GAAG,CAAC,CAAC,CAAC,CAAC,cAAc,GAAG,CAAC,CAAC;gBAE7D,IAAI,YAAY,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;oBAC5C,GAAG,EAAE,CAAC;gBACR,CAAC;gBACD,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;gBACrD,OAAO;YACT,CAAC;iBACD,IAAG,KAAK,CAAC,GAAG,IAAI,QAAQ,EAAC,CAAC;gBACxB,MAAM,QAAQ,GAAY,OAAO,CAAC,CAAC,CAAC,CAAC;gBACrC,MAAM,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;gBAC/C,MAAM,CAAC,GAAG,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACnD,MAAM,YAAY,GAAI,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;gBAE5C,+BAA+B;gBAC/B,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;gBAC5B,IAAI,GAAG,GAAW,cAAc,CAAC;gBACjC,IAAG,GAAG,IAAI,CAAC,CAAC,EAAC,CAAC;oBAAC,GAAG,GAAG,CAAC,CAAC;gBAAC,CAAC;gBACzB,IAAG,YAAY,GAAG,CAAC,EAAC,CAAC;oBACnB,GAAG,EAAE,CAAC;gBACR,CAAC;gBACD,IAAG,CAAC,QAAQ,EAAC,CAAC;oBACZ,GAAG,EAAE,CAAC;gBACR,CAAC;gBAED,MAAM,OAAO,CAAC,CAAC,CAAC,CAAC;gBACjB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;gBACrD,OAAO;YACT,CAAC;QACH,CAAC;aAAI,CAAC;YACJ,MAAM,CAAC,GAAG,MAAM,GAAG,OAAO,CAAC;YAC3B,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;YAC3C,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;YAE5B,MAAM,OAAO,CAAC,CAAC,CAAC,CAAC;YACjB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YAE7F,OAAO;QACT,CAAC;IACH,CAAC;+GAxNU,qBAAqB;mGAArB,qBAAqB,4VALrB;YACT,GAAG,oBAAoB,CAAC,YAAY,CAAC,qBAAqB,CAAC;YAC3D,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC,EAAE;SAC/E,oPCdH,6/BA8BM;;4FDdO,qBAAqB;kBATjC,SAAS;+BACE,+DAA+D,aAG9D;wBACT,GAAG,oBAAoB,CAAC,YAAY,uBAAuB;wBAC3D,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC,EAAE;qBAC/E;+EAQmB,KAAK;sBAAxB,SAAS;uBAAC,OAAO;gBACW,cAAc;sBAA1C,SAAS;uBAAC,gBAAgB;gBAsC3B,OAAO;sBADN,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC;;AAgLnC,MAAM,eAAe,GAAG,oBAAoB,CAAA;AAE5C,MAAM,gBAAgB,GAAY,GAAG,CAAC;AACtC,MAAM,iBAAiB,GAAW,GAAG,CAAC;AAEtC,MAAM,QAAQ,GAAa,CAAC,CAAC,CAAS,EAAU,EAAE;IAChD,OAAO,CAAC,CAAC,UAAU,CAAC,iBAAiB,EAAE,EAAE,CAAC;SACjC,OAAO,CAAI,gBAAgB,EAAG,EAAE,CAAC,CAAA;AACpC,CAAC,CAAC,CAAC;AAEX,MAAM,UAAU,GAAY,CAAE,GAAG,EAAC,GAAG,EAAC,GAAG,EAAC,GAAG,EAAC,GAAG,EAAC,GAAG,EAAC,GAAG,EAAC,GAAG,EAAC,GAAG,EAAC,GAAG,CAAE,CAAC;AACxE,MAAM,mBAAmB,GAAG,CAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,EAAE,SAAS,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;AAC/H,MAAM,gBAAgB,GAAM,CAAE,WAAW,EAAE,QAAQ,CAAE,CAAC","sourcesContent":["import { Component, computed, ElementRef, forwardRef, HostListener, model, ModelSignal, Signal, ViewChild } from '@angular/core';\r\nimport { formatNumber } from '@angular/common';\r\nimport { InputCurrencyConfiguration, InputDecimalConfiguration, InputNumberConfiguration, InputPercentageConfiguration } from './input-decimal.configuration';\r\nimport { InputProviderFactory } from '../input-provider-factory';\r\nimport { CustomInput } from '../custom-input';\r\nimport { Timeout } from '../../../services/utils.service';\r\n\r\n@Component({\r\n  selector: 'input-decimal, input-number, input-currency, input-percentage',\r\n  templateUrl: './input-decimal.component.html',\r\n  styleUrls: ['./input-decimal.component.scss', '../inputs.scss'],\r\n  providers: [\r\n    ...InputProviderFactory.GetProviders(InputDecimalComponent),\r\n    { provide: CustomInput, useExisting: forwardRef(() => InputDecimalComponent) },\r\n  ],\r\n})\r\nexport class InputDecimalComponent extends CustomInput<number> {\r\n\r\n  configuration: ModelSignal<InputDecimalConfiguration> = model<InputDecimalConfiguration>();\r\n  digitsInfo: Signal<string> = computed(() => `1.${this.configuration().precision}-${this.configuration().precision}`);\r\n  divider: Signal<number> = computed(() => Math.pow(10, this.configuration().precision));\r\n\r\n  @ViewChild('input') input: ElementRef<HTMLInputElement>;\r\n  @ViewChild('inputContainer') inputContainer: ElementRef<HTMLDivElement>;\r\n  override setFocus(event: MouseEvent | null): void {\r\n    if(this.input && event.target == this.inputContainer.nativeElement) { \r\n      this.input.nativeElement.focus(); \r\n      this.input.nativeElement.setSelectionRange(this.valueString.length, this.valueString.length); \r\n    }      \r\n  }\r\n  constructor(\r\n    override elementRef: ElementRef\r\n  ) { \r\n    super(); \r\n    this.value.set(0);\r\n    const selector: string = this.elementRef.nativeElement.tagName.toLowerCase().split('-').at(-1);\r\n    if(selector == \"number\"     && !this.configuration()){ this.configuration.set(new InputNumberConfiguration());     } else\r\n    if(selector == \"decimal\"    && !this.configuration()){ this.configuration.set(new InputDecimalConfiguration());    } else\r\n    if(selector == \"currency\"   && !this.configuration()){ this.configuration.set(new InputCurrencyConfiguration());   } else\r\n    if(selector == \"percentage\" && !this.configuration()){ this.configuration.set(new InputPercentageConfiguration()); }\r\n    this.SetValueString(); \r\n  }\r\n  \r\n  override writeValue(obj: number): void | Promise<void> {\r\n    this.value.set(obj);\r\n    this.SetValueString();\r\n    this.runValidation();\r\n  }\r\n  override SetValue(obj: number): void {\r\n    this.value.set(obj);\r\n    this.SetValueString();\r\n    this.runValidation();\r\n    this.propagateChange(obj); \r\n  }\r\n  SetValueString(): void {\r\n    this.valueString = formatNumber(this.value(), \"pt-BR\", this.digitsInfo());\r\n  }\r\n  \r\n  valueString: string;\r\n\r\n  @HostListener('paste', ['$event'])\r\n  onPaste(event: ClipboardEvent): void {\r\n    event.preventDefault();\r\n    \r\n    let clipboardData = event.clipboardData || window['clipboardData'];\r\n    let pastedText    = clipboardData.getData('text');\r\n\r\n    const s = pastedText.replaceAll('.', '').replaceAll(',', '.');\r\n    const n = Number(s);\r\n\r\n    if(Number(s) && isFinite(n)){ \r\n      this.SetValue(n);\r\n    }\r\n    event.preventDefault();\r\n  }\r\n\r\n  async onKeyDown(event: KeyboardEvent): Promise<void>{\r\n    const value: string = this.input.nativeElement.value;\r\n\r\n    const selectionStart: number = this.input.nativeElement.selectionStart;\r\n    const selectionEnd  : number = this.input.nativeElement.selectionEnd;\r\n\r\n    const atLeft  = value.slice(0, selectionStart); \r\n    const atRight = value.slice(selectionEnd, value.length); \r\n    if([\"-\"].includes(event.key)){ \r\n      return await this.HandleNegative(event, selectionStart, selectionEnd, value, atLeft, atRight);\r\n    }else\r\n    if(lstNumbers.includes(event.key)){ \r\n      return await this.HandleNumber(event, selectionStart, selectionEnd, value, atLeft, atRight); \r\n    }else\r\n    if(lstEspecialCases.includes(event.key)){ \r\n      return await this.HandleEspecial(event, selectionStart, selectionEnd, value, atLeft, atRight); \r\n    }else\r\n    if([\"A\", \"a\"].includes(event.key) && event.ctrlKey){ \r\n      return; \r\n    }else\r\n    if([\"C\", \"c\"].includes(event.key) && event.ctrlKey){ \r\n      return; \r\n    }else\r\n    if([\"V\", \"v\"].includes(event.key) && event.ctrlKey){ \r\n      return; \r\n    }else\r\n    if(lstIgnoreNotPrevent.includes(event.key)){ \r\n      return; \r\n    }else{\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  async HandleNegative(event: KeyboardEvent, selectionStart: number, selectionEnd: number, value: string, atLeft: string, atRight: string): Promise<void>{\r\n    event.preventDefault();\r\n\r\n    let focusEnd = (selectionStart == 0 && selectionEnd == this.valueString.length);\r\n    /** [ Remove decimalSeparator & thousandSeparator ] */\r\n    let f;\r\n    if(!atLeft.includes('-')){\r\n      f = event.key + atLeft + atRight;\r\n    }else{\r\n      f = (atLeft + atRight).replace('-', '')\r\n    }\r\n\r\n    if(f == \"-\"){ \r\n      if(value.includes('-')){\r\n        f = value.replace('-', '');\r\n      }\r\n      else{\r\n        f = `-${value}`;\r\n      }\r\n    }\r\n\r\n    const CurrentValue: number = this.SanitizeValue(f);\r\n    if(CurrentValue == this.value()){ return; }\r\n    \r\n    //[ Handle Set Cursor Position]\r\n    this.SetValue(CurrentValue);\r\n    const newPos = selectionStart + 1 + this.valueString.split('.').length - value.split('.').length;\r\n    \r\n    //Horrivel, mas nao tem uma alternativa boa, https://stackoverflow.com/questions/511088/use-javascript-to-place-cursor-at-end-of-text-in-text-input-element\r\n    await Timeout(0);\r\n    this.input.nativeElement.setSelectionRange(newPos, newPos); \r\n    if(focusEnd){\r\n      this.input.nativeElement.setSelectionRange(this.valueString.length, this.valueString.length); \r\n    }\r\n    return;\r\n  }\r\n\r\n  async HandleNumber(event: KeyboardEvent, selectionStart: number, selectionEnd: number, value: string, atLeft: string, atRight: string): Promise<void> {\r\n    event.preventDefault();\r\n    \r\n    let focusEnd = (selectionStart == 0 && selectionEnd == this.valueString.length);\r\n    /** [ Remove decimalSeparator & thousandSeparator ] */\r\n    const f = atLeft + event.key + atRight;\r\n    const CurrentValue: number = this.SanitizeValue(f);\r\n    if(CurrentValue == this.value()){ return; }\r\n    if(CurrentValue > decimalMaxValue){ return; }\r\n    \r\n    //[ Handle Set Cursor Position]\r\n    this.SetValue(CurrentValue);\r\n    const newPosition = selectionStart + 1 + this.valueString.split('.').length - value.split('.').length;\r\n    \r\n    //Horrivel, mas nao sem uma alternativa boa, https://stackoverflow.com/questions/511088/use-javascript-to-place-cursor-at-end-of-text-in-text-input-element\r\n    await Timeout(0);\r\n    this.input.nativeElement.setSelectionRange(newPosition, newPosition); \r\n    if(focusEnd){\r\n      this.input.nativeElement.setSelectionRange(this.valueString.length, this.valueString.length); \r\n    }\r\n    return;\r\n  }\r\n\r\n  SanitizeValue(f: string): number{\r\n    var CurrentValue: number = Number(Sanitize(f)) / this.divider();\r\n    if(CurrentValue >= decimalMaxValue){ \r\n      return this.value(); \r\n    }\r\n    return CurrentValue;\r\n  }\r\n\r\n  async HandleEspecial(event: KeyboardEvent, selectionStart: number, selectionEnd: number, value: string, atLeft: string, atRight: string): Promise<void> {\r\n    event.preventDefault();\r\n    if(selectionStart == selectionEnd){\r\n      if(event.key == \"Backspace\"){\r\n        if(selectionStart ==  selectionEnd && selectionStart == 0){ \r\n          return; \r\n        }\r\n\r\n        const previousChar: string = atLeft.at(-1);\r\n        const isNumber = lstNumbers.includes(previousChar);\r\n        const f = atLeft.slice(0, atLeft.length - (isNumber ? 1 : 2)) + atRight;\r\n        const CurrentValue = this.SanitizeValue(f);\r\n        \r\n        //[ Handle Set Cursor Position]\r\n        this.SetValue(CurrentValue);\r\n        await Timeout(0);\r\n        let pos = isNumber ? selectionStart - 1 : selectionStart - 2;\r\n\r\n        if (selectionEnd == this.valueString.length) {\r\n          pos++;\r\n        }\r\n        this.input.nativeElement.setSelectionRange(pos, pos); \r\n        return;\r\n      }else\r\n      if(event.key == \"Delete\"){\r\n        const nextChar: string =  atRight[0];\r\n        const isNumber = lstNumbers.includes(nextChar);\r\n        const f = atLeft + atRight.slice(isNumber ? 1 : 2);\r\n        const CurrentValue =  this.SanitizeValue(f);\r\n        \r\n        //[ Handle Set Cursor Position]\r\n        this.SetValue(CurrentValue);\r\n        var pos: number = selectionStart;\r\n        if(pos <= -1){ pos = 0; }\r\n        if(CurrentValue < 1){\r\n          pos++;\r\n        }\r\n        if(!isNumber){\r\n          pos++;\r\n        }\r\n\r\n        await Timeout(0);\r\n        this.input.nativeElement.setSelectionRange(pos, pos);\r\n        return;\r\n      }\r\n    }else{\r\n      const f = atLeft + atRight;\r\n      const CurrentValue = this.SanitizeValue(f);\r\n      this.SetValue(CurrentValue);\r\n      \r\n      await Timeout(0);\r\n      this.input.nativeElement.setSelectionRange(this.valueString.length, this.valueString.length); \r\n\r\n      return;\r\n    }\r\n  }\r\n}\r\n\r\n\r\nconst decimalMaxValue = 9_000_000_000_000.00\r\n\r\nconst decimalSeparator : string = \",\";\r\nconst thousandSeparator: string = \".\";\r\n\r\nconst Sanitize: Function = ((v: string): string => { \r\n  return v.replaceAll(thousandSeparator, '')\r\n          .replace   (decimalSeparator , '') \r\n        });\r\n\r\nconst lstNumbers          = [ \"0\",\"1\",\"2\",\"3\",\"4\",\"5\",\"6\",\"7\",\"8\",\"9\" ];\r\nconst lstIgnoreNotPrevent = [ \"Tab\", \"CapsLock\", \"Shift\", \"Control\", \"Alt\", \"ArrowRight\", \"ArrowUp\", \"ArrowDown\", \"ArrowLeft\"];\r\nconst lstEspecialCases    = [ \"Backspace\", \"Delete\" ];","<div \r\n  #inputContainer\r\n  class=\"input-container\" \r\n  (click)=\"setFocus($event)\"\r\n  [class.required]=\"required()\" \r\n  [class.submitted]=\"submitted()\" \r\n  [class.invalid]=\"invalid\" \r\n  [class.disabled]=\"disabled() || loading()\"\r\n  [class.loading]=\"loading()\"\r\n>\r\n  <div class=\"input-label\"> \r\n    <span class=\"truncate\">\r\n      {{label()}} \r\n    </span>\r\n  </div>\r\n\r\n  <div class=\"decimal-input-container text-dark\">\r\n    <span *ngIf=\"configuration().prefix\" slot=\"start\">{{configuration().prefix}}</span>\r\n    <input #input\r\n      inputmode=\"numeric\"\r\n      [value]=\"valueString\" \r\n      (keydown)=\"onKeyDown($event)\"\r\n      [disabled]=\"disabled() || loading()\"\r\n      (blur)=\"blur.emit($event)\"\r\n    />\r\n    <span *ngIf=\"configuration().sufix\"  slot=\"end\"  >{{configuration().sufix}}</span>\r\n  </div>\r\n  <div class=\"loading-container\" [class.loading]=\"loading()\">\r\n    <ion-spinner></ion-spinner>\r\n  </div>\r\n</div>"]}
|
|
276
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-decimal.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/inputs/input-decimal/input-decimal.component.ts","../../../../../../src/lib/components/inputs/input-decimal/input-decimal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, ElementRef, forwardRef, HostListener, model, ModelSignal, Signal, ViewChild } from '@angular/core';\r\nimport { formatNumber } from '@angular/common';\r\nimport { InputCurrencyConfiguration, InputDecimalConfiguration, InputNumberConfiguration, InputPercentageConfiguration } from './input-decimal.configuration';\r\nimport { InputProviderFactory } from '../input-provider-factory';\r\nimport { CustomInput } from '../custom-input';\r\nimport { Timeout } from '../../../services/utils.service';\r\n\r\n@Component({\r\n  selector: 'input-decimal, input-number, input-currency, input-percentage',\r\n  templateUrl: './input-decimal.component.html',\r\n  styleUrls: ['./input-decimal.component.scss', '../inputs.scss'],\r\n  providers: [\r\n    ...InputProviderFactory.GetProviders(InputDecimalComponent),\r\n    { provide: CustomInput, useExisting: forwardRef(() => InputDecimalComponent) },\r\n  ],\r\n})\r\nexport class InputDecimalComponent extends CustomInput<number | null> {\r\n\r\n  configuration: ModelSignal<InputDecimalConfiguration> = model<InputDecimalConfiguration>();\r\n  digitsInfo: Signal<string> = computed(() => `1.${this.configuration().precision}-${this.configuration().precision}`);\r\n  divider: Signal<number> = computed(() => Math.pow(10, this.configuration().precision));\r\n\r\n  placeholder: Signal<string> = computed(() => {\r\n    const selector: string = this.elementRef.nativeElement.tagName.toLowerCase().split('-').at(-1);\r\n    if(selector == \"number\"){\r\n      return `0`;\r\n    }else{\r\n      const zeros = '0'.repeat(this.configuration().precision);\r\n      return `0,${zeros}`;\r\n    }\r\n  });\r\n\r\n  @ViewChild('input') input: ElementRef<HTMLInputElement>;\r\n  @ViewChild('inputContainer') inputContainer: ElementRef<HTMLDivElement>;\r\n  override setFocus(event: MouseEvent | null): void {\r\n    if(this.input && event.target == this.inputContainer.nativeElement) { \r\n      this.input.nativeElement.focus(); \r\n      this.input.nativeElement.setSelectionRange(this.valueString.length, this.valueString.length); \r\n    }      \r\n  }\r\n  constructor(\r\n    override elementRef: ElementRef\r\n  ) { \r\n    super(); \r\n    this.value.set(null);\r\n    this.valueString = '';\r\n    const selector: string = this.elementRef.nativeElement.tagName.toLowerCase().split('-').at(-1);\r\n    if(selector == \"number\"     && !this.configuration()){ this.configuration.set(new InputNumberConfiguration());     } else\r\n    if(selector == \"decimal\"    && !this.configuration()){ this.configuration.set(new InputDecimalConfiguration());    } else\r\n    if(selector == \"currency\"   && !this.configuration()){ this.configuration.set(new InputCurrencyConfiguration());   } else\r\n    if(selector == \"percentage\" && !this.configuration()){ this.configuration.set(new InputPercentageConfiguration()); }\r\n    this.SetValueString(); \r\n  }\r\n  \r\n  override writeValue(obj: number | null): void {\r\n    this.value.set(obj);\r\n\r\n    if (!obj) {\r\n      this.valueString = '';\r\n    } else {\r\n      this.SetValueString();\r\n    }\r\n\r\n    this.runValidation();\r\n  }\r\n  override SetValue(obj: number | null): void {\r\n    this.value.set(obj);\r\n\r\n    if (!obj) {\r\n      this.valueString = '';\r\n    } else {\r\n      this.SetValueString();\r\n    }\r\n\r\n    this.runValidation();\r\n    this.propagateChange(obj);\r\n  }\r\n  SetValueString(): void {\r\n    this.valueString = formatNumber(this.value(), \"pt-BR\", this.digitsInfo());\r\n  }\r\n  \r\n  valueString: string;\r\n\r\n  @HostListener('paste', ['$event'])\r\n  onPaste(event: ClipboardEvent): void {\r\n    event.preventDefault();\r\n    \r\n    let clipboardData = event.clipboardData || window['clipboardData'];\r\n    let pastedText    = clipboardData.getData('text');\r\n\r\n    const s = pastedText.replaceAll('.', '').replaceAll(',', '.');\r\n    const n = Number(s);\r\n\r\n    if(Number(s) && isFinite(n)){ \r\n      this.SetValue(n);\r\n    }\r\n    event.preventDefault();\r\n  }\r\n\r\n  async onKeyDown(event: KeyboardEvent): Promise<void>{\r\n    const value: string = this.input.nativeElement.value;\r\n\r\n    const selectionStart: number = this.input.nativeElement.selectionStart;\r\n    const selectionEnd  : number = this.input.nativeElement.selectionEnd;\r\n\r\n    const atLeft  = value.slice(0, selectionStart); \r\n    const atRight = value.slice(selectionEnd, value.length); \r\n    if([\"-\"].includes(event.key)){ \r\n      return await this.HandleNegative(event, selectionStart, selectionEnd, value, atLeft, atRight);\r\n    }else\r\n    if(lstNumbers.includes(event.key)){ \r\n      return await this.HandleNumber(event, selectionStart, selectionEnd, value, atLeft, atRight); \r\n    }else\r\n    if(lstEspecialCases.includes(event.key)){ \r\n      return await this.HandleEspecial(event, selectionStart, selectionEnd, value, atLeft, atRight); \r\n    }else\r\n    if([\"A\", \"a\"].includes(event.key) && event.ctrlKey){ \r\n      return; \r\n    }else\r\n    if([\"C\", \"c\"].includes(event.key) && event.ctrlKey){ \r\n      return; \r\n    }else\r\n    if([\"V\", \"v\"].includes(event.key) && event.ctrlKey){ \r\n      return; \r\n    }else\r\n    if(lstIgnoreNotPrevent.includes(event.key)){ \r\n      return; \r\n    }else{\r\n      event.preventDefault();\r\n    }\r\n  }\r\n\r\n  async HandleNegative(event: KeyboardEvent, selectionStart: number, selectionEnd: number, value: string, atLeft: string, atRight: string): Promise<void>{\r\n    event.preventDefault();\r\n\r\n    let focusEnd = (selectionStart == 0 && selectionEnd == this.valueString.length);\r\n    /** [ Remove decimalSeparator & thousandSeparator ] */\r\n    let f;\r\n    if(!atLeft.includes('-')){\r\n      f = event.key + atLeft + atRight;\r\n    }else{\r\n      f = (atLeft + atRight).replace('-', '')\r\n    }\r\n\r\n    if(f == \"-\"){ \r\n      if(value.includes('-')){\r\n        f = value.replace('-', '');\r\n      }\r\n      else{\r\n        f = `-${value}`;\r\n      }\r\n    }\r\n\r\n    const CurrentValue: number = this.SanitizeValue(f);\r\n    if(CurrentValue == this.value()){ return; }\r\n    \r\n    //[ Handle Set Cursor Position]\r\n    this.SetValue(CurrentValue);\r\n    const newPos = selectionStart + 1 + this.valueString.split('.').length - value.split('.').length;\r\n    \r\n    //Horrivel, mas nao tem uma alternativa boa, https://stackoverflow.com/questions/511088/use-javascript-to-place-cursor-at-end-of-text-in-text-input-element\r\n    await Timeout(0);\r\n    this.input.nativeElement.setSelectionRange(newPos, newPos); \r\n    if(focusEnd){\r\n      this.input.nativeElement.setSelectionRange(this.valueString.length, this.valueString.length); \r\n    }\r\n    return;\r\n  }\r\n\r\n  async HandleNumber(event: KeyboardEvent, selectionStart: number, selectionEnd: number, value: string, atLeft: string, atRight: string): Promise<void> {\r\n    event.preventDefault();\r\n    \r\n    let focusEnd = (selectionStart == 0 && selectionEnd == this.valueString.length);\r\n    /** [ Remove decimalSeparator & thousandSeparator ] */\r\n    const f = atLeft + event.key + atRight;\r\n    const CurrentValue: number = this.SanitizeValue(f);\r\n    if(CurrentValue == this.value()){ return; }\r\n    if(CurrentValue > decimalMaxValue){ return; }\r\n    \r\n    //[ Handle Set Cursor Position]\r\n    this.SetValue(CurrentValue);\r\n    const newPosition = selectionStart + 1 + this.valueString.split('.').length - value.split('.').length;\r\n    \r\n    //Horrivel, mas nao sem uma alternativa boa, https://stackoverflow.com/questions/511088/use-javascript-to-place-cursor-at-end-of-text-in-text-input-element\r\n    await Timeout(0);\r\n    this.input.nativeElement.setSelectionRange(newPosition, newPosition); \r\n    if(focusEnd){\r\n      this.input.nativeElement.setSelectionRange(this.valueString.length, this.valueString.length); \r\n    }\r\n    return;\r\n  }\r\n\r\n  SanitizeValue(f: string): number{\r\n    var CurrentValue: number = Number(Sanitize(f)) / this.divider();\r\n    if(CurrentValue >= decimalMaxValue){ \r\n      return this.value(); \r\n    }\r\n    return CurrentValue;\r\n  }\r\n\r\n  async HandleEspecial(event: KeyboardEvent, selectionStart: number, selectionEnd: number, value: string, atLeft: string, atRight: string): Promise<void> {\r\n    event.preventDefault();\r\n    if(selectionStart == selectionEnd){\r\n      if(event.key == \"Backspace\"){\r\n        if(selectionStart ==  selectionEnd && selectionStart == 0){ \r\n          return; \r\n        }\r\n\r\n        const previousChar: string = atLeft.at(-1);\r\n        const isNumber = lstNumbers.includes(previousChar);\r\n        const f = atLeft.slice(0, atLeft.length - (isNumber ? 1 : 2)) + atRight;\r\n        const CurrentValue = this.SanitizeValue(f);\r\n        if (f === '' || Sanitize(f) === '') {\r\n          this.SetValue(null);\r\n          await Timeout(0);\r\n          this.input.nativeElement.setSelectionRange(0, 0);\r\n          return;\r\n        }\r\n        \r\n        //[ Handle Set Cursor Position]\r\n        this.SetValue(CurrentValue);\r\n        await Timeout(0);\r\n        let pos = isNumber ? selectionStart - 1 : selectionStart - 2;\r\n\r\n        if (selectionEnd == this.valueString.length) {\r\n          pos++;\r\n        }\r\n        this.input.nativeElement.setSelectionRange(pos, pos); \r\n        return;\r\n      }else\r\n      if(event.key == \"Delete\"){\r\n        const nextChar: string =  atRight[0];\r\n        const isNumber = lstNumbers.includes(nextChar);\r\n        const f = atLeft + atRight.slice(isNumber ? 1 : 2);\r\n        const CurrentValue = this.SanitizeValue(f);\r\n        if (f === '' || Sanitize(f) === '') {\r\n          this.SetValue(null);\r\n          await Timeout(0);\r\n          this.input.nativeElement.setSelectionRange(0, 0);\r\n          return;\r\n        }\r\n        //[ Handle Set Cursor Position]\r\n        this.SetValue(CurrentValue);\r\n        var pos: number = selectionStart;\r\n        if(pos <= -1){ pos = 0; }\r\n        if(CurrentValue < 1){\r\n          pos++;\r\n        }\r\n        if(!isNumber){\r\n          pos++;\r\n        }\r\n\r\n        await Timeout(0);\r\n        this.input.nativeElement.setSelectionRange(pos, pos);\r\n        return;\r\n      }\r\n    }else{\r\n      const f = atLeft + atRight;\r\n      const CurrentValue = this.SanitizeValue(f);\r\n      this.SetValue(CurrentValue);\r\n      \r\n      await Timeout(0);\r\n      this.input.nativeElement.setSelectionRange(this.valueString.length, this.valueString.length); \r\n\r\n      return;\r\n    }\r\n  }\r\n}\r\n\r\n\r\nconst decimalMaxValue = 9_000_000_000_000.00\r\n\r\nconst decimalSeparator : string = \",\";\r\nconst thousandSeparator: string = \".\";\r\n\r\nconst Sanitize: Function = ((v: string): string => { \r\n  return v.replaceAll(thousandSeparator, '')\r\n          .replace   (decimalSeparator , '') \r\n        });\r\n\r\nconst lstNumbers          = [ \"0\",\"1\",\"2\",\"3\",\"4\",\"5\",\"6\",\"7\",\"8\",\"9\" ];\r\nconst lstIgnoreNotPrevent = [ \"Tab\", \"CapsLock\", \"Shift\", \"Control\", \"Alt\", \"ArrowRight\", \"ArrowUp\", \"ArrowDown\", \"ArrowLeft\"];\r\nconst lstEspecialCases    = [ \"Backspace\", \"Delete\" ];","<div \r\n  #inputContainer\r\n  class=\"input-container\" \r\n  (click)=\"setFocus($event)\"\r\n  [class.required]=\"required()\" \r\n  [class.submitted]=\"submitted()\" \r\n  [class.invalid]=\"invalid\" \r\n  [class.disabled]=\"disabled() || loading()\"\r\n  [class.loading]=\"loading()\"\r\n>\r\n  <div class=\"input-label\"> \r\n    <span class=\"truncate\">\r\n      {{label()}} \r\n    </span>\r\n  </div>\r\n\r\n  <div class=\"decimal-input-container text-dark\">\r\n    <span *ngIf=\"configuration().prefix\" slot=\"start\">{{configuration().prefix}}</span>\r\n    <input #input\r\n      inputmode=\"numeric\"\r\n      [attr.placeholder]=\"!valueString ? placeholder() : null\"\r\n      [value]=\"valueString\" \r\n      (keydown)=\"onKeyDown($event)\"\r\n      [disabled]=\"disabled() || loading()\"\r\n      (blur)=\"blur.emit($event)\"\r\n    />\r\n    <span *ngIf=\"configuration().sufix\"  slot=\"end\"  >{{configuration().sufix}}</span>\r\n  </div>\r\n  <div class=\"loading-container\" [class.loading]=\"loading()\">\r\n    <ion-spinner></ion-spinner>\r\n  </div>\r\n</div>"]}
|
package/esm2022/lib/components/inputs/input-file/download-button/download-button.component.mjs
CHANGED
|
@@ -72,10 +72,10 @@ export class DownloadButtonComponent {
|
|
|
72
72
|
isLoading(path) {
|
|
73
73
|
return this.lstLoading.indexOf(path) != -1;
|
|
74
74
|
}
|
|
75
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.
|
|
76
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.
|
|
75
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DownloadButtonComponent, deps: [{ token: i1.StorageService }, { token: i0.ElementRef }, { token: i2.ApiUrlProviderService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
76
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: DownloadButtonComponent, selector: "download-button", inputs: { expand: { classPropertyName: "expand", publicName: "expand", isSignal: false, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: false, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: false, isRequired: false, transformFunction: null }, params: { classPropertyName: "params", publicName: "params", isSignal: false, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null }, post: { classPropertyName: "post", publicName: "post", isSignal: false, isRequired: false, transformFunction: null }, configuration: { classPropertyName: "configuration", publicName: "configuration", isSignal: false, isRequired: false, transformFunction: null }, customLabel: { classPropertyName: "customLabel", publicName: "customLabel", isSignal: false, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: false, isRequired: false, transformFunction: null }, fileName: { classPropertyName: "fileName", publicName: "fileName", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { value: "valueChange" }, providers: InputProviderFactory.GetProviders(DownloadButtonComponent), ngImport: i0, template: "@if(lstFiles().length == 0){\r\n <ion-button [color]=\"color\" fill=\"outline\" [disabled]=\"true\" [size]=\"size\"> \r\n <ion-icon name=\"close-circle\" slot=\"start\"></ion-icon> \r\n <ion-label> Sem arquivos... </ion-label>\r\n </ion-button>\r\n}\r\n@else if(lstFiles().length == 1){\r\n <ion-button [color]=\"color\" *ngVar=\"storageService.GetProgress(lstFiles()[0]) as val\" class=\"relative block {{expand == 'block' ? 'size-full' : ''}}\" [disabled]=\"val != 0 || disabled\" (click)=\"Download(lstFiles()[0])\" fill=\"outline\" [size]=\"size\"> \r\n <ion-icon name=\"download\" slot=\"start\"></ion-icon> \r\n <ion-label> {{customLabel ? label : Sanitize(lstFiles()[0])}} </ion-label>\r\n <div class=\"absolute size-full h-[calc(100%+var(--padding-top)+var(--padding-bottom))] w-[calc(100%+var(--padding-end)+var(--padding-start))]\">\r\n <loading [type]=\"3\" [loading]=\"val != 0\"></loading>\r\n <div class=\"size-full flex flex-row-reverse relative\">\r\n <ion-progress-bar class=\"absolute bottom-0 left-0 w-full h-1 default-transition\" [ngClass]=\"{'-translate-y-4 opacity-0': (!val || val == 0)}\" [value]=\"val\"></ion-progress-bar>\r\n </div>\r\n </div>\r\n </ion-button>\r\n}\r\n@else{\r\n <ion-button [color]=\"color\" [id]=\"guid\" fill=\"outline\" [size]=\"size\"> \r\n <ion-icon name=\"download\" slot=\"start\"></ion-icon> \r\n <ion-label> {{lstFiles().length}} Arquivos </ion-label>\r\n </ion-button>\r\n\r\n <ion-popover [trigger]=\"guid\" [keepContentsMounted]=\"true\" triggerAction=\"click\">\r\n <ng-template>\r\n <ion-content class=\"p-0 bg-transparent\">\r\n <ion-list>\r\n @for (item of lstFiles(); track item; let i = $index; let l = $last) {\r\n <section *ngVar=\"storageService.GetProgress(item) as val\">\r\n <ion-item style=\"--background: transparent\" lines=\"{{l ? 'none' : 'full'}}\" button [detail]=\"false\">\r\n\r\n <ion-icon name=\"download\" (click)=\"Download(item)\" slot=\"start\"></ion-icon> \r\n @if (ExtensionIsImage(item)) {\r\n <ion-icon [id]=\"guid + '-' + i + '-nested-popover'\" name=\"image\" slot=\"start\"></ion-icon> \r\n }\r\n\r\n <ion-label>{{Sanitize(item)}}</ion-label>\r\n <ion-text *ngIf=\"val != 0\" slot=\"end\" class=\"text-sm\"><b>{{val * 100 | number : '1.2-2'}}%</b></ion-text>\r\n </ion-item>\r\n <ion-progress-bar class=\"h-0 default-transition\" [ngClass]=\"{'h-1': val != 0 }\" [value]=\"val\"></ion-progress-bar>\r\n <ion-popover *ngIf=\"ExtensionIsImage(item)\" side=\"end\" alignment=\"center\" [trigger]=\"guid + '-' + i + '-nested-popover'\" [dismissOnSelect]=\"true\" triggerAction=\"click\">\r\n <ng-template>\r\n <ion-content *ngVar=\"isLoading(item) as isLoading\">\r\n <loading [hidden]=\"!isLoading\"></loading>\r\n <ion-img [hidden]=\"isLoading\" [src]=\"apiUrl + item\" (ionImgWillLoad)=\"SetLoading(item)\" (ionImgDidLoad)=\"SetNotLoading(item)\"></ion-img>\r\n </ion-content>\r\n </ng-template>\r\n </ion-popover>\r\n </section>\r\n }\r\n </ion-list>\r\n </ion-content>\r\n </ng-template>\r\n </ion-popover>\r\n}", styles: ["ion-popover{--width: 30rem }\n"], dependencies: [{ kind: "component", type: i3.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i3.IonContent, selector: "ion-content", inputs: ["color", "fixedSlotPlacement", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonImg, selector: "ion-img", inputs: ["alt", "src"] }, { kind: "component", type: i3.IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i3.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i3.IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: i3.IonProgressBar, selector: "ion-progress-bar", inputs: ["buffer", "color", "mode", "reversed", "type", "value"] }, { kind: "component", type: i3.IonText, selector: "ion-text", inputs: ["color", "mode"] }, { kind: "component", type: i3.IonPopover, selector: "ion-popover" }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.LoadingComponent, selector: "loading", inputs: ["text", "type", "loading"] }, { kind: "directive", type: i6.NgVarDirective, selector: "[ngVar]", inputs: ["ngVar"] }, { kind: "pipe", type: i4.DecimalPipe, name: "number" }] }); }
|
|
77
77
|
}
|
|
78
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.
|
|
78
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DownloadButtonComponent, decorators: [{
|
|
79
79
|
type: Component,
|
|
80
80
|
args: [{ selector: 'download-button', providers: InputProviderFactory.GetProviders(DownloadButtonComponent), template: "@if(lstFiles().length == 0){\r\n <ion-button [color]=\"color\" fill=\"outline\" [disabled]=\"true\" [size]=\"size\"> \r\n <ion-icon name=\"close-circle\" slot=\"start\"></ion-icon> \r\n <ion-label> Sem arquivos... </ion-label>\r\n </ion-button>\r\n}\r\n@else if(lstFiles().length == 1){\r\n <ion-button [color]=\"color\" *ngVar=\"storageService.GetProgress(lstFiles()[0]) as val\" class=\"relative block {{expand == 'block' ? 'size-full' : ''}}\" [disabled]=\"val != 0 || disabled\" (click)=\"Download(lstFiles()[0])\" fill=\"outline\" [size]=\"size\"> \r\n <ion-icon name=\"download\" slot=\"start\"></ion-icon> \r\n <ion-label> {{customLabel ? label : Sanitize(lstFiles()[0])}} </ion-label>\r\n <div class=\"absolute size-full h-[calc(100%+var(--padding-top)+var(--padding-bottom))] w-[calc(100%+var(--padding-end)+var(--padding-start))]\">\r\n <loading [type]=\"3\" [loading]=\"val != 0\"></loading>\r\n <div class=\"size-full flex flex-row-reverse relative\">\r\n <ion-progress-bar class=\"absolute bottom-0 left-0 w-full h-1 default-transition\" [ngClass]=\"{'-translate-y-4 opacity-0': (!val || val == 0)}\" [value]=\"val\"></ion-progress-bar>\r\n </div>\r\n </div>\r\n </ion-button>\r\n}\r\n@else{\r\n <ion-button [color]=\"color\" [id]=\"guid\" fill=\"outline\" [size]=\"size\"> \r\n <ion-icon name=\"download\" slot=\"start\"></ion-icon> \r\n <ion-label> {{lstFiles().length}} Arquivos </ion-label>\r\n </ion-button>\r\n\r\n <ion-popover [trigger]=\"guid\" [keepContentsMounted]=\"true\" triggerAction=\"click\">\r\n <ng-template>\r\n <ion-content class=\"p-0 bg-transparent\">\r\n <ion-list>\r\n @for (item of lstFiles(); track item; let i = $index; let l = $last) {\r\n <section *ngVar=\"storageService.GetProgress(item) as val\">\r\n <ion-item style=\"--background: transparent\" lines=\"{{l ? 'none' : 'full'}}\" button [detail]=\"false\">\r\n\r\n <ion-icon name=\"download\" (click)=\"Download(item)\" slot=\"start\"></ion-icon> \r\n @if (ExtensionIsImage(item)) {\r\n <ion-icon [id]=\"guid + '-' + i + '-nested-popover'\" name=\"image\" slot=\"start\"></ion-icon> \r\n }\r\n\r\n <ion-label>{{Sanitize(item)}}</ion-label>\r\n <ion-text *ngIf=\"val != 0\" slot=\"end\" class=\"text-sm\"><b>{{val * 100 | number : '1.2-2'}}%</b></ion-text>\r\n </ion-item>\r\n <ion-progress-bar class=\"h-0 default-transition\" [ngClass]=\"{'h-1': val != 0 }\" [value]=\"val\"></ion-progress-bar>\r\n <ion-popover *ngIf=\"ExtensionIsImage(item)\" side=\"end\" alignment=\"center\" [trigger]=\"guid + '-' + i + '-nested-popover'\" [dismissOnSelect]=\"true\" triggerAction=\"click\">\r\n <ng-template>\r\n <ion-content *ngVar=\"isLoading(item) as isLoading\">\r\n <loading [hidden]=\"!isLoading\"></loading>\r\n <ion-img [hidden]=\"isLoading\" [src]=\"apiUrl + item\" (ionImgWillLoad)=\"SetLoading(item)\" (ionImgDidLoad)=\"SetNotLoading(item)\"></ion-img>\r\n </ion-content>\r\n </ng-template>\r\n </ion-popover>\r\n </section>\r\n }\r\n </ion-list>\r\n </ion-content>\r\n </ng-template>\r\n </ion-popover>\r\n}", styles: ["ion-popover{--width: 30rem }\n"] }]
|
|
81
81
|
}], ctorParameters: () => [{ type: i1.StorageService }, { type: i0.ElementRef }, { type: i2.ApiUrlProviderService }], propDecorators: { expand: [{
|