@marcura/marcura-combobox 4.6.2 → 6.0.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.
- package/esm2020/lib/combobox.module.mjs +103 -0
- package/esm2020/lib/components/abstract-combobox/abstract-combobox.component.mjs +241 -0
- package/esm2020/lib/components/abstract-dropdown/abstract-dropdown.component.mjs +227 -0
- package/esm2020/lib/components/combobox/combobox.component.mjs +359 -0
- package/esm2020/lib/components/combobox-popup-footer/combobox-popup-footer.component.mjs +38 -0
- package/esm2020/lib/components/dropdown/dropdown.component.mjs +232 -0
- package/esm2020/lib/components/multiselect/multiselect.component.mjs +244 -0
- package/esm2020/lib/directives/combobox-item-template.directive.mjs +13 -0
- package/esm2020/lib/directives/dropdown-item-template.directive.mjs +13 -0
- package/esm2020/lib/directives/dropdown-value-template.directive.mjs +13 -0
- package/esm2020/lib/directives/multiselect-item-template.directive.mjs +13 -0
- package/esm2020/lib/directives/multiselect-tag-template.directive.mjs +13 -0
- package/esm2020/lib/directives/multiselect-tag-wrapper.directive.mjs +60 -0
- package/{esm2015/lib/model/combobox-kendo-component.interface.js → esm2020/lib/model/combobox-kendo-component.interface.mjs} +1 -0
- package/{esm2015/lib/model/combobox-localization.interface.js → esm2020/lib/model/combobox-localization.interface.mjs} +1 -0
- package/esm2020/lib/model/combobox-search-fn.type.mjs +2 -0
- package/{esm2015/lib/model/combobox-search-settings.interface.js → esm2020/lib/model/combobox-search-settings.interface.mjs} +1 -0
- package/{esm2015/lib/model/dropdown-kendo-component.interface.js → esm2020/lib/model/dropdown-kendo-component.interface.mjs} +1 -0
- package/{esm2015/lib/model/dropdown-localization.interface.js → esm2020/lib/model/dropdown-localization.interface.mjs} +1 -0
- package/{esm2015/lib/model/dropdown-localizer.interface.js → esm2020/lib/model/dropdown-localizer.interface.mjs} +1 -0
- package/{esm2015/lib/model/multiselect-localization.interface.js → esm2020/lib/model/multiselect-localization.interface.mjs} +1 -0
- package/fesm2015/marcura-marcura-combobox.mjs +1522 -0
- package/fesm2015/marcura-marcura-combobox.mjs.map +1 -0
- package/fesm2020/marcura-marcura-combobox.mjs +1517 -0
- package/fesm2020/marcura-marcura-combobox.mjs.map +1 -0
- package/{marcura-marcura-combobox.d.ts → index.d.ts} +1 -0
- package/lib/combobox.module.d.ts +21 -0
- package/lib/components/abstract-combobox/abstract-combobox.component.d.ts +19 -12
- package/lib/components/abstract-dropdown/abstract-dropdown.component.d.ts +16 -10
- package/lib/components/combobox/combobox.component.d.ts +8 -6
- package/lib/components/combobox-popup-footer/combobox-popup-footer.component.d.ts +3 -0
- package/lib/components/dropdown/dropdown.component.d.ts +8 -6
- package/lib/components/multiselect/multiselect.component.d.ts +11 -9
- package/lib/directives/combobox-item-template.directive.d.ts +3 -0
- package/lib/directives/dropdown-item-template.directive.d.ts +3 -0
- package/lib/directives/dropdown-value-template.directive.d.ts +3 -0
- package/lib/directives/multiselect-item-template.directive.d.ts +3 -0
- package/lib/directives/multiselect-tag-template.directive.d.ts +3 -0
- package/lib/directives/multiselect-tag-wrapper.directive.d.ts +3 -0
- package/lib/model/combobox-search-fn.type.d.ts +2 -1
- package/package.json +29 -17
- package/bundles/marcura-marcura-combobox.umd.js +0 -1850
- package/bundles/marcura-marcura-combobox.umd.js.map +0 -1
- package/bundles/marcura-marcura-combobox.umd.min.js +0 -2
- package/bundles/marcura-marcura-combobox.umd.min.js.map +0 -1
- package/esm2015/lib/combobox.module.js +0 -61
- package/esm2015/lib/components/abstract-combobox/abstract-combobox.component.js +0 -226
- package/esm2015/lib/components/abstract-dropdown/abstract-dropdown.component.js +0 -205
- package/esm2015/lib/components/combobox/combobox.component.js +0 -289
- package/esm2015/lib/components/combobox-popup-footer/combobox-popup-footer.component.js +0 -27
- package/esm2015/lib/components/dropdown/dropdown.component.js +0 -166
- package/esm2015/lib/components/multiselect/multiselect.component.js +0 -180
- package/esm2015/lib/directives/combobox-item-template.directive.js +0 -9
- package/esm2015/lib/directives/dropdown-item-template.directive.js +0 -9
- package/esm2015/lib/directives/dropdown-value-template.directive.js +0 -9
- package/esm2015/lib/directives/multiselect-item-template.directive.js +0 -9
- package/esm2015/lib/directives/multiselect-tag-template.directive.js +0 -9
- package/esm2015/lib/directives/multiselect-tag-wrapper.directive.js +0 -59
- package/esm2015/lib/model/combobox-search-fn.type.js +0 -1
- package/fesm2015/marcura-marcura-combobox.js +0 -1229
- package/fesm2015/marcura-marcura-combobox.js.map +0 -1
- package/marcura-marcura-combobox.metadata.json +0 -1
- /package/{esm2015/lib/combobox.injectables.js → esm2020/lib/combobox.injectables.mjs} +0 -0
- /package/{esm2015/lib/model/combobox-changed.event.js → esm2020/lib/model/combobox-changed.event.mjs} +0 -0
- /package/{esm2015/lib/model/combobox-search-settings-operator.enum.js → esm2020/lib/model/combobox-search-settings-operator.enum.mjs} +0 -0
- /package/{esm2015/lib/model/dropdown-changed.event.js → esm2020/lib/model/dropdown-changed.event.mjs} +0 -0
- /package/{esm2015/lib/model/multiselect-changed.event.js → esm2020/lib/model/multiselect-changed.event.mjs} +0 -0
- /package/{esm2015/marcura-marcura-combobox.js → esm2020/marcura-marcura-combobox.mjs} +0 -0
- /package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { TagModule } from '@marcura/marcura-tag';
|
|
5
|
+
import { ComboBoxModule, DropDownListModule, MultiSelectModule } from '@progress/kendo-angular-dropdowns';
|
|
6
|
+
import { PopupModule, POPUP_CONTAINER } from '@progress/kendo-angular-popup';
|
|
7
|
+
import { ComboboxItemTemplateDirective } from '../lib/directives/combobox-item-template.directive';
|
|
8
|
+
import { DropdownItemTemplateDirective } from '../lib/directives/dropdown-item-template.directive';
|
|
9
|
+
import { DropdownValueTemplateDirective } from '../lib/directives/dropdown-value-template.directive';
|
|
10
|
+
import { MultiselectItemTemplateDirective } from '../lib/directives/multiselect-item-template.directive';
|
|
11
|
+
import { MultiselectTagTemplateDirective } from '../lib/directives/multiselect-tag-template.directive';
|
|
12
|
+
import { MultiselectTagWrapperDirective } from '../lib/directives/multiselect-tag-wrapper.directive';
|
|
13
|
+
import { AbstractComboboxComponent } from './components/abstract-combobox/abstract-combobox.component';
|
|
14
|
+
import { AbstractDropdownComponent } from './components/abstract-dropdown/abstract-dropdown.component';
|
|
15
|
+
import { ComboboxPopupFooterComponent } from './components/combobox-popup-footer/combobox-popup-footer.component';
|
|
16
|
+
import { ComboboxComponent } from './components/combobox/combobox.component';
|
|
17
|
+
import { DropdownComponent } from './components/dropdown/dropdown.component';
|
|
18
|
+
import { MultiselectComponent } from './components/multiselect/multiselect.component';
|
|
19
|
+
import * as i0 from "@angular/core";
|
|
20
|
+
const components = [
|
|
21
|
+
AbstractComboboxComponent,
|
|
22
|
+
AbstractDropdownComponent,
|
|
23
|
+
ComboboxComponent,
|
|
24
|
+
ComboboxPopupFooterComponent,
|
|
25
|
+
MultiselectComponent,
|
|
26
|
+
DropdownComponent,
|
|
27
|
+
];
|
|
28
|
+
const directives = [
|
|
29
|
+
ComboboxItemTemplateDirective,
|
|
30
|
+
MultiselectItemTemplateDirective,
|
|
31
|
+
MultiselectTagTemplateDirective,
|
|
32
|
+
MultiselectTagWrapperDirective,
|
|
33
|
+
DropdownItemTemplateDirective,
|
|
34
|
+
DropdownValueTemplateDirective,
|
|
35
|
+
];
|
|
36
|
+
export function getPopupContainer() {
|
|
37
|
+
return { nativeElement: document.body };
|
|
38
|
+
}
|
|
39
|
+
export class ComboboxModule {
|
|
40
|
+
}
|
|
41
|
+
ComboboxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ComboboxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
42
|
+
ComboboxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: ComboboxModule, declarations: [AbstractComboboxComponent,
|
|
43
|
+
AbstractDropdownComponent,
|
|
44
|
+
ComboboxComponent,
|
|
45
|
+
ComboboxPopupFooterComponent,
|
|
46
|
+
MultiselectComponent,
|
|
47
|
+
DropdownComponent, ComboboxItemTemplateDirective,
|
|
48
|
+
MultiselectItemTemplateDirective,
|
|
49
|
+
MultiselectTagTemplateDirective,
|
|
50
|
+
MultiselectTagWrapperDirective,
|
|
51
|
+
DropdownItemTemplateDirective,
|
|
52
|
+
DropdownValueTemplateDirective], imports: [CommonModule,
|
|
53
|
+
ReactiveFormsModule,
|
|
54
|
+
ComboBoxModule,
|
|
55
|
+
MultiSelectModule,
|
|
56
|
+
PopupModule,
|
|
57
|
+
TagModule,
|
|
58
|
+
DropDownListModule], exports: [AbstractComboboxComponent,
|
|
59
|
+
AbstractDropdownComponent,
|
|
60
|
+
ComboboxComponent,
|
|
61
|
+
ComboboxPopupFooterComponent,
|
|
62
|
+
MultiselectComponent,
|
|
63
|
+
DropdownComponent, ComboboxItemTemplateDirective,
|
|
64
|
+
MultiselectItemTemplateDirective,
|
|
65
|
+
MultiselectTagTemplateDirective,
|
|
66
|
+
MultiselectTagWrapperDirective,
|
|
67
|
+
DropdownItemTemplateDirective,
|
|
68
|
+
DropdownValueTemplateDirective] });
|
|
69
|
+
ComboboxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ComboboxModule, providers: [
|
|
70
|
+
{
|
|
71
|
+
provide: POPUP_CONTAINER,
|
|
72
|
+
useFactory: getPopupContainer,
|
|
73
|
+
},
|
|
74
|
+
], imports: [CommonModule,
|
|
75
|
+
ReactiveFormsModule,
|
|
76
|
+
ComboBoxModule,
|
|
77
|
+
MultiSelectModule,
|
|
78
|
+
PopupModule,
|
|
79
|
+
TagModule,
|
|
80
|
+
DropDownListModule] });
|
|
81
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ComboboxModule, decorators: [{
|
|
82
|
+
type: NgModule,
|
|
83
|
+
args: [{
|
|
84
|
+
declarations: [...components, ...directives],
|
|
85
|
+
imports: [
|
|
86
|
+
CommonModule,
|
|
87
|
+
ReactiveFormsModule,
|
|
88
|
+
ComboBoxModule,
|
|
89
|
+
MultiSelectModule,
|
|
90
|
+
PopupModule,
|
|
91
|
+
TagModule,
|
|
92
|
+
DropDownListModule,
|
|
93
|
+
],
|
|
94
|
+
exports: [...components, ...directives],
|
|
95
|
+
providers: [
|
|
96
|
+
{
|
|
97
|
+
provide: POPUP_CONTAINER,
|
|
98
|
+
useFactory: getPopupContainer,
|
|
99
|
+
},
|
|
100
|
+
],
|
|
101
|
+
}]
|
|
102
|
+
}] });
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tYm9ib3gubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9jb21ib2JveC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBYSxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDbkQsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQy9DLE9BQU8sRUFBQyxjQUFjLEVBQUUsa0JBQWtCLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUN4RyxPQUFPLEVBQUMsV0FBVyxFQUFFLGVBQWUsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQzNFLE9BQU8sRUFBQyw2QkFBNkIsRUFBQyxNQUFNLG9EQUFvRCxDQUFDO0FBQ2pHLE9BQU8sRUFBQyw2QkFBNkIsRUFBQyxNQUFNLG9EQUFvRCxDQUFDO0FBQ2pHLE9BQU8sRUFBQyw4QkFBOEIsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBQ25HLE9BQU8sRUFBQyxnQ0FBZ0MsRUFBQyxNQUFNLHVEQUF1RCxDQUFDO0FBQ3ZHLE9BQU8sRUFBQywrQkFBK0IsRUFBQyxNQUFNLHNEQUFzRCxDQUFDO0FBQ3JHLE9BQU8sRUFBQyw4QkFBOEIsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBQ25HLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLDREQUE0RCxDQUFDO0FBQ3JHLE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLDREQUE0RCxDQUFDO0FBQ3JHLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLG9FQUFvRSxDQUFDO0FBQ2hILE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQzNFLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLDBDQUEwQyxDQUFDO0FBQzNFLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLGdEQUFnRCxDQUFDOztBQUVwRixNQUFNLFVBQVUsR0FBVTtJQUN4Qix5QkFBeUI7SUFDekIseUJBQXlCO0lBQ3pCLGlCQUFpQjtJQUNqQiw0QkFBNEI7SUFDNUIsb0JBQW9CO0lBQ3BCLGlCQUFpQjtDQUNsQixDQUFDO0FBQ0YsTUFBTSxVQUFVLEdBQVU7SUFDeEIsNkJBQTZCO0lBQzdCLGdDQUFnQztJQUNoQywrQkFBK0I7SUFDL0IsOEJBQThCO0lBQzlCLDZCQUE2QjtJQUM3Qiw4QkFBOEI7Q0FDL0IsQ0FBQztBQUVGLE1BQU0sVUFBVSxpQkFBaUI7SUFDL0IsT0FBTyxFQUFDLGFBQWEsRUFBRSxRQUFRLENBQUMsSUFBSSxFQUFlLENBQUM7QUFDdEQsQ0FBQztBQXFCRCxNQUFNLE9BQU8sY0FBYzs7MkdBQWQsY0FBYzs0R0FBZCxjQUFjLGlCQXZDekIseUJBQXlCO1FBQ3pCLHlCQUF5QjtRQUN6QixpQkFBaUI7UUFDakIsNEJBQTRCO1FBQzVCLG9CQUFvQjtRQUNwQixpQkFBaUIsRUFHakIsNkJBQTZCO1FBQzdCLGdDQUFnQztRQUNoQywrQkFBK0I7UUFDL0IsOEJBQThCO1FBQzlCLDZCQUE2QjtRQUM3Qiw4QkFBOEIsYUFVNUIsWUFBWTtRQUNaLG1CQUFtQjtRQUNuQixjQUFjO1FBQ2QsaUJBQWlCO1FBQ2pCLFdBQVc7UUFDWCxTQUFTO1FBQ1Qsa0JBQWtCLGFBN0JwQix5QkFBeUI7UUFDekIseUJBQXlCO1FBQ3pCLGlCQUFpQjtRQUNqQiw0QkFBNEI7UUFDNUIsb0JBQW9CO1FBQ3BCLGlCQUFpQixFQUdqQiw2QkFBNkI7UUFDN0IsZ0NBQWdDO1FBQ2hDLCtCQUErQjtRQUMvQiw4QkFBOEI7UUFDOUIsNkJBQTZCO1FBQzdCLDhCQUE4Qjs0R0EwQm5CLGNBQWMsYUFQZDtRQUNUO1lBQ0UsT0FBTyxFQUFFLGVBQWU7WUFDeEIsVUFBVSxFQUFFLGlCQUFpQjtTQUM5QjtLQUNGLFlBZEMsWUFBWTtRQUNaLG1CQUFtQjtRQUNuQixjQUFjO1FBQ2QsaUJBQWlCO1FBQ2pCLFdBQVc7UUFDWCxTQUFTO1FBQ1Qsa0JBQWtCOzJGQVVULGNBQWM7a0JBbkIxQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLEdBQUcsVUFBVSxFQUFFLEdBQUcsVUFBVSxDQUFDO29CQUM1QyxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixtQkFBbUI7d0JBQ25CLGNBQWM7d0JBQ2QsaUJBQWlCO3dCQUNqQixXQUFXO3dCQUNYLFNBQVM7d0JBQ1Qsa0JBQWtCO3FCQUNuQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxHQUFHLFVBQVUsRUFBRSxHQUFHLFVBQVUsQ0FBQztvQkFDdkMsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxlQUFlOzRCQUN4QixVQUFVLEVBQUUsaUJBQWlCO3lCQUM5QjtxQkFDRjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtFbGVtZW50UmVmLCBOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1JlYWN0aXZlRm9ybXNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7VGFnTW9kdWxlfSBmcm9tICdAbWFyY3VyYS9tYXJjdXJhLXRhZyc7XG5pbXBvcnQge0NvbWJvQm94TW9kdWxlLCBEcm9wRG93bkxpc3RNb2R1bGUsIE11bHRpU2VsZWN0TW9kdWxlfSBmcm9tICdAcHJvZ3Jlc3Mva2VuZG8tYW5ndWxhci1kcm9wZG93bnMnO1xuaW1wb3J0IHtQb3B1cE1vZHVsZSwgUE9QVVBfQ09OVEFJTkVSfSBmcm9tICdAcHJvZ3Jlc3Mva2VuZG8tYW5ndWxhci1wb3B1cCc7XG5pbXBvcnQge0NvbWJvYm94SXRlbVRlbXBsYXRlRGlyZWN0aXZlfSBmcm9tICcuLi9saWIvZGlyZWN0aXZlcy9jb21ib2JveC1pdGVtLXRlbXBsYXRlLmRpcmVjdGl2ZSc7XG5pbXBvcnQge0Ryb3Bkb3duSXRlbVRlbXBsYXRlRGlyZWN0aXZlfSBmcm9tICcuLi9saWIvZGlyZWN0aXZlcy9kcm9wZG93bi1pdGVtLXRlbXBsYXRlLmRpcmVjdGl2ZSc7XG5pbXBvcnQge0Ryb3Bkb3duVmFsdWVUZW1wbGF0ZURpcmVjdGl2ZX0gZnJvbSAnLi4vbGliL2RpcmVjdGl2ZXMvZHJvcGRvd24tdmFsdWUtdGVtcGxhdGUuZGlyZWN0aXZlJztcbmltcG9ydCB7TXVsdGlzZWxlY3RJdGVtVGVtcGxhdGVEaXJlY3RpdmV9IGZyb20gJy4uL2xpYi9kaXJlY3RpdmVzL211bHRpc2VsZWN0LWl0ZW0tdGVtcGxhdGUuZGlyZWN0aXZlJztcbmltcG9ydCB7TXVsdGlzZWxlY3RUYWdUZW1wbGF0ZURpcmVjdGl2ZX0gZnJvbSAnLi4vbGliL2RpcmVjdGl2ZXMvbXVsdGlzZWxlY3QtdGFnLXRlbXBsYXRlLmRpcmVjdGl2ZSc7XG5pbXBvcnQge011bHRpc2VsZWN0VGFnV3JhcHBlckRpcmVjdGl2ZX0gZnJvbSAnLi4vbGliL2RpcmVjdGl2ZXMvbXVsdGlzZWxlY3QtdGFnLXdyYXBwZXIuZGlyZWN0aXZlJztcbmltcG9ydCB7QWJzdHJhY3RDb21ib2JveENvbXBvbmVudH0gZnJvbSAnLi9jb21wb25lbnRzL2Fic3RyYWN0LWNvbWJvYm94L2Fic3RyYWN0LWNvbWJvYm94LmNvbXBvbmVudCc7XG5pbXBvcnQge0Fic3RyYWN0RHJvcGRvd25Db21wb25lbnR9IGZyb20gJy4vY29tcG9uZW50cy9hYnN0cmFjdC1kcm9wZG93bi9hYnN0cmFjdC1kcm9wZG93bi5jb21wb25lbnQnO1xuaW1wb3J0IHtDb21ib2JveFBvcHVwRm9vdGVyQ29tcG9uZW50fSBmcm9tICcuL2NvbXBvbmVudHMvY29tYm9ib3gtcG9wdXAtZm9vdGVyL2NvbWJvYm94LXBvcHVwLWZvb3Rlci5jb21wb25lbnQnO1xuaW1wb3J0IHtDb21ib2JveENvbXBvbmVudH0gZnJvbSAnLi9jb21wb25lbnRzL2NvbWJvYm94L2NvbWJvYm94LmNvbXBvbmVudCc7XG5pbXBvcnQge0Ryb3Bkb3duQ29tcG9uZW50fSBmcm9tICcuL2NvbXBvbmVudHMvZHJvcGRvd24vZHJvcGRvd24uY29tcG9uZW50JztcbmltcG9ydCB7TXVsdGlzZWxlY3RDb21wb25lbnR9IGZyb20gJy4vY29tcG9uZW50cy9tdWx0aXNlbGVjdC9tdWx0aXNlbGVjdC5jb21wb25lbnQnO1xuXG5jb25zdCBjb21wb25lbnRzOiBhbnlbXSA9IFtcbiAgQWJzdHJhY3RDb21ib2JveENvbXBvbmVudCxcbiAgQWJzdHJhY3REcm9wZG93bkNvbXBvbmVudCxcbiAgQ29tYm9ib3hDb21wb25lbnQsXG4gIENvbWJvYm94UG9wdXBGb290ZXJDb21wb25lbnQsXG4gIE11bHRpc2VsZWN0Q29tcG9uZW50LFxuICBEcm9wZG93bkNvbXBvbmVudCxcbl07XG5jb25zdCBkaXJlY3RpdmVzOiBhbnlbXSA9IFtcbiAgQ29tYm9ib3hJdGVtVGVtcGxhdGVEaXJlY3RpdmUsXG4gIE11bHRpc2VsZWN0SXRlbVRlbXBsYXRlRGlyZWN0aXZlLFxuICBNdWx0aXNlbGVjdFRhZ1RlbXBsYXRlRGlyZWN0aXZlLFxuICBNdWx0aXNlbGVjdFRhZ1dyYXBwZXJEaXJlY3RpdmUsXG4gIERyb3Bkb3duSXRlbVRlbXBsYXRlRGlyZWN0aXZlLFxuICBEcm9wZG93blZhbHVlVGVtcGxhdGVEaXJlY3RpdmUsXG5dO1xuXG5leHBvcnQgZnVuY3Rpb24gZ2V0UG9wdXBDb250YWluZXIoKTogRWxlbWVudFJlZiB7XG4gIHJldHVybiB7bmF0aXZlRWxlbWVudDogZG9jdW1lbnQuYm9keX0gYXMgRWxlbWVudFJlZjtcbn1cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbLi4uY29tcG9uZW50cywgLi4uZGlyZWN0aXZlc10sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBDb21ib0JveE1vZHVsZSxcbiAgICBNdWx0aVNlbGVjdE1vZHVsZSxcbiAgICBQb3B1cE1vZHVsZSxcbiAgICBUYWdNb2R1bGUsXG4gICAgRHJvcERvd25MaXN0TW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbLi4uY29tcG9uZW50cywgLi4uZGlyZWN0aXZlc10sXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IFBPUFVQX0NPTlRBSU5FUixcbiAgICAgIHVzZUZhY3Rvcnk6IGdldFBvcHVwQ29udGFpbmVyLFxuICAgIH0sXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIENvbWJvYm94TW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, Renderer2, } from '@angular/core';
|
|
2
|
+
import { isFalse, Is, Observer, Worker, flatten } from '@marcura/marcura-common';
|
|
3
|
+
import { combineLatest, BehaviorSubject } from 'rxjs';
|
|
4
|
+
import { debounceTime, distinctUntilChanged, filter, map, skip, tap } from 'rxjs/operators';
|
|
5
|
+
import { AbstractDropdownComponent } from '../../components/abstract-dropdown/abstract-dropdown.component';
|
|
6
|
+
import { ComboboxSearchSettingsOperator } from '../../model/combobox-search-settings-operator.enum';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class AbstractComboboxComponent extends AbstractDropdownComponent {
|
|
9
|
+
get debounceTime() {
|
|
10
|
+
return this._debounceTime;
|
|
11
|
+
}
|
|
12
|
+
set debounceTime(value) {
|
|
13
|
+
this._debounceTime = value;
|
|
14
|
+
this._listenToSearched();
|
|
15
|
+
}
|
|
16
|
+
get items() {
|
|
17
|
+
return this._items;
|
|
18
|
+
}
|
|
19
|
+
set items(items) {
|
|
20
|
+
this._isSync = true;
|
|
21
|
+
this._items = items || [];
|
|
22
|
+
this._listenToSearched();
|
|
23
|
+
this._loadedItems.next(this._items);
|
|
24
|
+
}
|
|
25
|
+
get additionalItems() {
|
|
26
|
+
return this._additionalItems.value;
|
|
27
|
+
}
|
|
28
|
+
set additionalItems(additionalItems) {
|
|
29
|
+
this._additionalItems.next(additionalItems || []);
|
|
30
|
+
}
|
|
31
|
+
_disableChromeAutocomplete() {
|
|
32
|
+
if (this._component.searchbar && this._component.searchbar.input) {
|
|
33
|
+
this._renderer.setAttribute(this._component.searchbar.input.nativeElement, 'autocomplete', 'disabled');
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
_listenToSearched() {
|
|
37
|
+
this._debounceObserver.clear();
|
|
38
|
+
this._debounceObserver.listen(this._searchText.pipe(distinctUntilChanged(), skip(1), tap((searchText) => {
|
|
39
|
+
this.searched.emit(searchText);
|
|
40
|
+
this._isSearching.next(this.canLoadItems(searchText) && this._isOpen.value.isOpen);
|
|
41
|
+
}), debounceTime(this._isSync ? 0 : this.debounceTime), filter(() => this._isOpen.value.isOpen)), this.loadItems);
|
|
42
|
+
}
|
|
43
|
+
_filterItems(items, searchText) {
|
|
44
|
+
if (!items || !items.length) {
|
|
45
|
+
return [];
|
|
46
|
+
}
|
|
47
|
+
// TODO: technical-debt - fix group result case to avoid any
|
|
48
|
+
return items.filter((item) => {
|
|
49
|
+
let itemText = (item[this.textField] || '').toString().trim() ?? '';
|
|
50
|
+
itemText = this.searchSettings.isCaseSensitive ? itemText : itemText.toLowerCase();
|
|
51
|
+
return this.searchSettings.operator === ComboboxSearchSettingsOperator.Contains
|
|
52
|
+
? itemText.indexOf(searchText) !== -1
|
|
53
|
+
: itemText.substring(0, searchText.length) === searchText;
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
_setComponent(component) {
|
|
57
|
+
this._component = component;
|
|
58
|
+
this._disableChromeAutocomplete();
|
|
59
|
+
}
|
|
60
|
+
searchItems(searchText) {
|
|
61
|
+
if (!this.searchSettings || !searchText || !this._items.length) {
|
|
62
|
+
return this._items;
|
|
63
|
+
}
|
|
64
|
+
searchText = this.searchSettings.isCaseSensitive ? searchText : searchText.toLowerCase();
|
|
65
|
+
if (this.isGroupable) {
|
|
66
|
+
const groups = this._items;
|
|
67
|
+
const filteredGroups = groups
|
|
68
|
+
.map((group) => ({
|
|
69
|
+
...group,
|
|
70
|
+
items: this._filterItems(group.items, searchText),
|
|
71
|
+
}))
|
|
72
|
+
.filter((group) => group.items.length > 0);
|
|
73
|
+
return filteredGroups;
|
|
74
|
+
}
|
|
75
|
+
return this._filterItems(this._items, searchText);
|
|
76
|
+
}
|
|
77
|
+
canLoadItems(searchText) {
|
|
78
|
+
return searchText.length >= this.minSearchCharacters && !this._isSync;
|
|
79
|
+
}
|
|
80
|
+
getItem(items, text) {
|
|
81
|
+
text = text.toLowerCase();
|
|
82
|
+
return this._unwrapGroups(items).find((item) => `${item[this.textField]}`.toLowerCase() === text) ?? null;
|
|
83
|
+
}
|
|
84
|
+
_unwrapGroups(items) {
|
|
85
|
+
return flatten(items.map(item => this._isGroupResult(item) ? item.items : [item]));
|
|
86
|
+
}
|
|
87
|
+
_isGroupResult(item) {
|
|
88
|
+
const object = item;
|
|
89
|
+
return object.items !== undefined && object.aggregates !== undefined && object.field !== undefined && object.value !== undefined;
|
|
90
|
+
}
|
|
91
|
+
isItemEqual(item1, item2) {
|
|
92
|
+
const isItem1Empty = item1 === null || item1 === undefined;
|
|
93
|
+
const isItem2Empty = item2 === null || item2 === undefined;
|
|
94
|
+
if (isItem1Empty && isItem2Empty) {
|
|
95
|
+
return true;
|
|
96
|
+
}
|
|
97
|
+
if (isItem1Empty || isItem2Empty) {
|
|
98
|
+
return false;
|
|
99
|
+
}
|
|
100
|
+
return this.isPrimitiveValue ? item1 === item2 : item1[this.valueField] === item2[this.valueField];
|
|
101
|
+
}
|
|
102
|
+
constructor(changeDetectorRef, _renderer) {
|
|
103
|
+
super(changeDetectorRef);
|
|
104
|
+
this._renderer = _renderer;
|
|
105
|
+
this._debounceTime = 500;
|
|
106
|
+
this._debounceObserver = new Observer();
|
|
107
|
+
this._worker = new Worker();
|
|
108
|
+
this._additionalItems = new BehaviorSubject([]);
|
|
109
|
+
this._valueNormalizerItems = [];
|
|
110
|
+
this._isSync = false;
|
|
111
|
+
this._loadedItems = new BehaviorSubject([]);
|
|
112
|
+
this._hasSearched = new BehaviorSubject(false);
|
|
113
|
+
this._isSearching = new BehaviorSubject(false);
|
|
114
|
+
this._searchText = new BehaviorSubject('');
|
|
115
|
+
this.combinedItems = combineLatest([this._loadedItems, this._additionalItems]).pipe(map(([items, additionalItems]) => [...items, ...additionalItems].filter(Is.truthy)));
|
|
116
|
+
this.isSearchable = true;
|
|
117
|
+
this.minSearchCharacters = 1;
|
|
118
|
+
this.search = null;
|
|
119
|
+
this.areItemsCached = false;
|
|
120
|
+
this.searchSettings = {
|
|
121
|
+
isCaseSensitive: false,
|
|
122
|
+
operator: ComboboxSearchSettingsOperator.Contains,
|
|
123
|
+
};
|
|
124
|
+
this.isGroupable = false;
|
|
125
|
+
this.searched = new EventEmitter();
|
|
126
|
+
this.isNoItemsTextVisible = combineLatest([
|
|
127
|
+
this._isSearching,
|
|
128
|
+
this._hasSearched,
|
|
129
|
+
this._isFocused,
|
|
130
|
+
this.combinedItems,
|
|
131
|
+
]).pipe(map(([isSearching, hasSearched, isFocused, combinedItems]) => {
|
|
132
|
+
return !isSearching && hasSearched && isFocused && combinedItems.length === 0;
|
|
133
|
+
}));
|
|
134
|
+
this.isMinSearchTextVisible = combineLatest([
|
|
135
|
+
this._isSearching,
|
|
136
|
+
this._hasSearched,
|
|
137
|
+
this._isFocused,
|
|
138
|
+
]).pipe(map(([isSearching, hasSearched, isFocused]) => {
|
|
139
|
+
return !this._isSync && !isSearching && !hasSearched && isFocused;
|
|
140
|
+
}));
|
|
141
|
+
this.isLoadingSpinnerVisible = combineLatest([
|
|
142
|
+
this._isLoading,
|
|
143
|
+
this._isSearching,
|
|
144
|
+
]).pipe(map(([isLoading, isSearching]) => isLoading || isSearching));
|
|
145
|
+
// To show loading properly we are to use loadedItems as they don't include additionalItems.
|
|
146
|
+
this.isLoadingTextVisible = combineLatest([
|
|
147
|
+
this.isLoadingSpinnerVisible,
|
|
148
|
+
this._loadedItems,
|
|
149
|
+
]).pipe(map(([isLoadingSpinnerVisible, loadedItems]) => isLoadingSpinnerVisible && loadedItems.length === 0));
|
|
150
|
+
this.loadItems = (searchText) => {
|
|
151
|
+
searchText = (searchText || '').trim();
|
|
152
|
+
if (this._isSync) {
|
|
153
|
+
this._hasSearched.next(!!searchText);
|
|
154
|
+
this._loadedItems.next(this.searchItems(searchText));
|
|
155
|
+
}
|
|
156
|
+
else {
|
|
157
|
+
if (this.canLoadItems(searchText)) {
|
|
158
|
+
this._isSearching.next(true);
|
|
159
|
+
this._worker.handle(this.search ? this.search(searchText) : new BehaviorSubject([]), (items) => {
|
|
160
|
+
this._hasSearched.next(true);
|
|
161
|
+
this._loadedItems.next(items);
|
|
162
|
+
this._valueNormalizerItems = [...items, ...this._additionalItems.value];
|
|
163
|
+
this._isSearching.next(false);
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
this._hasSearched.next(false);
|
|
168
|
+
this._loadedItems.next([]);
|
|
169
|
+
this._valueNormalizerItems = [];
|
|
170
|
+
this._isSearching.next(false);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
};
|
|
174
|
+
}
|
|
175
|
+
ngOnDestroy() {
|
|
176
|
+
this._debounceObserver.destroy();
|
|
177
|
+
this._worker.destroy();
|
|
178
|
+
super.ngOnDestroy();
|
|
179
|
+
}
|
|
180
|
+
init() {
|
|
181
|
+
super.init();
|
|
182
|
+
this._listenToSearched();
|
|
183
|
+
if (this._isSync) {
|
|
184
|
+
this._loadedItems.next(this._items);
|
|
185
|
+
}
|
|
186
|
+
// Closed.
|
|
187
|
+
this._observer.listen(this._isOpen.pipe(filter((event) => !event.isOpen), skip(1)), (event) => {
|
|
188
|
+
if (!this.areItemsCached && !this._isSync) {
|
|
189
|
+
this._loadedItems.next([]);
|
|
190
|
+
}
|
|
191
|
+
this._worker.cancel();
|
|
192
|
+
this._isSearching.next(false);
|
|
193
|
+
if (event.shouldEmit) {
|
|
194
|
+
this.closed.emit();
|
|
195
|
+
}
|
|
196
|
+
});
|
|
197
|
+
// Blurred.
|
|
198
|
+
this._observer.listen(this._isFocused.pipe(filter(isFalse)), () => {
|
|
199
|
+
// Restore original unfiltered items when the component is blurred
|
|
200
|
+
// after some search text entered. Consider a case:
|
|
201
|
+
// 1. Search with text that gives 0 items.
|
|
202
|
+
// 2. Blur and focus.
|
|
203
|
+
// 3. Search text is cleared, but items remain empty, so the list won't show up.
|
|
204
|
+
this._loadedItems.next(this._items);
|
|
205
|
+
this._hasSearched.next(false);
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
onSearched(searchText) {
|
|
209
|
+
this._searchText.next(searchText);
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
AbstractComboboxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AbstractComboboxComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
|
|
213
|
+
AbstractComboboxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.0", type: AbstractComboboxComponent, selector: "ng-component", inputs: { isSearchable: "isSearchable", minSearchCharacters: "minSearchCharacters", search: "search", areItemsCached: "areItemsCached", debounceTime: "debounceTime", items: "items", additionalItems: "additionalItems", searchSettings: "searchSettings", isGroupable: "isGroupable" }, outputs: { searched: "searched" }, usesInheritance: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
214
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AbstractComboboxComponent, decorators: [{
|
|
215
|
+
type: Component,
|
|
216
|
+
args: [{
|
|
217
|
+
template: '',
|
|
218
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
219
|
+
}]
|
|
220
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }]; }, propDecorators: { isSearchable: [{
|
|
221
|
+
type: Input
|
|
222
|
+
}], minSearchCharacters: [{
|
|
223
|
+
type: Input
|
|
224
|
+
}], search: [{
|
|
225
|
+
type: Input
|
|
226
|
+
}], areItemsCached: [{
|
|
227
|
+
type: Input
|
|
228
|
+
}], debounceTime: [{
|
|
229
|
+
type: Input
|
|
230
|
+
}], items: [{
|
|
231
|
+
type: Input
|
|
232
|
+
}], additionalItems: [{
|
|
233
|
+
type: Input
|
|
234
|
+
}], searchSettings: [{
|
|
235
|
+
type: Input
|
|
236
|
+
}], isGroupable: [{
|
|
237
|
+
type: Input
|
|
238
|
+
}], searched: [{
|
|
239
|
+
type: Output
|
|
240
|
+
}] } });
|
|
241
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-combobox.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/abstract-combobox/abstract-combobox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  Renderer2,\n} from '@angular/core';\nimport {ControlValueAccessor} from '@angular/forms';\nimport {isFalse, Is, Observer, Worker, ControlChangedEvent, flatten} from '@marcura/marcura-common';\nimport {GroupResult} from '@progress/kendo-data-query';\nimport {combineLatest, BehaviorSubject, Observable} from 'rxjs';\nimport {debounceTime, distinctUntilChanged, filter, map, skip, tap} from 'rxjs/operators';\nimport {AbstractDropdownComponent} from '../../components/abstract-dropdown/abstract-dropdown.component';\nimport {IComboboxKendoComponent} from '../../model/combobox-kendo-component.interface';\nimport {ComboboxSearchFn} from '../../model/combobox-search-fn.type';\nimport {ComboboxSearchSettingsOperator} from '../../model/combobox-search-settings-operator.enum';\nimport {IComboboxSearchSettings} from '../../model/combobox-search-settings.interface';\n\n@Component({\n  template: '',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AbstractComboboxComponent<TItem, TValue, TChangedEvent extends ControlChangedEvent<TValue> = ControlChangedEvent<TValue>>\n  extends AbstractDropdownComponent<TItem, TValue, IComboboxKendoComponent, TChangedEvent>\n  implements ControlValueAccessor, OnDestroy {\n  private _debounceTime: number = 500;\n  private readonly _debounceObserver: Observer = new Observer();\n  private readonly _worker: Worker = new Worker();\n  private readonly _additionalItems: BehaviorSubject<TItem[] | GroupResult[]> = new BehaviorSubject<TItem[] | GroupResult[]>([]);\n  protected _valueNormalizerItems: TItem[] | GroupResult[] = [];\n  protected _isSync: boolean = false;\n  protected readonly _loadedItems: BehaviorSubject<TItem[] | GroupResult[]> = new BehaviorSubject<TItem[] | GroupResult[]>([]);\n  protected readonly _hasSearched: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  protected readonly _isSearching: BehaviorSubject<boolean> = new BehaviorSubject(false);\n  protected readonly _searchText: BehaviorSubject<string> = new BehaviorSubject('');\n  public readonly combinedItems: Observable<TItem[] | GroupResult[]> = combineLatest([this._loadedItems, this._additionalItems]).pipe(\n    map(([items, additionalItems]): TItem[] | GroupResult[] => [...items, ...additionalItems].filter(Is.truthy) as TItem[] | GroupResult[])\n  );\n  @Input()\n  public isSearchable: boolean = true;\n  @Input()\n  public minSearchCharacters: number = 1;\n  @Input()\n  public search: ComboboxSearchFn<TItem> | null = null;\n  @Input()\n  public areItemsCached: boolean = false;\n  @Input()\n  public get debounceTime(): number {\n    return this._debounceTime;\n  }\n  public set debounceTime(value: number) {\n    this._debounceTime = value;\n    this._listenToSearched();\n  }\n  @Input()\n  public override get items(): TItem[] | GroupResult[] {\n    return this._items;\n  }\n  public override set items(items: TItem[] | GroupResult[]) {\n    this._isSync = true;\n    this._items = items || [];\n    this._listenToSearched();\n    this._loadedItems.next(this._items);\n  }\n  @Input()\n  public get additionalItems(): TItem[] | GroupResult[] {\n    return this._additionalItems.value;\n  }\n  public set additionalItems(additionalItems: TItem[] | GroupResult[]) {\n    this._additionalItems.next(additionalItems || []);\n  }\n  @Input()\n  public searchSettings: IComboboxSearchSettings = {\n    isCaseSensitive: false,\n    operator: ComboboxSearchSettingsOperator.Contains,\n  };\n  @Input()\n  public isGroupable: boolean = false;\n  @Output()\n  public searched: EventEmitter<string> = new EventEmitter();\n  public readonly isNoItemsTextVisible: Observable<boolean> = combineLatest([\n    this._isSearching,\n    this._hasSearched,\n    this._isFocused,\n    this.combinedItems,\n  ]).pipe(\n    map(([isSearching, hasSearched, isFocused, combinedItems]) => {\n      return !isSearching && hasSearched && isFocused && combinedItems.length === 0;\n    })\n  );\n  public readonly isMinSearchTextVisible: Observable<boolean> = combineLatest([\n    this._isSearching,\n    this._hasSearched,\n    this._isFocused,\n  ]).pipe(\n    map(([isSearching, hasSearched, isFocused]) => {\n      return !this._isSync && !isSearching && !hasSearched && isFocused;\n    })\n  );\n  public readonly isLoadingSpinnerVisible: Observable<boolean> = combineLatest([\n    this._isLoading,\n    this._isSearching,\n  ]).pipe(map(([isLoading, isSearching]) => isLoading || isSearching));\n  // To show loading properly we are to use loadedItems as they don't include additionalItems.\n  public readonly isLoadingTextVisible: Observable<boolean> = combineLatest([\n    this.isLoadingSpinnerVisible,\n    this._loadedItems,\n  ]).pipe(map(([isLoadingSpinnerVisible, loadedItems]) => isLoadingSpinnerVisible && loadedItems.length === 0));\n\n  private _disableChromeAutocomplete(): void {\n    if (this._component.searchbar && this._component.searchbar.input) {\n      this._renderer.setAttribute(this._component.searchbar.input.nativeElement, 'autocomplete', 'disabled');\n    }\n  }\n\n  private _listenToSearched(): void {\n    this._debounceObserver.clear();\n    this._debounceObserver.listen(\n      this._searchText.pipe(\n        distinctUntilChanged(),\n        skip(1),\n        tap((searchText) => {\n          this.searched.emit(searchText);\n          this._isSearching.next(this.canLoadItems(searchText) && this._isOpen.value.isOpen);\n        }),\n        debounceTime(this._isSync ? 0 : this.debounceTime),\n        filter(() => this._isOpen.value.isOpen)\n      ),\n      this.loadItems\n    );\n  }\n\n  private _filterItems(items: TItem[] | GroupResult[], searchText: string): TItem[] {\n    if (!items || !items.length) {\n      return [];\n    }\n\n    // TODO: technical-debt - fix group result case to avoid any\n    return (items as any[]).filter((item) => {\n      let itemText: string = (item[this.textField] || '').toString().trim() ?? '';\n      itemText = this.searchSettings.isCaseSensitive ? itemText : itemText.toLowerCase();\n\n      return this.searchSettings.operator === ComboboxSearchSettingsOperator.Contains\n        ? itemText.indexOf(searchText) !== -1\n        : itemText.substring(0, searchText.length) === searchText;\n    });\n  }\n\n  protected override _setComponent(component: IComboboxKendoComponent): void {\n    this._component = component;\n    this._disableChromeAutocomplete();\n  }\n\n  protected searchItems(searchText: string): TItem[] | GroupResult[] {\n    if (!this.searchSettings || !searchText || !this._items.length) {\n      return this._items;\n    }\n\n    searchText = this.searchSettings.isCaseSensitive ? searchText : searchText.toLowerCase();\n\n    if (this.isGroupable) {\n      const groups: GroupResult[] = <any>this._items;\n      const filteredGroups: GroupResult[] = groups\n        .map((group): GroupResult => ({\n          ...group,\n          items: this._filterItems(<TItem[]>group.items, searchText) as any,\n        }))\n        .filter((group) => group.items.length > 0);\n\n      return <any>filteredGroups;\n    }\n\n    return this._filterItems(this._items, searchText);\n  }\n\n  protected canLoadItems(searchText: string): boolean {\n    return searchText.length >= this.minSearchCharacters && !this._isSync;\n  }\n\n  protected getItem(items: TItem[] | GroupResult[], text: string): TItem | null {\n    text = text.toLowerCase();\n    return this._unwrapGroups(items).find((item) => `${item[this.textField]}`.toLowerCase() === text) ?? null;\n  }\n\n  private _unwrapGroups(items: TItem[] | GroupResult[]): TItem[] {\n    return flatten(\n      items.map(item => this._isGroupResult(item) ? item.items as TItem[] : [item])\n    );\n  }\n\n  private _isGroupResult(item: TItem | GroupResult): item is GroupResult {\n    const object: any = item;\n    return object.items !== undefined && object.aggregates !== undefined && object.field !== undefined && object.value !== undefined;\n  }\n\n  protected isItemEqual(item1: TItem, item2: TItem): boolean {\n    const isItem1Empty: boolean = item1 === null || item1 === undefined;\n    const isItem2Empty: boolean = item2 === null || item2 === undefined;\n\n    if (isItem1Empty && isItem2Empty) {\n      return true;\n    }\n\n    if (isItem1Empty || isItem2Empty) {\n      return false;\n    }\n\n    return this.isPrimitiveValue ? item1 === item2 : item1[this.valueField] === item2[this.valueField];\n  }\n\n  protected loadItems = (searchText?: string): void => {\n    searchText = (searchText || '').trim();\n\n    if (this._isSync) {\n      this._hasSearched.next(!!searchText);\n      this._loadedItems.next(this.searchItems(searchText));\n    } else {\n      if (this.canLoadItems(searchText)) {\n        this._isSearching.next(true);\n        this._worker.handle(this.search ? this.search(searchText) : new BehaviorSubject([]), (items) => {\n          this._hasSearched.next(true);\n          this._loadedItems.next(items);\n          this._valueNormalizerItems = [...items, ...this._additionalItems.value] as TItem[] | GroupResult[];\n          this._isSearching.next(false);\n        });\n      } else {\n        this._hasSearched.next(false);\n        this._loadedItems.next([]);\n        this._valueNormalizerItems = [];\n        this._isSearching.next(false);\n      }\n    }\n  };\n\n  public constructor(changeDetectorRef: ChangeDetectorRef, protected readonly _renderer: Renderer2) {\n    super(changeDetectorRef);\n  }\n\n  public override ngOnDestroy(): void {\n    this._debounceObserver.destroy();\n    this._worker.destroy();\n    super.ngOnDestroy();\n  }\n\n  public override init(): void {\n    super.init();\n    this._listenToSearched();\n\n    if (this._isSync) {\n      this._loadedItems.next(this._items);\n    }\n\n    // Closed.\n    this._observer.listen(\n      this._isOpen.pipe(\n        filter((event) => !event.isOpen),\n        skip(1)\n      ),\n      (event) => {\n        if (!this.areItemsCached && !this._isSync) {\n          this._loadedItems.next([]);\n        }\n\n        this._worker.cancel();\n        this._isSearching.next(false);\n\n        if (event.shouldEmit) {\n          this.closed.emit();\n        }\n      }\n    );\n\n    // Blurred.\n    this._observer.listen(this._isFocused.pipe(filter(isFalse)), () => {\n      // Restore original unfiltered items when the component is blurred\n      // after some search text entered. Consider a case:\n      // 1. Search with text that gives 0 items.\n      // 2. Blur and focus.\n      // 3. Search text is cleared, but items remain empty, so the list won't show up.\n      this._loadedItems.next(this._items);\n      this._hasSearched.next(false);\n    });\n  }\n\n  public onSearched(searchText: string): void {\n    this._searchText.next(searchText);\n  }\n}\n"]}
|