@annalib/anna-core 31.2.0 → 31.3.0

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 (32) hide show
  1. package/esm2022/lib/anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component.mjs +3 -2
  2. package/esm2022/lib/anna-core-shared-lib/models/anna-non-editable-gt-models.mjs +1 -1
  3. package/esm2022/lib/anna-core-shared-lib/services/anna-filter.service.mjs +27 -8
  4. package/esm2022/lib/anna-core-shared-lib/services/anna-sort.service.mjs +2 -1
  5. package/esm2022/lib/anna-dropdown-lib/components/anna-single-select/anna-single-select.component.mjs +155 -0
  6. package/esm2022/lib/anna-dropdown-lib/components/anna-single-select/models/anna-single-select.model.mjs +12 -0
  7. package/esm2022/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-checkbox-filter/anna-column-checkbox-filter.component.mjs +13 -8
  8. package/esm2022/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-date-range-filter/anna-column-date-range-filter.component.mjs +7 -4
  9. package/esm2022/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-slider-filter/anna-column-slider-filter.component.mjs +7 -4
  10. package/esm2022/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-time-filter/anna-column-time-filter.component.mjs +9 -6
  11. package/esm2022/lib/anna-generic-table-lib/components/anna-non-editable-generic-table/anna-non-editable-generic-table.component.mjs +44 -78
  12. package/esm2022/lib/anna-generic-table-lib/components/anna-sort/anna-sort.component.mjs +3 -2
  13. package/esm2022/lib/anna-generic-table-lib/services/gt-table-related-common-functions.service.mjs +90 -0
  14. package/esm2022/public-api.mjs +2 -1
  15. package/fesm2022/annalib-anna-core.mjs +343 -111
  16. package/fesm2022/annalib-anna-core.mjs.map +1 -1
  17. package/lib/anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component.d.ts +1 -1
  18. package/lib/anna-core-shared-lib/models/anna-non-editable-gt-models.d.ts +8 -2
  19. package/lib/anna-core-shared-lib/services/anna-date-time-format.service.d.ts +2 -2
  20. package/lib/anna-core-shared-lib/services/anna-filter.service.d.ts +2 -0
  21. package/lib/anna-dropdown-lib/components/anna-single-select/anna-single-select.component.d.ts +44 -0
  22. package/lib/anna-dropdown-lib/components/anna-single-select/models/anna-single-select.model.d.ts +10 -0
  23. package/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-checkbox-filter/anna-column-checkbox-filter.component.d.ts +1 -1
  24. package/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-date-range-filter/anna-column-date-range-filter.component.d.ts +1 -1
  25. package/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-slider-filter/anna-column-slider-filter.component.d.ts +1 -1
  26. package/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-time-filter/anna-column-time-filter.component.d.ts +2 -2
  27. package/lib/anna-generic-table-lib/components/anna-non-editable-generic-table/anna-non-editable-generic-table.component.d.ts +8 -4
  28. package/lib/anna-generic-table-lib/components/anna-sort/anna-sort.component.d.ts +1 -1
  29. package/lib/anna-generic-table-lib/services/gt-table-related-common-functions.service.d.ts +10 -0
  30. package/package.json +10 -10
  31. package/public-api.d.ts +1 -0
  32. package/src/lib/anna-common-scss/_edit-filter-popup.scss +5 -1
@@ -20,6 +20,7 @@ export class AnnaSortService {
20
20
  "flightEndDate",
21
21
  "date",
22
22
  "GeneratedOn",
23
+ "AirDate"
23
24
  ]);
24
25
  }
25
26
  sortDataForComponentOtherThanLurAndCsrPage(isAsc, data, key) {
@@ -173,4 +174,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
173
174
  providedIn: "root",
174
175
  }]
175
176
  }], ctorParameters: function () { return [{ type: i1.AnnaDateTimeFormatService }]; } });
176
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-sort.service.js","sourceRoot":"","sources":["../../../../../../projects/anna-core/src/lib/anna-core-shared-lib/services/anna-sort.service.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular import statements\r\nimport { Injectable } from \"@angular/core\";\r\nimport { cloneDeep } from \"lodash-es\";\r\nimport { Subject } from \"rxjs\";\r\n\r\nimport { SortType } from \"../models/anna-sort.model\";\r\nimport { AnnaDateTimeFormatService } from \"./anna-date-time-format.service\";\r\n\r\n// Third party import statements\r\n\r\n// User defined import statements\r\n\r\n@Injectable({\r\n    providedIn: \"root\",\r\n})\r\nexport class AnnaSortService {\r\n    columnSortState: Map<string, SortType>;\r\n    noSortingAppliedData: any[];\r\n    updateSortTypeSubject: Subject<string> = new Subject();\r\n\r\n    dateSet = new Set([\r\n        \"endDate\",\r\n        \"startDate\",\r\n        \"end_date\",\r\n        \"start_date\",\r\n        \"flightStartDate\",\r\n        \"flightEndDate\",\r\n        \"date\",\r\n        \"GeneratedOn\",\r\n    ]);\r\n\r\n    constructor(private annaDateTimeFormatService: AnnaDateTimeFormatService) {}\r\n\r\n    sortDataForComponentOtherThanLurAndCsrPage(isAsc: boolean, data: any[], key: string) {\r\n        let param1: string | number;\r\n        let param2: string | number;\r\n\r\n        let dataToBeSorted = data;\r\n        if (this.dateSet.has(key)) {\r\n            dataToBeSorted.sort((a, b) => this.annaDateTimeFormatService.compareDate(a[key], b[key], isAsc));\r\n        } else if (key === \"AirDateAndTime\" || key === \"Date\") {\r\n            dataToBeSorted.sort((a, b) => {\r\n                if (a[key] === \"-\") {\r\n                    return 1;\r\n                }\r\n\r\n                if (b[key] === \"-\") {\r\n                    return -1;\r\n                }\r\n                const first = this.annaDateTimeFormatService.formatDateAndHHMMATimeToStandardFormat(a[key]);\r\n                const second = this.annaDateTimeFormatService.formatDateAndHHMMATimeToStandardFormat(b[key]);\r\n                const compareDate = this.annaDateTimeFormatService.compareDate(first, second, isAsc);\r\n                return compareDate;\r\n            });\r\n        } else if (key === \"startEndTime\" || key === \"TimeBand\") {\r\n            dataToBeSorted.sort((a, b) => {\r\n                if (isAsc) {\r\n                    param1 = a[key][1];\r\n                    param2 = b[key][1];\r\n                } else {\r\n                    param1 = a[key][2];\r\n                    param2 = b[key][2];\r\n                }\r\n                const val = isAsc\r\n                    ? this.annaDateTimeFormatService.sortByTimeAscending(param1, param2)\r\n                    : this.annaDateTimeFormatService.sortByTimeDescending(param1, param2);\r\n                return val;\r\n            });\r\n        } else {\r\n            const dataWithoutEmptyOrHyphenValues = dataToBeSorted.filter((n) => n[key] !== \"-\");\r\n            const rowsWithHyphenOrZeroValues = dataToBeSorted.filter((n) => n[key] === \"-\");\r\n\r\n            dataWithoutEmptyOrHyphenValues.sort((a, b) => {\r\n                param1 = a[key];\r\n                param2 = b[key];\r\n\r\n                if (param1 !== param2) {\r\n                    return this.annaDateTimeFormatService.compare(param1, param2, isAsc);\r\n                }\r\n\r\n                return 0;\r\n            });\r\n\r\n            dataToBeSorted = isAsc\r\n                ? [...rowsWithHyphenOrZeroValues, ...dataWithoutEmptyOrHyphenValues]\r\n                : [...dataWithoutEmptyOrHyphenValues, ...rowsWithHyphenOrZeroValues];\r\n        }\r\n\r\n        return dataToBeSorted;\r\n    }\r\n\r\n    sortEnterEditLurAndCsrPage(isAsc: boolean, data: any[], key: any) {\r\n        let param1: string | number;\r\n        let param2: string | number;\r\n\r\n        if (key.includes(\"_\")) {\r\n            const keys = key.split(\"_\");\r\n            const weekNumber = keys[0];\r\n            let sortKey = keys[1];\r\n\r\n            if (keys.length > 2) {\r\n                sortKey = keys[2] === \"true\" ? \"BookedAurIncludingNoChargeSpots\" : \"BookedAurExcludingNoChargeSpots\";\r\n            }\r\n\r\n            data.sort((a, b) => {\r\n                const aInventoryCodeWeekWiseKey = Object.keys(a.WeekWiseInventoryCodeData).filter(\r\n                    (invKey) => invKey.split(\"_\")[1] === weekNumber,\r\n                );\r\n                const bInventoryCodeWeekWiseKey = Object.keys(b.WeekWiseInventoryCodeData).filter(\r\n                    (invKey) => invKey.split(\"_\")[1] === weekNumber,\r\n                );\r\n\r\n                param1 = null;\r\n                param2 = null;\r\n                if (aInventoryCodeWeekWiseKey.length > 0) {\r\n                    param1 = a.WeekWiseInventoryCodeData[aInventoryCodeWeekWiseKey[0]][sortKey][1];\r\n                }\r\n\r\n                if (bInventoryCodeWeekWiseKey.length > 0) {\r\n                    param2 = b.WeekWiseInventoryCodeData[bInventoryCodeWeekWiseKey[0]][sortKey][1];\r\n                }\r\n\r\n                if (param1 !== param2) {\r\n                    return this.annaDateTimeFormatService.compare(param1, param2, isAsc);\r\n                }\r\n\r\n                return 0;\r\n            });\r\n        } else if (key === \"TimeBand\") {\r\n            data.sort((a, b) => {\r\n                if (isAsc) {\r\n                    param1 = a[key][1];\r\n                    param2 = b[key][1];\r\n                } else {\r\n                    param1 = a[key][2];\r\n                    param2 = b[key][2];\r\n                }\r\n                const val = isAsc\r\n                    ? this.annaDateTimeFormatService.sortByTimeAscending(param1, param2)\r\n                    : this.annaDateTimeFormatService.sortByTimeDescending(param1, param2);\r\n                return val;\r\n            });\r\n        } else {\r\n            data.sort((a, b) => {\r\n                param1 = a[key];\r\n                param2 = b[key];\r\n\r\n                if (param1 !== param2) {\r\n                    return this.annaDateTimeFormatService.compare(param1, param2, isAsc);\r\n                }\r\n\r\n                return 0;\r\n            });\r\n        }\r\n\r\n        return data;\r\n    }\r\n\r\n    checkIfSortingIsApplied(tableData: any[], isLurAndCsrComponent: boolean) {\r\n        let sortedTableData = tableData;\r\n        this.columnSortState.forEach((value, key) => {\r\n            if (value === \"ASC\") {\r\n                sortedTableData = cloneDeep(\r\n                    isLurAndCsrComponent\r\n                        ? this.sortEnterEditLurAndCsrPage(true, tableData, key)\r\n                        : this.sortDataForComponentOtherThanLurAndCsrPage(true, tableData, key),\r\n                );\r\n            } else if (value === \"DESC\") {\r\n                sortedTableData = cloneDeep(\r\n                    isLurAndCsrComponent\r\n                        ? this.sortEnterEditLurAndCsrPage(false, tableData, key)\r\n                        : this.sortDataForComponentOtherThanLurAndCsrPage(false, tableData, key),\r\n                );\r\n            }\r\n        });\r\n\r\n        return sortedTableData;\r\n    }\r\n\r\n    applySorting(key: string, tempSortOrder: SortType, tableData: any[], isLurAndCsrComponent: boolean) {\r\n        let sortedTableData = tableData;\r\n        if (tempSortOrder === \"ASC\") {\r\n            sortedTableData = cloneDeep(\r\n                isLurAndCsrComponent\r\n                    ? this.sortEnterEditLurAndCsrPage(true, tableData, key)\r\n                    : this.sortDataForComponentOtherThanLurAndCsrPage(true, tableData, key),\r\n            );\r\n        } else if (tempSortOrder === \"DESC\") {\r\n            sortedTableData = cloneDeep(\r\n                isLurAndCsrComponent\r\n                    ? this.sortEnterEditLurAndCsrPage(false, tableData, key)\r\n                    : this.sortDataForComponentOtherThanLurAndCsrPage(false, tableData, key),\r\n            );\r\n        } else if (tempSortOrder === \"DEFAULT\") {\r\n            sortedTableData = cloneDeep(this.noSortingAppliedData);\r\n        }\r\n\r\n        return sortedTableData;\r\n    }\r\n}\r\n"]}
177
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-sort.service.js","sourceRoot":"","sources":["../../../../../../projects/anna-core/src/lib/anna-core-shared-lib/services/anna-sort.service.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular import statements\r\nimport { Injectable } from \"@angular/core\";\r\nimport { cloneDeep } from \"lodash-es\";\r\nimport { Subject } from \"rxjs\";\r\n\r\nimport { SortType } from \"../models/anna-sort.model\";\r\nimport { AnnaDateTimeFormatService } from \"./anna-date-time-format.service\";\r\n\r\n// Third party import statements\r\n\r\n// User defined import statements\r\n\r\n@Injectable({\r\n    providedIn: \"root\",\r\n})\r\nexport class AnnaSortService {\r\n    columnSortState: Map<string, SortType>;\r\n    noSortingAppliedData: any[];\r\n    updateSortTypeSubject: Subject<string> = new Subject();\r\n\r\n    dateSet = new Set([\r\n        \"endDate\",\r\n        \"startDate\",\r\n        \"end_date\",\r\n        \"start_date\",\r\n        \"flightStartDate\",\r\n        \"flightEndDate\",\r\n        \"date\",\r\n        \"GeneratedOn\",\r\n        \"AirDate\"\r\n    ]);\r\n\r\n    constructor(private annaDateTimeFormatService: AnnaDateTimeFormatService) {}\r\n\r\n    sortDataForComponentOtherThanLurAndCsrPage(isAsc: boolean, data: any[], key: string) {\r\n        let param1: string | number;\r\n        let param2: string | number;\r\n\r\n        let dataToBeSorted = data;\r\n        if (this.dateSet.has(key)) {\r\n            dataToBeSorted.sort((a, b) => this.annaDateTimeFormatService.compareDate(a[key], b[key], isAsc));\r\n        } else if (key === \"AirDateAndTime\" || key === \"Date\") {\r\n            dataToBeSorted.sort((a, b) => {\r\n                if (a[key] === \"-\") {\r\n                    return 1;\r\n                }\r\n\r\n                if (b[key] === \"-\") {\r\n                    return -1;\r\n                }\r\n                const first = this.annaDateTimeFormatService.formatDateAndHHMMATimeToStandardFormat(a[key]);\r\n                const second = this.annaDateTimeFormatService.formatDateAndHHMMATimeToStandardFormat(b[key]);\r\n                const compareDate = this.annaDateTimeFormatService.compareDate(first, second, isAsc);\r\n                return compareDate;\r\n            });\r\n        } else if (key === \"startEndTime\" || key === \"TimeBand\") {\r\n            dataToBeSorted.sort((a, b) => {\r\n                if (isAsc) {\r\n                    param1 = a[key][1];\r\n                    param2 = b[key][1];\r\n                } else {\r\n                    param1 = a[key][2];\r\n                    param2 = b[key][2];\r\n                }\r\n                const val = isAsc\r\n                    ? this.annaDateTimeFormatService.sortByTimeAscending(param1, param2)\r\n                    : this.annaDateTimeFormatService.sortByTimeDescending(param1, param2);\r\n                return val;\r\n            });\r\n        } else {\r\n            const dataWithoutEmptyOrHyphenValues = dataToBeSorted.filter((n) => n[key] !== \"-\");\r\n            const rowsWithHyphenOrZeroValues = dataToBeSorted.filter((n) => n[key] === \"-\");\r\n\r\n            dataWithoutEmptyOrHyphenValues.sort((a, b) => {\r\n                param1 = a[key];\r\n                param2 = b[key];\r\n\r\n                if (param1 !== param2) {\r\n                    return this.annaDateTimeFormatService.compare(param1, param2, isAsc);\r\n                }\r\n\r\n                return 0;\r\n            });\r\n\r\n            dataToBeSorted = isAsc\r\n                ? [...rowsWithHyphenOrZeroValues, ...dataWithoutEmptyOrHyphenValues]\r\n                : [...dataWithoutEmptyOrHyphenValues, ...rowsWithHyphenOrZeroValues];\r\n        }\r\n\r\n        return dataToBeSorted;\r\n    }\r\n\r\n    sortEnterEditLurAndCsrPage(isAsc: boolean, data: any[], key: any) {\r\n        let param1: string | number;\r\n        let param2: string | number;\r\n\r\n        if (key.includes(\"_\")) {\r\n            const keys = key.split(\"_\");\r\n            const weekNumber = keys[0];\r\n            let sortKey = keys[1];\r\n\r\n            if (keys.length > 2) {\r\n                sortKey = keys[2] === \"true\" ? \"BookedAurIncludingNoChargeSpots\" : \"BookedAurExcludingNoChargeSpots\";\r\n            }\r\n\r\n            data.sort((a, b) => {\r\n                const aInventoryCodeWeekWiseKey = Object.keys(a.WeekWiseInventoryCodeData).filter(\r\n                    (invKey) => invKey.split(\"_\")[1] === weekNumber,\r\n                );\r\n                const bInventoryCodeWeekWiseKey = Object.keys(b.WeekWiseInventoryCodeData).filter(\r\n                    (invKey) => invKey.split(\"_\")[1] === weekNumber,\r\n                );\r\n\r\n                param1 = null;\r\n                param2 = null;\r\n                if (aInventoryCodeWeekWiseKey.length > 0) {\r\n                    param1 = a.WeekWiseInventoryCodeData[aInventoryCodeWeekWiseKey[0]][sortKey][1];\r\n                }\r\n\r\n                if (bInventoryCodeWeekWiseKey.length > 0) {\r\n                    param2 = b.WeekWiseInventoryCodeData[bInventoryCodeWeekWiseKey[0]][sortKey][1];\r\n                }\r\n\r\n                if (param1 !== param2) {\r\n                    return this.annaDateTimeFormatService.compare(param1, param2, isAsc);\r\n                }\r\n\r\n                return 0;\r\n            });\r\n        } else if (key === \"TimeBand\") {\r\n            data.sort((a, b) => {\r\n                if (isAsc) {\r\n                    param1 = a[key][1];\r\n                    param2 = b[key][1];\r\n                } else {\r\n                    param1 = a[key][2];\r\n                    param2 = b[key][2];\r\n                }\r\n                const val = isAsc\r\n                    ? this.annaDateTimeFormatService.sortByTimeAscending(param1, param2)\r\n                    : this.annaDateTimeFormatService.sortByTimeDescending(param1, param2);\r\n                return val;\r\n            });\r\n        } else {\r\n            data.sort((a, b) => {\r\n                param1 = a[key];\r\n                param2 = b[key];\r\n\r\n                if (param1 !== param2) {\r\n                    return this.annaDateTimeFormatService.compare(param1, param2, isAsc);\r\n                }\r\n\r\n                return 0;\r\n            });\r\n        }\r\n\r\n        return data;\r\n    }\r\n\r\n    checkIfSortingIsApplied(tableData: any[], isLurAndCsrComponent: boolean) {\r\n        let sortedTableData = tableData;\r\n        this.columnSortState.forEach((value, key) => {\r\n            if (value === \"ASC\") {\r\n                sortedTableData = cloneDeep(\r\n                    isLurAndCsrComponent\r\n                        ? this.sortEnterEditLurAndCsrPage(true, tableData, key)\r\n                        : this.sortDataForComponentOtherThanLurAndCsrPage(true, tableData, key),\r\n                );\r\n            } else if (value === \"DESC\") {\r\n                sortedTableData = cloneDeep(\r\n                    isLurAndCsrComponent\r\n                        ? this.sortEnterEditLurAndCsrPage(false, tableData, key)\r\n                        : this.sortDataForComponentOtherThanLurAndCsrPage(false, tableData, key),\r\n                );\r\n            }\r\n        });\r\n\r\n        return sortedTableData;\r\n    }\r\n\r\n    applySorting(key: string, tempSortOrder: SortType, tableData: any[], isLurAndCsrComponent: boolean) {\r\n        let sortedTableData = tableData;\r\n        if (tempSortOrder === \"ASC\") {\r\n            sortedTableData = cloneDeep(\r\n                isLurAndCsrComponent\r\n                    ? this.sortEnterEditLurAndCsrPage(true, tableData, key)\r\n                    : this.sortDataForComponentOtherThanLurAndCsrPage(true, tableData, key),\r\n            );\r\n        } else if (tempSortOrder === \"DESC\") {\r\n            sortedTableData = cloneDeep(\r\n                isLurAndCsrComponent\r\n                    ? this.sortEnterEditLurAndCsrPage(false, tableData, key)\r\n                    : this.sortDataForComponentOtherThanLurAndCsrPage(false, tableData, key),\r\n            );\r\n        } else if (tempSortOrder === \"DEFAULT\") {\r\n            sortedTableData = cloneDeep(this.noSortingAppliedData);\r\n        }\r\n\r\n        return sortedTableData;\r\n    }\r\n}\r\n"]}
@@ -0,0 +1,155 @@
1
+ /* eslint-disable import/no-extraneous-dependencies */
2
+ import { CdkFixedSizeVirtualScroll, CdkVirtualForOf, CdkVirtualScrollViewport } from "@angular/cdk/scrolling";
3
+ import { NgClass, NgFor, NgIf, NgTemplateOutlet } from "@angular/common";
4
+ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from "@angular/core";
5
+ import { FormsModule } from "@angular/forms";
6
+ import { MatMenuModule } from "@angular/material/menu";
7
+ import { isEqual } from "lodash-es";
8
+ import { AnnaFilterSearchedTextPipe } from "../../../anna-core-shared-lib/pipes/annaFilterSearchedText.pipe";
9
+ import { AnnaTypeofDataPipe } from "../../../anna-core-shared-lib/pipes/annaTypeOfData.pipe";
10
+ import { AnnaGlobalConfigService } from "../../../anna-core-shared-lib/services/anna-global-config.service";
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "../../../anna-core-shared-lib/services/anna-global-config.service";
13
+ import * as i2 from "../../../anna-core-shared-lib/pipes/annaFilterSearchedText.pipe";
14
+ import * as i3 from "@angular/material/menu";
15
+ import * as i4 from "@angular/forms";
16
+ export class AnnaSingleSelectComponent {
17
+ constructor(annaGlobalConfig, searchFilterPipe) {
18
+ this.annaGlobalConfig = annaGlobalConfig;
19
+ this.searchFilterPipe = searchFilterPipe;
20
+ this.loading = false;
21
+ this.showAdditionalDataInSelectedText = false;
22
+ this.keyToUseForDisplay = "text";
23
+ this.keyToUseForCheckingSelectedItem = "id";
24
+ this.hideDropdownArrow = false;
25
+ this.borderbottomObject = {};
26
+ this.defaultDropdownHeight = null;
27
+ this.itemsToHideInDropdownIds = [];
28
+ this.showClearSelection = false;
29
+ this.valueChanged = new EventEmitter();
30
+ this.dropdownClosedEvent = new EventEmitter();
31
+ this.dropdownOpenedEvent = new EventEmitter();
32
+ this.clearSelectionClickedEvent = new EventEmitter();
33
+ this.yPosition = "above";
34
+ }
35
+ ngOnChanges(changes) {
36
+ if (changes.config?.currentValue) {
37
+ this.config = { ...this.annaGlobalConfig.defaultSingleSelectConfig, ...this.config };
38
+ }
39
+ if (changes.items?.currentValue) {
40
+ if (this.defaultDropdownHeight)
41
+ this.heightOfCheckboxTooltipFilter = this.defaultDropdownHeight;
42
+ else
43
+ this.heightOfCheckboxTooltipFilter = this.items.length > 7 ? 200 : 25.68 * this.items.length;
44
+ }
45
+ if (changes.itemsToHideInDropdownIds?.currentValue) {
46
+ this.items = this.items.filter((item) => !this.itemsToHideInDropdownIds.includes(item.id));
47
+ }
48
+ }
49
+ ngOnInit() {
50
+ this.config = { ...this.annaGlobalConfig.defaultSingleSelectConfig, ...this.config };
51
+ this.setPostion();
52
+ }
53
+ trackByFn(index) {
54
+ return index;
55
+ }
56
+ itemSelected(item, event) {
57
+ if (item?.isDisabled) {
58
+ event.stopPropagation();
59
+ return;
60
+ }
61
+ if (!isEqual(this.selectedItem, item)) {
62
+ this.valueChanged.emit(item);
63
+ }
64
+ this.selectedItem = item;
65
+ }
66
+ dropdownOpened() {
67
+ this.searchFor = "";
68
+ this.updateHeight();
69
+ this.width = this.buttonElement.nativeElement.offsetWidth;
70
+ this.dropdownOpenedEvent.emit();
71
+ }
72
+ dropdownClosed() {
73
+ this.dropdownClosedEvent.emit();
74
+ }
75
+ clearSelectionClicked() {
76
+ this.selectedItem = null;
77
+ this.clearSelectionClickedEvent.emit();
78
+ }
79
+ setPostion() {
80
+ if (this.config && this.config.position === "TOP") {
81
+ this.yPosition = "above";
82
+ }
83
+ else if (this.config && this.config.position === "BOTTOM") {
84
+ this.yPosition = "below";
85
+ }
86
+ }
87
+ updateHeight() {
88
+ const items = this.searchFilterPipe.transform(this.items, this.searchFor, this.keyToUseForDisplay);
89
+ if (items.length > 7) {
90
+ this.heightOfCheckboxTooltipFilter = 200;
91
+ }
92
+ else if (items.length > 0) {
93
+ this.heightOfCheckboxTooltipFilter = 25.68 * items.length;
94
+ }
95
+ else {
96
+ this.heightOfCheckboxTooltipFilter = 25.68;
97
+ }
98
+ }
99
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AnnaSingleSelectComponent, deps: [{ token: i1.AnnaGlobalConfigService }, { token: i2.AnnaFilterSearchedTextPipe }], target: i0.ɵɵFactoryTarget.Component }); }
100
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AnnaSingleSelectComponent, isStandalone: true, selector: "anna-core-single-select", inputs: { config: "config", loading: "loading", showAdditionalDataInSelectedText: "showAdditionalDataInSelectedText", disabled: "disabled", items: "items", selectedItem: "selectedItem", keyToUseForDisplay: "keyToUseForDisplay", keyToUseForCheckingSelectedItem: "keyToUseForCheckingSelectedItem", hideDropdownArrow: "hideDropdownArrow", borderbottomObject: "borderbottomObject", defaultDropdownHeight: "defaultDropdownHeight", itemsToHideInDropdownIds: "itemsToHideInDropdownIds", showClearSelection: "showClearSelection" }, outputs: { valueChanged: "valueChanged", dropdownClosedEvent: "dropdownClosedEvent", dropdownOpenedEvent: "dropdownOpenedEvent", clearSelectionClickedEvent: "clearSelectionClickedEvent" }, viewQueries: [{ propertyName: "buttonElement", first: true, predicate: ["dropdown"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<button\r\n id=\"dropdown-trigger\"\r\n #dropdown\r\n #t=\"matMenuTrigger\"\r\n (menuClosed)=\"dropdownClosed()\"\r\n (menuOpened)=\"dropdownOpened()\"\r\n [matMenuTriggerFor]=\"contextMenu\"\r\n [disabled]=\"disabled || loading\"\r\n>\r\n <span\r\n class=\"placeholder\"\r\n *ngIf=\"!selectedItem && config\"\r\n >{{ config.placeholder }}</span\r\n >\r\n <span\r\n class=\"selected-item\"\r\n [class]=\"selectedItem.class\"\r\n annaCoreShowEllipsisTextOnHover\r\n *ngIf=\"selectedItem\"\r\n >\r\n <ng-container *ngIf=\"(selectedItem | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n {{ selectedItem[keyToUseForDisplay] }}\r\n <ng-container *ngIf=\"showAdditionalDataInSelectedText && selectedItem && selectedItem?.additionalData\">\r\n <span [class]=\"selectedItem?.additionalClass\">{{ selectedItem?.additionalData }} </span>\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #stringTypeTemplate>\r\n {{ selectedItem }}\r\n </ng-template>\r\n </span>\r\n <div\r\n *ngIf=\"loading\"\r\n [ngClass]=\"{ 'spinner-for-button-directive': loading }\"\r\n ></div>\r\n\r\n <ng-container *ngIf=\"!loading && !hideDropdownArrow\">\r\n <i\r\n *ngIf=\"!t.menuOpen\"\r\n class=\"mdi mdi-menu-down icon\"\r\n ></i>\r\n <i\r\n *ngIf=\"t.menuOpen\"\r\n class=\"mdi mdi-menu-up icon\"\r\n ></i>\r\n </ng-container>\r\n</button>\r\n<ng-content select=\".role-tooltip-icon\"></ng-content>\r\n<mat-menu\r\n backdropClass=\"single-select-dropdown\"\r\n [yPosition]=\"yPosition\"\r\n #contextMenu=\"matMenu\"\r\n>\r\n <ng-template matMenuContent>\r\n <div\r\n class=\"{{ config.classes }}\"\r\n [style.width.px]=\"width\"\r\n >\r\n <div\r\n class=\"gap\"\r\n *ngIf=\"config.showSearchBar\"\r\n ></div>\r\n <div\r\n *ngIf=\"showClearSelection\"\r\n class=\"clear-selection\"\r\n >\r\n <a\r\n (click)=\"clearSelectionClicked()\"\r\n [ngClass]=\"{ disabled: !selectedItem }\"\r\n >Clear selection</a\r\n >\r\n </div>\r\n <section\r\n *ngIf=\"config.showSearchBar\"\r\n class=\"search-bar\"\r\n >\r\n <i class=\"mi mdi-search search-icon\"></i>\r\n <input\r\n type=\"text\"\r\n [(ngModel)]=\"searchFor\"\r\n placeholder=\"Search\"\r\n (ngModelChange)=\"updateHeight()\"\r\n (click)=\"$event.stopPropagation()\"\r\n />\r\n </section>\r\n <cdk-virtual-scroll-viewport\r\n class=\"dropdown-data-container\"\r\n itemSize=\"18\"\r\n [style.height.px]=\"heightOfCheckboxTooltipFilter\"\r\n >\r\n <ul\r\n class=\"single-select-ul\"\r\n [style.width.px]=\"width\"\r\n >\r\n <ng-container *ngIf=\"items && (items[0] | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n *cdkVirtualFor=\"\r\n let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n let last = last;\r\n trackBy: trackByFn\r\n \"\r\n [ngClass]=\"{\r\n active:\r\n selectedItem &&\r\n selectedItem[keyToUseForCheckingSelectedItem] ===\r\n item[keyToUseForCheckingSelectedItem],\r\n 'show-bottom-border': !last && borderbottomObject[item.id],\r\n disabled: item.isDisabled\r\n }\"\r\n (click)=\"itemSelected(item, $event)\"\r\n >\r\n <span [class]=\"item.class\"> {{ item[keyToUseForDisplay] }} </span>\r\n <ng-container *ngIf=\"item && item.additionalData\">\r\n <span\r\n class=\"ml-0\"\r\n [class]=\"item.additionalClass\"\r\n >\r\n {{ item?.additionalData }}\r\n </span>\r\n </ng-container>\r\n </li>\r\n\r\n <ng-container\r\n [ngTemplateOutlet]=\"noDataCase\"\r\n [ngTemplateOutletContext]=\"{ items: items }\"\r\n ></ng-container>\r\n </ng-container>\r\n\r\n <ng-template #stringTypeTemplate>\r\n <ng-container\r\n *ngFor=\"\r\n let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n [ngClass]=\"{ active: selectedItem && selectedItem === item }\"\r\n (click)=\"itemSelected(item, $event)\"\r\n >\r\n <span> {{ item }} </span>\r\n </li>\r\n </ng-container>\r\n <ng-container\r\n [ngTemplateOutlet]=\"noDataCase\"\r\n [ngTemplateOutletContext]=\"{ items: items }\"\r\n ></ng-container>\r\n </ng-template>\r\n </ul>\r\n </cdk-virtual-scroll-viewport>\r\n </div>\r\n </ng-template>\r\n</mat-menu>\r\n\r\n<ng-template\r\n #noDataCase\r\n let-items=\"items\"\r\n>\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n *ngIf=\"(items | AnnafilterSearchedText: searchFor : keyToUseForDisplay)?.length === 0\"\r\n >\r\n <span> No data found </span>\r\n </li>\r\n</ng-template>\r\n", styles: ["#dropdown-trigger{height:1.5rem;background:#fff;border-radius:2px;border:1px solid #b7b7b7;width:100%;text-align:left;display:flex;align-items:center}#dropdown-trigger:disabled{background-color:#bdbdbd;opacity:.5}#dropdown-trigger:disabled .placeholder,#dropdown-trigger:disabled .icon{color:#000}.placeholder{color:#bdbdbd;width:100%;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;opacity:1!important}.icon{font-size:1.125rem;float:right;margin-left:auto}.search-bar{margin:0 7px 8px;border:1px solid #b7b7b7;height:24px;border-radius:2px}.search-bar input{outline:none;border:none;position:relative;bottom:4px;width:calc(100% - 29px);font-size:var(--dropdown-text-fs)}.search-bar .search-icon{font-size:var(--multi-select-dropdown-checkbox-fs);color:#9b9b9b;margin:5px}.search-bar .close-icon{cursor:pointer}ul{overflow-y:auto;padding-left:0;padding-bottom:0;margin-bottom:0;max-height:calc(50vh - 80px)!important}li{list-style-type:none;cursor:pointer;padding-inline:10px;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:2.14;letter-spacing:normal;color:#4a4a4a;width:100%}ul::-webkit-scrollbar{width:4px;height:4px}ul::-webkit-scrollbar-track{border:1px solid rgba(0,0,0,.1)}ul::-webkit-scrollbar-thumb{border-radius:4px;background-color:#0006!important;border:1px solid rgba(0,0,0,.2)}li:hover{background:#ebebeb}li.active{color:#fff;background:#268bff}span.selected-item{background:transparent;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#4a4a4a;width:calc(100% - 22px);display:inline-block;vertical-align:middle}.ellipsify,li,span.selected-item{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}::ng-deep .cdk-overlay-container{z-index:1051}span.red-color-text{color:#f44336!important}span.additional-data-color-text{color:#b7b6b6!important}span.italic{font-style:italic}.spinner-for-button-directive{left:0;margin-left:auto}.spinner-for-button-directive span.additional-data-color-text{color:#000}::ng-deep .mat-menu-panel{min-height:auto!important}.small-text li{font-size:12px!important}.ml-0{margin-left:0}#dropdown-trigger:disabled{cursor:default!important}#dropdown-trigger:disabled span{color:#4a4a4a!important;cursor:default!important}::ng-deep .mat-mdc-menu-panel.mat-elevation-z8{box-shadow:var(--dropdown-box-shadow)}::ng-deep .mat-mdc-menu-panel .mat-mdc-menu-content{background-color:#fff;padding:0!important}::ng-deep .mat-mdc-menu-panel .mat-mdc-menu-content.mdc-list{background-color:#fff}::ng-deep .mat-mdc-menu-panel.mat-mdc-menu-panel{max-width:none!important}::ng-deep .mat-mdc-menu-panel .clear-selection{margin:0 7px!important}::ng-deep .mat-mdc-menu-panel .clear-selection a{color:#268bff!important;text-decoration:underline!important;font-size:12px!important}::ng-deep .mat-mdc-menu-panel .clear-selection a.disabled{color:#4a4a4a!important;pointer-events:none;cursor:not-allowed;opacity:.5}li{background-color:#fff}cdk-virtual-scroll-viewport.dropdown-data-container{max-height:12.5rem;width:100%;overflow-y:auto;overflow-x:hidden}cdk-virtual-scroll-viewport.dropdown-data-container li.disabled{opacity:.5;cursor:default}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar{width:.1875rem}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar-thumb{color:#d3d3d3;background:#d3d3d3}::ng-deep ul.single-select-ul{max-height:none!important}li.show-bottom-border{border-bottom:1px solid #e6e6e6}::ng-deep .no-wrap-text ul li{line-height:1.41!important;padding-top:4px;padding-bottom:4px}::ng-deep .no-wrap-text ul li span{white-space:normal!important}.gap{height:9px}\n"], dependencies: [{ kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "directive", type: i3.MatMenuContent, selector: "ng-template[matMenuContent]" }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "directive", type: CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: AnnaFilterSearchedTextPipe, name: "AnnafilterSearchedText" }, { kind: "pipe", type: AnnaTypeofDataPipe, name: "AnnatypeofData" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
101
+ }
102
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AnnaSingleSelectComponent, decorators: [{
103
+ type: Component,
104
+ args: [{ selector: "anna-core-single-select", changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
105
+ MatMenuModule,
106
+ NgIf,
107
+ NgClass,
108
+ FormsModule,
109
+ CdkVirtualScrollViewport,
110
+ CdkFixedSizeVirtualScroll,
111
+ CdkVirtualForOf,
112
+ NgTemplateOutlet,
113
+ NgFor,
114
+ AnnaFilterSearchedTextPipe,
115
+ AnnaTypeofDataPipe,
116
+ ], template: "<button\r\n id=\"dropdown-trigger\"\r\n #dropdown\r\n #t=\"matMenuTrigger\"\r\n (menuClosed)=\"dropdownClosed()\"\r\n (menuOpened)=\"dropdownOpened()\"\r\n [matMenuTriggerFor]=\"contextMenu\"\r\n [disabled]=\"disabled || loading\"\r\n>\r\n <span\r\n class=\"placeholder\"\r\n *ngIf=\"!selectedItem && config\"\r\n >{{ config.placeholder }}</span\r\n >\r\n <span\r\n class=\"selected-item\"\r\n [class]=\"selectedItem.class\"\r\n annaCoreShowEllipsisTextOnHover\r\n *ngIf=\"selectedItem\"\r\n >\r\n <ng-container *ngIf=\"(selectedItem | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n {{ selectedItem[keyToUseForDisplay] }}\r\n <ng-container *ngIf=\"showAdditionalDataInSelectedText && selectedItem && selectedItem?.additionalData\">\r\n <span [class]=\"selectedItem?.additionalClass\">{{ selectedItem?.additionalData }} </span>\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #stringTypeTemplate>\r\n {{ selectedItem }}\r\n </ng-template>\r\n </span>\r\n <div\r\n *ngIf=\"loading\"\r\n [ngClass]=\"{ 'spinner-for-button-directive': loading }\"\r\n ></div>\r\n\r\n <ng-container *ngIf=\"!loading && !hideDropdownArrow\">\r\n <i\r\n *ngIf=\"!t.menuOpen\"\r\n class=\"mdi mdi-menu-down icon\"\r\n ></i>\r\n <i\r\n *ngIf=\"t.menuOpen\"\r\n class=\"mdi mdi-menu-up icon\"\r\n ></i>\r\n </ng-container>\r\n</button>\r\n<ng-content select=\".role-tooltip-icon\"></ng-content>\r\n<mat-menu\r\n backdropClass=\"single-select-dropdown\"\r\n [yPosition]=\"yPosition\"\r\n #contextMenu=\"matMenu\"\r\n>\r\n <ng-template matMenuContent>\r\n <div\r\n class=\"{{ config.classes }}\"\r\n [style.width.px]=\"width\"\r\n >\r\n <div\r\n class=\"gap\"\r\n *ngIf=\"config.showSearchBar\"\r\n ></div>\r\n <div\r\n *ngIf=\"showClearSelection\"\r\n class=\"clear-selection\"\r\n >\r\n <a\r\n (click)=\"clearSelectionClicked()\"\r\n [ngClass]=\"{ disabled: !selectedItem }\"\r\n >Clear selection</a\r\n >\r\n </div>\r\n <section\r\n *ngIf=\"config.showSearchBar\"\r\n class=\"search-bar\"\r\n >\r\n <i class=\"mi mdi-search search-icon\"></i>\r\n <input\r\n type=\"text\"\r\n [(ngModel)]=\"searchFor\"\r\n placeholder=\"Search\"\r\n (ngModelChange)=\"updateHeight()\"\r\n (click)=\"$event.stopPropagation()\"\r\n />\r\n </section>\r\n <cdk-virtual-scroll-viewport\r\n class=\"dropdown-data-container\"\r\n itemSize=\"18\"\r\n [style.height.px]=\"heightOfCheckboxTooltipFilter\"\r\n >\r\n <ul\r\n class=\"single-select-ul\"\r\n [style.width.px]=\"width\"\r\n >\r\n <ng-container *ngIf=\"items && (items[0] | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n *cdkVirtualFor=\"\r\n let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n let last = last;\r\n trackBy: trackByFn\r\n \"\r\n [ngClass]=\"{\r\n active:\r\n selectedItem &&\r\n selectedItem[keyToUseForCheckingSelectedItem] ===\r\n item[keyToUseForCheckingSelectedItem],\r\n 'show-bottom-border': !last && borderbottomObject[item.id],\r\n disabled: item.isDisabled\r\n }\"\r\n (click)=\"itemSelected(item, $event)\"\r\n >\r\n <span [class]=\"item.class\"> {{ item[keyToUseForDisplay] }} </span>\r\n <ng-container *ngIf=\"item && item.additionalData\">\r\n <span\r\n class=\"ml-0\"\r\n [class]=\"item.additionalClass\"\r\n >\r\n {{ item?.additionalData }}\r\n </span>\r\n </ng-container>\r\n </li>\r\n\r\n <ng-container\r\n [ngTemplateOutlet]=\"noDataCase\"\r\n [ngTemplateOutletContext]=\"{ items: items }\"\r\n ></ng-container>\r\n </ng-container>\r\n\r\n <ng-template #stringTypeTemplate>\r\n <ng-container\r\n *ngFor=\"\r\n let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n [ngClass]=\"{ active: selectedItem && selectedItem === item }\"\r\n (click)=\"itemSelected(item, $event)\"\r\n >\r\n <span> {{ item }} </span>\r\n </li>\r\n </ng-container>\r\n <ng-container\r\n [ngTemplateOutlet]=\"noDataCase\"\r\n [ngTemplateOutletContext]=\"{ items: items }\"\r\n ></ng-container>\r\n </ng-template>\r\n </ul>\r\n </cdk-virtual-scroll-viewport>\r\n </div>\r\n </ng-template>\r\n</mat-menu>\r\n\r\n<ng-template\r\n #noDataCase\r\n let-items=\"items\"\r\n>\r\n <li\r\n annaCoreShowEllipsisTextOnHover\r\n *ngIf=\"(items | AnnafilterSearchedText: searchFor : keyToUseForDisplay)?.length === 0\"\r\n >\r\n <span> No data found </span>\r\n </li>\r\n</ng-template>\r\n", styles: ["#dropdown-trigger{height:1.5rem;background:#fff;border-radius:2px;border:1px solid #b7b7b7;width:100%;text-align:left;display:flex;align-items:center}#dropdown-trigger:disabled{background-color:#bdbdbd;opacity:.5}#dropdown-trigger:disabled .placeholder,#dropdown-trigger:disabled .icon{color:#000}.placeholder{color:#bdbdbd;width:100%;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;opacity:1!important}.icon{font-size:1.125rem;float:right;margin-left:auto}.search-bar{margin:0 7px 8px;border:1px solid #b7b7b7;height:24px;border-radius:2px}.search-bar input{outline:none;border:none;position:relative;bottom:4px;width:calc(100% - 29px);font-size:var(--dropdown-text-fs)}.search-bar .search-icon{font-size:var(--multi-select-dropdown-checkbox-fs);color:#9b9b9b;margin:5px}.search-bar .close-icon{cursor:pointer}ul{overflow-y:auto;padding-left:0;padding-bottom:0;margin-bottom:0;max-height:calc(50vh - 80px)!important}li{list-style-type:none;cursor:pointer;padding-inline:10px;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:2.14;letter-spacing:normal;color:#4a4a4a;width:100%}ul::-webkit-scrollbar{width:4px;height:4px}ul::-webkit-scrollbar-track{border:1px solid rgba(0,0,0,.1)}ul::-webkit-scrollbar-thumb{border-radius:4px;background-color:#0006!important;border:1px solid rgba(0,0,0,.2)}li:hover{background:#ebebeb}li.active{color:#fff;background:#268bff}span.selected-item{background:transparent;font-family:Roboto;font-size:var(--dropdown-text-fs);font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#4a4a4a;width:calc(100% - 22px);display:inline-block;vertical-align:middle}.ellipsify,li,span.selected-item{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}::ng-deep .cdk-overlay-container{z-index:1051}span.red-color-text{color:#f44336!important}span.additional-data-color-text{color:#b7b6b6!important}span.italic{font-style:italic}.spinner-for-button-directive{left:0;margin-left:auto}.spinner-for-button-directive span.additional-data-color-text{color:#000}::ng-deep .mat-menu-panel{min-height:auto!important}.small-text li{font-size:12px!important}.ml-0{margin-left:0}#dropdown-trigger:disabled{cursor:default!important}#dropdown-trigger:disabled span{color:#4a4a4a!important;cursor:default!important}::ng-deep .mat-mdc-menu-panel.mat-elevation-z8{box-shadow:var(--dropdown-box-shadow)}::ng-deep .mat-mdc-menu-panel .mat-mdc-menu-content{background-color:#fff;padding:0!important}::ng-deep .mat-mdc-menu-panel .mat-mdc-menu-content.mdc-list{background-color:#fff}::ng-deep .mat-mdc-menu-panel.mat-mdc-menu-panel{max-width:none!important}::ng-deep .mat-mdc-menu-panel .clear-selection{margin:0 7px!important}::ng-deep .mat-mdc-menu-panel .clear-selection a{color:#268bff!important;text-decoration:underline!important;font-size:12px!important}::ng-deep .mat-mdc-menu-panel .clear-selection a.disabled{color:#4a4a4a!important;pointer-events:none;cursor:not-allowed;opacity:.5}li{background-color:#fff}cdk-virtual-scroll-viewport.dropdown-data-container{max-height:12.5rem;width:100%;overflow-y:auto;overflow-x:hidden}cdk-virtual-scroll-viewport.dropdown-data-container li.disabled{opacity:.5;cursor:default}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar{width:.1875rem}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar-thumb{color:#d3d3d3;background:#d3d3d3}::ng-deep ul.single-select-ul{max-height:none!important}li.show-bottom-border{border-bottom:1px solid #e6e6e6}::ng-deep .no-wrap-text ul li{line-height:1.41!important;padding-top:4px;padding-bottom:4px}::ng-deep .no-wrap-text ul li span{white-space:normal!important}.gap{height:9px}\n"] }]
117
+ }], ctorParameters: function () { return [{ type: i1.AnnaGlobalConfigService }, { type: i2.AnnaFilterSearchedTextPipe }]; }, propDecorators: { config: [{
118
+ type: Input
119
+ }], loading: [{
120
+ type: Input
121
+ }], showAdditionalDataInSelectedText: [{
122
+ type: Input
123
+ }], disabled: [{
124
+ type: Input
125
+ }], items: [{
126
+ type: Input
127
+ }], selectedItem: [{
128
+ type: Input
129
+ }], keyToUseForDisplay: [{
130
+ type: Input
131
+ }], keyToUseForCheckingSelectedItem: [{
132
+ type: Input
133
+ }], hideDropdownArrow: [{
134
+ type: Input
135
+ }], borderbottomObject: [{
136
+ type: Input
137
+ }], defaultDropdownHeight: [{
138
+ type: Input
139
+ }], itemsToHideInDropdownIds: [{
140
+ type: Input
141
+ }], showClearSelection: [{
142
+ type: Input
143
+ }], valueChanged: [{
144
+ type: Output
145
+ }], dropdownClosedEvent: [{
146
+ type: Output
147
+ }], dropdownOpenedEvent: [{
148
+ type: Output
149
+ }], clearSelectionClickedEvent: [{
150
+ type: Output
151
+ }], buttonElement: [{
152
+ type: ViewChild,
153
+ args: ["dropdown"]
154
+ }] } });
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-single-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/anna-core/src/lib/anna-dropdown-lib/components/anna-single-select/anna-single-select.component.ts","../../../../../../../projects/anna-core/src/lib/anna-dropdown-lib/components/anna-single-select/anna-single-select.component.html"],"names":[],"mappings":"AAAA,sDAAsD;AACtD,OAAO,EAAE,yBAAyB,EAAE,eAAe,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAC9G,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACzE,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EAGL,MAAM,EAEN,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,OAAO,EAAE,0BAA0B,EAAE,MAAM,iEAAiE,CAAC;AAC7G,OAAO,EAAE,kBAAkB,EAAE,MAAM,yDAAyD,CAAC;AAC7F,OAAO,EAAE,uBAAuB,EAAE,MAAM,mEAAmE,CAAC;;;;;;AAuB5G,MAAM,OAAO,yBAAyB;IA0BlC,YACY,gBAAyC,EACzC,gBAA4C;QAD5C,qBAAgB,GAAhB,gBAAgB,CAAyB;QACzC,qBAAgB,GAAhB,gBAAgB,CAA4B;QA1B/C,YAAO,GAAY,KAAK,CAAC;QACzB,qCAAgC,GAAY,KAAK,CAAC;QAIlD,uBAAkB,GAAW,MAAM,CAAC;QACpC,oCAA+B,GAAW,IAAI,CAAC;QAC/C,sBAAiB,GAAY,KAAK,CAAC;QACnC,uBAAkB,GAAQ,EAAE,CAAC;QAC7B,0BAAqB,GAAW,IAAI,CAAC;QACrC,6BAAwB,GAAa,EAAE,CAAC;QACxC,uBAAkB,GAAY,KAAK,CAAC;QAEnC,iBAAY,GAAqC,IAAI,YAAY,EAAsB,CAAC;QACxF,wBAAmB,GAAsB,IAAI,YAAY,EAAO,CAAC;QACjE,wBAAmB,GAAsB,IAAI,YAAY,EAAO,CAAC;QACjE,+BAA0B,GAAsB,IAAI,YAAY,EAAO,CAAC;QAElF,cAAS,GAAQ,OAAO,CAAC;IAStB,CAAC;IAEJ,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,CAAC,MAAM,EAAE,YAAY,EAAE;YAC9B,IAAI,CAAC,MAAM,GAAG,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,yBAAyB,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;SACxF;QAED,IAAI,OAAO,CAAC,KAAK,EAAE,YAAY,EAAE;YAC7B,IAAI,IAAI,CAAC,qBAAqB;gBAAE,IAAI,CAAC,6BAA6B,GAAG,IAAI,CAAC,qBAAqB,CAAC;;gBAC3F,IAAI,CAAC,6BAA6B,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;SACrG;QAED,IAAI,OAAO,CAAC,wBAAwB,EAAE,YAAY,EAAE;YAChD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAC1B,CAAC,IAAwB,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CACjF,CAAC;SACL;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,MAAM,GAAG,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,yBAAyB,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QACrF,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED,SAAS,CAAC,KAAa;QACnB,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,YAAY,CAAC,IAAwB,EAAE,KAAiB;QACpD,IAAI,IAAI,EAAE,UAAU,EAAE;YAClB,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,OAAO;SACV;QACD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,EAAE;YACnC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAChC;QACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC7B,CAAC;IAED,cAAc;QACV,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,WAAW,CAAC;QAC1D,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC;IACpC,CAAC;IAED,cAAc;QACV,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC;IACpC,CAAC;IAED,qBAAqB;QACjB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,0BAA0B,CAAC,IAAI,EAAE,CAAC;IAC3C,CAAC;IAED,UAAU;QACN,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,KAAK,KAAK,EAAE;YAC/C,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC;SAC5B;aAAM,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,KAAK,QAAQ,EAAE;YACzD,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC;SAC5B;IACL,CAAC;IACD,YAAY;QACR,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;QACnG,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAClB,IAAI,CAAC,6BAA6B,GAAG,GAAG,CAAC;SAC5C;aAAM,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,IAAI,CAAC,6BAA6B,GAAG,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC;SAC7D;aAAM;YACH,IAAI,CAAC,6BAA6B,GAAG,KAAK,CAAC;SAC9C;IACL,CAAC;+GApGQ,yBAAyB;mGAAzB,yBAAyB,45BC7CtC,spNAqKA,uyHDrIQ,aAAa,qVACb,IAAI,6FACJ,OAAO,mFACP,WAAW,+mBACX,wBAAwB,iJACxB,yBAAyB,sIACzB,eAAe,6LACf,gBAAgB,oJAChB,KAAK,8GACL,0BAA0B,0DAC1B,kBAAkB;;4FAGb,yBAAyB;kBApBrC,SAAS;+BACI,yBAAyB,mBAGlB,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACL,aAAa;wBACb,IAAI;wBACJ,OAAO;wBACP,WAAW;wBACX,wBAAwB;wBACxB,yBAAyB;wBACzB,eAAe;wBACf,gBAAgB;wBAChB,KAAK;wBACL,0BAA0B;wBAC1B,kBAAkB;qBACrB;uJAGQ,MAAM;sBAAd,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,gCAAgC;sBAAxC,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,+BAA+B;sBAAvC,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,wBAAwB;sBAAhC,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBAEI,YAAY;sBAArB,MAAM;gBACG,mBAAmB;sBAA5B,MAAM;gBACG,mBAAmB;sBAA5B,MAAM;gBACG,0BAA0B;sBAAnC,MAAM;gBAMgB,aAAa;sBAAnC,SAAS;uBAAC,UAAU","sourcesContent":["/* eslint-disable import/no-extraneous-dependencies */\r\nimport { CdkFixedSizeVirtualScroll, CdkVirtualForOf, CdkVirtualScrollViewport } from \"@angular/cdk/scrolling\";\r\nimport { NgClass, NgFor, NgIf, NgTemplateOutlet } from \"@angular/common\";\r\nimport {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    Input,\r\n    OnChanges,\r\n    OnInit,\r\n    Output,\r\n    SimpleChanges,\r\n    ViewChild,\r\n} from \"@angular/core\";\r\nimport { FormsModule } from \"@angular/forms\";\r\nimport { MatMenuModule } from \"@angular/material/menu\";\r\nimport { isEqual } from \"lodash-es\";\r\n\r\nimport { ICustomSingleSelect } from \"../../../anna-core-shared-lib/models/anna-global-dropdown-config.model\";\r\nimport { AnnaFilterSearchedTextPipe } from \"../../../anna-core-shared-lib/pipes/annaFilterSearchedText.pipe\";\r\nimport { AnnaTypeofDataPipe } from \"../../../anna-core-shared-lib/pipes/annaTypeOfData.pipe\";\r\nimport { AnnaGlobalConfigService } from \"../../../anna-core-shared-lib/services/anna-global-config.service\";\r\nimport { SingleSelectIdText } from \"./models/anna-single-select.model\";\r\n\r\n@Component({\r\n    selector: \"anna-core-single-select\",\r\n    templateUrl: \"./anna-single-select.component.html\",\r\n    styleUrls: [\"./anna-single-select.component.scss\"],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n    imports: [\r\n        MatMenuModule,\r\n        NgIf,\r\n        NgClass,\r\n        FormsModule,\r\n        CdkVirtualScrollViewport,\r\n        CdkFixedSizeVirtualScroll,\r\n        CdkVirtualForOf,\r\n        NgTemplateOutlet,\r\n        NgFor,\r\n        AnnaFilterSearchedTextPipe,\r\n        AnnaTypeofDataPipe,\r\n    ],\r\n})\r\nexport class AnnaSingleSelectComponent implements OnInit, OnChanges {\r\n    @Input() config: ICustomSingleSelect;\r\n    @Input() loading: boolean = false;\r\n    @Input() showAdditionalDataInSelectedText: boolean = false;\r\n    @Input() disabled: boolean;\r\n    @Input() items: SingleSelectIdText[] | string[] | any;\r\n    @Input() selectedItem: SingleSelectIdText | string | any;\r\n    @Input() keyToUseForDisplay: string = \"text\";\r\n    @Input() keyToUseForCheckingSelectedItem: string = \"id\";\r\n    @Input() hideDropdownArrow: boolean = false;\r\n    @Input() borderbottomObject: any = {};\r\n    @Input() defaultDropdownHeight: number = null;\r\n    @Input() itemsToHideInDropdownIds: number[] = [];\r\n    @Input() showClearSelection: boolean = false;\r\n\r\n    @Output() valueChanged: EventEmitter<SingleSelectIdText> = new EventEmitter<SingleSelectIdText>();\r\n    @Output() dropdownClosedEvent: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output() dropdownOpenedEvent: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output() clearSelectionClickedEvent: EventEmitter<any> = new EventEmitter<any>();\r\n    searchFor: string;\r\n    yPosition: any = \"above\";\r\n    width: number;\r\n    heightOfCheckboxTooltipFilter: number;\r\n\r\n    @ViewChild(\"dropdown\") buttonElement: ElementRef;\r\n\r\n    constructor(\r\n        private annaGlobalConfig: AnnaGlobalConfigService,\r\n        private searchFilterPipe: AnnaFilterSearchedTextPipe,\r\n    ) {}\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (changes.config?.currentValue) {\r\n            this.config = { ...this.annaGlobalConfig.defaultSingleSelectConfig, ...this.config };\r\n        }\r\n\r\n        if (changes.items?.currentValue) {\r\n            if (this.defaultDropdownHeight) this.heightOfCheckboxTooltipFilter = this.defaultDropdownHeight;\r\n            else this.heightOfCheckboxTooltipFilter = this.items.length > 7 ? 200 : 25.68 * this.items.length;\r\n        }\r\n\r\n        if (changes.itemsToHideInDropdownIds?.currentValue) {\r\n            this.items = this.items.filter(\r\n                (item: SingleSelectIdText) => !this.itemsToHideInDropdownIds.includes(item.id),\r\n            );\r\n        }\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.config = { ...this.annaGlobalConfig.defaultSingleSelectConfig, ...this.config };\r\n        this.setPostion();\r\n    }\r\n\r\n    trackByFn(index: number) {\r\n        return index;\r\n    }\r\n\r\n    itemSelected(item: SingleSelectIdText, event: MouseEvent) {\r\n        if (item?.isDisabled) {\r\n            event.stopPropagation();\r\n            return;\r\n        }\r\n        if (!isEqual(this.selectedItem, item)) {\r\n            this.valueChanged.emit(item);\r\n        }\r\n        this.selectedItem = item;\r\n    }\r\n\r\n    dropdownOpened() {\r\n        this.searchFor = \"\";\r\n        this.updateHeight();\r\n        this.width = this.buttonElement.nativeElement.offsetWidth;\r\n        this.dropdownOpenedEvent.emit();\r\n    }\r\n\r\n    dropdownClosed() {\r\n        this.dropdownClosedEvent.emit();\r\n    }\r\n\r\n    clearSelectionClicked() {\r\n        this.selectedItem = null;\r\n        this.clearSelectionClickedEvent.emit();\r\n    }\r\n\r\n    setPostion() {\r\n        if (this.config && this.config.position === \"TOP\") {\r\n            this.yPosition = \"above\";\r\n        } else if (this.config && this.config.position === \"BOTTOM\") {\r\n            this.yPosition = \"below\";\r\n        }\r\n    }\r\n    updateHeight() {\r\n        const items = this.searchFilterPipe.transform(this.items, this.searchFor, this.keyToUseForDisplay);\r\n        if (items.length > 7) {\r\n            this.heightOfCheckboxTooltipFilter = 200;\r\n        } else if (items.length > 0) {\r\n            this.heightOfCheckboxTooltipFilter = 25.68 * items.length;\r\n        } else {\r\n            this.heightOfCheckboxTooltipFilter = 25.68;\r\n        }\r\n    }\r\n}\r\n","<button\r\n    id=\"dropdown-trigger\"\r\n    #dropdown\r\n    #t=\"matMenuTrigger\"\r\n    (menuClosed)=\"dropdownClosed()\"\r\n    (menuOpened)=\"dropdownOpened()\"\r\n    [matMenuTriggerFor]=\"contextMenu\"\r\n    [disabled]=\"disabled || loading\"\r\n>\r\n    <span\r\n        class=\"placeholder\"\r\n        *ngIf=\"!selectedItem && config\"\r\n        >{{ config.placeholder }}</span\r\n    >\r\n    <span\r\n        class=\"selected-item\"\r\n        [class]=\"selectedItem.class\"\r\n        annaCoreShowEllipsisTextOnHover\r\n        *ngIf=\"selectedItem\"\r\n    >\r\n        <ng-container *ngIf=\"(selectedItem | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n            {{ selectedItem[keyToUseForDisplay] }}\r\n            <ng-container *ngIf=\"showAdditionalDataInSelectedText && selectedItem && selectedItem?.additionalData\">\r\n                <span [class]=\"selectedItem?.additionalClass\">{{ selectedItem?.additionalData }} </span>\r\n            </ng-container>\r\n        </ng-container>\r\n        <ng-template #stringTypeTemplate>\r\n            {{ selectedItem }}\r\n        </ng-template>\r\n    </span>\r\n    <div\r\n        *ngIf=\"loading\"\r\n        [ngClass]=\"{ 'spinner-for-button-directive': loading }\"\r\n    ></div>\r\n\r\n    <ng-container *ngIf=\"!loading && !hideDropdownArrow\">\r\n        <i\r\n            *ngIf=\"!t.menuOpen\"\r\n            class=\"mdi mdi-menu-down icon\"\r\n        ></i>\r\n        <i\r\n            *ngIf=\"t.menuOpen\"\r\n            class=\"mdi mdi-menu-up icon\"\r\n        ></i>\r\n    </ng-container>\r\n</button>\r\n<ng-content select=\".role-tooltip-icon\"></ng-content>\r\n<mat-menu\r\n    backdropClass=\"single-select-dropdown\"\r\n    [yPosition]=\"yPosition\"\r\n    #contextMenu=\"matMenu\"\r\n>\r\n    <ng-template matMenuContent>\r\n        <div\r\n            class=\"{{ config.classes }}\"\r\n            [style.width.px]=\"width\"\r\n        >\r\n            <div\r\n                class=\"gap\"\r\n                *ngIf=\"config.showSearchBar\"\r\n            ></div>\r\n            <div\r\n                *ngIf=\"showClearSelection\"\r\n                class=\"clear-selection\"\r\n            >\r\n                <a\r\n                    (click)=\"clearSelectionClicked()\"\r\n                    [ngClass]=\"{ disabled: !selectedItem }\"\r\n                    >Clear selection</a\r\n                >\r\n            </div>\r\n            <section\r\n                *ngIf=\"config.showSearchBar\"\r\n                class=\"search-bar\"\r\n            >\r\n                <i class=\"mi mdi-search search-icon\"></i>\r\n                <input\r\n                    type=\"text\"\r\n                    [(ngModel)]=\"searchFor\"\r\n                    placeholder=\"Search\"\r\n                    (ngModelChange)=\"updateHeight()\"\r\n                    (click)=\"$event.stopPropagation()\"\r\n                />\r\n            </section>\r\n            <cdk-virtual-scroll-viewport\r\n                class=\"dropdown-data-container\"\r\n                itemSize=\"18\"\r\n                [style.height.px]=\"heightOfCheckboxTooltipFilter\"\r\n            >\r\n                <ul\r\n                    class=\"single-select-ul\"\r\n                    [style.width.px]=\"width\"\r\n                >\r\n                    <ng-container *ngIf=\"items && (items[0] | AnnatypeofData) === 'object'; else stringTypeTemplate\">\r\n                        <li\r\n                            annaCoreShowEllipsisTextOnHover\r\n                            *cdkVirtualFor=\"\r\n                                let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n                                let last = last;\r\n                                trackBy: trackByFn\r\n                            \"\r\n                            [ngClass]=\"{\r\n                                active:\r\n                                    selectedItem &&\r\n                                    selectedItem[keyToUseForCheckingSelectedItem] ===\r\n                                        item[keyToUseForCheckingSelectedItem],\r\n                                'show-bottom-border': !last && borderbottomObject[item.id],\r\n                                disabled: item.isDisabled\r\n                            }\"\r\n                            (click)=\"itemSelected(item, $event)\"\r\n                        >\r\n                            <span [class]=\"item.class\"> {{ item[keyToUseForDisplay] }} </span>\r\n                            <ng-container *ngIf=\"item && item.additionalData\">\r\n                                <span\r\n                                    class=\"ml-0\"\r\n                                    [class]=\"item.additionalClass\"\r\n                                >\r\n                                    {{ item?.additionalData }}\r\n                                </span>\r\n                            </ng-container>\r\n                        </li>\r\n\r\n                        <ng-container\r\n                            [ngTemplateOutlet]=\"noDataCase\"\r\n                            [ngTemplateOutletContext]=\"{ items: items }\"\r\n                        ></ng-container>\r\n                    </ng-container>\r\n\r\n                    <ng-template #stringTypeTemplate>\r\n                        <ng-container\r\n                            *ngFor=\"\r\n                                let item of items | AnnafilterSearchedText: searchFor : keyToUseForDisplay;\r\n                                trackBy: trackByFn\r\n                            \"\r\n                        >\r\n                            <li\r\n                                annaCoreShowEllipsisTextOnHover\r\n                                [ngClass]=\"{ active: selectedItem && selectedItem === item }\"\r\n                                (click)=\"itemSelected(item, $event)\"\r\n                            >\r\n                                <span> {{ item }} </span>\r\n                            </li>\r\n                        </ng-container>\r\n                        <ng-container\r\n                            [ngTemplateOutlet]=\"noDataCase\"\r\n                            [ngTemplateOutletContext]=\"{ items: items }\"\r\n                        ></ng-container>\r\n                    </ng-template>\r\n                </ul>\r\n            </cdk-virtual-scroll-viewport>\r\n        </div>\r\n    </ng-template>\r\n</mat-menu>\r\n\r\n<ng-template\r\n    #noDataCase\r\n    let-items=\"items\"\r\n>\r\n    <li\r\n        annaCoreShowEllipsisTextOnHover\r\n        *ngIf=\"(items | AnnafilterSearchedText: searchFor : keyToUseForDisplay)?.length === 0\"\r\n    >\r\n        <span> No data found </span>\r\n    </li>\r\n</ng-template>\r\n"]}
@@ -0,0 +1,12 @@
1
+ export class SingleSelectIdText {
2
+ constructor(id, text, className, additionalClass, additionalData, isSelected, isDisabled) {
3
+ this.id = id;
4
+ this.text = text;
5
+ this.class = className;
6
+ this.additionalClass = additionalClass;
7
+ this.additionalData = additionalData;
8
+ this.isSelected = isSelected;
9
+ this.isDisabled = isDisabled;
10
+ }
11
+ }
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5uYS1zaW5nbGUtc2VsZWN0Lm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYW5uYS1jb3JlL3NyYy9saWIvYW5uYS1kcm9wZG93bi1saWIvY29tcG9uZW50cy9hbm5hLXNpbmdsZS1zZWxlY3QvbW9kZWxzL2FubmEtc2luZ2xlLXNlbGVjdC5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sa0JBQWtCO0lBUTNCLFlBQ0ksRUFBTyxFQUNQLElBQVksRUFDWixTQUFrQixFQUNsQixlQUF3QixFQUN4QixjQUF1QixFQUN2QixVQUFvQixFQUNwQixVQUFvQjtRQUVwQixJQUFJLENBQUMsRUFBRSxHQUFHLEVBQUUsQ0FBQztRQUNiLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxLQUFLLEdBQUcsU0FBUyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxlQUFlLEdBQUcsZUFBZSxDQUFDO1FBQ3ZDLElBQUksQ0FBQyxjQUFjLEdBQUcsY0FBYyxDQUFDO1FBQ3JDLElBQUksQ0FBQyxVQUFVLEdBQUcsVUFBVSxDQUFDO1FBQzdCLElBQUksQ0FBQyxVQUFVLEdBQUcsVUFBVSxDQUFDO0lBQ2pDLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBTaW5nbGVTZWxlY3RJZFRleHQge1xyXG4gICAgaWQ6IGFueTtcclxuICAgIHRleHQ6IHN0cmluZztcclxuICAgIGNsYXNzPzogc3RyaW5nO1xyXG4gICAgYWRkaXRpb25hbENsYXNzPzogc3RyaW5nO1xyXG4gICAgYWRkaXRpb25hbERhdGE/OiBzdHJpbmc7XHJcbiAgICBpc1NlbGVjdGVkPzogYm9vbGVhbjtcclxuICAgIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgaWQ6IGFueSxcclxuICAgICAgICB0ZXh0OiBzdHJpbmcsXHJcbiAgICAgICAgY2xhc3NOYW1lPzogc3RyaW5nLFxyXG4gICAgICAgIGFkZGl0aW9uYWxDbGFzcz86IHN0cmluZyxcclxuICAgICAgICBhZGRpdGlvbmFsRGF0YT86IHN0cmluZyxcclxuICAgICAgICBpc1NlbGVjdGVkPzogYm9vbGVhbixcclxuICAgICAgICBpc0Rpc2FibGVkPzogYm9vbGVhbixcclxuICAgICkge1xyXG4gICAgICAgIHRoaXMuaWQgPSBpZDtcclxuICAgICAgICB0aGlzLnRleHQgPSB0ZXh0O1xyXG4gICAgICAgIHRoaXMuY2xhc3MgPSBjbGFzc05hbWU7XHJcbiAgICAgICAgdGhpcy5hZGRpdGlvbmFsQ2xhc3MgPSBhZGRpdGlvbmFsQ2xhc3M7XHJcbiAgICAgICAgdGhpcy5hZGRpdGlvbmFsRGF0YSA9IGFkZGl0aW9uYWxEYXRhO1xyXG4gICAgICAgIHRoaXMuaXNTZWxlY3RlZCA9IGlzU2VsZWN0ZWQ7XHJcbiAgICAgICAgdGhpcy5pc0Rpc2FibGVkID0gaXNEaXNhYmxlZDtcclxuICAgIH1cclxufVxyXG4iXX0=