ngx-histaff-alpha 2.3.5 → 2.3.7
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/app-pipes/map-attachment-to-server.pipe.mjs +25 -0
- package/esm2022/lib/app/app-pipes/uploaded-filename-cutoff.pipe.mjs +22 -0
- package/esm2022/lib/app/libraries/core-attachment/core-attachment/core-attachment.component.mjs +59 -24
- package/esm2022/lib/app/libraries/core-table/EnumCoreTablePipeType.mjs +2 -1
- package/esm2022/lib/app/libraries/core-table/core-table.component.mjs +6 -4
- package/esm2022/lib/app/libraries/pipes/table-cell.pipe.mjs +9 -1
- package/esm2022/lib/app/services/app-config.service.mjs +2 -1
- package/esm2022/lib/app/services/app-initialization.service.mjs +4 -3
- package/esm2022/lib/app/services/uploaded-file.service.mjs +24 -0
- package/esm2022/public-api.mjs +4 -1
- package/fesm2022/ngx-histaff-alpha.mjs +134 -26
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/app-pipes/map-attachment-to-server.pipe.d.ts +10 -0
- package/lib/app/app-pipes/uploaded-filename-cutoff.pipe.d.ts +7 -0
- package/lib/app/libraries/core-attachment/core-attachment/core-attachment.component.d.ts +14 -4
- package/lib/app/libraries/core-table/EnumCoreTablePipeType.d.ts +2 -1
- package/lib/app/services/app-config.service.d.ts +1 -0
- package/lib/app/services/uploaded-file.service.d.ts +7 -0
- package/package.json +1 -1
- package/public-api.d.ts +3 -0
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../services/app-config.service";
|
|
4
|
+
export class MapAttachmentToServerPipe {
|
|
5
|
+
constructor(appConfigService) {
|
|
6
|
+
this.appConfigService = appConfigService;
|
|
7
|
+
}
|
|
8
|
+
transform(value) {
|
|
9
|
+
if (!value)
|
|
10
|
+
return value;
|
|
11
|
+
let result = '';
|
|
12
|
+
result = `${this.appConfigService.BASE_URL}/${this.appConfigService.STATIC_FOLDER}/${this.appConfigService.ATTACHMENT_FOLDER}/${value}`;
|
|
13
|
+
return result;
|
|
14
|
+
}
|
|
15
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: MapAttachmentToServerPipe, deps: [{ token: i1.AppConfigService }], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
16
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.3", ngImport: i0, type: MapAttachmentToServerPipe, isStandalone: true, name: "mapAttachmentToServer" }); }
|
|
17
|
+
}
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: MapAttachmentToServerPipe, decorators: [{
|
|
19
|
+
type: Pipe,
|
|
20
|
+
args: [{
|
|
21
|
+
name: 'mapAttachmentToServer',
|
|
22
|
+
standalone: true
|
|
23
|
+
}]
|
|
24
|
+
}], ctorParameters: () => [{ type: i1.AppConfigService }] });
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwLWF0dGFjaG1lbnQtdG8tc2VydmVyLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9hcHAtcGlwZXMvbWFwLWF0dGFjaG1lbnQtdG8tc2VydmVyLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7OztBQU9wRCxNQUFNLE9BQU8seUJBQXlCO0lBRXBDLFlBQW9CLGdCQUFrQztRQUFsQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO0lBQUksQ0FBQztJQUUzRCxTQUFTLENBQUMsS0FBZ0M7UUFDeEMsSUFBSSxDQUFDLEtBQUs7WUFBRSxPQUFPLEtBQU0sQ0FBQztRQUMxQixJQUFJLE1BQU0sR0FBVyxFQUFFLENBQUM7UUFDeEIsTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxpQkFBaUIsSUFBSSxLQUFLLEVBQUUsQ0FBQztRQUN4SSxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDOzhHQVRVLHlCQUF5Qjs0R0FBekIseUJBQXlCOzsyRkFBekIseUJBQXlCO2tCQUpyQyxJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSx1QkFBdUI7b0JBQzdCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQXBwQ29uZmlnU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2FwcC1jb25maWcuc2VydmljZSc7XHJcblxyXG5AUGlwZSh7XHJcbiAgbmFtZTogJ21hcEF0dGFjaG1lbnRUb1NlcnZlcicsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTWFwQXR0YWNobWVudFRvU2VydmVyUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGFwcENvbmZpZ1NlcnZpY2U6IEFwcENvbmZpZ1NlcnZpY2UpIHsgfVxyXG5cclxuICB0cmFuc2Zvcm0odmFsdWU6IHN0cmluZyB8IG51bGwgfCB1bmRlZmluZWQpOiBzdHJpbmcge1xyXG4gICAgaWYgKCF2YWx1ZSkgcmV0dXJuIHZhbHVlITtcclxuICAgIGxldCByZXN1bHQ6IHN0cmluZyA9ICcnO1xyXG4gICAgcmVzdWx0ID0gYCR7dGhpcy5hcHBDb25maWdTZXJ2aWNlLkJBU0VfVVJMfS8ke3RoaXMuYXBwQ29uZmlnU2VydmljZS5TVEFUSUNfRk9MREVSfS8ke3RoaXMuYXBwQ29uZmlnU2VydmljZS5BVFRBQ0hNRU5UX0ZPTERFUn0vJHt2YWx1ZX1gO1xyXG4gICAgcmV0dXJuIHJlc3VsdDtcclxuICB9XHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class UploadedFilenameCutoffPipe {
|
|
4
|
+
transform(value, ...args) {
|
|
5
|
+
if (!!value && typeof (value) === 'string' && value.length > 52) {
|
|
6
|
+
return value.substring(52);
|
|
7
|
+
}
|
|
8
|
+
else {
|
|
9
|
+
return '';
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: UploadedFilenameCutoffPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
13
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.3", ngImport: i0, type: UploadedFilenameCutoffPipe, isStandalone: true, name: "uploadedFilenameCutoff" }); }
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: UploadedFilenameCutoffPipe, decorators: [{
|
|
16
|
+
type: Pipe,
|
|
17
|
+
args: [{
|
|
18
|
+
name: 'uploadedFilenameCutoff',
|
|
19
|
+
standalone: true
|
|
20
|
+
}]
|
|
21
|
+
}] });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsb2FkZWQtZmlsZW5hbWUtY3V0b2ZmLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9hcHAtcGlwZXMvdXBsb2FkZWQtZmlsZW5hbWUtY3V0b2ZmLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBTXBELE1BQU0sT0FBTywwQkFBMEI7SUFFckMsU0FBUyxDQUFDLEtBQXlCLEVBQUUsR0FBRyxJQUFlO1FBQ3JELElBQUksQ0FBQyxDQUFDLEtBQUssSUFBSSxPQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssUUFBUSxJQUFJLEtBQUssQ0FBQyxNQUFNLEdBQUcsRUFBRSxFQUFFO1lBQzlELE9BQU8sS0FBSyxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQztTQUM1QjthQUFNO1lBQ0wsT0FBTyxFQUFFLENBQUM7U0FDWDtJQUNILENBQUM7OEdBUlUsMEJBQTBCOzRHQUExQiwwQkFBMEI7OzJGQUExQiwwQkFBMEI7a0JBSnRDLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLHdCQUF3QjtvQkFDOUIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQFBpcGUoe1xyXG4gIG5hbWU6ICd1cGxvYWRlZEZpbGVuYW1lQ3V0b2ZmJyxcclxuICBzdGFuZGFsb25lOiB0cnVlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVcGxvYWRlZEZpbGVuYW1lQ3V0b2ZmUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG5cclxuICB0cmFuc2Zvcm0odmFsdWU6IHN0cmluZyB8IHVuZGVmaW5lZCwgLi4uYXJnczogdW5rbm93bltdKTogc3RyaW5nIHtcclxuICAgIGlmICghIXZhbHVlICYmIHR5cGVvZih2YWx1ZSkgPT09ICdzdHJpbmcnICYmIHZhbHVlLmxlbmd0aCA+IDUyKSB7XHJcbiAgICAgIHJldHVybiB2YWx1ZS5zdWJzdHJpbmcoNTIpO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgcmV0dXJuICcnO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbn1cclxuIl19
|
package/esm2022/lib/app/libraries/core-attachment/core-attachment/core-attachment.component.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Input, ViewChild, isDevMode } from '@angular/core';
|
|
1
|
+
import { Component, Input, ViewChild, isDevMode, forwardRef } from '@angular/core';
|
|
2
2
|
import { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';
|
|
3
3
|
import { FormsModule, NG_VALUE_ACCESSOR, NgControl } from '@angular/forms';
|
|
4
4
|
import { alertOptions, noneAutoClosedAlertOptions } from '../../../constants/alertOptions';
|
|
@@ -8,26 +8,35 @@ 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
10
|
import { coreFileUtils } from '../../../../assets/js/coreFileUtils';
|
|
11
|
+
import { UploadedFilenameCutoffPipe } from '../../../app-pipes/uploaded-filename-cutoff.pipe';
|
|
12
|
+
import { MapAttachmentToServerPipe } from '../../../app-pipes/map-attachment-to-server.pipe';
|
|
13
|
+
import { ImageErrorResolverDirective } from '../../../directives/image-error-resolver.directive';
|
|
11
14
|
import * as i0 from "@angular/core";
|
|
12
15
|
import * as i1 from "../../alert/alert.service";
|
|
13
16
|
import * as i2 from "../../../services/multi-language.service";
|
|
14
17
|
import * as i3 from "../../../services/app-config.service";
|
|
15
|
-
import * as i4 from "
|
|
16
|
-
import * as i5 from "@angular/
|
|
18
|
+
import * as i4 from "../../../services/uploaded-file.service";
|
|
19
|
+
import * as i5 from "@angular/common";
|
|
20
|
+
import * as i6 from "@angular/forms";
|
|
17
21
|
export class CoreAttachmentComponent extends CoreFormControlBaseComponent {
|
|
18
22
|
writeValue(obj) {
|
|
19
23
|
this.valueToShow = obj?.serverFileName;
|
|
20
24
|
}
|
|
21
|
-
constructor(injector, alertService, mls, appConfigService) {
|
|
25
|
+
constructor(injector, alertService, mls, appConfigService, uploadedFileService, renderer) {
|
|
22
26
|
super();
|
|
23
27
|
this.injector = injector;
|
|
24
28
|
this.alertService = alertService;
|
|
25
29
|
this.mls = mls;
|
|
26
30
|
this.appConfigService = appConfigService;
|
|
31
|
+
this.uploadedFileService = uploadedFileService;
|
|
32
|
+
this.renderer = renderer;
|
|
33
|
+
this.dropdownHeight = 0;
|
|
34
|
+
this.dropdownPadding = 0;
|
|
27
35
|
}
|
|
28
36
|
ngOnChanges(changes) {
|
|
29
37
|
if (changes['valueToShow']) {
|
|
30
38
|
this.valueToShow = changes['valueToShow']?.currentValue;
|
|
39
|
+
this.previewable = this.uploadedFileService.canPreviewAsImage(this.valueToShow);
|
|
31
40
|
}
|
|
32
41
|
}
|
|
33
42
|
ngOnInit() {
|
|
@@ -38,22 +47,43 @@ export class CoreAttachmentComponent extends CoreFormControlBaseComponent {
|
|
|
38
47
|
`, noneAutoClosedAlertOptions);
|
|
39
48
|
}
|
|
40
49
|
}
|
|
50
|
+
ngAfterViewInit() {
|
|
51
|
+
setTimeout(() => {
|
|
52
|
+
this.listenerFn = this.renderer.listen('window', 'click', (e) => {
|
|
53
|
+
if (this.container && !!!this.container.nativeElement.contains(e.target)) {
|
|
54
|
+
this.dropdownHeight = 0;
|
|
55
|
+
this.dropdownPadding = 0;
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
}
|
|
41
60
|
onClickUpload() {
|
|
42
61
|
if (this.disabled || this.readonly)
|
|
43
62
|
return;
|
|
63
|
+
this.dropdownHeight = 0;
|
|
64
|
+
this.dropdownPadding = 0;
|
|
44
65
|
this.rawInput.nativeElement.dispatchEvent(new MouseEvent('click'));
|
|
45
66
|
}
|
|
46
67
|
onClickDownload() {
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
.
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
68
|
+
if (this.uploadedFileService.canPreviewAsImage(this.valueToShow)) {
|
|
69
|
+
this.dropdownHeight = this.dropdownHeight === 0 ? 200 : 0;
|
|
70
|
+
this.dropdownPadding = this.dropdownPadding === 0 ? 15 : 0;
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
var uri = this.appConfigService.BASE_URL + '/' + this.appConfigService.STATIC_FOLDER + '/attachments/' + this.valueToShow;
|
|
74
|
+
fetch(uri)
|
|
75
|
+
.then(response => response.blob())
|
|
76
|
+
.then(blob => {
|
|
77
|
+
const link = document.createElement("a");
|
|
78
|
+
link.href = URL.createObjectURL(blob);
|
|
79
|
+
link.download = this.valueToShow.substring(52);
|
|
80
|
+
link.click();
|
|
81
|
+
})
|
|
82
|
+
.catch(console.error);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
isPreviewable() {
|
|
86
|
+
return this.previewable;
|
|
57
87
|
}
|
|
58
88
|
handleInputChange(e) {
|
|
59
89
|
if (!!e.target.files.length) {
|
|
@@ -107,14 +137,14 @@ export class CoreAttachmentComponent extends CoreFormControlBaseComponent {
|
|
|
107
137
|
}
|
|
108
138
|
}
|
|
109
139
|
}
|
|
110
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreAttachmentComponent, deps: [{ token: i0.Injector }, { token: i1.AlertService }, { token: i2.MultiLanguageService }, { token: i3.AppConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
111
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
140
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreAttachmentComponent, deps: [{ token: i0.Injector }, { token: i1.AlertService }, { token: i2.MultiLanguageService }, { token: i3.AppConfigService }, { token: i4.UploadedFileService }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
141
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreAttachmentComponent, isStandalone: true, selector: "core-attachment", inputs: { assignTo: "assignTo", readonly: "readonly", valueToShow: "valueToShow" }, providers: [
|
|
112
142
|
{
|
|
113
143
|
provide: NG_VALUE_ACCESSOR,
|
|
114
144
|
multi: true,
|
|
115
|
-
useExisting: CoreAttachmentComponent
|
|
145
|
+
useExisting: forwardRef(() => CoreAttachmentComponent),
|
|
116
146
|
}
|
|
117
|
-
], viewQueries: [{ propertyName: "rawInput", first: true, predicate: ["rawInput"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #container class=\"core-attachment-container\">\r\n <input id=\"rawInput\" #rawInput type=\"file\" (change)=\"handleInputChange($event)\">\r\n <
|
|
147
|
+
], viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }, { propertyName: "rawInput", first: true, predicate: ["rawInput"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #container class=\"core-attachment-container\">\r\n <input id=\"rawInput\" #rawInput type=\"file\" (change)=\"handleInputChange($event)\">\r\n <div class=\"form-control\" type=\"text\" [(ngModel)]=\"valueToShow\" readonly [class.form-control-disabled]=\"disabled\">\r\n <div class=\"text-to-show\" [appTooltip]=\"valueToShow | uploadedFilenameCutoff\">{{ valueToShow |\r\n uploadedFilenameCutoff}}</div>\r\n </div>\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 @if (!!valueToShow && !!!touched) {\r\n <div class=\"download-icon-wrapper\" (click)=\"onClickDownload()\">\r\n <div class=\"flex-wrapper\">\r\n <i class=\"feather-download\"></i>\r\n </div>\r\n </div>\r\n }\r\n\r\n <div class=\"dropdown\" [ngStyle]=\"{ height: dropdownHeight + 'px', padding: dropdownPadding + 'px' }\">\r\n @if (previewable) {\r\n <img [src]=\"valueToShow | mapAttachmentToServer\" imageErrorResolver />\r\n }\r\n </div>\r\n\r\n</div>", styles: [".core-attachment-container{--height: 35px;display:block;position:relative;background-color:#fff;width:100%}.core-attachment-container .dropdown{box-sizing:border-box;display:block;position:absolute;width:100%;overflow:hidden;background-color:#fff;font-size:15px;box-shadow:0 1rem 3rem #0000002e;transition:height .25s linear;z-index:calc(var(--max-z-index) + 1)}.core-attachment-container .dropdown img{transform:none;max-width:100%;max-height:170px}.core-attachment-container .dropdown img:hover{transform:none}.core-attachment-container #rawInput{display:none}.core-attachment-container .text-to-show{width:calc(100% - 60px);height:calc(var(--height) - 12px);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transform:translate(30px)}.core-attachment-container>.upload-icon-wrapper{right:3px;top:3px}.core-attachment-container>.download-icon-wrapper{left:3px;top:3px}.core-attachment-container>.upload-icon-wrapper,.core-attachment-container>.download-icon-wrapper{display:block;position:absolute;background-color:#e9e9e9;width:calc(var(--height) - 6px);height:calc(var(--height) - 6px);border-radius:.275rem;cursor:pointer}.core-attachment-container>.upload-icon-wrapper>.flex-wrapper,.core-attachment-container>.download-icon-wrapper>.flex-wrapper{width:calc(var(--height) - 6px);height:calc(var(--height) - 6px);display:flex;align-items:center;justify-content:center}.core-attachment-container>.upload-icon-wrapper>.flex-wrapper>i,.core-attachment-container>.download-icon-wrapper>.flex-wrapper>i{color:#848484;font-size:20px}.core-attachment-container .source-container{display:block;background-color:var(--color-bg-main);padding:var(--size-layout-block-cell-spacing);max-width:1200px;max-height:800px;overflow:hidden;border-radius:10px}.core-attachment-container .source-container i{font-size:20px;cursor:pointer;float:right}.core-attachment-container .source-container.d-none{display:none}.core-attachment-container .source-container>caption{display:block;width:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: TooltipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "showAnyway", "position"] }, { kind: "pipe", type: UploadedFilenameCutoffPipe, name: "uploadedFilenameCutoff" }, { kind: "pipe", type: MapAttachmentToServerPipe, name: "mapAttachmentToServer" }] }); }
|
|
118
148
|
}
|
|
119
149
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreAttachmentComponent, decorators: [{
|
|
120
150
|
type: Component,
|
|
@@ -122,22 +152,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
122
152
|
CommonModule,
|
|
123
153
|
FormsModule,
|
|
124
154
|
TooltipDirective,
|
|
155
|
+
UploadedFilenameCutoffPipe,
|
|
156
|
+
MapAttachmentToServerPipe,
|
|
157
|
+
ImageErrorResolverDirective
|
|
125
158
|
], providers: [
|
|
126
159
|
{
|
|
127
160
|
provide: NG_VALUE_ACCESSOR,
|
|
128
161
|
multi: true,
|
|
129
|
-
useExisting: CoreAttachmentComponent
|
|
162
|
+
useExisting: forwardRef(() => CoreAttachmentComponent),
|
|
130
163
|
}
|
|
131
|
-
], template: "<div #container class=\"core-attachment-container\">\r\n <input id=\"rawInput\" #rawInput type=\"file\" (change)=\"handleInputChange($event)\">\r\n <
|
|
132
|
-
}], ctorParameters: () => [{ type: i0.Injector }, { type: i1.AlertService }, { type: i2.MultiLanguageService }, { type: i3.AppConfigService }], propDecorators: { assignTo: [{
|
|
133
|
-
type: Input
|
|
134
|
-
args: [{ required: true }]
|
|
164
|
+
], template: "<div #container class=\"core-attachment-container\">\r\n <input id=\"rawInput\" #rawInput type=\"file\" (change)=\"handleInputChange($event)\">\r\n <div class=\"form-control\" type=\"text\" [(ngModel)]=\"valueToShow\" readonly [class.form-control-disabled]=\"disabled\">\r\n <div class=\"text-to-show\" [appTooltip]=\"valueToShow | uploadedFilenameCutoff\">{{ valueToShow |\r\n uploadedFilenameCutoff}}</div>\r\n </div>\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 @if (!!valueToShow && !!!touched) {\r\n <div class=\"download-icon-wrapper\" (click)=\"onClickDownload()\">\r\n <div class=\"flex-wrapper\">\r\n <i class=\"feather-download\"></i>\r\n </div>\r\n </div>\r\n }\r\n\r\n <div class=\"dropdown\" [ngStyle]=\"{ height: dropdownHeight + 'px', padding: dropdownPadding + 'px' }\">\r\n @if (previewable) {\r\n <img [src]=\"valueToShow | mapAttachmentToServer\" imageErrorResolver />\r\n }\r\n </div>\r\n\r\n</div>", styles: [".core-attachment-container{--height: 35px;display:block;position:relative;background-color:#fff;width:100%}.core-attachment-container .dropdown{box-sizing:border-box;display:block;position:absolute;width:100%;overflow:hidden;background-color:#fff;font-size:15px;box-shadow:0 1rem 3rem #0000002e;transition:height .25s linear;z-index:calc(var(--max-z-index) + 1)}.core-attachment-container .dropdown img{transform:none;max-width:100%;max-height:170px}.core-attachment-container .dropdown img:hover{transform:none}.core-attachment-container #rawInput{display:none}.core-attachment-container .text-to-show{width:calc(100% - 60px);height:calc(var(--height) - 12px);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;transform:translate(30px)}.core-attachment-container>.upload-icon-wrapper{right:3px;top:3px}.core-attachment-container>.download-icon-wrapper{left:3px;top:3px}.core-attachment-container>.upload-icon-wrapper,.core-attachment-container>.download-icon-wrapper{display:block;position:absolute;background-color:#e9e9e9;width:calc(var(--height) - 6px);height:calc(var(--height) - 6px);border-radius:.275rem;cursor:pointer}.core-attachment-container>.upload-icon-wrapper>.flex-wrapper,.core-attachment-container>.download-icon-wrapper>.flex-wrapper{width:calc(var(--height) - 6px);height:calc(var(--height) - 6px);display:flex;align-items:center;justify-content:center}.core-attachment-container>.upload-icon-wrapper>.flex-wrapper>i,.core-attachment-container>.download-icon-wrapper>.flex-wrapper>i{color:#848484;font-size:20px}.core-attachment-container .source-container{display:block;background-color:var(--color-bg-main);padding:var(--size-layout-block-cell-spacing);max-width:1200px;max-height:800px;overflow:hidden;border-radius:10px}.core-attachment-container .source-container i{font-size:20px;cursor:pointer;float:right}.core-attachment-container .source-container.d-none{display:none}.core-attachment-container .source-container>caption{display:block;width:100%}\n"] }]
|
|
165
|
+
}], ctorParameters: () => [{ type: i0.Injector }, { type: i1.AlertService }, { type: i2.MultiLanguageService }, { type: i3.AppConfigService }, { type: i4.UploadedFileService }, { type: i0.Renderer2 }], propDecorators: { assignTo: [{
|
|
166
|
+
type: Input
|
|
135
167
|
}], readonly: [{
|
|
136
168
|
type: Input
|
|
137
169
|
}], valueToShow: [{
|
|
138
170
|
type: Input
|
|
171
|
+
}], container: [{
|
|
172
|
+
type: ViewChild,
|
|
173
|
+
args: ['container']
|
|
139
174
|
}], rawInput: [{
|
|
140
175
|
type: ViewChild,
|
|
141
176
|
args: ['rawInput']
|
|
142
177
|
}] } });
|
|
143
|
-
//# 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\nimport { coreFileUtils } from '../../../../assets/js/coreFileUtils';\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  @Input({ required: true}) assignTo!: string;\r\n  @Input() override readonly!: boolean;\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        coreFileUtils.prototype.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>"]}
|
|
178
|
+
//# 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 { AfterViewInit, Component, Renderer2, ElementRef, Injector, Input, OnChanges, OnInit, SimpleChanges, ViewChild, isDevMode, forwardRef } 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\nimport { coreFileUtils } from '../../../../assets/js/coreFileUtils';\r\n\r\nimport { UploadedFilenameCutoffPipe } from '../../../app-pipes/uploaded-filename-cutoff.pipe';\r\nimport { UploadedFileService } from '../../../services/uploaded-file.service';\r\nimport { MapAttachmentToServerPipe } from '../../../app-pipes/map-attachment-to-server.pipe';\r\nimport { ImageErrorResolverDirective } from '../../../directives/image-error-resolver.directive';\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    UploadedFilenameCutoffPipe,\r\n    MapAttachmentToServerPipe,\r\n    ImageErrorResolverDirective\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: forwardRef(() => CoreAttachmentComponent),\r\n    }\r\n  ]\r\n})\r\nexport class CoreAttachmentComponent extends CoreFormControlBaseComponent implements OnChanges, OnInit, AfterViewInit {\r\n  @Input() assignTo!: string;\r\n  @Input() override readonly!: boolean;\r\n  @Input() valueToShow!: string;\r\n\r\n  @ViewChild('container') container!: ElementRef;\r\n\r\n  previewable!: boolean;\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  listenerFn!: () => void;\r\n\r\n  dropdownHeight: number = 0;\r\n  dropdownPadding: number = 0;\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    private uploadedFileService: UploadedFileService,\r\n    private renderer: Renderer2,\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      this.previewable = this.uploadedFileService.canPreviewAsImage(this.valueToShow);\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  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n        if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n          this.dropdownHeight = 0;\r\n          this.dropdownPadding = 0;\r\n        }\r\n      });\r\n    })\r\n  }\r\n\r\n  onClickUpload(): void {\r\n    if (this.disabled || this.readonly) return;\r\n    this.dropdownHeight = 0;\r\n    this.dropdownPadding = 0;\r\n    this.rawInput.nativeElement.dispatchEvent(new MouseEvent('click'));\r\n  }\r\n\r\n  onClickDownload(): void {\r\n\r\n    if (this.uploadedFileService.canPreviewAsImage(this.valueToShow)) {\r\n\r\n      this.dropdownHeight = this.dropdownHeight === 0 ? 200 : 0;\r\n      this.dropdownPadding = this.dropdownPadding === 0 ? 15 : 0;\r\n\r\n    } else {\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  }\r\n\r\n  isPreviewable(): boolean {\r\n    return this.previewable\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        coreFileUtils.prototype.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    <div class=\"form-control\" type=\"text\" [(ngModel)]=\"valueToShow\" readonly [class.form-control-disabled]=\"disabled\">\r\n        <div class=\"text-to-show\" [appTooltip]=\"valueToShow | uploadedFilenameCutoff\">{{ valueToShow |\r\n            uploadedFilenameCutoff}}</div>\r\n    </div>\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    @if (!!valueToShow && !!!touched) {\r\n    <div class=\"download-icon-wrapper\" (click)=\"onClickDownload()\">\r\n        <div class=\"flex-wrapper\">\r\n            <i class=\"feather-download\"></i>\r\n        </div>\r\n    </div>\r\n    }\r\n\r\n    <div class=\"dropdown\" [ngStyle]=\"{ height: dropdownHeight + 'px', padding: dropdownPadding + 'px' }\">\r\n        @if (previewable) {\r\n        <img [src]=\"valueToShow | mapAttachmentToServer\" imageErrorResolver />\r\n        }\r\n    </div>\r\n\r\n</div>"]}
|
|
@@ -16,5 +16,6 @@ export var EnumCoreTablePipeType;
|
|
|
16
16
|
EnumCoreTablePipeType["LOWERCASE"] = "LOWERCASE";
|
|
17
17
|
EnumCoreTablePipeType["UPPERCASE"] = "UPPERCASE";
|
|
18
18
|
EnumCoreTablePipeType["NORMALIZE_HUMAN_NAME"] = "NORMALIZE_HUMAN_NAME";
|
|
19
|
+
EnumCoreTablePipeType["UPLOADED_FILENAME_CUT_OFF"] = "UPLOADED_FILENAME_CUT_OFF";
|
|
19
20
|
})(EnumCoreTablePipeType || (EnumCoreTablePipeType = {}));
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRW51bUNvcmVUYWJsZVBpcGVUeXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWhpc3RhZmYtYWxwaGEvc3JjL2xpYi9hcHAvbGlicmFyaWVzL2NvcmUtdGFibGUvRW51bUNvcmVUYWJsZVBpcGVUeXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLHFCQWtCWDtBQWxCRCxXQUFZLHFCQUFxQjtJQUM3QixnREFBdUIsQ0FBQTtJQUN2QiwwREFBaUMsQ0FBQTtJQUNqQyxzQ0FBYSxDQUFBO0lBQ2IsMENBQWlCLENBQUE7SUFDakIsOERBQXFDLENBQUE7SUFDckMsOERBQXFDLENBQUE7SUFDckMsOERBQXFDLENBQUE7SUFDckMsZ0RBQXVCLENBQUE7SUFDdkIsZ0RBQXVCLENBQUE7SUFDdkIsZ0VBQXVDLENBQUE7SUFDdkMsMEVBQWlELENBQUE7SUFDakQsd0VBQStDLENBQUE7SUFDL0Msa0ZBQXlELENBQUE7SUFDekQsZ0RBQXVCLENBQUE7SUFDdkIsZ0RBQXVCLENBQUE7SUFDdkIsc0VBQTZDLENBQUE7SUFDN0MsZ0ZBQXVELENBQUE7QUFDM0QsQ0FBQyxFQWxCVyxxQkFBcUIsS0FBckIscUJBQXFCLFFBa0JoQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIEVudW1Db3JlVGFibGVQaXBlVHlwZSB7XHJcbiAgICBUUkFOU0xBVEUgPSAnVFJBTlNMQVRFJyxcclxuICAgIEJFQVVUSUZVTF9KU09OID0gJ0JFQVVUSUZVTF9KU09OJyxcclxuICAgIERBVEUgPSAnREFURScsXHJcbiAgICBOVU1CRVIgPSAnTlVNQkVSJyxcclxuICAgIERFQ0lNQUxfVE9fRklYXzIgPSAnREVDSU1BTF9UT19GSVhfMicsXHJcbiAgICBERUNJTUFMX1RPX0ZJWF8zID0gJ0RFQ0lNQUxfVE9fRklYXzMnLFxyXG4gICAgREVDSU1BTF9UT19GSVhfNSA9ICdERUNJTUFMX1RPX0ZJWF81JyxcclxuICAgIERBVEVfVElNRSA9ICdEQVRFX1RJTUUnLFxyXG4gICAgVElNRV9ISE1NID0gJ1RJTUVfSEhNTScsXHJcbiAgICBCT09MRUFOX1RPX1lFU19OTyA9ICdCT09MRUFOX1RPX1lFU19OTycsXHJcbiAgICBCT09MRUFOX1RPX0RPTkVfTk9UWUVUID0gJ0JPT0xFQU5fVE9fRE9ORV9OT1RZRVQnLFxyXG4gICAgQk9PTEVBTl9UT19UUlVFX0ZBTFNFID0gJ0JPT0xFQU5fVE9fVFJVRV9GQUxTRScsXHJcbiAgICBCT09MRUFOX1RPX0FDVElWRV9JTkFDVElWRSA9ICdCT09MRUFOX1RPX0FDVElWRV9JTkFDVElWRScsXHJcbiAgICBMT1dFUkNBU0UgPSAnTE9XRVJDQVNFJyxcclxuICAgIFVQUEVSQ0FTRSA9ICdVUFBFUkNBU0UnLFxyXG4gICAgTk9STUFMSVpFX0hVTUFOX05BTUUgPSAnTk9STUFMSVpFX0hVTUFOX05BTUUnLFxyXG4gICAgVVBMT0FERURfRklMRU5BTUVfQ1VUX09GRiA9ICdVUExPQURFRF9GSUxFTkFNRV9DVVRfT0ZGJyxcclxufSJdfQ==
|