barsa-sap-ui 1.0.321 → 1.0.323
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/barsa-pishnamayesh-payam/barsa-pishnamayesh-payam.component.mjs +129 -11
- package/esm2020/lib/blob-viewer/blob-viewer.component.mjs +11 -3
- package/esm2020/lib/file-viewer-popover/file-viewer-popover.component.mjs +9 -4
- package/esm2020/lib/form-dialog/form-dialog.component.mjs +9 -4
- package/fesm2015/barsa-sap-ui.mjs +144 -14
- package/fesm2015/barsa-sap-ui.mjs.map +1 -1
- package/fesm2020/barsa-sap-ui.mjs +143 -14
- package/fesm2020/barsa-sap-ui.mjs.map +1 -1
- package/lib/barsa-pishnamayesh-payam/barsa-pishnamayesh-payam.component.d.ts +56 -6
- package/lib/blob-viewer/blob-viewer.component.d.ts +3 -2
- package/lib/file-viewer-popover/file-viewer-popover.component.d.ts +3 -1
- package/lib/form-dialog/form-dialog.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,14 +1,21 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
-
import { FieldBaseComponent } from 'barsa-novin-ray-core';
|
|
2
|
+
import { FieldBaseComponent, DateService, getDateService, LogService, BarsaApi } from 'barsa-novin-ray-core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
5
|
import * as i2 from "@fundamental-ngx/core/avatar";
|
|
6
6
|
import * as i3 from "@fundamental-ngx/core/link";
|
|
7
7
|
import * as i4 from "@fundamental-ngx/core/button";
|
|
8
8
|
import * as i5 from "@fundamental-ngx/core/card";
|
|
9
|
-
import * as i6 from "@fundamental-ngx/core/
|
|
10
|
-
import * as i7 from "@fundamental-ngx/core/
|
|
11
|
-
import * as i8 from "@fundamental-ngx/core/
|
|
9
|
+
import * as i6 from "@fundamental-ngx/core/info-label";
|
|
10
|
+
import * as i7 from "@fundamental-ngx/core/list";
|
|
11
|
+
import * as i8 from "@fundamental-ngx/core/title";
|
|
12
|
+
import * as i9 from "@fundamental-ngx/core/message-strip";
|
|
13
|
+
import * as i10 from "@fundamental-ngx/core/object-identifier";
|
|
14
|
+
import * as i11 from "@fundamental-ngx/core/panel";
|
|
15
|
+
import * as i12 from "@fundamental-ngx/core/popover";
|
|
16
|
+
import * as i13 from "../file-viewer-popover/file-viewer-popover.component";
|
|
17
|
+
import * as i14 from "../download-files.directive";
|
|
18
|
+
import * as i15 from "barsa-novin-ray-core";
|
|
12
19
|
export class BarsaPishnamayeshPayamComponent extends FieldBaseComponent {
|
|
13
20
|
constructor() {
|
|
14
21
|
super(...arguments);
|
|
@@ -18,15 +25,126 @@ export class BarsaPishnamayeshPayamComponent extends FieldBaseComponent {
|
|
|
18
25
|
super.ngOnInit();
|
|
19
26
|
const mo = this.context.formControl.Mo;
|
|
20
27
|
const { $FieldDict } = mo;
|
|
21
|
-
this.data = mo[$FieldDict['محتوای پیام']];
|
|
22
|
-
this.data.$ContentHtml = this._domSanitizer.bypassSecurityTrustHtml(this.data.ContentHtml);
|
|
23
|
-
this.data.$SendDate = 'امروز 11:45';
|
|
28
|
+
this.data = new PayamClassType(mo[$FieldDict['محتوای پیام']], this._domSanitizer, this._dateService);
|
|
24
29
|
}
|
|
25
30
|
}
|
|
26
31
|
BarsaPishnamayeshPayamComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaPishnamayeshPayamComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
27
|
-
BarsaPishnamayeshPayamComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaPishnamayeshPayamComponent, selector: "bsu-barsa-pishnamayesh-payam",
|
|
32
|
+
BarsaPishnamayeshPayamComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaPishnamayeshPayamComponent, selector: "bsu-barsa-pishnamayesh-payam", providers: [
|
|
33
|
+
{
|
|
34
|
+
provide: DateService,
|
|
35
|
+
useFactory: getDateService,
|
|
36
|
+
deps: [LogService]
|
|
37
|
+
}
|
|
38
|
+
], usesInheritance: true, ngImport: i0, template: "<ng-container\n *ngTemplateOutlet=\"\n showPayamClass;\n context: {\n $implicit: data,\n primary: !data.$details?.length,\n isFirst: true\n }\n \"\n>\n</ng-container>\n<ng-template #showPayamClass let-data let-primary=\"primary\" let-isFirst=\"isFirst\">\n <ng-container\n *ngTemplateOutlet=\"\n namayeshPayam;\n context: {\n $implicit: data.payam.Subject,\n fromText: data.payam.FromText,\n toText: data.$toText,\n importance: data.$importance,\n readDate: data.$readDate,\n sendDate: data.$sendDate,\n ccText: data.$ccText,\n bccText: data.$bccText,\n accessLevel: data.$accessLevel,\n content: data.$content,\n fromPhoto: data.$fromPhoto,\n details: data.$details,\n attachments: data.$attachments,\n todo: data.$todo,\n customText: data.payam.CustomText,\n primary: primary,\n isFirst: isFirst\n }\n \"\n >\n </ng-container>\n</ng-template>\n\n<ng-template\n #namayeshPayam\n let-subject\n let-content=\"content\"\n let-fromText=\"fromText\"\n let-toText=\"toText\"\n let-importance=\"importance\"\n let-readDate=\"readDate\"\n let-sendDate=\"sendDate\"\n let-ccText=\"ccText\"\n let-bccText=\"bccText\"\n let-fromPhoto=\"fromPhoto\"\n let-details=\"details\"\n let-accessLevel=\"accessLevel\"\n let-primary=\"primary\"\n let-isFirst=\"isFirst\"\n let-attachments=\"attachments\"\n let-todo=\"todo\"\n let-customText=\"customText\"\n>\n <fd-card cardType=\"object\">\n <fd-card-header>\n <fd-avatar\n [image]=\"fromPhoto\"\n [circle]=\"true\"\n size=\"s\"\n [ariaLabel]=\"fromText\"\n [label]=\"fromText\"\n [title]=\"fromText\"\n ></fd-avatar>\n <div fd-card-title class=\"header-fields\">\n <h5 fd-title>\n <a fd-link [emphasized]=\"true\" aria-label=\"Sender\"> {{ fromText }}</a>\n </h5>\n <fd-object-identifier [description]=\"'(' + sendDate + ')'\"> </fd-object-identifier>\n </div>\n <div fd-card-subtitle>\n <h5 fd-title>{{ subject }}</h5>\n <fd-popover>\n <fd-popover-control>\n <button fd-button fdType=\"transparent\" [fdMenu]=\"true\">{{ 'Recievers' | bbbTranslate }}</button>\n </fd-popover-control>\n <fd-popover-body>\n <ul fd-list>\n <li fd-list-item *ngFor=\"let rec of toText\">\n <a fd-list-link>{{ rec }}</a>\n </li>\n </ul>\n </fd-popover-body>\n </fd-popover>\n </div>\n </fd-card-header>\n <fd-card-content>\n <fd-panel [expanded]=\"isFirst\">\n <div fd-panel-title id=\"panel-expandable-title-1\">\n <h5 fd-title>{{ '\u0645\u062D\u062A\u0648\u0627\u06CC \u067E\u06CC\u0627\u0645' | bbbTranslate }}</h5>\n <div class=\"payamIcons\">\n <fd-popover *ngIf=\"importance.icon\">\n <fd-popover-control>\n <img [src]=\"'/Customization/Mail/' + importance.icon\" />\n </fd-popover-control>\n <fd-popover-body>\n <ul fd-list>\n <li fd-list-item>{{ importance.text }}</li>\n </ul>\n </fd-popover-body>\n </fd-popover>\n <fd-popover *ngIf=\"accessLevel.icon\">\n <fd-popover-control>\n <img [src]=\"'/Customization/Mail/' + accessLevel.icon\" />\n </fd-popover-control>\n <fd-popover-body>\n <ul fd-list>\n <li fd-list-item>{{ accessLevel.text }}</li>\n </ul>\n </fd-popover-body>\n </fd-popover>\n <fd-info-label\n *ngIf=\"todo\"\n [label]=\"todo.text\"\n [color]=\"todo.color\"\n [title]=\"todo.text\"\n ></fd-info-label>\n </div>\n </div>\n <div fd-panel-content>\n <div *ngIf=\"customText\">\n <fd-message-strip type=\"information\" [noIcon]=\"true\" [dismissible]=\"false\">\n {{ customText }}\n </fd-message-strip>\n </div>\n <div [innerHtml]=\"content\" [disable]=\"!primary || attachments?.length\"></div>\n\n <div *ngIf=\"attachments?.length\" class=\"attachments\">\n <ng-container *ngFor=\"let file of attachments\">\n <bsu-file-viewer-popover\n *ngIf=\"!file.IsDeleted\"\n [file]=\"file\"\n [files]=\"attachments\"\n [deviceSize]=\"(deviceSize$ | async)!!\"\n [canDownload]=\"true\"\n [disableRemove]=\"true\"\n ></bsu-file-viewer-popover>\n </ng-container>\n <ng-container *ngIf=\"attachments.length > 1\">\n <button\n fd-button\n [title]=\"'Download' | bbbTranslate\"\n [glyph]=\"'download'\"\n downloadFiles\n [files]=\"attachments\"\n ></button>\n </ng-container>\n </div>\n <div class=\"readAt\">\n <fd-object-identifier\n *ngIf=\"readDate\"\n [description]=\"('ReadAt' | bbbTranslate) + ': (' + readDate + ')'\"\n >\n </fd-object-identifier>\n </div>\n </div>\n </fd-panel>\n </fd-card-content>\n <!-- <fd-card-footer>\n <button *fdCardFooterActionItem fd-button fdCompact>Assign to Project</button>\n </fd-card-footer> -->\n </fd-card>\n <ng-contianer *ngFor=\"let detail of details\">\n <ng-container\n *ngTemplateOutlet=\"\n showPayamClass;\n context: {\n $implicit: detail\n }\n \"\n >\n </ng-container>\n </ng-contianer>\n</ng-template>\n", styles: [":host{display:block;position:relative;width:100%;height:100%}:host ::ng-deep .fd-panel__content{border-bottom:none;padding-bottom:5px}:host ::ng-deep .fd-card__subtitle{display:flex;align-items:center;column-gap:5px;justify-content:start}:host ::ng-deep .fd-object-identifier__text{margin-top:0}:host ::ng-deep .fd-panel__header{border-bottom:none}fd-card-header{cursor:default;border-bottom:none!important}fd-card-header:before{position:relative!important;display:none!important}fd-card-header:hover{background:var(--fdCard_Background_Color)!important}.attachments{display:flex;flex-wrap:wrap;column-gap:5px;row-gap:5px}.readAt{padding-top:2rem}.readAt ::ng-deep p{color:var(--sapButton_BorderColor)!important}.payamIcons{display:flex;column-gap:5px}.payamIcons img{width:16px}@media (max-width: 410px){h5{max-width:210px}}@media (max-width: 1040px){.h5{max-width:600px}}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.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: i3.LinkComponent, selector: "[fdLink], [fd-link], [fd-breadcrumb-link]", inputs: ["class", "emphasized", "disabled", "inverted", "subtle", "undecorated"] }, { kind: "component", type: i4.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i5.CardComponent, selector: "fd-card", inputs: ["badge", "isLoading", "cardType", "id", "role"] }, { kind: "component", type: i5.CardHeaderComponent, selector: "fd-card-header", inputs: ["interactive", "tabindex"] }, { kind: "component", type: i5.CardContentComponent, selector: "fd-card-content" }, { kind: "directive", type: i5.CardTitleDirective, selector: "[fd-card-title]" }, { kind: "directive", type: i5.CardSubtitleDirective, selector: "[fd-card-subtitle]" }, { kind: "component", type: i6.InfoLabelComponent, selector: "fd-info-label", inputs: ["class", "type", "glyph", "font", "color", "label", "title", "ariaLabel", "ariaLabelledBy"] }, { kind: "component", type: i7.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline"], outputs: ["focusEscapeList"] }, { kind: "component", type: i7.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i7.ListLinkDirective, selector: "[fd-list-link], [fdListLink]", inputs: ["navigationIndicator", "navigated"] }, { kind: "component", type: i8.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: "component", type: i9.MessageStripComponent, selector: "fd-message-strip", inputs: ["class", "dismissible", "noIcon", "type", "id", "ariaLabelledBy", "ariaLabel", "dismissLabel", "width", "minWidth", "marginBottom"], outputs: ["onDismiss"] }, { kind: "component", type: i10.ObjectIdentifierComponent, selector: "fd-object-identifier", inputs: ["description", "bold", "medium"] }, { kind: "component", type: i11.PanelComponent, selector: "fd-panel", inputs: ["class", "fixed", "id", "expandId", "expandAriaLabel", "expandAriaLabelledBy", "expanded"], outputs: ["expandedChange"] }, { kind: "directive", type: i11.PanelContentDirective, selector: "[fd-panel-content]", inputs: ["height", "minHeight", "maxHeight", "ariaLabel", "ariaLabelledBy", "role", "id"] }, { kind: "directive", type: i11.PanelTitleDirective, selector: "[fd-panel-title]", inputs: ["id"] }, { kind: "component", type: i12.PopoverControlComponent, selector: "fd-popover-control" }, { kind: "component", type: i12.PopoverBodyComponent, selector: "fd-popover-body" }, { kind: "component", type: i12.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig"] }, { kind: "component", type: i13.FileViewerPopoverComponent, selector: "bsu-file-viewer-popover", inputs: ["files", "file", "deviceSize", "canDownload", "disableRemove"], outputs: ["remove"] }, { kind: "directive", type: i14.DownloadFilesDirective, selector: "[downloadFiles]", inputs: ["files"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i15.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
28
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaPishnamayeshPayamComponent, decorators: [{
|
|
29
40
|
type: Component,
|
|
30
|
-
args: [{ selector: 'bsu-barsa-pishnamayesh-payam', changeDetection: ChangeDetectionStrategy.OnPush,
|
|
41
|
+
args: [{ selector: 'bsu-barsa-pishnamayesh-payam', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
42
|
+
{
|
|
43
|
+
provide: DateService,
|
|
44
|
+
useFactory: getDateService,
|
|
45
|
+
deps: [LogService]
|
|
46
|
+
}
|
|
47
|
+
], template: "<ng-container\n *ngTemplateOutlet=\"\n showPayamClass;\n context: {\n $implicit: data,\n primary: !data.$details?.length,\n isFirst: true\n }\n \"\n>\n</ng-container>\n<ng-template #showPayamClass let-data let-primary=\"primary\" let-isFirst=\"isFirst\">\n <ng-container\n *ngTemplateOutlet=\"\n namayeshPayam;\n context: {\n $implicit: data.payam.Subject,\n fromText: data.payam.FromText,\n toText: data.$toText,\n importance: data.$importance,\n readDate: data.$readDate,\n sendDate: data.$sendDate,\n ccText: data.$ccText,\n bccText: data.$bccText,\n accessLevel: data.$accessLevel,\n content: data.$content,\n fromPhoto: data.$fromPhoto,\n details: data.$details,\n attachments: data.$attachments,\n todo: data.$todo,\n customText: data.payam.CustomText,\n primary: primary,\n isFirst: isFirst\n }\n \"\n >\n </ng-container>\n</ng-template>\n\n<ng-template\n #namayeshPayam\n let-subject\n let-content=\"content\"\n let-fromText=\"fromText\"\n let-toText=\"toText\"\n let-importance=\"importance\"\n let-readDate=\"readDate\"\n let-sendDate=\"sendDate\"\n let-ccText=\"ccText\"\n let-bccText=\"bccText\"\n let-fromPhoto=\"fromPhoto\"\n let-details=\"details\"\n let-accessLevel=\"accessLevel\"\n let-primary=\"primary\"\n let-isFirst=\"isFirst\"\n let-attachments=\"attachments\"\n let-todo=\"todo\"\n let-customText=\"customText\"\n>\n <fd-card cardType=\"object\">\n <fd-card-header>\n <fd-avatar\n [image]=\"fromPhoto\"\n [circle]=\"true\"\n size=\"s\"\n [ariaLabel]=\"fromText\"\n [label]=\"fromText\"\n [title]=\"fromText\"\n ></fd-avatar>\n <div fd-card-title class=\"header-fields\">\n <h5 fd-title>\n <a fd-link [emphasized]=\"true\" aria-label=\"Sender\"> {{ fromText }}</a>\n </h5>\n <fd-object-identifier [description]=\"'(' + sendDate + ')'\"> </fd-object-identifier>\n </div>\n <div fd-card-subtitle>\n <h5 fd-title>{{ subject }}</h5>\n <fd-popover>\n <fd-popover-control>\n <button fd-button fdType=\"transparent\" [fdMenu]=\"true\">{{ 'Recievers' | bbbTranslate }}</button>\n </fd-popover-control>\n <fd-popover-body>\n <ul fd-list>\n <li fd-list-item *ngFor=\"let rec of toText\">\n <a fd-list-link>{{ rec }}</a>\n </li>\n </ul>\n </fd-popover-body>\n </fd-popover>\n </div>\n </fd-card-header>\n <fd-card-content>\n <fd-panel [expanded]=\"isFirst\">\n <div fd-panel-title id=\"panel-expandable-title-1\">\n <h5 fd-title>{{ '\u0645\u062D\u062A\u0648\u0627\u06CC \u067E\u06CC\u0627\u0645' | bbbTranslate }}</h5>\n <div class=\"payamIcons\">\n <fd-popover *ngIf=\"importance.icon\">\n <fd-popover-control>\n <img [src]=\"'/Customization/Mail/' + importance.icon\" />\n </fd-popover-control>\n <fd-popover-body>\n <ul fd-list>\n <li fd-list-item>{{ importance.text }}</li>\n </ul>\n </fd-popover-body>\n </fd-popover>\n <fd-popover *ngIf=\"accessLevel.icon\">\n <fd-popover-control>\n <img [src]=\"'/Customization/Mail/' + accessLevel.icon\" />\n </fd-popover-control>\n <fd-popover-body>\n <ul fd-list>\n <li fd-list-item>{{ accessLevel.text }}</li>\n </ul>\n </fd-popover-body>\n </fd-popover>\n <fd-info-label\n *ngIf=\"todo\"\n [label]=\"todo.text\"\n [color]=\"todo.color\"\n [title]=\"todo.text\"\n ></fd-info-label>\n </div>\n </div>\n <div fd-panel-content>\n <div *ngIf=\"customText\">\n <fd-message-strip type=\"information\" [noIcon]=\"true\" [dismissible]=\"false\">\n {{ customText }}\n </fd-message-strip>\n </div>\n <div [innerHtml]=\"content\" [disable]=\"!primary || attachments?.length\"></div>\n\n <div *ngIf=\"attachments?.length\" class=\"attachments\">\n <ng-container *ngFor=\"let file of attachments\">\n <bsu-file-viewer-popover\n *ngIf=\"!file.IsDeleted\"\n [file]=\"file\"\n [files]=\"attachments\"\n [deviceSize]=\"(deviceSize$ | async)!!\"\n [canDownload]=\"true\"\n [disableRemove]=\"true\"\n ></bsu-file-viewer-popover>\n </ng-container>\n <ng-container *ngIf=\"attachments.length > 1\">\n <button\n fd-button\n [title]=\"'Download' | bbbTranslate\"\n [glyph]=\"'download'\"\n downloadFiles\n [files]=\"attachments\"\n ></button>\n </ng-container>\n </div>\n <div class=\"readAt\">\n <fd-object-identifier\n *ngIf=\"readDate\"\n [description]=\"('ReadAt' | bbbTranslate) + ': (' + readDate + ')'\"\n >\n </fd-object-identifier>\n </div>\n </div>\n </fd-panel>\n </fd-card-content>\n <!-- <fd-card-footer>\n <button *fdCardFooterActionItem fd-button fdCompact>Assign to Project</button>\n </fd-card-footer> -->\n </fd-card>\n <ng-contianer *ngFor=\"let detail of details\">\n <ng-container\n *ngTemplateOutlet=\"\n showPayamClass;\n context: {\n $implicit: detail\n }\n \"\n >\n </ng-container>\n </ng-contianer>\n</ng-template>\n", styles: [":host{display:block;position:relative;width:100%;height:100%}:host ::ng-deep .fd-panel__content{border-bottom:none;padding-bottom:5px}:host ::ng-deep .fd-card__subtitle{display:flex;align-items:center;column-gap:5px;justify-content:start}:host ::ng-deep .fd-object-identifier__text{margin-top:0}:host ::ng-deep .fd-panel__header{border-bottom:none}fd-card-header{cursor:default;border-bottom:none!important}fd-card-header:before{position:relative!important;display:none!important}fd-card-header:hover{background:var(--fdCard_Background_Color)!important}.attachments{display:flex;flex-wrap:wrap;column-gap:5px;row-gap:5px}.readAt{padding-top:2rem}.readAt ::ng-deep p{color:var(--sapButton_BorderColor)!important}.payamIcons{display:flex;column-gap:5px}.payamIcons img{width:16px}@media (max-width: 410px){h5{max-width:210px}}@media (max-width: 1040px){.h5{max-width:600px}}\n"] }]
|
|
31
48
|
}] });
|
|
32
|
-
|
|
49
|
+
class PayamClassType {
|
|
50
|
+
constructor(payam, _domSanitizer, _dateService) {
|
|
51
|
+
this.payam = payam;
|
|
52
|
+
this._domSanitizer = _domSanitizer;
|
|
53
|
+
this._dateService = _dateService;
|
|
54
|
+
this.$content = this._domSanitizer.bypassSecurityTrustHtml(payam.ContentHtml);
|
|
55
|
+
this.$sendDate = this._getDateString(payam.SendDate);
|
|
56
|
+
this.$readDate = !payam.ReadDate ? '' : this._getDateString(payam.ReadDate);
|
|
57
|
+
this.$toText = payam.ToText.split(';');
|
|
58
|
+
this.$ccText = payam.CcText?.split(';');
|
|
59
|
+
this.$bccText = payam.BccText?.split(';');
|
|
60
|
+
this.$fromPhoto = BarsaApi.Common.Util.GetIconUrl(payam.FromPhoto, null, null, 64);
|
|
61
|
+
this.$details = payam.Details?.map((c) => new PayamClassType(c, _domSanitizer, _dateService));
|
|
62
|
+
this.$attachments = payam.Attachments?.map((c) => ({
|
|
63
|
+
Id: c.Id,
|
|
64
|
+
IsNew: false,
|
|
65
|
+
IsDeleted: false,
|
|
66
|
+
Type: c.Extension,
|
|
67
|
+
FileName: `${c.Name}.${c.Extension}`
|
|
68
|
+
}));
|
|
69
|
+
this.$importance = {
|
|
70
|
+
icon: this._iconImportance(payam.Importance),
|
|
71
|
+
text: this._textImportance(payam.Importance)
|
|
72
|
+
};
|
|
73
|
+
this.$accessLevel = {
|
|
74
|
+
icon: this._iconAccessLevel(payam.AccessLevel),
|
|
75
|
+
text: this._textAccessLevel(payam.AccessLevel)
|
|
76
|
+
};
|
|
77
|
+
if (payam.Todo?.DueDate) {
|
|
78
|
+
this.$todo = this._textTodo(payam.Todo);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
_textTodo(todo) {
|
|
82
|
+
if (!todo || !todo.DueDate) {
|
|
83
|
+
return { text: '', color: '10' };
|
|
84
|
+
}
|
|
85
|
+
let dueDateStr = '';
|
|
86
|
+
let doneDateStr = '';
|
|
87
|
+
if (BarsaApi.Ext.isString(todo.DueDate)) {
|
|
88
|
+
dueDateStr = this._getDateString(todo.DueDate);
|
|
89
|
+
}
|
|
90
|
+
if (todo.DoneDate) {
|
|
91
|
+
doneDateStr = this._getDateString(todo.DoneDate);
|
|
92
|
+
}
|
|
93
|
+
// eslint-disable-next-line no-eval
|
|
94
|
+
const dueDate = eval(todo.DueDate);
|
|
95
|
+
if (todo.State === 2) {
|
|
96
|
+
return { text: BarsaApi.BBB.Mail_TodoCompleted + ': ' + doneDateStr, color: '8' };
|
|
97
|
+
}
|
|
98
|
+
else if (new Date().getTime() < dueDate.getTime()) {
|
|
99
|
+
return { text: BarsaApi.BBB.Mail_TodoDueDate + ': ' + dueDateStr, color: '1' };
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
return {
|
|
103
|
+
text: BarsaApi.BBB.Mail_TodoOverdue + ': ' + (doneDateStr ? doneDateStr : dueDateStr),
|
|
104
|
+
color: '2'
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
_textImportance(i) {
|
|
109
|
+
if (i) {
|
|
110
|
+
return BarsaApi.BBB['Mail_Importance' + i];
|
|
111
|
+
}
|
|
112
|
+
return null;
|
|
113
|
+
}
|
|
114
|
+
_textAccessLevel(i) {
|
|
115
|
+
if (i) {
|
|
116
|
+
return BarsaApi.BBB['Mail_Sensitivity' + i];
|
|
117
|
+
}
|
|
118
|
+
return null;
|
|
119
|
+
}
|
|
120
|
+
_iconImportance(i) {
|
|
121
|
+
if (i) {
|
|
122
|
+
return 'priority_' + i.toString() + '.png';
|
|
123
|
+
}
|
|
124
|
+
return null;
|
|
125
|
+
}
|
|
126
|
+
_iconAccessLevel(i) {
|
|
127
|
+
if (i) {
|
|
128
|
+
return 'lock_' + i.toString() + '.png';
|
|
129
|
+
}
|
|
130
|
+
return null;
|
|
131
|
+
}
|
|
132
|
+
_getSize(size) {
|
|
133
|
+
size = size.replace('KB', 'کیلوبایت');
|
|
134
|
+
size = size.replace('MB', 'مگابایت');
|
|
135
|
+
size = size.replace('B', 'بایت');
|
|
136
|
+
return size;
|
|
137
|
+
}
|
|
138
|
+
_getAttachmentIcon(extension) {
|
|
139
|
+
if (BarsaApi.Ext.isEmpty(extension) === false) {
|
|
140
|
+
return '/assets/Images/FileTypeIcons/' + '_' + extension + '.PNG';
|
|
141
|
+
}
|
|
142
|
+
return null;
|
|
143
|
+
}
|
|
144
|
+
_getDateString(date) {
|
|
145
|
+
// eslint-disable-next-line no-eval
|
|
146
|
+
const dateInfo = this._dateService.getDateInfo(eval(date));
|
|
147
|
+
return `${dateInfo.dayName} ${dateInfo.monthName} ${dateInfo.year} ${dateInfo.hour}:${dateInfo.minutes}`;
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-pishnamayesh-payam.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-pishnamayesh-payam/barsa-pishnamayesh-payam.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-pishnamayesh-payam/barsa-pishnamayesh-payam.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\n\nimport {\n    FieldBaseComponent,\n    DateService,\n    getDateService,\n    LogService,\n    DateInfo,\n    BarsaApi,\n    FileAttachmentInfo\n} from 'barsa-novin-ray-core';\n@Component({\n    selector: 'bsu-barsa-pishnamayesh-payam',\n    templateUrl: './barsa-pishnamayesh-payam.component.html',\n    styleUrls: ['./barsa-pishnamayesh-payam.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: DateService,\n            useFactory: getDateService,\n            deps: [LogService]\n        }\n    ]\n})\nexport class BarsaPishnamayeshPayamComponent extends FieldBaseComponent implements OnInit {\n    data: PayamClassType;\n    expanded = true;\n    ngOnInit(): void {\n        super.ngOnInit();\n        const mo = this.context.formControl.Mo;\n        const { $FieldDict } = mo;\n        this.data = new PayamClassType(mo[$FieldDict['محتوای پیام']], this._domSanitizer, this._dateService);\n    }\n}\n\ntype PayamType = {\n    AccessLevel: number;\n    Attachments?: PayamAttachment[]; // null\n    BccText: string;\n    Subject: string;\n    CategoryString: string;\n    CcText: string;\n    ContentHtml: string;\n    CustomText: string;\n    FromText: string;\n    FromPhoto: string;\n    Order: number; // 1\n    Importance: number;\n    ReadDate: string; // \"new Date(2023,6,20,11,21,19)\"\n    SendDate: string; // \"new Date(2023,6,20,11,20,55)\"\n    ToText: string;\n    Todo: PayamTodo; // null\n    Details?: PayamType[];\n};\nclass PayamClassType {\n    $content?: SafeHtml;\n    $sendDate?: string;\n    $readDate?: string;\n    $fromPhoto?: string;\n    $toText?: string[];\n    $ccText?: string[];\n    $bccText?: string[];\n    $details?: PayamClassType[];\n    $attachments?: FileAttachmentInfo[];\n    $importance: { icon: string | null; text: string | null };\n    $accessLevel: { icon: string | null; text: string | null };\n    $todo: { text: string; color: string };\n\n    constructor(public payam: PayamType, private _domSanitizer: DomSanitizer, private _dateService: DateService) {\n        this.$content = this._domSanitizer.bypassSecurityTrustHtml(payam.ContentHtml);\n        this.$sendDate = this._getDateString(payam.SendDate);\n        this.$readDate = !payam.ReadDate ? '' : this._getDateString(payam.ReadDate);\n\n        this.$toText = payam.ToText.split(';');\n        this.$ccText = payam.CcText?.split(';');\n        this.$bccText = payam.BccText?.split(';');\n        this.$fromPhoto = BarsaApi.Common.Util.GetIconUrl(payam.FromPhoto, null, null, 64);\n        this.$details = payam.Details?.map((c) => new PayamClassType(c, _domSanitizer, _dateService));\n        this.$attachments = payam.Attachments?.map((c) => ({\n            Id: c.Id,\n            IsNew: false,\n            IsDeleted: false,\n            Type: c.Extension,\n            FileName: `${c.Name}.${c.Extension}`\n        }));\n        this.$importance = {\n            icon: this._iconImportance(payam.Importance),\n            text: this._textImportance(payam.Importance)\n        };\n        this.$accessLevel = {\n            icon: this._iconAccessLevel(payam.AccessLevel),\n            text: this._textAccessLevel(payam.AccessLevel)\n        };\n\n        if (payam.Todo?.DueDate) {\n            this.$todo = this._textTodo(payam.Todo);\n        }\n    }\n    private _textTodo(todo: PayamTodo): { text: string; color: string } {\n        if (!todo || !todo.DueDate) {\n            return { text: '', color: '10' };\n        }\n        let dueDateStr = '';\n        let doneDateStr = '';\n        if (BarsaApi.Ext.isString(todo.DueDate)) {\n            dueDateStr = this._getDateString(todo.DueDate);\n        }\n        if (todo.DoneDate) {\n            doneDateStr = this._getDateString(todo.DoneDate);\n        }\n        // eslint-disable-next-line no-eval\n        const dueDate = eval(todo.DueDate);\n        if (todo.State === 2) {\n            return { text: BarsaApi.BBB.Mail_TodoCompleted + ': ' + doneDateStr, color: '8' };\n        } else if (new Date().getTime() < dueDate.getTime()) {\n            return { text: BarsaApi.BBB.Mail_TodoDueDate + ': ' + dueDateStr, color: '1' };\n        } else {\n            return {\n                text: BarsaApi.BBB.Mail_TodoOverdue + ': ' + (doneDateStr ? doneDateStr : dueDateStr),\n                color: '2'\n            };\n        }\n    }\n    private _textImportance(i): string | null {\n        if (i) {\n            return BarsaApi.BBB['Mail_Importance' + i];\n        }\n        return null;\n    }\n    private _textAccessLevel(i): string | null {\n        if (i) {\n            return BarsaApi.BBB['Mail_Sensitivity' + i];\n        }\n        return null;\n    }\n    private _iconImportance(i): string | null {\n        if (i) {\n            return 'priority_' + i.toString() + '.png';\n        }\n        return null;\n    }\n    private _iconAccessLevel(i): string | null {\n        if (i) {\n            return 'lock_' + i.toString() + '.png';\n        }\n        return null;\n    }\n    private _getSize(size: string): string {\n        size = size.replace('KB', 'کیلوبایت');\n        size = size.replace('MB', 'مگابایت');\n        size = size.replace('B', 'بایت');\n        return size;\n    }\n    private _getAttachmentIcon(extension): string | null {\n        if (BarsaApi.Ext.isEmpty(extension) === false) {\n            return '/assets/Images/FileTypeIcons/' + '_' + extension + '.PNG';\n        }\n        return null;\n    }\n    private _getDateString(date: string): string {\n        // eslint-disable-next-line no-eval\n        const dateInfo: DateInfo = this._dateService.getDateInfo(eval(date));\n        return `${dateInfo.dayName} ${dateInfo.monthName} ${dateInfo.year} ${dateInfo.hour}:${dateInfo.minutes}`;\n    }\n}\n\ntype PayamAttachment = {\n    Attachtype: string; // \"attachContent\"\n    Extension: string; // \"docx\"\n    Id: string; // \"_OQ2X_SN0og2Y4S-X_ACxBtJMf5oig1\"\n    Name: string; // \"Document 10\"\n    Size: string; // \"14.9 KB\"\n};\ntype PayamTodo = { DueDate: string; State: number; DoneDate?: string };\n","<ng-container\n    *ngTemplateOutlet=\"\n        showPayamClass;\n        context: {\n            $implicit: data,\n            primary: !data.$details?.length,\n            isFirst: true\n        }\n    \"\n>\n</ng-container>\n<ng-template #showPayamClass let-data let-primary=\"primary\" let-isFirst=\"isFirst\">\n    <ng-container\n        *ngTemplateOutlet=\"\n            namayeshPayam;\n            context: {\n                $implicit: data.payam.Subject,\n                fromText: data.payam.FromText,\n                toText: data.$toText,\n                importance: data.$importance,\n                readDate: data.$readDate,\n                sendDate: data.$sendDate,\n                ccText: data.$ccText,\n                bccText: data.$bccText,\n                accessLevel: data.$accessLevel,\n                content: data.$content,\n                fromPhoto: data.$fromPhoto,\n                details: data.$details,\n                attachments: data.$attachments,\n                todo: data.$todo,\n                customText: data.payam.CustomText,\n                primary: primary,\n                isFirst: isFirst\n            }\n        \"\n    >\n    </ng-container>\n</ng-template>\n\n<ng-template\n    #namayeshPayam\n    let-subject\n    let-content=\"content\"\n    let-fromText=\"fromText\"\n    let-toText=\"toText\"\n    let-importance=\"importance\"\n    let-readDate=\"readDate\"\n    let-sendDate=\"sendDate\"\n    let-ccText=\"ccText\"\n    let-bccText=\"bccText\"\n    let-fromPhoto=\"fromPhoto\"\n    let-details=\"details\"\n    let-accessLevel=\"accessLevel\"\n    let-primary=\"primary\"\n    let-isFirst=\"isFirst\"\n    let-attachments=\"attachments\"\n    let-todo=\"todo\"\n    let-customText=\"customText\"\n>\n    <fd-card cardType=\"object\">\n        <fd-card-header>\n            <fd-avatar\n                [image]=\"fromPhoto\"\n                [circle]=\"true\"\n                size=\"s\"\n                [ariaLabel]=\"fromText\"\n                [label]=\"fromText\"\n                [title]=\"fromText\"\n            ></fd-avatar>\n            <div fd-card-title class=\"header-fields\">\n                <h5 fd-title>\n                    <a fd-link [emphasized]=\"true\" aria-label=\"Sender\"> {{ fromText }}</a>\n                </h5>\n                <fd-object-identifier [description]=\"'(' + sendDate + ')'\"> </fd-object-identifier>\n            </div>\n            <div fd-card-subtitle>\n                <h5 fd-title>{{ subject }}</h5>\n                <fd-popover>\n                    <fd-popover-control>\n                        <button fd-button fdType=\"transparent\" [fdMenu]=\"true\">{{ 'Recievers' | bbbTranslate }}</button>\n                    </fd-popover-control>\n                    <fd-popover-body>\n                        <ul fd-list>\n                            <li fd-list-item *ngFor=\"let rec of toText\">\n                                <a fd-list-link>{{ rec }}</a>\n                            </li>\n                        </ul>\n                    </fd-popover-body>\n                </fd-popover>\n            </div>\n        </fd-card-header>\n        <fd-card-content>\n            <fd-panel [expanded]=\"isFirst\">\n                <div fd-panel-title id=\"panel-expandable-title-1\">\n                    <h5 fd-title>{{ 'محتوای پیام' | bbbTranslate }}</h5>\n                    <div class=\"payamIcons\">\n                        <fd-popover *ngIf=\"importance.icon\">\n                            <fd-popover-control>\n                                <img [src]=\"'/Customization/Mail/' + importance.icon\" />\n                            </fd-popover-control>\n                            <fd-popover-body>\n                                <ul fd-list>\n                                    <li fd-list-item>{{ importance.text }}</li>\n                                </ul>\n                            </fd-popover-body>\n                        </fd-popover>\n                        <fd-popover *ngIf=\"accessLevel.icon\">\n                            <fd-popover-control>\n                                <img [src]=\"'/Customization/Mail/' + accessLevel.icon\" />\n                            </fd-popover-control>\n                            <fd-popover-body>\n                                <ul fd-list>\n                                    <li fd-list-item>{{ accessLevel.text }}</li>\n                                </ul>\n                            </fd-popover-body>\n                        </fd-popover>\n                        <fd-info-label\n                            *ngIf=\"todo\"\n                            [label]=\"todo.text\"\n                            [color]=\"todo.color\"\n                            [title]=\"todo.text\"\n                        ></fd-info-label>\n                    </div>\n                </div>\n                <div fd-panel-content>\n                    <div *ngIf=\"customText\">\n                        <fd-message-strip type=\"information\" [noIcon]=\"true\" [dismissible]=\"false\">\n                            {{ customText }}\n                        </fd-message-strip>\n                    </div>\n                    <div [innerHtml]=\"content\" [disable]=\"!primary || attachments?.length\"></div>\n\n                    <div *ngIf=\"attachments?.length\" class=\"attachments\">\n                        <ng-container *ngFor=\"let file of attachments\">\n                            <bsu-file-viewer-popover\n                                *ngIf=\"!file.IsDeleted\"\n                                [file]=\"file\"\n                                [files]=\"attachments\"\n                                [deviceSize]=\"(deviceSize$ | async)!!\"\n                                [canDownload]=\"true\"\n                                [disableRemove]=\"true\"\n                            ></bsu-file-viewer-popover>\n                        </ng-container>\n                        <ng-container *ngIf=\"attachments.length > 1\">\n                            <button\n                                fd-button\n                                [title]=\"'Download' | bbbTranslate\"\n                                [glyph]=\"'download'\"\n                                downloadFiles\n                                [files]=\"attachments\"\n                            ></button>\n                        </ng-container>\n                    </div>\n                    <div class=\"readAt\">\n                        <fd-object-identifier\n                            *ngIf=\"readDate\"\n                            [description]=\"('ReadAt' | bbbTranslate) + ': (' + readDate + ')'\"\n                        >\n                        </fd-object-identifier>\n                    </div>\n                </div>\n            </fd-panel>\n        </fd-card-content>\n        <!-- <fd-card-footer>\n            <button *fdCardFooterActionItem fd-button fdCompact>Assign to Project</button>\n        </fd-card-footer> -->\n    </fd-card>\n    <ng-contianer *ngFor=\"let detail of details\">\n        <ng-container\n            *ngTemplateOutlet=\"\n                showPayamClass;\n                context: {\n                    $implicit: detail\n                }\n            \"\n        >\n        </ng-container>\n    </ng-contianer>\n</ng-template>\n"]}
|
|
@@ -16,6 +16,14 @@ export class BlobViewerComponent extends BaseComponent {
|
|
|
16
16
|
this.fallbackUrl = this.getFallbackUrl(this.file.Id);
|
|
17
17
|
this._downloadFileId(this.file.Id, true, 'pdf', false, false);
|
|
18
18
|
}
|
|
19
|
+
ngOnChanges(changes) {
|
|
20
|
+
super.ngOnChanges(changes);
|
|
21
|
+
const { file } = changes;
|
|
22
|
+
if (file && !file.firstChange) {
|
|
23
|
+
this.fallbackUrl = this.getFallbackUrl(this.file.Id);
|
|
24
|
+
this._downloadFileId(this.file.Id, true, 'pdf', false, false);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
19
27
|
_downloadFileId(fileId, viewInBrowser, convertTo, forOcx, isOfficeOnline) {
|
|
20
28
|
this._setLoading(true);
|
|
21
29
|
BarsaApi.Common.File.DownloadFileContent.bind(this)({
|
|
@@ -36,7 +44,7 @@ export class BlobViewerComponent extends BaseComponent {
|
|
|
36
44
|
});
|
|
37
45
|
}
|
|
38
46
|
getFallbackUrl(fileId) {
|
|
39
|
-
return `امکان نمایش فایل در این مرورگر وجود ندارد.
|
|
47
|
+
return `امکان نمایش فایل در این مرورگر وجود ندارد.
|
|
40
48
|
برای باز کردن فایل از لینک زیر استفاده کنید: </br> <a href='${BarsaApi.Common.File.CreateAttachmentUrl(fileId, false, true)}'>دانلود فایل بصورت pdf</a> </br> <a href='${BarsaApi.Common.File.CreateAttachmentUrl(fileId, false, false)}'>دانلود فایل بصورت بصورت اصلی</a>`;
|
|
41
49
|
}
|
|
42
50
|
_setLoading(loading) {
|
|
@@ -50,11 +58,11 @@ export class BlobViewerComponent extends BaseComponent {
|
|
|
50
58
|
}
|
|
51
59
|
}
|
|
52
60
|
BlobViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BlobViewerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
|
|
53
|
-
BlobViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BlobViewerComponent, selector: "bsu-blob-viewer", inputs: { file: "file" }, usesInheritance: true, ngImport: i0, template: "<bsu-mask *ngIf=\"loading\"></bsu-mask>\r\n<object\r\n *ngIf=\"valueUrl\"\r\n style=\"flex-grow: 1\"\r\n [attr.data]=\"valueUrl\"\r\n type=\"application/pdf\"\r\n width=\"100%\"\r\n height=\"100%\"\r\n [attr.html]=\"fallbackUrl\"\r\n></object>\r\n", styles: [":host{display:block;position:relative;height:100%;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MaskComponent, selector: "bsu-mask", inputs: ["size", "top"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
61
|
+
BlobViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BlobViewerComponent, selector: "bsu-blob-viewer", inputs: { file: "file" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<bsu-mask *ngIf=\"loading\"></bsu-mask>\r\n<object\r\n *ngIf=\"valueUrl\"\r\n style=\"flex-grow: 1\"\r\n [attr.data]=\"valueUrl\"\r\n type=\"application/pdf\"\r\n width=\"100%\"\r\n height=\"100%\"\r\n [attr.html]=\"fallbackUrl\"\r\n></object>\r\n", styles: [":host{display:block;position:relative;height:100%;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MaskComponent, selector: "bsu-mask", inputs: ["size", "top"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
54
62
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BlobViewerComponent, decorators: [{
|
|
55
63
|
type: Component,
|
|
56
64
|
args: [{ selector: 'bsu-blob-viewer', changeDetection: ChangeDetectionStrategy.OnPush, template: "<bsu-mask *ngIf=\"loading\"></bsu-mask>\r\n<object\r\n *ngIf=\"valueUrl\"\r\n style=\"flex-grow: 1\"\r\n [attr.data]=\"valueUrl\"\r\n type=\"application/pdf\"\r\n width=\"100%\"\r\n height=\"100%\"\r\n [attr.html]=\"fallbackUrl\"\r\n></object>\r\n", styles: [":host{display:block;position:relative;height:100%;width:100%}\n"] }]
|
|
57
65
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.DomSanitizer }]; }, propDecorators: { file: [{
|
|
58
66
|
type: Input
|
|
59
67
|
}] } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvYi12aWV3ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmxvYi12aWV3ZXIvYmxvYi12aWV3ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmxvYi12aWV3ZXIvYmxvYi12aWV3ZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILHVCQUF1QixFQUV2QixTQUFTLEVBQ1QsS0FBSyxFQUlSLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxRQUFRLEVBQUUsYUFBYSxFQUFzQixNQUFNLHNCQUFzQixDQUFDOzs7OztBQVFuRixNQUFNLE9BQU8sbUJBQW9CLFNBQVEsYUFBYTtJQUtsRCxZQUFvQixJQUF1QixFQUFVLGFBQTJCO1FBQzVFLEtBQUssRUFBRSxDQUFDO1FBRFEsU0FBSSxHQUFKLElBQUksQ0FBbUI7UUFBVSxrQkFBYSxHQUFiLGFBQWEsQ0FBYztRQUZoRixZQUFPLEdBQUcsS0FBSyxDQUFDO0lBSWhCLENBQUM7SUFFRCxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ3JELElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDbEUsQ0FBQztJQUNELFdBQVcsQ0FBQyxPQUFzQjtRQUM5QixLQUFLLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzNCLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxPQUFPLENBQUM7UUFDekIsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQzNCLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1lBQ3JELElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7U0FDakU7SUFDTCxDQUFDO0lBRVMsZUFBZSxDQUFDLE1BQU0sRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxjQUFjO1FBQzlFLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdkIsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUMvQztZQUNJLE1BQU07WUFDTixPQUFPLEVBQUUsSUFBSTtZQUNiLGFBQWE7WUFDYixTQUFTO1lBQ1QsY0FBYztZQUNkLE1BQU07U0FDVCxFQUNELENBQUMsUUFBUSxFQUFFLEVBQUU7WUFDVCxJQUFJLFFBQVEsQ0FBQyxPQUFPLEVBQUU7Z0JBQ2xCLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxRQUFRLENBQUMsQ0FBQzthQUMzQztZQUNELElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDNUIsQ0FBQyxFQUNELENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDTixLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDYixJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzVCLENBQUMsQ0FDSixDQUFDO0lBQ04sQ0FBQztJQUNTLGNBQWMsQ0FBQyxNQUFNO1FBQzNCLE9BQU87bUVBQ29ELFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUNuRyxNQUFNLEVBQ04sS0FBSyxFQUNMLElBQUksQ0FDUCxnREFBZ0QsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQ2pGLE1BQU0sRUFDTixLQUFLLEVBQ0wsS0FBSyxDQUNSLG9DQUFvQyxDQUFDO0lBQzFDLENBQUM7SUFDUyxXQUFXLENBQUMsT0FBTztRQUN6QixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN2QixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzlCLENBQUM7SUFDUyx3QkFBd0IsQ0FBQyxRQUFRO1FBQ3ZDLE1BQU0sSUFBSSxHQUFHLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsT0FBTyxFQUFFLFFBQVEsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNwRixNQUFNLEdBQUcsR0FBRyxNQUFNLENBQUMsR0FBRyxJQUFJLE1BQU0sQ0FBQyxTQUFTLENBQUM7UUFDM0MsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLDhCQUE4QixDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUNqRyxDQUFDOztnSEFsRVEsbUJBQW1CO29HQUFuQixtQkFBbUIsNkhDbEJoQyw4UUFVQTsyRkRRYSxtQkFBbUI7a0JBTi9CLFNBQVM7K0JBQ0ksaUJBQWlCLG1CQUdWLHVCQUF1QixDQUFDLE1BQU07bUlBR3RDLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgQ29tcG9uZW50LFxuICAgIElucHV0LFxuICAgIE9uQ2hhbmdlcyxcbiAgICBPbkluaXQsXG4gICAgU2ltcGxlQ2hhbmdlc1xufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERvbVNhbml0aXplciwgU2FmZVJlc291cmNlVXJsIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5pbXBvcnQgeyBCYXJzYUFwaSwgQmFzZUNvbXBvbmVudCwgRmlsZUF0dGFjaG1lbnRJbmZvIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2JzdS1ibG9iLXZpZXdlcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2Jsb2Itdmlld2VyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9ibG9iLXZpZXdlci5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEJsb2JWaWV3ZXJDb21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICAgIEBJbnB1dCgpIGZpbGU6IEZpbGVBdHRhY2htZW50SW5mbztcbiAgICB2YWx1ZVVybDogU2FmZVJlc291cmNlVXJsO1xuICAgIGxvYWRpbmcgPSBmYWxzZTtcbiAgICBmYWxsYmFja1VybDogc3RyaW5nO1xuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgX2NkcjogQ2hhbmdlRGV0ZWN0b3JSZWYsIHByaXZhdGUgX2RvbVNhbml0aXplcjogRG9tU2FuaXRpemVyKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgICAgIHRoaXMuZmFsbGJhY2tVcmwgPSB0aGlzLmdldEZhbGxiYWNrVXJsKHRoaXMuZmlsZS5JZCk7XG4gICAgICAgIHRoaXMuX2Rvd25sb2FkRmlsZUlkKHRoaXMuZmlsZS5JZCwgdHJ1ZSwgJ3BkZicsIGZhbHNlLCBmYWxzZSk7XG4gICAgfVxuICAgIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIubmdPbkNoYW5nZXMoY2hhbmdlcyk7XG4gICAgICAgIGNvbnN0IHsgZmlsZSB9ID0gY2hhbmdlcztcbiAgICAgICAgaWYgKGZpbGUgJiYgIWZpbGUuZmlyc3RDaGFuZ2UpIHtcbiAgICAgICAgICAgIHRoaXMuZmFsbGJhY2tVcmwgPSB0aGlzLmdldEZhbGxiYWNrVXJsKHRoaXMuZmlsZS5JZCk7XG4gICAgICAgICAgICB0aGlzLl9kb3dubG9hZEZpbGVJZCh0aGlzLmZpbGUuSWQsIHRydWUsICdwZGYnLCBmYWxzZSwgZmFsc2UpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIF9kb3dubG9hZEZpbGVJZChmaWxlSWQsIHZpZXdJbkJyb3dzZXIsIGNvbnZlcnRUbywgZm9yT2N4LCBpc09mZmljZU9ubGluZSk6IHZvaWQge1xuICAgICAgICB0aGlzLl9zZXRMb2FkaW5nKHRydWUpO1xuICAgICAgICBCYXJzYUFwaS5Db21tb24uRmlsZS5Eb3dubG9hZEZpbGVDb250ZW50LmJpbmQodGhpcykoXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgZmlsZUlkLFxuICAgICAgICAgICAgICAgIGZpbGVVcmw6IG51bGwsXG4gICAgICAgICAgICAgICAgdmlld0luQnJvd3NlcixcbiAgICAgICAgICAgICAgICBjb252ZXJ0VG8sXG4gICAgICAgICAgICAgICAgaXNPZmZpY2VPbmxpbmUsXG4gICAgICAgICAgICAgICAgZm9yT2N4XG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgKHJlc3BvbnNlKSA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKHJlc3BvbnNlLnN1Y2NlZWQpIHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5fZG93bmxvYWRGaWxlSWRDb21wbGV0ZWQocmVzcG9uc2UpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB0aGlzLl9zZXRMb2FkaW5nKGZhbHNlKTtcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAoZXJyb3IpID0+IHtcbiAgICAgICAgICAgICAgICBhbGVydChlcnJvcik7XG4gICAgICAgICAgICAgICAgdGhpcy5fc2V0TG9hZGluZyhmYWxzZSk7XG4gICAgICAgICAgICB9XG4gICAgICAgICk7XG4gICAgfVxuICAgIHByb3RlY3RlZCBnZXRGYWxsYmFja1VybChmaWxlSWQpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gYNin2YXaqdin2YYg2YbZhdin24zYtCDZgdin24zZhCDYr9ixINin24zZhiDZhdix2YjYsdqv2LEg2YjYrNmI2K8g2YbYr9in2LHYry5cbiAgICDYqNix2KfbjCDYqNin2LIg2qnYsdiv2YYg2YHYp9uM2YQg2KfYsiDZhNuM2YbaqSDYstuM2LEg2KfYs9iq2YHYp9iv2Ycg2qnZhtuM2K86ICA8L2JyPiA8YSBocmVmPScke0JhcnNhQXBpLkNvbW1vbi5GaWxlLkNyZWF0ZUF0dGFjaG1lbnRVcmwoXG4gICAgICAgIGZpbGVJZCxcbiAgICAgICAgZmFsc2UsXG4gICAgICAgIHRydWVcbiAgICApfSc+2K/Yp9mG2YTZiNivINmB2KfbjNmEINio2LXZiNix2KogcGRmPC9hPiAgPC9icj4gIDxhIGhyZWY9JyR7QmFyc2FBcGkuQ29tbW9uLkZpbGUuQ3JlYXRlQXR0YWNobWVudFVybChcbiAgICAgICAgICAgIGZpbGVJZCxcbiAgICAgICAgICAgIGZhbHNlLFxuICAgICAgICAgICAgZmFsc2VcbiAgICAgICAgKX0nPtiv2KfZhtmE2YjYryDZgdin24zZhCDYqNi12YjYsdiqINio2LXZiNix2Kog2KfYtdmE24w8L2E+YDtcbiAgICB9XG4gICAgcHJvdGVjdGVkIF9zZXRMb2FkaW5nKGxvYWRpbmcpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5sb2FkaW5nID0gbG9hZGluZztcbiAgICAgICAgdGhpcy5fY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgICB9XG4gICAgcHJvdGVjdGVkIF9kb3dubG9hZEZpbGVJZENvbXBsZXRlZChyZXNwb25zZSk6IHZvaWQge1xuICAgICAgICBjb25zdCBibG9iID0gQmFyc2FBcGkuQ29tbW9uLkZpbGUuQjY0dG9CbG9iKHJlc3BvbnNlLmNvbnRlbnQsIHJlc3BvbnNlLmNvbnRlbnRUeXBlKTtcbiAgICAgICAgY29uc3QgdXJsID0gd2luZG93LlVSTCB8fCB3aW5kb3cud2Via2l0VVJMO1xuICAgICAgICB0aGlzLnZhbHVlVXJsID0gdGhpcy5fZG9tU2FuaXRpemVyLmJ5cGFzc1NlY3VyaXR5VHJ1c3RSZXNvdXJjZVVybCh1cmwuY3JlYXRlT2JqZWN0VVJMKGJsb2IpKTtcbiAgICB9XG59XG4iLCI8YnN1LW1hc2sgKm5nSWY9XCJsb2FkaW5nXCI+PC9ic3UtbWFzaz5cclxuPG9iamVjdFxyXG4gICAgKm5nSWY9XCJ2YWx1ZVVybFwiXHJcbiAgICBzdHlsZT1cImZsZXgtZ3JvdzogMVwiXHJcbiAgICBbYXR0ci5kYXRhXT1cInZhbHVlVXJsXCJcclxuICAgIHR5cGU9XCJhcHBsaWNhdGlvbi9wZGZcIlxyXG4gICAgd2lkdGg9XCIxMDAlXCJcclxuICAgIGhlaWdodD1cIjEwMCVcIlxyXG4gICAgW2F0dHIuaHRtbF09XCJmYWxsYmFja1VybFwiXHJcbj48L29iamVjdD5cclxuIl19
|
|
@@ -8,6 +8,7 @@ import * as i4 from "@fundamental-ngx/core/popover";
|
|
|
8
8
|
import * as i5 from "../file-viewer-content/file-viewer-content.component";
|
|
9
9
|
import * as i6 from "../fullscreen-files.directive";
|
|
10
10
|
import * as i7 from "../download-files.directive";
|
|
11
|
+
import * as i8 from "barsa-novin-ray-core";
|
|
11
12
|
export class FileViewerPopoverComponent extends BaseComponent {
|
|
12
13
|
constructor() {
|
|
13
14
|
super();
|
|
@@ -18,17 +19,21 @@ export class FileViewerPopoverComponent extends BaseComponent {
|
|
|
18
19
|
}
|
|
19
20
|
}
|
|
20
21
|
FileViewerPopoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: FileViewerPopoverComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
21
|
-
FileViewerPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: FileViewerPopoverComponent, selector: "bsu-file-viewer-popover", inputs: { file: "file", deviceSize: "deviceSize", canDownload: "canDownload" }, outputs: { remove: "remove" }, usesInheritance: true, ngImport: i0, template: "<div style=\"display: flex; align-items: center; column-gap: 1px\">\
|
|
22
|
+
FileViewerPopoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: FileViewerPopoverComponent, selector: "bsu-file-viewer-popover", inputs: { files: "files", file: "file", deviceSize: "deviceSize", canDownload: "canDownload", disableRemove: "disableRemove" }, outputs: { remove: "remove" }, usesInheritance: true, ngImport: i0, template: "<div style=\"display: flex; align-items: center; column-gap: 1px\">\n <button\n fd-button\n [fdPopoverTrigger]=\"deviceSize === 's' ? popoverMobile : popoverLarge\"\n [label]=\"file.FileName || ''\"\n glyph=\"attachment\"\n [fdMenu]=\"true\"\n class=\"btn-actionsheet\"\n ></button>\n <fd-popover\n #popoverMobile\n [mobile]=\"true\"\n [mobileConfig]=\"{ title: 'ShowFiles' | bbbTranslate, hasCloseButton: true }\"\n >\n <ng-template #popoverBodyContent>\n <ng-container\n *ngTemplateOutlet=\"popoverbodyTpl; context: { $implicit: popoverMobile, mobile: true }\"\n ></ng-container>\n </ng-template>\n </fd-popover>\n <fd-popover #popoverLarge>\n <fd-popover-body>\n <ng-container\n *ngTemplateOutlet=\"popoverbodyTpl; context: { $implicit: popoverLarge, mobile: false }\"\n ></ng-container>\n </fd-popover-body>\n </fd-popover>\n\n <button *ngIf=\"!disableRemove\" fd-button glyph=\"delete\" (click)=\"remove.emit()\"></button>\n</div>\n\n<ng-template #popoverbodyTpl let-popover let-mobile=\"mobile\">\n <div fd-popover-body-header>\n <div fd-bar [cozy]=\"true\" id=\"popover-bar-header-3\">\n <div fd-bar-left>\n <fd-bar-element>{{ file.FileName }}</fd-bar-element>\n </div>\n </div>\n </div>\n <bsu-file-viewer-content\n [file]=\"file\"\n [width]=\"mobile ? '100vw' : '30vw'\"\n [cardMode]=\"true\"\n [showContent]=\"true\"\n [showFooter]=\"true\"\n [cardContentHeight]=\"mobile ? null : '320px'\"\n ></bsu-file-viewer-content>\n <div fd-popover-body-footer *ngIf=\"canDownload\">\n <div fd-bar barDesign=\"footer\">\n <div fd-bar-right>\n <fd-button-bar\n fdType=\"transparent\"\n glyph=\"download\"\n downloadFiles\n [files]=\"[file]\"\n (click)=\"popover.close()\"\n ></fd-button-bar>\n <fd-button-bar\n *ngIf=\"!mobile\"\n fdType=\"transparent\"\n glyph=\"resize\"\n fullscreenFiles\n [files]=\"files?.length ? files : [file]\"\n (click)=\"popover.close()\"\n ></fd-button-bar>\n </div>\n </div>\n </div>\n</ng-template>\n", styles: [":host{display:block}.btn-actionsheet{width:100%!important;max-width:100%!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.BarComponent, selector: "[fd-bar]", inputs: ["class", "barDesign", "inPage", "inHomePage", "size"] }, { kind: "directive", type: i2.BarLeftDirective, selector: "[fd-bar-left]" }, { kind: "directive", type: i2.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "directive", type: i2.BarElementDirective, selector: "fd-bar-element", inputs: ["fullWidth", "isTitle"] }, { kind: "component", type: i2.ButtonBarComponent, selector: "fd-button-bar", inputs: ["fullWidth", "fdType", "title", "ariaLabel", "ariaLabelledby", "id"] }, { kind: "directive", type: i2.DeprecatedBarContentDensityDirective, selector: "[fd-bar][cozy]" }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.PopoverBodyComponent, selector: "fd-popover-body" }, { kind: "directive", type: i4.PopoverBodyHeaderDirective, selector: "[fdPopoverBodyHeader], [fd-popover-body-header]" }, { kind: "directive", type: i4.PopoverBodyFooterDirective, selector: "[fdPopoverBodyFooter], [fd-popover-body-footer]" }, { kind: "component", type: i4.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig"] }, { kind: "directive", type: i4.PopoverTriggerDirective, selector: "[fdPopoverTrigger], [fd-popover-trigger]", inputs: ["fdPopoverTrigger"] }, { kind: "component", type: i5.FileViewerContentComponent, selector: "bsu-file-viewer-content", inputs: ["fillWidth", "imageOnly", "cardMode", "showFooter", "showContent", "width", "cardContentHeight", "file"] }, { kind: "directive", type: i6.FullscreenFilesDirective, selector: "[fullscreenFiles]", inputs: ["files", "title", "isImageGallery", "component"] }, { kind: "directive", type: i7.DownloadFilesDirective, selector: "[downloadFiles]", inputs: ["files"] }, { kind: "pipe", type: i8.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
22
23
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: FileViewerPopoverComponent, decorators: [{
|
|
23
24
|
type: Component,
|
|
24
|
-
args: [{ selector: 'bsu-file-viewer-popover', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div style=\"display: flex; align-items: center; column-gap: 1px\">\
|
|
25
|
-
}], ctorParameters: function () { return []; }, propDecorators: {
|
|
25
|
+
args: [{ selector: 'bsu-file-viewer-popover', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div style=\"display: flex; align-items: center; column-gap: 1px\">\n <button\n fd-button\n [fdPopoverTrigger]=\"deviceSize === 's' ? popoverMobile : popoverLarge\"\n [label]=\"file.FileName || ''\"\n glyph=\"attachment\"\n [fdMenu]=\"true\"\n class=\"btn-actionsheet\"\n ></button>\n <fd-popover\n #popoverMobile\n [mobile]=\"true\"\n [mobileConfig]=\"{ title: 'ShowFiles' | bbbTranslate, hasCloseButton: true }\"\n >\n <ng-template #popoverBodyContent>\n <ng-container\n *ngTemplateOutlet=\"popoverbodyTpl; context: { $implicit: popoverMobile, mobile: true }\"\n ></ng-container>\n </ng-template>\n </fd-popover>\n <fd-popover #popoverLarge>\n <fd-popover-body>\n <ng-container\n *ngTemplateOutlet=\"popoverbodyTpl; context: { $implicit: popoverLarge, mobile: false }\"\n ></ng-container>\n </fd-popover-body>\n </fd-popover>\n\n <button *ngIf=\"!disableRemove\" fd-button glyph=\"delete\" (click)=\"remove.emit()\"></button>\n</div>\n\n<ng-template #popoverbodyTpl let-popover let-mobile=\"mobile\">\n <div fd-popover-body-header>\n <div fd-bar [cozy]=\"true\" id=\"popover-bar-header-3\">\n <div fd-bar-left>\n <fd-bar-element>{{ file.FileName }}</fd-bar-element>\n </div>\n </div>\n </div>\n <bsu-file-viewer-content\n [file]=\"file\"\n [width]=\"mobile ? '100vw' : '30vw'\"\n [cardMode]=\"true\"\n [showContent]=\"true\"\n [showFooter]=\"true\"\n [cardContentHeight]=\"mobile ? null : '320px'\"\n ></bsu-file-viewer-content>\n <div fd-popover-body-footer *ngIf=\"canDownload\">\n <div fd-bar barDesign=\"footer\">\n <div fd-bar-right>\n <fd-button-bar\n fdType=\"transparent\"\n glyph=\"download\"\n downloadFiles\n [files]=\"[file]\"\n (click)=\"popover.close()\"\n ></fd-button-bar>\n <fd-button-bar\n *ngIf=\"!mobile\"\n fdType=\"transparent\"\n glyph=\"resize\"\n fullscreenFiles\n [files]=\"files?.length ? files : [file]\"\n (click)=\"popover.close()\"\n ></fd-button-bar>\n </div>\n </div>\n </div>\n</ng-template>\n", styles: [":host{display:block}.btn-actionsheet{width:100%!important;max-width:100%!important}\n"] }]
|
|
26
|
+
}], ctorParameters: function () { return []; }, propDecorators: { files: [{
|
|
27
|
+
type: Input
|
|
28
|
+
}], file: [{
|
|
26
29
|
type: Input
|
|
27
30
|
}], deviceSize: [{
|
|
28
31
|
type: Input
|
|
29
32
|
}], canDownload: [{
|
|
30
33
|
type: Input
|
|
34
|
+
}], disableRemove: [{
|
|
35
|
+
type: Input
|
|
31
36
|
}], remove: [{
|
|
32
37
|
type: Output
|
|
33
38
|
}] } });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS12aWV3ZXItcG9wb3Zlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1zYXAtdWkvc3JjL2xpYi9maWxlLXZpZXdlci1wb3BvdmVyL2ZpbGUtdmlld2VyLXBvcG92ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvZmlsZS12aWV3ZXItcG9wb3Zlci9maWxlLXZpZXdlci1wb3BvdmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEcsT0FBTyxFQUF5QixhQUFhLEVBQXNCLE1BQU0sc0JBQXNCLENBQUM7Ozs7Ozs7Ozs7QUFRaEcsTUFBTSxPQUFPLDBCQUEyQixTQUFRLGFBQWE7SUFPekQ7UUFDSSxLQUFLLEVBQUUsQ0FBQztRQUZGLFdBQU0sR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO0lBRzVDLENBQUM7SUFFRCxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ3JCLENBQUM7O3VIQWJRLDBCQUEwQjsyR0FBMUIsMEJBQTBCLHFQQ1R2Qyx3K0VBcUVBOzJGRDVEYSwwQkFBMEI7a0JBTnRDLFNBQVM7K0JBQ0kseUJBQXlCLG1CQUdsQix1QkFBdUIsQ0FBQyxNQUFNOzBFQUd0QyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNJLE1BQU07c0JBQWYsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBYmJyZXZhdGlvbkRldmljZVNpemUsIEJhc2VDb21wb25lbnQsIEZpbGVBdHRhY2htZW50SW5mbyB9IGZyb20gJ2JhcnNhLW5vdmluLXJheS1jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdic3UtZmlsZS12aWV3ZXItcG9wb3ZlcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2ZpbGUtdmlld2VyLXBvcG92ZXIuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2ZpbGUtdmlld2VyLXBvcG92ZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBGaWxlVmlld2VyUG9wb3ZlckNvbXBvbmVudCBleHRlbmRzIEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBJbnB1dCgpIGZpbGVzOiBGaWxlQXR0YWNobWVudEluZm9bXTtcbiAgICBASW5wdXQoKSBmaWxlOiBGaWxlQXR0YWNobWVudEluZm87XG4gICAgQElucHV0KCkgZGV2aWNlU2l6ZTogQWJicmV2YXRpb25EZXZpY2VTaXplO1xuICAgIEBJbnB1dCgpIGNhbkRvd25sb2FkOiBib29sZWFuO1xuICAgIEBJbnB1dCgpIGRpc2FibGVSZW1vdmU6IGJvb2xlYW47XG4gICAgQE91dHB1dCgpIHJlbW92ZSA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICB9XG59XG4iLCI8ZGl2IHN0eWxlPVwiZGlzcGxheTogZmxleDsgYWxpZ24taXRlbXM6IGNlbnRlcjsgY29sdW1uLWdhcDogMXB4XCI+XG4gICAgPGJ1dHRvblxuICAgICAgICBmZC1idXR0b25cbiAgICAgICAgW2ZkUG9wb3ZlclRyaWdnZXJdPVwiZGV2aWNlU2l6ZSA9PT0gJ3MnID8gcG9wb3Zlck1vYmlsZSA6IHBvcG92ZXJMYXJnZVwiXG4gICAgICAgIFtsYWJlbF09XCJmaWxlLkZpbGVOYW1lIHx8ICcnXCJcbiAgICAgICAgZ2x5cGg9XCJhdHRhY2htZW50XCJcbiAgICAgICAgW2ZkTWVudV09XCJ0cnVlXCJcbiAgICAgICAgY2xhc3M9XCJidG4tYWN0aW9uc2hlZXRcIlxuICAgID48L2J1dHRvbj5cbiAgICA8ZmQtcG9wb3ZlclxuICAgICAgICAjcG9wb3Zlck1vYmlsZVxuICAgICAgICBbbW9iaWxlXT1cInRydWVcIlxuICAgICAgICBbbW9iaWxlQ29uZmlnXT1cInsgdGl0bGU6ICdTaG93RmlsZXMnIHwgYmJiVHJhbnNsYXRlLCBoYXNDbG9zZUJ1dHRvbjogdHJ1ZSB9XCJcbiAgICA+XG4gICAgICAgIDxuZy10ZW1wbGF0ZSAjcG9wb3ZlckJvZHlDb250ZW50PlxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lclxuICAgICAgICAgICAgICAgICpuZ1RlbXBsYXRlT3V0bGV0PVwicG9wb3ZlcmJvZHlUcGw7IGNvbnRleHQ6IHsgJGltcGxpY2l0OiBwb3BvdmVyTW9iaWxlLCBtb2JpbGU6IHRydWUgfVwiXG4gICAgICAgICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgICAgIDwvbmctdGVtcGxhdGU+XG4gICAgPC9mZC1wb3BvdmVyPlxuICAgIDxmZC1wb3BvdmVyICNwb3BvdmVyTGFyZ2U+XG4gICAgICAgIDxmZC1wb3BvdmVyLWJvZHk+XG4gICAgICAgICAgICA8bmctY29udGFpbmVyXG4gICAgICAgICAgICAgICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJwb3BvdmVyYm9keVRwbDsgY29udGV4dDogeyAkaW1wbGljaXQ6IHBvcG92ZXJMYXJnZSwgbW9iaWxlOiBmYWxzZSB9XCJcbiAgICAgICAgICAgID48L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC9mZC1wb3BvdmVyLWJvZHk+XG4gICAgPC9mZC1wb3BvdmVyPlxuXG4gICAgPGJ1dHRvbiAqbmdJZj1cIiFkaXNhYmxlUmVtb3ZlXCIgZmQtYnV0dG9uIGdseXBoPVwiZGVsZXRlXCIgKGNsaWNrKT1cInJlbW92ZS5lbWl0KClcIj48L2J1dHRvbj5cbjwvZGl2PlxuXG48bmctdGVtcGxhdGUgI3BvcG92ZXJib2R5VHBsIGxldC1wb3BvdmVyIGxldC1tb2JpbGU9XCJtb2JpbGVcIj5cbiAgICA8ZGl2IGZkLXBvcG92ZXItYm9keS1oZWFkZXI+XG4gICAgICAgIDxkaXYgZmQtYmFyIFtjb3p5XT1cInRydWVcIiBpZD1cInBvcG92ZXItYmFyLWhlYWRlci0zXCI+XG4gICAgICAgICAgICA8ZGl2IGZkLWJhci1sZWZ0PlxuICAgICAgICAgICAgICAgIDxmZC1iYXItZWxlbWVudD57eyBmaWxlLkZpbGVOYW1lIH19PC9mZC1iYXItZWxlbWVudD5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8YnN1LWZpbGUtdmlld2VyLWNvbnRlbnRcbiAgICAgICAgW2ZpbGVdPVwiZmlsZVwiXG4gICAgICAgIFt3aWR0aF09XCJtb2JpbGUgPyAnMTAwdncnIDogJzMwdncnXCJcbiAgICAgICAgW2NhcmRNb2RlXT1cInRydWVcIlxuICAgICAgICBbc2hvd0NvbnRlbnRdPVwidHJ1ZVwiXG4gICAgICAgIFtzaG93Rm9vdGVyXT1cInRydWVcIlxuICAgICAgICBbY2FyZENvbnRlbnRIZWlnaHRdPVwibW9iaWxlID8gbnVsbCA6ICczMjBweCdcIlxuICAgID48L2JzdS1maWxlLXZpZXdlci1jb250ZW50PlxuICAgIDxkaXYgZmQtcG9wb3Zlci1ib2R5LWZvb3RlciAqbmdJZj1cImNhbkRvd25sb2FkXCI+XG4gICAgICAgIDxkaXYgZmQtYmFyIGJhckRlc2lnbj1cImZvb3RlclwiPlxuICAgICAgICAgICAgPGRpdiBmZC1iYXItcmlnaHQ+XG4gICAgICAgICAgICAgICAgPGZkLWJ1dHRvbi1iYXJcbiAgICAgICAgICAgICAgICAgICAgZmRUeXBlPVwidHJhbnNwYXJlbnRcIlxuICAgICAgICAgICAgICAgICAgICBnbHlwaD1cImRvd25sb2FkXCJcbiAgICAgICAgICAgICAgICAgICAgZG93bmxvYWRGaWxlc1xuICAgICAgICAgICAgICAgICAgICBbZmlsZXNdPVwiW2ZpbGVdXCJcbiAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cInBvcG92ZXIuY2xvc2UoKVwiXG4gICAgICAgICAgICAgICAgPjwvZmQtYnV0dG9uLWJhcj5cbiAgICAgICAgICAgICAgICA8ZmQtYnV0dG9uLWJhclxuICAgICAgICAgICAgICAgICAgICAqbmdJZj1cIiFtb2JpbGVcIlxuICAgICAgICAgICAgICAgICAgICBmZFR5cGU9XCJ0cmFuc3BhcmVudFwiXG4gICAgICAgICAgICAgICAgICAgIGdseXBoPVwicmVzaXplXCJcbiAgICAgICAgICAgICAgICAgICAgZnVsbHNjcmVlbkZpbGVzXG4gICAgICAgICAgICAgICAgICAgIFtmaWxlc109XCJmaWxlcz8ubGVuZ3RoID8gZmlsZXMgOiBbZmlsZV1cIlxuICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwicG9wb3Zlci5jbG9zZSgpXCJcbiAgICAgICAgICAgICAgICA+PC9mZC1idXR0b24tYmFyPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
|
|
@@ -33,6 +33,9 @@ export class FormDialogComponent extends BaseComponent {
|
|
|
33
33
|
this._setCaption(formPanelCtrlr);
|
|
34
34
|
this.formPanelCtrlr = formPanelCtrlr;
|
|
35
35
|
}
|
|
36
|
+
get Adapter() {
|
|
37
|
+
return this.formPanelCtrlr.Adapter;
|
|
38
|
+
}
|
|
36
39
|
ngOnInit() {
|
|
37
40
|
super.ngOnInit();
|
|
38
41
|
const formPanelCtrlr = this.formPanelCtrlr;
|
|
@@ -80,14 +83,16 @@ export class FormDialogComponent extends BaseComponent {
|
|
|
80
83
|
this.dialogRef = this._dialogService.open(this.dialogTemplateRef, setting);
|
|
81
84
|
}
|
|
82
85
|
onCancel() {
|
|
86
|
+
const adapter = this.Adapter;
|
|
87
|
+
adapter.fireEvent('ToolClick', adapter, { Key: 'Cancel' });
|
|
83
88
|
this._close();
|
|
84
89
|
}
|
|
85
90
|
onSave() {
|
|
86
|
-
const adapter = this.
|
|
91
|
+
const adapter = this.Adapter;
|
|
87
92
|
adapter.fireEvent('ToolClick', adapter, { Key: 'SaveAndClose' });
|
|
88
93
|
}
|
|
89
94
|
onOk() {
|
|
90
|
-
const adapter = this.
|
|
95
|
+
const adapter = this.Adapter;
|
|
91
96
|
adapter.fireEvent('ToolClick', adapter, { Key: 'Ok' });
|
|
92
97
|
}
|
|
93
98
|
onFormClose() {
|
|
@@ -103,7 +108,7 @@ export class FormDialogComponent extends BaseComponent {
|
|
|
103
108
|
// @Input() RefreshFormPanelControl = (formpanelCtrlr) => {};
|
|
104
109
|
_close() {
|
|
105
110
|
// this.dialogRef.nativeElement.close();
|
|
106
|
-
this.
|
|
111
|
+
this.Adapter.Control.fireEvent('RequestForClose', this.Adapter.Control);
|
|
107
112
|
// this.dialogRef.close();
|
|
108
113
|
// this.dialogParams.close();
|
|
109
114
|
// this.dialogOpened = false;
|
|
@@ -123,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
123
128
|
type: ViewChild,
|
|
124
129
|
args: ['dialog', { read: TemplateRef, static: true }]
|
|
125
130
|
}] } });
|
|
126
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/form-dialog/form-dialog.component.ts","../../../../../projects/barsa-sap-ui/src/lib/form-dialog/form-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, ComponentRef, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { DialogRef, DialogService } from '@fundamental-ngx/core';\nimport {\n    BarsaApi,\n    DialogParams,\n    FormComponent,\n    PortalService,\n    ContainerService,\n    BaseComponent\n} from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-form-dialog',\n    templateUrl: './form-dialog.component.html',\n    styleUrls: ['./form-dialog.component.scss'],\n    providers: [ContainerService],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormDialogComponent extends BaseComponent implements OnInit {\n    @ViewChild('dialog', { read: TemplateRef, static: true })\n    dialogTemplateRef: TemplateRef<any>;\n\n    formPanelCtrlr: any;\n    formComponentRef: ComponentRef<FormComponent>;\n    caption = '';\n    fullscreen = false;\n    dialogOpened: boolean;\n    dialogRef: DialogRef;\n    inDialog: any;\n    params: {\n        moId: string;\n        typeDefId: string;\n        reportId: string;\n        inDialog: boolean;\n    };\n    parentContainer: any;\n    deviceSize: string;\n    isNonePersistance = false;\n    showSaveButton = true;\n    showToolbar = true;\n    showFooter: boolean;\n    constructor(\n        private _dialogService: DialogService,\n        private dialogParams: DialogParams,\n        private _portalService: PortalService\n    ) {\n        super();\n        this._portalService.deviceSize$.subscribe((deviceSize) => {\n            this.deviceSize = deviceSize;\n        });\n        const formPanelCtrlr = this.dialogParams.context.formpanelCtrlr;\n        const moId = this.dialogParams.context.id;\n        const typeDefId = this.dialogParams.context.tyid;\n        const reportId = this.dialogParams.context.repid;\n        this.inDialog = this.dialogParams.context.inDialog;\n        this.fullscreen = this.dialogParams.context.fullscreen;\n        this.params = { moId, typeDefId, reportId, inDialog: true };\n        this._setCaption(formPanelCtrlr);\n        this.formPanelCtrlr = formPanelCtrlr;\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        const formPanelCtrlr = this.formPanelCtrlr;\n        this.showSaveButton = BarsaApi.Common.Util.TryGetValue(\n            formPanelCtrlr,\n            'Setting.View.FormSettings.ShowSaveButton'\n        );\n        this.showToolbar = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Setting.View.FormSettings.ShowToolbar');\n        this.isNonePersistance = formPanelCtrlr?.Setting?.View?.IsNonePersistance;\n        this.showFooter = this.isNonePersistance\n            ? this.showSaveButton !== false && this.showToolbar !== false\n            : this.showSaveButton;\n        if (typeof this.showFooter == typeof null) {\n            this.showFooter = true;\n        }\n        this.openDialog();\n    }\n    openDialog(): void {\n        const smallDevice = this.deviceSize === 's' || this.deviceSize === 'm';\n        const width = smallDevice ? '100vw' : '30vw';\n        let height = smallDevice ? '100vh' : 'auto';\n        const viewWidth = BarsaApi.Common.Util.TryGetValue(this.formPanelCtrlr, 'Setting.View.MinSize.width', null);\n        const viewHieght = BarsaApi.Common.Util.TryGetValue(this.formPanelCtrlr, 'Setting.View.MinSize.height', null);\n        const minWidth = smallDevice ? '100vw' : viewWidth ? viewWidth + 'px' : 'auto';\n        const minHeight = smallDevice ? '100vw' : viewHieght ? viewHieght + 'px' : 'auto';\n        if (viewHieght) {\n            height = '100%';\n        }\n        const modalSetting = BarsaApi.Common.Util.TryGetValue(\n            this.formPanelCtrlr,\n            'Setting.View.CustomUi.Parameters.ModalSetting',\n            null\n        );\n        let setting = {\n            escKeyCloseable: false,\n            responsivePadding: true,\n            backdropClickCloseable: false,\n            mobile: smallDevice,\n            width,\n            height,\n            // bodyMinHeight: minHeight,\n            minHeight,\n            minWidth,\n            fullScreen: smallDevice,\n            verticalPadding: true,\n            resizable: false,\n            data: { caption: this.caption }\n        };\n        if (modalSetting) {\n            setting = { ...setting, ...modalSetting };\n        }\n        this.dialogRef = this._dialogService.open(this.dialogTemplateRef, setting);\n    }\n\n    onCancel(): void {\n        this._close();\n    }\n    onSave(): void {\n        const adapter = this.formPanelCtrlr.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'SaveAndClose' });\n    }\n    onOk(): void {\n        const adapter = this.formPanelCtrlr.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'Ok' });\n    }\n\n    onFormClose(): void {\n        this.dialogRef.close();\n        this.dialogParams.close();\n        this.dialogOpened = false;\n    }\n    // /* eslint-disable */\n    // @Input() ShowFormPanelControl = (formpanelCtrlr) => {};\n    // /* eslint-disable */\n    // @Input() ForceCloseChild = () => {};\n    // /* eslint-disable */\n    // @Input() RefreshFormPanelControl = (formpanelCtrlr) => {};\n\n    private _close(): void {\n        // this.dialogRef.nativeElement.close();\n        this.formPanelCtrlr.Adapter.Control.fireEvent('RequestForClose', this.formPanelCtrlr.Adapter.Control);\n        // this.dialogRef.close();\n        // this.dialogParams.close();\n        // this.dialogOpened = false;\n    }\n\n    private _setCaption(formPanelCtrlr: any): void {\n        const typeDefName = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Mo.$TypeDefName', '');\n        const moCaption = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Mo.$Caption', '');\n        this.caption = typeDefName + ':' + moCaption;\n    }\n}\n","<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #dialog>\n    <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTplRef>\n        <fd-dialog-header>\n            <ng-template fdTemplate=\"header\">\n                <div fd-bar-left>\n                    <h1 fd-title>{{ dialogConfig.data.caption }}</h1>\n                </div>\n                <div fd-bar-right>\n                    <fd-button-bar\n                        *ngIf=\"dialogConfig.height !== '100vh'\"\n                        ariaLabel=\"fullscreen\"\n                        [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n                        fullscreenDialog\n                        [dialog]=\"dialog\"\n                        [dialogComponent]=\"dialogTplRef\"\n                    ></fd-button-bar>\n                    <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel()\"></fd-button-bar>\n                </div>\n            </ng-template>\n        </fd-dialog-header>\n\n        <fd-dialog-body>\n            <bnrc-form [formPanelCtrl]=\"formPanelCtrlr\" [params]=\"params\" (formClose)=\"onFormClose()\"></bnrc-form>\n        </fd-dialog-body>\n        <fd-dialog-footer [style.display]=\"!showFooter ? 'none' : null\">\n            <ng-container *ngIf=\"isNonePersistance; else saveBtn\">\n                <fd-dialog-footer-button>\n                    <fd-button-bar\n                        fd-dialog-decisive-button\n                        fdType=\"emphasized\"\n                        [label]=\"'Ok' | bbbTranslate\"\n                        (click)=\"onOk()\"\n                    ></fd-button-bar>\n                </fd-dialog-footer-button>\n            </ng-container>\n            <ng-template #saveBtn>\n                <fd-dialog-footer-button>\n                    <fd-button-bar\n                        fd-dialog-decisive-button\n                        fdType=\"emphasized\"\n                        [label]=\"'Save' | bbbTranslate\"\n                        (click)=\"onSave()\"\n                    ></fd-button-bar>\n                </fd-dialog-footer-button>\n            </ng-template>\n\n            <fd-dialog-footer-button>\n                <fd-button-bar\n                    fd-initial-focus\n                    fd-dialog-decisive-button\n                    fdType=\"transparent\"\n                    [label]=\"'Cancel' | bbbTranslate\"\n                    (click)=\"onCancel()\"\n                ></fd-button-bar>\n            </fd-dialog-footer-button>\n        </fd-dialog-footer>\n    </fd-dialog>\n</ng-template>\n"]}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/form-dialog/form-dialog.component.ts","../../../../../projects/barsa-sap-ui/src/lib/form-dialog/form-dialog.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAwB,WAAW,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAEjH,OAAO,EACH,QAAQ,EAIR,gBAAgB,EAChB,aAAa,EAChB,MAAM,sBAAsB,CAAC;;;;;;;;;;AAS9B,MAAM,OAAO,mBAAoB,SAAQ,aAAa;IAuBlD,YACY,cAA6B,EAC7B,YAA0B,EAC1B,cAA6B;QAErC,KAAK,EAAE,CAAC;QAJA,mBAAc,GAAd,cAAc,CAAe;QAC7B,iBAAY,GAAZ,YAAY,CAAc;QAC1B,mBAAc,GAAd,cAAc,CAAe;QApBzC,YAAO,GAAG,EAAE,CAAC;QACb,eAAU,GAAG,KAAK,CAAC;QAYnB,sBAAiB,GAAG,KAAK,CAAC;QAC1B,mBAAc,GAAG,IAAI,CAAC;QACtB,gBAAW,GAAG,IAAI,CAAC;QAQf,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,EAAE;YACrD,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,cAAc,CAAC;QAChE,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,EAAE,CAAC;QAC1C,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC;QACjD,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,KAAK,CAAC;QACjD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,QAAQ,CAAC;QACnD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,UAAU,CAAC;QACvD,IAAI,CAAC,MAAM,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;QAC5D,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;QACjC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAC;IACzC,CAAC;IACD,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC;IACvC,CAAC;IACD,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QAC3C,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAClD,cAAc,EACd,0CAA0C,CAC7C,CAAC;QACF,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,uCAAuC,CAAC,CAAC;QAC7G,IAAI,CAAC,iBAAiB,GAAG,cAAc,EAAE,OAAO,EAAE,IAAI,EAAE,iBAAiB,CAAC;QAC1E,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,iBAAiB;YACpC,CAAC,CAAC,IAAI,CAAC,cAAc,KAAK,KAAK,IAAI,IAAI,CAAC,WAAW,KAAK,KAAK;YAC7D,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC;QAC1B,IAAI,OAAO,IAAI,CAAC,UAAU,IAAI,OAAO,IAAI,EAAE;YACvC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;SAC1B;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IACD,UAAU;QACN,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,KAAK,GAAG,IAAI,IAAI,CAAC,UAAU,KAAK,GAAG,CAAC;QACvE,MAAM,KAAK,GAAG,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;QAC7C,IAAI,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;QAC5C,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,EAAE,4BAA4B,EAAE,IAAI,CAAC,CAAC;QAC5G,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,EAAE,6BAA6B,EAAE,IAAI,CAAC,CAAC;QAC9G,MAAM,QAAQ,GAAG,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC;QAC/E,MAAM,SAAS,GAAG,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC;QAClF,IAAI,UAAU,EAAE;YACZ,MAAM,GAAG,MAAM,CAAC;SACnB;QACD,MAAM,YAAY,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CACjD,IAAI,CAAC,cAAc,EACnB,+CAA+C,EAC/C,IAAI,CACP,CAAC;QACF,IAAI,OAAO,GAAG;YACV,eAAe,EAAE,KAAK;YACtB,iBAAiB,EAAE,IAAI;YACvB,sBAAsB,EAAE,KAAK;YAC7B,MAAM,EAAE,WAAW;YACnB,KAAK;YACL,MAAM;YACN,4BAA4B;YAC5B,SAAS;YACT,QAAQ;YACR,UAAU,EAAE,WAAW;YACvB,eAAe,EAAE,IAAI;YACrB,SAAS,EAAE,KAAK;YAChB,IAAI,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE;SAClC,CAAC;QACF,IAAI,YAAY,EAAE;YACd,OAAO,GAAG,EAAE,GAAG,OAAO,EAAE,GAAG,YAAY,EAAE,CAAC;SAC7C;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,OAAO,CAAC,CAAC;IAC/E,CAAC;IAED,QAAQ;QACJ,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7B,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,OAAO,EAAE,EAAE,GAAG,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC3D,IAAI,CAAC,MAAM,EAAE,CAAC;IAClB,CAAC;IACD,MAAM;QACF,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7B,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,OAAO,EAAE,EAAE,GAAG,EAAE,cAAc,EAAE,CAAC,CAAC;IACrE,CAAC;IACD,IAAI;QACA,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QAC7B,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,OAAO,EAAE,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3D,CAAC;IAED,WAAW;QACP,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;QACvB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;QAC1B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC9B,CAAC;IACD,uBAAuB;IACvB,0DAA0D;IAC1D,uBAAuB;IACvB,uCAAuC;IACvC,uBAAuB;IACvB,6DAA6D;IAErD,MAAM;QACV,wCAAwC;QACxC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,iBAAiB,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACxE,0BAA0B;QAC1B,6BAA6B;QAC7B,6BAA6B;IACjC,CAAC;IAEO,WAAW,CAAC,cAAmB;QACnC,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,iBAAiB,EAAE,EAAE,CAAC,CAAC;QAC5F,MAAM,SAAS,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,cAAc,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC;QACtF,IAAI,CAAC,OAAO,GAAG,WAAW,GAAG,GAAG,GAAG,SAAS,CAAC;IACjD,CAAC;;gHAzIQ,mBAAmB;oGAAnB,mBAAmB,0CAHjB,CAAC,gBAAgB,CAAC,kHAIA,WAAW,kECnB5C,8iFA0DA;2FDxCa,mBAAmB;kBAP/B,SAAS;+BACI,iBAAiB,aAGhB,CAAC,gBAAgB,CAAC,mBACZ,uBAAuB,CAAC,MAAM;2JAI/C,iBAAiB;sBADhB,SAAS;uBAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { ChangeDetectionStrategy, Component, ComponentRef, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { DialogRef, DialogService } from '@fundamental-ngx/core';\nimport {\n    BarsaApi,\n    DialogParams,\n    FormComponent,\n    PortalService,\n    ContainerService,\n    BaseComponent\n} from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-form-dialog',\n    templateUrl: './form-dialog.component.html',\n    styleUrls: ['./form-dialog.component.scss'],\n    providers: [ContainerService],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class FormDialogComponent extends BaseComponent implements OnInit {\n    @ViewChild('dialog', { read: TemplateRef, static: true })\n    dialogTemplateRef: TemplateRef<any>;\n\n    formPanelCtrlr: any;\n    formComponentRef: ComponentRef<FormComponent>;\n    caption = '';\n    fullscreen = false;\n    dialogOpened: boolean;\n    dialogRef: DialogRef;\n    inDialog: any;\n    params: {\n        moId: string;\n        typeDefId: string;\n        reportId: string;\n        inDialog: boolean;\n    };\n    parentContainer: any;\n    deviceSize: string;\n    isNonePersistance = false;\n    showSaveButton = true;\n    showToolbar = true;\n    showFooter: boolean;\n    constructor(\n        private _dialogService: DialogService,\n        private dialogParams: DialogParams,\n        private _portalService: PortalService\n    ) {\n        super();\n        this._portalService.deviceSize$.subscribe((deviceSize) => {\n            this.deviceSize = deviceSize;\n        });\n        const formPanelCtrlr = this.dialogParams.context.formpanelCtrlr;\n        const moId = this.dialogParams.context.id;\n        const typeDefId = this.dialogParams.context.tyid;\n        const reportId = this.dialogParams.context.repid;\n        this.inDialog = this.dialogParams.context.inDialog;\n        this.fullscreen = this.dialogParams.context.fullscreen;\n        this.params = { moId, typeDefId, reportId, inDialog: true };\n        this._setCaption(formPanelCtrlr);\n        this.formPanelCtrlr = formPanelCtrlr;\n    }\n    get Adapter(): any {\n        return this.formPanelCtrlr.Adapter;\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        const formPanelCtrlr = this.formPanelCtrlr;\n        this.showSaveButton = BarsaApi.Common.Util.TryGetValue(\n            formPanelCtrlr,\n            'Setting.View.FormSettings.ShowSaveButton'\n        );\n        this.showToolbar = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Setting.View.FormSettings.ShowToolbar');\n        this.isNonePersistance = formPanelCtrlr?.Setting?.View?.IsNonePersistance;\n        this.showFooter = this.isNonePersistance\n            ? this.showSaveButton !== false && this.showToolbar !== false\n            : this.showSaveButton;\n        if (typeof this.showFooter == typeof null) {\n            this.showFooter = true;\n        }\n        this.openDialog();\n    }\n    openDialog(): void {\n        const smallDevice = this.deviceSize === 's' || this.deviceSize === 'm';\n        const width = smallDevice ? '100vw' : '30vw';\n        let height = smallDevice ? '100vh' : 'auto';\n        const viewWidth = BarsaApi.Common.Util.TryGetValue(this.formPanelCtrlr, 'Setting.View.MinSize.width', null);\n        const viewHieght = BarsaApi.Common.Util.TryGetValue(this.formPanelCtrlr, 'Setting.View.MinSize.height', null);\n        const minWidth = smallDevice ? '100vw' : viewWidth ? viewWidth + 'px' : 'auto';\n        const minHeight = smallDevice ? '100vw' : viewHieght ? viewHieght + 'px' : 'auto';\n        if (viewHieght) {\n            height = '100%';\n        }\n        const modalSetting = BarsaApi.Common.Util.TryGetValue(\n            this.formPanelCtrlr,\n            'Setting.View.CustomUi.Parameters.ModalSetting',\n            null\n        );\n        let setting = {\n            escKeyCloseable: false,\n            responsivePadding: true,\n            backdropClickCloseable: false,\n            mobile: smallDevice,\n            width,\n            height,\n            // bodyMinHeight: minHeight,\n            minHeight,\n            minWidth,\n            fullScreen: smallDevice,\n            verticalPadding: true,\n            resizable: false,\n            data: { caption: this.caption }\n        };\n        if (modalSetting) {\n            setting = { ...setting, ...modalSetting };\n        }\n        this.dialogRef = this._dialogService.open(this.dialogTemplateRef, setting);\n    }\n\n    onCancel(): void {\n        const adapter = this.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'Cancel' });\n        this._close();\n    }\n    onSave(): void {\n        const adapter = this.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'SaveAndClose' });\n    }\n    onOk(): void {\n        const adapter = this.Adapter;\n        adapter.fireEvent('ToolClick', adapter, { Key: 'Ok' });\n    }\n\n    onFormClose(): void {\n        this.dialogRef.close();\n        this.dialogParams.close();\n        this.dialogOpened = false;\n    }\n    // /* eslint-disable */\n    // @Input() ShowFormPanelControl = (formpanelCtrlr) => {};\n    // /* eslint-disable */\n    // @Input() ForceCloseChild = () => {};\n    // /* eslint-disable */\n    // @Input() RefreshFormPanelControl = (formpanelCtrlr) => {};\n\n    private _close(): void {\n        // this.dialogRef.nativeElement.close();\n        this.Adapter.Control.fireEvent('RequestForClose', this.Adapter.Control);\n        // this.dialogRef.close();\n        // this.dialogParams.close();\n        // this.dialogOpened = false;\n    }\n\n    private _setCaption(formPanelCtrlr: any): void {\n        const typeDefName = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Mo.$TypeDefName', '');\n        const moCaption = BarsaApi.Common.Util.TryGetValue(formPanelCtrlr, 'Mo.$Caption', '');\n        this.caption = typeDefName + ':' + moCaption;\n    }\n}\n","<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #dialog>\n    <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTplRef>\n        <fd-dialog-header>\n            <ng-template fdTemplate=\"header\">\n                <div fd-bar-left>\n                    <h1 fd-title>{{ dialogConfig.data.caption }}</h1>\n                </div>\n                <div fd-bar-right>\n                    <fd-button-bar\n                        *ngIf=\"dialogConfig.height !== '100vh'\"\n                        ariaLabel=\"fullscreen\"\n                        [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n                        fullscreenDialog\n                        [dialog]=\"dialog\"\n                        [dialogComponent]=\"dialogTplRef\"\n                    ></fd-button-bar>\n                    <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel()\"></fd-button-bar>\n                </div>\n            </ng-template>\n        </fd-dialog-header>\n\n        <fd-dialog-body>\n            <bnrc-form [formPanelCtrl]=\"formPanelCtrlr\" [params]=\"params\" (formClose)=\"onFormClose()\"></bnrc-form>\n        </fd-dialog-body>\n        <fd-dialog-footer [style.display]=\"!showFooter ? 'none' : null\">\n            <ng-container *ngIf=\"isNonePersistance; else saveBtn\">\n                <fd-dialog-footer-button>\n                    <fd-button-bar\n                        fd-dialog-decisive-button\n                        fdType=\"emphasized\"\n                        [label]=\"'Ok' | bbbTranslate\"\n                        (click)=\"onOk()\"\n                    ></fd-button-bar>\n                </fd-dialog-footer-button>\n            </ng-container>\n            <ng-template #saveBtn>\n                <fd-dialog-footer-button>\n                    <fd-button-bar\n                        fd-dialog-decisive-button\n                        fdType=\"emphasized\"\n                        [label]=\"'Save' | bbbTranslate\"\n                        (click)=\"onSave()\"\n                    ></fd-button-bar>\n                </fd-dialog-footer-button>\n            </ng-template>\n\n            <fd-dialog-footer-button>\n                <fd-button-bar\n                    fd-initial-focus\n                    fd-dialog-decisive-button\n                    fdType=\"transparent\"\n                    [label]=\"'Cancel' | bbbTranslate\"\n                    (click)=\"onCancel()\"\n                ></fd-button-bar>\n            </fd-dialog-footer-button>\n        </fd-dialog-footer>\n    </fd-dialog>\n</ng-template>\n"]}
|