ngb-calendar.js 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { NgbDate } from './ngb-date';
  6. import { Injectable } from '@angular/core';
  7. import { isInteger } from '../util/util';
  8. import * as i0 from "@angular/core";
  9. /**
  10. * @param {?} jsDate
  11. * @return {?}
  12. */
  13. export function fromJSDate(jsDate) {
  14. return new NgbDate(jsDate.getFullYear(), jsDate.getMonth() + 1, jsDate.getDate());
  15. }
  16. /**
  17. * @param {?} date
  18. * @return {?}
  19. */
  20. export function toJSDate(date) {
  21. /** @type {?} */
  22. const jsDate = new Date(date.year, date.month - 1, date.day, 12);
  23. // this is done avoid 30 -> 1930 conversion
  24. if (!isNaN(jsDate.getTime())) {
  25. jsDate.setFullYear(date.year);
  26. }
  27. return jsDate;
  28. }
  29. /**
  30. * @return {?}
  31. */
  32. export function NGB_DATEPICKER_CALENDAR_FACTORY() {
  33. return new NgbCalendarGregorian();
  34. }
  35. /**
  36. * A service that represents the calendar used by the datepicker.
  37. *
  38. * The default implementation uses the Gregorian calendar. You can inject it in your own
  39. * implementations if necessary to simplify `NgbDate` calculations.
  40. * @abstract
  41. */
  42. export class NgbCalendar {
  43. }
  44. NgbCalendar.decorators = [
  45. { type: Injectable, args: [{ providedIn: 'root', useFactory: NGB_DATEPICKER_CALENDAR_FACTORY },] }
  46. ];
  47. /** @nocollapse */ NgbCalendar.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: NGB_DATEPICKER_CALENDAR_FACTORY, token: NgbCalendar, providedIn: "root" });
  48. if (false) {
  49. /**
  50. * Returns the number of days per week.
  51. * @abstract
  52. * @return {?}
  53. */
  54. NgbCalendar.prototype.getDaysPerWeek = function () { };
  55. /**
  56. * Returns an array of months per year.
  57. *
  58. * With default calendar we use ISO 8601 and return [1, 2, ..., 12];
  59. * @abstract
  60. * @param {?=} year
  61. * @return {?}
  62. */
  63. NgbCalendar.prototype.getMonths = function (year) { };
  64. /**
  65. * Returns the number of weeks per month.
  66. * @abstract
  67. * @return {?}
  68. */
  69. NgbCalendar.prototype.getWeeksPerMonth = function () { };
  70. /**
  71. * Returns the weekday number for a given day.
  72. *
  73. * With the default calendar we use ISO 8601: 'weekday' is 1=Mon ... 7=Sun
  74. * @abstract
  75. * @param {?} date
  76. * @return {?}
  77. */
  78. NgbCalendar.prototype.getWeekday = function (date) { };
  79. /**
  80. * Adds a number of years, months or days to a given date.
  81. *
  82. * * `period` can be `y`, `m` or `d` and defaults to day.
  83. * * `number` defaults to 1.
  84. *
  85. * Always returns a new date.
  86. * @abstract
  87. * @param {?} date
  88. * @param {?=} period
  89. * @param {?=} number
  90. * @return {?}
  91. */
  92. NgbCalendar.prototype.getNext = function (date, period, number) { };
  93. /**
  94. * Subtracts a number of years, months or days from a given date.
  95. *
  96. * * `period` can be `y`, `m` or `d` and defaults to day.
  97. * * `number` defaults to 1.
  98. *
  99. * Always returns a new date.
  100. * @abstract
  101. * @param {?} date
  102. * @param {?=} period
  103. * @param {?=} number
  104. * @return {?}
  105. */
  106. NgbCalendar.prototype.getPrev = function (date, period, number) { };
  107. /**
  108. * Returns the week number for a given week.
  109. * @abstract
  110. * @param {?} week
  111. * @param {?} firstDayOfWeek
  112. * @return {?}
  113. */
  114. NgbCalendar.prototype.getWeekNumber = function (week, firstDayOfWeek) { };
  115. /**
  116. * Returns the today's date.
  117. * @abstract
  118. * @return {?}
  119. */
  120. NgbCalendar.prototype.getToday = function () { };
  121. /**
  122. * Checks if a date is valid in the current calendar.
  123. * @abstract
  124. * @param {?} date
  125. * @return {?}
  126. */
  127. NgbCalendar.prototype.isValid = function (date) { };
  128. }
  129. export class NgbCalendarGregorian extends NgbCalendar {
  130. /**
  131. * @return {?}
  132. */
  133. getDaysPerWeek() { return 7; }
  134. /**
  135. * @return {?}
  136. */
  137. getMonths() { return [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]; }
  138. /**
  139. * @return {?}
  140. */
  141. getWeeksPerMonth() { return 6; }
  142. /**
  143. * @param {?} date
  144. * @param {?=} period
  145. * @param {?=} number
  146. * @return {?}
  147. */
  148. getNext(date, period = 'd', number = 1) {
  149. /** @type {?} */
  150. let jsDate = toJSDate(date);
  151. /** @type {?} */
  152. let checkMonth = true;
  153. /** @type {?} */
  154. let expectedMonth = jsDate.getMonth();
  155. switch (period) {
  156. case 'y':
  157. jsDate.setFullYear(jsDate.getFullYear() + number);
  158. break;
  159. case 'm':
  160. expectedMonth += number;
  161. jsDate.setMonth(expectedMonth);
  162. expectedMonth = expectedMonth % 12;
  163. if (expectedMonth < 0) {
  164. expectedMonth = expectedMonth + 12;
  165. }
  166. break;
  167. case 'd':
  168. jsDate.setDate(jsDate.getDate() + number);
  169. checkMonth = false;
  170. break;
  171. default:
  172. return date;
  173. }
  174. if (checkMonth && jsDate.getMonth() !== expectedMonth) {
  175. // this means the destination month has less days than the initial month
  176. // let's go back to the end of the previous month:
  177. jsDate.setDate(0);
  178. }
  179. return fromJSDate(jsDate);
  180. }
  181. /**
  182. * @param {?} date
  183. * @param {?=} period
  184. * @param {?=} number
  185. * @return {?}
  186. */
  187. getPrev(date, period = 'd', number = 1) { return this.getNext(date, period, -number); }
  188. /**
  189. * @param {?} date
  190. * @return {?}
  191. */
  192. getWeekday(date) {
  193. /** @type {?} */
  194. let jsDate = toJSDate(date);
  195. /** @type {?} */
  196. let day = jsDate.getDay();
  197. // in JS Date Sun=0, in ISO 8601 Sun=7
  198. return day === 0 ? 7 : day;
  199. }
  200. /**
  201. * @param {?} week
  202. * @param {?} firstDayOfWeek
  203. * @return {?}
  204. */
  205. getWeekNumber(week, firstDayOfWeek) {
  206. // in JS Date Sun=0, in ISO 8601 Sun=7
  207. if (firstDayOfWeek === 7) {
  208. firstDayOfWeek = 0;
  209. }
  210. /** @type {?} */
  211. const thursdayIndex = (4 + 7 - firstDayOfWeek) % 7;
  212. /** @type {?} */
  213. let date = week[thursdayIndex];
  214. /** @type {?} */
  215. const jsDate = toJSDate(date);
  216. jsDate.setDate(jsDate.getDate() + 4 - (jsDate.getDay() || 7)); // Thursday
  217. // Thursday
  218. /** @type {?} */
  219. const time = jsDate.getTime();
  220. jsDate.setMonth(0); // Compare with Jan 1
  221. jsDate.setDate(1);
  222. return Math.floor(Math.round((time - jsDate.getTime()) / 86400000) / 7) + 1;
  223. }
  224. /**
  225. * @return {?}
  226. */
  227. getToday() { return fromJSDate(new Date()); }
  228. /**
  229. * @param {?} date
  230. * @return {?}
  231. */
  232. isValid(date) {
  233. if (!date || !isInteger(date.year) || !isInteger(date.month) || !isInteger(date.day)) {
  234. return false;
  235. }
  236. // year 0 doesn't exist in Gregorian calendar
  237. if (date.year === 0) {
  238. return false;
  239. }
  240. /** @type {?} */
  241. const jsDate = toJSDate(date);
  242. return !isNaN(jsDate.getTime()) && jsDate.getFullYear() === date.year && jsDate.getMonth() + 1 === date.month &&
  243. jsDate.getDate() === date.day;
  244. }
  245. }
  246. NgbCalendarGregorian.decorators = [
  247. { type: Injectable }
  248. ];
  249. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngb-calendar.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["datepicker/ngb-calendar.ts"],"names":[],"mappings":"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","sourcesContent":["import {NgbDate} from './ngb-date';\nimport {Injectable} from '@angular/core';\nimport {isInteger} from '../util/util';\n\nexport function fromJSDate(jsDate: Date) {\n  return new NgbDate(jsDate.getFullYear(), jsDate.getMonth() + 1, jsDate.getDate());\n}\nexport function toJSDate(date: NgbDate) {\n  const jsDate = new Date(date.year, date.month - 1, date.day, 12);\n  // this is done avoid 30 -> 1930 conversion\n  if (!isNaN(jsDate.getTime())) {\n    jsDate.setFullYear(date.year);\n  }\n  return jsDate;\n}\n\nexport type NgbPeriod = 'y' | 'm' | 'd';\n\nexport function NGB_DATEPICKER_CALENDAR_FACTORY() {\n  return new NgbCalendarGregorian();\n}\n\n/**\n * A service that represents the calendar used by the datepicker.\n *\n * The default implementation uses the Gregorian calendar. You can inject it in your own\n * implementations if necessary to simplify `NgbDate` calculations.\n */\n@Injectable({providedIn: 'root', useFactory: NGB_DATEPICKER_CALENDAR_FACTORY})\nexport abstract class NgbCalendar {\n  /**\n   * Returns the number of days per week.\n   */\n  abstract getDaysPerWeek(): number;\n\n  /**\n   * Returns an array of months per year.\n   *\n   * With default calendar we use ISO 8601 and return [1, 2, ..., 12];\n   */\n  abstract getMonths(year?: number): number[];\n\n  /**\n   * Returns the number of weeks per month.\n   */\n  abstract getWeeksPerMonth(): number;\n\n  /**\n   * Returns the weekday number for a given day.\n   *\n   * With the default calendar we use ISO 8601: 'weekday' is 1=Mon ... 7=Sun\n   */\n  abstract getWeekday(date: NgbDate): number;\n\n  /**\n   * Adds a number of years, months or days to a given date.\n   *\n   * * `period` can be `y`, `m` or `d` and defaults to day.\n   * * `number` defaults to 1.\n   *\n   * Always returns a new date.\n   */\n  abstract getNext(date: NgbDate, period?: NgbPeriod, number?: number): NgbDate;\n\n  /**\n   * Subtracts a number of years, months or days from a given date.\n   *\n   * * `period` can be `y`, `m` or `d` and defaults to day.\n   * * `number` defaults to 1.\n   *\n   * Always returns a new date.\n   */\n  abstract getPrev(date: NgbDate, period?: NgbPeriod, number?: number): NgbDate;\n\n  /**\n   * Returns the week number for a given week.\n   */\n  abstract getWeekNumber(week: readonly NgbDate[], firstDayOfWeek: number): number;\n\n  /**\n   * Returns the today's date.\n   */\n  abstract getToday(): NgbDate;\n\n  /**\n   * Checks if a date is valid in the current calendar.\n   */\n  abstract isValid(date: NgbDate): boolean;\n}\n\n@Injectable()\nexport class NgbCalendarGregorian extends NgbCalendar {\n  getDaysPerWeek() { return 7; }\n\n  getMonths() { return [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]; }\n\n  getWeeksPerMonth() { return 6; }\n\n  getNext(date: NgbDate, period: NgbPeriod = 'd', number = 1) {\n    let jsDate = toJSDate(date);\n    let checkMonth = true;\n    let expectedMonth = jsDate.getMonth();\n\n    switch (period) {\n      case 'y':\n        jsDate.setFullYear(jsDate.getFullYear() + number);\n        break;\n      case 'm':\n        expectedMonth += number;\n        jsDate.setMonth(expectedMonth);\n        expectedMonth = expectedMonth % 12;\n        if (expectedMonth < 0) {\n          expectedMonth = expectedMonth + 12;\n        }\n        break;\n      case 'd':\n        jsDate.setDate(jsDate.getDate() + number);\n        checkMonth = false;\n        break;\n      default:\n        return date;\n    }\n\n    if (checkMonth && jsDate.getMonth() !== expectedMonth) {\n      // this means the destination month has less days than the initial month\n      // let's go back to the end of the previous month:\n      jsDate.setDate(0);\n    }\n\n    return fromJSDate(jsDate);\n  }\n\n  getPrev(date: NgbDate, period: NgbPeriod = 'd', number = 1) { return this.getNext(date, period, -number); }\n\n  getWeekday(date: NgbDate) {\n    let jsDate = toJSDate(date);\n    let day = jsDate.getDay();\n    // in JS Date Sun=0, in ISO 8601 Sun=7\n    return day === 0 ? 7 : day;\n  }\n\n  getWeekNumber(week: readonly NgbDate[], firstDayOfWeek: number) {\n    // in JS Date Sun=0, in ISO 8601 Sun=7\n    if (firstDayOfWeek === 7) {\n      firstDayOfWeek = 0;\n    }\n\n    const thursdayIndex = (4 + 7 - firstDayOfWeek) % 7;\n    let date = week[thursdayIndex];\n\n    const jsDate = toJSDate(date);\n    jsDate.setDate(jsDate.getDate() + 4 - (jsDate.getDay() || 7));  // Thursday\n    const time = jsDate.getTime();\n    jsDate.setMonth(0);  // Compare with Jan 1\n    jsDate.setDate(1);\n    return Math.floor(Math.round((time - jsDate.getTime()) / 86400000) / 7) + 1;\n  }\n\n  getToday(): NgbDate { return fromJSDate(new Date()); }\n\n  isValid(date: NgbDate): boolean {\n    if (!date || !isInteger(date.year) || !isInteger(date.month) || !isInteger(date.day)) {\n      return false;\n    }\n\n    // year 0 doesn't exist in Gregorian calendar\n    if (date.year === 0) {\n      return false;\n    }\n\n    const jsDate = toJSDate(date);\n\n    return !isNaN(jsDate.getTime()) && jsDate.getFullYear() === date.year && jsDate.getMonth() + 1 === date.month &&\n        jsDate.getDate() === date.day;\n  }\n}\n"]}