@mintplayer/ng-bootstrap 13.3.6 → 13.3.7

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 (78) hide show
  1. package/_bootstrap.scss +1 -0
  2. package/esm2020/lib/components/calendar/calendar.component.mjs +4 -4
  3. package/esm2020/lib/components/index.mjs +2 -1
  4. package/esm2020/lib/components/offcanvas/components/index.mjs +4 -0
  5. package/esm2020/lib/components/offcanvas/components/offcanvas/offcanvas.component.mjs +62 -0
  6. package/esm2020/lib/components/offcanvas/components/offcanvas-body/offcanvas-body.component.mjs +14 -0
  7. package/esm2020/lib/components/offcanvas/components/offcanvas-header/offcanvas-header.component.mjs +14 -0
  8. package/esm2020/lib/components/offcanvas/directives/index.mjs +2 -0
  9. package/esm2020/lib/components/offcanvas/directives/offcanvas-close/offcanvas-close.directive.mjs +27 -0
  10. package/esm2020/lib/components/offcanvas/index.mjs +7 -0
  11. package/esm2020/lib/components/offcanvas/interfaces/index.mjs +2 -0
  12. package/esm2020/lib/components/offcanvas/interfaces/offcanvas-animation-meta.mjs +2 -0
  13. package/esm2020/lib/components/offcanvas/offcanvas.module.mjs +45 -0
  14. package/esm2020/lib/components/offcanvas/providers/offcanvas-content.provider.mjs +3 -0
  15. package/esm2020/lib/components/offcanvas/services/index.mjs +2 -0
  16. package/esm2020/lib/components/offcanvas/services/offcanvas/offcanvas.service.mjs +72 -0
  17. package/esm2020/lib/components/offcanvas/types/index.mjs +2 -0
  18. package/esm2020/lib/components/offcanvas/types/position.mjs +2 -0
  19. package/esm2020/lib/components/scheduler/components/index.mjs +2 -1
  20. package/esm2020/lib/components/scheduler/components/resource-group-presenter/resource-group-presenter.component.mjs +84 -0
  21. package/esm2020/lib/components/scheduler/components/scheduler/scheduler.component.mjs +197 -72
  22. package/esm2020/lib/components/scheduler/constants/available-scales.mjs +12 -0
  23. package/esm2020/lib/components/scheduler/constants/index.mjs +2 -0
  24. package/esm2020/lib/components/scheduler/enums/index.mjs +2 -0
  25. package/esm2020/lib/components/scheduler/enums/scheduler-mode.mjs +6 -0
  26. package/esm2020/lib/components/scheduler/index.mjs +4 -1
  27. package/esm2020/lib/components/scheduler/interfaces/index.mjs +6 -0
  28. package/esm2020/lib/components/scheduler/interfaces/resource-group.mjs +2 -0
  29. package/esm2020/lib/components/scheduler/interfaces/resource-or-group.mjs +2 -0
  30. package/esm2020/lib/components/scheduler/interfaces/resource.mjs +2 -0
  31. package/esm2020/lib/components/scheduler/interfaces/scheduler-schale.mjs +2 -0
  32. package/esm2020/lib/components/scheduler/interfaces/scheduler-stamp-with-slots.mjs +2 -0
  33. package/esm2020/lib/components/scheduler/interfaces/timeline-options.mjs +2 -0
  34. package/esm2020/lib/components/scheduler/interfaces/week-options.mjs +2 -0
  35. package/esm2020/lib/components/scheduler/scheduler.module.mjs +9 -4
  36. package/esm2020/lib/components/snackbar/service/snackbar.service.mjs +6 -7
  37. package/esm2020/lib/components/snackbar/snackbar.module.mjs +2 -9
  38. package/fesm2015/mintplayer-ng-bootstrap.mjs +512 -87
  39. package/fesm2015/mintplayer-ng-bootstrap.mjs.map +1 -1
  40. package/fesm2020/mintplayer-ng-bootstrap.mjs +510 -87
  41. package/fesm2020/mintplayer-ng-bootstrap.mjs.map +1 -1
  42. package/lib/components/calendar/calendar.component.d.ts +1 -1
  43. package/lib/components/index.d.ts +1 -0
  44. package/lib/components/offcanvas/components/index.d.ts +3 -0
  45. package/lib/components/offcanvas/components/offcanvas/offcanvas.component.d.ts +20 -0
  46. package/lib/components/offcanvas/components/offcanvas-body/offcanvas-body.component.d.ts +8 -0
  47. package/lib/components/offcanvas/components/offcanvas-header/offcanvas-header.component.d.ts +8 -0
  48. package/lib/components/offcanvas/directives/index.d.ts +1 -0
  49. package/lib/components/offcanvas/directives/offcanvas-close/offcanvas-close.directive.d.ts +11 -0
  50. package/lib/components/offcanvas/index.d.ts +6 -0
  51. package/lib/components/offcanvas/interfaces/index.d.ts +1 -0
  52. package/lib/components/offcanvas/interfaces/offcanvas-animation-meta.d.ts +7 -0
  53. package/lib/components/offcanvas/offcanvas.module.d.ts +12 -0
  54. package/lib/components/offcanvas/providers/offcanvas-content.provider.d.ts +2 -0
  55. package/lib/components/offcanvas/services/index.d.ts +1 -0
  56. package/lib/components/offcanvas/services/offcanvas/offcanvas.service.d.ts +13 -0
  57. package/lib/components/offcanvas/types/index.d.ts +1 -0
  58. package/lib/components/offcanvas/types/position.d.ts +1 -0
  59. package/lib/components/scheduler/components/index.d.ts +1 -0
  60. package/lib/components/scheduler/components/resource-group-presenter/resource-group-presenter.component.d.ts +26 -0
  61. package/lib/components/scheduler/components/scheduler/scheduler.component.d.ts +32 -11
  62. package/lib/components/scheduler/constants/available-scales.d.ts +2 -0
  63. package/lib/components/scheduler/constants/index.d.ts +1 -0
  64. package/lib/components/scheduler/enums/index.d.ts +1 -0
  65. package/lib/components/scheduler/enums/scheduler-mode.d.ts +4 -0
  66. package/lib/components/scheduler/index.d.ts +3 -0
  67. package/lib/components/scheduler/interfaces/index.d.ts +5 -0
  68. package/lib/components/scheduler/interfaces/resource-group.d.ts +5 -0
  69. package/lib/components/scheduler/interfaces/resource-or-group.d.ts +6 -0
  70. package/lib/components/scheduler/interfaces/resource.d.ts +5 -0
  71. package/lib/components/scheduler/interfaces/scheduler-schale.d.ts +5 -0
  72. package/lib/components/scheduler/interfaces/scheduler-stamp-with-slots.d.ts +6 -0
  73. package/lib/components/scheduler/interfaces/timeline-options.d.ts +3 -0
  74. package/lib/components/scheduler/interfaces/week-options.d.ts +3 -0
  75. package/lib/components/scheduler/scheduler.module.d.ts +3 -2
  76. package/lib/components/snackbar/service/snackbar.service.d.ts +2 -3
  77. package/package.json +1 -1
  78. package/src/styles/utilities/overflow.scss +10 -0
package/_bootstrap.scss CHANGED
@@ -8,6 +8,7 @@
8
8
  @import "~bootstrap/scss/bootstrap-utilities.scss";
9
9
  @import './src/styles/utilities/cursor.scss';
10
10
  @import './src/styles/utilities/white-space.scss';
11
+ @import './src/styles/utilities/overflow.scss';
11
12
 
12
13
  // Finally import the bootstrap
13
14
  @import "~bootstrap/scss/bootstrap.scss";
@@ -20,7 +20,7 @@ export class BsCalendarComponent {
20
20
  this.weeks$ = this.currentMonth$
21
21
  .pipe(map((month) => this.calendarMonthService.getWeeks(month)))
22
22
  .pipe(takeUntil(this.destroyed$));
23
- this.daysOfWeek$ = this.weeks$
23
+ this.shownDays$ = this.weeks$
24
24
  .pipe(filter((weeks) => weeks.length > 1))
25
25
  .pipe(map((weeks) => weeks[1].days))
26
26
  .pipe(map((days) => {
@@ -89,10 +89,10 @@ export class BsCalendarComponent {
89
89
  }
90
90
  }
91
91
  BsCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsCalendarComponent, deps: [{ token: i1.BsCalendarMonthService }], target: i0.ɵɵFactoryTarget.Component });
92
- BsCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", 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$ | async\" [title]=\"dayOfWeek.long\">\n {{ dayOfWeek.short }}\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.days\" (click)=\"goto(day)\">\n <span *ngIf=\"day !== null\" [class.text-muted]=\"!day.isInMonth\">{{ day.dayOfMonth }}</span>\n </td>\n </tr>\n</table>", styles: [".text-muted{color:#9ea7af!important}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 } });
92
+ BsCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", 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 shownDays$ | async\" [title]=\"dayOfWeek.long\">\n {{ dayOfWeek.short }}\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.days\" (click)=\"goto(day)\">\n <span *ngIf=\"day !== null\" [class.text-muted]=\"!day.isInMonth\">{{ day.dayOfMonth }}</span>\n </td>\n </tr>\n</table>", styles: [".text-muted{color:#9ea7af!important}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 } });
93
93
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsCalendarComponent, decorators: [{
94
94
  type: Component,
95
- 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$ | async\" [title]=\"dayOfWeek.long\">\n {{ dayOfWeek.short }}\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.days\" (click)=\"goto(day)\">\n <span *ngIf=\"day !== null\" [class.text-muted]=\"!day.isInMonth\">{{ day.dayOfMonth }}</span>\n </td>\n </tr>\n</table>", styles: [".text-muted{color:#9ea7af!important}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
+ 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 shownDays$ | async\" [title]=\"dayOfWeek.long\">\n {{ dayOfWeek.short }}\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.days\" (click)=\"goto(day)\">\n <span *ngIf=\"day !== null\" [class.text-muted]=\"!day.isInMonth\">{{ day.dayOfMonth }}</span>\n </td>\n </tr>\n</table>", styles: [".text-muted{color:#9ea7af!important}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"] }]
96
96
  }], ctorParameters: function () { return [{ type: i1.BsCalendarMonthService }]; }, propDecorators: { currentMonthChange: [{
97
97
  type: Output
98
98
  }], currentMonth: [{
@@ -102,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImpor
102
102
  }], selectedDate: [{
103
103
  type: Input
104
104
  }] } });
105
- //# 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 { Component, EventEmitter, Input, OnDestroy, 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 { WeekDay } from '../../interfaces/weekday';\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(private calendarMonthService: BsCalendarMonthService) {\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].days))\n      .pipe(\n        map((days) => {\n          const firstDay = days[0];\n          if (firstDay) {\n            return days.map((d) => {\n              const date = new Date(\n                firstDay.date.getFullYear(),\n                firstDay.date.getMonth(),\n                d?.dayOfMonth\n              );\n              return <WeekDay>{\n                short: date.toLocaleString('default', { weekday: 'short' }),\n                long: date.toLocaleString('default', { weekday: 'long' })\n              };\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<WeekDay[]>;\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  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$ | async\" [title]=\"dayOfWeek.long\">\n            {{ dayOfWeek.short }}\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.days\" (click)=\"goto(day)\">\n            <span *ngIf=\"day !== null\" [class.text-muted]=\"!day.isInMonth\">{{ day.dayOfMonth }}</span>\n        </td>\n    </tr>\n</table>"]}
105
+ //# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,GAAG,EAAc,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAI1F,OAAO,EAAE,sBAAsB,EAAE,MAAM,sDAAsD,CAAC;;;;;;AAO9F,MAAM,OAAO,mBAAmB;IAC9B,YAAoB,oBAA4C;QAA5C,yBAAoB,GAApB,oBAAoB,CAAwB;QAmCxD,eAAU,GAAG,IAAI,OAAO,EAAE,CAAC;QAInC,sBAAsB;QACtB,kBAAa,GAAG,IAAI,eAAe,CAAO,IAAI,IAAI,EAAE,CAAC,CAAC;QACrC,uBAAkB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAO/D,YAAY;QACZ,sBAAsB;QACtB,kBAAa,GAAG,IAAI,eAAe,CAAO,IAAI,IAAI,EAAE,CAAC,CAAC;QACrC,uBAAkB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAlD7D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa;aAC7B,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;aAC/D,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QACpC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM;aAC1B,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;aACzC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;aACnC,IAAI,CACH,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YACX,MAAM,QAAQ,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;YACzB,IAAI,QAAQ,EAAE;gBACZ,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;oBACpB,MAAM,IAAI,GAAG,IAAI,IAAI,CACnB,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,EAC3B,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,EACxB,CAAC,EAAE,UAAU,CACd,CAAC;oBACF,OAAgB;wBACd,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC;wBAC3D,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,SAAS,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;qBAC1D,CAAC;gBACJ,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,OAAO,EAAE,CAAC;aACX;QACH,CAAC,CAAC,CACH,CAAC;QACJ,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YACrE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACtE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;IACL,CAAC;IASD,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;IAClC,CAAC;IACD,IAAa,YAAY,CAAC,KAAW;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAKD,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;IAClC,CAAC;IACD,IAAa,YAAY,CAAC,KAAW;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IACD,YAAY;IAEZ,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC;IAED,aAAa;QACX,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACnD,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CACvD,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IACf,CAAC;IAED,SAAS;QACP,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YACnD,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,EAAE,KAAK,CAAC,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CACvD,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IACf,CAAC;IAED,UAAU,CAAC,KAAkB,EAAE,KAAkB;QAC/C,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,IAAI;YAAE,OAAO,IAAI,CAAC;QAClD,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,IAAI;YAAE,OAAO,KAAK,CAAC;QAEnD,OAAO,CACL,KAAK,CAAC,WAAW,EAAE,KAAK,KAAK,CAAC,WAAW,EAAE;YAC3C,KAAK,CAAC,QAAQ,EAAE,KAAK,KAAK,CAAC,QAAQ,EAAE;YACrC,KAAK,CAAC,OAAO,EAAE,KAAK,KAAK,CAAC,OAAO,EAAE,CACpC,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,GAA0B;QAC7B,IAAI,GAAG,EAAE;YACP,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;SACnC;IACH,CAAC;;gHApGU,mBAAmB;oGAAnB,mBAAmB,4NCZhC,2sCA+BQ;2FDnBK,mBAAmB;kBAL/B,SAAS;+BACE,aAAa;6GA8CN,kBAAkB;sBAAlC,MAAM;gBAIM,YAAY;sBAAxB,KAAK;gBAMW,kBAAkB;sBAAlC,MAAM;gBAIM,YAAY;sBAAxB,KAAK","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, 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 { WeekDay } from '../../interfaces/weekday';\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(private calendarMonthService: BsCalendarMonthService) {\n    this.weeks$ = this.currentMonth$\n      .pipe(map((month) => this.calendarMonthService.getWeeks(month)))\n      .pipe(takeUntil(this.destroyed$));\n    this.shownDays$ = this.weeks$\n      .pipe(filter((weeks) => weeks.length > 1))\n      .pipe(map((weeks) => weeks[1].days))\n      .pipe(\n        map((days) => {\n          const firstDay = days[0];\n          if (firstDay) {\n            return days.map((d) => {\n              const date = new Date(\n                firstDay.date.getFullYear(),\n                firstDay.date.getMonth(),\n                d?.dayOfMonth\n              );\n              return <WeekDay>{\n                short: date.toLocaleString('default', { weekday: 'short' }),\n                long: date.toLocaleString('default', { weekday: 'long' })\n              };\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  shownDays$: Observable<WeekDay[]>;\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  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 shownDays$ | async\" [title]=\"dayOfWeek.long\">\n            {{ dayOfWeek.short }}\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.days\" (click)=\"goto(day)\">\n            <span *ngIf=\"day !== null\" [class.text-muted]=\"!day.isInMonth\">{{ day.dayOfMonth }}</span>\n        </td>\n    </tr>\n</table>"]}
@@ -16,6 +16,7 @@ export * from './list-group';
16
16
  export * from './modal';
17
17
  export * from './multiselect';
18
18
  export * from './navbar';
19
+ export * from './offcanvas';
19
20
  export * from './pagination';
20
21
  export * from './progress-bar';
21
22
  export * from './rating';
@@ -27,4 +28,4 @@ export * from './timepicker';
27
28
  export * from './toggle-button';
28
29
  export * from './tooltip';
29
30
  export * from './typeahead';
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY2NvcmRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9hbGVydCc7XG5leHBvcnQgKiBmcm9tICcuL2NhbGVuZGFyJztcbmV4cG9ydCAqIGZyb20gJy4vY2FyZCc7XG5leHBvcnQgKiBmcm9tICcuL2Nhcm91c2VsJztcbmV4cG9ydCAqIGZyb20gJy4vY29kZS1zbmlwcGV0JztcbmV4cG9ydCAqIGZyb20gJy4vY29udGV4dC1tZW51JztcbmV4cG9ydCAqIGZyb20gJy4vY29weSc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGF0YWJsZSc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGVwaWNrZXInO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bic7XG5leHBvcnQgKiBmcm9tICcuL2ZpbGUtdXBsb2FkJztcbmV4cG9ydCAqIGZyb20gJy4vZm9yJztcbmV4cG9ydCAqIGZyb20gJy4vc2NoZWR1bGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC1ncm91cCc7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsJztcbmV4cG9ydCAqIGZyb20gJy4vbXVsdGlzZWxlY3QnO1xuZXhwb3J0ICogZnJvbSAnLi9uYXZiYXInO1xuZXhwb3J0ICogZnJvbSAnLi9wYWdpbmF0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vcHJvZ3Jlc3MtYmFyJztcbmV4cG9ydCAqIGZyb20gJy4vcmF0aW5nJztcbmV4cG9ydCAqIGZyb20gJy4vc2Nyb2xsc3B5JztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0Mic7XG5leHBvcnQgKiBmcm9tICcuL3NuYWNrYmFyJztcbmV4cG9ydCAqIGZyb20gJy4vdGFiLWNvbnRyb2wnO1xuZXhwb3J0ICogZnJvbSAnLi90aW1lcGlja2VyJztcbmV4cG9ydCAqIGZyb20gJy4vdG9nZ2xlLWJ1dHRvbic7XG5leHBvcnQgKiBmcm9tICcuL3Rvb2x0aXAnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlYWhlYWQnOyJdfQ==
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY2NvcmRpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9hbGVydCc7XG5leHBvcnQgKiBmcm9tICcuL2NhbGVuZGFyJztcbmV4cG9ydCAqIGZyb20gJy4vY2FyZCc7XG5leHBvcnQgKiBmcm9tICcuL2Nhcm91c2VsJztcbmV4cG9ydCAqIGZyb20gJy4vY29kZS1zbmlwcGV0JztcbmV4cG9ydCAqIGZyb20gJy4vY29udGV4dC1tZW51JztcbmV4cG9ydCAqIGZyb20gJy4vY29weSc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGF0YWJsZSc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGVwaWNrZXInO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bic7XG5leHBvcnQgKiBmcm9tICcuL2ZpbGUtdXBsb2FkJztcbmV4cG9ydCAqIGZyb20gJy4vZm9yJztcbmV4cG9ydCAqIGZyb20gJy4vc2NoZWR1bGVyJztcbmV4cG9ydCAqIGZyb20gJy4vbGlzdC1ncm91cCc7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsJztcbmV4cG9ydCAqIGZyb20gJy4vbXVsdGlzZWxlY3QnO1xuZXhwb3J0ICogZnJvbSAnLi9uYXZiYXInO1xuZXhwb3J0ICogZnJvbSAnLi9vZmZjYW52YXMnO1xuZXhwb3J0ICogZnJvbSAnLi9wYWdpbmF0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vcHJvZ3Jlc3MtYmFyJztcbmV4cG9ydCAqIGZyb20gJy4vcmF0aW5nJztcbmV4cG9ydCAqIGZyb20gJy4vc2Nyb2xsc3B5JztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0Mic7XG5leHBvcnQgKiBmcm9tICcuL3NuYWNrYmFyJztcbmV4cG9ydCAqIGZyb20gJy4vdGFiLWNvbnRyb2wnO1xuZXhwb3J0ICogZnJvbSAnLi90aW1lcGlja2VyJztcbmV4cG9ydCAqIGZyb20gJy4vdG9nZ2xlLWJ1dHRvbic7XG5leHBvcnQgKiBmcm9tICcuL3Rvb2x0aXAnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlYWhlYWQnOyJdfQ==
@@ -0,0 +1,4 @@
1
+ export * from './offcanvas/offcanvas.component';
2
+ export * from './offcanvas-body/offcanvas-body.component';
3
+ export * from './offcanvas-header/offcanvas-header.component';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9vZmZjYW52YXMvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYywrQ0FBK0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vb2ZmY2FudmFzL29mZmNhbnZhcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9vZmZjYW52YXMtYm9keS9vZmZjYW52YXMtYm9keS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9vZmZjYW52YXMtaGVhZGVyL29mZmNhbnZhcy1oZWFkZXIuY29tcG9uZW50JzsiXX0=
@@ -0,0 +1,62 @@
1
+ import { Component, HostBinding, Inject, Input, TemplateRef } from '@angular/core';
2
+ import { BehaviorSubject, map } from 'rxjs';
3
+ import { OFFCANVAS_CONTENT } from '../../providers/offcanvas-content.provider';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ export class BsOffcanvasComponent {
7
+ constructor(content) {
8
+ this.size = null;
9
+ this.displayBlock = true;
10
+ this.instance = null;
11
+ this.show$ = new BehaviorSubject(false);
12
+ this.position$ = new BehaviorSubject('bottom');
13
+ this.content = content;
14
+ this.offcanvasClass$ = this.position$
15
+ .pipe(map((pos) => `offcanvas-${pos}`));
16
+ this.offcanvasHeight100$ = this.position$
17
+ .pipe(map((pos) => {
18
+ switch (this.position) {
19
+ case 'top':
20
+ case 'bottom':
21
+ return false;
22
+ default:
23
+ return true;
24
+ }
25
+ }));
26
+ }
27
+ get width100() {
28
+ switch (this.position) {
29
+ case 'top':
30
+ case 'bottom':
31
+ return true;
32
+ default:
33
+ return false;
34
+ }
35
+ }
36
+ ;
37
+ //#region Position
38
+ set position(value) {
39
+ this.position$.next(value);
40
+ }
41
+ get position() {
42
+ return this.position$.value;
43
+ }
44
+ }
45
+ BsOffcanvasComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasComponent, deps: [{ token: OFFCANVAS_CONTENT }], target: i0.ɵɵFactoryTarget.Component });
46
+ BsOffcanvasComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", type: BsOffcanvasComponent, selector: "bs-offcanvas", inputs: { size: "size" }, host: { properties: { "class.d-block": "this.displayBlock", "class.w-100": "this.width100" } }, ngImport: i0, template: "<div class=\"offcanvas\" [class]=\"offcanvasClass$ | async\"\n [class.show]=\"show$ | async\"\n [class.h-100]=\"offcanvasHeight100$ | async\"\n [style.height.px]=\"size\">\n <ng-container *ngTemplateOutlet=\"content; context: { $implicit: this }\" ></ng-container>\n</div>", styles: [".offcanvas{position:relative;visibility:unset}.offcanvas.offcanvas-bottom,.offcanvas.offcanvas-top{height:auto}\n"], directives: [{ type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i1.AsyncPipe } });
47
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasComponent, decorators: [{
48
+ type: Component,
49
+ args: [{ selector: 'bs-offcanvas', template: "<div class=\"offcanvas\" [class]=\"offcanvasClass$ | async\"\n [class.show]=\"show$ | async\"\n [class.h-100]=\"offcanvasHeight100$ | async\"\n [style.height.px]=\"size\">\n <ng-container *ngTemplateOutlet=\"content; context: { $implicit: this }\" ></ng-container>\n</div>", styles: [".offcanvas{position:relative;visibility:unset}.offcanvas.offcanvas-bottom,.offcanvas.offcanvas-top{height:auto}\n"] }]
50
+ }], ctorParameters: function () { return [{ type: i0.TemplateRef, decorators: [{
51
+ type: Inject,
52
+ args: [OFFCANVAS_CONTENT]
53
+ }] }]; }, propDecorators: { size: [{
54
+ type: Input
55
+ }], displayBlock: [{
56
+ type: HostBinding,
57
+ args: ['class.d-block']
58
+ }], width100: [{
59
+ type: HostBinding,
60
+ args: ['class.w-100']
61
+ }] } });
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2ZmY2FudmFzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL29mZmNhbnZhcy9jb21wb25lbnRzL29mZmNhbnZhcy9vZmZjYW52YXMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvb2ZmY2FudmFzL2NvbXBvbmVudHMvb2ZmY2FudmFzL29mZmNhbnZhcy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRixPQUFPLEVBQUUsZUFBZSxFQUFFLEdBQUcsRUFBYyxNQUFNLE1BQU0sQ0FBQztBQUd4RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQzs7O0FBTy9FLE1BQU0sT0FBTyxvQkFBb0I7SUFFL0IsWUFBdUMsT0FBeUI7UUFnQmhELFNBQUksR0FBa0IsSUFBSSxDQUFDO1FBQ2IsaUJBQVksR0FBRyxJQUFJLENBQUM7UUFZMUMsYUFBUSxHQUFrQyxJQUFJLENBQUM7UUFFdkQsVUFBSyxHQUFHLElBQUksZUFBZSxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBQzVDLGNBQVMsR0FBRyxJQUFJLGVBQWUsQ0FBb0IsUUFBUSxDQUFDLENBQUM7UUEvQjNELElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLFNBQVM7YUFDbEMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsYUFBYSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDMUMsSUFBSSxDQUFDLG1CQUFtQixHQUFHLElBQUksQ0FBQyxTQUFTO2FBQ3RDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUNoQixRQUFRLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ3JCLEtBQUssS0FBSyxDQUFDO2dCQUNYLEtBQUssUUFBUTtvQkFDWCxPQUFPLEtBQUssQ0FBQztnQkFDZjtvQkFDRSxPQUFPLElBQUksQ0FBQzthQUNmO1FBQ0gsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNSLENBQUM7SUFJRCxJQUFnQyxRQUFRO1FBQ3RDLFFBQVEsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNyQixLQUFLLEtBQUssQ0FBQztZQUNYLEtBQUssUUFBUTtnQkFDWCxPQUFPLElBQUksQ0FBQztZQUNkO2dCQUNFLE9BQU8sS0FBSyxDQUFDO1NBQ2hCO0lBQ0gsQ0FBQztJQUFBLENBQUM7SUFVRixrQkFBa0I7SUFDbEIsSUFBVyxRQUFRLENBQUMsS0FBd0I7UUFDMUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUNELElBQVcsUUFBUTtRQUNqQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDO0lBQzlCLENBQUM7O2lIQTVDVSxvQkFBb0Isa0JBRVgsaUJBQWlCO3FHQUYxQixvQkFBb0IsOEtDWGpDLGlTQUtNOzJGRE1PLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxjQUFjOzswQkFNWCxNQUFNOzJCQUFDLGlCQUFpQjs0Q0FnQnJCLElBQUk7c0JBQW5CLEtBQUs7Z0JBQ3dCLFlBQVk7c0JBQXpDLFdBQVc7dUJBQUMsZUFBZTtnQkFDSSxRQUFRO3NCQUF2QyxXQUFXO3VCQUFDLGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbmplY3QsIElucHV0LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCBtYXAsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IE9mZmNhbnZhc1Bvc2l0aW9uIH0gZnJvbSAnLi4vLi4vdHlwZXMvcG9zaXRpb24nO1xuaW1wb3J0IHsgT2ZmY2FudmFzQW5pbWF0aW9uTWV0YSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgT0ZGQ0FOVkFTX0NPTlRFTlQgfSBmcm9tICcuLi8uLi9wcm92aWRlcnMvb2ZmY2FudmFzLWNvbnRlbnQucHJvdmlkZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdicy1vZmZjYW52YXMnLFxuICB0ZW1wbGF0ZVVybDogJy4vb2ZmY2FudmFzLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vb2ZmY2FudmFzLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIEJzT2ZmY2FudmFzQ29tcG9uZW50IHtcblxuICBjb25zdHJ1Y3RvcihASW5qZWN0KE9GRkNBTlZBU19DT05URU5UKSBjb250ZW50OiBUZW1wbGF0ZVJlZjxhbnk+KSB7XG4gICAgdGhpcy5jb250ZW50ID0gY29udGVudDtcbiAgICB0aGlzLm9mZmNhbnZhc0NsYXNzJCA9IHRoaXMucG9zaXRpb24kXG4gICAgICAucGlwZShtYXAoKHBvcykgPT4gYG9mZmNhbnZhcy0ke3Bvc31gKSk7XG4gICAgdGhpcy5vZmZjYW52YXNIZWlnaHQxMDAkID0gdGhpcy5wb3NpdGlvbiRcbiAgICAgIC5waXBlKG1hcCgocG9zKSA9PiB7XG4gICAgICAgIHN3aXRjaCAodGhpcy5wb3NpdGlvbikge1xuICAgICAgICAgIGNhc2UgJ3RvcCc6XG4gICAgICAgICAgY2FzZSAnYm90dG9tJzpcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgIH1cbiAgICAgIH0pKTtcbiAgfVxuXG4gIEBJbnB1dCgpIHB1YmxpYyBzaXplOiBudW1iZXIgfCBudWxsID0gbnVsbDtcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy5kLWJsb2NrJykgZGlzcGxheUJsb2NrID0gdHJ1ZTtcbiAgQEhvc3RCaW5kaW5nKCdjbGFzcy53LTEwMCcpIGdldCB3aWR0aDEwMCgpIHtcbiAgICBzd2l0Y2ggKHRoaXMucG9zaXRpb24pIHtcbiAgICAgIGNhc2UgJ3RvcCc6XG4gICAgICBjYXNlICdib3R0b20nOlxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH07XG4gIFxuICBjb250ZW50OiBUZW1wbGF0ZVJlZjxhbnk+O1xuICBwcml2YXRlIGluc3RhbmNlOiBPZmZjYW52YXNBbmltYXRpb25NZXRhIHwgbnVsbCA9IG51bGw7XG4gIFxuICBzaG93JCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8Ym9vbGVhbj4oZmFsc2UpO1xuICBwb3NpdGlvbiQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PE9mZmNhbnZhc1Bvc2l0aW9uPignYm90dG9tJyk7XG4gIG9mZmNhbnZhc0NsYXNzJDogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuICBvZmZjYW52YXNIZWlnaHQxMDAkOiBPYnNlcnZhYmxlPGJvb2xlYW4+O1xuXG4gIC8vI3JlZ2lvbiBQb3NpdGlvblxuICBwdWJsaWMgc2V0IHBvc2l0aW9uKHZhbHVlOiBPZmZjYW52YXNQb3NpdGlvbikge1xuICAgIHRoaXMucG9zaXRpb24kLm5leHQodmFsdWUpO1xuICB9XG4gIHB1YmxpYyBnZXQgcG9zaXRpb24oKSB7XG4gICAgcmV0dXJuIHRoaXMucG9zaXRpb24kLnZhbHVlO1xuICB9XG4gIC8vI2VuZHJlZ2lvblxuXG59XG4iLCI8ZGl2IGNsYXNzPVwib2ZmY2FudmFzXCIgW2NsYXNzXT1cIm9mZmNhbnZhc0NsYXNzJCB8IGFzeW5jXCJcbiAgICAgW2NsYXNzLnNob3ddPVwic2hvdyQgfCBhc3luY1wiXG4gICAgIFtjbGFzcy5oLTEwMF09XCJvZmZjYW52YXNIZWlnaHQxMDAkIHwgYXN5bmNcIlxuICAgICBbc3R5bGUuaGVpZ2h0LnB4XT1cInNpemVcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiY29udGVudDsgY29udGV4dDogeyAkaW1wbGljaXQ6IHRoaXMgfVwiID48L25nLWNvbnRhaW5lcj5cbjwvZGl2PiJdfQ==
@@ -0,0 +1,14 @@
1
+ import { Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class BsOffcanvasBodyComponent {
4
+ constructor() { }
5
+ ngOnInit() {
6
+ }
7
+ }
8
+ BsOffcanvasBodyComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasBodyComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
9
+ BsOffcanvasBodyComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", type: BsOffcanvasBodyComponent, selector: "bs-offcanvas-body", ngImport: i0, template: "<div class=\"offcanvas-body small\">\n <ng-content></ng-content>\n</div>", styles: [""] });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasBodyComponent, decorators: [{
11
+ type: Component,
12
+ args: [{ selector: 'bs-offcanvas-body', template: "<div class=\"offcanvas-body small\">\n <ng-content></ng-content>\n</div>", styles: [""] }]
13
+ }], ctorParameters: function () { return []; } });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2ZmY2FudmFzLWJvZHkuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvb2ZmY2FudmFzL2NvbXBvbmVudHMvb2ZmY2FudmFzLWJvZHkvb2ZmY2FudmFzLWJvZHkuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvb2ZmY2FudmFzL2NvbXBvbmVudHMvb2ZmY2FudmFzLWJvZHkvb2ZmY2FudmFzLWJvZHkuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFPbEQsTUFBTSxPQUFPLHdCQUF3QjtJQUVuQyxnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQzs7cUhBTFUsd0JBQXdCO3lHQUF4Qix3QkFBd0IseURDUHJDLDZFQUVNOzJGREtPLHdCQUF3QjtrQkFMcEMsU0FBUzsrQkFDRSxtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdicy1vZmZjYW52YXMtYm9keScsXG4gIHRlbXBsYXRlVXJsOiAnLi9vZmZjYW52YXMtYm9keS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL29mZmNhbnZhcy1ib2R5LmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQnNPZmZjYW52YXNCb2R5Q29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbn1cbiIsIjxkaXYgY2xhc3M9XCJvZmZjYW52YXMtYm9keSBzbWFsbFwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PiJdfQ==
@@ -0,0 +1,14 @@
1
+ import { Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class BsOffcanvasHeaderComponent {
4
+ constructor() { }
5
+ ngOnInit() {
6
+ }
7
+ }
8
+ BsOffcanvasHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
9
+ BsOffcanvasHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", type: BsOffcanvasHeaderComponent, selector: "bs-offcanvas-header", ngImport: i0, template: "<div class=\"offcanvas-header\">\n <ng-content></ng-content>\n</div>\n", styles: [""] });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasHeaderComponent, decorators: [{
11
+ type: Component,
12
+ args: [{ selector: 'bs-offcanvas-header', template: "<div class=\"offcanvas-header\">\n <ng-content></ng-content>\n</div>\n", styles: [""] }]
13
+ }], ctorParameters: function () { return []; } });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2ZmY2FudmFzLWhlYWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9vZmZjYW52YXMvY29tcG9uZW50cy9vZmZjYW52YXMtaGVhZGVyL29mZmNhbnZhcy1oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvb2ZmY2FudmFzL2NvbXBvbmVudHMvb2ZmY2FudmFzLWhlYWRlci9vZmZjYW52YXMtaGVhZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7O0FBT2xELE1BQU0sT0FBTywwQkFBMEI7SUFFckMsZ0JBQWdCLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7O3VIQUxVLDBCQUEwQjsyR0FBMUIsMEJBQTBCLDJEQ1B2QywyRUFHQTsyRkRJYSwwQkFBMEI7a0JBTHRDLFNBQVM7K0JBQ0UscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYnMtb2ZmY2FudmFzLWhlYWRlcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9vZmZjYW52YXMtaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vb2ZmY2FudmFzLWhlYWRlci5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEJzT2ZmY2FudmFzSGVhZGVyQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBjb25zdHJ1Y3RvcigpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbn1cbiIsIjxkaXYgY2xhc3M9XCJvZmZjYW52YXMtaGVhZGVyXCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuPC9kaXY+XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export * from './offcanvas-close/offcanvas-close.directive';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9vZmZjYW52YXMvZGlyZWN0aXZlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZDQUE2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9vZmZjYW52YXMtY2xvc2Uvb2ZmY2FudmFzLWNsb3NlLmRpcmVjdGl2ZSc7XG4iXX0=
@@ -0,0 +1,27 @@
1
+ import { Directive, HostListener, Input } from '@angular/core';
2
+ import { BsOffcanvasComponent } from '../../components/offcanvas/offcanvas.component';
3
+ import { BsOffcanvasService } from '../../services/offcanvas/offcanvas.service';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../services/offcanvas/offcanvas.service";
6
+ export class BsOffcanvasCloseDirective {
7
+ constructor(offcanvasService) {
8
+ this.offcanvasService = offcanvasService;
9
+ }
10
+ onClick() {
11
+ this.offcanvasService.hide(this.bsOffcanvasClose);
12
+ }
13
+ }
14
+ BsOffcanvasCloseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasCloseDirective, deps: [{ token: i1.BsOffcanvasService }], target: i0.ɵɵFactoryTarget.Directive });
15
+ BsOffcanvasCloseDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.0", type: BsOffcanvasCloseDirective, selector: "[bsOffcanvasClose]", inputs: { bsOffcanvasClose: "bsOffcanvasClose" }, host: { listeners: { "click": "onClick()" } }, ngImport: i0 });
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasCloseDirective, decorators: [{
17
+ type: Directive,
18
+ args: [{
19
+ selector: '[bsOffcanvasClose]'
20
+ }]
21
+ }], ctorParameters: function () { return [{ type: i1.BsOffcanvasService }]; }, propDecorators: { bsOffcanvasClose: [{
22
+ type: Input
23
+ }], onClick: [{
24
+ type: HostListener,
25
+ args: ['click']
26
+ }] } });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2ZmY2FudmFzLWNsb3NlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL29mZmNhbnZhcy9kaXJlY3RpdmVzL29mZmNhbnZhcy1jbG9zZS9vZmZjYW52YXMtY2xvc2UuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUN0RixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQzs7O0FBS2hGLE1BQU0sT0FBTyx5QkFBeUI7SUFDcEMsWUFBb0IsZ0JBQW9DO1FBQXBDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBb0I7SUFBSSxDQUFDO0lBSXRDLE9BQU87UUFDNUIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUNwRCxDQUFDOztzSEFQVSx5QkFBeUI7MEdBQXpCLHlCQUF5QjsyRkFBekIseUJBQXlCO2tCQUhyQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7aUJBQy9CO3lHQUlpQixnQkFBZ0I7c0JBQS9CLEtBQUs7Z0JBRWlCLE9BQU87c0JBQTdCLFlBQVk7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdExpc3RlbmVyLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQnNPZmZjYW52YXNDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL29mZmNhbnZhcy9vZmZjYW52YXMuY29tcG9uZW50JztcbmltcG9ydCB7IEJzT2ZmY2FudmFzU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL29mZmNhbnZhcy9vZmZjYW52YXMuc2VydmljZSc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tic09mZmNhbnZhc0Nsb3NlXSdcbn0pXG5leHBvcnQgY2xhc3MgQnNPZmZjYW52YXNDbG9zZURpcmVjdGl2ZSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgb2ZmY2FudmFzU2VydmljZTogQnNPZmZjYW52YXNTZXJ2aWNlKSB7IH1cblxuICBASW5wdXQoKSBwdWJsaWMgYnNPZmZjYW52YXNDbG9zZSE6IEJzT2ZmY2FudmFzQ29tcG9uZW50O1xuXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJykgb25DbGljaygpIHtcbiAgICB0aGlzLm9mZmNhbnZhc1NlcnZpY2UuaGlkZSh0aGlzLmJzT2ZmY2FudmFzQ2xvc2UpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,7 @@
1
+ export * from './services';
2
+ export * from './offcanvas.module';
3
+ export * from './components';
4
+ export * from './interfaces';
5
+ export * from './directives';
6
+ export * from './types';
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9vZmZjYW52YXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9vZmZjYW52YXMubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2ludGVyZmFjZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzJztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnOyJdfQ==
@@ -0,0 +1,2 @@
1
+ export * from './offcanvas-animation-meta';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9vZmZjYW52YXMvaW50ZXJmYWNlcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9vZmZjYW52YXMtYW5pbWF0aW9uLW1ldGEnO1xuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2ZmY2FudmFzLWFuaW1hdGlvbi1tZXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9taW50cGxheWVyLW5nLWJvb3RzdHJhcC9zcmMvbGliL2NvbXBvbmVudHMvb2ZmY2FudmFzL2ludGVyZmFjZXMvb2ZmY2FudmFzLWFuaW1hdGlvbi1tZXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPdmVybGF5UmVmIH0gZnJvbSBcIkBhbmd1bGFyL2Nkay9vdmVybGF5XCI7XG5pbXBvcnQgeyBDb21wb25lbnRSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQnNPZmZjYW52YXNDb21wb25lbnQgfSBmcm9tIFwiLi4vY29tcG9uZW50cy9vZmZjYW52YXMvb2ZmY2FudmFzLmNvbXBvbmVudFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIE9mZmNhbnZhc0FuaW1hdGlvbk1ldGEge1xuICAgIGNvbXBvbmVudDogQ29tcG9uZW50UmVmPEJzT2ZmY2FudmFzQ29tcG9uZW50PjtcbiAgICBvdmVybGF5OiBPdmVybGF5UmVmO1xufSJdfQ==
@@ -0,0 +1,45 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { OverlayModule } from '@angular/cdk/overlay';
4
+ import { BsOffcanvasHeaderComponent } from './components/offcanvas-header/offcanvas-header.component';
5
+ import { BsOffcanvasBodyComponent } from './components/offcanvas-body/offcanvas-body.component';
6
+ import { BsOffcanvasComponent } from './components/offcanvas/offcanvas.component';
7
+ import { BsOffcanvasCloseDirective } from './directives/offcanvas-close/offcanvas-close.directive';
8
+ import * as i0 from "@angular/core";
9
+ export class BsOffcanvasModule {
10
+ }
11
+ BsOffcanvasModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
+ BsOffcanvasModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasModule, declarations: [BsOffcanvasComponent,
13
+ BsOffcanvasHeaderComponent,
14
+ BsOffcanvasBodyComponent,
15
+ BsOffcanvasCloseDirective], imports: [CommonModule,
16
+ OverlayModule], exports: [BsOffcanvasComponent,
17
+ BsOffcanvasHeaderComponent,
18
+ BsOffcanvasBodyComponent,
19
+ BsOffcanvasCloseDirective] });
20
+ BsOffcanvasModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasModule, imports: [[
21
+ CommonModule,
22
+ OverlayModule
23
+ ]] });
24
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasModule, decorators: [{
25
+ type: NgModule,
26
+ args: [{
27
+ declarations: [
28
+ BsOffcanvasComponent,
29
+ BsOffcanvasHeaderComponent,
30
+ BsOffcanvasBodyComponent,
31
+ BsOffcanvasCloseDirective
32
+ ],
33
+ imports: [
34
+ CommonModule,
35
+ OverlayModule
36
+ ],
37
+ exports: [
38
+ BsOffcanvasComponent,
39
+ BsOffcanvasHeaderComponent,
40
+ BsOffcanvasBodyComponent,
41
+ BsOffcanvasCloseDirective
42
+ ]
43
+ }]
44
+ }] });
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2ZmY2FudmFzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvbWludHBsYXllci1uZy1ib290c3RyYXAvc3JjL2xpYi9jb21wb25lbnRzL29mZmNhbnZhcy9vZmZjYW52YXMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSwwREFBMEQsQ0FBQztBQUN0RyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUNoRyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUNsRixPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSx3REFBd0QsQ0FBQzs7QUFzQm5HLE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFoQjFCLG9CQUFvQjtRQUNwQiwwQkFBMEI7UUFDMUIsd0JBQXdCO1FBQ3hCLHlCQUF5QixhQUd6QixZQUFZO1FBQ1osYUFBYSxhQUdiLG9CQUFvQjtRQUNwQiwwQkFBMEI7UUFDMUIsd0JBQXdCO1FBQ3hCLHlCQUF5QjsrR0FHaEIsaUJBQWlCLFlBWG5CO1lBQ1AsWUFBWTtZQUNaLGFBQWE7U0FDZDsyRkFRVSxpQkFBaUI7a0JBbEI3QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixvQkFBb0I7d0JBQ3BCLDBCQUEwQjt3QkFDMUIsd0JBQXdCO3dCQUN4Qix5QkFBeUI7cUJBQzFCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7cUJBQ2Q7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLG9CQUFvQjt3QkFDcEIsMEJBQTBCO3dCQUMxQix3QkFBd0I7d0JBQ3hCLHlCQUF5QjtxQkFDMUI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE92ZXJsYXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBCc09mZmNhbnZhc0hlYWRlckNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9vZmZjYW52YXMtaGVhZGVyL29mZmNhbnZhcy1oZWFkZXIuY29tcG9uZW50JztcbmltcG9ydCB7IEJzT2ZmY2FudmFzQm9keUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9vZmZjYW52YXMtYm9keS9vZmZjYW52YXMtYm9keS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQnNPZmZjYW52YXNDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvb2ZmY2FudmFzL29mZmNhbnZhcy5jb21wb25lbnQnO1xuaW1wb3J0IHsgQnNPZmZjYW52YXNDbG9zZURpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9vZmZjYW52YXMtY2xvc2Uvb2ZmY2FudmFzLWNsb3NlLmRpcmVjdGl2ZSc7XG5cblxuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBCc09mZmNhbnZhc0NvbXBvbmVudCxcbiAgICBCc09mZmNhbnZhc0hlYWRlckNvbXBvbmVudCxcbiAgICBCc09mZmNhbnZhc0JvZHlDb21wb25lbnQsXG4gICAgQnNPZmZjYW52YXNDbG9zZURpcmVjdGl2ZVxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE92ZXJsYXlNb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEJzT2ZmY2FudmFzQ29tcG9uZW50LFxuICAgIEJzT2ZmY2FudmFzSGVhZGVyQ29tcG9uZW50LFxuICAgIEJzT2ZmY2FudmFzQm9keUNvbXBvbmVudCxcbiAgICBCc09mZmNhbnZhc0Nsb3NlRGlyZWN0aXZlXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgQnNPZmZjYW52YXNNb2R1bGUgeyB9XG4iXX0=
@@ -0,0 +1,3 @@
1
+ import { InjectionToken } from "@angular/core";
2
+ export const OFFCANVAS_CONTENT = new InjectionToken('OffcanvasContent');
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2ZmY2FudmFzLWNvbnRlbnQucHJvdmlkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9vZmZjYW52YXMvcHJvdmlkZXJzL29mZmNhbnZhcy1jb250ZW50LnByb3ZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQWUsTUFBTSxlQUFlLENBQUM7QUFFNUQsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxjQUFjLENBQW1CLGtCQUFrQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiwgVGVtcGxhdGVSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5leHBvcnQgY29uc3QgT0ZGQ0FOVkFTX0NPTlRFTlQgPSBuZXcgSW5qZWN0aW9uVG9rZW48VGVtcGxhdGVSZWY8YW55Pj4oJ09mZmNhbnZhc0NvbnRlbnQnKTsiXX0=
@@ -0,0 +1,2 @@
1
+ export * from './offcanvas/offcanvas.service';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9vZmZjYW52YXMvc2VydmljZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vb2ZmY2FudmFzL29mZmNhbnZhcy5zZXJ2aWNlJztcbiJdfQ==
@@ -0,0 +1,72 @@
1
+ import { Overlay } from '@angular/cdk/overlay';
2
+ import { ComponentPortal } from '@angular/cdk/portal';
3
+ import { Injectable, Injector } from '@angular/core';
4
+ import { BsOffcanvasModule } from '../../offcanvas.module';
5
+ import { BsOffcanvasComponent } from '../../components/offcanvas/offcanvas.component';
6
+ import { OFFCANVAS_CONTENT } from '../../providers/offcanvas-content.provider';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/cdk/overlay";
9
+ export class BsOffcanvasService {
10
+ constructor(overlay, parentInjector) {
11
+ this.overlay = overlay;
12
+ this.parentInjector = parentInjector;
13
+ }
14
+ show(template, position, hasBackdrop = false, backdropClick = null) {
15
+ const injector = Injector.create({
16
+ providers: [{ provide: OFFCANVAS_CONTENT, useValue: template }],
17
+ parent: this.parentInjector
18
+ });
19
+ const portal = new ComponentPortal(BsOffcanvasComponent, null, injector);
20
+ const positioning = this.overlay.position().global();
21
+ const config = {
22
+ scrollStrategy: this.overlay.scrollStrategies.reposition(),
23
+ positionStrategy: positioning,
24
+ hasBackdrop,
25
+ };
26
+ switch (position) {
27
+ case 'bottom':
28
+ positioning.centerHorizontally().bottom('0');
29
+ config.width = '100%';
30
+ break;
31
+ case 'top':
32
+ positioning.centerHorizontally().top('0');
33
+ config.width = '100%';
34
+ break;
35
+ case 'start':
36
+ positioning.centerVertically().left('0');
37
+ config.height = '100%';
38
+ break;
39
+ case 'end':
40
+ positioning.centerVertically().right('0');
41
+ config.height = '100%';
42
+ break;
43
+ default:
44
+ throw 'Invalid value for position';
45
+ }
46
+ const overlayRef = this.overlay.create(config);
47
+ const componentInstance = overlayRef.attach(portal);
48
+ componentInstance.instance.position = position;
49
+ setTimeout(() => componentInstance.instance.show$.next(true));
50
+ componentInstance.instance['instance'] = {
51
+ component: componentInstance,
52
+ overlay: overlayRef
53
+ };
54
+ if (hasBackdrop && backdropClick) {
55
+ overlayRef.backdropClick().subscribe(() => backdropClick(componentInstance.instance));
56
+ }
57
+ return componentInstance.instance;
58
+ }
59
+ hide(offcanvas) {
60
+ offcanvas.show$.next(false);
61
+ setTimeout(() => offcanvas['instance']?.overlay.dispose(), 300);
62
+ }
63
+ }
64
+ BsOffcanvasService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasService, deps: [{ token: i1.Overlay }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
65
+ BsOffcanvasService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasService, providedIn: BsOffcanvasModule });
66
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: BsOffcanvasService, decorators: [{
67
+ type: Injectable,
68
+ args: [{
69
+ providedIn: BsOffcanvasModule
70
+ }]
71
+ }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.Injector }]; } });
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib2ZmY2FudmFzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9vZmZjYW52YXMvc2VydmljZXMvb2ZmY2FudmFzL29mZmNhbnZhcy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQWlCLE1BQU0sc0JBQXNCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFlLE1BQU0sZUFBZSxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzNELE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBRXRGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRDQUE0QyxDQUFDOzs7QUFLL0UsTUFBTSxPQUFPLGtCQUFrQjtJQUU3QixZQUNVLE9BQWdCLEVBQ2hCLGNBQXdCO1FBRHhCLFlBQU8sR0FBUCxPQUFPLENBQVM7UUFDaEIsbUJBQWMsR0FBZCxjQUFjLENBQVU7SUFDOUIsQ0FBQztJQUVFLElBQUksQ0FBQyxRQUEwQixFQUFFLFFBQTRDLEVBQUUsV0FBVyxHQUFHLEtBQUssRUFBRSxnQkFBb0UsSUFBSTtRQUNqTCxNQUFNLFFBQVEsR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDO1lBQy9CLFNBQVMsRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQztZQUMvRCxNQUFNLEVBQUUsSUFBSSxDQUFDLGNBQWM7U0FDNUIsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxNQUFNLEdBQUcsSUFBSSxlQUFlLENBQUMsb0JBQW9CLEVBQUUsSUFBSSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBRXpFLE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDckQsTUFBTSxNQUFNLEdBQWtCO1lBQzVCLGNBQWMsRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLFVBQVUsRUFBRTtZQUMxRCxnQkFBZ0IsRUFBRSxXQUFXO1lBQzdCLFdBQVc7U0FDWixDQUFDO1FBRUYsUUFBUSxRQUFRLEVBQUU7WUFDaEIsS0FBSyxRQUFRO2dCQUNYLFdBQVcsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDN0MsTUFBTSxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUM7Z0JBQ3RCLE1BQU07WUFDUixLQUFLLEtBQUs7Z0JBQ1IsV0FBVyxDQUFDLGtCQUFrQixFQUFFLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO2dCQUMxQyxNQUFNLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQztnQkFDdEIsTUFBTTtZQUNSLEtBQUssT0FBTztnQkFDVixXQUFXLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ3pDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO2dCQUN2QixNQUFNO1lBQ1IsS0FBSyxLQUFLO2dCQUNSLFdBQVcsQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDMUMsTUFBTSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7Z0JBQ3ZCLE1BQU07WUFFUjtnQkFDRSxNQUFNLDRCQUE0QixDQUFDO1NBQ3RDO1FBRUQsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFFL0MsTUFBTSxpQkFBaUIsR0FBRyxVQUFVLENBQUMsTUFBTSxDQUF1QixNQUFNLENBQUMsQ0FBQztRQUMxRSxpQkFBaUIsQ0FBQyxRQUFRLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztRQUMvQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsaUJBQWlCLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztRQUU5RCxpQkFBaUIsQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLEdBQTJCO1lBQy9ELFNBQVMsRUFBRSxpQkFBaUI7WUFDNUIsT0FBTyxFQUFFLFVBQVU7U0FDcEIsQ0FBQztRQUVGLElBQUksV0FBVyxJQUFJLGFBQWEsRUFBRTtZQUNoQyxVQUFVLENBQUMsYUFBYSxFQUFFLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLGFBQWEsQ0FBQyxpQkFBaUIsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1NBQ3ZGO1FBRUQsT0FBTyxpQkFBaUIsQ0FBQyxRQUFRLENBQUM7SUFDcEMsQ0FBQztJQUVNLElBQUksQ0FBQyxTQUErQjtRQUN6QyxTQUFTLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUM1QixVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxPQUFPLEVBQUUsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUNsRSxDQUFDOzsrR0FoRVUsa0JBQWtCO21IQUFsQixrQkFBa0IsY0FGakIsaUJBQWlCOzJGQUVsQixrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLGlCQUFpQjtpQkFDOUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPdmVybGF5LCBPdmVybGF5Q29uZmlnIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgQ29tcG9uZW50UG9ydGFsIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3BvcnRhbCc7XG5pbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3RvciwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJzT2ZmY2FudmFzTW9kdWxlIH0gZnJvbSAnLi4vLi4vb2ZmY2FudmFzLm1vZHVsZSc7XG5pbXBvcnQgeyBCc09mZmNhbnZhc0NvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvb2ZmY2FudmFzL29mZmNhbnZhcy5jb21wb25lbnQnO1xuaW1wb3J0IHsgT2ZmY2FudmFzQW5pbWF0aW9uTWV0YSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvb2ZmY2FudmFzLWFuaW1hdGlvbi1tZXRhJztcbmltcG9ydCB7IE9GRkNBTlZBU19DT05URU5UIH0gZnJvbSAnLi4vLi4vcHJvdmlkZXJzL29mZmNhbnZhcy1jb250ZW50LnByb3ZpZGVyJztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiBCc09mZmNhbnZhc01vZHVsZVxufSlcbmV4cG9ydCBjbGFzcyBCc09mZmNhbnZhc1NlcnZpY2Uge1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgb3ZlcmxheTogT3ZlcmxheSxcbiAgICBwcml2YXRlIHBhcmVudEluamVjdG9yOiBJbmplY3RvcixcbiAgKSB7IH1cblxuICBwdWJsaWMgc2hvdyh0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PiwgcG9zaXRpb246ICd0b3AnIHwgJ2JvdHRvbScgfCAnc3RhcnQnIHwgJ2VuZCcsIGhhc0JhY2tkcm9wID0gZmFsc2UsIGJhY2tkcm9wQ2xpY2s6ICgob2ZmY2FudmFzOiBCc09mZmNhbnZhc0NvbXBvbmVudCkgPT4gdm9pZCkgfCBudWxsID0gbnVsbCkge1xuICAgIGNvbnN0IGluamVjdG9yID0gSW5qZWN0b3IuY3JlYXRlKHtcbiAgICAgIHByb3ZpZGVyczogW3sgcHJvdmlkZTogT0ZGQ0FOVkFTX0NPTlRFTlQsIHVzZVZhbHVlOiB0ZW1wbGF0ZSB9XSxcbiAgICAgIHBhcmVudDogdGhpcy5wYXJlbnRJbmplY3RvclxuICAgIH0pO1xuICAgIGNvbnN0IHBvcnRhbCA9IG5ldyBDb21wb25lbnRQb3J0YWwoQnNPZmZjYW52YXNDb21wb25lbnQsIG51bGwsIGluamVjdG9yKTtcbiAgXG4gICAgY29uc3QgcG9zaXRpb25pbmcgPSB0aGlzLm92ZXJsYXkucG9zaXRpb24oKS5nbG9iYWwoKTtcbiAgICBjb25zdCBjb25maWc6IE92ZXJsYXlDb25maWcgPSB7XG4gICAgICBzY3JvbGxTdHJhdGVneTogdGhpcy5vdmVybGF5LnNjcm9sbFN0cmF0ZWdpZXMucmVwb3NpdGlvbigpLFxuICAgICAgcG9zaXRpb25TdHJhdGVneTogcG9zaXRpb25pbmcsXG4gICAgICBoYXNCYWNrZHJvcCxcbiAgICB9O1xuXG4gICAgc3dpdGNoIChwb3NpdGlvbikge1xuICAgICAgY2FzZSAnYm90dG9tJzpcbiAgICAgICAgcG9zaXRpb25pbmcuY2VudGVySG9yaXpvbnRhbGx5KCkuYm90dG9tKCcwJyk7XG4gICAgICAgIGNvbmZpZy53aWR0aCA9ICcxMDAlJztcbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlICd0b3AnOlxuICAgICAgICBwb3NpdGlvbmluZy5jZW50ZXJIb3Jpem9udGFsbHkoKS50b3AoJzAnKTtcbiAgICAgICAgY29uZmlnLndpZHRoID0gJzEwMCUnO1xuICAgICAgICBicmVhaztcbiAgICAgIGNhc2UgJ3N0YXJ0JzpcbiAgICAgICAgcG9zaXRpb25pbmcuY2VudGVyVmVydGljYWxseSgpLmxlZnQoJzAnKTtcbiAgICAgICAgY29uZmlnLmhlaWdodCA9ICcxMDAlJztcbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlICdlbmQnOlxuICAgICAgICBwb3NpdGlvbmluZy5jZW50ZXJWZXJ0aWNhbGx5KCkucmlnaHQoJzAnKTtcbiAgICAgICAgY29uZmlnLmhlaWdodCA9ICcxMDAlJztcbiAgICAgICAgYnJlYWs7XG4gICAgICAgICAgXG4gICAgICBkZWZhdWx0OlxuICAgICAgICB0aHJvdyAnSW52YWxpZCB2YWx1ZSBmb3IgcG9zaXRpb24nO1xuICAgIH1cblxuICAgIGNvbnN0IG92ZXJsYXlSZWYgPSB0aGlzLm92ZXJsYXkuY3JlYXRlKGNvbmZpZyk7XG4gIFxuICAgIGNvbnN0IGNvbXBvbmVudEluc3RhbmNlID0gb3ZlcmxheVJlZi5hdHRhY2g8QnNPZmZjYW52YXNDb21wb25lbnQ+KHBvcnRhbCk7XG4gICAgY29tcG9uZW50SW5zdGFuY2UuaW5zdGFuY2UucG9zaXRpb24gPSBwb3NpdGlvbjtcbiAgICBzZXRUaW1lb3V0KCgpID0+IGNvbXBvbmVudEluc3RhbmNlLmluc3RhbmNlLnNob3ckLm5leHQodHJ1ZSkpO1xuICAgIFxuICAgIGNvbXBvbmVudEluc3RhbmNlLmluc3RhbmNlWydpbnN0YW5jZSddID0gPE9mZmNhbnZhc0FuaW1hdGlvbk1ldGE+e1xuICAgICAgY29tcG9uZW50OiBjb21wb25lbnRJbnN0YW5jZSxcbiAgICAgIG92ZXJsYXk6IG92ZXJsYXlSZWZcbiAgICB9O1xuXG4gICAgaWYgKGhhc0JhY2tkcm9wICYmIGJhY2tkcm9wQ2xpY2spIHtcbiAgICAgIG92ZXJsYXlSZWYuYmFja2Ryb3BDbGljaygpLnN1YnNjcmliZSgoKSA9PiBiYWNrZHJvcENsaWNrKGNvbXBvbmVudEluc3RhbmNlLmluc3RhbmNlKSk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGNvbXBvbmVudEluc3RhbmNlLmluc3RhbmNlO1xuICB9XG5cbiAgcHVibGljIGhpZGUob2ZmY2FudmFzOiBCc09mZmNhbnZhc0NvbXBvbmVudCkge1xuICAgIG9mZmNhbnZhcy5zaG93JC5uZXh0KGZhbHNlKTtcbiAgICBzZXRUaW1lb3V0KCgpID0+IG9mZmNhbnZhc1snaW5zdGFuY2UnXT8ub3ZlcmxheS5kaXNwb3NlKCksIDMwMCk7XG4gIH1cblxufVxuIl19
@@ -0,0 +1,2 @@
1
+ export * from './position';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9vZmZjYW52YXMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxZQUFZLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3Bvc2l0aW9uJzsiXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zaXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9vZmZjYW52YXMvdHlwZXMvcG9zaXRpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIE9mZmNhbnZhc1Bvc2l0aW9uID0gJ3RvcCcgfCAnYm90dG9tJyB8ICdzdGFydCcgfCAnZW5kJzsiXX0=
@@ -1,2 +1,3 @@
1
1
  export * from './scheduler/scheduler.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9zY2hlZHVsZXIvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zY2hlZHVsZXIvc2NoZWR1bGVyLmNvbXBvbmVudCc7Il19
2
+ export * from './resource-group-presenter/resource-group-presenter.component';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL21pbnRwbGF5ZXItbmctYm9vdHN0cmFwL3NyYy9saWIvY29tcG9uZW50cy9zY2hlZHVsZXIvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsK0RBQStELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3NjaGVkdWxlci9zY2hlZHVsZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcmVzb3VyY2UtZ3JvdXAtcHJlc2VudGVyL3Jlc291cmNlLWdyb3VwLXByZXNlbnRlci5jb21wb25lbnQnOyJdfQ==
@@ -0,0 +1,84 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import { BehaviorSubject, filter, map, Subject, take } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ export class ResourceGroupPresenterComponent {
6
+ constructor() {
7
+ this.level = 0;
8
+ this.resourceOrGroup$ = new BehaviorSubject(null);
9
+ this.timeSlots$ = new BehaviorSubject([]);
10
+ this.isExpanded$ = new BehaviorSubject(false);
11
+ this.destroyed$ = new Subject();
12
+ this.data$ = this.resourceOrGroup$
13
+ .pipe(map((resourceOrGroup) => {
14
+ if (!resourceOrGroup) {
15
+ return null;
16
+ }
17
+ else if ('children' in resourceOrGroup) {
18
+ return {
19
+ resource: null,
20
+ resourceGroup: resourceOrGroup
21
+ };
22
+ }
23
+ else {
24
+ return {
25
+ resource: resourceOrGroup,
26
+ resourceGroup: null
27
+ };
28
+ }
29
+ }))
30
+ .pipe(filter((resourceOrGroup) => !!resourceOrGroup))
31
+ .pipe(map((resourceOrGroup) => resourceOrGroup));
32
+ this.colSpan$ = this.timeSlots$
33
+ .pipe(map(timeSlots => timeSlots
34
+ .map(timeslot => timeslot.slots.length)
35
+ .reduce((sum, current) => sum + current, 0)));
36
+ }
37
+ //#region resourceOrGroup
38
+ get resourceOrGroup() {
39
+ return this.resourceOrGroup$.value;
40
+ }
41
+ set resourceGroup(value) {
42
+ this.resourceOrGroup$.next(value);
43
+ }
44
+ //#endregion
45
+ //#region timeSlots
46
+ get timeSlots() {
47
+ return this.timeSlots$.value;
48
+ }
49
+ set timeSlots(value) {
50
+ this.timeSlots$.next(value);
51
+ }
52
+ //#endregion
53
+ //#region isExpanded
54
+ get isExpanded() {
55
+ return this.isExpanded$.value;
56
+ }
57
+ set isExpanded(value) {
58
+ this.isExpanded$.next(value);
59
+ }
60
+ //#endregion
61
+ toggleExpanded() {
62
+ this.isExpanded$.pipe(take(1)).subscribe((isExpanded) => {
63
+ this.isExpanded$.next(!isExpanded);
64
+ });
65
+ }
66
+ ngOnDestroy() {
67
+ this.destroyed$.next(true);
68
+ }
69
+ }
70
+ ResourceGroupPresenterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: ResourceGroupPresenterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
71
+ ResourceGroupPresenterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", type: ResourceGroupPresenterComponent, selector: "bs-resource-group-presenter", inputs: { level: "level", resourceGroup: "resourceGroup", timeSlots: "timeSlots", isExpanded: "isExpanded" }, ngImport: i0, template: "<ng-container *ngIf=\"(data$ | async) as data\">\n\n <!-- Data is a resource group -->\n <ng-container *ngIf=\"data.resourceGroup\">\n <!-- Header -->\n <tr class=\"p-0 cursor-pointer\" *ngIf=\"(timeSlots$ | async) as timeSlots\" [title]=\"data.resourceGroup.description\">\n <ng-container *ngIf=\"(colSpan$ | async) as colspan\">\n <td class=\"p-2 cursor-pointer\" [colSpan]=\"colspan + 1\" (click)=\"toggleExpanded()\">\n <span class=\"p-2 align-middle position-sticky\">\n <i class=\"bi bi-chevron-down\" [style.padding-left.px]=\"level * 20\" *ngIf=\"isExpanded$ | async\"></i>\n <i class=\"bi bi-chevron-right\" [style.padding-left.px]=\"level * 20\" *ngIf=\"(isExpanded$ | async) === false\"></i>\n {{ data.resourceGroup.description }}\n </span>\n </td>\n </ng-container>\n </tr>\n\n <!-- Subgroups or resources -->\n <ng-container *ngIf=\"isExpanded$ | async\">\n <ng-container *ngIf=\"(timeSlots$ | async) as timeSlots\">\n <ng-container *ngFor=\"let child of data.resourceGroup.children\">\n <bs-resource-group-presenter [resourceGroup]=\"child\" [timeSlots]=\"timeSlots\" [level]=\"level + 1\"></bs-resource-group-presenter>\n </ng-container>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <!-- Data is a resource -->\n <tr *ngIf=\"data.resource\" class=\"p-0 bordered\" [title]=\"data.resource.description\">\n <td class=\"p-0 bg-white\">\n <div class=\"p-2\">{{ data.resource.description }}</div>\n </td>\n <ng-container *ngFor=\"let slots of (timeSlots$ | async)\">\n <td class=\"bg-white border-1\" *ngFor=\"let slot of slots.slots\">\n <!-- {{ slot.start | date: 'dd/MM/yyyy HH:mm:ss' }} -->\n </td>\n </ng-container>\n </tr>\n</ng-container>", styles: [":host{display:contents}tr{border-bottom-width:1px}tr:not(.bordered) td span.position-sticky{left:0;right:0}\n"], components: [{ type: ResourceGroupPresenterComponent, selector: "bs-resource-group-presenter", inputs: ["level", "resourceGroup", "timeSlots", "isExpanded"] }], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i1.AsyncPipe } });
72
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: ResourceGroupPresenterComponent, decorators: [{
73
+ type: Component,
74
+ args: [{ selector: 'bs-resource-group-presenter', template: "<ng-container *ngIf=\"(data$ | async) as data\">\n\n <!-- Data is a resource group -->\n <ng-container *ngIf=\"data.resourceGroup\">\n <!-- Header -->\n <tr class=\"p-0 cursor-pointer\" *ngIf=\"(timeSlots$ | async) as timeSlots\" [title]=\"data.resourceGroup.description\">\n <ng-container *ngIf=\"(colSpan$ | async) as colspan\">\n <td class=\"p-2 cursor-pointer\" [colSpan]=\"colspan + 1\" (click)=\"toggleExpanded()\">\n <span class=\"p-2 align-middle position-sticky\">\n <i class=\"bi bi-chevron-down\" [style.padding-left.px]=\"level * 20\" *ngIf=\"isExpanded$ | async\"></i>\n <i class=\"bi bi-chevron-right\" [style.padding-left.px]=\"level * 20\" *ngIf=\"(isExpanded$ | async) === false\"></i>\n {{ data.resourceGroup.description }}\n </span>\n </td>\n </ng-container>\n </tr>\n\n <!-- Subgroups or resources -->\n <ng-container *ngIf=\"isExpanded$ | async\">\n <ng-container *ngIf=\"(timeSlots$ | async) as timeSlots\">\n <ng-container *ngFor=\"let child of data.resourceGroup.children\">\n <bs-resource-group-presenter [resourceGroup]=\"child\" [timeSlots]=\"timeSlots\" [level]=\"level + 1\"></bs-resource-group-presenter>\n </ng-container>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <!-- Data is a resource -->\n <tr *ngIf=\"data.resource\" class=\"p-0 bordered\" [title]=\"data.resource.description\">\n <td class=\"p-0 bg-white\">\n <div class=\"p-2\">{{ data.resource.description }}</div>\n </td>\n <ng-container *ngFor=\"let slots of (timeSlots$ | async)\">\n <td class=\"bg-white border-1\" *ngFor=\"let slot of slots.slots\">\n <!-- {{ slot.start | date: 'dd/MM/yyyy HH:mm:ss' }} -->\n </td>\n </ng-container>\n </tr>\n</ng-container>", styles: [":host{display:contents}tr{border-bottom-width:1px}tr:not(.bordered) td span.position-sticky{left:0;right:0}\n"] }]
75
+ }], ctorParameters: function () { return []; }, propDecorators: { level: [{
76
+ type: Input
77
+ }], resourceGroup: [{
78
+ type: Input
79
+ }], timeSlots: [{
80
+ type: Input
81
+ }], isExpanded: [{
82
+ type: Input
83
+ }] } });
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-group-presenter.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/scheduler/components/resource-group-presenter/resource-group-presenter.component.ts","../../../../../../../../../libs/mintplayer-ng-bootstrap/src/lib/components/scheduler/components/resource-group-presenter/resource-group-presenter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy } from '@angular/core';\nimport { BehaviorSubject, filter, map, Observable, Subject, take, takeUntil } from 'rxjs';\nimport { Resource, ResourceGroup } from '../../interfaces';\nimport { ResourceOrGroup } from '../../interfaces/resource-or-group';\nimport { SchedulerStampWithSlots } from '../../interfaces/scheduler-stamp-with-slots';\nimport { TimeSlot } from '../../interfaces/time-slot';\n\n@Component({\n  selector: 'bs-resource-group-presenter',\n  templateUrl: './resource-group-presenter.component.html',\n  styleUrls: ['./resource-group-presenter.component.scss'],\n  \n})\nexport class ResourceGroupPresenterComponent implements OnDestroy {\n  \n  constructor() {\n    this.data$ = this.resourceOrGroup$\n      .pipe(map((resourceOrGroup) => {\n        if (!resourceOrGroup) {\n          return null;\n        } else if ('children' in resourceOrGroup) {\n          return <ResourceOrGroup>{\n            resource: null,\n            resourceGroup: resourceOrGroup\n          };\n        } else {\n          return <ResourceOrGroup>{\n            resource: resourceOrGroup,\n            resourceGroup: null\n          };\n        }\n      }))\n      .pipe(filter((resourceOrGroup) => !!resourceOrGroup))\n      .pipe(map((resourceOrGroup) => <ResourceOrGroup>resourceOrGroup));\n\n    this.colSpan$ = this.timeSlots$\n      .pipe(map(timeSlots => timeSlots\n        .map(timeslot => timeslot.slots.length)\n        .reduce((sum, current) => sum + current, 0)\n      ));\n  }\n\n  @Input() level = 0;\n  resourceOrGroup$ = new BehaviorSubject<Resource | ResourceGroup | null>(null);\n  timeSlots$ = new BehaviorSubject<SchedulerStampWithSlots[]>([]);\n  isExpanded$ = new BehaviorSubject<boolean>(false);\n  data$: Observable<ResourceOrGroup>;\n  colSpan$: Observable<number>;\n  destroyed$ = new Subject();\n\n  //#region resourceOrGroup\n  public get resourceOrGroup() {\n    return this.resourceOrGroup$.value;\n  }\n  @Input() public set resourceGroup(value: Resource | ResourceGroup | null) {\n    this.resourceOrGroup$.next(value);\n  }\n  //#endregion\n\n  //#region timeSlots\n  public get timeSlots() {\n    return this.timeSlots$.value;\n  }\n  @Input() public set timeSlots(value: SchedulerStampWithSlots[]) {\n    this.timeSlots$.next(value);\n  }\n  //#endregion\n\n  //#region isExpanded\n  public get isExpanded() {\n    return this.isExpanded$.value;\n  }\n  @Input() public set isExpanded(value: boolean) {\n    this.isExpanded$.next(value);\n  }\n  //#endregion\n\n  toggleExpanded() {\n    this.isExpanded$.pipe(take(1)).subscribe((isExpanded) => {\n      this.isExpanded$.next(!isExpanded);\n    });\n  }\n\n  ngOnDestroy() {\n    this.destroyed$.next(true);\n  }\n\n}\n","<ng-container *ngIf=\"(data$ | async) as data\">\n\n    <!-- Data is a resource group -->\n    <ng-container *ngIf=\"data.resourceGroup\">\n        <!-- Header -->\n        <tr class=\"p-0 cursor-pointer\" *ngIf=\"(timeSlots$ | async) as timeSlots\" [title]=\"data.resourceGroup.description\">\n            <ng-container *ngIf=\"(colSpan$ | async) as colspan\">\n                <td class=\"p-2 cursor-pointer\" [colSpan]=\"colspan + 1\" (click)=\"toggleExpanded()\">\n                    <span class=\"p-2 align-middle position-sticky\">\n                        <i class=\"bi bi-chevron-down\" [style.padding-left.px]=\"level * 20\" *ngIf=\"isExpanded$ | async\"></i>\n                        <i class=\"bi bi-chevron-right\" [style.padding-left.px]=\"level * 20\" *ngIf=\"(isExpanded$ | async) === false\"></i>\n                        {{ data.resourceGroup.description }}\n                    </span>\n                </td>\n            </ng-container>\n        </tr>\n\n        <!-- Subgroups or resources -->\n        <ng-container *ngIf=\"isExpanded$ | async\">\n            <ng-container *ngIf=\"(timeSlots$ | async) as timeSlots\">\n                <ng-container *ngFor=\"let child of data.resourceGroup.children\">\n                    <bs-resource-group-presenter [resourceGroup]=\"child\" [timeSlots]=\"timeSlots\" [level]=\"level + 1\"></bs-resource-group-presenter>\n                </ng-container>\n            </ng-container>\n        </ng-container>\n    </ng-container>\n\n    <!-- Data is a resource -->\n    <tr *ngIf=\"data.resource\" class=\"p-0 bordered\" [title]=\"data.resource.description\">\n        <td class=\"p-0 bg-white\">\n            <div class=\"p-2\">{{ data.resource.description }}</div>\n        </td>\n        <ng-container *ngFor=\"let slots of (timeSlots$ | async)\">\n            <td class=\"bg-white border-1\" *ngFor=\"let slot of slots.slots\">\n                <!-- {{ slot.start | date: 'dd/MM/yyyy HH:mm:ss' }} -->\n            </td>\n        </ng-container>\n    </tr>\n</ng-container>"]}