matcha-components 19.74.0 → 19.76.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (115) hide show
  1. package/esm2022/lib/matcha-accordion/accordion/accordion.component.mjs +49 -0
  2. package/esm2022/lib/matcha-accordion/accordion-content/accordion-content.component.mjs +11 -0
  3. package/esm2022/lib/matcha-accordion/accordion-header/accordion-header.component.mjs +11 -0
  4. package/esm2022/lib/matcha-accordion/accordion-item/accordion-item.component.mjs +42 -0
  5. package/esm2022/lib/matcha-accordion/accordion.module.mjs +59 -0
  6. package/esm2022/lib/matcha-animations/animations.mjs +352 -0
  7. package/esm2022/lib/matcha-autocomplete/matcha-autocomplete/matcha-autocomplete.component.mjs +46 -0
  8. package/esm2022/lib/matcha-autocomplete/matcha-autocomplete.directive.mjs +71 -0
  9. package/esm2022/lib/matcha-autocomplete/matcha-autocomplete.module.mjs +21 -0
  10. package/esm2022/lib/matcha-badge/badge.directive.mjs +20 -0
  11. package/esm2022/lib/matcha-badge/badge.module.mjs +17 -0
  12. package/esm2022/lib/matcha-button/button/button.component.mjs +205 -0
  13. package/esm2022/lib/matcha-button/button.module.mjs +17 -0
  14. package/esm2022/lib/matcha-button-toggle/button-toggle/button-toggle.component.mjs +88 -0
  15. package/esm2022/lib/matcha-button-toggle/button-toggle.module.mjs +24 -0
  16. package/esm2022/lib/matcha-card/card/card.component.mjs +81 -0
  17. package/esm2022/lib/matcha-card/card.module.mjs +40 -0
  18. package/esm2022/lib/matcha-checkbox/checkbox/checkbox.component.mjs +81 -0
  19. package/esm2022/lib/matcha-checkbox/checkbox.module.mjs +23 -0
  20. package/esm2022/lib/matcha-chips/chips.module.mjs +19 -0
  21. package/esm2022/lib/matcha-chips/matcha-chips.directive.mjs +20 -0
  22. package/esm2022/lib/matcha-components.module.mjs +55 -0
  23. package/esm2022/lib/matcha-datepicker/datepicker.directive.mjs +20 -0
  24. package/esm2022/lib/matcha-datepicker/datepicker.module.mjs +17 -0
  25. package/esm2022/lib/matcha-divider/divider/divider.component.mjs +66 -0
  26. package/esm2022/lib/matcha-divider/divider.module.mjs +22 -0
  27. package/esm2022/lib/matcha-elevation/elevation.directive.mjs +39 -0
  28. package/esm2022/lib/matcha-elevation/elevation.module.mjs +18 -0
  29. package/esm2022/lib/matcha-form-field/matcha-error/matcha-error.component.mjs +12 -0
  30. package/esm2022/lib/matcha-form-field/matcha-form-field/matcha-form-field.component.mjs +51 -0
  31. package/esm2022/lib/matcha-form-field/matcha-form-field.module.mjs +21 -0
  32. package/esm2022/lib/matcha-form-field/matcha-label/matcha-label.component.mjs +16 -0
  33. package/esm2022/lib/matcha-grid/grid.component.mjs +110 -0
  34. package/esm2022/lib/matcha-grid/grid.module.mjs +18 -0
  35. package/esm2022/lib/matcha-hint-text/hint/hint-text.component.mjs +38 -0
  36. package/esm2022/lib/matcha-hint-text/hint.module.mjs +24 -0
  37. package/esm2022/lib/matcha-icon/icon.component.mjs +36 -0
  38. package/esm2022/lib/matcha-icon/icon.module.mjs +19 -0
  39. package/esm2022/lib/matcha-infinite-scroll/matcha-infinite-scroll/matcha-infinite-scroll.component.mjs +46 -0
  40. package/esm2022/lib/matcha-infinite-scroll/matcha-infinite-scroll-data/matcha-infinite-scroll-data.component.mjs +137 -0
  41. package/esm2022/lib/matcha-infinite-scroll/matcha-infinite-scroll.module.mjs +21 -0
  42. package/esm2022/lib/matcha-input/input.directive.mjs +20 -0
  43. package/esm2022/lib/matcha-input/input.module.mjs +17 -0
  44. package/esm2022/lib/matcha-masonry/masonry/masonry.component.mjs +77 -0
  45. package/esm2022/lib/matcha-masonry/masonry.module.mjs +18 -0
  46. package/esm2022/lib/matcha-menu/menu.component.mjs +54 -0
  47. package/esm2022/lib/matcha-menu/menu.directive.mjs +53 -0
  48. package/esm2022/lib/matcha-menu/menu.module.mjs +29 -0
  49. package/esm2022/lib/matcha-modal/matcha-modal.module.mjs +73 -0
  50. package/esm2022/lib/matcha-modal/modal/modal.component.mjs +89 -0
  51. package/esm2022/lib/matcha-modal/modal-content/modal-content.component.mjs +11 -0
  52. package/esm2022/lib/matcha-modal/modal-footer/modal-footer.component.mjs +35 -0
  53. package/esm2022/lib/matcha-modal/modal-header/modal-header.component.mjs +12 -0
  54. package/esm2022/lib/matcha-modal/modal-options/modal-options.component.mjs +11 -0
  55. package/esm2022/lib/matcha-modal/modal.service.mjs +43 -0
  56. package/esm2022/lib/matcha-modal/overlay.service.mjs +131 -0
  57. package/esm2022/lib/matcha-option/matcha-option/matcha-option.component.mjs +33 -0
  58. package/esm2022/lib/matcha-option/matcha-option.module.mjs +18 -0
  59. package/esm2022/lib/matcha-option/matcha-option.service.mjs +73 -0
  60. package/esm2022/lib/matcha-overflow-draggable/matcha-overflow-draggable.component.mjs +54 -0
  61. package/esm2022/lib/matcha-paginator/paginator.directive.mjs +20 -0
  62. package/esm2022/lib/matcha-paginator/paginator.module.mjs +18 -0
  63. package/esm2022/lib/matcha-progress-bar/progress-bar.directive.mjs +20 -0
  64. package/esm2022/lib/matcha-progress-bar/progress-bar.module.mjs +22 -0
  65. package/esm2022/lib/matcha-radio-button/matcha-radio-button.directive.mjs +20 -0
  66. package/esm2022/lib/matcha-radio-button/radio-button.module.mjs +20 -0
  67. package/esm2022/lib/matcha-ripple/ripple.directive.mjs +71 -0
  68. package/esm2022/lib/matcha-ripple/ripple.module.mjs +24 -0
  69. package/esm2022/lib/matcha-select/select.directive.mjs +20 -0
  70. package/esm2022/lib/matcha-select/select.module.mjs +18 -0
  71. package/esm2022/lib/matcha-sidenav/sidenav.directive.mjs +20 -0
  72. package/esm2022/lib/matcha-sidenav/sidenav.module.mjs +18 -0
  73. package/esm2022/lib/matcha-slide-toggle/slide-toggle/slide-toggle.component.mjs +95 -0
  74. package/esm2022/lib/matcha-slide-toggle/slide-toggle.module.mjs +21 -0
  75. package/esm2022/lib/matcha-slider/matcha-slider.directive.mjs +20 -0
  76. package/esm2022/lib/matcha-slider/slider.module.mjs +20 -0
  77. package/esm2022/lib/matcha-snackbar/snack-bar.directive.mjs +20 -0
  78. package/esm2022/lib/matcha-snackbar/snack-bar.module.mjs +18 -0
  79. package/esm2022/lib/matcha-sort-header/sort-header.directive.mjs +20 -0
  80. package/esm2022/lib/matcha-sort-header/sort-header.module.mjs +18 -0
  81. package/esm2022/lib/matcha-spin/spin/spin.component.mjs +85 -0
  82. package/esm2022/lib/matcha-spin/spin.module.mjs +20 -0
  83. package/esm2022/lib/matcha-table/table.directive.mjs +20 -0
  84. package/esm2022/lib/matcha-table/table.module.mjs +18 -0
  85. package/esm2022/lib/matcha-tabs/tab-item/tab-item.component.mjs +29 -0
  86. package/esm2022/lib/matcha-tabs/tabs/tabs.component.mjs +68 -0
  87. package/esm2022/lib/matcha-tabs/tabs.module.mjs +29 -0
  88. package/esm2022/lib/matcha-title/title/title.component.mjs +66 -0
  89. package/esm2022/lib/matcha-title/title.module.mjs +18 -0
  90. package/esm2022/lib/matcha-toolbar/toolbar/toolbar.component.mjs +34 -0
  91. package/esm2022/lib/matcha-toolbar/toolbar-button/toolbar-button.component.mjs +28 -0
  92. package/esm2022/lib/matcha-toolbar/toolbar-content/toolbar-content.component.mjs +11 -0
  93. package/esm2022/lib/matcha-toolbar/toolbar-main-button/toolbar-main-button.component.mjs +20 -0
  94. package/esm2022/lib/matcha-toolbar/toolbar.module.mjs +53 -0
  95. package/esm2022/lib/matcha-tooltip/tooltip.directive.mjs +184 -0
  96. package/esm2022/lib/matcha-tooltip/tooltip.module.mjs +19 -0
  97. package/esm2022/lib/matcha-tree/tree.directive.mjs +20 -0
  98. package/esm2022/lib/matcha-tree/tree.module.mjs +18 -0
  99. package/esm2022/matcha-components.mjs +5 -0
  100. package/esm2022/public-api.mjs +119 -0
  101. package/fesm2022/matcha-components.mjs +536 -571
  102. package/fesm2022/matcha-components.mjs.map +1 -1
  103. package/lib/matcha-autocomplete/matcha-autocomplete/matcha-autocomplete.component.d.ts +16 -0
  104. package/lib/matcha-autocomplete/matcha-autocomplete.directive.d.ts +19 -0
  105. package/lib/matcha-autocomplete/matcha-autocomplete.module.d.ts +11 -0
  106. package/lib/matcha-components.module.d.ts +19 -18
  107. package/lib/matcha-form-field/matcha-form-field/matcha-form-field.component.d.ts +1 -1
  108. package/lib/matcha-option/matcha-option/matcha-option.component.d.ts +14 -0
  109. package/lib/matcha-option/matcha-option.module.d.ts +8 -0
  110. package/lib/matcha-option/matcha-option.service.d.ts +24 -0
  111. package/package.json +3 -1
  112. package/public-api.d.ts +6 -3
  113. package/lib/matcha-autocomplete/autocomplete-overview.directive.d.ts +0 -9
  114. package/lib/matcha-autocomplete/autocomplete.directive.d.ts +0 -9
  115. package/lib/matcha-autocomplete/autocomplete.module.d.ts +0 -8
@@ -0,0 +1,46 @@
1
+ import { Component, ContentChildren } from '@angular/core';
2
+ import { MatchaOptionComponent } from '../../../public-api';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../matcha-option/matcha-option.service";
5
+ import * as i2 from "@angular/common";
6
+ export class MatchaAutocompleteComponent {
7
+ constructor(changeDetectorRef, matchaOptionService) {
8
+ this.changeDetectorRef = changeDetectorRef;
9
+ this.matchaOptionService = matchaOptionService;
10
+ this.isDisplayAutocomplete = false;
11
+ this.activeOption = 0;
12
+ }
13
+ ngOnInit() {
14
+ this.matchaOptionService.canShowOptions$.subscribe((canShowOptions) => {
15
+ if (!canShowOptions) {
16
+ this.matchaOptionService.resetActiveOption();
17
+ }
18
+ this.isDisplayAutocomplete = canShowOptions;
19
+ });
20
+ }
21
+ ngAfterContentInit() {
22
+ const options = this.options.toArray();
23
+ if (options.length > 0) {
24
+ options[0].setIsOptionActive(true, false);
25
+ }
26
+ this.matchaOptionService.updateOptions(options);
27
+ this.options.changes.subscribe((newOptions) => {
28
+ this.matchaOptionService.updateOptions(newOptions.toArray());
29
+ this.matchaOptionService.resetActiveOption();
30
+ });
31
+ this.matchaOptionService.activeOption$.subscribe((currentActiveOption) => {
32
+ this.activeOption = currentActiveOption;
33
+ this.changeDetectorRef.detectChanges();
34
+ });
35
+ }
36
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaAutocompleteComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.MatchaOptionService }], target: i0.ɵɵFactoryTarget.Component }); }
37
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MatchaAutocompleteComponent, selector: "matcha-autocomplete", queries: [{ propertyName: "options", predicate: MatchaOptionComponent }], ngImport: i0, template: "<ng-container *ngIf=\"isDisplayAutocomplete\">\n <div class=\"background-bg pt-24 position-absolute z-index-2 w-100-p\">\n <ul class=\"background-surface m-0 radius-8 elevation-z-1 p-0\">\n <ng-content></ng-content>\n </ul>\n </div>\n</ng-container>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
38
+ }
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaAutocompleteComponent, decorators: [{
40
+ type: Component,
41
+ args: [{ selector: 'matcha-autocomplete', standalone: false, template: "<ng-container *ngIf=\"isDisplayAutocomplete\">\n <div class=\"background-bg pt-24 position-absolute z-index-2 w-100-p\">\n <ul class=\"background-surface m-0 radius-8 elevation-z-1 p-0\">\n <ng-content></ng-content>\n </ul>\n </div>\n</ng-container>\n" }]
42
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.MatchaOptionService }], propDecorators: { options: [{
43
+ type: ContentChildren,
44
+ args: [MatchaOptionComponent]
45
+ }] } });
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0Y2hhLWF1dG9jb21wbGV0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXRjaGEtY29tcG9uZW50cy9zcmMvbGliL21hdGNoYS1hdXRvY29tcGxldGUvbWF0Y2hhLWF1dG9jb21wbGV0ZS9tYXRjaGEtYXV0b2NvbXBsZXRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hdGNoYS1jb21wb25lbnRzL3NyYy9saWIvbWF0Y2hhLWF1dG9jb21wbGV0ZS9tYXRjaGEtYXV0b2NvbXBsZXRlL21hdGNoYS1hdXRvY29tcGxldGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUF1QyxTQUFTLEVBQUUsZUFBZSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQzNHLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDOzs7O0FBVTVELE1BQU0sT0FBTywyQkFBMkI7SUFLcEMsWUFBb0IsaUJBQW9DLEVBQVUsbUJBQXdDO1FBQXRGLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBbUI7UUFBVSx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQXFCO1FBSG5HLDBCQUFxQixHQUFZLEtBQUssQ0FBQztRQUN2QyxpQkFBWSxHQUFHLENBQUMsQ0FBQztJQUVxRixDQUFDO0lBRTlHLFFBQVE7UUFDSixJQUFJLENBQUMsbUJBQW1CLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxDQUFDLGNBQWMsRUFBRSxFQUFFO1lBQ2xFLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztnQkFDbEIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGlCQUFpQixFQUFFLENBQUM7WUFDakQsQ0FBQztZQUNELElBQUksQ0FBQyxxQkFBcUIsR0FBRyxjQUFjLENBQUM7UUFDaEQsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsa0JBQWtCO1FBQ2QsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUN2QyxJQUFJLE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7WUFDckIsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLGlCQUFpQixDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQztRQUM5QyxDQUFDO1FBRUQsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVoRCxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxVQUFVLEVBQUUsRUFBRTtZQUMxQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1lBQzdELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1FBQ2pELENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsQ0FBQyxtQkFBbUIsRUFBRSxFQUFFO1lBQ3JFLElBQUksQ0FBQyxZQUFZLEdBQUcsbUJBQW1CLENBQUM7WUFDeEMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQzNDLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzsrR0FqQ1EsMkJBQTJCO21HQUEzQiwyQkFBMkIsbUZBQ25CLHFCQUFxQiw2QkNaMUMsNFJBT0E7OzRGRElhLDJCQUEyQjtrQkFOdkMsU0FBUzsrQkFDSSxxQkFBcUIsY0FHbkIsS0FBSzt3SEFHdUIsT0FBTztzQkFBOUMsZUFBZTt1QkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlckNvbnRlbnRJbml0LCBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBDb250ZW50Q2hpbGRyZW4sIFF1ZXJ5TGlzdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0Y2hhT3B0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vcHVibGljLWFwaSc7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBNYXRjaGFPcHRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vbWF0Y2hhLW9wdGlvbi9tYXRjaGEtb3B0aW9uLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ21hdGNoYS1hdXRvY29tcGxldGUnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9tYXRjaGEtYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybDogJy4vbWF0Y2hhLWF1dG9jb21wbGV0ZS5jb21wb25lbnQuc2NzcycsXG4gICAgc3RhbmRhbG9uZTogZmFsc2UsXG59KVxuZXhwb3J0IGNsYXNzIE1hdGNoYUF1dG9jb21wbGV0ZUNvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyQ29udGVudEluaXQge1xuICAgIEBDb250ZW50Q2hpbGRyZW4oTWF0Y2hhT3B0aW9uQ29tcG9uZW50KSBvcHRpb25zITogUXVlcnlMaXN0PE1hdGNoYU9wdGlvbkNvbXBvbmVudD47XG4gICAgcHVibGljIGlzRGlzcGxheUF1dG9jb21wbGV0ZTogYm9vbGVhbiA9IGZhbHNlO1xuICAgIHB1YmxpYyBhY3RpdmVPcHRpb24gPSAwO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBjaGFuZ2VEZXRlY3RvclJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYsIHByaXZhdGUgbWF0Y2hhT3B0aW9uU2VydmljZTogTWF0Y2hhT3B0aW9uU2VydmljZSkge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLm1hdGNoYU9wdGlvblNlcnZpY2UuY2FuU2hvd09wdGlvbnMkLnN1YnNjcmliZSgoY2FuU2hvd09wdGlvbnMpID0+IHtcbiAgICAgICAgICAgIGlmICghY2FuU2hvd09wdGlvbnMpIHtcbiAgICAgICAgICAgICAgICB0aGlzLm1hdGNoYU9wdGlvblNlcnZpY2UucmVzZXRBY3RpdmVPcHRpb24oKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHRoaXMuaXNEaXNwbGF5QXV0b2NvbXBsZXRlID0gY2FuU2hvd09wdGlvbnM7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIG5nQWZ0ZXJDb250ZW50SW5pdCgpOiB2b2lkIHtcbiAgICAgICAgY29uc3Qgb3B0aW9ucyA9IHRoaXMub3B0aW9ucy50b0FycmF5KCk7XG4gICAgICAgIGlmIChvcHRpb25zLmxlbmd0aCA+IDApIHtcbiAgICAgICAgICAgIG9wdGlvbnNbMF0uc2V0SXNPcHRpb25BY3RpdmUodHJ1ZSwgZmFsc2UpO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5tYXRjaGFPcHRpb25TZXJ2aWNlLnVwZGF0ZU9wdGlvbnMob3B0aW9ucyk7XG5cbiAgICAgICAgdGhpcy5vcHRpb25zLmNoYW5nZXMuc3Vic2NyaWJlKChuZXdPcHRpb25zKSA9PiB7XG4gICAgICAgICAgICB0aGlzLm1hdGNoYU9wdGlvblNlcnZpY2UudXBkYXRlT3B0aW9ucyhuZXdPcHRpb25zLnRvQXJyYXkoKSk7XG4gICAgICAgICAgICB0aGlzLm1hdGNoYU9wdGlvblNlcnZpY2UucmVzZXRBY3RpdmVPcHRpb24oKTtcbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGhpcy5tYXRjaGFPcHRpb25TZXJ2aWNlLmFjdGl2ZU9wdGlvbiQuc3Vic2NyaWJlKChjdXJyZW50QWN0aXZlT3B0aW9uKSA9PiB7XG4gICAgICAgICAgICB0aGlzLmFjdGl2ZU9wdGlvbiA9IGN1cnJlbnRBY3RpdmVPcHRpb247XG4gICAgICAgICAgICB0aGlzLmNoYW5nZURldGVjdG9yUmVmLmRldGVjdENoYW5nZXMoKTtcbiAgICAgICAgfSk7XG4gICAgfVxufVxuIiwiPG5nLWNvbnRhaW5lciAqbmdJZj1cImlzRGlzcGxheUF1dG9jb21wbGV0ZVwiPlxuICAgIDxkaXYgY2xhc3M9XCJiYWNrZ3JvdW5kLWJnIHB0LTI0IHBvc2l0aW9uLWFic29sdXRlIHotaW5kZXgtMiB3LTEwMC1wXCI+XG4gICAgICAgIDx1bCBjbGFzcz1cImJhY2tncm91bmQtc3VyZmFjZSBtLTAgcmFkaXVzLTggZWxldmF0aW9uLXotMSBwLTBcIj5cbiAgICAgICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICAgICAgPC91bD5cbiAgICA8L2Rpdj5cbjwvbmctY29udGFpbmVyPlxuIl19
@@ -0,0 +1,71 @@
1
+ import { Directive, HostListener, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/forms";
4
+ import * as i2 from "../matcha-option/matcha-option.service";
5
+ export class MatchaAutocompleteDirective {
6
+ displayAutocomplete() {
7
+ this.matchaOptionService.setCanShowOptions(true);
8
+ }
9
+ hideAutocomplete() {
10
+ setTimeout(() => {
11
+ const canShowAutocomplete = this.matchaOptionService.getCanShowOptions();
12
+ if (canShowAutocomplete) {
13
+ this.matchaOptionService.setCanShowOptions(false);
14
+ }
15
+ }, 300);
16
+ }
17
+ onArrowDown(event) {
18
+ switch (event.key) {
19
+ case 'ArrowDown':
20
+ this.matchaOptionService.changeActiveOption(1);
21
+ break;
22
+ case 'ArrowUp':
23
+ this.matchaOptionService.changeActiveOption(-1);
24
+ break;
25
+ case 'Enter':
26
+ this.matchaOptionService.selectActiveOption();
27
+ break;
28
+ default:
29
+ break;
30
+ }
31
+ }
32
+ constructor(ngControl, _elementRef, matchaOptionService) {
33
+ this.ngControl = ngControl;
34
+ this._elementRef = _elementRef;
35
+ this.matchaOptionService = matchaOptionService;
36
+ }
37
+ ngOnInit() {
38
+ this.matchaOptionService.selectedOption$.subscribe((option) => {
39
+ this._updateInputValue(option);
40
+ });
41
+ }
42
+ _updateInputValue(selectedOption) {
43
+ if (this.ngControl.control) {
44
+ this.ngControl.control.setValue(selectedOption);
45
+ this.ngControl.control.markAsDirty();
46
+ this.matchaOptionService.setCanShowOptions(false);
47
+ this._elementRef.nativeElement.blur();
48
+ }
49
+ }
50
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaAutocompleteDirective, deps: [{ token: i1.NgControl }, { token: i0.ElementRef }, { token: i2.MatchaOptionService }], target: i0.ɵɵFactoryTarget.Directive }); }
51
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: MatchaAutocompleteDirective, selector: "[matchaAutocomplete]", inputs: { matchaAutocomplete: "matchaAutocomplete" }, host: { listeners: { "focus": "displayAutocomplete()", "focusout": "hideAutocomplete()", "keydown": "onArrowDown($event)" } }, ngImport: i0 }); }
52
+ }
53
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaAutocompleteDirective, decorators: [{
54
+ type: Directive,
55
+ args: [{
56
+ selector: '[matchaAutocomplete]',
57
+ standalone: false,
58
+ }]
59
+ }], ctorParameters: () => [{ type: i1.NgControl }, { type: i0.ElementRef }, { type: i2.MatchaOptionService }], propDecorators: { matchaAutocomplete: [{
60
+ type: Input
61
+ }], displayAutocomplete: [{
62
+ type: HostListener,
63
+ args: ['focus']
64
+ }], hideAutocomplete: [{
65
+ type: HostListener,
66
+ args: ['focusout']
67
+ }], onArrowDown: [{
68
+ type: HostListener,
69
+ args: ['keydown', ['$event']]
70
+ }] } });
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0Y2hhLWF1dG9jb21wbGV0ZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXRjaGEtY29tcG9uZW50cy9zcmMvbGliL21hdGNoYS1hdXRvY29tcGxldGUvbWF0Y2hhLWF1dG9jb21wbGV0ZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBUzNFLE1BQU0sT0FBTywyQkFBMkI7SUFHYixtQkFBbUI7UUFDdEMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFFeUIsZ0JBQWdCO1FBQ3RDLFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDWixNQUFNLG1CQUFtQixHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBRXpFLElBQUksbUJBQW1CLEVBQUUsQ0FBQztnQkFDdEIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ3RELENBQUM7UUFDTCxDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDWixDQUFDO0lBRW9DLFdBQVcsQ0FBQyxLQUFvQjtRQUNqRSxRQUFRLEtBQUssQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNoQixLQUFLLFdBQVc7Z0JBQ1osSUFBSSxDQUFDLG1CQUFtQixDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUMvQyxNQUFNO1lBQ1YsS0FBSyxTQUFTO2dCQUNWLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUNoRCxNQUFNO1lBQ1YsS0FBSyxPQUFPO2dCQUNSLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO2dCQUM5QyxNQUFNO1lBQ1Y7Z0JBQ0ksTUFBTTtRQUNkLENBQUM7SUFDTCxDQUFDO0lBRUQsWUFBb0IsU0FBb0IsRUFBVSxXQUF5QyxFQUFVLG1CQUF3QztRQUF6SCxjQUFTLEdBQVQsU0FBUyxDQUFXO1FBQVUsZ0JBQVcsR0FBWCxXQUFXLENBQThCO1FBQVUsd0JBQW1CLEdBQW5CLG1CQUFtQixDQUFxQjtJQUFHLENBQUM7SUFFakosUUFBUTtRQUNKLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxlQUFlLENBQUMsU0FBUyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUU7WUFDMUQsSUFBSSxDQUFDLGlCQUFpQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ25DLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVPLGlCQUFpQixDQUFDLGNBQW1CO1FBQ3pDLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUN6QixJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLENBQUM7WUFDaEQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDckMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2xELElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQzFDLENBQUM7SUFDTCxDQUFDOytHQWhEUSwyQkFBMkI7bUdBQTNCLDJCQUEyQjs7NEZBQTNCLDJCQUEyQjtrQkFKdkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsc0JBQXNCO29CQUNoQyxVQUFVLEVBQUUsS0FBSztpQkFDcEI7eUlBRVksa0JBQWtCO3NCQUExQixLQUFLO2dCQUVpQixtQkFBbUI7c0JBQXpDLFlBQVk7dUJBQUMsT0FBTztnQkFJSyxnQkFBZ0I7c0JBQXpDLFlBQVk7dUJBQUMsVUFBVTtnQkFVYSxXQUFXO3NCQUEvQyxZQUFZO3VCQUFDLFNBQVMsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmdDb250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTWF0Y2hhT3B0aW9uU2VydmljZSB9IGZyb20gJy4uL21hdGNoYS1vcHRpb24vbWF0Y2hhLW9wdGlvbi5zZXJ2aWNlJztcbmltcG9ydCB7IE1hdGNoYUF1dG9jb21wbGV0ZUNvbXBvbmVudCB9IGZyb20gJy4vbWF0Y2hhLWF1dG9jb21wbGV0ZS9tYXRjaGEtYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW21hdGNoYUF1dG9jb21wbGV0ZV0nLFxuICAgIHN0YW5kYWxvbmU6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBNYXRjaGFBdXRvY29tcGxldGVEaXJlY3RpdmUge1xuICAgIEBJbnB1dCgpIG1hdGNoYUF1dG9jb21wbGV0ZSE6IE1hdGNoYUF1dG9jb21wbGV0ZUNvbXBvbmVudDtcblxuICAgIEBIb3N0TGlzdGVuZXIoJ2ZvY3VzJykgZGlzcGxheUF1dG9jb21wbGV0ZSgpIHtcbiAgICAgICAgdGhpcy5tYXRjaGFPcHRpb25TZXJ2aWNlLnNldENhblNob3dPcHRpb25zKHRydWUpO1xuICAgIH1cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2ZvY3Vzb3V0JykgaGlkZUF1dG9jb21wbGV0ZSgpIHtcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICBjb25zdCBjYW5TaG93QXV0b2NvbXBsZXRlID0gdGhpcy5tYXRjaGFPcHRpb25TZXJ2aWNlLmdldENhblNob3dPcHRpb25zKCk7XG5cbiAgICAgICAgICAgIGlmIChjYW5TaG93QXV0b2NvbXBsZXRlKSB7XG4gICAgICAgICAgICAgICAgdGhpcy5tYXRjaGFPcHRpb25TZXJ2aWNlLnNldENhblNob3dPcHRpb25zKGZhbHNlKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSwgMzAwKTtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCdrZXlkb3duJywgWyckZXZlbnQnXSkgb25BcnJvd0Rvd24oZXZlbnQ6IEtleWJvYXJkRXZlbnQpIHtcbiAgICAgICAgc3dpdGNoIChldmVudC5rZXkpIHtcbiAgICAgICAgICAgIGNhc2UgJ0Fycm93RG93bic6XG4gICAgICAgICAgICAgICAgdGhpcy5tYXRjaGFPcHRpb25TZXJ2aWNlLmNoYW5nZUFjdGl2ZU9wdGlvbigxKTtcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIGNhc2UgJ0Fycm93VXAnOlxuICAgICAgICAgICAgICAgIHRoaXMubWF0Y2hhT3B0aW9uU2VydmljZS5jaGFuZ2VBY3RpdmVPcHRpb24oLTEpO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICAgICAgY2FzZSAnRW50ZXInOlxuICAgICAgICAgICAgICAgIHRoaXMubWF0Y2hhT3B0aW9uU2VydmljZS5zZWxlY3RBY3RpdmVPcHRpb24oKTtcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIG5nQ29udHJvbDogTmdDb250cm9sLCBwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxJbnB1dEVsZW1lbnQ+LCBwcml2YXRlIG1hdGNoYU9wdGlvblNlcnZpY2U6IE1hdGNoYU9wdGlvblNlcnZpY2UpIHt9XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5tYXRjaGFPcHRpb25TZXJ2aWNlLnNlbGVjdGVkT3B0aW9uJC5zdWJzY3JpYmUoKG9wdGlvbikgPT4ge1xuICAgICAgICAgICAgdGhpcy5fdXBkYXRlSW5wdXRWYWx1ZShvcHRpb24pO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBwcml2YXRlIF91cGRhdGVJbnB1dFZhbHVlKHNlbGVjdGVkT3B0aW9uOiBhbnkpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMubmdDb250cm9sLmNvbnRyb2wpIHtcbiAgICAgICAgICAgIHRoaXMubmdDb250cm9sLmNvbnRyb2wuc2V0VmFsdWUoc2VsZWN0ZWRPcHRpb24pO1xuICAgICAgICAgICAgdGhpcy5uZ0NvbnRyb2wuY29udHJvbC5tYXJrQXNEaXJ0eSgpO1xuICAgICAgICAgICAgdGhpcy5tYXRjaGFPcHRpb25TZXJ2aWNlLnNldENhblNob3dPcHRpb25zKGZhbHNlKTtcbiAgICAgICAgICAgIHRoaXMuX2VsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5ibHVyKCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,21 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { MatchaOptionModule } from '../matcha-option/matcha-option.module';
5
+ import { MatchaAutocompleteComponent } from './matcha-autocomplete/matcha-autocomplete.component';
6
+ import { MatchaAutocompleteDirective } from './matcha-autocomplete.directive';
7
+ import * as i0 from "@angular/core";
8
+ export class MatchaAutocompleteModule {
9
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaAutocompleteModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
10
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: MatchaAutocompleteModule, declarations: [MatchaAutocompleteComponent, MatchaAutocompleteDirective], imports: [CommonModule, FormsModule, MatchaOptionModule], exports: [MatchaAutocompleteComponent, MatchaAutocompleteDirective] }); }
11
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaAutocompleteModule, imports: [CommonModule, FormsModule, MatchaOptionModule] }); }
12
+ }
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaAutocompleteModule, decorators: [{
14
+ type: NgModule,
15
+ args: [{
16
+ declarations: [MatchaAutocompleteComponent, MatchaAutocompleteDirective],
17
+ imports: [CommonModule, FormsModule, MatchaOptionModule],
18
+ exports: [MatchaAutocompleteComponent, MatchaAutocompleteDirective],
19
+ }]
20
+ }] });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0Y2hhLWF1dG9jb21wbGV0ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXRjaGEtY29tcG9uZW50cy9zcmMvbGliL21hdGNoYS1hdXRvY29tcGxldGUvbWF0Y2hhLWF1dG9jb21wbGV0ZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRTNFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBQ2xHLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOztBQU85RSxNQUFNLE9BQU8sd0JBQXdCOytHQUF4Qix3QkFBd0I7Z0hBQXhCLHdCQUF3QixpQkFKbEIsMkJBQTJCLEVBQUUsMkJBQTJCLGFBQzdELFlBQVksRUFBRSxXQUFXLEVBQUUsa0JBQWtCLGFBQzdDLDJCQUEyQixFQUFFLDJCQUEyQjtnSEFFekQsd0JBQXdCLFlBSHZCLFlBQVksRUFBRSxXQUFXLEVBQUUsa0JBQWtCOzs0RkFHOUMsd0JBQXdCO2tCQUxwQyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLDJCQUEyQixFQUFFLDJCQUEyQixDQUFDO29CQUN4RSxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsV0FBVyxFQUFFLGtCQUFrQixDQUFDO29CQUN4RCxPQUFPLEVBQUUsQ0FBQywyQkFBMkIsRUFBRSwyQkFBMkIsQ0FBQztpQkFDdEUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTWF0Y2hhT3B0aW9uTW9kdWxlIH0gZnJvbSAnLi4vbWF0Y2hhLW9wdGlvbi9tYXRjaGEtb3B0aW9uLm1vZHVsZSc7XG5cbmltcG9ydCB7IE1hdGNoYUF1dG9jb21wbGV0ZUNvbXBvbmVudCB9IGZyb20gJy4vbWF0Y2hhLWF1dG9jb21wbGV0ZS9tYXRjaGEtYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXRjaGFBdXRvY29tcGxldGVEaXJlY3RpdmUgfSBmcm9tICcuL21hdGNoYS1hdXRvY29tcGxldGUuZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtNYXRjaGFBdXRvY29tcGxldGVDb21wb25lbnQsIE1hdGNoYUF1dG9jb21wbGV0ZURpcmVjdGl2ZV0sXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIE1hdGNoYU9wdGlvbk1vZHVsZV0sXG4gICAgZXhwb3J0czogW01hdGNoYUF1dG9jb21wbGV0ZUNvbXBvbmVudCwgTWF0Y2hhQXV0b2NvbXBsZXRlRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgTWF0Y2hhQXV0b2NvbXBsZXRlTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,20 @@
1
+ import { Directive } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class MatchaBadgeDirective {
4
+ constructor(_elementRef, _renderer) {
5
+ this._elementRef = _elementRef;
6
+ this._renderer = _renderer;
7
+ //this._elementRef.nativeElement.style.backgroundColor = 'grey';
8
+ this._renderer.addClass(this._elementRef.nativeElement, 'matcha-badge');
9
+ }
10
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaBadgeDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
11
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: MatchaBadgeDirective, selector: "[matcha-badge]", ngImport: i0 }); }
12
+ }
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaBadgeDirective, decorators: [{
14
+ type: Directive,
15
+ args: [{
16
+ selector: '[matcha-badge]',
17
+ standalone: false
18
+ }]
19
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }] });
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFkZ2UuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWF0Y2hhLWNvbXBvbmVudHMvc3JjL2xpYi9tYXRjaGEtYmFkZ2UvYmFkZ2UuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXlCLE1BQU0sZUFBZSxDQUFDOztBQU1qRSxNQUFNLE9BQU8sb0JBQW9CO0lBQzdCLFlBQW9CLFdBQXVCLEVBQVUsU0FBb0I7UUFBckQsZ0JBQVcsR0FBWCxXQUFXLENBQVk7UUFBVSxjQUFTLEdBQVQsU0FBUyxDQUFXO1FBQ3JFLGdFQUFnRTtRQUNoRSxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsRUFBRSxjQUFjLENBQUMsQ0FBQztJQUM1RSxDQUFDOytHQUpRLG9CQUFvQjttR0FBcEIsb0JBQW9COzs0RkFBcEIsb0JBQW9CO2tCQUpoQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLFVBQVUsRUFBRSxLQUFLO2lCQUNwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW21hdGNoYS1iYWRnZV0nLFxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXG59KVxuZXhwb3J0IGNsYXNzIE1hdGNoYUJhZGdlRGlyZWN0aXZlIHtcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9lbGVtZW50UmVmOiBFbGVtZW50UmVmLCBwcml2YXRlIF9yZW5kZXJlcjogUmVuZGVyZXIyKSB7XG4gICAgICAgIC8vdGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LnN0eWxlLmJhY2tncm91bmRDb2xvciA9ICdncmV5JztcbiAgICAgICAgdGhpcy5fcmVuZGVyZXIuYWRkQ2xhc3ModGhpcy5fZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCAnbWF0Y2hhLWJhZGdlJyk7XG4gICAgfVxufVxuIl19
@@ -0,0 +1,17 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { MatchaBadgeDirective } from './badge.directive';
3
+ import * as i0 from "@angular/core";
4
+ export class MatchaBadgeModule {
5
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaBadgeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
6
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: MatchaBadgeModule, declarations: [MatchaBadgeDirective], exports: [MatchaBadgeDirective] }); }
7
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaBadgeModule }); }
8
+ }
9
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaBadgeModule, decorators: [{
10
+ type: NgModule,
11
+ args: [{
12
+ declarations: [MatchaBadgeDirective],
13
+ imports: [],
14
+ exports: [MatchaBadgeDirective],
15
+ }]
16
+ }] });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFkZ2UubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWF0Y2hhLWNvbXBvbmVudHMvc3JjL2xpYi9tYXRjaGEtYmFkZ2UvYmFkZ2UubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBT3pELE1BQU0sT0FBTyxpQkFBaUI7K0dBQWpCLGlCQUFpQjtnSEFBakIsaUJBQWlCLGlCQUpYLG9CQUFvQixhQUV6QixvQkFBb0I7Z0hBRXJCLGlCQUFpQjs7NEZBQWpCLGlCQUFpQjtrQkFMN0IsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztvQkFDcEMsT0FBTyxFQUFFLEVBQUU7b0JBQ1gsT0FBTyxFQUFFLENBQUMsb0JBQW9CLENBQUM7aUJBQ2xDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdGNoYUJhZGdlRGlyZWN0aXZlIH0gZnJvbSAnLi9iYWRnZS5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW01hdGNoYUJhZGdlRGlyZWN0aXZlXSxcbiAgICBpbXBvcnRzOiBbXSxcbiAgICBleHBvcnRzOiBbTWF0Y2hhQmFkZ2VEaXJlY3RpdmVdLFxufSlcbmV4cG9ydCBjbGFzcyBNYXRjaGFCYWRnZU1vZHVsZSB7fVxuIl19
@@ -0,0 +1,205 @@
1
+ import { Component, ElementRef, HostBinding, Inject, Input, Renderer2 } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class MatchaButtonComponent {
4
+ get colorAttr() {
5
+ return this.color;
6
+ }
7
+ get basic() { return this._basic; }
8
+ set basic(v) { this._basic = v === 'false' ? false : !!v; }
9
+ get outline() { return this._outline; }
10
+ set outline(v) { this._outline = v === 'false' ? false : !!v; }
11
+ get alpha() { return this._alpha; }
12
+ set alpha(v) { this._alpha = v === 'false' ? false : !!v; }
13
+ get pill() { return this._pill; }
14
+ set pill(v) { this._pill = v === 'false' ? false : !!v; }
15
+ get link() { return this._link; }
16
+ set link(v) { this._link = v === 'false' ? false : !!v; }
17
+ get icon() { return this._icon; }
18
+ set icon(v) { this._icon = v === 'false' ? false : !!v; }
19
+ constructor(_elementRef, _renderer) {
20
+ this._elementRef = _elementRef;
21
+ this._renderer = _renderer;
22
+ this.size = null;
23
+ this.sizeXs = null;
24
+ this.sizeSm = null;
25
+ this.sizeMd = null;
26
+ this.sizeLg = null;
27
+ this.sizeXl = null;
28
+ this.color = 'basic';
29
+ this._basic = false;
30
+ this._outline = false;
31
+ this._alpha = false;
32
+ this._pill = false;
33
+ this._link = false;
34
+ this._icon = false;
35
+ this._config = {
36
+ sizeXs: 'tiny',
37
+ sizeSm: 'small',
38
+ sizeMd: 'medium',
39
+ sizeLg: 'large',
40
+ sizeXl: 'huge',
41
+ size: 'medium',
42
+ basic: false,
43
+ outline: false,
44
+ pill: false,
45
+ icon: false,
46
+ link: false
47
+ };
48
+ }
49
+ ngOnInit() {
50
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button`);
51
+ this.setConfig();
52
+ // Adicione o evento de clique apenas a elementos com a classe "matcha-button"
53
+ const buttons = document.querySelectorAll('.matcha-button');
54
+ buttons.forEach(button => {
55
+ // mouse down event
56
+ button.addEventListener('mousedown', this.addRippleEffect, false);
57
+ });
58
+ }
59
+ ngOnChanges() {
60
+ this.setConfig();
61
+ }
62
+ clearConfig() {
63
+ //size
64
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-${this._config.size}`);
65
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-xs-${this._config.sizeXs}`);
66
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-sm-${this._config.sizeSm}`);
67
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-md-${this._config.sizeMd}`);
68
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-lg-${this._config.sizeLg}`);
69
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-xl-${this._config.sizeXl}`);
70
+ //basic
71
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-icon`);
72
+ //outline
73
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-outline`);
74
+ //pill
75
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-pill`);
76
+ //icon
77
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-basic`);
78
+ //link
79
+ this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-link`);
80
+ }
81
+ setConfig() {
82
+ this.clearConfig();
83
+ this.size ? this.setSize() : null;
84
+ (this.outline === true || this.outline === 'true') ? this.setOutline() : null;
85
+ (this.pill === true || this.pill === 'true') ? this.setPill() : null;
86
+ (this.link === true || this.link === 'true') ? this.setLink() : null;
87
+ (this.basic === true || this.basic === 'true') ? this.setBasic() : null;
88
+ (this.icon === true || this.icon === 'true') ? this.setIcon() : null;
89
+ }
90
+ setSize() {
91
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-${this.size}`);
92
+ this._config.size = this.size;
93
+ if (this.sizeXs) {
94
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-xs-${this.sizeXs}`);
95
+ this._config.sizeXs = this.sizeXs;
96
+ }
97
+ if (this.sizeSm) {
98
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-sm-${this.sizeSm}`);
99
+ this._config.sizeSm = this.sizeSm;
100
+ }
101
+ if (this.sizeMd) {
102
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-md-${this.sizeMd}`);
103
+ this._config.sizeMd = this.sizeMd;
104
+ }
105
+ if (this.sizeLg) {
106
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-lg-${this.sizeLg}`);
107
+ this._config.sizeLg = this.sizeLg;
108
+ }
109
+ if (this.sizeXl) {
110
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-xl-${this.sizeXl}`);
111
+ this._config.sizeXl = this.sizeXl;
112
+ }
113
+ }
114
+ setOutline() {
115
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-outline`);
116
+ }
117
+ setPill() {
118
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-pill`);
119
+ }
120
+ setLink() {
121
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-link`);
122
+ }
123
+ setBasic() {
124
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-basic`);
125
+ this._renderer.addClass(this._elementRef.nativeElement, `basic`);
126
+ }
127
+ setIcon() {
128
+ this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-icon`);
129
+ }
130
+ addRippleEffect(e) {
131
+ var target = e.target;
132
+ if (target.tagName.toLowerCase() !== 'button')
133
+ return false;
134
+ var rect = target.getBoundingClientRect();
135
+ var ripple = target.querySelector('.ripple');
136
+ if (!ripple) {
137
+ ripple = document.createElement('span');
138
+ ripple.className = `ripple`;
139
+ ripple.style.height = ripple.style.width = target.offsetWidth + 'px';
140
+ target.appendChild(ripple);
141
+ }
142
+ ripple.classList.remove('show');
143
+ var top = e.pageY - rect.top - ripple.offsetHeight / 2 - window.scrollY;
144
+ var left = e.pageX - rect.left - ripple.offsetWidth / 2 - window.scrollX;
145
+ ripple.style.top = top + 'px';
146
+ ripple.style.left = left + 'px';
147
+ ripple.classList.add('show');
148
+ return false;
149
+ }
150
+ ngOnDestroy() {
151
+ const buttons = document.querySelectorAll('.matcha-button');
152
+ buttons.forEach(button => {
153
+ button.removeEventListener('click', this.addRippleEffect, false);
154
+ });
155
+ }
156
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonComponent, deps: [{ token: ElementRef }, { token: Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
157
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MatchaButtonComponent, selector: "[matcha-button]", inputs: { size: "size", sizeXs: ["size-xs", "sizeXs"], sizeSm: ["size-sm", "sizeSm"], sizeMd: ["size-md", "sizeMd"], sizeLg: ["size-lg", "sizeLg"], sizeXl: ["size-xl", "sizeXl"], color: "color", basic: "basic", outline: "outline", alpha: "alpha", pill: "pill", link: "link", icon: "icon" }, host: { properties: { "attr.color": "this.colorAttr" } }, usesOnChanges: true, ngImport: i0, template: "<ng-content></ng-content>\n", styles: [""] }); }
158
+ }
159
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonComponent, decorators: [{
160
+ type: Component,
161
+ args: [{ selector: '[matcha-button]', standalone: false, template: "<ng-content></ng-content>\n" }]
162
+ }], ctorParameters: () => [{ type: i0.ElementRef, decorators: [{
163
+ type: Inject,
164
+ args: [ElementRef]
165
+ }] }, { type: i0.Renderer2, decorators: [{
166
+ type: Inject,
167
+ args: [Renderer2]
168
+ }] }], propDecorators: { size: [{
169
+ type: Input,
170
+ args: ['size']
171
+ }], sizeXs: [{
172
+ type: Input,
173
+ args: ['size-xs']
174
+ }], sizeSm: [{
175
+ type: Input,
176
+ args: ['size-sm']
177
+ }], sizeMd: [{
178
+ type: Input,
179
+ args: ['size-md']
180
+ }], sizeLg: [{
181
+ type: Input,
182
+ args: ['size-lg']
183
+ }], sizeXl: [{
184
+ type: Input,
185
+ args: ['size-xl']
186
+ }], color: [{
187
+ type: Input,
188
+ args: ['color']
189
+ }], colorAttr: [{
190
+ type: HostBinding,
191
+ args: ['attr.color']
192
+ }], basic: [{
193
+ type: Input
194
+ }], outline: [{
195
+ type: Input
196
+ }], alpha: [{
197
+ type: Input
198
+ }], pill: [{
199
+ type: Input
200
+ }], link: [{
201
+ type: Input
202
+ }], icon: [{
203
+ type: Input
204
+ }] } });
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../projects/matcha-components/src/lib/matcha-button/button/button.component.ts","../../../../../../projects/matcha-components/src/lib/matcha-button/button/button.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostBinding, Inject, Input, OnChanges, OnInit, Renderer2 } from '@angular/core';\n\n@Component({\n    selector: '[matcha-button]',\n    templateUrl: './button.component.html',\n    styleUrls: ['./button.component.scss'],\n    standalone: false\n})\nexport class MatchaButtonComponent implements OnChanges, OnInit {\n    @Input('size') size: string | null = null;\n\n    @Input('size-xs') sizeXs: string | null = null;\n    @Input('size-sm') sizeSm: string | null = null;\n    @Input('size-md') sizeMd: string | null = null;\n    @Input('size-lg') sizeLg: string | null = null;\n    @Input('size-xl') sizeXl: string | null = null;\n\n    @Input('color') color: string | null = 'basic';\n\n    @HostBinding('attr.color')\n    get colorAttr(): string | null {\n        return this.color;\n    }\n\n    private _basic = false;\n    @Input() get basic() { return this._basic; }\n    set basic(v: boolean | string) { this._basic = v === 'false' ? false : !!v; }\n\n    private _outline = false;\n    @Input() get outline() { return this._outline; }\n    set outline(v: boolean | string) { this._outline = v === 'false' ? false : !!v;}\n\n    private _alpha = false;\n    @Input() get alpha() { return this._alpha; }\n    set alpha(v: boolean | string) { this._alpha = v === 'false' ? false : !!v;}\n\n    private _pill = false;\n    @Input() get pill() { return this._pill; }\n    set pill(v: boolean | string) { this._pill = v === 'false' ? false : !!v;}\n\n    private _link = false;\n    @Input() get link() { return this._link; }\n    set link(v: boolean | string) { this._link = v === 'false' ? false : !!v;}\n\n    private _icon = false;\n    @Input() get icon() { return this._icon; }\n    set icon(v: boolean | string) { this._icon = v === 'false' ? false : !!v;}\n\n    constructor(@Inject(ElementRef) private _elementRef: ElementRef, @Inject(Renderer2) private _renderer: Renderer2) {}\n\n    private _config: any = {\n        sizeXs: 'tiny',\n        sizeSm: 'small',\n        sizeMd: 'medium',\n        sizeLg: 'large',\n        sizeXl: 'huge',\n        size: 'medium',\n        basic: false,\n        outline: false,\n        pill: false,\n        icon: false,\n        link: false\n    };\n\n    ngOnInit() {\n        this._renderer.addClass(this._elementRef.nativeElement, `matcha-button`);\n        this.setConfig();\n        // Adicione o evento de clique apenas a elementos com a classe \"matcha-button\"\n        const buttons = document.querySelectorAll('.matcha-button');\n        buttons.forEach(button => {\n            // mouse down event\n            button.addEventListener('mousedown', this.addRippleEffect, false);\n        });\n    }\n\n    ngOnChanges() {\n        this.setConfig();\n    }\n\n    private clearConfig() {\n        //size\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-${this._config.size}`);\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-xs-${this._config.sizeXs}`);\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-sm-${this._config.sizeSm}`);\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-md-${this._config.sizeMd}`);\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-lg-${this._config.sizeLg}`);\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-xl-${this._config.sizeXl}`);\n        //basic\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-icon`);\n        //outline\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-outline`);\n        //pill\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-pill`);\n        //icon\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-basic`);\n        //link\n        this._renderer.removeClass(this._elementRef.nativeElement, `matcha-button-link`);\n    }\n\n    private setConfig() {\n        this.clearConfig();\n        this.size ? this.setSize() : null;\n        (this.outline === true || this.outline === 'true') ? this.setOutline() : null;\n        (this.pill === true || this.pill === 'true') ? this.setPill() : null;\n        (this.link === true || this.link === 'true') ? this.setLink() : null;\n        (this.basic === true || this.basic === 'true') ? this.setBasic() : null;\n        (this.icon === true || this.icon === 'true') ? this.setIcon() : null;\n    }\n\n    private setSize() {\n        this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-${this.size}`);\n        this._config.size = this.size;\n        if(this.sizeXs) {\n            this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-xs-${this.sizeXs}`);\n            this._config.sizeXs = this.sizeXs;\n        }\n        if(this.sizeSm) {\n            this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-sm-${this.sizeSm}`);\n            this._config.sizeSm = this.sizeSm;\n        }\n        if(this.sizeMd) {\n            this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-md-${this.sizeMd}`);\n            this._config.sizeMd = this.sizeMd;\n        }\n        if(this.sizeLg) {\n            this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-lg-${this.sizeLg}`);\n            this._config.sizeLg = this.sizeLg;\n        }\n        if(this.sizeXl) {\n            this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-xl-${this.sizeXl}`);\n            this._config.sizeXl = this.sizeXl;\n        }\n    }\n\n    private setOutline() {\n        this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-outline`);\n    }\n\n    private setPill() {\n        this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-pill`);\n    }\n\n    private setLink() {\n        this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-link`);\n    }\n\n    private setBasic() {\n        this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-basic`);\n        this._renderer.addClass(this._elementRef.nativeElement, `basic`);\n    }\n\n    private setIcon() {\n        this._renderer.addClass(this._elementRef.nativeElement, `matcha-button-icon`);\n    }\n\n    private addRippleEffect(e: any) {\n        var target = e.target;\n        if (target.tagName.toLowerCase() !== 'button') return false;\n        var rect = target.getBoundingClientRect();\n        var ripple = target.querySelector('.ripple');\n        if (!ripple) {\n            ripple = document.createElement('span');\n            ripple.className = `ripple`;\n            ripple.style.height = ripple.style.width = target.offsetWidth + 'px';\n            target.appendChild(ripple);\n        }\n        ripple.classList.remove('show');\n        var top = e.pageY - rect.top - ripple.offsetHeight / 2 - window.scrollY;\n        var left = e.pageX - rect.left - ripple.offsetWidth / 2 - window.scrollX;\n        ripple.style.top = top + 'px';\n        ripple.style.left = left + 'px';\n        ripple.classList.add('show');\n        return false;\n    }\n\n    ngOnDestroy() {\n        const buttons = document.querySelectorAll('.matcha-button');\n        buttons.forEach(button => {\n            button.removeEventListener('click', this.addRippleEffect, false);\n        });\n    }\n}\n","<ng-content></ng-content>\n"]}
@@ -0,0 +1,17 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { MatchaButtonComponent } from './button/button.component';
3
+ import * as i0 from "@angular/core";
4
+ export class MatchaButtonModule {
5
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
6
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonModule, declarations: [MatchaButtonComponent], exports: [MatchaButtonComponent] }); }
7
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonModule }); }
8
+ }
9
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonModule, decorators: [{
10
+ type: NgModule,
11
+ args: [{
12
+ declarations: [MatchaButtonComponent],
13
+ imports: [],
14
+ exports: [MatchaButtonComponent],
15
+ }]
16
+ }] });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21hdGNoYS1jb21wb25lbnRzL3NyYy9saWIvbWF0Y2hhLWJ1dHRvbi9idXR0b24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFekMsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7O0FBT2xFLE1BQU0sT0FBTyxrQkFBa0I7K0dBQWxCLGtCQUFrQjtnSEFBbEIsa0JBQWtCLGlCQUpaLHFCQUFxQixhQUUxQixxQkFBcUI7Z0hBRXRCLGtCQUFrQjs7NEZBQWxCLGtCQUFrQjtrQkFMOUIsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztvQkFDckMsT0FBTyxFQUFFLEVBQUU7b0JBQ1gsT0FBTyxFQUFFLENBQUMscUJBQXFCLENBQUM7aUJBQ25DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgTWF0Y2hhQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9idXR0b24vYnV0dG9uLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbTWF0Y2hhQnV0dG9uQ29tcG9uZW50XSxcbiAgICBpbXBvcnRzOiBbXSxcbiAgICBleHBvcnRzOiBbTWF0Y2hhQnV0dG9uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTWF0Y2hhQnV0dG9uTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,88 @@
1
+ import { Component, ContentChildren, HostBinding, Input } from '@angular/core';
2
+ import { MatchaButtonComponent } from '../../matcha-button/button/button.component';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ export class MatchaButtonToggleComponent {
6
+ get multiple() { return this._multiple; }
7
+ set multiple(v) { this._multiple = v === 'false' ? false : !!v; }
8
+ get disabled() { return this._disabled; }
9
+ set disabled(v) { this._disabled = v === 'false' ? false : !!v; }
10
+ get isDisabled() { return this.disabled || null; }
11
+ get required() { return this._required; }
12
+ set required(v) { this._required = v === 'false' ? false : !!v; }
13
+ set gap(v) { const n = +v; this._gap = isNaN(n) ? 16 : n; }
14
+ get gapClass() { return `gap-${this._gap}`; }
15
+ get gap() {
16
+ return this._gap;
17
+ }
18
+ constructor(elementRef) {
19
+ this.elementRef = elementRef;
20
+ this._multiple = false;
21
+ this._disabled = false;
22
+ this._required = false;
23
+ this.inactiveColor = 'primary';
24
+ this.inactiveType = 'solid';
25
+ this._gap = 16;
26
+ }
27
+ ngAfterContentInit() {
28
+ const buttons = this.elementRef.nativeElement.querySelectorAll('button[matcha-button]');
29
+ buttons.forEach((button, index) => {
30
+ const isActive = button.hasAttribute('active');
31
+ this.setButtonState(button, isActive);
32
+ button.addEventListener('click', () => this.onButtonSelected(button));
33
+ });
34
+ }
35
+ setButtonState(button, isActive) {
36
+ if (isActive) {
37
+ button.setAttribute('active', '');
38
+ }
39
+ else {
40
+ button.removeAttribute('active');
41
+ }
42
+ }
43
+ onButtonSelected(selectedButton) {
44
+ const buttons = this.elementRef.nativeElement.querySelectorAll('button[matcha-button]');
45
+ const activeButtons = Array.from(buttons).filter((button) => button.hasAttribute('active'));
46
+ if (this.required && activeButtons.length === 1 && activeButtons[0] === selectedButton) {
47
+ return;
48
+ }
49
+ if (this.multiple) {
50
+ const isActive = selectedButton.hasAttribute('active');
51
+ this.setButtonState(selectedButton, !isActive);
52
+ return;
53
+ }
54
+ if (selectedButton.hasAttribute('active')) {
55
+ this.setButtonState(selectedButton, false);
56
+ }
57
+ else {
58
+ buttons.forEach((button) => {
59
+ this.setButtonState(button, button === selectedButton);
60
+ });
61
+ }
62
+ }
63
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonToggleComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
64
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: MatchaButtonToggleComponent, selector: "matcha-button-toggle", inputs: { multiple: "multiple", disabled: "disabled", required: "required", inactiveColor: "inactiveColor", inactiveType: "inactiveType", gap: "gap" }, host: { properties: { "attr.disabled": "this.isDisabled" } }, queries: [{ propertyName: "buttons", predicate: MatchaButtonComponent }], ngImport: i0, template: "<div\n class=\"button-group d-flex\"\n [ngClass]=\"gapClass\"\n [class.flex-wrap]=\"gap !== 0\"\n role=\"group\"\n>\n <ng-content></ng-content>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
65
+ }
66
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonToggleComponent, decorators: [{
67
+ type: Component,
68
+ args: [{ selector: 'matcha-button-toggle', standalone: false, template: "<div\n class=\"button-group d-flex\"\n [ngClass]=\"gapClass\"\n [class.flex-wrap]=\"gap !== 0\"\n role=\"group\"\n>\n <ng-content></ng-content>\n</div>\n" }]
69
+ }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { multiple: [{
70
+ type: Input
71
+ }], disabled: [{
72
+ type: Input
73
+ }], isDisabled: [{
74
+ type: HostBinding,
75
+ args: ['attr.disabled']
76
+ }], required: [{
77
+ type: Input
78
+ }], inactiveColor: [{
79
+ type: Input
80
+ }], inactiveType: [{
81
+ type: Input
82
+ }], gap: [{
83
+ type: Input
84
+ }], buttons: [{
85
+ type: ContentChildren,
86
+ args: [MatchaButtonComponent]
87
+ }] } });
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-toggle.component.js","sourceRoot":"","sources":["../../../../../../projects/matcha-components/src/lib/matcha-button-toggle/button-toggle/button-toggle.component.ts","../../../../../../projects/matcha-components/src/lib/matcha-button-toggle/button-toggle/button-toggle.component.html"],"names":[],"mappings":"AAAA,OAAO,EACa,SAAS,EAAE,eAAe,EAAE,WAAW,EACzD,KAAK,EACN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,qBAAqB,EAAE,MAAM,6CAA6C,CAAC;;;AAQpF,MAAM,OAAO,2BAA2B;IAGtC,IAAa,QAAQ,KAAK,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IAClD,IAAI,QAAQ,CAAC,CAAmB,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAGnF,IAAa,QAAQ,KAAK,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IAClD,IAAI,QAAQ,CAAC,CAAmB,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACnF,IAAkC,UAAU,KAAK,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC;IAGhF,IAAa,QAAQ,KAAK,OAAO,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC;IAClD,IAAI,QAAQ,CAAC,CAAmB,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAOnF,IAAa,GAAG,CAAC,CAAkB,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACrF,IAAI,QAAQ,KAAK,OAAO,OAAO,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;IAE7C,IAAI,GAAG;QACL,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAKD,YAAoB,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;QA5BhC,cAAS,GAAG,KAAK,CAAC;QAIpB,cAAS,GAAG,KAAK,CAAC;QAKlB,cAAS,GAAG,KAAK,CAAC;QAIjB,kBAAa,GAAG,SAAS,CAAC;QAE1B,iBAAY,GAAW,OAAO,CAAC;QAEhC,SAAI,GAAG,EAAE,CAAC;IAW2B,CAAC;IAE9C,kBAAkB;QAChB,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,CAAC;QACxF,OAAO,CAAC,OAAO,CAAC,CAAC,MAAe,EAAE,KAAa,EAAE,EAAE;YACjD,MAAM,QAAQ,GAAG,MAAM,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;YAC/C,IAAI,CAAC,cAAc,CAAC,MAAqB,EAAE,QAAQ,CAAC,CAAC;YAErD,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,MAAqB,CAAC,CAAC,CAAC;QACvF,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,cAAc,CAAC,MAAmB,EAAE,QAAiB;QAC3D,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;QACpC,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;QACnC,CAAC;IACH,CAAC;IAEO,gBAAgB,CAAC,cAA2B;QAClD,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,uBAAuB,CAAC,CAAC;QACxF,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,MAAe,EAAE,EAAE,CAClE,MAAkB,CAAC,YAAY,CAAC,QAAQ,CAAC,CAC3C,CAAC;QAEF,IAAI,IAAI,CAAC,QAAQ,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,IAAI,aAAa,CAAC,CAAC,CAAC,KAAK,cAAc,EAAE,CAAC;YACvF,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,MAAM,QAAQ,GAAG,cAAc,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;YACvD,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE,CAAC,QAAQ,CAAC,CAAC;YAC/C,OAAO;QACT,CAAC;QAED,IAAI,cAAc,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC1C,IAAI,CAAC,cAAc,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QAC7C,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,OAAO,CAAC,CAAC,MAAe,EAAE,EAAE;gBAClC,IAAI,CAAC,cAAc,CAAC,MAAqB,EAAE,MAAM,KAAK,cAAc,CAAC,CAAC;YACxE,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;+GAzEU,2BAA2B;mGAA3B,2BAA2B,0SA2BrB,qBAAqB,6BCvCxC,gKAQA;;4FDIa,2BAA2B;kBANvC,SAAS;+BACE,sBAAsB,cAGpB,KAAK;+EAKJ,QAAQ;sBAApB,KAAK;gBAIO,QAAQ;sBAApB,KAAK;gBAE4B,UAAU;sBAA3C,WAAW;uBAAC,eAAe;gBAGf,QAAQ;sBAApB,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBAEG,YAAY;sBAApB,KAAK;gBAGO,GAAG;sBAAf,KAAK;gBAQN,OAAO;sBADN,eAAe;uBAAC,qBAAqB","sourcesContent":["import {\n  AfterContentInit, Component, ContentChildren, HostBinding,\n  Input, QueryList, ElementRef\n} from '@angular/core';\nimport { MatchaButtonComponent } from '../../matcha-button/button/button.component';\n\n@Component({\n  selector: 'matcha-button-toggle',\n  templateUrl: './button-toggle.component.html',\n  styleUrl: './button-toggle.component.scss',\n  standalone: false\n})\nexport class MatchaButtonToggleComponent implements AfterContentInit {\n\n    private _multiple = false;\n  @Input() get multiple() { return this._multiple; }\n  set multiple(v: boolean | string) { this._multiple = v === 'false' ? false : !!v; }\n\n  private _disabled = false;\n  @Input() get disabled() { return this._disabled; }\n  set disabled(v: boolean | string) { this._disabled = v === 'false' ? false : !!v; }\n  @HostBinding('attr.disabled') get isDisabled() { return this.disabled || null; }\n\n  private _required = false;\n  @Input() get required() { return this._required; }\n  set required(v: boolean | string) { this._required = v === 'false' ? false : !!v; }\n\n  @Input() inactiveColor = 'primary';\n\n  @Input() inactiveType: string = 'solid';\n\n  private _gap = 16;\n  @Input() set gap(v: string | number) { const n = +v; this._gap = isNaN(n) ? 16 : n; }\n  get gapClass() { return `gap-${this._gap}`; }\n\n  get gap(): number {\n    return this._gap;\n  }\n\n  @ContentChildren(MatchaButtonComponent)\n  buttons!: QueryList<MatchaButtonComponent>;\n\n  constructor(private elementRef: ElementRef) {}\n\n  ngAfterContentInit(): void {\n    const buttons = this.elementRef.nativeElement.querySelectorAll('button[matcha-button]');\n    buttons.forEach((button: Element, index: number) => {\n      const isActive = button.hasAttribute('active');\n      this.setButtonState(button as HTMLElement, isActive);\n\n      button.addEventListener('click', () => this.onButtonSelected(button as HTMLElement));\n    });\n  }\n\n  private setButtonState(button: HTMLElement, isActive: boolean): void {\n    if (isActive) {\n      button.setAttribute('active', '');\n    } else {\n      button.removeAttribute('active');\n    }\n  }\n\n  private onButtonSelected(selectedButton: HTMLElement): void {\n    const buttons = this.elementRef.nativeElement.querySelectorAll('button[matcha-button]');\n    const activeButtons = Array.from(buttons).filter((button: unknown) =>\n      (button as Element).hasAttribute('active')\n    );\n\n    if (this.required && activeButtons.length === 1 && activeButtons[0] === selectedButton) {\n      return;\n    }\n\n    if (this.multiple) {\n      const isActive = selectedButton.hasAttribute('active');\n      this.setButtonState(selectedButton, !isActive);\n      return;\n    }\n\n    if (selectedButton.hasAttribute('active')) {\n      this.setButtonState(selectedButton, false);\n    } else {\n      buttons.forEach((button: Element) => {\n        this.setButtonState(button as HTMLElement, button === selectedButton);\n      });\n    }\n  }\n}\n","<div\n  class=\"button-group d-flex\"\n  [ngClass]=\"gapClass\"\n  [class.flex-wrap]=\"gap !== 0\"\n  role=\"group\"\n>\n  <ng-content></ng-content>\n</div>\n"]}
@@ -0,0 +1,24 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { MatchaButtonToggleComponent } from './button-toggle/button-toggle.component';
4
+ import { MatchaTooltipModule } from '../matcha-tooltip/tooltip.module';
5
+ import * as i0 from "@angular/core";
6
+ export class MatchaButtonToggleModule {
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonToggleModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
8
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonToggleModule, declarations: [MatchaButtonToggleComponent], imports: [CommonModule,
9
+ MatchaTooltipModule], exports: [MatchaButtonToggleComponent] }); }
10
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonToggleModule, imports: [CommonModule,
11
+ MatchaTooltipModule] }); }
12
+ }
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MatchaButtonToggleModule, decorators: [{
14
+ type: NgModule,
15
+ args: [{
16
+ declarations: [MatchaButtonToggleComponent],
17
+ imports: [
18
+ CommonModule,
19
+ MatchaTooltipModule
20
+ ],
21
+ exports: [MatchaButtonToggleComponent]
22
+ }]
23
+ }] });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLXRvZ2dsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXRjaGEtY29tcG9uZW50cy9zcmMvbGliL21hdGNoYS1idXR0b24tdG9nZ2xlL2J1dHRvbi10b2dnbGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDOztBQVl2RSxNQUFNLE9BQU8sd0JBQXdCOytHQUF4Qix3QkFBd0I7Z0hBQXhCLHdCQUF3QixpQkFQcEIsMkJBQTJCLGFBRXhDLFlBQVk7WUFDWixtQkFBbUIsYUFFWCwyQkFBMkI7Z0hBRTFCLHdCQUF3QixZQUxqQyxZQUFZO1lBQ1osbUJBQW1COzs0RkFJVix3QkFBd0I7a0JBUnBDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsMkJBQTJCLENBQUM7b0JBQzNDLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsMkJBQTJCLENBQUM7aUJBQ3ZDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBNYXRjaGFCdXR0b25Ub2dnbGVDb21wb25lbnQgfSBmcm9tICcuL2J1dHRvbi10b2dnbGUvYnV0dG9uLXRvZ2dsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTWF0Y2hhVG9vbHRpcE1vZHVsZSB9IGZyb20gJy4uL21hdGNoYS10b29sdGlwL3Rvb2x0aXAubW9kdWxlJztcblxuXG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW01hdGNoYUJ1dHRvblRvZ2dsZUNvbXBvbmVudF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgTWF0Y2hhVG9vbHRpcE1vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbTWF0Y2hhQnV0dG9uVG9nZ2xlQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBNYXRjaGFCdXR0b25Ub2dnbGVNb2R1bGUgeyB9XG4iXX0=