@softpak/components 0.3.5 → 0.3.7
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/placeholder.mjs +2 -0
- package/esm2022/public_api.mjs +2 -0
- package/esm2022/softpak-components.mjs +5 -0
- package/esm2022/spx-alert/public-api.mjs +3 -0
- package/esm2022/spx-alert/softpak-components-spx-alert.mjs +5 -0
- package/esm2022/spx-alert/spx-alert.component.mjs +193 -0
- package/esm2022/spx-alert/spx-alert.interface.mjs +3 -0
- package/esm2022/spx-app-configuration/public-api.mjs +8 -0
- package/esm2022/spx-app-configuration/softpak-components-spx-app-configuration.mjs +5 -0
- package/esm2022/spx-app-configuration/spx-app-alert.interface.mjs +2 -0
- package/esm2022/spx-app-configuration/spx-app-bundle-set.interface.mjs +2 -0
- package/esm2022/spx-app-configuration/spx-app-channel-type.enum.mjs +8 -0
- package/esm2022/spx-app-configuration/spx-app-channel.interface.mjs +2 -0
- package/esm2022/spx-app-configuration/spx-app-config.interface.mjs +2 -0
- package/esm2022/spx-app-configuration/spx-app-id.enum.mjs +8 -0
- package/esm2022/spx-app-configuration/spx-app-lang.enum.mjs +6 -0
- package/esm2022/spx-app-configuration/spx-app-release-note.interface.mjs +2 -0
- package/esm2022/spx-app-expiry/public-api.mjs +6 -0
- package/esm2022/spx-app-expiry/softpak-components-spx-app-expiry.mjs +5 -0
- package/esm2022/spx-app-expiry/spx-app-expiry.component.mjs +90 -0
- package/esm2022/spx-app-expiry/spx-app-expiry.interface.mjs +2 -0
- package/esm2022/spx-app-expiry/spx-check-expiry-final-warning.interface.mjs +5 -0
- package/esm2022/spx-app-expiry/spx-check-expiry-happened.interface.mjs +5 -0
- package/esm2022/spx-app-expiry/spx-check-expiry-warning.interface.mjs +5 -0
- package/esm2022/spx-app-update/public-api.mjs +2 -0
- package/esm2022/spx-app-update/softpak-components-spx-app-update.mjs +5 -0
- package/esm2022/spx-app-update/spx-app-update.component.mjs +314 -0
- package/esm2022/spx-button/public-api.mjs +2 -0
- package/esm2022/spx-button/softpak-components-spx-button.mjs +5 -0
- package/esm2022/spx-button/spx-button.component.mjs +142 -0
- package/esm2022/spx-capitalize/public-api.mjs +2 -0
- package/esm2022/spx-capitalize/softpak-components-spx-capitalize.mjs +5 -0
- package/esm2022/spx-capitalize/spx-capitalize.pipe.mjs +20 -0
- package/esm2022/spx-card/public-api.mjs +5 -0
- package/esm2022/spx-card/softpak-components-spx-card.mjs +5 -0
- package/esm2022/spx-card/spx-card-grid.component.mjs +46 -0
- package/esm2022/spx-card/spx-card-item.component.mjs +111 -0
- package/esm2022/spx-card/spx-card-line.component.mjs +101 -0
- package/esm2022/spx-card/spx-card.component.mjs +93 -0
- package/esm2022/spx-change-details/public-api.mjs +2 -0
- package/esm2022/spx-change-details/softpak-components-spx-change-details.mjs +5 -0
- package/esm2022/spx-change-details/spx-change-details-value.interface.mjs +2 -0
- package/esm2022/spx-change-details/spx-change-details.component.mjs +199 -0
- package/esm2022/spx-channel-selection/public-api.mjs +3 -0
- package/esm2022/spx-channel-selection/softpak-components-spx-channel-selection.mjs +5 -0
- package/esm2022/spx-channel-selection/src/spx-channel-indicator.component.mjs +45 -0
- package/esm2022/spx-channel-selection/src/spx-welcome.component.mjs +135 -0
- package/esm2022/spx-check-digit/public-api.mjs +2 -0
- package/esm2022/spx-check-digit/softpak-components-spx-check-digit.mjs +5 -0
- package/esm2022/spx-check-digit/spx-check-digit.component.mjs +94 -0
- package/esm2022/spx-form-section/public-api.mjs +2 -0
- package/esm2022/spx-form-section/softpak-components-spx-form-section.mjs +5 -0
- package/esm2022/spx-form-section/spx-form-section.component.mjs +37 -0
- package/esm2022/spx-form-view/public-api.mjs +7 -0
- package/esm2022/spx-form-view/softpak-components-spx-form-view.mjs +5 -0
- package/esm2022/spx-form-view/spx-autocomplete-search.component.mjs +119 -0
- package/esm2022/spx-form-view/spx-form-button-type.enum.mjs +6 -0
- package/esm2022/spx-form-view/spx-form-button.interface.mjs +2 -0
- package/esm2022/spx-form-view/spx-form-field.interface.mjs +2 -0
- package/esm2022/spx-form-view/spx-form-section.interface.mjs +2 -0
- package/esm2022/spx-form-view/spx-form-view.component.mjs +289 -0
- package/esm2022/spx-form-view/spx-form.interface.mjs +2 -0
- package/esm2022/spx-helpers/calc-check-digit.function.mjs +21 -0
- package/esm2022/spx-helpers/public-api.mjs +4 -0
- package/esm2022/spx-helpers/softpak-components-spx-helpers.mjs +5 -0
- package/esm2022/spx-helpers/spx-severity.enum.mjs +9 -0
- package/esm2022/spx-helpers/value-pair-to-value.function.mjs +7 -0
- package/esm2022/spx-inputs/public-api.mjs +6 -0
- package/esm2022/spx-inputs/softpak-components-spx-inputs.mjs +5 -0
- package/esm2022/spx-inputs/spx-dropdown.component.mjs +94 -0
- package/esm2022/spx-inputs/spx-input-box.component.mjs +255 -0
- package/esm2022/spx-inputs/spx-input-date.component.mjs +294 -0
- package/esm2022/spx-inputs/spx-input-float.component.mjs +159 -0
- package/esm2022/spx-inputs/spx-input-number.component.mjs +87 -0
- package/esm2022/spx-inputs/spx-input-radio.component.mjs +129 -0
- package/esm2022/spx-inputs/spx-input-text.component.mjs +156 -0
- package/esm2022/spx-inputs/spx-input-time-modal.component.mjs +116 -0
- package/esm2022/spx-inputs/spx-input-time.component.mjs +166 -0
- package/esm2022/spx-inputs/spx-input-type.enum.mjs +17 -0
- package/esm2022/spx-inputs/spx-input.component.mjs +449 -0
- package/esm2022/spx-inputs/spx-value-interface.mjs +2 -0
- package/esm2022/spx-navigation/public-api.mjs +5 -0
- package/esm2022/spx-navigation/softpak-components-spx-navigation.mjs +5 -0
- package/esm2022/spx-navigation/spx-home-tile.component.mjs +68 -0
- package/esm2022/spx-navigation/spx-home-tiles.component.mjs +24 -0
- package/esm2022/spx-navigation/spx-navigation-item.interface.mjs +2 -0
- package/esm2022/spx-navigation/spx-navigation.component.mjs +51 -0
- package/esm2022/spx-number-check/public-api.mjs +2 -0
- package/esm2022/spx-number-check/softpak-components-spx-number-check.mjs +5 -0
- package/esm2022/spx-number-check/spx-number-check.component.mjs +259 -0
- package/esm2022/spx-pagination/public-api.mjs +2 -0
- package/esm2022/spx-pagination/softpak-components-spx-pagination.mjs +5 -0
- package/esm2022/spx-pagination/spx-pagination.component.mjs +44 -0
- package/esm2022/spx-patch/patch-check.function.mjs +9 -0
- package/esm2022/spx-patch/public-api.mjs +4 -0
- package/esm2022/spx-patch/release-check.function.mjs +14 -0
- package/esm2022/spx-patch/softpak-components-spx-patch.mjs +5 -0
- package/esm2022/spx-patch/spx-patch.component.mjs +48 -0
- package/esm2022/spx-progress-bar/public-api.mjs +2 -0
- package/esm2022/spx-progress-bar/softpak-components-spx-progress-bar.mjs +5 -0
- package/esm2022/spx-progress-bar/spx-progress-bar.component.mjs +29 -0
- package/esm2022/spx-spinner/public-api.mjs +2 -0
- package/esm2022/spx-spinner/softpak-components-spx-spinner.mjs +5 -0
- package/esm2022/spx-spinner/spx-spinner.component.mjs +159 -0
- package/esm2022/spx-stock-info/public-api.mjs +3 -0
- package/esm2022/spx-stock-info/softpak-components-spx-stock-info.mjs +5 -0
- package/esm2022/spx-stock-info/spx-stock-info-value.interface.mjs +2 -0
- package/esm2022/spx-stock-info/spx-stock-info.component.mjs +327 -0
- package/esm2022/spx-storage/public-api.mjs +3 -0
- package/esm2022/spx-storage/softpak-components-spx-storage.mjs +5 -0
- package/esm2022/spx-storage/src/spx-storage-key.enum.mjs +13 -0
- package/esm2022/spx-storage/src/spx-storage.class.mjs +45 -0
- package/esm2022/spx-suggestion/public-api.mjs +2 -0
- package/esm2022/spx-suggestion/softpak-components-spx-suggestion.mjs +5 -0
- package/esm2022/spx-suggestion/spx-suggestion.component.mjs +69 -0
- package/esm2022/spx-toaster/public-api.mjs +4 -0
- package/esm2022/spx-toaster/softpak-components-spx-toaster.mjs +5 -0
- package/esm2022/spx-toaster/src/spx-toaster-autoclose-speed.mjs +23 -0
- package/esm2022/spx-toaster/src/spx-toaster-message.interface.mjs +3 -0
- package/esm2022/spx-toaster/src/spx-toaster.component.mjs +173 -0
- package/esm2022/spx-update/public-api.mjs +3 -0
- package/esm2022/spx-update/softpak-components-spx-update.mjs +5 -0
- package/esm2022/spx-update/src/spx-update-info.component.mjs +88 -0
- package/esm2022/spx-update/src/spx-update-progress.component.mjs +46 -0
- package/esm2022/spx-validation/max.validator.mjs +17 -0
- package/esm2022/spx-validation/maxlength.validator.mjs +20 -0
- package/esm2022/spx-validation/min.validator.mjs +17 -0
- package/esm2022/spx-validation/minlength.validator.mjs +20 -0
- package/esm2022/spx-validation/pattern.validator.mjs +12 -0
- package/esm2022/spx-validation/public-api.mjs +9 -0
- package/esm2022/spx-validation/required.validator.mjs +12 -0
- package/esm2022/spx-validation/softpak-components-spx-validation.mjs +5 -0
- package/esm2022/spx-validation/spx-validate-control.component.mjs +68 -0
- package/esm2022/spx-validation/year-and-month.validator.mjs +42 -0
- package/fesm2022/softpak-components-spx-alert.mjs +3 -3
- package/fesm2022/softpak-components-spx-alert.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-app-configuration.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-app-expiry.mjs +3 -3
- package/fesm2022/softpak-components-spx-app-expiry.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-app-update.mjs +3 -3
- package/fesm2022/softpak-components-spx-app-update.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-button.mjs +3 -3
- package/fesm2022/softpak-components-spx-button.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-capitalize.mjs +3 -3
- package/fesm2022/softpak-components-spx-capitalize.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-card.mjs +16 -16
- package/fesm2022/softpak-components-spx-card.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-change-details.mjs +3 -3
- package/fesm2022/softpak-components-spx-change-details.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-channel-selection.mjs +6 -6
- package/fesm2022/softpak-components-spx-channel-selection.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-check-digit.mjs +3 -3
- package/fesm2022/softpak-components-spx-check-digit.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-form-section.mjs +3 -3
- package/fesm2022/softpak-components-spx-form-section.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-form-view.mjs +6 -6
- package/fesm2022/softpak-components-spx-form-view.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-helpers.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-inputs.mjs +30 -30
- package/fesm2022/softpak-components-spx-inputs.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-navigation.mjs +9 -9
- package/fesm2022/softpak-components-spx-navigation.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-number-check.mjs +3 -3
- package/fesm2022/softpak-components-spx-number-check.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-pagination.mjs +3 -3
- package/fesm2022/softpak-components-spx-pagination.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-patch.mjs +3 -3
- package/fesm2022/softpak-components-spx-patch.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-progress-bar.mjs +3 -3
- package/fesm2022/softpak-components-spx-progress-bar.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-spinner.mjs +3 -3
- package/fesm2022/softpak-components-spx-spinner.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-stock-info.mjs +3 -3
- package/fesm2022/softpak-components-spx-stock-info.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-storage.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-suggestion.mjs +3 -3
- package/fesm2022/softpak-components-spx-suggestion.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-toaster.mjs +4 -4
- package/fesm2022/softpak-components-spx-toaster.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-update.mjs +6 -6
- package/fesm2022/softpak-components-spx-update.mjs.map +1 -1
- package/fesm2022/softpak-components-spx-validation.mjs +3 -3
- package/fesm2022/softpak-components-spx-validation.mjs.map +1 -1
- package/package.json +75 -21
- package/tailwind.css +1 -1
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
import { NgIf } from '@angular/common';
|
|
2
|
+
import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
|
3
|
+
import { SpxButtonComponent } from '@softpak/components/spx-button';
|
|
4
|
+
import { FontAwesomeModule } from '@fortawesome/angular-fontawesome';
|
|
5
|
+
import { faEdit, faQuestion, faSearch, faTimes } from '@fortawesome/free-solid-svg-icons';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@fortawesome/angular-fontawesome";
|
|
8
|
+
export class SpxInputBoxComponent {
|
|
9
|
+
handleFocusIn(ev) {
|
|
10
|
+
this.emitFocusIn();
|
|
11
|
+
}
|
|
12
|
+
handleFocusOut(ev) {
|
|
13
|
+
const thisEl = this.elRef.nativeElement;
|
|
14
|
+
const relatedElement = ev.relatedTarget;
|
|
15
|
+
if (!relatedElement || !thisEl.contains(relatedElement)) {
|
|
16
|
+
this.emitFocusOut();
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
handleWindowClick(ev) {
|
|
20
|
+
if (ev.composedPath().includes(this.elRef.nativeElement)) {
|
|
21
|
+
this.emitFocusIn();
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
this.emitFocusOut();
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
onClear() {
|
|
28
|
+
this.spxClear.emit();
|
|
29
|
+
}
|
|
30
|
+
onSearch() {
|
|
31
|
+
this.spxSearch.emit();
|
|
32
|
+
}
|
|
33
|
+
onEdit() {
|
|
34
|
+
this.spxEdit.emit();
|
|
35
|
+
}
|
|
36
|
+
onHelp() {
|
|
37
|
+
this.spxHelp.emit();
|
|
38
|
+
}
|
|
39
|
+
constructor(elRef) {
|
|
40
|
+
this.elRef = elRef;
|
|
41
|
+
this.faEdit = faEdit;
|
|
42
|
+
this.faSearch = faSearch;
|
|
43
|
+
this.faQuestion = faQuestion;
|
|
44
|
+
this.faTimes = faTimes;
|
|
45
|
+
this.spxFocused = false;
|
|
46
|
+
this.spxReadonly = false;
|
|
47
|
+
this.spxShowClear = true;
|
|
48
|
+
this.spxShowLabel = true;
|
|
49
|
+
this.spxClear = new EventEmitter();
|
|
50
|
+
this.spxSearch = new EventEmitter();
|
|
51
|
+
this.spxFocus = new EventEmitter();
|
|
52
|
+
this.spxFocusOut = new EventEmitter();
|
|
53
|
+
this.spxEdit = new EventEmitter();
|
|
54
|
+
this.spxHelp = new EventEmitter();
|
|
55
|
+
}
|
|
56
|
+
emitFocusIn() {
|
|
57
|
+
if (!this.spxFocused) {
|
|
58
|
+
this.spxFocus.emit();
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
emitFocusOut() {
|
|
62
|
+
if (this.spxFocused) {
|
|
63
|
+
this.spxFocusOut.emit();
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SpxInputBoxComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
67
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SpxInputBoxComponent, isStandalone: true, selector: "spx-input-box", inputs: { spxCompact: "spxCompact", spxFocused: "spxFocused", spxLabel: "spxLabel", spxReadonly: "spxReadonly", spxRequired: "spxRequired", spxShowClear: "spxShowClear", spxShowEdit: "spxShowEdit", spxShowHelp: "spxShowHelp", spxShowLabel: "spxShowLabel", spxShowSearch: "spxShowSearch", spxShowValidationMessages: "spxShowValidationMessages", spxValue: "spxValue" }, outputs: { spxClear: "spxClear", spxSearch: "spxSearch", spxFocus: "spxFocus", spxFocusOut: "spxFocusOut", spxEdit: "spxEdit", spxHelp: "spxHelp" }, host: { listeners: { "focusin": "handleFocusIn($event)", "focusout": "handleFocusOut($event)", "document:click": "handleWindowClick($event)" } }, ngImport: i0, template: `<div class="flex rounded w-full gap-3"
|
|
68
|
+
[class.rounded-none]="this.spxShowValidationMessages"
|
|
69
|
+
[class.rounded-t]="this.spxShowValidationMessages"
|
|
70
|
+
[class.outline-none]="this.spxFocused && !this.spxReadonly"
|
|
71
|
+
[class.ring-2]="this.spxFocused && !this.spxReadonly"
|
|
72
|
+
[class.ring-offset-2]="this.spxFocused && !this.spxReadonly"
|
|
73
|
+
[class.ring-blue-500]="this.spxFocused && !this.spxReadonly"
|
|
74
|
+
[class.bg-white]="!this.spxReadonly"
|
|
75
|
+
[class.bg-gray-300]="this.spxReadonly"
|
|
76
|
+
[class.cursor-not-allowed]="this.spxReadonly">
|
|
77
|
+
<div class="flex-auto p-3"
|
|
78
|
+
[class.p-0]="this.spxCompact"
|
|
79
|
+
[class.flex]="this.spxCompact"
|
|
80
|
+
[class.items-center]="this.spxCompact">
|
|
81
|
+
<div *ngIf="this.spxShowLabel" class="font-bold text-sm mb-1 text-gray-800"
|
|
82
|
+
[class.mb-0]="this.spxCompact"
|
|
83
|
+
[class.px-3]="this.spxCompact">
|
|
84
|
+
{{this.spxLabel}} <span *ngIf="spxRequired" class="text-red-800">*</span>
|
|
85
|
+
</div>
|
|
86
|
+
<ng-content select="[controls]"></ng-content>
|
|
87
|
+
</div>
|
|
88
|
+
<div class="flex flex-none gap-1 p-1">
|
|
89
|
+
<spx-button
|
|
90
|
+
*ngIf="this.spxShowEdit"
|
|
91
|
+
(spxClick)="onEdit()"
|
|
92
|
+
[spxFullHeight]="true"
|
|
93
|
+
[spxSize]="'xl'"
|
|
94
|
+
[spxType]="'button'">
|
|
95
|
+
<fa-icon [icon]="faEdit" class="block text-xl"></fa-icon>
|
|
96
|
+
</spx-button>
|
|
97
|
+
<spx-button
|
|
98
|
+
*ngIf="this.spxShowHelp"
|
|
99
|
+
(spxClick)="onHelp()"
|
|
100
|
+
[spxFullHeight]="true"
|
|
101
|
+
[spxDisabled]="this.spxReadonly"
|
|
102
|
+
[spxSize]="'xl'"
|
|
103
|
+
[spxTabIndex]="-1"
|
|
104
|
+
[spxType]="'button'">
|
|
105
|
+
<fa-icon [icon]="faQuestion" class="block text-xl"></fa-icon>
|
|
106
|
+
</spx-button>
|
|
107
|
+
<spx-button
|
|
108
|
+
*ngIf="this.spxShowSearch"
|
|
109
|
+
(spxClick)="onSearch()"
|
|
110
|
+
[spxFullHeight]="true"
|
|
111
|
+
[spxDisabled]="this.spxReadonly"
|
|
112
|
+
[spxSize]="'xl'"
|
|
113
|
+
[spxTabIndex]="-1"
|
|
114
|
+
[spxType]="'button'">
|
|
115
|
+
<fa-icon [icon]="faSearch" class="block text-xl"></fa-icon>
|
|
116
|
+
</spx-button>
|
|
117
|
+
<spx-button
|
|
118
|
+
*ngIf="this.spxShowClear"
|
|
119
|
+
(spxClick)="onClear()"
|
|
120
|
+
[spxDisabled]="this.spxReadonly || !this.spxValue?.value"
|
|
121
|
+
[spxFullHeight]="true"
|
|
122
|
+
[spxSize]="'xl'"
|
|
123
|
+
[spxTabIndex]="-1"
|
|
124
|
+
[spxType]="'button'">
|
|
125
|
+
<fa-icon [icon]="faTimes" class="block text-xl"></fa-icon>
|
|
126
|
+
</spx-button>
|
|
127
|
+
</div>
|
|
128
|
+
</div>
|
|
129
|
+
<div *ngIf="this.spxShowValidationMessages" class="bg-red-600 rounded-b text-white p-3">
|
|
130
|
+
<ng-content select="[validation-messages]"></ng-content>
|
|
131
|
+
</div>`, isInline: true, dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: SpxButtonComponent, selector: "spx-button", inputs: ["spxDisabled", "spxClass", "spxClassObject", "spxForm", "spxFullHeight", "spxFullWidth", "spxSeverity", "spxSize", "spxTabIndex", "spxType"], outputs: ["spxClick"] }, { kind: "ngmodule", type: FontAwesomeModule }, { kind: "component", type: i1.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "mask", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }] }); }
|
|
132
|
+
}
|
|
133
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SpxInputBoxComponent, decorators: [{
|
|
134
|
+
type: Component,
|
|
135
|
+
args: [{
|
|
136
|
+
selector: 'spx-input-box',
|
|
137
|
+
standalone: true,
|
|
138
|
+
imports: [
|
|
139
|
+
NgIf,
|
|
140
|
+
SpxButtonComponent,
|
|
141
|
+
FontAwesomeModule,
|
|
142
|
+
],
|
|
143
|
+
template: `<div class="flex rounded w-full gap-3"
|
|
144
|
+
[class.rounded-none]="this.spxShowValidationMessages"
|
|
145
|
+
[class.rounded-t]="this.spxShowValidationMessages"
|
|
146
|
+
[class.outline-none]="this.spxFocused && !this.spxReadonly"
|
|
147
|
+
[class.ring-2]="this.spxFocused && !this.spxReadonly"
|
|
148
|
+
[class.ring-offset-2]="this.spxFocused && !this.spxReadonly"
|
|
149
|
+
[class.ring-blue-500]="this.spxFocused && !this.spxReadonly"
|
|
150
|
+
[class.bg-white]="!this.spxReadonly"
|
|
151
|
+
[class.bg-gray-300]="this.spxReadonly"
|
|
152
|
+
[class.cursor-not-allowed]="this.spxReadonly">
|
|
153
|
+
<div class="flex-auto p-3"
|
|
154
|
+
[class.p-0]="this.spxCompact"
|
|
155
|
+
[class.flex]="this.spxCompact"
|
|
156
|
+
[class.items-center]="this.spxCompact">
|
|
157
|
+
<div *ngIf="this.spxShowLabel" class="font-bold text-sm mb-1 text-gray-800"
|
|
158
|
+
[class.mb-0]="this.spxCompact"
|
|
159
|
+
[class.px-3]="this.spxCompact">
|
|
160
|
+
{{this.spxLabel}} <span *ngIf="spxRequired" class="text-red-800">*</span>
|
|
161
|
+
</div>
|
|
162
|
+
<ng-content select="[controls]"></ng-content>
|
|
163
|
+
</div>
|
|
164
|
+
<div class="flex flex-none gap-1 p-1">
|
|
165
|
+
<spx-button
|
|
166
|
+
*ngIf="this.spxShowEdit"
|
|
167
|
+
(spxClick)="onEdit()"
|
|
168
|
+
[spxFullHeight]="true"
|
|
169
|
+
[spxSize]="'xl'"
|
|
170
|
+
[spxType]="'button'">
|
|
171
|
+
<fa-icon [icon]="faEdit" class="block text-xl"></fa-icon>
|
|
172
|
+
</spx-button>
|
|
173
|
+
<spx-button
|
|
174
|
+
*ngIf="this.spxShowHelp"
|
|
175
|
+
(spxClick)="onHelp()"
|
|
176
|
+
[spxFullHeight]="true"
|
|
177
|
+
[spxDisabled]="this.spxReadonly"
|
|
178
|
+
[spxSize]="'xl'"
|
|
179
|
+
[spxTabIndex]="-1"
|
|
180
|
+
[spxType]="'button'">
|
|
181
|
+
<fa-icon [icon]="faQuestion" class="block text-xl"></fa-icon>
|
|
182
|
+
</spx-button>
|
|
183
|
+
<spx-button
|
|
184
|
+
*ngIf="this.spxShowSearch"
|
|
185
|
+
(spxClick)="onSearch()"
|
|
186
|
+
[spxFullHeight]="true"
|
|
187
|
+
[spxDisabled]="this.spxReadonly"
|
|
188
|
+
[spxSize]="'xl'"
|
|
189
|
+
[spxTabIndex]="-1"
|
|
190
|
+
[spxType]="'button'">
|
|
191
|
+
<fa-icon [icon]="faSearch" class="block text-xl"></fa-icon>
|
|
192
|
+
</spx-button>
|
|
193
|
+
<spx-button
|
|
194
|
+
*ngIf="this.spxShowClear"
|
|
195
|
+
(spxClick)="onClear()"
|
|
196
|
+
[spxDisabled]="this.spxReadonly || !this.spxValue?.value"
|
|
197
|
+
[spxFullHeight]="true"
|
|
198
|
+
[spxSize]="'xl'"
|
|
199
|
+
[spxTabIndex]="-1"
|
|
200
|
+
[spxType]="'button'">
|
|
201
|
+
<fa-icon [icon]="faTimes" class="block text-xl"></fa-icon>
|
|
202
|
+
</spx-button>
|
|
203
|
+
</div>
|
|
204
|
+
</div>
|
|
205
|
+
<div *ngIf="this.spxShowValidationMessages" class="bg-red-600 rounded-b text-white p-3">
|
|
206
|
+
<ng-content select="[validation-messages]"></ng-content>
|
|
207
|
+
</div>`,
|
|
208
|
+
}]
|
|
209
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { spxCompact: [{
|
|
210
|
+
type: Input
|
|
211
|
+
}], spxFocused: [{
|
|
212
|
+
type: Input
|
|
213
|
+
}], spxLabel: [{
|
|
214
|
+
type: Input
|
|
215
|
+
}], spxReadonly: [{
|
|
216
|
+
type: Input
|
|
217
|
+
}], spxRequired: [{
|
|
218
|
+
type: Input
|
|
219
|
+
}], spxShowClear: [{
|
|
220
|
+
type: Input
|
|
221
|
+
}], spxShowEdit: [{
|
|
222
|
+
type: Input
|
|
223
|
+
}], spxShowHelp: [{
|
|
224
|
+
type: Input
|
|
225
|
+
}], spxShowLabel: [{
|
|
226
|
+
type: Input
|
|
227
|
+
}], spxShowSearch: [{
|
|
228
|
+
type: Input
|
|
229
|
+
}], spxShowValidationMessages: [{
|
|
230
|
+
type: Input
|
|
231
|
+
}], spxValue: [{
|
|
232
|
+
type: Input
|
|
233
|
+
}], spxClear: [{
|
|
234
|
+
type: Output
|
|
235
|
+
}], spxSearch: [{
|
|
236
|
+
type: Output
|
|
237
|
+
}], spxFocus: [{
|
|
238
|
+
type: Output
|
|
239
|
+
}], spxFocusOut: [{
|
|
240
|
+
type: Output
|
|
241
|
+
}], spxEdit: [{
|
|
242
|
+
type: Output
|
|
243
|
+
}], spxHelp: [{
|
|
244
|
+
type: Output
|
|
245
|
+
}], handleFocusIn: [{
|
|
246
|
+
type: HostListener,
|
|
247
|
+
args: ['focusin', ["$event"]]
|
|
248
|
+
}], handleFocusOut: [{
|
|
249
|
+
type: HostListener,
|
|
250
|
+
args: ['focusout', ["$event"]]
|
|
251
|
+
}], handleWindowClick: [{
|
|
252
|
+
type: HostListener,
|
|
253
|
+
args: ['document:click', ["$event"]]
|
|
254
|
+
}] } });
|
|
255
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3B4LWlucHV0LWJveC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zb2Z0cGFrL2NvbXBvbmVudHMvc3B4LWlucHV0cy9zcHgtaW5wdXQtYm94LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdkMsT0FBTyxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakcsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFFcEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDckUsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxNQUFNLG1DQUFtQyxDQUFDOzs7QUE0RTFGLE1BQU0sT0FBTyxvQkFBb0I7SUF1Qk0sYUFBYSxDQUFDLEVBQVM7UUFDMUQsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFDcUMsY0FBYyxDQUFDLEVBQWM7UUFDakUsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxhQUE0QixDQUFDO1FBQ3ZELE1BQU0sY0FBYyxHQUFHLEVBQUUsQ0FBQyxhQUE0QixDQUFDO1FBQ3ZELElBQUksQ0FBQyxjQUFjLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQyxFQUFFLENBQUM7WUFDeEQsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ3RCLENBQUM7SUFDSCxDQUFDO0lBQzJDLGlCQUFpQixDQUFDLEVBQVM7UUFDckUsSUFBSSxFQUFFLENBQUMsWUFBWSxFQUFFLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxDQUFDLEVBQUUsQ0FBQztZQUN6RCxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDckIsQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDdEIsQ0FBQztJQUNILENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELE1BQU07UUFDSixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxNQUFNO1FBQ0osSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN0QixDQUFDO0lBRUQsWUFBb0IsS0FBaUI7UUFBakIsVUFBSyxHQUFMLEtBQUssQ0FBWTtRQXhEckMsV0FBTSxHQUFHLE1BQU0sQ0FBQztRQUNoQixhQUFRLEdBQUcsUUFBUSxDQUFDO1FBQ3BCLGVBQVUsR0FBRyxVQUFVLENBQUM7UUFDeEIsWUFBTyxHQUFHLE9BQU8sQ0FBQztRQUVULGVBQVUsR0FBRyxLQUFLLENBQUM7UUFFbkIsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFFcEIsaUJBQVksR0FBRyxJQUFJLENBQUM7UUFHcEIsaUJBQVksR0FBRyxJQUFJLENBQUM7UUFJbkIsYUFBUSxHQUF1QixJQUFJLFlBQVksRUFBUSxDQUFDO1FBQ3hELGNBQVMsR0FBdUIsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUN6RCxhQUFRLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFDeEQsZ0JBQVcsR0FBdUIsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUMzRCxZQUFPLEdBQXVCLElBQUksWUFBWSxFQUFRLENBQUM7UUFDdkQsWUFBTyxHQUF1QixJQUFJLFlBQVksRUFBUSxDQUFDO0lBb0NqRSxDQUFDO0lBRU8sV0FBVztRQUNqQixJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDdkIsQ0FBQztJQUNILENBQUM7SUFFTyxZQUFZO1FBQ2xCLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDMUIsQ0FBQztJQUNILENBQUM7K0dBdEVVLG9CQUFvQjttR0FBcEIsb0JBQW9CLGd1QkFsRXJCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O1NBZ0VILDREQXBFTCxJQUFJLDZGQUNKLGtCQUFrQixvT0FDbEIsaUJBQWlCOzs0RkFvRVIsb0JBQW9CO2tCQTFFaEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsZUFBZTtvQkFDekIsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRTt3QkFDUCxJQUFJO3dCQUNKLGtCQUFrQjt3QkFDbEIsaUJBQWlCO3FCQUNsQjtvQkFDRCxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7U0FnRUg7aUJBQ1I7K0VBTVUsVUFBVTtzQkFBbEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSztnQkFDRyx5QkFBeUI7c0JBQWpDLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDSSxRQUFRO3NCQUFqQixNQUFNO2dCQUNHLFNBQVM7c0JBQWxCLE1BQU07Z0JBQ0csUUFBUTtzQkFBakIsTUFBTTtnQkFDRyxXQUFXO3NCQUFwQixNQUFNO2dCQUNHLE9BQU87c0JBQWhCLE1BQU07Z0JBQ0csT0FBTztzQkFBaEIsTUFBTTtnQkFDOEIsYUFBYTtzQkFBakQsWUFBWTt1QkFBQyxTQUFTLEVBQUUsQ0FBQyxRQUFRLENBQUM7Z0JBR0csY0FBYztzQkFBbkQsWUFBWTt1QkFBQyxVQUFVLEVBQUUsQ0FBQyxRQUFRLENBQUM7Z0JBT1EsaUJBQWlCO3NCQUE1RCxZQUFZO3VCQUFDLGdCQUFnQixFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSG9zdExpc3RlbmVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTcHhCdXR0b25Db21wb25lbnQgfSBmcm9tICdAc29mdHBhay9jb21wb25lbnRzL3NweC1idXR0b24nO1xuaW1wb3J0IHsgU3B4VmFsdWVQYWlyIH0gZnJvbSAnLi9zcHgtdmFsdWUtaW50ZXJmYWNlJztcbmltcG9ydCB7IEZvbnRBd2Vzb21lTW9kdWxlIH0gZnJvbSAnQGZvcnRhd2Vzb21lL2FuZ3VsYXItZm9udGF3ZXNvbWUnO1xuaW1wb3J0IHsgZmFFZGl0LCBmYVF1ZXN0aW9uLCBmYVNlYXJjaCwgZmFUaW1lcyB9IGZyb20gJ0Bmb3J0YXdlc29tZS9mcmVlLXNvbGlkLXN2Zy1pY29ucyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NweC1pbnB1dC1ib3gnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgTmdJZixcbiAgICBTcHhCdXR0b25Db21wb25lbnQsXG4gICAgRm9udEF3ZXNvbWVNb2R1bGUsXG4gIF0sXG4gIHRlbXBsYXRlOiBgPGRpdiBjbGFzcz1cImZsZXggcm91bmRlZCB3LWZ1bGwgZ2FwLTNcIlxuICAgIFtjbGFzcy5yb3VuZGVkLW5vbmVdPVwidGhpcy5zcHhTaG93VmFsaWRhdGlvbk1lc3NhZ2VzXCJcbiAgICBbY2xhc3Mucm91bmRlZC10XT1cInRoaXMuc3B4U2hvd1ZhbGlkYXRpb25NZXNzYWdlc1wiXG4gICAgW2NsYXNzLm91dGxpbmUtbm9uZV09XCJ0aGlzLnNweEZvY3VzZWQgJiYgIXRoaXMuc3B4UmVhZG9ubHlcIlxuICAgIFtjbGFzcy5yaW5nLTJdPVwidGhpcy5zcHhGb2N1c2VkICYmICF0aGlzLnNweFJlYWRvbmx5XCJcbiAgICBbY2xhc3MucmluZy1vZmZzZXQtMl09XCJ0aGlzLnNweEZvY3VzZWQgJiYgIXRoaXMuc3B4UmVhZG9ubHlcIlxuICAgIFtjbGFzcy5yaW5nLWJsdWUtNTAwXT1cInRoaXMuc3B4Rm9jdXNlZCAmJiAhdGhpcy5zcHhSZWFkb25seVwiXG4gICAgW2NsYXNzLmJnLXdoaXRlXT1cIiF0aGlzLnNweFJlYWRvbmx5XCJcbiAgICBbY2xhc3MuYmctZ3JheS0zMDBdPVwidGhpcy5zcHhSZWFkb25seVwiXG4gICAgW2NsYXNzLmN1cnNvci1ub3QtYWxsb3dlZF09XCJ0aGlzLnNweFJlYWRvbmx5XCI+XG4gICAgPGRpdiBjbGFzcz1cImZsZXgtYXV0byBwLTNcIlxuICAgICAgW2NsYXNzLnAtMF09XCJ0aGlzLnNweENvbXBhY3RcIlxuICAgICAgW2NsYXNzLmZsZXhdPVwidGhpcy5zcHhDb21wYWN0XCJcbiAgICAgIFtjbGFzcy5pdGVtcy1jZW50ZXJdPVwidGhpcy5zcHhDb21wYWN0XCI+XG4gICAgICA8ZGl2ICpuZ0lmPVwidGhpcy5zcHhTaG93TGFiZWxcIiBjbGFzcz1cImZvbnQtYm9sZCB0ZXh0LXNtIG1iLTEgdGV4dC1ncmF5LTgwMFwiXG4gICAgICAgIFtjbGFzcy5tYi0wXT1cInRoaXMuc3B4Q29tcGFjdFwiXG4gICAgICAgIFtjbGFzcy5weC0zXT1cInRoaXMuc3B4Q29tcGFjdFwiPlxuICAgICAgICB7e3RoaXMuc3B4TGFiZWx9fSA8c3BhbiAqbmdJZj1cInNweFJlcXVpcmVkXCIgY2xhc3M9XCJ0ZXh0LXJlZC04MDBcIj4qPC9zcGFuPlxuICAgICAgPC9kaXY+XG4gICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbY29udHJvbHNdXCI+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuICAgIDxkaXYgY2xhc3M9XCJmbGV4IGZsZXgtbm9uZSBnYXAtMSBwLTFcIj5cbiAgICAgIDxzcHgtYnV0dG9uXG4gICAgICAgICpuZ0lmPVwidGhpcy5zcHhTaG93RWRpdFwiXG4gICAgICAgIChzcHhDbGljayk9XCJvbkVkaXQoKVwiXG4gICAgICAgIFtzcHhGdWxsSGVpZ2h0XT1cInRydWVcIlxuICAgICAgICBbc3B4U2l6ZV09XCIneGwnXCJcbiAgICAgICAgW3NweFR5cGVdPVwiJ2J1dHRvbidcIj5cbiAgICAgICAgPGZhLWljb24gW2ljb25dPVwiZmFFZGl0XCIgY2xhc3M9XCJibG9jayB0ZXh0LXhsXCI+PC9mYS1pY29uPlxuICAgICAgPC9zcHgtYnV0dG9uPlxuICAgICAgPHNweC1idXR0b25cbiAgICAgICAgKm5nSWY9XCJ0aGlzLnNweFNob3dIZWxwXCJcbiAgICAgICAgKHNweENsaWNrKT1cIm9uSGVscCgpXCJcbiAgICAgICAgW3NweEZ1bGxIZWlnaHRdPVwidHJ1ZVwiXG4gICAgICAgIFtzcHhEaXNhYmxlZF09XCJ0aGlzLnNweFJlYWRvbmx5XCJcbiAgICAgICAgW3NweFNpemVdPVwiJ3hsJ1wiXG4gICAgICAgIFtzcHhUYWJJbmRleF09XCItMVwiXG4gICAgICAgIFtzcHhUeXBlXT1cIididXR0b24nXCI+XG4gICAgICAgIDxmYS1pY29uIFtpY29uXT1cImZhUXVlc3Rpb25cIiBjbGFzcz1cImJsb2NrIHRleHQteGxcIj48L2ZhLWljb24+XG4gICAgICA8L3NweC1idXR0b24+XG4gICAgICA8c3B4LWJ1dHRvblxuICAgICAgICAqbmdJZj1cInRoaXMuc3B4U2hvd1NlYXJjaFwiXG4gICAgICAgIChzcHhDbGljayk9XCJvblNlYXJjaCgpXCJcbiAgICAgICAgW3NweEZ1bGxIZWlnaHRdPVwidHJ1ZVwiXG4gICAgICAgIFtzcHhEaXNhYmxlZF09XCJ0aGlzLnNweFJlYWRvbmx5XCJcbiAgICAgICAgW3NweFNpemVdPVwiJ3hsJ1wiXG4gICAgICAgIFtzcHhUYWJJbmRleF09XCItMVwiXG4gICAgICAgIFtzcHhUeXBlXT1cIididXR0b24nXCI+XG4gICAgICAgIDxmYS1pY29uIFtpY29uXT1cImZhU2VhcmNoXCIgY2xhc3M9XCJibG9jayB0ZXh0LXhsXCI+PC9mYS1pY29uPlxuICAgICAgPC9zcHgtYnV0dG9uPlxuICAgICAgPHNweC1idXR0b25cbiAgICAgICAgKm5nSWY9XCJ0aGlzLnNweFNob3dDbGVhclwiXG4gICAgICAgIChzcHhDbGljayk9XCJvbkNsZWFyKClcIlxuICAgICAgICBbc3B4RGlzYWJsZWRdPVwidGhpcy5zcHhSZWFkb25seSB8fCAhdGhpcy5zcHhWYWx1ZT8udmFsdWVcIlxuICAgICAgICBbc3B4RnVsbEhlaWdodF09XCJ0cnVlXCJcbiAgICAgICAgW3NweFNpemVdPVwiJ3hsJ1wiXG4gICAgICAgIFtzcHhUYWJJbmRleF09XCItMVwiXG4gICAgICAgIFtzcHhUeXBlXT1cIididXR0b24nXCI+XG4gICAgICAgIDxmYS1pY29uIFtpY29uXT1cImZhVGltZXNcIiBjbGFzcz1cImJsb2NrIHRleHQteGxcIj48L2ZhLWljb24+XG4gICAgICA8L3NweC1idXR0b24+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuICA8ZGl2ICpuZ0lmPVwidGhpcy5zcHhTaG93VmFsaWRhdGlvbk1lc3NhZ2VzXCIgY2xhc3M9XCJiZy1yZWQtNjAwIHJvdW5kZWQtYiB0ZXh0LXdoaXRlIHAtM1wiPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIlt2YWxpZGF0aW9uLW1lc3NhZ2VzXVwiPjwvbmctY29udGVudD5cbiAgPC9kaXY+YCxcbn0pXG5leHBvcnQgY2xhc3MgU3B4SW5wdXRCb3hDb21wb25lbnQge1xuICBmYUVkaXQgPSBmYUVkaXQ7XG4gIGZhU2VhcmNoID0gZmFTZWFyY2g7XG4gIGZhUXVlc3Rpb24gPSBmYVF1ZXN0aW9uO1xuICBmYVRpbWVzID0gZmFUaW1lcztcbiAgQElucHV0KCkgc3B4Q29tcGFjdD86IGJvb2xlYW47XG4gIEBJbnB1dCgpIHNweEZvY3VzZWQgPSBmYWxzZTtcbiAgQElucHV0KCkgc3B4TGFiZWw/OiBzdHJpbmc7XG4gIEBJbnB1dCgpIHNweFJlYWRvbmx5ID0gZmFsc2U7XG4gIEBJbnB1dCgpIHNweFJlcXVpcmVkPzogYm9vbGVhbjtcbiAgQElucHV0KCkgc3B4U2hvd0NsZWFyID0gdHJ1ZTtcbiAgQElucHV0KCkgc3B4U2hvd0VkaXQ/OiBib29sZWFuO1xuICBASW5wdXQoKSBzcHhTaG93SGVscD86IGJvb2xlYW47XG4gIEBJbnB1dCgpIHNweFNob3dMYWJlbCA9IHRydWU7XG4gIEBJbnB1dCgpIHNweFNob3dTZWFyY2g/OiBib29sZWFuO1xuICBASW5wdXQoKSBzcHhTaG93VmFsaWRhdGlvbk1lc3NhZ2VzPzogYm9vbGVhbiB8IG51bGwgfCB1bmRlZmluZWQ7XG4gIEBJbnB1dCgpIHNweFZhbHVlPzogU3B4VmFsdWVQYWlyPGFueT47XG4gIEBPdXRwdXQoKSBzcHhDbGVhcjogRXZlbnRFbWl0dGVyPHZvaWQ+ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBAT3V0cHV0KCkgc3B4U2VhcmNoOiBFdmVudEVtaXR0ZXI8dm9pZD4gPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG4gIEBPdXRwdXQoKSBzcHhGb2N1czogRXZlbnRFbWl0dGVyPHZvaWQ+ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICBAT3V0cHV0KCkgc3B4Rm9jdXNPdXQ6IEV2ZW50RW1pdHRlcjx2b2lkPiA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgQE91dHB1dCgpIHNweEVkaXQ6IEV2ZW50RW1pdHRlcjx2b2lkPiA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgQE91dHB1dCgpIHNweEhlbHA6IEV2ZW50RW1pdHRlcjx2b2lkPiA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgQEhvc3RMaXN0ZW5lcignZm9jdXNpbicsIFtcIiRldmVudFwiXSkgaGFuZGxlRm9jdXNJbihldjogRXZlbnQpIHtcbiAgICB0aGlzLmVtaXRGb2N1c0luKCk7XG4gIH1cbiAgQEhvc3RMaXN0ZW5lcignZm9jdXNvdXQnLCBbXCIkZXZlbnRcIl0pIGhhbmRsZUZvY3VzT3V0KGV2OiBGb2N1c0V2ZW50KSB7XG4gICAgY29uc3QgdGhpc0VsID0gdGhpcy5lbFJlZi5uYXRpdmVFbGVtZW50IGFzIEhUTUxFbGVtZW50O1xuICAgIGNvbnN0IHJlbGF0ZWRFbGVtZW50ID0gZXYucmVsYXRlZFRhcmdldCBhcyBIVE1MRWxlbWVudDtcbiAgICBpZiAoIXJlbGF0ZWRFbGVtZW50IHx8ICF0aGlzRWwuY29udGFpbnMocmVsYXRlZEVsZW1lbnQpKSB7XG4gICAgICB0aGlzLmVtaXRGb2N1c091dCgpO1xuICAgIH1cbiAgfVxuICBASG9zdExpc3RlbmVyKCdkb2N1bWVudDpjbGljaycsIFtcIiRldmVudFwiXSkgaGFuZGxlV2luZG93Q2xpY2soZXY6IEV2ZW50KSB7XG4gICAgaWYgKGV2LmNvbXBvc2VkUGF0aCgpLmluY2x1ZGVzKHRoaXMuZWxSZWYubmF0aXZlRWxlbWVudCkpIHtcbiAgICAgIHRoaXMuZW1pdEZvY3VzSW4oKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5lbWl0Rm9jdXNPdXQoKTtcbiAgICB9XG4gIH1cblxuICBvbkNsZWFyKCkge1xuICAgIHRoaXMuc3B4Q2xlYXIuZW1pdCgpO1xuICB9XG5cbiAgb25TZWFyY2goKSB7XG4gICAgdGhpcy5zcHhTZWFyY2guZW1pdCgpO1xuICB9XG5cbiAgb25FZGl0KCkge1xuICAgIHRoaXMuc3B4RWRpdC5lbWl0KCk7XG4gIH1cblxuICBvbkhlbHAoKSB7XG4gICAgdGhpcy5zcHhIZWxwLmVtaXQoKTtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxSZWY6IEVsZW1lbnRSZWYpIHtcbiAgfVxuXG4gIHByaXZhdGUgZW1pdEZvY3VzSW4oKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLnNweEZvY3VzZWQpIHtcbiAgICAgIHRoaXMuc3B4Rm9jdXMuZW1pdCgpO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgZW1pdEZvY3VzT3V0KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLnNweEZvY3VzZWQpIHtcbiAgICAgIHRoaXMuc3B4Rm9jdXNPdXQuZW1pdCgpO1xuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,294 @@
|
|
|
1
|
+
import { NgFor, NgIf } from '@angular/common';
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import { SpxButtonComponent } from '@softpak/components/spx-button';
|
|
4
|
+
import { SpxSuggestionComponent } from '@softpak/components/spx-suggestion';
|
|
5
|
+
import { DateTime } from 'luxon';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class SpxInputDateComponent {
|
|
8
|
+
async spxSetFocus() {
|
|
9
|
+
// this.elYear.focus();
|
|
10
|
+
}
|
|
11
|
+
// @Watch('spxValidators') watchSpxValidators(newValue) {
|
|
12
|
+
// console.log('validators', newValue);
|
|
13
|
+
// }
|
|
14
|
+
// @Watch('value') watchValue(newValue) {
|
|
15
|
+
// if (this.spxWasInternalUpdate) {
|
|
16
|
+
// this.spxWasInternalUpdate = false;
|
|
17
|
+
// } else {
|
|
18
|
+
// const parsedValue = DateTime.fromISO(newValue?.value);
|
|
19
|
+
// this.spxInternalValue.years = parsedValue.year;
|
|
20
|
+
// this.spxInternalValue.months = parsedValue.month;
|
|
21
|
+
// this.spxInternalValue.days = parsedValue.day;
|
|
22
|
+
// this.spxSelectStep = 'years';
|
|
23
|
+
// }
|
|
24
|
+
// }
|
|
25
|
+
constructor() {
|
|
26
|
+
this.spxReadonly = false;
|
|
27
|
+
this.spxFocused = true;
|
|
28
|
+
this.spxSelectMonth = true;
|
|
29
|
+
this.spxSelectDay = true;
|
|
30
|
+
this.spxChange = new EventEmitter();
|
|
31
|
+
this.spxFocus = new EventEmitter();
|
|
32
|
+
this.spxSelectStep = 'years';
|
|
33
|
+
this.spxInternalValue = {};
|
|
34
|
+
this.spxSuggestions = {
|
|
35
|
+
years: [],
|
|
36
|
+
months: [{
|
|
37
|
+
description: 'Jan',
|
|
38
|
+
value: 1,
|
|
39
|
+
}, {
|
|
40
|
+
description: 'Feb',
|
|
41
|
+
value: 2,
|
|
42
|
+
}, {
|
|
43
|
+
description: 'Mar',
|
|
44
|
+
value: 3,
|
|
45
|
+
}, {
|
|
46
|
+
description: 'Apr',
|
|
47
|
+
value: 4,
|
|
48
|
+
}, {
|
|
49
|
+
description: 'May',
|
|
50
|
+
value: 5,
|
|
51
|
+
}, {
|
|
52
|
+
description: 'Jun',
|
|
53
|
+
value: 6,
|
|
54
|
+
}, {
|
|
55
|
+
description: 'Jul',
|
|
56
|
+
value: 7,
|
|
57
|
+
}, {
|
|
58
|
+
description: 'Aug',
|
|
59
|
+
value: 8,
|
|
60
|
+
}, {
|
|
61
|
+
description: 'Sep',
|
|
62
|
+
value: 9,
|
|
63
|
+
}, {
|
|
64
|
+
description: 'Oct',
|
|
65
|
+
value: 10,
|
|
66
|
+
}, {
|
|
67
|
+
description: 'Nov',
|
|
68
|
+
value: 11,
|
|
69
|
+
}, {
|
|
70
|
+
description: 'Dec',
|
|
71
|
+
value: 12,
|
|
72
|
+
}],
|
|
73
|
+
days: [],
|
|
74
|
+
};
|
|
75
|
+
this.spxWasInternalUpdate = false;
|
|
76
|
+
this.suggestYears();
|
|
77
|
+
}
|
|
78
|
+
componentWillLoad() {
|
|
79
|
+
const parsedValue = this.value ? DateTime.fromISO(this.value.value) : DateTime.now();
|
|
80
|
+
this.spxInternalValue.years = parsedValue.year;
|
|
81
|
+
this.spxInternalValue.months = parsedValue.month;
|
|
82
|
+
this.spxInternalValue.days = parsedValue.day;
|
|
83
|
+
}
|
|
84
|
+
handleDayInput(event) {
|
|
85
|
+
this.spxInternalValue.days = event.target ? event.target.value : null;
|
|
86
|
+
this.updateValue();
|
|
87
|
+
}
|
|
88
|
+
handleMonthInput(event) {
|
|
89
|
+
this.spxInternalValue.months = event.target ? event.target.value : null;
|
|
90
|
+
this.afterMonthChange();
|
|
91
|
+
}
|
|
92
|
+
afterMonthChange() {
|
|
93
|
+
if (this.spxInternalValue.months.toString().length === 2 && this.spxSelectDay && this.spxLastKeyPressed !== 38 && this.spxLastKeyPressed !== 40) {
|
|
94
|
+
// this.elDay!.focus();
|
|
95
|
+
}
|
|
96
|
+
this.updateValue();
|
|
97
|
+
}
|
|
98
|
+
handleYearInput(event) {
|
|
99
|
+
this.spxInternalValue.years = event.target ? event.target.value : null;
|
|
100
|
+
this.afterYearChange();
|
|
101
|
+
}
|
|
102
|
+
afterYearChange() {
|
|
103
|
+
if (this.spxInternalValue.years.toString().length === 4 && this.spxSelectMonth && this.spxLastKeyPressed !== 38 && this.spxLastKeyPressed !== 40) {
|
|
104
|
+
// this.elMonth!.focus();
|
|
105
|
+
}
|
|
106
|
+
this.updateValue();
|
|
107
|
+
}
|
|
108
|
+
handleInput(event) {
|
|
109
|
+
this.setValue(event.target ? event.target.value : null);
|
|
110
|
+
}
|
|
111
|
+
handleFocus(step) {
|
|
112
|
+
this.spxSelectStep = step;
|
|
113
|
+
this.spxFocus.emit();
|
|
114
|
+
}
|
|
115
|
+
handleKeyDown(event) {
|
|
116
|
+
this.spxLastKeyPressed = event.which;
|
|
117
|
+
}
|
|
118
|
+
handleSuggestionClick(value) {
|
|
119
|
+
this.spxLastKeyPressed = null;
|
|
120
|
+
this.spxInternalValue[this.spxSelectStep] = value;
|
|
121
|
+
this.updateValue();
|
|
122
|
+
this.doneWithField();
|
|
123
|
+
}
|
|
124
|
+
updateValue() {
|
|
125
|
+
const concatenatedValue = `${this.spxInternalValue.years ? this.spxInternalValue.years : ``}${this.spxInternalValue.months ? `-${this.spxInternalValue.months < 10 ? `0${this.spxInternalValue.months}` : this.spxInternalValue.months}` : ``}${this.spxInternalValue.days ? `-${this.spxInternalValue.days < 10 ? `0${this.spxInternalValue.days}` : this.spxInternalValue.days}` : ``}`;
|
|
126
|
+
const parsedValue = DateTime.fromISO(concatenatedValue);
|
|
127
|
+
this.spxWasInternalUpdate = true;
|
|
128
|
+
this.value = {
|
|
129
|
+
description: parsedValue.toISO(),
|
|
130
|
+
value: parsedValue.toISO(),
|
|
131
|
+
};
|
|
132
|
+
this.spxChange.emit(this.value);
|
|
133
|
+
}
|
|
134
|
+
doneWithField() {
|
|
135
|
+
if (this.spxSelectStep === 'days') {
|
|
136
|
+
this.spxSelectStep = 'years';
|
|
137
|
+
}
|
|
138
|
+
else if (this.spxSelectStep === 'months') {
|
|
139
|
+
this.spxSelectStep = this.spxSelectDay ? 'days' : 'years';
|
|
140
|
+
this.afterMonthChange();
|
|
141
|
+
}
|
|
142
|
+
else if (this.spxSelectStep === 'years') {
|
|
143
|
+
this.afterYearChange();
|
|
144
|
+
this.spxSelectStep = this.spxSelectMonth ? 'months' : 'years';
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
setValue(value) {
|
|
148
|
+
this.spxInternalValue = value;
|
|
149
|
+
const parsed = DateTime.fromISO(value);
|
|
150
|
+
this.value = {
|
|
151
|
+
description: parsed.toISO(),
|
|
152
|
+
value: parsed.toISO(),
|
|
153
|
+
};
|
|
154
|
+
this.spxChange.emit(this.value);
|
|
155
|
+
this.spxWasInternalUpdate = true;
|
|
156
|
+
}
|
|
157
|
+
suggestYears() {
|
|
158
|
+
this.spxSuggestions.years = [];
|
|
159
|
+
for (let year = DateTime.fromISO(this.spxMin).year; year <= DateTime.fromISO(this.spxMax).year; year++) {
|
|
160
|
+
this.spxSuggestions.years.push({
|
|
161
|
+
description: `'${year.toString().substring(2, 4)}`,
|
|
162
|
+
value: year,
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SpxInputDateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
167
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SpxInputDateComponent, isStandalone: true, selector: "spx-input-date", inputs: { spxMax: "spxMax", spxMin: "spxMin", spxName: "spxName", spxReadonly: "spxReadonly", spxValidators: "spxValidators", spxFocused: "spxFocused", spxSelectMonth: "spxSelectMonth", spxSelectDay: "spxSelectDay", value: "value", spxLastKeyPressed: "spxLastKeyPressed", spxSelectStep: "spxSelectStep", spxInternalValue: "spxInternalValue", spxSuggestions: "spxSuggestions", spxWasInternalUpdate: "spxWasInternalUpdate" }, outputs: { spxChange: "spxChange", spxFocus: "spxFocus" }, ngImport: i0, template: `<div class='spx-input-date__controls'>
|
|
168
|
+
<input
|
|
169
|
+
class='spx-input-date__input'
|
|
170
|
+
[attr.value]="this.spxInternalValue.years"
|
|
171
|
+
(focus)="this.handleFocus('years')"
|
|
172
|
+
(input)="this.handleYearInput($event)"
|
|
173
|
+
(keyDown)="this.handleKeyDown($event)"
|
|
174
|
+
[attr.type]="'number'"
|
|
175
|
+
[attr.min]="1900"
|
|
176
|
+
[attr.max]="2100"
|
|
177
|
+
[attr.step]="1"
|
|
178
|
+
/>
|
|
179
|
+
<div class='spx-input-date__control-label'>Year</div>
|
|
180
|
+
<input
|
|
181
|
+
*ngIf="this.spxSelectMonth"
|
|
182
|
+
class='spx-input-date__input'
|
|
183
|
+
[attr.value]="this.spxInternalValue.months"
|
|
184
|
+
(focus)="this.handleFocus('months')"
|
|
185
|
+
(input)="this.handleMonthInput($event)"
|
|
186
|
+
(keyDown)="this.handleKeyDown($event)"
|
|
187
|
+
[attr.type]="'number'"
|
|
188
|
+
[attr.min]="1"
|
|
189
|
+
[attr.max]="12"
|
|
190
|
+
[attr.step]="1" />
|
|
191
|
+
<div class='spx-input-date__control-label'>Month</div>
|
|
192
|
+
<input
|
|
193
|
+
*ngIf="this.spxSelectDay"
|
|
194
|
+
class='spx-input-date__input'
|
|
195
|
+
[attr.value]="this.spxInternalValue.days"
|
|
196
|
+
(focus)="this.handleFocus('days')"
|
|
197
|
+
(input)="this.handleDayInput($event)"
|
|
198
|
+
(keyDown)="this.handleKeyDown($event)"
|
|
199
|
+
[attr.type]="'number'"
|
|
200
|
+
[attr.min]="1"
|
|
201
|
+
[attr.max]="31"
|
|
202
|
+
[attr.step]="1" />
|
|
203
|
+
<div class='spx-input-date__control-label'>Days</div>
|
|
204
|
+
</div>
|
|
205
|
+
<div class='spx-input-date__suggestions'>
|
|
206
|
+
<spx-suggestion
|
|
207
|
+
*ngFor="let valuePair of spxSuggestions[spxSelectStep]"
|
|
208
|
+
(click)="this.handleSuggestionClick(valuePair.value)">{{valuePair?.description}}</spx-suggestion>
|
|
209
|
+
</div>`, isInline: true, styles: [":host{display:block}.spx-input-date__input{background-color:transparent;border:1px solid #979797;border-radius:4px;color:var(--spx-input--color, rgba(0, 0, 0, .9));box-sizing:border-box;font-size:16px;margin-right:10px;padding:6px;text-align:center;width:100%}.spx-input-date__input:active{transform:scale(.95)}.spx-input-date__input:focus{border:var(--spx-input-box--focus--border, 1px solid rgb(115, 168, 210));border-radius:4px;outline:none}.spx-input-date__control-label{align-items:center;color:#000000b3;display:inline-grid;font-size:13px;letter-spacing:1px}.spx-input-date__input::-webkit-outer-spin-button,.spx-input-date__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.spx-input-date__input[type=number]{-moz-appearance:textfield}.spx-input-date__suggestions,.spx-input-date__controls{display:grid;grid-gap:8px;grid-template-columns:repeat(4,1fr);margin-top:8px}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: SpxSuggestionComponent, selector: "spx-suggestion", inputs: ["spxDisabled", "spxFocused", "spxSelected", "spxTabbable"] }] }); }
|
|
210
|
+
}
|
|
211
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SpxInputDateComponent, decorators: [{
|
|
212
|
+
type: Component,
|
|
213
|
+
args: [{ selector: 'spx-input-date', standalone: true, imports: [
|
|
214
|
+
NgIf,
|
|
215
|
+
NgFor,
|
|
216
|
+
SpxButtonComponent,
|
|
217
|
+
SpxSuggestionComponent
|
|
218
|
+
], template: `<div class='spx-input-date__controls'>
|
|
219
|
+
<input
|
|
220
|
+
class='spx-input-date__input'
|
|
221
|
+
[attr.value]="this.spxInternalValue.years"
|
|
222
|
+
(focus)="this.handleFocus('years')"
|
|
223
|
+
(input)="this.handleYearInput($event)"
|
|
224
|
+
(keyDown)="this.handleKeyDown($event)"
|
|
225
|
+
[attr.type]="'number'"
|
|
226
|
+
[attr.min]="1900"
|
|
227
|
+
[attr.max]="2100"
|
|
228
|
+
[attr.step]="1"
|
|
229
|
+
/>
|
|
230
|
+
<div class='spx-input-date__control-label'>Year</div>
|
|
231
|
+
<input
|
|
232
|
+
*ngIf="this.spxSelectMonth"
|
|
233
|
+
class='spx-input-date__input'
|
|
234
|
+
[attr.value]="this.spxInternalValue.months"
|
|
235
|
+
(focus)="this.handleFocus('months')"
|
|
236
|
+
(input)="this.handleMonthInput($event)"
|
|
237
|
+
(keyDown)="this.handleKeyDown($event)"
|
|
238
|
+
[attr.type]="'number'"
|
|
239
|
+
[attr.min]="1"
|
|
240
|
+
[attr.max]="12"
|
|
241
|
+
[attr.step]="1" />
|
|
242
|
+
<div class='spx-input-date__control-label'>Month</div>
|
|
243
|
+
<input
|
|
244
|
+
*ngIf="this.spxSelectDay"
|
|
245
|
+
class='spx-input-date__input'
|
|
246
|
+
[attr.value]="this.spxInternalValue.days"
|
|
247
|
+
(focus)="this.handleFocus('days')"
|
|
248
|
+
(input)="this.handleDayInput($event)"
|
|
249
|
+
(keyDown)="this.handleKeyDown($event)"
|
|
250
|
+
[attr.type]="'number'"
|
|
251
|
+
[attr.min]="1"
|
|
252
|
+
[attr.max]="31"
|
|
253
|
+
[attr.step]="1" />
|
|
254
|
+
<div class='spx-input-date__control-label'>Days</div>
|
|
255
|
+
</div>
|
|
256
|
+
<div class='spx-input-date__suggestions'>
|
|
257
|
+
<spx-suggestion
|
|
258
|
+
*ngFor="let valuePair of spxSuggestions[spxSelectStep]"
|
|
259
|
+
(click)="this.handleSuggestionClick(valuePair.value)">{{valuePair?.description}}</spx-suggestion>
|
|
260
|
+
</div>`, styles: [":host{display:block}.spx-input-date__input{background-color:transparent;border:1px solid #979797;border-radius:4px;color:var(--spx-input--color, rgba(0, 0, 0, .9));box-sizing:border-box;font-size:16px;margin-right:10px;padding:6px;text-align:center;width:100%}.spx-input-date__input:active{transform:scale(.95)}.spx-input-date__input:focus{border:var(--spx-input-box--focus--border, 1px solid rgb(115, 168, 210));border-radius:4px;outline:none}.spx-input-date__control-label{align-items:center;color:#000000b3;display:inline-grid;font-size:13px;letter-spacing:1px}.spx-input-date__input::-webkit-outer-spin-button,.spx-input-date__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.spx-input-date__input[type=number]{-moz-appearance:textfield}.spx-input-date__suggestions,.spx-input-date__controls{display:grid;grid-gap:8px;grid-template-columns:repeat(4,1fr);margin-top:8px}\n"] }]
|
|
261
|
+
}], ctorParameters: () => [], propDecorators: { spxMax: [{
|
|
262
|
+
type: Input
|
|
263
|
+
}], spxMin: [{
|
|
264
|
+
type: Input
|
|
265
|
+
}], spxName: [{
|
|
266
|
+
type: Input
|
|
267
|
+
}], spxReadonly: [{
|
|
268
|
+
type: Input
|
|
269
|
+
}], spxValidators: [{
|
|
270
|
+
type: Input
|
|
271
|
+
}], spxFocused: [{
|
|
272
|
+
type: Input
|
|
273
|
+
}], spxSelectMonth: [{
|
|
274
|
+
type: Input
|
|
275
|
+
}], spxSelectDay: [{
|
|
276
|
+
type: Input
|
|
277
|
+
}], value: [{
|
|
278
|
+
type: Input
|
|
279
|
+
}], spxChange: [{
|
|
280
|
+
type: Output
|
|
281
|
+
}], spxFocus: [{
|
|
282
|
+
type: Output
|
|
283
|
+
}], spxLastKeyPressed: [{
|
|
284
|
+
type: Input
|
|
285
|
+
}], spxSelectStep: [{
|
|
286
|
+
type: Input
|
|
287
|
+
}], spxInternalValue: [{
|
|
288
|
+
type: Input
|
|
289
|
+
}], spxSuggestions: [{
|
|
290
|
+
type: Input
|
|
291
|
+
}], spxWasInternalUpdate: [{
|
|
292
|
+
type: Input
|
|
293
|
+
}] } });
|
|
294
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3B4LWlucHV0LWRhdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc29mdHBhay9jb21wb25lbnRzL3NweC1pbnB1dHMvc3B4LWlucHV0LWRhdGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDOUMsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sT0FBTyxDQUFDOztBQStHakMsTUFBTSxPQUFPLHFCQUFxQjtJQXFFaEMsS0FBSyxDQUFDLFdBQVc7UUFDZix1QkFBdUI7SUFDekIsQ0FBQztJQUNELHlEQUF5RDtJQUN6RCx5Q0FBeUM7SUFDekMsSUFBSTtJQUNKLHlDQUF5QztJQUN6QyxxQ0FBcUM7SUFDckMseUNBQXlDO0lBQ3pDLGFBQWE7SUFDYiw2REFBNkQ7SUFDN0Qsc0RBQXNEO0lBQ3RELHdEQUF3RDtJQUN4RCxvREFBb0Q7SUFDcEQsb0NBQW9DO0lBQ3BDLE1BQU07SUFDTixJQUFJO0lBRUo7UUEvRVMsZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFFcEIsZUFBVSxHQUFHLElBQUksQ0FBQztRQUNsQixtQkFBYyxHQUFHLElBQUksQ0FBQztRQUN0QixpQkFBWSxHQUFHLElBQUksQ0FBQztRQUVuQixjQUFTLEdBQW9DLElBQUksWUFBWSxFQUFxQixDQUFDO1FBQ25GLGFBQVEsR0FBdUIsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUV6RCxrQkFBYSxHQUFnQyxPQUFPLENBQUM7UUFDckQs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Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdGb3IsIE5nSWYgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNweEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJ0Bzb2Z0cGFrL2NvbXBvbmVudHMvc3B4LWJ1dHRvbic7XG5pbXBvcnQgeyBTcHhTdWdnZXN0aW9uQ29tcG9uZW50IH0gZnJvbSAnQHNvZnRwYWsvY29tcG9uZW50cy9zcHgtc3VnZ2VzdGlvbic7XG5pbXBvcnQgeyBEYXRlVGltZSB9IGZyb20gJ2x1eG9uJztcbmltcG9ydCB7IFNweFZhbHVlUGFpciB9IGZyb20gJy4vc3B4LXZhbHVlLWludGVyZmFjZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NweC1pbnB1dC1kYXRlJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIE5nSWYsXG4gICAgTmdGb3IsXG4gICAgU3B4QnV0dG9uQ29tcG9uZW50LFxuICAgIFNweFN1Z2dlc3Rpb25Db21wb25lbnRcbiAgXSxcbiAgdGVtcGxhdGU6IGA8ZGl2IGNsYXNzPSdzcHgtaW5wdXQtZGF0ZV9fY29udHJvbHMnPlxuICA8aW5wdXRcbiAgICBjbGFzcz0nc3B4LWlucHV0LWRhdGVfX2lucHV0J1xuICAgIFthdHRyLnZhbHVlXT1cInRoaXMuc3B4SW50ZXJuYWxWYWx1ZS55ZWFyc1wiXG4gICAgKGZvY3VzKT1cInRoaXMuaGFuZGxlRm9jdXMoJ3llYXJzJylcIlxuICAgIChpbnB1dCk9XCJ0aGlzLmhhbmRsZVllYXJJbnB1dCgkZXZlbnQpXCJcbiAgICAoa2V5RG93bik9XCJ0aGlzLmhhbmRsZUtleURvd24oJGV2ZW50KVwiXG4gICAgW2F0dHIudHlwZV09XCInbnVtYmVyJ1wiXG4gICAgW2F0dHIubWluXT1cIjE5MDBcIlxuICAgIFthdHRyLm1heF09XCIyMTAwXCJcbiAgICBbYXR0ci5zdGVwXT1cIjFcIlxuICAvPlxuICA8ZGl2IGNsYXNzPSdzcHgtaW5wdXQtZGF0ZV9fY29udHJvbC1sYWJlbCc+WWVhcjwvZGl2PlxuICAgIDxpbnB1dFxuICAgICAgKm5nSWY9XCJ0aGlzLnNweFNlbGVjdE1vbnRoXCJcbiAgICAgIGNsYXNzPSdzcHgtaW5wdXQtZGF0ZV9faW5wdXQnXG4gICAgICBbYXR0ci52YWx1ZV09XCJ0aGlzLnNweEludGVybmFsVmFsdWUubW9udGhzXCJcbiAgICAgIChmb2N1cyk9XCJ0aGlzLmhhbmRsZUZvY3VzKCdtb250aHMnKVwiXG4gICAgICAoaW5wdXQpPVwidGhpcy5oYW5kbGVNb250aElucHV0KCRldmVudClcIlxuICAgICAgKGtleURvd24pPVwidGhpcy5oYW5kbGVLZXlEb3duKCRldmVudClcIlxuICAgICAgW2F0dHIudHlwZV09XCInbnVtYmVyJ1wiXG4gICAgICBbYXR0ci5taW5dPVwiMVwiXG4gICAgICBbYXR0ci5tYXhdPVwiMTJcIlxuICAgICAgW2F0dHIuc3RlcF09XCIxXCIgLz5cbiAgICAgIDxkaXYgY2xhc3M9J3NweC1pbnB1dC1kYXRlX19jb250cm9sLWxhYmVsJz5Nb250aDwvZGl2PlxuICAgIDxpbnB1dFxuICAgICAgKm5nSWY9XCJ0aGlzLnNweFNlbGVjdERheVwiXG4gICAgICBjbGFzcz0nc3B4LWlucHV0LWRhdGVfX2lucHV0J1xuICAgICAgW2F0dHIudmFsdWVdPVwidGhpcy5zcHhJbnRlcm5hbFZhbHVlLmRheXNcIlxuICAgICAgKGZvY3VzKT1cInRoaXMuaGFuZGxlRm9jdXMoJ2RheXMnKVwiXG4gICAgICAoaW5wdXQpPVwidGhpcy5oYW5kbGVEYXlJbnB1dCgkZXZlbnQpXCJcbiAgICAgIChrZXlEb3duKT1cInRoaXMuaGFuZGxlS2V5RG93bigkZXZlbnQpXCJcbiAgICAgIFthdHRyLnR5cGVdPVwiJ251bWJlcidcIlxuICAgICAgW2F0dHIubWluXT1cIjFcIlxuICAgICAgW2F0dHIubWF4XT1cIjMxXCJcbiAgICAgIFthdHRyLnN0ZXBdPVwiMVwiIC8+XG4gICAgICA8ZGl2IGNsYXNzPSdzcHgtaW5wdXQtZGF0ZV9fY29udHJvbC1sYWJlbCc+RGF5czwvZGl2PlxuPC9kaXY+XG48ZGl2IGNsYXNzPSdzcHgtaW5wdXQtZGF0ZV9fc3VnZ2VzdGlvbnMnPlxuICA8c3B4LXN1Z2dlc3Rpb24gXG4gICpuZ0Zvcj1cImxldCB2YWx1ZVBhaXIgb2Ygc3B4U3VnZ2VzdGlvbnNbc3B4U2VsZWN0U3RlcF1cIiAgXG4gIChjbGljayk9XCJ0aGlzLmhhbmRsZVN1Z2dlc3Rpb25DbGljayh2YWx1ZVBhaXIudmFsdWUpXCI+e3t2YWx1ZVBhaXI/LmRlc2NyaXB0aW9ufX08L3NweC1zdWdnZXN0aW9uPlxuPC9kaXY+YCxcbnN0eWxlczogYFxuOmhvc3Qge1xuICBkaXNwbGF5OiBibG9jaztcbn1cblxuLnNweC1pbnB1dC1kYXRlX19pbnB1dCB7XG4gIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBib3JkZXI6IDFweCBzb2xpZCAjOTc5Nzk3O1xuICBib3JkZXItcmFkaXVzOiA0cHg7XG4gIGNvbG9yOiB2YXIoLS1zcHgtaW5wdXQtLWNvbG9yLCByZ2JhKDAsIDAsIDAsIC45KSk7XG4gIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gIGZvbnQtc2l6ZTogMTZweDtcbiAgbWFyZ2luLXJpZ2h0OiAxMHB4O1xuICBwYWRkaW5nOiA2cHg7XG4gIHRleHQtYWxpZ246IGNlbnRlcjtcbiAgd2lkdGg6IDEwMCU7XG59XG5cbi5zcHgtaW5wdXQtZGF0ZV9faW5wdXQ6YWN0aXZlIHtcbiAgdHJhbnNmb3JtOiBzY2FsZSgwLjk1KTtcbn1cblxuLnNweC1pbnB1dC1kYXRlX19pbnB1dDpmb2N1cyB7XG4gIGJvcmRlcjogdmFyKC0tc3B4LWlucHV0LWJveC0tZm9jdXMtLWJvcmRlciwgMXB4IHNvbGlkIHJnYigxMTUsIDE2OCwgMjEwKSk7XG4gIGJvcmRlci1yYWRpdXM6IDRweDtcbiAgb3V0bGluZTogbm9uZTtcbn1cblxuLnNweC1pbnB1dC1kYXRlX19jb250cm9sLWxhYmVsIHtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgY29sb3I6IHJnYmEoMCwgMCwgMCwgLjcpO1xuICBkaXNwbGF5OiBpbmxpbmUtZ3JpZDtcbiAgZm9udC1zaXplOiAxM3B4O1xuICBsZXR0ZXItc3BhY2luZzogMXB4O1xufVxuXG4uc3B4LWlucHV0LWRhdGVfX2lucHV0Ojotd2Via2l0LW91dGVyLXNwaW4tYnV0dG9uLFxuLnNweC1pbnB1dC1kYXRlX19pbnB1dDo6LXdlYmtpdC1pbm5lci1zcGluLWJ1dHRvbiB7XG4gICAgLyogZGlzcGxheTogbm9uZTsgPC0gQ3Jhc2hlcyBDaHJvbWUgb24gaG92ZXIgKi9cbiAgICAtd2Via2l0LWFwcGVhcmFuY2U6IG5vbmU7XG4gICAgbWFyZ2luOiAwOyAvKiA8LS0gQXBwYXJlbnRseSBzb21lIG1hcmdpbiBhcmUgc3RpbGwgdGhlcmUgZXZlbiB0aG91Z2ggaXQncyBoaWRkZW4gKi9cbn1cblxuLnNweC1pbnB1dC1kYXRlX19pbnB1dFt0eXBlPW51bWJlcl0ge1xuICAgIC1tb3otYXBwZWFyYW5jZTp0ZXh0ZmllbGQ7IC8qIEZpcmVmb3ggKi9cbn1cblxuLnNweC1pbnB1dC1kYXRlX19zdWdnZXN0aW9ucyxcbi5zcHgtaW5wdXQtZGF0ZV9fY29udHJvbHMge1xuICBkaXNwbGF5OiBncmlkO1xuICBncmlkLWdhcDogOHB4O1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IHJlcGVhdCg0LCAxZnIpO1xuICBtYXJnaW4tdG9wOiA4cHg7XG59XG5gLFxufSlcbmV4cG9ydCBjbGFzcyBTcHhJbnB1dERhdGVDb21wb25lbnQge1xuICBwcml2YXRlIGVsWWVhcj86IEhUTUxFbGVtZW50O1xuICBwcml2YXRlIGVsTW9udGg/OiBIVE1MRWxlbWVudDtcbiAgcHJpdmF0ZSBlbERheT86IEhUTUxFbGVtZW50O1xuICAvLyBARWxlbWVudCgpIGVsITogSFRNTEVsZW1lbnQ7XG4gIEBJbnB1dCgpIHNweE1heD86IHN0cmluZztcbiAgQElucHV0KCkgc3B4TWluPzogc3RyaW5nO1xuICBASW5wdXQoKSBzcHhOYW1lPzogc3RyaW5nO1xuICBASW5wdXQoKSBzcHhSZWFkb25seSA9IGZhbHNlO1xuICBASW5wdXQoKSBzcHhWYWxpZGF0b3JzPzogYW55W107XG4gIEBJbnB1dCgpIHNweEZvY3VzZWQgPSB0cnVlO1xuICBASW5wdXQoKSBzcHhTZWxlY3RNb250aCA9IHRydWU7XG4gIEBJbnB1dCgpIHNweFNlbGVjdERheSA9IHRydWU7XG4gIEBJbnB1dCgpIHZhbHVlPzogU3B4VmFsdWVQYWlyPHN0cmluZz47XG4gIEBPdXRwdXQoKSBzcHhDaGFuZ2U6IEV2ZW50RW1pdHRlcjxTcHhWYWx1ZVBhaXI8YW55Pj4gPSBuZXcgRXZlbnRFbWl0dGVyPFNweFZhbHVlUGFpcjxhbnk+PigpO1xuICBAT3V0cHV0KCkgc3B4Rm9jdXM6IEV2ZW50RW1pdHRlcjx2b2lkPiA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgQElucHV0KCkgc3B4TGFzdEtleVByZXNzZWQhOiBudWxsO1xuICBASW5wdXQoKSBzcHhTZWxlY3RTdGVwOiAneWVhcnMnIHwgJ2RheXMnIHwgJ21vbnRocycgPSAneWVhcnMnO1xuICBASW5wdXQoKSBzcHhJbnRlcm5hbFZhbHVlOiB7XG4gICAgeWVhcnM/OiBudW1iZXI7XG4gICAgbW9udGhzPzogbnVtYmVyO1xuICAgIGRheXM/OiBudW1iZXI7XG4gIH0gPSB7fTtcbiAgQElucHV0KCkgc3B4U3VnZ2VzdGlvbnM6IHtcbiAgICB5ZWFyczogU3B4VmFsdWVQYWlyPG51bWJlcj5bXTtcbiAgICBtb250aHM6IFNweFZhbHVlUGFpcjxudW1iZXI+W107XG4gICAgZGF5czogU3B4VmFsdWVQYWlyPG51bWJlcj5bXTtcbiAgfSA9IHtcbiAgICAgIHllYXJzOiBbXSxcbiAgICAgIG1vbnRoczogW3tcbiAgICAgICAgZGVzY3JpcHRpb246ICdKYW4nLFxuICAgICAgICB2YWx1ZTogMSxcbiAgICAgIH0sIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdGZWInLFxuICAgICAgICB2YWx1ZTogMixcbiAgICAgIH0sIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdNYXInLFxuICAgICAgICB2YWx1ZTogMyxcbiAgICAgIH0sIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdBcHInLFxuICAgICAgICB2YWx1ZTogNCxcbiAgICAgIH0sIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdNYXknLFxuICAgICAgICB2YWx1ZTogNSxcbiAgICAgIH0sIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdKdW4nLFxuICAgICAgICB2YWx1ZTogNixcbiAgICAgIH0sIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdKdWwnLFxuICAgICAgICB2YWx1ZTogNyxcbiAgICAgIH0sIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdBdWcnLFxuICAgICAgICB2YWx1ZTogOCxcbiAgICAgIH0sIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdTZXAnLFxuICAgICAgICB2YWx1ZTogOSxcbiAgICAgIH0sIHtcbiAgICAgICAgZGVzY3JpcHRpb246ICdPY3QnLFxuICAgICAgICB2YWx1ZTogMTAsXG4gICAgICB9LCB7XG4gICAgICAgIGRlc2NyaXB0aW9uOiAnTm92JyxcbiAgICAgICAgdmFsdWU6IDExLFxuICAgICAgfSwge1xuICAgICAgICBkZXNjcmlwdGlvbjogJ0RlYycsXG4gICAgICAgIHZhbHVlOiAxMixcbiAgICAgIH1dLFxuICAgICAgZGF5czogW10sXG4gICAgfTtcbiAgQElucHV0KCkgc3B4V2FzSW50ZXJuYWxVcGRhdGUgPSBmYWxzZTtcbiAgYXN5bmMgc3B4U2V0Rm9jdXMoKSB7XG4gICAgLy8gdGhpcy5lbFllYXIuZm9jdXMoKTtcbiAgfVxuICAvLyBAV2F0Y2goJ3NweFZhbGlkYXRvcnMnKSB3YXRjaFNweFZhbGlkYXRvcnMobmV3VmFsdWUpIHtcbiAgLy8gICBjb25zb2xlLmxvZygndmFsaWRhdG9ycycsIG5ld1ZhbHVlKTtcbiAgLy8gfVxuICAvLyBAV2F0Y2goJ3ZhbHVlJykgd2F0Y2hWYWx1ZShuZXdWYWx1ZSkge1xuICAvLyAgIGlmICh0aGlzLnNweFdhc0ludGVybmFsVXBkYXRlKSB7XG4gIC8vICAgICB0aGlzLnNweFdhc0ludGVybmFsVXBkYXRlID0gZmFsc2U7XG4gIC8vICAgfSBlbHNlIHtcbiAgLy8gICAgIGNvbnN0IHBhcnNlZFZhbHVlID0gRGF0ZVRpbWUuZnJvbUlTTyhuZXdWYWx1ZT8udmFsdWUpO1xuICAvLyAgICAgdGhpcy5zcHhJbnRlcm5hbFZhbHVlLnllYXJzID0gcGFyc2VkVmFsdWUueWVhcjtcbiAgLy8gICAgIHRoaXMuc3B4SW50ZXJuYWxWYWx1ZS5tb250aHMgPSBwYXJzZWRWYWx1ZS5tb250aDtcbiAgLy8gICAgIHRoaXMuc3B4SW50ZXJuYWxWYWx1ZS5kYXlzID0gcGFyc2VkVmFsdWUuZGF5O1xuICAvLyAgICAgdGhpcy5zcHhTZWxlY3RTdGVwID0gJ3llYXJzJztcbiAgLy8gICB9XG4gIC8vIH1cblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLnN1Z2dlc3RZZWFycygpO1xuICB9XG5cbiAgY29tcG9uZW50V2lsbExvYWQoKSB7XG4gICAgY29uc3QgcGFyc2VkVmFsdWUgPSB0aGlzLnZhbHVlID8gRGF0ZVRpbWUuZnJvbUlTTyh0aGlzLnZhbHVlIS52YWx1ZSkgOiBEYXRlVGltZS5ub3coKTtcbiAgICB0aGlzLnNweEludGVybmFsVmFsdWUueWVhcnMgPSBwYXJzZWRWYWx1ZS55ZWFyO1xuICAgIHRoaXMuc3B4SW50ZXJuYWxWYWx1ZS5tb250aHMgPSBwYXJzZWRWYWx1ZS5tb250aDtcbiAgICB0aGlzLnNweEludGVybmFsVmFsdWUuZGF5cyA9IHBhcnNlZFZhbHVlLmRheTtcbiAgfVxuXG4gIGhhbmRsZURheUlucHV0KGV2ZW50OiBhbnkpIHtcbiAgICB0aGlzLnNweEludGVybmFsVmFsdWUuZGF5cyA9IGV2ZW50LnRhcmdldCA/IGV2ZW50LnRhcmdldC52YWx1ZSA6IG51bGw7XG4gICAgdGhpcy51cGRhdGVWYWx1ZSgpO1xuICB9XG5cbiAgaGFuZGxlTW9udGhJbnB1dChldmVudDogYW55KSB7XG4gICAgdGhpcy5zcHhJbnRlcm5hbFZhbHVlLm1vbnRocyA9IGV2ZW50LnRhcmdldCA/IGV2ZW50LnRhcmdldC52YWx1ZSA6IG51bGw7XG4gICAgdGhpcy5hZnRlck1vbnRoQ2hhbmdlKCk7XG4gIH1cblxuICBhZnRlck1vbnRoQ2hhbmdlKCkge1xuICAgIGlmICh0aGlzLnNweEludGVybmFsVmFsdWUubW9udGhzIS50b1N0cmluZygpLmxlbmd0aCA9PT0gMiAmJiB0aGlzLnNweFNlbGVjdERheSAmJiB0aGlzLnNweExhc3RLZXlQcmVzc2VkICE9PSAzOCAmJiB0aGlzLnNweExhc3RLZXlQcmVzc2VkICE9PSA0MCkge1xuICAgICAgLy8gdGhpcy5lbERheSEuZm9jdXMoKTtcbiAgICB9XG4gICAgdGhpcy51cGRhdGVWYWx1ZSgpO1xuICB9XG5cbiAgaGFuZGxlWWVhcklucHV0KGV2ZW50OiBhbnkpIHtcbiAgICB0aGlzLnNweEludGVybmFsVmFsdWUueWVhcnMgPSBldmVudC50YXJnZXQgPyBldmVudC50YXJnZXQudmFsdWUgOiBudWxsO1xuICAgIHRoaXMuYWZ0ZXJZZWFyQ2hhbmdlKCk7XG4gIH1cblxuICBhZnRlclllYXJDaGFuZ2UoKSB7XG4gICAgaWYgKHRoaXMuc3B4SW50ZXJuYWxWYWx1ZS55ZWFycyEudG9TdHJpbmcoKS5sZW5ndGggPT09IDQgJiYgdGhpcy5zcHhTZWxlY3RNb250aCAmJiB0aGlzLnNweExhc3RLZXlQcmVzc2VkICE9PSAzOCAmJiB0aGlzLnNweExhc3RLZXlQcmVzc2VkICE9PSA0MCkge1xuICAgICAgLy8gdGhpcy5lbE1vbnRoIS5mb2N1cygpO1xuICAgIH1cbiAgICB0aGlzLnVwZGF0ZVZhbHVlKCk7XG4gIH1cblxuICBoYW5kbGVJbnB1dChldmVudDogYW55KSB7XG4gICAgdGhpcy5zZXRWYWx1ZShldmVudC50YXJnZXQgPyBldmVudC50YXJnZXQudmFsdWUgOiBudWxsKTtcbiAgfVxuXG4gIGhhbmRsZUZvY3VzKHN0ZXA6ICd5ZWFycycgfCAnbW9udGhzJyB8ICdkYXlzJykge1xuICAgIHRoaXMuc3B4U2VsZWN0U3RlcCA9IHN0ZXA7XG4gICAgdGhpcy5zcHhGb2N1cy5lbWl0KCk7XG4gIH1cblxuICBoYW5kbGVLZXlEb3duKGV2ZW50OiBhbnkpIHtcbiAgICB0aGlzLnNweExhc3RLZXlQcmVzc2VkID0gZXZlbnQud2hpY2g7XG4gIH1cblxuICBoYW5kbGVTdWdnZXN0aW9uQ2xpY2sodmFsdWU6IG51bWJlcikge1xuICAgIHRoaXMuc3B4TGFzdEtleVByZXNzZWQgPSBudWxsO1xuICAgIHRoaXMuc3B4SW50ZXJuYWxWYWx1ZVt0aGlzLnNweFNlbGVjdFN0ZXBdID0gdmFsdWU7XG4gICAgdGhpcy51cGRhdGVWYWx1ZSgpO1xuICAgIHRoaXMuZG9uZVdpdGhGaWVsZCgpO1xuICB9XG5cbiAgdXBkYXRlVmFsdWUoKSB7XG4gICAgY29uc3QgY29uY2F0ZW5hdGVkVmFsdWUgPSBgJHt0aGlzLnNweEludGVybmFsVmFsdWUueWVhcnMgPyB0aGlzLnNweEludGVybmFsVmFsdWUueWVhcnMgOiBgYH0ke3RoaXMuc3B4SW50ZXJuYWxWYWx1ZS5tb250aHMgPyBgLSR7dGhpcy5zcHhJbnRlcm5hbFZhbHVlLm1vbnRocyA8IDEwID8gYDAke3RoaXMuc3B4SW50ZXJuYWxWYWx1ZS5tb250aHN9YCA6IHRoaXMuc3B4SW50ZXJuYWxWYWx1ZS5tb250aHN9YCA6IGBgfSR7dGhpcy5zcHhJbnRlcm5hbFZhbHVlLmRheXMgPyBgLSR7dGhpcy5zcHhJbnRlcm5hbFZhbHVlLmRheXMgPCAxMCA/IGAwJHt0aGlzLnNweEludGVybmFsVmFsdWUuZGF5c31gIDogdGhpcy5zcHhJbnRlcm5hbFZhbHVlLmRheXN9YCA6IGBgfWBcbiAgICBjb25zdCBwYXJzZWRWYWx1ZSA9IERhdGVUaW1lLmZyb21JU08oY29uY2F0ZW5hdGVkVmFsdWUpO1xuICAgIHRoaXMuc3B4V2FzSW50ZXJuYWxVcGRhdGUgPSB0cnVlO1xuICAgIHRoaXMudmFsdWUgPSB7XG4gICAgICBkZXNjcmlwdGlvbjogcGFyc2VkVmFsdWUudG9JU08oKSxcbiAgICAgIHZhbHVlOiBwYXJzZWRWYWx1ZS50b0lTTygpISxcbiAgICB9O1xuICAgIHRoaXMuc3B4Q2hhbmdlLmVtaXQodGhpcy52YWx1ZSk7XG4gIH1cblxuICBkb25lV2l0aEZpZWxkKCkge1xuICAgIGlmICh0aGlzLnNweFNlbGVjdFN0ZXAgPT09ICdkYXlzJykge1xuICAgICAgdGhpcy5zcHhTZWxlY3RTdGVwID0gJ3llYXJzJztcbiAgICB9IGVsc2UgaWYgKHRoaXMuc3B4U2VsZWN0U3RlcCA9PT0gJ21vbnRocycpIHtcbiAgICAgIHRoaXMuc3B4U2VsZWN0U3RlcCA9IHRoaXMuc3B4U2VsZWN0RGF5ID8gJ2RheXMnIDogJ3llYXJzJztcbiAgICAgIHRoaXMuYWZ0ZXJNb250aENoYW5nZSgpO1xuICAgIH0gZWxzZSBpZiAodGhpcy5zcHhTZWxlY3RTdGVwID09PSAneWVhcnMnKSB7XG4gICAgICB0aGlzLmFmdGVyWWVhckNoYW5nZSgpO1xuICAgICAgdGhpcy5zcHhTZWxlY3RTdGVwID0gdGhpcy5zcHhTZWxlY3RNb250aCA/ICdtb250aHMnIDogJ3llYXJzJztcbiAgICB9XG4gIH1cblxuICBzZXRWYWx1ZSh2YWx1ZTogYW55KSB7XG4gICAgdGhpcy5zcHhJbnRlcm5hbFZhbHVlID0gdmFsdWU7XG4gICAgY29uc3QgcGFyc2VkID0gRGF0ZVRpbWUuZnJvbUlTTyh2YWx1ZSk7XG4gICAgdGhpcy52YWx1ZSA9IHtcbiAgICAgIGRlc2NyaXB0aW9uOiBwYXJzZWQudG9JU08oKSxcbiAgICAgIHZhbHVlOiBwYXJzZWQudG9JU08oKSEsXG4gICAgfTtcbiAgICB0aGlzLnNweENoYW5nZS5lbWl0KHRoaXMudmFsdWUpO1xuICAgIHRoaXMuc3B4V2FzSW50ZXJuYWxVcGRhdGUgPSB0cnVlO1xuICB9XG5cbiAgcHJpdmF0ZSBzdWdnZXN0WWVhcnMoKTogdm9pZCB7XG4gICAgdGhpcy5zcHhTdWdnZXN0aW9ucy55ZWFycyA9IFtdO1xuICAgIGZvciAobGV0IHllYXIgPSBEYXRlVGltZS5mcm9tSVNPKHRoaXMuc3B4TWluISkueWVhcjsgeWVhciA8PSBEYXRlVGltZS5mcm9tSVNPKHRoaXMuc3B4TWF4ISkueWVhcjsgeWVhcisrKSB7XG4gICAgICB0aGlzLnNweFN1Z2dlc3Rpb25zLnllYXJzLnB1c2goe1xuICAgICAgICBkZXNjcmlwdGlvbjogYCcke3llYXIudG9TdHJpbmcoKS5zdWJzdHJpbmcoMiw0KX1gLFxuICAgICAgICB2YWx1ZTogeWVhcixcbiAgICAgIH0pO1xuICAgIH1cbiAgfVxufVxuIl19
|