qrono 1.5.0 → 1.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,12 +1,12 @@
1
1
  # <img src="docs/public/logo.svg" alt="Qrono Logo" width="48"> [Qrono](https://qronojs.dev/) — Small. Complete. Deterministic. JavaScript date-time.
2
2
 
3
- _**4kB** JavaScript date library with **100+ APIs** and **strict DST guarantees**. Designed for **single-timezone** applications._
3
+ _A **tiny** JavaScript date library with **100+ APIs** and **strict DST guarantees**. Designed for **single-timezone** applications._
4
4
 
5
5
  [![MIT License][image-license]][url-license]
6
6
  [![CodeQL][image-codeql]][url-codeql]
7
7
  [![NPM version][image-npm-version]][url-npm]
8
8
  [![NPM downloads][image-downloads]][url-downloads]
9
- [![gzip size][image-size]][url-size]
9
+ [![brotli size][image-size]][url-size]
10
10
 
11
11
  ```js
12
12
  import { qrono } from 'qrono'
@@ -50,7 +50,7 @@ date.endOfMonth() // 2024-06-30
50
50
 
51
51
  #### ⚡ **Minimal and Focused**
52
52
  - Pure JavaScript with zero dependencies.
53
- - Lightweight (**4kB**) with **100+** APIs through focused design.
53
+ - Lightweight (**3.3 kB** brotli-compressed), with **100+** APIs in a focused design.
54
54
 
55
55
  #### 🌍 **UTC-first with Local Time Support**
56
56
  - Supports UTC by default and the environment's local time zone.
@@ -76,7 +76,7 @@ date.endOfMonth() // 2024-06-30
76
76
 
77
77
  - **[Day.js](https://day.js.org/)**
78
78
  A small, Moment.js-compatible library with a large GitHub following, increasingly considered a de facto standard.
79
- Approximately 3kB with 30+ core APIs. Timezone, locale support, and additional functionality require plugins.
79
+ Approximately 3 kB with 30+ core APIs. Timezone, locale support, and additional functionality require plugins.
80
80
  Currently preparing a major version upgrade.
81
81
 
82
82
  - **[date-fns](https://date-fns.org/)**
@@ -111,9 +111,13 @@ yarn add @urin/qrono # for Yarn
111
111
 
112
112
  ```html
113
113
  <!-- for Browser -->
114
- <script src="path/to/qrono.min.js"></script>
114
+ <script type="module">
115
+ import { qrono } from './path/to/qrono.js'
116
+ </script>
115
117
  <!-- from UNPKG -->
116
- <script src="https://unpkg.com/qrono/dist/qrono.min.js"></script>
118
+ <script type="module">
119
+ import { qrono } from 'https://unpkg.com/qrono@1/dist/qrono.js'
120
+ </script>
117
121
  ```
118
122
 
119
123
  ```js
@@ -324,7 +328,5 @@ Copyright (c) 2021 [Urin](https://github.com/urin)
324
328
  [image-downloads]: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/urin/my-actions/main/badges/downloads.json
325
329
  [url-downloads]: https://npmcharts.com/compare/qrono?minimal=true
326
330
 
327
- [image-size]: https://img.badgesize.io/https://unpkg.com/qrono/dist/qrono.min.js?compression=gzip&color=blue
328
- [url-size]: https://unpkg.com/qrono/dist/qrono.min.js
329
-
330
-
331
+ [image-size]: https://raw.githubusercontent.com/urin/qrono/main/images/size.svg
332
+ [url-size]: https://qronojs.dev/introduction#package-size-comparison
package/dist/qrono.min.js CHANGED
@@ -1,2 +1,2 @@
1
- var Qrono=(function(e){Object.defineProperty(e,Symbol.toStringTag,{value:`Module`});var t=new Date(1915,0,1,12,0,0,0),n=1440;n*7;var r=3600,i=r*24,a=i*7,o=1e3,s=60*o;r*o;var c=i*o;a*o;function l(e,...t){return t.flat().some(e.hasOwnProperty,e)}function u(e){return Object.entries(e).filter(([,e])=>!f(e)).map(([e])=>e)}function d(e){return e!==void 0}function f(e){return e instanceof Function}function p(e){return typeof e==`string`||e instanceof String}function m(e){return typeof e==`object`&&!!e&&e.constructor===Object}function h(e){return!Number.isNaN(e.getTime())}function g(e){return l(e,[`year`,`month`,`day`,`hour`,`minute`,`second`,`millisecond`])}var _=w;w.date=F;var v={localtime:!1,disambiguation:`compatible`};w.context=function(e){if(d(e)){for(let t of u(v))l(e,t)&&(v[t]=e[t]);return this}return{...v}};var y=1,b=2,x=3,S=4;Object.assign(w,{monday:y,tuesday:b,wednesday:x,thursday:S,friday:5,saturday:6,sunday:7});var C=Symbol();function w(...e){if(!new.target)return new w(...e);let t={nativeDate:null,localtime:!1,disambiguation:`compatible`,set:O,parse:A,valid:T,context:E,getNative:D};if(this[C]=t,t.context(v),e[0]instanceof w){let n=e.shift();t.nativeDate=n.nativeDate(),t.context(n.context())}m(e[0])&&!g(e[0])&&t.context(e.shift());let n=e[0],r=e[1];if(n==null)t.nativeDate??=new Date;else if(n instanceof Date)t.nativeDate=new Date(n.getTime());else if(p(n))t.parse(n);else if(m(n)){if(!g(n))throw RangeError(`Missing time field (year, minute, day, hour, minute, second or millisecond)`);t.set(n)}else if(Number.isFinite(n)&&!Number.isFinite(r))t.nativeDate=new Date(n);else if(Number.isFinite(n)||Array.isArray(n)){let n=e.flat(),r=n.filter(e=>Number.isSafeInteger(e));if(r.length!==n.length)throw RangeError(`Should be safe integers`);if(r.length>7)throw RangeError(`Too many numbers`);t.set({year:r[0],month:r[1],day:r[2],hour:r[3],minute:r[4],second:r[5],millisecond:r[6]})}else throw TypeError(`Invalid argument ${e}`);return this}function T(){return h(this.nativeDate)}function E(e){return e?(`localtime`in e&&(this.localtime=e.localtime),`disambiguation`in e&&(this.disambiguation=e.disambiguation),this):{localtime:this.localtime,disambiguation:this.disambiguation}}function D(e){return this.nativeDate[`get${this.localtime?``:`UTC`}${e}`]()}function O(e){let n={...e};if(n.month=n.month&&n.month-1,!this.localtime){let e=this.nativeDate??new Date(0),t=new Date(0);return t.setUTCFullYear(n.year??e.getUTCFullYear(),n.month??e.getUTCMonth(),n.day??e.getUTCDate()),t.setUTCHours(n.hour??e.getUTCHours(),n.minute??e.getUTCMinutes(),n.second??e.getUTCSeconds(),n.millisecond??e.getUTCMilliseconds()),this.nativeDate=t,this}let r=!l(e,`hour`,`minute`,`second`,`millisecond`),i=r?`later`:this.disambiguation,a=this.nativeDate??new Date(0,0),o=new Date(t.getTime()),s={year:n.year??a.getFullYear(),month:n.month??a.getMonth(),day:n.day??a.getDate(),hour:n.hour??(r?0:a.getHours()),minute:n.minute??(r?0:a.getMinutes()),second:n.second??(r?0:a.getSeconds()),millisecond:n.millisecond??(r?0:a.getMilliseconds())};o.setFullYear(s.year,s.month,s.day),o.setHours(s.hour,s.minute,s.second,s.millisecond);let c=o.getTime(),u=new Date(c);u.setDate(o.getDate()+1);let d=new Date(c);d.setDate(o.getDate()-1);let f=u.getTimezoneOffset()-d.getTimezoneOffset();if(i===`compatible`||f===0)return this.nativeDate=o,this;let p=s.year*1e8+s.month*1e6+s.day*1e4+s.hour*100+s.minute<o.getFullYear()*1e8+o.getMonth()*1e6+o.getDate()*1e4+o.getHours()*100+o.getMinutes(),m=new Date(new Date(c).setUTCMinutes(o.getUTCMinutes()+f)),h=m.getHours()===o.getHours()&&m.getMinutes()===o.getMinutes();if(!p&&!h)return this.nativeDate=o,this;if(i===`reject`)throw RangeError(`Requested local time ${s} is ambiguous.`);return this.nativeDate=i===`later`?o:m,this}var k=RegExp(`^(\\d{4})(?:[-/]?([0-2]?\\d)(?:[-/]?([0-3]?\\d))?)?(?:[T\\s]([0-2]?\\d)(?::([0-5]?\\d)?(?::([0-6]?\\d)?(?:[.:](\\d{1,3})?\\d*)?)?)?)?(Z|[-+]\\d{2}:?\\d{2})?$`);function A(e){let t=e.trim().toUpperCase(),n=t.match(k);if(!n)throw RangeError(`Failed to parse '${e}'. Should be yyyy[[-|/]MM[[-|/]DD]][(T| )HH:mm[:ss[(.|:)SSS]]][Z|(+|-)hh:mm]`);let r=n[4]!==void 0,[i,a,o,s]=[+n[1],+n[2]||1,+n[3]||1,n[8]],c=new Date(t);if(!h(c))throw RangeError(`Failed to parse '${e}' by Date. Should be yyyy[[-|/]MM[[-|/]DD]][(T| )HH:mm[:ss[(.|:)SSS]]][Z|(+|-)hh:mm]`);return s?this.nativeDate=c:r?this.set({year:i,month:a,day:o,hour:+n[4]||0,minute:+n[5]||0,second:+n[6]||0,millisecond:+n[7]?.padStart(3,`0`)||0}):this.set({year:i,month:a,day:o}),this}var j=(e,t)=>String(e).padStart(t,`0`);w.prototype.toString=function(){if(this[C].localtime){let e=this[C].nativeDate,t=-e.getTimezoneOffset(),n=Math.abs(t);return`${j(e.getFullYear(),4)}-${j(e.getMonth()+1,2)}-${j(e.getDate(),2)}T${j(e.getHours(),2)}:${j(e.getMinutes(),2)}:${j(e.getSeconds(),2)}.${j(e.getMilliseconds(),3)}${t>=0?`+`:`-`}${j(Math.trunc(n/60),2)}:${j(n%60,2)}`}return this[C].nativeDate.toISOString()},w.prototype.valueOf=function(){return this[C].nativeDate.valueOf()},w.prototype.clone=function(...e){return new w(this,...e)},w.prototype.context=function(e){return d(e)?this.clone(e):{localtime:this[C].localtime,disambiguation:this[C].disambiguation}},w.prototype.nativeDate=function(){return new Date(this[C].nativeDate.getTime())},w.prototype.offset=function(){return this[C].localtime?-this[C].nativeDate.getTimezoneOffset():0},w.prototype.valid=function(){return this[C].valid()},w.prototype.toObject=function(){return{year:this.year(),month:this.month(),day:this.day(),hour:this.hour(),minute:this.minute(),second:this.second(),millisecond:this.millisecond()}},w.prototype.toArray=function(){return[this.year(),this.month(),this.day(),this.hour(),this.minute(),this.second(),this.millisecond()]},w.prototype.toDate=function(...e){return new F(this.clone(...e))};for(let[e,t,n]of[[`year`,`FullYear`,0],[`month`,`Month`,1],[`day`,`Date`,0],[`hour`,`Hours`,0],[`minute`,`Minutes`,0],[`second`,`Seconds`,0],[`millisecond`,`Milliseconds`,0]])w.prototype[e]=function(r){return d(r)?this.clone({[e]:r}):this[C].getNative(t)+n};w.prototype.dayOfWeek=function(){return 1+(this[C].getNative(`Day`)-1+7)%7},w.prototype.dayOfYear=function(){let e=this.toDate();return 1+e-e.startOfYear()},w.prototype.weekOfYear=function(){let e=this.toDate(),t=e.day(e.day()-e.dayOfWeek()+S),n=t.startOfYear(),r=n.dayOfWeek()===S?n:n.day(1+(S-n.dayOfWeek()+7)%7);return 1+Math.ceil((t-r)/7)},w.prototype.yearOfWeek=function(){let e=this.toDate();return e.day(e.day()-e.dayOfWeek()+S).year()},w.prototype.isLeapYear=function(){let e=this.year();return e%4==0&&(e%100!=0||e%400==0)},w.prototype.hasOffsetChangeInYear=function(){if(!this[C].localtime)return!1;let e=this.offset();return[3,6,9,12].map(e=>this.month(e).offset()).some(t=>t!==e)},w.prototype.isInDst=function(){if(!this[C].localtime)return!1;let e=this.offset(),t=!1,n=!1;for(let r=1;r<=5;r+=2)if(this.month(-r).offset()<e&&(t=!0),this.month(r).offset()<e&&(n=!0),t&&n)return!0;return!1},w.prototype.hasOffsetChangeInDay=function(){return this[C].localtime?this.minutesInDay()!==n:!1},w.prototype.minutesInDay=function(){if(!this[C].localtime)return n;let e=this.context({disambiguation:`later`}).startOfDay(),t=e.plus({day:1}).startOfDay();return e.day()===t.day()?n:(t-e)/s},w.prototype.daysInMonth=function(){let e=[31,28,31,30,31,30,31,31,30,31,30,31],t=this.month();return e[t-1]+(this.isLeapYear()&&t===2?1:0)},w.prototype.daysInYear=function(){return this.isLeapYear()?366:365},w.prototype.weeksInYear=function(){let e=this.toDate({month:12,day:31}),t=e.minus({year:1});return e.dayOfWeek()===S||t.dayOfWeek()===x?53:52};for(let[e,t]of[[`Year`,{month:1,day:1,hour:0,minute:0,second:0,millisecond:0}],[`Month`,{day:1,hour:0,minute:0,second:0,millisecond:0}],[`Hour`,{minute:0,second:0,millisecond:0}],[`Minute`,{second:0,millisecond:0}],[`Second`,{millisecond:0}]])w.prototype[`startOf${e}`]=function(){return this.clone(t)};w.prototype.startOfDay=function(){let e=this.clone({disambiguation:`later`},{hour:0,minute:0,second:0,millisecond:0}).valueOf();return this.clone(e)};function M(e){Object.assign(e,{isSame(e){return+this==+e},isBefore(e){return this<e},isAfter(e){return this>e},isSameOrBefore(e){return this<=e},isSameOrAfter(e){return this>=e},isBetween(e,t){return e<=this&&this<=t||t<=this&&this<=e}})}M(w.prototype),w.prototype.plus=function(...e){return N.call(this,1,...e)},w.prototype.minus=function(...e){return N.call(this,-1,...e)};function N(e,...t){let n=t[0],r=t[1];if(Number.isFinite(n)&&!Number.isFinite(r))return this.clone(this.valueOf()+n);let i=null;if(m(n)){if(!g(n))throw RangeError(`Missing time field (year, minute, day, hour, minute, second or millisecond)`);i=n}else if(Number.isFinite(n)||Array.isArray(n)){let e=t.flat(),n=e.filter(e=>Number.isSafeInteger(e));if(n.length!==e.length)throw RangeError(`Should be safe integers`);if(n.length>7)throw RangeError(`Too many numbers`);i={year:n[0],month:n[1],day:n[2],hour:n[3],minute:n[4],second:n[5],millisecond:n[6]}}else throw TypeError();let a=this.nativeDate(),o=this[C].localtime?``:`UTC`;if(l(i,`year`)||l(i,`month`)){let t=this.year()+e*(i.year??0),n=this.month()+e*(i.month??0),r=new Date(a.getTime());r[`set${o}FullYear`](t,n,0);let s=r[`get${o}Date`]();s<this.day()?a[`set${o}FullYear`](t,r[`get${o}Month`](),s):a[`set${o}FullYear`](t,n-1)}l(i,`day`)&&a[`set${o}Date`](a[`get${o}Date`]()+e*i.day);for(let[t,n]of[[`hour`,`Hours`],[`minute`,`Minutes`],[`second`,`Seconds`],[`millisecond`,`Milliseconds`]])!l(i,t)||i[t]==null||a[`setUTC${n}`](a[`getUTC${n}`]()+e*i[t]);return this.clone(a)}var P=Symbol();function F(...e){if(!new.target)return new F(...e);let t={datetime:null};this[P]=t;let n=null;e[0]instanceof F?n=e.shift().toDatetime():e[0]instanceof w&&(n=e.shift());let r=e[0],i=e[1];return Number.isFinite(r)&&!Number.isFinite(i)&&(e[0]=Math.floor(r)*c),n=n?n.clone(...e):_(...e),t.datetime=n.startOfDay(),this}F.prototype.toString=function(){return this[P].datetime.toString().substring(0,10)},F.prototype.valueOf=function(){return this[P].datetime/c},F.prototype.valid=function(){return this[P].datetime.valid()},F.prototype.clone=function(...e){return new F(this,...e)},F.prototype.toDatetime=function(){return _(this[P].datetime.toArray())},F.prototype.toObject=function(){return{year:this.year(),month:this.month(),day:this.day()}},F.prototype.toArray=function(){return[this.year(),this.month(),this.day()]};for(let e of[`Year`,`Month`])F.prototype[`startOf${e}`]=function(){return new F(this[P].datetime[`startOf${e}`]())};for(let e of[`year`,`month`,`day`])F.prototype[e]=function(t){return d(t)?new F(this[P].datetime[e](t)):this[P].datetime[e]()};for(let e of[`dayOfWeek`,`dayOfYear`,`weekOfYear`,`yearOfWeek`,`isLeapYear`,`daysInMonth`,`daysInYear`,`weeksInYear`])F.prototype[e]=function(){return this[P].datetime[e]()};for(let e of[`minutesInDay`,`hasOffsetChangeInYear`,`hasOffsetChangeInDay`])F.prototype[e]=function(){return _({disambiguation:`later`},this[P].datetime.toArray().slice(0,3))[e]()};F.prototype.endOfYear=function(){return this.clone({month:12,day:31})},F.prototype.endOfMonth=function(){return this.clone({day:this.daysInMonth()})},M(F.prototype),F.prototype.plus=function(...e){return I.call(this,1,...e)},F.prototype.minus=function(...e){return I.call(this,-1,...e)};function I(e,...t){let n=t[0],r=t[1],i=this[P].datetime;if(Number.isFinite(n)&&!Number.isFinite(r))return i.plus({day:e*n}).toDate();let a=null;if(m(n)&&g(n))a={year:e*(n.year??0),month:e*(n.month??0),day:e*(n.day??0)};else if(Number.isFinite(n)){if(t.length>3)throw RangeError(`Too many arguments`);a={year:e*n,month:e*r,day:e*arg2}}else if(Array.isArray(n)){if(n.length>3)throw RangeError(`Too many elements`);a={year:e*n[0],month:e*n[1],day:e*n[2]}}else throw TypeError();return i.plus(a).toDate()}return e.qrono=_,e})({});
1
+ (function(){var e=new Date(1915,0,1,12,0,0,0),t=1440;t*7;var n=3600,r=n*24,i=r*7,a=1e3,o=60*a;n*a;var s=r*a;i*a;function c(e,...t){return t.flat().some(e.hasOwnProperty,e)}function l(e){return Object.entries(e).filter(([,e])=>!d(e)).map(([e])=>e)}function u(e){return e!==void 0}function d(e){return e instanceof Function}function f(e){return typeof e==`string`||e instanceof String}function p(e){return typeof e==`object`&&!!e&&e.constructor===Object}function m(e){return!Number.isNaN(e.getTime())}function h(e){return c(e,[`year`,`month`,`day`,`hour`,`minute`,`second`,`millisecond`])}var g=C;C.date=P;var _={localtime:!1,disambiguation:`compatible`};C.context=function(e){if(u(e)){for(let t of l(_))c(e,t)&&(_[t]=e[t]);return this}return{..._}};var v=1,y=2,b=3,x=4;Object.assign(C,{monday:v,tuesday:y,wednesday:b,thursday:x,friday:5,saturday:6,sunday:7});var S=Symbol();function C(...e){if(!new.target)return new C(...e);let t={nativeDate:null,localtime:!1,disambiguation:`compatible`,set:D,parse:k,valid:w,context:T,getNative:E};if(this[S]=t,t.context(_),e[0]instanceof C){let n=e.shift();t.nativeDate=n.nativeDate(),t.context(n.context())}p(e[0])&&!h(e[0])&&t.context(e.shift());let n=e[0],r=e[1];if(n==null)t.nativeDate??=new Date;else if(n instanceof Date)t.nativeDate=new Date(n.getTime());else if(f(n))t.parse(n);else if(p(n)){if(!h(n))throw RangeError(`Missing time field (year, minute, day, hour, minute, second or millisecond)`);t.set(n)}else if(Number.isFinite(n)&&!Number.isFinite(r))t.nativeDate=new Date(n);else if(Number.isFinite(n)||Array.isArray(n)){let n=e.flat(),r=n.filter(e=>Number.isSafeInteger(e));if(r.length!==n.length)throw RangeError(`Should be safe integers`);if(r.length>7)throw RangeError(`Too many numbers`);t.set({year:r[0],month:r[1],day:r[2],hour:r[3],minute:r[4],second:r[5],millisecond:r[6]})}else throw TypeError(`Invalid argument ${e}`);return this}function w(){return m(this.nativeDate)}function T(e){return e?(`localtime`in e&&(this.localtime=e.localtime),`disambiguation`in e&&(this.disambiguation=e.disambiguation),this):{localtime:this.localtime,disambiguation:this.disambiguation}}function E(e){return this.nativeDate[`get${this.localtime?``:`UTC`}${e}`]()}function D(t){let n={...t};if(n.month=n.month&&n.month-1,!this.localtime){let e=this.nativeDate??new Date(0),t=new Date(0);return t.setUTCFullYear(n.year??e.getUTCFullYear(),n.month??e.getUTCMonth(),n.day??e.getUTCDate()),t.setUTCHours(n.hour??e.getUTCHours(),n.minute??e.getUTCMinutes(),n.second??e.getUTCSeconds(),n.millisecond??e.getUTCMilliseconds()),this.nativeDate=t,this}let r=!c(t,`hour`,`minute`,`second`,`millisecond`),i=r?`later`:this.disambiguation,a=this.nativeDate??new Date(0,0),o=new Date(e.getTime()),s={year:n.year??a.getFullYear(),month:n.month??a.getMonth(),day:n.day??a.getDate(),hour:n.hour??(r?0:a.getHours()),minute:n.minute??(r?0:a.getMinutes()),second:n.second??(r?0:a.getSeconds()),millisecond:n.millisecond??(r?0:a.getMilliseconds())};o.setFullYear(s.year,s.month,s.day),o.setHours(s.hour,s.minute,s.second,s.millisecond);let l=o.getTime(),u=new Date(l);u.setDate(o.getDate()+1);let d=new Date(l);d.setDate(o.getDate()-1);let f=u.getTimezoneOffset()-d.getTimezoneOffset();if(i===`compatible`||f===0)return this.nativeDate=o,this;let p=s.year*1e8+s.month*1e6+s.day*1e4+s.hour*100+s.minute<o.getFullYear()*1e8+o.getMonth()*1e6+o.getDate()*1e4+o.getHours()*100+o.getMinutes(),m=new Date(new Date(l).setUTCMinutes(o.getUTCMinutes()+f)),h=m.getHours()===o.getHours()&&m.getMinutes()===o.getMinutes();if(!p&&!h)return this.nativeDate=o,this;if(i===`reject`)throw RangeError(`Requested local time ${s} is ambiguous.`);return this.nativeDate=i===`later`?o:m,this}var O=RegExp(`^(\\d{4})(?:[-/]?([0-2]?\\d)(?:[-/]?([0-3]?\\d))?)?(?:[T\\s]([0-2]?\\d)(?::([0-5]?\\d)?(?::([0-6]?\\d)?(?:[.:](\\d{1,3})?\\d*)?)?)?)?(Z|[-+]\\d{2}:?\\d{2})?$`);function k(e){let t=e.trim().toUpperCase(),n=t.match(O);if(!n)throw RangeError(`Failed to parse '${e}'. Should be yyyy[[-|/]MM[[-|/]DD]][(T| )HH:mm[:ss[(.|:)SSS]]][Z|(+|-)hh:mm]`);let r=n[4]!==void 0,[i,a,o,s]=[+n[1],+n[2]||1,+n[3]||1,n[8]],c=new Date(t);if(!m(c))throw RangeError(`Failed to parse '${e}' by Date. Should be yyyy[[-|/]MM[[-|/]DD]][(T| )HH:mm[:ss[(.|:)SSS]]][Z|(+|-)hh:mm]`);return s?this.nativeDate=c:r?this.set({year:i,month:a,day:o,hour:+n[4]||0,minute:+n[5]||0,second:+n[6]||0,millisecond:+n[7]?.padStart(3,`0`)||0}):this.set({year:i,month:a,day:o}),this}var A=(e,t)=>String(e).padStart(t,`0`);C.prototype.toString=function(){if(this[S].localtime){let e=this[S].nativeDate,t=-e.getTimezoneOffset(),n=Math.abs(t);return`${A(e.getFullYear(),4)}-${A(e.getMonth()+1,2)}-${A(e.getDate(),2)}T${A(e.getHours(),2)}:${A(e.getMinutes(),2)}:${A(e.getSeconds(),2)}.${A(e.getMilliseconds(),3)}${t>=0?`+`:`-`}${A(Math.trunc(n/60),2)}:${A(n%60,2)}`}return this[S].nativeDate.toISOString()},C.prototype.valueOf=function(){return this[S].nativeDate.valueOf()},C.prototype.clone=function(...e){return new C(this,...e)},C.prototype.context=function(e){return u(e)?this.clone(e):{localtime:this[S].localtime,disambiguation:this[S].disambiguation}},C.prototype.nativeDate=function(){return new Date(this[S].nativeDate.getTime())},C.prototype.offset=function(){return this[S].localtime?-this[S].nativeDate.getTimezoneOffset():0},C.prototype.valid=function(){return this[S].valid()},C.prototype.toObject=function(){return{year:this.year(),month:this.month(),day:this.day(),hour:this.hour(),minute:this.minute(),second:this.second(),millisecond:this.millisecond()}},C.prototype.toArray=function(){return[this.year(),this.month(),this.day(),this.hour(),this.minute(),this.second(),this.millisecond()]},C.prototype.toDate=function(...e){return new P(this.clone(...e))};for(let[e,t,n]of[[`year`,`FullYear`,0],[`month`,`Month`,1],[`day`,`Date`,0],[`hour`,`Hours`,0],[`minute`,`Minutes`,0],[`second`,`Seconds`,0],[`millisecond`,`Milliseconds`,0]])C.prototype[e]=function(r){return u(r)?this.clone({[e]:r}):this[S].getNative(t)+n};C.prototype.dayOfWeek=function(){return 1+(this[S].getNative(`Day`)-1+7)%7},C.prototype.dayOfYear=function(){let e=this.toDate();return 1+e-e.startOfYear()},C.prototype.weekOfYear=function(){let e=this.toDate(),t=e.day(e.day()-e.dayOfWeek()+x),n=t.startOfYear(),r=n.dayOfWeek()===x?n:n.day(1+(x-n.dayOfWeek()+7)%7);return 1+Math.ceil((t-r)/7)},C.prototype.yearOfWeek=function(){let e=this.toDate();return e.day(e.day()-e.dayOfWeek()+x).year()},C.prototype.isLeapYear=function(){let e=this.year();return e%4==0&&(e%100!=0||e%400==0)},C.prototype.hasOffsetChangeInYear=function(){if(!this[S].localtime)return!1;let e=this.offset();return[3,6,9,12].map(e=>this.month(e).offset()).some(t=>t!==e)},C.prototype.isInDst=function(){if(!this[S].localtime)return!1;let e=this.offset(),t=!1,n=!1;for(let r=1;r<=5;r+=2)if(this.month(-r).offset()<e&&(t=!0),this.month(r).offset()<e&&(n=!0),t&&n)return!0;return!1},C.prototype.hasOffsetChangeInDay=function(){return this[S].localtime?this.minutesInDay()!==t:!1},C.prototype.minutesInDay=function(){if(!this[S].localtime)return t;let e=this.context({disambiguation:`later`}).startOfDay(),n=e.plus({day:1}).startOfDay();return e.day()===n.day()?t:(n-e)/o},C.prototype.daysInMonth=function(){let e=[31,28,31,30,31,30,31,31,30,31,30,31],t=this.month();return e[t-1]+(this.isLeapYear()&&t===2?1:0)},C.prototype.daysInYear=function(){return this.isLeapYear()?366:365},C.prototype.weeksInYear=function(){let e=this.toDate({month:12,day:31}),t=e.minus({year:1});return e.dayOfWeek()===x||t.dayOfWeek()===b?53:52};for(let[e,t]of[[`Year`,{month:1,day:1,hour:0,minute:0,second:0,millisecond:0}],[`Month`,{day:1,hour:0,minute:0,second:0,millisecond:0}],[`Hour`,{minute:0,second:0,millisecond:0}],[`Minute`,{second:0,millisecond:0}],[`Second`,{millisecond:0}]])C.prototype[`startOf${e}`]=function(){return this.clone(t)};C.prototype.startOfDay=function(){let e=this.clone({disambiguation:`later`},{hour:0,minute:0,second:0,millisecond:0}).valueOf();return this.clone(e)};function j(e){Object.assign(e,{isSame(e){return+this==+e},isBefore(e){return this<e},isAfter(e){return this>e},isSameOrBefore(e){return this<=e},isSameOrAfter(e){return this>=e},isBetween(e,t){return e<=this&&this<=t||t<=this&&this<=e}})}j(C.prototype),C.prototype.plus=function(...e){return M.call(this,1,...e)},C.prototype.minus=function(...e){return M.call(this,-1,...e)};function M(e,...t){let n=t[0],r=t[1];if(Number.isFinite(n)&&!Number.isFinite(r))return this.clone(this.valueOf()+n);let i=null;if(p(n)){if(!h(n))throw RangeError(`Missing time field (year, minute, day, hour, minute, second or millisecond)`);i=n}else if(Number.isFinite(n)||Array.isArray(n)){let e=t.flat(),n=e.filter(e=>Number.isSafeInteger(e));if(n.length!==e.length)throw RangeError(`Should be safe integers`);if(n.length>7)throw RangeError(`Too many numbers`);i={year:n[0],month:n[1],day:n[2],hour:n[3],minute:n[4],second:n[5],millisecond:n[6]}}else throw TypeError();let a=this.nativeDate(),o=this[S].localtime?``:`UTC`;if(c(i,`year`)||c(i,`month`)){let t=this.year()+e*(i.year??0),n=this.month()+e*(i.month??0),r=new Date(a.getTime());r[`set${o}FullYear`](t,n,0);let s=r[`get${o}Date`]();s<this.day()?a[`set${o}FullYear`](t,r[`get${o}Month`](),s):a[`set${o}FullYear`](t,n-1)}c(i,`day`)&&a[`set${o}Date`](a[`get${o}Date`]()+e*i.day);for(let[t,n]of[[`hour`,`Hours`],[`minute`,`Minutes`],[`second`,`Seconds`],[`millisecond`,`Milliseconds`]])!c(i,t)||i[t]==null||a[`setUTC${n}`](a[`getUTC${n}`]()+e*i[t]);return this.clone(a)}var N=Symbol();function P(...e){if(!new.target)return new P(...e);let t={datetime:null};this[N]=t;let n=null;e[0]instanceof P?n=e.shift().toDatetime():e[0]instanceof C&&(n=e.shift());let r=e[0],i=e[1];return Number.isFinite(r)&&!Number.isFinite(i)&&(e[0]=Math.floor(r)*s),n=n?n.clone(...e):g(...e),t.datetime=n.startOfDay(),this}P.prototype.toString=function(){return this[N].datetime.toString().substring(0,10)},P.prototype.valueOf=function(){return this[N].datetime/s},P.prototype.valid=function(){return this[N].datetime.valid()},P.prototype.clone=function(...e){return new P(this,...e)},P.prototype.toDatetime=function(){return g(this[N].datetime.toArray())},P.prototype.toObject=function(){return{year:this.year(),month:this.month(),day:this.day()}},P.prototype.toArray=function(){return[this.year(),this.month(),this.day()]};for(let e of[`Year`,`Month`])P.prototype[`startOf${e}`]=function(){return new P(this[N].datetime[`startOf${e}`]())};for(let e of[`year`,`month`,`day`])P.prototype[e]=function(t){return u(t)?new P(this[N].datetime[e](t)):this[N].datetime[e]()};for(let e of[`dayOfWeek`,`dayOfYear`,`weekOfYear`,`yearOfWeek`,`isLeapYear`,`daysInMonth`,`daysInYear`,`weeksInYear`])P.prototype[e]=function(){return this[N].datetime[e]()};for(let e of[`minutesInDay`,`hasOffsetChangeInYear`,`hasOffsetChangeInDay`])P.prototype[e]=function(){return g({disambiguation:`later`},this[N].datetime.toArray().slice(0,3))[e]()};P.prototype.endOfYear=function(){return this.clone({month:12,day:31})},P.prototype.endOfMonth=function(){return this.clone({day:this.daysInMonth()})},j(P.prototype),P.prototype.plus=function(...e){return F.call(this,1,...e)},P.prototype.minus=function(...e){return F.call(this,-1,...e)};function F(e,...t){let n=t[0],r=t[1],i=this[N].datetime;if(Number.isFinite(n)&&!Number.isFinite(r))return i.plus({day:e*n}).toDate();let a=null;if(p(n)&&h(n))a={year:e*(n.year??0),month:e*(n.month??0),day:e*(n.day??0)};else if(Number.isFinite(n)){if(t.length>3)throw RangeError(`Too many arguments`);a={year:e*n,month:e*r,day:e*arg2}}else if(Array.isArray(n)){if(n.length>3)throw RangeError(`Too many elements`);a={year:e*n[0],month:e*n[1],day:e*n[2]}}else throw TypeError();return i.plus(a).toDate()}globalThis.qrono=g})();
2
2
  //# sourceMappingURL=qrono.min.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"qrono.min.js","names":[],"sources":["../src/helpers.js","../src/qrono.js"],"sourcesContent":["export const epoch = new Date(0)\n\n/**\n * When creating or updating a local time, both `Date.setFullYear` and `Date.setHours` are used.\n * Noon is used as the initial reference point to avoid the time after `setFullYear`\n * from falling into an ambiguous DST period. Historically, DST transitions in all countries\n * have been scheduled around midnight, and it should be the same in the future.\n * The reason for selecting 1915 as the initial value is as follows.\n * Since DST was first established in 1916, the initial value should be set to a year prior to that.\n * If a year too far in the past is chosen, it may correspond to a period when time zones were not yet\n * precisely defined in some regions, which could result in unexpected timezone offsets.\n */\nexport const initialSafeDate = new Date(1915, 0, 1, 12, 0, 0, 0)\n\nexport const daysPerWeek = 7\nexport const hoursPerDay = 24\nexport const hoursPerWeek = hoursPerDay * daysPerWeek\nexport const minutesPerHour = 60\nexport const minutesPerDay = minutesPerHour * hoursPerDay\nexport const minutesPerWeek = minutesPerDay * daysPerWeek\nexport const secondsPerMinute = 60\nexport const secondsPerHour = secondsPerMinute * minutesPerHour\nexport const secondsPerDay = secondsPerHour * hoursPerDay\nexport const secondsPerWeek = secondsPerDay * daysPerWeek\nexport const millisecondsPerSecond = 1000\nexport const millisecondsPerMinute = secondsPerMinute * millisecondsPerSecond\nexport const millisecondsPerHour = secondsPerHour * millisecondsPerSecond\nexport const millisecondsPerDay = secondsPerDay * millisecondsPerSecond\nexport const millisecondsPerWeek = secondsPerWeek * millisecondsPerSecond\n\nexport function has(object, ...keys) {\n return keys.flat().some(object.hasOwnProperty, object)\n}\n\nexport function fields(object) {\n return Object.entries(object)\n .filter(([, value]) => !isFunction(value))\n .map(([key]) => key)\n}\n\nexport function given(arg) {\n return arg !== undefined\n}\n\nexport function isFunction(a) {\n return a instanceof Function\n}\n\nexport function isString(a) {\n return typeof a === 'string' || a instanceof String\n}\n\nexport function isObject(a) {\n return a !== null && typeof a === 'object' && a.constructor === Object\n}\n\nexport function isValidDate(date) {\n return !Number.isNaN(date.getTime())\n}\n\nexport function hasDateField(object) {\n return has(object, ['year', 'month', 'day'])\n}\n\nexport function hasTimeField(object) {\n return has(object, ['hour', 'minute', 'second', 'millisecond'])\n}\n\nexport function hasDatetimeField(object) {\n return has(object, [\n 'year',\n 'month',\n 'day',\n 'hour',\n 'minute',\n 'second',\n 'millisecond',\n ])\n}\n","/* @ts-self-types=\"../types/qrono.d.ts\" */\nimport {\n has,\n given,\n fields,\n isObject,\n isString,\n isValidDate,\n hasDatetimeField,\n initialSafeDate,\n daysPerWeek,\n minutesPerDay,\n minutesPerHour,\n millisecondsPerMinute,\n millisecondsPerDay,\n} from './helpers.js'\n\n// -----------------------------------------------------------------------------\n// Exports\n// -----------------------------------------------------------------------------\nconst qrono = Qrono\n\nexport { qrono }\n\n// -----------------------------------------------------------------------------\n// Static\n// -----------------------------------------------------------------------------\nQrono.date = QronoDate\n\n// NOTE Must be flat object for shallow cloning.\nconst defaultContext = {\n localtime: false,\n disambiguation: 'compatible',\n}\n\nQrono.context = function (context) {\n if (given(context)) {\n for (const key of fields(defaultContext)) {\n if (!has(context, key)) {\n continue\n }\n defaultContext[key] = context[key]\n }\n return this\n }\n return { ...defaultContext }\n}\n\nconst monday = 1\nconst tuesday = 2\nconst wednesday = 3\nconst thursday = 4\nconst friday = 5\nconst saturday = 6\nconst sunday = 7\n\nObject.assign(Qrono, {\n monday,\n tuesday,\n wednesday,\n thursday,\n friday,\n saturday,\n sunday,\n})\n\n// -----------------------------------------------------------------------------\n// Constructor\n// -----------------------------------------------------------------------------\nconst internal = Symbol()\n\nfunction Qrono(...args) {\n if (!new.target) {\n return new Qrono(...args)\n }\n const self = {\n // properties\n nativeDate: null,\n localtime: false,\n disambiguation: 'compatible',\n // methods\n set,\n parse,\n valid,\n context,\n getNative,\n }\n this[internal] = self\n\n // Construction\n self.context(defaultContext)\n if (args[0] instanceof Qrono) {\n const source = args.shift()\n self.nativeDate = source.nativeDate()\n self.context(source.context())\n }\n if (isObject(args[0]) && !hasDatetimeField(args[0])) {\n self.context(args.shift())\n }\n const first = args[0]\n const second = args[1]\n if (first == null) {\n self.nativeDate ??= new Date()\n } else if (first instanceof Date) {\n self.nativeDate = new Date(first.getTime())\n } else if (isString(first)) {\n self.parse(first)\n } else if (isObject(first)) {\n if (!hasDatetimeField(first)) {\n throw RangeError(\n 'Missing time field' +\n ' (year, minute, day, hour, minute, second or millisecond)'\n )\n }\n self.set(first)\n } else if (Number.isFinite(first) && !Number.isFinite(second)) {\n self.nativeDate = new Date(first)\n } else if (Number.isFinite(first) || Array.isArray(first)) {\n const flat = args.flat()\n const values = flat.filter(v => Number.isSafeInteger(v))\n if (values.length !== flat.length) {\n throw RangeError('Should be safe integers')\n }\n if (values.length > 7) {\n throw RangeError('Too many numbers')\n }\n self.set({\n year: values[0],\n month: values[1],\n day: values[2],\n hour: values[3],\n minute: values[4],\n second: values[5],\n millisecond: values[6],\n })\n } else {\n throw TypeError(`Invalid argument ${args}`)\n }\n return this\n}\n\n// -----------------------------------------------------------------------------\n// Private methods\n// -----------------------------------------------------------------------------\nfunction valid() {\n return isValidDate(this.nativeDate)\n}\n\nfunction context(arg) {\n if (!arg) {\n return { localtime: this.localtime, disambiguation: this.disambiguation }\n }\n if ('localtime' in arg) this.localtime = arg.localtime\n if ('disambiguation' in arg) this.disambiguation = arg.disambiguation\n return this\n}\n\nfunction getNative(name) {\n return this.nativeDate[`get${this.localtime ? '' : 'UTC'}${name}`]()\n}\n\nfunction set(values) {\n const args = { ...values }\n args.month = args.month && args.month - 1\n if (!this.localtime) {\n const baseDate = this.nativeDate ?? new Date(0)\n const newDate = new Date(0)\n newDate.setUTCFullYear(\n args.year ?? baseDate.getUTCFullYear(),\n args.month ?? baseDate.getUTCMonth(),\n args.day ?? baseDate.getUTCDate()\n )\n newDate.setUTCHours(\n args.hour ?? baseDate.getUTCHours(),\n args.minute ?? baseDate.getUTCMinutes(),\n args.second ?? baseDate.getUTCSeconds(),\n args.millisecond ?? baseDate.getUTCMilliseconds()\n )\n this.nativeDate = newDate\n return this\n }\n const dateOnly = !has(values, 'hour', 'minute', 'second', 'millisecond')\n const disambig = dateOnly ? 'later' : this.disambiguation\n const baseDate = this.nativeDate ?? new Date(0, 0) // 1900-01-01T00:00:00.000Z\n const newDate = new Date(initialSafeDate.getTime())\n const requested = {\n year: args.year ?? baseDate.getFullYear(),\n month: args.month ?? baseDate.getMonth(),\n day: args.day ?? baseDate.getDate(),\n hour: args.hour ?? (dateOnly ? 0 : baseDate.getHours()),\n minute: args.minute ?? (dateOnly ? 0 : baseDate.getMinutes()),\n second: args.second ?? (dateOnly ? 0 : baseDate.getSeconds()),\n millisecond:\n args.millisecond ?? (dateOnly ? 0 : baseDate.getMilliseconds()),\n }\n newDate.setFullYear(requested.year, requested.month, requested.day)\n newDate.setHours(\n requested.hour,\n requested.minute,\n requested.second,\n requested.millisecond\n )\n // Compute the offset-delta between the day before and after.\n const numeric = newDate.getTime()\n const nextDay = new Date(numeric)\n nextDay.setDate(newDate.getDate() + 1)\n const prevDay = new Date(numeric)\n prevDay.setDate(newDate.getDate() - 1)\n const adjust = nextDay.getTimezoneOffset() - prevDay.getTimezoneOffset()\n // No DST transition nearby — nothing to resolve.\n if (disambig === 'compatible' || adjust === 0) {\n this.nativeDate = newDate\n return this\n }\n // Detect whether the constructed Date landed in a DST gap (missing time).\n // In a gap, JavaScript silently shifts the time forward.\n const isGap =\n requested.year * 1e8 +\n requested.month * 1e6 +\n requested.day * 1e4 +\n requested.hour * 1e2 +\n requested.minute <\n newDate.getFullYear() * 1e8 +\n newDate.getMonth() * 1e6 +\n newDate.getDate() * 1e4 +\n newDate.getHours() * 1e2 +\n newDate.getMinutes()\n // Compute the standard-time candidate.\n // Verify the candidate actually preserves the original local fields.\n // If it doesn't, the time isn't truly in an overlap.\n const adjustedUTC = new Date(\n new Date(numeric).setUTCMinutes(newDate.getUTCMinutes() + adjust)\n )\n const isOverlap =\n adjustedUTC.getHours() === newDate.getHours() &&\n adjustedUTC.getMinutes() === newDate.getMinutes()\n if (!isGap && !isOverlap) {\n this.nativeDate = newDate\n return this\n }\n if (disambig === 'reject') {\n throw new RangeError(`Requested local time ${requested} is ambiguous.`)\n }\n this.nativeDate = disambig === 'later' ? newDate : adjustedUTC\n return this\n}\n\nconst parsePattern = new RegExp(\n // yyyy[[-|/]MM[[-|/]DD]]\n '^(\\\\d{4})(?:[-/]?([0-2]?\\\\d)(?:[-/]?([0-3]?\\\\d))?)?' +\n // [(T| )HH[:]mm[[:]ss[(.|:)SSS]]]\n '(?:[T\\\\s]([0-2]?\\\\d)(?::([0-5]?\\\\d)?(?::([0-6]?\\\\d)?(?:[.:](\\\\d{1,3})?\\\\d*)?)?)?)?' +\n // [Z|(+|-)hh:mm]\n '(Z|[-+]\\\\d{2}:?\\\\d{2})?$'\n)\n\nfunction parse(str) {\n const text = str.trim().toUpperCase()\n const values = text.match(parsePattern)\n if (!values) {\n throw RangeError(\n `Failed to parse '${str}'.` +\n ' Should be yyyy[[-|/]MM[[-|/]DD]][(T| )HH:mm[:ss[(.|:)SSS]]][Z|(+|-)hh:mm]'\n )\n }\n const hasTime = values[4] !== undefined\n const [year, month, day, offset] = [\n +values[1],\n +values[2] || 1,\n +values[3] || 1,\n values[8],\n ]\n const native = new Date(text)\n if (!isValidDate(native)) {\n throw RangeError(\n `Failed to parse '${str}' by Date.` +\n ' Should be yyyy[[-|/]MM[[-|/]DD]][(T| )HH:mm[:ss[(.|:)SSS]]][Z|(+|-)hh:mm]'\n )\n }\n if (offset) {\n this.nativeDate = native\n } else if (hasTime) {\n this.set({\n year,\n month,\n day,\n hour: +values[4] || 0,\n minute: +values[5] || 0,\n second: +values[6] || 0,\n millisecond: +values[7]?.padStart(3, '0') || 0,\n })\n } else {\n this.set({ year, month, day })\n }\n return this\n}\n\n// -----------------------------------------------------------------------------\n// Public methods\n// -----------------------------------------------------------------------------\nconst pad0 = (v, n) => String(v).padStart(n, '0')\n\n// Basic\nQrono.prototype.toString = function () {\n if (this[internal].localtime) {\n const t = this[internal].nativeDate\n const offset = -t.getTimezoneOffset()\n const offsetAbs = Math.abs(offset)\n return (\n `${pad0(t.getFullYear(), 4)}-` +\n `${pad0(t.getMonth() + 1, 2)}-` +\n `${pad0(t.getDate(), 2)}T` +\n `${pad0(t.getHours(), 2)}:` +\n `${pad0(t.getMinutes(), 2)}:` +\n `${pad0(t.getSeconds(), 2)}.` +\n `${pad0(t.getMilliseconds(), 3)}` +\n `${offset >= 0 ? '+' : '-'}` +\n `${pad0(Math.trunc(offsetAbs / minutesPerHour), 2)}:` +\n `${pad0(offsetAbs % minutesPerHour, 2)}`\n )\n }\n return this[internal].nativeDate.toISOString()\n}\n\nQrono.prototype.valueOf = function () {\n return this[internal].nativeDate.valueOf()\n}\n\nQrono.prototype.clone = function (...args) {\n return new Qrono(this, ...args)\n}\n\nQrono.prototype.context = function (context) {\n return given(context)\n ? this.clone(context)\n : {\n localtime: this[internal].localtime,\n disambiguation: this[internal].disambiguation,\n }\n}\n\nQrono.prototype.nativeDate = function () {\n return new Date(this[internal].nativeDate.getTime())\n}\n\nQrono.prototype.offset = function () {\n return this[internal].localtime\n ? -this[internal].nativeDate.getTimezoneOffset()\n : 0\n}\n\nQrono.prototype.valid = function () {\n return this[internal].valid()\n}\n\n// Transform\nQrono.prototype.toObject = function () {\n return {\n year: this.year(),\n month: this.month(),\n day: this.day(),\n hour: this.hour(),\n minute: this.minute(),\n second: this.second(),\n millisecond: this.millisecond(),\n }\n}\n\nQrono.prototype.toArray = function () {\n return [\n this.year(),\n this.month(),\n this.day(),\n this.hour(),\n this.minute(),\n this.second(),\n this.millisecond(),\n ]\n}\n\nQrono.prototype.toDate = function (...args) {\n return new QronoDate(this.clone(...args))\n}\n\n// Accessor\nfor (const [field, native, base] of [\n ['year', 'FullYear', 0],\n ['month', 'Month', 1],\n ['day', 'Date', 0],\n ['hour', 'Hours', 0],\n ['minute', 'Minutes', 0],\n ['second', 'Seconds', 0],\n ['millisecond', 'Milliseconds', 0],\n]) {\n Qrono.prototype[field] = function (value) {\n return given(value)\n ? this.clone({ [field]: value })\n : this[internal].getNative(native) + base\n }\n}\n\n// Getter\nQrono.prototype.dayOfWeek = function () {\n return 1 + ((this[internal].getNative('Day') - 1 + daysPerWeek) % daysPerWeek)\n}\n\nQrono.prototype.dayOfYear = function () {\n const date = this.toDate()\n return 1 + date - date.startOfYear()\n}\n\nQrono.prototype.weekOfYear = function () {\n const date = this.toDate()\n const theThursday = date.day(date.day() - date.dayOfWeek() + thursday)\n const startOfYear = theThursday.startOfYear()\n const firstThursday =\n startOfYear.dayOfWeek() === thursday\n ? startOfYear\n : startOfYear.day(\n 1 + ((thursday - startOfYear.dayOfWeek() + daysPerWeek) % daysPerWeek)\n )\n return 1 + Math.ceil((theThursday - firstThursday) / daysPerWeek)\n}\n\nQrono.prototype.yearOfWeek = function () {\n const date = this.toDate()\n return date.day(date.day() - date.dayOfWeek() + thursday).year()\n}\n\nQrono.prototype.isLeapYear = function () {\n const year = this.year()\n return year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0)\n}\n\nQrono.prototype.hasOffsetChangeInYear = function () {\n if (!this[internal].localtime) {\n return false\n }\n const currentOffset = this.offset()\n return [3, 6, 9, 12]\n .map(month => this.month(month).offset())\n .some(offset => offset !== currentOffset)\n}\n\nQrono.prototype.isInDst = function () {\n if (!this[internal].localtime) return false\n const offset = this.offset()\n let past = false,\n future = false\n for (let i = 1; i <= 5; i += 2) {\n if (this.month(-i).offset() < offset) past = true\n if (this.month(i).offset() < offset) future = true\n if (past && future) return true\n }\n return false\n}\n\nQrono.prototype.hasOffsetChangeInDay = function () {\n if (!this[internal].localtime) {\n return false\n }\n return this.minutesInDay() !== minutesPerDay\n}\n\nQrono.prototype.minutesInDay = function () {\n if (!this[internal].localtime) {\n return minutesPerDay\n }\n const startOfDay = this.context({ disambiguation: 'later' }).startOfDay()\n const nextDay = startOfDay.plus({ day: 1 }).startOfDay()\n if (startOfDay.day() === nextDay.day()) {\n return minutesPerDay\n }\n return (nextDay - startOfDay) / millisecondsPerMinute\n}\n\nQrono.prototype.daysInMonth = function () {\n const days = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]\n const month = this.month()\n return days[month - 1] + (this.isLeapYear() && month === 2 ? 1 : 0)\n}\n\nQrono.prototype.daysInYear = function () {\n return this.isLeapYear() ? 366 : 365\n}\n\nQrono.prototype.weeksInYear = function () {\n const endOfYear = this.toDate({ month: 12, day: 31 })\n const endOfLastYear = endOfYear.minus({ year: 1 })\n if (\n endOfYear.dayOfWeek() === thursday ||\n endOfLastYear.dayOfWeek() === wednesday\n ) {\n return 53\n }\n return 52\n}\n\nfor (const [name, cloneArg] of [\n ['Year', { month: 1, day: 1, hour: 0, minute: 0, second: 0, millisecond: 0 }],\n ['Month', { day: 1, hour: 0, minute: 0, second: 0, millisecond: 0 }],\n ['Hour', { minute: 0, second: 0, millisecond: 0 }],\n ['Minute', { second: 0, millisecond: 0 }],\n ['Second', { millisecond: 0 }],\n]) {\n Qrono.prototype[`startOf${name}`] = function () {\n return this.clone(cloneArg)\n }\n}\n\nQrono.prototype.startOfDay = function () {\n const timestamp = this.clone(\n { disambiguation: 'later' },\n { hour: 0, minute: 0, second: 0, millisecond: 0 }\n ).valueOf()\n return this.clone(timestamp)\n}\n\nfunction implementComparison(prototype) {\n Object.assign(prototype, {\n isSame(another) {\n return +this === +another\n },\n isBefore(another) {\n return this < another\n },\n isAfter(another) {\n return this > another\n },\n isSameOrBefore(another) {\n return this <= another\n },\n isSameOrAfter(another) {\n return this >= another\n },\n isBetween(a, b) {\n return (a <= this && this <= b) || (b <= this && this <= a)\n },\n })\n}\n\nimplementComparison(Qrono.prototype)\n\n// Calculation\nQrono.prototype.plus = function (...args) {\n return plus.call(this, 1, ...args)\n}\n\nQrono.prototype.minus = function (...args) {\n return plus.call(this, -1, ...args)\n}\n\nfunction plus(sign, ...args) {\n const arg0 = args[0]\n const arg1 = args[1]\n if (Number.isFinite(arg0) && !Number.isFinite(arg1)) {\n return this.clone(this.valueOf() + arg0)\n }\n let timeFields = null\n if (isObject(arg0)) {\n if (!hasDatetimeField(arg0)) {\n throw RangeError(\n 'Missing time field' +\n ' (year, minute, day, hour, minute, second or millisecond)'\n )\n }\n timeFields = arg0\n } else if (Number.isFinite(arg0) || Array.isArray(arg0)) {\n const flat = args.flat()\n const values = flat.filter(v => Number.isSafeInteger(v))\n if (values.length !== flat.length) {\n throw RangeError('Should be safe integers')\n }\n if (values.length > 7) {\n throw RangeError('Too many numbers')\n }\n timeFields = {\n year: values[0],\n month: values[1],\n day: values[2],\n hour: values[3],\n minute: values[4],\n second: values[5],\n millisecond: values[6],\n }\n } else {\n throw TypeError()\n }\n const date = this.nativeDate()\n const utc = this[internal].localtime ? '' : 'UTC'\n if (has(timeFields, 'year') || has(timeFields, 'month')) {\n const year = this.year() + sign * (timeFields.year ?? 0)\n const month = this.month() + sign * (timeFields.month ?? 0)\n const endOfMonth = new Date(date.getTime())\n endOfMonth[`set${utc}FullYear`](year, month, 0)\n const lastDay = endOfMonth[`get${utc}Date`]()\n if (lastDay < this.day()) {\n date[`set${utc}FullYear`](year, endOfMonth[`get${utc}Month`](), lastDay)\n } else {\n date[`set${utc}FullYear`](year, month - 1)\n }\n }\n if (has(timeFields, 'day')) {\n date[`set${utc}Date`](date[`get${utc}Date`]() + sign * timeFields.day)\n }\n for (const [key, nativeKey] of [\n ['hour', 'Hours'],\n ['minute', 'Minutes'],\n ['second', 'Seconds'],\n ['millisecond', 'Milliseconds'],\n ]) {\n if (!has(timeFields, key) || timeFields[key] == null) {\n continue\n }\n date[`setUTC${nativeKey}`](\n date[`getUTC${nativeKey}`]() + sign * timeFields[key]\n )\n }\n return this.clone(date)\n}\n\n// -----------------------------------------------------------------------------\n// QronoDate Class\n// -----------------------------------------------------------------------------\nconst internalDate = Symbol()\n\nfunction QronoDate(...args) {\n if (!new.target) {\n return new QronoDate(...args)\n }\n const self = { datetime: null }\n this[internalDate] = self\n let source = null\n if (args[0] instanceof QronoDate) {\n source = args.shift().toDatetime()\n } else if (args[0] instanceof Qrono) {\n source = args.shift()\n }\n const first = args[0]\n const second = args[1]\n if (Number.isFinite(first) && !Number.isFinite(second)) {\n args[0] = Math.floor(first) * millisecondsPerDay\n }\n if (source) {\n source = source.clone(...args)\n } else {\n source = qrono(...args)\n }\n self.datetime = source.startOfDay()\n return this\n}\n\nQronoDate.prototype.toString = function () {\n return this[internalDate].datetime.toString().substring(0, 10)\n}\n\nQronoDate.prototype.valueOf = function () {\n return this[internalDate].datetime / millisecondsPerDay\n}\n\nQronoDate.prototype.valid = function () {\n return this[internalDate].datetime.valid()\n}\n\nQronoDate.prototype.clone = function (...args) {\n return new QronoDate(this, ...args)\n}\n\nQronoDate.prototype.toDatetime = function () {\n return qrono(this[internalDate].datetime.toArray())\n}\n\nQronoDate.prototype.toObject = function () {\n return {\n year: this.year(),\n month: this.month(),\n day: this.day(),\n }\n}\n\nQronoDate.prototype.toArray = function () {\n return [this.year(), this.month(), this.day()]\n}\n\nfor (const name of ['Year', 'Month']) {\n QronoDate.prototype[`startOf${name}`] = function () {\n return new QronoDate(this[internalDate].datetime[`startOf${name}`]())\n }\n}\n\nfor (const field of ['year', 'month', 'day']) {\n QronoDate.prototype[field] = function (value) {\n if (given(value)) {\n return new QronoDate(this[internalDate].datetime[field](value))\n }\n return this[internalDate].datetime[field]()\n }\n}\nfor (const method of [\n 'dayOfWeek',\n 'dayOfYear',\n 'weekOfYear',\n 'yearOfWeek',\n 'isLeapYear',\n 'daysInMonth',\n 'daysInYear',\n 'weeksInYear',\n]) {\n QronoDate.prototype[method] = function () {\n return this[internalDate].datetime[method]()\n }\n}\nfor (const method of [\n 'minutesInDay',\n 'hasOffsetChangeInYear',\n 'hasOffsetChangeInDay',\n]) {\n QronoDate.prototype[method] = function () {\n return qrono(\n { disambiguation: 'later' },\n this[internalDate].datetime.toArray().slice(0, 3)\n )[method]()\n }\n}\n\nQronoDate.prototype.endOfYear = function () {\n return this.clone({ month: 12, day: 31 })\n}\n\nQronoDate.prototype.endOfMonth = function () {\n return this.clone({ day: this.daysInMonth() })\n}\n\nimplementComparison(QronoDate.prototype)\n\nQronoDate.prototype.plus = function (...args) {\n return plusDate.call(this, 1, ...args)\n}\n\nQronoDate.prototype.minus = function (...args) {\n return plusDate.call(this, -1, ...args)\n}\n\nfunction plusDate(sign, ...args) {\n const arg0 = args[0]\n const arg1 = args[1]\n const datetime = this[internalDate].datetime\n if (Number.isFinite(arg0) && !Number.isFinite(arg1)) {\n return datetime.plus({ day: sign * arg0 }).toDate()\n }\n let timeFields = null\n if (isObject(arg0) && hasDatetimeField(arg0)) {\n timeFields = {\n year: sign * (arg0.year ?? 0),\n month: sign * (arg0.month ?? 0),\n day: sign * (arg0.day ?? 0),\n }\n } else if (Number.isFinite(arg0)) {\n if (args.length > 3) {\n throw RangeError('Too many arguments')\n }\n timeFields = { year: sign * arg0, month: sign * arg1, day: sign * arg2 }\n } else if (Array.isArray(arg0)) {\n if (arg0.length > 3) {\n throw RangeError('Too many elements')\n }\n timeFields = {\n year: sign * arg0[0],\n month: sign * arg0[1],\n day: sign * arg0[2],\n }\n } else {\n throw TypeError()\n }\n return datetime.plus(timeFields).toDate()\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"qrono.min.js","names":[],"sources":["../src/helpers.js","../src/qrono.js","../src/qrono.global.js"],"sourcesContent":["export const epoch = new Date(0)\n\n/**\n * When creating or updating a local time, both `Date.setFullYear` and `Date.setHours` are used.\n * Noon is used as the initial reference point to avoid the time after `setFullYear`\n * from falling into an ambiguous DST period. Historically, DST transitions in all countries\n * have been scheduled around midnight, and it should be the same in the future.\n * The reason for selecting 1915 as the initial value is as follows.\n * Since DST was first established in 1916, the initial value should be set to a year prior to that.\n * If a year too far in the past is chosen, it may correspond to a period when time zones were not yet\n * precisely defined in some regions, which could result in unexpected timezone offsets.\n */\nexport const initialSafeDate = new Date(1915, 0, 1, 12, 0, 0, 0)\n\nexport const daysPerWeek = 7\nexport const hoursPerDay = 24\nexport const hoursPerWeek = hoursPerDay * daysPerWeek\nexport const minutesPerHour = 60\nexport const minutesPerDay = minutesPerHour * hoursPerDay\nexport const minutesPerWeek = minutesPerDay * daysPerWeek\nexport const secondsPerMinute = 60\nexport const secondsPerHour = secondsPerMinute * minutesPerHour\nexport const secondsPerDay = secondsPerHour * hoursPerDay\nexport const secondsPerWeek = secondsPerDay * daysPerWeek\nexport const millisecondsPerSecond = 1000\nexport const millisecondsPerMinute = secondsPerMinute * millisecondsPerSecond\nexport const millisecondsPerHour = secondsPerHour * millisecondsPerSecond\nexport const millisecondsPerDay = secondsPerDay * millisecondsPerSecond\nexport const millisecondsPerWeek = secondsPerWeek * millisecondsPerSecond\n\nexport function has(object, ...keys) {\n return keys.flat().some(object.hasOwnProperty, object)\n}\n\nexport function fields(object) {\n return Object.entries(object)\n .filter(([, value]) => !isFunction(value))\n .map(([key]) => key)\n}\n\nexport function given(arg) {\n return arg !== undefined\n}\n\nexport function isFunction(a) {\n return a instanceof Function\n}\n\nexport function isString(a) {\n return typeof a === 'string' || a instanceof String\n}\n\nexport function isObject(a) {\n return a !== null && typeof a === 'object' && a.constructor === Object\n}\n\nexport function isValidDate(date) {\n return !Number.isNaN(date.getTime())\n}\n\nexport function hasDateField(object) {\n return has(object, ['year', 'month', 'day'])\n}\n\nexport function hasTimeField(object) {\n return has(object, ['hour', 'minute', 'second', 'millisecond'])\n}\n\nexport function hasDatetimeField(object) {\n return has(object, [\n 'year',\n 'month',\n 'day',\n 'hour',\n 'minute',\n 'second',\n 'millisecond',\n ])\n}\n","/* @ts-self-types=\"../types/qrono.d.ts\" */\nimport {\n has,\n given,\n fields,\n isObject,\n isString,\n isValidDate,\n hasDatetimeField,\n initialSafeDate,\n daysPerWeek,\n minutesPerDay,\n minutesPerHour,\n millisecondsPerMinute,\n millisecondsPerDay,\n} from './helpers.js'\n\n// -----------------------------------------------------------------------------\n// Exports\n// -----------------------------------------------------------------------------\nconst qrono = Qrono\n\nexport { qrono }\n\n// -----------------------------------------------------------------------------\n// Static\n// -----------------------------------------------------------------------------\nQrono.date = QronoDate\n\n// NOTE Must be flat object for shallow cloning.\nconst defaultContext = {\n localtime: false,\n disambiguation: 'compatible',\n}\n\nQrono.context = function (context) {\n if (given(context)) {\n for (const key of fields(defaultContext)) {\n if (!has(context, key)) {\n continue\n }\n defaultContext[key] = context[key]\n }\n return this\n }\n return { ...defaultContext }\n}\n\nconst monday = 1\nconst tuesday = 2\nconst wednesday = 3\nconst thursday = 4\nconst friday = 5\nconst saturday = 6\nconst sunday = 7\n\nObject.assign(Qrono, {\n monday,\n tuesday,\n wednesday,\n thursday,\n friday,\n saturday,\n sunday,\n})\n\n// -----------------------------------------------------------------------------\n// Constructor\n// -----------------------------------------------------------------------------\nconst internal = Symbol()\n\nfunction Qrono(...args) {\n if (!new.target) {\n return new Qrono(...args)\n }\n const self = {\n // properties\n nativeDate: null,\n localtime: false,\n disambiguation: 'compatible',\n // methods\n set,\n parse,\n valid,\n context,\n getNative,\n }\n this[internal] = self\n\n // Construction\n self.context(defaultContext)\n if (args[0] instanceof Qrono) {\n const source = args.shift()\n self.nativeDate = source.nativeDate()\n self.context(source.context())\n }\n if (isObject(args[0]) && !hasDatetimeField(args[0])) {\n self.context(args.shift())\n }\n const first = args[0]\n const second = args[1]\n if (first == null) {\n self.nativeDate ??= new Date()\n } else if (first instanceof Date) {\n self.nativeDate = new Date(first.getTime())\n } else if (isString(first)) {\n self.parse(first)\n } else if (isObject(first)) {\n if (!hasDatetimeField(first)) {\n throw RangeError(\n 'Missing time field' +\n ' (year, minute, day, hour, minute, second or millisecond)'\n )\n }\n self.set(first)\n } else if (Number.isFinite(first) && !Number.isFinite(second)) {\n self.nativeDate = new Date(first)\n } else if (Number.isFinite(first) || Array.isArray(first)) {\n const flat = args.flat()\n const values = flat.filter(v => Number.isSafeInteger(v))\n if (values.length !== flat.length) {\n throw RangeError('Should be safe integers')\n }\n if (values.length > 7) {\n throw RangeError('Too many numbers')\n }\n self.set({\n year: values[0],\n month: values[1],\n day: values[2],\n hour: values[3],\n minute: values[4],\n second: values[5],\n millisecond: values[6],\n })\n } else {\n throw TypeError(`Invalid argument ${args}`)\n }\n return this\n}\n\n// -----------------------------------------------------------------------------\n// Private methods\n// -----------------------------------------------------------------------------\nfunction valid() {\n return isValidDate(this.nativeDate)\n}\n\nfunction context(arg) {\n if (!arg) {\n return { localtime: this.localtime, disambiguation: this.disambiguation }\n }\n if ('localtime' in arg) this.localtime = arg.localtime\n if ('disambiguation' in arg) this.disambiguation = arg.disambiguation\n return this\n}\n\nfunction getNative(name) {\n return this.nativeDate[`get${this.localtime ? '' : 'UTC'}${name}`]()\n}\n\nfunction set(values) {\n const args = { ...values }\n args.month = args.month && args.month - 1\n if (!this.localtime) {\n const baseDate = this.nativeDate ?? new Date(0)\n const newDate = new Date(0)\n newDate.setUTCFullYear(\n args.year ?? baseDate.getUTCFullYear(),\n args.month ?? baseDate.getUTCMonth(),\n args.day ?? baseDate.getUTCDate()\n )\n newDate.setUTCHours(\n args.hour ?? baseDate.getUTCHours(),\n args.minute ?? baseDate.getUTCMinutes(),\n args.second ?? baseDate.getUTCSeconds(),\n args.millisecond ?? baseDate.getUTCMilliseconds()\n )\n this.nativeDate = newDate\n return this\n }\n const dateOnly = !has(values, 'hour', 'minute', 'second', 'millisecond')\n const disambig = dateOnly ? 'later' : this.disambiguation\n const baseDate = this.nativeDate ?? new Date(0, 0) // 1900-01-01T00:00:00.000Z\n const newDate = new Date(initialSafeDate.getTime())\n const requested = {\n year: args.year ?? baseDate.getFullYear(),\n month: args.month ?? baseDate.getMonth(),\n day: args.day ?? baseDate.getDate(),\n hour: args.hour ?? (dateOnly ? 0 : baseDate.getHours()),\n minute: args.minute ?? (dateOnly ? 0 : baseDate.getMinutes()),\n second: args.second ?? (dateOnly ? 0 : baseDate.getSeconds()),\n millisecond:\n args.millisecond ?? (dateOnly ? 0 : baseDate.getMilliseconds()),\n }\n newDate.setFullYear(requested.year, requested.month, requested.day)\n newDate.setHours(\n requested.hour,\n requested.minute,\n requested.second,\n requested.millisecond\n )\n // Compute the offset-delta between the day before and after.\n const numeric = newDate.getTime()\n const nextDay = new Date(numeric)\n nextDay.setDate(newDate.getDate() + 1)\n const prevDay = new Date(numeric)\n prevDay.setDate(newDate.getDate() - 1)\n const adjust = nextDay.getTimezoneOffset() - prevDay.getTimezoneOffset()\n // No DST transition nearby — nothing to resolve.\n if (disambig === 'compatible' || adjust === 0) {\n this.nativeDate = newDate\n return this\n }\n // Detect whether the constructed Date landed in a DST gap (missing time).\n // In a gap, JavaScript silently shifts the time forward.\n const isGap =\n requested.year * 1e8 +\n requested.month * 1e6 +\n requested.day * 1e4 +\n requested.hour * 1e2 +\n requested.minute <\n newDate.getFullYear() * 1e8 +\n newDate.getMonth() * 1e6 +\n newDate.getDate() * 1e4 +\n newDate.getHours() * 1e2 +\n newDate.getMinutes()\n // Compute the standard-time candidate.\n // Verify the candidate actually preserves the original local fields.\n // If it doesn't, the time isn't truly in an overlap.\n const adjustedUTC = new Date(\n new Date(numeric).setUTCMinutes(newDate.getUTCMinutes() + adjust)\n )\n const isOverlap =\n adjustedUTC.getHours() === newDate.getHours() &&\n adjustedUTC.getMinutes() === newDate.getMinutes()\n if (!isGap && !isOverlap) {\n this.nativeDate = newDate\n return this\n }\n if (disambig === 'reject') {\n throw new RangeError(`Requested local time ${requested} is ambiguous.`)\n }\n this.nativeDate = disambig === 'later' ? newDate : adjustedUTC\n return this\n}\n\nconst parsePattern = new RegExp(\n // yyyy[[-|/]MM[[-|/]DD]]\n '^(\\\\d{4})(?:[-/]?([0-2]?\\\\d)(?:[-/]?([0-3]?\\\\d))?)?' +\n // [(T| )HH[:]mm[[:]ss[(.|:)SSS]]]\n '(?:[T\\\\s]([0-2]?\\\\d)(?::([0-5]?\\\\d)?(?::([0-6]?\\\\d)?(?:[.:](\\\\d{1,3})?\\\\d*)?)?)?)?' +\n // [Z|(+|-)hh:mm]\n '(Z|[-+]\\\\d{2}:?\\\\d{2})?$'\n)\n\nfunction parse(str) {\n const text = str.trim().toUpperCase()\n const values = text.match(parsePattern)\n if (!values) {\n throw RangeError(\n `Failed to parse '${str}'.` +\n ' Should be yyyy[[-|/]MM[[-|/]DD]][(T| )HH:mm[:ss[(.|:)SSS]]][Z|(+|-)hh:mm]'\n )\n }\n const hasTime = values[4] !== undefined\n const [year, month, day, offset] = [\n +values[1],\n +values[2] || 1,\n +values[3] || 1,\n values[8],\n ]\n const native = new Date(text)\n if (!isValidDate(native)) {\n throw RangeError(\n `Failed to parse '${str}' by Date.` +\n ' Should be yyyy[[-|/]MM[[-|/]DD]][(T| )HH:mm[:ss[(.|:)SSS]]][Z|(+|-)hh:mm]'\n )\n }\n if (offset) {\n this.nativeDate = native\n } else if (hasTime) {\n this.set({\n year,\n month,\n day,\n hour: +values[4] || 0,\n minute: +values[5] || 0,\n second: +values[6] || 0,\n millisecond: +values[7]?.padStart(3, '0') || 0,\n })\n } else {\n this.set({ year, month, day })\n }\n return this\n}\n\n// -----------------------------------------------------------------------------\n// Public methods\n// -----------------------------------------------------------------------------\nconst pad0 = (v, n) => String(v).padStart(n, '0')\n\n// Basic\nQrono.prototype.toString = function () {\n if (this[internal].localtime) {\n const t = this[internal].nativeDate\n const offset = -t.getTimezoneOffset()\n const offsetAbs = Math.abs(offset)\n return (\n `${pad0(t.getFullYear(), 4)}-` +\n `${pad0(t.getMonth() + 1, 2)}-` +\n `${pad0(t.getDate(), 2)}T` +\n `${pad0(t.getHours(), 2)}:` +\n `${pad0(t.getMinutes(), 2)}:` +\n `${pad0(t.getSeconds(), 2)}.` +\n `${pad0(t.getMilliseconds(), 3)}` +\n `${offset >= 0 ? '+' : '-'}` +\n `${pad0(Math.trunc(offsetAbs / minutesPerHour), 2)}:` +\n `${pad0(offsetAbs % minutesPerHour, 2)}`\n )\n }\n return this[internal].nativeDate.toISOString()\n}\n\nQrono.prototype.valueOf = function () {\n return this[internal].nativeDate.valueOf()\n}\n\nQrono.prototype.clone = function (...args) {\n return new Qrono(this, ...args)\n}\n\nQrono.prototype.context = function (context) {\n return given(context)\n ? this.clone(context)\n : {\n localtime: this[internal].localtime,\n disambiguation: this[internal].disambiguation,\n }\n}\n\nQrono.prototype.nativeDate = function () {\n return new Date(this[internal].nativeDate.getTime())\n}\n\nQrono.prototype.offset = function () {\n return this[internal].localtime\n ? -this[internal].nativeDate.getTimezoneOffset()\n : 0\n}\n\nQrono.prototype.valid = function () {\n return this[internal].valid()\n}\n\n// Transform\nQrono.prototype.toObject = function () {\n return {\n year: this.year(),\n month: this.month(),\n day: this.day(),\n hour: this.hour(),\n minute: this.minute(),\n second: this.second(),\n millisecond: this.millisecond(),\n }\n}\n\nQrono.prototype.toArray = function () {\n return [\n this.year(),\n this.month(),\n this.day(),\n this.hour(),\n this.minute(),\n this.second(),\n this.millisecond(),\n ]\n}\n\nQrono.prototype.toDate = function (...args) {\n return new QronoDate(this.clone(...args))\n}\n\n// Accessor\nfor (const [field, native, base] of [\n ['year', 'FullYear', 0],\n ['month', 'Month', 1],\n ['day', 'Date', 0],\n ['hour', 'Hours', 0],\n ['minute', 'Minutes', 0],\n ['second', 'Seconds', 0],\n ['millisecond', 'Milliseconds', 0],\n]) {\n Qrono.prototype[field] = function (value) {\n return given(value)\n ? this.clone({ [field]: value })\n : this[internal].getNative(native) + base\n }\n}\n\n// Getter\nQrono.prototype.dayOfWeek = function () {\n return 1 + ((this[internal].getNative('Day') - 1 + daysPerWeek) % daysPerWeek)\n}\n\nQrono.prototype.dayOfYear = function () {\n const date = this.toDate()\n return 1 + date - date.startOfYear()\n}\n\nQrono.prototype.weekOfYear = function () {\n const date = this.toDate()\n const theThursday = date.day(date.day() - date.dayOfWeek() + thursday)\n const startOfYear = theThursday.startOfYear()\n const firstThursday =\n startOfYear.dayOfWeek() === thursday\n ? startOfYear\n : startOfYear.day(\n 1 + ((thursday - startOfYear.dayOfWeek() + daysPerWeek) % daysPerWeek)\n )\n return 1 + Math.ceil((theThursday - firstThursday) / daysPerWeek)\n}\n\nQrono.prototype.yearOfWeek = function () {\n const date = this.toDate()\n return date.day(date.day() - date.dayOfWeek() + thursday).year()\n}\n\nQrono.prototype.isLeapYear = function () {\n const year = this.year()\n return year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0)\n}\n\nQrono.prototype.hasOffsetChangeInYear = function () {\n if (!this[internal].localtime) {\n return false\n }\n const currentOffset = this.offset()\n return [3, 6, 9, 12]\n .map(month => this.month(month).offset())\n .some(offset => offset !== currentOffset)\n}\n\nQrono.prototype.isInDst = function () {\n if (!this[internal].localtime) return false\n const offset = this.offset()\n let past = false,\n future = false\n for (let i = 1; i <= 5; i += 2) {\n if (this.month(-i).offset() < offset) past = true\n if (this.month(i).offset() < offset) future = true\n if (past && future) return true\n }\n return false\n}\n\nQrono.prototype.hasOffsetChangeInDay = function () {\n if (!this[internal].localtime) {\n return false\n }\n return this.minutesInDay() !== minutesPerDay\n}\n\nQrono.prototype.minutesInDay = function () {\n if (!this[internal].localtime) {\n return minutesPerDay\n }\n const startOfDay = this.context({ disambiguation: 'later' }).startOfDay()\n const nextDay = startOfDay.plus({ day: 1 }).startOfDay()\n if (startOfDay.day() === nextDay.day()) {\n return minutesPerDay\n }\n return (nextDay - startOfDay) / millisecondsPerMinute\n}\n\nQrono.prototype.daysInMonth = function () {\n const days = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]\n const month = this.month()\n return days[month - 1] + (this.isLeapYear() && month === 2 ? 1 : 0)\n}\n\nQrono.prototype.daysInYear = function () {\n return this.isLeapYear() ? 366 : 365\n}\n\nQrono.prototype.weeksInYear = function () {\n const endOfYear = this.toDate({ month: 12, day: 31 })\n const endOfLastYear = endOfYear.minus({ year: 1 })\n if (\n endOfYear.dayOfWeek() === thursday ||\n endOfLastYear.dayOfWeek() === wednesday\n ) {\n return 53\n }\n return 52\n}\n\nfor (const [name, cloneArg] of [\n ['Year', { month: 1, day: 1, hour: 0, minute: 0, second: 0, millisecond: 0 }],\n ['Month', { day: 1, hour: 0, minute: 0, second: 0, millisecond: 0 }],\n ['Hour', { minute: 0, second: 0, millisecond: 0 }],\n ['Minute', { second: 0, millisecond: 0 }],\n ['Second', { millisecond: 0 }],\n]) {\n Qrono.prototype[`startOf${name}`] = function () {\n return this.clone(cloneArg)\n }\n}\n\nQrono.prototype.startOfDay = function () {\n const timestamp = this.clone(\n { disambiguation: 'later' },\n { hour: 0, minute: 0, second: 0, millisecond: 0 }\n ).valueOf()\n return this.clone(timestamp)\n}\n\nfunction implementComparison(prototype) {\n Object.assign(prototype, {\n isSame(another) {\n return +this === +another\n },\n isBefore(another) {\n return this < another\n },\n isAfter(another) {\n return this > another\n },\n isSameOrBefore(another) {\n return this <= another\n },\n isSameOrAfter(another) {\n return this >= another\n },\n isBetween(a, b) {\n return (a <= this && this <= b) || (b <= this && this <= a)\n },\n })\n}\n\nimplementComparison(Qrono.prototype)\n\n// Calculation\nQrono.prototype.plus = function (...args) {\n return plus.call(this, 1, ...args)\n}\n\nQrono.prototype.minus = function (...args) {\n return plus.call(this, -1, ...args)\n}\n\nfunction plus(sign, ...args) {\n const arg0 = args[0]\n const arg1 = args[1]\n if (Number.isFinite(arg0) && !Number.isFinite(arg1)) {\n return this.clone(this.valueOf() + arg0)\n }\n let timeFields = null\n if (isObject(arg0)) {\n if (!hasDatetimeField(arg0)) {\n throw RangeError(\n 'Missing time field' +\n ' (year, minute, day, hour, minute, second or millisecond)'\n )\n }\n timeFields = arg0\n } else if (Number.isFinite(arg0) || Array.isArray(arg0)) {\n const flat = args.flat()\n const values = flat.filter(v => Number.isSafeInteger(v))\n if (values.length !== flat.length) {\n throw RangeError('Should be safe integers')\n }\n if (values.length > 7) {\n throw RangeError('Too many numbers')\n }\n timeFields = {\n year: values[0],\n month: values[1],\n day: values[2],\n hour: values[3],\n minute: values[4],\n second: values[5],\n millisecond: values[6],\n }\n } else {\n throw TypeError()\n }\n const date = this.nativeDate()\n const utc = this[internal].localtime ? '' : 'UTC'\n if (has(timeFields, 'year') || has(timeFields, 'month')) {\n const year = this.year() + sign * (timeFields.year ?? 0)\n const month = this.month() + sign * (timeFields.month ?? 0)\n const endOfMonth = new Date(date.getTime())\n endOfMonth[`set${utc}FullYear`](year, month, 0)\n const lastDay = endOfMonth[`get${utc}Date`]()\n if (lastDay < this.day()) {\n date[`set${utc}FullYear`](year, endOfMonth[`get${utc}Month`](), lastDay)\n } else {\n date[`set${utc}FullYear`](year, month - 1)\n }\n }\n if (has(timeFields, 'day')) {\n date[`set${utc}Date`](date[`get${utc}Date`]() + sign * timeFields.day)\n }\n for (const [key, nativeKey] of [\n ['hour', 'Hours'],\n ['minute', 'Minutes'],\n ['second', 'Seconds'],\n ['millisecond', 'Milliseconds'],\n ]) {\n if (!has(timeFields, key) || timeFields[key] == null) {\n continue\n }\n date[`setUTC${nativeKey}`](\n date[`getUTC${nativeKey}`]() + sign * timeFields[key]\n )\n }\n return this.clone(date)\n}\n\n// -----------------------------------------------------------------------------\n// QronoDate Class\n// -----------------------------------------------------------------------------\nconst internalDate = Symbol()\n\nfunction QronoDate(...args) {\n if (!new.target) {\n return new QronoDate(...args)\n }\n const self = { datetime: null }\n this[internalDate] = self\n let source = null\n if (args[0] instanceof QronoDate) {\n source = args.shift().toDatetime()\n } else if (args[0] instanceof Qrono) {\n source = args.shift()\n }\n const first = args[0]\n const second = args[1]\n if (Number.isFinite(first) && !Number.isFinite(second)) {\n args[0] = Math.floor(first) * millisecondsPerDay\n }\n if (source) {\n source = source.clone(...args)\n } else {\n source = qrono(...args)\n }\n self.datetime = source.startOfDay()\n return this\n}\n\nQronoDate.prototype.toString = function () {\n return this[internalDate].datetime.toString().substring(0, 10)\n}\n\nQronoDate.prototype.valueOf = function () {\n return this[internalDate].datetime / millisecondsPerDay\n}\n\nQronoDate.prototype.valid = function () {\n return this[internalDate].datetime.valid()\n}\n\nQronoDate.prototype.clone = function (...args) {\n return new QronoDate(this, ...args)\n}\n\nQronoDate.prototype.toDatetime = function () {\n return qrono(this[internalDate].datetime.toArray())\n}\n\nQronoDate.prototype.toObject = function () {\n return {\n year: this.year(),\n month: this.month(),\n day: this.day(),\n }\n}\n\nQronoDate.prototype.toArray = function () {\n return [this.year(), this.month(), this.day()]\n}\n\nfor (const name of ['Year', 'Month']) {\n QronoDate.prototype[`startOf${name}`] = function () {\n return new QronoDate(this[internalDate].datetime[`startOf${name}`]())\n }\n}\n\nfor (const field of ['year', 'month', 'day']) {\n QronoDate.prototype[field] = function (value) {\n if (given(value)) {\n return new QronoDate(this[internalDate].datetime[field](value))\n }\n return this[internalDate].datetime[field]()\n }\n}\nfor (const method of [\n 'dayOfWeek',\n 'dayOfYear',\n 'weekOfYear',\n 'yearOfWeek',\n 'isLeapYear',\n 'daysInMonth',\n 'daysInYear',\n 'weeksInYear',\n]) {\n QronoDate.prototype[method] = function () {\n return this[internalDate].datetime[method]()\n }\n}\nfor (const method of [\n 'minutesInDay',\n 'hasOffsetChangeInYear',\n 'hasOffsetChangeInDay',\n]) {\n QronoDate.prototype[method] = function () {\n return qrono(\n { disambiguation: 'later' },\n this[internalDate].datetime.toArray().slice(0, 3)\n )[method]()\n }\n}\n\nQronoDate.prototype.endOfYear = function () {\n return this.clone({ month: 12, day: 31 })\n}\n\nQronoDate.prototype.endOfMonth = function () {\n return this.clone({ day: this.daysInMonth() })\n}\n\nimplementComparison(QronoDate.prototype)\n\nQronoDate.prototype.plus = function (...args) {\n return plusDate.call(this, 1, ...args)\n}\n\nQronoDate.prototype.minus = function (...args) {\n return plusDate.call(this, -1, ...args)\n}\n\nfunction plusDate(sign, ...args) {\n const arg0 = args[0]\n const arg1 = args[1]\n const datetime = this[internalDate].datetime\n if (Number.isFinite(arg0) && !Number.isFinite(arg1)) {\n return datetime.plus({ day: sign * arg0 }).toDate()\n }\n let timeFields = null\n if (isObject(arg0) && hasDatetimeField(arg0)) {\n timeFields = {\n year: sign * (arg0.year ?? 0),\n month: sign * (arg0.month ?? 0),\n day: sign * (arg0.day ?? 0),\n }\n } else if (Number.isFinite(arg0)) {\n if (args.length > 3) {\n throw RangeError('Too many arguments')\n }\n timeFields = { year: sign * arg0, month: sign * arg1, day: sign * arg2 }\n } else if (Array.isArray(arg0)) {\n if (arg0.length > 3) {\n throw RangeError('Too many elements')\n }\n timeFields = {\n year: sign * arg0[0],\n month: sign * arg0[1],\n day: sign * arg0[2],\n }\n } else {\n throw TypeError()\n }\n return datetime.plus(timeFields).toDate()\n}\n","import { qrono } from './qrono.js'\n\nglobalThis.qrono = qrono\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "qrono",
3
- "version": "1.5.0",
4
- "description": "A 4kB JavaScript date library with 100+ APIs and strict DST guarantees.",
3
+ "version": "1.5.1",
4
+ "description": "A tiny JavaScript date library with 100+ APIs and strict DST guarantees.",
5
5
  "license": "MIT",
6
6
  "keywords": [
7
7
  "qrono",
@@ -37,11 +37,12 @@
37
37
  "scripts": {
38
38
  "prepare": "husky && npm run check:fix && npm run build",
39
39
  "postpublish": "jsr publish --no-provenance",
40
- "lint": "biome lint ./src ./tests",
40
+ "lint": "biome lint ./src ./tests ./scripts",
41
41
  "format": "biome format --write .",
42
- "check": "biome check ./src ./tests",
43
- "check:fix": "biome check ./src ./tests --write",
42
+ "check": "biome check ./src ./tests ./scripts",
43
+ "check:fix": "biome check ./src ./tests ./scripts --write",
44
44
  "build": "vite build --config vite.lib.config.js && vite build --config vite.iife.config.js",
45
+ "postbuild": "node scripts/make-badges.js",
45
46
  "test": "vitest run",
46
47
  "test:watch": "vitest",
47
48
  "test:ui": "vitest --ui",
@@ -0,0 +1,3 @@
1
+ import { qrono } from './qrono.js'
2
+
3
+ globalThis.qrono = qrono