@design-edito/tools 0.4.5 → 0.4.11
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/TODO.md +269 -0
- package/agnostic/arrays/dedupe/index.js +9 -7
- package/agnostic/arrays/dedupe/index.test.js +24 -0
- package/agnostic/arrays/find-duplicates/index.js +34 -22
- package/agnostic/arrays/find-duplicates/index.test.js +31 -0
- package/agnostic/arrays/index.d.ts +2 -2
- package/agnostic/arrays/index.js +2 -2
- package/agnostic/arrays/is-array-of/index.js +28 -26
- package/agnostic/arrays/is-array-of/index.test.js +56 -0
- package/agnostic/arrays/make/index.d.ts +1 -1
- package/agnostic/arrays/make/index.js +11 -6
- package/agnostic/arrays/make/index.test.js +10 -0
- package/agnostic/arrays/random-pick/index.js +38 -22
- package/agnostic/arrays/random-pick/index.test.js +23 -0
- package/agnostic/arrays/shuffle/index.js +15 -11
- package/agnostic/arrays/shuffle/index.test.js +14 -0
- package/agnostic/booleans/is-falsy/index.js +24 -15
- package/agnostic/booleans/is-falsy/index.test.js +26 -0
- package/agnostic/colors/channels/index.js +139 -936
- package/agnostic/colors/channels/index.test.js +64 -0
- package/agnostic/colors/contrast/index.js +24 -643
- package/agnostic/colors/contrast/index.test.js +21 -0
- package/agnostic/colors/convert/index.js +811 -837
- package/agnostic/colors/convert/index.test.js +98 -0
- package/agnostic/colors/cssColorsMap.js +153 -0
- package/agnostic/colors/distance/index.js +66 -538
- package/agnostic/colors/distance/index.test.js +21 -0
- package/agnostic/colors/grayscale/index.js +95 -872
- package/agnostic/colors/grayscale/index.test.js +34 -0
- package/agnostic/colors/index.d.ts +4 -4
- package/agnostic/colors/index.js +4 -4
- package/agnostic/colors/invert/index.js +34 -719
- package/agnostic/colors/invert/index.test.js +31 -0
- package/agnostic/colors/lerp/index.js +75 -804
- package/agnostic/colors/lerp/index.test.js +55 -0
- package/agnostic/colors/luminance/index.js +17 -625
- package/agnostic/colors/luminance/index.test.js +30 -0
- package/agnostic/colors/palette/index.js +83 -917
- package/agnostic/colors/palette/index.test.js +35 -0
- package/agnostic/colors/rotate/index.js +35 -835
- package/agnostic/colors/rotate/index.test.js +45 -0
- package/agnostic/colors/tidy/index.js +79 -530
- package/agnostic/colors/tidy/index.test.js +45 -0
- package/agnostic/colors/typechecks/index.js +188 -250
- package/agnostic/colors/typechecks/index.test.js +113 -0
- package/agnostic/colors/types.js +1 -0
- package/agnostic/css/bem/index.js +134 -171
- package/agnostic/css/clss/index.js +64 -29
- package/agnostic/css/clss/index.test.js +60 -0
- package/agnostic/css/generate-nice-color/index.js +26 -71
- package/agnostic/css/generate-nice-color/index.test.js +8 -0
- package/agnostic/css/index.d.ts +2 -2
- package/agnostic/css/index.js +2 -2
- package/agnostic/css/is-valid-css-class-name/index.js +14 -8
- package/agnostic/css/is-valid-css-class-name/index.test.js +36 -0
- package/agnostic/css/scale/index.d.ts +46 -16
- package/agnostic/css/scale/index.js +70 -54
- package/agnostic/css/scale/index.test.js +88 -0
- package/agnostic/css/styles-set/index.js +151 -178
- package/agnostic/errors/index.d.ts +1 -1
- package/agnostic/errors/index.js +1 -1
- package/agnostic/errors/register/index.js +45 -49
- package/agnostic/errors/unknown-to-string/index.js +17 -10
- package/agnostic/errors/unknown-to-string/index.test.js +35 -0
- package/agnostic/html/get-node-ancestors/index.js +29 -29
- package/agnostic/html/get-node-ancestors/index.test.js +58 -0
- package/agnostic/html/get-position-inside-parent/index.js +13 -8
- package/agnostic/html/get-position-inside-parent/index.test.js +56 -0
- package/agnostic/html/hyper-json/cast/index.js +128 -2931
- package/agnostic/html/hyper-json/index.js +23 -2954
- package/agnostic/html/hyper-json/method/index.js +10 -14
- package/agnostic/html/hyper-json/serialize/index.js +88 -222
- package/agnostic/html/hyper-json/smart-tags/coalesced/add/index.js +14 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/addclass/index.js +27 -2937
- package/agnostic/html/hyper-json/smart-tags/coalesced/and/index.js +13 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/append/index.js +34 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/at/index.js +42 -2935
- package/agnostic/html/hyper-json/smart-tags/coalesced/call/index.js +47 -2937
- package/agnostic/html/hyper-json/smart-tags/coalesced/clone/index.js +10 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/deleteproperties/index.js +45 -2936
- package/agnostic/html/hyper-json/smart-tags/coalesced/equals/index.js +22 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/getattribute/index.js +26 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/getproperties/index.js +19 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/getproperty/index.js +67 -2935
- package/agnostic/html/hyper-json/smart-tags/coalesced/hjparse/index.js +21 -2937
- package/agnostic/html/hyper-json/smart-tags/coalesced/hjstringify/index.js +89 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/if/index.js +20 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/index.d.ts +11 -11
- package/agnostic/html/hyper-json/smart-tags/coalesced/index.js +11 -11
- package/agnostic/html/hyper-json/smart-tags/coalesced/initialize/index.js +37 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/join/index.js +16 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/length/index.js +21 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/map/index.js +31 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/negate/index.js +10 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/notrailing/index.js +33 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/or/index.js +13 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/pickrandom/index.js +17 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/populate/index.js +59 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/print/index.js +23 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/push/index.js +10 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/pusheach/index.js +26 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/recordtoarray/index.js +10 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/removeattribute/index.js +53 -2935
- package/agnostic/html/hyper-json/smart-tags/coalesced/removeclass/index.js +27 -2937
- package/agnostic/html/hyper-json/smart-tags/coalesced/renameproperty/index.js +31 -2937
- package/agnostic/html/hyper-json/smart-tags/coalesced/replace/index.js +55 -2940
- package/agnostic/html/hyper-json/smart-tags/coalesced/select/index.js +29 -2935
- package/agnostic/html/hyper-json/smart-tags/coalesced/set/index.js +29 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/setattribute/index.js +53 -2935
- package/agnostic/html/hyper-json/smart-tags/coalesced/setproperty/index.js +232 -2936
- package/agnostic/html/hyper-json/smart-tags/coalesced/sorton/index.js +89 -2936
- package/agnostic/html/hyper-json/smart-tags/coalesced/split/index.js +20 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/spread/index.js +23 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/toarray/index.js +11 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/toboolean/index.js +11 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/toelement/index.js +17 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/toggleclass/index.js +27 -2937
- package/agnostic/html/hyper-json/smart-tags/coalesced/tonodelist/index.js +11 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/tonull/index.js +10 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/tonumber/index.js +11 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/torecord/index.js +11 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/toref/index.js +11 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/tostring/index.js +11 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/totext/index.js +11 -2939
- package/agnostic/html/hyper-json/smart-tags/coalesced/transformselected/index.js +84 -2938
- package/agnostic/html/hyper-json/smart-tags/coalesced/trim/index.js +14 -2938
- package/agnostic/html/hyper-json/smart-tags/index.js +28 -181
- package/agnostic/html/hyper-json/smart-tags/isolated/any/index.js +12 -195
- package/agnostic/html/hyper-json/smart-tags/isolated/array/index.js +12 -195
- package/agnostic/html/hyper-json/smart-tags/isolated/boolean/index.js +12 -2939
- package/agnostic/html/hyper-json/smart-tags/isolated/element/index.js +24 -2938
- package/agnostic/html/hyper-json/smart-tags/isolated/get/index.js +18 -2938
- package/agnostic/html/hyper-json/smart-tags/isolated/guess/index.js +56 -2937
- package/agnostic/html/hyper-json/smart-tags/isolated/index.d.ts +2 -2
- package/agnostic/html/hyper-json/smart-tags/isolated/index.js +2 -2
- package/agnostic/html/hyper-json/smart-tags/isolated/nodelist/index.js +18 -2938
- package/agnostic/html/hyper-json/smart-tags/isolated/null/index.js +9 -193
- package/agnostic/html/hyper-json/smart-tags/isolated/number/index.js +16 -2938
- package/agnostic/html/hyper-json/smart-tags/isolated/record/index.js +12 -2938
- package/agnostic/html/hyper-json/smart-tags/isolated/ref/index.js +40 -2935
- package/agnostic/html/hyper-json/smart-tags/isolated/string/index.js +16 -2938
- package/agnostic/html/hyper-json/smart-tags/isolated/text/index.js +18 -2938
- package/agnostic/html/hyper-json/transformer/index.js +112 -148
- package/agnostic/html/hyper-json/tree/index.js +411 -2928
- package/agnostic/html/hyper-json/types/index.js +27 -18
- package/agnostic/html/hyper-json/utils/index.js +497 -2921
- package/agnostic/html/index.d.ts +2 -2
- package/agnostic/html/index.js +2 -2
- package/agnostic/html/insert-node/index.js +27 -16
- package/agnostic/html/insert-node/index.test.js +73 -0
- package/agnostic/html/placeholders/index.js +26 -29
- package/agnostic/html/replace-in-element/index.js +31 -48
- package/agnostic/html/replace-in-element/index.test.js +80 -0
- package/agnostic/html/selector-to-element/index.js +53 -39
- package/agnostic/html/selector-to-element/index.test.js +69 -0
- package/agnostic/html/string-to-nodes/index.js +24 -25
- package/agnostic/html/string-to-nodes/index.test.js +54 -0
- package/agnostic/index.d.ts +4 -4
- package/agnostic/index.js +4 -4
- package/agnostic/misc/assert/index.js +60 -66
- package/agnostic/misc/cast/index.js +123 -57
- package/agnostic/misc/cast/index.test.js +134 -0
- package/agnostic/misc/connection/index.js +55 -36
- package/agnostic/misc/connection/index.test.js +143 -0
- package/agnostic/misc/crawler/index.js +68 -46
- package/agnostic/misc/crawler/index.test.js +56 -0
- package/agnostic/misc/crossenv/detect-runtime/index.js +41 -13
- package/agnostic/misc/crossenv/detect-runtime/index.test.js +24 -0
- package/agnostic/misc/crossenv/types.js +21 -14
- package/agnostic/misc/crossenv/window/index.js +45 -24
- package/agnostic/misc/crossenv/window/index.test.js +24 -0
- package/agnostic/misc/data-size/index.js +182 -294
- package/agnostic/misc/data-size/index.test.js +100 -0
- package/agnostic/misc/data-size/types.js +1 -0
- package/agnostic/misc/index.d.ts +5 -5
- package/agnostic/misc/index.js +5 -5
- package/agnostic/misc/is-constructor-function/index.js +12 -6
- package/agnostic/misc/is-constructor-function/index.test.js +36 -0
- package/agnostic/misc/is-nullish/index.js +24 -11
- package/agnostic/misc/is-nullish/index.test.js +44 -0
- package/agnostic/misc/logs/index.d.ts +1 -1
- package/agnostic/misc/logs/index.js +1 -1
- package/agnostic/misc/logs/logger/index.js +115 -140
- package/agnostic/misc/logs/make-text-block/index.js +13 -13
- package/agnostic/misc/logs/styles/index.js +29 -48
- package/agnostic/misc/lorem-ipsum/index.js +51 -201
- package/agnostic/misc/lorem-ipsum/index.test.js +49 -0
- package/agnostic/misc/normalize-extension/index.js +99 -88
- package/agnostic/misc/normalize-extension/index.test.js +40 -0
- package/agnostic/misc/outcome/index.js +20 -14
- package/agnostic/misc/outcome/index.test.js +40 -0
- package/agnostic/numbers/absolute-modulo/index.js +9 -6
- package/agnostic/numbers/absolute-modulo/index.test.js +23 -0
- package/agnostic/numbers/approximate-rational/index.js +86 -69
- package/agnostic/numbers/approximate-rational/index.test.js +90 -0
- package/agnostic/numbers/clamp/index.js +12 -8
- package/agnostic/numbers/clamp/index.test.js +24 -0
- package/agnostic/numbers/geometric-progressions/index.js +25 -16
- package/agnostic/numbers/geometric-progressions/index.test.js +45 -0
- package/agnostic/numbers/index.d.ts +2 -2
- package/agnostic/numbers/index.js +2 -2
- package/agnostic/numbers/interpolate/index.js +25 -10
- package/agnostic/numbers/interpolate/index.test.js +40 -0
- package/agnostic/numbers/round/index.js +30 -15
- package/agnostic/numbers/round/index.test.js +56 -0
- package/agnostic/objects/deep-get-property/index.js +30 -27
- package/agnostic/objects/deep-get-property/index.test.js +59 -0
- package/agnostic/objects/enums/is-in-enum/index.js +17 -11
- package/agnostic/objects/enums/is-in-enum/index.test.js +100 -0
- package/agnostic/objects/flatten-getters/index.js +15 -14
- package/agnostic/objects/flatten-getters/index.test.js +78 -0
- package/agnostic/objects/index.d.ts +4 -4
- package/agnostic/objects/index.js +4 -4
- package/agnostic/objects/is-object/index.js +16 -9
- package/agnostic/objects/is-object/index.test.js +60 -0
- package/agnostic/objects/is-record/index.js +12 -7
- package/agnostic/objects/is-record/index.test.js +48 -0
- package/agnostic/objects/record-format/index.js +18 -12
- package/agnostic/objects/record-format/index.test.js +92 -0
- package/agnostic/objects/record-map/index.js +16 -11
- package/agnostic/objects/record-map/index.test.js +56 -0
- package/agnostic/objects/sort-keys/index.js +15 -11
- package/agnostic/objects/sort-keys/index.test.js +37 -0
- package/agnostic/objects/validation/index.js +21 -8
- package/agnostic/objects/validation/index.test.js +72 -0
- package/agnostic/optim/memoize/index.js +24 -16
- package/agnostic/optim/memoize/index.test.js +30 -0
- package/agnostic/optim/throttle-debounce/index.js +120 -102
- package/agnostic/optim/throttle-debounce/index.test.js +44 -0
- package/agnostic/optim/throttle-debounce/types.js +1 -0
- package/agnostic/random/hex-char/index.js +8 -10
- package/agnostic/random/hex-char/index.test.js +20 -0
- package/agnostic/random/index.d.ts +1 -1
- package/agnostic/random/index.js +1 -1
- package/agnostic/random/random/index.js +17 -14
- package/agnostic/random/random/index.test.js +73 -0
- package/agnostic/random/uuid/index.js +28 -20
- package/agnostic/random/uuid/index.test.js +45 -0
- package/agnostic/regexps/index.js +126 -84
- package/agnostic/regexps/index.test.js +108 -0
- package/agnostic/sanitization/file-name/index.js +24 -8
- package/agnostic/sanitization/file-name/index.test.js +23 -0
- package/agnostic/sanitization/html/index.js +172 -122
- package/agnostic/sanitization/index.d.ts +1 -1
- package/agnostic/sanitization/index.js +1 -1
- package/agnostic/sanitization/path/index.js +23 -15
- package/agnostic/sanitization/path/index.test.js +18 -0
- package/agnostic/sanitization/types.js +1 -0
- package/agnostic/sanitization/user-input/index.js +36 -24
- package/agnostic/sanitization/user-input/index.test.js +31 -0
- package/agnostic/strings/char-codes/index.js +123 -55
- package/agnostic/strings/index.d.ts +1 -1
- package/agnostic/strings/index.js +1 -1
- package/agnostic/strings/matches/index.js +35 -16
- package/agnostic/strings/normalize-indent/index.js +34 -16
- package/agnostic/strings/parse-table/index.js +153 -86
- package/agnostic/strings/replace-all/index.js +36 -15
- package/agnostic/strings/to-alphanum/index.js +23 -8
- package/agnostic/strings/trim/index.js +22 -9
- package/agnostic/time/dates/format-date/index.js +140 -72
- package/agnostic/time/duration/index.js +106 -140
- package/agnostic/time/timeout/index.js +24 -16
- package/agnostic/time/transitions/index.js +200 -158
- package/agnostic/time/wait/index.js +10 -8
- package/agnostic/typescript/types.js +1 -0
- package/components/BeforeAfter/index.controlled.js +95 -0
- package/components/BeforeAfter/index.js +54 -189
- package/components/BeforeAfter/utils.js +9 -0
- package/components/Disclaimer/index.js +50 -110
- package/components/Drawer/index.js +81 -196
- package/components/EventListener/index.js +29 -80
- package/components/Gallery/index.js +146 -221
- package/components/Gallery/utils.js +12 -0
- package/components/Image/index.js +66 -293
- package/components/IntersectionObserver/index.js +62 -110
- package/components/Overlayer/index.js +59 -103
- package/components/Paginator/index.js +124 -155
- package/components/ResizeObserver/index.js +66 -119
- package/components/ResizeObserver/style.module.css +0 -0
- package/components/Scrllgngn/index.js +171 -468
- package/components/ScrollListener/index.js +97 -276
- package/components/ScrollListener/utils.js +51 -0
- package/components/Sequencer/index.controlled.js +67 -0
- package/components/Sequencer/index.js +105 -262
- package/components/ShadowRoot/index.js +42 -96
- package/components/Subtitles/index.js +107 -244
- package/components/Subtitles/types.js +1 -0
- package/components/Subtitles/utils.js +102 -0
- package/components/Theatre/index.js +88 -136
- package/components/UIModule/index.js +156 -199
- package/components/Video/index.js +292 -857
- package/components/Video/utils.js +137 -0
- package/components/_WIP_AudioQuote/index.js +1 -0
- package/components/_WIP_Icon/index.js +1 -0
- package/components/index.d.ts +4 -4
- package/components/index.js +4 -4
- package/components/public-classnames.js +18 -0
- package/components/utils/index.js +11 -11
- package/components/utils/types.js +1 -0
- package/index.d.ts +1 -1
- package/index.js +1 -1
- package/node/@aws-s3/index.test.js +6 -0
- package/node/@aws-s3/storage/directory/copy-dir/index.js +66 -72
- package/node/@aws-s3/storage/directory/index.d.ts +1 -1
- package/node/@aws-s3/storage/directory/index.js +1 -1
- package/node/@aws-s3/storage/directory/list/index.js +32 -42
- package/node/@aws-s3/storage/directory/move-dir/index.js +68 -86
- package/node/@aws-s3/storage/directory/remove-dir/index.js +56 -67
- package/node/@aws-s3/storage/file/copy/index.js +41 -53
- package/node/@aws-s3/storage/file/download/index.js +29 -40
- package/node/@aws-s3/storage/file/exists/index.js +35 -43
- package/node/@aws-s3/storage/file/index.d.ts +1 -1
- package/node/@aws-s3/storage/file/index.js +1 -1
- package/node/@aws-s3/storage/file/move/index.js +57 -63
- package/node/@aws-s3/storage/file/remove/index.js +35 -43
- package/node/@aws-s3/storage/file/stat/index.js +33 -47
- package/node/@aws-s3/storage/file/upload/index.js +52 -63
- package/node/@design-edito/index.js +1 -0
- package/node/@express/@multer/index.js +61 -55
- package/node/@google-cloud/storage/bucket/get-metadata/index.js +25 -29
- package/node/@google-cloud/storage/directory/copy-dir/index.js +35 -41
- package/node/@google-cloud/storage/directory/index.d.ts +1 -1
- package/node/@google-cloud/storage/directory/index.js +1 -1
- package/node/@google-cloud/storage/directory/list/index.js +28 -35
- package/node/@google-cloud/storage/directory/move-dir/index.js +43 -42
- package/node/@google-cloud/storage/directory/remove-dir/index.js +34 -38
- package/node/@google-cloud/storage/file/copy/index.js +35 -40
- package/node/@google-cloud/storage/file/download/index.js +27 -34
- package/node/@google-cloud/storage/file/exists/index.js +25 -31
- package/node/@google-cloud/storage/file/generate-signed-url/index.js +33 -35
- package/node/@google-cloud/storage/file/get-metadata/index.js +28 -31
- package/node/@google-cloud/storage/file/get-permissions/index.js +25 -31
- package/node/@google-cloud/storage/file/index.d.ts +3 -3
- package/node/@google-cloud/storage/file/index.js +3 -3
- package/node/@google-cloud/storage/file/move/index.js +38 -42
- package/node/@google-cloud/storage/file/remove/index.js +34 -35
- package/node/@google-cloud/storage/file/revoke-signed-urls/index.js +32 -95
- package/node/@google-cloud/storage/file/stat/index.js +34 -38
- package/node/@google-cloud/storage/file/update-metadata/index.js +30 -31
- package/node/@google-cloud/storage/file/upload/index.js +44 -46
- package/node/@google-cloud/storage/index.d.ts +1 -1
- package/node/@google-cloud/storage/index.js +1 -1
- package/node/cloud-storage/clients/index.js +35 -15
- package/node/cloud-storage/operations/copy-dir/index.js +30 -203
- package/node/cloud-storage/operations/copy-file/index.js +30 -152
- package/node/cloud-storage/operations/download-file/index.js +30 -103
- package/node/cloud-storage/operations/exists-file/index.js +30 -103
- package/node/cloud-storage/operations/index.d.ts +2 -2
- package/node/cloud-storage/operations/index.js +2 -2
- package/node/cloud-storage/operations/list-dir/index.js +29 -98
- package/node/cloud-storage/operations/move-dir/index.js +30 -169
- package/node/cloud-storage/operations/move-file/index.js +30 -157
- package/node/cloud-storage/operations/remove-dir/index.js +29 -159
- package/node/cloud-storage/operations/remove-file/index.js +29 -121
- package/node/cloud-storage/operations/stat-file/index.js +29 -124
- package/node/cloud-storage/operations/upload-file/index.js +30 -162
- package/node/encryption/@aes-256-gcm/buffer/index.js +31 -72
- package/node/encryption/@aes-256-gcm/uint8-array/index.js +55 -55
- package/node/encryption/key/index.js +19 -12
- package/node/files/index.d.ts +1 -1
- package/node/files/index.js +1 -1
- package/node/files/is-in-directory/index.js +11 -8
- package/node/files/read-write/index.js +11 -15
- package/node/files/subpaths/index.js +156 -121
- package/node/ftps/directory/copy-dir/index.js +55 -62
- package/node/ftps/directory/list/index.js +24 -29
- package/node/ftps/directory/move-dir/index.js +38 -38
- package/node/ftps/directory/remove-dir/index.js +39 -42
- package/node/ftps/file/copy/index.js +42 -47
- package/node/ftps/file/download/index.js +29 -34
- package/node/ftps/file/exists/index.js +38 -36
- package/node/ftps/file/index.d.ts +2 -2
- package/node/ftps/file/index.js +2 -2
- package/node/ftps/file/move/index.js +46 -44
- package/node/ftps/file/remove/index.js +36 -39
- package/node/ftps/file/stat/index.js +30 -38
- package/node/ftps/file/upload/index.js +40 -44
- package/node/images/create/index.js +10 -562
- package/node/images/format/index.js +264 -815
- package/node/images/metadata/index.js +10 -571
- package/node/images/transform/index.js +169 -1022
- package/node/images/transform/operations/blur/index.js +11 -24
- package/node/images/transform/operations/brighten/index.js +11 -24
- package/node/images/transform/operations/extend/index.js +25 -589
- package/node/images/transform/operations/extract/index.js +15 -28
- package/node/images/transform/operations/flatten/index.js +20 -584
- package/node/images/transform/operations/flip/index.js +2 -6
- package/node/images/transform/operations/flop/index.js +2 -6
- package/node/images/transform/operations/hue/index.js +13 -26
- package/node/images/transform/operations/index.d.ts +3 -3
- package/node/images/transform/operations/index.js +3 -3
- package/node/images/transform/operations/level/index.js +14 -30
- package/node/images/transform/operations/lighten/index.js +13 -26
- package/node/images/transform/operations/normalize/index.js +14 -27
- package/node/images/transform/operations/overlay/index.js +89 -673
- package/node/images/transform/operations/resize/index.js +46 -610
- package/node/images/transform/operations/rotate/index.js +20 -584
- package/node/images/transform/operations/saturate/index.js +14 -27
- package/node/images/types.js +34 -31
- package/node/images/utils/index.js +84 -568
- package/node/index.d.ts +2 -2
- package/node/index.js +2 -2
- package/node/process/on-exit/index.js +45 -26
- package/node/process/prompt-continue/index.js +29 -14
- package/node/process/spawner/index.js +104 -134
- package/node/sftp/directory/copy-dir/index.js +52 -60
- package/node/sftp/directory/index.d.ts +1 -1
- package/node/sftp/directory/index.js +1 -1
- package/node/sftp/directory/list/index.js +22 -29
- package/node/sftp/directory/move-dir/index.js +35 -35
- package/node/sftp/directory/remove-dir/index.js +39 -42
- package/node/sftp/file/copy/index.js +37 -45
- package/node/sftp/file/download/index.js +26 -32
- package/node/sftp/file/exists/index.js +29 -29
- package/node/sftp/file/index.d.ts +2 -2
- package/node/sftp/file/index.js +2 -2
- package/node/sftp/file/move/index.js +39 -38
- package/node/sftp/file/remove/index.js +31 -34
- package/node/sftp/file/stat/index.js +26 -37
- package/node/sftp/file/upload/index.js +34 -38
- package/package.json +1 -1
|
@@ -1,20 +1,50 @@
|
|
|
1
|
-
/**
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Generates an array of interpolated values between a minimum and maximum using a geometric progression.
|
|
3
|
+
*
|
|
4
|
+
* @param {number} min - The starting value of the scale.
|
|
5
|
+
* @param {number} max - The ending value of the scale.
|
|
6
|
+
* @param {number} intermediateLevels - The number of intermediate levels between min and max.
|
|
7
|
+
* @returns {number[]} An array of rounded values including the minimum and interpolated steps up to the maximum.
|
|
8
|
+
*/
|
|
9
|
+
export declare const interpolateLevels: (min: number, max: number, intermediateLevels: number) => number[];
|
|
10
|
+
/** Describes the configuration used to compute scale values across breakpoints. */
|
|
11
|
+
export type ScaleDataOptions = {
|
|
12
|
+
/** Ordered list of breakpoint widths in pixels. Must contain at least two values. */ breakpoints: number[];
|
|
13
|
+
/** The minimum and maximum values for the low end of the scale. */ loScaleBounds: [number, number];
|
|
14
|
+
/** The minimum and maximum values for the high end of the scale. */ hiScaleBounds: [number, number];
|
|
15
|
+
/** Number of intermediate levels between the minimum and maximum values. */ intermediateLevels: number;
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Computes scale data for each breakpoint, including interpolated levels.
|
|
19
|
+
*
|
|
20
|
+
* @param {ScaleDataOptions} options - Configuration for generating scale data.
|
|
21
|
+
* @param {number[]} options.breakpoints - Ordered list of breakpoint widths in pixels.
|
|
22
|
+
* @param {[number, number]} options.loScaleBounds - Minimum and maximum values for the low end of the scale.
|
|
23
|
+
* @param {[number, number]} options.hiScaleBounds - Minimum and maximum values for the high end of the scale.
|
|
24
|
+
* @param {number} options.intermediateLevels - Number of intermediate levels between bounds.
|
|
25
|
+
* @throws Will throw if `breakpoints` contains fewer than two values.
|
|
26
|
+
*/
|
|
27
|
+
export declare const getScaleData: ({ breakpoints, loScaleBounds, hiScaleBounds, intermediateLevels }: ScaleDataOptions) => Array<{
|
|
28
|
+
breakpoint: number;
|
|
29
|
+
levels: number[];
|
|
30
|
+
}>;
|
|
31
|
+
/** Extends scale data options with CSS generation parameters. */
|
|
32
|
+
export type GenerateScaleCssOptions = ScaleDataOptions & {
|
|
33
|
+
/** The base name used for generated CSS custom properties. */ scaleName: string;
|
|
34
|
+
/** The CSS selector that will receive the custom properties. */ targetSelector: string;
|
|
35
|
+
/** The unit to append to each generated value (e.g., `px`, `rem`). */ unit: string;
|
|
8
36
|
};
|
|
9
37
|
/**
|
|
10
|
-
*
|
|
38
|
+
* Generates responsive CSS custom properties for a scale across breakpoints.
|
|
11
39
|
*
|
|
12
|
-
* @param {
|
|
13
|
-
* @param {
|
|
14
|
-
* @param {
|
|
15
|
-
* @param {
|
|
16
|
-
* @param {number}
|
|
17
|
-
* @param {
|
|
18
|
-
* @
|
|
40
|
+
* @param {GenerateScaleCssOptions} options - Configuration for generating the CSS output.
|
|
41
|
+
* @param {string} options.scaleName - Base name for CSS custom properties.
|
|
42
|
+
* @param {string} options.targetSelector - CSS selector to which the properties will be applied.
|
|
43
|
+
* @param {string} options.unit - Unit appended to each value.
|
|
44
|
+
* @param {number[]} options.breakpoints - Ordered list of breakpoint widths in pixels.
|
|
45
|
+
* @param {[number, number]} options.loScaleBounds - Minimum and maximum values for the low end of the scale.
|
|
46
|
+
* @param {[number, number]} options.hiScaleBounds - Minimum and maximum values for the high end of the scale.
|
|
47
|
+
* @param {number} options.intermediateLevels - Number of intermediate levels between bounds.
|
|
48
|
+
* @returns {string} A CSS string containing custom properties for each breakpoint, wrapped in media queries where applicable.
|
|
19
49
|
*/
|
|
20
|
-
export declare
|
|
50
|
+
export declare const generateScaleCss: ({ scaleName, targetSelector, unit, ...options }: GenerateScaleCssOptions) => string;
|
|
@@ -1,55 +1,71 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
}
|
|
47
|
-
function getCssValueFromAffine(affine) {
|
|
48
|
-
const { slope, yIntercept } = affine;
|
|
49
|
-
const roundedSlope = round(100 * slope, 3);
|
|
50
|
-
const roundedIntercept = round(yIntercept, 2);
|
|
51
|
-
return `calc(${roundedSlope}vw + ${roundedIntercept}px)`;
|
|
52
|
-
}
|
|
53
|
-
export {
|
|
54
|
-
createScale
|
|
1
|
+
import { getGeometricStep } from '../../numbers/geometric-progressions/index.js';
|
|
2
|
+
import { round } from '../../numbers/round/index.js';
|
|
3
|
+
import { make as makeArr } from '../../arrays/make/index.js';
|
|
4
|
+
/**
|
|
5
|
+
* Generates an array of interpolated values between a minimum and maximum using a geometric progression.
|
|
6
|
+
*
|
|
7
|
+
* @param {number} min - The starting value of the scale.
|
|
8
|
+
* @param {number} max - The ending value of the scale.
|
|
9
|
+
* @param {number} intermediateLevels - The number of intermediate levels between min and max.
|
|
10
|
+
* @returns {number[]} An array of rounded values including the minimum and interpolated steps up to the maximum.
|
|
11
|
+
*/
|
|
12
|
+
export const interpolateLevels = (min, max, intermediateLevels) => [
|
|
13
|
+
round(min, 2),
|
|
14
|
+
...makeArr(pos => round(getGeometricStep(min, max, pos + 1, intermediateLevels + 1), 2), intermediateLevels + 1)
|
|
15
|
+
];
|
|
16
|
+
/**
|
|
17
|
+
* Computes scale data for each breakpoint, including interpolated levels.
|
|
18
|
+
*
|
|
19
|
+
* @param {ScaleDataOptions} options - Configuration for generating scale data.
|
|
20
|
+
* @param {number[]} options.breakpoints - Ordered list of breakpoint widths in pixels.
|
|
21
|
+
* @param {[number, number]} options.loScaleBounds - Minimum and maximum values for the low end of the scale.
|
|
22
|
+
* @param {[number, number]} options.hiScaleBounds - Minimum and maximum values for the high end of the scale.
|
|
23
|
+
* @param {number} options.intermediateLevels - Number of intermediate levels between bounds.
|
|
24
|
+
* @throws Will throw if `breakpoints` contains fewer than two values.
|
|
25
|
+
*/
|
|
26
|
+
export const getScaleData = ({ breakpoints, loScaleBounds, hiScaleBounds, intermediateLevels }) => {
|
|
27
|
+
const [loMinValuePx, loMaxValuePx] = loScaleBounds;
|
|
28
|
+
const [hiMinValuePx, hiMaxValuePx] = hiScaleBounds;
|
|
29
|
+
const loValueDiff = loMaxValuePx - loMinValuePx;
|
|
30
|
+
const hiValueDiff = hiMaxValuePx - hiMinValuePx;
|
|
31
|
+
const maxBreakpoint = breakpoints.at(-1);
|
|
32
|
+
const minBreakpoint = breakpoints.at(0);
|
|
33
|
+
if (breakpoints.length < 2
|
|
34
|
+
|| maxBreakpoint === undefined
|
|
35
|
+
|| minBreakpoint === undefined)
|
|
36
|
+
throw new Error(`\`breakpoints\` length must be at least 2. Found ${breakpoints.length}`);
|
|
37
|
+
return breakpoints.map(breakpoint => {
|
|
38
|
+
const thisBreakpointRatio = (breakpoint - minBreakpoint) / (maxBreakpoint - minBreakpoint);
|
|
39
|
+
const lo = (thisBreakpointRatio * loValueDiff) + loMinValuePx;
|
|
40
|
+
const hi = (thisBreakpointRatio * hiValueDiff) + hiMinValuePx;
|
|
41
|
+
return {
|
|
42
|
+
breakpoint,
|
|
43
|
+
levels: interpolateLevels(lo, hi, intermediateLevels)
|
|
44
|
+
};
|
|
45
|
+
});
|
|
55
46
|
};
|
|
47
|
+
/**
|
|
48
|
+
* Generates responsive CSS custom properties for a scale across breakpoints.
|
|
49
|
+
*
|
|
50
|
+
* @param {GenerateScaleCssOptions} options - Configuration for generating the CSS output.
|
|
51
|
+
* @param {string} options.scaleName - Base name for CSS custom properties.
|
|
52
|
+
* @param {string} options.targetSelector - CSS selector to which the properties will be applied.
|
|
53
|
+
* @param {string} options.unit - Unit appended to each value.
|
|
54
|
+
* @param {number[]} options.breakpoints - Ordered list of breakpoint widths in pixels.
|
|
55
|
+
* @param {[number, number]} options.loScaleBounds - Minimum and maximum values for the low end of the scale.
|
|
56
|
+
* @param {[number, number]} options.hiScaleBounds - Minimum and maximum values for the high end of the scale.
|
|
57
|
+
* @param {number} options.intermediateLevels - Number of intermediate levels between bounds.
|
|
58
|
+
* @returns {string} A CSS string containing custom properties for each breakpoint, wrapped in media queries where applicable.
|
|
59
|
+
*/
|
|
60
|
+
export const generateScaleCss = ({ scaleName, targetSelector, unit, ...options }) => getScaleData(options).map(({ breakpoint, levels }, pos) => {
|
|
61
|
+
const levelsCss = levels.map((lvlVal, lvlPos) => `--${scaleName}-${lvlPos}: ${lvlVal}${unit};`);
|
|
62
|
+
if (pos === 0)
|
|
63
|
+
return `${targetSelector} {
|
|
64
|
+
${levelsCss.join('\n ')}
|
|
65
|
+
}\n`;
|
|
66
|
+
return `@media (min-width: ${breakpoint}px) {
|
|
67
|
+
${targetSelector} {
|
|
68
|
+
${levelsCss.join('\n ')}
|
|
69
|
+
}
|
|
70
|
+
}\n`;
|
|
71
|
+
}).join('\n');
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { describe, it, expect } from 'vitest';
|
|
2
|
+
import { interpolateLevels, getScaleData, generateScaleCss } from './index.js';
|
|
3
|
+
describe('interpolateLevels', () => {
|
|
4
|
+
it('returns an array including min and interpolated values', () => {
|
|
5
|
+
const result = interpolateLevels(10, 20, 2);
|
|
6
|
+
expect(result.length).toBe(4);
|
|
7
|
+
expect(result[0]).toBe(10);
|
|
8
|
+
expect(result.at(-1)).toBeCloseTo(20, 2);
|
|
9
|
+
});
|
|
10
|
+
it('rounds values to 2 decimals', () => {
|
|
11
|
+
const result = interpolateLevels(10, 20, 3);
|
|
12
|
+
result.forEach(val => {
|
|
13
|
+
expect(Number(val.toFixed(2))).toBe(val);
|
|
14
|
+
});
|
|
15
|
+
});
|
|
16
|
+
it('handles descending ranges', () => {
|
|
17
|
+
const result = interpolateLevels(20, 10, 2);
|
|
18
|
+
expect(result[0]).toBe(20);
|
|
19
|
+
expect(result.at(-1)).toBeCloseTo(10, 2);
|
|
20
|
+
});
|
|
21
|
+
});
|
|
22
|
+
describe('getScaleData', () => {
|
|
23
|
+
const baseOptions = {
|
|
24
|
+
breakpoints: [320, 768, 1280],
|
|
25
|
+
loScaleBounds: [10, 20],
|
|
26
|
+
hiScaleBounds: [30, 60],
|
|
27
|
+
intermediateLevels: 2
|
|
28
|
+
};
|
|
29
|
+
it('returns one entry per breakpoint', () => {
|
|
30
|
+
const result = getScaleData(baseOptions);
|
|
31
|
+
expect(result.length).toBe(baseOptions.breakpoints.length);
|
|
32
|
+
});
|
|
33
|
+
it('includes breakpoint and levels', () => {
|
|
34
|
+
const result = getScaleData(baseOptions);
|
|
35
|
+
result.forEach(entry => {
|
|
36
|
+
expect(entry).toHaveProperty('breakpoint');
|
|
37
|
+
expect(entry).toHaveProperty('levels');
|
|
38
|
+
expect(Array.isArray(entry.levels)).toBe(true);
|
|
39
|
+
});
|
|
40
|
+
});
|
|
41
|
+
it('interpolates values between low and high bounds', () => {
|
|
42
|
+
const result = getScaleData(baseOptions);
|
|
43
|
+
const first = result[0];
|
|
44
|
+
const last = result.at(-1);
|
|
45
|
+
expect(first?.levels[0]).toBeCloseTo(10, 2);
|
|
46
|
+
expect(last?.levels.at(-1)).toBeCloseTo(60, 2);
|
|
47
|
+
});
|
|
48
|
+
it('throws if breakpoints length < 2', () => {
|
|
49
|
+
expect(() => getScaleData({
|
|
50
|
+
...baseOptions,
|
|
51
|
+
breakpoints: [320]
|
|
52
|
+
})).toThrow();
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
describe('generateScaleCss', () => {
|
|
56
|
+
const options = {
|
|
57
|
+
scaleName: 'size',
|
|
58
|
+
targetSelector: ':root',
|
|
59
|
+
unit: 'px',
|
|
60
|
+
breakpoints: [320, 768],
|
|
61
|
+
loScaleBounds: [10, 20],
|
|
62
|
+
hiScaleBounds: [30, 40],
|
|
63
|
+
intermediateLevels: 1
|
|
64
|
+
};
|
|
65
|
+
it('generates base CSS block for first breakpoint', () => {
|
|
66
|
+
const css = generateScaleCss(options);
|
|
67
|
+
expect(css).toMatch(/:root\s*{[^}]+}/);
|
|
68
|
+
});
|
|
69
|
+
it('generates media queries for subsequent breakpoints', () => {
|
|
70
|
+
const css = generateScaleCss(options);
|
|
71
|
+
expect(css).toMatch(/@media \(min-width: 768px\)/);
|
|
72
|
+
});
|
|
73
|
+
it('generates CSS custom properties with correct naming', () => {
|
|
74
|
+
const css = generateScaleCss(options);
|
|
75
|
+
expect(css).toMatch(/--size-0:/);
|
|
76
|
+
expect(css).toMatch(/--size-1:/);
|
|
77
|
+
});
|
|
78
|
+
it('applies the provided unit', () => {
|
|
79
|
+
const css = generateScaleCss(options);
|
|
80
|
+
expect(css).toMatch(/px;/);
|
|
81
|
+
});
|
|
82
|
+
it('produces consistent number of variables per breakpoint', () => {
|
|
83
|
+
const css = generateScaleCss(options);
|
|
84
|
+
const matches = css.match(/--size-\d+:/g) ?? [];
|
|
85
|
+
// 3 levels * 2 breakpoints
|
|
86
|
+
expect(matches.length).toBe(6);
|
|
87
|
+
});
|
|
88
|
+
});
|
|
@@ -1,182 +1,155 @@
|
|
|
1
|
-
|
|
2
|
-
import { Component } from
|
|
3
|
-
import {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
{
|
|
71
|
-
items,
|
|
72
|
-
privateIDAttribute: this.tagsPrivateIDAttribute,
|
|
73
|
-
publicIDAttribute: this.tagsPublicIDAttribute
|
|
74
|
-
}
|
|
75
|
-
));
|
|
76
|
-
this._rendered.set(element, root);
|
|
77
|
-
return this;
|
|
78
|
-
}
|
|
79
|
-
unmount(element) {
|
|
80
|
-
if (!this._rendered.has(element)) return this;
|
|
81
|
-
const root = this._rendered.get(element);
|
|
82
|
-
if (root === void 0) return this;
|
|
83
|
-
root.unmount();
|
|
84
|
-
this._rendered.delete(element);
|
|
85
|
-
return this;
|
|
86
|
-
}
|
|
87
|
-
updateRendered() {
|
|
88
|
-
const { items } = this;
|
|
89
|
-
this._rendered.forEach((root) => root.render(/* @__PURE__ */ jsx(
|
|
90
|
-
StylesSetComp,
|
|
91
|
-
{
|
|
92
|
-
items,
|
|
93
|
-
privateIDAttribute: this.tagsPrivateIDAttribute,
|
|
94
|
-
publicIDAttribute: this.tagsPublicIDAttribute
|
|
95
|
-
}
|
|
96
|
-
)));
|
|
97
|
-
return this;
|
|
98
|
-
}
|
|
99
|
-
addItem(item, abortIfIdExists = true) {
|
|
100
|
-
const existing = Array.from(this._items.entries()).map(([privateId2, entry]) => ({ privateId: privateId2, entry })).find(({ entry }) => entry.id !== void 0 && entry.id === item.id);
|
|
101
|
-
if (existing !== void 0) {
|
|
102
|
-
if (abortIfIdExists) return this;
|
|
103
|
-
this._items.delete(existing.privateId);
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { Component } from 'react';
|
|
3
|
+
import { createRoot as reactCreateRoot } from 'react-dom/client';
|
|
4
|
+
import { randomHash } from '../../random/uuid/index.js';
|
|
5
|
+
export class StylesSet {
|
|
6
|
+
static defaultPrivateIDAttribute = 'data-styleset-private-id';
|
|
7
|
+
static defaultPublicIDAttribute = 'data-styleset-public-id';
|
|
8
|
+
tagsPrivateIDAttribute = StylesSet.defaultPrivateIDAttribute;
|
|
9
|
+
tagsPublicIDAttribute = StylesSet.defaultPublicIDAttribute;
|
|
10
|
+
_items = new Map();
|
|
11
|
+
get items() {
|
|
12
|
+
const sortedItemsArray = Array.from(this._items).map(([privateId, item]) => {
|
|
13
|
+
const targetPosition = this.getTargetPosition(privateId) ?? 0;
|
|
14
|
+
return { targetPosition, privateId, item };
|
|
15
|
+
}).sort((a, b) => a.targetPosition - b.targetPosition)
|
|
16
|
+
.map(({ item, privateId }) => [privateId, item]);
|
|
17
|
+
const sortedItemsMap = new Map(sortedItemsArray);
|
|
18
|
+
return sortedItemsMap;
|
|
19
|
+
}
|
|
20
|
+
getTargetPosition(privateId) {
|
|
21
|
+
const orderedStyles = Array.from(this._items)
|
|
22
|
+
.map(([privateId, data]) => ({ privateId, data }))
|
|
23
|
+
.sort((a, b) => {
|
|
24
|
+
const aPos = a.data.position ?? 0;
|
|
25
|
+
const bPos = b.data.position ?? 0;
|
|
26
|
+
return aPos - bPos;
|
|
27
|
+
});
|
|
28
|
+
const foundIndex = orderedStyles.findIndex(item => item.privateId === privateId);
|
|
29
|
+
return foundIndex === -1 ? null : foundIndex;
|
|
30
|
+
}
|
|
31
|
+
setTagsPrivateIDAttribute(str) {
|
|
32
|
+
this.tagsPrivateIDAttribute = str;
|
|
33
|
+
return this;
|
|
34
|
+
}
|
|
35
|
+
setTagsPublicIDAttribute(str) {
|
|
36
|
+
this.tagsPublicIDAttribute = str;
|
|
37
|
+
return this;
|
|
38
|
+
}
|
|
39
|
+
getById(id) {
|
|
40
|
+
const found = Array.from(this._items.values())
|
|
41
|
+
.find(entry => entry.id === id);
|
|
42
|
+
if (found === undefined)
|
|
43
|
+
return undefined;
|
|
44
|
+
return found;
|
|
45
|
+
}
|
|
46
|
+
generateUniquePrivateId() {
|
|
47
|
+
const existingIds = Array.from(this._items.keys());
|
|
48
|
+
const generated = randomHash(12);
|
|
49
|
+
if (existingIds.includes(generated))
|
|
50
|
+
return this.generateUniquePrivateId();
|
|
51
|
+
return generated;
|
|
52
|
+
}
|
|
53
|
+
_rendered = new Map();
|
|
54
|
+
render(element) {
|
|
55
|
+
const root = reactCreateRoot(element);
|
|
56
|
+
const items = this.items;
|
|
57
|
+
root.render(_jsx(StylesSetComp, { items: items, privateIDAttribute: this.tagsPrivateIDAttribute, publicIDAttribute: this.tagsPublicIDAttribute }));
|
|
58
|
+
this._rendered.set(element, root);
|
|
59
|
+
return this;
|
|
60
|
+
}
|
|
61
|
+
unmount(element) {
|
|
62
|
+
if (!this._rendered.has(element))
|
|
63
|
+
return this;
|
|
64
|
+
const root = this._rendered.get(element);
|
|
65
|
+
if (root === undefined)
|
|
66
|
+
return this;
|
|
67
|
+
root.unmount();
|
|
68
|
+
this._rendered.delete(element);
|
|
69
|
+
return this;
|
|
104
70
|
}
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
}
|
|
110
|
-
removeItem(idOrPosition) {
|
|
111
|
-
if (typeof idOrPosition === "string") {
|
|
112
|
-
const existing = Array.from(this._items.entries()).map(([privateId, entry]) => ({ privateId, entry })).find(({ entry }) => entry.id !== void 0 && entry.id === idOrPosition);
|
|
113
|
-
if (existing === void 0) return this;
|
|
114
|
-
this._items.delete(existing.privateId);
|
|
115
|
-
this.updateRendered();
|
|
116
|
-
return this;
|
|
71
|
+
updateRendered() {
|
|
72
|
+
const { items } = this;
|
|
73
|
+
this._rendered.forEach((root) => root.render(_jsx(StylesSetComp, { items: items, privateIDAttribute: this.tagsPrivateIDAttribute, publicIDAttribute: this.tagsPublicIDAttribute })));
|
|
74
|
+
return this;
|
|
117
75
|
}
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
return await new Promise((resolve) => {
|
|
128
|
-
const tempElt = actualDocumentObj.createElement("div");
|
|
129
|
-
const tempRoot = reactCreateRoot(tempElt);
|
|
130
|
-
const { items } = this;
|
|
131
|
-
const onRendered = () => {
|
|
132
|
-
resolve(tempElt.innerHTML);
|
|
133
|
-
tempRoot.unmount();
|
|
134
|
-
tempElt.remove();
|
|
135
|
-
};
|
|
136
|
-
tempRoot.render(/* @__PURE__ */ jsx(
|
|
137
|
-
StylesSetComp,
|
|
138
|
-
{
|
|
139
|
-
items,
|
|
140
|
-
privateIDAttribute: this.tagsPrivateIDAttribute,
|
|
141
|
-
publicIDAttribute: this.tagsPublicIDAttribute,
|
|
142
|
-
onRendered
|
|
76
|
+
addItem(item, abortIfIdExists = true) {
|
|
77
|
+
const existing = Array
|
|
78
|
+
.from(this._items.entries())
|
|
79
|
+
.map(([privateId, entry]) => ({ privateId, entry }))
|
|
80
|
+
.find(({ entry }) => (entry.id !== undefined && entry.id === item.id));
|
|
81
|
+
if (existing !== undefined) {
|
|
82
|
+
if (abortIfIdExists)
|
|
83
|
+
return this;
|
|
84
|
+
this._items.delete(existing.privateId);
|
|
143
85
|
}
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
const { props } = this;
|
|
161
|
-
const items = props.items ?? /* @__PURE__ */ new Map();
|
|
162
|
-
const pidAttr = props.privateIDAttribute ?? StylesSet.defaultPrivateIDAttribute;
|
|
163
|
-
const idAttr = props.publicIDAttribute ?? StylesSet.defaultPublicIDAttribute;
|
|
164
|
-
return /* @__PURE__ */ jsx(Fragment, { children: Array.from(items).map(([privateId, itemData]) => {
|
|
165
|
-
const customAttributes = { [pidAttr]: privateId, [idAttr]: itemData.id };
|
|
166
|
-
if (itemData.type === "url") return /* @__PURE__ */ jsx(
|
|
167
|
-
"link",
|
|
168
|
-
{
|
|
169
|
-
onLoad: itemData.onLoad,
|
|
170
|
-
rel: "stylesheet",
|
|
171
|
-
href: itemData.content,
|
|
172
|
-
...customAttributes
|
|
86
|
+
const privateId = this.generateUniquePrivateId();
|
|
87
|
+
this._items.set(privateId, item);
|
|
88
|
+
this.updateRendered();
|
|
89
|
+
return this;
|
|
90
|
+
}
|
|
91
|
+
removeItem(idOrPosition) {
|
|
92
|
+
if (typeof idOrPosition === 'string') {
|
|
93
|
+
const existing = Array
|
|
94
|
+
.from(this._items.entries())
|
|
95
|
+
.map(([privateId, entry]) => ({ privateId, entry }))
|
|
96
|
+
.find(({ entry }) => (entry.id !== undefined && entry.id === idOrPosition));
|
|
97
|
+
if (existing === undefined)
|
|
98
|
+
return this;
|
|
99
|
+
this._items.delete(existing.privateId);
|
|
100
|
+
this.updateRendered();
|
|
101
|
+
return this;
|
|
173
102
|
}
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
103
|
+
const toRemove = Array
|
|
104
|
+
.from(this._items)
|
|
105
|
+
.map(([privateId, entry]) => ({ privateId, entry }))
|
|
106
|
+
.at(idOrPosition);
|
|
107
|
+
if (toRemove === undefined)
|
|
108
|
+
return this;
|
|
109
|
+
this._items.delete(toRemove.privateId);
|
|
110
|
+
this.updateRendered();
|
|
111
|
+
return this;
|
|
112
|
+
}
|
|
113
|
+
async getDomString(documentObj) {
|
|
114
|
+
const actualDocumentObj = documentObj ?? window.document;
|
|
115
|
+
if (actualDocumentObj === null)
|
|
116
|
+
throw new Error('Window.document is not available');
|
|
117
|
+
return await new Promise(resolve => {
|
|
118
|
+
const tempElt = actualDocumentObj.createElement('div');
|
|
119
|
+
const tempRoot = reactCreateRoot(tempElt);
|
|
120
|
+
const { items } = this;
|
|
121
|
+
const onRendered = () => {
|
|
122
|
+
resolve(tempElt.innerHTML);
|
|
123
|
+
tempRoot.unmount();
|
|
124
|
+
tempElt.remove();
|
|
125
|
+
};
|
|
126
|
+
tempRoot.render(_jsx(StylesSetComp, { items: items, privateIDAttribute: this.tagsPrivateIDAttribute, publicIDAttribute: this.tagsPublicIDAttribute, onRendered: onRendered }));
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
export class StylesSetComp extends Component {
|
|
131
|
+
componentDidMount() {
|
|
132
|
+
const { props } = this;
|
|
133
|
+
const { onRendered } = props;
|
|
134
|
+
if (onRendered !== undefined)
|
|
135
|
+
onRendered();
|
|
136
|
+
}
|
|
137
|
+
componentDidUpdate() {
|
|
138
|
+
const { props } = this;
|
|
139
|
+
const { onRendered } = props;
|
|
140
|
+
if (onRendered !== undefined)
|
|
141
|
+
onRendered();
|
|
142
|
+
}
|
|
143
|
+
render() {
|
|
144
|
+
const { props } = this;
|
|
145
|
+
const items = props.items ?? new Map();
|
|
146
|
+
const pidAttr = props.privateIDAttribute ?? StylesSet.defaultPrivateIDAttribute;
|
|
147
|
+
const idAttr = props.publicIDAttribute ?? StylesSet.defaultPublicIDAttribute;
|
|
148
|
+
return _jsx(_Fragment, { children: Array.from(items).map(([privateId, itemData]) => {
|
|
149
|
+
const customAttributes = { [pidAttr]: privateId, [idAttr]: itemData.id };
|
|
150
|
+
if (itemData.type === 'url')
|
|
151
|
+
return _jsx("link", { onLoad: itemData.onLoad, rel: 'stylesheet', href: itemData.content, ...customAttributes });
|
|
152
|
+
return _jsx("style", { ...customAttributes, children: itemData.content });
|
|
153
|
+
}) });
|
|
154
|
+
}
|
|
155
|
+
}
|
package/agnostic/errors/index.js
CHANGED