@dontdrinkandroot/ngx-material-extensions 0.6.0 → 0.7.1

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.
@@ -1,55 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { ContentChildren, Directive, HostListener } from '@angular/core';
3
- import { GridTileLazyImgDirective } from './grid-tile-lazy-img.directive';
4
- import { Debounce, Limit } from '@dontdrinkandroot/ngx-extensions';
5
- import * as i0 from "@angular/core";
6
- export class GridTileLazyImageContainerDirective {
7
- windowResized($event) {
8
- if (null != this.lazyImages) {
9
- this.lazyImages.forEach((lazyImage, index) => lazyImage.recheck());
10
- }
11
- }
12
- windowScroll($event) {
13
- if (null != this.lazyImages) {
14
- this.lazyImages.forEach((lazyImage, index) => lazyImage.check());
15
- }
16
- }
17
- /**
18
- * @override
19
- */
20
- ngAfterContentInit() {
21
- this.lazyImages.forEach((lazyImage, index) => lazyImage.check());
22
- this.changeSubscription = this.lazyImages.changes.subscribe(() => {
23
- /* Wait one tick until layout is ready */
24
- setTimeout(() => this.lazyImages.forEach((lazyImage, index) => lazyImage.recheck()), 1);
25
- });
26
- }
27
- /**
28
- * @override
29
- */
30
- ngOnDestroy() {
31
- this.changeSubscription.unsubscribe();
32
- }
33
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: GridTileLazyImageContainerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
34
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.1", type: GridTileLazyImageContainerDirective, selector: "[ddrGridTileLazyImgContainer]", host: { listeners: { "window:resize": "windowResized($event)", "window:scroll": "windowScroll($event)" } }, queries: [{ propertyName: "lazyImages", predicate: GridTileLazyImgDirective, descendants: true }], ngImport: i0 }); }
35
- }
36
- __decorate([
37
- Debounce()
38
- ], GridTileLazyImageContainerDirective.prototype, "windowResized", null);
39
- __decorate([
40
- Limit()
41
- ], GridTileLazyImageContainerDirective.prototype, "windowScroll", null);
42
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: GridTileLazyImageContainerDirective, decorators: [{
43
- type: Directive,
44
- args: [{ selector: '[ddrGridTileLazyImgContainer]' }]
45
- }], propDecorators: { lazyImages: [{
46
- type: ContentChildren,
47
- args: [GridTileLazyImgDirective, { descendants: true }]
48
- }], windowResized: [{
49
- type: HostListener,
50
- args: ['window:resize', ['$event']]
51
- }], windowScroll: [{
52
- type: HostListener,
53
- args: ['window:scroll', ['$event']]
54
- }] } });
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC10aWxlLWxhenktaW1hZ2UtY29udGFpbmVyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9ncmlkbGlzdC9ncmlkLXRpbGUtbGF6eS1pbWFnZS1jb250YWluZXIuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQW1CLGVBQWUsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUMvRyxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUV4RSxPQUFPLEVBQUMsUUFBUSxFQUFFLEtBQUssRUFBQyxNQUFNLGtDQUFrQyxDQUFDOztBQUdqRSxNQUFNLE9BQU8sbUNBQW1DO0lBUXJDLGFBQWEsQ0FBQyxNQUFhO1FBRTlCLElBQUksSUFBSSxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUMxQixJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLFNBQW1DLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztRQUNqRyxDQUFDO0lBQ0wsQ0FBQztJQUlNLFlBQVksQ0FBQyxNQUFhO1FBRTdCLElBQUksSUFBSSxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUMxQixJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLFNBQW1DLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQztRQUMvRixDQUFDO0lBQ0wsQ0FBQztJQUVEOztPQUVHO0lBQ0ksa0JBQWtCO1FBRXJCLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUMsU0FBbUMsRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBQzNGLElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQzdELHlDQUF5QztZQUN6QyxVQUFVLENBQ04sR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQyxTQUFtQyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFBRSxDQUFDLEVBQ2hHLENBQUMsQ0FDTixDQUFDO1FBQ04sQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxXQUFXO1FBRWQsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzFDLENBQUM7OEdBN0NRLG1DQUFtQztrR0FBbkMsbUNBQW1DLDRNQUUzQix3QkFBd0I7O0FBTWxDO0lBRE4sUUFBUSxFQUFFO3dFQU1WO0FBSU07SUFETixLQUFLLEVBQUU7dUVBTVA7MkZBdEJRLG1DQUFtQztrQkFEL0MsU0FBUzttQkFBQyxFQUFDLFFBQVEsRUFBRSwrQkFBK0IsRUFBQzs4QkFHYyxVQUFVO3NCQUF6RSxlQUFlO3VCQUFDLHdCQUF3QixFQUFFLEVBQUMsV0FBVyxFQUFFLElBQUksRUFBQztnQkFNdkQsYUFBYTtzQkFGbkIsWUFBWTt1QkFBQyxlQUFlLEVBQUUsQ0FBQyxRQUFRLENBQUM7Z0JBV2xDLFlBQVk7c0JBRmxCLFlBQVk7dUJBQUMsZUFBZSxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBZnRlckNvbnRlbnRJbml0LCBDb250ZW50Q2hpbGRyZW4sIERpcmVjdGl2ZSwgSG9zdExpc3RlbmVyLCBPbkRlc3Ryb3ksIFF1ZXJ5TGlzdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0dyaWRUaWxlTGF6eUltZ0RpcmVjdGl2ZX0gZnJvbSAnLi9ncmlkLXRpbGUtbGF6eS1pbWcuZGlyZWN0aXZlJztcbmltcG9ydCB7U3Vic2NyaXB0aW9ufSBmcm9tICdyeGpzJztcbmltcG9ydCB7RGVib3VuY2UsIExpbWl0fSBmcm9tICdAZG9udGRyaW5rYW5kcm9vdC9uZ3gtZXh0ZW5zaW9ucyc7XG5cbkBEaXJlY3RpdmUoe3NlbGVjdG9yOiAnW2RkckdyaWRUaWxlTGF6eUltZ0NvbnRhaW5lcl0nfSlcbmV4cG9ydCBjbGFzcyBHcmlkVGlsZUxhenlJbWFnZUNvbnRhaW5lckRpcmVjdGl2ZSBpbXBsZW1lbnRzIEFmdGVyQ29udGVudEluaXQsIE9uRGVzdHJveVxue1xuICAgIEBDb250ZW50Q2hpbGRyZW4oR3JpZFRpbGVMYXp5SW1nRGlyZWN0aXZlLCB7ZGVzY2VuZGFudHM6IHRydWV9KSBsYXp5SW1hZ2VzITogUXVlcnlMaXN0PEdyaWRUaWxlTGF6eUltZ0RpcmVjdGl2ZT47XG5cbiAgICBwcml2YXRlIGNoYW5nZVN1YnNjcmlwdGlvbiE6IFN1YnNjcmlwdGlvbjtcblxuICAgIEBIb3N0TGlzdGVuZXIoJ3dpbmRvdzpyZXNpemUnLCBbJyRldmVudCddKVxuICAgIEBEZWJvdW5jZSgpXG4gICAgcHVibGljIHdpbmRvd1Jlc2l6ZWQoJGV2ZW50OiBFdmVudClcbiAgICB7XG4gICAgICAgIGlmIChudWxsICE9IHRoaXMubGF6eUltYWdlcykge1xuICAgICAgICAgICAgdGhpcy5sYXp5SW1hZ2VzLmZvckVhY2goKGxhenlJbWFnZTogR3JpZFRpbGVMYXp5SW1nRGlyZWN0aXZlLCBpbmRleCkgPT4gbGF6eUltYWdlLnJlY2hlY2soKSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCd3aW5kb3c6c2Nyb2xsJywgWyckZXZlbnQnXSlcbiAgICBATGltaXQoKVxuICAgIHB1YmxpYyB3aW5kb3dTY3JvbGwoJGV2ZW50OiBFdmVudClcbiAgICB7XG4gICAgICAgIGlmIChudWxsICE9IHRoaXMubGF6eUltYWdlcykge1xuICAgICAgICAgICAgdGhpcy5sYXp5SW1hZ2VzLmZvckVhY2goKGxhenlJbWFnZTogR3JpZFRpbGVMYXp5SW1nRGlyZWN0aXZlLCBpbmRleCkgPT4gbGF6eUltYWdlLmNoZWNrKCkpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQG92ZXJyaWRlXG4gICAgICovXG4gICAgcHVibGljIG5nQWZ0ZXJDb250ZW50SW5pdCgpOiB2b2lkXG4gICAge1xuICAgICAgICB0aGlzLmxhenlJbWFnZXMuZm9yRWFjaCgobGF6eUltYWdlOiBHcmlkVGlsZUxhenlJbWdEaXJlY3RpdmUsIGluZGV4KSA9PiBsYXp5SW1hZ2UuY2hlY2soKSk7XG4gICAgICAgIHRoaXMuY2hhbmdlU3Vic2NyaXB0aW9uID0gdGhpcy5sYXp5SW1hZ2VzLmNoYW5nZXMuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgIC8qIFdhaXQgb25lIHRpY2sgdW50aWwgbGF5b3V0IGlzIHJlYWR5ICovXG4gICAgICAgICAgICBzZXRUaW1lb3V0KFxuICAgICAgICAgICAgICAgICgpID0+IHRoaXMubGF6eUltYWdlcy5mb3JFYWNoKChsYXp5SW1hZ2U6IEdyaWRUaWxlTGF6eUltZ0RpcmVjdGl2ZSwgaW5kZXgpID0+IGxhenlJbWFnZS5yZWNoZWNrKCkpXG4gICAgICAgICAgICAgICAgLCAxXG4gICAgICAgICAgICApO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBAb3ZlcnJpZGVcbiAgICAgKi9cbiAgICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZFxuICAgIHtcbiAgICAgICAgdGhpcy5jaGFuZ2VTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgICB9XG59XG4iXX0=
@@ -1,115 +0,0 @@
1
- import { Directive, HostBinding, Input } from '@angular/core';
2
- import { NumberUtils, StringUtils } from '@dontdrinkandroot/ngx-extensions';
3
- import * as i0 from "@angular/core";
4
- export class GridTileLazyImgDirective {
5
- constructor(element, cd) {
6
- this.element = element;
7
- this.cd = cd;
8
- this.hostSrc = 'assets/placeholder.gif';
9
- this.hostStyleObjectFit = 'contain';
10
- this.hostStyleOpacity = 0;
11
- this.offset = 1000;
12
- this.objectFit = 'cover';
13
- this.displayed = false;
14
- this.maxLoadedDimension = null;
15
- }
16
- recheck() {
17
- this.displayed = false;
18
- this.check();
19
- }
20
- check() {
21
- if (this.displayed
22
- || this.isHidden(this.element.nativeElement)
23
- || !this.isInsideViewport(this.element.nativeElement, this.offset)) {
24
- return;
25
- }
26
- this.displayed = true;
27
- const dimension = this.getDimension();
28
- if (null != this.maxLoadedDimension
29
- && this.maxLoadedDimension.width >= dimension.width
30
- && this.maxLoadedDimension.height >= dimension.height) {
31
- return;
32
- }
33
- this.maxLoadedDimension = dimension;
34
- this.hostStyleWidthPx = dimension.width;
35
- this.hostStyleHeightPx = dimension.height;
36
- let wantedSize;
37
- if (this.objectFit === 'cover') {
38
- wantedSize = NumberUtils.getNextPowerOfTwo(Math.max(dimension.width, dimension.height));
39
- this.hostStyleObjectFit = 'cover';
40
- }
41
- else {
42
- wantedSize = NumberUtils.getNextPowerOfTwo(Math.min(dimension.width, dimension.height));
43
- this.hostStyleObjectFit = 'contain';
44
- }
45
- this.hostSrc = StringUtils.updateUrlParameter(this.src, 'size', String(wantedSize));
46
- this.hostStyleOpacity = 1;
47
- this.cd.detectChanges();
48
- }
49
- /**
50
- * @override
51
- */
52
- ngOnChanges(changes) {
53
- this.displayed = false;
54
- this.maxLoadedDimension = null;
55
- this.hostStyleOpacity = 0;
56
- if (this.element.nativeElement.parentElement.offsetWidth > 0) {
57
- this.check();
58
- }
59
- }
60
- isInsideViewport(nativeElement, offset) {
61
- // console.log('isInsideViewport');
62
- const ownerDocument = nativeElement.ownerDocument;
63
- const documentTop = window.pageYOffset || ownerDocument.body.scrollTop;
64
- const documentLeft = window.pageXOffset || ownerDocument.body.scrollLeft;
65
- const documentWidth = window.innerWidth || (ownerDocument.documentElement.clientWidth || document.body.clientWidth);
66
- const documentHeight = window.innerHeight || (ownerDocument.documentElement.clientHeight || document.body.clientHeight);
67
- const topOffset = nativeElement.getBoundingClientRect().top + documentTop - ownerDocument.documentElement.clientTop;
68
- const leftOffset = nativeElement.getBoundingClientRect().left + documentLeft - ownerDocument.documentElement.clientLeft;
69
- // console.log(documentWidth, documentHeight, topOffset, leftOffset);
70
- const isBelowViewport = documentHeight + documentTop <= topOffset - offset;
71
- const isAtRightOfViewport = documentWidth + window.pageXOffset <= leftOffset - offset;
72
- const isAboveViewport = documentTop >= topOffset + offset + nativeElement.offsetHeight;
73
- const isAtLeftOfViewport = documentLeft >= leftOffset + offset + nativeElement.offsetWidth;
74
- return !isBelowViewport && !isAboveViewport && !isAtRightOfViewport && !isAtLeftOfViewport;
75
- }
76
- getDimension() {
77
- return {
78
- width: this.element.nativeElement.parentElement.offsetWidth,
79
- height: this.element.nativeElement.parentElement.offsetHeight,
80
- };
81
- }
82
- isHidden(nativeElement) {
83
- // console.log('isHidden');
84
- return window.getComputedStyle(nativeElement).display === 'none';
85
- }
86
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: GridTileLazyImgDirective, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
87
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.1", type: GridTileLazyImgDirective, selector: "[ddrGridTileLazyImg]", inputs: { src: ["ddrGridTileLazyImg", "src"], offset: "offset", objectFit: "objectFit" }, host: { properties: { "src": "this.hostSrc", "style.object-fit": "this.hostStyleObjectFit", "style.width.px": "this.hostStyleWidthPx", "style.height.px": "this.hostStyleHeightPx", "style.opacity": "this.hostStyleOpacity" } }, usesOnChanges: true, ngImport: i0 }); }
88
- }
89
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: GridTileLazyImgDirective, decorators: [{
90
- type: Directive,
91
- args: [{ selector: '[ddrGridTileLazyImg]' }]
92
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], propDecorators: { src: [{
93
- type: Input,
94
- args: ['ddrGridTileLazyImg']
95
- }], hostSrc: [{
96
- type: HostBinding,
97
- args: ['src']
98
- }], hostStyleObjectFit: [{
99
- type: HostBinding,
100
- args: ['style.object-fit']
101
- }], hostStyleWidthPx: [{
102
- type: HostBinding,
103
- args: ['style.width.px']
104
- }], hostStyleHeightPx: [{
105
- type: HostBinding,
106
- args: ['style.height.px']
107
- }], hostStyleOpacity: [{
108
- type: HostBinding,
109
- args: ['style.opacity']
110
- }], offset: [{
111
- type: Input
112
- }], objectFit: [{
113
- type: Input
114
- }] } });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-tile-lazy-img.directive.js","sourceRoot":"","sources":["../../../../src/gridlist/grid-tile-lazy-img.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAc,WAAW,EAAE,KAAK,EAA2B,MAAM,eAAe,CAAC;AACrH,OAAO,EAAC,WAAW,EAAE,WAAW,EAAC,MAAM,kCAAkC,CAAC;;AAG1E,MAAM,OAAO,wBAAwB;IA8BjC,YAAoB,OAAmB,EAAU,EAAqB;QAAlD,YAAO,GAAP,OAAO,CAAY;QAAU,OAAE,GAAF,EAAE,CAAmB;QAxB/D,YAAO,GAAG,wBAAwB,CAAC;QAGnC,uBAAkB,GAAG,SAAS,CAAC;QAS/B,qBAAgB,GAAG,CAAC,CAAC;QAGrB,WAAM,GAAG,IAAI,CAAC;QAGd,cAAS,GAAG,OAAO,CAAC;QAEnB,cAAS,GAAG,KAAK,CAAC;QAElB,uBAAkB,GAA6C,IAAI,CAAC;IAI5E,CAAC;IAEM,OAAO;QAEV,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,KAAK,EAAE,CAAC;IACjB,CAAC;IAEM,KAAK;QAER,IACI,IAAI,CAAC,SAAS;eACX,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;eACzC,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,EACpE,CAAC;YACC,OAAO;QACX,CAAC;QAED,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAEtC,IACI,IAAI,IAAI,IAAI,CAAC,kBAAkB;eAC5B,IAAI,CAAC,kBAAkB,CAAC,KAAK,IAAI,SAAS,CAAC,KAAK;eAChD,IAAI,CAAC,kBAAkB,CAAC,MAAM,IAAI,SAAS,CAAC,MAAM,EACvD,CAAC;YACC,OAAO;QACX,CAAC;QAED,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC;QACpC,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC,KAAK,CAAC;QACxC,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC,MAAM,CAAC;QAC1C,IAAI,UAAkB,CAAC;QACvB,IAAI,IAAI,CAAC,SAAS,KAAK,OAAO,EAAE,CAAC;YAC7B,UAAU,GAAG,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;YACxF,IAAI,CAAC,kBAAkB,GAAG,OAAO,CAAC;QACtC,CAAC;aAAM,CAAC;YACJ,UAAU,GAAG,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,KAAK,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;YACxF,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC;QACxC,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,kBAAkB,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC;QACpF,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;QAC1B,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;IAC5B,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,OAAsB;QAErC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;QAC/B,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC;QAC1B,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,GAAG,CAAC,EAAE,CAAC;YAC3D,IAAI,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC;IACL,CAAC;IAEO,gBAAgB,CAAC,aAA0B,EAAE,MAAc;QAE/D,mCAAmC;QACnC,MAAM,aAAa,GAAG,aAAa,CAAC,aAAa,CAAC;QAClD,MAAM,WAAW,GAAG,MAAM,CAAC,WAAW,IAAI,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC;QACvE,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,IAAI,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC;QAEzE,MAAM,aAAa,GAAG,MAAM,CAAC,UAAU,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,WAAW,IAAI,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpH,MAAM,cAAc,GAAG,MAAM,CAAC,WAAW,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,YAAY,IAAI,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACxH,MAAM,SAAS,GAAG,aAAa,CAAC,qBAAqB,EAAE,CAAC,GAAG,GAAG,WAAW,GAAG,aAAa,CAAC,eAAe,CAAC,SAAS,CAAC;QACpH,MAAM,UAAU,GAAG,aAAa,CAAC,qBAAqB,EAAE,CAAC,IAAI,GAAG,YAAY,GAAG,aAAa,CAAC,eAAe,CAAC,UAAU,CAAC;QAExH,qEAAqE;QAErE,MAAM,eAAe,GAAG,cAAc,GAAG,WAAW,IAAI,SAAS,GAAG,MAAM,CAAC;QAC3E,MAAM,mBAAmB,GAAG,aAAa,GAAG,MAAM,CAAC,WAAW,IAAI,UAAU,GAAG,MAAM,CAAC;QACtF,MAAM,eAAe,GAAG,WAAW,IAAI,SAAS,GAAG,MAAM,GAAG,aAAa,CAAC,YAAY,CAAC;QACvF,MAAM,kBAAkB,GAAG,YAAY,IAAI,UAAU,GAAG,MAAM,GAAG,aAAa,CAAC,WAAW,CAAC;QAE3F,OAAO,CAAC,eAAe,IAAI,CAAC,eAAe,IAAI,CAAC,mBAAmB,IAAI,CAAC,kBAAkB,CAAC;IAC/F,CAAC;IAEO,YAAY;QAEhB,OAAO;YACH,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW;YAC3D,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,YAAY;SAChE,CAAC;IACN,CAAC;IAEO,QAAQ,CAAC,aAA0B;QAEvC,2BAA2B;QAC3B,OAAO,MAAM,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,OAAO,KAAK,MAAM,CAAC;IACrE,CAAC;8GA5HQ,wBAAwB;kGAAxB,wBAAwB;;2FAAxB,wBAAwB;kBADpC,SAAS;mBAAC,EAAC,QAAQ,EAAE,sBAAsB,EAAC;+GAIlC,GAAG;sBADT,KAAK;uBAAC,oBAAoB;gBAIpB,OAAO;sBADb,WAAW;uBAAC,KAAK;gBAIX,kBAAkB;sBADxB,WAAW;uBAAC,kBAAkB;gBAIxB,gBAAgB;sBADtB,WAAW;uBAAC,gBAAgB;gBAItB,iBAAiB;sBADvB,WAAW;uBAAC,iBAAiB;gBAIvB,gBAAgB;sBADtB,WAAW;uBAAC,eAAe;gBAIrB,MAAM;sBADZ,KAAK;gBAIC,SAAS;sBADf,KAAK","sourcesContent":["import {ChangeDetectorRef, Directive, ElementRef, HostBinding, Input, OnChanges, SimpleChanges} from '@angular/core';\nimport {NumberUtils, StringUtils} from '@dontdrinkandroot/ngx-extensions';\n\n@Directive({selector: '[ddrGridTileLazyImg]'})\nexport class GridTileLazyImgDirective implements OnChanges\n{\n    @Input('ddrGridTileLazyImg')\n    public src!: string;\n\n    @HostBinding('src')\n    public hostSrc = 'assets/placeholder.gif';\n\n    @HostBinding('style.object-fit')\n    public hostStyleObjectFit = 'contain';\n\n    @HostBinding('style.width.px')\n    public hostStyleWidthPx!: number;\n\n    @HostBinding('style.height.px')\n    public hostStyleHeightPx!: number;\n\n    @HostBinding('style.opacity')\n    public hostStyleOpacity = 0;\n\n    @Input()\n    public offset = 1000;\n\n    @Input()\n    public objectFit = 'cover';\n\n    private displayed = false;\n\n    private maxLoadedDimension: { width: number, height: number } | null = null;\n\n    constructor(private element: ElementRef, private cd: ChangeDetectorRef)\n    {\n    }\n\n    public recheck()\n    {\n        this.displayed = false;\n        this.check();\n    }\n\n    public check()\n    {\n        if (\n            this.displayed\n            || this.isHidden(this.element.nativeElement)\n            || !this.isInsideViewport(this.element.nativeElement, this.offset)\n        ) {\n            return;\n        }\n\n        this.displayed = true;\n        const dimension = this.getDimension();\n\n        if (\n            null != this.maxLoadedDimension\n            && this.maxLoadedDimension.width >= dimension.width\n            && this.maxLoadedDimension.height >= dimension.height\n        ) {\n            return;\n        }\n\n        this.maxLoadedDimension = dimension;\n        this.hostStyleWidthPx = dimension.width;\n        this.hostStyleHeightPx = dimension.height;\n        let wantedSize: number;\n        if (this.objectFit === 'cover') {\n            wantedSize = NumberUtils.getNextPowerOfTwo(Math.max(dimension.width, dimension.height));\n            this.hostStyleObjectFit = 'cover';\n        } else {\n            wantedSize = NumberUtils.getNextPowerOfTwo(Math.min(dimension.width, dimension.height));\n            this.hostStyleObjectFit = 'contain';\n        }\n        this.hostSrc = StringUtils.updateUrlParameter(this.src, 'size', String(wantedSize));\n        this.hostStyleOpacity = 1;\n        this.cd.detectChanges();\n    }\n\n    /**\n     * @override\n     */\n    public ngOnChanges(changes: SimpleChanges): void\n    {\n        this.displayed = false;\n        this.maxLoadedDimension = null;\n        this.hostStyleOpacity = 0;\n        if (this.element.nativeElement.parentElement.offsetWidth > 0) {\n            this.check();\n        }\n    }\n\n    private isInsideViewport(nativeElement: HTMLElement, offset: number): boolean\n    {\n        // console.log('isInsideViewport');\n        const ownerDocument = nativeElement.ownerDocument;\n        const documentTop = window.pageYOffset || ownerDocument.body.scrollTop;\n        const documentLeft = window.pageXOffset || ownerDocument.body.scrollLeft;\n\n        const documentWidth = window.innerWidth || (ownerDocument.documentElement.clientWidth || document.body.clientWidth);\n        const documentHeight = window.innerHeight || (ownerDocument.documentElement.clientHeight || document.body.clientHeight);\n        const topOffset = nativeElement.getBoundingClientRect().top + documentTop - ownerDocument.documentElement.clientTop;\n        const leftOffset = nativeElement.getBoundingClientRect().left + documentLeft - ownerDocument.documentElement.clientLeft;\n\n        // console.log(documentWidth, documentHeight, topOffset, leftOffset);\n\n        const isBelowViewport = documentHeight + documentTop <= topOffset - offset;\n        const isAtRightOfViewport = documentWidth + window.pageXOffset <= leftOffset - offset;\n        const isAboveViewport = documentTop >= topOffset + offset + nativeElement.offsetHeight;\n        const isAtLeftOfViewport = documentLeft >= leftOffset + offset + nativeElement.offsetWidth;\n\n        return !isBelowViewport && !isAboveViewport && !isAtRightOfViewport && !isAtLeftOfViewport;\n    }\n\n    private getDimension(): { width: number, height: number }\n    {\n        return {\n            width: this.element.nativeElement.parentElement.offsetWidth,\n            height: this.element.nativeElement.parentElement.offsetHeight,\n        };\n    }\n\n    private isHidden(nativeElement: HTMLElement)\n    {\n        // console.log('isHidden');\n        return window.getComputedStyle(nativeElement).display === 'none';\n    }\n}\n"]}
@@ -1,43 +0,0 @@
1
- import { Component, Input, ViewChild } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "./sidenav.service";
4
- import * as i2 from "@angular/common";
5
- import * as i3 from "@angular/material/sidenav";
6
- export class SidenavContainerComponent {
7
- constructor(sidenavService) {
8
- this.sidenavService = sidenavService;
9
- this.stayOpenOnLargeScreen = true;
10
- this.mode$ = this.sidenavService.getModeObservable();
11
- this.opened$ = this.sidenavService.getOpenedObservable();
12
- }
13
- /**
14
- * @override
15
- */
16
- ngOnChanges(changes) {
17
- this.sidenavService.setStayOpenOnLargeScreen(changes['stayOpenOnLargeScreen'].currentValue);
18
- }
19
- /**
20
- * @override
21
- */
22
- ngOnInit() {
23
- this.sidenavService.setSidenav(this.sidenav);
24
- }
25
- /**
26
- * @override
27
- */
28
- ngOnDestroy() {
29
- this.scrollSubscription.unsubscribe();
30
- }
31
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: SidenavContainerComponent, deps: [{ token: i1.SidenavService }], target: i0.ɵɵFactoryTarget.Component }); }
32
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: SidenavContainerComponent, selector: "ddr-mat-sidenav-container", inputs: { stayOpenOnLargeScreen: "stayOpenOnLargeScreen" }, viewQueries: [{ propertyName: "sidenav", first: true, predicate: ["sidenav"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<mat-sidenav-container [ngClass]=\"(mode$|async)\">\n <mat-sidenav\n #sidenav\n [mode]=\"(mode$|async) ?? 'over'\"\n [opened]=\"(opened$|async)\"\n [fixedInViewport]=\"true\"\n >\n <ng-content select=\"[slot=mat-sidenav]\"></ng-content>\n </mat-sidenav>\n <mat-sidenav-content #sidenavContent>\n <ng-content select=\"[slot=mat-sidenav-content]\"></ng-content>\n </mat-sidenav-content>\n</mat-sidenav-container>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i3.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i3.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i3.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] }); }
33
- }
34
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: SidenavContainerComponent, decorators: [{
35
- type: Component,
36
- args: [{ selector: 'ddr-mat-sidenav-container', template: "<mat-sidenav-container [ngClass]=\"(mode$|async)\">\n <mat-sidenav\n #sidenav\n [mode]=\"(mode$|async) ?? 'over'\"\n [opened]=\"(opened$|async)\"\n [fixedInViewport]=\"true\"\n >\n <ng-content select=\"[slot=mat-sidenav]\"></ng-content>\n </mat-sidenav>\n <mat-sidenav-content #sidenavContent>\n <ng-content select=\"[slot=mat-sidenav-content]\"></ng-content>\n </mat-sidenav-content>\n</mat-sidenav-container>\n" }]
37
- }], ctorParameters: () => [{ type: i1.SidenavService }], propDecorators: { sidenav: [{
38
- type: ViewChild,
39
- args: ['sidenav', { static: true }]
40
- }], stayOpenOnLargeScreen: [{
41
- type: Input
42
- }] } });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi1jb250YWluZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3NpZGVuYXYvc2lkZW5hdi1jb250YWluZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vc3JjL3NpZGVuYXYvc2lkZW5hdi1jb250YWluZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxLQUFLLEVBQStDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFTdkcsTUFBTSxPQUFPLHlCQUF5QjtJQWNsQyxZQUNZLGNBQThCO1FBQTlCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQVRuQywwQkFBcUIsR0FBRyxJQUFJLENBQUM7UUFFN0IsVUFBSyxHQUE4QixJQUFJLENBQUMsY0FBYyxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFFM0UsWUFBTyxHQUF3QixJQUFJLENBQUMsY0FBYyxDQUFDLG1CQUFtQixFQUFFLENBQUM7SUFRaEYsQ0FBQztJQUVEOztPQUVHO0lBQ0ksV0FBVyxDQUFDLE9BQXNCO1FBRXJDLElBQUksQ0FBQyxjQUFjLENBQUMsd0JBQXdCLENBQUMsT0FBTyxDQUFDLHVCQUF1QixDQUFDLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDaEcsQ0FBQztJQUVEOztPQUVHO0lBQ0ksUUFBUTtRQUVYLElBQUksQ0FBQyxjQUFjLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNqRCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxXQUFXO1FBRWQsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQzFDLENBQUM7OEdBMUNRLHlCQUF5QjtrR0FBekIseUJBQXlCLG9RQ1R0Qyx1ZEFhQTs7MkZESmEseUJBQXlCO2tCQUpyQyxTQUFTOytCQUNJLDJCQUEyQjttRkFNOUIsT0FBTztzQkFEYixTQUFTO3VCQUFDLFNBQVMsRUFBRSxFQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUM7Z0JBSTdCLHFCQUFxQjtzQkFEM0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3ksIE9uSW5pdCwgU2ltcGxlQ2hhbmdlcywgVmlld0NoaWxkfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TWF0RHJhd2VyTW9kZSwgTWF0U2lkZW5hdn0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2lkZW5hdic7XG5pbXBvcnQge1NpZGVuYXZTZXJ2aWNlfSBmcm9tICcuL3NpZGVuYXYuc2VydmljZSc7XG5pbXBvcnQge09ic2VydmFibGUsIFN1YnNjcmlwdGlvbn0gZnJvbSAncnhqcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZGRyLW1hdC1zaWRlbmF2LWNvbnRhaW5lcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3NpZGVuYXYtY29udGFpbmVyLmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBTaWRlbmF2Q29udGFpbmVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMsIE9uRGVzdHJveVxue1xuICAgIEBWaWV3Q2hpbGQoJ3NpZGVuYXYnLCB7c3RhdGljOiB0cnVlfSlcbiAgICBwdWJsaWMgc2lkZW5hdiE6IE1hdFNpZGVuYXY7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBzdGF5T3Blbk9uTGFyZ2VTY3JlZW4gPSB0cnVlO1xuXG4gICAgcHVibGljIG1vZGUkOiBPYnNlcnZhYmxlPE1hdERyYXdlck1vZGU+ID0gdGhpcy5zaWRlbmF2U2VydmljZS5nZXRNb2RlT2JzZXJ2YWJsZSgpO1xuXG4gICAgcHVibGljIG9wZW5lZCQ6IE9ic2VydmFibGU8Ym9vbGVhbj4gPSB0aGlzLnNpZGVuYXZTZXJ2aWNlLmdldE9wZW5lZE9ic2VydmFibGUoKTtcblxuICAgIHByaXZhdGUgc2Nyb2xsU3Vic2NyaXB0aW9uITogU3Vic2NyaXB0aW9uO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgc2lkZW5hdlNlcnZpY2U6IFNpZGVuYXZTZXJ2aWNlLFxuICAgIClcbiAgICB7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQG92ZXJyaWRlXG4gICAgICovXG4gICAgcHVibGljIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkXG4gICAge1xuICAgICAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLnNldFN0YXlPcGVuT25MYXJnZVNjcmVlbihjaGFuZ2VzWydzdGF5T3Blbk9uTGFyZ2VTY3JlZW4nXS5jdXJyZW50VmFsdWUpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEBvdmVycmlkZVxuICAgICAqL1xuICAgIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkXG4gICAge1xuICAgICAgICB0aGlzLnNpZGVuYXZTZXJ2aWNlLnNldFNpZGVuYXYodGhpcy5zaWRlbmF2KTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBAb3ZlcnJpZGVcbiAgICAgKi9cbiAgICBwdWJsaWMgbmdPbkRlc3Ryb3koKVxuICAgIHtcbiAgICAgICAgdGhpcy5zY3JvbGxTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcbiAgICB9XG59XG4iLCI8bWF0LXNpZGVuYXYtY29udGFpbmVyIFtuZ0NsYXNzXT1cIihtb2RlJHxhc3luYylcIj5cbiAgICA8bWF0LXNpZGVuYXZcbiAgICAgICAgI3NpZGVuYXZcbiAgICAgICAgW21vZGVdPVwiKG1vZGUkfGFzeW5jKSA/PyAnb3ZlcidcIlxuICAgICAgICBbb3BlbmVkXT1cIihvcGVuZWQkfGFzeW5jKVwiXG4gICAgICAgIFtmaXhlZEluVmlld3BvcnRdPVwidHJ1ZVwiXG4gICAgPlxuICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbc2xvdD1tYXQtc2lkZW5hdl1cIj48L25nLWNvbnRlbnQ+XG4gICAgPC9tYXQtc2lkZW5hdj5cbiAgICA8bWF0LXNpZGVuYXYtY29udGVudCAjc2lkZW5hdkNvbnRlbnQ+XG4gICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIltzbG90PW1hdC1zaWRlbmF2LWNvbnRlbnRdXCI+PC9uZy1jb250ZW50PlxuICAgIDwvbWF0LXNpZGVuYXYtY29udGVudD5cbjwvbWF0LXNpZGVuYXYtY29udGFpbmVyPlxuIl19
@@ -1,34 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import { toSignal } from '@angular/core/rxjs-interop';
3
- import * as i0 from "@angular/core";
4
- import * as i1 from "./sidenav.service";
5
- import * as i2 from "@angular/material/icon";
6
- import * as i3 from "@angular/material/button";
7
- export class SidenavToggleComponent {
8
- constructor(sidenavService) {
9
- this.sidenavService = sidenavService;
10
- this.visible = toSignal(this.sidenavService.watchToggleVisible(), { initialValue: false });
11
- }
12
- toggleSidenav() {
13
- this.sidenavService.toggle();
14
- }
15
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: SidenavToggleComponent, deps: [{ token: i1.SidenavService }], target: i0.ɵɵFactoryTarget.Component }); }
16
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.1", type: SidenavToggleComponent, selector: "ddr-mat-sidenav-toggle", host: { properties: { "style.display": "visible() ? \"block\" : \"none\"" } }, ngImport: i0, template: `
17
- <button mat-icon-button (click)="toggleSidenav()">
18
- <mat-icon>menu</mat-icon>
19
- </button>`, isInline: true, dependencies: [{ kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }] }); }
20
- }
21
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: SidenavToggleComponent, decorators: [{
22
- type: Component,
23
- args: [{
24
- selector: 'ddr-mat-sidenav-toggle',
25
- template: `
26
- <button mat-icon-button (click)="toggleSidenav()">
27
- <mat-icon>menu</mat-icon>
28
- </button>`,
29
- host: {
30
- '[style.display]': 'visible() ? "block" : "none"'
31
- }
32
- }]
33
- }], ctorParameters: () => [{ type: i1.SidenavService }] });
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi10b2dnbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3NpZGVuYXYvc2lkZW5hdi10b2dnbGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFeEMsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLDRCQUE0QixDQUFDOzs7OztBQVlwRCxNQUFNLE9BQU8sc0JBQXNCO0lBSS9CLFlBQW9CLGNBQThCO1FBQTlCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUYzQyxZQUFPLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsa0JBQWtCLEVBQUUsRUFBRSxFQUFDLFlBQVksRUFBRSxLQUFLLEVBQUMsQ0FBQyxDQUFDO0lBSTNGLENBQUM7SUFFTSxhQUFhO1FBRWhCLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDakMsQ0FBQzs4R0FYUSxzQkFBc0I7a0dBQXRCLHNCQUFzQiw2SUFSckI7OztrQkFHSTs7MkZBS0wsc0JBQXNCO2tCQVZsQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx3QkFBd0I7b0JBQ2xDLFFBQVEsRUFBRTs7O2tCQUdJO29CQUNkLElBQUksRUFBRTt3QkFDRixpQkFBaUIsRUFBRSw4QkFBOEI7cUJBQ3BEO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtTaWRlbmF2U2VydmljZX0gZnJvbSAnLi9zaWRlbmF2LnNlcnZpY2UnO1xuaW1wb3J0IHt0b1NpZ25hbH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2Rkci1tYXQtc2lkZW5hdi10b2dnbGUnLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uIChjbGljayk9XCJ0b2dnbGVTaWRlbmF2KClcIj5cbiAgICAgICAgICAgIDxtYXQtaWNvbj5tZW51PC9tYXQtaWNvbj5cbiAgICAgICAgPC9idXR0b24+YCxcbiAgICBob3N0OiB7XG4gICAgICAgICdbc3R5bGUuZGlzcGxheV0nOiAndmlzaWJsZSgpID8gXCJibG9ja1wiIDogXCJub25lXCInXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBTaWRlbmF2VG9nZ2xlQ29tcG9uZW50XG57XG4gICAgcHVibGljIHZpc2libGUgPSB0b1NpZ25hbCh0aGlzLnNpZGVuYXZTZXJ2aWNlLndhdGNoVG9nZ2xlVmlzaWJsZSgpLCB7aW5pdGlhbFZhbHVlOiBmYWxzZX0pO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBzaWRlbmF2U2VydmljZTogU2lkZW5hdlNlcnZpY2UpXG4gICAge1xuICAgIH1cblxuICAgIHB1YmxpYyB0b2dnbGVTaWRlbmF2KClcbiAgICB7XG4gICAgICAgIHRoaXMuc2lkZW5hdlNlcnZpY2UudG9nZ2xlKCk7XG4gICAgfVxufVxuIl19
@@ -1,78 +0,0 @@
1
- import { Inject, Injectable } from '@angular/core';
2
- import { Breakpoints } from '@angular/cdk/layout';
3
- import { BehaviorSubject } from 'rxjs';
4
- import { map } from 'rxjs/operators';
5
- import { NavigationStart } from '@angular/router';
6
- import { DOCUMENT } from '@angular/common';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/cdk/layout";
9
- import * as i2 from "@angular/router";
10
- export class SidenavService {
11
- constructor(breakpointObserver, router, document) {
12
- this.breakpointObserver = breakpointObserver;
13
- this.router = router;
14
- this.document = document;
15
- this.stayOpenOnLargeScreen = true;
16
- this.largeBreakpoints = [
17
- Breakpoints.Medium,
18
- Breakpoints.Large,
19
- Breakpoints.XLarge
20
- ];
21
- this.sidenavContentScrolled$ = new BehaviorSubject(false);
22
- this.screenLarge$ = this.breakpointObserver.observe(this.largeBreakpoints).pipe(map(result => result.matches));
23
- this.mode$ = this.screenLarge$.pipe(map(large => large && this.stayOpenOnLargeScreen ? 'side' : 'over'));
24
- this.opened$ = this.screenLarge$.pipe(map(large => large && this.stayOpenOnLargeScreen));
25
- this.router.events.subscribe(event => {
26
- if (event instanceof NavigationStart) {
27
- this.closeSidebar();
28
- }
29
- });
30
- }
31
- setSidenav(sidenav) {
32
- this.sidenav = sidenav;
33
- }
34
- getStayOpenOnLargeScreen() {
35
- return this.stayOpenOnLargeScreen;
36
- }
37
- setStayOpenOnLargeScreen(value) {
38
- this.stayOpenOnLargeScreen = value;
39
- }
40
- toggle() {
41
- if (null == this.sidenav) {
42
- return Promise.reject('No MatSidenav found. Use setSidenav() of SidenavService');
43
- }
44
- if (!(this.stayOpenOnLargeScreen && this.breakpointObserver.isMatched(this.largeBreakpoints))) {
45
- return this.sidenav.toggle();
46
- }
47
- return Promise.resolve(this.sidenav.opened ? 'open' : 'close');
48
- }
49
- closeSidebar() {
50
- if (!(this.stayOpenOnLargeScreen && this.breakpointObserver.isMatched(this.largeBreakpoints))) {
51
- this.sidenav.close();
52
- }
53
- }
54
- getModeObservable() {
55
- return this.mode$;
56
- }
57
- getOpenedObservable() {
58
- return this.opened$;
59
- }
60
- watchToggleVisible() {
61
- return this.screenLarge$.pipe(map(large => !large || !this.stayOpenOnLargeScreen));
62
- }
63
- watchContentScrolled() {
64
- return this.sidenavContentScrolled$.asObservable();
65
- }
66
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: SidenavService, deps: [{ token: i1.BreakpointObserver }, { token: i2.Router }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
67
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: SidenavService, providedIn: 'root' }); }
68
- }
69
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: SidenavService, decorators: [{
70
- type: Injectable,
71
- args: [{
72
- providedIn: 'root'
73
- }]
74
- }], ctorParameters: () => [{ type: i1.BreakpointObserver }, { type: i2.Router }, { type: Document, decorators: [{
75
- type: Inject,
76
- args: [DOCUMENT]
77
- }] }] });
78
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZW5hdi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3NpZGVuYXYvc2lkZW5hdi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxNQUFNLEVBQUUsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRWpELE9BQU8sRUFBcUIsV0FBVyxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDcEUsT0FBTyxFQUFDLGVBQWUsRUFBYSxNQUFNLE1BQU0sQ0FBQztBQUNqRCxPQUFPLEVBQUMsR0FBRyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDbkMsT0FBTyxFQUFDLGVBQWUsRUFBUyxNQUFNLGlCQUFpQixDQUFDO0FBQ3hELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQzs7OztBQUt6QyxNQUFNLE9BQU8sY0FBYztJQW1CdkIsWUFDWSxrQkFBc0MsRUFDdEMsTUFBYyxFQUNJLFFBQWtCO1FBRnBDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBb0I7UUFDdEMsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNJLGFBQVEsR0FBUixRQUFRLENBQVU7UUFuQnhDLDBCQUFxQixHQUFHLElBQUksQ0FBQztRQUU3QixxQkFBZ0IsR0FBRztZQUN2QixXQUFXLENBQUMsTUFBTTtZQUNsQixXQUFXLENBQUMsS0FBSztZQUNqQixXQUFXLENBQUMsTUFBTTtTQUNyQixDQUFDO1FBUU0sNEJBQXVCLEdBQUcsSUFBSSxlQUFlLENBQVUsS0FBSyxDQUFDLENBQUM7UUFPbEUsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLElBQUksQ0FDM0UsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUNoQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FDL0IsR0FBRyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FDdEUsQ0FBQztRQUNGLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQ2pDLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMscUJBQXFCLENBQUMsQ0FDcEQsQ0FBQztRQUNGLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNqQyxJQUFJLEtBQUssWUFBWSxlQUFlLEVBQUUsQ0FBQztnQkFDbkMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3hCLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFTSxVQUFVLENBQUMsT0FBbUI7UUFDakMsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDM0IsQ0FBQztJQUdNLHdCQUF3QjtRQUMzQixPQUFPLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztJQUN0QyxDQUFDO0lBRU0sd0JBQXdCLENBQUMsS0FBYztRQUMxQyxJQUFJLENBQUMscUJBQXFCLEdBQUcsS0FBSyxDQUFDO0lBQ3ZDLENBQUM7SUFFTSxNQUFNO1FBQ1QsSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ3ZCLE9BQU8sT0FBTyxDQUFDLE1BQU0sQ0FBQyx5REFBeUQsQ0FBQyxDQUFDO1FBQ3JGLENBQUM7UUFFRCxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMscUJBQXFCLElBQUksSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDNUYsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ2pDLENBQUM7UUFFRCxPQUFPLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDbkUsQ0FBQztJQUVNLFlBQVk7UUFDZixJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMscUJBQXFCLElBQUksSUFBSSxDQUFDLGtCQUFrQixDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxFQUFFLENBQUM7WUFDNUYsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUN6QixDQUFDO0lBQ0wsQ0FBQztJQUVNLGlCQUFpQjtRQUNwQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDdEIsQ0FBQztJQUVNLG1CQUFtQjtRQUN0QixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDeEIsQ0FBQztJQUVNLGtCQUFrQjtRQUNyQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUN6QixHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxDQUN0RCxDQUFDO0lBQ04sQ0FBQztJQUVNLG9CQUFvQjtRQUN2QixPQUFPLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN2RCxDQUFDOzhHQXZGUSxjQUFjLDBFQXNCWCxRQUFRO2tIQXRCWCxjQUFjLGNBRlgsTUFBTTs7MkZBRVQsY0FBYztrQkFIMUIsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckI7OzBCQXVCUSxNQUFNOzJCQUFDLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdCwgSW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge01hdERyYXdlck1vZGUsIE1hdERyYXdlclRvZ2dsZVJlc3VsdCwgTWF0U2lkZW5hdn0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2lkZW5hdic7XG5pbXBvcnQge0JyZWFrcG9pbnRPYnNlcnZlciwgQnJlYWtwb2ludHN9IGZyb20gJ0Bhbmd1bGFyL2Nkay9sYXlvdXQnO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHttYXB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbmltcG9ydCB7TmF2aWdhdGlvblN0YXJ0LCBSb3V0ZXJ9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge0RPQ1VNRU5UfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5ASW5qZWN0YWJsZSh7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIFNpZGVuYXZTZXJ2aWNlIHtcbiAgICBwcml2YXRlIHNpZGVuYXYhOiBNYXRTaWRlbmF2O1xuXG4gICAgcHJpdmF0ZSBzdGF5T3Blbk9uTGFyZ2VTY3JlZW4gPSB0cnVlO1xuXG4gICAgcHJpdmF0ZSBsYXJnZUJyZWFrcG9pbnRzID0gW1xuICAgICAgICBCcmVha3BvaW50cy5NZWRpdW0sXG4gICAgICAgIEJyZWFrcG9pbnRzLkxhcmdlLFxuICAgICAgICBCcmVha3BvaW50cy5YTGFyZ2VcbiAgICBdO1xuXG4gICAgcHJpdmF0ZSBzY3JlZW5MYXJnZSQ6IE9ic2VydmFibGU8Ym9vbGVhbj47XG5cbiAgICBwcml2YXRlIG1vZGUkOiBPYnNlcnZhYmxlPE1hdERyYXdlck1vZGU+O1xuXG4gICAgcHJpdmF0ZSBvcGVuZWQkOiBPYnNlcnZhYmxlPGJvb2xlYW4+O1xuXG4gICAgcHJpdmF0ZSBzaWRlbmF2Q29udGVudFNjcm9sbGVkJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgYnJlYWtwb2ludE9ic2VydmVyOiBCcmVha3BvaW50T2JzZXJ2ZXIsXG4gICAgICAgIHByaXZhdGUgcm91dGVyOiBSb3V0ZXIsXG4gICAgICAgIEBJbmplY3QoRE9DVU1FTlQpIHByaXZhdGUgZG9jdW1lbnQ6IERvY3VtZW50LFxuICAgICkge1xuICAgICAgICB0aGlzLnNjcmVlbkxhcmdlJCA9IHRoaXMuYnJlYWtwb2ludE9ic2VydmVyLm9ic2VydmUodGhpcy5sYXJnZUJyZWFrcG9pbnRzKS5waXBlKFxuICAgICAgICAgICAgbWFwKHJlc3VsdCA9PiByZXN1bHQubWF0Y2hlcylcbiAgICAgICAgKTtcbiAgICAgICAgdGhpcy5tb2RlJCA9IHRoaXMuc2NyZWVuTGFyZ2UkLnBpcGUoXG4gICAgICAgICAgICBtYXAobGFyZ2UgPT4gbGFyZ2UgJiYgdGhpcy5zdGF5T3Blbk9uTGFyZ2VTY3JlZW4gPyAnc2lkZScgOiAnb3ZlcicpXG4gICAgICAgICk7XG4gICAgICAgIHRoaXMub3BlbmVkJCA9IHRoaXMuc2NyZWVuTGFyZ2UkLnBpcGUoXG4gICAgICAgICAgICBtYXAobGFyZ2UgPT4gbGFyZ2UgJiYgdGhpcy5zdGF5T3Blbk9uTGFyZ2VTY3JlZW4pXG4gICAgICAgICk7XG4gICAgICAgIHRoaXMucm91dGVyLmV2ZW50cy5zdWJzY3JpYmUoZXZlbnQgPT4ge1xuICAgICAgICAgICAgaWYgKGV2ZW50IGluc3RhbmNlb2YgTmF2aWdhdGlvblN0YXJ0KSB7XG4gICAgICAgICAgICAgICAgdGhpcy5jbG9zZVNpZGViYXIoKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIHNldFNpZGVuYXYoc2lkZW5hdjogTWF0U2lkZW5hdik6IHZvaWQge1xuICAgICAgICB0aGlzLnNpZGVuYXYgPSBzaWRlbmF2O1xuICAgIH1cblxuXG4gICAgcHVibGljIGdldFN0YXlPcGVuT25MYXJnZVNjcmVlbigpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc3RheU9wZW5PbkxhcmdlU2NyZWVuO1xuICAgIH1cblxuICAgIHB1YmxpYyBzZXRTdGF5T3Blbk9uTGFyZ2VTY3JlZW4odmFsdWU6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5zdGF5T3Blbk9uTGFyZ2VTY3JlZW4gPSB2YWx1ZTtcbiAgICB9XG5cbiAgICBwdWJsaWMgdG9nZ2xlKCk6IFByb21pc2U8TWF0RHJhd2VyVG9nZ2xlUmVzdWx0PiB7XG4gICAgICAgIGlmIChudWxsID09IHRoaXMuc2lkZW5hdikge1xuICAgICAgICAgICAgcmV0dXJuIFByb21pc2UucmVqZWN0KCdObyBNYXRTaWRlbmF2IGZvdW5kLiBVc2Ugc2V0U2lkZW5hdigpIG9mIFNpZGVuYXZTZXJ2aWNlJyk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoISh0aGlzLnN0YXlPcGVuT25MYXJnZVNjcmVlbiAmJiB0aGlzLmJyZWFrcG9pbnRPYnNlcnZlci5pc01hdGNoZWQodGhpcy5sYXJnZUJyZWFrcG9pbnRzKSkpIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLnNpZGVuYXYudG9nZ2xlKCk7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKHRoaXMuc2lkZW5hdi5vcGVuZWQgPyAnb3BlbicgOiAnY2xvc2UnKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xvc2VTaWRlYmFyKCk6IHZvaWQge1xuICAgICAgICBpZiAoISh0aGlzLnN0YXlPcGVuT25MYXJnZVNjcmVlbiAmJiB0aGlzLmJyZWFrcG9pbnRPYnNlcnZlci5pc01hdGNoZWQodGhpcy5sYXJnZUJyZWFrcG9pbnRzKSkpIHtcbiAgICAgICAgICAgIHRoaXMuc2lkZW5hdi5jbG9zZSgpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGdldE1vZGVPYnNlcnZhYmxlKCk6IE9ic2VydmFibGU8TWF0RHJhd2VyTW9kZT4ge1xuICAgICAgICByZXR1cm4gdGhpcy5tb2RlJDtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0T3BlbmVkT2JzZXJ2YWJsZSgpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMub3BlbmVkJDtcbiAgICB9XG5cbiAgICBwdWJsaWMgd2F0Y2hUb2dnbGVWaXNpYmxlKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5zY3JlZW5MYXJnZSQucGlwZShcbiAgICAgICAgICAgIG1hcChsYXJnZSA9PiAhbGFyZ2UgfHwgIXRoaXMuc3RheU9wZW5PbkxhcmdlU2NyZWVuKVxuICAgICAgICApO1xuICAgIH1cblxuICAgIHB1YmxpYyB3YXRjaENvbnRlbnRTY3JvbGxlZCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc2lkZW5hdkNvbnRlbnRTY3JvbGxlZCQuYXNPYnNlcnZhYmxlKCk7XG4gICAgfVxufVxuIl19
@@ -1,3 +0,0 @@
1
- import { InjectionToken } from "@angular/core";
2
- export const DDR_MATERIAL_EXTENSIONS_THEME = new InjectionToken('DDR_MATERIAL_EXTENSIONS_THEME');
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUtY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3RoZW1lL3RoZW1lLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTdDLE1BQU0sQ0FBQyxNQUFNLDZCQUE2QixHQUFHLElBQUksY0FBYyxDQUFjLCtCQUErQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGlvblRva2VufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5leHBvcnQgY29uc3QgRERSX01BVEVSSUFMX0VYVEVOU0lPTlNfVEhFTUUgPSBuZXcgSW5qZWN0aW9uVG9rZW48VGhlbWVDb25maWc+KCdERFJfTUFURVJJQUxfRVhURU5TSU9OU19USEVNRScpO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRoZW1lQ29uZmlnIHtcbiAgICB0aGVtZUNvbG9yTGlnaHQ6IHN0cmluZyxcbiAgICB0aGVtZUNvbG9yRGFyazogc3RyaW5nLFxuICAgIHRoZW1lQ29sb3JMaWdodFNjcm9sbGVkOiBzdHJpbmcsXG4gICAgdGhlbWVDb2xvckRhcmtTY3JvbGxlZDogc3RyaW5nLFxufVxuIl19
@@ -1,49 +0,0 @@
1
- import { Inject, Injectable } from "@angular/core";
2
- import { DOCUMENT } from "@angular/common";
3
- import { distinctUntilChanged, fromEvent } from "rxjs";
4
- import { map } from "rxjs/operators";
5
- import { DDR_MATERIAL_EXTENSIONS_THEME } from "./theme-config";
6
- import * as i0 from "@angular/core";
7
- export class ThemeScrollService {
8
- constructor(document, themeConfig) {
9
- this.document = document;
10
- this.themeConfig = themeConfig;
11
- }
12
- init() {
13
- const lightMetaElement = this.findOrCreateThemeColorMetaElement('(prefers-color-scheme: light)', this.themeConfig.themeColorLight);
14
- const darkMetaElement = this.findOrCreateThemeColorMetaElement('(prefers-color-scheme: dark)', this.themeConfig.themeColorDark);
15
- fromEvent(this.document, 'scroll')
16
- .pipe(map(() => this.document.documentElement.scrollTop > 0), distinctUntilChanged()).subscribe((scrolled) => {
17
- scrolled ? this.document.body.classList.add('ddr-mat-scrolled') : this.document.body.classList.remove('ddr-mat-scrolled');
18
- lightMetaElement.content = scrolled ? this.themeConfig.themeColorLightScrolled : this.themeConfig.themeColorLight;
19
- darkMetaElement.content = scrolled ? this.themeConfig.themeColorDarkScrolled : this.themeConfig.themeColorDark;
20
- });
21
- }
22
- findOrCreateThemeColorMetaElement(media, content) {
23
- let metaElement = this.document.head.querySelector(`meta[name="theme-color"][media="${media}"]`);
24
- if (null == metaElement) {
25
- metaElement = this.createThemeColorMetaElement(media, content);
26
- }
27
- return metaElement;
28
- }
29
- createThemeColorMetaElement(media, content) {
30
- const metaElement = this.document.createElement('meta');
31
- metaElement.name = 'theme-color';
32
- metaElement.media = media;
33
- metaElement.content = content;
34
- this.document.head.appendChild(metaElement);
35
- return metaElement;
36
- }
37
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ThemeScrollService, deps: [{ token: DOCUMENT }, { token: DDR_MATERIAL_EXTENSIONS_THEME }], target: i0.ɵɵFactoryTarget.Injectable }); }
38
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ThemeScrollService }); }
39
- }
40
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ThemeScrollService, decorators: [{
41
- type: Injectable
42
- }], ctorParameters: () => [{ type: Document, decorators: [{
43
- type: Inject,
44
- args: [DOCUMENT]
45
- }] }, { type: undefined, decorators: [{
46
- type: Inject,
47
- args: [DDR_MATERIAL_EXTENSIONS_THEME]
48
- }] }] });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUtc2Nyb2xsLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdGhlbWUvdGhlbWUtc2Nyb2xsLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQ3pDLE9BQU8sRUFBQyxvQkFBb0IsRUFBRSxTQUFTLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFDckQsT0FBTyxFQUFDLEdBQUcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQ25DLE9BQU8sRUFBQyw2QkFBNkIsRUFBYyxNQUFNLGdCQUFnQixDQUFDOztBQUcxRSxNQUFNLE9BQU8sa0JBQWtCO0lBQzNCLFlBQ3VDLFFBQWtCLEVBQ0csV0FBd0I7UUFEN0MsYUFBUSxHQUFSLFFBQVEsQ0FBVTtRQUNHLGdCQUFXLEdBQVgsV0FBVyxDQUFhO0lBRXBGLENBQUM7SUFFTSxJQUFJO1FBQ1AsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLENBQUMsaUNBQWlDLENBQUMsK0JBQStCLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUNuSSxNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsaUNBQWlDLENBQUMsOEJBQThCLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUVoSSxTQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxRQUFRLENBQUM7YUFDN0IsSUFBSSxDQUNELEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxTQUFTLEdBQUcsQ0FBQyxDQUFDLEVBQ3RELG9CQUFvQixFQUFFLENBQ3pCLENBQUMsU0FBUyxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUU7WUFDekIsUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQztZQUUxSCxnQkFBZ0IsQ0FBQyxPQUFPLEdBQUcsUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLHVCQUF1QixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQztZQUNsSCxlQUFlLENBQUMsT0FBTyxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxjQUFjLENBQUM7UUFDbkgsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU8saUNBQWlDLENBQUMsS0FBYSxFQUFFLE9BQWU7UUFDcEUsSUFBSSxXQUFXLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFrQixtQ0FBbUMsS0FBSyxJQUFJLENBQUMsQ0FBQztRQUNsSCxJQUFJLElBQUksSUFBSSxXQUFXLEVBQUUsQ0FBQztZQUN0QixXQUFXLEdBQUcsSUFBSSxDQUFDLDJCQUEyQixDQUFDLEtBQUssRUFBRSxPQUFPLENBQUMsQ0FBQztRQUNuRSxDQUFDO1FBQ0QsT0FBTyxXQUFXLENBQUM7SUFDdkIsQ0FBQztJQUVPLDJCQUEyQixDQUFDLEtBQWEsRUFBRSxPQUFlO1FBQzlELE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ3hELFdBQVcsQ0FBQyxJQUFJLEdBQUcsYUFBYSxDQUFDO1FBQ2pDLFdBQVcsQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQzFCLFdBQVcsQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQzlCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUU1QyxPQUFPLFdBQVcsQ0FBQztJQUN2QixDQUFDOzhHQXZDUSxrQkFBa0Isa0JBRWYsUUFBUSxhQUNSLDZCQUE2QjtrSEFIaEMsa0JBQWtCOzsyRkFBbEIsa0JBQWtCO2tCQUQ5QixVQUFVOzswQkFHRixNQUFNOzJCQUFDLFFBQVE7OzBCQUNmLE1BQU07MkJBQUMsNkJBQTZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJbmplY3QsIEluamVjdGFibGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQge0RPQ1VNRU5UfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQge2Rpc3RpbmN0VW50aWxDaGFuZ2VkLCBmcm9tRXZlbnR9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQge21hcH0gZnJvbSBcInJ4anMvb3BlcmF0b3JzXCI7XG5pbXBvcnQge0REUl9NQVRFUklBTF9FWFRFTlNJT05TX1RIRU1FLCBUaGVtZUNvbmZpZ30gZnJvbSBcIi4vdGhlbWUtY29uZmlnXCI7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBUaGVtZVNjcm9sbFNlcnZpY2Uge1xuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KERPQ1VNRU5UKSBwcml2YXRlIHJlYWRvbmx5IGRvY3VtZW50OiBEb2N1bWVudCxcbiAgICAgICAgQEluamVjdChERFJfTUFURVJJQUxfRVhURU5TSU9OU19USEVNRSkgcHJpdmF0ZSByZWFkb25seSB0aGVtZUNvbmZpZzogVGhlbWVDb25maWdcbiAgICApIHtcbiAgICB9XG5cbiAgICBwdWJsaWMgaW5pdCgpIHtcbiAgICAgICAgY29uc3QgbGlnaHRNZXRhRWxlbWVudCA9IHRoaXMuZmluZE9yQ3JlYXRlVGhlbWVDb2xvck1ldGFFbGVtZW50KCcocHJlZmVycy1jb2xvci1zY2hlbWU6IGxpZ2h0KScsIHRoaXMudGhlbWVDb25maWcudGhlbWVDb2xvckxpZ2h0KTtcbiAgICAgICAgY29uc3QgZGFya01ldGFFbGVtZW50ID0gdGhpcy5maW5kT3JDcmVhdGVUaGVtZUNvbG9yTWV0YUVsZW1lbnQoJyhwcmVmZXJzLWNvbG9yLXNjaGVtZTogZGFyayknLCB0aGlzLnRoZW1lQ29uZmlnLnRoZW1lQ29sb3JEYXJrKTtcblxuICAgICAgICBmcm9tRXZlbnQodGhpcy5kb2N1bWVudCwgJ3Njcm9sbCcpXG4gICAgICAgICAgICAucGlwZShcbiAgICAgICAgICAgICAgICBtYXAoKCkgPT4gdGhpcy5kb2N1bWVudC5kb2N1bWVudEVsZW1lbnQuc2Nyb2xsVG9wID4gMCksXG4gICAgICAgICAgICAgICAgZGlzdGluY3RVbnRpbENoYW5nZWQoKVxuICAgICAgICAgICAgKS5zdWJzY3JpYmUoKHNjcm9sbGVkKSA9PiB7XG4gICAgICAgICAgICBzY3JvbGxlZCA/IHRoaXMuZG9jdW1lbnQuYm9keS5jbGFzc0xpc3QuYWRkKCdkZHItbWF0LXNjcm9sbGVkJykgOiB0aGlzLmRvY3VtZW50LmJvZHkuY2xhc3NMaXN0LnJlbW92ZSgnZGRyLW1hdC1zY3JvbGxlZCcpO1xuXG4gICAgICAgICAgICBsaWdodE1ldGFFbGVtZW50LmNvbnRlbnQgPSBzY3JvbGxlZCA/IHRoaXMudGhlbWVDb25maWcudGhlbWVDb2xvckxpZ2h0U2Nyb2xsZWQgOiB0aGlzLnRoZW1lQ29uZmlnLnRoZW1lQ29sb3JMaWdodDtcbiAgICAgICAgICAgIGRhcmtNZXRhRWxlbWVudC5jb250ZW50ID0gc2Nyb2xsZWQgPyB0aGlzLnRoZW1lQ29uZmlnLnRoZW1lQ29sb3JEYXJrU2Nyb2xsZWQgOiB0aGlzLnRoZW1lQ29uZmlnLnRoZW1lQ29sb3JEYXJrO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGZpbmRPckNyZWF0ZVRoZW1lQ29sb3JNZXRhRWxlbWVudChtZWRpYTogc3RyaW5nLCBjb250ZW50OiBzdHJpbmcpIHtcbiAgICAgICAgbGV0IG1ldGFFbGVtZW50ID0gdGhpcy5kb2N1bWVudC5oZWFkLnF1ZXJ5U2VsZWN0b3I8SFRNTE1ldGFFbGVtZW50PihgbWV0YVtuYW1lPVwidGhlbWUtY29sb3JcIl1bbWVkaWE9XCIke21lZGlhfVwiXWApO1xuICAgICAgICBpZiAobnVsbCA9PSBtZXRhRWxlbWVudCkge1xuICAgICAgICAgICAgbWV0YUVsZW1lbnQgPSB0aGlzLmNyZWF0ZVRoZW1lQ29sb3JNZXRhRWxlbWVudChtZWRpYSwgY29udGVudCk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG1ldGFFbGVtZW50O1xuICAgIH1cblxuICAgIHByaXZhdGUgY3JlYXRlVGhlbWVDb2xvck1ldGFFbGVtZW50KG1lZGlhOiBzdHJpbmcsIGNvbnRlbnQ6IHN0cmluZykge1xuICAgICAgICBjb25zdCBtZXRhRWxlbWVudCA9IHRoaXMuZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnbWV0YScpO1xuICAgICAgICBtZXRhRWxlbWVudC5uYW1lID0gJ3RoZW1lLWNvbG9yJztcbiAgICAgICAgbWV0YUVsZW1lbnQubWVkaWEgPSBtZWRpYTtcbiAgICAgICAgbWV0YUVsZW1lbnQuY29udGVudCA9IGNvbnRlbnQ7XG4gICAgICAgIHRoaXMuZG9jdW1lbnQuaGVhZC5hcHBlbmRDaGlsZChtZXRhRWxlbWVudCk7XG5cbiAgICAgICAgcmV0dXJuIG1ldGFFbGVtZW50O1xuICAgIH1cbn1cbiJdfQ==
@@ -1,33 +0,0 @@
1
- import { Directive, Input } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class ToolbarFixedTopDirective {
4
- constructor(el) {
5
- this.el = el;
6
- this.ddrMatToolbarFixedTop = '';
7
- }
8
- /**
9
- * @override
10
- */
11
- ngOnInit() {
12
- const container = document.createElement('div');
13
- container.classList.add('ddr-mat-toolbar-fixed-top-container');
14
- this.el.nativeElement.parentElement.insertBefore(container, this.el.nativeElement);
15
- container.appendChild(this.el.nativeElement);
16
- if ('' !== this.ddrMatToolbarFixedTop) {
17
- this.ddrMatToolbarFixedTop.forEach((className) => {
18
- container.classList.add(className);
19
- });
20
- }
21
- }
22
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ToolbarFixedTopDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
23
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.1", type: ToolbarFixedTopDirective, selector: "[ddrMatToolbarFixedTop]", inputs: { ddrMatToolbarFixedTop: "ddrMatToolbarFixedTop" }, ngImport: i0 }); }
24
- }
25
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: ToolbarFixedTopDirective, decorators: [{
26
- type: Directive,
27
- args: [{
28
- selector: '[ddrMatToolbarFixedTop]'
29
- }]
30
- }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { ddrMatToolbarFixedTop: [{
31
- type: Input
32
- }] } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbGJhci1maXhlZC10b3AuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3Rvb2xiYXIvdG9vbGJhci1maXhlZC10b3AuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQWMsS0FBSyxFQUFTLE1BQU0sZUFBZSxDQUFDOztBQUtuRSxNQUFNLE9BQU8sd0JBQXdCO0lBTWpDLFlBQW9CLEVBQWM7UUFBZCxPQUFFLEdBQUYsRUFBRSxDQUFZO1FBRjNCLDBCQUFxQixHQUFrQixFQUFFLENBQUM7SUFJakQsQ0FBQztJQUVEOztPQUVHO0lBQ0ksUUFBUTtRQUVYLE1BQU0sU0FBUyxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDaEQsU0FBUyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMscUNBQXFDLENBQUMsQ0FBQztRQUMvRCxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ25GLFNBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUU3QyxJQUFJLEVBQUUsS0FBSyxJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FBQztZQUNwQyxJQUFJLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDLENBQUMsU0FBaUIsRUFBRSxFQUFFO2dCQUNyRCxTQUFTLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUN2QyxDQUFDLENBQUMsQ0FBQztRQUNQLENBQUM7SUFDTCxDQUFDOzhHQXpCUSx3QkFBd0I7a0dBQXhCLHdCQUF3Qjs7MkZBQXhCLHdCQUF3QjtrQkFIcEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUseUJBQXlCO2lCQUN0QzsrRUFLVSxxQkFBcUI7c0JBRDNCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0RpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5wdXQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2Rkck1hdFRvb2xiYXJGaXhlZFRvcF0nXG59KVxuZXhwb3J0IGNsYXNzIFRvb2xiYXJGaXhlZFRvcERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdFxue1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgZGRyTWF0VG9vbGJhckZpeGVkVG9wOiBzdHJpbmdbXSB8ICcnID0gJyc7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsOiBFbGVtZW50UmVmKVxuICAgIHtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBAb3ZlcnJpZGVcbiAgICAgKi9cbiAgICBwdWJsaWMgbmdPbkluaXQoKVxuICAgIHtcbiAgICAgICAgY29uc3QgY29udGFpbmVyID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnZGl2Jyk7XG4gICAgICAgIGNvbnRhaW5lci5jbGFzc0xpc3QuYWRkKCdkZHItbWF0LXRvb2xiYXItZml4ZWQtdG9wLWNvbnRhaW5lcicpO1xuICAgICAgICB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQucGFyZW50RWxlbWVudC5pbnNlcnRCZWZvcmUoY29udGFpbmVyLCB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQpO1xuICAgICAgICBjb250YWluZXIuYXBwZW5kQ2hpbGQodGhpcy5lbC5uYXRpdmVFbGVtZW50KTtcblxuICAgICAgICBpZiAoJycgIT09IHRoaXMuZGRyTWF0VG9vbGJhckZpeGVkVG9wKSB7XG4gICAgICAgICAgICB0aGlzLmRkck1hdFRvb2xiYXJGaXhlZFRvcC5mb3JFYWNoKChjbGFzc05hbWU6IHN0cmluZykgPT4ge1xuICAgICAgICAgICAgICAgIGNvbnRhaW5lci5jbGFzc0xpc3QuYWRkKGNsYXNzTmFtZSk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==