ngx-edu-sharing-ui 9.1.4 → 10.0.0
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/assets/scss/mixins.scss +4 -4
- package/assets/scss/variables-scss.scss +6 -0
- package/assets/scss/variables.scss +2 -3
- package/esm2022/lib/actionbar/actionbar.component.mjs +13 -10
- package/esm2022/lib/common/edu-sharing-ui-common.module.mjs +8 -5
- package/esm2022/lib/directives/border-box-observer.directive.mjs +7 -7
- package/esm2022/lib/directives/check-text-overflow.directive.mjs +6 -6
- package/esm2022/lib/directives/drag-nodes/nodes-drag-source.directive.mjs +5 -5
- package/esm2022/lib/directives/drag-nodes/nodes-drag.directive.mjs +5 -5
- package/esm2022/lib/directives/drag-nodes/nodes-drop-target.directive.mjs +5 -5
- package/esm2022/lib/directives/focus-state.directive.mjs +5 -5
- package/esm2022/lib/directives/icon.directive.mjs +6 -6
- package/esm2022/lib/directives/infinite-scroll.directive.mjs +5 -5
- package/esm2022/lib/dropdown/dropdown.component.mjs +17 -11
- package/esm2022/lib/edu-sharing-ui-configuration.mjs +4 -4
- package/esm2022/lib/edu-sharing-ui.module.mjs +5 -5
- package/esm2022/lib/index.mjs +4 -1
- package/esm2022/lib/list-items/format-duration.pipe.mjs +4 -4
- package/esm2022/lib/list-items/list-base/list-base.component.mjs +5 -5
- package/esm2022/lib/list-items/list-collection-info/list-collection-info.component.mjs +5 -5
- package/esm2022/lib/list-items/list-counts/list-counts.component.mjs +4 -4
- package/esm2022/lib/list-items/list-items.module.mjs +5 -5
- package/esm2022/lib/list-items/list-node-license/list-node-license.component.mjs +5 -5
- package/esm2022/lib/list-items/list-node-replication-source/list-node-replication-source.component.mjs +5 -5
- package/esm2022/lib/list-items/list-node-workflow/list-node-workflow.component.mjs +6 -6
- package/esm2022/lib/list-items/list-text/list-text.component.mjs +12 -12
- package/esm2022/lib/list-items/list-widget.mjs +5 -5
- package/esm2022/lib/list-items/node-row/node-row.component.mjs +5 -5
- package/esm2022/lib/list-items/node-source.pipe.mjs +5 -5
- package/esm2022/lib/mds/mds-helper.service.mjs +5 -5
- package/esm2022/lib/mds/mds.module.mjs +5 -5
- package/esm2022/lib/node-entries/drag-preview/drag-preview.component.mjs +4 -4
- package/esm2022/lib/node-entries/entries-model.mjs +1 -1
- package/esm2022/lib/node-entries/items-cap.mjs +1 -1
- package/esm2022/lib/node-entries/list-item-label.pipe.mjs +5 -5
- package/esm2022/lib/node-entries/node-cache.mjs +1 -1
- package/esm2022/lib/node-entries/node-data-source-remote.mjs +1 -1
- package/esm2022/lib/node-entries/node-data-source.mjs +1 -1
- package/esm2022/lib/node-entries/node-entries-card/node-entries-card.component.mjs +8 -8
- package/esm2022/lib/node-entries/node-entries-card-grid/node-entries-card-grid.component.mjs +8 -7
- package/esm2022/lib/node-entries/node-entries-card-small/node-entries-card-small.component.mjs +8 -9
- package/esm2022/lib/node-entries/node-entries-global-options/node-entries-global-options.component.mjs +6 -6
- package/esm2022/lib/node-entries/node-entries-global.service.mjs +5 -5
- package/esm2022/lib/node-entries/node-entries-table/column-chooser/column-chooser.component.mjs +6 -6
- package/esm2022/lib/node-entries/node-entries-table/node-entries-table.component.mjs +10 -7
- package/esm2022/lib/node-entries/node-entries-templates.service.mjs +5 -5
- package/esm2022/lib/node-entries/node-entries-wrapper.component.mjs +54 -21
- package/esm2022/lib/node-entries/node-entries.component.mjs +7 -7
- package/esm2022/lib/node-entries/node-entries.module.mjs +5 -5
- package/esm2022/lib/node-entries/node-rating/node-rating.component.mjs +5 -5
- package/esm2022/lib/node-entries/node-stats-badges/node-stats-badges.component.mjs +6 -6
- package/esm2022/lib/node-entries/node-type-badge/node-type-badge.component.mjs +5 -5
- package/esm2022/lib/node-entries/option-button/option-button.component.mjs +7 -7
- package/esm2022/lib/node-entries/preview-image/preview-image.component.mjs +5 -5
- package/esm2022/lib/node-entries/sort-select-panel/sort-select-panel.component.mjs +6 -6
- package/esm2022/lib/node-url/node-url.component.mjs +5 -5
- package/esm2022/lib/pipes/file-size.pipe.mjs +5 -5
- package/esm2022/lib/pipes/format-date.pipe.mjs +5 -5
- package/esm2022/lib/pipes/node-icon.pipe.mjs +5 -5
- package/esm2022/lib/pipes/node-image-size.pipe.mjs +4 -4
- package/esm2022/lib/pipes/node-image.pipe.mjs +5 -5
- package/esm2022/lib/pipes/node-license.pipe.mjs +24 -0
- package/esm2022/lib/pipes/node-person-name.pipe.mjs +5 -5
- package/esm2022/lib/pipes/node-title.pipe.mjs +17 -8
- package/esm2022/lib/pipes/option-tooltip.pipe.mjs +5 -5
- package/esm2022/lib/pipes/property-slug.pipe.mjs +4 -4
- package/esm2022/lib/pipes/replace-chars.pipe.mjs +5 -5
- package/esm2022/lib/pipes/vcard-name.pipe.mjs +11 -5
- package/esm2022/lib/services/abstract/keyboard-shortcuts.service.mjs +4 -4
- package/esm2022/lib/services/accessibility.service.mjs +5 -5
- package/esm2022/lib/services/app-container.service.mjs +8 -5
- package/esm2022/lib/services/local-events.service.mjs +11 -4
- package/esm2022/lib/services/node-entries.service.mjs +9 -10
- package/esm2022/lib/services/node-helper.service.mjs +23 -7
- package/esm2022/lib/services/nodes-drag-drop.service.mjs +5 -5
- package/esm2022/lib/services/options-helper-data.service.mjs +6 -6
- package/esm2022/lib/services/render-helper.service.mjs +114 -0
- package/esm2022/lib/services/repo-url.service.mjs +5 -5
- package/esm2022/lib/services/search-helper.service.mjs +5 -5
- package/esm2022/lib/services/temporary-storage.service.mjs +5 -5
- package/esm2022/lib/services/ui.service.mjs +10 -10
- package/esm2022/lib/sort-dropdown/sort-dropdown.component.mjs +9 -9
- package/esm2022/lib/spinner/spinner.component.mjs +8 -8
- package/esm2022/lib/translations/translation-loader.mjs +45 -10
- package/esm2022/lib/translations/translations.module.mjs +10 -8
- package/esm2022/lib/translations/translations.service.mjs +26 -10
- package/esm2022/lib/types/api-models.mjs +1 -1
- package/esm2022/lib/types/injection-tokens.mjs +10 -1
- package/esm2022/lib/types/list-item.mjs +1 -1
- package/esm2022/lib/types/option-item.mjs +11 -1
- package/esm2022/lib/util/DateHelper.mjs +1 -1
- package/esm2022/lib/util/VCard.mjs +2 -2
- package/esm2022/lib/util/color-helper.mjs +1 -1
- package/esm2022/lib/util/duration-helper.mjs +1 -1
- package/esm2022/lib/util/helper.mjs +1 -1
- package/esm2022/lib/util/rest-helper.mjs +1 -1
- package/fesm2022/ngx-edu-sharing-ui.mjs +648 -373
- package/fesm2022/ngx-edu-sharing-ui.mjs.map +1 -1
- package/lib/actionbar/actionbar.component.d.ts +2 -1
- package/lib/common/edu-sharing-ui-common.module.d.ts +17 -16
- package/lib/dropdown/dropdown.component.d.ts +4 -3
- package/lib/index.d.ts +3 -0
- package/lib/list-items/list-text/list-text.component.d.ts +4 -5
- package/lib/list-items/list-widget.d.ts +1 -1
- package/lib/node-entries/entries-model.d.ts +3 -0
- package/lib/node-entries/node-data-source-remote.d.ts +2 -2
- package/lib/node-entries/node-entries-card-small/node-entries-card-small.component.d.ts +1 -3
- package/lib/node-entries/node-entries-wrapper.component.d.ts +9 -2
- package/lib/pipes/node-license.pipe.d.ts +14 -0
- package/lib/pipes/node-title.pipe.d.ts +3 -1
- package/lib/pipes/vcard-name.pipe.d.ts +1 -1
- package/lib/services/app-container.service.d.ts +2 -1
- package/lib/services/local-events.service.d.ts +7 -0
- package/lib/services/node-entries.service.d.ts +5 -2
- package/lib/services/render-helper.service.d.ts +24 -0
- package/lib/services/ui.service.d.ts +3 -2
- package/lib/sort-dropdown/sort-dropdown.component.d.ts +2 -2
- package/lib/translations/translation-loader.d.ts +3 -1
- package/lib/translations/translations.service.d.ts +1 -0
- package/lib/types/api-models.d.ts +9 -0
- package/lib/types/injection-tokens.d.ts +9 -0
- package/lib/types/list-item.d.ts +2 -2
- package/lib/types/option-item.d.ts +36 -25
- package/lib/util/ui-constants.d.ts +2 -2
- package/package.json +7 -7
|
@@ -113,13 +113,13 @@ export class NodeRatingComponent {
|
|
|
113
113
|
isFromHomeRepo(node) {
|
|
114
114
|
return this.networkApi.isFromHomeRepository(node);
|
|
115
115
|
}
|
|
116
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
117
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
116
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeRatingComponent, deps: [{ token: i1.Toast }, { token: i2.ConfigService }, { token: i2.NetworkService }, { token: i2.AuthenticationService }, { token: i0.ChangeDetectorRef }, { token: i2.RatingV1Service }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
117
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeRatingComponent, selector: "es-node-rating", inputs: { node: "node" }, ngImport: i0, template: "<ng-container *ngIf=\"hasPermission && node.type === 'ccm:io' && isFromHomeRepo(node)\">\n <div *ngIf=\"mode === 'likes'\" class=\"likes\">\n <button\n (click)=\"toogleLike()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n mat-icon-button\n color=\"primary\"\n matTooltip=\"{{ 'RATING.LIKES' | translate }}\"\n >\n <i [esIcon]=\"'edu-thumb_up' + (!node.rating?.user ? '_off' : '')\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_LIKES' | translate }}\">{{\n node.rating?.overall.count\n }}</span>\n </div>\n <div *ngIf=\"mode === 'stars'\" class=\"stars\" mat-icon-button color=\"primary\">\n <button\n *ngFor=\"let rating of [1, 2, 3, 4, 5]\"\n mat-icon-button\n color=\"primary\"\n class=\"star\"\n (click)=\"setRating(rating)\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n (focus)=\"hoverStar = rating\"\n (mouseenter)=\"hoverStar = rating\"\n (mouseleave)=\"hoverStar = 0\"\n (blur)=\"hoverStar = 0\"\n [class.star-hover]=\"hoverStar >= rating\"\n >\n <i\n [esIcon]=\"\n 'star' +\n ((hoverStar ? hoverStar >= rating : getPrimaryRating() >= rating) ? '' : '_border')\n \"\n matTooltip=\"{{ 'RATING.STARS_RATE' | translate : { rating: rating } }}\"\n ></i>\n </button>\n <button\n *ngIf=\"!!node.rating?.user\"\n mat-icon-button\n color=\"primary\"\n class=\"delete\"\n matTooltip=\"{{ 'RATING.DELETE_RATING' | translate }}\"\n (click)=\"deleteRating()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n >\n <i esIcon=\"clear\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_RATINGS' | translate }}\"\n >({{ node.rating?.overall.count }})</span\n >\n </div>\n</ng-container>\n", styles: [".stars{display:flex;align-items:center}.stars span{padding-left:8px}.likes{display:flex;align-items:center}.mdc-icon-button.mat-primary{color:var(--textLight);display:flex;align-items:center;padding:0}.mdc-icon-button.mat-primary.star,.mdc-icon-button.mat-primary.delete{min-width:unset;width:18px;height:18px}.mdc-icon-button.mat-primary.star i,.mdc-icon-button.mat-primary.delete i{font-size:17px;line-height:1}.mdc-icon-button.mat-primary.star ::ng-deep .mat-mdc-button-touch-target,.mdc-icon-button.mat-primary.delete ::ng-deep .mat-mdc-button-touch-target{display:none}.mdc-icon-button.mat-primary.star.star-hover,.mdc-icon-button.mat-primary.delete.star-hover{color:var(--colorStarActive)}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "component", type: i5.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
|
|
118
118
|
}
|
|
119
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
119
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeRatingComponent, decorators: [{
|
|
120
120
|
type: Component,
|
|
121
121
|
args: [{ selector: 'es-node-rating', template: "<ng-container *ngIf=\"hasPermission && node.type === 'ccm:io' && isFromHomeRepo(node)\">\n <div *ngIf=\"mode === 'likes'\" class=\"likes\">\n <button\n (click)=\"toogleLike()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n mat-icon-button\n color=\"primary\"\n matTooltip=\"{{ 'RATING.LIKES' | translate }}\"\n >\n <i [esIcon]=\"'edu-thumb_up' + (!node.rating?.user ? '_off' : '')\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_LIKES' | translate }}\">{{\n node.rating?.overall.count\n }}</span>\n </div>\n <div *ngIf=\"mode === 'stars'\" class=\"stars\" mat-icon-button color=\"primary\">\n <button\n *ngFor=\"let rating of [1, 2, 3, 4, 5]\"\n mat-icon-button\n color=\"primary\"\n class=\"star\"\n (click)=\"setRating(rating)\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n (focus)=\"hoverStar = rating\"\n (mouseenter)=\"hoverStar = rating\"\n (mouseleave)=\"hoverStar = 0\"\n (blur)=\"hoverStar = 0\"\n [class.star-hover]=\"hoverStar >= rating\"\n >\n <i\n [esIcon]=\"\n 'star' +\n ((hoverStar ? hoverStar >= rating : getPrimaryRating() >= rating) ? '' : '_border')\n \"\n matTooltip=\"{{ 'RATING.STARS_RATE' | translate : { rating: rating } }}\"\n ></i>\n </button>\n <button\n *ngIf=\"!!node.rating?.user\"\n mat-icon-button\n color=\"primary\"\n class=\"delete\"\n matTooltip=\"{{ 'RATING.DELETE_RATING' | translate }}\"\n (click)=\"deleteRating()\"\n [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n >\n <i esIcon=\"clear\"></i>\n </button>\n <span matTooltip=\"{{ 'RATING.COUNT_RATINGS' | translate }}\"\n >({{ node.rating?.overall.count }})</span\n >\n </div>\n</ng-container>\n", styles: [".stars{display:flex;align-items:center}.stars span{padding-left:8px}.likes{display:flex;align-items:center}.mdc-icon-button.mat-primary{color:var(--textLight);display:flex;align-items:center;padding:0}.mdc-icon-button.mat-primary.star,.mdc-icon-button.mat-primary.delete{min-width:unset;width:18px;height:18px}.mdc-icon-button.mat-primary.star i,.mdc-icon-button.mat-primary.delete i{font-size:17px;line-height:1}.mdc-icon-button.mat-primary.star ::ng-deep .mat-mdc-button-touch-target,.mdc-icon-button.mat-primary.delete ::ng-deep .mat-mdc-button-touch-target{display:none}.mdc-icon-button.mat-primary.star.star-hover,.mdc-icon-button.mat-primary.delete.star-hover{color:var(--colorStarActive)}\n"] }]
|
|
122
|
-
}], ctorParameters:
|
|
122
|
+
}], ctorParameters: () => [{ type: i1.Toast }, { type: i2.ConfigService }, { type: i2.NetworkService }, { type: i2.AuthenticationService }, { type: i0.ChangeDetectorRef }, { type: i2.RatingV1Service }], propDecorators: { node: [{
|
|
123
123
|
type: Input
|
|
124
124
|
}] } });
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-rating.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-rating/node-rating.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-rating/node-rating.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input, OnInit } from '@angular/core';\nimport {\n    Node,\n    ConfigService,\n    AuthenticationService,\n    RestConstants,\n    NetworkService,\n    RatingV1Service,\n} from 'ngx-edu-sharing-api';\nimport { Toast } from '../../services/abstract/toast.service';\nimport { take, takeUntil } from 'rxjs/operators';\nimport { RestHelper } from '../../util/rest-helper';\n\n@Component({\n    selector: 'es-node-rating',\n    templateUrl: 'node-rating.component.html',\n    styleUrls: ['node-rating.component.scss'],\n})\nexport class NodeRatingComponent<T extends Node> implements OnInit {\n    @Input() node: T;\n    mode: RatingMode;\n    hasPermission: boolean;\n    hoverStar: number;\n    constructor(\n        public toast: Toast,\n        public configService: ConfigService,\n        private networkApi: NetworkService,\n        public authenticationService: AuthenticationService,\n        public changeDetectorRef: ChangeDetectorRef,\n        public ratingService: RatingV1Service,\n    ) {}\n\n    async ngOnInit() {\n        await this.configService.observeConfig().pipe(take(1)).toPromise();\n        this.mode = this.configService.instant('rating.mode', 'none');\n        this.hasPermission = await this.authenticationService.hasToolpermission(\n            RestConstants.TOOLPERMISSION_RATE_READ,\n        );\n    }\n\n    async toogleLike() {\n        const name = RestHelper.getTitle(this.node);\n        if (this.node.rating?.user) {\n            try {\n                await this.ratingService\n                    .deleteRating({\n                        repository: this.node.ref.repo,\n                        node: this.node.ref.id,\n                    })\n                    .toPromise();\n                this.toast.toast('RATING.TOAST.LIKE_REMOVED', { name });\n                this.node.rating.user = 0;\n                this.node.rating.overall.count--;\n            } catch (e) {\n                this.toast.error(e);\n            }\n        } else {\n            try {\n                await this.ratingService\n                    .addOrUpdateRating({\n                        repository: this.node.ref.repo,\n                        node: this.node.ref.id,\n                        rating: 5,\n                        body: null,\n                    })\n                    .toPromise();\n                this.toast.toast('RATING.TOAST.LIKED', { name });\n                this.node.rating.user = 5;\n                this.node.rating.overall.count++;\n            } catch (e) {\n                this.toast.error(e);\n            }\n        }\n        this.changeDetectorRef.detectChanges();\n    }\n\n    getPrimaryRating() {\n        if (!this.node.rating) {\n            return 0;\n        }\n        if (this.node.rating.user) {\n            return this.node.rating.user;\n        }\n        return this.node.rating.overall.sum / this.node.rating.overall.count;\n    }\n\n    async setRating(rating: number) {\n        const name = RestHelper.getTitle(this.node);\n        try {\n            await this.ratingService\n                .addOrUpdateRating({\n                    repository: this.node.ref.repo,\n                    node: this.node.ref.id,\n                    rating,\n                    body: null,\n                })\n                .toPromise();\n            this.toast.toast('RATING.TOAST.RATED', { name, rating });\n            this.node.rating.overall.count += this.node.rating.user ? 0 : 1;\n            this.node.rating.user = rating;\n            this.changeDetectorRef.detectChanges();\n        } catch (e) {\n            this.toast.error(e);\n        }\n    }\n\n    async deleteRating() {\n        const name = RestHelper.getTitle(this.node);\n        try {\n            await this.ratingService\n                .deleteRating({\n                    repository: this.node.ref.repo,\n                    node: this.node.ref.id,\n                })\n                .toPromise();\n            this.toast.toast('RATING.TOAST.RATING_REMOVED', { name });\n            this.node.rating.overall.count--;\n            this.node.rating.overall.sum -= this.node.rating.user;\n            this.node.rating.user = 0;\n            this.changeDetectorRef.detectChanges();\n        } catch (e) {\n            this.toast.error(e);\n        }\n    }\n\n    isFromHomeRepo(node: Node) {\n        return this.networkApi.isFromHomeRepository(node);\n    }\n}\nexport type RatingMode = 'none' | 'likes' | 'stars';\n","<ng-container *ngIf=\"hasPermission && node.type === 'ccm:io' && isFromHomeRepo(node)\">\n  <div *ngIf=\"mode === 'likes'\" class=\"likes\">\n    <button\n      (click)=\"toogleLike()\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n      mat-icon-button\n      color=\"primary\"\n      matTooltip=\"{{ 'RATING.LIKES' | translate }}\"\n    >\n      <i [esIcon]=\"'edu-thumb_up' + (!node.rating?.user ? '_off' : '')\"></i>\n    </button>\n    <span matTooltip=\"{{ 'RATING.COUNT_LIKES' | translate }}\">{{\n      node.rating?.overall.count\n    }}</span>\n  </div>\n  <div *ngIf=\"mode === 'stars'\" class=\"stars\" mat-icon-button color=\"primary\">\n    <button\n      *ngFor=\"let rating of [1, 2, 3, 4, 5]\"\n      mat-icon-button\n      color=\"primary\"\n      class=\"star\"\n      (click)=\"setRating(rating)\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n      (focus)=\"hoverStar = rating\"\n      (mouseenter)=\"hoverStar = rating\"\n      (mouseleave)=\"hoverStar = 0\"\n      (blur)=\"hoverStar = 0\"\n      [class.star-hover]=\"hoverStar >= rating\"\n    >\n      <i\n        [esIcon]=\"\n          'star' +\n          ((hoverStar ? hoverStar >= rating : getPrimaryRating() >= rating) ? '' : '_border')\n        \"\n        matTooltip=\"{{ 'RATING.STARS_RATE' | translate : { rating: rating } }}\"\n      ></i>\n    </button>\n    <button\n      *ngIf=\"!!node.rating?.user\"\n      mat-icon-button\n      color=\"primary\"\n      class=\"delete\"\n      matTooltip=\"{{ 'RATING.DELETE_RATING' | translate }}\"\n      (click)=\"deleteRating()\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n    >\n      <i esIcon=\"clear\"></i>\n    </button>\n    <span matTooltip=\"{{ 'RATING.COUNT_RATINGS' | translate }}\"\n      >({{ node.rating?.overall.count }})</span\n    >\n  </div>\n</ng-container>\n"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-rating.component.js","sourceRoot":"","sources":["../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-rating/node-rating.component.ts","../../../../../../projects/edu-sharing-ui/src/lib/node-entries/node-rating/node-rating.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input, OnInit } from '@angular/core';\nimport {\n    Node,\n    ConfigService,\n    AuthenticationService,\n    RestConstants,\n    NetworkService,\n    RatingV1Service,\n} from 'ngx-edu-sharing-api';\nimport { Toast } from '../../services/abstract/toast.service';\nimport { take, takeUntil } from 'rxjs/operators';\nimport { RestHelper } from '../../util/rest-helper';\n\n@Component({\n    selector: 'es-node-rating',\n    templateUrl: 'node-rating.component.html',\n    styleUrls: ['node-rating.component.scss'],\n})\nexport class NodeRatingComponent<T extends Node> implements OnInit {\n    @Input() node: T;\n    mode: RatingMode;\n    hasPermission: boolean;\n    hoverStar: number;\n    constructor(\n        public toast: Toast,\n        public configService: ConfigService,\n        private networkApi: NetworkService,\n        public authenticationService: AuthenticationService,\n        public changeDetectorRef: ChangeDetectorRef,\n        public ratingService: RatingV1Service,\n    ) {}\n\n    async ngOnInit() {\n        await this.configService.observeConfig().pipe(take(1)).toPromise();\n        this.mode = this.configService.instant('rating.mode', 'none');\n        this.hasPermission = await this.authenticationService.hasToolpermission(\n            RestConstants.TOOLPERMISSION_RATE_READ,\n        );\n    }\n\n    async toogleLike() {\n        const name = RestHelper.getTitle(this.node);\n        if (this.node.rating?.user) {\n            try {\n                await this.ratingService\n                    .deleteRating({\n                        repository: this.node.ref.repo,\n                        node: this.node.ref.id,\n                    })\n                    .toPromise();\n                this.toast.toast('RATING.TOAST.LIKE_REMOVED', { name });\n                this.node.rating.user = 0;\n                this.node.rating.overall.count--;\n            } catch (e) {\n                this.toast.error(e);\n            }\n        } else {\n            try {\n                await this.ratingService\n                    .addOrUpdateRating({\n                        repository: this.node.ref.repo,\n                        node: this.node.ref.id,\n                        rating: 5,\n                        body: null,\n                    })\n                    .toPromise();\n                this.toast.toast('RATING.TOAST.LIKED', { name });\n                this.node.rating.user = 5;\n                this.node.rating.overall.count++;\n            } catch (e) {\n                this.toast.error(e);\n            }\n        }\n        this.changeDetectorRef.detectChanges();\n    }\n\n    getPrimaryRating() {\n        if (!this.node.rating) {\n            return 0;\n        }\n        if (this.node.rating.user) {\n            return this.node.rating.user;\n        }\n        return this.node.rating.overall.sum / this.node.rating.overall.count;\n    }\n\n    async setRating(rating: number) {\n        const name = RestHelper.getTitle(this.node);\n        try {\n            await this.ratingService\n                .addOrUpdateRating({\n                    repository: this.node.ref.repo,\n                    node: this.node.ref.id,\n                    rating,\n                    body: null,\n                })\n                .toPromise();\n            this.toast.toast('RATING.TOAST.RATED', { name, rating });\n            this.node.rating.overall.count += this.node.rating.user ? 0 : 1;\n            this.node.rating.user = rating;\n            this.changeDetectorRef.detectChanges();\n        } catch (e) {\n            this.toast.error(e);\n        }\n    }\n\n    async deleteRating() {\n        const name = RestHelper.getTitle(this.node);\n        try {\n            await this.ratingService\n                .deleteRating({\n                    repository: this.node.ref.repo,\n                    node: this.node.ref.id,\n                })\n                .toPromise();\n            this.toast.toast('RATING.TOAST.RATING_REMOVED', { name });\n            this.node.rating.overall.count--;\n            this.node.rating.overall.sum -= this.node.rating.user;\n            this.node.rating.user = 0;\n            this.changeDetectorRef.detectChanges();\n        } catch (e) {\n            this.toast.error(e);\n        }\n    }\n\n    isFromHomeRepo(node: Node) {\n        return this.networkApi.isFromHomeRepository(node);\n    }\n}\nexport type RatingMode = 'none' | 'likes' | 'stars';\n","<ng-container *ngIf=\"hasPermission && node.type === 'ccm:io' && isFromHomeRepo(node)\">\n  <div *ngIf=\"mode === 'likes'\" class=\"likes\">\n    <button\n      (click)=\"toogleLike()\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n      mat-icon-button\n      color=\"primary\"\n      matTooltip=\"{{ 'RATING.LIKES' | translate }}\"\n    >\n      <i [esIcon]=\"'edu-thumb_up' + (!node.rating?.user ? '_off' : '')\"></i>\n    </button>\n    <span matTooltip=\"{{ 'RATING.COUNT_LIKES' | translate }}\">{{\n      node.rating?.overall.count\n    }}</span>\n  </div>\n  <div *ngIf=\"mode === 'stars'\" class=\"stars\" mat-icon-button color=\"primary\">\n    <button\n      *ngFor=\"let rating of [1, 2, 3, 4, 5]\"\n      mat-icon-button\n      color=\"primary\"\n      class=\"star\"\n      (click)=\"setRating(rating)\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n      (focus)=\"hoverStar = rating\"\n      (mouseenter)=\"hoverStar = rating\"\n      (mouseleave)=\"hoverStar = 0\"\n      (blur)=\"hoverStar = 0\"\n      [class.star-hover]=\"hoverStar >= rating\"\n    >\n      <i\n        [esIcon]=\"\n          'star' +\n          ((hoverStar ? hoverStar >= rating : getPrimaryRating() >= rating) ? '' : '_border')\n        \"\n        matTooltip=\"{{ 'RATING.STARS_RATE' | translate : { rating: rating } }}\"\n      ></i>\n    </button>\n    <button\n      *ngIf=\"!!node.rating?.user\"\n      mat-icon-button\n      color=\"primary\"\n      class=\"delete\"\n      matTooltip=\"{{ 'RATING.DELETE_RATING' | translate }}\"\n      (click)=\"deleteRating()\"\n      [disabled]=\"(this.authenticationService.observeLoginInfo() | async)?.isGuest\"\n    >\n      <i esIcon=\"clear\"></i>\n    </button>\n    <span matTooltip=\"{{ 'RATING.COUNT_RATINGS' | translate }}\"\n      >({{ node.rating?.overall.count }})</span\n    >\n  </div>\n</ng-container>\n"]}
|
|
@@ -29,15 +29,15 @@ export class NodeStatsBadgesComponent {
|
|
|
29
29
|
return 0;
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
33
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
32
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeStatsBadgesComponent, deps: [{ token: i1.NodeEntriesService, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
33
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeStatsBadgesComponent, selector: "es-node-stats-badges", inputs: { node: "node", backgroundStyle: "backgroundStyle" }, host: { properties: { "attr.backgroundStyle": "this.backgroundStyle" } }, ngImport: i0, template: "<!--\n <div\n *ngIf=\"node.aspects?.includes('ccm:published')\"\n class=\"card-top-bar-published-copy\"\n >\n <div class=\"node-published-copy\">\n <i\n esIcon=\"content_copy\"\n [matTooltip]=\"'PUBLISHED_COPY_TOOLTIP' | translate\"\n ></i>\n </div>\n </div>\n -->\n<div class=\"card-top-bar-comments\">\n <div\n class=\"node-comments\"\n *ngIf=\"node.type === 'ccm:io'\"\n (click)=\"\n entriesService?.onClicked({\n event: $event,\n element: node,\n source: ClickSource.Comments\n })\n \"\n [matTooltip]=\"('COMMENTS_MULTIPLE' | translate) + ': ' + node.commentCount\"\n >\n <i esIcon=\"comment\"></i>\n <span>{{ node.commentCount }}</span>\n </div>\n</div>\n<div class=\"card-top-bar-childobjects\" *ngIf=\"childObjectCount > 0\">\n <div\n class=\"childobject-count\"\n matTooltip=\"{{ 'CHILDOBJECT_COUNT' | translate : { count: childObjectCount + 1 } }}\"\n >\n <span>{{ childObjectCount + 1 }}</span\n ><i esIcon=\"filter_none\"></i>\n </div>\n</div>\n", styles: [":host{display:flex;gap:15px}.card-top-bar-comments>div,.card-top-bar-published-copy>div,.card-top-bar-childobjects>div{border-radius:15px;display:inline-flex;align-items:center;min-width:35px;min-height:22px;justify-content:center;cursor:default;-webkit-user-select:none;user-select:none;padding:2px 8px}:host[backgroundStyle=lighten] .card-top-bar-comments>div,:host[backgroundStyle=lighten] .card-top-bar-published-copy>div,:host[backgroundStyle=lighten] .card-top-bar-childobjects>div{background-color:#ffffffbf}:host[backgroundStyle=darken] .card-top-bar-comments>div,:host[backgroundStyle=darken] .card-top-bar-published-copy>div,:host[backgroundStyle=darken] .card-top-bar-childobjects>div{background-color:#0003}.card-top-bar-comments>div.childobject-count>i,.card-top-bar-published-copy>div.childobject-count>i,.card-top-bar-childobjects>div.childobject-count>i{font-size:13px;margin-left:4px}.card-top-bar-comments>div.node-published-copy,.card-top-bar-published-copy>div.node-published-copy,.card-top-bar-childobjects>div.node-published-copy{min-width:auto}.card-top-bar-comments>div.node-published-copy>i,.card-top-bar-published-copy>div.node-published-copy>i,.card-top-bar-childobjects>div.node-published-copy>i{font-size:13px}.card-top-bar-comments>div.node-comments>i,.card-top-bar-published-copy>div.node-comments>i,.card-top-bar-childobjects>div.node-comments>i{font-size:13px;margin-right:4px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }] }); }
|
|
34
34
|
}
|
|
35
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
35
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeStatsBadgesComponent, decorators: [{
|
|
36
36
|
type: Component,
|
|
37
37
|
args: [{ selector: 'es-node-stats-badges', template: "<!--\n <div\n *ngIf=\"node.aspects?.includes('ccm:published')\"\n class=\"card-top-bar-published-copy\"\n >\n <div class=\"node-published-copy\">\n <i\n esIcon=\"content_copy\"\n [matTooltip]=\"'PUBLISHED_COPY_TOOLTIP' | translate\"\n ></i>\n </div>\n </div>\n -->\n<div class=\"card-top-bar-comments\">\n <div\n class=\"node-comments\"\n *ngIf=\"node.type === 'ccm:io'\"\n (click)=\"\n entriesService?.onClicked({\n event: $event,\n element: node,\n source: ClickSource.Comments\n })\n \"\n [matTooltip]=\"('COMMENTS_MULTIPLE' | translate) + ': ' + node.commentCount\"\n >\n <i esIcon=\"comment\"></i>\n <span>{{ node.commentCount }}</span>\n </div>\n</div>\n<div class=\"card-top-bar-childobjects\" *ngIf=\"childObjectCount > 0\">\n <div\n class=\"childobject-count\"\n matTooltip=\"{{ 'CHILDOBJECT_COUNT' | translate : { count: childObjectCount + 1 } }}\"\n >\n <span>{{ childObjectCount + 1 }}</span\n ><i esIcon=\"filter_none\"></i>\n </div>\n</div>\n", styles: [":host{display:flex;gap:15px}.card-top-bar-comments>div,.card-top-bar-published-copy>div,.card-top-bar-childobjects>div{border-radius:15px;display:inline-flex;align-items:center;min-width:35px;min-height:22px;justify-content:center;cursor:default;-webkit-user-select:none;user-select:none;padding:2px 8px}:host[backgroundStyle=lighten] .card-top-bar-comments>div,:host[backgroundStyle=lighten] .card-top-bar-published-copy>div,:host[backgroundStyle=lighten] .card-top-bar-childobjects>div{background-color:#ffffffbf}:host[backgroundStyle=darken] .card-top-bar-comments>div,:host[backgroundStyle=darken] .card-top-bar-published-copy>div,:host[backgroundStyle=darken] .card-top-bar-childobjects>div{background-color:#0003}.card-top-bar-comments>div.childobject-count>i,.card-top-bar-published-copy>div.childobject-count>i,.card-top-bar-childobjects>div.childobject-count>i{font-size:13px;margin-left:4px}.card-top-bar-comments>div.node-published-copy,.card-top-bar-published-copy>div.node-published-copy,.card-top-bar-childobjects>div.node-published-copy{min-width:auto}.card-top-bar-comments>div.node-published-copy>i,.card-top-bar-published-copy>div.node-published-copy>i,.card-top-bar-childobjects>div.node-published-copy>i{font-size:13px}.card-top-bar-comments>div.node-comments>i,.card-top-bar-published-copy>div.node-comments>i,.card-top-bar-childobjects>div.node-comments>i{font-size:13px;margin-right:4px}\n"] }]
|
|
38
|
-
}], ctorParameters:
|
|
38
|
+
}], ctorParameters: () => [{ type: i1.NodeEntriesService, decorators: [{
|
|
39
39
|
type: Optional
|
|
40
|
-
}] }]
|
|
40
|
+
}] }], propDecorators: { node: [{
|
|
41
41
|
type: Input
|
|
42
42
|
}], backgroundStyle: [{
|
|
43
43
|
type: HostBinding,
|
|
@@ -45,4 +45,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
|
|
|
45
45
|
}, {
|
|
46
46
|
type: Input
|
|
47
47
|
}] } });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1zdGF0cy1iYWRnZXMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9ub2RlLWVudHJpZXMvbm9kZS1zdGF0cy1iYWRnZXMvbm9kZS1zdGF0cy1iYWRnZXMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9ub2RlLWVudHJpZXMvbm9kZS1zdGF0cy1iYWRnZXMvbm9kZS1zdGF0cy1iYWRnZXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV4RSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7Ozs7Ozs7QUFRL0MsTUFBTSxPQUFPLHdCQUF3QjtJQU1qQyxJQUNJLElBQUk7UUFDSixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDdEIsQ0FBQztJQUNELElBQUksSUFBSSxDQUFDLElBQVU7UUFDZixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztRQUNsQixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFNRCxZQUVXLGNBQXdDO1FBQXhDLG1CQUFjLEdBQWQsY0FBYyxDQUEwQjtRQXBCMUMsZ0JBQVcsR0FBRyxXQUFXLENBQUM7UUFFbkMscUJBQWdCLEdBQUcsQ0FBQyxDQUFDO1FBY3JCLG9CQUFlLEdBQXlCLFNBQVMsQ0FBQztJQUsvQyxDQUFDO0lBRUksbUJBQW1CLENBQUMsSUFBVTtRQUNsQyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsMEJBQTBCLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ2pFLElBQUksS0FBSyxFQUFFLENBQUM7WUFDUixPQUFPLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMzQixDQUFDO2FBQU0sQ0FBQztZQUNKLE9BQU8sQ0FBQyxDQUFDO1FBQ2IsQ0FBQztJQUNMLENBQUM7K0dBL0JRLHdCQUF3QjttR0FBeEIsd0JBQXdCLG9NQ1ZyQyxva0NBdUNBOzs0RkQ3QmEsd0JBQXdCO2tCQUxwQyxTQUFTOytCQUNJLHNCQUFzQjs7MEJBd0IzQixRQUFRO3lDQWJULElBQUk7c0JBRFAsS0FBSztnQkFXTixlQUFlO3NCQUZkLFdBQVc7dUJBQUMsc0JBQXNCOztzQkFDbEMsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0LCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTm9kZSB9IGZyb20gJ25neC1lZHUtc2hhcmluZy1hcGknO1xuaW1wb3J0IHsgQ2xpY2tTb3VyY2UgfSBmcm9tICcuLi9lbnRyaWVzLW1vZGVsJztcbmltcG9ydCB7IE5vZGVFbnRyaWVzU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL25vZGUtZW50cmllcy5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdlcy1ub2RlLXN0YXRzLWJhZGdlcycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL25vZGUtc3RhdHMtYmFkZ2VzLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ub2RlLXN0YXRzLWJhZGdlcy5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBOb2RlU3RhdHNCYWRnZXNDb21wb25lbnQge1xuICAgIHJlYWRvbmx5IENsaWNrU291cmNlID0gQ2xpY2tTb3VyY2U7XG5cbiAgICBjaGlsZE9iamVjdENvdW50ID0gMDtcblxuICAgIHByaXZhdGUgX25vZGU6IE5vZGU7XG4gICAgQElucHV0KClcbiAgICBnZXQgbm9kZSgpOiBOb2RlIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX25vZGU7XG4gICAgfVxuICAgIHNldCBub2RlKG5vZGU6IE5vZGUpIHtcbiAgICAgICAgdGhpcy5fbm9kZSA9IG5vZGU7XG4gICAgICAgIHRoaXMuY2hpbGRPYmplY3RDb3VudCA9IHRoaXMuZ2V0Q2hpbGRPYmplY3RDb3VudChub2RlKTtcbiAgICB9XG5cbiAgICBASG9zdEJpbmRpbmcoJ2F0dHIuYmFja2dyb3VuZFN0eWxlJylcbiAgICBASW5wdXQoKVxuICAgIGJhY2tncm91bmRTdHlsZTogJ2RhcmtlbicgfCAnbGlnaHRlbicgPSAnbGlnaHRlbic7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQE9wdGlvbmFsKClcbiAgICAgICAgcHVibGljIGVudHJpZXNTZXJ2aWNlOiBOb2RlRW50cmllc1NlcnZpY2U8Tm9kZT4sXG4gICAgKSB7fVxuXG4gICAgcHJpdmF0ZSBnZXRDaGlsZE9iamVjdENvdW50KG5vZGU6IE5vZGUpOiBudW1iZXIge1xuICAgICAgICBjb25zdCB2YWx1ZSA9IG5vZGUucHJvcGVydGllcz8uWyd2aXJ0dWFsOmNoaWxkb2JqZWN0Y291bnQnXT8uWzBdO1xuICAgICAgICBpZiAodmFsdWUpIHtcbiAgICAgICAgICAgIHJldHVybiBwYXJzZUludCh2YWx1ZSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICByZXR1cm4gMDtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjwhLS1cbiAgICA8ZGl2XG4gICAgICAqbmdJZj1cIm5vZGUuYXNwZWN0cz8uaW5jbHVkZXMoJ2NjbTpwdWJsaXNoZWQnKVwiXG4gICAgICBjbGFzcz1cImNhcmQtdG9wLWJhci1wdWJsaXNoZWQtY29weVwiXG4gICAgPlxuICAgICAgPGRpdiBjbGFzcz1cIm5vZGUtcHVibGlzaGVkLWNvcHlcIj5cbiAgICAgICAgPGlcbiAgICAgICAgICBlc0ljb249XCJjb250ZW50X2NvcHlcIlxuICAgICAgICAgIFttYXRUb29sdGlwXT1cIidQVUJMSVNIRURfQ09QWV9UT09MVElQJyB8IHRyYW5zbGF0ZVwiXG4gICAgICAgID48L2k+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICAtLT5cbjxkaXYgY2xhc3M9XCJjYXJkLXRvcC1iYXItY29tbWVudHNcIj5cbiAgPGRpdlxuICAgIGNsYXNzPVwibm9kZS1jb21tZW50c1wiXG4gICAgKm5nSWY9XCJub2RlLnR5cGUgPT09ICdjY206aW8nXCJcbiAgICAoY2xpY2spPVwiXG4gICAgICBlbnRyaWVzU2VydmljZT8ub25DbGlja2VkKHtcbiAgICAgICAgZXZlbnQ6ICRldmVudCxcbiAgICAgICAgZWxlbWVudDogbm9kZSxcbiAgICAgICAgc291cmNlOiBDbGlja1NvdXJjZS5Db21tZW50c1xuICAgICAgfSlcbiAgICBcIlxuICAgIFttYXRUb29sdGlwXT1cIignQ09NTUVOVFNfTVVMVElQTEUnIHwgdHJhbnNsYXRlKSArICc6ICcgKyBub2RlLmNvbW1lbnRDb3VudFwiXG4gID5cbiAgICA8aSBlc0ljb249XCJjb21tZW50XCI+PC9pPlxuICAgIDxzcGFuPnt7IG5vZGUuY29tbWVudENvdW50IH19PC9zcGFuPlxuICA8L2Rpdj5cbjwvZGl2PlxuPGRpdiBjbGFzcz1cImNhcmQtdG9wLWJhci1jaGlsZG9iamVjdHNcIiAqbmdJZj1cImNoaWxkT2JqZWN0Q291bnQgPiAwXCI+XG4gIDxkaXZcbiAgICBjbGFzcz1cImNoaWxkb2JqZWN0LWNvdW50XCJcbiAgICBtYXRUb29sdGlwPVwie3sgJ0NISUxET0JKRUNUX0NPVU5UJyB8IHRyYW5zbGF0ZSA6IHsgY291bnQ6IGNoaWxkT2JqZWN0Q291bnQgKyAxIH0gfX1cIlxuICA+XG4gICAgPHNwYW4+e3sgY2hpbGRPYmplY3RDb3VudCArIDEgfX08L3NwYW5cbiAgICA+PGkgZXNJY29uPVwiZmlsdGVyX25vbmVcIj48L2k+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -24,13 +24,13 @@ export class NodeTypeBadgeComponent {
|
|
|
24
24
|
getCustomTemplate() {
|
|
25
25
|
return this.nodeEntriesGlobalService.getCustomFieldTemplate({ type: 'NODE', name: CustomFieldSpecialType.type }, this.node);
|
|
26
26
|
}
|
|
27
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
28
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
27
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeTypeBadgeComponent, deps: [{ token: i1.NodeHelperService }, { token: i2.NodeEntriesGlobalService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
28
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeTypeBadgeComponent, selector: "es-node-type-badge", inputs: { node: "node" }, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"isCollection\">\n <i\n [matTooltip]=\"\n 'COLLECTION.SCOPE.' + nodeHelper.getCollectionScopeInfo($any(node)).scopeName | translate\n \"\n [altText]=\"\n 'COLLECTION.SCOPE.' + nodeHelper.getCollectionScopeInfo($any(node)).scopeName | translate\n \"\n [esIcon]=\"nodeHelper.getCollectionScopeInfo($any(node)).icon\"\n ></i>\n</ng-container>\n<ng-container *ngIf=\"!isCollection\">\n <ng-container *ngIf=\"getCustomTemplate() as ref\">\n <ng-container *ngTemplateOutlet=\"ref; context: { node: this.node }\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!getCustomTemplate()\">\n <img\n [src]=\"node | esNodeIcon | async\"\n [alt]=\"\n node.mediatype\n ? ('NODE.mediatype' | translate) + ': ' + ('MEDIATYPE.' + node.mediatype | translate)\n : ''\n \"\n [matTooltip]=\"\n node.mediatype\n ? ('NODE.mediatype' | translate) + ': ' + ('MEDIATYPE.' + node.mediatype | translate)\n : ''\n \"\n />\n </ng-container>\n</ng-container>\n", styles: [":host{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;border-radius:50%;background-color:#fff;padding:5px;position:relative;z-index:1;box-shadow:0 0 5px #0000004d}:host i{font-size:18px;color:#333}:host img{width:18px;height:18px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.NodeIconPipe, name: "esNodeIcon" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
|
|
29
29
|
}
|
|
30
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeTypeBadgeComponent, decorators: [{
|
|
31
31
|
type: Component,
|
|
32
32
|
args: [{ selector: 'es-node-type-badge', template: "<ng-container *ngIf=\"isCollection\">\n <i\n [matTooltip]=\"\n 'COLLECTION.SCOPE.' + nodeHelper.getCollectionScopeInfo($any(node)).scopeName | translate\n \"\n [altText]=\"\n 'COLLECTION.SCOPE.' + nodeHelper.getCollectionScopeInfo($any(node)).scopeName | translate\n \"\n [esIcon]=\"nodeHelper.getCollectionScopeInfo($any(node)).icon\"\n ></i>\n</ng-container>\n<ng-container *ngIf=\"!isCollection\">\n <ng-container *ngIf=\"getCustomTemplate() as ref\">\n <ng-container *ngTemplateOutlet=\"ref; context: { node: this.node }\"></ng-container>\n </ng-container>\n <ng-container *ngIf=\"!getCustomTemplate()\">\n <img\n [src]=\"node | esNodeIcon | async\"\n [alt]=\"\n node.mediatype\n ? ('NODE.mediatype' | translate) + ': ' + ('MEDIATYPE.' + node.mediatype | translate)\n : ''\n \"\n [matTooltip]=\"\n node.mediatype\n ? ('NODE.mediatype' | translate) + ': ' + ('MEDIATYPE.' + node.mediatype | translate)\n : ''\n \"\n />\n </ng-container>\n</ng-container>\n", styles: [":host{display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;border-radius:50%;background-color:#fff;padding:5px;position:relative;z-index:1;box-shadow:0 0 5px #0000004d}:host i{font-size:18px;color:#333}:host img{width:18px;height:18px}\n"] }]
|
|
33
|
-
}], ctorParameters:
|
|
33
|
+
}], ctorParameters: () => [{ type: i1.NodeHelperService }, { type: i2.NodeEntriesGlobalService }], propDecorators: { node: [{
|
|
34
34
|
type: Input
|
|
35
35
|
}] } });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS10eXBlLWJhZGdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VkdS1zaGFyaW5nLXVpL3NyYy9saWIvbm9kZS1lbnRyaWVzL25vZGUtdHlwZS1iYWRnZS9ub2RlLXR5cGUtYmFkZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9ub2RlLWVudHJpZXMvbm9kZS10eXBlLWJhZGdlL25vZGUtdHlwZS1iYWRnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUU1RCxPQUFPLEVBQUUsc0JBQXNCLEVBQTRCLE1BQU0sZ0NBQWdDLENBQUM7Ozs7Ozs7OztBQUdsRzs7OztHQUlHO0FBTUgsTUFBTSxPQUFPLHNCQUFzQjtJQUsvQixZQUNXLFVBQTZCLEVBQzVCLHdCQUFrRDtRQURuRCxlQUFVLEdBQVYsVUFBVSxDQUFtQjtRQUM1Qiw2QkFBd0IsR0FBeEIsd0JBQXdCLENBQTBCO0lBQzNELENBQUM7SUFFSixXQUFXO1FBQ1AsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNwRSxDQUFDO0lBRUQsaUJBQWlCO1FBQ2IsT0FBTyxJQUFJLENBQUMsd0JBQXdCLENBQUMsc0JBQXNCLENBQ3ZELEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsc0JBQXNCLENBQUMsSUFBSSxFQUFFLEVBQ25ELElBQUksQ0FBQyxJQUFJLENBQ1osQ0FBQztJQUNOLENBQUM7K0dBbkJRLHNCQUFzQjttR0FBdEIsc0JBQXNCLHlHQ2ZuQyxtakNBK0JBOzs0RkRoQmEsc0JBQXNCO2tCQUxsQyxTQUFTOytCQUNJLG9CQUFvQjs2SEFLckIsSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOb2RlIH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5pbXBvcnQgeyBDdXN0b21GaWVsZFNwZWNpYWxUeXBlLCBOb2RlRW50cmllc0dsb2JhbFNlcnZpY2UgfSBmcm9tICcuLi9ub2RlLWVudHJpZXMtZ2xvYmFsLnNlcnZpY2UnO1xuaW1wb3J0IHsgTm9kZUhlbHBlclNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9ub2RlLWhlbHBlci5zZXJ2aWNlJztcblxuLyoqXG4gKiBBIHNtYWxsIGNpcmN1bGFyIGJhZGdlIHRoYXQgZGVwaWN0cyB0aGUgbm9kZSdzIHR5cGUuXG4gKlxuICogVG8gYmUgdXNlZCBpbiB0aGUgdG9wIGJhciBvZiBhIGNhcmQgb3Igc2ltaWxhciBwbGFjZXMuXG4gKi9cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXMtbm9kZS10eXBlLWJhZGdlJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbm9kZS10eXBlLWJhZGdlLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ub2RlLXR5cGUtYmFkZ2UuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgTm9kZVR5cGVCYWRnZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gICAgQElucHV0KCkgbm9kZTogTm9kZTtcblxuICAgIGlzQ29sbGVjdGlvbjogYm9vbGVhbjtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBwdWJsaWMgbm9kZUhlbHBlcjogTm9kZUhlbHBlclNlcnZpY2UsXG4gICAgICAgIHByaXZhdGUgbm9kZUVudHJpZXNHbG9iYWxTZXJ2aWNlOiBOb2RlRW50cmllc0dsb2JhbFNlcnZpY2UsXG4gICAgKSB7fVxuXG4gICAgbmdPbkNoYW5nZXMoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaXNDb2xsZWN0aW9uID0gdGhpcy5ub2RlSGVscGVyLmlzTm9kZUNvbGxlY3Rpb24odGhpcy5ub2RlKTtcbiAgICB9XG5cbiAgICBnZXRDdXN0b21UZW1wbGF0ZSgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMubm9kZUVudHJpZXNHbG9iYWxTZXJ2aWNlLmdldEN1c3RvbUZpZWxkVGVtcGxhdGUoXG4gICAgICAgICAgICB7IHR5cGU6ICdOT0RFJywgbmFtZTogQ3VzdG9tRmllbGRTcGVjaWFsVHlwZS50eXBlIH0sXG4gICAgICAgICAgICB0aGlzLm5vZGUsXG4gICAgICAgICk7XG4gICAgfVxufVxuIiwiPG5nLWNvbnRhaW5lciAqbmdJZj1cImlzQ29sbGVjdGlvblwiPlxuICA8aVxuICAgIFttYXRUb29sdGlwXT1cIlxuICAgICAgJ0NPTExFQ1RJT04uU0NPUEUuJyArIG5vZGVIZWxwZXIuZ2V0Q29sbGVjdGlvblNjb3BlSW5mbygkYW55KG5vZGUpKS5zY29wZU5hbWUgfCB0cmFuc2xhdGVcbiAgICBcIlxuICAgIFthbHRUZXh0XT1cIlxuICAgICAgJ0NPTExFQ1RJT04uU0NPUEUuJyArIG5vZGVIZWxwZXIuZ2V0Q29sbGVjdGlvblNjb3BlSW5mbygkYW55KG5vZGUpKS5zY29wZU5hbWUgfCB0cmFuc2xhdGVcbiAgICBcIlxuICAgIFtlc0ljb25dPVwibm9kZUhlbHBlci5nZXRDb2xsZWN0aW9uU2NvcGVJbmZvKCRhbnkobm9kZSkpLmljb25cIlxuICA+PC9pPlxuPC9uZy1jb250YWluZXI+XG48bmctY29udGFpbmVyICpuZ0lmPVwiIWlzQ29sbGVjdGlvblwiPlxuICA8bmctY29udGFpbmVyICpuZ0lmPVwiZ2V0Q3VzdG9tVGVtcGxhdGUoKSBhcyByZWZcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwicmVmOyBjb250ZXh0OiB7IG5vZGU6IHRoaXMubm9kZSB9XCI+PC9uZy1jb250YWluZXI+XG4gIDwvbmctY29udGFpbmVyPlxuICA8bmctY29udGFpbmVyICpuZ0lmPVwiIWdldEN1c3RvbVRlbXBsYXRlKClcIj5cbiAgICA8aW1nXG4gICAgICBbc3JjXT1cIm5vZGUgfCBlc05vZGVJY29uIHwgYXN5bmNcIlxuICAgICAgW2FsdF09XCJcbiAgICAgICAgbm9kZS5tZWRpYXR5cGVcbiAgICAgICAgICA/ICgnTk9ERS5tZWRpYXR5cGUnIHwgdHJhbnNsYXRlKSArICc6ICcgKyAoJ01FRElBVFlQRS4nICsgbm9kZS5tZWRpYXR5cGUgfCB0cmFuc2xhdGUpXG4gICAgICAgICAgOiAnJ1xuICAgICAgXCJcbiAgICAgIFttYXRUb29sdGlwXT1cIlxuICAgICAgICBub2RlLm1lZGlhdHlwZVxuICAgICAgICAgID8gKCdOT0RFLm1lZGlhdHlwZScgfCB0cmFuc2xhdGUpICsgJzogJyArICgnTUVESUFUWVBFLicgKyBub2RlLm1lZGlhdHlwZSB8IHRyYW5zbGF0ZSlcbiAgICAgICAgICA6ICcnXG4gICAgICBcIlxuICAgIC8+XG4gIDwvbmctY29udGFpbmVyPlxuPC9uZy1jb250YWluZXI+XG4iXX0=
|
|
@@ -19,13 +19,13 @@ export class OptionButtonComponent {
|
|
|
19
19
|
}
|
|
20
20
|
async optionIsValid(optionItem, node) {
|
|
21
21
|
if (optionItem.enabledCallback) {
|
|
22
|
-
return await optionItem.enabledCallback(node);
|
|
22
|
+
return await optionItem.enabledCallback([node]);
|
|
23
23
|
}
|
|
24
24
|
return optionItem.isEnabled;
|
|
25
25
|
}
|
|
26
26
|
async optionIsShown(optionItem, node) {
|
|
27
27
|
if (optionItem.showCallback) {
|
|
28
|
-
return optionItem.showCallback(node);
|
|
28
|
+
return optionItem.showCallback([node]);
|
|
29
29
|
}
|
|
30
30
|
return true;
|
|
31
31
|
}
|
|
@@ -34,8 +34,8 @@ export class OptionButtonComponent {
|
|
|
34
34
|
option.callback(node);
|
|
35
35
|
}
|
|
36
36
|
}
|
|
37
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
38
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
37
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: OptionButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
38
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: OptionButtonComponent, selector: "es-option-button", inputs: { option: "option", node: "node" }, usesOnChanges: true, ngImport: i0, template: `
|
|
39
39
|
<button
|
|
40
40
|
mat-icon-button
|
|
41
41
|
color="primary"
|
|
@@ -47,9 +47,9 @@ export class OptionButtonComponent {
|
|
|
47
47
|
>
|
|
48
48
|
<i esIcon="{{ option.icon }}" [aria]="false"></i>
|
|
49
49
|
</button>
|
|
50
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: i1.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]",
|
|
50
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }] }); }
|
|
51
51
|
}
|
|
52
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
52
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: OptionButtonComponent, decorators: [{
|
|
53
53
|
type: Component,
|
|
54
54
|
args: [{
|
|
55
55
|
selector: 'es-option-button',
|
|
@@ -72,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
|
|
|
72
72
|
}], node: [{
|
|
73
73
|
type: Input
|
|
74
74
|
}] } });
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL25vZGUtZW50cmllcy9vcHRpb24tYnV0dG9uL29wdGlvbi1idXR0b24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUE0QixNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBRzNFLGtHQUFrRztBQUNsRyxnR0FBZ0c7QUFDaEcsNEZBQTRGO0FBQzVGLFdBQVc7QUFrQlgsTUFBTSxPQUFPLHFCQUFxQjtJQWhCbEM7UUFvQkksWUFBTyxHQUFHLEtBQUssQ0FBQztRQUNoQixjQUFTLEdBQUcsS0FBSyxDQUFDO0tBeUJyQjtJQXhCRyxLQUFLLENBQUMsV0FBVyxDQUFDLE9BQXNCO1FBQ3BDLElBQUksQ0FBQyxTQUFTLEdBQUcsTUFBTSxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxPQUFPLEdBQUcsTUFBTSxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3BFLENBQUM7SUFFRCxLQUFLLENBQUMsYUFBYSxDQUFDLFVBQXNCLEVBQUUsSUFBVTtRQUNsRCxJQUFJLFVBQVUsQ0FBQyxlQUFlLEVBQUUsQ0FBQztZQUM3QixPQUFPLE1BQU0sVUFBVSxDQUFDLGVBQWUsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDcEQsQ0FBQztRQUNELE9BQU8sVUFBVSxDQUFDLFNBQVMsQ0FBQztJQUNoQyxDQUFDO0lBRU8sS0FBSyxDQUFDLGFBQWEsQ0FBQyxVQUFzQixFQUFFLElBQVU7UUFDMUQsSUFBSSxVQUFVLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDMUIsT0FBTyxVQUFVLENBQUMsWUFBWSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUMzQyxDQUFDO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQztJQUVELEtBQUssQ0FBQyxLQUFLLENBQUMsTUFBa0IsRUFBRSxJQUFVO1FBQ3RDLElBQUksTUFBTSxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDO1lBQ3pDLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUIsQ0FBQztJQUNMLENBQUM7K0dBN0JRLHFCQUFxQjttR0FBckIscUJBQXFCLHlIQWRwQjs7Ozs7Ozs7Ozs7O0tBWVQ7OzRGQUVRLHFCQUFxQjtrQkFoQmpDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7S0FZVDtpQkFDSjs4QkFFWSxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOb2RlIH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5pbXBvcnQgeyBPcHRpb25JdGVtIH0gZnJvbSAnLi4vLi4vdHlwZXMvb3B0aW9uLWl0ZW0nO1xuLy8gVE9ETzogRGVjaWRlIGlmIHByb3ZpZGluZyBmb2N1cyBoaWdobGlnaHRzIGFuZCByaXBwbGVzIHdpdGggdGhpcyBjb21wb25lbnQgaXMgYSBnb29kIGlkZWEuIFdoZW5cbi8vIHVzaW5nIGBhcHAtbm9kZS11cmxgIGZvciBjYXJkcywgd2UgbWlnaHQgbmVlZCBoaWdobGlnaHRzIGFuZCByaXBwbGVzIGZvciB0aGUgd2hvbGUgY2FyZCB3aGlsZVxuLy8gYGFwcC1ub2RlLXVybGAgc2hvdWxkIG9ubHkgd3JhcCB0aGUgdGl0bGUgc2luY2UgbGlua3Mgd2l0aCBsb3RzIG9mIGNvbnRlbnQgY29uZnVzZSBzY3JlZW5cbi8vIHJlYWRlcnMuXG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXMtb3B0aW9uLWJ1dHRvbicsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgbWF0LWljb24tYnV0dG9uXG4gICAgICAgICAgICBjb2xvcj1cInByaW1hcnlcIlxuICAgICAgICAgICAgbWF0VG9vbHRpcD1cInt7IG9wdGlvbi5uYW1lIHwgdHJhbnNsYXRlIH19XCJcbiAgICAgICAgICAgIFtjbGFzcy5kaXNwbGF5LW5vbmVdPVwiIWlzU2hvd25cIlxuICAgICAgICAgICAgW2Rpc2FibGVkXT1cIiFpc0VuYWJsZWRcIlxuICAgICAgICAgICAgKGNsaWNrKT1cImNsaWNrKG9wdGlvbiwgbm9kZSlcIlxuICAgICAgICAgICAgYXR0ci5kYXRhLXRlc3Q9XCJvcHRpb24tYnV0dG9uLXt7IG9wdGlvbi5uYW1lIH19XCJcbiAgICAgICAgPlxuICAgICAgICAgICAgPGkgZXNJY29uPVwie3sgb3B0aW9uLmljb24gfX1cIiBbYXJpYV09XCJmYWxzZVwiPjwvaT5cbiAgICAgICAgPC9idXR0b24+XG4gICAgYCxcbn0pXG5leHBvcnQgY2xhc3MgT3B0aW9uQnV0dG9uQ29tcG9uZW50IGltcGxlbWVudHMgT25DaGFuZ2VzIHtcbiAgICBASW5wdXQoKSBvcHRpb246IE9wdGlvbkl0ZW07XG4gICAgQElucHV0KCkgbm9kZTogTm9kZTtcblxuICAgIGlzU2hvd24gPSBmYWxzZTtcbiAgICBpc0VuYWJsZWQgPSBmYWxzZTtcbiAgICBhc3luYyBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgICAgIHRoaXMuaXNFbmFibGVkID0gYXdhaXQgdGhpcy5vcHRpb25Jc1ZhbGlkKHRoaXMub3B0aW9uLCB0aGlzLm5vZGUpO1xuICAgICAgICB0aGlzLmlzU2hvd24gPSBhd2FpdCB0aGlzLm9wdGlvbklzU2hvd24odGhpcy5vcHRpb24sIHRoaXMubm9kZSk7XG4gICAgfVxuXG4gICAgYXN5bmMgb3B0aW9uSXNWYWxpZChvcHRpb25JdGVtOiBPcHRpb25JdGVtLCBub2RlOiBOb2RlKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgICAgIGlmIChvcHRpb25JdGVtLmVuYWJsZWRDYWxsYmFjaykge1xuICAgICAgICAgICAgcmV0dXJuIGF3YWl0IG9wdGlvbkl0ZW0uZW5hYmxlZENhbGxiYWNrKFtub2RlXSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG9wdGlvbkl0ZW0uaXNFbmFibGVkO1xuICAgIH1cblxuICAgIHByaXZhdGUgYXN5bmMgb3B0aW9uSXNTaG93bihvcHRpb25JdGVtOiBPcHRpb25JdGVtLCBub2RlOiBOb2RlKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgICAgIGlmIChvcHRpb25JdGVtLnNob3dDYWxsYmFjaykge1xuICAgICAgICAgICAgcmV0dXJuIG9wdGlvbkl0ZW0uc2hvd0NhbGxiYWNrKFtub2RlXSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuXG4gICAgYXN5bmMgY2xpY2sob3B0aW9uOiBPcHRpb25JdGVtLCBub2RlOiBOb2RlKSB7XG4gICAgICAgIGlmIChhd2FpdCB0aGlzLm9wdGlvbklzU2hvd24ob3B0aW9uLCBub2RlKSkge1xuICAgICAgICAgICAgb3B0aW9uLmNhbGxiYWNrKG5vZGUpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
|
|
@@ -33,13 +33,13 @@ export class PreviewImageComponent {
|
|
|
33
33
|
canvas.height = height;
|
|
34
34
|
canvas.getContext('2d').drawImage(image, 0, 0, width, height);
|
|
35
35
|
}
|
|
36
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
37
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
36
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: PreviewImageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
37
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: PreviewImageComponent, selector: "es-preview-image", inputs: { node: "node", playAnimation: "playAnimation" }, viewQueries: [{ propertyName: "imageRef", first: true, predicate: ["image"], descendants: true }, { propertyName: "canvasRef", first: true, predicate: ["canvas"], descendants: true }], ngImport: i0, template: "<div class=\"card-image-backdrop\">\n <!-- The blur filter does not work with canvas as it does with img on Chrome, so we go for a black\n background for now. -->\n <!-- <canvas *ngIf=\"showCanvas\" #backdropCanvas role=\"presentation\" aria-hidden=\"true\"></canvas> -->\n <img\n [src]=\"node | esNodeImage : { maxWidth: 300, maxHeight: 300, crop: true } | async\"\n alt=\"\"\n *ngIf=\"!replacedWithStatic\"\n />\n</div>\n\n<canvas *ngIf=\"showCanvas\" #canvas role=\"presentation\" aria-hidden=\"true\"></canvas>\n<img\n (load)=\"onImageLoad($event)\"\n #image\n [src]=\"node | esNodeImage : { maxWidth: 300, maxHeight: 300, crop: true } | async\"\n alt=\"\"\n [class.display-none]=\"replacedWithStatic && !playAnimation\"\n/>\n", styles: [":host{position:relative;overflow:hidden}.card-image-backdrop{position:absolute;width:100%;height:100%;background-color:#000}.card-image-backdrop img,.card-image-backdrop canvas{position:absolute;left:-30px;top:-30px;width:calc(100% + 60px);height:calc(100% + 60px);z-index:0;overflow:hidden;filter:blur(15px);object-fit:cover;opacity:.7;opacity:1}:host>img,:host>canvas{width:100%;height:100%;object-fit:contain;position:absolute}.display-none{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.NodeImagePipe, name: "esNodeImage" }] }); }
|
|
38
38
|
}
|
|
39
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: PreviewImageComponent, decorators: [{
|
|
40
40
|
type: Component,
|
|
41
41
|
args: [{ selector: 'es-preview-image', template: "<div class=\"card-image-backdrop\">\n <!-- The blur filter does not work with canvas as it does with img on Chrome, so we go for a black\n background for now. -->\n <!-- <canvas *ngIf=\"showCanvas\" #backdropCanvas role=\"presentation\" aria-hidden=\"true\"></canvas> -->\n <img\n [src]=\"node | esNodeImage : { maxWidth: 300, maxHeight: 300, crop: true } | async\"\n alt=\"\"\n *ngIf=\"!replacedWithStatic\"\n />\n</div>\n\n<canvas *ngIf=\"showCanvas\" #canvas role=\"presentation\" aria-hidden=\"true\"></canvas>\n<img\n (load)=\"onImageLoad($event)\"\n #image\n [src]=\"node | esNodeImage : { maxWidth: 300, maxHeight: 300, crop: true } | async\"\n alt=\"\"\n [class.display-none]=\"replacedWithStatic && !playAnimation\"\n/>\n", styles: [":host{position:relative;overflow:hidden}.card-image-backdrop{position:absolute;width:100%;height:100%;background-color:#000}.card-image-backdrop img,.card-image-backdrop canvas{position:absolute;left:-30px;top:-30px;width:calc(100% + 60px);height:calc(100% + 60px);z-index:0;overflow:hidden;filter:blur(15px);object-fit:cover;opacity:.7;opacity:1}:host>img,:host>canvas{width:100%;height:100%;object-fit:contain;position:absolute}.display-none{display:none}\n"] }]
|
|
42
|
-
}], ctorParameters:
|
|
42
|
+
}], ctorParameters: () => [], propDecorators: { node: [{
|
|
43
43
|
type: Input
|
|
44
44
|
}], playAnimation: [{
|
|
45
45
|
type: Input
|
|
@@ -50,4 +50,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
|
|
|
50
50
|
type: ViewChild,
|
|
51
51
|
args: ['canvas']
|
|
52
52
|
}] } });
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJldmlldy1pbWFnZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL25vZGUtZW50cmllcy9wcmV2aWV3LWltYWdlL3ByZXZpZXctaW1hZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9ub2RlLWVudHJpZXMvcHJldmlldy1pbWFnZS9wcmV2aWV3LWltYWdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7OztBQUd4RTs7Ozs7R0FLRztBQU1ILE1BQU0sT0FBTyxxQkFBcUI7SUFXOUI7UUFUUyxrQkFBYSxHQUFHLEtBQUssQ0FBQztRQUkvQixpRkFBaUY7UUFFakYsZUFBVSxHQUFZLEtBQUssQ0FBQztRQUM1Qix1QkFBa0IsR0FBWSxLQUFLLENBQUM7SUFFckIsQ0FBQztJQUVoQixXQUFXLENBQUMsS0FBWTtRQUNwQixJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxPQUFPLENBQUMsRUFBRSxDQUFDO1lBQzFDLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxNQUEwQixDQUFDO1lBQy9DLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO1lBQ3ZCLFVBQVUsQ0FBQyxHQUFHLEVBQUU7Z0JBQ1osSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUMsQ0FBQztnQkFDckQsZ0VBQWdFO2dCQUNoRSxJQUFJLENBQUMsa0JBQWtCLEdBQUcsSUFBSSxDQUFDO1lBQ25DLENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQztJQUNMLENBQUM7SUFFTyxVQUFVLENBQUMsS0FBdUIsRUFBRSxNQUF5QjtRQUNqRSxJQUFJLEtBQUssR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFDO1FBQy9CLElBQUksTUFBTSxHQUFHLEtBQUssQ0FBQyxhQUFhLENBQUM7UUFDakMsTUFBTSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDckIsTUFBTSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDdkIsTUFBTSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ2xFLENBQUM7K0dBL0JRLHFCQUFxQjttR0FBckIscUJBQXFCLDJTQ2RsQywrdUJBbUJBOzs0RkRMYSxxQkFBcUI7a0JBTGpDLFNBQVM7K0JBQ0ksa0JBQWtCO3dEQUtuQixJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSztnQkFFYyxRQUFRO3NCQUEzQixTQUFTO3VCQUFDLE9BQU87Z0JBQ0csU0FBUztzQkFBN0IsU0FBUzt1QkFBQyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOb2RlIH0gZnJvbSAnbmd4LWVkdS1zaGFyaW5nLWFwaSc7XG5cbi8qKlxuICogRGlzcGxheXMgdGhlIHByZXZpZXcgaW1hZ2Ugb2YgYG5vZGVgLlxuICpcbiAqIFdoZW4gYG5vZGVgIGlzIGEgdmlkZW8sIHRoZSBhbmltYXRlZCBwcmV2aWV3IGltYWdlIGlzIHJlcGxhY2VkIHdpdGggYSBzdGF0aWMgY2FudmFzIHVubGVzc1xuICogYHBsYXlBbmltYXRpb25gIGlzIHNldCB0byBgdHJ1ZWAuXG4gKi9cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZXMtcHJldmlldy1pbWFnZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3ByZXZpZXctaW1hZ2UuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL3ByZXZpZXctaW1hZ2UuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgUHJldmlld0ltYWdlQ29tcG9uZW50PFQgZXh0ZW5kcyBOb2RlPiB7XG4gICAgQElucHV0KCkgbm9kZTogVDtcbiAgICBASW5wdXQoKSBwbGF5QW5pbWF0aW9uID0gZmFsc2U7XG5cbiAgICBAVmlld0NoaWxkKCdpbWFnZScpIGltYWdlUmVmOiBFbGVtZW50UmVmPEhUTUxJbWFnZUVsZW1lbnQ+O1xuICAgIEBWaWV3Q2hpbGQoJ2NhbnZhcycpIGNhbnZhc1JlZjogRWxlbWVudFJlZjxIVE1MQ2FudmFzRWxlbWVudD47XG4gICAgLy8gQFZpZXdDaGlsZCgnYmFja2Ryb3BDYW52YXMnKSBiYWNrZHJvcENhbnZhc1JlZjogRWxlbWVudFJlZjxIVE1MQ2FudmFzRWxlbWVudD47XG5cbiAgICBzaG93Q2FudmFzOiBib29sZWFuID0gZmFsc2U7XG4gICAgcmVwbGFjZWRXaXRoU3RhdGljOiBib29sZWFuID0gZmFsc2U7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgICBvbkltYWdlTG9hZChldmVudDogRXZlbnQpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMubm9kZS5taW1ldHlwZT8uc3RhcnRzV2l0aCgndmlkZW8nKSkge1xuICAgICAgICAgICAgY29uc3QgaW1hZ2UgPSBldmVudC50YXJnZXQgYXMgSFRNTEltYWdlRWxlbWVudDtcbiAgICAgICAgICAgIHRoaXMuc2hvd0NhbnZhcyA9IHRydWU7XG4gICAgICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLmluaXRDYW52YXMoaW1hZ2UsIHRoaXMuY2FudmFzUmVmLm5hdGl2ZUVsZW1lbnQpO1xuICAgICAgICAgICAgICAgIC8vIHRoaXMuaW5pdENhbnZhcyhpbWFnZSwgdGhpcy5iYWNrZHJvcENhbnZhc1JlZi5uYXRpdmVFbGVtZW50KTtcbiAgICAgICAgICAgICAgICB0aGlzLnJlcGxhY2VkV2l0aFN0YXRpYyA9IHRydWU7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByaXZhdGUgaW5pdENhbnZhcyhpbWFnZTogSFRNTEltYWdlRWxlbWVudCwgY2FudmFzOiBIVE1MQ2FudmFzRWxlbWVudCk6IHZvaWQge1xuICAgICAgICB2YXIgd2lkdGggPSBpbWFnZS5uYXR1cmFsV2lkdGg7XG4gICAgICAgIHZhciBoZWlnaHQgPSBpbWFnZS5uYXR1cmFsSGVpZ2h0O1xuICAgICAgICBjYW52YXMud2lkdGggPSB3aWR0aDtcbiAgICAgICAgY2FudmFzLmhlaWdodCA9IGhlaWdodDtcbiAgICAgICAgY2FudmFzLmdldENvbnRleHQoJzJkJykuZHJhd0ltYWdlKGltYWdlLCAwLCAwLCB3aWR0aCwgaGVpZ2h0KTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiY2FyZC1pbWFnZS1iYWNrZHJvcFwiPlxuICA8IS0tIFRoZSBibHVyIGZpbHRlciBkb2VzIG5vdCB3b3JrIHdpdGggY2FudmFzIGFzIGl0IGRvZXMgd2l0aCBpbWcgb24gQ2hyb21lLCBzbyB3ZSBnbyBmb3IgYSBibGFja1xuICBiYWNrZ3JvdW5kIGZvciBub3cuIC0tPlxuICA8IS0tIDxjYW52YXMgKm5nSWY9XCJzaG93Q2FudmFzXCIgI2JhY2tkcm9wQ2FudmFzIHJvbGU9XCJwcmVzZW50YXRpb25cIiBhcmlhLWhpZGRlbj1cInRydWVcIj48L2NhbnZhcz4gLS0+XG4gIDxpbWdcbiAgICBbc3JjXT1cIm5vZGUgfCBlc05vZGVJbWFnZSA6IHsgbWF4V2lkdGg6IDMwMCwgbWF4SGVpZ2h0OiAzMDAsIGNyb3A6IHRydWUgfSB8IGFzeW5jXCJcbiAgICBhbHQ9XCJcIlxuICAgICpuZ0lmPVwiIXJlcGxhY2VkV2l0aFN0YXRpY1wiXG4gIC8+XG48L2Rpdj5cblxuPGNhbnZhcyAqbmdJZj1cInNob3dDYW52YXNcIiAjY2FudmFzIHJvbGU9XCJwcmVzZW50YXRpb25cIiBhcmlhLWhpZGRlbj1cInRydWVcIj48L2NhbnZhcz5cbjxpbWdcbiAgKGxvYWQpPVwib25JbWFnZUxvYWQoJGV2ZW50KVwiXG4gICNpbWFnZVxuICBbc3JjXT1cIm5vZGUgfCBlc05vZGVJbWFnZSA6IHsgbWF4V2lkdGg6IDMwMCwgbWF4SGVpZ2h0OiAzMDAsIGNyb3A6IHRydWUgfSB8IGFzeW5jXCJcbiAgYWx0PVwiXCJcbiAgW2NsYXNzLmRpc3BsYXktbm9uZV09XCJyZXBsYWNlZFdpdGhTdGF0aWMgJiYgIXBsYXlBbmltYXRpb25cIlxuLz5cbiJdfQ==
|
|
@@ -19,13 +19,13 @@ export class SortSelectPanelComponent {
|
|
|
19
19
|
direction: event.ascending ? 'asc' : 'desc',
|
|
20
20
|
});
|
|
21
21
|
}
|
|
22
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
23
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
22
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SortSelectPanelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
23
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: SortSelectPanelComponent, selector: "es-sort-select-panel", inputs: { active: "active", direction: "direction", columns: "columns", customSortingInProgress: "customSortingInProgress" }, outputs: { sortChange: "sortChange", customSortingInProgressChange: "customSortingInProgressChange" }, ngImport: i0, template: "<mat-slide-toggle\n *ngIf=\"active === 'ccm:collection_ordered_position'\"\n [(ngModel)]=\"customSortingInProgress\"\n (ngModelChange)=\"customSortingInProgressChange.emit($event)\"\n>\n {{ 'COLLECTIONS.SORT_SLIDER' | translate }}\n</mat-slide-toggle>\n<ng-container *ngIf=\"columns?.length\">\n <button\n *ngIf=\"sortDropdown.menu\"\n [matMenuTriggerFor]=\"sortDropdown.menu\"\n mat-button\n color=\"primary\"\n >\n <span *ngIf=\"active\">{{ 'NODE.' + active | translate }}</span>\n <span *ngIf=\"!active\">{{ 'SORT_BY' | translate }}</span>\n <i\n *ngIf=\"active && active !== 'ccm:collection_ordered_position'\"\n [esIcon]=\"'arrow_' + (direction === 'asc' ? 'upward' : 'downward')\"\n ></i>\n </button>\n\n <es-sort-dropdown\n #sortDropdown\n [columns]=\"columns\"\n [sortBy]=\"active\"\n [sortAscending]=\"direction === 'asc'\"\n (sort)=\"onSort($event)\"\n ></es-sort-dropdown>\n</ng-container>\n", styles: [":host{display:flex;justify-content:flex-end;align-items:center}mat-slide-toggle{margin-right:10px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.IconDirective, selector: "i[esIcon], i.material-icons", inputs: ["altText", "aria", "esIcon"] }, { kind: "component", type: i4.SortDropdownComponent, selector: "es-sort-dropdown", inputs: ["columns", "sortBy", "sortAscending"], outputs: ["sort"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i6.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "component", type: i7.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["name", "id", "labelPosition", "aria-label", "aria-labelledby", "aria-describedby", "required", "color", "disabled", "disableRipple", "tabIndex", "checked", "hideIcon", "disabledInteractive"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
|
|
24
24
|
}
|
|
25
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: SortSelectPanelComponent, decorators: [{
|
|
26
26
|
type: Component,
|
|
27
|
-
args: [{ selector: 'es-sort-select-panel', template: "<mat-slide-toggle\n *ngIf=\"active === 'ccm:collection_ordered_position'\"\n [(ngModel)]=\"customSortingInProgress\"\n (ngModelChange)=\"customSortingInProgressChange.emit($event)\"\n>\n {{ 'COLLECTIONS.SORT_SLIDER' | translate }}\n</mat-slide-toggle>\n<ng-container *ngIf=\"columns?.length\">\n <button\n *ngIf=\"sortDropdown.menu\"\n [matMenuTriggerFor]=\"sortDropdown.menu\"\n mat-button\n color=\"primary\"\n >\n <span *ngIf=\"active\">{{ 'NODE.' + active | translate }}</span>\n <span *ngIf=\"!active\">{{ 'SORT_BY' | translate }}</span>\n <i\n *ngIf=\"active && active !== 'ccm:collection_ordered_position'\"\n [esIcon]=\"'arrow_' + (direction === 'asc' ? 'upward' : 'downward')\"\n ></i>\n </button>\n\n <es-sort-dropdown\n #sortDropdown\n [columns]=\"columns\"\n [sortBy]=\"active\"\n [sortAscending]=\"direction === 'asc'\"\n (
|
|
28
|
-
}], ctorParameters:
|
|
27
|
+
args: [{ selector: 'es-sort-select-panel', template: "<mat-slide-toggle\n *ngIf=\"active === 'ccm:collection_ordered_position'\"\n [(ngModel)]=\"customSortingInProgress\"\n (ngModelChange)=\"customSortingInProgressChange.emit($event)\"\n>\n {{ 'COLLECTIONS.SORT_SLIDER' | translate }}\n</mat-slide-toggle>\n<ng-container *ngIf=\"columns?.length\">\n <button\n *ngIf=\"sortDropdown.menu\"\n [matMenuTriggerFor]=\"sortDropdown.menu\"\n mat-button\n color=\"primary\"\n >\n <span *ngIf=\"active\">{{ 'NODE.' + active | translate }}</span>\n <span *ngIf=\"!active\">{{ 'SORT_BY' | translate }}</span>\n <i\n *ngIf=\"active && active !== 'ccm:collection_ordered_position'\"\n [esIcon]=\"'arrow_' + (direction === 'asc' ? 'upward' : 'downward')\"\n ></i>\n </button>\n\n <es-sort-dropdown\n #sortDropdown\n [columns]=\"columns\"\n [sortBy]=\"active\"\n [sortAscending]=\"direction === 'asc'\"\n (sort)=\"onSort($event)\"\n ></es-sort-dropdown>\n</ng-container>\n", styles: [":host{display:flex;justify-content:flex-end;align-items:center}mat-slide-toggle{margin-right:10px}\n"] }]
|
|
28
|
+
}], ctorParameters: () => [], propDecorators: { active: [{
|
|
29
29
|
type: Input
|
|
30
30
|
}], direction: [{
|
|
31
31
|
type: Input
|
|
@@ -38,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
|
|
|
38
38
|
}], customSortingInProgressChange: [{
|
|
39
39
|
type: Output
|
|
40
40
|
}] } });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydC1zZWxlY3QtcGFuZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9ub2RlLWVudHJpZXMvc29ydC1zZWxlY3QtcGFuZWwvc29ydC1zZWxlY3QtcGFuZWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWR1LXNoYXJpbmctdWkvc3JjL2xpYi9ub2RlLWVudHJpZXMvc29ydC1zZWxlY3QtcGFuZWwvc29ydC1zZWxlY3QtcGFuZWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7Ozs7OztBQVN2RSxNQUFNLE9BQU8sd0JBQXdCO0lBUWpDO1FBSlUsZUFBVSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFFdEMsa0NBQTZCLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztJQUV2RCxDQUFDO0lBRWhCLE1BQU0sQ0FBQyxLQUFnQjtRQUNuQixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQztZQUNqQixNQUFNLEVBQUUsS0FBSyxDQUFDLElBQUk7WUFDbEIsU0FBUyxFQUFFLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsTUFBTTtTQUM5QyxDQUFDLENBQUM7SUFDUCxDQUFDOytHQWZRLHdCQUF3QjttR0FBeEIsd0JBQXdCLGlTQ1RyQyxrOEJBOEJBOzs0RkRyQmEsd0JBQXdCO2tCQUxwQyxTQUFTOytCQUNJLHNCQUFzQjt3REFLdkIsTUFBTTtzQkFBZCxLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNJLFVBQVU7c0JBQW5CLE1BQU07Z0JBQ0UsdUJBQXVCO3NCQUEvQixLQUFLO2dCQUNJLDZCQUE2QjtzQkFBdEMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTb3J0LCBTb3J0RGlyZWN0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc29ydCc7XG5pbXBvcnQgeyBMaXN0SXRlbVNvcnQsIFNvcnRFdmVudCwgU29ydFBhbmVsIH0gZnJvbSAnLi4vLi4vdHlwZXMvbGlzdC1pdGVtJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdlcy1zb3J0LXNlbGVjdC1wYW5lbCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3NvcnQtc2VsZWN0LXBhbmVsLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zb3J0LXNlbGVjdC1wYW5lbC5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBTb3J0U2VsZWN0UGFuZWxDb21wb25lbnQgaW1wbGVtZW50cyBTb3J0UGFuZWwge1xuICAgIEBJbnB1dCgpIGFjdGl2ZTogc3RyaW5nO1xuICAgIEBJbnB1dCgpIGRpcmVjdGlvbjogU29ydERpcmVjdGlvbjtcbiAgICBASW5wdXQoKSBjb2x1bW5zOiBMaXN0SXRlbVNvcnRbXTtcbiAgICBAT3V0cHV0KCkgc29ydENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8U29ydD4oKTtcbiAgICBASW5wdXQoKSBjdXN0b21Tb3J0aW5nSW5Qcm9ncmVzczogYm9vbGVhbjtcbiAgICBAT3V0cHV0KCkgY3VzdG9tU29ydGluZ0luUHJvZ3Jlc3NDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPGJvb2xlYW4+KCk7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgICBvblNvcnQoZXZlbnQ6IFNvcnRFdmVudCkge1xuICAgICAgICB0aGlzLnNvcnRDaGFuZ2UuZW1pdCh7XG4gICAgICAgICAgICBhY3RpdmU6IGV2ZW50Lm5hbWUsXG4gICAgICAgICAgICBkaXJlY3Rpb246IGV2ZW50LmFzY2VuZGluZyA/ICdhc2MnIDogJ2Rlc2MnLFxuICAgICAgICB9KTtcbiAgICB9XG59XG4iLCI8bWF0LXNsaWRlLXRvZ2dsZVxuICAqbmdJZj1cImFjdGl2ZSA9PT0gJ2NjbTpjb2xsZWN0aW9uX29yZGVyZWRfcG9zaXRpb24nXCJcbiAgWyhuZ01vZGVsKV09XCJjdXN0b21Tb3J0aW5nSW5Qcm9ncmVzc1wiXG4gIChuZ01vZGVsQ2hhbmdlKT1cImN1c3RvbVNvcnRpbmdJblByb2dyZXNzQ2hhbmdlLmVtaXQoJGV2ZW50KVwiXG4+XG4gIHt7ICdDT0xMRUNUSU9OUy5TT1JUX1NMSURFUicgfCB0cmFuc2xhdGUgfX1cbjwvbWF0LXNsaWRlLXRvZ2dsZT5cbjxuZy1jb250YWluZXIgKm5nSWY9XCJjb2x1bW5zPy5sZW5ndGhcIj5cbiAgPGJ1dHRvblxuICAgICpuZ0lmPVwic29ydERyb3Bkb3duLm1lbnVcIlxuICAgIFttYXRNZW51VHJpZ2dlckZvcl09XCJzb3J0RHJvcGRvd24ubWVudVwiXG4gICAgbWF0LWJ1dHRvblxuICAgIGNvbG9yPVwicHJpbWFyeVwiXG4gID5cbiAgICA8c3BhbiAqbmdJZj1cImFjdGl2ZVwiPnt7ICdOT0RFLicgKyBhY3RpdmUgfCB0cmFuc2xhdGUgfX08L3NwYW4+XG4gICAgPHNwYW4gKm5nSWY9XCIhYWN0aXZlXCI+e3sgJ1NPUlRfQlknIHwgdHJhbnNsYXRlIH19PC9zcGFuPlxuICAgIDxpXG4gICAgICAqbmdJZj1cImFjdGl2ZSAmJiBhY3RpdmUgIT09ICdjY206Y29sbGVjdGlvbl9vcmRlcmVkX3Bvc2l0aW9uJ1wiXG4gICAgICBbZXNJY29uXT1cIidhcnJvd18nICsgKGRpcmVjdGlvbiA9PT0gJ2FzYycgPyAndXB3YXJkJyA6ICdkb3dud2FyZCcpXCJcbiAgICA+PC9pPlxuICA8L2J1dHRvbj5cblxuICA8ZXMtc29ydC1kcm9wZG93blxuICAgICNzb3J0RHJvcGRvd25cbiAgICBbY29sdW1uc109XCJjb2x1bW5zXCJcbiAgICBbc29ydEJ5XT1cImFjdGl2ZVwiXG4gICAgW3NvcnRBc2NlbmRpbmddPVwiZGlyZWN0aW9uID09PSAnYXNjJ1wiXG4gICAgKHNvcnQpPVwib25Tb3J0KCRldmVudClcIlxuICA+PC9lcy1zb3J0LWRyb3Bkb3duPlxuPC9uZy1jb250YWluZXI+XG4iXX0=
|
|
@@ -73,13 +73,13 @@ export class NodeUrlComponent {
|
|
|
73
73
|
}
|
|
74
74
|
return false;
|
|
75
75
|
}
|
|
76
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
77
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
76
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeUrlComponent, deps: [{ token: i1.NodeHelperService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: NodeUrlComponent, selector: "es-node-url", inputs: { node: "node", nodes: "nodes", target: "target", scope: "scope", queryParams: "queryParams", mode: "mode", disabled: "disabled", alwaysRipple: "alwaysRipple", ariaDescribedby: ["aria-describedby", "ariaDescribedby"], ariaLabel: ["aria-label", "ariaLabel"] }, outputs: { buttonClick: "buttonClick" }, viewQueries: [{ propertyName: "link", first: true, predicate: ["link"], descendants: true }], ngImport: i0, template: "<ng-template #content><ng-content></ng-content></ng-template>\n<ng-container *ngIf=\"mode === 'link'\">\n <a\n *ngIf=\"!disabled\"\n #link\n matRipple\n matRippleColor=\"primary\"\n [matRippleDisabled]=\"isNested\"\n [routerLink]=\"get('routerLink')\"\n [state]=\"getState()\"\n [target]=\"target\"\n [queryParams]=\"get('queryParams')\"\n queryParamsHandling=\"merge\"\n cdkMonitorElementFocus\n [attr.aria-label]=\"ariaLabel ? node.name : null\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n >\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </a>\n <!-- We use `div`s instead of `span`s here because the legacy `ListTable` component will insert\n `div` elements into this component's content. However, this will lead to invalid HTML for \"button\"\n mode. So really, users of this component should only insert flow content. -->\n <div *ngIf=\"disabled && !alwaysRipple\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <div *ngIf=\"disabled && alwaysRipple\" matRipple matRippleColor=\"primary\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n</ng-container>\n<ng-container *ngIf=\"mode === 'wrapper'\">\n <div\n class=\"node-url-wrapper\"\n #wrapper\n matRipple\n matRippleColor=\"primary\"\n [matRippleDisabled]=\"disabled && !alwaysRipple\"\n (click)=\"clickWrapper($event)\"\n (auxclick)=\"clickWrapper($event)\"\n >\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <!-- An invisible link that will by clicked programmatically by `clickWrapper()`. -->\n <a\n #link\n [routerLink]=\"get('routerLink')\"\n [state]=\"getState()\"\n [queryParams]=\"get('queryParams')\"\n queryParamsHandling=\"merge\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n class=\"cdk-visually-hidden\"\n ></a>\n</ng-container>\n<ng-container *ngIf=\"mode === 'button'\">\n <button\n [disabled]=\"disabled\"\n #link\n matRipple\n matRippleColor=\"primary\"\n [matRippleDisabled]=\"disabled && !alwaysRipple\"\n (click)=\"buttonClick.emit($event)\"\n cdkMonitorElementFocus\n >\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </button>\n</ng-container>\n", styles: [":host{position:relative;display:flex}:host>*{flex-grow:1}:host>a{text-decoration:none}.cdk-keyboard-focused{outline:none;outline:var(--focusWidth) solid var(--palette-primary-300);outline-offset:2px}button{background-color:unset;border:unset;padding:unset;text-align:unset}div.node-url-wrapper{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "directive", type: i4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
|
|
78
78
|
}
|
|
79
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
79
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: NodeUrlComponent, decorators: [{
|
|
80
80
|
type: Component,
|
|
81
81
|
args: [{ selector: NODE_URL_TAG_NAME, template: "<ng-template #content><ng-content></ng-content></ng-template>\n<ng-container *ngIf=\"mode === 'link'\">\n <a\n *ngIf=\"!disabled\"\n #link\n matRipple\n matRippleColor=\"primary\"\n [matRippleDisabled]=\"isNested\"\n [routerLink]=\"get('routerLink')\"\n [state]=\"getState()\"\n [target]=\"target\"\n [queryParams]=\"get('queryParams')\"\n queryParamsHandling=\"merge\"\n cdkMonitorElementFocus\n [attr.aria-label]=\"ariaLabel ? node.name : null\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n >\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </a>\n <!-- We use `div`s instead of `span`s here because the legacy `ListTable` component will insert\n `div` elements into this component's content. However, this will lead to invalid HTML for \"button\"\n mode. So really, users of this component should only insert flow content. -->\n <div *ngIf=\"disabled && !alwaysRipple\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <div *ngIf=\"disabled && alwaysRipple\" matRipple matRippleColor=\"primary\">\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n</ng-container>\n<ng-container *ngIf=\"mode === 'wrapper'\">\n <div\n class=\"node-url-wrapper\"\n #wrapper\n matRipple\n matRippleColor=\"primary\"\n [matRippleDisabled]=\"disabled && !alwaysRipple\"\n (click)=\"clickWrapper($event)\"\n (auxclick)=\"clickWrapper($event)\"\n >\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </div>\n <!-- An invisible link that will by clicked programmatically by `clickWrapper()`. -->\n <a\n #link\n [routerLink]=\"get('routerLink')\"\n [state]=\"getState()\"\n [queryParams]=\"get('queryParams')\"\n queryParamsHandling=\"merge\"\n tabindex=\"-1\"\n aria-hidden=\"true\"\n class=\"cdk-visually-hidden\"\n ></a>\n</ng-container>\n<ng-container *ngIf=\"mode === 'button'\">\n <button\n [disabled]=\"disabled\"\n #link\n matRipple\n matRippleColor=\"primary\"\n [matRippleDisabled]=\"disabled && !alwaysRipple\"\n (click)=\"buttonClick.emit($event)\"\n cdkMonitorElementFocus\n >\n <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n </button>\n</ng-container>\n", styles: [":host{position:relative;display:flex}:host>*{flex-grow:1}:host>a{text-decoration:none}.cdk-keyboard-focused{outline:none;outline:var(--focusWidth) solid var(--palette-primary-300);outline-offset:2px}button{background-color:unset;border:unset;padding:unset;text-align:unset}div.node-url-wrapper{cursor:pointer}\n"] }]
|
|
82
|
-
}], ctorParameters:
|
|
82
|
+
}], ctorParameters: () => [{ type: i1.NodeHelperService }, { type: i0.ElementRef }], propDecorators: { link: [{
|
|
83
83
|
type: ViewChild,
|
|
84
84
|
args: ['link']
|
|
85
85
|
}], node: [{
|
|
@@ -129,4 +129,4 @@ function copyClickEvent(event) {
|
|
|
129
129
|
function isFirefox() {
|
|
130
130
|
return navigator.userAgent.includes('Firefox');
|
|
131
131
|
}
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-url.component.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-url/node-url.component.ts","../../../../../projects/edu-sharing-ui/src/lib/node-url/node-url.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport { Node } from 'ngx-edu-sharing-api';\nimport { NodeHelperService } from '../services/node-helper.service';\n\n// TODO: Decide if providing focus highlights and ripples with this component is a good idea. When\n// using `app-node-url` for cards, we might need highlights and ripples for the whole card while\n// `app-node-url` should only wrap the title since links with lots of content confuse screen\n// readers.\n\nconst NODE_URL_TAG_NAME = 'es-node-url';\n\n@Component({\n    selector: NODE_URL_TAG_NAME,\n    templateUrl: 'node-url.component.html',\n    styleUrls: ['node-url.component.scss'],\n})\nexport class NodeUrlComponent implements AfterViewInit {\n    @ViewChild('link') link: ElementRef<HTMLAnchorElement>;\n\n    @Input() node: Node;\n    @Input() nodes: Node[];\n    @Input() target: string;\n    @Input() scope: string;\n    /**\n     * custom query params to include\n     */\n    @Input() queryParams: { [key: string]: string | number | boolean } = {};\n    /**\n     * link: a element\n     * button: button element\n     * wrapper: div element with behavior \"like\" a link\n     */\n    @Input() mode: 'link' | 'button' | 'wrapper' = 'link';\n    @Input() disabled = false;\n    /**\n     * Show the ripple effect even when disabled.\n     *\n     * @deprecated Temporary workaround for list-table, which *sometimes* uses it's on click\n     * bindings.\n     */\n    @Input() alwaysRipple = false;\n    @Input('aria-describedby') ariaDescribedby: string;\n    @Input('aria-label') ariaLabel = true;\n\n    @Output() buttonClick = new EventEmitter<MouseEvent>();\n\n    /**\n     * Whether this instance of `NodeUrl` is nested inside another `NodeUrl`.\n     */\n    // We use nested `NodeUrl`s for a11y where we have a `NodeUrl` in wrapper mode to maximize\n    // clickable area and one in  link mode that only contains the title. We only want the outmost\n    // `NodeUrl` to apply the ripple effect.\n    //\n    // Note that nesting `NodeUrl`s is only necessary when we want to provide hover effects on parts\n    // of the outer `NodeUrl`. If we don't need that, it would be easier to attach a pseudo `:after`\n    // element to the inner `NodeUrl` that expands its click area.\n    isNested: boolean;\n\n    constructor(\n        private nodeHelper: NodeHelperService,\n        private elementRef: ElementRef<HTMLElement>,\n    ) {}\n\n    ngAfterViewInit(): void {\n        setTimeout(() => {\n            this.isNested = this.getIsNested();\n        });\n    }\n\n    getState() {\n        return {\n            scope: this.scope,\n        };\n    }\n\n    get(mode: 'routerLink' | 'queryParams'): any {\n        const result: any = this.nodeHelper.getNodeLink(mode, this.node);\n        if (mode === 'queryParams') {\n            // it is important that we remove the fromLogin info because otherwise the render component will redirect to the default page on back\n            result.fromLogin = null;\n            if (mode === 'queryParams') {\n                Object.keys(this.queryParams).forEach((k) => (result[k] = this.queryParams[k]));\n            }\n        }\n        return result;\n    }\n\n    focus(): void {\n        this.link.nativeElement.focus();\n    }\n\n    clickWrapper(event: MouseEvent) {\n        const eventCopy = copyClickEvent(event);\n        this.link.nativeElement.dispatchEvent(eventCopy);\n        event.preventDefault();\n    }\n\n    private getIsNested(): boolean {\n        let ancestor = this.elementRef.nativeElement.parentElement;\n        while (ancestor) {\n            if (ancestor.tagName === NODE_URL_TAG_NAME.toUpperCase()) {\n                return true;\n            }\n            ancestor = ancestor.parentElement;\n        }\n        return false;\n    }\n}\n\nfunction copyClickEvent(event: MouseEvent): MouseEvent {\n    // On Firefox, a middle click via neither the 'click', nor the 'auxclick' event cause a new tab\n    // to be opened when triggered programmatically. As a workaround, we simulate a ctrl click\n    // instead of a middle click. This matches Firefox's defaults, but we cannot account for\n    // changed middle-click behavior.\n    if (event.type === 'auxclick' && event.button === 1 && isFirefox()) {\n        return copyClickEvent({ ...event, type: 'click', ctrlKey: true, button: 0 });\n    }\n    // It would seem better to use `event.type` instead of hard-coding 'click', but that doesn't\n    // have the desired effect for non-click events when dispatched.\n    return new MouseEvent('click', {\n        cancelable: true,\n        button: event.button,\n        ctrlKey: event.ctrlKey,\n        shiftKey: event.shiftKey,\n        altKey: event.altKey,\n        metaKey: event.metaKey,\n    });\n}\n\nfunction isFirefox(): boolean {\n    return navigator.userAgent.includes('Firefox');\n}\n","<ng-template #content><ng-content></ng-content></ng-template>\n<ng-container *ngIf=\"mode === 'link'\">\n  <a\n    *ngIf=\"!disabled\"\n    #link\n    matRipple\n    matRippleColor=\"primary\"\n    [matRippleDisabled]=\"isNested\"\n    [routerLink]=\"get('routerLink')\"\n    [state]=\"getState()\"\n    [target]=\"target\"\n    [queryParams]=\"get('queryParams')\"\n    queryParamsHandling=\"merge\"\n    cdkMonitorElementFocus\n    [attr.aria-label]=\"ariaLabel ? node.name : null\"\n    [attr.aria-describedby]=\"ariaDescribedby\"\n  >\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </a>\n  <!-- We use `div`s instead of `span`s here because the legacy `ListTable` component will insert\n  `div` elements into this component's content. However, this will lead to invalid HTML for \"button\"\n  mode. So really, users of this component should only insert flow content. -->\n  <div *ngIf=\"disabled && !alwaysRipple\">\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </div>\n  <div *ngIf=\"disabled && alwaysRipple\" matRipple matRippleColor=\"primary\">\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </div>\n</ng-container>\n<ng-container *ngIf=\"mode === 'wrapper'\">\n  <div\n    class=\"node-url-wrapper\"\n    #wrapper\n    matRipple\n    matRippleColor=\"primary\"\n    [matRippleDisabled]=\"disabled && !alwaysRipple\"\n    (click)=\"clickWrapper($event)\"\n    (auxclick)=\"clickWrapper($event)\"\n  >\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </div>\n  <!-- An invisible link that will by clicked programmatically by `clickWrapper()`. -->\n  <a\n    #link\n    [routerLink]=\"get('routerLink')\"\n    [state]=\"getState()\"\n    [queryParams]=\"get('queryParams')\"\n    queryParamsHandling=\"merge\"\n    tabindex=\"-1\"\n    aria-hidden=\"true\"\n    class=\"cdk-visually-hidden\"\n  ></a>\n</ng-container>\n<ng-container *ngIf=\"mode === 'button'\">\n  <button\n    [disabled]=\"disabled\"\n    #link\n    matRipple\n    matRippleColor=\"primary\"\n    [matRippleDisabled]=\"disabled && !alwaysRipple\"\n    (click)=\"buttonClick.emit($event)\"\n    cdkMonitorElementFocus\n  >\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </button>\n</ng-container>\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-url.component.js","sourceRoot":"","sources":["../../../../../projects/edu-sharing-ui/src/lib/node-url/node-url.component.ts","../../../../../projects/edu-sharing-ui/src/lib/node-url/node-url.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEH,SAAS,EAET,YAAY,EACZ,KAAK,EACL,MAAM,EACN,SAAS,GACZ,MAAM,eAAe,CAAC;;;;;;AAIvB,kGAAkG;AAClG,gGAAgG;AAChG,4FAA4F;AAC5F,WAAW;AAEX,MAAM,iBAAiB,GAAG,aAAa,CAAC;AAOxC,MAAM,OAAO,gBAAgB;IA0CzB,YACY,UAA6B,EAC7B,UAAmC;QADnC,eAAU,GAAV,UAAU,CAAmB;QAC7B,eAAU,GAAV,UAAU,CAAyB;QArC/C;;WAEG;QACM,gBAAW,GAAiD,EAAE,CAAC;QACxE;;;;WAIG;QACM,SAAI,GAAkC,MAAM,CAAC;QAC7C,aAAQ,GAAG,KAAK,CAAC;QAC1B;;;;;WAKG;QACM,iBAAY,GAAG,KAAK,CAAC;QAET,cAAS,GAAG,IAAI,CAAC;QAE5B,gBAAW,GAAG,IAAI,YAAY,EAAc,CAAC;IAiBpD,CAAC;IAEJ,eAAe;QACX,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;QACvC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,QAAQ;QACJ,OAAO;YACH,KAAK,EAAE,IAAI,CAAC,KAAK;SACpB,CAAC;IACN,CAAC;IAED,GAAG,CAAC,IAAkC;QAClC,MAAM,MAAM,GAAQ,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;QACjE,IAAI,IAAI,KAAK,aAAa,EAAE,CAAC;YACzB,qIAAqI;YACrI,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC;YACxB,IAAI,IAAI,KAAK,aAAa,EAAE,CAAC;gBACzB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACpF,CAAC;QACL,CAAC;QACD,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,KAAK;QACD,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACpC,CAAC;IAED,YAAY,CAAC,KAAiB;QAC1B,MAAM,SAAS,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;QACxC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;QACjD,KAAK,CAAC,cAAc,EAAE,CAAC;IAC3B,CAAC;IAEO,WAAW;QACf,IAAI,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC;QAC3D,OAAO,QAAQ,EAAE,CAAC;YACd,IAAI,QAAQ,CAAC,OAAO,KAAK,iBAAiB,CAAC,WAAW,EAAE,EAAE,CAAC;gBACvD,OAAO,IAAI,CAAC;YAChB,CAAC;YACD,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC;QACtC,CAAC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;+GA1FQ,gBAAgB;mGAAhB,gBAAgB,scCxB7B,suEAkEA;;4FD1Ca,gBAAgB;kBAL5B,SAAS;+BACI,iBAAiB;+GAKR,IAAI;sBAAtB,SAAS;uBAAC,MAAM;gBAER,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAIG,WAAW;sBAAnB,KAAK;gBAMG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAOG,YAAY;sBAApB,KAAK;gBACqB,eAAe;sBAAzC,KAAK;uBAAC,kBAAkB;gBACJ,SAAS;sBAA7B,KAAK;uBAAC,YAAY;gBAET,WAAW;sBAApB,MAAM;;AAiEX,SAAS,cAAc,CAAC,KAAiB;IACrC,+FAA+F;IAC/F,0FAA0F;IAC1F,wFAAwF;IACxF,iCAAiC;IACjC,IAAI,KAAK,CAAC,IAAI,KAAK,UAAU,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,SAAS,EAAE,EAAE,CAAC;QACjE,OAAO,cAAc,CAAC,EAAE,GAAG,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;IACjF,CAAC;IACD,4FAA4F;IAC5F,gEAAgE;IAChE,OAAO,IAAI,UAAU,CAAC,OAAO,EAAE;QAC3B,UAAU,EAAE,IAAI;QAChB,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,OAAO,EAAE,KAAK,CAAC,OAAO;QACtB,QAAQ,EAAE,KAAK,CAAC,QAAQ;QACxB,MAAM,EAAE,KAAK,CAAC,MAAM;QACpB,OAAO,EAAE,KAAK,CAAC,OAAO;KACzB,CAAC,CAAC;AACP,CAAC;AAED,SAAS,SAAS;IACd,OAAO,SAAS,CAAC,SAAS,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;AACnD,CAAC","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport { Node } from 'ngx-edu-sharing-api';\nimport { NodeHelperService } from '../services/node-helper.service';\n\n// TODO: Decide if providing focus highlights and ripples with this component is a good idea. When\n// using `app-node-url` for cards, we might need highlights and ripples for the whole card while\n// `app-node-url` should only wrap the title since links with lots of content confuse screen\n// readers.\n\nconst NODE_URL_TAG_NAME = 'es-node-url';\n\n@Component({\n    selector: NODE_URL_TAG_NAME,\n    templateUrl: 'node-url.component.html',\n    styleUrls: ['node-url.component.scss'],\n})\nexport class NodeUrlComponent implements AfterViewInit {\n    @ViewChild('link') link: ElementRef<HTMLAnchorElement>;\n\n    @Input() node: Node;\n    @Input() nodes: Node[];\n    @Input() target: string;\n    @Input() scope: string;\n    /**\n     * custom query params to include\n     */\n    @Input() queryParams: { [key: string]: string | number | boolean } = {};\n    /**\n     * link: a element\n     * button: button element\n     * wrapper: div element with behavior \"like\" a link\n     */\n    @Input() mode: 'link' | 'button' | 'wrapper' = 'link';\n    @Input() disabled = false;\n    /**\n     * Show the ripple effect even when disabled.\n     *\n     * @deprecated Temporary workaround for list-table, which *sometimes* uses it's on click\n     * bindings.\n     */\n    @Input() alwaysRipple = false;\n    @Input('aria-describedby') ariaDescribedby: string;\n    @Input('aria-label') ariaLabel = true;\n\n    @Output() buttonClick = new EventEmitter<MouseEvent>();\n\n    /**\n     * Whether this instance of `NodeUrl` is nested inside another `NodeUrl`.\n     */\n    // We use nested `NodeUrl`s for a11y where we have a `NodeUrl` in wrapper mode to maximize\n    // clickable area and one in  link mode that only contains the title. We only want the outmost\n    // `NodeUrl` to apply the ripple effect.\n    //\n    // Note that nesting `NodeUrl`s is only necessary when we want to provide hover effects on parts\n    // of the outer `NodeUrl`. If we don't need that, it would be easier to attach a pseudo `:after`\n    // element to the inner `NodeUrl` that expands its click area.\n    isNested: boolean;\n\n    constructor(\n        private nodeHelper: NodeHelperService,\n        private elementRef: ElementRef<HTMLElement>,\n    ) {}\n\n    ngAfterViewInit(): void {\n        setTimeout(() => {\n            this.isNested = this.getIsNested();\n        });\n    }\n\n    getState() {\n        return {\n            scope: this.scope,\n        };\n    }\n\n    get(mode: 'routerLink' | 'queryParams'): any {\n        const result: any = this.nodeHelper.getNodeLink(mode, this.node);\n        if (mode === 'queryParams') {\n            // it is important that we remove the fromLogin info because otherwise the render component will redirect to the default page on back\n            result.fromLogin = null;\n            if (mode === 'queryParams') {\n                Object.keys(this.queryParams).forEach((k) => (result[k] = this.queryParams[k]));\n            }\n        }\n        return result;\n    }\n\n    focus(): void {\n        this.link.nativeElement.focus();\n    }\n\n    clickWrapper(event: MouseEvent) {\n        const eventCopy = copyClickEvent(event);\n        this.link.nativeElement.dispatchEvent(eventCopy);\n        event.preventDefault();\n    }\n\n    private getIsNested(): boolean {\n        let ancestor = this.elementRef.nativeElement.parentElement;\n        while (ancestor) {\n            if (ancestor.tagName === NODE_URL_TAG_NAME.toUpperCase()) {\n                return true;\n            }\n            ancestor = ancestor.parentElement;\n        }\n        return false;\n    }\n}\n\nfunction copyClickEvent(event: MouseEvent): MouseEvent {\n    // On Firefox, a middle click via neither the 'click', nor the 'auxclick' event cause a new tab\n    // to be opened when triggered programmatically. As a workaround, we simulate a ctrl click\n    // instead of a middle click. This matches Firefox's defaults, but we cannot account for\n    // changed middle-click behavior.\n    if (event.type === 'auxclick' && event.button === 1 && isFirefox()) {\n        return copyClickEvent({ ...event, type: 'click', ctrlKey: true, button: 0 });\n    }\n    // It would seem better to use `event.type` instead of hard-coding 'click', but that doesn't\n    // have the desired effect for non-click events when dispatched.\n    return new MouseEvent('click', {\n        cancelable: true,\n        button: event.button,\n        ctrlKey: event.ctrlKey,\n        shiftKey: event.shiftKey,\n        altKey: event.altKey,\n        metaKey: event.metaKey,\n    });\n}\n\nfunction isFirefox(): boolean {\n    return navigator.userAgent.includes('Firefox');\n}\n","<ng-template #content><ng-content></ng-content></ng-template>\n<ng-container *ngIf=\"mode === 'link'\">\n  <a\n    *ngIf=\"!disabled\"\n    #link\n    matRipple\n    matRippleColor=\"primary\"\n    [matRippleDisabled]=\"isNested\"\n    [routerLink]=\"get('routerLink')\"\n    [state]=\"getState()\"\n    [target]=\"target\"\n    [queryParams]=\"get('queryParams')\"\n    queryParamsHandling=\"merge\"\n    cdkMonitorElementFocus\n    [attr.aria-label]=\"ariaLabel ? node.name : null\"\n    [attr.aria-describedby]=\"ariaDescribedby\"\n  >\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </a>\n  <!-- We use `div`s instead of `span`s here because the legacy `ListTable` component will insert\n  `div` elements into this component's content. However, this will lead to invalid HTML for \"button\"\n  mode. So really, users of this component should only insert flow content. -->\n  <div *ngIf=\"disabled && !alwaysRipple\">\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </div>\n  <div *ngIf=\"disabled && alwaysRipple\" matRipple matRippleColor=\"primary\">\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </div>\n</ng-container>\n<ng-container *ngIf=\"mode === 'wrapper'\">\n  <div\n    class=\"node-url-wrapper\"\n    #wrapper\n    matRipple\n    matRippleColor=\"primary\"\n    [matRippleDisabled]=\"disabled && !alwaysRipple\"\n    (click)=\"clickWrapper($event)\"\n    (auxclick)=\"clickWrapper($event)\"\n  >\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </div>\n  <!-- An invisible link that will by clicked programmatically by `clickWrapper()`. -->\n  <a\n    #link\n    [routerLink]=\"get('routerLink')\"\n    [state]=\"getState()\"\n    [queryParams]=\"get('queryParams')\"\n    queryParamsHandling=\"merge\"\n    tabindex=\"-1\"\n    aria-hidden=\"true\"\n    class=\"cdk-visually-hidden\"\n  ></a>\n</ng-container>\n<ng-container *ngIf=\"mode === 'button'\">\n  <button\n    [disabled]=\"disabled\"\n    #link\n    matRipple\n    matRippleColor=\"primary\"\n    [matRippleDisabled]=\"disabled && !alwaysRipple\"\n    (click)=\"buttonClick.emit($event)\"\n    cdkMonitorElementFocus\n  >\n    <ng-container *ngTemplateOutlet=\"content\"></ng-container>\n  </button>\n</ng-container>\n"]}
|
|
@@ -22,11 +22,11 @@ export class FormatSizePipe {
|
|
|
22
22
|
let numberFormat = new Intl.NumberFormat([], options);
|
|
23
23
|
return numberFormat.format(value) + ' ' + names[i];
|
|
24
24
|
}
|
|
25
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
26
|
-
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "
|
|
25
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: FormatSizePipe, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
26
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.12", ngImport: i0, type: FormatSizePipe, name: "formatSize" }); }
|
|
27
27
|
}
|
|
28
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: FormatSizePipe, decorators: [{
|
|
29
29
|
type: Pipe,
|
|
30
30
|
args: [{ name: 'formatSize' }]
|
|
31
|
-
}], ctorParameters:
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
}], ctorParameters: () => [{ type: i1.TranslateService }] });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1zaXplLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lZHUtc2hhcmluZy11aS9zcmMvbGliL3BpcGVzL2ZpbGUtc2l6ZS5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsSUFBSSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFJcEQsTUFBTSxPQUFPLGNBQWM7SUFDdkIsWUFBb0IsU0FBMkI7UUFBM0IsY0FBUyxHQUFULFNBQVMsQ0FBa0I7SUFBRyxDQUFDO0lBRW5ELFNBQVMsQ0FBQyxLQUFVLEVBQUUsT0FBaUIsSUFBSTtRQUN2QyxJQUFJLEtBQUssR0FBRyxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztRQUM5QyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDVixJQUFJLEtBQUssQ0FBQyxLQUFLLENBQUM7WUFBRSxPQUFPLEtBQUssQ0FBQztRQUMvQixJQUFJLEtBQUssSUFBSSxJQUFJO1lBQUUsS0FBSyxHQUFHLENBQUMsQ0FBQztRQUM3QixPQUFPLEtBQUssSUFBSSxJQUFJLElBQUksQ0FBQyxHQUFHLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUN2QyxLQUFLLElBQUksSUFBSSxDQUFDO1lBQ2QsQ0FBQyxFQUFFLENBQUM7UUFDUixDQUFDO1FBQ0QsSUFBSSxPQUFPLEdBQTZCO1lBQ3BDLHFCQUFxQixFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUN2QyxDQUFDO1FBQ0YsSUFBSSxZQUFZLEdBQUcsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLEVBQUUsRUFBRSxPQUFPLENBQUMsQ0FBQztRQUN0RCxPQUFPLFlBQVksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsR0FBRyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN2RCxDQUFDOytHQWpCUSxjQUFjOzZHQUFkLGNBQWM7OzRGQUFkLGNBQWM7a0JBRDFCLElBQUk7bUJBQUMsRUFBRSxJQUFJLEVBQUUsWUFBWSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZVRyYW5zZm9ybSwgUGlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuXG5AUGlwZSh7IG5hbWU6ICdmb3JtYXRTaXplJyB9KVxuZXhwb3J0IGNsYXNzIEZvcm1hdFNpemVQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSB0cmFuc2xhdGU6IFRyYW5zbGF0ZVNlcnZpY2UpIHt9XG5cbiAgICB0cmFuc2Zvcm0odmFsdWU6IGFueSwgYXJnczogc3RyaW5nW10gPSBudWxsKTogc3RyaW5nIHtcbiAgICAgICAgbGV0IG5hbWVzID0gWydieXRlcycsICdLQicsICdNQicsICdHQicsICdUQiddO1xuICAgICAgICBsZXQgaSA9IDA7XG4gICAgICAgIGlmIChpc05hTih2YWx1ZSkpIHJldHVybiB2YWx1ZTtcbiAgICAgICAgaWYgKHZhbHVlID09IG51bGwpIHZhbHVlID0gMDtcbiAgICAgICAgd2hpbGUgKHZhbHVlID49IDEwMjQgJiYgaSA8IG5hbWVzLmxlbmd0aCkge1xuICAgICAgICAgICAgdmFsdWUgLz0gMTAyNDtcbiAgICAgICAgICAgIGkrKztcbiAgICAgICAgfVxuICAgICAgICBsZXQgb3B0aW9uczogSW50bC5OdW1iZXJGb3JtYXRPcHRpb25zID0ge1xuICAgICAgICAgICAgbWF4aW11bUZyYWN0aW9uRGlnaXRzOiBpID4gMSA/IDEgOiAwLFxuICAgICAgICB9O1xuICAgICAgICBsZXQgbnVtYmVyRm9ybWF0ID0gbmV3IEludGwuTnVtYmVyRm9ybWF0KFtdLCBvcHRpb25zKTtcbiAgICAgICAgcmV0dXJuIG51bWJlckZvcm1hdC5mb3JtYXQodmFsdWUpICsgJyAnICsgbmFtZXNbaV07XG4gICAgfVxufVxuIl19
|