yummies 5.11.0 → 5.11.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/async.cjs +1 -1
- package/async.cjs.map +1 -1
- package/async.js +38 -21
- package/async.js.map +1 -1
- package/common.cjs +1 -1
- package/common.cjs.map +1 -1
- package/common.js +9 -3
- package/common.js.map +1 -1
- package/complex.cjs +1 -1
- package/complex.cjs.map +1 -1
- package/complex.js +56 -33
- package/complex.js.map +1 -1
- package/cookie.cjs +1 -1
- package/cookie.cjs.map +1 -1
- package/cookie.js +7 -2
- package/cookie.js.map +1 -1
- package/css.cjs +1 -1
- package/css.cjs.map +1 -1
- package/css.js +41 -20
- package/css.js.map +1 -1
- package/data.cjs +1 -1
- package/data.cjs.map +1 -1
- package/data.js +35 -25
- package/data.js.map +1 -1
- package/date-time.cjs +1 -1
- package/date-time.cjs.map +1 -1
- package/date-time.d.ts.map +1 -1
- package/date-time.js +332 -250
- package/date-time.js.map +1 -1
- package/device.cjs +1 -1
- package/device.cjs.map +1 -1
- package/device.js +27 -18
- package/device.js.map +1 -1
- package/encodings.cjs +1 -1
- package/encodings.cjs.map +1 -1
- package/encodings.js +10 -10
- package/encodings.js.map +1 -1
- package/errors.cjs +1 -1
- package/errors.cjs.map +1 -1
- package/errors.d.ts.map +1 -1
- package/errors.js +21 -6
- package/errors.js.map +1 -1
- package/file.cjs +1 -1
- package/file.cjs.map +1 -1
- package/file.js +26 -17
- package/file.js.map +1 -1
- package/format/percent.d.ts +2 -2
- package/format/percent.d.ts.map +1 -1
- package/format.cjs +1 -1
- package/format.cjs.map +1 -1
- package/format.js +66 -42
- package/format.js.map +1 -1
- package/html.cjs +1 -1
- package/html.cjs.map +1 -1
- package/html.d.ts +1 -1
- package/html.d.ts.map +1 -1
- package/html.js +111 -68
- package/html.js.map +1 -1
- package/id.cjs +1 -2
- package/id.cjs.map +1 -1
- package/id.js +23 -13
- package/id.js.map +1 -1
- package/imports.cjs +1 -1
- package/imports.cjs.map +1 -1
- package/imports.js +27 -18
- package/imports.js.map +1 -1
- package/math.cjs +1 -1
- package/math.cjs.map +1 -1
- package/math.js +10 -8
- package/math.js.map +1 -1
- package/media.cjs +1 -1
- package/media.cjs.map +1 -1
- package/media.js +94 -49
- package/media.js.map +1 -1
- package/mobx/deep-observable-struct.d.ts.map +1 -1
- package/mobx.cjs +1 -1
- package/mobx.cjs.map +1 -1
- package/mobx.js +123 -68
- package/mobx.js.map +1 -1
- package/ms.cjs +1 -1
- package/ms.cjs.map +1 -1
- package/ms.js +9 -8
- package/ms.js.map +1 -1
- package/number.cjs +1 -1
- package/number.cjs.map +1 -1
- package/number.js +7 -6
- package/number.js.map +1 -1
- package/package.json +34 -33
- package/parser.cjs +1 -1
- package/parser.cjs.map +1 -1
- package/parser.js +64 -10
- package/parser.js.map +1 -1
- package/price.cjs +1 -1
- package/price.cjs.map +1 -1
- package/price.js +14 -7
- package/price.js.map +1 -1
- package/random.cjs +1 -1
- package/random.cjs.map +1 -1
- package/random.js +22 -9
- package/random.js.map +1 -1
- package/react.cjs +1 -1
- package/react.cjs.map +1 -1
- package/react.js +195 -130
- package/react.js.map +1 -1
- package/sound.cjs +1 -1
- package/sound.cjs.map +1 -1
- package/sound.js +8 -4
- package/sound.js.map +1 -1
- package/text.cjs +1 -1
- package/text.cjs.map +1 -1
- package/text.js +30 -14
- package/text.js.map +1 -1
- package/type-guard.cjs +1 -1
- package/type-guard.cjs.map +1 -1
- package/type-guard.js +93 -2
- package/type-guard.js.map +1 -1
- package/utility-types.d.ts +4 -0
- package/utils/types.d.ts +4 -0
- package/utils/types.d.ts.map +1 -1
- package/vibrate.cjs +1 -1
- package/vibrate.cjs.map +1 -1
- package/vibrate.js +5 -3
- package/vibrate.js.map +1 -1
- package/~constants-CFexlSUS.js +0 -7
- package/~constants-CFexlSUS.js.map +0 -1
- package/~constants-HmaulHpr.js +0 -2
- package/~constants-HmaulHpr.js.map +0 -1
- package/~index-C3wKHvHr.js +0 -80
- package/~index-C3wKHvHr.js.map +0 -1
- package/~index-PKNbSTT-.js +0 -2
- package/~index-PKNbSTT-.js.map +0 -1
- package/~number-B1MpW9GU.js +0 -2
- package/~number-B1MpW9GU.js.map +0 -1
- package/~number-EWff2XI6.js +0 -25
- package/~number-EWff2XI6.js.map +0 -1
package/parser.js
CHANGED
|
@@ -1,15 +1,69 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { typeGuard
|
|
3
|
-
const
|
|
4
|
-
const
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
import { format } from "yummies/format";
|
|
2
|
+
import { typeGuard } from "yummies/type-guard";
|
|
3
|
+
const number = (input, userSettings) => {
|
|
4
|
+
const settings = {
|
|
5
|
+
...number.defaultSettings,
|
|
6
|
+
...userSettings
|
|
7
|
+
};
|
|
8
|
+
const fallback = settings?.fallback ?? 0;
|
|
9
|
+
let result;
|
|
10
|
+
if (typeGuard.isNumber(input)) {
|
|
11
|
+
result = input;
|
|
12
|
+
} else if (typeGuard.isString(input)) {
|
|
13
|
+
const formattedInput = format.skipSpaces(input).replace(",", ".");
|
|
14
|
+
if (formattedInput === "") {
|
|
15
|
+
result = fallback;
|
|
16
|
+
} else {
|
|
17
|
+
result = Number(formattedInput);
|
|
18
|
+
}
|
|
19
|
+
} else {
|
|
20
|
+
result = fallback;
|
|
21
|
+
}
|
|
22
|
+
if (typeGuard.isNumber(result)) {
|
|
23
|
+
if (settings?.clamped != null) {
|
|
24
|
+
result = Math.max(
|
|
25
|
+
settings.clamped[0] ?? -Infinity,
|
|
26
|
+
Math.min(result, settings.clamped[1] ?? Infinity)
|
|
27
|
+
);
|
|
28
|
+
}
|
|
29
|
+
if (settings?.ceil != null) {
|
|
30
|
+
result = Math.ceil(result);
|
|
31
|
+
}
|
|
32
|
+
if (settings?.floor != null) {
|
|
33
|
+
result = Math.floor(result);
|
|
34
|
+
}
|
|
35
|
+
if (settings?.digits != null) {
|
|
36
|
+
result = +result.toFixed(settings.digits);
|
|
37
|
+
}
|
|
38
|
+
return result;
|
|
39
|
+
} else {
|
|
40
|
+
return fallback;
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
number.defaultSettings = {};
|
|
44
|
+
const percent = (value, maxValue, settings) => {
|
|
45
|
+
return number(Number(value) / Number(maxValue) * 100, settings);
|
|
46
|
+
};
|
|
47
|
+
const string = (input, settings) => {
|
|
48
|
+
const fallback = settings && "fallback" in settings ? settings.fallback : "";
|
|
49
|
+
if (input == null) {
|
|
50
|
+
return fallback;
|
|
51
|
+
}
|
|
52
|
+
if (typeGuard.isObject(input)) {
|
|
53
|
+
if (settings?.prettyJson) {
|
|
54
|
+
return JSON.stringify(input, null, 2);
|
|
55
|
+
}
|
|
56
|
+
return JSON.stringify(input);
|
|
57
|
+
}
|
|
58
|
+
return String(input);
|
|
59
|
+
};
|
|
60
|
+
const _exports = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
7
61
|
__proto__: null,
|
|
8
|
-
number
|
|
9
|
-
percent
|
|
10
|
-
string
|
|
62
|
+
number,
|
|
63
|
+
percent,
|
|
64
|
+
string
|
|
11
65
|
}, Symbol.toStringTag, { value: "Module" }));
|
|
12
66
|
export {
|
|
13
|
-
|
|
67
|
+
_exports as parser
|
|
14
68
|
};
|
|
15
69
|
//# sourceMappingURL=parser.js.map
|
package/parser.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parser.js","sources":["../src/parser/percent.ts","../src/parser/string.ts"],"sourcesContent":["import type { Maybe } from 'yummies/utils/types';\n\nimport { type NumberParserSettings, number } from './number.js';\n\nexport const percent = <TFallback = number>(\n value: Maybe<string | number>,\n maxValue?: Maybe<string | number>,\n settings?: Maybe<NumberParserSettings<TFallback>>,\n) => {\n return number<TFallback>((Number(value) / Number(maxValue)) * 100, settings);\n};\n","import { typeGuard } from 'yummies/type-guard';\nimport type { Maybe } from 'yummies/utils/types';\n\nexport interface StringParserSettings<TFallback = string> {\n fallback?: TFallback;\n prettyJson?: boolean;\n}\n\nexport const string = <TFallback = string>(\n input: Maybe<unknown>,\n settings?: Maybe<StringParserSettings<TFallback>>,\n): string | TFallback => {\n const fallback =\n settings && 'fallback' in settings ? (settings.fallback as TFallback) : '';\n\n if (input == null) {\n return fallback;\n }\n\n if (typeGuard.isObject(input)) {\n if (settings?.prettyJson) {\n return JSON.stringify(input, null, 2);\n }\n\n return JSON.stringify(input);\n }\n\n return String(input);\n};\n"],"names":[
|
|
1
|
+
{"version":3,"file":"parser.js","sources":["../src/parser/number.ts","../src/parser/percent.ts","../src/parser/string.ts"],"sourcesContent":["import { format } from 'yummies/format';\nimport { typeGuard } from 'yummies/type-guard';\nimport type { Maybe } from 'yummies/utils/types';\n\nexport interface NumberParserSettings<TFallback = number> {\n digits?: number;\n fallback?: TFallback;\n /**\n * Round to upper boundary\n * 5.1 -> 6\n */\n ceil?: boolean;\n /**\n * Round to bottom boundary\n * 5.9 -> 5\n */\n floor?: boolean;\n clamped?: [min?: Maybe<number>, max?: Maybe<number>];\n}\n\nexport const number = <TFallback = number>(\n input: Maybe<unknown>,\n userSettings?: Maybe<NumberParserSettings<TFallback>>,\n): number | TFallback => {\n const settings = {\n ...number.defaultSettings,\n ...userSettings,\n };\n\n const fallback = settings?.fallback ?? 0;\n\n let result: number;\n\n if (typeGuard.isNumber(input)) {\n result = input;\n } else if (typeGuard.isString(input)) {\n const formattedInput = format.skipSpaces(input).replace(',', '.');\n if (formattedInput === '') {\n result = fallback as any;\n } else {\n result = Number(formattedInput);\n }\n } else {\n result = fallback as any;\n }\n\n if (typeGuard.isNumber(result)) {\n if (settings?.clamped != null) {\n result = Math.max(\n settings.clamped[0] ?? -Infinity,\n Math.min(result, settings.clamped[1] ?? Infinity),\n );\n }\n\n if (settings?.ceil != null) {\n result = Math.ceil(result);\n }\n\n if (settings?.floor != null) {\n result = Math.floor(result);\n }\n\n if (settings?.digits != null) {\n result = +result.toFixed(settings.digits);\n }\n\n return result;\n } else {\n return fallback;\n }\n};\n\nnumber.defaultSettings = {} as NumberParserSettings;\n","import type { Maybe } from 'yummies/utils/types';\n\nimport { type NumberParserSettings, number } from './number.js';\n\nexport const percent = <TFallback = number>(\n value: Maybe<string | number>,\n maxValue?: Maybe<string | number>,\n settings?: Maybe<NumberParserSettings<TFallback>>,\n) => {\n return number<TFallback>((Number(value) / Number(maxValue)) * 100, settings);\n};\n","import { typeGuard } from 'yummies/type-guard';\nimport type { Maybe } from 'yummies/utils/types';\n\nexport interface StringParserSettings<TFallback = string> {\n fallback?: TFallback;\n prettyJson?: boolean;\n}\n\nexport const string = <TFallback = string>(\n input: Maybe<unknown>,\n settings?: Maybe<StringParserSettings<TFallback>>,\n): string | TFallback => {\n const fallback =\n settings && 'fallback' in settings ? (settings.fallback as TFallback) : '';\n\n if (input == null) {\n return fallback;\n }\n\n if (typeGuard.isObject(input)) {\n if (settings?.prettyJson) {\n return JSON.stringify(input, null, 2);\n }\n\n return JSON.stringify(input);\n }\n\n return String(input);\n};\n"],"names":[],"mappings":";;AAoBO,MAAM,SAAS,CACpB,OACA,iBACuB;AACvB,QAAM,WAAW;AAAA,IACf,GAAG,OAAO;AAAA,IACV,GAAG;AAAA,EAAA;AAGL,QAAM,WAAW,UAAU,YAAY;AAEvC,MAAI;AAEJ,MAAI,UAAU,SAAS,KAAK,GAAG;AAC7B,aAAS;AAAA,EACX,WAAW,UAAU,SAAS,KAAK,GAAG;AACpC,UAAM,iBAAiB,OAAO,WAAW,KAAK,EAAE,QAAQ,KAAK,GAAG;AAChE,QAAI,mBAAmB,IAAI;AACzB,eAAS;AAAA,IACX,OAAO;AACL,eAAS,OAAO,cAAc;AAAA,IAChC;AAAA,EACF,OAAO;AACL,aAAS;AAAA,EACX;AAEA,MAAI,UAAU,SAAS,MAAM,GAAG;AAC9B,QAAI,UAAU,WAAW,MAAM;AAC7B,eAAS,KAAK;AAAA,QACZ,SAAS,QAAQ,CAAC,KAAK;AAAA,QACvB,KAAK,IAAI,QAAQ,SAAS,QAAQ,CAAC,KAAK,QAAQ;AAAA,MAAA;AAAA,IAEpD;AAEA,QAAI,UAAU,QAAQ,MAAM;AAC1B,eAAS,KAAK,KAAK,MAAM;AAAA,IAC3B;AAEA,QAAI,UAAU,SAAS,MAAM;AAC3B,eAAS,KAAK,MAAM,MAAM;AAAA,IAC5B;AAEA,QAAI,UAAU,UAAU,MAAM;AAC5B,eAAS,CAAC,OAAO,QAAQ,SAAS,MAAM;AAAA,IAC1C;AAEA,WAAO;AAAA,EACT,OAAO;AACL,WAAO;AAAA,EACT;AACF;AAEA,OAAO,kBAAkB,CAAA;ACpElB,MAAM,UAAU,CACrB,OACA,UACA,aACG;AACH,SAAO,OAAmB,OAAO,KAAK,IAAI,OAAO,QAAQ,IAAK,KAAK,QAAQ;AAC7E;ACFO,MAAM,SAAS,CACpB,OACA,aACuB;AACvB,QAAM,WACJ,YAAY,cAAc,WAAY,SAAS,WAAyB;AAE1E,MAAI,SAAS,MAAM;AACjB,WAAO;AAAA,EACT;AAEA,MAAI,UAAU,SAAS,KAAK,GAAG;AAC7B,QAAI,UAAU,YAAY;AACxB,aAAO,KAAK,UAAU,OAAO,MAAM,CAAC;AAAA,IACtC;AAEA,WAAO,KAAK,UAAU,KAAK;AAAA,EAC7B;AAEA,SAAO,OAAO,KAAK;AACrB;;;;;;;"}
|
package/price.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});exports.formatPrice=(r,e,t,{withoutSymbol:o,customSymbol:c,...m}={})=>{const a=new Intl.NumberFormat(e,{style:"currency",currency:t,minimumFractionDigits:0,currencyDisplay:"narrowSymbol",...m}),l=a.format(0).replace("0",""),n=a.format(r).replace(l,"");return o?n:`${n} ${c??("RUB"===t?"р":l)}`.replace(/\s{2,}/," ")};
|
|
2
2
|
//# sourceMappingURL=price.cjs.map
|
package/price.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"price.cjs","sources":["../src/price.ts"],"sourcesContent":["export interface PriceFormatOptions\n extends Partial<Omit<Intl.NumberFormatOptions, 'currency'>> {\n withoutSymbol?: boolean;\n customSymbol?: string;\n}\n\nexport const formatPrice = (\n price: number,\n locale: string,\n currency?: string,\n { withoutSymbol, customSymbol, ...options }: PriceFormatOptions = {},\n) => {\n const priceFormatter = new Intl.NumberFormat(locale, {\n style: 'currency',\n currency,\n minimumFractionDigits: 0,\n currencyDisplay: 'narrowSymbol',\n ...options,\n });\n\n const zeroPrice = priceFormatter.format(0);\n const currencySymbol = zeroPrice.replace('0', '');\n const rawPrice = priceFormatter.format(price);\n const priceWithoutCurrency = rawPrice.replace(currencySymbol, '');\n\n if (withoutSymbol) {\n return priceWithoutCurrency;\n }\n\n return `${priceWithoutCurrency} ${\n customSymbol ?? (currency === 'RUB' ? 'р' : currencySymbol)\n }`.replace(/\\s{2,}/, ' ');\n};\n"],"names":["
|
|
1
|
+
{"version":3,"file":"price.cjs","sources":["../src/price.ts"],"sourcesContent":["export interface PriceFormatOptions\n extends Partial<Omit<Intl.NumberFormatOptions, 'currency'>> {\n withoutSymbol?: boolean;\n customSymbol?: string;\n}\n\nexport const formatPrice = (\n price: number,\n locale: string,\n currency?: string,\n { withoutSymbol, customSymbol, ...options }: PriceFormatOptions = {},\n) => {\n const priceFormatter = new Intl.NumberFormat(locale, {\n style: 'currency',\n currency,\n minimumFractionDigits: 0,\n currencyDisplay: 'narrowSymbol',\n ...options,\n });\n\n const zeroPrice = priceFormatter.format(0);\n const currencySymbol = zeroPrice.replace('0', '');\n const rawPrice = priceFormatter.format(price);\n const priceWithoutCurrency = rawPrice.replace(currencySymbol, '');\n\n if (withoutSymbol) {\n return priceWithoutCurrency;\n }\n\n return `${priceWithoutCurrency} ${\n customSymbol ?? (currency === 'RUB' ? 'р' : currencySymbol)\n }`.replace(/\\s{2,}/, ' ');\n};\n"],"names":["price","locale","currency","withoutSymbol","customSymbol","options","priceFormatter","Intl","NumberFormat","style","minimumFractionDigits","currencyDisplay","currencySymbol","format","replace","priceWithoutCurrency"],"mappings":"oGAM2B,CACzBA,EACAC,EACAC,GACEC,gBAAeC,kBAAiBC,GAAgC,MAElE,MAAMC,EAAiB,IAAIC,KAAKC,aAAaP,EAAQ,CACnDQ,MAAO,WACPP,WACAQ,sBAAuB,EACvBC,gBAAiB,kBACdN,IAICO,EADYN,EAAeO,OAAO,GACPC,QAAQ,IAAK,IAExCC,EADWT,EAAeO,OAAOb,GACDc,QAAQF,EAAgB,IAE9D,OAAIT,EACKY,EAGF,GAAGA,KACRX,IAA8B,QAAbF,EAAqB,IAAMU,KAC3CE,QAAQ,SAAU"}
|
package/price.js
CHANGED
|
@@ -1,14 +1,21 @@
|
|
|
1
|
-
const
|
|
2
|
-
const
|
|
1
|
+
const formatPrice = (price, locale, currency, { withoutSymbol, customSymbol, ...options } = {}) => {
|
|
2
|
+
const priceFormatter = new Intl.NumberFormat(locale, {
|
|
3
3
|
style: "currency",
|
|
4
|
-
currency
|
|
4
|
+
currency,
|
|
5
5
|
minimumFractionDigits: 0,
|
|
6
6
|
currencyDisplay: "narrowSymbol",
|
|
7
|
-
...
|
|
8
|
-
})
|
|
9
|
-
|
|
7
|
+
...options
|
|
8
|
+
});
|
|
9
|
+
const zeroPrice = priceFormatter.format(0);
|
|
10
|
+
const currencySymbol = zeroPrice.replace("0", "");
|
|
11
|
+
const rawPrice = priceFormatter.format(price);
|
|
12
|
+
const priceWithoutCurrency = rawPrice.replace(currencySymbol, "");
|
|
13
|
+
if (withoutSymbol) {
|
|
14
|
+
return priceWithoutCurrency;
|
|
15
|
+
}
|
|
16
|
+
return `${priceWithoutCurrency} ${customSymbol ?? (currency === "RUB" ? "р" : currencySymbol)}`.replace(/\s{2,}/, " ");
|
|
10
17
|
};
|
|
11
18
|
export {
|
|
12
|
-
|
|
19
|
+
formatPrice
|
|
13
20
|
};
|
|
14
21
|
//# sourceMappingURL=price.js.map
|
package/price.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"price.js","sources":["../src/price.ts"],"sourcesContent":["export interface PriceFormatOptions\n extends Partial<Omit<Intl.NumberFormatOptions, 'currency'>> {\n withoutSymbol?: boolean;\n customSymbol?: string;\n}\n\nexport const formatPrice = (\n price: number,\n locale: string,\n currency?: string,\n { withoutSymbol, customSymbol, ...options }: PriceFormatOptions = {},\n) => {\n const priceFormatter = new Intl.NumberFormat(locale, {\n style: 'currency',\n currency,\n minimumFractionDigits: 0,\n currencyDisplay: 'narrowSymbol',\n ...options,\n });\n\n const zeroPrice = priceFormatter.format(0);\n const currencySymbol = zeroPrice.replace('0', '');\n const rawPrice = priceFormatter.format(price);\n const priceWithoutCurrency = rawPrice.replace(currencySymbol, '');\n\n if (withoutSymbol) {\n return priceWithoutCurrency;\n }\n\n return `${priceWithoutCurrency} ${\n customSymbol ?? (currency === 'RUB' ? 'р' : currencySymbol)\n }`.replace(/\\s{2,}/, ' ');\n};\n"],"names":[
|
|
1
|
+
{"version":3,"file":"price.js","sources":["../src/price.ts"],"sourcesContent":["export interface PriceFormatOptions\n extends Partial<Omit<Intl.NumberFormatOptions, 'currency'>> {\n withoutSymbol?: boolean;\n customSymbol?: string;\n}\n\nexport const formatPrice = (\n price: number,\n locale: string,\n currency?: string,\n { withoutSymbol, customSymbol, ...options }: PriceFormatOptions = {},\n) => {\n const priceFormatter = new Intl.NumberFormat(locale, {\n style: 'currency',\n currency,\n minimumFractionDigits: 0,\n currencyDisplay: 'narrowSymbol',\n ...options,\n });\n\n const zeroPrice = priceFormatter.format(0);\n const currencySymbol = zeroPrice.replace('0', '');\n const rawPrice = priceFormatter.format(price);\n const priceWithoutCurrency = rawPrice.replace(currencySymbol, '');\n\n if (withoutSymbol) {\n return priceWithoutCurrency;\n }\n\n return `${priceWithoutCurrency} ${\n customSymbol ?? (currency === 'RUB' ? 'р' : currencySymbol)\n }`.replace(/\\s{2,}/, ' ');\n};\n"],"names":[],"mappings":"AAMO,MAAM,cAAc,CACzB,OACA,QACA,UACA,EAAE,eAAe,cAAc,GAAG,QAAA,IAAgC,OAC/D;AACH,QAAM,iBAAiB,IAAI,KAAK,aAAa,QAAQ;AAAA,IACnD,OAAO;AAAA,IACP;AAAA,IACA,uBAAuB;AAAA,IACvB,iBAAiB;AAAA,IACjB,GAAG;AAAA,EAAA,CACJ;AAED,QAAM,YAAY,eAAe,OAAO,CAAC;AACzC,QAAM,iBAAiB,UAAU,QAAQ,KAAK,EAAE;AAChD,QAAM,WAAW,eAAe,OAAO,KAAK;AAC5C,QAAM,uBAAuB,SAAS,QAAQ,gBAAgB,EAAE;AAEhE,MAAI,eAAe;AACjB,WAAO;AAAA,EACT;AAEA,SAAO,GAAG,oBAAoB,IAC5B,iBAAiB,aAAa,QAAQ,MAAM,eAC9C,GAAG,QAAQ,UAAU,GAAG;AAC1B;"}
|
package/random.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=(o=0,e=1)=>Math.random()*(e-o)+o,e=(e=0,t=1)=>e===t?e:Math.round(o(e,t)),t=()=>e(0,10)<=6;exports.getFrequencyValue=o=>Math.random()<o,exports.getMajorRandomBool=t,exports.getMinorRandomBool=()=>!t(),exports.getRandomBool=()=>1===e(0,1),exports.getRandomChoice=o=>o[e(0,o.length-1)],exports.getRandomFloat=o,exports.getRandomInt=e,exports.getRandomSizeArray=(o=0,t=10)=>Array.from({length:e(o,t)}).fill(null);
|
|
2
2
|
//# sourceMappingURL=random.cjs.map
|
package/random.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"random.cjs","sources":["../src/random.ts"],"sourcesContent":["export const getRandomFloat = <T extends number = number>(\n min = 0,\n max = 1,\n): T => (Math.random() * (max - min) + min) as T;\n\nexport const getRandomInt = <T extends number = number>(min = 0, max = 1): T =>\n min === max ? (min as T) : (Math.round(getRandomFloat(min, max)) as T);\n\nexport const getRandomChoice = <T>(arr: T[]): T =>\n arr[getRandomInt(0, arr.length - 1)];\n\nexport const getRandomSizeArray = (min = 0, max = 10) =>\n Array.from({ length: getRandomInt(min, max) }).fill(null);\n\nexport const getRandomBool = () => getRandomInt(0, 1) === 1;\n\nexport const getMajorRandomBool = () => {\n return getRandomInt(0, 10) <= 6;\n};\n\nexport const getMinorRandomBool = () => {\n return !getMajorRandomBool();\n};\n\nexport const getFrequencyValue = (frequency: number) => {\n return Math.random() < frequency;\n};\n"],"names":["getRandomFloat","min","max","getRandomInt","
|
|
1
|
+
{"version":3,"file":"random.cjs","sources":["../src/random.ts"],"sourcesContent":["export const getRandomFloat = <T extends number = number>(\n min = 0,\n max = 1,\n): T => (Math.random() * (max - min) + min) as T;\n\nexport const getRandomInt = <T extends number = number>(min = 0, max = 1): T =>\n min === max ? (min as T) : (Math.round(getRandomFloat(min, max)) as T);\n\nexport const getRandomChoice = <T>(arr: T[]): T =>\n arr[getRandomInt(0, arr.length - 1)];\n\nexport const getRandomSizeArray = (min = 0, max = 10) =>\n Array.from({ length: getRandomInt(min, max) }).fill(null);\n\nexport const getRandomBool = () => getRandomInt(0, 1) === 1;\n\nexport const getMajorRandomBool = () => {\n return getRandomInt(0, 10) <= 6;\n};\n\nexport const getMinorRandomBool = () => {\n return !getMajorRandomBool();\n};\n\nexport const getFrequencyValue = (frequency: number) => {\n return Math.random() < frequency;\n};\n"],"names":["getRandomFloat","min","max","Math","random","getRandomInt","round","getMajorRandomBool","frequency","arr","length","Array","from","fill"],"mappings":"gFAAO,MAAMA,EAAiB,CAC5BC,EAAM,EACNC,EAAM,IACCC,KAAKC,UAAYF,EAAMD,GAAOA,EAE1BI,EAAe,CAA4BJ,EAAM,EAAGC,EAAM,IACrED,IAAQC,EAAOD,EAAaE,KAAKG,MAAMN,EAAeC,EAAKC,IAUhDK,EAAqB,IACzBF,EAAa,EAAG,KAAO,4BAOEG,GACzBL,KAAKC,SAAWI,0DALS,KACxBD,0BAPmB,IAA6B,IAAvBF,EAAa,EAAG,2BANhBI,GACjCA,EAAIJ,EAAa,EAAGI,EAAIC,OAAS,+EAED,CAACT,EAAM,EAAGC,EAAM,KAChDS,MAAMC,KAAK,CAAEF,OAAQL,EAAaJ,EAAKC,KAAQW,KAAK"}
|
package/random.js
CHANGED
|
@@ -1,12 +1,25 @@
|
|
|
1
|
-
const
|
|
1
|
+
const getRandomFloat = (min = 0, max = 1) => Math.random() * (max - min) + min;
|
|
2
|
+
const getRandomInt = (min = 0, max = 1) => min === max ? min : Math.round(getRandomFloat(min, max));
|
|
3
|
+
const getRandomChoice = (arr) => arr[getRandomInt(0, arr.length - 1)];
|
|
4
|
+
const getRandomSizeArray = (min = 0, max = 10) => Array.from({ length: getRandomInt(min, max) }).fill(null);
|
|
5
|
+
const getRandomBool = () => getRandomInt(0, 1) === 1;
|
|
6
|
+
const getMajorRandomBool = () => {
|
|
7
|
+
return getRandomInt(0, 10) <= 6;
|
|
8
|
+
};
|
|
9
|
+
const getMinorRandomBool = () => {
|
|
10
|
+
return !getMajorRandomBool();
|
|
11
|
+
};
|
|
12
|
+
const getFrequencyValue = (frequency) => {
|
|
13
|
+
return Math.random() < frequency;
|
|
14
|
+
};
|
|
2
15
|
export {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
16
|
+
getFrequencyValue,
|
|
17
|
+
getMajorRandomBool,
|
|
18
|
+
getMinorRandomBool,
|
|
19
|
+
getRandomBool,
|
|
20
|
+
getRandomChoice,
|
|
21
|
+
getRandomFloat,
|
|
22
|
+
getRandomInt,
|
|
23
|
+
getRandomSizeArray
|
|
11
24
|
};
|
|
12
25
|
//# sourceMappingURL=random.js.map
|
package/random.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"random.js","sources":["../src/random.ts"],"sourcesContent":["export const getRandomFloat = <T extends number = number>(\n min = 0,\n max = 1,\n): T => (Math.random() * (max - min) + min) as T;\n\nexport const getRandomInt = <T extends number = number>(min = 0, max = 1): T =>\n min === max ? (min as T) : (Math.round(getRandomFloat(min, max)) as T);\n\nexport const getRandomChoice = <T>(arr: T[]): T =>\n arr[getRandomInt(0, arr.length - 1)];\n\nexport const getRandomSizeArray = (min = 0, max = 10) =>\n Array.from({ length: getRandomInt(min, max) }).fill(null);\n\nexport const getRandomBool = () => getRandomInt(0, 1) === 1;\n\nexport const getMajorRandomBool = () => {\n return getRandomInt(0, 10) <= 6;\n};\n\nexport const getMinorRandomBool = () => {\n return !getMajorRandomBool();\n};\n\nexport const getFrequencyValue = (frequency: number) => {\n return Math.random() < frequency;\n};\n"],"names":[
|
|
1
|
+
{"version":3,"file":"random.js","sources":["../src/random.ts"],"sourcesContent":["export const getRandomFloat = <T extends number = number>(\n min = 0,\n max = 1,\n): T => (Math.random() * (max - min) + min) as T;\n\nexport const getRandomInt = <T extends number = number>(min = 0, max = 1): T =>\n min === max ? (min as T) : (Math.round(getRandomFloat(min, max)) as T);\n\nexport const getRandomChoice = <T>(arr: T[]): T =>\n arr[getRandomInt(0, arr.length - 1)];\n\nexport const getRandomSizeArray = (min = 0, max = 10) =>\n Array.from({ length: getRandomInt(min, max) }).fill(null);\n\nexport const getRandomBool = () => getRandomInt(0, 1) === 1;\n\nexport const getMajorRandomBool = () => {\n return getRandomInt(0, 10) <= 6;\n};\n\nexport const getMinorRandomBool = () => {\n return !getMajorRandomBool();\n};\n\nexport const getFrequencyValue = (frequency: number) => {\n return Math.random() < frequency;\n};\n"],"names":[],"mappings":"AAAO,MAAM,iBAAiB,CAC5B,MAAM,GACN,MAAM,MACC,KAAK,OAAA,KAAY,MAAM,OAAO;AAEhC,MAAM,eAAe,CAA4B,MAAM,GAAG,MAAM,MACrE,QAAQ,MAAO,MAAa,KAAK,MAAM,eAAe,KAAK,GAAG,CAAC;AAE1D,MAAM,kBAAkB,CAAI,QACjC,IAAI,aAAa,GAAG,IAAI,SAAS,CAAC,CAAC;AAE9B,MAAM,qBAAqB,CAAC,MAAM,GAAG,MAAM,OAChD,MAAM,KAAK,EAAE,QAAQ,aAAa,KAAK,GAAG,GAAG,EAAE,KAAK,IAAI;AAEnD,MAAM,gBAAgB,MAAM,aAAa,GAAG,CAAC,MAAM;AAEnD,MAAM,qBAAqB,MAAM;AACtC,SAAO,aAAa,GAAG,EAAE,KAAK;AAChC;AAEO,MAAM,qBAAqB,MAAM;AACtC,SAAO,CAAC,mBAAA;AACV;AAEO,MAAM,oBAAoB,CAAC,cAAsB;AACtD,SAAO,KAAK,WAAW;AACzB;"}
|
package/react.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react"),t=t=>{const r=e.useRef();return r.current||(r.current={value:t()}),r.current.value},r=()=>{const r=t(()=>new AbortController);return e.useEffect(()=>()=>{r.abort()},[]),r},s=()=>r().signal,n=t=>{const r=e.useRef(t);return r.current=t,r},u=({event:t,handler:r,options:s,deps:u=[],node:o=document})=>{const c=n(r);e.useEffect(()=>{const e=e=>c.current(e);return o.addEventListener(t,e,s),()=>o.removeEventListener(t,e,s)},u)},o=t=>{const r=e.useRef(void 0);return r.current||(r.current=t()),r},c=r=>(n,u)=>{const o=s(),c=t(()=>n({...r,abortSignal:o,payload:u?.payload}));return e.useLayoutEffect(()=>{u?.onUpdate?.(u.payload)},[u?.payload]),c},a=c();exports.createUseInstanceHook=c,exports.useAbortController=r,exports.useAbortSignal=s,exports.useClickOutside=({contentRef:e,onClick:t,options:r})=>{u({event:"mousedown",handler:r=>{e.current&&!e.current.contains(r.target)&&t()},options:r})},exports.useConstant=t,exports.useDefineRef=o,exports.useElementRef=t=>{const r=e.useRef();return e.useLayoutEffect(()=>{r.current=t()},[]),r},exports.useEvent=t=>{const r=e.useRef(t);return e.useLayoutEffect(()=>{r.current=t}),e.useCallback((...e)=>(0,r.current)(...e),[])},exports.useEventListener=u,exports.useFlag=(t=!1)=>{const[r,s]=e.useState(t),n=e.useCallback(()=>s(e=>!e),[]),u=e.useCallback(()=>s(!0),[]),o=e.useCallback(()=>s(!1),[]),c=e.useRef({enabled:r,toggle:n,enable:u,disable:o});return c.current.enabled=r,c.current},exports.useForceUpdate=()=>{const[,t]=e.useState(null);return e.useCallback(()=>{t({})},[])},exports.useInitialHeight=()=>{const t=e.useRef(null),[r,s]=e.useState(void 0);return e.useEffect(()=>{t.current&&!r&&s(t.current.offsetHeight)},[r]),{ref:t,initialHeight:r}},exports.useInstance=a,exports.useIntersectionObserver=(t,r)=>{const[s]=e.useState(()=>new IntersectionObserver(t,r));return e.useEffect(()=>()=>{s.disconnect()},[]),s},exports.useLastDefinedValue=t=>{const r=e.useRef(t);return null!=t&&(r.current=t),r.current},exports.useLastValueRef=t=>{const r=e.useRef(t);return null!=t&&(r.current=t),r},exports.useLifeCycle=t=>{const r=n(t);e.useEffect(()=>{const e=r.current();return e.mount?.(),e.unmount?.()},[])},exports.useResizeObserver=t=>{const r=o(()=>new ResizeObserver(t));return e.useLayoutEffect(()=>()=>{r.current.disconnect()},[]),r},exports.useSyncRef=n,exports.useToggle=t=>{const[r,s]=e.useState(!!t);return[r,e.useCallback(()=>s(e=>!e),[]),s]},exports.useValue=t=>{const[r,s]=e.useState(t);return{value:r,set:s}},exports.useVisibilityState=()=>{const[t,r]=e.useState();return e.useEffect(()=>{const e=()=>{r(document.visibilityState)};return document.addEventListener("visibilitychange",e),()=>{document.removeEventListener("visibilitychange",e)}},[]),t};
|
|
2
2
|
//# sourceMappingURL=react.cjs.map
|
package/react.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"react.cjs","sources":["../src/react/hooks/use-constant.ts","../src/react/hooks/use-abort-controller.ts","../src/react/hooks/use-abort-signal.ts","../src/react/hooks/use-sync-ref.ts","../src/react/hooks/use-event-listener.ts","../src/react/hooks/use-click-outside.ts","../src/react/hooks/use-define-ref.ts","../src/react/hooks/use-element-ref.ts","../src/react/hooks/use-event.ts","../src/react/hooks/use-flag.ts","../src/react/hooks/use-force-update.ts","../src/react/hooks/use-initial-height.ts","../src/react/hooks/use-instance.ts","../src/react/hooks/use-intersection-observer.ts","../src/react/hooks/use-last-defined-value.ts","../src/react/hooks/use-last-value-ref.ts","../src/react/hooks/use-life-cycle.ts","../src/react/hooks/use-resize-observer.ts","../src/react/hooks/use-toggle.ts","../src/react/hooks/use-value.ts","../src/react/hooks/use-visibility-state.ts"],"sourcesContent":["import { useRef } from 'react';\n\n/**\n * React hook for creating a value exactly once.\n * useMemo doesn't give this guarantee unfortunately -\n * https://reactjs.org/docs/hooks-faq.html#how-to-create-expensive-objects-lazily\n * https://reactjs.org/docs/hooks-reference.html#usememo\n * @param defineValue Function which returns defined value.\n */\nexport const useConstant = <T>(defineValue: () => T): T => {\n const ref = useRef<{ value: T }>();\n\n if (!ref.current) {\n ref.current = { value: defineValue() };\n }\n\n return ref.current.value;\n};\n","import { useEffect } from 'react';\n\nimport { useConstant } from './use-constant.js';\n\nexport const useAbortController = () => {\n const controller = useConstant(() => new AbortController());\n\n useEffect(() => {\n return () => {\n controller.abort();\n };\n }, []);\n\n return controller;\n};\n","import { useAbortController } from './use-abort-controller.js';\n\nexport const useAbortSignal = () => {\n return useAbortController().signal;\n};\n","import { useRef } from 'react';\n\nexport const useSyncRef = <T>(value: T) => {\n const ref = useRef(value);\n ref.current = value;\n return ref;\n};\n","/* eslint-disable @typescript-eslint/ban-ts-comment */\nimport { useEffect } from 'react';\nimport { useSyncRef } from './use-sync-ref.js';\n\nexport const useEventListener = <EventName extends keyof HTMLElementEventMap>({\n event,\n handler,\n options,\n deps = [],\n node = document,\n}: {\n event: EventName;\n handler: (e: HTMLElementEventMap[EventName]) => void;\n options?: boolean | AddEventListenerOptions;\n deps?: unknown[];\n node?: HTMLElement | Document | Window;\n}) => {\n const handlerRef = useSyncRef(handler);\n\n useEffect(() => {\n const handleEvent = (e: HTMLElementEventMap[EventName]) =>\n handlerRef.current(e);\n\n // @ts-expect-error\n node.addEventListener(event, handleEvent, options);\n // @ts-expect-error\n return () => node.removeEventListener(event, handleEvent, options);\n }, deps);\n};\n","import type { MutableRefObject } from 'react';\nimport { useEventListener } from './use-event-listener.js';\n\ntype ClickOutsideInput = {\n contentRef: MutableRefObject<HTMLElement | null>;\n onClick: VoidFunction;\n options?: AddEventListenerOptions;\n};\n\nexport const useClickOutside = ({\n contentRef,\n onClick,\n options,\n}: ClickOutsideInput) => {\n useEventListener({\n event: 'mousedown',\n handler: (event) => {\n if (\n contentRef.current &&\n !contentRef.current.contains(event.target as Node)\n ) {\n onClick();\n }\n },\n options,\n });\n};\n","import { type MutableRefObject, useRef } from 'react';\n\n/**\n * React hook for creating a value exactly once.\n * useMemo doesn't give this guarantee unfortunately -\n * https://reactjs.org/docs/hooks-faq.html#how-to-create-expensive-objects-lazily\n * https://reactjs.org/docs/hooks-reference.html#usememo\n * @param defineFn Function which returns defined value.\n */\nexport const useDefineRef = <T>(defineFn: () => T): MutableRefObject<T> => {\n const ref = useRef<T>(void 0 as T);\n\n if (!ref.current) {\n ref.current = defineFn();\n }\n\n return ref;\n};\n","import { useLayoutEffect, useRef } from 'react';\n\nexport const useElementRef = <T extends HTMLElement>(selector: () => T) => {\n const ref = useRef<T>();\n\n useLayoutEffect(() => {\n ref.current = selector();\n }, []);\n\n return ref;\n};\n","/**\n * A Hook to define an event handler with an always-stable function identity.\n *\n * borrowed from @gaeron\n * https://github.com/reactjs/rfcs/blob/useevent/text/0000-useevent.md\n */\nimport { useCallback, useLayoutEffect, useRef } from 'react';\nimport type { AnyFunction } from 'yummies/utils/types';\n\nexport const useEvent = <H extends AnyFunction>(handler: H): H => {\n const handlerRef = useRef<H>(handler);\n\n // In a real implementation, this would run before layout effects\n useLayoutEffect(() => {\n handlerRef.current = handler;\n });\n\n return useCallback((...args: unknown[]) => {\n // In a real implementation, this would throw if called during render\n const fn = handlerRef.current as AnyFunction;\n return fn(...args);\n }, []) as unknown as H;\n};\n","import { useCallback, useRef, useState } from 'react';\n\nexport interface FlagHook {\n enabled: boolean;\n toggle: VoidFunction;\n enable: VoidFunction;\n disable: VoidFunction;\n}\n\nexport const useFlag = (defaultValue = false): FlagHook => {\n const [enabled, setEnabled] = useState(defaultValue);\n\n const toggle = useCallback(() => setEnabled((value) => !value), []);\n const enable = useCallback(() => setEnabled(true), []);\n const disable = useCallback(() => setEnabled(false), []);\n\n const flagObjRef = useRef<FlagHook>({\n enabled,\n toggle,\n enable,\n disable,\n });\n\n flagObjRef.current.enabled = enabled;\n\n return flagObjRef.current;\n};\n","import { useCallback, useState } from 'react';\n\nexport const useForceUpdate = () => {\n const [, setState] = useState<unknown>(null);\n\n return useCallback(() => {\n setState({});\n }, []);\n};\n","import { useEffect, useRef, useState } from 'react';\n\nexport const useInitialHeight = <T extends HTMLElement>() => {\n const ref = useRef<T | null>(null);\n const [initialHeight, setInitialHeight] = useState<number | undefined>(\n undefined,\n );\n\n useEffect(() => {\n if (ref.current && !initialHeight) {\n setInitialHeight(ref.current.offsetHeight);\n }\n }, [initialHeight]);\n\n return { ref, initialHeight };\n};\n","import { useLayoutEffect } from 'react';\nimport { useAbortSignal } from './use-abort-signal.js';\nimport { useConstant } from './use-constant.js';\n\nexport type InstanceCreateConfig<TPayload, TExtension = {}> = TExtension & {\n abortSignal: AbortSignal;\n payload: TPayload;\n};\n\nexport const createUseInstanceHook =\n <TExtension = {}>(extension?: TExtension) =>\n <TInstance, TPayload>(\n factory: (\n config: InstanceCreateConfig<NoInfer<TPayload>, TExtension>,\n ) => TInstance,\n config?: {\n payload?: TPayload;\n onUpdate?: (payload: TPayload) => void;\n },\n ) => {\n const abortSignal = useAbortSignal();\n\n const instance = useConstant(() =>\n factory({\n ...(extension as TExtension),\n abortSignal,\n payload: config?.payload as any,\n }),\n );\n\n useLayoutEffect(() => {\n config?.onUpdate?.(config.payload!);\n }, [config?.payload]);\n\n return instance;\n };\n\n/**\n * The `useInstance` hook is used to create and manage an instance of an object\n * that requires access to the root store and an abort signal.\n *\n * You can create YOUR OWN CUSTOM `useInstance` hook using `createUseInstanceHook` if you need\n * to provide some specific data\n *\n * @param factory - A factory function that takes a configuration and returns an instance.\n * @param config - An optional configuration containing additional input parameters and an update function.\n * @returns An instance created by the factory function.\n */\nexport const useInstance = createUseInstanceHook();\n","import { useEffect, useState } from 'react';\n\nexport const useIntersectionObserver = (\n callback: IntersectionObserverCallback,\n options?: IntersectionObserverInit,\n) => {\n const [intersectionObserver] = useState(\n () => new IntersectionObserver(callback, options),\n );\n\n useEffect(() => {\n return () => {\n intersectionObserver.disconnect();\n };\n }, []);\n\n return intersectionObserver;\n};\n","import { useRef } from 'react';\n\nexport const useLastDefinedValue = <T>(value: T) => {\n const ref = useRef(value);\n if (value != null) {\n ref.current = value;\n }\n return ref.current;\n};\n","import { useRef } from 'react';\n\nexport const useLastValueRef = <T>(value: T | null | undefined) => {\n const ref = useRef(value);\n\n if (value != null) {\n ref.current = value;\n }\n\n return ref;\n};\n","import { useEffect } from 'react';\nimport { useSyncRef } from './use-sync-ref.js';\n\nexport const useLifeCycle = (\n fn: () => {\n mount?: VoidFunction;\n unmount?: VoidFunction;\n },\n) => {\n const fnRef = useSyncRef(fn);\n\n useEffect(() => {\n const fnOperation = fnRef.current();\n fnOperation.mount?.();\n return fnOperation.unmount?.();\n }, []);\n};\n","import { useLayoutEffect } from 'react';\nimport { useDefineRef } from './use-define-ref.js';\n\nexport const useResizeObserver = (callback: ResizeObserverCallback) => {\n const resizeObserverRef = useDefineRef(() => new ResizeObserver(callback));\n\n useLayoutEffect(() => {\n return () => {\n resizeObserverRef.current.disconnect();\n };\n }, []);\n\n return resizeObserverRef;\n};\n","import { useCallback, useState } from 'react';\n\nexport const useToggle = (initialState?: boolean) => {\n const [toggled, setToggled] = useState(!!initialState);\n\n const toggle = useCallback(() => setToggled((toggled) => !toggled), []);\n\n return [toggled, toggle, setToggled] as const;\n};\n","import { useState } from 'react';\n\nexport const useValue = <T>(defaults: T | (() => T)) => {\n const [value, setValue] = useState<T>(defaults);\n\n return {\n value,\n set: setValue,\n };\n};\n","import { useEffect, useState } from 'react';\n\nexport const useVisibilityState = () => {\n const [state, setState] = useState<DocumentVisibilityState>();\n\n useEffect(() => {\n const handleVisibilityChange = () => {\n setState(document.visibilityState);\n };\n\n document.addEventListener('visibilitychange', handleVisibilityChange);\n\n return () => {\n document.removeEventListener('visibilitychange', handleVisibilityChange);\n };\n }, []);\n\n return state;\n};\n"],"names":["useConstant","defineValue","ref","useRef","useAbortController","controller","useEffect","useAbortSignal","useSyncRef","value","useEventListener","event","handler","options","deps","node","handlerRef","handleEvent","e","useClickOutside","contentRef","onClick","useDefineRef","defineFn","useElementRef","selector","useLayoutEffect","useEvent","useCallback","args","fn","useFlag","defaultValue","enabled","setEnabled","useState","toggle","enable","disable","flagObjRef","useForceUpdate","setState","useInitialHeight","initialHeight","setInitialHeight","createUseInstanceHook","extension","factory","config","abortSignal","instance","useInstance","useIntersectionObserver","callback","intersectionObserver","useLastDefinedValue","useLastValueRef","useLifeCycle","fnRef","fnOperation","useResizeObserver","resizeObserverRef","useToggle","initialState","toggled","setToggled","useValue","defaults","setValue","useVisibilityState","state","handleVisibilityChange"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"react.cjs","sources":["../src/react/hooks/use-constant.ts","../src/react/hooks/use-abort-controller.ts","../src/react/hooks/use-abort-signal.ts","../src/react/hooks/use-sync-ref.ts","../src/react/hooks/use-event-listener.ts","../src/react/hooks/use-define-ref.ts","../src/react/hooks/use-instance.ts","../src/react/hooks/use-click-outside.ts","../src/react/hooks/use-element-ref.ts","../src/react/hooks/use-event.ts","../src/react/hooks/use-flag.ts","../src/react/hooks/use-force-update.ts","../src/react/hooks/use-initial-height.ts","../src/react/hooks/use-intersection-observer.ts","../src/react/hooks/use-last-defined-value.ts","../src/react/hooks/use-last-value-ref.ts","../src/react/hooks/use-life-cycle.ts","../src/react/hooks/use-resize-observer.ts","../src/react/hooks/use-toggle.ts","../src/react/hooks/use-value.ts","../src/react/hooks/use-visibility-state.ts"],"sourcesContent":["import { useRef } from 'react';\n\n/**\n * React hook for creating a value exactly once.\n * useMemo doesn't give this guarantee unfortunately -\n * https://reactjs.org/docs/hooks-faq.html#how-to-create-expensive-objects-lazily\n * https://reactjs.org/docs/hooks-reference.html#usememo\n * @param defineValue Function which returns defined value.\n */\nexport const useConstant = <T>(defineValue: () => T): T => {\n const ref = useRef<{ value: T }>();\n\n if (!ref.current) {\n ref.current = { value: defineValue() };\n }\n\n return ref.current.value;\n};\n","import { useEffect } from 'react';\n\nimport { useConstant } from './use-constant.js';\n\nexport const useAbortController = () => {\n const controller = useConstant(() => new AbortController());\n\n useEffect(() => {\n return () => {\n controller.abort();\n };\n }, []);\n\n return controller;\n};\n","import { useAbortController } from './use-abort-controller.js';\n\nexport const useAbortSignal = () => {\n return useAbortController().signal;\n};\n","import { useRef } from 'react';\n\nexport const useSyncRef = <T>(value: T) => {\n const ref = useRef(value);\n ref.current = value;\n return ref;\n};\n","/* eslint-disable @typescript-eslint/ban-ts-comment */\nimport { useEffect } from 'react';\nimport { useSyncRef } from './use-sync-ref.js';\n\nexport const useEventListener = <EventName extends keyof HTMLElementEventMap>({\n event,\n handler,\n options,\n deps = [],\n node = document,\n}: {\n event: EventName;\n handler: (e: HTMLElementEventMap[EventName]) => void;\n options?: boolean | AddEventListenerOptions;\n deps?: unknown[];\n node?: HTMLElement | Document | Window;\n}) => {\n const handlerRef = useSyncRef(handler);\n\n useEffect(() => {\n const handleEvent = (e: HTMLElementEventMap[EventName]) =>\n handlerRef.current(e);\n\n // @ts-expect-error\n node.addEventListener(event, handleEvent, options);\n // @ts-expect-error\n return () => node.removeEventListener(event, handleEvent, options);\n }, deps);\n};\n","import { type MutableRefObject, useRef } from 'react';\n\n/**\n * React hook for creating a value exactly once.\n * useMemo doesn't give this guarantee unfortunately -\n * https://reactjs.org/docs/hooks-faq.html#how-to-create-expensive-objects-lazily\n * https://reactjs.org/docs/hooks-reference.html#usememo\n * @param defineFn Function which returns defined value.\n */\nexport const useDefineRef = <T>(defineFn: () => T): MutableRefObject<T> => {\n const ref = useRef<T>(void 0 as T);\n\n if (!ref.current) {\n ref.current = defineFn();\n }\n\n return ref;\n};\n","import { useLayoutEffect } from 'react';\nimport { useAbortSignal } from './use-abort-signal.js';\nimport { useConstant } from './use-constant.js';\n\nexport type InstanceCreateConfig<TPayload, TExtension = {}> = TExtension & {\n abortSignal: AbortSignal;\n payload: TPayload;\n};\n\nexport const createUseInstanceHook =\n <TExtension = {}>(extension?: TExtension) =>\n <TInstance, TPayload>(\n factory: (\n config: InstanceCreateConfig<NoInfer<TPayload>, TExtension>,\n ) => TInstance,\n config?: {\n payload?: TPayload;\n onUpdate?: (payload: TPayload) => void;\n },\n ) => {\n const abortSignal = useAbortSignal();\n\n const instance = useConstant(() =>\n factory({\n ...(extension as TExtension),\n abortSignal,\n payload: config?.payload as any,\n }),\n );\n\n useLayoutEffect(() => {\n config?.onUpdate?.(config.payload!);\n }, [config?.payload]);\n\n return instance;\n };\n\n/**\n * The `useInstance` hook is used to create and manage an instance of an object\n * that requires access to the root store and an abort signal.\n *\n * You can create YOUR OWN CUSTOM `useInstance` hook using `createUseInstanceHook` if you need\n * to provide some specific data\n *\n * @param factory - A factory function that takes a configuration and returns an instance.\n * @param config - An optional configuration containing additional input parameters and an update function.\n * @returns An instance created by the factory function.\n */\nexport const useInstance = createUseInstanceHook();\n","import type { MutableRefObject } from 'react';\nimport { useEventListener } from './use-event-listener.js';\n\ntype ClickOutsideInput = {\n contentRef: MutableRefObject<HTMLElement | null>;\n onClick: VoidFunction;\n options?: AddEventListenerOptions;\n};\n\nexport const useClickOutside = ({\n contentRef,\n onClick,\n options,\n}: ClickOutsideInput) => {\n useEventListener({\n event: 'mousedown',\n handler: (event) => {\n if (\n contentRef.current &&\n !contentRef.current.contains(event.target as Node)\n ) {\n onClick();\n }\n },\n options,\n });\n};\n","import { useLayoutEffect, useRef } from 'react';\n\nexport const useElementRef = <T extends HTMLElement>(selector: () => T) => {\n const ref = useRef<T>();\n\n useLayoutEffect(() => {\n ref.current = selector();\n }, []);\n\n return ref;\n};\n","/**\n * A Hook to define an event handler with an always-stable function identity.\n *\n * borrowed from @gaeron\n * https://github.com/reactjs/rfcs/blob/useevent/text/0000-useevent.md\n */\nimport { useCallback, useLayoutEffect, useRef } from 'react';\nimport type { AnyFunction } from 'yummies/utils/types';\n\nexport const useEvent = <H extends AnyFunction>(handler: H): H => {\n const handlerRef = useRef<H>(handler);\n\n // In a real implementation, this would run before layout effects\n useLayoutEffect(() => {\n handlerRef.current = handler;\n });\n\n return useCallback((...args: unknown[]) => {\n // In a real implementation, this would throw if called during render\n const fn = handlerRef.current as AnyFunction;\n return fn(...args);\n }, []) as unknown as H;\n};\n","import { useCallback, useRef, useState } from 'react';\n\nexport interface FlagHook {\n enabled: boolean;\n toggle: VoidFunction;\n enable: VoidFunction;\n disable: VoidFunction;\n}\n\nexport const useFlag = (defaultValue = false): FlagHook => {\n const [enabled, setEnabled] = useState(defaultValue);\n\n const toggle = useCallback(() => setEnabled((value) => !value), []);\n const enable = useCallback(() => setEnabled(true), []);\n const disable = useCallback(() => setEnabled(false), []);\n\n const flagObjRef = useRef<FlagHook>({\n enabled,\n toggle,\n enable,\n disable,\n });\n\n flagObjRef.current.enabled = enabled;\n\n return flagObjRef.current;\n};\n","import { useCallback, useState } from 'react';\n\nexport const useForceUpdate = () => {\n const [, setState] = useState<unknown>(null);\n\n return useCallback(() => {\n setState({});\n }, []);\n};\n","import { useEffect, useRef, useState } from 'react';\n\nexport const useInitialHeight = <T extends HTMLElement>() => {\n const ref = useRef<T | null>(null);\n const [initialHeight, setInitialHeight] = useState<number | undefined>(\n undefined,\n );\n\n useEffect(() => {\n if (ref.current && !initialHeight) {\n setInitialHeight(ref.current.offsetHeight);\n }\n }, [initialHeight]);\n\n return { ref, initialHeight };\n};\n","import { useEffect, useState } from 'react';\n\nexport const useIntersectionObserver = (\n callback: IntersectionObserverCallback,\n options?: IntersectionObserverInit,\n) => {\n const [intersectionObserver] = useState(\n () => new IntersectionObserver(callback, options),\n );\n\n useEffect(() => {\n return () => {\n intersectionObserver.disconnect();\n };\n }, []);\n\n return intersectionObserver;\n};\n","import { useRef } from 'react';\n\nexport const useLastDefinedValue = <T>(value: T) => {\n const ref = useRef(value);\n if (value != null) {\n ref.current = value;\n }\n return ref.current;\n};\n","import { useRef } from 'react';\n\nexport const useLastValueRef = <T>(value: T | null | undefined) => {\n const ref = useRef(value);\n\n if (value != null) {\n ref.current = value;\n }\n\n return ref;\n};\n","import { useEffect } from 'react';\nimport { useSyncRef } from './use-sync-ref.js';\n\nexport const useLifeCycle = (\n fn: () => {\n mount?: VoidFunction;\n unmount?: VoidFunction;\n },\n) => {\n const fnRef = useSyncRef(fn);\n\n useEffect(() => {\n const fnOperation = fnRef.current();\n fnOperation.mount?.();\n return fnOperation.unmount?.();\n }, []);\n};\n","import { useLayoutEffect } from 'react';\nimport { useDefineRef } from './use-define-ref.js';\n\nexport const useResizeObserver = (callback: ResizeObserverCallback) => {\n const resizeObserverRef = useDefineRef(() => new ResizeObserver(callback));\n\n useLayoutEffect(() => {\n return () => {\n resizeObserverRef.current.disconnect();\n };\n }, []);\n\n return resizeObserverRef;\n};\n","import { useCallback, useState } from 'react';\n\nexport const useToggle = (initialState?: boolean) => {\n const [toggled, setToggled] = useState(!!initialState);\n\n const toggle = useCallback(() => setToggled((toggled) => !toggled), []);\n\n return [toggled, toggle, setToggled] as const;\n};\n","import { useState } from 'react';\n\nexport const useValue = <T>(defaults: T | (() => T)) => {\n const [value, setValue] = useState<T>(defaults);\n\n return {\n value,\n set: setValue,\n };\n};\n","import { useEffect, useState } from 'react';\n\nexport const useVisibilityState = () => {\n const [state, setState] = useState<DocumentVisibilityState>();\n\n useEffect(() => {\n const handleVisibilityChange = () => {\n setState(document.visibilityState);\n };\n\n document.addEventListener('visibilitychange', handleVisibilityChange);\n\n return () => {\n document.removeEventListener('visibilitychange', handleVisibilityChange);\n };\n }, []);\n\n return state;\n};\n"],"names":["useConstant","defineValue","ref","useRef","current","value","useAbortController","controller","AbortController","useEffect","abort","useAbortSignal","signal","useSyncRef","useEventListener","event","handler","options","deps","node","document","handlerRef","handleEvent","e","addEventListener","removeEventListener","useDefineRef","defineFn","createUseInstanceHook","extension","factory","config","abortSignal","instance","payload","useLayoutEffect","onUpdate","useInstance","contentRef","onClick","contains","target","selector","useCallback","args","fn","defaultValue","enabled","setEnabled","useState","toggle","enable","disable","flagObjRef","setState","initialHeight","setInitialHeight","offsetHeight","callback","intersectionObserver","IntersectionObserver","disconnect","fnRef","fnOperation","mount","unmount","resizeObserverRef","ResizeObserver","initialState","toggled","setToggled","defaults","setValue","set","state","handleVisibilityChange","visibilityState"],"mappings":"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"}
|