barsa-sap-ui 1.0.359 → 1.0.361
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/barsa-card-layout-panel/barsa-card-layout-panel.component.mjs +18 -0
- package/esm2020/lib/barsa-enum-menu-button/barsa-enum-menu-button.component.mjs +61 -0
- package/esm2020/lib/barsa-linkable-items-panel/barsa-linkable-items-panel.component.mjs +44 -0
- package/esm2020/lib/barsa-list-file-linear/barsa-list-file-linear.component.mjs +26 -13
- package/esm2020/lib/barsa-list-file-linear-gmail/barsa-list-file-linear-gmail.component.mjs +29 -0
- package/esm2020/lib/barsa-sap-ui.module.mjs +21 -17
- package/esm2020/lib/barsa-tinyemce/barsa-tinyemce.component.mjs +19 -3
- package/esm2020/lib/index.mjs +10 -2
- package/esm2020/lib/layout-control/layout-control.component.mjs +5 -4
- package/esm2020/lib/ly-label/ly-label.component.mjs +3 -3
- package/esm2020/lib/report-view-renderer.directive.mjs +11 -2
- package/esm2020/lib/ui-date-time/ui-date-time.component.mjs +3 -3
- package/esm2020/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.mjs +4 -3
- package/esm2020/lib/ui-grid/ui-grid.component.mjs +3 -3
- package/esm2020/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.mjs +3 -3
- package/esm2020/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.mjs +3 -3
- package/esm2020/lib/ui-report-container/ui-report-container.component.mjs +3 -3
- package/esm2020/lib/ui-simple-combo/ui-simple-combo.component.mjs +3 -3
- package/esm2020/lib/ui-tinymce/ui-tinymce.component.mjs +3 -3
- package/esm2020/public-api.mjs +5 -1
- package/fesm2015/barsa-sap-ui.mjs +313 -154
- package/fesm2015/barsa-sap-ui.mjs.map +1 -1
- package/fesm2020/barsa-sap-ui.mjs +311 -154
- package/fesm2020/barsa-sap-ui.mjs.map +1 -1
- package/lib/barsa-card-layout-panel/barsa-card-layout-panel.component.d.ts +8 -0
- package/lib/barsa-enum-menu-button/barsa-enum-menu-button.component.d.ts +23 -0
- package/lib/barsa-linkable-items-panel/barsa-linkable-items-panel.component.d.ts +13 -0
- package/lib/barsa-list-file-linear/barsa-list-file-linear.component.d.ts +9 -0
- package/lib/barsa-list-file-linear-gmail/barsa-list-file-linear-gmail.component.d.ts +8 -0
- package/lib/barsa-sap-ui.module.d.ts +31 -27
- package/lib/barsa-tinyemce/barsa-tinyemce.component.d.ts +4 -3
- package/lib/index.d.ts +2 -2
- package/lib/report-view-renderer.directive.d.ts +4 -1
- package/lib/ui-date-time/ui-date-time.component.d.ts +7 -0
- package/lib/ui-file-linear-list-box/ui-file-linear-list-box.component.d.ts +2 -0
- package/lib/ui-tinymce/ui-tinymce.component.d.ts +6 -1
- package/package.json +1 -1
- package/public-api.d.ts +4 -0
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { LayoutPanelBaseComponent, LayoutService } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "barsa-novin-ray-core";
|
|
6
|
+
import * as i3 from "@fundamental-ngx/core/card";
|
|
7
|
+
export class BarsaCardLayoutPanelComponent extends LayoutPanelBaseComponent {
|
|
8
|
+
ngOnInit() {
|
|
9
|
+
super.ngOnInit();
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
BarsaCardLayoutPanelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaCardLayoutPanelComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
13
|
+
BarsaCardLayoutPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaCardLayoutPanelComponent, selector: "bsu-barsa-card-layout-panel", providers: [LayoutService], usesInheritance: true, ngImport: i0, template: "<fd-card>\n <fd-card-header>\n {{ (config.TextVisible ? config.Title ?? '' : '') | bbbTranslate }}\n </fd-card-header>\n <fd-card-content>\n <ng-container *ngFor=\"let item of config | filterToolbarControl\">\n <ng-container [ngSwitch]=\"item.xtype\">\n <ng-container *ngSwitchCase=\"'Ly.LayoutTabPanel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n name: 'LyLayoutPanelComponent',\n selector: 'bsu-ly-tab-container'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-tab-container [config]=\"item\"></bsu-ly-tab-container> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutPanel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n name: 'LyLayoutPanelComponent',\n selector: 'bsu-ly-layout-panel'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-layout-panel [config]=\"item\"></bsu-ly-layout-panel> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutContainer'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n name: 'LyLayoutContainerComponent',\n selector: 'bsu-ly-layout-container'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-layout-container [config]=\"item\"></bsu-ly-layout-container> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.EmptySpace'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, name: 'LyEmptySpaceComponent', selector: 'bsu-ly-empty-space' }\n \"\n ></ng-container>\n <!-- <bsu-ly-empty-space [config]=\"item\"></bsu-ly-empty-space> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.SimpleLabel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n name: 'LySimpleLabelComponent',\n selector: 'bsu-ly-simple-label'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-simple-label [config]=\"item\"></bsu-ly-simple-label> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutLine'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, name: 'LyLineComponent', selector: 'bsu-ly-line' }\n \"\n ></ng-container>\n <!-- <bsu-ly-line [isVertical]=\"item.IsVertical\"></bsu-ly-line> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutJoin'\">\n <ng-container *ngIf=\"item.Type === 'HorizontalJoin'; else verticalJoin\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-ly-horizontal-layout',\n name: 'LyLayoutHorizontalComponent'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-horizontal-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-horizontal-layout> -->\n </ng-container>\n <ng-template #verticalJoin>\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-ly-vertical-layout',\n name: 'LyLayoutVerticalComponent'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-vertical-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-vertical-layout> -->\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutControl'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-layout-control',\n name: 'LayoutControlComponent'\n }\n \"\n ></ng-container>\n <!-- <bsu-layout-control [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-layout-control> -->\n </ng-container>\n </ng-container>\n </ng-container>\n <ng-template\n #dynamicLayout\n let-config\n let-selector=\"selector\"\n let-maxLabelWidth=\"maxLabelWidth\"\n let-name=\"name\"\n >\n <bnrc-dynamic-layout\n [config]=\"config\"\n [selector]=\"selector\"\n [name]=\"name\"\n [module]=\"'BarsaSapUi'\"\n [moduleFileName]=\"'BarsaSapUi'\"\n [maxLabelWidth]=\"(maxLabelWidth$ | async)!!\"\n [flex]=\"isSearchPanel ? 'unset' : config.Bounds.width\"\n [isSearchPanel]=\"isSearchPanel\"\n >\n </bnrc-dynamic-layout>\n </ng-template>\n </fd-card-content>\n</fd-card>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i2.DynamicLayoutComponent, selector: "bnrc-dynamic-layout", inputs: ["selector", "module", "name", "parameters", "moduleFileName", "flex", "config", "maxLabelWidth", "hasHorizontalText", "isSearchPanel"] }, { kind: "component", type: i3.CardComponent, selector: "fd-card", inputs: ["badge", "isLoading", "cardType", "id", "role"] }, { kind: "component", type: i3.CardHeaderComponent, selector: "fd-card-header", inputs: ["interactive", "tabindex"] }, { kind: "component", type: i3.CardContentComponent, selector: "fd-card-content" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i2.FilterToolbarControlPipe, name: "filterToolbarControl" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaCardLayoutPanelComponent, decorators: [{
|
|
15
|
+
type: Component,
|
|
16
|
+
args: [{ selector: 'bsu-barsa-card-layout-panel', changeDetection: ChangeDetectionStrategy.OnPush, providers: [LayoutService], template: "<fd-card>\n <fd-card-header>\n {{ (config.TextVisible ? config.Title ?? '' : '') | bbbTranslate }}\n </fd-card-header>\n <fd-card-content>\n <ng-container *ngFor=\"let item of config | filterToolbarControl\">\n <ng-container [ngSwitch]=\"item.xtype\">\n <ng-container *ngSwitchCase=\"'Ly.LayoutTabPanel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n name: 'LyLayoutPanelComponent',\n selector: 'bsu-ly-tab-container'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-tab-container [config]=\"item\"></bsu-ly-tab-container> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutPanel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n name: 'LyLayoutPanelComponent',\n selector: 'bsu-ly-layout-panel'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-layout-panel [config]=\"item\"></bsu-ly-layout-panel> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutContainer'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n name: 'LyLayoutContainerComponent',\n selector: 'bsu-ly-layout-container'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-layout-container [config]=\"item\"></bsu-ly-layout-container> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.EmptySpace'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, name: 'LyEmptySpaceComponent', selector: 'bsu-ly-empty-space' }\n \"\n ></ng-container>\n <!-- <bsu-ly-empty-space [config]=\"item\"></bsu-ly-empty-space> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.SimpleLabel'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n name: 'LySimpleLabelComponent',\n selector: 'bsu-ly-simple-label'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-simple-label [config]=\"item\"></bsu-ly-simple-label> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutLine'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: { $implicit: item, name: 'LyLineComponent', selector: 'bsu-ly-line' }\n \"\n ></ng-container>\n <!-- <bsu-ly-line [isVertical]=\"item.IsVertical\"></bsu-ly-line> -->\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutJoin'\">\n <ng-container *ngIf=\"item.Type === 'HorizontalJoin'; else verticalJoin\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-ly-horizontal-layout',\n name: 'LyLayoutHorizontalComponent'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-horizontal-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-horizontal-layout> -->\n </ng-container>\n <ng-template #verticalJoin>\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-ly-vertical-layout',\n name: 'LyLayoutVerticalComponent'\n }\n \"\n ></ng-container>\n <!-- <bsu-ly-vertical-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-vertical-layout> -->\n </ng-template>\n </ng-container>\n <ng-container *ngSwitchCase=\"'Ly.LayoutControl'\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-layout-control',\n name: 'LayoutControlComponent'\n }\n \"\n ></ng-container>\n <!-- <bsu-layout-control [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-layout-control> -->\n </ng-container>\n </ng-container>\n </ng-container>\n <ng-template\n #dynamicLayout\n let-config\n let-selector=\"selector\"\n let-maxLabelWidth=\"maxLabelWidth\"\n let-name=\"name\"\n >\n <bnrc-dynamic-layout\n [config]=\"config\"\n [selector]=\"selector\"\n [name]=\"name\"\n [module]=\"'BarsaSapUi'\"\n [moduleFileName]=\"'BarsaSapUi'\"\n [maxLabelWidth]=\"(maxLabelWidth$ | async)!!\"\n [flex]=\"isSearchPanel ? 'unset' : config.Bounds.width\"\n [isSearchPanel]=\"isSearchPanel\"\n >\n </bnrc-dynamic-layout>\n </ng-template>\n </fd-card-content>\n</fd-card>\n" }]
|
|
17
|
+
}] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-card-layout-panel.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-card-layout-panel/barsa-card-layout-panel.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-card-layout-panel/barsa-card-layout-panel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAC3E,OAAO,EAAE,wBAAwB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;;;;;AAS/E,MAAM,OAAO,6BAA8B,SAAQ,wBAAwB;IACvE,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;IACrB,CAAC;;0HAHQ,6BAA6B;8GAA7B,6BAA6B,sDAF3B,CAAC,aAAa,CAAC,iDCR9B,8tNA6IA;2FDnIa,6BAA6B;kBAPzC,SAAS;+BACI,6BAA6B,mBAGtB,uBAAuB,CAAC,MAAM,aACpC,CAAC,aAAa,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\nimport { LayoutPanelBaseComponent, LayoutService } from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-barsa-card-layout-panel',\n    templateUrl: './barsa-card-layout-panel.component.html',\n    styleUrls: ['./barsa-card-layout-panel.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [LayoutService]\n})\nexport class BarsaCardLayoutPanelComponent extends LayoutPanelBaseComponent implements OnInit {\n    ngOnInit(): void {\n        super.ngOnInit();\n    }\n}\n","<fd-card>\n    <fd-card-header>\n        {{ (config.TextVisible ? config.Title ?? '' : '') | bbbTranslate }}\n    </fd-card-header>\n    <fd-card-content>\n        <ng-container *ngFor=\"let item of config | filterToolbarControl\">\n            <ng-container [ngSwitch]=\"item.xtype\">\n                <ng-container *ngSwitchCase=\"'Ly.LayoutTabPanel'\">\n                    <ng-container\n                        *ngTemplateOutlet=\"\n                            dynamicLayout;\n                            context: {\n                                $implicit: item,\n                                name: 'LyLayoutPanelComponent',\n                                selector: 'bsu-ly-tab-container'\n                            }\n                        \"\n                    ></ng-container>\n                    <!-- <bsu-ly-tab-container [config]=\"item\"></bsu-ly-tab-container> -->\n                </ng-container>\n                <ng-container *ngSwitchCase=\"'Ly.LayoutPanel'\">\n                    <ng-container\n                        *ngTemplateOutlet=\"\n                            dynamicLayout;\n                            context: {\n                                $implicit: item,\n                                name: 'LyLayoutPanelComponent',\n                                selector: 'bsu-ly-layout-panel'\n                            }\n                        \"\n                    ></ng-container>\n                    <!-- <bsu-ly-layout-panel [config]=\"item\"></bsu-ly-layout-panel> -->\n                </ng-container>\n                <ng-container *ngSwitchCase=\"'Ly.LayoutContainer'\">\n                    <ng-container\n                        *ngTemplateOutlet=\"\n                            dynamicLayout;\n                            context: {\n                                $implicit: item,\n                                name: 'LyLayoutContainerComponent',\n                                selector: 'bsu-ly-layout-container'\n                            }\n                        \"\n                    ></ng-container>\n                    <!-- <bsu-ly-layout-container [config]=\"item\"></bsu-ly-layout-container> -->\n                </ng-container>\n                <ng-container *ngSwitchCase=\"'Ly.EmptySpace'\">\n                    <ng-container\n                        *ngTemplateOutlet=\"\n                            dynamicLayout;\n                            context: { $implicit: item, name: 'LyEmptySpaceComponent', selector: 'bsu-ly-empty-space' }\n                        \"\n                    ></ng-container>\n                    <!-- <bsu-ly-empty-space [config]=\"item\"></bsu-ly-empty-space> -->\n                </ng-container>\n                <ng-container *ngSwitchCase=\"'Ly.SimpleLabel'\">\n                    <ng-container\n                        *ngTemplateOutlet=\"\n                            dynamicLayout;\n                            context: {\n                                $implicit: item,\n                                name: 'LySimpleLabelComponent',\n                                selector: 'bsu-ly-simple-label'\n                            }\n                        \"\n                    ></ng-container>\n                    <!-- <bsu-ly-simple-label [config]=\"item\"></bsu-ly-simple-label> -->\n                </ng-container>\n                <ng-container *ngSwitchCase=\"'Ly.LayoutLine'\">\n                    <ng-container\n                        *ngTemplateOutlet=\"\n                            dynamicLayout;\n                            context: { $implicit: item, name: 'LyLineComponent', selector: 'bsu-ly-line' }\n                        \"\n                    ></ng-container>\n                    <!-- <bsu-ly-line [isVertical]=\"item.IsVertical\"></bsu-ly-line> -->\n                </ng-container>\n                <ng-container *ngSwitchCase=\"'Ly.LayoutJoin'\">\n                    <ng-container *ngIf=\"item.Type === 'HorizontalJoin'; else verticalJoin\">\n                        <ng-container\n                            *ngTemplateOutlet=\"\n                                dynamicLayout;\n                                context: {\n                                    $implicit: item,\n                                    selector: 'bsu-ly-horizontal-layout',\n                                    name: 'LyLayoutHorizontalComponent'\n                                }\n                            \"\n                        ></ng-container>\n                        <!-- <bsu-ly-horizontal-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-horizontal-layout> -->\n                    </ng-container>\n                    <ng-template #verticalJoin>\n                        <ng-container\n                            *ngTemplateOutlet=\"\n                                dynamicLayout;\n                                context: {\n                                    $implicit: item,\n                                    selector: 'bsu-ly-vertical-layout',\n                                    name: 'LyLayoutVerticalComponent'\n                                }\n                            \"\n                        ></ng-container>\n                        <!-- <bsu-ly-vertical-layout [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-ly-vertical-layout> -->\n                    </ng-template>\n                </ng-container>\n                <ng-container *ngSwitchCase=\"'Ly.LayoutControl'\">\n                    <ng-container\n                        *ngTemplateOutlet=\"\n                            dynamicLayout;\n                            context: {\n                                $implicit: item,\n                                selector: 'bsu-layout-control',\n                                name: 'LayoutControlComponent'\n                            }\n                        \"\n                    ></ng-container>\n                    <!-- <bsu-layout-control [config]=\"item\" [maxLabelWidth]=\"maxLabelWidth\"></bsu-layout-control> -->\n                </ng-container>\n            </ng-container>\n        </ng-container>\n        <ng-template\n            #dynamicLayout\n            let-config\n            let-selector=\"selector\"\n            let-maxLabelWidth=\"maxLabelWidth\"\n            let-name=\"name\"\n        >\n            <bnrc-dynamic-layout\n                [config]=\"config\"\n                [selector]=\"selector\"\n                [name]=\"name\"\n                [module]=\"'BarsaSapUi'\"\n                [moduleFileName]=\"'BarsaSapUi'\"\n                [maxLabelWidth]=\"(maxLabelWidth$ | async)!!\"\n                [flex]=\"isSearchPanel ? 'unset' : config.Bounds.width\"\n                [isSearchPanel]=\"isSearchPanel\"\n            >\n            </bnrc-dynamic-layout>\n        </ng-template>\n    </fd-card-content>\n</fd-card>\n"]}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { FieldBaseComponent } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@fundamental-ngx/core/button";
|
|
6
|
+
import * as i3 from "@fundamental-ngx/core/menu";
|
|
7
|
+
export class BarsaEnumMenuButtonComponent extends FieldBaseComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this.valueStatus = 'transparent';
|
|
11
|
+
}
|
|
12
|
+
ngOnInit() {
|
|
13
|
+
super.ngOnInit();
|
|
14
|
+
this._setValueCaption();
|
|
15
|
+
}
|
|
16
|
+
onValueChange(menu, value) {
|
|
17
|
+
menu.close();
|
|
18
|
+
const selectedValue = value;
|
|
19
|
+
this.setValue(selectedValue);
|
|
20
|
+
}
|
|
21
|
+
_setValueCaption() {
|
|
22
|
+
const store = this.context.store;
|
|
23
|
+
const item = store.data[store.root].find((c) => c.id === this.value);
|
|
24
|
+
if (item) {
|
|
25
|
+
this.valueItem = item;
|
|
26
|
+
}
|
|
27
|
+
this.valueCaption = item?.txt;
|
|
28
|
+
if (!item || item.IsEmpty) {
|
|
29
|
+
this.valueCaption = this._getPlaceholder();
|
|
30
|
+
}
|
|
31
|
+
if (item?.id) {
|
|
32
|
+
if (this.parameters?.ValuesStatus?.MoDataList.length) {
|
|
33
|
+
const x = this.parameters.ValuesStatus.MoDataList.find((c) => c.ValueOfEnum === item.id);
|
|
34
|
+
this.valueStatus = x ? x.StatusOfEnum$Caption : 'standard';
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
this.valueStatus = 'standard';
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
_getPlaceholder() {
|
|
42
|
+
return this.parameters?.Placeholder ? this.parameters?.Placeholder : this.Setting.ControlFieldCaptionTranslated;
|
|
43
|
+
}
|
|
44
|
+
_setValue(value) {
|
|
45
|
+
this._setValueCaption();
|
|
46
|
+
super._setValue(value);
|
|
47
|
+
}
|
|
48
|
+
setValue(selectedValue) {
|
|
49
|
+
this.value = selectedValue;
|
|
50
|
+
this.valueChange.emit(this.value);
|
|
51
|
+
this._setValueCaption();
|
|
52
|
+
this.fireContextEvent('select', this.value);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
BarsaEnumMenuButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaEnumMenuButtonComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
56
|
+
BarsaEnumMenuButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaEnumMenuButtonComponent, selector: "bsu-barsa-enum-menu-button", usesInheritance: true, ngImport: i0, template: "<button\n fd-button\n [label]=\"valueCaption ? valueCaption : Setting.ControlFieldCaptionTranslated\"\n [title]=\"Setting.ControlFieldCaptionTranslated\"\n [fdType]=\"valueStatus\"\n [fdMenu]=\"(disableOrReadonly$ | async) === true ? false : true\"\n [fdMenuTrigger]=\"(disableOrReadonly$ | async) === true ? undefined : menu\"\n [class.placeholder-custom]=\"!valueItem || valueItem?.IsEmpty\"\n></button>\n<fd-menu #menu>\n <li *ngFor=\"let item of context.store.data[context.store.root]\" fd-menu-item>\n <a fd-menu-interactive (click)=\"onValueChange(menu, item.id)\">\n <span fd-menu-title [class.list-empty-item]=\"item.IsEmpty\">{{ item.txt }}</span>\n </a>\n </li>\n</fd-menu>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i3.MenuComponent, selector: "fd-menu", inputs: ["mobile", "disabled", "focusTrapped", "openOnHoverTime", "mobileConfig", "ariaLabel", "ariaLabelledby", "id"], outputs: ["activePath"] }, { kind: "component", type: i3.MenuItemComponent, selector: "li[fd-menu-item]", inputs: ["disabled", "itemId", "submenu"], outputs: ["onSelect"], exportAs: ["fd-menu-item"] }, { kind: "directive", type: i3.MenuInteractiveDirective, selector: "[fd-menu-interactive]" }, { kind: "directive", type: i3.MenuTitleDirective, selector: "[fd-menu-title]" }, { kind: "directive", type: i3.MenuTriggerDirective, selector: "[fdMenuTrigger]", inputs: ["fdMenuTrigger"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
57
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaEnumMenuButtonComponent, decorators: [{
|
|
58
|
+
type: Component,
|
|
59
|
+
args: [{ selector: 'bsu-barsa-enum-menu-button', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n fd-button\n [label]=\"valueCaption ? valueCaption : Setting.ControlFieldCaptionTranslated\"\n [title]=\"Setting.ControlFieldCaptionTranslated\"\n [fdType]=\"valueStatus\"\n [fdMenu]=\"(disableOrReadonly$ | async) === true ? false : true\"\n [fdMenuTrigger]=\"(disableOrReadonly$ | async) === true ? undefined : menu\"\n [class.placeholder-custom]=\"!valueItem || valueItem?.IsEmpty\"\n></button>\n<fd-menu #menu>\n <li *ngFor=\"let item of context.store.data[context.store.root]\" fd-menu-item>\n <a fd-menu-interactive (click)=\"onValueChange(menu, item.id)\">\n <span fd-menu-title [class.list-empty-item]=\"item.IsEmpty\">{{ item.txt }}</span>\n </a>\n </li>\n</fd-menu>\n" }]
|
|
60
|
+
}] });
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtZW51bS1tZW51LWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1zYXAtdWkvc3JjL2xpYi9iYXJzYS1lbnVtLW1lbnUtYnV0dG9uL2JhcnNhLWVudW0tbWVudS1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtZW51bS1tZW51LWJ1dHRvbi9iYXJzYS1lbnVtLW1lbnUtYnV0dG9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFHM0UsT0FBTyxFQUF1QixrQkFBa0IsRUFBb0IsTUFBTSxzQkFBc0IsQ0FBQzs7Ozs7QUFRakcsTUFBTSxPQUFPLDRCQUE2QixTQUFRLGtCQUFrQjtJQU5wRTs7UUFTSSxnQkFBVyxHQUFlLGFBQWEsQ0FBQztLQTJDM0M7SUF6Q0csUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBQ0QsYUFBYSxDQUFDLElBQVMsRUFBRSxLQUFhO1FBQ2xDLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNiLE1BQU0sYUFBYSxHQUFHLEtBQUssQ0FBQztRQUM1QixJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFDUyxnQkFBZ0I7UUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUM7UUFDakMsTUFBTSxJQUFJLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNyRSxJQUFJLElBQUksRUFBRTtZQUNOLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1NBQ3pCO1FBQ0QsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLEVBQUUsR0FBRyxDQUFDO1FBQzlCLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUN2QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztTQUM5QztRQUNELElBQUksSUFBSSxFQUFFLEVBQUUsRUFBRTtZQUNWLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBRSxZQUFZLEVBQUUsVUFBVSxDQUFDLE1BQU0sRUFBRTtnQkFDbEQsTUFBTSxDQUFDLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxZQUFZLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFdBQVcsS0FBSyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUM7Z0JBQ3pGLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsb0JBQW9CLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQzthQUM5RDtpQkFBTTtnQkFDSCxJQUFJLENBQUMsV0FBVyxHQUFHLFVBQVUsQ0FBQzthQUNqQztTQUNKO0lBQ0wsQ0FBQztJQUNTLGVBQWU7UUFDckIsT0FBTyxJQUFJLENBQUMsVUFBVSxFQUFFLFdBQVcsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsNkJBQTZCLENBQUM7SUFDcEgsQ0FBQztJQUNTLFNBQVMsQ0FBQyxLQUFhO1FBQzdCLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3hCLEtBQUssQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUNTLFFBQVEsQ0FBQyxhQUFrQjtRQUNqQyxJQUFJLENBQUMsS0FBSyxHQUFHLGFBQWEsQ0FBQztRQUMzQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDeEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEQsQ0FBQzs7eUhBN0NRLDRCQUE0Qjs2R0FBNUIsNEJBQTRCLHlGQ1h6QyxtdUJBZ0JBOzJGRExhLDRCQUE0QjtrQkFOeEMsU0FBUzsrQkFDSSw0QkFBNEIsbUJBR3JCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJ1dHRvblR5cGUgfSBmcm9tICdAZnVuZGFtZW50YWwtbmd4L2NvcmUnO1xuXG5pbXBvcnQgeyBNZXRhb2JqZWN0RGF0YU1vZGVsLCBGaWVsZEJhc2VDb21wb25lbnQsIE1vRm9yUmVwb3J0TW9kZWwgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYnN1LWJhcnNhLWVudW0tbWVudS1idXR0b24nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9iYXJzYS1lbnVtLW1lbnUtYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9iYXJzYS1lbnVtLW1lbnUtYnV0dG9uLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQmFyc2FFbnVtTWVudUJ1dHRvbkNvbXBvbmVudCBleHRlbmRzIEZpZWxkQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgcGFyYW1ldGVyczogQmFyc2FFbnVtTWVudUJ1dHRvblNldHRpbmc7XG4gICAgdmFsdWVDYXB0aW9uOiBzdHJpbmc7XG4gICAgdmFsdWVTdGF0dXM6IEJ1dHRvblR5cGUgPSAndHJhbnNwYXJlbnQnO1xuICAgIHZhbHVlSXRlbTogYW55O1xuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICB0aGlzLl9zZXRWYWx1ZUNhcHRpb24oKTtcbiAgICB9XG4gICAgb25WYWx1ZUNoYW5nZShtZW51OiBhbnksIHZhbHVlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICAgICAgbWVudS5jbG9zZSgpO1xuICAgICAgICBjb25zdCBzZWxlY3RlZFZhbHVlID0gdmFsdWU7XG4gICAgICAgIHRoaXMuc2V0VmFsdWUoc2VsZWN0ZWRWYWx1ZSk7XG4gICAgfVxuICAgIHByb3RlY3RlZCBfc2V0VmFsdWVDYXB0aW9uKCk6IHZvaWQge1xuICAgICAgICBjb25zdCBzdG9yZSA9IHRoaXMuY29udGV4dC5zdG9yZTtcbiAgICAgICAgY29uc3QgaXRlbSA9IHN0b3JlLmRhdGFbc3RvcmUucm9vdF0uZmluZCgoYykgPT4gYy5pZCA9PT0gdGhpcy52YWx1ZSk7XG4gICAgICAgIGlmIChpdGVtKSB7XG4gICAgICAgICAgICB0aGlzLnZhbHVlSXRlbSA9IGl0ZW07XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy52YWx1ZUNhcHRpb24gPSBpdGVtPy50eHQ7XG4gICAgICAgIGlmICghaXRlbSB8fCBpdGVtLklzRW1wdHkpIHtcbiAgICAgICAgICAgIHRoaXMudmFsdWVDYXB0aW9uID0gdGhpcy5fZ2V0UGxhY2Vob2xkZXIoKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoaXRlbT8uaWQpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLnBhcmFtZXRlcnM/LlZhbHVlc1N0YXR1cz8uTW9EYXRhTGlzdC5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICBjb25zdCB4ID0gdGhpcy5wYXJhbWV0ZXJzLlZhbHVlc1N0YXR1cy5Nb0RhdGFMaXN0LmZpbmQoKGMpID0+IGMuVmFsdWVPZkVudW0gPT09IGl0ZW0uaWQpO1xuICAgICAgICAgICAgICAgIHRoaXMudmFsdWVTdGF0dXMgPSB4ID8geC5TdGF0dXNPZkVudW0kQ2FwdGlvbiA6ICdzdGFuZGFyZCc7XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHRoaXMudmFsdWVTdGF0dXMgPSAnc3RhbmRhcmQnO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxuICAgIHByb3RlY3RlZCBfZ2V0UGxhY2Vob2xkZXIoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIHRoaXMucGFyYW1ldGVycz8uUGxhY2Vob2xkZXIgPyB0aGlzLnBhcmFtZXRlcnM/LlBsYWNlaG9sZGVyIDogdGhpcy5TZXR0aW5nLkNvbnRyb2xGaWVsZENhcHRpb25UcmFuc2xhdGVkO1xuICAgIH1cbiAgICBwcm90ZWN0ZWQgX3NldFZhbHVlKHZhbHVlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5fc2V0VmFsdWVDYXB0aW9uKCk7XG4gICAgICAgIHN1cGVyLl9zZXRWYWx1ZSh2YWx1ZSk7XG4gICAgfVxuICAgIHByb3RlY3RlZCBzZXRWYWx1ZShzZWxlY3RlZFZhbHVlOiBhbnkpOiB2b2lkIHtcbiAgICAgICAgdGhpcy52YWx1ZSA9IHNlbGVjdGVkVmFsdWU7XG4gICAgICAgIHRoaXMudmFsdWVDaGFuZ2UuZW1pdCh0aGlzLnZhbHVlKTtcbiAgICAgICAgdGhpcy5fc2V0VmFsdWVDYXB0aW9uKCk7XG4gICAgICAgIHRoaXMuZmlyZUNvbnRleHRFdmVudCgnc2VsZWN0JywgdGhpcy52YWx1ZSk7XG4gICAgfVxufVxuXG5pbnRlcmZhY2UgQmFyc2FFbnVtTWVudUJ1dHRvblNldHRpbmcgZXh0ZW5kcyBNZXRhb2JqZWN0RGF0YU1vZGVsIHtcbiAgICBWYWx1ZXNTdGF0dXM6IE1vRm9yUmVwb3J0TW9kZWw7XG4gICAgUGxhY2Vob2xkZXI6IHN0cmluZztcbn1cbiIsIjxidXR0b25cbiAgICBmZC1idXR0b25cbiAgICBbbGFiZWxdPVwidmFsdWVDYXB0aW9uID8gdmFsdWVDYXB0aW9uIDogU2V0dGluZy5Db250cm9sRmllbGRDYXB0aW9uVHJhbnNsYXRlZFwiXG4gICAgW3RpdGxlXT1cIlNldHRpbmcuQ29udHJvbEZpZWxkQ2FwdGlvblRyYW5zbGF0ZWRcIlxuICAgIFtmZFR5cGVdPVwidmFsdWVTdGF0dXNcIlxuICAgIFtmZE1lbnVdPVwiKGRpc2FibGVPclJlYWRvbmx5JCB8IGFzeW5jKSA9PT0gdHJ1ZSA/IGZhbHNlIDogdHJ1ZVwiXG4gICAgW2ZkTWVudVRyaWdnZXJdPVwiKGRpc2FibGVPclJlYWRvbmx5JCB8IGFzeW5jKSA9PT0gdHJ1ZSA/IHVuZGVmaW5lZCA6IG1lbnVcIlxuICAgIFtjbGFzcy5wbGFjZWhvbGRlci1jdXN0b21dPVwiIXZhbHVlSXRlbSB8fCB2YWx1ZUl0ZW0/LklzRW1wdHlcIlxuPjwvYnV0dG9uPlxuPGZkLW1lbnUgI21lbnU+XG4gICAgPGxpICpuZ0Zvcj1cImxldCBpdGVtIG9mIGNvbnRleHQuc3RvcmUuZGF0YVtjb250ZXh0LnN0b3JlLnJvb3RdXCIgZmQtbWVudS1pdGVtPlxuICAgICAgICA8YSBmZC1tZW51LWludGVyYWN0aXZlIChjbGljayk9XCJvblZhbHVlQ2hhbmdlKG1lbnUsIGl0ZW0uaWQpXCI+XG4gICAgICAgICAgICA8c3BhbiBmZC1tZW51LXRpdGxlIFtjbGFzcy5saXN0LWVtcHR5LWl0ZW1dPVwiaXRlbS5Jc0VtcHR5XCI+e3sgaXRlbS50eHQgfX08L3NwYW4+XG4gICAgICAgIDwvYT5cbiAgICA8L2xpPlxuPC9mZC1tZW51PlxuIl19
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { LayoutPanelBaseComponent, LayoutService } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "barsa-novin-ray-core";
|
|
6
|
+
import * as i3 from "@fundamental-ngx/core/link";
|
|
7
|
+
export class BarsaLinkableItemsPanelComponent extends LayoutPanelBaseComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this.layoutControls = [];
|
|
11
|
+
this.visibleControls = [];
|
|
12
|
+
this.hideControls = [];
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() {
|
|
15
|
+
super.ngOnInit();
|
|
16
|
+
this._setLayoutControls(this.config);
|
|
17
|
+
this.layoutControls.forEach((c, index) => {
|
|
18
|
+
if (index === 0) {
|
|
19
|
+
this.visibleControls.push(c);
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
this.hideControls.push(c);
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
onAddToVisibleControls(item) {
|
|
27
|
+
this.visibleControls.push(item);
|
|
28
|
+
this.hideControls = this.hideControls.filter((c) => c.Caption !== item.Caption);
|
|
29
|
+
}
|
|
30
|
+
_setLayoutControls(item) {
|
|
31
|
+
if (item.xtype === 'Ly.LayoutControl') {
|
|
32
|
+
this.layoutControls.push(item);
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
item.items.forEach((c) => this._setLayoutControls(c));
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
BarsaLinkableItemsPanelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaLinkableItemsPanelComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
39
|
+
BarsaLinkableItemsPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaLinkableItemsPanelComponent, selector: "bsu-barsa-linkable-items-panel", providers: [LayoutService], usesInheritance: true, ngImport: i0, template: "<ng-container *ngFor=\"let item of visibleControls; let i = index\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-layout-control',\n name: 'LayoutControlComponent',\n index: i\n }\n \"\n ></ng-container>\n</ng-container>\n<ng-template\n #dynamicLayout\n let-index\n let-config\n let-selector=\"selector\"\n let-maxLabelWidth=\"maxLabelWidth\"\n let-name=\"name\"\n>\n <bnrc-dynamic-layout\n [config]=\"config\"\n [selector]=\"selector\"\n [name]=\"name\"\n [module]=\"'BarsaSapUi'\"\n [moduleFileName]=\"'BarsaSapUi'\"\n [maxLabelWidth]=\"(maxLabelWidth$ | async)!!\"\n [flex]=\"isSearchPanel ? 'unset' : config.Bounds.width\"\n [isSearchPanel]=\"isSearchPanel\"\n >\n </bnrc-dynamic-layout>\n</ng-template>\n<div style=\"display: flex; column-gap: 3px; padding: 0 5px\">\n <ng-container *ngFor=\"let item of hideControls; let i = index\">\n <a fd-link [attr.aria-label]=\"item.Caption\" (click)=\"onAddToVisibleControls(item)\"> {{ item.Caption }}</a>\n <span *ngIf=\"i < hideControls.length - 1\">/</span>\n </ng-container>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.DynamicLayoutComponent, selector: "bnrc-dynamic-layout", inputs: ["selector", "module", "name", "parameters", "moduleFileName", "flex", "config", "maxLabelWidth", "hasHorizontalText", "isSearchPanel"] }, { kind: "component", type: i3.LinkComponent, selector: "[fdLink], [fd-link], [fd-breadcrumb-link]", inputs: ["class", "emphasized", "disabled", "inverted", "subtle", "undecorated"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
40
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaLinkableItemsPanelComponent, decorators: [{
|
|
41
|
+
type: Component,
|
|
42
|
+
args: [{ selector: 'bsu-barsa-linkable-items-panel', changeDetection: ChangeDetectionStrategy.OnPush, providers: [LayoutService], template: "<ng-container *ngFor=\"let item of visibleControls; let i = index\">\n <ng-container\n *ngTemplateOutlet=\"\n dynamicLayout;\n context: {\n $implicit: item,\n selector: 'bsu-layout-control',\n name: 'LayoutControlComponent',\n index: i\n }\n \"\n ></ng-container>\n</ng-container>\n<ng-template\n #dynamicLayout\n let-index\n let-config\n let-selector=\"selector\"\n let-maxLabelWidth=\"maxLabelWidth\"\n let-name=\"name\"\n>\n <bnrc-dynamic-layout\n [config]=\"config\"\n [selector]=\"selector\"\n [name]=\"name\"\n [module]=\"'BarsaSapUi'\"\n [moduleFileName]=\"'BarsaSapUi'\"\n [maxLabelWidth]=\"(maxLabelWidth$ | async)!!\"\n [flex]=\"isSearchPanel ? 'unset' : config.Bounds.width\"\n [isSearchPanel]=\"isSearchPanel\"\n >\n </bnrc-dynamic-layout>\n</ng-template>\n<div style=\"display: flex; column-gap: 3px; padding: 0 5px\">\n <ng-container *ngFor=\"let item of hideControls; let i = index\">\n <a fd-link [attr.aria-label]=\"item.Caption\" (click)=\"onAddToVisibleControls(item)\"> {{ item.Caption }}</a>\n <span *ngIf=\"i < hideControls.length - 1\">/</span>\n </ng-container>\n</div>\n" }]
|
|
43
|
+
}] });
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyc2EtbGlua2FibGUtaXRlbXMtcGFuZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtbGlua2FibGUtaXRlbXMtcGFuZWwvYmFyc2EtbGlua2FibGUtaXRlbXMtcGFuZWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvYmFyc2EtbGlua2FibGUtaXRlbXMtcGFuZWwvYmFyc2EtbGlua2FibGUtaXRlbXMtcGFuZWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsYUFBYSxFQUFpQixNQUFNLHNCQUFzQixDQUFDOzs7OztBQVM5RixNQUFNLE9BQU8sZ0NBQWlDLFNBQVEsd0JBQXdCO0lBUDlFOztRQVFJLG1CQUFjLEdBQW9CLEVBQUUsQ0FBQztRQUNyQyxvQkFBZSxHQUFvQixFQUFFLENBQUM7UUFDdEMsaUJBQVksR0FBb0IsRUFBRSxDQUFDO0tBdUJ0QztJQXRCRyxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDckMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUU7WUFDckMsSUFBSSxLQUFLLEtBQUssQ0FBQyxFQUFFO2dCQUNiLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ2hDO2lCQUFNO2dCQUNILElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQzdCO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBQ0Qsc0JBQXNCLENBQUMsSUFBbUI7UUFDdEMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDaEMsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sS0FBSyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDcEYsQ0FBQztJQUNTLGtCQUFrQixDQUFDLElBQW1CO1FBQzVDLElBQUksSUFBSSxDQUFDLEtBQUssS0FBSyxrQkFBa0IsRUFBRTtZQUNuQyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUMvQixPQUFPO1NBQ1Y7UUFDRCxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDMUQsQ0FBQzs7NkhBekJRLGdDQUFnQztpSEFBaEMsZ0NBQWdDLHlEQUY5QixDQUFDLGFBQWEsQ0FBQyxpRENSOUIsaXlDQXVDQTsyRkQ3QmEsZ0NBQWdDO2tCQVA1QyxTQUFTOytCQUNJLGdDQUFnQyxtQkFHekIsdUJBQXVCLENBQUMsTUFBTSxhQUNwQyxDQUFDLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTGF5b3V0UGFuZWxCYXNlQ29tcG9uZW50LCBMYXlvdXRTZXJ2aWNlLCBMYXlvdXRTZXR0aW5nIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2JzdS1iYXJzYS1saW5rYWJsZS1pdGVtcy1wYW5lbCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2JhcnNhLWxpbmthYmxlLWl0ZW1zLXBhbmVsLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9iYXJzYS1saW5rYWJsZS1pdGVtcy1wYW5lbC5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHByb3ZpZGVyczogW0xheW91dFNlcnZpY2VdXG59KVxuZXhwb3J0IGNsYXNzIEJhcnNhTGlua2FibGVJdGVtc1BhbmVsQ29tcG9uZW50IGV4dGVuZHMgTGF5b3V0UGFuZWxCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBsYXlvdXRDb250cm9sczogTGF5b3V0U2V0dGluZ1tdID0gW107XG4gICAgdmlzaWJsZUNvbnRyb2xzOiBMYXlvdXRTZXR0aW5nW10gPSBbXTtcbiAgICBoaWRlQ29udHJvbHM6IExheW91dFNldHRpbmdbXSA9IFtdO1xuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICB0aGlzLl9zZXRMYXlvdXRDb250cm9scyh0aGlzLmNvbmZpZyk7XG4gICAgICAgIHRoaXMubGF5b3V0Q29udHJvbHMuZm9yRWFjaCgoYywgaW5kZXgpID0+IHtcbiAgICAgICAgICAgIGlmIChpbmRleCA9PT0gMCkge1xuICAgICAgICAgICAgICAgIHRoaXMudmlzaWJsZUNvbnRyb2xzLnB1c2goYyk7XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHRoaXMuaGlkZUNvbnRyb2xzLnB1c2goYyk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgIH1cbiAgICBvbkFkZFRvVmlzaWJsZUNvbnRyb2xzKGl0ZW06IExheW91dFNldHRpbmcpOiB2b2lkIHtcbiAgICAgICAgdGhpcy52aXNpYmxlQ29udHJvbHMucHVzaChpdGVtKTtcbiAgICAgICAgdGhpcy5oaWRlQ29udHJvbHMgPSB0aGlzLmhpZGVDb250cm9scy5maWx0ZXIoKGMpID0+IGMuQ2FwdGlvbiAhPT0gaXRlbS5DYXB0aW9uKTtcbiAgICB9XG4gICAgcHJvdGVjdGVkIF9zZXRMYXlvdXRDb250cm9scyhpdGVtOiBMYXlvdXRTZXR0aW5nKTogdm9pZCB7XG4gICAgICAgIGlmIChpdGVtLnh0eXBlID09PSAnTHkuTGF5b3V0Q29udHJvbCcpIHtcbiAgICAgICAgICAgIHRoaXMubGF5b3V0Q29udHJvbHMucHVzaChpdGVtKTtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBpdGVtLml0ZW1zLmZvckVhY2goKGMpID0+IHRoaXMuX3NldExheW91dENvbnRyb2xzKGMpKTtcbiAgICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBpdGVtIG9mIHZpc2libGVDb250cm9sczsgbGV0IGkgPSBpbmRleFwiPlxuICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJcbiAgICAgICAgICAgIGR5bmFtaWNMYXlvdXQ7XG4gICAgICAgICAgICBjb250ZXh0OiB7XG4gICAgICAgICAgICAgICAgJGltcGxpY2l0OiBpdGVtLFxuICAgICAgICAgICAgICAgIHNlbGVjdG9yOiAnYnN1LWxheW91dC1jb250cm9sJyxcbiAgICAgICAgICAgICAgICBuYW1lOiAnTGF5b3V0Q29udHJvbENvbXBvbmVudCcsXG4gICAgICAgICAgICAgICAgaW5kZXg6IGlcbiAgICAgICAgICAgIH1cbiAgICAgICAgXCJcbiAgICA+PC9uZy1jb250YWluZXI+XG48L25nLWNvbnRhaW5lcj5cbjxuZy10ZW1wbGF0ZVxuICAgICNkeW5hbWljTGF5b3V0XG4gICAgbGV0LWluZGV4XG4gICAgbGV0LWNvbmZpZ1xuICAgIGxldC1zZWxlY3Rvcj1cInNlbGVjdG9yXCJcbiAgICBsZXQtbWF4TGFiZWxXaWR0aD1cIm1heExhYmVsV2lkdGhcIlxuICAgIGxldC1uYW1lPVwibmFtZVwiXG4+XG4gICAgPGJucmMtZHluYW1pYy1sYXlvdXRcbiAgICAgICAgW2NvbmZpZ109XCJjb25maWdcIlxuICAgICAgICBbc2VsZWN0b3JdPVwic2VsZWN0b3JcIlxuICAgICAgICBbbmFtZV09XCJuYW1lXCJcbiAgICAgICAgW21vZHVsZV09XCInQmFyc2FTYXBVaSdcIlxuICAgICAgICBbbW9kdWxlRmlsZU5hbWVdPVwiJ0JhcnNhU2FwVWknXCJcbiAgICAgICAgW21heExhYmVsV2lkdGhdPVwiKG1heExhYmVsV2lkdGgkIHwgYXN5bmMpISFcIlxuICAgICAgICBbZmxleF09XCJpc1NlYXJjaFBhbmVsID8gJ3Vuc2V0JyA6IGNvbmZpZy5Cb3VuZHMud2lkdGhcIlxuICAgICAgICBbaXNTZWFyY2hQYW5lbF09XCJpc1NlYXJjaFBhbmVsXCJcbiAgICA+XG4gICAgPC9ibnJjLWR5bmFtaWMtbGF5b3V0PlxuPC9uZy10ZW1wbGF0ZT5cbjxkaXYgc3R5bGU9XCJkaXNwbGF5OiBmbGV4OyBjb2x1bW4tZ2FwOiAzcHg7IHBhZGRpbmc6IDAgNXB4XCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgaXRlbSBvZiBoaWRlQ29udHJvbHM7IGxldCBpID0gaW5kZXhcIj5cbiAgICAgICAgPGEgZmQtbGluayBbYXR0ci5hcmlhLWxhYmVsXT1cIml0ZW0uQ2FwdGlvblwiIChjbGljayk9XCJvbkFkZFRvVmlzaWJsZUNvbnRyb2xzKGl0ZW0pXCI+IHt7IGl0ZW0uQ2FwdGlvbiB9fTwvYT5cbiAgICAgICAgPHNwYW4gKm5nSWY9XCJpIDwgaGlkZUNvbnRyb2xzLmxlbmd0aCAtIDFcIj4vPC9zcGFuPlxuICAgIDwvbmctY29udGFpbmVyPlxuPC9kaXY+XG4iXX0=
|
|
@@ -1,28 +1,41 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
2
|
import { UploadService } from 'barsa-novin-ray-core';
|
|
3
3
|
import { UiFileLinearListBoxComponent } from '../ui-file-linear-list-box/ui-file-linear-list-box.component';
|
|
4
|
+
import { BarsaApi } from 'barsa-novin-ray-core';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/common";
|
|
6
7
|
import * as i2 from "@angular/forms";
|
|
7
|
-
import * as i3 from "@fundamental-ngx/core/
|
|
8
|
-
import * as i4 from "@fundamental-ngx/core/
|
|
9
|
-
import * as i5 from "@fundamental-ngx/core/
|
|
10
|
-
import * as i6 from "@fundamental-ngx/core/
|
|
11
|
-
import * as i7 from "@fundamental-ngx/core/
|
|
12
|
-
import * as i8 from "@fundamental-ngx/core/
|
|
13
|
-
import * as i9 from "@fundamental-ngx/core/
|
|
14
|
-
import * as i10 from "@fundamental-ngx/core/
|
|
15
|
-
import * as i11 from "
|
|
16
|
-
import * as i12 from "
|
|
8
|
+
import * as i3 from "@fundamental-ngx/core/content-density";
|
|
9
|
+
import * as i4 from "@fundamental-ngx/core/avatar";
|
|
10
|
+
import * as i5 from "@fundamental-ngx/core/button";
|
|
11
|
+
import * as i6 from "@fundamental-ngx/core/file-uploader";
|
|
12
|
+
import * as i7 from "@fundamental-ngx/core/form";
|
|
13
|
+
import * as i8 from "@fundamental-ngx/core/icon";
|
|
14
|
+
import * as i9 from "@fundamental-ngx/core/list";
|
|
15
|
+
import * as i10 from "@fundamental-ngx/core/object-status";
|
|
16
|
+
import * as i11 from "@fundamental-ngx/core/toolbar";
|
|
17
|
+
import * as i12 from "@fundamental-ngx/core/slider";
|
|
18
|
+
import * as i13 from "@fundamental-ngx/core/progress-indicator";
|
|
19
|
+
import * as i14 from "barsa-novin-ray-core";
|
|
20
|
+
import * as i15 from "../upload-file-status.pipe";
|
|
17
21
|
export class BarsaListFileLinearComponent extends UiFileLinearListBoxComponent {
|
|
18
22
|
onRetry(fileAttachment) {
|
|
19
23
|
this.retry(fileAttachment);
|
|
20
24
|
}
|
|
25
|
+
onHandleRenameFile(file) {
|
|
26
|
+
if (!file.inEdit) {
|
|
27
|
+
file.inEdit = true;
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
file.inEdit = false;
|
|
31
|
+
BarsaApi.Common.Ajax.GetServerData('Form94.RenameFileAttachment', { renameModel: { Id: file.Id, Name: file.FileName } }, (_) => { }, (_) => { }, null, this);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
21
34
|
}
|
|
22
35
|
BarsaListFileLinearComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaListFileLinearComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
23
|
-
BarsaListFileLinearComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaListFileLinearComponent, selector: "bsu-barsa-list-file-linear", providers: [UploadService], usesInheritance: true, ngImport: i0, template: "<fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\" *ngIf=\"(disableOrReadonly$ | async) === false\">\n <fd-file-uploader\n fd-toolbar-item\n [id]=\"id\"\n [name]=\"id\"\n [placeholder]=\"'AttachFile' | bbbTranslate\"\n [buttonLabel]=\"'AttachFile' | bbbTranslate\"\n [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\n [accept]=\"Setting.ValidExtensions || ''\"\n [multiple]=\"maxFileCount > 1\"\n (selectedFilesChanged)=\"onFileSelection($event)\"\n [contentDensity]=\"(contentDensity$ | async)!!\"\n ></fd-file-uploader>\n</fd-toolbar>\n<ul fd-list [byline]=\"true\">\n <ng-container *ngIf=\"fileCount$ | async as fileCount\">\n <li fd-list-item *ngIf=\"fileCount === 0\">\n <div fd-list-content style=\"text-align: center\">\n <span>{{ 'NoFiles' | bbbTranslate }}</span>\n </div>\n </li>\n </ng-container>\n <ng-container *ngFor=\"let file of value\">\n <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n <li fd-list-item *ngIf=\"!file.IsDeleted\">\n <span fd-list-thumbnail>\n <fd-icon\n *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\n [glyph]=\"valueExtra[file.Id].FileUrl\"\n ></fd-icon>\n <ng-template #isImage>\n <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\n </ng-template>\n </span>\n <!-- for byline, fd-list-content is mandatory -->\n <div fd-list-content>\n <div fd-list-title>{{ file.FileName }}</div>\n <div fd-list-byline [twoCol]=\"true\">\n <div fd-list-byline-left></div>\n <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\n <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\n <ng-container *ngIf=\"file.IsNew\">\n <span\n fd-toolbar-item\n fd-object-status\n [status]=\"file.Id | uploadFileStatus: valueExtra\"\n [label]=\"valueExtra[file.Id]?.UploadState || ''\"\n [title]=\"valueExtra[file.Id]?.UploadState\"\n [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\n ></span>\n <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\n <fd-slider\n [contentDensity]=\"(contentDensity$ | async)!!\"\n [(ngModel)]=\"valueExtra[file.Id].Progress\"\n [name]=\"'filerLinear_' + id\"\n fd-toolbar-item\n [id]=\"id\"\n [min]=\"0\"\n [max]=\"100\"\n [step]=\"1\"\n >\n </fd-slider>\n </ng-container>\n </ng-container>\n </fd-toolbar>\n </div>\n </div>\n </div>\n <button\n *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n (click)=\"onFileDeleted(file.Id)\"\n ></button>\n <button\n *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\n fd-button\n [fdType]=\"'transparent'\"\n [glyph]=\"'stop'\"\n (click)=\"onTerminate(file)\"\n ></button>\n <button\n *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\n fd-button\n [fdType]=\"'transparent'\"\n [glyph]=\"'refresh'\"\n (click)=\"onRetry(file)\"\n ></button>\n </li>\n </ng-container>\n </ng-container>\n</ul>\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}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.AvatarComponent, selector: "fd-avatar", inputs: ["class", "id", "ariaLabel", "ariaLabelledby", "label", "size", "glyph", "zoomGlyph", "circle", "transparent", "contain", "placeholder", "tile", "border", "colorAccent", "random", "clickable", "backgroundImage", "image", "alterIcon", "backupImage"], outputs: ["avatarClicked", "zoomGlyphClicked"] }, { kind: "component", type: i4.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i5.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: i6.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "class", "ariaLabel"] }, { kind: "component", type: i7.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline"], outputs: ["focusEscapeList"] }, { kind: "component", type: i7.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i7.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i7.ListBylineDirective, selector: "[fdListByline], [fd-list-byline]", inputs: ["twoCol", "wrap"] }, { kind: "directive", type: i7.ListBylineLeftDirective, selector: "[fdListBylineLeft], [fd-list-byline-left]", inputs: ["wrap"] }, { kind: "directive", type: i7.ListBylineRightDirective, selector: "[fdListBylineRight], [fd-list-byline-right]", inputs: ["status", "wrap"] }, { kind: "directive", type: i7.ListContentDirective, selector: "[fdListContent], [fd-list-content]", inputs: ["twoCol"] }, { kind: "directive", type: i7.ListThumbnailDirective, selector: "[fdListThumbnail], [fd-list-thumbnail]" }, { kind: "component", type: i8.ObjectStatusComponent, selector: "[fd-object-status]", inputs: ["class", "status", "glyph", "label", "glyphAriaLabel", "indicationColor", "clickable", "inverted", "large"] }, { kind: "component", type: i9.ToolbarComponent, selector: "fd-toolbar", inputs: ["class", "shouldOverflow", "fdType", "hasTitle", "title", "active", "clearBorder", "forceOverflow", "tabindex"] }, { kind: "directive", type: i9.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "component", type: i10.SliderComponent, selector: "fd-slider", inputs: ["id", "class", "ariaLabelledBy", "ariaLabel", "min", "max", "step", "jump", "tickmarksBetweenLabels", "mode", "showTicks", "showTicksLabels", "customValues", "tooltipMode", "hideProgressBar", "disabled", "singleSliderCurrentValuePrefix", "rangeSliderHandle1CurrentValuePrefix", "rangeSliderHandle2CurrentValuePrefix", "value"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i11.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i12.UploadFileStatusPipe, name: "uploadFileStatus" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
36
|
+
BarsaListFileLinearComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaListFileLinearComponent, selector: "bsu-barsa-list-file-linear", providers: [UploadService], usesInheritance: true, ngImport: i0, template: "<ul fd-list class=\"file-viewer-attachments\" *ngIf=\"parameters.ModeValue === '1'\">\n <ng-container *ngFor=\"let file of value\">\n <li fd-list-item *ngIf=\"!file.IsDeleted\" style=\"background-color: #f5f5f5; margin: 0 0 0 30%; width: 100%\">\n <input\n style=\"width: 90%\"\n *ngIf=\"file.inEdit\"\n fd-form-control\n [(ngModel)]=\"file.FileName\"\n (click)=\"$event.preventDefault(); $event.stopPropagation()\"\n (keydown.enter)=\"onHandleRenameFile(file)\"\n />\n <span *ngIf=\"!file.inEdit\" fd-list-title>\n {{ file.FileName }}\n </span>\n <span fd-list-secondary>\n <button\n ariaLabel=\"Edit Or Save\"\n fdType=\"transparent\"\n class=\"fd-button--compact\"\n fd-button\n fdCompact\n [glyph]=\"file.inEdit ? 'save' : 'edit'\"\n (click)=\"onHandleRenameFile(file)\"\n ></button>\n <button\n *ngIf=\"!file.inEdit\"\n ariaLabel=\"Remove\"\n fdType=\"transparent\"\n title=\"Remove\"\n fd-button\n glyph=\"delete\"\n (click)=\"onFileDeleted(file.Id)\"\n ></button>\n </span>\n </li>\n </ng-container>\n <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n <ng-container *ngFor=\"let file of valueExtra | keyvalue\">\n <li\n *ngIf=\"file.value.UploadState === 'Uploading'\"\n style=\"background-color: #f5f5f5; margin: 0 0 0 30%; width: 100%\"\n >\n <fd-progress-indicator\n *ngIf=\"file.value.Progress\"\n state=\"informative\"\n [valueNow]=\"file.value.Progress\"\n ></fd-progress-indicator>\n </li>\n </ng-container>\n </ng-container>\n</ul>\n\n<ul fd-list [byline]=\"true\" *ngIf=\"parameters.ModeValue === '2'\">\n <ng-container *ngIf=\"fileCount$ | async as fileCount\">\n <li fd-list-item *ngIf=\"fileCount === 0\">\n <div fd-list-content style=\"text-align: center\">\n <span>{{ 'NoFiles' | bbbTranslate }}</span>\n </div>\n </li>\n </ng-container>\n <ng-container *ngFor=\"let file of value\">\n <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n <li fd-list-item *ngIf=\"!file.IsDeleted\">\n <span fd-list-thumbnail>\n <fd-icon\n *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\n [glyph]=\"valueExtra[file.Id].FileUrl\"\n ></fd-icon>\n <ng-template #isImage>\n <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\n </ng-template>\n </span>\n <!-- for byline, fd-list-content is mandatory -->\n <div fd-list-content>\n <div fd-list-title>{{ file.FileName }}</div>\n <div fd-list-byline [twoCol]=\"true\">\n <div fd-list-byline-left></div>\n <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\n <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\n <ng-container *ngIf=\"file.IsNew\">\n <span\n fd-toolbar-item\n fd-object-status\n [status]=\"file.Id | uploadFileStatus: valueExtra\"\n [label]=\"valueExtra[file.Id]?.UploadState || ''\"\n [title]=\"valueExtra[file.Id]?.UploadState\"\n [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\n ></span>\n <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\n <fd-slider\n [contentDensity]=\"(contentDensity$ | async)!!\"\n [(ngModel)]=\"valueExtra[file.Id].Progress\"\n [name]=\"'filerLinear_' + id\"\n fd-toolbar-item\n [id]=\"id\"\n [min]=\"0\"\n [max]=\"100\"\n [step]=\"1\"\n >\n </fd-slider>\n </ng-container>\n </ng-container>\n </fd-toolbar>\n </div>\n </div>\n </div>\n <button\n *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n (click)=\"onFileDeleted(file.Id)\"\n ></button>\n <button\n *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\n fd-button\n [fdType]=\"'transparent'\"\n [glyph]=\"'stop'\"\n (click)=\"onTerminate(file)\"\n ></button>\n <button\n *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\n fd-button\n [fdType]=\"'transparent'\"\n [glyph]=\"'refresh'\"\n (click)=\"onRetry(file)\"\n ></button>\n </li>\n </ng-container>\n </ng-container>\n</ul>\n<fd-toolbar\n style=\"display: block\"\n [style.height.px]=\"parameters.ModeValue === '1' ? 0 : null\"\n [fdType]=\"'transparent'\"\n [clearBorder]=\"true\"\n *ngIf=\"(disableOrReadonly$ | async) !== true\"\n>\n <fd-file-uploader\n fd-toolbar-item\n [class.hide-file-uploader]=\"parameters?.HideAttachButton\"\n [id]=\"id\"\n [name]=\"id\"\n [placeholder]=\"'AttachFile' | bbbTranslate\"\n [buttonLabel]=\"'AttachFile' | bbbTranslate\"\n [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\n [accept]=\"Setting.ValidExtensions || ''\"\n [multiple]=\"maxFileCount > 1\"\n (selectedFilesChanged)=\"onFileSelection($event)\"\n [contentDensity]=\"(contentDensity$ | async)!!\"\n ></fd-file-uploader>\n</fd-toolbar>\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 ::ng-deep fd-file-uploader .fd-button{background-color:var(--sapButton_Lite_Background);border-color:var(--sapButton_Lite_BorderColor);color:var(--sapButton_Lite_TextColor)}:host .hide-file-uploader{visibility:hidden;height:0;width:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ContentDensityDirective, selector: "[fdContentDensity]:not([fdCompact]):not([fdCondensed]):not([fdCozy]), [fdCompact]:not([fdContentDensity]):not([fdCondensed]):not([fdCozy]), [fdCondensed]:not([fdContentDensity]):not([fdCompact]):not([fdCozy]), [fdCozy]:not([fdContentDensity]):not([fdCompact]):not([fdCondensed])", inputs: ["fdContentDensity", "fdCompact", "fdCondensed", "fdCozy"], exportAs: ["fdContentDensity"] }, { kind: "component", type: i4.AvatarComponent, selector: "fd-avatar", inputs: ["class", "id", "ariaLabel", "ariaLabelledby", "label", "size", "glyph", "zoomGlyph", "circle", "transparent", "contain", "placeholder", "tile", "border", "colorAccent", "random", "clickable", "backgroundImage", "image", "alterIcon", "backupImage"], outputs: ["avatarClicked", "zoomGlyphClicked"] }, { kind: "component", type: i5.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i6.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: i7.FormControlComponent, selector: "[fd-form-control]", inputs: ["state", "type", "class"] }, { kind: "directive", type: i7.InputFormControlDirective, selector: "input[fd-form-control]" }, { kind: "component", type: i8.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "class", "ariaLabel"] }, { kind: "component", type: i9.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline"], outputs: ["focusEscapeList"] }, { kind: "component", type: i9.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i9.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i9.ListSecondaryDirective, selector: "[fd-list-secondary] ,[fdListSecondary]" }, { kind: "directive", type: i9.ListBylineDirective, selector: "[fdListByline], [fd-list-byline]", inputs: ["twoCol", "wrap"] }, { kind: "directive", type: i9.ListBylineLeftDirective, selector: "[fdListBylineLeft], [fd-list-byline-left]", inputs: ["wrap"] }, { kind: "directive", type: i9.ListBylineRightDirective, selector: "[fdListBylineRight], [fd-list-byline-right]", inputs: ["status", "wrap"] }, { kind: "directive", type: i9.ListContentDirective, selector: "[fdListContent], [fd-list-content]", inputs: ["twoCol"] }, { kind: "directive", type: i9.ListThumbnailDirective, selector: "[fdListThumbnail], [fd-list-thumbnail]" }, { kind: "component", type: i10.ObjectStatusComponent, selector: "[fd-object-status]", inputs: ["class", "status", "glyph", "label", "glyphAriaLabel", "indicationColor", "clickable", "inverted", "large"] }, { kind: "component", type: i11.ToolbarComponent, selector: "fd-toolbar", inputs: ["class", "shouldOverflow", "fdType", "hasTitle", "title", "active", "clearBorder", "forceOverflow", "tabindex"] }, { kind: "directive", type: i11.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "component", type: i12.SliderComponent, selector: "fd-slider", inputs: ["id", "class", "ariaLabelledBy", "ariaLabel", "min", "max", "step", "jump", "tickmarksBetweenLabels", "mode", "showTicks", "showTicksLabels", "customValues", "tooltipMode", "hideProgressBar", "disabled", "singleSliderCurrentValuePrefix", "rangeSliderHandle1CurrentValuePrefix", "rangeSliderHandle2CurrentValuePrefix", "value"] }, { kind: "component", type: i13.ProgressIndicatorComponent, selector: "fd-progress-indicator", inputs: ["valueText", "unit", "valueMin", "valueMax", "valueNow", "state", "animate"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.KeyValuePipe, name: "keyvalue" }, { kind: "pipe", type: i14.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i15.UploadFileStatusPipe, name: "uploadFileStatus" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
24
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaListFileLinearComponent, decorators: [{
|
|
25
38
|
type: Component,
|
|
26
|
-
args: [{ selector: 'bsu-barsa-list-file-linear', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UploadService], template: "<fd-
|
|
39
|
+
args: [{ selector: 'bsu-barsa-list-file-linear', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UploadService], template: "<ul fd-list class=\"file-viewer-attachments\" *ngIf=\"parameters.ModeValue === '1'\">\n <ng-container *ngFor=\"let file of value\">\n <li fd-list-item *ngIf=\"!file.IsDeleted\" style=\"background-color: #f5f5f5; margin: 0 0 0 30%; width: 100%\">\n <input\n style=\"width: 90%\"\n *ngIf=\"file.inEdit\"\n fd-form-control\n [(ngModel)]=\"file.FileName\"\n (click)=\"$event.preventDefault(); $event.stopPropagation()\"\n (keydown.enter)=\"onHandleRenameFile(file)\"\n />\n <span *ngIf=\"!file.inEdit\" fd-list-title>\n {{ file.FileName }}\n </span>\n <span fd-list-secondary>\n <button\n ariaLabel=\"Edit Or Save\"\n fdType=\"transparent\"\n class=\"fd-button--compact\"\n fd-button\n fdCompact\n [glyph]=\"file.inEdit ? 'save' : 'edit'\"\n (click)=\"onHandleRenameFile(file)\"\n ></button>\n <button\n *ngIf=\"!file.inEdit\"\n ariaLabel=\"Remove\"\n fdType=\"transparent\"\n title=\"Remove\"\n fd-button\n glyph=\"delete\"\n (click)=\"onFileDeleted(file.Id)\"\n ></button>\n </span>\n </li>\n </ng-container>\n <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n <ng-container *ngFor=\"let file of valueExtra | keyvalue\">\n <li\n *ngIf=\"file.value.UploadState === 'Uploading'\"\n style=\"background-color: #f5f5f5; margin: 0 0 0 30%; width: 100%\"\n >\n <fd-progress-indicator\n *ngIf=\"file.value.Progress\"\n state=\"informative\"\n [valueNow]=\"file.value.Progress\"\n ></fd-progress-indicator>\n </li>\n </ng-container>\n </ng-container>\n</ul>\n\n<ul fd-list [byline]=\"true\" *ngIf=\"parameters.ModeValue === '2'\">\n <ng-container *ngIf=\"fileCount$ | async as fileCount\">\n <li fd-list-item *ngIf=\"fileCount === 0\">\n <div fd-list-content style=\"text-align: center\">\n <span>{{ 'NoFiles' | bbbTranslate }}</span>\n </div>\n </li>\n </ng-container>\n <ng-container *ngFor=\"let file of value\">\n <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n <li fd-list-item *ngIf=\"!file.IsDeleted\">\n <span fd-list-thumbnail>\n <fd-icon\n *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\n [glyph]=\"valueExtra[file.Id].FileUrl\"\n ></fd-icon>\n <ng-template #isImage>\n <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\n </ng-template>\n </span>\n <!-- for byline, fd-list-content is mandatory -->\n <div fd-list-content>\n <div fd-list-title>{{ file.FileName }}</div>\n <div fd-list-byline [twoCol]=\"true\">\n <div fd-list-byline-left></div>\n <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\n <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\n <ng-container *ngIf=\"file.IsNew\">\n <span\n fd-toolbar-item\n fd-object-status\n [status]=\"file.Id | uploadFileStatus: valueExtra\"\n [label]=\"valueExtra[file.Id]?.UploadState || ''\"\n [title]=\"valueExtra[file.Id]?.UploadState\"\n [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\n ></span>\n <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\n <fd-slider\n [contentDensity]=\"(contentDensity$ | async)!!\"\n [(ngModel)]=\"valueExtra[file.Id].Progress\"\n [name]=\"'filerLinear_' + id\"\n fd-toolbar-item\n [id]=\"id\"\n [min]=\"0\"\n [max]=\"100\"\n [step]=\"1\"\n >\n </fd-slider>\n </ng-container>\n </ng-container>\n </fd-toolbar>\n </div>\n </div>\n </div>\n <button\n *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n (click)=\"onFileDeleted(file.Id)\"\n ></button>\n <button\n *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\n fd-button\n [fdType]=\"'transparent'\"\n [glyph]=\"'stop'\"\n (click)=\"onTerminate(file)\"\n ></button>\n <button\n *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\n fd-button\n [fdType]=\"'transparent'\"\n [glyph]=\"'refresh'\"\n (click)=\"onRetry(file)\"\n ></button>\n </li>\n </ng-container>\n </ng-container>\n</ul>\n<fd-toolbar\n style=\"display: block\"\n [style.height.px]=\"parameters.ModeValue === '1' ? 0 : null\"\n [fdType]=\"'transparent'\"\n [clearBorder]=\"true\"\n *ngIf=\"(disableOrReadonly$ | async) !== true\"\n>\n <fd-file-uploader\n fd-toolbar-item\n [class.hide-file-uploader]=\"parameters?.HideAttachButton\"\n [id]=\"id\"\n [name]=\"id\"\n [placeholder]=\"'AttachFile' | bbbTranslate\"\n [buttonLabel]=\"'AttachFile' | bbbTranslate\"\n [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\n [accept]=\"Setting.ValidExtensions || ''\"\n [multiple]=\"maxFileCount > 1\"\n (selectedFilesChanged)=\"onFileSelection($event)\"\n [contentDensity]=\"(contentDensity$ | async)!!\"\n ></fd-file-uploader>\n</fd-toolbar>\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 ::ng-deep fd-file-uploader .fd-button{background-color:var(--sapButton_Lite_Background);border-color:var(--sapButton_Lite_BorderColor);color:var(--sapButton_Lite_TextColor)}:host .hide-file-uploader{visibility:hidden;height:0;width:0}\n"] }]
|
|
27
40
|
}] });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-list-file-linear.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-list-file-linear/barsa-list-file-linear.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-list-file-linear/barsa-list-file-linear.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAAE,aAAa,EAAsB,MAAM,sBAAsB,CAAC;AACzE,OAAO,EAAE,4BAA4B,EAAE,MAAM,8DAA8D,CAAC;;;;;;;;;;;;;;AAS5G,MAAM,OAAO,4BAA6B,SAAQ,4BAA4B;IAC1E,OAAO,CAAC,cAAkC;QACtC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;IAC/B,CAAC;;yHAHQ,4BAA4B;6GAA5B,4BAA4B,qDAF1B,CAAC,aAAa,CAAC,iDCT9B,orJA6FA;2FDlFa,4BAA4B;kBAPxC,SAAS;+BACI,4BAA4B,mBAGrB,uBAAuB,CAAC,MAAM,aACpC,CAAC,aAAa,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component } from '@angular/core';\r\nimport { UploadService, FileAttachmentInfo } from 'barsa-novin-ray-core';\r\nimport { UiFileLinearListBoxComponent } from '../ui-file-linear-list-box/ui-file-linear-list-box.component';\r\n\r\n@Component({\r\n    selector: 'bsu-barsa-list-file-linear',\r\n    templateUrl: './barsa-list-file-linear.component.html',\r\n    styleUrls: ['./barsa-list-file-linear.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [UploadService]\r\n})\r\nexport class BarsaListFileLinearComponent extends UiFileLinearListBoxComponent {\r\n    onRetry(fileAttachment: FileAttachmentInfo): void {\r\n        this.retry(fileAttachment);\r\n    }\r\n}\r\n","<fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\" *ngIf=\"(disableOrReadonly$ | async) === false\">\n    <fd-file-uploader\n        fd-toolbar-item\n        [id]=\"id\"\n        [name]=\"id\"\n        [placeholder]=\"'AttachFile' | bbbTranslate\"\n        [buttonLabel]=\"'AttachFile' | bbbTranslate\"\n        [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\n        [accept]=\"Setting.ValidExtensions || ''\"\n        [multiple]=\"maxFileCount > 1\"\n        (selectedFilesChanged)=\"onFileSelection($event)\"\n        [contentDensity]=\"(contentDensity$ | async)!!\"\n    ></fd-file-uploader>\n</fd-toolbar>\n<ul fd-list [byline]=\"true\">\n    <ng-container *ngIf=\"fileCount$ | async as fileCount\">\n        <li fd-list-item *ngIf=\"fileCount === 0\">\n            <div fd-list-content style=\"text-align: center\">\n                <span>{{ 'NoFiles' | bbbTranslate }}</span>\n            </div>\n        </li>\n    </ng-container>\n    <ng-container *ngFor=\"let file of value\">\n        <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n            <li fd-list-item *ngIf=\"!file.IsDeleted\">\n                <span fd-list-thumbnail>\n                    <fd-icon\n                        *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\n                        [glyph]=\"valueExtra[file.Id].FileUrl\"\n                    ></fd-icon>\n                    <ng-template #isImage>\n                        <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\n                    </ng-template>\n                </span>\n                <!-- for byline, fd-list-content is mandatory -->\n                <div fd-list-content>\n                    <div fd-list-title>{{ file.FileName }}</div>\n                    <div fd-list-byline [twoCol]=\"true\">\n                        <div fd-list-byline-left></div>\n                        <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\n                            <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\n                                <ng-container *ngIf=\"file.IsNew\">\n                                    <span\n                                        fd-toolbar-item\n                                        fd-object-status\n                                        [status]=\"file.Id | uploadFileStatus: valueExtra\"\n                                        [label]=\"valueExtra[file.Id]?.UploadState || ''\"\n                                        [title]=\"valueExtra[file.Id]?.UploadState\"\n                                        [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\n                                    ></span>\n                                    <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\n                                        <fd-slider\n                                            [contentDensity]=\"(contentDensity$ | async)!!\"\n                                            [(ngModel)]=\"valueExtra[file.Id].Progress\"\n                                            [name]=\"'filerLinear_' + id\"\n                                            fd-toolbar-item\n                                            [id]=\"id\"\n                                            [min]=\"0\"\n                                            [max]=\"100\"\n                                            [step]=\"1\"\n                                        >\n                                        </fd-slider>\n                                    </ng-container>\n                                </ng-container>\n                            </fd-toolbar>\n                        </div>\n                    </div>\n                </div>\n                <button\n                    *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\n                    fd-button\n                    fdType=\"transparent\"\n                    glyph=\"decline\"\n                    (click)=\"onFileDeleted(file.Id)\"\n                ></button>\n                <button\n                    *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\n                    fd-button\n                    [fdType]=\"'transparent'\"\n                    [glyph]=\"'stop'\"\n                    (click)=\"onTerminate(file)\"\n                ></button>\n                <button\n                    *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\n                    fd-button\n                    [fdType]=\"'transparent'\"\n                    [glyph]=\"'refresh'\"\n                    (click)=\"onRetry(file)\"\n                ></button>\n            </li>\n        </ng-container>\n    </ng-container>\n</ul>\n"]}
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-list-file-linear.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-list-file-linear/barsa-list-file-linear.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-list-file-linear/barsa-list-file-linear.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAAE,aAAa,EAAsB,MAAM,sBAAsB,CAAC;AACzE,OAAO,EAAE,4BAA4B,EAAE,MAAM,8DAA8D,CAAC;AAC5G,OAAO,EAAuB,QAAQ,EAAE,MAAM,sBAAsB,CAAC;;;;;;;;;;;;;;;;;AASrE,MAAM,OAAO,4BAA6B,SAAQ,4BAA4B;IAE1E,OAAO,CAAC,cAAkC;QACtC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;IAC/B,CAAC;IACD,kBAAkB,CAAC,IAAwB;QACvC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YACd,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACtB;aAAM;YACH,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAC9B,6BAA6B,EAC7B,EAAE,WAAW,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,EACrD,CAAC,CAAC,EAAE,EAAE,GAAE,CAAC,EACT,CAAC,CAAC,EAAE,EAAE,GAAE,CAAC,EACT,IAAI,EACJ,IAAI,CACP,CAAC;SACL;IACL,CAAC;;yHAnBQ,4BAA4B;6GAA5B,4BAA4B,qDAF1B,CAAC,aAAa,CAAC,iDCV9B,q/NAwJA;2FD5Ia,4BAA4B;kBAPxC,SAAS;+BACI,4BAA4B,mBAGrB,uBAAuB,CAAC,MAAM,aACpC,CAAC,aAAa,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { UploadService, FileAttachmentInfo } from 'barsa-novin-ray-core';\nimport { UiFileLinearListBoxComponent } from '../ui-file-linear-list-box/ui-file-linear-list-box.component';\nimport { MetaobjectDataModel, BarsaApi } from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-barsa-list-file-linear',\n    templateUrl: './barsa-list-file-linear.component.html',\n    styleUrls: ['./barsa-list-file-linear.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [UploadService]\n})\nexport class BarsaListFileLinearComponent extends UiFileLinearListBoxComponent {\n    parameters: BarsaListFileLinearSetting;\n    onRetry(fileAttachment: FileAttachmentInfo): void {\n        this.retry(fileAttachment);\n    }\n    onHandleRenameFile(file: FileAttachmentInfo): void {\n        if (!file.inEdit) {\n            file.inEdit = true;\n        } else {\n            file.inEdit = false;\n            BarsaApi.Common.Ajax.GetServerData(\n                'Form94.RenameFileAttachment',\n                { renameModel: { Id: file.Id, Name: file.FileName } },\n                (_) => {},\n                (_) => {},\n                null,\n                this\n            );\n        }\n    }\n}\n\ninterface BarsaListFileLinearSetting extends MetaobjectDataModel {\n    HideAttachButton: boolean;\n    ModeValue: string;\n    ModeValue$Caption: string;\n}\n","<ul fd-list class=\"file-viewer-attachments\" *ngIf=\"parameters.ModeValue === '1'\">\n    <ng-container *ngFor=\"let file of value\">\n        <li fd-list-item *ngIf=\"!file.IsDeleted\" style=\"background-color: #f5f5f5; margin: 0 0 0 30%; width: 100%\">\n            <input\n                style=\"width: 90%\"\n                *ngIf=\"file.inEdit\"\n                fd-form-control\n                [(ngModel)]=\"file.FileName\"\n                (click)=\"$event.preventDefault(); $event.stopPropagation()\"\n                (keydown.enter)=\"onHandleRenameFile(file)\"\n            />\n            <span *ngIf=\"!file.inEdit\" fd-list-title>\n                {{ file.FileName }}\n            </span>\n            <span fd-list-secondary>\n                <button\n                    ariaLabel=\"Edit Or Save\"\n                    fdType=\"transparent\"\n                    class=\"fd-button--compact\"\n                    fd-button\n                    fdCompact\n                    [glyph]=\"file.inEdit ? 'save' : 'edit'\"\n                    (click)=\"onHandleRenameFile(file)\"\n                ></button>\n                <button\n                    *ngIf=\"!file.inEdit\"\n                    ariaLabel=\"Remove\"\n                    fdType=\"transparent\"\n                    title=\"Remove\"\n                    fd-button\n                    glyph=\"delete\"\n                    (click)=\"onFileDeleted(file.Id)\"\n                ></button>\n            </span>\n        </li>\n    </ng-container>\n    <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n        <ng-container *ngFor=\"let file of valueExtra | keyvalue\">\n            <li\n                *ngIf=\"file.value.UploadState === 'Uploading'\"\n                style=\"background-color: #f5f5f5; margin: 0 0 0 30%; width: 100%\"\n            >\n                <fd-progress-indicator\n                    *ngIf=\"file.value.Progress\"\n                    state=\"informative\"\n                    [valueNow]=\"file.value.Progress\"\n                ></fd-progress-indicator>\n            </li>\n        </ng-container>\n    </ng-container>\n</ul>\n\n<ul fd-list [byline]=\"true\" *ngIf=\"parameters.ModeValue === '2'\">\n    <ng-container *ngIf=\"fileCount$ | async as fileCount\">\n        <li fd-list-item *ngIf=\"fileCount === 0\">\n            <div fd-list-content style=\"text-align: center\">\n                <span>{{ 'NoFiles' | bbbTranslate }}</span>\n            </div>\n        </li>\n    </ng-container>\n    <ng-container *ngFor=\"let file of value\">\n        <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n            <li fd-list-item *ngIf=\"!file.IsDeleted\">\n                <span fd-list-thumbnail>\n                    <fd-icon\n                        *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\n                        [glyph]=\"valueExtra[file.Id].FileUrl\"\n                    ></fd-icon>\n                    <ng-template #isImage>\n                        <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\n                    </ng-template>\n                </span>\n                <!-- for byline, fd-list-content is mandatory -->\n                <div fd-list-content>\n                    <div fd-list-title>{{ file.FileName }}</div>\n                    <div fd-list-byline [twoCol]=\"true\">\n                        <div fd-list-byline-left></div>\n                        <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\n                            <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\n                                <ng-container *ngIf=\"file.IsNew\">\n                                    <span\n                                        fd-toolbar-item\n                                        fd-object-status\n                                        [status]=\"file.Id | uploadFileStatus: valueExtra\"\n                                        [label]=\"valueExtra[file.Id]?.UploadState || ''\"\n                                        [title]=\"valueExtra[file.Id]?.UploadState\"\n                                        [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\n                                    ></span>\n                                    <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\n                                        <fd-slider\n                                            [contentDensity]=\"(contentDensity$ | async)!!\"\n                                            [(ngModel)]=\"valueExtra[file.Id].Progress\"\n                                            [name]=\"'filerLinear_' + id\"\n                                            fd-toolbar-item\n                                            [id]=\"id\"\n                                            [min]=\"0\"\n                                            [max]=\"100\"\n                                            [step]=\"1\"\n                                        >\n                                        </fd-slider>\n                                    </ng-container>\n                                </ng-container>\n                            </fd-toolbar>\n                        </div>\n                    </div>\n                </div>\n                <button\n                    *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\n                    fd-button\n                    fdType=\"transparent\"\n                    glyph=\"decline\"\n                    (click)=\"onFileDeleted(file.Id)\"\n                ></button>\n                <button\n                    *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\n                    fd-button\n                    [fdType]=\"'transparent'\"\n                    [glyph]=\"'stop'\"\n                    (click)=\"onTerminate(file)\"\n                ></button>\n                <button\n                    *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\n                    fd-button\n                    [fdType]=\"'transparent'\"\n                    [glyph]=\"'refresh'\"\n                    (click)=\"onRetry(file)\"\n                ></button>\n            </li>\n        </ng-container>\n    </ng-container>\n</ul>\n<fd-toolbar\n    style=\"display: block\"\n    [style.height.px]=\"parameters.ModeValue === '1' ? 0 : null\"\n    [fdType]=\"'transparent'\"\n    [clearBorder]=\"true\"\n    *ngIf=\"(disableOrReadonly$ | async) !== true\"\n>\n    <fd-file-uploader\n        fd-toolbar-item\n        [class.hide-file-uploader]=\"parameters?.HideAttachButton\"\n        [id]=\"id\"\n        [name]=\"id\"\n        [placeholder]=\"'AttachFile' | bbbTranslate\"\n        [buttonLabel]=\"'AttachFile' | bbbTranslate\"\n        [buttonAriaLabel]=\"'AttachFile' | bbbTranslate\"\n        [accept]=\"Setting.ValidExtensions || ''\"\n        [multiple]=\"maxFileCount > 1\"\n        (selectedFilesChanged)=\"onFileSelection($event)\"\n        [contentDensity]=\"(contentDensity$ | async)!!\"\n    ></fd-file-uploader>\n</fd-toolbar>\n"]}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { UploadService } from 'barsa-novin-ray-core';
|
|
3
|
+
import { UiFileLinearListBoxComponent } from '../ui-file-linear-list-box/ui-file-linear-list-box.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@angular/forms";
|
|
7
|
+
import * as i3 from "@fundamental-ngx/core/content-density";
|
|
8
|
+
import * as i4 from "@fundamental-ngx/core/avatar";
|
|
9
|
+
import * as i5 from "@fundamental-ngx/core/button";
|
|
10
|
+
import * as i6 from "@fundamental-ngx/core/form";
|
|
11
|
+
import * as i7 from "@fundamental-ngx/core/icon";
|
|
12
|
+
import * as i8 from "@fundamental-ngx/core/list";
|
|
13
|
+
import * as i9 from "@fundamental-ngx/core/object-status";
|
|
14
|
+
import * as i10 from "@fundamental-ngx/core/toolbar";
|
|
15
|
+
import * as i11 from "@fundamental-ngx/core/slider";
|
|
16
|
+
import * as i12 from "barsa-novin-ray-core";
|
|
17
|
+
import * as i13 from "../upload-file-status.pipe";
|
|
18
|
+
export class BarsaListFileLinearGmailComponent extends UiFileLinearListBoxComponent {
|
|
19
|
+
onRetry(fileAttachment) {
|
|
20
|
+
this.retry(fileAttachment);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
BarsaListFileLinearGmailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaListFileLinearGmailComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
24
|
+
BarsaListFileLinearGmailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaListFileLinearGmailComponent, selector: "bsu-barsa-list-file-linear-gmail", providers: [UploadService], usesInheritance: true, ngImport: i0, template: "<ul fd-list>\n <ng-container *ngFor=\"let item of value\">\n <li *ngIf=\"!item.IsDeleted\" fd-list-item style=\"background-color: #f5f5f5; margin: 0.5rem 0 0 30%\">\n <input\n style=\"width: 90%\"\n *ngIf=\"item.inEdit\"\n fd-form-control\n [value]=\"item.fileName\"\n (click)=\"$event.preventDefault(); $event.stopPropagation()\"\n />\n <span *ngIf=\"!item.inEdit\" fd-list-title>\n {{ item.fileName }}\n </span>\n <span fd-list-secondary>\n <button\n ariaLabel=\"Edit Or Save\"\n fdType=\"transparent\"\n class=\"fd-button--compact\"\n fd-button\n fdCompact\n [glyph]=\"item.inEdit ? 'save' : 'edit'\"\n (click)=\"item.inEdit = !item.inEdit\"\n ></button>\n <button\n *ngIf=\"!item.inEdit\"\n ariaLabel=\"Remove\"\n fdType=\"transparent\"\n title=\"Remove\"\n fd-button\n glyph=\"delete\"\n ></button>\n </span>\n </li>\n </ng-container>\n</ul>\n<ul fd-list [byline]=\"true\">\n <ng-container *ngIf=\"fileCount$ | async as fileCount\">\n <li fd-list-item *ngIf=\"fileCount === 0\">\n <div fd-list-content style=\"text-align: center\">\n <span>{{ 'NoFiles' | bbbTranslate }}</span>\n </div>\n </li>\n </ng-container>\n <ng-container *ngFor=\"let file of value\">\n <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n <li fd-list-item *ngIf=\"!file.IsDeleted\">\n <span fd-list-thumbnail>\n <fd-icon\n *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\n [glyph]=\"valueExtra[file.Id].FileUrl\"\n ></fd-icon>\n <ng-template #isImage>\n <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\n </ng-template>\n </span>\n <!-- for byline, fd-list-content is mandatory -->\n <div fd-list-content>\n <div fd-list-title>{{ file.FileName }}</div>\n <div fd-list-byline [twoCol]=\"true\">\n <div fd-list-byline-left></div>\n <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\n <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\n <ng-container *ngIf=\"file.IsNew\">\n <span\n fd-toolbar-item\n fd-object-status\n [status]=\"file.Id | uploadFileStatus: valueExtra\"\n [label]=\"valueExtra[file.Id]?.UploadState || ''\"\n [title]=\"valueExtra[file.Id]?.UploadState\"\n [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\n ></span>\n <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\n <fd-slider\n [contentDensity]=\"(contentDensity$ | async)!!\"\n [(ngModel)]=\"valueExtra[file.Id].Progress\"\n [name]=\"'filerLinear_' + id\"\n fd-toolbar-item\n [id]=\"id\"\n [min]=\"0\"\n [max]=\"100\"\n [step]=\"1\"\n >\n </fd-slider>\n </ng-container>\n </ng-container>\n </fd-toolbar>\n </div>\n </div>\n </div>\n <button\n *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n (click)=\"onFileDeleted(file.Id)\"\n ></button>\n <button\n *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\n fd-button\n [fdType]=\"'transparent'\"\n [glyph]=\"'stop'\"\n (click)=\"onTerminate(file)\"\n ></button>\n <button\n *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\n fd-button\n [fdType]=\"'transparent'\"\n [glyph]=\"'refresh'\"\n (click)=\"onRetry(file)\"\n ></button>\n </li>\n </ng-container>\n </ng-container>\n</ul>\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}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ContentDensityDirective, selector: "[fdContentDensity]:not([fdCompact]):not([fdCondensed]):not([fdCozy]), [fdCompact]:not([fdContentDensity]):not([fdCondensed]):not([fdCozy]), [fdCondensed]:not([fdContentDensity]):not([fdCompact]):not([fdCozy]), [fdCozy]:not([fdContentDensity]):not([fdCompact]):not([fdCondensed])", inputs: ["fdContentDensity", "fdCompact", "fdCondensed", "fdCozy"], exportAs: ["fdContentDensity"] }, { kind: "component", type: i4.AvatarComponent, selector: "fd-avatar", inputs: ["class", "id", "ariaLabel", "ariaLabelledby", "label", "size", "glyph", "zoomGlyph", "circle", "transparent", "contain", "placeholder", "tile", "border", "colorAccent", "random", "clickable", "backgroundImage", "image", "alterIcon", "backupImage"], outputs: ["avatarClicked", "zoomGlyphClicked"] }, { kind: "component", type: i5.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i6.FormControlComponent, selector: "[fd-form-control]", inputs: ["state", "type", "class"] }, { kind: "directive", type: i6.InputFormControlDirective, selector: "input[fd-form-control]" }, { kind: "component", type: i7.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "class", "ariaLabel"] }, { kind: "component", type: i8.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline"], outputs: ["focusEscapeList"] }, { kind: "component", type: i8.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i8.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i8.ListSecondaryDirective, selector: "[fd-list-secondary] ,[fdListSecondary]" }, { kind: "directive", type: i8.ListBylineDirective, selector: "[fdListByline], [fd-list-byline]", inputs: ["twoCol", "wrap"] }, { kind: "directive", type: i8.ListBylineLeftDirective, selector: "[fdListBylineLeft], [fd-list-byline-left]", inputs: ["wrap"] }, { kind: "directive", type: i8.ListBylineRightDirective, selector: "[fdListBylineRight], [fd-list-byline-right]", inputs: ["status", "wrap"] }, { kind: "directive", type: i8.ListContentDirective, selector: "[fdListContent], [fd-list-content]", inputs: ["twoCol"] }, { kind: "directive", type: i8.ListThumbnailDirective, selector: "[fdListThumbnail], [fd-list-thumbnail]" }, { kind: "component", type: i9.ObjectStatusComponent, selector: "[fd-object-status]", inputs: ["class", "status", "glyph", "label", "glyphAriaLabel", "indicationColor", "clickable", "inverted", "large"] }, { kind: "component", type: i10.ToolbarComponent, selector: "fd-toolbar", inputs: ["class", "shouldOverflow", "fdType", "hasTitle", "title", "active", "clearBorder", "forceOverflow", "tabindex"] }, { kind: "directive", type: i10.ToolbarItemDirective, selector: "[fd-toolbar-item]" }, { kind: "component", type: i11.SliderComponent, selector: "fd-slider", inputs: ["id", "class", "ariaLabelledBy", "ariaLabel", "min", "max", "step", "jump", "tickmarksBetweenLabels", "mode", "showTicks", "showTicksLabels", "customValues", "tooltipMode", "hideProgressBar", "disabled", "singleSliderCurrentValuePrefix", "rangeSliderHandle1CurrentValuePrefix", "rangeSliderHandle2CurrentValuePrefix", "value"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i12.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i13.UploadFileStatusPipe, name: "uploadFileStatus" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaListFileLinearGmailComponent, decorators: [{
|
|
26
|
+
type: Component,
|
|
27
|
+
args: [{ selector: 'bsu-barsa-list-file-linear-gmail', changeDetection: ChangeDetectionStrategy.OnPush, providers: [UploadService], template: "<ul fd-list>\n <ng-container *ngFor=\"let item of value\">\n <li *ngIf=\"!item.IsDeleted\" fd-list-item style=\"background-color: #f5f5f5; margin: 0.5rem 0 0 30%\">\n <input\n style=\"width: 90%\"\n *ngIf=\"item.inEdit\"\n fd-form-control\n [value]=\"item.fileName\"\n (click)=\"$event.preventDefault(); $event.stopPropagation()\"\n />\n <span *ngIf=\"!item.inEdit\" fd-list-title>\n {{ item.fileName }}\n </span>\n <span fd-list-secondary>\n <button\n ariaLabel=\"Edit Or Save\"\n fdType=\"transparent\"\n class=\"fd-button--compact\"\n fd-button\n fdCompact\n [glyph]=\"item.inEdit ? 'save' : 'edit'\"\n (click)=\"item.inEdit = !item.inEdit\"\n ></button>\n <button\n *ngIf=\"!item.inEdit\"\n ariaLabel=\"Remove\"\n fdType=\"transparent\"\n title=\"Remove\"\n fd-button\n glyph=\"delete\"\n ></button>\n </span>\n </li>\n </ng-container>\n</ul>\n<ul fd-list [byline]=\"true\">\n <ng-container *ngIf=\"fileCount$ | async as fileCount\">\n <li fd-list-item *ngIf=\"fileCount === 0\">\n <div fd-list-content style=\"text-align: center\">\n <span>{{ 'NoFiles' | bbbTranslate }}</span>\n </div>\n </li>\n </ng-container>\n <ng-container *ngFor=\"let file of value\">\n <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n <li fd-list-item *ngIf=\"!file.IsDeleted\">\n <span fd-list-thumbnail>\n <fd-icon\n *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\n [glyph]=\"valueExtra[file.Id].FileUrl\"\n ></fd-icon>\n <ng-template #isImage>\n <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\n </ng-template>\n </span>\n <!-- for byline, fd-list-content is mandatory -->\n <div fd-list-content>\n <div fd-list-title>{{ file.FileName }}</div>\n <div fd-list-byline [twoCol]=\"true\">\n <div fd-list-byline-left></div>\n <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\n <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\n <ng-container *ngIf=\"file.IsNew\">\n <span\n fd-toolbar-item\n fd-object-status\n [status]=\"file.Id | uploadFileStatus: valueExtra\"\n [label]=\"valueExtra[file.Id]?.UploadState || ''\"\n [title]=\"valueExtra[file.Id]?.UploadState\"\n [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\n ></span>\n <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\n <fd-slider\n [contentDensity]=\"(contentDensity$ | async)!!\"\n [(ngModel)]=\"valueExtra[file.Id].Progress\"\n [name]=\"'filerLinear_' + id\"\n fd-toolbar-item\n [id]=\"id\"\n [min]=\"0\"\n [max]=\"100\"\n [step]=\"1\"\n >\n </fd-slider>\n </ng-container>\n </ng-container>\n </fd-toolbar>\n </div>\n </div>\n </div>\n <button\n *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n (click)=\"onFileDeleted(file.Id)\"\n ></button>\n <button\n *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\n fd-button\n [fdType]=\"'transparent'\"\n [glyph]=\"'stop'\"\n (click)=\"onTerminate(file)\"\n ></button>\n <button\n *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\n fd-button\n [fdType]=\"'transparent'\"\n [glyph]=\"'refresh'\"\n (click)=\"onRetry(file)\"\n ></button>\n </li>\n </ng-container>\n </ng-container>\n</ul>\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}\n"] }]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-list-file-linear-gmail.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-list-file-linear-gmail/barsa-list-file-linear-gmail.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-list-file-linear-gmail/barsa-list-file-linear-gmail.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAAE,aAAa,EAAsB,MAAM,sBAAsB,CAAC;AACzE,OAAO,EAAE,4BAA4B,EAAE,MAAM,8DAA8D,CAAC;;;;;;;;;;;;;;;AAS5G,MAAM,OAAO,iCAAkC,SAAQ,4BAA4B;IAC/E,OAAO,CAAC,cAAkC;QACtC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;IAC/B,CAAC;;8HAHQ,iCAAiC;kHAAjC,iCAAiC,2DAF/B,CAAC,aAAa,CAAC,iDCT9B,q3KAkHA;2FDvGa,iCAAiC;kBAP7C,SAAS;+BACI,kCAAkC,mBAG3B,uBAAuB,CAAC,MAAM,aACpC,CAAC,aAAa,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { UploadService, FileAttachmentInfo } from 'barsa-novin-ray-core';\nimport { UiFileLinearListBoxComponent } from '../ui-file-linear-list-box/ui-file-linear-list-box.component';\n\n@Component({\n    selector: 'bsu-barsa-list-file-linear-gmail',\n    templateUrl: './barsa-list-file-linear-gmail.component.html',\n    styleUrls: ['./barsa-list-file-linear-gmail.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [UploadService]\n})\nexport class BarsaListFileLinearGmailComponent extends UiFileLinearListBoxComponent {\n    onRetry(fileAttachment: FileAttachmentInfo): void {\n        this.retry(fileAttachment);\n    }\n}\n","<ul fd-list>\n    <ng-container *ngFor=\"let item of value\">\n        <li *ngIf=\"!item.IsDeleted\" fd-list-item style=\"background-color: #f5f5f5; margin: 0.5rem 0 0 30%\">\n            <input\n                style=\"width: 90%\"\n                *ngIf=\"item.inEdit\"\n                fd-form-control\n                [value]=\"item.fileName\"\n                (click)=\"$event.preventDefault(); $event.stopPropagation()\"\n            />\n            <span *ngIf=\"!item.inEdit\" fd-list-title>\n                {{ item.fileName }}\n            </span>\n            <span fd-list-secondary>\n                <button\n                    ariaLabel=\"Edit Or Save\"\n                    fdType=\"transparent\"\n                    class=\"fd-button--compact\"\n                    fd-button\n                    fdCompact\n                    [glyph]=\"item.inEdit ? 'save' : 'edit'\"\n                    (click)=\"item.inEdit = !item.inEdit\"\n                ></button>\n                <button\n                    *ngIf=\"!item.inEdit\"\n                    ariaLabel=\"Remove\"\n                    fdType=\"transparent\"\n                    title=\"Remove\"\n                    fd-button\n                    glyph=\"delete\"\n                ></button>\n            </span>\n        </li>\n    </ng-container>\n</ul>\n<ul fd-list [byline]=\"true\">\n    <ng-container *ngIf=\"fileCount$ | async as fileCount\">\n        <li fd-list-item *ngIf=\"fileCount === 0\">\n            <div fd-list-content style=\"text-align: center\">\n                <span>{{ 'NoFiles' | bbbTranslate }}</span>\n            </div>\n        </li>\n    </ng-container>\n    <ng-container *ngFor=\"let file of value\">\n        <ng-container *ngIf=\"valueExtra$ | async as valueExtra\">\n            <li fd-list-item *ngIf=\"!file.IsDeleted\">\n                <span fd-list-thumbnail>\n                    <fd-icon\n                        *ngIf=\"valueExtra[file.Id].IsIcon; else isImage\"\n                        [glyph]=\"valueExtra[file.Id].FileUrl\"\n                    ></fd-icon>\n                    <ng-template #isImage>\n                        <fd-avatar size=\"m\" [image]=\"valueExtra[file.Id].FileUrl || ''\"></fd-avatar>\n                    </ng-template>\n                </span>\n                <!-- for byline, fd-list-content is mandatory -->\n                <div fd-list-content>\n                    <div fd-list-title>{{ file.FileName }}</div>\n                    <div fd-list-byline [twoCol]=\"true\">\n                        <div fd-list-byline-left></div>\n                        <div fd-list-byline-right style=\"display: flex; justify-content: flex-end\">\n                            <fd-toolbar [fdType]=\"'transparent'\" [clearBorder]=\"true\">\n                                <ng-container *ngIf=\"file.IsNew\">\n                                    <span\n                                        fd-toolbar-item\n                                        fd-object-status\n                                        [status]=\"file.Id | uploadFileStatus: valueExtra\"\n                                        [label]=\"valueExtra[file.Id]?.UploadState || ''\"\n                                        [title]=\"valueExtra[file.Id]?.UploadState\"\n                                        [aria-label]=\"'File Upload Status Is ' + valueExtra[file.Id]?.UploadState\"\n                                    ></span>\n                                    <ng-container *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\">\n                                        <fd-slider\n                                            [contentDensity]=\"(contentDensity$ | async)!!\"\n                                            [(ngModel)]=\"valueExtra[file.Id].Progress\"\n                                            [name]=\"'filerLinear_' + id\"\n                                            fd-toolbar-item\n                                            [id]=\"id\"\n                                            [min]=\"0\"\n                                            [max]=\"100\"\n                                            [step]=\"1\"\n                                        >\n                                        </fd-slider>\n                                    </ng-container>\n                                </ng-container>\n                            </fd-toolbar>\n                        </div>\n                    </div>\n                </div>\n                <button\n                    *ngIf=\"(disableOrReadonly$ | async) === false && valueExtra[file.Id].UploadState !== 'Uploading'\"\n                    fd-button\n                    fdType=\"transparent\"\n                    glyph=\"decline\"\n                    (click)=\"onFileDeleted(file.Id)\"\n                ></button>\n                <button\n                    *ngIf=\"valueExtra[file.Id].UploadState === 'Uploading'\"\n                    fd-button\n                    [fdType]=\"'transparent'\"\n                    [glyph]=\"'stop'\"\n                    (click)=\"onTerminate(file)\"\n                ></button>\n                <button\n                    *ngIf=\"valueExtra[file.Id].UploadState === 'Error'\"\n                    fd-button\n                    [fdType]=\"'transparent'\"\n                    [glyph]=\"'refresh'\"\n                    (click)=\"onRetry(file)\"\n                ></button>\n            </li>\n        </ng-container>\n    </ng-container>\n</ul>\n"]}
|