@ti-tecnologico-de-monterrey-oficial/ds-ng 1.6.18-e → 1.6.18-f

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 (81) hide show
  1. package/assets/i18n/en.json +31 -1
  2. package/assets/i18n/es.json +31 -1
  3. package/assets/styles/mainGED.min.css +1 -1
  4. package/assets/styles/mainGED.min.css.map +1 -1
  5. package/assets/styles/mainTEC.min.css +1 -1
  6. package/assets/styles/mainTEC.min.css.map +1 -1
  7. package/assets/styles/mainTECMI.min.css +1 -1
  8. package/assets/styles/mainTECMI.min.css.map +1 -1
  9. package/assets/styles/micro.min.css +1 -1
  10. package/assets/styles/micro.min.css.map +1 -1
  11. package/esm2022/assets/i18n/en.json +31 -1
  12. package/esm2022/assets/i18n/es.json +31 -1
  13. package/esm2022/lib/components/bmb-account-statement/bmb-account-statement.component.mjs +2 -2
  14. package/esm2022/lib/components/bmb-action-menu/bmb-action-menu.component.mjs +3 -3
  15. package/esm2022/lib/components/bmb-alert-center/bmb-alert-center-form/bmb-alert-center-form.component.mjs +91 -78
  16. package/esm2022/lib/components/bmb-alert-center/bmb-alert-center-list/bmb-alert-center-list.component.mjs +17 -5
  17. package/esm2022/lib/components/bmb-alert-center/bmb-alert-center.component.mjs +10 -4
  18. package/esm2022/lib/components/bmb-alert-center/types.mjs +1 -1
  19. package/esm2022/lib/components/bmb-button-icon/bmb-button-icon.component.mjs +3 -3
  20. package/esm2022/lib/components/bmb-card-button/bmb-card-button.component.mjs +3 -3
  21. package/esm2022/lib/components/bmb-chevron-title-selector/bmb-chevron-title-selector.component.mjs +2 -2
  22. package/esm2022/lib/components/bmb-container-button/bmb-container-button.component.mjs +3 -3
  23. package/esm2022/lib/components/bmb-datepicker/bmb-datepicker.component.mjs +2 -2
  24. package/esm2022/lib/components/bmb-digital-id/bmb-digital-id.component.mjs +2 -2
  25. package/esm2022/lib/components/bmb-dropdown/bmb-dropdown.component.mjs +1 -1
  26. package/esm2022/lib/components/bmb-dropdown-menu/bmb-dropdown-menu.component.mjs +3 -3
  27. package/esm2022/lib/components/bmb-evaluation-rubric/bmb-evaluation-rubric.component.mjs +2 -2
  28. package/esm2022/lib/components/bmb-external-link/bmb-external-link.component.mjs +3 -3
  29. package/esm2022/lib/components/bmb-filter-card/bmb-filter-card.component.mjs +2 -2
  30. package/esm2022/lib/components/bmb-grades/bmb-grades.component.mjs +2 -2
  31. package/esm2022/lib/components/bmb-home-card/bmb-home-card-header/bmb-home-card-header.component.mjs +2 -2
  32. package/esm2022/lib/components/bmb-icon/bmb-icon.component.mjs +3 -1
  33. package/esm2022/lib/components/bmb-image/bmb-image.component.mjs +38 -8
  34. package/esm2022/lib/components/bmb-image/types.mjs +2 -0
  35. package/esm2022/lib/components/bmb-inner-header/bmb-inner-header.component.mjs +2 -2
  36. package/esm2022/lib/components/bmb-input/bmb-input-content/bmb-input-content.component.mjs +6 -3
  37. package/esm2022/lib/components/bmb-input/bmb-input.component.mjs +4 -3
  38. package/esm2022/lib/components/bmb-input-phone-number/bmb-input-phone-number.component.mjs +2 -2
  39. package/esm2022/lib/components/bmb-input-tags/bmb-input-tags.component.mjs +2 -2
  40. package/esm2022/lib/components/bmb-list-group/bmb-list-group-item/bmb-list-group-item.component.mjs +1 -1
  41. package/esm2022/lib/components/bmb-list-items/bmb-list-items.component.mjs +1 -1
  42. package/esm2022/lib/components/bmb-login/bmb-login-content/bmb-login-content.component.mjs +2 -2
  43. package/esm2022/lib/components/bmb-modal/bmb-modal.component.mjs +2 -2
  44. package/esm2022/lib/components/bmb-modal/bmb-native-modal.component.mjs +2 -2
  45. package/esm2022/lib/components/bmb-notification-card/bmb-notification-card.component.mjs +28 -18
  46. package/esm2022/lib/components/bmb-portal/bmb-portal.component.mjs +3 -3
  47. package/esm2022/lib/components/bmb-profile/bmb-profile.component.mjs +9 -3
  48. package/esm2022/lib/components/bmb-search-card/bmb-search-card-empty-state/bmb-search-card-empty-state.component.mjs +17 -0
  49. package/esm2022/lib/components/bmb-search-card/bmb-search-card-item/bmb-search-card-item.component.mjs +35 -0
  50. package/esm2022/lib/components/bmb-search-card/bmb-search-card.component.mjs +72 -0
  51. package/esm2022/lib/components/bmb-search-input/bmb-search-input.component.mjs +2 -2
  52. package/esm2022/lib/components/bmb-table-lite/bmb-table-lite.component.mjs +2 -2
  53. package/esm2022/lib/components/bmb-tables/bmb-tables.component.mjs +2 -2
  54. package/esm2022/lib/components/bmb-text-editor/bmb-text-editor-prompt/bmb-text-editor-prompt.component.mjs +2 -2
  55. package/esm2022/lib/components/bmb-title-content/bmb-title-content.component.mjs +7 -3
  56. package/esm2022/lib/components/bmb-tooltip/bmb-tooltip.component.mjs +3 -3
  57. package/esm2022/lib/components/bmb-top-bar/bmb-top-bar-user-section/bmb-top-bar-user-section.component.mjs +3 -3
  58. package/esm2022/lib/components/bmb-top-bar/bmb-top-bar.component.mjs +3 -3
  59. package/esm2022/lib/components/bmb-totp/bmb-totp.component.mjs +2 -2
  60. package/esm2022/lib/components/utils/bmb-alert-center-detail/bmb-alert-center-detail.component.mjs +2 -2
  61. package/esm2022/lib/types/colors.mjs +1 -1
  62. package/esm2022/public-api.mjs +2 -1
  63. package/fesm2022/ti-tecnologico-de-monterrey-oficial-ds-ng.mjs +1486 -1237
  64. package/fesm2022/ti-tecnologico-de-monterrey-oficial-ds-ng.mjs.map +1 -1
  65. package/lib/components/bmb-alert-center/bmb-alert-center-form/bmb-alert-center-form.component.d.ts +15 -18
  66. package/lib/components/bmb-alert-center/bmb-alert-center-list/bmb-alert-center-list.component.d.ts +3 -2
  67. package/lib/components/bmb-alert-center/types.d.ts +6 -0
  68. package/lib/components/bmb-image/bmb-image.component.d.ts +10 -1
  69. package/lib/components/bmb-image/types.d.ts +12 -0
  70. package/lib/components/bmb-input/bmb-input-content/bmb-input-content.component.d.ts +2 -1
  71. package/lib/components/bmb-input/bmb-input.component.d.ts +2 -1
  72. package/lib/components/bmb-notification-card/bmb-notification-card.component.d.ts +1 -0
  73. package/lib/components/bmb-profile/bmb-profile.component.d.ts +5 -1
  74. package/lib/components/bmb-search-card/bmb-search-card-empty-state/bmb-search-card-empty-state.component.d.ts +6 -0
  75. package/lib/components/bmb-search-card/bmb-search-card-item/bmb-search-card-item.component.d.ts +15 -0
  76. package/lib/components/bmb-search-card/bmb-search-card.component.d.ts +33 -0
  77. package/lib/components/bmb-tables/bmb-tables.component.d.ts +1 -1
  78. package/lib/components/bmb-title-content/bmb-title-content.component.d.ts +4 -1
  79. package/lib/types/colors.d.ts +1 -1
  80. package/package.json +1 -1
  81. package/public-api.d.ts +1 -0
@@ -0,0 +1,72 @@
1
+ import { Component, computed, input, model, output } from '@angular/core';
2
+ import { BmbHomeCardComponent } from '../bmb-home-card/bmb-home-card.component';
3
+ import { TranslatePipe } from '../../pipes/translations';
4
+ import { BmbInputComponent } from '../bmb-input/bmb-input.component';
5
+ import { BmbTabsComponent } from '../bmb-tabs/bmb-tabs.component';
6
+ import { FormControl } from '@angular/forms';
7
+ import { CommonModule } from '@angular/common';
8
+ import { BmbSearchCardEmptyStateComponent } from './bmb-search-card-empty-state/bmb-search-card-empty-state.component';
9
+ import { BmbSearchCardItemComponent } from './bmb-search-card-item/bmb-search-card-item.component';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "../../services/translations/translations.service";
12
+ import * as i2 from "@angular/common";
13
+ export class BmbSearchCardComponent {
14
+ constructor(translationsService) {
15
+ this.translationsService = translationsService;
16
+ this.title = input('');
17
+ this.inputPlaceholder = input('');
18
+ this.results = input([]);
19
+ this.isLoading = input(false);
20
+ this.selectedTabId = model(1);
21
+ this.triggerSearch = output();
22
+ this.searchItemClick = output();
23
+ this.inputSearchControl = new FormControl('');
24
+ this.computedResults = computed(() => {
25
+ return this.results().reduce((acc, item) => {
26
+ if (item.type === 'service') {
27
+ acc.services.push(item);
28
+ }
29
+ else if (item.type === 'person') {
30
+ acc.persons.push(item);
31
+ }
32
+ return acc;
33
+ }, { services: [], persons: [] });
34
+ });
35
+ this.tabsData = computed(() => [
36
+ {
37
+ id: 1,
38
+ title: this.translationsService.translate('search_card.tabs.all'),
39
+ badge: this.computedResults().persons.length + this.computedResults().services.length,
40
+ isActive: true,
41
+ },
42
+ {
43
+ id: 2,
44
+ title: this.translationsService.translate('search_card.tabs.services'),
45
+ badge: this.computedResults().services.length,
46
+ },
47
+ {
48
+ id: 3,
49
+ title: this.translationsService.translate('search_card.tabs.people'),
50
+ badge: this.computedResults().persons.length,
51
+ },
52
+ ]);
53
+ this.inputSearchControl.valueChanges.subscribe((value) => {
54
+ this.triggerSearch.emit(value || '');
55
+ });
56
+ }
57
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BmbSearchCardComponent, deps: [{ token: i1.BmbTranslationsService }], target: i0.ɵɵFactoryTarget.Component }); }
58
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: BmbSearchCardComponent, isStandalone: true, selector: "bmb-search-card", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, inputPlaceholder: { classPropertyName: "inputPlaceholder", publicName: "inputPlaceholder", isSignal: true, isRequired: false, transformFunction: null }, results: { classPropertyName: "results", publicName: "results", isSignal: true, isRequired: false, transformFunction: null }, isLoading: { classPropertyName: "isLoading", publicName: "isLoading", isSignal: true, isRequired: false, transformFunction: null }, selectedTabId: { classPropertyName: "selectedTabId", publicName: "selectedTabId", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selectedTabId: "selectedTabIdChange", triggerSearch: "triggerSearch", searchItemClick: "searchItemClick" }, ngImport: i0, template: "<section class=\"bmb_search-card\">\n <bmb-home-card\n [title]=\"title() || 'search_card.title' | translate\"\n [showRightButton]=\"false\"\n icon=\"search\"\n bgIconAppearance=\"blue-primary\"\n >\n <bmb-input\n [placeholder]=\"\n inputPlaceholder() || 'search_card.input_placeholder' | translate\n \"\n [icon]=\"'search'\"\n [isClearable]=\"true\"\n [control]=\"inputSearchControl\"\n [isLoading]=\"isLoading()\"\n />\n <section\n class=\"bmb_search-card-results\"\n [ngClass]=\"{\n 'bmb_search-card-results-active':\n computedResults().persons.length && computedResults().services.length\n }\"\n ></section>\n <bmb-tabs [tabs]=\"tabsData()\" [(selectedTabId)]=\"selectedTabId\">\n @switch (selectedTabId()) {\n @case (1) {\n @if (computedResults().services.length) {\n <section class=\"bmb_search-card-results-section\">\n <h3>{{ 'search_card.tabs.services' | translate }}</h3>\n <ul class=\"bmb_search-card-results-list\">\n @for (service of computedResults().services; track $index) {\n <ng-container *ngTemplateOutlet=\"cardItem; context: { item: service }\"></ng-container>\n }\n </ul>\n </section>\n }\n @if (computedResults().persons.length) {\n <section class=\"bmb_search-card-results-section\">\n <h3>{{ 'search_card.tabs.people' | translate }}</h3>\n <ul class=\"bmb_search-card-results-list\">\n @for (person of computedResults().persons; track $index) {\n <ng-container *ngTemplateOutlet=\"cardItem; context: { item: person }\"></ng-container>\n }\n </ul>\n </section>\n }\n }\n @case (2) {\n @if (computedResults().services.length) {\n <section class=\"bmb_search-card-results-section\">\n <h3>{{ 'search_card.tabs.services' | translate }}</h3>\n <ul class=\"bmb_search-card-results-list\">\n @for (service of computedResults().services; track $index) {\n <ng-container *ngTemplateOutlet=\"cardItem; context: { item: service }\"></ng-container>\n }\n </ul>\n </section>\n }\n }\n @case (3) {\n @if (computedResults().persons.length) {\n <section class=\"bmb_search-card-results-section\">\n <h3>{{ 'search_card.tabs.people' | translate }}</h3>\n <ul class=\"bmb_search-card-results-list\">\n @for (person of computedResults().persons; track $index) {\n <ng-container *ngTemplateOutlet=\"cardItem; context: { item: person }\"></ng-container>\n }\n </ul>\n </section>\n }\n }\n }\n </bmb-tabs>\n @if (\n !computedResults().persons.length && !computedResults().services.length && !isLoading()\n ) {\n <bmb-search-card-empty-state\n [inputHasValue]=\"!!inputSearchControl.value\"\n ></bmb-search-card-empty-state>\n }\n {{ isLoading() ? 'Loading...' : '' }}\n </bmb-home-card>\n</section>\n\n<ng-template #cardItem let-item=\"item\">\n <li class=\"bmb_search-card-results-list-item\">\n <bmb-search-card-item\n [name]=\"item.name\"\n [subtitle]=\"item.subtitle\"\n [icon]=\"item.avatarOrIcon\"\n [isService]=\"false\"\n (triggerClick)=\"searchItemClick.emit(item)\"\n ></bmb-search-card-item>\n </li>\n</ng-template>\n", styles: [".bmb_search-card-results-list{padding:0;margin:0;list-style:none}.bmb_search-card-results-section{padding-block-start:var(--bmb-spacing-l)}\n"], dependencies: [{ kind: "component", type: BmbHomeCardComponent, selector: "bmb-home-card", inputs: ["title", "subtitle", "dataLocalNav", "leftIcon", "icon", "iconSize", "bgIconAppearance", "actionHeaders", "isMobile", "contentPadding", "showRightButton", "isExpanded", "useAutoExpand", "isChat", "actionsList"], outputs: ["isExpandedChange", "onClose", "onBack", "onExpandClick"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: BmbInputComponent, selector: "bmb-input", inputs: ["label", "type", "placeholder", "icon", "appearance", "errorMessage", "helperMessage", "disabled", "isRequired", "name", "spellcheck", "jsonFormat", "heightTextArea", "maxlength", "minlength", "pattern", "max", "min", "value", "autocomplete", "tooltip", "rows", "showMaxTextLength", "additionalAction", "tooltipPosition", "isClearable", "customValidation", "inputId", "isLoading", "showError", "control"], outputs: ["showErrorChange", "controlChange", "isFocus", "isBlur", "onChange", "onKeyDown"] }, { kind: "component", type: BmbTabsComponent, selector: "bmb-tabs", inputs: ["appearanceContrast", "format", "tabs", "selectedTabId"], outputs: ["selectedTabIdChange", "selected"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: BmbSearchCardEmptyStateComponent, selector: "bmb-search-card-empty-state", inputs: ["inputHasValue"] }, { kind: "component", type: BmbSearchCardItemComponent, selector: "bmb-search-card-item", inputs: ["name", "itemId", "subtitle", "icon", "isService", "backgroundColorIcon"], outputs: ["triggerClick"] }] }); }
59
+ }
60
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BmbSearchCardComponent, decorators: [{
61
+ type: Component,
62
+ args: [{ selector: 'bmb-search-card', standalone: true, imports: [
63
+ BmbHomeCardComponent,
64
+ TranslatePipe,
65
+ BmbInputComponent,
66
+ BmbTabsComponent,
67
+ CommonModule,
68
+ BmbSearchCardEmptyStateComponent,
69
+ BmbSearchCardItemComponent,
70
+ ], template: "<section class=\"bmb_search-card\">\n <bmb-home-card\n [title]=\"title() || 'search_card.title' | translate\"\n [showRightButton]=\"false\"\n icon=\"search\"\n bgIconAppearance=\"blue-primary\"\n >\n <bmb-input\n [placeholder]=\"\n inputPlaceholder() || 'search_card.input_placeholder' | translate\n \"\n [icon]=\"'search'\"\n [isClearable]=\"true\"\n [control]=\"inputSearchControl\"\n [isLoading]=\"isLoading()\"\n />\n <section\n class=\"bmb_search-card-results\"\n [ngClass]=\"{\n 'bmb_search-card-results-active':\n computedResults().persons.length && computedResults().services.length\n }\"\n ></section>\n <bmb-tabs [tabs]=\"tabsData()\" [(selectedTabId)]=\"selectedTabId\">\n @switch (selectedTabId()) {\n @case (1) {\n @if (computedResults().services.length) {\n <section class=\"bmb_search-card-results-section\">\n <h3>{{ 'search_card.tabs.services' | translate }}</h3>\n <ul class=\"bmb_search-card-results-list\">\n @for (service of computedResults().services; track $index) {\n <ng-container *ngTemplateOutlet=\"cardItem; context: { item: service }\"></ng-container>\n }\n </ul>\n </section>\n }\n @if (computedResults().persons.length) {\n <section class=\"bmb_search-card-results-section\">\n <h3>{{ 'search_card.tabs.people' | translate }}</h3>\n <ul class=\"bmb_search-card-results-list\">\n @for (person of computedResults().persons; track $index) {\n <ng-container *ngTemplateOutlet=\"cardItem; context: { item: person }\"></ng-container>\n }\n </ul>\n </section>\n }\n }\n @case (2) {\n @if (computedResults().services.length) {\n <section class=\"bmb_search-card-results-section\">\n <h3>{{ 'search_card.tabs.services' | translate }}</h3>\n <ul class=\"bmb_search-card-results-list\">\n @for (service of computedResults().services; track $index) {\n <ng-container *ngTemplateOutlet=\"cardItem; context: { item: service }\"></ng-container>\n }\n </ul>\n </section>\n }\n }\n @case (3) {\n @if (computedResults().persons.length) {\n <section class=\"bmb_search-card-results-section\">\n <h3>{{ 'search_card.tabs.people' | translate }}</h3>\n <ul class=\"bmb_search-card-results-list\">\n @for (person of computedResults().persons; track $index) {\n <ng-container *ngTemplateOutlet=\"cardItem; context: { item: person }\"></ng-container>\n }\n </ul>\n </section>\n }\n }\n }\n </bmb-tabs>\n @if (\n !computedResults().persons.length && !computedResults().services.length && !isLoading()\n ) {\n <bmb-search-card-empty-state\n [inputHasValue]=\"!!inputSearchControl.value\"\n ></bmb-search-card-empty-state>\n }\n {{ isLoading() ? 'Loading...' : '' }}\n </bmb-home-card>\n</section>\n\n<ng-template #cardItem let-item=\"item\">\n <li class=\"bmb_search-card-results-list-item\">\n <bmb-search-card-item\n [name]=\"item.name\"\n [subtitle]=\"item.subtitle\"\n [icon]=\"item.avatarOrIcon\"\n [isService]=\"false\"\n (triggerClick)=\"searchItemClick.emit(item)\"\n ></bmb-search-card-item>\n </li>\n</ng-template>\n", styles: [".bmb_search-card-results-list{padding:0;margin:0;list-style:none}.bmb_search-card-results-section{padding-block-start:var(--bmb-spacing-l)}\n"] }]
71
+ }], ctorParameters: () => [{ type: i1.BmbTranslationsService }] });
72
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bmb-search-card.component.js","sourceRoot":"","sources":["../../../../../../projects/ds-ng/src/lib/components/bmb-search-card/bmb-search-card.component.ts","../../../../../../projects/ds-ng/src/lib/components/bmb-search-card/bmb-search-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAE,oBAAoB,EAAE,MAAM,0CAA0C,CAAC;AAChF,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAW,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gCAAgC,EAAE,MAAM,qEAAqE,CAAC;AAEvH,OAAO,EAAE,0BAA0B,EAAE,MAAM,uDAAuD,CAAC;;;;AA4BnG,MAAM,OAAO,sBAAsB;IAkDjC,YAAoB,mBAA2C;QAA3C,wBAAmB,GAAnB,mBAAmB,CAAwB;QAjD/D,UAAK,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAC1B,qBAAgB,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QACrC,YAAO,GAAG,KAAK,CAA6B,EAAE,CAAC,CAAC;QAChD,cAAS,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAElC,kBAAa,GAAG,KAAK,CAAS,CAAC,CAAC,CAAC;QAEjC,kBAAa,GAAG,MAAM,EAAU,CAAC;QACjC,oBAAe,GAAG,MAAM,EAA4B,CAAC;QAErD,uBAAkB,GAAG,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;QACzC,oBAAe,GAAG,QAAQ,CAGvB,GAAG,EAAE;YACN,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,CAC1B,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;gBACZ,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;oBAC5B,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC1B,CAAC;qBAAM,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;oBAClC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACzB,CAAC;gBACD,OAAO,GAAG,CAAC;YACb,CAAC,EACD,EAAE,QAAQ,EAAE,EAAE,EAAE,OAAO,EAAE,EAAE,EAG1B,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,aAAQ,GAAG,QAAQ,CAAY,GAAG,EAAE,CAAC;YACnC;gBACE,EAAE,EAAE,CAAC;gBACL,KAAK,EAAE,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,sBAAsB,CAAC;gBACjE,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC,QAAQ,CAAC,MAAM;gBACrF,QAAQ,EAAE,IAAI;aACf;YACD;gBACE,EAAE,EAAE,CAAC;gBACL,KAAK,EAAE,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,2BAA2B,CAAC;gBACtE,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,QAAQ,CAAC,MAAM;aAC9C;YACD;gBACE,EAAE,EAAE,CAAC;gBACL,KAAK,EAAE,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,yBAAyB,CAAC;gBACpE,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC,OAAO,CAAC,MAAM;aAC7C;SACF,CAAC,CAAC;QAGD,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACvD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;+GAtDU,sBAAsB;mGAAtB,sBAAsB,i3BCrCnC,wkHA+FA,uMDrEI,oBAAoB,uVACpB,aAAa,kDACb,iBAAiB,kjBACjB,gBAAgB,qKAChB,YAAY,oSACZ,gCAAgC,mGAChC,0BAA0B;;4FAKjB,sBAAsB;kBAflC,SAAS;+BACE,iBAAiB,cACf,IAAI,WACP;wBACP,oBAAoB;wBACpB,aAAa;wBACb,iBAAiB;wBACjB,gBAAgB;wBAChB,YAAY;wBACZ,gCAAgC;wBAChC,0BAA0B;qBAC3B","sourcesContent":["import { Component, computed, input, model, output } from '@angular/core';\nimport { BmbHomeCardComponent } from '../bmb-home-card/bmb-home-card.component';\nimport { TranslatePipe } from '../../pipes/translations';\nimport { BmbInputComponent } from '../bmb-input/bmb-input.component';\nimport { BmbTabsComponent, IBmbTab } from '../bmb-tabs/bmb-tabs.component';\nimport { FormControl } from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { BmbSearchCardEmptyStateComponent } from './bmb-search-card-empty-state/bmb-search-card-empty-state.component';\nimport { BmbTranslationsService } from '../../services/translations/translations.service';\nimport { BmbSearchCardItemComponent } from './bmb-search-card-item/bmb-search-card-item.component';\nimport { IBmbColor } from '../../types/colors';\n\nexport interface IBmbSearchCardItemResult {\n  id: string;\n  name: string;\n  subtitle: string;\n  avatarOrIcon: string;\n  backgroundColorIcon?: IBmbColor;\n  type: 'person' | 'service';\n  [key: string]: any;\n}\n\n@Component({\n  selector: 'bmb-search-card',\n  standalone: true,\n  imports: [\n    BmbHomeCardComponent,\n    TranslatePipe,\n    BmbInputComponent,\n    BmbTabsComponent,\n    CommonModule,\n    BmbSearchCardEmptyStateComponent,\n    BmbSearchCardItemComponent,\n  ],\n  templateUrl: './bmb-search-card.component.html',\n  styleUrl: './bmb-search-card.component.scss',\n})\nexport class BmbSearchCardComponent {\n  title = input<string>('');\n  inputPlaceholder = input<string>('');\n  results = input<IBmbSearchCardItemResult[]>([]);\n  isLoading = input<boolean>(false);\n\n  selectedTabId = model<number>(1);\n\n  triggerSearch = output<string>();\n  searchItemClick = output<IBmbSearchCardItemResult>();\n\n  inputSearchControl = new FormControl('');\n  computedResults = computed<{\n    services: IBmbSearchCardItemResult[];\n    persons: IBmbSearchCardItemResult[];\n  }>(() => {\n    return this.results().reduce(\n      (acc, item) => {\n        if (item.type === 'service') {\n          acc.services.push(item);\n        } else if (item.type === 'person') {\n          acc.persons.push(item);\n        }\n        return acc;\n      },\n      { services: [], persons: [] } as {\n        services: IBmbSearchCardItemResult[];\n        persons: IBmbSearchCardItemResult[];\n      },\n    );\n  });\n  tabsData = computed<IBmbTab[]>(() => [\n    {\n      id: 1,\n      title: this.translationsService.translate('search_card.tabs.all'),\n      badge: this.computedResults().persons.length + this.computedResults().services.length,\n      isActive: true,\n    },\n    {\n      id: 2,\n      title: this.translationsService.translate('search_card.tabs.services'),\n      badge: this.computedResults().services.length,\n    },\n    {\n      id: 3,\n      title: this.translationsService.translate('search_card.tabs.people'),\n      badge: this.computedResults().persons.length,\n    },\n  ]);\n\n  constructor(private translationsService: BmbTranslationsService) {\n    this.inputSearchControl.valueChanges.subscribe((value) => {\n      this.triggerSearch.emit(value || '');\n    });\n  }\n}\n","<section class=\"bmb_search-card\">\n  <bmb-home-card\n    [title]=\"title() || 'search_card.title' | translate\"\n    [showRightButton]=\"false\"\n    icon=\"search\"\n    bgIconAppearance=\"blue-primary\"\n  >\n    <bmb-input\n      [placeholder]=\"\n        inputPlaceholder() || 'search_card.input_placeholder' | translate\n      \"\n      [icon]=\"'search'\"\n      [isClearable]=\"true\"\n      [control]=\"inputSearchControl\"\n      [isLoading]=\"isLoading()\"\n    />\n    <section\n      class=\"bmb_search-card-results\"\n      [ngClass]=\"{\n        'bmb_search-card-results-active':\n          computedResults().persons.length && computedResults().services.length\n      }\"\n    ></section>\n    <bmb-tabs [tabs]=\"tabsData()\" [(selectedTabId)]=\"selectedTabId\">\n      @switch (selectedTabId()) {\n        @case (1) {\n          @if (computedResults().services.length) {\n            <section class=\"bmb_search-card-results-section\">\n              <h3>{{ 'search_card.tabs.services' | translate }}</h3>\n              <ul class=\"bmb_search-card-results-list\">\n                @for (service of computedResults().services; track $index) {\n                  <ng-container *ngTemplateOutlet=\"cardItem; context: { item: service }\"></ng-container>\n                }\n              </ul>\n            </section>\n          }\n          @if (computedResults().persons.length) {\n            <section class=\"bmb_search-card-results-section\">\n              <h3>{{ 'search_card.tabs.people' | translate }}</h3>\n              <ul class=\"bmb_search-card-results-list\">\n                @for (person of computedResults().persons; track $index) {\n                  <ng-container *ngTemplateOutlet=\"cardItem; context: { item: person }\"></ng-container>\n                }\n              </ul>\n            </section>\n          }\n        }\n        @case (2) {\n          @if (computedResults().services.length) {\n            <section class=\"bmb_search-card-results-section\">\n              <h3>{{ 'search_card.tabs.services' | translate }}</h3>\n              <ul class=\"bmb_search-card-results-list\">\n                @for (service of computedResults().services; track $index) {\n                  <ng-container *ngTemplateOutlet=\"cardItem; context: { item: service }\"></ng-container>\n                }\n              </ul>\n            </section>\n          }\n        }\n        @case (3) {\n          @if (computedResults().persons.length) {\n            <section class=\"bmb_search-card-results-section\">\n              <h3>{{ 'search_card.tabs.people' | translate }}</h3>\n              <ul class=\"bmb_search-card-results-list\">\n                @for (person of computedResults().persons; track $index) {\n                  <ng-container *ngTemplateOutlet=\"cardItem; context: { item: person }\"></ng-container>\n                }\n              </ul>\n            </section>\n          }\n        }\n      }\n    </bmb-tabs>\n    @if (\n      !computedResults().persons.length && !computedResults().services.length && !isLoading()\n    ) {\n      <bmb-search-card-empty-state\n        [inputHasValue]=\"!!inputSearchControl.value\"\n      ></bmb-search-card-empty-state>\n    }\n    {{ isLoading() ? 'Loading...' : '' }}\n  </bmb-home-card>\n</section>\n\n<ng-template #cardItem let-item=\"item\">\n  <li class=\"bmb_search-card-results-list-item\">\n    <bmb-search-card-item\n      [name]=\"item.name\"\n      [subtitle]=\"item.subtitle\"\n      [icon]=\"item.avatarOrIcon\"\n      [isService]=\"false\"\n      (triggerClick)=\"searchItemClick.emit(item)\"\n    ></bmb-search-card-item>\n  </li>\n</ng-template>\n"]}
@@ -114,7 +114,7 @@ export class BmbSearchInputComponent {
114
114
  }
115
115
  }
116
116
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BmbSearchInputComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
117
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.14", type: BmbSearchInputComponent, isStandalone: true, selector: "bmb-search-input", inputs: { inputId: { classPropertyName: "inputId", publicName: "inputId", isSignal: true, isRequired: false, transformFunction: null }, name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: false, transformFunction: null }, isLoading: { classPropertyName: "isLoading", publicName: "isLoading", isSignal: true, isRequired: false, transformFunction: null }, isServerSideFilter: { classPropertyName: "isServerSideFilter", publicName: "isServerSideFilter", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, serverSideFilteredData: { classPropertyName: "serverSideFilteredData", publicName: "serverSideFilteredData", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onValueChange: "onValueChange", onServerSideFilterEvent: "onServerSideFilterEvent", onClearField: "onClearField" }, usesOnChanges: true, ngImport: i0, template: "<section class=\"bmb_search-input\">\n <section\n class=\"bmb_search-input-container\"\n clickOutside\n (clickOutside)=\"closeList()\"\n >\n <bmb-input-content\n class=\"bmb_search-input-field\"\n [inputId]=\"inputId()\"\n [name]=\"name()\"\n icon=\"search\"\n [control]=\"filterControl\"\n [placeholder]=\"placeholder()\"\n [isClearable]=\"true\"\n (keydown)=\"handleKeyDown($event)\"\n (click)=\"handleItemClick()\"\n (clearEvent)=\"handleClearFilter()\"\n />\n <dialog [open]=\"isDialogOpen\" class=\"bmb_generic-dialog\">\n <bmb-dropdown-content\n class=\"bmb_search-input-dialog\"\n name=\"list\"\n [selectedOption]=\"filterControl.value\"\n [(items)]=\"filteredData\"\n [(isOpen)]=\"isDialogOpen\"\n />\n </dialog>\n </section>\n</section>\n", styles: [".bmb_search-input{padding-bottom:var(--bmb-spacing-s)}.bmb_search-input-container{position:relative}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: ClickOutsideDirective, selector: "[clickOutside]", outputs: ["clickOutside"] }, { kind: "component", type: BmbInputContentComponent, selector: "bmb-input-content", inputs: ["type", "placeholder", "icon", "appearance", "isRequired", "name", "spellcheck", "heightTextArea", "maxLength", "minLength", "pattern", "max", "min", "inputId", "autoComplete", "rows", "isReadOnly", "additionalAction", "isClearable", "isError", "isHidden", "showStates", "control"], outputs: ["controlChange", "onFocus", "onBlur", "onChange", "onKeyDown", "onKeyUp", "clearEvent"] }, { kind: "component", type: BmbDropdownContentComponent, selector: "bmb-dropdown-content", inputs: ["selectedOption", "items", "isKeyboardEvent", "enableFilter", "customFilterFunction", "isOpen"], outputs: ["itemsChange", "isKeyboardEventChange", "clickedItem", "isOpenChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
117
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.14", type: BmbSearchInputComponent, isStandalone: true, selector: "bmb-search-input", inputs: { inputId: { classPropertyName: "inputId", publicName: "inputId", isSignal: true, isRequired: false, transformFunction: null }, name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: false, transformFunction: null }, isLoading: { classPropertyName: "isLoading", publicName: "isLoading", isSignal: true, isRequired: false, transformFunction: null }, isServerSideFilter: { classPropertyName: "isServerSideFilter", publicName: "isServerSideFilter", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, serverSideFilteredData: { classPropertyName: "serverSideFilteredData", publicName: "serverSideFilteredData", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onValueChange: "onValueChange", onServerSideFilterEvent: "onServerSideFilterEvent", onClearField: "onClearField" }, usesOnChanges: true, ngImport: i0, template: "<section class=\"bmb_search-input\">\n <section\n class=\"bmb_search-input-container\"\n clickOutside\n (clickOutside)=\"closeList()\"\n >\n <bmb-input-content\n class=\"bmb_search-input-field\"\n [inputId]=\"inputId()\"\n [name]=\"name()\"\n icon=\"search\"\n [control]=\"filterControl\"\n [placeholder]=\"placeholder()\"\n [isClearable]=\"true\"\n (keydown)=\"handleKeyDown($event)\"\n (click)=\"handleItemClick()\"\n (clearEvent)=\"handleClearFilter()\"\n />\n <dialog [open]=\"isDialogOpen\" class=\"bmb_generic-dialog\">\n <bmb-dropdown-content\n class=\"bmb_search-input-dialog\"\n name=\"list\"\n [selectedOption]=\"filterControl.value\"\n [(items)]=\"filteredData\"\n [(isOpen)]=\"isDialogOpen\"\n />\n </dialog>\n </section>\n</section>\n", styles: [".bmb_search-input{padding-bottom:var(--bmb-spacing-s)}.bmb_search-input-container{position:relative}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: ClickOutsideDirective, selector: "[clickOutside]", outputs: ["clickOutside"] }, { kind: "component", type: BmbInputContentComponent, selector: "bmb-input-content", inputs: ["type", "placeholder", "icon", "appearance", "isRequired", "name", "spellcheck", "heightTextArea", "maxLength", "minLength", "pattern", "max", "min", "inputId", "autoComplete", "rows", "isReadOnly", "additionalAction", "isClearable", "isError", "isHidden", "showStates", "isLoading", "control"], outputs: ["controlChange", "onFocus", "onBlur", "onChange", "onKeyDown", "onKeyUp", "clearEvent"] }, { kind: "component", type: BmbDropdownContentComponent, selector: "bmb-dropdown-content", inputs: ["selectedOption", "items", "isKeyboardEvent", "enableFilter", "customFilterFunction", "isOpen"], outputs: ["itemsChange", "isKeyboardEventChange", "clickedItem", "isOpenChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
118
118
  }
119
119
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BmbSearchInputComponent, decorators: [{
120
120
  type: Component,
@@ -126,4 +126,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
126
126
  BmbDropdownContentComponent,
127
127
  ], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<section class=\"bmb_search-input\">\n <section\n class=\"bmb_search-input-container\"\n clickOutside\n (clickOutside)=\"closeList()\"\n >\n <bmb-input-content\n class=\"bmb_search-input-field\"\n [inputId]=\"inputId()\"\n [name]=\"name()\"\n icon=\"search\"\n [control]=\"filterControl\"\n [placeholder]=\"placeholder()\"\n [isClearable]=\"true\"\n (keydown)=\"handleKeyDown($event)\"\n (click)=\"handleItemClick()\"\n (clearEvent)=\"handleClearFilter()\"\n />\n <dialog [open]=\"isDialogOpen\" class=\"bmb_generic-dialog\">\n <bmb-dropdown-content\n class=\"bmb_search-input-dialog\"\n name=\"list\"\n [selectedOption]=\"filterControl.value\"\n [(items)]=\"filteredData\"\n [(isOpen)]=\"isDialogOpen\"\n />\n </dialog>\n </section>\n</section>\n", styles: [".bmb_search-input{padding-bottom:var(--bmb-spacing-s)}.bmb_search-input-container{position:relative}\n"] }]
128
128
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }] });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bmb-search-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ds-ng/src/lib/components/bmb-search-input/bmb-search-input.component.ts","../../../../../../projects/ds-ng/src/lib/components/bmb-search-input/bmb-search-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,iBAAiB,EACjB,uBAAuB,EAEvB,KAAK,EACL,MAAM,GAIP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAC3G,OAAO,EAAE,wBAAwB,EAAE,MAAM,4DAA4D,CAAC;AACtG,OAAO,EAAE,qBAAqB,EAAE,MAAM,+CAA+C,CAAC;AAEtF,OAAO,EAAE,uBAAuB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;;AAiB9E,MAAM,OAAO,uBAAuB;IAoBlC,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QAnB1C,YAAO,GAAG,KAAK,CAAS,OAAO,EAAE,CAAC,CAAC;QACnC,SAAI,GAAG,KAAK,CAAS,OAAO,EAAE,CAAC,CAAC;QAChC,SAAI,GAAG,KAAK,CAAW,EAAE,CAAC,CAAC;QAC3B,cAAS,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAClC,uBAAkB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAC3C,gBAAW,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAChC,2BAAsB,GAAG,KAAK,CAAW,EAAE,CAAC,CAAC;QAE7C,kBAAa,GAAG,MAAM,EAAU,CAAC;QACjC,4BAAuB,GAAG,MAAM,EAAU,CAAC;QAC3C,iBAAY,GAAG,MAAM,EAAW,CAAC;QAEjC,UAAK,GAAW,EAAE,CAAC;QACnB,iBAAY,GAAoB,EAAE,CAAC;QACnC,QAAG,GAAW,OAAO,EAAE,CAAC;QACxB,iBAAY,GAAY,KAAK,CAAC;QAC9B,kBAAa,GAAG,IAAI,WAAW,EAAE,CAAC;QAClC,UAAK,GAAoB,EAAE,CAAC;IAEiB,CAAC;IAE9C,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,YAAY;aAC5B,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;aACvB,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YACrD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,wBAAwB,CAAC,IAAI,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;YACnE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC,YAAY,CAAC,CAAC;QACnE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAChC,CAAC;QACD,IACE,OAAO,CAAC,wBAAwB,CAAC;YACjC,OAAO,CAAC,WAAW,CAAC;YACpB,IAAI,CAAC,kBAAkB,EAAE,EACzB,CAAC;YACD,IAAI,CAAC,YAAY;gBACf,OAAO,CAAC,wBAAwB,CAAC,EAAE,YAAY,EAAE,MAAM;oBACvD,OAAO,CAAC,WAAW,CAAC,EAAE,YAAY,CAAC;QACvC,CAAC;QAED,IAAI,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;YACzB,IAAI,OAAO,CAAC,WAAW,CAAC,EAAE,YAAY,EAAE,CAAC;gBACvC,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC;YAC9B,CAAC;QACH,CAAC;IACH,CAAC;IAED,WAAW,CAAC,IAAc;QACxB,IAAI,CAAC,KAAK,GAAG,uBAAuB,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAsB,EAAE,EAAE;YACrD,OAAO;gBACL,GAAG,OAAO;gBACV,MAAM,EAAE,GAAG,EAAE;oBACX,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;gBACjC,CAAC;aACe,CAAC;QACrB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,SAAS;QACP,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IAED,gBAAgB,CAAC,OAAsB;QACrC,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAEnC,IAAI,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;YAC9B,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAM,CAAC,CAAC;QAC5C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAM,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;IACzC,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,aAAa,CAAC,KAAoB;QAChC,MAAM,0BAA0B,GAAG,CAAC,GAAG,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC;QAC9D,MAAM,yBAAyB,GAAG,CAAC,OAAO,CAAC,CAAC;QAE5C,IAAI,0BAA0B,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;YACnD,IAAI,CAAC,IAAI,CAAC,YAAY;gBAAE,IAAI,CAAC,eAAe,EAAE,CAAC;YAE/C,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;gBAC9B,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,OAAO;YACT,CAAC;YACD,OAAO;QACT,CAAC;QAED,IAAI,yBAAyB,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;YAClD,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;gBAC/B,MAAM,cAAc,GAAW,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;gBAExD,IAAI,CAAC,CAAC,cAAc,EAAE,CAAC;oBACrB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC9C,CAAC;YACH,CAAC;YACD,OAAO;QACT,CAAC;IACH,CAAC;+GAtHU,uBAAuB;mGAAvB,uBAAuB,4qCCpCpC,o2BA6BA,+JDJI,YAAY,8BACZ,mBAAmB,+BACnB,qBAAqB,sFACrB,wBAAwB,qcACxB,2BAA2B;;4FAOlB,uBAAuB;kBAfnC,SAAS;+BACE,kBAAkB,cAChB,IAAI,WACP;wBACP,YAAY;wBACZ,mBAAmB;wBACnB,qBAAqB;wBACrB,wBAAwB;wBACxB,2BAA2B;qBAC5B,iBAGc,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM","sourcesContent":["import {\n  Component,\n  ViewEncapsulation,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  input,\n  output,\n  OnChanges,\n  SimpleChanges,\n  AfterViewInit,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { debounceTime } from 'rxjs/operators';\nimport { getUUID } from '../../utils/utils';\nimport { BmbDropdownContentComponent } from '../utils/bmb-dropdown-content/bmb-dropdown-content.component';\nimport { BmbInputContentComponent } from '../bmb-input/bmb-input-content/bmb-input-content.component';\nimport { ClickOutsideDirective } from '../../directives/utils/clickoutside.directive';\nimport { IDropdownItem } from '../../types';\nimport { convertListToSelectList, filteredValue } from '../../utils/dropdown';\n\n@Component({\n  selector: 'bmb-search-input',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    ClickOutsideDirective,\n    BmbInputContentComponent,\n    BmbDropdownContentComponent,\n  ],\n  templateUrl: './bmb-search-input.component.html',\n  styleUrl: './bmb-search-input.component.scss',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BmbSearchInputComponent implements AfterViewInit, OnChanges {\n  inputId = input<string>(getUUID());\n  name = input<string>(getUUID());\n  data = input<string[]>([]);\n  isLoading = input<boolean>(false);\n  isServerSideFilter = input<boolean>(false);\n  placeholder = input<string>('');\n  serverSideFilteredData = input<string[]>([]);\n\n  onValueChange = output<string>();\n  onServerSideFilterEvent = output<string>();\n  onClearField = output<boolean>();\n\n  value: string = '';\n  filteredData: IDropdownItem[] = [];\n  uid: string = getUUID();\n  isDialogOpen: boolean = false;\n  filterControl = new FormControl();\n  items: IDropdownItem[] = [];\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngAfterViewInit(): void {\n    this.filterControl.valueChanges\n      .pipe(debounceTime(300))\n      .subscribe((value) => {\n        this.filteredData = filteredValue(value, this.items);\n        this.cdr.detectChanges();\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['serverSideFilteredData'] && this.isServerSideFilter()) {\n      this.initOptions(changes['serverSideFilteredData'].currentValue);\n    } else {\n      this.initOptions(this.data());\n    }\n    if (\n      changes['serverSideFilteredData'] &&\n      changes['isLoading'] &&\n      this.isServerSideFilter()\n    ) {\n      this.isDialogOpen =\n        changes['serverSideFilteredData']?.currentValue?.length ||\n        changes['isLoading']?.currentValue;\n    }\n\n    if (changes['isLoading']) {\n      if (changes['isLoading']?.currentValue) {\n        this.filterControl.disable();\n      } else {\n        this.filterControl.enable();\n      }\n    }\n  }\n\n  initOptions(list: string[]): void {\n    this.items = convertListToSelectList(list);\n    this.items = this.items.map((element: IDropdownItem) => {\n      return {\n        ...element,\n        action: () => {\n          this.setSelectedValue(element);\n        },\n      } as IDropdownItem;\n    });\n\n    this.filteredData = [...this.items];\n  }\n\n  closeList() {\n    this.isDialogOpen = false;\n  }\n\n  setSelectedValue(element: IDropdownItem): void {\n    const value = element.value;\n    this.filterControl.setValue(value);\n\n    if (this.isServerSideFilter()) {\n      this.onServerSideFilterEvent.emit(value!);\n    } else {\n      this.onValueChange.emit(value!);\n    }\n  }\n\n  handleItemClick(): void {\n    this.isDialogOpen = !this.isDialogOpen;\n  }\n\n  handleClearFilter(): void {\n    this.onClearField.emit(true);\n  }\n\n  handleKeyDown(event: KeyboardEvent) {\n    const keyboardValuesToOpenDialog = [' ', 'ArrowDown', 'Down'];\n    const keyboardValuesToAddOption = ['Enter'];\n\n    if (keyboardValuesToOpenDialog.includes(event.key)) {\n      if (!this.isDialogOpen) this.handleItemClick();\n\n      if (!this.filteredData.length) {\n        event.preventDefault();\n        return;\n      }\n      return;\n    }\n\n    if (keyboardValuesToAddOption.includes(event.key)) {\n      event.preventDefault();\n      if (!!this.filterControl.value) {\n        const selectedLength: number = this.filteredData.length;\n\n        if (!!selectedLength) {\n          this.setSelectedValue(this.filteredData[0]);\n        }\n      }\n      return;\n    }\n  }\n}\n","<section class=\"bmb_search-input\">\n  <section\n    class=\"bmb_search-input-container\"\n    clickOutside\n    (clickOutside)=\"closeList()\"\n  >\n    <bmb-input-content\n      class=\"bmb_search-input-field\"\n      [inputId]=\"inputId()\"\n      [name]=\"name()\"\n      icon=\"search\"\n      [control]=\"filterControl\"\n      [placeholder]=\"placeholder()\"\n      [isClearable]=\"true\"\n      (keydown)=\"handleKeyDown($event)\"\n      (click)=\"handleItemClick()\"\n      (clearEvent)=\"handleClearFilter()\"\n    />\n    <dialog [open]=\"isDialogOpen\" class=\"bmb_generic-dialog\">\n      <bmb-dropdown-content\n        class=\"bmb_search-input-dialog\"\n        name=\"list\"\n        [selectedOption]=\"filterControl.value\"\n        [(items)]=\"filteredData\"\n        [(isOpen)]=\"isDialogOpen\"\n      />\n    </dialog>\n  </section>\n</section>\n"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bmb-search-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ds-ng/src/lib/components/bmb-search-input/bmb-search-input.component.ts","../../../../../../projects/ds-ng/src/lib/components/bmb-search-input/bmb-search-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,iBAAiB,EACjB,uBAAuB,EAEvB,KAAK,EACL,MAAM,GAIP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAC5C,OAAO,EAAE,2BAA2B,EAAE,MAAM,8DAA8D,CAAC;AAC3G,OAAO,EAAE,wBAAwB,EAAE,MAAM,4DAA4D,CAAC;AACtG,OAAO,EAAE,qBAAqB,EAAE,MAAM,+CAA+C,CAAC;AAEtF,OAAO,EAAE,uBAAuB,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;;AAiB9E,MAAM,OAAO,uBAAuB;IAoBlC,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QAnB1C,YAAO,GAAG,KAAK,CAAS,OAAO,EAAE,CAAC,CAAC;QACnC,SAAI,GAAG,KAAK,CAAS,OAAO,EAAE,CAAC,CAAC;QAChC,SAAI,GAAG,KAAK,CAAW,EAAE,CAAC,CAAC;QAC3B,cAAS,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAClC,uBAAkB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;QAC3C,gBAAW,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;QAChC,2BAAsB,GAAG,KAAK,CAAW,EAAE,CAAC,CAAC;QAE7C,kBAAa,GAAG,MAAM,EAAU,CAAC;QACjC,4BAAuB,GAAG,MAAM,EAAU,CAAC;QAC3C,iBAAY,GAAG,MAAM,EAAW,CAAC;QAEjC,UAAK,GAAW,EAAE,CAAC;QACnB,iBAAY,GAAoB,EAAE,CAAC;QACnC,QAAG,GAAW,OAAO,EAAE,CAAC;QACxB,iBAAY,GAAY,KAAK,CAAC;QAC9B,kBAAa,GAAG,IAAI,WAAW,EAAE,CAAC;QAClC,UAAK,GAAoB,EAAE,CAAC;IAEiB,CAAC;IAE9C,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,YAAY;aAC5B,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;aACvB,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YACrD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,wBAAwB,CAAC,IAAI,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;YACnE,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,wBAAwB,CAAC,CAAC,YAAY,CAAC,CAAC;QACnE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAChC,CAAC;QACD,IACE,OAAO,CAAC,wBAAwB,CAAC;YACjC,OAAO,CAAC,WAAW,CAAC;YACpB,IAAI,CAAC,kBAAkB,EAAE,EACzB,CAAC;YACD,IAAI,CAAC,YAAY;gBACf,OAAO,CAAC,wBAAwB,CAAC,EAAE,YAAY,EAAE,MAAM;oBACvD,OAAO,CAAC,WAAW,CAAC,EAAE,YAAY,CAAC;QACvC,CAAC;QAED,IAAI,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;YACzB,IAAI,OAAO,CAAC,WAAW,CAAC,EAAE,YAAY,EAAE,CAAC;gBACvC,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;YAC/B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC;YAC9B,CAAC;QACH,CAAC;IACH,CAAC;IAED,WAAW,CAAC,IAAc;QACxB,IAAI,CAAC,KAAK,GAAG,uBAAuB,CAAC,IAAI,CAAC,CAAC;QAC3C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAsB,EAAE,EAAE;YACrD,OAAO;gBACL,GAAG,OAAO;gBACV,MAAM,EAAE,GAAG,EAAE;oBACX,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;gBACjC,CAAC;aACe,CAAC;QACrB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAED,SAAS;QACP,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IAED,gBAAgB,CAAC,OAAsB;QACrC,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAEnC,IAAI,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;YAC9B,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAM,CAAC,CAAC;QAC5C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAM,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;IACzC,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,aAAa,CAAC,KAAoB;QAChC,MAAM,0BAA0B,GAAG,CAAC,GAAG,EAAE,WAAW,EAAE,MAAM,CAAC,CAAC;QAC9D,MAAM,yBAAyB,GAAG,CAAC,OAAO,CAAC,CAAC;QAE5C,IAAI,0BAA0B,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;YACnD,IAAI,CAAC,IAAI,CAAC,YAAY;gBAAE,IAAI,CAAC,eAAe,EAAE,CAAC;YAE/C,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;gBAC9B,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,OAAO;YACT,CAAC;YACD,OAAO;QACT,CAAC;QAED,IAAI,yBAAyB,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;YAClD,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;gBAC/B,MAAM,cAAc,GAAW,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;gBAExD,IAAI,CAAC,CAAC,cAAc,EAAE,CAAC;oBACrB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC9C,CAAC;YACH,CAAC;YACD,OAAO;QACT,CAAC;IACH,CAAC;+GAtHU,uBAAuB;mGAAvB,uBAAuB,4qCCpCpC,o2BA6BA,+JDJI,YAAY,8BACZ,mBAAmB,+BACnB,qBAAqB,sFACrB,wBAAwB,kdACxB,2BAA2B;;4FAOlB,uBAAuB;kBAfnC,SAAS;+BACE,kBAAkB,cAChB,IAAI,WACP;wBACP,YAAY;wBACZ,mBAAmB;wBACnB,qBAAqB;wBACrB,wBAAwB;wBACxB,2BAA2B;qBAC5B,iBAGc,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM","sourcesContent":["import {\n  Component,\n  ViewEncapsulation,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  input,\n  output,\n  OnChanges,\n  SimpleChanges,\n  AfterViewInit,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { debounceTime } from 'rxjs/operators';\nimport { getUUID } from '../../utils/utils';\nimport { BmbDropdownContentComponent } from '../utils/bmb-dropdown-content/bmb-dropdown-content.component';\nimport { BmbInputContentComponent } from '../bmb-input/bmb-input-content/bmb-input-content.component';\nimport { ClickOutsideDirective } from '../../directives/utils/clickoutside.directive';\nimport { IDropdownItem } from '../../types';\nimport { convertListToSelectList, filteredValue } from '../../utils/dropdown';\n\n@Component({\n  selector: 'bmb-search-input',\n  standalone: true,\n  imports: [\n    CommonModule,\n    ReactiveFormsModule,\n    ClickOutsideDirective,\n    BmbInputContentComponent,\n    BmbDropdownContentComponent,\n  ],\n  templateUrl: './bmb-search-input.component.html',\n  styleUrl: './bmb-search-input.component.scss',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BmbSearchInputComponent implements AfterViewInit, OnChanges {\n  inputId = input<string>(getUUID());\n  name = input<string>(getUUID());\n  data = input<string[]>([]);\n  isLoading = input<boolean>(false);\n  isServerSideFilter = input<boolean>(false);\n  placeholder = input<string>('');\n  serverSideFilteredData = input<string[]>([]);\n\n  onValueChange = output<string>();\n  onServerSideFilterEvent = output<string>();\n  onClearField = output<boolean>();\n\n  value: string = '';\n  filteredData: IDropdownItem[] = [];\n  uid: string = getUUID();\n  isDialogOpen: boolean = false;\n  filterControl = new FormControl();\n  items: IDropdownItem[] = [];\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngAfterViewInit(): void {\n    this.filterControl.valueChanges\n      .pipe(debounceTime(300))\n      .subscribe((value) => {\n        this.filteredData = filteredValue(value, this.items);\n        this.cdr.detectChanges();\n      });\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['serverSideFilteredData'] && this.isServerSideFilter()) {\n      this.initOptions(changes['serverSideFilteredData'].currentValue);\n    } else {\n      this.initOptions(this.data());\n    }\n    if (\n      changes['serverSideFilteredData'] &&\n      changes['isLoading'] &&\n      this.isServerSideFilter()\n    ) {\n      this.isDialogOpen =\n        changes['serverSideFilteredData']?.currentValue?.length ||\n        changes['isLoading']?.currentValue;\n    }\n\n    if (changes['isLoading']) {\n      if (changes['isLoading']?.currentValue) {\n        this.filterControl.disable();\n      } else {\n        this.filterControl.enable();\n      }\n    }\n  }\n\n  initOptions(list: string[]): void {\n    this.items = convertListToSelectList(list);\n    this.items = this.items.map((element: IDropdownItem) => {\n      return {\n        ...element,\n        action: () => {\n          this.setSelectedValue(element);\n        },\n      } as IDropdownItem;\n    });\n\n    this.filteredData = [...this.items];\n  }\n\n  closeList() {\n    this.isDialogOpen = false;\n  }\n\n  setSelectedValue(element: IDropdownItem): void {\n    const value = element.value;\n    this.filterControl.setValue(value);\n\n    if (this.isServerSideFilter()) {\n      this.onServerSideFilterEvent.emit(value!);\n    } else {\n      this.onValueChange.emit(value!);\n    }\n  }\n\n  handleItemClick(): void {\n    this.isDialogOpen = !this.isDialogOpen;\n  }\n\n  handleClearFilter(): void {\n    this.onClearField.emit(true);\n  }\n\n  handleKeyDown(event: KeyboardEvent) {\n    const keyboardValuesToOpenDialog = [' ', 'ArrowDown', 'Down'];\n    const keyboardValuesToAddOption = ['Enter'];\n\n    if (keyboardValuesToOpenDialog.includes(event.key)) {\n      if (!this.isDialogOpen) this.handleItemClick();\n\n      if (!this.filteredData.length) {\n        event.preventDefault();\n        return;\n      }\n      return;\n    }\n\n    if (keyboardValuesToAddOption.includes(event.key)) {\n      event.preventDefault();\n      if (!!this.filterControl.value) {\n        const selectedLength: number = this.filteredData.length;\n\n        if (!!selectedLength) {\n          this.setSelectedValue(this.filteredData[0]);\n        }\n      }\n      return;\n    }\n  }\n}\n","<section class=\"bmb_search-input\">\n  <section\n    class=\"bmb_search-input-container\"\n    clickOutside\n    (clickOutside)=\"closeList()\"\n  >\n    <bmb-input-content\n      class=\"bmb_search-input-field\"\n      [inputId]=\"inputId()\"\n      [name]=\"name()\"\n      icon=\"search\"\n      [control]=\"filterControl\"\n      [placeholder]=\"placeholder()\"\n      [isClearable]=\"true\"\n      (keydown)=\"handleKeyDown($event)\"\n      (click)=\"handleItemClick()\"\n      (clearEvent)=\"handleClearFilter()\"\n    />\n    <dialog [open]=\"isDialogOpen\" class=\"bmb_generic-dialog\">\n      <bmb-dropdown-content\n        class=\"bmb_search-input-dialog\"\n        name=\"list\"\n        [selectedOption]=\"filterControl.value\"\n        [(items)]=\"filteredData\"\n        [(isOpen)]=\"isDialogOpen\"\n      />\n    </dialog>\n  </section>\n</section>\n"]}