UNPKG

angular-bootstrap-datetimepicker

Version:

Native Angular (8+) datetime picker component styled by Twitter Bootstrap 4.

249 lines 31.4 kB
/** * @license * Copyright 2013-present Dale Lotts All Rights Reserved. * http://www.dalelotts.com * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/dalelotts/angular-bootstrap-datetimepicker/blob/master/LICENSE */ import * as _moment from 'moment'; /** * Work around for moment namespace conflict when used with webpack and rollup. * See https://github.com/dherges/ng-packagr/issues/163 * * Depending on whether rollup is used, moment needs to be imported differently. * Since Moment.js doesn't have a default export, we normally need to import using * the `* as`syntax. * * rollup creates a synthetic default module and we thus need to import it using * the `default as` syntax. * * @internal **/ var moment = _moment; /** * Default implementation for the `day` view. */ var DlDayModelProvider = /** @class */ (function () { function DlDayModelProvider() { } /** * Receives input changes detected by Angular. * * @param changes * the input changes detected by Angular. */ DlDayModelProvider.prototype.onChanges = function ( // @ts-ignore changes) { }; /** * Returns the `day` model for the specified moment in `local` time with the * `active` day set to the first day of the month. * * The `day` model represents a month (42 days) as six rows with seven columns * and each cell representing one-day increments. * * The `day` always starts at midnight. * * Each cell represents a one-day increment at midnight. * * @param milliseconds * the moment in time from which the minute model will be created. * @param selectedMilliseconds * the current value of the date/time picker. * @returns * the model representing the specified moment in time. */ DlDayModelProvider.prototype.getModel = function (milliseconds, selectedMilliseconds) { var startOfMonth = moment(milliseconds).startOf('month'); var endOfMonth = moment(milliseconds).endOf('month'); var startOfView = moment(startOfMonth).subtract(Math.abs(startOfMonth.weekday()), 'days'); var rowNumbers = [0, 1, 2, 3, 4, 5]; var columnNumbers = [0, 1, 2, 3, 4, 5, 6]; var previousMonth = moment(startOfMonth).subtract(1, 'month'); var nextMonth = moment(startOfMonth).add(1, 'month'); var activeValue = moment(milliseconds).startOf('day').valueOf(); var selectedValue = selectedMilliseconds === null || selectedMilliseconds === undefined ? selectedMilliseconds : moment(selectedMilliseconds).startOf('day').valueOf(); return { viewName: 'day', viewLabel: startOfMonth.format('MMM YYYY'), activeDate: activeValue, leftButton: { value: previousMonth.valueOf(), ariaLabel: "Go to " + previousMonth.format('MMM YYYY'), classes: {}, }, upButton: { value: startOfMonth.valueOf(), ariaLabel: "Go to month view", classes: {}, }, rightButton: { value: nextMonth.valueOf(), ariaLabel: "Go to " + nextMonth.format('MMM YYYY'), classes: {}, }, rowLabels: columnNumbers.map(function (column) { return moment().weekday(column).format('dd'); }), rows: rowNumbers.map(rowOfDays) }; function rowOfDays(rowNumber) { var currentMoment = moment(); var cells = columnNumbers.map(function (columnNumber) { var dayMoment = moment(startOfView).add((rowNumber * columnNumbers.length) + columnNumber, 'days'); return { display: dayMoment.format('D'), ariaLabel: dayMoment.format('ll'), value: dayMoment.valueOf(), classes: { 'dl-abdtp-active': activeValue === dayMoment.valueOf(), 'dl-abdtp-future': dayMoment.isAfter(endOfMonth), 'dl-abdtp-past': dayMoment.isBefore(startOfMonth), 'dl-abdtp-selected': selectedValue === dayMoment.valueOf(), 'dl-abdtp-now': dayMoment.isSame(currentMoment, 'day'), } }; }); return { cells: cells }; } }; /** * Move the active `day` one row `down` from the specified moment in time. * * Moving `down` can result in the `active` day being part of a different month than * the specified `fromMilliseconds`, in this case the month represented by the model * will change to show the correct hour. * * @param fromMilliseconds * the moment in time from which the next `day` model `down` will be constructed. * @param selectedMilliseconds * the current value of the date/time picker. * @returns * model containing an `active` `day` one row `down` from the specified moment in time. */ DlDayModelProvider.prototype.goDown = function (fromMilliseconds, selectedMilliseconds) { return this.getModel(moment(fromMilliseconds).add(7, 'days').valueOf(), selectedMilliseconds); }; /** * Move the active `day` one row `up` from the specified moment in time. * * Moving `up` can result in the `active` day being part of a different month than * the specified `fromMilliseconds`, in this case the month represented by the model * will change to show the correct hour. * * @param fromMilliseconds * the moment in time from which the next `day` model `up` will be constructed. * @param selectedMilliseconds * the current value of the date/time picker. * @returns * model containing an `active` `day` one row `up` from the specified moment in time. */ DlDayModelProvider.prototype.goUp = function (fromMilliseconds, selectedMilliseconds) { return this.getModel(moment(fromMilliseconds).subtract(7, 'days').valueOf(), selectedMilliseconds); }; /** * Move the `active` day one cell `left` in the current `day` view. * * Moving `left` can result in the `active` day being part of a different month than * the specified `fromMilliseconds`, in this case the month represented by the model * will change to show the correct year. * * @param fromMilliseconds * the moment in time from which the `day` model to the `left` will be constructed. * @param selectedMilliseconds * the current value of the date/time picker. * @returns * model containing an `active` `day` one cell to the `left` of the specified moment in time. */ DlDayModelProvider.prototype.goLeft = function (fromMilliseconds, selectedMilliseconds) { return this.getModel(moment(fromMilliseconds).subtract(1, 'day').valueOf(), selectedMilliseconds); }; /** * Move the `active` day one cell `right` in the current `day` view. * * Moving `right` can result in the `active` day being part of a different month than * the specified `fromMilliseconds`, in this case the month represented by the model * will change to show the correct year. * * @param fromMilliseconds * the moment in time from which the `day` model to the `right` will be constructed. * @param selectedMilliseconds * the current value of the date/time picker. * @returns * model containing an `active` `day` one cell to the `right` of the specified moment in time. */ DlDayModelProvider.prototype.goRight = function (fromMilliseconds, selectedMilliseconds) { return this.getModel(moment(fromMilliseconds).add(1, 'day').valueOf(), selectedMilliseconds); }; /** * Move the active `day` one month `down` from the specified moment in time. * * Paging `down` will result in the `active` day being part of a different month than * the specified `fromMilliseconds`. As a result, the month represented by the model * will change to show the correct year. * * @param fromMilliseconds * the moment in time from which the next `day` model page `down` will be constructed. * @param selectedMilliseconds * the current value of the date/time picker. * @returns * model containing an `active` `day` one month `down` from the specified moment in time. */ DlDayModelProvider.prototype.pageDown = function (fromMilliseconds, selectedMilliseconds) { return this.getModel(moment(fromMilliseconds).add(1, 'month').valueOf(), selectedMilliseconds); }; /** * Move the active `day` one month `up` from the specified moment in time. * * Paging `up` will result in the `active` day being part of a different month than * the specified `fromMilliseconds`. As a result, the month represented by the model * will change to show the correct year. * * @param fromMilliseconds * the moment in time from which the next `day` model page `up` will be constructed. * @param selectedMilliseconds * the current value of the date/time picker. * @returns * model containing an `active` `day` one month `up` from the specified moment in time. */ DlDayModelProvider.prototype.pageUp = function (fromMilliseconds, selectedMilliseconds) { return this.getModel(moment(fromMilliseconds).subtract(1, 'month').valueOf(), selectedMilliseconds); }; /** * Move the `active` `day` to the last day of the month. * * The view or time range will not change unless the `fromMilliseconds` value * is in a different day than the displayed decade. * * @param fromMilliseconds * the moment in time from which the last day of the month will be calculated. * @param selectedMilliseconds * the current value of the date/time picker. * @returns * a model with the last cell in the view as the active `day`. */ DlDayModelProvider.prototype.goEnd = function (fromMilliseconds, selectedMilliseconds) { return this.getModel(moment(fromMilliseconds) .endOf('month').startOf('day').valueOf(), selectedMilliseconds); }; /** * Move the `active` `day` to the first day of the month. * * The view or time range will not change unless the `fromMilliseconds` value * is in a different day than the displayed decade. * * @param fromMilliseconds * the moment in time from which the first day of the month will be calculated. * @param selectedMilliseconds * the current value of the date/time picker. * @returns * a model with the first cell in the view as the active `day`. */ DlDayModelProvider.prototype.goHome = function (fromMilliseconds, selectedMilliseconds) { return this.getModel(moment(fromMilliseconds).startOf('month').valueOf(), selectedMilliseconds); }; return DlDayModelProvider; }()); export { DlDayModelProvider }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dl-model-provider-day.js","sourceRoot":"ng://angular-bootstrap-datetimepicker/","sources":["dl-date-time-picker/dl-model-provider-day.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAGH,OAAO,KAAK,OAAO,MAAM,QAAQ,CAAC;AAIlC;;;;;;;;;;;;IAYI;AACJ,IAAM,MAAM,GAAG,OAAO,CAAC;AAEvB;;GAEG;AACH;IAAA;IA0OA,CAAC;IAxOC;;;;;OAKG;IACH,sCAAS,GAAT;IACE,aAAa;IACb,OAAsB,IACf,CAAC;IAEV;;;;;;;;;;;;;;;;;OAiBG;IACH,qCAAQ,GAAR,UAAS,YAAoB,EAAE,oBAA4B;QAEzD,IAAM,YAAY,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAC3D,IAAM,UAAU,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACvD,IAAM,WAAW,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC;QAE5F,IAAM,UAAU,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACtC,IAAM,aAAa,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAE5C,IAAM,aAAa,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QAChE,IAAM,SAAS,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QACvD,IAAM,WAAW,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC;QAClE,IAAM,aAAa,GAAG,oBAAoB,KAAK,IAAI,IAAI,oBAAoB,KAAK,SAAS;YACvF,CAAC,CAAC,oBAAoB;YACtB,CAAC,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC;QAE1D,OAAO;YACL,QAAQ,EAAE,KAAK;YACf,SAAS,EAAE,YAAY,CAAC,MAAM,CAAC,UAAU,CAAC;YAC1C,UAAU,EAAE,WAAW;YACvB,UAAU,EAAE;gBACV,KAAK,EAAE,aAAa,CAAC,OAAO,EAAE;gBAC9B,SAAS,EAAE,WAAS,aAAa,CAAC,MAAM,CAAC,UAAU,CAAG;gBACtD,OAAO,EAAE,EAAE;aACZ;YACD,QAAQ,EAAE;gBACR,KAAK,EAAE,YAAY,CAAC,OAAO,EAAE;gBAC7B,SAAS,EAAE,kBAAkB;gBAC7B,OAAO,EAAE,EAAE;aACZ;YACD,WAAW,EAAE;gBACX,KAAK,EAAE,SAAS,CAAC,OAAO,EAAE;gBAC1B,SAAS,EAAE,WAAS,SAAS,CAAC,MAAM,CAAC,UAAU,CAAG;gBAClD,OAAO,EAAE,EAAE;aACZ;YACD,SAAS,EAAE,aAAa,CAAC,GAAG,CAAC,UAAC,MAAM,IAAK,OAAA,MAAM,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAArC,CAAqC,CAAC;YAC/E,IAAI,EAAE,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC;SAChC,CAAC;QAEF,SAAS,SAAS,CAAC,SAAS;YAC1B,IAAM,aAAa,GAAG,MAAM,EAAE,CAAC;YAC/B,IAAM,KAAK,GAAG,aAAa,CAAC,GAAG,CAAC,UAAC,YAAY;gBAC3C,IAAM,SAAS,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC,GAAG,CAAC,CAAC,SAAS,GAAG,aAAa,CAAC,MAAM,CAAC,GAAG,YAAY,EAAE,MAAM,CAAC,CAAC;gBACrG,OAAO;oBACL,OAAO,EAAE,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC;oBAC9B,SAAS,EAAE,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC;oBACjC,KAAK,EAAE,SAAS,CAAC,OAAO,EAAE;oBAC1B,OAAO,EAAE;wBACP,iBAAiB,EAAE,WAAW,KAAK,SAAS,CAAC,OAAO,EAAE;wBACtD,iBAAiB,EAAE,SAAS,CAAC,OAAO,CAAC,UAAU,CAAC;wBAChD,eAAe,EAAE,SAAS,CAAC,QAAQ,CAAC,YAAY,CAAC;wBACjD,mBAAmB,EAAE,aAAa,KAAK,SAAS,CAAC,OAAO,EAAE;wBAC1D,cAAc,EAAE,SAAS,CAAC,MAAM,CAAC,aAAa,EAAE,KAAK,CAAC;qBACvD;iBACF,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,OAAO,EAAC,KAAK,OAAA,EAAC,CAAC;QACjB,CAAC;IACH,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,mCAAM,GAAN,UAAO,gBAAwB,EAAE,oBAA4B;QAC3D,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,oBAAoB,CAAC,CAAC;IAChG,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,iCAAI,GAAJ,UAAK,gBAAwB,EAAE,oBAA4B;QACzD,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,oBAAoB,CAAC,CAAC;IACrG,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,mCAAM,GAAN,UAAO,gBAAwB,EAAE,oBAA4B;QAC3D,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,OAAO,EAAE,EAAE,oBAAoB,CAAC,CAAC;IACpG,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,oCAAO,GAAP,UAAQ,gBAAwB,EAAE,oBAA4B;QAC5D,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,OAAO,EAAE,EAAE,oBAAoB,CAAC,CAAC;IAC/F,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,qCAAQ,GAAR,UAAS,gBAAwB,EAAE,oBAA4B;QAC7D,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,oBAAoB,CAAC,CAAC;IACjG,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,mCAAM,GAAN,UAAO,gBAAwB,EAAE,oBAA4B;QAC3D,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,oBAAoB,CAAC,CAAC;IACtG,CAAC;IAGD;;;;;;;;;;;;OAYG;IACH,kCAAK,GAAL,UAAM,gBAAwB,EAAE,oBAA4B;QAC1D,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC;aAC1C,KAAK,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,EAAE,oBAAoB,CAAC,CAAC;IACpE,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,mCAAM,GAAN,UAAO,gBAAwB,EAAE,oBAA4B;QAC3D,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,oBAAoB,CAAC,CAAC;IAClG,CAAC;IACH,yBAAC;AAAD,CAAC,AA1OD,IA0OC","sourcesContent":["/**\n * @license\n * Copyright 2013-present Dale Lotts All Rights Reserved.\n * http://www.dalelotts.com\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/dalelotts/angular-bootstrap-datetimepicker/blob/master/LICENSE\n */\n\nimport {SimpleChanges} from '@angular/core';\nimport * as _moment from 'moment';\nimport {DlDateTimePickerModel} from './dl-date-time-picker-model';\nimport {DlModelProvider} from './dl-model-provider';\n\n/**\n * Work around for moment namespace conflict when used with webpack and rollup.\n * See https://github.com/dherges/ng-packagr/issues/163\n *\n * Depending on whether rollup is used, moment needs to be imported differently.\n * Since Moment.js doesn't have a default export, we normally need to import using\n * the `* as`syntax.\n *\n * rollup creates a synthetic default module and we thus need to import it using\n * the `default as` syntax.\n *\n * @internal\n **/\nconst moment = _moment;\n\n/**\n * Default implementation for the `day` view.\n */\nexport class DlDayModelProvider implements DlModelProvider {\n\n  /**\n   * Receives input changes detected by Angular.\n   *\n   * @param changes\n   *  the input changes detected by Angular.\n   */\n  onChanges(\n    // @ts-ignore\n    changes: SimpleChanges\n  ): void {}\n\n  /**\n   * Returns the `day` model for the specified moment in `local` time with the\n   * `active` day set to the first day of the month.\n   *\n   * The `day` model represents a month (42 days) as six rows with seven columns\n   * and each cell representing one-day increments.\n   *\n   * The `day` always starts at midnight.\n   *\n   * Each cell represents a one-day increment at midnight.\n   *\n   * @param milliseconds\n   *  the moment in time from which the minute model will be created.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  the model representing the specified moment in time.\n   */\n  getModel(milliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n\n    const startOfMonth = moment(milliseconds).startOf('month');\n    const endOfMonth = moment(milliseconds).endOf('month');\n    const startOfView = moment(startOfMonth).subtract(Math.abs(startOfMonth.weekday()), 'days');\n\n    const rowNumbers = [0, 1, 2, 3, 4, 5];\n    const columnNumbers = [0, 1, 2, 3, 4, 5, 6];\n\n    const previousMonth = moment(startOfMonth).subtract(1, 'month');\n    const nextMonth = moment(startOfMonth).add(1, 'month');\n    const activeValue = moment(milliseconds).startOf('day').valueOf();\n    const selectedValue = selectedMilliseconds === null || selectedMilliseconds === undefined\n      ? selectedMilliseconds\n      : moment(selectedMilliseconds).startOf('day').valueOf();\n\n    return {\n      viewName: 'day',\n      viewLabel: startOfMonth.format('MMM YYYY'),\n      activeDate: activeValue,\n      leftButton: {\n        value: previousMonth.valueOf(),\n        ariaLabel: `Go to ${previousMonth.format('MMM YYYY')}`,\n        classes: {},\n      },\n      upButton: {\n        value: startOfMonth.valueOf(),\n        ariaLabel: `Go to month view`,\n        classes: {},\n      },\n      rightButton: {\n        value: nextMonth.valueOf(),\n        ariaLabel: `Go to ${nextMonth.format('MMM YYYY')}`,\n        classes: {},\n      },\n      rowLabels: columnNumbers.map((column) => moment().weekday(column).format('dd')),\n      rows: rowNumbers.map(rowOfDays)\n    };\n\n    function rowOfDays(rowNumber) {\n      const currentMoment = moment();\n      const cells = columnNumbers.map((columnNumber) => {\n        const dayMoment = moment(startOfView).add((rowNumber * columnNumbers.length) + columnNumber, 'days');\n        return {\n          display: dayMoment.format('D'),\n          ariaLabel: dayMoment.format('ll'),\n          value: dayMoment.valueOf(),\n          classes: {\n            'dl-abdtp-active': activeValue === dayMoment.valueOf(),\n            'dl-abdtp-future': dayMoment.isAfter(endOfMonth),\n            'dl-abdtp-past': dayMoment.isBefore(startOfMonth),\n            'dl-abdtp-selected': selectedValue === dayMoment.valueOf(),\n            'dl-abdtp-now': dayMoment.isSame(currentMoment, 'day'),\n          }\n        };\n      });\n      return {cells};\n    }\n  }\n\n  /**\n   * Move the active `day` one row `down` from the specified moment in time.\n   *\n   * Moving `down` can result in the `active` day being part of a different month than\n   * the specified `fromMilliseconds`, in this case the month represented by the model\n   * will change to show the correct hour.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the next `day` model `down` will be constructed.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  model containing an `active` `day` one row `down` from the specified moment in time.\n   */\n  goDown(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).add(7, 'days').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the active `day` one row `up` from the specified moment in time.\n   *\n   * Moving `up` can result in the `active` day being part of a different month than\n   * the specified `fromMilliseconds`, in this case the month represented by the model\n   * will change to show the correct hour.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the next `day` model `up` will be constructed.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  model containing an `active` `day` one row `up` from the specified moment in time.\n   */\n  goUp(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).subtract(7, 'days').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the `active` day one cell `left` in the current `day` view.\n   *\n   * Moving `left` can result in the `active` day being part of a different month than\n   * the specified `fromMilliseconds`, in this case the month represented by the model\n   * will change to show the correct year.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the `day` model to the `left` will be constructed.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  model containing an `active` `day` one cell to the `left` of the specified moment in time.\n   */\n  goLeft(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).subtract(1, 'day').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the `active` day one cell `right` in the current `day` view.\n   *\n   * Moving `right` can result in the `active` day being part of a different month than\n   * the specified `fromMilliseconds`, in this case the month represented by the model\n   * will change to show the correct year.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the `day` model to the `right` will be constructed.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  model containing an `active` `day` one cell to the `right` of the specified moment in time.\n   */\n  goRight(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).add(1, 'day').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the active `day` one month `down` from the specified moment in time.\n   *\n   * Paging `down` will result in the `active` day being part of a different month than\n   * the specified `fromMilliseconds`. As a result, the month represented by the model\n   * will change to show the correct year.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the next `day` model page `down` will be constructed.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  model containing an `active` `day` one month `down` from the specified moment in time.\n   */\n  pageDown(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).add(1, 'month').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the active `day` one month `up` from the specified moment in time.\n   *\n   * Paging `up` will result in the `active` day being part of a different month than\n   * the specified `fromMilliseconds`. As a result, the month represented by the model\n   * will change to show the correct year.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the next `day` model page `up` will be constructed.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  model containing an `active` `day` one month `up` from the specified moment in time.\n   */\n  pageUp(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).subtract(1, 'month').valueOf(), selectedMilliseconds);\n  }\n\n\n  /**\n   * Move the `active` `day` to the last day of the month.\n   *\n   * The view or time range will not change unless the `fromMilliseconds` value\n   * is in a different day than the displayed decade.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the last day of the month will be calculated.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  a model with the last cell in the view as the active `day`.\n   */\n  goEnd(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds)\n      .endOf('month').startOf('day').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the `active` `day` to the first day of the month.\n   *\n   * The view or time range will not change unless the `fromMilliseconds` value\n   * is in a different day than the displayed decade.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the first day of the month will be calculated.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  a model with the first cell in the view as the active `day`.\n   */\n  goHome(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).startOf('month').valueOf(), selectedMilliseconds);\n  }\n}\n"]}