From 2279b74b3957e4b0eeeb5890d6eae54681d562dd Mon Sep 17 00:00:00 2001 From: Arash Mousavi Date: Sun, 25 Aug 2019 00:42:23 +0100 Subject: [PATCH] Adds support for passing integer numbers --- README.md | 9 +++++---- lib/jdate.js | 27 ++++++++++++++++++--------- lib/jdate.min.js | 4 ++-- src/jdate.js | 21 +++++++++++++++------ tests/jdate.test.js | 11 +++++++++++ 5 files changed, 51 insertions(+), 21 deletions(-) diff --git a/README.md b/README.md index 90a7d30..8e9bb51 100644 --- a/README.md +++ b/README.md @@ -32,14 +32,15 @@ For initializing `JDate` you may either pass an array of Jalali date to it or a ```javascript const JDate = require('jalali-date'); const jdate = new JDate; // => default to today -const jdate2 = new JDate([1393, 10, 11]); -const jdate3 = new JDate(new Date(2014, 1, 3)); +const jdate2 = new JDate(1393, 10, 11); +const jdate3 = new JDate([1393, 10, 11]); +const jdate4 = new JDate(new Date(2014, 1, 3)); ``` ### API ```javascript -jdate.date //=> [1393,5,13] An Array of Jalali Date +jdate.date //=> [1393, 5, 13] An Array of Jalali Date jdate._d // => Gregorian Date Object // Getters @@ -59,7 +60,7 @@ jdate.format('dddd DD MMMM YYYY') // => پنج‌شنبه 12 شهریور 1394 // Static functions JDate.isLeapYear(1393) // => false JDate.daysInMonth(1393, 5) // => 31 -JDate.toGregorian(1393,12,11) // => Gregorian Date object +JDate.toGregorian(1393, 12, 11) // => Gregorian Date object JDate.toJalali(new Date) // => JDate object ``` diff --git a/lib/jdate.js b/lib/jdate.js index 7060173..e6fe622 100644 --- a/lib/jdate.js +++ b/lib/jdate.js @@ -447,7 +447,6 @@ function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _d /* * https://github.com/arashm/JDate * @author: Arash Mousavi - * @version: 1.0.0 */ @@ -456,19 +455,29 @@ var JDate = /*#__PURE__*/ function () { function JDate() { - var input = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : new Date(); - _classCallCheck(this, JDate); - this.input = input; + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + + if (Array.isArray(args[0]) || args[0] instanceof Date) { + this.input = args[0]; + } else if (args.length === 3) { + this.input = args; + } else if (!args.length) { + this.input = new Date(); + } else { + throw new Error('Unexpected input'); + } - if (Array.isArray(input)) { - this.date = input.map(function (num) { + if (Array.isArray(this.input)) { + this.date = this.input.map(function (num) { return parseInt(num, 10); }); this._d = this.toGregorian(); - } else if (input instanceof Date) { - this._d = input; + } else if (this.input instanceof Date) { + this._d = this.input; this.date = JDate.toJalali(this.input); } } @@ -687,4 +696,4 @@ function () { /******/ })["default"]; }); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://JDate/webpack/universalModuleDefinition","webpack://JDate/webpack/bootstrap","webpack://JDate/./src/constants.js","webpack://JDate/./src/converter.js","webpack://JDate/./src/helpers.js","webpack://JDate/./src/jdate.js"],"names":["module","exports","MONTH_NAMES","ABBR_DAYS","DAYS_NAMES","GREGORIAN_EPOCH","PERSIAN_EPOCH","Converter","year","month","day","pad","leapGregorian","Math","floor","jd","wjd","depoch","quadricent","dqc","mod","cent","dcent","quad","dquad","yindex","yearday","gregorianToJulian","leapadj","epbase","epyear","njd","persianToJulian","cycle","cyear","ycycle","aux1","aux2","yday","ceil","julian","julianToGregorian","julianToPersian","div","a","b","fixMonth","yearDiff","newYear","newMonth","zeroLeading","str","length","replaceYear","date","match","value","replace","getFullYear","String","slice","replaceMonth","getMonth","zeroLeadingMonth","toString","replaceDay","getDate","zeroLeadingDate","getDay","JDate","input","Date","Array","isArray","map","num","parseInt","_d","toGregorian","toJalali","fixed","helpers","format","result","julianDate","jdate","gdate","leapPersian","calcedYear","calcedMonth","isLeapYear"],"mappings":"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","file":"jdate.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"JDate\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"JDate\"] = factory();\n\telse\n\t\troot[\"JDate\"] = factory();\n})(this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/jdate.js\");\n","module.exports = {\n  MONTH_NAMES: ['فروردین', 'اردیبهشت', 'خرداد', 'تیر', 'امرداد', 'شهریور', 'مهر', 'آبان', 'آذر', 'دی', 'بهمن', 'اسفند'],\n  ABBR_DAYS: ['۱ش', '۲ش', '۳ش', '۴ش', '۵ش', 'ج', 'ش'],\n  DAYS_NAMES: ['یکشنبه', 'دوشنبه', 'سه‌شنبه', 'چهارشنبه', 'پنج‌شنبه', 'جمعه', 'شنبه'],\n  GREGORIAN_EPOCH: 1721425.5,\n  PERSIAN_EPOCH: 1948320.5\n};\n","import { mod } from './helpers';\nimport { GREGORIAN_EPOCH, PERSIAN_EPOCH } from './constants';\n\nexport default class Converter {\n  //  LEAP_GREGORIAN  --  Is a given year in the Gregorian calendar a leap year?\n  static leapGregorian(year) {\n    return ((year % 4) === 0)\n      && (!(((year % 100) === 0) && ((year % 400) !== 0)));\n  }\n\n  // GREGORIAN_TO_JD  --  Determine Julian day number from Gregorian calendar date\n  static gregorianToJulian(year, month, day) {\n    let pad;\n    if (month <= 2) {\n      pad = 0;\n    } else if (Converter.leapGregorian(year)) {\n      pad = -1;\n    } else {\n      pad = -2;\n    }\n\n    return (GREGORIAN_EPOCH - 1)\n      + (365 * (year - 1))\n      + Math.floor((year - 1) / 4)\n      + (-Math.floor((year - 1) / 100))\n      + Math.floor((year - 1) / 400)\n      + Math.floor((((367 * month) - 362) / 12) + (pad + day));\n  }\n\n  //  JD_TO_GREGORIAN  --  Calculate Gregorian calendar date from Julian day\n  static julianToGregorian(jd) {\n    const wjd = Math.floor(jd - 0.5) + 0.5;\n    const depoch = wjd - GREGORIAN_EPOCH;\n    const quadricent = Math.floor(depoch / 146097);\n    const dqc = mod(depoch, 146097);\n    const cent = Math.floor(dqc / 36524);\n    const dcent = mod(dqc, 36524);\n    const quad = Math.floor(dcent / 1461);\n    const dquad = mod(dcent, 1461);\n    const yindex = Math.floor(dquad / 365);\n    let year = (quadricent * 400) + (cent * 100) + (quad * 4) + yindex;\n    if (!((cent === 4) || (yindex === 4))) { year += 1; }\n    const yearday = wjd - Converter.gregorianToJulian(year, 1, 1);\n    let leapadj;\n    if (wjd < Converter.gregorianToJulian(year, 3, 1)) {\n      leapadj = 0;\n    } else if (Converter.leapGregorian(year) ? 1 : 2) {\n      leapadj = 1;\n    } else {\n      leapadj = 2;\n    }\n    const month = Math.floor((((yearday + leapadj) * 12) + 373) / 367);\n    const day = (wjd - Converter.gregorianToJulian(year, month, 1)) + 1;\n\n    return [year, month, day];\n  }\n\n  //  LEAP_PERSIAN  --  Is a given year a leap year in the Persian calendar ?\n  static leapPersian(year) {\n    return (\n      (((((year - ((year > 0) ? 474 : 473)) % 2820) + 474) + 38) * 682) % 2816\n    ) < 682;\n  }\n\n  //  PERSIAN_TO_JD  --  Determine Julian day from Persian date\n  static persianToJulian(year, month, day) {\n    const epbase = year - ((year >= 0) ? 474 : 473);\n    const epyear = 474 + mod(epbase, 2820);\n\n    return day\n      + ((month <= 7)\n        ? ((month - 1) * 31)\n        : (((month - 1) * 30) + 6)\n      )\n      + Math.floor(((epyear * 682) - 110) / 2816)\n      + ((epyear - 1) * 365)\n      + (Math.floor(epbase / 2820) * 1029983) + (PERSIAN_EPOCH - 1);\n  }\n\n  //  JD_TO_PERSIAN  --  Calculate Persian date from Julian day\n  static julianToPersian(jd) {\n    const njd = Math.floor(jd) + 0.5;\n    const depoch = njd - Converter.persianToJulian(475, 1, 1);\n    const cycle = Math.floor(depoch / 1029983);\n    const cyear = mod(depoch, 1029983);\n    let ycycle;\n    if (cyear === 1029982) {\n      ycycle = 2820;\n    } else {\n      const aux1 = Math.floor(cyear / 366);\n      const aux2 = mod(cyear, 366);\n      ycycle = Math.floor(((2134 * aux1) + (2816 * aux2) + 2815) / 1028522)\n        + aux1 + 1;\n    }\n    let year = ycycle + (2820 * cycle) + 474;\n    if (year <= 0) {\n      year -= 1;\n    }\n    const yday = (njd - Converter.persianToJulian(year, 1, 1)) + 1;\n    const month = (yday <= 186) ? Math.ceil(yday / 31) : Math.ceil((yday - 6) / 30);\n    const day = (njd - Converter.persianToJulian(year, month, 1)) + 1;\n\n    return [year, month, day];\n  }\n\n  static persianToGregorian(year, month, day) {\n    const julian = Converter.persianToJulian(year, month, day);\n\n    return Converter.julianToGregorian(julian);\n  }\n\n  static gregorianToPersian(year, month, day) {\n    const julian = Converter.gregorianToJulian(year, month, day);\n\n    return Converter.julianToPersian(julian);\n  }\n}\n","/* eslint-disable no-unused-vars */\n\nimport {\n  MONTH_NAMES,\n  ABBR_DAYS,\n  DAYS_NAMES\n} from './constants';\n\nexport function div(a, b) {\n  return Math.floor(a / b);\n}\n\nexport function mod(a, b) {\n  return a - (Math.floor(a / b) * b);\n}\n\nexport function fixMonth(year, month) {\n  if (month > 12 || month <= 0) {\n    const yearDiff = Math.floor((month - 1) / 12);\n    const newYear = year - yearDiff;\n    const newMonth = month - (yearDiff * 12);\n\n    return [newYear, newMonth];\n  }\n\n  return [year, month];\n}\n\nexport function zeroLeading(str) {\n  if (str && str.length === 1) { return `0${str}`; }\n  return str;\n}\n\nexport function replaceYear(str, date) {\n  const match = str.match(/[yY]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'YYYY':\n    case 'YYY': {\n      const value = replaceYear(str.replace(match, date.getFullYear()), date);\n      return value;\n    }\n    case 'YY': {\n      const value = replaceYear(\n        str.replace(match, String(date.getFullYear()).slice(2)), date\n      );\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n\nexport function replaceMonth(str, date) {\n  const match = str.match(/[mM]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'M': {\n      const value = replaceMonth(str.replace(match, date.getMonth()), date);\n      return value;\n    }\n    case 'MM': {\n      const zeroLeadingMonth = zeroLeading(date.getMonth().toString());\n      const value = replaceMonth(str.replace(match, zeroLeadingMonth), date);\n      return value;\n    }\n    case 'MMM':\n    case 'MMMM': {\n      const value = replaceMonth(\n        str.replace(match, MONTH_NAMES[date.getMonth() - 1]), date\n      );\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n\nexport function replaceDay(str, date) {\n  const match = str.match(/[dD]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'D': {\n      const value = replaceDay(str.replace(match, date.getDate()), date);\n      return value;\n    }\n    case 'DD': {\n      const zeroLeadingDate = zeroLeading(date.getDate().toString());\n      const value = replaceDay(str.replace(match, zeroLeadingDate), date);\n      return value;\n    }\n    case 'd':\n    case 'dd': {\n      const value = replaceDay(str.replace(match, ABBR_DAYS[date.getDay()]), date);\n      return value;\n    }\n    case 'ddd':\n    case 'dddd': {\n      const value = replaceDay(str.replace(match, DAYS_NAMES[date.getDay()]), date);\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n","/*\n * https://github.com/arashm/JDate\n * @author: Arash Mousavi\n * @version: 1.0.0\n */\n\nimport Converter from './converter';\nimport * as helpers from './helpers';\n\nexport default class JDate {\n  constructor(input = new Date()) {\n    this.input = input;\n    if (Array.isArray(input)) {\n      this.date = input.map((num) => parseInt(num, 10));\n      this._d = this.toGregorian();\n    } else if (input instanceof Date) {\n      this._d = input;\n      this.date = JDate.toJalali(this.input);\n    }\n  }\n\n  /*\n   * Coverts a Gregorian date to Jalali date\n   *\n   * @params {Date} date\n   * @return {Array}\n   */\n  static toJalali(date) {\n    const julianDate = Converter.gregorianToJulian(\n      date.getFullYear(),\n      date.getMonth() + 1,\n      date.getDate(),\n    );\n    const jdate = Converter.julianToPersian(julianDate);\n\n    return jdate;\n  }\n\n  // eslint-disable-next-line camelcase\n  static to_jalali(date) { return JDate.toJalali(date); }\n\n  /*\n   * converts a Jalali date to Gregorian\n   *\n   * @params {Number} year\n   * @params {Number} month\n   * @params {Number} day\n   * @return {Date}\n   */\n  static toGregorian(year, month, day) {\n    const gdate = Converter.julianToGregorian(\n      Converter.persianToJulian(year, month, day)\n    );\n\n    return new Date(gdate[0], gdate[1] - 1, gdate[2]);\n  }\n\n  // eslint-disable-next-line camelcase\n  static to_gregorian(year, month, day) { return JDate.toGregorian(year, month, day); }\n\n  /*\n   * Checks if a given year is a leap year or not\n   *\n   * @params {Number} year\n   * @return {Boolean}\n   */\n  static isLeapYear(year) {\n    return Converter.leapPersian(year);\n  }\n\n  /*\n   * Returns month length.\n   *\n   * @params {Number} year\n   * @params {Number} month zero based\n   * @return {Number}\n   */\n  static daysInMonth(year, month) {\n    let calcedYear = year - Math.floor(month / 12);\n    let calcedMonth = month - (Math.floor(month / 12) * 12);\n\n    if (calcedMonth < 0) {\n      calcedMonth += 12;\n      calcedYear -= 1;\n    } else if (calcedMonth === 0) {\n      calcedMonth = 12;\n    }\n\n    if (calcedMonth < 6) {\n      return 31;\n    } if (calcedMonth < 11) {\n      return 30;\n    } if (JDate.isLeapYear(calcedYear)) {\n      return 30;\n    }\n    return 29;\n  }\n\n  /*\n   * Converts JDate date to Gregorian\n   */\n  toGregorian() {\n    return JDate.toGregorian(this.date[0], this.date[1], this.date[2]);\n  }\n\n  /*\n   * Shows Jalali's full year, ex: 1393\n   *\n   * @return {Integer}\n   */\n  getFullYear() {\n    return this.date[0];\n  }\n\n  /*\n   * Sets the Jalali full year\n   *\n   * @params {Number} year\n   * @return {JDate}\n   */\n  setFullYear(year) {\n    this.date[0] = parseInt(year, 10);\n    this.input = this.toGregorian();\n    return this;\n  }\n\n  /*\n   * Shows Jalali month number.\n   *\n   * @return {Number} Jalali month number\n   */\n  getMonth() {\n    return this.date[1];\n  }\n\n  /*\n   * Sets the Jalali month number. An integer between 0 and 11\n   *\n   * @params {Number} month\n   * @returns {JDate}\n   */\n  setMonth(month) {\n    const fixed = helpers.fixMonth(this.getFullYear(), parseInt(month, 10));\n    [this.date[0], this.date[1]] = fixed;\n    this.input = this.toGregorian();\n\n    return this;\n  }\n\n  /*\n   * Shows Jalali day number. A number between 0 to 31\n   *\n   * @return {Number} Jalali day number\n   */\n  getDate() {\n    return this.date[2];\n  }\n\n  /*\n   * Sets Jalali day number. A number between 0 to 31\n   *\n   * @params {Number} date\n   * @return {JDate}\n   */\n  setDate(date) {\n    this.date[2] = parseInt(date, 10);\n    this.input = this.toGregorian();\n\n    return this;\n  }\n\n  /*\n   * Returns the day of the week for the specified date. A number between 0 to 6\n   *\n   * @returns {Number}\n   */\n  getDay() {\n    return this._d.getDay();\n  }\n\n  /*\n   * Returns a formated output of current date\n   *\n   * @params {String} format\n   * @return {String}\n   */\n  format(format) {\n    let result = helpers.replaceYear(format, this);\n    result = helpers.replaceMonth(result, this);\n    result = helpers.replaceDay(result, this);\n\n    return result;\n  }\n}\n"],"sourceRoot":""} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://JDate/webpack/universalModuleDefinition","webpack://JDate/webpack/bootstrap","webpack://JDate/./src/constants.js","webpack://JDate/./src/converter.js","webpack://JDate/./src/helpers.js","webpack://JDate/./src/jdate.js"],"names":["module","exports","MONTH_NAMES","ABBR_DAYS","DAYS_NAMES","GREGORIAN_EPOCH","PERSIAN_EPOCH","Converter","year","month","day","pad","leapGregorian","Math","floor","jd","wjd","depoch","quadricent","dqc","mod","cent","dcent","quad","dquad","yindex","yearday","gregorianToJulian","leapadj","epbase","epyear","njd","persianToJulian","cycle","cyear","ycycle","aux1","aux2","yday","ceil","julian","julianToGregorian","julianToPersian","div","a","b","fixMonth","yearDiff","newYear","newMonth","zeroLeading","str","length","replaceYear","date","match","value","replace","getFullYear","String","slice","replaceMonth","getMonth","zeroLeadingMonth","toString","replaceDay","getDate","zeroLeadingDate","getDay","JDate","args","Array","isArray","Date","input","Error","map","num","parseInt","_d","toGregorian","toJalali","fixed","helpers","format","result","julianDate","jdate","gdate","leapPersian","calcedYear","calcedMonth","isLeapYear"],"mappings":"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","file":"jdate.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"JDate\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"JDate\"] = factory();\n\telse\n\t\troot[\"JDate\"] = factory();\n})(this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./src/jdate.js\");\n","module.exports = {\n  MONTH_NAMES: ['فروردین', 'اردیبهشت', 'خرداد', 'تیر', 'امرداد', 'شهریور', 'مهر', 'آبان', 'آذر', 'دی', 'بهمن', 'اسفند'],\n  ABBR_DAYS: ['۱ش', '۲ش', '۳ش', '۴ش', '۵ش', 'ج', 'ش'],\n  DAYS_NAMES: ['یکشنبه', 'دوشنبه', 'سه‌شنبه', 'چهارشنبه', 'پنج‌شنبه', 'جمعه', 'شنبه'],\n  GREGORIAN_EPOCH: 1721425.5,\n  PERSIAN_EPOCH: 1948320.5\n};\n","import { mod } from './helpers';\nimport { GREGORIAN_EPOCH, PERSIAN_EPOCH } from './constants';\n\nexport default class Converter {\n  //  LEAP_GREGORIAN  --  Is a given year in the Gregorian calendar a leap year?\n  static leapGregorian(year) {\n    return ((year % 4) === 0)\n      && (!(((year % 100) === 0) && ((year % 400) !== 0)));\n  }\n\n  // GREGORIAN_TO_JD  --  Determine Julian day number from Gregorian calendar date\n  static gregorianToJulian(year, month, day) {\n    let pad;\n    if (month <= 2) {\n      pad = 0;\n    } else if (Converter.leapGregorian(year)) {\n      pad = -1;\n    } else {\n      pad = -2;\n    }\n\n    return (GREGORIAN_EPOCH - 1)\n      + (365 * (year - 1))\n      + Math.floor((year - 1) / 4)\n      + (-Math.floor((year - 1) / 100))\n      + Math.floor((year - 1) / 400)\n      + Math.floor((((367 * month) - 362) / 12) + (pad + day));\n  }\n\n  //  JD_TO_GREGORIAN  --  Calculate Gregorian calendar date from Julian day\n  static julianToGregorian(jd) {\n    const wjd = Math.floor(jd - 0.5) + 0.5;\n    const depoch = wjd - GREGORIAN_EPOCH;\n    const quadricent = Math.floor(depoch / 146097);\n    const dqc = mod(depoch, 146097);\n    const cent = Math.floor(dqc / 36524);\n    const dcent = mod(dqc, 36524);\n    const quad = Math.floor(dcent / 1461);\n    const dquad = mod(dcent, 1461);\n    const yindex = Math.floor(dquad / 365);\n    let year = (quadricent * 400) + (cent * 100) + (quad * 4) + yindex;\n    if (!((cent === 4) || (yindex === 4))) { year += 1; }\n    const yearday = wjd - Converter.gregorianToJulian(year, 1, 1);\n    let leapadj;\n    if (wjd < Converter.gregorianToJulian(year, 3, 1)) {\n      leapadj = 0;\n    } else if (Converter.leapGregorian(year) ? 1 : 2) {\n      leapadj = 1;\n    } else {\n      leapadj = 2;\n    }\n    const month = Math.floor((((yearday + leapadj) * 12) + 373) / 367);\n    const day = (wjd - Converter.gregorianToJulian(year, month, 1)) + 1;\n\n    return [year, month, day];\n  }\n\n  //  LEAP_PERSIAN  --  Is a given year a leap year in the Persian calendar ?\n  static leapPersian(year) {\n    return (\n      (((((year - ((year > 0) ? 474 : 473)) % 2820) + 474) + 38) * 682) % 2816\n    ) < 682;\n  }\n\n  //  PERSIAN_TO_JD  --  Determine Julian day from Persian date\n  static persianToJulian(year, month, day) {\n    const epbase = year - ((year >= 0) ? 474 : 473);\n    const epyear = 474 + mod(epbase, 2820);\n\n    return day\n      + ((month <= 7)\n        ? ((month - 1) * 31)\n        : (((month - 1) * 30) + 6)\n      )\n      + Math.floor(((epyear * 682) - 110) / 2816)\n      + ((epyear - 1) * 365)\n      + (Math.floor(epbase / 2820) * 1029983) + (PERSIAN_EPOCH - 1);\n  }\n\n  //  JD_TO_PERSIAN  --  Calculate Persian date from Julian day\n  static julianToPersian(jd) {\n    const njd = Math.floor(jd) + 0.5;\n    const depoch = njd - Converter.persianToJulian(475, 1, 1);\n    const cycle = Math.floor(depoch / 1029983);\n    const cyear = mod(depoch, 1029983);\n    let ycycle;\n    if (cyear === 1029982) {\n      ycycle = 2820;\n    } else {\n      const aux1 = Math.floor(cyear / 366);\n      const aux2 = mod(cyear, 366);\n      ycycle = Math.floor(((2134 * aux1) + (2816 * aux2) + 2815) / 1028522)\n        + aux1 + 1;\n    }\n    let year = ycycle + (2820 * cycle) + 474;\n    if (year <= 0) {\n      year -= 1;\n    }\n    const yday = (njd - Converter.persianToJulian(year, 1, 1)) + 1;\n    const month = (yday <= 186) ? Math.ceil(yday / 31) : Math.ceil((yday - 6) / 30);\n    const day = (njd - Converter.persianToJulian(year, month, 1)) + 1;\n\n    return [year, month, day];\n  }\n\n  static persianToGregorian(year, month, day) {\n    const julian = Converter.persianToJulian(year, month, day);\n\n    return Converter.julianToGregorian(julian);\n  }\n\n  static gregorianToPersian(year, month, day) {\n    const julian = Converter.gregorianToJulian(year, month, day);\n\n    return Converter.julianToPersian(julian);\n  }\n}\n","/* eslint-disable no-unused-vars */\n\nimport {\n  MONTH_NAMES,\n  ABBR_DAYS,\n  DAYS_NAMES\n} from './constants';\n\nexport function div(a, b) {\n  return Math.floor(a / b);\n}\n\nexport function mod(a, b) {\n  return a - (Math.floor(a / b) * b);\n}\n\nexport function fixMonth(year, month) {\n  if (month > 12 || month <= 0) {\n    const yearDiff = Math.floor((month - 1) / 12);\n    const newYear = year - yearDiff;\n    const newMonth = month - (yearDiff * 12);\n\n    return [newYear, newMonth];\n  }\n\n  return [year, month];\n}\n\nexport function zeroLeading(str) {\n  if (str && str.length === 1) { return `0${str}`; }\n  return str;\n}\n\nexport function replaceYear(str, date) {\n  const match = str.match(/[yY]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'YYYY':\n    case 'YYY': {\n      const value = replaceYear(str.replace(match, date.getFullYear()), date);\n      return value;\n    }\n    case 'YY': {\n      const value = replaceYear(\n        str.replace(match, String(date.getFullYear()).slice(2)), date\n      );\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n\nexport function replaceMonth(str, date) {\n  const match = str.match(/[mM]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'M': {\n      const value = replaceMonth(str.replace(match, date.getMonth()), date);\n      return value;\n    }\n    case 'MM': {\n      const zeroLeadingMonth = zeroLeading(date.getMonth().toString());\n      const value = replaceMonth(str.replace(match, zeroLeadingMonth), date);\n      return value;\n    }\n    case 'MMM':\n    case 'MMMM': {\n      const value = replaceMonth(\n        str.replace(match, MONTH_NAMES[date.getMonth() - 1]), date\n      );\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n\nexport function replaceDay(str, date) {\n  const match = str.match(/[dD]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'D': {\n      const value = replaceDay(str.replace(match, date.getDate()), date);\n      return value;\n    }\n    case 'DD': {\n      const zeroLeadingDate = zeroLeading(date.getDate().toString());\n      const value = replaceDay(str.replace(match, zeroLeadingDate), date);\n      return value;\n    }\n    case 'd':\n    case 'dd': {\n      const value = replaceDay(str.replace(match, ABBR_DAYS[date.getDay()]), date);\n      return value;\n    }\n    case 'ddd':\n    case 'dddd': {\n      const value = replaceDay(str.replace(match, DAYS_NAMES[date.getDay()]), date);\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n","/*\n * https://github.com/arashm/JDate\n * @author: Arash Mousavi\n */\n\nimport Converter from './converter';\nimport * as helpers from './helpers';\n\nexport default class JDate {\n  constructor(...args) {\n    if (Array.isArray(args[0]) || args[0] instanceof Date) {\n      [this.input] = args;\n    } else if (args.length === 3) {\n      this.input = args;\n    } else if (!args.length) {\n      this.input = new Date();\n    } else {\n      throw new Error('Unexpected input');\n    }\n\n    if (Array.isArray(this.input)) {\n      this.date = this.input.map((num) => parseInt(num, 10));\n      this._d = this.toGregorian();\n    } else if (this.input instanceof Date) {\n      this._d = this.input;\n      this.date = JDate.toJalali(this.input);\n    }\n  }\n\n  /*\n   * Coverts a Gregorian date to Jalali date\n   *\n   * @params {Date} date\n   * @return {Array}\n   */\n  static toJalali(date) {\n    const julianDate = Converter.gregorianToJulian(\n      date.getFullYear(),\n      date.getMonth() + 1,\n      date.getDate(),\n    );\n    const jdate = Converter.julianToPersian(julianDate);\n\n    return jdate;\n  }\n\n  // eslint-disable-next-line camelcase\n  static to_jalali(date) { return JDate.toJalali(date); }\n\n  /*\n   * converts a Jalali date to Gregorian\n   *\n   * @params {Number} year\n   * @params {Number} month\n   * @params {Number} day\n   * @return {Date}\n   */\n  static toGregorian(year, month, day) {\n    const gdate = Converter.julianToGregorian(\n      Converter.persianToJulian(year, month, day)\n    );\n\n    return new Date(gdate[0], gdate[1] - 1, gdate[2]);\n  }\n\n  // eslint-disable-next-line camelcase\n  static to_gregorian(year, month, day) { return JDate.toGregorian(year, month, day); }\n\n  /*\n   * Checks if a given year is a leap year or not\n   *\n   * @params {Number} year\n   * @return {Boolean}\n   */\n  static isLeapYear(year) {\n    return Converter.leapPersian(year);\n  }\n\n  /*\n   * Returns month length.\n   *\n   * @params {Number} year\n   * @params {Number} month zero based\n   * @return {Number}\n   */\n  static daysInMonth(year, month) {\n    let calcedYear = year - Math.floor(month / 12);\n    let calcedMonth = month - (Math.floor(month / 12) * 12);\n\n    if (calcedMonth < 0) {\n      calcedMonth += 12;\n      calcedYear -= 1;\n    } else if (calcedMonth === 0) {\n      calcedMonth = 12;\n    }\n\n    if (calcedMonth < 6) {\n      return 31;\n    } if (calcedMonth < 11) {\n      return 30;\n    } if (JDate.isLeapYear(calcedYear)) {\n      return 30;\n    }\n    return 29;\n  }\n\n  /*\n   * Converts JDate date to Gregorian\n   */\n  toGregorian() {\n    return JDate.toGregorian(this.date[0], this.date[1], this.date[2]);\n  }\n\n  /*\n   * Shows Jalali's full year, ex: 1393\n   *\n   * @return {Integer}\n   */\n  getFullYear() {\n    return this.date[0];\n  }\n\n  /*\n   * Sets the Jalali full year\n   *\n   * @params {Number} year\n   * @return {JDate}\n   */\n  setFullYear(year) {\n    this.date[0] = parseInt(year, 10);\n    this.input = this.toGregorian();\n    return this;\n  }\n\n  /*\n   * Shows Jalali month number.\n   *\n   * @return {Number} Jalali month number\n   */\n  getMonth() {\n    return this.date[1];\n  }\n\n  /*\n   * Sets the Jalali month number. An integer between 0 and 11\n   *\n   * @params {Number} month\n   * @returns {JDate}\n   */\n  setMonth(month) {\n    const fixed = helpers.fixMonth(this.getFullYear(), parseInt(month, 10));\n    [this.date[0], this.date[1]] = fixed;\n    this.input = this.toGregorian();\n\n    return this;\n  }\n\n  /*\n   * Shows Jalali day number. A number between 0 to 31\n   *\n   * @return {Number} Jalali day number\n   */\n  getDate() {\n    return this.date[2];\n  }\n\n  /*\n   * Sets Jalali day number. A number between 0 to 31\n   *\n   * @params {Number} date\n   * @return {JDate}\n   */\n  setDate(date) {\n    this.date[2] = parseInt(date, 10);\n    this.input = this.toGregorian();\n\n    return this;\n  }\n\n  /*\n   * Returns the day of the week for the specified date. A number between 0 to 6\n   *\n   * @returns {Number}\n   */\n  getDay() {\n    return this._d.getDay();\n  }\n\n  /*\n   * Returns a formated output of current date\n   *\n   * @params {String} format\n   * @return {String}\n   */\n  format(format) {\n    let result = helpers.replaceYear(format, this);\n    result = helpers.replaceMonth(result, this);\n    result = helpers.replaceDay(result, this);\n\n    return result;\n  }\n}\n"],"sourceRoot":""} \ No newline at end of file diff --git a/lib/jdate.min.js b/lib/jdate.min.js index 2ed4f37..0e10ad7 100644 --- a/lib/jdate.min.js +++ b/lib/jdate.min.js @@ -1,2 +1,2 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("JDate",[],t):"object"==typeof exports?exports.JDate=t():e.JDate=t()}(this,function(){return function(e){var t={};function r(n){if(t[n])return t[n].exports;var a=t[n]={i:n,l:!1,exports:{}};return e[n].call(a.exports,a,a.exports,r),a.l=!0,a.exports}return r.m=e,r.c=t,r.d=function(e,t,n){r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},r.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(r.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var a in e)r.d(n,a,function(t){return e[t]}.bind(null,a));return n},r.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,"a",t),t},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r.p="",r(r.s=1)}([function(e,t){e.exports={MONTH_NAMES:["فروردین","اردیبهشت","خرداد","تیر","امرداد","شهریور","مهر","آبان","آذر","دی","بهمن","اسفند"],ABBR_DAYS:["۱ش","۲ش","۳ش","۴ش","۵ش","ج","ش"],DAYS_NAMES:["یکشنبه","دوشنبه","سه‌شنبه","چهارشنبه","پنج‌شنبه","جمعه","شنبه"],GREGORIAN_EPOCH:1721425.5,PERSIAN_EPOCH:1948320.5}},function(e,t,r){"use strict";r.r(t);var n=r(0);function a(e,t){return e-Math.floor(e/t)*t}function o(e){return e&&1===e.length?"0".concat(e):e}function i(e,t){for(var r=0;r0?474:473))%2820+474+38)%2816<682}},{key:"persianToJulian",value:function(e,t,r){var o=e-(e>=0?474:473),i=474+a(o,2820);return r+(t<=7?31*(t-1):30*(t-1)+6)+Math.floor((682*i-110)/2816)+365*(i-1)+1029983*Math.floor(o/2820)+(n.PERSIAN_EPOCH-1)}},{key:"julianToPersian",value:function(t){var r,n=Math.floor(t)+.5,o=n-e.persianToJulian(475,1,1),i=Math.floor(o/1029983),u=a(o,1029983);if(1029982===u)r=2820;else{var l=Math.floor(u/366),f=a(u,366);r=Math.floor((2134*l+2816*f+2815)/1028522)+l+1}var c=r+2820*i+474;c<=0&&(c-=1);var s=n-e.persianToJulian(c,1,1)+1,h=s<=186?Math.ceil(s/31):Math.ceil((s-6)/30);return[c,h,n-e.persianToJulian(c,h,1)+1]}},{key:"persianToGregorian",value:function(t,r,n){var a=e.persianToJulian(t,r,n);return e.julianToGregorian(a)}},{key:"gregorianToPersian",value:function(t,r,n){var a=e.gregorianToJulian(t,r,n);return e.julianToPersian(a)}}],(r=null)&&i(t.prototype,r),o&&i(t,o),e}();function l(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var r=[],n=!0,a=!1,o=void 0;try{for(var i,u=e[Symbol.iterator]();!(n=(i=u.next()).done)&&(r.push(i.value),!t||r.length!==t);n=!0);}catch(e){a=!0,o=e}finally{try{n||null==u.return||u.return()}finally{if(a)throw o}}return r}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}()}function f(e,t){for(var r=0;r0&&void 0!==arguments[0]?arguments[0]:new Date;!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,e),this.input=t,Array.isArray(t)?(this.date=t.map(function(e){return parseInt(e,10)}),this._d=this.toGregorian()):t instanceof Date&&(this._d=t,this.date=e.toJalali(this.input))}var t,r,a;return t=e,a=[{key:"toJalali",value:function(e){var t=u.gregorianToJulian(e.getFullYear(),e.getMonth()+1,e.getDate());return u.julianToPersian(t)}},{key:"to_jalali",value:function(t){return e.toJalali(t)}},{key:"toGregorian",value:function(e,t,r){var n=u.julianToGregorian(u.persianToJulian(e,t,r));return new Date(n[0],n[1]-1,n[2])}},{key:"to_gregorian",value:function(t,r,n){return e.toGregorian(t,r,n)}},{key:"isLeapYear",value:function(e){return u.leapPersian(e)}},{key:"daysInMonth",value:function(t,r){var n=t-Math.floor(r/12),a=r-12*Math.floor(r/12);return a<0?(a+=12,n-=1):0===a&&(a=12),a<6?31:a<11?30:e.isLeapYear(n)?30:29}}],(r=[{key:"toGregorian",value:function(){return e.toGregorian(this.date[0],this.date[1],this.date[2])}},{key:"getFullYear",value:function(){return this.date[0]}},{key:"setFullYear",value:function(e){return this.date[0]=parseInt(e,10),this.input=this.toGregorian(),this}},{key:"getMonth",value:function(){return this.date[1]}},{key:"setMonth",value:function(e){var t=l(function(e,t){if(t>12||t<=0){var r=Math.floor((t-1)/12);return[e-r,t-12*r]}return[e,t]}(this.getFullYear(),parseInt(e,10)),2);return this.date[0]=t[0],this.date[1]=t[1],this.input=this.toGregorian(),this}},{key:"getDate",value:function(){return this.date[2]}},{key:"setDate",value:function(e){return this.date[2]=parseInt(e,10),this.input=this.toGregorian(),this}},{key:"getDay",value:function(){return this._d.getDay()}},{key:"format",value:function(e){var t=function e(t,r){var n=t.match(/[yY]+/);if(!n)return t;switch(n[0]){case"YYYY":case"YYY":return e(t.replace(n,r.getFullYear()),r);case"YY":return e(t.replace(n,String(r.getFullYear()).slice(2)),r);default:return t}}(e,this);return t=function e(t,r){var a=t.match(/[dD]+/);if(!a)return t;switch(a[0]){case"D":return e(t.replace(a,r.getDate()),r);case"DD":var i=o(r.getDate().toString());return e(t.replace(a,i),r);case"d":case"dd":return e(t.replace(a,n.ABBR_DAYS[r.getDay()]),r);case"ddd":case"dddd":return e(t.replace(a,n.DAYS_NAMES[r.getDay()]),r);default:return t}}(t=function e(t,r){var a=t.match(/[mM]+/);if(!a)return t;switch(a[0]){case"M":return e(t.replace(a,r.getMonth()),r);case"MM":var i=o(r.getMonth().toString());return e(t.replace(a,i),r);case"MMM":case"MMMM":return e(t.replace(a,n.MONTH_NAMES[r.getMonth()-1]),r);default:return t}}(t,this),this)}}])&&f(t.prototype,r),a&&f(t,a),e}()}]).default}); -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://JDate/webpack/universalModuleDefinition","webpack://JDate/webpack/bootstrap","webpack://JDate/./src/constants.js","webpack://JDate/./src/helpers.js","webpack://JDate/./src/converter.js","webpack://JDate/./src/jdate.js"],"names":["root","factory","exports","module","define","amd","this","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","MONTH_NAMES","ABBR_DAYS","DAYS_NAMES","GREGORIAN_EPOCH","PERSIAN_EPOCH","mod","a","b","Math","floor","zeroLeading","str","length","Converter","year","month","day","pad","leapGregorian","jd","wjd","depoch","quadricent","dqc","cent","dcent","quad","dquad","yindex","leapadj","yearday","gregorianToJulian","epbase","epyear","ycycle","njd","persianToJulian","cycle","cyear","aux1","aux2","yday","ceil","julian","julianToGregorian","julianToPersian","JDate","input","Date","Array","isArray","date","map","num","parseInt","_d","toGregorian","toJalali","julianDate","getFullYear","getMonth","getDate","gdate","leapPersian","calcedYear","calcedMonth","isLeapYear","yearDiff","helpers","getDay","format","result","replaceYear","match","replace","String","slice","replaceDay","zeroLeadingDate","toString","replaceMonth","zeroLeadingMonth"],"mappings":"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","file":"jdate.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"JDate\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"JDate\"] = factory();\n\telse\n\t\troot[\"JDate\"] = factory();\n})(this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 1);\n","module.exports = {\n  MONTH_NAMES: ['فروردین', 'اردیبهشت', 'خرداد', 'تیر', 'امرداد', 'شهریور', 'مهر', 'آبان', 'آذر', 'دی', 'بهمن', 'اسفند'],\n  ABBR_DAYS: ['۱ش', '۲ش', '۳ش', '۴ش', '۵ش', 'ج', 'ش'],\n  DAYS_NAMES: ['یکشنبه', 'دوشنبه', 'سه‌شنبه', 'چهارشنبه', 'پنج‌شنبه', 'جمعه', 'شنبه'],\n  GREGORIAN_EPOCH: 1721425.5,\n  PERSIAN_EPOCH: 1948320.5\n};\n","/* eslint-disable no-unused-vars */\n\nimport {\n  MONTH_NAMES,\n  ABBR_DAYS,\n  DAYS_NAMES\n} from './constants';\n\nexport function div(a, b) {\n  return Math.floor(a / b);\n}\n\nexport function mod(a, b) {\n  return a - (Math.floor(a / b) * b);\n}\n\nexport function fixMonth(year, month) {\n  if (month > 12 || month <= 0) {\n    const yearDiff = Math.floor((month - 1) / 12);\n    const newYear = year - yearDiff;\n    const newMonth = month - (yearDiff * 12);\n\n    return [newYear, newMonth];\n  }\n\n  return [year, month];\n}\n\nexport function zeroLeading(str) {\n  if (str && str.length === 1) { return `0${str}`; }\n  return str;\n}\n\nexport function replaceYear(str, date) {\n  const match = str.match(/[yY]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'YYYY':\n    case 'YYY': {\n      const value = replaceYear(str.replace(match, date.getFullYear()), date);\n      return value;\n    }\n    case 'YY': {\n      const value = replaceYear(\n        str.replace(match, String(date.getFullYear()).slice(2)), date\n      );\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n\nexport function replaceMonth(str, date) {\n  const match = str.match(/[mM]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'M': {\n      const value = replaceMonth(str.replace(match, date.getMonth()), date);\n      return value;\n    }\n    case 'MM': {\n      const zeroLeadingMonth = zeroLeading(date.getMonth().toString());\n      const value = replaceMonth(str.replace(match, zeroLeadingMonth), date);\n      return value;\n    }\n    case 'MMM':\n    case 'MMMM': {\n      const value = replaceMonth(\n        str.replace(match, MONTH_NAMES[date.getMonth() - 1]), date\n      );\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n\nexport function replaceDay(str, date) {\n  const match = str.match(/[dD]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'D': {\n      const value = replaceDay(str.replace(match, date.getDate()), date);\n      return value;\n    }\n    case 'DD': {\n      const zeroLeadingDate = zeroLeading(date.getDate().toString());\n      const value = replaceDay(str.replace(match, zeroLeadingDate), date);\n      return value;\n    }\n    case 'd':\n    case 'dd': {\n      const value = replaceDay(str.replace(match, ABBR_DAYS[date.getDay()]), date);\n      return value;\n    }\n    case 'ddd':\n    case 'dddd': {\n      const value = replaceDay(str.replace(match, DAYS_NAMES[date.getDay()]), date);\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n","import { mod } from './helpers';\nimport { GREGORIAN_EPOCH, PERSIAN_EPOCH } from './constants';\n\nexport default class Converter {\n  //  LEAP_GREGORIAN  --  Is a given year in the Gregorian calendar a leap year?\n  static leapGregorian(year) {\n    return ((year % 4) === 0)\n      && (!(((year % 100) === 0) && ((year % 400) !== 0)));\n  }\n\n  // GREGORIAN_TO_JD  --  Determine Julian day number from Gregorian calendar date\n  static gregorianToJulian(year, month, day) {\n    let pad;\n    if (month <= 2) {\n      pad = 0;\n    } else if (Converter.leapGregorian(year)) {\n      pad = -1;\n    } else {\n      pad = -2;\n    }\n\n    return (GREGORIAN_EPOCH - 1)\n      + (365 * (year - 1))\n      + Math.floor((year - 1) / 4)\n      + (-Math.floor((year - 1) / 100))\n      + Math.floor((year - 1) / 400)\n      + Math.floor((((367 * month) - 362) / 12) + (pad + day));\n  }\n\n  //  JD_TO_GREGORIAN  --  Calculate Gregorian calendar date from Julian day\n  static julianToGregorian(jd) {\n    const wjd = Math.floor(jd - 0.5) + 0.5;\n    const depoch = wjd - GREGORIAN_EPOCH;\n    const quadricent = Math.floor(depoch / 146097);\n    const dqc = mod(depoch, 146097);\n    const cent = Math.floor(dqc / 36524);\n    const dcent = mod(dqc, 36524);\n    const quad = Math.floor(dcent / 1461);\n    const dquad = mod(dcent, 1461);\n    const yindex = Math.floor(dquad / 365);\n    let year = (quadricent * 400) + (cent * 100) + (quad * 4) + yindex;\n    if (!((cent === 4) || (yindex === 4))) { year += 1; }\n    const yearday = wjd - Converter.gregorianToJulian(year, 1, 1);\n    let leapadj;\n    if (wjd < Converter.gregorianToJulian(year, 3, 1)) {\n      leapadj = 0;\n    } else if (Converter.leapGregorian(year) ? 1 : 2) {\n      leapadj = 1;\n    } else {\n      leapadj = 2;\n    }\n    const month = Math.floor((((yearday + leapadj) * 12) + 373) / 367);\n    const day = (wjd - Converter.gregorianToJulian(year, month, 1)) + 1;\n\n    return [year, month, day];\n  }\n\n  //  LEAP_PERSIAN  --  Is a given year a leap year in the Persian calendar ?\n  static leapPersian(year) {\n    return (\n      (((((year - ((year > 0) ? 474 : 473)) % 2820) + 474) + 38) * 682) % 2816\n    ) < 682;\n  }\n\n  //  PERSIAN_TO_JD  --  Determine Julian day from Persian date\n  static persianToJulian(year, month, day) {\n    const epbase = year - ((year >= 0) ? 474 : 473);\n    const epyear = 474 + mod(epbase, 2820);\n\n    return day\n      + ((month <= 7)\n        ? ((month - 1) * 31)\n        : (((month - 1) * 30) + 6)\n      )\n      + Math.floor(((epyear * 682) - 110) / 2816)\n      + ((epyear - 1) * 365)\n      + (Math.floor(epbase / 2820) * 1029983) + (PERSIAN_EPOCH - 1);\n  }\n\n  //  JD_TO_PERSIAN  --  Calculate Persian date from Julian day\n  static julianToPersian(jd) {\n    const njd = Math.floor(jd) + 0.5;\n    const depoch = njd - Converter.persianToJulian(475, 1, 1);\n    const cycle = Math.floor(depoch / 1029983);\n    const cyear = mod(depoch, 1029983);\n    let ycycle;\n    if (cyear === 1029982) {\n      ycycle = 2820;\n    } else {\n      const aux1 = Math.floor(cyear / 366);\n      const aux2 = mod(cyear, 366);\n      ycycle = Math.floor(((2134 * aux1) + (2816 * aux2) + 2815) / 1028522)\n        + aux1 + 1;\n    }\n    let year = ycycle + (2820 * cycle) + 474;\n    if (year <= 0) {\n      year -= 1;\n    }\n    const yday = (njd - Converter.persianToJulian(year, 1, 1)) + 1;\n    const month = (yday <= 186) ? Math.ceil(yday / 31) : Math.ceil((yday - 6) / 30);\n    const day = (njd - Converter.persianToJulian(year, month, 1)) + 1;\n\n    return [year, month, day];\n  }\n\n  static persianToGregorian(year, month, day) {\n    const julian = Converter.persianToJulian(year, month, day);\n\n    return Converter.julianToGregorian(julian);\n  }\n\n  static gregorianToPersian(year, month, day) {\n    const julian = Converter.gregorianToJulian(year, month, day);\n\n    return Converter.julianToPersian(julian);\n  }\n}\n","/*\n * https://github.com/arashm/JDate\n * @author: Arash Mousavi\n * @version: 1.0.0\n */\n\nimport Converter from './converter';\nimport * as helpers from './helpers';\n\nexport default class JDate {\n  constructor(input = new Date()) {\n    this.input = input;\n    if (Array.isArray(input)) {\n      this.date = input.map((num) => parseInt(num, 10));\n      this._d = this.toGregorian();\n    } else if (input instanceof Date) {\n      this._d = input;\n      this.date = JDate.toJalali(this.input);\n    }\n  }\n\n  /*\n   * Coverts a Gregorian date to Jalali date\n   *\n   * @params {Date} date\n   * @return {Array}\n   */\n  static toJalali(date) {\n    const julianDate = Converter.gregorianToJulian(\n      date.getFullYear(),\n      date.getMonth() + 1,\n      date.getDate(),\n    );\n    const jdate = Converter.julianToPersian(julianDate);\n\n    return jdate;\n  }\n\n  // eslint-disable-next-line camelcase\n  static to_jalali(date) { return JDate.toJalali(date); }\n\n  /*\n   * converts a Jalali date to Gregorian\n   *\n   * @params {Number} year\n   * @params {Number} month\n   * @params {Number} day\n   * @return {Date}\n   */\n  static toGregorian(year, month, day) {\n    const gdate = Converter.julianToGregorian(\n      Converter.persianToJulian(year, month, day)\n    );\n\n    return new Date(gdate[0], gdate[1] - 1, gdate[2]);\n  }\n\n  // eslint-disable-next-line camelcase\n  static to_gregorian(year, month, day) { return JDate.toGregorian(year, month, day); }\n\n  /*\n   * Checks if a given year is a leap year or not\n   *\n   * @params {Number} year\n   * @return {Boolean}\n   */\n  static isLeapYear(year) {\n    return Converter.leapPersian(year);\n  }\n\n  /*\n   * Returns month length.\n   *\n   * @params {Number} year\n   * @params {Number} month zero based\n   * @return {Number}\n   */\n  static daysInMonth(year, month) {\n    let calcedYear = year - Math.floor(month / 12);\n    let calcedMonth = month - (Math.floor(month / 12) * 12);\n\n    if (calcedMonth < 0) {\n      calcedMonth += 12;\n      calcedYear -= 1;\n    } else if (calcedMonth === 0) {\n      calcedMonth = 12;\n    }\n\n    if (calcedMonth < 6) {\n      return 31;\n    } if (calcedMonth < 11) {\n      return 30;\n    } if (JDate.isLeapYear(calcedYear)) {\n      return 30;\n    }\n    return 29;\n  }\n\n  /*\n   * Converts JDate date to Gregorian\n   */\n  toGregorian() {\n    return JDate.toGregorian(this.date[0], this.date[1], this.date[2]);\n  }\n\n  /*\n   * Shows Jalali's full year, ex: 1393\n   *\n   * @return {Integer}\n   */\n  getFullYear() {\n    return this.date[0];\n  }\n\n  /*\n   * Sets the Jalali full year\n   *\n   * @params {Number} year\n   * @return {JDate}\n   */\n  setFullYear(year) {\n    this.date[0] = parseInt(year, 10);\n    this.input = this.toGregorian();\n    return this;\n  }\n\n  /*\n   * Shows Jalali month number.\n   *\n   * @return {Number} Jalali month number\n   */\n  getMonth() {\n    return this.date[1];\n  }\n\n  /*\n   * Sets the Jalali month number. An integer between 0 and 11\n   *\n   * @params {Number} month\n   * @returns {JDate}\n   */\n  setMonth(month) {\n    const fixed = helpers.fixMonth(this.getFullYear(), parseInt(month, 10));\n    [this.date[0], this.date[1]] = fixed;\n    this.input = this.toGregorian();\n\n    return this;\n  }\n\n  /*\n   * Shows Jalali day number. A number between 0 to 31\n   *\n   * @return {Number} Jalali day number\n   */\n  getDate() {\n    return this.date[2];\n  }\n\n  /*\n   * Sets Jalali day number. A number between 0 to 31\n   *\n   * @params {Number} date\n   * @return {JDate}\n   */\n  setDate(date) {\n    this.date[2] = parseInt(date, 10);\n    this.input = this.toGregorian();\n\n    return this;\n  }\n\n  /*\n   * Returns the day of the week for the specified date. A number between 0 to 6\n   *\n   * @returns {Number}\n   */\n  getDay() {\n    return this._d.getDay();\n  }\n\n  /*\n   * Returns a formated output of current date\n   *\n   * @params {String} format\n   * @return {String}\n   */\n  format(format) {\n    let result = helpers.replaceYear(format, this);\n    result = helpers.replaceMonth(result, this);\n    result = helpers.replaceDay(result, this);\n\n    return result;\n  }\n}\n"],"sourceRoot":""} +!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define("JDate",[],t):"object"==typeof exports?exports.JDate=t():e.JDate=t()}(this,function(){return function(e){var t={};function r(n){if(t[n])return t[n].exports;var a=t[n]={i:n,l:!1,exports:{}};return e[n].call(a.exports,a,a.exports,r),a.l=!0,a.exports}return r.m=e,r.c=t,r.d=function(e,t,n){r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},r.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(r.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var a in e)r.d(n,a,function(t){return e[t]}.bind(null,a));return n},r.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,"a",t),t},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r.p="",r(r.s=1)}([function(e,t){e.exports={MONTH_NAMES:["فروردین","اردیبهشت","خرداد","تیر","امرداد","شهریور","مهر","آبان","آذر","دی","بهمن","اسفند"],ABBR_DAYS:["۱ش","۲ش","۳ش","۴ش","۵ش","ج","ش"],DAYS_NAMES:["یکشنبه","دوشنبه","سه‌شنبه","چهارشنبه","پنج‌شنبه","جمعه","شنبه"],GREGORIAN_EPOCH:1721425.5,PERSIAN_EPOCH:1948320.5}},function(e,t,r){"use strict";r.r(t);var n=r(0);function a(e,t){return e-Math.floor(e/t)*t}function o(e){return e&&1===e.length?"0".concat(e):e}function i(e,t){for(var r=0;r0?474:473))%2820+474+38)%2816<682}},{key:"persianToJulian",value:function(e,t,r){var o=e-(e>=0?474:473),i=474+a(o,2820);return r+(t<=7?31*(t-1):30*(t-1)+6)+Math.floor((682*i-110)/2816)+365*(i-1)+1029983*Math.floor(o/2820)+(n.PERSIAN_EPOCH-1)}},{key:"julianToPersian",value:function(t){var r,n=Math.floor(t)+.5,o=n-e.persianToJulian(475,1,1),i=Math.floor(o/1029983),u=a(o,1029983);if(1029982===u)r=2820;else{var l=Math.floor(u/366),f=a(u,366);r=Math.floor((2134*l+2816*f+2815)/1028522)+l+1}var c=r+2820*i+474;c<=0&&(c-=1);var s=n-e.persianToJulian(c,1,1)+1,h=s<=186?Math.ceil(s/31):Math.ceil((s-6)/30);return[c,h,n-e.persianToJulian(c,h,1)+1]}},{key:"persianToGregorian",value:function(t,r,n){var a=e.persianToJulian(t,r,n);return e.julianToGregorian(a)}},{key:"gregorianToPersian",value:function(t,r,n){var a=e.gregorianToJulian(t,r,n);return e.julianToPersian(a)}}],(r=null)&&i(t.prototype,r),o&&i(t,o),e}();function l(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){var r=[],n=!0,a=!1,o=void 0;try{for(var i,u=e[Symbol.iterator]();!(n=(i=u.next()).done)&&(r.push(i.value),!t||r.length!==t);n=!0);}catch(e){a=!0,o=e}finally{try{n||null==u.return||u.return()}finally{if(a)throw o}}return r}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}()}function f(e,t){for(var r=0;r12||t<=0){var r=Math.floor((t-1)/12);return[e-r,t-12*r]}return[e,t]}(this.getFullYear(),parseInt(e,10)),2);return this.date[0]=t[0],this.date[1]=t[1],this.input=this.toGregorian(),this}},{key:"getDate",value:function(){return this.date[2]}},{key:"setDate",value:function(e){return this.date[2]=parseInt(e,10),this.input=this.toGregorian(),this}},{key:"getDay",value:function(){return this._d.getDay()}},{key:"format",value:function(e){var t=function e(t,r){var n=t.match(/[yY]+/);if(!n)return t;switch(n[0]){case"YYYY":case"YYY":return e(t.replace(n,r.getFullYear()),r);case"YY":return e(t.replace(n,String(r.getFullYear()).slice(2)),r);default:return t}}(e,this);return t=function e(t,r){var a=t.match(/[dD]+/);if(!a)return t;switch(a[0]){case"D":return e(t.replace(a,r.getDate()),r);case"DD":var i=o(r.getDate().toString());return e(t.replace(a,i),r);case"d":case"dd":return e(t.replace(a,n.ABBR_DAYS[r.getDay()]),r);case"ddd":case"dddd":return e(t.replace(a,n.DAYS_NAMES[r.getDay()]),r);default:return t}}(t=function e(t,r){var a=t.match(/[mM]+/);if(!a)return t;switch(a[0]){case"M":return e(t.replace(a,r.getMonth()),r);case"MM":var i=o(r.getMonth().toString());return e(t.replace(a,i),r);case"MMM":case"MMMM":return e(t.replace(a,n.MONTH_NAMES[r.getMonth()-1]),r);default:return t}}(t,this),this)}}])&&f(t.prototype,r),a&&f(t,a),e}()}]).default}); +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://JDate/webpack/universalModuleDefinition","webpack://JDate/webpack/bootstrap","webpack://JDate/./src/constants.js","webpack://JDate/./src/helpers.js","webpack://JDate/./src/converter.js","webpack://JDate/./src/jdate.js"],"names":["root","factory","exports","module","define","amd","this","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","MONTH_NAMES","ABBR_DAYS","DAYS_NAMES","GREGORIAN_EPOCH","PERSIAN_EPOCH","mod","a","b","Math","floor","zeroLeading","str","length","Converter","year","month","day","pad","leapGregorian","jd","wjd","depoch","quadricent","dqc","cent","dcent","quad","dquad","yindex","leapadj","yearday","gregorianToJulian","epbase","epyear","ycycle","njd","persianToJulian","cycle","cyear","aux1","aux2","yday","ceil","julian","julianToGregorian","julianToPersian","JDate","args","Array","isArray","Date","input","Error","date","map","num","parseInt","_d","toGregorian","toJalali","julianDate","getFullYear","getMonth","getDate","gdate","leapPersian","calcedYear","calcedMonth","isLeapYear","yearDiff","helpers","getDay","format","result","replaceYear","match","replace","String","slice","replaceDay","zeroLeadingDate","toString","replaceMonth","zeroLeadingMonth"],"mappings":"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","file":"jdate.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine(\"JDate\", [], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"JDate\"] = factory();\n\telse\n\t\troot[\"JDate\"] = factory();\n})(this, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 1);\n","module.exports = {\n  MONTH_NAMES: ['فروردین', 'اردیبهشت', 'خرداد', 'تیر', 'امرداد', 'شهریور', 'مهر', 'آبان', 'آذر', 'دی', 'بهمن', 'اسفند'],\n  ABBR_DAYS: ['۱ش', '۲ش', '۳ش', '۴ش', '۵ش', 'ج', 'ش'],\n  DAYS_NAMES: ['یکشنبه', 'دوشنبه', 'سه‌شنبه', 'چهارشنبه', 'پنج‌شنبه', 'جمعه', 'شنبه'],\n  GREGORIAN_EPOCH: 1721425.5,\n  PERSIAN_EPOCH: 1948320.5\n};\n","/* eslint-disable no-unused-vars */\n\nimport {\n  MONTH_NAMES,\n  ABBR_DAYS,\n  DAYS_NAMES\n} from './constants';\n\nexport function div(a, b) {\n  return Math.floor(a / b);\n}\n\nexport function mod(a, b) {\n  return a - (Math.floor(a / b) * b);\n}\n\nexport function fixMonth(year, month) {\n  if (month > 12 || month <= 0) {\n    const yearDiff = Math.floor((month - 1) / 12);\n    const newYear = year - yearDiff;\n    const newMonth = month - (yearDiff * 12);\n\n    return [newYear, newMonth];\n  }\n\n  return [year, month];\n}\n\nexport function zeroLeading(str) {\n  if (str && str.length === 1) { return `0${str}`; }\n  return str;\n}\n\nexport function replaceYear(str, date) {\n  const match = str.match(/[yY]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'YYYY':\n    case 'YYY': {\n      const value = replaceYear(str.replace(match, date.getFullYear()), date);\n      return value;\n    }\n    case 'YY': {\n      const value = replaceYear(\n        str.replace(match, String(date.getFullYear()).slice(2)), date\n      );\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n\nexport function replaceMonth(str, date) {\n  const match = str.match(/[mM]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'M': {\n      const value = replaceMonth(str.replace(match, date.getMonth()), date);\n      return value;\n    }\n    case 'MM': {\n      const zeroLeadingMonth = zeroLeading(date.getMonth().toString());\n      const value = replaceMonth(str.replace(match, zeroLeadingMonth), date);\n      return value;\n    }\n    case 'MMM':\n    case 'MMMM': {\n      const value = replaceMonth(\n        str.replace(match, MONTH_NAMES[date.getMonth() - 1]), date\n      );\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n\nexport function replaceDay(str, date) {\n  const match = str.match(/[dD]+/);\n  if (!match) { return str; }\n  switch (match[0]) {\n    case 'D': {\n      const value = replaceDay(str.replace(match, date.getDate()), date);\n      return value;\n    }\n    case 'DD': {\n      const zeroLeadingDate = zeroLeading(date.getDate().toString());\n      const value = replaceDay(str.replace(match, zeroLeadingDate), date);\n      return value;\n    }\n    case 'd':\n    case 'dd': {\n      const value = replaceDay(str.replace(match, ABBR_DAYS[date.getDay()]), date);\n      return value;\n    }\n    case 'ddd':\n    case 'dddd': {\n      const value = replaceDay(str.replace(match, DAYS_NAMES[date.getDay()]), date);\n      return value;\n    }\n    default: {\n      return str;\n    }\n  }\n}\n","import { mod } from './helpers';\nimport { GREGORIAN_EPOCH, PERSIAN_EPOCH } from './constants';\n\nexport default class Converter {\n  //  LEAP_GREGORIAN  --  Is a given year in the Gregorian calendar a leap year?\n  static leapGregorian(year) {\n    return ((year % 4) === 0)\n      && (!(((year % 100) === 0) && ((year % 400) !== 0)));\n  }\n\n  // GREGORIAN_TO_JD  --  Determine Julian day number from Gregorian calendar date\n  static gregorianToJulian(year, month, day) {\n    let pad;\n    if (month <= 2) {\n      pad = 0;\n    } else if (Converter.leapGregorian(year)) {\n      pad = -1;\n    } else {\n      pad = -2;\n    }\n\n    return (GREGORIAN_EPOCH - 1)\n      + (365 * (year - 1))\n      + Math.floor((year - 1) / 4)\n      + (-Math.floor((year - 1) / 100))\n      + Math.floor((year - 1) / 400)\n      + Math.floor((((367 * month) - 362) / 12) + (pad + day));\n  }\n\n  //  JD_TO_GREGORIAN  --  Calculate Gregorian calendar date from Julian day\n  static julianToGregorian(jd) {\n    const wjd = Math.floor(jd - 0.5) + 0.5;\n    const depoch = wjd - GREGORIAN_EPOCH;\n    const quadricent = Math.floor(depoch / 146097);\n    const dqc = mod(depoch, 146097);\n    const cent = Math.floor(dqc / 36524);\n    const dcent = mod(dqc, 36524);\n    const quad = Math.floor(dcent / 1461);\n    const dquad = mod(dcent, 1461);\n    const yindex = Math.floor(dquad / 365);\n    let year = (quadricent * 400) + (cent * 100) + (quad * 4) + yindex;\n    if (!((cent === 4) || (yindex === 4))) { year += 1; }\n    const yearday = wjd - Converter.gregorianToJulian(year, 1, 1);\n    let leapadj;\n    if (wjd < Converter.gregorianToJulian(year, 3, 1)) {\n      leapadj = 0;\n    } else if (Converter.leapGregorian(year) ? 1 : 2) {\n      leapadj = 1;\n    } else {\n      leapadj = 2;\n    }\n    const month = Math.floor((((yearday + leapadj) * 12) + 373) / 367);\n    const day = (wjd - Converter.gregorianToJulian(year, month, 1)) + 1;\n\n    return [year, month, day];\n  }\n\n  //  LEAP_PERSIAN  --  Is a given year a leap year in the Persian calendar ?\n  static leapPersian(year) {\n    return (\n      (((((year - ((year > 0) ? 474 : 473)) % 2820) + 474) + 38) * 682) % 2816\n    ) < 682;\n  }\n\n  //  PERSIAN_TO_JD  --  Determine Julian day from Persian date\n  static persianToJulian(year, month, day) {\n    const epbase = year - ((year >= 0) ? 474 : 473);\n    const epyear = 474 + mod(epbase, 2820);\n\n    return day\n      + ((month <= 7)\n        ? ((month - 1) * 31)\n        : (((month - 1) * 30) + 6)\n      )\n      + Math.floor(((epyear * 682) - 110) / 2816)\n      + ((epyear - 1) * 365)\n      + (Math.floor(epbase / 2820) * 1029983) + (PERSIAN_EPOCH - 1);\n  }\n\n  //  JD_TO_PERSIAN  --  Calculate Persian date from Julian day\n  static julianToPersian(jd) {\n    const njd = Math.floor(jd) + 0.5;\n    const depoch = njd - Converter.persianToJulian(475, 1, 1);\n    const cycle = Math.floor(depoch / 1029983);\n    const cyear = mod(depoch, 1029983);\n    let ycycle;\n    if (cyear === 1029982) {\n      ycycle = 2820;\n    } else {\n      const aux1 = Math.floor(cyear / 366);\n      const aux2 = mod(cyear, 366);\n      ycycle = Math.floor(((2134 * aux1) + (2816 * aux2) + 2815) / 1028522)\n        + aux1 + 1;\n    }\n    let year = ycycle + (2820 * cycle) + 474;\n    if (year <= 0) {\n      year -= 1;\n    }\n    const yday = (njd - Converter.persianToJulian(year, 1, 1)) + 1;\n    const month = (yday <= 186) ? Math.ceil(yday / 31) : Math.ceil((yday - 6) / 30);\n    const day = (njd - Converter.persianToJulian(year, month, 1)) + 1;\n\n    return [year, month, day];\n  }\n\n  static persianToGregorian(year, month, day) {\n    const julian = Converter.persianToJulian(year, month, day);\n\n    return Converter.julianToGregorian(julian);\n  }\n\n  static gregorianToPersian(year, month, day) {\n    const julian = Converter.gregorianToJulian(year, month, day);\n\n    return Converter.julianToPersian(julian);\n  }\n}\n","/*\n * https://github.com/arashm/JDate\n * @author: Arash Mousavi\n */\n\nimport Converter from './converter';\nimport * as helpers from './helpers';\n\nexport default class JDate {\n  constructor(...args) {\n    if (Array.isArray(args[0]) || args[0] instanceof Date) {\n      [this.input] = args;\n    } else if (args.length === 3) {\n      this.input = args;\n    } else if (!args.length) {\n      this.input = new Date();\n    } else {\n      throw new Error('Unexpected input');\n    }\n\n    if (Array.isArray(this.input)) {\n      this.date = this.input.map((num) => parseInt(num, 10));\n      this._d = this.toGregorian();\n    } else if (this.input instanceof Date) {\n      this._d = this.input;\n      this.date = JDate.toJalali(this.input);\n    }\n  }\n\n  /*\n   * Coverts a Gregorian date to Jalali date\n   *\n   * @params {Date} date\n   * @return {Array}\n   */\n  static toJalali(date) {\n    const julianDate = Converter.gregorianToJulian(\n      date.getFullYear(),\n      date.getMonth() + 1,\n      date.getDate(),\n    );\n    const jdate = Converter.julianToPersian(julianDate);\n\n    return jdate;\n  }\n\n  // eslint-disable-next-line camelcase\n  static to_jalali(date) { return JDate.toJalali(date); }\n\n  /*\n   * converts a Jalali date to Gregorian\n   *\n   * @params {Number} year\n   * @params {Number} month\n   * @params {Number} day\n   * @return {Date}\n   */\n  static toGregorian(year, month, day) {\n    const gdate = Converter.julianToGregorian(\n      Converter.persianToJulian(year, month, day)\n    );\n\n    return new Date(gdate[0], gdate[1] - 1, gdate[2]);\n  }\n\n  // eslint-disable-next-line camelcase\n  static to_gregorian(year, month, day) { return JDate.toGregorian(year, month, day); }\n\n  /*\n   * Checks if a given year is a leap year or not\n   *\n   * @params {Number} year\n   * @return {Boolean}\n   */\n  static isLeapYear(year) {\n    return Converter.leapPersian(year);\n  }\n\n  /*\n   * Returns month length.\n   *\n   * @params {Number} year\n   * @params {Number} month zero based\n   * @return {Number}\n   */\n  static daysInMonth(year, month) {\n    let calcedYear = year - Math.floor(month / 12);\n    let calcedMonth = month - (Math.floor(month / 12) * 12);\n\n    if (calcedMonth < 0) {\n      calcedMonth += 12;\n      calcedYear -= 1;\n    } else if (calcedMonth === 0) {\n      calcedMonth = 12;\n    }\n\n    if (calcedMonth < 6) {\n      return 31;\n    } if (calcedMonth < 11) {\n      return 30;\n    } if (JDate.isLeapYear(calcedYear)) {\n      return 30;\n    }\n    return 29;\n  }\n\n  /*\n   * Converts JDate date to Gregorian\n   */\n  toGregorian() {\n    return JDate.toGregorian(this.date[0], this.date[1], this.date[2]);\n  }\n\n  /*\n   * Shows Jalali's full year, ex: 1393\n   *\n   * @return {Integer}\n   */\n  getFullYear() {\n    return this.date[0];\n  }\n\n  /*\n   * Sets the Jalali full year\n   *\n   * @params {Number} year\n   * @return {JDate}\n   */\n  setFullYear(year) {\n    this.date[0] = parseInt(year, 10);\n    this.input = this.toGregorian();\n    return this;\n  }\n\n  /*\n   * Shows Jalali month number.\n   *\n   * @return {Number} Jalali month number\n   */\n  getMonth() {\n    return this.date[1];\n  }\n\n  /*\n   * Sets the Jalali month number. An integer between 0 and 11\n   *\n   * @params {Number} month\n   * @returns {JDate}\n   */\n  setMonth(month) {\n    const fixed = helpers.fixMonth(this.getFullYear(), parseInt(month, 10));\n    [this.date[0], this.date[1]] = fixed;\n    this.input = this.toGregorian();\n\n    return this;\n  }\n\n  /*\n   * Shows Jalali day number. A number between 0 to 31\n   *\n   * @return {Number} Jalali day number\n   */\n  getDate() {\n    return this.date[2];\n  }\n\n  /*\n   * Sets Jalali day number. A number between 0 to 31\n   *\n   * @params {Number} date\n   * @return {JDate}\n   */\n  setDate(date) {\n    this.date[2] = parseInt(date, 10);\n    this.input = this.toGregorian();\n\n    return this;\n  }\n\n  /*\n   * Returns the day of the week for the specified date. A number between 0 to 6\n   *\n   * @returns {Number}\n   */\n  getDay() {\n    return this._d.getDay();\n  }\n\n  /*\n   * Returns a formated output of current date\n   *\n   * @params {String} format\n   * @return {String}\n   */\n  format(format) {\n    let result = helpers.replaceYear(format, this);\n    result = helpers.replaceMonth(result, this);\n    result = helpers.replaceDay(result, this);\n\n    return result;\n  }\n}\n"],"sourceRoot":""} \ No newline at end of file diff --git a/src/jdate.js b/src/jdate.js index 9ef8dc6..09e5994 100644 --- a/src/jdate.js +++ b/src/jdate.js @@ -7,13 +7,22 @@ import Converter from './converter'; import * as helpers from './helpers'; export default class JDate { - constructor(input = new Date()) { - this.input = input; - if (Array.isArray(input)) { - this.date = input.map((num) => parseInt(num, 10)); + constructor(...args) { + if (Array.isArray(args[0]) || args[0] instanceof Date) { + [this.input] = args; + } else if (args.length === 3) { + this.input = args; + } else if (!args.length) { + this.input = new Date(); + } else { + throw new Error('Unexpected input'); + } + + if (Array.isArray(this.input)) { + this.date = this.input.map((num) => parseInt(num, 10)); this._d = this.toGregorian(); - } else if (input instanceof Date) { - this._d = input; + } else if (this.input instanceof Date) { + this._d = this.input; this.date = JDate.toJalali(this.input); } } diff --git a/tests/jdate.test.js b/tests/jdate.test.js index 16018ab..34ce141 100644 --- a/tests/jdate.test.js +++ b/tests/jdate.test.js @@ -21,6 +21,17 @@ describe('JDate', () => { expect(jdate._d.getDate()).toEqual(1); }); + it('should convert by passing just integers', () => { + const jdate = new JDate(1396, 10, 11); + + expect(jdate.date).toEqual([1396, 10, 11]); + expect(jdate.input).toEqual([1396, 10, 11]); + expect(jdate._d).toBeInstanceOf(Date); + expect(jdate._d.getFullYear()).toEqual(2018); + expect(jdate._d.getMonth()).toEqual(0); + expect(jdate._d.getDate()).toEqual(1); + }); + it('should convert a JS date object', () => { const currentDate = new Date(2018, 0, 1); const jdate = new JDate(currentDate);