@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.
254 lines • 34.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 `minute` view.
*/
export class DlMinuteModelProvider {
constructor() {
this.step = 5;
}
/**
* Receives `minuteStep` configuration changes detected by Angular.
*
* Changes where the value has not changed are ignored.
*
* Setting `minuteStep` to `null` or `undefined` will result in a
* minuteStep of `5`.
*
* @param changes
* the input changes detected by Angular.
*/
onChanges(changes) {
const minuteStepChange = changes['minuteStep'];
if (minuteStepChange
&& (minuteStepChange.previousValue !== minuteStepChange.currentValue)) {
this.step = minuteStepChange.currentValue;
if (this.step === null || this.step === undefined) {
this.step = 5;
}
}
}
/**
* Returns the `minute` model for the specified moment in `local` time with the
* `active` minute set to the beginning of the hour.
*
* The `minute` model represents an hour (60 minutes) as three rows with four columns
* and each cell representing 5-minute increments.
*
* The hour always starts at midnight.
*
* Each cell represents a 5-minute increment starting at midnight.
*
* The `active` minute will be the 5-minute increments less than or equal to the specified milliseconds.
*
* @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('hour');
const currentMilliseconds = moment().valueOf();
const minuteSteps = new Array(Math.ceil(60 / this.step)).fill(0).map((zero, index) => zero + index * this.step);
const minuteValues = minuteSteps.map((minutesToAdd) => moment(startDate).add(minutesToAdd, 'minutes').valueOf());
const activeValue = moment(minuteValues.filter((value) => value <= milliseconds).pop()).valueOf();
const nowValue = currentMilliseconds >= startDate.valueOf() && currentMilliseconds <= moment(startDate).endOf('hour').valueOf()
? moment(minuteValues.filter((value) => value <= currentMilliseconds).pop()).valueOf()
: null;
const previousHour = moment(startDate).subtract(1, 'hour');
const nextHour = moment(startDate).add(1, 'hour');
const selectedValue = selectedMilliseconds === null || selectedMilliseconds === undefined
? selectedMilliseconds
: moment(minuteValues.filter((value) => value <= selectedMilliseconds).pop()).valueOf();
const rows = new Array(Math.ceil(minuteSteps.length / 4))
.fill(0)
.map((zero, index) => zero + index)
.map((value) => {
return { cells: minuteSteps.slice((value * 4), (value * 4) + 4).map(rowOfMinutes) };
});
return {
viewName: 'minute',
viewLabel: startDate.format('lll'),
activeDate: activeValue,
leftButton: {
value: previousHour.valueOf(),
ariaLabel: `Go to ${previousHour.format('lll')}`,
classes: {},
},
upButton: {
value: startDate.valueOf(),
ariaLabel: `Go to ${startDate.format('ll')}`,
classes: {},
},
rightButton: {
value: nextHour.valueOf(),
ariaLabel: `Go to ${nextHour.format('lll')}`,
classes: {},
},
rows
};
function rowOfMinutes(stepMinutes) {
const minuteMoment = moment(startDate).add(stepMinutes, 'minutes');
return {
display: minuteMoment.format('LT'),
ariaLabel: minuteMoment.format('LLL'),
value: minuteMoment.valueOf(),
classes: {
'dl-abdtp-active': activeValue === minuteMoment.valueOf(),
'dl-abdtp-selected': selectedValue === minuteMoment.valueOf(),
'dl-abdtp-now': nowValue === minuteMoment.valueOf(),
}
};
}
}
/**
* Move the active `minute` one row `down` from the specified moment in time.
*
* Moving `down` can result in the `active` minute being part of a different hour than
* the specified `fromMilliseconds`, in this case the hour represented by the model
* will change to show the correct hour.
*
* @param fromMilliseconds
* the moment in time from which the next `minute` model `down` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `minute` one row `down` from the specified moment in time.
*/
goDown(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).add(this.step * 4, 'minutes').valueOf(), selectedMilliseconds);
}
/**
* Move the active `minute` one row `down` from the specified moment in time.
*
* Moving `down` can result in the `active` minute being part of a different hour than
* the specified `fromMilliseconds`, in this case the hour represented by the model
* will change to show the correct hour.
*
* @param fromMilliseconds
* the moment in time from which the next `minute` model `down` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `minute` one row `down` from the specified moment in time.
*/
goUp(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).subtract(this.step * 4, 'minutes').valueOf(), selectedMilliseconds);
}
/**
* Move the `active` date one cell to `left` in the current `minute` view.
*
* Moving `left` can result in the `active` hour being part of a different hour than
* the specified `fromMilliseconds`, in this case the hour represented by the model
* will change to show the correct hour.
*
* @param fromMilliseconds
* the moment in time from which the `minute` model to the `left` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `minute` one cell to the `left` of the specified moment in time.
*/
goLeft(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).subtract(this.step, 'minutes').valueOf(), selectedMilliseconds);
}
/**
* Move `active` minute one cell to `right` in the current `minute` view.
*
* Moving `right` can result in the `active` hour being part of a different hour than
* the specified `fromMilliseconds`, in this case the hour represented by the model
* will change to show the correct hour.
*
* @param fromMilliseconds
* the moment in time from which the `minute` model to the `right` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `minute` one cell to the `right` of the specified moment in time.
*/
goRight(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).add(this.step, 'minutes').valueOf(), selectedMilliseconds);
}
/**
* Move the active `minute` one hour `down` from the specified moment in time.
*
* The `active` minute will be `one (1) hour after` the specified milliseconds.
* This moves the `active` date one `page` `down` from the current `minute` view.
*
* The next cell `page-down` will be in a different hour than the currently
* displayed view and the model time range will include the new active cell.
*
* @param fromMilliseconds
* the moment in time from which the next `month` model page `down` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `month` one year `down` from the specified moment in time.
*/
pageDown(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).add(1, 'hour').valueOf(), selectedMilliseconds);
}
/**
* Move the active `minute` one hour `up` from the specified moment in time.
*
* The `active` minute will be `one (1) hour before` the specified milliseconds.
* This moves the `active` date one `page` `down` from the current `minute` view.
*
* The next cell `page-up` will be in a different hour than the currently
* displayed view and the model time range will include the new active cell.
*
* @param fromMilliseconds
* the moment in time from which the next `month` model page `down` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `month` one year `down` from the specified moment in time.
*/
pageUp(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).subtract(1, 'hour').valueOf(), selectedMilliseconds);
}
/**
* Move the `active` `minute` to the last cell of the current hour.
*
* The view or time range will not change unless the `fromMilliseconds` value
* is in a different hour than the displayed decade.
*
* @param fromMilliseconds
* the moment in time from which the last cell 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 `minute`.
*/
goEnd(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds)
.endOf('hour')
.valueOf(), selectedMilliseconds);
}
/**
* Move the `active` `minute` to the first cell of the current hour.
*
* The view or time range will not change unless the `fromMilliseconds` value
* is in a different hour than the displayed decade.
*
* @param fromMilliseconds
* the moment in time from which the first cell 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 `minute`.
*/
goHome(fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).startOf('hour').valueOf(), selectedMilliseconds);
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dl-model-provider-minute.js","sourceRoot":"","sources":["../../../src/lib/dl-date-time-picker/dl-model-provider-minute.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 `minute` view.\r\n */\r\nexport class DlMinuteModelProvider implements DlModelProvider {\r\n\r\n  private step = 5;\r\n\r\n  /**\r\n   * Receives `minuteStep` configuration changes detected by Angular.\r\n   *\r\n   * Changes where the value has not changed are ignored.\r\n   *\r\n   * Setting `minuteStep` to `null` or `undefined` will result in a\r\n   * minuteStep of `5`.\r\n   *\r\n   * @param changes\r\n   *  the input changes detected by Angular.\r\n   */\r\n\r\n  onChanges(changes: SimpleChanges): void {\r\n\r\n    const minuteStepChange = changes['minuteStep'];\r\n\r\n    if (minuteStepChange\r\n      && (minuteStepChange.previousValue !== minuteStepChange.currentValue)\r\n    ) {\r\n      this.step = minuteStepChange.currentValue;\r\n      if (this.step === null || this.step === undefined) {\r\n        this.step = 5;\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Returns the `minute` model for the specified moment in `local` time with the\r\n   * `active` minute set to the beginning of the hour.\r\n   *\r\n   * The `minute` model represents an hour (60 minutes) as three rows with four columns\r\n   * and each cell representing 5-minute increments.\r\n   *\r\n   * The hour always starts at midnight.\r\n   *\r\n   * Each cell represents a 5-minute increment starting at midnight.\r\n   *\r\n   * The `active` minute will be the 5-minute increments less than or equal to the specified milliseconds.\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    const startDate = moment(milliseconds).startOf('hour');\r\n    const currentMilliseconds = moment().valueOf();\r\n\r\n    const minuteSteps = new Array(Math.ceil(60 / this.step)).fill(0).map((zero, index) => zero + index * this.step);\r\n    const minuteValues = minuteSteps.map((minutesToAdd) => moment(startDate).add(minutesToAdd, 'minutes').valueOf());\r\n    const activeValue = moment(minuteValues.filter((value) => value <= milliseconds).pop()).valueOf();\r\n\r\n    const nowValue = currentMilliseconds >= startDate.valueOf() && currentMilliseconds <= moment(startDate).endOf('hour').valueOf()\r\n      ? moment(minuteValues.filter((value) => value <= currentMilliseconds).pop()).valueOf()\r\n      : null;\r\n\r\n\r\n    const previousHour = moment(startDate).subtract(1, 'hour');\r\n    const nextHour = moment(startDate).add(1, 'hour');\r\n    const selectedValue = selectedMilliseconds === null || selectedMilliseconds === undefined\r\n      ? selectedMilliseconds\r\n      : moment(minuteValues.filter((value) => value <= selectedMilliseconds).pop()).valueOf();\r\n\r\n    const rows = new Array(Math.ceil(minuteSteps.length / 4))\r\n      .fill(0)\r\n      .map((zero, index) => zero + index)\r\n      .map((value) => {\r\n        return {cells: minuteSteps.slice((value * 4), (value * 4) + 4).map(rowOfMinutes)};\r\n      });\r\n\r\n    return {\r\n      viewName: 'minute',\r\n      viewLabel: startDate.format('lll'),\r\n      activeDate: activeValue,\r\n      leftButton: {\r\n        value: previousHour.valueOf(),\r\n        ariaLabel: `Go to ${previousHour.format('lll')}`,\r\n        classes: {},\r\n      },\r\n      upButton: {\r\n        value: startDate.valueOf(),\r\n        ariaLabel: `Go to ${startDate.format('ll')}`,\r\n        classes: {},\r\n      },\r\n      rightButton: {\r\n        value: nextHour.valueOf(),\r\n        ariaLabel: `Go to ${nextHour.format('lll')}`,\r\n        classes: {},\r\n      },\r\n      rows\r\n    };\r\n\r\n    function rowOfMinutes(stepMinutes): {\r\n      display: string;\r\n      ariaLabel: string;\r\n      value: number;\r\n      classes: {};\r\n    } {\r\n      const minuteMoment = moment(startDate).add(stepMinutes, 'minutes');\r\n      return {\r\n        display: minuteMoment.format('LT'),\r\n        ariaLabel: minuteMoment.format('LLL'),\r\n        value: minuteMoment.valueOf(),\r\n        classes: {\r\n          'dl-abdtp-active': activeValue === minuteMoment.valueOf(),\r\n          'dl-abdtp-selected': selectedValue === minuteMoment.valueOf(),\r\n          'dl-abdtp-now': nowValue === minuteMoment.valueOf(),\r\n        }\r\n      };\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Move the active `minute` one row `down` from the specified moment in time.\r\n   *\r\n   * Moving `down` can result in the `active` minute being part of a different hour than\r\n   * the specified `fromMilliseconds`, in this case the hour 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 `minute` 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` `minute` 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(this.step * 4, 'minutes').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the active `minute` one row `down` from the specified moment in time.\r\n   *\r\n   * Moving `down` can result in the `active` minute being part of a different hour than\r\n   * the specified `fromMilliseconds`, in this case the hour 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 `minute` 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` `minute` one row `down` from the specified moment in time.\r\n   */\r\n  goUp(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds).subtract(this.step * 4, 'minutes').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the `active` date one cell to `left` in the current `minute` view.\r\n   *\r\n   * Moving `left` can result in the `active` hour being part of a different hour than\r\n   * the specified `fromMilliseconds`, in this case the hour 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 `minute` 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` `minute` 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(this.step, 'minutes').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move `active` minute one cell to `right` in the current `minute` view.\r\n   *\r\n   * Moving `right` can result in the `active` hour being part of a different hour than\r\n   * the specified `fromMilliseconds`, in this case the hour 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 `minute` 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` `minute` 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(this.step, 'minutes').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the active `minute` one hour `down` from the specified moment in time.\r\n   *\r\n   * The `active` minute will be `one (1) hour after` the specified milliseconds.\r\n   * This moves the `active` date one `page` `down` from the current `minute` view.\r\n   *\r\n   * The next cell `page-down` will be in a different hour than the currently\r\n   * displayed view and the model time range will include the new active cell.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the next `month` 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` `month` one year `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, 'hour').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the active `minute` one hour `up` from the specified moment in time.\r\n   *\r\n   * The `active` minute will be `one (1) hour before` the specified milliseconds.\r\n   * This moves the `active` date one `page` `down` from the current `minute` view.\r\n   *\r\n   * The next cell `page-up` will be in a different hour than the currently\r\n   * displayed view and the model time range will include the new active cell.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the next `month` 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` `month` one year `down` 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, 'hour').valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the `active` `minute` to the last cell of the current hour.\r\n   *\r\n   * The view or time range will not change unless the `fromMilliseconds` value\r\n   * is in a different hour than the displayed decade.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the last cell 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 `minute`.\r\n   */\r\n  goEnd(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds)\r\n      .endOf('hour')\r\n      .valueOf(), selectedMilliseconds);\r\n  }\r\n\r\n  /**\r\n   * Move the `active` `minute` to the first cell of the current hour.\r\n   *\r\n   * The view or time range will not change unless the `fromMilliseconds` value\r\n   * is in a different hour than the displayed decade.\r\n   *\r\n   * @param fromMilliseconds\r\n   *  the moment in time from which the first cell 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 `minute`.\r\n   */\r\n  goHome(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\r\n    return this.getModel(moment(fromMilliseconds).startOf('hour').valueOf(), selectedMilliseconds);\r\n  }\r\n}\r\n"]}