@a-type/ui 2.0.10 → 2.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/colors.stories.d.ts +20 -1
- package/dist/cjs/colors.stories.js +30 -5
- package/dist/cjs/colors.stories.js.map +1 -1
- package/dist/cjs/components/emojiPicker/EmojiPicker.d.ts +28 -0
- package/dist/cjs/components/emojiPicker/EmojiPicker.js +79 -0
- package/dist/cjs/components/emojiPicker/EmojiPicker.js.map +1 -0
- package/dist/cjs/components/emojiPicker/EmojiPicker.stories.d.ts +25 -0
- package/dist/cjs/components/emojiPicker/EmojiPicker.stories.js +21 -0
- package/dist/cjs/components/emojiPicker/EmojiPicker.stories.js.map +1 -0
- package/dist/cjs/components/index.d.ts +1 -0
- package/dist/cjs/components/index.js +1 -0
- package/dist/cjs/components/index.js.map +1 -1
- package/dist/cjs/components/relativeTime/RelativeTime.d.ts +10 -1
- package/dist/cjs/components/relativeTime/RelativeTime.js +17 -9
- package/dist/cjs/components/relativeTime/RelativeTime.js.map +1 -1
- package/dist/cjs/components/relativeTime/RelativeTime.stories.d.ts +19 -0
- package/dist/cjs/components/relativeTime/RelativeTime.stories.js +20 -0
- package/dist/cjs/components/relativeTime/RelativeTime.stories.js.map +1 -0
- package/dist/cjs/hooks/useStorage.d.ts +2 -0
- package/dist/cjs/hooks/useStorage.js +80 -0
- package/dist/cjs/hooks/useStorage.js.map +1 -0
- package/dist/cjs/hooks/withProps.d.ts +5 -0
- package/dist/cjs/hooks/withProps.js +7 -1
- package/dist/cjs/hooks/withProps.js.map +1 -1
- package/dist/cjs/uno/colors.js +1 -1
- package/dist/css/main.css +34 -34
- package/dist/esm/colors.stories.d.ts +20 -1
- package/dist/esm/colors.stories.js +30 -5
- package/dist/esm/colors.stories.js.map +1 -1
- package/dist/esm/components/emojiPicker/EmojiPicker.d.ts +28 -0
- package/dist/esm/components/emojiPicker/EmojiPicker.js +68 -0
- package/dist/esm/components/emojiPicker/EmojiPicker.js.map +1 -0
- package/dist/esm/components/emojiPicker/EmojiPicker.stories.d.ts +25 -0
- package/dist/esm/components/emojiPicker/EmojiPicker.stories.js +18 -0
- package/dist/esm/components/emojiPicker/EmojiPicker.stories.js.map +1 -0
- package/dist/esm/components/index.d.ts +1 -0
- package/dist/esm/components/index.js +1 -0
- package/dist/esm/components/index.js.map +1 -1
- package/dist/esm/components/relativeTime/RelativeTime.d.ts +10 -1
- package/dist/esm/components/relativeTime/RelativeTime.js +17 -9
- package/dist/esm/components/relativeTime/RelativeTime.js.map +1 -1
- package/dist/esm/components/relativeTime/RelativeTime.stories.d.ts +19 -0
- package/dist/esm/components/relativeTime/RelativeTime.stories.js +17 -0
- package/dist/esm/components/relativeTime/RelativeTime.stories.js.map +1 -0
- package/dist/esm/hooks/useStorage.d.ts +2 -0
- package/dist/esm/hooks/useStorage.js +77 -0
- package/dist/esm/hooks/useStorage.js.map +1 -0
- package/dist/esm/hooks/withProps.d.ts +5 -0
- package/dist/esm/hooks/withProps.js +5 -0
- package/dist/esm/hooks/withProps.js.map +1 -1
- package/dist/esm/uno/colors.js +1 -1
- package/package.json +4 -2
- package/src/colors.stories.tsx +30 -4
- package/src/components/emojiPicker/EmojiPicker.stories.tsx +21 -0
- package/src/components/emojiPicker/EmojiPicker.tsx +170 -0
- package/src/components/index.ts +1 -0
- package/src/components/relativeTime/RelativeTime.stories.tsx +21 -0
- package/src/components/relativeTime/RelativeTime.tsx +32 -9
- package/src/hooks/useStorage.ts +107 -0
- package/src/hooks/withProps.tsx +12 -0
- package/src/uno/colors.ts +1 -1
|
@@ -1,7 +1,26 @@
|
|
|
1
1
|
import type { StoryObj } from '@storybook/react';
|
|
2
2
|
declare const meta: {
|
|
3
3
|
title: string;
|
|
4
|
-
argTypes: {
|
|
4
|
+
argTypes: {
|
|
5
|
+
customHue: {
|
|
6
|
+
control: {
|
|
7
|
+
type: "range";
|
|
8
|
+
min: number;
|
|
9
|
+
max: number;
|
|
10
|
+
};
|
|
11
|
+
};
|
|
12
|
+
customRotate: {
|
|
13
|
+
control: {
|
|
14
|
+
type: "range";
|
|
15
|
+
min: number;
|
|
16
|
+
max: number;
|
|
17
|
+
};
|
|
18
|
+
};
|
|
19
|
+
};
|
|
20
|
+
args: {
|
|
21
|
+
customHue: number;
|
|
22
|
+
customRotate: number;
|
|
23
|
+
};
|
|
5
24
|
parameters: {
|
|
6
25
|
controls: {
|
|
7
26
|
expanded: boolean;
|
|
@@ -3,15 +3,40 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
3
3
|
import { Box } from './components/index.js';
|
|
4
4
|
const meta = {
|
|
5
5
|
title: 'colors',
|
|
6
|
-
argTypes: {
|
|
6
|
+
argTypes: {
|
|
7
|
+
customHue: {
|
|
8
|
+
control: {
|
|
9
|
+
type: 'range',
|
|
10
|
+
min: 0,
|
|
11
|
+
max: 360,
|
|
12
|
+
},
|
|
13
|
+
},
|
|
14
|
+
customRotate: {
|
|
15
|
+
control: {
|
|
16
|
+
type: 'range',
|
|
17
|
+
min: -180,
|
|
18
|
+
max: 180,
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
args: {
|
|
23
|
+
customHue: 0,
|
|
24
|
+
customRotate: 0,
|
|
25
|
+
},
|
|
7
26
|
parameters: {
|
|
8
27
|
controls: { expanded: true },
|
|
9
28
|
},
|
|
10
29
|
};
|
|
11
30
|
export default meta;
|
|
12
31
|
export const Default = {
|
|
13
|
-
render() {
|
|
14
|
-
|
|
32
|
+
render(args) {
|
|
33
|
+
const style = args.customHue
|
|
34
|
+
? {
|
|
35
|
+
'--dyn-primary-source': args.customHue,
|
|
36
|
+
'--dyn-primary-hue-rotate': args.customRotate,
|
|
37
|
+
}
|
|
38
|
+
: {};
|
|
39
|
+
return (_jsxs(Box, { d: "col", children: [_jsx(Range, { className: "theme-lemon" }), _jsx(Range, { className: "theme-leek" }), _jsx(Range, { className: "theme-tomato" }), _jsx(Range, { className: "theme-eggplant" }), _jsx(Range, { className: "theme-blueberry" }), _jsx(Range, { className: "theme-salt" }), _jsx(Range, { className: "theme", style: style })] }));
|
|
15
40
|
},
|
|
16
41
|
};
|
|
17
42
|
function Swatch({ className }) {
|
|
@@ -20,7 +45,7 @@ function Swatch({ className }) {
|
|
|
20
45
|
height: '100px',
|
|
21
46
|
} }));
|
|
22
47
|
}
|
|
23
|
-
function Range({ className }) {
|
|
24
|
-
return (_jsxs(Box, { className: className, children: [_jsx(Swatch, { className: "bg-primary-wash" }), _jsx(Swatch, { className: "bg-primary-light" }), _jsx(Swatch, { className: "bg-primary" }), _jsx(Swatch, { className: "bg-primary-dark" }), _jsx(Swatch, { className: "bg-primary-ink" })] }));
|
|
48
|
+
function Range({ className, style }) {
|
|
49
|
+
return (_jsxs(Box, { className: className, style: style, children: [_jsx(Swatch, { className: "bg-primary-wash" }), _jsx(Swatch, { className: "bg-primary-light" }), _jsx(Swatch, { className: "bg-primary" }), _jsx(Swatch, { className: "bg-primary-dark" }), _jsx(Swatch, { className: "bg-primary-ink" })] }));
|
|
25
50
|
}
|
|
26
51
|
//# sourceMappingURL=colors.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"colors.stories.js","sourceRoot":"","sources":["../../src/colors.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,MAAM,uBAAuB,CAAC;AAE5C,MAAM,IAAI,GAAG;IACZ,KAAK,EAAE,QAAQ;IACf,QAAQ,EAAE,EAAE;
|
|
1
|
+
{"version":3,"file":"colors.stories.js","sourceRoot":"","sources":["../../src/colors.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,MAAM,uBAAuB,CAAC;AAE5C,MAAM,IAAI,GAAG;IACZ,KAAK,EAAE,QAAQ;IACf,QAAQ,EAAE;QACT,SAAS,EAAE;YACV,OAAO,EAAE;gBACR,IAAI,EAAE,OAAO;gBACb,GAAG,EAAE,CAAC;gBACN,GAAG,EAAE,GAAG;aACR;SACD;QACD,YAAY,EAAE;YACb,OAAO,EAAE;gBACR,IAAI,EAAE,OAAO;gBACb,GAAG,EAAE,CAAC,GAAG;gBACT,GAAG,EAAE,GAAG;aACR;SACD;KACD;IACD,IAAI,EAAE;QACL,SAAS,EAAE,CAAC;QACZ,YAAY,EAAE,CAAC;KACf;IACD,UAAU,EAAE;QACX,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE;KAC5B;CACc,CAAC;AAEjB,eAAe,IAAI,CAAC;AAIpB,MAAM,CAAC,MAAM,OAAO,GAAU;IAC7B,MAAM,CAAC,IAAS;QACf,MAAM,KAAK,GAAQ,IAAI,CAAC,SAAS;YAChC,CAAC,CAAC;gBACA,sBAAsB,EAAE,IAAI,CAAC,SAAS;gBACtC,0BAA0B,EAAE,IAAI,CAAC,YAAY;aAC5C;YACH,CAAC,CAAC,EAAE,CAAC;QACN,OAAO,CACN,MAAC,GAAG,IAAC,CAAC,EAAC,KAAK,aACX,KAAC,KAAK,IAAC,SAAS,EAAC,aAAa,GAAG,EACjC,KAAC,KAAK,IAAC,SAAS,EAAC,YAAY,GAAG,EAChC,KAAC,KAAK,IAAC,SAAS,EAAC,cAAc,GAAG,EAClC,KAAC,KAAK,IAAC,SAAS,EAAC,gBAAgB,GAAG,EACpC,KAAC,KAAK,IAAC,SAAS,EAAC,iBAAiB,GAAG,EACrC,KAAC,KAAK,IAAC,SAAS,EAAC,YAAY,GAAG,EAChC,KAAC,KAAK,IAAC,SAAS,EAAC,OAAO,EAAC,KAAK,EAAE,KAAK,GAAI,IACpC,CACN,CAAC;IACH,CAAC;CACD,CAAC;AAEF,SAAS,MAAM,CAAC,EAAE,SAAS,EAA0B;IACpD,OAAO,CACN,cACC,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE;YACN,KAAK,EAAE,OAAO;YACd,MAAM,EAAE,OAAO;SACf,GACA,CACF,CAAC;AACH,CAAC;AAED,SAAS,KAAK,CAAC,EAAE,SAAS,EAAE,KAAK,EAAuC;IACvE,OAAO,CACN,MAAC,GAAG,IAAC,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,KAAK,aACtC,KAAC,MAAM,IAAC,SAAS,EAAC,iBAAiB,GAAG,EACtC,KAAC,MAAM,IAAC,SAAS,EAAC,kBAAkB,GAAG,EACvC,KAAC,MAAM,IAAC,SAAS,EAAC,YAAY,GAAG,EACjC,KAAC,MAAM,IAAC,SAAS,EAAC,iBAAiB,GAAG,EACtC,KAAC,MAAM,IAAC,SAAS,EAAC,gBAAgB,GAAG,IAChC,CACN,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { EmojiPickerListCategoryHeaderProps, EmojiPickerListEmojiProps, EmojiPickerListProps, EmojiPickerRootProps, EmojiPickerViewportProps, useSkinTone } from 'frimousse';
|
|
2
|
+
import { BoxProps } from '../box/Box.js';
|
|
3
|
+
export declare const EmojiPickerRoot: import("react").FunctionComponent<Omit<EmojiPickerRootProps, "ref"> & import("react").RefAttributes<HTMLDivElement>>;
|
|
4
|
+
export declare const EmojiPickerSearch: import("react").FunctionComponent<Omit<import("react").DetailedHTMLProps<import("react").InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>, "ref"> & import("react").RefAttributes<HTMLInputElement>>;
|
|
5
|
+
export declare const EmojiPickerViewport: ({ className, ...props }: EmojiPickerViewportProps) => import("react/jsx-runtime").JSX.Element;
|
|
6
|
+
export declare const EmojiPickerLoading: import("react").FunctionComponent<import("react").ClassAttributes<HTMLSpanElement> & import("react").HTMLAttributes<HTMLSpanElement>>;
|
|
7
|
+
export declare const EmojiPickerEmpty: import("react").FunctionComponent<import("frimousse").EmojiPickerEmptyProps>;
|
|
8
|
+
export declare const EmojiPickerCategoryHeader: (props: EmojiPickerListCategoryHeaderProps) => import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
export declare const EmojiPickerRow: import("react").FunctionComponent<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>>;
|
|
10
|
+
export declare const EmojiPickerEmoji: import("react").FunctionComponent<EmojiPickerListEmojiProps>;
|
|
11
|
+
export declare const EmojiPickerList: ({ className, components, }: EmojiPickerListProps) => import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
export declare const useEmojiSkinTone: () => readonly [import("frimousse").SkinTone | undefined, (value: import("frimousse").SkinTone | ((current: import("frimousse").SkinTone | undefined) => import("frimousse").SkinTone | undefined) | undefined) => void];
|
|
13
|
+
export type SkinTone = ReturnType<typeof useSkinTone>[0];
|
|
14
|
+
export declare const EmojiPickerSkinToneSelector: (props: BoxProps) => import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
export interface EmojiPickerProps extends Omit<EmojiPickerRootProps, 'emoji' | 'onEmojiSelect'> {
|
|
16
|
+
onValueChange: (value: string, label: string) => void;
|
|
17
|
+
}
|
|
18
|
+
export declare const EmojiPicker: (({ onValueChange, ...props }: EmojiPickerProps) => import("react/jsx-runtime").JSX.Element) & {
|
|
19
|
+
Root: import("react").FunctionComponent<Omit<EmojiPickerRootProps, "ref"> & import("react").RefAttributes<HTMLDivElement>>;
|
|
20
|
+
Search: import("react").FunctionComponent<Omit<import("react").DetailedHTMLProps<import("react").InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>, "ref"> & import("react").RefAttributes<HTMLInputElement>>;
|
|
21
|
+
Viewport: ({ className, ...props }: EmojiPickerViewportProps) => import("react/jsx-runtime").JSX.Element;
|
|
22
|
+
List: ({ className, components, }: EmojiPickerListProps) => import("react/jsx-runtime").JSX.Element;
|
|
23
|
+
Loading: import("react").FunctionComponent<import("react").ClassAttributes<HTMLSpanElement> & import("react").HTMLAttributes<HTMLSpanElement>>;
|
|
24
|
+
Empty: import("react").FunctionComponent<import("frimousse").EmojiPickerEmptyProps>;
|
|
25
|
+
CategoryHeader: (props: EmojiPickerListCategoryHeaderProps) => import("react/jsx-runtime").JSX.Element;
|
|
26
|
+
Row: import("react").FunctionComponent<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>>;
|
|
27
|
+
Emoji: import("react").FunctionComponent<EmojiPickerListEmojiProps>;
|
|
28
|
+
};
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
// @unocss-include
|
|
2
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
3
|
+
var t = {};
|
|
4
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
5
|
+
t[p] = s[p];
|
|
6
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
7
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
8
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
9
|
+
t[p[i]] = s[p[i]];
|
|
10
|
+
}
|
|
11
|
+
return t;
|
|
12
|
+
};
|
|
13
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
14
|
+
import clsx from 'clsx';
|
|
15
|
+
import { EmojiPicker as Core, useSkinTone, } from 'frimousse';
|
|
16
|
+
import { withClassName, withProps } from '../../hooks.js';
|
|
17
|
+
import { useLocalStorage } from '../../hooks/useStorage.js';
|
|
18
|
+
import { Box } from '../box/Box.js';
|
|
19
|
+
import { Button } from '../button/Button.js';
|
|
20
|
+
import { inputClassName } from '../input/Input.js';
|
|
21
|
+
import { Spinner } from '../spinner/Spinner.js';
|
|
22
|
+
export const EmojiPickerRoot = withClassName(Core.Root, 'layer-components:isolate layer-components:flex layer-components:flex-col layer-components:w-fit layer-components:h-368px layer-components:bg-white layer-components:gap-sm');
|
|
23
|
+
export const EmojiPickerSearch = withClassName(Core.Search, 'layer-components:z-10', inputClassName);
|
|
24
|
+
export const EmojiPickerViewport = (_a) => {
|
|
25
|
+
var { className } = _a, props = __rest(_a, ["className"]);
|
|
26
|
+
return (_jsx(Box, { border: true, className: "flex-1 min-h-0 overflow-hidden", children: _jsx(Core.Viewport, Object.assign({ className: "layer-components:relative layer-components:outline-hidden" }, props)) }));
|
|
27
|
+
};
|
|
28
|
+
export const EmojiPickerLoading = withClassName(withProps(Core.Loading, {
|
|
29
|
+
children: _jsx(Spinner, {}),
|
|
30
|
+
}), 'layer-compoennts:absolute layer-compoennts:inset-0 layer-compoennts:flex layer-compoennts:items-center layer-compoennts:justify-center layer-compoennts:bg-inherit');
|
|
31
|
+
export const EmojiPickerEmpty = withClassName(withProps(Core.Empty, {
|
|
32
|
+
children: _jsx(_Fragment, { children: "No emoji found" }),
|
|
33
|
+
}), 'layer-components:absolute layer-components:inset-0 layer-components:flex layer-components:items-center layer-components:justify-center layer-components:bg-inherit layer-components:color-gray-dark layer-components:text-xs');
|
|
34
|
+
export const EmojiPickerCategoryHeader = (props) => (_jsx("div", { className: clsx('layer-components:bg-inherit layer-components:px-md layer-components:py-sm layer-components:text-xs layer-components:font-semibold layer-components:text-gray-dark layer-components:sticky layer-components:top-0', props.className), children: props.category.label }));
|
|
35
|
+
export const EmojiPickerRow = withClassName('div', 'layer-components:scroll-my-xs layer-components:px-xs');
|
|
36
|
+
export const EmojiPickerEmoji = withClassName((p) => (_jsx(Button, Object.assign({}, p, { color: "ghost", toggled: p.emoji.isActive, toggleMode: "color", size: "icon-small", "aria-label": p.emoji.label, className: "text-lg p-xs", children: p.emoji.emoji }))), '');
|
|
37
|
+
const defaultListComponents = {
|
|
38
|
+
CategoryHeader: EmojiPickerCategoryHeader,
|
|
39
|
+
Row: EmojiPickerRow,
|
|
40
|
+
Emoji: EmojiPickerEmoji,
|
|
41
|
+
};
|
|
42
|
+
export const EmojiPickerList = ({ className, components, }) => {
|
|
43
|
+
return (_jsx(Core.List, { className: clsx('layer-components:select-none layer-components:pb-md', className), components: components
|
|
44
|
+
? Object.assign(Object.assign({}, defaultListComponents), components) : defaultListComponents }));
|
|
45
|
+
};
|
|
46
|
+
export const useEmojiSkinTone = () => useLocalStorage('emoji-skin-tone', undefined, false);
|
|
47
|
+
export const EmojiPickerSkinToneSelector = (props) => {
|
|
48
|
+
const [_, __, options] = useSkinTone();
|
|
49
|
+
const [skinTone, setSkinTone] = useEmojiSkinTone();
|
|
50
|
+
return (_jsx(Box, Object.assign({ d: "row", gap: true, border: true }, props, { children: options.map((option) => (_jsx(Button, { color: "ghost", toggled: option.skinTone === skinTone, toggleMode: "color", size: "icon-small", "aria-label": `Skin tone ${option}`, className: "text-md p-xs", onClick: () => setSkinTone(option.skinTone), children: option.emoji }, option.skinTone))) })));
|
|
51
|
+
};
|
|
52
|
+
const EmojiPickerPrefab = (_a) => {
|
|
53
|
+
var { onValueChange } = _a, props = __rest(_a, ["onValueChange"]);
|
|
54
|
+
const [skinTone] = useEmojiSkinTone();
|
|
55
|
+
return (_jsxs(EmojiPickerRoot, Object.assign({}, props, { onEmojiSelect: (emoji) => onValueChange(emoji.emoji, emoji.label), skinTone: skinTone, children: [_jsx(EmojiPickerSearch, {}), _jsxs(EmojiPickerViewport, { children: [_jsx(EmojiPickerList, {}), _jsx(EmojiPickerLoading, {}), _jsx(EmojiPickerEmpty, {})] }), _jsx(EmojiPickerSkinToneSelector, { className: "mr-auto" })] })));
|
|
56
|
+
};
|
|
57
|
+
export const EmojiPicker = Object.assign(EmojiPickerPrefab, {
|
|
58
|
+
Root: EmojiPickerRoot,
|
|
59
|
+
Search: EmojiPickerSearch,
|
|
60
|
+
Viewport: EmojiPickerViewport,
|
|
61
|
+
List: EmojiPickerList,
|
|
62
|
+
Loading: EmojiPickerLoading,
|
|
63
|
+
Empty: EmojiPickerEmpty,
|
|
64
|
+
CategoryHeader: EmojiPickerCategoryHeader,
|
|
65
|
+
Row: EmojiPickerRow,
|
|
66
|
+
Emoji: EmojiPickerEmoji,
|
|
67
|
+
});
|
|
68
|
+
//# sourceMappingURL=EmojiPicker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EmojiPicker.js","sourceRoot":"","sources":["../../../../src/components/emojiPicker/EmojiPicker.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { StoryObj } from '@storybook/react';
|
|
2
|
+
import { EmojiPicker } from './EmojiPicker.js';
|
|
3
|
+
declare const meta: {
|
|
4
|
+
title: string;
|
|
5
|
+
component: (({ onValueChange, ...props }: import("./EmojiPicker.js").EmojiPickerProps) => import("react/jsx-runtime").JSX.Element) & {
|
|
6
|
+
Root: import("react").FunctionComponent<Omit<import("frimousse").EmojiPickerRootProps, "ref"> & import("react").RefAttributes<HTMLDivElement>>;
|
|
7
|
+
Search: import("react").FunctionComponent<Omit<import("react").DetailedHTMLProps<import("react").InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>, "ref"> & import("react").RefAttributes<HTMLInputElement>>;
|
|
8
|
+
Viewport: ({ className, ...props }: import("frimousse").EmojiPickerViewportProps) => import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
List: ({ className, components, }: import("frimousse").EmojiPickerListProps) => import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
Loading: import("react").FunctionComponent<import("react").ClassAttributes<HTMLSpanElement> & import("react").HTMLAttributes<HTMLSpanElement>>;
|
|
11
|
+
Empty: import("react").FunctionComponent<import("frimousse").EmojiPickerEmptyProps>;
|
|
12
|
+
CategoryHeader: (props: import("frimousse").EmojiPickerListCategoryHeaderProps) => import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
Row: import("react").FunctionComponent<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>>;
|
|
14
|
+
Emoji: import("react").FunctionComponent<import("frimousse").EmojiPickerListEmojiProps>;
|
|
15
|
+
};
|
|
16
|
+
argTypes: {};
|
|
17
|
+
parameters: {
|
|
18
|
+
controls: {
|
|
19
|
+
expanded: boolean;
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
};
|
|
23
|
+
export default meta;
|
|
24
|
+
type Story = StoryObj<typeof EmojiPicker>;
|
|
25
|
+
export declare const Default: Story;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// @unocss-include
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import { EmojiPicker } from './EmojiPicker.js';
|
|
4
|
+
const meta = {
|
|
5
|
+
title: 'EmojiPicker',
|
|
6
|
+
component: EmojiPicker,
|
|
7
|
+
argTypes: {},
|
|
8
|
+
parameters: {
|
|
9
|
+
controls: { expanded: true },
|
|
10
|
+
},
|
|
11
|
+
};
|
|
12
|
+
export default meta;
|
|
13
|
+
export const Default = {
|
|
14
|
+
render(args) {
|
|
15
|
+
return _jsx(EmojiPicker, Object.assign({}, args));
|
|
16
|
+
},
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=EmojiPicker.stories.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EmojiPicker.stories.js","sourceRoot":"","sources":["../../../../src/components/emojiPicker/EmojiPicker.stories.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE/C,MAAM,IAAI,GAAG;IACZ,KAAK,EAAE,aAAa;IACpB,SAAS,EAAE,WAAW;IACtB,QAAQ,EAAE,EAAE;IACZ,UAAU,EAAE;QACX,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE;KAC5B;CACkC,CAAC;AAErC,eAAe,IAAI,CAAC;AAIpB,MAAM,CAAC,MAAM,OAAO,GAAU;IAC7B,MAAM,CAAC,IAAI;QACV,OAAO,KAAC,WAAW,oBAAK,IAAI,EAAI,CAAC;IAClC,CAAC;CACD,CAAC"}
|
|
@@ -15,6 +15,7 @@ export * from './dialog/index.js';
|
|
|
15
15
|
export * from './divider/index.js';
|
|
16
16
|
export * from './dropdownMenu/index.js';
|
|
17
17
|
export * from './editableText/EditableText.js';
|
|
18
|
+
export * from './emojiPicker/EmojiPicker.js';
|
|
18
19
|
export * from './errorBoundary/index.js';
|
|
19
20
|
export * from './forms/index.js';
|
|
20
21
|
export * from './horizontalList/HorizontalList.js';
|
|
@@ -16,6 +16,7 @@ export * from './dialog/index.js';
|
|
|
16
16
|
export * from './divider/index.js';
|
|
17
17
|
export * from './dropdownMenu/index.js';
|
|
18
18
|
export * from './editableText/EditableText.js';
|
|
19
|
+
export * from './emojiPicker/EmojiPicker.js';
|
|
19
20
|
export * from './errorBoundary/index.js';
|
|
20
21
|
export * from './forms/index.js';
|
|
21
22
|
export * from './horizontalList/HorizontalList.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,SAAS,EAAkB,MAAM,sBAAsB,CAAC;AACvE,cAAc,oBAAoB,CAAC;AACnC,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,iBAAiB,CAAC;AAChC,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,wBAAwB,CAAC;AACvC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uBAAuB,CAAC;AACtC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,0BAA0B,CAAC;AACzC,cAAc,kBAAkB,CAAC;AACjC,cAAc,oCAAoC,CAAC;AACnD,cAAc,iBAAiB,CAAC;AAChC,cAAc,0BAA0B,CAAC;AACzC,cAAc,8CAA8C,CAAC;AAC7D,cAAc,kBAAkB,CAAC;AACjC,cAAc,oBAAoB,CAAC;AACnC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,sBAAsB,CAAC;AACrC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,iBAAiB,CAAC;AAChC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,iBAAiB,CAAC;AAChC,cAAc,oBAAoB,CAAC;AACnC,cAAc,wBAAwB,CAAC;AACvC,cAAc,wBAAwB,CAAC;AACvC,cAAc,yBAAyB,CAAC;AACxC,cAAc,uBAAuB,CAAC;AACtC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,mBAAmB,CAAC;AAClC,cAAc,0BAA0B,CAAC;AACzC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,oCAAoC,CAAC;AACnD,cAAc,sBAAsB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,SAAS,EAAkB,MAAM,sBAAsB,CAAC;AACvE,cAAc,oBAAoB,CAAC;AACnC,cAAc,mBAAmB,CAAC;AAClC,cAAc,cAAc,CAAC;AAC7B,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,iBAAiB,CAAC;AAChC,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,wBAAwB,CAAC;AACvC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uBAAuB,CAAC;AACtC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,yBAAyB,CAAC;AACxC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,8BAA8B,CAAC;AAC7C,cAAc,0BAA0B,CAAC;AACzC,cAAc,kBAAkB,CAAC;AACjC,cAAc,oCAAoC,CAAC;AACnD,cAAc,iBAAiB,CAAC;AAChC,cAAc,0BAA0B,CAAC;AACzC,cAAc,8CAA8C,CAAC;AAC7D,cAAc,kBAAkB,CAAC;AACjC,cAAc,oBAAoB,CAAC;AACnC,cAAc,gCAAgC,CAAC;AAC/C,cAAc,sBAAsB,CAAC;AACrC,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,iBAAiB,CAAC;AAChC,cAAc,0BAA0B,CAAC;AACzC,cAAc,sBAAsB,CAAC;AACrC,cAAc,iBAAiB,CAAC;AAChC,cAAc,oBAAoB,CAAC;AACnC,cAAc,wBAAwB,CAAC;AACvC,cAAc,wBAAwB,CAAC;AACvC,cAAc,yBAAyB,CAAC;AACxC,cAAc,uBAAuB,CAAC;AACtC,cAAc,4BAA4B,CAAC;AAC3C,cAAc,mBAAmB,CAAC;AAClC,cAAc,0BAA0B,CAAC;AACzC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,oBAAoB,CAAC;AACnC,cAAc,8BAA8B,CAAC;AAC7C,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,oCAAoC,CAAC;AACnD,cAAc,sBAAsB,CAAC"}
|
|
@@ -1,5 +1,14 @@
|
|
|
1
1
|
export interface RelativeTimeProps {
|
|
2
2
|
value: number;
|
|
3
3
|
abbreviate?: boolean;
|
|
4
|
+
/**
|
|
5
|
+
* Makes it count down seconds for a future date value as it approaches.
|
|
6
|
+
* Does not affect past dates.
|
|
7
|
+
*/
|
|
8
|
+
countdownSeconds?: boolean;
|
|
9
|
+
/**
|
|
10
|
+
* Remove "from now" or "ago" from the output.
|
|
11
|
+
*/
|
|
12
|
+
disableRelativeText?: boolean;
|
|
4
13
|
}
|
|
5
|
-
export declare function RelativeTime({ value, abbreviate }: RelativeTimeProps): import("react/jsx-runtime").JSX.Element;
|
|
14
|
+
export declare function RelativeTime({ value, abbreviate, countdownSeconds, disableRelativeText, }: RelativeTimeProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -2,31 +2,39 @@
|
|
|
2
2
|
'use client';
|
|
3
3
|
import { Fragment as _Fragment, jsx as _jsx } from "react/jsx-runtime";
|
|
4
4
|
import { shortenTimeUnits } from '@a-type/utils';
|
|
5
|
+
import { differenceInMinutes } from 'date-fns/differenceInMinutes';
|
|
5
6
|
import { formatDistanceToNowStrict } from 'date-fns/formatDistanceToNowStrict';
|
|
6
7
|
import { useEffect, useMemo, useState } from 'react';
|
|
7
|
-
function formatDistanceToNow(date) {
|
|
8
|
+
function formatDistanceToNow(date, relativeText = true) {
|
|
8
9
|
const now = Date.now();
|
|
9
10
|
if (Math.abs(date.getTime() - now) < 1000) {
|
|
10
11
|
return 'just now';
|
|
11
12
|
}
|
|
12
13
|
return (formatDistanceToNowStrict(date) +
|
|
13
|
-
(date.getTime() < now ? ' ago' : ' from now'));
|
|
14
|
+
(relativeText ? (date.getTime() < now ? ' ago' : ' from now') : ''));
|
|
14
15
|
}
|
|
15
|
-
export function RelativeTime({ value, abbreviate }) {
|
|
16
|
+
export function RelativeTime({ value, abbreviate, countdownSeconds, disableRelativeText, }) {
|
|
16
17
|
const asDate = useMemo(() => new Date(value), [value]);
|
|
17
18
|
const [time, setTime] = useState(() => abbreviate
|
|
18
|
-
? shortenTimeUnits(formatDistanceToNow(asDate))
|
|
19
|
-
: formatDistanceToNow(asDate));
|
|
19
|
+
? shortenTimeUnits(formatDistanceToNow(asDate, !disableRelativeText))
|
|
20
|
+
: formatDistanceToNow(asDate, !disableRelativeText));
|
|
21
|
+
// increase update rate if the date is less than 1 minute away and in the future
|
|
22
|
+
// (past is ok to just leave ~1 minute)
|
|
23
|
+
const updateRate = countdownSeconds &&
|
|
24
|
+
asDate.getTime() > Date.now() &&
|
|
25
|
+
Math.abs(differenceInMinutes(asDate, new Date())) < 1
|
|
26
|
+
? 1000
|
|
27
|
+
: 60 * 1000;
|
|
20
28
|
useEffect(() => {
|
|
21
29
|
const update = () => {
|
|
22
30
|
setTime(abbreviate
|
|
23
|
-
? shortenTimeUnits(formatDistanceToNow(asDate))
|
|
24
|
-
: formatDistanceToNow(asDate));
|
|
31
|
+
? shortenTimeUnits(formatDistanceToNow(asDate, !disableRelativeText))
|
|
32
|
+
: formatDistanceToNow(asDate, !disableRelativeText));
|
|
25
33
|
};
|
|
26
|
-
const interval = setInterval(update,
|
|
34
|
+
const interval = setInterval(update, updateRate);
|
|
27
35
|
update();
|
|
28
36
|
return () => clearInterval(interval);
|
|
29
|
-
}, [asDate, abbreviate]);
|
|
37
|
+
}, [asDate, abbreviate, updateRate, disableRelativeText]);
|
|
30
38
|
return _jsx(_Fragment, { children: time });
|
|
31
39
|
}
|
|
32
40
|
//# sourceMappingURL=RelativeTime.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"RelativeTime.js","sourceRoot":"","sources":["../../../../src/components/relativeTime/RelativeTime.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,yBAAyB,EAAE,MAAM,oCAAoC,CAAC;AAC/E,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"RelativeTime.js","sourceRoot":"","sources":["../../../../src/components/relativeTime/RelativeTime.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,yBAAyB,EAAE,MAAM,oCAAoC,CAAC;AAC/E,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAgBrD,SAAS,mBAAmB,CAAC,IAAU,EAAE,YAAY,GAAG,IAAI;IAC3D,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IACvB,IAAI,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,GAAG,CAAC,GAAG,IAAI,EAAE,CAAC;QAC3C,OAAO,UAAU,CAAC;IACnB,CAAC;IACD,OAAO,CACN,yBAAyB,CAAC,IAAI,CAAC;QAC/B,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CACnE,CAAC;AACH,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,EAC5B,KAAK,EACL,UAAU,EACV,gBAAgB,EAChB,mBAAmB,GACA;IACnB,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IACvD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,GAAG,EAAE,CACrC,UAAU;QACT,CAAC,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,MAAM,EAAE,CAAC,mBAAmB,CAAC,CAAC;QACrE,CAAC,CAAC,mBAAmB,CAAC,MAAM,EAAE,CAAC,mBAAmB,CAAC,CACpD,CAAC;IACF,gFAAgF;IAChF,uCAAuC;IACvC,MAAM,UAAU,GACf,gBAAgB;QAChB,MAAM,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE;QAC7B,IAAI,CAAC,GAAG,CAAC,mBAAmB,CAAC,MAAM,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC;QACpD,CAAC,CAAC,IAAI;QACN,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC;IAEd,SAAS,CAAC,GAAG,EAAE;QACd,MAAM,MAAM,GAAG,GAAG,EAAE;YACnB,OAAO,CACN,UAAU;gBACT,CAAC,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,MAAM,EAAE,CAAC,mBAAmB,CAAC,CAAC;gBACrE,CAAC,CAAC,mBAAmB,CAAC,MAAM,EAAE,CAAC,mBAAmB,CAAC,CACpD,CAAC;QACH,CAAC,CAAC;QACF,MAAM,QAAQ,GAAG,WAAW,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QACjD,MAAM,EAAE,CAAC;QACT,OAAO,GAAG,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;IACtC,CAAC,EAAE,CAAC,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,mBAAmB,CAAC,CAAC,CAAC;IAE1D,OAAO,4BAAG,IAAI,GAAI,CAAC;AACpB,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { StoryObj } from '@storybook/react';
|
|
2
|
+
import { RelativeTime } from './RelativeTime.js';
|
|
3
|
+
declare const meta: {
|
|
4
|
+
title: string;
|
|
5
|
+
component: typeof RelativeTime;
|
|
6
|
+
argTypes: {};
|
|
7
|
+
args: {
|
|
8
|
+
value: number;
|
|
9
|
+
abbreviate: false;
|
|
10
|
+
};
|
|
11
|
+
parameters: {
|
|
12
|
+
controls: {
|
|
13
|
+
expanded: boolean;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
};
|
|
17
|
+
export default meta;
|
|
18
|
+
type Story = StoryObj<typeof RelativeTime>;
|
|
19
|
+
export declare const Default: Story;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
// @unocss-include
|
|
2
|
+
import { RelativeTime } from './RelativeTime.js';
|
|
3
|
+
const meta = {
|
|
4
|
+
title: 'RelativeTime',
|
|
5
|
+
component: RelativeTime,
|
|
6
|
+
argTypes: {},
|
|
7
|
+
args: {
|
|
8
|
+
value: Date.now() + 60 * 1000 * 2,
|
|
9
|
+
abbreviate: false,
|
|
10
|
+
},
|
|
11
|
+
parameters: {
|
|
12
|
+
controls: { expanded: true },
|
|
13
|
+
},
|
|
14
|
+
};
|
|
15
|
+
export default meta;
|
|
16
|
+
export const Default = {};
|
|
17
|
+
//# sourceMappingURL=RelativeTime.stories.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RelativeTime.stories.js","sourceRoot":"","sources":["../../../../src/components/relativeTime/RelativeTime.stories.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD,MAAM,IAAI,GAAG;IACZ,KAAK,EAAE,cAAc;IACrB,SAAS,EAAE,YAAY;IACvB,QAAQ,EAAE,EAAE;IACZ,IAAI,EAAE;QACL,KAAK,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,IAAI,GAAG,CAAC;QACjC,UAAU,EAAE,KAAK;KACjB;IACD,UAAU,EAAE;QACX,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE;KAC5B;CACmC,CAAC;AAEtC,eAAe,IAAI,CAAC;AAIpB,MAAM,CAAC,MAAM,OAAO,GAAU,EAAE,CAAC"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export declare const useLocalStorage: <T>(key: string, initialValue: T, writeInitialValue?: boolean) => readonly [T, (value: T | ((current: T) => T)) => void];
|
|
2
|
+
export declare const useSessionStorage: <T>(key: string, initialValue: T, writeInitialValue?: boolean) => readonly [T, (value: T | ((current: T) => T)) => void];
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
// @unocss-include
|
|
2
|
+
import { useEffect, useMemo } from 'react';
|
|
3
|
+
import { proxy, useSnapshot } from 'valtio';
|
|
4
|
+
function makeUseStorage(storage, cache, name = storage.constructor.name) {
|
|
5
|
+
return function useStorage(key, initialValue, writeInitialValue = false) {
|
|
6
|
+
var _a;
|
|
7
|
+
// using useMemo to execute synchronous code in render just once.
|
|
8
|
+
// this hook comes before useLocalStorageCache because we want to load
|
|
9
|
+
// values into the cache before accessing them.
|
|
10
|
+
useMemo(() => {
|
|
11
|
+
if (typeof window === 'undefined')
|
|
12
|
+
return;
|
|
13
|
+
try {
|
|
14
|
+
const stored = storage.getItem(key);
|
|
15
|
+
if (stored) {
|
|
16
|
+
cache[key] = JSON.parse(stored);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
catch (err) {
|
|
20
|
+
console.error(`Error loading use-${name} value for ${key}: ${err}`);
|
|
21
|
+
storage.removeItem(key);
|
|
22
|
+
}
|
|
23
|
+
}, [key]);
|
|
24
|
+
const snapshot = useSnapshot(cache);
|
|
25
|
+
const storedValue = ((_a = snapshot[key]) !== null && _a !== void 0 ? _a : initialValue);
|
|
26
|
+
const hasValue = snapshot[key] !== undefined;
|
|
27
|
+
useEffect(() => {
|
|
28
|
+
if (!hasValue && writeInitialValue) {
|
|
29
|
+
storage.setItem(key, JSON.stringify(initialValue));
|
|
30
|
+
}
|
|
31
|
+
}, [hasValue, initialValue, writeInitialValue, key]);
|
|
32
|
+
// Return a wrapped version of useState's setter function that
|
|
33
|
+
// persists the new value to localStorage. It's throttled to prevent
|
|
34
|
+
// frequent writes to localStorage, which can be costly.
|
|
35
|
+
const setValue = useMemo(() => throttle((value) => {
|
|
36
|
+
if (typeof window === 'undefined')
|
|
37
|
+
return;
|
|
38
|
+
try {
|
|
39
|
+
// Allow value to be a function so we have same API as useState
|
|
40
|
+
const valueToStore = value instanceof Function ? value(storedValue) : value;
|
|
41
|
+
// Save to local storage
|
|
42
|
+
storage.setItem(key, JSON.stringify(valueToStore));
|
|
43
|
+
// sync it to other instances of the hook via the global cache
|
|
44
|
+
cache[key] = valueToStore;
|
|
45
|
+
}
|
|
46
|
+
catch (error) {
|
|
47
|
+
console.error(`Error setting use-${name} value for ${key}: ${value}: ${error}`);
|
|
48
|
+
throw new Error('Error setting value');
|
|
49
|
+
}
|
|
50
|
+
}, 300, { trailing: true, leading: true }), [key, storedValue]);
|
|
51
|
+
return [storedValue, setValue];
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
export const useLocalStorage = makeUseStorage(localStorage, proxy({}), 'LocalStorage');
|
|
55
|
+
export const useSessionStorage = makeUseStorage(sessionStorage, proxy({}), 'SessionStorage');
|
|
56
|
+
function throttle(func, wait, options) {
|
|
57
|
+
let previous = 0;
|
|
58
|
+
return function (...args) {
|
|
59
|
+
const now = Date.now();
|
|
60
|
+
if (!previous && (options === null || options === void 0 ? void 0 : options.leading) === false)
|
|
61
|
+
previous = now;
|
|
62
|
+
const remaining = wait - (now - previous);
|
|
63
|
+
if (remaining <= 0) {
|
|
64
|
+
if ((options === null || options === void 0 ? void 0 : options.trailing) === false)
|
|
65
|
+
previous = now;
|
|
66
|
+
return func(...args);
|
|
67
|
+
}
|
|
68
|
+
if ((options === null || options === void 0 ? void 0 : options.trailing) === false) {
|
|
69
|
+
return func(...args);
|
|
70
|
+
}
|
|
71
|
+
return setTimeout(() => {
|
|
72
|
+
previous = (options === null || options === void 0 ? void 0 : options.leading) === false ? 0 : Date.now();
|
|
73
|
+
func(...args);
|
|
74
|
+
}, remaining);
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
//# sourceMappingURL=useStorage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useStorage.js","sourceRoot":"","sources":["../../../src/hooks/useStorage.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,2 +1,7 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
export declare const withProps: <T extends {}>(Component: React.ComponentType<T>, extras: Partial<T>) => (props: T) => import("react/jsx-runtime").JSX.Element;
|
|
3
|
+
type OptionalKeys<T> = {
|
|
4
|
+
[K in keyof T]-?: undefined extends T[K] ? K : never;
|
|
5
|
+
}[keyof T];
|
|
6
|
+
export declare const withoutProps: <T extends {}, P extends OptionalKeys<T>>(Component: React.ComponentType<T>, remove: P[]) => (props: Omit<T, P>) => import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
export {};
|
|
@@ -5,4 +5,9 @@ export const withProps = (Component, extras) => {
|
|
|
5
5
|
return _jsx(Component, Object.assign({}, props, extras));
|
|
6
6
|
};
|
|
7
7
|
};
|
|
8
|
+
export const withoutProps = (Component, remove) => {
|
|
9
|
+
return (props) => {
|
|
10
|
+
return _jsx(Component, Object.assign({}, props));
|
|
11
|
+
};
|
|
12
|
+
};
|
|
8
13
|
//# sourceMappingURL=withProps.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"withProps.js","sourceRoot":"","sources":["../../../src/hooks/withProps.tsx"],"names":[],"mappings":";AAEA,MAAM,CAAC,MAAM,SAAS,GAAG,CACxB,SAAiC,EACjC,MAAkB,EACjB,EAAE;IACH,OAAO,CAAC,KAAQ,EAAE,EAAE;QACnB,OAAO,KAAC,SAAS,oBAAK,KAAK,EAAM,MAAM,EAAI,CAAC;IAC7C,CAAC,CAAC;AACH,CAAC,CAAC"}
|
|
1
|
+
{"version":3,"file":"withProps.js","sourceRoot":"","sources":["../../../src/hooks/withProps.tsx"],"names":[],"mappings":";AAEA,MAAM,CAAC,MAAM,SAAS,GAAG,CACxB,SAAiC,EACjC,MAAkB,EACjB,EAAE;IACH,OAAO,CAAC,KAAQ,EAAE,EAAE;QACnB,OAAO,KAAC,SAAS,oBAAK,KAAK,EAAM,MAAM,EAAI,CAAC;IAC7C,CAAC,CAAC;AACH,CAAC,CAAC;AAKF,MAAM,CAAC,MAAM,YAAY,GAAG,CAC3B,SAAiC,EACjC,MAAW,EACV,EAAE;IACH,OAAO,CAAC,KAAiB,EAAE,EAAE;QAC5B,OAAO,KAAC,SAAS,oBAAM,KAAa,EAAI,CAAC;IAC1C,CAAC,CAAC;AACH,CAAC,CAAC"}
|
package/dist/esm/uno/colors.js
CHANGED
|
@@ -7,7 +7,7 @@ export const colorConstants = `
|
|
|
7
7
|
`;
|
|
8
8
|
export const dynamicThemeComputedColors = (name) => `
|
|
9
9
|
--color-${name}: oklch(calc(90% - 35% * var(--dyn-source-mode-adjust, 0) - (var(--dyn-mode-sign, 1) * var(--dyn-${name}-base-dim, 0%))) calc(var(--dyn-${name}-sat-mult,1) * (35% - 2% * var(--dyn-source-mode-adjust, 0))) var(--dyn-${name}-source, 0));
|
|
10
|
-
--color-${name}-wash: oklch(from var(--color-${name}) calc(min(0.999,max(0.15, l + 0.15 * var(--dyn-mode-mult, 1)))) calc(var(--dyn-${name}-sat-mult) * (c * var(--dyn-saturation-x-wash, 1) - 0.
|
|
10
|
+
--color-${name}-wash: oklch(from var(--color-${name}) calc(min(0.999,max(0.15, l + 0.15 * var(--dyn-mode-mult, 1)))) calc(var(--dyn-${name}-sat-mult) * (c * var(--dyn-saturation-x-wash, 1) - 0.06)) calc(h - 5 * var(--dyn-${name}-hue-rotate, 0) * var(--dyn-${name}-hue-rotate-mult, 1)));
|
|
11
11
|
--color-${name}-light: oklch(from var(--color-${name}) calc(l + 0.08 * var(--dyn-mode-mult, 1)) calc(var(--dyn-${name}-sat-mult) * (c * var(--dyn-saturation-x-light, 1) - 0.03)) calc(h - 0.5 * var(--dyn-${name}-hue-rotate, 0) * var(--dyn-${name}-hue-rotate-mult, 1)));
|
|
12
12
|
--color-${name}-dark: oklch(from var(--color-${name}) calc(l - 0.26 * var(--dyn-mode-mult, 1)) calc(var(--dyn-${name}-sat-mult) * (c * var(--dyn-saturation-x-dark, 1) + 0.01)) calc(h + 0.2 * var(--dyn-${name}-hue-rotate, 0) * var(--dyn-${name}-hue-rotate-mult, 1)));
|
|
13
13
|
--color-${name}-ink: oklch(from var(--color-${name}) calc(l - 0.45 * var(--dyn-mode-mult, 1)) calc(var(--dyn-${name}-sat-mult) * (c * var(--dyn-saturation-x-ink, 1) + 0.01)) calc(h + 1 * var(--dyn-${name}-hue-rotate, 0) * var(--dyn-${name}-hue-rotate-mult, 1)));
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@a-type/ui",
|
|
3
|
-
"version": "2.0
|
|
3
|
+
"version": "2.1.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"files": [
|
|
6
6
|
"/dist",
|
|
@@ -67,8 +67,10 @@
|
|
|
67
67
|
"csstype": "^3.1.3",
|
|
68
68
|
"date-fns": "^4.1.0",
|
|
69
69
|
"formik": "^2.4.6",
|
|
70
|
+
"frimousse": "^0.2.0",
|
|
70
71
|
"pluralize": "^8.0.0",
|
|
71
|
-
"react-hot-toast": "^2.4.1"
|
|
72
|
+
"react-hot-toast": "^2.4.1",
|
|
73
|
+
"valtio": "^2.1.4"
|
|
72
74
|
},
|
|
73
75
|
"devDependencies": {
|
|
74
76
|
"@changesets/changelog-git": "^0.2.1",
|
package/src/colors.stories.tsx
CHANGED
|
@@ -3,7 +3,26 @@ import { Box } from './components/index.js';
|
|
|
3
3
|
|
|
4
4
|
const meta = {
|
|
5
5
|
title: 'colors',
|
|
6
|
-
argTypes: {
|
|
6
|
+
argTypes: {
|
|
7
|
+
customHue: {
|
|
8
|
+
control: {
|
|
9
|
+
type: 'range',
|
|
10
|
+
min: 0,
|
|
11
|
+
max: 360,
|
|
12
|
+
},
|
|
13
|
+
},
|
|
14
|
+
customRotate: {
|
|
15
|
+
control: {
|
|
16
|
+
type: 'range',
|
|
17
|
+
min: -180,
|
|
18
|
+
max: 180,
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
},
|
|
22
|
+
args: {
|
|
23
|
+
customHue: 0,
|
|
24
|
+
customRotate: 0,
|
|
25
|
+
},
|
|
7
26
|
parameters: {
|
|
8
27
|
controls: { expanded: true },
|
|
9
28
|
},
|
|
@@ -14,7 +33,13 @@ export default meta;
|
|
|
14
33
|
type Story = StoryObj;
|
|
15
34
|
|
|
16
35
|
export const Default: Story = {
|
|
17
|
-
render() {
|
|
36
|
+
render(args: any) {
|
|
37
|
+
const style: any = args.customHue
|
|
38
|
+
? {
|
|
39
|
+
'--dyn-primary-source': args.customHue,
|
|
40
|
+
'--dyn-primary-hue-rotate': args.customRotate,
|
|
41
|
+
}
|
|
42
|
+
: {};
|
|
18
43
|
return (
|
|
19
44
|
<Box d="col">
|
|
20
45
|
<Range className="theme-lemon" />
|
|
@@ -23,6 +48,7 @@ export const Default: Story = {
|
|
|
23
48
|
<Range className="theme-eggplant" />
|
|
24
49
|
<Range className="theme-blueberry" />
|
|
25
50
|
<Range className="theme-salt" />
|
|
51
|
+
<Range className="theme" style={style} />
|
|
26
52
|
</Box>
|
|
27
53
|
);
|
|
28
54
|
},
|
|
@@ -40,9 +66,9 @@ function Swatch({ className }: { className?: string }) {
|
|
|
40
66
|
);
|
|
41
67
|
}
|
|
42
68
|
|
|
43
|
-
function Range({ className }: { className?: string }) {
|
|
69
|
+
function Range({ className, style }: { className?: string; style?: any }) {
|
|
44
70
|
return (
|
|
45
|
-
<Box className={className}>
|
|
71
|
+
<Box className={className} style={style}>
|
|
46
72
|
<Swatch className="bg-primary-wash" />
|
|
47
73
|
<Swatch className="bg-primary-light" />
|
|
48
74
|
<Swatch className="bg-primary" />
|