master-control 0.4.29 → 0.4.30
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/master-control.component.mjs +2 -2
- package/esm2022/lib/master.service.mjs +8 -1
- package/esm2022/lib/medial-questions/medial-questions.component.mjs +23 -23
- package/esm2022/lib/upload/upload.component.mjs +75 -10
- package/fesm2022/master-control.mjs +153 -82
- package/fesm2022/master-control.mjs.map +1 -1
- package/lib/master.service.d.ts +1 -0
- package/lib/upload/upload.component.d.ts +11 -5
- package/master-control-0.4.30.tgz +0 -0
- package/package.json +1 -1
- package/master-control-0.4.29.tgz +0 -0
|
@@ -4,17 +4,49 @@ import { FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/fo
|
|
|
4
4
|
import { FilePreviewComponent } from '../file-preview/file-preview.component';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "../master-control.service";
|
|
7
|
-
import * as i2 from "
|
|
8
|
-
import * as i3 from "@angular/
|
|
7
|
+
import * as i2 from "../master.service";
|
|
8
|
+
import * as i3 from "@angular/common";
|
|
9
|
+
import * as i4 from "@angular/forms";
|
|
9
10
|
export class UploadComponent {
|
|
10
11
|
masterService;
|
|
11
12
|
appRef;
|
|
12
13
|
injector;
|
|
14
|
+
masterservice;
|
|
13
15
|
documentUploaderField = input();
|
|
14
|
-
|
|
16
|
+
openQuoteImageObj = input();
|
|
17
|
+
http;
|
|
18
|
+
// openQuoteImageObj : any = {
|
|
19
|
+
// documentId: "E1B17401B6604614AC72714AB1C89BEB",
|
|
20
|
+
// documentCode: "LAPIC",
|
|
21
|
+
// documentName: "LAPIC_1687424860972.png",
|
|
22
|
+
// companyCode: "DL"
|
|
23
|
+
// }
|
|
24
|
+
// configData object for api call
|
|
25
|
+
// {
|
|
26
|
+
// "apiUrl" : "https://uat-directportallife.godigit.com/DirectPortalLife/life/document",
|
|
27
|
+
// "sessionStorageApplicationIdParam": "applicationid",
|
|
28
|
+
// "isSendToken" : false,
|
|
29
|
+
// "tokenCookieParam" : "v3Token"
|
|
30
|
+
// }
|
|
31
|
+
constructor(masterService, appRef, injector, masterservice) {
|
|
15
32
|
this.masterService = masterService;
|
|
16
33
|
this.appRef = appRef;
|
|
17
34
|
this.injector = injector;
|
|
35
|
+
this.masterservice = masterservice;
|
|
36
|
+
}
|
|
37
|
+
ngOnChanges(changes) {
|
|
38
|
+
if ((changes['openQuoteImageObj']) && !this.masterService.checkIfValueIsEmpty(changes['openQuoteImageObj'].currentValue)) {
|
|
39
|
+
if (!this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj()) &&
|
|
40
|
+
!this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentId) &&
|
|
41
|
+
!this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentCode) &&
|
|
42
|
+
!this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentName)) {
|
|
43
|
+
this.uploadedFiles = [
|
|
44
|
+
{
|
|
45
|
+
name: this.openQuoteImageObj().documentName
|
|
46
|
+
}
|
|
47
|
+
];
|
|
48
|
+
}
|
|
49
|
+
}
|
|
18
50
|
}
|
|
19
51
|
field = input.required();
|
|
20
52
|
reactiveFormControlobject = input();
|
|
@@ -93,7 +125,40 @@ export class UploadComponent {
|
|
|
93
125
|
this.fileInput.nativeElement.click();
|
|
94
126
|
}
|
|
95
127
|
}
|
|
96
|
-
previewFile(file, index) {
|
|
128
|
+
previewFile(file, index, event) {
|
|
129
|
+
if (event) {
|
|
130
|
+
event.stopPropagation();
|
|
131
|
+
event.preventDefault();
|
|
132
|
+
}
|
|
133
|
+
// Check if the file is newly uploaded or not
|
|
134
|
+
const isActualFile = file instanceof File && file.size > 0;
|
|
135
|
+
if (!isActualFile &&
|
|
136
|
+
!this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj()) &&
|
|
137
|
+
!this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentId) &&
|
|
138
|
+
!this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentCode) &&
|
|
139
|
+
!this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentName)) {
|
|
140
|
+
// This is the initially loaded file from openQuoteImageObj, fetch it from server
|
|
141
|
+
if (!this.masterService.checkIfValueIsEmpty(this.field().configData) && !this.masterService.checkIfValueIsEmpty(this.field().configData['apiUrl']) && !this.masterService.checkIfValueIsEmpty(this.field().configData['sessionStorageApplicationIdParam'])) {
|
|
142
|
+
let req = {
|
|
143
|
+
documentId: this.openQuoteImageObj().documentId,
|
|
144
|
+
documentCode: this.openQuoteImageObj().documentCode,
|
|
145
|
+
companycode: this.openQuoteImageObj().companyCode,
|
|
146
|
+
};
|
|
147
|
+
this.masterservice.getImage(this.field().configData, req).subscribe((response) => {
|
|
148
|
+
if (response) {
|
|
149
|
+
const previewFile = new File([response], this.openQuoteImageObj().documentName, { type: response.type });
|
|
150
|
+
console.log('Downloaded file for preview:', previewFile);
|
|
151
|
+
this.showFilePreview(previewFile);
|
|
152
|
+
}
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
else {
|
|
157
|
+
this.showFilePreview(file);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
// Helper method to show file preview
|
|
161
|
+
showFilePreview(file) {
|
|
97
162
|
this.filePreviewRef = createComponent(FilePreviewComponent, {
|
|
98
163
|
environmentInjector: this.injector
|
|
99
164
|
});
|
|
@@ -119,14 +184,14 @@ export class UploadComponent {
|
|
|
119
184
|
ngOnDestroy() {
|
|
120
185
|
this.closeFilePreview();
|
|
121
186
|
}
|
|
122
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UploadComponent, deps: [{ token: i1.MasterControlService }, { token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }], target: i0.ɵɵFactoryTarget.Component });
|
|
123
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: UploadComponent, isStandalone: true, selector: "lib-upload", inputs: { documentUploaderField: { classPropertyName: "documentUploaderField", publicName: "documentUploaderField", isSignal: true, isRequired: false, transformFunction: null }, field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, reactiveFormControlobject: { classPropertyName: "reactiveFormControlobject", publicName: "reactiveFormControlobject", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { filesChanged: "filesChanged", fileRemoved: "fileRemoved", filePreview: "filePreview" }, providers: [
|
|
187
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UploadComponent, deps: [{ token: i1.MasterControlService }, { token: i0.ApplicationRef }, { token: i0.EnvironmentInjector }, { token: i2.MasterService }], target: i0.ɵɵFactoryTarget.Component });
|
|
188
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: UploadComponent, isStandalone: true, selector: "lib-upload", inputs: { documentUploaderField: { classPropertyName: "documentUploaderField", publicName: "documentUploaderField", isSignal: true, isRequired: false, transformFunction: null }, openQuoteImageObj: { classPropertyName: "openQuoteImageObj", publicName: "openQuoteImageObj", isSignal: true, isRequired: false, transformFunction: null }, field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, reactiveFormControlobject: { classPropertyName: "reactiveFormControlobject", publicName: "reactiveFormControlobject", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { filesChanged: "filesChanged", fileRemoved: "fileRemoved", filePreview: "filePreview" }, providers: [
|
|
124
189
|
{
|
|
125
190
|
provide: NG_VALUE_ACCESSOR,
|
|
126
191
|
useExisting: UploadComponent,
|
|
127
192
|
multi: true
|
|
128
193
|
}
|
|
129
|
-
], viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], ngImport: i0, template: "<label class=\"field-lable upload-label\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\">{{field()?.label}}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n @if(reactiveFormControlobject()) {\n <input\n hidden\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldName\"\n [id]=\"field()?.fieldName\"\n [multiple]=\"field()?.configData?.multiple\"\n [accept]=\"field()?.configData?.accept\"\n #fileInput\n (change)=\"onFileSelected($event)\"\n (click)=\"fileInput.value = ''\"\n [required]=\"field()?.validators?.isRequired\"\n [disabled]=\"field()?.isDisable\"\n [formControl]=\"reactiveFormControlobject()\"\n />\n }@else {\n <input\n hidden\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldName\"\n [id]=\"field()?.fieldName\"\n [multiple]=\"field()?.configData?.multiple\"\n [accept]=\"field()?.configData?.accept\"\n #fileInput\n (change)=\"onFileSelected($event)\"\n (click)=\"fileInput.value = ''\"\n [required]=\"field()?.validators?.isRequired\"\n [disabled]=\"field()?.isDisable\"\n />\n }\n <button\n type=\"button\"\n class=\"upload-btn\"\n (click)=\"triggerFileInput()\"\n [ngClass]=\"field()?.label ? 'lightbackground' : 'successBackground'\"\n *ngIf=\"field() && field()?.isVisible\"\n [disabled]=\"field()?.isDisable\"\n [ngStyle]=\"{\n'--upload-width': field()?.controlStyle?.width ,\n'--upload-border-radius': field()?.controlStyle?.borderRadius ,\n'--upload-border-color': field()?.controlStyle?.borderColor ,\n'--upload-border-width': field()?.controlStyle?.borderWidth ,\n'--upload-border-style': field()?.controlStyle?.borderStyle ,\n'--upload-background-color': field()?.controlStyle?.background ,\n'--upload-focus-border-color': field()?.controlStyle?.focusBorderColor ,\n'--upload-focus-background-color': field()?.controlStyle?.focusBackground ,\n}\"\n >\n <ng-container *ngIf=\"field()?.label && !hasFiles(); else fileUploadedTemplate\">\n <span class=\"upload-icon\">\n <span\n ><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n <span class=\"upload-text\" [ngStyle]=\"{\n'--upload-font-color': field()?.controlStyle?.color ,\n'--upload-font-size': field()?.controlStyle?.fontSize ,\n'--upload-font-weight': field()?.controlStyle?.fontWeight,\n'--upload-focus-font-color': field()?.controlStyle?.focusColor ,\n}\">{{ field()?.placeHolder }} <span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></span>\n </span>\n </ng-container>\n <ng-template #fileUploadedTemplate>\n <div *ngFor=\"let file of uploadedFiles; let i = index\" class=\"uploaded-file d-flex gap-4\" style=\"transform: translate(0px, -3px);\">\n <span class=\"mt-2 right-icon\" style=\" white-space: nowrap !important;\n overflow: hidden !important;\n text-overflow: ellipsis !important;\">\n <span><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n <span [title]=\"file.name\">{{ file.name }}</span>\n </span>\n <div class=\"mt-2 left-icon\">\n <span (click)=\"previewFile(file, i
|
|
194
|
+
], viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<label class=\"field-lable upload-label\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\">{{field()?.label}}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n @if(reactiveFormControlobject()) {\n <input\n hidden\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldName\"\n [id]=\"field()?.fieldName\"\n [multiple]=\"field()?.configData?.multiple\"\n [accept]=\"field()?.configData?.accept\"\n #fileInput\n (change)=\"onFileSelected($event)\"\n (click)=\"fileInput.value = ''\"\n [required]=\"field()?.validators?.isRequired\"\n [disabled]=\"field()?.isDisable\"\n [formControl]=\"reactiveFormControlobject()\"\n />\n }@else {\n <input\n hidden\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldName\"\n [id]=\"field()?.fieldName\"\n [multiple]=\"field()?.configData?.multiple\"\n [accept]=\"field()?.configData?.accept\"\n #fileInput\n (change)=\"onFileSelected($event)\"\n (click)=\"fileInput.value = ''\"\n [required]=\"field()?.validators?.isRequired\"\n [disabled]=\"field()?.isDisable\"\n />\n }\n <button\n type=\"button\"\n class=\"upload-btn\"\n (click)=\"triggerFileInput()\"\n [ngClass]=\"field()?.label ? 'lightbackground' : 'successBackground'\"\n *ngIf=\"field() && field()?.isVisible\"\n [disabled]=\"field()?.isDisable\"\n [ngStyle]=\"{\n'--upload-width': field()?.controlStyle?.width ,\n'--upload-border-radius': field()?.controlStyle?.borderRadius ,\n'--upload-border-color': field()?.controlStyle?.borderColor ,\n'--upload-border-width': field()?.controlStyle?.borderWidth ,\n'--upload-border-style': field()?.controlStyle?.borderStyle ,\n'--upload-background-color': field()?.controlStyle?.background ,\n'--upload-focus-border-color': field()?.controlStyle?.focusBorderColor ,\n'--upload-focus-background-color': field()?.controlStyle?.focusBackground ,\n}\"\n >\n <ng-container *ngIf=\"field()?.label && !hasFiles(); else fileUploadedTemplate\">\n <span class=\"upload-icon\">\n <span\n ><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n <span class=\"upload-text\" [ngStyle]=\"{\n'--upload-font-color': field()?.controlStyle?.color ,\n'--upload-font-size': field()?.controlStyle?.fontSize ,\n'--upload-font-weight': field()?.controlStyle?.fontWeight,\n'--upload-focus-font-color': field()?.controlStyle?.focusColor ,\n}\">{{ field()?.placeHolder }} <span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></span>\n </span>\n </ng-container>\n <ng-template #fileUploadedTemplate>\n <div *ngFor=\"let file of uploadedFiles; let i = index\" class=\"uploaded-file d-flex gap-4\" style=\"transform: translate(0px, -3px);\">\n <span class=\"mt-2 right-icon\" style=\" white-space: nowrap !important;\n overflow: hidden !important;\n text-overflow: ellipsis !important;\">\n <span><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n <span [title]=\"file.name\">{{ file.name }}</span>\n </span>\n <div class=\"mt-2 left-icon\">\n <span (click)=\"previewFile(file, i, $event)\" style=\"cursor: pointer;\"><img src=\"https://cdn.godigit.com/retail-life/visibility-oui.svg\" alt=\"\"/></span>\n <span (click)=\"removeFile(i, $event)\" style=\"cursor: pointer;\">\n <img src=\"https://cdn.godigit.com/retail-life/delete-oui.svg\" alt=\"\"/>\n </span>\n </div>\n </div>\n </ng-template>\n </button>\n <div class=\"upload-info\" *ngIf=\"field() && field()?.isVisible && field()?.configData?.subText\">{{field()?.configData?.subText}}</div>\n", styles: ["*{font-family:mulish!important}.field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:0!important}.upload-label{opacity:1}.upload-btn{width:100%!important;height:48px!important;padding:10px;border-radius:.5rem}.upload-btn{width:var(--upload-width , 100%)!important;border-radius:var(--upload-border-radius , 8px)!important}.lightbackground{border-color:#999;border-width:1px;border-style:dashed;background:#fff;color:#444;font-size:14px;font-weight:700}.lightbackground{border-color:var(--upload-border-color , #999)!important;border-width:var(--upload-border-width , 1px)!important;border-style:var(--upload-border-style , dashed)!important;background:var(--upload-background-color , #ffffff)!important}.successBackground{border-color:var(--upload-focus-border-color , #ddd)!important;background:var(--upload-focus-background-color , #fafafa)!important;color:var(--upload-focus-font-color , #444)!important}.successBackground{border:1px dashed #ddd;background:#fafafa;color:#444;display:flex;justify-content:space-between}.upload-icon{display:flex;justify-content:center;gap:7px}.upload-text{color:#444!important;font-weight:700!important;font-size:14px!important}.upload-text{color:var(--upload-font-color , #444)!important;font-size:var( --upload-font-size , 14px)!important;font-weight:var(--upload-font-weight , 700)!important}.right-icon{display:flex;gap:10px;margin-left:.5em}.left-icon{display:flex;gap:15px;margin-right:1em}.upload-info{font-size:10px;font-weight:500;font-family:Mulish!important;letter-spacing:0px;color:#444}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] });
|
|
130
195
|
}
|
|
131
196
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UploadComponent, decorators: [{
|
|
132
197
|
type: Component,
|
|
@@ -140,8 +205,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
140
205
|
useExisting: UploadComponent,
|
|
141
206
|
multi: true
|
|
142
207
|
}
|
|
143
|
-
], template: "<label class=\"field-lable upload-label\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\">{{field()?.label}}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n @if(reactiveFormControlobject()) {\n <input\n hidden\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldName\"\n [id]=\"field()?.fieldName\"\n [multiple]=\"field()?.configData?.multiple\"\n [accept]=\"field()?.configData?.accept\"\n #fileInput\n (change)=\"onFileSelected($event)\"\n (click)=\"fileInput.value = ''\"\n [required]=\"field()?.validators?.isRequired\"\n [disabled]=\"field()?.isDisable\"\n [formControl]=\"reactiveFormControlobject()\"\n />\n }@else {\n <input\n hidden\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldName\"\n [id]=\"field()?.fieldName\"\n [multiple]=\"field()?.configData?.multiple\"\n [accept]=\"field()?.configData?.accept\"\n #fileInput\n (change)=\"onFileSelected($event)\"\n (click)=\"fileInput.value = ''\"\n [required]=\"field()?.validators?.isRequired\"\n [disabled]=\"field()?.isDisable\"\n />\n }\n <button\n type=\"button\"\n class=\"upload-btn\"\n (click)=\"triggerFileInput()\"\n [ngClass]=\"field()?.label ? 'lightbackground' : 'successBackground'\"\n *ngIf=\"field() && field()?.isVisible\"\n [disabled]=\"field()?.isDisable\"\n [ngStyle]=\"{\n'--upload-width': field()?.controlStyle?.width ,\n'--upload-border-radius': field()?.controlStyle?.borderRadius ,\n'--upload-border-color': field()?.controlStyle?.borderColor ,\n'--upload-border-width': field()?.controlStyle?.borderWidth ,\n'--upload-border-style': field()?.controlStyle?.borderStyle ,\n'--upload-background-color': field()?.controlStyle?.background ,\n'--upload-focus-border-color': field()?.controlStyle?.focusBorderColor ,\n'--upload-focus-background-color': field()?.controlStyle?.focusBackground ,\n}\"\n >\n <ng-container *ngIf=\"field()?.label && !hasFiles(); else fileUploadedTemplate\">\n <span class=\"upload-icon\">\n <span\n ><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n <span class=\"upload-text\" [ngStyle]=\"{\n'--upload-font-color': field()?.controlStyle?.color ,\n'--upload-font-size': field()?.controlStyle?.fontSize ,\n'--upload-font-weight': field()?.controlStyle?.fontWeight,\n'--upload-focus-font-color': field()?.controlStyle?.focusColor ,\n}\">{{ field()?.placeHolder }} <span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></span>\n </span>\n </ng-container>\n <ng-template #fileUploadedTemplate>\n <div *ngFor=\"let file of uploadedFiles; let i = index\" class=\"uploaded-file d-flex gap-4\" style=\"transform: translate(0px, -3px);\">\n <span class=\"mt-2 right-icon\" style=\" white-space: nowrap !important;\n overflow: hidden !important;\n text-overflow: ellipsis !important;\">\n <span><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n <span [title]=\"file.name\">{{ file.name }}</span>\n </span>\n <div class=\"mt-2 left-icon\">\n <span (click)=\"previewFile(file, i
|
|
144
|
-
}], ctorParameters: () => [{ type: i1.MasterControlService }, { type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }], propDecorators: { fileInput: [{
|
|
208
|
+
], template: "<label class=\"field-lable upload-label\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\">{{field()?.label}}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n @if(reactiveFormControlobject()) {\n <input\n hidden\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldName\"\n [id]=\"field()?.fieldName\"\n [multiple]=\"field()?.configData?.multiple\"\n [accept]=\"field()?.configData?.accept\"\n #fileInput\n (change)=\"onFileSelected($event)\"\n (click)=\"fileInput.value = ''\"\n [required]=\"field()?.validators?.isRequired\"\n [disabled]=\"field()?.isDisable\"\n [formControl]=\"reactiveFormControlobject()\"\n />\n }@else {\n <input\n hidden\n [type]=\"field()?.controlType\"\n [name]=\"field()?.fieldName\"\n [id]=\"field()?.fieldName\"\n [multiple]=\"field()?.configData?.multiple\"\n [accept]=\"field()?.configData?.accept\"\n #fileInput\n (change)=\"onFileSelected($event)\"\n (click)=\"fileInput.value = ''\"\n [required]=\"field()?.validators?.isRequired\"\n [disabled]=\"field()?.isDisable\"\n />\n }\n <button\n type=\"button\"\n class=\"upload-btn\"\n (click)=\"triggerFileInput()\"\n [ngClass]=\"field()?.label ? 'lightbackground' : 'successBackground'\"\n *ngIf=\"field() && field()?.isVisible\"\n [disabled]=\"field()?.isDisable\"\n [ngStyle]=\"{\n'--upload-width': field()?.controlStyle?.width ,\n'--upload-border-radius': field()?.controlStyle?.borderRadius ,\n'--upload-border-color': field()?.controlStyle?.borderColor ,\n'--upload-border-width': field()?.controlStyle?.borderWidth ,\n'--upload-border-style': field()?.controlStyle?.borderStyle ,\n'--upload-background-color': field()?.controlStyle?.background ,\n'--upload-focus-border-color': field()?.controlStyle?.focusBorderColor ,\n'--upload-focus-background-color': field()?.controlStyle?.focusBackground ,\n}\"\n >\n <ng-container *ngIf=\"field()?.label && !hasFiles(); else fileUploadedTemplate\">\n <span class=\"upload-icon\">\n <span\n ><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n <span class=\"upload-text\" [ngStyle]=\"{\n'--upload-font-color': field()?.controlStyle?.color ,\n'--upload-font-size': field()?.controlStyle?.fontSize ,\n'--upload-font-weight': field()?.controlStyle?.fontWeight,\n'--upload-focus-font-color': field()?.controlStyle?.focusColor ,\n}\">{{ field()?.placeHolder }} <span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></span>\n </span>\n </ng-container>\n <ng-template #fileUploadedTemplate>\n <div *ngFor=\"let file of uploadedFiles; let i = index\" class=\"uploaded-file d-flex gap-4\" style=\"transform: translate(0px, -3px);\">\n <span class=\"mt-2 right-icon\" style=\" white-space: nowrap !important;\n overflow: hidden !important;\n text-overflow: ellipsis !important;\">\n <span><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n <span [title]=\"file.name\">{{ file.name }}</span>\n </span>\n <div class=\"mt-2 left-icon\">\n <span (click)=\"previewFile(file, i, $event)\" style=\"cursor: pointer;\"><img src=\"https://cdn.godigit.com/retail-life/visibility-oui.svg\" alt=\"\"/></span>\n <span (click)=\"removeFile(i, $event)\" style=\"cursor: pointer;\">\n <img src=\"https://cdn.godigit.com/retail-life/delete-oui.svg\" alt=\"\"/>\n </span>\n </div>\n </div>\n </ng-template>\n </button>\n <div class=\"upload-info\" *ngIf=\"field() && field()?.isVisible && field()?.configData?.subText\">{{field()?.configData?.subText}}</div>\n", styles: ["*{font-family:mulish!important}.field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:0!important}.upload-label{opacity:1}.upload-btn{width:100%!important;height:48px!important;padding:10px;border-radius:.5rem}.upload-btn{width:var(--upload-width , 100%)!important;border-radius:var(--upload-border-radius , 8px)!important}.lightbackground{border-color:#999;border-width:1px;border-style:dashed;background:#fff;color:#444;font-size:14px;font-weight:700}.lightbackground{border-color:var(--upload-border-color , #999)!important;border-width:var(--upload-border-width , 1px)!important;border-style:var(--upload-border-style , dashed)!important;background:var(--upload-background-color , #ffffff)!important}.successBackground{border-color:var(--upload-focus-border-color , #ddd)!important;background:var(--upload-focus-background-color , #fafafa)!important;color:var(--upload-focus-font-color , #444)!important}.successBackground{border:1px dashed #ddd;background:#fafafa;color:#444;display:flex;justify-content:space-between}.upload-icon{display:flex;justify-content:center;gap:7px}.upload-text{color:#444!important;font-weight:700!important;font-size:14px!important}.upload-text{color:var(--upload-font-color , #444)!important;font-size:var( --upload-font-size , 14px)!important;font-weight:var(--upload-font-weight , 700)!important}.right-icon{display:flex;gap:10px;margin-left:.5em}.left-icon{display:flex;gap:15px;margin-right:1em}.upload-info{font-size:10px;font-weight:500;font-family:Mulish!important;letter-spacing:0px;color:#444}\n"] }]
|
|
209
|
+
}], ctorParameters: () => [{ type: i1.MasterControlService }, { type: i0.ApplicationRef }, { type: i0.EnvironmentInjector }, { type: i2.MasterService }], propDecorators: { fileInput: [{
|
|
145
210
|
type: ViewChild,
|
|
146
211
|
args: ['fileInput']
|
|
147
212
|
}], filesChanged: [{
|
|
@@ -151,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
151
216
|
}], filePreview: [{
|
|
152
217
|
type: Output
|
|
153
218
|
}] } });
|
|
154
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/upload/upload.component.ts","../../../../../projects/master-control/src/lib/upload/upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, input, ViewChild, ElementRef, Output, EventEmitter, ComponentRef, EnvironmentInjector, ApplicationRef, createComponent, OnInit } from '@angular/core';\nimport { MasterControlService } from '../master-control.service';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { FilePreviewComponent } from '../file-preview/file-preview.component';\n\n@Component({\n  selector: 'lib-upload',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule\n  ],\n  templateUrl: './upload.component.html',\n  styleUrl: './upload.component.css',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: UploadComponent,\n      multi: true\n    }\n  ]\n})\nexport class UploadComponent implements ControlValueAccessor {\n  documentUploaderField = input<any>();\n  constructor(public masterService : MasterControlService, public appRef: ApplicationRef,\n  public injector: EnvironmentInjector){}\n  field : any = input.required<any>();\n  reactiveFormControlobject : any = input<any>();\n\n  @ViewChild('fileInput') fileInput!: ElementRef<HTMLInputElement>;\n\n  @Output() filesChanged = new EventEmitter<File[]>();\n  @Output() fileRemoved = new EventEmitter<{ file: File, index: number }>();\n  @Output() filePreview = new EventEmitter<{ file: File, index: number }>();\n  public filePreviewRef: ComponentRef<FilePreviewComponent> | null = null;\n  // ControlValueAccessor properties\n  uploadedFiles: File[] = [];\n  value: any = null;\n  _onChange: any = (value: any) => {};\n  _onTouched: any = () => {};\n  disabled: any = false;\n\n  // ControlValueAccessor implementation\n  writeValue(obj: any) {\n    this.value = obj;\n    if (obj && Array.isArray(obj)) {\n      this.uploadedFiles = obj;\n    } else if (obj) {\n      this.uploadedFiles = [obj];\n    } else {\n      this.uploadedFiles = [];\n    }\n  }\n\n  registerOnChange(fn: any) {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this._onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: any) {\n    this.disabled = isDisabled;\n  }\n\n  // File upload handling\n  onFileSelected(event: any) {\n    const files = event.target.files;\n    if (files && files.length > 0) {\n      if (this.field()?.multiple) {\n        this.uploadedFiles = Array.from(files);\n        this.value = this.uploadedFiles;\n      } else {\n        this.uploadedFiles = [files[0]];\n        this.value = files[0];\n      }\n      this._onChange(this.value);\n      this._onTouched();\n    }\n    this.filesChanged.emit(this.uploadedFiles);\n  }\n\n  removeFile(index: any, event?: Event) {\n    if (event) {\n    event.stopPropagation();\n    event.preventDefault();\n  }\n    const removedFile = this.uploadedFiles[index];\n    this.uploadedFiles.splice(index, 1);\n    if (this.field()?.multiple) {\n      this.value = [...this.uploadedFiles];\n    } else {\n      this.value = this.uploadedFiles.length > 0 ? this.uploadedFiles[0] : null;\n    }\n    this._onChange(this.value);\n    this.fileRemoved.emit({ file: removedFile, index });\n    this.filesChanged.emit(this.uploadedFiles);\n  }\n\n  hasFiles(): any {\n    return this.uploadedFiles.length > 0;\n  }\n\n  triggerFileInput(): void {\n    if (this.fileInput) {\n      this.fileInput.nativeElement.click();\n    }\n  }\n\npreviewFile(file: File, index: number): void {\n    this.filePreviewRef = createComponent(FilePreviewComponent, {\n      environmentInjector: this.injector\n    });\n    this.filePreviewRef.setInput('field', this.field());\n    this.filePreviewRef.setInput('file', file);\n    this.filePreviewRef.instance.closed.subscribe(() => {\n      this.closeFilePreview();\n    });\n    document.body.appendChild(this.filePreviewRef.location.nativeElement);\n    this.appRef.attachView(this.filePreviewRef.hostView);\n  }\n\n  closeFilePreview(): void {\n    if (this.filePreviewRef) {\n      const element = this.filePreviewRef.location.nativeElement;\n      if (element.parentNode) {\n        element.parentNode.removeChild(element);\n      }\n      this.appRef.detachView(this.filePreviewRef.hostView);\n      this.filePreviewRef.destroy();\n      this.filePreviewRef = null;\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.closeFilePreview();\n  }\n}\n","<label class=\"field-lable upload-label\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\">{{field()?.label}}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n  @if(reactiveFormControlobject()) {\n  <input\n    hidden\n    [type]=\"field()?.controlType\"\n    [name]=\"field()?.fieldName\"\n    [id]=\"field()?.fieldName\"\n    [multiple]=\"field()?.configData?.multiple\"\n    [accept]=\"field()?.configData?.accept\"\n    #fileInput\n    (change)=\"onFileSelected($event)\"\n    (click)=\"fileInput.value = ''\"\n    [required]=\"field()?.validators?.isRequired\"\n    [disabled]=\"field()?.isDisable\"\n    [formControl]=\"reactiveFormControlobject()\"\n  />\n  }@else {\n  <input\n    hidden\n    [type]=\"field()?.controlType\"\n    [name]=\"field()?.fieldName\"\n    [id]=\"field()?.fieldName\"\n    [multiple]=\"field()?.configData?.multiple\"\n    [accept]=\"field()?.configData?.accept\"\n    #fileInput\n    (change)=\"onFileSelected($event)\"\n    (click)=\"fileInput.value = ''\"\n    [required]=\"field()?.validators?.isRequired\"\n    [disabled]=\"field()?.isDisable\"\n  />\n  }\n  <button\n    type=\"button\"\n    class=\"upload-btn\"\n    (click)=\"triggerFileInput()\"\n    [ngClass]=\"field()?.label ? 'lightbackground' : 'successBackground'\"\n    *ngIf=\"field() && field()?.isVisible\"\n    [disabled]=\"field()?.isDisable\"\n     [ngStyle]=\"{\n'--upload-width': field()?.controlStyle?.width ,\n'--upload-border-radius': field()?.controlStyle?.borderRadius ,\n'--upload-border-color': field()?.controlStyle?.borderColor ,\n'--upload-border-width': field()?.controlStyle?.borderWidth ,\n'--upload-border-style': field()?.controlStyle?.borderStyle ,\n'--upload-background-color': field()?.controlStyle?.background ,\n'--upload-focus-border-color': field()?.controlStyle?.focusBorderColor ,\n'--upload-focus-background-color': field()?.controlStyle?.focusBackground ,\n}\"\n  >\n    <ng-container *ngIf=\"field()?.label && !hasFiles(); else fileUploadedTemplate\">\n      <span class=\"upload-icon\">\n        <span\n          ><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n        <span class=\"upload-text\" [ngStyle]=\"{\n'--upload-font-color': field()?.controlStyle?.color ,\n'--upload-font-size': field()?.controlStyle?.fontSize ,\n'--upload-font-weight': field()?.controlStyle?.fontWeight,\n'--upload-focus-font-color': field()?.controlStyle?.focusColor ,\n}\">{{ field()?.placeHolder }} <span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></span>\n      </span>\n    </ng-container>\n    <ng-template #fileUploadedTemplate>\n      <div *ngFor=\"let file of uploadedFiles; let i = index\" class=\"uploaded-file d-flex gap-4\" style=\"transform: translate(0px, -3px);\">\n        <span class=\"mt-2 right-icon\" style=\" white-space: nowrap !important;\n    overflow: hidden !important;\n    text-overflow: ellipsis !important;\">\n          <span><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n          <span [title]=\"file.name\">{{ file.name }}</span>\n        </span>\n        <div class=\"mt-2 left-icon\">\n          <span (click)=\"previewFile(file, i);$event.stopPropagation()\"><img src=\"https://cdn.godigit.com/retail-life/visibility-oui.svg\" alt=\"\"/></span>\n          <span (click)=\"removeFile(i, $event);$event.stopPropagation()\" style=\"cursor: pointer;\">\n            <img src=\"https://cdn.godigit.com/retail-life/delete-oui.svg\" alt=\"\"/>\n          </span>\n        </div>\n      </div>\n    </ng-template>\n  </button>\n  <div class=\"upload-info\" *ngIf=\"field() && field()?.isVisible && field()?.configData?.subText\">{{field()?.configData?.subText}}</div>\n"]}
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/upload/upload.component.ts","../../../../../projects/master-control/src/lib/upload/upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, input, ViewChild, ElementRef, Output, EventEmitter, ComponentRef, EnvironmentInjector, ApplicationRef, createComponent, OnInit, SimpleChanges } from '@angular/core';\nimport { MasterControlService } from '../master-control.service';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { FilePreviewComponent } from '../file-preview/file-preview.component';\nimport { MasterService } from '../master.service';\n\n@Component({\n  selector: 'lib-upload',\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    ReactiveFormsModule\n  ],\n  templateUrl: './upload.component.html',\n  styleUrl: './upload.component.css',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: UploadComponent,\n      multi: true\n    }\n  ]\n})\nexport class UploadComponent implements ControlValueAccessor {\n  documentUploaderField = input<any>();\n  openQuoteImageObj : any = input<any>();\n  http: any;\n  // openQuoteImageObj : any = {\n  //   documentId: \"E1B17401B6604614AC72714AB1C89BEB\",\n  //   documentCode: \"LAPIC\",\n  //   documentName: \"LAPIC_1687424860972.png\",\n  //   companyCode: \"DL\"\n  // }\n\n  // configData object for api call\n\n//   {\n//   \"apiUrl\" : \"https://uat-directportallife.godigit.com/DirectPortalLife/life/document\",\n//   \"sessionStorageApplicationIdParam\": \"applicationid\",\n//   \"isSendToken\" : false,\n//   \"tokenCookieParam\" : \"v3Token\"\n// }\n  constructor(public masterService : MasterControlService, public appRef: ApplicationRef,\n  public injector: EnvironmentInjector, public masterservice : MasterService){}\n\n  ngOnChanges(changes: SimpleChanges) {\n    if ( (changes['openQuoteImageObj']) && !this.masterService.checkIfValueIsEmpty(changes['openQuoteImageObj'].currentValue) ) {\n      if (\n        !this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj()) &&\n        !this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentId) &&\n        !this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentCode) &&\n        !this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentName)\n      ) {\n        this.uploadedFiles = [\n          {\n            name: this.openQuoteImageObj().documentName\n          }\n        ];\n      }\n\n\n    }\n  }\n  field : any = input.required<any>();\n  reactiveFormControlobject : any = input<any>();\n\n  @ViewChild('fileInput') fileInput!: ElementRef<HTMLInputElement>;\n\n  @Output() filesChanged = new EventEmitter<File[]>();\n  @Output() fileRemoved = new EventEmitter<{ file: File, index: number }>();\n  @Output() filePreview = new EventEmitter<{ file: File, index: number }>();\n  public filePreviewRef: ComponentRef<FilePreviewComponent> | null = null;\n  // ControlValueAccessor properties\n  uploadedFiles: any = [];\n  value: any = null;\n  _onChange: any = (value: any) => {};\n  _onTouched: any = () => {};\n  disabled: any = false;\n\n\n  // ControlValueAccessor implementation\n  writeValue(obj: any) {\n    this.value = obj;\n    if (obj && Array.isArray(obj)) {\n      this.uploadedFiles = obj;\n    } else if (obj) {\n      this.uploadedFiles = [obj];\n    } else {\n      this.uploadedFiles = [];\n    }\n  }\n\n  registerOnChange(fn: any) {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this._onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: any) {\n    this.disabled = isDisabled;\n  }\n\n  // File upload handling\n  onFileSelected(event: any) {\n    const files = event.target.files;\n    if (files && files.length > 0) {\n      if (this.field()?.multiple) {\n        this.uploadedFiles = Array.from(files);\n        this.value = this.uploadedFiles;\n      } else {\n        this.uploadedFiles = [files[0]];\n        this.value = files[0];\n      }\n      this._onChange(this.value);\n      this._onTouched();\n    }\n    this.filesChanged.emit(this.uploadedFiles);\n  }\n\n  removeFile(index: any, event?: Event) {\n    if (event) {\n    event.stopPropagation();\n    event.preventDefault();\n  }\n    const removedFile = this.uploadedFiles[index];\n    this.uploadedFiles.splice(index, 1);\n    if (this.field()?.multiple) {\n      this.value = [...this.uploadedFiles];\n    } else {\n      this.value = this.uploadedFiles.length > 0 ? this.uploadedFiles[0] : null;\n    }\n    this._onChange(this.value);\n    this.fileRemoved.emit({ file: removedFile, index });\n    this.filesChanged.emit(this.uploadedFiles);\n  }\n\n  hasFiles(): any {\n    return this.uploadedFiles.length > 0;\n  }\n\n  triggerFileInput(): void {\n    if (this.fileInput) {\n      this.fileInput.nativeElement.click();\n    }\n  }\n\npreviewFile(file: File, index: number, event?: Event): void {\n  if (event) {\n    event.stopPropagation();\n    event.preventDefault();\n  }\n\n  // Check if the file is newly uploaded or not\n  const isActualFile = file instanceof File && file.size > 0;\n\n  if (\n    !isActualFile &&\n    !this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj()) &&\n    !this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentId) &&\n    !this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentCode) &&\n    !this.masterService.checkIfValueIsEmpty(this.openQuoteImageObj().documentName)\n  ) {\n    // This is the initially loaded file from openQuoteImageObj, fetch it from server\n    if(!this.masterService.checkIfValueIsEmpty(this.field().configData) && !this.masterService.checkIfValueIsEmpty(this.field().configData['apiUrl']) &&  !this.masterService.checkIfValueIsEmpty(this.field().configData['sessionStorageApplicationIdParam'])) {\n      let req : any = {\n        documentId: this.openQuoteImageObj().documentId,\n        documentCode: this.openQuoteImageObj().documentCode,\n        companycode: this.openQuoteImageObj().companyCode,\n      }\n      this.masterservice.getImage(this.field().configData,req).subscribe((response : any) => {\n        if (response) {\n          const previewFile = new File([response], this.openQuoteImageObj().documentName, { type: response.type });\n          console.log('Downloaded file for preview:', previewFile);\n          this.showFilePreview(previewFile);\n        }\n      });\n    }\n  } else {\n    this.showFilePreview(file);\n  }\n}\n\n  // Helper method to show file preview\n  private showFilePreview(file: File): void {\n    this.filePreviewRef = createComponent(FilePreviewComponent, {\n      environmentInjector: this.injector\n    });\n    this.filePreviewRef.setInput('field', this.field());\n    this.filePreviewRef.setInput('file', file);\n    this.filePreviewRef.instance.closed.subscribe(() => {\n      this.closeFilePreview();\n    });\n    document.body.appendChild(this.filePreviewRef.location.nativeElement);\n    this.appRef.attachView(this.filePreviewRef.hostView);\n  }\n\n  closeFilePreview(): void {\n    if (this.filePreviewRef) {\n      const element = this.filePreviewRef.location.nativeElement;\n      if (element.parentNode) {\n        element.parentNode.removeChild(element);\n      }\n      this.appRef.detachView(this.filePreviewRef.hostView);\n      this.filePreviewRef.destroy();\n      this.filePreviewRef = null;\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.closeFilePreview();\n  }\n}\n","<label class=\"field-lable upload-label\" *ngIf=\"field() && field()?.isVisible && field()?.isShowLabel\">{{field()?.label}}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n  @if(reactiveFormControlobject()) {\n  <input\n    hidden\n    [type]=\"field()?.controlType\"\n    [name]=\"field()?.fieldName\"\n    [id]=\"field()?.fieldName\"\n    [multiple]=\"field()?.configData?.multiple\"\n    [accept]=\"field()?.configData?.accept\"\n    #fileInput\n    (change)=\"onFileSelected($event)\"\n    (click)=\"fileInput.value = ''\"\n    [required]=\"field()?.validators?.isRequired\"\n    [disabled]=\"field()?.isDisable\"\n    [formControl]=\"reactiveFormControlobject()\"\n  />\n  }@else {\n  <input\n    hidden\n    [type]=\"field()?.controlType\"\n    [name]=\"field()?.fieldName\"\n    [id]=\"field()?.fieldName\"\n    [multiple]=\"field()?.configData?.multiple\"\n    [accept]=\"field()?.configData?.accept\"\n    #fileInput\n    (change)=\"onFileSelected($event)\"\n    (click)=\"fileInput.value = ''\"\n    [required]=\"field()?.validators?.isRequired\"\n    [disabled]=\"field()?.isDisable\"\n  />\n  }\n  <button\n    type=\"button\"\n    class=\"upload-btn\"\n    (click)=\"triggerFileInput()\"\n    [ngClass]=\"field()?.label ? 'lightbackground' : 'successBackground'\"\n    *ngIf=\"field() && field()?.isVisible\"\n    [disabled]=\"field()?.isDisable\"\n     [ngStyle]=\"{\n'--upload-width': field()?.controlStyle?.width ,\n'--upload-border-radius': field()?.controlStyle?.borderRadius ,\n'--upload-border-color': field()?.controlStyle?.borderColor ,\n'--upload-border-width': field()?.controlStyle?.borderWidth ,\n'--upload-border-style': field()?.controlStyle?.borderStyle ,\n'--upload-background-color': field()?.controlStyle?.background ,\n'--upload-focus-border-color': field()?.controlStyle?.focusBorderColor ,\n'--upload-focus-background-color': field()?.controlStyle?.focusBackground ,\n}\"\n  >\n    <ng-container *ngIf=\"field()?.label && !hasFiles(); else fileUploadedTemplate\">\n      <span class=\"upload-icon\">\n        <span\n          ><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n        <span class=\"upload-text\" [ngStyle]=\"{\n'--upload-font-color': field()?.controlStyle?.color ,\n'--upload-font-size': field()?.controlStyle?.fontSize ,\n'--upload-font-weight': field()?.controlStyle?.fontWeight,\n'--upload-focus-font-color': field()?.controlStyle?.focusColor ,\n}\">{{ field()?.placeHolder }} <span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></span>\n      </span>\n    </ng-container>\n    <ng-template #fileUploadedTemplate>\n      <div *ngFor=\"let file of uploadedFiles; let i = index\" class=\"uploaded-file d-flex gap-4\" style=\"transform: translate(0px, -3px);\">\n        <span class=\"mt-2 right-icon\" style=\" white-space: nowrap !important;\n    overflow: hidden !important;\n    text-overflow: ellipsis !important;\">\n          <span><img [src]=\"field()?.imageUrl\" alt=\"\"/></span>\n          <span [title]=\"file.name\">{{ file.name }}</span>\n        </span>\n        <div class=\"mt-2 left-icon\">\n          <span (click)=\"previewFile(file, i, $event)\" style=\"cursor: pointer;\"><img src=\"https://cdn.godigit.com/retail-life/visibility-oui.svg\" alt=\"\"/></span>\n          <span (click)=\"removeFile(i, $event)\" style=\"cursor: pointer;\">\n            <img src=\"https://cdn.godigit.com/retail-life/delete-oui.svg\" alt=\"\"/>\n          </span>\n        </div>\n      </div>\n    </ng-template>\n  </button>\n  <div class=\"upload-info\" *ngIf=\"field() && field()?.isVisible && field()?.configData?.subText\">{{field()?.configData?.subText}}</div>\n"]}
|