UNPKG

angular-bootstrap-datetimepicker

Version:

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

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