yummies 7.11.0 → 7.12.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 (146) hide show
  1. package/async.cjs +162 -48
  2. package/async.cjs.map +1 -1
  3. package/async.d.ts +108 -7
  4. package/async.js +163 -54
  5. package/async.js.map +1 -1
  6. package/chunk-CVq3Gv4J.cjs +50 -0
  7. package/chunk-YKewjYmz.js +37 -0
  8. package/common.cjs +48 -8
  9. package/common.cjs.map +1 -1
  10. package/common.d.ts +35 -2
  11. package/common.js +49 -11
  12. package/common.js.map +1 -1
  13. package/complex.cjs +275 -128
  14. package/complex.cjs.map +1 -1
  15. package/complex.js +275 -133
  16. package/complex.js.map +1 -1
  17. package/cookie.cjs +17 -7
  18. package/cookie.cjs.map +1 -1
  19. package/cookie.d.ts +8 -0
  20. package/cookie.js +18 -9
  21. package/cookie.js.map +1 -1
  22. package/css.cjs +147 -39
  23. package/css.cjs.map +1 -1
  24. package/css.d.ts +98 -6
  25. package/css.js +143 -41
  26. package/css.js.map +1 -1
  27. package/data.cjs +90 -55
  28. package/data.cjs.map +1 -1
  29. package/data.d.ts +32 -0
  30. package/data.js +91 -61
  31. package/data.js.map +1 -1
  32. package/date-time.cjs +578 -412
  33. package/date-time.cjs.map +1 -1
  34. package/date-time.d.ts +88 -0
  35. package/date-time.js +575 -421
  36. package/date-time.js.map +1 -1
  37. package/device.cjs +48 -23
  38. package/device.cjs.map +1 -1
  39. package/device.d.ts +32 -0
  40. package/device.js +49 -31
  41. package/device.js.map +1 -1
  42. package/encodings.cjs +275 -266
  43. package/encodings.cjs.map +1 -1
  44. package/encodings.d.ts +8 -0
  45. package/encodings.js +276 -268
  46. package/encodings.js.map +1 -1
  47. package/errors.cjs +20 -18
  48. package/errors.cjs.map +1 -1
  49. package/errors.js +19 -19
  50. package/errors.js.map +1 -1
  51. package/file.cjs +42 -24
  52. package/file.cjs.map +1 -1
  53. package/file.d.ts +16 -0
  54. package/file.js +43 -27
  55. package/file.js.map +1 -1
  56. package/format.cjs +125 -83
  57. package/format.cjs.map +1 -1
  58. package/format.js +118 -82
  59. package/format.js.map +1 -1
  60. package/html.cjs +226 -137
  61. package/html.cjs.map +1 -1
  62. package/html.d.ts +64 -0
  63. package/html.js +223 -150
  64. package/html.js.map +1 -1
  65. package/id.cjs +74 -17
  66. package/id.cjs.map +1 -1
  67. package/id.js +73 -24
  68. package/id.js.map +1 -1
  69. package/imports.cjs +41 -29
  70. package/imports.cjs.map +1 -1
  71. package/imports.d.ts +8 -0
  72. package/imports.js +40 -31
  73. package/imports.js.map +1 -1
  74. package/math.cjs +32 -6
  75. package/math.cjs.map +1 -1
  76. package/math.d.ts +16 -0
  77. package/math.js +33 -10
  78. package/math.js.map +1 -1
  79. package/media.cjs +275 -84
  80. package/media.cjs.map +1 -1
  81. package/media.d.ts +188 -2
  82. package/media.js +274 -93
  83. package/media.js.map +1 -1
  84. package/mobx.cjs +353 -193
  85. package/mobx.cjs.map +1 -1
  86. package/mobx.d.ts +7 -0
  87. package/mobx.js +351 -200
  88. package/mobx.js.map +1 -1
  89. package/ms.cjs +21 -10
  90. package/ms.cjs.map +1 -1
  91. package/ms.js +22 -13
  92. package/ms.js.map +1 -1
  93. package/number.cjs +13 -7
  94. package/number.cjs.map +1 -1
  95. package/number.js +14 -9
  96. package/number.js.map +1 -1
  97. package/package.json +10 -2
  98. package/parser.cjs +117 -64
  99. package/parser.cjs.map +1 -1
  100. package/parser.js +111 -64
  101. package/parser.js.map +1 -1
  102. package/price.cjs +24 -18
  103. package/price.cjs.map +1 -1
  104. package/price.d.ts +8 -0
  105. package/price.js +25 -20
  106. package/price.js.map +1 -1
  107. package/random.cjs +79 -13
  108. package/random.cjs.map +1 -1
  109. package/random.d.ts +64 -0
  110. package/random.js +80 -22
  111. package/random.js.map +1 -1
  112. package/react.cjs +673 -214
  113. package/react.cjs.map +1 -1
  114. package/react.d.ts +21 -0
  115. package/react.js +674 -239
  116. package/react.js.map +1 -1
  117. package/sound.cjs +14 -9
  118. package/sound.cjs.map +1 -1
  119. package/sound.js +15 -11
  120. package/sound.js.map +1 -1
  121. package/storage.cjs +49 -50
  122. package/storage.cjs.map +1 -1
  123. package/storage.d.ts +8 -0
  124. package/storage.js +50 -53
  125. package/storage.js.map +1 -1
  126. package/text.cjs +51 -34
  127. package/text.cjs.map +1 -1
  128. package/text.js +52 -37
  129. package/text.js.map +1 -1
  130. package/type-guard.cjs +292 -72
  131. package/type-guard.cjs.map +1 -1
  132. package/type-guard.js +288 -73
  133. package/type-guard.js.map +1 -1
  134. package/types.cjs +0 -2
  135. package/types.global.cjs +0 -2
  136. package/types.global.js +0 -2
  137. package/types.js +0 -2
  138. package/vibrate.cjs +31 -6
  139. package/vibrate.cjs.map +1 -1
  140. package/vibrate.d.ts +23 -1
  141. package/vibrate.js +32 -8
  142. package/vibrate.js.map +1 -1
  143. package/types.cjs.map +0 -1
  144. package/types.global.cjs.map +0 -1
  145. package/types.global.js.map +0 -1
  146. package/types.js.map +0 -1
package/type-guard.js CHANGED
@@ -1,76 +1,291 @@
1
- const TYPE = {
2
- Null: "null",
3
- Undefined: "undefined",
4
- NaN: "nan",
5
- Object: "[object Object]",
6
- Array: "[object Array]",
7
- String: "[object String]",
8
- Number: "[object Number]",
9
- Boolean: "[object Boolean]",
10
- Function: "[object Function]",
11
- AsyncFunction: "[object AsyncFunction]",
12
- RegExp: "[object RegExp]",
13
- Symbol: "[object Symbol]",
14
- Infinite: "infinite",
15
- Element: "element"
1
+ import { n as __exportAll } from "./chunk-YKewjYmz.js";
2
+ //#region src/type-guard/_exports.ts
3
+ var _exports_exports = /* @__PURE__ */ __exportAll({
4
+ isArray: () => isArray,
5
+ isBoolean: () => isBoolean,
6
+ isDefined: () => isDefined,
7
+ isElement: () => isElement,
8
+ isFunction: () => isFunction,
9
+ isInfinite: () => isInfinite,
10
+ isNaN: () => isNaN,
11
+ isNull: () => isNull,
12
+ isNumber: () => isNumber,
13
+ isObject: () => isObject,
14
+ isRegExp: () => isRegExp,
15
+ isString: () => isString,
16
+ isSymbol: () => isSymbol,
17
+ isUndefined: () => isUndefined
18
+ });
19
+ var TYPE = {
20
+ Null: "null",
21
+ Undefined: "undefined",
22
+ NaN: "nan",
23
+ Object: "[object Object]",
24
+ Array: "[object Array]",
25
+ String: "[object String]",
26
+ Number: "[object Number]",
27
+ Boolean: "[object Boolean]",
28
+ Function: "[object Function]",
29
+ AsyncFunction: "[object AsyncFunction]",
30
+ RegExp: "[object RegExp]",
31
+ Symbol: "[object Symbol]",
32
+ Infinite: "infinite",
33
+ Element: "element"
16
34
  };
17
35
  function getType(value) {
18
- if (value === void 0) {
19
- return TYPE.Undefined;
20
- }
21
- if (value === null) {
22
- return TYPE.Null;
23
- }
24
- if (value && (value.nodeType === 1 || value.nodeType === 9)) {
25
- return TYPE.Element;
26
- }
27
- const stringifiedValue = Object.prototype.toString.call(value);
28
- if (stringifiedValue === TYPE.Number) {
29
- if (Number.isNaN(value)) {
30
- return TYPE.NaN;
31
- }
32
- if (!Number.isFinite(value)) {
33
- return TYPE.Infinite;
34
- }
35
- }
36
- return stringifiedValue;
36
+ if (value === void 0) return TYPE.Undefined;
37
+ if (value === null) return TYPE.Null;
38
+ if (value && (value.nodeType === 1 || value.nodeType === 9)) return TYPE.Element;
39
+ const stringifiedValue = Object.prototype.toString.call(value);
40
+ if (stringifiedValue === TYPE.Number) {
41
+ if (Number.isNaN(value)) return TYPE.NaN;
42
+ if (!Number.isFinite(value)) return TYPE.Infinite;
43
+ }
44
+ return stringifiedValue;
37
45
  }
38
- const createTypeGuard = (...types) => (value) => types.includes(getType(value));
39
- const isDefined = (value) => value != null;
40
- const isNull = createTypeGuard(TYPE.Null);
41
- const isUndefined = createTypeGuard(TYPE.Undefined);
42
- const isObject = createTypeGuard(TYPE.Object);
43
- const isArray = createTypeGuard(TYPE.Array);
44
- const isString = createTypeGuard(TYPE.String);
45
- const isNumber = createTypeGuard(TYPE.Number);
46
- const isBoolean = createTypeGuard(TYPE.Boolean);
47
- const isFunction = createTypeGuard(
48
- TYPE.Function,
49
- TYPE.AsyncFunction
50
- );
51
- const isRegExp = createTypeGuard(TYPE.RegExp);
52
- const isElement = createTypeGuard(TYPE.Element);
53
- const isNaN = createTypeGuard(TYPE.NaN);
54
- const isInfinite = createTypeGuard(TYPE.Infinite);
55
- const isSymbol = createTypeGuard(TYPE.Symbol);
56
- const _exports = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
57
- __proto__: null,
58
- isArray,
59
- isBoolean,
60
- isDefined,
61
- isElement,
62
- isFunction,
63
- isInfinite,
64
- isNaN,
65
- isNull,
66
- isNumber,
67
- isObject,
68
- isRegExp,
69
- isString,
70
- isSymbol,
71
- isUndefined
72
- }, Symbol.toStringTag, { value: "Module" }));
73
- export {
74
- _exports as typeGuard
75
- };
76
- //# sourceMappingURL=type-guard.js.map
46
+ var createTypeGuard = (...types) => (value) => types.includes(getType(value));
47
+ /**
48
+ * Checks that a value is neither `null` nor `undefined`.
49
+ *
50
+ * @template T Value type without nullish branches.
51
+ * @param value Value to test.
52
+ * @returns `true` when the value is defined.
53
+ *
54
+ * @example
55
+ * ```ts
56
+ * isDefined(0); // true
57
+ * ```
58
+ *
59
+ * @example
60
+ * ```ts
61
+ * isDefined(null); // false
62
+ * ```
63
+ */
64
+ var isDefined = (value) => value != null;
65
+ /**
66
+ * Checks whether a value is exactly `null`.
67
+ *
68
+ * @param value Value to test.
69
+ * @returns `true` when the value is `null`.
70
+ *
71
+ * @example
72
+ * ```ts
73
+ * isNull(null); // true
74
+ * ```
75
+ *
76
+ * @example
77
+ * ```ts
78
+ * isNull(undefined); // false
79
+ * ```
80
+ */
81
+ var isNull = createTypeGuard(TYPE.Null);
82
+ /**
83
+ * Checks whether a value is exactly `undefined`.
84
+ *
85
+ * @param value Value to test.
86
+ * @returns `true` when the value is `undefined`.
87
+ *
88
+ * @example
89
+ * ```ts
90
+ * isUndefined(undefined); // true
91
+ * ```
92
+ *
93
+ * @example
94
+ * ```ts
95
+ * isUndefined('value'); // false
96
+ * ```
97
+ */
98
+ var isUndefined = createTypeGuard(TYPE.Undefined);
99
+ /**
100
+ * Checks whether a value is a plain object.
101
+ *
102
+ * @param value Value to test.
103
+ * @returns `true` when the value matches `[object Object]`.
104
+ *
105
+ * @example
106
+ * ```ts
107
+ * isObject({ id: 1 }); // true
108
+ * ```
109
+ *
110
+ * @example
111
+ * ```ts
112
+ * isObject([]); // false
113
+ * ```
114
+ */
115
+ var isObject = createTypeGuard(TYPE.Object);
116
+ /**
117
+ * Checks whether a value is an array.
118
+ *
119
+ * @param value Value to test.
120
+ * @returns `true` when the value is an array.
121
+ *
122
+ * @example
123
+ * ```ts
124
+ * isArray([1, 2, 3]); // true
125
+ * ```
126
+ *
127
+ * @example
128
+ * ```ts
129
+ * isArray({ length: 1 }); // false
130
+ * ```
131
+ */
132
+ var isArray = createTypeGuard(TYPE.Array);
133
+ /**
134
+ * Checks whether a value is a string object or primitive string.
135
+ *
136
+ * @param value Value to test.
137
+ * @returns `true` when the value is a string.
138
+ *
139
+ * @example
140
+ * ```ts
141
+ * isString('hello'); // true
142
+ * ```
143
+ *
144
+ * @example
145
+ * ```ts
146
+ * isString(123); // false
147
+ * ```
148
+ */
149
+ var isString = createTypeGuard(TYPE.String);
150
+ /**
151
+ * Checks whether a value is a finite number.
152
+ *
153
+ * Unlike `isNaN` and `isInfinite`, this guard only matches regular numeric values.
154
+ *
155
+ * @param value Value to test.
156
+ * @returns `true` when the value is a non-NaN finite number.
157
+ *
158
+ * @example
159
+ * ```ts
160
+ * isNumber(123); // true
161
+ * ```
162
+ *
163
+ * @example
164
+ * ```ts
165
+ * isNumber(Number.NaN); // false
166
+ * ```
167
+ */
168
+ var isNumber = createTypeGuard(TYPE.Number);
169
+ /**
170
+ * Checks whether a value is a boolean.
171
+ *
172
+ * @param value Value to test.
173
+ * @returns `true` when the value is a boolean.
174
+ *
175
+ * @example
176
+ * ```ts
177
+ * isBoolean(true); // true
178
+ * ```
179
+ *
180
+ * @example
181
+ * ```ts
182
+ * isBoolean('true'); // false
183
+ * ```
184
+ */
185
+ var isBoolean = createTypeGuard(TYPE.Boolean);
186
+ /**
187
+ * Checks whether a value is a synchronous or asynchronous function.
188
+ *
189
+ * @param value Value to test.
190
+ * @returns `true` when the value is a function.
191
+ *
192
+ * @example
193
+ * ```ts
194
+ * isFunction(() => {}); // true
195
+ * ```
196
+ *
197
+ * @example
198
+ * ```ts
199
+ * isFunction(async () => {}); // true
200
+ * ```
201
+ */
202
+ var isFunction = createTypeGuard(TYPE.Function, TYPE.AsyncFunction);
203
+ /**
204
+ * Checks whether a value is a regular expression.
205
+ *
206
+ * @param value Value to test.
207
+ * @returns `true` when the value is a `RegExp`.
208
+ *
209
+ * @example
210
+ * ```ts
211
+ * isRegExp(/foo/); // true
212
+ * ```
213
+ *
214
+ * @example
215
+ * ```ts
216
+ * isRegExp('foo'); // false
217
+ * ```
218
+ */
219
+ var isRegExp = createTypeGuard(TYPE.RegExp);
220
+ /**
221
+ * Checks whether a value looks like a DOM element or document node.
222
+ *
223
+ * @param value Value to test.
224
+ * @returns `true` when the value has an element-like node type.
225
+ *
226
+ * @example
227
+ * ```ts
228
+ * isElement(document.body); // true
229
+ * ```
230
+ *
231
+ * @example
232
+ * ```ts
233
+ * isElement({ nodeType: 3 }); // false
234
+ * ```
235
+ */
236
+ var isElement = createTypeGuard(TYPE.Element);
237
+ /**
238
+ * Checks whether a value is `NaN`.
239
+ *
240
+ * @param value Value to test.
241
+ * @returns `true` when the value is `NaN`.
242
+ *
243
+ * @example
244
+ * ```ts
245
+ * isNaN(Number.NaN); // true
246
+ * ```
247
+ *
248
+ * @example
249
+ * ```ts
250
+ * isNaN(5); // false
251
+ * ```
252
+ */
253
+ var isNaN = createTypeGuard(TYPE.NaN);
254
+ /**
255
+ * Checks whether a value is positive or negative infinity.
256
+ *
257
+ * @param value Value to test.
258
+ * @returns `true` when the value is not finite.
259
+ *
260
+ * @example
261
+ * ```ts
262
+ * isInfinite(Infinity); // true
263
+ * ```
264
+ *
265
+ * @example
266
+ * ```ts
267
+ * isInfinite(10); // false
268
+ * ```
269
+ */
270
+ var isInfinite = createTypeGuard(TYPE.Infinite);
271
+ /**
272
+ * Checks whether a value is a symbol.
273
+ *
274
+ * @param value Value to test.
275
+ * @returns `true` when the value is a symbol.
276
+ *
277
+ * @example
278
+ * ```ts
279
+ * isSymbol(Symbol('id')); // true
280
+ * ```
281
+ *
282
+ * @example
283
+ * ```ts
284
+ * isSymbol('id'); // false
285
+ * ```
286
+ */
287
+ var isSymbol = createTypeGuard(TYPE.Symbol);
288
+ //#endregion
289
+ export { _exports_exports as typeGuard };
290
+
291
+ //# sourceMappingURL=type-guard.js.map
package/type-guard.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"type-guard.js","sources":["../src/type-guard/_exports.ts"],"sourcesContent":["import type { AnyFunction, AnyObject, ValueOf } from 'yummies/types';\n\nconst TYPE = {\n Null: 'null',\n Undefined: 'undefined',\n NaN: 'nan',\n Object: '[object Object]',\n Array: '[object Array]',\n String: '[object String]',\n Number: '[object Number]',\n Boolean: '[object Boolean]',\n Function: '[object Function]',\n AsyncFunction: '[object AsyncFunction]',\n RegExp: '[object RegExp]',\n Symbol: '[object Symbol]',\n Infinite: 'infinite',\n Element: 'element',\n};\n\ntype Type = ValueOf<typeof TYPE>;\n\nfunction getType(value: unknown): Type {\n if (value === undefined) {\n return TYPE.Undefined;\n }\n if (value === null) {\n return TYPE.Null;\n }\n\n // handle DOM elements\n // @ts-expect-error\n if (value && (value.nodeType === 1 || value.nodeType === 9)) {\n return TYPE.Element;\n }\n\n const stringifiedValue = Object.prototype.toString.call(value);\n\n // handle NaN and Infinity\n if (stringifiedValue === TYPE.Number) {\n if (Number.isNaN(value as number)) {\n return TYPE.NaN;\n }\n if (!Number.isFinite(value as number)) {\n return TYPE.Infinite;\n }\n }\n\n return stringifiedValue as Type;\n}\n\nconst createTypeGuard =\n <T>(...types: Type[]) =>\n (value: unknown): value is T =>\n types.includes(getType(value));\n\n/**\n * Checks that a value is neither `null` nor `undefined`.\n *\n * @template T Value type without nullish branches.\n * @param value Value to test.\n * @returns `true` when the value is defined.\n *\n * @example\n * ```ts\n * isDefined(0); // true\n * ```\n *\n * @example\n * ```ts\n * isDefined(null); // false\n * ```\n */\nexport const isDefined = <T>(value: T | undefined | null): value is T =>\n value != null;\n\n/**\n * Checks whether a value is exactly `null`.\n *\n * @param value Value to test.\n * @returns `true` when the value is `null`.\n *\n * @example\n * ```ts\n * isNull(null); // true\n * ```\n *\n * @example\n * ```ts\n * isNull(undefined); // false\n * ```\n */\nexport const isNull = createTypeGuard<null>(TYPE.Null);\n\n/**\n * Checks whether a value is exactly `undefined`.\n *\n * @param value Value to test.\n * @returns `true` when the value is `undefined`.\n *\n * @example\n * ```ts\n * isUndefined(undefined); // true\n * ```\n *\n * @example\n * ```ts\n * isUndefined('value'); // false\n * ```\n */\nexport const isUndefined = createTypeGuard<undefined>(TYPE.Undefined);\n\n/**\n * Checks whether a value is a plain object.\n *\n * @param value Value to test.\n * @returns `true` when the value matches `[object Object]`.\n *\n * @example\n * ```ts\n * isObject({ id: 1 }); // true\n * ```\n *\n * @example\n * ```ts\n * isObject([]); // false\n * ```\n */\nexport const isObject = createTypeGuard<AnyObject>(TYPE.Object);\n\n/**\n * Checks whether a value is an array.\n *\n * @param value Value to test.\n * @returns `true` when the value is an array.\n *\n * @example\n * ```ts\n * isArray([1, 2, 3]); // true\n * ```\n *\n * @example\n * ```ts\n * isArray({ length: 1 }); // false\n * ```\n */\nexport const isArray = createTypeGuard<unknown[]>(TYPE.Array);\n\n/**\n * Checks whether a value is a string object or primitive string.\n *\n * @param value Value to test.\n * @returns `true` when the value is a string.\n *\n * @example\n * ```ts\n * isString('hello'); // true\n * ```\n *\n * @example\n * ```ts\n * isString(123); // false\n * ```\n */\nexport const isString = createTypeGuard<string>(TYPE.String);\n\n/**\n * Checks whether a value is a finite number.\n *\n * Unlike `isNaN` and `isInfinite`, this guard only matches regular numeric values.\n *\n * @param value Value to test.\n * @returns `true` when the value is a non-NaN finite number.\n *\n * @example\n * ```ts\n * isNumber(123); // true\n * ```\n *\n * @example\n * ```ts\n * isNumber(Number.NaN); // false\n * ```\n */\nexport const isNumber = createTypeGuard<number>(TYPE.Number);\n\n/**\n * Checks whether a value is a boolean.\n *\n * @param value Value to test.\n * @returns `true` when the value is a boolean.\n *\n * @example\n * ```ts\n * isBoolean(true); // true\n * ```\n *\n * @example\n * ```ts\n * isBoolean('true'); // false\n * ```\n */\nexport const isBoolean = createTypeGuard<boolean>(TYPE.Boolean);\n\n/**\n * Checks whether a value is a synchronous or asynchronous function.\n *\n * @param value Value to test.\n * @returns `true` when the value is a function.\n *\n * @example\n * ```ts\n * isFunction(() => {}); // true\n * ```\n *\n * @example\n * ```ts\n * isFunction(async () => {}); // true\n * ```\n */\nexport const isFunction = createTypeGuard<AnyFunction>(\n TYPE.Function,\n TYPE.AsyncFunction,\n);\n\n/**\n * Checks whether a value is a regular expression.\n *\n * @param value Value to test.\n * @returns `true` when the value is a `RegExp`.\n *\n * @example\n * ```ts\n * isRegExp(/foo/); // true\n * ```\n *\n * @example\n * ```ts\n * isRegExp('foo'); // false\n * ```\n */\nexport const isRegExp = createTypeGuard<RegExp>(TYPE.RegExp);\n\n/**\n * Checks whether a value looks like a DOM element or document node.\n *\n * @param value Value to test.\n * @returns `true` when the value has an element-like node type.\n *\n * @example\n * ```ts\n * isElement(document.body); // true\n * ```\n *\n * @example\n * ```ts\n * isElement({ nodeType: 3 }); // false\n * ```\n */\nexport const isElement = createTypeGuard<HTMLElement>(TYPE.Element);\n\n/**\n * Checks whether a value is `NaN`.\n *\n * @param value Value to test.\n * @returns `true` when the value is `NaN`.\n *\n * @example\n * ```ts\n * isNaN(Number.NaN); // true\n * ```\n *\n * @example\n * ```ts\n * isNaN(5); // false\n * ```\n */\nexport const isNaN = createTypeGuard<number>(TYPE.NaN) as (\n value: unknown,\n) => boolean;\n\n/**\n * Checks whether a value is positive or negative infinity.\n *\n * @param value Value to test.\n * @returns `true` when the value is not finite.\n *\n * @example\n * ```ts\n * isInfinite(Infinity); // true\n * ```\n *\n * @example\n * ```ts\n * isInfinite(10); // false\n * ```\n */\nexport const isInfinite = createTypeGuard<number>(TYPE.Infinite) as (\n value: unknown,\n) => boolean;\n\n/**\n * Checks whether a value is a symbol.\n *\n * @param value Value to test.\n * @returns `true` when the value is a symbol.\n *\n * @example\n * ```ts\n * isSymbol(Symbol('id')); // true\n * ```\n *\n * @example\n * ```ts\n * isSymbol('id'); // false\n * ```\n */\nexport const isSymbol = createTypeGuard<symbol>(TYPE.Symbol);\n"],"names":[],"mappings":"AAEA,MAAM,OAAO;AAAA,EACX,MAAM;AAAA,EACN,WAAW;AAAA,EACX,KAAK;AAAA,EACL,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,UAAU;AAAA,EACV,eAAe;AAAA,EACf,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,UAAU;AAAA,EACV,SAAS;AACX;AAIA,SAAS,QAAQ,OAAsB;AACrC,MAAI,UAAU,QAAW;AACvB,WAAO,KAAK;AAAA,EACd;AACA,MAAI,UAAU,MAAM;AAClB,WAAO,KAAK;AAAA,EACd;AAIA,MAAI,UAAU,MAAM,aAAa,KAAK,MAAM,aAAa,IAAI;AAC3D,WAAO,KAAK;AAAA,EACd;AAEA,QAAM,mBAAmB,OAAO,UAAU,SAAS,KAAK,KAAK;AAG7D,MAAI,qBAAqB,KAAK,QAAQ;AACpC,QAAI,OAAO,MAAM,KAAe,GAAG;AACjC,aAAO,KAAK;AAAA,IACd;AACA,QAAI,CAAC,OAAO,SAAS,KAAe,GAAG;AACrC,aAAO,KAAK;AAAA,IACd;AAAA,EACF;AAEA,SAAO;AACT;AAEA,MAAM,kBACJ,IAAO,UACP,CAAC,UACC,MAAM,SAAS,QAAQ,KAAK,CAAC;AAmB1B,MAAM,YAAY,CAAI,UAC3B,SAAS;AAkBJ,MAAM,SAAS,gBAAsB,KAAK,IAAI;AAkB9C,MAAM,cAAc,gBAA2B,KAAK,SAAS;AAkB7D,MAAM,WAAW,gBAA2B,KAAK,MAAM;AAkBvD,MAAM,UAAU,gBAA2B,KAAK,KAAK;AAkBrD,MAAM,WAAW,gBAAwB,KAAK,MAAM;AAoBpD,MAAM,WAAW,gBAAwB,KAAK,MAAM;AAkBpD,MAAM,YAAY,gBAAyB,KAAK,OAAO;AAkBvD,MAAM,aAAa;AAAA,EACxB,KAAK;AAAA,EACL,KAAK;AACP;AAkBO,MAAM,WAAW,gBAAwB,KAAK,MAAM;AAkBpD,MAAM,YAAY,gBAA6B,KAAK,OAAO;AAkB3D,MAAM,QAAQ,gBAAwB,KAAK,GAAG;AAoB9C,MAAM,aAAa,gBAAwB,KAAK,QAAQ;AAoBxD,MAAM,WAAW,gBAAwB,KAAK,MAAM;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"type-guard.js","names":[],"sources":["../src/type-guard/_exports.ts"],"sourcesContent":["import type { AnyFunction, AnyObject, ValueOf } from 'yummies/types';\n\nconst TYPE = {\n Null: 'null',\n Undefined: 'undefined',\n NaN: 'nan',\n Object: '[object Object]',\n Array: '[object Array]',\n String: '[object String]',\n Number: '[object Number]',\n Boolean: '[object Boolean]',\n Function: '[object Function]',\n AsyncFunction: '[object AsyncFunction]',\n RegExp: '[object RegExp]',\n Symbol: '[object Symbol]',\n Infinite: 'infinite',\n Element: 'element',\n};\n\ntype Type = ValueOf<typeof TYPE>;\n\nfunction getType(value: unknown): Type {\n if (value === undefined) {\n return TYPE.Undefined;\n }\n if (value === null) {\n return TYPE.Null;\n }\n\n // handle DOM elements\n // @ts-expect-error\n if (value && (value.nodeType === 1 || value.nodeType === 9)) {\n return TYPE.Element;\n }\n\n const stringifiedValue = Object.prototype.toString.call(value);\n\n // handle NaN and Infinity\n if (stringifiedValue === TYPE.Number) {\n if (Number.isNaN(value as number)) {\n return TYPE.NaN;\n }\n if (!Number.isFinite(value as number)) {\n return TYPE.Infinite;\n }\n }\n\n return stringifiedValue as Type;\n}\n\nconst createTypeGuard =\n <T>(...types: Type[]) =>\n (value: unknown): value is T =>\n types.includes(getType(value));\n\n/**\n * Checks that a value is neither `null` nor `undefined`.\n *\n * @template T Value type without nullish branches.\n * @param value Value to test.\n * @returns `true` when the value is defined.\n *\n * @example\n * ```ts\n * isDefined(0); // true\n * ```\n *\n * @example\n * ```ts\n * isDefined(null); // false\n * ```\n */\nexport const isDefined = <T>(value: T | undefined | null): value is T =>\n value != null;\n\n/**\n * Checks whether a value is exactly `null`.\n *\n * @param value Value to test.\n * @returns `true` when the value is `null`.\n *\n * @example\n * ```ts\n * isNull(null); // true\n * ```\n *\n * @example\n * ```ts\n * isNull(undefined); // false\n * ```\n */\nexport const isNull = createTypeGuard<null>(TYPE.Null);\n\n/**\n * Checks whether a value is exactly `undefined`.\n *\n * @param value Value to test.\n * @returns `true` when the value is `undefined`.\n *\n * @example\n * ```ts\n * isUndefined(undefined); // true\n * ```\n *\n * @example\n * ```ts\n * isUndefined('value'); // false\n * ```\n */\nexport const isUndefined = createTypeGuard<undefined>(TYPE.Undefined);\n\n/**\n * Checks whether a value is a plain object.\n *\n * @param value Value to test.\n * @returns `true` when the value matches `[object Object]`.\n *\n * @example\n * ```ts\n * isObject({ id: 1 }); // true\n * ```\n *\n * @example\n * ```ts\n * isObject([]); // false\n * ```\n */\nexport const isObject = createTypeGuard<AnyObject>(TYPE.Object);\n\n/**\n * Checks whether a value is an array.\n *\n * @param value Value to test.\n * @returns `true` when the value is an array.\n *\n * @example\n * ```ts\n * isArray([1, 2, 3]); // true\n * ```\n *\n * @example\n * ```ts\n * isArray({ length: 1 }); // false\n * ```\n */\nexport const isArray = createTypeGuard<unknown[]>(TYPE.Array);\n\n/**\n * Checks whether a value is a string object or primitive string.\n *\n * @param value Value to test.\n * @returns `true` when the value is a string.\n *\n * @example\n * ```ts\n * isString('hello'); // true\n * ```\n *\n * @example\n * ```ts\n * isString(123); // false\n * ```\n */\nexport const isString = createTypeGuard<string>(TYPE.String);\n\n/**\n * Checks whether a value is a finite number.\n *\n * Unlike `isNaN` and `isInfinite`, this guard only matches regular numeric values.\n *\n * @param value Value to test.\n * @returns `true` when the value is a non-NaN finite number.\n *\n * @example\n * ```ts\n * isNumber(123); // true\n * ```\n *\n * @example\n * ```ts\n * isNumber(Number.NaN); // false\n * ```\n */\nexport const isNumber = createTypeGuard<number>(TYPE.Number);\n\n/**\n * Checks whether a value is a boolean.\n *\n * @param value Value to test.\n * @returns `true` when the value is a boolean.\n *\n * @example\n * ```ts\n * isBoolean(true); // true\n * ```\n *\n * @example\n * ```ts\n * isBoolean('true'); // false\n * ```\n */\nexport const isBoolean = createTypeGuard<boolean>(TYPE.Boolean);\n\n/**\n * Checks whether a value is a synchronous or asynchronous function.\n *\n * @param value Value to test.\n * @returns `true` when the value is a function.\n *\n * @example\n * ```ts\n * isFunction(() => {}); // true\n * ```\n *\n * @example\n * ```ts\n * isFunction(async () => {}); // true\n * ```\n */\nexport const isFunction = createTypeGuard<AnyFunction>(\n TYPE.Function,\n TYPE.AsyncFunction,\n);\n\n/**\n * Checks whether a value is a regular expression.\n *\n * @param value Value to test.\n * @returns `true` when the value is a `RegExp`.\n *\n * @example\n * ```ts\n * isRegExp(/foo/); // true\n * ```\n *\n * @example\n * ```ts\n * isRegExp('foo'); // false\n * ```\n */\nexport const isRegExp = createTypeGuard<RegExp>(TYPE.RegExp);\n\n/**\n * Checks whether a value looks like a DOM element or document node.\n *\n * @param value Value to test.\n * @returns `true` when the value has an element-like node type.\n *\n * @example\n * ```ts\n * isElement(document.body); // true\n * ```\n *\n * @example\n * ```ts\n * isElement({ nodeType: 3 }); // false\n * ```\n */\nexport const isElement = createTypeGuard<HTMLElement>(TYPE.Element);\n\n/**\n * Checks whether a value is `NaN`.\n *\n * @param value Value to test.\n * @returns `true` when the value is `NaN`.\n *\n * @example\n * ```ts\n * isNaN(Number.NaN); // true\n * ```\n *\n * @example\n * ```ts\n * isNaN(5); // false\n * ```\n */\nexport const isNaN = createTypeGuard<number>(TYPE.NaN) as (\n value: unknown,\n) => boolean;\n\n/**\n * Checks whether a value is positive or negative infinity.\n *\n * @param value Value to test.\n * @returns `true` when the value is not finite.\n *\n * @example\n * ```ts\n * isInfinite(Infinity); // true\n * ```\n *\n * @example\n * ```ts\n * isInfinite(10); // false\n * ```\n */\nexport const isInfinite = createTypeGuard<number>(TYPE.Infinite) as (\n value: unknown,\n) => boolean;\n\n/**\n * Checks whether a value is a symbol.\n *\n * @param value Value to test.\n * @returns `true` when the value is a symbol.\n *\n * @example\n * ```ts\n * isSymbol(Symbol('id')); // true\n * ```\n *\n * @example\n * ```ts\n * isSymbol('id'); // false\n * ```\n */\nexport const isSymbol = createTypeGuard<symbol>(TYPE.Symbol);\n"],"mappings":";;;;;;;;;;;;;;;;;;AAEA,IAAM,OAAO;CACX,MAAM;CACN,WAAW;CACX,KAAK;CACL,QAAQ;CACR,OAAO;CACP,QAAQ;CACR,QAAQ;CACR,SAAS;CACT,UAAU;CACV,eAAe;CACf,QAAQ;CACR,QAAQ;CACR,UAAU;CACV,SAAS;CACV;AAID,SAAS,QAAQ,OAAsB;AACrC,KAAI,UAAU,KAAA,EACZ,QAAO,KAAK;AAEd,KAAI,UAAU,KACZ,QAAO,KAAK;AAKd,KAAI,UAAU,MAAM,aAAa,KAAK,MAAM,aAAa,GACvD,QAAO,KAAK;CAGd,MAAM,mBAAmB,OAAO,UAAU,SAAS,KAAK,MAAM;AAG9D,KAAI,qBAAqB,KAAK,QAAQ;AACpC,MAAI,OAAO,MAAM,MAAgB,CAC/B,QAAO,KAAK;AAEd,MAAI,CAAC,OAAO,SAAS,MAAgB,CACnC,QAAO,KAAK;;AAIhB,QAAO;;AAGT,IAAM,mBACA,GAAG,WACN,UACC,MAAM,SAAS,QAAQ,MAAM,CAAC;;;;;;;;;;;;;;;;;;AAmBlC,IAAa,aAAgB,UAC3B,SAAS;;;;;;;;;;;;;;;;;AAkBX,IAAa,SAAS,gBAAsB,KAAK,KAAK;;;;;;;;;;;;;;;;;AAkBtD,IAAa,cAAc,gBAA2B,KAAK,UAAU;;;;;;;;;;;;;;;;;AAkBrE,IAAa,WAAW,gBAA2B,KAAK,OAAO;;;;;;;;;;;;;;;;;AAkB/D,IAAa,UAAU,gBAA2B,KAAK,MAAM;;;;;;;;;;;;;;;;;AAkB7D,IAAa,WAAW,gBAAwB,KAAK,OAAO;;;;;;;;;;;;;;;;;;;AAoB5D,IAAa,WAAW,gBAAwB,KAAK,OAAO;;;;;;;;;;;;;;;;;AAkB5D,IAAa,YAAY,gBAAyB,KAAK,QAAQ;;;;;;;;;;;;;;;;;AAkB/D,IAAa,aAAa,gBACxB,KAAK,UACL,KAAK,cACN;;;;;;;;;;;;;;;;;AAkBD,IAAa,WAAW,gBAAwB,KAAK,OAAO;;;;;;;;;;;;;;;;;AAkB5D,IAAa,YAAY,gBAA6B,KAAK,QAAQ;;;;;;;;;;;;;;;;;AAkBnE,IAAa,QAAQ,gBAAwB,KAAK,IAAI;;;;;;;;;;;;;;;;;AAoBtD,IAAa,aAAa,gBAAwB,KAAK,SAAS;;;;;;;;;;;;;;;;;AAoBhE,IAAa,WAAW,gBAAwB,KAAK,OAAO"}
package/types.cjs CHANGED
@@ -1,2 +0,0 @@
1
- "use strict";
2
- //# sourceMappingURL=types.cjs.map
package/types.global.cjs CHANGED
@@ -1,2 +0,0 @@
1
- "use strict";
2
- //# sourceMappingURL=types.global.cjs.map
package/types.global.js CHANGED
@@ -1,2 +0,0 @@
1
-
2
- //# sourceMappingURL=types.global.js.map
package/types.js CHANGED
@@ -1,2 +0,0 @@
1
-
2
- //# sourceMappingURL=types.js.map
package/vibrate.cjs CHANGED
@@ -1,9 +1,34 @@
1
- "use strict";
2
1
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- const vibrate = (pattern) => {
4
- if ("vibrate" in navigator) {
5
- navigator.vibrate(pattern);
6
- }
2
+ //#region src/vibrate.ts
3
+ /**
4
+ * Triggers haptic feedback via the {@link https://developer.mozilla.org/en-US/docs/Web/API/Vibration_API | Vibration API}
5
+ * when `navigator.vibrate` exists (common on Android Chrome; often missing on iOS Safari / desktop).
6
+ *
7
+ * - **Single number** — vibrate for that many milliseconds, then stop.
8
+ * - **Array of numbers** — alternating vibration and pause lengths in ms: `[vibrate, pause, vibrate, ...]`.
9
+ * Per the spec, values are clamped; odd-length arrays imply a trailing vibrate segment.
10
+ *
11
+ * If the API is unavailable or the user has disabled vibration, this function **does nothing**
12
+ * (no throw). Call sites should not rely on vibration for critical UX.
13
+ *
14
+ * @param pattern - Duration in ms, or a pattern array as described above.
15
+ *
16
+ * @example
17
+ * Short confirmation buzz (200 ms):
18
+ * ```ts
19
+ * vibrate(200);
20
+ * ```
21
+ *
22
+ * @example
23
+ * Double-pulse pattern: 100 ms on, 50 ms off, 100 ms on:
24
+ * ```ts
25
+ * vibrate([100, 50, 100]);
26
+ * ```
27
+ */
28
+ var vibrate = (pattern) => {
29
+ if ("vibrate" in navigator) navigator.vibrate(pattern);
7
30
  };
31
+ //#endregion
8
32
  exports.vibrate = vibrate;
9
- //# sourceMappingURL=vibrate.cjs.map
33
+
34
+ //# sourceMappingURL=vibrate.cjs.map
package/vibrate.cjs.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"vibrate.cjs","sources":["../src/vibrate.ts"],"sourcesContent":["/**\n * Triggers vibration using the provided pattern.\n */\nexport const vibrate = (pattern: number | number[]) => {\n if ('vibrate' in navigator) {\n navigator.vibrate(pattern);\n }\n};\n"],"names":[],"mappings":";;AAGO,MAAM,UAAU,CAAC,YAA+B;AACrD,MAAI,aAAa,WAAW;AAC1B,cAAU,QAAQ,OAAO;AAAA,EAC3B;AACF;;"}
1
+ {"version":3,"file":"vibrate.cjs","names":[],"sources":["../src/vibrate.ts"],"sourcesContent":["/**\n * Triggers haptic feedback via the {@link https://developer.mozilla.org/en-US/docs/Web/API/Vibration_API | Vibration API}\n * when `navigator.vibrate` exists (common on Android Chrome; often missing on iOS Safari / desktop).\n *\n * - **Single number** — vibrate for that many milliseconds, then stop.\n * - **Array of numbers** — alternating vibration and pause lengths in ms: `[vibrate, pause, vibrate, ...]`.\n * Per the spec, values are clamped; odd-length arrays imply a trailing vibrate segment.\n *\n * If the API is unavailable or the user has disabled vibration, this function **does nothing**\n * (no throw). Call sites should not rely on vibration for critical UX.\n *\n * @param pattern - Duration in ms, or a pattern array as described above.\n *\n * @example\n * Short confirmation buzz (200 ms):\n * ```ts\n * vibrate(200);\n * ```\n *\n * @example\n * Double-pulse pattern: 100 ms on, 50 ms off, 100 ms on:\n * ```ts\n * vibrate([100, 50, 100]);\n * ```\n */\nexport const vibrate = (pattern: number | number[]) => {\n if ('vibrate' in navigator) {\n navigator.vibrate(pattern);\n }\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAyBA,IAAa,WAAW,YAA+B;AACrD,KAAI,aAAa,UACf,WAAU,QAAQ,QAAQ"}
package/vibrate.d.ts CHANGED
@@ -1,5 +1,27 @@
1
1
  /**
2
- * Triggers vibration using the provided pattern.
2
+ * Triggers haptic feedback via the {@link https://developer.mozilla.org/en-US/docs/Web/API/Vibration_API | Vibration API}
3
+ * when `navigator.vibrate` exists (common on Android Chrome; often missing on iOS Safari / desktop).
4
+ *
5
+ * - **Single number** — vibrate for that many milliseconds, then stop.
6
+ * - **Array of numbers** — alternating vibration and pause lengths in ms: `[vibrate, pause, vibrate, ...]`.
7
+ * Per the spec, values are clamped; odd-length arrays imply a trailing vibrate segment.
8
+ *
9
+ * If the API is unavailable or the user has disabled vibration, this function **does nothing**
10
+ * (no throw). Call sites should not rely on vibration for critical UX.
11
+ *
12
+ * @param pattern - Duration in ms, or a pattern array as described above.
13
+ *
14
+ * @example
15
+ * Short confirmation buzz (200 ms):
16
+ * ```ts
17
+ * vibrate(200);
18
+ * ```
19
+ *
20
+ * @example
21
+ * Double-pulse pattern: 100 ms on, 50 ms off, 100 ms on:
22
+ * ```ts
23
+ * vibrate([100, 50, 100]);
24
+ * ```
3
25
  */
4
26
  declare const vibrate: (pattern: number | number[]) => void;
5
27
 
package/vibrate.js CHANGED
@@ -1,9 +1,33 @@
1
- const vibrate = (pattern) => {
2
- if ("vibrate" in navigator) {
3
- navigator.vibrate(pattern);
4
- }
1
+ //#region src/vibrate.ts
2
+ /**
3
+ * Triggers haptic feedback via the {@link https://developer.mozilla.org/en-US/docs/Web/API/Vibration_API | Vibration API}
4
+ * when `navigator.vibrate` exists (common on Android Chrome; often missing on iOS Safari / desktop).
5
+ *
6
+ * - **Single number** — vibrate for that many milliseconds, then stop.
7
+ * - **Array of numbers** — alternating vibration and pause lengths in ms: `[vibrate, pause, vibrate, ...]`.
8
+ * Per the spec, values are clamped; odd-length arrays imply a trailing vibrate segment.
9
+ *
10
+ * If the API is unavailable or the user has disabled vibration, this function **does nothing**
11
+ * (no throw). Call sites should not rely on vibration for critical UX.
12
+ *
13
+ * @param pattern - Duration in ms, or a pattern array as described above.
14
+ *
15
+ * @example
16
+ * Short confirmation buzz (200 ms):
17
+ * ```ts
18
+ * vibrate(200);
19
+ * ```
20
+ *
21
+ * @example
22
+ * Double-pulse pattern: 100 ms on, 50 ms off, 100 ms on:
23
+ * ```ts
24
+ * vibrate([100, 50, 100]);
25
+ * ```
26
+ */
27
+ var vibrate = (pattern) => {
28
+ if ("vibrate" in navigator) navigator.vibrate(pattern);
5
29
  };
6
- export {
7
- vibrate
8
- };
9
- //# sourceMappingURL=vibrate.js.map
30
+ //#endregion
31
+ export { vibrate };
32
+
33
+ //# sourceMappingURL=vibrate.js.map
package/vibrate.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"vibrate.js","sources":["../src/vibrate.ts"],"sourcesContent":["/**\n * Triggers vibration using the provided pattern.\n */\nexport const vibrate = (pattern: number | number[]) => {\n if ('vibrate' in navigator) {\n navigator.vibrate(pattern);\n }\n};\n"],"names":[],"mappings":"AAGO,MAAM,UAAU,CAAC,YAA+B;AACrD,MAAI,aAAa,WAAW;AAC1B,cAAU,QAAQ,OAAO;AAAA,EAC3B;AACF;"}
1
+ {"version":3,"file":"vibrate.js","names":[],"sources":["../src/vibrate.ts"],"sourcesContent":["/**\n * Triggers haptic feedback via the {@link https://developer.mozilla.org/en-US/docs/Web/API/Vibration_API | Vibration API}\n * when `navigator.vibrate` exists (common on Android Chrome; often missing on iOS Safari / desktop).\n *\n * - **Single number** — vibrate for that many milliseconds, then stop.\n * - **Array of numbers** — alternating vibration and pause lengths in ms: `[vibrate, pause, vibrate, ...]`.\n * Per the spec, values are clamped; odd-length arrays imply a trailing vibrate segment.\n *\n * If the API is unavailable or the user has disabled vibration, this function **does nothing**\n * (no throw). Call sites should not rely on vibration for critical UX.\n *\n * @param pattern - Duration in ms, or a pattern array as described above.\n *\n * @example\n * Short confirmation buzz (200 ms):\n * ```ts\n * vibrate(200);\n * ```\n *\n * @example\n * Double-pulse pattern: 100 ms on, 50 ms off, 100 ms on:\n * ```ts\n * vibrate([100, 50, 100]);\n * ```\n */\nexport const vibrate = (pattern: number | number[]) => {\n if ('vibrate' in navigator) {\n navigator.vibrate(pattern);\n }\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAyBA,IAAa,WAAW,YAA+B;AACrD,KAAI,aAAa,UACf,WAAU,QAAQ,QAAQ"}
package/types.cjs.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.global.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.global.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
package/types.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"types.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}