zek 14.2.38 → 14.2.48

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 (72) hide show
  1. package/esm2020/lib/components/base.component.mjs +3 -2
  2. package/esm2020/lib/components/core-ui.component.mjs +20 -5
  3. package/esm2020/lib/modules/age/age.pipe.mjs +2 -3
  4. package/esm2020/lib/modules/alert/alert/alert.component.mjs +1 -1
  5. package/esm2020/lib/modules/bb/bb-modal-base.component.mjs +9 -2
  6. package/esm2020/lib/modules/bb/bb-modal-toolbar.mjs +9 -2
  7. package/esm2020/lib/modules/bb/bb.component.mjs +32 -8
  8. package/esm2020/lib/modules/card/card/card.component.mjs +1 -1
  9. package/esm2020/lib/modules/edit-toolbar/edit-toolbar.component.mjs +23 -4
  10. package/esm2020/lib/modules/file/file-size.pipe.mjs +3 -3
  11. package/esm2020/lib/modules/grid-toolbar/grid-toolbar/grid-toolbar.component.mjs +72 -11
  12. package/esm2020/lib/modules/index.mjs +3 -1
  13. package/esm2020/lib/modules/list-toolbar/list-toolbar.component.mjs +44 -7
  14. package/esm2020/lib/modules/modal/modal/modal.component.mjs +72 -8
  15. package/esm2020/lib/modules/page-title/page-title.component.mjs +11 -1
  16. package/esm2020/lib/modules/pager/pager/pager.component.mjs +9 -2
  17. package/esm2020/lib/modules/password/password.component.mjs +9 -2
  18. package/esm2020/lib/modules/radio/radio-button.component.mjs +3 -3
  19. package/esm2020/lib/modules/readonly/readonly.directive.mjs +5 -5
  20. package/esm2020/lib/modules/select/index.mjs +3 -0
  21. package/esm2020/lib/modules/select/model.mjs +4 -0
  22. package/esm2020/lib/modules/select/module.mjs +28 -0
  23. package/esm2020/lib/modules/select/select.mjs +198 -0
  24. package/esm2020/lib/modules/select2/select2.component.mjs +1 -1
  25. package/esm2020/lib/modules/select2-multiple/select2-multiple.component.mjs +1 -1
  26. package/esm2020/lib/modules/validator/field-validator.component.mjs +1 -1
  27. package/esm2020/lib/modules/validators/directive.mjs +75 -0
  28. package/esm2020/lib/modules/validators/index.mjs +4 -0
  29. package/esm2020/lib/modules/validators/module.mjs +22 -0
  30. package/esm2020/lib/modules/validators/validator.mjs +72 -0
  31. package/esm2020/lib/modules/wizard/wizard/wizard.component.mjs +1 -1
  32. package/esm2020/lib/services/auth.service.mjs +2 -2
  33. package/esm2020/lib/utils/array-helper.mjs +25 -9
  34. package/esm2020/lib/utils/bitwise-helper.mjs +3 -3
  35. package/esm2020/lib/utils/convert.mjs +1 -1
  36. package/esm2020/lib/utils/date-helper.mjs +2 -2
  37. package/esm2020/lib/utils/filter-helper.mjs +2 -2
  38. package/esm2020/lib/utils/object-helper.mjs +17 -4
  39. package/esm2020/lib/utils/string-helper.mjs +9 -18
  40. package/esm2020/lib/utils/time-helper.mjs +2 -2
  41. package/fesm2015/zek.mjs +734 -91
  42. package/fesm2015/zek.mjs.map +1 -1
  43. package/fesm2020/zek.mjs +734 -91
  44. package/fesm2020/zek.mjs.map +1 -1
  45. package/lib/components/base.component.d.ts +3 -2
  46. package/lib/components/core-ui.component.d.ts +9 -4
  47. package/lib/modules/bb/bb-modal-base.component.d.ts +4 -2
  48. package/lib/modules/bb/bb-modal-toolbar.d.ts +4 -1
  49. package/lib/modules/bb/bb.component.d.ts +13 -10
  50. package/lib/modules/edit-toolbar/edit-toolbar.component.d.ts +10 -3
  51. package/lib/modules/grid-toolbar/grid-toolbar/grid-toolbar.component.d.ts +31 -10
  52. package/lib/modules/index.d.ts +2 -0
  53. package/lib/modules/list-toolbar/list-toolbar.component.d.ts +19 -6
  54. package/lib/modules/modal/modal/modal.component.d.ts +31 -11
  55. package/lib/modules/page-title/page-title.component.d.ts +4 -1
  56. package/lib/modules/pager/pager/pager.component.d.ts +4 -1
  57. package/lib/modules/password/password.component.d.ts +4 -1
  58. package/lib/modules/radio/radio-button.component.d.ts +0 -6
  59. package/lib/modules/readonly/readonly.directive.d.ts +3 -2
  60. package/lib/modules/select/index.d.ts +2 -0
  61. package/lib/modules/select/model.d.ts +5 -0
  62. package/lib/modules/select/module.d.ts +9 -0
  63. package/lib/modules/select/select.d.ts +42 -0
  64. package/lib/modules/validators/directive.d.ts +67 -0
  65. package/lib/modules/validators/index.d.ts +3 -0
  66. package/lib/modules/validators/module.d.ts +8 -0
  67. package/lib/modules/validators/validator.d.ts +33 -0
  68. package/lib/utils/array-helper.d.ts +2 -1
  69. package/lib/utils/bitwise-helper.d.ts +2 -2
  70. package/lib/utils/object-helper.d.ts +6 -0
  71. package/lib/utils/string-helper.d.ts +3 -3
  72. package/package.json +1 -1
@@ -1,16 +1,23 @@
1
1
  import { Component, Input, Output, EventEmitter } from '@angular/core';
2
2
  import { Pager } from '../../../models';
3
+ import { Convert } from '../../../utils';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@angular/common";
5
6
  import * as i2 from "@ngx-translate/core";
6
7
  export class PagerComponent {
7
8
  constructor() {
8
9
  this.pager = new Pager();
9
- this.showPageSize = true;
10
+ this._showPageSize = true;
10
11
  this.pagerAlign = 'start';
11
12
  this.onPageChange = new EventEmitter();
12
13
  this.onPageSizeChange = new EventEmitter();
13
14
  }
15
+ get showPageSize() {
16
+ return this._showPageSize;
17
+ }
18
+ set showPageSize(v) {
19
+ this._showPageSize = Convert.toBoolean(v);
20
+ }
14
21
  setPage(page) {
15
22
  // if (!this.pager) return;
16
23
  if (page === this.pager.pageNumber)
@@ -40,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
40
47
  }], onPageSizeChange: [{
41
48
  type: Output
42
49
  }] } });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9wYWdlci9wYWdlci9wYWdlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL3BhZ2VyL3BhZ2VyL3BhZ2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7O0FBT3hDLE1BQU0sT0FBTyxjQUFjO0lBTDNCO1FBTWEsVUFBSyxHQUFHLElBQUksS0FBSyxFQUFFLENBQUM7UUFDcEIsaUJBQVksR0FBRyxJQUFJLENBQUM7UUFDcEIsZUFBVSxHQUFHLE9BQU8sQ0FBQztRQWtCcEIsaUJBQVksR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBRTFDLHFCQUFnQixHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7S0FDM0Q7SUFsQkcsT0FBTyxDQUFDLElBQVk7UUFDaEIsMkJBQTJCO1FBRTNCLElBQUksSUFBSSxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVTtZQUM5QixPQUFPO1FBQ1gsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUNELFdBQVcsQ0FBQyxRQUFnQjtRQUN4QiwyQkFBMkI7UUFFM0IsSUFBSSxRQUFRLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRO1lBQ2hDLE9BQU87UUFDWCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3pDLENBQUM7OzJHQW5CUSxjQUFjOytGQUFkLGNBQWMsc05DUjNCLHN3SEFnRE07MkZEeENPLGNBQWM7a0JBTDFCLFNBQVM7K0JBQ0ksV0FBVzs4QkFLWixLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQWtCSSxZQUFZO3NCQUFyQixNQUFNO2dCQUVHLGdCQUFnQjtzQkFBekIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFBhZ2VyIH0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICd6ZWstcGFnZXInLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3BhZ2VyLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlczogWyc6aG9zdCB7IGRpc3BsYXk6IGJsb2NrOyB9J11cclxufSlcclxuZXhwb3J0IGNsYXNzIFBhZ2VyQ29tcG9uZW50IHtcclxuICAgIEBJbnB1dCgpIHBhZ2VyID0gbmV3IFBhZ2VyKCk7XHJcbiAgICBASW5wdXQoKSBzaG93UGFnZVNpemUgPSB0cnVlO1xyXG4gICAgQElucHV0KCkgcGFnZXJBbGlnbiA9ICdzdGFydCc7XHJcblxyXG5cclxuICAgIHNldFBhZ2UocGFnZTogbnVtYmVyKSB7XHJcbiAgICAgICAgLy8gaWYgKCF0aGlzLnBhZ2VyKSByZXR1cm47XHJcblxyXG4gICAgICAgIGlmIChwYWdlID09PSB0aGlzLnBhZ2VyLnBhZ2VOdW1iZXIpXHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB0aGlzLm9uUGFnZUNoYW5nZS5lbWl0KHBhZ2UpO1xyXG4gICAgfVxyXG4gICAgc2V0UGFnZVNpemUocGFnZVNpemU6IG51bWJlcikge1xyXG4gICAgICAgIC8vIGlmICghdGhpcy5wYWdlcikgcmV0dXJuO1xyXG5cclxuICAgICAgICBpZiAocGFnZVNpemUgPT09IHRoaXMucGFnZXIucGFnZVNpemUpXHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB0aGlzLm9uUGFnZVNpemVDaGFuZ2UuZW1pdChwYWdlU2l6ZSk7XHJcbiAgICB9XHJcblxyXG4gICAgQE91dHB1dCgpIG9uUGFnZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xyXG5cclxuICAgIEBPdXRwdXQoKSBvblBhZ2VTaXplQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxudW1iZXI+KCk7XHJcbn0iLCI8ZGl2ICpuZ0lmPVwicGFnZXJcIiBjbGFzcz1cInJvd1wiPlxyXG4gICAgPGRpdiBbbmdDbGFzc109XCJ7ICdjb2wtc20tOCc6IHNob3dQYWdlU2l6ZSwgJ2NvbC1zbS0xMic6ICFzaG93UGFnZVNpemV9XCI+XHJcbiAgICAgICAgPG5hdiBhcmlhLWxhYmVsPVwiUGFnaW5hdGlvblwiPlxyXG4gICAgICAgICAgICA8dWwgY2xhc3M9XCJwYWdpbmF0aW9uXCIgW25nQ2xhc3NdPVwieyAnanVzdGlmeS1jb250ZW50LWNlbnRlcic6IHBhZ2VyQWxpZ24gPT09ICdjZW50ZXInLCAnanVzdGlmeS1jb250ZW50LWVuZCc6IHBhZ2VyQWxpZ24gPT09ICdlbmQnfVwiPlxyXG4gICAgICAgICAgICAgICAgPGxpIFtjbGFzcy5kaXNhYmxlZF09XCJwYWdlci5pc0ZpcnN0UGFnZVwiIGNsYXNzPVwicGFnZS1pdGVtXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPGEgY2xhc3M9XCJwYWdlLWxpbmtcIiAoY2xpY2spPVwic2V0UGFnZSgxKVwiIGhyZWY9XCJqYXZhc2NyaXB0OnZvaWQoMClcIiBbYXR0ci5hcmlhLWRpc2FibGVkXT1cInBhZ2VyLmlzRmlyc3RQYWdlID8gJ3RydWUnIDogbnVsbFwiIGFyaWEtbGFiZWw9XCJGaXJzdFwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8c3BhbiBhcmlhLWhpZGRlbj1cInRydWVcIj4mbGFxdW87JmxhcXVvOzwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgICA8L2E+XHJcbiAgICAgICAgICAgICAgICA8L2xpPlxyXG4gICAgICAgICAgICAgICAgPGxpIFtjbGFzcy5kaXNhYmxlZF09XCIhcGFnZXIuaGFzUHJldmlvdXNQYWdlXCIgY2xhc3M9XCJwYWdlLWl0ZW1cIj5cclxuICAgICAgICAgICAgICAgICAgICA8YSBjbGFzcz1cInBhZ2UtbGlua1wiIChjbGljayk9XCJzZXRQYWdlKHBhZ2VyLnBhZ2VOdW1iZXIgLSAxKVwiIGhyZWY9XCJqYXZhc2NyaXB0OnZvaWQoMClcIiBbYXR0ci5hcmlhLWRpc2FibGVkXT1cIiFwYWdlci5oYXNQcmV2aW91c1BhZ2UgPyAndHJ1ZScgOiBudWxsXCIgYXJpYS1sYWJlbD1cIlByZXZpb3VzXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPiZsYXF1bzs8L3NwYW4+XHJcbiAgICAgICAgICAgICAgICAgICAgPC9hPlxyXG4gICAgICAgICAgICAgICAgPC9saT5cclxuICAgICAgICAgICAgICAgIDxsaSAqbmdGb3I9XCJsZXQgcGFnZSBvZiBwYWdlci5wYWdlc1wiIFtjbGFzcy5hY3RpdmVdPVwicGFnZSA9PT0gcGFnZXIucGFnZU51bWJlclwiIGNsYXNzPVwicGFnZS1pdGVtXCI+PGEgY2xhc3M9XCJwYWdlLWxpbmtcIiAoY2xpY2spPVwic2V0UGFnZShwYWdlKVwiIGhyZWY9XCJqYXZhc2NyaXB0OnZvaWQoMClcIj57e3BhZ2V9fTwvYT48L2xpPlxyXG4gICAgICAgICAgICAgICAgPGxpIFtjbGFzcy5kaXNhYmxlZF09XCIhcGFnZXIuaGFzTmV4dFBhZ2VcIiBjbGFzcz1cInBhZ2UtaXRlbVwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxhIGNsYXNzPVwicGFnZS1saW5rXCIgKGNsaWNrKT1cInNldFBhZ2UocGFnZXIucGFnZU51bWJlciArIDEpXCIgaHJlZj1cImphdmFzY3JpcHQ6dm9pZCgwKVwiIFthdHRyLmFyaWEtZGlzYWJsZWRdPVwiIXBhZ2VyLmhhc05leHRQYWdlID8gJ3RydWUnIDogbnVsbFwiIGFyaWEtbGFiZWw9XCJOZXh0XCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPiZyYXF1bzs8L3NwYW4+XHJcbiAgICAgICAgICAgICAgICAgICAgPC9hPlxyXG4gICAgICAgICAgICAgICAgPC9saT5cclxuICAgICAgICAgICAgICAgIDxsaSBbY2xhc3MuZGlzYWJsZWRdPVwicGFnZXIuaXNMYXN0UGFnZVwiIGNsYXNzPVwicGFnZS1pdGVtXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPGEgY2xhc3M9XCJwYWdlLWxpbmtcIiAoY2xpY2spPVwic2V0UGFnZShwYWdlci5wYWdlQ291bnQpXCIgaHJlZj1cImphdmFzY3JpcHQ6dm9pZCgwKVwiIFthdHRyLmFyaWEtZGlzYWJsZWRdPVwicGFnZXIuaXNMYXN0UGFnZSA/ICd0cnVlJyA6IG51bGxcIiBhcmlhLWxhYmVsPVwiTGFzdFwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8c3BhbiBhcmlhLWhpZGRlbj1cInRydWVcIj4mcmFxdW87JnJhcXVvOzwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgICA8L2E+XHJcbiAgICAgICAgICAgICAgICA8L2xpPlxyXG4gICAgICAgICAgICA8L3VsPlxyXG4gICAgICAgIDwvbmF2PlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY29sLXNtLTRcIiAqbmdJZj1cInNob3dQYWdlU2l6ZVwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJmbG9hdC1lbmRcIj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImRyb3Bkb3duXCI+XHJcbiAgICAgICAgICAgICAgICA8YnV0dG9uIGNsYXNzPVwiYnRuIGJ0bi1zZWNvbmRhcnkgZHJvcGRvd24tdG9nZ2xlXCIgdHlwZT1cImJ1dHRvblwiIGlkPVwicGFnZS1zaXplLWJ1dHRvblwiIGRhdGEtYnMtdG9nZ2xlPVwiZHJvcGRvd25cIiBhcmlhLWV4cGFuZGVkPVwiZmFsc2VcIj5cclxuICAgICAgICAgICAgICAgICAgICB7e3BhZ2VyLnBhZ2VTaXplfX1cclxuICAgICAgICAgICAgICAgIDwvYnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgPHVsIGNsYXNzPVwiZHJvcGRvd24tbWVudSBkcm9wZG93bi1tZW51LWVuZFwiIGFyaWEtbGFiZWxsZWRieT1cInBhZ2Utc2l6ZS1idXR0b25cIj5cclxuICAgICAgICAgICAgICAgICAgICA8bGk+PGg2IGNsYXNzPVwiZHJvcGRvd24taGVhZGVyXCI+e3sgJ1BhZ2luYXRpb24uUGFnZVNpemUnIHwgdHJhbnNsYXRlIH19PC9oNj48L2xpPlxyXG4gICAgICAgICAgICAgICAgICAgIDxsaT48YSBjbGFzcz1cImRyb3Bkb3duLWl0ZW1cIiBbY2xhc3MuYWN0aXZlXT1cInBhZ2VyLnBhZ2VTaXplID09PSAxMFwiIChjbGljayk9XCJzZXRQYWdlU2l6ZSgxMClcIiBocmVmPVwiamF2YXNjcmlwdDp2b2lkKDApXCI+MTA8L2E+PC9saT5cclxuICAgICAgICAgICAgICAgICAgICA8bGk+PGEgY2xhc3M9XCJkcm9wZG93bi1pdGVtXCIgW2NsYXNzLmFjdGl2ZV09XCJwYWdlci5wYWdlU2l6ZSA9PT0gMjBcIiAoY2xpY2spPVwic2V0UGFnZVNpemUoMjApXCIgaHJlZj1cImphdmFzY3JpcHQ6dm9pZCgwKVwiPjIwPC9hPjwvbGk+XHJcbiAgICAgICAgICAgICAgICAgICAgPGxpPjxhIGNsYXNzPVwiZHJvcGRvd24taXRlbVwiIFtjbGFzcy5hY3RpdmVdPVwicGFnZXIucGFnZVNpemUgPT09IDUwXCIgKGNsaWNrKT1cInNldFBhZ2VTaXplKDUwKVwiIGhyZWY9XCJqYXZhc2NyaXB0OnZvaWQoMClcIj41MDwvYT48L2xpPlxyXG4gICAgICAgICAgICAgICAgICAgIDxsaT48YSBjbGFzcz1cImRyb3Bkb3duLWl0ZW1cIiBbY2xhc3MuYWN0aXZlXT1cInBhZ2VyLnBhZ2VTaXplID09PSAxMDBcIiAoY2xpY2spPVwic2V0UGFnZVNpemUoMTAwKVwiIGhyZWY9XCJqYXZhc2NyaXB0OnZvaWQoMClcIj4xMDA8L2E+PC9saT5cclxuICAgICAgICAgICAgICAgICAgICA8bGk+PGEgY2xhc3M9XCJkcm9wZG93bi1pdGVtXCIgW2NsYXNzLmFjdGl2ZV09XCJwYWdlci5wYWdlU2l6ZSA9PT0gNTAwXCIgKGNsaWNrKT1cInNldFBhZ2VTaXplKDUwMClcIiBocmVmPVwiamF2YXNjcmlwdDp2b2lkKDApXCI+NTAwPC9hPjwvbGk+XHJcbiAgICAgICAgICAgICAgICA8L3VsPlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZmxvYXQtZW5kIG10LTJcIj5cclxuICAgICAgICAgICAge3twYWdlci5maXJzdEl0ZW1PblBhZ2V9fSAtIHt7cGFnZXIubGFzdEl0ZW1PblBhZ2V9fSBvZiB7e3BhZ2VyLnRvdGFsSXRlbUNvdW50fX0gJm5ic3A7XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuPC9kaXY+Il19
50
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pager.component.js","sourceRoot":"","sources":["../../../../../../../projects/zek/src/lib/modules/pager/pager/pager.component.ts","../../../../../../../projects/zek/src/lib/modules/pager/pager/pager.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;;;;AAOzC,MAAM,OAAO,cAAc;IAL3B;QAMa,UAAK,GAAG,IAAI,KAAK,EAAE,CAAC;QAErB,kBAAa,GAAY,IAAI,CAAC;QAS7B,eAAU,GAAG,OAAO,CAAC;QAkBpB,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC;QAE1C,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;KAC3D;IA7BG,IACI,YAAY;QACZ,OAAO,IAAI,CAAC,aAAa,CAAC;IAC9B,CAAC;IACD,IAAI,YAAY,CAAC,CAAe;QAC5B,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC;IAKD,OAAO,CAAC,IAAY;QAChB,2BAA2B;QAE3B,IAAI,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,UAAU;YAC9B,OAAO;QACX,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IACD,WAAW,CAAC,QAAgB;QACxB,2BAA2B;QAE3B,IAAI,QAAQ,KAAK,IAAI,CAAC,KAAK,CAAC,QAAQ;YAChC,OAAO;QACX,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACzC,CAAC;;2GA5BQ,cAAc;+FAAd,cAAc,sNCV3B,swHAgDM;2FDtCO,cAAc;kBAL1B,SAAS;+BACI,WAAW;8BAKZ,KAAK;sBAAb,KAAK;gBAIF,YAAY;sBADf,KAAK;gBAQG,UAAU;sBAAlB,KAAK;gBAkBI,YAAY;sBAArB,MAAM;gBAEG,gBAAgB;sBAAzB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\r\nimport { BooleanInput } from '../../../components';\r\nimport { Pager } from '../../../models';\r\nimport { Convert } from '../../../utils';\r\n\r\n@Component({\r\n    selector: 'zek-pager',\r\n    templateUrl: './pager.component.html',\r\n    styles: [':host { display: block; }']\r\n})\r\nexport class PagerComponent {\r\n    @Input() pager = new Pager();\r\n\r\n    private _showPageSize: boolean = true;\r\n    @Input()\r\n    get showPageSize(): boolean {\r\n        return this._showPageSize;\r\n    }\r\n    set showPageSize(v: BooleanInput) {\r\n        this._showPageSize = Convert.toBoolean(v);\r\n    }\r\n\r\n    @Input() pagerAlign = 'start';\r\n\r\n\r\n    setPage(page: number) {\r\n        // if (!this.pager) return;\r\n\r\n        if (page === this.pager.pageNumber)\r\n            return;\r\n        this.onPageChange.emit(page);\r\n    }\r\n    setPageSize(pageSize: number) {\r\n        // if (!this.pager) return;\r\n\r\n        if (pageSize === this.pager.pageSize)\r\n            return;\r\n        this.onPageSizeChange.emit(pageSize);\r\n    }\r\n\r\n    @Output() onPageChange = new EventEmitter<number>();\r\n\r\n    @Output() onPageSizeChange = new EventEmitter<number>();\r\n}","<div *ngIf=\"pager\" class=\"row\">\r\n    <div [ngClass]=\"{ 'col-sm-8': showPageSize, 'col-sm-12': !showPageSize}\">\r\n        <nav aria-label=\"Pagination\">\r\n            <ul class=\"pagination\" [ngClass]=\"{ 'justify-content-center': pagerAlign === 'center', 'justify-content-end': pagerAlign === 'end'}\">\r\n                <li [class.disabled]=\"pager.isFirstPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(1)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"pager.isFirstPage ? 'true' : null\" aria-label=\"First\">\r\n                        <span aria-hidden=\"true\">&laquo;&laquo;</span>\r\n                    </a>\r\n                </li>\r\n                <li [class.disabled]=\"!pager.hasPreviousPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(pager.pageNumber - 1)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"!pager.hasPreviousPage ? 'true' : null\" aria-label=\"Previous\">\r\n                        <span aria-hidden=\"true\">&laquo;</span>\r\n                    </a>\r\n                </li>\r\n                <li *ngFor=\"let page of pager.pages\" [class.active]=\"page === pager.pageNumber\" class=\"page-item\"><a class=\"page-link\" (click)=\"setPage(page)\" href=\"javascript:void(0)\">{{page}}</a></li>\r\n                <li [class.disabled]=\"!pager.hasNextPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(pager.pageNumber + 1)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"!pager.hasNextPage ? 'true' : null\" aria-label=\"Next\">\r\n                        <span aria-hidden=\"true\">&raquo;</span>\r\n                    </a>\r\n                </li>\r\n                <li [class.disabled]=\"pager.isLastPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(pager.pageCount)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"pager.isLastPage ? 'true' : null\" aria-label=\"Last\">\r\n                        <span aria-hidden=\"true\">&raquo;&raquo;</span>\r\n                    </a>\r\n                </li>\r\n            </ul>\r\n        </nav>\r\n    </div>\r\n    <div class=\"col-sm-4\" *ngIf=\"showPageSize\">\r\n        <div class=\"float-end\">\r\n            <div class=\"dropdown\">\r\n                <button class=\"btn btn-secondary dropdown-toggle\" type=\"button\" id=\"page-size-button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n                    {{pager.pageSize}}\r\n                </button>\r\n                <ul class=\"dropdown-menu dropdown-menu-end\" aria-labelledby=\"page-size-button\">\r\n                    <li><h6 class=\"dropdown-header\">{{ 'Pagination.PageSize' | translate }}</h6></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 10\" (click)=\"setPageSize(10)\" href=\"javascript:void(0)\">10</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 20\" (click)=\"setPageSize(20)\" href=\"javascript:void(0)\">20</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 50\" (click)=\"setPageSize(50)\" href=\"javascript:void(0)\">50</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 100\" (click)=\"setPageSize(100)\" href=\"javascript:void(0)\">100</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 500\" (click)=\"setPageSize(500)\" href=\"javascript:void(0)\">500</a></li>\r\n                </ul>\r\n            </div>\r\n        </div>\r\n        <div class=\"float-end mt-2\">\r\n            {{pager.firstItemOnPage}} - {{pager.lastItemOnPage}} of {{pager.totalItemCount}} &nbsp;\r\n        </div>\r\n    </div>\r\n</div>"]}
@@ -1,16 +1,23 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { Convert } from '../../utils';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "@angular/forms";
4
5
  import * as i2 from "../validator/field-validator.component";
5
6
  export class PasswordComponent {
6
7
  constructor() {
7
8
  this.name = 'Password';
8
- this.required = false;
9
+ this._required = false;
9
10
  this.minlength = null;
10
11
  this.maxlength = null;
11
12
  this.onChange = new EventEmitter();
12
13
  this._type = 'password';
13
14
  }
15
+ get required() {
16
+ return this._required;
17
+ }
18
+ set required(v) {
19
+ this._required = Convert.toBoolean(v);
20
+ }
14
21
  get type() {
15
22
  return this._type;
16
23
  }
@@ -37,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
37
44
  type: Output,
38
45
  args: ['modelChange']
39
46
  }] } });
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFzc3dvcmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9wYXNzd29yZC9wYXNzd29yZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL3Bhc3N3b3JkL3Bhc3N3b3JkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFNdkUsTUFBTSxPQUFPLGlCQUFpQjtJQUo5QjtRQUtXLFNBQUksR0FBRyxVQUFVLENBQUM7UUFDbEIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNqQixjQUFTLEdBQTJCLElBQUksQ0FBQztRQUN6QyxjQUFTLEdBQTJCLElBQUksQ0FBQztRQUczQixhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUU3QyxVQUFLLEdBQUcsVUFBVSxDQUFDO0tBUTVCO0lBUEMsSUFBSSxJQUFJO1FBQ04sT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3BCLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxLQUFLLFVBQVUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUM7SUFDL0QsQ0FBQzs7OEdBaEJVLGlCQUFpQjtrR0FBakIsaUJBQWlCLDBNQ045Qiw0a0JBUU07MkZERk8saUJBQWlCO2tCQUo3QixTQUFTOytCQUNFLGNBQWM7OEJBSWYsSUFBSTtzQkFBWixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUVHLEtBQUs7c0JBQWIsS0FBSztnQkFDaUIsUUFBUTtzQkFBOUIsTUFBTTt1QkFBQyxhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnemVrLXBhc3N3b3JkJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vcGFzc3dvcmQuY29tcG9uZW50Lmh0bWwnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQYXNzd29yZENvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgbmFtZSA9ICdQYXNzd29yZCc7XHJcbiAgQElucHV0KCkgcmVxdWlyZWQgPSBmYWxzZTtcclxuICBASW5wdXQoKSBtaW5sZW5ndGg6IG51bWJlciB8IHN0cmluZyB8IG51bGwgPSBudWxsO1xyXG4gIEBJbnB1dCgpIG1heGxlbmd0aDogbnVtYmVyIHwgc3RyaW5nIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gIEBJbnB1dCgpIG1vZGVsPzogc3RyaW5nIHwgbnVsbDtcclxuICBAT3V0cHV0KCdtb2RlbENoYW5nZScpIG9uQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG5cclxuICBwcml2YXRlIF90eXBlID0gJ3Bhc3N3b3JkJztcclxuICBnZXQgdHlwZSgpIHtcclxuICAgIHJldHVybiB0aGlzLl90eXBlO1xyXG4gIH1cclxuXHJcbiAgc2hvd0hpZGUoKSB7XHJcbiAgICB0aGlzLl90eXBlID0gdGhpcy5fdHlwZSA9PT0gJ3Bhc3N3b3JkJyA/ICd0ZXh0JyA6ICdwYXNzd29yZCc7XHJcbiAgfVxyXG59IiwiPGRpdiBjbGFzcz1cImlucHV0LWdyb3VwIGhhcy12YWxpZGF0aW9uXCI+XHJcbiAgICA8aW5wdXQgdHlwZT1cInt7dHlwZX19XCIgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIiBuYW1lPVwie3tuYW1lfX1cIiBpZD1cInt7bmFtZX19XCIgW2F0dHIuYXJpYS1kZXNjcmliZWRieV09XCJuYW1lKyctc2hvdydcIlxyXG4gICAgW3JlcXVpcmVkXT1cInJlcXVpcmVkXCIgW21pbmxlbmd0aF09XCJtaW5sZW5ndGhcIiBbbWF4bGVuZ3RoXT1cIm1heGxlbmd0aFwiXHJcbiAgICBbbmdNb2RlbF09XCJtb2RlbFwiIChuZ01vZGVsQ2hhbmdlKT1cIm9uQ2hhbmdlLmVtaXQoJGV2ZW50KVwiXHJcbiAgICAjcGFzc3dvcmQ9XCJuZ01vZGVsXCJcclxuICAgID5cclxuICAgIDxidXR0b24gY2xhc3M9XCJidG4gYnRuLW91dGxpbmUtc2Vjb25kYXJ5XCIgdHlwZT1cImJ1dHRvblwiIGlkPVwie3tuYW1lfX0tc2hvd1wiIChjbGljayk9XCJzaG93SGlkZSgpXCI+PGkgY2xhc3M9XCJmYS1zb2xpZCBmYS1leWVcIj48L2k+PC9idXR0b24+XHJcbiAgICA8ZGl2IHplay1maWVsZC12YWxpZGF0b3IgW2ZpZWxkXT1cInBhc3N3b3JkXCI+PC9kaXY+XHJcbjwvZGl2PiJdfQ==
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFzc3dvcmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9wYXNzd29yZC9wYXNzd29yZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL3Bhc3N3b3JkL3Bhc3N3b3JkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFdkUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGFBQWEsQ0FBQzs7OztBQU10QyxNQUFNLE9BQU8saUJBQWlCO0lBSjlCO1FBS2EsU0FBSSxHQUFHLFVBQVUsQ0FBQztRQUVuQixjQUFTLEdBQVksS0FBSyxDQUFDO1FBUzFCLGNBQVMsR0FBMkIsSUFBSSxDQUFDO1FBQ3pDLGNBQVMsR0FBMkIsSUFBSSxDQUFDO1FBRzNCLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRTdDLFVBQUssR0FBRyxVQUFVLENBQUM7S0FROUI7SUF0QkcsSUFDSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFDRCxJQUFJLFFBQVEsQ0FBQyxDQUFlO1FBQ3hCLElBQUksQ0FBQyxTQUFTLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBU0QsSUFBSSxJQUFJO1FBQ0osT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxLQUFLLFVBQVUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUM7SUFDakUsQ0FBQzs7OEdBekJRLGlCQUFpQjtrR0FBakIsaUJBQWlCLDBNQ1I5Qiw0a0JBUU07MkZEQU8saUJBQWlCO2tCQUo3QixTQUFTOytCQUNJLGNBQWM7OEJBSWYsSUFBSTtzQkFBWixLQUFLO2dCQUlGLFFBQVE7c0JBRFgsS0FBSztnQkFRRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRUcsS0FBSztzQkFBYixLQUFLO2dCQUNpQixRQUFRO3NCQUE5QixNQUFNO3VCQUFDLGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBCb29sZWFuSW5wdXQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgQ29udmVydCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICd6ZWstcGFzc3dvcmQnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3Bhc3N3b3JkLmNvbXBvbmVudC5odG1sJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgUGFzc3dvcmRDb21wb25lbnQge1xyXG4gICAgQElucHV0KCkgbmFtZSA9ICdQYXNzd29yZCc7XHJcblxyXG4gICAgcHJpdmF0ZSBfcmVxdWlyZWQ6IGJvb2xlYW4gPSBmYWxzZTtcclxuICAgIEBJbnB1dCgpXHJcbiAgICBnZXQgcmVxdWlyZWQoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3JlcXVpcmVkO1xyXG4gICAgfVxyXG4gICAgc2V0IHJlcXVpcmVkKHY6IEJvb2xlYW5JbnB1dCkge1xyXG4gICAgICAgIHRoaXMuX3JlcXVpcmVkID0gQ29udmVydC50b0Jvb2xlYW4odik7XHJcbiAgICB9XHJcblxyXG4gICAgQElucHV0KCkgbWlubGVuZ3RoOiBudW1iZXIgfCBzdHJpbmcgfCBudWxsID0gbnVsbDtcclxuICAgIEBJbnB1dCgpIG1heGxlbmd0aDogbnVtYmVyIHwgc3RyaW5nIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gICAgQElucHV0KCkgbW9kZWw/OiBzdHJpbmcgfCBudWxsO1xyXG4gICAgQE91dHB1dCgnbW9kZWxDaGFuZ2UnKSBvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuXHJcbiAgICBwcml2YXRlIF90eXBlID0gJ3Bhc3N3b3JkJztcclxuICAgIGdldCB0eXBlKCkge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl90eXBlO1xyXG4gICAgfVxyXG5cclxuICAgIHNob3dIaWRlKCkge1xyXG4gICAgICAgIHRoaXMuX3R5cGUgPSB0aGlzLl90eXBlID09PSAncGFzc3dvcmQnID8gJ3RleHQnIDogJ3Bhc3N3b3JkJztcclxuICAgIH1cclxufSIsIjxkaXYgY2xhc3M9XCJpbnB1dC1ncm91cCBoYXMtdmFsaWRhdGlvblwiPlxyXG4gICAgPGlucHV0IHR5cGU9XCJ7e3R5cGV9fVwiIGNsYXNzPVwiZm9ybS1jb250cm9sXCIgbmFtZT1cInt7bmFtZX19XCIgaWQ9XCJ7e25hbWV9fVwiIFthdHRyLmFyaWEtZGVzY3JpYmVkYnldPVwibmFtZSsnLXNob3cnXCJcclxuICAgIFtyZXF1aXJlZF09XCJyZXF1aXJlZFwiIFttaW5sZW5ndGhdPVwibWlubGVuZ3RoXCIgW21heGxlbmd0aF09XCJtYXhsZW5ndGhcIlxyXG4gICAgW25nTW9kZWxdPVwibW9kZWxcIiAobmdNb2RlbENoYW5nZSk9XCJvbkNoYW5nZS5lbWl0KCRldmVudClcIlxyXG4gICAgI3Bhc3N3b3JkPVwibmdNb2RlbFwiXHJcbiAgICA+XHJcbiAgICA8YnV0dG9uIGNsYXNzPVwiYnRuIGJ0bi1vdXRsaW5lLXNlY29uZGFyeVwiIHR5cGU9XCJidXR0b25cIiBpZD1cInt7bmFtZX19LXNob3dcIiAoY2xpY2spPVwic2hvd0hpZGUoKVwiPjxpIGNsYXNzPVwiZmEtc29saWQgZmEtZXllXCI+PC9pPjwvYnV0dG9uPlxyXG4gICAgPGRpdiB6ZWstZmllbGQtdmFsaWRhdG9yIFtmaWVsZF09XCJwYXNzd29yZFwiPjwvZGl2PlxyXG48L2Rpdj4iXX0=
@@ -5,11 +5,11 @@ import { Convert } from '../../utils';
5
5
  import * as i0 from "@angular/core";
6
6
  let uniqueId = 0;
7
7
  /**
8
- * Provider Expression that allows mat-radio-group to register as a ControlValueAccessor. This
8
+ * Provider Expression that allows zek-radio to register as a ControlValueAccessor. This
9
9
  * allows it to support [(ngModel)] and ngControl.
10
10
  * @docs-private
11
11
  */
12
- export const ZEK_RADIO_CONTROL_VALUE_ACCESSOR = {
12
+ const ZEK_RADIO_CONTROL_VALUE_ACCESSOR = {
13
13
  provide: NG_VALUE_ACCESSOR,
14
14
  useExisting: forwardRef(() => RadioComponent),
15
15
  multi: true,
@@ -120,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
120
120
  }], checked: [{
121
121
  type: Input
122
122
  }] } });
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-button.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/radio/radio-button.component.ts","../../../../../../projects/zek/src/lib/modules/radio/radio.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input, OnInit, Renderer2, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BooleanInput } from '../../components';\r\nimport { CoreUiComponent } from '../../components/core-ui.component';\r\nimport { Convert } from '../../utils';\r\n\r\nlet uniqueId = 0;\r\n\r\n/**\r\n * Provider Expression that allows mat-radio-group to register as a ControlValueAccessor. This\r\n * allows it to support [(ngModel)] and ngControl.\r\n * @docs-private\r\n */\r\nexport const ZEK_RADIO_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => RadioComponent),\r\n    multi: true,\r\n};\r\n\r\n\r\n@Component({\r\n    selector: 'zek-radio',\r\n    templateUrl: './radio.component.html',\r\n    host: {\r\n        '[attr.id]': 'id',\r\n        '[attr.tabindex]': 'null',\r\n        '[attr.aria-label]': 'null',\r\n        '[attr.aria-labelledby]': 'null',\r\n        '[attr.aria-describedby]': 'null',\r\n        // Note: under normal conditions focus shouldn't land on this element, however it may be\r\n        // programmatically set, for example inside of a focus trap, in this case we want to forward\r\n        // the focus to the native element.\r\n        '(focus)': '_inputElement.nativeElement.focus()',\r\n\r\n    },\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [ZEK_RADIO_CONTROL_VALUE_ACCESSOR],\r\n})\r\nexport class RadioComponent extends CoreUiComponent\r\n    implements OnInit {\r\n    constructor(\r\n        private _changeDetector: ChangeDetectorRef,\r\n        _renderer: Renderer2,\r\n        _elementRef: ElementRef) {\r\n        super(_renderer, _elementRef);\r\n    }\r\n\r\n\r\n    private _uniqueId: string = `zek-radio-${++uniqueId}`;\r\n\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    /** Used to set the 'aria-label' attribute on the underlying input element. */\r\n    @Input('aria-label') ariaLabel?: string | null;\r\n\r\n    /** The 'aria-labelledby' attribute takes precedence as the element's text alternative. */\r\n    @Input('aria-labelledby') ariaLabelledby?: string | null;\r\n\r\n    /** The 'aria-describedby' attribute is read after the element's label and field type. */\r\n    @Input('aria-describedby') ariaDescribedby?: string | null;\r\n\r\n    /** The native `<input type=radio>` element */\r\n    @ViewChild('input') _inputElement?: ElementRef<HTMLInputElement> | null;\r\n\r\n\r\n    @Input() inline = false;\r\n\r\n    get inputId(): string {\r\n        return `${this.id || this._uniqueId}-input`;\r\n    }\r\n\r\n\r\n    /** The value from ngModel. */\r\n    private modelValue: any;\r\n\r\n\r\n    private _checked: boolean = false;\r\n    @Input()\r\n    get checked(): boolean {\r\n        return this._checked;\r\n    }\r\n    set checked(value: BooleanInput) {\r\n        const newCheckedState = Convert.toBoolean(value);\r\n        if (this._checked !== newCheckedState) {\r\n            this._checked = newCheckedState;\r\n            this._markForCheck();\r\n        }\r\n    }\r\n\r\n\r\n    override writeValue(value: any): void {\r\n        if (this.modelValue !== value) {\r\n            this.modelValue = value;\r\n            this.checked = this.modelValue === this._value;\r\n        }\r\n\r\n    }\r\n    override onValueChanged() {\r\n        if (!this.checked) {\r\n            // Update checked when the value changed to match the radio group's value\r\n            this.checked = this.modelValue === this._value;\r\n        }\r\n    }\r\n\r\n\r\n    override onRequiredChanged(): void {\r\n        this._markForCheck();\r\n    }\r\n    override onDisabledChanged() {\r\n        this._markForCheck();\r\n    }\r\n\r\n\r\n    /**\r\n     * Marks the radio button as needing checking for change detection.\r\n     * This method is exposed because the parent radio group will directly\r\n     * update bound properties of the radio button.\r\n     */\r\n    private _markForCheck() {\r\n        // When group value changes, the button will not be notified. Use `markForCheck` to explicit\r\n        // update radio button's status\r\n        this._changeDetector.markForCheck();\r\n    }\r\n\r\n\r\n    override init(): void {\r\n        // Determine if it should be checked\r\n        this.checked = this.modelValue === this._value;\r\n    }\r\n\r\n\r\n    /** Triggered when the radio button receives an interaction from the user. */\r\n    override _onInputInteraction(event: Event) {\r\n        // We always have to stop propagation on the change event.\r\n        // Otherwise the change event, from the input element, will bubble up and\r\n        // emit its event object to the `change` output.\r\n        event.stopPropagation();\r\n\r\n        if (!this.checked && !this.disabled) {\r\n            const modelValueChanged = this.value !== this.modelValue;\r\n            this.checked = true;\r\n            this.modelValue = this._value;\r\n            this._emitChangeEvent();\r\n\r\n            if (modelValueChanged) {\r\n                this._onChange(this._value);\r\n            }\r\n        }\r\n    }\r\n}","<div class=\"form-check\" [class.form-check-inline]=\"inline\">\r\n    <input #input class=\"form-check-input\" type=\"radio\"\r\n    [id]=\"inputId\"\r\n    [checked]=\"checked\"\r\n    [disabled]=\"disabled\"\r\n    [attr.name]=\"name\"\r\n    [attr.value]=\"value\"\r\n    [required]=\"required\"\r\n    [attr.aria-label]=\"ariaLabel\"\r\n    [attr.aria-labelledby]=\"ariaLabelledby\"\r\n    [attr.aria-describedby]=\"ariaDescribedby\"\r\n    (change)=\"_onInputInteraction($event)\">\r\n    <label [for]=\"inputId\">\r\n        <ng-content></ng-content>\r\n    </label>\r\n</div>"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-button.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/radio/radio-button.component.ts","../../../../../../projects/zek/src/lib/modules/radio/radio.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, forwardRef, Input, OnInit, Renderer2, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BooleanInput } from '../../components';\r\nimport { CoreUiComponent } from '../../components/core-ui.component';\r\nimport { Convert } from '../../utils';\r\n\r\nlet uniqueId = 0;\r\n\r\n/**\r\n * Provider Expression that allows zek-radio to register as a ControlValueAccessor. This\r\n * allows it to support [(ngModel)] and ngControl.\r\n * @docs-private\r\n */\r\nconst ZEK_RADIO_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => RadioComponent),\r\n    multi: true,\r\n};\r\n\r\n\r\n@Component({\r\n    selector: 'zek-radio',\r\n    templateUrl: './radio.component.html',\r\n    host: {\r\n        '[attr.id]': 'id',\r\n        '[attr.tabindex]': 'null',\r\n        '[attr.aria-label]': 'null',\r\n        '[attr.aria-labelledby]': 'null',\r\n        '[attr.aria-describedby]': 'null',\r\n        // Note: under normal conditions focus shouldn't land on this element, however it may be\r\n        // programmatically set, for example inside of a focus trap, in this case we want to forward\r\n        // the focus to the native element.\r\n        '(focus)': '_inputElement.nativeElement.focus()',\r\n\r\n    },\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [ZEK_RADIO_CONTROL_VALUE_ACCESSOR],\r\n})\r\nexport class RadioComponent extends CoreUiComponent\r\n    implements OnInit {\r\n    constructor(\r\n        private _changeDetector: ChangeDetectorRef,\r\n        _renderer: Renderer2,\r\n        _elementRef: ElementRef) {\r\n        super(_renderer, _elementRef);\r\n    }\r\n\r\n\r\n    private _uniqueId: string = `zek-radio-${++uniqueId}`;\r\n\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    /** Used to set the 'aria-label' attribute on the underlying input element. */\r\n    @Input('aria-label') ariaLabel?: string | null;\r\n\r\n    /** The 'aria-labelledby' attribute takes precedence as the element's text alternative. */\r\n    @Input('aria-labelledby') ariaLabelledby?: string | null;\r\n\r\n    /** The 'aria-describedby' attribute is read after the element's label and field type. */\r\n    @Input('aria-describedby') ariaDescribedby?: string | null;\r\n\r\n    /** The native `<input type=radio>` element */\r\n    @ViewChild('input') _inputElement?: ElementRef<HTMLInputElement> | null;\r\n\r\n\r\n    @Input() inline = false;\r\n\r\n    get inputId(): string {\r\n        return `${this.id || this._uniqueId}-input`;\r\n    }\r\n\r\n\r\n    /** The value from ngModel. */\r\n    private modelValue: any;\r\n\r\n\r\n    private _checked: boolean = false;\r\n    @Input()\r\n    get checked(): boolean {\r\n        return this._checked;\r\n    }\r\n    set checked(value: BooleanInput) {\r\n        const newCheckedState = Convert.toBoolean(value);\r\n        if (this._checked !== newCheckedState) {\r\n            this._checked = newCheckedState;\r\n            this._markForCheck();\r\n        }\r\n    }\r\n\r\n\r\n    override writeValue(value: any): void {\r\n        if (this.modelValue !== value) {\r\n            this.modelValue = value;\r\n            this.checked = this.modelValue === this._value;\r\n        }\r\n\r\n    }\r\n    override onValueChanged() {\r\n        if (!this.checked) {\r\n            // Update checked when the value changed to match the radio group's value\r\n            this.checked = this.modelValue === this._value;\r\n        }\r\n    }\r\n\r\n\r\n    override onRequiredChanged(): void {\r\n        this._markForCheck();\r\n    }\r\n    override onDisabledChanged() {\r\n        this._markForCheck();\r\n    }\r\n\r\n\r\n    /**\r\n     * Marks the radio button as needing checking for change detection.\r\n     * This method is exposed because the parent radio group will directly\r\n     * update bound properties of the radio button.\r\n     */\r\n    private _markForCheck() {\r\n        // When group value changes, the button will not be notified. Use `markForCheck` to explicit\r\n        // update radio button's status\r\n        this._changeDetector.markForCheck();\r\n    }\r\n\r\n\r\n    override init(): void {\r\n        // Determine if it should be checked\r\n        this.checked = this.modelValue === this._value;\r\n    }\r\n\r\n\r\n    /** Triggered when the radio button receives an interaction from the user. */\r\n    override _onInputInteraction(event: Event) {\r\n        // We always have to stop propagation on the change event.\r\n        // Otherwise the change event, from the input element, will bubble up and\r\n        // emit its event object to the `change` output.\r\n        event.stopPropagation();\r\n\r\n        if (!this.checked && !this.disabled) {\r\n            const modelValueChanged = this.value !== this.modelValue;\r\n            this.checked = true;\r\n            this.modelValue = this._value;\r\n            this._emitChangeEvent();\r\n\r\n            if (modelValueChanged) {\r\n                this._onChange(this._value);\r\n            }\r\n        }\r\n    }\r\n}","<div class=\"form-check\" [class.form-check-inline]=\"inline\">\r\n    <input #input class=\"form-check-input\" type=\"radio\"\r\n    [id]=\"inputId\"\r\n    [checked]=\"checked\"\r\n    [disabled]=\"disabled\"\r\n    [attr.name]=\"name\"\r\n    [attr.value]=\"value\"\r\n    [required]=\"required\"\r\n    [attr.aria-label]=\"ariaLabel\"\r\n    [attr.aria-labelledby]=\"ariaLabelledby\"\r\n    [attr.aria-describedby]=\"ariaDescribedby\"\r\n    (change)=\"_onInputInteraction($event)\">\r\n    <label [for]=\"inputId\">\r\n        <ng-content></ng-content>\r\n    </label>\r\n</div>"]}
@@ -1,13 +1,13 @@
1
1
  import { Directive, Input } from '@angular/core';
2
+ import { Convert } from '../../utils';
2
3
  import * as i0 from "@angular/core";
3
4
  export class ReadOnlyDirective {
4
5
  constructor() {
5
- this._isReadonly = false;
6
+ this._readonly = false;
6
7
  }
7
- set readonly(v) {
8
- this._isReadonly = v == true || v == '';
8
+ readonly(v) {
9
+ this._readonly = Convert.toBoolean(v);
9
10
  }
10
- ;
11
11
  }
12
12
  ReadOnlyDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ReadOnlyDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
13
13
  ReadOnlyDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: ReadOnlyDirective, selector: "[readonly],[readOnly]", inputs: { readonly: "readonly" }, host: { properties: { "attr.readonly": "_isReadonly ? \"\" : null" } }, ngImport: i0 });
@@ -22,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
22
22
  }], propDecorators: { readonly: [{
23
23
  type: Input
24
24
  }] } });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhZG9ubHkuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9yZWFkb25seS9yZWFkb25seS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBUWpELE1BQU0sT0FBTyxpQkFBaUI7SUFOOUI7UUFPSSxnQkFBVyxHQUFHLEtBQUssQ0FBQztLQUt2QjtJQUhHLElBQWEsUUFBUSxDQUFDLENBQW1CO1FBQ3JDLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzVDLENBQUM7SUFBQSxDQUFDOzs4R0FMTyxpQkFBaUI7a0dBQWpCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQU43QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLElBQUksRUFBRTt3QkFDRixpQkFBaUIsRUFBRSx5QkFBeUI7cUJBQy9DO2lCQUNKOzhCQUlnQixRQUFRO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgICBzZWxlY3RvcjogJ1tyZWFkb25seV0sW3JlYWRPbmx5XScsXHJcbiAgICBob3N0OiB7XHJcbiAgICAgICAgJ1thdHRyLnJlYWRvbmx5XSc6ICdfaXNSZWFkb25seSA/IFwiXCIgOiBudWxsJ1xyXG4gICAgfVxyXG59KVxyXG5leHBvcnQgY2xhc3MgUmVhZE9ubHlEaXJlY3RpdmUge1xyXG4gICAgX2lzUmVhZG9ubHkgPSBmYWxzZTtcclxuXHJcbiAgICBASW5wdXQoKSBzZXQgcmVhZG9ubHkodjogYm9vbGVhbiB8IHN0cmluZykge1xyXG4gICAgICAgIHRoaXMuX2lzUmVhZG9ubHkgPSB2ID09IHRydWUgfHwgdiA9PSAnJztcclxuICAgIH07XHJcbn0iXX0=
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhZG9ubHkuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9yZWFkb25seS9yZWFkb25seS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGFBQWEsQ0FBQzs7QUFRdEMsTUFBTSxPQUFPLGlCQUFpQjtJQU45QjtRQU9JLGNBQVMsR0FBRyxLQUFLLENBQUM7S0FJckI7SUFIWSxRQUFRLENBQUMsQ0FBZTtRQUM3QixJQUFJLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDMUMsQ0FBQzs7OEdBSlEsaUJBQWlCO2tHQUFqQixpQkFBaUI7MkZBQWpCLGlCQUFpQjtrQkFON0IsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxJQUFJLEVBQUU7d0JBQ0YsaUJBQWlCLEVBQUUseUJBQXlCO3FCQUMvQztpQkFDSjs4QkFHWSxRQUFRO3NCQUFoQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBCb29sZWFuSW5wdXQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgQ29udmVydCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gICAgc2VsZWN0b3I6ICdbcmVhZG9ubHldLFtyZWFkT25seV0nLFxyXG4gICAgaG9zdDoge1xyXG4gICAgICAgICdbYXR0ci5yZWFkb25seV0nOiAnX2lzUmVhZG9ubHkgPyBcIlwiIDogbnVsbCdcclxuICAgIH1cclxufSlcclxuZXhwb3J0IGNsYXNzIFJlYWRPbmx5RGlyZWN0aXZlIHtcclxuICAgIF9yZWFkb25seSA9IGZhbHNlO1xyXG4gICAgQElucHV0KCkgcmVhZG9ubHkodjogQm9vbGVhbklucHV0KSB7XHJcbiAgICAgICAgdGhpcy5fcmVhZG9ubHkgPSBDb252ZXJ0LnRvQm9vbGVhbih2KTtcclxuICAgIH1cclxufSJdfQ==
@@ -0,0 +1,3 @@
1
+ export * from './module';
2
+ export * from './select';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL3NlbGVjdC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3QnOyJdfQ==
@@ -0,0 +1,4 @@
1
+ import { KeyPair } from "../../models";
2
+ export class KeyPairOption extends KeyPair {
3
+ }
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL3NlbGVjdC9tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRXZDLE1BQU0sT0FBTyxhQUFjLFNBQVEsT0FBTztDQUd6QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEtleVBhaXIgfSBmcm9tIFwiLi4vLi4vbW9kZWxzXCI7XHJcblxyXG5leHBvcnQgY2xhc3MgS2V5UGFpck9wdGlvbiBleHRlbmRzIEtleVBhaXIge1xyXG4gICAgY2hlY2tlZD86IGJvb2xlYW4gfCBudWxsO1xyXG4gICAgaXRlbTogYW55O1xyXG59Il19
@@ -0,0 +1,28 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { ZekSelectMultiple } from './select';
5
+ import * as i0 from "@angular/core";
6
+ export class ZekSelectModule {
7
+ }
8
+ ZekSelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ZekSelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
+ ZekSelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.0", ngImport: i0, type: ZekSelectModule, declarations: [ZekSelectMultiple], imports: [CommonModule,
10
+ FormsModule], exports: [ZekSelectMultiple] });
11
+ ZekSelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ZekSelectModule, imports: [CommonModule,
12
+ FormsModule] });
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ZekSelectModule, decorators: [{
14
+ type: NgModule,
15
+ args: [{
16
+ imports: [
17
+ CommonModule,
18
+ FormsModule
19
+ ],
20
+ declarations: [
21
+ ZekSelectMultiple
22
+ ],
23
+ exports: [
24
+ ZekSelectMultiple
25
+ ],
26
+ }]
27
+ }] });
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9zZWxlY3QvbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxVQUFVLENBQUM7O0FBZTdDLE1BQU0sT0FBTyxlQUFlOzs0R0FBZixlQUFlOzZHQUFmLGVBQWUsaUJBUHhCLGlCQUFpQixhQUpqQixZQUFZO1FBQ1osV0FBVyxhQU1YLGlCQUFpQjs2R0FJUixlQUFlLFlBWHhCLFlBQVk7UUFDWixXQUFXOzJGQVVGLGVBQWU7a0JBYjNCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVztxQkFDWjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1osaUJBQWlCO3FCQUNsQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsaUJBQWlCO3FCQUNsQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbIiAgXHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBaZWtTZWxlY3RNdWx0aXBsZSB9IGZyb20gJy4vc2VsZWN0JztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGVcclxuICBdLFxyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgWmVrU2VsZWN0TXVsdGlwbGVcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFpla1NlbGVjdE11bHRpcGxlXHJcbiAgXSxcclxufSlcclxuXHJcbmV4cG9ydCBjbGFzcyBaZWtTZWxlY3RNb2R1bGUge1xyXG59Il19
@@ -0,0 +1,198 @@
1
+ import { Component, forwardRef, Input } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { CoreUiComponent } from '../../components';
4
+ import { ArrayHelper, Convert } from '../../utils';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ let uniqueId = 0;
8
+ const ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR = {
9
+ provide: NG_VALUE_ACCESSOR,
10
+ useExisting: forwardRef(() => ZekSelectMultiple),
11
+ multi: true,
12
+ };
13
+ export class ZekSelectMultiple extends CoreUiComponent {
14
+ constructor(renderer, elementRef) {
15
+ super(renderer, elementRef);
16
+ this._uniqueId = `zek-select-${++uniqueId}`;
17
+ /** The unique ID for the radio button. */
18
+ this.id = this._uniqueId;
19
+ this.css = 'primary';
20
+ this._placeholder = '';
21
+ this._label = '';
22
+ this._multiple = true;
23
+ this._selected = [];
24
+ this._data = [];
25
+ this.normalized = [];
26
+ this._text = '';
27
+ }
28
+ get placeholder() {
29
+ return this._placeholder;
30
+ }
31
+ set placeholder(value) {
32
+ if (value)
33
+ this._placeholder = value;
34
+ else
35
+ this._placeholder = '';
36
+ }
37
+ get label() {
38
+ return this._label;
39
+ }
40
+ set label(value) {
41
+ if (value)
42
+ this._label = value;
43
+ else
44
+ this._label = '';
45
+ }
46
+ get multiple() {
47
+ return this._multiple;
48
+ }
49
+ set multiple(value) {
50
+ this._multiple = Convert.toBoolean(value);
51
+ }
52
+ get data() {
53
+ return this._data;
54
+ }
55
+ set data(value) {
56
+ if (this._data !== value) {
57
+ this._data = value;
58
+ this.onDataChanged();
59
+ }
60
+ }
61
+ onDataChanged() {
62
+ this._setSelectionByValue(this._value);
63
+ if (this.isInitialized) {
64
+ this._normalizeData();
65
+ }
66
+ }
67
+ onValueChanged() {
68
+ if (Array.isArray(this._data)) {
69
+ this._setSelectionByValue(this._value);
70
+ }
71
+ }
72
+ init() {
73
+ this._normalizeData();
74
+ }
75
+ _normalizeData() {
76
+ this.normalized = [];
77
+ if (Array.isArray(this._data)) {
78
+ if (this.valueField && this.textField) {
79
+ for (const item of this._data) {
80
+ this.normalized.push({ key: item[this.valueField], value: item[this.textField], checked: this._selected.includes(item), item: item });
81
+ }
82
+ }
83
+ else {
84
+ for (const item of this._data) {
85
+ this.normalized.push({ key: item, value: item, checked: this._selected.includes(item), item });
86
+ }
87
+ }
88
+ }
89
+ }
90
+ /**
91
+ * Sets the selected option based on a value. If no option can be
92
+ * found with the designated value, the select trigger is cleared.
93
+ */
94
+ _setSelectionByValue(value) {
95
+ this._selected = [];
96
+ if (this.multiple && value) {
97
+ if (!Array.isArray(value)) {
98
+ throw new Error("value is not array");
99
+ }
100
+ if (Array.isArray(this._data)) {
101
+ let notUnique = [];
102
+ if (this.valueField) {
103
+ for (const currentValue of value) {
104
+ let items = ArrayHelper.filterByKey(currentValue, this.valueField, this._data);
105
+ notUnique = notUnique.concat(items);
106
+ }
107
+ }
108
+ else {
109
+ for (const currentValue of value) {
110
+ let items = this._data.filter(x => x === currentValue);
111
+ notUnique = notUnique.concat(items);
112
+ }
113
+ }
114
+ this._selected = ArrayHelper.distinct(notUnique);
115
+ }
116
+ }
117
+ else {
118
+ if (Array.isArray(this._data)) {
119
+ if (this.valueField) {
120
+ this._selected = ArrayHelper.filterByKey(value, this.valueField, this._data);
121
+ }
122
+ else {
123
+ this._selected = this._data.filter(x => x === value);
124
+ }
125
+ }
126
+ }
127
+ for (const norm of this.normalized) {
128
+ norm.checked = this._selected.includes(norm.item);
129
+ }
130
+ this._initText();
131
+ }
132
+ toggleChecked(v) {
133
+ if (v && !this.disabled && !this.readonly) {
134
+ if (!v.checked) {
135
+ v.checked = true;
136
+ if (this.multiple) {
137
+ let tmp = [];
138
+ for (const item of this.normalized) {
139
+ if (item.checked) {
140
+ tmp.push(item.key);
141
+ }
142
+ }
143
+ this.setNgModel(tmp);
144
+ // this.value = tmp;
145
+ }
146
+ else {
147
+ //this.value = v.key;
148
+ this.setNgModel(v.key);
149
+ }
150
+ }
151
+ else {
152
+ v.checked = false;
153
+ if (this.multiple) {
154
+ if (Array.isArray(this._value)) {
155
+ this.setNgModel(this._value.filter(x => x !== v.key));
156
+ }
157
+ }
158
+ else {
159
+ this.setNgModel(null);
160
+ }
161
+ }
162
+ }
163
+ }
164
+ _initText() {
165
+ let field = this.checkedTextField || this.textField || '';
166
+ if (field) {
167
+ this._text = this._selected.filter(x => x !== undefined && x !== null).map(x => x[field]).join(', ');
168
+ }
169
+ else {
170
+ this._text = this._selected.join(', ');
171
+ }
172
+ }
173
+ }
174
+ ZekSelectMultiple.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ZekSelectMultiple, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
175
+ ZekSelectMultiple.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ZekSelectMultiple, selector: "zek-select,[zek-select]", inputs: { id: "id", valueField: "valueField", textField: "textField", checkedTextField: "checkedTextField", css: "css", placeholder: "placeholder", label: "label", multiple: "multiple", data: "data" }, providers: [ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR], usesInheritance: true, ngImport: i0, template: "<div class=\"dropdown\" id=\"dropdown-{{id}}\">\r\n <button class=\"btn btn-{{css}} dropdown-toggle\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n {{label}} <ng-container *ngIf=\"!_text\">{{placeholder}}</ng-container> {{_text}}\r\n </button>\r\n <ul class=\"dropdown-menu\">\r\n <ng-container *ngIf=\"normalized\">\r\n <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" *ngFor=\"let item of normalized\" (click)=\"toggleChecked(item)\">\r\n <span *ngIf=\"item.checked\"><i class=\"fa-regular fa-square-check\"></i></span>\r\n <span *ngIf=\"!item.checked\"><i class=\"fa-regular fa-square\"></i></span>\r\n {{item.value}}\r\n </a></li>\r\n </ng-container>\r\n </ul>\r\n</div>", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
176
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ZekSelectMultiple, decorators: [{
177
+ type: Component,
178
+ args: [{ selector: 'zek-select,[zek-select]', providers: [ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR], template: "<div class=\"dropdown\" id=\"dropdown-{{id}}\">\r\n <button class=\"btn btn-{{css}} dropdown-toggle\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n {{label}} <ng-container *ngIf=\"!_text\">{{placeholder}}</ng-container> {{_text}}\r\n </button>\r\n <ul class=\"dropdown-menu\">\r\n <ng-container *ngIf=\"normalized\">\r\n <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" *ngFor=\"let item of normalized\" (click)=\"toggleChecked(item)\">\r\n <span *ngIf=\"item.checked\"><i class=\"fa-regular fa-square-check\"></i></span>\r\n <span *ngIf=\"!item.checked\"><i class=\"fa-regular fa-square\"></i></span>\r\n {{item.value}}\r\n </a></li>\r\n </ng-container>\r\n </ul>\r\n</div>" }]
179
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { id: [{
180
+ type: Input
181
+ }], valueField: [{
182
+ type: Input
183
+ }], textField: [{
184
+ type: Input
185
+ }], checkedTextField: [{
186
+ type: Input
187
+ }], css: [{
188
+ type: Input
189
+ }], placeholder: [{
190
+ type: Input
191
+ }], label: [{
192
+ type: Input
193
+ }], multiple: [{
194
+ type: Input
195
+ }], data: [{
196
+ type: Input
197
+ }] } });
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select/select.ts","../../../../../../projects/zek/src/lib/modules/select/select.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,UAAU,EAAE,KAAK,EAAa,MAAM,eAAe,CAAC;AACpF,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAgB,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACjE,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;;;AAInD,IAAI,QAAQ,GAAG,CAAC,CAAC;AAGjB,MAAM,0CAA0C,GAAQ;IACpD,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;IAChD,KAAK,EAAE,IAAI;CACd,CAAC;AAQF,MAAM,OAAO,iBAAkB,SAAQ,eAAe;IAClD,YAAY,QAAmB,EAAE,UAAsB;QACnD,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QAGxB,cAAS,GAAW,cAAc,EAAE,QAAQ,EAAE,CAAC;QACvD,0CAA0C;QACjC,OAAE,GAAW,IAAI,CAAC,SAAS,CAAC;QAM5B,QAAG,GAA4F,SAAS,CAAC;QAa1G,iBAAY,GAAG,EAAE,CAAC;QAYlB,WAAM,GAAG,EAAE,CAAC;QAWZ,cAAS,GAAG,IAAI,CAAC;QAGjB,cAAS,GAAU,EAAE,CAAC;QAYtB,UAAK,GAAkB,EAAE,CAAC;QAClC,eAAU,GAAoB,EAAE,CAAC;QAQjC,UAAK,GAAG,EAAE,CAAC;IAtEX,CAAC;IAaD,IACI,WAAW;QACX,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IACD,IAAI,WAAW,CAAC,KAAgC;QAC5C,IAAI,KAAK;YACL,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;;YAE1B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IAC/B,CAAC;IAGD,IACI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IACD,IAAI,KAAK,CAAC,KAAgC;QACtC,IAAI,KAAK;YACL,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;;YAEpB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;IACzB,CAAC;IAKD,IACI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IACD,IAAI,QAAQ,CAAC,KAAmB;QAC5B,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAMD,IACI,IAAI;QACJ,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IACD,IAAI,IAAI,CAAC,KAA+B;QACpC,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE;YACtB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;IACL,CAAC;IAGD,aAAa;QACT,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvC,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,cAAc,EAAE,CAAC;SACzB;IACL,CAAC;IAMQ,cAAc;QACnB,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC3B,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC1C;IACL,CAAC;IAGQ,IAAI;QACT,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAGO,cAAc;QAClB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC3B,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,SAAS,EAAE;gBACnC,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE;oBAC3B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;iBACzI;aACJ;iBAAM;gBACH,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE;oBAC3B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;iBAClG;aACJ;SACJ;IACL,CAAC;IAED;;;OAGG;IACK,oBAAoB,CAAC,KAAkB;QAC3C,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QAEpB,IAAI,IAAI,CAAC,QAAQ,IAAI,KAAK,EAAE;YACxB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBACvB,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;aACzC;YAED,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;gBAC3B,IAAI,SAAS,GAAU,EAAE,CAAC;gBAC1B,IAAI,IAAI,CAAC,UAAU,EAAE;oBACjB,KAAK,MAAM,YAAY,IAAI,KAAK,EAAE;wBAC9B,IAAI,KAAK,GAAG,WAAW,CAAC,WAAW,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;wBAC/E,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;qBACvC;iBACJ;qBAAM;oBACH,KAAK,MAAM,YAAY,IAAI,KAAK,EAAE;wBAC9B,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,YAAY,CAAC,CAAC;wBACvD,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;qBACvC;iBACJ;gBAED,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;aACpD;SACJ;aAAM;YACH,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;gBAC3B,IAAI,IAAI,CAAC,UAAU,EAAE;oBACjB,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;iBAChF;qBAAM;oBACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC;iBACxD;aACJ;SACJ;QAED,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE;YAChC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACrD;QACD,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAKD,aAAa,CAAC,CAAM;QAChB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACvC,IAAI,CAAC,CAAC,CAAC,OAAO,EAAE;gBACZ,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC;gBAEjB,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACf,IAAI,GAAG,GAAG,EAAE,CAAC;oBACb,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE;wBAChC,IAAI,IAAI,CAAC,OAAO,EAAE;4BACd,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;yBACtB;qBACJ;oBAED,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;oBACrB,oBAAoB;iBACvB;qBACI;oBACD,qBAAqB;oBACrB,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;iBAC1B;aACJ;iBAAM;gBACH,CAAC,CAAC,OAAO,GAAG,KAAK,CAAC;gBAClB,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACf,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;wBAC5B,IAAI,CAAC,UAAU,CAAE,IAAI,CAAC,MAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;qBACpE;iBACJ;qBAAM;oBACH,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;iBACzB;aACJ;SACJ;IACL,CAAC;IAGO,SAAS;QACb,IAAI,KAAK,GAAG,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,SAAS,IAAI,EAAE,CAAC;QAC1D,IAAI,KAAK,EAAE;YACP,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,SAAS,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACxG;aAAM;YACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC1C;IACL,CAAC;;8GAhMQ,iBAAiB;kGAAjB,iBAAiB,4PAHf,CAAC,0CAA0C,CAAC,iDCnB3D,6zBAaM;2FDSO,iBAAiB;kBAN7B,SAAS;+BACI,yBAAyB,aAExB,CAAC,0CAA0C,CAAC;yHAU9C,EAAE;sBAAV,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEG,GAAG;sBAAX,KAAK;gBAIF,WAAW;sBADd,KAAK;gBAaF,KAAK;sBADR,KAAK;gBAeF,QAAQ;sBADX,KAAK;gBAaF,IAAI;sBADP,KAAK","sourcesContent":["import { Component, ElementRef, forwardRef, Input, Renderer2 } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BooleanInput, CoreUiComponent } from '../../components';\r\nimport { ArrayHelper, Convert } from '../../utils';\r\nimport { KeyPairOption } from './model';\r\n\r\n\r\nlet uniqueId = 0;\r\n\r\n\r\nconst ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ZekSelectMultiple),\r\n    multi: true,\r\n};\r\n\r\n@Component({\r\n    selector: 'zek-select,[zek-select]',\r\n    templateUrl: './select.html',\r\n    providers: [ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR],\r\n})\r\n\r\nexport class ZekSelectMultiple extends CoreUiComponent {\r\n    constructor(renderer: Renderer2, elementRef: ElementRef) {\r\n        super(renderer, elementRef);\r\n    }\r\n\r\n    private _uniqueId: string = `zek-select-${++uniqueId}`;\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    @Input() valueField?: string | null;\r\n    @Input() textField?: string | null;\r\n    @Input() checkedTextField?: string | null;\r\n\r\n    @Input() css: 'primary' | 'secondary' | 'success' | 'danger ' | 'warning' | 'info' | 'light' | 'dark' = 'primary';\r\n\r\n\r\n    @Input()\r\n    get placeholder(): string {\r\n        return this._placeholder;\r\n    }\r\n    set placeholder(value: string | null | undefined) {\r\n        if (value)\r\n            this._placeholder = value;\r\n        else\r\n            this._placeholder = '';\r\n    }\r\n    private _placeholder = '';\r\n\r\n    @Input()\r\n    get label(): string {\r\n        return this._label;\r\n    }\r\n    set label(value: string | null | undefined) {\r\n        if (value)\r\n            this._label = value;\r\n        else\r\n            this._label = '';\r\n    }\r\n    private _label = '';\r\n\r\n\r\n\r\n    @Input()\r\n    get multiple() {\r\n        return this._multiple;\r\n    }\r\n    set multiple(value: BooleanInput) {\r\n        this._multiple = Convert.toBoolean(value);\r\n    }\r\n    private _multiple = true;\r\n\r\n\r\n    private _selected: any[] = [];\r\n\r\n    @Input()\r\n    get data() {\r\n        return this._data;\r\n    }\r\n    set data(value: any[] | null | undefined) {\r\n        if (this._data !== value) {\r\n            this._data = value;\r\n            this.onDataChanged();\r\n        }\r\n    }\r\n    private _data?: any[] | null = [];\r\n    normalized: KeyPairOption[] = [];\r\n    onDataChanged() {\r\n        this._setSelectionByValue(this._value);\r\n        if (this.isInitialized) {\r\n            this._normalizeData();\r\n        }\r\n    }\r\n\r\n    _text = '';\r\n\r\n\r\n\r\n    override onValueChanged() {\r\n        if (Array.isArray(this._data)) {\r\n            this._setSelectionByValue(this._value);\r\n        }\r\n    }\r\n\r\n\r\n    override init(): void {\r\n        this._normalizeData();\r\n    }\r\n\r\n\r\n    private _normalizeData() {\r\n        this.normalized = [];\r\n        if (Array.isArray(this._data)) {\r\n            if (this.valueField && this.textField) {\r\n                for (const item of this._data) {\r\n                    this.normalized.push({ key: item[this.valueField], value: item[this.textField], checked: this._selected.includes(item), item: item });\r\n                }\r\n            } else {\r\n                for (const item of this._data) {\r\n                    this.normalized.push({ key: item, value: item, checked: this._selected.includes(item), item });\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Sets the selected option based on a value. If no option can be\r\n     * found with the designated value, the select trigger is cleared.\r\n     */\r\n    private _setSelectionByValue(value: any | any[]): void {\r\n        this._selected = [];\r\n\r\n        if (this.multiple && value) {\r\n            if (!Array.isArray(value)) {\r\n                throw new Error(\"value is not array\");\r\n            }\r\n\r\n            if (Array.isArray(this._data)) {\r\n                let notUnique: any[] = [];\r\n                if (this.valueField) {\r\n                    for (const currentValue of value) {\r\n                        let items = ArrayHelper.filterByKey(currentValue, this.valueField, this._data);\r\n                        notUnique = notUnique.concat(items);\r\n                    }\r\n                } else {\r\n                    for (const currentValue of value) {\r\n                        let items = this._data.filter(x => x === currentValue);\r\n                        notUnique = notUnique.concat(items);\r\n                    }\r\n                }\r\n\r\n                this._selected = ArrayHelper.distinct(notUnique);\r\n            }\r\n        } else {\r\n            if (Array.isArray(this._data)) {\r\n                if (this.valueField) {\r\n                    this._selected = ArrayHelper.filterByKey(value, this.valueField, this._data);\r\n                } else {\r\n                    this._selected = this._data.filter(x => x === value);\r\n                }\r\n            }\r\n        }\r\n\r\n        for (const norm of this.normalized) {\r\n            norm.checked = this._selected.includes(norm.item);\r\n        }\r\n        this._initText();\r\n    }\r\n\r\n\r\n\r\n\r\n    toggleChecked(v: any) {\r\n        if (v && !this.disabled && !this.readonly) {\r\n            if (!v.checked) {\r\n                v.checked = true;\r\n\r\n                if (this.multiple) {\r\n                    let tmp = [];\r\n                    for (const item of this.normalized) {\r\n                        if (item.checked) {\r\n                            tmp.push(item.key);\r\n                        }\r\n                    }\r\n\r\n                    this.setNgModel(tmp);\r\n                    // this.value = tmp;\r\n                }\r\n                else {\r\n                    //this.value = v.key;\r\n                    this.setNgModel(v.key);\r\n                }\r\n            } else {\r\n                v.checked = false;\r\n                if (this.multiple) {\r\n                    if (Array.isArray(this._value)) {\r\n                        this.setNgModel((this._value as any[]).filter(x => x !== v.key));\r\n                    }\r\n                } else {\r\n                    this.setNgModel(null);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    private _initText() {\r\n        let field = this.checkedTextField || this.textField || '';\r\n        if (field) {\r\n            this._text = this._selected.filter(x => x !== undefined && x !== null).map(x => x[field]).join(', ');\r\n        } else {\r\n            this._text = this._selected.join(', ');\r\n        }\r\n    }\r\n}\r\n","<div class=\"dropdown\" id=\"dropdown-{{id}}\">\r\n    <button class=\"btn btn-{{css}} dropdown-toggle\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n        {{label}} <ng-container *ngIf=\"!_text\">{{placeholder}}</ng-container> {{_text}}\r\n    </button>\r\n    <ul class=\"dropdown-menu\">\r\n        <ng-container *ngIf=\"normalized\">\r\n            <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" *ngFor=\"let item of normalized\" (click)=\"toggleChecked(item)\">\r\n                    <span *ngIf=\"item.checked\"><i class=\"fa-regular fa-square-check\"></i></span>\r\n                    <span *ngIf=\"!item.checked\"><i class=\"fa-regular fa-square\"></i></span>\r\n                    {{item.value}}\r\n                </a></li>\r\n        </ng-container>\r\n    </ul>\r\n</div>"]}
@@ -167,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
167
167
  }], value: [{
168
168
  type: Input
169
169
  }] } });
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select2.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select2/select2.component.ts","../../../../../../projects/zek/src/lib/modules/select2/select2.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { RandomHelper, StringHelper } from '../../utils';\r\n\r\n@Component({\r\n  selector: 'zek-select2,[zek-select2]',\r\n  templateUrl: './select2.component.html',\r\n  styleUrls: ['./select2.component.css']\r\n\r\n})\r\n\r\nexport class Select2Component implements OnDestroy {\r\n  filter?: string | null;\r\n  text?: string | null;\r\n\r\n  readonly elementId = RandomHelper.randomHex();\r\n\r\n  private _data: Array<any> = [];\r\n  @Input() get data(): Array<any> {\r\n    return this._data;\r\n  }\r\n  set data(value: Array<any>) {\r\n    if (this._data !== value) {\r\n      this._data = value;\r\n      this.findAndSetItem();\r\n      this.filterData();\r\n    }\r\n  }\r\n  filteredData: Array<any> = [];\r\n\r\n  @Input() textField: any;\r\n  @Input() valueField: any;\r\n  @Input() placeholder: string = ''\r\n\r\n  @Output() selectedItemChange = new EventEmitter<any>();\r\n  private _selectedItem: any;\r\n  get selectedItem(): any {\r\n    return this._selectedItem;\r\n  }\r\n\r\n  @Output() valueChange = new EventEmitter<any>();\r\n  private _value: any;\r\n  @Input() get value() {\r\n    return this._value;\r\n  }\r\n  set value(v: any) {\r\n    if (this._value !== v) {\r\n      this._value = v;\r\n      this.findAndSetItem();\r\n    }\r\n  }\r\n\r\n  private findAndSetItem() {\r\n    let foundItem = null;\r\n    if (this._value === undefined || this._value === null || !this.data) {\r\n\r\n    } else if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n      foundItem = this.data.find(x => x === this._value);\r\n    } else {\r\n      foundItem = this.data.find(x => x[this.valueField] === this._value);\r\n    }\r\n\r\n    this._selectedItem = foundItem;\r\n    this.setText();\r\n  }\r\n\r\n\r\n\r\n\r\n  // private _dropdown: any;\r\n  // public get dropdown(): any {\r\n  //     if (!this._dropdown) {\r\n  //         let el = document.getElementById('btn-' + this.elementId);\r\n  //         this._dropdown = new bootstrap.Dropdown(el);\r\n  //     }\r\n  //     return this._dropdown;\r\n  // }\r\n  // public set dropdown(v: any) {\r\n  //     this._dropdown = v;\r\n  // }\r\n\r\n  ngOnDestroy() {\r\n    // this.dropdown?.dispose();\r\n    // this.dropdown = null;\r\n  }\r\n\r\n\r\n  onTextChange(text: string) {\r\n    this.filter = StringHelper.tryTrim(text);\r\n    this.filterData();\r\n  }\r\n\r\n  private filterData() {\r\n    if (this.filter && this.filter !== '') {\r\n      let searchString = this.filter;\r\n      if (this.textField === undefined || this.textField === null) {\r\n        this.filteredData = this.data.filter(item => item.toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n      } else {\r\n        this.filteredData = this.data.filter(item => item[this.textField].toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n      }\r\n    }\r\n    else// if (this.filter === undefined || this.filter === null || this.filter === '') \r\n    {\r\n      this.filteredData = this.data;\r\n    }\r\n  }\r\n\r\n  onFocus(e: FocusEvent) {\r\n    // if (this.dropdown){\r\n    //   this.dropdown.show();\r\n    // }\r\n    // let dropdown = document.getElementById(`dropdown-menu-container-${this.elementId}`);\r\n    // console.log(dropdown);\r\n\r\n    // if (dropdown) {\r\n    //   console.log(dropdown.classList);\r\n\r\n    //   if (!dropdown.classList.contains('show')) {\r\n    //     let el = document.getElementById(`input-${this.elementId}`);\r\n    //     if (el) {\r\n    //       el.click();\r\n    //     }\r\n    //   }\r\n    // }\r\n\r\n\r\n\r\n    // let inputId = 'input-' + this.elementId;\r\n    // let el = document.getElementById(inputId);\r\n    // if (el) {\r\n\r\n    //   if (!el.classList.contains('show')) {\r\n    //     this.dropdown?.show();\r\n    //   }\r\n\r\n    // let menuId = '#dropdown-menu-' + this.elementId + ' ' + 'a';\r\n    // el.addEventListener('keydown', function (e) {\r\n    //   if (e.key == 'ArrowDown') {\r\n    //     (document.querySelectorAll(menuId)[0] as any).focus();\r\n    //   }\r\n    // });\r\n    // }\r\n  }\r\n  inputUnfocused() {\r\n    // this.expanded = false;\r\n  }\r\n\r\n  private setText() {\r\n    if (this._selectedItem === undefined || this._selectedItem === null) {\r\n      this.text = null;\r\n    }\r\n    else if (this.textField === undefined || this.textField === null) {\r\n      this.text = this._selectedItem;\r\n    } else {\r\n      this.text = this._selectedItem[this.textField];\r\n    }\r\n  }\r\n\r\n  selectItem(item: any) {\r\n\r\n    if (this._selectedItem !== item) {\r\n      this._selectedItem = item;\r\n      this.selectedItemChange.emit(item);\r\n\r\n      this.setText();\r\n\r\n      //set value\r\n      let v;\r\n      if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n        // this.value = v\r\n        v = item;\r\n      } else {\r\n        // this.value = v[this.valueField];\r\n        v = item[this.valueField];\r\n      }\r\n\r\n      //if value not equals then emit valueChange\r\n      if (this._value !== v) {\r\n        this._value = v;\r\n        this.valueChange.emit(v);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n}\r\n","<div class=\"input-group position-relative\" id=\"dropdown-menu-container-{{elementId}}\">\r\n  <input type=\"text\" class=\"form-control\" placeholder=\"{{placeholder}}\" data-bs-toggle=\"dropdown\" id=\"input-{{elementId}}\" [(ngModel)]=\"text\" (ngModelChange)=\"onTextChange($event)\" (focus)=\"onFocus($event)\" (blur)=\"inputUnfocused()\">\r\n  <button class=\"btn btn-outline-secondary dropdown-toggle\" id=\"btn-{{elementId}}\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\" data-bs-reference=\"parent\"></button>\r\n  <ul class=\"dropdown-menu dropdown-menu-start w-100 scrollable-menu\" id=\"dropdown-menu-{{elementId}}\">\r\n    <ng-container *ngIf=\"textField\">\r\n      <li *ngFor=\"let entry of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(entry)\" class=\"dropdown-item\">{{entry[textField]}}</a>\r\n      </li>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"!textField\">\r\n      <li *ngFor=\"let entry of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(entry)\" class=\"dropdown-item\">{{textField}}</a>\r\n      </li>\r\n    </ng-container>\r\n  </ul>\r\n</div>\r\n<!-- <kendo-autocomplete\r\n  [data]=\"data\"\r\n  [filterable]=\"true\"\r\n  (valueChange)=\"valueChange($event)\"\r\n  (filterChange)=\"filterChange($event)\"\r\n  (open)=\"open()\"\r\n  (close)=\"close()\"\r\n  (focus)=\"focus()\"\r\n  (blur)=\"blur()\">\r\n</kendo-autocomplete> -->"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select2.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select2/select2.component.ts","../../../../../../projects/zek/src/lib/modules/select2/select2.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { RandomHelper, StringHelper } from '../../utils';\r\n\r\n@Component({\r\n    selector: 'zek-select2,[zek-select2]',\r\n    templateUrl: './select2.component.html',\r\n    styleUrls: ['./select2.component.css']\r\n\r\n})\r\n\r\nexport class Select2Component implements OnDestroy {\r\n    filter?: string | null;\r\n    text?: string | null;\r\n\r\n    readonly elementId = RandomHelper.randomHex();\r\n\r\n    private _data: Array<any> = [];\r\n    @Input()\r\n    get data(): Array<any> {\r\n        return this._data;\r\n    }\r\n    set data(value: Array<any>) {\r\n        if (this._data !== value) {\r\n            this._data = value;\r\n            this.findAndSetItem();\r\n            this.filterData();\r\n        }\r\n    }\r\n    filteredData: Array<any> = [];\r\n\r\n    @Input() textField: any;\r\n    @Input() valueField: any;\r\n    @Input() placeholder: string = ''\r\n\r\n    @Output() selectedItemChange = new EventEmitter<any>();\r\n    private _selectedItem: any;\r\n    get selectedItem(): any {\r\n        return this._selectedItem;\r\n    }\r\n\r\n    @Output() valueChange = new EventEmitter<any>();\r\n    private _value: any;\r\n    @Input()\r\n    get value() {\r\n        return this._value;\r\n    }\r\n    set value(v: any) {\r\n        if (this._value !== v) {\r\n            this._value = v;\r\n            this.findAndSetItem();\r\n        }\r\n    }\r\n\r\n    private findAndSetItem() {\r\n        let foundItem = null;\r\n        if (this._value === undefined || this._value === null || !this.data) {\r\n\r\n        } else if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n            foundItem = this.data.find(x => x === this._value);\r\n        } else {\r\n            foundItem = this.data.find(x => x[this.valueField] === this._value);\r\n        }\r\n\r\n        this._selectedItem = foundItem;\r\n        this.setText();\r\n    }\r\n\r\n\r\n\r\n\r\n    // private _dropdown: any;\r\n    // public get dropdown(): any {\r\n    //     if (!this._dropdown) {\r\n    //         let el = document.getElementById('btn-' + this.elementId);\r\n    //         this._dropdown = new bootstrap.Dropdown(el);\r\n    //     }\r\n    //     return this._dropdown;\r\n    // }\r\n    // public set dropdown(v: any) {\r\n    //     this._dropdown = v;\r\n    // }\r\n\r\n    ngOnDestroy() {\r\n        // this.dropdown?.dispose();\r\n        // this.dropdown = null;\r\n    }\r\n\r\n\r\n    onTextChange(text: string) {\r\n        this.filter = StringHelper.tryTrim(text);\r\n        this.filterData();\r\n    }\r\n\r\n    private filterData() {\r\n        if (this.filter && this.filter !== '') {\r\n            let searchString = this.filter;\r\n            if (this.textField === undefined || this.textField === null) {\r\n                this.filteredData = this.data.filter(item => item.toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n            } else {\r\n                this.filteredData = this.data.filter(item => item[this.textField].toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n            }\r\n        }\r\n        else// if (this.filter === undefined || this.filter === null || this.filter === '') \r\n        {\r\n            this.filteredData = this.data;\r\n        }\r\n    }\r\n\r\n    onFocus(e: FocusEvent) {\r\n        // if (this.dropdown){\r\n        //   this.dropdown.show();\r\n        // }\r\n        // let dropdown = document.getElementById(`dropdown-menu-container-${this.elementId}`);\r\n        // console.log(dropdown);\r\n\r\n        // if (dropdown) {\r\n        //   console.log(dropdown.classList);\r\n\r\n        //   if (!dropdown.classList.contains('show')) {\r\n        //     let el = document.getElementById(`input-${this.elementId}`);\r\n        //     if (el) {\r\n        //       el.click();\r\n        //     }\r\n        //   }\r\n        // }\r\n\r\n\r\n\r\n        // let inputId = 'input-' + this.elementId;\r\n        // let el = document.getElementById(inputId);\r\n        // if (el) {\r\n\r\n        //   if (!el.classList.contains('show')) {\r\n        //     this.dropdown?.show();\r\n        //   }\r\n\r\n        // let menuId = '#dropdown-menu-' + this.elementId + ' ' + 'a';\r\n        // el.addEventListener('keydown', function (e) {\r\n        //   if (e.key == 'ArrowDown') {\r\n        //     (document.querySelectorAll(menuId)[0] as any).focus();\r\n        //   }\r\n        // });\r\n        // }\r\n    }\r\n    inputUnfocused() {\r\n        // this.expanded = false;\r\n    }\r\n\r\n    private setText() {\r\n        if (this._selectedItem === undefined || this._selectedItem === null) {\r\n            this.text = null;\r\n        }\r\n        else if (this.textField === undefined || this.textField === null) {\r\n            this.text = this._selectedItem;\r\n        } else {\r\n            this.text = this._selectedItem[this.textField];\r\n        }\r\n    }\r\n\r\n    selectItem(item: any) {\r\n\r\n        if (this._selectedItem !== item) {\r\n            this._selectedItem = item;\r\n            this.selectedItemChange.emit(item);\r\n\r\n            this.setText();\r\n\r\n            //set value\r\n            let v;\r\n            if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n                // this.value = v\r\n                v = item;\r\n            } else {\r\n                // this.value = v[this.valueField];\r\n                v = item[this.valueField];\r\n            }\r\n\r\n            //if value not equals then emit valueChange\r\n            if (this._value !== v) {\r\n                this._value = v;\r\n                this.valueChange.emit(v);\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n}\r\n","<div class=\"input-group position-relative\" id=\"dropdown-menu-container-{{elementId}}\">\r\n  <input type=\"text\" class=\"form-control\" placeholder=\"{{placeholder}}\" data-bs-toggle=\"dropdown\" id=\"input-{{elementId}}\" [(ngModel)]=\"text\" (ngModelChange)=\"onTextChange($event)\" (focus)=\"onFocus($event)\" (blur)=\"inputUnfocused()\">\r\n  <button class=\"btn btn-outline-secondary dropdown-toggle\" id=\"btn-{{elementId}}\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\" data-bs-reference=\"parent\"></button>\r\n  <ul class=\"dropdown-menu dropdown-menu-start w-100 scrollable-menu\" id=\"dropdown-menu-{{elementId}}\">\r\n    <ng-container *ngIf=\"textField\">\r\n      <li *ngFor=\"let entry of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(entry)\" class=\"dropdown-item\">{{entry[textField]}}</a>\r\n      </li>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"!textField\">\r\n      <li *ngFor=\"let entry of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(entry)\" class=\"dropdown-item\">{{textField}}</a>\r\n      </li>\r\n    </ng-container>\r\n  </ul>\r\n</div>\r\n<!-- <kendo-autocomplete\r\n  [data]=\"data\"\r\n  [filterable]=\"true\"\r\n  (valueChange)=\"valueChange($event)\"\r\n  (filterChange)=\"filterChange($event)\"\r\n  (open)=\"open()\"\r\n  (close)=\"close()\"\r\n  (focus)=\"focus()\"\r\n  (blur)=\"blur()\">\r\n</kendo-autocomplete> -->"]}