ngx-bootstrap
Version:
Angular Bootstrap
1 lines • 824 kB
Source Map (JSON)
{"version":3,"file":"ngx-bootstrap-datepicker.mjs","sources":["../tmp-esm2022/bs-datepicker.config.js","../tmp-esm2022/datepicker-animations.js","../tmp-esm2022/base/bs-datepicker-container.js","../tmp-esm2022/reducer/bs-datepicker.actions.js","../tmp-esm2022/bs-locale.service.js","../tmp-esm2022/reducer/bs-datepicker.effects.js","../tmp-esm2022/reducer/_defaults.js","../tmp-esm2022/reducer/bs-datepicker.state.js","../tmp-esm2022/utils/bs-calendar-utils.js","../tmp-esm2022/utils/matrix-utils.js","../tmp-esm2022/engine/calc-days-calendar.js","../tmp-esm2022/engine/format-days-calendar.js","../tmp-esm2022/engine/flag-days-calendar.js","../tmp-esm2022/engine/view-mode.js","../tmp-esm2022/engine/format-months-calendar.js","../tmp-esm2022/engine/flag-months-calendar.js","../tmp-esm2022/engine/format-years-calendar.js","../tmp-esm2022/engine/flag-years-calendar.js","../tmp-esm2022/utils/copy-time-utils.js","../tmp-esm2022/reducer/bs-datepicker.reducer.js","../tmp-esm2022/reducer/bs-datepicker.store.js","../tmp-esm2022/themes/bs/bs-custom-dates-view.component.js","../tmp-esm2022/models/index.js","../tmp-esm2022/themes/bs/bs-datepicker-navigation-view.component.js","../tmp-esm2022/themes/bs/bs-timepicker-view.component.js","../tmp-esm2022/themes/bs/bs-current-date-view.component.js","../tmp-esm2022/themes/bs/bs-calendar-layout.component.js","../tmp-esm2022/themes/bs/bs-years-calendar-view.component.js","../tmp-esm2022/themes/bs/bs-months-calendar-view.component.js","../tmp-esm2022/themes/bs/bs-datepicker-day-decorator.directive.js","../tmp-esm2022/themes/bs/bs-days-calendar-view.component.js","../tmp-esm2022/themes/bs/bs-datepicker-container.component.js","../tmp-esm2022/bs-datepicker.component.js","../tmp-esm2022/bs-datepicker-inline.config.js","../tmp-esm2022/themes/bs/bs-datepicker-inline-container.component.js","../tmp-esm2022/bs-datepicker-inline.component.js","../tmp-esm2022/bs-daterangepicker-inline.config.js","../tmp-esm2022/themes/bs/bs-daterangepicker-container.component.js","../tmp-esm2022/themes/bs/bs-daterangepicker-inline-container.component.js","../tmp-esm2022/bs-daterangepicker-inline.component.js","../tmp-esm2022/bs-datepicker-input.directive.js","../tmp-esm2022/bs-daterangepicker.config.js","../tmp-esm2022/bs-daterangepicker.component.js","../tmp-esm2022/bs-daterangepicker-input.directive.js","../tmp-esm2022/bs-datepicker.module.js","../tmp-esm2022/ngx-bootstrap-datepicker.js"],"sourcesContent":["import { Injectable } from '@angular/core';\nimport * as i0 from \"@angular/core\";\n/**\n * For date range picker there are `BsDaterangepickerConfig` which inherits all properties,\n * except `displayMonths`, for range picker it default to `2`\n */\nexport class BsDatepickerConfig {\n constructor() {\n /** sets use adaptive position */\n this.adaptivePosition = false;\n /** sets use UTC date time format */\n this.useUtc = false;\n /** turn on/off animation */\n this.isAnimated = false;\n /**\n * The view that the datepicker should start in\n */\n this.startView = 'day';\n /**\n * If true, returns focus to the datepicker / daterangepicker input after date selection\n */\n this.returnFocusToInput = false;\n /** CSS class which will be applied to datepicker container,\n * usually used to set color theme\n */\n this.containerClass = 'theme-green';\n // DatepickerRenderOptions\n this.displayMonths = 1;\n /**\n * Allows to hide week numbers in datepicker\n */\n this.showWeekNumbers = true;\n this.dateInputFormat = 'L';\n // range picker\n this.rangeSeparator = ' - ';\n /**\n * Date format for date range input field\n */\n this.rangeInputFormat = 'L';\n // DatepickerFormatOptions\n this.monthTitle = 'MMMM';\n this.yearTitle = 'YYYY';\n this.dayLabel = 'D';\n this.monthLabel = 'MMMM';\n this.yearLabel = 'YYYY';\n this.weekNumbers = 'w';\n /**\n * Shows 'today' button\n */\n this.showTodayButton = false;\n /**\n * Shows clear button\n */\n this.showClearButton = false;\n /**\n * Positioning of 'today' button\n */\n this.todayPosition = 'center';\n /**\n * Positioning of 'clear' button\n */\n this.clearPosition = 'right';\n /**\n * Label for 'today' button\n */\n this.todayButtonLabel = 'Today';\n /**\n * Label for 'clear' button\n */\n this.clearButtonLabel = 'Clear';\n /**\n * Label for 'custom range' button\n */\n this.customRangeButtonLabel = 'Custom Range';\n /**\n * Shows timepicker under datepicker\n */\n this.withTimepicker = false;\n /**\n * Set allowed positions of container.\n */\n this.allowedPositions = ['top', 'bottom'];\n /**\n * Set rule for datepicker closing. If value is true datepicker closes only if date is changed, if user changes only time datepicker doesn't close. It is available only if property withTimepicker is set true\n * */\n this.keepDatepickerOpened = false;\n /**\n * Allows keep invalid dates in range. Can be used with minDate, maxDate\n * */\n this.keepDatesOutOfRules = false;\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.2\", ngImport: i0, type: BsDatepickerConfig, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.0.2\", ngImport: i0, type: BsDatepickerConfig, providedIn: 'root' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.2\", ngImport: i0, type: BsDatepickerConfig, decorators: [{\n type: Injectable,\n args: [{\n providedIn: 'root'\n }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-datepicker.config.js","sourceRoot":"","sources":["../../../../src/datepicker/bs-datepicker.config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;AAU3C;;;GAGG;AAIH,MAAM,OAAO,kBAAkB;IAH/B;QAIE,iCAAiC;QACjC,qBAAgB,GAAG,KAAK,CAAC;QACzB,oCAAoC;QACpC,WAAM,GAAG,KAAK,CAAC;QACf,4BAA4B;QAC5B,eAAU,GAAG,KAAK,CAAC;QAWnB;;WAEG;QACH,cAAS,GAAyB,KAAK,CAAC;QA8DxC;;WAEG;QACH,uBAAkB,GAAG,KAAK,CAAC;QAE3B;;WAEG;QACH,mBAAc,GAAG,aAAa,CAAC;QAE/B,0BAA0B;QAC1B,kBAAa,GAAG,CAAC,CAAC;QAClB;;WAEG;QACH,oBAAe,GAAG,IAAI,CAAC;QAEvB,oBAAe,GAAG,GAAG,CAAC;QACtB,eAAe;QACf,mBAAc,GAAG,KAAK,CAAC;QACvB;;WAEG;QACH,qBAAgB,GAAG,GAAG,CAAC;QAYvB,0BAA0B;QAC1B,eAAU,GAAG,MAAM,CAAC;QACpB,cAAS,GAAG,MAAM,CAAC;QACnB,aAAQ,GAAG,GAAG,CAAC;QACf,eAAU,GAAG,MAAM,CAAC;QACpB,cAAS,GAAG,MAAM,CAAC;QACnB,gBAAW,GAAG,GAAG,CAAC;QAElB;;WAEG;QACH,oBAAe,GAAG,KAAK,CAAC;QAExB;;WAEG;QACH,oBAAe,GAAG,KAAK,CAAC;QAExB;;WAEG;QACH,kBAAa,GAAG,QAAQ,CAAC;QAEzB;;WAEG;QACH,kBAAa,GAAG,OAAO,CAAC;QAExB;;WAEG;QACH,qBAAgB,GAAG,OAAO,CAAC;QAE3B;;WAEG;QACH,qBAAgB,GAAG,OAAO,CAAC;QAE3B;;WAEG;QACH,2BAAsB,GAAG,cAAc,CAAC;QAExC;;WAEG;QACH,mBAAc,GAAG,KAAK,CAAC;QAKvB;;WAEG;QACH,qBAAgB,GAAG,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QACrC;;aAEK;QACL,yBAAoB,GAAG,KAAK,CAAC;QAC7B;;aAEK;QACL,wBAAmB,GAAG,KAAK,CAAC;KAC7B;8GApLY,kBAAkB;kHAAlB,kBAAkB,cAFjB,MAAM;;2FAEP,kBAAkB;kBAH9B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  DatepickerRenderOptions,\n  BsDatepickerViewMode,\n  DatepickerDateCustomClasses,\n  DatepickerDateTooltipText\n} from './models';\nimport { BsCustomDates } from './themes/bs/bs-custom-dates-view.component';\n\n\n/**\n * For date range picker there are `BsDaterangepickerConfig` which inherits all properties,\n * except `displayMonths`, for range picker it default to `2`\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class BsDatepickerConfig implements DatepickerRenderOptions {\n  /** sets use adaptive position */\n  adaptivePosition = false;\n  /** sets use UTC date time format */\n  useUtc = false;\n  /** turn on/off animation */\n  isAnimated = false;\n  value?: Date | Date[];\n  isDisabled?: boolean;\n  /**\n   * Default min date for all date/range pickers\n   */\n  minDate?: Date;\n  /**\n   * Default max date for all date/range pickers\n   */\n  maxDate?: Date;\n  /**\n   * The view that the datepicker should start in\n   */\n  startView: BsDatepickerViewMode = 'day';\n  /**\n   * Default date custom classes for all date/range pickers\n   */\n  dateCustomClasses?: DatepickerDateCustomClasses[];\n  /**\n   * Default tooltip text for all date/range pickers\n   */\n  dateTooltipTexts?: DatepickerDateTooltipText[];\n  /**\n   * Disable specific days, e.g. [0,6] will disable all Saturdays and Sundays\n   */\n  daysDisabled?: number[];\n  /**\n   * Disable specific dates\n   */\n  datesDisabled?: Date[];\n  /**\n   * Show one months for special cases (only for dateRangePicker)\n   * 1. maxDate is equal to today's date\n   * 2. minDate's month is equal to maxDate's month\n   */\n  displayOneMonthRange?: boolean;\n  /**\n   * Enable specific dates\n   */\n  datesEnabled?: Date[];\n  /**\n   * Makes dates from other months active\n   */\n  selectFromOtherMonth?: boolean;\n\n  /**\n   * Allows select first date of the week by click on week number\n   */\n  selectWeek?: boolean;\n\n  /**\n   * Allows select daterange as first and last day of week by click on week number (dateRangePicker only)\n   */\n  selectWeekDateRange?: boolean;\n\n  /**\n   * Shows previous and current month, instead of current and next (dateRangePicker only)\n   */\n  showPreviousMonth?: boolean;\n\n  /**\n   * Prevents change to next month for right calendar in two calendars view (dateRangePicker only)\n   */\n  preventChangeToNextMonth?: boolean;\n\n  /**\n   * Add class to current day\n   */\n  customTodayClass?: string;\n\n  /**\n   * Default mode for all date pickers\n   */\n  minMode?: BsDatepickerViewMode;\n\n  /**\n   * If true, returns focus to the datepicker / daterangepicker input after date selection\n   */\n  returnFocusToInput = false;\n\n  /** CSS class which will be applied to datepicker container,\n   * usually used to set color theme\n   */\n  containerClass = 'theme-green';\n\n  // DatepickerRenderOptions\n  displayMonths = 1;\n  /**\n   * Allows to hide week numbers in datepicker\n   */\n  showWeekNumbers = true;\n\n  dateInputFormat = 'L';\n  // range picker\n  rangeSeparator = ' - ';\n  /**\n   * Date format for date range input field\n   */\n  rangeInputFormat = 'L';\n\n  /**\n   * Predefined ranges\n   */\n  ranges?: BsCustomDates[];\n\n  /**\n   * Max Date Range in days\n   */\n  maxDateRange?: number;\n\n  // DatepickerFormatOptions\n  monthTitle = 'MMMM';\n  yearTitle = 'YYYY';\n  dayLabel = 'D';\n  monthLabel = 'MMMM';\n  yearLabel = 'YYYY';\n  weekNumbers = 'w';\n\n  /**\n   * Shows 'today' button\n   */\n  showTodayButton = false;\n\n  /**\n   * Shows clear button\n   */\n  showClearButton = false;\n\n  /**\n   * Positioning of 'today' button\n   */\n  todayPosition = 'center';\n\n  /**\n   * Positioning of 'clear' button\n   */\n  clearPosition = 'right';\n\n  /**\n   * Label for 'today' button\n   */\n  todayButtonLabel = 'Today';\n\n  /**\n   * Label for 'clear' button\n   */\n  clearButtonLabel = 'Clear';\n\n  /**\n   * Label for 'custom range' button\n   */\n  customRangeButtonLabel = 'Custom Range';\n\n  /**\n   * Shows timepicker under datepicker\n   */\n  withTimepicker = false;\n  /**\n   * Set current hours, minutes, seconds and milliseconds for bsValue\n   */\n  initCurrentTime?: boolean;\n  /**\n   * Set allowed positions of container.\n   */\n  allowedPositions = ['top', 'bottom'];\n  /**\n   * Set rule for datepicker closing. If value is true datepicker closes only if date is changed, if user changes only time datepicker doesn't close. It is available only if property withTimepicker is set true\n   * */\n  keepDatepickerOpened = false;\n  /**\n   * Allows keep invalid dates in range. Can be used with minDate, maxDate\n   * */\n  keepDatesOutOfRules = false;\n}\n"]}","import { animate, style, state, transition, trigger } from '@angular/animations';\nexport const DATEPICKER_ANIMATION_TIMING = '220ms cubic-bezier(0, 0, 0.2, 1)';\nexport const datepickerAnimation = trigger('datepickerAnimation', [\n state('animated-down', style({ height: '*', overflow: 'hidden' })),\n transition('* => animated-down', [\n style({ height: 0, overflow: 'hidden' }),\n animate(DATEPICKER_ANIMATION_TIMING)\n ]),\n state('animated-up', style({ height: '*', overflow: 'hidden' })),\n transition('* => animated-up', [\n style({ height: '*', overflow: 'hidden' }),\n animate(DATEPICKER_ANIMATION_TIMING)\n ]),\n transition('* => unanimated', animate('0s'))\n]);\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1hbmltYXRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci1hbmltYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxPQUFPLEVBQ1AsS0FBSyxFQUVMLEtBQUssRUFDTCxVQUFVLEVBQ1YsT0FBTyxFQUNSLE1BQU0scUJBQXFCLENBQUM7QUFFN0IsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQUcsa0NBQWtDLENBQUM7QUFFOUUsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQzlCLE9BQU8sQ0FBQyxxQkFBcUIsRUFBRTtJQUM3QixLQUFLLENBQUMsZUFBZSxFQUFFLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBQyxDQUFDLENBQUM7SUFDakUsVUFBVSxDQUFDLG9CQUFvQixFQUFFO1FBQy9CLEtBQUssQ0FBQyxFQUFFLE1BQU0sRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxDQUFDO1FBQ3hDLE9BQU8sQ0FBQywyQkFBMkIsQ0FBQztLQUNyQyxDQUFDO0lBQ0YsS0FBSyxDQUFDLGFBQWEsRUFBRSxLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUMsQ0FBQyxDQUFDO0lBQy9ELFVBQVUsQ0FBQyxrQkFBa0IsRUFBRTtRQUM3QixLQUFLLENBQUMsRUFBRSxNQUFNLEVBQUUsR0FBRyxFQUFFLFFBQVEsRUFBRSxRQUFRLEVBQUUsQ0FBQztRQUMxQyxPQUFPLENBQUMsMkJBQTJCLENBQUM7S0FDckMsQ0FBQztJQUNGLFVBQVUsQ0FBQyxpQkFBaUIsRUFBRSxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7Q0FDN0MsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgYW5pbWF0ZSxcbiAgc3R5bGUsXG4gIEFuaW1hdGlvblRyaWdnZXJNZXRhZGF0YSxcbiAgc3RhdGUsXG4gIHRyYW5zaXRpb24sXG4gIHRyaWdnZXJcbn0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5cbmV4cG9ydCBjb25zdCBEQVRFUElDS0VSX0FOSU1BVElPTl9USU1JTkcgPSAnMjIwbXMgY3ViaWMtYmV6aWVyKDAsIDAsIDAuMiwgMSknO1xuXG5leHBvcnQgY29uc3QgZGF0ZXBpY2tlckFuaW1hdGlvbjogQW5pbWF0aW9uVHJpZ2dlck1ldGFkYXRhID1cbiAgdHJpZ2dlcignZGF0ZXBpY2tlckFuaW1hdGlvbicsIFtcbiAgICBzdGF0ZSgnYW5pbWF0ZWQtZG93bicsIHN0eWxlKHsgaGVpZ2h0OiAnKicsIG92ZXJmbG93OiAnaGlkZGVuJ30pKSxcbiAgICB0cmFuc2l0aW9uKCcqID0+IGFuaW1hdGVkLWRvd24nLCBbXG4gICAgICBzdHlsZSh7IGhlaWdodDogMCwgb3ZlcmZsb3c6ICdoaWRkZW4nIH0pLFxuICAgICAgYW5pbWF0ZShEQVRFUElDS0VSX0FOSU1BVElPTl9USU1JTkcpXG4gICAgXSksXG4gICAgc3RhdGUoJ2FuaW1hdGVkLXVwJywgc3R5bGUoeyBoZWlnaHQ6ICcqJywgb3ZlcmZsb3c6ICdoaWRkZW4nfSkpLFxuICAgIHRyYW5zaXRpb24oJyogPT4gYW5pbWF0ZWQtdXAnLCBbXG4gICAgICBzdHlsZSh7IGhlaWdodDogJyonLCBvdmVyZmxvdzogJ2hpZGRlbicgfSksXG4gICAgICBhbmltYXRlKERBVEVQSUNLRVJfQU5JTUFUSU9OX1RJTUlORylcbiAgICBdKSxcbiAgICB0cmFuc2l0aW9uKCcqID0+IHVuYW5pbWF0ZWQnLCBhbmltYXRlKCcwcycpKVxuICBdKTtcbiJdfQ==","import { Subscription } from 'rxjs';\nexport class BsDatepickerAbstractComponent {\n constructor() {\n this.containerClass = '';\n this.customRanges = [];\n this.chosenRange = [];\n this._daysCalendarSub = new Subscription();\n this.selectedTimeSub = new Subscription();\n }\n set minDate(value) {\n this._effects?.setMinDate(value);\n }\n set maxDate(value) {\n this._effects?.setMaxDate(value);\n }\n set daysDisabled(value) {\n this._effects?.setDaysDisabled(value);\n }\n set datesDisabled(value) {\n this._effects?.setDatesDisabled(value);\n }\n set datesEnabled(value) {\n this._effects?.setDatesEnabled(value);\n }\n set isDisabled(value) {\n this._effects?.setDisabled(value);\n }\n set dateCustomClasses(value) {\n this._effects?.setDateCustomClasses(value);\n }\n set dateTooltipTexts(value) {\n this._effects?.setDateTooltipTexts(value);\n }\n set daysCalendar$(value) {\n this._daysCalendar$ = value;\n this._daysCalendarSub.unsubscribe();\n this._daysCalendarSub.add(this._daysCalendar$.subscribe(value => {\n this.multipleCalendars = !!value && value.length > 1;\n }));\n }\n get daysCalendar$() {\n return this._daysCalendar$;\n }\n // todo: valorkin fix\n // eslint-disable-next-line @typescript-eslint/no-unused-vars,@typescript-eslint/no-empty-function\n setViewMode(event) { }\n // eslint-disable-next-line\n navigateTo(event) { }\n // eslint-disable-next-line\n dayHoverHandler(event) { }\n // eslint-disable-next-line\n weekHoverHandler(event) { }\n // eslint-disable-next-line\n monthHoverHandler(event) { }\n // eslint-disable-next-line\n yearHoverHandler(event) { }\n // eslint-disable-next-line\n timeSelectHandler(date, index) { }\n // eslint-disable-next-line\n daySelectHandler(day) { }\n // eslint-disable-next-line\n monthSelectHandler(event) { }\n // eslint-disable-next-line\n yearSelectHandler(event) { }\n // eslint-disable-next-line\n setRangeOnCalendar(dates) { }\n // eslint-disable-next-line\n setToday() { }\n // eslint-disable-next-line\n clearDate() { }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n _stopPropagation(event) {\n event.stopPropagation();\n }\n}\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-datepicker-container.js","sourceRoot":"","sources":["../../../../../src/datepicker/base/bs-datepicker-container.ts"],"names":[],"mappings":"AAGA,OAAO,EAAc,YAAY,EAAE,MAAM,MAAM,CAAC;AAgBhD,MAAM,OAAgB,6BAA6B;IAAnD;QACE,mBAAc,GAAG,EAAE,CAAC;QAUpB,iBAAY,GAAoB,EAAE,CAAC;QAEnC,gBAAW,GAAW,EAAE,CAAC;QA2CzB,qBAAgB,GAAG,IAAI,YAAY,EAAE,CAAC;QAetC,oBAAe,GAAG,IAAI,YAAY,EAAE,CAAC;IA8CvC,CAAC;IAjGC,IAAI,OAAO,CAAC,KAAqB;QAC/B,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAED,IAAI,OAAO,CAAC,KAAqB;QAC/B,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IACD,IAAI,YAAY,CAAC,KAAyB;QACxC,IAAI,CAAC,QAAQ,EAAE,eAAe,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IACD,IAAI,aAAa,CAAC,KAAuB;QACvC,IAAI,CAAC,QAAQ,EAAE,gBAAgB,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,IAAI,YAAY,CAAC,KAAuB;QACtC,IAAI,CAAC,QAAQ,EAAE,eAAe,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,IAAI,UAAU,CAAC,KAAwB;QACrC,IAAI,CAAC,QAAQ,EAAE,WAAW,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAED,IAAI,iBAAiB,CAAC,KAA8C;QAClE,IAAI,CAAC,QAAQ,EAAE,oBAAoB,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IAED,IAAI,gBAAgB,CAAC,KAA4C;QAC/D,IAAI,CAAC,QAAQ,EAAE,mBAAmB,CAAC,KAAK,CAAC,CAAC;IAC5C,CAAC;IAUD,IAAI,aAAa,CAAC,KAAoD;QACpE,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC;QACpC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC9D,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACvD,CAAC,CAAC,CAAC,CAAC;IACN,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAKD,qBAAqB;IACrB,kGAAkG;IAClG,WAAW,CAAC,KAA2B,IAAS,CAAC;IAEjD,2BAA2B;IAC3B,UAAU,CAAC,KAAwB,IAAS,CAAC;IAE7C,2BAA2B;IAC3B,eAAe,CAAC,KAAqB,IAAS,CAAC;IAE/C,2BAA2B;IAC3B,gBAAgB,CAAC,KAAoB,IAAS,CAAC;IAE/C,2BAA2B;IAC3B,iBAAiB,CAAC,KAAqB,IAAS,CAAC;IAEjD,2BAA2B;IAC3B,gBAAgB,CAAC,KAAqB,IAAS,CAAC;IAEhD,2BAA2B;IAC3B,iBAAiB,CAAC,IAAU,EAAE,KAAa,IAAS,CAAC;IAErD,2BAA2B;IAC3B,gBAAgB,CAAC,GAAiB,IAAS,CAAC;IAE5C,2BAA2B;IAC3B,kBAAkB,CAAC,KAA4B,IAAS,CAAC;IAEzD,2BAA2B;IAC3B,iBAAiB,CAAC,KAA4B,IAAS,CAAC;IAExD,2BAA2B;IAC3B,kBAAkB,CAAC,KAAoB,IAAS,CAAC;IAEjD,2BAA2B;IAC3B,QAAQ,KAAU,CAAC;IAEnB,2BAA2B;IAC3B,SAAS,KAAU,CAAC;IAElB,8DAA8D;IAChE,gBAAgB,CAAC,KAAU;QACzB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;CACF","sourcesContent":["// datepicker container component\nimport { BsCustomDates } from '../themes/bs/bs-custom-dates-view.component';\nimport { BsDatepickerEffects } from '../reducer/bs-datepicker.effects';\nimport { Observable, Subscription } from 'rxjs';\nimport {\n  BsDatepickerViewMode,\n  BsNavigationEvent,\n  CalendarCellViewModel,\n  CellHoverEvent,\n  DatepickerRenderOptions,\n  DatepickerDateCustomClasses,\n  DatepickerDateTooltipText,\n  DaysCalendarViewModel,\n  DayViewModel,\n  MonthsCalendarViewModel,\n  WeekViewModel,\n  YearsCalendarViewModel\n} from '../models';\n\nexport abstract class BsDatepickerAbstractComponent {\n  containerClass = '';\n  isOtherMonthsActive?: boolean;\n  showTodayBtn?: boolean;\n  todayBtnLbl?: string;\n  todayPos?: string;\n  showClearBtn?: boolean;\n  clearBtnLbl?: string;\n  clearPos?: string;\n\n  _effects?: BsDatepickerEffects;\n  customRanges: BsCustomDates[] = [];\n  customRangeBtnLbl?: string;\n  chosenRange: Date[] = [];\n\n  multipleCalendars?: boolean;\n\n  isRangePicker?: boolean;\n  withTimepicker?: boolean;\n\n  set minDate(value: Date|undefined) {\n    this._effects?.setMinDate(value);\n  }\n\n  set maxDate(value: Date|undefined) {\n    this._effects?.setMaxDate(value);\n  }\n  set daysDisabled(value: number[]|undefined) {\n    this._effects?.setDaysDisabled(value);\n  }\n  set datesDisabled(value: Date[]|undefined) {\n    this._effects?.setDatesDisabled(value);\n  }\n\n  set datesEnabled(value: Date[]|undefined) {\n    this._effects?.setDatesEnabled(value);\n  }\n\n  set isDisabled(value: boolean|undefined) {\n    this._effects?.setDisabled(value);\n  }\n\n  set dateCustomClasses(value: DatepickerDateCustomClasses[]|undefined) {\n    this._effects?.setDateCustomClasses(value);\n  }\n\n  set dateTooltipTexts(value: DatepickerDateTooltipText[]|undefined) {\n    this._effects?.setDateTooltipTexts(value);\n  }\n\n  viewMode?: Observable<BsDatepickerViewMode|undefined>;\n  monthsCalendar?: Observable<MonthsCalendarViewModel[]|undefined>;\n  yearsCalendar?: Observable<YearsCalendarViewModel[]|undefined>;\n  options$!: Observable<DatepickerRenderOptions|undefined>;\n\n  _daysCalendar$!: Observable<DaysCalendarViewModel[]|undefined>;\n  _daysCalendarSub = new Subscription();\n\n  set daysCalendar$(value: Observable<DaysCalendarViewModel[]|undefined>) {\n    this._daysCalendar$ = value;\n    this._daysCalendarSub.unsubscribe();\n    this._daysCalendarSub.add(this._daysCalendar$.subscribe(value => {\n      this.multipleCalendars = !!value && value.length > 1;\n    }));\n  }\n\n  get daysCalendar$(): Observable<DaysCalendarViewModel[]|undefined> {\n    return this._daysCalendar$;\n  }\n\n  selectedTime?: Observable<Date[]|undefined>;\n  selectedTimeSub = new Subscription();\n\n  // todo: valorkin fix\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars,@typescript-eslint/no-empty-function\n  setViewMode(event: BsDatepickerViewMode): void {}\n\n  // eslint-disable-next-line\n  navigateTo(event: BsNavigationEvent): void {}\n\n  // eslint-disable-next-line\n  dayHoverHandler(event: CellHoverEvent): void {}\n\n  // eslint-disable-next-line\n  weekHoverHandler(event: WeekViewModel): void {}\n\n  // eslint-disable-next-line\n  monthHoverHandler(event: CellHoverEvent): void {}\n\n  // eslint-disable-next-line\n  yearHoverHandler(event: CellHoverEvent): void {}\n\n  // eslint-disable-next-line\n  timeSelectHandler(date: Date, index: number): void {}\n\n  // eslint-disable-next-line\n  daySelectHandler(day: DayViewModel): void {}\n\n  // eslint-disable-next-line\n  monthSelectHandler(event: CalendarCellViewModel): void {}\n\n  // eslint-disable-next-line\n  yearSelectHandler(event: CalendarCellViewModel): void {}\n\n  // eslint-disable-next-line\n  setRangeOnCalendar(dates: BsCustomDates): void {}\n\n  // eslint-disable-next-line\n  setToday(): void {}\n\n  // eslint-disable-next-line\n  clearDate(): void {}\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  _stopPropagation(event: any): void {\n    event.stopPropagation();\n  }\n}\n"]}","import { Injectable } from '@angular/core';\nimport * as i0 from \"@angular/core\";\nexport class BsDatepickerActions {\n static { this.CALCULATE = '[datepicker] calculate dates matrix'; }\n static { this.FORMAT = '[datepicker] format datepicker values'; }\n static { this.FLAG = '[datepicker] set flags'; }\n static { this.SELECT = '[datepicker] select date'; }\n static { this.NAVIGATE_OFFSET = '[datepicker] shift view date'; }\n static { this.NAVIGATE_TO = '[datepicker] change view date'; }\n static { this.SET_OPTIONS = '[datepicker] update render options'; }\n static { this.HOVER = '[datepicker] hover date'; }\n static { this.CHANGE_VIEWMODE = '[datepicker] switch view mode'; }\n static { this.SET_MIN_DATE = '[datepicker] set min date'; }\n static { this.SET_MAX_DATE = '[datepicker] set max date'; }\n static { this.SET_DAYSDISABLED = '[datepicker] set days disabled'; }\n static { this.SET_DATESDISABLED = '[datepicker] set dates disabled'; }\n static { this.SET_DATESENABLED = '[datepicker] set dates enabled'; }\n static { this.SET_IS_DISABLED = '[datepicker] set is disabled'; }\n static { this.SET_DATE_CUSTOM_CLASSES = '[datepicker] set date custom classes'; }\n static { this.SET_DATE_TOOLTIP_TEXTS = '[datepicker] set date tooltip texts'; }\n static { this.SET_LOCALE = '[datepicker] set datepicker locale'; }\n static { this.SELECT_TIME = '[datepicker] select time'; }\n static { this.SELECT_RANGE = '[daterangepicker] select dates range'; }\n calculate() {\n return { type: BsDatepickerActions.CALCULATE };\n }\n format() {\n return { type: BsDatepickerActions.FORMAT };\n }\n flag() {\n return { type: BsDatepickerActions.FLAG };\n }\n select(date) {\n return {\n type: BsDatepickerActions.SELECT,\n payload: date\n };\n }\n selectTime(date, index) {\n return {\n type: BsDatepickerActions.SELECT_TIME,\n payload: { date, index },\n };\n }\n changeViewMode(event) {\n return {\n type: BsDatepickerActions.CHANGE_VIEWMODE,\n payload: event\n };\n }\n navigateTo(event) {\n return {\n type: BsDatepickerActions.NAVIGATE_TO,\n payload: event\n };\n }\n navigateStep(step) {\n return {\n type: BsDatepickerActions.NAVIGATE_OFFSET,\n payload: step\n };\n }\n setOptions(options) {\n return {\n type: BsDatepickerActions.SET_OPTIONS,\n payload: options\n };\n }\n // date range picker\n selectRange(value) {\n return {\n type: BsDatepickerActions.SELECT_RANGE,\n payload: value\n };\n }\n hoverDay(event) {\n return {\n type: BsDatepickerActions.HOVER,\n payload: event.isHovered ? event.cell.date : null\n };\n }\n minDate(date) {\n return {\n type: BsDatepickerActions.SET_MIN_DATE,\n payload: date\n };\n }\n maxDate(date) {\n return {\n type: BsDatepickerActions.SET_MAX_DATE,\n payload: date\n };\n }\n daysDisabled(days) {\n return {\n type: BsDatepickerActions.SET_DAYSDISABLED,\n payload: days\n };\n }\n datesDisabled(dates) {\n return {\n type: BsDatepickerActions.SET_DATESDISABLED,\n payload: dates\n };\n }\n datesEnabled(dates) {\n return {\n type: BsDatepickerActions.SET_DATESENABLED,\n payload: dates\n };\n }\n isDisabled(value) {\n return {\n type: BsDatepickerActions.SET_IS_DISABLED,\n payload: value\n };\n }\n setDateCustomClasses(value) {\n return {\n type: BsDatepickerActions.SET_DATE_CUSTOM_CLASSES,\n payload: value\n };\n }\n setDateTooltipTexts(value) {\n return {\n type: BsDatepickerActions.SET_DATE_TOOLTIP_TEXTS,\n payload: value\n };\n }\n setLocale(locale) {\n return {\n type: BsDatepickerActions.SET_LOCALE,\n payload: locale\n };\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.2\", ngImport: i0, type: BsDatepickerActions, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.0.2\", ngImport: i0, type: BsDatepickerActions, providedIn: 'platform' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.2\", ngImport: i0, type: BsDatepickerActions, decorators: [{\n type: Injectable,\n args: [{ providedIn: 'platform' }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-datepicker.actions.js","sourceRoot":"","sources":["../../../../../src/datepicker/reducer/bs-datepicker.actions.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { TimeUnit } from 'ngx-bootstrap/chronos';\nimport { Action } from 'ngx-bootstrap/mini-ngrx';\nimport {\n  BsDatepickerViewMode,\n  BsViewNavigationEvent,\n  CellHoverEvent,\n  DatepickerRenderOptions,\n  DatepickerDateCustomClasses,\n  DatepickerDateTooltipText\n} from '../models';\n\n@Injectable({providedIn: 'platform'})\nexport class BsDatepickerActions {\n  static readonly CALCULATE = '[datepicker] calculate dates matrix';\n  static readonly FORMAT = '[datepicker] format datepicker values';\n  static readonly FLAG = '[datepicker] set flags';\n  static readonly SELECT = '[datepicker] select date';\n  static readonly NAVIGATE_OFFSET = '[datepicker] shift view date';\n  static readonly NAVIGATE_TO = '[datepicker] change view date';\n  static readonly SET_OPTIONS = '[datepicker] update render options';\n  static readonly HOVER = '[datepicker] hover date';\n  static readonly CHANGE_VIEWMODE = '[datepicker] switch view mode';\n\n  static readonly SET_MIN_DATE = '[datepicker] set min date';\n  static readonly SET_MAX_DATE = '[datepicker] set max date';\n  static readonly SET_DAYSDISABLED = '[datepicker] set days disabled';\n  static readonly SET_DATESDISABLED = '[datepicker] set dates disabled';\n  static readonly SET_DATESENABLED = '[datepicker] set dates enabled';\n  static readonly SET_IS_DISABLED = '[datepicker] set is disabled';\n  static readonly SET_DATE_CUSTOM_CLASSES = '[datepicker] set date custom classes';\n  static readonly SET_DATE_TOOLTIP_TEXTS = '[datepicker] set date tooltip texts';\n  static readonly SET_LOCALE = '[datepicker] set datepicker locale';\n  static readonly SELECT_TIME = '[datepicker] select time';\n\n  static readonly SELECT_RANGE = '[daterangepicker] select dates range';\n\n  calculate(): Action {\n    return { type: BsDatepickerActions.CALCULATE };\n  }\n\n  format(): Action {\n    return { type: BsDatepickerActions.FORMAT };\n  }\n\n  flag(): Action {\n    return { type: BsDatepickerActions.FLAG };\n  }\n\n  select(date?: Date): Action {\n    return {\n      type: BsDatepickerActions.SELECT,\n      payload: date\n    };\n  }\n\n  selectTime(date: Date, index: number): Action {\n    return  {\n      type: BsDatepickerActions.SELECT_TIME,\n      payload: { date, index },\n    };\n  }\n\n  changeViewMode(event: BsDatepickerViewMode): Action {\n    return {\n      type: BsDatepickerActions.CHANGE_VIEWMODE,\n      payload: event\n    };\n  }\n\n  navigateTo(event: BsViewNavigationEvent): Action {\n    return {\n      type: BsDatepickerActions.NAVIGATE_TO,\n      payload: event\n    };\n  }\n\n  navigateStep(step?: TimeUnit): Action {\n    return {\n      type: BsDatepickerActions.NAVIGATE_OFFSET,\n      payload: step\n    };\n  }\n\n  setOptions(options: DatepickerRenderOptions): Action {\n    return {\n      type: BsDatepickerActions.SET_OPTIONS,\n      payload: options\n    };\n  }\n\n  // date range picker\n  selectRange(value?: (Date|undefined)[] | undefined): Action {\n    return {\n      type: BsDatepickerActions.SELECT_RANGE,\n      payload: value\n    };\n  }\n\n  hoverDay(event: CellHoverEvent): Action {\n    return {\n      type: BsDatepickerActions.HOVER,\n      payload: event.isHovered ? event.cell.date : null\n    };\n  }\n\n  minDate(date?: Date): Action {\n    return {\n      type: BsDatepickerActions.SET_MIN_DATE,\n      payload: date\n    };\n  }\n\n  maxDate(date?: Date): Action {\n    return {\n      type: BsDatepickerActions.SET_MAX_DATE,\n      payload: date\n    };\n  }\n\n  daysDisabled(days?: number[]): Action {\n    return {\n      type: BsDatepickerActions.SET_DAYSDISABLED,\n      payload: days\n    };\n  }\n\n  datesDisabled(dates?: Date[]): Action {\n    return {\n      type: BsDatepickerActions.SET_DATESDISABLED,\n      payload: dates\n    };\n  }\n\n  datesEnabled(dates?: Date[]): Action {\n    return {\n      type: BsDatepickerActions.SET_DATESENABLED,\n      payload: dates\n    };\n  }\n\n  isDisabled(value?: boolean): Action {\n    return {\n      type: BsDatepickerActions.SET_IS_DISABLED,\n      payload: value\n    };\n  }\n\n  setDateCustomClasses(value?: DatepickerDateCustomClasses[]): Action {\n    return {\n      type: BsDatepickerActions.SET_DATE_CUSTOM_CLASSES,\n      payload: value\n    };\n  }\n\n  setDateTooltipTexts(value?: DatepickerDateTooltipText[]): Action {\n    return {\n      type: BsDatepickerActions.SET_DATE_TOOLTIP_TEXTS,\n      payload: value\n    };\n  }\n\n  setLocale(locale: string): Action {\n    return {\n      type: BsDatepickerActions.SET_LOCALE,\n      payload: locale\n    };\n  }\n}\n"]}","import { Injectable } from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\nimport * as i0 from \"@angular/core\";\nexport class BsLocaleService {\n constructor() {\n this._defaultLocale = 'en';\n this._locale = new BehaviorSubject(this._defaultLocale);\n this._localeChange = this._locale.asObservable();\n }\n get locale() {\n return this._locale;\n }\n get localeChange() {\n return this._localeChange;\n }\n get currentLocale() {\n return this._locale.getValue();\n }\n use(locale) {\n if (locale === this.currentLocale) {\n return;\n }\n this._locale.next(locale);\n }\n static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.2\", ngImport: i0, type: BsLocaleService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }\n static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.0.2\", ngImport: i0, type: BsLocaleService, providedIn: 'platform' }); }\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.2\", ngImport: i0, type: BsLocaleService, decorators: [{\n type: Injectable,\n args: [{ providedIn: 'platform' }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnMtbG9jYWxlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZGF0ZXBpY2tlci9icy1sb2NhbGUuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQWMsTUFBTSxNQUFNLENBQUM7O0FBR25ELE1BQU0sT0FBTyxlQUFlO0lBRDVCO1FBRVUsbUJBQWMsR0FBRyxJQUFJLENBQUM7UUFDdEIsWUFBTyxHQUFHLElBQUksZUFBZSxDQUFTLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUMzRCxrQkFBYSxHQUF1QixJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksRUFBRSxDQUFDO0tBcUJ6RTtJQW5CQyxJQUFJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDdEIsQ0FBQztJQUVELElBQUksWUFBWTtRQUNkLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUM1QixDQUFDO0lBRUQsSUFBSSxhQUFhO1FBQ2YsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxHQUFHLENBQUMsTUFBYztRQUNoQixJQUFJLE1BQU0sS0FBSyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDbEMsT0FBTztRQUNULENBQUM7UUFFRCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM1QixDQUFDOzhHQXZCVSxlQUFlO2tIQUFmLGVBQWUsY0FESCxVQUFVOzsyRkFDdEIsZUFBZTtrQkFEM0IsVUFBVTttQkFBQyxFQUFDLFVBQVUsRUFBRSxVQUFVLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcblxuQEluamVjdGFibGUoe3Byb3ZpZGVkSW46ICdwbGF0Zm9ybSd9KVxuZXhwb3J0IGNsYXNzIEJzTG9jYWxlU2VydmljZSB7XG4gIHByaXZhdGUgX2RlZmF1bHRMb2NhbGUgPSAnZW4nO1xuICBwcml2YXRlIF9sb2NhbGUgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PHN0cmluZz4odGhpcy5fZGVmYXVsdExvY2FsZSk7XG4gIHByaXZhdGUgX2xvY2FsZUNoYW5nZTogT2JzZXJ2YWJsZTxzdHJpbmc+ID0gdGhpcy5fbG9jYWxlLmFzT2JzZXJ2YWJsZSgpO1xuXG4gIGdldCBsb2NhbGUoKTogQmVoYXZpb3JTdWJqZWN0PHN0cmluZz4ge1xuICAgIHJldHVybiB0aGlzLl9sb2NhbGU7XG4gIH1cblxuICBnZXQgbG9jYWxlQ2hhbmdlKCk6IE9ic2VydmFibGU8c3RyaW5nPiB7XG4gICAgcmV0dXJuIHRoaXMuX2xvY2FsZUNoYW5nZTtcbiAgfVxuXG4gIGdldCBjdXJyZW50TG9jYWxlKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX2xvY2FsZS5nZXRWYWx1ZSgpO1xuICB9XG5cbiAgdXNlKGxvY2FsZTogc3RyaW5nKTogdm9pZCB7XG4gICAgaWYgKGxvY2FsZSA9PT0gdGhpcy5jdXJyZW50TG9jYWxlKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgdGhpcy5fbG9jYWxlLm5leHQobG9jYWxlKTtcbiAgfVxufVxuIl19","import { Injectable } from '@angular/core';\nimport { combineLatest } from 'rxjs';\nimport { filter, map } from 'rxjs/operators';\nimport { BsLocaleService } from '../bs-locale.service';\nimport { BsDatepickerActions } from './bs-datepicker.actions';\nimport * as i0 from \"@angular/core\";\nimport * as i1 from \"./bs-datepicker.actions\";\nimport * as i2 from \"../bs-locale.service\";\nexport class BsDatepickerEffects {\n constructor(_actions, _localeService) {\n this._actions = _actions;\n this._localeService = _localeService;\n this._subs = [];\n }\n init(_bsDatepickerStore) {\n this._store = _bsDatepickerStore;\n return this;\n }\n /** setters */\n setValue(value) {\n this._store?.dispatch(this._actions.select(value));\n }\n setRangeValue(value) {\n this._store?.dispatch(this._actions.selectRange(value));\n }\n setMinDate(value) {\n this._store?.dispatch(this._actions.minDate(value));\n return this;\n }\n setMaxDate(value) {\n this._store?.dispatch(this._actions.maxDate(value));\n return this;\n }\n setDaysDisabled(value) {\n this._store?.dispatch(this._actions.daysDisabled(value));\n return this;\n }\n setDatesDisabled(value) {\n this._store?.dispatch(this._actions.datesDisabled(value));\n return this;\n }\n setDatesEnabled(value) {\n this._store?.dispatch(this._actions.datesEnabled(value));\n return this;\n }\n setDisabled(value) {\n this._store?.dispatch(this._actions.isDisabled(value));\n return this;\n }\n setDateCustomClasses(value) {\n this._store?.dispatch(this._actions.setDateCustomClasses(value));\n return this;\n }\n setDateTooltipTexts(value) {\n this._store?.dispatch(this._actions.setDateTooltipTexts(value));\n return this;\n }\n /* Set rendering options */\n setOptions(_config) {\n const _options = Object.assign({ locale: this._localeService.currentLocale }, _config);\n this._store?.dispatch(this._actions.setOptions(_options));\n return this;\n }\n /** view to mode bindings */\n setBindings(container) {\n if (!this._store) {\n return this;\n }\n container.selectedTime = this._store.select(state => state.selectedTime)\n .pipe(filter(times => !!times));\n container.daysCalendar$ = this._store.select(state => state.flaggedMonths)\n .pipe(filter(months => !!months));\n // month calendar\n container.monthsCalendar = this._store.select(state => state.flaggedMonthsCalendar)\n .pipe(filter(months => !!months));\n // year calendar\n container.yearsCalendar = this._store.select(state => state.yearsCalendarFlagged)\n .pipe(filter(years => !!years));\n container.viewMode = this._store.select(state => state.view?.mode);\n container.options$ = combineLatest([\n this._store.select(state => state.showWeekNumbers),\n this._store.select(state => state.di