barsa-sap-ui 1.0.357 → 1.0.358

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.
Files changed (58) hide show
  1. package/esm2020/lib/barsa-list-file-linear/barsa-list-file-linear.component.mjs +12 -12
  2. package/esm2020/lib/barsa-sap-ui.module.mjs +118 -129
  3. package/esm2020/lib/barsa-table-column/barsa-table-column.component.mjs +3 -3
  4. package/esm2020/lib/barsa-table-header/barsa-table-header.component.mjs +51 -18
  5. package/esm2020/lib/barsa-table-row/barsa-table-row.component.mjs +3 -3
  6. package/esm2020/lib/barsa-toolbaritem-search/barsa-toolbaritem-search.component.mjs +11 -8
  7. package/esm2020/lib/barsa-tree-item/barsa-tree-item.component.mjs +6 -7
  8. package/esm2020/lib/barsa-ulv-main/barsa-ulv-main.component.mjs +7 -8
  9. package/esm2020/lib/card-item/card-item.component.mjs +3 -3
  10. package/esm2020/lib/column-renderer/column-renderer.component.mjs +9 -8
  11. package/esm2020/lib/fundamental-dynamic-form/fundamental-dynamic-form.component.mjs +3 -3
  12. package/esm2020/lib/global-search/global-search.component.mjs +7 -6
  13. package/esm2020/lib/index.mjs +1 -3
  14. package/esm2020/lib/inline-save-and-cancel/inline-save-and-cancel.component.mjs +4 -4
  15. package/esm2020/lib/layout-actions/layout-actions.component.mjs +3 -4
  16. package/esm2020/lib/list-item/list-item.component.mjs +3 -3
  17. package/esm2020/lib/models/grid-data-provider.mjs +3 -142
  18. package/esm2020/lib/report-search-fields-manage/report-search-fields-manage.component.mjs +5 -6
  19. package/esm2020/lib/report-view-renderer.directive.mjs +8 -2
  20. package/esm2020/lib/sap-ui-report-base.component.mjs +2 -3
  21. package/esm2020/lib/ui-calendar/ui-calendar.component.mjs +3 -3
  22. package/esm2020/lib/ui-card-view-horizontal-group/ui-card-view-horizontal-group.component.mjs +3 -3
  23. package/esm2020/lib/ui-check-box/ui-check-box.component.mjs +3 -3
  24. package/esm2020/lib/ui-editable-grid/ui-editable-grid.component.mjs +3 -3
  25. package/esm2020/lib/ui-form-panel-toolbar/ui-form-panel-toolbar.component.mjs +5 -7
  26. package/esm2020/lib/ui-gantt-chart/ui-gantt-chart.component.mjs +3 -3
  27. package/esm2020/lib/ui-grid/ui-grid.component.mjs +3 -3
  28. package/esm2020/lib/ui-linear-list-container-with-button/ui-linear-list-container-with-button.component.mjs +3 -3
  29. package/esm2020/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.mjs +4 -5
  30. package/esm2020/lib/ui-picture-file/ui-picture-file.component.mjs +4 -4
  31. package/esm2020/lib/ui-pictures-info/ui-pictures-info.component.mjs +1 -1
  32. package/esm2020/lib/ui-report-container/ui-report-container.component.mjs +3 -3
  33. package/esm2020/lib/ui-table-view/ui-table-view.component.mjs +57 -8
  34. package/esm2020/lib/ui-tree/ui-tree.component.mjs +8 -8
  35. package/esm2020/lib/ulv-column-settings/ulv-column-settings.component.mjs +15 -13
  36. package/esm2020/lib/ulv-form-multi-select/ulv-form-multi-select.component.mjs +13 -14
  37. package/esm2020/lib/ulv-toolbar/ulv-toolbar.component.mjs +5 -6
  38. package/esm2020/public-api.mjs +1 -2
  39. package/fesm2015/barsa-sap-ui.mjs +351 -477
  40. package/fesm2015/barsa-sap-ui.mjs.map +1 -1
  41. package/fesm2020/barsa-sap-ui.mjs +351 -476
  42. package/fesm2020/barsa-sap-ui.mjs.map +1 -1
  43. package/lib/barsa-sap-ui.module.d.ts +124 -126
  44. package/lib/barsa-table-header/barsa-table-header.component.d.ts +13 -4
  45. package/lib/barsa-toolbaritem-search/barsa-toolbaritem-search.component.d.ts +2 -2
  46. package/lib/global-search/global-search.component.d.ts +1 -2
  47. package/lib/index.d.ts +1 -2
  48. package/lib/models/grid-data-provider.d.ts +2 -6
  49. package/lib/report-view-renderer.directive.d.ts +3 -1
  50. package/lib/sap-ui-report-base.component.d.ts +1 -3
  51. package/lib/ui-pictures-info/ui-pictures-info.component.d.ts +1 -1
  52. package/lib/ui-table-view/ui-table-view.component.d.ts +12 -3
  53. package/lib/ulv-column-settings/ulv-column-settings.component.d.ts +2 -1
  54. package/lib/ulv-toolbar/ulv-toolbar.component.d.ts +2 -4
  55. package/package.json +1 -1
  56. package/public-api.d.ts +0 -1
  57. package/esm2020/lib/page-with-header/page-with-header.component.mjs +0 -75
  58. package/lib/page-with-header/page-with-header.component.d.ts +0 -29
@@ -3,18 +3,20 @@ import { BaseUlvSettingComponent } from 'barsa-novin-ray-core';
3
3
  import { UiGridColumnsComponent } from '../ui-grid-columns/ui-grid-columns.component';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@fundamental-ngx/core";
6
- import * as i2 from "@fundamental-ngx/core/bar";
7
- import * as i3 from "@fundamental-ngx/core/button";
8
- import * as i4 from "@fundamental-ngx/core/dialog";
9
- import * as i5 from "@fundamental-ngx/core/title";
10
- import * as i6 from "@fundamental-ngx/core/utils";
11
- import * as i7 from "@fundamental-ngx/platform/search-field";
12
- import * as i8 from "../ui-grid-columns/ui-grid-columns.component";
13
- import * as i9 from "barsa-novin-ray-core";
6
+ import * as i2 from "@angular/forms";
7
+ import * as i3 from "@fundamental-ngx/core/bar";
8
+ import * as i4 from "@fundamental-ngx/core/button";
9
+ import * as i5 from "@fundamental-ngx/core/input-group";
10
+ import * as i6 from "@fundamental-ngx/core/dialog";
11
+ import * as i7 from "@fundamental-ngx/core/title";
12
+ import * as i8 from "@fundamental-ngx/core/utils";
13
+ import * as i9 from "../ui-grid-columns/ui-grid-columns.component";
14
+ import * as i10 from "barsa-novin-ray-core";
14
15
  export class UlvColumnSettingsComponent extends BaseUlvSettingComponent {
15
16
  constructor(dialogRef) {
16
17
  super();
17
18
  this.dialogRef = dialogRef;
19
+ this.searchTerm = '';
18
20
  }
19
21
  ngOnInit() {
20
22
  this.context = this.dialogRef.data.context;
@@ -24,8 +26,8 @@ export class UlvColumnSettingsComponent extends BaseUlvSettingComponent {
24
26
  onColumnsChange(columns) {
25
27
  this.columns = [...columns];
26
28
  }
27
- onSearchChange(e) {
28
- const filterText = e.text;
29
+ onSearchSubmit() {
30
+ const filterText = this.searchTerm;
29
31
  this.columns = this.allColumns.filter((c) => c.Caption.indexOf(filterText) > -1);
30
32
  }
31
33
  onReset() {
@@ -42,12 +44,12 @@ export class UlvColumnSettingsComponent extends BaseUlvSettingComponent {
42
44
  }
43
45
  }
44
46
  UlvColumnSettingsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UlvColumnSettingsComponent, deps: [{ token: i1.DialogRef }], target: i0.ɵɵFactoryTarget.Component });
45
- UlvColumnSettingsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UlvColumnSettingsComponent, selector: "bsu-ulv-column-settings", viewQueries: [{ propertyName: "gridColumnsComponent", first: true, predicate: UiGridColumnsComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--this commit is for test some github ability not more-->\r\n\r\n<fd-dialog>\r\n <fd-dialog-header>\r\n <ng-template fdTemplate=\"header\">\r\n <div fd-bar-left>\r\n <fd-bar-element>\r\n <h4 fd-title [headerSize]=\"4\">\r\n {{ 'Columns' | bbbTranslate }}\r\n </h4>\r\n </fd-bar-element>\r\n </div>\r\n <div fd-bar-right>\r\n <fd-bar-element>\r\n <button\r\n fd-button\r\n [label]=\"'Reset' | bbbTranslate\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onReset()\"\r\n ></button>\r\n </fd-bar-element>\r\n </div>\r\n </ng-template>\r\n </fd-dialog-header>\r\n <fd-dialog-body class=\"setting-wrapper\">\r\n <fdp-search-field\r\n [placeholder]=\"'EnterSearchCriteria' | bbbTranslate\"\r\n [suggestions]=\"[]\"\r\n (searchSubmit)=\"onSearchChange($event)\"\r\n ></fdp-search-field>\r\n <bsu-ui-grid-columns\r\n [selectedColumns]=\"columns | filter: { Hidden: false } | listCount\"\r\n [columns]=\"columns\"\r\n (columnsChange)=\"onColumnsChange($event)\"\r\n #gridColumnsRef\r\n ></bsu-ui-grid-columns>\r\n </fd-dialog-body>\r\n\r\n <fd-dialog-footer>\r\n <fd-dialog-footer-button>\r\n <button fd-button fdType=\"emphasized\" (click)=\"onOkClick()\" [label]=\"'OK' | bbbTranslate\"></button>\r\n </fd-dialog-footer-button>\r\n <fd-dialog-footer-button>\r\n <button fd-button (click)=\"onCancelSettings()\" [label]=\"'Cancel' | bbbTranslate\"></button>\r\n </fd-dialog-footer-button>\r\n </fd-dialog-footer>\r\n</fd-dialog>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i2.BarLeftDirective, selector: "[fd-bar-left]" }, { kind: "directive", type: i2.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "directive", type: i2.BarElementDirective, selector: "fd-bar-element", inputs: ["fullWidth", "isTitle"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i4.DialogBodyComponent, selector: "fd-dialog-body" }, { kind: "component", type: i4.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i4.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "component", type: i4.DialogFooterButtonComponent, selector: "fd-dialog-footer-button" }, { kind: "component", type: i5.TitleComponent, selector: "h1[fd-title], h2[fd-title], h3[fd-title], h4[fd-title], h5[fd-title], h6[fd-title]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "directive", type: i6.TemplateDirective, selector: "[fdTemplate]", inputs: ["fdTemplate"] }, { kind: "component", type: i7.SearchFieldComponent, selector: "fdp-search-field", inputs: ["placeholder", "mobile", "mobileConfig", "disableRefresh", "suggestions", "dataSource", "inputText", "categories", "currentCategory", "categoryLabel", "hideCategoryLabel", "isLoading", "ariaLabel", "ariaLabelledby", "searchSuggestionMessage", "searchSuggestionNavigateMessage"], outputs: ["inputChange", "searchSubmit", "cancelSearch", "isOpenChange"] }, { kind: "component", type: i8.UiGridColumnsComponent, selector: "bsu-ui-grid-columns", inputs: ["columns", "selectedColumns"], outputs: ["columnsChange"] }, { kind: "pipe", type: i9.FilterPipe, name: "filter" }, { kind: "pipe", type: i9.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i9.ListCountPipe, name: "listCount" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
47
+ UlvColumnSettingsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UlvColumnSettingsComponent, selector: "bsu-ulv-column-settings", viewQueries: [{ propertyName: "gridColumnsComponent", first: true, predicate: UiGridColumnsComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<!--this commit is for test some github ability not more-->\n\n<fd-dialog>\n <fd-dialog-header>\n <ng-template fdTemplate=\"header\">\n <div fd-bar-left>\n <fd-bar-element>\n <h4 fd-title [headerSize]=\"4\">\n {{ 'Columns' | bbbTranslate }}\n </h4>\n </fd-bar-element>\n </div>\n <div fd-bar-right>\n <fd-bar-element>\n <button\n fd-button\n [label]=\"'Reset' | bbbTranslate\"\n [fdType]=\"'transparent'\"\n (click)=\"onReset()\"\n ></button>\n </fd-bar-element>\n </div>\n </ng-template>\n </fd-dialog-header>\n <fd-dialog-body class=\"setting-wrapper\">\n <fd-input-group\n type=\"search\"\n glyph=\"search\"\n [glyphAriaLabel]=\"'EnterSearchCriteria' | bbbTranslate\"\n [placeholder]=\"'EnterSearchCriteria' | bbbTranslate\"\n [button]=\"true\"\n [disabled]=\"false\"\n [(ngModel)]=\"searchTerm\"\n (addOnButtonClicked)=\"onSearchSubmit()\"\n >\n </fd-input-group>\n\n <bsu-ui-grid-columns\n [selectedColumns]=\"columns | filter: { Hidden: false } | listCount\"\n [columns]=\"columns\"\n (columnsChange)=\"onColumnsChange($event)\"\n #gridColumnsRef\n ></bsu-ui-grid-columns>\n </fd-dialog-body>\n\n <fd-dialog-footer>\n <fd-dialog-footer-button>\n <button fd-button fdType=\"emphasized\" (click)=\"onOkClick()\" [label]=\"'OK' | bbbTranslate\"></button>\n </fd-dialog-footer-button>\n <fd-dialog-footer-button>\n <button fd-button (click)=\"onCancelSettings()\" [label]=\"'Cancel' | bbbTranslate\"></button>\n </fd-dialog-footer-button>\n </fd-dialog-footer>\n</fd-dialog>\n", styles: [""], dependencies: [{ 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.BarLeftDirective, selector: "[fd-bar-left]" }, { kind: "directive", type: i3.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "directive", type: i3.BarElementDirective, selector: "fd-bar-element", inputs: ["fullWidth", "isTitle"] }, { kind: "component", type: i4.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i5.InputGroupComponent, selector: "fd-input-group", inputs: ["inputTemplate", "placement", "required", "inline", "placeholder", "addOnText", "buttonFocusable", "type", "glyph", "button", "disabled", "readonly", "state", "isControl", "showFocus", "isExpanded", "glyphAriaLabel", "iconTitle", "ariaLabelledby", "ariaLabelledBy"], outputs: ["addOnButtonClicked", "search"] }, { kind: "component", type: i6.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i6.DialogBodyComponent, selector: "fd-dialog-body" }, { kind: "component", type: i6.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i6.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "component", type: i6.DialogFooterButtonComponent, selector: "fd-dialog-footer-button" }, { kind: "component", type: i7.TitleComponent, selector: "h1[fd-title], h2[fd-title], h3[fd-title], h4[fd-title], h5[fd-title], h6[fd-title]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "directive", type: i8.TemplateDirective, selector: "[fdTemplate]", inputs: ["fdTemplate"] }, { kind: "component", type: i9.UiGridColumnsComponent, selector: "bsu-ui-grid-columns", inputs: ["columns", "selectedColumns"], outputs: ["columnsChange"] }, { kind: "pipe", type: i10.FilterPipe, name: "filter" }, { kind: "pipe", type: i10.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i10.ListCountPipe, name: "listCount" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
46
48
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UlvColumnSettingsComponent, decorators: [{
47
49
  type: Component,
48
- args: [{ selector: 'bsu-ulv-column-settings', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--this commit is for test some github ability not more-->\r\n\r\n<fd-dialog>\r\n <fd-dialog-header>\r\n <ng-template fdTemplate=\"header\">\r\n <div fd-bar-left>\r\n <fd-bar-element>\r\n <h4 fd-title [headerSize]=\"4\">\r\n {{ 'Columns' | bbbTranslate }}\r\n </h4>\r\n </fd-bar-element>\r\n </div>\r\n <div fd-bar-right>\r\n <fd-bar-element>\r\n <button\r\n fd-button\r\n [label]=\"'Reset' | bbbTranslate\"\r\n [fdType]=\"'transparent'\"\r\n (click)=\"onReset()\"\r\n ></button>\r\n </fd-bar-element>\r\n </div>\r\n </ng-template>\r\n </fd-dialog-header>\r\n <fd-dialog-body class=\"setting-wrapper\">\r\n <fdp-search-field\r\n [placeholder]=\"'EnterSearchCriteria' | bbbTranslate\"\r\n [suggestions]=\"[]\"\r\n (searchSubmit)=\"onSearchChange($event)\"\r\n ></fdp-search-field>\r\n <bsu-ui-grid-columns\r\n [selectedColumns]=\"columns | filter: { Hidden: false } | listCount\"\r\n [columns]=\"columns\"\r\n (columnsChange)=\"onColumnsChange($event)\"\r\n #gridColumnsRef\r\n ></bsu-ui-grid-columns>\r\n </fd-dialog-body>\r\n\r\n <fd-dialog-footer>\r\n <fd-dialog-footer-button>\r\n <button fd-button fdType=\"emphasized\" (click)=\"onOkClick()\" [label]=\"'OK' | bbbTranslate\"></button>\r\n </fd-dialog-footer-button>\r\n <fd-dialog-footer-button>\r\n <button fd-button (click)=\"onCancelSettings()\" [label]=\"'Cancel' | bbbTranslate\"></button>\r\n </fd-dialog-footer-button>\r\n </fd-dialog-footer>\r\n</fd-dialog>\r\n" }]
50
+ args: [{ selector: 'bsu-ulv-column-settings', changeDetection: ChangeDetectionStrategy.OnPush, template: "<!--this commit is for test some github ability not more-->\n\n<fd-dialog>\n <fd-dialog-header>\n <ng-template fdTemplate=\"header\">\n <div fd-bar-left>\n <fd-bar-element>\n <h4 fd-title [headerSize]=\"4\">\n {{ 'Columns' | bbbTranslate }}\n </h4>\n </fd-bar-element>\n </div>\n <div fd-bar-right>\n <fd-bar-element>\n <button\n fd-button\n [label]=\"'Reset' | bbbTranslate\"\n [fdType]=\"'transparent'\"\n (click)=\"onReset()\"\n ></button>\n </fd-bar-element>\n </div>\n </ng-template>\n </fd-dialog-header>\n <fd-dialog-body class=\"setting-wrapper\">\n <fd-input-group\n type=\"search\"\n glyph=\"search\"\n [glyphAriaLabel]=\"'EnterSearchCriteria' | bbbTranslate\"\n [placeholder]=\"'EnterSearchCriteria' | bbbTranslate\"\n [button]=\"true\"\n [disabled]=\"false\"\n [(ngModel)]=\"searchTerm\"\n (addOnButtonClicked)=\"onSearchSubmit()\"\n >\n </fd-input-group>\n\n <bsu-ui-grid-columns\n [selectedColumns]=\"columns | filter: { Hidden: false } | listCount\"\n [columns]=\"columns\"\n (columnsChange)=\"onColumnsChange($event)\"\n #gridColumnsRef\n ></bsu-ui-grid-columns>\n </fd-dialog-body>\n\n <fd-dialog-footer>\n <fd-dialog-footer-button>\n <button fd-button fdType=\"emphasized\" (click)=\"onOkClick()\" [label]=\"'OK' | bbbTranslate\"></button>\n </fd-dialog-footer-button>\n <fd-dialog-footer-button>\n <button fd-button (click)=\"onCancelSettings()\" [label]=\"'Cancel' | bbbTranslate\"></button>\n </fd-dialog-footer-button>\n </fd-dialog-footer>\n</fd-dialog>\n" }]
49
51
  }], ctorParameters: function () { return [{ type: i1.DialogRef }]; }, propDecorators: { gridColumnsComponent: [{
50
52
  type: ViewChild,
51
53
  args: [UiGridColumnsComponent]
52
54
  }] } });
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWx2LWNvbHVtbi1zZXR0aW5ncy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1zYXAtdWkvc3JjL2xpYi91bHYtY29sdW1uLXNldHRpbmdzL3Vsdi1jb2x1bW4tc2V0dGluZ3MuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWx2LWNvbHVtbi1zZXR0aW5ncy91bHYtY29sdW1uLXNldHRpbmdzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3RGLE9BQU8sRUFBRSx1QkFBdUIsRUFBaUMsTUFBTSxzQkFBc0IsQ0FBQztBQUM5RixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQzs7Ozs7Ozs7Ozs7QUFPdEYsTUFBTSxPQUFPLDBCQUEyQixTQUFRLHVCQUF1QjtJQUluRSxZQUFvQixTQUFvQjtRQUNwQyxLQUFLLEVBQUUsQ0FBQztRQURRLGNBQVMsR0FBVCxTQUFTLENBQVc7SUFFeEMsQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztRQUMzQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ25DLENBQUM7SUFDRCxlQUFlLENBQUMsT0FBTztRQUNuQixJQUFJLENBQUMsT0FBTyxHQUFHLENBQUMsR0FBRyxPQUFPLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBQ0QsY0FBYyxDQUFDLENBQUM7UUFDWixNQUFNLFVBQVUsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDO1FBQzFCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDckYsQ0FBQztJQUNELE9BQU87UUFDSCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxDQUFDLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ25GLENBQUM7SUFDRCxXQUFXO1FBQ1AsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQztRQUM3QixNQUFNLFFBQVEsR0FBRyxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDckMsUUFBUSxDQUFDLGNBQWMsR0FBRyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUMsQ0FBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDckcsT0FBTyxRQUFRLENBQUM7SUFDcEIsQ0FBQztJQUNELEtBQUssQ0FBQyxVQUFlLElBQUk7UUFDckIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDbEMsQ0FBQzs7dUhBL0JRLDBCQUEwQjsyR0FBMUIsMEJBQTBCLHFIQUN4QixzQkFBc0IsdUVDWnJDLHEzREErQ0E7MkZEcENhLDBCQUEwQjtrQkFOdEMsU0FBUzsrQkFDSSx5QkFBeUIsbUJBR2xCLHVCQUF1QixDQUFDLE1BQU07Z0dBSS9DLG9CQUFvQjtzQkFEbkIsU0FBUzt1QkFBQyxzQkFBc0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGlhbG9nUmVmIH0gZnJvbSAnQGZ1bmRhbWVudGFsLW5neC9jb3JlJztcblxuaW1wb3J0IHsgQmFzZVVsdlNldHRpbmdDb21wb25lbnQsIEdyaWRTZXR0aW5nLCBSZXBvcnRWaWV3Q29sdW1uIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xuaW1wb3J0IHsgVWlHcmlkQ29sdW1uc0NvbXBvbmVudCB9IGZyb20gJy4uL3VpLWdyaWQtY29sdW1ucy91aS1ncmlkLWNvbHVtbnMuY29tcG9uZW50JztcbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYnN1LXVsdi1jb2x1bW4tc2V0dGluZ3MnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi91bHYtY29sdW1uLXNldHRpbmdzLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi91bHYtY29sdW1uLXNldHRpbmdzLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgVWx2Q29sdW1uU2V0dGluZ3NDb21wb25lbnQgZXh0ZW5kcyBCYXNlVWx2U2V0dGluZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQFZpZXdDaGlsZChVaUdyaWRDb2x1bW5zQ29tcG9uZW50KVxuICAgIGdyaWRDb2x1bW5zQ29tcG9uZW50OiBVaUdyaWRDb2x1bW5zQ29tcG9uZW50O1xuICAgIGNvbHVtbnM6IFJlcG9ydFZpZXdDb2x1bW5bXTtcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGRpYWxvZ1JlZjogRGlhbG9nUmVmKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY29udGV4dCA9IHRoaXMuZGlhbG9nUmVmLmRhdGEuY29udGV4dDtcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICAgICAgdGhpcy5jb2x1bW5zID0gdGhpcy5hbGxDb2x1bW5zO1xuICAgIH1cbiAgICBvbkNvbHVtbnNDaGFuZ2UoY29sdW1ucyk6IHZvaWQge1xuICAgICAgICB0aGlzLmNvbHVtbnMgPSBbLi4uY29sdW1uc107XG4gICAgfVxuICAgIG9uU2VhcmNoQ2hhbmdlKGUpOiB2b2lkIHtcbiAgICAgICAgY29uc3QgZmlsdGVyVGV4dCA9IGUudGV4dDtcbiAgICAgICAgdGhpcy5jb2x1bW5zID0gdGhpcy5hbGxDb2x1bW5zLmZpbHRlcigoYykgPT4gYy5DYXB0aW9uLmluZGV4T2YoZmlsdGVyVGV4dCkgPiAtMSk7XG4gICAgfVxuICAgIG9uUmVzZXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY29sdW1ucyA9IHRoaXMuYWxsQ29sdW1ucy5tYXAoKGMpID0+ICh7IC4uLmMsIEhpZGRlbjogZmFsc2UsIFdpZHRoOiAwIH0pKTtcbiAgICB9XG4gICAgZ2V0U2V0dGluZ3MoKTogR3JpZFNldHRpbmcge1xuICAgICAgICBjb25zdCBjb2xMaXN0ID0gdGhpcy5jb2x1bW5zO1xuICAgICAgICBjb25zdCBzZXR0aW5ncyA9IHN1cGVyLmdldFNldHRpbmdzKCk7XG4gICAgICAgIHNldHRpbmdzLkNvbFNldHRpbmdMaXN0ID0gY29sTGlzdC5tYXAoKGMpID0+ICh7IElzSGlkZGVuOiBjLkhpZGRlbiwgTmFtZTogYy5OYW1lLCBXaWR0aDogYy5XaWR0aCB9KSk7XG4gICAgICAgIHJldHVybiBzZXR0aW5ncztcbiAgICB9XG4gICAgY2xvc2Uoc2V0dGluZzogYW55ID0gbnVsbCk6IHZvaWQge1xuICAgICAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZShzZXR0aW5nKTtcbiAgICB9XG59XG4iLCI8IS0tdGhpcyBjb21taXQgaXMgZm9yIHRlc3Qgc29tZSBnaXRodWIgYWJpbGl0eSBub3QgbW9yZS0tPlxyXG5cclxuPGZkLWRpYWxvZz5cclxuICAgIDxmZC1kaWFsb2ctaGVhZGVyPlxyXG4gICAgICAgIDxuZy10ZW1wbGF0ZSBmZFRlbXBsYXRlPVwiaGVhZGVyXCI+XHJcbiAgICAgICAgICAgIDxkaXYgZmQtYmFyLWxlZnQ+XHJcbiAgICAgICAgICAgICAgICA8ZmQtYmFyLWVsZW1lbnQ+XHJcbiAgICAgICAgICAgICAgICAgICAgPGg0IGZkLXRpdGxlIFtoZWFkZXJTaXplXT1cIjRcIj5cclxuICAgICAgICAgICAgICAgICAgICAgICAge3sgJ0NvbHVtbnMnIHwgYmJiVHJhbnNsYXRlIH19XHJcbiAgICAgICAgICAgICAgICAgICAgPC9oND5cclxuICAgICAgICAgICAgICAgIDwvZmQtYmFyLWVsZW1lbnQ+XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8ZGl2IGZkLWJhci1yaWdodD5cclxuICAgICAgICAgICAgICAgIDxmZC1iYXItZWxlbWVudD5cclxuICAgICAgICAgICAgICAgICAgICA8YnV0dG9uXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGZkLWJ1dHRvblxyXG4gICAgICAgICAgICAgICAgICAgICAgICBbbGFiZWxdPVwiJ1Jlc2V0JyB8IGJiYlRyYW5zbGF0ZVwiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIFtmZFR5cGVdPVwiJ3RyYW5zcGFyZW50J1wiXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIChjbGljayk9XCJvblJlc2V0KClcIlxyXG4gICAgICAgICAgICAgICAgICAgID48L2J1dHRvbj5cclxuICAgICAgICAgICAgICAgIDwvZmQtYmFyLWVsZW1lbnQ+XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICA8L2ZkLWRpYWxvZy1oZWFkZXI+XHJcbiAgICA8ZmQtZGlhbG9nLWJvZHkgY2xhc3M9XCJzZXR0aW5nLXdyYXBwZXJcIj5cclxuICAgICAgICA8ZmRwLXNlYXJjaC1maWVsZFxyXG4gICAgICAgICAgICBbcGxhY2Vob2xkZXJdPVwiJ0VudGVyU2VhcmNoQ3JpdGVyaWEnIHwgYmJiVHJhbnNsYXRlXCJcclxuICAgICAgICAgICAgW3N1Z2dlc3Rpb25zXT1cIltdXCJcclxuICAgICAgICAgICAgKHNlYXJjaFN1Ym1pdCk9XCJvblNlYXJjaENoYW5nZSgkZXZlbnQpXCJcclxuICAgICAgICA+PC9mZHAtc2VhcmNoLWZpZWxkPlxyXG4gICAgICAgIDxic3UtdWktZ3JpZC1jb2x1bW5zXHJcbiAgICAgICAgICAgIFtzZWxlY3RlZENvbHVtbnNdPVwiY29sdW1ucyB8IGZpbHRlcjogeyBIaWRkZW46IGZhbHNlIH0gfCBsaXN0Q291bnRcIlxyXG4gICAgICAgICAgICBbY29sdW1uc109XCJjb2x1bW5zXCJcclxuICAgICAgICAgICAgKGNvbHVtbnNDaGFuZ2UpPVwib25Db2x1bW5zQ2hhbmdlKCRldmVudClcIlxyXG4gICAgICAgICAgICAjZ3JpZENvbHVtbnNSZWZcclxuICAgICAgICA+PC9ic3UtdWktZ3JpZC1jb2x1bW5zPlxyXG4gICAgPC9mZC1kaWFsb2ctYm9keT5cclxuXHJcbiAgICA8ZmQtZGlhbG9nLWZvb3Rlcj5cclxuICAgICAgICA8ZmQtZGlhbG9nLWZvb3Rlci1idXR0b24+XHJcbiAgICAgICAgICAgIDxidXR0b24gZmQtYnV0dG9uIGZkVHlwZT1cImVtcGhhc2l6ZWRcIiAoY2xpY2spPVwib25Pa0NsaWNrKClcIiBbbGFiZWxdPVwiJ09LJyB8IGJiYlRyYW5zbGF0ZVwiPjwvYnV0dG9uPlxyXG4gICAgICAgIDwvZmQtZGlhbG9nLWZvb3Rlci1idXR0b24+XHJcbiAgICAgICAgPGZkLWRpYWxvZy1mb290ZXItYnV0dG9uPlxyXG4gICAgICAgICAgICA8YnV0dG9uIGZkLWJ1dHRvbiAoY2xpY2spPVwib25DYW5jZWxTZXR0aW5ncygpXCIgW2xhYmVsXT1cIidDYW5jZWwnIHwgYmJiVHJhbnNsYXRlXCI+PC9idXR0b24+XHJcbiAgICAgICAgPC9mZC1kaWFsb2ctZm9vdGVyLWJ1dHRvbj5cclxuICAgIDwvZmQtZGlhbG9nLWZvb3Rlcj5cclxuPC9mZC1kaWFsb2c+XHJcbiJdfQ==
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWx2LWNvbHVtbi1zZXR0aW5ncy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS1zYXAtdWkvc3JjL2xpYi91bHYtY29sdW1uLXNldHRpbmdzL3Vsdi1jb2x1bW4tc2V0dGluZ3MuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWx2LWNvbHVtbi1zZXR0aW5ncy91bHYtY29sdW1uLXNldHRpbmdzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQVUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR3RGLE9BQU8sRUFBRSx1QkFBdUIsRUFBaUMsTUFBTSxzQkFBc0IsQ0FBQztBQUM5RixPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw4Q0FBOEMsQ0FBQzs7Ozs7Ozs7Ozs7O0FBT3RGLE1BQU0sT0FBTywwQkFBMkIsU0FBUSx1QkFBdUI7SUFLbkUsWUFBb0IsU0FBb0I7UUFDcEMsS0FBSyxFQUFFLENBQUM7UUFEUSxjQUFTLEdBQVQsU0FBUyxDQUFXO1FBRHhDLGVBQVUsR0FBRyxFQUFFLENBQUM7SUFHaEIsQ0FBQztJQUVELFFBQVE7UUFDSixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQztRQUMzQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ25DLENBQUM7SUFDRCxlQUFlLENBQUMsT0FBTztRQUNuQixJQUFJLENBQUMsT0FBTyxHQUFHLENBQUMsR0FBRyxPQUFPLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBQ0QsY0FBYztRQUNWLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUM7UUFDbkMsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNyRixDQUFDO0lBQ0QsT0FBTztRQUNILElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxHQUFHLENBQUMsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDbkYsQ0FBQztJQUNELFdBQVc7UUFDUCxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDO1FBQzdCLE1BQU0sUUFBUSxHQUFHLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNyQyxRQUFRLENBQUMsY0FBYyxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNyRyxPQUFPLFFBQVEsQ0FBQztJQUNwQixDQUFDO0lBQ0QsS0FBSyxDQUFDLFVBQWUsSUFBSTtRQUNyQixJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNsQyxDQUFDOzt1SEFoQ1EsMEJBQTBCOzJHQUExQiwwQkFBMEIscUhBQ3hCLHNCQUFzQix1RUNackMsdytEQXNEQTsyRkQzQ2EsMEJBQTBCO2tCQU50QyxTQUFTOytCQUNJLHlCQUF5QixtQkFHbEIsdUJBQXVCLENBQUMsTUFBTTtnR0FJL0Msb0JBQW9CO3NCQURuQixTQUFTO3VCQUFDLHNCQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uSW5pdCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEaWFsb2dSZWYgfSBmcm9tICdAZnVuZGFtZW50YWwtbmd4L2NvcmUnO1xuXG5pbXBvcnQgeyBCYXNlVWx2U2V0dGluZ0NvbXBvbmVudCwgR3JpZFNldHRpbmcsIFJlcG9ydFZpZXdDb2x1bW4gfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XG5pbXBvcnQgeyBVaUdyaWRDb2x1bW5zQ29tcG9uZW50IH0gZnJvbSAnLi4vdWktZ3JpZC1jb2x1bW5zL3VpLWdyaWQtY29sdW1ucy5jb21wb25lbnQnO1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdic3UtdWx2LWNvbHVtbi1zZXR0aW5ncycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3Vsdi1jb2x1bW4tc2V0dGluZ3MuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL3Vsdi1jb2x1bW4tc2V0dGluZ3MuY29tcG9uZW50LnNjc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBVbHZDb2x1bW5TZXR0aW5nc0NvbXBvbmVudCBleHRlbmRzIEJhc2VVbHZTZXR0aW5nQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBAVmlld0NoaWxkKFVpR3JpZENvbHVtbnNDb21wb25lbnQpXG4gICAgZ3JpZENvbHVtbnNDb21wb25lbnQ6IFVpR3JpZENvbHVtbnNDb21wb25lbnQ7XG4gICAgY29sdW1uczogUmVwb3J0Vmlld0NvbHVtbltdO1xuICAgIHNlYXJjaFRlcm0gPSAnJztcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGRpYWxvZ1JlZjogRGlhbG9nUmVmKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY29udGV4dCA9IHRoaXMuZGlhbG9nUmVmLmRhdGEuY29udGV4dDtcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICAgICAgdGhpcy5jb2x1bW5zID0gdGhpcy5hbGxDb2x1bW5zO1xuICAgIH1cbiAgICBvbkNvbHVtbnNDaGFuZ2UoY29sdW1ucyk6IHZvaWQge1xuICAgICAgICB0aGlzLmNvbHVtbnMgPSBbLi4uY29sdW1uc107XG4gICAgfVxuICAgIG9uU2VhcmNoU3VibWl0KCk6IHZvaWQge1xuICAgICAgICBjb25zdCBmaWx0ZXJUZXh0ID0gdGhpcy5zZWFyY2hUZXJtO1xuICAgICAgICB0aGlzLmNvbHVtbnMgPSB0aGlzLmFsbENvbHVtbnMuZmlsdGVyKChjKSA9PiBjLkNhcHRpb24uaW5kZXhPZihmaWx0ZXJUZXh0KSA+IC0xKTtcbiAgICB9XG4gICAgb25SZXNldCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5jb2x1bW5zID0gdGhpcy5hbGxDb2x1bW5zLm1hcCgoYykgPT4gKHsgLi4uYywgSGlkZGVuOiBmYWxzZSwgV2lkdGg6IDAgfSkpO1xuICAgIH1cbiAgICBnZXRTZXR0aW5ncygpOiBHcmlkU2V0dGluZyB7XG4gICAgICAgIGNvbnN0IGNvbExpc3QgPSB0aGlzLmNvbHVtbnM7XG4gICAgICAgIGNvbnN0IHNldHRpbmdzID0gc3VwZXIuZ2V0U2V0dGluZ3MoKTtcbiAgICAgICAgc2V0dGluZ3MuQ29sU2V0dGluZ0xpc3QgPSBjb2xMaXN0Lm1hcCgoYykgPT4gKHsgSXNIaWRkZW46IGMuSGlkZGVuLCBOYW1lOiBjLk5hbWUsIFdpZHRoOiBjLldpZHRoIH0pKTtcbiAgICAgICAgcmV0dXJuIHNldHRpbmdzO1xuICAgIH1cbiAgICBjbG9zZShzZXR0aW5nOiBhbnkgPSBudWxsKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKHNldHRpbmcpO1xuICAgIH1cbn1cbiIsIjwhLS10aGlzIGNvbW1pdCBpcyBmb3IgdGVzdCBzb21lIGdpdGh1YiBhYmlsaXR5IG5vdCBtb3JlLS0+XG5cbjxmZC1kaWFsb2c+XG4gICAgPGZkLWRpYWxvZy1oZWFkZXI+XG4gICAgICAgIDxuZy10ZW1wbGF0ZSBmZFRlbXBsYXRlPVwiaGVhZGVyXCI+XG4gICAgICAgICAgICA8ZGl2IGZkLWJhci1sZWZ0PlxuICAgICAgICAgICAgICAgIDxmZC1iYXItZWxlbWVudD5cbiAgICAgICAgICAgICAgICAgICAgPGg0IGZkLXRpdGxlIFtoZWFkZXJTaXplXT1cIjRcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgIHt7ICdDb2x1bW5zJyB8IGJiYlRyYW5zbGF0ZSB9fVxuICAgICAgICAgICAgICAgICAgICA8L2g0PlxuICAgICAgICAgICAgICAgIDwvZmQtYmFyLWVsZW1lbnQ+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgZmQtYmFyLXJpZ2h0PlxuICAgICAgICAgICAgICAgIDxmZC1iYXItZWxlbWVudD5cbiAgICAgICAgICAgICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgICAgICAgICAgICAgZmQtYnV0dG9uXG4gICAgICAgICAgICAgICAgICAgICAgICBbbGFiZWxdPVwiJ1Jlc2V0JyB8IGJiYlRyYW5zbGF0ZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICBbZmRUeXBlXT1cIid0cmFuc3BhcmVudCdcIlxuICAgICAgICAgICAgICAgICAgICAgICAgKGNsaWNrKT1cIm9uUmVzZXQoKVwiXG4gICAgICAgICAgICAgICAgICAgID48L2J1dHRvbj5cbiAgICAgICAgICAgICAgICA8L2ZkLWJhci1lbGVtZW50PlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvbmctdGVtcGxhdGU+XG4gICAgPC9mZC1kaWFsb2ctaGVhZGVyPlxuICAgIDxmZC1kaWFsb2ctYm9keSBjbGFzcz1cInNldHRpbmctd3JhcHBlclwiPlxuICAgICAgICA8ZmQtaW5wdXQtZ3JvdXBcbiAgICAgICAgICAgIHR5cGU9XCJzZWFyY2hcIlxuICAgICAgICAgICAgZ2x5cGg9XCJzZWFyY2hcIlxuICAgICAgICAgICAgW2dseXBoQXJpYUxhYmVsXT1cIidFbnRlclNlYXJjaENyaXRlcmlhJyB8IGJiYlRyYW5zbGF0ZVwiXG4gICAgICAgICAgICBbcGxhY2Vob2xkZXJdPVwiJ0VudGVyU2VhcmNoQ3JpdGVyaWEnIHwgYmJiVHJhbnNsYXRlXCJcbiAgICAgICAgICAgIFtidXR0b25dPVwidHJ1ZVwiXG4gICAgICAgICAgICBbZGlzYWJsZWRdPVwiZmFsc2VcIlxuICAgICAgICAgICAgWyhuZ01vZGVsKV09XCJzZWFyY2hUZXJtXCJcbiAgICAgICAgICAgIChhZGRPbkJ1dHRvbkNsaWNrZWQpPVwib25TZWFyY2hTdWJtaXQoKVwiXG4gICAgICAgID5cbiAgICAgICAgPC9mZC1pbnB1dC1ncm91cD5cblxuICAgICAgICA8YnN1LXVpLWdyaWQtY29sdW1uc1xuICAgICAgICAgICAgW3NlbGVjdGVkQ29sdW1uc109XCJjb2x1bW5zIHwgZmlsdGVyOiB7IEhpZGRlbjogZmFsc2UgfSB8IGxpc3RDb3VudFwiXG4gICAgICAgICAgICBbY29sdW1uc109XCJjb2x1bW5zXCJcbiAgICAgICAgICAgIChjb2x1bW5zQ2hhbmdlKT1cIm9uQ29sdW1uc0NoYW5nZSgkZXZlbnQpXCJcbiAgICAgICAgICAgICNncmlkQ29sdW1uc1JlZlxuICAgICAgICA+PC9ic3UtdWktZ3JpZC1jb2x1bW5zPlxuICAgIDwvZmQtZGlhbG9nLWJvZHk+XG5cbiAgICA8ZmQtZGlhbG9nLWZvb3Rlcj5cbiAgICAgICAgPGZkLWRpYWxvZy1mb290ZXItYnV0dG9uPlxuICAgICAgICAgICAgPGJ1dHRvbiBmZC1idXR0b24gZmRUeXBlPVwiZW1waGFzaXplZFwiIChjbGljayk9XCJvbk9rQ2xpY2soKVwiIFtsYWJlbF09XCInT0snIHwgYmJiVHJhbnNsYXRlXCI+PC9idXR0b24+XG4gICAgICAgIDwvZmQtZGlhbG9nLWZvb3Rlci1idXR0b24+XG4gICAgICAgIDxmZC1kaWFsb2ctZm9vdGVyLWJ1dHRvbj5cbiAgICAgICAgICAgIDxidXR0b24gZmQtYnV0dG9uIChjbGljayk9XCJvbkNhbmNlbFNldHRpbmdzKClcIiBbbGFiZWxdPVwiJ0NhbmNlbCcgfCBiYmJUcmFuc2xhdGVcIj48L2J1dHRvbj5cbiAgICAgICAgPC9mZC1kaWFsb2ctZm9vdGVyLWJ1dHRvbj5cbiAgICA8L2ZkLWRpYWxvZy1mb290ZXI+XG48L2ZkLWRpYWxvZz5cbiJdfQ==
@@ -5,17 +5,16 @@ import * as i0 from "@angular/core";
5
5
  import * as i1 from "@fundamental-ngx/core";
6
6
  import * as i2 from "barsa-novin-ray-core";
7
7
  import * as i3 from "@angular/common";
8
- import * as i4 from "@fundamental-ngx/core/bar";
9
- import * as i5 from "@fundamental-ngx/core/button";
10
- import * as i6 from "@fundamental-ngx/core/dialog";
11
- import * as i7 from "@fundamental-ngx/core/title";
12
- import * as i8 from "@fundamental-ngx/core/utils";
13
- import * as i9 from "@fundamental-ngx/core/toolbar";
14
- import * as i10 from "@fundamental-ngx/core/token";
15
- import * as i11 from "@fundamental-ngx/platform/shared";
16
- import * as i12 from "@fundamental-ngx/platform/button";
17
- import * as i13 from "../ui-ulv-main-ui/ui-ulv-main-ui.component";
18
- import * as i14 from "../fullscreen-dialog.directive";
8
+ import * as i4 from "@fundamental-ngx/core/content-density";
9
+ import * as i5 from "@fundamental-ngx/core/bar";
10
+ import * as i6 from "@fundamental-ngx/core/button";
11
+ import * as i7 from "@fundamental-ngx/core/dialog";
12
+ import * as i8 from "@fundamental-ngx/core/title";
13
+ import * as i9 from "@fundamental-ngx/core/utils";
14
+ import * as i10 from "@fundamental-ngx/core/toolbar";
15
+ import * as i11 from "@fundamental-ngx/core/token";
16
+ import * as i12 from "../ui-ulv-main-ui/ui-ulv-main-ui.component";
17
+ import * as i13 from "../fullscreen-dialog.directive";
19
18
  export class UlvFormMultiSelectComponent extends BaseComponent {
20
19
  constructor(_dialogService, _bbbTranslatePipe, _portalService, _contentDensityService) {
21
20
  super();
@@ -173,14 +172,14 @@ export class UlvFormMultiSelectComponent extends BaseComponent {
173
172
  }
174
173
  }
175
174
  UlvFormMultiSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UlvFormMultiSelectComponent, deps: [{ token: i1.DialogService }, { token: i2.BbbTranslatePipe }, { token: i2.PortalService }, { token: i1.ContentDensityService }], target: i0.ɵɵFactoryTarget.Component });
176
- UlvFormMultiSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UlvFormMultiSelectComponent, selector: "bsu-ulv-form-multi-select", inputs: { Show: "Show" }, viewQueries: [{ propertyName: "dialogContainer", first: true, predicate: ["container"], descendants: true, read: TemplateRef }], usesInheritance: true, ngImport: i0, template: "<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #container>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTpl>\n <fd-dialog-header>\n <ng-template fdTemplate=\"header\">\n <div fd-bar-left>\n <fd-bar-element>\n <h1 id=\"fd-dialog-header-3\" fd-title>{{ dialog.data.title }}</h1>\n </fd-bar-element>\n </div>\n <div fd-bar-right>\n <fd-button-bar\n *ngIf=\"!dialogConfig.fullscreen\"\n ariaLabel=\"fullscreen\"\n [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n fullscreenDialog\n [dialog]=\"dialog\"\n [dialogComponent]=\"dialogTpl\"\n ></fd-button-bar>\n <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel(dialog)\"></fd-button-bar>\n </div>\n </ng-template>\n <!-- <h3 fd-title>{{ dialog.data.title }}</h3>\n <button fd-dialog-close-button></button> -->\n </fd-dialog-header>\n\n <fd-dialog-body>\n <ng-container *ngIf=\"dialog.data.ulv1 as ulv1\">\n <bsu-ui-ulv-main-ui\n class=\"ulv-form-multi-select\"\n [context]=\"ulv1\"\n [inDialog]=\"true\"\n [isMultiSelect]=\"dialog.data.ShowSecondPanel\"\n [fullscreen]=\"dialog.data.fullscreen\"\n ></bsu-ui-ulv-main-ui>\n </ng-container>\n <div\n *ngIf=\"dialog.data.ulv2 && dialog.data.ShowSecondPanel\"\n class=\"ulv-selection-form-dialog__row ulv-selection-form-dialog__selection-row\"\n [aria-label]=\"'SelectedItemsAndConditions' | bbbTranslate\"\n >\n <h5 fd-title class=\"selected-and-condition-title\">\n <ng-container>\n <ng-container>{{ 'SelectedItemsAndConditions' | bbbTranslate }} </ng-container>\n ({{ dialog.data.selectedItems?.MoDataList?.length || 0 }})\n </ng-container>\n </h5>\n\n <div class=\"ulv-selection-form-dialog__tokens-wrapper\">\n <div class=\"ulv-selection-form-dialog__tokens\">\n <fd-toolbar [shouldOverflow]=\"true\" *ngIf=\"dialog.data.selectedItems\">\n <!-- Selected items -->\n <fd-token\n fd-toolbar-item\n fdOverflowPriority=\"high\"\n class=\"fdp-value-help-dialog__selection-token\"\n (onCloseClick)=\"onRemoveSelected(dialog, item)\"\n *ngFor=\"\n let item of dialog.data.selectedItems.MoDataList;\n index as selectedIndex;\n trackBy: _trackBySelectedFn\n \"\n >{{ item.$Caption }}\n </fd-token>\n </fd-toolbar>\n </div>\n <button\n class=\"ulv-selection-form-dialog__tokens-clear\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n [aria-label]=\"'Clear' | bbbTranslate\"\n (click)=\"onClear(dialog)\"\n ></button>\n </div>\n </div>\n </fd-dialog-body>\n\n <fd-dialog-footer *ngIf=\"dialog.data.ulv1 && !dialog.data.ulv1?.HideOkCancelButtons\">\n <ng-template fdTemplate=\"footer\">\n <div\n class=\"ulv-selection-form-dialog__actions-row\"\n *ngIf=\"dialog.data.adapter?.ShowOkCancelButtons !== false\"\n >\n <button\n fd-button\n data-succes\n [label]=\"'OK' | bbbTranslate\"\n fdType=\"emphasized\"\n [compact]=\"true\"\n (click)=\"onOk(dialog)\"\n ></button>\n <fdp-button\n [contentDensity]=\"'compact'\"\n data-dismiss-dialog\n fd-dialog-decisive-button\n [label]=\"'Cancel' | bbbTranslate\"\n [buttonType]=\"'transparent'\"\n (click)=\"onCancel(dialog)\"\n ></fdp-button>\n </div>\n </ng-template>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [".ulv-selection-form-dialog{cursor:default}.ulv-selection-form-dialog .fd-dialog__body bsu-ui-table-view{overflow-x:inherit!important}.ulv-selection-form-dialog__advanced-filters{padding-top:1rem}.ulv-selection-form-dialog__advanced-filters label{height:auto}.ulv-selection-form-dialog__toggle-filters{display:flex;justify-content:flex-end;align-items:flex-end}.ulv-selection-form-dialog__toggle-filters .fd-button{margin-bottom:.25rem}.ulv-selection-form-dialog__advanced-actions{display:flex;align-items:center;justify-content:flex-end}.ulv-selection-form-dialog-mobile .ulv-selection-form-dialog__advanced-actions{justify-content:flex-start}.ulv-selection-form-dialog__advanced-actions .fd-toolbar{padding:0}.ulv-selection-form-dialog fd-dialog-body{height:100%;display:flex;flex-direction:column;overflow-y:hidden}.ulv-selection-form-dialog bsu-ui-ulv-main-ui{height:100%;flex-grow:1}.ulv-selection-form-dialog bsu-ui-ulv-main-ui .viewer-container{height:100%!important;overflow:auto}.ulv-selection-form-dialog .ulv-selection-form-dialog__row{border-top:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9);padding-top:1rem}.ulv-selection-form-dialog bsu-search-panel{border-bottom:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9)}.ulv-selection-form-dialog fd-dialog-footer{height:auto}.ulv-selection-form-dialog .fd-dialog__footer{flex-direction:column}.ulv-selection-form-dialog .fd-dialog__footer.fd-bar{padding:0!important}.ulv-selection-form-dialog .fd-dialog__footer{border-top:none}.ulv-selection-form-dialog__content-holder{padding:0 2rem 1rem;display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.ulv-selection-form-dialog__row{padding:0 2rem 1rem}.ulv-selection-form-dialog__row.ulv-selection-form-dialog__selection-row{background-color:#f7f7f7;background-color:var(--sapBackgroundColor, #f7f7f7)}.ulv-selection-form-dialog__tokens-wrapper{display:flex}.ulv-selection-form-dialog__tokens{display:flex;flex:1 1 auto;overflow:hidden;align-items:center;border:1px solid #89919a;border-color:var(--sapContent_ForegroundBorderColor, #89919a);margin-right:.5rem;border-radius:.25rem;border-radius:var(--sapElement_BorderCornerRadius, .25rem);background:none}.ulv-selection-form-dialog__tokens fd-toolbar{flex:1 1 auto;overflow:hidden}.ulv-selection-form-dialog__tokens-clear{height:auto;min-width:2rem;padding:.125rem 0;justify-content:center}.ulv-selection-form-dialog__actions-row{padding:.5rem 0;display:flex;align-items:center;justify-content:flex-end;border-top:.0625rem solid #d9d9d9;border-top:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9)}.ulv-selection-form-dialog__actions-row .fd-button{margin-left:.5rem}.ulv-selection-form-dialog__tokens-wrapper{align-items:center}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.BarLeftDirective, selector: "[fd-bar-left]" }, { kind: "directive", type: i4.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "directive", type: i4.BarElementDirective, selector: "fd-bar-element", inputs: ["fullWidth", "isTitle"] }, { kind: "component", type: i4.ButtonBarComponent, selector: "fd-button-bar", inputs: ["fullWidth", "fdType", "title", "ariaLabel", "ariaLabelledby", "id"] }, { kind: "component", type: i5.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "directive", type: i5.DeprecatedButtonContentDensityDirective, selector: "[fd-button][compact]" }, { kind: "component", type: i6.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i6.DialogBodyComponent, selector: "fd-dialog-body" }, { kind: "component", type: i6.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i6.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "directive", type: i6.DialogDecisiveButtonDirective, selector: "[fd-dialog-decisive-button]" }, { kind: "component", type: i7.TitleComponent, selector: "h1[fd-title], h2[fd-title], h3[fd-title], h4[fd-title], h5[fd-title], h6[fd-title]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "directive", type: i8.TemplateDirective, selector: "[fdTemplate]", inputs: ["fdTemplate"] }, { 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: "directive", type: i9.ToolbarOverflowPriorityDirective, selector: "[fdOverflowPriority]", inputs: ["fdOverflowPriority"] }, { kind: "component", type: i10.TokenComponent, selector: "fd-token", inputs: ["disabled", "selected", "readOnly", "deleteButtonLabel", "ariaRoleDescription"], outputs: ["onCloseClick", "onRemove", "onTokenClick", "onTokenKeydown"] }, { kind: "directive", type: i11.PlatformContentDensityDeprecationDirective, selector: " fdp-action-bar[contentDensity], fdp-button[contentDensity], fdp-object-list-item[contentDensity], fdp-standard-list-item[contentDensity], fdp-menu[contentDensity], fdp-menu-button[contentDensity], fdp-panel[contentDensity], fdp-search-field[contentDensity], fdp-split-menu-button[contentDensity], fdp-file-uploader[contentDensity], fdp-upload-collection[contentDensity], fdp-table[contentDensity], fdp-multi-input[contentDensity], fdp-list[contentDensity], fdp-slider[contentDensity], fdp-time-picker[contentDensity], fdp-textarea[contentDensity], fdp-switch[contentDensity], fdp-number-step-input[contentDensity], fdp-select[contentDensity], fdp-date-picker[contentDensity], fdp-checkbox[contentDensity], fdp-checkbox-group[contentDensity], fdp-combobox[contentDensity], fdp-datetime-picker[contentDensity], fdp-input[contentDensity], fdp-radio-group[contentDensity], fdp-radio-button[contentDensity], fdp-multi-combobox[contentDensity], fdp-input-group-addon-body[contentDensity], fdp-input-group[contentDensity], fdp-value-help-dialog[contentDensity], fdp-filter-single-select[contentDensity], fdp-filter-multi-select[contentDensity], fdp-filter-custom[contentDensity] " }, { kind: "component", type: i12.ButtonComponent, selector: "fdp-button", inputs: ["glyphPosition", "label", "glyph", "buttonType", "title", "ariaSelected", "ariaDisabled", "ariaExpanded", "ariaControlsId", "ariaPressed", "name", "type", "value"], outputs: ["buttonClicked"] }, { kind: "component", type: i13.UiUlvMainUiComponent, selector: "bsu-ui-ulv-main-ui", inputs: ["context", "isReportPage", "inDialog", "isMultiSelect", "layoutInfo", "fullscreen"] }, { kind: "directive", type: i14.FullscreenDialogDirective, selector: "[fullscreenDialog]", inputs: ["dialog", "dialogComponent"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
175
+ UlvFormMultiSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UlvFormMultiSelectComponent, selector: "bsu-ulv-form-multi-select", inputs: { Show: "Show" }, viewQueries: [{ propertyName: "dialogContainer", first: true, predicate: ["container"], descendants: true, read: TemplateRef }], usesInheritance: true, ngImport: i0, template: "<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #container>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTpl>\n <fd-dialog-header>\n <ng-template fdTemplate=\"header\">\n <div fd-bar-left>\n <fd-bar-element>\n <h1 id=\"fd-dialog-header-3\" fd-title>{{ dialog.data.title }}</h1>\n </fd-bar-element>\n </div>\n <div fd-bar-right>\n <fd-button-bar\n *ngIf=\"!dialogConfig.fullscreen\"\n ariaLabel=\"fullscreen\"\n [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n fullscreenDialog\n [dialog]=\"dialog\"\n [dialogComponent]=\"dialogTpl\"\n ></fd-button-bar>\n <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel(dialog)\"></fd-button-bar>\n </div>\n </ng-template>\n <!-- <h3 fd-title>{{ dialog.data.title }}</h3>\n <button fd-dialog-close-button></button> -->\n </fd-dialog-header>\n\n <fd-dialog-body>\n <ng-container *ngIf=\"dialog.data.ulv1 as ulv1\">\n <bsu-ui-ulv-main-ui\n class=\"ulv-form-multi-select\"\n [context]=\"ulv1\"\n [inDialog]=\"true\"\n [isMultiSelect]=\"dialog.data.ShowSecondPanel\"\n [fullscreen]=\"dialog.data.fullscreen\"\n ></bsu-ui-ulv-main-ui>\n </ng-container>\n <div\n *ngIf=\"dialog.data.ulv2 && dialog.data.ShowSecondPanel\"\n class=\"ulv-selection-form-dialog__row ulv-selection-form-dialog__selection-row\"\n [aria-label]=\"'SelectedItemsAndConditions' | bbbTranslate\"\n >\n <h5 fd-title class=\"selected-and-condition-title\">\n <ng-container>\n <ng-container>{{ 'SelectedItemsAndConditions' | bbbTranslate }} </ng-container>\n ({{ dialog.data.selectedItems?.MoDataList?.length || 0 }})\n </ng-container>\n </h5>\n\n <div class=\"ulv-selection-form-dialog__tokens-wrapper\">\n <div class=\"ulv-selection-form-dialog__tokens\">\n <fd-toolbar [shouldOverflow]=\"true\" *ngIf=\"dialog.data.selectedItems\">\n <!-- Selected items -->\n <fd-token\n fd-toolbar-item\n fdOverflowPriority=\"high\"\n class=\"fdp-value-help-dialog__selection-token\"\n (onCloseClick)=\"onRemoveSelected(dialog, item)\"\n *ngFor=\"\n let item of dialog.data.selectedItems.MoDataList;\n index as selectedIndex;\n trackBy: _trackBySelectedFn\n \"\n >{{ item.$Caption }}\n </fd-token>\n </fd-toolbar>\n </div>\n <button\n class=\"ulv-selection-form-dialog__tokens-clear\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n [aria-label]=\"'Clear' | bbbTranslate\"\n (click)=\"onClear(dialog)\"\n ></button>\n </div>\n </div>\n </fd-dialog-body>\n\n <fd-dialog-footer *ngIf=\"dialog.data.ulv1 && !dialog.data.ulv1?.HideOkCancelButtons\">\n <ng-template fdTemplate=\"footer\">\n <div\n class=\"ulv-selection-form-dialog__actions-row\"\n *ngIf=\"dialog.data.adapter?.ShowOkCancelButtons !== false\"\n >\n <button\n fd-button\n data-succes\n [label]=\"'OK' | bbbTranslate\"\n fdType=\"emphasized\"\n [compact]=\"true\"\n (click)=\"onOk(dialog)\"\n ></button>\n <button\n fd-button\n fdCompact\n data-dismiss-dialog\n fd-dialog-decisive-button\n [label]=\"'Cancel' | bbbTranslate\"\n [fdType]=\"'transparent'\"\n (click)=\"onCancel(dialog)\"\n ></button>\n </div>\n </ng-template>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [".ulv-selection-form-dialog{cursor:default}.ulv-selection-form-dialog .fd-dialog__body bsu-ui-table-view{overflow-x:inherit!important}.ulv-selection-form-dialog__advanced-filters{padding-top:1rem}.ulv-selection-form-dialog__advanced-filters label{height:auto}.ulv-selection-form-dialog__toggle-filters{display:flex;justify-content:flex-end;align-items:flex-end}.ulv-selection-form-dialog__toggle-filters .fd-button{margin-bottom:.25rem}.ulv-selection-form-dialog__advanced-actions{display:flex;align-items:center;justify-content:flex-end}.ulv-selection-form-dialog-mobile .ulv-selection-form-dialog__advanced-actions{justify-content:flex-start}.ulv-selection-form-dialog__advanced-actions .fd-toolbar{padding:0}.ulv-selection-form-dialog fd-dialog-body{height:100%;display:flex;flex-direction:column;overflow-y:hidden}.ulv-selection-form-dialog bsu-ui-ulv-main-ui{height:100%;flex-grow:1}.ulv-selection-form-dialog bsu-ui-ulv-main-ui .viewer-container{height:100%!important;overflow:auto}.ulv-selection-form-dialog .ulv-selection-form-dialog__row{border-top:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9);padding-top:1rem}.ulv-selection-form-dialog bsu-search-panel{border-bottom:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9)}.ulv-selection-form-dialog fd-dialog-footer{height:auto}.ulv-selection-form-dialog .fd-dialog__footer{flex-direction:column}.ulv-selection-form-dialog .fd-dialog__footer.fd-bar{padding:0!important}.ulv-selection-form-dialog .fd-dialog__footer{border-top:none}.ulv-selection-form-dialog__content-holder{padding:0 2rem 1rem;display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.ulv-selection-form-dialog__row{padding:0 2rem 1rem}.ulv-selection-form-dialog__row.ulv-selection-form-dialog__selection-row{background-color:#f7f7f7;background-color:var(--sapBackgroundColor, #f7f7f7)}.ulv-selection-form-dialog__tokens-wrapper{display:flex}.ulv-selection-form-dialog__tokens{display:flex;flex:1 1 auto;overflow:hidden;align-items:center;border:1px solid #89919a;border-color:var(--sapContent_ForegroundBorderColor, #89919a);margin-right:.5rem;border-radius:.25rem;border-radius:var(--sapElement_BorderCornerRadius, .25rem);background:none}.ulv-selection-form-dialog__tokens fd-toolbar{flex:1 1 auto;overflow:hidden}.ulv-selection-form-dialog__tokens-clear{height:auto;min-width:2rem;padding:.125rem 0;justify-content:center}.ulv-selection-form-dialog__actions-row{padding:.5rem 0;display:flex;align-items:center;justify-content:flex-end;border-top:.0625rem solid #d9d9d9;border-top:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9)}.ulv-selection-form-dialog__actions-row .fd-button{margin-left:.5rem}.ulv-selection-form-dialog__tokens-wrapper{align-items:center}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.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: "directive", type: i5.BarLeftDirective, selector: "[fd-bar-left]" }, { kind: "directive", type: i5.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "directive", type: i5.BarElementDirective, selector: "fd-bar-element", inputs: ["fullWidth", "isTitle"] }, { kind: "component", type: i5.ButtonBarComponent, selector: "fd-button-bar", inputs: ["fullWidth", "fdType", "title", "ariaLabel", "ariaLabelledby", "id"] }, { kind: "component", type: i6.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "directive", type: i6.DeprecatedButtonContentDensityDirective, selector: "[fd-button][compact]" }, { kind: "component", type: i7.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i7.DialogBodyComponent, selector: "fd-dialog-body" }, { kind: "component", type: i7.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i7.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "directive", type: i7.DialogDecisiveButtonDirective, selector: "[fd-dialog-decisive-button]" }, { kind: "component", type: i8.TitleComponent, selector: "h1[fd-title], h2[fd-title], h3[fd-title], h4[fd-title], h5[fd-title], h6[fd-title]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "directive", type: i9.TemplateDirective, selector: "[fdTemplate]", inputs: ["fdTemplate"] }, { 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: "directive", type: i10.ToolbarOverflowPriorityDirective, selector: "[fdOverflowPriority]", inputs: ["fdOverflowPriority"] }, { kind: "component", type: i11.TokenComponent, selector: "fd-token", inputs: ["disabled", "selected", "readOnly", "deleteButtonLabel", "ariaRoleDescription"], outputs: ["onCloseClick", "onRemove", "onTokenClick", "onTokenKeydown"] }, { kind: "component", type: i12.UiUlvMainUiComponent, selector: "bsu-ui-ulv-main-ui", inputs: ["context", "isReportPage", "inDialog", "isMultiSelect", "layoutInfo", "fullscreen"] }, { kind: "directive", type: i13.FullscreenDialogDirective, selector: "[fullscreenDialog]", inputs: ["dialog", "dialogComponent"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
177
176
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UlvFormMultiSelectComponent, decorators: [{
178
177
  type: Component,
179
- args: [{ selector: 'bsu-ulv-form-multi-select', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #container>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTpl>\n <fd-dialog-header>\n <ng-template fdTemplate=\"header\">\n <div fd-bar-left>\n <fd-bar-element>\n <h1 id=\"fd-dialog-header-3\" fd-title>{{ dialog.data.title }}</h1>\n </fd-bar-element>\n </div>\n <div fd-bar-right>\n <fd-button-bar\n *ngIf=\"!dialogConfig.fullscreen\"\n ariaLabel=\"fullscreen\"\n [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n fullscreenDialog\n [dialog]=\"dialog\"\n [dialogComponent]=\"dialogTpl\"\n ></fd-button-bar>\n <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel(dialog)\"></fd-button-bar>\n </div>\n </ng-template>\n <!-- <h3 fd-title>{{ dialog.data.title }}</h3>\n <button fd-dialog-close-button></button> -->\n </fd-dialog-header>\n\n <fd-dialog-body>\n <ng-container *ngIf=\"dialog.data.ulv1 as ulv1\">\n <bsu-ui-ulv-main-ui\n class=\"ulv-form-multi-select\"\n [context]=\"ulv1\"\n [inDialog]=\"true\"\n [isMultiSelect]=\"dialog.data.ShowSecondPanel\"\n [fullscreen]=\"dialog.data.fullscreen\"\n ></bsu-ui-ulv-main-ui>\n </ng-container>\n <div\n *ngIf=\"dialog.data.ulv2 && dialog.data.ShowSecondPanel\"\n class=\"ulv-selection-form-dialog__row ulv-selection-form-dialog__selection-row\"\n [aria-label]=\"'SelectedItemsAndConditions' | bbbTranslate\"\n >\n <h5 fd-title class=\"selected-and-condition-title\">\n <ng-container>\n <ng-container>{{ 'SelectedItemsAndConditions' | bbbTranslate }} </ng-container>\n ({{ dialog.data.selectedItems?.MoDataList?.length || 0 }})\n </ng-container>\n </h5>\n\n <div class=\"ulv-selection-form-dialog__tokens-wrapper\">\n <div class=\"ulv-selection-form-dialog__tokens\">\n <fd-toolbar [shouldOverflow]=\"true\" *ngIf=\"dialog.data.selectedItems\">\n <!-- Selected items -->\n <fd-token\n fd-toolbar-item\n fdOverflowPriority=\"high\"\n class=\"fdp-value-help-dialog__selection-token\"\n (onCloseClick)=\"onRemoveSelected(dialog, item)\"\n *ngFor=\"\n let item of dialog.data.selectedItems.MoDataList;\n index as selectedIndex;\n trackBy: _trackBySelectedFn\n \"\n >{{ item.$Caption }}\n </fd-token>\n </fd-toolbar>\n </div>\n <button\n class=\"ulv-selection-form-dialog__tokens-clear\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n [aria-label]=\"'Clear' | bbbTranslate\"\n (click)=\"onClear(dialog)\"\n ></button>\n </div>\n </div>\n </fd-dialog-body>\n\n <fd-dialog-footer *ngIf=\"dialog.data.ulv1 && !dialog.data.ulv1?.HideOkCancelButtons\">\n <ng-template fdTemplate=\"footer\">\n <div\n class=\"ulv-selection-form-dialog__actions-row\"\n *ngIf=\"dialog.data.adapter?.ShowOkCancelButtons !== false\"\n >\n <button\n fd-button\n data-succes\n [label]=\"'OK' | bbbTranslate\"\n fdType=\"emphasized\"\n [compact]=\"true\"\n (click)=\"onOk(dialog)\"\n ></button>\n <fdp-button\n [contentDensity]=\"'compact'\"\n data-dismiss-dialog\n fd-dialog-decisive-button\n [label]=\"'Cancel' | bbbTranslate\"\n [buttonType]=\"'transparent'\"\n (click)=\"onCancel(dialog)\"\n ></fdp-button>\n </div>\n </ng-template>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [".ulv-selection-form-dialog{cursor:default}.ulv-selection-form-dialog .fd-dialog__body bsu-ui-table-view{overflow-x:inherit!important}.ulv-selection-form-dialog__advanced-filters{padding-top:1rem}.ulv-selection-form-dialog__advanced-filters label{height:auto}.ulv-selection-form-dialog__toggle-filters{display:flex;justify-content:flex-end;align-items:flex-end}.ulv-selection-form-dialog__toggle-filters .fd-button{margin-bottom:.25rem}.ulv-selection-form-dialog__advanced-actions{display:flex;align-items:center;justify-content:flex-end}.ulv-selection-form-dialog-mobile .ulv-selection-form-dialog__advanced-actions{justify-content:flex-start}.ulv-selection-form-dialog__advanced-actions .fd-toolbar{padding:0}.ulv-selection-form-dialog fd-dialog-body{height:100%;display:flex;flex-direction:column;overflow-y:hidden}.ulv-selection-form-dialog bsu-ui-ulv-main-ui{height:100%;flex-grow:1}.ulv-selection-form-dialog bsu-ui-ulv-main-ui .viewer-container{height:100%!important;overflow:auto}.ulv-selection-form-dialog .ulv-selection-form-dialog__row{border-top:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9);padding-top:1rem}.ulv-selection-form-dialog bsu-search-panel{border-bottom:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9)}.ulv-selection-form-dialog fd-dialog-footer{height:auto}.ulv-selection-form-dialog .fd-dialog__footer{flex-direction:column}.ulv-selection-form-dialog .fd-dialog__footer.fd-bar{padding:0!important}.ulv-selection-form-dialog .fd-dialog__footer{border-top:none}.ulv-selection-form-dialog__content-holder{padding:0 2rem 1rem;display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.ulv-selection-form-dialog__row{padding:0 2rem 1rem}.ulv-selection-form-dialog__row.ulv-selection-form-dialog__selection-row{background-color:#f7f7f7;background-color:var(--sapBackgroundColor, #f7f7f7)}.ulv-selection-form-dialog__tokens-wrapper{display:flex}.ulv-selection-form-dialog__tokens{display:flex;flex:1 1 auto;overflow:hidden;align-items:center;border:1px solid #89919a;border-color:var(--sapContent_ForegroundBorderColor, #89919a);margin-right:.5rem;border-radius:.25rem;border-radius:var(--sapElement_BorderCornerRadius, .25rem);background:none}.ulv-selection-form-dialog__tokens fd-toolbar{flex:1 1 auto;overflow:hidden}.ulv-selection-form-dialog__tokens-clear{height:auto;min-width:2rem;padding:.125rem 0;justify-content:center}.ulv-selection-form-dialog__actions-row{padding:.5rem 0;display:flex;align-items:center;justify-content:flex-end;border-top:.0625rem solid #d9d9d9;border-top:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9)}.ulv-selection-form-dialog__actions-row .fd-button{margin-left:.5rem}.ulv-selection-form-dialog__tokens-wrapper{align-items:center}\n"] }]
178
+ args: [{ selector: 'bsu-ulv-form-multi-select', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #container>\n <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTpl>\n <fd-dialog-header>\n <ng-template fdTemplate=\"header\">\n <div fd-bar-left>\n <fd-bar-element>\n <h1 id=\"fd-dialog-header-3\" fd-title>{{ dialog.data.title }}</h1>\n </fd-bar-element>\n </div>\n <div fd-bar-right>\n <fd-button-bar\n *ngIf=\"!dialogConfig.fullscreen\"\n ariaLabel=\"fullscreen\"\n [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n fullscreenDialog\n [dialog]=\"dialog\"\n [dialogComponent]=\"dialogTpl\"\n ></fd-button-bar>\n <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel(dialog)\"></fd-button-bar>\n </div>\n </ng-template>\n <!-- <h3 fd-title>{{ dialog.data.title }}</h3>\n <button fd-dialog-close-button></button> -->\n </fd-dialog-header>\n\n <fd-dialog-body>\n <ng-container *ngIf=\"dialog.data.ulv1 as ulv1\">\n <bsu-ui-ulv-main-ui\n class=\"ulv-form-multi-select\"\n [context]=\"ulv1\"\n [inDialog]=\"true\"\n [isMultiSelect]=\"dialog.data.ShowSecondPanel\"\n [fullscreen]=\"dialog.data.fullscreen\"\n ></bsu-ui-ulv-main-ui>\n </ng-container>\n <div\n *ngIf=\"dialog.data.ulv2 && dialog.data.ShowSecondPanel\"\n class=\"ulv-selection-form-dialog__row ulv-selection-form-dialog__selection-row\"\n [aria-label]=\"'SelectedItemsAndConditions' | bbbTranslate\"\n >\n <h5 fd-title class=\"selected-and-condition-title\">\n <ng-container>\n <ng-container>{{ 'SelectedItemsAndConditions' | bbbTranslate }} </ng-container>\n ({{ dialog.data.selectedItems?.MoDataList?.length || 0 }})\n </ng-container>\n </h5>\n\n <div class=\"ulv-selection-form-dialog__tokens-wrapper\">\n <div class=\"ulv-selection-form-dialog__tokens\">\n <fd-toolbar [shouldOverflow]=\"true\" *ngIf=\"dialog.data.selectedItems\">\n <!-- Selected items -->\n <fd-token\n fd-toolbar-item\n fdOverflowPriority=\"high\"\n class=\"fdp-value-help-dialog__selection-token\"\n (onCloseClick)=\"onRemoveSelected(dialog, item)\"\n *ngFor=\"\n let item of dialog.data.selectedItems.MoDataList;\n index as selectedIndex;\n trackBy: _trackBySelectedFn\n \"\n >{{ item.$Caption }}\n </fd-token>\n </fd-toolbar>\n </div>\n <button\n class=\"ulv-selection-form-dialog__tokens-clear\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n [aria-label]=\"'Clear' | bbbTranslate\"\n (click)=\"onClear(dialog)\"\n ></button>\n </div>\n </div>\n </fd-dialog-body>\n\n <fd-dialog-footer *ngIf=\"dialog.data.ulv1 && !dialog.data.ulv1?.HideOkCancelButtons\">\n <ng-template fdTemplate=\"footer\">\n <div\n class=\"ulv-selection-form-dialog__actions-row\"\n *ngIf=\"dialog.data.adapter?.ShowOkCancelButtons !== false\"\n >\n <button\n fd-button\n data-succes\n [label]=\"'OK' | bbbTranslate\"\n fdType=\"emphasized\"\n [compact]=\"true\"\n (click)=\"onOk(dialog)\"\n ></button>\n <button\n fd-button\n fdCompact\n data-dismiss-dialog\n fd-dialog-decisive-button\n [label]=\"'Cancel' | bbbTranslate\"\n [fdType]=\"'transparent'\"\n (click)=\"onCancel(dialog)\"\n ></button>\n </div>\n </ng-template>\n </fd-dialog-footer>\n </fd-dialog>\n</ng-template>\n", styles: [".ulv-selection-form-dialog{cursor:default}.ulv-selection-form-dialog .fd-dialog__body bsu-ui-table-view{overflow-x:inherit!important}.ulv-selection-form-dialog__advanced-filters{padding-top:1rem}.ulv-selection-form-dialog__advanced-filters label{height:auto}.ulv-selection-form-dialog__toggle-filters{display:flex;justify-content:flex-end;align-items:flex-end}.ulv-selection-form-dialog__toggle-filters .fd-button{margin-bottom:.25rem}.ulv-selection-form-dialog__advanced-actions{display:flex;align-items:center;justify-content:flex-end}.ulv-selection-form-dialog-mobile .ulv-selection-form-dialog__advanced-actions{justify-content:flex-start}.ulv-selection-form-dialog__advanced-actions .fd-toolbar{padding:0}.ulv-selection-form-dialog fd-dialog-body{height:100%;display:flex;flex-direction:column;overflow-y:hidden}.ulv-selection-form-dialog bsu-ui-ulv-main-ui{height:100%;flex-grow:1}.ulv-selection-form-dialog bsu-ui-ulv-main-ui .viewer-container{height:100%!important;overflow:auto}.ulv-selection-form-dialog .ulv-selection-form-dialog__row{border-top:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9);padding-top:1rem}.ulv-selection-form-dialog bsu-search-panel{border-bottom:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9)}.ulv-selection-form-dialog fd-dialog-footer{height:auto}.ulv-selection-form-dialog .fd-dialog__footer{flex-direction:column}.ulv-selection-form-dialog .fd-dialog__footer.fd-bar{padding:0!important}.ulv-selection-form-dialog .fd-dialog__footer{border-top:none}.ulv-selection-form-dialog__content-holder{padding:0 2rem 1rem;display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.ulv-selection-form-dialog__row{padding:0 2rem 1rem}.ulv-selection-form-dialog__row.ulv-selection-form-dialog__selection-row{background-color:#f7f7f7;background-color:var(--sapBackgroundColor, #f7f7f7)}.ulv-selection-form-dialog__tokens-wrapper{display:flex}.ulv-selection-form-dialog__tokens{display:flex;flex:1 1 auto;overflow:hidden;align-items:center;border:1px solid #89919a;border-color:var(--sapContent_ForegroundBorderColor, #89919a);margin-right:.5rem;border-radius:.25rem;border-radius:var(--sapElement_BorderCornerRadius, .25rem);background:none}.ulv-selection-form-dialog__tokens fd-toolbar{flex:1 1 auto;overflow:hidden}.ulv-selection-form-dialog__tokens-clear{height:auto;min-width:2rem;padding:.125rem 0;justify-content:center}.ulv-selection-form-dialog__actions-row{padding:.5rem 0;display:flex;align-items:center;justify-content:flex-end;border-top:.0625rem solid #d9d9d9;border-top:.0625rem solid var(--sapPageFooter_BorderColor, #d9d9d9)}.ulv-selection-form-dialog__actions-row .fd-button{margin-left:.5rem}.ulv-selection-form-dialog__tokens-wrapper{align-items:center}\n"] }]
180
179
  }], ctorParameters: function () { return [{ type: i1.DialogService }, { type: i2.BbbTranslatePipe }, { type: i2.PortalService }, { type: i1.ContentDensityService }]; }, propDecorators: { dialogContainer: [{
181
180
  type: ViewChild,
182
181
  args: ['container', { read: TemplateRef }]
183
182
  }], Show: [{
184
183
  type: Input
185
184
  }] } });
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ulv-form-multi-select.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ulv-form-multi-select/ulv-form-multi-select.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ulv-form-multi-select/ulv-form-multi-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { ContentDensity, ContentDensityService, DialogRef, DialogService } from '@fundamental-ngx/core';\nimport { BaseComponent, BarsaApi, MetaobjectDataModel, BbbTranslatePipe, PortalService } from 'barsa-novin-ray-core';\nimport { Observable } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\n@Component({\n    selector: 'bsu-ulv-form-multi-select',\n    templateUrl: './ulv-form-multi-select.component.html',\n    styleUrls: ['./ulv-form-multi-select.component.scss'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class UlvFormMultiSelectComponent extends BaseComponent {\n    @ViewChild('container', { read: TemplateRef })\n    dialogContainer: TemplateRef<any>;\n\n    deviceSize: string;\n    contentDensity$: Observable<ContentDensity>;\n\n    constructor(\n        private _dialogService: DialogService,\n        private _bbbTranslatePipe: BbbTranslatePipe,\n        _portalService: PortalService,\n        _contentDensityService: ContentDensityService\n    ) {\n        super();\n        this.contentDensity$ = _contentDensityService.contentDensity;\n        BarsaApi.Bw.UlvFormMultiSelect = this;\n        _portalService.deviceSize$.pipe(takeUntil(this._onDestroy$)).subscribe((c) => {\n            this.deviceSize = c;\n        });\n    }\n    /* eslint-disable */\n    @Input() Show = (adapter, config) => {\n        const largeScreen = this.deviceSize === 'l' || this.deviceSize === 'xl';\n        const dialogConfig: { [key: string]: any } = {\n            data: { ...config, adapter },\n            escKeyCloseable: false,\n            dialogPanelClass: `ulv-selection-form-dialog ${this.deviceSize ? 'ulv-selection-form-dialog-mobile' : ''}`,\n            verticalPadding: false\n        };\n        if (largeScreen) {\n            dialogConfig.width = '50vw';\n            dialogConfig.height = 'auto';\n            dialogConfig.minWidth = '400';\n            dialogConfig.minHeight = '60vh';\n        } else {\n            dialogConfig.mobile = true;\n            dialogConfig.fullScreen = true;\n        }\n        if (adapter.HideOkCancelButtons) {\n            dialogConfig.fullScreen = true;\n        }\n        const dialogRef = this._dialogService.open(this.dialogContainer, dialogConfig);\n        dialogRef.loading(config.IsLoaded === true ? false : true); // means ulv is loaded and it does not show loading in dialog\n        (dialogRef as any).mask = (val) => {\n            dialogRef.loading(val);\n        };\n        (dialogRef as any).AddUlvToWindow = (ulvControl1, ulvControl2) => {\n            dialogRef.loading(false);\n            const selectFormTitleText = this._bbbTranslatePipe.transform('SelectFormTitle');\n            dialogRef.data.title =\n                ulvControl1.Setting.Extra?.ExtraJsonPropReport?.Title === false\n                    ? ''\n                    : selectFormTitleText.replace('{0}', ulvControl1.Setting.Extra.Report.TypeDefCaption);\n            dialogRef.data.ulv1 = ulvControl1;\n            if (ulvControl1.viewerControl) {\n                this._handleUlvViewerEvent(ulvControl1, adapter, dialogRef);\n            } else {\n                ulvControl1.on({\n                    ViewerControlChanged: () => {\n                        this._handleUlvViewerEvent(ulvControl1, adapter, dialogRef);\n                    }\n                });\n            }\n            if (ulvControl2) {\n                dialogRef.data.ulv2 = ulvControl2;\n                dialogRef.data.selectedItems = ulvControl2.Setting.Data;\n            }\n        };\n        return dialogRef;\n        /* eslint-disable */\n    };\n\n    private _handleUlvViewerEvent(ulvControl1: any, adapter: any, dialogRef: DialogRef<any, any>) {\n        ulvControl1.viewerControl.ShowOkCancelButtons = adapter.ShowOkCancelButtons;\n        ulvControl1.viewerControl.on({\n            /* eslint-disable */\n            rowselect: (sender, index, mo) => {\n                this._addItem(dialogRef, mo);\n            },\n            /* eslint-disable */\n            rowdeselect: (sender, index, mo) => {\n                this._removeItem(dialogRef, mo);\n            },\n            rowSelectAll: () => {\n                ulvControl1.Setting.Data.MoDataList.forEach((mo) => {\n                    this._addItem(dialogRef, mo);\n                });\n            },\n            rowDeSelectAll: () => {\n                ulvControl1.Setting.Data.MoDataList.forEach((mo) => {\n                    this._removeItem(dialogRef, mo);\n                });\n            }\n        });\n    }\n\n    onOk(dialogRef: DialogRef): void {\n        const { ulv, ulv2 } = this._getUlv(dialogRef);\n        // if (ulv) {\n        //     if (ulv2) {\n        //         const adapter = dialogRef.data.adapter;\n        //         adapter.fireEvent('AddRemoveButtonClick', adapter, 'Add');\n        //     }\n        // }\n        this._btnClick(ulv, 'Ok');\n    }\n\n    private _getUlv(dialogRef: DialogRef): { ulv: any; ulv2: any } {\n        const ulv2 = dialogRef.data.ulv2;\n        const ulv1 = dialogRef.data.ulv1;\n        const ulv = ulv2 || ulv1;\n        return { ulv, ulv2 };\n    }\n\n    private _btnClick(ulv: any, btnKey: string): void {\n        const okBtn = ulv.buttons.find((c) => c.Key === btnKey);\n        const scope = okBtn.scope;\n        okBtn.handler.bind(scope)(okBtn);\n    }\n\n    onCancel(dialogRef: DialogRef): void {\n        if (!dialogRef.data.adapter?.ShowOkCancelButtons) {\n            dialogRef.dismiss();\n            return;\n        }\n        const { ulv, ulv2 } = this._getUlv(dialogRef);\n        this._btnClick(ulv, 'Cancel');\n    }\n\n    onClear(dialogRef: DialogRef): void {\n        dialogRef.data.ulv1.viewerControl.fireEvent('ClearAllSelected');\n        dialogRef.data.selectedItems.MoDataList = [];\n    }\n\n    onRemoveSelected(dialogRef: DialogRef, item: MetaobjectDataModel): void {\n        this._removeItem(dialogRef, item);\n    }\n\n    protected _removeItem(dialogRef: DialogRef<any>, mo: any): void {\n        const selectedItems = dialogRef.data.selectedItems;\n        if (!selectedItems) {\n            return;\n        }\n        selectedItems.MoDataList = selectedItems.MoDataList.filter((c) => c.Id !== mo.Id);\n        dialogRef.data.ulv1.viewerControl.fireEvent('DeselectRowInDialog', [mo]);\n        if (dialogRef.data.ulv2) {\n            const adapter = dialogRef.data.adapter;\n            adapter.fireEvent('AddRemoveButtonClick', adapter, 'Remove');\n        }\n        // const adapter = dialogRef.data.adapter;\n        // adapter.fireEvent('AddRemoveButtonClick', adapter, 'Remove');\n    }\n\n    protected _addItem(dialogRef: DialogRef<any>, mo: MetaobjectDataModel): void {\n        const selectedItems = dialogRef.data.selectedItems;\n        if (!selectedItems) {\n            return;\n        }\n        if (!selectedItems.MoDataList.find((c) => c.Id === mo.Id)) {\n            selectedItems.MoDataList = [...selectedItems.MoDataList, mo];\n            if (dialogRef.data.ulv2) {\n                const adapter = dialogRef.data.adapter;\n                adapter.fireEvent('AddRemoveButtonClick', adapter, 'Add');\n            }\n\n            // const adapter = dialogRef.data.adapter;\n            // adapter.fireEvent('AddRemoveButtonClick', adapter, 'Add');\n        }\n    }\n\n    _trackBySelectedFn(_index: number, item: MetaobjectDataModel): number | string {\n        return item.Id;\n    }\n}\n","<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #container>\n    <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTpl>\n        <fd-dialog-header>\n            <ng-template fdTemplate=\"header\">\n                <div fd-bar-left>\n                    <fd-bar-element>\n                        <h1 id=\"fd-dialog-header-3\" fd-title>{{ dialog.data.title }}</h1>\n                    </fd-bar-element>\n                </div>\n                <div fd-bar-right>\n                    <fd-button-bar\n                        *ngIf=\"!dialogConfig.fullscreen\"\n                        ariaLabel=\"fullscreen\"\n                        [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n                        fullscreenDialog\n                        [dialog]=\"dialog\"\n                        [dialogComponent]=\"dialogTpl\"\n                    ></fd-button-bar>\n                    <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel(dialog)\"></fd-button-bar>\n                </div>\n            </ng-template>\n            <!-- <h3 fd-title>{{ dialog.data.title }}</h3>\n      <button fd-dialog-close-button></button> -->\n        </fd-dialog-header>\n\n        <fd-dialog-body>\n            <ng-container *ngIf=\"dialog.data.ulv1 as ulv1\">\n                <bsu-ui-ulv-main-ui\n                    class=\"ulv-form-multi-select\"\n                    [context]=\"ulv1\"\n                    [inDialog]=\"true\"\n                    [isMultiSelect]=\"dialog.data.ShowSecondPanel\"\n                    [fullscreen]=\"dialog.data.fullscreen\"\n                ></bsu-ui-ulv-main-ui>\n            </ng-container>\n            <div\n                *ngIf=\"dialog.data.ulv2 && dialog.data.ShowSecondPanel\"\n                class=\"ulv-selection-form-dialog__row ulv-selection-form-dialog__selection-row\"\n                [aria-label]=\"'SelectedItemsAndConditions' | bbbTranslate\"\n            >\n                <h5 fd-title class=\"selected-and-condition-title\">\n                    <ng-container>\n                        <ng-container>{{ 'SelectedItemsAndConditions' | bbbTranslate }} </ng-container>\n                        ({{ dialog.data.selectedItems?.MoDataList?.length || 0 }})\n                    </ng-container>\n                </h5>\n\n                <div class=\"ulv-selection-form-dialog__tokens-wrapper\">\n                    <div class=\"ulv-selection-form-dialog__tokens\">\n                        <fd-toolbar [shouldOverflow]=\"true\" *ngIf=\"dialog.data.selectedItems\">\n                            <!-- Selected items -->\n                            <fd-token\n                                fd-toolbar-item\n                                fdOverflowPriority=\"high\"\n                                class=\"fdp-value-help-dialog__selection-token\"\n                                (onCloseClick)=\"onRemoveSelected(dialog, item)\"\n                                *ngFor=\"\n                                    let item of dialog.data.selectedItems.MoDataList;\n                                    index as selectedIndex;\n                                    trackBy: _trackBySelectedFn\n                                \"\n                                >{{ item.$Caption }}\n                            </fd-token>\n                        </fd-toolbar>\n                    </div>\n                    <button\n                        class=\"ulv-selection-form-dialog__tokens-clear\"\n                        fd-button\n                        fdType=\"transparent\"\n                        glyph=\"decline\"\n                        [aria-label]=\"'Clear' | bbbTranslate\"\n                        (click)=\"onClear(dialog)\"\n                    ></button>\n                </div>\n            </div>\n        </fd-dialog-body>\n\n        <fd-dialog-footer *ngIf=\"dialog.data.ulv1 && !dialog.data.ulv1?.HideOkCancelButtons\">\n            <ng-template fdTemplate=\"footer\">\n                <div\n                    class=\"ulv-selection-form-dialog__actions-row\"\n                    *ngIf=\"dialog.data.adapter?.ShowOkCancelButtons !== false\"\n                >\n                    <button\n                        fd-button\n                        data-succes\n                        [label]=\"'OK' | bbbTranslate\"\n                        fdType=\"emphasized\"\n                        [compact]=\"true\"\n                        (click)=\"onOk(dialog)\"\n                    ></button>\n                    <fdp-button\n                        [contentDensity]=\"'compact'\"\n                        data-dismiss-dialog\n                        fd-dialog-decisive-button\n                        [label]=\"'Cancel' | bbbTranslate\"\n                        [buttonType]=\"'transparent'\"\n                        (click)=\"onCancel(dialog)\"\n                    ></fdp-button>\n                </div>\n            </ng-template>\n        </fd-dialog-footer>\n    </fd-dialog>\n</ng-template>\n"]}
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ulv-form-multi-select.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ulv-form-multi-select/ulv-form-multi-select.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ulv-form-multi-select/ulv-form-multi-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { ContentDensity, ContentDensityService, DialogRef, DialogService } from '@fundamental-ngx/core';\nimport { BaseComponent, BarsaApi, MetaobjectDataModel, BbbTranslatePipe, PortalService } from 'barsa-novin-ray-core';\nimport { Observable } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\n@Component({\n    selector: 'bsu-ulv-form-multi-select',\n    templateUrl: './ulv-form-multi-select.component.html',\n    styleUrls: ['./ulv-form-multi-select.component.scss'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class UlvFormMultiSelectComponent extends BaseComponent {\n    @ViewChild('container', { read: TemplateRef })\n    dialogContainer: TemplateRef<any>;\n\n    deviceSize: string;\n    contentDensity$: Observable<ContentDensity>;\n\n    constructor(\n        private _dialogService: DialogService,\n        private _bbbTranslatePipe: BbbTranslatePipe,\n        _portalService: PortalService,\n        _contentDensityService: ContentDensityService\n    ) {\n        super();\n        this.contentDensity$ = _contentDensityService.contentDensity;\n        BarsaApi.Bw.UlvFormMultiSelect = this;\n        _portalService.deviceSize$.pipe(takeUntil(this._onDestroy$)).subscribe((c) => {\n            this.deviceSize = c;\n        });\n    }\n    /* eslint-disable */\n    @Input() Show = (adapter, config) => {\n        const largeScreen = this.deviceSize === 'l' || this.deviceSize === 'xl';\n        const dialogConfig: { [key: string]: any } = {\n            data: { ...config, adapter },\n            escKeyCloseable: false,\n            dialogPanelClass: `ulv-selection-form-dialog ${this.deviceSize ? 'ulv-selection-form-dialog-mobile' : ''}`,\n            verticalPadding: false\n        };\n        if (largeScreen) {\n            dialogConfig.width = '50vw';\n            dialogConfig.height = 'auto';\n            dialogConfig.minWidth = '400';\n            dialogConfig.minHeight = '60vh';\n        } else {\n            dialogConfig.mobile = true;\n            dialogConfig.fullScreen = true;\n        }\n        if (adapter.HideOkCancelButtons) {\n            dialogConfig.fullScreen = true;\n        }\n        const dialogRef = this._dialogService.open(this.dialogContainer, dialogConfig);\n        dialogRef.loading(config.IsLoaded === true ? false : true); // means ulv is loaded and it does not show loading in dialog\n        (dialogRef as any).mask = (val) => {\n            dialogRef.loading(val);\n        };\n        (dialogRef as any).AddUlvToWindow = (ulvControl1, ulvControl2) => {\n            dialogRef.loading(false);\n            const selectFormTitleText = this._bbbTranslatePipe.transform('SelectFormTitle');\n            dialogRef.data.title =\n                ulvControl1.Setting.Extra?.ExtraJsonPropReport?.Title === false\n                    ? ''\n                    : selectFormTitleText.replace('{0}', ulvControl1.Setting.Extra.Report.TypeDefCaption);\n            dialogRef.data.ulv1 = ulvControl1;\n            if (ulvControl1.viewerControl) {\n                this._handleUlvViewerEvent(ulvControl1, adapter, dialogRef);\n            } else {\n                ulvControl1.on({\n                    ViewerControlChanged: () => {\n                        this._handleUlvViewerEvent(ulvControl1, adapter, dialogRef);\n                    }\n                });\n            }\n            if (ulvControl2) {\n                dialogRef.data.ulv2 = ulvControl2;\n                dialogRef.data.selectedItems = ulvControl2.Setting.Data;\n            }\n        };\n        return dialogRef;\n        /* eslint-disable */\n    };\n\n    private _handleUlvViewerEvent(ulvControl1: any, adapter: any, dialogRef: DialogRef<any, any>) {\n        ulvControl1.viewerControl.ShowOkCancelButtons = adapter.ShowOkCancelButtons;\n        ulvControl1.viewerControl.on({\n            /* eslint-disable */\n            rowselect: (sender, index, mo) => {\n                this._addItem(dialogRef, mo);\n            },\n            /* eslint-disable */\n            rowdeselect: (sender, index, mo) => {\n                this._removeItem(dialogRef, mo);\n            },\n            rowSelectAll: () => {\n                ulvControl1.Setting.Data.MoDataList.forEach((mo) => {\n                    this._addItem(dialogRef, mo);\n                });\n            },\n            rowDeSelectAll: () => {\n                ulvControl1.Setting.Data.MoDataList.forEach((mo) => {\n                    this._removeItem(dialogRef, mo);\n                });\n            }\n        });\n    }\n\n    onOk(dialogRef: DialogRef): void {\n        const { ulv, ulv2 } = this._getUlv(dialogRef);\n        // if (ulv) {\n        //     if (ulv2) {\n        //         const adapter = dialogRef.data.adapter;\n        //         adapter.fireEvent('AddRemoveButtonClick', adapter, 'Add');\n        //     }\n        // }\n        this._btnClick(ulv, 'Ok');\n    }\n\n    private _getUlv(dialogRef: DialogRef): { ulv: any; ulv2: any } {\n        const ulv2 = dialogRef.data.ulv2;\n        const ulv1 = dialogRef.data.ulv1;\n        const ulv = ulv2 || ulv1;\n        return { ulv, ulv2 };\n    }\n\n    private _btnClick(ulv: any, btnKey: string): void {\n        const okBtn = ulv.buttons.find((c) => c.Key === btnKey);\n        const scope = okBtn.scope;\n        okBtn.handler.bind(scope)(okBtn);\n    }\n\n    onCancel(dialogRef: DialogRef): void {\n        if (!dialogRef.data.adapter?.ShowOkCancelButtons) {\n            dialogRef.dismiss();\n            return;\n        }\n        const { ulv, ulv2 } = this._getUlv(dialogRef);\n        this._btnClick(ulv, 'Cancel');\n    }\n\n    onClear(dialogRef: DialogRef): void {\n        dialogRef.data.ulv1.viewerControl.fireEvent('ClearAllSelected');\n        dialogRef.data.selectedItems.MoDataList = [];\n    }\n\n    onRemoveSelected(dialogRef: DialogRef, item: MetaobjectDataModel): void {\n        this._removeItem(dialogRef, item);\n    }\n\n    protected _removeItem(dialogRef: DialogRef<any>, mo: any): void {\n        const selectedItems = dialogRef.data.selectedItems;\n        if (!selectedItems) {\n            return;\n        }\n        selectedItems.MoDataList = selectedItems.MoDataList.filter((c) => c.Id !== mo.Id);\n        dialogRef.data.ulv1.viewerControl.fireEvent('DeselectRowInDialog', [mo]);\n        if (dialogRef.data.ulv2) {\n            const adapter = dialogRef.data.adapter;\n            adapter.fireEvent('AddRemoveButtonClick', adapter, 'Remove');\n        }\n        // const adapter = dialogRef.data.adapter;\n        // adapter.fireEvent('AddRemoveButtonClick', adapter, 'Remove');\n    }\n\n    protected _addItem(dialogRef: DialogRef<any>, mo: MetaobjectDataModel): void {\n        const selectedItems = dialogRef.data.selectedItems;\n        if (!selectedItems) {\n            return;\n        }\n        if (!selectedItems.MoDataList.find((c) => c.Id === mo.Id)) {\n            selectedItems.MoDataList = [...selectedItems.MoDataList, mo];\n            if (dialogRef.data.ulv2) {\n                const adapter = dialogRef.data.adapter;\n                adapter.fireEvent('AddRemoveButtonClick', adapter, 'Add');\n            }\n\n            // const adapter = dialogRef.data.adapter;\n            // adapter.fireEvent('AddRemoveButtonClick', adapter, 'Add');\n        }\n    }\n\n    _trackBySelectedFn(_index: number, item: MetaobjectDataModel): number | string {\n        return item.Id;\n    }\n}\n","<ng-template let-dialog let-dialogConfig=\"dialogConfig\" #container>\n    <fd-dialog [dialogConfig]=\"dialogConfig\" [dialogRef]=\"dialog\" #dialogTpl>\n        <fd-dialog-header>\n            <ng-template fdTemplate=\"header\">\n                <div fd-bar-left>\n                    <fd-bar-element>\n                        <h1 id=\"fd-dialog-header-3\" fd-title>{{ dialog.data.title }}</h1>\n                    </fd-bar-element>\n                </div>\n                <div fd-bar-right>\n                    <fd-button-bar\n                        *ngIf=\"!dialogConfig.fullscreen\"\n                        ariaLabel=\"fullscreen\"\n                        [glyph]=\"dialog.data.fullscreen ? 'exitfullscreen' : 'resize'\"\n                        fullscreenDialog\n                        [dialog]=\"dialog\"\n                        [dialogComponent]=\"dialogTpl\"\n                    ></fd-button-bar>\n                    <fd-button-bar ariaLabel=\"close\" glyph=\"decline\" (click)=\"onCancel(dialog)\"></fd-button-bar>\n                </div>\n            </ng-template>\n            <!-- <h3 fd-title>{{ dialog.data.title }}</h3>\n      <button fd-dialog-close-button></button> -->\n        </fd-dialog-header>\n\n        <fd-dialog-body>\n            <ng-container *ngIf=\"dialog.data.ulv1 as ulv1\">\n                <bsu-ui-ulv-main-ui\n                    class=\"ulv-form-multi-select\"\n                    [context]=\"ulv1\"\n                    [inDialog]=\"true\"\n                    [isMultiSelect]=\"dialog.data.ShowSecondPanel\"\n                    [fullscreen]=\"dialog.data.fullscreen\"\n                ></bsu-ui-ulv-main-ui>\n            </ng-container>\n            <div\n                *ngIf=\"dialog.data.ulv2 && dialog.data.ShowSecondPanel\"\n                class=\"ulv-selection-form-dialog__row ulv-selection-form-dialog__selection-row\"\n                [aria-label]=\"'SelectedItemsAndConditions' | bbbTranslate\"\n            >\n                <h5 fd-title class=\"selected-and-condition-title\">\n                    <ng-container>\n                        <ng-container>{{ 'SelectedItemsAndConditions' | bbbTranslate }} </ng-container>\n                        ({{ dialog.data.selectedItems?.MoDataList?.length || 0 }})\n                    </ng-container>\n                </h5>\n\n                <div class=\"ulv-selection-form-dialog__tokens-wrapper\">\n                    <div class=\"ulv-selection-form-dialog__tokens\">\n                        <fd-toolbar [shouldOverflow]=\"true\" *ngIf=\"dialog.data.selectedItems\">\n                            <!-- Selected items -->\n                            <fd-token\n                                fd-toolbar-item\n                                fdOverflowPriority=\"high\"\n                                class=\"fdp-value-help-dialog__selection-token\"\n                                (onCloseClick)=\"onRemoveSelected(dialog, item)\"\n                                *ngFor=\"\n                                    let item of dialog.data.selectedItems.MoDataList;\n                                    index as selectedIndex;\n                                    trackBy: _trackBySelectedFn\n                                \"\n                                >{{ item.$Caption }}\n                            </fd-token>\n                        </fd-toolbar>\n                    </div>\n                    <button\n                        class=\"ulv-selection-form-dialog__tokens-clear\"\n                        fd-button\n                        fdType=\"transparent\"\n                        glyph=\"decline\"\n                        [aria-label]=\"'Clear' | bbbTranslate\"\n                        (click)=\"onClear(dialog)\"\n                    ></button>\n                </div>\n            </div>\n        </fd-dialog-body>\n\n        <fd-dialog-footer *ngIf=\"dialog.data.ulv1 && !dialog.data.ulv1?.HideOkCancelButtons\">\n            <ng-template fdTemplate=\"footer\">\n                <div\n                    class=\"ulv-selection-form-dialog__actions-row\"\n                    *ngIf=\"dialog.data.adapter?.ShowOkCancelButtons !== false\"\n                >\n                    <button\n                        fd-button\n                        data-succes\n                        [label]=\"'OK' | bbbTranslate\"\n                        fdType=\"emphasized\"\n                        [compact]=\"true\"\n                        (click)=\"onOk(dialog)\"\n                    ></button>\n                    <button\n                        fd-button\n                        fdCompact\n                        data-dismiss-dialog\n                        fd-dialog-decisive-button\n                        [label]=\"'Cancel' | bbbTranslate\"\n                        [fdType]=\"'transparent'\"\n                        (click)=\"onCancel(dialog)\"\n                    ></button>\n                </div>\n            </ng-template>\n        </fd-dialog-footer>\n    </fd-dialog>\n</ng-template>\n"]}