design-angular-kit 1.0.0-16 → 1.0.0-18
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +31 -6
- package/assets/i18n/en.json +4 -1
- package/assets/i18n/it.json +4 -1
- package/esm2022/lib/abstracts/abstract-form.component.mjs +186 -0
- package/esm2022/lib/abstracts/abstract.component.mjs +45 -0
- package/esm2022/lib/components/components.module.mjs +188 -0
- package/esm2022/lib/components/core/accordion/accordion.component.mjs +38 -0
- package/esm2022/lib/components/core/alert/alert.component.mjs +74 -0
- package/esm2022/lib/components/core/badge/badge.directive.mjs +38 -0
- package/esm2022/lib/components/core/button/button.directive.mjs +85 -0
- package/esm2022/lib/components/core/callout/callout.component.mjs +57 -0
- package/esm2022/lib/components/core/card/card.component.mjs +64 -0
- package/esm2022/lib/components/core/carousel/carousel/carousel.component.mjs +89 -0
- package/esm2022/lib/components/core/carousel/carousel-item/carousel-item.component.mjs +19 -0
- package/esm2022/lib/components/core/carousel/carousel.module.mjs +23 -0
- package/esm2022/lib/components/core/chip/chip.component.mjs +96 -0
- package/esm2022/lib/components/core/collapse/collapse.component.mjs +101 -0
- package/esm2022/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.mjs +24 -0
- package/esm2022/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.mjs +11 -0
- package/esm2022/lib/components/core/dimmer/dimmer.component.mjs +59 -0
- package/esm2022/lib/components/core/dimmer/dimmer.module.mjs +27 -0
- package/esm2022/lib/components/core/dropdown/dropdown/dropdown.component.mjs +143 -0
- package/esm2022/lib/components/core/dropdown/dropdown-item/dropdown-item.component.mjs +68 -0
- package/esm2022/lib/components/core/dropdown/dropdown.module.mjs +18 -0
- package/esm2022/lib/components/core/forward/forward.directive.mjs +53 -0
- package/esm2022/lib/components/core/link/link.component.mjs +46 -0
- package/esm2022/lib/components/core/list/list/list.component.mjs +17 -0
- package/esm2022/lib/components/core/list/list-item/list-item.component.mjs +40 -0
- package/esm2022/lib/components/core/list/list.module.mjs +23 -0
- package/esm2022/lib/components/core/modal/modal.component.mjs +164 -0
- package/esm2022/lib/components/core/notifications/notifications.component.mjs +111 -0
- package/esm2022/lib/components/core/pagination/pagination.component.mjs +133 -0
- package/esm2022/lib/components/core/popover/popover.directive.mjs +175 -0
- package/esm2022/lib/components/core/progress-bar/progress-bar.component.mjs +35 -0
- package/esm2022/lib/components/core/progress-button/progress-button.component.mjs +27 -0
- package/esm2022/lib/components/core/spinner/spinner.component.mjs +36 -0
- package/esm2022/lib/components/core/steppers/steppers-container/steppers-container.component.mjs +138 -0
- package/esm2022/lib/components/core/steppers/steppers-item/steppers-item.component.mjs +19 -0
- package/esm2022/lib/components/core/steppers/steppers.module.mjs +23 -0
- package/esm2022/lib/components/core/tab/tab-container/tab-container.component.mjs +60 -0
- package/esm2022/lib/components/core/tab/tab-item/tab-item.component.mjs +36 -0
- package/esm2022/lib/components/core/tab/tab.module.mjs +23 -0
- package/esm2022/lib/components/core/table/table.component.mjs +57 -0
- package/esm2022/lib/components/core/tooltip/tooltip.directive.mjs +142 -0
- package/esm2022/lib/components/form/checkbox/checkbox.component.mjs +49 -0
- package/esm2022/lib/components/form/form.module.mjs +55 -0
- package/esm2022/lib/components/form/input/input.component.mjs +239 -0
- package/esm2022/lib/components/form/password-input/password-input.component.mjs +155 -0
- package/esm2022/lib/components/form/radio-button/radio-button.component.mjs +69 -0
- package/esm2022/lib/components/form/range/range.component.mjs +64 -0
- package/esm2022/lib/components/form/rating/rating.component.mjs +51 -0
- package/esm2022/lib/components/form/select/select.component.mjs +70 -0
- package/esm2022/lib/components/form/textarea/textarea.component.mjs +47 -0
- package/esm2022/lib/components/form/upload-drag-drop/upload-drag-drop.component.mjs +140 -0
- package/esm2022/lib/components/form/upload-file-list/upload-file-list.component.mjs +112 -0
- package/esm2022/lib/components/navigation/back-button/back-button.component.mjs +71 -0
- package/esm2022/lib/components/navigation/back-to-top/back-to-top.component.mjs +64 -0
- package/esm2022/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.mjs +57 -0
- package/esm2022/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.mjs +23 -0
- package/esm2022/lib/components/navigation/breadcrumbs/breadcrumbs.module.mjs +18 -0
- package/esm2022/lib/components/navigation/header/header.component.mjs +58 -0
- package/esm2022/lib/components/utils/error-page/error-page.component.mjs +81 -0
- package/esm2022/lib/components/utils/icon/icon.component.mjs +55 -0
- package/esm2022/lib/components/utils/language-switcher/language-switcher.component.mjs +41 -0
- package/esm2022/lib/design-angular-kit.module.mjs +68 -0
- package/{esm2020 → esm2022}/lib/interfaces/form.mjs +1 -1
- package/esm2022/lib/interfaces/icon.mjs +165 -0
- package/esm2022/lib/pipes/mark-matching-text.pipe.mjs +37 -0
- package/esm2022/lib/services/notification/notification.service.mjs +120 -0
- package/esm2022/lib/utils/file-utils.mjs +73 -0
- package/esm2022/lib/utils/regex.mjs +31 -0
- package/esm2022/lib/validators/it-validators.mjs +153 -0
- package/esm2022/public_api.mjs +85 -0
- package/fesm2022/design-angular-kit.mjs +4615 -0
- package/fesm2022/design-angular-kit.mjs.map +1 -0
- package/lib/abstracts/abstract-form.component.d.ts +4 -4
- package/lib/abstracts/abstract.component.d.ts +3 -3
- package/lib/components/components.module.d.ts +32 -52
- package/lib/components/core/accordion/accordion.component.d.ts +6 -5
- package/lib/components/core/alert/alert.component.d.ts +5 -5
- package/lib/components/core/badge/badge.directive.d.ts +5 -5
- package/lib/components/core/button/button.directive.d.ts +11 -11
- package/lib/components/core/callout/callout.component.d.ts +7 -7
- package/lib/components/core/card/card.component.d.ts +8 -8
- package/lib/components/core/carousel/carousel/carousel.component.d.ts +10 -10
- package/lib/components/core/carousel/carousel-item/carousel-item.component.d.ts +4 -4
- package/lib/components/core/carousel/carousel.module.d.ts +8 -0
- package/lib/components/core/chip/chip.component.d.ts +6 -3
- package/lib/components/core/collapse/collapse.component.d.ts +8 -8
- package/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.d.ts +3 -3
- package/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.d.ts +3 -3
- package/lib/components/core/dimmer/dimmer.component.d.ts +4 -4
- package/lib/components/core/dimmer/dimmer.module.d.ts +9 -0
- package/lib/components/core/dropdown/dropdown/dropdown.component.d.ts +14 -9
- package/lib/components/core/dropdown/dropdown-item/dropdown-item.component.d.ts +8 -8
- package/lib/components/core/dropdown/dropdown.module.d.ts +8 -0
- package/lib/components/core/forward/forward.directive.d.ts +3 -3
- package/lib/components/core/link/link.component.d.ts +9 -8
- package/lib/components/core/list/list/list.component.d.ts +4 -4
- package/lib/components/core/list/list-item/list-item.component.d.ts +9 -9
- package/lib/components/core/list/list.module.d.ts +8 -0
- package/lib/components/core/modal/modal.component.d.ts +11 -11
- package/lib/components/core/notifications/notifications.component.d.ts +6 -6
- package/lib/components/core/pagination/pagination.component.d.ts +8 -8
- package/lib/components/core/popover/popover.directive.d.ts +3 -3
- package/lib/components/core/progress-bar/progress-bar.component.d.ts +6 -6
- package/lib/components/core/progress-button/progress-button.component.d.ts +5 -5
- package/lib/components/core/spinner/spinner.component.d.ts +5 -5
- package/lib/components/core/steppers/steppers-container/steppers-container.component.d.ts +37 -13
- package/lib/components/core/steppers/steppers-item/steppers-item.component.d.ts +5 -5
- package/lib/components/core/steppers/steppers.module.d.ts +8 -0
- package/lib/components/core/tab/tab-container/tab-container.component.d.ts +9 -9
- package/lib/components/core/tab/tab-item/tab-item.component.d.ts +8 -8
- package/lib/components/core/tab/tab.module.d.ts +8 -0
- package/lib/components/core/table/table.component.d.ts +12 -12
- package/lib/components/core/tooltip/tooltip.directive.d.ts +3 -3
- package/lib/components/form/checkbox/checkbox.component.d.ts +12 -10
- package/lib/components/form/form.module.d.ts +16 -0
- package/lib/components/form/input/input.component.d.ts +18 -13
- package/lib/components/form/password-input/password-input.component.d.ts +11 -6
- package/lib/components/form/radio-button/radio-button.component.d.ts +6 -6
- package/lib/components/form/range/range.component.d.ts +42 -0
- package/lib/components/form/rating/rating.component.d.ts +24 -0
- package/lib/components/form/select/select.component.d.ts +11 -6
- package/lib/components/form/textarea/textarea.component.d.ts +5 -5
- package/lib/components/form/upload-drag-drop/upload-drag-drop.component.d.ts +4 -4
- package/lib/components/form/upload-file-list/upload-file-list.component.d.ts +6 -6
- package/lib/components/navigation/back-button/back-button.component.d.ts +3 -3
- package/lib/components/navigation/back-to-top/back-to-top.component.d.ts +7 -7
- package/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.d.ts +6 -6
- package/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.d.ts +6 -6
- package/lib/components/navigation/breadcrumbs/breadcrumbs.module.d.ts +8 -0
- package/lib/components/navigation/header/header.component.d.ts +6 -6
- package/lib/components/utils/error-page/error-page.component.d.ts +6 -6
- package/lib/components/utils/icon/icon.component.d.ts +7 -7
- package/lib/components/utils/language-switcher/language-switcher.component.d.ts +4 -4
- package/lib/design-angular-kit.module.d.ts +3 -4
- package/lib/interfaces/core.d.ts +16 -16
- package/lib/interfaces/form.d.ts +3 -3
- package/lib/interfaces/icon.d.ts +4 -4
- package/lib/pipes/mark-matching-text.pipe.d.ts +4 -4
- package/lib/services/{notifications/notifications.service.d.ts → notification/notification.service.d.ts} +3 -3
- package/lib/utils/boolean-input.d.ts +1 -1
- package/lib/utils/regex.d.ts +5 -0
- package/lib/validators/it-validators.d.ts +4 -0
- package/package.json +13 -19
- package/public_api.d.ts +13 -4
- package/esm2020/lib/abstracts/abstract-form.component.mjs +0 -188
- package/esm2020/lib/abstracts/abstract.component.mjs +0 -45
- package/esm2020/lib/components/components.module.mjs +0 -256
- package/esm2020/lib/components/core/accordion/accordion.component.mjs +0 -35
- package/esm2020/lib/components/core/alert/alert.component.mjs +0 -73
- package/esm2020/lib/components/core/badge/badge.directive.mjs +0 -37
- package/esm2020/lib/components/core/button/button.directive.mjs +0 -84
- package/esm2020/lib/components/core/callout/callout.component.mjs +0 -57
- package/esm2020/lib/components/core/card/card.component.mjs +0 -64
- package/esm2020/lib/components/core/carousel/carousel/carousel.component.mjs +0 -89
- package/esm2020/lib/components/core/carousel/carousel-item/carousel-item.component.mjs +0 -19
- package/esm2020/lib/components/core/chip/chip.component.mjs +0 -89
- package/esm2020/lib/components/core/collapse/collapse.component.mjs +0 -101
- package/esm2020/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.mjs +0 -24
- package/esm2020/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.mjs +0 -11
- package/esm2020/lib/components/core/dimmer/dimmer.component.mjs +0 -59
- package/esm2020/lib/components/core/dropdown/dropdown/dropdown.component.mjs +0 -130
- package/esm2020/lib/components/core/dropdown/dropdown-item/dropdown-item.component.mjs +0 -68
- package/esm2020/lib/components/core/forward/forward.directive.mjs +0 -52
- package/esm2020/lib/components/core/link/link.component.mjs +0 -40
- package/esm2020/lib/components/core/list/list/list.component.mjs +0 -17
- package/esm2020/lib/components/core/list/list-item/list-item.component.mjs +0 -41
- package/esm2020/lib/components/core/modal/modal.component.mjs +0 -163
- package/esm2020/lib/components/core/notifications/notifications.component.mjs +0 -110
- package/esm2020/lib/components/core/pagination/pagination.component.mjs +0 -131
- package/esm2020/lib/components/core/popover/popover.directive.mjs +0 -174
- package/esm2020/lib/components/core/progress-bar/progress-bar.component.mjs +0 -34
- package/esm2020/lib/components/core/progress-button/progress-button.component.mjs +0 -27
- package/esm2020/lib/components/core/rating/rating.component.mjs +0 -49
- package/esm2020/lib/components/core/spinner/spinner.component.mjs +0 -35
- package/esm2020/lib/components/core/steppers/steppers-container/steppers-container.component.mjs +0 -127
- package/esm2020/lib/components/core/steppers/steppers-item/steppers-item.component.mjs +0 -19
- package/esm2020/lib/components/core/tab/tab-container/tab-container.component.mjs +0 -59
- package/esm2020/lib/components/core/tab/tab-item/tab-item.component.mjs +0 -36
- package/esm2020/lib/components/core/table/table.component.mjs +0 -57
- package/esm2020/lib/components/core/tooltip/tooltip.directive.mjs +0 -141
- package/esm2020/lib/components/form/checkbox/checkbox.component.mjs +0 -40
- package/esm2020/lib/components/form/input/input.component.mjs +0 -232
- package/esm2020/lib/components/form/password-input/password-input.component.mjs +0 -152
- package/esm2020/lib/components/form/radio-button/radio-button.component.mjs +0 -68
- package/esm2020/lib/components/form/select/select.component.mjs +0 -62
- package/esm2020/lib/components/form/textarea/textarea.component.mjs +0 -46
- package/esm2020/lib/components/form/upload-drag-drop/upload-drag-drop.component.mjs +0 -139
- package/esm2020/lib/components/form/upload-file-list/upload-file-list.component.mjs +0 -104
- package/esm2020/lib/components/navigation/back-button/back-button.component.mjs +0 -69
- package/esm2020/lib/components/navigation/back-to-top/back-to-top.component.mjs +0 -64
- package/esm2020/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.mjs +0 -56
- package/esm2020/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.mjs +0 -23
- package/esm2020/lib/components/navigation/header/header.component.mjs +0 -57
- package/esm2020/lib/components/utils/error-page/error-page.component.mjs +0 -79
- package/esm2020/lib/components/utils/icon/icon.component.mjs +0 -55
- package/esm2020/lib/components/utils/language-switcher/language-switcher.component.mjs +0 -39
- package/esm2020/lib/design-angular-kit.module.mjs +0 -68
- package/esm2020/lib/interfaces/icon.mjs +0 -162
- package/esm2020/lib/pipes/mark-matching-text.pipe.mjs +0 -36
- package/esm2020/lib/services/notifications/notifications.service.mjs +0 -120
- package/esm2020/lib/utils/file-utils.mjs +0 -73
- package/esm2020/lib/utils/regex.mjs +0 -26
- package/esm2020/lib/validators/it-validators.mjs +0 -147
- package/esm2020/public_api.mjs +0 -74
- package/fesm2015/design-angular-kit.mjs +0 -4422
- package/fesm2015/design-angular-kit.mjs.map +0 -1
- package/fesm2020/design-angular-kit.mjs +0 -4354
- package/fesm2020/design-angular-kit.mjs.map +0 -1
- package/lib/components/core/rating/rating.component.d.ts +0 -24
- /package/{esm2020 → esm2022}/design-angular-kit.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/design-angular-kit-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/interfaces/core.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/interfaces/design-angular-kit-init.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/interfaces/utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/utils/boolean-input.mjs +0 -0
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Output } from '@angular/core';
|
|
2
|
+
import { NgClass, NgIf } from '@angular/common';
|
|
3
|
+
import { DESIGN_ANGULAR_KIT_CONFIG } from '../../../design-angular-kit-config';
|
|
4
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@ngx-translate/core";
|
|
7
|
+
import * as i2 from "../../../design-angular-kit-config";
|
|
8
|
+
export class ItChipComponent {
|
|
9
|
+
/**
|
|
10
|
+
* Indica la label
|
|
11
|
+
*/
|
|
12
|
+
set label(value) { this._label = value; }
|
|
13
|
+
get label() { return this._label; }
|
|
14
|
+
/**
|
|
15
|
+
* Indica se mostrate il pulante di chisura
|
|
16
|
+
*/
|
|
17
|
+
set showCloseButton(value) { this._showCloseButton = value; }
|
|
18
|
+
get showCloseButton() { return this._showCloseButton; }
|
|
19
|
+
/**
|
|
20
|
+
* Indica il size
|
|
21
|
+
*/
|
|
22
|
+
set size(value) { this._size = value; }
|
|
23
|
+
get size() { return this._size; }
|
|
24
|
+
/**
|
|
25
|
+
* Indica il colore della chip
|
|
26
|
+
*/
|
|
27
|
+
set color(value) { this._color = value; }
|
|
28
|
+
get color() { return this._color; }
|
|
29
|
+
/**
|
|
30
|
+
* Indica se la chip è disabilitata
|
|
31
|
+
*/
|
|
32
|
+
set disabled(value) { this._disabled = value; }
|
|
33
|
+
get disabled() { return this._disabled; }
|
|
34
|
+
/**
|
|
35
|
+
* Indica il nome dell'icona, se valorizzata viene mostrata
|
|
36
|
+
*/
|
|
37
|
+
set icon(value) { this._icon = value; }
|
|
38
|
+
get icon() { return this._icon; }
|
|
39
|
+
/**
|
|
40
|
+
* Indica l'url dell'avatar, se valorizzata viene mostrata
|
|
41
|
+
*/
|
|
42
|
+
set avatar(value) { this._avatar = value; }
|
|
43
|
+
get avatar() { return this._avatar; }
|
|
44
|
+
/**
|
|
45
|
+
* Indica il valore da aggiungere al parametro alt, di default ''
|
|
46
|
+
*/
|
|
47
|
+
set altAvatar(value) { this._altAvatar = value; }
|
|
48
|
+
get altAvatar() { return this._altAvatar; }
|
|
49
|
+
constructor(config) {
|
|
50
|
+
this.config = config;
|
|
51
|
+
this._label = '';
|
|
52
|
+
this._showCloseButton = false;
|
|
53
|
+
this._size = '';
|
|
54
|
+
this._color = undefined;
|
|
55
|
+
this._disabled = false;
|
|
56
|
+
this._icon = undefined;
|
|
57
|
+
this._avatar = undefined;
|
|
58
|
+
this._altAvatar = '';
|
|
59
|
+
/**
|
|
60
|
+
* Evento emesso al click sul bottone di chiusura
|
|
61
|
+
*/
|
|
62
|
+
this.closeEvent = new EventEmitter();
|
|
63
|
+
this.iconClose = 'close';
|
|
64
|
+
}
|
|
65
|
+
clickToClose() {
|
|
66
|
+
this.closeEvent.emit();
|
|
67
|
+
}
|
|
68
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItChipComponent, deps: [{ token: DESIGN_ANGULAR_KIT_CONFIG }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
69
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.3", type: ItChipComponent, isStandalone: true, selector: "it-chip", inputs: { label: "label", showCloseButton: "showCloseButton", size: "size", color: "color", disabled: "disabled", icon: "icon", avatar: "avatar", altAvatar: "altAvatar" }, outputs: { closeEvent: "closeEvent" }, ngImport: i0, template: "<div class=\"chip\" [ngClass]=\"[!showCloseButton ? 'chip-simple': 'alert', size === 'lg' ? 'chip-lg': '', color ? 'chip-' + color : '', disabled ? 'chip-disabled' : '']\">\n <svg *ngIf=\"icon\" class=\"icon icon-xs\">\n <use [attr.href]=\"this.config.iconHref + '#it-' + icon\" [attr.xlink:href]=\"this.config.iconHref + '#it-' + icon\"></use>\n </svg>\n <div *ngIf=\"avatar\" class=\"avatar size-xs\"><img [src]=\"avatar\" [alt]=\"altAvatar\"></div>\n <span class=\"chip-label\">{{ label }}</span>\n <button *ngIf=\"showCloseButton\" (click)=\"clickToClose()\" [disabled]=\"disabled\">\n <svg class=\"icon\"><use [attr.href]=\"this.config.iconHref + '#it-close'\" [attr.xlink:href]=\"this.config.iconHref + '#it-close'\"></use></svg>\n <span class=\"visually-hidden\">{{ 'it.core.remove' | translate }} {{ label }}</span>\n </button>\n</div>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
70
|
+
}
|
|
71
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItChipComponent, decorators: [{
|
|
72
|
+
type: Component,
|
|
73
|
+
args: [{ standalone: true, selector: 'it-chip', changeDetection: ChangeDetectionStrategy.OnPush, imports: [NgClass, NgIf, TranslateModule], template: "<div class=\"chip\" [ngClass]=\"[!showCloseButton ? 'chip-simple': 'alert', size === 'lg' ? 'chip-lg': '', color ? 'chip-' + color : '', disabled ? 'chip-disabled' : '']\">\n <svg *ngIf=\"icon\" class=\"icon icon-xs\">\n <use [attr.href]=\"this.config.iconHref + '#it-' + icon\" [attr.xlink:href]=\"this.config.iconHref + '#it-' + icon\"></use>\n </svg>\n <div *ngIf=\"avatar\" class=\"avatar size-xs\"><img [src]=\"avatar\" [alt]=\"altAvatar\"></div>\n <span class=\"chip-label\">{{ label }}</span>\n <button *ngIf=\"showCloseButton\" (click)=\"clickToClose()\" [disabled]=\"disabled\">\n <svg class=\"icon\"><use [attr.href]=\"this.config.iconHref + '#it-close'\" [attr.xlink:href]=\"this.config.iconHref + '#it-close'\"></use></svg>\n <span class=\"visually-hidden\">{{ 'it.core.remove' | translate }} {{ label }}</span>\n </button>\n</div>\n" }]
|
|
74
|
+
}], ctorParameters: function () { return [{ type: i2.DesignAngularKitConfig, decorators: [{
|
|
75
|
+
type: Inject,
|
|
76
|
+
args: [DESIGN_ANGULAR_KIT_CONFIG]
|
|
77
|
+
}] }]; }, propDecorators: { label: [{
|
|
78
|
+
type: Input
|
|
79
|
+
}], showCloseButton: [{
|
|
80
|
+
type: Input
|
|
81
|
+
}], size: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}], color: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}], disabled: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], icon: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}], avatar: [{
|
|
90
|
+
type: Input
|
|
91
|
+
}], altAvatar: [{
|
|
92
|
+
type: Input
|
|
93
|
+
}], closeEvent: [{
|
|
94
|
+
type: Output
|
|
95
|
+
}] } });
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tYW5ndWxhci1raXQvc3JjL2xpYi9jb21wb25lbnRzL2NvcmUvY2hpcC9jaGlwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9jaGlwL2NoaXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHeEcsT0FBTyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUNoRCxPQUFPLEVBQUUseUJBQXlCLEVBQTBCLE1BQU0sb0NBQW9DLENBQUM7QUFDdkcsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDOzs7O0FBU3RELE1BQU0sT0FBTyxlQUFlO0lBRTFCOztNQUVFO0lBQ0YsSUFBYSxLQUFLLENBQUUsS0FBYSxJQUFJLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUMzRCxJQUFJLEtBQUssS0FBYyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBRzVDOztNQUVFO0lBQ0YsSUFBYSxlQUFlLENBQUUsS0FBYyxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ2hGLElBQUksZUFBZSxLQUFlLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUMsQ0FBQztJQUdqRTs7TUFFRTtJQUNGLElBQWEsSUFBSSxDQUFFLEtBQWdCLElBQUksSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQzVELElBQUksSUFBSSxLQUFpQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBRzdDOztNQUVFO0lBQ0YsSUFBYSxLQUFLLENBQUUsS0FBNEIsSUFBSSxJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDMUUsSUFBSSxLQUFLLEtBQTZCLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7SUFHM0Q7O01BRUU7SUFDRixJQUFhLFFBQVEsQ0FBRSxLQUFjLElBQUksSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ2xFLElBQUksUUFBUSxLQUFlLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFHbkQ7O01BRUU7SUFDRixJQUFhLElBQUksQ0FBRSxLQUEyQixJQUFJLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUN2RSxJQUFJLElBQUksS0FBNEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUd4RDs7TUFFRTtJQUNGLElBQWEsTUFBTSxDQUFFLEtBQXlCLElBQUksSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ3pFLElBQUksTUFBTSxLQUEwQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO0lBRzFEOztNQUVFO0lBQ0YsSUFBYSxTQUFTLENBQUUsS0FBYSxJQUFJLElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNuRSxJQUFJLFNBQVMsS0FBYyxPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO0lBVXBELFlBQ3dELE1BQThCO1FBQTlCLFdBQU0sR0FBTixNQUFNLENBQXdCO1FBM0Q5RSxXQUFNLEdBQUcsRUFBRSxDQUFDO1FBT1oscUJBQWdCLEdBQUcsS0FBSyxDQUFDO1FBT3pCLFVBQUssR0FBZSxFQUFFLENBQUM7UUFPdkIsV0FBTSxHQUEyQixTQUFTLENBQUM7UUFPM0MsY0FBUyxHQUFhLEtBQUssQ0FBQztRQU81QixVQUFLLEdBQTBCLFNBQVMsQ0FBQztRQU96QyxZQUFPLEdBQXdCLFNBQVMsQ0FBQztRQU96QyxlQUFVLEdBQVksRUFBRSxDQUFDO1FBRWpDOztVQUVFO1FBQ1EsZUFBVSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFFMUMsY0FBUyxHQUFhLE9BQU8sQ0FBQztJQUs5QixDQUFDO0lBRUQsWUFBWTtRQUNWLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDekIsQ0FBQzs4R0F4RVUsZUFBZSxrQkFrRWhCLHlCQUF5QjtrR0FsRXhCLGVBQWUsc1JDZDVCLG8zQkFXQSw0Q0RDWSxPQUFPLG9GQUFFLElBQUksNEZBQUUsZUFBZTs7MkZBRTdCLGVBQWU7a0JBUDNCLFNBQVM7aUNBQ0ksSUFBSSxZQUNOLFNBQVMsbUJBRUYsdUJBQXVCLENBQUMsTUFBTSxXQUN0QyxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsZUFBZSxDQUFDOzswQkFvRXRDLE1BQU07MkJBQUMseUJBQXlCOzRDQTdEdEIsS0FBSztzQkFBakIsS0FBSztnQkFPTyxlQUFlO3NCQUEzQixLQUFLO2dCQU9PLElBQUk7c0JBQWhCLEtBQUs7Z0JBT08sS0FBSztzQkFBakIsS0FBSztnQkFPTyxRQUFRO3NCQUFwQixLQUFLO2dCQU9PLElBQUk7c0JBQWhCLEtBQUs7Z0JBT08sTUFBTTtzQkFBbEIsS0FBSztnQkFPTyxTQUFTO3NCQUFyQixLQUFLO2dCQU9JLFVBQVU7c0JBQW5CLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEluamVjdCwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSWNvbk5hbWUgfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzL2ljb24nO1xuaW1wb3J0IHsgQ2hpcENvbG9yIH0gZnJvbSAnLi4vLi4vLi4vaW50ZXJmYWNlcy9jb3JlJztcbmltcG9ydCB7IE5nQ2xhc3MsIE5nSWYgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgREVTSUdOX0FOR1VMQVJfS0lUX0NPTkZJRywgRGVzaWduQW5ndWxhcktpdENvbmZpZyB9IGZyb20gJy4uLy4uLy4uL2Rlc2lnbi1hbmd1bGFyLWtpdC1jb25maWcnO1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ2l0LWNoaXAnLFxuICB0ZW1wbGF0ZVVybDogJy4vY2hpcC5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBpbXBvcnRzOiBbTmdDbGFzcywgTmdJZiwgVHJhbnNsYXRlTW9kdWxlXVxufSlcbmV4cG9ydCBjbGFzcyBJdENoaXBDb21wb25lbnQge1xuXG4gIC8qKlxuICAgKiBJbmRpY2EgbGEgbGFiZWxcbiAgKi9cbiAgQElucHV0KCkgc2V0IGxhYmVsICh2YWx1ZTogc3RyaW5nKSB7IHRoaXMuX2xhYmVsID0gdmFsdWU7IH1cbiAgZ2V0IGxhYmVsICgpOiBzdHJpbmcgeyByZXR1cm4gdGhpcy5fbGFiZWw7IH1cbiAgcHJpdmF0ZSBfbGFiZWwgPSAnJztcblxuICAvKipcbiAgICogSW5kaWNhIHNlIG1vc3RyYXRlIGlsIHB1bGFudGUgZGkgY2hpc3VyYVxuICAqL1xuICBASW5wdXQoKSBzZXQgc2hvd0Nsb3NlQnV0dG9uICh2YWx1ZTogYm9vbGVhbikgeyB0aGlzLl9zaG93Q2xvc2VCdXR0b24gPSB2YWx1ZTsgfVxuICBnZXQgc2hvd0Nsb3NlQnV0dG9uICgpOiBib29sZWFuIHsgcmV0dXJuIHRoaXMuX3Nob3dDbG9zZUJ1dHRvbjsgfVxuICBwcml2YXRlIF9zaG93Q2xvc2VCdXR0b24gPSBmYWxzZTtcblxuICAvKipcbiAgICogSW5kaWNhIGlsIHNpemVcbiAgKi9cbiAgQElucHV0KCkgc2V0IHNpemUgKHZhbHVlOiAnJyB8ICdsZycpIHsgdGhpcy5fc2l6ZSA9IHZhbHVlOyB9XG4gIGdldCBzaXplICgpOiAnJyB8ICdsZycgeyByZXR1cm4gdGhpcy5fc2l6ZTsgfVxuICBwcml2YXRlIF9zaXplOiAnJyB8ICdsZycgID0gJyc7XG5cbiAgLyoqXG4gICAqIEluZGljYSBpbCBjb2xvcmUgZGVsbGEgY2hpcFxuICAqL1xuICBASW5wdXQoKSBzZXQgY29sb3IgKHZhbHVlOiBDaGlwQ29sb3IgfCB1bmRlZmluZWQpIHsgdGhpcy5fY29sb3IgPSB2YWx1ZTsgfVxuICBnZXQgY29sb3IgKCk6IENoaXBDb2xvciB8IHVuZGVmaW5lZCB7IHJldHVybiB0aGlzLl9jb2xvcjsgfVxuICBwcml2YXRlIF9jb2xvcjogQ2hpcENvbG9yIHwgdW5kZWZpbmVkICA9IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogSW5kaWNhIHNlIGxhIGNoaXAgw6ggZGlzYWJpbGl0YXRhXG4gICovXG4gIEBJbnB1dCgpIHNldCBkaXNhYmxlZCAodmFsdWU6IGJvb2xlYW4pIHsgdGhpcy5fZGlzYWJsZWQgPSB2YWx1ZTsgfVxuICBnZXQgZGlzYWJsZWQgKCk6IGJvb2xlYW4geyByZXR1cm4gdGhpcy5fZGlzYWJsZWQ7IH1cbiAgcHJpdmF0ZSBfZGlzYWJsZWQ6IGJvb2xlYW4gID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIEluZGljYSBpbCBub21lIGRlbGwnaWNvbmEsIHNlIHZhbG9yaXp6YXRhIHZpZW5lIG1vc3RyYXRhXG4gICovXG4gIEBJbnB1dCgpIHNldCBpY29uICh2YWx1ZTogSWNvbk5hbWUgfCB1bmRlZmluZWQpIHsgdGhpcy5faWNvbiA9IHZhbHVlOyB9XG4gIGdldCBpY29uICgpOiBJY29uTmFtZSB8IHVuZGVmaW5lZCB7IHJldHVybiB0aGlzLl9pY29uOyB9XG4gIHByaXZhdGUgX2ljb246IEljb25OYW1lIHwgdW5kZWZpbmVkICA9IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogSW5kaWNhIGwndXJsIGRlbGwnYXZhdGFyLCBzZSB2YWxvcml6emF0YSB2aWVuZSBtb3N0cmF0YVxuICAqL1xuICBASW5wdXQoKSBzZXQgYXZhdGFyICh2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkKSB7IHRoaXMuX2F2YXRhciA9IHZhbHVlOyB9XG4gIGdldCBhdmF0YXIgKCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7IHJldHVybiB0aGlzLl9hdmF0YXI7IH1cbiAgcHJpdmF0ZSBfYXZhdGFyOiBzdHJpbmcgfCB1bmRlZmluZWQgID0gdW5kZWZpbmVkO1xuXG4gIC8qKlxuICAgKiBJbmRpY2EgaWwgdmFsb3JlIGRhIGFnZ2l1bmdlcmUgYWwgcGFyYW1ldHJvIGFsdCwgZGkgZGVmYXVsdCAnJ1xuICAqL1xuICBASW5wdXQoKSBzZXQgYWx0QXZhdGFyICh2YWx1ZTogc3RyaW5nKSB7IHRoaXMuX2FsdEF2YXRhciA9IHZhbHVlOyB9XG4gIGdldCBhbHRBdmF0YXIgKCk6IHN0cmluZyB7IHJldHVybiB0aGlzLl9hbHRBdmF0YXI7IH1cbiAgcHJpdmF0ZSBfYWx0QXZhdGFyOiBzdHJpbmcgID0gJyc7XG5cbiAgLyoqXG4gICAqIEV2ZW50byBlbWVzc28gYWwgY2xpY2sgc3VsIGJvdHRvbmUgZGkgY2hpdXN1cmFcbiAgKi9cbiAgQE91dHB1dCgpIGNsb3NlRXZlbnQgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgaWNvbkNsb3NlOiBJY29uTmFtZSA9ICdjbG9zZSc7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChERVNJR05fQU5HVUxBUl9LSVRfQ09ORklHKSBwcm90ZWN0ZWQgcmVhZG9ubHkgY29uZmlnOiBEZXNpZ25Bbmd1bGFyS2l0Q29uZmlnXG4gICkge1xuICB9XG5cbiAgY2xpY2tUb0Nsb3NlKCk6IHZvaWQge1xuICAgIHRoaXMuY2xvc2VFdmVudC5lbWl0KCk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJjaGlwXCIgW25nQ2xhc3NdPVwiWyFzaG93Q2xvc2VCdXR0b24gPyAnY2hpcC1zaW1wbGUnOiAnYWxlcnQnLCBzaXplID09PSAnbGcnID8gJ2NoaXAtbGcnOiAnJywgY29sb3IgPyAnY2hpcC0nICsgY29sb3IgOiAnJywgZGlzYWJsZWQgPyAnY2hpcC1kaXNhYmxlZCcgOiAnJ11cIj5cbiAgICA8c3ZnICpuZ0lmPVwiaWNvblwiIGNsYXNzPVwiaWNvbiBpY29uLXhzXCI+XG4gICAgICA8dXNlIFthdHRyLmhyZWZdPVwidGhpcy5jb25maWcuaWNvbkhyZWYgKyAnI2l0LScgKyBpY29uXCIgW2F0dHIueGxpbms6aHJlZl09XCJ0aGlzLmNvbmZpZy5pY29uSHJlZiArICcjaXQtJyArIGljb25cIj48L3VzZT5cbiAgICA8L3N2Zz5cbiAgICA8ZGl2ICpuZ0lmPVwiYXZhdGFyXCIgY2xhc3M9XCJhdmF0YXIgc2l6ZS14c1wiPjxpbWcgW3NyY109XCJhdmF0YXJcIiBbYWx0XT1cImFsdEF2YXRhclwiPjwvZGl2PlxuICAgIDxzcGFuIGNsYXNzPVwiY2hpcC1sYWJlbFwiPnt7IGxhYmVsIH19PC9zcGFuPlxuICAgIDxidXR0b24gKm5nSWY9XCJzaG93Q2xvc2VCdXR0b25cIiAoY2xpY2spPVwiY2xpY2tUb0Nsb3NlKClcIiBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIj5cbiAgICAgICAgPHN2ZyBjbGFzcz1cImljb25cIj48dXNlIFthdHRyLmhyZWZdPVwidGhpcy5jb25maWcuaWNvbkhyZWYgKyAnI2l0LWNsb3NlJ1wiIFthdHRyLnhsaW5rOmhyZWZdPVwidGhpcy5jb25maWcuaWNvbkhyZWYgKyAnI2l0LWNsb3NlJ1wiPjwvdXNlPjwvc3ZnPlxuICAgICAgICA8c3BhbiBjbGFzcz1cInZpc3VhbGx5LWhpZGRlblwiPnt7ICdpdC5jb3JlLnJlbW92ZScgfCB0cmFuc2xhdGUgfX0ge3sgbGFiZWwgfX08L3NwYW4+XG4gICAgPC9idXR0b24+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { ItAbstractComponent } from '../../../abstracts/abstract.component';
|
|
3
|
+
import { isTrueBooleanInput } from '../../../utils/boolean-input';
|
|
4
|
+
import { Collapse } from 'bootstrap-italia';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class ItCollapseComponent extends ItAbstractComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(...arguments);
|
|
9
|
+
/**
|
|
10
|
+
* Custom class
|
|
11
|
+
*/
|
|
12
|
+
this.class = '';
|
|
13
|
+
/**
|
|
14
|
+
* This event fires immediately when the show method is called.
|
|
15
|
+
*/
|
|
16
|
+
this.showEvent = new EventEmitter();
|
|
17
|
+
/**
|
|
18
|
+
* This event is triggered when the tooltip has been made visible to the user (it will wait for the CSS transitions to complete).
|
|
19
|
+
*/
|
|
20
|
+
this.shownEvent = new EventEmitter();
|
|
21
|
+
/**
|
|
22
|
+
* This event fires immediately when the hide method is called.
|
|
23
|
+
*/
|
|
24
|
+
this.hideEvent = new EventEmitter();
|
|
25
|
+
/**
|
|
26
|
+
* This event is raised when the tooltip has finished being hidden from the user (it will wait for the CSS transitions to complete).
|
|
27
|
+
*/
|
|
28
|
+
this.hiddenEvent = new EventEmitter();
|
|
29
|
+
}
|
|
30
|
+
get isMulti() {
|
|
31
|
+
return isTrueBooleanInput(this.multi);
|
|
32
|
+
}
|
|
33
|
+
get isOpenedOnStart() {
|
|
34
|
+
return isTrueBooleanInput(this.opened);
|
|
35
|
+
}
|
|
36
|
+
ngAfterViewInit() {
|
|
37
|
+
super.ngAfterViewInit();
|
|
38
|
+
this._renderer.removeAttribute(this._elementRef.nativeElement, 'class');
|
|
39
|
+
if (this.collapseDiv) {
|
|
40
|
+
const element = this.collapseDiv.nativeElement;
|
|
41
|
+
this.collapse = Collapse.getOrCreateInstance(element, {
|
|
42
|
+
toggle: this.isOpenedOnStart
|
|
43
|
+
});
|
|
44
|
+
element.addEventListener('show.bs.collapse', event => this.showEvent.emit(event));
|
|
45
|
+
element.addEventListener('shown.bs.collapse', event => this.shownEvent.emit(event));
|
|
46
|
+
element.addEventListener('hide.bs.collapse', event => this.hideEvent.emit(event));
|
|
47
|
+
element.addEventListener('hidden.bs.collapse', event => this.hiddenEvent.emit(event));
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Shows a resealable item
|
|
52
|
+
* NOTE: Returns to the caller before the collapsable element has actually been shown (onShown event).
|
|
53
|
+
*/
|
|
54
|
+
show() {
|
|
55
|
+
this.collapse?.show();
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Hides a resealable item
|
|
59
|
+
* NOTE: Returns to the caller before the collapsable element has actually been hidden (onHidden Event)
|
|
60
|
+
*/
|
|
61
|
+
hide() {
|
|
62
|
+
this.collapse?.hide();
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* Toggle a collapsible item to show or hide it.
|
|
66
|
+
* NOTE: Returns to the caller before the collapsable element has actually been shown or hidden (onShown and onHidden events)
|
|
67
|
+
*/
|
|
68
|
+
toggle() {
|
|
69
|
+
this.collapse?.toggle();
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Eliminates the possibility of an item being resealable
|
|
73
|
+
*/
|
|
74
|
+
dispose() {
|
|
75
|
+
this.collapse?.dispose();
|
|
76
|
+
}
|
|
77
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItCollapseComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
78
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.3", type: ItCollapseComponent, isStandalone: true, selector: "it-collapse", inputs: { multi: "multi", opened: "opened", class: "class" }, outputs: { showEvent: "showEvent", shownEvent: "shownEvent", hideEvent: "hideEvent", hiddenEvent: "hiddenEvent" }, viewQueries: [{ propertyName: "collapseDiv", first: true, predicate: ["collapse"], descendants: true }], exportAs: ["itCollapse"], usesInheritance: true, ngImport: i0, template: "<div [id]=\"id\" class=\"collapse {{class}}\" [class.multi-collapse]=\"isMulti\" #collapse>\n <ng-content></ng-content>\n</div>\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
79
|
+
}
|
|
80
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItCollapseComponent, decorators: [{
|
|
81
|
+
type: Component,
|
|
82
|
+
args: [{ standalone: true, selector: 'it-collapse', exportAs: 'itCollapse', changeDetection: ChangeDetectionStrategy.OnPush, imports: [], template: "<div [id]=\"id\" class=\"collapse {{class}}\" [class.multi-collapse]=\"isMulti\" #collapse>\n <ng-content></ng-content>\n</div>\n" }]
|
|
83
|
+
}], propDecorators: { multi: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}], opened: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], class: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}], showEvent: [{
|
|
90
|
+
type: Output
|
|
91
|
+
}], shownEvent: [{
|
|
92
|
+
type: Output
|
|
93
|
+
}], hideEvent: [{
|
|
94
|
+
type: Output
|
|
95
|
+
}], hiddenEvent: [{
|
|
96
|
+
type: Output
|
|
97
|
+
}], collapseDiv: [{
|
|
98
|
+
type: ViewChild,
|
|
99
|
+
args: ['collapse']
|
|
100
|
+
}] } });
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sbGFwc2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWFuZ3VsYXIta2l0L3NyYy9saWIvY29tcG9uZW50cy9jb3JlL2NvbGxhcHNlL2NvbGxhcHNlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9jb2xsYXBzZS9jb2xsYXBzZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFFVCxZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sRUFDTixTQUFTLEVBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDNUUsT0FBTyxFQUFnQixrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2hGLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFVNUMsTUFBTSxPQUFPLG1CQUFvQixTQUFRLG1CQUFtQjtJQVI1RDs7UUFvQkU7O1dBRUc7UUFDTSxVQUFLLEdBQVcsRUFBRSxDQUFDO1FBRTVCOztXQUVHO1FBQ08sY0FBUyxHQUF3QixJQUFJLFlBQVksRUFBRSxDQUFDO1FBRTlEOztXQUVHO1FBQ08sZUFBVSxHQUF3QixJQUFJLFlBQVksRUFBRSxDQUFDO1FBRS9EOztXQUVHO1FBQ08sY0FBUyxHQUF3QixJQUFJLFlBQVksRUFBRSxDQUFDO1FBRTlEOztXQUVHO1FBQ08sZ0JBQVcsR0FBd0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztLQThEakU7SUF2REMsSUFBSSxPQUFPO1FBQ1QsT0FBTyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDeEMsQ0FBQztJQUVELElBQUksZUFBZTtRQUNqQixPQUFPLGtCQUFrQixDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRVEsZUFBZTtRQUN0QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDeEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFFeEUsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3BCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDO1lBQy9DLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDLG1CQUFtQixDQUFDLE9BQU8sRUFBRTtnQkFDcEQsTUFBTSxFQUFFLElBQUksQ0FBQyxlQUFlO2FBQzdCLENBQUMsQ0FBQztZQUVILE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxrQkFBa0IsRUFBRSxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFDbEYsT0FBTyxDQUFDLGdCQUFnQixDQUFDLG1CQUFtQixFQUFFLEtBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUNwRixPQUFPLENBQUMsZ0JBQWdCLENBQUMsa0JBQWtCLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQ2xGLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxvQkFBb0IsRUFBRSxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDdkY7SUFDSCxDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksSUFBSTtRQUNULElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVEOzs7T0FHRztJQUNJLElBQUk7UUFDVCxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRDs7O09BR0c7SUFDSSxNQUFNO1FBQ1gsSUFBSSxDQUFDLFFBQVEsRUFBRSxNQUFNLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQ7O09BRUc7SUFDSSxPQUFPO1FBQ1osSUFBSSxDQUFDLFFBQVEsRUFBRSxPQUFPLEVBQUUsQ0FBQztJQUMzQixDQUFDOzhHQWhHVSxtQkFBbUI7a0dBQW5CLG1CQUFtQixrWkN0QmhDLG9JQUdBOzsyRkRtQmEsbUJBQW1CO2tCQVIvQixTQUFTO2lDQUNJLElBQUksWUFDTixhQUFhLFlBRWIsWUFBWSxtQkFDTCx1QkFBdUIsQ0FBQyxNQUFNLFdBQ3RDLEVBQUU7OEJBT0YsS0FBSztzQkFBYixLQUFLO2dCQUtHLE1BQU07c0JBQWQsS0FBSztnQkFLRyxLQUFLO3NCQUFiLEtBQUs7Z0JBS0ksU0FBUztzQkFBbEIsTUFBTTtnQkFLRyxVQUFVO3NCQUFuQixNQUFNO2dCQUtHLFNBQVM7c0JBQWxCLE1BQU07Z0JBS0csV0FBVztzQkFBcEIsTUFBTTtnQkFLMEIsV0FBVztzQkFBM0MsU0FBUzt1QkFBQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT3V0cHV0LFxuICBWaWV3Q2hpbGRcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJdEFic3RyYWN0Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vYWJzdHJhY3RzL2Fic3RyYWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCb29sZWFuSW5wdXQsIGlzVHJ1ZUJvb2xlYW5JbnB1dCB9IGZyb20gJy4uLy4uLy4uL3V0aWxzL2Jvb2xlYW4taW5wdXQnO1xuaW1wb3J0IHsgQ29sbGFwc2UgfSBmcm9tICdib290c3RyYXAtaXRhbGlhJztcblxuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnaXQtY29sbGFwc2UnLFxuICB0ZW1wbGF0ZVVybDogJy4vY29sbGFwc2UuY29tcG9uZW50Lmh0bWwnLFxuICBleHBvcnRBczogJ2l0Q29sbGFwc2UnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaW1wb3J0czogW11cbn0pXG5leHBvcnQgY2xhc3MgSXRDb2xsYXBzZUNvbXBvbmVudCBleHRlbmRzIEl0QWJzdHJhY3RDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcblxuICAvKipcbiAgICogRW5hYmxlIG11bHRpcGxlIGNvbGxhcHNlXG4gICAqL1xuICBASW5wdXQoKSBtdWx0aTogQm9vbGVhbklucHV0IHwgdW5kZWZpbmVkO1xuXG4gIC8qKlxuICAgKiBUb2dnbGVzIHRoZSBjb2xsYXBzaWJsZSBlbGVtZW50IG9uIGludm9jYXRpb25cbiAgICovXG4gIEBJbnB1dCgpIG9wZW5lZDogQm9vbGVhbklucHV0IHwgdW5kZWZpbmVkO1xuXG4gIC8qKlxuICAgKiBDdXN0b20gY2xhc3NcbiAgICovXG4gIEBJbnB1dCgpIGNsYXNzOiBzdHJpbmcgPSAnJztcblxuICAvKipcbiAgICogVGhpcyBldmVudCBmaXJlcyBpbW1lZGlhdGVseSB3aGVuIHRoZSBzaG93IG1ldGhvZCBpcyBjYWxsZWQuXG4gICAqL1xuICBAT3V0cHV0KCkgc2hvd0V2ZW50OiBFdmVudEVtaXR0ZXI8RXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIC8qKlxuICAgKiBUaGlzIGV2ZW50IGlzIHRyaWdnZXJlZCB3aGVuIHRoZSB0b29sdGlwIGhhcyBiZWVuIG1hZGUgdmlzaWJsZSB0byB0aGUgdXNlciAoaXQgd2lsbCB3YWl0IGZvciB0aGUgQ1NTIHRyYW5zaXRpb25zIHRvIGNvbXBsZXRlKS5cbiAgICovXG4gIEBPdXRwdXQoKSBzaG93bkV2ZW50OiBFdmVudEVtaXR0ZXI8RXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIC8qKlxuICAgKiBUaGlzIGV2ZW50IGZpcmVzIGltbWVkaWF0ZWx5IHdoZW4gdGhlIGhpZGUgbWV0aG9kIGlzIGNhbGxlZC5cbiAgICovXG4gIEBPdXRwdXQoKSBoaWRlRXZlbnQ6IEV2ZW50RW1pdHRlcjxFdmVudD4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgLyoqXG4gICAqIFRoaXMgZXZlbnQgaXMgcmFpc2VkIHdoZW4gdGhlIHRvb2x0aXAgaGFzIGZpbmlzaGVkIGJlaW5nIGhpZGRlbiBmcm9tIHRoZSB1c2VyIChpdCB3aWxsIHdhaXQgZm9yIHRoZSBDU1MgdHJhbnNpdGlvbnMgdG8gY29tcGxldGUpLlxuICAgKi9cbiAgQE91dHB1dCgpIGhpZGRlbkV2ZW50OiBFdmVudEVtaXR0ZXI8RXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG5cbiAgcHJpdmF0ZSBjb2xsYXBzZT86IENvbGxhcHNlO1xuXG4gIEBWaWV3Q2hpbGQoJ2NvbGxhcHNlJykgcHJvdGVjdGVkIGNvbGxhcHNlRGl2PzogRWxlbWVudFJlZjxIVE1MRGl2RWxlbWVudD47XG5cbiAgZ2V0IGlzTXVsdGkoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGlzVHJ1ZUJvb2xlYW5JbnB1dCh0aGlzLm11bHRpKTtcbiAgfVxuXG4gIGdldCBpc09wZW5lZE9uU3RhcnQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGlzVHJ1ZUJvb2xlYW5JbnB1dCh0aGlzLm9wZW5lZCk7XG4gIH1cblxuICBvdmVycmlkZSBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgc3VwZXIubmdBZnRlclZpZXdJbml0KCk7XG4gICAgdGhpcy5fcmVuZGVyZXIucmVtb3ZlQXR0cmlidXRlKHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ2NsYXNzJyk7XG5cbiAgICBpZiAodGhpcy5jb2xsYXBzZURpdikge1xuICAgICAgY29uc3QgZWxlbWVudCA9IHRoaXMuY29sbGFwc2VEaXYubmF0aXZlRWxlbWVudDtcbiAgICAgIHRoaXMuY29sbGFwc2UgPSBDb2xsYXBzZS5nZXRPckNyZWF0ZUluc3RhbmNlKGVsZW1lbnQsIHtcbiAgICAgICAgdG9nZ2xlOiB0aGlzLmlzT3BlbmVkT25TdGFydFxuICAgICAgfSk7XG5cbiAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignc2hvdy5icy5jb2xsYXBzZScsIGV2ZW50ID0+IHRoaXMuc2hvd0V2ZW50LmVtaXQoZXZlbnQpKTtcbiAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignc2hvd24uYnMuY29sbGFwc2UnLCBldmVudCA9PiB0aGlzLnNob3duRXZlbnQuZW1pdChldmVudCkpO1xuICAgICAgZWxlbWVudC5hZGRFdmVudExpc3RlbmVyKCdoaWRlLmJzLmNvbGxhcHNlJywgZXZlbnQgPT4gdGhpcy5oaWRlRXZlbnQuZW1pdChldmVudCkpO1xuICAgICAgZWxlbWVudC5hZGRFdmVudExpc3RlbmVyKCdoaWRkZW4uYnMuY29sbGFwc2UnLCBldmVudCA9PiB0aGlzLmhpZGRlbkV2ZW50LmVtaXQoZXZlbnQpKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogU2hvd3MgYSByZXNlYWxhYmxlIGl0ZW1cbiAgICogTk9URTogUmV0dXJucyB0byB0aGUgY2FsbGVyIGJlZm9yZSB0aGUgY29sbGFwc2FibGUgZWxlbWVudCBoYXMgYWN0dWFsbHkgYmVlbiBzaG93biAob25TaG93biBldmVudCkuXG4gICAqL1xuICBwdWJsaWMgc2hvdygpOiB2b2lkIHtcbiAgICB0aGlzLmNvbGxhcHNlPy5zaG93KCk7XG4gIH1cblxuICAvKipcbiAgICogSGlkZXMgYSByZXNlYWxhYmxlIGl0ZW1cbiAgICogTk9URTogUmV0dXJucyB0byB0aGUgY2FsbGVyIGJlZm9yZSB0aGUgY29sbGFwc2FibGUgZWxlbWVudCBoYXMgYWN0dWFsbHkgYmVlbiBoaWRkZW4gKG9uSGlkZGVuIEV2ZW50KVxuICAgKi9cbiAgcHVibGljIGhpZGUoKTogdm9pZCB7XG4gICAgdGhpcy5jb2xsYXBzZT8uaGlkZSgpO1xuICB9XG5cbiAgLyoqXG4gICAqIFRvZ2dsZSBhIGNvbGxhcHNpYmxlIGl0ZW0gdG8gc2hvdyBvciBoaWRlIGl0LlxuICAgKiBOT1RFOiBSZXR1cm5zIHRvIHRoZSBjYWxsZXIgYmVmb3JlIHRoZSBjb2xsYXBzYWJsZSBlbGVtZW50IGhhcyBhY3R1YWxseSBiZWVuIHNob3duIG9yIGhpZGRlbiAob25TaG93biBhbmQgb25IaWRkZW4gZXZlbnRzKVxuICAgKi9cbiAgcHVibGljIHRvZ2dsZSgpOiB2b2lkIHtcbiAgICB0aGlzLmNvbGxhcHNlPy50b2dnbGUoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBFbGltaW5hdGVzIHRoZSBwb3NzaWJpbGl0eSBvZiBhbiBpdGVtIGJlaW5nIHJlc2VhbGFibGVcbiAgICovXG4gIHB1YmxpYyBkaXNwb3NlKCk6IHZvaWQge1xuICAgIHRoaXMuY29sbGFwc2U/LmRpc3Bvc2UoKTtcbiAgfVxufVxuIiwiPGRpdiBbaWRdPVwiaWRcIiBjbGFzcz1cImNvbGxhcHNlIHt7Y2xhc3N9fVwiIFtjbGFzcy5tdWx0aS1jb2xsYXBzZV09XCJpc011bHRpXCIgI2NvbGxhcHNlPlxuICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { NgClass } from '@angular/common';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ItDimmerButtonsComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this._hasOneButton = false;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* Indica se abbiamo 1 solo bottone
|
|
10
|
+
* @default false
|
|
11
|
+
*/
|
|
12
|
+
set hasOneButton(value) { this._hasOneButton = value; }
|
|
13
|
+
;
|
|
14
|
+
get hasOneButton() { return this._hasOneButton; }
|
|
15
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDimmerButtonsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
16
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.3", type: ItDimmerButtonsComponent, isStandalone: true, selector: "it-dimmer-buttons", inputs: { hasOneButton: "hasOneButton" }, ngImport: i0, template: "<div class=\"dimmer-buttons bg-dark\" [ngClass]=\"{'single-button': hasOneButton}\">\n <ng-content></ng-content>\n</div>", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
17
|
+
}
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDimmerButtonsComponent, decorators: [{
|
|
19
|
+
type: Component,
|
|
20
|
+
args: [{ standalone: true, selector: 'it-dimmer-buttons', changeDetection: ChangeDetectionStrategy.OnPush, imports: [NgClass], template: "<div class=\"dimmer-buttons bg-dark\" [ngClass]=\"{'single-button': hasOneButton}\">\n <ng-content></ng-content>\n</div>" }]
|
|
21
|
+
}], propDecorators: { hasOneButton: [{
|
|
22
|
+
type: Input
|
|
23
|
+
}] } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltbWVyLWJ1dHRvbnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWFuZ3VsYXIta2l0L3NyYy9saWIvY29tcG9uZW50cy9jb3JlL2RpbW1lci9kaW1tZXItYnV0dG9ucy9kaW1tZXItYnV0dG9ucy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tYW5ndWxhci1raXQvc3JjL2xpYi9jb21wb25lbnRzL2NvcmUvZGltbWVyL2RpbW1lci1idXR0b25zL2RpbW1lci1idXR0b25zLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFTMUMsTUFBTSxPQUFPLHdCQUF3QjtJQVByQztRQWVVLGtCQUFhLEdBQUcsS0FBSyxDQUFDO0tBRS9CO0lBUkM7OztNQUdFO0lBQ0YsSUFBYSxZQUFZLENBQUUsS0FBYyxJQUFHLElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFBLENBQUEsQ0FBQztJQUFBLENBQUM7SUFDeEUsSUFBSSxZQUFZLEtBQUksT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQzs4R0FQckMsd0JBQXdCO2tHQUF4Qix3QkFBd0IsdUhDVnJDLDZIQUVNLDRDRE1NLE9BQU87OzJGQUVOLHdCQUF3QjtrQkFQcEMsU0FBUztpQ0FDSSxJQUFJLFlBQ04sbUJBQW1CLG1CQUVaLHVCQUF1QixDQUFDLE1BQU0sV0FDdEMsQ0FBQyxPQUFPLENBQUM7OEJBUUwsWUFBWTtzQkFBeEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ0NsYXNzIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnaXQtZGltbWVyLWJ1dHRvbnMnLFxuICB0ZW1wbGF0ZVVybDogJy4vZGltbWVyLWJ1dHRvbnMuY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgaW1wb3J0czogW05nQ2xhc3NdXG59KVxuZXhwb3J0IGNsYXNzIEl0RGltbWVyQnV0dG9uc0NvbXBvbmVudCB7XG5cbiAgLyoqXG4gICAqIEluZGljYSBzZSBhYmJpYW1vIDEgc29sbyBib3R0b25lXG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICovXG4gIEBJbnB1dCgpIHNldCBoYXNPbmVCdXR0b24gKHZhbHVlOiBib29sZWFuKSB7dGhpcy5faGFzT25lQnV0dG9uID0gdmFsdWV9O1xuICBnZXQgaGFzT25lQnV0dG9uKCkge3JldHVybiB0aGlzLl9oYXNPbmVCdXR0b247IH1cbiAgcHJpdmF0ZSBfaGFzT25lQnV0dG9uID0gZmFsc2U7XG5cbn1cbiIsIjxkaXYgY2xhc3M9XCJkaW1tZXItYnV0dG9ucyBiZy1kYXJrXCIgW25nQ2xhc3NdPVwieydzaW5nbGUtYnV0dG9uJzogaGFzT25lQnV0dG9ufVwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PiJdfQ==
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class ItDimmerIconComponent {
|
|
4
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDimmerIconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.3", type: ItDimmerIconComponent, isStandalone: true, selector: "it-dimmer-icon", ngImport: i0, template: "<div class=\"dimmer-icon\">\n <ng-content></ng-content>\n</div>", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
6
|
+
}
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDimmerIconComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
9
|
+
args: [{ standalone: true, selector: 'it-dimmer-icon', changeDetection: ChangeDetectionStrategy.OnPush, imports: [], template: "<div class=\"dimmer-icon\">\n <ng-content></ng-content>\n</div>" }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltbWVyLWljb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWFuZ3VsYXIta2l0L3NyYy9saWIvY29tcG9uZW50cy9jb3JlL2RpbW1lci9kaW1tZXItaWNvbi9kaW1tZXItaWNvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tYW5ndWxhci1raXQvc3JjL2xpYi9jb21wb25lbnRzL2NvcmUvZGltbWVyL2RpbW1lci1pY29uL2RpbW1lci1pY29uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBU25FLE1BQU0sT0FBTyxxQkFBcUI7OEdBQXJCLHFCQUFxQjtrR0FBckIscUJBQXFCLDBFQ1RsQyxvRUFFTTs7MkZET08scUJBQXFCO2tCQVBqQyxTQUFTO2lDQUNJLElBQUksWUFDTixnQkFBZ0IsbUJBRVQsdUJBQXVCLENBQUMsTUFBTSxXQUN0QyxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdpdC1kaW1tZXItaWNvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9kaW1tZXItaWNvbi5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBpbXBvcnRzOiBbXVxufSlcbmV4cG9ydCBjbGFzcyBJdERpbW1lckljb25Db21wb25lbnQge1xuXG59XG4iLCI8ZGl2IGNsYXNzPVwiZGltbWVyLWljb25cIj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG48L2Rpdj4iXX0=
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { animate, style, transition, trigger } from '@angular/animations';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
3
|
+
import { NgClass, NgIf } from '@angular/common';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class ItDimmerComponent {
|
|
6
|
+
/**
|
|
7
|
+
* Dimmer status
|
|
8
|
+
* @default false
|
|
9
|
+
*/
|
|
10
|
+
set active(value) { this._active = value; }
|
|
11
|
+
;
|
|
12
|
+
get active() { return this._active; }
|
|
13
|
+
/**
|
|
14
|
+
* Colore del dimmer
|
|
15
|
+
* @default ''
|
|
16
|
+
*/
|
|
17
|
+
set color(value) { this._color = value; }
|
|
18
|
+
;
|
|
19
|
+
get color() { return this._color; }
|
|
20
|
+
constructor(elementRef) {
|
|
21
|
+
this.elementRef = elementRef;
|
|
22
|
+
this._active = false;
|
|
23
|
+
this._color = '';
|
|
24
|
+
}
|
|
25
|
+
ngOnInit() {
|
|
26
|
+
this.elementRef?.nativeElement?.parentElement?.classList?.add('dimmable');
|
|
27
|
+
}
|
|
28
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDimmerComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
29
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.3", type: ItDimmerComponent, isStandalone: true, selector: "it-dimmer", inputs: { active: "active", color: "color" }, ngImport: i0, template: "<div class=\"dimmer\" *ngIf=\"active\" @fade [ngClass]=\"[color]\">\n <div class=\"dimmer-inner\">\n <ng-content></ng-content>\n </div>\n</div>", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [
|
|
30
|
+
trigger('fade', [
|
|
31
|
+
transition(':enter', [
|
|
32
|
+
style({ opacity: 0 }),
|
|
33
|
+
animate('150ms', style({ opacity: 0.92 })),
|
|
34
|
+
]),
|
|
35
|
+
transition(':leave', [
|
|
36
|
+
animate('150ms', style({ opacity: 0 })),
|
|
37
|
+
]),
|
|
38
|
+
])
|
|
39
|
+
], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
40
|
+
}
|
|
41
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDimmerComponent, decorators: [{
|
|
42
|
+
type: Component,
|
|
43
|
+
args: [{ standalone: true, selector: 'it-dimmer', changeDetection: ChangeDetectionStrategy.OnPush, animations: [
|
|
44
|
+
trigger('fade', [
|
|
45
|
+
transition(':enter', [
|
|
46
|
+
style({ opacity: 0 }),
|
|
47
|
+
animate('150ms', style({ opacity: 0.92 })),
|
|
48
|
+
]),
|
|
49
|
+
transition(':leave', [
|
|
50
|
+
animate('150ms', style({ opacity: 0 })),
|
|
51
|
+
]),
|
|
52
|
+
])
|
|
53
|
+
], imports: [NgIf, NgClass], template: "<div class=\"dimmer\" *ngIf=\"active\" @fade [ngClass]=\"[color]\">\n <div class=\"dimmer-inner\">\n <ng-content></ng-content>\n </div>\n</div>" }]
|
|
54
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { active: [{
|
|
55
|
+
type: Input
|
|
56
|
+
}], color: [{
|
|
57
|
+
type: Input
|
|
58
|
+
}] } });
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltbWVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9kaW1tZXIvZGltbWVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9kaW1tZXIvZGltbWVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxPQUFPLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUMxRSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUM5RixPQUFPLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQXNCaEQsTUFBTSxPQUFPLGlCQUFpQjtJQUU1Qjs7O01BR0U7SUFDRixJQUFhLE1BQU0sQ0FBRSxLQUFjLElBQUcsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUEsQ0FBQSxDQUFDO0lBQUEsQ0FBQztJQUM1RCxJQUFJLE1BQU0sS0FBSSxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO0lBR3BDOzs7TUFHRTtJQUNGLElBQWEsS0FBSyxDQUFFLEtBQWtCLElBQUcsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUEsQ0FBQSxDQUFDO0lBQUEsQ0FBQztJQUM5RCxJQUFJLEtBQUssS0FBSSxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBR2xDLFlBQ1UsVUFBc0I7UUFBdEIsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQVh4QixZQUFPLEdBQUcsS0FBSyxDQUFDO1FBUWhCLFdBQU0sR0FBZ0IsRUFBRSxDQUFDO0lBSTlCLENBQUM7SUFFSixRQUFRO1FBQ04sSUFBSSxDQUFDLFVBQVUsRUFBRSxhQUFhLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDNUUsQ0FBQzs4R0F4QlUsaUJBQWlCO2tHQUFqQixpQkFBaUIsbUhDeEI5QixzSkFJTSw0Q0RrQk0sSUFBSSw2RkFBRSxPQUFPLHNFQVhYO1lBQ1YsT0FBTyxDQUFDLE1BQU0sRUFBRTtnQkFDWixVQUFVLENBQUMsUUFBUSxFQUFFO29CQUNqQixLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUM7b0JBQ3JCLE9BQU8sQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7aUJBQzdDLENBQUM7Z0JBQ0YsVUFBVSxDQUFDLFFBQVEsRUFBRTtvQkFDakIsT0FBTyxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztpQkFDMUMsQ0FBQzthQUNMLENBQUM7U0FDSDs7MkZBR1UsaUJBQWlCO2tCQWxCN0IsU0FBUztpQ0FDSSxJQUFJLFlBQ04sV0FBVyxtQkFFSix1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DO3dCQUNWLE9BQU8sQ0FBQyxNQUFNLEVBQUU7NEJBQ1osVUFBVSxDQUFDLFFBQVEsRUFBRTtnQ0FDakIsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDO2dDQUNyQixPQUFPLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDOzZCQUM3QyxDQUFDOzRCQUNGLFVBQVUsQ0FBQyxRQUFRLEVBQUU7Z0NBQ2pCLE9BQU8sQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7NkJBQzFDLENBQUM7eUJBQ0wsQ0FBQztxQkFDSCxXQUNRLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQztpR0FRWCxNQUFNO3NCQUFsQixLQUFLO2dCQVFPLEtBQUs7c0JBQWpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBhbmltYXRlLCBzdHlsZSwgdHJhbnNpdGlvbiwgdHJpZ2dlciB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdDbGFzcywgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmV4cG9ydCB0eXBlIERpbW1lckNvbG9yID0gJycgfCAnZGltbWVyLXByaW1hcnknO1xuXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgc2VsZWN0b3I6ICdpdC1kaW1tZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZGltbWVyLmNvbXBvbmVudC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGFuaW1hdGlvbnM6IFtcbiAgICB0cmlnZ2VyKCdmYWRlJywgW1xuICAgICAgICB0cmFuc2l0aW9uKCc6ZW50ZXInLCBbXG4gICAgICAgICAgICBzdHlsZSh7IG9wYWNpdHk6IDAgfSksXG4gICAgICAgICAgICBhbmltYXRlKCcxNTBtcycsIHN0eWxlKHsgb3BhY2l0eTogMC45MiB9KSksXG4gICAgICAgIF0pLFxuICAgICAgICB0cmFuc2l0aW9uKCc6bGVhdmUnLCBbXG4gICAgICAgICAgICBhbmltYXRlKCcxNTBtcycsIHN0eWxlKHsgb3BhY2l0eTogMCB9KSksXG4gICAgICAgIF0pLFxuICAgIF0pXG4gIF0sXG4gIGltcG9ydHM6IFtOZ0lmLCBOZ0NsYXNzXVxufSlcbmV4cG9ydCBjbGFzcyBJdERpbW1lckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgLyoqXG4gICAqIERpbW1lciBzdGF0dXNcbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgKi9cbiAgQElucHV0KCkgc2V0IGFjdGl2ZSAodmFsdWU6IGJvb2xlYW4pIHt0aGlzLl9hY3RpdmUgPSB2YWx1ZX07XG4gIGdldCBhY3RpdmUoKSB7cmV0dXJuIHRoaXMuX2FjdGl2ZTsgfVxuICBwcml2YXRlIF9hY3RpdmUgPSBmYWxzZTtcblxuICAvKipcbiAgICogQ29sb3JlIGRlbCBkaW1tZXJcbiAgICogQGRlZmF1bHQgJydcbiAgKi9cbiAgQElucHV0KCkgc2V0IGNvbG9yICh2YWx1ZTogRGltbWVyQ29sb3IpIHt0aGlzLl9jb2xvciA9IHZhbHVlfTtcbiAgZ2V0IGNvbG9yKCkge3JldHVybiB0aGlzLl9jb2xvcjsgfVxuICBwcml2YXRlIF9jb2xvcjogRGltbWVyQ29sb3IgPSAnJztcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWZcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuZWxlbWVudFJlZj8ubmF0aXZlRWxlbWVudD8ucGFyZW50RWxlbWVudD8uY2xhc3NMaXN0Py5hZGQoJ2RpbW1hYmxlJyk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJkaW1tZXJcIiAqbmdJZj1cImFjdGl2ZVwiIEBmYWRlIFtuZ0NsYXNzXT1cIltjb2xvcl1cIj5cbiAgPGRpdiBjbGFzcz1cImRpbW1lci1pbm5lclwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgPC9kaXY+XG48L2Rpdj4iXX0=
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { ItDimmerComponent } from './dimmer.component';
|
|
3
|
+
import { ItDimmerIconComponent } from './dimmer-icon/dimmer-icon.component';
|
|
4
|
+
import { ItDimmerButtonsComponent } from './dimmer-buttons/dimmer-buttons.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
const dimmerComponents = [
|
|
7
|
+
ItDimmerComponent,
|
|
8
|
+
ItDimmerIconComponent,
|
|
9
|
+
ItDimmerButtonsComponent
|
|
10
|
+
];
|
|
11
|
+
export class ItDimmerModule {
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDimmerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
13
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.3", ngImport: i0, type: ItDimmerModule, imports: [ItDimmerComponent,
|
|
14
|
+
ItDimmerIconComponent,
|
|
15
|
+
ItDimmerButtonsComponent], exports: [ItDimmerComponent,
|
|
16
|
+
ItDimmerIconComponent,
|
|
17
|
+
ItDimmerButtonsComponent] }); }
|
|
18
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDimmerModule }); }
|
|
19
|
+
}
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDimmerModule, decorators: [{
|
|
21
|
+
type: NgModule,
|
|
22
|
+
args: [{
|
|
23
|
+
imports: dimmerComponents,
|
|
24
|
+
exports: dimmerComponents
|
|
25
|
+
}]
|
|
26
|
+
}] });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGltbWVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9kaW1tZXIvZGltbWVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzVFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDOztBQUVyRixNQUFNLGdCQUFnQixHQUFHO0lBQ3ZCLGlCQUFpQjtJQUNqQixxQkFBcUI7SUFDckIsd0JBQXdCO0NBQ3pCLENBQUM7QUFNRixNQUFNLE9BQU8sY0FBYzs4R0FBZCxjQUFjOytHQUFkLGNBQWMsWUFUekIsaUJBQWlCO1lBQ2pCLHFCQUFxQjtZQUNyQix3QkFBd0IsYUFGeEIsaUJBQWlCO1lBQ2pCLHFCQUFxQjtZQUNyQix3QkFBd0I7K0dBT2IsY0FBYzs7MkZBQWQsY0FBYztrQkFKMUIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsZ0JBQWdCO29CQUN6QixPQUFPLEVBQUUsZ0JBQWdCO2lCQUMxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJdERpbW1lckNvbXBvbmVudCB9IGZyb20gJy4vZGltbWVyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJdERpbW1lckljb25Db21wb25lbnQgfSBmcm9tICcuL2RpbW1lci1pY29uL2RpbW1lci1pY29uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJdERpbW1lckJ1dHRvbnNDb21wb25lbnQgfSBmcm9tICcuL2RpbW1lci1idXR0b25zL2RpbW1lci1idXR0b25zLmNvbXBvbmVudCc7XG5cbmNvbnN0IGRpbW1lckNvbXBvbmVudHMgPSBbXG4gIEl0RGltbWVyQ29tcG9uZW50LFxuICBJdERpbW1lckljb25Db21wb25lbnQsXG4gIEl0RGltbWVyQnV0dG9uc0NvbXBvbmVudFxuXTtcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogZGltbWVyQ29tcG9uZW50cyxcbiAgZXhwb3J0czogZGltbWVyQ29tcG9uZW50c1xufSlcbmV4cG9ydCBjbGFzcyBJdERpbW1lck1vZHVsZSB7XG59XG4iXX0=
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { ItAbstractComponent } from '../../../../abstracts/abstract.component';
|
|
3
|
+
import { isTrueBooleanInput } from '../../../../utils/boolean-input';
|
|
4
|
+
import { ItDropdownItemComponent } from '../dropdown-item/dropdown-item.component';
|
|
5
|
+
import { Dropdown } from 'bootstrap-italia';
|
|
6
|
+
import { ItIconComponent } from '../../../utils/icon/icon.component';
|
|
7
|
+
import { NgIf, NgTemplateOutlet } from '@angular/common';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export class ItDropdownComponent extends ItAbstractComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments);
|
|
12
|
+
/**
|
|
13
|
+
* Dropdown mode
|
|
14
|
+
*/
|
|
15
|
+
this.mode = 'button';
|
|
16
|
+
/**
|
|
17
|
+
* Fires immediately when the show instance method is called.
|
|
18
|
+
*/
|
|
19
|
+
this.showEvent = new EventEmitter();
|
|
20
|
+
/**
|
|
21
|
+
* Fired when the dropdown has been made visible to the user and CSS transitions have completed.
|
|
22
|
+
*/
|
|
23
|
+
this.shownEvent = new EventEmitter();
|
|
24
|
+
/**
|
|
25
|
+
* Fires immediately when the hide instance method has been called.
|
|
26
|
+
*/
|
|
27
|
+
this.hideEvent = new EventEmitter();
|
|
28
|
+
/**
|
|
29
|
+
* Fired when the dropdown has finished being hidden from the user and CSS transitions have completed.
|
|
30
|
+
*/
|
|
31
|
+
this.hiddenEvent = new EventEmitter();
|
|
32
|
+
}
|
|
33
|
+
get buttonClass() {
|
|
34
|
+
let btnClass = 'btn dropdown-toggle';
|
|
35
|
+
if (this.color) {
|
|
36
|
+
btnClass += ` btn-${this.color}`;
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
btnClass += ` btn-dropdown`;
|
|
40
|
+
}
|
|
41
|
+
return btnClass;
|
|
42
|
+
}
|
|
43
|
+
get isFullWidth() {
|
|
44
|
+
return isTrueBooleanInput(this.fullWidth);
|
|
45
|
+
}
|
|
46
|
+
get isDark() {
|
|
47
|
+
return isTrueBooleanInput(this.dark);
|
|
48
|
+
}
|
|
49
|
+
ngOnChanges(changes) {
|
|
50
|
+
if (changes['dark'] && !changes['dark'].firstChange) {
|
|
51
|
+
this.setDarkItems();
|
|
52
|
+
}
|
|
53
|
+
if (changes['mode'] && !changes['mode'].firstChange) {
|
|
54
|
+
this.updateListeners();
|
|
55
|
+
}
|
|
56
|
+
super.ngOnChanges(changes);
|
|
57
|
+
}
|
|
58
|
+
ngAfterViewInit() {
|
|
59
|
+
super.ngAfterViewInit();
|
|
60
|
+
this.setDarkItems();
|
|
61
|
+
this.updateListeners();
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Set child items dark mode
|
|
65
|
+
* @private
|
|
66
|
+
*/
|
|
67
|
+
setDarkItems() {
|
|
68
|
+
this.items?.forEach(item => {
|
|
69
|
+
item.setDark(this.isDark);
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
updateListeners() {
|
|
73
|
+
if (this.dropdownButton) {
|
|
74
|
+
const element = this.dropdownButton.nativeElement;
|
|
75
|
+
this.dropdown = Dropdown.getOrCreateInstance(element);
|
|
76
|
+
element.addEventListener('show.bs.dropdown', event => this.showEvent.emit(event));
|
|
77
|
+
element.addEventListener('shown.bs.dropdown', event => this.shownEvent.emit(event));
|
|
78
|
+
element.addEventListener('hide.bs.dropdown', event => this.hideEvent.emit(event));
|
|
79
|
+
element.addEventListener('hidden.bs.dropdown', event => this.hiddenEvent.emit(event));
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Toggles the dropdown menu of a given navbar or tabbed navigation.
|
|
84
|
+
*/
|
|
85
|
+
toggle() {
|
|
86
|
+
this.dropdown?.toggle();
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Shows the dropdown menu of a given navbar or tabbed navigation.
|
|
90
|
+
*/
|
|
91
|
+
show() {
|
|
92
|
+
this.dropdown?.show();
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Hides the dropdown menu of a given navbar or tabbed navigation.
|
|
96
|
+
*/
|
|
97
|
+
hide() {
|
|
98
|
+
this.dropdown?.hide();
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Updates the position of an element's dropdown.
|
|
102
|
+
*/
|
|
103
|
+
update() {
|
|
104
|
+
this.dropdown?.update();
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Destroys an element's dropdown. (Removes stored data on the DOM element)
|
|
108
|
+
*/
|
|
109
|
+
dispose() {
|
|
110
|
+
this.dropdown?.dispose();
|
|
111
|
+
}
|
|
112
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDropdownComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
113
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.3", type: ItDropdownComponent, isStandalone: true, selector: "it-dropdown", inputs: { mode: "mode", color: "color", direction: "direction", fullWidth: "fullWidth", dark: "dark" }, outputs: { showEvent: "showEvent", shownEvent: "shownEvent", hideEvent: "hideEvent", hiddenEvent: "hiddenEvent" }, queries: [{ propertyName: "items", predicate: ItDropdownItemComponent }], viewQueries: [{ propertyName: "dropdownButton", first: true, predicate: ["dropdownButton"], descendants: true }], exportAs: ["itDropdown"], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"dropdown {{direction}}\">\n <button #dropdownButton\n *ngIf=\"mode === 'button'; else linkButton\"\n [id]=\"id\"\n [class]=\"buttonClass\"\n type=\"button\"\n data-bs-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\">\n <ng-container *ngTemplateOutlet=\"buttonContent\"></ng-container>\n <it-icon svgClass=\"icon-expand\" name=\"expand\" size=\"sm\" [color]=\"this.color ? 'light' : 'primary'\"></it-icon>\n </button>\n\n <ng-template #linkButton>\n <a #dropdownButton\n [id]=\"id\"\n class=\"btn btn-dropdown dropdown-toggle\"\n role=\"button\"\n data-bs-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\">\n <ng-container *ngTemplateOutlet=\"buttonContent\"></ng-container>\n <it-icon svgClass=\"icon-expand\" name=\"expand\" size=\"sm\" color=\"primary\"></it-icon>\n </a>\n </ng-template>\n\n\n <div class=\"dropdown-menu\" [class.full-width]=\"isFullWidth\" [class.dark]=\"isDark\" [attr.aria-labelledby]=\"id\">\n <div class=\"link-list-wrapper\">\n <div class=\"link-list-heading\">\n <ng-content select=\"[listHeading]\"></ng-content>\n </div>\n <ul class=\"link-list\">\n <ng-content select=\"[list]\"></ng-content>\n </ul>\n </div>\n </div>\n</div>\n\n<ng-template #buttonContent>\n <ng-content select=\"[button]\"></ng-content>\n</ng-template>\n", styles: [".link-list-heading:empty{display:none}\n"], dependencies: [{ kind: "component", type: ItIconComponent, selector: "it-icon[name]", inputs: ["name", "size", "color", "padded", "svgClass"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
114
|
+
}
|
|
115
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.3", ngImport: i0, type: ItDropdownComponent, decorators: [{
|
|
116
|
+
type: Component,
|
|
117
|
+
args: [{ standalone: true, selector: 'it-dropdown', exportAs: 'itDropdown', changeDetection: ChangeDetectionStrategy.OnPush, imports: [ItIconComponent, NgTemplateOutlet, NgIf], template: "<div class=\"dropdown {{direction}}\">\n <button #dropdownButton\n *ngIf=\"mode === 'button'; else linkButton\"\n [id]=\"id\"\n [class]=\"buttonClass\"\n type=\"button\"\n data-bs-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\">\n <ng-container *ngTemplateOutlet=\"buttonContent\"></ng-container>\n <it-icon svgClass=\"icon-expand\" name=\"expand\" size=\"sm\" [color]=\"this.color ? 'light' : 'primary'\"></it-icon>\n </button>\n\n <ng-template #linkButton>\n <a #dropdownButton\n [id]=\"id\"\n class=\"btn btn-dropdown dropdown-toggle\"\n role=\"button\"\n data-bs-toggle=\"dropdown\"\n aria-haspopup=\"true\"\n aria-expanded=\"false\">\n <ng-container *ngTemplateOutlet=\"buttonContent\"></ng-container>\n <it-icon svgClass=\"icon-expand\" name=\"expand\" size=\"sm\" color=\"primary\"></it-icon>\n </a>\n </ng-template>\n\n\n <div class=\"dropdown-menu\" [class.full-width]=\"isFullWidth\" [class.dark]=\"isDark\" [attr.aria-labelledby]=\"id\">\n <div class=\"link-list-wrapper\">\n <div class=\"link-list-heading\">\n <ng-content select=\"[listHeading]\"></ng-content>\n </div>\n <ul class=\"link-list\">\n <ng-content select=\"[list]\"></ng-content>\n </ul>\n </div>\n </div>\n</div>\n\n<ng-template #buttonContent>\n <ng-content select=\"[button]\"></ng-content>\n</ng-template>\n", styles: [".link-list-heading:empty{display:none}\n"] }]
|
|
118
|
+
}], propDecorators: { mode: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], color: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], direction: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], fullWidth: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], dark: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], items: [{
|
|
129
|
+
type: ContentChildren,
|
|
130
|
+
args: [ItDropdownItemComponent]
|
|
131
|
+
}], showEvent: [{
|
|
132
|
+
type: Output
|
|
133
|
+
}], shownEvent: [{
|
|
134
|
+
type: Output
|
|
135
|
+
}], hideEvent: [{
|
|
136
|
+
type: Output
|
|
137
|
+
}], hiddenEvent: [{
|
|
138
|
+
type: Output
|
|
139
|
+
}], dropdownButton: [{
|
|
140
|
+
type: ViewChild,
|
|
141
|
+
args: ['dropdownButton']
|
|
142
|
+
}] } });
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzaWduLWFuZ3VsYXIta2l0L3NyYy9saWIvY29tcG9uZW50cy9jb3JlL2Ryb3Bkb3duL2Ryb3Bkb3duL2Ryb3Bkb3duLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9kcm9wZG93bi9kcm9wZG93bi9kcm9wZG93bi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxlQUFlLEVBRWYsWUFBWSxFQUNaLEtBQUssRUFFTCxNQUFNLEVBR04sU0FBUyxFQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBRS9FLE9BQU8sRUFBZ0Isa0JBQWtCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNuRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUNuRixPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDNUMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFXekQsTUFBTSxPQUFPLG1CQUFvQixTQUFRLG1CQUFtQjtJQVQ1RDs7UUFXRTs7V0FFRztRQUNNLFNBQUksR0FBc0IsUUFBUSxDQUFDO1FBOEI1Qzs7V0FFRztRQUNPLGNBQVMsR0FBd0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUU5RDs7V0FFRztRQUNPLGVBQVUsR0FBd0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUUvRDs7V0FFRztRQUNPLGNBQVMsR0FBd0IsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUU5RDs7V0FFRztRQUNPLGdCQUFXLEdBQXdCLElBQUksWUFBWSxFQUFFLENBQUM7S0FrR2pFO0lBM0ZDLElBQUksV0FBVztRQUNiLElBQUksUUFBUSxHQUFHLHFCQUFxQixDQUFDO1FBQ3JDLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNkLFFBQVEsSUFBSSxRQUFRLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUNsQzthQUFNO1lBQ0wsUUFBUSxJQUFJLGVBQWUsQ0FBQztTQUM3QjtRQUVELE9BQU8sUUFBUSxDQUFDO0lBQ2xCLENBQUM7SUFFRCxJQUFJLFdBQVc7UUFDYixPQUFPLGtCQUFrQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUM1QyxDQUFDO0lBRUQsSUFBSSxNQUFNO1FBQ1IsT0FBTyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVRLFdBQVcsQ0FBQyxPQUFzQjtRQUN6QyxJQUFJLE9BQU8sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxXQUFXLEVBQUU7WUFDbkQsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1NBQ3JCO1FBQ0QsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsV0FBVyxFQUFFO1lBQ25ELElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztTQUN4QjtRQUNELEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVRLGVBQWU7UUFDdEIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUNwQixJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVEOzs7T0FHRztJQUNLLFlBQVk7UUFDbEIsSUFBSSxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDekIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDNUIsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRU8sZUFBZTtRQUNyQixJQUFJLElBQUksQ0FBQyxjQUFjLEVBQUU7WUFDdkIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxhQUFhLENBQUM7WUFDbEQsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUMsbUJBQW1CLENBQUMsT0FBTyxDQUFDLENBQUM7WUFFdEQsT0FBTyxDQUFDLGdCQUFnQixDQUFDLGtCQUFrQixFQUFFLEtBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztZQUNsRixPQUFPLENBQUMsZ0JBQWdCLENBQUMsbUJBQW1CLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1lBQ3BGLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxrQkFBa0IsRUFBRSxLQUFLLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7WUFDbEYsT0FBTyxDQUFDLGdCQUFnQixDQUFDLG9CQUFvQixFQUFFLEtBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztTQUN2RjtJQUNILENBQUM7SUFFRDs7T0FFRztJQUNJLE1BQU07UUFDWCxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRDs7T0FFRztJQUNJLElBQUk7UUFDVCxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRDs7T0FFRztJQUNJLElBQUk7UUFDVCxJQUFJLENBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRDs7T0FFRztJQUNJLE1BQU07UUFDWCxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRDs7T0FFRztJQUNJLE9BQU87UUFDWixJQUFJLENBQUMsUUFBUSxFQUFFLE9BQU8sRUFBRSxDQUFDO0lBQzNCLENBQUM7OEdBdEpVLG1CQUFtQjtrR0FBbkIsbUJBQW1CLHdUQWlDYix1QkFBdUIscU5DaEUxQyx3OENBMENBLGtHRGJZLGVBQWUsbUhBQUUsZ0JBQWdCLG9KQUFFLElBQUk7OzJGQUV0QyxtQkFBbUI7a0JBVC9CLFNBQVM7aUNBQ0ksSUFBSSxZQUNOLGFBQWEsWUFHYixZQUFZLG1CQUNMLHVCQUF1QixDQUFDLE1BQU0sV0FDdEMsQ0FBQyxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDOzhCQU96QyxJQUFJO3NCQUFaLEtBQUs7Z0JBS0csS0FBSztzQkFBYixLQUFLO2dCQVFHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBS0csU0FBUztzQkFBakIsS0FBSztnQkFLRyxJQUFJO3NCQUFaLEtBQUs7Z0JBS29DLEtBQUs7c0JBQTlDLGVBQWU7dUJBQUMsdUJBQXVCO2dCQUs5QixTQUFTO3NCQUFsQixNQUFNO2dCQUtHLFVBQVU7c0JBQW5CLE1BQU07Z0JBS0csU0FBUztzQkFBbEIsTUFBTTtnQkFLRyxXQUFXO3NCQUFwQixNQUFNO2dCQUs4QixjQUFjO3NCQUFsRCxTQUFTO3VCQUFDLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIENvbnRlbnRDaGlsZHJlbixcbiAgRWxlbWVudFJlZixcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxuICBPdXRwdXQsXG4gIFF1ZXJ5TGlzdCxcbiAgU2ltcGxlQ2hhbmdlcyxcbiAgVmlld0NoaWxkXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSXRBYnN0cmFjdENvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uLy4uL2Fic3RyYWN0cy9hYnN0cmFjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQnV0dG9uQ29sb3IsIERyb3Bkb3duRGlyZWN0aW9uIH0gZnJvbSAnLi4vLi4vLi4vLi4vaW50ZXJmYWNlcy9jb3JlJztcbmltcG9ydCB7IEJvb2xlYW5JbnB1dCwgaXNUcnVlQm9vbGVhbklucHV0IH0gZnJvbSAnLi4vLi4vLi4vLi4vdXRpbHMvYm9vbGVhbi1pbnB1dCc7XG5pbXBvcnQgeyBJdERyb3Bkb3duSXRlbUNvbXBvbmVudCB9IGZyb20gJy4uL2Ryb3Bkb3duLWl0ZW0vZHJvcGRvd24taXRlbS5jb21wb25lbnQnO1xuaW1wb3J0IHsgRHJvcGRvd24gfSBmcm9tICdib290c3RyYXAtaXRhbGlhJztcbmltcG9ydCB7IEl0SWNvbkNvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL3V0aWxzL2ljb24vaWNvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmdJZiwgTmdUZW1wbGF0ZU91dGxldCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ2l0LWRyb3Bkb3duJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Ryb3Bkb3duLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZHJvcGRvd24uY29tcG9uZW50LnNjc3MnXSxcbiAgZXhwb3J0QXM6ICdpdERyb3Bkb3duJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGltcG9ydHM6IFtJdEljb25Db21wb25lbnQsIE5nVGVtcGxhdGVPdXRsZXQsIE5nSWZdXG59KVxuZXhwb3J0IGNsYXNzIEl0RHJvcGRvd25Db21wb25lbnQgZXh0ZW5kcyBJdEFic3RyYWN0Q29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCwgT25DaGFuZ2VzIHtcblxuICAvKipcbiAgICogRHJvcGRvd24gbW9kZVxuICAgKi9cbiAgQElucHV0KCkgbW9kZTogJ2J1dHRvbicgfCAnbGluaycgPSAnYnV0dG9uJztcblxuICAvKipcbiAgICogQnV0dG9uIGNvbG9yXG4gICAqL1xuICBASW5wdXQoKSBjb2xvcj86IEJ1dHRvbkNvbG9yO1xuXG4gIC8qKlxuICAgKiBUbyBvcGVuIG1lbnUgaXRlbXMgdG86XG4gICAqIC0gPHN0cm9uZz5kcm9wdXA8L3N0cm9uZz46IHVwXG4gICAqIC0gPHN0cm9uZz5kcm9wZW5kPC9zdHJvbmc+OiByaWdodFxuICAgKiAtIDxzdHJvbmc+ZHJvcHN0YXJ0PC9zdHJvbmc+OiBsZWZ0XG4gICAqL1xuICBASW5wdXQoKSBkaXJlY3Rpb246IERyb3Bkb3duRGlyZWN0aW9uIHwgdW5kZWZpbmVkO1xuXG4gIC8qKlxuICAgKiBUbyBnZXQgYSBkcm9wZG93biBtZW51IGFzIHdpZGUgYXMgdGhlIGVsZW1lbnQgY29udGFpbmluZyB0aGUgZHJvcGRvd24gYnV0dG9uXG4gICAqL1xuICBASW5wdXQoKSBmdWxsV2lkdGg6IEJvb2xlYW5JbnB1dCB8IHVuZGVmaW5lZDtcblxuICAvKipcbiAgICogRGFyayBtZW51IHN0eWxlXG4gICAqL1xuICBASW5wdXQoKSBkYXJrOiBCb29sZWFuSW5wdXQgfCB1bmRlZmluZWQ7XG5cbiAgLyoqXG4gICAqIFRoZSBkcm9wZG93biBpdGVtc1xuICAgKi9cbiAgQENvbnRlbnRDaGlsZHJlbihJdERyb3Bkb3duSXRlbUNvbXBvbmVudCkgaXRlbXM/OiBRdWVyeUxpc3Q8SXREcm9wZG93bkl0ZW1Db21wb25lbnQ+O1xuXG4gIC8qKlxuICAgKiBGaXJlcyBpbW1lZGlhdGVseSB3aGVuIHRoZSBzaG93IGluc3RhbmNlIG1ldGhvZCBpcyBjYWxsZWQuXG4gICAqL1xuICBAT3V0cHV0KCkgc2hvd0V2ZW50OiBFdmVudEVtaXR0ZXI8RXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIC8qKlxuICAgKiBGaXJlZCB3aGVuIHRoZSBkcm9wZG93biBoYXMgYmVlbiBtYWRlIHZpc2libGUgdG8gdGhlIHVzZXIgYW5kIENTUyB0cmFuc2l0aW9ucyBoYXZlIGNvbXBsZXRlZC5cbiAgICovXG4gIEBPdXRwdXQoKSBzaG93bkV2ZW50OiBFdmVudEVtaXR0ZXI8RXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIC8qKlxuICAgKiBGaXJlcyBpbW1lZGlhdGVseSB3aGVuIHRoZSBoaWRlIGluc3RhbmNlIG1ldGhvZCBoYXMgYmVlbiBjYWxsZWQuXG4gICAqL1xuICBAT3V0cHV0KCkgaGlkZUV2ZW50OiBFdmVudEVtaXR0ZXI8RXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIC8qKlxuICAgKiBGaXJlZCB3aGVuIHRoZSBkcm9wZG93biBoYXMgZmluaXNoZWQgYmVpbmcgaGlkZGVuIGZyb20gdGhlIHVzZXIgYW5kIENTUyB0cmFuc2l0aW9ucyBoYXZlIGNvbXBsZXRlZC5cbiAgICovXG4gIEBPdXRwdXQoKSBoaWRkZW5FdmVudDogRXZlbnRFbWl0dGVyPEV2ZW50PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuXG4gIHByaXZhdGUgZHJvcGRvd24/OiBEcm9wZG93bjtcblxuICBAVmlld0NoaWxkKCdkcm9wZG93bkJ1dHRvbicpIHByaXZhdGUgZHJvcGRvd25CdXR0b24/OiBFbGVtZW50UmVmPEhUTUxCdXR0b25FbGVtZW50PjtcblxuICBnZXQgYnV0dG9uQ2xhc3MoKTogc3RyaW5nIHtcbiAgICBsZXQgYnRuQ2xhc3MgPSAnYnRuIGRyb3Bkb3duLXRvZ2dsZSc7XG4gICAgaWYgKHRoaXMuY29sb3IpIHtcbiAgICAgIGJ0bkNsYXNzICs9IGAgYnRuLSR7dGhpcy5jb2xvcn1gO1xuICAgIH0gZWxzZSB7XG4gICAgICBidG5DbGFzcyArPSBgIGJ0bi1kcm9wZG93bmA7XG4gICAgfVxuXG4gICAgcmV0dXJuIGJ0bkNsYXNzO1xuICB9XG5cbiAgZ2V0IGlzRnVsbFdpZHRoKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBpc1RydWVCb29sZWFuSW5wdXQodGhpcy5mdWxsV2lkdGgpO1xuICB9XG5cbiAgZ2V0IGlzRGFyaygpOiBib29sZWFuIHtcbiAgICByZXR1cm4gaXNUcnVlQm9vbGVhbklucHV0KHRoaXMuZGFyayk7XG4gIH1cblxuICBvdmVycmlkZSBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgaWYgKGNoYW5nZXNbJ2RhcmsnXSAmJiAhY2hhbmdlc1snZGFyayddLmZpcnN0Q2hhbmdlKSB7XG4gICAgICB0aGlzLnNldERhcmtJdGVtcygpO1xuICAgIH1cbiAgICBpZiAoY2hhbmdlc1snbW9kZSddICYmICFjaGFuZ2VzWydtb2RlJ10uZmlyc3RDaGFuZ2UpIHtcbiAgICAgIHRoaXMudXBkYXRlTGlzdGVuZXJzKCk7XG4gICAgfVxuICAgIHN1cGVyLm5nT25DaGFuZ2VzKGNoYW5nZXMpO1xuICB9XG5cbiAgb3ZlcnJpZGUgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIHN1cGVyLm5nQWZ0ZXJWaWV3SW5pdCgpO1xuICAgIHRoaXMuc2V0RGFya0l0ZW1zKCk7XG4gICAgdGhpcy51cGRhdGVMaXN0ZW5lcnMoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXQgY2hpbGQgaXRlbXMgZGFyayBtb2RlXG4gICAqIEBwcml2YXRlXG4gICAqL1xuICBwcml2YXRlIHNldERhcmtJdGVtcygpOiB2b2lkIHtcbiAgICB0aGlzLml0ZW1zPy5mb3JFYWNoKGl0ZW0gPT4ge1xuICAgICAgaXRlbS5zZXREYXJrKHRoaXMuaXNEYXJrKTtcbiAgICB9KTtcbiAgfVxuXG4gIHByaXZhdGUgdXBkYXRlTGlzdGVuZXJzKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmRyb3Bkb3duQnV0dG9uKSB7XG4gICAgICBjb25zdCBlbGVtZW50ID0gdGhpcy5kcm9wZG93bkJ1dHRvbi5uYXRpdmVFbGVtZW50O1xuICAgICAgdGhpcy5kcm9wZG93biA9IERyb3Bkb3duLmdldE9yQ3JlYXRlSW5zdGFuY2UoZWxlbWVudCk7XG5cbiAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignc2hvdy5icy5kcm9wZG93bicsIGV2ZW50ID0+IHRoaXMuc2hvd0V2ZW50LmVtaXQoZXZlbnQpKTtcbiAgICAgIGVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignc2hvd24uYnMuZHJvcGRvd24nLCBldmVudCA9PiB0aGlzLnNob3duRXZlbnQuZW1pdChldmVudCkpO1xuICAgICAgZWxlbWVudC5hZGRFdmVudExpc3RlbmVyKCdoaWRlLmJzLmRyb3Bkb3duJywgZXZlbnQgPT4gdGhpcy5oaWRlRXZlbnQuZW1pdChldmVudCkpO1xuICAgICAgZWxlbWVudC5hZGRFdmVudExpc3RlbmVyKCdoaWRkZW4uYnMuZHJvcGRvd24nLCBldmVudCA9PiB0aGlzLmhpZGRlbkV2ZW50LmVtaXQoZXZlbnQpKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogVG9nZ2xlcyB0aGUgZHJvcGRvd24gbWVudSBvZiBhIGdpdmVuIG5hdmJhciBvciB0YWJiZWQgbmF2aWdhdGlvbi5cbiAgICovXG4gIHB1YmxpYyB0b2dnbGUoKTogdm9pZCB7XG4gICAgdGhpcy5kcm9wZG93bj8udG9nZ2xlKCk7XG4gIH1cblxuICAvKipcbiAgICogU2hvd3MgdGhlIGRyb3Bkb3duIG1lbnUgb2YgYSBnaXZlbiBuYXZiYXIgb3IgdGFiYmVkIG5hdmlnYXRpb24uXG4gICAqL1xuICBwdWJsaWMgc2hvdygpOiB2b2lkIHtcbiAgICB0aGlzLmRyb3Bkb3duPy5zaG93KCk7XG4gIH1cblxuICAvKipcbiAgICogSGlkZXMgdGhlIGRyb3Bkb3duIG1lbnUgb2YgYSBnaXZlbiBuYXZiYXIgb3IgdGFiYmVkIG5hdmlnYXRpb24uXG4gICAqL1xuICBwdWJsaWMgaGlkZSgpOiB2b2lkIHtcbiAgICB0aGlzLmRyb3Bkb3duPy5oaWRlKCk7XG4gIH1cblxuICAvKipcbiAgICogVXBkYXRlcyB0aGUgcG9zaXRpb24gb2YgYW4gZWxlbWVudCdzIGRyb3Bkb3duLlxuICAgKi9cbiAgcHVibGljIHVwZGF0ZSgpOiB2b2lkIHtcbiAgICB0aGlzLmRyb3Bkb3duPy51cGRhdGUoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBEZXN0cm95cyBhbiBlbGVtZW50J3MgZHJvcGRvd24uIChSZW1vdmVzIHN0b3JlZCBkYXRhIG9uIHRoZSBET00gZWxlbWVudClcbiAgICovXG4gIHB1YmxpYyBkaXNwb3NlKCk6IHZvaWQge1xuICAgIHRoaXMuZHJvcGRvd24/LmRpc3Bvc2UoKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImRyb3Bkb3duIHt7ZGlyZWN0aW9ufX1cIj5cbiAgPGJ1dHRvbiAjZHJvcGRvd25CdXR0b25cbiAgICAgICAgICAqbmdJZj1cIm1vZGUgPT09ICdidXR0b24nOyBlbHNlIGxpbmtCdXR0b25cIlxuICAgICAgICAgIFtpZF09XCJpZFwiXG4gICAgICAgICAgW2NsYXNzXT1cImJ1dHRvbkNsYXNzXCJcbiAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICBkYXRhLWJzLXRvZ2dsZT1cImRyb3Bkb3duXCJcbiAgICAgICAgICBhcmlhLWhhc3BvcHVwPVwidHJ1ZVwiXG4gICAgICAgICAgYXJpYS1leHBhbmRlZD1cImZhbHNlXCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImJ1dHRvbkNvbnRlbnRcIj48L25nLWNvbnRhaW5lcj5cbiAgICA8aXQtaWNvbiBzdmdDbGFzcz1cImljb24tZXhwYW5kXCIgbmFtZT1cImV4cGFuZFwiIHNpemU9XCJzbVwiIFtjb2xvcl09XCJ0aGlzLmNvbG9yID8gJ2xpZ2h0JyA6ICdwcmltYXJ5J1wiPjwvaXQtaWNvbj5cbiAgPC9idXR0b24+XG5cbiAgPG5nLXRlbXBsYXRlICNsaW5rQnV0dG9uPlxuICAgIDxhICNkcm9wZG93bkJ1dHRvblxuICAgICAgIFtpZF09XCJpZFwiXG4gICAgICAgY2xhc3M9XCJidG4gYnRuLWRyb3Bkb3duIGRyb3Bkb3duLXRvZ2dsZVwiXG4gICAgICAgcm9sZT1cImJ1dHRvblwiXG4gICAgICAgZGF0YS1icy10b2dnbGU9XCJkcm9wZG93blwiXG4gICAgICAgYXJpYS1oYXNwb3B1cD1cInRydWVcIlxuICAgICAgIGFyaWEtZXhwYW5kZWQ9XCJmYWxzZVwiPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImJ1dHRvbkNvbnRlbnRcIj48L25nLWNvbnRhaW5lcj5cbiAgICAgIDxpdC1pY29uIHN2Z0NsYXNzPVwiaWNvbi1leHBhbmRcIiBuYW1lPVwiZXhwYW5kXCIgc2l6ZT1cInNtXCIgY29sb3I9XCJwcmltYXJ5XCI+PC9pdC1pY29uPlxuICAgIDwvYT5cbiAgPC9uZy10ZW1wbGF0ZT5cblxuXG4gIDxkaXYgY2xhc3M9XCJkcm9wZG93bi1tZW51XCIgW2NsYXNzLmZ1bGwtd2lkdGhdPVwiaXNGdWxsV2lkdGhcIiBbY2xhc3MuZGFya109XCJpc0RhcmtcIiBbYXR0ci5hcmlhLWxhYmVsbGVkYnldPVwiaWRcIj5cbiAgICA8ZGl2IGNsYXNzPVwibGluay1saXN0LXdyYXBwZXJcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJsaW5rLWxpc3QtaGVhZGluZ1wiPlxuICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbbGlzdEhlYWRpbmddXCI+PC9uZy1jb250ZW50PlxuICAgICAgPC9kaXY+XG4gICAgICA8dWwgY2xhc3M9XCJsaW5rLWxpc3RcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW2xpc3RdXCI+PC9uZy1jb250ZW50PlxuICAgICAgPC91bD5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L2Rpdj5cblxuPG5nLXRlbXBsYXRlICNidXR0b25Db250ZW50PlxuICA8bmctY29udGVudCBzZWxlY3Q9XCJbYnV0dG9uXVwiPjwvbmctY29udGVudD5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
|