@mintplayer/ng-bootstrap 13.1.5 → 13.1.10

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 (157) hide show
  1. package/esm2020/index.mjs +3 -1
  2. package/esm2020/lib/components/accordion/accordion-tab/accordion-tab.component.mjs +4 -3
  3. package/esm2020/lib/components/accordion/accordion-tab-header/accordion-tab-header.component.mjs +7 -3
  4. package/esm2020/lib/components/alert/alert/alert.component.mjs +4 -4
  5. package/esm2020/lib/components/calendar/calendar.component.mjs +77 -34
  6. package/esm2020/lib/components/card/card/card.component.mjs +1 -2
  7. package/esm2020/lib/components/carousel/carousel/carousel.component.mjs +21 -7
  8. package/esm2020/lib/components/context-menu/context-menu.directive.mjs +57 -0
  9. package/esm2020/lib/components/context-menu/context-menu.module.mjs +26 -0
  10. package/esm2020/lib/components/context-menu/index.mjs +3 -0
  11. package/esm2020/lib/components/datatable/datatable/datatable.component.mjs +51 -0
  12. package/esm2020/lib/components/datatable/datatable-column/datatable-column-metadata.mjs +2 -0
  13. package/esm2020/lib/components/datatable/datatable-column/datatable-column.directive.mjs +19 -0
  14. package/esm2020/lib/components/datatable/datatable-settings.mjs +37 -0
  15. package/esm2020/lib/components/datatable/datatable.module.mjs +40 -0
  16. package/esm2020/lib/components/datatable/index.mjs +6 -0
  17. package/esm2020/lib/components/datatable/row-template/row-template.directive.mjs +19 -0
  18. package/esm2020/lib/components/datepicker/datepicker.component.mjs +22 -0
  19. package/esm2020/lib/components/datepicker/datepicker.module.mjs +34 -0
  20. package/esm2020/lib/components/datepicker/index.mjs +3 -0
  21. package/esm2020/lib/components/dropdown/dropdown/dropdown.directive.mjs +51 -0
  22. package/esm2020/lib/components/dropdown/dropdown-menu/dropdown-menu.directive.mjs +91 -0
  23. package/esm2020/lib/components/dropdown/dropdown-toggle/dropdown-toggle.directive.mjs +28 -0
  24. package/esm2020/lib/components/dropdown/dropdown.module.mjs +44 -0
  25. package/esm2020/lib/components/dropdown/index.mjs +5 -0
  26. package/esm2020/lib/components/index.mjs +16 -4
  27. package/esm2020/lib/components/multiselect/index.mjs +3 -0
  28. package/esm2020/lib/components/multiselect/multiselect.component.mjs +36 -0
  29. package/esm2020/lib/components/multiselect/multiselect.module.mjs +34 -0
  30. package/esm2020/lib/components/navbar/nav-link/nav-link.directive.mjs +1 -1
  31. package/esm2020/lib/components/navbar/navbar/navbar.component.mjs +9 -6
  32. package/esm2020/lib/components/navbar/navbar-nav/navbar-nav.component.mjs +47 -9
  33. package/esm2020/lib/components/pagination/index.mjs +3 -0
  34. package/esm2020/lib/components/pagination/pagination/pagination.component.mjs +146 -0
  35. package/esm2020/lib/components/pagination/pagination.module.mjs +26 -0
  36. package/esm2020/lib/components/progress-bar/index.mjs +4 -0
  37. package/esm2020/lib/components/progress-bar/progress/progress.component.mjs +27 -0
  38. package/esm2020/lib/components/progress-bar/progress-bar/progress-bar.component.mjs +121 -0
  39. package/esm2020/lib/components/progress-bar/progress-bar.module.mjs +31 -0
  40. package/esm2020/lib/components/scrollspy/component/scrollspy.component.mjs +28 -12
  41. package/esm2020/lib/components/select2/component/select2.component.mjs +96 -0
  42. package/esm2020/lib/components/select2/directive/item-template.directive.mjs +20 -0
  43. package/esm2020/lib/components/select2/index.mjs +4 -0
  44. package/esm2020/lib/components/select2/select2.module.mjs +43 -0
  45. package/esm2020/lib/components/snackbar/component/snackbar.component.mjs +35 -0
  46. package/esm2020/lib/components/snackbar/directives/index.mjs +2 -0
  47. package/esm2020/lib/components/snackbar/directives/snackbar-close/snackbar-close.directive.mjs +27 -0
  48. package/esm2020/lib/components/snackbar/index.mjs +6 -0
  49. package/esm2020/lib/components/snackbar/interfaces/index.mjs +2 -0
  50. package/esm2020/lib/components/snackbar/interfaces/snackbar-animation-meta.mjs +2 -0
  51. package/esm2020/lib/components/snackbar/providers/snackbar-content.provider.mjs +3 -0
  52. package/esm2020/lib/components/snackbar/service/snackbar.service.mjs +50 -0
  53. package/esm2020/lib/components/snackbar/snackbar.module.mjs +38 -0
  54. package/esm2020/lib/components/toggle-button/index.mjs +3 -0
  55. package/esm2020/lib/components/toggle-button/toggle-button.component.mjs +42 -0
  56. package/esm2020/lib/components/toggle-button/toggle-button.module.mjs +26 -0
  57. package/esm2020/lib/components/tooltip/component/tooltip.component.mjs +25 -0
  58. package/esm2020/lib/components/tooltip/directive/tooltip.directive.mjs +104 -0
  59. package/esm2020/lib/components/tooltip/index.mjs +4 -0
  60. package/esm2020/lib/components/tooltip/providers/tooltip-content.provider.mjs +3 -0
  61. package/esm2020/lib/components/tooltip/tooltip.module.mjs +29 -0
  62. package/esm2020/lib/components/typeahead/index.mjs +3 -0
  63. package/esm2020/lib/components/typeahead/typeahead.component.mjs +90 -0
  64. package/esm2020/lib/components/typeahead/typeahead.module.mjs +38 -0
  65. package/esm2020/lib/enums/index.mjs +2 -1
  66. package/esm2020/lib/enums/position.enum.mjs +8 -0
  67. package/esm2020/lib/interfaces/index.mjs +2 -0
  68. package/esm2020/lib/interfaces/page-with-selection.mjs +2 -0
  69. package/esm2020/lib/pipes/font-color/font-color.module.mjs +26 -0
  70. package/esm2020/lib/pipes/font-color/font-color.pipe.mjs +26 -0
  71. package/esm2020/lib/pipes/font-color/index.mjs +3 -0
  72. package/esm2020/lib/pipes/in-list/in-list.module.mjs +26 -0
  73. package/esm2020/lib/pipes/in-list/in-list.pipe.mjs +16 -0
  74. package/esm2020/lib/pipes/index.mjs +2 -0
  75. package/esm2020/lib/pipes/month-name/month-name.pipe.mjs +7 -2
  76. package/esm2020/lib/services/calendar-month/calendar-month.service.mjs +12 -14
  77. package/esm2020/lib/services/scroll-offset/scroll-offset.service.mjs +31 -0
  78. package/esm2020/lib/types/page-number.type.mjs +2 -0
  79. package/fesm2015/mintplayer-ng-bootstrap.mjs +1970 -297
  80. package/fesm2015/mintplayer-ng-bootstrap.mjs.map +1 -1
  81. package/fesm2020/mintplayer-ng-bootstrap.mjs +1943 -283
  82. package/fesm2020/mintplayer-ng-bootstrap.mjs.map +1 -1
  83. package/index.d.ts +2 -0
  84. package/lib/components/accordion/accordion-tab-header/accordion-tab-header.component.d.ts +1 -0
  85. package/lib/components/calendar/calendar.component.d.ts +21 -13
  86. package/lib/components/carousel/carousel/carousel.component.d.ts +4 -1
  87. package/lib/components/context-menu/context-menu.directive.d.ts +16 -0
  88. package/lib/components/context-menu/context-menu.module.d.ts +8 -0
  89. package/lib/components/context-menu/index.d.ts +2 -0
  90. package/lib/components/datatable/datatable/datatable.component.d.ts +17 -0
  91. package/lib/components/datatable/datatable-column/datatable-column-metadata.d.ts +4 -0
  92. package/lib/components/datatable/datatable-column/datatable-column.directive.d.ts +10 -0
  93. package/lib/components/datatable/datatable-settings.d.ts +15 -0
  94. package/lib/components/datatable/datatable.module.d.ts +11 -0
  95. package/lib/components/datatable/index.d.ts +5 -0
  96. package/lib/components/datatable/row-template/row-template.directive.d.ts +9 -0
  97. package/lib/components/datepicker/datepicker.component.d.ts +10 -0
  98. package/lib/components/datepicker/datepicker.module.d.ts +10 -0
  99. package/lib/components/datepicker/index.d.ts +2 -0
  100. package/lib/components/dropdown/dropdown/dropdown.directive.d.ts +20 -0
  101. package/lib/components/dropdown/dropdown-menu/dropdown-menu.directive.d.ts +20 -0
  102. package/lib/components/dropdown/dropdown-toggle/dropdown-toggle.directive.d.ts +11 -0
  103. package/lib/components/dropdown/dropdown.module.d.ts +12 -0
  104. package/lib/components/dropdown/index.d.ts +4 -0
  105. package/lib/components/index.d.ts +15 -3
  106. package/lib/components/multiselect/index.d.ts +2 -0
  107. package/lib/components/multiselect/multiselect.component.d.ts +12 -0
  108. package/lib/components/multiselect/multiselect.module.d.ts +10 -0
  109. package/lib/components/navbar/navbar/navbar.component.d.ts +3 -3
  110. package/lib/components/navbar/navbar-nav/navbar-nav.component.d.ts +10 -4
  111. package/lib/components/pagination/index.d.ts +2 -0
  112. package/lib/components/pagination/pagination/pagination.component.d.ts +45 -0
  113. package/lib/components/pagination/pagination.module.d.ts +8 -0
  114. package/lib/components/progress-bar/index.d.ts +3 -0
  115. package/lib/components/progress-bar/progress/progress.component.d.ts +8 -0
  116. package/lib/components/progress-bar/progress-bar/progress-bar.component.d.ts +31 -0
  117. package/lib/components/progress-bar/progress-bar.module.d.ts +9 -0
  118. package/lib/components/scrollspy/component/scrollspy.component.d.ts +6 -4
  119. package/lib/components/select2/component/select2.component.d.ts +30 -0
  120. package/lib/components/select2/directive/item-template.directive.d.ts +9 -0
  121. package/lib/components/select2/index.d.ts +3 -0
  122. package/lib/components/select2/select2.module.d.ts +12 -0
  123. package/lib/components/snackbar/component/snackbar.component.d.ts +16 -0
  124. package/lib/components/snackbar/directives/index.d.ts +1 -0
  125. package/lib/components/snackbar/directives/snackbar-close/snackbar-close.directive.d.ts +11 -0
  126. package/lib/components/snackbar/index.d.ts +5 -0
  127. package/lib/components/snackbar/interfaces/index.d.ts +1 -0
  128. package/lib/components/snackbar/interfaces/snackbar-animation-meta.d.ts +7 -0
  129. package/lib/components/snackbar/providers/snackbar-content.provider.d.ts +2 -0
  130. package/lib/components/snackbar/service/snackbar.service.d.ts +14 -0
  131. package/lib/components/snackbar/snackbar.module.d.ts +9 -0
  132. package/lib/components/toggle-button/index.d.ts +2 -0
  133. package/lib/components/toggle-button/toggle-button.component.d.ts +15 -0
  134. package/lib/components/toggle-button/toggle-button.module.d.ts +8 -0
  135. package/lib/components/tooltip/component/tooltip.component.d.ts +11 -0
  136. package/lib/components/tooltip/directive/tooltip.directive.d.ts +19 -0
  137. package/lib/components/tooltip/index.d.ts +2 -0
  138. package/lib/components/tooltip/providers/tooltip-content.provider.d.ts +2 -0
  139. package/lib/components/tooltip/tooltip.module.d.ts +9 -0
  140. package/lib/components/typeahead/index.d.ts +2 -0
  141. package/lib/components/typeahead/typeahead.component.d.ts +29 -0
  142. package/lib/components/typeahead/typeahead.module.d.ts +11 -0
  143. package/lib/enums/index.d.ts +1 -0
  144. package/lib/enums/position.enum.d.ts +6 -0
  145. package/lib/interfaces/index.d.ts +1 -0
  146. package/lib/interfaces/page-with-selection.d.ts +5 -0
  147. package/lib/pipes/font-color/font-color.module.d.ts +8 -0
  148. package/lib/pipes/font-color/font-color.pipe.d.ts +7 -0
  149. package/lib/pipes/font-color/index.d.ts +2 -0
  150. package/lib/pipes/in-list/in-list.module.d.ts +8 -0
  151. package/lib/pipes/in-list/in-list.pipe.d.ts +7 -0
  152. package/lib/pipes/index.d.ts +1 -0
  153. package/lib/pipes/month-name/month-name.pipe.d.ts +1 -1
  154. package/lib/services/calendar-month/calendar-month.service.d.ts +0 -1
  155. package/lib/services/scroll-offset/scroll-offset.service.d.ts +9 -0
  156. package/lib/types/page-number.type.d.ts +1 -0
  157. package/package.json +6 -2
package/esm2020/index.mjs CHANGED
@@ -1,3 +1,5 @@
1
1
  export * from './lib/components';
2
2
  export * from './lib/enums';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbnVtcyc7Il19
3
+ export * from './lib/interfaces';
4
+ export * from './lib/pipes';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VudW1zJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyZmFjZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGlwZXMnOyJdfQ==
@@ -3,6 +3,7 @@ import { SlideUpDownAnimation } from '@mintplayer/ng-animations';
3
3
  import { BsAccordionComponent } from '../accordion/accordion.component';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "../accordion/accordion.component";
6
+ import * as i2 from "@angular/common";
6
7
  export class BsAccordionTabComponent {
7
8
  constructor(accordion) {
8
9
  this.accordion = accordion;
@@ -19,9 +20,9 @@ export class BsAccordionTabComponent {
19
20
  }
20
21
  }
21
22
  BsAccordionTabComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsAccordionTabComponent, deps: [{ token: i1.BsAccordionComponent }], target: i0.ɵɵFactoryTarget.Component });
22
- BsAccordionTabComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsAccordionTabComponent, selector: "bs-accordion-tab", ngImport: i0, template: "<div class=\"card\">\n <ng-content select=\"bs-accordion-tab-header\"></ng-content>\n <div class=\"card-block overflow-hidden\" [@slideUpDown]=\"(accordion.activeTab === this) ? 'down' : 'up'\">\n <ng-content></ng-content>\n </div>\n</div>", styles: [".card,.card-header,.card-block{border-radius:0}.card{margin-bottom:-1px}\n"], animations: [SlideUpDownAnimation] });
23
+ BsAccordionTabComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsAccordionTabComponent, selector: "bs-accordion-tab", ngImport: i0, template: "<div class=\"card\">\n <ng-content select=\"bs-accordion-tab-header\"></ng-content>\n <div class=\"card-block overflow-hidden\" [@slideUpDown] *ngIf=\"accordion.activeTab === this\">\n <ng-content></ng-content>\n </div>\n</div>", styles: [".card,.card-header,.card-block{border-radius:0}.card{margin-bottom:-1px}\n"], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], animations: [SlideUpDownAnimation] });
23
24
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsAccordionTabComponent, decorators: [{
24
25
  type: Component,
25
- args: [{ selector: 'bs-accordion-tab', animations: [SlideUpDownAnimation], template: "<div class=\"card\">\n <ng-content select=\"bs-accordion-tab-header\"></ng-content>\n <div class=\"card-block overflow-hidden\" [@slideUpDown]=\"(accordion.activeTab === this) ? 'down' : 'up'\">\n <ng-content></ng-content>\n </div>\n</div>", styles: [".card,.card-header,.card-block{border-radius:0}.card{margin-bottom:-1px}\n"] }]
26
+ args: [{ selector: 'bs-accordion-tab', animations: [SlideUpDownAnimation], template: "<div class=\"card\">\n <ng-content select=\"bs-accordion-tab-header\"></ng-content>\n <div class=\"card-block overflow-hidden\" [@slideUpDown] *ngIf=\"accordion.activeTab === this\">\n <ng-content></ng-content>\n </div>\n</div>", styles: [".card,.card-header,.card-block{border-radius:0}.card{margin-bottom:-1px}\n"] }]
26
27
  }], ctorParameters: function () { return [{ type: i1.BsAccordionComponent }]; } });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLXRhYi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9hY2NvcmRpb24vYWNjb3JkaW9uLXRhYi9hY2NvcmRpb24tdGFiLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL2FjY29yZGlvbi9hY2NvcmRpb24tdGFiL2FjY29yZGlvbi10YWIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDakUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7OztBQVF4RSxNQUFNLE9BQU8sdUJBQXVCO0lBR2xDLFlBQVksU0FBK0I7UUFDekMsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7SUFDN0IsQ0FBQztJQUVELFFBQVE7SUFDUixDQUFDO0lBRUQsYUFBYSxDQUFDLEtBQWlCO1FBQzdCLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLEtBQUssSUFBSSxFQUFFO1lBQ3JDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztTQUNqQzthQUFNO1lBQ0wsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1NBQ2pDO0lBQ0gsQ0FBQzs7b0hBaEJVLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLHdEQ1ZwQyxpUUFLTSxzR0RHUSxDQUFDLG9CQUFvQixDQUFDOzJGQUV2Qix1QkFBdUI7a0JBTm5DLFNBQVM7K0JBQ0Usa0JBQWtCLGNBR2hCLENBQUMsb0JBQW9CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNsaWRlVXBEb3duQW5pbWF0aW9uIH0gZnJvbSAnQG1pbnRwbGF5ZXIvbmctYW5pbWF0aW9ucyc7XG5pbXBvcnQgeyBCc0FjY29yZGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL2FjY29yZGlvbi9hY2NvcmRpb24uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYnMtYWNjb3JkaW9uLXRhYicsXG4gIHRlbXBsYXRlVXJsOiAnLi9hY2NvcmRpb24tdGFiLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYWNjb3JkaW9uLXRhYi5jb21wb25lbnQuc2NzcyddLFxuICBhbmltYXRpb25zOiBbU2xpZGVVcERvd25BbmltYXRpb25dXG59KVxuZXhwb3J0IGNsYXNzIEJzQWNjb3JkaW9uVGFiQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBhY2NvcmRpb246IEJzQWNjb3JkaW9uQ29tcG9uZW50O1xuICBjb25zdHJ1Y3RvcihhY2NvcmRpb246IEJzQWNjb3JkaW9uQ29tcG9uZW50KSB7XG4gICAgdGhpcy5hY2NvcmRpb24gPSBhY2NvcmRpb247XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgfVxuXG4gIGhlYWRlckNsaWNrZWQoZXZlbnQ6IE1vdXNlRXZlbnQpIHtcbiAgICBpZiAodGhpcy5hY2NvcmRpb24uYWN0aXZlVGFiID09PSB0aGlzKSB7XG4gICAgICB0aGlzLmFjY29yZGlvbi5hY3RpdmVUYWIgPSBudWxsO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmFjY29yZGlvbi5hY3RpdmVUYWIgPSB0aGlzO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImNhcmRcIj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJicy1hY2NvcmRpb24tdGFiLWhlYWRlclwiPjwvbmctY29udGVudD5cbiAgICA8ZGl2IGNsYXNzPVwiY2FyZC1ibG9jayBvdmVyZmxvdy1oaWRkZW5cIiBbQHNsaWRlVXBEb3duXT1cIihhY2NvcmRpb24uYWN0aXZlVGFiID09PSB0aGlzKSA/ICdkb3duJyA6ICd1cCdcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuPC9kaXY+Il19
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLXRhYi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9hY2NvcmRpb24vYWNjb3JkaW9uLXRhYi9hY2NvcmRpb24tdGFiLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL2FjY29yZGlvbi9hY2NvcmRpb24tdGFiL2FjY29yZGlvbi10YWIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDakUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7Ozs7QUFReEUsTUFBTSxPQUFPLHVCQUF1QjtJQUdsQyxZQUFZLFNBQStCO1FBQ3pDLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO0lBQzdCLENBQUM7SUFFRCxRQUFRO0lBQ1IsQ0FBQztJQUVELGFBQWEsQ0FBQyxLQUFpQjtRQUM3QixJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxLQUFLLElBQUksRUFBRTtZQUNyQyxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUM7U0FDakM7YUFBTTtZQUNMLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztTQUNqQztJQUNILENBQUM7O29IQWhCVSx1QkFBdUI7d0dBQXZCLHVCQUF1Qix3RENWcEMscVBBS00scU1ER1EsQ0FBQyxvQkFBb0IsQ0FBQzsyRkFFdkIsdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNFLGtCQUFrQixjQUdoQixDQUFDLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTbGlkZVVwRG93bkFuaW1hdGlvbiB9IGZyb20gJ0BtaW50cGxheWVyL25nLWFuaW1hdGlvbnMnO1xuaW1wb3J0IHsgQnNBY2NvcmRpb25Db21wb25lbnQgfSBmcm9tICcuLi9hY2NvcmRpb24vYWNjb3JkaW9uLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2JzLWFjY29yZGlvbi10YWInLFxuICB0ZW1wbGF0ZVVybDogJy4vYWNjb3JkaW9uLXRhYi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2FjY29yZGlvbi10YWIuY29tcG9uZW50LnNjc3MnXSxcbiAgYW5pbWF0aW9uczogW1NsaWRlVXBEb3duQW5pbWF0aW9uXVxufSlcbmV4cG9ydCBjbGFzcyBCc0FjY29yZGlvblRhYkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgYWNjb3JkaW9uOiBCc0FjY29yZGlvbkNvbXBvbmVudDtcbiAgY29uc3RydWN0b3IoYWNjb3JkaW9uOiBCc0FjY29yZGlvbkNvbXBvbmVudCkge1xuICAgIHRoaXMuYWNjb3JkaW9uID0gYWNjb3JkaW9uO1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gIH1cblxuICBoZWFkZXJDbGlja2VkKGV2ZW50OiBNb3VzZUV2ZW50KSB7XG4gICAgaWYgKHRoaXMuYWNjb3JkaW9uLmFjdGl2ZVRhYiA9PT0gdGhpcykge1xuICAgICAgdGhpcy5hY2NvcmRpb24uYWN0aXZlVGFiID0gbnVsbDtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5hY2NvcmRpb24uYWN0aXZlVGFiID0gdGhpcztcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJjYXJkXCI+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiYnMtYWNjb3JkaW9uLXRhYi1oZWFkZXJcIj48L25nLWNvbnRlbnQ+XG4gICAgPGRpdiBjbGFzcz1cImNhcmQtYmxvY2sgb3ZlcmZsb3ctaGlkZGVuXCIgW0BzbGlkZVVwRG93bl0gKm5nSWY9XCJhY2NvcmRpb24uYWN0aXZlVGFiID09PSB0aGlzXCI+XG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbjwvZGl2PiJdfQ==
@@ -12,6 +12,7 @@ export class BsAccordionTabHeaderComponent {
12
12
  ngOnInit() {
13
13
  }
14
14
  headerClicked(event) {
15
+ event.preventDefault();
15
16
  if (this.accordion.activeTab === this.accordionTab) {
16
17
  this.accordion.activeTab = null;
17
18
  }
@@ -19,11 +20,14 @@ export class BsAccordionTabHeaderComponent {
19
20
  this.accordion.activeTab = this.accordionTab;
20
21
  }
21
22
  }
23
+ foo(event) {
24
+ event.preventDefault();
25
+ }
22
26
  }
23
27
  BsAccordionTabHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsAccordionTabHeaderComponent, deps: [{ token: i1.BsAccordionTabComponent }, { token: i2.BsAccordionComponent }], target: i0.ɵɵFactoryTarget.Component });
24
- BsAccordionTabHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsAccordionTabHeaderComponent, selector: "bs-accordion-tab-header", ngImport: i0, template: "<div class=\"card-header cursor-pointer\" (click)=\"headerClicked($event)\">\n <ng-content></ng-content>\n</div>", styles: [""] });
28
+ BsAccordionTabHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsAccordionTabHeaderComponent, selector: "bs-accordion-tab-header", ngImport: i0, template: "<div class=\"card-header cursor-pointer\" (click)=\"headerClicked($event)\" (contextmenu)=\"foo($event)\">\n <ng-content></ng-content>\n</div>", styles: [""] });
25
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsAccordionTabHeaderComponent, decorators: [{
26
30
  type: Component,
27
- args: [{ selector: 'bs-accordion-tab-header', template: "<div class=\"card-header cursor-pointer\" (click)=\"headerClicked($event)\">\n <ng-content></ng-content>\n</div>", styles: [""] }]
31
+ args: [{ selector: 'bs-accordion-tab-header', template: "<div class=\"card-header cursor-pointer\" (click)=\"headerClicked($event)\" (contextmenu)=\"foo($event)\">\n <ng-content></ng-content>\n</div>", styles: [""] }]
28
32
  }], ctorParameters: function () { return [{ type: i1.BsAccordionTabComponent }, { type: i2.BsAccordionComponent }]; } });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLXRhYi1oZWFkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvYWNjb3JkaW9uL2FjY29yZGlvbi10YWItaGVhZGVyL2FjY29yZGlvbi10YWItaGVhZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL2FjY29yZGlvbi9hY2NvcmRpb24tdGFiLWhlYWRlci9hY2NvcmRpb24tdGFiLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDOzs7O0FBT3hFLE1BQU0sT0FBTyw2QkFBNkI7SUFFeEMsWUFBb0IsWUFBcUMsRUFBVSxTQUErQjtRQUE5RSxpQkFBWSxHQUFaLFlBQVksQ0FBeUI7UUFBVSxjQUFTLEdBQVQsU0FBUyxDQUFzQjtJQUNsRyxDQUFDO0lBRUQsUUFBUTtJQUNSLENBQUM7SUFFRCxhQUFhLENBQUMsS0FBaUI7UUFDN0IsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsS0FBSyxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ2xELElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQztTQUNqQzthQUFNO1lBQ0wsSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQztTQUM5QztJQUNILENBQUM7OzBIQWRVLDZCQUE2Qjs4R0FBN0IsNkJBQTZCLCtEQ1QxQyxxSEFFTTsyRkRPTyw2QkFBNkI7a0JBTHpDLFNBQVM7K0JBQ0UseUJBQXlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJzQWNjb3JkaW9uVGFiQ29tcG9uZW50IH0gZnJvbSAnLi4vYWNjb3JkaW9uLXRhYi9hY2NvcmRpb24tdGFiLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCc0FjY29yZGlvbkNvbXBvbmVudCB9IGZyb20gJy4uL2FjY29yZGlvbi9hY2NvcmRpb24uY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYnMtYWNjb3JkaW9uLXRhYi1oZWFkZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vYWNjb3JkaW9uLXRhYi1oZWFkZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9hY2NvcmRpb24tdGFiLWhlYWRlci5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEJzQWNjb3JkaW9uVGFiSGVhZGVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGFjY29yZGlvblRhYjogQnNBY2NvcmRpb25UYWJDb21wb25lbnQsIHByaXZhdGUgYWNjb3JkaW9uOiBCc0FjY29yZGlvbkNvbXBvbmVudCkge1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gIH1cblxuICBoZWFkZXJDbGlja2VkKGV2ZW50OiBNb3VzZUV2ZW50KSB7XG4gICAgaWYgKHRoaXMuYWNjb3JkaW9uLmFjdGl2ZVRhYiA9PT0gdGhpcy5hY2NvcmRpb25UYWIpIHtcbiAgICAgIHRoaXMuYWNjb3JkaW9uLmFjdGl2ZVRhYiA9IG51bGw7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuYWNjb3JkaW9uLmFjdGl2ZVRhYiA9IHRoaXMuYWNjb3JkaW9uVGFiO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImNhcmQtaGVhZGVyIGN1cnNvci1wb2ludGVyXCIgKGNsaWNrKT1cImhlYWRlckNsaWNrZWQoJGV2ZW50KVwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PiJdfQ==
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3JkaW9uLXRhYi1oZWFkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvYWNjb3JkaW9uL2FjY29yZGlvbi10YWItaGVhZGVyL2FjY29yZGlvbi10YWItaGVhZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL2FjY29yZGlvbi9hY2NvcmRpb24tdGFiLWhlYWRlci9hY2NvcmRpb24tdGFiLWhlYWRlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDOzs7O0FBT3hFLE1BQU0sT0FBTyw2QkFBNkI7SUFFeEMsWUFBb0IsWUFBcUMsRUFBVSxTQUErQjtRQUE5RSxpQkFBWSxHQUFaLFlBQVksQ0FBeUI7UUFBVSxjQUFTLEdBQVQsU0FBUyxDQUFzQjtJQUNsRyxDQUFDO0lBRUQsUUFBUTtJQUNSLENBQUM7SUFFRCxhQUFhLENBQUMsS0FBaUI7UUFDN0IsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZCLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxTQUFTLEtBQUssSUFBSSxDQUFDLFlBQVksRUFBRTtZQUNsRCxJQUFJLENBQUMsU0FBUyxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUM7U0FDakM7YUFBTTtZQUNMLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUM7U0FDOUM7SUFDSCxDQUFDO0lBRUQsR0FBRyxDQUFDLEtBQWlCO1FBQ25CLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztJQUN6QixDQUFDOzswSEFuQlUsNkJBQTZCOzhHQUE3Qiw2QkFBNkIsK0RDVDFDLG1KQUVNOzJGRE9PLDZCQUE2QjtrQkFMekMsU0FBUzsrQkFDRSx5QkFBeUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQnNBY2NvcmRpb25UYWJDb21wb25lbnQgfSBmcm9tICcuLi9hY2NvcmRpb24tdGFiL2FjY29yZGlvbi10YWIuY29tcG9uZW50JztcbmltcG9ydCB7IEJzQWNjb3JkaW9uQ29tcG9uZW50IH0gZnJvbSAnLi4vYWNjb3JkaW9uL2FjY29yZGlvbi5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdicy1hY2NvcmRpb24tdGFiLWhlYWRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9hY2NvcmRpb24tdGFiLWhlYWRlci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2FjY29yZGlvbi10YWItaGVhZGVyLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQnNBY2NvcmRpb25UYWJIZWFkZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgYWNjb3JkaW9uVGFiOiBCc0FjY29yZGlvblRhYkNvbXBvbmVudCwgcHJpdmF0ZSBhY2NvcmRpb246IEJzQWNjb3JkaW9uQ29tcG9uZW50KSB7XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgfVxuXG4gIGhlYWRlckNsaWNrZWQoZXZlbnQ6IE1vdXNlRXZlbnQpIHtcbiAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIGlmICh0aGlzLmFjY29yZGlvbi5hY3RpdmVUYWIgPT09IHRoaXMuYWNjb3JkaW9uVGFiKSB7XG4gICAgICB0aGlzLmFjY29yZGlvbi5hY3RpdmVUYWIgPSBudWxsO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmFjY29yZGlvbi5hY3RpdmVUYWIgPSB0aGlzLmFjY29yZGlvblRhYjtcbiAgICB9XG4gIH1cblxuICBmb28oZXZlbnQ6IE1vdXNlRXZlbnQpIHtcbiAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiY2FyZC1oZWFkZXIgY3Vyc29yLXBvaW50ZXJcIiAoY2xpY2spPVwiaGVhZGVyQ2xpY2tlZCgkZXZlbnQpXCIgKGNvbnRleHRtZW51KT1cImZvbygkZXZlbnQpXCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuPC9kaXY+Il19
@@ -1,5 +1,5 @@
1
1
  import { Component, Input } from '@angular/core';
2
- import { SlideUpDownAnimation, FadeInOutAnimation } from '@mintplayer/ng-animations';
2
+ import { FadeInOutAnimation } from '@mintplayer/ng-animations';
3
3
  import { Color } from '../../../enums';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
@@ -13,11 +13,11 @@ export class BsAlertComponent {
13
13
  }
14
14
  }
15
15
  BsAlertComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsAlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
16
- BsAlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsAlertComponent, selector: "bs-alert", inputs: { type: "type" }, ngImport: i0, template: "<div class=\"mb-3 overflow-hidden\" *ngIf=\"isVisible\" [@fadeInOut]>\n <div class=\"alert mb-0\" [ngClass]=\"'alert-' + colors[type]\">\n <ng-content></ng-content>\n </div>\n</div>", styles: ["::ng-deep .alert .btn{bottom:0;display:inline-flex;align-items:center}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [SlideUpDownAnimation, FadeInOutAnimation] });
16
+ BsAlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsAlertComponent, selector: "bs-alert", inputs: { type: "type" }, ngImport: i0, template: "<div class=\"mb-3 overflow-hidden\" *ngIf=\"isVisible\" [@fadeInOut]>\n <div class=\"alert mb-0\" [ngClass]=\"'alert-' + colors[type]\">\n <ng-content></ng-content>\n </div>\n</div>", styles: ["::ng-deep .alert .btn{bottom:0;display:inline-flex;align-items:center}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], animations: [FadeInOutAnimation] });
17
17
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsAlertComponent, decorators: [{
18
18
  type: Component,
19
- args: [{ selector: 'bs-alert', animations: [SlideUpDownAnimation, FadeInOutAnimation], template: "<div class=\"mb-3 overflow-hidden\" *ngIf=\"isVisible\" [@fadeInOut]>\n <div class=\"alert mb-0\" [ngClass]=\"'alert-' + colors[type]\">\n <ng-content></ng-content>\n </div>\n</div>", styles: ["::ng-deep .alert .btn{bottom:0;display:inline-flex;align-items:center}\n"] }]
19
+ args: [{ selector: 'bs-alert', animations: [FadeInOutAnimation], template: "<div class=\"mb-3 overflow-hidden\" *ngIf=\"isVisible\" [@fadeInOut]>\n <div class=\"alert mb-0\" [ngClass]=\"'alert-' + colors[type]\">\n <ng-content></ng-content>\n </div>\n</div>", styles: ["::ng-deep .alert .btn{bottom:0;display:inline-flex;align-items:center}\n"] }]
20
20
  }], ctorParameters: function () { return []; }, propDecorators: { type: [{
21
21
  type: Input
22
22
  }] } });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvYWxlcnQvYWxlcnQvYWxlcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvYWxlcnQvYWxlcnQvYWxlcnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBZSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDdEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLGtCQUFrQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDckYsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7QUFRdkMsTUFBTSxPQUFPLGdCQUFnQjtJQUUzQjtRQU1nQixTQUFJLEdBQVUsS0FBSyxDQUFDLE9BQU8sQ0FBQztRQUM1QyxXQUFNLEdBQUcsS0FBSyxDQUFDO1FBRWYsY0FBUyxHQUFZLElBQUksQ0FBQztJQVIxQixDQUFDO0lBRUQsUUFBUTtJQUNSLENBQUM7OzZHQU5VLGdCQUFnQjtpR0FBaEIsZ0JBQWdCLDBFQ1Y3QixvTUFJTSw4UURJUSxDQUFFLG9CQUFvQixFQUFFLGtCQUFrQixDQUFFOzJGQUU3QyxnQkFBZ0I7a0JBTjVCLFNBQVM7K0JBQ0UsVUFBVSxjQUdSLENBQUUsb0JBQW9CLEVBQUUsa0JBQWtCLENBQUU7MEVBVXhDLElBQUk7c0JBQW5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTbGlkZVVwRG93bkFuaW1hdGlvbiwgRmFkZUluT3V0QW5pbWF0aW9uIH0gZnJvbSAnQG1pbnRwbGF5ZXIvbmctYW5pbWF0aW9ucyc7XG5pbXBvcnQgeyBDb2xvciB9IGZyb20gJy4uLy4uLy4uL2VudW1zJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYnMtYWxlcnQnLFxuICB0ZW1wbGF0ZVVybDogJy4vYWxlcnQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9hbGVydC5jb21wb25lbnQuc2NzcyddLFxuICBhbmltYXRpb25zOiBbIFNsaWRlVXBEb3duQW5pbWF0aW9uLCBGYWRlSW5PdXRBbmltYXRpb24gXVxufSlcbmV4cG9ydCBjbGFzcyBCc0FsZXJ0Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbiAgQElucHV0KCkgcHVibGljIHR5cGU6IENvbG9yID0gQ29sb3IucHJpbWFyeTtcbiAgY29sb3JzID0gQ29sb3I7XG5cbiAgaXNWaXNpYmxlOiBib29sZWFuID0gdHJ1ZTtcbn1cbiIsIjxkaXYgY2xhc3M9XCJtYi0zIG92ZXJmbG93LWhpZGRlblwiICpuZ0lmPVwiaXNWaXNpYmxlXCIgW0BmYWRlSW5PdXRdPlxuICAgIDxkaXYgY2xhc3M9XCJhbGVydCBtYi0wXCIgW25nQ2xhc3NdPVwiJ2FsZXJ0LScgKyBjb2xvcnNbdHlwZV1cIj5cbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuPC9kaXY+Il19
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvYWxlcnQvYWxlcnQvYWxlcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvYWxlcnQvYWxlcnQvYWxlcnQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDL0QsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7QUFRdkMsTUFBTSxPQUFPLGdCQUFnQjtJQUUzQjtRQU1nQixTQUFJLEdBQVUsS0FBSyxDQUFDLE9BQU8sQ0FBQztRQUM1QyxXQUFNLEdBQUcsS0FBSyxDQUFDO1FBRWYsY0FBUyxHQUFZLElBQUksQ0FBQztJQVIxQixDQUFDO0lBRUQsUUFBUTtJQUNSLENBQUM7OzZHQU5VLGdCQUFnQjtpR0FBaEIsZ0JBQWdCLDBFQ1Y3QixvTUFJTSw4UURJUSxDQUFFLGtCQUFrQixDQUFFOzJGQUV2QixnQkFBZ0I7a0JBTjVCLFNBQVM7K0JBQ0UsVUFBVSxjQUdSLENBQUUsa0JBQWtCLENBQUU7MEVBVWxCLElBQUk7c0JBQW5CLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZhZGVJbk91dEFuaW1hdGlvbiB9IGZyb20gJ0BtaW50cGxheWVyL25nLWFuaW1hdGlvbnMnO1xuaW1wb3J0IHsgQ29sb3IgfSBmcm9tICcuLi8uLi8uLi9lbnVtcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2JzLWFsZXJ0JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2FsZXJ0LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYWxlcnQuY29tcG9uZW50LnNjc3MnXSxcbiAgYW5pbWF0aW9uczogWyBGYWRlSW5PdXRBbmltYXRpb24gXVxufSlcbmV4cG9ydCBjbGFzcyBCc0FsZXJ0Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbiAgQElucHV0KCkgcHVibGljIHR5cGU6IENvbG9yID0gQ29sb3IucHJpbWFyeTtcbiAgY29sb3JzID0gQ29sb3I7XG5cbiAgaXNWaXNpYmxlOiBib29sZWFuID0gdHJ1ZTtcbn1cbiIsIjxkaXYgY2xhc3M9XCJtYi0zIG92ZXJmbG93LWhpZGRlblwiICpuZ0lmPVwiaXNWaXNpYmxlXCIgW0BmYWRlSW5PdXRdPlxuICAgIDxkaXYgY2xhc3M9XCJhbGVydCBtYi0wXCIgW25nQ2xhc3NdPVwiJ2FsZXJ0LScgKyBjb2xvcnNbdHlwZV1cIj5cbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuPC9kaXY+Il19
@@ -1,4 +1,5 @@
1
- import { Component } from '@angular/core';
1
+ import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { BehaviorSubject, filter, map, Subject, take, takeUntil } from 'rxjs';
2
3
  import { BsCalendarMonthService } from '../../services/calendar-month/calendar-month.service';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "../../services/calendar-month/calendar-month.service";
@@ -6,56 +7,98 @@ import * as i2 from "@angular/common";
6
7
  import * as i3 from "../../pipes/uc-first/uc-first.pipe";
7
8
  import * as i4 from "../../pipes/month-name/month-name.pipe";
8
9
  export class BsCalendarComponent {
9
- constructor(calendarMonthService) {
10
+ constructor(calendarMonthService, ref) {
10
11
  this.calendarMonthService = calendarMonthService;
11
- this.daysOfWeek = ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'];
12
+ this.ref = ref;
13
+ this.destroyed$ = new Subject();
14
+ //#region CurrentMonth
15
+ this.currentMonth$ = new BehaviorSubject(new Date());
16
+ this.currentMonthChange = new EventEmitter();
17
+ //#endregion
12
18
  //#region SelectedDate
13
- this.selectedDate = new Date();
19
+ this.selectedDate$ = new BehaviorSubject(new Date());
20
+ this.selectedDateChange = new EventEmitter();
14
21
  //#endregion
15
- //#region Weeks
16
- this._weeks = [];
22
+ this.daysOfWeek = ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'];
23
+ this.weeks$ = this.currentMonth$
24
+ .pipe(map((month) => this.calendarMonthService.getWeeks(month)))
25
+ .pipe(takeUntil(this.destroyed$));
26
+ this.daysOfWeek$ = this.weeks$
27
+ .pipe(filter((weeks) => weeks.length > 1))
28
+ .pipe(map((weeks) => weeks[1].week))
29
+ .pipe(map((week) => {
30
+ const firstDay = week[0];
31
+ if (firstDay) {
32
+ return week.map((d) => {
33
+ const date = new Date(firstDay.date.getFullYear(), firstDay.date.getMonth(), d?.dayOfMonth);
34
+ return date.toLocaleString('default', { weekday: 'short' });
35
+ });
36
+ }
37
+ else {
38
+ return [];
39
+ }
40
+ }));
41
+ this.selectedDate$.pipe(takeUntil(this.destroyed$)).subscribe((date) => {
42
+ this.selectedDateChange.emit(date);
43
+ });
44
+ this.currentMonth$.pipe(takeUntil(this.destroyed$)).subscribe((month) => {
45
+ this.currentMonthChange.emit(month);
46
+ });
17
47
  }
18
- ngOnInit() {
19
- this.month = new Date();
48
+ get currentMonth() {
49
+ return this.currentMonth$.value;
20
50
  }
21
- get month() {
22
- return this._month;
51
+ set currentMonth(value) {
52
+ this.currentMonth$.next(value);
23
53
  }
24
- set month(value) {
25
- this._month = value;
26
- this.weeks = this.calendarMonthService.getWeeks(this.month);
54
+ get selectedDate() {
55
+ return this.selectedDate$.value;
27
56
  }
28
- get weeks() {
29
- return this._weeks;
57
+ set selectedDate(value) {
58
+ this.selectedDate$.next(value);
30
59
  }
31
- set weeks(value) {
32
- this._weeks = value;
33
- if (this._weeks.length > 1) {
34
- this.daysOfWeek = this._weeks[1].week.map(d => {
35
- let date = new Date(this.month.getFullYear(), this.month.getMonth(), d?.dayOfMonth);
36
- return date.toLocaleString("default", { weekday: 'short' });
37
- });
38
- }
60
+ ngOnDestroy() {
61
+ this.destroyed$.next(true);
39
62
  }
40
- //#endregion
41
63
  previousMonth() {
42
- this.month = new Date(this.month.getFullYear(), this.month.getMonth() - 1, 1);
64
+ this.currentMonth$.pipe(take(1)).subscribe((month) => {
65
+ this.currentMonth$.next(new Date(month.getFullYear(), month.getMonth() - 1, 1));
66
+ });
43
67
  return false;
44
68
  }
45
69
  nextMonth() {
46
- this.month = new Date(this.month.getFullYear(), this.month.getMonth() + 1, 1);
70
+ this.currentMonth$.pipe(take(1)).subscribe((month) => {
71
+ this.currentMonth$.next(new Date(month.getFullYear(), month.getMonth() + 1, 1));
72
+ });
47
73
  return false;
48
74
  }
49
75
  isSameDate(date1, date2) {
50
- return (date1.getFullYear() === date2.getFullYear())
51
- && (date1.getMonth() === date2.getMonth())
52
- && (date1.getDate() === date2.getDate());
76
+ if (date1 === null && date2 === null)
77
+ return true;
78
+ if (date1 === null || date2 === null)
79
+ return false;
80
+ return (date1.getFullYear() === date2.getFullYear() &&
81
+ date1.getMonth() === date2.getMonth() &&
82
+ date1.getDate() === date2.getDate());
83
+ }
84
+ goto(day) {
85
+ if (day) {
86
+ this.selectedDate$.next(day.date);
87
+ }
53
88
  }
54
89
  }
55
- BsCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsCalendarComponent, deps: [{ token: i1.BsCalendarMonthService }], target: i0.ɵɵFactoryTarget.Component });
56
- BsCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsCalendarComponent, selector: "bs-calendar", ngImport: i0, template: "<table class=\"table w-auto\">\n <tr>\n <td>\n <button class=\"btn btn-default\" (click)=\"previousMonth()\">\n <i class=\"bi bi-chevron-left fw-bolder\"></i>\n </button>\n </td>\n <td colspan=\"6\" class=\"fw-bolder\">\n {{ month | monthName | ucFirst }}\n {{ month.getFullYear() }}\n </td>\n <td>\n <button class=\"btn btn-default border-bottom-0\" (click)=\"nextMonth()\">\n <i class=\"bi bi-chevron-right fw-bolder\"></i>\n </button>\n </td>\n </tr>\n <tr>\n <th></th>\n <th *ngFor=\"let dayOfWeek of daysOfWeek\">\n {{ dayOfWeek }}\n </th>\n </tr>\n <tr *ngFor=\"let week of weeks\">\n <th>\n {{ week.number }}\n </th>\n <td [class.selected]=\"day === null ? false : isSameDate(selectedDate, day.date)\" *ngFor=\"let day of week.week\" (click)=\"day && selectedDate = day.date\">\n <span *ngIf=\"day !== null\">{{ day.dayOfMonth }}</span>\n </td>\n </tr>\n</table>", styles: ["table{border-collapse:collapse;border:1px solid rgba(0,0,0,.125)}table td,table th{width:40px;height:40px;text-align:center}table td span,table th span{cursor:pointer;white-space:nowrap}table td.selected{background-color:#0d6efd;color:#fff}table th{background-color:#f8f9fa}table tr{border-top:none}table tr:first-child>td{border-bottom:1px solid rgba(0,0,0,.125)}table tr:nth-of-type(2)>th:not(:nth-of-type(1)){border-bottom:1px solid rgba(0,0,0,.125)}table tr:not(:nth-of-type(2))>th:nth-of-type(1){border-right:1px solid rgba(0,0,0,.125)}\n"], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "ucFirst": i3.UcFirstPipe, "monthName": i4.MonthNamePipe } });
90
+ BsCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsCalendarComponent, deps: [{ token: i1.BsCalendarMonthService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
91
+ BsCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsCalendarComponent, selector: "bs-calendar", inputs: { currentMonth: "currentMonth", selectedDate: "selectedDate" }, outputs: { currentMonthChange: "currentMonthChange", selectedDateChange: "selectedDateChange" }, ngImport: i0, template: "<table class=\"table w-auto mb-0\">\n <tr>\n <td>\n <button class=\"btn btn-default\" (click)=\"previousMonth()\">\n <i class=\"bi bi-chevron-left fw-bolder\"></i>\n </button>\n </td>\n <td colspan=\"6\" class=\"fw-bolder\">\n {{ currentMonth$ | async | monthName | ucFirst }}\n {{ (currentMonth$ | async)?.getFullYear() }}\n </td>\n <td>\n <button class=\"btn btn-default border-bottom-0\" (click)=\"nextMonth()\">\n <i class=\"bi bi-chevron-right fw-bolder\"></i>\n </button>\n </td>\n </tr>\n <tr>\n <th></th>\n <th *ngFor=\"let dayOfWeek of daysOfWeek\">\n {{ dayOfWeek }}\n </th>\n </tr>\n <tr *ngFor=\"let week of (weeks$ | async)\">\n <th>\n {{ week.number }}\n </th>\n <td [class.selected]=\"day === null ? false : isSameDate(selectedDate$ | async, day.date)\" *ngFor=\"let day of week.week\" (click)=\"goto(day)\">\n <span *ngIf=\"day !== null\">{{ day.dayOfMonth }}</span>\n </td>\n </tr>\n</table>", styles: ["table{border-collapse:collapse;border:1px solid rgba(0,0,0,.125);background:#fff}table td,table th{width:40px;height:40px;text-align:center}table td span,table th span{cursor:pointer;white-space:nowrap}table td.selected{background-color:#0d6efd;color:#fff}table th{background-color:#f8f9fa}table tr{border-top:none}table tr:first-child>td{border-bottom:1px solid rgba(0,0,0,.125)}table tr:nth-of-type(2)>th:not(:nth-of-type(1)){border-bottom:1px solid rgba(0,0,0,.125)}table tr:not(:nth-of-type(2))>th:nth-of-type(1){border-right:1px solid rgba(0,0,0,.125)}\n"], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "ucFirst": i3.UcFirstPipe, "monthName": i4.MonthNamePipe, "async": i2.AsyncPipe } });
57
92
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsCalendarComponent, decorators: [{
58
93
  type: Component,
59
- args: [{ selector: 'bs-calendar', template: "<table class=\"table w-auto\">\n <tr>\n <td>\n <button class=\"btn btn-default\" (click)=\"previousMonth()\">\n <i class=\"bi bi-chevron-left fw-bolder\"></i>\n </button>\n </td>\n <td colspan=\"6\" class=\"fw-bolder\">\n {{ month | monthName | ucFirst }}\n {{ month.getFullYear() }}\n </td>\n <td>\n <button class=\"btn btn-default border-bottom-0\" (click)=\"nextMonth()\">\n <i class=\"bi bi-chevron-right fw-bolder\"></i>\n </button>\n </td>\n </tr>\n <tr>\n <th></th>\n <th *ngFor=\"let dayOfWeek of daysOfWeek\">\n {{ dayOfWeek }}\n </th>\n </tr>\n <tr *ngFor=\"let week of weeks\">\n <th>\n {{ week.number }}\n </th>\n <td [class.selected]=\"day === null ? false : isSameDate(selectedDate, day.date)\" *ngFor=\"let day of week.week\" (click)=\"day && selectedDate = day.date\">\n <span *ngIf=\"day !== null\">{{ day.dayOfMonth }}</span>\n </td>\n </tr>\n</table>", styles: ["table{border-collapse:collapse;border:1px solid rgba(0,0,0,.125)}table td,table th{width:40px;height:40px;text-align:center}table td span,table th span{cursor:pointer;white-space:nowrap}table td.selected{background-color:#0d6efd;color:#fff}table th{background-color:#f8f9fa}table tr{border-top:none}table tr:first-child>td{border-bottom:1px solid rgba(0,0,0,.125)}table tr:nth-of-type(2)>th:not(:nth-of-type(1)){border-bottom:1px solid rgba(0,0,0,.125)}table tr:not(:nth-of-type(2))>th:nth-of-type(1){border-right:1px solid rgba(0,0,0,.125)}\n"] }]
60
- }], ctorParameters: function () { return [{ type: i1.BsCalendarMonthService }]; } });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvY2FsZW5kYXIvY2FsZW5kYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvY2FsZW5kYXIvY2FsZW5kYXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUVsRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQzs7Ozs7O0FBTzlGLE1BQU0sT0FBTyxtQkFBbUI7SUFFOUIsWUFBb0Isb0JBQTRDO1FBQTVDLHlCQUFvQixHQUFwQixvQkFBb0IsQ0FBd0I7UUFHaEUsZUFBVSxHQUFhLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFLbEUsc0JBQXNCO1FBQ3RCLGlCQUFZLEdBQVMsSUFBSSxJQUFJLEVBQUUsQ0FBQztRQVdoQyxZQUFZO1FBQ1osZUFBZTtRQUNQLFdBQU0sR0FBVyxFQUFFLENBQUE7SUFyQjNCLENBQUM7SUFHRCxRQUFRO1FBQ04sSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFPRCxJQUFXLEtBQUs7UUFDZCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDckIsQ0FBQztJQUNELElBQVcsS0FBSyxDQUFDLEtBQVc7UUFDMUIsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7UUFDcEIsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsb0JBQW9CLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBSUQsSUFBSSxLQUFLO1FBQ1AsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3JCLENBQUM7SUFDRCxJQUFJLEtBQUssQ0FBQyxLQUFhO1FBQ3JCLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQzFCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFO2dCQUM1QyxJQUFJLElBQUksR0FBRyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsRUFBRSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxFQUFFLFVBQVUsQ0FBQyxDQUFDO2dCQUNwRixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUMsU0FBUyxFQUFFLEVBQUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxDQUFDLENBQUM7WUFDOUQsQ0FBQyxDQUFDLENBQUM7U0FDSjtJQUNILENBQUM7SUFDRCxZQUFZO0lBRVosYUFBYTtRQUNYLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQUUsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUM5RSxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFFRCxTQUFTO1FBQ1AsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsRUFBRSxFQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQzlFLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELFVBQVUsQ0FBQyxLQUFXLEVBQUUsS0FBVztRQUNqQyxPQUFPLENBQUMsS0FBSyxDQUFDLFdBQVcsRUFBRSxLQUFLLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQztlQUMvQyxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsS0FBSyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7ZUFDdkMsQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLEtBQUssS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUM7SUFDN0MsQ0FBQzs7Z0hBckRVLG1CQUFtQjtvR0FBbkIsbUJBQW1CLG1EQ1RoQyxxbENBK0JROzJGRHRCSyxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0UsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBXZWVrIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy93ZWVrJztcbmltcG9ydCB7IEJzQ2FsZW5kYXJNb250aFNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9jYWxlbmRhci1tb250aC9jYWxlbmRhci1tb250aC5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYnMtY2FsZW5kYXInLFxuICB0ZW1wbGF0ZVVybDogJy4vY2FsZW5kYXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jYWxlbmRhci5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEJzQ2FsZW5kYXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2FsZW5kYXJNb250aFNlcnZpY2U6IEJzQ2FsZW5kYXJNb250aFNlcnZpY2UpIHtcbiAgfVxuXG4gIGRheXNPZldlZWs6IHN0cmluZ1tdID0gWydNbycsICdUdScsICdXZScsICdUaCcsICdGcicsICdTYScsICdTdSddO1xuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLm1vbnRoID0gbmV3IERhdGUoKTtcbiAgfVxuXG4gIC8vI3JlZ2lvbiBTZWxlY3RlZERhdGVcbiAgc2VsZWN0ZWREYXRlOiBEYXRlID0gbmV3IERhdGUoKTtcbiAgLy8jZW5kcmVnaW9uXG4gIC8vI3JlZ2lvbiBNb250aFxuICBwcml2YXRlIF9tb250aCE6IERhdGU7XG4gIHB1YmxpYyBnZXQgbW9udGgoKSB7XG4gICAgcmV0dXJuIHRoaXMuX21vbnRoO1xuICB9XG4gIHB1YmxpYyBzZXQgbW9udGgodmFsdWU6IERhdGUpIHtcbiAgICB0aGlzLl9tb250aCA9IHZhbHVlO1xuICAgIHRoaXMud2Vla3MgPSB0aGlzLmNhbGVuZGFyTW9udGhTZXJ2aWNlLmdldFdlZWtzKHRoaXMubW9udGgpO1xuICB9XG4gIC8vI2VuZHJlZ2lvblxuICAvLyNyZWdpb24gV2Vla3NcbiAgcHJpdmF0ZSBfd2Vla3M6IFdlZWtbXSA9IFtdXG4gIGdldCB3ZWVrcygpIHtcbiAgICByZXR1cm4gdGhpcy5fd2Vla3M7XG4gIH1cbiAgc2V0IHdlZWtzKHZhbHVlOiBXZWVrW10pIHtcbiAgICB0aGlzLl93ZWVrcyA9IHZhbHVlO1xuICAgIGlmICh0aGlzLl93ZWVrcy5sZW5ndGggPiAxKSB7XG4gICAgICB0aGlzLmRheXNPZldlZWsgPSB0aGlzLl93ZWVrc1sxXS53ZWVrLm1hcChkID0+IHtcbiAgICAgICAgbGV0IGRhdGUgPSBuZXcgRGF0ZSh0aGlzLm1vbnRoLmdldEZ1bGxZZWFyKCksIHRoaXMubW9udGguZ2V0TW9udGgoKSwgZD8uZGF5T2ZNb250aCk7XG4gICAgICAgIHJldHVybiBkYXRlLnRvTG9jYWxlU3RyaW5nKFwiZGVmYXVsdFwiLCB7IHdlZWtkYXk6ICdzaG9ydCcgfSk7XG4gICAgICB9KTtcbiAgICB9XG4gIH1cbiAgLy8jZW5kcmVnaW9uXG5cbiAgcHJldmlvdXNNb250aCgpIHtcbiAgICB0aGlzLm1vbnRoID0gbmV3IERhdGUodGhpcy5tb250aC5nZXRGdWxsWWVhcigpLCB0aGlzLm1vbnRoLmdldE1vbnRoKCkgLSAxLCAxKTtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBuZXh0TW9udGgoKSB7XG4gICAgdGhpcy5tb250aCA9IG5ldyBEYXRlKHRoaXMubW9udGguZ2V0RnVsbFllYXIoKSwgdGhpcy5tb250aC5nZXRNb250aCgpICsgMSwgMSk7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgaXNTYW1lRGF0ZShkYXRlMTogRGF0ZSwgZGF0ZTI6IERhdGUpIHtcbiAgICByZXR1cm4gKGRhdGUxLmdldEZ1bGxZZWFyKCkgPT09IGRhdGUyLmdldEZ1bGxZZWFyKCkpXG4gICAgICAmJiAoZGF0ZTEuZ2V0TW9udGgoKSA9PT0gZGF0ZTIuZ2V0TW9udGgoKSlcbiAgICAgICYmIChkYXRlMS5nZXREYXRlKCkgPT09IGRhdGUyLmdldERhdGUoKSk7XG4gIH1cbn1cbiIsIjx0YWJsZSBjbGFzcz1cInRhYmxlIHctYXV0b1wiPlxuICAgIDx0cj5cbiAgICAgICAgPHRkPlxuICAgICAgICAgICAgPGJ1dHRvbiBjbGFzcz1cImJ0biBidG4tZGVmYXVsdFwiIChjbGljayk9XCJwcmV2aW91c01vbnRoKClcIj5cbiAgICAgICAgICAgICAgICA8aSBjbGFzcz1cImJpIGJpLWNoZXZyb24tbGVmdCBmdy1ib2xkZXJcIj48L2k+XG4gICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPC90ZD5cbiAgICAgICAgPHRkIGNvbHNwYW49XCI2XCIgY2xhc3M9XCJmdy1ib2xkZXJcIj5cbiAgICAgICAgICAgIHt7IG1vbnRoIHwgbW9udGhOYW1lIHwgdWNGaXJzdCB9fVxuICAgICAgICAgICAge3sgbW9udGguZ2V0RnVsbFllYXIoKSB9fVxuICAgICAgICA8L3RkPlxuICAgICAgICA8dGQ+XG4gICAgICAgICAgICA8YnV0dG9uIGNsYXNzPVwiYnRuIGJ0bi1kZWZhdWx0IGJvcmRlci1ib3R0b20tMFwiIChjbGljayk9XCJuZXh0TW9udGgoKVwiPlxuICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiYmkgYmktY2hldnJvbi1yaWdodCBmdy1ib2xkZXJcIj48L2k+XG4gICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPC90ZD5cbiAgICA8L3RyPlxuICAgIDx0cj5cbiAgICAgICAgPHRoPjwvdGg+XG4gICAgICAgIDx0aCAqbmdGb3I9XCJsZXQgZGF5T2ZXZWVrIG9mIGRheXNPZldlZWtcIj5cbiAgICAgICAgICAgIHt7IGRheU9mV2VlayB9fVxuICAgICAgICA8L3RoPlxuICAgIDwvdHI+XG4gICAgPHRyICpuZ0Zvcj1cImxldCB3ZWVrIG9mIHdlZWtzXCI+XG4gICAgICAgIDx0aD5cbiAgICAgICAgICAgIHt7IHdlZWsubnVtYmVyIH19XG4gICAgICAgIDwvdGg+XG4gICAgICAgIDx0ZCBbY2xhc3Muc2VsZWN0ZWRdPVwiZGF5ID09PSBudWxsID8gZmFsc2UgOiBpc1NhbWVEYXRlKHNlbGVjdGVkRGF0ZSwgZGF5LmRhdGUpXCIgKm5nRm9yPVwibGV0IGRheSBvZiB3ZWVrLndlZWtcIiAoY2xpY2spPVwiZGF5ICYmIHNlbGVjdGVkRGF0ZSA9IGRheS5kYXRlXCI+XG4gICAgICAgICAgICA8c3BhbiAqbmdJZj1cImRheSAhPT0gbnVsbFwiPnt7IGRheS5kYXlPZk1vbnRoIH19PC9zcGFuPlxuICAgICAgICA8L3RkPlxuICAgIDwvdHI+XG48L3RhYmxlPiJdfQ==
94
+ args: [{ selector: 'bs-calendar', template: "<table class=\"table w-auto mb-0\">\n <tr>\n <td>\n <button class=\"btn btn-default\" (click)=\"previousMonth()\">\n <i class=\"bi bi-chevron-left fw-bolder\"></i>\n </button>\n </td>\n <td colspan=\"6\" class=\"fw-bolder\">\n {{ currentMonth$ | async | monthName | ucFirst }}\n {{ (currentMonth$ | async)?.getFullYear() }}\n </td>\n <td>\n <button class=\"btn btn-default border-bottom-0\" (click)=\"nextMonth()\">\n <i class=\"bi bi-chevron-right fw-bolder\"></i>\n </button>\n </td>\n </tr>\n <tr>\n <th></th>\n <th *ngFor=\"let dayOfWeek of daysOfWeek\">\n {{ dayOfWeek }}\n </th>\n </tr>\n <tr *ngFor=\"let week of (weeks$ | async)\">\n <th>\n {{ week.number }}\n </th>\n <td [class.selected]=\"day === null ? false : isSameDate(selectedDate$ | async, day.date)\" *ngFor=\"let day of week.week\" (click)=\"goto(day)\">\n <span *ngIf=\"day !== null\">{{ day.dayOfMonth }}</span>\n </td>\n </tr>\n</table>", styles: ["table{border-collapse:collapse;border:1px solid rgba(0,0,0,.125);background:#fff}table td,table th{width:40px;height:40px;text-align:center}table td span,table th span{cursor:pointer;white-space:nowrap}table td.selected{background-color:#0d6efd;color:#fff}table th{background-color:#f8f9fa}table tr{border-top:none}table tr:first-child>td{border-bottom:1px solid rgba(0,0,0,.125)}table tr:nth-of-type(2)>th:not(:nth-of-type(1)){border-bottom:1px solid rgba(0,0,0,.125)}table tr:not(:nth-of-type(2))>th:nth-of-type(1){border-right:1px solid rgba(0,0,0,.125)}\n"] }]
95
+ }], ctorParameters: function () { return [{ type: i1.BsCalendarMonthService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { currentMonthChange: [{
96
+ type: Output
97
+ }], currentMonth: [{
98
+ type: Input
99
+ }], selectedDateChange: [{
100
+ type: Output
101
+ }], selectedDate: [{
102
+ type: Input
103
+ }] } });
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.component.js","sourceRoot":"","sources":["../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/calendar/calendar.component.ts","../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/calendar/calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { BehaviorSubject, filter, map, Observable, Subject, take, takeUntil } from 'rxjs';\nimport { DateDayOfMonth } from '../../interfaces/date-day-of-month';\nimport { Week } from '../../interfaces/week';\nimport { BsCalendarMonthService } from '../../services/calendar-month/calendar-month.service';\n\n@Component({\n  selector: 'bs-calendar',\n  templateUrl: './calendar.component.html',\n  styleUrls: ['./calendar.component.scss'],\n})\nexport class BsCalendarComponent implements OnDestroy {\n  constructor(\n    private calendarMonthService: BsCalendarMonthService,\n    private ref: ChangeDetectorRef\n  ) {\n    this.weeks$ = this.currentMonth$\n      .pipe(map((month) => this.calendarMonthService.getWeeks(month)))\n      .pipe(takeUntil(this.destroyed$));\n    this.daysOfWeek$ = this.weeks$\n      .pipe(filter((weeks) => weeks.length > 1))\n      .pipe(map((weeks) => weeks[1].week))\n      .pipe(\n        map((week) => {\n          const firstDay = week[0];\n          if (firstDay) {\n            return week.map((d) => {\n              const date = new Date(\n                firstDay.date.getFullYear(),\n                firstDay.date.getMonth(),\n                d?.dayOfMonth\n              );\n              return date.toLocaleString('default', { weekday: 'short' });\n            });\n          } else {\n            return [];\n          }\n        })\n      );\n    this.selectedDate$.pipe(takeUntil(this.destroyed$)).subscribe((date) => {\n      this.selectedDateChange.emit(date);\n    });\n    this.currentMonth$.pipe(takeUntil(this.destroyed$)).subscribe((month) => {\n      this.currentMonthChange.emit(month);\n    });\n  }\n\n  private destroyed$ = new Subject();\n  weeks$: Observable<Week[]>;\n  daysOfWeek$: Observable<string[]>;\n\n  //#region CurrentMonth\n  currentMonth$ = new BehaviorSubject<Date>(new Date());\n  @Output() public currentMonthChange = new EventEmitter<Date>();\n  get currentMonth() {\n    return this.currentMonth$.value;\n  }\n  @Input() set currentMonth(value: Date) {\n    this.currentMonth$.next(value);\n  }\n  //#endregion\n  //#region SelectedDate\n  selectedDate$ = new BehaviorSubject<Date>(new Date());\n  @Output() public selectedDateChange = new EventEmitter<Date>();\n  get selectedDate() {\n    return this.selectedDate$.value;\n  }\n  @Input() set selectedDate(value: Date) {\n    this.selectedDate$.next(value);\n  }\n  //#endregion\n\n  daysOfWeek: string[] = ['Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa', 'Su'];\n\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n\n  previousMonth() {\n    this.currentMonth$.pipe(take(1)).subscribe((month) => {\n      this.currentMonth$.next(\n        new Date(month.getFullYear(), month.getMonth() - 1, 1)\n      );\n    });\n\n    return false;\n  }\n\n  nextMonth() {\n    this.currentMonth$.pipe(take(1)).subscribe((month) => {\n      this.currentMonth$.next(\n        new Date(month.getFullYear(), month.getMonth() + 1, 1)\n      );\n    });\n\n    return false;\n  }\n\n  isSameDate(date1: Date | null, date2: Date | null) {\n    if (date1 === null && date2 === null) return true;\n    if (date1 === null || date2 === null) return false;\n\n    return (\n      date1.getFullYear() === date2.getFullYear() &&\n      date1.getMonth() === date2.getMonth() &&\n      date1.getDate() === date2.getDate()\n    );\n  }\n\n  goto(day: DateDayOfMonth | null) {\n    if (day) {\n      this.selectedDate$.next(day.date);\n    }\n  }\n}\n","<table class=\"table w-auto mb-0\">\n    <tr>\n        <td>\n            <button class=\"btn btn-default\" (click)=\"previousMonth()\">\n                <i class=\"bi bi-chevron-left fw-bolder\"></i>\n            </button>\n        </td>\n        <td colspan=\"6\" class=\"fw-bolder\">\n            {{ currentMonth$ | async | monthName | ucFirst }}\n            {{ (currentMonth$ | async)?.getFullYear() }}\n        </td>\n        <td>\n            <button class=\"btn btn-default border-bottom-0\" (click)=\"nextMonth()\">\n                <i class=\"bi bi-chevron-right fw-bolder\"></i>\n            </button>\n        </td>\n    </tr>\n    <tr>\n        <th></th>\n        <th *ngFor=\"let dayOfWeek of daysOfWeek\">\n            {{ dayOfWeek }}\n        </th>\n    </tr>\n    <tr *ngFor=\"let week of (weeks$ | async)\">\n        <th>\n            {{ week.number }}\n        </th>\n        <td [class.selected]=\"day === null ? false : isSameDate(selectedDate$ | async, day.date)\" *ngFor=\"let day of week.week\" (click)=\"goto(day)\">\n            <span *ngIf=\"day !== null\">{{ day.dayOfMonth }}</span>\n        </td>\n    </tr>\n</table>"]}
@@ -6,7 +6,6 @@ export class BsCardComponent {
6
6
  ngOnInit() {
7
7
  }
8
8
  ngAfterViewInit() {
9
- // console.log('header', this.header);
10
9
  }
11
10
  }
12
11
  BsCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
@@ -15,4 +14,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
15
14
  type: Component,
16
15
  args: [{ selector: 'bs-card', template: "<div class=\"card\" style=\"width: 18rem;\">\n <ng-content select=\"bs-card-header\"></ng-content>\n <div class=\"card-block\">\n <ng-content></ng-content>\n </div>\n</div>", styles: [".card-block{margin:-1px}\n"] }]
17
16
  }], ctorParameters: function () { return []; } });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9jYXJkL2NhcmQvY2FyZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9jYXJkL2NhcmQvY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDOztBQVFsRCxNQUFNLE9BQU8sZUFBZTtJQUUxQjtJQUNBLENBQUM7SUFFRCxRQUFRO0lBQ1IsQ0FBQztJQUVELGVBQWU7UUFDYixzQ0FBc0M7SUFDeEMsQ0FBQzs7NEdBVlUsZUFBZTtnR0FBZixlQUFlLCtDQ1Q1Qiw4TEFLTTsyRkRJTyxlQUFlO2tCQUwzQixTQUFTOytCQUNFLFNBQVMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBDb250ZW50Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCc0NhcmRIZWFkZXJDb21wb25lbnQgfSBmcm9tICcuLi9jYXJkLWhlYWRlci9jYXJkLWhlYWRlci5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdicy1jYXJkJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NhcmQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jYXJkLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQnNDYXJkQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0IHtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgfVxuXG4gIG5nT25Jbml0KCkge1xuICB9XG5cbiAgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIC8vIGNvbnNvbGUubG9nKCdoZWFkZXInLCB0aGlzLmhlYWRlcik7XG4gIH1cblxuICAvLyBAQ29udGVudENoaWxkKENhcmRIZWFkZXJDb21wb25lbnQpIGhlYWRlciE6IENhcmRIZWFkZXJDb21wb25lbnQ7XG59XG4iLCI8ZGl2IGNsYXNzPVwiY2FyZFwiIHN0eWxlPVwid2lkdGg6IDE4cmVtO1wiPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImJzLWNhcmQtaGVhZGVyXCI+PC9uZy1jb250ZW50PlxuICAgIDxkaXYgY2xhc3M9XCJjYXJkLWJsb2NrXCI+XG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbjwvZGl2PiJdfQ==
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9jYXJkL2NhcmQvY2FyZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9jYXJkL2NhcmQvY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDOztBQVFsRCxNQUFNLE9BQU8sZUFBZTtJQUUxQjtJQUNBLENBQUM7SUFFRCxRQUFRO0lBQ1IsQ0FBQztJQUVELGVBQWU7SUFDZixDQUFDOzs0R0FUVSxlQUFlO2dHQUFmLGVBQWUsK0NDVDVCLDhMQUtNOzJGRElPLGVBQWU7a0JBTDNCLFNBQVM7K0JBQ0UsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFmdGVyVmlld0luaXQsIENvbnRlbnRDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJzQ2FyZEhlYWRlckNvbXBvbmVudCB9IGZyb20gJy4uL2NhcmQtaGVhZGVyL2NhcmQtaGVhZGVyLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2JzLWNhcmQnLFxuICB0ZW1wbGF0ZVVybDogJy4vY2FyZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2NhcmQuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBCc0NhcmRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIEFmdGVyVmlld0luaXQge1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gIH1cblxuICAvLyBAQ29udGVudENoaWxkKENhcmRIZWFkZXJDb21wb25lbnQpIGhlYWRlciE6IENhcmRIZWFkZXJDb21wb25lbnQ7XG59XG4iLCI8ZGl2IGNsYXNzPVwiY2FyZFwiIHN0eWxlPVwid2lkdGg6IDE4cmVtO1wiPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImJzLWNhcmQtaGVhZGVyXCI+PC9uZy1jb250ZW50PlxuICAgIDxkaXYgY2xhc3M9XCJjYXJkLWJsb2NrXCI+XG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbjwvZGl2PiJdfQ==
@@ -1,4 +1,4 @@
1
- import { Component, ContentChildren, Input, QueryList } from '@angular/core';
1
+ import { Component, ContentChildren, HostBinding, Input, QueryList } from '@angular/core';
2
2
  import { FadeInOutAnimation, CarouselSlideAnimation } from '@mintplayer/ng-animations';
3
3
  import { BehaviorSubject, Subject } from 'rxjs';
4
4
  import { map, take, takeUntil } from 'rxjs/operators';
@@ -7,9 +7,10 @@ import * as i0 from "@angular/core";
7
7
  import * as i1 from "@angular/common";
8
8
  export class BsCarouselComponent {
9
9
  constructor() {
10
- // @HostBinding('@.disabled')
11
- // public animationsDisabled = false;
12
- this.animation = 'slide';
10
+ this.animationsDisabled = false;
11
+ //#region Animation
12
+ this._animation = 'slide';
13
+ //#endregion
13
14
  this.destroyed$ = new Subject();
14
15
  this.currentImageCounter$ = new BehaviorSubject(-1);
15
16
  this.currentImageIndex$ = this.currentImageCounter$
@@ -34,6 +35,16 @@ export class BsCarouselComponent {
34
35
  this.currentImageCounter$.next(-1);
35
36
  }
36
37
  }
38
+ set animation(value) {
39
+ this.animationsDisabled = true;
40
+ this._animation = value;
41
+ setTimeout(() => {
42
+ this.animationsDisabled = false;
43
+ }, 20);
44
+ }
45
+ get animation() {
46
+ return this._animation;
47
+ }
37
48
  previousImage() {
38
49
  this.currentImageCounter$
39
50
  .pipe(take(1))
@@ -57,14 +68,17 @@ export class BsCarouselComponent {
57
68
  }
58
69
  }
59
70
  BsCarouselComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsCarouselComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
60
- BsCarouselComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsCarouselComponent, selector: "bs-carousel", inputs: { animation: "animation" }, queries: [{ propertyName: "images", predicate: BsCarouselImageDirective }], ngImport: i0, template: "<div class=\"carousel slide\">\n <div class=\"carousel-indicators\">\n <button *ngFor=\"let image of images; let i = index\" type=\"button\" (click)=\"setCurrentImage(i)\"\n [class.active]=\"(currentImageIndex$ | async) === i\" data-bs-target\n [attr.aria-current]=\"(currentImageIndex$ | async) === i ? true : null\"\n [attr.aria-label]=\"'Slide ' + i\"></button>\n </div>\n\n <div class=\"carousel-inner\" [@carouselSlide]=\"currentImageCounter$ | async\" *ngIf=\"animation === 'slide'\">\n <ng-container *ngFor=\"let image of images; let i = index\">\n <div class=\"carousel-item\" [class.active]=\"true\" *ngIf=\"(currentImageIndex$ | async) === i\">\n <ng-container [ngTemplateOutlet]=\"image.itemTemplate\"></ng-container> \n </div>\n </ng-container>\n </div>\n <div class=\"carousel-inner\" *ngIf=\"animation === 'fade'\">\n <ng-container *ngFor=\"let image of images; let i = index\">\n <div class=\"carousel-item\" [class.active]=\"true\" @fadeInOut *ngIf=\"(currentImageIndex$ | async) === i\">\n <ng-container [ngTemplateOutlet]=\"image.itemTemplate\"></ng-container> \n </div>\n </ng-container>\n </div>\n\n <button class=\"carousel-control-prev\" type=\"button\" (click)=\"previousImage()\">\n <span class=\"carousel-control-prev-icon\" aria-hidden=\"true\"></span>\n <span class=\"visually-hidden\">Previous</span>\n </button>\n <button class=\"carousel-control-next\" type=\"button\" (click)=\"nextImage()\">\n <span class=\"carousel-control-next-icon\" aria-hidden=\"true\"></span>\n <span class=\"visually-hidden\">Next</span>\n </button>\n</div>", styles: [".carousel{min-height:100px}\n"], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i1.AsyncPipe }, animations: [FadeInOutAnimation, CarouselSlideAnimation] });
71
+ BsCarouselComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: BsCarouselComponent, selector: "bs-carousel", inputs: { animation: "animation" }, host: { properties: { "@.disabled": "this.animationsDisabled" } }, queries: [{ propertyName: "images", predicate: BsCarouselImageDirective }], ngImport: i0, template: "<div class=\"carousel slide\">\n <div class=\"carousel-indicators\">\n <button *ngFor=\"let image of images; let i = index\" type=\"button\" (click)=\"setCurrentImage(i)\"\n [class.active]=\"(currentImageIndex$ | async) === i\" data-bs-target\n [attr.aria-current]=\"(currentImageIndex$ | async) === i ? true : null\"\n [attr.aria-label]=\"'Slide ' + i\"></button>\n </div>\n\n <div class=\"carousel-inner\" [@carouselSlide]=\"currentImageCounter$ | async\" *ngIf=\"animation === 'slide'\">\n <ng-container *ngFor=\"let image of images; let i = index\">\n <div class=\"carousel-item\" [class.active]=\"true\" *ngIf=\"(currentImageIndex$ | async) === i\">\n <ng-container [ngTemplateOutlet]=\"image.itemTemplate\"></ng-container> \n </div>\n </ng-container>\n </div>\n <div class=\"carousel-inner\" *ngIf=\"animation === 'fade'\">\n <ng-container *ngFor=\"let image of images; let i = index\">\n <div class=\"carousel-item\" [class.active]=\"true\" @fadeInOut *ngIf=\"(currentImageIndex$ | async) === i\">\n <ng-container [ngTemplateOutlet]=\"image.itemTemplate\"></ng-container> \n </div>\n </ng-container>\n </div>\n\n <button class=\"carousel-control-prev\" type=\"button\" (click)=\"previousImage()\">\n <span class=\"carousel-control-prev-icon\" aria-hidden=\"true\"></span>\n <span class=\"visually-hidden\">Previous</span>\n </button>\n <button class=\"carousel-control-next\" type=\"button\" (click)=\"nextImage()\">\n <span class=\"carousel-control-next-icon\" aria-hidden=\"true\"></span>\n <span class=\"visually-hidden\">Next</span>\n </button>\n</div>", styles: [".carousel{min-height:100px}\n"], directives: [{ type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i1.AsyncPipe }, animations: [FadeInOutAnimation, CarouselSlideAnimation] });
61
72
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsCarouselComponent, decorators: [{
62
73
  type: Component,
63
74
  args: [{ selector: 'bs-carousel', animations: [FadeInOutAnimation, CarouselSlideAnimation], template: "<div class=\"carousel slide\">\n <div class=\"carousel-indicators\">\n <button *ngFor=\"let image of images; let i = index\" type=\"button\" (click)=\"setCurrentImage(i)\"\n [class.active]=\"(currentImageIndex$ | async) === i\" data-bs-target\n [attr.aria-current]=\"(currentImageIndex$ | async) === i ? true : null\"\n [attr.aria-label]=\"'Slide ' + i\"></button>\n </div>\n\n <div class=\"carousel-inner\" [@carouselSlide]=\"currentImageCounter$ | async\" *ngIf=\"animation === 'slide'\">\n <ng-container *ngFor=\"let image of images; let i = index\">\n <div class=\"carousel-item\" [class.active]=\"true\" *ngIf=\"(currentImageIndex$ | async) === i\">\n <ng-container [ngTemplateOutlet]=\"image.itemTemplate\"></ng-container> \n </div>\n </ng-container>\n </div>\n <div class=\"carousel-inner\" *ngIf=\"animation === 'fade'\">\n <ng-container *ngFor=\"let image of images; let i = index\">\n <div class=\"carousel-item\" [class.active]=\"true\" @fadeInOut *ngIf=\"(currentImageIndex$ | async) === i\">\n <ng-container [ngTemplateOutlet]=\"image.itemTemplate\"></ng-container> \n </div>\n </ng-container>\n </div>\n\n <button class=\"carousel-control-prev\" type=\"button\" (click)=\"previousImage()\">\n <span class=\"carousel-control-prev-icon\" aria-hidden=\"true\"></span>\n <span class=\"visually-hidden\">Previous</span>\n </button>\n <button class=\"carousel-control-next\" type=\"button\" (click)=\"nextImage()\">\n <span class=\"carousel-control-next-icon\" aria-hidden=\"true\"></span>\n <span class=\"visually-hidden\">Next</span>\n </button>\n</div>", styles: [".carousel{min-height:100px}\n"] }]
64
- }], ctorParameters: function () { return []; }, propDecorators: { animation: [{
75
+ }], ctorParameters: function () { return []; }, propDecorators: { animationsDisabled: [{
76
+ type: HostBinding,
77
+ args: ['@.disabled']
78
+ }], animation: [{
65
79
  type: Input
66
80
  }], images: [{
67
81
  type: ContentChildren,
68
82
  args: [BsCarouselImageDirective]
69
83
  }] } });
70
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/carousel/carousel/carousel.component.ts","../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/carousel/carousel/carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ContentChildren, ElementRef, HostBinding, Input, OnDestroy, OnInit, QueryList, TemplateRef } from '@angular/core';\nimport { FadeInOutAnimation, CarouselSlideAnimation } from '@mintplayer/ng-animations';\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\nimport { map, tap, take, takeUntil } from 'rxjs/operators';\nimport { BsCarouselImageDirective } from '../carousel-image/carousel-image.directive';\n\n@Component({\n  selector: 'bs-carousel',\n  templateUrl: './carousel.component.html',\n  styleUrls: ['./carousel.component.scss'],\n  animations: [FadeInOutAnimation, CarouselSlideAnimation]\n})\nexport class BsCarouselComponent implements OnInit, OnDestroy, AfterContentInit {\n\n  constructor() {\n    this.currentImageIndex$ = this.currentImageCounter$\n      .pipe(map((counter) => {\n        const l = this.images.length;\n        return ((counter % l) + l) % l;\n      }))\n      .pipe(takeUntil(this.destroyed$));\n    this.currentImage$ = this.currentImageIndex$\n      .pipe(map((index) => this.images.get(index)?.itemTemplate ?? null))\n      .pipe(takeUntil(this.destroyed$));\n  }\n\n  ngOnInit(): void { }\n\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n\n  ngAfterContentInit() {\n    if (this.images.length > 0) {\n      this.currentImageCounter$.next(0);\n    } else {\n      this.currentImageCounter$.next(-1);\n    }\n  }\n  \n  // @HostBinding('@.disabled')\n  // public animationsDisabled = false;\n\n  @Input() public animation: 'fade' | 'slide' = 'slide';\n\n  destroyed$ = new Subject();\n  currentImageCounter$ = new BehaviorSubject<number>(-1);\n  currentImageIndex$: Observable<number>;\n  currentImage$: Observable<TemplateRef<any> | null>;\n\n  previousImage() {\n    this.currentImageCounter$\n      .pipe(take(1))\n      .subscribe((currentImageCounter) => {\n        this.currentImageCounter$.next(currentImageCounter - 1);\n      });\n  }\n\n  nextImage() {\n    this.currentImageCounter$\n      .pipe(take(1))\n      .subscribe((currentImageCounter) => {\n        this.currentImageCounter$.next(currentImageCounter + 1);\n      });\n  }\n\n  setCurrentImage(index: number) {\n    const currentValue = this.currentImageCounter$.value;\n    const l = this.images.length;\n    const counterMod = ((currentValue % l) + l) % l;\n    const newValue = currentValue - counterMod + index;\n    this.currentImageCounter$.next(newValue);\n  }\n\n  @ContentChildren(BsCarouselImageDirective) images!: QueryList<BsCarouselImageDirective>;\n\n}\n","<div class=\"carousel slide\">\n    <div class=\"carousel-indicators\">\n        <button *ngFor=\"let image of images; let i = index\" type=\"button\" (click)=\"setCurrentImage(i)\"\n            [class.active]=\"(currentImageIndex$ | async) === i\" data-bs-target\n            [attr.aria-current]=\"(currentImageIndex$ | async) === i ? true : null\"\n            [attr.aria-label]=\"'Slide ' + i\"></button>\n    </div>\n\n    <div class=\"carousel-inner\" [@carouselSlide]=\"currentImageCounter$ | async\" *ngIf=\"animation === 'slide'\">\n        <ng-container *ngFor=\"let image of images; let i = index\">\n            <div class=\"carousel-item\" [class.active]=\"true\" *ngIf=\"(currentImageIndex$ | async) === i\">\n                <ng-container [ngTemplateOutlet]=\"image.itemTemplate\"></ng-container>    \n            </div>\n        </ng-container>\n    </div>\n    <div class=\"carousel-inner\" *ngIf=\"animation === 'fade'\">\n        <ng-container *ngFor=\"let image of images; let i = index\">\n            <div class=\"carousel-item\" [class.active]=\"true\" @fadeInOut *ngIf=\"(currentImageIndex$ | async) === i\">\n                <ng-container [ngTemplateOutlet]=\"image.itemTemplate\"></ng-container>    \n            </div>\n        </ng-container>\n    </div>\n\n    <button class=\"carousel-control-prev\" type=\"button\" (click)=\"previousImage()\">\n        <span class=\"carousel-control-prev-icon\" aria-hidden=\"true\"></span>\n        <span class=\"visually-hidden\">Previous</span>\n    </button>\n    <button class=\"carousel-control-next\" type=\"button\" (click)=\"nextImage()\">\n        <span class=\"carousel-control-next-icon\" aria-hidden=\"true\"></span>\n        <span class=\"visually-hidden\">Next</span>\n    </button>\n</div>"]}
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"carousel.component.js","sourceRoot":"","sources":["../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/carousel/carousel/carousel.component.ts","../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/carousel/carousel/carousel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ContentChildren, ElementRef, HostBinding, Input, OnDestroy, OnInit, QueryList, TemplateRef } from '@angular/core';\nimport { FadeInOutAnimation, CarouselSlideAnimation } from '@mintplayer/ng-animations';\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\nimport { map, tap, take, takeUntil } from 'rxjs/operators';\nimport { BsCarouselImageDirective } from '../carousel-image/carousel-image.directive';\n\n@Component({\n  selector: 'bs-carousel',\n  templateUrl: './carousel.component.html',\n  styleUrls: ['./carousel.component.scss'],\n  animations: [FadeInOutAnimation, CarouselSlideAnimation]\n})\nexport class BsCarouselComponent implements OnInit, OnDestroy, AfterContentInit {\n\n  constructor() {\n    this.currentImageIndex$ = this.currentImageCounter$\n      .pipe(map((counter) => {\n        const l = this.images.length;\n        return ((counter % l) + l) % l;\n      }))\n      .pipe(takeUntil(this.destroyed$));\n    this.currentImage$ = this.currentImageIndex$\n      .pipe(map((index) => this.images.get(index)?.itemTemplate ?? null))\n      .pipe(takeUntil(this.destroyed$));\n  }\n\n  ngOnInit(): void { }\n\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n\n  ngAfterContentInit() {\n    if (this.images.length > 0) {\n      this.currentImageCounter$.next(0);\n    } else {\n      this.currentImageCounter$.next(-1);\n    }\n  }\n  \n  @HostBinding('@.disabled')\n  public animationsDisabled = false;\n\n  //#region Animation\n  private _animation: 'fade' | 'slide' = 'slide';\n  @Input() public set animation(value: 'fade' | 'slide') {\n    this.animationsDisabled = true;\n    this._animation = value;\n    setTimeout(() => {\n      this.animationsDisabled = false;\n    }, 20);\n  }\n  public get animation() {\n    return this._animation;\n  }\n  //#endregion\n\n  destroyed$ = new Subject();\n  currentImageCounter$ = new BehaviorSubject<number>(-1);\n  currentImageIndex$: Observable<number>;\n  currentImage$: Observable<TemplateRef<any> | null>;\n\n  previousImage() {\n    this.currentImageCounter$\n      .pipe(take(1))\n      .subscribe((currentImageCounter) => {\n        this.currentImageCounter$.next(currentImageCounter - 1);\n      });\n  }\n\n  nextImage() {\n    this.currentImageCounter$\n      .pipe(take(1))\n      .subscribe((currentImageCounter) => {\n        this.currentImageCounter$.next(currentImageCounter + 1);\n      });\n  }\n\n  setCurrentImage(index: number) {\n    const currentValue = this.currentImageCounter$.value;\n    const l = this.images.length;\n    const counterMod = ((currentValue % l) + l) % l;\n    const newValue = currentValue - counterMod + index;\n    this.currentImageCounter$.next(newValue);\n  }\n\n  @ContentChildren(BsCarouselImageDirective) images!: QueryList<BsCarouselImageDirective>;\n\n}\n","<div class=\"carousel slide\">\n    <div class=\"carousel-indicators\">\n        <button *ngFor=\"let image of images; let i = index\" type=\"button\" (click)=\"setCurrentImage(i)\"\n            [class.active]=\"(currentImageIndex$ | async) === i\" data-bs-target\n            [attr.aria-current]=\"(currentImageIndex$ | async) === i ? true : null\"\n            [attr.aria-label]=\"'Slide ' + i\"></button>\n    </div>\n\n    <div class=\"carousel-inner\" [@carouselSlide]=\"currentImageCounter$ | async\" *ngIf=\"animation === 'slide'\">\n        <ng-container *ngFor=\"let image of images; let i = index\">\n            <div class=\"carousel-item\" [class.active]=\"true\" *ngIf=\"(currentImageIndex$ | async) === i\">\n                <ng-container [ngTemplateOutlet]=\"image.itemTemplate\"></ng-container>    \n            </div>\n        </ng-container>\n    </div>\n    <div class=\"carousel-inner\" *ngIf=\"animation === 'fade'\">\n        <ng-container *ngFor=\"let image of images; let i = index\">\n            <div class=\"carousel-item\" [class.active]=\"true\" @fadeInOut *ngIf=\"(currentImageIndex$ | async) === i\">\n                <ng-container [ngTemplateOutlet]=\"image.itemTemplate\"></ng-container>    \n            </div>\n        </ng-container>\n    </div>\n\n    <button class=\"carousel-control-prev\" type=\"button\" (click)=\"previousImage()\">\n        <span class=\"carousel-control-prev-icon\" aria-hidden=\"true\"></span>\n        <span class=\"visually-hidden\">Previous</span>\n    </button>\n    <button class=\"carousel-control-next\" type=\"button\" (click)=\"nextImage()\">\n        <span class=\"carousel-control-next-icon\" aria-hidden=\"true\"></span>\n        <span class=\"visually-hidden\">Next</span>\n    </button>\n</div>"]}
@@ -0,0 +1,57 @@
1
+ import { Overlay } from '@angular/cdk/overlay';
2
+ import { TemplatePortal } from '@angular/cdk/portal';
3
+ import { Directive, ElementRef, Host, HostListener, SkipSelf, TemplateRef, ViewContainerRef } from '@angular/core';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/cdk/overlay";
6
+ export class BsContextMenuDirective {
7
+ constructor(overlay, templateRef, viewContainerRef, element) {
8
+ this.overlay = overlay;
9
+ this.templateRef = templateRef;
10
+ this.viewContainerRef = viewContainerRef;
11
+ this.element = element;
12
+ this.overlayRef = null;
13
+ this.templatePortal = null;
14
+ this.element.nativeElement.oncontextmenu = (ev) => {
15
+ ev.preventDefault();
16
+ this.checkAndCloseExisting(ev);
17
+ this.overlayRef = this.overlay.create({
18
+ scrollStrategy: this.overlay.scrollStrategies.noop(),
19
+ positionStrategy: this.overlay.position()
20
+ .global()
21
+ .left(ev.x + 'px')
22
+ .bottom((window.innerHeight - ev.y) + 'px')
23
+ .top(ev.y + 'px')
24
+ });
25
+ this.templatePortal = new TemplatePortal(this.templateRef, this.viewContainerRef);
26
+ this.overlayRef.attach(this.templatePortal);
27
+ };
28
+ }
29
+ clickAnywhere(ev) {
30
+ this.checkAndCloseExisting(ev);
31
+ }
32
+ checkAndCloseExisting(ev) {
33
+ if (this.overlayRef) {
34
+ if (!this.overlayRef.overlayElement.contains(ev.target)) {
35
+ this.overlayRef.detach();
36
+ this.overlayRef.dispose();
37
+ this.overlayRef = null;
38
+ }
39
+ }
40
+ }
41
+ }
42
+ BsContextMenuDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsContextMenuDirective, deps: [{ token: i1.Overlay }, { token: i0.TemplateRef }, { token: i0.ViewContainerRef }, { token: i0.ElementRef, host: true, skipSelf: true }], target: i0.ɵɵFactoryTarget.Directive });
43
+ BsContextMenuDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.1.1", type: BsContextMenuDirective, selector: "[bsContextMenu]", host: { listeners: { "document:click": "clickAnywhere($event)" } }, ngImport: i0 });
44
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsContextMenuDirective, decorators: [{
45
+ type: Directive,
46
+ args: [{
47
+ selector: '[bsContextMenu]'
48
+ }]
49
+ }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.TemplateRef }, { type: i0.ViewContainerRef }, { type: i0.ElementRef, decorators: [{
50
+ type: Host
51
+ }, {
52
+ type: SkipSelf
53
+ }] }]; }, propDecorators: { clickAnywhere: [{
54
+ type: HostListener,
55
+ args: ['document:click', ['$event']]
56
+ }] } });
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1tZW51LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL2NvbnRleHQtbWVudS9jb250ZXh0LW1lbnUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQWMsTUFBTSxzQkFBc0IsQ0FBQztBQUMzRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDckQsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsSUFBSSxFQUFFLFlBQVksRUFBRSxRQUFRLEVBQUUsV0FBVyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFLbkgsTUFBTSxPQUFPLHNCQUFzQjtJQUVqQyxZQUNVLE9BQWdCLEVBQ2hCLFdBQTZCLEVBQzdCLGdCQUFrQyxFQUNkLE9BQW1CO1FBSHZDLFlBQU8sR0FBUCxPQUFPLENBQVM7UUFDaEIsZ0JBQVcsR0FBWCxXQUFXLENBQWtCO1FBQzdCLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFDZCxZQUFPLEdBQVAsT0FBTyxDQUFZO1FBZ0N6QyxlQUFVLEdBQXNCLElBQUksQ0FBQztRQUNyQyxtQkFBYyxHQUErQixJQUFJLENBQUM7UUEvQnhELElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLGFBQWEsR0FBRyxDQUFDLEVBQWMsRUFBRSxFQUFFO1lBQzVELEVBQUUsQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUNwQixJQUFJLENBQUMscUJBQXFCLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDL0IsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztnQkFDcEMsY0FBYyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxFQUFFO2dCQUNwRCxnQkFBZ0IsRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRTtxQkFDdEMsTUFBTSxFQUFFO3FCQUNSLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQztxQkFDakIsTUFBTSxDQUFDLENBQUMsTUFBTSxDQUFDLFdBQVcsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO3FCQUMxQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUM7YUFDcEIsQ0FBQyxDQUFDO1lBQ0gsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLGNBQWMsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBQ2xGLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUM5QyxDQUFDLENBQUM7SUFDSixDQUFDO0lBRTJDLGFBQWEsQ0FBQyxFQUFjO1FBQ3RFLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRU8scUJBQXFCLENBQUMsRUFBYztRQUMxQyxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDbkIsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBTSxFQUFFLENBQUMsTUFBTSxDQUFDLEVBQUU7Z0JBQzVELElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxFQUFFLENBQUM7Z0JBQ3pCLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFLENBQUM7Z0JBQzFCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO2FBQ3hCO1NBQ0Y7SUFDSCxDQUFDOzttSEFwQ1Usc0JBQXNCO3VHQUF0QixzQkFBc0I7MkZBQXRCLHNCQUFzQjtrQkFIbEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsaUJBQWlCO2lCQUM1Qjs7MEJBT0ksSUFBSTs7MEJBQUksUUFBUTs0Q0FrQnlCLGFBQWE7c0JBQXhELFlBQVk7dUJBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPdmVybGF5LCBPdmVybGF5UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgVGVtcGxhdGVQb3J0YWwgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcbmltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdCwgSG9zdExpc3RlbmVyLCBTa2lwU2VsZiwgVGVtcGxhdGVSZWYsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2JzQ29udGV4dE1lbnVdJ1xufSlcbmV4cG9ydCBjbGFzcyBCc0NvbnRleHRNZW51RGlyZWN0aXZlIHtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIG92ZXJsYXk6IE92ZXJsYXksXG4gICAgcHJpdmF0ZSB0ZW1wbGF0ZVJlZjogVGVtcGxhdGVSZWY8YW55PixcbiAgICBwcml2YXRlIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYsXG4gICAgQEhvc3QoKSBAU2tpcFNlbGYoKSBwcml2YXRlIGVsZW1lbnQ6IEVsZW1lbnRSZWZcbiAgKSB7XG4gICAgdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQub25jb250ZXh0bWVudSA9IChldjogTW91c2VFdmVudCkgPT4ge1xuICAgICAgZXYucHJldmVudERlZmF1bHQoKTtcbiAgICAgIHRoaXMuY2hlY2tBbmRDbG9zZUV4aXN0aW5nKGV2KTtcbiAgICAgIHRoaXMub3ZlcmxheVJlZiA9IHRoaXMub3ZlcmxheS5jcmVhdGUoe1xuICAgICAgICBzY3JvbGxTdHJhdGVneTogdGhpcy5vdmVybGF5LnNjcm9sbFN0cmF0ZWdpZXMubm9vcCgpLFxuICAgICAgICBwb3NpdGlvblN0cmF0ZWd5OiB0aGlzLm92ZXJsYXkucG9zaXRpb24oKVxuICAgICAgICAgIC5nbG9iYWwoKVxuICAgICAgICAgIC5sZWZ0KGV2LnggKyAncHgnKVxuICAgICAgICAgIC5ib3R0b20oKHdpbmRvdy5pbm5lckhlaWdodCAtIGV2LnkpICsgJ3B4JylcbiAgICAgICAgICAudG9wKGV2LnkgKyAncHgnKVxuICAgICAgfSk7XG4gICAgICB0aGlzLnRlbXBsYXRlUG9ydGFsID0gbmV3IFRlbXBsYXRlUG9ydGFsKHRoaXMudGVtcGxhdGVSZWYsIHRoaXMudmlld0NvbnRhaW5lclJlZik7XG4gICAgICB0aGlzLm92ZXJsYXlSZWYuYXR0YWNoKHRoaXMudGVtcGxhdGVQb3J0YWwpO1xuICAgIH07XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdkb2N1bWVudDpjbGljaycsIFsnJGV2ZW50J10pIGNsaWNrQW55d2hlcmUoZXY6IE1vdXNlRXZlbnQpIHtcbiAgICB0aGlzLmNoZWNrQW5kQ2xvc2VFeGlzdGluZyhldik7XG4gIH1cblxuICBwcml2YXRlIGNoZWNrQW5kQ2xvc2VFeGlzdGluZyhldjogTW91c2VFdmVudCkge1xuICAgIGlmICh0aGlzLm92ZXJsYXlSZWYpIHtcbiAgICAgIGlmICghdGhpcy5vdmVybGF5UmVmLm92ZXJsYXlFbGVtZW50LmNvbnRhaW5zKDxhbnk+ZXYudGFyZ2V0KSkge1xuICAgICAgICB0aGlzLm92ZXJsYXlSZWYuZGV0YWNoKCk7XG4gICAgICAgIHRoaXMub3ZlcmxheVJlZi5kaXNwb3NlKCk7XG4gICAgICAgIHRoaXMub3ZlcmxheVJlZiA9IG51bGw7XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBvdmVybGF5UmVmOiBPdmVybGF5UmVmIHwgbnVsbCA9IG51bGw7XG4gIHByaXZhdGUgdGVtcGxhdGVQb3J0YWw6IFRlbXBsYXRlUG9ydGFsPGFueT4gfCBudWxsID0gbnVsbDtcblxufVxuIl19
@@ -0,0 +1,26 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { BsContextMenuDirective } from './context-menu.directive';
4
+ import * as i0 from "@angular/core";
5
+ export class BsContextMenuModule {
6
+ }
7
+ BsContextMenuModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsContextMenuModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
+ BsContextMenuModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsContextMenuModule, declarations: [BsContextMenuDirective], imports: [CommonModule], exports: [BsContextMenuDirective] });
9
+ BsContextMenuModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsContextMenuModule, imports: [[
10
+ CommonModule
11
+ ]] });
12
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: BsContextMenuModule, decorators: [{
13
+ type: NgModule,
14
+ args: [{
15
+ declarations: [
16
+ BsContextMenuDirective
17
+ ],
18
+ imports: [
19
+ CommonModule
20
+ ],
21
+ exports: [
22
+ BsContextMenuDirective
23
+ ]
24
+ }]
25
+ }] });
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1tZW51Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL2NvbnRleHQtbWVudS9jb250ZXh0LW1lbnUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQWFsRSxNQUFNLE9BQU8sbUJBQW1COztnSEFBbkIsbUJBQW1CO2lIQUFuQixtQkFBbUIsaUJBVDVCLHNCQUFzQixhQUd0QixZQUFZLGFBR1osc0JBQXNCO2lIQUdiLG1CQUFtQixZQVByQjtZQUNQLFlBQVk7U0FDYjsyRkFLVSxtQkFBbUI7a0JBWC9CLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHNCQUFzQjtxQkFDdkI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7cUJBQ2I7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHNCQUFzQjtxQkFDdkI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEJzQ29udGV4dE1lbnVEaXJlY3RpdmUgfSBmcm9tICcuL2NvbnRleHQtbWVudS5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBCc0NvbnRleHRNZW51RGlyZWN0aXZlXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEJzQ29udGV4dE1lbnVEaXJlY3RpdmVcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBCc0NvbnRleHRNZW51TW9kdWxlIHsgfVxuIl19
@@ -0,0 +1,3 @@
1
+ export * from './context-menu.directive';
2
+ export * from './context-menu.module';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9jb250ZXh0LW1lbnUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LW1lbnUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vY29udGV4dC1tZW51Lm1vZHVsZSc7Il19