bs-days-calendar-view.component.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { Component, EventEmitter, Input, Output } from '@angular/core';
  6. import { BsNavigationDirection } from '../../models';
  7. import { BsDatepickerConfig } from '../../bs-datepicker.config';
  8. var BsDaysCalendarViewComponent = /** @class */ (function () {
  9. function BsDaysCalendarViewComponent(_config) {
  10. this._config = _config;
  11. this.onNavigate = new EventEmitter();
  12. this.onViewMode = new EventEmitter();
  13. this.onSelect = new EventEmitter();
  14. this.onHover = new EventEmitter();
  15. this.onHoverWeek = new EventEmitter();
  16. }
  17. /**
  18. * @param {?} event
  19. * @return {?}
  20. */
  21. BsDaysCalendarViewComponent.prototype.navigateTo = /**
  22. * @param {?} event
  23. * @return {?}
  24. */
  25. function (event) {
  26. /** @type {?} */
  27. var step = BsNavigationDirection.DOWN === event ? -1 : 1;
  28. this.onNavigate.emit({ step: { month: step } });
  29. };
  30. /**
  31. * @param {?} event
  32. * @return {?}
  33. */
  34. BsDaysCalendarViewComponent.prototype.changeViewMode = /**
  35. * @param {?} event
  36. * @return {?}
  37. */
  38. function (event) {
  39. this.onViewMode.emit(event);
  40. };
  41. /**
  42. * @param {?} event
  43. * @return {?}
  44. */
  45. BsDaysCalendarViewComponent.prototype.selectDay = /**
  46. * @param {?} event
  47. * @return {?}
  48. */
  49. function (event) {
  50. this.onSelect.emit(event);
  51. };
  52. /**
  53. * @param {?} week
  54. * @return {?}
  55. */
  56. BsDaysCalendarViewComponent.prototype.selectWeek = /**
  57. * @param {?} week
  58. * @return {?}
  59. */
  60. function (week) {
  61. var _this = this;
  62. if (!this._config.selectWeek) {
  63. return;
  64. }
  65. if (week.days
  66. && week.days[0]
  67. && !week.days[0].isDisabled
  68. && this._config.selectFromOtherMonth) {
  69. this.onSelect.emit(week.days[0]);
  70. return;
  71. }
  72. if (week.days.length === 0) {
  73. return;
  74. }
  75. /** @type {?} */
  76. var selectedDay = week.days.find((/**
  77. * @param {?} day
  78. * @return {?}
  79. */
  80. function (day) {
  81. return _this._config.selectFromOtherMonth
  82. ? !day.isDisabled
  83. : !day.isOtherMonth && !day.isDisabled;
  84. }));
  85. this.onSelect.emit(selectedDay);
  86. };
  87. /**
  88. * @param {?} cell
  89. * @param {?} isHovered
  90. * @return {?}
  91. */
  92. BsDaysCalendarViewComponent.prototype.weekHoverHandler = /**
  93. * @param {?} cell
  94. * @param {?} isHovered
  95. * @return {?}
  96. */
  97. function (cell, isHovered) {
  98. var _this = this;
  99. if (!this._config.selectWeek) {
  100. return;
  101. }
  102. /** @type {?} */
  103. var hasActiveDays = cell.days.find((/**
  104. * @param {?} day
  105. * @return {?}
  106. */
  107. function (day) {
  108. return _this._config.selectFromOtherMonth
  109. ? !day.isDisabled
  110. : !day.isOtherMonth && !day.isDisabled;
  111. }));
  112. if (hasActiveDays) {
  113. cell.isHovered = isHovered;
  114. this.isWeekHovered = isHovered;
  115. this.onHoverWeek.emit(cell);
  116. }
  117. };
  118. /**
  119. * @param {?} cell
  120. * @param {?} isHovered
  121. * @return {?}
  122. */
  123. BsDaysCalendarViewComponent.prototype.hoverDay = /**
  124. * @param {?} cell
  125. * @param {?} isHovered
  126. * @return {?}
  127. */
  128. function (cell, isHovered) {
  129. if (this._config.selectFromOtherMonth && cell.isOtherMonth) {
  130. cell.isOtherMonthHovered = isHovered;
  131. }
  132. this.onHover.emit({ cell: cell, isHovered: isHovered });
  133. };
  134. BsDaysCalendarViewComponent.decorators = [
  135. { type: Component, args: [{
  136. selector: 'bs-days-calendar-view',
  137. // changeDetection: ChangeDetectionStrategy.OnPush,
  138. template: "\n <bs-calendar-layout>\n <bs-datepicker-navigation-view\n [calendar]=\"calendar\"\n (onNavigate)=\"navigateTo($event)\"\n (onViewMode)=\"changeViewMode($event)\"\n ></bs-datepicker-navigation-view>\n\n <!--days matrix-->\n <table role=\"grid\" class=\"days weeks\">\n <thead>\n <tr>\n <!--if show weeks-->\n <th *ngIf=\"options.showWeekNumbers\"></th>\n <th *ngFor=\"let weekday of calendar.weekdays; let i = index\"\n aria-label=\"weekday\">{{ calendar.weekdays[i] }}\n </th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let week of calendar.weeks; let i = index\">\n <td class=\"week\" [class.active-week]=\"isWeekHovered\" *ngIf=\"options.showWeekNumbers\">\n <span\n (click)=\"selectWeek(week)\"\n (mouseenter)=\"weekHoverHandler(week, true)\"\n (mouseleave)=\"weekHoverHandler(week, false)\">{{ calendar.weekNumbers[i] }}</span>\n </td>\n <td *ngFor=\"let day of week.days\" role=\"gridcell\">\n <span bsDatepickerDayDecorator\n [day]=\"day\"\n (click)=\"selectDay(day)\"\n (mouseenter)=\"hoverDay(day, true)\"\n (mouseleave)=\"hoverDay(day, false)\">{{ day.label }}</span>\n </td>\n </tr>\n </tbody>\n </table>\n\n </bs-calendar-layout>\n "
  139. }] }
  140. ];
  141. /** @nocollapse */
  142. BsDaysCalendarViewComponent.ctorParameters = function () { return [
  143. { type: BsDatepickerConfig }
  144. ]; };
  145. BsDaysCalendarViewComponent.propDecorators = {
  146. calendar: [{ type: Input }],
  147. options: [{ type: Input }],
  148. onNavigate: [{ type: Output }],
  149. onViewMode: [{ type: Output }],
  150. onSelect: [{ type: Output }],
  151. onHover: [{ type: Output }],
  152. onHoverWeek: [{ type: Output }]
  153. };
  154. return BsDaysCalendarViewComponent;
  155. }());
  156. export { BsDaysCalendarViewComponent };
  157. if (false) {
  158. /** @type {?} */
  159. BsDaysCalendarViewComponent.prototype.calendar;
  160. /** @type {?} */
  161. BsDaysCalendarViewComponent.prototype.options;
  162. /** @type {?} */
  163. BsDaysCalendarViewComponent.prototype.onNavigate;
  164. /** @type {?} */
  165. BsDaysCalendarViewComponent.prototype.onViewMode;
  166. /** @type {?} */
  167. BsDaysCalendarViewComponent.prototype.onSelect;
  168. /** @type {?} */
  169. BsDaysCalendarViewComponent.prototype.onHover;
  170. /** @type {?} */
  171. BsDaysCalendarViewComponent.prototype.onHoverWeek;
  172. /** @type {?} */
  173. BsDaysCalendarViewComponent.prototype.isWeekHovered;
  174. /**
  175. * @type {?}
  176. * @private
  177. */
  178. BsDaysCalendarViewComponent.prototype._config;
  179. }
  180. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-days-calendar-view.component.js","sourceRoot":"ng://ngx-bootstrap/datepicker/","sources":["themes/bs/bs-days-calendar-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  Output\n} from '@angular/core';\n\nimport {\n  BsDatepickerViewMode,\n  BsNavigationDirection,\n  BsNavigationEvent,\n  CellHoverEvent,\n  DatepickerRenderOptions,\n  DaysCalendarViewModel,\n  DayViewModel, WeekViewModel\n} from '../../models';\n\nimport { BsDatepickerConfig } from '../../bs-datepicker.config';\n\n@Component({\n  selector: 'bs-days-calendar-view',\n  // changeDetection: ChangeDetectionStrategy.OnPush,\n  template: `\n    <bs-calendar-layout>\n      <bs-datepicker-navigation-view\n        [calendar]=\"calendar\"\n        (onNavigate)=\"navigateTo($event)\"\n        (onViewMode)=\"changeViewMode($event)\"\n      ></bs-datepicker-navigation-view>\n\n      <!--days matrix-->\n      <table role=\"grid\" class=\"days weeks\">\n        <thead>\n        <tr>\n          <!--if show weeks-->\n          <th *ngIf=\"options.showWeekNumbers\"></th>\n          <th *ngFor=\"let weekday of calendar.weekdays; let i = index\"\n              aria-label=\"weekday\">{{ calendar.weekdays[i] }}\n          </th>\n        </tr>\n        </thead>\n        <tbody>\n        <tr *ngFor=\"let week of calendar.weeks; let i = index\">\n          <td class=\"week\" [class.active-week]=\"isWeekHovered\"  *ngIf=\"options.showWeekNumbers\">\n            <span\n                (click)=\"selectWeek(week)\"\n                (mouseenter)=\"weekHoverHandler(week, true)\"\n                (mouseleave)=\"weekHoverHandler(week, false)\">{{ calendar.weekNumbers[i] }}</span>\n          </td>\n          <td *ngFor=\"let day of week.days\" role=\"gridcell\">\n          <span bsDatepickerDayDecorator\n                [day]=\"day\"\n                (click)=\"selectDay(day)\"\n                (mouseenter)=\"hoverDay(day, true)\"\n                (mouseleave)=\"hoverDay(day, false)\">{{ day.label }}</span>\n          </td>\n        </tr>\n        </tbody>\n      </table>\n\n    </bs-calendar-layout>\n  `\n})\nexport class BsDaysCalendarViewComponent  {\n  @Input() calendar: DaysCalendarViewModel;\n  @Input() options: DatepickerRenderOptions;\n\n  @Output() onNavigate = new EventEmitter<BsNavigationEvent>();\n  @Output() onViewMode = new EventEmitter<BsDatepickerViewMode>();\n\n  @Output() onSelect = new EventEmitter<DayViewModel>();\n  @Output() onHover = new EventEmitter<CellHoverEvent>();\n  @Output() onHoverWeek = new EventEmitter<WeekViewModel>();\n\n  isWeekHovered: boolean;\n\n  constructor(private _config: BsDatepickerConfig) { }\n\n  navigateTo(event: BsNavigationDirection): void {\n    const step = BsNavigationDirection.DOWN === event ? -1 : 1;\n    this.onNavigate.emit({ step: { month: step } });\n  }\n\n  changeViewMode(event: BsDatepickerViewMode): void {\n    this.onViewMode.emit(event);\n  }\n\n  selectDay(event: DayViewModel): void {\n    this.onSelect.emit(event);\n  }\n\n  selectWeek(week: WeekViewModel): void {\n    if (!this._config.selectWeek) {\n      return;\n    }\n\n    if (week.days\n      && week.days[0]\n      && !week.days[0].isDisabled\n      && this._config.selectFromOtherMonth) {\n\n      this.onSelect.emit(week.days[0]);\n\n      return;\n    }\n\n    if (week.days.length === 0) {\n      return;\n    }\n\n    const selectedDay = week.days.find((day: DayViewModel) => {\n      return this._config.selectFromOtherMonth\n        ? !day.isDisabled\n        : !day.isOtherMonth && !day.isDisabled;\n    });\n\n    this.onSelect.emit(selectedDay);\n  }\n\n  weekHoverHandler(cell: WeekViewModel, isHovered: boolean): void {\n    if (!this._config.selectWeek) {\n      return;\n    }\n\n    const hasActiveDays = cell.days.find((day: DayViewModel) => {\n      return this._config.selectFromOtherMonth\n        ? !day.isDisabled\n        : !day.isOtherMonth && !day.isDisabled;\n    });\n\n    if (hasActiveDays) {\n      cell.isHovered = isHovered;\n      this.isWeekHovered = isHovered;\n      this.onHoverWeek.emit(cell);\n    }\n  }\n\n  hoverDay(cell: DayViewModel, isHovered: boolean): void {\n    if (this._config.selectFromOtherMonth && cell.isOtherMonth) {\n      cell.isOtherMonthHovered = isHovered;\n    }\n\n    this.onHover.emit({ cell, isHovered });\n  }\n}\n"]}