ca-components 1.0.72 → 1.0.73

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -21,4 +21,4 @@ Run `ng test ca-components` to execute the unit tests via [Karma](https://karma-
21
21
 
22
22
  ## Further help
23
23
 
24
- To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page.
24
+ To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI Overview and Command Reference](https://angular.io/cli) page.
@@ -0,0 +1,205 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
+ import { FormsModule } from '@angular/forms';
3
+ import { CommonModule } from '@angular/common';
4
+ import { ObserversModule } from '@angular/cdk/observers';
5
+ import { Subject } from 'rxjs';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/common";
8
+ import * as i2 from "@angular/cdk/observers";
9
+ export class CaCustomScrollbarComponent {
10
+ constructor(ngZone, elRef, chng) {
11
+ this.ngZone = ngZone;
12
+ this.elRef = elRef;
13
+ this.chng = chng;
14
+ this.scrollEvent = new EventEmitter();
15
+ this.scrollTop = 5;
16
+ this.showScrollbar = false;
17
+ this.scrollHeight = 0;
18
+ this.scrollRatio = 0;
19
+ this.scrollRatioFull = 0;
20
+ this.isMouseDown = false;
21
+ this.barClickPosition = 0;
22
+ this.barClickRestHeight = 0;
23
+ this.destroy$ = new Subject();
24
+ this.tableBarClickPosition = 0;
25
+ this.tableBarClickRestWidth = 0;
26
+ this.tableScrollRatio = 0;
27
+ this.tableScrollRatioFull = 0;
28
+ this.tableScrollWidth = 0;
29
+ this.setScrollEvent = (e) => {
30
+ if (!this.isMouseDown) {
31
+ this.calculateBarSizeAndPosition(this.elRef.nativeElement.children[0]);
32
+ }
33
+ };
34
+ this.onMouseUpHandler = () => {
35
+ this.isMouseDown = false;
36
+ };
37
+ this.onResizeHandler = () => {
38
+ if (!this.isMouseDown) {
39
+ clearTimeout(this.resizeHandlerCount);
40
+ this.resizeHandlerCount = setTimeout(() => {
41
+ this.calculateBarSizeAndPosition(this.elRef.nativeElement.children[0]);
42
+ }, 150);
43
+ }
44
+ };
45
+ this.onMouseMoveHandler = (e) => {
46
+ if (this.isMouseDown) {
47
+ // Regular Scroll
48
+ if (this.scrollBarOptions.showVerticalScrollBar) {
49
+ const offsetBar = e.clientY - this.barClickPosition;
50
+ if (offsetBar > -1 &&
51
+ e.clientY + this.barClickRestHeight < window.innerHeight) {
52
+ this.bar.nativeElement.style.transform = `translateY(${offsetBar}px)`;
53
+ }
54
+ this.elRef.nativeElement.children[0].scrollTop =
55
+ (e.clientY - this.barClickPosition) * this.scrollRatioFull;
56
+ }
57
+ // Table Scroll
58
+ else {
59
+ let offsetBar = e.clientX - this.tableBarClickPosition;
60
+ const maxWidth = this.tableNotPinedBoundingRect.width;
61
+ offsetBar = offsetBar < 0 ? 0 : offsetBar;
62
+ offsetBar =
63
+ e.clientX + this.tableBarClickRestWidth > maxWidth
64
+ ? maxWidth - this.tableScrollWidth
65
+ : offsetBar;
66
+ this.bar.nativeElement.style.transform = `translateX(${offsetBar}px)`;
67
+ this.scrollEvent.emit({
68
+ eventAction: 'scrolling',
69
+ scrollPosition: offsetBar * this.tableScrollRatioFull,
70
+ });
71
+ }
72
+ }
73
+ };
74
+ }
75
+ ngOnInit() {
76
+ this.ngZone.runOutsideAngular(() => {
77
+ document.addEventListener('mouseup', this.onMouseUpHandler);
78
+ document.addEventListener('mousemove', this.onMouseMoveHandler);
79
+ this.elRef.nativeElement.children[0].addEventListener('scroll', this.setScrollEvent);
80
+ window.addEventListener('resize', this.onResizeHandler);
81
+ this.calculateBarSizeAndPosition(this.elRef.nativeElement.children[0]);
82
+ });
83
+ }
84
+ ngOnChanges(changes) {
85
+ if (!changes?.['horizontalScrollHeight']?.firstChange &&
86
+ changes?.['horizontalScrollHeight']) {
87
+ this.horizontalScrollHeight =
88
+ changes['horizontalScrollHeight'].currentValue;
89
+ }
90
+ if (!changes?.['scrollBarOptions']?.firstChange &&
91
+ changes?.['scrollBarOptions']) {
92
+ this.scrollBarOptions = changes['scrollBarOptions'].currentValue;
93
+ }
94
+ }
95
+ ngAfterViewInit() {
96
+ // Table Scroll
97
+ if (this.scrollBarOptions.showHorizontalScrollBar) {
98
+ setTimeout(() => {
99
+ this.tableNotPinedContainer =
100
+ document.querySelector('.not-pined-columns');
101
+ this.tableNotPinedBoundingRect =
102
+ this.tableNotPinedContainer?.getBoundingClientRect()
103
+ ? this.tableNotPinedContainer.getBoundingClientRect()
104
+ : null;
105
+ }, 100);
106
+ }
107
+ }
108
+ setDraggingStart(e) {
109
+ const style = window.getComputedStyle(this.bar.nativeElement);
110
+ const matrix = new DOMMatrixReadOnly(style.transform);
111
+ this.barClickPosition = e.clientY - matrix.m42;
112
+ this.barClickRestHeight = this.scrollHeight - this.barClickPosition;
113
+ this.isMouseDown = true;
114
+ // Table Scroll
115
+ this.tableBarClickPosition = e.clientX - matrix.m41;
116
+ this.tableBarClickRestWidth =
117
+ this.tableScrollWidth - this.tableBarClickPosition;
118
+ }
119
+ calculateBarSizeAndPosition(elem, pageHeight) {
120
+ setTimeout(() => {
121
+ // Table Scroll
122
+ if (this.scrollBarOptions.showHorizontalScrollBar) {
123
+ const scrollWrapper = document.querySelector('.not-pined-columns');
124
+ this.tableNotPinedBoundingRect =
125
+ scrollWrapper?.getBoundingClientRect()
126
+ ? scrollWrapper.getBoundingClientRect()
127
+ : null;
128
+ const tableFullWidth = scrollWrapper?.scrollWidth
129
+ ? scrollWrapper.scrollWidth
130
+ : 0;
131
+ const tableVisibleWidth = scrollWrapper?.getBoundingClientRect()
132
+ .width
133
+ ? Math.ceil(scrollWrapper.getBoundingClientRect().width)
134
+ : 0;
135
+ this.tableScrollRatio = tableVisibleWidth / tableFullWidth;
136
+ this.tableScrollRatioFull = tableFullWidth / tableVisibleWidth;
137
+ this.tableScrollWidth =
138
+ this.tableScrollRatio * tableVisibleWidth;
139
+ if (tableFullWidth <= tableVisibleWidth) {
140
+ this.showScrollbar = false;
141
+ this.chng.detectChanges();
142
+ }
143
+ else {
144
+ this.showScrollbar = true;
145
+ this.chng.detectChanges();
146
+ }
147
+ this.scrollEvent.emit({
148
+ eventAction: 'isScrollShowing',
149
+ isScrollBarShowing: this.showScrollbar,
150
+ });
151
+ }
152
+ // Regular Scroll
153
+ else {
154
+ const content_height = this.elRef.nativeElement.children[0].scrollHeight - 1;
155
+ const visible_height = window.innerHeight;
156
+ if (content_height <= visible_height) {
157
+ this.showScrollbar = false;
158
+ this.chng.detectChanges();
159
+ return;
160
+ }
161
+ else {
162
+ this.showScrollbar = true;
163
+ this.chng.detectChanges();
164
+ }
165
+ this.scrollRatio = visible_height / content_height;
166
+ this.scrollRatioFull = content_height / visible_height;
167
+ this.scrollTop = elem.scrollTop * this.scrollRatio;
168
+ if (this.bar) {
169
+ this.bar.nativeElement.style.transform = `translateY(${this.scrollTop}px)`;
170
+ }
171
+ this.scrollHeight = this.scrollRatio * visible_height;
172
+ }
173
+ this.chng.detectChanges();
174
+ }, 100);
175
+ }
176
+ ngOnDestroy() {
177
+ document.removeEventListener('mouseup', this.onMouseUpHandler);
178
+ document.removeEventListener('mousemove', this.onMouseMoveHandler);
179
+ window.removeEventListener('resize', this.onResizeHandler);
180
+ this.destroy$.next();
181
+ this.destroy$.complete();
182
+ }
183
+ projectContentChanged(e) {
184
+ clearTimeout(this.calculateSizeHeightTimer);
185
+ this.calculateSizeHeightTimer = setTimeout(() => {
186
+ this.calculateBarSizeAndPosition(this.elRef.nativeElement.children[0]);
187
+ }, 100);
188
+ }
189
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaCustomScrollbarComponent, deps: [{ token: i0.NgZone }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
190
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CaCustomScrollbarComponent, isStandalone: true, selector: "app-ca-custom-scrollbar", inputs: { scrollBarOptions: "scrollBarOptions", horizontalScrollHeight: "horizontalScrollHeight" }, outputs: { scrollEvent: "scrollEvent" }, viewQueries: [{ propertyName: "bar", first: true, predicate: ["bar"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n class=\"custom-scrollbar-holder\"\n #contentHolder\n (cdkObserveContent)=\"projectContentChanged($event)\"\n [class.activeToolbar]=\"showScrollbar\"\n [ngStyle]=\"{\n height: scrollBarOptions.showHorizontalScrollBar\n ? horizontalScrollHeight + 'px'\n : 100 + 'vh',\n 'overflow-y': scrollBarOptions.showHorizontalScrollBar\n ? 'visible'\n : 'auto',\n }\"\n>\n <ng-content></ng-content>\n <!-- Vertical Scroll Bar -->\n <div\n class=\"right-bar-scroll\"\n *ngIf=\"showScrollbar && scrollBarOptions.showVerticalScrollBar\"\n >\n <div\n class=\"right-bar\"\n #bar\n [ngStyle]=\"{ height: scrollHeight + 'px' }\"\n (mousedown)=\"setDraggingStart($event)\"\n (mouseup)=\"isMouseDown = false\"\n ></div>\n </div>\n\n <!-- Horizontal Scroll Bar -->\n <div\n class=\"horizontal-scroll-bar\"\n [ngStyle]=\"{\n 'left.px':\n scrollBarOptions?.modalStyle?.horizontalScrollBarLeft === 0 ||\n scrollBarOptions?.modalStyle?.horizontalScrollBarLeft\n ? scrollBarOptions.modalStyle.horizontalScrollBarLeft\n : tableNotPinedBoundingRect?.left - 74,\n 'width.px': scrollBarOptions?.modalStyle?.horizontalScrollBarWidth\n ? scrollBarOptions.modalStyle.horizontalScrollBarWidth\n : tableNotPinedBoundingRect?.width,\n 'margin-top.px': scrollBarOptions?.modalStyle\n ?.horizontalScrollBarMarginTop\n ? scrollBarOptions.modalStyle.horizontalScrollBarMarginTop\n : -15,\n }\"\n [ngClass]=\"{\n 'modal-horizontal-scroll-bar':\n scrollBarOptions?.modalStyle?.modalScrollClassActive,\n }\"\n *ngIf=\"showScrollbar && scrollBarOptions.showHorizontalScrollBar\"\n >\n <div\n class=\"horizontal-bar\"\n #bar\n [ngStyle]=\"{\n 'width.px': scrollBarOptions?.modalStyle?.additionalWidth\n ? tableScrollWidth +\n scrollBarOptions.modalStyle.additionalWidth\n : tableScrollWidth,\n }\"\n [ngClass]=\"{\n 'horizontal-bar-sticky': scrollBarOptions.dataLength >= 23,\n }\"\n (mousedown)=\"setDraggingStart($event)\"\n (mouseup)=\"isMouseDown = false\"\n ></div>\n </div>\n</div>\n", styles: [".custom-scrollbar-holder{position:relative;transition:height .25s ease-in-out;scrollbar-width:none!important;-ms-overflow-style:none!important}.custom-scrollbar-holder::-webkit-scrollbar{display:none!important}.custom-scrollbar-holder ::-webkit-scrollbar-thumb,.custom-scrollbar-holder ::-webkit-scrollbar{width:1px!important;display:none!important}.custom-scrollbar-holder .overflow-unset{overflow-y:unset!important;overflow-x:unset!important}.custom-scrollbar-holder .right-bar-scroll{height:100%;position:fixed;right:0;top:0;-webkit-user-select:none;user-select:none}.custom-scrollbar-holder .right-bar-scroll .right-bar{position:absolute;right:3px;width:6px;min-height:30px;border-radius:1px;background-color:#aaa}.custom-scrollbar-holder .right-bar-scroll .right-bar:hover{background:#0000008c}.custom-scrollbar-holder .modal-horizontal-scroll-bar{height:6px;background:#eee;border-radius:2px}.custom-scrollbar-holder .horizontal-scroll-bar{width:100%;position:absolute;left:0;-webkit-user-select:none;user-select:none}.custom-scrollbar-holder .horizontal-scroll-bar .horizontal-bar{width:6px;position:relative!important;height:6px;min-width:30px;border-radius:1px;background-color:#aaa}.custom-scrollbar-holder .horizontal-scroll-bar .horizontal-bar:hover{background:#0000008c}.custom-scrollbar-holder .horizontal-scroll-bar .horizontal-bar-sticky{position:fixed;bottom:calc(0% + 14px)}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: ObserversModule }, { kind: "directive", type: i2.CdkObserveContent, selector: "[cdkObserveContent]", inputs: ["cdkObserveContentDisabled", "debounce"], outputs: ["cdkObserveContent"], exportAs: ["cdkObserveContent"] }] }); }
191
+ }
192
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaCustomScrollbarComponent, decorators: [{
193
+ type: Component,
194
+ args: [{ selector: 'app-ca-custom-scrollbar', standalone: true, imports: [FormsModule, CommonModule, ObserversModule], template: "<div\n class=\"custom-scrollbar-holder\"\n #contentHolder\n (cdkObserveContent)=\"projectContentChanged($event)\"\n [class.activeToolbar]=\"showScrollbar\"\n [ngStyle]=\"{\n height: scrollBarOptions.showHorizontalScrollBar\n ? horizontalScrollHeight + 'px'\n : 100 + 'vh',\n 'overflow-y': scrollBarOptions.showHorizontalScrollBar\n ? 'visible'\n : 'auto',\n }\"\n>\n <ng-content></ng-content>\n <!-- Vertical Scroll Bar -->\n <div\n class=\"right-bar-scroll\"\n *ngIf=\"showScrollbar && scrollBarOptions.showVerticalScrollBar\"\n >\n <div\n class=\"right-bar\"\n #bar\n [ngStyle]=\"{ height: scrollHeight + 'px' }\"\n (mousedown)=\"setDraggingStart($event)\"\n (mouseup)=\"isMouseDown = false\"\n ></div>\n </div>\n\n <!-- Horizontal Scroll Bar -->\n <div\n class=\"horizontal-scroll-bar\"\n [ngStyle]=\"{\n 'left.px':\n scrollBarOptions?.modalStyle?.horizontalScrollBarLeft === 0 ||\n scrollBarOptions?.modalStyle?.horizontalScrollBarLeft\n ? scrollBarOptions.modalStyle.horizontalScrollBarLeft\n : tableNotPinedBoundingRect?.left - 74,\n 'width.px': scrollBarOptions?.modalStyle?.horizontalScrollBarWidth\n ? scrollBarOptions.modalStyle.horizontalScrollBarWidth\n : tableNotPinedBoundingRect?.width,\n 'margin-top.px': scrollBarOptions?.modalStyle\n ?.horizontalScrollBarMarginTop\n ? scrollBarOptions.modalStyle.horizontalScrollBarMarginTop\n : -15,\n }\"\n [ngClass]=\"{\n 'modal-horizontal-scroll-bar':\n scrollBarOptions?.modalStyle?.modalScrollClassActive,\n }\"\n *ngIf=\"showScrollbar && scrollBarOptions.showHorizontalScrollBar\"\n >\n <div\n class=\"horizontal-bar\"\n #bar\n [ngStyle]=\"{\n 'width.px': scrollBarOptions?.modalStyle?.additionalWidth\n ? tableScrollWidth +\n scrollBarOptions.modalStyle.additionalWidth\n : tableScrollWidth,\n }\"\n [ngClass]=\"{\n 'horizontal-bar-sticky': scrollBarOptions.dataLength >= 23,\n }\"\n (mousedown)=\"setDraggingStart($event)\"\n (mouseup)=\"isMouseDown = false\"\n ></div>\n </div>\n</div>\n", styles: [".custom-scrollbar-holder{position:relative;transition:height .25s ease-in-out;scrollbar-width:none!important;-ms-overflow-style:none!important}.custom-scrollbar-holder::-webkit-scrollbar{display:none!important}.custom-scrollbar-holder ::-webkit-scrollbar-thumb,.custom-scrollbar-holder ::-webkit-scrollbar{width:1px!important;display:none!important}.custom-scrollbar-holder .overflow-unset{overflow-y:unset!important;overflow-x:unset!important}.custom-scrollbar-holder .right-bar-scroll{height:100%;position:fixed;right:0;top:0;-webkit-user-select:none;user-select:none}.custom-scrollbar-holder .right-bar-scroll .right-bar{position:absolute;right:3px;width:6px;min-height:30px;border-radius:1px;background-color:#aaa}.custom-scrollbar-holder .right-bar-scroll .right-bar:hover{background:#0000008c}.custom-scrollbar-holder .modal-horizontal-scroll-bar{height:6px;background:#eee;border-radius:2px}.custom-scrollbar-holder .horizontal-scroll-bar{width:100%;position:absolute;left:0;-webkit-user-select:none;user-select:none}.custom-scrollbar-holder .horizontal-scroll-bar .horizontal-bar{width:6px;position:relative!important;height:6px;min-width:30px;border-radius:1px;background-color:#aaa}.custom-scrollbar-holder .horizontal-scroll-bar .horizontal-bar:hover{background:#0000008c}.custom-scrollbar-holder .horizontal-scroll-bar .horizontal-bar-sticky{position:fixed;bottom:calc(0% + 14px)}\n"] }]
195
+ }], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], propDecorators: { bar: [{
196
+ type: ViewChild,
197
+ args: ['bar', { static: false }]
198
+ }], scrollEvent: [{
199
+ type: Output
200
+ }], scrollBarOptions: [{
201
+ type: Input
202
+ }], horizontalScrollHeight: [{
203
+ type: Input
204
+ }] } });
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-custom-scrollbar.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-custom-scrollbar/ca-custom-scrollbar.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-custom-scrollbar/ca-custom-scrollbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { AfterViewInit, OnChanges } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { ObserversModule } from '@angular/cdk/observers';\n\nimport { Subject } from 'rxjs';\n\n@Component({\n    selector: 'app-ca-custom-scrollbar',\n    standalone: true,\n    imports: [FormsModule, CommonModule, ObserversModule],\n    templateUrl: './ca-custom-scrollbar.component.html',\n    styleUrl: './ca-custom-scrollbar.component.scss',\n})\nexport class CaCustomScrollbarComponent\n    implements OnInit, OnChanges, AfterViewInit, OnDestroy\n{\n    @ViewChild('bar', { static: false }) private bar!: ElementRef;\n    @Output() scrollEvent: EventEmitter<any> = new EventEmitter();\n    @Input() scrollBarOptions: any;\n    @Input() horizontalScrollHeight!: number;\n\n    scrollTop: number = 5;\n    showScrollbar: boolean = false;\n    scrollHeight: number = 0;\n    scrollRatio: number = 0;\n    scrollRatioFull: number = 0;\n\n    isMouseDown: boolean = false;\n    barClickPosition: number = 0;\n    barClickRestHeight: number = 0;\n    private destroy$ = new Subject<void>();\n    calculateSizeHeightTimer: any;\n\n    // Table Horizontal Scroll\n    tableNotPinedContainer: any;\n    tableNotPinedBoundingRect: any;\n    tableBarClickPosition: number = 0;\n    tableBarClickRestWidth: number = 0;\n    tableScrollRatio: number = 0;\n    tableScrollRatioFull: number = 0;\n    tableScrollWidth: number = 0;\n\n    constructor(\n        private ngZone: NgZone,\n        private elRef: ElementRef,\n        private chng: ChangeDetectorRef\n    ) {}\n\n    ngOnInit(): void {\n        this.ngZone.runOutsideAngular(() => {\n            document.addEventListener('mouseup', this.onMouseUpHandler);\n\n            document.addEventListener('mousemove', this.onMouseMoveHandler);\n\n            this.elRef.nativeElement.children[0].addEventListener(\n                'scroll',\n                this.setScrollEvent\n            );\n\n            window.addEventListener('resize', this.onResizeHandler);\n\n            this.calculateBarSizeAndPosition(\n                this.elRef.nativeElement.children[0]\n            );\n        });\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (\n            !changes?.['horizontalScrollHeight']?.firstChange &&\n            changes?.['horizontalScrollHeight']\n        ) {\n            this.horizontalScrollHeight =\n                changes['horizontalScrollHeight'].currentValue;\n        }\n\n        if (\n            !changes?.['scrollBarOptions']?.firstChange &&\n            changes?.['scrollBarOptions']\n        ) {\n            this.scrollBarOptions = changes['scrollBarOptions'].currentValue;\n        }\n    }\n\n    ngAfterViewInit(): void {\n        // Table Scroll\n        if (this.scrollBarOptions.showHorizontalScrollBar) {\n            setTimeout(() => {\n                this.tableNotPinedContainer =\n                    document.querySelector('.not-pined-columns');\n\n                this.tableNotPinedBoundingRect =\n                    this.tableNotPinedContainer?.getBoundingClientRect()\n                        ? this.tableNotPinedContainer.getBoundingClientRect()\n                        : null;\n            }, 100);\n        }\n    }\n\n    public setScrollEvent = (e: any) => {\n        if (!this.isMouseDown) {\n            this.calculateBarSizeAndPosition(\n                this.elRef.nativeElement.children[0]\n            );\n        }\n    };\n\n    setDraggingStart(e: MouseEvent) {\n        const style = window.getComputedStyle(this.bar.nativeElement);\n        const matrix = new DOMMatrixReadOnly(style.transform);\n\n        this.barClickPosition = e.clientY - matrix.m42;\n        this.barClickRestHeight = this.scrollHeight - this.barClickPosition;\n        this.isMouseDown = true;\n\n        // Table Scroll\n        this.tableBarClickPosition = e.clientX - matrix.m41;\n        this.tableBarClickRestWidth =\n            this.tableScrollWidth - this.tableBarClickPosition;\n    }\n\n    calculateBarSizeAndPosition(elem: any, pageHeight?: number) {\n        setTimeout(() => {\n            // Table Scroll\n            if (this.scrollBarOptions.showHorizontalScrollBar) {\n                const scrollWrapper =\n                    document.querySelector('.not-pined-columns');\n\n                this.tableNotPinedBoundingRect =\n                    scrollWrapper?.getBoundingClientRect()\n                        ? scrollWrapper.getBoundingClientRect()\n                        : null;\n\n                const tableFullWidth = scrollWrapper?.scrollWidth\n                    ? scrollWrapper.scrollWidth\n                    : 0;\n\n                const tableVisibleWidth = scrollWrapper?.getBoundingClientRect()\n                    .width\n                    ? Math.ceil(scrollWrapper.getBoundingClientRect().width)\n                    : 0;\n\n                this.tableScrollRatio = tableVisibleWidth / tableFullWidth;\n\n                this.tableScrollRatioFull = tableFullWidth / tableVisibleWidth;\n\n                this.tableScrollWidth =\n                    this.tableScrollRatio * tableVisibleWidth;\n\n                if (tableFullWidth <= tableVisibleWidth) {\n                    this.showScrollbar = false;\n\n                    this.chng.detectChanges();\n                } else {\n                    this.showScrollbar = true;\n                    this.chng.detectChanges();\n                }\n\n                this.scrollEvent.emit({\n                    eventAction: 'isScrollShowing',\n                    isScrollBarShowing: this.showScrollbar,\n                });\n            }\n            // Regular Scroll\n            else {\n                const content_height =\n                    this.elRef.nativeElement.children[0].scrollHeight - 1;\n                const visible_height = window.innerHeight;\n\n                if (content_height <= visible_height) {\n                    this.showScrollbar = false;\n                    this.chng.detectChanges();\n                    return;\n                } else {\n                    this.showScrollbar = true;\n                    this.chng.detectChanges();\n                }\n\n                this.scrollRatio = visible_height / content_height;\n                this.scrollRatioFull = content_height / visible_height;\n                this.scrollTop = elem.scrollTop * this.scrollRatio;\n\n                if (this.bar) {\n                    this.bar.nativeElement.style.transform = `translateY(${this.scrollTop}px)`;\n                }\n\n                this.scrollHeight = this.scrollRatio * visible_height;\n            }\n\n            this.chng.detectChanges();\n        }, 100);\n    }\n\n    onMouseUpHandler = () => {\n        this.isMouseDown = false;\n    };\n\n    resizeHandlerCount: any;\n    onResizeHandler = () => {\n        if (!this.isMouseDown) {\n            clearTimeout(this.resizeHandlerCount);\n            this.resizeHandlerCount = setTimeout(() => {\n                this.calculateBarSizeAndPosition(\n                    this.elRef.nativeElement.children[0]\n                );\n            }, 150);\n        }\n    };\n\n    onMouseMoveHandler = (e: any) => {\n        if (this.isMouseDown) {\n            // Regular Scroll\n            if (this.scrollBarOptions.showVerticalScrollBar) {\n                const offsetBar = e.clientY - this.barClickPosition;\n                if (\n                    offsetBar > -1 &&\n                    e.clientY + this.barClickRestHeight < window.innerHeight\n                ) {\n                    this.bar.nativeElement.style.transform = `translateY(${offsetBar}px)`;\n                }\n                this.elRef.nativeElement.children[0].scrollTop =\n                    (e.clientY - this.barClickPosition) * this.scrollRatioFull;\n            }\n            // Table Scroll\n            else {\n                let offsetBar = e.clientX - this.tableBarClickPosition;\n                const maxWidth = this.tableNotPinedBoundingRect.width;\n\n                offsetBar = offsetBar < 0 ? 0 : offsetBar;\n                offsetBar =\n                    e.clientX + this.tableBarClickRestWidth > maxWidth\n                        ? maxWidth - this.tableScrollWidth\n                        : offsetBar;\n\n                this.bar.nativeElement.style.transform = `translateX(${offsetBar}px)`;\n\n                this.scrollEvent.emit({\n                    eventAction: 'scrolling',\n                    scrollPosition: offsetBar * this.tableScrollRatioFull,\n                });\n            }\n        }\n    };\n\n    ngOnDestroy(): void {\n        document.removeEventListener('mouseup', this.onMouseUpHandler);\n        document.removeEventListener('mousemove', this.onMouseMoveHandler);\n        window.removeEventListener('resize', this.onResizeHandler);\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    projectContentChanged(e: any) {\n        clearTimeout(this.calculateSizeHeightTimer);\n        this.calculateSizeHeightTimer = setTimeout(() => {\n            this.calculateBarSizeAndPosition(\n                this.elRef.nativeElement.children[0]\n            );\n        }, 100);\n    }\n}\n","<div\n    class=\"custom-scrollbar-holder\"\n    #contentHolder\n    (cdkObserveContent)=\"projectContentChanged($event)\"\n    [class.activeToolbar]=\"showScrollbar\"\n    [ngStyle]=\"{\n        height: scrollBarOptions.showHorizontalScrollBar\n            ? horizontalScrollHeight + 'px'\n            : 100 + 'vh',\n        'overflow-y': scrollBarOptions.showHorizontalScrollBar\n            ? 'visible'\n            : 'auto',\n    }\"\n>\n    <ng-content></ng-content>\n    <!-- Vertical Scroll Bar -->\n    <div\n        class=\"right-bar-scroll\"\n        *ngIf=\"showScrollbar && scrollBarOptions.showVerticalScrollBar\"\n    >\n        <div\n            class=\"right-bar\"\n            #bar\n            [ngStyle]=\"{ height: scrollHeight + 'px' }\"\n            (mousedown)=\"setDraggingStart($event)\"\n            (mouseup)=\"isMouseDown = false\"\n        ></div>\n    </div>\n\n    <!-- Horizontal Scroll Bar -->\n    <div\n        class=\"horizontal-scroll-bar\"\n        [ngStyle]=\"{\n            'left.px':\n                scrollBarOptions?.modalStyle?.horizontalScrollBarLeft === 0 ||\n                scrollBarOptions?.modalStyle?.horizontalScrollBarLeft\n                    ? scrollBarOptions.modalStyle.horizontalScrollBarLeft\n                    : tableNotPinedBoundingRect?.left - 74,\n            'width.px': scrollBarOptions?.modalStyle?.horizontalScrollBarWidth\n                ? scrollBarOptions.modalStyle.horizontalScrollBarWidth\n                : tableNotPinedBoundingRect?.width,\n            'margin-top.px': scrollBarOptions?.modalStyle\n                ?.horizontalScrollBarMarginTop\n                ? scrollBarOptions.modalStyle.horizontalScrollBarMarginTop\n                : -15,\n        }\"\n        [ngClass]=\"{\n            'modal-horizontal-scroll-bar':\n                scrollBarOptions?.modalStyle?.modalScrollClassActive,\n        }\"\n        *ngIf=\"showScrollbar && scrollBarOptions.showHorizontalScrollBar\"\n    >\n        <div\n            class=\"horizontal-bar\"\n            #bar\n            [ngStyle]=\"{\n                'width.px': scrollBarOptions?.modalStyle?.additionalWidth\n                    ? tableScrollWidth +\n                      scrollBarOptions.modalStyle.additionalWidth\n                    : tableScrollWidth,\n            }\"\n            [ngClass]=\"{\n                'horizontal-bar-sticky': scrollBarOptions.dataLength >= 23,\n            }\"\n            (mousedown)=\"setDraggingStart($event)\"\n            (mouseup)=\"isMouseDown = false\"\n        ></div>\n    </div>\n</div>\n"]}
@@ -5,6 +5,8 @@ import { Component, Input } from '@angular/core';
5
5
  import { FormsModule } from '@angular/forms';
6
6
  import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
7
7
  import { AngularSvgIconModule } from 'angular-svg-icon';
8
+ // components
9
+ import { CaCustomScrollbarComponent } from '../ca-custom-scrollbar/ca-custom-scrollbar.component';
8
10
  import * as i0 from "@angular/core";
9
11
  import * as i1 from "@angular/common";
10
12
  import * as i2 from "@angular/cdk/drag-drop";
@@ -15,7 +17,9 @@ export class CaModalComponent {
15
17
  this.modalTitle = '';
16
18
  }
17
19
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CaModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
18
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CaModalComponent, isStandalone: true, selector: "app-ca-modal", inputs: { customClass: "customClass", partClass: "partClass", modalTitle: "modalTitle", leftHeaderTemplate: "leftHeaderTemplate", rightHeaderTemplate: "rightHeaderTemplate", footerTemplate: "footerTemplate", additionalPartTemplate: "additionalPartTemplate" }, ngImport: i0, template: "<div cdkDrag class=\"modal-container {{ customClass }}\" ngBAutofocus>\n <div class=\"modal-original-part {{ partClass }}\">\n <div cdkDragHandle class=\"modal-header d-flex justify-content-between\">\n <div class=\"modal-header-leftside\">\n <!-- Header title -->\n\n <h5 class=\"modal-title\">{{ modalTitle }}</h5>\n <!-- Haeder left side template -->\n\n <ng-container *ngTemplateOutlet=\"leftHeaderTemplate\"></ng-container>\n </div>\n <div class=\"modal-header-rightside\">\n <!-- Haeder right side -->\n\n <ng-container *ngTemplateOutlet=\"rightHeaderTemplate\"></ng-container>\n </div>\n </div>\n\n <div class=\"modal-body\">\n <!-- Modal content -->\n\n <ng-content select=\"[origin]\"></ng-content>\n </div>\n <!-- Footer Template Content -->\n\n <div cdkDragHandle>\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n </div>\n \n </div>\n <!-- Additional Part Content -->\n\n <ng-container *ngTemplateOutlet=\"additionalPartTemplate\"></ng-container>\n</div>", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.modal-open{overflow:hidden!important}.modal-open::-webkit-scrollbar-track{background-color:#0000004d}.modal-open::-webkit-scrollbar-thumb{background-color:#0000004d}.modal-date-logo{height:26px;width:26px;cursor:pointer!important;position:relative}.modal-date-logo svg:hover{cursor:pointer}.modal-date-logo svg:hover path{fill:#919191}.modal-date-border{height:18px;margin-right:4px;border-right:1px solid #cccccc}.modal-container{width:480px;height:auto;overflow:hidden;position:relative;transition:width .3s}.modal-container .drop-zone-active{width:100%;height:100%;position:absolute;top:0%;left:0%;z-index:99999999999}.modal-container .drop-zone-active .drop-zone-title{position:absolute;z-index:9999;top:16px;left:14px;color:#6c6c6c;font-size:18px;font-weight:800;margin:0}.modal-container .drop-zone-active .ta-modal-dropzone{position:absolute;top:0;border:4px dashed #e5e5e5}.modal-container .drop-zone-active-hovered .ta-modal-dropzone{position:absolute;top:0;border:4px dashed #dadada;background-color:#eee}.modal-container .drop-zone-active-hovered .ta-modal-dropzone .ta-modal-dropzone-label{background-color:#eee}.modal-container .drop-zone-active-hovered .ta-modal-dropzone .ta-modal-dropzone-text{color:#6c6c6c}.modal-container .drop-zone-active .ta-modal-dropzone-area{transform:scale(2)}.modal-container .drop-zone-active .ta-modal-dropzone-text{position:absolute!important;top:84%!important;text-align:center;left:50%!important;transform:translate(-50%,-50%)}.modal-container.modal-container-load{width:1280px;display:flex}.modal-container.modal-container-load .divider{width:615px}.modal-container.modal-container-load .modal-additional-part{width:640px}.modal-container.modal-container-load .modal-additional-part-load{background-color:#f7f7f7;height:650px}.modal-container.modal-container-load .modal-additional-part-load .divider{background-color:#dadada;height:1px}.modal-container.modal-container-load .modal-additional-part-load-modal{max-width:640px;width:calc(100vw - 640px)}.modal-container .load-modal-origin-part{width:640px!important}.modal-container.modal-container-XS{width:390px}.modal-container.modal-container-XS .divider{width:366px}.modal-container.modal-container-XS .confirmation-modal-body{padding:22px 6px}.modal-container.modal-container-S{width:366px}.modal-container.modal-container-S .divider{width:341px}.modal-container.modal-container-M{width:640px}.modal-container.modal-container-M .divider{height:1px;background-color:#dadada;width:616px;margin:0 auto}.modal-container.modal-container-L{width:710px}.modal-container.modal-container-L .divider{width:685px}.modal-container.modal-container-XL{width:860px}.modal-container.modal-container-XL .divider{width:836px}.modal-container.modal-container-XL-2{width:800px;overflow:visible!important}.modal-container.modal-container-XL-2 .divider{width:775px}.modal-container .divider-bottom{margin-bottom:12px!important}.modal-container .card-divider{background-color:#dadada!important;height:1px!important}.modal-container.modal-container-sph-applicant{width:940px;height:960px;overflow-y:scroll;scrollbar-width:none!important}.modal-container.modal-container-sph-applicant::-webkit-scrollbar{width:2px}.modal-container.modal-container-sph-applicant::-webkit-scrollbar-thumb{background-color:transparent;border:6px solid transparent;border-radius:1px}.modal-container.modal-container-sph-applicant::-webkit-scrollbar-track{padding:0;position:relative;right:0;top:0;background:transparent}.modal-container.modal-container-sph-applicant .divider{display:none}.modal-container .divider{width:455px;height:2px;content:\"\";border-radius:1px;background-color:#f3f3f3;margin:0 auto}.modal-container .modal-spinner{position:absolute;bottom:7px;right:8px}.modal-container .form-container .row>*:nth-child(odd){padding-left:12px;padding-right:12px}.modal-container .form-container .row>*:nth-child(2n){padding-left:0;padding-right:12px}.modal-container .not-clickable{pointer-events:none;cursor:not-allowed;background:#f7f7f7!important;color:#ccc!important}.modal-container .modal-footer>*{margin:0!important}.modal-container .modal-footer .ta-modal-footer-right-side,.modal-container .modal-footer .ta-modal-footer-left-side{gap:12px;padding-left:1px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: DragDropModule }, { kind: "directive", type: i2.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i2.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "ngmodule", type: AngularSvgIconModule }, { kind: "ngmodule", type: NgbModule }], animations: [
20
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CaModalComponent, isStandalone: true, selector: "app-ca-modal", inputs: { customClass: "customClass", partClass: "partClass", modalTitle: "modalTitle", leftHeaderTemplate: "leftHeaderTemplate", rightHeaderTemplate: "rightHeaderTemplate", footerTemplate: "footerTemplate", additionalPartTemplate: "additionalPartTemplate" }, ngImport: i0, template: "<app-ca-custom-scrollbar\n [scrollBarOptions]=\"{\n showVerticalScrollBar: true,\n showHorizontalScrollBar: false,\n }\"\n>\n <div cdkDrag class=\"modal-container {{ customClass }}\" ngBAutofocus>\n <div class=\"modal-original-part {{ partClass }}\">\n <div\n cdkDragHandle\n class=\"modal-header d-flex justify-content-between\"\n >\n <div class=\"modal-header-leftside\">\n <!-- Header title -->\n\n <h5 class=\"modal-title\">{{ modalTitle }}</h5>\n <!-- Haeder left side template -->\n\n <ng-container\n *ngTemplateOutlet=\"leftHeaderTemplate\"\n ></ng-container>\n </div>\n <div class=\"modal-header-rightside\">\n <!-- Haeder right side -->\n\n <ng-container\n *ngTemplateOutlet=\"rightHeaderTemplate\"\n ></ng-container>\n </div>\n </div>\n\n <div class=\"modal-body\">\n <!-- Modal content -->\n\n <ng-content select=\"[origin]\"></ng-content>\n </div>\n <!-- Footer Template Content -->\n\n <div cdkDragHandle>\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n </div>\n </div>\n <!-- Additional Part Content -->\n\n <ng-container *ngTemplateOutlet=\"additionalPartTemplate\"></ng-container>\n </div>\n</app-ca-custom-scrollbar>\n", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.modal-open{overflow:hidden!important}.modal-open::-webkit-scrollbar-track{background-color:#0000004d}.modal-open::-webkit-scrollbar-thumb{background-color:#0000004d}.modal-date-logo{height:26px;width:26px;cursor:pointer!important;position:relative}.modal-date-logo svg:hover{cursor:pointer}.modal-date-logo svg:hover path{fill:#919191}.modal-date-border{height:18px;margin-right:4px;border-right:1px solid #cccccc}.modal-container{width:480px;height:auto;overflow:hidden;position:relative;transition:width .3s}.modal-container .drop-zone-active{width:100%;height:100%;position:absolute;top:0%;left:0%;z-index:99999999999}.modal-container .drop-zone-active .drop-zone-title{position:absolute;z-index:9999;top:16px;left:14px;color:#6c6c6c;font-size:18px;font-weight:800;margin:0}.modal-container .drop-zone-active .ta-modal-dropzone{position:absolute;top:0;border:4px dashed #e5e5e5}.modal-container .drop-zone-active-hovered .ta-modal-dropzone{position:absolute;top:0;border:4px dashed #dadada;background-color:#eee}.modal-container .drop-zone-active-hovered .ta-modal-dropzone .ta-modal-dropzone-label{background-color:#eee}.modal-container .drop-zone-active-hovered .ta-modal-dropzone .ta-modal-dropzone-text{color:#6c6c6c}.modal-container .drop-zone-active .ta-modal-dropzone-area{transform:scale(2)}.modal-container .drop-zone-active .ta-modal-dropzone-text{position:absolute!important;top:84%!important;text-align:center;left:50%!important;transform:translate(-50%,-50%)}.modal-container.modal-container-load{width:1280px;display:flex}.modal-container.modal-container-load .divider{width:615px}.modal-container.modal-container-load .modal-additional-part{width:640px}.modal-container.modal-container-load .modal-additional-part-load{background-color:#f7f7f7;height:650px}.modal-container.modal-container-load .modal-additional-part-load .divider{background-color:#dadada;height:1px}.modal-container.modal-container-load .modal-additional-part-load-modal{max-width:640px;width:calc(100vw - 640px)}.modal-container .load-modal-origin-part{width:640px!important}.modal-container.modal-container-XS{width:390px}.modal-container.modal-container-XS .divider{width:366px}.modal-container.modal-container-XS .confirmation-modal-body{padding:22px 6px}.modal-container.modal-container-S{width:366px}.modal-container.modal-container-S .divider{width:341px}.modal-container.modal-container-M{width:640px}.modal-container.modal-container-M .divider{height:1px;background-color:#dadada;width:616px;margin:0 auto}.modal-container.modal-container-L{width:710px}.modal-container.modal-container-L .divider{width:685px}.modal-container.modal-container-XL{width:860px}.modal-container.modal-container-XL .divider{width:836px}.modal-container.modal-container-XL-2{width:800px;overflow:visible!important}.modal-container.modal-container-XL-2 .divider{width:775px}.modal-container .divider-bottom{margin-bottom:12px!important}.modal-container .card-divider{background-color:#dadada!important;height:1px!important}.modal-container.modal-container-sph-applicant{width:940px;height:960px;overflow-y:scroll;scrollbar-width:none!important}.modal-container.modal-container-sph-applicant::-webkit-scrollbar{width:2px}.modal-container.modal-container-sph-applicant::-webkit-scrollbar-thumb{background-color:transparent;border:6px solid transparent;border-radius:1px}.modal-container.modal-container-sph-applicant::-webkit-scrollbar-track{padding:0;position:relative;right:0;top:0;background:transparent}.modal-container.modal-container-sph-applicant .divider{display:none}.modal-container .divider{width:455px;height:2px;content:\"\";border-radius:1px;background-color:#f3f3f3;margin:0 auto}.modal-container .modal-spinner{position:absolute;bottom:7px;right:8px}.modal-container .form-container .row>*:nth-child(odd){padding-left:12px;padding-right:12px}.modal-container .form-container .row>*:nth-child(2n){padding-left:0;padding-right:12px}.modal-container .not-clickable{pointer-events:none;cursor:not-allowed;background:#f7f7f7!important;color:#ccc!important}.modal-container .modal-footer>*{margin:0!important}.modal-container .modal-footer .ta-modal-footer-right-side,.modal-container .modal-footer .ta-modal-footer-left-side{gap:12px;padding-left:1px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: DragDropModule }, { kind: "directive", type: i2.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i2.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "ngmodule", type: AngularSvgIconModule }, { kind: "ngmodule", type: NgbModule }, { kind: "component", type:
21
+ // components
22
+ CaCustomScrollbarComponent, selector: "app-ca-custom-scrollbar", inputs: ["scrollBarOptions", "horizontalScrollHeight"], outputs: ["scrollEvent"] }], animations: [
19
23
  trigger('widthGrow', [
20
24
  state('closed', style({
21
25
  transform: 'scale(0)',
@@ -35,6 +39,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
35
39
  DragDropModule,
36
40
  AngularSvgIconModule,
37
41
  NgbModule,
42
+ // components
43
+ CaCustomScrollbarComponent,
38
44
  ], animations: [
39
45
  trigger('widthGrow', [
40
46
  state('closed', style({
@@ -45,7 +51,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
45
51
  })),
46
52
  transition('closed => open', animate(100)),
47
53
  ]),
48
- ], template: "<div cdkDrag class=\"modal-container {{ customClass }}\" ngBAutofocus>\n <div class=\"modal-original-part {{ partClass }}\">\n <div cdkDragHandle class=\"modal-header d-flex justify-content-between\">\n <div class=\"modal-header-leftside\">\n <!-- Header title -->\n\n <h5 class=\"modal-title\">{{ modalTitle }}</h5>\n <!-- Haeder left side template -->\n\n <ng-container *ngTemplateOutlet=\"leftHeaderTemplate\"></ng-container>\n </div>\n <div class=\"modal-header-rightside\">\n <!-- Haeder right side -->\n\n <ng-container *ngTemplateOutlet=\"rightHeaderTemplate\"></ng-container>\n </div>\n </div>\n\n <div class=\"modal-body\">\n <!-- Modal content -->\n\n <ng-content select=\"[origin]\"></ng-content>\n </div>\n <!-- Footer Template Content -->\n\n <div cdkDragHandle>\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n </div>\n \n </div>\n <!-- Additional Part Content -->\n\n <ng-container *ngTemplateOutlet=\"additionalPartTemplate\"></ng-container>\n</div>", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.modal-open{overflow:hidden!important}.modal-open::-webkit-scrollbar-track{background-color:#0000004d}.modal-open::-webkit-scrollbar-thumb{background-color:#0000004d}.modal-date-logo{height:26px;width:26px;cursor:pointer!important;position:relative}.modal-date-logo svg:hover{cursor:pointer}.modal-date-logo svg:hover path{fill:#919191}.modal-date-border{height:18px;margin-right:4px;border-right:1px solid #cccccc}.modal-container{width:480px;height:auto;overflow:hidden;position:relative;transition:width .3s}.modal-container .drop-zone-active{width:100%;height:100%;position:absolute;top:0%;left:0%;z-index:99999999999}.modal-container .drop-zone-active .drop-zone-title{position:absolute;z-index:9999;top:16px;left:14px;color:#6c6c6c;font-size:18px;font-weight:800;margin:0}.modal-container .drop-zone-active .ta-modal-dropzone{position:absolute;top:0;border:4px dashed #e5e5e5}.modal-container .drop-zone-active-hovered .ta-modal-dropzone{position:absolute;top:0;border:4px dashed #dadada;background-color:#eee}.modal-container .drop-zone-active-hovered .ta-modal-dropzone .ta-modal-dropzone-label{background-color:#eee}.modal-container .drop-zone-active-hovered .ta-modal-dropzone .ta-modal-dropzone-text{color:#6c6c6c}.modal-container .drop-zone-active .ta-modal-dropzone-area{transform:scale(2)}.modal-container .drop-zone-active .ta-modal-dropzone-text{position:absolute!important;top:84%!important;text-align:center;left:50%!important;transform:translate(-50%,-50%)}.modal-container.modal-container-load{width:1280px;display:flex}.modal-container.modal-container-load .divider{width:615px}.modal-container.modal-container-load .modal-additional-part{width:640px}.modal-container.modal-container-load .modal-additional-part-load{background-color:#f7f7f7;height:650px}.modal-container.modal-container-load .modal-additional-part-load .divider{background-color:#dadada;height:1px}.modal-container.modal-container-load .modal-additional-part-load-modal{max-width:640px;width:calc(100vw - 640px)}.modal-container .load-modal-origin-part{width:640px!important}.modal-container.modal-container-XS{width:390px}.modal-container.modal-container-XS .divider{width:366px}.modal-container.modal-container-XS .confirmation-modal-body{padding:22px 6px}.modal-container.modal-container-S{width:366px}.modal-container.modal-container-S .divider{width:341px}.modal-container.modal-container-M{width:640px}.modal-container.modal-container-M .divider{height:1px;background-color:#dadada;width:616px;margin:0 auto}.modal-container.modal-container-L{width:710px}.modal-container.modal-container-L .divider{width:685px}.modal-container.modal-container-XL{width:860px}.modal-container.modal-container-XL .divider{width:836px}.modal-container.modal-container-XL-2{width:800px;overflow:visible!important}.modal-container.modal-container-XL-2 .divider{width:775px}.modal-container .divider-bottom{margin-bottom:12px!important}.modal-container .card-divider{background-color:#dadada!important;height:1px!important}.modal-container.modal-container-sph-applicant{width:940px;height:960px;overflow-y:scroll;scrollbar-width:none!important}.modal-container.modal-container-sph-applicant::-webkit-scrollbar{width:2px}.modal-container.modal-container-sph-applicant::-webkit-scrollbar-thumb{background-color:transparent;border:6px solid transparent;border-radius:1px}.modal-container.modal-container-sph-applicant::-webkit-scrollbar-track{padding:0;position:relative;right:0;top:0;background:transparent}.modal-container.modal-container-sph-applicant .divider{display:none}.modal-container .divider{width:455px;height:2px;content:\"\";border-radius:1px;background-color:#f3f3f3;margin:0 auto}.modal-container .modal-spinner{position:absolute;bottom:7px;right:8px}.modal-container .form-container .row>*:nth-child(odd){padding-left:12px;padding-right:12px}.modal-container .form-container .row>*:nth-child(2n){padding-left:0;padding-right:12px}.modal-container .not-clickable{pointer-events:none;cursor:not-allowed;background:#f7f7f7!important;color:#ccc!important}.modal-container .modal-footer>*{margin:0!important}.modal-container .modal-footer .ta-modal-footer-right-side,.modal-container .modal-footer .ta-modal-footer-left-side{gap:12px;padding-left:1px}\n"] }]
54
+ ], template: "<app-ca-custom-scrollbar\n [scrollBarOptions]=\"{\n showVerticalScrollBar: true,\n showHorizontalScrollBar: false,\n }\"\n>\n <div cdkDrag class=\"modal-container {{ customClass }}\" ngBAutofocus>\n <div class=\"modal-original-part {{ partClass }}\">\n <div\n cdkDragHandle\n class=\"modal-header d-flex justify-content-between\"\n >\n <div class=\"modal-header-leftside\">\n <!-- Header title -->\n\n <h5 class=\"modal-title\">{{ modalTitle }}</h5>\n <!-- Haeder left side template -->\n\n <ng-container\n *ngTemplateOutlet=\"leftHeaderTemplate\"\n ></ng-container>\n </div>\n <div class=\"modal-header-rightside\">\n <!-- Haeder right side -->\n\n <ng-container\n *ngTemplateOutlet=\"rightHeaderTemplate\"\n ></ng-container>\n </div>\n </div>\n\n <div class=\"modal-body\">\n <!-- Modal content -->\n\n <ng-content select=\"[origin]\"></ng-content>\n </div>\n <!-- Footer Template Content -->\n\n <div cdkDragHandle>\n <ng-container *ngTemplateOutlet=\"footerTemplate\"></ng-container>\n </div>\n </div>\n <!-- Additional Part Content -->\n\n <ng-container *ngTemplateOutlet=\"additionalPartTemplate\"></ng-container>\n </div>\n</app-ca-custom-scrollbar>\n", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.modal-open{overflow:hidden!important}.modal-open::-webkit-scrollbar-track{background-color:#0000004d}.modal-open::-webkit-scrollbar-thumb{background-color:#0000004d}.modal-date-logo{height:26px;width:26px;cursor:pointer!important;position:relative}.modal-date-logo svg:hover{cursor:pointer}.modal-date-logo svg:hover path{fill:#919191}.modal-date-border{height:18px;margin-right:4px;border-right:1px solid #cccccc}.modal-container{width:480px;height:auto;overflow:hidden;position:relative;transition:width .3s}.modal-container .drop-zone-active{width:100%;height:100%;position:absolute;top:0%;left:0%;z-index:99999999999}.modal-container .drop-zone-active .drop-zone-title{position:absolute;z-index:9999;top:16px;left:14px;color:#6c6c6c;font-size:18px;font-weight:800;margin:0}.modal-container .drop-zone-active .ta-modal-dropzone{position:absolute;top:0;border:4px dashed #e5e5e5}.modal-container .drop-zone-active-hovered .ta-modal-dropzone{position:absolute;top:0;border:4px dashed #dadada;background-color:#eee}.modal-container .drop-zone-active-hovered .ta-modal-dropzone .ta-modal-dropzone-label{background-color:#eee}.modal-container .drop-zone-active-hovered .ta-modal-dropzone .ta-modal-dropzone-text{color:#6c6c6c}.modal-container .drop-zone-active .ta-modal-dropzone-area{transform:scale(2)}.modal-container .drop-zone-active .ta-modal-dropzone-text{position:absolute!important;top:84%!important;text-align:center;left:50%!important;transform:translate(-50%,-50%)}.modal-container.modal-container-load{width:1280px;display:flex}.modal-container.modal-container-load .divider{width:615px}.modal-container.modal-container-load .modal-additional-part{width:640px}.modal-container.modal-container-load .modal-additional-part-load{background-color:#f7f7f7;height:650px}.modal-container.modal-container-load .modal-additional-part-load .divider{background-color:#dadada;height:1px}.modal-container.modal-container-load .modal-additional-part-load-modal{max-width:640px;width:calc(100vw - 640px)}.modal-container .load-modal-origin-part{width:640px!important}.modal-container.modal-container-XS{width:390px}.modal-container.modal-container-XS .divider{width:366px}.modal-container.modal-container-XS .confirmation-modal-body{padding:22px 6px}.modal-container.modal-container-S{width:366px}.modal-container.modal-container-S .divider{width:341px}.modal-container.modal-container-M{width:640px}.modal-container.modal-container-M .divider{height:1px;background-color:#dadada;width:616px;margin:0 auto}.modal-container.modal-container-L{width:710px}.modal-container.modal-container-L .divider{width:685px}.modal-container.modal-container-XL{width:860px}.modal-container.modal-container-XL .divider{width:836px}.modal-container.modal-container-XL-2{width:800px;overflow:visible!important}.modal-container.modal-container-XL-2 .divider{width:775px}.modal-container .divider-bottom{margin-bottom:12px!important}.modal-container .card-divider{background-color:#dadada!important;height:1px!important}.modal-container.modal-container-sph-applicant{width:940px;height:960px;overflow-y:scroll;scrollbar-width:none!important}.modal-container.modal-container-sph-applicant::-webkit-scrollbar{width:2px}.modal-container.modal-container-sph-applicant::-webkit-scrollbar-thumb{background-color:transparent;border:6px solid transparent;border-radius:1px}.modal-container.modal-container-sph-applicant::-webkit-scrollbar-track{padding:0;position:relative;right:0;top:0;background:transparent}.modal-container.modal-container-sph-applicant .divider{display:none}.modal-container .divider{width:455px;height:2px;content:\"\";border-radius:1px;background-color:#f3f3f3;margin:0 auto}.modal-container .modal-spinner{position:absolute;bottom:7px;right:8px}.modal-container .form-container .row>*:nth-child(odd){padding-left:12px;padding-right:12px}.modal-container .form-container .row>*:nth-child(2n){padding-left:0;padding-right:12px}.modal-container .not-clickable{pointer-events:none;cursor:not-allowed;background:#f7f7f7!important;color:#ccc!important}.modal-container .modal-footer>*{margin:0!important}.modal-container .modal-footer .ta-modal-footer-right-side,.modal-container .modal-footer .ta-modal-footer-left-side{gap:12px;padding-left:1px}\n"] }]
49
55
  }], propDecorators: { customClass: [{
50
56
  type: Input
51
57
  }], partClass: [{
@@ -61,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
61
67
  }], additionalPartTemplate: [{
62
68
  type: Input
63
69
  }] } });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2EtbW9kYWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtbW9kYWwvY2EtbW9kYWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtbW9kYWwvY2EtbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLE9BQU8sRUFDUCxLQUFLLEVBQ0wsS0FBSyxFQUNMLFVBQVUsRUFDVixPQUFPLEdBQ1IsTUFBTSxxQkFBcUIsQ0FBQztBQUM3QixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFlLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7Ozs7QUFnQ3hELE1BQU0sT0FBTyxnQkFBZ0I7SUE5QjdCO1FBK0JXLGdCQUFXLEdBQVcsRUFBRSxDQUFDO1FBQ3pCLGNBQVMsR0FBVyxFQUFFLENBQUM7UUFDdkIsZUFBVSxHQUFXLEVBQUUsQ0FBQztLQU9sQzsrR0FWWSxnQkFBZ0I7bUdBQWhCLGdCQUFnQiw0VUM1QzdCLHdrQ0FpQ00sdzdJRGJGLFlBQVkscU1BQ1osV0FBVyw4QkFDWCxjQUFjLCtsQkFDZCxvQkFBb0IsOEJBQ3BCLFNBQVMsaUJBRUM7WUFDVixPQUFPLENBQUMsV0FBVyxFQUFFO2dCQUNuQixLQUFLLENBQ0gsUUFBUSxFQUNSLEtBQUssQ0FBQztvQkFDSixTQUFTLEVBQUUsVUFBVTtpQkFDdEIsQ0FBQyxDQUNIO2dCQUNELEtBQUssQ0FDSCxNQUFNLEVBQ04sS0FBSyxDQUFDO29CQUNKLFNBQVMsRUFBRSxVQUFVO2lCQUN0QixDQUFDLENBQ0g7Z0JBQ0QsVUFBVSxDQUFDLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUMzQyxDQUFDO1NBQ0g7OzRGQUVVLGdCQUFnQjtrQkE5QjVCLFNBQVM7aUNBQ0ksSUFBSSxZQUNOLGNBQWMsV0FHZjt3QkFDUCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsY0FBYzt3QkFDZCxvQkFBb0I7d0JBQ3BCLFNBQVM7cUJBQ1YsY0FDVzt3QkFDVixPQUFPLENBQUMsV0FBVyxFQUFFOzRCQUNuQixLQUFLLENBQ0gsUUFBUSxFQUNSLEtBQUssQ0FBQztnQ0FDSixTQUFTLEVBQUUsVUFBVTs2QkFDdEIsQ0FBQyxDQUNIOzRCQUNELEtBQUssQ0FDSCxNQUFNLEVBQ04sS0FBSyxDQUFDO2dDQUNKLFNBQVMsRUFBRSxVQUFVOzZCQUN0QixDQUFDLENBQ0g7NEJBQ0QsVUFBVSxDQUFDLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQzt5QkFDM0MsQ0FBQztxQkFDSDs4QkFHUSxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFFRyxrQkFBa0I7c0JBQTFCLEtBQUs7Z0JBQ0csbUJBQW1CO3NCQUEzQixLQUFLO2dCQUNHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBQ0csc0JBQXNCO3NCQUE5QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgYW5pbWF0ZSxcbiAgc3RhdGUsXG4gIHN0eWxlLFxuICB0cmFuc2l0aW9uLFxuICB0cmlnZ2VyLFxufSBmcm9tICdAYW5ndWxhci9hbmltYXRpb25zJztcbmltcG9ydCB7IERyYWdEcm9wTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2RyYWctZHJvcCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTmdiTW9kdWxlIH0gZnJvbSAnQG5nLWJvb3RzdHJhcC9uZy1ib290c3RyYXAnO1xuaW1wb3J0IHsgQW5ndWxhclN2Z0ljb25Nb2R1bGUgfSBmcm9tICdhbmd1bGFyLXN2Zy1pY29uJztcblxuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnYXBwLWNhLW1vZGFsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NhLW1vZGFsLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY2EtbW9kYWwuY29tcG9uZW50LnNjc3MnXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBEcmFnRHJvcE1vZHVsZSxcbiAgICBBbmd1bGFyU3ZnSWNvbk1vZHVsZSxcbiAgICBOZ2JNb2R1bGUsXG4gIF0sXG4gIGFuaW1hdGlvbnM6IFtcbiAgICB0cmlnZ2VyKCd3aWR0aEdyb3cnLCBbXG4gICAgICBzdGF0ZShcbiAgICAgICAgJ2Nsb3NlZCcsXG4gICAgICAgIHN0eWxlKHtcbiAgICAgICAgICB0cmFuc2Zvcm06ICdzY2FsZSgwKScsXG4gICAgICAgIH0pXG4gICAgICApLFxuICAgICAgc3RhdGUoXG4gICAgICAgICdvcGVuJyxcbiAgICAgICAgc3R5bGUoe1xuICAgICAgICAgIHRyYW5zZm9ybTogJ3NjYWxlKDEpJyxcbiAgICAgICAgfSlcbiAgICAgICksXG4gICAgICB0cmFuc2l0aW9uKCdjbG9zZWQgPT4gb3BlbicsIGFuaW1hdGUoMTAwKSksXG4gICAgXSksXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIENhTW9kYWxDb21wb25lbnQge1xuICBASW5wdXQoKSBjdXN0b21DbGFzczogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIHBhcnRDbGFzczogc3RyaW5nID0gJyc7XG4gIEBJbnB1dCgpIG1vZGFsVGl0bGU6IHN0cmluZyA9ICcnO1xuXG4gIEBJbnB1dCgpIGxlZnRIZWFkZXJUZW1wbGF0ZSE6IFRlbXBsYXRlUmVmPG51bGw+O1xuICBASW5wdXQoKSByaWdodEhlYWRlclRlbXBsYXRlITogVGVtcGxhdGVSZWY8bnVsbD47XG4gIEBJbnB1dCgpIGZvb3RlclRlbXBsYXRlITogVGVtcGxhdGVSZWY8bnVsbD47XG4gIEBJbnB1dCgpIGFkZGl0aW9uYWxQYXJ0VGVtcGxhdGUhOiBUZW1wbGF0ZVJlZjxudWxsPjtcbiAgXG59XG4iLCI8ZGl2IGNka0RyYWcgY2xhc3M9XCJtb2RhbC1jb250YWluZXIge3sgY3VzdG9tQ2xhc3MgfX1cIiBuZ0JBdXRvZm9jdXM+XG4gIDxkaXYgY2xhc3M9XCJtb2RhbC1vcmlnaW5hbC1wYXJ0IHt7IHBhcnRDbGFzcyB9fVwiPlxuICAgIDxkaXYgY2RrRHJhZ0hhbmRsZSBjbGFzcz1cIm1vZGFsLWhlYWRlciBkLWZsZXgganVzdGlmeS1jb250ZW50LWJldHdlZW5cIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJtb2RhbC1oZWFkZXItbGVmdHNpZGVcIj5cbiAgICAgICAgPCEtLSBIZWFkZXIgdGl0bGUgLS0+XG5cbiAgICAgICAgIDxoNSBjbGFzcz1cIm1vZGFsLXRpdGxlXCI+e3sgbW9kYWxUaXRsZSB9fTwvaDU+XG4gICAgICAgIDwhLS0gSGFlZGVyIGxlZnQgc2lkZSB0ZW1wbGF0ZSAtLT5cblxuICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImxlZnRIZWFkZXJUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2IGNsYXNzPVwibW9kYWwtaGVhZGVyLXJpZ2h0c2lkZVwiPlxuICAgICAgICA8IS0tIEhhZWRlciByaWdodCBzaWRlIC0tPlxuXG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJyaWdodEhlYWRlclRlbXBsYXRlXCI+PC9uZy1jb250YWluZXI+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cblxuICAgIDxkaXYgY2xhc3M9XCJtb2RhbC1ib2R5XCI+XG4gICAgICA8IS0tIE1vZGFsIGNvbnRlbnQgLS0+XG5cbiAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIltvcmlnaW5dXCI+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuICAgIDwhLS0gRm9vdGVyIFRlbXBsYXRlIENvbnRlbnQgLS0+XG5cbiAgICA8ZGl2IGNka0RyYWdIYW5kbGU+XG4gICAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiZm9vdGVyVGVtcGxhdGVcIj48L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbiAgICBcbiAgPC9kaXY+XG4gIDwhLS0gQWRkaXRpb25hbCBQYXJ0IENvbnRlbnQgLS0+XG5cbiAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cImFkZGl0aW9uYWxQYXJ0VGVtcGxhdGVcIj48L25nLWNvbnRhaW5lcj5cbjwvZGl2PiJdfQ==
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2EtbW9kYWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtbW9kYWwvY2EtbW9kYWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtbW9kYWwvY2EtbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILE9BQU8sRUFDUCxLQUFLLEVBQ0wsS0FBSyxFQUNMLFVBQVUsRUFDVixPQUFPLEdBQ1YsTUFBTSxxQkFBcUIsQ0FBQztBQUM3QixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFlLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFeEQsYUFBYTtBQUNiLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHNEQUFzRCxDQUFDOzs7O0FBbUNsRyxNQUFNLE9BQU8sZ0JBQWdCO0lBakM3QjtRQWtDYSxnQkFBVyxHQUFXLEVBQUUsQ0FBQztRQUN6QixjQUFTLEdBQVcsRUFBRSxDQUFDO1FBQ3ZCLGVBQVUsR0FBVyxFQUFFLENBQUM7S0FNcEM7K0dBVFksZ0JBQWdCO21HQUFoQixnQkFBZ0IsNFVDbEQ3QixtbURBK0NBLHc3SUR4QlEsWUFBWSxxTUFDWixXQUFXLDhCQUNYLGNBQWMsK2xCQUNkLG9CQUFvQiw4QkFDcEIsU0FBUztnQkFFVCxhQUFhO2dCQUNiLDBCQUEwQix3SUFFbEI7WUFDUixPQUFPLENBQUMsV0FBVyxFQUFFO2dCQUNqQixLQUFLLENBQ0QsUUFBUSxFQUNSLEtBQUssQ0FBQztvQkFDRixTQUFTLEVBQUUsVUFBVTtpQkFDeEIsQ0FBQyxDQUNMO2dCQUNELEtBQUssQ0FDRCxNQUFNLEVBQ04sS0FBSyxDQUFDO29CQUNGLFNBQVMsRUFBRSxVQUFVO2lCQUN4QixDQUFDLENBQ0w7Z0JBQ0QsVUFBVSxDQUFDLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUM3QyxDQUFDO1NBQ0w7OzRGQUVRLGdCQUFnQjtrQkFqQzVCLFNBQVM7aUNBQ00sSUFBSSxZQUNOLGNBQWMsV0FHZjt3QkFDTCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsY0FBYzt3QkFDZCxvQkFBb0I7d0JBQ3BCLFNBQVM7d0JBRVQsYUFBYTt3QkFDYiwwQkFBMEI7cUJBQzdCLGNBQ1c7d0JBQ1IsT0FBTyxDQUFDLFdBQVcsRUFBRTs0QkFDakIsS0FBSyxDQUNELFFBQVEsRUFDUixLQUFLLENBQUM7Z0NBQ0YsU0FBUyxFQUFFLFVBQVU7NkJBQ3hCLENBQUMsQ0FDTDs0QkFDRCxLQUFLLENBQ0QsTUFBTSxFQUNOLEtBQUssQ0FBQztnQ0FDRixTQUFTLEVBQUUsVUFBVTs2QkFDeEIsQ0FBQyxDQUNMOzRCQUNELFVBQVUsQ0FBQyxnQkFBZ0IsRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7eUJBQzdDLENBQUM7cUJBQ0w7OEJBR1EsV0FBVztzQkFBbkIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBRUcsa0JBQWtCO3NCQUExQixLQUFLO2dCQUNHLG1CQUFtQjtzQkFBM0IsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLHNCQUFzQjtzQkFBOUIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgYW5pbWF0ZSxcbiAgICBzdGF0ZSxcbiAgICBzdHlsZSxcbiAgICB0cmFuc2l0aW9uLFxuICAgIHRyaWdnZXIsXG59IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgRHJhZ0Ryb3BNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBOZ2JNb2R1bGUgfSBmcm9tICdAbmctYm9vdHN0cmFwL25nLWJvb3RzdHJhcCc7XG5pbXBvcnQgeyBBbmd1bGFyU3ZnSWNvbk1vZHVsZSB9IGZyb20gJ2FuZ3VsYXItc3ZnLWljb24nO1xuXG4vLyBjb21wb25lbnRzXG5pbXBvcnQgeyBDYUN1c3RvbVNjcm9sbGJhckNvbXBvbmVudCB9IGZyb20gJy4uL2NhLWN1c3RvbS1zY3JvbGxiYXIvY2EtY3VzdG9tLXNjcm9sbGJhci5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAnYXBwLWNhLW1vZGFsJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2EtbW9kYWwuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2NhLW1vZGFsLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIEZvcm1zTW9kdWxlLFxuICAgICAgICBEcmFnRHJvcE1vZHVsZSxcbiAgICAgICAgQW5ndWxhclN2Z0ljb25Nb2R1bGUsXG4gICAgICAgIE5nYk1vZHVsZSxcblxuICAgICAgICAvLyBjb21wb25lbnRzXG4gICAgICAgIENhQ3VzdG9tU2Nyb2xsYmFyQ29tcG9uZW50LFxuICAgIF0sXG4gICAgYW5pbWF0aW9uczogW1xuICAgICAgICB0cmlnZ2VyKCd3aWR0aEdyb3cnLCBbXG4gICAgICAgICAgICBzdGF0ZShcbiAgICAgICAgICAgICAgICAnY2xvc2VkJyxcbiAgICAgICAgICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgICAgICAgICAgIHRyYW5zZm9ybTogJ3NjYWxlKDApJyxcbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgKSxcbiAgICAgICAgICAgIHN0YXRlKFxuICAgICAgICAgICAgICAgICdvcGVuJyxcbiAgICAgICAgICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgICAgICAgICAgIHRyYW5zZm9ybTogJ3NjYWxlKDEpJyxcbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgKSxcbiAgICAgICAgICAgIHRyYW5zaXRpb24oJ2Nsb3NlZCA9PiBvcGVuJywgYW5pbWF0ZSgxMDApKSxcbiAgICAgICAgXSksXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2FNb2RhbENvbXBvbmVudCB7XG4gICAgQElucHV0KCkgY3VzdG9tQ2xhc3M6IHN0cmluZyA9ICcnO1xuICAgIEBJbnB1dCgpIHBhcnRDbGFzczogc3RyaW5nID0gJyc7XG4gICAgQElucHV0KCkgbW9kYWxUaXRsZTogc3RyaW5nID0gJyc7XG5cbiAgICBASW5wdXQoKSBsZWZ0SGVhZGVyVGVtcGxhdGUhOiBUZW1wbGF0ZVJlZjxudWxsPjtcbiAgICBASW5wdXQoKSByaWdodEhlYWRlclRlbXBsYXRlITogVGVtcGxhdGVSZWY8bnVsbD47XG4gICAgQElucHV0KCkgZm9vdGVyVGVtcGxhdGUhOiBUZW1wbGF0ZVJlZjxudWxsPjtcbiAgICBASW5wdXQoKSBhZGRpdGlvbmFsUGFydFRlbXBsYXRlITogVGVtcGxhdGVSZWY8bnVsbD47XG59XG4iLCI8YXBwLWNhLWN1c3RvbS1zY3JvbGxiYXJcbiAgICBbc2Nyb2xsQmFyT3B0aW9uc109XCJ7XG4gICAgICAgIHNob3dWZXJ0aWNhbFNjcm9sbEJhcjogdHJ1ZSxcbiAgICAgICAgc2hvd0hvcml6b250YWxTY3JvbGxCYXI6IGZhbHNlLFxuICAgIH1cIlxuPlxuICAgIDxkaXYgY2RrRHJhZyBjbGFzcz1cIm1vZGFsLWNvbnRhaW5lciB7eyBjdXN0b21DbGFzcyB9fVwiIG5nQkF1dG9mb2N1cz5cbiAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLW9yaWdpbmFsLXBhcnQge3sgcGFydENsYXNzIH19XCI+XG4gICAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICAgICAgY2RrRHJhZ0hhbmRsZVxuICAgICAgICAgICAgICAgIGNsYXNzPVwibW9kYWwtaGVhZGVyIGQtZmxleCBqdXN0aWZ5LWNvbnRlbnQtYmV0d2VlblwiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWhlYWRlci1sZWZ0c2lkZVwiPlxuICAgICAgICAgICAgICAgICAgICA8IS0tIEhlYWRlciB0aXRsZSAtLT5cblxuICAgICAgICAgICAgICAgICAgICA8aDUgY2xhc3M9XCJtb2RhbC10aXRsZVwiPnt7IG1vZGFsVGl0bGUgfX08L2g1PlxuICAgICAgICAgICAgICAgICAgICA8IS0tIEhhZWRlciBsZWZ0IHNpZGUgdGVtcGxhdGUgLS0+XG5cbiAgICAgICAgICAgICAgICAgICAgPG5nLWNvbnRhaW5lclxuICAgICAgICAgICAgICAgICAgICAgICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJsZWZ0SGVhZGVyVGVtcGxhdGVcIlxuICAgICAgICAgICAgICAgICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWhlYWRlci1yaWdodHNpZGVcIj5cbiAgICAgICAgICAgICAgICAgICAgPCEtLSBIYWVkZXIgcmlnaHQgc2lkZSAtLT5cblxuICAgICAgICAgICAgICAgICAgICA8bmctY29udGFpbmVyXG4gICAgICAgICAgICAgICAgICAgICAgICAqbmdUZW1wbGF0ZU91dGxldD1cInJpZ2h0SGVhZGVyVGVtcGxhdGVcIlxuICAgICAgICAgICAgICAgICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cblxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWJvZHlcIj5cbiAgICAgICAgICAgICAgICA8IS0tIE1vZGFsIGNvbnRlbnQgLS0+XG5cbiAgICAgICAgICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbb3JpZ2luXVwiPjwvbmctY29udGVudD5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPCEtLSBGb290ZXIgVGVtcGxhdGUgQ29udGVudCAtLT5cblxuICAgICAgICAgICAgPGRpdiBjZGtEcmFnSGFuZGxlPlxuICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJmb290ZXJUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8IS0tIEFkZGl0aW9uYWwgUGFydCBDb250ZW50IC0tPlxuXG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJhZGRpdGlvbmFsUGFydFRlbXBsYXRlXCI+PC9uZy1jb250YWluZXI+XG4gICAgPC9kaXY+XG48L2FwcC1jYS1jdXN0b20tc2Nyb2xsYmFyPlxuIl19