zeed 1.3.0 → 1.4.0
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/AGENTS.md +50 -211
- package/README.md +16 -0
- package/dist/_experiments/bitcask.cjs +243 -1
- package/dist/_experiments/bitcask.cjs.map +1 -1
- package/dist/_experiments/bitcask.mjs +230 -1
- package/dist/_experiments/bitcask.mjs.map +1 -1
- package/dist/bin-BAoS4qtm.mjs +593 -0
- package/dist/{bin-SPdenYkw.mjs.map → bin-BAoS4qtm.mjs.map} +1 -1
- package/dist/bin-Ddaz2lxM.cjs +862 -0
- package/dist/{bin-Ce3i6ABn.cjs.map → bin-Ddaz2lxM.cjs.map} +1 -1
- package/dist/browser/base64.cjs +14 -1
- package/dist/browser/base64.cjs.map +1 -1
- package/dist/browser/base64.mjs +12 -1
- package/dist/browser/base64.mjs.map +1 -1
- package/dist/browser/gravatar.cjs +186 -1
- package/dist/browser/gravatar.cjs.map +1 -1
- package/dist/browser/gravatar.mjs +184 -1
- package/dist/browser/gravatar.mjs.map +1 -1
- package/dist/browser/index.cjs +14 -1
- package/dist/browser/index.mjs +8 -1
- package/dist/browser/localstorage.cjs +46 -1
- package/dist/browser/localstorage.cjs.map +1 -1
- package/dist/browser/localstorage.mjs +45 -1
- package/dist/browser/localstorage.mjs.map +1 -1
- package/dist/browser/log/index.cjs +8 -1
- package/dist/browser/log/index.mjs +5 -1
- package/dist/browser/log/log-browser-factory.cjs +65 -1
- package/dist/browser/log/log-browser-factory.cjs.map +1 -1
- package/dist/browser/log/log-browser-factory.mjs +64 -1
- package/dist/browser/log/log-browser-factory.mjs.map +1 -1
- package/dist/browser/log/log-browser.cjs +72 -1
- package/dist/browser/log/log-browser.cjs.map +1 -1
- package/dist/browser/log/log-browser.mjs +71 -1
- package/dist/browser/log/log-browser.mjs.map +1 -1
- package/dist/browser/log/log-colors.cjs +11 -1
- package/dist/browser/log/log-colors.cjs.map +1 -1
- package/dist/browser/log/log-colors.mjs +9 -1
- package/dist/browser/log/log-colors.mjs.map +1 -1
- package/dist/browser/log/log-context-browser.cjs +25 -1
- package/dist/browser/log/log-context-browser.cjs.map +1 -1
- package/dist/browser/log/log-context-browser.mjs +23 -1
- package/dist/browser/log/log-context-browser.mjs.map +1 -1
- package/dist/chunk-DQk6qfdC.mjs +18 -0
- package/dist/chunk-uaV2rQ02.cjs +53 -0
- package/dist/common/assert.cjs +22 -1
- package/dist/common/assert.cjs.map +1 -1
- package/dist/common/assert.mjs +19 -1
- package/dist/common/assert.mjs.map +1 -1
- package/dist/common/bin/index.cjs +106 -1
- package/dist/common/bin/index.cjs.map +1 -1
- package/dist/common/bin/index.mjs +98 -1
- package/dist/common/bin/index.mjs.map +1 -1
- package/dist/common/bin/lib0/binary.cjs +146 -1
- package/dist/common/bin/lib0/binary.cjs.map +1 -1
- package/dist/common/bin/lib0/binary.mjs +80 -1
- package/dist/common/bin/lib0/binary.mjs.map +1 -1
- package/dist/common/bin/lib0/buffer.cjs +42 -1
- package/dist/common/bin/lib0/buffer.cjs.map +1 -1
- package/dist/common/bin/lib0/buffer.mjs +38 -1
- package/dist/common/bin/lib0/buffer.mjs.map +1 -1
- package/dist/common/bin/lib0/create.cjs +24 -1
- package/dist/common/bin/lib0/create.cjs.map +1 -1
- package/dist/common/bin/lib0/create.mjs +21 -1
- package/dist/common/bin/lib0/create.mjs.map +1 -1
- package/dist/common/bin/lib0/decoding.cjs +325 -1
- package/dist/common/bin/lib0/decoding.cjs.map +1 -1
- package/dist/common/bin/lib0/decoding.mjs +298 -1
- package/dist/common/bin/lib0/decoding.mjs.map +1 -1
- package/dist/common/bin/lib0/encoding.cjs +404 -1
- package/dist/common/bin/lib0/encoding.cjs.map +1 -1
- package/dist/common/bin/lib0/encoding.mjs +377 -1
- package/dist/common/bin/lib0/encoding.mjs.map +1 -1
- package/dist/common/bin/lib0/string.cjs +81 -1
- package/dist/common/bin/lib0/string.cjs.map +1 -1
- package/dist/common/bin/lib0/string.mjs +71 -1
- package/dist/common/bin/lib0/string.mjs.map +1 -1
- package/dist/common/crypto/aes-sealed.cjs +34 -1
- package/dist/common/crypto/aes-sealed.cjs.map +1 -1
- package/dist/common/crypto/aes-sealed.mjs +32 -1
- package/dist/common/crypto/aes-sealed.mjs.map +1 -1
- package/dist/common/crypto/crypto.cjs +91 -1
- package/dist/common/crypto/crypto.cjs.map +1 -1
- package/dist/common/crypto/crypto.mjs +80 -1
- package/dist/common/crypto/crypto.mjs.map +1 -1
- package/dist/common/crypto/index.cjs +23 -1
- package/dist/common/crypto/index.mjs +5 -1
- package/dist/common/crypto/xaes.cjs +128 -1
- package/dist/common/crypto/xaes.cjs.map +1 -1
- package/dist/common/crypto/xaes.mjs +123 -1
- package/dist/common/crypto/xaes.mjs.map +1 -1
- package/dist/common/csv.cjs +49 -4
- package/dist/common/csv.cjs.map +1 -1
- package/dist/common/csv.mjs +46 -4
- package/dist/common/csv.mjs.map +1 -1
- package/dist/common/data/array.cjs +299 -1
- package/dist/common/data/array.cjs.map +1 -1
- package/dist/common/data/array.mjs +274 -1
- package/dist/common/data/array.mjs.map +1 -1
- package/dist/common/data/basex-secure.cjs +30 -1
- package/dist/common/data/basex-secure.mjs +3 -1
- package/dist/common/data/basex.cjs +163 -1
- package/dist/common/data/basex.cjs.map +1 -1
- package/dist/common/data/basex.mjs +152 -1
- package/dist/common/data/basex.mjs.map +1 -1
- package/dist/common/data/bin-types.mjs +1 -1
- package/dist/common/data/bin.cjs +21 -1
- package/dist/common/data/bin.mjs +3 -1
- package/dist/common/data/camelcase.cjs +27 -1
- package/dist/common/data/camelcase.cjs.map +1 -1
- package/dist/common/data/camelcase.mjs +22 -1
- package/dist/common/data/camelcase.mjs.map +1 -1
- package/dist/common/data/convert.cjs +104 -1
- package/dist/common/data/convert.cjs.map +1 -1
- package/dist/common/data/convert.mjs +88 -1
- package/dist/common/data/convert.mjs.map +1 -1
- package/dist/common/data/datauri.cjs +32 -1
- package/dist/common/data/datauri.cjs.map +1 -1
- package/dist/common/data/datauri.mjs +27 -1
- package/dist/common/data/datauri.mjs.map +1 -1
- package/dist/common/data/day-legacy.cjs +148 -1
- package/dist/common/data/day-legacy.cjs.map +1 -1
- package/dist/common/data/day-legacy.mjs +143 -1
- package/dist/common/data/day-legacy.mjs.map +1 -1
- package/dist/common/data/day.cjs +335 -1
- package/dist/common/data/day.cjs.map +1 -1
- package/dist/common/data/day.mjs +305 -1
- package/dist/common/data/day.mjs.map +1 -1
- package/dist/common/data/decimal.cjs +28 -1
- package/dist/common/data/decimal.cjs.map +1 -1
- package/dist/common/data/decimal.mjs +23 -1
- package/dist/common/data/decimal.mjs.map +1 -1
- package/dist/common/data/deep.cjs +57 -1
- package/dist/common/data/deep.cjs.map +1 -1
- package/dist/common/data/deep.mjs +54 -1
- package/dist/common/data/deep.mjs.map +1 -1
- package/dist/common/data/diff.cjs +62 -1
- package/dist/common/data/diff.cjs.map +1 -1
- package/dist/common/data/diff.mjs +60 -1
- package/dist/common/data/diff.mjs.map +1 -1
- package/dist/common/data/distributed.cjs +24 -1
- package/dist/common/data/distributed.cjs.map +1 -1
- package/dist/common/data/distributed.mjs +22 -1
- package/dist/common/data/distributed.mjs.map +1 -1
- package/dist/common/data/format.cjs +63 -1
- package/dist/common/data/format.cjs.map +1 -1
- package/dist/common/data/format.mjs +59 -1
- package/dist/common/data/format.mjs.map +1 -1
- package/dist/common/data/html.cjs +13 -1
- package/dist/common/data/html.cjs.map +1 -1
- package/dist/common/data/html.mjs +10 -1
- package/dist/common/data/html.mjs.map +1 -1
- package/dist/common/data/index.cjs +296 -1
- package/dist/common/data/index.mjs +37 -1
- package/dist/common/data/is.cjs +106 -1
- package/dist/common/data/is.cjs.map +1 -1
- package/dist/common/data/is.mjs +85 -1
- package/dist/common/data/is.mjs.map +1 -1
- package/dist/common/data/json.cjs +70 -1
- package/dist/common/data/json.cjs.map +1 -1
- package/dist/common/data/json.mjs +65 -1
- package/dist/common/data/json.mjs.map +1 -1
- package/dist/common/data/list.cjs +32 -1
- package/dist/common/data/list.cjs.map +1 -1
- package/dist/common/data/list.mjs +27 -1
- package/dist/common/data/list.mjs.map +1 -1
- package/dist/common/data/lru.mjs +1 -1
- package/dist/common/data/math.cjs +79 -1
- package/dist/common/data/math.cjs.map +1 -1
- package/dist/common/data/math.mjs +65 -1
- package/dist/common/data/math.mjs.map +1 -1
- package/dist/common/data/message.cjs +30 -1
- package/dist/common/data/message.cjs.map +1 -1
- package/dist/common/data/message.mjs +28 -1
- package/dist/common/data/message.mjs.map +1 -1
- package/dist/common/data/object-changes.cjs +66 -1
- package/dist/common/data/object-changes.cjs.map +1 -1
- package/dist/common/data/object-changes.mjs +63 -1
- package/dist/common/data/object-changes.mjs.map +1 -1
- package/dist/common/data/object.cjs +112 -1
- package/dist/common/data/object.cjs.map +1 -1
- package/dist/common/data/object.mjs +104 -1
- package/dist/common/data/object.mjs.map +1 -1
- package/dist/common/data/orderby.cjs +42 -1
- package/dist/common/data/orderby.cjs.map +1 -1
- package/dist/common/data/orderby.mjs +37 -1
- package/dist/common/data/orderby.mjs.map +1 -1
- package/dist/common/data/path.cjs +26 -1
- package/dist/common/data/path.cjs.map +1 -1
- package/dist/common/data/path.mjs +25 -1
- package/dist/common/data/path.mjs.map +1 -1
- package/dist/common/data/regexp.cjs +12 -1
- package/dist/common/data/regexp.cjs.map +1 -1
- package/dist/common/data/regexp.mjs +10 -1
- package/dist/common/data/regexp.mjs.map +1 -1
- package/dist/common/data/rounding.cjs +107 -1
- package/dist/common/data/rounding.cjs.map +1 -1
- package/dist/common/data/rounding.mjs +95 -1
- package/dist/common/data/rounding.mjs.map +1 -1
- package/dist/common/data/signal.cjs +39 -1
- package/dist/common/data/signal.cjs.map +1 -1
- package/dist/common/data/signal.mjs +38 -1
- package/dist/common/data/signal.mjs.map +1 -1
- package/dist/common/data/sortable.cjs +35 -1
- package/dist/common/data/sortable.cjs.map +1 -1
- package/dist/common/data/sortable.mjs +31 -1
- package/dist/common/data/sortable.mjs.map +1 -1
- package/dist/common/data/sorted.cjs +54 -1
- package/dist/common/data/sorted.cjs.map +1 -1
- package/dist/common/data/sorted.mjs +53 -1
- package/dist/common/data/sorted.mjs.map +1 -1
- package/dist/common/data/string-deburr.cjs +240 -1
- package/dist/common/data/string-deburr.cjs.map +1 -1
- package/dist/common/data/string-deburr.mjs +238 -1
- package/dist/common/data/string-deburr.mjs.map +1 -1
- package/dist/common/data/string-hash-fnv.cjs +69 -1
- package/dist/common/data/string-hash-fnv.cjs.map +1 -1
- package/dist/common/data/string-hash-fnv.mjs +67 -1
- package/dist/common/data/string-hash-fnv.mjs.map +1 -1
- package/dist/common/data/string-hash-pool.cjs +28 -1
- package/dist/common/data/string-hash-pool.cjs.map +1 -1
- package/dist/common/data/string-hash-pool.mjs +27 -1
- package/dist/common/data/string-hash-pool.mjs.map +1 -1
- package/dist/common/data/url.cjs +98 -2
- package/dist/common/data/url.cjs.map +1 -1
- package/dist/common/data/url.mjs +91 -2
- package/dist/common/data/url.mjs.map +1 -1
- package/dist/common/data/utils.cjs +118 -1
- package/dist/common/data/utils.cjs.map +1 -1
- package/dist/common/data/utils.mjs +107 -1
- package/dist/common/data/utils.mjs.map +1 -1
- package/dist/common/data/wordlist.cjs +531 -1
- package/dist/common/data/wordlist.cjs.map +1 -1
- package/dist/common/data/wordlist.mjs +529 -1
- package/dist/common/data/wordlist.mjs.map +1 -1
- package/dist/common/data/xrx.cjs +96 -1
- package/dist/common/data/xrx.cjs.map +1 -1
- package/dist/common/data/xrx.mjs +92 -1
- package/dist/common/data/xrx.mjs.map +1 -1
- package/dist/common/dispose-defer.cjs +133 -1
- package/dist/common/dispose-defer.cjs.map +1 -1
- package/dist/common/dispose-defer.mjs +130 -1
- package/dist/common/dispose-defer.mjs.map +1 -1
- package/dist/common/dispose-types.mjs +1 -1
- package/dist/common/dispose-utils.cjs +113 -1
- package/dist/common/dispose-utils.cjs.map +1 -1
- package/dist/common/dispose-utils.mjs +106 -1
- package/dist/common/dispose-utils.mjs.map +1 -1
- package/dist/common/exec/index.cjs +24 -1
- package/dist/common/exec/index.d.cts +1 -1
- package/dist/common/exec/index.d.mts +1 -1
- package/dist/common/exec/index.mjs +8 -1
- package/dist/common/exec/mutex.cjs +44 -1
- package/dist/common/exec/mutex.cjs.map +1 -1
- package/dist/common/exec/mutex.mjs +42 -1
- package/dist/common/exec/mutex.mjs.map +1 -1
- package/dist/common/exec/pool.cjs +181 -1
- package/dist/common/exec/pool.cjs.map +1 -1
- package/dist/common/exec/pool.d.cts +1 -1
- package/dist/common/exec/pool.d.mts +1 -1
- package/dist/common/exec/pool.mjs +180 -1
- package/dist/common/exec/pool.mjs.map +1 -1
- package/dist/common/exec/progress.cjs +149 -1
- package/dist/common/exec/progress.cjs.map +1 -1
- package/dist/common/exec/progress.d.cts +1 -1
- package/dist/common/exec/progress.d.mts +1 -1
- package/dist/common/exec/progress.mjs +148 -1
- package/dist/common/exec/progress.mjs.map +1 -1
- package/dist/common/exec/promise.cjs +113 -1
- package/dist/common/exec/promise.cjs.map +1 -1
- package/dist/common/exec/promise.mjs +103 -1
- package/dist/common/exec/promise.mjs.map +1 -1
- package/dist/common/exec/queue.cjs +125 -1
- package/dist/common/exec/queue.cjs.map +1 -1
- package/dist/common/exec/queue.d.cts +1 -1
- package/dist/common/exec/queue.d.mts +1 -1
- package/dist/common/exec/queue.mjs +124 -1
- package/dist/common/exec/queue.mjs.map +1 -1
- package/dist/common/exec/throttle-debounce.cjs +114 -1
- package/dist/common/exec/throttle-debounce.cjs.map +1 -1
- package/dist/common/exec/throttle-debounce.mjs +112 -1
- package/dist/common/exec/throttle-debounce.mjs.map +1 -1
- package/dist/common/global.cjs +22 -1
- package/dist/common/global.cjs.map +1 -1
- package/dist/common/global.mjs +19 -1
- package/dist/common/global.mjs.map +1 -1
- package/dist/common/index.cjs +559 -1
- package/dist/common/index.d.cts +1 -1
- package/dist/common/index.d.mts +1 -1
- package/dist/common/index.mjs +89 -1
- package/dist/common/localhost.cjs +16 -1
- package/dist/common/localhost.cjs.map +1 -1
- package/dist/common/localhost.mjs +14 -1
- package/dist/common/localhost.mjs.map +1 -1
- package/dist/common/log/index.cjs +34 -1
- package/dist/common/log/index.mjs +11 -1
- package/dist/common/log/log-base.cjs +40 -1
- package/dist/common/log/log-base.cjs.map +1 -1
- package/dist/common/log/log-base.mjs +31 -1
- package/dist/common/log/log-base.mjs.map +1 -1
- package/dist/common/log/log-colors.cjs +92 -1
- package/dist/common/log/log-colors.cjs.map +1 -1
- package/dist/common/log/log-colors.mjs +90 -1
- package/dist/common/log/log-colors.mjs.map +1 -1
- package/dist/common/log/log-config.cjs +15 -1
- package/dist/common/log/log-config.cjs.map +1 -1
- package/dist/common/log/log-config.mjs +14 -1
- package/dist/common/log/log-config.mjs.map +1 -1
- package/dist/common/log/log-console-capture.cjs +33 -1
- package/dist/common/log/log-console-capture.cjs.map +1 -1
- package/dist/common/log/log-console-capture.mjs +32 -1
- package/dist/common/log/log-console-capture.mjs.map +1 -1
- package/dist/common/log/log-console-original.cjs +27 -1
- package/dist/common/log/log-console-original.cjs.map +1 -1
- package/dist/common/log/log-console-original.mjs +26 -1
- package/dist/common/log/log-console-original.mjs.map +1 -1
- package/dist/common/log/log-console.cjs +39 -1
- package/dist/common/log/log-console.cjs.map +1 -1
- package/dist/common/log/log-console.mjs +38 -1
- package/dist/common/log/log-console.mjs.map +1 -1
- package/dist/common/log/log-context.cjs +109 -1
- package/dist/common/log/log-context.cjs.map +1 -1
- package/dist/common/log/log-context.mjs +108 -1
- package/dist/common/log/log-context.mjs.map +1 -1
- package/dist/common/log/log-filter.cjs +80 -1
- package/dist/common/log/log-filter.cjs.map +1 -1
- package/dist/common/log/log-filter.mjs +75 -1
- package/dist/common/log/log-filter.mjs.map +1 -1
- package/dist/common/log/log-memory.cjs +45 -1
- package/dist/common/log/log-memory.cjs.map +1 -1
- package/dist/common/log/log-memory.mjs +43 -1
- package/dist/common/log/log-memory.mjs.map +1 -1
- package/dist/common/log/log-noop.cjs +17 -1
- package/dist/common/log/log-noop.cjs.map +1 -1
- package/dist/common/log/log-noop.mjs +15 -1
- package/dist/common/log/log-noop.mjs.map +1 -1
- package/dist/common/log/log.cjs +46 -1
- package/dist/common/log/log.cjs.map +1 -1
- package/dist/common/log/log.mjs +43 -1
- package/dist/common/log/log.mjs.map +1 -1
- package/dist/common/msg/channel-debug.cjs +17 -1
- package/dist/common/msg/channel-debug.cjs.map +1 -1
- package/dist/common/msg/channel-debug.d.cts +1 -1
- package/dist/common/msg/channel-debug.d.mts +1 -1
- package/dist/common/msg/channel-debug.mjs +16 -1
- package/dist/common/msg/channel-debug.mjs.map +1 -1
- package/dist/common/msg/channel-local.cjs +28 -1
- package/dist/common/msg/channel-local.cjs.map +1 -1
- package/dist/common/msg/channel-local.d.cts +1 -1
- package/dist/common/msg/channel-local.d.mts +1 -1
- package/dist/common/msg/channel-local.mjs +26 -1
- package/dist/common/msg/channel-local.mjs.map +1 -1
- package/dist/common/msg/channel-resilient.cjs +63 -1
- package/dist/common/msg/channel-resilient.cjs.map +1 -1
- package/dist/common/msg/channel-resilient.d.cts +1 -1
- package/dist/common/msg/channel-resilient.d.mts +1 -1
- package/dist/common/msg/channel-resilient.mjs +62 -1
- package/dist/common/msg/channel-resilient.mjs.map +1 -1
- package/dist/common/msg/channel-wkwebview.cjs +35 -1
- package/dist/common/msg/channel-wkwebview.cjs.map +1 -1
- package/dist/common/msg/channel-wkwebview.d.cts +2 -1
- package/dist/common/msg/channel-wkwebview.d.mts +2 -1
- package/dist/common/msg/channel-wkwebview.mjs +34 -1
- package/dist/common/msg/channel-wkwebview.mjs.map +1 -1
- package/dist/common/msg/channel.cjs +23 -1
- package/dist/common/msg/channel.cjs.map +1 -1
- package/dist/common/msg/channel.d.cts +1 -1
- package/dist/common/msg/channel.d.mts +1 -1
- package/dist/common/msg/channel.mjs +22 -1
- package/dist/common/msg/channel.mjs.map +1 -1
- package/dist/common/msg/emitter.cjs +141 -1
- package/dist/common/msg/emitter.cjs.map +1 -1
- package/dist/common/msg/emitter.d.cts +1 -1
- package/dist/common/msg/emitter.d.mts +1 -1
- package/dist/common/msg/emitter.mjs +139 -1
- package/dist/common/msg/emitter.mjs.map +1 -1
- package/dist/common/msg/encoder.cjs +38 -1
- package/dist/common/msg/encoder.cjs.map +1 -1
- package/dist/common/msg/encoder.mjs +35 -1
- package/dist/common/msg/encoder.mjs.map +1 -1
- package/dist/common/msg/index.cjs +28 -1
- package/dist/common/msg/index.d.cts +1 -1
- package/dist/common/msg/index.d.mts +1 -1
- package/dist/common/msg/index.mjs +11 -1
- package/dist/common/msg/messages.cjs +135 -1
- package/dist/common/msg/messages.cjs.map +1 -1
- package/dist/common/msg/messages.d.cts +1 -1
- package/dist/common/msg/messages.d.mts +1 -1
- package/dist/common/msg/messages.mjs +133 -1
- package/dist/common/msg/messages.mjs.map +1 -1
- package/dist/common/msg/pipe.mjs +1 -1
- package/dist/common/msg/pubsub.cjs +78 -1
- package/dist/common/msg/pubsub.cjs.map +1 -1
- package/dist/common/msg/pubsub.d.cts +1 -1
- package/dist/common/msg/pubsub.d.mts +1 -1
- package/dist/common/msg/pubsub.mjs +76 -1
- package/dist/common/msg/pubsub.mjs.map +1 -1
- package/dist/common/msg/rpc.cjs +142 -1
- package/dist/common/msg/rpc.cjs.map +1 -1
- package/dist/common/msg/rpc.mjs +139 -1
- package/dist/common/msg/rpc.mjs.map +1 -1
- package/dist/common/network.cjs +129 -1
- package/dist/common/network.cjs.map +1 -1
- package/dist/common/network.mjs +122 -1
- package/dist/common/network.mjs.map +1 -1
- package/dist/common/platform.cjs +92 -1
- package/dist/common/platform.cjs.map +1 -1
- package/dist/common/platform.mjs +84 -1
- package/dist/common/platform.mjs.map +1 -1
- package/dist/common/schema/_sandbox/sandbox-inherit.mjs +1 -1
- package/dist/common/schema/_sandbox/sandbox.mjs +1 -1
- package/dist/common/schema/_sandbox/sandbox.xspec.mjs +1 -1
- package/dist/common/schema/export-json-schema.cjs +54 -1
- package/dist/common/schema/export-json-schema.cjs.map +1 -1
- package/dist/common/schema/export-json-schema.mjs +52 -1
- package/dist/common/schema/export-json-schema.mjs.map +1 -1
- package/dist/common/schema/export-swift.cjs +30 -2
- package/dist/common/schema/export-swift.cjs.map +1 -1
- package/dist/common/schema/export-swift.mjs +29 -2
- package/dist/common/schema/export-swift.mjs.map +1 -1
- package/dist/common/schema/export-typescript.cjs +20 -2
- package/dist/common/schema/export-typescript.cjs.map +1 -1
- package/dist/common/schema/export-typescript.mjs +19 -2
- package/dist/common/schema/export-typescript.mjs.map +1 -1
- package/dist/common/schema/index.cjs +55 -1
- package/dist/common/schema/index.mjs +12 -1
- package/dist/common/schema/parse-args.cjs +62 -2
- package/dist/common/schema/parse-args.cjs.map +1 -1
- package/dist/common/schema/parse-args.mjs +60 -2
- package/dist/common/schema/parse-args.mjs.map +1 -1
- package/dist/common/schema/parse-env.cjs +48 -3
- package/dist/common/schema/parse-env.cjs.map +1 -1
- package/dist/common/schema/parse-env.mjs +46 -3
- package/dist/common/schema/parse-env.mjs.map +1 -1
- package/dist/common/schema/parse-object.cjs +122 -1
- package/dist/common/schema/parse-object.cjs.map +1 -1
- package/dist/common/schema/parse-object.mjs +119 -1
- package/dist/common/schema/parse-object.mjs.map +1 -1
- package/dist/common/schema/schema-standard.mjs +1 -1
- package/dist/common/schema/schema.cjs +423 -1
- package/dist/common/schema/schema.cjs.map +1 -1
- package/dist/common/schema/schema.mjs +404 -1
- package/dist/common/schema/schema.mjs.map +1 -1
- package/dist/common/schema/serialize.cjs +109 -1
- package/dist/common/schema/serialize.cjs.map +1 -1
- package/dist/common/schema/serialize.mjs +107 -1
- package/dist/common/schema/serialize.mjs.map +1 -1
- package/dist/common/schema/type-test.mjs +1 -1
- package/dist/common/schema/utils.cjs +25 -1
- package/dist/common/schema/utils.cjs.map +1 -1
- package/dist/common/schema/utils.mjs +19 -1
- package/dist/common/schema/utils.mjs.map +1 -1
- package/dist/common/schema/z-collection.cjs +51 -1
- package/dist/common/schema/z-collection.mjs +27 -1
- package/dist/common/schema/z.cjs +9 -1
- package/dist/common/schema/z.mjs +3 -1
- package/dist/common/storage/index.cjs +4 -1
- package/dist/common/storage/index.mjs +3 -1
- package/dist/common/storage/memstorage.cjs +26 -1
- package/dist/common/storage/memstorage.cjs.map +1 -1
- package/dist/common/storage/memstorage.mjs +25 -1
- package/dist/common/storage/memstorage.mjs.map +1 -1
- package/dist/common/test.cjs +14 -1
- package/dist/common/test.cjs.map +1 -1
- package/dist/common/test.mjs +13 -1
- package/dist/common/test.mjs.map +1 -1
- package/dist/common/time.cjs +220 -1
- package/dist/common/time.cjs.map +1 -1
- package/dist/common/time.mjs +194 -1
- package/dist/common/time.mjs.map +1 -1
- package/dist/common/timeout.cjs +27 -1
- package/dist/common/timeout.cjs.map +1 -1
- package/dist/common/timeout.mjs +25 -1
- package/dist/common/timeout.mjs.map +1 -1
- package/dist/common/types.mjs +1 -1
- package/dist/common/utils.cjs +7 -1
- package/dist/common/utils.cjs.map +1 -1
- package/dist/common/utils.mjs +5 -1
- package/dist/common/utils.mjs.map +1 -1
- package/dist/common/uuid.cjs +307 -1
- package/dist/common/uuid.cjs.map +1 -1
- package/dist/common/uuid.mjs +284 -1
- package/dist/common/uuid.mjs.map +1 -1
- package/dist/{index-DHXVOH8h.d.cts → index-CFkMqHvX.d.cts} +1 -2
- package/dist/{index-DMaPyx9O.d.mts → index-C_3Y_s6f.d.mts} +1 -2
- package/dist/index.all.cjs +641 -1
- package/dist/index.all.d.cts +1 -1
- package/dist/index.all.d.mts +1 -1
- package/dist/index.all.mjs +113 -1
- package/dist/index.browser.cjs +576 -1
- package/dist/index.browser.d.cts +1 -1
- package/dist/index.browser.d.mts +1 -1
- package/dist/index.browser.mjs +98 -1
- package/dist/index.jsr.cjs +57 -1
- package/dist/index.jsr.mjs +6 -1
- package/dist/index.node.cjs +628 -1
- package/dist/index.node.d.cts +1 -1
- package/dist/index.node.d.mts +1 -1
- package/dist/index.node.mjs +106 -1
- package/dist/node/args.cjs +56 -1
- package/dist/node/args.cjs.map +1 -1
- package/dist/node/args.mjs +53 -1
- package/dist/node/args.mjs.map +1 -1
- package/dist/node/clipboard.cjs +18 -1
- package/dist/node/clipboard.cjs.map +1 -1
- package/dist/node/clipboard.mjs +16 -1
- package/dist/node/clipboard.mjs.map +1 -1
- package/dist/node/crypto.cjs +28 -1
- package/dist/node/crypto.cjs.map +1 -1
- package/dist/node/crypto.mjs +24 -1
- package/dist/node/crypto.mjs.map +1 -1
- package/dist/node/env.cjs +100 -4
- package/dist/node/env.cjs.map +1 -1
- package/dist/node/env.mjs +90 -4
- package/dist/node/env.mjs.map +1 -1
- package/dist/node/files-async.cjs +66 -1
- package/dist/node/files-async.cjs.map +1 -1
- package/dist/node/files-async.mjs +60 -1
- package/dist/node/files-async.mjs.map +1 -1
- package/dist/node/files.cjs +52 -1
- package/dist/node/files.cjs.map +1 -1
- package/dist/node/files.mjs +46 -1
- package/dist/node/files.mjs.map +1 -1
- package/dist/node/filestorage.cjs +100 -1
- package/dist/node/filestorage.cjs.map +1 -1
- package/dist/node/filestorage.mjs +97 -1
- package/dist/node/filestorage.mjs.map +1 -1
- package/dist/node/fs.cjs +119 -1
- package/dist/node/fs.cjs.map +1 -1
- package/dist/node/fs.mjs +101 -1
- package/dist/node/fs.mjs.map +1 -1
- package/dist/node/glob.cjs +75 -1
- package/dist/node/glob.cjs.map +1 -1
- package/dist/node/glob.mjs +73 -1
- package/dist/node/glob.mjs.map +1 -1
- package/dist/node/index.cjs +66 -1
- package/dist/node/index.mjs +16 -1
- package/dist/node/log/index.cjs +20 -1
- package/dist/node/log/index.mjs +7 -1
- package/dist/node/log/log-context-node.cjs +39 -1
- package/dist/node/log/log-context-node.cjs.map +1 -1
- package/dist/node/log/log-context-node.mjs +35 -1
- package/dist/node/log/log-context-node.mjs.map +1 -1
- package/dist/node/log/log-file-rotation.cjs +71 -1
- package/dist/node/log/log-file-rotation.cjs.map +1 -1
- package/dist/node/log/log-file-rotation.mjs +68 -1
- package/dist/node/log/log-file-rotation.mjs.map +1 -1
- package/dist/node/log/log-file.cjs +57 -1
- package/dist/node/log/log-file.cjs.map +1 -1
- package/dist/node/log/log-file.mjs +54 -1
- package/dist/node/log/log-file.mjs.map +1 -1
- package/dist/node/log/log-node.cjs +162 -1
- package/dist/node/log/log-node.cjs.map +1 -1
- package/dist/node/log/log-node.mjs +155 -1
- package/dist/node/log/log-node.mjs.map +1 -1
- package/dist/node/log/log-rotation.cjs +543 -3
- package/dist/node/log/log-rotation.cjs.map +1 -1
- package/dist/node/log/log-rotation.mjs +538 -3
- package/dist/node/log/log-rotation.mjs.map +1 -1
- package/dist/node/log/log-util.cjs +69 -3
- package/dist/node/log/log-util.cjs.map +1 -1
- package/dist/node/log/log-util.mjs +63 -3
- package/dist/node/log/log-util.mjs.map +1 -1
- package/dist/node/open-browser.cjs +20 -1
- package/dist/node/open-browser.cjs.map +1 -1
- package/dist/node/open-browser.mjs +18 -1
- package/dist/node/open-browser.mjs.map +1 -1
- package/package.json +15 -15
- package/src/common/schema/README.md +247 -66
- package/src/eslint-defaults.js +4 -0
- package/src/index.spec.ts +6 -6
- package/dist/bin-Ce3i6ABn.cjs +0 -3
- package/dist/bin-SPdenYkw.mjs +0 -3
- package/dist/chunk-0Lt9GpW0.mjs +0 -1
- package/dist/chunk-D-qHiVGv.cjs +0 -1
- package/src/common/schema/README-SCHEMA.md +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"day-legacy.cjs","names":["DAY_MS","isPromise"],"sources":["../../../src/common/data/day-legacy.ts"],"sourcesContent":["import { isPromise } from '../exec/promise'\nimport type { DayInput, DayValue } from './day'\nimport { DAY_MS } from './day'\n\n// See also and alternatives:\n// https://blog.openreplay.com/is-it-time-for-the-javascript-temporal-api\n// https://github.com/iamkun/dayjs\n// https://github.com/date-fns/date-fns\n\nexport type DayInputLegacy = DayInput | Day\n\n/**\n * Date represented as positive integer value. Years smaller 0 are not supported.\n * @deprecated\n */\nexport class Day {\n days: DayValue\n\n get value() {\n return this.days\n }\n\n constructor(days?: DayInputLegacy) {\n if (typeof days === 'number') {\n this.days = days\n return\n }\n\n if (days != null)\n days = Day.from(days)?.days\n\n if (days == null) {\n const date = new Date()\n this.days\n = date.getFullYear() * 10000\n + (date.getMonth() + 1) * 100\n + date.getDate()\n }\n else {\n this.days = days\n }\n }\n\n static fromNumber(n: number): Day {\n return new Day(n)\n }\n\n static fromString(dateString: string): Day | undefined {\n return Day.from(+dateString.replace(/\\D/g, '').slice(0, 8))\n }\n\n static fromDate(date: Date, utc = false): Day {\n return (\n utc\n ? Day.fromString(date.toISOString().substr(0, 10))\n : Day.from(\n date.getFullYear() * 10000\n + (date.getMonth() + 1) * 100\n + date.getDate(),\n )\n ) as Day\n }\n\n static fromDateUTC(date: Date): Day {\n return Day.fromDate(date, true)\n }\n\n /** @deprecated use fromDateUTC */\n static fromDateGMT(date: Date): Day {\n return Day.fromDate(date, true)\n }\n\n static from(value: DayInputLegacy, utc = false): Day | undefined {\n if (typeof value === 'number') {\n if (value < 100)\n return\n return new Day(value)\n }\n else if (typeof value === 'string') {\n return Day.fromString(value)\n }\n else if (Array.isArray(value) && value.length === 3) {\n const [year, month = 1, day = 1] = value\n if (month < 1 || month > 12 || day < 1 || day > 31)\n return\n return new Day(year * 10000 + month * 100 + day)\n }\n else if (value instanceof Date) {\n return Day.fromDate(value, utc)\n }\n else if (value instanceof Day) {\n return value\n }\n }\n\n toNumber(): number {\n return this.days\n }\n\n // Transformer\n\n /** Just for future extensions */\n toJson() {\n return this.days\n }\n\n toString(sep = '-') {\n const baseString = String(this.days)\n return (\n baseString.slice(0, 4)\n + sep\n + baseString.slice(4, 6)\n + sep\n + baseString.slice(6, 8)\n )\n }\n\n toDate(utc = false): Date {\n return utc\n ? new Date(`${this.toString()}T00:00:00.000Z`)\n : new Date(\n this.days / 10000, // year\n ((this.days / 100) % 100) - 1, // month\n this.days % 100, // day\n )\n }\n\n toDateUTC() {\n return this.toDate(true)\n }\n\n /** @deprecated use toDateUTC */\n toDateGMT() {\n return this.toDate(true)\n }\n\n get year() {\n return Math.floor(this.days / 10000)\n }\n\n get month() {\n return Math.floor((this.days / 100) % 100)\n }\n\n get day() {\n return Math.floor(this.days % 100)\n }\n\n // Calculations\n\n dayOffset(offset: number): Day {\n // Important! Don't use local time here due to summer/winter time days can\n // be longer or shorter!\n return Day.fromDateUTC(\n new Date(this.toDateUTC().getTime() + offset * DAY_MS),\n )\n }\n\n monthStart(): Day {\n return Day.from([this.year, this.month, 1])!\n }\n\n yearStart(): Day {\n return Day.from([this.year, 1, 1])!\n }\n\n /** Very stupid approach, only works for days <= 28 */\n monthOffset(offset: number): Day {\n const m = this.month + offset\n let mm = Math.floor((m - 1) % 12) + 1\n if (mm === 0)\n mm = 12\n const yy = Math.floor((m - 1) / 12)\n // log(\"calc\", m, mm, yy, [this.year + yy, mm, this.day])\n return Day.from([this.year + yy, mm, this.day])!\n }\n\n daysUntil(otherDay: DayInputLegacy): number {\n return Math.round(\n (new Day(otherDay)?.toDateUTC().getTime() - this.toDateUTC().getTime())\n / DAY_MS,\n )\n }\n\n // Shortcuts\n\n yesterday() {\n return this.dayOffset(-1)\n }\n\n tomorrow() {\n return this.dayOffset(+1)\n }\n}\n\nexport async function forEachDay(\n from: DayInputLegacy,\n to: DayInputLegacy,\n handler: (date: Day) => Promise<void> | void,\n) {\n let start = Day.from(from)\n const end = Day.from(to)\n // eslint-disable-next-line no-unmodified-loop-condition\n while (start && end && start?.days <= end?.days) {\n const result = handler(start)\n if (isPromise(result))\n await result\n start = start.dayOffset(+1)\n }\n}\n\nexport function today(): Day {\n return new Day()\n}\n\n/** @deprecated */\nexport function day(days?: DayInputLegacy): Day {\n return new Day(days)\n}\n\nexport function dateStringToDays(dateString: string): number {\n return Day.fromDate(new Date(dateString)).days\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"file":"day-legacy.cjs","names":["DAY_MS","isPromise"],"sources":["../../../src/common/data/day-legacy.ts"],"sourcesContent":["import { isPromise } from '../exec/promise'\nimport type { DayInput, DayValue } from './day'\nimport { DAY_MS } from './day'\n\n// See also and alternatives:\n// https://blog.openreplay.com/is-it-time-for-the-javascript-temporal-api\n// https://github.com/iamkun/dayjs\n// https://github.com/date-fns/date-fns\n\nexport type DayInputLegacy = DayInput | Day\n\n/**\n * Date represented as positive integer value. Years smaller 0 are not supported.\n * @deprecated\n */\nexport class Day {\n days: DayValue\n\n get value() {\n return this.days\n }\n\n constructor(days?: DayInputLegacy) {\n if (typeof days === 'number') {\n this.days = days\n return\n }\n\n if (days != null)\n days = Day.from(days)?.days\n\n if (days == null) {\n const date = new Date()\n this.days\n = date.getFullYear() * 10000\n + (date.getMonth() + 1) * 100\n + date.getDate()\n }\n else {\n this.days = days\n }\n }\n\n static fromNumber(n: number): Day {\n return new Day(n)\n }\n\n static fromString(dateString: string): Day | undefined {\n return Day.from(+dateString.replace(/\\D/g, '').slice(0, 8))\n }\n\n static fromDate(date: Date, utc = false): Day {\n return (\n utc\n ? Day.fromString(date.toISOString().substr(0, 10))\n : Day.from(\n date.getFullYear() * 10000\n + (date.getMonth() + 1) * 100\n + date.getDate(),\n )\n ) as Day\n }\n\n static fromDateUTC(date: Date): Day {\n return Day.fromDate(date, true)\n }\n\n /** @deprecated use fromDateUTC */\n static fromDateGMT(date: Date): Day {\n return Day.fromDate(date, true)\n }\n\n static from(value: DayInputLegacy, utc = false): Day | undefined {\n if (typeof value === 'number') {\n if (value < 100)\n return\n return new Day(value)\n }\n else if (typeof value === 'string') {\n return Day.fromString(value)\n }\n else if (Array.isArray(value) && value.length === 3) {\n const [year, month = 1, day = 1] = value\n if (month < 1 || month > 12 || day < 1 || day > 31)\n return\n return new Day(year * 10000 + month * 100 + day)\n }\n else if (value instanceof Date) {\n return Day.fromDate(value, utc)\n }\n else if (value instanceof Day) {\n return value\n }\n }\n\n toNumber(): number {\n return this.days\n }\n\n // Transformer\n\n /** Just for future extensions */\n toJson() {\n return this.days\n }\n\n toString(sep = '-') {\n const baseString = String(this.days)\n return (\n baseString.slice(0, 4)\n + sep\n + baseString.slice(4, 6)\n + sep\n + baseString.slice(6, 8)\n )\n }\n\n toDate(utc = false): Date {\n return utc\n ? new Date(`${this.toString()}T00:00:00.000Z`)\n : new Date(\n this.days / 10000, // year\n ((this.days / 100) % 100) - 1, // month\n this.days % 100, // day\n )\n }\n\n toDateUTC() {\n return this.toDate(true)\n }\n\n /** @deprecated use toDateUTC */\n toDateGMT() {\n return this.toDate(true)\n }\n\n get year() {\n return Math.floor(this.days / 10000)\n }\n\n get month() {\n return Math.floor((this.days / 100) % 100)\n }\n\n get day() {\n return Math.floor(this.days % 100)\n }\n\n // Calculations\n\n dayOffset(offset: number): Day {\n // Important! Don't use local time here due to summer/winter time days can\n // be longer or shorter!\n return Day.fromDateUTC(\n new Date(this.toDateUTC().getTime() + offset * DAY_MS),\n )\n }\n\n monthStart(): Day {\n return Day.from([this.year, this.month, 1])!\n }\n\n yearStart(): Day {\n return Day.from([this.year, 1, 1])!\n }\n\n /** Very stupid approach, only works for days <= 28 */\n monthOffset(offset: number): Day {\n const m = this.month + offset\n let mm = Math.floor((m - 1) % 12) + 1\n if (mm === 0)\n mm = 12\n const yy = Math.floor((m - 1) / 12)\n // log(\"calc\", m, mm, yy, [this.year + yy, mm, this.day])\n return Day.from([this.year + yy, mm, this.day])!\n }\n\n daysUntil(otherDay: DayInputLegacy): number {\n return Math.round(\n (new Day(otherDay)?.toDateUTC().getTime() - this.toDateUTC().getTime())\n / DAY_MS,\n )\n }\n\n // Shortcuts\n\n yesterday() {\n return this.dayOffset(-1)\n }\n\n tomorrow() {\n return this.dayOffset(+1)\n }\n}\n\nexport async function forEachDay(\n from: DayInputLegacy,\n to: DayInputLegacy,\n handler: (date: Day) => Promise<void> | void,\n) {\n let start = Day.from(from)\n const end = Day.from(to)\n // eslint-disable-next-line no-unmodified-loop-condition\n while (start && end && start?.days <= end?.days) {\n const result = handler(start)\n if (isPromise(result))\n await result\n start = start.dayOffset(+1)\n }\n}\n\nexport function today(): Day {\n return new Day()\n}\n\n/** @deprecated */\nexport function day(days?: DayInputLegacy): Day {\n return new Day(days)\n}\n\nexport function dateStringToDays(dateString: string): number {\n return Day.fromDate(new Date(dateString)).days\n}\n"],"mappings":"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"}
|
|
@@ -1,2 +1,144 @@
|
|
|
1
|
-
import{isPromise
|
|
1
|
+
import { isPromise } from "../exec/promise.mjs";
|
|
2
|
+
import { DAY_MS } from "./day.mjs";
|
|
3
|
+
|
|
4
|
+
//#region src/common/data/day-legacy.ts
|
|
5
|
+
/**
|
|
6
|
+
* Date represented as positive integer value. Years smaller 0 are not supported.
|
|
7
|
+
* @deprecated
|
|
8
|
+
*/
|
|
9
|
+
var Day = class Day {
|
|
10
|
+
days;
|
|
11
|
+
get value() {
|
|
12
|
+
return this.days;
|
|
13
|
+
}
|
|
14
|
+
constructor(days) {
|
|
15
|
+
if (typeof days === "number") {
|
|
16
|
+
this.days = days;
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
if (days != null) days = Day.from(days)?.days;
|
|
20
|
+
if (days == null) {
|
|
21
|
+
const date = /* @__PURE__ */ new Date();
|
|
22
|
+
this.days = date.getFullYear() * 1e4 + (date.getMonth() + 1) * 100 + date.getDate();
|
|
23
|
+
} else this.days = days;
|
|
24
|
+
}
|
|
25
|
+
static fromNumber(n) {
|
|
26
|
+
return new Day(n);
|
|
27
|
+
}
|
|
28
|
+
static fromString(dateString) {
|
|
29
|
+
return Day.from(+dateString.replace(/\D/g, "").slice(0, 8));
|
|
30
|
+
}
|
|
31
|
+
static fromDate(date, utc = false) {
|
|
32
|
+
return utc ? Day.fromString(date.toISOString().substr(0, 10)) : Day.from(date.getFullYear() * 1e4 + (date.getMonth() + 1) * 100 + date.getDate());
|
|
33
|
+
}
|
|
34
|
+
static fromDateUTC(date) {
|
|
35
|
+
return Day.fromDate(date, true);
|
|
36
|
+
}
|
|
37
|
+
/** @deprecated use fromDateUTC */
|
|
38
|
+
static fromDateGMT(date) {
|
|
39
|
+
return Day.fromDate(date, true);
|
|
40
|
+
}
|
|
41
|
+
static from(value, utc = false) {
|
|
42
|
+
if (typeof value === "number") {
|
|
43
|
+
if (value < 100) return;
|
|
44
|
+
return new Day(value);
|
|
45
|
+
} else if (typeof value === "string") return Day.fromString(value);
|
|
46
|
+
else if (Array.isArray(value) && value.length === 3) {
|
|
47
|
+
const [year, month = 1, day = 1] = value;
|
|
48
|
+
if (month < 1 || month > 12 || day < 1 || day > 31) return;
|
|
49
|
+
return new Day(year * 1e4 + month * 100 + day);
|
|
50
|
+
} else if (value instanceof Date) return Day.fromDate(value, utc);
|
|
51
|
+
else if (value instanceof Day) return value;
|
|
52
|
+
}
|
|
53
|
+
toNumber() {
|
|
54
|
+
return this.days;
|
|
55
|
+
}
|
|
56
|
+
/** Just for future extensions */
|
|
57
|
+
toJson() {
|
|
58
|
+
return this.days;
|
|
59
|
+
}
|
|
60
|
+
toString(sep = "-") {
|
|
61
|
+
const baseString = String(this.days);
|
|
62
|
+
return baseString.slice(0, 4) + sep + baseString.slice(4, 6) + sep + baseString.slice(6, 8);
|
|
63
|
+
}
|
|
64
|
+
toDate(utc = false) {
|
|
65
|
+
return utc ? /* @__PURE__ */ new Date(`${this.toString()}T00:00:00.000Z`) : new Date(this.days / 1e4, this.days / 100 % 100 - 1, this.days % 100);
|
|
66
|
+
}
|
|
67
|
+
toDateUTC() {
|
|
68
|
+
return this.toDate(true);
|
|
69
|
+
}
|
|
70
|
+
/** @deprecated use toDateUTC */
|
|
71
|
+
toDateGMT() {
|
|
72
|
+
return this.toDate(true);
|
|
73
|
+
}
|
|
74
|
+
get year() {
|
|
75
|
+
return Math.floor(this.days / 1e4);
|
|
76
|
+
}
|
|
77
|
+
get month() {
|
|
78
|
+
return Math.floor(this.days / 100 % 100);
|
|
79
|
+
}
|
|
80
|
+
get day() {
|
|
81
|
+
return Math.floor(this.days % 100);
|
|
82
|
+
}
|
|
83
|
+
dayOffset(offset) {
|
|
84
|
+
return Day.fromDateUTC(new Date(this.toDateUTC().getTime() + offset * DAY_MS));
|
|
85
|
+
}
|
|
86
|
+
monthStart() {
|
|
87
|
+
return Day.from([
|
|
88
|
+
this.year,
|
|
89
|
+
this.month,
|
|
90
|
+
1
|
|
91
|
+
]);
|
|
92
|
+
}
|
|
93
|
+
yearStart() {
|
|
94
|
+
return Day.from([
|
|
95
|
+
this.year,
|
|
96
|
+
1,
|
|
97
|
+
1
|
|
98
|
+
]);
|
|
99
|
+
}
|
|
100
|
+
/** Very stupid approach, only works for days <= 28 */
|
|
101
|
+
monthOffset(offset) {
|
|
102
|
+
const m = this.month + offset;
|
|
103
|
+
let mm = Math.floor((m - 1) % 12) + 1;
|
|
104
|
+
if (mm === 0) mm = 12;
|
|
105
|
+
const yy = Math.floor((m - 1) / 12);
|
|
106
|
+
return Day.from([
|
|
107
|
+
this.year + yy,
|
|
108
|
+
mm,
|
|
109
|
+
this.day
|
|
110
|
+
]);
|
|
111
|
+
}
|
|
112
|
+
daysUntil(otherDay) {
|
|
113
|
+
return Math.round((new Day(otherDay)?.toDateUTC().getTime() - this.toDateUTC().getTime()) / DAY_MS);
|
|
114
|
+
}
|
|
115
|
+
yesterday() {
|
|
116
|
+
return this.dayOffset(-1);
|
|
117
|
+
}
|
|
118
|
+
tomorrow() {
|
|
119
|
+
return this.dayOffset(1);
|
|
120
|
+
}
|
|
121
|
+
};
|
|
122
|
+
async function forEachDay(from, to, handler) {
|
|
123
|
+
let start = Day.from(from);
|
|
124
|
+
const end = Day.from(to);
|
|
125
|
+
while (start && end && start?.days <= end?.days) {
|
|
126
|
+
const result = handler(start);
|
|
127
|
+
if (isPromise(result)) await result;
|
|
128
|
+
start = start.dayOffset(1);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
function today() {
|
|
132
|
+
return new Day();
|
|
133
|
+
}
|
|
134
|
+
/** @deprecated */
|
|
135
|
+
function day(days) {
|
|
136
|
+
return new Day(days);
|
|
137
|
+
}
|
|
138
|
+
function dateStringToDays(dateString) {
|
|
139
|
+
return Day.fromDate(new Date(dateString)).days;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
//#endregion
|
|
143
|
+
export { Day, dateStringToDays, day, forEachDay, today };
|
|
2
144
|
//# sourceMappingURL=day-legacy.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"day-legacy.mjs","names":[],"sources":["../../../src/common/data/day-legacy.ts"],"sourcesContent":["import { isPromise } from '../exec/promise'\nimport type { DayInput, DayValue } from './day'\nimport { DAY_MS } from './day'\n\n// See also and alternatives:\n// https://blog.openreplay.com/is-it-time-for-the-javascript-temporal-api\n// https://github.com/iamkun/dayjs\n// https://github.com/date-fns/date-fns\n\nexport type DayInputLegacy = DayInput | Day\n\n/**\n * Date represented as positive integer value. Years smaller 0 are not supported.\n * @deprecated\n */\nexport class Day {\n days: DayValue\n\n get value() {\n return this.days\n }\n\n constructor(days?: DayInputLegacy) {\n if (typeof days === 'number') {\n this.days = days\n return\n }\n\n if (days != null)\n days = Day.from(days)?.days\n\n if (days == null) {\n const date = new Date()\n this.days\n = date.getFullYear() * 10000\n + (date.getMonth() + 1) * 100\n + date.getDate()\n }\n else {\n this.days = days\n }\n }\n\n static fromNumber(n: number): Day {\n return new Day(n)\n }\n\n static fromString(dateString: string): Day | undefined {\n return Day.from(+dateString.replace(/\\D/g, '').slice(0, 8))\n }\n\n static fromDate(date: Date, utc = false): Day {\n return (\n utc\n ? Day.fromString(date.toISOString().substr(0, 10))\n : Day.from(\n date.getFullYear() * 10000\n + (date.getMonth() + 1) * 100\n + date.getDate(),\n )\n ) as Day\n }\n\n static fromDateUTC(date: Date): Day {\n return Day.fromDate(date, true)\n }\n\n /** @deprecated use fromDateUTC */\n static fromDateGMT(date: Date): Day {\n return Day.fromDate(date, true)\n }\n\n static from(value: DayInputLegacy, utc = false): Day | undefined {\n if (typeof value === 'number') {\n if (value < 100)\n return\n return new Day(value)\n }\n else if (typeof value === 'string') {\n return Day.fromString(value)\n }\n else if (Array.isArray(value) && value.length === 3) {\n const [year, month = 1, day = 1] = value\n if (month < 1 || month > 12 || day < 1 || day > 31)\n return\n return new Day(year * 10000 + month * 100 + day)\n }\n else if (value instanceof Date) {\n return Day.fromDate(value, utc)\n }\n else if (value instanceof Day) {\n return value\n }\n }\n\n toNumber(): number {\n return this.days\n }\n\n // Transformer\n\n /** Just for future extensions */\n toJson() {\n return this.days\n }\n\n toString(sep = '-') {\n const baseString = String(this.days)\n return (\n baseString.slice(0, 4)\n + sep\n + baseString.slice(4, 6)\n + sep\n + baseString.slice(6, 8)\n )\n }\n\n toDate(utc = false): Date {\n return utc\n ? new Date(`${this.toString()}T00:00:00.000Z`)\n : new Date(\n this.days / 10000, // year\n ((this.days / 100) % 100) - 1, // month\n this.days % 100, // day\n )\n }\n\n toDateUTC() {\n return this.toDate(true)\n }\n\n /** @deprecated use toDateUTC */\n toDateGMT() {\n return this.toDate(true)\n }\n\n get year() {\n return Math.floor(this.days / 10000)\n }\n\n get month() {\n return Math.floor((this.days / 100) % 100)\n }\n\n get day() {\n return Math.floor(this.days % 100)\n }\n\n // Calculations\n\n dayOffset(offset: number): Day {\n // Important! Don't use local time here due to summer/winter time days can\n // be longer or shorter!\n return Day.fromDateUTC(\n new Date(this.toDateUTC().getTime() + offset * DAY_MS),\n )\n }\n\n monthStart(): Day {\n return Day.from([this.year, this.month, 1])!\n }\n\n yearStart(): Day {\n return Day.from([this.year, 1, 1])!\n }\n\n /** Very stupid approach, only works for days <= 28 */\n monthOffset(offset: number): Day {\n const m = this.month + offset\n let mm = Math.floor((m - 1) % 12) + 1\n if (mm === 0)\n mm = 12\n const yy = Math.floor((m - 1) / 12)\n // log(\"calc\", m, mm, yy, [this.year + yy, mm, this.day])\n return Day.from([this.year + yy, mm, this.day])!\n }\n\n daysUntil(otherDay: DayInputLegacy): number {\n return Math.round(\n (new Day(otherDay)?.toDateUTC().getTime() - this.toDateUTC().getTime())\n / DAY_MS,\n )\n }\n\n // Shortcuts\n\n yesterday() {\n return this.dayOffset(-1)\n }\n\n tomorrow() {\n return this.dayOffset(+1)\n }\n}\n\nexport async function forEachDay(\n from: DayInputLegacy,\n to: DayInputLegacy,\n handler: (date: Day) => Promise<void> | void,\n) {\n let start = Day.from(from)\n const end = Day.from(to)\n // eslint-disable-next-line no-unmodified-loop-condition\n while (start && end && start?.days <= end?.days) {\n const result = handler(start)\n if (isPromise(result))\n await result\n start = start.dayOffset(+1)\n }\n}\n\nexport function today(): Day {\n return new Day()\n}\n\n/** @deprecated */\nexport function day(days?: DayInputLegacy): Day {\n return new Day(days)\n}\n\nexport function dateStringToDays(dateString: string): number {\n return Day.fromDate(new Date(dateString)).days\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"file":"day-legacy.mjs","names":[],"sources":["../../../src/common/data/day-legacy.ts"],"sourcesContent":["import { isPromise } from '../exec/promise'\nimport type { DayInput, DayValue } from './day'\nimport { DAY_MS } from './day'\n\n// See also and alternatives:\n// https://blog.openreplay.com/is-it-time-for-the-javascript-temporal-api\n// https://github.com/iamkun/dayjs\n// https://github.com/date-fns/date-fns\n\nexport type DayInputLegacy = DayInput | Day\n\n/**\n * Date represented as positive integer value. Years smaller 0 are not supported.\n * @deprecated\n */\nexport class Day {\n days: DayValue\n\n get value() {\n return this.days\n }\n\n constructor(days?: DayInputLegacy) {\n if (typeof days === 'number') {\n this.days = days\n return\n }\n\n if (days != null)\n days = Day.from(days)?.days\n\n if (days == null) {\n const date = new Date()\n this.days\n = date.getFullYear() * 10000\n + (date.getMonth() + 1) * 100\n + date.getDate()\n }\n else {\n this.days = days\n }\n }\n\n static fromNumber(n: number): Day {\n return new Day(n)\n }\n\n static fromString(dateString: string): Day | undefined {\n return Day.from(+dateString.replace(/\\D/g, '').slice(0, 8))\n }\n\n static fromDate(date: Date, utc = false): Day {\n return (\n utc\n ? Day.fromString(date.toISOString().substr(0, 10))\n : Day.from(\n date.getFullYear() * 10000\n + (date.getMonth() + 1) * 100\n + date.getDate(),\n )\n ) as Day\n }\n\n static fromDateUTC(date: Date): Day {\n return Day.fromDate(date, true)\n }\n\n /** @deprecated use fromDateUTC */\n static fromDateGMT(date: Date): Day {\n return Day.fromDate(date, true)\n }\n\n static from(value: DayInputLegacy, utc = false): Day | undefined {\n if (typeof value === 'number') {\n if (value < 100)\n return\n return new Day(value)\n }\n else if (typeof value === 'string') {\n return Day.fromString(value)\n }\n else if (Array.isArray(value) && value.length === 3) {\n const [year, month = 1, day = 1] = value\n if (month < 1 || month > 12 || day < 1 || day > 31)\n return\n return new Day(year * 10000 + month * 100 + day)\n }\n else if (value instanceof Date) {\n return Day.fromDate(value, utc)\n }\n else if (value instanceof Day) {\n return value\n }\n }\n\n toNumber(): number {\n return this.days\n }\n\n // Transformer\n\n /** Just for future extensions */\n toJson() {\n return this.days\n }\n\n toString(sep = '-') {\n const baseString = String(this.days)\n return (\n baseString.slice(0, 4)\n + sep\n + baseString.slice(4, 6)\n + sep\n + baseString.slice(6, 8)\n )\n }\n\n toDate(utc = false): Date {\n return utc\n ? new Date(`${this.toString()}T00:00:00.000Z`)\n : new Date(\n this.days / 10000, // year\n ((this.days / 100) % 100) - 1, // month\n this.days % 100, // day\n )\n }\n\n toDateUTC() {\n return this.toDate(true)\n }\n\n /** @deprecated use toDateUTC */\n toDateGMT() {\n return this.toDate(true)\n }\n\n get year() {\n return Math.floor(this.days / 10000)\n }\n\n get month() {\n return Math.floor((this.days / 100) % 100)\n }\n\n get day() {\n return Math.floor(this.days % 100)\n }\n\n // Calculations\n\n dayOffset(offset: number): Day {\n // Important! Don't use local time here due to summer/winter time days can\n // be longer or shorter!\n return Day.fromDateUTC(\n new Date(this.toDateUTC().getTime() + offset * DAY_MS),\n )\n }\n\n monthStart(): Day {\n return Day.from([this.year, this.month, 1])!\n }\n\n yearStart(): Day {\n return Day.from([this.year, 1, 1])!\n }\n\n /** Very stupid approach, only works for days <= 28 */\n monthOffset(offset: number): Day {\n const m = this.month + offset\n let mm = Math.floor((m - 1) % 12) + 1\n if (mm === 0)\n mm = 12\n const yy = Math.floor((m - 1) / 12)\n // log(\"calc\", m, mm, yy, [this.year + yy, mm, this.day])\n return Day.from([this.year + yy, mm, this.day])!\n }\n\n daysUntil(otherDay: DayInputLegacy): number {\n return Math.round(\n (new Day(otherDay)?.toDateUTC().getTime() - this.toDateUTC().getTime())\n / DAY_MS,\n )\n }\n\n // Shortcuts\n\n yesterday() {\n return this.dayOffset(-1)\n }\n\n tomorrow() {\n return this.dayOffset(+1)\n }\n}\n\nexport async function forEachDay(\n from: DayInputLegacy,\n to: DayInputLegacy,\n handler: (date: Day) => Promise<void> | void,\n) {\n let start = Day.from(from)\n const end = Day.from(to)\n // eslint-disable-next-line no-unmodified-loop-condition\n while (start && end && start?.days <= end?.days) {\n const result = handler(start)\n if (isPromise(result))\n await result\n start = start.dayOffset(+1)\n }\n}\n\nexport function today(): Day {\n return new Day()\n}\n\n/** @deprecated */\nexport function day(days?: DayInputLegacy): Day {\n return new Day(days)\n}\n\nexport function dateStringToDays(dateString: string): number {\n return Day.fromDate(new Date(dateString)).days\n}\n"],"mappings":"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"}
|
package/dist/common/data/day.cjs
CHANGED
|
@@ -1,2 +1,336 @@
|
|
|
1
|
-
Object.defineProperty(exports,Symbol.toStringTag,
|
|
1
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
2
|
+
const require_common_time = require('../time.cjs');
|
|
3
|
+
|
|
4
|
+
//#region src/common/data/day.ts
|
|
5
|
+
let testModeDay;
|
|
6
|
+
/**
|
|
7
|
+
* Enable test mode for date functions by forcing "today" to a fixed day value.
|
|
8
|
+
*
|
|
9
|
+
* Use a numeric DayValue like 20000101 (YYYYMMDD). This is intended for tests
|
|
10
|
+
* to make date-based logic deterministic. Call with no args to reset.
|
|
11
|
+
*
|
|
12
|
+
* @param ts - day to use as "today" in YYYYMMDD format (default: 20000101)
|
|
13
|
+
*/
|
|
14
|
+
function setDayTest(ts = 20000101) {
|
|
15
|
+
testModeDay = ts;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* @deprecated use TIME_DAY_MS
|
|
19
|
+
* Number of milliseconds in one calendar day (24 * 60 * 60 * 1000). */
|
|
20
|
+
const DAY_MS = require_common_time.TIME_DAY_MS;
|
|
21
|
+
/**
|
|
22
|
+
* Extract the year (YYYY) from a DayValue.
|
|
23
|
+
*
|
|
24
|
+
* @param day - day as YYYYMMDD
|
|
25
|
+
* @returns year as number (e.g. 2025)
|
|
26
|
+
*/
|
|
27
|
+
function dayYear(day) {
|
|
28
|
+
return Math.floor(day / 1e4);
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Extract the month (1-12) from a DayValue.
|
|
32
|
+
*
|
|
33
|
+
* @param day - day as YYYYMMDD
|
|
34
|
+
* @returns month number (1-12)
|
|
35
|
+
*/
|
|
36
|
+
function dayMonth(day) {
|
|
37
|
+
return Math.floor(day / 100 % 100);
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Extract the day of month (1-31) from a DayValue.
|
|
41
|
+
*
|
|
42
|
+
* @param day - day as YYYYMMDD
|
|
43
|
+
* @returns day of month (1-31)
|
|
44
|
+
*/
|
|
45
|
+
function dayDay(day) {
|
|
46
|
+
return Math.floor(day % 100);
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Split a DayValue into [year, month, day].
|
|
50
|
+
*
|
|
51
|
+
* @param day - day as YYYYMMDD
|
|
52
|
+
* @returns tuple [year, month, day]
|
|
53
|
+
*/
|
|
54
|
+
function dayToParts(day) {
|
|
55
|
+
return [
|
|
56
|
+
dayYear(day),
|
|
57
|
+
dayMonth(day),
|
|
58
|
+
dayDay(day)
|
|
59
|
+
];
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Convert a DayValue to a JavaScript Date.
|
|
63
|
+
*
|
|
64
|
+
* By default returns a local Date at midnight for the day. If `utc` is true
|
|
65
|
+
* the returned Date represents midnight UTC for that day.
|
|
66
|
+
*
|
|
67
|
+
* @param day - day as YYYYMMDD
|
|
68
|
+
* @param utc - whether to construct the Date in UTC (default: false)
|
|
69
|
+
* @returns Date object for the given day
|
|
70
|
+
*/
|
|
71
|
+
function dayToDate(day, utc = false) {
|
|
72
|
+
return utc ? /* @__PURE__ */ new Date(`${dayToString(day)}T00:00:00.000Z`) : new Date(day / 1e4, Math.max(0, day / 100 % 100 - 1), Math.max(1, day % 100));
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Return today's day as a DayValue (YYYYMMDD).
|
|
76
|
+
*
|
|
77
|
+
* If test mode has been enabled via `setDayTest` this returns the forced
|
|
78
|
+
* value instead. Otherwise it uses the current local date.
|
|
79
|
+
*/
|
|
80
|
+
function dayFromToday() {
|
|
81
|
+
return testModeDay ?? dayFromDate(/* @__PURE__ */ new Date());
|
|
82
|
+
}
|
|
83
|
+
/**
|
|
84
|
+
* Convert multiple input types to a DayValue (YYYYMMDD).
|
|
85
|
+
*
|
|
86
|
+
* Supports numbers (DayValue), strings, Date objects and [year, month?, day?]
|
|
87
|
+
* tuples. Returns undefined for invalid or unsupported values.
|
|
88
|
+
*
|
|
89
|
+
* @param value - input to convert
|
|
90
|
+
* @param utc - when converting from Date, interpret as UTC if true
|
|
91
|
+
*/
|
|
92
|
+
function dayFromAny(value, utc = false) {
|
|
93
|
+
if (typeof value === "number") {
|
|
94
|
+
if (value < 100) return;
|
|
95
|
+
return value;
|
|
96
|
+
} else if (typeof value === "string") return dayFromString(value);
|
|
97
|
+
else if (Array.isArray(value) && value.length >= 1) return dayFromParts(...value);
|
|
98
|
+
else if (value instanceof Date) return dayFromDate(value, utc);
|
|
99
|
+
}
|
|
100
|
+
/** Convert a DayValue to a Date at midnight UTC. */
|
|
101
|
+
function dayToDateUTC(day) {
|
|
102
|
+
return dayToDate(day, true);
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* @deprecated use dayToDateUTC
|
|
106
|
+
*
|
|
107
|
+
* Kept for backwards compatibility; returns a Date for midnight UTC.
|
|
108
|
+
*/
|
|
109
|
+
function dayToDateGMT(day) {
|
|
110
|
+
return dayToDate(day, true);
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Convert a JavaScript Date to a DayValue (YYYYMMDD).
|
|
114
|
+
*
|
|
115
|
+
* If `utc` is true the function uses the ISO string representation to
|
|
116
|
+
* calculate the day in UTC. Otherwise it uses local date components.
|
|
117
|
+
*/
|
|
118
|
+
function dayFromDate(date, utc = false) {
|
|
119
|
+
return utc ? dayFromString(date.toISOString()) : date.getFullYear() * 1e4 + (date.getMonth() + 1) * 100 + date.getDate();
|
|
120
|
+
}
|
|
121
|
+
/** Convert a Date to DayValue using UTC. */
|
|
122
|
+
function dayFromDateUTC(date) {
|
|
123
|
+
return dayFromDate(date, true);
|
|
124
|
+
}
|
|
125
|
+
/** @deprecated use dayFromDateUTC */
|
|
126
|
+
/**
|
|
127
|
+
* Deprecated: use `dayFromDateUTC`.
|
|
128
|
+
*
|
|
129
|
+
* Kept for backwards compatibility; converts a Date to a UTC DayValue.
|
|
130
|
+
*/
|
|
131
|
+
function dayFromDateGMT(date) {
|
|
132
|
+
return dayFromDate(date, true);
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Convert a DayValue to a UNIX timestamp in seconds. Returns seconds since
|
|
136
|
+
* epoch for midnight of the given day. Defaults to UTC.
|
|
137
|
+
*/
|
|
138
|
+
function dayToTimestampSeconds(day, utc = true) {
|
|
139
|
+
return Math.floor(dayToDate(day, utc).getTime() / 1e3);
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Convert a DayValue to a timestamp in milliseconds for midnight of that day.
|
|
143
|
+
* Defaults to UTC when constructing the Date.
|
|
144
|
+
*/
|
|
145
|
+
function dayToTimestamp(day, utc = true) {
|
|
146
|
+
return dayToDate(day, utc).getTime();
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Convert a timestamp in milliseconds to a DayValue. The timestamp is turned
|
|
150
|
+
* into a Date and then converted; `utc` controls interpretation.
|
|
151
|
+
*/
|
|
152
|
+
function dayFromTimestamp(ms, utc = true) {
|
|
153
|
+
return dayFromDate(new Date(ms), utc);
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Convert a UNIX timestamp in seconds to a DayValue.
|
|
157
|
+
*
|
|
158
|
+
* @param ms - seconds since epoch
|
|
159
|
+
*/
|
|
160
|
+
function dayFromTimestampSeconds(ms, utc = true) {
|
|
161
|
+
return dayFromDate(new Date(Math.floor(ms * 1e3)), utc);
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* Format a DayValue as a string with an optional separator.
|
|
165
|
+
*
|
|
166
|
+
* Example: dayToString(20250907) -> "2025-09-07"
|
|
167
|
+
*/
|
|
168
|
+
function dayToString(day, sep = "-") {
|
|
169
|
+
const baseString = String(day);
|
|
170
|
+
return baseString.slice(0, 4) + sep + baseString.slice(4, 6) + sep + baseString.slice(6, 8);
|
|
171
|
+
}
|
|
172
|
+
/**
|
|
173
|
+
* Build a DayValue from numeric parts. Returns undefined for invalid parts.
|
|
174
|
+
*
|
|
175
|
+
* @param year - full year (e.g. 2025)
|
|
176
|
+
* @param month - 1-12 (default 1)
|
|
177
|
+
* @param day - 1-31 (default 1)
|
|
178
|
+
*/
|
|
179
|
+
function dayFromParts(year, month = 1, day = 1) {
|
|
180
|
+
if (month < 1 || month > 12 || day < 1 || day > 31) return;
|
|
181
|
+
return year * 1e4 + month * 100 + day;
|
|
182
|
+
}
|
|
183
|
+
/**
|
|
184
|
+
* Parse a string into a DayValue by extracting up to 8 digits (YYYYMMDD).
|
|
185
|
+
* Returns undefined for invalid results.
|
|
186
|
+
*
|
|
187
|
+
* Example:
|
|
188
|
+
* dayValue === dayFromString(String(dayValue))
|
|
189
|
+
*/
|
|
190
|
+
function dayFromString(value) {
|
|
191
|
+
const string = String(value).replace(/\D/g, "").slice(0, 8);
|
|
192
|
+
if (string.length === 8) return +string;
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* Return the first day of the month for the given DayValue. An optional
|
|
196
|
+
* `offset` (positive or negative) moves the result by months.
|
|
197
|
+
*
|
|
198
|
+
* @param day - source DayValue
|
|
199
|
+
* @param offset - months to offset (default 0)
|
|
200
|
+
*/
|
|
201
|
+
function dayMonthStart(day, offset = 0) {
|
|
202
|
+
let year = dayYear(day);
|
|
203
|
+
let month = dayMonth(day);
|
|
204
|
+
if (offset !== 0) {
|
|
205
|
+
month += offset;
|
|
206
|
+
year += Math.floor((month - 1) / 12);
|
|
207
|
+
month = Math.floor((month - 1) % 12) + 1;
|
|
208
|
+
if (month === 0) month = 12;
|
|
209
|
+
}
|
|
210
|
+
return dayFromParts(year, month, 1);
|
|
211
|
+
}
|
|
212
|
+
/**
|
|
213
|
+
* Return the day offset by whole months, keeping the day-of-month when possible.
|
|
214
|
+
* If the target month has fewer days, the result is clamped to the last day.
|
|
215
|
+
*
|
|
216
|
+
* @param day - source DayValue
|
|
217
|
+
* @param offset - months to offset (positive or negative)
|
|
218
|
+
*/
|
|
219
|
+
function dayMonthOffset(day, offset) {
|
|
220
|
+
let year = dayYear(day);
|
|
221
|
+
let month = dayMonth(day);
|
|
222
|
+
const dayOfMonth = dayDay(day);
|
|
223
|
+
if (offset !== 0) {
|
|
224
|
+
month += offset;
|
|
225
|
+
year += Math.floor((month - 1) / 12);
|
|
226
|
+
month = Math.floor((month - 1) % 12) + 1;
|
|
227
|
+
if (month === 0) month = 12;
|
|
228
|
+
}
|
|
229
|
+
const maxDay = dayDaysInMonth(year, month);
|
|
230
|
+
return dayFromParts(year, month, Math.min(dayOfMonth, maxDay));
|
|
231
|
+
}
|
|
232
|
+
/**
|
|
233
|
+
* Return the first day of the year for the given DayValue. `offset` moves
|
|
234
|
+
* the year by the given amount.
|
|
235
|
+
*/
|
|
236
|
+
function dayYearStart(day, offset = 0) {
|
|
237
|
+
return dayFromParts(dayYear(day) + offset, 1, 1);
|
|
238
|
+
}
|
|
239
|
+
/**
|
|
240
|
+
* Return the day offset by whole years, keeping month and day when possible.
|
|
241
|
+
* If the target month has fewer days, the result is clamped to the last day.
|
|
242
|
+
*
|
|
243
|
+
* @param day - source DayValue
|
|
244
|
+
* @param offset - years to offset (positive or negative)
|
|
245
|
+
*/
|
|
246
|
+
function dayYearOffset(day, offset) {
|
|
247
|
+
const year = dayYear(day) + offset;
|
|
248
|
+
const month = dayMonth(day);
|
|
249
|
+
const dayOfMonth = dayDay(day);
|
|
250
|
+
const maxDay = dayDaysInMonth(year, month);
|
|
251
|
+
return dayFromParts(year, month, Math.min(dayOfMonth, maxDay));
|
|
252
|
+
}
|
|
253
|
+
/** Return number of days in a given month. Month is 1-12. */
|
|
254
|
+
function dayDaysInMonth(year, month) {
|
|
255
|
+
return new Date(Date.UTC(year, month, 0)).getUTCDate();
|
|
256
|
+
}
|
|
257
|
+
/**
|
|
258
|
+
* Offset a DayValue by a number of days. Uses timestamp math to avoid local
|
|
259
|
+
* DST issues.
|
|
260
|
+
*
|
|
261
|
+
* @param day - source DayValue
|
|
262
|
+
* @param offset - days to add (negative to subtract)
|
|
263
|
+
*/
|
|
264
|
+
function dayOffset(day, offset) {
|
|
265
|
+
return dayFromTimestamp(dayToTimestamp(day) + offset * require_common_time.TIME_DAY_MS);
|
|
266
|
+
}
|
|
267
|
+
/**
|
|
268
|
+
* Compute the difference in whole days between two DayValues (right - left).
|
|
269
|
+
*/
|
|
270
|
+
function dayDiff(left, right) {
|
|
271
|
+
return Math.round((dayToTimestamp(right) - dayToTimestamp(left)) / require_common_time.TIME_DAY_MS);
|
|
272
|
+
}
|
|
273
|
+
/**
|
|
274
|
+
* Return an array of DayValues from left to right (inclusive).
|
|
275
|
+
*
|
|
276
|
+
* If `right` is omitted it defaults to today. If `left` is negative it is
|
|
277
|
+
* interpreted as an offset relative to `right` (e.g. -7 means the last 7 days).
|
|
278
|
+
*/
|
|
279
|
+
function dayRange(left, right) {
|
|
280
|
+
const list = [];
|
|
281
|
+
if (right == null) right = dayFromToday();
|
|
282
|
+
if (left < 0) left = dayOffset(right, left + 1);
|
|
283
|
+
while (left <= right) {
|
|
284
|
+
list.push(left);
|
|
285
|
+
left = dayOffset(left, 1);
|
|
286
|
+
}
|
|
287
|
+
return list;
|
|
288
|
+
}
|
|
289
|
+
/** Iterator, see dayRange */
|
|
290
|
+
/**
|
|
291
|
+
* Generator that yields DayValues from left to right (inclusive). Same rules
|
|
292
|
+
* as `dayRange` regarding defaults and negative left values.
|
|
293
|
+
*/
|
|
294
|
+
function* dayIterator(left, right) {
|
|
295
|
+
const list = [];
|
|
296
|
+
if (right == null) right = dayFromToday();
|
|
297
|
+
if (left < 0) left = dayOffset(right, left + 1);
|
|
298
|
+
while (left <= right) {
|
|
299
|
+
yield left;
|
|
300
|
+
left = dayOffset(left, 1);
|
|
301
|
+
}
|
|
302
|
+
return list;
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
//#endregion
|
|
306
|
+
exports.DAY_MS = DAY_MS;
|
|
307
|
+
exports.dayDay = dayDay;
|
|
308
|
+
exports.dayDaysInMonth = dayDaysInMonth;
|
|
309
|
+
exports.dayDiff = dayDiff;
|
|
310
|
+
exports.dayFromAny = dayFromAny;
|
|
311
|
+
exports.dayFromDate = dayFromDate;
|
|
312
|
+
exports.dayFromDateGMT = dayFromDateGMT;
|
|
313
|
+
exports.dayFromDateUTC = dayFromDateUTC;
|
|
314
|
+
exports.dayFromParts = dayFromParts;
|
|
315
|
+
exports.dayFromString = dayFromString;
|
|
316
|
+
exports.dayFromTimestamp = dayFromTimestamp;
|
|
317
|
+
exports.dayFromTimestampSeconds = dayFromTimestampSeconds;
|
|
318
|
+
exports.dayFromToday = dayFromToday;
|
|
319
|
+
exports.dayIterator = dayIterator;
|
|
320
|
+
exports.dayMonth = dayMonth;
|
|
321
|
+
exports.dayMonthOffset = dayMonthOffset;
|
|
322
|
+
exports.dayMonthStart = dayMonthStart;
|
|
323
|
+
exports.dayOffset = dayOffset;
|
|
324
|
+
exports.dayRange = dayRange;
|
|
325
|
+
exports.dayToDate = dayToDate;
|
|
326
|
+
exports.dayToDateGMT = dayToDateGMT;
|
|
327
|
+
exports.dayToDateUTC = dayToDateUTC;
|
|
328
|
+
exports.dayToParts = dayToParts;
|
|
329
|
+
exports.dayToString = dayToString;
|
|
330
|
+
exports.dayToTimestamp = dayToTimestamp;
|
|
331
|
+
exports.dayToTimestampSeconds = dayToTimestampSeconds;
|
|
332
|
+
exports.dayYear = dayYear;
|
|
333
|
+
exports.dayYearOffset = dayYearOffset;
|
|
334
|
+
exports.dayYearStart = dayYearStart;
|
|
335
|
+
exports.setDayTest = setDayTest;
|
|
2
336
|
//# sourceMappingURL=day.cjs.map
|