@vibes.diy/use-vibes-base 0.0.0-dev-fresh-data
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/LICENSE.md +232 -0
- package/ManualRedirectStrategy.d.ts +24 -0
- package/ManualRedirectStrategy.js +289 -0
- package/ManualRedirectStrategy.js.map +1 -0
- package/README.md +549 -0
- package/components/AuthWall/AuthWall.d.ts +8 -0
- package/components/AuthWall/AuthWall.js +161 -0
- package/components/AuthWall/AuthWall.js.map +1 -0
- package/components/AuthWall/AuthWall.styles.d.ts +24 -0
- package/components/AuthWall/AuthWall.styles.js +82 -0
- package/components/AuthWall/AuthWall.styles.js.map +1 -0
- package/components/BrutalistCard/BrutalistCard.d.ts +8 -0
- package/components/BrutalistCard/BrutalistCard.js +11 -0
- package/components/BrutalistCard/BrutalistCard.js.map +1 -0
- package/components/BrutalistCard/BrutalistCard.styles.d.ts +4 -0
- package/components/BrutalistCard/BrutalistCard.styles.js +66 -0
- package/components/BrutalistCard/BrutalistCard.styles.js.map +1 -0
- package/components/BrutalistCard/index.d.ts +3 -0
- package/components/BrutalistCard/index.js +2 -0
- package/components/BrutalistCard/index.js.map +1 -0
- package/components/ControlsBar.d.ts +20 -0
- package/components/ControlsBar.js +108 -0
- package/components/ControlsBar.js.map +1 -0
- package/components/HiddenMenuWrapper/HiddenMenuWrapper.d.ts +7 -0
- package/components/HiddenMenuWrapper/HiddenMenuWrapper.js +103 -0
- package/components/HiddenMenuWrapper/HiddenMenuWrapper.js.map +1 -0
- package/components/HiddenMenuWrapper/HiddenMenuWrapper.styles.d.ts +31 -0
- package/components/HiddenMenuWrapper/HiddenMenuWrapper.styles.js +86 -0
- package/components/HiddenMenuWrapper/HiddenMenuWrapper.styles.js.map +1 -0
- package/components/ImgGen.css +675 -0
- package/components/ImgGen.d.ts +23 -0
- package/components/ImgGen.js +260 -0
- package/components/ImgGen.js.map +1 -0
- package/components/ImgGenUtils/AsyncImg.d.ts +7 -0
- package/components/ImgGenUtils/AsyncImg.js +41 -0
- package/components/ImgGenUtils/AsyncImg.js.map +1 -0
- package/components/ImgGenUtils/ImgGenDisplay.d.ts +3 -0
- package/components/ImgGenUtils/ImgGenDisplay.js +240 -0
- package/components/ImgGenUtils/ImgGenDisplay.js.map +1 -0
- package/components/ImgGenUtils/ImgGenDisplayPlaceholder.d.ts +3 -0
- package/components/ImgGenUtils/ImgGenDisplayPlaceholder.js +99 -0
- package/components/ImgGenUtils/ImgGenDisplayPlaceholder.js.map +1 -0
- package/components/ImgGenUtils/ImgGenDisplayUtils.d.ts +27 -0
- package/components/ImgGenUtils/ImgGenDisplayUtils.js +95 -0
- package/components/ImgGenUtils/ImgGenDisplayUtils.js.map +1 -0
- package/components/ImgGenUtils/ImgGenError.d.ts +3 -0
- package/components/ImgGenUtils/ImgGenError.js +9 -0
- package/components/ImgGenUtils/ImgGenError.js.map +1 -0
- package/components/ImgGenUtils/ImgGenFileDrop.d.ts +11 -0
- package/components/ImgGenUtils/ImgGenFileDrop.js +56 -0
- package/components/ImgGenUtils/ImgGenFileDrop.js.map +1 -0
- package/components/ImgGenUtils/ImgGenModal.d.ts +25 -0
- package/components/ImgGenUtils/ImgGenModal.js +67 -0
- package/components/ImgGenUtils/ImgGenModal.js.map +1 -0
- package/components/ImgGenUtils/ImgGenModeUtils.d.ts +9 -0
- package/components/ImgGenUtils/ImgGenModeUtils.js +59 -0
- package/components/ImgGenUtils/ImgGenModeUtils.js.map +1 -0
- package/components/ImgGenUtils/ImgGenPromptWaiting.d.ts +11 -0
- package/components/ImgGenUtils/ImgGenPromptWaiting.js +40 -0
- package/components/ImgGenUtils/ImgGenPromptWaiting.js.map +1 -0
- package/components/ImgGenUtils/ImgGenUploadWaiting.d.ts +16 -0
- package/components/ImgGenUtils/ImgGenUploadWaiting.js +155 -0
- package/components/ImgGenUtils/ImgGenUploadWaiting.js.map +1 -0
- package/components/ImgGenUtils/index.d.ts +6 -0
- package/components/ImgGenUtils/index.js +7 -0
- package/components/ImgGenUtils/index.js.map +1 -0
- package/components/ImgGenUtils/overlays/DeleteConfirmationOverlay.d.ts +9 -0
- package/components/ImgGenUtils/overlays/DeleteConfirmationOverlay.js +31 -0
- package/components/ImgGenUtils/overlays/DeleteConfirmationOverlay.js.map +1 -0
- package/components/ImgGenUtils/overlays/ImageOverlay.d.ts +22 -0
- package/components/ImgGenUtils/overlays/ImageOverlay.js +11 -0
- package/components/ImgGenUtils/overlays/ImageOverlay.js.map +1 -0
- package/components/ImgGenUtils/types.d.ts +29 -0
- package/components/ImgGenUtils/types.js +2 -0
- package/components/ImgGenUtils/types.js.map +1 -0
- package/components/ImgGenUtils.d.ts +2 -0
- package/components/ImgGenUtils.js +3 -0
- package/components/ImgGenUtils.js.map +1 -0
- package/components/PromptBar.d.ts +11 -0
- package/components/PromptBar.js +24 -0
- package/components/PromptBar.js.map +1 -0
- package/components/VibeControl.d.ts +13 -0
- package/components/VibeControl.js +74 -0
- package/components/VibeControl.js.map +1 -0
- package/components/VibesButton/VibesButton.d.ts +10 -0
- package/components/VibesButton/VibesButton.js +20 -0
- package/components/VibesButton/VibesButton.js.map +1 -0
- package/components/VibesButton/VibesButton.styles.d.ts +6 -0
- package/components/VibesButton/VibesButton.styles.js +35 -0
- package/components/VibesButton/VibesButton.styles.js.map +1 -0
- package/components/VibesPanel/VibesPanel.d.ts +6 -0
- package/components/VibesPanel/VibesPanel.js +115 -0
- package/components/VibesPanel/VibesPanel.js.map +1 -0
- package/components/VibesPanel/index.d.ts +1 -0
- package/components/VibesPanel/index.js +2 -0
- package/components/VibesPanel/index.js.map +1 -0
- package/components/VibesSwitch/VibesSwitch.d.ts +6 -0
- package/components/VibesSwitch/VibesSwitch.js +54 -0
- package/components/VibesSwitch/VibesSwitch.js.map +1 -0
- package/components/VibesSwitch/VibesSwitch.styles.d.ts +4 -0
- package/components/VibesSwitch/VibesSwitch.styles.js +5 -0
- package/components/VibesSwitch/VibesSwitch.styles.js.map +1 -0
- package/constants.d.ts +4 -0
- package/constants.js +5 -0
- package/constants.js.map +1 -0
- package/events.d.ts +7 -0
- package/events.js +4 -0
- package/events.js.map +1 -0
- package/hooks/image-gen/image-generator.d.ts +11 -0
- package/hooks/image-gen/image-generator.js +146 -0
- package/hooks/image-gen/image-generator.js.map +1 -0
- package/hooks/image-gen/index.d.ts +7 -0
- package/hooks/image-gen/index.js +6 -0
- package/hooks/image-gen/index.js.map +1 -0
- package/hooks/image-gen/use-image-gen.d.ts +2 -0
- package/hooks/image-gen/use-image-gen.js +554 -0
- package/hooks/image-gen/use-image-gen.js.map +1 -0
- package/hooks/image-gen/utils.d.ts +19 -0
- package/hooks/image-gen/utils.js +150 -0
- package/hooks/image-gen/utils.js.map +1 -0
- package/hooks/use-image-gen.d.ts +1 -0
- package/hooks/use-image-gen.js +2 -0
- package/hooks/use-image-gen.js.map +1 -0
- package/hooks/vibes-gen/IframeVibesComponent.d.ts +10 -0
- package/hooks/vibes-gen/IframeVibesComponent.js +67 -0
- package/hooks/vibes-gen/IframeVibesComponent.js.map +1 -0
- package/hooks/vibes-gen/index.d.ts +2 -0
- package/hooks/vibes-gen/index.js +2 -0
- package/hooks/vibes-gen/index.js.map +1 -0
- package/hooks/vibes-gen/use-vibes.d.ts +3 -0
- package/hooks/vibes-gen/use-vibes.js +185 -0
- package/hooks/vibes-gen/use-vibes.js.map +1 -0
- package/index.d.ts +68 -0
- package/index.js +340 -0
- package/index.js.map +1 -0
- package/install-tracker.d.ts +30 -0
- package/install-tracker.js +246 -0
- package/install-tracker.js.map +1 -0
- package/package.json +47 -0
- package/stories/VibeControl.stories.d.ts +13 -0
- package/stories/VibeControl.stories.js +195 -0
- package/stories/VibeControl.stories.js.map +1 -0
- package/tsconfig.json +18 -0
- package/utils/appSlug.d.ts +17 -0
- package/utils/appSlug.js +175 -0
- package/utils/appSlug.js.map +1 -0
- package/utils/base64.d.ts +1 -0
- package/utils/base64.js +13 -0
- package/utils/base64.js.map +1 -0
- package/utils/debug.d.ts +2 -0
- package/utils/debug.js +8 -0
- package/utils/debug.js.map +1 -0
- package/utils/style-utils.d.ts +4 -0
- package/utils/style-utils.js +15 -0
- package/utils/style-utils.js.map +1 -0
- package/utils/styles.d.ts +325 -0
- package/utils/styles.js +328 -0
- package/utils/styles.js.map +1 -0
- package/utils/vibe-control-styles.d.ts +148 -0
- package/utils/vibe-control-styles.js +170 -0
- package/utils/vibe-control-styles.js.map +1 -0
- package/vibe-app-mount.d.ts +13 -0
- package/vibe-app-mount.js +124 -0
- package/vibe-app-mount.js.map +1 -0
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import React, { useRef, useState, useEffect } from 'react';
|
|
2
|
+
import { getWrapperStyle, getMenuStyle, getContentWrapperStyle, getContentStyle, getToggleButtonStyle, getInnerContentWrapperStyle, } from './HiddenMenuWrapper.styles.js';
|
|
3
|
+
import { VibesSwitch } from '../VibesSwitch/VibesSwitch.js';
|
|
4
|
+
export function HiddenMenuWrapper({ children, menuContent, triggerBounce, }) {
|
|
5
|
+
const [menuOpen, setMenuOpen] = useState(false);
|
|
6
|
+
const [menuHeight, setMenuHeight] = useState(0);
|
|
7
|
+
const menuRef = useRef(null);
|
|
8
|
+
const buttonRef = useRef(null);
|
|
9
|
+
const menuContainerRef = useRef(null);
|
|
10
|
+
const [isBouncing, setIsBouncing] = useState(false);
|
|
11
|
+
const [hasBouncedOnMount, setHasBouncedOnMount] = useState(false);
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
if (!hasBouncedOnMount && !menuOpen) {
|
|
14
|
+
const prefersReducedMotion = window.matchMedia?.('(prefers-reduced-motion: reduce)')?.matches || false;
|
|
15
|
+
if (!prefersReducedMotion) {
|
|
16
|
+
setIsBouncing(true);
|
|
17
|
+
setTimeout(() => setIsBouncing(false), 800);
|
|
18
|
+
}
|
|
19
|
+
setHasBouncedOnMount(true);
|
|
20
|
+
}
|
|
21
|
+
}, [hasBouncedOnMount, menuOpen]);
|
|
22
|
+
useEffect(() => {
|
|
23
|
+
const styleId = 'vibes-drop-to-close-keyframes';
|
|
24
|
+
const existingStyle = document.getElementById(styleId);
|
|
25
|
+
if (!existingStyle) {
|
|
26
|
+
const style = document.createElement('style');
|
|
27
|
+
style.id = styleId;
|
|
28
|
+
style.textContent = `
|
|
29
|
+
@keyframes vibes-drop-to-close {
|
|
30
|
+
0% { transform: translateY(-400px); } /* Start pushed up */
|
|
31
|
+
10% { transform: translateY(0); } /* First big drop */
|
|
32
|
+
25% { transform: translateY(-175px); } /* First bounce back up */
|
|
33
|
+
35% { transform: translateY(0); } /* Second drop */
|
|
34
|
+
48% { transform: translateY(-75px); } /* Second bounce back up */
|
|
35
|
+
62% { transform: translateY(0); } /* Third drop */
|
|
36
|
+
72% { transform: translateY(-25px); } /* Third bounce back up */
|
|
37
|
+
80% { transform: translateY(0); } /* Fourth drop - faster */
|
|
38
|
+
82% { transform: translateY(-10px); } /* Fourth bounce back up - much faster */
|
|
39
|
+
88% { transform: translateY(0); } /* Fifth drop */
|
|
40
|
+
91% { transform: translateY(-5px); } /* Final tiny bounce back up */
|
|
41
|
+
95% { transform: translateY(0); } /* Final settle */
|
|
42
|
+
100% { transform: translateY(0); }
|
|
43
|
+
}
|
|
44
|
+
`;
|
|
45
|
+
document.head.appendChild(style);
|
|
46
|
+
}
|
|
47
|
+
}, []);
|
|
48
|
+
useEffect(() => {
|
|
49
|
+
if (triggerBounce) {
|
|
50
|
+
setIsBouncing(true);
|
|
51
|
+
const timeout = setTimeout(() => setIsBouncing(false), 800);
|
|
52
|
+
return () => clearTimeout(timeout);
|
|
53
|
+
}
|
|
54
|
+
}, [triggerBounce]);
|
|
55
|
+
useEffect(() => {
|
|
56
|
+
if (menuRef.current) {
|
|
57
|
+
setMenuHeight(menuRef.current.offsetHeight);
|
|
58
|
+
}
|
|
59
|
+
}, [menuContent]);
|
|
60
|
+
useEffect(() => {
|
|
61
|
+
const handleKeyDown = (e) => {
|
|
62
|
+
if (e.key === 'Escape' && menuOpen) {
|
|
63
|
+
setMenuOpen(false);
|
|
64
|
+
buttonRef.current?.focus();
|
|
65
|
+
}
|
|
66
|
+
if (menuOpen && e.key === 'Tab' && menuContainerRef.current) {
|
|
67
|
+
const focusableElements = menuContainerRef.current.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])');
|
|
68
|
+
const first = focusableElements[0];
|
|
69
|
+
const last = focusableElements[focusableElements.length - 1];
|
|
70
|
+
if (!first || !last)
|
|
71
|
+
return;
|
|
72
|
+
if (e.shiftKey) {
|
|
73
|
+
if (document.activeElement === first) {
|
|
74
|
+
e.preventDefault();
|
|
75
|
+
last.focus();
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
if (document.activeElement === last) {
|
|
80
|
+
e.preventDefault();
|
|
81
|
+
first.focus();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
};
|
|
86
|
+
document.addEventListener('keydown', handleKeyDown);
|
|
87
|
+
return () => document.removeEventListener('keydown', handleKeyDown);
|
|
88
|
+
}, [menuOpen]);
|
|
89
|
+
useEffect(() => {
|
|
90
|
+
if (menuOpen) {
|
|
91
|
+
const firstFocusable = menuRef.current?.querySelector('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])');
|
|
92
|
+
firstFocusable?.focus();
|
|
93
|
+
}
|
|
94
|
+
}, [menuOpen]);
|
|
95
|
+
return (React.createElement("div", { style: getWrapperStyle() },
|
|
96
|
+
React.createElement("div", { id: "hidden-menu", role: "dialog", "aria-modal": "true", "aria-label": "Hidden menu", "aria-hidden": !menuOpen, ref: menuRef, style: getMenuStyle() }, menuContent),
|
|
97
|
+
React.createElement("div", { style: getContentWrapperStyle(menuHeight, menuOpen, isBouncing), ref: menuContainerRef },
|
|
98
|
+
React.createElement("div", { style: getInnerContentWrapperStyle(menuOpen) },
|
|
99
|
+
React.createElement("div", { style: getContentStyle() }, children))),
|
|
100
|
+
React.createElement("button", { "aria-haspopup": "dialog", "aria-expanded": menuOpen, "aria-controls": "hidden-menu", ref: buttonRef, onClick: () => setMenuOpen(!menuOpen), style: getToggleButtonStyle() },
|
|
101
|
+
React.createElement(VibesSwitch, { size: 80 }))));
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=HiddenMenuWrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HiddenMenuWrapper.js","sourceRoot":"","sources":["../../../jsr/components/HiddenMenuWrapper/HiddenMenuWrapper.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import type { CSSProperties } from 'react';
|
|
2
|
+
export declare const hiddenMenuTheme: {
|
|
3
|
+
colors: {
|
|
4
|
+
menuBg: string;
|
|
5
|
+
menuText: string;
|
|
6
|
+
contentBg: string;
|
|
7
|
+
shadow: string;
|
|
8
|
+
gridLineColor: string;
|
|
9
|
+
};
|
|
10
|
+
zIndex: {
|
|
11
|
+
menu: number;
|
|
12
|
+
content: number;
|
|
13
|
+
toggle: number;
|
|
14
|
+
};
|
|
15
|
+
dimensions: {
|
|
16
|
+
gridSize: string;
|
|
17
|
+
padding: string;
|
|
18
|
+
bottomOffset: string;
|
|
19
|
+
};
|
|
20
|
+
animation: {
|
|
21
|
+
duration: string;
|
|
22
|
+
easing: string;
|
|
23
|
+
blurAmount: string;
|
|
24
|
+
};
|
|
25
|
+
};
|
|
26
|
+
export declare const getWrapperStyle: () => CSSProperties;
|
|
27
|
+
export declare const getMenuStyle: () => CSSProperties;
|
|
28
|
+
export declare const getContentStyle: () => CSSProperties;
|
|
29
|
+
export declare const getContentWrapperStyle: (menuHeight: number, menuOpen: boolean, isBouncing: boolean) => CSSProperties;
|
|
30
|
+
export declare const getInnerContentWrapperStyle: (menuOpen: boolean) => CSSProperties;
|
|
31
|
+
export declare const getToggleButtonStyle: () => CSSProperties;
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
export const hiddenMenuTheme = {
|
|
2
|
+
colors: {
|
|
3
|
+
menuBg: 'var(--hm-menu-bg, #d4d4d4)',
|
|
4
|
+
menuText: 'var(--hm-menu-text, white)',
|
|
5
|
+
contentBg: 'var(--hm-content-bg, #1e1e1e)',
|
|
6
|
+
shadow: 'var(--hm-shadow, rgba(0, 0, 0, 0.3))',
|
|
7
|
+
gridLineColor: 'var(--hm-grid-line, rgba(255, 255, 255, 0.5))',
|
|
8
|
+
},
|
|
9
|
+
zIndex: {
|
|
10
|
+
menu: 5,
|
|
11
|
+
content: 10,
|
|
12
|
+
toggle: 20,
|
|
13
|
+
},
|
|
14
|
+
dimensions: {
|
|
15
|
+
gridSize: '40px',
|
|
16
|
+
padding: '24px',
|
|
17
|
+
bottomOffset: '16px',
|
|
18
|
+
},
|
|
19
|
+
animation: {
|
|
20
|
+
duration: '0.4s',
|
|
21
|
+
easing: 'ease',
|
|
22
|
+
blurAmount: '4px',
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
export const getWrapperStyle = () => ({
|
|
26
|
+
position: 'relative',
|
|
27
|
+
overflow: 'hidden',
|
|
28
|
+
});
|
|
29
|
+
export const getMenuStyle = () => ({
|
|
30
|
+
position: 'fixed',
|
|
31
|
+
bottom: 0,
|
|
32
|
+
left: 0,
|
|
33
|
+
right: 0,
|
|
34
|
+
zIndex: hiddenMenuTheme.zIndex.menu,
|
|
35
|
+
color: hiddenMenuTheme.colors.menuText,
|
|
36
|
+
padding: hiddenMenuTheme.dimensions.padding,
|
|
37
|
+
boxShadow: `0 -2px 10px ${hiddenMenuTheme.colors.shadow}`,
|
|
38
|
+
backgroundColor: hiddenMenuTheme.colors.menuBg,
|
|
39
|
+
backgroundImage: `
|
|
40
|
+
linear-gradient(${hiddenMenuTheme.colors.gridLineColor} 1px, transparent 1px),
|
|
41
|
+
linear-gradient(90deg, ${hiddenMenuTheme.colors.gridLineColor} 1px, transparent 1px)
|
|
42
|
+
`,
|
|
43
|
+
backgroundSize: hiddenMenuTheme.dimensions.gridSize + ' ' + hiddenMenuTheme.dimensions.gridSize,
|
|
44
|
+
});
|
|
45
|
+
export const getContentStyle = () => ({
|
|
46
|
+
filter: 'none',
|
|
47
|
+
width: '100%',
|
|
48
|
+
height: '100%',
|
|
49
|
+
});
|
|
50
|
+
export const getContentWrapperStyle = (menuHeight, menuOpen, isBouncing) => ({
|
|
51
|
+
position: 'fixed',
|
|
52
|
+
top: 0,
|
|
53
|
+
left: 0,
|
|
54
|
+
right: 0,
|
|
55
|
+
bottom: 0,
|
|
56
|
+
zIndex: hiddenMenuTheme.zIndex.content,
|
|
57
|
+
transition: isBouncing
|
|
58
|
+
? `filter 0.3s ${hiddenMenuTheme.animation.easing}`
|
|
59
|
+
: `transform ${hiddenMenuTheme.animation.duration} ${hiddenMenuTheme.animation.easing}, filter 0.3s ${hiddenMenuTheme.animation.easing}`,
|
|
60
|
+
transform: menuOpen ? `translateY(-${menuHeight}px)` : 'translateY(0)',
|
|
61
|
+
overflowY: 'auto',
|
|
62
|
+
borderTopColor: hiddenMenuTheme.colors.menuBg,
|
|
63
|
+
borderTopWidth: '1px',
|
|
64
|
+
borderTopStyle: 'solid',
|
|
65
|
+
boxShadow: `0 -2px 10px ${hiddenMenuTheme.colors.shadow}`,
|
|
66
|
+
backgroundColor: hiddenMenuTheme.colors.contentBg,
|
|
67
|
+
animation: isBouncing
|
|
68
|
+
? 'vibes-drop-to-close 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94)'
|
|
69
|
+
: undefined,
|
|
70
|
+
willChange: isBouncing ? 'transform' : undefined,
|
|
71
|
+
});
|
|
72
|
+
export const getInnerContentWrapperStyle = (menuOpen) => ({
|
|
73
|
+
filter: menuOpen ? `blur(${hiddenMenuTheme.animation.blurAmount})` : 'none',
|
|
74
|
+
width: '100%',
|
|
75
|
+
height: '100%',
|
|
76
|
+
});
|
|
77
|
+
export const getToggleButtonStyle = () => ({
|
|
78
|
+
position: 'fixed',
|
|
79
|
+
bottom: hiddenMenuTheme.dimensions.bottomOffset,
|
|
80
|
+
right: 0,
|
|
81
|
+
zIndex: hiddenMenuTheme.zIndex.toggle,
|
|
82
|
+
backgroundColor: 'transparent',
|
|
83
|
+
border: 'none',
|
|
84
|
+
cursor: 'pointer',
|
|
85
|
+
});
|
|
86
|
+
//# sourceMappingURL=HiddenMenuWrapper.styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"HiddenMenuWrapper.styles.js","sourceRoot":"","sources":["../../../jsr/components/HiddenMenuWrapper/HiddenMenuWrapper.styles.ts"],"names":[],"mappings":"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"}
|