lucy-calendar
Version:
LucyCalendar is a powerful and flexible date picker library for Angular applications, specifically designed for Ethiopian dates. It provides a user-friendly interface for selecting dates and supports various customization options to fit your needs.
110 lines • 21.2 kB
JavaScript
var EpochOffset;
(function (EpochOffset) {
EpochOffset[EpochOffset["AmeteAlem"] = -285019] = "AmeteAlem";
EpochOffset[EpochOffset["AmeteMihret"] = 1723856] = "AmeteMihret";
EpochOffset[EpochOffset["Coptic"] = 1824665] = "Coptic";
EpochOffset[EpochOffset["Gregorian"] = 1721426] = "Gregorian";
EpochOffset[EpochOffset["Unset"] = -1] = "Unset";
})(EpochOffset || (EpochOffset = {}));
const nMonths = 12;
const monthDays = [0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];
const JD_EPOCH_OFFSET_AMETE_ALEM = -285019; // ዓ/ዓ
const JD_EPOCH_OFFSET_AMETE_MIHRET = 1723856; // ዓ/ም
const JD_EPOCH_OFFSET_COPTIC = 1824665;
const JD_EPOCH_OFFSET_GREGORIAN = 1721426;
export const monthNames = [
"መስከረም", "ጥቅምት", "ህዳር", "ታህሳስ", "ጥር", "የካቲት",
"መጋቢት", "ሚይዚያ", "ግንቦት", "ሰኔ", "ሐምሌ", "ነሐሴ", "ጳጉሜ"
];
export const dayNames = ["እሁድ", "ሰኞ", "ማክሰኞ", "ረቡዕ", "ሐሙስ", "ዓርብ", "ቅዳሜ"];
export function toGregorian(param) {
const { year, month, day } = param;
const era = year <= 0 ? JD_EPOCH_OFFSET_AMETE_ALEM : JD_EPOCH_OFFSET_AMETE_MIHRET;
let jdn = EthiopicToJdn({ year: param.year, month: param.month, day: param.day, era });
const date = JdnToGregorian(jdn);
return new Date(Date.UTC(date[0], date[1] - 1, date[2]));
}
export function toEthiopian(gcDate) {
const jdn = GregorianToJdn(gcDate.getFullYear(), gcDate.getMonth() + 1, gcDate.getDate());
return JdnToEthiopic(jdn, GuessEraFromJDN(jdn));
}
function Quotient(i, j) {
return Math.floor(i / j);
}
function Mod(i, j) {
return i - j * Quotient(i, j);
}
function GuessEraFromJDN(jdn) {
return (jdn >= (JD_EPOCH_OFFSET_AMETE_MIHRET + 365)) ? JD_EPOCH_OFFSET_AMETE_MIHRET : JD_EPOCH_OFFSET_AMETE_ALEM;
}
export function isEthiopianLeapYear(year) {
return year % 4 === 3; // Ethiopian leap years are multiples of 4 with a remainder of 3
}
function IsGregorianLeap(year) {
return (year % 4 === 0) && ((year % 100 !== 0) || (year % 400 === 0));
}
function GregorianToJdn(year, month, day) {
const s = Quotient(year, 4) - Quotient(year - 1, 4) - Quotient(year, 100) + Quotient(year - 1, 100) + Quotient(year, 400) - Quotient(year - 1, 400);
const t = Quotient(14 - month, 12);
const n = 31 * t * (month - 1) + (1 - t) * (59 + s + 30 * (month - 3) + Quotient((3 * month - 7), 5)) + day - 1;
const j = JD_EPOCH_OFFSET_GREGORIAN + 365 * (year - 1) + Quotient(year - 1, 4) - Quotient(year - 1, 100) + Quotient(year - 1, 400) + n;
return j;
}
function JdnToEthiopic(jdn, era) {
era = era ?? GuessEraFromJDN(jdn);
const r = Mod((jdn - era), 1461);
const n = Mod(r, 365) + 365 * Quotient(r, 1460);
const year = 4 * Quotient((jdn - era), 1461) + Quotient(r, 365) - Quotient(r, 1460);
;
const month = Quotient(n, 30) + 1;
const day = Mod(n, 30) + 1;
return { year, month: Number(month), day: Number(day) };
}
function EthCopticToJdn(year, month, day, era) {
return (era + 365) + 365 * (year - 1) + Quotient(year, 4) + 30 * month + day - 31;
}
function JdnToGregorian(j) {
const r2000 = Mod((j - JD_EPOCH_OFFSET_GREGORIAN), 730485);
const r400 = Mod((j - JD_EPOCH_OFFSET_GREGORIAN), 146097);
const r100 = Mod(r400, 36524);
const r4 = Mod(r100, 1461);
let n = Mod(r4, 365) + 365 * Quotient(r4, 1460);
const s = Quotient(r4, 1095);
const aprime = 400 * Quotient((j - JD_EPOCH_OFFSET_GREGORIAN), 146097) + 100 * Quotient(r400, 36524) + 4 * Quotient(r100, 1461) + Quotient(r4, 365) - Quotient(r4, 1460) - Quotient(r2000, 730484);
;
const year = aprime + 1;
const t = Quotient((364 + s - n), 306);
const month = t * (Quotient(n, 31) + 1) + (1 - t) * (Quotient((5 * (n - s) + 13), 153) + 1);
n += 1 - Quotient(r2000, 730484);
let day = n;
if ((r100 == 0) && (n == 0) && (r400 != 0)) {
let month = 12;
day = 31;
}
else {
monthDays[2] = (IsGregorianLeap(year)) ? 29 : 28;
for (let i = 1; i <= nMonths; ++i) {
if (n <= monthDays[i]) {
day = n;
break;
}
n -= monthDays[i];
}
}
return [year, month, day];
}
function EthiopicToJdn(param) {
return EthCopticToJdn(param.year, param.month, param.day, param.era);
}
function CopticToGregorian(year, month, day) {
let jdn = EthiopicToJdn({ year, month, day, era: JD_EPOCH_OFFSET_COPTIC });
return JdnToGregorian(jdn);
}
function GregorianToCoptic(year, month, day) {
let jdn = GregorianToJdn(year, month, day);
return JdnToEthiopic(jdn, JD_EPOCH_OFFSET_COPTIC);
}
function CopticToJdn(year, month, day) {
return EthCopticToJdn(year, month, day, JD_EPOCH_OFFSET_COPTIC);
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-convertor.js","sourceRoot":"","sources":["../../../../projects/lucy-calendar/src/lib/date-convertor.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\r\n\r\nenum EpochOffset {\r\n    AmeteAlem = -285019,\r\n    AmeteMihret = 1723856,\r\n    Coptic = 1824665,\r\n    Gregorian = 1721426,\r\n    Unset = -1\r\n}\r\nconst nMonths: number = 12;\r\n\r\nconst monthDays: number[] = [0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\r\nconst JD_EPOCH_OFFSET_AMETE_ALEM: number = -285019; // ዓ/ዓ\r\nconst JD_EPOCH_OFFSET_AMETE_MIHRET: number = 1723856; // ዓ/ም\r\nconst JD_EPOCH_OFFSET_COPTIC: number = 1824665;\r\nconst JD_EPOCH_OFFSET_GREGORIAN: number = 1721426;\r\n\r\nexport const monthNames: string[] = [\r\n    \"መስከረም\", \"ጥቅምት\", \"ህዳር\", \"ታህሳስ\", \"ጥር\", \"የካቲት\",\r\n    \"መጋቢት\", \"ሚይዚያ\", \"ግንቦት\", \"ሰኔ\", \"ሐምሌ\", \"ነሐሴ\", \"ጳጉሜ\"\r\n];\r\nexport const dayNames: string[] = [\"እሁድ\", \"ሰኞ\", \"ማክሰኞ\", \"ረቡዕ\", \"ሐሙስ\", \"ዓርብ\", \"ቅዳሜ\"];\r\n\r\n\r\nexport function toGregorian(param: { year: number, month: number, day: number }): Date {\r\n    const { year, month, day } = param;\r\n\r\n    const era: number = year <= 0 ? JD_EPOCH_OFFSET_AMETE_ALEM : JD_EPOCH_OFFSET_AMETE_MIHRET;\r\n\r\n    let jdn = EthiopicToJdn({ year: param.year, month: param.month, day: param.day, era });\r\n    const date = JdnToGregorian(jdn);\r\n    return new Date(Date.UTC(date[0], date[1] - 1, date[2]));\r\n}\r\n\r\nexport function toEthiopian(gcDate: Date): { year: number, month: number, day: number } {\r\n    const jdn = GregorianToJdn(gcDate.getFullYear(), gcDate.getMonth() + 1, gcDate.getDate());\r\n    return JdnToEthiopic(jdn, GuessEraFromJDN(jdn));\r\n}\r\n\r\nfunction Quotient(i: number, j: number): number {\r\n    return Math.floor(i / j);\r\n}\r\n\r\nfunction Mod(i: number, j: number): number {\r\n    return i - j * Quotient(i, j);\r\n}\r\nfunction GuessEraFromJDN(jdn: number): number {\r\n    return (jdn >= (JD_EPOCH_OFFSET_AMETE_MIHRET + 365)) ? JD_EPOCH_OFFSET_AMETE_MIHRET : JD_EPOCH_OFFSET_AMETE_ALEM;\r\n}\r\nexport function isEthiopianLeapYear(year: number) {\r\n    return year % 4 === 3; // Ethiopian leap years are multiples of 4 with a remainder of 3\r\n}\r\nfunction IsGregorianLeap(year: number): boolean {\r\n    return (year % 4 === 0) && ((year % 100 !== 0) || (year % 400 === 0));\r\n}\r\n\r\nfunction GregorianToJdn(year: number, month: number, day: number): number {\r\n    const s = Quotient(year, 4) - Quotient(year - 1, 4) - Quotient(year, 100) + Quotient(year - 1, 100) + Quotient(year, 400) - Quotient(year - 1, 400);\r\n\r\n    const t = Quotient(14 - month, 12);\r\n\r\n    const n = 31 * t * (month - 1) + (1 - t) * (59 + s + 30 * (month - 3) + Quotient((3 * month - 7), 5)) + day - 1;\r\n\r\n    const j = JD_EPOCH_OFFSET_GREGORIAN + 365 * (year - 1) + Quotient(year - 1, 4) - Quotient(year - 1, 100) + Quotient(year - 1, 400) + n;\r\n\r\n    return j;\r\n}\r\n\r\nfunction JdnToEthiopic(jdn: number, era?: number): { year: number, month: number, day: number } {\r\n    era = era ?? GuessEraFromJDN(jdn);\r\n    const r = Mod((jdn - era), 1461);\r\n    const n = Mod(r, 365) + 365 * Quotient(r, 1460);\r\n\r\n    const year = 4 * Quotient((jdn - era), 1461) + Quotient(r, 365) - Quotient(r, 1460);;\r\n    const month = Quotient(n, 30) + 1;\r\n    const day = Mod(n, 30) + 1;\r\n    return { year, month: Number(month), day: Number(day) };\r\n}\r\n\r\nfunction EthCopticToJdn(year: number, month: number, day: number, era: number): number {\r\n    return (era + 365) + 365 * (year - 1) + Quotient(year, 4) + 30 * month + day - 31;\r\n}\r\n\r\nfunction JdnToGregorian(j: number): number[] {\r\n    const r2000: number = Mod((j - JD_EPOCH_OFFSET_GREGORIAN), 730485);\r\n    const r400: number = Mod((j - JD_EPOCH_OFFSET_GREGORIAN), 146097);\r\n    const r100: number = Mod(r400, 36524);\r\n    const r4: number = Mod(r100, 1461);\r\n\r\n    let n: number = Mod(r4, 365) + 365 * Quotient(r4, 1460);\r\n    const s: number = Quotient(r4, 1095);\r\n\r\n    const aprime: number = 400 * Quotient((j - JD_EPOCH_OFFSET_GREGORIAN), 146097) + 100 * Quotient(r400, 36524) + 4 * Quotient(r100, 1461) + Quotient(r4, 365) - Quotient(r4, 1460) - Quotient(r2000, 730484);;\r\n    const year: number = aprime + 1;\r\n    const t: number = Quotient((364 + s - n), 306);\r\n    const month: number = t * (Quotient(n, 31) + 1) + (1 - t) * (Quotient((5 * (n - s) + 13), 153) + 1);\r\n\r\n    n += 1 - Quotient(r2000, 730484);\r\n    let day = n;\r\n\r\n    if ((r100 == 0) && (n == 0) && (r400 != 0)) {\r\n        let month = 12;\r\n        day = 31;\r\n    }\r\n    else {\r\n        monthDays[2] = (IsGregorianLeap(year)) ? 29 : 28;\r\n        for (let i = 1; i <= nMonths; ++i) {\r\n            if (n <= monthDays[i]) {\r\n                day = n;\r\n                break;\r\n            }\r\n            n -= monthDays[i];\r\n        }\r\n    }\r\n\r\n    return [year, month, day];\r\n}\r\n\r\nfunction EthiopicToJdn(param: { year: number, month: number, day: number, era: number }): number {\r\n    return EthCopticToJdn(param.year, param.month, param.day, param.era);\r\n}\r\n\r\nfunction CopticToGregorian(year: number, month: number, day: number): number[] {\r\n    let jdn = EthiopicToJdn({ year, month, day, era: JD_EPOCH_OFFSET_COPTIC });\r\n    return JdnToGregorian(jdn);\r\n}\r\n\r\nfunction GregorianToCoptic(year: number, month: number, day: number): { year: number, month: number, day: number } {\r\n    let jdn = GregorianToJdn(year, month, day);\r\n    return JdnToEthiopic(jdn, JD_EPOCH_OFFSET_COPTIC);\r\n}\r\n\r\nfunction CopticToJdn(year: number, month: number, day: number): number {\r\n    return EthCopticToJdn(year, month, day, JD_EPOCH_OFFSET_COPTIC);\r\n}"]}