@recursyve/nice-ui-kit.v2 13.1.0-beta.91 → 13.2.0-beta.100

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/_index.scss +0 -1
  2. package/esm2020/lib/api/nice.api.mjs +2 -1
  3. package/esm2020/lib/components/alert/alert.component.mjs +22 -10
  4. package/esm2020/lib/components/alert/alert.types.mjs +1 -1
  5. package/esm2020/lib/components/async-typeahead/async-typeahead.component.mjs +9 -5
  6. package/esm2020/lib/components/base-form/base-form.component.mjs +20 -5
  7. package/esm2020/lib/components/form-error/control-status.directive.mjs +21 -14
  8. package/esm2020/lib/components/navigation/vertical/vertical.component.mjs +8 -6
  9. package/esm2020/lib/components/sweet-alert/sweet-alert.component.mjs +3 -3
  10. package/esm2020/lib/components/toast/toast.component.mjs +1 -1
  11. package/esm2020/lib/directives/chip-async-typeahead/chip-async-typeahead.directive.mjs +39 -0
  12. package/esm2020/lib/directives/chip-async-typeahead/index.mjs +2 -0
  13. package/esm2020/lib/directives/chip-async-typeahead/public-api.mjs +2 -0
  14. package/esm2020/lib/directives/chip-list/chip-list-items/chip-list-item-label.directive.mjs +14 -0
  15. package/esm2020/lib/directives/chip-list/chip-list-items/chip-list-items.component.mjs +32 -0
  16. package/esm2020/lib/directives/chip-list/chip-list.directive.mjs +100 -0
  17. package/esm2020/lib/directives/chip-list/chip-list.module.mjs +21 -0
  18. package/esm2020/lib/directives/chip-list/index.mjs +2 -0
  19. package/esm2020/lib/directives/chip-list/public-api.mjs +5 -0
  20. package/esm2020/lib/directives/public-api.mjs +3 -1
  21. package/fesm2015/recursyve-nice-ui-kit.v2.mjs +245 -39
  22. package/fesm2015/recursyve-nice-ui-kit.v2.mjs.map +1 -1
  23. package/fesm2020/recursyve-nice-ui-kit.v2.mjs +250 -37
  24. package/fesm2020/recursyve-nice-ui-kit.v2.mjs.map +1 -1
  25. package/lib/api/nice.api.d.ts +1 -0
  26. package/lib/components/alert/alert.component.d.ts +3 -2
  27. package/lib/components/alert/alert.types.d.ts +1 -0
  28. package/lib/components/async-typeahead/async-typeahead.component.d.ts +3 -2
  29. package/lib/components/base-form/base-form.component.d.ts +4 -3
  30. package/lib/components/form-error/control-status.directive.d.ts +2 -3
  31. package/lib/components/navigation/vertical/vertical.component.d.ts +2 -2
  32. package/lib/directives/chip-async-typeahead/chip-async-typeahead.directive.d.ts +14 -0
  33. package/lib/directives/chip-async-typeahead/index.d.ts +1 -0
  34. package/lib/directives/chip-async-typeahead/public-api.d.ts +1 -0
  35. package/lib/directives/chip-list/chip-list-items/chip-list-item-label.directive.d.ts +8 -0
  36. package/lib/directives/chip-list/chip-list-items/chip-list-items.component.d.ts +14 -0
  37. package/lib/directives/chip-list/chip-list.directive.d.ts +27 -0
  38. package/lib/directives/chip-list/chip-list.module.d.ts +11 -0
  39. package/lib/directives/chip-list/index.d.ts +1 -0
  40. package/lib/directives/chip-list/public-api.d.ts +4 -0
  41. package/lib/directives/public-api.d.ts +2 -0
  42. package/package.json +1 -1
  43. package/src/lib/components/chip-list/chip-list.theme.scss +14 -0
  44. package/src/lib/components/chip-list/components/item-list/item-list.theme.scss +37 -0
  45. package/src/lib/directives/chip-list/chip-list-items/chip-list-items.theme.scss +35 -0
  46. package/src/lib/nice.theme.scss +5 -0
  47. package/styles/tailwind.scss +77 -74
  48. package/tailwind/plugins/theming.js +1 -1
  49. package/src/lib/nice.tailwind.scss +0 -94
@@ -48,12 +48,12 @@ export class NiceSweetAlertComponent {
48
48
  }
49
49
  }
50
50
  NiceSweetAlertComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceSweetAlertComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }], target: i0.ɵɵFactoryTarget.Component });
51
- NiceSweetAlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: NiceSweetAlertComponent, selector: "nice-alert", ngImport: i0, template: "<mat-dialog-content class=\"mat-typography mb-12 text-center\">\n <nice-lottie\n [options]=\"lottieConfig\"\n [width]=\"250\"\n (animCreated)=\"handleAnimation($event)\"\n ></nice-lottie>\n <h2 class=\"mt-8\">{{ alertConfig?.title }}</h2>\n {{ alertConfig?.message }}\n</mat-dialog-content>\n<mat-dialog-actions align=\"end\">\n <ng-container *ngFor=\"let button of alertConfig.buttons; let i = index\">\n <button mat-raised-button class=\"mr-4\" [ngClass]=\"getConfirmButtonClass()\" *ngIf=\"i === 0\" (click)=\"confirm()\">\n {{ button }}\n </button>\n <button mat-button (click)=\"close()\" *ngIf=\"i !== 0\">{{ button }}</button>\n </ng-container>\n</mat-dialog-actions>\n", styles: [".nice-alert-modal{width:500px}\n"], components: [{ type: i2.NiceLottieComponent, selector: "nice-lottie", inputs: ["options", "width", "height"], outputs: ["animCreated"] }, { type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], encapsulation: i0.ViewEncapsulation.None });
51
+ NiceSweetAlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: NiceSweetAlertComponent, selector: "nice-alert", ngImport: i0, template: "<mat-dialog-content class=\"mat-typography mb-12 text-center\">\n <nice-lottie\n [options]=\"lottieConfig\"\n [width]=\"250\"\n (animCreated)=\"handleAnimation($event)\"\n ></nice-lottie>\n <h2 class=\"mt-8\">{{ alertConfig?.title }}</h2>\n <span [innerHTML]=\"alertConfig?.message\"></span>\n</mat-dialog-content>\n<mat-dialog-actions align=\"end\">\n <ng-container *ngFor=\"let button of alertConfig.buttons; let i = index\">\n <button mat-raised-button class=\"mr-4\" [ngClass]=\"getConfirmButtonClass()\" *ngIf=\"i === 0\" (click)=\"confirm()\">\n {{ button }}\n </button>\n <button mat-button (click)=\"close()\" *ngIf=\"i !== 0\">{{ button }}</button>\n </ng-container>\n</mat-dialog-actions>\n", styles: [".nice-alert-modal{width:500px}\n"], components: [{ type: i2.NiceLottieComponent, selector: "nice-lottie", inputs: ["options", "width", "height"], outputs: ["animCreated"] }, { type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], encapsulation: i0.ViewEncapsulation.None });
52
52
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceSweetAlertComponent, decorators: [{
53
53
  type: Component,
54
- args: [{ selector: "nice-alert", encapsulation: ViewEncapsulation.None, template: "<mat-dialog-content class=\"mat-typography mb-12 text-center\">\n <nice-lottie\n [options]=\"lottieConfig\"\n [width]=\"250\"\n (animCreated)=\"handleAnimation($event)\"\n ></nice-lottie>\n <h2 class=\"mt-8\">{{ alertConfig?.title }}</h2>\n {{ alertConfig?.message }}\n</mat-dialog-content>\n<mat-dialog-actions align=\"end\">\n <ng-container *ngFor=\"let button of alertConfig.buttons; let i = index\">\n <button mat-raised-button class=\"mr-4\" [ngClass]=\"getConfirmButtonClass()\" *ngIf=\"i === 0\" (click)=\"confirm()\">\n {{ button }}\n </button>\n <button mat-button (click)=\"close()\" *ngIf=\"i !== 0\">{{ button }}</button>\n </ng-container>\n</mat-dialog-actions>\n", styles: [".nice-alert-modal{width:500px}\n"] }]
54
+ args: [{ selector: "nice-alert", encapsulation: ViewEncapsulation.None, template: "<mat-dialog-content class=\"mat-typography mb-12 text-center\">\n <nice-lottie\n [options]=\"lottieConfig\"\n [width]=\"250\"\n (animCreated)=\"handleAnimation($event)\"\n ></nice-lottie>\n <h2 class=\"mt-8\">{{ alertConfig?.title }}</h2>\n <span [innerHTML]=\"alertConfig?.message\"></span>\n</mat-dialog-content>\n<mat-dialog-actions align=\"end\">\n <ng-container *ngFor=\"let button of alertConfig.buttons; let i = index\">\n <button mat-raised-button class=\"mr-4\" [ngClass]=\"getConfirmButtonClass()\" *ngIf=\"i === 0\" (click)=\"confirm()\">\n {{ button }}\n </button>\n <button mat-button (click)=\"close()\" *ngIf=\"i !== 0\">{{ button }}</button>\n </ng-container>\n</mat-dialog-actions>\n", styles: [".nice-alert-modal{width:500px}\n"] }]
55
55
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
56
56
  type: Inject,
57
57
  args: [MAT_DIALOG_DATA]
58
58
  }] }, { type: i1.MatDialogRef }]; } });
59
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dlZXQtYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmljZS11aS1raXQtdjIvc3JjL2xpYi9jb21wb25lbnRzL3N3ZWV0LWFsZXJ0L3N3ZWV0LWFsZXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9zd2VldC1hbGVydC9zd2VldC1hbGVydC50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFVLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdFLE9BQU8sRUFBRSxlQUFlLEVBQUUsWUFBWSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7OztBQWV6RSxNQUFNLE9BQU8sdUJBQXVCO0lBT2hDLFlBQ29DLFdBQTRCLEVBQ3BELFNBQWdEO1FBRHhCLGdCQUFXLEdBQVgsV0FBVyxDQUFpQjtRQUNwRCxjQUFTLEdBQVQsU0FBUyxDQUF1QztRQVJyRCxpQkFBWSxHQUFHO1lBQ2xCLElBQUksRUFBRSxnQ0FBZ0M7WUFDdEMsUUFBUSxFQUFFLElBQUk7WUFDZCxJQUFJLEVBQUUsS0FBSztTQUNkLENBQUM7UUFNRSxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUNyRCxDQUFDO0lBRU0sUUFBUSxLQUFJLENBQUM7SUFFYixlQUFlLENBQUMsU0FBUztRQUM1QixTQUFTLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFTSxPQUFPO1FBQ1YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVNLEtBQUs7UUFDUixJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBRU0sZ0JBQWdCO1FBQ25CLFFBQVEsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUU7WUFDM0IsS0FBSyxTQUFTO2dCQUNWLE9BQU8sZ0NBQWdDLENBQUM7WUFDNUMsS0FBSyxTQUFTO2dCQUNWLE9BQU8sZ0NBQWdDLENBQUM7WUFDNUMsS0FBSyxNQUFNO2dCQUNQLE9BQU8sNkJBQTZCLENBQUM7U0FDNUM7SUFDTCxDQUFDO0lBRU0scUJBQXFCO1FBQ3hCLFFBQVEsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUU7WUFDM0IsS0FBSyxTQUFTO2dCQUNWLE9BQU8sWUFBWSxDQUFDO1lBQ3hCLEtBQUssU0FBUztnQkFDVixPQUFPLFVBQVUsQ0FBQztZQUN0QixLQUFLLE1BQU07Z0JBQ1AsT0FBTyxtQkFBbUIsQ0FBQztTQUNsQztJQUNMLENBQUM7O29IQWhEUSx1QkFBdUIsa0JBUXBCLGVBQWU7d0dBUmxCLHVCQUF1QixrRENoQnBDLDZ1QkFpQkE7MkZERGEsdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNJLFlBQVksaUJBR1AsaUJBQWlCLENBQUMsSUFBSTs7MEJBVWhDLE1BQU07MkJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0LCBPbkluaXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1BVF9ESUFMT0dfREFUQSwgTWF0RGlhbG9nUmVmIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2RpYWxvZ1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIE5pY2VBbGVydENvbmZpZyB7XG4gICAgdHlwZTogXCJzdWNjZXNzXCIgfCBcIndhcm5pbmdcIiB8IFwiaW5mb1wiO1xuICAgIHRpdGxlPzogc3RyaW5nO1xuICAgIG1lc3NhZ2U/OiBzdHJpbmc7XG4gICAgYnV0dG9uczogc3RyaW5nW107XG59XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiBcIm5pY2UtYWxlcnRcIixcbiAgICB0ZW1wbGF0ZVVybDogXCJzd2VldC1hbGVydC50ZW1wbGF0ZS5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCJzd2VldC1hbGVydC5zdHlsZS5zY3NzXCJdLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgTmljZVN3ZWV0QWxlcnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIHB1YmxpYyBsb3R0aWVDb25maWcgPSB7XG4gICAgICAgIHBhdGg6IFwiYXNzZXRzL2FuaW1hdGlvbnMvc3VjY2Vzcy5qc29uXCIsXG4gICAgICAgIGF1dG9wbGF5OiB0cnVlLFxuICAgICAgICBsb29wOiBmYWxzZVxuICAgIH07XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBhbGVydENvbmZpZzogTmljZUFsZXJ0Q29uZmlnLFxuICAgICAgICBwcml2YXRlIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPE5pY2VTd2VldEFsZXJ0Q29tcG9uZW50PlxuICAgICkge1xuICAgICAgICB0aGlzLmxvdHRpZUNvbmZpZy5wYXRoID0gdGhpcy5nZXRBbmltYXRpb25QYXRoKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25Jbml0KCkge31cblxuICAgIHB1YmxpYyBoYW5kbGVBbmltYXRpb24oYW5pbWF0aW9uKSB7XG4gICAgICAgIGFuaW1hdGlvbi5zZXRTcGVlZCgxLjApO1xuICAgIH1cblxuICAgIHB1YmxpYyBjb25maXJtKCkge1xuICAgICAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSh0cnVlKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xvc2UoKSB7XG4gICAgICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKGZhbHNlKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0QW5pbWF0aW9uUGF0aCgpOiBzdHJpbmcge1xuICAgICAgICBzd2l0Y2ggKHRoaXMuYWxlcnRDb25maWcudHlwZSkge1xuICAgICAgICAgICAgY2FzZSBcInN1Y2Nlc3NcIjpcbiAgICAgICAgICAgICAgICByZXR1cm4gXCJhc3NldHMvYW5pbWF0aW9ucy9zdWNjZXNzLmpzb25cIjtcbiAgICAgICAgICAgIGNhc2UgXCJ3YXJuaW5nXCI6XG4gICAgICAgICAgICAgICAgcmV0dXJuIFwiYXNzZXRzL2FuaW1hdGlvbnMvd2FybmluZy5qc29uXCI7XG4gICAgICAgICAgICBjYXNlIFwiaW5mb1wiOlxuICAgICAgICAgICAgICAgIHJldHVybiBcImFzc2V0cy9hbmltYXRpb25zL2luZm8uanNvblwiO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGdldENvbmZpcm1CdXR0b25DbGFzcygpOiBzdHJpbmcge1xuICAgICAgICBzd2l0Y2ggKHRoaXMuYWxlcnRDb25maWcudHlwZSkge1xuICAgICAgICAgICAgY2FzZSBcInN1Y2Nlc3NcIjpcbiAgICAgICAgICAgICAgICByZXR1cm4gXCJtYXQtYWNjZW50XCI7XG4gICAgICAgICAgICBjYXNlIFwid2FybmluZ1wiOlxuICAgICAgICAgICAgICAgIHJldHVybiBcIm1hdC13YXJuXCI7XG4gICAgICAgICAgICBjYXNlIFwiaW5mb1wiOlxuICAgICAgICAgICAgICAgIHJldHVybiBcImJnLWxpZ2h0LWJsdWUtNTAwXCI7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8bWF0LWRpYWxvZy1jb250ZW50IGNsYXNzPVwibWF0LXR5cG9ncmFwaHkgbWItMTIgdGV4dC1jZW50ZXJcIj5cbiAgICA8bmljZS1sb3R0aWVcbiAgICAgICAgW29wdGlvbnNdPVwibG90dGllQ29uZmlnXCJcbiAgICAgICAgW3dpZHRoXT1cIjI1MFwiXG4gICAgICAgIChhbmltQ3JlYXRlZCk9XCJoYW5kbGVBbmltYXRpb24oJGV2ZW50KVwiXG4gICAgPjwvbmljZS1sb3R0aWU+XG4gICAgPGgyIGNsYXNzPVwibXQtOFwiPnt7IGFsZXJ0Q29uZmlnPy50aXRsZSB9fTwvaDI+XG4gICAge3sgYWxlcnRDb25maWc/Lm1lc3NhZ2UgfX1cbjwvbWF0LWRpYWxvZy1jb250ZW50PlxuPG1hdC1kaWFsb2ctYWN0aW9ucyBhbGlnbj1cImVuZFwiPlxuICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGJ1dHRvbiBvZiBhbGVydENvbmZpZy5idXR0b25zOyBsZXQgaSA9IGluZGV4XCI+XG4gICAgICAgIDxidXR0b24gbWF0LXJhaXNlZC1idXR0b24gY2xhc3M9XCJtci00XCIgW25nQ2xhc3NdPVwiZ2V0Q29uZmlybUJ1dHRvbkNsYXNzKClcIiAqbmdJZj1cImkgPT09IDBcIiAoY2xpY2spPVwiY29uZmlybSgpXCI+XG4gICAgICAgICAgICB7eyBidXR0b24gfX1cbiAgICAgICAgPC9idXR0b24+XG4gICAgICAgIDxidXR0b24gbWF0LWJ1dHRvbiAoY2xpY2spPVwiY2xvc2UoKVwiICpuZ0lmPVwiaSAhPT0gMFwiPnt7IGJ1dHRvbiB9fTwvYnV0dG9uPlxuICAgIDwvbmctY29udGFpbmVyPlxuPC9tYXQtZGlhbG9nLWFjdGlvbnM+XG4iXX0=
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dlZXQtYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmljZS11aS1raXQtdjIvc3JjL2xpYi9jb21wb25lbnRzL3N3ZWV0LWFsZXJ0L3N3ZWV0LWFsZXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9zd2VldC1hbGVydC9zd2VldC1hbGVydC50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFVLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdFLE9BQU8sRUFBRSxlQUFlLEVBQUUsWUFBWSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7OztBQWV6RSxNQUFNLE9BQU8sdUJBQXVCO0lBT2hDLFlBQ29DLFdBQTRCLEVBQ3BELFNBQWdEO1FBRHhCLGdCQUFXLEdBQVgsV0FBVyxDQUFpQjtRQUNwRCxjQUFTLEdBQVQsU0FBUyxDQUF1QztRQVJyRCxpQkFBWSxHQUFHO1lBQ2xCLElBQUksRUFBRSxnQ0FBZ0M7WUFDdEMsUUFBUSxFQUFFLElBQUk7WUFDZCxJQUFJLEVBQUUsS0FBSztTQUNkLENBQUM7UUFNRSxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQztJQUNyRCxDQUFDO0lBRU0sUUFBUSxLQUFJLENBQUM7SUFFYixlQUFlLENBQUMsU0FBUztRQUM1QixTQUFTLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFTSxPQUFPO1FBQ1YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVNLEtBQUs7UUFDUixJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBRU0sZ0JBQWdCO1FBQ25CLFFBQVEsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUU7WUFDM0IsS0FBSyxTQUFTO2dCQUNWLE9BQU8sZ0NBQWdDLENBQUM7WUFDNUMsS0FBSyxTQUFTO2dCQUNWLE9BQU8sZ0NBQWdDLENBQUM7WUFDNUMsS0FBSyxNQUFNO2dCQUNQLE9BQU8sNkJBQTZCLENBQUM7U0FDNUM7SUFDTCxDQUFDO0lBRU0scUJBQXFCO1FBQ3hCLFFBQVEsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUU7WUFDM0IsS0FBSyxTQUFTO2dCQUNWLE9BQU8sWUFBWSxDQUFDO1lBQ3hCLEtBQUssU0FBUztnQkFDVixPQUFPLFVBQVUsQ0FBQztZQUN0QixLQUFLLE1BQU07Z0JBQ1AsT0FBTyxtQkFBbUIsQ0FBQztTQUNsQztJQUNMLENBQUM7O29IQWhEUSx1QkFBdUIsa0JBUXBCLGVBQWU7d0dBUmxCLHVCQUF1QixrRENoQnBDLHF3QkFpQkE7MkZERGEsdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNJLFlBQVksaUJBR1AsaUJBQWlCLENBQUMsSUFBSTs7MEJBVWhDLE1BQU07MkJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0LCBPbkluaXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IE1BVF9ESUFMT0dfREFUQSwgTWF0RGlhbG9nUmVmIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2RpYWxvZ1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIE5pY2VBbGVydENvbmZpZyB7XG4gICAgdHlwZTogXCJzdWNjZXNzXCIgfCBcIndhcm5pbmdcIiB8IFwiaW5mb1wiO1xuICAgIHRpdGxlPzogc3RyaW5nO1xuICAgIG1lc3NhZ2U/OiBzdHJpbmc7XG4gICAgYnV0dG9uczogc3RyaW5nW107XG59XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiBcIm5pY2UtYWxlcnRcIixcbiAgICB0ZW1wbGF0ZVVybDogXCJzd2VldC1hbGVydC50ZW1wbGF0ZS5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCJzd2VldC1hbGVydC5zdHlsZS5zY3NzXCJdLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmVcbn0pXG5leHBvcnQgY2xhc3MgTmljZVN3ZWV0QWxlcnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIHB1YmxpYyBsb3R0aWVDb25maWcgPSB7XG4gICAgICAgIHBhdGg6IFwiYXNzZXRzL2FuaW1hdGlvbnMvc3VjY2Vzcy5qc29uXCIsXG4gICAgICAgIGF1dG9wbGF5OiB0cnVlLFxuICAgICAgICBsb29wOiBmYWxzZVxuICAgIH07XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBhbGVydENvbmZpZzogTmljZUFsZXJ0Q29uZmlnLFxuICAgICAgICBwcml2YXRlIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPE5pY2VTd2VldEFsZXJ0Q29tcG9uZW50PlxuICAgICkge1xuICAgICAgICB0aGlzLmxvdHRpZUNvbmZpZy5wYXRoID0gdGhpcy5nZXRBbmltYXRpb25QYXRoKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25Jbml0KCkge31cblxuICAgIHB1YmxpYyBoYW5kbGVBbmltYXRpb24oYW5pbWF0aW9uKSB7XG4gICAgICAgIGFuaW1hdGlvbi5zZXRTcGVlZCgxLjApO1xuICAgIH1cblxuICAgIHB1YmxpYyBjb25maXJtKCkge1xuICAgICAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSh0cnVlKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xvc2UoKSB7XG4gICAgICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKGZhbHNlKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0QW5pbWF0aW9uUGF0aCgpOiBzdHJpbmcge1xuICAgICAgICBzd2l0Y2ggKHRoaXMuYWxlcnRDb25maWcudHlwZSkge1xuICAgICAgICAgICAgY2FzZSBcInN1Y2Nlc3NcIjpcbiAgICAgICAgICAgICAgICByZXR1cm4gXCJhc3NldHMvYW5pbWF0aW9ucy9zdWNjZXNzLmpzb25cIjtcbiAgICAgICAgICAgIGNhc2UgXCJ3YXJuaW5nXCI6XG4gICAgICAgICAgICAgICAgcmV0dXJuIFwiYXNzZXRzL2FuaW1hdGlvbnMvd2FybmluZy5qc29uXCI7XG4gICAgICAgICAgICBjYXNlIFwiaW5mb1wiOlxuICAgICAgICAgICAgICAgIHJldHVybiBcImFzc2V0cy9hbmltYXRpb25zL2luZm8uanNvblwiO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGdldENvbmZpcm1CdXR0b25DbGFzcygpOiBzdHJpbmcge1xuICAgICAgICBzd2l0Y2ggKHRoaXMuYWxlcnRDb25maWcudHlwZSkge1xuICAgICAgICAgICAgY2FzZSBcInN1Y2Nlc3NcIjpcbiAgICAgICAgICAgICAgICByZXR1cm4gXCJtYXQtYWNjZW50XCI7XG4gICAgICAgICAgICBjYXNlIFwid2FybmluZ1wiOlxuICAgICAgICAgICAgICAgIHJldHVybiBcIm1hdC13YXJuXCI7XG4gICAgICAgICAgICBjYXNlIFwiaW5mb1wiOlxuICAgICAgICAgICAgICAgIHJldHVybiBcImJnLWxpZ2h0LWJsdWUtNTAwXCI7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8bWF0LWRpYWxvZy1jb250ZW50IGNsYXNzPVwibWF0LXR5cG9ncmFwaHkgbWItMTIgdGV4dC1jZW50ZXJcIj5cbiAgICA8bmljZS1sb3R0aWVcbiAgICAgICAgW29wdGlvbnNdPVwibG90dGllQ29uZmlnXCJcbiAgICAgICAgW3dpZHRoXT1cIjI1MFwiXG4gICAgICAgIChhbmltQ3JlYXRlZCk9XCJoYW5kbGVBbmltYXRpb24oJGV2ZW50KVwiXG4gICAgPjwvbmljZS1sb3R0aWU+XG4gICAgPGgyIGNsYXNzPVwibXQtOFwiPnt7IGFsZXJ0Q29uZmlnPy50aXRsZSB9fTwvaDI+XG4gICAgPHNwYW4gW2lubmVySFRNTF09XCJhbGVydENvbmZpZz8ubWVzc2FnZVwiPjwvc3Bhbj5cbjwvbWF0LWRpYWxvZy1jb250ZW50PlxuPG1hdC1kaWFsb2ctYWN0aW9ucyBhbGlnbj1cImVuZFwiPlxuICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGJ1dHRvbiBvZiBhbGVydENvbmZpZy5idXR0b25zOyBsZXQgaSA9IGluZGV4XCI+XG4gICAgICAgIDxidXR0b24gbWF0LXJhaXNlZC1idXR0b24gY2xhc3M9XCJtci00XCIgW25nQ2xhc3NdPVwiZ2V0Q29uZmlybUJ1dHRvbkNsYXNzKClcIiAqbmdJZj1cImkgPT09IDBcIiAoY2xpY2spPVwiY29uZmlybSgpXCI+XG4gICAgICAgICAgICB7eyBidXR0b24gfX1cbiAgICAgICAgPC9idXR0b24+XG4gICAgICAgIDxidXR0b24gbWF0LWJ1dHRvbiAoY2xpY2spPVwiY2xvc2UoKVwiICpuZ0lmPVwiaSAhPT0gMFwiPnt7IGJ1dHRvbiB9fTwvYnV0dG9uPlxuICAgIDwvbmctY29udGFpbmVyPlxuPC9tYXQtZGlhbG9nLWFjdGlvbnM+XG4iXX0=
@@ -14,7 +14,7 @@ export class NiceToastComponent {
14
14
  }
15
15
  }
16
16
  NiceToastComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceToastComponent, deps: [{ token: MAT_SNACK_BAR_DATA }, { token: i1.MatSnackBarRef }], target: i0.ɵɵFactoryTarget.Component });
17
- NiceToastComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: NiceToastComponent, selector: "nice-toast", ngImport: i0, template: "<nice-alert disableAnimation [type]=\"data.type\" [appearance]=\"data.appearance || 'outline'\" (click)=\"dismiss()\">\n <span niceAlertTitle *ngIf=\"data.title\">{{ data.title }}</span>\n <span [innerHtml]=\"data.message\" *ngIf=\"data.message\"></span>\n</nice-alert>\n", styles: [".message-box{background-color:transparent!important;box-shadow:none!important}\n"], components: [{ type: i2.NiceAlertComponent, selector: "nice-alert", inputs: ["appearance", "dismissed", "dismissible", "disableAnimation", "name", "showIcon", "type"], outputs: ["dismissedChanged"], exportAs: ["niceAlert"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
17
+ NiceToastComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: NiceToastComponent, selector: "nice-toast", ngImport: i0, template: "<nice-alert disableAnimation [type]=\"data.type\" [appearance]=\"data.appearance || 'outline'\" (click)=\"dismiss()\">\n <span niceAlertTitle *ngIf=\"data.title\">{{ data.title }}</span>\n <span [innerHtml]=\"data.message\" *ngIf=\"data.message\"></span>\n</nice-alert>\n", styles: [".message-box{background-color:transparent!important;box-shadow:none!important}\n"], components: [{ type: i2.NiceAlertComponent, selector: "nice-alert", inputs: ["appearance", "dismissed", "dismissible", "disableAnimation", "name", "showIcon", "type", "color"], outputs: ["dismissedChanged"], exportAs: ["niceAlert"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
18
18
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceToastComponent, decorators: [{
19
19
  type: Component,
20
20
  args: [{ selector: "nice-toast", encapsulation: ViewEncapsulation.None, template: "<nice-alert disableAnimation [type]=\"data.type\" [appearance]=\"data.appearance || 'outline'\" (click)=\"dismiss()\">\n <span niceAlertTitle *ngIf=\"data.title\">{{ data.title }}</span>\n <span [innerHtml]=\"data.message\" *ngIf=\"data.message\"></span>\n</nice-alert>\n", styles: [".message-box{background-color:transparent!important;box-shadow:none!important}\n"] }]
@@ -0,0 +1,39 @@
1
+ import { Directive, ElementRef, EventEmitter, Output, } from "@angular/core";
2
+ import { Subject } from "rxjs";
3
+ import { filter, takeUntil } from "rxjs/operators";
4
+ import { NiceAsyncTypeaheadComponent } from "../../components";
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../../components";
7
+ export class NiceChipAsyncTypeaheadDirective {
8
+ constructor(typeahead, elementRef) {
9
+ this.typeahead = typeahead;
10
+ this.elementRef = elementRef;
11
+ this.niceChipAsyncTypeaheadTokenEnd = new EventEmitter();
12
+ this.unsubscribeAll$ = new Subject();
13
+ }
14
+ ngOnInit() {
15
+ this.typeahead.selected
16
+ .pipe(takeUntil(this.unsubscribeAll$), filter((selected) => selected))
17
+ .subscribe((_) => {
18
+ this.niceChipAsyncTypeaheadTokenEnd.emit(this.typeahead.getActive());
19
+ this.typeahead.writeValue(null);
20
+ });
21
+ this.elementRef.nativeElement.classList.add("nice-chip-async-typeahead");
22
+ }
23
+ ngOnDestroy() {
24
+ this.unsubscribeAll$.next(null);
25
+ this.unsubscribeAll$.complete();
26
+ }
27
+ }
28
+ NiceChipAsyncTypeaheadDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceChipAsyncTypeaheadDirective, deps: [{ token: i1.NiceAsyncTypeaheadComponent }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
29
+ NiceChipAsyncTypeaheadDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.3", type: NiceChipAsyncTypeaheadDirective, selector: "[niceChipAsyncTypeahead]", outputs: { niceChipAsyncTypeaheadTokenEnd: "niceChipAsyncTypeaheadTokenEnd" }, exportAs: ["niceChipAsyncTypeahead"], ngImport: i0 });
30
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceChipAsyncTypeaheadDirective, decorators: [{
31
+ type: Directive,
32
+ args: [{
33
+ selector: "[niceChipAsyncTypeahead]",
34
+ exportAs: "niceChipAsyncTypeahead",
35
+ }]
36
+ }], ctorParameters: function () { return [{ type: i1.NiceAsyncTypeaheadComponent }, { type: i0.ElementRef }]; }, propDecorators: { niceChipAsyncTypeaheadTokenEnd: [{
37
+ type: Output
38
+ }] } });
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1hc3luYy10eXBlYWhlYWQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmljZS11aS1raXQtdjIvc3JjL2xpYi9kaXJlY3RpdmVzL2NoaXAtYXN5bmMtdHlwZWFoZWFkL2NoaXAtYXN5bmMtdHlwZWFoZWFkLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQXFCLE1BQU0sR0FBRyxNQUFNLGVBQWUsQ0FBQztBQUNoRyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQy9CLE9BQU8sRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbkQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7OztBQU0vRCxNQUFNLE9BQU8sK0JBQStCO0lBTXhDLFlBQ1ksU0FBc0MsRUFDdEMsVUFBbUM7UUFEbkMsY0FBUyxHQUFULFNBQVMsQ0FBNkI7UUFDdEMsZUFBVSxHQUFWLFVBQVUsQ0FBeUI7UUFOeEMsbUNBQThCLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUV4RCxvQkFBZSxHQUFHLElBQUksT0FBTyxFQUFFLENBQUM7SUFNeEMsQ0FBQztJQUVNLFFBQVE7UUFDWCxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVE7YUFDbEIsSUFBSSxDQUNELFNBQVMsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLEVBQy9CLE1BQU0sQ0FBQyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLENBQ2pDO2FBQ0EsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7WUFDYixJQUFJLENBQUMsOEJBQThCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxFQUFFLENBQUMsQ0FBQztZQUNyRSxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUNwQyxDQUFDLENBQUMsQ0FBQztRQUVQLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsMkJBQTJCLENBQUMsQ0FBQztJQUM3RSxDQUFDO0lBRU0sV0FBVztRQUNkLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2hDLElBQUksQ0FBQyxlQUFlLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDcEMsQ0FBQzs7NEhBN0JRLCtCQUErQjtnSEFBL0IsK0JBQStCOzJGQUEvQiwrQkFBK0I7a0JBSjNDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDBCQUEwQjtvQkFDcEMsUUFBUSxFQUFFLHdCQUF3QjtpQkFDckM7MklBR1UsOEJBQThCO3NCQURwQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsIE9uRGVzdHJveSwgT25Jbml0LCBPdXRwdXQsIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tIFwicnhqc1wiO1xuaW1wb3J0IHsgZmlsdGVyLCB0YWtlVW50aWwgfSBmcm9tIFwicnhqcy9vcGVyYXRvcnNcIjtcbmltcG9ydCB7IE5pY2VBc3luY1R5cGVhaGVhZENvbXBvbmVudCB9IGZyb20gXCIuLi8uLi9jb21wb25lbnRzXCI7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiBcIltuaWNlQ2hpcEFzeW5jVHlwZWFoZWFkXVwiLFxuICAgIGV4cG9ydEFzOiBcIm5pY2VDaGlwQXN5bmNUeXBlYWhlYWRcIixcbn0pXG5leHBvcnQgY2xhc3MgTmljZUNoaXBBc3luY1R5cGVhaGVhZERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgbmljZUNoaXBBc3luY1R5cGVhaGVhZFRva2VuRW5kID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG5cbiAgICBwcml2YXRlIHVuc3Vic2NyaWJlQWxsJCA9IG5ldyBTdWJqZWN0KCk7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSB0eXBlYWhlYWQ6IE5pY2VBc3luY1R5cGVhaGVhZENvbXBvbmVudCxcbiAgICAgICAgcHJpdmF0ZSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PlxuICAgICkge1xuICAgIH1cblxuICAgIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy50eXBlYWhlYWQuc2VsZWN0ZWRcbiAgICAgICAgICAgIC5waXBlKFxuICAgICAgICAgICAgICAgIHRha2VVbnRpbCh0aGlzLnVuc3Vic2NyaWJlQWxsJCksXG4gICAgICAgICAgICAgICAgZmlsdGVyKChzZWxlY3RlZCkgPT4gc2VsZWN0ZWQpXG4gICAgICAgICAgICApXG4gICAgICAgICAgICAuc3Vic2NyaWJlKChfKSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5uaWNlQ2hpcEFzeW5jVHlwZWFoZWFkVG9rZW5FbmQuZW1pdCh0aGlzLnR5cGVhaGVhZC5nZXRBY3RpdmUoKSk7XG4gICAgICAgICAgICAgICAgdGhpcy50eXBlYWhlYWQud3JpdGVWYWx1ZShudWxsKTtcbiAgICAgICAgICAgIH0pO1xuXG4gICAgICAgIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmNsYXNzTGlzdC5hZGQoXCJuaWNlLWNoaXAtYXN5bmMtdHlwZWFoZWFkXCIpO1xuICAgIH1cblxuICAgIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy51bnN1YnNjcmliZUFsbCQubmV4dChudWxsKTtcbiAgICAgICAgdGhpcy51bnN1YnNjcmliZUFsbCQuY29tcGxldGUoKTtcbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export * from "./public-api";
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLXVpLWtpdC12Mi9zcmMvbGliL2RpcmVjdGl2ZXMvY2hpcC1hc3luYy10eXBlYWhlYWQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9wdWJsaWMtYXBpXCI7XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export * from "./chip-async-typeahead.directive";
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvZGlyZWN0aXZlcy9jaGlwLWFzeW5jLXR5cGVhaGVhZC9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0NBQWtDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9jaGlwLWFzeW5jLXR5cGVhaGVhZC5kaXJlY3RpdmVcIjtcbiJdfQ==
@@ -0,0 +1,14 @@
1
+ import { Directive, TemplateRef } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class ChipListItemLabelDirective {
4
+ constructor(template) {
5
+ this.template = template;
6
+ }
7
+ }
8
+ ChipListItemLabelDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ChipListItemLabelDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
9
+ ChipListItemLabelDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.3", type: ChipListItemLabelDirective, selector: "[niceChipListItemLabel]", ngImport: i0 });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: ChipListItemLabelDirective, decorators: [{
11
+ type: Directive,
12
+ args: [{ selector: "[niceChipListItemLabel]" }]
13
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1saXN0LWl0ZW0tbGFiZWwuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmljZS11aS1raXQtdjIvc3JjL2xpYi9kaXJlY3RpdmVzL2NoaXAtbGlzdC9jaGlwLWxpc3QtaXRlbXMvY2hpcC1saXN0LWl0ZW0tbGFiZWwuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUd2RCxNQUFNLE9BQU8sMEJBQTBCO0lBQ25DLFlBQW1CLFFBQTBCO1FBQTFCLGFBQVEsR0FBUixRQUFRLENBQWtCO0lBQUcsQ0FBQzs7dUhBRHhDLDBCQUEwQjsyR0FBMUIsMEJBQTBCOzJGQUExQiwwQkFBMEI7a0JBRHRDLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUseUJBQXlCLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuQERpcmVjdGl2ZSh7IHNlbGVjdG9yOiBcIltuaWNlQ2hpcExpc3RJdGVtTGFiZWxdXCIgfSlcbmV4cG9ydCBjbGFzcyBDaGlwTGlzdEl0ZW1MYWJlbERpcmVjdGl2ZSB7XG4gICAgY29uc3RydWN0b3IocHVibGljIHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+KSB7fVxufVxuIl19
@@ -0,0 +1,32 @@
1
+ import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from "@angular/core";
2
+ import { Observable } from "rxjs";
3
+ import { ChipListItemLabelDirective } from "./chip-list-item-label.directive";
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/material/icon";
6
+ import * as i2 from "@angular/common";
7
+ export class NiceChipListItemsComponent {
8
+ constructor() {
9
+ this.color = "primary";
10
+ this.removeChip = new EventEmitter();
11
+ this.defaultColor = "primary";
12
+ }
13
+ remove(index) {
14
+ this.removeChip.next(index);
15
+ }
16
+ }
17
+ NiceChipListItemsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceChipListItemsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
18
+ NiceChipListItemsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: NiceChipListItemsComponent, selector: "nice-chip-list-items", inputs: { color: "color", items$: "items$" }, outputs: { removeChip: "removeChip" }, queries: [{ propertyName: "itemLabel", first: true, predicate: ChipListItemLabelDirective, descendants: true, read: TemplateRef }], ngImport: i0, template: "<div class=\"nice-items-row\" *ngIf=\"(items$ | async)?.length\">\n <div\n class=\"nice-chip\"\n *ngFor=\"let value of items$ | async; let i = index\"\n [ngClass]=\"color\"\n >\n <span *ngIf=\"!itemLabel\">{{ value }}</span>\n <ng-container *ngIf=\"itemLabel\">\n <ng-container *ngTemplateOutlet=\"itemLabel; context: { $implicit: value }\"></ng-container>\n </ng-container>\n <button (click)=\"remove(i)\">\n <mat-icon class=\"close-icon\">cancel</mat-icon>\n </button>\n </div>\n</div>\n", components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i2.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceChipListItemsComponent, decorators: [{
20
+ type: Component,
21
+ args: [{ selector: "nice-chip-list-items", changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"nice-items-row\" *ngIf=\"(items$ | async)?.length\">\n <div\n class=\"nice-chip\"\n *ngFor=\"let value of items$ | async; let i = index\"\n [ngClass]=\"color\"\n >\n <span *ngIf=\"!itemLabel\">{{ value }}</span>\n <ng-container *ngIf=\"itemLabel\">\n <ng-container *ngTemplateOutlet=\"itemLabel; context: { $implicit: value }\"></ng-container>\n </ng-container>\n <button (click)=\"remove(i)\">\n <mat-icon class=\"close-icon\">cancel</mat-icon>\n </button>\n </div>\n</div>\n" }]
22
+ }], propDecorators: { itemLabel: [{
23
+ type: ContentChild,
24
+ args: [ChipListItemLabelDirective, { read: TemplateRef }]
25
+ }], color: [{
26
+ type: Input
27
+ }], removeChip: [{
28
+ type: Output
29
+ }], items$: [{
30
+ type: Input
31
+ }] } });
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1saXN0LWl0ZW1zLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvZGlyZWN0aXZlcy9jaGlwLWxpc3QvY2hpcC1saXN0LWl0ZW1zL2NoaXAtbGlzdC1pdGVtcy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLXVpLWtpdC12Mi9zcmMvbGliL2RpcmVjdGl2ZXMvY2hpcC1saXN0L2NoaXAtbGlzdC1pdGVtcy9jaGlwLWxpc3QtaXRlbXMudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0gsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNsQyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQzs7OztBQU85RSxNQUFNLE9BQU8sMEJBQTBCO0lBTHZDO1FBVVcsVUFBSyxHQUFpQixTQUFTLENBQUM7UUFHaEMsZUFBVSxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFLeEMsaUJBQVksR0FBaUIsU0FBUyxDQUFDO0tBS2pEO0lBSFUsTUFBTSxDQUFDLEtBQWE7UUFDdkIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEMsQ0FBQzs7dUhBakJRLDBCQUEwQjsyR0FBMUIsMEJBQTBCLHdMQUNyQiwwQkFBMEIsMkJBQVUsV0FBVyw2QkNYakUsa2tCQWVBOzJGRExhLDBCQUEwQjtrQkFMdEMsU0FBUzsrQkFDSSxzQkFBc0IsbUJBRWYsdUJBQXVCLENBQUMsTUFBTTs4QkFJeEMsU0FBUztzQkFEZixZQUFZO3VCQUFDLDBCQUEwQixFQUFFLEVBQUUsSUFBSSxFQUFFLFdBQVcsRUFBRTtnQkFJeEQsS0FBSztzQkFEWCxLQUFLO2dCQUlDLFVBQVU7c0JBRGhCLE1BQU07Z0JBSUEsTUFBTTtzQkFEWixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgQ29udGVudENoaWxkLCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQsIFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IENhbkNvbG9yLCBUaGVtZVBhbGV0dGUgfSBmcm9tIFwiQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZVwiO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgeyBDaGlwTGlzdEl0ZW1MYWJlbERpcmVjdGl2ZSB9IGZyb20gXCIuL2NoaXAtbGlzdC1pdGVtLWxhYmVsLmRpcmVjdGl2ZVwiO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogXCJuaWNlLWNoaXAtbGlzdC1pdGVtc1wiLFxuICAgIHRlbXBsYXRlVXJsOiBcIi4vY2hpcC1saXN0LWl0ZW1zLnRlbXBsYXRlLmh0bWxcIixcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBOaWNlQ2hpcExpc3RJdGVtc0NvbXBvbmVudCBpbXBsZW1lbnRzIENhbkNvbG9yIHtcbiAgICBAQ29udGVudENoaWxkKENoaXBMaXN0SXRlbUxhYmVsRGlyZWN0aXZlLCB7IHJlYWQ6IFRlbXBsYXRlUmVmIH0pXG4gICAgcHVibGljIGl0ZW1MYWJlbDogVGVtcGxhdGVSZWY8YW55PjtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGNvbG9yOiBUaGVtZVBhbGV0dGUgPSBcInByaW1hcnlcIjtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyByZW1vdmVDaGlwID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBpdGVtcyQ6IE9ic2VydmFibGU8YW55W10+O1xuXG4gICAgcHVibGljIGRlZmF1bHRDb2xvcjogVGhlbWVQYWxldHRlID0gXCJwcmltYXJ5XCI7XG5cbiAgICBwdWJsaWMgcmVtb3ZlKGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5yZW1vdmVDaGlwLm5leHQoaW5kZXgpO1xuICAgIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJuaWNlLWl0ZW1zLXJvd1wiICpuZ0lmPVwiKGl0ZW1zJCB8IGFzeW5jKT8ubGVuZ3RoXCI+XG4gICAgPGRpdlxuICAgICAgICBjbGFzcz1cIm5pY2UtY2hpcFwiXG4gICAgICAgICpuZ0Zvcj1cImxldCB2YWx1ZSBvZiBpdGVtcyQgfCBhc3luYzsgbGV0IGkgPSBpbmRleFwiXG4gICAgICAgIFtuZ0NsYXNzXT1cImNvbG9yXCJcbiAgICA+XG4gICAgICAgIDxzcGFuICpuZ0lmPVwiIWl0ZW1MYWJlbFwiPnt7IHZhbHVlIH19PC9zcGFuPlxuICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiaXRlbUxhYmVsXCI+XG4gICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiaXRlbUxhYmVsOyBjb250ZXh0OiB7ICRpbXBsaWNpdDogdmFsdWUgfVwiPjwvbmctY29udGFpbmVyPlxuICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwicmVtb3ZlKGkpXCI+XG4gICAgICAgICAgICA8bWF0LWljb24gY2xhc3M9XCJjbG9zZS1pY29uXCI+Y2FuY2VsPC9tYXQtaWNvbj5cbiAgICAgICAgPC9idXR0b24+XG4gICAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
@@ -0,0 +1,100 @@
1
+ import { Directive, ElementRef, HostListener, Input, Optional } from "@angular/core";
2
+ import { NgControl } from "@angular/forms";
3
+ import { BehaviorSubject, Subject } from "rxjs";
4
+ import { filter, takeUntil } from "rxjs/operators";
5
+ import { NiceAsyncTypeaheadComponent } from "../../components";
6
+ import { KeyboardCodes } from "../../utils";
7
+ import { NiceChipListItemsComponent } from "./chip-list-items/chip-list-items.component";
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "../../components";
10
+ import * as i2 from "@angular/forms";
11
+ export class NiceChipListDirective {
12
+ constructor(asyncTypeahead, ngControl, elementRef) {
13
+ this.asyncTypeahead = asyncTypeahead;
14
+ this.ngControl = ngControl;
15
+ this.elementRef = elementRef;
16
+ this.unsubscribeAll$ = new Subject();
17
+ this.values$ = new BehaviorSubject([]);
18
+ this._values = [];
19
+ this.propagateChanges = (value) => { };
20
+ if (this.ngControl) {
21
+ this.ngControl.valueAccessor = this;
22
+ }
23
+ }
24
+ get values() {
25
+ return this._values;
26
+ }
27
+ onKeyDown(event) {
28
+ if (this.asyncTypeahead) {
29
+ return;
30
+ }
31
+ if (event.code === KeyboardCodes.Enter) {
32
+ if (!this.elementRef.nativeElement.validity.valid) {
33
+ return;
34
+ }
35
+ this.addValue(this.elementRef.nativeElement.value);
36
+ this.elementRef.nativeElement.value = "";
37
+ return;
38
+ }
39
+ }
40
+ ngOnInit() {
41
+ if (this.asyncTypeahead) {
42
+ this.setupAsyncTypeahead();
43
+ }
44
+ if (this.elementRef.nativeElement.parentElement.classList.contains("mat-form-field-infix")) {
45
+ this.elementRef.nativeElement.parentElement.style.alignItems = "flex-start";
46
+ this.elementRef.nativeElement.parentElement.style.flexDirection = "column-reverse";
47
+ }
48
+ }
49
+ ngOnChanges(changes) {
50
+ if ("withItemList" in changes) {
51
+ this.withItemList.items$ = this.values$;
52
+ this.withItemList.removeChip.pipe(takeUntil(this.unsubscribeAll$)).subscribe(x => {
53
+ this._values.splice(x, 1);
54
+ this.propagateChanges(this._values);
55
+ this.values$.next(this._values);
56
+ });
57
+ }
58
+ }
59
+ writeValue(obj) {
60
+ this._values = [];
61
+ }
62
+ registerOnChange(fn) {
63
+ this.propagateChanges = fn;
64
+ }
65
+ registerOnTouched(fn) { }
66
+ setupAsyncTypeahead() {
67
+ this.asyncTypeahead.selected
68
+ .pipe(takeUntil(this.unsubscribeAll$), filter((selected) => selected))
69
+ .subscribe((_) => {
70
+ this.addValue(this.asyncTypeahead.getActive());
71
+ this.asyncTypeahead.writeValue(null);
72
+ });
73
+ }
74
+ addValue(value) {
75
+ if (this._values.includes(value)) {
76
+ return;
77
+ }
78
+ this._values.push(value);
79
+ this.propagateChanges(this._values);
80
+ this.values$.next(this._values);
81
+ }
82
+ }
83
+ NiceChipListDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceChipListDirective, deps: [{ token: i1.NiceAsyncTypeaheadComponent, optional: true }, { token: i2.NgControl, optional: true }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
84
+ NiceChipListDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.3", type: NiceChipListDirective, selector: "input[niceChipList], nice-async-typeahead[niceChipList]", inputs: { withItemList: "withItemList" }, host: { listeners: { "keydown": "onKeyDown($event)" } }, usesOnChanges: true, ngImport: i0 });
85
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceChipListDirective, decorators: [{
86
+ type: Directive,
87
+ args: [{
88
+ selector: "input[niceChipList], nice-async-typeahead[niceChipList]"
89
+ }]
90
+ }], ctorParameters: function () { return [{ type: i1.NiceAsyncTypeaheadComponent, decorators: [{
91
+ type: Optional
92
+ }] }, { type: i2.NgControl, decorators: [{
93
+ type: Optional
94
+ }] }, { type: i0.ElementRef }]; }, propDecorators: { withItemList: [{
95
+ type: Input
96
+ }], onKeyDown: [{
97
+ type: HostListener,
98
+ args: ["keydown", ["$event"]]
99
+ }] } });
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chip-list.directive.js","sourceRoot":"","sources":["../../../../../../projects/nice-ui-kit-v2/src/lib/directives/chip-list/chip-list.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Input, OnChanges, OnInit, Optional, SimpleChanges } from \"@angular/core\";\nimport { ControlValueAccessor, NgControl } from \"@angular/forms\";\nimport { BehaviorSubject, Subject } from \"rxjs\";\nimport { filter, takeUntil } from \"rxjs/operators\";\nimport { NiceAsyncTypeaheadComponent } from \"../../components\";\nimport { KeyboardCodes } from \"../../utils\";\nimport { NiceChipListItemsComponent } from \"./chip-list-items/chip-list-items.component\";\n\n@Directive({\n    selector: \"input[niceChipList], nice-async-typeahead[niceChipList]\"\n})\nexport class NiceChipListDirective implements ControlValueAccessor, OnInit, OnChanges {\n    @Input()\n    public withItemList: NiceChipListItemsComponent;\n\n    private unsubscribeAll$ = new Subject<void>();\n    private values$ = new BehaviorSubject([]);\n\n    private _values: any[] = [];\n    private propagateChanges = (value: any[]) => {};\n\n    public get values(): any[] {\n        return this._values;\n    }\n\n    constructor(\n        @Optional() private asyncTypeahead: NiceAsyncTypeaheadComponent,\n        @Optional() private ngControl: NgControl,\n        private elementRef: ElementRef<HTMLInputElement>\n    ) {\n        if (this.ngControl) {\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    @HostListener(\"keydown\", [\"$event\"])\n    public onKeyDown(event: KeyboardEvent): void {\n        if (this.asyncTypeahead) {\n            return;\n        }\n\n        if (event.code === KeyboardCodes.Enter) {\n            if (!this.elementRef.nativeElement.validity.valid) {\n                return;\n            }\n\n            this.addValue(this.elementRef.nativeElement.value);\n            this.elementRef.nativeElement.value = \"\";\n            return;\n        }\n    }\n\n    public ngOnInit(): void {\n        if (this.asyncTypeahead) {\n            this.setupAsyncTypeahead();\n        }\n\n        if (this.elementRef.nativeElement.parentElement.classList.contains(\"mat-form-field-infix\")) {\n            this.elementRef.nativeElement.parentElement.style.alignItems = \"flex-start\";\n            this.elementRef.nativeElement.parentElement.style.flexDirection = \"column-reverse\";\n        }\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (\"withItemList\" in changes) {\n            this.withItemList.items$ = this.values$;\n            this.withItemList.removeChip.pipe(takeUntil(this.unsubscribeAll$)).subscribe(x => {\n                this._values.splice(x, 1);\n                this.propagateChanges(this._values);\n                this.values$.next(this._values);\n            });\n        }\n    }\n\n    public writeValue(obj: any[]): void {\n        this._values = [];\n    }\n\n    public registerOnChange(fn: any): void {\n        this.propagateChanges = fn;\n    }\n\n    public registerOnTouched(fn: any): void {}\n\n    private setupAsyncTypeahead(): void {\n        this.asyncTypeahead.selected\n            .pipe(\n                takeUntil(this.unsubscribeAll$),\n                filter((selected) => selected)\n            )\n            .subscribe((_) => {\n                this.addValue(this.asyncTypeahead.getActive());\n                this.asyncTypeahead.writeValue(null);\n            });\n    }\n\n    private addValue(value: any): void {\n        if (this._values.includes(value)) {\n            return;\n        }\n\n        this._values.push(value);\n        this.propagateChanges(this._values);\n        this.values$.next(this._values);\n    }\n}\n"]}
@@ -0,0 +1,21 @@
1
+ import { CommonModule } from "@angular/common";
2
+ import { NgModule } from "@angular/core";
3
+ import { MatIconModule } from "@angular/material/icon";
4
+ import { ChipListItemLabelDirective } from "./chip-list-items/chip-list-item-label.directive";
5
+ import { NiceChipListItemsComponent } from "./chip-list-items/chip-list-items.component";
6
+ import { NiceChipListDirective } from "./chip-list.directive";
7
+ import * as i0 from "@angular/core";
8
+ export class NiceChipListDirectiveModule {
9
+ }
10
+ NiceChipListDirectiveModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceChipListDirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
11
+ NiceChipListDirectiveModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceChipListDirectiveModule, declarations: [NiceChipListDirective, NiceChipListItemsComponent, ChipListItemLabelDirective], imports: [CommonModule, MatIconModule], exports: [NiceChipListDirective, NiceChipListItemsComponent, ChipListItemLabelDirective] });
12
+ NiceChipListDirectiveModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceChipListDirectiveModule, imports: [[CommonModule, MatIconModule]] });
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceChipListDirectiveModule, decorators: [{
14
+ type: NgModule,
15
+ args: [{
16
+ imports: [CommonModule, MatIconModule],
17
+ declarations: [NiceChipListDirective, NiceChipListItemsComponent, ChipListItemLabelDirective],
18
+ exports: [NiceChipListDirective, NiceChipListItemsComponent, ChipListItemLabelDirective]
19
+ }]
20
+ }] });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1saXN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvZGlyZWN0aXZlcy9jaGlwLWxpc3QvY2hpcC1saXN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDOUYsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFFekYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBTzlELE1BQU0sT0FBTywyQkFBMkI7O3dIQUEzQiwyQkFBMkI7eUhBQTNCLDJCQUEyQixpQkFIckIscUJBQXFCLEVBQUUsMEJBQTBCLEVBQUUsMEJBQTBCLGFBRGxGLFlBQVksRUFBRSxhQUFhLGFBRTNCLHFCQUFxQixFQUFFLDBCQUEwQixFQUFFLDBCQUEwQjt5SEFFOUUsMkJBQTJCLFlBSjNCLENBQUMsWUFBWSxFQUFFLGFBQWEsQ0FBQzsyRkFJN0IsMkJBQTJCO2tCQUx2QyxRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxhQUFhLENBQUM7b0JBQ3RDLFlBQVksRUFBRSxDQUFDLHFCQUFxQixFQUFFLDBCQUEwQixFQUFFLDBCQUEwQixDQUFDO29CQUM3RixPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSwwQkFBMEIsRUFBRSwwQkFBMEIsQ0FBQztpQkFDM0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2ljb25cIjtcbmltcG9ydCB7IENoaXBMaXN0SXRlbUxhYmVsRGlyZWN0aXZlIH0gZnJvbSBcIi4vY2hpcC1saXN0LWl0ZW1zL2NoaXAtbGlzdC1pdGVtLWxhYmVsLmRpcmVjdGl2ZVwiO1xuaW1wb3J0IHsgTmljZUNoaXBMaXN0SXRlbXNDb21wb25lbnQgfSBmcm9tIFwiLi9jaGlwLWxpc3QtaXRlbXMvY2hpcC1saXN0LWl0ZW1zLmNvbXBvbmVudFwiO1xuXG5pbXBvcnQgeyBOaWNlQ2hpcExpc3REaXJlY3RpdmUgfSBmcm9tIFwiLi9jaGlwLWxpc3QuZGlyZWN0aXZlXCI7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTWF0SWNvbk1vZHVsZV0sXG4gICAgZGVjbGFyYXRpb25zOiBbTmljZUNoaXBMaXN0RGlyZWN0aXZlLCBOaWNlQ2hpcExpc3RJdGVtc0NvbXBvbmVudCwgQ2hpcExpc3RJdGVtTGFiZWxEaXJlY3RpdmVdLFxuICAgIGV4cG9ydHM6IFtOaWNlQ2hpcExpc3REaXJlY3RpdmUsIE5pY2VDaGlwTGlzdEl0ZW1zQ29tcG9uZW50LCBDaGlwTGlzdEl0ZW1MYWJlbERpcmVjdGl2ZV1cbn0pXG5leHBvcnQgY2xhc3MgTmljZUNoaXBMaXN0RGlyZWN0aXZlTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export * from "./public-api";
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLXVpLWtpdC12Mi9zcmMvbGliL2RpcmVjdGl2ZXMvY2hpcC1saXN0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vcHVibGljLWFwaVwiO1xuIl19
@@ -0,0 +1,5 @@
1
+ export * from "./chip-list-items/chip-list-item-label.directive";
2
+ export * from "./chip-list-items/chip-list-items.component";
3
+ export * from "./chip-list.directive";
4
+ export * from "./chip-list.module";
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvZGlyZWN0aXZlcy9jaGlwLWxpc3QvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsNkNBQTZDLENBQUM7QUFDNUQsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vY2hpcC1saXN0LWl0ZW1zL2NoaXAtbGlzdC1pdGVtLWxhYmVsLmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY2hpcC1saXN0LWl0ZW1zL2NoaXAtbGlzdC1pdGVtcy5jb21wb25lbnRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NoaXAtbGlzdC5kaXJlY3RpdmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NoaXAtbGlzdC5tb2R1bGVcIjtcbiJdfQ==
@@ -1,5 +1,7 @@
1
1
  export * from "./autofocus";
2
2
  export * from "./autogrow";
3
+ export * from "./chip-async-typeahead";
4
+ export * from "./chip-list";
3
5
  export * from "./dropzone";
4
6
  export * from "./image-error-placeholder";
5
7
  export * from "./material";
@@ -8,4 +10,4 @@ export * from "./scroll-reset";
8
10
  export * from "./scrollbar";
9
11
  export * from "./stop-propagation";
10
12
  export * from "./window";
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvZGlyZWN0aXZlcy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vYXV0b2ZvY3VzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9hdXRvZ3Jvd1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZHJvcHpvbmVcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2ltYWdlLWVycm9yLXBsYWNlaG9sZGVyXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tYXRlcmlhbFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vbW9kYWxzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zY3JvbGwtcmVzZXRcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3Njcm9sbGJhclwiO1xuZXhwb3J0ICogZnJvbSBcIi4vc3RvcC1wcm9wYWdhdGlvblwiO1xuZXhwb3J0ICogZnJvbSBcIi4vd2luZG93XCI7XG4iXX0=
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvZGlyZWN0aXZlcy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9hdXRvZm9jdXNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2F1dG9ncm93XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jaGlwLWFzeW5jLXR5cGVhaGVhZFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vY2hpcC1saXN0XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9kcm9wem9uZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vaW1hZ2UtZXJyb3ItcGxhY2Vob2xkZXJcIjtcbmV4cG9ydCAqIGZyb20gXCIuL21hdGVyaWFsXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tb2RhbHNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3Njcm9sbC1yZXNldFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vc2Nyb2xsYmFyXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zdG9wLXByb3BhZ2F0aW9uXCI7XG5leHBvcnQgKiBmcm9tIFwiLi93aW5kb3dcIjtcbiJdfQ==