@acpaas-ui/ngx-forms 5.3.0 → 6.0.0-beta.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/README.md +0 -2
- package/esm2020/acpaas-ui-ngx-forms.mjs +5 -0
- package/esm2020/lib/auto-complete/auto-complete.module.mjs +25 -0
- package/esm2020/lib/auto-complete/components/auto-complete/auto-complete.component.mjs +370 -0
- package/esm2020/lib/auto-complete/public-api.mjs +3 -0
- package/esm2020/lib/datepicker/components/datepicker/datepicker.component.mjs +274 -0
- package/esm2020/lib/datepicker/datepicker.conf.mjs +9 -0
- package/esm2020/lib/datepicker/datepicker.module.mjs +55 -0
- package/esm2020/lib/datepicker/public-api.mjs +4 -0
- package/esm2020/lib/datepicker/types/datepicker.types.mjs +2 -0
- package/esm2020/lib/mask/directives/mask.directive.mjs +25 -0
- package/esm2020/lib/mask/mask.module.mjs +20 -0
- package/esm2020/lib/mask/public-api.mjs +3 -0
- package/esm2020/lib/range-slider/components/range-slider/range-slider.component.mjs +349 -0
- package/esm2020/lib/range-slider/public-api.mjs +3 -0
- package/esm2020/lib/range-slider/range-slider.module.mjs +20 -0
- package/esm2020/lib/range-slider/types/range-slider.types.mjs +2 -0
- package/esm2020/lib/search-filter/components/search-filter/search-filter.component.mjs +259 -0
- package/esm2020/lib/search-filter/public-api.mjs +3 -0
- package/esm2020/lib/search-filter/search-filter.module.mjs +22 -0
- package/esm2020/lib/search-filter/types/search-filter.types.mjs +2 -0
- package/esm2020/lib/shared/services/search.service.mjs +32 -0
- package/esm2020/lib/shared/types/search.types.mjs +2 -0
- package/esm2020/lib/timepicker/classes/timepicker.validators.mjs +49 -0
- package/esm2020/lib/timepicker/components/timepicker/timepicker.component.mjs +229 -0
- package/esm2020/lib/timepicker/public-api.mjs +5 -0
- package/esm2020/lib/timepicker/timepicker.module.mjs +22 -0
- package/esm2020/lib/timepicker/types/timepicker.types.mjs +7 -0
- package/esm2020/lib/upload/classes/uploader.class.mjs +112 -0
- package/esm2020/lib/upload/components/upload/upload.component.mjs +97 -0
- package/esm2020/lib/upload/components/upload-input/upload-input.component.mjs +56 -0
- package/esm2020/lib/upload/components/upload-queue/upload-queue.component.mjs +78 -0
- package/esm2020/lib/upload/components/upload-zone/upload-zone.component.mjs +252 -0
- package/esm2020/lib/upload/components/validation-list/validation-list.component.mjs +64 -0
- package/esm2020/lib/upload/public-api.mjs +10 -0
- package/esm2020/lib/upload/services/validation-messages.service.mjs +29 -0
- package/esm2020/lib/upload/types/upload.types.mjs +2 -0
- package/esm2020/lib/upload/upload.conf.mjs +12 -0
- package/esm2020/lib/upload/upload.module.mjs +45 -0
- package/esm2020/public-api.mjs +8 -0
- package/fesm2015/acpaas-ui-ngx-forms.mjs +2591 -0
- package/fesm2015/acpaas-ui-ngx-forms.mjs.map +1 -0
- package/fesm2020/acpaas-ui-ngx-forms.mjs +2402 -0
- package/fesm2020/acpaas-ui-ngx-forms.mjs.map +1 -0
- package/{acpaas-ui-ngx-forms.d.ts → index.d.ts} +1 -1
- package/lib/auto-complete/auto-complete.module.d.ts +10 -0
- package/lib/auto-complete/components/auto-complete/auto-complete.component.d.ts +5 -0
- package/lib/datepicker/components/datepicker/datepicker.component.d.ts +15 -8
- package/lib/datepicker/datepicker.module.d.ts +11 -1
- package/lib/datepicker/public-api.d.ts +1 -1
- package/lib/mask/directives/mask.directive.d.ts +3 -0
- package/lib/mask/mask.module.d.ts +6 -0
- package/lib/range-slider/components/range-slider/range-slider.component.d.ts +8 -2
- package/lib/range-slider/range-slider.module.d.ts +7 -0
- package/lib/search-filter/components/search-filter/search-filter.component.d.ts +10 -4
- package/lib/search-filter/search-filter.module.d.ts +9 -0
- package/lib/shared/services/search.service.d.ts +3 -0
- package/lib/timepicker/components/timepicker/timepicker.component.d.ts +9 -4
- package/lib/timepicker/timepicker.module.d.ts +8 -0
- package/lib/upload/components/upload/upload.component.d.ts +5 -0
- package/lib/upload/components/upload-input/upload-input.component.d.ts +3 -0
- package/lib/upload/components/upload-queue/upload-queue.component.d.ts +3 -0
- package/lib/upload/components/upload-zone/upload-zone.component.d.ts +7 -0
- package/lib/upload/components/validation-list/validation-list.component.d.ts +3 -0
- package/lib/upload/services/validation-messages.service.d.ts +3 -0
- package/lib/upload/upload.module.d.ts +14 -1
- package/package.json +37 -24
- package/public-api.d.ts +0 -1
- package/acpaas-ui-ngx-forms.metadata.json +0 -1
- package/bundles/acpaas-ui-ngx-forms.umd.js +0 -3854
- package/bundles/acpaas-ui-ngx-forms.umd.js.map +0 -1
- package/bundles/acpaas-ui-ngx-forms.umd.min.js +0 -2
- package/bundles/acpaas-ui-ngx-forms.umd.min.js.map +0 -1
- package/esm2015/acpaas-ui-ngx-forms.js +0 -11
- package/esm2015/lib/auto-complete/auto-complete.module.js +0 -36
- package/esm2015/lib/auto-complete/components/auto-complete/auto-complete.component.js +0 -416
- package/esm2015/lib/auto-complete/public-api.js +0 -8
- package/esm2015/lib/datepicker/components/datepicker/datepicker.component.js +0 -335
- package/esm2015/lib/datepicker/datepicker.conf.js +0 -18
- package/esm2015/lib/datepicker/datepicker.module.js +0 -59
- package/esm2015/lib/datepicker/public-api.js +0 -9
- package/esm2015/lib/datepicker/types/datepicker.types.js +0 -20
- package/esm2015/lib/mask/directives/mask.directive.js +0 -51
- package/esm2015/lib/mask/mask.module.js +0 -25
- package/esm2015/lib/mask/public-api.js +0 -8
- package/esm2015/lib/range-slider/components/range-slider/range-slider.component.js +0 -424
- package/esm2015/lib/range-slider/public-api.js +0 -8
- package/esm2015/lib/range-slider/range-slider.module.js +0 -26
- package/esm2015/lib/range-slider/types/range-slider.types.js +0 -16
- package/esm2015/lib/search-filter/components/search-filter/search-filter.component.js +0 -219
- package/esm2015/lib/search-filter/public-api.js +0 -8
- package/esm2015/lib/search-filter/search-filter.module.js +0 -30
- package/esm2015/lib/search-filter/types/search-filter.types.js +0 -16
- package/esm2015/lib/shared/services/search.service.js +0 -58
- package/esm2015/lib/shared/types/search.types.js +0 -20
- package/esm2015/lib/timepicker/classes/timepicker.validators.js +0 -84
- package/esm2015/lib/timepicker/components/timepicker/timepicker.component.js +0 -227
- package/esm2015/lib/timepicker/public-api.js +0 -10
- package/esm2015/lib/timepicker/timepicker.module.js +0 -29
- package/esm2015/lib/timepicker/types/timepicker.types.js +0 -13
- package/esm2015/lib/upload/classes/uploader.class.js +0 -189
- package/esm2015/lib/upload/components/upload/upload.component.js +0 -100
- package/esm2015/lib/upload/components/upload-input/upload-input.component.js +0 -67
- package/esm2015/lib/upload/components/upload-queue/upload-queue.component.js +0 -68
- package/esm2015/lib/upload/components/upload-zone/upload-zone.component.js +0 -219
- package/esm2015/lib/upload/components/validation-list/validation-list.component.js +0 -62
- package/esm2015/lib/upload/public-api.js +0 -15
- package/esm2015/lib/upload/services/validation-messages.service.js +0 -48
- package/esm2015/lib/upload/types/upload.types.js +0 -48
- package/esm2015/lib/upload/upload.conf.js +0 -21
- package/esm2015/lib/upload/upload.module.js +0 -62
- package/esm2015/lib/wysiwyg/components/wysiwyg/wysiwyg.component.js +0 -158
- package/esm2015/lib/wysiwyg/public-api.js +0 -9
- package/esm2015/lib/wysiwyg/wysiwyg.conf.js +0 -24
- package/esm2015/lib/wysiwyg/wysiwyg.module.js +0 -29
- package/esm2015/public-api.js +0 -14
- package/esm5/acpaas-ui-ngx-forms.js +0 -11
- package/esm5/lib/auto-complete/auto-complete.module.js +0 -40
- package/esm5/lib/auto-complete/components/auto-complete/auto-complete.component.js +0 -506
- package/esm5/lib/auto-complete/public-api.js +0 -8
- package/esm5/lib/datepicker/components/datepicker/datepicker.component.js +0 -384
- package/esm5/lib/datepicker/datepicker.conf.js +0 -18
- package/esm5/lib/datepicker/datepicker.module.js +0 -69
- package/esm5/lib/datepicker/public-api.js +0 -9
- package/esm5/lib/datepicker/types/datepicker.types.js +0 -20
- package/esm5/lib/mask/directives/mask.directive.js +0 -58
- package/esm5/lib/mask/mask.module.js +0 -29
- package/esm5/lib/mask/public-api.js +0 -8
- package/esm5/lib/range-slider/components/range-slider/range-slider.component.js +0 -514
- package/esm5/lib/range-slider/public-api.js +0 -8
- package/esm5/lib/range-slider/range-slider.module.js +0 -30
- package/esm5/lib/range-slider/types/range-slider.types.js +0 -16
- package/esm5/lib/search-filter/components/search-filter/search-filter.component.js +0 -256
- package/esm5/lib/search-filter/public-api.js +0 -8
- package/esm5/lib/search-filter/search-filter.module.js +0 -34
- package/esm5/lib/search-filter/types/search-filter.types.js +0 -16
- package/esm5/lib/shared/services/search.service.js +0 -68
- package/esm5/lib/shared/types/search.types.js +0 -20
- package/esm5/lib/timepicker/classes/timepicker.validators.js +0 -102
- package/esm5/lib/timepicker/components/timepicker/timepicker.component.js +0 -259
- package/esm5/lib/timepicker/public-api.js +0 -10
- package/esm5/lib/timepicker/timepicker.module.js +0 -33
- package/esm5/lib/timepicker/types/timepicker.types.js +0 -13
- package/esm5/lib/upload/classes/uploader.class.js +0 -249
- package/esm5/lib/upload/components/upload/upload.component.js +0 -117
- package/esm5/lib/upload/components/upload-input/upload-input.component.js +0 -84
- package/esm5/lib/upload/components/upload-queue/upload-queue.component.js +0 -78
- package/esm5/lib/upload/components/upload-zone/upload-zone.component.js +0 -264
- package/esm5/lib/upload/components/validation-list/validation-list.component.js +0 -81
- package/esm5/lib/upload/public-api.js +0 -15
- package/esm5/lib/upload/services/validation-messages.service.js +0 -47
- package/esm5/lib/upload/types/upload.types.js +0 -48
- package/esm5/lib/upload/upload.conf.js +0 -21
- package/esm5/lib/upload/upload.module.js +0 -71
- package/esm5/lib/wysiwyg/components/wysiwyg/wysiwyg.component.js +0 -199
- package/esm5/lib/wysiwyg/public-api.js +0 -9
- package/esm5/lib/wysiwyg/wysiwyg.conf.js +0 -24
- package/esm5/lib/wysiwyg/wysiwyg.module.js +0 -33
- package/esm5/public-api.js +0 -14
- package/fesm2015/acpaas-ui-ngx-forms.js +0 -3071
- package/fesm2015/acpaas-ui-ngx-forms.js.map +0 -1
- package/fesm5/acpaas-ui-ngx-forms.js +0 -3627
- package/fesm5/acpaas-ui-ngx-forms.js.map +0 -1
- package/lib/wysiwyg/components/wysiwyg/wysiwyg.component.d.ts +0 -43
- package/lib/wysiwyg/public-api.d.ts +0 -3
- package/lib/wysiwyg/wysiwyg.conf.d.ts +0 -18
- package/lib/wysiwyg/wysiwyg.module.d.ts +0 -2
package/README.md
CHANGED
|
@@ -13,12 +13,10 @@ Visit our [documentation site](https://antwerp-ui.digipolis.be/) for full how-to
|
|
|
13
13
|
| ----------- | ------ | -------------------------- |
|
|
14
14
|
| `AutoCompleteModule` | This module creates an input field with autocomplete functionality. | [Documentation](src/lib/auto-complete/README.md) |
|
|
15
15
|
| `DatepickerModule` | This package allows the user to select a date either by input or by picking one in the calendar flyout. | [Documentation](src/lib/datepicker/README.md) |
|
|
16
|
-
| `MaskModule` | With this module you can make input fields that only accept a specific format. | [Documentation](src/lib/mask/README.md) |
|
|
17
16
|
| `RangeSliderModule` | This module provides a range slider. | [Documentation](src/lib/range-slider/README.md) |
|
|
18
17
|
| `SearchFilterModule` | This package allows the user to use a JIRA-like filter component with remote search capabilities. | [Documentation](src/lib/search-filter/README.md) |
|
|
19
18
|
| `TimepickerModule` | This package allows the user set the time either by choosing a slot in the dropdown or by typing in the autocomplete field. | [Documentation](src/lib/timepicker/README.md) |
|
|
20
19
|
| `UploadModule` | This module provides a couple of upload components and a specific `Uploader` class. | [Documentation](src/lib/upload/README.md) |
|
|
21
|
-
| `WysiwygModule` | This module provides a wysiwyg that can be used on a page or a form. | [Documentation](src/lib/wysiwyg/README.md) |
|
|
22
20
|
|
|
23
21
|
## Contributing
|
|
24
22
|
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNwYWFzLXVpLW5neC1mb3Jtcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hY3BhYXMtdWktbmd4LWZvcm1zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { FlyoutModule } from '@acpaas-ui/ngx-flyout';
|
|
5
|
+
import { SelectableListModule } from '@acpaas-ui/ngx-selectable-list';
|
|
6
|
+
import { MaskModule } from '../mask/mask.module';
|
|
7
|
+
import { SearchService } from '../shared/services/search.service';
|
|
8
|
+
import { AutoCompleteComponent } from './components/auto-complete/auto-complete.component';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export class AutoCompleteModule {
|
|
11
|
+
}
|
|
12
|
+
/** @nocollapse */ AutoCompleteModule.ɵfac = function AutoCompleteModule_Factory(t) { return new (t || AutoCompleteModule)(); };
|
|
13
|
+
/** @nocollapse */ AutoCompleteModule.ɵmod = /** @pureOrBreakMyCode */ i0.ɵɵdefineNgModule({ type: AutoCompleteModule });
|
|
14
|
+
/** @nocollapse */ AutoCompleteModule.ɵinj = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjector({ providers: [SearchService], imports: [CommonModule, FormsModule, FlyoutModule, SelectableListModule, MaskModule] });
|
|
15
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AutoCompleteModule, [{
|
|
16
|
+
type: NgModule,
|
|
17
|
+
args: [{
|
|
18
|
+
imports: [CommonModule, FormsModule, FlyoutModule, SelectableListModule, MaskModule],
|
|
19
|
+
declarations: [AutoCompleteComponent],
|
|
20
|
+
exports: [AutoCompleteComponent],
|
|
21
|
+
providers: [SearchService],
|
|
22
|
+
}]
|
|
23
|
+
}], null, null); })();
|
|
24
|
+
(function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(AutoCompleteModule, { declarations: [AutoCompleteComponent], imports: [CommonModule, FormsModule, FlyoutModule, SelectableListModule, MaskModule], exports: [AutoCompleteComponent] }); })();
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0by1jb21wbGV0ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2F1dG8tY29tcGxldGUvYXV0by1jb21wbGV0ZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNyRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN0RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDakQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDOztBQVEzRixNQUFNLE9BQU8sa0JBQWtCOzt1R0FBbEIsa0JBQWtCO21HQUFsQixrQkFBa0I7d0dBRmxCLENBQUMsYUFBYSxDQUFDLFlBSGhCLFlBQVksRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLG9CQUFvQixFQUFFLFVBQVU7dUZBS3hFLGtCQUFrQjtjQU45QixRQUFRO2VBQUM7Z0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxZQUFZLEVBQUUsb0JBQW9CLEVBQUUsVUFBVSxDQUFDO2dCQUNwRixZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztnQkFDckMsT0FBTyxFQUFFLENBQUMscUJBQXFCLENBQUM7Z0JBQ2hDLFNBQVMsRUFBRSxDQUFDLGFBQWEsQ0FBQzthQUMzQjs7d0ZBQ1ksa0JBQWtCLG1CQUpkLHFCQUFxQixhQUQxQixZQUFZLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxvQkFBb0IsRUFBRSxVQUFVLGFBRXpFLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBGbHlvdXRNb2R1bGUgfSBmcm9tICdAYWNwYWFzLXVpL25neC1mbHlvdXQnO1xuaW1wb3J0IHsgU2VsZWN0YWJsZUxpc3RNb2R1bGUgfSBmcm9tICdAYWNwYWFzLXVpL25neC1zZWxlY3RhYmxlLWxpc3QnO1xuaW1wb3J0IHsgTWFza01vZHVsZSB9IGZyb20gJy4uL21hc2svbWFzay5tb2R1bGUnO1xuaW1wb3J0IHsgU2VhcmNoU2VydmljZSB9IGZyb20gJy4uL3NoYXJlZC9zZXJ2aWNlcy9zZWFyY2guc2VydmljZSc7XG5pbXBvcnQgeyBBdXRvQ29tcGxldGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYXV0by1jb21wbGV0ZS9hdXRvLWNvbXBsZXRlLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEZvcm1zTW9kdWxlLCBGbHlvdXRNb2R1bGUsIFNlbGVjdGFibGVMaXN0TW9kdWxlLCBNYXNrTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbQXV0b0NvbXBsZXRlQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW0F1dG9Db21wbGV0ZUNvbXBvbmVudF0sXG4gIHByb3ZpZGVyczogW1NlYXJjaFNlcnZpY2VdLFxufSlcbmV4cG9ydCBjbGFzcyBBdXRvQ29tcGxldGVNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,370 @@
|
|
|
1
|
+
import { Component, ContentChild, EventEmitter, forwardRef, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { get, isEqual } from 'lodash-es';
|
|
4
|
+
import { FlyoutDirective, FlyoutZoneDirective } from '@acpaas-ui/ngx-flyout';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../../shared/services/search.service";
|
|
7
|
+
import * as i2 from "@angular/common";
|
|
8
|
+
import * as i3 from "@angular/forms";
|
|
9
|
+
import * as i4 from "@acpaas-ui/ngx-flyout";
|
|
10
|
+
import * as i5 from "@acpaas-ui/ngx-selectable-list";
|
|
11
|
+
import * as i6 from "../../../mask/directives/mask.directive";
|
|
12
|
+
function AutoCompleteComponent_input_1_Template(rf, ctx) { if (rf & 1) {
|
|
13
|
+
const _r4 = i0.ɵɵgetCurrentView();
|
|
14
|
+
i0.ɵɵelementStart(0, "input", 4);
|
|
15
|
+
i0.ɵɵlistener("focus", function AutoCompleteComponent_input_1_Template_input_focus_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.onFocus()); })("keyArrowDown", function AutoCompleteComponent_input_1_Template_input_keyArrowDown_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r5 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r5.onKeyArrowDown()); })("keyArrowUp", function AutoCompleteComponent_input_1_Template_input_keyArrowUp_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r6 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r6.onKeyArrowUp()); })("keyEnter", function AutoCompleteComponent_input_1_Template_input_keyEnter_0_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r7 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r7.onKeyEnter($event)); })("keyEscape", function AutoCompleteComponent_input_1_Template_input_keyEscape_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r8 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r8.onKeyEscape()); })("ngModelChange", function AutoCompleteComponent_input_1_Template_input_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r4); const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.query = $event); })("ngModelChange", function AutoCompleteComponent_input_1_Template_input_ngModelChange_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r10 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r10.doSearch()); });
|
|
16
|
+
i0.ɵɵelementEnd();
|
|
17
|
+
} if (rf & 2) {
|
|
18
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
19
|
+
i0.ɵɵproperty("ngModel", ctx_r0.query)("disabled", ctx_r0.isDisabled ? true : null)("id", ctx_r0.id)("placeholder", ctx_r0.placeholder)("autocomplete", ctx_r0.autoComplete);
|
|
20
|
+
} }
|
|
21
|
+
function AutoCompleteComponent_input_2_Template(rf, ctx) { if (rf & 1) {
|
|
22
|
+
const _r12 = i0.ɵɵgetCurrentView();
|
|
23
|
+
i0.ɵɵelementStart(0, "input", 5);
|
|
24
|
+
i0.ɵɵlistener("focus", function AutoCompleteComponent_input_2_Template_input_focus_0_listener() { i0.ɵɵrestoreView(_r12); const ctx_r11 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r11.onFocus()); })("keyArrowDown", function AutoCompleteComponent_input_2_Template_input_keyArrowDown_0_listener() { i0.ɵɵrestoreView(_r12); const ctx_r13 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r13.onKeyArrowDown()); })("keyArrowUp", function AutoCompleteComponent_input_2_Template_input_keyArrowUp_0_listener() { i0.ɵɵrestoreView(_r12); const ctx_r14 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r14.onKeyArrowUp()); })("keyEnter", function AutoCompleteComponent_input_2_Template_input_keyEnter_0_listener($event) { i0.ɵɵrestoreView(_r12); const ctx_r15 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r15.onKeyEnter($event)); })("keyEscape", function AutoCompleteComponent_input_2_Template_input_keyEscape_0_listener() { i0.ɵɵrestoreView(_r12); const ctx_r16 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r16.onKeyEscape()); })("ngModelChange", function AutoCompleteComponent_input_2_Template_input_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r12); const ctx_r17 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r17.query = $event); })("ngModelChange", function AutoCompleteComponent_input_2_Template_input_ngModelChange_0_listener() { i0.ɵɵrestoreView(_r12); const ctx_r18 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r18.doSearch()); });
|
|
25
|
+
i0.ɵɵelementEnd();
|
|
26
|
+
} if (rf & 2) {
|
|
27
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
28
|
+
i0.ɵɵproperty("ngModel", ctx_r1.query)("auiMask", ctx_r1.mask)("disabled", ctx_r1.isDisabled ? true : null)("id", ctx_r1.id)("placeholder", ctx_r1.placeholder)("autocomplete", ctx_r1.autoComplete);
|
|
29
|
+
} }
|
|
30
|
+
function AutoCompleteComponent_div_3_span_1_Template(rf, ctx) { if (rf & 1) {
|
|
31
|
+
i0.ɵɵelementStart(0, "span", 10);
|
|
32
|
+
i0.ɵɵelement(1, "span", 11);
|
|
33
|
+
i0.ɵɵelementStart(2, "span", 12);
|
|
34
|
+
i0.ɵɵtext(3);
|
|
35
|
+
i0.ɵɵelementEnd()();
|
|
36
|
+
} if (rf & 2) {
|
|
37
|
+
const ctx_r19 = i0.ɵɵnextContext(2);
|
|
38
|
+
i0.ɵɵadvance(3);
|
|
39
|
+
i0.ɵɵtextInterpolate(ctx_r19.loadingText);
|
|
40
|
+
} }
|
|
41
|
+
function AutoCompleteComponent_div_3_span_2_Template(rf, ctx) { if (rf & 1) {
|
|
42
|
+
i0.ɵɵelementStart(0, "span", 13);
|
|
43
|
+
i0.ɵɵtext(1);
|
|
44
|
+
i0.ɵɵelementEnd();
|
|
45
|
+
} if (rf & 2) {
|
|
46
|
+
const ctx_r20 = i0.ɵɵnextContext(2);
|
|
47
|
+
i0.ɵɵadvance(1);
|
|
48
|
+
i0.ɵɵtextInterpolate(ctx_r20.searchIncentiveText);
|
|
49
|
+
} }
|
|
50
|
+
function AutoCompleteComponent_div_3_span_3_Template(rf, ctx) { if (rf & 1) {
|
|
51
|
+
i0.ɵɵelementStart(0, "span", 13);
|
|
52
|
+
i0.ɵɵtext(1);
|
|
53
|
+
i0.ɵɵelementEnd();
|
|
54
|
+
} if (rf & 2) {
|
|
55
|
+
const ctx_r21 = i0.ɵɵnextContext(2);
|
|
56
|
+
i0.ɵɵadvance(1);
|
|
57
|
+
i0.ɵɵtextInterpolate(ctx_r21.noResultsText);
|
|
58
|
+
} }
|
|
59
|
+
function AutoCompleteComponent_div_3_aui_selectable_list_4_Template(rf, ctx) { if (rf & 1) {
|
|
60
|
+
const _r24 = i0.ɵɵgetCurrentView();
|
|
61
|
+
i0.ɵɵelementStart(0, "aui-selectable-list", 14);
|
|
62
|
+
i0.ɵɵlistener("selected", function AutoCompleteComponent_div_3_aui_selectable_list_4_Template_aui_selectable_list_selected_0_listener($event) { i0.ɵɵrestoreView(_r24); const ctx_r23 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r23.onSelect($event)); });
|
|
63
|
+
i0.ɵɵelementEnd();
|
|
64
|
+
} if (rf & 2) {
|
|
65
|
+
const ctx_r22 = i0.ɵɵnextContext(2);
|
|
66
|
+
i0.ɵɵproperty("index", ctx_r22.index)("itemTemplate", ctx_r22.template)("items", ctx_r22.results)("label", ctx_r22.label)("search", ctx_r22.query);
|
|
67
|
+
} }
|
|
68
|
+
function AutoCompleteComponent_div_3_Template(rf, ctx) { if (rf & 1) {
|
|
69
|
+
i0.ɵɵelementStart(0, "div", 6);
|
|
70
|
+
i0.ɵɵtemplate(1, AutoCompleteComponent_div_3_span_1_Template, 4, 1, "span", 7);
|
|
71
|
+
i0.ɵɵtemplate(2, AutoCompleteComponent_div_3_span_2_Template, 2, 1, "span", 8);
|
|
72
|
+
i0.ɵɵtemplate(3, AutoCompleteComponent_div_3_span_3_Template, 2, 1, "span", 8);
|
|
73
|
+
i0.ɵɵtemplate(4, AutoCompleteComponent_div_3_aui_selectable_list_4_Template, 1, 5, "aui-selectable-list", 9);
|
|
74
|
+
i0.ɵɵelementEnd();
|
|
75
|
+
} if (rf & 2) {
|
|
76
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
77
|
+
i0.ɵɵadvance(1);
|
|
78
|
+
i0.ɵɵproperty("ngIf", ctx_r2.focused && ctx_r2.loadingText && ctx_r2.searching);
|
|
79
|
+
i0.ɵɵadvance(1);
|
|
80
|
+
i0.ɵɵproperty("ngIf", ctx_r2.focused && ctx_r2.searchIncentiveText && !ctx_r2.searching && !ctx_r2.query && !ctx_r2.results.length);
|
|
81
|
+
i0.ɵɵadvance(1);
|
|
82
|
+
i0.ɵɵproperty("ngIf", ctx_r2.focused && ctx_r2.noResultsText && !ctx_r2.searching && ctx_r2.query && !ctx_r2.results.length);
|
|
83
|
+
i0.ɵɵadvance(1);
|
|
84
|
+
i0.ɵɵproperty("ngIf", ctx_r2.results.length > 0 && !(ctx_r2.focused && ctx_r2.loadingText && ctx_r2.searching));
|
|
85
|
+
} }
|
|
86
|
+
export class AutoCompleteComponent {
|
|
87
|
+
constructor(ref, searchService) {
|
|
88
|
+
this.ref = ref;
|
|
89
|
+
this.searchService = searchService;
|
|
90
|
+
this.results = []; // The values for the selectable list
|
|
91
|
+
this.data = []; // The values to search in when remote search is disabled
|
|
92
|
+
this.remote = false; // Disable or enamble remote search
|
|
93
|
+
this.minCharacters = 0;
|
|
94
|
+
this.mask = null;
|
|
95
|
+
this.clearInvalid = false;
|
|
96
|
+
this.showAllByDefault = false;
|
|
97
|
+
this.autoComplete = 'off';
|
|
98
|
+
// Eventemitter for searchvalue (parent object should update the results with this param)
|
|
99
|
+
this.search = new EventEmitter();
|
|
100
|
+
// eslint-disable-next-line @angular-eslint/no-output-native
|
|
101
|
+
this.select = new EventEmitter();
|
|
102
|
+
this.query = '';
|
|
103
|
+
this.index = -1; // index for active element in selectable list, by default -1 (so it starts in the input field)
|
|
104
|
+
this.selectedItem = null; // keep a backup of the selectedItem
|
|
105
|
+
this.searching = false; // track remote search state
|
|
106
|
+
this.focused = false;
|
|
107
|
+
this.isDisabled = false;
|
|
108
|
+
this.remoteValue = false;
|
|
109
|
+
this.updateModel = (_) => { };
|
|
110
|
+
}
|
|
111
|
+
// CONTROL_VALUE_ACCESSOR interface
|
|
112
|
+
writeValue(value = '') {
|
|
113
|
+
if (this.value) {
|
|
114
|
+
const selected = this.data.find((item) => item[this.value] === value);
|
|
115
|
+
if (selected) {
|
|
116
|
+
return (this.query = selected[this.label]);
|
|
117
|
+
}
|
|
118
|
+
if (this.remote && !!value) {
|
|
119
|
+
this.remoteValue = true;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
this.query = value;
|
|
123
|
+
}
|
|
124
|
+
// CONTROL_VALUE_ACCESSOR interface
|
|
125
|
+
registerOnChange(fn) {
|
|
126
|
+
this.updateModel = fn;
|
|
127
|
+
}
|
|
128
|
+
// CONTROL_VALUE_ACCESSOR interface
|
|
129
|
+
registerOnTouched() { }
|
|
130
|
+
setDisabledState(isDisabled) {
|
|
131
|
+
this.isDisabled = isDisabled;
|
|
132
|
+
}
|
|
133
|
+
ngOnInit() {
|
|
134
|
+
if (Array.isArray(this.data) && this.data.length > 0 && !this.query && this.showAllByDefault) {
|
|
135
|
+
this.results = [...this.data];
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
// OnChanges interface
|
|
139
|
+
ngOnChanges(changes) {
|
|
140
|
+
if (!changes) {
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
const newData = get(changes, 'data.currentValue', []);
|
|
144
|
+
if (!isEqual(newData, get(changes, 'data.previousValue', []))) {
|
|
145
|
+
if (this.remote) {
|
|
146
|
+
this.remoteSearch();
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
this.localSearch();
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
if (changes.results && changes.results.currentValue) {
|
|
153
|
+
this.searching = false;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
propagateChange(item) {
|
|
157
|
+
this.query = item !== null ? (this.label ? item[this.label] : item) : '';
|
|
158
|
+
this.select.emit(item);
|
|
159
|
+
if (!item) {
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
const key = this.value ? this.value : this.label ? this.label : null;
|
|
163
|
+
this.updateModel(key ? item[key] || '' : item);
|
|
164
|
+
this.selectedItem = item;
|
|
165
|
+
}
|
|
166
|
+
/**
|
|
167
|
+
* triggers on input value change
|
|
168
|
+
*/
|
|
169
|
+
doSearch() {
|
|
170
|
+
this.index = -1; // reset index
|
|
171
|
+
this.searching = true;
|
|
172
|
+
if (this.remote) {
|
|
173
|
+
this.search.emit(this.query); // ask for new remote data
|
|
174
|
+
}
|
|
175
|
+
else {
|
|
176
|
+
this.localSearch();
|
|
177
|
+
}
|
|
178
|
+
this.openFlyout(); // open the flyout when there is a change
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* triggers on selectable-list:select -> onClick event in selectable-list
|
|
182
|
+
*/
|
|
183
|
+
onSelect(item) {
|
|
184
|
+
this.propagateChange(item);
|
|
185
|
+
this.closeFlyout(); // Close the flyout manually
|
|
186
|
+
}
|
|
187
|
+
onFlyoutClosed() {
|
|
188
|
+
// there is only 1 result, select it
|
|
189
|
+
if (this.index >= 0 && this.results.length === 1) {
|
|
190
|
+
return this.onSelect(this.results[0]);
|
|
191
|
+
}
|
|
192
|
+
// there is no query nor selected item, clear the selected item
|
|
193
|
+
if (!this.query && this.index < 0) {
|
|
194
|
+
return this.onSelect(null);
|
|
195
|
+
}
|
|
196
|
+
// reset the query for an invalid query if clearInvalid is true
|
|
197
|
+
if (this.clearInvalid && this.query && !this.results.length && this.index < 0) {
|
|
198
|
+
this.query = this.selectedItem ? (this.label ? this.selectedItem[this.label] : this.selectedItem) : '';
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
onKeyArrowDown() {
|
|
202
|
+
if (this.index < this.results.length - 1) {
|
|
203
|
+
this.scrollList(1);
|
|
204
|
+
}
|
|
205
|
+
this.openFlyout();
|
|
206
|
+
}
|
|
207
|
+
onKeyArrowUp() {
|
|
208
|
+
if (this.index >= 0) {
|
|
209
|
+
this.scrollList(-1);
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
onKeyEnter(event) {
|
|
213
|
+
event.preventDefault(); // Do not submit form when selecting an item.
|
|
214
|
+
const query = this.index >= 0 ? this.results[this.index] : this.query;
|
|
215
|
+
this.propagateChange(query);
|
|
216
|
+
this.closeFlyout();
|
|
217
|
+
}
|
|
218
|
+
onKeyEscape() {
|
|
219
|
+
this.closeFlyout();
|
|
220
|
+
}
|
|
221
|
+
onFocus() {
|
|
222
|
+
this.focused = true;
|
|
223
|
+
this.openFlyout();
|
|
224
|
+
}
|
|
225
|
+
openFlyout() {
|
|
226
|
+
if (this.flyout) {
|
|
227
|
+
this.flyout.open();
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
closeFlyout() {
|
|
231
|
+
if (this.flyout) {
|
|
232
|
+
this.flyout.close();
|
|
233
|
+
}
|
|
234
|
+
this.focused = false;
|
|
235
|
+
}
|
|
236
|
+
localSearch() {
|
|
237
|
+
this.results = this.searchService.search(this.data, {
|
|
238
|
+
minLength: this.minCharacters,
|
|
239
|
+
key: this.label,
|
|
240
|
+
query: this.query,
|
|
241
|
+
showAllByDefault: this.showAllByDefault,
|
|
242
|
+
});
|
|
243
|
+
if (this.results.length === 1 && this.query === this.results[0][this.label]) {
|
|
244
|
+
this.index = 0;
|
|
245
|
+
}
|
|
246
|
+
this.searching = false;
|
|
247
|
+
}
|
|
248
|
+
remoteSearch() {
|
|
249
|
+
if (!this.remoteValue || !this.data) {
|
|
250
|
+
return;
|
|
251
|
+
}
|
|
252
|
+
const selected = this.data.find((item) => {
|
|
253
|
+
if (this.value) {
|
|
254
|
+
return item[this.value] === this.query;
|
|
255
|
+
}
|
|
256
|
+
return item === this.query;
|
|
257
|
+
});
|
|
258
|
+
if (selected) {
|
|
259
|
+
this.query = this.label ? selected[this.label] : selected;
|
|
260
|
+
}
|
|
261
|
+
else {
|
|
262
|
+
this.query = '';
|
|
263
|
+
}
|
|
264
|
+
this.remoteValue = false;
|
|
265
|
+
}
|
|
266
|
+
scrollList(factor) {
|
|
267
|
+
this.index += factor;
|
|
268
|
+
if (!this.flyoutZone) {
|
|
269
|
+
return;
|
|
270
|
+
}
|
|
271
|
+
const liItems = this.flyoutZone.element.getElementsByTagName('li');
|
|
272
|
+
const liHeight = liItems[1] ? liItems[1].offsetHeight : liItems[0].offsetHeight;
|
|
273
|
+
const zoneHeight = this.flyoutZone.element.offsetHeight;
|
|
274
|
+
const offset = zoneHeight / liHeight / 2;
|
|
275
|
+
this.flyoutZone.element.scrollTop = this.index * liHeight - offset * liHeight;
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
/** @nocollapse */ AutoCompleteComponent.ɵfac = function AutoCompleteComponent_Factory(t) { return new (t || AutoCompleteComponent)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i1.SearchService)); };
|
|
279
|
+
/** @nocollapse */ AutoCompleteComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: AutoCompleteComponent, selectors: [["aui-auto-complete"]], contentQueries: function AutoCompleteComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
|
|
280
|
+
i0.ɵɵcontentQuery(dirIndex, TemplateRef, 7);
|
|
281
|
+
} if (rf & 2) {
|
|
282
|
+
let _t;
|
|
283
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.template = _t.first);
|
|
284
|
+
} }, viewQuery: function AutoCompleteComponent_Query(rf, ctx) { if (rf & 1) {
|
|
285
|
+
i0.ɵɵviewQuery(FlyoutDirective, 7);
|
|
286
|
+
i0.ɵɵviewQuery(FlyoutZoneDirective, 7);
|
|
287
|
+
} if (rf & 2) {
|
|
288
|
+
let _t;
|
|
289
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.flyout = _t.first);
|
|
290
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.flyoutZone = _t.first);
|
|
291
|
+
} }, inputs: { id: "id", placeholder: "placeholder", description: "description", inputLabel: "inputLabel", results: "results", data: "data", remote: "remote", minCharacters: "minCharacters", mask: "mask", clearInvalid: "clearInvalid", searchIncentiveText: "searchIncentiveText", loadingText: "loadingText", noResultsText: "noResultsText", showAllByDefault: "showAllByDefault", autoComplete: "autoComplete", label: "label", value: "value" }, outputs: { search: "search", select: "select" }, features: [i0.ɵɵProvidersFeature([
|
|
292
|
+
{
|
|
293
|
+
provide: NG_VALUE_ACCESSOR,
|
|
294
|
+
useExisting: forwardRef((() => AutoCompleteComponent)),
|
|
295
|
+
multi: true,
|
|
296
|
+
},
|
|
297
|
+
]), i0.ɵɵNgOnChangesFeature], decls: 4, vars: 4, consts: [["aria-haspopup", "listbox", "auiFlyout", "", 1, "m-flyout", "m-flyout--scrollable", "m-flyout--full", "o-auto-complete", 3, "toggleClick", "closed"], ["aria-autocomplete", "list", "auiFlyoutAction", "", "auiSelectableActions", "", "type", "text", "class", "a-input", 3, "ngModel", "disabled", "id", "placeholder", "autocomplete", "focus", "keyArrowDown", "keyArrowUp", "keyEnter", "keyEscape", "ngModelChange", 4, "ngIf"], ["aria-autocomplete", "list", "auiFlyoutAction", "", "auiSelectableActions", "", "type", "text", "class", "a-input", 3, "ngModel", "auiMask", "disabled", "id", "placeholder", "autocomplete", "focus", "keyArrowDown", "keyArrowUp", "keyEnter", "keyEscape", "ngModelChange", 4, "ngIf"], ["auiFlyoutZone", "", 4, "ngIf"], ["aria-autocomplete", "list", "auiFlyoutAction", "", "auiSelectableActions", "", "type", "text", 1, "a-input", 3, "ngModel", "disabled", "id", "placeholder", "autocomplete", "focus", "keyArrowDown", "keyArrowUp", "keyEnter", "keyEscape", "ngModelChange"], ["aria-autocomplete", "list", "auiFlyoutAction", "", "auiSelectableActions", "", "type", "text", 1, "a-input", 3, "ngModel", "auiMask", "disabled", "id", "placeholder", "autocomplete", "focus", "keyArrowDown", "keyArrowUp", "keyEnter", "keyEscape", "ngModelChange"], ["auiFlyoutZone", ""], ["class", "a-spinner a-spinner--s u-margin-xs", "role", "alert", 4, "ngIf"], ["class", "o-auto-complete__info u-text-light u-margin-xs", 4, "ngIf"], [3, "index", "itemTemplate", "items", "label", "search", "selected", 4, "ngIf"], ["role", "alert", 1, "a-spinner", "a-spinner--s", "u-margin-xs"], [1, "a-spinner__circle"], [1, "a-spinner__text"], [1, "o-auto-complete__info", "u-text-light", "u-margin-xs"], [3, "index", "itemTemplate", "items", "label", "search", "selected"]], template: function AutoCompleteComponent_Template(rf, ctx) { if (rf & 1) {
|
|
298
|
+
i0.ɵɵelementStart(0, "div", 0);
|
|
299
|
+
i0.ɵɵlistener("closed", function AutoCompleteComponent_Template_div_closed_0_listener() { return ctx.onFlyoutClosed(); });
|
|
300
|
+
i0.ɵɵtemplate(1, AutoCompleteComponent_input_1_Template, 1, 5, "input", 1);
|
|
301
|
+
i0.ɵɵtemplate(2, AutoCompleteComponent_input_2_Template, 1, 6, "input", 2);
|
|
302
|
+
i0.ɵɵtemplate(3, AutoCompleteComponent_div_3_Template, 5, 4, "div", 3);
|
|
303
|
+
i0.ɵɵelementEnd();
|
|
304
|
+
} if (rf & 2) {
|
|
305
|
+
i0.ɵɵproperty("toggleClick", false);
|
|
306
|
+
i0.ɵɵadvance(1);
|
|
307
|
+
i0.ɵɵproperty("ngIf", !ctx.mask);
|
|
308
|
+
i0.ɵɵadvance(1);
|
|
309
|
+
i0.ɵɵproperty("ngIf", ctx.mask);
|
|
310
|
+
i0.ɵɵadvance(1);
|
|
311
|
+
i0.ɵɵproperty("ngIf", !ctx.isDisabled);
|
|
312
|
+
} }, dependencies: [i2.NgIf, i3.DefaultValueAccessor, i3.NgControlStatus, i3.NgModel, i4.FlyoutActionDirective, i4.FlyoutZoneDirective, i4.FlyoutDirective, i5.SelectableListComponent, i5.SelectableActionsDirective, i6.MaskDirective], styles: [".o-auto-complete[_ngcontent-%COMP%], .o-auto-complete__info[_ngcontent-%COMP%]{display:block}"] });
|
|
313
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(AutoCompleteComponent, [{
|
|
314
|
+
type: Component,
|
|
315
|
+
args: [{ selector: 'aui-auto-complete', providers: [
|
|
316
|
+
{
|
|
317
|
+
provide: NG_VALUE_ACCESSOR,
|
|
318
|
+
useExisting: forwardRef((() => AutoCompleteComponent)),
|
|
319
|
+
multi: true,
|
|
320
|
+
},
|
|
321
|
+
], template: "<div\n (closed)=\"onFlyoutClosed()\"\n [toggleClick]=\"false\"\n aria-haspopup=\"listbox\"\n auiFlyout\n class=\"m-flyout m-flyout--scrollable m-flyout--full o-auto-complete\"\n>\n <input\n (focus)=\"onFocus()\"\n (keyArrowDown)=\"onKeyArrowDown()\"\n (keyArrowUp)=\"onKeyArrowUp()\"\n (keyEnter)=\"onKeyEnter($event)\"\n (keyEscape)=\"onKeyEscape()\"\n [(ngModel)]=\"query\"\n (ngModelChange)=\"doSearch()\"\n *ngIf=\"!mask\"\n [disabled]=\"isDisabled ? true : null\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n aria-autocomplete=\"list\"\n auiFlyoutAction\n auiSelectableActions\n [autocomplete]=\"autoComplete\"\n type=\"text\"\n class=\"a-input\"\n />\n <input\n (focus)=\"onFocus()\"\n (keyArrowDown)=\"onKeyArrowDown()\"\n (keyArrowUp)=\"onKeyArrowUp()\"\n (keyEnter)=\"onKeyEnter($event)\"\n (keyEscape)=\"onKeyEscape()\"\n [(ngModel)]=\"query\"\n (ngModelChange)=\"doSearch()\"\n *ngIf=\"mask\"\n [auiMask]=\"mask\"\n [disabled]=\"isDisabled ? true : null\"\n [id]=\"id\"\n [placeholder]=\"placeholder\"\n aria-autocomplete=\"list\"\n auiFlyoutAction\n auiSelectableActions\n [autocomplete]=\"autoComplete\"\n type=\"text\"\n class=\"a-input\"\n />\n <div *ngIf=\"!isDisabled\" auiFlyoutZone>\n <span *ngIf=\"focused && loadingText && searching\" class=\"a-spinner a-spinner--s u-margin-xs\" role=\"alert\">\n <span class=\"a-spinner__circle\"></span>\n <span class=\"a-spinner__text\">{{ loadingText }}</span>\n </span>\n <span\n *ngIf=\"focused && searchIncentiveText && !searching && !query && !results.length\"\n class=\"o-auto-complete__info u-text-light u-margin-xs\"\n >{{ searchIncentiveText }}</span\n >\n <span\n *ngIf=\"focused && noResultsText && !searching && query && !results.length\"\n class=\"o-auto-complete__info u-text-light u-margin-xs\"\n >{{ noResultsText }}</span\n >\n <aui-selectable-list\n (selected)=\"onSelect($event)\"\n *ngIf=\"results.length > 0 && !(focused && loadingText && searching)\"\n [index]=\"index\"\n [itemTemplate]=\"template\"\n [items]=\"results\"\n [label]=\"label\"\n [search]=\"query\"\n ></aui-selectable-list>\n </div>\n</div>\n", styles: [".o-auto-complete,.o-auto-complete__info{display:block}\n"] }]
|
|
322
|
+
}], function () { return [{ type: i0.ElementRef }, { type: i1.SearchService }]; }, { id: [{
|
|
323
|
+
type: Input
|
|
324
|
+
}], placeholder: [{
|
|
325
|
+
type: Input
|
|
326
|
+
}], description: [{
|
|
327
|
+
type: Input
|
|
328
|
+
}], inputLabel: [{
|
|
329
|
+
type: Input
|
|
330
|
+
}], results: [{
|
|
331
|
+
type: Input
|
|
332
|
+
}], data: [{
|
|
333
|
+
type: Input
|
|
334
|
+
}], remote: [{
|
|
335
|
+
type: Input
|
|
336
|
+
}], minCharacters: [{
|
|
337
|
+
type: Input
|
|
338
|
+
}], mask: [{
|
|
339
|
+
type: Input
|
|
340
|
+
}], clearInvalid: [{
|
|
341
|
+
type: Input
|
|
342
|
+
}], searchIncentiveText: [{
|
|
343
|
+
type: Input
|
|
344
|
+
}], loadingText: [{
|
|
345
|
+
type: Input
|
|
346
|
+
}], noResultsText: [{
|
|
347
|
+
type: Input
|
|
348
|
+
}], showAllByDefault: [{
|
|
349
|
+
type: Input
|
|
350
|
+
}], autoComplete: [{
|
|
351
|
+
type: Input
|
|
352
|
+
}], label: [{
|
|
353
|
+
type: Input
|
|
354
|
+
}], value: [{
|
|
355
|
+
type: Input
|
|
356
|
+
}], search: [{
|
|
357
|
+
type: Output
|
|
358
|
+
}], select: [{
|
|
359
|
+
type: Output
|
|
360
|
+
}], flyout: [{
|
|
361
|
+
type: ViewChild,
|
|
362
|
+
args: [FlyoutDirective, { static: true }]
|
|
363
|
+
}], flyoutZone: [{
|
|
364
|
+
type: ViewChild,
|
|
365
|
+
args: [FlyoutZoneDirective, { static: true }]
|
|
366
|
+
}], template: [{
|
|
367
|
+
type: ContentChild,
|
|
368
|
+
args: [TemplateRef, { static: true }]
|
|
369
|
+
}] }); })();
|
|
370
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-complete.component.js","sourceRoot":"","sources":["../../../../../../src/lib/auto-complete/components/auto-complete/auto-complete.component.ts","../../../../../../src/lib/auto-complete/components/auto-complete/auto-complete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { get, isEqual } from 'lodash-es';\nimport { FlyoutDirective, FlyoutZoneDirective } from '@acpaas-ui/ngx-flyout';\nimport { SearchService } from '../../../shared/services/search.service';\n\n@Component({\n  selector: 'aui-auto-complete',\n  styleUrls: ['./auto-complete.component.scss'],\n  templateUrl: './auto-complete.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AutoCompleteComponent), // eslint-disable-line\n      multi: true,\n    },\n  ],\n})\nexport class AutoCompleteComponent implements ControlValueAccessor, OnInit, OnChanges {\n  @Input() id: string;\n  @Input() placeholder: string;\n  @Input() description: string;\n  @Input() inputLabel: string;\n  @Input() results: any[] = []; // The values for the selectable list\n  @Input() data: any[] = []; // The values to search in when remote search is disabled\n  @Input() remote = false; // Disable or enamble remote search\n  @Input() minCharacters = 0;\n  @Input() mask: string = null;\n  @Input() clearInvalid = false;\n  @Input() searchIncentiveText: string;\n  @Input() loadingText: string;\n  @Input() noResultsText: string;\n  @Input() showAllByDefault = false;\n  @Input() autoComplete = 'off';\n\n  // specify which label/value props to use\n  @Input() label: string;\n  @Input() value: string;\n\n  // Eventemitter for searchvalue (parent object should update the results with this param)\n  @Output() search: EventEmitter<string> = new EventEmitter();\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() select: EventEmitter<any> = new EventEmitter();\n\n  @ViewChild(FlyoutDirective, { static: true }) flyout: FlyoutDirective;\n  @ViewChild(FlyoutZoneDirective, { static: true }) flyoutZone: FlyoutZoneDirective;\n\n  @ContentChild(TemplateRef, { static: true }) public template: TemplateRef<any>;\n\n  public query = '';\n  public index = -1; // index for active element in selectable list, by default -1 (so it starts in the input field)\n  public selectedItem: any = null; // keep a backup of the selectedItem\n  public searching = false; // track remote search state\n  public focused = false;\n  public isDisabled = false;\n\n  private remoteValue = false;\n\n  constructor(private ref: ElementRef, private searchService: SearchService) {}\n\n  public updateModel = (_: any) => {};\n\n  // CONTROL_VALUE_ACCESSOR interface\n  public writeValue(value = '') {\n    if (this.value) {\n      const selected = this.data.find((item: any) => item[this.value] === value);\n\n      if (selected) {\n        return (this.query = selected[this.label]);\n      }\n\n      if (this.remote && !!value) {\n        this.remoteValue = true;\n      }\n    }\n\n    this.query = value;\n  }\n\n  // CONTROL_VALUE_ACCESSOR interface\n  public registerOnChange(fn) {\n    this.updateModel = fn;\n  }\n\n  // CONTROL_VALUE_ACCESSOR interface\n  public registerOnTouched() {}\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n  }\n\n  public ngOnInit(): void {\n    if (Array.isArray(this.data) && this.data.length > 0 && !this.query && this.showAllByDefault) {\n      this.results = [...this.data];\n    }\n  }\n\n  // OnChanges interface\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (!changes) {\n      return;\n    }\n\n    const newData = get(changes, 'data.currentValue', []);\n    if (!isEqual(newData, get(changes, 'data.previousValue', []))) {\n      if (this.remote) {\n        this.remoteSearch();\n      } else {\n        this.localSearch();\n      }\n    }\n\n    if (changes.results && changes.results.currentValue) {\n      this.searching = false;\n    }\n  }\n\n  public propagateChange(item: any) {\n    this.query = item !== null ? (this.label ? item[this.label] : item) : '';\n    this.select.emit(item);\n\n    if (!item) {\n      return;\n    }\n\n    const key = this.value ? this.value : this.label ? this.label : null;\n    this.updateModel(key ? item[key] || '' : item);\n    this.selectedItem = item;\n  }\n\n  /**\n   * triggers on input value change\n   */\n  public doSearch(): void {\n    this.index = -1; // reset index\n    this.searching = true;\n\n    if (this.remote) {\n      this.search.emit(this.query); // ask for new remote data\n    } else {\n      this.localSearch();\n    }\n\n    this.openFlyout(); // open the flyout when there is a change\n  }\n\n  /**\n   * triggers on selectable-list:select -> onClick event in selectable-list\n   */\n  public onSelect(item: any): void {\n    this.propagateChange(item);\n    this.closeFlyout(); // Close the flyout manually\n  }\n\n  public onFlyoutClosed(): void {\n    // there is only 1 result, select it\n    if (this.index >= 0 && this.results.length === 1) {\n      return this.onSelect(this.results[0]);\n    }\n\n    // there is no query nor selected item, clear the selected item\n    if (!this.query && this.index < 0) {\n      return this.onSelect(null);\n    }\n\n    // reset the query for an invalid query if clearInvalid is true\n    if (this.clearInvalid && this.query && !this.results.length && this.index < 0) {\n      this.query = this.selectedItem ? (this.label ? this.selectedItem[this.label] : this.selectedItem) : '';\n    }\n  }\n\n  public onKeyArrowDown(): void {\n    if (this.index < this.results.length - 1) {\n      this.scrollList(1);\n    }\n\n    this.openFlyout();\n  }\n\n  public onKeyArrowUp(): void {\n    if (this.index >= 0) {\n      this.scrollList(-1);\n    }\n  }\n\n  public onKeyEnter(event: Event): void {\n    event.preventDefault(); // Do not submit form when selecting an item.\n\n    const query = this.index >= 0 ? this.results[this.index] : this.query;\n\n    this.propagateChange(query);\n    this.closeFlyout();\n  }\n\n  public onKeyEscape(): void {\n    this.closeFlyout();\n  }\n\n  public onFocus(): void {\n    this.focused = true;\n    this.openFlyout();\n  }\n\n  public openFlyout(): void {\n    if (this.flyout) {\n      this.flyout.open();\n    }\n  }\n\n  public closeFlyout(): void {\n    if (this.flyout) {\n      this.flyout.close();\n    }\n\n    this.focused = false;\n  }\n\n  public localSearch(): void {\n    this.results = this.searchService.search(this.data, {\n      minLength: this.minCharacters,\n      key: this.label,\n      query: this.query,\n      showAllByDefault: this.showAllByDefault,\n    });\n\n    if (this.results.length === 1 && this.query === this.results[0][this.label]) {\n      this.index = 0;\n    }\n\n    this.searching = false;\n  }\n\n  public remoteSearch(): void {\n    if (!this.remoteValue || !this.data) {\n      return;\n    }\n\n    const selected = this.data.find((item: any) => {\n      if (this.value) {\n        return item[this.value] === this.query;\n      }\n\n      return item === this.query;\n    });\n\n    if (selected) {\n      this.query = this.label ? selected[this.label] : selected;\n    } else {\n      this.query = '';\n    }\n\n    this.remoteValue = false;\n  }\n\n  public scrollList(factor: number): void {\n    this.index += factor;\n\n    if (!this.flyoutZone) {\n      return;\n    }\n\n    const liItems = this.flyoutZone.element.getElementsByTagName('li');\n    const liHeight = liItems[1] ? liItems[1].offsetHeight : liItems[0].offsetHeight;\n    const zoneHeight = this.flyoutZone.element.offsetHeight;\n    const offset = zoneHeight / liHeight / 2;\n\n    this.flyoutZone.element.scrollTop = this.index * liHeight - offset * liHeight;\n  }\n}\n","<div\n  (closed)=\"onFlyoutClosed()\"\n  [toggleClick]=\"false\"\n  aria-haspopup=\"listbox\"\n  auiFlyout\n  class=\"m-flyout m-flyout--scrollable m-flyout--full o-auto-complete\"\n>\n  <input\n    (focus)=\"onFocus()\"\n    (keyArrowDown)=\"onKeyArrowDown()\"\n    (keyArrowUp)=\"onKeyArrowUp()\"\n    (keyEnter)=\"onKeyEnter($event)\"\n    (keyEscape)=\"onKeyEscape()\"\n    [(ngModel)]=\"query\"\n    (ngModelChange)=\"doSearch()\"\n    *ngIf=\"!mask\"\n    [disabled]=\"isDisabled ? true : null\"\n    [id]=\"id\"\n    [placeholder]=\"placeholder\"\n    aria-autocomplete=\"list\"\n    auiFlyoutAction\n    auiSelectableActions\n    [autocomplete]=\"autoComplete\"\n    type=\"text\"\n    class=\"a-input\"\n  />\n  <input\n    (focus)=\"onFocus()\"\n    (keyArrowDown)=\"onKeyArrowDown()\"\n    (keyArrowUp)=\"onKeyArrowUp()\"\n    (keyEnter)=\"onKeyEnter($event)\"\n    (keyEscape)=\"onKeyEscape()\"\n    [(ngModel)]=\"query\"\n    (ngModelChange)=\"doSearch()\"\n    *ngIf=\"mask\"\n    [auiMask]=\"mask\"\n    [disabled]=\"isDisabled ? true : null\"\n    [id]=\"id\"\n    [placeholder]=\"placeholder\"\n    aria-autocomplete=\"list\"\n    auiFlyoutAction\n    auiSelectableActions\n    [autocomplete]=\"autoComplete\"\n    type=\"text\"\n    class=\"a-input\"\n  />\n  <div *ngIf=\"!isDisabled\" auiFlyoutZone>\n    <span *ngIf=\"focused && loadingText && searching\" class=\"a-spinner a-spinner--s u-margin-xs\" role=\"alert\">\n      <span class=\"a-spinner__circle\"></span>\n      <span class=\"a-spinner__text\">{{ loadingText }}</span>\n    </span>\n    <span\n      *ngIf=\"focused && searchIncentiveText && !searching && !query && !results.length\"\n      class=\"o-auto-complete__info u-text-light u-margin-xs\"\n      >{{ searchIncentiveText }}</span\n    >\n    <span\n      *ngIf=\"focused && noResultsText && !searching && query && !results.length\"\n      class=\"o-auto-complete__info u-text-light u-margin-xs\"\n      >{{ noResultsText }}</span\n    >\n    <aui-selectable-list\n      (selected)=\"onSelect($event)\"\n      *ngIf=\"results.length > 0 && !(focused && loadingText && searching)\"\n      [index]=\"index\"\n      [itemTemplate]=\"template\"\n      [items]=\"results\"\n      [label]=\"label\"\n      [search]=\"query\"\n    ></aui-selectable-list>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { AutoCompleteModule } from './auto-complete.module';
|
|
2
|
+
export { AutoCompleteComponent } from './components/auto-complete/auto-complete.component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvYXV0by1jb21wbGV0ZS9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzVELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLG9EQUFvRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQXV0b0NvbXBsZXRlTW9kdWxlIH0gZnJvbSAnLi9hdXRvLWNvbXBsZXRlLm1vZHVsZSc7XG5leHBvcnQgeyBBdXRvQ29tcGxldGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYXV0by1jb21wbGV0ZS9hdXRvLWNvbXBsZXRlLmNvbXBvbmVudCc7XG4iXX0=
|