bs-daterangepicker-container.component.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import * as tslib_1 from "tslib";
  6. import { Component, ElementRef, EventEmitter, Renderer2 } from '@angular/core';
  7. import { BsDatepickerAbstractComponent } from '../../base/bs-datepicker-container';
  8. import { BsDatepickerConfig } from '../../bs-datepicker.config';
  9. import { BsDatepickerActions } from '../../reducer/bs-datepicker.actions';
  10. import { BsDatepickerEffects } from '../../reducer/bs-datepicker.effects';
  11. import { BsDatepickerStore } from '../../reducer/bs-datepicker.store';
  12. import { PositioningService } from 'ngx-bootstrap/positioning';
  13. import { datepickerAnimation } from '../../datepicker-animations';
  14. import { take } from 'rxjs/operators';
  15. var BsDaterangepickerContainerComponent = /** @class */ (function (_super) {
  16. tslib_1.__extends(BsDaterangepickerContainerComponent, _super);
  17. function BsDaterangepickerContainerComponent(_renderer, _config, _store, _element, _actions, _effects, _positionService) {
  18. var _this = _super.call(this) || this;
  19. _this._config = _config;
  20. _this._store = _store;
  21. _this._element = _element;
  22. _this._actions = _actions;
  23. _this._positionService = _positionService;
  24. _this.valueChange = new EventEmitter();
  25. _this.animationState = 'void';
  26. _this._rangeStack = [];
  27. _this._subs = [];
  28. _this._effects = _effects;
  29. _renderer.setStyle(_element.nativeElement, 'display', 'block');
  30. _renderer.setStyle(_element.nativeElement, 'position', 'absolute');
  31. return _this;
  32. }
  33. Object.defineProperty(BsDaterangepickerContainerComponent.prototype, "value", {
  34. set: /**
  35. * @param {?} value
  36. * @return {?}
  37. */
  38. function (value) {
  39. this._effects.setRangeValue(value);
  40. },
  41. enumerable: true,
  42. configurable: true
  43. });
  44. /**
  45. * @return {?}
  46. */
  47. BsDaterangepickerContainerComponent.prototype.ngOnInit = /**
  48. * @return {?}
  49. */
  50. function () {
  51. var _this = this;
  52. this._positionService.setOptions({
  53. modifiers: { flip: { enabled: this._config.adaptivePosition } },
  54. allowedPositions: ['top', 'bottom']
  55. });
  56. this._positionService.event$
  57. .pipe(take(1))
  58. .subscribe((/**
  59. * @return {?}
  60. */
  61. function () {
  62. _this._positionService.disable();
  63. if (_this._config.isAnimated) {
  64. _this.animationState = _this.isTopPosition ? 'animated-up' : 'animated-down';
  65. return;
  66. }
  67. _this.animationState = 'unanimated';
  68. }));
  69. this.containerClass = this._config.containerClass;
  70. this.isOtherMonthsActive = this._config.selectFromOtherMonth;
  71. this._effects
  72. .init(this._store)
  73. // intial state options
  74. // todo: fix this, split configs
  75. .setOptions(this._config)
  76. // data binding view --> model
  77. .setBindings(this)
  78. // set event handlers
  79. .setEventHandlers(this)
  80. .registerDatepickerSideEffects();
  81. // todo: move it somewhere else
  82. // on selected date change
  83. this._subs.push(this._store
  84. .select((/**
  85. * @param {?} state
  86. * @return {?}
  87. */
  88. function (state) { return state.selectedRange; }))
  89. .subscribe((/**
  90. * @param {?} date
  91. * @return {?}
  92. */
  93. function (date) { return _this.valueChange.emit(date); })));
  94. };
  95. Object.defineProperty(BsDaterangepickerContainerComponent.prototype, "isTopPosition", {
  96. get: /**
  97. * @return {?}
  98. */
  99. function () {
  100. return this._element.nativeElement.classList.contains('top');
  101. },
  102. enumerable: true,
  103. configurable: true
  104. });
  105. /**
  106. * @return {?}
  107. */
  108. BsDaterangepickerContainerComponent.prototype.positionServiceEnable = /**
  109. * @return {?}
  110. */
  111. function () {
  112. this._positionService.enable();
  113. };
  114. /**
  115. * @param {?} day
  116. * @return {?}
  117. */
  118. BsDaterangepickerContainerComponent.prototype.daySelectHandler = /**
  119. * @param {?} day
  120. * @return {?}
  121. */
  122. function (day) {
  123. /** @type {?} */
  124. var isDisabled = this.isOtherMonthsActive ? day.isDisabled : (day.isOtherMonth || day.isDisabled);
  125. if (isDisabled) {
  126. return;
  127. }
  128. // if only one date is already selected
  129. // and user clicks on previous date
  130. // start selection from new date
  131. // but if new date is after initial one
  132. // than finish selection
  133. if (this._rangeStack.length === 1) {
  134. this._rangeStack =
  135. day.date >= this._rangeStack[0]
  136. ? [this._rangeStack[0], day.date]
  137. : [day.date];
  138. }
  139. if (this._rangeStack.length === 0) {
  140. this._rangeStack = [day.date];
  141. }
  142. this._store.dispatch(this._actions.selectRange(this._rangeStack));
  143. if (this._rangeStack.length === 2) {
  144. this._rangeStack = [];
  145. }
  146. };
  147. /**
  148. * @return {?}
  149. */
  150. BsDaterangepickerContainerComponent.prototype.ngOnDestroy = /**
  151. * @return {?}
  152. */
  153. function () {
  154. var e_1, _a;
  155. try {
  156. for (var _b = tslib_1.__values(this._subs), _c = _b.next(); !_c.done; _c = _b.next()) {
  157. var sub = _c.value;
  158. sub.unsubscribe();
  159. }
  160. }
  161. catch (e_1_1) { e_1 = { error: e_1_1 }; }
  162. finally {
  163. try {
  164. if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
  165. }
  166. finally { if (e_1) throw e_1.error; }
  167. }
  168. this._effects.destroy();
  169. };
  170. BsDaterangepickerContainerComponent.decorators = [
  171. { type: Component, args: [{
  172. selector: 'bs-daterangepicker-container',
  173. providers: [BsDatepickerStore, BsDatepickerEffects],
  174. template: "<!-- days calendar view mode -->\n<div class=\"bs-datepicker\" [ngClass]=\"containerClass\" *ngIf=\"viewMode | async\">\n <div class=\"bs-datepicker-container\"\n [@datepickerAnimation]=\"animationState\"\n (@datepickerAnimation.done)=\"positionServiceEnable()\">\n <!--calendars-->\n <div class=\"bs-calendar-container\" [ngSwitch]=\"viewMode | async\" role=\"application\">\n <!--days calendar-->\n <div *ngSwitchCase=\"'day'\" class=\"bs-media-container\">\n <bs-days-calendar-view\n *ngFor=\"let calendar of daysCalendar | async\"\n [class.bs-datepicker-multiple]=\"(daysCalendar | async)?.length > 1\"\n [calendar]=\"calendar\"\n [options]=\"options | async\"\n (onNavigate)=\"navigateTo($event)\"\n (onViewMode)=\"setViewMode($event)\"\n (onHover)=\"dayHoverHandler($event)\"\n (onHoverWeek)=\"weekHoverHandler($event)\"\n (onSelect)=\"daySelectHandler($event)\">\n </bs-days-calendar-view>\n </div>\n\n <!--months calendar-->\n <div *ngSwitchCase=\"'month'\" class=\"bs-media-container\">\n <bs-month-calendar-view\n *ngFor=\"let calendar of monthsCalendar | async\"\n [class.bs-datepicker-multiple]=\"(daysCalendar | async)?.length > 1\"\n [calendar]=\"calendar\"\n (onNavigate)=\"navigateTo($event)\"\n (onViewMode)=\"setViewMode($event)\"\n (onHover)=\"monthHoverHandler($event)\"\n (onSelect)=\"monthSelectHandler($event)\">\n </bs-month-calendar-view>\n </div>\n\n <!--years calendar-->\n <div *ngSwitchCase=\"'year'\" class=\"bs-media-container\">\n <bs-years-calendar-view\n *ngFor=\"let calendar of yearsCalendar | async\"\n [class.bs-datepicker-multiple]=\"(daysCalendar | async)?.length > 1\"\n [calendar]=\"calendar\"\n (onNavigate)=\"navigateTo($event)\"\n (onViewMode)=\"setViewMode($event)\"\n (onHover)=\"yearHoverHandler($event)\"\n (onSelect)=\"yearSelectHandler($event)\">\n </bs-years-calendar-view>\n </div>\n </div>\n\n <!--applycancel buttons-->\n <div class=\"bs-datepicker-buttons\" *ngIf=\"false\">\n <button class=\"btn btn-success\" type=\"button\">Apply</button>\n <button class=\"btn btn-default\" type=\"button\">Cancel</button>\n </div>\n </div>\n\n <!--custom dates or date ranges picker-->\n <div class=\"bs-datepicker-custom-range\" *ngIf=\"false\">\n <bs-custom-date-view [ranges]=\"_customRangesFish\"></bs-custom-date-view>\n </div>\n</div>\n",
  175. host: {
  176. class: 'bottom',
  177. '(click)': '_stopPropagation($event)',
  178. role: 'dialog',
  179. 'aria-label': 'calendar'
  180. },
  181. animations: [datepickerAnimation]
  182. }] }
  183. ];
  184. /** @nocollapse */
  185. BsDaterangepickerContainerComponent.ctorParameters = function () { return [
  186. { type: Renderer2 },
  187. { type: BsDatepickerConfig },
  188. { type: BsDatepickerStore },
  189. { type: ElementRef },
  190. { type: BsDatepickerActions },
  191. { type: BsDatepickerEffects },
  192. { type: PositioningService }
  193. ]; };
  194. return BsDaterangepickerContainerComponent;
  195. }(BsDatepickerAbstractComponent));
  196. export { BsDaterangepickerContainerComponent };
  197. if (false) {
  198. /** @type {?} */
  199. BsDaterangepickerContainerComponent.prototype.valueChange;
  200. /** @type {?} */
  201. BsDaterangepickerContainerComponent.prototype.animationState;
  202. /** @type {?} */
  203. BsDaterangepickerContainerComponent.prototype._rangeStack;
  204. /** @type {?} */
  205. BsDaterangepickerContainerComponent.prototype._subs;
  206. /**
  207. * @type {?}
  208. * @private
  209. */
  210. BsDaterangepickerContainerComponent.prototype._config;
  211. /**
  212. * @type {?}
  213. * @private
  214. */
  215. BsDaterangepickerContainerComponent.prototype._store;
  216. /**
  217. * @type {?}
  218. * @private
  219. */
  220. BsDaterangepickerContainerComponent.prototype._element;
  221. /**
  222. * @type {?}
  223. * @private
  224. */
  225. BsDaterangepickerContainerComponent.prototype._actions;
  226. /**
  227. * @type {?}
  228. * @private
  229. */
  230. BsDaterangepickerContainerComponent.prototype._positionService;
  231. }
  232. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-daterangepicker-container.component.js","sourceRoot":"ng://ngx-bootstrap/datepicker/","sources":["themes/bs/bs-daterangepicker-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, OnDestroy, OnInit, Renderer2 } from '@angular/core';\n\nimport { BsDatepickerAbstractComponent } from '../../base/bs-datepicker-container';\nimport { BsDatepickerConfig } from '../../bs-datepicker.config';\nimport { DayViewModel } from '../../models';\nimport { BsDatepickerActions } from '../../reducer/bs-datepicker.actions';\nimport { BsDatepickerEffects } from '../../reducer/bs-datepicker.effects';\nimport { BsDatepickerStore } from '../../reducer/bs-datepicker.store';\nimport { PositioningService } from 'ngx-bootstrap/positioning';\n\nimport { Subscription } from 'rxjs';\nimport { datepickerAnimation } from '../../datepicker-animations';\nimport { take } from 'rxjs/operators';\n\n\n@Component({\n  selector: 'bs-daterangepicker-container',\n  providers: [BsDatepickerStore, BsDatepickerEffects],\n  templateUrl: './bs-datepicker-view.html',\n  host: {\n    class: 'bottom',\n    '(click)': '_stopPropagation($event)',\n    role: 'dialog',\n    'aria-label': 'calendar'\n  },\n  animations: [datepickerAnimation]\n})\nexport class BsDaterangepickerContainerComponent extends BsDatepickerAbstractComponent\n  implements OnInit, OnDestroy {\n  set value(value: Date[]) {\n    this._effects.setRangeValue(value);\n  }\n\n  valueChange = new EventEmitter<Date[]>();\n  animationState = 'void';\n\n  _rangeStack: Date[] = [];\n  _subs: Subscription[] = [];\n\n  constructor(\n    _renderer: Renderer2,\n    private _config: BsDatepickerConfig,\n    private _store: BsDatepickerStore,\n    private _element: ElementRef,\n    private _actions: BsDatepickerActions,\n    _effects: BsDatepickerEffects,\n    private _positionService: PositioningService\n  ) {\n    super();\n    this._effects = _effects;\n\n    _renderer.setStyle(_element.nativeElement, 'display', 'block');\n    _renderer.setStyle(_element.nativeElement, 'position', 'absolute');\n  }\n\n  ngOnInit(): void {\n    this._positionService.setOptions({\n      modifiers: { flip: { enabled: this._config.adaptivePosition } },\n      allowedPositions: ['top', 'bottom']\n    });\n\n    this._positionService.event$\n      .pipe(\n        take(1)\n      )\n      .subscribe(() => {\n        this._positionService.disable();\n\n        if (this._config.isAnimated) {\n          this.animationState = this.isTopPosition ? 'animated-up' : 'animated-down';\n\n          return;\n        }\n\n        this.animationState = 'unanimated';\n      });\n    this.containerClass = this._config.containerClass;\n    this.isOtherMonthsActive = this._config.selectFromOtherMonth;\n    this._effects\n      .init(this._store)\n      // intial state options\n      // todo: fix this, split configs\n      .setOptions(this._config)\n      // data binding view --> model\n      .setBindings(this)\n      // set event handlers\n      .setEventHandlers(this)\n      .registerDatepickerSideEffects();\n\n    // todo: move it somewhere else\n    // on selected date change\n    this._subs.push(\n      this._store\n        .select(state => state.selectedRange)\n        .subscribe(date => this.valueChange.emit(date))\n    );\n  }\n\n  get isTopPosition(): boolean {\n    return this._element.nativeElement.classList.contains('top');\n  }\n\n  positionServiceEnable(): void {\n    this._positionService.enable();\n  }\n\n  daySelectHandler(day: DayViewModel): void {\n    const isDisabled = this.isOtherMonthsActive ? day.isDisabled : (day.isOtherMonth || day.isDisabled);\n\n    if (isDisabled) {\n      return;\n    }\n\n    // if only one date is already selected\n    // and user clicks on previous date\n    // start selection from new date\n    // but if new date is after initial one\n    // than finish selection\n    if (this._rangeStack.length === 1) {\n      this._rangeStack =\n        day.date >= this._rangeStack[0]\n          ? [this._rangeStack[0], day.date]\n          : [day.date];\n    }\n\n    if (this._rangeStack.length === 0) {\n      this._rangeStack = [day.date];\n    }\n\n    this._store.dispatch(this._actions.selectRange(this._rangeStack));\n\n    if (this._rangeStack.length === 2) {\n      this._rangeStack = [];\n    }\n  }\n\n  ngOnDestroy(): void {\n    for (const sub of this._subs) {\n      sub.unsubscribe();\n    }\n    this._effects.destroy();\n  }\n}\n"]}