@philipab/angular-bootstrap-datetimepicker
Version:
**Note**: This npm package is a fork of dalelotts/angular-bootstrap-datetimepicker, to provide an Ivy-compiled build of the current master branch. The fork was necessary because the official npm package did not release a new version with ivy support, yet.
229 lines • 30.1 kB
JavaScript
/**
* @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 moment from 'moment';
/**
* Default implementation for the `day` view.
*/
export class DlDayModelProvider {
/**
* Receives input changes detected by Angular.
*
* @param changes
* the input changes detected by Angular.
*/
onChanges(_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.
*/
getModel(milliseconds, selectedMilliseconds) {
const startOfMonth = moment(milliseconds).startOf('month');
const endOfMonth = moment(milliseconds).endOf('month');
const startOfView = moment(startOfMonth).subtract(Math.abs(startOfMonth.weekday()), 'days');
const rowNumbers = [0, 1, 2, 3, 4, 5];
const columnNumbers = [0, 1, 2, 3, 4, 5, 6];
const previousMonth = moment(startOfMonth).subtract(1, 'month');
const nextMonth = moment(startOfMonth).add(1, 'month');
const activeValue = moment(milliseconds).startOf('day').valueOf();
const 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((column) => moment().weekday(column).format('dd')),
rows: rowNumbers.map(rowOfDays)
};
function rowOfDays(rowNumber) {
const currentMoment = moment();
const cells = columnNumbers.map((columnNumber) => {
const 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 };
}
}
/**
* 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.
*/
goDown(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.
*/
goUp(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.
*/
goLeft(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.
*/
goRight(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.
*/
pageDown(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.
*/
pageUp(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`.
*/
goEnd(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`.
*/
goHome(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).startOf('month').valueOf(), selectedMilliseconds);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dl-model-provider-day.js","sourceRoot":"","sources":["../../../src/lib/dl-date-time-picker/dl-model-provider-day.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * @license\r\n * Copyright 2013-present Dale Lotts All Rights Reserved.\r\n * http://www.dalelotts.com\r\n *\r\n * Use of this source code is governed by an MIT-style license that can be\r\n * found in the LICENSE file at https://github.com/dalelotts/angular-bootstrap-datetimepicker/blob/master/LICENSE\r\n */\r\n\r\nimport {SimpleChanges} from '@angular/core';\r\nimport moment from 'moment';\r\nimport {DlDateTimePickerModel} from './dl-date-time-picker-model';\r\nimport {DlModelProvider} from './dl-model-provider';\r\n\r\n/**\r\n * Default implementation for the `day` view.\r\n */\r\nexport class DlDayModelProvider implements DlModelProvider {\r\n\r\n  /**\r\n   * Receives input changes detected by Angular.\r\n   *\r\n   * @param changes\r\n   *  the input changes detected by Angular.\r\n   */\r\n  onChanges(\r\n    _changes: SimpleChanges\r\n  ): void {}\r\n\r\n  /**\r\n   * Returns the `day` model for the specified moment in `local` time with the\r\n   * `active` day set to the first day of the month.\r\n   *\r\n   * The `day` model represents a month (42 days) as six rows with seven columns\r\n   * and each cell representing one-day increments.\r\n   *\r\n   * The `day` always starts at midnight.\r\n   *\r\n   * Each cell represents a one-day increment at midnight.\r\n   *\r\n   * @param milliseconds\r\n   *  the moment in time from which the minute model will be created.\r\n   * @param selectedMilliseconds\r\n   *  the current value of the date/time picker.\r\n   * @returns\r\n   *  the model representing the specified moment in time.\r\n   */\r\n  getModel(milliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n\r\n    const startOfMonth = moment(milliseconds).startOf('month');\r\n    const endOfMonth = moment(milliseconds).endOf('month');\r\n    const startOfView = moment(startOfMonth).subtract(Math.abs(startOfMonth.weekday()), 'days');\r\n\r\n    const rowNumbers = [0, 1, 2, 3, 4, 5];\r\n    const columnNumbers = [0, 1, 2, 3, 4, 5, 6];\r\n\r\n    const previousMonth = moment(startOfMonth).subtract(1, 'month');\r\n    const nextMonth = moment(startOfMonth).add(1, 'month');\r\n    const activeValue = moment(milliseconds).startOf('day').valueOf();\r\n    const selectedValue = selectedMilliseconds === null || selectedMilliseconds === undefined\r\n      ? selectedMilliseconds\r\n      : moment(selectedMilliseconds).startOf('day').valueOf();\r\n\r\n    return {\r\n      viewName: 'day',\r\n      viewLabel: startOfMonth.format('MMM YYYY'),\r\n      activeDate: activeValue,\r\n      leftButton: {\r\n        value: previousMonth.valueOf(),\r\n        ariaLabel: `Go to ${previousMonth.format('MMM YYYY')}`,\r\n        classes: {},\r\n      },\r\n      upButton: {\r\n        value: startOfMonth.valueOf(),\r\n        ariaLabel: `Go to month view`,\r\n        classes: {},\r\n      },\r\n      rightButton: {\r\n        value: nextMonth.valueOf(),\r\n        ariaLabel: `Go to ${nextMonth.format('MMM YYYY')}`,\r\n        classes: {},\r\n      },\r\n      rowLabels: columnNumbers.map((column) => moment().weekday(column).format('dd')),\r\n      rows: rowNumbers.map(rowOfDays)\r\n    };\r\n\r\n    function rowOfDays(rowNumber) {\r\n      const currentMoment = moment();\r\n      const cells = columnNumbers.map((columnNumber) => {\r\n        const dayMoment = moment(startOfView).add((rowNumber * columnNumbers.length) + columnNumber, 'days');\r\n        return {\r\n          display: dayMoment.format('D'),\r\n          ariaLabel: dayMoment.format('ll'),\r\n          value: dayMoment.valueOf(),\r\n          classes: {\r\n            'dl-abdtp-active': activeValue === dayMoment.valueOf(),\r\n            'dl-abdtp-future': dayMoment.isAfter(endOfMonth),\r\n            'dl-abdtp-past': dayMoment.isBefore(startOfMonth),\r\n            'dl-abdtp-selected': selectedValue === dayMoment.valueOf(),\r\n            'dl-abdtp-now': dayMoment.isSame(currentMoment, 'day'),\r\n          }\r\n        };\r\n      });\r\n      return {cells};\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Move the active `day` one row `down` from the specified moment in time.\r\n   *\r\n   * Moving `down` can result in the `active` day being part of a different month than\r\n   * the specified `fromMilliseconds`, in this case the month represented by the model\r\n   * will change to show the correct hour.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the next `day` model `down` will be constructed.\r\n   * @param selectedMilliseconds\r\n   *  the current value of the date/time picker.\r\n   * @returns\r\n   *  model containing an `active` `day` one row `down` from the specified moment in time.\r\n   */\r\n  goDown(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds).add(7, 'days').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the active `day` one row `up` from the specified moment in time.\r\n   *\r\n   * Moving `up` can result in the `active` day being part of a different month than\r\n   * the specified `fromMilliseconds`, in this case the month represented by the model\r\n   * will change to show the correct hour.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the next `day` model `up` will be constructed.\r\n   * @param selectedMilliseconds\r\n   *  the current value of the date/time picker.\r\n   * @returns\r\n   *  model containing an `active` `day` one row `up` from the specified moment in time.\r\n   */\r\n  goUp(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds).subtract(7, 'days').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the `active` day one cell `left` in the current `day` view.\r\n   *\r\n   * Moving `left` can result in the `active` day being part of a different month than\r\n   * the specified `fromMilliseconds`, in this case the month represented by the model\r\n   * will change to show the correct year.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the `day` model to the `left` will be constructed.\r\n   * @param selectedMilliseconds\r\n   *  the current value of the date/time picker.\r\n   * @returns\r\n   *  model containing an `active` `day` one cell to the `left` of the specified moment in time.\r\n   */\r\n  goLeft(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds).subtract(1, 'day').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the `active` day one cell `right` in the current `day` view.\r\n   *\r\n   * Moving `right` can result in the `active` day being part of a different month than\r\n   * the specified `fromMilliseconds`, in this case the month represented by the model\r\n   * will change to show the correct year.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the `day` model to the `right` will be constructed.\r\n   * @param selectedMilliseconds\r\n   *  the current value of the date/time picker.\r\n   * @returns\r\n   *  model containing an `active` `day` one cell to the `right` of the specified moment in time.\r\n   */\r\n  goRight(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds).add(1, 'day').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the active `day` one month `down` from the specified moment in time.\r\n   *\r\n   * Paging `down` will result in the `active` day being part of a different month than\r\n   * the specified `fromMilliseconds`. As a result, the month represented by the model\r\n   * will change to show the correct year.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the next `day` model page `down` will be constructed.\r\n   * @param selectedMilliseconds\r\n   *  the current value of the date/time picker.\r\n   * @returns\r\n   *  model containing an `active` `day` one month `down` from the specified moment in time.\r\n   */\r\n  pageDown(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds).add(1, 'month').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the active `day` one month `up` from the specified moment in time.\r\n   *\r\n   * Paging `up` will result in the `active` day being part of a different month than\r\n   * the specified `fromMilliseconds`. As a result, the month represented by the model\r\n   * will change to show the correct year.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the next `day` model page `up` will be constructed.\r\n   * @param selectedMilliseconds\r\n   *  the current value of the date/time picker.\r\n   * @returns\r\n   *  model containing an `active` `day` one month `up` from the specified moment in time.\r\n   */\r\n  pageUp(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds).subtract(1, 'month').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n\r\n  /**\r\n   * Move the `active` `day` to the last day of the month.\r\n   *\r\n   * The view or time range will not change unless the `fromMilliseconds` value\r\n   * is in a different day than the displayed decade.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the last day of the month will be calculated.\r\n   * @param selectedMilliseconds\r\n   *  the current value of the date/time picker.\r\n   * @returns\r\n   *  a model with the last cell in the view as the active `day`.\r\n   */\r\n  goEnd(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds)\r\n      .endOf('month').startOf('day').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the `active` `day` to the first day of the month.\r\n   *\r\n   * The view or time range will not change unless the `fromMilliseconds` value\r\n   * is in a different day than the displayed decade.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the first day of the month will be calculated.\r\n   * @param selectedMilliseconds\r\n   *  the current value of the date/time picker.\r\n   * @returns\r\n   *  a model with the first cell in the view as the active `day`.\r\n   */\r\n  goHome(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds).startOf('month').valueOf(), selectedMilliseconds);\r\n  }\r\n}\r\n"]}