barsa-develop-components 0.0.2 → 1.0.248
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/esm2020/lib/accept-reject/accept-reject.component.mjs +69 -0
- package/esm2020/lib/avatar/avatar.component.mjs +3 -3
- package/esm2020/lib/barcode-reader/barcode-reader.component.mjs +1 -1
- package/esm2020/lib/barcode-reader-dialog/barcode-reader-dialog.component.mjs +1 -1
- package/esm2020/lib/barcode-reader-video/barcode-reader-video.component.mjs +1 -1
- package/esm2020/lib/barsa-develop-components.module.mjs +36 -4
- package/esm2020/lib/barsa-document-list-item/barsa-document-list-item.component.mjs +104 -0
- package/esm2020/lib/barsa-documents/barsa-documents.component.mjs +173 -0
- package/esm2020/lib/card-content-image-and-title/card-content-image-and-title.component.mjs +3 -3
- package/esm2020/lib/card-content-line-chart/card-content-line-chart.component.mjs +3 -3
- package/esm2020/lib/card-header-kpi/card-header-kpi.component.mjs +3 -3
- package/esm2020/lib/card-header-logo-title-subtitle/card-header-logo-title-subtitle.component.mjs +1 -1
- package/esm2020/lib/checkbox-button/checkbox-button.component.mjs +3 -3
- package/esm2020/lib/enum-info-micro-proccess-flow/enum-info-micro-proccess-flow.component.mjs +3 -3
- package/esm2020/lib/footer/footer.component.mjs +41 -0
- package/esm2020/lib/form-chart-content/form-chart-content.component.mjs +3 -3
- package/esm2020/lib/form-content-quick-view/form-content-quick-view.component.mjs +14 -5
- package/esm2020/lib/g4b-details/g4b-details.component.mjs +3 -3
- package/esm2020/lib/g4b-estelam/g4b-estelam.component.mjs +3 -3
- package/esm2020/lib/login-form/login-form.component.mjs +17 -12
- package/esm2020/lib/login-social-conncetions/login-social-conncetions.component.mjs +3 -3
- package/esm2020/lib/master-detail-card-form/master-detail-card-form.component.mjs +17 -0
- package/esm2020/lib/media-file-uploader/media-file-uploader.component.mjs +238 -0
- package/esm2020/lib/micro-proccess-flow/micro-proccess-flow.component.mjs +12 -7
- package/esm2020/lib/micro-process-flow-view/micro-process-flow-view.component.mjs +1 -1
- package/esm2020/lib/mo-info-micro-proccess-flow/mo-info-micro-proccess-flow.component.mjs +3 -3
- package/esm2020/lib/models/document-item.mjs +2 -0
- package/esm2020/lib/models/documents-setting.mjs +2 -0
- package/esm2020/lib/models/index.mjs +7 -0
- package/esm2020/lib/models/micro-process-flow-view-setting.mjs +2 -0
- package/esm2020/lib/models/service-desk-view-of-services-setting.mjs +2 -0
- package/esm2020/lib/models/tab-process-view-setting.mjs +2 -0
- package/esm2020/lib/pipes/datasource-to-flow-item.mjs +1 -1
- package/esm2020/lib/pipes/index.mjs +1 -1
- package/esm2020/lib/pipes/mo-list-to-flow-item.pipe.mjs +1 -1
- package/esm2020/lib/query-string-form-observable/query-string-form-observable.component.mjs +1 -1
- package/esm2020/lib/query-string-observable/query-string-observable.component.mjs +1 -1
- package/esm2020/lib/report-button-view/report-button-view.component.mjs +38 -0
- package/esm2020/lib/report-line-chart-view/report-line-chart-view.component.mjs +3 -3
- package/esm2020/lib/report-tab-view/report-tab-view.component.mjs +3 -3
- package/esm2020/lib/resend-verification-code/resend-verification-code.component.mjs +3 -3
- package/esm2020/lib/service-desk-form-layout-content-mojavez/service-desk-form-layout-content-mojavez.component.mjs +1 -1
- package/esm2020/lib/service-desk-header/service-desk-header.component.mjs +7 -6
- package/esm2020/lib/service-desk-servcie-detail/service-desk-servcie-detail.component.mjs +3 -3
- package/esm2020/lib/service-desk-view-of-services/service-desk-view-of-services.component.mjs +3 -3
- package/esm2020/lib/setting-form/setting-form.component.mjs +3 -3
- package/esm2020/lib/subform-in-row-report/subform-in-row-report.component.mjs +24 -0
- package/esm2020/lib/tab-process-view/tab-process-view.component.mjs +1 -1
- package/esm2020/lib/table-view-vertical-columns/table-view-vertical-columns.component.mjs +4 -3
- package/esm2020/lib/timer-count-down/timer-count-down.component.mjs +6 -6
- package/esm2020/lib/ui-enum-segmented-button/ui-enum-segmented-button.component.mjs +1 -1
- package/esm2020/lib/ui-num-rate/ui-num-rate.component.mjs +3 -3
- package/esm2020/lib/ui-person/ui-person.component.mjs +1 -1
- package/esm2020/lib/ui-pictures-carousel/ui-pictures-carousel.component.mjs +3 -3
- package/esm2020/lib/ui-text-field-search/ui-text-field-search.component.mjs +16 -5
- package/esm2020/lib/ulv-context-menu-item-show-file-content/ulv-context-menu-item-show-file-content.component.mjs +1 -1
- package/esm2020/public-api.mjs +9 -1
- package/fesm2015/barsa-develop-components.mjs +812 -116
- package/fesm2015/barsa-develop-components.mjs.map +1 -1
- package/fesm2020/barsa-develop-components.mjs +803 -114
- package/fesm2020/barsa-develop-components.mjs.map +1 -1
- package/lib/accept-reject/accept-reject.component.d.ts +28 -0
- package/lib/barsa-develop-components.module.d.ts +30 -18
- package/lib/barsa-document-list-item/barsa-document-list-item.component.d.ts +39 -0
- package/lib/barsa-documents/barsa-documents.component.d.ts +47 -0
- package/lib/footer/footer.component.d.ts +15 -0
- package/lib/form-content-quick-view/form-content-quick-view.component.d.ts +1 -0
- package/lib/login-form/login-form.component.d.ts +3 -1
- package/lib/master-detail-card-form/master-detail-card-form.component.d.ts +8 -0
- package/lib/media-file-uploader/media-file-uploader.component.d.ts +52 -0
- package/lib/micro-proccess-flow/micro-proccess-flow.component.d.ts +7 -1
- package/lib/micro-process-flow-view/micro-process-flow-view.component.d.ts +1 -1
- package/lib/models/document-item.d.ts +19 -0
- package/lib/models/documents-setting.d.ts +11 -0
- package/lib/models/index.d.ts +6 -0
- package/lib/models/micro-process-flow-view-setting.d.ts +8 -0
- package/lib/models/service-desk-view-of-services-setting.d.ts +6 -0
- package/lib/models/tab-process-view-setting.d.ts +7 -0
- package/lib/report-button-view/report-button-view.component.d.ts +12 -0
- package/lib/service-desk-header/service-desk-header.component.d.ts +2 -1
- package/lib/service-desk-view-of-services/service-desk-view-of-services.component.d.ts +1 -1
- package/lib/subform-in-row-report/subform-in-row-report.component.d.ts +10 -0
- package/lib/tab-process-view/tab-process-view.component.d.ts +1 -1
- package/lib/ui-text-field-search/ui-text-field-search.component.d.ts +3 -0
- package/package.json +4 -4
- package/public-api.d.ts +8 -0
- package/esm2020/lib/models/models.mjs +0 -2
- package/lib/models/models.d.ts +0 -19
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { AudioMimeType, BaseComponent, ImageMimeType, PreventDefaulEvent, VideoMimeType, AllFilesMimeType, isImage, getIcon } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "barsa-novin-ray-core";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "barsa-sap-ui";
|
|
7
|
+
import * as i4 from "@fundamental-ngx/core/action-sheet";
|
|
8
|
+
import * as i5 from "@fundamental-ngx/core/avatar";
|
|
9
|
+
import * as i6 from "@fundamental-ngx/core/button";
|
|
10
|
+
import * as i7 from "@fundamental-ngx/core/file-uploader";
|
|
11
|
+
import * as i8 from "@fundamental-ngx/core/form";
|
|
12
|
+
import * as i9 from "@fundamental-ngx/core/inline-help";
|
|
13
|
+
import * as i10 from "@fundamental-ngx/core/object-status";
|
|
14
|
+
import * as i11 from "@fundamental-ngx/core/table";
|
|
15
|
+
import * as i12 from "@fundamental-ngx/core/toolbar";
|
|
16
|
+
export class BarsaDocumentListItemComponent extends BaseComponent {
|
|
17
|
+
constructor(_cdr, _picFieldSrc) {
|
|
18
|
+
super();
|
|
19
|
+
this._cdr = _cdr;
|
|
20
|
+
this._picFieldSrc = _picFieldSrc;
|
|
21
|
+
this.statusChanged = new EventEmitter();
|
|
22
|
+
this.rejectTextChange = new EventEmitter();
|
|
23
|
+
this.fileSelectionChange = new EventEmitter();
|
|
24
|
+
this.removeFile = new EventEmitter();
|
|
25
|
+
this.fullscreen = new EventEmitter();
|
|
26
|
+
this.download = new EventEmitter();
|
|
27
|
+
this.downloadAll = new EventEmitter();
|
|
28
|
+
this.hasFiles = false;
|
|
29
|
+
}
|
|
30
|
+
ngOnInit() {
|
|
31
|
+
super.ngOnInit();
|
|
32
|
+
const documentItem = this.documentItem;
|
|
33
|
+
documentItem.$ValidExtensions = `
|
|
34
|
+
${documentItem.SupportImage ? ImageMimeType : ''},
|
|
35
|
+
${documentItem.SupportAudio ? AudioMimeType : ''},
|
|
36
|
+
${documentItem.SupportVideo ? VideoMimeType : ''},
|
|
37
|
+
${documentItem.SupportFile ? AllFilesMimeType : ''}
|
|
38
|
+
`;
|
|
39
|
+
}
|
|
40
|
+
ngOnChanges(changes) {
|
|
41
|
+
super.ngOnChanges(changes);
|
|
42
|
+
const { files } = changes;
|
|
43
|
+
files && Array.isArray(files.currentValue) && this._setFirstImage(files.currentValue);
|
|
44
|
+
this._detectChanges();
|
|
45
|
+
}
|
|
46
|
+
onReject(e) {
|
|
47
|
+
this.statusChanged.emit({ value: e, rejectedText: e === 2 ? '' : this.rejectedReason });
|
|
48
|
+
}
|
|
49
|
+
onRejectedTextChange(e) {
|
|
50
|
+
this.rejectTextChange.emit(e.target.value);
|
|
51
|
+
}
|
|
52
|
+
onPreventClick(e) {
|
|
53
|
+
PreventDefaulEvent(e);
|
|
54
|
+
}
|
|
55
|
+
onFileSelection(files) {
|
|
56
|
+
this.fileSelectionChange.emit(files);
|
|
57
|
+
}
|
|
58
|
+
_setFirstImage(files) {
|
|
59
|
+
files.length &&
|
|
60
|
+
(this.firstImageUrl = isImage(files[0].Type)
|
|
61
|
+
? this._picFieldSrc.transform(files[0].Id, 'ID', null, '', 120, 120)
|
|
62
|
+
: getIcon(files[0].Type));
|
|
63
|
+
}
|
|
64
|
+
_detectChanges() {
|
|
65
|
+
this._cdr.detectChanges();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
BarsaDocumentListItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaDocumentListItemComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.PictureFieldSourcePipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
69
|
+
BarsaDocumentListItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaDocumentListItemComponent, selector: "bdc-barsa-document-list-item", inputs: { documentItem: "documentItem", deviceSize: "deviceSize", files: "files", accepted: "accepted", rejectedReason: "rejectedReason", readonly: "readonly", status: "status", uploadingState: "uploadingState" }, outputs: { statusChanged: "statusChanged", rejectTextChange: "rejectTextChange", fileSelectionChange: "fileSelectionChange", removeFile: "removeFile", fullscreen: "fullscreen", download: "download", downloadAll: "downloadAll" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!-- <li fd-list-item style=\"padding: 0.5rem 1rem\">\n <span fd-list-thumbnail>\n <fd-icon *ngIf=\"documentItem.FontIcon\" [glyph]=\"documentItem.FontIcon\"></fd-icon>\n <fd-avatar\n *ngIf=\"documentItem.Avatar\"\n size=\"s\"\n [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:''\"\n [clickable]=\"true\"\n ></fd-avatar\n ></span>\n \n <div fd-list-content>\n <div fd-list-title>\n <div style=\"display: flex; column-gap: 3px\">\n <strong\n >{{ documentItem.Title }}\n <span fd-object-status status=\"negative\" *ngIf=\"documentItem.IsRequired\"\n >*({{ '\u0627\u062C\u0628\u0627\u0631\u06CC' | bbbTranslate }})\n </span>\n </strong>\n <div\n *ngIf=\"documentItem.$Accepted === false || documentItem.$Accepted === true\"\n style=\"display: flex; column-gap: 3px; flex-wrap: wrap; align-items: center\"\n >\n <span\n fd-object-status\n [status]=\"accepted ? 'positive' : 'negative'\"\n [label]=\"accepted ? acceptedText : rejectedText\"\n [clickable]=\"true\"\n [inverted]=\"true\"\n [aria-label]=\"accepted ? acceptedText : rejectedText\"\n ></span>\n <fd-popover title=\"Rejected document\" *ngIf=\"rejectedReason && !accepted\">\n <fd-popover-control>\n <span\n fd-object-status\n status=\"negative\"\n glyph=\"question-mark\"\n glyphAriaLabel=\"Negative\"\n title=\"Rejected document\"\n ></span>\n </fd-popover-control>\n <fd-popover-body>\n <fd-message-strip type=\"error\" [dismissible]=\"false\">\n {{ rejectedReason }}\n </fd-message-strip>\n </fd-popover-body>\n </fd-popover>\n </div>\n </div>\n </div>\n <div fd-list-byline [twoCol]=\"true\" [class.smallSize]=\"deviceSize === 's'\">\n <div fd-list-byline-left>\n <div style=\"display: flex; flex-direction: column; row-gap: 5px; flex-wrap: wrap\">\n <span>\n {{ documentItem.Description }}\n </span>\n <div style=\"display: flex; flex-wrap: wrap; column-gap: 3px; align-items: center\">\n <ng-container *ngIf=\"hasFiles\">\n <button fd-button [fdType]=\"'transparent'\" glyph=\"show\" (click)=\"onFullscreen()\"></button>\n <ng-container *ngFor=\"let file of files\">\n <fd-token\n [readOnly]=\"readonly\"\n *ngIf=\"!file.IsDeleted\"\n (onCloseClick)=\"onRemoveFile(file)\"\n >{{ file.FileName }}</fd-token\n >\n </ng-container>\n </ng-container>\n <button\n fd-button\n *ngIf=\"documentItem.MaxFileCount && !readonly\"\n glyph=\"attachment\"\n [label]=\"'AttachFile' | bbbTranslate\"\n (click)=\"!readonly && uploader.open()\"\n ></button>\n <fd-file-uploader\n #uploader\n [style.display]=\"'none'\"\n fd-toolbar-item\n [id]=\"documentItem.ItemKey\"\n [name]=\"'pictures_' + documentItem.ItemKey\"\n [accept]=\"documentItem.$ValidExtensions\"\n [fileLimit]=\"documentItem.MaxFileCount\"\n [multiple]=\"documentItem.MaxFileCount > 0\"\n (selectedFilesChanged)=\"onFileSelection($event)\"\n ></fd-file-uploader>\n </div>\n </div>\n </div>\n <div fd-list-byline-right *ngIf=\"documentItem.CanAccept\">\n <bdc-accept-reject\n [rejectedReason]=\"rejectedReason\"\n [positiveText]=\"acceptedText\"\n [negativeText]=\"rejectedText\"\n [deviceSize]=\"deviceSize\"\n [readonly]=\"readonly\"\n ></bdc-accept-reject>\n </div>\n </div>\n </div>\n</li> -->\n\n<tr fd-table-row>\n <td fd-table-cell>\n <fd-avatar\n *ngIf=\"documentItem.Avatar && !files.length; else fontIconTpl\"\n size=\"s\"\n [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:'':64:64\"\n [clickable]=\"true\"\n [transparent]=\"true\"\n ></fd-avatar>\n <ng-template #fontIconTpl>\n <fd-avatar\n *ngIf=\"files.length\"\n [transparent]=\"true\"\n size=\"s\"\n [image]=\"firstImageUrl\"\n [clickable]=\"true\"\n ></fd-avatar>\n <fd-avatar\n *ngIf=\"!files.length\"\n [transparent]=\"true\"\n size=\"s\"\n [glyph]=\"documentItem.FontIcon\"\n [clickable]=\"true\"\n ></fd-avatar>\n </ng-template>\n </td>\n <td fd-table-cell style=\"min-width: 140px\">\n <p fd-table-text>\n <strong\n >{{ documentItem.Title }}\n <span fd-object-status status=\"negative\" *ngIf=\"documentItem.IsRequired\"\n >*({{ '\u0627\u062C\u0628\u0627\u0631\u06CC' | bbbTranslate }})\n </span>\n </strong>\n </p>\n <div>\n <span>\n {{ documentItem.Description }}\n </span>\n </div>\n </td>\n\n <td fd-table-cell>\n <ng-container>\n <!-- <ul fd-list>\n <li fd-list-item *ngFor=\"let file of files; let ind = index\">\n <span fd-list-title>\n {{ file.FileName }}\n </span>\n <span fd-list-secondary>\n <button ariaLabel=\"Remove\" title=\"Remove\" fd-button glyph=\"delete\" ></button>\n </span>\n </li>\n </ul> -->\n <div style=\"display: flex; align-items: flex-start; column-gap: 3px; row-gap: 3px; flex-direction: column\">\n <ng-container *ngFor=\"let file of files\">\n <!-- <span><fd-icon glyph=\"attachment\"></fd-icon><a fd-link>{{file.FileName}}</a></span> -->\n <bsu-file-viewer-popover\n *ngIf=\"!file.IsDeleted\"\n [file]=\"file\"\n [deviceSize]=\"deviceSize\"\n [canDownload]=\"true\"\n (remove)=\"removeFile.emit(file)\"\n ></bsu-file-viewer-popover>\n </ng-container>\n <!-- <button\n fd-button\n *ngIf=\"+documentItem.MaxFileCount && !readonly\"\n glyph=\"add\"\n (click)=\"!readonly && uploader.open()\"\n ></button> -->\n </div>\n <!-- <p *ngFor=\"let file of files\" fd-table-text>\n <fd-action-sheet >\n <fd-action-sheet-control>\n <button\n fd-button\n glyph=\"settings\"\n title=\"Open Action Sheet Mobile\"\n id=\"fd-action-sheet-mobile-control\"\n aria-haspopup=\"menu\"\n [label]=\"file.FileName ||''\"\n aria-controls=\"fd-action-sheet-mobile-body\"\n ></button>\n </fd-action-sheet-control>\n \n <fd-action-sheet-body\n actionSheetBodyId=\"fd-action-sheet-mobile-body\"\n ariaLabelledby=\"fd-action-sheet-mobile-control\"\n >\n <li fd-action-sheet-item label=\"Search\" glyph=\"search\"></li>\n <li fd-action-sheet-item label=\"Download\" glyph=\"download\" ></li>\n <li fd-action-sheet-item label=\"Accept\" glyph=\"accept\" ></li>\n <li fd-action-sheet-item label=\"Reject\" glyph=\"cancel\" ></li>\n <li fd-action-sheet-item label=\"Decide Later\" [isCloseButton]=\"true\"></li>\n <li fd-action-sheet-item label=\"Cancel\" [negative]=\"true\" [isCloseButton]=\"true\"></li>\n </fd-action-sheet-body>\n </fd-action-sheet>\n </p> -->\n </ng-container>\n </td>\n <td fd-table-cell>\n <div class=\"status\" style=\"position: relative\">\n <button\n fd-button\n *ngIf=\"+documentItem.MaxFileCount && !readonly\"\n glyph=\"attachment\"\n [label]=\"'AttachFile' | bbbTranslate\"\n [disabled]=\"uploadingState?.key === documentItem.Title && uploadingState?.uploading\"\n (click)=\"!readonly && uploader.open()\"\n >\n <bsu-mask\n *ngIf=\"uploadingState?.key === documentItem.Title && uploadingState?.uploading\"\n [marginTop]=\"'3px'\"\n ></bsu-mask>\n </button>\n <button\n fd-button\n glyph=\"show\"\n fullscreenFiles\n [files]=\"files\"\n [title]=\"documentItem.Title\"\n [fd-inline-help]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\n [aria-describedby]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\n [ariaLabel]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\n fullscreenFiles\n [disabled]=\"!files.length\"\n [files]=\"files\"\n ></button>\n <button\n fd-button\n glyph=\"download\"\n [fd-inline-help]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\n [aria-describedby]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\n [ariaLabel]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\n downloadFiles\n [disabled]=\"!files.length\"\n [files]=\"files\"\n (click)=\"downloadAll.emit()\"\n ></button>\n </div>\n </td>\n <td fd-table-cell>\n <fd-action-sheet #actionSheet>\n <fd-action-sheet-control>\n <ng-container *ngTemplateOutlet=\"statusTpl\"></ng-container>\n </fd-action-sheet-control>\n <fd-action-sheet-body>\n <li\n fd-action-sheet-item\n [label]=\"'Accept' | bbbTranslate\"\n glyph=\"accept\"\n (click)=\"actionSheet.close(); onReject(2)\"\n ></li>\n <li\n fd-action-sheet-item\n [label]=\"'Reject' | bbbTranslate\"\n glyph=\"cancel\"\n (click)=\"actionSheet.close(); onReject(3)\"\n ></li>\n </fd-action-sheet-body>\n </fd-action-sheet>\n\n <p fd-table-text maxWidth=\"400px\" *ngIf=\"status === 3\">\n <span *ngIf=\"readonly && rejectedReason\"> {{ rejectedReason | bbbTranslate }} </span>\n <input\n *ngIf=\"!readonly\"\n fd-form-control\n [value]=\"rejectedReason | bbbTranslate\"\n [placeholder]=\"'\u062F\u0644\u0627\u06CC\u0644 \u0631\u062F \u0645\u062F\u0631\u06A9' | bbbTranslate\"\n />\n </p>\n </td>\n</tr>\n\n<fd-file-uploader\n #uploader\n [style.display]=\"'none'\"\n fd-toolbar-item\n [id]=\"documentItem.ItemKey\"\n [name]=\"'pictures_' + documentItem.ItemKey\"\n [accept]=\"documentItem.$ValidExtensions\"\n [fileLimit]=\"documentItem.MaxFileCount\"\n [multiple]=\"documentItem.MaxFileCount > 0\"\n (selectedFilesChanged)=\"onFileSelection($event)\"\n></fd-file-uploader>\n<ng-template #statusTpl>\n <div class=\"status\">\n <button fd-button fdType=\"transparent\">\n <span\n *ngIf=\"status === 1\"\n fd-object-status\n [label]=\"'[\u067E\u06CC\u0648\u0633\u062A \u0645\u062F\u0627\u0631\u06A9]' | bbbTranslate\"\n [aria-label]=\"'[\u067E\u06CC\u0648\u0633\u062A \u0645\u062F\u0627\u0631\u06A9]' | bbbTranslate\"\n ></span>\n <span\n *ngIf=\"status === 2\"\n fd-object-status\n glyph=\"message-success\"\n status=\"positive\"\n [label]=\"'Accepted' | bbbTranslate\"\n [label]=\"'Accepted' | bbbTranslate\"\n ></span>\n <span\n *ngIf=\"status === 3\"\n fd-object-status\n glyph=\"cancel\"\n status=\"negative\"\n [label]=\"'Rejected' | bbbTranslate\"\n [aria-label]=\"'Rejected' | bbbTranslate\"\n ></span>\n </button>\n </div>\n</ng-template>\n", styles: [":host{display:contents}::ng-deep .fd-list--byline .fd-list__byline-left,::ng-deep .fd-list--byline .fd-list__byline-right{line-height:1.1rem!important}.fd-list__byline.smallSize{flex-direction:column;row-gap:5px}.fd-list__byline.smallSize div{width:100%}td{white-space:nowrap;padding:.5rem}fd-avatar ::ng-deep i{font-size:2.3rem!important}.status{display:flex;align-items:center;column-gap:3px;row-gap:3px}.status span.fd-object-status{font-size:var(--sapFontSize)!important;font-weight:700!important}.status span.fd-object-status ::ng-deep fd-icon{font-size:var(--sapFontSize);font-weight:700}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.MaskComponent, selector: "bsu-mask", inputs: ["size", "marginTop"] }, { kind: "component", type: i3.FileViewerPopoverComponent, selector: "bsu-file-viewer-popover", inputs: ["file", "deviceSize", "canDownload"], outputs: ["remove"] }, { kind: "directive", type: i3.FullscreenFilesDirective, selector: "[fullscreenFiles]", inputs: ["files", "title", "isImageGallery", "component"] }, { kind: "directive", type: i3.DownloadFilesDirective, selector: "[downloadFiles]", inputs: ["files"] }, { kind: "component", type: i4.ActionSheetComponent, selector: "fd-action-sheet", inputs: ["mobile", "placement", "noArrow", "isOpen", "keyboardSupport", "triggers"], outputs: ["focusEscapeList", "isOpenChange"] }, { kind: "component", type: i4.ActionSheetControlComponent, selector: "fd-action-sheet-control", outputs: ["clicked"] }, { kind: "component", type: i4.ActionSheetItemComponent, selector: "[fd-action-sheet-item]", inputs: ["label", "glyph", "negative", "isCloseButton", "disabled"], outputs: ["keyDown"] }, { kind: "component", type: i4.ActionSheetBodyComponent, selector: "fd-action-sheet-body", inputs: ["actionSheetBodyId", "mobile", "ariaLabel", "ariaLabelledby"] }, { kind: "component", type: i5.AvatarComponent, selector: "fd-avatar", inputs: ["class", "id", "ariaLabel", "ariaLabelledby", "label", "size", "glyph", "zoomGlyph", "circle", "transparent", "contain", "placeholder", "tile", "border", "colorAccent", "random", "clickable", "backgroundImage", "image", "alterIcon", "backupImage"], outputs: ["avatarClicked", "zoomGlyphClicked"] }, { kind: "component", type: i6.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i7.FileUploaderComponent, selector: "fd-file-uploader", inputs: ["disabled", "required", "multiple", "accept", "dragndrop", "maxFileSize", "minFileSize", "id", "ariaLabel", "ariaLabelledBy", "placeholder", "buttonLabel", "buttonAriaLabel", "state", "fileLimit", "inputHidden", "width"], outputs: ["selectedFilesChanged", "selectedInvalidFiles", "onDragEnter", "onDragLeave"] }, { kind: "component", type: i8.FormControlComponent, selector: "[fd-form-control]", inputs: ["state", "type", "class"] }, { kind: "directive", type: i8.InputFormControlDirective, selector: "input[fd-form-control]" }, { kind: "directive", type: i9.InlineHelpDirective, selector: "[fd-inline-help], [fd-inline-help-template]", inputs: ["triggers", "noArrow", "closeOnEscapeKey", "closeOnOutsideClick", "fd-inline-help", "fd-inline-help-template"] }, { kind: "component", type: i10.ObjectStatusComponent, selector: "[fd-object-status]", inputs: ["class", "status", "glyph", "label", "glyphAriaLabel", "indicationColor", "clickable", "inverted", "large"] }, { kind: "directive", type: i11.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i11.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "tabindex", "hoverable", "fitContent", "noPadding", "noData", "key", "cellFocusedEventAnnouncer"] }, { kind: "directive", type: i11.TableTextDirective, selector: "[fdTableText], [fd-table-text]", inputs: ["fdTableTextClass", "noWrap", "title", "maxWidth"] }, { kind: "directive", type: i12.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "pipe", type: i1.PictureFieldSourcePipe, name: "picFieldSrc" }, { kind: "pipe", type: i1.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
70
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaDocumentListItemComponent, decorators: [{
|
|
71
|
+
type: Component,
|
|
72
|
+
args: [{ selector: 'bdc-barsa-document-list-item', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- <li fd-list-item style=\"padding: 0.5rem 1rem\">\n <span fd-list-thumbnail>\n <fd-icon *ngIf=\"documentItem.FontIcon\" [glyph]=\"documentItem.FontIcon\"></fd-icon>\n <fd-avatar\n *ngIf=\"documentItem.Avatar\"\n size=\"s\"\n [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:''\"\n [clickable]=\"true\"\n ></fd-avatar\n ></span>\n \n <div fd-list-content>\n <div fd-list-title>\n <div style=\"display: flex; column-gap: 3px\">\n <strong\n >{{ documentItem.Title }}\n <span fd-object-status status=\"negative\" *ngIf=\"documentItem.IsRequired\"\n >*({{ '\u0627\u062C\u0628\u0627\u0631\u06CC' | bbbTranslate }})\n </span>\n </strong>\n <div\n *ngIf=\"documentItem.$Accepted === false || documentItem.$Accepted === true\"\n style=\"display: flex; column-gap: 3px; flex-wrap: wrap; align-items: center\"\n >\n <span\n fd-object-status\n [status]=\"accepted ? 'positive' : 'negative'\"\n [label]=\"accepted ? acceptedText : rejectedText\"\n [clickable]=\"true\"\n [inverted]=\"true\"\n [aria-label]=\"accepted ? acceptedText : rejectedText\"\n ></span>\n <fd-popover title=\"Rejected document\" *ngIf=\"rejectedReason && !accepted\">\n <fd-popover-control>\n <span\n fd-object-status\n status=\"negative\"\n glyph=\"question-mark\"\n glyphAriaLabel=\"Negative\"\n title=\"Rejected document\"\n ></span>\n </fd-popover-control>\n <fd-popover-body>\n <fd-message-strip type=\"error\" [dismissible]=\"false\">\n {{ rejectedReason }}\n </fd-message-strip>\n </fd-popover-body>\n </fd-popover>\n </div>\n </div>\n </div>\n <div fd-list-byline [twoCol]=\"true\" [class.smallSize]=\"deviceSize === 's'\">\n <div fd-list-byline-left>\n <div style=\"display: flex; flex-direction: column; row-gap: 5px; flex-wrap: wrap\">\n <span>\n {{ documentItem.Description }}\n </span>\n <div style=\"display: flex; flex-wrap: wrap; column-gap: 3px; align-items: center\">\n <ng-container *ngIf=\"hasFiles\">\n <button fd-button [fdType]=\"'transparent'\" glyph=\"show\" (click)=\"onFullscreen()\"></button>\n <ng-container *ngFor=\"let file of files\">\n <fd-token\n [readOnly]=\"readonly\"\n *ngIf=\"!file.IsDeleted\"\n (onCloseClick)=\"onRemoveFile(file)\"\n >{{ file.FileName }}</fd-token\n >\n </ng-container>\n </ng-container>\n <button\n fd-button\n *ngIf=\"documentItem.MaxFileCount && !readonly\"\n glyph=\"attachment\"\n [label]=\"'AttachFile' | bbbTranslate\"\n (click)=\"!readonly && uploader.open()\"\n ></button>\n <fd-file-uploader\n #uploader\n [style.display]=\"'none'\"\n fd-toolbar-item\n [id]=\"documentItem.ItemKey\"\n [name]=\"'pictures_' + documentItem.ItemKey\"\n [accept]=\"documentItem.$ValidExtensions\"\n [fileLimit]=\"documentItem.MaxFileCount\"\n [multiple]=\"documentItem.MaxFileCount > 0\"\n (selectedFilesChanged)=\"onFileSelection($event)\"\n ></fd-file-uploader>\n </div>\n </div>\n </div>\n <div fd-list-byline-right *ngIf=\"documentItem.CanAccept\">\n <bdc-accept-reject\n [rejectedReason]=\"rejectedReason\"\n [positiveText]=\"acceptedText\"\n [negativeText]=\"rejectedText\"\n [deviceSize]=\"deviceSize\"\n [readonly]=\"readonly\"\n ></bdc-accept-reject>\n </div>\n </div>\n </div>\n</li> -->\n\n<tr fd-table-row>\n <td fd-table-cell>\n <fd-avatar\n *ngIf=\"documentItem.Avatar && !files.length; else fontIconTpl\"\n size=\"s\"\n [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:'':64:64\"\n [clickable]=\"true\"\n [transparent]=\"true\"\n ></fd-avatar>\n <ng-template #fontIconTpl>\n <fd-avatar\n *ngIf=\"files.length\"\n [transparent]=\"true\"\n size=\"s\"\n [image]=\"firstImageUrl\"\n [clickable]=\"true\"\n ></fd-avatar>\n <fd-avatar\n *ngIf=\"!files.length\"\n [transparent]=\"true\"\n size=\"s\"\n [glyph]=\"documentItem.FontIcon\"\n [clickable]=\"true\"\n ></fd-avatar>\n </ng-template>\n </td>\n <td fd-table-cell style=\"min-width: 140px\">\n <p fd-table-text>\n <strong\n >{{ documentItem.Title }}\n <span fd-object-status status=\"negative\" *ngIf=\"documentItem.IsRequired\"\n >*({{ '\u0627\u062C\u0628\u0627\u0631\u06CC' | bbbTranslate }})\n </span>\n </strong>\n </p>\n <div>\n <span>\n {{ documentItem.Description }}\n </span>\n </div>\n </td>\n\n <td fd-table-cell>\n <ng-container>\n <!-- <ul fd-list>\n <li fd-list-item *ngFor=\"let file of files; let ind = index\">\n <span fd-list-title>\n {{ file.FileName }}\n </span>\n <span fd-list-secondary>\n <button ariaLabel=\"Remove\" title=\"Remove\" fd-button glyph=\"delete\" ></button>\n </span>\n </li>\n </ul> -->\n <div style=\"display: flex; align-items: flex-start; column-gap: 3px; row-gap: 3px; flex-direction: column\">\n <ng-container *ngFor=\"let file of files\">\n <!-- <span><fd-icon glyph=\"attachment\"></fd-icon><a fd-link>{{file.FileName}}</a></span> -->\n <bsu-file-viewer-popover\n *ngIf=\"!file.IsDeleted\"\n [file]=\"file\"\n [deviceSize]=\"deviceSize\"\n [canDownload]=\"true\"\n (remove)=\"removeFile.emit(file)\"\n ></bsu-file-viewer-popover>\n </ng-container>\n <!-- <button\n fd-button\n *ngIf=\"+documentItem.MaxFileCount && !readonly\"\n glyph=\"add\"\n (click)=\"!readonly && uploader.open()\"\n ></button> -->\n </div>\n <!-- <p *ngFor=\"let file of files\" fd-table-text>\n <fd-action-sheet >\n <fd-action-sheet-control>\n <button\n fd-button\n glyph=\"settings\"\n title=\"Open Action Sheet Mobile\"\n id=\"fd-action-sheet-mobile-control\"\n aria-haspopup=\"menu\"\n [label]=\"file.FileName ||''\"\n aria-controls=\"fd-action-sheet-mobile-body\"\n ></button>\n </fd-action-sheet-control>\n \n <fd-action-sheet-body\n actionSheetBodyId=\"fd-action-sheet-mobile-body\"\n ariaLabelledby=\"fd-action-sheet-mobile-control\"\n >\n <li fd-action-sheet-item label=\"Search\" glyph=\"search\"></li>\n <li fd-action-sheet-item label=\"Download\" glyph=\"download\" ></li>\n <li fd-action-sheet-item label=\"Accept\" glyph=\"accept\" ></li>\n <li fd-action-sheet-item label=\"Reject\" glyph=\"cancel\" ></li>\n <li fd-action-sheet-item label=\"Decide Later\" [isCloseButton]=\"true\"></li>\n <li fd-action-sheet-item label=\"Cancel\" [negative]=\"true\" [isCloseButton]=\"true\"></li>\n </fd-action-sheet-body>\n </fd-action-sheet>\n </p> -->\n </ng-container>\n </td>\n <td fd-table-cell>\n <div class=\"status\" style=\"position: relative\">\n <button\n fd-button\n *ngIf=\"+documentItem.MaxFileCount && !readonly\"\n glyph=\"attachment\"\n [label]=\"'AttachFile' | bbbTranslate\"\n [disabled]=\"uploadingState?.key === documentItem.Title && uploadingState?.uploading\"\n (click)=\"!readonly && uploader.open()\"\n >\n <bsu-mask\n *ngIf=\"uploadingState?.key === documentItem.Title && uploadingState?.uploading\"\n [marginTop]=\"'3px'\"\n ></bsu-mask>\n </button>\n <button\n fd-button\n glyph=\"show\"\n fullscreenFiles\n [files]=\"files\"\n [title]=\"documentItem.Title\"\n [fd-inline-help]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\n [aria-describedby]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\n [ariaLabel]=\"'\u0645\u0634\u0627\u0647\u062F\u0647 \u0647\u0645\u0647' | bbbTranslate\"\n fullscreenFiles\n [disabled]=\"!files.length\"\n [files]=\"files\"\n ></button>\n <button\n fd-button\n glyph=\"download\"\n [fd-inline-help]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\n [aria-describedby]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\n [ariaLabel]=\"'\u062F\u0627\u0646\u0644\u0648\u062F \u0647\u0645\u0647' | bbbTranslate\"\n downloadFiles\n [disabled]=\"!files.length\"\n [files]=\"files\"\n (click)=\"downloadAll.emit()\"\n ></button>\n </div>\n </td>\n <td fd-table-cell>\n <fd-action-sheet #actionSheet>\n <fd-action-sheet-control>\n <ng-container *ngTemplateOutlet=\"statusTpl\"></ng-container>\n </fd-action-sheet-control>\n <fd-action-sheet-body>\n <li\n fd-action-sheet-item\n [label]=\"'Accept' | bbbTranslate\"\n glyph=\"accept\"\n (click)=\"actionSheet.close(); onReject(2)\"\n ></li>\n <li\n fd-action-sheet-item\n [label]=\"'Reject' | bbbTranslate\"\n glyph=\"cancel\"\n (click)=\"actionSheet.close(); onReject(3)\"\n ></li>\n </fd-action-sheet-body>\n </fd-action-sheet>\n\n <p fd-table-text maxWidth=\"400px\" *ngIf=\"status === 3\">\n <span *ngIf=\"readonly && rejectedReason\"> {{ rejectedReason | bbbTranslate }} </span>\n <input\n *ngIf=\"!readonly\"\n fd-form-control\n [value]=\"rejectedReason | bbbTranslate\"\n [placeholder]=\"'\u062F\u0644\u0627\u06CC\u0644 \u0631\u062F \u0645\u062F\u0631\u06A9' | bbbTranslate\"\n />\n </p>\n </td>\n</tr>\n\n<fd-file-uploader\n #uploader\n [style.display]=\"'none'\"\n fd-toolbar-item\n [id]=\"documentItem.ItemKey\"\n [name]=\"'pictures_' + documentItem.ItemKey\"\n [accept]=\"documentItem.$ValidExtensions\"\n [fileLimit]=\"documentItem.MaxFileCount\"\n [multiple]=\"documentItem.MaxFileCount > 0\"\n (selectedFilesChanged)=\"onFileSelection($event)\"\n></fd-file-uploader>\n<ng-template #statusTpl>\n <div class=\"status\">\n <button fd-button fdType=\"transparent\">\n <span\n *ngIf=\"status === 1\"\n fd-object-status\n [label]=\"'[\u067E\u06CC\u0648\u0633\u062A \u0645\u062F\u0627\u0631\u06A9]' | bbbTranslate\"\n [aria-label]=\"'[\u067E\u06CC\u0648\u0633\u062A \u0645\u062F\u0627\u0631\u06A9]' | bbbTranslate\"\n ></span>\n <span\n *ngIf=\"status === 2\"\n fd-object-status\n glyph=\"message-success\"\n status=\"positive\"\n [label]=\"'Accepted' | bbbTranslate\"\n [label]=\"'Accepted' | bbbTranslate\"\n ></span>\n <span\n *ngIf=\"status === 3\"\n fd-object-status\n glyph=\"cancel\"\n status=\"negative\"\n [label]=\"'Rejected' | bbbTranslate\"\n [aria-label]=\"'Rejected' | bbbTranslate\"\n ></span>\n </button>\n </div>\n</ng-template>\n", styles: [":host{display:contents}::ng-deep .fd-list--byline .fd-list__byline-left,::ng-deep .fd-list--byline .fd-list__byline-right{line-height:1.1rem!important}.fd-list__byline.smallSize{flex-direction:column;row-gap:5px}.fd-list__byline.smallSize div{width:100%}td{white-space:nowrap;padding:.5rem}fd-avatar ::ng-deep i{font-size:2.3rem!important}.status{display:flex;align-items:center;column-gap:3px;row-gap:3px}.status span.fd-object-status{font-size:var(--sapFontSize)!important;font-weight:700!important}.status span.fd-object-status ::ng-deep fd-icon{font-size:var(--sapFontSize);font-weight:700}\n"] }]
|
|
73
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.PictureFieldSourcePipe }]; }, propDecorators: { documentItem: [{
|
|
74
|
+
type: Input
|
|
75
|
+
}], deviceSize: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}], files: [{
|
|
78
|
+
type: Input
|
|
79
|
+
}], accepted: [{
|
|
80
|
+
type: Input
|
|
81
|
+
}], rejectedReason: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}], readonly: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}], status: [{
|
|
86
|
+
type: Input
|
|
87
|
+
}], uploadingState: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}], statusChanged: [{
|
|
90
|
+
type: Output
|
|
91
|
+
}], rejectTextChange: [{
|
|
92
|
+
type: Output
|
|
93
|
+
}], fileSelectionChange: [{
|
|
94
|
+
type: Output
|
|
95
|
+
}], removeFile: [{
|
|
96
|
+
type: Output
|
|
97
|
+
}], fullscreen: [{
|
|
98
|
+
type: Output
|
|
99
|
+
}], download: [{
|
|
100
|
+
type: Output
|
|
101
|
+
}], downloadAll: [{
|
|
102
|
+
type: Output
|
|
103
|
+
}] } });
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-document-list-item.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-develop-components/src/lib/barsa-document-list-item/barsa-document-list-item.component.ts","../../../../../projects/barsa-develop-components/src/lib/barsa-document-list-item/barsa-document-list-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EAET,MAAM,eAAe,CAAC;AACvB,OAAO,EAEH,aAAa,EACb,aAAa,EAEb,aAAa,EACb,kBAAkB,EAClB,aAAa,EACb,gBAAgB,EAEhB,OAAO,EACP,OAAO,EAEV,MAAM,sBAAsB,CAAC;;;;;;;;;;;;;;AAS9B,MAAM,OAAO,8BAA+B,SAAQ,aAAa;IAqB7D,YAAoB,IAAuB,EAAU,YAAoC;QACrF,KAAK,EAAE,CAAC;QADQ,SAAI,GAAJ,IAAI,CAAmB;QAAU,iBAAY,GAAZ,YAAY,CAAwB;QAV/E,kBAAa,GAAG,IAAI,YAAY,EAA2C,CAAC;QAC5E,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;QAC9C,wBAAmB,GAAG,IAAI,YAAY,EAAU,CAAC;QACjD,eAAU,GAAG,IAAI,YAAY,EAAsB,CAAC;QACpD,eAAU,GAAG,IAAI,YAAY,EAA6B,CAAC;QAC3D,aAAQ,GAAG,IAAI,YAAY,EAAsB,CAAC;QAClD,gBAAW,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEjD,aAAQ,GAAG,KAAK,CAAC;IAIjB,CAAC;IACD,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;QACvC,YAAY,CAAC,gBAAgB,GAAG;UAC9B,YAAY,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;UAC9C,YAAY,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;UAC9C,YAAY,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;UAC9C,YAAY,CAAC,WAAW,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE;SACjD,CAAC;IACN,CAAC;IACD,WAAW,CAAC,OAAsB;QAC9B,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC3B,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,CAAC;QAC1B,KAAK,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACtF,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IACD,QAAQ,CAAC,CAAS;QACd,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;IAC5F,CAAC;IACD,oBAAoB,CAAC,CAAC;QAClB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;IACD,cAAc,CAAC,CAAC;QACZ,kBAAkB,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;IACD,eAAe,CAAC,KAAa;QACzB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAES,cAAc,CAAC,KAA2B;QAChD,KAAK,CAAC,MAAM;YACR,CAAC,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;gBACxC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,CAAC;gBACpE,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IACtC,CAAC;IACS,cAAc;QACpB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;;2HA7DQ,8BAA8B;+GAA9B,8BAA8B,2iBChC3C,wncA6TA;2FD7Ra,8BAA8B;kBAN1C,SAAS;+BACI,8BAA8B,mBAGvB,uBAAuB,CAAC,MAAM;6IAGtC,YAAY;sBAApB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAEI,aAAa;sBAAtB,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACG,mBAAmB;sBAA5B,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,WAAW;sBAApB,MAAM","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    SimpleChanges\n} from '@angular/core';\nimport {\n    AbbrevationDeviceSize,\n    AudioMimeType,\n    BaseComponent,\n    FileAttachmentInfo,\n    ImageMimeType,\n    PreventDefaulEvent,\n    VideoMimeType,\n    AllFilesMimeType,\n    PictureFieldSourcePipe,\n    isImage,\n    getIcon,\n    IUploadingState\n} from 'barsa-novin-ray-core';\nimport { DocumentItem } from '../models';\n\n@Component({\n    selector: 'bdc-barsa-document-list-item',\n    templateUrl: './barsa-document-list-item.component.html',\n    styleUrls: ['./barsa-document-list-item.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaDocumentListItemComponent extends BaseComponent implements OnChanges {\n    @Input() documentItem: DocumentItem;\n\n    @Input() deviceSize: AbbrevationDeviceSize;\n    @Input() files: FileAttachmentInfo[];\n    @Input() accepted: boolean;\n    @Input() rejectedReason: string;\n    @Input() readonly: boolean;\n    @Input() status: number;\n    @Input() uploadingState: IUploadingState;\n\n    @Output() statusChanged = new EventEmitter<{ value: number; rejectedText: string }>();\n    @Output() rejectTextChange = new EventEmitter<string>();\n    @Output() fileSelectionChange = new EventEmitter<File[]>();\n    @Output() removeFile = new EventEmitter<FileAttachmentInfo>();\n    @Output() fullscreen = new EventEmitter<null | FileAttachmentInfo>();\n    @Output() download = new EventEmitter<FileAttachmentInfo>();\n    @Output() downloadAll = new EventEmitter<void>();\n\n    hasFiles = false;\n    firstImageUrl: any;\n    constructor(private _cdr: ChangeDetectorRef, private _picFieldSrc: PictureFieldSourcePipe) {\n        super();\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        const documentItem = this.documentItem;\n        documentItem.$ValidExtensions = `            \n        ${documentItem.SupportImage ? ImageMimeType : ''},\n        ${documentItem.SupportAudio ? AudioMimeType : ''},\n        ${documentItem.SupportVideo ? VideoMimeType : ''},\n        ${documentItem.SupportFile ? AllFilesMimeType : ''}\n        `;\n    }\n    ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        const { files } = changes;\n        files && Array.isArray(files.currentValue) && this._setFirstImage(files.currentValue);\n        this._detectChanges();\n    }\n    onReject(e: number): void {\n        this.statusChanged.emit({ value: e, rejectedText: e === 2 ? '' : this.rejectedReason });\n    }\n    onRejectedTextChange(e): void {\n        this.rejectTextChange.emit(e.target.value);\n    }\n    onPreventClick(e): void {\n        PreventDefaulEvent(e);\n    }\n    onFileSelection(files: File[]): void {\n        this.fileSelectionChange.emit(files);\n    }\n\n    protected _setFirstImage(files: FileAttachmentInfo[]): void {\n        files.length &&\n            (this.firstImageUrl = isImage(files[0].Type)\n                ? this._picFieldSrc.transform(files[0].Id, 'ID', null, '', 120, 120)\n                : getIcon(files[0].Type));\n    }\n    protected _detectChanges(): void {\n        this._cdr.detectChanges();\n    }\n}\n","<!-- <li fd-list-item style=\"padding: 0.5rem 1rem\">\n    <span fd-list-thumbnail>\n        <fd-icon *ngIf=\"documentItem.FontIcon\" [glyph]=\"documentItem.FontIcon\"></fd-icon>\n        <fd-avatar\n            *ngIf=\"documentItem.Avatar\"\n            size=\"s\"\n            [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:''\"\n            [clickable]=\"true\"\n        ></fd-avatar\n    ></span>\n    \n    <div fd-list-content>\n        <div fd-list-title>\n            <div style=\"display: flex; column-gap: 3px\">\n                <strong\n                    >{{ documentItem.Title }}\n                    <span fd-object-status status=\"negative\" *ngIf=\"documentItem.IsRequired\"\n                        >*({{ 'اجباری' | bbbTranslate }})\n                    </span>\n                </strong>\n                <div\n                    *ngIf=\"documentItem.$Accepted === false || documentItem.$Accepted === true\"\n                    style=\"display: flex; column-gap: 3px; flex-wrap: wrap; align-items: center\"\n                >\n                    <span\n                        fd-object-status\n                        [status]=\"accepted ? 'positive' : 'negative'\"\n                        [label]=\"accepted ? acceptedText : rejectedText\"\n                        [clickable]=\"true\"\n                        [inverted]=\"true\"\n                        [aria-label]=\"accepted ? acceptedText : rejectedText\"\n                    ></span>\n                    <fd-popover title=\"Rejected document\" *ngIf=\"rejectedReason && !accepted\">\n                        <fd-popover-control>\n                            <span\n                                fd-object-status\n                                status=\"negative\"\n                                glyph=\"question-mark\"\n                                glyphAriaLabel=\"Negative\"\n                                title=\"Rejected document\"\n                            ></span>\n                        </fd-popover-control>\n                        <fd-popover-body>\n                            <fd-message-strip type=\"error\" [dismissible]=\"false\">\n                                {{ rejectedReason }}\n                            </fd-message-strip>\n                        </fd-popover-body>\n                    </fd-popover>\n                </div>\n            </div>\n        </div>\n        <div fd-list-byline [twoCol]=\"true\" [class.smallSize]=\"deviceSize === 's'\">\n            <div fd-list-byline-left>\n                <div style=\"display: flex; flex-direction: column; row-gap: 5px; flex-wrap: wrap\">\n                    <span>\n                        {{ documentItem.Description }}\n                    </span>\n                    <div style=\"display: flex; flex-wrap: wrap; column-gap: 3px; align-items: center\">\n                        <ng-container *ngIf=\"hasFiles\">\n                            <button fd-button [fdType]=\"'transparent'\" glyph=\"show\" (click)=\"onFullscreen()\"></button>\n                            <ng-container *ngFor=\"let file of files\">\n                                <fd-token\n                                    [readOnly]=\"readonly\"\n                                    *ngIf=\"!file.IsDeleted\"\n                                    (onCloseClick)=\"onRemoveFile(file)\"\n                                    >{{ file.FileName }}</fd-token\n                                >\n                            </ng-container>\n                        </ng-container>\n                        <button\n                            fd-button\n                            *ngIf=\"documentItem.MaxFileCount && !readonly\"\n                            glyph=\"attachment\"\n                            [label]=\"'AttachFile' | bbbTranslate\"\n                            (click)=\"!readonly && uploader.open()\"\n                        ></button>\n                        <fd-file-uploader\n                            #uploader\n                            [style.display]=\"'none'\"\n                            fd-toolbar-item\n                            [id]=\"documentItem.ItemKey\"\n                            [name]=\"'pictures_' + documentItem.ItemKey\"\n                            [accept]=\"documentItem.$ValidExtensions\"\n                            [fileLimit]=\"documentItem.MaxFileCount\"\n                            [multiple]=\"documentItem.MaxFileCount > 0\"\n                            (selectedFilesChanged)=\"onFileSelection($event)\"\n                        ></fd-file-uploader>\n                    </div>\n                </div>\n            </div>\n            <div fd-list-byline-right *ngIf=\"documentItem.CanAccept\">\n                <bdc-accept-reject\n                    [rejectedReason]=\"rejectedReason\"\n                    [positiveText]=\"acceptedText\"\n                    [negativeText]=\"rejectedText\"\n                    [deviceSize]=\"deviceSize\"\n                    [readonly]=\"readonly\"\n                ></bdc-accept-reject>\n            </div>\n        </div>\n    </div>\n</li> -->\n\n<tr fd-table-row>\n    <td fd-table-cell>\n        <fd-avatar\n            *ngIf=\"documentItem.Avatar && !files.length; else fontIconTpl\"\n            size=\"s\"\n            [image]=\"documentItem.Avatar.FileId | picFieldSrc: 'ID':null:'':64:64\"\n            [clickable]=\"true\"\n            [transparent]=\"true\"\n        ></fd-avatar>\n        <ng-template #fontIconTpl>\n            <fd-avatar\n                *ngIf=\"files.length\"\n                [transparent]=\"true\"\n                size=\"s\"\n                [image]=\"firstImageUrl\"\n                [clickable]=\"true\"\n            ></fd-avatar>\n            <fd-avatar\n                *ngIf=\"!files.length\"\n                [transparent]=\"true\"\n                size=\"s\"\n                [glyph]=\"documentItem.FontIcon\"\n                [clickable]=\"true\"\n            ></fd-avatar>\n        </ng-template>\n    </td>\n    <td fd-table-cell style=\"min-width: 140px\">\n        <p fd-table-text>\n            <strong\n                >{{ documentItem.Title }}\n                <span fd-object-status status=\"negative\" *ngIf=\"documentItem.IsRequired\"\n                    >*({{ 'اجباری' | bbbTranslate }})\n                </span>\n            </strong>\n        </p>\n        <div>\n            <span>\n                {{ documentItem.Description }}\n            </span>\n        </div>\n    </td>\n\n    <td fd-table-cell>\n        <ng-container>\n            <!-- <ul fd-list>\n                <li fd-list-item *ngFor=\"let file of files; let ind = index\">\n                    <span fd-list-title>\n                        {{ file.FileName }}\n                    </span>\n                    <span fd-list-secondary>\n                        <button ariaLabel=\"Remove\" title=\"Remove\" fd-button glyph=\"delete\" ></button>\n                    </span>\n                </li>\n            </ul> -->\n            <div style=\"display: flex; align-items: flex-start; column-gap: 3px; row-gap: 3px; flex-direction: column\">\n                <ng-container *ngFor=\"let file of files\">\n                    <!-- <span><fd-icon glyph=\"attachment\"></fd-icon><a fd-link>{{file.FileName}}</a></span> -->\n                    <bsu-file-viewer-popover\n                        *ngIf=\"!file.IsDeleted\"\n                        [file]=\"file\"\n                        [deviceSize]=\"deviceSize\"\n                        [canDownload]=\"true\"\n                        (remove)=\"removeFile.emit(file)\"\n                    ></bsu-file-viewer-popover>\n                </ng-container>\n                <!-- <button\n                    fd-button\n                    *ngIf=\"+documentItem.MaxFileCount && !readonly\"\n                    glyph=\"add\"\n                    (click)=\"!readonly && uploader.open()\"\n                ></button> -->\n            </div>\n            <!-- <p *ngFor=\"let file of files\" fd-table-text>\n                <fd-action-sheet  >\n                    <fd-action-sheet-control>\n                        <button\n                            fd-button\n                            glyph=\"settings\"\n                            title=\"Open Action Sheet Mobile\"\n                            id=\"fd-action-sheet-mobile-control\"\n                            aria-haspopup=\"menu\"\n                            [label]=\"file.FileName ||''\"\n                            aria-controls=\"fd-action-sheet-mobile-body\"\n                        ></button>\n                    </fd-action-sheet-control>\n            \n                    <fd-action-sheet-body\n                        actionSheetBodyId=\"fd-action-sheet-mobile-body\"\n                        ariaLabelledby=\"fd-action-sheet-mobile-control\"\n                    >\n                        <li fd-action-sheet-item label=\"Search\" glyph=\"search\"></li>\n                        <li fd-action-sheet-item label=\"Download\" glyph=\"download\" ></li>\n                        <li fd-action-sheet-item label=\"Accept\" glyph=\"accept\" ></li>\n                        <li fd-action-sheet-item label=\"Reject\" glyph=\"cancel\" ></li>\n                        <li fd-action-sheet-item label=\"Decide Later\" [isCloseButton]=\"true\"></li>\n                        <li fd-action-sheet-item label=\"Cancel\" [negative]=\"true\" [isCloseButton]=\"true\"></li>\n                    </fd-action-sheet-body>\n                </fd-action-sheet>\n            </p> -->\n        </ng-container>\n    </td>\n    <td fd-table-cell>\n        <div class=\"status\" style=\"position: relative\">\n            <button\n                fd-button\n                *ngIf=\"+documentItem.MaxFileCount && !readonly\"\n                glyph=\"attachment\"\n                [label]=\"'AttachFile' | bbbTranslate\"\n                [disabled]=\"uploadingState?.key === documentItem.Title && uploadingState?.uploading\"\n                (click)=\"!readonly && uploader.open()\"\n            >\n                <bsu-mask\n                    *ngIf=\"uploadingState?.key === documentItem.Title && uploadingState?.uploading\"\n                    [marginTop]=\"'3px'\"\n                ></bsu-mask>\n            </button>\n            <button\n                fd-button\n                glyph=\"show\"\n                fullscreenFiles\n                [files]=\"files\"\n                [title]=\"documentItem.Title\"\n                [fd-inline-help]=\"'مشاهده همه' | bbbTranslate\"\n                [aria-describedby]=\"'مشاهده همه' | bbbTranslate\"\n                [ariaLabel]=\"'مشاهده همه' | bbbTranslate\"\n                fullscreenFiles\n                [disabled]=\"!files.length\"\n                [files]=\"files\"\n            ></button>\n            <button\n                fd-button\n                glyph=\"download\"\n                [fd-inline-help]=\"'دانلود همه' | bbbTranslate\"\n                [aria-describedby]=\"'دانلود همه' | bbbTranslate\"\n                [ariaLabel]=\"'دانلود همه' | bbbTranslate\"\n                downloadFiles\n                [disabled]=\"!files.length\"\n                [files]=\"files\"\n                (click)=\"downloadAll.emit()\"\n            ></button>\n        </div>\n    </td>\n    <td fd-table-cell>\n        <fd-action-sheet #actionSheet>\n            <fd-action-sheet-control>\n                <ng-container *ngTemplateOutlet=\"statusTpl\"></ng-container>\n            </fd-action-sheet-control>\n            <fd-action-sheet-body>\n                <li\n                    fd-action-sheet-item\n                    [label]=\"'Accept' | bbbTranslate\"\n                    glyph=\"accept\"\n                    (click)=\"actionSheet.close(); onReject(2)\"\n                ></li>\n                <li\n                    fd-action-sheet-item\n                    [label]=\"'Reject' | bbbTranslate\"\n                    glyph=\"cancel\"\n                    (click)=\"actionSheet.close(); onReject(3)\"\n                ></li>\n            </fd-action-sheet-body>\n        </fd-action-sheet>\n\n        <p fd-table-text maxWidth=\"400px\" *ngIf=\"status === 3\">\n            <span *ngIf=\"readonly && rejectedReason\"> {{ rejectedReason | bbbTranslate }} </span>\n            <input\n                *ngIf=\"!readonly\"\n                fd-form-control\n                [value]=\"rejectedReason | bbbTranslate\"\n                [placeholder]=\"'دلایل رد مدرک' | bbbTranslate\"\n            />\n        </p>\n    </td>\n</tr>\n\n<fd-file-uploader\n    #uploader\n    [style.display]=\"'none'\"\n    fd-toolbar-item\n    [id]=\"documentItem.ItemKey\"\n    [name]=\"'pictures_' + documentItem.ItemKey\"\n    [accept]=\"documentItem.$ValidExtensions\"\n    [fileLimit]=\"documentItem.MaxFileCount\"\n    [multiple]=\"documentItem.MaxFileCount > 0\"\n    (selectedFilesChanged)=\"onFileSelection($event)\"\n></fd-file-uploader>\n<ng-template #statusTpl>\n    <div class=\"status\">\n        <button fd-button fdType=\"transparent\">\n            <span\n                *ngIf=\"status === 1\"\n                fd-object-status\n                [label]=\"'[پیوست مدارک]' | bbbTranslate\"\n                [aria-label]=\"'[پیوست مدارک]' | bbbTranslate\"\n            ></span>\n            <span\n                *ngIf=\"status === 2\"\n                fd-object-status\n                glyph=\"message-success\"\n                status=\"positive\"\n                [label]=\"'Accepted' | bbbTranslate\"\n                [label]=\"'Accepted' | bbbTranslate\"\n            ></span>\n            <span\n                *ngIf=\"status === 3\"\n                fd-object-status\n                glyph=\"cancel\"\n                status=\"negative\"\n                [label]=\"'Rejected' | bbbTranslate\"\n                [aria-label]=\"'Rejected' | bbbTranslate\"\n            ></span>\n        </button>\n    </div>\n</ng-template>\n"]}
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Optional } from '@angular/core';
|
|
2
|
+
import { FilesValidationHelper, LinearListHelper, ReportViewBaseComponent, UploadService } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "barsa-novin-ray-core";
|
|
5
|
+
import * as i2 from "@fundamental-ngx/core";
|
|
6
|
+
import * as i3 from "@angular/common";
|
|
7
|
+
import * as i4 from "@fundamental-ngx/core/table";
|
|
8
|
+
import * as i5 from "../barsa-document-list-item/barsa-document-list-item.component";
|
|
9
|
+
export class BarsaDocumentsComponent extends ReportViewBaseComponent {
|
|
10
|
+
constructor(_el, _cdr, _renderer2, _findColumnByDbName, _ulvMainService, _portalService, _dialogService, _uploadService) {
|
|
11
|
+
super(_el, _cdr, _renderer2, _findColumnByDbName, _ulvMainService, _portalService, _uploadService);
|
|
12
|
+
this._el = _el;
|
|
13
|
+
this._cdr = _cdr;
|
|
14
|
+
this._renderer2 = _renderer2;
|
|
15
|
+
this._findColumnByDbName = _findColumnByDbName;
|
|
16
|
+
this._ulvMainService = _ulvMainService;
|
|
17
|
+
this._portalService = _portalService;
|
|
18
|
+
this._dialogService = _dialogService;
|
|
19
|
+
this._uploadService = _uploadService;
|
|
20
|
+
}
|
|
21
|
+
get documentItems() {
|
|
22
|
+
if (this.customFieldInfo) {
|
|
23
|
+
return this.customFieldInfo.DocumentItems.MoDataList;
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
return this.viewSetting.FilesSetting.DocumentItems.MoDataList;
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
ngOnInit() {
|
|
30
|
+
super.ngOnInit();
|
|
31
|
+
const { moDataList, viewSetting, allColumns } = this;
|
|
32
|
+
this._initColumnField(allColumns, viewSetting);
|
|
33
|
+
this._subscribeOnUploadFile(this.fileColumn);
|
|
34
|
+
this._mapDocumentItem(moDataList, this.documentItems);
|
|
35
|
+
this._checkMandatory();
|
|
36
|
+
}
|
|
37
|
+
ngOnChanges(changes) {
|
|
38
|
+
super.ngOnChanges(changes);
|
|
39
|
+
const { moDataList } = changes;
|
|
40
|
+
if (moDataList && !moDataList.firstChange) {
|
|
41
|
+
if (moDataList && !moDataList.firstChange) {
|
|
42
|
+
this._mapDocumentItem(moDataList.currentValue, this.documentItems);
|
|
43
|
+
this.detectChanges();
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
ngAfterViewInit() {
|
|
48
|
+
super.ngAfterViewInit();
|
|
49
|
+
setTimeout(() => {
|
|
50
|
+
for (let i = 0; i < this.documentItems.length - this.moDataList.length; i++) {
|
|
51
|
+
this.createNewMo.emit();
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
onFileSelection(files, documentItem, mo) {
|
|
56
|
+
this.selectedMo = mo;
|
|
57
|
+
this._uploadFile(files, documentItem);
|
|
58
|
+
}
|
|
59
|
+
onRemoveFile(file, mo) {
|
|
60
|
+
const fileDbName = this.fileColumn.Name;
|
|
61
|
+
let files = mo[fileDbName].Files;
|
|
62
|
+
if (file.IsNew) {
|
|
63
|
+
files = files.filter((c) => c.Id !== file.Id);
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
const existFile = files.find((c) => c.Id === file.Id);
|
|
67
|
+
existFile.IsDeleted = true;
|
|
68
|
+
}
|
|
69
|
+
mo[fileDbName].Files = [...files];
|
|
70
|
+
this._updateMo(mo);
|
|
71
|
+
}
|
|
72
|
+
onStatusChanged(e, mo) {
|
|
73
|
+
mo[this.statusColumn.Name] = e.value;
|
|
74
|
+
mo[this.rejectedReasonColumn.Name] = e.rejectedText;
|
|
75
|
+
this._updateMo(mo);
|
|
76
|
+
}
|
|
77
|
+
onRejectedTextChange(text, mo) {
|
|
78
|
+
mo[this.rejectedReasonColumn.Name] = text;
|
|
79
|
+
this._updateMo(mo);
|
|
80
|
+
}
|
|
81
|
+
_checkMandatory() {
|
|
82
|
+
const moDataList = this.moDataList;
|
|
83
|
+
const items = this.documentItems.filter((c) => c.IsRequired);
|
|
84
|
+
let mandatory = items.length > 0;
|
|
85
|
+
const mandatory2 = items
|
|
86
|
+
.map((item) => moDataList.find((c) => c[this.keyColumn.Name] === item.ItemKey))
|
|
87
|
+
.filter((item) => item)
|
|
88
|
+
.some((mo) => mo[this.fileColumn.Name].Files.filter((c) => !c.IsDeleted).length === 0);
|
|
89
|
+
mandatory = mandatory && mandatory2;
|
|
90
|
+
this.mandatory.emit(mandatory);
|
|
91
|
+
}
|
|
92
|
+
_mapDocumentItem(moDataList, documentItems) {
|
|
93
|
+
const keyName = this.keyColumn.Name;
|
|
94
|
+
moDataList.forEach((mo, index) => {
|
|
95
|
+
let documentItem = documentItems.find((c) => c.ItemKey === mo[keyName]); // find setting that matches with mo by itemKey
|
|
96
|
+
if (documentItem) {
|
|
97
|
+
mo.$documentItem = documentItem;
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
documentItem = documentItems.find((item) => moDataList.map((c) => c[keyName]).indexOf(item.ItemKey) < 0); // find a setting has not have $RelatedMo yet
|
|
101
|
+
if (documentItem) {
|
|
102
|
+
mo[keyName] = documentItem.ItemKey;
|
|
103
|
+
mo.$documentItem = documentItem;
|
|
104
|
+
this.updateMo.emit(mo);
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
_initColumnField(allColumns, viewSetting) {
|
|
110
|
+
const keyColumn = this._findColumnByDbName.transform(allColumns, viewSetting.ItemKeyField);
|
|
111
|
+
const fileColumn = this._findColumnByDbName.transform(allColumns, viewSetting.FileField);
|
|
112
|
+
const acceptedColumn = this._findColumnByDbName.transform(allColumns, viewSetting.AcceptedField);
|
|
113
|
+
const rejectedReasonColumn = this._findColumnByDbName.transform(allColumns, viewSetting.RejectedReasonField);
|
|
114
|
+
const statusColumn = this._findColumnByDbName.transform(allColumns, viewSetting.StatusField);
|
|
115
|
+
!keyColumn && this._columnNotExistsInReport(viewSetting.ItemKeyField);
|
|
116
|
+
!fileColumn && this._columnNotExistsInReport(viewSetting.FileField);
|
|
117
|
+
!rejectedReasonColumn && this._columnNotExistsInReport(viewSetting.RejectedReasonField);
|
|
118
|
+
!acceptedColumn && this._columnNotExistsInReport(viewSetting.AcceptedField);
|
|
119
|
+
!statusColumn && this._columnNotExistsInReport(viewSetting.StatusField);
|
|
120
|
+
keyColumn && (this.keyColumn = keyColumn);
|
|
121
|
+
fileColumn && (this.fileColumn = fileColumn);
|
|
122
|
+
acceptedColumn && (this.acceptedColumn = acceptedColumn);
|
|
123
|
+
rejectedReasonColumn && (this.rejectedReasonColumn = rejectedReasonColumn);
|
|
124
|
+
statusColumn && (this.statusColumn = statusColumn);
|
|
125
|
+
}
|
|
126
|
+
_subscribeOnUploadFile(fileColumn) {
|
|
127
|
+
this._filesValidationHelper = new FilesValidationHelper(0, 0, 0);
|
|
128
|
+
if (this._uploadService) {
|
|
129
|
+
this._createLinearHelper(this._uploadService, this._filesValidationHelper, fileColumn.FieldDefId);
|
|
130
|
+
this.uploadingState$ = this._uploadService.uploadingState$;
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
throw new Error('UploadService not provided.');
|
|
134
|
+
}
|
|
135
|
+
this._linearHelper.newFileUploaded$.subscribe((file) => {
|
|
136
|
+
const mo = this.moDataList.find((c) => c.Id === this.selectedMo.Id);
|
|
137
|
+
if (mo) {
|
|
138
|
+
mo[fileColumn.Name].Files = [...mo[fileColumn.Name].Files, file];
|
|
139
|
+
this._updateMo(mo);
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
_updateMo(mo) {
|
|
144
|
+
mo.$NewInlineMo = undefined;
|
|
145
|
+
if (mo.$State === 'Unchanged') {
|
|
146
|
+
mo.$State = 'Modified';
|
|
147
|
+
}
|
|
148
|
+
this.updateMo.emit(mo);
|
|
149
|
+
this._checkMandatory();
|
|
150
|
+
}
|
|
151
|
+
_createLinearHelper(uploadService, filesValidationHelper, fieldDefId) {
|
|
152
|
+
this._linearHelper = new LinearListHelper(uploadService, filesValidationHelper, fieldDefId);
|
|
153
|
+
}
|
|
154
|
+
_uploadFile(files, documentItem) {
|
|
155
|
+
const filesValidationHelper = this._filesValidationHelper;
|
|
156
|
+
filesValidationHelper.maxFileCount = +documentItem.MaxFileCount;
|
|
157
|
+
filesValidationHelper.maxFileSize = +documentItem.EachFileSize;
|
|
158
|
+
filesValidationHelper.maxTotalFileSize = +documentItem.MaxFileSize;
|
|
159
|
+
this._linearHelper.uploadToServer(files, documentItem.Title);
|
|
160
|
+
}
|
|
161
|
+
_columnNotExistsInReport(columnCaption) {
|
|
162
|
+
throw new Error(`can not find ${columnCaption} column in report.please add it to report columns.`);
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
BarsaDocumentsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaDocumentsComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }, { token: i1.FindColumnByDbNamePipe }, { token: i1.UlvMainService }, { token: i1.PortalService }, { token: i2.DialogService }, { token: i1.UploadService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
166
|
+
BarsaDocumentsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaDocumentsComponent, selector: "bdc-barsa-documents", providers: [UploadService], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!-- <ul fd-list [byline]=\"true\" fdCompact [selection]=\"false\"> -->\n<table fd-table aria-label=\"Default\" [allCellsFocusable]=\"true\" [noBorderX]=\"true\">\n <thead fd-table-header>\n <tr fd-table-row>\n <th fd-table-cell>{{ '\u0639\u06A9\u0633' | bbbTranslate }}</th>\n <th fd-table-cell style=\"min-width: 140px; width: auto\">{{ '\u0646\u0648\u0639 \u0645\u062F\u0631\u06A9' | bbbTranslate }}</th>\n <th fd-table-cell style=\"width: 99%\">{{ '\u0627\u0644\u0635\u0627\u0642 \u0641\u0627\u06CC\u0644' | bbbTranslate }}</th>\n <th fd-table-cell></th>\n <th fd-table-cell style=\"width: 400px; min-width: 400px; max-width: 400px\">{{ '\u0648\u0636\u0639\u06CC\u062A' | bbbTranslate }}</th>\n </tr>\n </thead>\n <tbody fd-table-body>\n <ng-container *ngFor=\"let mo of moDataList; trackBy: _trackByRow\">\n <bdc-barsa-document-list-item\n *ngIf=\"mo.$documentItem\"\n [documentItem]=\"mo.$documentItem\"\n [accepted]=\"mo[acceptedColumn.Name]\"\n [files]=\"mo[fileColumn.Name].Files\"\n [uploadingState]=\"(uploadingState$ | async)!!\"\n [rejectedReason]=\"mo[rejectedReasonColumn.Name]\"\n [fileDbName]=\"fileColumn.Name\"\n [status]=\"+mo[statusColumn.Name]\"\n [deviceSize]=\"deviceSize\"\n [readonly]=\"!access.Edit\"\n [deviceSize]=\"deviceSize\"\n (removeFile)=\"onRemoveFile($event, mo)\"\n (fileSelectionChange)=\"onFileSelection($event, mo.$documentItem, mo)\"\n (rejectTextChange)=\"onRejectedTextChange($event, mo)\"\n (statusChanged)=\"onStatusChanged($event, mo)\"\n ></bdc-barsa-document-list-item>\n </ng-container>\n <!-- </ul> -->\n </tbody>\n</table>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TableComponent, selector: "table[fd-table]", inputs: ["noBorderX", "noBorderY", "popIn", "responsive", "keys", "allCellsFocusable"], exportAs: ["fd-table"] }, { kind: "directive", type: i4.TableHeaderDirective, selector: "[fdTableHeader], [fd-table-header]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i4.TableBodyDirective, selector: "[fdTableBody], [fd-table-body]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i4.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i4.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "tabindex", "hoverable", "fitContent", "noPadding", "noData", "key", "cellFocusedEventAnnouncer"] }, { kind: "component", type: i5.BarsaDocumentListItemComponent, selector: "bdc-barsa-document-list-item", inputs: ["documentItem", "deviceSize", "files", "accepted", "rejectedReason", "readonly", "status", "uploadingState"], outputs: ["statusChanged", "rejectTextChange", "fileSelectionChange", "removeFile", "fullscreen", "download", "downloadAll"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
167
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaDocumentsComponent, decorators: [{
|
|
168
|
+
type: Component,
|
|
169
|
+
args: [{ selector: 'bdc-barsa-documents', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UploadService], template: "<!-- <ul fd-list [byline]=\"true\" fdCompact [selection]=\"false\"> -->\n<table fd-table aria-label=\"Default\" [allCellsFocusable]=\"true\" [noBorderX]=\"true\">\n <thead fd-table-header>\n <tr fd-table-row>\n <th fd-table-cell>{{ '\u0639\u06A9\u0633' | bbbTranslate }}</th>\n <th fd-table-cell style=\"min-width: 140px; width: auto\">{{ '\u0646\u0648\u0639 \u0645\u062F\u0631\u06A9' | bbbTranslate }}</th>\n <th fd-table-cell style=\"width: 99%\">{{ '\u0627\u0644\u0635\u0627\u0642 \u0641\u0627\u06CC\u0644' | bbbTranslate }}</th>\n <th fd-table-cell></th>\n <th fd-table-cell style=\"width: 400px; min-width: 400px; max-width: 400px\">{{ '\u0648\u0636\u0639\u06CC\u062A' | bbbTranslate }}</th>\n </tr>\n </thead>\n <tbody fd-table-body>\n <ng-container *ngFor=\"let mo of moDataList; trackBy: _trackByRow\">\n <bdc-barsa-document-list-item\n *ngIf=\"mo.$documentItem\"\n [documentItem]=\"mo.$documentItem\"\n [accepted]=\"mo[acceptedColumn.Name]\"\n [files]=\"mo[fileColumn.Name].Files\"\n [uploadingState]=\"(uploadingState$ | async)!!\"\n [rejectedReason]=\"mo[rejectedReasonColumn.Name]\"\n [fileDbName]=\"fileColumn.Name\"\n [status]=\"+mo[statusColumn.Name]\"\n [deviceSize]=\"deviceSize\"\n [readonly]=\"!access.Edit\"\n [deviceSize]=\"deviceSize\"\n (removeFile)=\"onRemoveFile($event, mo)\"\n (fileSelectionChange)=\"onFileSelection($event, mo.$documentItem, mo)\"\n (rejectTextChange)=\"onRejectedTextChange($event, mo)\"\n (statusChanged)=\"onStatusChanged($event, mo)\"\n ></bdc-barsa-document-list-item>\n </ng-container>\n <!-- </ul> -->\n </tbody>\n</table>\n", styles: [":host{display:block}\n"] }]
|
|
170
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }, { type: i1.FindColumnByDbNamePipe }, { type: i1.UlvMainService }, { type: i1.PortalService }, { type: i2.DialogService }, { type: i1.UploadService, decorators: [{
|
|
171
|
+
type: Optional
|
|
172
|
+
}] }]; } });
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-documents.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-develop-components/src/lib/barsa-documents/barsa-documents.component.ts","../../../../../projects/barsa-develop-components/src/lib/barsa-documents/barsa-documents.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    OnChanges,\n    OnInit,\n    Optional,\n    Renderer2,\n    SimpleChanges\n} from '@angular/core';\nimport { DialogService } from '@fundamental-ngx/core';\nimport {\n    FilesValidationHelper,\n    LinearListHelper,\n    MetaobjectDataModel,\n    ReportViewBaseComponent,\n    ReportViewColumn,\n    UploadService,\n    FileAttachmentInfo,\n    FindColumnByDbNamePipe,\n    PortalService,\n    UlvMainService,\n    IUploadingState\n} from 'barsa-novin-ray-core';\nimport { Observable } from 'rxjs';\nimport { DocumentItem, DocumentsSetting } from '../models';\n\n@Component({\n    selector: 'bdc-barsa-documents',\n    templateUrl: './barsa-documents.component.html',\n    styleUrls: ['./barsa-documents.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [UploadService]\n})\nexport class BarsaDocumentsComponent extends ReportViewBaseComponent<DocumentsSetting> implements OnInit, OnChanges {\n    keyColumn: ReportViewColumn;\n    fileColumn: ReportViewColumn;\n    statusColumn: ReportViewColumn;\n    rejectedReasonColumn: ReportViewColumn;\n    acceptedColumn: ReportViewColumn;\n    selectedMo: MetaobjectDataModel;\n    uploadingState$: Observable<IUploadingState>;\n\n    protected _filesValidationHelper: FilesValidationHelper;\n    protected _linearHelper: LinearListHelper;\n\n    constructor(\n        protected _el: ElementRef,\n        protected _cdr: ChangeDetectorRef,\n        protected _renderer2: Renderer2,\n        protected _findColumnByDbName: FindColumnByDbNamePipe,\n        protected _ulvMainService: UlvMainService,\n        protected _portalService: PortalService,\n        protected _dialogService: DialogService,\n        @Optional() protected _uploadService?: UploadService\n    ) {\n        super(_el, _cdr, _renderer2, _findColumnByDbName, _ulvMainService, _portalService, _uploadService);\n    }\n\n    get documentItems(): Array<DocumentItem> {\n        if (this.customFieldInfo) {\n            return this.customFieldInfo.DocumentItems.MoDataList as Array<DocumentItem>;\n        } else {\n            return this.viewSetting.FilesSetting.DocumentItems.MoDataList as Array<DocumentItem>;\n        }\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        const { moDataList, viewSetting, allColumns } = this;\n\n        this._initColumnField(allColumns, viewSetting);\n        this._subscribeOnUploadFile(this.fileColumn);\n        this._mapDocumentItem(moDataList, this.documentItems);\n        this._checkMandatory();\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        const { moDataList } = changes;\n        if (moDataList && !moDataList.firstChange) {\n            if (moDataList && !moDataList.firstChange) {\n                this._mapDocumentItem(moDataList.currentValue, this.documentItems);\n                this.detectChanges();\n            }\n        }\n    }\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        setTimeout(() => {\n            for (let i = 0; i < this.documentItems.length - this.moDataList.length; i++) {\n                this.createNewMo.emit();\n            }\n        });\n    }\n    onFileSelection(files: File[], documentItem: DocumentItem, mo: MetaobjectDataModel): void {\n        this.selectedMo = mo;\n        this._uploadFile(files, documentItem);\n    }\n    onRemoveFile(file: FileAttachmentInfo, mo: MetaobjectDataModel): void {\n        const fileDbName = this.fileColumn.Name;\n        let files = mo[fileDbName].Files;\n        if (file.IsNew) {\n            files = files.filter((c) => c.Id !== file.Id);\n        } else {\n            const existFile = files.find((c) => c.Id === file.Id);\n            existFile.IsDeleted = true;\n        }\n        mo[fileDbName].Files = [...files];\n        this._updateMo(mo);\n    }\n    onStatusChanged(e: { value: number; rejectedText: string }, mo: MetaobjectDataModel): void {\n        mo[this.statusColumn.Name] = e.value;\n        mo[this.rejectedReasonColumn.Name] = e.rejectedText;\n        this._updateMo(mo);\n    }\n    onRejectedTextChange(text: string, mo: MetaobjectDataModel): void {\n        mo[this.rejectedReasonColumn.Name] = text;\n        this._updateMo(mo);\n    }\n    _checkMandatory(): void {\n        const moDataList = this.moDataList;\n        const items = this.documentItems.filter((c) => c.IsRequired);\n        let mandatory = items.length > 0;\n        const mandatory2 = items\n            .map((item) => moDataList.find((c) => c[this.keyColumn.Name] === item.ItemKey))\n            .filter((item) => item)\n            .some((mo) => mo[this.fileColumn.Name].Files.filter((c) => !c.IsDeleted).length === 0);\n        mandatory = mandatory && mandatory2;\n        this.mandatory.emit(mandatory);\n    }\n    _mapDocumentItem(moDataList: Array<MetaobjectDataModel>, documentItems: Array<DocumentItem>): void {\n        const keyName = this.keyColumn.Name;\n        moDataList.forEach((mo, index) => {\n            let documentItem = documentItems.find((c) => c.ItemKey === mo[keyName]); // find setting that matches with mo by itemKey\n            if (documentItem) {\n                mo.$documentItem = documentItem;\n            } else {\n                documentItem = documentItems.find(\n                    (item) => moDataList.map((c) => c[keyName]).indexOf(item.ItemKey) < 0\n                ); // find a setting has not have $RelatedMo yet\n                if (documentItem) {\n                    mo[keyName] = documentItem.ItemKey;\n                    mo.$documentItem = documentItem;\n                    this.updateMo.emit(mo);\n                }\n            }\n        });\n    }\n    protected _initColumnField(allColumns: ReportViewColumn[], viewSetting: DocumentsSetting): void {\n        const keyColumn = this._findColumnByDbName.transform(allColumns, viewSetting.ItemKeyField);\n        const fileColumn = this._findColumnByDbName.transform(allColumns, viewSetting.FileField);\n        const acceptedColumn = this._findColumnByDbName.transform(allColumns, viewSetting.AcceptedField);\n        const rejectedReasonColumn = this._findColumnByDbName.transform(allColumns, viewSetting.RejectedReasonField);\n        const statusColumn = this._findColumnByDbName.transform(allColumns, viewSetting.StatusField);\n        !keyColumn && this._columnNotExistsInReport(viewSetting.ItemKeyField);\n        !fileColumn && this._columnNotExistsInReport(viewSetting.FileField);\n        !rejectedReasonColumn && this._columnNotExistsInReport(viewSetting.RejectedReasonField);\n        !acceptedColumn && this._columnNotExistsInReport(viewSetting.AcceptedField);\n        !statusColumn && this._columnNotExistsInReport(viewSetting.StatusField);\n\n        keyColumn && (this.keyColumn = keyColumn);\n        fileColumn && (this.fileColumn = fileColumn);\n        acceptedColumn && (this.acceptedColumn = acceptedColumn);\n        rejectedReasonColumn && (this.rejectedReasonColumn = rejectedReasonColumn);\n        statusColumn && (this.statusColumn = statusColumn);\n    }\n    protected _subscribeOnUploadFile(fileColumn: ReportViewColumn): void {\n        this._filesValidationHelper = new FilesValidationHelper(0, 0, 0);\n        if (this._uploadService) {\n            this._createLinearHelper(this._uploadService, this._filesValidationHelper, fileColumn.FieldDefId);\n            this.uploadingState$ = this._uploadService.uploadingState$;\n        } else {\n            throw new Error('UploadService not provided.');\n        }\n\n        this._linearHelper.newFileUploaded$.subscribe((file) => {\n            const mo = this.moDataList.find((c) => c.Id === this.selectedMo.Id);\n            if (mo) {\n                mo[fileColumn.Name].Files = [...mo[fileColumn.Name].Files, file];\n                this._updateMo(mo);\n            }\n        });\n    }\n    protected _updateMo(mo: MetaobjectDataModel): void {\n        mo.$NewInlineMo = undefined;\n        if (mo.$State === 'Unchanged') {\n            mo.$State = 'Modified';\n        }\n        this.updateMo.emit(mo);\n        this._checkMandatory();\n    }\n    protected _createLinearHelper(\n        uploadService: UploadService,\n        filesValidationHelper: FilesValidationHelper,\n        fieldDefId: string\n    ): void {\n        this._linearHelper = new LinearListHelper(uploadService, filesValidationHelper, fieldDefId);\n    }\n    protected _uploadFile(files: File[], documentItem: DocumentItem): void {\n        const filesValidationHelper = this._filesValidationHelper;\n        filesValidationHelper.maxFileCount = +documentItem.MaxFileCount;\n        filesValidationHelper.maxFileSize = +documentItem.EachFileSize;\n        filesValidationHelper.maxTotalFileSize = +documentItem.MaxFileSize;\n        this._linearHelper.uploadToServer(files, documentItem.Title);\n    }\n    protected _columnNotExistsInReport(columnCaption): void {\n        throw new Error(`can not find ${columnCaption} column in report.please add it to report columns.`);\n    }\n}\n","<!-- <ul fd-list [byline]=\"true\" fdCompact [selection]=\"false\"> -->\n<table fd-table aria-label=\"Default\" [allCellsFocusable]=\"true\" [noBorderX]=\"true\">\n    <thead fd-table-header>\n        <tr fd-table-row>\n            <th fd-table-cell>{{ 'عکس' | bbbTranslate }}</th>\n            <th fd-table-cell style=\"min-width: 140px; width: auto\">{{ 'نوع مدرک' | bbbTranslate }}</th>\n            <th fd-table-cell style=\"width: 99%\">{{ 'الصاق فایل' | bbbTranslate }}</th>\n            <th fd-table-cell></th>\n            <th fd-table-cell style=\"width: 400px; min-width: 400px; max-width: 400px\">{{ 'وضعیت' | bbbTranslate }}</th>\n        </tr>\n    </thead>\n    <tbody fd-table-body>\n        <ng-container *ngFor=\"let mo of moDataList; trackBy: _trackByRow\">\n            <bdc-barsa-document-list-item\n                *ngIf=\"mo.$documentItem\"\n                [documentItem]=\"mo.$documentItem\"\n                [accepted]=\"mo[acceptedColumn.Name]\"\n                [files]=\"mo[fileColumn.Name].Files\"\n                [uploadingState]=\"(uploadingState$ | async)!!\"\n                [rejectedReason]=\"mo[rejectedReasonColumn.Name]\"\n                [fileDbName]=\"fileColumn.Name\"\n                [status]=\"+mo[statusColumn.Name]\"\n                [deviceSize]=\"deviceSize\"\n                [readonly]=\"!access.Edit\"\n                [deviceSize]=\"deviceSize\"\n                (removeFile)=\"onRemoveFile($event, mo)\"\n                (fileSelectionChange)=\"onFileSelection($event, mo.$documentItem, mo)\"\n                (rejectTextChange)=\"onRejectedTextChange($event, mo)\"\n                (statusChanged)=\"onStatusChanged($event, mo)\"\n            ></bdc-barsa-document-list-item>\n        </ng-container>\n        <!-- </ul> -->\n    </tbody>\n</table>\n"]}
|
|
@@ -36,10 +36,10 @@ export class CardContentImageAndTitleComponent extends BaseItemContentPropsCompo
|
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
38
|
CardContentImageAndTitleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CardContentImageAndTitleComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
39
|
-
CardContentImageAndTitleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CardContentImageAndTitleComponent, selector: "bdc-card-content-image-and-title", viewQueries: [{ propertyName: "iconRef", first: true, predicate: ["iconRef"], descendants: true, read: ElementRef }, { propertyName: "elemRef", first: true, predicate: ["elemRef"], descendants: true, read: ElementRef }], usesInheritance: true, ngImport: i0, template: "<div class=\"card-content\" #elemRef>\n <div class=\"item-data\">\n <img\n *ngIf=\"iconPicture; else iconTemplate\"\n [imgLazy]=\"iconPicture.FileId | picFieldSrc: 'ID':null:'':100:70\"\n height=\"70\"\n width=\"100\"\n [alt]=\"title\"\n />\n <ng-template #iconTemplate>\n <fd-icon #iconRef *ngIf=\"icon\" [glyph]=\"icon\"> </fd-icon>\n </ng-template>\n </div>\n <h4 fd-title class=\"item-data fd-title--wrap\">\n {{ title }}\n </h4>\n</div>\n", styles: [":host{display:flex;justify-content:center;align-items:stretch;height:100%;width:100%;min-height:180px}:host:hover{cursor:pointer}.card-content{display:flex;align-items:center;flex-direction:column;align-self:stretch;margin-top:auto;margin-bottom:auto;width:100%}.item-data{text-align:center}fd-icon{font-size:2.5rem}h4{height:60px;width:80%;text-align:center}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ImageLazyDirective, selector: "[imgLazy]", inputs: ["auto", "threshold", "imgLazy"], outputs: ["imageLoaded"] }, { kind: "component", type: i3.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "class", "ariaLabel"] }, { kind: "component", type: i4.TitleComponent, selector: "h1[fd-title], h2[fd-title], h3[fd-title], h4[fd-title], h5[fd-title], h6[fd-title]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "pipe", type: i2.PictureFieldSourcePipe, name: "picFieldSrc" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
39
|
+
CardContentImageAndTitleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CardContentImageAndTitleComponent, selector: "bdc-card-content-image-and-title", viewQueries: [{ propertyName: "iconRef", first: true, predicate: ["iconRef"], descendants: true, read: ElementRef }, { propertyName: "elemRef", first: true, predicate: ["elemRef"], descendants: true, read: ElementRef }], usesInheritance: true, ngImport: i0, template: "<div class=\"card-content\" #elemRef>\r\n <div class=\"item-data\">\r\n <img\r\n *ngIf=\"iconPicture; else iconTemplate\"\r\n [imgLazy]=\"iconPicture.FileId | picFieldSrc: 'ID':null:'':100:70\"\r\n height=\"70\"\r\n width=\"100\"\r\n [alt]=\"title\"\r\n />\r\n <ng-template #iconTemplate>\r\n <fd-icon #iconRef *ngIf=\"icon\" [glyph]=\"icon\"> </fd-icon>\r\n </ng-template>\r\n </div>\r\n <h4 fd-title class=\"item-data fd-title--wrap\">\r\n {{ title }}\r\n </h4>\r\n</div>\r\n", styles: [":host{display:flex;justify-content:center;align-items:stretch;height:100%;width:100%;min-height:180px}:host:hover{cursor:pointer}.card-content{display:flex;align-items:center;flex-direction:column;align-self:stretch;margin-top:auto;margin-bottom:auto;width:100%}.item-data{text-align:center}fd-icon{font-size:2.5rem}h4{height:60px;width:80%;text-align:center}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ImageLazyDirective, selector: "[imgLazy]", inputs: ["auto", "threshold", "imgLazy"], outputs: ["imageLoaded"] }, { kind: "component", type: i3.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "class", "ariaLabel"] }, { kind: "component", type: i4.TitleComponent, selector: "h1[fd-title], h2[fd-title], h3[fd-title], h4[fd-title], h5[fd-title], h6[fd-title]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "pipe", type: i2.PictureFieldSourcePipe, name: "picFieldSrc" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
40
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CardContentImageAndTitleComponent, decorators: [{
|
|
41
41
|
type: Component,
|
|
42
|
-
args: [{ selector: 'bdc-card-content-image-and-title', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"card-content\" #elemRef>\n <div class=\"item-data\">\n <img\n *ngIf=\"iconPicture; else iconTemplate\"\n [imgLazy]=\"iconPicture.FileId | picFieldSrc: 'ID':null:'':100:70\"\n height=\"70\"\n width=\"100\"\n [alt]=\"title\"\n />\n <ng-template #iconTemplate>\n <fd-icon #iconRef *ngIf=\"icon\" [glyph]=\"icon\"> </fd-icon>\n </ng-template>\n </div>\n <h4 fd-title class=\"item-data fd-title--wrap\">\n {{ title }}\n </h4>\n</div>\n", styles: [":host{display:flex;justify-content:center;align-items:stretch;height:100%;width:100%;min-height:180px}:host:hover{cursor:pointer}.card-content{display:flex;align-items:center;flex-direction:column;align-self:stretch;margin-top:auto;margin-bottom:auto;width:100%}.item-data{text-align:center}fd-icon{font-size:2.5rem}h4{height:60px;width:80%;text-align:center}\n"] }]
|
|
42
|
+
args: [{ selector: 'bdc-card-content-image-and-title', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"card-content\" #elemRef>\r\n <div class=\"item-data\">\r\n <img\r\n *ngIf=\"iconPicture; else iconTemplate\"\r\n [imgLazy]=\"iconPicture.FileId | picFieldSrc: 'ID':null:'':100:70\"\r\n height=\"70\"\r\n width=\"100\"\r\n [alt]=\"title\"\r\n />\r\n <ng-template #iconTemplate>\r\n <fd-icon #iconRef *ngIf=\"icon\" [glyph]=\"icon\"> </fd-icon>\r\n </ng-template>\r\n </div>\r\n <h4 fd-title class=\"item-data fd-title--wrap\">\r\n {{ title }}\r\n </h4>\r\n</div>\r\n", styles: [":host{display:flex;justify-content:center;align-items:stretch;height:100%;width:100%;min-height:180px}:host:hover{cursor:pointer}.card-content{display:flex;align-items:center;flex-direction:column;align-self:stretch;margin-top:auto;margin-bottom:auto;width:100%}.item-data{text-align:center}fd-icon{font-size:2.5rem}h4{height:60px;width:80%;text-align:center}\n"] }]
|
|
43
43
|
}], propDecorators: { iconRef: [{
|
|
44
44
|
type: ViewChild,
|
|
45
45
|
args: ['iconRef', { read: ElementRef }]
|
|
@@ -47,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
47
47
|
type: ViewChild,
|
|
48
48
|
args: ['elemRef', { read: ElementRef }]
|
|
49
49
|
}] } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC1jb250ZW50LWltYWdlLWFuZC10aXRsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1kZXZlbG9wLWNvbXBvbmVudHMvc3JjL2xpYi9jYXJkLWNvbnRlbnQtaW1hZ2UtYW5kLXRpdGxlL2NhcmQtY29udGVudC1pbWFnZS1hbmQtdGl0bGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzL3NyYy9saWIvY2FyZC1jb250ZW50LWltYWdlLWFuZC10aXRsZS9jYXJkLWNvbnRlbnQtaW1hZ2UtYW5kLXRpdGxlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRyxPQUFPLEVBQXdCLDZCQUE2QixFQUEyQixNQUFNLHNCQUFzQixDQUFDOzs7Ozs7QUFRcEgsTUFBTSxPQUFPLGlDQUNULFNBQVEsNkJBQXNEO0lBaUI5RCxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUM7UUFDbkMsSUFBSSxVQUFVLElBQUksSUFBSSxFQUFFO1lBQ3BCLElBQUksQ0FBQyxTQUFTLEdBQUcsVUFBVSxDQUFDLGFBQWEsQ0FBQztZQUMxQyxJQUFJLENBQUMsZUFBZSxHQUFHLFVBQVUsQ0FBQyx1QkFBdUIsQ0FBQztZQUMxRCxJQUFJLENBQUMsb0JBQW9CLEdBQUcsVUFBVSxDQUFDLDRCQUE0QixDQUFDO1lBQ3BFLElBQUksQ0FBQyxjQUFjLEdBQUcsVUFBVSxDQUFDLGtCQUFrQixDQUFDO1lBRXBELElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUMxRixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLEVBQUUsRUFBRSxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDOUUsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsWUFBWSxFQUFFLElBQUksQ0FBQyxFQUFFLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBRXBGLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1NBQzVCO0lBQ0wsQ0FBQztJQUVPLGlCQUFpQjtRQUNyQixJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUNqQyxJQUFJLENBQUMsU0FBUyxHQUFHLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1NBQ3pDO1FBRUQsSUFBSSxJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDdkMsSUFBSSxDQUFDLGVBQWUsR0FBRyxHQUFHLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQztTQUNyRDtRQUVELElBQUksSUFBSSxDQUFDLG9CQUFvQixDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDNUMsSUFBSSxDQUFDLG9CQUFvQixHQUFHLEdBQUcsR0FBRyxJQUFJLENBQUMsb0JBQW9CLENBQUM7U0FDL0Q7UUFFRCxJQUFJLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUN0QyxJQUFJLENBQUMsY0FBYyxHQUFHLEdBQUcsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDO1NBQ25EO0lBQ0wsQ0FBQzs7OEhBbkRRLGlDQUFpQztrSEFBakMsaUNBQWlDLHVKQUlaLFVBQVUsNkZBQ1YsVUFBVSxvRENkNUMsZ2xCQWlCQTsyRkRSYSxpQ0FBaUM7a0JBTjdDLFNBQVM7K0JBQ0ksa0NBQWtDLG1CQUczQix1QkFBdUIsQ0FBQyxNQUFNOzhCQU1ILE9BQU87c0JBQWxELFNBQVM7dUJBQUMsU0FBUyxFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRTtnQkFDRSxPQUFPO3NCQUFsRCxTQUFTO3VCQUFDLFNBQVMsRUFBRSxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIFZpZXdDaGlsZCwgRWxlbWVudFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGaWxlUGljdHVyZUluZm9Nb2RlbCwgQmFzZUl0ZW1Db250ZW50UHJvcHNDb21wb25lbnQsIFVpUmVwb3J0Vmlld0Jhc2VTZXR0aW5nIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JkYy1jYXJkLWNvbnRlbnQtaW1hZ2UtYW5kLXRpdGxlJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9jYXJkLWNvbnRlbnQtaW1hZ2UtYW5kLXRpdGxlLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2NhcmQtY29udGVudC1pbWFnZS1hbmQtdGl0bGUuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDYXJkQ29udGVudEltYWdlQW5kVGl0bGVDb21wb25lbnRcclxuICAgIGV4dGVuZHMgQmFzZUl0ZW1Db250ZW50UHJvcHNDb21wb25lbnQ8VWlSZXBvcnRWaWV3QmFzZVNldHRpbmc+XHJcbiAgICBpbXBsZW1lbnRzIE9uSW5pdFxyXG57XHJcbiAgICBAVmlld0NoaWxkKCdpY29uUmVmJywgeyByZWFkOiBFbGVtZW50UmVmIH0pIGljb25SZWY6IEVsZW1lbnRSZWY7XHJcbiAgICBAVmlld0NoaWxkKCdlbGVtUmVmJywgeyByZWFkOiBFbGVtZW50UmVmIH0pIGVsZW1SZWY6IEVsZW1lbnRSZWY7XHJcblxyXG4gICAgaWNvbkNvbG9yOiBzdHJpbmc7XHJcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHN0cmluZztcclxuICAgIGJhY2tncm91bmRIb3ZlckNvbG9yOiBzdHJpbmc7XHJcbiAgICBpY29uSG92ZXJDb2xvcjogc3RyaW5nO1xyXG4gICAgX2ljb25Db2xvcjogc3RyaW5nO1xyXG4gICAgX2ljb25Ib3ZlckNvbG9yOiBzdHJpbmc7XHJcbiAgICBfYmFja2dyb3VuZENvbG9yOiBzdHJpbmc7XHJcbiAgICB0aXRsZTogc3RyaW5nO1xyXG4gICAgaWNvbjogc3RyaW5nO1xyXG4gICAgaWNvblBpY3R1cmU6IEZpbGVQaWN0dXJlSW5mb01vZGVsO1xyXG5cclxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XHJcbiAgICAgICAgY29uc3QgcGFyYW1ldGVycyA9IHRoaXMucGFyYW1ldGVycztcclxuICAgICAgICBpZiAocGFyYW1ldGVycyAhPSBudWxsKSB7XHJcbiAgICAgICAgICAgIHRoaXMuaWNvbkNvbG9yID0gcGFyYW1ldGVycy5Gb250SWNvbkNvbG9yO1xyXG4gICAgICAgICAgICB0aGlzLmJhY2tncm91bmRDb2xvciA9IHBhcmFtZXRlcnMuRm9udEljb25CYWNrZ3JvdW5kQ29sb3I7XHJcbiAgICAgICAgICAgIHRoaXMuYmFja2dyb3VuZEhvdmVyQ29sb3IgPSBwYXJhbWV0ZXJzLkZvbnRJY29uSG92ZXJCYWNrZ3JvdW5kQ29sb3I7XHJcbiAgICAgICAgICAgIHRoaXMuaWNvbkhvdmVyQ29sb3IgPSBwYXJhbWV0ZXJzLkZvbnRJY29uSG92ZXJDb2xvcjtcclxuXHJcbiAgICAgICAgICAgIHRoaXMuaWNvblBpY3R1cmUgPSB0aGlzLl9ydmFsLnRyYW5zZm9ybShwYXJhbWV0ZXJzLkljb25QaWN0dXJlLCB0aGlzLm1vLCB0aGlzLmFsbENvbHVtbnMpO1xyXG4gICAgICAgICAgICB0aGlzLnRpdGxlID0gdGhpcy5fcnZhbC50cmFuc2Zvcm0ocGFyYW1ldGVycy5UaXRsZSwgdGhpcy5tbywgdGhpcy5hbGxDb2x1bW5zKTtcclxuICAgICAgICAgICAgdGhpcy5pY29uID0gdGhpcy5fcnZhbC50cmFuc2Zvcm0ocGFyYW1ldGVycy5Gb250SWNvbk5hbWUsIHRoaXMubW8sIHRoaXMuYWxsQ29sdW1ucyk7XHJcblxyXG4gICAgICAgICAgICB0aGlzLnByZXBhcmVOdW1iZXJTaWduKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgcHJlcGFyZU51bWJlclNpZ24oKTogdm9pZCB7XHJcbiAgICAgICAgaWYgKHRoaXMuaWNvbkNvbG9yLmluZGV4T2YoJyMnKSA8IDApIHtcclxuICAgICAgICAgICAgdGhpcy5pY29uQ29sb3IgPSAnIycgKyB0aGlzLmljb25Db2xvcjtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGlmICh0aGlzLmJhY2tncm91bmRDb2xvci5pbmRleE9mKCcjJykgPCAwKSB7XHJcbiAgICAgICAgICAgIHRoaXMuYmFja2dyb3VuZENvbG9yID0gJyMnICsgdGhpcy5iYWNrZ3JvdW5kQ29sb3I7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBpZiAodGhpcy5iYWNrZ3JvdW5kSG92ZXJDb2xvci5pbmRleE9mKCcjJykgPCAwKSB7XHJcbiAgICAgICAgICAgIHRoaXMuYmFja2dyb3VuZEhvdmVyQ29sb3IgPSAnIycgKyB0aGlzLmJhY2tncm91bmRIb3ZlckNvbG9yO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgaWYgKHRoaXMuaWNvbkhvdmVyQ29sb3IuaW5kZXhPZignIycpIDwgMCkge1xyXG4gICAgICAgICAgICB0aGlzLmljb25Ib3ZlckNvbG9yID0gJyMnICsgdGhpcy5pY29uSG92ZXJDb2xvcjtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImNhcmQtY29udGVudFwiICNlbGVtUmVmPlxyXG4gICAgPGRpdiBjbGFzcz1cIml0ZW0tZGF0YVwiPlxyXG4gICAgICAgIDxpbWdcclxuICAgICAgICAgICAgKm5nSWY9XCJpY29uUGljdHVyZTsgZWxzZSBpY29uVGVtcGxhdGVcIlxyXG4gICAgICAgICAgICBbaW1nTGF6eV09XCJpY29uUGljdHVyZS5GaWxlSWQgfCBwaWNGaWVsZFNyYzogJ0lEJzpudWxsOicnOjEwMDo3MFwiXHJcbiAgICAgICAgICAgIGhlaWdodD1cIjcwXCJcclxuICAgICAgICAgICAgd2lkdGg9XCIxMDBcIlxyXG4gICAgICAgICAgICBbYWx0XT1cInRpdGxlXCJcclxuICAgICAgICAvPlxyXG4gICAgICAgIDxuZy10ZW1wbGF0ZSAjaWNvblRlbXBsYXRlPlxyXG4gICAgICAgICAgICA8ZmQtaWNvbiAjaWNvblJlZiAqbmdJZj1cImljb25cIiBbZ2x5cGhdPVwiaWNvblwiPiA8L2ZkLWljb24+XHJcbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgIDwvZGl2PlxyXG4gICAgPGg0IGZkLXRpdGxlIGNsYXNzPVwiaXRlbS1kYXRhIGZkLXRpdGxlLS13cmFwXCI+XHJcbiAgICAgICAge3sgdGl0bGUgfX1cclxuICAgIDwvaDQ+XHJcbjwvZGl2PlxyXG4iXX0=
|
|
@@ -30,9 +30,9 @@ export class CardContentLineChartComponent extends BaseItemContentPropsComponent
|
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
32
|
CardContentLineChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CardContentLineChartComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
-
CardContentLineChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CardContentLineChartComponent, selector: "bdc-card-content-line-chart", usesInheritance: true, ngImport: i0, template: "<div class=\"card-content\" *ngIf=\"chartOption\" #elemRef>\n <div beChartLineTime [chartOption]=\"chartOption\"></div>\n</div>\n", styles: [":host{display:block;padding:15px}.card-content{height:300px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ChartLineTimeBaseDirective, selector: "[beChartLineTime]", inputs: ["chartOption"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
33
|
+
CardContentLineChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: CardContentLineChartComponent, selector: "bdc-card-content-line-chart", usesInheritance: true, ngImport: i0, template: "<div class=\"card-content\" *ngIf=\"chartOption\" #elemRef>\r\n <div beChartLineTime [chartOption]=\"chartOption\"></div>\r\n</div>\r\n", styles: [":host{display:block;padding:15px}.card-content{height:300px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ChartLineTimeBaseDirective, selector: "[beChartLineTime]", inputs: ["chartOption"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
34
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: CardContentLineChartComponent, decorators: [{
|
|
35
35
|
type: Component,
|
|
36
|
-
args: [{ selector: 'bdc-card-content-line-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"card-content\" *ngIf=\"chartOption\" #elemRef>\n <div beChartLineTime [chartOption]=\"chartOption\"></div>\n</div>\n", styles: [":host{display:block;padding:15px}.card-content{height:300px}\n"] }]
|
|
36
|
+
args: [{ selector: 'bdc-card-content-line-chart', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"card-content\" *ngIf=\"chartOption\" #elemRef>\r\n <div beChartLineTime [chartOption]=\"chartOption\"></div>\r\n</div>\r\n", styles: [":host{display:block;padding:15px}.card-content{height:300px}\n"] }]
|
|
37
37
|
}] });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC1jb250ZW50LWxpbmUtY2hhcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzL3NyYy9saWIvY2FyZC1jb250ZW50LWxpbmUtY2hhcnQvY2FyZC1jb250ZW50LWxpbmUtY2hhcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtZGV2ZWxvcC1jb21wb25lbnRzL3NyYy9saWIvY2FyZC1jb250ZW50LWxpbmUtY2hhcnQvY2FyZC1jb250ZW50LWxpbmUtY2hhcnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSx1QkFBdUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsUUFBUSxFQUFFLDZCQUE2QixFQUEyQixNQUFNLHNCQUFzQixDQUFDOzs7O0FBUXhHLE1BQU0sT0FBTyw2QkFDVCxTQUFRLDZCQUFzRDtJQUs5RCxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUM7UUFDbkMsTUFBTSxFQUFFLHlCQUF5QixFQUFFLGVBQWUsRUFBRSxHQUFHLFVBQVUsQ0FBQztRQUNsRSxNQUFNLGdCQUFnQixHQUFRLEVBQUUsQ0FBQztRQUNqQyx5QkFBeUIsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7WUFDL0MsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN6QixJQUFJLE9BQU8sS0FBSyxLQUFLLFFBQVEsSUFBSSxLQUFLLENBQUMsRUFBRSxFQUFFO2dCQUN2QyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO2FBQ25DO2lCQUFNO2dCQUNILGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUNoQztRQUNMLENBQUMsQ0FBQyxDQUFDO1FBQ0gsUUFBUSxDQUFDLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztZQUN6QixVQUFVLEVBQUUsZ0JBQWdCO1lBQzVCLE1BQU0sRUFBRSxlQUFlO1lBQ3ZCLFNBQVMsRUFBRSxDQUFDLFdBQW1CLEVBQUUsRUFBRTtnQkFDL0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO2dCQUMzQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQzlCLENBQUM7WUFDRCxNQUFNLEVBQUUsR0FBRyxFQUFFLEdBQUUsQ0FBQztTQUNuQixDQUFDLENBQUM7SUFDUCxDQUFDOzswSEE1QlEsNkJBQTZCOzhHQUE3Qiw2QkFBNkIsMEZDVDFDLDRJQUdBOzJGRE1hLDZCQUE2QjtrQkFOekMsU0FBUzsrQkFDSSw2QkFBNkIsbUJBR3RCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQmFyc2FBcGksIEJhc2VJdGVtQ29udGVudFByb3BzQ29tcG9uZW50LCBVaVJlcG9ydFZpZXdCYXNlU2V0dGluZyB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdiZGMtY2FyZC1jb250ZW50LWxpbmUtY2hhcnQnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NhcmQtY29udGVudC1saW5lLWNoYXJ0LmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2NhcmQtY29udGVudC1saW5lLWNoYXJ0LmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2FyZENvbnRlbnRMaW5lQ2hhcnRDb21wb25lbnRcclxuICAgIGV4dGVuZHMgQmFzZUl0ZW1Db250ZW50UHJvcHNDb21wb25lbnQ8VWlSZXBvcnRWaWV3QmFzZVNldHRpbmc+XHJcbiAgICBpbXBsZW1lbnRzIE9uSW5pdFxyXG57XHJcbiAgICBjaGFydE9wdGlvbjogYW55O1xyXG5cclxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XHJcbiAgICAgICAgY29uc3QgcGFyYW1ldGVycyA9IHRoaXMucGFyYW1ldGVycztcclxuICAgICAgICBjb25zdCB7IE1ldGhvZFBhcmFtZXRlcnNGaWVsZE5hbWUsIFJ1bkJsTWV0aG9kTmFtZSB9ID0gcGFyYW1ldGVycztcclxuICAgICAgICBjb25zdCBtZXRob2RQYXJhbWV0ZXJzOiBhbnkgPSBbXTtcclxuICAgICAgICBNZXRob2RQYXJhbWV0ZXJzRmllbGROYW1lLnNwbGl0KCcsJykuZm9yRWFjaCgoYykgPT4ge1xyXG4gICAgICAgICAgICBjb25zdCB2YWx1ZSA9IHRoaXMubW9bY107XHJcbiAgICAgICAgICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdvYmplY3QnICYmIHZhbHVlLklkKSB7XHJcbiAgICAgICAgICAgICAgICBtZXRob2RQYXJhbWV0ZXJzLnB1c2godmFsdWUuSWQpO1xyXG4gICAgICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICAgICAgbWV0aG9kUGFyYW1ldGVycy5wdXNoKHZhbHVlKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgICAgIEJhcnNhQXBpLkJ3LlJ1bkJsTWV0aG9kQXN5bmMoe1xyXG4gICAgICAgICAgICBQYXJhbWV0ZXJzOiBtZXRob2RQYXJhbWV0ZXJzLFxyXG4gICAgICAgICAgICBNZXRob2Q6IFJ1bkJsTWV0aG9kTmFtZSxcclxuICAgICAgICAgICAgU3VjY2Vzc0ZuOiAoY2hhcnRPcHRpb246IHN0cmluZykgPT4ge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5jaGFydE9wdGlvbiA9IEpTT04ucGFyc2UoY2hhcnRPcHRpb24pO1xyXG4gICAgICAgICAgICAgICAgdGhpcy5fY2RyLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgRmFpbEZuOiAoKSA9PiB7fVxyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJjYXJkLWNvbnRlbnRcIiAqbmdJZj1cImNoYXJ0T3B0aW9uXCIgI2VsZW1SZWY+XHJcbiAgICA8ZGl2IGJlQ2hhcnRMaW5lVGltZSBbY2hhcnRPcHRpb25dPVwiY2hhcnRPcHRpb25cIj48L2Rpdj5cclxuPC9kaXY+XHJcbiJdfQ==
|