barsa-sap-ui 2.2.19 → 2.2.21

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.
@@ -107,7 +107,7 @@ export class UiFileLinearListBoxComponent extends DeviceInfoFieldBaseComponent {
107
107
  this.fireContextEvent('CommandRequest', this.context, 'FileUpload', newFileAttachment);
108
108
  }
109
109
  _setFileCount(value) {
110
- this._fileCountSource.next(value.filter((c) => !c.IsDeleted).length);
110
+ this._fileCountSource.next(value?.filter((c) => !c.IsDeleted).length);
111
111
  }
112
112
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiFileLinearListBoxComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
113
113
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: UiFileLinearListBoxComponent, selector: "bsu-ui-file-linear-list-box", inputs: { value: "value" }, providers: [UploadService], viewQueries: [{ propertyName: "fileUploadComponent", first: true, predicate: FileUploaderComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "@if (value) {\r\n<div class=\"token-container\">\r\n <div class=\"token-wrapper\">\r\n @for (file of value; track trackById($index, file)) { @if (!file.IsDeleted) {\r\n <fd-popover #popover>\r\n <fd-popover-control>\r\n <fd-token (onCloseClick)=\"onFileDeleted(file.Id)\" [readOnly]=\"(disableOrReadonly$ | async)!!\"\r\n >{{ file.FileName }}\r\n @if (file.IsNew) { @if (valueExtra$ | async; as valueExtra) { @if (valueExtra[file.Id].UploadState\r\n !== 'Complete') {\r\n <span\r\n fd-object-status\r\n [status]=\"file.Id | uploadFileStatus: valueExtra\"\r\n [label]=\"valueExtra[file.Id]?.UploadState || ''\"\r\n [title]=\"valueExtra[file.Id]?.UploadState\"\r\n [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\r\n ></span>\r\n } @if (valueExtra[file.Id].Progress) {\r\n <fd-object-number\r\n [number]=\"valueExtra[file.Id].Progress || 0\"\r\n unit=\"%\"\r\n status=\"informative\"\r\n ></fd-object-number>\r\n } @if (valueExtra[file.Id].UploadState === 'Uploading') {\r\n <fd-busy-indicator [loading]=\"true\" [size]=\"'s'\"></fd-busy-indicator>\r\n } } }\r\n </fd-token>\r\n </fd-popover-control>\r\n <fd-popover-body>\r\n @if (valueExtra$ | async; as valueExtra) { @if ( valueExtra[file.Id].UploadState !== 'Error' ||\r\n valueExtra[file.Id].UploadState === 'Complete' ) {\r\n <bsu-file-viewer-content\r\n [file]=\"file\"\r\n [width]=\"isMobile ? '100vw' : '30vw'\"\r\n [cardMode]=\"true\"\r\n [showContent]=\"true\"\r\n [showFooter]=\"true\"\r\n [deviceSize]=\"(deviceSize$ | async) || 's'\"\r\n ></bsu-file-viewer-content>\r\n <div fd-popover-body-footer>\r\n <bsu-barsa-bar-download-file\r\n [isMobile]=\"false\"\r\n [popover]=\"popover\"\r\n [canPrint]=\"file.Type | isImageType\"\r\n [files]=\"[file]\"\r\n [hideFullScreen]=\"false\"\r\n [deviceSize]=\"(deviceSize$ | async) || 's'\"\r\n ></bsu-barsa-bar-download-file>\r\n </div>\r\n <!-- <ul fd-list>\r\n <li fd-list-item>\r\n <a fd-list-link (click)=\"onDownloadFile(file)\">\r\n <i fd-list-icon glyph=\"download\"></i>\r\n <span fd-list-title>\r\n {{ 'Download' | bbbTranslate }}\r\n </span>\r\n <fd-busy-indicator [loading]=\"fileDownloading\" [size]=\"'s'\"></fd-busy-indicator>\r\n </a>\r\n </li>\r\n </ul> -->\r\n } }\r\n </fd-popover-body>\r\n </fd-popover>\r\n } }\r\n <div style=\"display: flex\">\r\n @if (loading) {\r\n <div style=\"position: relative; width: 3rem\">\r\n <bsu-mask [size]=\"'s'\" style=\"background: transparent\"></bsu-mask>\r\n </div>\r\n } @if ((fileCount$ | async) | canUploadFile: maxFileCount:(disable$ | async)===true:(readonly$ |\r\n async)===true) {\r\n <fd-file-uploader\r\n class=\"file-linear-upload\"\r\n fd-toolbar-item\r\n [id]=\"id\"\r\n [name]=\"'linear_' + id\"\r\n [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n [accept]=\"validExtension\"\r\n [multiple]=\"maxFileCount > 1 || Setting.IsMultiSelect\"\r\n (selectedFilesChanged)=\"onFileSelection($event)\"\r\n [contentDensity]=\"(contentDensity$ | async)!!\"\r\n ></fd-file-uploader>\r\n }\r\n </div>\r\n </div>\r\n</div>\r\n}\r\n", styles: [":host{display:block;width:100%;height:100%}:host ::ng-deep .fd-slider__handle{display:none}:host ::ng-deep .fd-file-uploader input{display:none}:host.isMobile ::ng-deep fd-token>span{-webkit-line-clamp:2;-webkit-box-orient:vertical;white-space:pre-wrap;height:auto;text-align:right}:host.isMobile ::ng-deep body[dir=ltr] fd-token>span{text-align:left}.token-container{background:transparent;padding:3px;display:flex}.token-wrapper{align-items:center;flex-grow:1;display:flex;flex-wrap:wrap}.token-wrapper fd-token,.token-wrapper .file-linear-upload{padding:4px}\n"], dependencies: [{ kind: "component", type: i1.BusyIndicatorComponent, selector: "fd-busy-indicator", inputs: ["loading", "size", "block", "ariaLabel", "title", "label", "ariaLive"] }, { kind: "component", type: i2.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: i3.ObjectNumberComponent, selector: "fd-object-number", inputs: ["number", "decimal", "unit", "emphasized", "large", "status", "class", "ariaLabelledBy", "ariaLabel"] }, { kind: "component", type: i4.ObjectStatusComponent, selector: "[fd-object-status]", inputs: ["class", "status", "glyph", "glyphFont", "label", "glyphAriaLabel", "indicationColor", "clickable", "inverted", "large", "secondaryIndication", "textTemplate"] }, { kind: "component", type: i5.PopoverControlComponent, selector: "fd-popover-control, [fdPopoverControl]" }, { kind: "component", type: i5.PopoverBodyComponent, selector: "fd-popover-body", inputs: ["minWidth", "maxWidth", "minHeight", "maxHeight"] }, { kind: "directive", type: i5.PopoverBodyFooterDirective, selector: "[fdPopoverBodyFooter], [fd-popover-body-footer]" }, { kind: "component", type: i5.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig", "preventSpaceKeyScroll"] }, { kind: "directive", type: i6.ToolbarItemDirective, selector: "[fd-toolbar-item], [fdOverflowGroup], [fdOverflowPriority]", inputs: ["fdOverflowPriority", "fdOverflowGroup"] }, { kind: "component", type: i7.TokenComponent, selector: "fd-token", inputs: ["disabled", "selected", "readOnly"], outputs: ["onCloseClick", "onRemove", "onTokenClick", "onTokenKeydown", "elementFocused"] }, { kind: "component", type: i8.BarsaBarDownloadFileComponent, selector: "bsu-barsa-bar-download-file", inputs: ["popover", "file", "files", "hideFullScreen", "isMobile", "canPrint", "deviceSize"] }, { kind: "component", type: i9.MaskComponent, selector: "bsu-mask", inputs: ["size", "top"] }, { kind: "component", type: i10.FileViewerContentComponent, selector: "bsu-file-viewer-content", inputs: ["fillWidth", "imageOnly", "isImageGallery", "cardMode", "showFooter", "showContent", "width", "deviceSize", "cardContentHeight", "file"], outputs: ["cantView"] }, { kind: "pipe", type: i11.AsyncPipe, name: "async" }, { kind: "pipe", type: i12.CanUploadFilePipe, name: "canUploadFile" }, { kind: "pipe", type: i12.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i12.IsImagePipe, name: "isImageType" }, { kind: "pipe", type: i13.UploadFileStatusPipe, name: "uploadFileStatus" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
@@ -121,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
121
121
  }], value: [{
122
122
  type: Input
123
123
  }] } });
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-file-linear-list-box.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\r\nimport { distinctUntilChanged, takeUntil } from 'rxjs/operators';\r\nimport { ContentDensity, FileUploaderComponent } from '@fundamental-ngx/core';\r\n\r\nimport {\r\n    UploadService,\r\n    FilesValidationHelper,\r\n    FileAttachmentInfo,\r\n    getValidExtension,\r\n    LinearListHelper\r\n} from 'barsa-novin-ray-core';\r\nimport { DeviceInfoFieldBaseComponent } from '../device-info-field-base';\r\nimport { IUploadingState } from 'barsa-novin-ray-core';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-file-linear-list-box',\r\n    templateUrl: './ui-file-linear-list-box.component.html',\r\n    styleUrls: ['./ui-file-linear-list-box.component.scss'],\r\n    providers: [UploadService],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: false\r\n})\r\nexport class UiFileLinearListBoxComponent extends DeviceInfoFieldBaseComponent implements OnInit, OnDestroy {\r\n    @ViewChild(FileUploaderComponent, { static: false }) fileUploadComponent: FileUploaderComponent;\r\n    @Input() value: FileAttachmentInfo[];\r\n\r\n    fileCount$: Observable<number>;\r\n    uploading$ = new Observable<IUploadingState>();\r\n\r\n    valueExtra$: Observable<{ [key: string]: UploadFileProps }>;\r\n    contentDensity$: Observable<ContentDensity>;\r\n    fileDownloading: boolean;\r\n    validExtension = '';\r\n    maxFileCount: number;\r\n    loading = false;\r\n    protected _linearHelper: LinearListHelper;\r\n    protected _filesValidationHelper: FilesValidationHelper;\r\n    private _fileCountSource = new BehaviorSubject<number>(0);\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.context.on({\r\n            ShowUploadWindow: this._showUploadWindow.bind(this)\r\n        });\r\n        this._filesValidationHelper = new FilesValidationHelper(\r\n            this.Setting.MaxFileCount,\r\n            this.Setting.MaxFileSizeKb,\r\n            this.Setting.MaxTotalFileSizeKb\r\n        );\r\n        this._linearHelper = new LinearListHelper(\r\n            this._uploadService,\r\n            this._filesValidationHelper,\r\n            this.Setting.FieldDefId\r\n        );\r\n        this.fileCount$ = this._fileCountSource.asObservable().pipe(distinctUntilChanged());\r\n        this.valueExtra$ = this._linearHelper.valueExtra$;\r\n        this.uploading$ = this._linearHelper.uploading$;\r\n        this._linearHelper.delete$.pipe(takeUntil(this._onDestroy$)).subscribe((fileAttachment) => {\r\n            this._deleteFileAttachment(fileAttachment);\r\n        });\r\n        this._linearHelper.newFileUploaded$.pipe(takeUntil(this._onDestroy$)).subscribe((fileAttachment) => {\r\n            this._newFileUploaded(fileAttachment);\r\n        });\r\n        this.value &&\r\n            this.value.forEach((c) => {\r\n                this._linearHelper.init(c);\r\n            });\r\n\r\n        if (!this.Setting.IsMultiSelect) {\r\n            this._filesValidationHelper.maxFileCount = 1;\r\n        }\r\n        this.maxFileCount = this._filesValidationHelper.maxFileCount;\r\n        this.validExtension = getValidExtension(this.Setting.ValidExtensions);\r\n        this._setFileCount(this.value);\r\n    }\r\n    ngOnDestroy(): void {\r\n        // this.valueExtra = {};\r\n        this.context.un('ShowUploadWindow', this._showUploadWindow);\r\n        super.ngOnDestroy();\r\n    }\r\n    onDownloadFile(file: FileAttachmentInfo): void {\r\n        if (!file.IsNew || file.UploadState === 'Complete' || !file.UploadState) {\r\n            this.fireContextEvent('CommandRequest', this.context, 'Download', file.Id);\r\n            this.fileDownloading = true;\r\n            setTimeout(() => {\r\n                this.fileDownloading = false;\r\n            }, 500);\r\n        }\r\n    }\r\n    onFileDeleted(fileId): void {\r\n        this._fileDelete(fileId);\r\n    }\r\n    onTerminate(fileAttachment: FileAttachmentInfo): void {\r\n        this.fireContextEvent('CommandRequest', this.context, 'Delete', fileAttachment.Id);\r\n        this._linearHelper.cancel(fileAttachment);\r\n    }\r\n    onFileSelection(files: File[]): void {\r\n        this._linearHelper.uploadToServer(files);\r\n    }\r\n\r\n    trackById(file, index): string | number {\r\n        return file ? file.Id : index;\r\n    }\r\n    protected retry(fileAttachment: FileAttachmentInfo): void {\r\n        this._linearHelper.retry(fileAttachment);\r\n    }\r\n    protected _setValue(value: any): void {\r\n        super._setValue(value);\r\n        this._setFileCount(value);\r\n    }\r\n    protected _showUploadWindow(): void {\r\n        this.fileUploadComponent.open();\r\n    }\r\n    protected _fileDelete(id): void {\r\n        const fileAttachment = this.value.find((c) => c.Id === id);\r\n        if (fileAttachment) {\r\n            this._deleteFileAttachment(fileAttachment);\r\n        }\r\n    }\r\n    protected _deleteFileAttachment(fileAttachment: FileAttachmentInfo): void {\r\n        this.fireContextEvent('CommandRequest', this.context, 'Delete', fileAttachment.Id);\r\n    }\r\n\r\n    protected _setLoading(loading: boolean): void {\r\n        this.loading = loading;\r\n        this._cdr.markForCheck();\r\n    }\r\n    protected _newFileUploaded(newFileAttachment: FileAttachmentInfo): void {\r\n        this.fireContextEvent('CommandRequest', this.context, 'FileUpload', newFileAttachment);\r\n    }\r\n    protected _setFileCount(value): void {\r\n        this._fileCountSource.next(value.filter((c) => !c.IsDeleted).length);\r\n    }\r\n}\r\n\r\ninterface UploadFileProps {\r\n    FileUrl?: string;\r\n    cancelation$?: Subject<void>;\r\n    binary?: any;\r\n    UploadState?: string;\r\n    Progress?: number;\r\n    IsIcon?: boolean;\r\n}\r\n","@if (value) {\r\n<div class=\"token-container\">\r\n    <div class=\"token-wrapper\">\r\n        @for (file of value; track trackById($index, file)) { @if (!file.IsDeleted) {\r\n        <fd-popover #popover>\r\n            <fd-popover-control>\r\n                <fd-token (onCloseClick)=\"onFileDeleted(file.Id)\" [readOnly]=\"(disableOrReadonly$ | async)!!\"\r\n                    >{{ file.FileName }}\r\n                    @if (file.IsNew) { @if (valueExtra$ | async; as valueExtra) { @if (valueExtra[file.Id].UploadState\r\n                    !== 'Complete') {\r\n                    <span\r\n                        fd-object-status\r\n                        [status]=\"file.Id | uploadFileStatus: valueExtra\"\r\n                        [label]=\"valueExtra[file.Id]?.UploadState || ''\"\r\n                        [title]=\"valueExtra[file.Id]?.UploadState\"\r\n                        [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\r\n                    ></span>\r\n                    } @if (valueExtra[file.Id].Progress) {\r\n                    <fd-object-number\r\n                        [number]=\"valueExtra[file.Id].Progress || 0\"\r\n                        unit=\"%\"\r\n                        status=\"informative\"\r\n                    ></fd-object-number>\r\n                    } @if (valueExtra[file.Id].UploadState === 'Uploading') {\r\n                    <fd-busy-indicator [loading]=\"true\" [size]=\"'s'\"></fd-busy-indicator>\r\n                    } } }\r\n                </fd-token>\r\n            </fd-popover-control>\r\n            <fd-popover-body>\r\n                @if (valueExtra$ | async; as valueExtra) { @if ( valueExtra[file.Id].UploadState !== 'Error' ||\r\n                valueExtra[file.Id].UploadState === 'Complete' ) {\r\n                <bsu-file-viewer-content\r\n                    [file]=\"file\"\r\n                    [width]=\"isMobile ? '100vw' : '30vw'\"\r\n                    [cardMode]=\"true\"\r\n                    [showContent]=\"true\"\r\n                    [showFooter]=\"true\"\r\n                    [deviceSize]=\"(deviceSize$ | async) || 's'\"\r\n                ></bsu-file-viewer-content>\r\n                <div fd-popover-body-footer>\r\n                    <bsu-barsa-bar-download-file\r\n                        [isMobile]=\"false\"\r\n                        [popover]=\"popover\"\r\n                        [canPrint]=\"file.Type | isImageType\"\r\n                        [files]=\"[file]\"\r\n                        [hideFullScreen]=\"false\"\r\n                        [deviceSize]=\"(deviceSize$ | async) || 's'\"\r\n                    ></bsu-barsa-bar-download-file>\r\n                </div>\r\n                <!-- <ul fd-list>\r\n                    <li fd-list-item>\r\n                        <a fd-list-link (click)=\"onDownloadFile(file)\">\r\n                            <i fd-list-icon glyph=\"download\"></i>\r\n                            <span fd-list-title>\r\n                                {{ 'Download' | bbbTranslate }}\r\n                            </span>\r\n                            <fd-busy-indicator [loading]=\"fileDownloading\" [size]=\"'s'\"></fd-busy-indicator>\r\n                        </a>\r\n                    </li>\r\n                </ul> -->\r\n                } }\r\n            </fd-popover-body>\r\n        </fd-popover>\r\n        } }\r\n        <div style=\"display: flex\">\r\n            @if (loading) {\r\n            <div style=\"position: relative; width: 3rem\">\r\n                <bsu-mask [size]=\"'s'\" style=\"background: transparent\"></bsu-mask>\r\n            </div>\r\n            } @if ((fileCount$ | async) | canUploadFile: maxFileCount:(disable$ | async)===true:(readonly$ |\r\n            async)===true) {\r\n            <fd-file-uploader\r\n                class=\"file-linear-upload\"\r\n                fd-toolbar-item\r\n                [id]=\"id\"\r\n                [name]=\"'linear_' + id\"\r\n                [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n                [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n                [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n                [accept]=\"validExtension\"\r\n                [multiple]=\"maxFileCount > 1 || Setting.IsMultiSelect\"\r\n                (selectedFilesChanged)=\"onFileSelection($event)\"\r\n                [contentDensity]=\"(contentDensity$ | async)!!\"\r\n            ></fd-file-uploader>\r\n            }\r\n        </div>\r\n    </div>\r\n</div>\r\n}\r\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-file-linear-list-box.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\r\nimport { distinctUntilChanged, takeUntil } from 'rxjs/operators';\r\nimport { ContentDensity, FileUploaderComponent } from '@fundamental-ngx/core';\r\n\r\nimport {\r\n    UploadService,\r\n    FilesValidationHelper,\r\n    FileAttachmentInfo,\r\n    getValidExtension,\r\n    LinearListHelper\r\n} from 'barsa-novin-ray-core';\r\nimport { DeviceInfoFieldBaseComponent } from '../device-info-field-base';\r\nimport { IUploadingState } from 'barsa-novin-ray-core';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-file-linear-list-box',\r\n    templateUrl: './ui-file-linear-list-box.component.html',\r\n    styleUrls: ['./ui-file-linear-list-box.component.scss'],\r\n    providers: [UploadService],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: false\r\n})\r\nexport class UiFileLinearListBoxComponent extends DeviceInfoFieldBaseComponent implements OnInit, OnDestroy {\r\n    @ViewChild(FileUploaderComponent, { static: false }) fileUploadComponent: FileUploaderComponent;\r\n    @Input() value: FileAttachmentInfo[];\r\n\r\n    fileCount$: Observable<number>;\r\n    uploading$ = new Observable<IUploadingState>();\r\n\r\n    valueExtra$: Observable<{ [key: string]: UploadFileProps }>;\r\n    contentDensity$: Observable<ContentDensity>;\r\n    fileDownloading: boolean;\r\n    validExtension = '';\r\n    maxFileCount: number;\r\n    loading = false;\r\n    protected _linearHelper: LinearListHelper;\r\n    protected _filesValidationHelper: FilesValidationHelper;\r\n    private _fileCountSource = new BehaviorSubject<number>(0);\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this.context.on({\r\n            ShowUploadWindow: this._showUploadWindow.bind(this)\r\n        });\r\n        this._filesValidationHelper = new FilesValidationHelper(\r\n            this.Setting.MaxFileCount,\r\n            this.Setting.MaxFileSizeKb,\r\n            this.Setting.MaxTotalFileSizeKb\r\n        );\r\n        this._linearHelper = new LinearListHelper(\r\n            this._uploadService,\r\n            this._filesValidationHelper,\r\n            this.Setting.FieldDefId\r\n        );\r\n        this.fileCount$ = this._fileCountSource.asObservable().pipe(distinctUntilChanged());\r\n        this.valueExtra$ = this._linearHelper.valueExtra$;\r\n        this.uploading$ = this._linearHelper.uploading$;\r\n        this._linearHelper.delete$.pipe(takeUntil(this._onDestroy$)).subscribe((fileAttachment) => {\r\n            this._deleteFileAttachment(fileAttachment);\r\n        });\r\n        this._linearHelper.newFileUploaded$.pipe(takeUntil(this._onDestroy$)).subscribe((fileAttachment) => {\r\n            this._newFileUploaded(fileAttachment);\r\n        });\r\n        this.value &&\r\n            this.value.forEach((c) => {\r\n                this._linearHelper.init(c);\r\n            });\r\n\r\n        if (!this.Setting.IsMultiSelect) {\r\n            this._filesValidationHelper.maxFileCount = 1;\r\n        }\r\n        this.maxFileCount = this._filesValidationHelper.maxFileCount;\r\n        this.validExtension = getValidExtension(this.Setting.ValidExtensions);\r\n        this._setFileCount(this.value);\r\n    }\r\n    ngOnDestroy(): void {\r\n        // this.valueExtra = {};\r\n        this.context.un('ShowUploadWindow', this._showUploadWindow);\r\n        super.ngOnDestroy();\r\n    }\r\n    onDownloadFile(file: FileAttachmentInfo): void {\r\n        if (!file.IsNew || file.UploadState === 'Complete' || !file.UploadState) {\r\n            this.fireContextEvent('CommandRequest', this.context, 'Download', file.Id);\r\n            this.fileDownloading = true;\r\n            setTimeout(() => {\r\n                this.fileDownloading = false;\r\n            }, 500);\r\n        }\r\n    }\r\n    onFileDeleted(fileId): void {\r\n        this._fileDelete(fileId);\r\n    }\r\n    onTerminate(fileAttachment: FileAttachmentInfo): void {\r\n        this.fireContextEvent('CommandRequest', this.context, 'Delete', fileAttachment.Id);\r\n        this._linearHelper.cancel(fileAttachment);\r\n    }\r\n    onFileSelection(files: File[]): void {\r\n        this._linearHelper.uploadToServer(files);\r\n    }\r\n\r\n    trackById(file, index): string | number {\r\n        return file ? file.Id : index;\r\n    }\r\n    protected retry(fileAttachment: FileAttachmentInfo): void {\r\n        this._linearHelper.retry(fileAttachment);\r\n    }\r\n    protected _setValue(value: any): void {\r\n        super._setValue(value);\r\n        this._setFileCount(value);\r\n    }\r\n    protected _showUploadWindow(): void {\r\n        this.fileUploadComponent.open();\r\n    }\r\n    protected _fileDelete(id): void {\r\n        const fileAttachment = this.value.find((c) => c.Id === id);\r\n        if (fileAttachment) {\r\n            this._deleteFileAttachment(fileAttachment);\r\n        }\r\n    }\r\n    protected _deleteFileAttachment(fileAttachment: FileAttachmentInfo): void {\r\n        this.fireContextEvent('CommandRequest', this.context, 'Delete', fileAttachment.Id);\r\n    }\r\n\r\n    protected _setLoading(loading: boolean): void {\r\n        this.loading = loading;\r\n        this._cdr.markForCheck();\r\n    }\r\n    protected _newFileUploaded(newFileAttachment: FileAttachmentInfo): void {\r\n        this.fireContextEvent('CommandRequest', this.context, 'FileUpload', newFileAttachment);\r\n    }\r\n    protected _setFileCount(value): void {\r\n        this._fileCountSource.next(value?.filter((c) => !c.IsDeleted).length);\r\n    }\r\n}\r\n\r\ninterface UploadFileProps {\r\n    FileUrl?: string;\r\n    cancelation$?: Subject<void>;\r\n    binary?: any;\r\n    UploadState?: string;\r\n    Progress?: number;\r\n    IsIcon?: boolean;\r\n}\r\n","@if (value) {\r\n<div class=\"token-container\">\r\n    <div class=\"token-wrapper\">\r\n        @for (file of value; track trackById($index, file)) { @if (!file.IsDeleted) {\r\n        <fd-popover #popover>\r\n            <fd-popover-control>\r\n                <fd-token (onCloseClick)=\"onFileDeleted(file.Id)\" [readOnly]=\"(disableOrReadonly$ | async)!!\"\r\n                    >{{ file.FileName }}\r\n                    @if (file.IsNew) { @if (valueExtra$ | async; as valueExtra) { @if (valueExtra[file.Id].UploadState\r\n                    !== 'Complete') {\r\n                    <span\r\n                        fd-object-status\r\n                        [status]=\"file.Id | uploadFileStatus: valueExtra\"\r\n                        [label]=\"valueExtra[file.Id]?.UploadState || ''\"\r\n                        [title]=\"valueExtra[file.Id]?.UploadState\"\r\n                        [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\r\n                    ></span>\r\n                    } @if (valueExtra[file.Id].Progress) {\r\n                    <fd-object-number\r\n                        [number]=\"valueExtra[file.Id].Progress || 0\"\r\n                        unit=\"%\"\r\n                        status=\"informative\"\r\n                    ></fd-object-number>\r\n                    } @if (valueExtra[file.Id].UploadState === 'Uploading') {\r\n                    <fd-busy-indicator [loading]=\"true\" [size]=\"'s'\"></fd-busy-indicator>\r\n                    } } }\r\n                </fd-token>\r\n            </fd-popover-control>\r\n            <fd-popover-body>\r\n                @if (valueExtra$ | async; as valueExtra) { @if ( valueExtra[file.Id].UploadState !== 'Error' ||\r\n                valueExtra[file.Id].UploadState === 'Complete' ) {\r\n                <bsu-file-viewer-content\r\n                    [file]=\"file\"\r\n                    [width]=\"isMobile ? '100vw' : '30vw'\"\r\n                    [cardMode]=\"true\"\r\n                    [showContent]=\"true\"\r\n                    [showFooter]=\"true\"\r\n                    [deviceSize]=\"(deviceSize$ | async) || 's'\"\r\n                ></bsu-file-viewer-content>\r\n                <div fd-popover-body-footer>\r\n                    <bsu-barsa-bar-download-file\r\n                        [isMobile]=\"false\"\r\n                        [popover]=\"popover\"\r\n                        [canPrint]=\"file.Type | isImageType\"\r\n                        [files]=\"[file]\"\r\n                        [hideFullScreen]=\"false\"\r\n                        [deviceSize]=\"(deviceSize$ | async) || 's'\"\r\n                    ></bsu-barsa-bar-download-file>\r\n                </div>\r\n                <!-- <ul fd-list>\r\n                    <li fd-list-item>\r\n                        <a fd-list-link (click)=\"onDownloadFile(file)\">\r\n                            <i fd-list-icon glyph=\"download\"></i>\r\n                            <span fd-list-title>\r\n                                {{ 'Download' | bbbTranslate }}\r\n                            </span>\r\n                            <fd-busy-indicator [loading]=\"fileDownloading\" [size]=\"'s'\"></fd-busy-indicator>\r\n                        </a>\r\n                    </li>\r\n                </ul> -->\r\n                } }\r\n            </fd-popover-body>\r\n        </fd-popover>\r\n        } }\r\n        <div style=\"display: flex\">\r\n            @if (loading) {\r\n            <div style=\"position: relative; width: 3rem\">\r\n                <bsu-mask [size]=\"'s'\" style=\"background: transparent\"></bsu-mask>\r\n            </div>\r\n            } @if ((fileCount$ | async) | canUploadFile: maxFileCount:(disable$ | async)===true:(readonly$ |\r\n            async)===true) {\r\n            <fd-file-uploader\r\n                class=\"file-linear-upload\"\r\n                fd-toolbar-item\r\n                [id]=\"id\"\r\n                [name]=\"'linear_' + id\"\r\n                [placeholder]=\"'AttachFile' | bbbTranslate\"\r\n                [buttonLabel]=\"'AttachFile' | bbbTranslate\"\r\n                [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\r\n                [accept]=\"validExtension\"\r\n                [multiple]=\"maxFileCount > 1 || Setting.IsMultiSelect\"\r\n                (selectedFilesChanged)=\"onFileSelection($event)\"\r\n                [contentDensity]=\"(contentDensity$ | async)!!\"\r\n            ></fd-file-uploader>\r\n            }\r\n        </div>\r\n    </div>\r\n</div>\r\n}\r\n"]}
@@ -28,10 +28,10 @@ export class UiMultiSelectCardComponent extends UiMultiSelectComboComponent {
28
28
  this._raiseValueChanged();
29
29
  }
30
30
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiMultiSelectCardComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
31
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: UiMultiSelectCardComponent, selector: "bsu-ui-multi-select-card", usesInheritance: true, ngImport: i0, template: "<fd-form-group [isInline]=\"!parameters?.IsVertically && !(isMobile && parameters?.OnlyInMobileVertically)\">\r\n @for (item of dataList; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n <fd-card>\r\n <fd-card-content>\r\n <img\r\n width=\"90px\"\r\n [src]=\"item.fileId | picFieldSrc: 'PictureFileInfo':item.Id:item.fieldDefId\"\r\n [alt]=\"item.txt\"\r\n [attr.aria-label]=\"item.txt\"\r\n [title]=\"item.txt\"\r\n />\r\n </fd-card-content>\r\n <fd-card-header (click)=\"onRadioClicked(item)\">\r\n <fd-card-main-header>\r\n <fd-radio-button\r\n fd-card-title\r\n [value]=\"item.id\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\"\r\n [disabled]=\"(disableOrReadonly$ | async)!!\"\r\n [ngModel]=\"value\"\r\n [selectedValue]=\"value\"\r\n >\r\n {{ item.txt }}\r\n </fd-radio-button>\r\n </fd-card-main-header>\r\n </fd-card-header>\r\n </fd-card>\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host{display:block;width:100%;height:100%}:host div[fd-form-item]{margin:0 .5rem}fd-form-group{row-gap:1rem}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.CardComponent, selector: "fd-card", inputs: ["badge", "badgeIcon", "badgeColor", "badgeColorSecondary", "badgeStatus", "badgeAriaLabel", "secondBadge", "secondBadgeIcon", "secondBadgeColor", "secondBadgeColorSecondary", "secondBadgeStatus", "secondBadgeAriaLabel", "isLoading", "cardType", "id", "ariaRoledescription", "ariaDescription", "ariaLabel", "role", "interactive", "selected", "ariaPosinset", "ariaSetsize"], outputs: ["ariaPosinsetChange", "ariaSetsizeChange"] }, { kind: "component", type: i2.CardHeaderComponent, selector: "fd-card-header", inputs: ["ariaRoleDescription"] }, { kind: "component", type: i2.CardMainHeaderComponent, selector: "fd-card-main-header", inputs: ["interactive", "title"] }, { kind: "component", type: i2.CardContentComponent, selector: "fd-card-content" }, { kind: "directive", type: i2.CardTitleDirective, selector: "[fd-card-title]", inputs: ["id"] }, { kind: "component", type: i3.FormItemComponent, selector: "[fd-form-item]", inputs: ["isInline", "horizontal"] }, { kind: "component", type: i3.FormGroupComponent, selector: "fd-form-group", inputs: ["isInline"] }, { kind: "component", type: i4.RadioButtonComponent, selector: "fd-radio-button", inputs: ["ariaLabel", "ariaLabelledBy", "ariaDescribedBy", "title", "tabIndex", "state", "disabled", "selectedValue", "name", "id", "value", "required", "standalone"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.PictureFieldSourcePipe, name: "picFieldSrc" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
31
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: UiMultiSelectCardComponent, selector: "bsu-ui-multi-select-card", usesInheritance: true, ngImport: i0, template: "<fd-form-group [isInline]=\"!parameters?.IsVertically && !(isMobile && parameters?.OnlyInMobileVertically)\">\r\n @for (item of dataList; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n <fd-card>\r\n <fd-card-content>\r\n <img\r\n width=\"90px\"\r\n [src]=\"item.fileId | picFieldSrc: 'PictureFileInfo':item.Id:item.fieldDefId\"\r\n [alt]=\"item.txt\"\r\n [attr.aria-label]=\"item.txt\"\r\n [title]=\"item.txt\"\r\n />\r\n </fd-card-content>\r\n <fd-card-header (click)=\"onRadioClicked(item)\">\r\n <fd-card-main-header>\r\n <fd-radio-button\r\n fd-card-title\r\n [value]=\"item.id\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\" \r\n [class.control-disabled]=\"(disableOrReadonly$ | async) === true\"\r\n [disabled]=\"(disableOrReadonly$ | async) === true\"\r\n [ngModel]=\"value\"\r\n [selectedValue]=\"value\"\r\n >\r\n {{ item.txt }}\r\n </fd-radio-button>\r\n </fd-card-main-header>\r\n </fd-card-header>\r\n </fd-card>\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host{display:block;width:100%;height:100%}:host div[fd-form-item]{margin:0 .5rem}fd-form-group{row-gap:1rem}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.CardComponent, selector: "fd-card", inputs: ["badge", "badgeIcon", "badgeColor", "badgeColorSecondary", "badgeStatus", "badgeAriaLabel", "secondBadge", "secondBadgeIcon", "secondBadgeColor", "secondBadgeColorSecondary", "secondBadgeStatus", "secondBadgeAriaLabel", "isLoading", "cardType", "id", "ariaRoledescription", "ariaDescription", "ariaLabel", "role", "interactive", "selected", "ariaPosinset", "ariaSetsize"], outputs: ["ariaPosinsetChange", "ariaSetsizeChange"] }, { kind: "component", type: i2.CardHeaderComponent, selector: "fd-card-header", inputs: ["ariaRoleDescription"] }, { kind: "component", type: i2.CardMainHeaderComponent, selector: "fd-card-main-header", inputs: ["interactive", "title"] }, { kind: "component", type: i2.CardContentComponent, selector: "fd-card-content" }, { kind: "directive", type: i2.CardTitleDirective, selector: "[fd-card-title]", inputs: ["id"] }, { kind: "component", type: i3.FormItemComponent, selector: "[fd-form-item]", inputs: ["isInline", "horizontal"] }, { kind: "component", type: i3.FormGroupComponent, selector: "fd-form-group", inputs: ["isInline"] }, { kind: "component", type: i4.RadioButtonComponent, selector: "fd-radio-button", inputs: ["ariaLabel", "ariaLabelledBy", "ariaDescribedBy", "title", "tabIndex", "state", "disabled", "selectedValue", "name", "id", "value", "required", "standalone"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.PictureFieldSourcePipe, name: "picFieldSrc" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
32
32
  }
33
33
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiMultiSelectCardComponent, decorators: [{
34
34
  type: Component,
35
- args: [{ selector: 'bsu-ui-multi-select-card', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<fd-form-group [isInline]=\"!parameters?.IsVertically && !(isMobile && parameters?.OnlyInMobileVertically)\">\r\n @for (item of dataList; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n <fd-card>\r\n <fd-card-content>\r\n <img\r\n width=\"90px\"\r\n [src]=\"item.fileId | picFieldSrc: 'PictureFileInfo':item.Id:item.fieldDefId\"\r\n [alt]=\"item.txt\"\r\n [attr.aria-label]=\"item.txt\"\r\n [title]=\"item.txt\"\r\n />\r\n </fd-card-content>\r\n <fd-card-header (click)=\"onRadioClicked(item)\">\r\n <fd-card-main-header>\r\n <fd-radio-button\r\n fd-card-title\r\n [value]=\"item.id\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\"\r\n [disabled]=\"(disableOrReadonly$ | async)!!\"\r\n [ngModel]=\"value\"\r\n [selectedValue]=\"value\"\r\n >\r\n {{ item.txt }}\r\n </fd-radio-button>\r\n </fd-card-main-header>\r\n </fd-card-header>\r\n </fd-card>\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host{display:block;width:100%;height:100%}:host div[fd-form-item]{margin:0 .5rem}fd-form-group{row-gap:1rem}\n"] }]
35
+ args: [{ selector: 'bsu-ui-multi-select-card', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<fd-form-group [isInline]=\"!parameters?.IsVertically && !(isMobile && parameters?.OnlyInMobileVertically)\">\r\n @for (item of dataList; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n <fd-card>\r\n <fd-card-content>\r\n <img\r\n width=\"90px\"\r\n [src]=\"item.fileId | picFieldSrc: 'PictureFileInfo':item.Id:item.fieldDefId\"\r\n [alt]=\"item.txt\"\r\n [attr.aria-label]=\"item.txt\"\r\n [title]=\"item.txt\"\r\n />\r\n </fd-card-content>\r\n <fd-card-header (click)=\"onRadioClicked(item)\">\r\n <fd-card-main-header>\r\n <fd-radio-button\r\n fd-card-title\r\n [value]=\"item.id\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\" \r\n [class.control-disabled]=\"(disableOrReadonly$ | async) === true\"\r\n [disabled]=\"(disableOrReadonly$ | async) === true\"\r\n [ngModel]=\"value\"\r\n [selectedValue]=\"value\"\r\n >\r\n {{ item.txt }}\r\n </fd-radio-button>\r\n </fd-card-main-header>\r\n </fd-card-header>\r\n </fd-card>\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host{display:block;width:100%;height:100%}:host div[fd-form-item]{margin:0 .5rem}fd-form-group{row-gap:1rem}\n"] }]
36
36
  }] });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktbXVsdGktc2VsZWN0LWNhcmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktbXVsdGktc2VsZWN0LWNhcmQvdWktbXVsdGktc2VsZWN0LWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktbXVsdGktc2VsZWN0LWNhcmQvdWktbXVsdGktc2VsZWN0LWNhcmQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDdEYsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDBEQUEwRCxDQUFDOzs7Ozs7OztBQVN2RyxNQUFNLE9BQU8sMEJBQTJCLFNBQVEsMkJBQTJCO0lBUDNFOztRQVFJLGtCQUFhLEdBQWtDLEVBQUUsQ0FBQztRQUdsRCxPQUFFLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBY3ZCO0lBYkcsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxjQUFjLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBQ0QsZUFBZTtRQUNYLG9DQUFvQztRQUNwQyw4QkFBOEI7SUFDbEMsQ0FBQztJQUNELGNBQWMsQ0FBQyxJQUFJO1FBQ2YsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO0lBQzlCLENBQUM7K0dBakJRLDBCQUEwQjttR0FBMUIsMEJBQTBCLHVGQ1h2Qyx5M0NBZ0NBOzs0RkRyQmEsMEJBQTBCO2tCQVB0QyxTQUFTOytCQUNJLDBCQUEwQixtQkFHbkIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgZ2V0VW5pcXVlSWQgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbmltcG9ydCB7IFVpTXVsdGlTZWxlY3RDb21ib0NvbXBvbmVudCB9IGZyb20gJy4uL3VpLW11bHRpLXNlbGVjdC1jb21iby91aS1tdWx0aS1zZWxlY3QtY29tYm8uY29tcG9uZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdic3UtdWktbXVsdGktc2VsZWN0LWNhcmQnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3VpLW11bHRpLXNlbGVjdC1jYXJkLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL3VpLW11bHRpLXNlbGVjdC1jYXJkLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVaU11bHRpU2VsZWN0Q2FyZENvbXBvbmVudCBleHRlbmRzIFVpTXVsdGlTZWxlY3RDb21ib0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcclxuICAgIHNlbGVjdGVkSXRlbXM6IHsgaWQ6IHN0cmluZzsgdHh0OiBzdHJpbmcgfVtdID0gW107XHJcbiAgICBtYXhXaWR0aDogYW55O1xyXG4gICAgZGF0YUxpc3Q6IGFueTtcclxuICAgIGlkID0gZ2V0VW5pcXVlSWQoNCk7XHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xyXG4gICAgICAgIHRoaXMuY29udGV4dC5maXJlRXZlbnQoJ1RyaWdnZXJDbGljaycsIHRoaXMuY29udGV4dCwgJycpO1xyXG4gICAgfVxyXG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgICAgIC8vIG92ZXJyaWVkZSBwYXJlbnQgdG8gYXZvaWQgZG8gbW9yZVxyXG4gICAgICAgIC8vIHN1cGVyLm5nQWZ0ZXJDb250ZW50SW5pdCgpO1xyXG4gICAgfVxyXG4gICAgb25SYWRpb0NsaWNrZWQoaXRlbSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuc2VsZWN0ZWRJdGVtcy5wdXNoKGl0ZW0pO1xyXG4gICAgICAgIHRoaXMudmFsdWUgPSBpdGVtLmlkO1xyXG4gICAgICAgIHRoaXMuX3JhaXNlVmFsdWVDaGFuZ2VkKCk7XHJcbiAgICB9XHJcbn1cclxuIiwiPGZkLWZvcm0tZ3JvdXAgW2lzSW5saW5lXT1cIiFwYXJhbWV0ZXJzPy5Jc1ZlcnRpY2FsbHkgJiYgIShpc01vYmlsZSAmJiBwYXJhbWV0ZXJzPy5Pbmx5SW5Nb2JpbGVWZXJ0aWNhbGx5KVwiPlxyXG4gICAgQGZvciAoaXRlbSBvZiBkYXRhTGlzdDsgdHJhY2sgaXRlbTsgbGV0IGkgPSAkaW5kZXg7IGxldCBmaXJzdCA9ICRmaXJzdCkge1xyXG4gICAgPGRpdiBmZC1mb3JtLWl0ZW0+XHJcbiAgICAgICAgPGZkLWNhcmQ+XHJcbiAgICAgICAgICAgIDxmZC1jYXJkLWNvbnRlbnQ+XHJcbiAgICAgICAgICAgICAgICA8aW1nXHJcbiAgICAgICAgICAgICAgICAgICAgd2lkdGg9XCI5MHB4XCJcclxuICAgICAgICAgICAgICAgICAgICBbc3JjXT1cIml0ZW0uZmlsZUlkIHwgcGljRmllbGRTcmM6ICdQaWN0dXJlRmlsZUluZm8nOml0ZW0uSWQ6aXRlbS5maWVsZERlZklkXCJcclxuICAgICAgICAgICAgICAgICAgICBbYWx0XT1cIml0ZW0udHh0XCJcclxuICAgICAgICAgICAgICAgICAgICBbYXR0ci5hcmlhLWxhYmVsXT1cIml0ZW0udHh0XCJcclxuICAgICAgICAgICAgICAgICAgICBbdGl0bGVdPVwiaXRlbS50eHRcIlxyXG4gICAgICAgICAgICAgICAgLz5cclxuICAgICAgICAgICAgPC9mZC1jYXJkLWNvbnRlbnQ+XHJcbiAgICAgICAgICAgIDxmZC1jYXJkLWhlYWRlciAoY2xpY2spPVwib25SYWRpb0NsaWNrZWQoaXRlbSlcIj5cclxuICAgICAgICAgICAgICAgIDxmZC1jYXJkLW1haW4taGVhZGVyPlxyXG4gICAgICAgICAgICAgICAgICAgIDxmZC1yYWRpby1idXR0b25cclxuICAgICAgICAgICAgICAgICAgICAgICAgZmQtY2FyZC10aXRsZVxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbdmFsdWVdPVwiaXRlbS5pZFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtpZF09XCIncmFkaW8tJyArIGlkICsgaVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtuYW1lXT1cIidyYWRpbycgKyBpZCArIGlcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbZGlzYWJsZWRdPVwiKGRpc2FibGVPclJlYWRvbmx5JCB8IGFzeW5jKSEhXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgW25nTW9kZWxdPVwidmFsdWVcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbc2VsZWN0ZWRWYWx1ZV09XCJ2YWx1ZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICB7eyBpdGVtLnR4dCB9fVxyXG4gICAgICAgICAgICAgICAgICAgIDwvZmQtcmFkaW8tYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgPC9mZC1jYXJkLW1haW4taGVhZGVyPlxyXG4gICAgICAgICAgICA8L2ZkLWNhcmQtaGVhZGVyPlxyXG4gICAgICAgIDwvZmQtY2FyZD5cclxuICAgIDwvZGl2PlxyXG4gICAgfVxyXG48L2ZkLWZvcm0tZ3JvdXA+XHJcbiJdfQ==
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktbXVsdGktc2VsZWN0LWNhcmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktbXVsdGktc2VsZWN0LWNhcmQvdWktbXVsdGktc2VsZWN0LWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktbXVsdGktc2VsZWN0LWNhcmQvdWktbXVsdGktc2VsZWN0LWNhcmQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDdEYsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ25ELE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDBEQUEwRCxDQUFDOzs7Ozs7OztBQVN2RyxNQUFNLE9BQU8sMEJBQTJCLFNBQVEsMkJBQTJCO0lBUDNFOztRQVFJLGtCQUFhLEdBQWtDLEVBQUUsQ0FBQztRQUdsRCxPQUFFLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBY3ZCO0lBYkcsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxjQUFjLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBQ0QsZUFBZTtRQUNYLG9DQUFvQztRQUNwQyw4QkFBOEI7SUFDbEMsQ0FBQztJQUNELGNBQWMsQ0FBQyxJQUFJO1FBQ2YsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO0lBQzlCLENBQUM7K0dBakJRLDBCQUEwQjttR0FBMUIsMEJBQTBCLHVGQ1h2QyxzL0NBaUNBOzs0RkR0QmEsMEJBQTBCO2tCQVB0QyxTQUFTOytCQUNJLDBCQUEwQixtQkFHbkIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgZ2V0VW5pcXVlSWQgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbmltcG9ydCB7IFVpTXVsdGlTZWxlY3RDb21ib0NvbXBvbmVudCB9IGZyb20gJy4uL3VpLW11bHRpLXNlbGVjdC1jb21iby91aS1tdWx0aS1zZWxlY3QtY29tYm8uY29tcG9uZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdic3UtdWktbXVsdGktc2VsZWN0LWNhcmQnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3VpLW11bHRpLXNlbGVjdC1jYXJkLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL3VpLW11bHRpLXNlbGVjdC1jYXJkLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVaU11bHRpU2VsZWN0Q2FyZENvbXBvbmVudCBleHRlbmRzIFVpTXVsdGlTZWxlY3RDb21ib0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcclxuICAgIHNlbGVjdGVkSXRlbXM6IHsgaWQ6IHN0cmluZzsgdHh0OiBzdHJpbmcgfVtdID0gW107XHJcbiAgICBtYXhXaWR0aDogYW55O1xyXG4gICAgZGF0YUxpc3Q6IGFueTtcclxuICAgIGlkID0gZ2V0VW5pcXVlSWQoNCk7XHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xyXG4gICAgICAgIHRoaXMuY29udGV4dC5maXJlRXZlbnQoJ1RyaWdnZXJDbGljaycsIHRoaXMuY29udGV4dCwgJycpO1xyXG4gICAgfVxyXG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgICAgIC8vIG92ZXJyaWVkZSBwYXJlbnQgdG8gYXZvaWQgZG8gbW9yZVxyXG4gICAgICAgIC8vIHN1cGVyLm5nQWZ0ZXJDb250ZW50SW5pdCgpO1xyXG4gICAgfVxyXG4gICAgb25SYWRpb0NsaWNrZWQoaXRlbSk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuc2VsZWN0ZWRJdGVtcy5wdXNoKGl0ZW0pO1xyXG4gICAgICAgIHRoaXMudmFsdWUgPSBpdGVtLmlkO1xyXG4gICAgICAgIHRoaXMuX3JhaXNlVmFsdWVDaGFuZ2VkKCk7XHJcbiAgICB9XHJcbn1cclxuIiwiPGZkLWZvcm0tZ3JvdXAgW2lzSW5saW5lXT1cIiFwYXJhbWV0ZXJzPy5Jc1ZlcnRpY2FsbHkgJiYgIShpc01vYmlsZSAmJiBwYXJhbWV0ZXJzPy5Pbmx5SW5Nb2JpbGVWZXJ0aWNhbGx5KVwiPlxyXG4gICAgQGZvciAoaXRlbSBvZiBkYXRhTGlzdDsgdHJhY2sgaXRlbTsgbGV0IGkgPSAkaW5kZXg7IGxldCBmaXJzdCA9ICRmaXJzdCkge1xyXG4gICAgPGRpdiBmZC1mb3JtLWl0ZW0+XHJcbiAgICAgICAgPGZkLWNhcmQ+XHJcbiAgICAgICAgICAgIDxmZC1jYXJkLWNvbnRlbnQ+XHJcbiAgICAgICAgICAgICAgICA8aW1nXHJcbiAgICAgICAgICAgICAgICAgICAgd2lkdGg9XCI5MHB4XCJcclxuICAgICAgICAgICAgICAgICAgICBbc3JjXT1cIml0ZW0uZmlsZUlkIHwgcGljRmllbGRTcmM6ICdQaWN0dXJlRmlsZUluZm8nOml0ZW0uSWQ6aXRlbS5maWVsZERlZklkXCJcclxuICAgICAgICAgICAgICAgICAgICBbYWx0XT1cIml0ZW0udHh0XCJcclxuICAgICAgICAgICAgICAgICAgICBbYXR0ci5hcmlhLWxhYmVsXT1cIml0ZW0udHh0XCJcclxuICAgICAgICAgICAgICAgICAgICBbdGl0bGVdPVwiaXRlbS50eHRcIlxyXG4gICAgICAgICAgICAgICAgLz5cclxuICAgICAgICAgICAgPC9mZC1jYXJkLWNvbnRlbnQ+XHJcbiAgICAgICAgICAgIDxmZC1jYXJkLWhlYWRlciAoY2xpY2spPVwib25SYWRpb0NsaWNrZWQoaXRlbSlcIj5cclxuICAgICAgICAgICAgICAgIDxmZC1jYXJkLW1haW4taGVhZGVyPlxyXG4gICAgICAgICAgICAgICAgICAgIDxmZC1yYWRpby1idXR0b25cclxuICAgICAgICAgICAgICAgICAgICAgICAgZmQtY2FyZC10aXRsZVxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbdmFsdWVdPVwiaXRlbS5pZFwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtpZF09XCIncmFkaW8tJyArIGlkICsgaVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtuYW1lXT1cIidyYWRpbycgKyBpZCArIGlcIiAgICAgICAgICAgICAgICAgICAgICAgIFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbY2xhc3MuY29udHJvbC1kaXNhYmxlZF09XCIoZGlzYWJsZU9yUmVhZG9ubHkkIHwgYXN5bmMpID09PSB0cnVlXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgW2Rpc2FibGVkXT1cIihkaXNhYmxlT3JSZWFkb25seSQgfCBhc3luYykgPT09IHRydWVcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbbmdNb2RlbF09XCJ2YWx1ZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtzZWxlY3RlZFZhbHVlXT1cInZhbHVlXCJcclxuICAgICAgICAgICAgICAgICAgICA+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHt7IGl0ZW0udHh0IH19XHJcbiAgICAgICAgICAgICAgICAgICAgPC9mZC1yYWRpby1idXR0b24+XHJcbiAgICAgICAgICAgICAgICA8L2ZkLWNhcmQtbWFpbi1oZWFkZXI+XHJcbiAgICAgICAgICAgIDwvZmQtY2FyZC1oZWFkZXI+XHJcbiAgICAgICAgPC9mZC1jYXJkPlxyXG4gICAgPC9kaXY+XHJcbiAgICB9XHJcbjwvZmQtZm9ybS1ncm91cD5cclxuIl19
@@ -27,10 +27,10 @@ export class UiMultiSelectRadioComponent extends UiMultiSelectComboComponent {
27
27
  this._raiseValueChanged();
28
28
  }
29
29
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiMultiSelectRadioComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
30
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: UiMultiSelectRadioComponent, selector: "bsu-ui-multi-select-radio", usesInheritance: true, ngImport: i0, template: "<fd-form-group [isInline]=\"!parameters?.IsVertically && !(isMobile && parameters?.OnlyInMobileVertically)\">\r\n @for (item of dataList; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n <fd-radio-button\r\n [value]=\"item.id\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\"\r\n [disabled]=\"(disableOrReadonly$ | async)!!\"\r\n (click)=\"onItemClicked(item)\"\r\n [ngModel]=\"value\"\r\n [selectedValue]=\"value\"\r\n >\r\n {{ item.txt }}\r\n </fd-radio-button>\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host{display:block;width:100%;height:100%}img[rtl=true]{margin-left:5px}img[rtl=false]{margin-right:5px}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.FormItemComponent, selector: "[fd-form-item]", inputs: ["isInline", "horizontal"] }, { kind: "component", type: i2.FormGroupComponent, selector: "fd-form-group", inputs: ["isInline"] }, { kind: "component", type: i3.RadioButtonComponent, selector: "fd-radio-button", inputs: ["ariaLabel", "ariaLabelledBy", "ariaDescribedBy", "title", "tabIndex", "state", "disabled", "selectedValue", "name", "id", "value", "required", "standalone"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
30
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: UiMultiSelectRadioComponent, selector: "bsu-ui-multi-select-radio", usesInheritance: true, ngImport: i0, template: "<fd-form-group [isInline]=\"!parameters?.IsVertically && !(isMobile && parameters?.OnlyInMobileVertically)\">\r\n @for (item of dataList; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n <fd-radio-button\r\n [value]=\"item.id\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\"\r\n [class.control-disabled]=\"(disableOrReadonly$ | async) === true\"\r\n [disabled]=\"(disableOrReadonly$ | async) === true\"\r\n (click)=\"onItemClicked(item)\"\r\n [ngModel]=\"value\"\r\n [selectedValue]=\"value\"\r\n >\r\n {{ item.txt }}\r\n </fd-radio-button>\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host{display:block;width:100%;height:100%}img[rtl=true]{margin-left:5px}img[rtl=false]{margin-right:5px}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.FormItemComponent, selector: "[fd-form-item]", inputs: ["isInline", "horizontal"] }, { kind: "component", type: i2.FormGroupComponent, selector: "fd-form-group", inputs: ["isInline"] }, { kind: "component", type: i3.RadioButtonComponent, selector: "fd-radio-button", inputs: ["ariaLabel", "ariaLabelledBy", "ariaDescribedBy", "title", "tabIndex", "state", "disabled", "selectedValue", "name", "id", "value", "required", "standalone"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
31
31
  }
32
32
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiMultiSelectRadioComponent, decorators: [{
33
33
  type: Component,
34
- args: [{ selector: 'bsu-ui-multi-select-radio', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<fd-form-group [isInline]=\"!parameters?.IsVertically && !(isMobile && parameters?.OnlyInMobileVertically)\">\r\n @for (item of dataList; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n <fd-radio-button\r\n [value]=\"item.id\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\"\r\n [disabled]=\"(disableOrReadonly$ | async)!!\"\r\n (click)=\"onItemClicked(item)\"\r\n [ngModel]=\"value\"\r\n [selectedValue]=\"value\"\r\n >\r\n {{ item.txt }}\r\n </fd-radio-button>\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host{display:block;width:100%;height:100%}img[rtl=true]{margin-left:5px}img[rtl=false]{margin-right:5px}\n"] }]
34
+ args: [{ selector: 'bsu-ui-multi-select-radio', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<fd-form-group [isInline]=\"!parameters?.IsVertically && !(isMobile && parameters?.OnlyInMobileVertically)\">\r\n @for (item of dataList; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n <fd-radio-button\r\n [value]=\"item.id\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\"\r\n [class.control-disabled]=\"(disableOrReadonly$ | async) === true\"\r\n [disabled]=\"(disableOrReadonly$ | async) === true\"\r\n (click)=\"onItemClicked(item)\"\r\n [ngModel]=\"value\"\r\n [selectedValue]=\"value\"\r\n >\r\n {{ item.txt }}\r\n </fd-radio-button>\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host{display:block;width:100%;height:100%}img[rtl=true]{margin-left:5px}img[rtl=false]{margin-right:5px}\n"] }]
35
35
  }] });
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktbXVsdGktc2VsZWN0LXJhZGlvLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLXNhcC11aS9zcmMvbGliL3VpLW11bHRpLXNlbGVjdC1yYWRpby91aS1tdWx0aS1zZWxlY3QtcmFkaW8uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktbXVsdGktc2VsZWN0LXJhZGlvL3VpLW11bHRpLXNlbGVjdC1yYWRpby5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUN0RixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbkQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMERBQTBELENBQUM7Ozs7OztBQVN2RyxNQUFNLE9BQU8sMkJBQTRCLFNBQVEsMkJBQTJCO0lBUDVFOztRQVFJLGtCQUFhLEdBQWtDLEVBQUUsQ0FBQztRQUdsRCxPQUFFLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBZ0J2QjtJQWZHLFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFakIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsY0FBYyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUNELGVBQWU7UUFDWCxvQ0FBb0M7UUFDcEMsOEJBQThCO0lBQ2xDLENBQUM7SUFDRCxhQUFhLENBQUMsSUFBSTtRQUNkLElBQUksQ0FBQyxhQUFhLEdBQUcsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzlCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUNyQixJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztJQUM5QixDQUFDOytHQW5CUSwyQkFBMkI7bUdBQTNCLDJCQUEyQix3RkNYeEMsOHBCQWlCQTs7NEZETmEsMkJBQTJCO2tCQVB2QyxTQUFTOytCQUNJLDJCQUEyQixtQkFHcEIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgZ2V0VW5pcXVlSWQgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbmltcG9ydCB7IFVpTXVsdGlTZWxlY3RDb21ib0NvbXBvbmVudCB9IGZyb20gJy4uL3VpLW11bHRpLXNlbGVjdC1jb21iby91aS1tdWx0aS1zZWxlY3QtY29tYm8uY29tcG9uZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdic3UtdWktbXVsdGktc2VsZWN0LXJhZGlvJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi91aS1tdWx0aS1zZWxlY3QtcmFkaW8uY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vdWktbXVsdGktc2VsZWN0LXJhZGlvLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVaU11bHRpU2VsZWN0UmFkaW9Db21wb25lbnQgZXh0ZW5kcyBVaU11bHRpU2VsZWN0Q29tYm9Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XHJcbiAgICBzZWxlY3RlZEl0ZW1zOiB7IGlkOiBzdHJpbmc7IHR4dDogc3RyaW5nIH1bXSA9IFtdO1xyXG4gICAgbWF4V2lkdGg6IGFueTtcclxuICAgIGRhdGFMaXN0OiBhbnk7XHJcbiAgICBpZCA9IGdldFVuaXF1ZUlkKDQpO1xyXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcclxuXHJcbiAgICAgICAgdGhpcy5jb250ZXh0LmZpcmVFdmVudCgnVHJpZ2dlckNsaWNrJywgdGhpcy5jb250ZXh0LCAnJyk7XHJcbiAgICB9XHJcbiAgICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XHJcbiAgICAgICAgLy8gb3ZlcnJpZWRlIHBhcmVudCB0byBhdm9pZCBkbyBtb3JlXHJcbiAgICAgICAgLy8gc3VwZXIubmdBZnRlckNvbnRlbnRJbml0KCk7XHJcbiAgICB9XHJcbiAgICBvbkl0ZW1DbGlja2VkKGl0ZW0pOiB2b2lkIHtcclxuICAgICAgICB0aGlzLnNlbGVjdGVkSXRlbXMgPSBbXTtcclxuICAgICAgICB0aGlzLnNlbGVjdGVkSXRlbXMucHVzaChpdGVtKTtcclxuICAgICAgICB0aGlzLnZhbHVlID0gaXRlbS5pZDtcclxuICAgICAgICB0aGlzLl9yYWlzZVZhbHVlQ2hhbmdlZCgpO1xyXG4gICAgfVxyXG59XHJcbiIsIjxmZC1mb3JtLWdyb3VwIFtpc0lubGluZV09XCIhcGFyYW1ldGVycz8uSXNWZXJ0aWNhbGx5ICYmICEoaXNNb2JpbGUgJiYgcGFyYW1ldGVycz8uT25seUluTW9iaWxlVmVydGljYWxseSlcIj5cclxuICAgIEBmb3IgKGl0ZW0gb2YgZGF0YUxpc3Q7IHRyYWNrIGl0ZW07IGxldCBpID0gJGluZGV4OyBsZXQgZmlyc3QgPSAkZmlyc3QpIHtcclxuICAgIDxkaXYgZmQtZm9ybS1pdGVtPlxyXG4gICAgICAgIDxmZC1yYWRpby1idXR0b25cclxuICAgICAgICAgICAgW3ZhbHVlXT1cIml0ZW0uaWRcIlxyXG4gICAgICAgICAgICBbaWRdPVwiJ3JhZGlvLScgKyBpZCArIGlcIlxyXG4gICAgICAgICAgICBbbmFtZV09XCIncmFkaW8nICsgaWQgKyBpXCJcclxuICAgICAgICAgICAgW2Rpc2FibGVkXT1cIihkaXNhYmxlT3JSZWFkb25seSQgfCBhc3luYykhIVwiXHJcbiAgICAgICAgICAgIChjbGljayk9XCJvbkl0ZW1DbGlja2VkKGl0ZW0pXCJcclxuICAgICAgICAgICAgW25nTW9kZWxdPVwidmFsdWVcIlxyXG4gICAgICAgICAgICBbc2VsZWN0ZWRWYWx1ZV09XCJ2YWx1ZVwiXHJcbiAgICAgICAgPlxyXG4gICAgICAgICAgICB7eyBpdGVtLnR4dCB9fVxyXG4gICAgICAgIDwvZmQtcmFkaW8tYnV0dG9uPlxyXG4gICAgPC9kaXY+XHJcbiAgICB9XHJcbjwvZmQtZm9ybS1ncm91cD5cclxuIl19
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktbXVsdGktc2VsZWN0LXJhZGlvLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLXNhcC11aS9zcmMvbGliL3VpLW11bHRpLXNlbGVjdC1yYWRpby91aS1tdWx0aS1zZWxlY3QtcmFkaW8uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktbXVsdGktc2VsZWN0LXJhZGlvL3VpLW11bHRpLXNlbGVjdC1yYWRpby5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUN0RixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbkQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMERBQTBELENBQUM7Ozs7OztBQVN2RyxNQUFNLE9BQU8sMkJBQTRCLFNBQVEsMkJBQTJCO0lBUDVFOztRQVFJLGtCQUFhLEdBQWtDLEVBQUUsQ0FBQztRQUdsRCxPQUFFLEdBQUcsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDO0tBZ0J2QjtJQWZHLFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFakIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsY0FBYyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUNELGVBQWU7UUFDWCxvQ0FBb0M7UUFDcEMsOEJBQThCO0lBQ2xDLENBQUM7SUFDRCxhQUFhLENBQUMsSUFBSTtRQUNkLElBQUksQ0FBQyxhQUFhLEdBQUcsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzlCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUNyQixJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztJQUM5QixDQUFDOytHQW5CUSwyQkFBMkI7bUdBQTNCLDJCQUEyQix3RkNYeEMsdXZCQWtCQTs7NEZEUGEsMkJBQTJCO2tCQVB2QyxTQUFTOytCQUNJLDJCQUEyQixtQkFHcEIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgZ2V0VW5pcXVlSWQgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbmltcG9ydCB7IFVpTXVsdGlTZWxlY3RDb21ib0NvbXBvbmVudCB9IGZyb20gJy4uL3VpLW11bHRpLXNlbGVjdC1jb21iby91aS1tdWx0aS1zZWxlY3QtY29tYm8uY29tcG9uZW50JztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdic3UtdWktbXVsdGktc2VsZWN0LXJhZGlvJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi91aS1tdWx0aS1zZWxlY3QtcmFkaW8uY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vdWktbXVsdGktc2VsZWN0LXJhZGlvLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVaU11bHRpU2VsZWN0UmFkaW9Db21wb25lbnQgZXh0ZW5kcyBVaU11bHRpU2VsZWN0Q29tYm9Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XHJcbiAgICBzZWxlY3RlZEl0ZW1zOiB7IGlkOiBzdHJpbmc7IHR4dDogc3RyaW5nIH1bXSA9IFtdO1xyXG4gICAgbWF4V2lkdGg6IGFueTtcclxuICAgIGRhdGFMaXN0OiBhbnk7XHJcbiAgICBpZCA9IGdldFVuaXF1ZUlkKDQpO1xyXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcclxuXHJcbiAgICAgICAgdGhpcy5jb250ZXh0LmZpcmVFdmVudCgnVHJpZ2dlckNsaWNrJywgdGhpcy5jb250ZXh0LCAnJyk7XHJcbiAgICB9XHJcbiAgICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XHJcbiAgICAgICAgLy8gb3ZlcnJpZWRlIHBhcmVudCB0byBhdm9pZCBkbyBtb3JlXHJcbiAgICAgICAgLy8gc3VwZXIubmdBZnRlckNvbnRlbnRJbml0KCk7XHJcbiAgICB9XHJcbiAgICBvbkl0ZW1DbGlja2VkKGl0ZW0pOiB2b2lkIHtcclxuICAgICAgICB0aGlzLnNlbGVjdGVkSXRlbXMgPSBbXTtcclxuICAgICAgICB0aGlzLnNlbGVjdGVkSXRlbXMucHVzaChpdGVtKTtcclxuICAgICAgICB0aGlzLnZhbHVlID0gaXRlbS5pZDtcclxuICAgICAgICB0aGlzLl9yYWlzZVZhbHVlQ2hhbmdlZCgpO1xyXG4gICAgfVxyXG59XHJcbiIsIjxmZC1mb3JtLWdyb3VwIFtpc0lubGluZV09XCIhcGFyYW1ldGVycz8uSXNWZXJ0aWNhbGx5ICYmICEoaXNNb2JpbGUgJiYgcGFyYW1ldGVycz8uT25seUluTW9iaWxlVmVydGljYWxseSlcIj5cclxuICAgIEBmb3IgKGl0ZW0gb2YgZGF0YUxpc3Q7IHRyYWNrIGl0ZW07IGxldCBpID0gJGluZGV4OyBsZXQgZmlyc3QgPSAkZmlyc3QpIHtcclxuICAgIDxkaXYgZmQtZm9ybS1pdGVtPlxyXG4gICAgICAgIDxmZC1yYWRpby1idXR0b25cclxuICAgICAgICAgICAgW3ZhbHVlXT1cIml0ZW0uaWRcIlxyXG4gICAgICAgICAgICBbaWRdPVwiJ3JhZGlvLScgKyBpZCArIGlcIlxyXG4gICAgICAgICAgICBbbmFtZV09XCIncmFkaW8nICsgaWQgKyBpXCJcclxuICAgICAgICAgICAgW2NsYXNzLmNvbnRyb2wtZGlzYWJsZWRdPVwiKGRpc2FibGVPclJlYWRvbmx5JCB8IGFzeW5jKSA9PT0gdHJ1ZVwiXHJcbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCIoZGlzYWJsZU9yUmVhZG9ubHkkIHwgYXN5bmMpID09PSB0cnVlXCJcclxuICAgICAgICAgICAgKGNsaWNrKT1cIm9uSXRlbUNsaWNrZWQoaXRlbSlcIlxyXG4gICAgICAgICAgICBbbmdNb2RlbF09XCJ2YWx1ZVwiXHJcbiAgICAgICAgICAgIFtzZWxlY3RlZFZhbHVlXT1cInZhbHVlXCJcclxuICAgICAgICA+XHJcbiAgICAgICAgICAgIHt7IGl0ZW0udHh0IH19XHJcbiAgICAgICAgPC9mZC1yYWRpby1idXR0b24+XHJcbiAgICA8L2Rpdj5cclxuICAgIH1cclxuPC9mZC1mb3JtLWdyb3VwPlxyXG4iXX0=
@@ -40,8 +40,10 @@ export class UiPictureFileComponent extends FieldBaseComponent {
40
40
  this.context.un('DisplayImage', this._displayImage);
41
41
  }
42
42
  onFileSelection(files) {
43
- this.filesValidationHelper.validateFiles(files);
44
- this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();
43
+ const isValid = this.filesValidationHelper.validateFiles(files);
44
+ if (isValid) {
45
+ this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();
46
+ }
45
47
  }
46
48
  onFileDeleted(uploaderComponent) {
47
49
  uploaderComponent.inputRef.nativeElement.value = '';
@@ -98,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
98
100
  }], sizeMode: [{
99
101
  type: Input
100
102
  }] } });
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-picture-file.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-picture-file/ui-picture-file.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-picture-file/ui-picture-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, HostBinding, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { FileUploaderComponent } from '@fundamental-ngx/core';\r\n\r\nimport {\r\n    FieldBaseComponent,\r\n    BarsaApi,\r\n    UploadService,\r\n    getValidExtension,\r\n    FilesValidationHelper,\r\n    ImageMimeType,\r\n    IUploadingState\r\n} from 'barsa-novin-ray-core';\r\n\r\nimport { Observable, of } from 'rxjs';\r\nimport { concatMap, exhaustMap, takeUntil, tap } from 'rxjs/operators';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-picture-file',\r\n    templateUrl: './ui-picture-file.component.html',\r\n    styleUrls: ['./ui-picture-file.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [UploadService],\r\n    standalone: false\r\n})\r\nexport class UiPictureFileComponent extends FieldBaseComponent implements OnInit, OnDestroy {\r\n    @HostBinding('class.editable') _editable = true;\r\n    @Input() imageUrl: any;\r\n    @Input() sizeMode: any;\r\n    files: File[] = [];\r\n    uploadingState$: Observable<IUploadingState>;\r\n    validExtensions: any;\r\n    filesValidationHelper: FilesValidationHelper;\r\n    layoutHeight: string;\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        if (this.Setting?.IsReadOnly === true) {\r\n            this._editable = false;\r\n        }\r\n        this.uploadingState$ = this._uploadService.uploadingState$;\r\n        this.context.on({\r\n            DispalyImage: this._displayImage.bind(this)\r\n        });\r\n        const x = 45;\r\n        const layoutHeight = +BarsaApi.Common.Util.TryGetValue(this.layoutInfo, 'ControlBounds.height', x);\r\n        this.layoutHeight = layoutHeight < x ? 'cacl(var(--sapElement_Height) +10px)' : `${layoutHeight}px`;\r\n        this.imageUrl = this.context.imageUrl;\r\n        this.value = this.context._value;\r\n        this.validExtensions = getValidExtension(this.Setting.ValidExtensions) || ImageMimeType;\r\n        this.filesValidationHelper = new FilesValidationHelper(\r\n            1,\r\n            this.Setting.MaxFileSizeKb,\r\n            this.Setting.MaxFileSizeKb\r\n        );\r\n    }\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.context.un('DisplayImage', this._displayImage);\r\n    }\r\n    onFileSelection(files: File[]): void {\r\n        this.filesValidationHelper.validateFiles(files);\r\n        this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();\r\n    }\r\n    onFileDeleted(uploaderComponent: FileUploaderComponent): void {\r\n        uploaderComponent.inputRef.nativeElement.value = '';\r\n        this.value = null;\r\n        this.fireContextEvent('Change', this.context, null);\r\n    }\r\n\r\n    onDownloadFile(): void {\r\n        BarsaApi.Common.File.OpenFile(this.value.FileId, false, this, true, false);\r\n    }\r\n\r\n    onRetry(): void {\r\n        this._upload(this.files);\r\n    }\r\n\r\n    onTerminate(): void {\r\n        this._uploadService.cancelation$.next();\r\n        this._cdr.detectChanges();\r\n    }\r\n    private _displayImage(imageUrl, sizeMode, value): void {\r\n        this.imageUrl = imageUrl;\r\n        this.value = value;\r\n        this.sizeMode = sizeMode;\r\n    }\r\n\r\n    private _upload(files: File[]): void {\r\n        of(true)\r\n            .pipe(\r\n                takeUntil(this._onDestroy$),\r\n                exhaustMap(() => this.uploadFile(files))\r\n            )\r\n            .subscribe();\r\n    }\r\n\r\n    private uploadFile(files: File[]): Observable<any> {\r\n        return this._uploadService.compressFiles$(files).pipe(\r\n            concatMap((formData: FormData) =>\r\n                this._uploadService.upload(formData, this.Setting.ControlFieldDefId).pipe(\r\n                    tap((res) => {\r\n                        if (Array.isArray(res)) {\r\n                            const picture = res[0];\r\n                            if (picture.ErrorMsg) {\r\n                                BarsaApi.Bw.Msg.Error(picture.ErrorMsg);\r\n                                return;\r\n                            }\r\n                            const value = {\r\n                                ...picture,\r\n                                FileId: picture.FileId\r\n                            };\r\n                            this.fireContextEvent('Change', this.context, value);\r\n                        }\r\n                    })\r\n                )\r\n            )\r\n        );\r\n    }\r\n}\r\n","<div\r\n    [style.max-height]=\"Setting.SizeMode === '2' ? null : layoutHeight\"\r\n    [class.no-inlineEdit]=\"!inlineEdit\"\r\n    [style.min-height.px]=\"!value && !inlineEdit ? null : 140\"\r\n    [class.inlineEdit]=\"inlineEdit\"\r\n>\r\n    @if (!((disableOrReadonly$ | async) === true || Setting.IsReadOnly === true)) {\r\n    <div>\r\n        <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"value && imageUrl ? false : true\">\r\n            <fd-file-uploader\r\n                #uploader\r\n                fd-toolbar-item\r\n                [style.display]=\"'none'\"\r\n                [id]=\"id\"\r\n                [name]=\"'uploader_' + id\"\r\n                [placeholder]=\"'AttachPicture' | bbbTranslate\"\r\n                [buttonLabel]=\"'AttachPicture' | bbbTranslate\"\r\n                [buttonAriaLabel]=\"'AttachPicture' | bbbTranslate\"\r\n                [accept]=\"validExtensions\"\r\n                [(ngModel)]=\"files\"\r\n                [multiple]=\"false\"\r\n                (selectedFilesChanged)=\"onFileSelection($event)\"\r\n            ></fd-file-uploader>\r\n            @if(value && !value?.IsDeleted){\r\n            <button\r\n                fd-button\r\n                fd-toolbar-item\r\n                glyph=\"print\"\r\n                fdType=\"transparent\"\r\n                printFiles\r\n                [files]=\"[{ Id: '0', IsNew: true, IsDeleted: false, Type: 'image', mediaUrl: imageUrl }]\"\r\n            ></button>\r\n            }\r\n            <button\r\n                class=\"delete\"\r\n                fd-button\r\n                fd-toolbar-item\r\n                [disabled]=\"!this.value || value?.IsDeleted\"\r\n                glyph=\"delete\"\r\n                [fdType]=\"'transparent'\"\r\n                (click)=\"onFileDeleted(uploader)\"\r\n            ></button>\r\n            <button\r\n                fd-toolbar-item\r\n                fd-button\r\n                [disabled]=\"this.value && value?.IsDeleted !== true\"\r\n                glyph=\"attachment\"\r\n                [fdType]=\"'transparent'\"\r\n                (click)=\"uploader.open()\"\r\n            ></button>\r\n            <ng-container\r\n                *ngTemplateOutlet=\"\r\n                    loadingTpl;\r\n                    context: {\r\n                        uploadingState: uploadingState$ | async\r\n                    }\r\n                \"\r\n            >\r\n            </ng-container>\r\n        </fd-toolbar>\r\n    </div>\r\n    } @if (!inlineEdit) {\r\n    <div\r\n        [style.max-height.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.height : null\"\r\n        [style.max-width.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.width : null\"\r\n        [class.centerImage]=\"Setting.SizeMode === '3'\"\r\n    >\r\n        @if (value && imageUrl) {\r\n        <bsu-mask [top]=\"'0px'\"></bsu-mask>\r\n        } @if ((value && imageUrl) || Setting.HasDefaultPicture) {\r\n        <img\r\n            imgLazy\r\n            [imgLazy]=\"imageUrl\"\r\n            [src]=\"imageUrl\"\r\n            [ngClass]=\"Setting.SizeMode === '1' ? 'cover' : 'contain'\"\r\n            [style.height.px]=\"Setting.SizeMode !== '2' ? layoutInfo.ControlBounds.height : null\"\r\n        />\r\n        }\r\n    </div>\r\n    } @else {\r\n    <fd-avatar [size]=\"'m'\" [image]=\"imageUrl\"></fd-avatar>\r\n    }\r\n</div>\r\n<ng-template #loadingTpl let-uploadingState=\"uploadingState\">\r\n    @if (uploadingState && uploadingState.state !== 'Complete' && uploadingState.uploading) {\r\n    <fd-slider\r\n        [(ngModel)]=\"uploadingState.progress\"\r\n        [name]=\"'slider_' + id\"\r\n        fd-toolbar-item\r\n        [id]=\"id + '1'\"\r\n        [min]=\"0\"\r\n        [max]=\"100\"\r\n        [step]=\"1\"\r\n    >\r\n    </fd-slider>\r\n    @if (uploadingState.state === 'Uploading') {\r\n    <button fd-toolbar-item fd-button glyph=\"stop\" fdType=\"transparent\" (click)=\"onTerminate()\"></button>\r\n    } @if (uploadingState.state === 'Error') {\r\n    <button fd-toolbar-item fd-button glyph=\"refresh\" [fdType]=\"'transparent'\" (click)=\"onRetry()\"></button>\r\n    } }\r\n</ng-template>\r\n"]}
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-picture-file.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-picture-file/ui-picture-file.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-picture-file/ui-picture-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, HostBinding, Input, OnDestroy, OnInit } from '@angular/core';\r\nimport { FileUploaderComponent } from '@fundamental-ngx/core';\r\n\r\nimport {\r\n    FieldBaseComponent,\r\n    BarsaApi,\r\n    UploadService,\r\n    getValidExtension,\r\n    FilesValidationHelper,\r\n    ImageMimeType,\r\n    IUploadingState\r\n} from 'barsa-novin-ray-core';\r\n\r\nimport { Observable, of } from 'rxjs';\r\nimport { concatMap, exhaustMap, takeUntil, tap } from 'rxjs/operators';\r\n\r\n@Component({\r\n    selector: 'bsu-ui-picture-file',\r\n    templateUrl: './ui-picture-file.component.html',\r\n    styleUrls: ['./ui-picture-file.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [UploadService],\r\n    standalone: false\r\n})\r\nexport class UiPictureFileComponent extends FieldBaseComponent implements OnInit, OnDestroy {\r\n    @HostBinding('class.editable') _editable = true;\r\n    @Input() imageUrl: any;\r\n    @Input() sizeMode: any;\r\n    files: File[] = [];\r\n    uploadingState$: Observable<IUploadingState>;\r\n    validExtensions: any;\r\n    filesValidationHelper: FilesValidationHelper;\r\n    layoutHeight: string;\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        if (this.Setting?.IsReadOnly === true) {\r\n            this._editable = false;\r\n        }\r\n        this.uploadingState$ = this._uploadService.uploadingState$;\r\n        this.context.on({\r\n            DispalyImage: this._displayImage.bind(this)\r\n        });\r\n        const x = 45;\r\n        const layoutHeight = +BarsaApi.Common.Util.TryGetValue(this.layoutInfo, 'ControlBounds.height', x);\r\n        this.layoutHeight = layoutHeight < x ? 'cacl(var(--sapElement_Height) +10px)' : `${layoutHeight}px`;\r\n        this.imageUrl = this.context.imageUrl;\r\n        this.value = this.context._value;\r\n        this.validExtensions = getValidExtension(this.Setting.ValidExtensions) || ImageMimeType;\r\n        this.filesValidationHelper = new FilesValidationHelper(\r\n            1,\r\n            this.Setting.MaxFileSizeKb,\r\n            this.Setting.MaxFileSizeKb\r\n        );\r\n    }\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.context.un('DisplayImage', this._displayImage);\r\n    }\r\n    onFileSelection(files: File[]): void {\r\n        const isValid = this.filesValidationHelper.validateFiles(files);\r\n        if (isValid) {\r\n            this.uploadFile(files).pipe(takeUntil(this._onDestroy$)).subscribe();\r\n        }\r\n    }\r\n    onFileDeleted(uploaderComponent: FileUploaderComponent): void {\r\n        uploaderComponent.inputRef.nativeElement.value = '';\r\n        this.value = null;\r\n        this.fireContextEvent('Change', this.context, null);\r\n    }\r\n\r\n    onDownloadFile(): void {\r\n        BarsaApi.Common.File.OpenFile(this.value.FileId, false, this, true, false);\r\n    }\r\n\r\n    onRetry(): void {\r\n        this._upload(this.files);\r\n    }\r\n\r\n    onTerminate(): void {\r\n        this._uploadService.cancelation$.next();\r\n        this._cdr.detectChanges();\r\n    }\r\n    private _displayImage(imageUrl, sizeMode, value): void {\r\n        this.imageUrl = imageUrl;\r\n        this.value = value;\r\n        this.sizeMode = sizeMode;\r\n    }\r\n\r\n    private _upload(files: File[]): void {\r\n        of(true)\r\n            .pipe(\r\n                takeUntil(this._onDestroy$),\r\n                exhaustMap(() => this.uploadFile(files))\r\n            )\r\n            .subscribe();\r\n    }\r\n\r\n    private uploadFile(files: File[]): Observable<any> {\r\n        return this._uploadService.compressFiles$(files).pipe(\r\n            concatMap((formData: FormData) =>\r\n                this._uploadService.upload(formData, this.Setting.ControlFieldDefId).pipe(\r\n                    tap((res) => {\r\n                        if (Array.isArray(res)) {\r\n                            const picture = res[0];\r\n                            if (picture.ErrorMsg) {\r\n                                BarsaApi.Bw.Msg.Error(picture.ErrorMsg);\r\n                                return;\r\n                            }\r\n                            const value = {\r\n                                ...picture,\r\n                                FileId: picture.FileId\r\n                            };\r\n                            this.fireContextEvent('Change', this.context, value);\r\n                        }\r\n                    })\r\n                )\r\n            )\r\n        );\r\n    }\r\n}\r\n","<div\r\n    [style.max-height]=\"Setting.SizeMode === '2' ? null : layoutHeight\"\r\n    [class.no-inlineEdit]=\"!inlineEdit\"\r\n    [style.min-height.px]=\"!value && !inlineEdit ? null : 140\"\r\n    [class.inlineEdit]=\"inlineEdit\"\r\n>\r\n    @if (!((disableOrReadonly$ | async) === true || Setting.IsReadOnly === true)) {\r\n    <div>\r\n        <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"value && imageUrl ? false : true\">\r\n            <fd-file-uploader\r\n                #uploader\r\n                fd-toolbar-item\r\n                [style.display]=\"'none'\"\r\n                [id]=\"id\"\r\n                [name]=\"'uploader_' + id\"\r\n                [placeholder]=\"'AttachPicture' | bbbTranslate\"\r\n                [buttonLabel]=\"'AttachPicture' | bbbTranslate\"\r\n                [buttonAriaLabel]=\"'AttachPicture' | bbbTranslate\"\r\n                [accept]=\"validExtensions\"\r\n                [(ngModel)]=\"files\"\r\n                [multiple]=\"false\"\r\n                (selectedFilesChanged)=\"onFileSelection($event)\"\r\n            ></fd-file-uploader>\r\n            @if(value && !value?.IsDeleted){\r\n            <button\r\n                fd-button\r\n                fd-toolbar-item\r\n                glyph=\"print\"\r\n                fdType=\"transparent\"\r\n                printFiles\r\n                [files]=\"[{ Id: '0', IsNew: true, IsDeleted: false, Type: 'image', mediaUrl: imageUrl }]\"\r\n            ></button>\r\n            }\r\n            <button\r\n                class=\"delete\"\r\n                fd-button\r\n                fd-toolbar-item\r\n                [disabled]=\"!this.value || value?.IsDeleted\"\r\n                glyph=\"delete\"\r\n                [fdType]=\"'transparent'\"\r\n                (click)=\"onFileDeleted(uploader)\"\r\n            ></button>\r\n            <button\r\n                fd-toolbar-item\r\n                fd-button\r\n                [disabled]=\"this.value && value?.IsDeleted !== true\"\r\n                glyph=\"attachment\"\r\n                [fdType]=\"'transparent'\"\r\n                (click)=\"uploader.open()\"\r\n            ></button>\r\n            <ng-container\r\n                *ngTemplateOutlet=\"\r\n                    loadingTpl;\r\n                    context: {\r\n                        uploadingState: uploadingState$ | async\r\n                    }\r\n                \"\r\n            >\r\n            </ng-container>\r\n        </fd-toolbar>\r\n    </div>\r\n    } @if (!inlineEdit) {\r\n    <div\r\n        [style.max-height.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.height : null\"\r\n        [style.max-width.px]=\"Setting.SizeMode === '0' ? layoutInfo.ControlBounds.width : null\"\r\n        [class.centerImage]=\"Setting.SizeMode === '3'\"\r\n    >\r\n        @if (value && imageUrl) {\r\n        <bsu-mask [top]=\"'0px'\"></bsu-mask>\r\n        } @if ((value && imageUrl) || Setting.HasDefaultPicture) {\r\n        <img\r\n            imgLazy\r\n            [imgLazy]=\"imageUrl\"\r\n            [src]=\"imageUrl\"\r\n            [ngClass]=\"Setting.SizeMode === '1' ? 'cover' : 'contain'\"\r\n            [style.height.px]=\"Setting.SizeMode !== '2' ? layoutInfo.ControlBounds.height : null\"\r\n        />\r\n        }\r\n    </div>\r\n    } @else {\r\n    <fd-avatar [size]=\"'m'\" [image]=\"imageUrl\"></fd-avatar>\r\n    }\r\n</div>\r\n<ng-template #loadingTpl let-uploadingState=\"uploadingState\">\r\n    @if (uploadingState && uploadingState.state !== 'Complete' && uploadingState.uploading) {\r\n    <fd-slider\r\n        [(ngModel)]=\"uploadingState.progress\"\r\n        [name]=\"'slider_' + id\"\r\n        fd-toolbar-item\r\n        [id]=\"id + '1'\"\r\n        [min]=\"0\"\r\n        [max]=\"100\"\r\n        [step]=\"1\"\r\n    >\r\n    </fd-slider>\r\n    @if (uploadingState.state === 'Uploading') {\r\n    <button fd-toolbar-item fd-button glyph=\"stop\" fdType=\"transparent\" (click)=\"onTerminate()\"></button>\r\n    } @if (uploadingState.state === 'Error') {\r\n    <button fd-toolbar-item fd-button glyph=\"refresh\" [fdType]=\"'transparent'\" (click)=\"onRetry()\"></button>\r\n    } }\r\n</ng-template>\r\n"]}
@@ -39,10 +39,10 @@ export class UiRadioGroupComponent extends DeviceInfoFieldBaseComponent {
39
39
  super._setValue(val);
40
40
  }
41
41
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiRadioGroupComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
42
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: UiRadioGroupComponent, selector: "bsu-ui-radio-group", usesInheritance: true, ngImport: i0, template: "<fd-form-group [isInline]=\"!isVertically && !(isMobileDevice && onlyInMobileVertically)\">\r\n @for (item of context.items; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n @if (!item.IsEmpty) {\r\n <fd-radio-button\r\n [value]=\"item.inputValue\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\"\r\n [disabled]=\"(disableOrReadonly$ | async)!!\"\r\n [ngModel]=\"value?.inputValue\"\r\n (click)=\"onRadioClicked(item)\"\r\n [selectedValue]=\"value?.inputValue\"\r\n >\r\n {{ item.boxLabel }}\r\n </fd-radio-button>\r\n }\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host ::ng-deep span{-webkit-user-select:none;user-select:none}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.FormItemComponent, selector: "[fd-form-item]", inputs: ["isInline", "horizontal"] }, { kind: "component", type: i2.FormGroupComponent, selector: "fd-form-group", inputs: ["isInline"] }, { kind: "component", type: i3.RadioButtonComponent, selector: "fd-radio-button", inputs: ["ariaLabel", "ariaLabelledBy", "ariaDescribedBy", "title", "tabIndex", "state", "disabled", "selectedValue", "name", "id", "value", "required", "standalone"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: UiRadioGroupComponent, selector: "bsu-ui-radio-group", usesInheritance: true, ngImport: i0, template: "<fd-form-group [isInline]=\"!isVertically && !(isMobileDevice && onlyInMobileVertically)\">\r\n @for (item of context.items; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n @if (!item.IsEmpty) {\r\n <fd-radio-button\r\n [value]=\"item.inputValue\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\"\r\n [class.control-disabled]=\"(disableOrReadonly$ | async) === true\"\r\n [disabled]=\"(disableOrReadonly$ | async) === true\"\r\n [ngModel]=\"value?.inputValue\"\r\n (click)=\"onRadioClicked(item)\"\r\n [selectedValue]=\"value?.inputValue\"\r\n >\r\n {{ item.boxLabel }}\r\n </fd-radio-button>\r\n }\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host ::ng-deep span{-webkit-user-select:none;user-select:none}:host .fd-form-item+.fd-form-item{-webkit-margin-before:0;margin-block-start:0}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.FormItemComponent, selector: "[fd-form-item]", inputs: ["isInline", "horizontal"] }, { kind: "component", type: i2.FormGroupComponent, selector: "fd-form-group", inputs: ["isInline"] }, { kind: "component", type: i3.RadioButtonComponent, selector: "fd-radio-button", inputs: ["ariaLabel", "ariaLabelledBy", "ariaDescribedBy", "title", "tabIndex", "state", "disabled", "selectedValue", "name", "id", "value", "required", "standalone"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
43
43
  }
44
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: UiRadioGroupComponent, decorators: [{
45
45
  type: Component,
46
- args: [{ selector: 'bsu-ui-radio-group', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<fd-form-group [isInline]=\"!isVertically && !(isMobileDevice && onlyInMobileVertically)\">\r\n @for (item of context.items; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n @if (!item.IsEmpty) {\r\n <fd-radio-button\r\n [value]=\"item.inputValue\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\"\r\n [disabled]=\"(disableOrReadonly$ | async)!!\"\r\n [ngModel]=\"value?.inputValue\"\r\n (click)=\"onRadioClicked(item)\"\r\n [selectedValue]=\"value?.inputValue\"\r\n >\r\n {{ item.boxLabel }}\r\n </fd-radio-button>\r\n }\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host ::ng-deep span{-webkit-user-select:none;user-select:none}\n"] }]
46
+ args: [{ selector: 'bsu-ui-radio-group', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<fd-form-group [isInline]=\"!isVertically && !(isMobileDevice && onlyInMobileVertically)\">\r\n @for (item of context.items; track item; let i = $index; let first = $first) {\r\n <div fd-form-item>\r\n @if (!item.IsEmpty) {\r\n <fd-radio-button\r\n [value]=\"item.inputValue\"\r\n [id]=\"'radio-' + id + i\"\r\n [name]=\"'radio' + id + i\"\r\n [class.control-disabled]=\"(disableOrReadonly$ | async) === true\"\r\n [disabled]=\"(disableOrReadonly$ | async) === true\"\r\n [ngModel]=\"value?.inputValue\"\r\n (click)=\"onRadioClicked(item)\"\r\n [selectedValue]=\"value?.inputValue\"\r\n >\r\n {{ item.boxLabel }}\r\n </fd-radio-button>\r\n }\r\n </div>\r\n }\r\n</fd-form-group>\r\n", styles: [":host ::ng-deep span{-webkit-user-select:none;user-select:none}:host .fd-form-item+.fd-form-item{-webkit-margin-before:0;margin-block-start:0}\n"] }]
47
47
  }] });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktcmFkaW8tZ3JvdXAvdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktcmFkaW8tZ3JvdXAvdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7Ozs7O0FBUXpFLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSw0QkFBNEI7SUFQdkU7O1FBUUksaUJBQVksR0FBRyxLQUFLLENBQUM7UUFDckIsMkJBQXNCLEdBQUcsS0FBSyxDQUFDO0tBNkJsQztJQTNCRyxJQUFJLEtBQUs7UUFDTCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDO0lBQzlCLENBQUM7SUFDRCxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUM7UUFDbkMsSUFBSSxPQUFPLElBQUksQ0FBQyxLQUFLLElBQUksUUFBUSxFQUFFLENBQUM7WUFDaEMsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2hGLENBQUM7YUFBTSxDQUFDO1lBQ0osSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDckUsQ0FBQztRQUNELElBQUksQ0FBQyxzQkFBc0IsR0FBRyxVQUFVLEVBQUUsc0JBQXNCLENBQUM7UUFDakUsSUFBSSxDQUFDLFlBQVksR0FBRyxVQUFVLEVBQUUsWUFBWSxDQUFDO0lBQ2pELENBQUM7SUFFRCxjQUFjLENBQUMsSUFBSTtRQUNmLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFDUyxTQUFTLENBQUMsS0FBVTtRQUMxQixJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzVDLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxLQUFLLEtBQUssQ0FBQyxDQUFDO1FBQzVELElBQUksSUFBSSxFQUFFLENBQUM7WUFDUCxHQUFHLEdBQUcsSUFBSSxDQUFDO1FBQ2YsQ0FBQztRQUNELEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDekIsQ0FBQzsrR0E5QlEscUJBQXFCO21HQUFyQixxQkFBcUIsaUZDVGxDLHF1QkFtQkE7OzRGRFZhLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDSSxvQkFBb0IsbUJBR2IsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERldmljZUluZm9GaWVsZEJhc2VDb21wb25lbnQgfSBmcm9tICcuLi9kZXZpY2UtaW5mby1maWVsZC1iYXNlJztcclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JzdS11aS1yYWRpby1ncm91cCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgc3RhbmRhbG9uZTogZmFsc2VcclxufSlcclxuZXhwb3J0IGNsYXNzIFVpUmFkaW9Hcm91cENvbXBvbmVudCBleHRlbmRzIERldmljZUluZm9GaWVsZEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gICAgaXNWZXJ0aWNhbGx5ID0gZmFsc2U7XHJcbiAgICBvbmx5SW5Nb2JpbGVWZXJ0aWNhbGx5ID0gZmFsc2U7XHJcbiAgICBzZWxlY3RlZEl0ZW06IEl0ZW1UeXBlO1xyXG4gICAgZ2V0IGl0ZW1zKCk6IEl0ZW1UeXBlW10ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLmNvbnRleHQuaXRlbXM7XHJcbiAgICB9XHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xyXG4gICAgICAgIGNvbnN0IHBhcmFtZXRlcnMgPSB0aGlzLnBhcmFtZXRlcnM7XHJcbiAgICAgICAgaWYgKHR5cGVvZiB0aGlzLnZhbHVlID09ICdvYmplY3QnKSB7XHJcbiAgICAgICAgICAgIHRoaXMudmFsdWUgPSB0aGlzLml0ZW1zLmZpbmQoKGMpID0+IGMuaW5wdXRWYWx1ZSA9PT0gdGhpcy52YWx1ZS5pbnB1dFZhbHVlKTtcclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICB0aGlzLnZhbHVlID0gdGhpcy5pdGVtcy5maW5kKChjKSA9PiBjLmlucHV0VmFsdWUgPT09IHRoaXMudmFsdWUpO1xyXG4gICAgICAgIH1cclxuICAgICAgICB0aGlzLm9ubHlJbk1vYmlsZVZlcnRpY2FsbHkgPSBwYXJhbWV0ZXJzPy5Pbmx5SW5Nb2JpbGVWZXJ0aWNhbGx5O1xyXG4gICAgICAgIHRoaXMuaXNWZXJ0aWNhbGx5ID0gcGFyYW1ldGVycz8uSXNWZXJ0aWNhbGx5O1xyXG4gICAgfVxyXG5cclxuICAgIG9uUmFkaW9DbGlja2VkKGl0ZW0pOiB2b2lkIHtcclxuICAgICAgICB0aGlzLnZhbHVlID0gaXRlbTtcclxuICAgICAgICB0aGlzLnZhbHVlQ2hhbmdlLmVtaXQoaXRlbSk7XHJcbiAgICB9XHJcbiAgICBwcm90ZWN0ZWQgX3NldFZhbHVlKHZhbHVlOiBhbnkpOiB2b2lkIHtcclxuICAgICAgICBsZXQgdmFsID0gdGhpcy5pdGVtcy5maW5kKChjKSA9PiBjLklzRW1wdHkpO1xyXG4gICAgICAgIGNvbnN0IGl0ZW0gPSB0aGlzLml0ZW1zLmZpbmQoKGMpID0+IGMuaW5wdXRWYWx1ZSA9PT0gdmFsdWUpO1xyXG4gICAgICAgIGlmIChpdGVtKSB7XHJcbiAgICAgICAgICAgIHZhbCA9IGl0ZW07XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHN1cGVyLl9zZXRWYWx1ZSh2YWwpO1xyXG4gICAgfVxyXG59XHJcbnR5cGUgSXRlbVR5cGUgPSB7XHJcbiAgICBba2V5OiBzdHJpbmddOiBhbnk7XHJcbiAgICBJc0VtcHR5OiBib29sZWFuO1xyXG4gICAgaW5wdXRWYWx1ZTogc3RyaW5nO1xyXG59O1xyXG4iLCI8ZmQtZm9ybS1ncm91cCBbaXNJbmxpbmVdPVwiIWlzVmVydGljYWxseSAmJiAhKGlzTW9iaWxlRGV2aWNlICYmIG9ubHlJbk1vYmlsZVZlcnRpY2FsbHkpXCI+XHJcbiAgICBAZm9yIChpdGVtIG9mIGNvbnRleHQuaXRlbXM7IHRyYWNrIGl0ZW07IGxldCBpID0gJGluZGV4OyBsZXQgZmlyc3QgPSAkZmlyc3QpIHtcclxuICAgIDxkaXYgZmQtZm9ybS1pdGVtPlxyXG4gICAgICAgIEBpZiAoIWl0ZW0uSXNFbXB0eSkge1xyXG4gICAgICAgIDxmZC1yYWRpby1idXR0b25cclxuICAgICAgICAgICAgW3ZhbHVlXT1cIml0ZW0uaW5wdXRWYWx1ZVwiXHJcbiAgICAgICAgICAgIFtpZF09XCIncmFkaW8tJyArIGlkICsgaVwiXHJcbiAgICAgICAgICAgIFtuYW1lXT1cIidyYWRpbycgKyBpZCArIGlcIlxyXG4gICAgICAgICAgICBbZGlzYWJsZWRdPVwiKGRpc2FibGVPclJlYWRvbmx5JCB8IGFzeW5jKSEhXCJcclxuICAgICAgICAgICAgW25nTW9kZWxdPVwidmFsdWU/LmlucHV0VmFsdWVcIlxyXG4gICAgICAgICAgICAoY2xpY2spPVwib25SYWRpb0NsaWNrZWQoaXRlbSlcIlxyXG4gICAgICAgICAgICBbc2VsZWN0ZWRWYWx1ZV09XCJ2YWx1ZT8uaW5wdXRWYWx1ZVwiXHJcbiAgICAgICAgPlxyXG4gICAgICAgICAgICB7eyBpdGVtLmJveExhYmVsIH19XHJcbiAgICAgICAgPC9mZC1yYWRpby1idXR0b24+XHJcbiAgICAgICAgfVxyXG4gICAgPC9kaXY+XHJcbiAgICB9XHJcbjwvZmQtZm9ybS1ncm91cD5cclxuIl19
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktcmFkaW8tZ3JvdXAvdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktcmFkaW8tZ3JvdXAvdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7Ozs7O0FBUXpFLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSw0QkFBNEI7SUFQdkU7O1FBUUksaUJBQVksR0FBRyxLQUFLLENBQUM7UUFDckIsMkJBQXNCLEdBQUcsS0FBSyxDQUFDO0tBNkJsQztJQTNCRyxJQUFJLEtBQUs7UUFDTCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDO0lBQzlCLENBQUM7SUFDRCxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUM7UUFDbkMsSUFBSSxPQUFPLElBQUksQ0FBQyxLQUFLLElBQUksUUFBUSxFQUFFLENBQUM7WUFDaEMsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ2hGLENBQUM7YUFBTSxDQUFDO1lBQ0osSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDckUsQ0FBQztRQUNELElBQUksQ0FBQyxzQkFBc0IsR0FBRyxVQUFVLEVBQUUsc0JBQXNCLENBQUM7UUFDakUsSUFBSSxDQUFDLFlBQVksR0FBRyxVQUFVLEVBQUUsWUFBWSxDQUFDO0lBQ2pELENBQUM7SUFFRCxjQUFjLENBQUMsSUFBSTtRQUNmLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFDUyxTQUFTLENBQUMsS0FBVTtRQUMxQixJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzVDLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxLQUFLLEtBQUssQ0FBQyxDQUFDO1FBQzVELElBQUksSUFBSSxFQUFFLENBQUM7WUFDUCxHQUFHLEdBQUcsSUFBSSxDQUFDO1FBQ2YsQ0FBQztRQUNELEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDekIsQ0FBQzsrR0E5QlEscUJBQXFCO21HQUFyQixxQkFBcUIsaUZDVGxDLDh6QkFvQkE7OzRGRFhhLHFCQUFxQjtrQkFQakMsU0FBUzsrQkFDSSxvQkFBb0IsbUJBR2IsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERldmljZUluZm9GaWVsZEJhc2VDb21wb25lbnQgfSBmcm9tICcuLi9kZXZpY2UtaW5mby1maWVsZC1iYXNlJztcclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JzdS11aS1yYWRpby1ncm91cCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgc3RhbmRhbG9uZTogZmFsc2VcclxufSlcclxuZXhwb3J0IGNsYXNzIFVpUmFkaW9Hcm91cENvbXBvbmVudCBleHRlbmRzIERldmljZUluZm9GaWVsZEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gICAgaXNWZXJ0aWNhbGx5ID0gZmFsc2U7XHJcbiAgICBvbmx5SW5Nb2JpbGVWZXJ0aWNhbGx5ID0gZmFsc2U7XHJcbiAgICBzZWxlY3RlZEl0ZW06IEl0ZW1UeXBlO1xyXG4gICAgZ2V0IGl0ZW1zKCk6IEl0ZW1UeXBlW10ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLmNvbnRleHQuaXRlbXM7XHJcbiAgICB9XHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xyXG4gICAgICAgIGNvbnN0IHBhcmFtZXRlcnMgPSB0aGlzLnBhcmFtZXRlcnM7XHJcbiAgICAgICAgaWYgKHR5cGVvZiB0aGlzLnZhbHVlID09ICdvYmplY3QnKSB7XHJcbiAgICAgICAgICAgIHRoaXMudmFsdWUgPSB0aGlzLml0ZW1zLmZpbmQoKGMpID0+IGMuaW5wdXRWYWx1ZSA9PT0gdGhpcy52YWx1ZS5pbnB1dFZhbHVlKTtcclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICB0aGlzLnZhbHVlID0gdGhpcy5pdGVtcy5maW5kKChjKSA9PiBjLmlucHV0VmFsdWUgPT09IHRoaXMudmFsdWUpO1xyXG4gICAgICAgIH1cclxuICAgICAgICB0aGlzLm9ubHlJbk1vYmlsZVZlcnRpY2FsbHkgPSBwYXJhbWV0ZXJzPy5Pbmx5SW5Nb2JpbGVWZXJ0aWNhbGx5O1xyXG4gICAgICAgIHRoaXMuaXNWZXJ0aWNhbGx5ID0gcGFyYW1ldGVycz8uSXNWZXJ0aWNhbGx5O1xyXG4gICAgfVxyXG5cclxuICAgIG9uUmFkaW9DbGlja2VkKGl0ZW0pOiB2b2lkIHtcclxuICAgICAgICB0aGlzLnZhbHVlID0gaXRlbTtcclxuICAgICAgICB0aGlzLnZhbHVlQ2hhbmdlLmVtaXQoaXRlbSk7XHJcbiAgICB9XHJcbiAgICBwcm90ZWN0ZWQgX3NldFZhbHVlKHZhbHVlOiBhbnkpOiB2b2lkIHtcclxuICAgICAgICBsZXQgdmFsID0gdGhpcy5pdGVtcy5maW5kKChjKSA9PiBjLklzRW1wdHkpO1xyXG4gICAgICAgIGNvbnN0IGl0ZW0gPSB0aGlzLml0ZW1zLmZpbmQoKGMpID0+IGMuaW5wdXRWYWx1ZSA9PT0gdmFsdWUpO1xyXG4gICAgICAgIGlmIChpdGVtKSB7XHJcbiAgICAgICAgICAgIHZhbCA9IGl0ZW07XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHN1cGVyLl9zZXRWYWx1ZSh2YWwpO1xyXG4gICAgfVxyXG59XHJcbnR5cGUgSXRlbVR5cGUgPSB7XHJcbiAgICBba2V5OiBzdHJpbmddOiBhbnk7XHJcbiAgICBJc0VtcHR5OiBib29sZWFuO1xyXG4gICAgaW5wdXRWYWx1ZTogc3RyaW5nO1xyXG59O1xyXG4iLCI8ZmQtZm9ybS1ncm91cCBbaXNJbmxpbmVdPVwiIWlzVmVydGljYWxseSAmJiAhKGlzTW9iaWxlRGV2aWNlICYmIG9ubHlJbk1vYmlsZVZlcnRpY2FsbHkpXCI+XHJcbiAgICBAZm9yIChpdGVtIG9mIGNvbnRleHQuaXRlbXM7IHRyYWNrIGl0ZW07IGxldCBpID0gJGluZGV4OyBsZXQgZmlyc3QgPSAkZmlyc3QpIHtcclxuICAgIDxkaXYgZmQtZm9ybS1pdGVtPlxyXG4gICAgICAgIEBpZiAoIWl0ZW0uSXNFbXB0eSkge1xyXG4gICAgICAgIDxmZC1yYWRpby1idXR0b25cclxuICAgICAgICAgICAgW3ZhbHVlXT1cIml0ZW0uaW5wdXRWYWx1ZVwiXHJcbiAgICAgICAgICAgIFtpZF09XCIncmFkaW8tJyArIGlkICsgaVwiXHJcbiAgICAgICAgICAgIFtuYW1lXT1cIidyYWRpbycgKyBpZCArIGlcIlxyXG4gICAgICAgICAgICBbY2xhc3MuY29udHJvbC1kaXNhYmxlZF09XCIoZGlzYWJsZU9yUmVhZG9ubHkkIHwgYXN5bmMpID09PSB0cnVlXCJcclxuICAgICAgICAgICAgW2Rpc2FibGVkXT1cIihkaXNhYmxlT3JSZWFkb25seSQgfCBhc3luYykgPT09IHRydWVcIlxyXG4gICAgICAgICAgICBbbmdNb2RlbF09XCJ2YWx1ZT8uaW5wdXRWYWx1ZVwiXHJcbiAgICAgICAgICAgIChjbGljayk9XCJvblJhZGlvQ2xpY2tlZChpdGVtKVwiXHJcbiAgICAgICAgICAgIFtzZWxlY3RlZFZhbHVlXT1cInZhbHVlPy5pbnB1dFZhbHVlXCJcclxuICAgICAgICA+XHJcbiAgICAgICAgICAgIHt7IGl0ZW0uYm94TGFiZWwgfX1cclxuICAgICAgICA8L2ZkLXJhZGlvLWJ1dHRvbj5cclxuICAgICAgICB9XHJcbiAgICA8L2Rpdj5cclxuICAgIH1cclxuPC9mZC1mb3JtLWdyb3VwPlxyXG4iXX0=