@sumaris-net/ngx-components 18.23.49 → 18.23.50
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/doc/changelog.md +4 -0
- package/esm2022/public_api.mjs +2 -1
- package/esm2022/src/app/admin/users/users.mjs +25 -22
- package/esm2022/src/app/core/account/new-token.form.mjs +12 -9
- package/esm2022/src/app/core/account/token.table.mjs +14 -11
- package/esm2022/src/app/core/form/array/testing/form-array.test.mjs +9 -6
- package/esm2022/src/app/core/form/buttons/form-buttons-bar.component.mjs +8 -5
- package/esm2022/src/app/core/form/list/list.form.mjs +8 -5
- package/esm2022/src/app/core/form/properties/properties.form.mjs +12 -9
- package/esm2022/src/app/core/form/properties/properties.table.mjs +15 -12
- package/esm2022/src/app/core/form/text-popover/text-popover.component.mjs +10 -7
- package/esm2022/src/app/core/home/home.mjs +21 -18
- package/esm2022/src/app/core/menu/menu.component.mjs +10 -7
- package/esm2022/src/app/core/settings/settings.page.mjs +10 -7
- package/esm2022/src/app/core/table/column/actions-column.component.mjs +8 -5
- package/esm2022/src/app/core/table/column/nav-actions-column.component.mjs +9 -6
- package/esm2022/src/app/core/table/testing/table.testing.mjs +27 -23
- package/esm2022/src/app/core/table/testing/table2.testing.mjs +25 -22
- package/esm2022/src/app/shared/constants.mjs +3 -1
- package/esm2022/src/app/shared/directives/autotooltip.directive.mjs +35 -0
- package/esm2022/src/app/shared/directives/directives.module.mjs +33 -4
- package/esm2022/src/app/shared/image/gallery/image-gallery.component.mjs +15 -12
- package/esm2022/src/app/shared/material/autocomplete/material.autocomplete.mjs +13 -11
- package/esm2022/src/app/shared/material/autocomplete/material.autocomplete.module.mjs +4 -2
- package/esm2022/src/app/shared/material/boolean/boolean.module.mjs +5 -2
- package/esm2022/src/app/shared/material/boolean/material.boolean.mjs +9 -6
- package/esm2022/src/app/shared/material/boolean/testing/boolean.test.page.mjs +15 -4
- package/esm2022/src/app/shared/material/chips/chips.module.mjs +5 -2
- package/esm2022/src/app/shared/material/chips/material.chips.mjs +14 -12
- package/esm2022/src/app/shared/named-filter/named-filter-selector.component.mjs +8 -5
- package/esm2022/src/app/shared/storage/storage-explorer.component.mjs +11 -9
- package/esm2022/src/app/social/feed/feed.component.mjs +15 -12
- package/esm2022/src/app/social/job/progression/job-progression.icon.mjs +11 -8
- package/esm2022/src/app/social/job/progression/job-progression.list.mjs +12 -9
- package/esm2022/src/app/social/user-event/notification/user-event-notification.icon.mjs +12 -8
- package/esm2022/src/app/social/user-event/notification/user-event-notification.list.mjs +12 -9
- package/esm2022/src/app/social/user-event/notification/user-event-notification.modal.mjs +9 -6
- package/fesm2022/sumaris-net.ngx-components.mjs +194 -89
- package/fesm2022/sumaris-net.ngx-components.mjs.map +1 -1
- package/package.json +1 -1
- package/public_api.d.ts +1 -0
- package/src/app/admin/users/users.d.ts +1 -0
- package/src/app/core/account/new-token.form.d.ts +1 -0
- package/src/app/core/account/token.table.d.ts +1 -0
- package/src/app/core/form/array/testing/form-array.test.d.ts +1 -0
- package/src/app/core/form/buttons/form-buttons-bar.component.d.ts +1 -0
- package/src/app/core/form/list/list.form.d.ts +1 -0
- package/src/app/core/form/properties/properties.form.d.ts +1 -0
- package/src/app/core/form/properties/properties.table.d.ts +1 -0
- package/src/app/core/form/text-popover/text-popover.component.d.ts +1 -0
- package/src/app/core/home/home.d.ts +1 -0
- package/src/app/core/menu/menu.component.d.ts +1 -0
- package/src/app/core/settings/settings.page.d.ts +1 -0
- package/src/app/core/table/column/actions-column.component.d.ts +1 -0
- package/src/app/core/table/column/nav-actions-column.component.d.ts +1 -0
- package/src/app/core/table/testing/table.testing.d.ts +1 -0
- package/src/app/core/table/testing/table2.testing.d.ts +1 -0
- package/src/app/shared/constants.d.ts +2 -0
- package/src/app/shared/directives/autotooltip.directive.d.ts +14 -0
- package/src/app/shared/directives/directives.module.d.ts +4 -3
- package/src/app/shared/image/gallery/image-gallery.component.d.ts +1 -0
- package/src/app/shared/material/autocomplete/material.autocomplete.d.ts +1 -0
- package/src/app/shared/material/autocomplete/material.autocomplete.module.d.ts +2 -1
- package/src/app/shared/material/boolean/boolean.module.d.ts +2 -1
- package/src/app/shared/material/boolean/material.boolean.d.ts +1 -0
- package/src/app/shared/material/boolean/testing/boolean.test.page.d.ts +5 -0
- package/src/app/shared/material/chips/chips.module.d.ts +2 -1
- package/src/app/shared/material/chips/material.chips.d.ts +1 -0
- package/src/app/shared/named-filter/named-filter-selector.component.d.ts +1 -0
- package/src/app/shared/storage/storage-explorer.component.d.ts +1 -0
- package/src/app/social/feed/feed.component.d.ts +1 -0
- package/src/app/social/job/progression/job-progression.icon.d.ts +1 -0
- package/src/app/social/job/progression/job-progression.list.d.ts +1 -0
- package/src/app/social/user-event/notification/user-event-notification.icon.d.ts +1 -0
- package/src/app/social/user-event/notification/user-event-notification.list.d.ts +2 -0
- package/src/app/social/user-event/notification/user-event-notification.modal.d.ts +1 -0
- package/src/assets/manifest.json +1 -1
|
@@ -1,11 +1,13 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Inject, Input, Optional, ViewChild } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, inject, Inject, Input, Optional, ViewChild } from '@angular/core';
|
|
2
2
|
import { APP_USER_EVENT_SERVICE } from '../user-event.service';
|
|
3
|
+
import { SHOW_TOOLTIP } from '../../../shared/constants';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "../../../core/services/local-settings.service";
|
|
5
6
|
import * as i2 from "@ionic/angular";
|
|
6
7
|
import * as i3 from "@ngx-translate/core";
|
|
7
|
-
import * as i4 from "
|
|
8
|
-
import * as i5 from "
|
|
8
|
+
import * as i4 from "@angular/material/tooltip";
|
|
9
|
+
import * as i5 from "./user-event-notification.list";
|
|
10
|
+
import * as i6 from "@angular/common";
|
|
9
11
|
export class UserEventNotificationModal {
|
|
10
12
|
cd;
|
|
11
13
|
settings;
|
|
@@ -24,6 +26,7 @@ export class UserEventNotificationModal {
|
|
|
24
26
|
mobile;
|
|
25
27
|
debug = false;
|
|
26
28
|
list;
|
|
29
|
+
showTooltip = inject(SHOW_TOOLTIP);
|
|
27
30
|
constructor(cd, settings, modalController, userEventService) {
|
|
28
31
|
this.cd = cd;
|
|
29
32
|
this.settings = settings;
|
|
@@ -42,11 +45,11 @@ export class UserEventNotificationModal {
|
|
|
42
45
|
this.cd.markForCheck();
|
|
43
46
|
}
|
|
44
47
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: UserEventNotificationModal, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.LocalSettingsService }, { token: i2.ModalController }, { token: APP_USER_EVENT_SERVICE, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
45
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: UserEventNotificationModal, selector: "app-user-event-notification-modal", inputs: { titleI18n: "titleI18n", sortBy: "sortBy", sortDirection: "sortDirection", filter: "filter", enableInfiniteScroll: "enableInfiniteScroll", infiniteScrollThreshold: "infiniteScrollThreshold", headerActions: "headerActions", footerActions: "footerActions", pageSize: "pageSize", mobile: "mobile", debug: "debug" }, viewQueries: [{ propertyName: "list", first: true, predicate: ["list"], descendants: true, static: true }], ngImport: i0, template: "<ion-header>\n <ion-toolbar color=\"secondary\">\n @if (mobile) {\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"close()\" visible-xs visible-sm>\n <ion-icon slot=\"icon-only\" name=\"arrow-back\"></ion-icon>\n </ion-button>\n </ion-buttons>\n }\n\n <ion-title>\n {{ titleI18n | translate }}\n @if (itemCount$ | async; as count) {\n <i>({{ count }})</i>\n }\n </ion-title>\n\n <ion-buttons slot=\"end\">\n
|
|
48
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: UserEventNotificationModal, selector: "app-user-event-notification-modal", inputs: { titleI18n: "titleI18n", sortBy: "sortBy", sortDirection: "sortDirection", filter: "filter", enableInfiniteScroll: "enableInfiniteScroll", infiniteScrollThreshold: "infiniteScrollThreshold", headerActions: "headerActions", footerActions: "footerActions", pageSize: "pageSize", mobile: "mobile", debug: "debug" }, viewQueries: [{ propertyName: "list", first: true, predicate: ["list"], descendants: true, static: true }], ngImport: i0, template: "<ion-header>\n <ion-toolbar color=\"secondary\">\n @if (mobile) {\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"close()\" visible-xs visible-sm>\n <ion-icon slot=\"icon-only\" name=\"arrow-back\"></ion-icon>\n </ion-button>\n </ion-buttons>\n }\n\n <ion-title>\n {{ titleI18n | translate }}\n @if (itemCount$ | async; as count) {\n <i>({{ count }})</i>\n }\n </ion-title>\n\n <ion-buttons slot=\"end\">\n @for (action of headerActions; track $index) {\n <ion-button\n (click)=\"list.executeAction($event, action, undefined)\"\n [title]=\"!showTooltip ? (action.title || action.name | translate) : ''\"\n [matTooltip]=\"showTooltip ? (action.title || action.name | translate) : ''\"\n >\n {{ action.name | translate }}\n </ion-button>\n }\n </ion-buttons>\n </ion-toolbar>\n</ion-header>\n\n<ion-content class=\"ion-not-padding\">\n <app-user-event-notification-list\n #list\n [showHeader]=\"false\"\n [showFooter]=\"false\"\n [sortBy]=\"sortBy\"\n [sortDirection]=\"sortDirection\"\n [filter]=\"filter\"\n [enableInfiniteScroll]=\"enableInfiniteScroll\"\n [infiniteScrollThreshold]=\"infiniteScrollThreshold\"\n [mobile]=\"mobile\"\n [debug]=\"debug\"\n (dismiss)=\"close()\"\n ></app-user-event-notification-list>\n</ion-content>\n\n<ion-footer>\n <ion-toolbar>\n <ion-row>\n <ion-col>\n @if (list.hasItem$ | async) {\n <ion-button fill=\"clear\" (click)=\"list.markAllAsRead($event)\">\n <ion-label translate>SOCIAL.USER_EVENT.NOTIFICATION.READ_ALL</ion-label>\n </ion-button>\n }\n @for (action of footerActions; track $index) {\n <ion-button\n fill=\"clear\"\n (click)=\"list.executeAction($event, action, undefined)\"\n [title]=\"!showTooltip ? (action.title || action.name | translate) : ''\"\n [matTooltip]=\"showTooltip ? (action.title || action.name | translate) : ''\"\n >\n {{ action.name | translate }}\n </ion-button>\n }\n </ion-col>\n @if (!mobile) {\n <ion-col size=\"auto\">\n <ion-button fill=\"solid\" color=\"tertiary\" (click)=\"close()\" hidden-xs hidden-sm>\n {{ 'COMMON.BTN_CLOSE' | translate }}\n </ion-button>\n </ion-col>\n }\n </ion-row>\n </ion-toolbar>\n</ion-footer>\n", dependencies: [{ kind: "component", type: i2.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i2.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: i2.IonCol, selector: "ion-col", inputs: ["offset", "offsetLg", "offsetMd", "offsetSm", "offsetXl", "offsetXs", "pull", "pullLg", "pullMd", "pullSm", "pullXl", "pullXs", "push", "pushLg", "pushMd", "pushSm", "pushXl", "pushXs", "size", "sizeLg", "sizeMd", "sizeSm", "sizeXl", "sizeXs"] }, { kind: "component", type: i2.IonContent, selector: "ion-content", inputs: ["color", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: i2.IonFooter, selector: "ion-footer", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: i2.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: i2.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i2.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i2.IonRow, selector: "ion-row" }, { kind: "component", type: i2.IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { kind: "component", type: i2.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i5.UserEventNotificationList, selector: "app-user-event-notification-list", inputs: ["titleI18n", "sortBy", "sortDirection", "filter", "enableInfiniteScroll", "infiniteScrollThreshold", "headerActions", "footerActions", "showHeader", "showFooter", "mobile", "debug", "pageSize"], outputs: ["readEvent", "readEvents", "dismiss"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
46
49
|
}
|
|
47
50
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: UserEventNotificationModal, decorators: [{
|
|
48
51
|
type: Component,
|
|
49
|
-
args: [{ selector: 'app-user-event-notification-modal', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ion-header>\n <ion-toolbar color=\"secondary\">\n @if (mobile) {\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"close()\" visible-xs visible-sm>\n <ion-icon slot=\"icon-only\" name=\"arrow-back\"></ion-icon>\n </ion-button>\n </ion-buttons>\n }\n\n <ion-title>\n {{ titleI18n | translate }}\n @if (itemCount$ | async; as count) {\n <i>({{ count }})</i>\n }\n </ion-title>\n\n <ion-buttons slot=\"end\">\n
|
|
52
|
+
args: [{ selector: 'app-user-event-notification-modal', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ion-header>\n <ion-toolbar color=\"secondary\">\n @if (mobile) {\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"close()\" visible-xs visible-sm>\n <ion-icon slot=\"icon-only\" name=\"arrow-back\"></ion-icon>\n </ion-button>\n </ion-buttons>\n }\n\n <ion-title>\n {{ titleI18n | translate }}\n @if (itemCount$ | async; as count) {\n <i>({{ count }})</i>\n }\n </ion-title>\n\n <ion-buttons slot=\"end\">\n @for (action of headerActions; track $index) {\n <ion-button\n (click)=\"list.executeAction($event, action, undefined)\"\n [title]=\"!showTooltip ? (action.title || action.name | translate) : ''\"\n [matTooltip]=\"showTooltip ? (action.title || action.name | translate) : ''\"\n >\n {{ action.name | translate }}\n </ion-button>\n }\n </ion-buttons>\n </ion-toolbar>\n</ion-header>\n\n<ion-content class=\"ion-not-padding\">\n <app-user-event-notification-list\n #list\n [showHeader]=\"false\"\n [showFooter]=\"false\"\n [sortBy]=\"sortBy\"\n [sortDirection]=\"sortDirection\"\n [filter]=\"filter\"\n [enableInfiniteScroll]=\"enableInfiniteScroll\"\n [infiniteScrollThreshold]=\"infiniteScrollThreshold\"\n [mobile]=\"mobile\"\n [debug]=\"debug\"\n (dismiss)=\"close()\"\n ></app-user-event-notification-list>\n</ion-content>\n\n<ion-footer>\n <ion-toolbar>\n <ion-row>\n <ion-col>\n @if (list.hasItem$ | async) {\n <ion-button fill=\"clear\" (click)=\"list.markAllAsRead($event)\">\n <ion-label translate>SOCIAL.USER_EVENT.NOTIFICATION.READ_ALL</ion-label>\n </ion-button>\n }\n @for (action of footerActions; track $index) {\n <ion-button\n fill=\"clear\"\n (click)=\"list.executeAction($event, action, undefined)\"\n [title]=\"!showTooltip ? (action.title || action.name | translate) : ''\"\n [matTooltip]=\"showTooltip ? (action.title || action.name | translate) : ''\"\n >\n {{ action.name | translate }}\n </ion-button>\n }\n </ion-col>\n @if (!mobile) {\n <ion-col size=\"auto\">\n <ion-button fill=\"solid\" color=\"tertiary\" (click)=\"close()\" hidden-xs hidden-sm>\n {{ 'COMMON.BTN_CLOSE' | translate }}\n </ion-button>\n </ion-col>\n }\n </ion-row>\n </ion-toolbar>\n</ion-footer>\n" }]
|
|
50
53
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.LocalSettingsService }, { type: i2.ModalController }, { type: undefined, decorators: [{
|
|
51
54
|
type: Optional
|
|
52
55
|
}, {
|
|
@@ -78,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
78
81
|
type: ViewChild,
|
|
79
82
|
args: ['list', { static: true }]
|
|
80
83
|
}] } });
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci1ldmVudC1ub3RpZmljYXRpb24ubW9kYWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL3NvY2lhbC91c2VyLWV2ZW50L25vdGlmaWNhdGlvbi91c2VyLWV2ZW50LW5vdGlmaWNhdGlvbi5tb2RhbC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvc29jaWFsL3VzZXItZXZlbnQvbm90aWZpY2F0aW9uL3VzZXItZXZlbnQtbm90aWZpY2F0aW9uLm1vZGFsLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFxQixTQUFTLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQVUsUUFBUSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUsxSSxPQUFPLEVBQUUsc0JBQXNCLEVBQXFCLE1BQU0sdUJBQXVCLENBQUM7QUFJbEYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7Ozs7OztBQVl6RCxNQUFNLE9BQU8sMEJBQTBCO0lBc0J6QjtJQUNBO0lBQ0E7SUFDeUM7SUF0QjNDLFVBQVUsQ0FBcUI7SUFFaEMsU0FBUyxHQUFXLHNDQUFzQyxDQUFDO0lBQzNELE1BQU0sR0FBRyxjQUFjLENBQUM7SUFDeEIsYUFBYSxHQUFrQixNQUFNLENBQUM7SUFDdEMsTUFBTSxDQUFhO0lBQ25CLG9CQUFvQixHQUFHLElBQUksQ0FBQztJQUM1Qix1QkFBdUIsQ0FBUztJQUNoQyxhQUFhLENBQXFCO0lBQ2xDLGFBQWEsQ0FBcUI7SUFDbEMsUUFBUSxDQUFTO0lBQ2pCLE1BQU0sQ0FBVTtJQUNoQixLQUFLLEdBQUcsS0FBSyxDQUFDO0lBRWMsSUFBSSxDQUFrQztJQUUzRSxXQUFXLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBRW5DLFlBQ1ksRUFBcUIsRUFDckIsUUFBOEIsRUFDOUIsZUFBZ0MsRUFDUyxnQkFBNkQ7UUFIdEcsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFDckIsYUFBUSxHQUFSLFFBQVEsQ0FBc0I7UUFDOUIsb0JBQWUsR0FBZixlQUFlLENBQWlCO1FBQ1MscUJBQWdCLEdBQWhCLGdCQUFnQixDQUE2QztRQUVoSCxJQUFJLENBQUMsTUFBTSxHQUFHLFFBQVEsQ0FBQyxNQUFNLENBQUM7SUFDaEMsQ0FBQztJQUVELFFBQVE7UUFDTixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pDLENBQUM7SUFFUyxLQUFLO1FBQ2IsSUFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUMvQixJQUFJLENBQUMsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLENBQUM7SUFDdEMsQ0FBQztJQUVTLFlBQVk7UUFDcEIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN6QixDQUFDO3dHQXpDVSwwQkFBMEIsc0hBeUJmLHNCQUFzQjs0RkF6QmpDLDBCQUEwQix1ZkNyQnZDLGk4RUE2RUE7OzRGRHhEYSwwQkFBMEI7a0JBTHRDLFNBQVM7K0JBQ0UsbUNBQW1DLG1CQUU1Qix1QkFBdUIsQ0FBQyxNQUFNOzswQkEyQjVDLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsc0JBQXNCO3lDQXBCbkMsU0FBUztzQkFBakIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csb0JBQW9CO3NCQUE1QixLQUFLO2dCQUNHLHVCQUF1QjtzQkFBL0IsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUUrQixJQUFJO3NCQUF4QyxTQUFTO3VCQUFDLE1BQU0sRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgaW5qZWN0LCBJbmplY3QsIElucHV0LCBPbkluaXQsIE9wdGlvbmFsLCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElVc2VyRXZlbnQsIElVc2VyRXZlbnRBY3Rpb24sIElVc2VyRXZlbnRGaWx0ZXIgfSBmcm9tICcuLi91c2VyLWV2ZW50Lm1vZGVsJztcbmltcG9ydCB7IE1vZGFsQ29udHJvbGxlciB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyJztcbmltcG9ydCB7IFNvcnREaXJlY3Rpb24gfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zb3J0JztcbmltcG9ydCB7IFVzZXJFdmVudE5vdGlmaWNhdGlvbkxpc3QsIFVzZXJFdmVudE5vdGlmaWNhdGlvbkxpc3RPcHRpb25zIH0gZnJvbSAnLi91c2VyLWV2ZW50LW5vdGlmaWNhdGlvbi5saXN0JztcbmltcG9ydCB7IEFQUF9VU0VSX0VWRU5UX1NFUlZJQ0UsIElVc2VyRXZlbnRTZXJ2aWNlIH0gZnJvbSAnLi4vdXNlci1ldmVudC5zZXJ2aWNlJztcbmltcG9ydCB7IExvY2FsU2V0dGluZ3NTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vY29yZS9zZXJ2aWNlcy9sb2NhbC1zZXR0aW5ncy5zZXJ2aWNlJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgU0hPV19UT09MVElQIH0gZnJvbSAnLi4vLi4vLi4vc2hhcmVkL2NvbnN0YW50cyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVXNlckV2ZW50Tm90aWZpY2F0aW9uTW9kYWxPcHRpb25zPFxuICBFIGV4dGVuZHMgSVVzZXJFdmVudDxhbnk+ID0gSVVzZXJFdmVudDxhbnk+LFxuICBGIGV4dGVuZHMgSVVzZXJFdmVudEZpbHRlcjxhbnk+ID0gSVVzZXJFdmVudEZpbHRlcjxhbnk+LFxuPiBleHRlbmRzIFVzZXJFdmVudE5vdGlmaWNhdGlvbkxpc3RPcHRpb25zPEUsIEY+IHt9XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC11c2VyLWV2ZW50LW5vdGlmaWNhdGlvbi1tb2RhbCcsXG4gIHRlbXBsYXRlVXJsOiAnLi91c2VyLWV2ZW50LW5vdGlmaWNhdGlvbi5tb2RhbC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFVzZXJFdmVudE5vdGlmaWNhdGlvbk1vZGFsPEUgZXh0ZW5kcyBJVXNlckV2ZW50PGFueT4gPSBJVXNlckV2ZW50PGFueT4sIEYgZXh0ZW5kcyBJVXNlckV2ZW50RmlsdGVyPGFueT4gPSBJVXNlckV2ZW50RmlsdGVyPGFueT4+XG4gIGltcGxlbWVudHMgVXNlckV2ZW50Tm90aWZpY2F0aW9uTW9kYWxPcHRpb25zPEUsIEY+LCBPbkluaXRcbntcbiAgcHJvdGVjdGVkIGl0ZW1Db3VudCQ6IE9ic2VydmFibGU8bnVtYmVyPjtcblxuICBASW5wdXQoKSB0aXRsZUkxOG46IHN0cmluZyA9ICdTT0NJQUwuVVNFUl9FVkVOVC5OT1RJRklDQVRJT04uVElUTEUnO1xuICBASW5wdXQoKSBzb3J0QnkgPSAnY3JlYXRpb25EYXRlJztcbiAgQElucHV0KCkgc29ydERpcmVjdGlvbjogU29ydERpcmVjdGlvbiA9ICdkZXNjJztcbiAgQElucHV0KCkgZmlsdGVyOiBQYXJ0aWFsPEY+O1xuICBASW5wdXQoKSBlbmFibGVJbmZpbml0ZVNjcm9sbCA9IHRydWU7XG4gIEBJbnB1dCgpIGluZmluaXRlU2Nyb2xsVGhyZXNob2xkOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGhlYWRlckFjdGlvbnM6IElVc2VyRXZlbnRBY3Rpb25bXTtcbiAgQElucHV0KCkgZm9vdGVyQWN0aW9uczogSVVzZXJFdmVudEFjdGlvbltdO1xuICBASW5wdXQoKSBwYWdlU2l6ZTogbnVtYmVyO1xuICBASW5wdXQoKSBtb2JpbGU6IGJvb2xlYW47XG4gIEBJbnB1dCgpIGRlYnVnID0gZmFsc2U7XG5cbiAgQFZpZXdDaGlsZCgnbGlzdCcsIHsgc3RhdGljOiB0cnVlIH0pIGxpc3Q6IFVzZXJFdmVudE5vdGlmaWNhdGlvbkxpc3Q8RSwgRj47XG5cbiAgc2hvd1Rvb2x0aXAgPSBpbmplY3QoU0hPV19UT09MVElQKTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcm90ZWN0ZWQgY2Q6IENoYW5nZURldGVjdG9yUmVmLFxuICAgIHByb3RlY3RlZCBzZXR0aW5nczogTG9jYWxTZXR0aW5nc1NlcnZpY2UsXG4gICAgcHJvdGVjdGVkIG1vZGFsQ29udHJvbGxlcjogTW9kYWxDb250cm9sbGVyLFxuICAgIEBPcHRpb25hbCgpIEBJbmplY3QoQVBQX1VTRVJfRVZFTlRfU0VSVklDRSkgcHVibGljIHVzZXJFdmVudFNlcnZpY2U6IElVc2VyRXZlbnRTZXJ2aWNlPEUsIElVc2VyRXZlbnRGaWx0ZXI8YW55Pj5cbiAgKSB7XG4gICAgdGhpcy5tb2JpbGUgPSBzZXR0aW5ncy5tb2JpbGU7XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLml0ZW1Db3VudCQgPSB0aGlzLmxpc3QuaXRlbUNvdW50JDtcbiAgfVxuXG4gIHByb3RlY3RlZCBjbG9zZSgpIHtcbiAgICB0aGlzLm1vZGFsQ29udHJvbGxlci5kaXNtaXNzKCk7XG4gICAgdGhpcy51c2VyRXZlbnRTZXJ2aWNlPy5yZXNldENvdW50KCk7XG4gIH1cblxuICBwcm90ZWN0ZWQgbWFya0ZvckNoZWNrKCkge1xuICAgIHRoaXMuY2QubWFya0ZvckNoZWNrKCk7XG4gIH1cbn1cbiIsIjxpb24taGVhZGVyPlxuICA8aW9uLXRvb2xiYXIgY29sb3I9XCJzZWNvbmRhcnlcIj5cbiAgICBAaWYgKG1vYmlsZSkge1xuICAgICAgPGlvbi1idXR0b25zIHNsb3Q9XCJzdGFydFwiPlxuICAgICAgICA8aW9uLWJ1dHRvbiAoY2xpY2spPVwiY2xvc2UoKVwiIHZpc2libGUteHMgdmlzaWJsZS1zbT5cbiAgICAgICAgICA8aW9uLWljb24gc2xvdD1cImljb24tb25seVwiIG5hbWU9XCJhcnJvdy1iYWNrXCI+PC9pb24taWNvbj5cbiAgICAgICAgPC9pb24tYnV0dG9uPlxuICAgICAgPC9pb24tYnV0dG9ucz5cbiAgICB9XG5cbiAgICA8aW9uLXRpdGxlPlxuICAgICAge3sgdGl0bGVJMThuIHwgdHJhbnNsYXRlIH19XG4gICAgICBAaWYgKGl0ZW1Db3VudCQgfCBhc3luYzsgYXMgY291bnQpIHtcbiAgICAgICAgPGk+KHt7IGNvdW50IH19KTwvaT5cbiAgICAgIH1cbiAgICA8L2lvbi10aXRsZT5cblxuICAgIDxpb24tYnV0dG9ucyBzbG90PVwiZW5kXCI+XG4gICAgICBAZm9yIChhY3Rpb24gb2YgaGVhZGVyQWN0aW9uczsgdHJhY2sgJGluZGV4KSB7XG4gICAgICAgIDxpb24tYnV0dG9uXG4gICAgICAgICAgKGNsaWNrKT1cImxpc3QuZXhlY3V0ZUFjdGlvbigkZXZlbnQsIGFjdGlvbiwgdW5kZWZpbmVkKVwiXG4gICAgICAgICAgW3RpdGxlXT1cIiFzaG93VG9vbHRpcCA/IChhY3Rpb24udGl0bGUgfHwgYWN0aW9uLm5hbWUgfCB0cmFuc2xhdGUpIDogJydcIlxuICAgICAgICAgIFttYXRUb29sdGlwXT1cInNob3dUb29sdGlwID8gKGFjdGlvbi50aXRsZSB8fCBhY3Rpb24ubmFtZSB8IHRyYW5zbGF0ZSkgOiAnJ1wiXG4gICAgICAgID5cbiAgICAgICAgICB7eyBhY3Rpb24ubmFtZSB8IHRyYW5zbGF0ZSB9fVxuICAgICAgICA8L2lvbi1idXR0b24+XG4gICAgICB9XG4gICAgPC9pb24tYnV0dG9ucz5cbiAgPC9pb24tdG9vbGJhcj5cbjwvaW9uLWhlYWRlcj5cblxuPGlvbi1jb250ZW50IGNsYXNzPVwiaW9uLW5vdC1wYWRkaW5nXCI+XG4gIDxhcHAtdXNlci1ldmVudC1ub3RpZmljYXRpb24tbGlzdFxuICAgICNsaXN0XG4gICAgW3Nob3dIZWFkZXJdPVwiZmFsc2VcIlxuICAgIFtzaG93Rm9vdGVyXT1cImZhbHNlXCJcbiAgICBbc29ydEJ5XT1cInNvcnRCeVwiXG4gICAgW3NvcnREaXJlY3Rpb25dPVwic29ydERpcmVjdGlvblwiXG4gICAgW2ZpbHRlcl09XCJmaWx0ZXJcIlxuICAgIFtlbmFibGVJbmZpbml0ZVNjcm9sbF09XCJlbmFibGVJbmZpbml0ZVNjcm9sbFwiXG4gICAgW2luZmluaXRlU2Nyb2xsVGhyZXNob2xkXT1cImluZmluaXRlU2Nyb2xsVGhyZXNob2xkXCJcbiAgICBbbW9iaWxlXT1cIm1vYmlsZVwiXG4gICAgW2RlYnVnXT1cImRlYnVnXCJcbiAgICAoZGlzbWlzcyk9XCJjbG9zZSgpXCJcbiAgPjwvYXBwLXVzZXItZXZlbnQtbm90aWZpY2F0aW9uLWxpc3Q+XG48L2lvbi1jb250ZW50PlxuXG48aW9uLWZvb3Rlcj5cbiAgPGlvbi10b29sYmFyPlxuICAgIDxpb24tcm93PlxuICAgICAgPGlvbi1jb2w+XG4gICAgICAgIEBpZiAobGlzdC5oYXNJdGVtJCB8IGFzeW5jKSB7XG4gICAgICAgICAgPGlvbi1idXR0b24gZmlsbD1cImNsZWFyXCIgKGNsaWNrKT1cImxpc3QubWFya0FsbEFzUmVhZCgkZXZlbnQpXCI+XG4gICAgICAgICAgICA8aW9uLWxhYmVsIHRyYW5zbGF0ZT5TT0NJQUwuVVNFUl9FVkVOVC5OT1RJRklDQVRJT04uUkVBRF9BTEw8L2lvbi1sYWJlbD5cbiAgICAgICAgICA8L2lvbi1idXR0b24+XG4gICAgICAgIH1cbiAgICAgICAgQGZvciAoYWN0aW9uIG9mIGZvb3RlckFjdGlvbnM7IHRyYWNrICRpbmRleCkge1xuICAgICAgICAgIDxpb24tYnV0dG9uXG4gICAgICAgICAgICBmaWxsPVwiY2xlYXJcIlxuICAgICAgICAgICAgKGNsaWNrKT1cImxpc3QuZXhlY3V0ZUFjdGlvbigkZXZlbnQsIGFjdGlvbiwgdW5kZWZpbmVkKVwiXG4gICAgICAgICAgICBbdGl0bGVdPVwiIXNob3dUb29sdGlwID8gKGFjdGlvbi50aXRsZSB8fCBhY3Rpb24ubmFtZSB8IHRyYW5zbGF0ZSkgOiAnJ1wiXG4gICAgICAgICAgICBbbWF0VG9vbHRpcF09XCJzaG93VG9vbHRpcCA/IChhY3Rpb24udGl0bGUgfHwgYWN0aW9uLm5hbWUgfCB0cmFuc2xhdGUpIDogJydcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIHt7IGFjdGlvbi5uYW1lIHwgdHJhbnNsYXRlIH19XG4gICAgICAgICAgPC9pb24tYnV0dG9uPlxuICAgICAgICB9XG4gICAgICA8L2lvbi1jb2w+XG4gICAgICBAaWYgKCFtb2JpbGUpIHtcbiAgICAgICAgPGlvbi1jb2wgc2l6ZT1cImF1dG9cIj5cbiAgICAgICAgICA8aW9uLWJ1dHRvbiBmaWxsPVwic29saWRcIiBjb2xvcj1cInRlcnRpYXJ5XCIgKGNsaWNrKT1cImNsb3NlKClcIiBoaWRkZW4teHMgaGlkZGVuLXNtPlxuICAgICAgICAgICAge3sgJ0NPTU1PTi5CVE5fQ0xPU0UnIHwgdHJhbnNsYXRlIH19XG4gICAgICAgICAgPC9pb24tYnV0dG9uPlxuICAgICAgICA8L2lvbi1jb2w+XG4gICAgICB9XG4gICAgPC9pb24tcm93PlxuICA8L2lvbi10b29sYmFyPlxuPC9pb24tZm9vdGVyPlxuIl19
|