design-angular-kit 1.0.0-1 → 1.0.0-11
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 +183 -24
- package/assets/i18n/en.json +97 -0
- package/assets/i18n/it.json +97 -0
- package/esm2020/lib/abstracts/abstract-form.component.mjs +171 -0
- package/esm2020/lib/abstracts/abstract.component.mjs +45 -0
- package/esm2020/lib/components/components.module.mjs +256 -0
- package/esm2020/lib/components/core/accordion/accordion.component.mjs +31 -0
- package/esm2020/lib/components/core/alert/alert.component.mjs +69 -0
- package/esm2020/lib/components/core/badge/badge.directive.mjs +34 -0
- package/esm2020/lib/components/core/button/button.directive.mjs +80 -0
- package/esm2020/lib/components/core/callout/callout.component.mjs +84 -0
- package/esm2020/lib/components/core/card/card.component.mjs +58 -0
- package/esm2020/lib/components/core/carousel/carousel/carousel.component.mjs +79 -0
- package/esm2020/lib/components/core/carousel/carousel-item/carousel-item.component.mjs +15 -0
- package/esm2020/lib/components/core/chip/chip.component.mjs +89 -0
- package/esm2020/lib/components/core/collapse/collapse.component.mjs +101 -0
- package/esm2020/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.mjs +24 -0
- package/esm2020/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.mjs +11 -0
- package/esm2020/lib/components/core/dimmer/dimmer.component.mjs +59 -0
- package/esm2020/lib/components/core/dropdown/dropdown/dropdown.component.mjs +130 -0
- package/esm2020/lib/components/core/dropdown/dropdown-item/dropdown-item.component.mjs +68 -0
- package/esm2020/lib/components/core/forward/forward.directive.mjs +51 -0
- package/esm2020/lib/components/core/link/link.component.mjs +40 -0
- package/esm2020/lib/components/core/list/list/list.component.mjs +13 -0
- package/esm2020/lib/components/core/list/list-item/list-item.component.mjs +36 -0
- package/esm2020/lib/components/core/modal/modal.component.mjs +98 -0
- package/esm2020/lib/components/core/notifications/notifications.component.mjs +110 -0
- package/esm2020/lib/components/core/pagination/pagination.component.mjs +131 -0
- package/esm2020/lib/components/core/popover/popover.directive.mjs +179 -0
- package/esm2020/lib/components/core/progress-bar/progress-bar.component.mjs +34 -0
- package/esm2020/lib/components/core/progress-button/progress-button.component.mjs +27 -0
- package/esm2020/lib/components/core/rating/rating.component.mjs +49 -0
- package/esm2020/lib/components/core/spinner/spinner.component.mjs +35 -0
- package/esm2020/lib/components/core/steppers/steppers-container/steppers-container.component.mjs +127 -0
- package/esm2020/lib/components/core/steppers/steppers-item/steppers-item.component.mjs +19 -0
- package/esm2020/lib/components/core/tab/tab-container/tab-container.component.mjs +59 -0
- package/esm2020/lib/components/core/tab/tab-item/tab-item.component.mjs +36 -0
- package/esm2020/lib/components/core/table/table.component.mjs +57 -0
- package/esm2020/lib/components/core/tooltip/tooltip.directive.mjs +143 -0
- package/esm2020/lib/components/form/checkbox/checkbox.component.mjs +40 -0
- package/esm2020/lib/components/form/input/input.component.mjs +222 -0
- package/esm2020/lib/components/form/password-input/password-input.component.mjs +112 -0
- package/esm2020/lib/components/form/radio-button/radio-button.component.mjs +68 -0
- package/esm2020/lib/components/form/select/select.component.mjs +62 -0
- package/esm2020/lib/components/form/textarea/textarea.component.mjs +46 -0
- package/esm2020/lib/components/form/upload-drag-drop/upload-drag-drop.component.mjs +139 -0
- package/esm2020/lib/components/form/upload-file-list/upload-file-list.component.mjs +104 -0
- package/esm2020/lib/components/navigation/back-button/back-button.component.mjs +69 -0
- package/esm2020/lib/components/navigation/back-to-top/back-to-top.component.mjs +64 -0
- package/esm2020/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.mjs +56 -0
- package/esm2020/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.mjs +23 -0
- package/esm2020/lib/components/navigation/header/header.component.mjs +57 -0
- package/esm2020/lib/components/utils/icon/icon.component.mjs +54 -0
- package/esm2020/lib/components/utils/language-switcher/language-switcher.component.mjs +39 -0
- package/esm2020/lib/components/utils/not-found-page/not-found-page.component.mjs +13 -0
- package/esm2020/lib/design-angular-kit.module.mjs +45 -131
- package/esm2020/lib/interfaces/core.mjs +16 -0
- package/esm2020/lib/interfaces/form.mjs +2 -0
- package/esm2020/lib/interfaces/icon.mjs +2 -0
- package/esm2020/lib/interfaces/utils.mjs +2 -0
- package/esm2020/lib/pipes/mark-matching-text.pipe.mjs +36 -0
- package/esm2020/lib/services/notifications/notifications.service.mjs +120 -0
- package/esm2020/lib/utils/boolean-input.mjs +15 -0
- package/esm2020/lib/utils/file-utils.mjs +73 -0
- package/esm2020/lib/utils/regex.mjs +26 -0
- package/esm2020/lib/validators/it-validators.mjs +134 -0
- package/esm2020/public_api.mjs +67 -36
- package/fesm2015/design-angular-kit.mjs +3550 -2712
- package/fesm2015/design-angular-kit.mjs.map +1 -1
- package/fesm2020/design-angular-kit.mjs +3519 -2722
- package/fesm2020/design-angular-kit.mjs.map +1 -1
- package/lib/abstracts/abstract-form.component.d.ts +86 -0
- package/lib/abstracts/abstract.component.d.ts +30 -0
- package/lib/components/components.module.d.ts +60 -0
- package/lib/components/core/accordion/accordion.component.d.ts +12 -0
- package/lib/components/core/alert/alert.component.d.ts +39 -0
- package/lib/components/core/badge/badge.directive.d.ts +16 -0
- package/lib/components/core/button/button.directive.d.ts +36 -0
- package/lib/components/core/callout/callout.component.d.ts +47 -0
- package/lib/components/core/card/card.component.d.ts +41 -0
- package/lib/components/core/carousel/carousel/carousel.component.d.ts +50 -0
- package/lib/components/core/carousel/carousel-item/carousel-item.component.d.ts +11 -0
- package/lib/components/core/chip/chip.component.d.ts +62 -0
- package/lib/components/core/collapse/collapse.component.d.ts +60 -0
- package/lib/components/core/dimmer/dimmer-buttons/dimmer-buttons.component.d.ts +12 -0
- package/lib/components/core/dimmer/dimmer-icon/dimmer-icon.component.d.ts +5 -0
- package/lib/components/core/dimmer/dimmer.component.d.ts +24 -0
- package/lib/components/core/dropdown/dropdown/dropdown.component.d.ts +81 -0
- package/lib/components/core/dropdown/dropdown-item/dropdown-item.component.d.ts +39 -0
- package/lib/components/core/forward/forward.directive.d.ts +14 -0
- package/lib/components/core/link/link.component.d.ts +31 -0
- package/lib/components/core/list/list/list.component.d.ts +10 -0
- package/lib/components/core/list/list-item/list-item.component.d.ts +24 -0
- package/lib/components/core/modal/modal.component.d.ts +59 -0
- package/lib/components/core/notifications/notifications.component.d.ts +44 -0
- package/lib/components/core/pagination/pagination.component.d.ts +92 -0
- package/lib/components/core/popover/popover.directive.d.ts +98 -0
- package/lib/components/core/progress-bar/progress-bar.component.d.ts +28 -0
- package/lib/components/core/progress-button/progress-button.component.d.ts +22 -0
- package/lib/components/core/rating/rating.component.d.ts +24 -0
- package/lib/components/core/spinner/spinner.component.d.ts +21 -0
- package/lib/components/core/steppers/steppers-container/steppers-container.component.d.ts +104 -0
- package/lib/components/core/steppers/steppers-item/steppers-item.component.d.ts +20 -0
- package/lib/components/core/tab/tab-container/tab-container.component.d.ts +30 -0
- package/lib/components/core/tab/tab-item/tab-item.component.d.ts +34 -0
- package/lib/components/core/table/table.component.d.ts +54 -0
- package/lib/components/core/tooltip/tooltip.directive.d.ts +81 -0
- package/lib/components/form/checkbox/checkbox.component.d.ts +30 -0
- package/lib/components/form/input/input.component.d.ts +96 -0
- package/lib/components/form/password-input/password-input.component.d.ts +55 -0
- package/lib/components/form/radio-button/radio-button.component.d.ts +29 -0
- package/lib/components/form/select/select.component.d.ts +30 -0
- package/lib/components/form/textarea/textarea.component.d.ts +24 -0
- package/lib/components/form/upload-drag-drop/upload-drag-drop.component.d.ts +54 -0
- package/lib/components/form/upload-file-list/upload-file-list.component.d.ts +59 -0
- package/lib/components/navigation/back-button/back-button.component.d.ts +47 -0
- package/lib/components/navigation/back-to-top/back-to-top.component.d.ts +41 -0
- package/lib/components/navigation/breadcrumbs/breadcrumb/breadcrumb.component.d.ts +32 -0
- package/lib/components/navigation/breadcrumbs/breadcrumb-item/breadcrumb-item.component.d.ts +22 -0
- package/lib/components/navigation/header/header.component.d.ts +24 -0
- package/lib/components/utils/icon/icon.component.d.ts +40 -0
- package/lib/components/utils/language-switcher/language-switcher.component.d.ts +23 -0
- package/lib/components/utils/not-found-page/not-found-page.component.d.ts +5 -0
- package/lib/design-angular-kit.module.d.ts +7 -24
- package/lib/interfaces/core.d.ts +59 -0
- package/lib/interfaces/form.d.ts +67 -0
- package/lib/interfaces/icon.d.ts +3 -0
- package/lib/interfaces/utils.d.ts +10 -0
- package/lib/services/notifications/notifications.service.d.ts +63 -0
- package/lib/utils/boolean-input.d.ts +11 -0
- package/lib/utils/file-utils.d.ts +32 -0
- package/lib/utils/regex.d.ts +25 -0
- package/lib/validators/it-validators.d.ts +58 -0
- package/package.json +22 -13
- package/public_api.d.ts +59 -35
- package/esm2020/lib/badge/badge.directive.mjs +0 -83
- package/esm2020/lib/breadcrumb/breadcrumb-item.component.mjs +0 -66
- package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +0 -89
- package/esm2020/lib/button/button.directive.mjs +0 -185
- package/esm2020/lib/button/button.module.mjs +0 -18
- package/esm2020/lib/checkbox/checkbox.component.mjs +0 -138
- package/esm2020/lib/collapse/collapse-group.component.mjs +0 -57
- package/esm2020/lib/collapse/collapse-item.component.mjs +0 -79
- package/esm2020/lib/collapse/collapse.config.mjs +0 -12
- package/esm2020/lib/collapse/collapse.directive.mjs +0 -55
- package/esm2020/lib/collapse/collapse.module.mjs +0 -22
- package/esm2020/lib/dropdown/dropdown-divider.component.mjs +0 -11
- package/esm2020/lib/dropdown/dropdown-item.component.mjs +0 -97
- package/esm2020/lib/dropdown/dropdown.component.mjs +0 -143
- package/esm2020/lib/dropdown/dropdown.config.mjs +0 -12
- package/esm2020/lib/dropdown/dropdown.directive.mjs +0 -156
- package/esm2020/lib/dropdown/dropdown.module.mjs +0 -25
- package/esm2020/lib/enums/icons.enum.mjs +0 -27
- package/esm2020/lib/form-input/form-input-password.utils.mjs +0 -154
- package/esm2020/lib/form-input/form-input.component.mjs +0 -495
- package/esm2020/lib/form-input/it-prefix.directive.mjs +0 -13
- package/esm2020/lib/form-input/it-suffix.directive.mjs +0 -13
- package/esm2020/lib/form-input/it-text-prefix.directive.mjs +0 -13
- package/esm2020/lib/form-input/it-text-suffix.directive.mjs +0 -13
- package/esm2020/lib/form-input/mark-matching-text.pipe.mjs +0 -36
- package/esm2020/lib/icon/icon.component.mjs +0 -87
- package/esm2020/lib/icon/icon.module.mjs +0 -18
- package/esm2020/lib/models/Alignment.mjs +0 -15
- package/esm2020/lib/models/ButtonSize.mjs +0 -15
- package/esm2020/lib/models/InputType.mjs +0 -44
- package/esm2020/lib/models/ThemeColor.mjs +0 -30
- package/esm2020/lib/popover/popover.config.mjs +0 -17
- package/esm2020/lib/popover/popover.directive.mjs +0 -33
- package/esm2020/lib/popover/popover.module.mjs +0 -19
- package/esm2020/lib/progress-bar/progress-bar.component.mjs +0 -98
- package/esm2020/lib/radio/radio.component.mjs +0 -287
- package/esm2020/lib/radio/unique-selection-dispatcher.mjs +0 -55
- package/esm2020/lib/tabs/tab-group.component.mjs +0 -177
- package/esm2020/lib/tabs/tab.component.mjs +0 -73
- package/esm2020/lib/tabs/tabs.module.mjs +0 -20
- package/esm2020/lib/toggle/toggle.component.mjs +0 -86
- package/esm2020/lib/tooltip/tooltip.config.mjs +0 -17
- package/esm2020/lib/tooltip/tooltip.directive.mjs +0 -43
- package/esm2020/lib/tooltip/tooltip.module.mjs +0 -19
- package/esm2020/lib/util/focus-mouse.directive.mjs +0 -32
- package/esm2020/lib/util/util.mjs +0 -12
- package/esm2020/lib/util/utils.module.mjs +0 -16
- package/lib/badge/badge.directive.d.ts +0 -33
- package/lib/breadcrumb/breadcrumb-item.component.d.ts +0 -33
- package/lib/breadcrumb/breadcrumb.component.d.ts +0 -33
- package/lib/button/button.directive.d.ts +0 -72
- package/lib/button/button.module.d.ts +0 -8
- package/lib/checkbox/checkbox.component.d.ts +0 -61
- package/lib/collapse/collapse-group.component.d.ts +0 -16
- package/lib/collapse/collapse-item.component.d.ts +0 -46
- package/lib/collapse/collapse.config.d.ts +0 -6
- package/lib/collapse/collapse.directive.d.ts +0 -25
- package/lib/collapse/collapse.module.d.ts +0 -12
- package/lib/dropdown/dropdown-divider.component.d.ts +0 -5
- package/lib/dropdown/dropdown-item.component.d.ts +0 -56
- package/lib/dropdown/dropdown.component.d.ts +0 -65
- package/lib/dropdown/dropdown.config.d.ts +0 -6
- package/lib/dropdown/dropdown.directive.d.ts +0 -77
- package/lib/dropdown/dropdown.module.d.ts +0 -15
- package/lib/enums/icons.enum.d.ts +0 -23
- package/lib/form-input/form-input-password.utils.d.ts +0 -45
- package/lib/form-input/form-input.component.d.ts +0 -283
- package/lib/form-input/it-prefix.directive.d.ts +0 -5
- package/lib/form-input/it-suffix.directive.d.ts +0 -5
- package/lib/form-input/it-text-prefix.directive.d.ts +0 -5
- package/lib/form-input/it-text-suffix.directive.d.ts +0 -5
- package/lib/icon/icon.component.d.ts +0 -34
- package/lib/icon/icon.module.d.ts +0 -8
- package/lib/models/Alignment.d.ts +0 -12
- package/lib/models/ButtonSize.d.ts +0 -11
- package/lib/models/InputType.d.ts +0 -36
- package/lib/models/ThemeColor.d.ts +0 -21
- package/lib/popover/popover.config.d.ts +0 -11
- package/lib/popover/popover.directive.d.ts +0 -20
- package/lib/popover/popover.module.d.ts +0 -9
- package/lib/progress-bar/progress-bar.component.d.ts +0 -55
- package/lib/radio/radio.component.d.ts +0 -116
- package/lib/radio/unique-selection-dispatcher.d.ts +0 -36
- package/lib/tabs/tab-group.component.d.ts +0 -71
- package/lib/tabs/tab.component.d.ts +0 -44
- package/lib/tabs/tabs.module.d.ts +0 -10
- package/lib/toggle/toggle.component.d.ts +0 -46
- package/lib/tooltip/tooltip.config.d.ts +0 -11
- package/lib/tooltip/tooltip.directive.d.ts +0 -27
- package/lib/tooltip/tooltip.module.d.ts +0 -9
- package/lib/util/focus-mouse.directive.d.ts +0 -13
- package/lib/util/util.d.ts +0 -5
- package/lib/util/utils.module.d.ts +0 -7
- /package/lib/{form-input → pipes}/mark-matching-text.pipe.d.ts +0 -0
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { NotificationType } from '../../../interfaces/core';
|
|
3
|
+
import { Notification as BSNotification } from 'bootstrap-italia';
|
|
4
|
+
import { isTrueBooleanInput } from '../../../utils/boolean-input';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../../services/notifications/notifications.service";
|
|
7
|
+
import * as i2 from "@angular/common";
|
|
8
|
+
import * as i3 from "../../utils/icon/icon.component";
|
|
9
|
+
import * as i4 from "@ngx-translate/core";
|
|
10
|
+
export class NotificationsComponent {
|
|
11
|
+
constructor(_changeDetectorRef, _notificationService) {
|
|
12
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
13
|
+
this._notificationService = _notificationService;
|
|
14
|
+
/**
|
|
15
|
+
* Default notifications duration (milliseconds)
|
|
16
|
+
* @default 8000
|
|
17
|
+
*/
|
|
18
|
+
this.duration = 8000;
|
|
19
|
+
/**
|
|
20
|
+
* Default notifications is dismissible
|
|
21
|
+
* @default true
|
|
22
|
+
*/
|
|
23
|
+
this.dismissible = true;
|
|
24
|
+
this.notificationCount = 0;
|
|
25
|
+
this.notifications = [];
|
|
26
|
+
this.subscription = this._notificationService.onNotification().subscribe(notification => {
|
|
27
|
+
if (!notification.duration) {
|
|
28
|
+
notification.duration = this.duration; // Add duration if not is set
|
|
29
|
+
}
|
|
30
|
+
if (!notification.position && this.position) {
|
|
31
|
+
notification.position = this.position; // Add position if not is set
|
|
32
|
+
}
|
|
33
|
+
if (notification.dismissible === undefined && isTrueBooleanInput(this.dismissible)) {
|
|
34
|
+
notification.dismissible = true; // Add dismissible if not is set
|
|
35
|
+
}
|
|
36
|
+
if (!notification.icon) {
|
|
37
|
+
notification.icon = this.getNotificationIcon(notification);
|
|
38
|
+
}
|
|
39
|
+
const newNotification = {
|
|
40
|
+
...notification,
|
|
41
|
+
id: `${notification.type}-${this.notificationCount++}-notification`
|
|
42
|
+
};
|
|
43
|
+
this.notifications.push(newNotification);
|
|
44
|
+
this._changeDetectorRef.detectChanges();
|
|
45
|
+
setTimeout(() => {
|
|
46
|
+
// Show the notification
|
|
47
|
+
new BSNotification(document.getElementById(newNotification.id), {
|
|
48
|
+
timeout: notification.duration
|
|
49
|
+
}).show();
|
|
50
|
+
// Clear notification after the duration
|
|
51
|
+
setTimeout(() => {
|
|
52
|
+
const index = this.notifications.findIndex(n => n.id === newNotification.id);
|
|
53
|
+
if (index > -1) {
|
|
54
|
+
this.notifications.splice(index, 1);
|
|
55
|
+
if (!this.notifications.length) {
|
|
56
|
+
this.notificationCount = 0;
|
|
57
|
+
}
|
|
58
|
+
this._changeDetectorRef.detectChanges();
|
|
59
|
+
}
|
|
60
|
+
}, notification.duration);
|
|
61
|
+
}, 200);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
ngOnDestroy() {
|
|
65
|
+
this.subscription.unsubscribe();
|
|
66
|
+
}
|
|
67
|
+
get NotificationType() {
|
|
68
|
+
return NotificationType;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Hide the notification
|
|
72
|
+
* @param id
|
|
73
|
+
*/
|
|
74
|
+
hideNotification(id) {
|
|
75
|
+
BSNotification.getInstance(document.getElementById(id))?.hide();
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Retrieve the icon name by notification type
|
|
79
|
+
* @param notification the notification
|
|
80
|
+
* @protected
|
|
81
|
+
*/
|
|
82
|
+
getNotificationIcon(notification) {
|
|
83
|
+
switch (notification.type) {
|
|
84
|
+
case NotificationType.Success:
|
|
85
|
+
return 'check-circle';
|
|
86
|
+
case NotificationType.Error:
|
|
87
|
+
return 'close-circle';
|
|
88
|
+
case NotificationType.Warning:
|
|
89
|
+
return 'error';
|
|
90
|
+
case NotificationType.Info:
|
|
91
|
+
return 'info-circle';
|
|
92
|
+
case NotificationType.Standard:
|
|
93
|
+
default:
|
|
94
|
+
return undefined;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
NotificationsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: NotificationsComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NotificationsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
99
|
+
NotificationsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: NotificationsComponent, selector: "it-notifications", inputs: { duration: "duration", position: "position", dismissible: "dismissible" }, ngImport: i0, template: "<div *ngFor=\"let notification of notifications\"\n [id]=\"notification.id\"\n class=\"notification {{notification.position}} {{notification.type}}\"\n [class.with-icon]=\"!!notification.icon\"\n [class.dismissable]=\"notification.dismissible\"\n role=\"alert\" [attr.aria-labelledby]=\"notification.id+'-title'\">\n\n <h2 [id]=\"notification.id+'-title'\" class=\"h5\">\n <it-icon *ngIf=\"!!notification.icon\" [name]=\"notification.icon\"></it-icon>\n <ng-container>{{notification.title}}</ng-container>\n </h2>\n <p *ngIf=\"notification.message\">{{notification.message}}</p>\n\n <button *ngIf=\"notification.dismissible\" type=\"button\" class=\"btn notification-close\"\n (click)=\"hideNotification(notification.id)\">\n <it-icon name=\"close\"></it-icon>\n <span class=\"visually-hidden\">{{'it.core.close-notification'|translate:{ title: notification.title } }}</span>\n </button>\n</div>\n", styles: [".notification{z-index:10000}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.IconComponent, selector: "it-icon[name]", inputs: ["name", "size", "color", "padded", "class"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
100
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: NotificationsComponent, decorators: [{
|
|
101
|
+
type: Component,
|
|
102
|
+
args: [{ selector: 'it-notifications', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngFor=\"let notification of notifications\"\n [id]=\"notification.id\"\n class=\"notification {{notification.position}} {{notification.type}}\"\n [class.with-icon]=\"!!notification.icon\"\n [class.dismissable]=\"notification.dismissible\"\n role=\"alert\" [attr.aria-labelledby]=\"notification.id+'-title'\">\n\n <h2 [id]=\"notification.id+'-title'\" class=\"h5\">\n <it-icon *ngIf=\"!!notification.icon\" [name]=\"notification.icon\"></it-icon>\n <ng-container>{{notification.title}}</ng-container>\n </h2>\n <p *ngIf=\"notification.message\">{{notification.message}}</p>\n\n <button *ngIf=\"notification.dismissible\" type=\"button\" class=\"btn notification-close\"\n (click)=\"hideNotification(notification.id)\">\n <it-icon name=\"close\"></it-icon>\n <span class=\"visually-hidden\">{{'it.core.close-notification'|translate:{ title: notification.title } }}</span>\n </button>\n</div>\n", styles: [".notification{z-index:10000}\n"] }]
|
|
103
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.NotificationsService }]; }, propDecorators: { duration: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], position: [{
|
|
106
|
+
type: Input
|
|
107
|
+
}], dismissible: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}] } });
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notifications.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/core/notifications/notifications.component.ts","../../../../../../../projects/design-angular-kit/src/lib/components/core/notifications/notifications.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, OnDestroy } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { NotificationsService } from '../../../services/notifications/notifications.service';\nimport { Notification, NotificationPosition, NotificationType } from '../../../interfaces/core';\nimport { Notification as BSNotification } from 'bootstrap-italia';\nimport { BooleanInput, isTrueBooleanInput } from '../../../utils/boolean-input';\nimport { IconName } from '../../../interfaces/icon';\n\n@Component({\n  selector: 'it-notifications',\n  templateUrl: './notifications.component.html',\n  styleUrls: ['./notifications.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NotificationsComponent implements OnDestroy {\n\n  /**\n   * Default notifications duration (milliseconds)\n   * @default 8000\n   */\n  @Input() duration: number = 8000;\n\n  /**\n   * Default notifications position\n   */\n  @Input() position?: NotificationPosition;\n\n  /**\n   * Default notifications is dismissible\n   * @default true\n   */\n  @Input() dismissible?: BooleanInput = true;\n\n  private subscription: Subscription;\n  private notificationCount: number = 0;\n  protected notifications: Array<Notification & { id: string }> = [];\n\n  constructor(\n    private readonly _changeDetectorRef: ChangeDetectorRef,\n    private readonly _notificationService: NotificationsService\n  ) {\n    this.subscription = this._notificationService.onNotification().subscribe(notification => {\n      if (!notification.duration) {\n        notification.duration = this.duration; // Add duration if not is set\n      }\n      if (!notification.position && this.position) {\n        notification.position = this.position; // Add position if not is set\n      }\n      if (notification.dismissible === undefined && isTrueBooleanInput(this.dismissible)) {\n        notification.dismissible = true; // Add dismissible if not is set\n      }\n      if (!notification.icon) {\n        notification.icon = this.getNotificationIcon(notification);\n      }\n\n      const newNotification = {\n        ...notification,\n        id: `${notification.type}-${this.notificationCount++}-notification`\n      };\n      this.notifications.push(newNotification);\n      this._changeDetectorRef.detectChanges();\n\n      setTimeout(() => {\n        // Show the notification\n        new BSNotification(document.getElementById(newNotification.id)!, {\n          timeout: notification.duration\n        }).show();\n\n        // Clear notification after the duration\n        setTimeout(() => {\n          const index = this.notifications.findIndex(n => n.id === newNotification.id);\n          if (index > -1) {\n            this.notifications.splice(index, 1);\n            if (!this.notifications.length) {\n              this.notificationCount = 0;\n            }\n            this._changeDetectorRef.detectChanges();\n          }\n        }, notification.duration);\n      }, 200);\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n\n  protected get NotificationType(): typeof NotificationType {\n    return NotificationType;\n  }\n\n  /**\n   * Hide the notification\n   * @param id\n   */\n  protected hideNotification(id: string): void {\n    BSNotification.getInstance(document.getElementById(id)!)?.hide();\n  }\n\n  /**\n   * Retrieve the icon name by notification type\n   * @param notification the notification\n   * @protected\n   */\n  private getNotificationIcon(notification: Notification): IconName | undefined {\n    switch (notification.type) {\n      case NotificationType.Success:\n        return 'check-circle';\n      case NotificationType.Error:\n        return 'close-circle';\n      case NotificationType.Warning:\n        return 'error';\n      case NotificationType.Info:\n        return 'info-circle';\n      case NotificationType.Standard:\n      default:\n        return undefined;\n    }\n  }\n}\n","<div *ngFor=\"let notification of notifications\"\n     [id]=\"notification.id\"\n     class=\"notification {{notification.position}} {{notification.type}}\"\n     [class.with-icon]=\"!!notification.icon\"\n     [class.dismissable]=\"notification.dismissible\"\n     role=\"alert\" [attr.aria-labelledby]=\"notification.id+'-title'\">\n\n  <h2 [id]=\"notification.id+'-title'\" class=\"h5\">\n    <it-icon *ngIf=\"!!notification.icon\" [name]=\"notification.icon\"></it-icon>\n    <ng-container>{{notification.title}}</ng-container>\n  </h2>\n  <p *ngIf=\"notification.message\">{{notification.message}}</p>\n\n  <button *ngIf=\"notification.dismissible\" type=\"button\" class=\"btn notification-close\"\n          (click)=\"hideNotification(notification.id)\">\n    <it-icon name=\"close\"></it-icon>\n    <span class=\"visually-hidden\">{{'it.core.close-notification'|translate:{ title: notification.title } }}</span>\n  </button>\n</div>\n"]}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { isTrueBooleanInput } from '../../../utils/boolean-input';
|
|
3
|
+
import { FormControl } from '@angular/forms';
|
|
4
|
+
import { debounceTime, distinctUntilChanged, filter } from 'rxjs';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "@angular/forms";
|
|
8
|
+
import * as i3 from "../dropdown/dropdown/dropdown.component";
|
|
9
|
+
import * as i4 from "../dropdown/dropdown-item/dropdown-item.component";
|
|
10
|
+
import * as i5 from "../../form/input/input.component";
|
|
11
|
+
import * as i6 from "../../utils/icon/icon.component";
|
|
12
|
+
import * as i7 from "@ngx-translate/core";
|
|
13
|
+
export class PaginationComponent {
|
|
14
|
+
constructor() {
|
|
15
|
+
/**
|
|
16
|
+
* Number of pages closest to the current one to display
|
|
17
|
+
* @default 5
|
|
18
|
+
*/
|
|
19
|
+
this.visiblePages = 5;
|
|
20
|
+
/**
|
|
21
|
+
* Available Changer values
|
|
22
|
+
* @default [10, 25, 50, 100]
|
|
23
|
+
*/
|
|
24
|
+
this.changerValues = [10, 25, 50, 100];
|
|
25
|
+
/**
|
|
26
|
+
* Fired when page is changed. Emit the new index of page
|
|
27
|
+
*/
|
|
28
|
+
this.pageEvent = new EventEmitter();
|
|
29
|
+
/**
|
|
30
|
+
* Fired when changer is changed. Emit the new changer value
|
|
31
|
+
*/
|
|
32
|
+
this.changerEvent = new EventEmitter();
|
|
33
|
+
/**
|
|
34
|
+
* The pages
|
|
35
|
+
* @protected
|
|
36
|
+
*/
|
|
37
|
+
this.pages = [];
|
|
38
|
+
/**
|
|
39
|
+
* Jump to page input
|
|
40
|
+
* @protected
|
|
41
|
+
*/
|
|
42
|
+
this.jumpToPage = new FormControl(null);
|
|
43
|
+
this.jumpToPage.valueChanges.pipe(debounceTime(300), // Delay filter data after time span has passed without another source emission
|
|
44
|
+
distinctUntilChanged(), filter(value => !!value && this.jumpToPage.valid)).subscribe(value => {
|
|
45
|
+
this.pageEvent.emit(value - 1);
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
get isSimpleMode() {
|
|
49
|
+
return isTrueBooleanInput(this.simpleMode);
|
|
50
|
+
}
|
|
51
|
+
get isTextLinks() {
|
|
52
|
+
return isTrueBooleanInput(this.textLinks);
|
|
53
|
+
}
|
|
54
|
+
get isShowJumpToPage() {
|
|
55
|
+
return isTrueBooleanInput(this.showJumpToPage);
|
|
56
|
+
}
|
|
57
|
+
ngOnChanges(changes) {
|
|
58
|
+
this.pages = this.calculatePages();
|
|
59
|
+
if (changes['currentPage']) {
|
|
60
|
+
this.jumpToPage.setValue(null, { emitEvent: false });
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Create array to generate pagination of `visiblePages` element
|
|
65
|
+
*/
|
|
66
|
+
calculatePages() {
|
|
67
|
+
if (this.isSimpleMode) {
|
|
68
|
+
return [this.currentPage];
|
|
69
|
+
}
|
|
70
|
+
const length = this.pageNumbers > this.visiblePages ? this.visiblePages : this.pageNumbers;
|
|
71
|
+
const halfVisiblePages = Math.floor(this.visiblePages / 2);
|
|
72
|
+
let start = (this.currentPage > halfVisiblePages && this.pageNumbers > this.visiblePages) ?
|
|
73
|
+
this.currentPage - halfVisiblePages + 1 : 1;
|
|
74
|
+
if (this.pageNumbers > this.visiblePages) {
|
|
75
|
+
if ((this.currentPage + 1) >= this.pageNumbers) {
|
|
76
|
+
start -= halfVisiblePages;
|
|
77
|
+
}
|
|
78
|
+
else if (this.currentPage >= (this.pageNumbers - halfVisiblePages)) {
|
|
79
|
+
start -= (this.pageNumbers - (this.currentPage + 1));
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
return Array.from({ length }, (_, i) => i + start);
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* On click page change
|
|
86
|
+
* @param event click event
|
|
87
|
+
* @param newPage the new page of table
|
|
88
|
+
*/
|
|
89
|
+
pageChange(event, newPage) {
|
|
90
|
+
event.preventDefault();
|
|
91
|
+
this.pageEvent.emit(newPage - 1); // emit new page index
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* On click changer
|
|
95
|
+
* @param event click event
|
|
96
|
+
* @param value the new changer value
|
|
97
|
+
*/
|
|
98
|
+
changerChange(event, value) {
|
|
99
|
+
event.preventDefault();
|
|
100
|
+
this.changerEvent.emit(value); // emit new changer value
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
PaginationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: PaginationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
104
|
+
PaginationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: PaginationComponent, selector: "it-pagination[currentPage][pageNumbers]", inputs: { currentPage: "currentPage", pageNumbers: "pageNumbers", visiblePages: "visiblePages", alignment: "alignment", simpleMode: "simpleMode", textLinks: "textLinks", currentChanger: "currentChanger", changerValues: "changerValues", showJumpToPage: "showJumpToPage" }, outputs: { pageEvent: "pageEvent", changerEvent: "changerEvent" }, usesOnChanges: true, ngImport: i0, template: "<nav class=\"pagination-wrapper\"\n [class.justify-content-center]=\"alignment==='center'\"\n [class.justify-content-end]=\"alignment==='end'\"\n [class.pagination-total]=\"totalNumberText.hasChildNodes()\">\n\n <ul *ngIf=\"pages.length\" class=\"pagination\">\n <li class=\"page-item\" [class.disabled]=\"currentPage < 1\">\n <a class=\"page-link\" [class.text]=\"isTextLinks\" href=\"#\" (click)=\"pageChange($event, currentPage)\">\n <it-icon *ngIf=\"!isTextLinks\" name=\"chevron-left\" color=\"primary\"></it-icon>\n <span class=\"visually-hidden\">\n {{(isTextLinks ? 'it.core.page' : 'it.core.previous-page') | translate}}\n </span>\n <ng-container *ngIf=\"isTextLinks\">{{'it.core.previous' | translate}}</ng-container>\n </a>\n </li>\n\n <ng-container *ngIf=\"isSimpleMode; else defaultView\">\n <li class=\"page-item\"><span class=\"page-link\" aria-current=\"page\">{{currentPage + 1}}</span></li>\n <li class=\"page-item\"><span class=\"page-link\">/</span></li>\n <li class=\"page-item\"><span class=\"page-link\">{{pageNumbers}}</span></li>\n <li class=\"page-item visually-hidden\">\n <a class=\"page-link\" href=\"#\" aria-current=\"page\">\n {{'it.core.page-of-total'|translate : {page: (currentPage + 1), total: pageNumbers} }}\n </a>\n </li>\n </ng-container>\n <ng-template #defaultView>\n <ng-container *ngIf=\"pageNumbers > visiblePages && pages[0] >= 2\">\n <li class=\"page-item\">\n <a class=\"page-link\" href=\"#\" (click)=\"pageChange($event, 1)\">1</a>\n </li>\n <li class=\"page-item\" *ngIf=\"pages[0] >= 3\">\n <span class=\"page-link\">...</span>\n </li>\n </ng-container>\n\n <li class=\"page-item\" *ngFor=\"let page of pages\">\n <a class=\"page-link\" aria-current=\"page\" *ngIf=\"page === (currentPage + 1); else inactivePage\">\n <span class=\"d-inline-block d-sm-none\">{{'it.core.page'|translate}}</span> {{page}}\n </a>\n <ng-template #inactivePage>\n <a class=\"page-link\" href=\"#\" (click)=\"pageChange($event, page)\">{{page}}</a>\n </ng-template>\n </li>\n\n <ng-container *ngIf=\"pageNumbers > visiblePages && pages[pages.length - 1] < pageNumbers\">\n <li class=\"page-item\" *ngIf=\"pages[pages.length - 1] < (pageNumbers - 1)\">\n <span class=\"page-link\">...</span>\n </li>\n <li class=\"page-item\">\n <a class=\"page-link\" href=\"#\" (click)=\"pageChange($event, pageNumbers)\">{{pageNumbers}}</a>\n </li>\n </ng-container>\n </ng-template>\n\n <li class=\"page-item\" [class.disabled]=\"currentPage >= pageNumbers - 1\">\n <a class=\"page-link\" [class.text]=\"isTextLinks\" href=\"#\" (click)=\"pageChange($event, currentPage + 2)\">\n <span class=\"visually-hidden\">\n {{(isTextLinks ? 'it.core.page' : 'it.core.next-page') | translate}}\n </span>\n <ng-container *ngIf=\"isTextLinks\">{{'it.core.next' | translate}}</ng-container>\n <it-icon *ngIf=\"!isTextLinks\" name=\"chevron-right\" color=\"primary\"></it-icon>\n </a>\n </li>\n </ul>\n\n <it-dropdown *ngIf=\"currentChanger !== undefined\" id=\"pager-changer\">\n <span button>{{currentChanger}} / {{'it.core.page' | translate | lowercase}}</span>\n <ng-container list>\n <it-dropdown-item *ngFor=\"let value of changerValues\" href=\"#\" externalLink=\"true\"\n (click)=\"changerChange($event, value)\">\n {{value}} / {{'it.core.page' | translate | lowercase}}\n </it-dropdown-item>\n </ng-container>\n </it-dropdown>\n\n <it-input *ngIf=\"isShowJumpToPage\" id=\"jump-to-page\" type=\"number\" [min]=\"1\" [max]=\"pageNumbers\"\n [label]=\"('it.core.go-to' | translate) + '...'\" [formControl]=\"jumpToPage\"></it-input>\n\n <p [class.d-none]=\"!totalNumberText.hasChildNodes()\" #totalNumberText>\n <ng-content></ng-content>\n </p>\n</nav>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i3.DropdownComponent, selector: "it-dropdown", inputs: ["color", "direction", "fullWidth", "dark"], outputs: ["onShow", "onShown", "onHide", "onHidden"], exportAs: ["itDropdown"] }, { kind: "component", type: i4.DropdownItemComponent, selector: "it-dropdown-item", inputs: ["divider", "active", "large", "iconName", "iconPosition"] }, { kind: "component", type: i5.InputComponent, selector: "it-input", inputs: ["type", "placeholder", "description", "readonly", "max", "min", "step", "currency", "percentage", "adaptive", "autocompleteData", "autocompleteDebounceTime"], outputs: ["onAutocompleteSelected"] }, { kind: "component", type: i6.IconComponent, selector: "it-icon[name]", inputs: ["name", "size", "color", "padded", "class"] }, { kind: "pipe", type: i1.LowerCasePipe, name: "lowercase" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
105
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: PaginationComponent, decorators: [{
|
|
106
|
+
type: Component,
|
|
107
|
+
args: [{ selector: 'it-pagination[currentPage][pageNumbers]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<nav class=\"pagination-wrapper\"\n [class.justify-content-center]=\"alignment==='center'\"\n [class.justify-content-end]=\"alignment==='end'\"\n [class.pagination-total]=\"totalNumberText.hasChildNodes()\">\n\n <ul *ngIf=\"pages.length\" class=\"pagination\">\n <li class=\"page-item\" [class.disabled]=\"currentPage < 1\">\n <a class=\"page-link\" [class.text]=\"isTextLinks\" href=\"#\" (click)=\"pageChange($event, currentPage)\">\n <it-icon *ngIf=\"!isTextLinks\" name=\"chevron-left\" color=\"primary\"></it-icon>\n <span class=\"visually-hidden\">\n {{(isTextLinks ? 'it.core.page' : 'it.core.previous-page') | translate}}\n </span>\n <ng-container *ngIf=\"isTextLinks\">{{'it.core.previous' | translate}}</ng-container>\n </a>\n </li>\n\n <ng-container *ngIf=\"isSimpleMode; else defaultView\">\n <li class=\"page-item\"><span class=\"page-link\" aria-current=\"page\">{{currentPage + 1}}</span></li>\n <li class=\"page-item\"><span class=\"page-link\">/</span></li>\n <li class=\"page-item\"><span class=\"page-link\">{{pageNumbers}}</span></li>\n <li class=\"page-item visually-hidden\">\n <a class=\"page-link\" href=\"#\" aria-current=\"page\">\n {{'it.core.page-of-total'|translate : {page: (currentPage + 1), total: pageNumbers} }}\n </a>\n </li>\n </ng-container>\n <ng-template #defaultView>\n <ng-container *ngIf=\"pageNumbers > visiblePages && pages[0] >= 2\">\n <li class=\"page-item\">\n <a class=\"page-link\" href=\"#\" (click)=\"pageChange($event, 1)\">1</a>\n </li>\n <li class=\"page-item\" *ngIf=\"pages[0] >= 3\">\n <span class=\"page-link\">...</span>\n </li>\n </ng-container>\n\n <li class=\"page-item\" *ngFor=\"let page of pages\">\n <a class=\"page-link\" aria-current=\"page\" *ngIf=\"page === (currentPage + 1); else inactivePage\">\n <span class=\"d-inline-block d-sm-none\">{{'it.core.page'|translate}}</span> {{page}}\n </a>\n <ng-template #inactivePage>\n <a class=\"page-link\" href=\"#\" (click)=\"pageChange($event, page)\">{{page}}</a>\n </ng-template>\n </li>\n\n <ng-container *ngIf=\"pageNumbers > visiblePages && pages[pages.length - 1] < pageNumbers\">\n <li class=\"page-item\" *ngIf=\"pages[pages.length - 1] < (pageNumbers - 1)\">\n <span class=\"page-link\">...</span>\n </li>\n <li class=\"page-item\">\n <a class=\"page-link\" href=\"#\" (click)=\"pageChange($event, pageNumbers)\">{{pageNumbers}}</a>\n </li>\n </ng-container>\n </ng-template>\n\n <li class=\"page-item\" [class.disabled]=\"currentPage >= pageNumbers - 1\">\n <a class=\"page-link\" [class.text]=\"isTextLinks\" href=\"#\" (click)=\"pageChange($event, currentPage + 2)\">\n <span class=\"visually-hidden\">\n {{(isTextLinks ? 'it.core.page' : 'it.core.next-page') | translate}}\n </span>\n <ng-container *ngIf=\"isTextLinks\">{{'it.core.next' | translate}}</ng-container>\n <it-icon *ngIf=\"!isTextLinks\" name=\"chevron-right\" color=\"primary\"></it-icon>\n </a>\n </li>\n </ul>\n\n <it-dropdown *ngIf=\"currentChanger !== undefined\" id=\"pager-changer\">\n <span button>{{currentChanger}} / {{'it.core.page' | translate | lowercase}}</span>\n <ng-container list>\n <it-dropdown-item *ngFor=\"let value of changerValues\" href=\"#\" externalLink=\"true\"\n (click)=\"changerChange($event, value)\">\n {{value}} / {{'it.core.page' | translate | lowercase}}\n </it-dropdown-item>\n </ng-container>\n </it-dropdown>\n\n <it-input *ngIf=\"isShowJumpToPage\" id=\"jump-to-page\" type=\"number\" [min]=\"1\" [max]=\"pageNumbers\"\n [label]=\"('it.core.go-to' | translate) + '...'\" [formControl]=\"jumpToPage\"></it-input>\n\n <p [class.d-none]=\"!totalNumberText.hasChildNodes()\" #totalNumberText>\n <ng-content></ng-content>\n </p>\n</nav>\n" }]
|
|
108
|
+
}], ctorParameters: function () { return []; }, propDecorators: { currentPage: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], pageNumbers: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], visiblePages: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}], alignment: [{
|
|
115
|
+
type: Input
|
|
116
|
+
}], simpleMode: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}], textLinks: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], currentChanger: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], changerValues: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], showJumpToPage: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], pageEvent: [{
|
|
127
|
+
type: Output
|
|
128
|
+
}], changerEvent: [{
|
|
129
|
+
type: Output
|
|
130
|
+
}] } });
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/core/pagination/pagination.component.ts","../../../../../../../projects/design-angular-kit/src/lib/components/core/pagination/pagination.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EAEP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAgB,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAChF,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,oBAAoB,EAAE,MAAM,EAAE,MAAM,MAAM,CAAC;;;;;;;;;AAOlE,MAAM,OAAO,mBAAmB;IA0F9B;QA9EA;;;WAGG;QACM,iBAAY,GAAW,CAAC,CAAC;QA4BlC;;;WAGG;QACM,kBAAa,GAAkB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC,CAAC;QAQ1D;;WAEG;QACO,cAAS,GAAG,IAAI,YAAY,EAAU,CAAC;QAEjD;;WAEG;QACO,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC;QAEpD;;;WAGG;QACO,UAAK,GAAkB,EAAE,CAAC;QAEpC;;;WAGG;QACO,eAAU,GAA+B,IAAI,WAAW,CAAgB,IAAI,CAAC,CAAC;QAetF,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,IAAI,CAC/B,YAAY,CAAC,GAAG,CAAC,EAAE,+EAA+E;QAClG,oBAAoB,EAAE,EACtB,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAClD,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAClB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAM,GAAG,CAAC,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC;IApBD,IAAI,YAAY;QACd,OAAO,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC7C,CAAC;IAED,IAAI,WAAW;QACb,OAAO,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC5C,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,kBAAkB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACjD,CAAC;IAYD,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACnC,IAAI,OAAO,CAAC,aAAa,CAAC,EAAE;YAC1B,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SACtD;IACH,CAAC;IAED;;OAEG;IACK,cAAc;QACpB,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAC3B;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;QAE3F,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;QAC3D,IAAI,KAAK,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,gBAAgB,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;YACzF,IAAI,CAAC,WAAW,GAAG,gBAAgB,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE9C,IAAI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,EAAE;YACxC,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE;gBAC9C,KAAK,IAAI,gBAAgB,CAAC;aAC3B;iBAAM,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,gBAAgB,CAAC,EAAE;gBACpE,KAAK,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC;aACtD;SACF;QAED,OAAO,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC;IACrD,CAAC;IAED;;;;OAIG;IACO,UAAU,CAAC,KAAY,EAAE,OAAe;QAChD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,sBAAsB;IAC1D,CAAC;IAED;;;;OAIG;IACO,aAAa,CAAC,KAAY,EAAE,KAAa;QACjD,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,yBAAyB;IAC1D,CAAC;;gHAtJU,mBAAmB;oGAAnB,mBAAmB,ubClBhC,i/HAmFA;2FDjEa,mBAAmB;kBAL/B,SAAS;+BACE,yCAAyC,mBAElC,uBAAuB,CAAC,MAAM;0EAOtC,WAAW;sBAAnB,KAAK;gBAKG,WAAW;sBAAnB,KAAK;gBAMG,YAAY;sBAApB,KAAK;gBAKG,SAAS;sBAAjB,KAAK;gBAOG,UAAU;sBAAlB,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAOG,cAAc;sBAAtB,KAAK;gBAMG,aAAa;sBAArB,KAAK;gBAMG,cAAc;sBAAtB,KAAK;gBAKI,SAAS;sBAAlB,MAAM;gBAKG,YAAY;sBAArB,MAAM","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { BooleanInput, isTrueBooleanInput } from '../../../utils/boolean-input';\nimport { FormControl } from '@angular/forms';\nimport { debounceTime, distinctUntilChanged, filter } from 'rxjs';\n\n@Component({\n  selector: 'it-pagination[currentPage][pageNumbers]',\n  templateUrl: './pagination.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PaginationComponent implements OnChanges {\n\n  /**\n   * Index of page (start 0)\n   */\n  @Input() currentPage!: number;\n\n  /**\n   * Max number of page (counter)\n   */\n  @Input() pageNumbers!: number;\n\n  /**\n   * Number of pages closest to the current one to display\n   * @default 5\n   */\n  @Input() visiblePages: number = 5;\n\n  /**\n   * Pagination alignment (justify-content)\n   */\n  @Input() alignment?: 'center' | 'end';\n\n  /**\n   * Enable/Disable simple mode\n   * Pagination in the \"Simple mode\" version is optimized for mobile devices.\n   * @default undefined - disabled\n   */\n  @Input() simpleMode?: BooleanInput;\n\n  /**\n   * Enable/Disable text links\n   * Chevron icons used as navigation links are replaced by text links such as “previous” and “next”.\n   * @default undefined - disabled\n   */\n  @Input() textLinks?: BooleanInput;\n\n  /**\n   * Current value of Changer\n   * If is set show the Changer\n   * @default undefined - hide the Changer\n   */\n  @Input() currentChanger?: number;\n\n  /**\n   * Available Changer values\n   * @default [10, 25, 50, 100]\n   */\n  @Input() changerValues: Array<number> = [10, 25, 50, 100];\n\n  /**\n   * Hide/Show \"Jump to page\" input\n   * @default undefined - hidden\n   */\n  @Input() showJumpToPage?: BooleanInput;\n\n  /**\n   * Fired when page is changed. Emit the new index of page\n   */\n  @Output() pageEvent = new EventEmitter<number>();\n\n  /**\n   * Fired when changer is changed. Emit the new changer value\n   */\n  @Output() changerEvent = new EventEmitter<number>();\n\n  /**\n   * The pages\n   * @protected\n   */\n  protected pages: Array<number> = [];\n\n  /**\n   * Jump to page input\n   * @protected\n   */\n  protected jumpToPage: FormControl<number | null> = new FormControl<number | null>(null);\n\n  get isSimpleMode(): boolean {\n    return isTrueBooleanInput(this.simpleMode);\n  }\n\n  get isTextLinks(): boolean {\n    return isTrueBooleanInput(this.textLinks);\n  }\n\n  get isShowJumpToPage(): boolean {\n    return isTrueBooleanInput(this.showJumpToPage);\n  }\n\n  constructor() {\n    this.jumpToPage.valueChanges.pipe(\n      debounceTime(300), // Delay filter data after time span has passed without another source emission\n      distinctUntilChanged(),\n      filter(value => !!value && this.jumpToPage.valid)\n    ).subscribe(value => {\n      this.pageEvent.emit(value! - 1);\n    });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.pages = this.calculatePages();\n    if (changes['currentPage']) {\n      this.jumpToPage.setValue(null, { emitEvent: false });\n    }\n  }\n\n  /**\n   * Create array to generate pagination of `visiblePages` element\n   */\n  private calculatePages(): Array<number> {\n    if (this.isSimpleMode) {\n      return [this.currentPage];\n    }\n\n    const length = this.pageNumbers > this.visiblePages ? this.visiblePages : this.pageNumbers;\n\n    const halfVisiblePages = Math.floor(this.visiblePages / 2);\n    let start = (this.currentPage > halfVisiblePages && this.pageNumbers > this.visiblePages) ?\n      this.currentPage - halfVisiblePages + 1 : 1;\n\n    if (this.pageNumbers > this.visiblePages) {\n      if ((this.currentPage + 1) >= this.pageNumbers) {\n        start -= halfVisiblePages;\n      } else if (this.currentPage >= (this.pageNumbers - halfVisiblePages)) {\n        start -= (this.pageNumbers - (this.currentPage + 1));\n      }\n    }\n\n    return Array.from({ length }, (_, i) => i + start);\n  }\n\n  /**\n   * On click page change\n   * @param event click event\n   * @param newPage the new page of table\n   */\n  protected pageChange(event: Event, newPage: number): void {\n    event.preventDefault();\n    this.pageEvent.emit(newPage - 1); // emit new page index\n  }\n\n  /**\n   * On click changer\n   * @param event click event\n   * @param value the new changer value\n   */\n  protected changerChange(event: Event, value: number): void {\n    event.preventDefault();\n    this.changerEvent.emit(value); // emit new changer value\n  }\n\n}\n","<nav class=\"pagination-wrapper\"\n     [class.justify-content-center]=\"alignment==='center'\"\n     [class.justify-content-end]=\"alignment==='end'\"\n     [class.pagination-total]=\"totalNumberText.hasChildNodes()\">\n\n  <ul *ngIf=\"pages.length\" class=\"pagination\">\n    <li class=\"page-item\" [class.disabled]=\"currentPage < 1\">\n      <a class=\"page-link\" [class.text]=\"isTextLinks\" href=\"#\" (click)=\"pageChange($event, currentPage)\">\n        <it-icon *ngIf=\"!isTextLinks\" name=\"chevron-left\" color=\"primary\"></it-icon>\n        <span class=\"visually-hidden\">\n          {{(isTextLinks ? 'it.core.page' : 'it.core.previous-page') | translate}}\n        </span>\n        <ng-container *ngIf=\"isTextLinks\">{{'it.core.previous' | translate}}</ng-container>\n      </a>\n    </li>\n\n    <ng-container *ngIf=\"isSimpleMode; else defaultView\">\n      <li class=\"page-item\"><span class=\"page-link\" aria-current=\"page\">{{currentPage + 1}}</span></li>\n      <li class=\"page-item\"><span class=\"page-link\">/</span></li>\n      <li class=\"page-item\"><span class=\"page-link\">{{pageNumbers}}</span></li>\n      <li class=\"page-item visually-hidden\">\n        <a class=\"page-link\" href=\"#\" aria-current=\"page\">\n          {{'it.core.page-of-total'|translate : {page: (currentPage + 1), total: pageNumbers} }}\n        </a>\n      </li>\n    </ng-container>\n    <ng-template #defaultView>\n      <ng-container *ngIf=\"pageNumbers > visiblePages && pages[0] >= 2\">\n        <li class=\"page-item\">\n          <a class=\"page-link\" href=\"#\" (click)=\"pageChange($event, 1)\">1</a>\n        </li>\n        <li class=\"page-item\" *ngIf=\"pages[0] >= 3\">\n          <span class=\"page-link\">...</span>\n        </li>\n      </ng-container>\n\n      <li class=\"page-item\" *ngFor=\"let page of pages\">\n        <a class=\"page-link\" aria-current=\"page\" *ngIf=\"page === (currentPage + 1); else inactivePage\">\n          <span class=\"d-inline-block d-sm-none\">{{'it.core.page'|translate}}</span> {{page}}\n        </a>\n        <ng-template #inactivePage>\n          <a class=\"page-link\" href=\"#\" (click)=\"pageChange($event, page)\">{{page}}</a>\n        </ng-template>\n      </li>\n\n      <ng-container *ngIf=\"pageNumbers > visiblePages && pages[pages.length - 1] < pageNumbers\">\n        <li class=\"page-item\" *ngIf=\"pages[pages.length - 1] < (pageNumbers - 1)\">\n          <span class=\"page-link\">...</span>\n        </li>\n        <li class=\"page-item\">\n          <a class=\"page-link\" href=\"#\" (click)=\"pageChange($event, pageNumbers)\">{{pageNumbers}}</a>\n        </li>\n      </ng-container>\n    </ng-template>\n\n    <li class=\"page-item\" [class.disabled]=\"currentPage >= pageNumbers - 1\">\n      <a class=\"page-link\" [class.text]=\"isTextLinks\" href=\"#\" (click)=\"pageChange($event, currentPage + 2)\">\n        <span class=\"visually-hidden\">\n          {{(isTextLinks ? 'it.core.page' : 'it.core.next-page') | translate}}\n        </span>\n        <ng-container *ngIf=\"isTextLinks\">{{'it.core.next' | translate}}</ng-container>\n        <it-icon *ngIf=\"!isTextLinks\" name=\"chevron-right\" color=\"primary\"></it-icon>\n      </a>\n    </li>\n  </ul>\n\n  <it-dropdown *ngIf=\"currentChanger !== undefined\" id=\"pager-changer\">\n    <span button>{{currentChanger}} / {{'it.core.page' | translate | lowercase}}</span>\n    <ng-container list>\n      <it-dropdown-item *ngFor=\"let value of changerValues\" href=\"#\" externalLink=\"true\"\n                        (click)=\"changerChange($event, value)\">\n        {{value}} / {{'it.core.page' | translate | lowercase}}\n      </it-dropdown-item>\n    </ng-container>\n  </it-dropdown>\n\n  <it-input *ngIf=\"isShowJumpToPage\" id=\"jump-to-page\" type=\"number\" [min]=\"1\" [max]=\"pageNumbers\"\n            [label]=\"('it.core.go-to' | translate) + '...'\" [formControl]=\"jumpToPage\"></it-input>\n\n  <p [class.d-none]=\"!totalNumberText.hasChildNodes()\" #totalNumberText>\n    <ng-content></ng-content>\n  </p>\n</nav>\n"]}
|
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
import { Directive, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { isTrueBooleanInput } from '../../../utils/boolean-input';
|
|
3
|
+
import { Popover } from 'bootstrap-italia';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class PopoverDirective {
|
|
6
|
+
constructor(_elementRef) {
|
|
7
|
+
this._elementRef = _elementRef;
|
|
8
|
+
/**
|
|
9
|
+
* This event fires immediately when the show method is called.
|
|
10
|
+
*/
|
|
11
|
+
this.onShow = new EventEmitter();
|
|
12
|
+
/**
|
|
13
|
+
* This event is triggered when the tooltip has been made visible to the user (it will wait for the CSS transitions to complete).
|
|
14
|
+
*/
|
|
15
|
+
this.onShown = new EventEmitter();
|
|
16
|
+
/**
|
|
17
|
+
* This event fires immediately when the hide method is called.
|
|
18
|
+
*/
|
|
19
|
+
this.onHide = new EventEmitter();
|
|
20
|
+
/**
|
|
21
|
+
* This event is raised when the tooltip has finished being hidden from the user (it will wait for the CSS transitions to complete).
|
|
22
|
+
*/
|
|
23
|
+
this.onHidden = new EventEmitter();
|
|
24
|
+
/**
|
|
25
|
+
* This event fires after the show event when the tooltip template has been added to the DOM.
|
|
26
|
+
*/
|
|
27
|
+
this.onInserted = new EventEmitter();
|
|
28
|
+
this.element = this._elementRef.nativeElement;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Define the popover content
|
|
32
|
+
* @param content the popover content
|
|
33
|
+
*/
|
|
34
|
+
set content(content) {
|
|
35
|
+
this.element.setAttribute('data-bs-content', content);
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Define the popover title
|
|
39
|
+
* @param title the popover title
|
|
40
|
+
*/
|
|
41
|
+
set title(title) {
|
|
42
|
+
if (title) {
|
|
43
|
+
this.element.setAttribute('title', title);
|
|
44
|
+
this.element.setAttribute('data-bs-original-title', title);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Define the popover placement
|
|
49
|
+
* @param placement
|
|
50
|
+
*/
|
|
51
|
+
set placement(placement) {
|
|
52
|
+
this.element.setAttribute('data-bs-placement', placement);
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Appends the popover to a specific element.
|
|
56
|
+
* @param container
|
|
57
|
+
*/
|
|
58
|
+
set container(container) {
|
|
59
|
+
if (container) {
|
|
60
|
+
this.element.setAttribute('data-container', container);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Indicates whether the title contains html
|
|
65
|
+
* @param html true if contain html
|
|
66
|
+
*/
|
|
67
|
+
set html(html) {
|
|
68
|
+
this.element.setAttribute('data-bs-html', isTrueBooleanInput(html) ? 'true' : 'false');
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* How popover is triggered
|
|
72
|
+
* - 'hover': To open the Popover on hover of the mouse over the element
|
|
73
|
+
* - 'focus': To ignore popovers on the user's next click of an element other than the toggle element.
|
|
74
|
+
* @param trigger
|
|
75
|
+
*/
|
|
76
|
+
set hover(trigger) {
|
|
77
|
+
if (trigger) {
|
|
78
|
+
this.element.setAttribute('data-bs-trigger', trigger);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
ngAfterViewInit() {
|
|
82
|
+
this.element.setAttribute('data-bs-toggle', 'popover');
|
|
83
|
+
this.popover = Popover.getOrCreateInstance(this.element);
|
|
84
|
+
this.element.addEventListener('show.bs.popover', event => this.onShow.emit(event));
|
|
85
|
+
this.element.addEventListener('shown.bs.popover', event => this.onShown.emit(event));
|
|
86
|
+
this.element.addEventListener('hide.bs.popover', event => this.onHide.emit(event));
|
|
87
|
+
this.element.addEventListener('hidden.bs.popover', event => this.onHidden.emit(event));
|
|
88
|
+
this.element.addEventListener('inserted.bs.popover', event => this.onInserted.emit(event));
|
|
89
|
+
}
|
|
90
|
+
ngOnDestroy() {
|
|
91
|
+
this.dispose();
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Shows the popover of an item.
|
|
95
|
+
*/
|
|
96
|
+
show() {
|
|
97
|
+
this.popover?.show();
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Hide the popover of an element.
|
|
101
|
+
*/
|
|
102
|
+
hide() {
|
|
103
|
+
this.popover?.hide();
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Activate / Deactivate the popover of an element
|
|
107
|
+
*/
|
|
108
|
+
toggle() {
|
|
109
|
+
this.popover?.toggle();
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Hides and destroys the popover of an element.
|
|
113
|
+
*/
|
|
114
|
+
dispose() {
|
|
115
|
+
this.popover?.dispose();
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Gives the popover of an element a chance to be shown.
|
|
119
|
+
*/
|
|
120
|
+
enable() {
|
|
121
|
+
this.popover?.enable();
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Removes the ability to show the popover of an element.
|
|
125
|
+
*/
|
|
126
|
+
disable() {
|
|
127
|
+
this.popover?.disable();
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Toggles the possibility that the popover of an element is shown or hidden.
|
|
131
|
+
*/
|
|
132
|
+
toggleEnabled() {
|
|
133
|
+
this.popover?.disable();
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Updates the position of an element's popover.
|
|
137
|
+
*/
|
|
138
|
+
update() {
|
|
139
|
+
this.popover?.disable();
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
PopoverDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: PopoverDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
143
|
+
PopoverDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.0.4", type: PopoverDirective, selector: "[itPopover]", inputs: { content: ["itPopover", "content"], title: ["popoverTitle", "title"], placement: ["popoverPlacement", "placement"], container: ["popoverContainer", "container"], html: ["popoverHtml", "html"], hover: ["popoverTrigger", "hover"] }, outputs: { onShow: "onShow", onShown: "onShown", onHide: "onHide", onHidden: "onHidden", onInserted: "onInserted" }, exportAs: ["itPopover"], ngImport: i0 });
|
|
144
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: PopoverDirective, decorators: [{
|
|
145
|
+
type: Directive,
|
|
146
|
+
args: [{
|
|
147
|
+
selector: '[itPopover]',
|
|
148
|
+
exportAs: 'itPopover'
|
|
149
|
+
}]
|
|
150
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { content: [{
|
|
151
|
+
type: Input,
|
|
152
|
+
args: ['itPopover']
|
|
153
|
+
}], title: [{
|
|
154
|
+
type: Input,
|
|
155
|
+
args: ['popoverTitle']
|
|
156
|
+
}], placement: [{
|
|
157
|
+
type: Input,
|
|
158
|
+
args: ['popoverPlacement']
|
|
159
|
+
}], container: [{
|
|
160
|
+
type: Input,
|
|
161
|
+
args: ['popoverContainer']
|
|
162
|
+
}], html: [{
|
|
163
|
+
type: Input,
|
|
164
|
+
args: ['popoverHtml']
|
|
165
|
+
}], hover: [{
|
|
166
|
+
type: Input,
|
|
167
|
+
args: ['popoverTrigger']
|
|
168
|
+
}], onShow: [{
|
|
169
|
+
type: Output
|
|
170
|
+
}], onShown: [{
|
|
171
|
+
type: Output
|
|
172
|
+
}], onHide: [{
|
|
173
|
+
type: Output
|
|
174
|
+
}], onHidden: [{
|
|
175
|
+
type: Output
|
|
176
|
+
}], onInserted: [{
|
|
177
|
+
type: Output
|
|
178
|
+
}] } });
|
|
179
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.directive.js","sourceRoot":"","sources":["../../../../../../../projects/design-angular-kit/src/lib/components/core/popover/popover.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, EventEmitter, Input, OnDestroy, Output } from '@angular/core';\nimport { ElementPlacement } from '../../../interfaces/core';\nimport { BooleanInput, isTrueBooleanInput } from '../../../utils/boolean-input';\nimport { Popover } from 'bootstrap-italia';\n\n@Directive({\n  selector: '[itPopover]',\n  exportAs: 'itPopover'\n})\nexport class PopoverDirective implements AfterViewInit, OnDestroy {\n\n  /**\n   * Define the popover content\n   * @param content the popover content\n   */\n  @Input('itPopover') set content(content: string) {\n    this.element.setAttribute('data-bs-content', content);\n  }\n\n  /**\n   * Define the popover title\n   * @param title the popover title\n   */\n  @Input('popoverTitle') set title(title: string | undefined) {\n    if (title) {\n      this.element.setAttribute('title', title);\n      this.element.setAttribute('data-bs-original-title', title);\n    }\n  }\n\n\n  /**\n   * Define the popover placement\n   * @param placement\n   */\n  @Input('popoverPlacement') set placement(placement: ElementPlacement) {\n    this.element.setAttribute('data-bs-placement', placement);\n  }\n\n  /**\n   * Appends the popover to a specific element.\n   * @param container\n   */\n  @Input('popoverContainer') set container(container: 'body' | string | undefined) {\n    if (container) {\n      this.element.setAttribute('data-container', container);\n    }\n  }\n\n  /**\n   * Indicates whether the title contains html\n   * @param html true if contain html\n   */\n  @Input('popoverHtml') set html(html: BooleanInput) {\n    this.element.setAttribute('data-bs-html', isTrueBooleanInput(html) ? 'true' : 'false');\n  }\n\n  /**\n   * How popover is triggered\n   * - 'hover': To open the Popover on hover of the mouse over the element\n   * - 'focus': To ignore popovers on the user's next click of an element other than the toggle element.\n   * @param trigger\n   */\n  @Input('popoverTrigger') set hover(trigger: 'click' | 'hover' | 'focus' | 'manual' | undefined) {\n    if (trigger) {\n      this.element.setAttribute('data-bs-trigger', trigger);\n    }\n  }\n\n  /**\n   * This event fires immediately when the show method is called.\n   */\n  @Output() onShow: EventEmitter<Event> = new EventEmitter();\n\n  /**\n   * This event is triggered when the tooltip has been made visible to the user (it will wait for the CSS transitions to complete).\n   */\n  @Output() onShown: EventEmitter<Event> = new EventEmitter();\n\n  /**\n   * This event fires immediately when the hide method is called.\n   */\n  @Output() onHide: EventEmitter<Event> = new EventEmitter();\n\n  /**\n   * This event is raised when the tooltip has finished being hidden from the user (it will wait for the CSS transitions to complete).\n   */\n  @Output() onHidden: EventEmitter<Event> = new EventEmitter();\n\n  /**\n   * This event fires after the show event when the tooltip template has been added to the DOM.\n   */\n  @Output() onInserted: EventEmitter<Event> = new EventEmitter();\n\n  private readonly element: HTMLElement;\n  private popover?: Popover;\n\n  constructor(\n    private readonly _elementRef: ElementRef\n  ) {\n    this.element = this._elementRef.nativeElement;\n  }\n\n  ngAfterViewInit(): void {\n    this.element.setAttribute('data-bs-toggle', 'popover');\n    this.popover = Popover.getOrCreateInstance(this.element);\n\n    this.element.addEventListener('show.bs.popover', event => this.onShow.emit(event));\n    this.element.addEventListener('shown.bs.popover', event => this.onShown.emit(event));\n    this.element.addEventListener('hide.bs.popover', event => this.onHide.emit(event));\n    this.element.addEventListener('hidden.bs.popover', event => this.onHidden.emit(event));\n    this.element.addEventListener('inserted.bs.popover', event => this.onInserted.emit(event));\n  }\n\n  ngOnDestroy(): void {\n    this.dispose();\n  }\n\n  /**\n   * Shows the popover of an item.\n   */\n  public show(): void {\n    this.popover?.show();\n  }\n\n  /**\n   * Hide the popover of an element.\n   */\n  public hide(): void {\n    this.popover?.hide();\n  }\n\n  /**\n   * Activate / Deactivate the popover of an element\n   */\n  public toggle(): void {\n    this.popover?.toggle();\n  }\n\n  /**\n   * Hides and destroys the popover of an element.\n   */\n  public dispose(): void {\n    this.popover?.dispose();\n  }\n\n  /**\n   * Gives the popover of an element a chance to be shown.\n   */\n  public enable(): void {\n    this.popover?.enable();\n  }\n\n  /**\n   * Removes the ability to show the popover of an element.\n   */\n  public disable(): void {\n    this.popover?.disable();\n  }\n\n  /**\n   * Toggles the possibility that the popover of an element is shown or hidden.\n   */\n  public toggleEnabled(): void {\n    this.popover?.disable();\n  }\n\n  /**\n   * Updates the position of an element's popover.\n   */\n  public update(): void {\n    this.popover?.disable();\n  }\n\n}\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { isTrueBooleanInput } from '../../../utils/boolean-input';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@ngx-translate/core";
|
|
6
|
+
export class ProgressBarComponent {
|
|
7
|
+
/**
|
|
8
|
+
* Return the background color
|
|
9
|
+
*/
|
|
10
|
+
get bgColor() {
|
|
11
|
+
if (!this.color) {
|
|
12
|
+
return '';
|
|
13
|
+
}
|
|
14
|
+
return ` bg-${this.color}`;
|
|
15
|
+
}
|
|
16
|
+
get isIndeterminate() {
|
|
17
|
+
return isTrueBooleanInput(this.indeterminate);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
ProgressBarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ProgressBarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
21
|
+
ProgressBarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: ProgressBarComponent, selector: "it-progress-bar[value]", inputs: { value: "value", showLabel: "showLabel", indeterminate: "indeterminate", color: "color" }, ngImport: i0, template: "<div class=\"progress-bar-wrapper\">\n <div *ngIf=\"showLabel\" class=\"progress-bar-label\">\n <span class=\"visually-hidden\">{{'it.core.progress'|translate}} </span>{{value}}%\n </div>\n <div class=\"progress\"\n [class.progress-color]=\"!!color\"\n [class.progress-indeterminate]=\"isIndeterminate\">\n\n <div *ngIf=\"isIndeterminate; else determinate\" class=\"progress-bar{{bgColor}}\" role=\"progressbar\"></div>\n <ng-template #determinate>\n <div class=\"progress-bar{{bgColor}}\" role=\"progressbar\" [style.width.%]=\"value\"\n [attr.aria-valuenow]=\"value\" aria-valuemin=\"0\" aria-valuemax=\"100\"></div>\n </ng-template>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ProgressBarComponent, decorators: [{
|
|
23
|
+
type: Component,
|
|
24
|
+
args: [{ selector: 'it-progress-bar[value]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"progress-bar-wrapper\">\n <div *ngIf=\"showLabel\" class=\"progress-bar-label\">\n <span class=\"visually-hidden\">{{'it.core.progress'|translate}} </span>{{value}}%\n </div>\n <div class=\"progress\"\n [class.progress-color]=\"!!color\"\n [class.progress-indeterminate]=\"isIndeterminate\">\n\n <div *ngIf=\"isIndeterminate; else determinate\" class=\"progress-bar{{bgColor}}\" role=\"progressbar\"></div>\n <ng-template #determinate>\n <div class=\"progress-bar{{bgColor}}\" role=\"progressbar\" [style.width.%]=\"value\"\n [attr.aria-valuenow]=\"value\" aria-valuemin=\"0\" aria-valuemax=\"100\"></div>\n </ng-template>\n </div>\n</div>\n" }]
|
|
25
|
+
}], propDecorators: { value: [{
|
|
26
|
+
type: Input
|
|
27
|
+
}], showLabel: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}], indeterminate: [{
|
|
30
|
+
type: Input
|
|
31
|
+
}], color: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}] } });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MtYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9wcm9ncmVzcy1iYXIvcHJvZ3Jlc3MtYmFyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9wcm9ncmVzcy1iYXIvcHJvZ3Jlc3MtYmFyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFFLE9BQU8sRUFBZ0Isa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7OztBQU9oRixNQUFNLE9BQU8sb0JBQW9CO0lBc0IvQjs7T0FFRztJQUNILElBQUksT0FBTztRQUNULElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2YsT0FBTyxFQUFFLENBQUM7U0FDWDtRQUVELE9BQU8sT0FBTyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDN0IsQ0FBQztJQUVELElBQUksZUFBZTtRQUNqQixPQUFPLGtCQUFrQixDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztJQUNoRCxDQUFDOztpSEFuQ1Usb0JBQW9CO3FHQUFwQixvQkFBb0Isa0tDVGpDLDJyQkFlQTsyRkROYSxvQkFBb0I7a0JBTGhDLFNBQVM7K0JBQ0Usd0JBQXdCLG1CQUVqQix1QkFBdUIsQ0FBQyxNQUFNOzhCQU90QyxLQUFLO3NCQUFiLEtBQUs7Z0JBS0csU0FBUztzQkFBakIsS0FBSztnQkFLRyxhQUFhO3NCQUFyQixLQUFLO2dCQUtHLEtBQUs7c0JBQWIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQcm9ncmVzc0JhckNvbG9yIH0gZnJvbSAnLi4vLi4vLi4vaW50ZXJmYWNlcy9jb3JlJztcbmltcG9ydCB7IEJvb2xlYW5JbnB1dCwgaXNUcnVlQm9vbGVhbklucHV0IH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvYm9vbGVhbi1pbnB1dCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2l0LXByb2dyZXNzLWJhclt2YWx1ZV0nLFxuICB0ZW1wbGF0ZVVybDogJy4vcHJvZ3Jlc3MtYmFyLmNvbXBvbmVudC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgUHJvZ3Jlc3NCYXJDb21wb25lbnQge1xuXG4gIC8qKlxuICAgKiBUaGUgcHJvZ3Jlc3MgYmFyIHZhbHVlIFswLCAxMDBdXG4gICAqL1xuICBASW5wdXQoKSB2YWx1ZSE6IG51bWJlcjtcblxuICAvKipcbiAgICogU2hvdyB0aGUgcHJvZ3Jlc3MgbGFiZWxcbiAgICovXG4gIEBJbnB1dCgpIHNob3dMYWJlbD86IEJvb2xlYW5JbnB1dDtcblxuICAvKipcbiAgICogU2hvdyB0aGUgcHJvZ3Jlc3MgYXMgaW5kZXRlcm1pbmF0ZVxuICAgKi9cbiAgQElucHV0KCkgaW5kZXRlcm1pbmF0ZT86IEJvb2xlYW5JbnB1dDtcblxuICAvKipcbiAgICogVGhlIHByb2dyZXNzIGJhciBjb2xvclxuICAgKi9cbiAgQElucHV0KCkgY29sb3I/OiBQcm9ncmVzc0JhckNvbG9yO1xuXG4gIC8qKlxuICAgKiBSZXR1cm4gdGhlIGJhY2tncm91bmQgY29sb3JcbiAgICovXG4gIGdldCBiZ0NvbG9yKCk6IHN0cmluZyB7XG4gICAgaWYgKCF0aGlzLmNvbG9yKSB7XG4gICAgICByZXR1cm4gJyc7XG4gICAgfVxuXG4gICAgcmV0dXJuIGAgYmctJHt0aGlzLmNvbG9yfWA7XG4gIH1cblxuICBnZXQgaXNJbmRldGVybWluYXRlKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBpc1RydWVCb29sZWFuSW5wdXQodGhpcy5pbmRldGVybWluYXRlKTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInByb2dyZXNzLWJhci13cmFwcGVyXCI+XG4gIDxkaXYgKm5nSWY9XCJzaG93TGFiZWxcIiBjbGFzcz1cInByb2dyZXNzLWJhci1sYWJlbFwiPlxuICAgIDxzcGFuIGNsYXNzPVwidmlzdWFsbHktaGlkZGVuXCI+e3snaXQuY29yZS5wcm9ncmVzcyd8dHJhbnNsYXRlfX0gPC9zcGFuPnt7dmFsdWV9fSVcbiAgPC9kaXY+XG4gIDxkaXYgY2xhc3M9XCJwcm9ncmVzc1wiXG4gICAgICAgW2NsYXNzLnByb2dyZXNzLWNvbG9yXT1cIiEhY29sb3JcIlxuICAgICAgIFtjbGFzcy5wcm9ncmVzcy1pbmRldGVybWluYXRlXT1cImlzSW5kZXRlcm1pbmF0ZVwiPlxuXG4gICAgPGRpdiAqbmdJZj1cImlzSW5kZXRlcm1pbmF0ZTsgZWxzZSBkZXRlcm1pbmF0ZVwiIGNsYXNzPVwicHJvZ3Jlc3MtYmFye3tiZ0NvbG9yfX1cIiByb2xlPVwicHJvZ3Jlc3NiYXJcIj48L2Rpdj5cbiAgICA8bmctdGVtcGxhdGUgI2RldGVybWluYXRlPlxuICAgICAgPGRpdiBjbGFzcz1cInByb2dyZXNzLWJhcnt7YmdDb2xvcn19XCIgcm9sZT1cInByb2dyZXNzYmFyXCIgW3N0eWxlLndpZHRoLiVdPVwidmFsdWVcIlxuICAgICAgICAgICBbYXR0ci5hcmlhLXZhbHVlbm93XT1cInZhbHVlXCIgYXJpYS12YWx1ZW1pbj1cIjBcIiBhcmlhLXZhbHVlbWF4PVwiMTAwXCI+PC9kaXY+XG4gICAgPC9uZy10ZW1wbGF0ZT5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { isTrueBooleanInput } from '../../../utils/boolean-input';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "../progress-bar/progress-bar.component";
|
|
6
|
+
export class ProgressButtonComponent {
|
|
7
|
+
get isProgress() {
|
|
8
|
+
return typeof this.progress === 'number' || isTrueBooleanInput(this.progress);
|
|
9
|
+
}
|
|
10
|
+
get progressValue() {
|
|
11
|
+
return typeof this.progress === 'number' ? this.progress : 0;
|
|
12
|
+
}
|
|
13
|
+
get isIndeterminate() {
|
|
14
|
+
return typeof this.progress !== 'number' && isTrueBooleanInput(this.progress);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
ProgressButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ProgressButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
+
ProgressButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: ProgressButtonComponent, selector: "button[itButton][progress]", inputs: { progress: "progress", progressColor: "progressColor" }, ngImport: i0, template: "<ng-content></ng-content>\n\n<it-progress-bar *ngIf=\"isProgress\"\n [value]=\"progressValue\"\n [indeterminate]=\"isIndeterminate\"\n [color]=\"progressColor\"></it-progress-bar>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ProgressBarComponent, selector: "it-progress-bar[value]", inputs: ["value", "showLabel", "indeterminate", "color"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: ProgressButtonComponent, decorators: [{
|
|
20
|
+
type: Component,
|
|
21
|
+
args: [{ selector: 'button[itButton][progress]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>\n\n<it-progress-bar *ngIf=\"isProgress\"\n [value]=\"progressValue\"\n [indeterminate]=\"isIndeterminate\"\n [color]=\"progressColor\"></it-progress-bar>\n" }]
|
|
22
|
+
}], propDecorators: { progress: [{
|
|
23
|
+
type: Input
|
|
24
|
+
}], progressColor: [{
|
|
25
|
+
type: Input
|
|
26
|
+
}] } });
|
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9wcm9ncmVzcy1idXR0b24vcHJvZ3Jlc3MtYnV0dG9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1hbmd1bGFyLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9wcm9ncmVzcy1idXR0b24vcHJvZ3Jlc3MtYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFFLE9BQU8sRUFBZ0Isa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7OztBQVFoRixNQUFNLE9BQU8sdUJBQXVCO0lBZ0JsQyxJQUFJLFVBQVU7UUFDWixPQUFPLE9BQU8sSUFBSSxDQUFDLFFBQVEsS0FBSyxRQUFRLElBQUksa0JBQWtCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ2hGLENBQUM7SUFFRCxJQUFJLGFBQWE7UUFDZixPQUFPLE9BQU8sSUFBSSxDQUFDLFFBQVEsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBRUQsSUFBSSxlQUFlO1FBQ2pCLE9BQU8sT0FBTyxJQUFJLENBQUMsUUFBUSxLQUFLLFFBQVEsSUFBSSxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDaEYsQ0FBQzs7b0hBMUJVLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLG9JQ1RwQyx1T0FNQTsyRkRHYSx1QkFBdUI7a0JBTG5DLFNBQVM7K0JBQ0UsNEJBQTRCLG1CQUVyQix1QkFBdUIsQ0FBQyxNQUFNOzhCQVd0QyxRQUFRO3NCQUFoQixLQUFLO2dCQUtHLGFBQWE7c0JBQXJCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQm9vbGVhbklucHV0LCBpc1RydWVCb29sZWFuSW5wdXQgfSBmcm9tICcuLi8uLi8uLi91dGlscy9ib29sZWFuLWlucHV0JztcbmltcG9ydCB7IFByb2dyZXNzQmFyQ29sb3IgfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdidXR0b25baXRCdXR0b25dW3Byb2dyZXNzXScsXG4gIHRlbXBsYXRlVXJsOiAnLi9wcm9ncmVzcy1idXR0b24uY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBQcm9ncmVzc0J1dHRvbkNvbXBvbmVudCB7XG5cbiAgLyoqXG4gICAqIEJlaGF2aW9yIG9mIHRoZSBwcm9ncmVzcyBiYXJcbiAgICogLSA8Yj50cnVlPC9iPjogU2hvdyBpbmRldGVybWluYXRlIHByb2dyZXNzIGJhclxuICAgKiAtIDxiPmZhbHNlPC9iPiBvciA8Yj51bmRlZmluZWQ8L2I+OiBIaWRlIHByb2dyZXNzIGJhclxuICAgKiAtIDxiPm51bWJlcjwvYj4gWzAsIDEwMF06IEFzc2lnbiBhIHNwZWNpZmljIHZhbHVlIHRvIHRoZSBwcm9ncmVzcyBiYXJcbiAgICogQGRlZmF1bHQgdW5kZWZpbmVkXG4gICAqL1xuICBASW5wdXQoKSBwcm9ncmVzcz86IG51bWJlciB8IEJvb2xlYW5JbnB1dDtcblxuICAvKipcbiAgICogVGhlIHByb2dyZXNzIGJhciBjb2xvclxuICAgKi9cbiAgQElucHV0KCkgcHJvZ3Jlc3NDb2xvcj86IFByb2dyZXNzQmFyQ29sb3I7XG5cbiAgZ2V0IGlzUHJvZ3Jlc3MoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHR5cGVvZiB0aGlzLnByb2dyZXNzID09PSAnbnVtYmVyJyB8fCBpc1RydWVCb29sZWFuSW5wdXQodGhpcy5wcm9ncmVzcyk7XG4gIH1cblxuICBnZXQgcHJvZ3Jlc3NWYWx1ZSgpOiBudW1iZXIge1xuICAgIHJldHVybiB0eXBlb2YgdGhpcy5wcm9ncmVzcyA9PT0gJ251bWJlcicgPyB0aGlzLnByb2dyZXNzIDogMDtcbiAgfVxuXG4gIGdldCBpc0luZGV0ZXJtaW5hdGUoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHR5cGVvZiB0aGlzLnByb2dyZXNzICE9PSAnbnVtYmVyJyAmJiBpc1RydWVCb29sZWFuSW5wdXQodGhpcy5wcm9ncmVzcyk7XG4gIH1cblxufVxuIiwiPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuXG48aXQtcHJvZ3Jlc3MtYmFyICpuZ0lmPVwiaXNQcm9ncmVzc1wiXG4gICAgICAgICAgICAgICAgIFt2YWx1ZV09XCJwcm9ncmVzc1ZhbHVlXCJcbiAgICAgICAgICAgICAgICAgW2luZGV0ZXJtaW5hdGVdPVwiaXNJbmRldGVybWluYXRlXCJcbiAgICAgICAgICAgICAgICAgW2NvbG9yXT1cInByb2dyZXNzQ29sb3JcIj48L2l0LXByb2dyZXNzLWJhcj5cbiJdfQ==
|