angular-bootstrap-datetimepicker
Version:
Native Angular (8+) datetime picker component styled by Twitter Bootstrap 4.
277 lines • 34.9 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
**/
var moment = _moment;
/**
* Default implementation for the `year` view.
*/
var DlYearModelProvider = /** @class */ (function () {
function DlYearModelProvider() {
}
/**
* Create a moment at midnight january 1 at the start of the current decade.
* The start of the decade is always a year ending in zero.
*
* @param fromMilliseconds
* the moment in time from which the start of the decade will be determined.
* @returns
* moment at midnight january 1 at the start of the current decade.
* @internal
*/
DlYearModelProvider.getStartOfDecade = function (fromMilliseconds) {
// Truncate the last digit from the current year to get the start of the decade
var startDecade = (Math.trunc(moment(fromMilliseconds).year() / 10) * 10);
return moment({ year: startDecade }).startOf('year');
};
/**
* Receives input changes detected by Angular.
*
* @param changes
* the input changes detected by Angular.
*/
DlYearModelProvider.prototype.onChanges = function (
// @ts-ignore
changes) { };
/**
* Returns the `year` model for the specified moment in `local` time with the
* `active` year set to January 1 of the specified year.
*
* The `year` model represents a decade (10 years) as two rows with five columns.
*
* The decade always starts on a year ending with zero.
*
* Each cell represents midnight January 1 of the indicated year.
*
* The `active` year will be the January 1 of year of the specified milliseconds.
*
* @param milliseconds
* the moment in time from which the year model will be created.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* the model representing the specified moment in time.
*/
DlYearModelProvider.prototype.getModel = function (milliseconds, selectedMilliseconds) {
var rowNumbers = [0, 1];
var columnNumbers = [0, 1, 2, 3, 4];
var startYear = moment(milliseconds).startOf('year');
var startDate = DlYearModelProvider.getStartOfDecade(milliseconds);
var futureYear = startDate.year() + 9;
var pastYear = startDate.year();
var activeValue = startYear.valueOf();
var selectedValue = selectedMilliseconds === null || selectedMilliseconds === undefined
? selectedMilliseconds
: moment(selectedMilliseconds).startOf('year').valueOf();
return {
viewName: 'year',
viewLabel: pastYear + "-" + futureYear,
activeDate: activeValue,
leftButton: {
value: moment(startDate).subtract(10, 'years').valueOf(),
ariaLabel: "Go to " + (pastYear - 10) + "-" + (pastYear - 1),
classes: {},
},
rightButton: {
value: moment(startDate).add(10, 'years').valueOf(),
ariaLabel: "Go to " + (futureYear + 1) + "-" + (futureYear + 10),
classes: {},
},
rows: rowNumbers.map(rowOfYears.bind(this))
};
function rowOfYears(rowNumber) {
var currentMoment = moment();
var cells = columnNumbers.map(function (columnNumber) {
var yearMoment = moment(startDate).add((rowNumber * columnNumbers.length) + columnNumber, 'years');
return {
display: yearMoment.format('YYYY'),
value: yearMoment.valueOf(),
classes: {
'dl-abdtp-active': activeValue === yearMoment.valueOf(),
'dl-abdtp-selected': selectedValue === yearMoment.valueOf(),
'dl-abdtp-now': yearMoment.isSame(currentMoment, 'year'),
}
};
});
return { cells: cells };
}
};
/**
* Move the active `year` one row `down` from the specified moment in time.
*
* The `active` year will be the January 1 `five (5) years after` the specified milliseconds.
* This moves the `active` date one row `down` in the current `year` view.
*
* Moving `down` can result in the `active` year being part of a different decade than
* the specified `fromMilliseconds`, in this case the decade represented by the model
* will change to show the correct decade.
*
* @param fromMilliseconds
* the moment in time from which the next `year` model `down` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `year` one row `down` from the specified moment in time.
*/
DlYearModelProvider.prototype.goDown = function (fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).add(5, 'year').valueOf(), selectedMilliseconds);
};
/**
* Move the active `year` one row `up` from the specified moment in time.
*
* The `active` year will be the January 1 `five (5) years before` the specified milliseconds.
* This moves the `active` date one row `up` in the current `year` view.
*
* Moving `up` can result in the `active` year being part of a different decade than
* the specified `fromMilliseconds`, in this case the decade represented by the model
* will change to show the correct decade.
*
* @param fromMilliseconds
* the moment in time from which the previous `year` model `up` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `year` one row `up` from the specified moment in time.
*/
DlYearModelProvider.prototype.goUp = function (fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).subtract(5, 'year').valueOf(), selectedMilliseconds);
};
/**
* Move the `active` `year` one (1) year to the `left` of the specified moment in time.
*
* The `active` year will be the January 1 `one (1) year before` the specified milliseconds.
* This moves the `active` date one year `left` in the current `year` view.
*
* Moving `left` can result in the `active` year being part of a different decade than
* the specified `fromMilliseconds`, in this case the decade represented by the model
* will change to show the correct decade.
*
* @param fromMilliseconds
* the moment in time from which the `year` model to the `left` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `year` one year to the `left` of the specified moment in time.
*/
DlYearModelProvider.prototype.goLeft = function (fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).subtract(1, 'year').valueOf(), selectedMilliseconds);
};
/**
* Move the `active` `year` one (1) year to the `right` of the specified moment in time.
*
* The `active` year will be the January 1 `one (1) year after` the specified milliseconds.
* This moves the `active` date one year `right` in the current `year` view.
*
* Moving `right` can result in the `active` year being part of a different decade than
* the specified `fromMilliseconds`, in this case the decade represented by the model
* will change to show the correct decade.
*
* @param fromMilliseconds
* the moment in time from which the `year` model to the `right` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `year` one year to the `right` of the specified moment in time.
*/
DlYearModelProvider.prototype.goRight = function (fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).add(1, 'year').valueOf(), selectedMilliseconds);
};
/**
* Move the active `year` one decade `down` from the specified moment in time.
*
* The `active` year will be the January 1 `ten (10) years after` the specified milliseconds.
* This moves the `active` date one `page` `down` from the current `year` view.
*
* Paging `down` will result in the `active` year being part of a different decade than
* the specified `fromMilliseconds`. As a result, the decade represented by the model
* will change to show the correct decade.
*
* @param fromMilliseconds
* the moment in time from which the next `year` model page `down` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `year` one decade `down` from the specified moment in time.
*/
DlYearModelProvider.prototype.pageDown = function (fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).add(10, 'year').valueOf(), selectedMilliseconds);
};
/**
* Move the active `year` one decade `up` from the specified moment in time.
*
* The `active` year will be the January 1 `ten (10) years before` the specified milliseconds.
* This moves the `active` date one `page-up` from the current `year` view.
*
* Paging `up` will result in the `active` year being part of a different decade than
* the specified `fromMilliseconds`. As a result, the decade represented by the model
* will change to show the correct decade.
*
* @param fromMilliseconds
* the moment in time from which the next `year` model page `up` will be constructed.
* @param selectedMilliseconds
* the current value of the date/time picker.
* @returns
* model containing an `active` `year` one decade `up` from the specified moment in time.
*/
DlYearModelProvider.prototype.pageUp = function (fromMilliseconds, selectedMilliseconds) {
return this.getModel(moment(fromMilliseconds).subtract(10, 'year').valueOf(), selectedMilliseconds);
};
/**
* Move the `active` `year` to the `last` year in the decade.
*
* The view or time range will not change unless the `fromMilliseconds` value
* is in a different decade than the displayed decade.
*
* @param fromMilliseconds
* the moment in time from which the `last` active `year` 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 `year`.
*/
DlYearModelProvider.prototype.goEnd = function (fromMilliseconds, selectedMilliseconds) {
return this.getModel(DlYearModelProvider.getStartOfDecade(fromMilliseconds)
.add(9, 'years')
.endOf('year')
.valueOf(), selectedMilliseconds);
};
/**
* Move the `active` `year` to the `first` year in the decade.
*
* The view or time range will not change unless the `fromMilliseconds` value
* is in a different decade than the displayed decade.
*
* @param fromMilliseconds
* the moment in time from which the `first` active `year` 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 `year`.
*/
DlYearModelProvider.prototype.goHome = function (fromMilliseconds, selectedMilliseconds) {
return this.getModel(DlYearModelProvider.getStartOfDecade(fromMilliseconds)
.startOf('year')
.valueOf(), selectedMilliseconds);
};
return DlYearModelProvider;
}());
export { DlYearModelProvider };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dl-model-provider-year.js","sourceRoot":"ng://angular-bootstrap-datetimepicker/","sources":["dl-date-time-picker/dl-model-provider-year.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 {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 `year` view.\n */\nexport class DlYearModelProvider implements DlModelProvider {\n\n  /**\n   * Create a moment at midnight january 1 at the start of the current decade.\n   * The start of the decade is always a year ending in zero.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the start of the decade will be determined.\n   * @returns\n   *  moment at midnight january 1 at the start of the current decade.\n   * @internal\n   */\n  private static getStartOfDecade(fromMilliseconds: number): Moment {\n    // Truncate the last digit from the current year to get the start of the decade\n    const startDecade = (Math.trunc(moment(fromMilliseconds).year() / 10) * 10);\n    return moment({year: startDecade}).startOf('year');\n  }\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 `year` model for the specified moment in `local` time with the\n   * `active` year set to January 1 of the specified year.\n   *\n   * The `year` model represents a decade (10 years) as two rows with five columns.\n   *\n   * The decade always starts on a year ending with zero.\n   *\n   * Each cell represents midnight January 1 of the indicated year.\n   *\n   * The `active` year will be the January 1 of year of the specified milliseconds.\n   *\n   * @param milliseconds\n   *  the moment in time from which the year 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 rowNumbers = [0, 1];\n    const columnNumbers = [0, 1, 2, 3, 4];\n\n    const startYear = moment(milliseconds).startOf('year');\n    const startDate = DlYearModelProvider.getStartOfDecade(milliseconds);\n\n    const futureYear = startDate.year() + 9;\n    const pastYear = startDate.year();\n    const activeValue = startYear.valueOf();\n    const selectedValue = selectedMilliseconds === null || selectedMilliseconds === undefined\n      ? selectedMilliseconds\n      : moment(selectedMilliseconds).startOf('year').valueOf();\n\n    return {\n      viewName: 'year',\n      viewLabel: `${pastYear}-${futureYear}`,\n      activeDate: activeValue,\n      leftButton: {\n        value: moment(startDate).subtract(10, 'years').valueOf(),\n        ariaLabel: `Go to ${pastYear - 10}-${pastYear - 1}`,\n        classes: {},\n      },\n      rightButton: {\n        value: moment(startDate).add(10, 'years').valueOf(),\n        ariaLabel: `Go to ${futureYear + 1}-${futureYear + 10}`,\n        classes: {},\n      },\n      rows: rowNumbers.map(rowOfYears.bind(this))\n    };\n\n    function rowOfYears(rowNumber) {\n\n      const currentMoment = moment();\n      const cells = columnNumbers.map((columnNumber) => {\n        const yearMoment = moment(startDate).add((rowNumber * columnNumbers.length) + columnNumber, 'years');\n        return {\n          display: yearMoment.format('YYYY'),\n          value: yearMoment.valueOf(),\n          classes: {\n            'dl-abdtp-active': activeValue === yearMoment.valueOf(),\n            'dl-abdtp-selected': selectedValue === yearMoment.valueOf(),\n            'dl-abdtp-now': yearMoment.isSame(currentMoment, 'year'),\n          }\n        };\n      });\n      return {cells};\n    }\n  }\n\n  /**\n   * Move the active `year` one row `down` from the specified moment in time.\n   *\n   * The `active` year will be the January 1 `five (5) years after` the specified milliseconds.\n   * This moves the `active` date one row `down` in the current `year` view.\n   *\n   * Moving `down` can result in the `active` year being part of a different decade than\n   * the specified `fromMilliseconds`, in this case the decade represented by the model\n   * will change to show the correct decade.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the next `year` model `down` will be constructed.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  model containing an `active` `year` one row `down` from the specified moment in time.\n   */\n  goDown(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).add(5, 'year').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the active `year` one row `up` from the specified moment in time.\n   *\n   * The `active` year will be the January 1 `five (5) years before` the specified milliseconds.\n   * This moves the `active` date one row `up` in the current `year` view.\n   *\n   * Moving `up` can result in the `active` year being part of a different decade than\n   * the specified `fromMilliseconds`, in this case the decade represented by the model\n   * will change to show the correct decade.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the previous `year` model `up` will be constructed.\n   * @param selectedMilliseconds\n   *  the current value of the date/time picker.\n   * @returns\n   *  model containing an `active` `year` one row `up` from the specified moment in time.\n   */\n  goUp(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).subtract(5, 'year').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the `active` `year` one (1) year to the `left` of the specified moment in time.\n   *\n   * The `active` year will be the January 1 `one (1) year before` the specified milliseconds.\n   * This moves the `active` date one year `left` in the current `year` view.\n   *\n   * Moving `left` can result in the `active` year being part of a different decade than\n   * the specified `fromMilliseconds`, in this case the decade represented by the model\n   * will change to show the correct decade.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the `year` 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` `year` one year 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, 'year').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the `active` `year` one (1) year to the `right` of the specified moment in time.\n   *\n   * The `active` year will be the January 1 `one (1) year after` the specified milliseconds.\n   * This moves the `active` date one year `right` in the current `year` view.\n   *\n   * Moving `right` can result in the `active` year being part of a different decade than\n   * the specified `fromMilliseconds`, in this case the decade represented by the model\n   * will change to show the correct decade.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the `year` 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` `year` one year 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, 'year').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the active `year` one decade `down` from the specified moment in time.\n   *\n   * The `active` year will be the January 1 `ten (10) years after` the specified milliseconds.\n   * This moves the `active` date one `page` `down` from the current `year` view.\n   *\n   * Paging `down` will result in the `active` year being part of a different decade than\n   * the specified `fromMilliseconds`. As a result, the decade represented by the model\n   * will change to show the correct decade.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the next `year` 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` `year` one decade `down` from the specified moment in time.\n   */\n  pageDown(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).add(10, 'year').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the active `year` one decade `up` from the specified moment in time.\n   *\n   * The `active` year will be the January 1 `ten (10) years before` the specified milliseconds.\n   * This moves the `active` date one `page-up` from the current `year` view.\n   *\n   * Paging `up` will result in the `active` year being part of a different decade than\n   * the specified `fromMilliseconds`. As a result, the decade represented by the model\n   * will change to show the correct decade.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the next `year` 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` `year` one decade `up` from the specified moment in time.\n   */\n  pageUp(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(moment(fromMilliseconds).subtract(10, 'year').valueOf(), selectedMilliseconds);\n  }\n\n  /**\n   * Move the `active` `year` to the `last` year in the decade.\n   *\n   * The view or time range will not change unless the `fromMilliseconds` value\n   * is in a different decade than the displayed decade.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the `last` active `year` 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 `year`.\n   */\n  goEnd(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(\n      DlYearModelProvider.getStartOfDecade(fromMilliseconds)\n        .add(9, 'years')\n        .endOf('year')\n        .valueOf(),\n      selectedMilliseconds\n    );\n  }\n\n  /**\n   * Move the `active` `year` to the `first` year in the decade.\n   *\n   * The view or time range will not change unless the `fromMilliseconds` value\n   * is in a different decade than the displayed decade.\n   *\n   * @param fromMilliseconds\n   *  the moment in time from which the `first` active `year` 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 `year`.\n   */\n  goHome(fromMilliseconds: number, selectedMilliseconds: number): DlDateTimePickerModel {\n    return this.getModel(\n      DlYearModelProvider.getStartOfDecade(fromMilliseconds)\n        .startOf('year')\n        .valueOf(),\n      selectedMilliseconds\n    );\n  }\n}\n"]}