/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ElementRef, EventEmitter, Renderer2 } from '@angular/core';
import { BsDatepickerAbstractComponent } from '../../base/bs-datepicker-container';
import { BsDatepickerConfig } from '../../bs-datepicker.config';
import { BsDatepickerActions } from '../../reducer/bs-datepicker.actions';
import { BsDatepickerEffects } from '../../reducer/bs-datepicker.effects';
import { BsDatepickerStore } from '../../reducer/bs-datepicker.store';
import { PositioningService } from 'ngx-bootstrap/positioning';
import { datepickerAnimation } from '../../datepicker-animations';
import { take } from 'rxjs/operators';
var BsDatepickerContainerComponent = /** @class */ (function (_super) {
tslib_1.__extends(BsDatepickerContainerComponent, _super);
function BsDatepickerContainerComponent(_renderer, _config, _store, _element, _actions, _effects, _positionService) {
var _this = _super.call(this) || this;
_this._config = _config;
_this._store = _store;
_this._element = _element;
_this._actions = _actions;
_this._positionService = _positionService;
_this.valueChange = new EventEmitter();
_this.animationState = 'void';
_this._subs = [];
_this._effects = _effects;
_renderer.setStyle(_element.nativeElement, 'display', 'block');
_renderer.setStyle(_element.nativeElement, 'position', 'absolute');
return _this;
}
Object.defineProperty(BsDatepickerContainerComponent.prototype, "value", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._effects.setValue(value);
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
BsDatepickerContainerComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this._positionService.setOptions({
modifiers: { flip: { enabled: this._config.adaptivePosition } },
allowedPositions: ['top', 'bottom']
});
this._positionService.event$
.pipe(take(1))
.subscribe((/**
* @return {?}
*/
function () {
_this._positionService.disable();
if (_this._config.isAnimated) {
_this.animationState = _this.isTopPosition ? 'animated-up' : 'animated-down';
return;
}
_this.animationState = 'unanimated';
}));
this.isOtherMonthsActive = this._config.selectFromOtherMonth;
this.containerClass = this._config.containerClass;
this._effects
.init(this._store)
// intial state options
.setOptions(this._config)
// data binding view --> model
.setBindings(this)
// set event handlers
.setEventHandlers(this)
.registerDatepickerSideEffects();
// todo: move it somewhere else
// on selected date change
this._subs.push(this._store
/* tslint:disable-next-line: no-any */
.select((/**
* @param {?} state
* @return {?}
*/
function (state) { return state.selectedDate; }))
/* tslint:disable-next-line: no-any */
.subscribe((/**
* @param {?} date
* @return {?}
*/
function (date) { return _this.valueChange.emit(date); })));
};
Object.defineProperty(BsDatepickerContainerComponent.prototype, "isTopPosition", {
get: /**
* @return {?}
*/
function () {
return this._element.nativeElement.classList.contains('top');
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
BsDatepickerContainerComponent.prototype.positionServiceEnable = /**
* @return {?}
*/
function () {
this._positionService.enable();
};
/**
* @param {?} day
* @return {?}
*/
BsDatepickerContainerComponent.prototype.daySelectHandler = /**
* @param {?} day
* @return {?}
*/
function (day) {
/** @type {?} */
var isDisabled = this.isOtherMonthsActive ? day.isDisabled : (day.isOtherMonth || day.isDisabled);
if (isDisabled) {
return;
}
this._store.dispatch(this._actions.select(day.date));
};
/**
* @return {?}
*/
BsDatepickerContainerComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
var e_1, _a;
try {
for (var _b = tslib_1.__values(this._subs), _c = _b.next(); !_c.done; _c = _b.next()) {
var sub = _c.value;
sub.unsubscribe();
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
this._effects.destroy();
};
BsDatepickerContainerComponent.decorators = [
{ type: Component, args: [{
selector: 'bs-datepicker-container',
providers: [BsDatepickerStore, BsDatepickerEffects],
template: "\n
\n
\n \n
\n \n
\n 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 \n
\n\n \n
\n 1\"\n [calendar]=\"calendar\"\n (onNavigate)=\"navigateTo($event)\"\n (onViewMode)=\"setViewMode($event)\"\n (onHover)=\"monthHoverHandler($event)\"\n (onSelect)=\"monthSelectHandler($event)\">\n \n
\n\n \n
\n 1\"\n [calendar]=\"calendar\"\n (onNavigate)=\"navigateTo($event)\"\n (onViewMode)=\"setViewMode($event)\"\n (onHover)=\"yearHoverHandler($event)\"\n (onSelect)=\"yearSelectHandler($event)\">\n \n
\n
\n\n \n
\n \n \n
\n
\n\n \n
\n \n
\n
\n",
host: {
class: 'bottom',
'(click)': '_stopPropagation($event)',
role: 'dialog',
'aria-label': 'calendar'
},
animations: [datepickerAnimation]
}] }
];
/** @nocollapse */
BsDatepickerContainerComponent.ctorParameters = function () { return [
{ type: Renderer2 },
{ type: BsDatepickerConfig },
{ type: BsDatepickerStore },
{ type: ElementRef },
{ type: BsDatepickerActions },
{ type: BsDatepickerEffects },
{ type: PositioningService }
]; };
return BsDatepickerContainerComponent;
}(BsDatepickerAbstractComponent));
export { BsDatepickerContainerComponent };
if (false) {
/** @type {?} */
BsDatepickerContainerComponent.prototype.valueChange;
/** @type {?} */
BsDatepickerContainerComponent.prototype.animationState;
/** @type {?} */
BsDatepickerContainerComponent.prototype._subs;
/**
* @type {?}
* @private
*/
BsDatepickerContainerComponent.prototype._config;
/**
* @type {?}
* @private
*/
BsDatepickerContainerComponent.prototype._store;
/**
* @type {?}
* @private
*/
BsDatepickerContainerComponent.prototype._element;
/**
* @type {?}
* @private
*/
BsDatepickerContainerComponent.prototype._actions;
/**
* @type {?}
* @private
*/
BsDatepickerContainerComponent.prototype._positionService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-datepicker-container.component.js","sourceRoot":"ng://ngx-bootstrap/datepicker/","sources":["themes/bs/bs-datepicker-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@Component({\n  selector: 'bs-datepicker-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 BsDatepickerContainerComponent extends BsDatepickerAbstractComponent\n  implements OnInit, OnDestroy {\n\n  set value(value: Date) {\n    this._effects.setValue(value);\n  }\n\n  valueChange: EventEmitter<Date> = new EventEmitter<Date>();\n  animationState = 'void';\n\n  _subs: Subscription[] = [];\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\n    this.isOtherMonthsActive = this._config.selectFromOtherMonth;\n    this.containerClass = this._config.containerClass;\n    this._effects\n      .init(this._store)\n      // intial state options\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        /* tslint:disable-next-line: no-any */\n        .select((state: any) => state.selectedDate)\n        /* tslint:disable-next-line: no-any */\n        .subscribe((date: any) => 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    this._store.dispatch(this._actions.select(day.date));\n  }\n\n  ngOnDestroy(): void {\n    for (const sub of this._subs) {\n      sub.unsubscribe();\n    }\n    this._effects.destroy();\n  }\n}\n"]}