yummies 5.15.0 → 6.0.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.
Files changed (235) hide show
  1. package/README.md +10 -4
  2. package/async.cjs +45 -1
  3. package/async.cjs.map +1 -1
  4. package/async.d.ts +7 -6
  5. package/common.cjs +11 -1
  6. package/common.cjs.map +1 -1
  7. package/common.d.ts +8 -5
  8. package/common.js.map +1 -1
  9. package/complex.cjs +88 -1
  10. package/complex.cjs.map +1 -1
  11. package/{complex/modules-factory.d.ts → complex.d.ts} +31 -4
  12. package/complex.js.map +1 -1
  13. package/cookie.cjs +9 -1
  14. package/cookie.cjs.map +1 -1
  15. package/cookie.d.ts +5 -3
  16. package/cookie.js.map +1 -1
  17. package/css.cjs +45 -1
  18. package/css.cjs.map +1 -1
  19. package/css.d.ts +11 -8
  20. package/css.js.map +1 -1
  21. package/data.cjs +43 -1
  22. package/data.cjs.map +1 -1
  23. package/data.d.ts +5 -4
  24. package/data.js.map +1 -1
  25. package/date-time.cjs +395 -1
  26. package/date-time.cjs.map +1 -1
  27. package/date-time.d.ts +12 -10
  28. package/date-time.js.map +1 -1
  29. package/device.cjs +32 -1
  30. package/device.cjs.map +1 -1
  31. package/device.d.ts +9 -8
  32. package/encodings.cjs +270 -1
  33. package/encodings.cjs.map +1 -1
  34. package/encodings.d.ts +3 -2
  35. package/encodings.js.map +1 -1
  36. package/errors.cjs +23 -1
  37. package/errors.cjs.map +1 -1
  38. package/errors.d.ts +5 -4
  39. package/errors.js.map +1 -1
  40. package/file.cjs +28 -1
  41. package/file.cjs.map +1 -1
  42. package/file.d.ts +4 -3
  43. package/format.cjs +75 -1
  44. package/format.cjs.map +1 -1
  45. package/format.d.ts +74 -0
  46. package/format.js.map +1 -1
  47. package/html.cjs +167 -1
  48. package/html.cjs.map +1 -1
  49. package/html.d.ts +19 -17
  50. package/html.js.map +1 -1
  51. package/id.cjs +25 -1
  52. package/id.cjs.map +1 -1
  53. package/id.d.ts +9 -8
  54. package/imports.cjs +33 -1
  55. package/imports.cjs.map +1 -1
  56. package/imports.d.ts +6 -4
  57. package/math.cjs +14 -1
  58. package/math.cjs.map +1 -1
  59. package/math.d.ts +7 -5
  60. package/math.js.map +1 -1
  61. package/media.cjs +105 -1
  62. package/media.cjs.map +1 -1
  63. package/media.d.ts +11 -11
  64. package/mobx.cjs +184 -1
  65. package/mobx.cjs.map +1 -1
  66. package/mobx.d.ts +66 -0
  67. package/mobx.js +16 -12
  68. package/mobx.js.map +1 -1
  69. package/ms.cjs +13 -1
  70. package/ms.cjs.map +1 -1
  71. package/ms.d.ts +4 -3
  72. package/number.cjs +10 -1
  73. package/number.cjs.map +1 -1
  74. package/number.d.ts +3 -2
  75. package/package.json +39 -113
  76. package/parser.cjs +68 -1
  77. package/parser.cjs.map +1 -1
  78. package/parser.d.ts +41 -0
  79. package/parser.js.map +1 -1
  80. package/price.cjs +20 -1
  81. package/price.cjs.map +1 -1
  82. package/price.d.ts +5 -3
  83. package/random.cjs +24 -1
  84. package/random.cjs.map +1 -1
  85. package/random.d.ts +10 -9
  86. package/react.cjs +216 -1
  87. package/react.cjs.map +1 -1
  88. package/react.d.ts +113 -0
  89. package/react.js.map +1 -1
  90. package/sound.cjs +11 -1
  91. package/sound.cjs.map +1 -1
  92. package/sound.d.ts +3 -2
  93. package/text.cjs +37 -1
  94. package/text.cjs.map +1 -1
  95. package/text.d.ts +4 -3
  96. package/type-guard.cjs +75 -1
  97. package/type-guard.cjs.map +1 -1
  98. package/type-guard.d.ts +121 -0
  99. package/type-guard.js.map +1 -1
  100. package/{utils/types.d.ts → types.d.ts} +54 -53
  101. package/types.global.cjs +2 -0
  102. package/types.global.cjs.map +1 -0
  103. package/{utility-types.d.ts → types.global.d.ts} +1 -1
  104. package/types.global.js +2 -0
  105. package/types.global.js.map +1 -0
  106. package/vibrate.cjs +8 -1
  107. package/vibrate.cjs.map +1 -1
  108. package/vibrate.d.ts +3 -2
  109. package/async.d.ts.map +0 -1
  110. package/common.d.ts.map +0 -1
  111. package/complex/counter.d.ts +0 -15
  112. package/complex/counter.d.ts.map +0 -1
  113. package/complex/global-config.d.ts +0 -11
  114. package/complex/global-config.d.ts.map +0 -1
  115. package/complex/index.d.ts +0 -4
  116. package/complex/index.d.ts.map +0 -1
  117. package/complex/modules-factory.d.ts.map +0 -1
  118. package/cookie.d.ts.map +0 -1
  119. package/css.d.ts.map +0 -1
  120. package/data.d.ts.map +0 -1
  121. package/date-time.d.ts.map +0 -1
  122. package/device.d.ts.map +0 -1
  123. package/encodings.d.ts.map +0 -1
  124. package/errors.d.ts.map +0 -1
  125. package/file.d.ts.map +0 -1
  126. package/format/_exports.d.ts +0 -5
  127. package/format/_exports.d.ts.map +0 -1
  128. package/format/constants.d.ts +0 -4
  129. package/format/constants.d.ts.map +0 -1
  130. package/format/index.d.ts +0 -3
  131. package/format/index.d.ts.map +0 -1
  132. package/format/number.d.ts +0 -36
  133. package/format/number.d.ts.map +0 -1
  134. package/format/percent.d.ts +0 -15
  135. package/format/percent.d.ts.map +0 -1
  136. package/format/skip-spaces.d.ts +0 -5
  137. package/format/skip-spaces.d.ts.map +0 -1
  138. package/html.d.ts.map +0 -1
  139. package/id.d.ts.map +0 -1
  140. package/imports.d.ts.map +0 -1
  141. package/math.d.ts.map +0 -1
  142. package/media.d.ts.map +0 -1
  143. package/mobx/apply-observable.d.ts +0 -4
  144. package/mobx/apply-observable.d.ts.map +0 -1
  145. package/mobx/create-enhanced-atom.d.ts +0 -11
  146. package/mobx/create-enhanced-atom.d.ts.map +0 -1
  147. package/mobx/create-ref.d.ts +0 -25
  148. package/mobx/create-ref.d.ts.map +0 -1
  149. package/mobx/deep-observable-struct.d.ts +0 -7
  150. package/mobx/deep-observable-struct.d.ts.map +0 -1
  151. package/mobx/get-mobx-administration.d.ts +0 -6
  152. package/mobx/get-mobx-administration.d.ts.map +0 -1
  153. package/mobx/index.d.ts +0 -7
  154. package/mobx/index.d.ts.map +0 -1
  155. package/mobx/lazy-observe.d.ts +0 -14
  156. package/mobx/lazy-observe.d.ts.map +0 -1
  157. package/ms.d.ts.map +0 -1
  158. package/number.d.ts.map +0 -1
  159. package/parser/_exports.d.ts +0 -4
  160. package/parser/_exports.d.ts.map +0 -1
  161. package/parser/index.d.ts +0 -3
  162. package/parser/index.d.ts.map +0 -1
  163. package/parser/number.d.ts +0 -21
  164. package/parser/number.d.ts.map +0 -1
  165. package/parser/percent.d.ts +0 -4
  166. package/parser/percent.d.ts.map +0 -1
  167. package/parser/string.d.ts +0 -7
  168. package/parser/string.d.ts.map +0 -1
  169. package/price.d.ts.map +0 -1
  170. package/random.d.ts.map +0 -1
  171. package/react/hooks/index.d.ts +0 -22
  172. package/react/hooks/index.d.ts.map +0 -1
  173. package/react/hooks/use-abort-controller.d.ts +0 -2
  174. package/react/hooks/use-abort-controller.d.ts.map +0 -1
  175. package/react/hooks/use-abort-signal.d.ts +0 -2
  176. package/react/hooks/use-abort-signal.d.ts.map +0 -1
  177. package/react/hooks/use-click-outside.d.ts +0 -9
  178. package/react/hooks/use-click-outside.d.ts.map +0 -1
  179. package/react/hooks/use-constant.d.ts +0 -9
  180. package/react/hooks/use-constant.d.ts.map +0 -1
  181. package/react/hooks/use-define-ref.d.ts +0 -10
  182. package/react/hooks/use-define-ref.d.ts.map +0 -1
  183. package/react/hooks/use-element-ref.d.ts +0 -2
  184. package/react/hooks/use-element-ref.d.ts.map +0 -1
  185. package/react/hooks/use-event-listener.d.ts +0 -8
  186. package/react/hooks/use-event-listener.d.ts.map +0 -1
  187. package/react/hooks/use-event.d.ts +0 -3
  188. package/react/hooks/use-event.d.ts.map +0 -1
  189. package/react/hooks/use-flag.d.ts +0 -8
  190. package/react/hooks/use-flag.d.ts.map +0 -1
  191. package/react/hooks/use-force-update.d.ts +0 -2
  192. package/react/hooks/use-force-update.d.ts.map +0 -1
  193. package/react/hooks/use-initial-height.d.ts +0 -5
  194. package/react/hooks/use-initial-height.d.ts.map +0 -1
  195. package/react/hooks/use-instance.d.ts +0 -27
  196. package/react/hooks/use-instance.d.ts.map +0 -1
  197. package/react/hooks/use-intersection-observer.d.ts +0 -2
  198. package/react/hooks/use-intersection-observer.d.ts.map +0 -1
  199. package/react/hooks/use-last-defined-value.d.ts +0 -2
  200. package/react/hooks/use-last-defined-value.d.ts.map +0 -1
  201. package/react/hooks/use-last-value-ref.d.ts +0 -2
  202. package/react/hooks/use-last-value-ref.d.ts.map +0 -1
  203. package/react/hooks/use-life-cycle.d.ts +0 -5
  204. package/react/hooks/use-life-cycle.d.ts.map +0 -1
  205. package/react/hooks/use-resize-observer.d.ts +0 -2
  206. package/react/hooks/use-resize-observer.d.ts.map +0 -1
  207. package/react/hooks/use-sync-ref.d.ts +0 -2
  208. package/react/hooks/use-sync-ref.d.ts.map +0 -1
  209. package/react/hooks/use-toggle.d.ts +0 -2
  210. package/react/hooks/use-toggle.d.ts.map +0 -1
  211. package/react/hooks/use-value.d.ts +0 -5
  212. package/react/hooks/use-value.d.ts.map +0 -1
  213. package/react/hooks/use-visibility-state.d.ts +0 -2
  214. package/react/hooks/use-visibility-state.d.ts.map +0 -1
  215. package/react/index.d.ts +0 -2
  216. package/react/index.d.ts.map +0 -1
  217. package/sound.d.ts.map +0 -1
  218. package/storage.d.ts +0 -39
  219. package/storage.d.ts.map +0 -1
  220. package/text.d.ts.map +0 -1
  221. package/type-guard/_exports.d.ts +0 -86
  222. package/type-guard/_exports.d.ts.map +0 -1
  223. package/type-guard/index.d.ts +0 -3
  224. package/type-guard/index.d.ts.map +0 -1
  225. package/utility-types.cjs +0 -2
  226. package/utility-types.cjs.map +0 -1
  227. package/utility-types.d.ts.map +0 -1
  228. package/utility-types.js +0 -2
  229. package/utility-types.js.map +0 -1
  230. package/utils/types.d.ts.map +0 -1
  231. package/vibrate.d.ts.map +0 -1
  232. /package/{utils/types.cjs → types.cjs} +0 -0
  233. /package/{utils/types.cjs.map → types.cjs.map} +0 -0
  234. /package/{utils/types.js → types.js} +0 -0
  235. /package/{utils/types.js.map → types.js.map} +0 -0
package/README.md CHANGED
@@ -71,18 +71,19 @@ Utility for type checks
71
71
  ## [yummies/vibrate](src/vibrate.ts)
72
72
  Utilities for working with vibrate api
73
73
 
74
- ## [yummies/utility-types](src/utils/types.ts)
74
+ ## [yummies/types.global](src/types.ts)
75
+ ## [yummies/types](src/types.ts)
75
76
  TypeScript utility types that simplify writing TypeScript code.
76
77
  They can be imported globally using the `d.ts` file, embedding it in the environment
77
78
  ```ts
78
- import 'yummies/utility-types';
79
+ import 'yummies/types.global';
79
80
  ```
80
81
  Or specified in `tsconfig.json` in the `"types"` field
81
82
  ```json
82
83
  {
83
84
  "compilerOptions": {
84
85
  "types": [
85
- "yummies/utility-types"
86
+ "yummies/types.global"
86
87
  ],
87
88
  "target": "...blabla",
88
89
  ...
@@ -91,7 +92,7 @@ Or specified in `tsconfig.json` in the `"types"` field
91
92
  }
92
93
  ```
93
94
  Alternatively, you can use the "library" approach, where you need exported types.
94
- For this, you can use the `yummies` or `yummies/utils/types` import.
95
+ For this, you can use the `yummies` or `yummies/types` import.
95
96
 
96
97
  ```ts
97
98
  import { AnyObject } from 'yummies';
@@ -103,6 +104,11 @@ import { AnyObject } from 'yummies';
103
104
  Additional set of complex utilities
104
105
 
105
106
 
107
+ ## Migration from 5.x to 6.x
108
+
109
+ 1. Replace all imports `yummies/utility-types` to `yummies/types.global`
110
+ 2. Replace all imports `yummies/utils/types` to `yummies/types`
111
+
106
112
  ## Contribution Guide
107
113
 
108
114
  Want to contribute ? [Follow this guide](https://github.com/js2me/yummies/blob/master/CONTRIBUTING.md)
package/async.cjs CHANGED
@@ -1,2 +1,46 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=(t,n)=>{if(t())return;const o=()=>requestAnimationFrame(()=>e(t,n));n?queueMicrotask(o):o()};exports.endlessRAF=e,exports.setAbortableInterval=function(e,t,n){let o=null;n?.addEventListener("abort",()=>{null!=o&&(clearInterval(o),o=null)},{once:!0}),o=setInterval(e,t)},exports.setAbortableTimeout=function(e,t,n){let o=null;const r=()=>{null!=o&&(clearTimeout(o),o=null)};n?.addEventListener("abort",r,{once:!0}),o=setTimeout(()=>{n?.removeEventListener("abort",r),e()},t)},exports.sleep=(e=0)=>new Promise(t=>setTimeout(t,e)),exports.waitAsync=async(e=1e3)=>new Promise(t=>setTimeout(t,e));
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const sleep = (time = 0) => new Promise((resolve) => setTimeout(resolve, time));
4
+ const waitAsync = async (ms = 1e3) => new Promise((resolve) => setTimeout(resolve, ms));
5
+ const endlessRAF = (quitFunction, asMicrotask) => {
6
+ if (quitFunction()) return;
7
+ const raf = () => requestAnimationFrame(() => endlessRAF(quitFunction, asMicrotask));
8
+ if (asMicrotask) {
9
+ queueMicrotask(raf);
10
+ } else {
11
+ raf();
12
+ }
13
+ };
14
+ function setAbortableTimeout(callback, delayInMs, signal) {
15
+ let internalTimer = null;
16
+ const handleAbort = () => {
17
+ if (internalTimer == null) {
18
+ return;
19
+ }
20
+ clearTimeout(internalTimer);
21
+ internalTimer = null;
22
+ };
23
+ signal?.addEventListener("abort", handleAbort, { once: true });
24
+ internalTimer = setTimeout(() => {
25
+ signal?.removeEventListener("abort", handleAbort);
26
+ callback();
27
+ }, delayInMs);
28
+ }
29
+ function setAbortableInterval(callback, delayInMs, signal) {
30
+ let timer = null;
31
+ const handleAbort = () => {
32
+ if (timer == null) {
33
+ return;
34
+ }
35
+ clearInterval(timer);
36
+ timer = null;
37
+ };
38
+ signal?.addEventListener("abort", handleAbort, { once: true });
39
+ timer = setInterval(callback, delayInMs);
40
+ }
41
+ exports.endlessRAF = endlessRAF;
42
+ exports.setAbortableInterval = setAbortableInterval;
43
+ exports.setAbortableTimeout = setAbortableTimeout;
44
+ exports.sleep = sleep;
45
+ exports.waitAsync = waitAsync;
2
46
  //# sourceMappingURL=async.cjs.map
package/async.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"async.cjs","sources":["../src/async.ts"],"sourcesContent":["/**\n * Создает промис, который будет ждать указанное количество ms, чтобы выполниться\n *\n * @param ms значение в миллисекундах\n * @returns Promise\n */\nexport const sleep = (time: number = 0) =>\n new Promise((resolve) => setTimeout(resolve, time));\n\n/**\n * Создает промис, который будет ждать указанное количество ms, чтобы выполниться\n *\n * @deprecated используй {sleep}\n * @param ms значение в миллисекундах\n * @returns Promise\n */\nexport const waitAsync = async (ms = 1000) =>\n new Promise((resolve) => setTimeout(resolve, ms));\n\n/**\n * Создает вызов requestAnimationFrame, посылая туда фукнцию {quitFn}, если она возвращает true,\n * тогда повторно не будет создан вызов requestAnimationFrame, иначе будут создаваться повторно\n * вызовы requestAnimationFrame до тем пор, пока эта функция не вернёт true\n *\n * @param quitFn - сама фукнция которая исполнится в requestAnimationFrame\n * @param asMicrotask - дополнительно оборачивает RAF в queueMicrotask\n * @returns void\n */\nexport const endlessRAF = (\n quitFunction: () => boolean | void,\n asMicrotask?: boolean,\n) => {\n if (quitFunction()) return;\n\n const raf = () =>\n requestAnimationFrame(() => endlessRAF(quitFunction, asMicrotask));\n\n if (asMicrotask) {\n queueMicrotask(raf);\n } else {\n raf();\n }\n};\n\nexport function setAbortableTimeout(\n callback: VoidFunction,\n delayInMs?: number,\n signal?: AbortSignal,\n) {\n let internalTimer: number | null = null;\n\n const handleAbort = () => {\n if (internalTimer == null) {\n return;\n }\n clearTimeout(internalTimer);\n internalTimer = null;\n };\n\n signal?.addEventListener('abort', handleAbort, { once: true });\n\n internalTimer = setTimeout(() => {\n signal?.removeEventListener('abort', handleAbort);\n callback();\n }, delayInMs);\n}\n\nexport function setAbortableInterval(\n callback: VoidFunction,\n delayInMs?: number,\n signal?: AbortSignal,\n) {\n let timer: number | null = null;\n\n const handleAbort = () => {\n if (timer == null) {\n return;\n }\n clearInterval(timer);\n timer = null;\n };\n\n signal?.addEventListener('abort', handleAbort, { once: true });\n\n timer = setInterval(callback, delayInMs);\n}\n"],"names":["endlessRAF","quitFunction","asMicrotask","raf","requestAnimationFrame","queueMicrotask","callback","delayInMs","signal","timer","addEventListener","clearInterval","once","setInterval","internalTimer","handleAbort","clearTimeout","setTimeout","removeEventListener","time","Promise","resolve","async","ms"],"mappings":"gFAMO,MAsBMA,EAAa,CACxBC,EACAC,KAEA,GAAID,IAAgB,OAEpB,MAAME,EAAM,IACVC,sBAAsB,IAAMJ,EAAWC,EAAcC,IAEnDA,EACFG,eAAeF,GAEfA,uDA2BG,SACLG,EACAC,EACAC,GAEA,IAAIC,EAAuB,KAU3BD,GAAQE,iBAAiB,QARL,KACL,MAATD,IAGJE,cAAcF,GACdA,EAAQ,OAGqC,CAAEG,MAAM,IAEvDH,EAAQI,YAAYP,EAAUC,EAChC,8BAzCO,SACLD,EACAC,EACAC,GAEA,IAAIM,EAA+B,KAEnC,MAAMC,EAAc,KACG,MAAjBD,IAGJE,aAAaF,GACbA,EAAgB,OAGlBN,GAAQE,iBAAiB,QAASK,EAAa,CAAEH,MAAM,IAEvDE,EAAgBG,WAAW,KACzBT,GAAQU,oBAAoB,QAASH,GACrCT,KACCC,EACL,gBA3DqB,CAACY,EAAe,IACnC,IAAIC,QAASC,GAAYJ,WAAWI,EAASF,sBAStBG,MAAOC,EAAK,MACnC,IAAIH,QAASC,GAAYJ,WAAWI,EAASE"}
1
+ {"version":3,"file":"async.cjs","sources":["../src/async.ts"],"sourcesContent":["/**\n * Создает промис, который будет ждать указанное количество ms, чтобы выполниться\n *\n * @param ms значение в миллисекундах\n * @returns Promise\n */\nexport const sleep = (time: number = 0) =>\n new Promise((resolve) => setTimeout(resolve, time));\n\n/**\n * Создает промис, который будет ждать указанное количество ms, чтобы выполниться\n *\n * @deprecated используй {sleep}\n * @param ms значение в миллисекундах\n * @returns Promise\n */\nexport const waitAsync = async (ms = 1000) =>\n new Promise((resolve) => setTimeout(resolve, ms));\n\n/**\n * Создает вызов requestAnimationFrame, посылая туда фукнцию {quitFn}, если она возвращает true,\n * тогда повторно не будет создан вызов requestAnimationFrame, иначе будут создаваться повторно\n * вызовы requestAnimationFrame до тем пор, пока эта функция не вернёт true\n *\n * @param quitFn - сама фукнция которая исполнится в requestAnimationFrame\n * @param asMicrotask - дополнительно оборачивает RAF в queueMicrotask\n * @returns void\n */\nexport const endlessRAF = (\n quitFunction: () => boolean | void,\n asMicrotask?: boolean,\n) => {\n if (quitFunction()) return;\n\n const raf = () =>\n requestAnimationFrame(() => endlessRAF(quitFunction, asMicrotask));\n\n if (asMicrotask) {\n queueMicrotask(raf);\n } else {\n raf();\n }\n};\n\nexport function setAbortableTimeout(\n callback: VoidFunction,\n delayInMs?: number,\n signal?: AbortSignal,\n) {\n let internalTimer: number | null = null;\n\n const handleAbort = () => {\n if (internalTimer == null) {\n return;\n }\n clearTimeout(internalTimer);\n internalTimer = null;\n };\n\n signal?.addEventListener('abort', handleAbort, { once: true });\n\n internalTimer = setTimeout(() => {\n signal?.removeEventListener('abort', handleAbort);\n callback();\n }, delayInMs);\n}\n\nexport function setAbortableInterval(\n callback: VoidFunction,\n delayInMs?: number,\n signal?: AbortSignal,\n) {\n let timer: number | null = null;\n\n const handleAbort = () => {\n if (timer == null) {\n return;\n }\n clearInterval(timer);\n timer = null;\n };\n\n signal?.addEventListener('abort', handleAbort, { once: true });\n\n timer = setInterval(callback, delayInMs);\n}\n"],"names":[],"mappings":";;AAMO,MAAM,QAAQ,CAAC,OAAe,MACnC,IAAI,QAAQ,CAAC,YAAY,WAAW,SAAS,IAAI,CAAC;AAS7C,MAAM,YAAY,OAAO,KAAK,QACnC,IAAI,QAAQ,CAAC,YAAY,WAAW,SAAS,EAAE,CAAC;AAW3C,MAAM,aAAa,CACxB,cACA,gBACG;AACH,MAAI,eAAgB;AAEpB,QAAM,MAAM,MACV,sBAAsB,MAAM,WAAW,cAAc,WAAW,CAAC;AAEnE,MAAI,aAAa;AACf,mBAAe,GAAG;AAAA,EACpB,OAAO;AACL,QAAA;AAAA,EACF;AACF;AAEO,SAAS,oBACd,UACA,WACA,QACA;AACA,MAAI,gBAA+B;AAEnC,QAAM,cAAc,MAAM;AACxB,QAAI,iBAAiB,MAAM;AACzB;AAAA,IACF;AACA,iBAAa,aAAa;AAC1B,oBAAgB;AAAA,EAClB;AAEA,UAAQ,iBAAiB,SAAS,aAAa,EAAE,MAAM,MAAM;AAE7D,kBAAgB,WAAW,MAAM;AAC/B,YAAQ,oBAAoB,SAAS,WAAW;AAChD,aAAA;AAAA,EACF,GAAG,SAAS;AACd;AAEO,SAAS,qBACd,UACA,WACA,QACA;AACA,MAAI,QAAuB;AAE3B,QAAM,cAAc,MAAM;AACxB,QAAI,SAAS,MAAM;AACjB;AAAA,IACF;AACA,kBAAc,KAAK;AACnB,YAAQ;AAAA,EACV;AAEA,UAAQ,iBAAiB,SAAS,aAAa,EAAE,MAAM,MAAM;AAE7D,UAAQ,YAAY,UAAU,SAAS;AACzC;;;;;;"}
package/async.d.ts CHANGED
@@ -4,7 +4,7 @@
4
4
  * @param ms значение в миллисекундах
5
5
  * @returns Promise
6
6
  */
7
- export declare const sleep: (time?: number) => Promise<unknown>;
7
+ declare const sleep: (time?: number) => Promise<unknown>;
8
8
  /**
9
9
  * Создает промис, который будет ждать указанное количество ms, чтобы выполниться
10
10
  *
@@ -12,7 +12,7 @@ export declare const sleep: (time?: number) => Promise<unknown>;
12
12
  * @param ms значение в миллисекундах
13
13
  * @returns Promise
14
14
  */
15
- export declare const waitAsync: (ms?: number) => Promise<unknown>;
15
+ declare const waitAsync: (ms?: number) => Promise<unknown>;
16
16
  /**
17
17
  * Создает вызов requestAnimationFrame, посылая туда фукнцию {quitFn}, если она возвращает true,
18
18
  * тогда повторно не будет создан вызов requestAnimationFrame, иначе будут создаваться повторно
@@ -22,7 +22,8 @@ export declare const waitAsync: (ms?: number) => Promise<unknown>;
22
22
  * @param asMicrotask - дополнительно оборачивает RAF в queueMicrotask
23
23
  * @returns void
24
24
  */
25
- export declare const endlessRAF: (quitFunction: () => boolean | void, asMicrotask?: boolean) => void;
26
- export declare function setAbortableTimeout(callback: VoidFunction, delayInMs?: number, signal?: AbortSignal): void;
27
- export declare function setAbortableInterval(callback: VoidFunction, delayInMs?: number, signal?: AbortSignal): void;
28
- //# sourceMappingURL=async.d.ts.map
25
+ declare const endlessRAF: (quitFunction: () => boolean | void, asMicrotask?: boolean) => void;
26
+ declare function setAbortableTimeout(callback: VoidFunction, delayInMs?: number, signal?: AbortSignal): void;
27
+ declare function setAbortableInterval(callback: VoidFunction, delayInMs?: number, signal?: AbortSignal): void;
28
+
29
+ export { endlessRAF, setAbortableInterval, setAbortableTimeout, sleep, waitAsync };
package/common.cjs CHANGED
@@ -1,2 +1,12 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=(e,...t)=>"function"==typeof e?e(...t):e,t=e;exports.callFunction=e,exports.resolveFnValue=t;
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const callFunction = (fn, ...args) => {
4
+ if (typeof fn === "function") {
5
+ return fn(...args);
6
+ }
7
+ return fn;
8
+ };
9
+ const resolveFnValue = callFunction;
10
+ exports.callFunction = callFunction;
11
+ exports.resolveFnValue = resolveFnValue;
2
12
  //# sourceMappingURL=common.cjs.map
package/common.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"common.cjs","sources":["../src/common.ts"],"sourcesContent":["import type { MaybeFn } from 'yummies/utils/types';\n\n/**\n * @deprecated use {MaybeFn} type\n */\nexport type FnValue<TValue, TArgs extends any[] = []> = MaybeFn<TValue, TArgs>;\n\n/**\n * Calls the provided function with the given arguments if it is a function;\n * otherwise, returns the value directly.\n */\nexport const callFunction = <TValue, TArgs extends any[] = []>(\n fn: MaybeFn<TValue, TArgs>,\n ...args: TArgs\n) => {\n if (typeof fn === 'function') {\n return (fn as any)(...args) as TValue;\n }\n\n return fn;\n};\n\n/**\n * @deprecated use {callFunction}\n */\nexport const resolveFnValue = callFunction;\n"],"names":["callFunction","fn","args","resolveFnValue"],"mappings":"gFAWO,MAAMA,EAAe,CAC1BC,KACGC,IAEe,mBAAPD,EACDA,KAAcC,GAGjBD,EAMIE,EAAiBH"}
1
+ {"version":3,"file":"common.cjs","sources":["../src/common.ts"],"sourcesContent":["import type { MaybeFn } from 'yummies/types';\n\n/**\n * @deprecated use {MaybeFn} type\n */\nexport type FnValue<TValue, TArgs extends any[] = []> = MaybeFn<TValue, TArgs>;\n\n/**\n * Calls the provided function with the given arguments if it is a function;\n * otherwise, returns the value directly.\n */\nexport const callFunction = <TValue, TArgs extends any[] = []>(\n fn: MaybeFn<TValue, TArgs>,\n ...args: TArgs\n) => {\n if (typeof fn === 'function') {\n return (fn as any)(...args) as TValue;\n }\n\n return fn;\n};\n\n/**\n * @deprecated use {callFunction}\n */\nexport const resolveFnValue = callFunction;\n"],"names":[],"mappings":";;AAWO,MAAM,eAAe,CAC1B,OACG,SACA;AACH,MAAI,OAAO,OAAO,YAAY;AAC5B,WAAQ,GAAW,GAAG,IAAI;AAAA,EAC5B;AAEA,SAAO;AACT;AAKO,MAAM,iBAAiB;;;"}
package/common.d.ts CHANGED
@@ -1,15 +1,18 @@
1
- import { MaybeFn } from './utils/types.ts';
1
+ import { MaybeFn } from 'yummies/types';
2
+
2
3
  /**
3
4
  * @deprecated use {MaybeFn} type
4
5
  */
5
- export type FnValue<TValue, TArgs extends any[] = []> = MaybeFn<TValue, TArgs>;
6
+ type FnValue<TValue, TArgs extends any[] = []> = MaybeFn<TValue, TArgs>;
6
7
  /**
7
8
  * Calls the provided function with the given arguments if it is a function;
8
9
  * otherwise, returns the value directly.
9
10
  */
10
- export declare const callFunction: <TValue, TArgs extends any[] = []>(fn: MaybeFn<TValue, TArgs>, ...args: TArgs) => TValue;
11
+ declare const callFunction: <TValue, TArgs extends any[] = []>(fn: MaybeFn<TValue, TArgs>, ...args: TArgs) => TValue;
11
12
  /**
12
13
  * @deprecated use {callFunction}
13
14
  */
14
- export declare const resolveFnValue: <TValue, TArgs extends any[] = []>(fn: MaybeFn<TValue, TArgs>, ...args: TArgs) => TValue;
15
- //# sourceMappingURL=common.d.ts.map
15
+ declare const resolveFnValue: <TValue, TArgs extends any[] = []>(fn: MaybeFn<TValue, TArgs>, ...args: TArgs) => TValue;
16
+
17
+ export { callFunction, resolveFnValue };
18
+ export type { FnValue };
package/common.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"common.js","sources":["../src/common.ts"],"sourcesContent":["import type { MaybeFn } from 'yummies/utils/types';\n\n/**\n * @deprecated use {MaybeFn} type\n */\nexport type FnValue<TValue, TArgs extends any[] = []> = MaybeFn<TValue, TArgs>;\n\n/**\n * Calls the provided function with the given arguments if it is a function;\n * otherwise, returns the value directly.\n */\nexport const callFunction = <TValue, TArgs extends any[] = []>(\n fn: MaybeFn<TValue, TArgs>,\n ...args: TArgs\n) => {\n if (typeof fn === 'function') {\n return (fn as any)(...args) as TValue;\n }\n\n return fn;\n};\n\n/**\n * @deprecated use {callFunction}\n */\nexport const resolveFnValue = callFunction;\n"],"names":[],"mappings":"AAWO,MAAM,eAAe,CAC1B,OACG,SACA;AACH,MAAI,OAAO,OAAO,YAAY;AAC5B,WAAQ,GAAW,GAAG,IAAI;AAAA,EAC5B;AAEA,SAAO;AACT;AAKO,MAAM,iBAAiB;"}
1
+ {"version":3,"file":"common.js","sources":["../src/common.ts"],"sourcesContent":["import type { MaybeFn } from 'yummies/types';\n\n/**\n * @deprecated use {MaybeFn} type\n */\nexport type FnValue<TValue, TArgs extends any[] = []> = MaybeFn<TValue, TArgs>;\n\n/**\n * Calls the provided function with the given arguments if it is a function;\n * otherwise, returns the value directly.\n */\nexport const callFunction = <TValue, TArgs extends any[] = []>(\n fn: MaybeFn<TValue, TArgs>,\n ...args: TArgs\n) => {\n if (typeof fn === 'function') {\n return (fn as any)(...args) as TValue;\n }\n\n return fn;\n};\n\n/**\n * @deprecated use {callFunction}\n */\nexport const resolveFnValue = callFunction;\n"],"names":[],"mappings":"AAWO,MAAM,eAAe,CAC1B,OACG,SACA;AACH,MAAI,OAAO,OAAO,YAAY;AAC5B,WAAQ,GAAW,GAAG,IAAI;AAAA,EAC5B;AAEA,SAAO;AACT;AAKO,MAAM,iBAAiB;"}
package/complex.cjs CHANGED
@@ -1,2 +1,89 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=e=>{if(null==e){let e;return{get:()=>e,set:t=>(e=t,t)}}const t=globalThis;return{get:()=>t[e],set:r=>(t[e]=r,r)}};exports.ModulesFactory=class{constructor(e){this.config=e}create(e,...t){return this.config.factory(e,{...this.config.deps,...t[0]})}},exports.createCounter=(e,t=0)=>{const r=t=>(o.value=e?.(t)??t,o.value),n=()=>r(++o.counter),o=n;return o.increment=n,o.decrement=()=>r(--o.counter),o.reset=()=>{o.counter=t,o.value=e?.(t)??t},o.reset(),o},exports.createGlobalConfig=(t,r)=>{const n=e(r);return n.get()||n.set(t)},exports.createGlobalDynamicConfig=(t,r)=>{const n=e(r),o=()=>n.get()??n.set(t(null,null));return{get:o,set:n.set,update:e=>{const r=o();Object.assign(r,t(e,r))}}};
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const createCounter = (processValue, initial = 0) => {
4
+ const update = (counter) => {
5
+ fn.value = processValue?.(counter) ?? counter;
6
+ return fn.value;
7
+ };
8
+ const increment = () => update(++fn.counter);
9
+ const decrement = () => update(--fn.counter);
10
+ const fn = increment;
11
+ fn.increment = increment;
12
+ fn.decrement = decrement;
13
+ fn.reset = () => {
14
+ fn.counter = initial;
15
+ fn.value = processValue?.(initial) ?? initial;
16
+ };
17
+ fn.reset();
18
+ return fn;
19
+ };
20
+ const createGlobalPoint = (accessSymbol) => {
21
+ if (accessSymbol == null) {
22
+ let storedValue;
23
+ return {
24
+ get: () => storedValue,
25
+ set: (value) => {
26
+ storedValue = value;
27
+ return value;
28
+ }
29
+ };
30
+ }
31
+ const _globalThis = globalThis;
32
+ return {
33
+ get: () => _globalThis[accessSymbol],
34
+ set: (value) => {
35
+ _globalThis[accessSymbol] = value;
36
+ return value;
37
+ }
38
+ };
39
+ };
40
+ const createGlobalConfig = (defaultValue, accessSymbol) => {
41
+ const globalPoint = createGlobalPoint(accessSymbol);
42
+ return globalPoint.get() || globalPoint.set(defaultValue);
43
+ };
44
+ const createGlobalDynamicConfig = (processFn, accessSymbol) => {
45
+ const globalPoint = createGlobalPoint(accessSymbol);
46
+ const getValue = () => {
47
+ return globalPoint.get() ?? globalPoint.set(processFn(null, null));
48
+ };
49
+ return {
50
+ get: getValue,
51
+ set: globalPoint.set,
52
+ update: (value) => {
53
+ const currentValue = getValue();
54
+ Object.assign(currentValue, processFn(value, currentValue));
55
+ }
56
+ };
57
+ };
58
+ class ModulesFactory {
59
+ /**
60
+ * Создает новый экземпляр `ModulesFactory`.
61
+ *
62
+ * @param config - Объект конфигурации для фабрики, включающий функцию фабрики и необязательные зависимости.
63
+ */
64
+ constructor(config) {
65
+ this.config = config;
66
+ }
67
+ /**
68
+ * Создает экземпляр указанного класса, внедряя необходимые зависимости.
69
+ *
70
+ * @template TInstance - Тип создаваемого экземпляра.
71
+ * @template TDeps - Тип зависимостей, необходимых для экземпляра.
72
+ *
73
+ * @param Constructor - Конструктор класса для создаваемого экземпляра.
74
+ * @param args - Необязательные дополнительные зависимости для объединения с предопределенными зависимостями.
75
+ *
76
+ * @returns Экземпляр указанного класса с внедренными зависимостями.
77
+ */
78
+ create(Constructor, ...args) {
79
+ return this.config.factory(Constructor, {
80
+ ...this.config.deps,
81
+ ...args[0]
82
+ });
83
+ }
84
+ }
85
+ exports.ModulesFactory = ModulesFactory;
86
+ exports.createCounter = createCounter;
87
+ exports.createGlobalConfig = createGlobalConfig;
88
+ exports.createGlobalDynamicConfig = createGlobalDynamicConfig;
2
89
  //# sourceMappingURL=complex.cjs.map
package/complex.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"complex.cjs","sources":["../src/complex/counter.ts","../src/complex/global-config.ts","../src/complex/modules-factory.ts"],"sourcesContent":["export interface Counter<TValue = number> {\n (): TValue;\n counter: number;\n value: TValue;\n increment(): TValue;\n decrement(): TValue;\n reset(): void;\n}\n\n/**\n * @deprecated use {`Counter`}. Will be removed in next major release\n */\nexport interface CounterFn<TValue = number> extends Counter<TValue> {}\n\nexport const createCounter = <TValue = number>(\n processValue?: (value: number) => TValue,\n initial: number = 0,\n): Counter<TValue> => {\n const update = (counter: number) => {\n fn.value = processValue?.(counter) ?? (counter as TValue);\n return fn.value;\n };\n\n const increment = () => update(++fn.counter);\n const decrement = () => update(--fn.counter);\n\n const fn: Counter<TValue> = increment as any;\n\n fn.increment = increment;\n fn.decrement = decrement;\n\n fn.reset = () => {\n fn.counter = initial;\n fn.value = processValue?.(initial) ?? (initial as TValue);\n };\n\n fn.reset();\n\n return fn as Counter<TValue>;\n};\n","import type { AnyObject, Maybe } from 'yummies/utils/types';\n\nconst createGlobalPoint = <TValue>(accessSymbol?: keyof any) => {\n if (accessSymbol == null) {\n let storedValue: TValue | undefined;\n return {\n get: (): TValue => storedValue!,\n set: (value: TValue): TValue => {\n storedValue = value;\n return value;\n },\n };\n }\n\n const _globalThis = globalThis as AnyObject;\n\n return {\n get: (): TValue => _globalThis[accessSymbol],\n set: (value: TValue): TValue => {\n _globalThis[accessSymbol] = value;\n return value;\n },\n };\n};\n\n/**\n * Создает глобальный конфиг, который может быть доступен в любой точке в коде\n */\nexport const createGlobalConfig = <T extends AnyObject>(\n defaultValue: T,\n accessSymbol?: keyof any,\n) => {\n const globalPoint = createGlobalPoint<T>(accessSymbol);\n return globalPoint.get() || globalPoint.set(defaultValue);\n};\n\nexport const createGlobalDynamicConfig = <T extends AnyObject>(\n processFn: (change: Maybe<Partial<T>>, current: Maybe<T>) => T,\n accessSymbol?: keyof any,\n) => {\n const globalPoint = createGlobalPoint<T | null | undefined>(accessSymbol);\n\n const getValue = () => {\n return globalPoint.get() ?? globalPoint.set(processFn(null, null))!;\n };\n\n return {\n get: getValue,\n set: globalPoint.set,\n update: (value: Partial<T>) => {\n const currentValue = getValue();\n Object.assign(currentValue, processFn(value, currentValue));\n },\n };\n};\n","import type {\n AnyObject,\n Class,\n EmptyObject,\n IsPartial,\n} from 'yummies/utils/types';\n\ntype ModuleLoaderConfig<TPredefinedDeps extends AnyObject = EmptyObject> = {\n factory<TInstance, TDeps extends TPredefinedDeps>(\n moduleClass: Class<TInstance, [TDeps]>,\n deps: TDeps,\n ): TInstance;\n} & (TPredefinedDeps extends EmptyObject\n ? { deps?: TPredefinedDeps }\n : { deps: TPredefinedDeps });\n\n/**\n * Класс `ModulesFactory` является универсальной фабрикой для создания экземпляров указанного класса с зависимостями.\n * Он использует объект конфигурации для определения того, как эти экземпляры создаются.\n *\n * Важное примечание - эта сущность работает только с классами конструктор которых имеет один параметр\n *\n * @template TPredefinedDeps - Тип, расширяющий `AnyObject`, представляющий предопределенные зависимости, которые использует фабрика.\n *\n * @example\n * ```\n * const factory = new ModulesFactory({\n * factory: (MyClass, deps) => new MyClass(deps),\n * deps: { someDependency: new Dependency() }\n * });\n *\n * const instance = factory.create(MyClass, { extraDependency: new ExtraDependency() });\n * ```\n */\nexport class ModulesFactory<TPredefinedDeps extends AnyObject = EmptyObject> {\n /**\n * Создает новый экземпляр `ModulesFactory`.\n *\n * @param config - Объект конфигурации для фабрики, включающий функцию фабрики и необязательные зависимости.\n */\n constructor(private config: ModuleLoaderConfig<TPredefinedDeps>) {}\n\n /**\n * Создает экземпляр указанного класса, внедряя необходимые зависимости.\n *\n * @template TInstance - Тип создаваемого экземпляра.\n * @template TDeps - Тип зависимостей, необходимых для экземпляра.\n *\n * @param Constructor - Конструктор класса для создаваемого экземпляра.\n * @param args - Необязательные дополнительные зависимости для объединения с предопределенными зависимостями.\n *\n * @returns Экземпляр указанного класса с внедренными зависимостями.\n */\n create<TInstance, TDeps extends TPredefinedDeps = TPredefinedDeps>(\n Constructor: Class<TInstance, [TDeps]>,\n ...args: IsPartial<Omit<TDeps, keyof TPredefinedDeps>> extends true\n ? [extraDeps?: Omit<TDeps, keyof TPredefinedDeps>]\n : [extraDeps: Omit<TDeps, keyof TPredefinedDeps>]\n ) {\n return this.config.factory(Constructor, {\n ...this.config.deps!,\n ...args[0],\n } as any);\n }\n}\n"],"names":["createGlobalPoint","accessSymbol","storedValue","get","set","value","_globalThis","globalThis","constructor","config","this","create","Constructor","args","factory","deps","processValue","initial","update","counter","fn","increment","decrement","reset","defaultValue","globalPoint","processFn","getValue","currentValue","Object","assign"],"mappings":"gFAcO,MCZDA,EAA6BC,IACjC,GAAoB,MAAhBA,EAAsB,CACxB,IAAIC,EACJ,MAAO,CACLC,IAAK,IAAcD,EACnBE,IAAMC,IACJH,EAAcG,EACPA,GAGb,CAEA,MAAMC,EAAcC,WAEpB,MAAO,CACLJ,IAAK,IAAcG,EAAYL,GAC/BG,IAAMC,IACJC,EAAYL,GAAgBI,EACrBA,4BCcN,MAML,WAAAG,CAAoBC,GAAAC,KAAAD,OAAAA,CAA8C,CAalE,MAAAE,CACEC,KACGC,GAIH,OAAOH,KAAKD,OAAOK,QAAQF,EAAa,IACnCF,KAAKD,OAAOM,QACZF,EAAK,IAEZ,yBFjD2B,CAC3BG,EACAC,EAAkB,KAElB,MAAMC,EAAUC,IACdC,EAAGf,MAAQW,IAAeG,IAAaA,EAChCC,EAAGf,OAGNgB,EAAY,IAAMH,IAASE,EAAGD,SAG9BC,EAAsBC,EAY5B,OAVAD,EAAGC,UAAYA,EACfD,EAAGE,UALe,IAAMJ,IAASE,EAAGD,SAOpCC,EAAGG,MAAQ,KACTH,EAAGD,QAAUF,EACbG,EAAGf,MAAQW,IAAeC,IAAaA,GAGzCG,EAAGG,QAEIH,8BCVyB,CAChCI,EACAvB,KAEA,MAAMwB,EAAczB,EAAqBC,GACzC,OAAOwB,EAAYtB,OAASsB,EAAYrB,IAAIoB,sCAGL,CACvCE,EACAzB,KAEA,MAAMwB,EAAczB,EAAwCC,GAEtD0B,EAAW,IACRF,EAAYtB,OAASsB,EAAYrB,IAAIsB,EAAU,KAAM,OAG9D,MAAO,CACLvB,IAAKwB,EACLvB,IAAKqB,EAAYrB,IACjBc,OAASb,IACP,MAAMuB,EAAeD,IACrBE,OAAOC,OAAOF,EAAcF,EAAUrB,EAAOuB"}
1
+ {"version":3,"file":"complex.cjs","sources":["../src/complex/counter.ts","../src/complex/global-config.ts","../src/complex/modules-factory.ts"],"sourcesContent":["export interface Counter<TValue = number> {\n (): TValue;\n counter: number;\n value: TValue;\n increment(): TValue;\n decrement(): TValue;\n reset(): void;\n}\n\n/**\n * @deprecated use {`Counter`}. Will be removed in next major release\n */\nexport interface CounterFn<TValue = number> extends Counter<TValue> {}\n\nexport const createCounter = <TValue = number>(\n processValue?: (value: number) => TValue,\n initial: number = 0,\n): Counter<TValue> => {\n const update = (counter: number) => {\n fn.value = processValue?.(counter) ?? (counter as TValue);\n return fn.value;\n };\n\n const increment = () => update(++fn.counter);\n const decrement = () => update(--fn.counter);\n\n const fn: Counter<TValue> = increment as any;\n\n fn.increment = increment;\n fn.decrement = decrement;\n\n fn.reset = () => {\n fn.counter = initial;\n fn.value = processValue?.(initial) ?? (initial as TValue);\n };\n\n fn.reset();\n\n return fn as Counter<TValue>;\n};\n","import type { AnyObject, Maybe } from 'yummies/types';\n\nconst createGlobalPoint = <TValue>(accessSymbol?: keyof any) => {\n if (accessSymbol == null) {\n let storedValue: TValue | undefined;\n return {\n get: (): TValue => storedValue!,\n set: (value: TValue): TValue => {\n storedValue = value;\n return value;\n },\n };\n }\n\n const _globalThis = globalThis as AnyObject;\n\n return {\n get: (): TValue => _globalThis[accessSymbol],\n set: (value: TValue): TValue => {\n _globalThis[accessSymbol] = value;\n return value;\n },\n };\n};\n\n/**\n * Создает глобальный конфиг, который может быть доступен в любой точке в коде\n */\nexport const createGlobalConfig = <T extends AnyObject>(\n defaultValue: T,\n accessSymbol?: keyof any,\n) => {\n const globalPoint = createGlobalPoint<T>(accessSymbol);\n return globalPoint.get() || globalPoint.set(defaultValue);\n};\n\nexport const createGlobalDynamicConfig = <T extends AnyObject>(\n processFn: (change: Maybe<Partial<T>>, current: Maybe<T>) => T,\n accessSymbol?: keyof any,\n) => {\n const globalPoint = createGlobalPoint<T | null | undefined>(accessSymbol);\n\n const getValue = () => {\n return globalPoint.get() ?? globalPoint.set(processFn(null, null))!;\n };\n\n return {\n get: getValue,\n set: globalPoint.set,\n update: (value: Partial<T>) => {\n const currentValue = getValue();\n Object.assign(currentValue, processFn(value, currentValue));\n },\n };\n};\n","import type { AnyObject, Class, EmptyObject, IsPartial } from 'yummies/types';\n\ntype ModuleLoaderConfig<TPredefinedDeps extends AnyObject = EmptyObject> = {\n factory<TInstance, TDeps extends TPredefinedDeps>(\n moduleClass: Class<TInstance, [TDeps]>,\n deps: TDeps,\n ): TInstance;\n} & (TPredefinedDeps extends EmptyObject\n ? { deps?: TPredefinedDeps }\n : { deps: TPredefinedDeps });\n\n/**\n * Класс `ModulesFactory` является универсальной фабрикой для создания экземпляров указанного класса с зависимостями.\n * Он использует объект конфигурации для определения того, как эти экземпляры создаются.\n *\n * Важное примечание - эта сущность работает только с классами конструктор которых имеет один параметр\n *\n * @template TPredefinedDeps - Тип, расширяющий `AnyObject`, представляющий предопределенные зависимости, которые использует фабрика.\n *\n * @example\n * ```\n * const factory = new ModulesFactory({\n * factory: (MyClass, deps) => new MyClass(deps),\n * deps: { someDependency: new Dependency() }\n * });\n *\n * const instance = factory.create(MyClass, { extraDependency: new ExtraDependency() });\n * ```\n */\nexport class ModulesFactory<TPredefinedDeps extends AnyObject = EmptyObject> {\n /**\n * Создает новый экземпляр `ModulesFactory`.\n *\n * @param config - Объект конфигурации для фабрики, включающий функцию фабрики и необязательные зависимости.\n */\n constructor(private config: ModuleLoaderConfig<TPredefinedDeps>) {}\n\n /**\n * Создает экземпляр указанного класса, внедряя необходимые зависимости.\n *\n * @template TInstance - Тип создаваемого экземпляра.\n * @template TDeps - Тип зависимостей, необходимых для экземпляра.\n *\n * @param Constructor - Конструктор класса для создаваемого экземпляра.\n * @param args - Необязательные дополнительные зависимости для объединения с предопределенными зависимостями.\n *\n * @returns Экземпляр указанного класса с внедренными зависимостями.\n */\n create<TInstance, TDeps extends TPredefinedDeps = TPredefinedDeps>(\n Constructor: Class<TInstance, [TDeps]>,\n ...args: IsPartial<Omit<TDeps, keyof TPredefinedDeps>> extends true\n ? [extraDeps?: Omit<TDeps, keyof TPredefinedDeps>]\n : [extraDeps: Omit<TDeps, keyof TPredefinedDeps>]\n ) {\n return this.config.factory(Constructor, {\n ...this.config.deps!,\n ...args[0],\n } as any);\n }\n}\n"],"names":[],"mappings":";;AAcO,MAAM,gBAAgB,CAC3B,cACA,UAAkB,MACE;AACpB,QAAM,SAAS,CAAC,YAAoB;AAClC,OAAG,QAAQ,eAAe,OAAO,KAAM;AACvC,WAAO,GAAG;AAAA,EACZ;AAEA,QAAM,YAAY,MAAM,OAAO,EAAE,GAAG,OAAO;AAC3C,QAAM,YAAY,MAAM,OAAO,EAAE,GAAG,OAAO;AAE3C,QAAM,KAAsB;AAE5B,KAAG,YAAY;AACf,KAAG,YAAY;AAEf,KAAG,QAAQ,MAAM;AACf,OAAG,UAAU;AACb,OAAG,QAAQ,eAAe,OAAO,KAAM;AAAA,EACzC;AAEA,KAAG,MAAA;AAEH,SAAO;AACT;ACrCA,MAAM,oBAAoB,CAAS,iBAA6B;AAC9D,MAAI,gBAAgB,MAAM;AACxB,QAAI;AACJ,WAAO;AAAA,MACL,KAAK,MAAc;AAAA,MACnB,KAAK,CAAC,UAA0B;AAC9B,sBAAc;AACd,eAAO;AAAA,MACT;AAAA,IAAA;AAAA,EAEJ;AAEA,QAAM,cAAc;AAEpB,SAAO;AAAA,IACL,KAAK,MAAc,YAAY,YAAY;AAAA,IAC3C,KAAK,CAAC,UAA0B;AAC9B,kBAAY,YAAY,IAAI;AAC5B,aAAO;AAAA,IACT;AAAA,EAAA;AAEJ;AAKO,MAAM,qBAAqB,CAChC,cACA,iBACG;AACH,QAAM,cAAc,kBAAqB,YAAY;AACrD,SAAO,YAAY,IAAA,KAAS,YAAY,IAAI,YAAY;AAC1D;AAEO,MAAM,4BAA4B,CACvC,WACA,iBACG;AACH,QAAM,cAAc,kBAAwC,YAAY;AAExE,QAAM,WAAW,MAAM;AACrB,WAAO,YAAY,SAAS,YAAY,IAAI,UAAU,MAAM,IAAI,CAAC;AAAA,EACnE;AAEA,SAAO;AAAA,IACL,KAAK;AAAA,IACL,KAAK,YAAY;AAAA,IACjB,QAAQ,CAAC,UAAsB;AAC7B,YAAM,eAAe,SAAA;AACrB,aAAO,OAAO,cAAc,UAAU,OAAO,YAAY,CAAC;AAAA,IAC5D;AAAA,EAAA;AAEJ;ACzBO,MAAM,eAAgE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAM3E,YAAoB,QAA6C;AAA7C,SAAA,SAAA;AAAA,EAA8C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAalE,OACE,gBACG,MAGH;AACA,WAAO,KAAK,OAAO,QAAQ,aAAa;AAAA,MACtC,GAAG,KAAK,OAAO;AAAA,MACf,GAAG,KAAK,CAAC;AAAA,IAAA,CACH;AAAA,EACV;AACF;;;;;"}
@@ -1,4 +1,30 @@
1
- import { AnyObject, Class, EmptyObject, IsPartial } from '../utils/types.ts';
1
+ import { AnyObject, Maybe, EmptyObject, Class, IsPartial } from 'yummies/types';
2
+
3
+ interface Counter<TValue = number> {
4
+ (): TValue;
5
+ counter: number;
6
+ value: TValue;
7
+ increment(): TValue;
8
+ decrement(): TValue;
9
+ reset(): void;
10
+ }
11
+ /**
12
+ * @deprecated use {`Counter`}. Will be removed in next major release
13
+ */
14
+ interface CounterFn<TValue = number> extends Counter<TValue> {
15
+ }
16
+ declare const createCounter: <TValue = number>(processValue?: (value: number) => TValue, initial?: number) => Counter<TValue>;
17
+
18
+ /**
19
+ * Создает глобальный конфиг, который может быть доступен в любой точке в коде
20
+ */
21
+ declare const createGlobalConfig: <T extends AnyObject>(defaultValue: T, accessSymbol?: keyof any) => T;
22
+ declare const createGlobalDynamicConfig: <T extends AnyObject>(processFn: (change: Maybe<Partial<T>>, current: Maybe<T>) => T, accessSymbol?: keyof any) => {
23
+ get: () => T;
24
+ set: (value: T | null | undefined) => T | null | undefined;
25
+ update: (value: Partial<T>) => void;
26
+ };
27
+
2
28
  type ModuleLoaderConfig<TPredefinedDeps extends AnyObject = EmptyObject> = {
3
29
  factory<TInstance, TDeps extends TPredefinedDeps>(moduleClass: Class<TInstance, [TDeps]>, deps: TDeps): TInstance;
4
30
  } & (TPredefinedDeps extends EmptyObject ? {
@@ -24,7 +50,7 @@ type ModuleLoaderConfig<TPredefinedDeps extends AnyObject = EmptyObject> = {
24
50
  * const instance = factory.create(MyClass, { extraDependency: new ExtraDependency() });
25
51
  * ```
26
52
  */
27
- export declare class ModulesFactory<TPredefinedDeps extends AnyObject = EmptyObject> {
53
+ declare class ModulesFactory<TPredefinedDeps extends AnyObject = EmptyObject> {
28
54
  private config;
29
55
  /**
30
56
  * Создает новый экземпляр `ModulesFactory`.
@@ -45,5 +71,6 @@ export declare class ModulesFactory<TPredefinedDeps extends AnyObject = EmptyObj
45
71
  */
46
72
  create<TInstance, TDeps extends TPredefinedDeps = TPredefinedDeps>(Constructor: Class<TInstance, [TDeps]>, ...args: IsPartial<Omit<TDeps, keyof TPredefinedDeps>> extends true ? [extraDeps?: Omit<TDeps, keyof TPredefinedDeps>] : [extraDeps: Omit<TDeps, keyof TPredefinedDeps>]): TInstance;
47
73
  }
48
- export {};
49
- //# sourceMappingURL=modules-factory.d.ts.map
74
+
75
+ export { ModulesFactory, createCounter, createGlobalConfig, createGlobalDynamicConfig };
76
+ export type { Counter, CounterFn };
package/complex.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"complex.js","sources":["../src/complex/counter.ts","../src/complex/global-config.ts","../src/complex/modules-factory.ts"],"sourcesContent":["export interface Counter<TValue = number> {\n (): TValue;\n counter: number;\n value: TValue;\n increment(): TValue;\n decrement(): TValue;\n reset(): void;\n}\n\n/**\n * @deprecated use {`Counter`}. Will be removed in next major release\n */\nexport interface CounterFn<TValue = number> extends Counter<TValue> {}\n\nexport const createCounter = <TValue = number>(\n processValue?: (value: number) => TValue,\n initial: number = 0,\n): Counter<TValue> => {\n const update = (counter: number) => {\n fn.value = processValue?.(counter) ?? (counter as TValue);\n return fn.value;\n };\n\n const increment = () => update(++fn.counter);\n const decrement = () => update(--fn.counter);\n\n const fn: Counter<TValue> = increment as any;\n\n fn.increment = increment;\n fn.decrement = decrement;\n\n fn.reset = () => {\n fn.counter = initial;\n fn.value = processValue?.(initial) ?? (initial as TValue);\n };\n\n fn.reset();\n\n return fn as Counter<TValue>;\n};\n","import type { AnyObject, Maybe } from 'yummies/utils/types';\n\nconst createGlobalPoint = <TValue>(accessSymbol?: keyof any) => {\n if (accessSymbol == null) {\n let storedValue: TValue | undefined;\n return {\n get: (): TValue => storedValue!,\n set: (value: TValue): TValue => {\n storedValue = value;\n return value;\n },\n };\n }\n\n const _globalThis = globalThis as AnyObject;\n\n return {\n get: (): TValue => _globalThis[accessSymbol],\n set: (value: TValue): TValue => {\n _globalThis[accessSymbol] = value;\n return value;\n },\n };\n};\n\n/**\n * Создает глобальный конфиг, который может быть доступен в любой точке в коде\n */\nexport const createGlobalConfig = <T extends AnyObject>(\n defaultValue: T,\n accessSymbol?: keyof any,\n) => {\n const globalPoint = createGlobalPoint<T>(accessSymbol);\n return globalPoint.get() || globalPoint.set(defaultValue);\n};\n\nexport const createGlobalDynamicConfig = <T extends AnyObject>(\n processFn: (change: Maybe<Partial<T>>, current: Maybe<T>) => T,\n accessSymbol?: keyof any,\n) => {\n const globalPoint = createGlobalPoint<T | null | undefined>(accessSymbol);\n\n const getValue = () => {\n return globalPoint.get() ?? globalPoint.set(processFn(null, null))!;\n };\n\n return {\n get: getValue,\n set: globalPoint.set,\n update: (value: Partial<T>) => {\n const currentValue = getValue();\n Object.assign(currentValue, processFn(value, currentValue));\n },\n };\n};\n","import type {\n AnyObject,\n Class,\n EmptyObject,\n IsPartial,\n} from 'yummies/utils/types';\n\ntype ModuleLoaderConfig<TPredefinedDeps extends AnyObject = EmptyObject> = {\n factory<TInstance, TDeps extends TPredefinedDeps>(\n moduleClass: Class<TInstance, [TDeps]>,\n deps: TDeps,\n ): TInstance;\n} & (TPredefinedDeps extends EmptyObject\n ? { deps?: TPredefinedDeps }\n : { deps: TPredefinedDeps });\n\n/**\n * Класс `ModulesFactory` является универсальной фабрикой для создания экземпляров указанного класса с зависимостями.\n * Он использует объект конфигурации для определения того, как эти экземпляры создаются.\n *\n * Важное примечание - эта сущность работает только с классами конструктор которых имеет один параметр\n *\n * @template TPredefinedDeps - Тип, расширяющий `AnyObject`, представляющий предопределенные зависимости, которые использует фабрика.\n *\n * @example\n * ```\n * const factory = new ModulesFactory({\n * factory: (MyClass, deps) => new MyClass(deps),\n * deps: { someDependency: new Dependency() }\n * });\n *\n * const instance = factory.create(MyClass, { extraDependency: new ExtraDependency() });\n * ```\n */\nexport class ModulesFactory<TPredefinedDeps extends AnyObject = EmptyObject> {\n /**\n * Создает новый экземпляр `ModulesFactory`.\n *\n * @param config - Объект конфигурации для фабрики, включающий функцию фабрики и необязательные зависимости.\n */\n constructor(private config: ModuleLoaderConfig<TPredefinedDeps>) {}\n\n /**\n * Создает экземпляр указанного класса, внедряя необходимые зависимости.\n *\n * @template TInstance - Тип создаваемого экземпляра.\n * @template TDeps - Тип зависимостей, необходимых для экземпляра.\n *\n * @param Constructor - Конструктор класса для создаваемого экземпляра.\n * @param args - Необязательные дополнительные зависимости для объединения с предопределенными зависимостями.\n *\n * @returns Экземпляр указанного класса с внедренными зависимостями.\n */\n create<TInstance, TDeps extends TPredefinedDeps = TPredefinedDeps>(\n Constructor: Class<TInstance, [TDeps]>,\n ...args: IsPartial<Omit<TDeps, keyof TPredefinedDeps>> extends true\n ? [extraDeps?: Omit<TDeps, keyof TPredefinedDeps>]\n : [extraDeps: Omit<TDeps, keyof TPredefinedDeps>]\n ) {\n return this.config.factory(Constructor, {\n ...this.config.deps!,\n ...args[0],\n } as any);\n }\n}\n"],"names":[],"mappings":"AAcO,MAAM,gBAAgB,CAC3B,cACA,UAAkB,MACE;AACpB,QAAM,SAAS,CAAC,YAAoB;AAClC,OAAG,QAAQ,eAAe,OAAO,KAAM;AACvC,WAAO,GAAG;AAAA,EACZ;AAEA,QAAM,YAAY,MAAM,OAAO,EAAE,GAAG,OAAO;AAC3C,QAAM,YAAY,MAAM,OAAO,EAAE,GAAG,OAAO;AAE3C,QAAM,KAAsB;AAE5B,KAAG,YAAY;AACf,KAAG,YAAY;AAEf,KAAG,QAAQ,MAAM;AACf,OAAG,UAAU;AACb,OAAG,QAAQ,eAAe,OAAO,KAAM;AAAA,EACzC;AAEA,KAAG,MAAA;AAEH,SAAO;AACT;ACrCA,MAAM,oBAAoB,CAAS,iBAA6B;AAC9D,MAAI,gBAAgB,MAAM;AACxB,QAAI;AACJ,WAAO;AAAA,MACL,KAAK,MAAc;AAAA,MACnB,KAAK,CAAC,UAA0B;AAC9B,sBAAc;AACd,eAAO;AAAA,MACT;AAAA,IAAA;AAAA,EAEJ;AAEA,QAAM,cAAc;AAEpB,SAAO;AAAA,IACL,KAAK,MAAc,YAAY,YAAY;AAAA,IAC3C,KAAK,CAAC,UAA0B;AAC9B,kBAAY,YAAY,IAAI;AAC5B,aAAO;AAAA,IACT;AAAA,EAAA;AAEJ;AAKO,MAAM,qBAAqB,CAChC,cACA,iBACG;AACH,QAAM,cAAc,kBAAqB,YAAY;AACrD,SAAO,YAAY,IAAA,KAAS,YAAY,IAAI,YAAY;AAC1D;AAEO,MAAM,4BAA4B,CACvC,WACA,iBACG;AACH,QAAM,cAAc,kBAAwC,YAAY;AAExE,QAAM,WAAW,MAAM;AACrB,WAAO,YAAY,SAAS,YAAY,IAAI,UAAU,MAAM,IAAI,CAAC;AAAA,EACnE;AAEA,SAAO;AAAA,IACL,KAAK;AAAA,IACL,KAAK,YAAY;AAAA,IACjB,QAAQ,CAAC,UAAsB;AAC7B,YAAM,eAAe,SAAA;AACrB,aAAO,OAAO,cAAc,UAAU,OAAO,YAAY,CAAC;AAAA,IAC5D;AAAA,EAAA;AAEJ;ACpBO,MAAM,eAAgE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAM3E,YAAoB,QAA6C;AAA7C,SAAA,SAAA;AAAA,EAA8C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAalE,OACE,gBACG,MAGH;AACA,WAAO,KAAK,OAAO,QAAQ,aAAa;AAAA,MACtC,GAAG,KAAK,OAAO;AAAA,MACf,GAAG,KAAK,CAAC;AAAA,IAAA,CACH;AAAA,EACV;AACF;"}
1
+ {"version":3,"file":"complex.js","sources":["../src/complex/counter.ts","../src/complex/global-config.ts","../src/complex/modules-factory.ts"],"sourcesContent":["export interface Counter<TValue = number> {\n (): TValue;\n counter: number;\n value: TValue;\n increment(): TValue;\n decrement(): TValue;\n reset(): void;\n}\n\n/**\n * @deprecated use {`Counter`}. Will be removed in next major release\n */\nexport interface CounterFn<TValue = number> extends Counter<TValue> {}\n\nexport const createCounter = <TValue = number>(\n processValue?: (value: number) => TValue,\n initial: number = 0,\n): Counter<TValue> => {\n const update = (counter: number) => {\n fn.value = processValue?.(counter) ?? (counter as TValue);\n return fn.value;\n };\n\n const increment = () => update(++fn.counter);\n const decrement = () => update(--fn.counter);\n\n const fn: Counter<TValue> = increment as any;\n\n fn.increment = increment;\n fn.decrement = decrement;\n\n fn.reset = () => {\n fn.counter = initial;\n fn.value = processValue?.(initial) ?? (initial as TValue);\n };\n\n fn.reset();\n\n return fn as Counter<TValue>;\n};\n","import type { AnyObject, Maybe } from 'yummies/types';\n\nconst createGlobalPoint = <TValue>(accessSymbol?: keyof any) => {\n if (accessSymbol == null) {\n let storedValue: TValue | undefined;\n return {\n get: (): TValue => storedValue!,\n set: (value: TValue): TValue => {\n storedValue = value;\n return value;\n },\n };\n }\n\n const _globalThis = globalThis as AnyObject;\n\n return {\n get: (): TValue => _globalThis[accessSymbol],\n set: (value: TValue): TValue => {\n _globalThis[accessSymbol] = value;\n return value;\n },\n };\n};\n\n/**\n * Создает глобальный конфиг, который может быть доступен в любой точке в коде\n */\nexport const createGlobalConfig = <T extends AnyObject>(\n defaultValue: T,\n accessSymbol?: keyof any,\n) => {\n const globalPoint = createGlobalPoint<T>(accessSymbol);\n return globalPoint.get() || globalPoint.set(defaultValue);\n};\n\nexport const createGlobalDynamicConfig = <T extends AnyObject>(\n processFn: (change: Maybe<Partial<T>>, current: Maybe<T>) => T,\n accessSymbol?: keyof any,\n) => {\n const globalPoint = createGlobalPoint<T | null | undefined>(accessSymbol);\n\n const getValue = () => {\n return globalPoint.get() ?? globalPoint.set(processFn(null, null))!;\n };\n\n return {\n get: getValue,\n set: globalPoint.set,\n update: (value: Partial<T>) => {\n const currentValue = getValue();\n Object.assign(currentValue, processFn(value, currentValue));\n },\n };\n};\n","import type { AnyObject, Class, EmptyObject, IsPartial } from 'yummies/types';\n\ntype ModuleLoaderConfig<TPredefinedDeps extends AnyObject = EmptyObject> = {\n factory<TInstance, TDeps extends TPredefinedDeps>(\n moduleClass: Class<TInstance, [TDeps]>,\n deps: TDeps,\n ): TInstance;\n} & (TPredefinedDeps extends EmptyObject\n ? { deps?: TPredefinedDeps }\n : { deps: TPredefinedDeps });\n\n/**\n * Класс `ModulesFactory` является универсальной фабрикой для создания экземпляров указанного класса с зависимостями.\n * Он использует объект конфигурации для определения того, как эти экземпляры создаются.\n *\n * Важное примечание - эта сущность работает только с классами конструктор которых имеет один параметр\n *\n * @template TPredefinedDeps - Тип, расширяющий `AnyObject`, представляющий предопределенные зависимости, которые использует фабрика.\n *\n * @example\n * ```\n * const factory = new ModulesFactory({\n * factory: (MyClass, deps) => new MyClass(deps),\n * deps: { someDependency: new Dependency() }\n * });\n *\n * const instance = factory.create(MyClass, { extraDependency: new ExtraDependency() });\n * ```\n */\nexport class ModulesFactory<TPredefinedDeps extends AnyObject = EmptyObject> {\n /**\n * Создает новый экземпляр `ModulesFactory`.\n *\n * @param config - Объект конфигурации для фабрики, включающий функцию фабрики и необязательные зависимости.\n */\n constructor(private config: ModuleLoaderConfig<TPredefinedDeps>) {}\n\n /**\n * Создает экземпляр указанного класса, внедряя необходимые зависимости.\n *\n * @template TInstance - Тип создаваемого экземпляра.\n * @template TDeps - Тип зависимостей, необходимых для экземпляра.\n *\n * @param Constructor - Конструктор класса для создаваемого экземпляра.\n * @param args - Необязательные дополнительные зависимости для объединения с предопределенными зависимостями.\n *\n * @returns Экземпляр указанного класса с внедренными зависимостями.\n */\n create<TInstance, TDeps extends TPredefinedDeps = TPredefinedDeps>(\n Constructor: Class<TInstance, [TDeps]>,\n ...args: IsPartial<Omit<TDeps, keyof TPredefinedDeps>> extends true\n ? [extraDeps?: Omit<TDeps, keyof TPredefinedDeps>]\n : [extraDeps: Omit<TDeps, keyof TPredefinedDeps>]\n ) {\n return this.config.factory(Constructor, {\n ...this.config.deps!,\n ...args[0],\n } as any);\n }\n}\n"],"names":[],"mappings":"AAcO,MAAM,gBAAgB,CAC3B,cACA,UAAkB,MACE;AACpB,QAAM,SAAS,CAAC,YAAoB;AAClC,OAAG,QAAQ,eAAe,OAAO,KAAM;AACvC,WAAO,GAAG;AAAA,EACZ;AAEA,QAAM,YAAY,MAAM,OAAO,EAAE,GAAG,OAAO;AAC3C,QAAM,YAAY,MAAM,OAAO,EAAE,GAAG,OAAO;AAE3C,QAAM,KAAsB;AAE5B,KAAG,YAAY;AACf,KAAG,YAAY;AAEf,KAAG,QAAQ,MAAM;AACf,OAAG,UAAU;AACb,OAAG,QAAQ,eAAe,OAAO,KAAM;AAAA,EACzC;AAEA,KAAG,MAAA;AAEH,SAAO;AACT;ACrCA,MAAM,oBAAoB,CAAS,iBAA6B;AAC9D,MAAI,gBAAgB,MAAM;AACxB,QAAI;AACJ,WAAO;AAAA,MACL,KAAK,MAAc;AAAA,MACnB,KAAK,CAAC,UAA0B;AAC9B,sBAAc;AACd,eAAO;AAAA,MACT;AAAA,IAAA;AAAA,EAEJ;AAEA,QAAM,cAAc;AAEpB,SAAO;AAAA,IACL,KAAK,MAAc,YAAY,YAAY;AAAA,IAC3C,KAAK,CAAC,UAA0B;AAC9B,kBAAY,YAAY,IAAI;AAC5B,aAAO;AAAA,IACT;AAAA,EAAA;AAEJ;AAKO,MAAM,qBAAqB,CAChC,cACA,iBACG;AACH,QAAM,cAAc,kBAAqB,YAAY;AACrD,SAAO,YAAY,IAAA,KAAS,YAAY,IAAI,YAAY;AAC1D;AAEO,MAAM,4BAA4B,CACvC,WACA,iBACG;AACH,QAAM,cAAc,kBAAwC,YAAY;AAExE,QAAM,WAAW,MAAM;AACrB,WAAO,YAAY,SAAS,YAAY,IAAI,UAAU,MAAM,IAAI,CAAC;AAAA,EACnE;AAEA,SAAO;AAAA,IACL,KAAK;AAAA,IACL,KAAK,YAAY;AAAA,IACjB,QAAQ,CAAC,UAAsB;AAC7B,YAAM,eAAe,SAAA;AACrB,aAAO,OAAO,cAAc,UAAU,OAAO,YAAY,CAAC;AAAA,IAC5D;AAAA,EAAA;AAEJ;ACzBO,MAAM,eAAgE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAM3E,YAAoB,QAA6C;AAA7C,SAAA,SAAA;AAAA,EAA8C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAalE,OACE,gBACG,MAGH;AACA,WAAO,KAAK,OAAO,QAAQ,aAAa;AAAA,MACtC,GAAG,KAAK,OAAO;AAAA,MACf,GAAG,KAAK,CAAC;AAAA,IAAA,CACH;AAAA,EACV;AACF;"}
package/cookie.cjs CHANGED
@@ -1,2 +1,10 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});exports.parseCookie=(e=document.cookie)=>e.split(";").map(e=>e.trim().split("=")).reduce((e,t)=>(e[t[0]]=t[1],e),{});
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const parseCookie = (cookiesString = document.cookie) => {
4
+ return cookiesString.split(";").map((cookieString) => cookieString.trim().split("=")).reduce((acc, current) => {
5
+ acc[current[0]] = current[1];
6
+ return acc;
7
+ }, {});
8
+ };
9
+ exports.parseCookie = parseCookie;
2
10
  //# sourceMappingURL=cookie.cjs.map
package/cookie.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"cookie.cjs","sources":["../src/cookie.ts"],"sourcesContent":["import type { AnyObject } from 'yummies/utils/types';\n\nexport const parseCookie = (cookiesString = document.cookie) => {\n return cookiesString\n .split(';')\n .map((cookieString) => cookieString.trim().split('='))\n .reduce<AnyObject>((acc, current) => {\n acc[current[0]] = current[1];\n return acc;\n }, {});\n};\n"],"names":["cookiesString","document","cookie","split","map","cookieString","trim","reduce","acc","current"],"mappings":"oGAE2B,CAACA,EAAgBC,SAASC,SAC5CF,EACJG,MAAM,KACNC,IAAKC,GAAiBA,EAAaC,OAAOH,MAAM,MAChDI,OAAkB,CAACC,EAAKC,KACvBD,EAAIC,EAAQ,IAAMA,EAAQ,GACnBD,GACN,CAAA"}
1
+ {"version":3,"file":"cookie.cjs","sources":["../src/cookie.ts"],"sourcesContent":["import type { AnyObject } from 'yummies/types';\n\nexport const parseCookie = (cookiesString = document.cookie) => {\n return cookiesString\n .split(';')\n .map((cookieString) => cookieString.trim().split('='))\n .reduce<AnyObject>((acc, current) => {\n acc[current[0]] = current[1];\n return acc;\n }, {});\n};\n"],"names":[],"mappings":";;AAEO,MAAM,cAAc,CAAC,gBAAgB,SAAS,WAAW;AAC9D,SAAO,cACJ,MAAM,GAAG,EACT,IAAI,CAAC,iBAAiB,aAAa,KAAA,EAAO,MAAM,GAAG,CAAC,EACpD,OAAkB,CAAC,KAAK,YAAY;AACnC,QAAI,QAAQ,CAAC,CAAC,IAAI,QAAQ,CAAC;AAC3B,WAAO;AAAA,EACT,GAAG,CAAA,CAAE;AACT;;"}
package/cookie.d.ts CHANGED
@@ -1,3 +1,5 @@
1
- import { AnyObject } from './utils/types.ts';
2
- export declare const parseCookie: (cookiesString?: string) => AnyObject;
3
- //# sourceMappingURL=cookie.d.ts.map
1
+ import { AnyObject } from 'yummies/types';
2
+
3
+ declare const parseCookie: (cookiesString?: string) => AnyObject;
4
+
5
+ export { parseCookie };
package/cookie.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"cookie.js","sources":["../src/cookie.ts"],"sourcesContent":["import type { AnyObject } from 'yummies/utils/types';\n\nexport const parseCookie = (cookiesString = document.cookie) => {\n return cookiesString\n .split(';')\n .map((cookieString) => cookieString.trim().split('='))\n .reduce<AnyObject>((acc, current) => {\n acc[current[0]] = current[1];\n return acc;\n }, {});\n};\n"],"names":[],"mappings":"AAEO,MAAM,cAAc,CAAC,gBAAgB,SAAS,WAAW;AAC9D,SAAO,cACJ,MAAM,GAAG,EACT,IAAI,CAAC,iBAAiB,aAAa,KAAA,EAAO,MAAM,GAAG,CAAC,EACpD,OAAkB,CAAC,KAAK,YAAY;AACnC,QAAI,QAAQ,CAAC,CAAC,IAAI,QAAQ,CAAC;AAC3B,WAAO;AAAA,EACT,GAAG,CAAA,CAAE;AACT;"}
1
+ {"version":3,"file":"cookie.js","sources":["../src/cookie.ts"],"sourcesContent":["import type { AnyObject } from 'yummies/types';\n\nexport const parseCookie = (cookiesString = document.cookie) => {\n return cookiesString\n .split(';')\n .map((cookieString) => cookieString.trim().split('='))\n .reduce<AnyObject>((acc, current) => {\n acc[current[0]] = current[1];\n return acc;\n }, {});\n};\n"],"names":[],"mappings":"AAEO,MAAM,cAAc,CAAC,gBAAgB,SAAS,WAAW;AAC9D,SAAO,cACJ,MAAM,GAAG,EACT,IAAI,CAAC,iBAAiB,aAAa,KAAA,EAAO,MAAM,GAAG,CAAC,EACpD,OAAkB,CAAC,KAAK,YAAY;AACnC,QAAI,QAAQ,CAAC,CAAC,IAAI,QAAQ,CAAC;AAC3B,WAAO;AAAA,EACT,GAAG,CAAA,CAAE;AACT;"}
package/css.cjs CHANGED
@@ -1,2 +1,46 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("class-variance-authority"),t=require("clsx"),r=require("tailwind-merge");exports.cva=(...t)=>{const o=e.cva(...t);return(...e)=>r.twMerge(o(...e))},exports.cx=(...e)=>r.twMerge(t(...e)),exports.loadCssFile=(e,t)=>new Promise((r,o)=>{let n;t?.id&&(n=document.getElementById(t.id),n&&n.remove()),n=document.createElement("link");const i=()=>{r(void 0),n.removeEventListener("load",i),n.removeEventListener("error",s)},s=()=>{o(void 0),n.removeEventListener("load",i),n.removeEventListener("error",s)};n.addEventListener("load",i),n.addEventListener("error",s),n.setAttribute("href",e),t?.rel||n.setAttribute("rel","stylesheet"),Object.entries(t||{}).forEach(([e,t])=>{n.setAttribute(e,t)}),document.head.appendChild(n)}),exports.toRem=(e,t=16)=>e/t+"rem";
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const classVarianceAuthority = require("class-variance-authority");
4
+ const clsx = require("clsx");
5
+ const tailwindMerge = require("tailwind-merge");
6
+ const toRem = (px, remValue = 16) => `${px / remValue}rem`;
7
+ const cx = (...args) => tailwindMerge.twMerge(clsx(...args));
8
+ const cva = (...args) => {
9
+ const schema = classVarianceAuthority.cva(...args);
10
+ return (...inputArgs) => tailwindMerge.twMerge(schema(...inputArgs));
11
+ };
12
+ const loadCssFile = (url, attrubutes) => new Promise((resolve, reject) => {
13
+ let link;
14
+ if (attrubutes?.id) {
15
+ link = document.getElementById(attrubutes.id);
16
+ if (link) {
17
+ link.remove();
18
+ }
19
+ }
20
+ link = document.createElement("link");
21
+ const handleLoad = () => {
22
+ resolve(void 0);
23
+ link.removeEventListener("load", handleLoad);
24
+ link.removeEventListener("error", handleError);
25
+ };
26
+ const handleError = () => {
27
+ reject(void 0);
28
+ link.removeEventListener("load", handleLoad);
29
+ link.removeEventListener("error", handleError);
30
+ };
31
+ link.addEventListener("load", handleLoad);
32
+ link.addEventListener("error", handleError);
33
+ link.setAttribute("href", url);
34
+ if (!attrubutes?.rel) {
35
+ link.setAttribute("rel", "stylesheet");
36
+ }
37
+ Object.entries(attrubutes || {}).forEach(([key, value]) => {
38
+ link.setAttribute(key, value);
39
+ });
40
+ document.head.appendChild(link);
41
+ });
42
+ exports.cva = cva;
43
+ exports.cx = cx;
44
+ exports.loadCssFile = loadCssFile;
45
+ exports.toRem = toRem;
2
46
  //# sourceMappingURL=css.cjs.map
package/css.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"css.cjs","sources":["../src/css.ts"],"sourcesContent":["import { cva as cvaLib } from 'class-variance-authority';\nimport clsx, { type ClassValue } from 'clsx';\nimport { twMerge } from 'tailwind-merge';\nimport type { Maybe } from 'yummies/utils/types';\n\ntype ClassProp = {\n class?: ClassValue;\n className?: ClassValue;\n};\n\ntype StringToBoolean<T> = T extends 'true' | 'false' ? boolean : T;\n\n/**\n * Перевод значения в пикселях в rem строковое\n */\nexport const toRem = (px: number, remValue = 16) => `${px / remValue}rem`;\n\n/**\n * classNames/clsx но с примесями tailwind-merge\n */\nexport const cx = (...args: Parameters<typeof clsx>) => twMerge(clsx(...args));\n\ntype ConfigSchema = Record<string, Record<string, ClassValue>>;\ntype ConfigVariants<T extends ConfigSchema> = {\n [Variant in keyof T]?: StringToBoolean<keyof T[Variant]> | null | undefined;\n};\ntype ConfigVariantsMulti<T extends ConfigSchema> = {\n [Variant in keyof T]?:\n | StringToBoolean<keyof T[Variant]>\n | StringToBoolean<keyof T[Variant]>[]\n | undefined;\n};\ntype Config<T> = T extends ConfigSchema\n ? {\n variants?: T;\n defaultVariants?: ConfigVariants<T>;\n compoundVariants?: (T extends ConfigSchema\n ? (ConfigVariants<T> | ConfigVariantsMulti<T>) & ClassProp\n : ClassProp)[];\n }\n : never;\n\ntype Props<T> = T extends ConfigSchema\n ? ConfigVariants<T> & ClassProp\n : ClassProp;\n\n/**\n * Class Variance Authority но с примесями tailwind-merge\n *\n * https://cva.style/docs\n */\nexport const cva = ((...args: any[]) => {\n const schema = cvaLib(...args);\n return (...inputArgs: any[]) => twMerge(schema(...inputArgs));\n}) as any as <T>(\n base?: ClassValue,\n config?: Config<T>,\n) => (props?: Props<T>) => string;\n\nexport type { VariantProps } from 'class-variance-authority';\nexport type { ClassValue } from 'clsx';\n\n/**\n * Load CSS file by providing `url`.\n *\n * **NOTE:** If `id` is provided, it will remove the existing link element with the same `id` before creating a new one.\n */\nexport const loadCssFile = (url: string, attrubutes?: Record<string, any>) =>\n new Promise((resolve, reject) => {\n let link: Maybe<HTMLLinkElement>;\n\n if (attrubutes?.id) {\n link = document.getElementById(attrubutes.id) as HTMLLinkElement | null;\n\n if (link) {\n link.remove();\n }\n }\n\n link = document.createElement('link');\n\n const handleLoad = () => {\n resolve(undefined);\n link!.removeEventListener('load', handleLoad);\n link!.removeEventListener('error', handleError);\n };\n\n const handleError = () => {\n reject(undefined);\n link!.removeEventListener('load', handleLoad);\n link!.removeEventListener('error', handleError);\n };\n\n link.addEventListener('load', handleLoad);\n link.addEventListener('error', handleError);\n\n link.setAttribute('href', url);\n\n if (!attrubutes?.rel) {\n link.setAttribute('rel', 'stylesheet');\n }\n\n Object.entries(attrubutes || {}).forEach(([key, value]) => {\n link.setAttribute(key, value);\n });\n\n document.head.appendChild(link);\n });\n"],"names":["args","schema","cvaLib","inputArgs","twMerge","clsx","url","attrubutes","Promise","resolve","reject","link","id","document","getElementById","remove","createElement","handleLoad","removeEventListener","handleError","addEventListener","setAttribute","rel","Object","entries","forEach","key","value","head","appendChild","px","remValue"],"mappings":"sLAmDoB,IAAIA,KACtB,MAAMC,EAASC,SAAUF,GACzB,MAAO,IAAIG,IAAqBC,EAAAA,QAAQH,KAAUE,gBAjClC,IAAIH,IAAkCI,EAAAA,QAAQC,KAAQL,wBA+C7C,CAACM,EAAaC,IACvC,IAAIC,QAAQ,CAACC,EAASC,KACpB,IAAIC,EAEAJ,GAAYK,KACdD,EAAOE,SAASC,eAAeP,EAAWK,IAEtCD,GACFA,EAAKI,UAITJ,EAAOE,SAASG,cAAc,QAE9B,MAAMC,EAAa,KACjBR,OAAQ,GACRE,EAAMO,oBAAoB,OAAQD,GAClCN,EAAMO,oBAAoB,QAASC,IAG/BA,EAAc,KAClBT,OAAO,GACPC,EAAMO,oBAAoB,OAAQD,GAClCN,EAAMO,oBAAoB,QAASC,IAGrCR,EAAKS,iBAAiB,OAAQH,GAC9BN,EAAKS,iBAAiB,QAASD,GAE/BR,EAAKU,aAAa,OAAQf,GAErBC,GAAYe,KACfX,EAAKU,aAAa,MAAO,cAG3BE,OAAOC,QAAQjB,GAAc,CAAA,GAAIkB,QAAQ,EAAEC,EAAKC,MAC9ChB,EAAKU,aAAaK,EAAKC,KAGzBd,SAASe,KAAKC,YAAYlB,mBA3FT,CAACmB,EAAYC,EAAW,KAAUD,EAAKC,EAAR"}
1
+ {"version":3,"file":"css.cjs","sources":["../src/css.ts"],"sourcesContent":["import { cva as cvaLib } from 'class-variance-authority';\nimport clsx, { type ClassValue } from 'clsx';\nimport { twMerge } from 'tailwind-merge';\nimport type { Maybe } from 'yummies/types';\n\ntype ClassProp = {\n class?: ClassValue;\n className?: ClassValue;\n};\n\ntype StringToBoolean<T> = T extends 'true' | 'false' ? boolean : T;\n\n/**\n * Перевод значения в пикселях в rem строковое\n */\nexport const toRem = (px: number, remValue = 16) => `${px / remValue}rem`;\n\n/**\n * classNames/clsx но с примесями tailwind-merge\n */\nexport const cx = (...args: Parameters<typeof clsx>) => twMerge(clsx(...args));\n\ntype ConfigSchema = Record<string, Record<string, ClassValue>>;\ntype ConfigVariants<T extends ConfigSchema> = {\n [Variant in keyof T]?: StringToBoolean<keyof T[Variant]> | null | undefined;\n};\ntype ConfigVariantsMulti<T extends ConfigSchema> = {\n [Variant in keyof T]?:\n | StringToBoolean<keyof T[Variant]>\n | StringToBoolean<keyof T[Variant]>[]\n | undefined;\n};\ntype Config<T> = T extends ConfigSchema\n ? {\n variants?: T;\n defaultVariants?: ConfigVariants<T>;\n compoundVariants?: (T extends ConfigSchema\n ? (ConfigVariants<T> | ConfigVariantsMulti<T>) & ClassProp\n : ClassProp)[];\n }\n : never;\n\ntype Props<T> = T extends ConfigSchema\n ? ConfigVariants<T> & ClassProp\n : ClassProp;\n\n/**\n * Class Variance Authority но с примесями tailwind-merge\n *\n * https://cva.style/docs\n */\nexport const cva = ((...args: any[]) => {\n const schema = cvaLib(...args);\n return (...inputArgs: any[]) => twMerge(schema(...inputArgs));\n}) as any as <T>(\n base?: ClassValue,\n config?: Config<T>,\n) => (props?: Props<T>) => string;\n\nexport type { VariantProps } from 'class-variance-authority';\nexport type { ClassValue } from 'clsx';\n\n/**\n * Load CSS file by providing `url`.\n *\n * **NOTE:** If `id` is provided, it will remove the existing link element with the same `id` before creating a new one.\n */\nexport const loadCssFile = (url: string, attrubutes?: Record<string, any>) =>\n new Promise((resolve, reject) => {\n let link: Maybe<HTMLLinkElement>;\n\n if (attrubutes?.id) {\n link = document.getElementById(attrubutes.id) as HTMLLinkElement | null;\n\n if (link) {\n link.remove();\n }\n }\n\n link = document.createElement('link');\n\n const handleLoad = () => {\n resolve(undefined);\n link!.removeEventListener('load', handleLoad);\n link!.removeEventListener('error', handleError);\n };\n\n const handleError = () => {\n reject(undefined);\n link!.removeEventListener('load', handleLoad);\n link!.removeEventListener('error', handleError);\n };\n\n link.addEventListener('load', handleLoad);\n link.addEventListener('error', handleError);\n\n link.setAttribute('href', url);\n\n if (!attrubutes?.rel) {\n link.setAttribute('rel', 'stylesheet');\n }\n\n Object.entries(attrubutes || {}).forEach(([key, value]) => {\n link.setAttribute(key, value);\n });\n\n document.head.appendChild(link);\n });\n"],"names":["twMerge","cvaLib"],"mappings":";;;;;AAeO,MAAM,QAAQ,CAAC,IAAY,WAAW,OAAO,GAAG,KAAK,QAAQ;AAK7D,MAAM,KAAK,IAAI,SAAkCA,cAAAA,QAAQ,KAAK,GAAG,IAAI,CAAC;AA+BtE,MAAM,MAAO,IAAI,SAAgB;AACtC,QAAM,SAASC,2BAAO,GAAG,IAAI;AAC7B,SAAO,IAAI,cAAqBD,cAAAA,QAAQ,OAAO,GAAG,SAAS,CAAC;AAC9D;AAaO,MAAM,cAAc,CAAC,KAAa,eACvC,IAAI,QAAQ,CAAC,SAAS,WAAW;AAC/B,MAAI;AAEJ,MAAI,YAAY,IAAI;AAClB,WAAO,SAAS,eAAe,WAAW,EAAE;AAE5C,QAAI,MAAM;AACR,WAAK,OAAA;AAAA,IACP;AAAA,EACF;AAEA,SAAO,SAAS,cAAc,MAAM;AAEpC,QAAM,aAAa,MAAM;AACvB,YAAQ,MAAS;AACjB,SAAM,oBAAoB,QAAQ,UAAU;AAC5C,SAAM,oBAAoB,SAAS,WAAW;AAAA,EAChD;AAEA,QAAM,cAAc,MAAM;AACxB,WAAO,MAAS;AAChB,SAAM,oBAAoB,QAAQ,UAAU;AAC5C,SAAM,oBAAoB,SAAS,WAAW;AAAA,EAChD;AAEA,OAAK,iBAAiB,QAAQ,UAAU;AACxC,OAAK,iBAAiB,SAAS,WAAW;AAE1C,OAAK,aAAa,QAAQ,GAAG;AAE7B,MAAI,CAAC,YAAY,KAAK;AACpB,SAAK,aAAa,OAAO,YAAY;AAAA,EACvC;AAEA,SAAO,QAAQ,cAAc,CAAA,CAAE,EAAE,QAAQ,CAAC,CAAC,KAAK,KAAK,MAAM;AACzD,SAAK,aAAa,KAAK,KAAK;AAAA,EAC9B,CAAC;AAED,WAAS,KAAK,YAAY,IAAI;AAChC,CAAC;;;;;"}
package/css.d.ts CHANGED
@@ -1,4 +1,7 @@
1
- import { default as clsx, ClassValue } from 'clsx';
1
+ import clsx, { ClassValue } from 'clsx';
2
+ export { ClassValue } from 'clsx';
3
+ export { VariantProps } from 'class-variance-authority';
4
+
2
5
  type ClassProp = {
3
6
  class?: ClassValue;
4
7
  className?: ClassValue;
@@ -7,11 +10,11 @@ type StringToBoolean<T> = T extends 'true' | 'false' ? boolean : T;
7
10
  /**
8
11
  * Перевод значения в пикселях в rem строковое
9
12
  */
10
- export declare const toRem: (px: number, remValue?: number) => string;
13
+ declare const toRem: (px: number, remValue?: number) => string;
11
14
  /**
12
15
  * classNames/clsx но с примесями tailwind-merge
13
16
  */
14
- export declare const cx: (...args: Parameters<typeof clsx>) => string;
17
+ declare const cx: (...args: Parameters<typeof clsx>) => string;
15
18
  type ConfigSchema = Record<string, Record<string, ClassValue>>;
16
19
  type ConfigVariants<T extends ConfigSchema> = {
17
20
  [Variant in keyof T]?: StringToBoolean<keyof T[Variant]> | null | undefined;
@@ -30,13 +33,13 @@ type Props<T> = T extends ConfigSchema ? ConfigVariants<T> & ClassProp : ClassPr
30
33
  *
31
34
  * https://cva.style/docs
32
35
  */
33
- export declare const cva: <T>(base?: ClassValue, config?: Config<T>) => (props?: Props<T>) => string;
34
- export type { VariantProps } from 'class-variance-authority';
35
- export type { ClassValue } from 'clsx';
36
+ declare const cva: <T>(base?: ClassValue, config?: Config<T>) => (props?: Props<T>) => string;
37
+
36
38
  /**
37
39
  * Load CSS file by providing `url`.
38
40
  *
39
41
  * **NOTE:** If `id` is provided, it will remove the existing link element with the same `id` before creating a new one.
40
42
  */
41
- export declare const loadCssFile: (url: string, attrubutes?: Record<string, any>) => Promise<unknown>;
42
- //# sourceMappingURL=css.d.ts.map
43
+ declare const loadCssFile: (url: string, attrubutes?: Record<string, any>) => Promise<unknown>;
44
+
45
+ export { cva, cx, loadCssFile, toRem };
package/css.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"css.js","sources":["../src/css.ts"],"sourcesContent":["import { cva as cvaLib } from 'class-variance-authority';\nimport clsx, { type ClassValue } from 'clsx';\nimport { twMerge } from 'tailwind-merge';\nimport type { Maybe } from 'yummies/utils/types';\n\ntype ClassProp = {\n class?: ClassValue;\n className?: ClassValue;\n};\n\ntype StringToBoolean<T> = T extends 'true' | 'false' ? boolean : T;\n\n/**\n * Перевод значения в пикселях в rem строковое\n */\nexport const toRem = (px: number, remValue = 16) => `${px / remValue}rem`;\n\n/**\n * classNames/clsx но с примесями tailwind-merge\n */\nexport const cx = (...args: Parameters<typeof clsx>) => twMerge(clsx(...args));\n\ntype ConfigSchema = Record<string, Record<string, ClassValue>>;\ntype ConfigVariants<T extends ConfigSchema> = {\n [Variant in keyof T]?: StringToBoolean<keyof T[Variant]> | null | undefined;\n};\ntype ConfigVariantsMulti<T extends ConfigSchema> = {\n [Variant in keyof T]?:\n | StringToBoolean<keyof T[Variant]>\n | StringToBoolean<keyof T[Variant]>[]\n | undefined;\n};\ntype Config<T> = T extends ConfigSchema\n ? {\n variants?: T;\n defaultVariants?: ConfigVariants<T>;\n compoundVariants?: (T extends ConfigSchema\n ? (ConfigVariants<T> | ConfigVariantsMulti<T>) & ClassProp\n : ClassProp)[];\n }\n : never;\n\ntype Props<T> = T extends ConfigSchema\n ? ConfigVariants<T> & ClassProp\n : ClassProp;\n\n/**\n * Class Variance Authority но с примесями tailwind-merge\n *\n * https://cva.style/docs\n */\nexport const cva = ((...args: any[]) => {\n const schema = cvaLib(...args);\n return (...inputArgs: any[]) => twMerge(schema(...inputArgs));\n}) as any as <T>(\n base?: ClassValue,\n config?: Config<T>,\n) => (props?: Props<T>) => string;\n\nexport type { VariantProps } from 'class-variance-authority';\nexport type { ClassValue } from 'clsx';\n\n/**\n * Load CSS file by providing `url`.\n *\n * **NOTE:** If `id` is provided, it will remove the existing link element with the same `id` before creating a new one.\n */\nexport const loadCssFile = (url: string, attrubutes?: Record<string, any>) =>\n new Promise((resolve, reject) => {\n let link: Maybe<HTMLLinkElement>;\n\n if (attrubutes?.id) {\n link = document.getElementById(attrubutes.id) as HTMLLinkElement | null;\n\n if (link) {\n link.remove();\n }\n }\n\n link = document.createElement('link');\n\n const handleLoad = () => {\n resolve(undefined);\n link!.removeEventListener('load', handleLoad);\n link!.removeEventListener('error', handleError);\n };\n\n const handleError = () => {\n reject(undefined);\n link!.removeEventListener('load', handleLoad);\n link!.removeEventListener('error', handleError);\n };\n\n link.addEventListener('load', handleLoad);\n link.addEventListener('error', handleError);\n\n link.setAttribute('href', url);\n\n if (!attrubutes?.rel) {\n link.setAttribute('rel', 'stylesheet');\n }\n\n Object.entries(attrubutes || {}).forEach(([key, value]) => {\n link.setAttribute(key, value);\n });\n\n document.head.appendChild(link);\n });\n"],"names":["cvaLib"],"mappings":";;;AAeO,MAAM,QAAQ,CAAC,IAAY,WAAW,OAAO,GAAG,KAAK,QAAQ;AAK7D,MAAM,KAAK,IAAI,SAAkC,QAAQ,KAAK,GAAG,IAAI,CAAC;AA+BtE,MAAM,MAAO,IAAI,SAAgB;AACtC,QAAM,SAASA,MAAO,GAAG,IAAI;AAC7B,SAAO,IAAI,cAAqB,QAAQ,OAAO,GAAG,SAAS,CAAC;AAC9D;AAaO,MAAM,cAAc,CAAC,KAAa,eACvC,IAAI,QAAQ,CAAC,SAAS,WAAW;AAC/B,MAAI;AAEJ,MAAI,YAAY,IAAI;AAClB,WAAO,SAAS,eAAe,WAAW,EAAE;AAE5C,QAAI,MAAM;AACR,WAAK,OAAA;AAAA,IACP;AAAA,EACF;AAEA,SAAO,SAAS,cAAc,MAAM;AAEpC,QAAM,aAAa,MAAM;AACvB,YAAQ,MAAS;AACjB,SAAM,oBAAoB,QAAQ,UAAU;AAC5C,SAAM,oBAAoB,SAAS,WAAW;AAAA,EAChD;AAEA,QAAM,cAAc,MAAM;AACxB,WAAO,MAAS;AAChB,SAAM,oBAAoB,QAAQ,UAAU;AAC5C,SAAM,oBAAoB,SAAS,WAAW;AAAA,EAChD;AAEA,OAAK,iBAAiB,QAAQ,UAAU;AACxC,OAAK,iBAAiB,SAAS,WAAW;AAE1C,OAAK,aAAa,QAAQ,GAAG;AAE7B,MAAI,CAAC,YAAY,KAAK;AACpB,SAAK,aAAa,OAAO,YAAY;AAAA,EACvC;AAEA,SAAO,QAAQ,cAAc,CAAA,CAAE,EAAE,QAAQ,CAAC,CAAC,KAAK,KAAK,MAAM;AACzD,SAAK,aAAa,KAAK,KAAK;AAAA,EAC9B,CAAC;AAED,WAAS,KAAK,YAAY,IAAI;AAChC,CAAC;"}
1
+ {"version":3,"file":"css.js","sources":["../src/css.ts"],"sourcesContent":["import { cva as cvaLib } from 'class-variance-authority';\nimport clsx, { type ClassValue } from 'clsx';\nimport { twMerge } from 'tailwind-merge';\nimport type { Maybe } from 'yummies/types';\n\ntype ClassProp = {\n class?: ClassValue;\n className?: ClassValue;\n};\n\ntype StringToBoolean<T> = T extends 'true' | 'false' ? boolean : T;\n\n/**\n * Перевод значения в пикселях в rem строковое\n */\nexport const toRem = (px: number, remValue = 16) => `${px / remValue}rem`;\n\n/**\n * classNames/clsx но с примесями tailwind-merge\n */\nexport const cx = (...args: Parameters<typeof clsx>) => twMerge(clsx(...args));\n\ntype ConfigSchema = Record<string, Record<string, ClassValue>>;\ntype ConfigVariants<T extends ConfigSchema> = {\n [Variant in keyof T]?: StringToBoolean<keyof T[Variant]> | null | undefined;\n};\ntype ConfigVariantsMulti<T extends ConfigSchema> = {\n [Variant in keyof T]?:\n | StringToBoolean<keyof T[Variant]>\n | StringToBoolean<keyof T[Variant]>[]\n | undefined;\n};\ntype Config<T> = T extends ConfigSchema\n ? {\n variants?: T;\n defaultVariants?: ConfigVariants<T>;\n compoundVariants?: (T extends ConfigSchema\n ? (ConfigVariants<T> | ConfigVariantsMulti<T>) & ClassProp\n : ClassProp)[];\n }\n : never;\n\ntype Props<T> = T extends ConfigSchema\n ? ConfigVariants<T> & ClassProp\n : ClassProp;\n\n/**\n * Class Variance Authority но с примесями tailwind-merge\n *\n * https://cva.style/docs\n */\nexport const cva = ((...args: any[]) => {\n const schema = cvaLib(...args);\n return (...inputArgs: any[]) => twMerge(schema(...inputArgs));\n}) as any as <T>(\n base?: ClassValue,\n config?: Config<T>,\n) => (props?: Props<T>) => string;\n\nexport type { VariantProps } from 'class-variance-authority';\nexport type { ClassValue } from 'clsx';\n\n/**\n * Load CSS file by providing `url`.\n *\n * **NOTE:** If `id` is provided, it will remove the existing link element with the same `id` before creating a new one.\n */\nexport const loadCssFile = (url: string, attrubutes?: Record<string, any>) =>\n new Promise((resolve, reject) => {\n let link: Maybe<HTMLLinkElement>;\n\n if (attrubutes?.id) {\n link = document.getElementById(attrubutes.id) as HTMLLinkElement | null;\n\n if (link) {\n link.remove();\n }\n }\n\n link = document.createElement('link');\n\n const handleLoad = () => {\n resolve(undefined);\n link!.removeEventListener('load', handleLoad);\n link!.removeEventListener('error', handleError);\n };\n\n const handleError = () => {\n reject(undefined);\n link!.removeEventListener('load', handleLoad);\n link!.removeEventListener('error', handleError);\n };\n\n link.addEventListener('load', handleLoad);\n link.addEventListener('error', handleError);\n\n link.setAttribute('href', url);\n\n if (!attrubutes?.rel) {\n link.setAttribute('rel', 'stylesheet');\n }\n\n Object.entries(attrubutes || {}).forEach(([key, value]) => {\n link.setAttribute(key, value);\n });\n\n document.head.appendChild(link);\n });\n"],"names":["cvaLib"],"mappings":";;;AAeO,MAAM,QAAQ,CAAC,IAAY,WAAW,OAAO,GAAG,KAAK,QAAQ;AAK7D,MAAM,KAAK,IAAI,SAAkC,QAAQ,KAAK,GAAG,IAAI,CAAC;AA+BtE,MAAM,MAAO,IAAI,SAAgB;AACtC,QAAM,SAASA,MAAO,GAAG,IAAI;AAC7B,SAAO,IAAI,cAAqB,QAAQ,OAAO,GAAG,SAAS,CAAC;AAC9D;AAaO,MAAM,cAAc,CAAC,KAAa,eACvC,IAAI,QAAQ,CAAC,SAAS,WAAW;AAC/B,MAAI;AAEJ,MAAI,YAAY,IAAI;AAClB,WAAO,SAAS,eAAe,WAAW,EAAE;AAE5C,QAAI,MAAM;AACR,WAAK,OAAA;AAAA,IACP;AAAA,EACF;AAEA,SAAO,SAAS,cAAc,MAAM;AAEpC,QAAM,aAAa,MAAM;AACvB,YAAQ,MAAS;AACjB,SAAM,oBAAoB,QAAQ,UAAU;AAC5C,SAAM,oBAAoB,SAAS,WAAW;AAAA,EAChD;AAEA,QAAM,cAAc,MAAM;AACxB,WAAO,MAAS;AAChB,SAAM,oBAAoB,QAAQ,UAAU;AAC5C,SAAM,oBAAoB,SAAS,WAAW;AAAA,EAChD;AAEA,OAAK,iBAAiB,QAAQ,UAAU;AACxC,OAAK,iBAAiB,SAAS,WAAW;AAE1C,OAAK,aAAa,QAAQ,GAAG;AAE7B,MAAI,CAAC,YAAY,KAAK;AACpB,SAAK,aAAa,OAAO,YAAY;AAAA,EACvC;AAEA,SAAO,QAAQ,cAAc,CAAA,CAAE,EAAE,QAAQ,CAAC,CAAC,KAAK,KAAK,MAAM;AACzD,SAAK,aAAa,KAAK,KAAK;AAAA,EAC9B,CAAC;AAED,WAAS,KAAK,YAAY,IAAI;AAChC,CAAC;"}