angular-bootstrap-datetimepicker
Version:
Native Angular (8+) datetime picker component styled by Twitter Bootstrap 4.
242 lines • 29.3 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 * 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
**/
const moment = _moment;
/**
* Default implementation for the `hour` view.
*/
export class DlHourModelProvider {
/**
* Receives input changes detected by Angular.
*
* @param changes
* the input changes detected by Angular.
*/
onChanges(
// @ts-ignore
changes) { }
/**
* Returns the `hour` model for the specified moment in `local` time with the
* `active` hour set to the beginning of the day.
*
* The `hour` model represents a day (24 hours) as six rows with four columns
* and each cell representing one-hour increments.
*
* The hour always starts at the beginning of the hour.
*
* Each cell represents a one-hour increment starting 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 startDate = moment(milliseconds).startOf('day');
const rowNumbers = [0, 1, 2, 3, 4, 5];
const columnNumbers = [0, 1, 2, 3];
const previousDay = moment(startDate).subtract(1, 'day');
const nextDay = moment(startDate).add(1, 'day');
const activeValue = moment(milliseconds).startOf('hour').valueOf();
const selectedValue = selectedMilliseconds === null || selectedMilliseconds === undefined
? selectedMilliseconds
: moment(selectedMilliseconds).startOf('hour').valueOf();
return {
viewName: 'hour',
viewLabel: startDate.format('ll'),
activeDate: activeValue,
leftButton: {
value: previousDay.valueOf(),
ariaLabel: `Go to ${previousDay.format('ll')}`,
classes: {},
},
upButton: {
value: startDate.valueOf(),
ariaLabel: `Go to ${startDate.format('MMM YYYY')}`,
classes: {},
},
rightButton: {
value: nextDay.valueOf(),
ariaLabel: `Go to ${nextDay.format('ll')}`,
classes: {},
},
rows: rowNumbers.map(rowOfHours)
};
function rowOfHours(rowNumber) {
const currentMoment = moment();
const cells = columnNumbers.map((columnNumber) => {
const hourMoment = moment(startDate).add((rowNumber * columnNumbers.length) + columnNumber, 'hours');
return {
display: hourMoment.format('LT'),
ariaLabel: hourMoment.format('LLL'),
value: hourMoment.valueOf(),
classes: {
'dl-abdtp-active': activeValue === hourMoment.valueOf(),
'dl-abdtp-selected': selectedValue === hourMoment.valueOf(),
'dl-abdtp-now': hourMoment.isSame(currentMoment, 'hour'),
}
};
});
return { cells };
}
}
/**
* Move the active `hour` one row `down` from the specified moment in time.
*
* Moving `down` can result in the `active` hour being part of a different day than
* the specified `fromMilliseconds`, in this case the day represented by the model
* will change to show the correct hour.
*
* @param fromMilliseconds
* the moment in time from which the next `hour` model `down` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `hour` one row `down` from the specified moment in time.
*/
goDown(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).add(4, 'hour').valueOf(), selectedMilliseconds);
}
/**
* Move the active `hour` one row `up` from the specified moment in time.
*
* Moving `up` can result in the `active` hour being part of a different day than
* the specified `fromMilliseconds`, in this case the day represented by the model
* will change to show the correct hour.
*
* @param fromMilliseconds
* the moment in time from which the next `hour` model `up` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `hour` one row `up` from the specified moment in time.
*/
goUp(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).subtract(4, 'hour').valueOf(), selectedMilliseconds);
}
/**
* Move the `active` hour one cell `left` in the current `hour` view.
*
* Moving `left` can result in the `active` hour being part of a different day than
* the specified `fromMilliseconds`, in this case the day represented by the model
* will change to show the correct year.
*
* @param fromMilliseconds
* the moment in time from which the `hour` model to the `left` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `hour` one cell to the `left` of the specified moment in time.
*/
goLeft(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).subtract(1, 'hour').valueOf(), selectedMilliseconds);
}
/**
* Move the `active` hour one cell `right` in the current `hour` view.
*
* Moving `right` can result in the `active` hour being part of a different day than
* the specified `fromMilliseconds`, in this case the day represented by the model
* will change to show the correct year.
*
* @param fromMilliseconds
* the moment in time from which the `hour` model to the `right` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `hour` one cell to the `right` of the specified moment in time.
*/
goRight(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).add(1, 'hour').valueOf(), selectedMilliseconds);
}
/**
* Move the active `hour` one day `down` from the specified moment in time.
*
* Paging `down` will result in the `active` hour being part of a different day than
* the specified `fromMilliseconds`. As a result, the day represented by the model
* will change to show the correct year.
*
* @param fromMilliseconds
* the moment in time from which the next `hour` model page `down` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `hour` one day `down` from the specified moment in time.
*/
pageDown(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).add(1, 'day').valueOf(), selectedMilliseconds);
}
/**
* Move the active `hour` one day `up` from the specified moment in time.
*
* Paging `up` will result in the `active` hour being part of a different day than
* the specified `fromMilliseconds`. As a result, the day represented by the model
* will change to show the correct year.
*
* @param fromMilliseconds
* the moment in time from which the next `hour` model page `up` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `hour` one day `up` from the specified moment in time.
*/
pageUp(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).subtract(1, 'day').valueOf(), selectedMilliseconds);
}
/**
* Move the `active` `hour` to `11:00 pm` of the current day.
*
* 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 `11:00 pm` will be calculated.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* a model with the `11:00 pm` cell in the view as the active `hour`.
*/
goEnd(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds)
.endOf('day')
.startOf('hour')
.valueOf(), selectedMilliseconds);
}
/**
* Move the `active` `hour` to `midnight` of the current day.
*
* 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 `midnight` will be calculated.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* a model with the `midnight` cell in the view as the active `hour`.
*/
goHome(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).startOf('day').valueOf(), selectedMilliseconds);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dl-model-provider-hour.js","sourceRoot":"ng://angular-bootstrap-datetimepicker/","sources":["dl-date-time-picker/dl-model-provider-hour.ts"],"names":[],"mappings":"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","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 `hour` view.\n */\nexport class DlHourModelProvider 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  /**\n   * Returns the `hour` model for the specified moment in `local` time with the\n   * `active` hour set to the beginning of the day.\n   *\n   * The `hour` model represents a day (24 hours) as six rows with four columns\n   * and each cell representing one-hour increments.\n   *\n   * The hour always starts at the beginning of the hour.\n   *\n   * Each cell represents a one-hour increment starting 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    const startDate = moment(milliseconds).startOf('day');\n\n    const rowNumbers = [0, 1, 2, 3, 4, 5];\n    const columnNumbers = [0, 1, 2, 3];\n\n    const previousDay = moment(startDate).subtract(1, 'day');\n    const nextDay = moment(startDate).add(1, 'day');\n    const activeValue = moment(milliseconds).startOf('hour').valueOf();\n    const selectedValue = selectedMilliseconds === null || selectedMilliseconds === undefined\n      ? selectedMilliseconds\n      : moment(selectedMilliseconds).startOf('hour').valueOf();\n\n    return {\n      viewName: 'hour',\n      viewLabel: startDate.format('ll'),\n      activeDate: activeValue,\n      leftButton: {\n        value: previousDay.valueOf(),\n        ariaLabel: `Go to ${previousDay.format('ll')}`,\n        classes: {},\n      },\n      upButton: {\n        value: startDate.valueOf(),\n        ariaLabel: `Go to ${startDate.format('MMM YYYY')}`,\n        classes: {},\n      },\n      rightButton: {\n        value: nextDay.valueOf(),\n        ariaLabel: `Go to ${nextDay.format('ll')}`,\n        classes: {},\n      },\n      rows: rowNumbers.map(rowOfHours)\n    };\n\n    function rowOfHours(rowNumber) {\n\n      const currentMoment = moment();\n      const cells = columnNumbers.map((columnNumber) => {\n        const hourMoment = moment(startDate).add((rowNumber * columnNumbers.length) + columnNumber, 'hours');\n        return {\n          display: hourMoment.format('LT'),\n          ariaLabel: hourMoment.format('LLL'),\n          value: hourMoment.valueOf(),\n          classes: {\n            'dl-abdtp-active': activeValue === hourMoment.valueOf(),\n            'dl-abdtp-selected': selectedValue === hourMoment.valueOf(),\n            'dl-abdtp-now': hourMoment.isSame(currentMoment, 'hour'),\n          }\n        };\n      });\n      return {cells};\n    }\n  }\n\n  /**\n   * Move the active `hour` one row `down` from the specified moment in time.\n   *\n   * Moving `down` can result in the `active` hour being part of a different day than\n   * the specified `fromMilliseconds`, in this case the day 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 `hour` model `down` will be constructed.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  model containing an `active` `hour` one row `down` from the specified moment in time.\n   */\n  goDown(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).add(4, 'hour').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the active `hour` one row `up` from the specified moment in time.\n   *\n   * Moving `up` can result in the `active` hour being part of a different day than\n   * the specified `fromMilliseconds`, in this case the day 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 `hour` model `up` will be constructed.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  model containing an `active` `hour` one row `up` from the specified moment in time.\n   */\n  goUp(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).subtract(4, 'hour').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the `active` hour one cell `left` in the current `hour` view.\n   *\n   * Moving `left` can result in the `active` hour being part of a different day than\n   * the specified `fromMilliseconds`, in this case the day represented by the model\n   * will change to show the correct year.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the `hour` 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` `hour` 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, 'hour').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the `active` hour one cell `right` in the current `hour` view.\n   *\n   * Moving `right` can result in the `active` hour being part of a different day than\n   * the specified `fromMilliseconds`, in this case the day represented by the model\n   * will change to show the correct year.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the `hour` 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` `hour` 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, 'hour').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the active `hour` one day `down` from the specified moment in time.\n   *\n   * Paging `down` will result in the `active` hour being part of a different day than\n   * the specified `fromMilliseconds`. As a result, the day 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 `hour` 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` `hour` one day `down` from the specified moment in time.\n   */\n  pageDown(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).add(1, 'day').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the active `hour` one day `up` from the specified moment in time.\n   *\n   * Paging `up` will result in the `active` hour being part of a different day than\n   * the specified `fromMilliseconds`. As a result, the day 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 `hour` 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` `hour` one day `up` from the specified moment in time.\n   */\n  pageUp(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).subtract(1, 'day').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the `active` `hour` to `11:00 pm` of the current day.\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 `11:00 pm` will be calculated.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  a model with the `11:00 pm` cell in the view as the active `hour`.\n   */\n  goEnd(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment\n    (fromMilliseconds)\n      .endOf('day')\n      .startOf('hour')\n      .valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the `active` `hour` to `midnight` of the current day.\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 `midnight` will be calculated.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  a model with the `midnight` cell in the view as the active `hour`.\n   */\n  goHome(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).startOf('day').valueOf(), selectedMilliseconds);\n  }\n}\n"]}