bs-datepicker.reducer.js 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. // tslint:disable:max-file-line-count
  6. import { initialDatepickerState } from './bs-datepicker.state';
  7. import { BsDatepickerActions } from './bs-datepicker.actions';
  8. import { calcDaysCalendar } from '../engine/calc-days-calendar';
  9. import { formatDaysCalendar } from '../engine/format-days-calendar';
  10. import { flagDaysCalendar } from '../engine/flag-days-calendar';
  11. import { setFullDate, shiftDate, isArray, isDateValid, startOf, getLocale, isAfter, isBefore } from 'ngx-bootstrap/chronos';
  12. import { canSwitchMode } from '../engine/view-mode';
  13. import { formatMonthsCalendar } from '../engine/format-months-calendar';
  14. import { flagMonthsCalendar } from '../engine/flag-months-calendar';
  15. import { formatYearsCalendar, initialYearShift, yearsPerCalendar } from '../engine/format-years-calendar';
  16. import { flagYearsCalendar } from '../engine/flag-years-calendar';
  17. import { getYearsCalendarInitialDate } from '../utils/bs-calendar-utils';
  18. /* tslint:disable-next-line: cyclomatic-complexity */
  19. /**
  20. * @param {?=} state
  21. * @param {?=} action
  22. * @return {?}
  23. */
  24. export function bsDatepickerReducer(state = initialDatepickerState, action) {
  25. switch (action.type) {
  26. case BsDatepickerActions.CALCULATE: {
  27. return calculateReducer(state);
  28. }
  29. case BsDatepickerActions.FORMAT: {
  30. return formatReducer(state, action);
  31. }
  32. case BsDatepickerActions.FLAG: {
  33. return flagReducer(state, action);
  34. }
  35. case BsDatepickerActions.NAVIGATE_OFFSET: {
  36. return navigateOffsetReducer(state, action);
  37. }
  38. case BsDatepickerActions.NAVIGATE_TO: {
  39. /** @type {?} */
  40. const payload = action.payload;
  41. /** @type {?} */
  42. const date = setFullDate(state.view.date, payload.unit);
  43. /** @type {?} */
  44. let newState;
  45. /** @type {?} */
  46. let mode;
  47. if (canSwitchMode(payload.viewMode, state.minMode)) {
  48. mode = payload.viewMode;
  49. newState = { view: { date, mode } };
  50. }
  51. else {
  52. mode = state.view.mode;
  53. newState = { selectedDate: date, view: { date, mode } };
  54. }
  55. return Object.assign({}, state, newState);
  56. }
  57. case BsDatepickerActions.CHANGE_VIEWMODE: {
  58. if (!canSwitchMode(action.payload, state.minMode)) {
  59. return state;
  60. }
  61. /** @type {?} */
  62. const date = state.view.date;
  63. /** @type {?} */
  64. const mode = action.payload;
  65. /** @type {?} */
  66. const newState = { view: { date, mode } };
  67. return Object.assign({}, state, newState);
  68. }
  69. case BsDatepickerActions.HOVER: {
  70. return Object.assign({}, state, { hoveredDate: action.payload });
  71. }
  72. case BsDatepickerActions.SELECT: {
  73. /** @type {?} */
  74. const newState = {
  75. selectedDate: action.payload,
  76. view: state.view
  77. };
  78. /** @type {?} */
  79. const mode = state.view.mode;
  80. /** @type {?} */
  81. const _date = action.payload || state.view.date;
  82. /** @type {?} */
  83. const date = getViewDate(_date, state.minDate, state.maxDate);
  84. newState.view = { mode, date };
  85. return Object.assign({}, state, newState);
  86. }
  87. case BsDatepickerActions.SET_OPTIONS: {
  88. /** @type {?} */
  89. const newState = action.payload;
  90. // preserve view mode
  91. /** @type {?} */
  92. const mode = newState.minMode ? newState.minMode : state.view.mode;
  93. /** @type {?} */
  94. const _viewDate = isDateValid(newState.value) && newState.value
  95. || isArray(newState.value) && isDateValid(newState.value[0]) && newState.value[0]
  96. || state.view.date;
  97. /** @type {?} */
  98. const date = getViewDate(_viewDate, newState.minDate, newState.maxDate);
  99. newState.view = { mode, date };
  100. // update selected value
  101. if (newState.value) {
  102. // if new value is array we work with date range
  103. if (isArray(newState.value)) {
  104. newState.selectedRange = newState.value;
  105. }
  106. // if new value is a date -> datepicker
  107. if (newState.value instanceof Date) {
  108. newState.selectedDate = newState.value;
  109. }
  110. // provided value is not supported :)
  111. // need to report it somehow
  112. }
  113. return Object.assign({}, state, newState);
  114. }
  115. // date range picker
  116. case BsDatepickerActions.SELECT_RANGE: {
  117. /** @type {?} */
  118. const newState = {
  119. selectedRange: action.payload,
  120. view: state.view
  121. };
  122. /** @type {?} */
  123. const mode = state.view.mode;
  124. /** @type {?} */
  125. const _date = action.payload && action.payload[0] || state.view.date;
  126. /** @type {?} */
  127. const date = getViewDate(_date, state.minDate, state.maxDate);
  128. newState.view = { mode, date };
  129. return Object.assign({}, state, newState);
  130. }
  131. case BsDatepickerActions.SET_MIN_DATE: {
  132. return Object.assign({}, state, {
  133. minDate: action.payload
  134. });
  135. }
  136. case BsDatepickerActions.SET_MAX_DATE: {
  137. return Object.assign({}, state, {
  138. maxDate: action.payload
  139. });
  140. }
  141. case BsDatepickerActions.SET_IS_DISABLED: {
  142. return Object.assign({}, state, {
  143. isDisabled: action.payload
  144. });
  145. }
  146. case BsDatepickerActions.SET_DATE_CUSTOM_CLASSES: {
  147. return Object.assign({}, state, {
  148. dateCustomClasses: action.payload
  149. });
  150. }
  151. default:
  152. return state;
  153. }
  154. }
  155. /**
  156. * @param {?} state
  157. * @return {?}
  158. */
  159. function calculateReducer(state) {
  160. // how many calendars
  161. /** @type {?} */
  162. const displayMonths = state.displayMonths;
  163. // use selected date on initial rendering if set
  164. /** @type {?} */
  165. let viewDate = state.view.date;
  166. if (state.view.mode === 'day') {
  167. state.monthViewOptions.firstDayOfWeek = getLocale(state.locale).firstDayOfWeek();
  168. /** @type {?} */
  169. const monthsModel = new Array(displayMonths);
  170. for (let monthIndex = 0; monthIndex < displayMonths; monthIndex++) {
  171. // todo: for unlinked calendars it will be harder
  172. monthsModel[monthIndex] = calcDaysCalendar(viewDate, state.monthViewOptions);
  173. viewDate = shiftDate(viewDate, { month: 1 });
  174. }
  175. return Object.assign({}, state, { monthsModel });
  176. }
  177. if (state.view.mode === 'month') {
  178. /** @type {?} */
  179. const monthsCalendar = new Array(displayMonths);
  180. for (let calendarIndex = 0; calendarIndex < displayMonths; calendarIndex++) {
  181. // todo: for unlinked calendars it will be harder
  182. monthsCalendar[calendarIndex] = formatMonthsCalendar(viewDate, getFormatOptions(state));
  183. viewDate = shiftDate(viewDate, { year: 1 });
  184. }
  185. return Object.assign({}, state, { monthsCalendar });
  186. }
  187. if (state.view.mode === 'year') {
  188. /** @type {?} */
  189. const yearsCalendarModel = new Array(displayMonths);
  190. for (let calendarIndex = 0; calendarIndex < displayMonths; calendarIndex++) {
  191. // todo: for unlinked calendars it will be harder
  192. yearsCalendarModel[calendarIndex] = formatYearsCalendar(viewDate, getFormatOptions(state), state.minMode === 'year' ? getYearsCalendarInitialDate(state, calendarIndex) : undefined);
  193. viewDate = shiftDate(viewDate, { year: yearsPerCalendar });
  194. }
  195. return Object.assign({}, state, { yearsCalendarModel });
  196. }
  197. return state;
  198. }
  199. /**
  200. * @param {?} state
  201. * @param {?} action
  202. * @return {?}
  203. */
  204. function formatReducer(state, action) {
  205. if (state.view.mode === 'day') {
  206. /** @type {?} */
  207. const formattedMonths = state.monthsModel.map((/**
  208. * @param {?} month
  209. * @param {?} monthIndex
  210. * @return {?}
  211. */
  212. (month, monthIndex) => formatDaysCalendar(month, getFormatOptions(state), monthIndex)));
  213. return Object.assign({}, state, { formattedMonths });
  214. }
  215. // how many calendars
  216. /** @type {?} */
  217. const displayMonths = state.displayMonths;
  218. // check initial rendering
  219. // use selected date on initial rendering if set
  220. /** @type {?} */
  221. let viewDate = state.view.date;
  222. if (state.view.mode === 'month') {
  223. /** @type {?} */
  224. const monthsCalendar = new Array(displayMonths);
  225. for (let calendarIndex = 0; calendarIndex < displayMonths; calendarIndex++) {
  226. // todo: for unlinked calendars it will be harder
  227. monthsCalendar[calendarIndex] = formatMonthsCalendar(viewDate, getFormatOptions(state));
  228. viewDate = shiftDate(viewDate, { year: 1 });
  229. }
  230. return Object.assign({}, state, { monthsCalendar });
  231. }
  232. if (state.view.mode === 'year') {
  233. /** @type {?} */
  234. const yearsCalendarModel = new Array(displayMonths);
  235. for (let calendarIndex = 0; calendarIndex < displayMonths; calendarIndex++) {
  236. // todo: for unlinked calendars it will be harder
  237. yearsCalendarModel[calendarIndex] = formatYearsCalendar(viewDate, getFormatOptions(state));
  238. viewDate = shiftDate(viewDate, { year: 16 });
  239. }
  240. return Object.assign({}, state, { yearsCalendarModel });
  241. }
  242. return state;
  243. }
  244. /**
  245. * @param {?} state
  246. * @param {?} action
  247. * @return {?}
  248. */
  249. function flagReducer(state, action) {
  250. if (state.view.mode === 'day') {
  251. /** @type {?} */
  252. const flaggedMonths = state.formattedMonths.map((/**
  253. * @param {?} formattedMonth
  254. * @param {?} monthIndex
  255. * @return {?}
  256. */
  257. (formattedMonth, monthIndex) => flagDaysCalendar(formattedMonth, {
  258. isDisabled: state.isDisabled,
  259. minDate: state.minDate,
  260. maxDate: state.maxDate,
  261. daysDisabled: state.daysDisabled,
  262. datesDisabled: state.datesDisabled,
  263. hoveredDate: state.hoveredDate,
  264. selectedDate: state.selectedDate,
  265. selectedRange: state.selectedRange,
  266. displayMonths: state.displayMonths,
  267. dateCustomClasses: state.dateCustomClasses,
  268. monthIndex
  269. })));
  270. return Object.assign({}, state, { flaggedMonths });
  271. }
  272. if (state.view.mode === 'month') {
  273. /** @type {?} */
  274. const flaggedMonthsCalendar = state.monthsCalendar.map((/**
  275. * @param {?} formattedMonth
  276. * @param {?} monthIndex
  277. * @return {?}
  278. */
  279. (formattedMonth, monthIndex) => flagMonthsCalendar(formattedMonth, {
  280. isDisabled: state.isDisabled,
  281. minDate: state.minDate,
  282. maxDate: state.maxDate,
  283. hoveredMonth: state.hoveredMonth,
  284. selectedDate: state.selectedDate,
  285. displayMonths: state.displayMonths,
  286. monthIndex
  287. })));
  288. return Object.assign({}, state, { flaggedMonthsCalendar });
  289. }
  290. if (state.view.mode === 'year') {
  291. /** @type {?} */
  292. const yearsCalendarFlagged = state.yearsCalendarModel.map((/**
  293. * @param {?} formattedMonth
  294. * @param {?} yearIndex
  295. * @return {?}
  296. */
  297. (formattedMonth, yearIndex) => flagYearsCalendar(formattedMonth, {
  298. isDisabled: state.isDisabled,
  299. minDate: state.minDate,
  300. maxDate: state.maxDate,
  301. hoveredYear: state.hoveredYear,
  302. selectedDate: state.selectedDate,
  303. displayMonths: state.displayMonths,
  304. yearIndex
  305. })));
  306. return Object.assign({}, state, { yearsCalendarFlagged });
  307. }
  308. return state;
  309. }
  310. /**
  311. * @param {?} state
  312. * @param {?} action
  313. * @return {?}
  314. */
  315. function navigateOffsetReducer(state, action) {
  316. /** @type {?} */
  317. const newState = {
  318. view: {
  319. mode: state.view.mode,
  320. date: shiftViewDate(state, action)
  321. }
  322. };
  323. return Object.assign({}, state, newState);
  324. }
  325. /**
  326. * @param {?} state
  327. * @param {?} action
  328. * @return {?}
  329. */
  330. function shiftViewDate(state, action) {
  331. if (state.view.mode === 'year' && state.minMode === 'year') {
  332. /** @type {?} */
  333. const initialDate = getYearsCalendarInitialDate(state, 0);
  334. /** @type {?} */
  335. const middleDate = shiftDate(initialDate, { year: -initialYearShift });
  336. return shiftDate(middleDate, action.payload);
  337. }
  338. return shiftDate(startOf(state.view.date, 'month'), action.payload);
  339. }
  340. /**
  341. * @param {?} state
  342. * @return {?}
  343. */
  344. function getFormatOptions(state) {
  345. return {
  346. locale: state.locale,
  347. monthTitle: state.monthTitle,
  348. yearTitle: state.yearTitle,
  349. dayLabel: state.dayLabel,
  350. monthLabel: state.monthLabel,
  351. yearLabel: state.yearLabel,
  352. weekNumbers: state.weekNumbers
  353. };
  354. }
  355. /**
  356. * if view date is provided (bsValue|ngModel) it should be shown
  357. * if view date is not provider:
  358. * if minDate>currentDate (default view value), show minDate
  359. * if maxDate<currentDate(default view value) show maxDate
  360. * @param {?} viewDate
  361. * @param {?} minDate
  362. * @param {?} maxDate
  363. * @return {?}
  364. */
  365. function getViewDate(viewDate, minDate, maxDate) {
  366. /** @type {?} */
  367. const _date = Array.isArray(viewDate) ? viewDate[0] : viewDate;
  368. if (minDate && isAfter(minDate, _date, 'day')) {
  369. return minDate;
  370. }
  371. if (maxDate && isBefore(maxDate, _date, 'day')) {
  372. return maxDate;
  373. }
  374. return _date;
  375. }
  376. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bs-datepicker.reducer.js","sourceRoot":"ng://ngx-bootstrap/datepicker/","sources":["reducer/bs-datepicker.reducer.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable:max-file-line-count\nimport { BsDatepickerState, initialDatepickerState } from './bs-datepicker.state';\nimport { Action } from 'ngx-bootstrap/mini-ngrx';\nimport { BsDatepickerActions } from './bs-datepicker.actions';\nimport { calcDaysCalendar } from '../engine/calc-days-calendar';\nimport { formatDaysCalendar } from '../engine/format-days-calendar';\nimport { flagDaysCalendar } from '../engine/flag-days-calendar';\nimport {\n  setFullDate,\n  shiftDate,\n  isArray,\n  isDateValid,\n  startOf,\n  getLocale,\n  isAfter,\n  isBefore\n} from 'ngx-bootstrap/chronos';\nimport { canSwitchMode } from '../engine/view-mode';\nimport { formatMonthsCalendar } from '../engine/format-months-calendar';\nimport { flagMonthsCalendar } from '../engine/flag-months-calendar';\nimport { formatYearsCalendar, initialYearShift, yearsPerCalendar } from '../engine/format-years-calendar';\nimport { flagYearsCalendar } from '../engine/flag-years-calendar';\nimport { BsViewNavigationEvent, DatepickerFormatOptions, BsDatepickerViewMode } from '../models';\nimport { getYearsCalendarInitialDate } from '../utils/bs-calendar-utils';\n\n\n/* tslint:disable-next-line: cyclomatic-complexity */\nexport function bsDatepickerReducer(state = initialDatepickerState,\n                                    action: Action): BsDatepickerState {\n  switch (action.type) {\n    case BsDatepickerActions.CALCULATE: {\n      return calculateReducer(state);\n    }\n\n    case BsDatepickerActions.FORMAT: {\n      return formatReducer(state, action);\n    }\n\n    case BsDatepickerActions.FLAG: {\n      return flagReducer(state, action);\n    }\n\n    case BsDatepickerActions.NAVIGATE_OFFSET: {\n      return navigateOffsetReducer(state, action);\n    }\n\n    case BsDatepickerActions.NAVIGATE_TO: {\n      const payload: BsViewNavigationEvent = action.payload;\n\n      const date = setFullDate(state.view.date, payload.unit);\n      let newState;\n      let mode: BsDatepickerViewMode;\n      if (canSwitchMode(payload.viewMode, state.minMode)) {\n        mode = payload.viewMode;\n        newState = { view: { date, mode } };\n      } else {\n        mode = state.view.mode;\n        newState = { selectedDate: date, view: { date, mode } };\n      }\n\n      return Object.assign({}, state, newState);\n    }\n\n    case BsDatepickerActions.CHANGE_VIEWMODE: {\n      if (!canSwitchMode(action.payload, state.minMode)) {\n        return state;\n      }\n      const date = state.view.date;\n      const mode = action.payload;\n      const newState = { view: { date, mode } };\n\n      return Object.assign({}, state, newState);\n    }\n\n    case BsDatepickerActions.HOVER: {\n      return Object.assign({}, state, { hoveredDate: action.payload });\n    }\n\n    case BsDatepickerActions.SELECT: {\n      const newState = {\n        selectedDate: action.payload,\n        view: state.view\n      };\n\n      const mode = state.view.mode;\n      const _date = action.payload || state.view.date;\n      const date = getViewDate(_date, state.minDate, state.maxDate);\n      newState.view = { mode, date };\n\n      return Object.assign({}, state, newState);\n    }\n\n    case BsDatepickerActions.SET_OPTIONS: {\n      const newState = action.payload;\n      // preserve view mode\n      const mode = newState.minMode ? newState.minMode : state.view.mode;\n      const _viewDate = isDateValid(newState.value) && newState.value\n        || isArray(newState.value) && isDateValid(newState.value[0]) && newState.value[0]\n        || state.view.date;\n      const date = getViewDate(_viewDate, newState.minDate, newState.maxDate);\n      newState.view = { mode, date };\n      // update selected value\n      if (newState.value) {\n        // if new value is array we work with date range\n        if (isArray(newState.value)) {\n          newState.selectedRange = newState.value;\n        }\n\n        // if new value is a date -> datepicker\n        if (newState.value instanceof Date) {\n          newState.selectedDate = newState.value;\n        }\n\n        // provided value is not supported :)\n        // need to report it somehow\n      }\n\n      return Object.assign({}, state, newState);\n    }\n\n    // date range picker\n    case BsDatepickerActions.SELECT_RANGE: {\n      const newState = {\n        selectedRange: action.payload,\n        view: state.view\n      };\n\n      const mode = state.view.mode;\n      const _date = action.payload && action.payload[0] || state.view.date;\n      const date = getViewDate(_date, state.minDate, state.maxDate);\n      newState.view = { mode, date };\n\n      return Object.assign({}, state, newState);\n    }\n\n    case BsDatepickerActions.SET_MIN_DATE: {\n      return Object.assign({}, state, {\n        minDate: action.payload\n      });\n    }\n    case BsDatepickerActions.SET_MAX_DATE: {\n      return Object.assign({}, state, {\n        maxDate: action.payload\n      });\n    }\n    case BsDatepickerActions.SET_IS_DISABLED: {\n      return Object.assign({}, state, {\n        isDisabled: action.payload\n      });\n    }\n    case BsDatepickerActions.SET_DATE_CUSTOM_CLASSES: {\n      return Object.assign({}, state, {\n        dateCustomClasses: action.payload\n      });\n    }\n\n    default:\n      return state;\n  }\n}\n\nfunction calculateReducer(state: BsDatepickerState): BsDatepickerState {\n  // how many calendars\n  const displayMonths = state.displayMonths;\n  // use selected date on initial rendering if set\n  let viewDate = state.view.date;\n\n  if (state.view.mode === 'day') {\n    state.monthViewOptions.firstDayOfWeek = getLocale(state.locale).firstDayOfWeek();\n    const monthsModel = new Array(displayMonths);\n    for (let monthIndex = 0; monthIndex < displayMonths; monthIndex++) {\n      // todo: for unlinked calendars it will be harder\n      monthsModel[monthIndex] = calcDaysCalendar(\n        viewDate,\n        state.monthViewOptions\n      );\n      viewDate = shiftDate(viewDate, { month: 1 });\n    }\n\n    return Object.assign({}, state, { monthsModel });\n  }\n\n  if (state.view.mode === 'month') {\n    const monthsCalendar = new Array(displayMonths);\n    for (\n      let calendarIndex = 0;\n      calendarIndex < displayMonths;\n      calendarIndex++\n    ) {\n      // todo: for unlinked calendars it will be harder\n      monthsCalendar[calendarIndex] = formatMonthsCalendar(\n        viewDate,\n        getFormatOptions(state)\n      );\n      viewDate = shiftDate(viewDate, { year: 1 });\n    }\n\n    return Object.assign({}, state, { monthsCalendar });\n  }\n\n  if (state.view.mode === 'year') {\n    const yearsCalendarModel = new Array(displayMonths);\n\n    for (\n      let calendarIndex = 0;\n      calendarIndex < displayMonths;\n      calendarIndex++\n    ) {\n      // todo: for unlinked calendars it will be harder\n      yearsCalendarModel[calendarIndex] = formatYearsCalendar(\n        viewDate,\n        getFormatOptions(state),\n        state.minMode === 'year' ? getYearsCalendarInitialDate(state, calendarIndex) : undefined\n      );\n      viewDate = shiftDate(viewDate, { year: yearsPerCalendar });\n    }\n\n    return Object.assign({}, state, { yearsCalendarModel });\n  }\n\n  return state;\n}\n\nfunction formatReducer(state: BsDatepickerState,\n                       action: Action): BsDatepickerState {\n  if (state.view.mode === 'day') {\n    const formattedMonths = state.monthsModel.map((month, monthIndex) =>\n      formatDaysCalendar(month, getFormatOptions(state), monthIndex)\n    );\n\n    return Object.assign({}, state, { formattedMonths });\n  }\n\n  // how many calendars\n  const displayMonths = state.displayMonths;\n  // check initial rendering\n  // use selected date on initial rendering if set\n  let viewDate = state.view.date;\n\n  if (state.view.mode === 'month') {\n    const monthsCalendar = new Array(displayMonths);\n    for (\n      let calendarIndex = 0;\n      calendarIndex < displayMonths;\n      calendarIndex++\n    ) {\n      // todo: for unlinked calendars it will be harder\n      monthsCalendar[calendarIndex] = formatMonthsCalendar(\n        viewDate,\n        getFormatOptions(state)\n      );\n      viewDate = shiftDate(viewDate, { year: 1 });\n    }\n\n    return Object.assign({}, state, { monthsCalendar });\n  }\n\n  if (state.view.mode === 'year') {\n    const yearsCalendarModel = new Array(displayMonths);\n    for (\n      let calendarIndex = 0;\n      calendarIndex < displayMonths;\n      calendarIndex++\n    ) {\n      // todo: for unlinked calendars it will be harder\n      yearsCalendarModel[calendarIndex] = formatYearsCalendar(\n        viewDate,\n        getFormatOptions(state)\n      );\n      viewDate = shiftDate(viewDate, { year: 16 });\n    }\n\n    return Object.assign({}, state, { yearsCalendarModel });\n  }\n\n  return state;\n}\n\nfunction flagReducer(state: BsDatepickerState,\n                     action: Action): BsDatepickerState {\n  if (state.view.mode === 'day') {\n    const flaggedMonths = state.formattedMonths.map(\n      (formattedMonth, monthIndex) =>\n        flagDaysCalendar(formattedMonth, {\n          isDisabled: state.isDisabled,\n          minDate: state.minDate,\n          maxDate: state.maxDate,\n          daysDisabled: state.daysDisabled,\n          datesDisabled: state.datesDisabled,\n          hoveredDate: state.hoveredDate,\n          selectedDate: state.selectedDate,\n          selectedRange: state.selectedRange,\n          displayMonths: state.displayMonths,\n          dateCustomClasses: state.dateCustomClasses,\n          monthIndex\n        })\n    );\n\n    return Object.assign({}, state, { flaggedMonths });\n  }\n\n  if (state.view.mode === 'month') {\n    const flaggedMonthsCalendar = state.monthsCalendar.map(\n      (formattedMonth, monthIndex) =>\n        flagMonthsCalendar(formattedMonth, {\n          isDisabled: state.isDisabled,\n          minDate: state.minDate,\n          maxDate: state.maxDate,\n          hoveredMonth: state.hoveredMonth,\n          selectedDate: state.selectedDate,\n          displayMonths: state.displayMonths,\n          monthIndex\n        })\n    );\n\n    return Object.assign({}, state, { flaggedMonthsCalendar });\n  }\n\n  if (state.view.mode === 'year') {\n    const yearsCalendarFlagged = state.yearsCalendarModel.map(\n      (formattedMonth, yearIndex) =>\n        flagYearsCalendar(formattedMonth, {\n          isDisabled: state.isDisabled,\n          minDate: state.minDate,\n          maxDate: state.maxDate,\n          hoveredYear: state.hoveredYear,\n          selectedDate: state.selectedDate,\n          displayMonths: state.displayMonths,\n          yearIndex\n        })\n    );\n\n    return Object.assign({}, state, { yearsCalendarFlagged });\n  }\n\n  return state;\n}\n\nfunction navigateOffsetReducer(state: BsDatepickerState, action: Action): BsDatepickerState {\n  const newState = {\n    view: {\n      mode: state.view.mode,\n      date: shiftViewDate(state, action)\n    }\n  };\n\n  return Object.assign({}, state, newState);\n}\n\nfunction shiftViewDate(state: BsDatepickerState, action: Action): Date {\n  if (state.view.mode === 'year' && state.minMode === 'year') {\n    const initialDate = getYearsCalendarInitialDate(state, 0);\n    const middleDate = shiftDate(initialDate, { year: -initialYearShift });\n\n    return shiftDate(middleDate, action.payload);\n  }\n\n  return shiftDate(startOf(state.view.date, 'month'), action.payload);\n}\n\nfunction getFormatOptions(state: BsDatepickerState): DatepickerFormatOptions {\n  return {\n    locale: state.locale,\n\n    monthTitle: state.monthTitle,\n    yearTitle: state.yearTitle,\n\n    dayLabel: state.dayLabel,\n    monthLabel: state.monthLabel,\n    yearLabel: state.yearLabel,\n\n    weekNumbers: state.weekNumbers\n  };\n}\n\n/**\n * if view date is provided (bsValue|ngModel) it should be shown\n * if view date is not provider:\n * if minDate>currentDate (default view value), show minDate\n * if maxDate<currentDate(default view value) show maxDate\n */\nfunction getViewDate(viewDate: Date | Date[], minDate: Date, maxDate: Date) {\n  const _date = Array.isArray(viewDate) ? viewDate[0] : viewDate;\n\n  if (minDate && isAfter(minDate, _date, 'day')) {\n    return minDate;\n  }\n\n  if (maxDate && isBefore(maxDate, _date, 'day')) {\n    return maxDate;\n  }\n\n  return _date;\n}\n"]}