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 +1 -1
- package/esm2022/lib/components/ca-custom-scrollbar/ca-custom-scrollbar.component.mjs +205 -0
- package/esm2022/lib/components/ca-modal/ca-modal.component.mjs +9 -3
- package/esm2022/lib/components/ca-modal-button/ca-modal-button.component.mjs +5 -5
- package/esm2022/lib/components/ca-modal-button/enums/modal-button-size.enum.mjs +1 -1
- package/esm2022/lib/components/ca-modal-button/enums/modal-button-type.enum.mjs +1 -4
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/ca-components.mjs +210 -10
- package/fesm2022/ca-components.mjs.map +1 -1
- package/lib/components/ca-custom-scrollbar/ca-custom-scrollbar.component.d.ts +44 -0
- package/lib/components/ca-filters/ca-filter.component.d.ts +2 -2
- package/lib/components/ca-modal-button/ca-modal-button.component.d.ts +2 -2
- package/lib/components/ca-modal-button/enums/modal-button-type.enum.d.ts +0 -3
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
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
|
|
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
|
|
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,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2EtbW9kYWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtbW9kYWwvY2EtbW9kYWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtbW9kYWwvY2EtbW9kYWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILE9BQU8sRUFDUCxLQUFLLEVBQ0wsS0FBSyxFQUNMLFVBQVUsRUFDVixPQUFPLEdBQ1YsTUFBTSxxQkFBcUIsQ0FBQztBQUM3QixPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDeEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFlLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdkQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFeEQsYUFBYTtBQUNiLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHNEQUFzRCxDQUFDOzs7O0FBbUNsRyxNQUFNLE9BQU8sZ0JBQWdCO0lBakM3QjtRQWtDYSxnQkFBVyxHQUFXLEVBQUUsQ0FBQztRQUN6QixjQUFTLEdBQVcsRUFBRSxDQUFDO1FBQ3ZCLGVBQVUsR0FBVyxFQUFFLENBQUM7S0FNcEM7K0dBVFksZ0JBQWdCO21HQUFoQixnQkFBZ0IsNFVDbEQ3QixtbURBK0NBLHc3SUR4QlEsWUFBWSxxTUFDWixXQUFXLDhCQUNYLGNBQWMsK2xCQUNkLG9CQUFvQiw4QkFDcEIsU0FBUztnQkFFVCxhQUFhO2dCQUNiLDBCQUEwQix3SUFFbEI7WUFDUixPQUFPLENBQUMsV0FBVyxFQUFFO2dCQUNqQixLQUFLLENBQ0QsUUFBUSxFQUNSLEtBQUssQ0FBQztvQkFDRixTQUFTLEVBQUUsVUFBVTtpQkFDeEIsQ0FBQyxDQUNMO2dCQUNELEtBQUssQ0FDRCxNQUFNLEVBQ04sS0FBSyxDQUFDO29CQUNGLFNBQVMsRUFBRSxVQUFVO2lCQUN4QixDQUFDLENBQ0w7Z0JBQ0QsVUFBVSxDQUFDLGdCQUFnQixFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUM3QyxDQUFDO1NBQ0w7OzRGQUVRLGdCQUFnQjtrQkFqQzVCLFNBQVM7aUNBQ00sSUFBSSxZQUNOLGNBQWMsV0FHZjt3QkFDTCxZQUFZO3dCQUNaLFdBQVc7d0JBQ1gsY0FBYzt3QkFDZCxvQkFBb0I7d0JBQ3BCLFNBQVM7d0JBRVQsYUFBYTt3QkFDYiwwQkFBMEI7cUJBQzdCLGNBQ1c7d0JBQ1IsT0FBTyxDQUFDLFdBQVcsRUFBRTs0QkFDakIsS0FBSyxDQUNELFFBQVEsRUFDUixLQUFLLENBQUM7Z0NBQ0YsU0FBUyxFQUFFLFVBQVU7NkJBQ3hCLENBQUMsQ0FDTDs0QkFDRCxLQUFLLENBQ0QsTUFBTSxFQUNOLEtBQUssQ0FBQztnQ0FDRixTQUFTLEVBQUUsVUFBVTs2QkFDeEIsQ0FBQyxDQUNMOzRCQUNELFVBQVUsQ0FBQyxnQkFBZ0IsRUFBRSxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7eUJBQzdDLENBQUM7cUJBQ0w7OEJBR1EsV0FBVztzQkFBbkIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBRUcsa0JBQWtCO3NCQUExQixLQUFLO2dCQUNHLG1CQUFtQjtzQkFBM0IsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLHNCQUFzQjtzQkFBOUIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgYW5pbWF0ZSxcbiAgICBzdGF0ZSxcbiAgICBzdHlsZSxcbiAgICB0cmFuc2l0aW9uLFxuICAgIHRyaWdnZXIsXG59IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgRHJhZ0Ryb3BNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBOZ2JNb2R1bGUgfSBmcm9tICdAbmctYm9vdHN0cmFwL25nLWJvb3RzdHJhcCc7XG5pbXBvcnQgeyBBbmd1bGFyU3ZnSWNvbk1vZHVsZSB9IGZyb20gJ2FuZ3VsYXItc3ZnLWljb24nO1xuXG4vLyBjb21wb25lbnRzXG5pbXBvcnQgeyBDYUN1c3RvbVNjcm9sbGJhckNvbXBvbmVudCB9IGZyb20gJy4uL2NhLWN1c3RvbS1zY3JvbGxiYXIvY2EtY3VzdG9tLXNjcm9sbGJhci5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAnYXBwLWNhLW1vZGFsJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2EtbW9kYWwuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2NhLW1vZGFsLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIEZvcm1zTW9kdWxlLFxuICAgICAgICBEcmFnRHJvcE1vZHVsZSxcbiAgICAgICAgQW5ndWxhclN2Z0ljb25Nb2R1bGUsXG4gICAgICAgIE5nYk1vZHVsZSxcblxuICAgICAgICAvLyBjb21wb25lbnRzXG4gICAgICAgIENhQ3VzdG9tU2Nyb2xsYmFyQ29tcG9uZW50LFxuICAgIF0sXG4gICAgYW5pbWF0aW9uczogW1xuICAgICAgICB0cmlnZ2VyKCd3aWR0aEdyb3cnLCBbXG4gICAgICAgICAgICBzdGF0ZShcbiAgICAgICAgICAgICAgICAnY2xvc2VkJyxcbiAgICAgICAgICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgICAgICAgICAgIHRyYW5zZm9ybTogJ3NjYWxlKDApJyxcbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgKSxcbiAgICAgICAgICAgIHN0YXRlKFxuICAgICAgICAgICAgICAgICdvcGVuJyxcbiAgICAgICAgICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgICAgICAgICAgIHRyYW5zZm9ybTogJ3NjYWxlKDEpJyxcbiAgICAgICAgICAgICAgICB9KVxuICAgICAgICAgICAgKSxcbiAgICAgICAgICAgIHRyYW5zaXRpb24oJ2Nsb3NlZCA9PiBvcGVuJywgYW5pbWF0ZSgxMDApKSxcbiAgICAgICAgXSksXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2FNb2RhbENvbXBvbmVudCB7XG4gICAgQElucHV0KCkgY3VzdG9tQ2xhc3M6IHN0cmluZyA9ICcnO1xuICAgIEBJbnB1dCgpIHBhcnRDbGFzczogc3RyaW5nID0gJyc7XG4gICAgQElucHV0KCkgbW9kYWxUaXRsZTogc3RyaW5nID0gJyc7XG5cbiAgICBASW5wdXQoKSBsZWZ0SGVhZGVyVGVtcGxhdGUhOiBUZW1wbGF0ZVJlZjxudWxsPjtcbiAgICBASW5wdXQoKSByaWdodEhlYWRlclRlbXBsYXRlITogVGVtcGxhdGVSZWY8bnVsbD47XG4gICAgQElucHV0KCkgZm9vdGVyVGVtcGxhdGUhOiBUZW1wbGF0ZVJlZjxudWxsPjtcbiAgICBASW5wdXQoKSBhZGRpdGlvbmFsUGFydFRlbXBsYXRlITogVGVtcGxhdGVSZWY8bnVsbD47XG59XG4iLCI8YXBwLWNhLWN1c3RvbS1zY3JvbGxiYXJcbiAgICBbc2Nyb2xsQmFyT3B0aW9uc109XCJ7XG4gICAgICAgIHNob3dWZXJ0aWNhbFNjcm9sbEJhcjogdHJ1ZSxcbiAgICAgICAgc2hvd0hvcml6b250YWxTY3JvbGxCYXI6IGZhbHNlLFxuICAgIH1cIlxuPlxuICAgIDxkaXYgY2RrRHJhZyBjbGFzcz1cIm1vZGFsLWNvbnRhaW5lciB7eyBjdXN0b21DbGFzcyB9fVwiIG5nQkF1dG9mb2N1cz5cbiAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLW9yaWdpbmFsLXBhcnQge3sgcGFydENsYXNzIH19XCI+XG4gICAgICAgICAgICA8ZGl2XG4gICAgICAgICAgICAgICAgY2RrRHJhZ0hhbmRsZVxuICAgICAgICAgICAgICAgIGNsYXNzPVwibW9kYWwtaGVhZGVyIGQtZmxleCBqdXN0aWZ5LWNvbnRlbnQtYmV0d2VlblwiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWhlYWRlci1sZWZ0c2lkZVwiPlxuICAgICAgICAgICAgICAgICAgICA8IS0tIEhlYWRlciB0aXRsZSAtLT5cblxuICAgICAgICAgICAgICAgICAgICA8aDUgY2xhc3M9XCJtb2RhbC10aXRsZVwiPnt7IG1vZGFsVGl0bGUgfX08L2g1PlxuICAgICAgICAgICAgICAgICAgICA8IS0tIEhhZWRlciBsZWZ0IHNpZGUgdGVtcGxhdGUgLS0+XG5cbiAgICAgICAgICAgICAgICAgICAgPG5nLWNvbnRhaW5lclxuICAgICAgICAgICAgICAgICAgICAgICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJsZWZ0SGVhZGVyVGVtcGxhdGVcIlxuICAgICAgICAgICAgICAgICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWhlYWRlci1yaWdodHNpZGVcIj5cbiAgICAgICAgICAgICAgICAgICAgPCEtLSBIYWVkZXIgcmlnaHQgc2lkZSAtLT5cblxuICAgICAgICAgICAgICAgICAgICA8bmctY29udGFpbmVyXG4gICAgICAgICAgICAgICAgICAgICAgICAqbmdUZW1wbGF0ZU91dGxldD1cInJpZ2h0SGVhZGVyVGVtcGxhdGVcIlxuICAgICAgICAgICAgICAgICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8L2Rpdj5cblxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWJvZHlcIj5cbiAgICAgICAgICAgICAgICA8IS0tIE1vZGFsIGNvbnRlbnQgLS0+XG5cbiAgICAgICAgICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbb3JpZ2luXVwiPjwvbmctY29udGVudD5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPCEtLSBGb290ZXIgVGVtcGxhdGUgQ29udGVudCAtLT5cblxuICAgICAgICAgICAgPGRpdiBjZGtEcmFnSGFuZGxlPlxuICAgICAgICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJmb290ZXJUZW1wbGF0ZVwiPjwvbmctY29udGFpbmVyPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8IS0tIEFkZGl0aW9uYWwgUGFydCBDb250ZW50IC0tPlxuXG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJhZGRpdGlvbmFsUGFydFRlbXBsYXRlXCI+PC9uZy1jb250YWluZXI+XG4gICAgPC9kaXY+XG48L2FwcC1jYS1jdXN0b20tc2Nyb2xsYmFyPlxuIl19
|