ngx-histaff-alpha 0.2.5 → 0.2.8
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/esm2022/lib/app/libraries/animated-text/animated-text/animated-text.component.mjs +24 -22
- package/esm2022/lib/app/libraries/core-attachment/core-attachment/core-attachment.component.mjs +3 -1
- package/esm2022/lib/app/libraries/core-file-uploader/core-file-uploader/core-file-uploader.component.mjs +3 -1
- package/esm2022/lib/app/libraries/core-page-list/core-page-list.component.mjs +3 -1
- package/esm2022/lib/app/services/app.service.mjs +7 -2
- package/esm2022/lib/assets/js/coreFileUtils.mjs +27 -0
- package/fesm2022/ngx-histaff-alpha.mjs +60 -22
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/libraries/animated-text/animated-text/animated-text.component.d.ts +0 -1
- package/lib/assets/js/coreFileUtils.d.ts +2 -0
- package/package.json +1 -1
|
@@ -2,8 +2,6 @@ import { Component, ViewChild } from '@angular/core';
|
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "../animated-text.service";
|
|
5
|
-
const d3_select = d3.select;
|
|
6
|
-
const d3_shuffle = d3.shuffle;
|
|
7
5
|
export class AnimatedTextComponent {
|
|
8
6
|
constructor(animatedTextService) {
|
|
9
7
|
this.animatedTextService = animatedTextService;
|
|
@@ -21,12 +19,15 @@ export class AnimatedTextComponent {
|
|
|
21
19
|
}));
|
|
22
20
|
}
|
|
23
21
|
ngAfterViewInit() {
|
|
22
|
+
/*
|
|
24
23
|
this.svg = d3_select(this.letters.nativeElement).append('svg')
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
24
|
+
.attr('width', this.WIDTH)
|
|
25
|
+
.attr('height', this.HEIGHT)
|
|
26
|
+
.append('g')
|
|
27
|
+
.attr('transform', 'translate(0,' + (this.HEIGHT / 2) + ')');
|
|
28
|
+
|
|
29
29
|
this.loop();
|
|
30
|
+
*/
|
|
30
31
|
}
|
|
31
32
|
update(data) {
|
|
32
33
|
const text = this.svg.selectAll('text').data(data, (d) => d.index);
|
|
@@ -40,25 +41,26 @@ export class AnimatedTextComponent {
|
|
|
40
41
|
.transition().duration(1000)
|
|
41
42
|
.attr('x', (d, _) => this.LETTER_WIDTH * d.pos);
|
|
42
43
|
}
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
44
|
+
/*
|
|
45
|
+
loop(): void {
|
|
46
|
+
if (!!!this.allowLoop) return;
|
|
47
|
+
this.update(this.data);
|
|
48
|
+
setTimeout(() => {
|
|
49
|
+
this.data = d3_shuffle(this.data).map((d: ILetterItem, i: number) => {
|
|
50
|
+
d.pos = i;
|
|
51
|
+
return d;
|
|
52
|
+
});
|
|
46
53
|
this.update(this.data);
|
|
47
54
|
setTimeout(() => {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
setTimeout(() => {
|
|
54
|
-
this.data = this.data.map((d, _) => {
|
|
55
|
-
d.pos = d.index;
|
|
56
|
-
return d;
|
|
57
|
-
});
|
|
58
|
-
this.loop();
|
|
59
|
-
}, 2000);
|
|
55
|
+
this.data = this.data.map((d: ILetterItem, _: number) => {
|
|
56
|
+
d.pos = d.index;
|
|
57
|
+
return d;
|
|
58
|
+
});
|
|
59
|
+
this.loop();
|
|
60
60
|
}, 2000);
|
|
61
|
+
}, 2000);
|
|
61
62
|
}
|
|
63
|
+
*/
|
|
62
64
|
ngOnDestroy() {
|
|
63
65
|
this.allowLoop = false;
|
|
64
66
|
this.subscriptions.map(x => x?.unsubscribe());
|
|
@@ -73,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
73
75
|
type: ViewChild,
|
|
74
76
|
args: ['letters']
|
|
75
77
|
}] } });
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0ZWQtdGV4dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9saWJyYXJpZXMvYW5pbWF0ZWQtdGV4dC9hbmltYXRlZC10ZXh0L2FuaW1hdGVkLXRleHQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWhpc3RhZmYtYWxwaGEvc3JjL2xpYi9hcHAvbGlicmFyaWVzL2FuaW1hdGVkLXRleHQvYW5pbWF0ZWQtdGV4dC9hbmltYXRlZC10ZXh0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXlCLFNBQVMsRUFBeUIsTUFBTSxlQUFlLENBQUM7QUFHbkcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7QUFzQi9DLE1BQU0sT0FBTyxxQkFBcUI7SUFlaEMsWUFBb0IsbUJBQXdDO1FBQXhDLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7UUFYNUQsa0JBQWEsR0FBbUIsRUFBRSxDQUFDO1FBR25DLGNBQVMsR0FBWSxJQUFJLENBQUM7UUFFMUIsaUJBQVksR0FBVyxFQUFFLENBQUM7UUFFMUIsV0FBTSxHQUFXLEVBQUUsQ0FBQztJQUk0QyxDQUFDO0lBRWpFLFFBQVE7UUFFTixJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FDckIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDakQsTUFBTSxPQUFPLEdBQWtCLEVBQUUsQ0FBQztZQUNsQyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsRUFBRSxNQUFNLEVBQUUsQ0FBQyxFQUFFLEdBQUcsRUFBRSxDQUFDLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQTtZQUM5RSxJQUFJLENBQUMsSUFBSSxHQUFHLE9BQU8sQ0FBQztZQUNwQixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDcEQsQ0FBQyxDQUFDLENBQ0gsQ0FBQztJQUVKLENBQUM7SUFFRCxlQUFlO1FBQ2I7Ozs7Ozs7O1VBUUU7SUFDSixDQUFDO0lBRUQsTUFBTSxDQUFDLElBQW1CO1FBQ3hCLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFjLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNoRixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQzthQUN4QixJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBYyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBRSxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxTQUFTLENBQUM7YUFDNUYsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQWMsRUFBRSxDQUFTLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxZQUFZLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQzthQUNuRSxLQUFLLENBQUMsV0FBVyxFQUFFLE1BQU0sQ0FBQzthQUMxQixLQUFLLENBQUMsYUFBYSxFQUFFLFdBQVcsQ0FBQzthQUNqQyxJQUFJLENBQUMsQ0FBQyxDQUFjLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUM7YUFDbEMsS0FBSyxDQUFDLElBQUksQ0FBQzthQUNYLFVBQVUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUM7YUFDM0IsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQWMsRUFBRSxDQUFTLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxZQUFZLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3pFLENBQUM7SUFFRDs7Ozs7Ozs7Ozs7Ozs7Ozs7OztNQW1CRTtJQUVGLFdBQVc7UUFDVCxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztRQUN2QixJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDO0lBQ2hELENBQUM7OEdBL0VVLHFCQUFxQjtrR0FBckIscUJBQXFCLGlMQ3pCbEMsMEJBQ0EseUREb0JZLFlBQVk7OzJGQUlYLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDRSxtQkFBbUIsY0FDakIsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDO3dGQU1ELE9BQU87c0JBQTVCLFNBQVM7dUJBQUMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBBZnRlclZpZXdJbml0LCBWaWV3Q2hpbGQsIEVsZW1lbnRSZWYsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBbmltYXRlZFRleHRTZXJ2aWNlIH0gZnJvbSAnLi4vYW5pbWF0ZWQtdGV4dC5zZXJ2aWNlJztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG4vKlxyXG5pbXBvcnQgKiBhcyBkMyBmcm9tICcuLi8uLi8uLi8uLi9hc3NldHMvanMvZDMtdjctOC00L2Rpc3QvZDMnXHJcblxyXG5jb25zdCBkM19zZWxlY3QgPSBkMy5zZWxlY3Q7XHJcbmNvbnN0IGQzX3NodWZmbGUgPSBkMy5zaHVmZmxlO1xyXG4qL1xyXG5cclxuaW50ZXJmYWNlIElMZXR0ZXJJdGVtIHtcclxuICBsZXR0ZXI6IHN0cmluZztcclxuICBwb3M6IG51bWJlcjtcclxuICBpbmRleDogbnVtYmVyO1xyXG59XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1hbmltYXRlZC10ZXh0JyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9hbmltYXRlZC10ZXh0LmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9hbmltYXRlZC10ZXh0LmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIEFuaW1hdGVkVGV4dENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJWaWV3SW5pdCwgT25EZXN0cm95IHtcclxuXHJcbiAgQFZpZXdDaGlsZCgnbGV0dGVycycpIGxldHRlcnMhOiBFbGVtZW50UmVmO1xyXG5cclxuICBzdWJzY3JpcHRpb25zOiBTdWJzY3JpcHRpb25bXSA9IFtdO1xyXG5cclxuICBkYXRhITogSUxldHRlckl0ZW1bXTtcclxuICBhbGxvd0xvb3A6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICBMRVRURVJfV0lEVEg6IG51bWJlciA9IDIyO1xyXG4gIFdJRFRIITogbnVtYmVyO1xyXG4gIEhFSUdIVDogbnVtYmVyID0gODA7XHJcblxyXG4gIHN2ZyE6IGFueTtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhbmltYXRlZFRleHRTZXJ2aWNlOiBBbmltYXRlZFRleHRTZXJ2aWNlKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcblxyXG4gICAgdGhpcy5zdWJzY3JpcHRpb25zLnB1c2goXHJcbiAgICAgIHRoaXMuYW5pbWF0ZWRUZXh0U2VydmljZS50ZXh0JC5zdWJzY3JpYmUobmV3VGV4dCA9PiB7XHJcbiAgICAgICAgY29uc3QgbmV3RGF0YTogSUxldHRlckl0ZW1bXSA9IFtdO1xyXG4gICAgICAgIG5ld1RleHQuc3BsaXQoJycpLm1hcCgoeCwgaSkgPT4gbmV3RGF0YS5wdXNoKHsgbGV0dGVyOiB4LCBwb3M6IGksIGluZGV4OiBpIH0pKVxyXG4gICAgICAgIHRoaXMuZGF0YSA9IG5ld0RhdGE7XHJcbiAgICAgICAgdGhpcy5XSURUSCA9IHRoaXMuTEVUVEVSX1dJRFRIICogdGhpcy5kYXRhLmxlbmd0aDtcclxuICAgICAgfSlcclxuICAgICk7XHJcblxyXG4gIH1cclxuXHJcbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgLypcclxuICAgIHRoaXMuc3ZnID0gZDNfc2VsZWN0KHRoaXMubGV0dGVycy5uYXRpdmVFbGVtZW50KS5hcHBlbmQoJ3N2ZycpXHJcbiAgICAgIC5hdHRyKCd3aWR0aCcsIHRoaXMuV0lEVEgpXHJcbiAgICAgIC5hdHRyKCdoZWlnaHQnLCB0aGlzLkhFSUdIVClcclxuICAgICAgLmFwcGVuZCgnZycpXHJcbiAgICAgIC5hdHRyKCd0cmFuc2Zvcm0nLCAndHJhbnNsYXRlKDAsJyArICh0aGlzLkhFSUdIVCAvIDIpICsgJyknKTtcclxuXHJcbiAgICB0aGlzLmxvb3AoKTtcclxuICAgICovXHJcbiAgfVxyXG5cclxuICB1cGRhdGUoZGF0YTogSUxldHRlckl0ZW1bXSk6IHZvaWQge1xyXG4gICAgY29uc3QgdGV4dCA9IHRoaXMuc3ZnLnNlbGVjdEFsbCgndGV4dCcpLmRhdGEoZGF0YSwgKGQ6IElMZXR0ZXJJdGVtKSA9PiBkLmluZGV4KTtcclxuICAgIHRleHQuZW50ZXIoKS5hcHBlbmQoJ3RleHQnKVxyXG4gICAgICAuYXR0cignZmlsbCcsIChkOiBJTGV0dGVySXRlbSkgPT4gWychJywgJz8nLCAnLiddLmluY2x1ZGVzKGQubGV0dGVyKSAgPyAndG9tYXRvJyA6ICcjRkZGRkZGJylcclxuICAgICAgLmF0dHIoJ3gnLCAoZDogSUxldHRlckl0ZW0sIF86IG51bWJlcikgPT4gdGhpcy5MRVRURVJfV0lEVEggKiBkLnBvcylcclxuICAgICAgLnN0eWxlKCdmb250LXNpemUnLCAnNDBweCcpXHJcbiAgICAgIC5zdHlsZSgnZm9udC1mYW1pbHknLCAnbW9ub3NwYWNlJylcclxuICAgICAgLnRleHQoKGQ6IElMZXR0ZXJJdGVtKSA9PiBkLmxldHRlcilcclxuICAgICAgLm1lcmdlKHRleHQpXHJcbiAgICAgIC50cmFuc2l0aW9uKCkuZHVyYXRpb24oMTAwMClcclxuICAgICAgLmF0dHIoJ3gnLCAoZDogSUxldHRlckl0ZW0sIF86IG51bWJlcikgPT4gdGhpcy5MRVRURVJfV0lEVEggKiBkLnBvcyk7XHJcbiAgfVxyXG5cclxuICAvKlxyXG4gIGxvb3AoKTogdm9pZCB7XHJcbiAgICBpZiAoISEhdGhpcy5hbGxvd0xvb3ApIHJldHVybjtcclxuICAgIHRoaXMudXBkYXRlKHRoaXMuZGF0YSk7XHJcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgdGhpcy5kYXRhID0gZDNfc2h1ZmZsZSh0aGlzLmRhdGEpLm1hcCgoZDogSUxldHRlckl0ZW0sIGk6IG51bWJlcikgPT4ge1xyXG4gICAgICAgIGQucG9zID0gaTtcclxuICAgICAgICByZXR1cm4gZDtcclxuICAgICAgfSk7XHJcbiAgICAgIHRoaXMudXBkYXRlKHRoaXMuZGF0YSk7XHJcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xyXG4gICAgICAgIHRoaXMuZGF0YSA9IHRoaXMuZGF0YS5tYXAoKGQ6IElMZXR0ZXJJdGVtLCBfOiBudW1iZXIpID0+IHtcclxuICAgICAgICAgIGQucG9zID0gZC5pbmRleDtcclxuICAgICAgICAgIHJldHVybiBkO1xyXG4gICAgICAgIH0pO1xyXG4gICAgICAgIHRoaXMubG9vcCgpO1xyXG4gICAgICB9LCAyMDAwKTtcclxuICAgIH0sIDIwMDApO1xyXG4gIH1cclxuICAqL1xyXG5cclxuICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgIHRoaXMuYWxsb3dMb29wID0gZmFsc2U7XHJcbiAgICB0aGlzLnN1YnNjcmlwdGlvbnMubWFwKHggPT4geD8udW5zdWJzY3JpYmUoKSk7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8ZGl2ICNsZXR0ZXJzPjwvZGl2PlxyXG4iXX0=
|
package/esm2022/lib/app/libraries/core-attachment/core-attachment/core-attachment.component.mjs
CHANGED
|
@@ -7,6 +7,8 @@ import { EnumTranslateKey } from "alpha-global-constants";
|
|
|
7
7
|
import { blob_to_base64_script } from '../../../../assets/js/blob2base64_wk';
|
|
8
8
|
import { TooltipDirective } from '../../tooltip/tooltip.directive';
|
|
9
9
|
import { CommonModule } from '@angular/common';
|
|
10
|
+
//declare let coreFileUtils: any;
|
|
11
|
+
import * as coreFileUtils from '../../../../assets/js/coreFileUtils';
|
|
10
12
|
import * as i0 from "@angular/core";
|
|
11
13
|
import * as i1 from "../../alert/alert.service";
|
|
12
14
|
import * as i2 from "../../../services/multi-language.service";
|
|
@@ -139,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
139
141
|
type: ViewChild,
|
|
140
142
|
args: ['rawInput']
|
|
141
143
|
}] } });
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-attachment.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-attachment/core-attachment/core-attachment.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-attachment/core-attachment/core-attachment.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAwB,KAAK,EAAoC,SAAS,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC/H,OAAO,EAAE,4BAA4B,EAAE,MAAM,+DAA+D,CAAC;AAC7G,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAI3E,OAAO,EAAE,YAAY,EAAE,0BAA0B,EAAE,MAAM,iCAAiC,CAAC;AAC3F,OAAO,EAAE,iBAAiB,EAAE,MAAM,sCAAsC,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;;;;AAG/C,MAAM,EAAE,YAAY,EAAE,GAAG,aAAa,CAAC;AA8BvC,MAAM,OAAO,uBAAwB,SAAQ,4BAA4B;IAS9D,UAAU,CAAC,GAA2B;QAC7C,IAAI,CAAC,WAAW,GAAG,GAAG,EAAE,cAAe,CAAA;IACzC,CAAC;IAQD,YACU,QAAkB,EAClB,YAA0B,EAC1B,GAAyB,EACzB,gBAAkC;QAE1C,KAAK,EAAE,CAAA;QALC,aAAQ,GAAR,QAAQ,CAAU;QAClB,iBAAY,GAAZ,YAAY,CAAc;QAC1B,QAAG,GAAH,GAAG,CAAsB;QACzB,qBAAgB,GAAhB,gBAAgB,CAAkB;IAG5C,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,aAAa,CAAC,EAAC;YACzB,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,aAAa,CAAC,EAAE,YAAY,CAAC;SACzD;IACH,CAAC;IAED,QAAQ;QACN,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,GAAG,CAAC,CAAC;QAErE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,SAAS,EAAE,EAAE;YACvD,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;;OAEvB,EAAE,0BAA0B,CAAC,CAAA;SAC/B;IACH,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC3C,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;IACrE,CAAC;IAED,eAAe;QACb,IAAI,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,GAAG,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,GAAG,eAAe,GAAG,IAAI,CAAC,WAAW,CAAA;QACzH,KAAK,CAAC,GAAG,CAAC;aACP,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;aACjC,IAAI,CAAC,IAAI,CAAC,EAAE;YACX,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YACzC,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YACtC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;YAC/C,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC,CAAC;aACD,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IAED,iBAAiB,CAAC,CAAM;QAEtB,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE;YAC3B,MAAM,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAE/B,IAAI,IAAI,CAAC,IAAI,GAAG,iBAAiB,CAAC,WAAW,EAAE;gBAC7C,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,gBAAgB,CAAC,qDAAqD,CAAC,KAAK,iBAAiB,CAAC,WAAW,SAAS,EAAE,YAAY,CAAC,CAAC;gBAC5K,OAAO;aACR;YAED,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;YACzB,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAA;YAChC,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAA;YAChC,IAAI,cAAc,GAAG,EAAE,CAAA;YAEvB,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YAC9B,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;gBACjC,IAAI,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC,qBAAqB,CAAC,CAAA;gBAC/C,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC,CAAC,EAAE;oBAE1C,OAAO,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAA;oBAChC,cAAc,GAAG,CAAC,CAAC,IAAI,CAAA;oBACvB,MAAM,KAAK,GAAI,cAAyB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;oBAC5D,IAAI,KAAK,IAAI,CAAC,EAAE;wBACd,cAAc,GAAI,cAAyB,CAAC,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;qBAClE;oBACD,IAAI,CAAC,QAAQ,CAAC;wBACZ,QAAQ,EAAE,IAAI,CAAC,QAAQ;wBACvB,cAAc,EAAE,IAAI,CAAC,KAAK,EAAE,cAAc;wBAC1C,cAAc;wBACd,cAAc;wBACd,cAAc;qBACf,CAAC,CAAC;oBACH,IAAI,CAAC,WAAW,GAAG,cAAc,CAAC;oBAClC,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,CAAC,CAAC,CAAA;gBACF,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;aAC/B;iBAAM;gBACL,YAAY,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,cAAmB,EAAE,EAAE;oBAC9C,MAAM,KAAK,GAAI,cAAyB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;oBAC5D,IAAI,KAAK,IAAI,CAAC,EAAE;wBACd,cAAc,GAAI,cAAyB,CAAC,SAAS,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;qBAClE;oBACD,IAAI,CAAC,QAAQ,CAAC;wBACZ,QAAQ,EAAE,IAAI,CAAC,QAAQ;wBACvB,cAAc,EAAE,IAAI,CAAC,KAAK,EAAE,cAAc;wBAC1C,cAAc;wBACd,cAAc;wBACd,cAAc;qBACf,CAAC,CAAC;oBACH,IAAI,CAAC,WAAW,GAAG,cAAc,CAAC;oBAClC,IAAI,CAAC,aAAa,EAAE,CAAC;gBACvB,CAAC,CAAC,CAAC;aACJ;SACF;IACH,CAAC;8GArHU,uBAAuB;kGAAvB,uBAAuB,kJARvB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,KAAK,EAAE,IAAI;gBACX,WAAW,EAAE,uBAAuB;aACrC;SACF,4KC1CH,q3BAcM,+6CDgBF,YAAY,kIACZ,WAAW,+mBACX,gBAAgB;;2FAYP,uBAAuB;kBAlBnC,SAAS;+BACE,iBAAiB,cACf,IAAI,WACP;wBACP,YAAY;wBACZ,WAAW;wBACX,gBAAgB;qBACjB,aAGU;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,KAAK,EAAE,IAAI;4BACX,WAAW,yBAAyB;yBACrC;qBACF;0KAIiB,QAAQ;sBAAzB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAaiB,QAAQ;sBAA9B,SAAS;uBAAC,UAAU","sourcesContent":["import { Component, ElementRef, Injector, Input, OnChanges, OnInit, SimpleChanges, ViewChild, isDevMode } from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { FormsModule, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { AppConfigService } from '../../../services/app-config.service';\r\nimport { alertOptions, noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { attachmentOptions } from '../../../constants/attachmentOptions';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { blob_to_base64_script } from '../../../../assets/js/blob2base64_wk';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { CommonModule } from '@angular/common';\r\n\r\ndeclare let coreFileUtils: any;\r\nconst { blobToBase64 } = coreFileUtils; \r\n\r\n\r\n\r\nexport interface ICoreAttachment {\r\n  assignTo: string;\r\n  serverFileName?: string;\r\n  clientFileName: string;\r\n  clientFileType: string;\r\n  clientFileData: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-attachment',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    TooltipDirective,\r\n  ],\r\n  templateUrl: './core-attachment.component.html',\r\n  styleUrls: ['./core-attachment.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreAttachmentComponent\r\n    }\r\n  ]\r\n})\r\nexport class CoreAttachmentComponent extends CoreFormControlBaseComponent implements OnChanges, OnInit {\r\n\r\n  @Input() override readonly!: boolean;\r\n  @Input() assignTo!: string; // Required\r\n  @Input() valueToShow!: string;\r\n\r\n  override value!: ICoreAttachment | null;\r\n  override onChange!: (_: ICoreAttachment | null) => void;\r\n\r\n  override writeValue(obj: ICoreAttachment | null): void {\r\n    this.valueToShow = obj?.serverFileName!\r\n  }\r\n\r\n  ngControl!: NgControl;\r\n\r\n  worker!: Worker;\r\n\r\n  @ViewChild('rawInput') rawInput!: ElementRef;\r\n\r\n  constructor(\r\n    private injector: Injector,\r\n    private alertService: AlertService,\r\n    private mls: MultiLanguageService,\r\n    private appConfigService: AppConfigService,\r\n  ) {\r\n    super()\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['valueToShow']){\r\n      this.valueToShow = changes['valueToShow']?.currentValue;\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    setTimeout(() => this.ngControl = this.injector.get(NgControl), 200);\r\n    \r\n    if (!!!this.assignTo && !!!this.readonly && isDevMode()) {\r\n      this.alertService.error(`\r\n      CoreAttachmentComponent required input 'assignTo'\r\n      `, noneAutoClosedAlertOptions)\r\n    }\r\n  }\r\n\r\n  onClickUpload(): void {\r\n    if (this.disabled || this.readonly) return;\r\n    this.rawInput.nativeElement.dispatchEvent(new MouseEvent('click'));\r\n  }\r\n\r\n  onClickDownload(): void {\r\n    var uri = this.appConfigService.BASE_URL + '/' + this.appConfigService.STATIC_FOLDER + '/attachments/' + this.valueToShow\r\n    fetch(uri)\r\n      .then(response => response.blob())\r\n      .then(blob => {\r\n        const link = document.createElement(\"a\");\r\n        link.href = URL.createObjectURL(blob);\r\n        link.download = this.valueToShow.substring(52);\r\n        link.click();\r\n      })\r\n      .catch(console.error);\r\n  }\r\n\r\n  handleInputChange(e: any) {\r\n\r\n    if (!!e.target.files.length) {\r\n      const file = e.target.files[0];\r\n\r\n      if (file.size > attachmentOptions.maxFileSize) {\r\n        this.alertService.error(`${this.mls.trans(EnumTranslateKey.UI_CORE_ATTACHMENT_MAXIMUM_ATTACHMENT_FILE_SIZE_ERROR)} (${attachmentOptions.maxFileSize} bytes)`, alertOptions);\r\n        return;\r\n      }\r\n\r\n      console.log(\"file\", file)\r\n      const clientFileName = file.name\r\n      const clientFileType = file.type\r\n      let clientFileData = \"\"\r\n\r\n      const blob = new Blob([file]);\r\n      if (typeof Worker !== 'undefined') {\r\n        this.worker = new Worker(blob_to_base64_script)\r\n        this.worker.addEventListener(\"message\", e => {\r\n\r\n          console.log(\"worker message\", e)\r\n          clientFileData = e.data\r\n          const index = (clientFileData as string).indexOf('base64,');\r\n          if (index >= 0) {\r\n            clientFileData = (clientFileData as string).substring(index + 7);\r\n          }\r\n          this.onChange({\r\n            assignTo: this.assignTo,\r\n            serverFileName: this.value?.serverFileName,\r\n            clientFileName,\r\n            clientFileType,\r\n            clientFileData,\r\n          });\r\n          this.valueToShow = clientFileName;\r\n          this.markAsTouched();\r\n        })\r\n        this.worker.postMessage(blob);\r\n      } else {\r\n        blobToBase64(blob).then((clientFileData: any) => {\r\n          const index = (clientFileData as string).indexOf('base64,');\r\n          if (index >= 0) {\r\n            clientFileData = (clientFileData as string).substring(index + 7);\r\n          }\r\n          this.onChange({\r\n            assignTo: this.assignTo,\r\n            serverFileName: this.value?.serverFileName,\r\n            clientFileName,\r\n            clientFileType,\r\n            clientFileData,\r\n          });\r\n          this.valueToShow = clientFileName;\r\n          this.markAsTouched();\r\n        });\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n\r\n","<div #container class=\"core-attachment-container\">\r\n    <input id=\"rawInput\" #rawInput type=\"file\" (change)=\"handleInputChange($event)\">\r\n    <input class=\"form-control\" type=\"text\" [(ngModel)]=\"valueToShow\" readonly [class.form-control-disabled]=\"disabled\"\r\n        [appTooltip]=\"(!!valueToShow && touched) ? 'This file will be uploaded and its path will be assigned to current record' : ''\">\r\n    <div class=\"upload-icon-wrapper\" (click)=\"onClickUpload()\" [class.opacity0]=\"readonly\">\r\n        <div class=\"flex-wrapper\">\r\n            <i class=\"feather-upload\"></i>\r\n        </div>\r\n    </div>\r\n    <div class=\"download-icon-wrapper\" (click)=\"onClickDownload()\" *ngIf=\"!!valueToShow && !!!touched\">\r\n        <div class=\"flex-wrapper\">\r\n            <i class=\"feather-download\"></i>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-attachment.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-attachment/core-attachment/core-attachment.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-attachment/core-attachment/core-attachment.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Injector, Input, OnChanges, OnInit, SimpleChanges, ViewChild, isDevMode } from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { FormsModule, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { AppConfigService } from '../../../services/app-config.service';\r\nimport { alertOptions, noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { attachmentOptions } from '../../../constants/attachmentOptions';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { blob_to_base64_script } from '../../../../assets/js/blob2base64_wk';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { CommonModule } from '@angular/common';\r\n\r\n//declare let coreFileUtils: any;\r\nimport * as coreFileUtils from '../../../../assets/js/coreFileUtils';\r\nconst { blobToBase64 } = coreFileUtils; \r\n\r\n\r\n\r\nexport interface ICoreAttachment {\r\n  assignTo: string;\r\n  serverFileName?: string;\r\n  clientFileName: string;\r\n  clientFileType: string;\r\n  clientFileData: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-attachment',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    TooltipDirective,\r\n  ],\r\n  templateUrl: './core-attachment.component.html',\r\n  styleUrls: ['./core-attachment.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreAttachmentComponent\r\n    }\r\n  ]\r\n})\r\nexport class CoreAttachmentComponent extends CoreFormControlBaseComponent implements OnChanges, OnInit {\r\n\r\n  @Input() override readonly!: boolean;\r\n  @Input() assignTo!: string; // Required\r\n  @Input() valueToShow!: string;\r\n\r\n  override value!: ICoreAttachment | null;\r\n  override onChange!: (_: ICoreAttachment | null) => void;\r\n\r\n  override writeValue(obj: ICoreAttachment | null): void {\r\n    this.valueToShow = obj?.serverFileName!\r\n  }\r\n\r\n  ngControl!: NgControl;\r\n\r\n  worker!: Worker;\r\n\r\n  @ViewChild('rawInput') rawInput!: ElementRef;\r\n\r\n  constructor(\r\n    private injector: Injector,\r\n    private alertService: AlertService,\r\n    private mls: MultiLanguageService,\r\n    private appConfigService: AppConfigService,\r\n  ) {\r\n    super()\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['valueToShow']){\r\n      this.valueToShow = changes['valueToShow']?.currentValue;\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    setTimeout(() => this.ngControl = this.injector.get(NgControl), 200);\r\n    \r\n    if (!!!this.assignTo && !!!this.readonly && isDevMode()) {\r\n      this.alertService.error(`\r\n      CoreAttachmentComponent required input 'assignTo'\r\n      `, noneAutoClosedAlertOptions)\r\n    }\r\n  }\r\n\r\n  onClickUpload(): void {\r\n    if (this.disabled || this.readonly) return;\r\n    this.rawInput.nativeElement.dispatchEvent(new MouseEvent('click'));\r\n  }\r\n\r\n  onClickDownload(): void {\r\n    var uri = this.appConfigService.BASE_URL + '/' + this.appConfigService.STATIC_FOLDER + '/attachments/' + this.valueToShow\r\n    fetch(uri)\r\n      .then(response => response.blob())\r\n      .then(blob => {\r\n        const link = document.createElement(\"a\");\r\n        link.href = URL.createObjectURL(blob);\r\n        link.download = this.valueToShow.substring(52);\r\n        link.click();\r\n      })\r\n      .catch(console.error);\r\n  }\r\n\r\n  handleInputChange(e: any) {\r\n\r\n    if (!!e.target.files.length) {\r\n      const file = e.target.files[0];\r\n\r\n      if (file.size > attachmentOptions.maxFileSize) {\r\n        this.alertService.error(`${this.mls.trans(EnumTranslateKey.UI_CORE_ATTACHMENT_MAXIMUM_ATTACHMENT_FILE_SIZE_ERROR)} (${attachmentOptions.maxFileSize} bytes)`, alertOptions);\r\n        return;\r\n      }\r\n\r\n      console.log(\"file\", file)\r\n      const clientFileName = file.name\r\n      const clientFileType = file.type\r\n      let clientFileData = \"\"\r\n\r\n      const blob = new Blob([file]);\r\n      if (typeof Worker !== 'undefined') {\r\n        this.worker = new Worker(blob_to_base64_script)\r\n        this.worker.addEventListener(\"message\", e => {\r\n\r\n          console.log(\"worker message\", e)\r\n          clientFileData = e.data\r\n          const index = (clientFileData as string).indexOf('base64,');\r\n          if (index >= 0) {\r\n            clientFileData = (clientFileData as string).substring(index + 7);\r\n          }\r\n          this.onChange({\r\n            assignTo: this.assignTo,\r\n            serverFileName: this.value?.serverFileName,\r\n            clientFileName,\r\n            clientFileType,\r\n            clientFileData,\r\n          });\r\n          this.valueToShow = clientFileName;\r\n          this.markAsTouched();\r\n        })\r\n        this.worker.postMessage(blob);\r\n      } else {\r\n        blobToBase64(blob).then((clientFileData: any) => {\r\n          const index = (clientFileData as string).indexOf('base64,');\r\n          if (index >= 0) {\r\n            clientFileData = (clientFileData as string).substring(index + 7);\r\n          }\r\n          this.onChange({\r\n            assignTo: this.assignTo,\r\n            serverFileName: this.value?.serverFileName,\r\n            clientFileName,\r\n            clientFileType,\r\n            clientFileData,\r\n          });\r\n          this.valueToShow = clientFileName;\r\n          this.markAsTouched();\r\n        });\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n\r\n","<div #container class=\"core-attachment-container\">\r\n    <input id=\"rawInput\" #rawInput type=\"file\" (change)=\"handleInputChange($event)\">\r\n    <input class=\"form-control\" type=\"text\" [(ngModel)]=\"valueToShow\" readonly [class.form-control-disabled]=\"disabled\"\r\n        [appTooltip]=\"(!!valueToShow && touched) ? 'This file will be uploaded and its path will be assigned to current record' : ''\">\r\n    <div class=\"upload-icon-wrapper\" (click)=\"onClickUpload()\" [class.opacity0]=\"readonly\">\r\n        <div class=\"flex-wrapper\">\r\n            <i class=\"feather-upload\"></i>\r\n        </div>\r\n    </div>\r\n    <div class=\"download-icon-wrapper\" (click)=\"onClickDownload()\" *ngIf=\"!!valueToShow && !!!touched\">\r\n        <div class=\"flex-wrapper\">\r\n            <i class=\"feather-download\"></i>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -7,6 +7,8 @@ import { CommonModule } from '@angular/common';
|
|
|
7
7
|
import { ThreedotsComponent } from '../../threedots/threedots.component';
|
|
8
8
|
import { TranslatePipe } from '../../../app-pipes/translate.pipe';
|
|
9
9
|
import { MapAvatarToServerPipe } from '../../../app-pipes/map-avatar-to-server.pipe';
|
|
10
|
+
//declare let coreFileUtils: any;
|
|
11
|
+
import * as coreFileUtils from '../../../../assets/js/coreFileUtils';
|
|
10
12
|
import * as i0 from "@angular/core";
|
|
11
13
|
import * as i1 from "../../alert/alert.service";
|
|
12
14
|
import * as i2 from "../../../services/multi-language.service";
|
|
@@ -180,4 +182,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
180
182
|
type: ViewChild,
|
|
181
183
|
args: ['customFileInput']
|
|
182
184
|
}] } });
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-file-uploader.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-file-uploader/core-file-uploader/core-file-uploader.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-file-uploader/core-file-uploader/core-file-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n  isDevMode,\r\n  Injector,\r\n} from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { FormsModule, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\r\n\r\nimport { AlertService } from '../../alert/alert.service';\r\n\r\nimport { Subscription } from 'rxjs';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { alertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ThreedotsComponent } from '../../threedots/threedots.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { MapAvatarToServerPipe } from '../../../app-pipes/map-avatar-to-server.pipe';\r\n\r\ndeclare let coreFileUtils: any;\r\nconst { compressImage, blobToBase64 } = coreFileUtils;\r\n\r\nexport enum EnumCoreFileUploaderType {\r\n  IMAGE_AVATAR = 'IMAGE_AVATAR',\r\n  IMAGE_OTHER = 'IMAGE_OTHER',\r\n  PDF = 'PDF',\r\n  DOC = 'DOC',\r\n  EXCEL = 'EXCEL',\r\n  AUDIO = 'AUDIO',\r\n  OTHER = 'OTHER',\r\n}\r\n\r\n@Component({\r\n  selector: 'core-file-uploader',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ThreedotsComponent,\r\n    TranslatePipe,\r\n    MapAvatarToServerPipe\r\n  ],\r\n  templateUrl: './core-file-uploader.component.html',\r\n  styleUrls: ['./core-file-uploader.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreFileUploaderComponent,\r\n    },\r\n  ],\r\n})\r\nexport class CoreFileUploaderComponent extends CoreFormControlBaseComponent implements OnInit, OnDestroy {\r\n  @Input() uploadFileType!: EnumCoreFileUploaderType;\r\n  @Input() fileDataControlName!: string;\r\n  @Input() fileNameControlName!: string;\r\n  @Input() fileTypeControlName!: string;\r\n  @Input() avatarSize!: number;\r\n  @Input() defaultAvatar!: string;\r\n  @Input() hidePreview!: boolean;\r\n  @Input() verticalMode!: boolean;\r\n  @ViewChild('customFileInput') customFileInput!: ElementRef;\r\n\r\n  override value!: string;\r\n\r\n  ngControl!: NgControl;\r\n\r\n  hoverText =\r\n    EnumTranslateKey.UI_CORE_CONTROL_FILE_UPLOADER_CLICK_TO_BROWSE_FILE;\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n  chosenFile: any;\r\n  compressedSize: any;\r\n  preview: any;\r\n  loading: boolean = false;\r\n  loadingCaption!: string;\r\n\r\n  accept!: string;\r\n\r\n  constructor(\r\n    private alertService: AlertService,\r\n    private mls: MultiLanguageService,\r\n    private injector: Injector\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    setTimeout(() => this.ngControl = this.injector.get(NgControl));\r\n\r\n    if (isDevMode() && !!!this.uploadFileType) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property uploadFileType!: EnumCoreFileUploaderType`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileDataControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileDataControlName!: string (base64)`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileNameControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileNameControlName!: string`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileTypeControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileTypeControlName!: string`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n\r\n    this.subscriptions.push(this.mls.lang$.subscribe((x) => (this.lang = x)));\r\n\r\n    if (\r\n      this.uploadFileType === EnumCoreFileUploaderType.IMAGE_AVATAR ||\r\n      this.uploadFileType === EnumCoreFileUploaderType.IMAGE_OTHER\r\n    ) {\r\n      this.accept = 'image/png, image/gif, image/jpeg';\r\n    } else if (\r\n      this.uploadFileType === EnumCoreFileUploaderType.PDF\r\n    ) {\r\n      this.accept = \"application/pdf\";\r\n    } else {\r\n      this.alertService.warn(\r\n        `When uploadFileType===${this.uploadFileType} => TO DO...`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n  }\r\n\r\n  onHover() {\r\n    console.log('onHover');\r\n    this.customFileInput.nativeElement.style.setProperty(\r\n      '--hover-text',\r\n      this.hoverText\r\n    );\r\n  }\r\n\r\n  handleInputChange(e: any) {\r\n    console.log('handleInputChange e', e);\r\n    if (!this.hasFileSize(e.target.files[0].size)) {\r\n      this.alertService.error(\r\n        `File size exceeds 3MB.`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n      return;\r\n    }\r\n    if (!!e.target.files.length) {\r\n      const file = e.target.files[0];\r\n      console.log('handleInputChange file', file);\r\n      this.chosenFile = file;\r\n\r\n      if (\r\n        file.type.split('/')[0] === 'image' ||\r\n        file.type.split('/')[0] === 'application'\r\n      ) {\r\n        const blob = new Blob([file]);\r\n        if (file.type !== 'image/gif') {\r\n          compressImage(blob).then((blob: any) => {\r\n            this.compressedSize = blob.size;\r\n            blobToBase64(blob).then((base64: any) => {\r\n              this.preview = base64;\r\n\r\n              const index = (base64 as string).indexOf('base64,');\r\n              if (index >= 0) {\r\n                base64 = (base64 as string).substring(index + 7);\r\n              }\r\n\r\n              this.onChange(base64);\r\n\r\n              const form = this.ngControl.control?.parent;\r\n              const objectToPatch: any = {};\r\n              objectToPatch[this.fileDataControlName] = base64;\r\n              objectToPatch[this.fileNameControlName] = file.name;\r\n              objectToPatch[this.fileTypeControlName] = file.type;\r\n              form?.patchValue(objectToPatch);\r\n\r\n              this.markAsTouched();\r\n            });\r\n          });\r\n        } else {\r\n          blobToBase64(blob).then((base64: any) => {\r\n            this.compressedSize = blob.size;\r\n            this.preview = base64;\r\n\r\n            const index = (base64 as string).indexOf('base64,');\r\n            if (index >= 0) {\r\n              base64 = (base64 as string).substring(index + 7);\r\n            }\r\n\r\n            this.onChange(base64);\r\n\r\n            const form = this.ngControl.control?.parent;\r\n            const objectToPatch: any = {};\r\n            objectToPatch[this.fileDataControlName] = base64;\r\n            objectToPatch[this.fileNameControlName] = file.name;\r\n            objectToPatch[this.fileTypeControlName] = file.type;\r\n            form?.patchValue(objectToPatch);\r\n\r\n            this.markAsTouched();\r\n          });\r\n        }\r\n      } else if (file.type.split('/')[0] === 'audio') {\r\n        console.log('To do');\r\n      } else {\r\n\r\n      }\r\n    } else {\r\n      this.preview = '';\r\n      this.onChange('');\r\n      this.markAsTouched();\r\n      this.chosenFile = '';\r\n    }\r\n  }\r\n\r\n  hasFileSize(fileSize : any) {\r\n    if (fileSize < 3 * 1024 * 1024) { return true; }\r\n    return false;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n}\r\n","<div class=\"core-file-uploader-container\">\r\n\r\n    <div *ngIf=\"!!!verticalMode\">\r\n\r\n        <div class=\"row\">\r\n            <div [class]=\"!!hidePreview ? 'col-md-12' : 'col-md-6'\">\r\n                <input id=\"custom-file-input\" #customFileInput class=\"custom-file-input\" type=\"file\" [accept]=\"accept\"\r\n                    (change)=\"handleInputChange($event)\" (hover)=\"onHover()\">\r\n                <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                    <img *ngIf=\"uploadFileType==='IMAGE_AVATAR'\"\r\n                        [src]=\"!!!hidePreview ? (value ? (value | mapAvatarToServer) : defaultAvatar) : (preview ? preview : defaultAvatar)\"\r\n                        class=\"avatar-preview\">\r\n                    <div *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\">{{'EXISTING FILE...'}}</div>\r\n                </label>\r\n                <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                    <input type=\"file\" *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\" [src]=\"value\"\r\n                        (change)=\"handleInputChange($event)\" class=\"\">\r\n                </label>\r\n            </div>\r\n            <div class=\"col-md-2\" *ngIf=\"!!!hidePreview\">\r\n                <div *ngIf=\"!!!loading\">\r\n                    <div class=\"selected-preview\" *ngIf=\"preview\">\r\n                        <img [src]=\"preview\" alt=\"selected-file\">\r\n                    </div>\r\n                </div>\r\n                <app-threedots *ngIf=\"!!loading\"></app-threedots>\r\n            </div>\r\n            <div class=\"col-md-4 d-none\" *ngIf=\"!!!hidePreview\">\r\n                <ng-container *ngIf=\"!!chosenFile\">\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_NAME' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.name }}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_TYPE' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.type }}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.size }}\r\n                        </div>\r\n                    </div>\r\n                </ng-container>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- <ng-container *ngIf=\"!!compressedSize\">\r\n            <div>\r\n                <div>\r\n                    {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE_COMPRESSED' | translate: lang }}:\r\n                </div>\r\n                <div>\r\n                    {{ compressedSize }}\r\n                </div>\r\n            </div>\r\n        </ng-container> -->\r\n    </div>\r\n\r\n    <div *ngIf=\"!!verticalMode\" class=\"mt20\">\r\n\r\n        <div class=\"container container-fluid\">\r\n\r\n            <div class=\"row\">\r\n                <div class='col-md-12'>\r\n                    <input id=\"custom-file-input\" #customFileInput class=\"custom-file-input\" type=\"file\"\r\n                        [accept]=\"accept\" (change)=\"handleInputChange($event)\" (hover)=\"onHover()\">\r\n                    <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                        <img *ngIf=\"uploadFileType==='IMAGE_AVATAR'\"\r\n                            [src]=\"!!!hidePreview ? (value ? (value | mapAvatarToServer) : defaultAvatar) : ((value && !!!preview) ? (value | mapAvatarToServer) : (preview ? preview : defaultAvatar))\"\r\n                            class=\"avatar-preview\">\r\n                        <div *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\">{{'EXISTING FILE...'}}</div>\r\n                    </label>\r\n                    <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                        <input type=\"file\" *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\" [src]=\"value\"\r\n                            (change)=\"handleInputChange($event)\" class=\"\">\r\n                    </label>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row\">\r\n                <div class=\"col-md-12\" *ngIf=\"!!!hidePreview\">\r\n                    <div *ngIf=\"!!!loading\">\r\n                        <div class=\"selected-preview\" *ngIf=\"preview\">\r\n                            <img [src]=\"preview\" alt=\"selected-file\">\r\n                        </div>\r\n                    </div>\r\n                    <app-threedots *ngIf=\"!!loading\"></app-threedots>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row d-none\">\r\n                <div class=\"col-md-12\" *ngIf=\"!!!hidePreview\">\r\n\r\n                    <ng-container *ngIf=\"!!chosenFile\">\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_NAME' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.name }}\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_TYPE' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.type }}\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.size }}\r\n                            </div>\r\n                        </div>\r\n\r\n                    </ng-container>\r\n\r\n                    <ng-container *ngIf=\"!!compressedSize\">\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE_COMPRESSED' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ compressedSize }}\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n\r\n                </div>\r\n            </div>\r\n\r\n        </div>\r\n\r\n    </div>\r\n\r\n</div>"]}
|
|
185
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-file-uploader.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-file-uploader/core-file-uploader/core-file-uploader.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-file-uploader/core-file-uploader/core-file-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n  isDevMode,\r\n  Injector,\r\n} from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { FormsModule, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';\r\n\r\nimport { AlertService } from '../../alert/alert.service';\r\n\r\nimport { Subscription } from 'rxjs';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { alertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ThreedotsComponent } from '../../threedots/threedots.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { MapAvatarToServerPipe } from '../../../app-pipes/map-avatar-to-server.pipe';\r\n\r\n//declare let coreFileUtils: any;\r\nimport * as coreFileUtils from '../../../../assets/js/coreFileUtils';\r\nconst { compressImage, blobToBase64 } = coreFileUtils;\r\n\r\nexport enum EnumCoreFileUploaderType {\r\n  IMAGE_AVATAR = 'IMAGE_AVATAR',\r\n  IMAGE_OTHER = 'IMAGE_OTHER',\r\n  PDF = 'PDF',\r\n  DOC = 'DOC',\r\n  EXCEL = 'EXCEL',\r\n  AUDIO = 'AUDIO',\r\n  OTHER = 'OTHER',\r\n}\r\n\r\n@Component({\r\n  selector: 'core-file-uploader',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ThreedotsComponent,\r\n    TranslatePipe,\r\n    MapAvatarToServerPipe\r\n  ],\r\n  templateUrl: './core-file-uploader.component.html',\r\n  styleUrls: ['./core-file-uploader.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreFileUploaderComponent,\r\n    },\r\n  ],\r\n})\r\nexport class CoreFileUploaderComponent extends CoreFormControlBaseComponent implements OnInit, OnDestroy {\r\n  @Input() uploadFileType!: EnumCoreFileUploaderType;\r\n  @Input() fileDataControlName!: string;\r\n  @Input() fileNameControlName!: string;\r\n  @Input() fileTypeControlName!: string;\r\n  @Input() avatarSize!: number;\r\n  @Input() defaultAvatar!: string;\r\n  @Input() hidePreview!: boolean;\r\n  @Input() verticalMode!: boolean;\r\n  @ViewChild('customFileInput') customFileInput!: ElementRef;\r\n\r\n  override value!: string;\r\n\r\n  ngControl!: NgControl;\r\n\r\n  hoverText =\r\n    EnumTranslateKey.UI_CORE_CONTROL_FILE_UPLOADER_CLICK_TO_BROWSE_FILE;\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n  chosenFile: any;\r\n  compressedSize: any;\r\n  preview: any;\r\n  loading: boolean = false;\r\n  loadingCaption!: string;\r\n\r\n  accept!: string;\r\n\r\n  constructor(\r\n    private alertService: AlertService,\r\n    private mls: MultiLanguageService,\r\n    private injector: Injector\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    setTimeout(() => this.ngControl = this.injector.get(NgControl));\r\n\r\n    if (isDevMode() && !!!this.uploadFileType) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property uploadFileType!: EnumCoreFileUploaderType`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileDataControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileDataControlName!: string (base64)`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileNameControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileNameControlName!: string`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n    if (isDevMode() && !!!this.fileTypeControlName) {\r\n      this.alertService.error(\r\n        `Using CoreFileUploaderComponent required property fileTypeControlName!: string`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n\r\n    this.subscriptions.push(this.mls.lang$.subscribe((x) => (this.lang = x)));\r\n\r\n    if (\r\n      this.uploadFileType === EnumCoreFileUploaderType.IMAGE_AVATAR ||\r\n      this.uploadFileType === EnumCoreFileUploaderType.IMAGE_OTHER\r\n    ) {\r\n      this.accept = 'image/png, image/gif, image/jpeg';\r\n    } else if (\r\n      this.uploadFileType === EnumCoreFileUploaderType.PDF\r\n    ) {\r\n      this.accept = \"application/pdf\";\r\n    } else {\r\n      this.alertService.warn(\r\n        `When uploadFileType===${this.uploadFileType} => TO DO...`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n    }\r\n  }\r\n\r\n  onHover() {\r\n    console.log('onHover');\r\n    this.customFileInput.nativeElement.style.setProperty(\r\n      '--hover-text',\r\n      this.hoverText\r\n    );\r\n  }\r\n\r\n  handleInputChange(e: any) {\r\n    console.log('handleInputChange e', e);\r\n    if (!this.hasFileSize(e.target.files[0].size)) {\r\n      this.alertService.error(\r\n        `File size exceeds 3MB.`,\r\n        { ...alertOptions, autoClose: false }\r\n      );\r\n      return;\r\n    }\r\n    if (!!e.target.files.length) {\r\n      const file = e.target.files[0];\r\n      console.log('handleInputChange file', file);\r\n      this.chosenFile = file;\r\n\r\n      if (\r\n        file.type.split('/')[0] === 'image' ||\r\n        file.type.split('/')[0] === 'application'\r\n      ) {\r\n        const blob = new Blob([file]);\r\n        if (file.type !== 'image/gif') {\r\n          compressImage(blob).then((blob: any) => {\r\n            this.compressedSize = blob.size;\r\n            blobToBase64(blob).then((base64: any) => {\r\n              this.preview = base64;\r\n\r\n              const index = (base64 as string).indexOf('base64,');\r\n              if (index >= 0) {\r\n                base64 = (base64 as string).substring(index + 7);\r\n              }\r\n\r\n              this.onChange(base64);\r\n\r\n              const form = this.ngControl.control?.parent;\r\n              const objectToPatch: any = {};\r\n              objectToPatch[this.fileDataControlName] = base64;\r\n              objectToPatch[this.fileNameControlName] = file.name;\r\n              objectToPatch[this.fileTypeControlName] = file.type;\r\n              form?.patchValue(objectToPatch);\r\n\r\n              this.markAsTouched();\r\n            });\r\n          });\r\n        } else {\r\n          blobToBase64(blob).then((base64: any) => {\r\n            this.compressedSize = blob.size;\r\n            this.preview = base64;\r\n\r\n            const index = (base64 as string).indexOf('base64,');\r\n            if (index >= 0) {\r\n              base64 = (base64 as string).substring(index + 7);\r\n            }\r\n\r\n            this.onChange(base64);\r\n\r\n            const form = this.ngControl.control?.parent;\r\n            const objectToPatch: any = {};\r\n            objectToPatch[this.fileDataControlName] = base64;\r\n            objectToPatch[this.fileNameControlName] = file.name;\r\n            objectToPatch[this.fileTypeControlName] = file.type;\r\n            form?.patchValue(objectToPatch);\r\n\r\n            this.markAsTouched();\r\n          });\r\n        }\r\n      } else if (file.type.split('/')[0] === 'audio') {\r\n        console.log('To do');\r\n      } else {\r\n\r\n      }\r\n    } else {\r\n      this.preview = '';\r\n      this.onChange('');\r\n      this.markAsTouched();\r\n      this.chosenFile = '';\r\n    }\r\n  }\r\n\r\n  hasFileSize(fileSize : any) {\r\n    if (fileSize < 3 * 1024 * 1024) { return true; }\r\n    return false;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n}\r\n","<div class=\"core-file-uploader-container\">\r\n\r\n    <div *ngIf=\"!!!verticalMode\">\r\n\r\n        <div class=\"row\">\r\n            <div [class]=\"!!hidePreview ? 'col-md-12' : 'col-md-6'\">\r\n                <input id=\"custom-file-input\" #customFileInput class=\"custom-file-input\" type=\"file\" [accept]=\"accept\"\r\n                    (change)=\"handleInputChange($event)\" (hover)=\"onHover()\">\r\n                <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                    <img *ngIf=\"uploadFileType==='IMAGE_AVATAR'\"\r\n                        [src]=\"!!!hidePreview ? (value ? (value | mapAvatarToServer) : defaultAvatar) : (preview ? preview : defaultAvatar)\"\r\n                        class=\"avatar-preview\">\r\n                    <div *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\">{{'EXISTING FILE...'}}</div>\r\n                </label>\r\n                <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                    <input type=\"file\" *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\" [src]=\"value\"\r\n                        (change)=\"handleInputChange($event)\" class=\"\">\r\n                </label>\r\n            </div>\r\n            <div class=\"col-md-2\" *ngIf=\"!!!hidePreview\">\r\n                <div *ngIf=\"!!!loading\">\r\n                    <div class=\"selected-preview\" *ngIf=\"preview\">\r\n                        <img [src]=\"preview\" alt=\"selected-file\">\r\n                    </div>\r\n                </div>\r\n                <app-threedots *ngIf=\"!!loading\"></app-threedots>\r\n            </div>\r\n            <div class=\"col-md-4 d-none\" *ngIf=\"!!!hidePreview\">\r\n                <ng-container *ngIf=\"!!chosenFile\">\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_NAME' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.name }}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_TYPE' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.type }}\r\n                        </div>\r\n                    </div>\r\n\r\n                    <div>\r\n                        <div>\r\n                            {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE' | translate: lang }}:\r\n                        </div>\r\n                        <div>\r\n                            {{ chosenFile?.size }}\r\n                        </div>\r\n                    </div>\r\n                </ng-container>\r\n            </div>\r\n        </div>\r\n\r\n        <!-- <ng-container *ngIf=\"!!compressedSize\">\r\n            <div>\r\n                <div>\r\n                    {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE_COMPRESSED' | translate: lang }}:\r\n                </div>\r\n                <div>\r\n                    {{ compressedSize }}\r\n                </div>\r\n            </div>\r\n        </ng-container> -->\r\n    </div>\r\n\r\n    <div *ngIf=\"!!verticalMode\" class=\"mt20\">\r\n\r\n        <div class=\"container container-fluid\">\r\n\r\n            <div class=\"row\">\r\n                <div class='col-md-12'>\r\n                    <input id=\"custom-file-input\" #customFileInput class=\"custom-file-input\" type=\"file\"\r\n                        [accept]=\"accept\" (change)=\"handleInputChange($event)\" (hover)=\"onHover()\">\r\n                    <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                        <img *ngIf=\"uploadFileType==='IMAGE_AVATAR'\"\r\n                            [src]=\"!!!hidePreview ? (value ? (value | mapAvatarToServer) : defaultAvatar) : ((value && !!!preview) ? (value | mapAvatarToServer) : (preview ? preview : defaultAvatar))\"\r\n                            class=\"avatar-preview\">\r\n                        <div *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\">{{'EXISTING FILE...'}}</div>\r\n                    </label>\r\n                    <label id=\"file-input-label\" for=\"custom-file-input\">\r\n                        <input type=\"file\" *ngIf=\"uploadFileType!=='IMAGE_AVATAR'\" [src]=\"value\"\r\n                            (change)=\"handleInputChange($event)\" class=\"\">\r\n                    </label>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row\">\r\n                <div class=\"col-md-12\" *ngIf=\"!!!hidePreview\">\r\n                    <div *ngIf=\"!!!loading\">\r\n                        <div class=\"selected-preview\" *ngIf=\"preview\">\r\n                            <img [src]=\"preview\" alt=\"selected-file\">\r\n                        </div>\r\n                    </div>\r\n                    <app-threedots *ngIf=\"!!loading\"></app-threedots>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row d-none\">\r\n                <div class=\"col-md-12\" *ngIf=\"!!!hidePreview\">\r\n\r\n                    <ng-container *ngIf=\"!!chosenFile\">\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_NAME' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.name }}\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_TYPE' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.type }}\r\n                            </div>\r\n                        </div>\r\n\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ chosenFile?.size }}\r\n                            </div>\r\n                        </div>\r\n\r\n                    </ng-container>\r\n\r\n                    <ng-container *ngIf=\"!!compressedSize\">\r\n                        <div class=\"row\">\r\n                            <div class='col-md-6'>\r\n                                {{ 'UI_CORE_FILE_UPLOADER_FILE_SIZE_COMPRESSED' | translate: lang }}:\r\n                            </div>\r\n                            <div class='col-md-6'>\r\n                                {{ compressedSize }}\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n\r\n                </div>\r\n            </div>\r\n\r\n        </div>\r\n\r\n    </div>\r\n\r\n</div>"]}
|