ngb-calendar-islamic-civil.js 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import * as tslib_1 from "tslib";
  6. import { NgbCalendarHijri } from './ngb-calendar-hijri';
  7. import { NgbDate } from '../ngb-date';
  8. import { Injectable } from '@angular/core';
  9. /**
  10. * Checks if islamic year is a leap year
  11. * @param {?} hYear
  12. * @return {?}
  13. */
  14. function isIslamicLeapYear(hYear) {
  15. return (14 + 11 * hYear) % 30 < 11;
  16. }
  17. /**
  18. * Checks if gregorian years is a leap year
  19. * @param {?} gDate
  20. * @return {?}
  21. */
  22. function isGregorianLeapYear(gDate) {
  23. /** @type {?} */
  24. var year = gDate.getFullYear();
  25. return year % 4 === 0 && year % 100 !== 0 || year % 400 === 0;
  26. }
  27. /**
  28. * Returns the start of Hijri Month.
  29. * `hMonth` is 0 for Muharram, 1 for Safar, etc.
  30. * `hYear` is any Hijri hYear.
  31. * @param {?} hYear
  32. * @param {?} hMonth
  33. * @return {?}
  34. */
  35. function getIslamicMonthStart(hYear, hMonth) {
  36. return Math.ceil(29.5 * hMonth) + (hYear - 1) * 354 + Math.floor((3 + 11 * hYear) / 30.0);
  37. }
  38. /**
  39. * Returns the start of Hijri year.
  40. * `year` is any Hijri year.
  41. * @param {?} year
  42. * @return {?}
  43. */
  44. function getIslamicYearStart(year) {
  45. return (year - 1) * 354 + Math.floor((3 + 11 * year) / 30.0);
  46. }
  47. /**
  48. * @param {?} a
  49. * @param {?} b
  50. * @return {?}
  51. */
  52. function mod(a, b) {
  53. return a - b * Math.floor(a / b);
  54. }
  55. /**
  56. * The civil calendar is one type of Hijri calendars used in islamic countries.
  57. * Uses a fixed cycle of alternating 29- and 30-day months,
  58. * with a leap day added to the last month of 11 out of every 30 years.
  59. * http://cldr.unicode.org/development/development-process/design-proposals/islamic-calendar-types
  60. * All the calculations here are based on the equations from "Calendrical Calculations" By Edward M. Reingold, Nachum
  61. * Dershowitz.
  62. * @type {?}
  63. */
  64. var GREGORIAN_EPOCH = 1721425.5;
  65. /** @type {?} */
  66. var ISLAMIC_EPOCH = 1948439.5;
  67. var NgbCalendarIslamicCivil = /** @class */ (function (_super) {
  68. tslib_1.__extends(NgbCalendarIslamicCivil, _super);
  69. function NgbCalendarIslamicCivil() {
  70. return _super !== null && _super.apply(this, arguments) || this;
  71. }
  72. /**
  73. * Returns the equivalent islamic(civil) date value for a give input Gregorian date.
  74. * `gDate` is a JS Date to be converted to Hijri.
  75. */
  76. /**
  77. * Returns the equivalent islamic(civil) date value for a give input Gregorian date.
  78. * `gDate` is a JS Date to be converted to Hijri.
  79. * @param {?} gDate
  80. * @return {?}
  81. */
  82. NgbCalendarIslamicCivil.prototype.fromGregorian = /**
  83. * Returns the equivalent islamic(civil) date value for a give input Gregorian date.
  84. * `gDate` is a JS Date to be converted to Hijri.
  85. * @param {?} gDate
  86. * @return {?}
  87. */
  88. function (gDate) {
  89. /** @type {?} */
  90. var gYear = gDate.getFullYear();
  91. /** @type {?} */
  92. var gMonth = gDate.getMonth();
  93. /** @type {?} */
  94. var gDay = gDate.getDate();
  95. /** @type {?} */
  96. var julianDay = GREGORIAN_EPOCH - 1 + 365 * (gYear - 1) + Math.floor((gYear - 1) / 4) +
  97. -Math.floor((gYear - 1) / 100) + Math.floor((gYear - 1) / 400) +
  98. Math.floor((367 * (gMonth + 1) - 362) / 12 + (gMonth + 1 <= 2 ? 0 : isGregorianLeapYear(gDate) ? -1 : -2) + gDay);
  99. julianDay = Math.floor(julianDay) + 0.5;
  100. /** @type {?} */
  101. var days = julianDay - ISLAMIC_EPOCH;
  102. /** @type {?} */
  103. var hYear = Math.floor((30 * days + 10646) / 10631.0);
  104. /** @type {?} */
  105. var hMonth = Math.ceil((days - 29 - getIslamicYearStart(hYear)) / 29.5);
  106. hMonth = Math.min(hMonth, 11);
  107. /** @type {?} */
  108. var hDay = Math.ceil(days - getIslamicMonthStart(hYear, hMonth)) + 1;
  109. return new NgbDate(hYear, hMonth + 1, hDay);
  110. };
  111. /**
  112. * Returns the equivalent JS date value for a give input islamic(civil) date.
  113. * `hDate` is an islamic(civil) date to be converted to Gregorian.
  114. */
  115. /**
  116. * Returns the equivalent JS date value for a give input islamic(civil) date.
  117. * `hDate` is an islamic(civil) date to be converted to Gregorian.
  118. * @param {?} hDate
  119. * @return {?}
  120. */
  121. NgbCalendarIslamicCivil.prototype.toGregorian = /**
  122. * Returns the equivalent JS date value for a give input islamic(civil) date.
  123. * `hDate` is an islamic(civil) date to be converted to Gregorian.
  124. * @param {?} hDate
  125. * @return {?}
  126. */
  127. function (hDate) {
  128. /** @type {?} */
  129. var hYear = hDate.year;
  130. /** @type {?} */
  131. var hMonth = hDate.month - 1;
  132. /** @type {?} */
  133. var hDay = hDate.day;
  134. /** @type {?} */
  135. var julianDay = hDay + Math.ceil(29.5 * hMonth) + (hYear - 1) * 354 + Math.floor((3 + 11 * hYear) / 30) + ISLAMIC_EPOCH - 1;
  136. /** @type {?} */
  137. var wjd = Math.floor(julianDay - 0.5) + 0.5;
  138. /** @type {?} */
  139. var depoch = wjd - GREGORIAN_EPOCH;
  140. /** @type {?} */
  141. var quadricent = Math.floor(depoch / 146097);
  142. /** @type {?} */
  143. var dqc = mod(depoch, 146097);
  144. /** @type {?} */
  145. var cent = Math.floor(dqc / 36524);
  146. /** @type {?} */
  147. var dcent = mod(dqc, 36524);
  148. /** @type {?} */
  149. var quad = Math.floor(dcent / 1461);
  150. /** @type {?} */
  151. var dquad = mod(dcent, 1461);
  152. /** @type {?} */
  153. var yindex = Math.floor(dquad / 365);
  154. /** @type {?} */
  155. var year = quadricent * 400 + cent * 100 + quad * 4 + yindex;
  156. if (!(cent === 4 || yindex === 4)) {
  157. year++;
  158. }
  159. /** @type {?} */
  160. var gYearStart = GREGORIAN_EPOCH + 365 * (year - 1) + Math.floor((year - 1) / 4) - Math.floor((year - 1) / 100) +
  161. Math.floor((year - 1) / 400);
  162. /** @type {?} */
  163. var yearday = wjd - gYearStart;
  164. /** @type {?} */
  165. var tjd = GREGORIAN_EPOCH - 1 + 365 * (year - 1) + Math.floor((year - 1) / 4) - Math.floor((year - 1) / 100) +
  166. Math.floor((year - 1) / 400) + Math.floor(739 / 12 + (isGregorianLeapYear(new Date(year, 3, 1)) ? -1 : -2) + 1);
  167. /** @type {?} */
  168. var leapadj = wjd < tjd ? 0 : isGregorianLeapYear(new Date(year, 3, 1)) ? 1 : 2;
  169. /** @type {?} */
  170. var month = Math.floor(((yearday + leapadj) * 12 + 373) / 367);
  171. /** @type {?} */
  172. var tjd2 = GREGORIAN_EPOCH - 1 + 365 * (year - 1) + Math.floor((year - 1) / 4) - Math.floor((year - 1) / 100) +
  173. Math.floor((year - 1) / 400) +
  174. Math.floor((367 * month - 362) / 12 + (month <= 2 ? 0 : isGregorianLeapYear(new Date(year, month - 1, 1)) ? -1 : -2) +
  175. 1);
  176. /** @type {?} */
  177. var day = wjd - tjd2 + 1;
  178. return new Date(year, month - 1, day);
  179. };
  180. /**
  181. * Returns the number of days in a specific Hijri month.
  182. * `month` is 1 for Muharram, 2 for Safar, etc.
  183. * `year` is any Hijri year.
  184. */
  185. /**
  186. * Returns the number of days in a specific Hijri month.
  187. * `month` is 1 for Muharram, 2 for Safar, etc.
  188. * `year` is any Hijri year.
  189. * @param {?} month
  190. * @param {?} year
  191. * @return {?}
  192. */
  193. NgbCalendarIslamicCivil.prototype.getDaysPerMonth = /**
  194. * Returns the number of days in a specific Hijri month.
  195. * `month` is 1 for Muharram, 2 for Safar, etc.
  196. * `year` is any Hijri year.
  197. * @param {?} month
  198. * @param {?} year
  199. * @return {?}
  200. */
  201. function (month, year) {
  202. year = year + Math.floor(month / 13);
  203. month = ((month - 1) % 12) + 1;
  204. /** @type {?} */
  205. var length = 29 + month % 2;
  206. if (month === 12 && isIslamicLeapYear(year)) {
  207. length++;
  208. }
  209. return length;
  210. };
  211. NgbCalendarIslamicCivil.decorators = [
  212. { type: Injectable }
  213. ];
  214. return NgbCalendarIslamicCivil;
  215. }(NgbCalendarHijri));
  216. export { NgbCalendarIslamicCivil };
  217. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngb-calendar-islamic-civil.js","sourceRoot":"ng://@ng-bootstrap/ng-bootstrap/","sources":["datepicker/hijri/ngb-calendar-islamic-civil.ts"],"names":[],"mappings":"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","sourcesContent":["import {NgbCalendarHijri} from './ngb-calendar-hijri';\nimport {NgbDate} from '../ngb-date';\nimport {Injectable} from '@angular/core';\n\n/**\n * Checks if islamic year is a leap year\n */\nfunction isIslamicLeapYear(hYear: number): boolean {\n  return (14 + 11 * hYear) % 30 < 11;\n}\n\n/**\n * Checks if gregorian years is a leap year\n */\nfunction isGregorianLeapYear(gDate: Date): boolean {\n  const year = gDate.getFullYear();\n  return year % 4 === 0 && year % 100 !== 0 || year % 400 === 0;\n}\n\n/**\n * Returns the start of Hijri Month.\n * `hMonth` is 0 for Muharram, 1 for Safar, etc.\n * `hYear` is any Hijri hYear.\n */\nfunction getIslamicMonthStart(hYear: number, hMonth: number): number {\n  return Math.ceil(29.5 * hMonth) + (hYear - 1) * 354 + Math.floor((3 + 11 * hYear) / 30.0);\n}\n\n/**\n * Returns the start of Hijri year.\n * `year` is any Hijri year.\n */\nfunction getIslamicYearStart(year: number): number {\n  return (year - 1) * 354 + Math.floor((3 + 11 * year) / 30.0);\n}\n\nfunction mod(a: number, b: number): number {\n  return a - b * Math.floor(a / b);\n}\n\n/**\n * The civil calendar is one type of Hijri calendars used in islamic countries.\n * Uses a fixed cycle of alternating 29- and 30-day months,\n * with a leap day added to the last month of 11 out of every 30 years.\n * http://cldr.unicode.org/development/development-process/design-proposals/islamic-calendar-types\n * All the calculations here are based on the equations from \"Calendrical Calculations\" By Edward M. Reingold, Nachum\n * Dershowitz.\n */\n\nconst GREGORIAN_EPOCH = 1721425.5;\nconst ISLAMIC_EPOCH = 1948439.5;\n\n@Injectable()\nexport class NgbCalendarIslamicCivil extends NgbCalendarHijri {\n  /**\n   * Returns the equivalent islamic(civil) date value for a give input Gregorian date.\n   * `gDate` is a JS Date to be converted to Hijri.\n   */\n  fromGregorian(gDate: Date): NgbDate {\n    const gYear = gDate.getFullYear(), gMonth = gDate.getMonth(), gDay = gDate.getDate();\n\n    let julianDay = GREGORIAN_EPOCH - 1 + 365 * (gYear - 1) + Math.floor((gYear - 1) / 4) +\n        -Math.floor((gYear - 1) / 100) + Math.floor((gYear - 1) / 400) +\n        Math.floor(\n            (367 * (gMonth + 1) - 362) / 12 + (gMonth + 1 <= 2 ? 0 : isGregorianLeapYear(gDate) ? -1 : -2) + gDay);\n    julianDay = Math.floor(julianDay) + 0.5;\n\n    const days = julianDay - ISLAMIC_EPOCH;\n    const hYear = Math.floor((30 * days + 10646) / 10631.0);\n    let hMonth = Math.ceil((days - 29 - getIslamicYearStart(hYear)) / 29.5);\n    hMonth = Math.min(hMonth, 11);\n    const hDay = Math.ceil(days - getIslamicMonthStart(hYear, hMonth)) + 1;\n    return new NgbDate(hYear, hMonth + 1, hDay);\n  }\n\n  /**\n   * Returns the equivalent JS date value for a give input islamic(civil) date.\n   * `hDate` is an islamic(civil) date to be converted to Gregorian.\n   */\n  toGregorian(hDate: NgbDate): Date {\n    const hYear = hDate.year;\n    const hMonth = hDate.month - 1;\n    const hDay = hDate.day;\n    const julianDay =\n        hDay + Math.ceil(29.5 * hMonth) + (hYear - 1) * 354 + Math.floor((3 + 11 * hYear) / 30) + ISLAMIC_EPOCH - 1;\n\n    const wjd = Math.floor(julianDay - 0.5) + 0.5, depoch = wjd - GREGORIAN_EPOCH,\n          quadricent = Math.floor(depoch / 146097), dqc = mod(depoch, 146097), cent = Math.floor(dqc / 36524),\n          dcent = mod(dqc, 36524), quad = Math.floor(dcent / 1461), dquad = mod(dcent, 1461),\n          yindex = Math.floor(dquad / 365);\n    let year = quadricent * 400 + cent * 100 + quad * 4 + yindex;\n    if (!(cent === 4 || yindex === 4)) {\n      year++;\n    }\n\n    const gYearStart = GREGORIAN_EPOCH + 365 * (year - 1) + Math.floor((year - 1) / 4) - Math.floor((year - 1) / 100) +\n        Math.floor((year - 1) / 400);\n\n    const yearday = wjd - gYearStart;\n\n    const tjd = GREGORIAN_EPOCH - 1 + 365 * (year - 1) + Math.floor((year - 1) / 4) - Math.floor((year - 1) / 100) +\n        Math.floor((year - 1) / 400) + Math.floor(739 / 12 + (isGregorianLeapYear(new Date(year, 3, 1)) ? -1 : -2) + 1);\n\n    const leapadj = wjd < tjd ? 0 : isGregorianLeapYear(new Date(year, 3, 1)) ? 1 : 2;\n\n    const month = Math.floor(((yearday + leapadj) * 12 + 373) / 367);\n    const tjd2 = GREGORIAN_EPOCH - 1 + 365 * (year - 1) + Math.floor((year - 1) / 4) - Math.floor((year - 1) / 100) +\n        Math.floor((year - 1) / 400) +\n        Math.floor(\n            (367 * month - 362) / 12 + (month <= 2 ? 0 : isGregorianLeapYear(new Date(year, month - 1, 1)) ? -1 : -2) +\n            1);\n\n    const day = wjd - tjd2 + 1;\n\n    return new Date(year, month - 1, day);\n  }\n\n  /**\n   * Returns the number of days in a specific Hijri month.\n   * `month` is 1 for Muharram, 2 for Safar, etc.\n   * `year` is any Hijri year.\n   */\n  getDaysPerMonth(month: number, year: number): number {\n    year = year + Math.floor(month / 13);\n    month = ((month - 1) % 12) + 1;\n    let length = 29 + month % 2;\n    if (month === 12 && isIslamicLeapYear(year)) {\n      length++;\n    }\n    return length;\n  }\n}\n"]}