@elderbyte/ngx-starter 14.11.0 → 14.12.0-beta
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/_index.scss +2 -0
- package/esm2020/lib/components/access-denied/elder-access-denied.component.mjs +3 -4
- package/esm2020/lib/components/access-denied/elder-access-denied.module.mjs +4 -8
- package/esm2020/lib/components/auditing/audited-entity/elder-audited-entity.component.mjs +9 -13
- package/esm2020/lib/components/auditing/elder-audit.module.mjs +1 -5
- package/esm2020/lib/components/button-group/elder-button-group/elder-button-group.component.mjs +3 -4
- package/esm2020/lib/components/button-group/elder-button-group.module.mjs +4 -8
- package/esm2020/lib/components/card-organizer/card-organizer/elder-card-organizer.component.mjs +4 -5
- package/esm2020/lib/components/card-organizer/card-stack/elder-card-stack.component.mjs +5 -6
- package/esm2020/lib/components/card-organizer/elder-card-organizer.module.mjs +4 -5
- package/esm2020/lib/components/cards/elder-card/elder-card-header/elder-card-header.component.mjs +3 -5
- package/esm2020/lib/components/cards/elder-card/elder-card.component.mjs +3 -5
- package/esm2020/lib/components/cards/elder-card/elder-card.module.mjs +4 -5
- package/esm2020/lib/components/connectivity/elder-connectivity.module.mjs +4 -5
- package/esm2020/lib/components/containers/elder-containers.module.mjs +4 -8
- package/esm2020/lib/components/containers/elder-scroll-container/elder-scroll-container.component.mjs +3 -4
- package/esm2020/lib/components/data-transfer/elder-data-transfer.module.mjs +4 -5
- package/esm2020/lib/components/data-transfer/http-data-transfer/http-data-transfer.component.mjs +3 -4
- package/esm2020/lib/components/data-transfer/http-data-transfer-aggregate/http-data-transfer-aggregate.component.mjs +4 -5
- package/esm2020/lib/components/data-transfer/http-data-transfer-indicator/http-data-transfer-indicator.component.mjs +6 -7
- package/esm2020/lib/components/data-transfer/http-data-transfer-overview/http-data-transfer-overview.component.mjs +5 -6
- package/esm2020/lib/components/data-view/common/data-context-state-indicator/data-context-state-indicator.component.mjs +4 -5
- package/esm2020/lib/components/data-view/common/elder-data-common.module.mjs +4 -5
- package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs +3 -4
- package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs +4 -5
- package/esm2020/lib/components/data-view/common/selection/elder-selection-master-checkbox/elder-selection-master-checkbox.component.mjs +3 -4
- package/esm2020/lib/components/data-view/grid/elder-grid/elder-grid.component.mjs +39 -26
- package/esm2020/lib/components/data-view/grid/elder-grid.module.mjs +1 -5
- package/esm2020/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.mjs +4 -5
- package/esm2020/lib/components/data-view/table/elder-table/elder-table.component.mjs +8 -9
- package/esm2020/lib/components/data-view/table/elder-table.module.mjs +4 -5
- package/esm2020/lib/components/dialogs/confirm-dialog/elder-confirm-dialog.component.mjs +4 -5
- package/esm2020/lib/components/dialogs/elder-dialog.module.mjs +4 -5
- package/esm2020/lib/components/dialogs/question-dialog/elder-question-dialog.component.mjs +4 -5
- package/esm2020/lib/components/dialogs/selection-dialog/elder-selection-dialog/elder-selection-dialog.component.mjs +4 -5
- package/esm2020/lib/components/errors/elder-error.module.mjs +4 -8
- package/esm2020/lib/components/errors/exception-detail/elder-exception-detail.component.mjs +3 -4
- package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.component.mjs +4 -5
- package/esm2020/lib/components/expand-toggle-button/elder-expand-toggle-button.module.mjs +4 -5
- package/esm2020/lib/components/files/blob-viewer/elder-blob-viewer.component.mjs +3 -4
- package/esm2020/lib/components/files/elder-file.module.mjs +4 -5
- package/esm2020/lib/components/files/file-upload/file-upload.component.mjs +11 -12
- package/esm2020/lib/components/forms/search/elder-search.module.mjs +4 -5
- package/esm2020/lib/components/forms/search/search-box/elder-search-box.component.mjs +5 -6
- package/esm2020/lib/components/global-search/elder-global-search.component.mjs +4 -5
- package/esm2020/lib/components/global-search/elder-global-search.module.mjs +4 -5
- package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.component.mjs +3 -11
- package/esm2020/lib/components/graph/elder-progress-bar/elder-progress-bar.module.mjs +4 -8
- package/esm2020/lib/components/headers/elder-header/elder-header.component.mjs +4 -5
- package/esm2020/lib/components/headers/elder-header.module.mjs +4 -5
- package/esm2020/lib/components/i18n/entities/elder-i18n-entities.module.mjs +1 -5
- package/esm2020/lib/components/i18n/entities/elder-localized-input/elder-localized-input.component.mjs +10 -11
- package/esm2020/lib/components/i18n/entities/elder-localized-input-dialog/elder-localized-input-dialog.component.mjs +8 -9
- package/esm2020/lib/components/i18n/entities/elder-localized-input-table/elder-localized-input-table.component.mjs +14 -15
- package/esm2020/lib/components/i18n/language/elder-language.module.mjs +1 -5
- package/esm2020/lib/components/i18n/language/language-switcher/elder-language-switcher.component.mjs +5 -6
- package/esm2020/lib/components/iframes/data-view/data-view-iframe/data-view-iframe.component.mjs +4 -5
- package/esm2020/lib/components/iframes/elder-iframe.module.mjs +1 -5
- package/esm2020/lib/components/iframes/iframe-dialog/iframe-dialog.component.mjs +4 -5
- package/esm2020/lib/components/iframes/iframe-host/iframe-host.component.mjs +6 -7
- package/esm2020/lib/components/iframes/iframe-side-content/iframe-side-content.component.mjs +4 -5
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete/elder-autocomplete.component.mjs +4 -5
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete.module.mjs +1 -5
- package/esm2020/lib/components/measures/dimensions-input/elder-dimensions-input.component.mjs +5 -16
- package/esm2020/lib/components/measures/elder-measures.module.mjs +1 -5
- package/esm2020/lib/components/measures/quantity-input/elder-quantity-input.component.mjs +12 -13
- package/esm2020/lib/components/navigation/bread-crumbs/bread-crumbs/elder-bread-crumbs.component.mjs +12 -13
- package/esm2020/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.mjs +4 -5
- package/esm2020/lib/components/navigation/nav/elder-nav.module.mjs +4 -5
- package/esm2020/lib/components/navigation/nav/nav-group/elder-nav-group.component.mjs +3 -4
- package/esm2020/lib/components/navigation/nav/nav-link/elder-nav-link.component.mjs +4 -5
- package/esm2020/lib/components/navigation/nav/nav-list/elder-nav-list.component.mjs +3 -5
- package/esm2020/lib/components/navigation/toolbar/elder-toolbar.module.mjs +4 -5
- package/esm2020/lib/components/navigation/toolbar/toolbar/elder-toolbar.component.mjs +6 -7
- package/esm2020/lib/components/overlays/elder-overlay-origin.directive.mjs +2 -2
- package/esm2020/lib/components/overlays/elder-overlay-trigger.directive.mjs +2 -2
- package/esm2020/lib/components/overlays/elder-overlay.component.mjs +2 -2
- package/esm2020/lib/components/panels/card-panel/elder-card-panel.component.mjs +3 -4
- package/esm2020/lib/components/panels/elder-dialog-panel/elder-dialog-panel.component.mjs +3 -4
- package/esm2020/lib/components/panels/elder-panel.module.mjs +3 -7
- package/esm2020/lib/components/select/elder-select.module.mjs +4 -5
- package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +9 -10
- package/esm2020/lib/components/select/popup/templated-selection-dialog/templated-selection-dialog.component.mjs +5 -6
- package/esm2020/lib/components/select/single/elder-select/elder-select.component.mjs +8 -9
- package/esm2020/lib/components/select-chip-list/chip-list-select/elder-chip-list-select.component.mjs +4 -6
- package/esm2020/lib/components/select-chip-list/elder-chip-list-select.module.mjs +4 -5
- package/esm2020/lib/components/select-list/elder-select-list.module.mjs +4 -5
- package/esm2020/lib/components/select-list/select-list/elder-select-list.component.mjs +3 -4
- package/esm2020/lib/components/select-list/select-list-item/elder-select-list-item.component.mjs +3 -4
- package/esm2020/lib/components/shell/elder-shell.module.mjs +4 -5
- package/esm2020/lib/components/shell/header/elder-app-header/elder-app-header.component.mjs +4 -5
- package/esm2020/lib/components/shell/shell/elder-shell.component.mjs +4 -5
- package/esm2020/lib/components/tabs/elder-tab.module.mjs +4 -8
- package/esm2020/lib/components/time/duration/elder-duration-input/elder-duration-input.component.mjs +7 -8
- package/esm2020/lib/components/time/elder-date-switcher/elder-date-switcher.component.mjs +9 -10
- package/esm2020/lib/components/time/elder-date-time-input/elder-date-time-input.component.mjs +7 -8
- package/esm2020/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +7 -8
- package/esm2020/lib/components/time/elder-local-date-input/elder-local-date-input.component.mjs +12 -13
- package/esm2020/lib/components/time/elder-local-time-input/elder-local-time-input.component.mjs +9 -10
- package/esm2020/lib/components/time/elder-time.module.mjs +1 -11
- package/esm2020/lib/components/time/period/elder-period-input/elder-period-input.component.mjs +7 -8
- package/esm2020/lib/components/toasts/elder-toast.module.mjs +4 -5
- package/esm2020/lib/components/toasts/standard-toast/standard-toast.component.mjs +5 -6
- package/esm2020/lib/components/url-fragment/elder-url-fragment.module.mjs +1 -5
- package/esm2020/lib/components/url-fragment/url-fragment-switcher/elder-url-fragment-switcher.component.mjs +4 -5
- package/fesm2015/elderbyte-ngx-starter.mjs +383 -447
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +383 -447
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/components/access-denied/elder-access-denied.module.d.ts +1 -2
- package/lib/components/auditing/audited-entity/elder-audited-entity.component.d.ts +1 -2
- package/lib/components/auditing/elder-audit.module.d.ts +5 -6
- package/lib/components/button-group/elder-button-group.module.d.ts +1 -2
- package/lib/components/card-organizer/elder-card-organizer.module.d.ts +3 -4
- package/lib/components/cards/elder-card/elder-card.module.d.ts +2 -3
- package/lib/components/connectivity/elder-connectivity.module.d.ts +6 -7
- package/lib/components/containers/elder-containers.module.d.ts +1 -2
- package/lib/components/data-transfer/elder-data-transfer.module.d.ts +4 -5
- package/lib/components/data-view/common/elder-data-common.module.d.ts +1 -2
- package/lib/components/data-view/grid/elder-grid/elder-grid.component.d.ts +4 -3
- package/lib/components/data-view/grid/elder-grid.module.d.ts +6 -7
- package/lib/components/data-view/simple/elder-simple-selection-view/elder-simple-selection-view.module.d.ts +4 -5
- package/lib/components/data-view/table/elder-table.module.d.ts +4 -5
- package/lib/components/dialogs/elder-dialog.module.d.ts +2 -3
- package/lib/components/errors/elder-error.module.d.ts +1 -2
- package/lib/components/expand-toggle-button/elder-expand-toggle-button.module.d.ts +1 -2
- package/lib/components/files/elder-file.module.d.ts +6 -7
- package/lib/components/forms/search/elder-search.module.d.ts +2 -3
- package/lib/components/global-search/elder-global-search.module.d.ts +2 -3
- package/lib/components/graph/elder-progress-bar/elder-progress-bar.component.d.ts +1 -8
- package/lib/components/graph/elder-progress-bar/elder-progress-bar.module.d.ts +1 -2
- package/lib/components/headers/elder-header.module.d.ts +2 -3
- package/lib/components/i18n/entities/elder-i18n-entities.module.d.ts +15 -16
- package/lib/components/i18n/language/elder-language.module.d.ts +2 -3
- package/lib/components/iframes/elder-iframe.module.d.ts +5 -6
- package/lib/components/input/autocomplete/elder-autocomplete.module.d.ts +2 -3
- package/lib/components/measures/dimensions-input/elder-dimensions-input.component.d.ts +1 -3
- package/lib/components/measures/elder-measures.module.d.ts +5 -6
- package/lib/components/navigation/bread-crumbs/elder-bread-crumbs.module.d.ts +8 -9
- package/lib/components/navigation/nav/elder-nav.module.d.ts +1 -2
- package/lib/components/navigation/nav/nav-list/elder-nav-list.component.d.ts +1 -3
- package/lib/components/navigation/toolbar/elder-toolbar.module.d.ts +8 -9
- package/lib/components/panels/elder-panel.module.d.ts +1 -2
- package/lib/components/select/elder-select.module.d.ts +10 -11
- package/lib/components/select-chip-list/elder-chip-list-select.module.d.ts +3 -4
- package/lib/components/select-list/elder-select-list.module.d.ts +1 -2
- package/lib/components/shell/elder-shell.module.d.ts +4 -5
- package/lib/components/tabs/elder-tab.module.d.ts +1 -2
- package/lib/components/time/elder-time.module.d.ts +9 -10
- package/lib/components/toasts/elder-toast.module.d.ts +3 -4
- package/lib/components/url-fragment/elder-url-fragment.module.d.ts +2 -3
- package/package.json +1 -2
- package/src/lib/components/graph/elder-progress-bar/elder-progress-bar.component.scss +5 -0
- package/src/lib/components/navigation/nav/nav-list/elder-nav-list.component.scss +5 -6
- package/src/lib/components/select/single/elder-select/elder-select.component.scss +1 -4
- package/theming/_elder-common.scss +32 -0
- package/theming/_elder-flex-layout.scss +562 -0
- package/theming/_elder-style-fixes.scss +3 -0
package/esm2020/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.mjs
CHANGED
|
@@ -8,7 +8,6 @@ import * as i3 from "@angular/common";
|
|
|
8
8
|
import * as i4 from "@angular/material/menu";
|
|
9
9
|
import * as i5 from "@angular/material/button";
|
|
10
10
|
import * as i6 from "@angular/material/icon";
|
|
11
|
-
import * as i7 from "@angular/flex-layout/flex";
|
|
12
11
|
/**
|
|
13
12
|
* This directive projects content identified by a placeholder id
|
|
14
13
|
* into the toolbar at the corresponding place.
|
|
@@ -116,10 +115,10 @@ export class ElderDataToolbarComponent {
|
|
|
116
115
|
}
|
|
117
116
|
}
|
|
118
117
|
ElderDataToolbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderDataToolbarComponent, deps: [{ token: i1.SelectionModel, optional: true }, { token: ELDER_DATA_VIEW, optional: true }, { token: i2.ElderDialogService }], target: i0.ɵɵFactoryTarget.Component });
|
|
119
|
-
ElderDataToolbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderDataToolbarComponent, selector: "elder-data-toolbar", inputs: { canAdd: "canAdd", canRemove: "canRemove", canMore: "canMore", confirmRemoval: "confirmRemoval", keepSelectionAfterRemoval: "keepSelectionAfterRemoval", selectionModel: "selectionModel" }, outputs: { requestNew: "requestNew", requestRemove: "requestRemove" }, queries: [{ propertyName: "templates", predicate: ElderToolbarContentDirective }], ngImport: i0, template: "<!-- Table Toolbar -->\n<div\n
|
|
118
|
+
ElderDataToolbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderDataToolbarComponent, selector: "elder-data-toolbar", inputs: { canAdd: "canAdd", canRemove: "canRemove", canMore: "canMore", confirmRemoval: "confirmRemoval", keepSelectionAfterRemoval: "keepSelectionAfterRemoval", selectionModel: "selectionModel" }, outputs: { requestNew: "requestNew", requestRemove: "requestRemove" }, queries: [{ propertyName: "templates", predicate: ElderToolbarContentDirective }], ngImport: i0, template: "<!-- Table Toolbar -->\n<div\n class=\"layout-row place-between-center gap-md\"\n style=\"padding: 4px 8px 0 8px\"\n *ngIf=\"selection$ | async as selection\"\n>\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('main') || defaultContent;\n context: { $implicit: selection }\n \"\n ></ng-container>\n</div>\n\n<!-- Default Templates -->\n\n<!-- Default Main Content -->\n<ng-template #defaultContent let-selection>\n <!-- Left column -->\n <div class=\"layout-row place-start-center\">\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('left') || defaultLeftContent;\n context: { $implicit: selection }\n \"\n ></ng-container>\n </div>\n\n <div class=\"layout-row place-center-center flex\">\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('center') || defaultCenterContent;\n context: { $implicit: selection }\n \"\n ></ng-container>\n </div>\n\n <!-- Right column -->\n <div class=\"layout-row place-end-center\">\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('right') || defaultRightContent;\n context: { $implicit: selection }\n \"\n ></ng-container>\n </div>\n</ng-template>\n\n<!-- Default Left Content -->\n<ng-template #defaultLeftContent let-selection>\n <!-- Add Action -->\n <button\n mat-icon-button type=\"button\"\n color=\"primary\"\n *ngIf=\"canAdd\"\n (click)=\"requestNew.next($event)\"\n >\n <mat-icon>add</mat-icon>\n </button>\n\n <!-- Placeholder for additional actions -->\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('left.actions');\n context: { $implicit: selection }\n \"\n ></ng-container>\n</ng-template>\n\n<!-- Default Center Content -->\n<ng-template #defaultCenterContent let-selection></ng-template>\n\n<!-- Default Right Content -->\n<ng-template #defaultRightContent let-selection>\n <!-- Placeholder for additional actions -->\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('right.actions');\n context: { $implicit: selection }\n \"\n ></ng-container>\n\n <!-- Delete Action -->\n <button\n mat-icon-button type=\"button\"\n color=\"primary\"\n *ngIf=\"canRemove\"\n [disabled]=\"!selection?.length\"\n (click)=\"requestRemoveItems(selection)\"\n >\n <mat-icon>delete</mat-icon>\n </button>\n\n <!-- More Menu -->\n <button\n mat-icon-button type=\"button\"\n color=\"primary\"\n [matMenuTriggerFor]=\"elderTableMenu\"\n [disabled]=\"!canMore\"\n >\n <mat-icon>more_vert</mat-icon>\n <mat-menu #elderTableMenu=\"matMenu\">\n <ng-content select=\"[mat-menu-item]\"></ng-content>\n <!-- Placeholder for mat menu items-->\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('right.menu');\n context: { $implicit: selection }\n \"\n ></ng-container>\n </mat-menu>\n </button>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "directive", type: i4.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
120
119
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderDataToolbarComponent, decorators: [{
|
|
121
120
|
type: Component,
|
|
122
|
-
args: [{ selector: 'elder-data-toolbar', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Table Toolbar -->\n<div\n
|
|
121
|
+
args: [{ selector: 'elder-data-toolbar', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Table Toolbar -->\n<div\n class=\"layout-row place-between-center gap-md\"\n style=\"padding: 4px 8px 0 8px\"\n *ngIf=\"selection$ | async as selection\"\n>\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('main') || defaultContent;\n context: { $implicit: selection }\n \"\n ></ng-container>\n</div>\n\n<!-- Default Templates -->\n\n<!-- Default Main Content -->\n<ng-template #defaultContent let-selection>\n <!-- Left column -->\n <div class=\"layout-row place-start-center\">\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('left') || defaultLeftContent;\n context: { $implicit: selection }\n \"\n ></ng-container>\n </div>\n\n <div class=\"layout-row place-center-center flex\">\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('center') || defaultCenterContent;\n context: { $implicit: selection }\n \"\n ></ng-container>\n </div>\n\n <!-- Right column -->\n <div class=\"layout-row place-end-center\">\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('right') || defaultRightContent;\n context: { $implicit: selection }\n \"\n ></ng-container>\n </div>\n</ng-template>\n\n<!-- Default Left Content -->\n<ng-template #defaultLeftContent let-selection>\n <!-- Add Action -->\n <button\n mat-icon-button type=\"button\"\n color=\"primary\"\n *ngIf=\"canAdd\"\n (click)=\"requestNew.next($event)\"\n >\n <mat-icon>add</mat-icon>\n </button>\n\n <!-- Placeholder for additional actions -->\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('left.actions');\n context: { $implicit: selection }\n \"\n ></ng-container>\n</ng-template>\n\n<!-- Default Center Content -->\n<ng-template #defaultCenterContent let-selection></ng-template>\n\n<!-- Default Right Content -->\n<ng-template #defaultRightContent let-selection>\n <!-- Placeholder for additional actions -->\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('right.actions');\n context: { $implicit: selection }\n \"\n ></ng-container>\n\n <!-- Delete Action -->\n <button\n mat-icon-button type=\"button\"\n color=\"primary\"\n *ngIf=\"canRemove\"\n [disabled]=\"!selection?.length\"\n (click)=\"requestRemoveItems(selection)\"\n >\n <mat-icon>delete</mat-icon>\n </button>\n\n <!-- More Menu -->\n <button\n mat-icon-button type=\"button\"\n color=\"primary\"\n [matMenuTriggerFor]=\"elderTableMenu\"\n [disabled]=\"!canMore\"\n >\n <mat-icon>more_vert</mat-icon>\n <mat-menu #elderTableMenu=\"matMenu\">\n <ng-content select=\"[mat-menu-item]\"></ng-content>\n <!-- Placeholder for mat menu items-->\n <ng-container\n *ngTemplateOutlet=\"\n getTemplate('right.menu');\n context: { $implicit: selection }\n \"\n ></ng-container>\n </mat-menu>\n </button>\n</ng-template>\n" }]
|
|
123
122
|
}], ctorParameters: function () { return [{ type: i1.SelectionModel, decorators: [{
|
|
124
123
|
type: Optional
|
|
125
124
|
}] }, { type: undefined, decorators: [{
|
|
@@ -147,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
|
|
|
147
146
|
}], selectionModel: [{
|
|
148
147
|
type: Input
|
|
149
148
|
}] } });
|
|
150
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-data-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    Directive,\n    Inject,\n    Input,\n    OnInit,\n    Optional,\n    Output,\n    QueryList,\n    TemplateRef,\n} from '@angular/core';\nimport { SelectionModel } from '../../../../common/selection/selection-model';\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\nimport { ElderDialogService } from '../../../dialogs/elder-dialog.module';\nimport { ELDER_DATA_VIEW, IElderDataView } from '../../base/elder-data-view';\n\nexport type ElderToolbarContentSlot =\n    | 'main'\n    | 'left'\n    | 'left.actions'\n    | 'center'\n    | 'right'\n    | 'right.actions'\n    | 'right.menu';\n\n/**\n * This directive projects content identified by a placeholder id\n * into the toolbar at the corresponding place.\n */\n@Directive({ selector: '[elderToolbarContent]' })\nexport class ElderToolbarContentDirective {\n    @Input('elderToolbarContent')\n    public placeholderId: ElderToolbarContentSlot;\n\n    constructor(public templateRef: TemplateRef<any>) {}\n}\n\n@Component({\n    selector: 'elder-data-toolbar',\n    templateUrl: './elder-data-toolbar.component.html',\n    styleUrls: ['./elder-data-toolbar.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ElderDataToolbarComponent<T = any> implements OnInit {\n    /***************************************************************************\n     *                                                                         *\n     * Fields                                                                  *\n     *                                                                         *\n     **************************************************************************/\n\n    private _selectionModel: SelectionModel<T>;\n\n    @Input()\n    public canAdd = true;\n\n    @Input()\n    public canRemove = true;\n\n    @Input()\n    public canMore = true;\n\n    @Input()\n    public confirmRemoval = true;\n\n    @Input()\n    public keepSelectionAfterRemoval = false;\n\n    @Output()\n    public readonly requestNew = new Subject<any>();\n\n    @Output()\n    public readonly requestRemove = new Subject<T[]>();\n\n    @ContentChildren(ElderToolbarContentDirective)\n    public templates: QueryList<ElderToolbarContentDirective>;\n\n    public selection$: Observable<T[]>;\n\n    public readonly selectionFallback = new BehaviorSubject<T[]>([]);\n\n    /***************************************************************************\n     *                                                                         *\n     * Constructor                                                             *\n     *                                                                         *\n     **************************************************************************/\n\n    constructor(\n        @Optional() selectionModel: SelectionModel<T>,\n        @Optional() @Inject(ELDER_DATA_VIEW) dataView: IElderDataView,\n        private dialogService: ElderDialogService\n    ) {\n        this.selection$ = this.selectionFallback.asObservable();\n\n        if (selectionModel) {\n            this.selectionModel = selectionModel;\n        }\n\n        if (dataView) {\n            this.selectionModel = dataView.selectionModel;\n        }\n    }\n\n    /***************************************************************************\n     *                                                                         *\n     * Life Cycle                                                              *\n     *                                                                         *\n     **************************************************************************/\n\n    public ngOnInit(): void {}\n\n    /***************************************************************************\n     *                                                                         *\n     * Properties                                                              *\n     *                                                                         *\n     **************************************************************************/\n\n    @Input()\n    public set selectionModel(model: SelectionModel<T>) {\n        this._selectionModel = model;\n        if (model) {\n            this.selection$ = model.selection;\n        } else {\n            this.selection$ = this.selectionFallback.asObservable();\n        }\n    }\n\n    public get selectionModel(): SelectionModel<T> {\n        return this._selectionModel;\n    }\n\n    /***************************************************************************\n     *                                                                         *\n     * Public API                                                              *\n     *                                                                         *\n     **************************************************************************/\n\n    public getTemplate(\n        placeholderId: ElderToolbarContentSlot\n    ): TemplateRef<any> {\n        if (!this.templates) {\n            return null;\n        }\n\n        const template = this.templates.find(\n            (item) => item.placeholderId === placeholderId\n        );\n        return template ? template.templateRef : null;\n    }\n\n    public requestRemoveItems(items: T[]): void {\n        if (this.confirmRemoval) {\n            this.dialogService\n                .showConfirm({\n                    title: 'dialogs.confirm-deletion.title',\n                    message: 'dialogs.confirm-deletion.message',\n                    yesNo: true,\n                    interpolateParams: { numOfItems: items.length },\n                })\n                .subscribe((confirmed) => {\n                    if (confirmed) {\n                        this.emitRemove(items);\n                    }\n                });\n        } else {\n            this.emitRemove(items);\n        }\n    }\n\n    private emitRemove(items: T[]): void {\n        this.requestRemove.next(items);\n\n        if (!this.keepSelectionAfterRemoval) {\n            // Clear the selection after deleting items\n            if (this._selectionModel) {\n                this._selectionModel.deselect(items);\n            }\n        }\n    }\n}\n","<!-- Table Toolbar -->\n<div\n    fxLayout=\"row\"\n    fxLayoutAlign=\"space-between center\"\n    fxLayoutGap=\"10px\"\n    style=\"padding: 4px 8px 0 8px\"\n    *ngIf=\"selection$ | async as selection\"\n>\n    <ng-container\n        *ngTemplateOutlet=\"\n            getTemplate('main') || defaultContent;\n            context: { $implicit: selection }\n        \"\n    ></ng-container>\n</div>\n\n<!-- Default Templates -->\n\n<!-- Default Main Content -->\n<ng-template #defaultContent let-selection>\n    <!-- Left column -->\n    <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                getTemplate('left') || defaultLeftContent;\n                context: { $implicit: selection }\n            \"\n        ></ng-container>\n    </div>\n\n    <div fxLayout=\"row\" fxLayoutAlign=\"center center\" fxFlex>\n        <ng-container\n            *ngTemplateOutlet=\"\n                getTemplate('center') || defaultCenterContent;\n                context: { $implicit: selection }\n            \"\n        ></ng-container>\n    </div>\n\n    <!-- Right column -->\n    <div fxLayout=\"row\" fxLayoutAlign=\"end center\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                getTemplate('right') || defaultRightContent;\n                context: { $implicit: selection }\n            \"\n        ></ng-container>\n    </div>\n</ng-template>\n\n<!-- Default Left Content -->\n<ng-template #defaultLeftContent let-selection>\n    <!-- Add Action -->\n    <button\n        mat-icon-button type=\"button\"\n        color=\"primary\"\n        *ngIf=\"canAdd\"\n        (click)=\"requestNew.next($event)\"\n    >\n        <mat-icon>add</mat-icon>\n    </button>\n\n    <!-- Placeholder for additional actions -->\n    <ng-container\n        *ngTemplateOutlet=\"\n            getTemplate('left.actions');\n            context: { $implicit: selection }\n        \"\n    ></ng-container>\n</ng-template>\n\n<!-- Default Center Content -->\n<ng-template #defaultCenterContent let-selection> </ng-template>\n\n<!-- Default Right Content -->\n<ng-template #defaultRightContent let-selection>\n    <!-- Placeholder for additional actions -->\n    <ng-container\n        *ngTemplateOutlet=\"\n            getTemplate('right.actions');\n            context: { $implicit: selection }\n        \"\n    ></ng-container>\n\n    <!-- Delete Action -->\n    <button\n        mat-icon-button type=\"button\"\n        color=\"primary\"\n        *ngIf=\"canRemove\"\n        [disabled]=\"!selection?.length\"\n        (click)=\"requestRemoveItems(selection)\"\n    >\n        <mat-icon>delete</mat-icon>\n    </button>\n\n    <!-- More Menu -->\n    <button\n        mat-icon-button type=\"button\"\n        color=\"primary\"\n        [matMenuTriggerFor]=\"elderTableMenu\"\n        [disabled]=\"!canMore\"\n    >\n        <mat-icon>more_vert</mat-icon>\n        <mat-menu #elderTableMenu=\"matMenu\">\n            <ng-content select=\"[mat-menu-item]\"></ng-content>\n            <!-- Placeholder for mat menu items-->\n            <ng-container\n                *ngTemplateOutlet=\"\n                    getTemplate('right.menu');\n                    context: { $implicit: selection }\n                \"\n            ></ng-container>\n        </mat-menu>\n    </button>\n</ng-template>\n"]}
|
|
149
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-data-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/common/elder-data-toolbar/elder-data-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    Directive,\n    Inject,\n    Input,\n    OnInit,\n    Optional,\n    Output,\n    QueryList,\n    TemplateRef,\n} from '@angular/core';\nimport { SelectionModel } from '../../../../common/selection/selection-model';\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\nimport { ElderDialogService } from '../../../dialogs/elder-dialog.module';\nimport { ELDER_DATA_VIEW, IElderDataView } from '../../base/elder-data-view';\n\nexport type ElderToolbarContentSlot =\n    | 'main'\n    | 'left'\n    | 'left.actions'\n    | 'center'\n    | 'right'\n    | 'right.actions'\n    | 'right.menu';\n\n/**\n * This directive projects content identified by a placeholder id\n * into the toolbar at the corresponding place.\n */\n@Directive({ selector: '[elderToolbarContent]' })\nexport class ElderToolbarContentDirective {\n    @Input('elderToolbarContent')\n    public placeholderId: ElderToolbarContentSlot;\n\n    constructor(public templateRef: TemplateRef<any>) {}\n}\n\n@Component({\n    selector: 'elder-data-toolbar',\n    templateUrl: './elder-data-toolbar.component.html',\n    styleUrls: ['./elder-data-toolbar.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ElderDataToolbarComponent<T = any> implements OnInit {\n    /***************************************************************************\n     *                                                                         *\n     * Fields                                                                  *\n     *                                                                         *\n     **************************************************************************/\n\n    private _selectionModel: SelectionModel<T>;\n\n    @Input()\n    public canAdd = true;\n\n    @Input()\n    public canRemove = true;\n\n    @Input()\n    public canMore = true;\n\n    @Input()\n    public confirmRemoval = true;\n\n    @Input()\n    public keepSelectionAfterRemoval = false;\n\n    @Output()\n    public readonly requestNew = new Subject<any>();\n\n    @Output()\n    public readonly requestRemove = new Subject<T[]>();\n\n    @ContentChildren(ElderToolbarContentDirective)\n    public templates: QueryList<ElderToolbarContentDirective>;\n\n    public selection$: Observable<T[]>;\n\n    public readonly selectionFallback = new BehaviorSubject<T[]>([]);\n\n    /***************************************************************************\n     *                                                                         *\n     * Constructor                                                             *\n     *                                                                         *\n     **************************************************************************/\n\n    constructor(\n        @Optional() selectionModel: SelectionModel<T>,\n        @Optional() @Inject(ELDER_DATA_VIEW) dataView: IElderDataView,\n        private dialogService: ElderDialogService\n    ) {\n        this.selection$ = this.selectionFallback.asObservable();\n\n        if (selectionModel) {\n            this.selectionModel = selectionModel;\n        }\n\n        if (dataView) {\n            this.selectionModel = dataView.selectionModel;\n        }\n    }\n\n    /***************************************************************************\n     *                                                                         *\n     * Life Cycle                                                              *\n     *                                                                         *\n     **************************************************************************/\n\n    public ngOnInit(): void {}\n\n    /***************************************************************************\n     *                                                                         *\n     * Properties                                                              *\n     *                                                                         *\n     **************************************************************************/\n\n    @Input()\n    public set selectionModel(model: SelectionModel<T>) {\n        this._selectionModel = model;\n        if (model) {\n            this.selection$ = model.selection;\n        } else {\n            this.selection$ = this.selectionFallback.asObservable();\n        }\n    }\n\n    public get selectionModel(): SelectionModel<T> {\n        return this._selectionModel;\n    }\n\n    /***************************************************************************\n     *                                                                         *\n     * Public API                                                              *\n     *                                                                         *\n     **************************************************************************/\n\n    public getTemplate(\n        placeholderId: ElderToolbarContentSlot\n    ): TemplateRef<any> {\n        if (!this.templates) {\n            return null;\n        }\n\n        const template = this.templates.find(\n            (item) => item.placeholderId === placeholderId\n        );\n        return template ? template.templateRef : null;\n    }\n\n    public requestRemoveItems(items: T[]): void {\n        if (this.confirmRemoval) {\n            this.dialogService\n                .showConfirm({\n                    title: 'dialogs.confirm-deletion.title',\n                    message: 'dialogs.confirm-deletion.message',\n                    yesNo: true,\n                    interpolateParams: { numOfItems: items.length },\n                })\n                .subscribe((confirmed) => {\n                    if (confirmed) {\n                        this.emitRemove(items);\n                    }\n                });\n        } else {\n            this.emitRemove(items);\n        }\n    }\n\n    private emitRemove(items: T[]): void {\n        this.requestRemove.next(items);\n\n        if (!this.keepSelectionAfterRemoval) {\n            // Clear the selection after deleting items\n            if (this._selectionModel) {\n                this._selectionModel.deselect(items);\n            }\n        }\n    }\n}\n","<!-- Table Toolbar -->\n<div\n  class=\"layout-row place-between-center gap-md\"\n  style=\"padding: 4px 8px 0 8px\"\n  *ngIf=\"selection$ | async as selection\"\n>\n  <ng-container\n    *ngTemplateOutlet=\"\n            getTemplate('main') || defaultContent;\n            context: { $implicit: selection }\n        \"\n  ></ng-container>\n</div>\n\n<!-- Default Templates -->\n\n<!-- Default Main Content -->\n<ng-template #defaultContent let-selection>\n  <!-- Left column -->\n  <div class=\"layout-row place-start-center\">\n    <ng-container\n      *ngTemplateOutlet=\"\n                getTemplate('left') || defaultLeftContent;\n                context: { $implicit: selection }\n            \"\n    ></ng-container>\n  </div>\n\n  <div class=\"layout-row place-center-center flex\">\n    <ng-container\n      *ngTemplateOutlet=\"\n                getTemplate('center') || defaultCenterContent;\n                context: { $implicit: selection }\n            \"\n    ></ng-container>\n  </div>\n\n  <!-- Right column -->\n  <div class=\"layout-row place-end-center\">\n    <ng-container\n      *ngTemplateOutlet=\"\n                getTemplate('right') || defaultRightContent;\n                context: { $implicit: selection }\n            \"\n    ></ng-container>\n  </div>\n</ng-template>\n\n<!-- Default Left Content -->\n<ng-template #defaultLeftContent let-selection>\n  <!-- Add Action -->\n  <button\n    mat-icon-button type=\"button\"\n    color=\"primary\"\n    *ngIf=\"canAdd\"\n    (click)=\"requestNew.next($event)\"\n  >\n    <mat-icon>add</mat-icon>\n  </button>\n\n  <!-- Placeholder for additional actions -->\n  <ng-container\n    *ngTemplateOutlet=\"\n            getTemplate('left.actions');\n            context: { $implicit: selection }\n        \"\n  ></ng-container>\n</ng-template>\n\n<!-- Default Center Content -->\n<ng-template #defaultCenterContent let-selection></ng-template>\n\n<!-- Default Right Content -->\n<ng-template #defaultRightContent let-selection>\n  <!-- Placeholder for additional actions -->\n  <ng-container\n    *ngTemplateOutlet=\"\n            getTemplate('right.actions');\n            context: { $implicit: selection }\n        \"\n  ></ng-container>\n\n  <!-- Delete Action -->\n  <button\n    mat-icon-button type=\"button\"\n    color=\"primary\"\n    *ngIf=\"canRemove\"\n    [disabled]=\"!selection?.length\"\n    (click)=\"requestRemoveItems(selection)\"\n  >\n    <mat-icon>delete</mat-icon>\n  </button>\n\n  <!-- More Menu -->\n  <button\n    mat-icon-button type=\"button\"\n    color=\"primary\"\n    [matMenuTriggerFor]=\"elderTableMenu\"\n    [disabled]=\"!canMore\"\n  >\n    <mat-icon>more_vert</mat-icon>\n    <mat-menu #elderTableMenu=\"matMenu\">\n      <ng-content select=\"[mat-menu-item]\"></ng-content>\n      <!-- Placeholder for mat menu items-->\n      <ng-container\n        *ngTemplateOutlet=\"\n                    getTemplate('right.menu');\n                    context: { $implicit: selection }\n                \"\n      ></ng-container>\n    </mat-menu>\n  </button>\n</ng-template>\n"]}
|
package/esm2020/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.mjs
CHANGED
|
@@ -7,8 +7,7 @@ import * as i1 from "@angular/common";
|
|
|
7
7
|
import * as i2 from "@angular/material/menu";
|
|
8
8
|
import * as i3 from "@angular/material/button";
|
|
9
9
|
import * as i4 from "@angular/material/icon";
|
|
10
|
-
import * as i5 from "@
|
|
11
|
-
import * as i6 from "@ngx-translate/core";
|
|
10
|
+
import * as i5 from "@ngx-translate/core";
|
|
12
11
|
export class ElderSingleSortComponent {
|
|
13
12
|
/***************************************************************************
|
|
14
13
|
* *
|
|
@@ -74,10 +73,10 @@ export class ElderSingleSortComponent {
|
|
|
74
73
|
}
|
|
75
74
|
}
|
|
76
75
|
ElderSingleSortComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderSingleSortComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
77
|
-
ElderSingleSortComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderSingleSortComponent, selector: "elder-single-sort", inputs: { availableSorts: "availableSorts", translationPrefix: "translationPrefix", sort: "sort" }, outputs: { sortChange: "sortChange" }, ngImport: i0, template: "<div *ngIf=\"(sort$ | async) as sort\"
|
|
76
|
+
ElderSingleSortComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderSingleSortComponent, selector: "elder-single-sort", inputs: { availableSorts: "availableSorts", translationPrefix: "translationPrefix", sort: "sort" }, outputs: { sortChange: "sortChange" }, ngImport: i0, template: "<div *ngIf=\"(sort$ | async) as sort\" class=\"layout-row flex-none\">\n\n <button mat-button type=\"button\" [matMenuTriggerFor]=\"menu\">\n\n {{ translationPrefix + sort.prop | translate}}\n\n <mat-icon style=\"font-size: 22px\">sort</mat-icon>\n\n <mat-menu #menu=\"matMenu\">\n <button mat-menu-item type=\"button\"\n *ngFor=\"let mysort of availableSorts\"\n (click)=\"setSortProp(mysort)\"\n >\n <mat-icon>sort</mat-icon>\n <span [class.mat-body-strong]=\"sort.prop == mysort\">{{translationPrefix + mysort | translate}}</span>\n </button>\n </mat-menu>\n\n </button>\n\n <button mat-icon-button type=\"button\" (click)=\"toggleSortDirection($event)\">\n <mat-icon style=\"font-size: 22px\">{{sort.dir === 'asc' ? 'arrow_downward' : 'arrow_upward'}}</mat-icon>\n </button>\n\n</div>\n", styles: [""], 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: "component", type: i2.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i2.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i2.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
78
77
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderSingleSortComponent, decorators: [{
|
|
79
78
|
type: Component,
|
|
80
|
-
args: [{ selector: 'elder-single-sort', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"(sort$ | async) as sort\"
|
|
79
|
+
args: [{ selector: 'elder-single-sort', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"(sort$ | async) as sort\" class=\"layout-row flex-none\">\n\n <button mat-button type=\"button\" [matMenuTriggerFor]=\"menu\">\n\n {{ translationPrefix + sort.prop | translate}}\n\n <mat-icon style=\"font-size: 22px\">sort</mat-icon>\n\n <mat-menu #menu=\"matMenu\">\n <button mat-menu-item type=\"button\"\n *ngFor=\"let mysort of availableSorts\"\n (click)=\"setSortProp(mysort)\"\n >\n <mat-icon>sort</mat-icon>\n <span [class.mat-body-strong]=\"sort.prop == mysort\">{{translationPrefix + mysort | translate}}</span>\n </button>\n </mat-menu>\n\n </button>\n\n <button mat-icon-button type=\"button\" (click)=\"toggleSortDirection($event)\">\n <mat-icon style=\"font-size: 22px\">{{sort.dir === 'asc' ? 'arrow_downward' : 'arrow_upward'}}</mat-icon>\n </button>\n\n</div>\n" }]
|
|
81
80
|
}], ctorParameters: function () { return []; }, propDecorators: { availableSorts: [{
|
|
82
81
|
type: Input
|
|
83
82
|
}], sortChange: [{
|
|
@@ -87,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
|
|
|
87
86
|
}], sort: [{
|
|
88
87
|
type: Input
|
|
89
88
|
}] } });
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-single-sort.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/data-view/common/elder-single-sort/elder-single-sort.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAC,MAAM,eAAe,CAAC;AACtG,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,eAAe,EAAC,MAAM,MAAM,CAAC;AACrC,OAAO,EAAC,IAAI,EAAgB,MAAM,8BAA8B,CAAC;;;;;;;AAQjE,MAAM,OAAO,wBAAwB;IAsBnC;;;;gFAI4E;IAE5E;QAzBA;;;;oFAI4E;QAE3D,QAAG,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QAEtD,UAAK,GAAG,IAAI,eAAe,CAAO,IAAI,CAAC,IAAI,CAAC,CAAC;QAG7C,mBAAc,GAAa,EAAE,CAAC;QAG9B,eAAU,GAAG,IAAI,YAAY,EAAQ,CAAC;QAG/C,sBAAiB,GAAG,kBAAkB,CAAC;IAQ9B,CAAC;IAEjB;;;;gFAI4E;IAE5E,QAAQ;IAER,CAAC;IAED;;;;gFAI4E;IAE5E,IACW,IAAI,CAAC,IAAU;QACxB,IAAI,CAAC,IAAI,EAAE;YACT,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;SAClB;QACD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;IAC/B,CAAC;IAED;;;;gFAI4E;IAErE,WAAW,CAAC,QAAgB;QACjC,MAAM,IAAI,GAAI,IAAI,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IACrB,CAAC;IAEM,mBAAmB,CAAC,KAAY;QAErC,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,GAAkB,CAAC;QACvB,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,KAAK,KAAK,EAAE;YAC3B,GAAG,GAAG,MAAM,CAAC;SACd;aAAM;YACL,GAAG,GAAG,KAAK,CAAC;SACb;QACD,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC;IAC9C,CAAC;IAEO,OAAO,CAAC,IAAU;QACxB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;;sHArFU,wBAAwB;0GAAxB,wBAAwB,oMCXrC,k2BAyBA;4FDda,wBAAwB;kBANpC,SAAS;+BACE,mBAAmB,mBAGZ,uBAAuB,CAAC,MAAM;0EAgB/B,cAAc;sBAD7B,KAAK;gBAIU,UAAU;sBADzB,MAAM;gBAIA,iBAAiB;sBADvB,KAAK;gBA4BK,IAAI;sBADd,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, EventEmitter, Input, OnInit, Output} from '@angular/core';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject} from 'rxjs';\nimport {Sort, SortDirection} from '../../../../common/data/sort';\n\n@Component({\n  selector: 'elder-single-sort',\n  templateUrl: './elder-single-sort.component.html',\n  styleUrls: ['./elder-single-sort.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ElderSingleSortComponent implements OnInit {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly sort$ = new BehaviorSubject<Sort>(Sort.NONE);\n\n  @Input()\n  public readonly availableSorts: string[] = [];\n\n  @Output()\n  public readonly sortChange = new EventEmitter<Sort>();\n\n  @Input()\n  public translationPrefix = 'documents.sorts.';\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  ngOnInit() {\n\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set sort(sort: Sort) {\n    if (!sort) {\n      sort = Sort.NONE;\n    }\n    this.sort$.next(sort);\n  }\n\n  public get sort(): Sort {\n    return this.sort$.getValue();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * API                                                                     *\n   *                                                                         *\n   **************************************************************************/\n\n  public setSortProp(sortProp: string): void {\n    const sort =  new Sort(sortProp, this.sort.dir);\n    this.setSort(sort);\n  }\n\n  public toggleSortDirection(event: Event): void {\n\n    event.stopPropagation();\n\n    let dir: SortDirection;\n    if (this.sort.dir === 'asc') {\n      dir = 'desc';\n    } else {\n      dir = 'asc';\n    }\n    this.setSort(new Sort(this.sort.prop, dir));\n  }\n\n  private setSort(sort: Sort): void {\n    this.sort = sort;\n    this.sortChange.emit(sort);\n  }\n\n}\n","<div *ngIf=\"(sort$ | async) as sort\" class=\"layout-row flex-none\">\n\n  <button mat-button type=\"button\" [matMenuTriggerFor]=\"menu\">\n\n    {{ translationPrefix + sort.prop | translate}}\n\n    <mat-icon style=\"font-size: 22px\">sort</mat-icon>\n\n    <mat-menu #menu=\"matMenu\">\n      <button mat-menu-item type=\"button\"\n              *ngFor=\"let mysort of availableSorts\"\n              (click)=\"setSortProp(mysort)\"\n      >\n        <mat-icon>sort</mat-icon>\n        <span [class.mat-body-strong]=\"sort.prop == mysort\">{{translationPrefix + mysort | translate}}</span>\n      </button>\n    </mat-menu>\n\n  </button>\n\n  <button mat-icon-button type=\"button\" (click)=\"toggleSortDirection($event)\">\n    <mat-icon style=\"font-size: 22px\">{{sort.dir === 'asc' ? 'arrow_downward' : 'arrow_upward'}}</mat-icon>\n  </button>\n\n</div>\n"]}
|
|
@@ -5,7 +5,6 @@ import * as i1 from "../data-context-selection.directive";
|
|
|
5
5
|
import * as i2 from "@angular/common";
|
|
6
6
|
import * as i3 from "@angular/material/checkbox";
|
|
7
7
|
import * as i4 from "@angular/material/badge";
|
|
8
|
-
import * as i5 from "@angular/flex-layout/flex";
|
|
9
8
|
export class ElderSelectionMasterCheckboxComponent {
|
|
10
9
|
/***************************************************************************
|
|
11
10
|
* *
|
|
@@ -30,9 +29,9 @@ export class ElderSelectionMasterCheckboxComponent {
|
|
|
30
29
|
}
|
|
31
30
|
}
|
|
32
31
|
ElderSelectionMasterCheckboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderSelectionMasterCheckboxComponent, deps: [{ token: i1.DataContextSelectionDirective }], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
-
ElderSelectionMasterCheckboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderSelectionMasterCheckboxComponent, selector: "elder-selection-master-checkbox", ngImport: i0, template: "<ng-container *ngIf=\"dataContextSelection?.selectionState$ | async as selectionState\">\n <div\n *ngIf=\"selectionState.isMultiSelection\"\n
|
|
32
|
+
ElderSelectionMasterCheckboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.10", type: ElderSelectionMasterCheckboxComponent, selector: "elder-selection-master-checkbox", ngImport: i0, template: "<ng-container *ngIf=\"dataContextSelection?.selectionState$ | async as selectionState\">\n <div\n *ngIf=\"selectionState.isMultiSelection\"\n class=\"layout-col flex-none\"\n [matBadgeHidden]=\"selectionState.count === 0\"\n [matBadge]=\"selectionState.count + ''\"\n [matBadgePosition]=\"'above before'\"\n [matBadgeOverlap]=\"false\"\n [matBadgeSize]=\"'small'\"\n >\n <mat-checkbox class=\"flex-none\"\n (change)=\"$event ? dataContextSelection.masterToggle() : null\"\n [checked]=\"selectionState.allSelected\"\n [indeterminate]=\"selectionState.someSelected\"\n >\n </mat-checkbox>\n </div>\n</ng-container>\n\n\n\n<!-- -->\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i4.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgeColor", "matBadgeOverlap", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
34
33
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImport: i0, type: ElderSelectionMasterCheckboxComponent, decorators: [{
|
|
35
34
|
type: Component,
|
|
36
|
-
args: [{ selector: 'elder-selection-master-checkbox', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"dataContextSelection?.selectionState$ | async as selectionState\">\n <div\n *ngIf=\"selectionState.isMultiSelection\"\n
|
|
35
|
+
args: [{ selector: 'elder-selection-master-checkbox', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"dataContextSelection?.selectionState$ | async as selectionState\">\n <div\n *ngIf=\"selectionState.isMultiSelection\"\n class=\"layout-col flex-none\"\n [matBadgeHidden]=\"selectionState.count === 0\"\n [matBadge]=\"selectionState.count + ''\"\n [matBadgePosition]=\"'above before'\"\n [matBadgeOverlap]=\"false\"\n [matBadgeSize]=\"'small'\"\n >\n <mat-checkbox class=\"flex-none\"\n (change)=\"$event ? dataContextSelection.masterToggle() : null\"\n [checked]=\"selectionState.allSelected\"\n [indeterminate]=\"selectionState.someSelected\"\n >\n </mat-checkbox>\n </div>\n</ng-container>\n\n\n\n<!-- -->\n" }]
|
|
37
36
|
}], ctorParameters: function () { return [{ type: i1.DataContextSelectionDirective }]; } });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItc2VsZWN0aW9uLW1hc3Rlci1jaGVja2JveC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy9jb21tb24vc2VsZWN0aW9uL2VsZGVyLXNlbGVjdGlvbi1tYXN0ZXItY2hlY2tib3gvZWxkZXItc2VsZWN0aW9uLW1hc3Rlci1jaGVja2JveC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGEtdmlldy9jb21tb24vc2VsZWN0aW9uL2VsZGVyLXNlbGVjdGlvbi1tYXN0ZXItY2hlY2tib3gvZWxkZXItc2VsZWN0aW9uLW1hc3Rlci1jaGVja2JveC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFTLE1BQU0sZUFBZSxDQUFDO0FBQ3pFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7O0FBU25ELE1BQU0sT0FBTyxxQ0FBcUM7SUFVaEQ7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ2tCLG9CQUFtRDtRQUFuRCx5QkFBb0IsR0FBcEIsb0JBQW9CLENBQStCO1FBZnJFOzs7O29GQUk0RTtRQUUzRCxXQUFNLEdBQUcsYUFBYSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBVXJFLENBQUM7SUFFTDs7OztnRkFJNEU7SUFFckUsUUFBUTtJQUVmLENBQUM7O21JQTVCVSxxQ0FBcUM7dUhBQXJDLHFDQUFxQyx1RUNWbEQsNnNCQXNCQTs0RkRaYSxxQ0FBcUM7a0JBTmpELFNBQVM7K0JBQ0UsaUNBQWlDLG1CQUcxQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtMb2dnZXJGYWN0b3J5fSBmcm9tICdAZWxkZXJieXRlL3RzLWxvZ2dlcic7XG5pbXBvcnQge0RhdGFDb250ZXh0U2VsZWN0aW9uRGlyZWN0aXZlfSBmcm9tICcuLi9kYXRhLWNvbnRleHQtc2VsZWN0aW9uLmRpcmVjdGl2ZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2VsZGVyLXNlbGVjdGlvbi1tYXN0ZXItY2hlY2tib3gnLFxuICB0ZW1wbGF0ZVVybDogJy4vZWxkZXItc2VsZWN0aW9uLW1hc3Rlci1jaGVja2JveC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2VsZGVyLXNlbGVjdGlvbi1tYXN0ZXItY2hlY2tib3guY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJTZWxlY3Rpb25NYXN0ZXJDaGVja2JveENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIEZpZWxkcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHJpdmF0ZSByZWFkb25seSBsb2dnZXIgPSBMb2dnZXJGYWN0b3J5LmdldExvZ2dlcih0aGlzLmNvbnN0cnVjdG9yLm5hbWUpO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvciAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZWFkb25seSBkYXRhQ29udGV4dFNlbGVjdGlvbjogRGF0YUNvbnRleHRTZWxlY3Rpb25EaXJlY3RpdmVcbiAgKSB7IH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogTGlmZSBDeWNsZSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG5cbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQcm9wZXJ0aWVzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQdWJsaWMgQVBJICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG59XG4iLCI8bmctY29udGFpbmVyICpuZ0lmPVwiZGF0YUNvbnRleHRTZWxlY3Rpb24/LnNlbGVjdGlvblN0YXRlJCB8IGFzeW5jIGFzIHNlbGVjdGlvblN0YXRlXCI+XG4gIDxkaXZcbiAgICAqbmdJZj1cInNlbGVjdGlvblN0YXRlLmlzTXVsdGlTZWxlY3Rpb25cIlxuICAgIGNsYXNzPVwibGF5b3V0LWNvbCBmbGV4LW5vbmVcIlxuICAgIFttYXRCYWRnZUhpZGRlbl09XCJzZWxlY3Rpb25TdGF0ZS5jb3VudCA9PT0gMFwiXG4gICAgW21hdEJhZGdlXT1cInNlbGVjdGlvblN0YXRlLmNvdW50ICsgJydcIlxuICAgIFttYXRCYWRnZVBvc2l0aW9uXT1cIidhYm92ZSBiZWZvcmUnXCJcbiAgICBbbWF0QmFkZ2VPdmVybGFwXT1cImZhbHNlXCJcbiAgICBbbWF0QmFkZ2VTaXplXT1cIidzbWFsbCdcIlxuICA+XG4gICAgPG1hdC1jaGVja2JveCBjbGFzcz1cImZsZXgtbm9uZVwiXG4gICAgICAgICAgICAgICAgICAoY2hhbmdlKT1cIiRldmVudCA/IGRhdGFDb250ZXh0U2VsZWN0aW9uLm1hc3RlclRvZ2dsZSgpIDogbnVsbFwiXG4gICAgICAgICAgICAgICAgICBbY2hlY2tlZF09XCJzZWxlY3Rpb25TdGF0ZS5hbGxTZWxlY3RlZFwiXG4gICAgICAgICAgICAgICAgICBbaW5kZXRlcm1pbmF0ZV09XCJzZWxlY3Rpb25TdGF0ZS5zb21lU2VsZWN0ZWRcIlxuICAgID5cbiAgICA8L21hdC1jaGVja2JveD5cbiAgPC9kaXY+XG48L25nLWNvbnRhaW5lcj5cblxuXG5cbjwhLS0gIC0tPlxuIl19
|