mirror of
https://github.com/actualbudget/actual.git
synced 2026-03-11 20:44:32 -05:00
feat: add command bar (#5076)
* deps(desktop-client): add cmdk * feat(desktop-client): create and integrate CommandBar * hover on selection * Ctrl+K only opens, ESC closes * add custom reports * add navigation items to cmdk * fix: mouse hovering can interfere with keyboard navigation * reset search state when CommandBar closes * revert import order changes * deps(desktop-client): readd cmdk * fix vite error * add item icons * move navigation items into their own section * hide scrollbar and release notes * style: run yarn lint:fix * fix: infinite loop opening commandbar with active modal * fix: infinite error loop bc focus conflicts * fix: kebab case console warning * chore: update yarn.lock * refactor: use autoFocus prop * feat: add i18next * style: relocate eslint-disable comment
This commit is contained in:
@@ -31,6 +31,7 @@
|
||||
"@vitejs/plugin-react-swc": "^3.6.0",
|
||||
"auto-text-size": "^0.2.3",
|
||||
"chokidar": "^3.6.0",
|
||||
"cmdk": "^1.1.1",
|
||||
"cross-env": "^7.0.3",
|
||||
"date-fns": "^4.1.0",
|
||||
"debounce": "^1.2.1",
|
||||
|
||||
278
packages/desktop-client/src/components/CommandBar.tsx
Normal file
278
packages/desktop-client/src/components/CommandBar.tsx
Normal file
@@ -0,0 +1,278 @@
|
||||
import {
|
||||
type ComponentType,
|
||||
type SVGProps,
|
||||
useCallback,
|
||||
useEffect,
|
||||
useMemo,
|
||||
useState,
|
||||
} from 'react';
|
||||
import { useTranslation } from 'react-i18next';
|
||||
|
||||
import {
|
||||
SvgCog,
|
||||
SvgPiggyBank,
|
||||
SvgReports,
|
||||
SvgStoreFront,
|
||||
SvgTuning,
|
||||
SvgWallet,
|
||||
} from '@actual-app/components/icons/v1';
|
||||
import {
|
||||
SvgCalendar3,
|
||||
SvgNotesPaperText,
|
||||
} from '@actual-app/components/icons/v2';
|
||||
import { css } from '@emotion/css';
|
||||
import { Command } from 'cmdk';
|
||||
|
||||
import { useAccounts } from '@desktop-client/hooks/useAccounts';
|
||||
import { useMetadataPref } from '@desktop-client/hooks/useMetadataPref';
|
||||
import { useModalState } from '@desktop-client/hooks/useModalState';
|
||||
import { useNavigate } from '@desktop-client/hooks/useNavigate';
|
||||
import { useReports } from '@desktop-client/hooks/useReports';
|
||||
|
||||
type SearchableItem = {
|
||||
id: string;
|
||||
name: string;
|
||||
Icon: ComponentType<SVGProps<SVGSVGElement>>;
|
||||
};
|
||||
|
||||
type SearchSection = {
|
||||
key: string;
|
||||
heading: string;
|
||||
items: Readonly<SearchableItem[]>;
|
||||
onSelect: (item: Pick<SearchableItem, 'id'>) => void;
|
||||
};
|
||||
|
||||
export function CommandBar() {
|
||||
const { t } = useTranslation();
|
||||
const [open, setOpen] = useState(false);
|
||||
const [search, setSearch] = useState('');
|
||||
const navigate = useNavigate();
|
||||
const [budgetName] = useMetadataPref('budgetName');
|
||||
const { modalStack } = useModalState();
|
||||
|
||||
const navigationItems = useMemo(
|
||||
() => [
|
||||
{ id: 'budget', name: t('Budget'), path: '/budget', Icon: SvgWallet },
|
||||
{
|
||||
id: 'reports-nav',
|
||||
name: t('Reports'),
|
||||
path: '/reports',
|
||||
Icon: SvgReports,
|
||||
},
|
||||
{
|
||||
id: 'schedules',
|
||||
name: t('Schedules'),
|
||||
path: '/schedules',
|
||||
Icon: SvgCalendar3,
|
||||
},
|
||||
{ id: 'payees', name: t('Payees'), path: '/payees', Icon: SvgStoreFront },
|
||||
{ id: 'rules', name: t('Rules'), path: '/rules', Icon: SvgTuning },
|
||||
{ id: 'settings', name: t('Settings'), path: '/settings', Icon: SvgCog },
|
||||
],
|
||||
[t],
|
||||
);
|
||||
|
||||
useEffect(() => {
|
||||
// Reset search when closing
|
||||
if (!open) setSearch('');
|
||||
}, [open]);
|
||||
|
||||
const allAccounts = useAccounts();
|
||||
const { data: customReports } = useReports();
|
||||
|
||||
const accounts = allAccounts.filter(acc => !acc.closed);
|
||||
|
||||
const openEventListener = useCallback(
|
||||
(e: KeyboardEvent) => {
|
||||
if (e.key === 'k' && (e.metaKey || e.ctrlKey)) {
|
||||
e.preventDefault();
|
||||
// Do not open CommandBar if a modal is already open
|
||||
if (modalStack.length > 0) return;
|
||||
setOpen(true);
|
||||
}
|
||||
},
|
||||
[modalStack.length],
|
||||
);
|
||||
|
||||
useEffect(() => {
|
||||
document.addEventListener('keydown', openEventListener);
|
||||
return () => document.removeEventListener('keydown', openEventListener);
|
||||
}, [openEventListener]);
|
||||
|
||||
const handleNavigate = useCallback(
|
||||
(path: string) => {
|
||||
setOpen(false);
|
||||
navigate(path);
|
||||
},
|
||||
[navigate],
|
||||
);
|
||||
|
||||
const sections: SearchSection[] = [
|
||||
{
|
||||
key: 'navigation',
|
||||
heading: t('Navigation'),
|
||||
items: navigationItems.map(({ id, name, Icon }) => ({
|
||||
id,
|
||||
name,
|
||||
Icon,
|
||||
})),
|
||||
onSelect: ({ id }) => {
|
||||
const item = navigationItems.find(item => item.id === id);
|
||||
if (!!item) handleNavigate(item.path);
|
||||
},
|
||||
},
|
||||
{
|
||||
key: 'accounts',
|
||||
heading: t('Accounts'),
|
||||
items: accounts.map(account => ({
|
||||
...account,
|
||||
Icon: SvgPiggyBank,
|
||||
})),
|
||||
onSelect: ({ id }) => handleNavigate(`/accounts/${id}`),
|
||||
},
|
||||
{
|
||||
key: 'reports-custom',
|
||||
heading: t('Custom Reports'),
|
||||
items: customReports.map(report => ({
|
||||
...report,
|
||||
Icon: SvgNotesPaperText,
|
||||
})),
|
||||
onSelect: ({ id }) => handleNavigate(`/reports/custom/${id}`),
|
||||
},
|
||||
];
|
||||
|
||||
const searchLower = search.toLowerCase();
|
||||
const filteredSections = sections.map(section => ({
|
||||
...section,
|
||||
items: section.items.filter(item =>
|
||||
item.name.toLowerCase().includes(searchLower),
|
||||
),
|
||||
}));
|
||||
const hasResults = filteredSections.some(section => !!section.items.length);
|
||||
|
||||
return (
|
||||
<Command.Dialog
|
||||
vimBindings
|
||||
open={open}
|
||||
onOpenChange={setOpen}
|
||||
label={t('Command Bar')}
|
||||
aria-label={t('Command Bar')}
|
||||
shouldFilter={false}
|
||||
className={css({
|
||||
position: 'fixed',
|
||||
top: '30%',
|
||||
left: '50%',
|
||||
transform: 'translate(-50%, -30%)',
|
||||
width: '90%',
|
||||
maxWidth: '600px',
|
||||
backgroundColor: 'var(--color-modalBackground)',
|
||||
border: '1px solid var(--color-modalBorder)',
|
||||
color: 'var(--color-pageText)',
|
||||
borderRadius: '8px',
|
||||
boxShadow: '0 4px 12px rgba(0, 0, 0, 0.1)',
|
||||
overflow: 'hidden',
|
||||
zIndex: 3001,
|
||||
})}
|
||||
>
|
||||
<Command.Input
|
||||
autoFocus
|
||||
placeholder={t('Search {{budgetName}}...', { budgetName })}
|
||||
value={search}
|
||||
onValueChange={setSearch}
|
||||
className={css({
|
||||
width: '100%',
|
||||
padding: '12px 16px',
|
||||
fontSize: '1rem',
|
||||
border: 'none',
|
||||
borderBottom: '1px solid var(--color-tableBorderSeparator)',
|
||||
backgroundColor: 'transparent',
|
||||
color: 'var(--color-pageText)',
|
||||
outline: 'none',
|
||||
'&::placeholder': {
|
||||
color: 'var(--color-pageTextSubdued)',
|
||||
},
|
||||
})}
|
||||
/>
|
||||
<Command.List
|
||||
className={css({
|
||||
maxHeight: '300px',
|
||||
overflowY: 'auto',
|
||||
padding: '8px 0',
|
||||
// Hide the scrollbar
|
||||
scrollbarWidth: 'none',
|
||||
'&::-webkit-scrollbar': {
|
||||
display: 'none',
|
||||
},
|
||||
// Ensure content is still scrollable
|
||||
msOverflowStyle: 'none',
|
||||
})}
|
||||
>
|
||||
{filteredSections.map(
|
||||
section =>
|
||||
!!section.items.length && (
|
||||
<Command.Group
|
||||
key={section.key}
|
||||
heading={section.heading}
|
||||
className={css({
|
||||
padding: '0 8px',
|
||||
'& [cmdk-group-heading]': {
|
||||
padding: '8px 8px 4px',
|
||||
fontSize: '0.8rem',
|
||||
fontWeight: 500,
|
||||
color: 'var(--color-pageTextSubdued)',
|
||||
textTransform: 'uppercase',
|
||||
},
|
||||
})}
|
||||
>
|
||||
{section.items.map(({ id, name, Icon }) => (
|
||||
<Command.Item
|
||||
key={id}
|
||||
onSelect={() => section.onSelect({ id })}
|
||||
value={name}
|
||||
className={css({
|
||||
padding: '8px 16px',
|
||||
cursor: 'pointer',
|
||||
fontSize: '0.9rem',
|
||||
borderRadius: '4px',
|
||||
margin: '0',
|
||||
display: 'flex',
|
||||
alignItems: 'center',
|
||||
gap: '8px',
|
||||
// Avoid showing mouse hover styles when using keyboard navigation
|
||||
'[data-cmdk-list]:not([data-cmdk-list-nav-active]) &:hover':
|
||||
{
|
||||
backgroundColor:
|
||||
'var(--color-menuItemBackgroundHover)',
|
||||
color: 'var(--color-menuItemTextHover)',
|
||||
},
|
||||
// eslint-disable-next-line rulesdir/typography
|
||||
"&[data-selected='true']": {
|
||||
backgroundColor: 'var(--color-menuItemBackgroundHover)',
|
||||
color: 'var(--color-menuItemTextHover)',
|
||||
},
|
||||
})}
|
||||
>
|
||||
<Icon width={16} height={16} />
|
||||
{name}
|
||||
</Command.Item>
|
||||
))}
|
||||
</Command.Group>
|
||||
),
|
||||
)}
|
||||
|
||||
{!hasResults && (
|
||||
<Command.Empty
|
||||
className={css({
|
||||
padding: '16px',
|
||||
textAlign: 'center',
|
||||
fontSize: '0.9rem',
|
||||
color: 'var(--color-pageTextSubdued)',
|
||||
})}
|
||||
>
|
||||
{t('No results found')}
|
||||
</Command.Empty>
|
||||
)}
|
||||
</Command.List>
|
||||
</Command.Dialog>
|
||||
);
|
||||
}
|
||||
@@ -18,6 +18,7 @@ import * as undo from 'loot-core/platform/client/undo';
|
||||
import { UserAccessPage } from './admin/UserAccess/UserAccessPage';
|
||||
import { BankSync } from './banksync';
|
||||
import { BankSyncStatus } from './BankSyncStatus';
|
||||
import { CommandBar } from './CommandBar';
|
||||
import { GlobalKeys } from './GlobalKeys';
|
||||
import { ManageRulesPage } from './ManageRulesPage';
|
||||
import { Category } from './mobile/budget/Category';
|
||||
@@ -176,7 +177,7 @@ export function FinancesApp() {
|
||||
<View style={{ height: '100%' }}>
|
||||
<RouterBehaviors />
|
||||
<GlobalKeys />
|
||||
|
||||
<CommandBar />
|
||||
<View
|
||||
style={{
|
||||
flexDirection: 'row',
|
||||
|
||||
6
upcoming-release-notes/5076.md
Normal file
6
upcoming-release-notes/5076.md
Normal file
@@ -0,0 +1,6 @@
|
||||
---
|
||||
category: Features
|
||||
authors: [elijaholmos]
|
||||
---
|
||||
|
||||
Add command bar for quick keyboard navigation
|
||||
418
yarn.lock
418
yarn.lock
@@ -151,6 +151,7 @@ __metadata:
|
||||
"@vitejs/plugin-react-swc": "npm:^3.6.0"
|
||||
auto-text-size: "npm:^0.2.3"
|
||||
chokidar: "npm:^3.6.0"
|
||||
cmdk: "npm:^1.1.1"
|
||||
cross-env: "npm:^7.0.3"
|
||||
date-fns: "npm:^4.1.0"
|
||||
debounce: "npm:^1.2.1"
|
||||
@@ -3014,6 +3015,289 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/primitive@npm:1.1.2":
|
||||
version: 1.1.2
|
||||
resolution: "@radix-ui/primitive@npm:1.1.2"
|
||||
checksum: 10/6cb2ac097faf77b7288bdfd87d92e983e357252d00ee0d2b51ad8e7897bf9f51ec53eafd7dd64c613671a2b02cb8166177bc3de444a6560ec60835c363321c18
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-compose-refs@npm:1.1.2, @radix-ui/react-compose-refs@npm:^1.1.1":
|
||||
version: 1.1.2
|
||||
resolution: "@radix-ui/react-compose-refs@npm:1.1.2"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/9a91f0213014ffa40c5b8aae4debb993be5654217e504e35aa7422887eb2d114486d37e53c482d0fffb00cd44f51b5269fcdf397b280c71666fa11b7f32f165d
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-context@npm:1.1.2":
|
||||
version: 1.1.2
|
||||
resolution: "@radix-ui/react-context@npm:1.1.2"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/156088367de42afa3c7e3acf5f0ba7cad6b359f3d17485585e80c2418434a6ed7cac2602eb73bca265d0091a1ad380f9405c069f103983e53497097ff35ba8f2
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-dialog@npm:^1.1.6":
|
||||
version: 1.1.14
|
||||
resolution: "@radix-ui/react-dialog@npm:1.1.14"
|
||||
dependencies:
|
||||
"@radix-ui/primitive": "npm:1.1.2"
|
||||
"@radix-ui/react-compose-refs": "npm:1.1.2"
|
||||
"@radix-ui/react-context": "npm:1.1.2"
|
||||
"@radix-ui/react-dismissable-layer": "npm:1.1.10"
|
||||
"@radix-ui/react-focus-guards": "npm:1.1.2"
|
||||
"@radix-ui/react-focus-scope": "npm:1.1.7"
|
||||
"@radix-ui/react-id": "npm:1.1.1"
|
||||
"@radix-ui/react-portal": "npm:1.1.9"
|
||||
"@radix-ui/react-presence": "npm:1.1.4"
|
||||
"@radix-ui/react-primitive": "npm:2.1.3"
|
||||
"@radix-ui/react-slot": "npm:1.2.3"
|
||||
"@radix-ui/react-use-controllable-state": "npm:1.2.2"
|
||||
aria-hidden: "npm:^1.2.4"
|
||||
react-remove-scroll: "npm:^2.6.3"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
"@types/react-dom": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
"@types/react-dom":
|
||||
optional: true
|
||||
checksum: 10/b87f8a4cec795cb7f956eec669c9452ac33a3c1a77b2872193b0feb231e10c00640bc734ba4209ac1f6bbf29d2e619828834fd208179619a8e1317ff87cb6e71
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-dismissable-layer@npm:1.1.10":
|
||||
version: 1.1.10
|
||||
resolution: "@radix-ui/react-dismissable-layer@npm:1.1.10"
|
||||
dependencies:
|
||||
"@radix-ui/primitive": "npm:1.1.2"
|
||||
"@radix-ui/react-compose-refs": "npm:1.1.2"
|
||||
"@radix-ui/react-primitive": "npm:2.1.3"
|
||||
"@radix-ui/react-use-callback-ref": "npm:1.1.1"
|
||||
"@radix-ui/react-use-escape-keydown": "npm:1.1.1"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
"@types/react-dom": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
"@types/react-dom":
|
||||
optional: true
|
||||
checksum: 10/e08733ee345521a09100f922191302960d87a723d3bebb804f5659ff37f2fae57e335b2debad5ac17cb929be6b1fa8bc092c016723665ea8c90f7cf396c92d3b
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-focus-guards@npm:1.1.2":
|
||||
version: 1.1.2
|
||||
resolution: "@radix-ui/react-focus-guards@npm:1.1.2"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/618658e2b98575198b94ccfdd27f41beb37f83721c9a04617e848afbc47461124ae008d703d713b9644771d96d4852e49de322cf4be3b5f10a4f94d200db5248
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-focus-scope@npm:1.1.7":
|
||||
version: 1.1.7
|
||||
resolution: "@radix-ui/react-focus-scope@npm:1.1.7"
|
||||
dependencies:
|
||||
"@radix-ui/react-compose-refs": "npm:1.1.2"
|
||||
"@radix-ui/react-primitive": "npm:2.1.3"
|
||||
"@radix-ui/react-use-callback-ref": "npm:1.1.1"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
"@types/react-dom": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
"@types/react-dom":
|
||||
optional: true
|
||||
checksum: 10/2a7cd00e39e01756999ebf0bdb3401d6a8efa489a7b19e6b629b40bad3022b7b1f616555ccb4b0505bc0ba53e13a1fb51be905db138b16ec39c4fe319fe701d3
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-id@npm:1.1.1, @radix-ui/react-id@npm:^1.1.0":
|
||||
version: 1.1.1
|
||||
resolution: "@radix-ui/react-id@npm:1.1.1"
|
||||
dependencies:
|
||||
"@radix-ui/react-use-layout-effect": "npm:1.1.1"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/8d68e200778eb3038906870fc869b3d881f4a46715fb20cddd9c76cba42fdaaa4810a3365b6ec2daf0f185b9201fc99d009167f59c7921bc3a139722c2e976db
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-portal@npm:1.1.9":
|
||||
version: 1.1.9
|
||||
resolution: "@radix-ui/react-portal@npm:1.1.9"
|
||||
dependencies:
|
||||
"@radix-ui/react-primitive": "npm:2.1.3"
|
||||
"@radix-ui/react-use-layout-effect": "npm:1.1.1"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
"@types/react-dom": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
"@types/react-dom":
|
||||
optional: true
|
||||
checksum: 10/bd6be39bf021d5c917e2474ecba411e2625171f7ef96862b9af04bbd68833bb3662a7f1fbdeb5a7a237111b10e811e76d2cd03e957dadd6e668ef16541bfbd68
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-presence@npm:1.1.4":
|
||||
version: 1.1.4
|
||||
resolution: "@radix-ui/react-presence@npm:1.1.4"
|
||||
dependencies:
|
||||
"@radix-ui/react-compose-refs": "npm:1.1.2"
|
||||
"@radix-ui/react-use-layout-effect": "npm:1.1.1"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
"@types/react-dom": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
"@types/react-dom":
|
||||
optional: true
|
||||
checksum: 10/ba01f385f6beedba7bf50ffd4aca8091554a67aee2b7252605876136155ceb2fcf1b627dccaf2e49032231eda271fe0e8915040729da9d1f95d08b854d815305
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-primitive@npm:2.1.3, @radix-ui/react-primitive@npm:^2.0.2":
|
||||
version: 2.1.3
|
||||
resolution: "@radix-ui/react-primitive@npm:2.1.3"
|
||||
dependencies:
|
||||
"@radix-ui/react-slot": "npm:1.2.3"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
"@types/react-dom": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
react-dom: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
"@types/react-dom":
|
||||
optional: true
|
||||
checksum: 10/1dbbf932a3527f4e62f210bb72944eff605c3e38c8d3275ed5a5c570c02820ab156169756a65ad9a638d2089a828a04a7903795377384e98c87d0ca456303253
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-slot@npm:1.2.3":
|
||||
version: 1.2.3
|
||||
resolution: "@radix-ui/react-slot@npm:1.2.3"
|
||||
dependencies:
|
||||
"@radix-ui/react-compose-refs": "npm:1.1.2"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/fe484c2741e31d9c20a8fb53c5790a73c0664e2bea35e27f4d484a90c42135fcfffe11a08abfcacb7a8ee2faf013471f0e856818f3ddac8ac51ceb8869e0fd08
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-use-callback-ref@npm:1.1.1":
|
||||
version: 1.1.1
|
||||
resolution: "@radix-ui/react-use-callback-ref@npm:1.1.1"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/cde8c40f1d4e79e6e71470218163a746858304bad03758ac84dc1f94247a046478e8e397518350c8d6609c84b7e78565441d7505bb3ed573afce82cfdcd19faf
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-use-controllable-state@npm:1.2.2":
|
||||
version: 1.2.2
|
||||
resolution: "@radix-ui/react-use-controllable-state@npm:1.2.2"
|
||||
dependencies:
|
||||
"@radix-ui/react-use-effect-event": "npm:0.0.2"
|
||||
"@radix-ui/react-use-layout-effect": "npm:1.1.1"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/a100bff3ddecb753dab17444147273c9f70046c5949712c52174b259622eaef12acbf7ebcf289bae4e714eb84d0a7317c1aa44064cd997f327d77b62bc732a7c
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-use-effect-event@npm:0.0.2":
|
||||
version: 0.0.2
|
||||
resolution: "@radix-ui/react-use-effect-event@npm:0.0.2"
|
||||
dependencies:
|
||||
"@radix-ui/react-use-layout-effect": "npm:1.1.1"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/5a1950a30a399ea7e4b98154da9f536737a610de80189b7aacd4f064a89a3cd0d2a48571d527435227252e72e872bdb544ff6ffcfbdd02de2efd011be4aaa902
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-use-escape-keydown@npm:1.1.1":
|
||||
version: 1.1.1
|
||||
resolution: "@radix-ui/react-use-escape-keydown@npm:1.1.1"
|
||||
dependencies:
|
||||
"@radix-ui/react-use-callback-ref": "npm:1.1.1"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/0eb0756c2c55ddcde9ff01446ab01c085ab2bf799173e97db7ef5f85126f9e8600225570801a1f64740e6d14c39ffe8eed7c14d29737345a5797f4622ac96f6f
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@radix-ui/react-use-layout-effect@npm:1.1.1":
|
||||
version: 1.1.1
|
||||
resolution: "@radix-ui/react-use-layout-effect@npm:1.1.1"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/bad2ba4f206e6255263582bedfb7868773c400836f9a1b423c0b464ffe4a17e13d3f306d1ce19cf7a19a492e9d0e49747464f2656451bb7c6a99f5a57bd34de2
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"@react-aria/autocomplete@npm:3.0.0-beta.2":
|
||||
version: 3.0.0-beta.2
|
||||
resolution: "@react-aria/autocomplete@npm:3.0.0-beta.2"
|
||||
@@ -7419,6 +7703,15 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"aria-hidden@npm:^1.2.4":
|
||||
version: 1.2.6
|
||||
resolution: "aria-hidden@npm:1.2.6"
|
||||
dependencies:
|
||||
tslib: "npm:^2.0.0"
|
||||
checksum: 10/1914e5a36225dccdb29f0b88cc891eeca736cdc5b0c905ab1437b90b28b5286263ed3a221c75b7dc788f25b942367be0044b2ac8ccf073a72e07a50b1d964202
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"aria-query@npm:5.3.0":
|
||||
version: 5.3.0
|
||||
resolution: "aria-query@npm:5.3.0"
|
||||
@@ -8514,6 +8807,21 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"cmdk@npm:^1.1.1":
|
||||
version: 1.1.1
|
||||
resolution: "cmdk@npm:1.1.1"
|
||||
dependencies:
|
||||
"@radix-ui/react-compose-refs": "npm:^1.1.1"
|
||||
"@radix-ui/react-dialog": "npm:^1.1.6"
|
||||
"@radix-ui/react-id": "npm:^1.1.0"
|
||||
"@radix-ui/react-primitive": "npm:^2.0.2"
|
||||
peerDependencies:
|
||||
react: ^18 || ^19 || ^19.0.0-rc
|
||||
react-dom: ^18 || ^19 || ^19.0.0-rc
|
||||
checksum: 10/8f52beee4a6289d67138bdeb3b9833fb67fb06cfea53968803f31b6a39b09ca3c8698a302c6bf8286ee6cc0c8f5dc2c4e5a398450f48db7b9f2d1657f3c4bde2
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"color-convert@npm:^1.9.0, color-convert@npm:^1.9.3":
|
||||
version: 1.9.3
|
||||
resolution: "color-convert@npm:1.9.3"
|
||||
@@ -9452,6 +9760,13 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"detect-node-es@npm:^1.1.0":
|
||||
version: 1.1.0
|
||||
resolution: "detect-node-es@npm:1.1.0"
|
||||
checksum: 10/e46307d7264644975b71c104b9f028ed1d3d34b83a15b8a22373640ce5ea630e5640b1078b8ea15f202b54641da71e4aa7597093bd4b91f113db520a26a37449
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"detect-node@npm:^2.0.4":
|
||||
version: 2.1.0
|
||||
resolution: "detect-node@npm:2.1.0"
|
||||
@@ -11394,6 +11709,13 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"get-nonce@npm:^1.0.0":
|
||||
version: 1.0.1
|
||||
resolution: "get-nonce@npm:1.0.1"
|
||||
checksum: 10/ad5104871d114a694ecc506a2d406e2331beccb961fe1e110dc25556b38bcdbf399a823a8a375976cd8889668156a9561e12ebe3fa6a4c6ba169c8466c2ff868
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"get-own-enumerable-property-symbols@npm:^3.0.0":
|
||||
version: 3.0.2
|
||||
resolution: "get-own-enumerable-property-symbols@npm:3.0.2"
|
||||
@@ -16415,6 +16737,41 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"react-remove-scroll-bar@npm:^2.3.7":
|
||||
version: 2.3.8
|
||||
resolution: "react-remove-scroll-bar@npm:2.3.8"
|
||||
dependencies:
|
||||
react-style-singleton: "npm:^2.2.2"
|
||||
tslib: "npm:^2.0.0"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/6c0f8cff98b9f49a4ee2263f1eedf12926dced5ce220fbe83bd93544460e2a7ec8ec39b35d1b2a75d2fced0b2d64afeb8e66f830431ca896e05a20585f9fc350
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"react-remove-scroll@npm:^2.6.3":
|
||||
version: 2.7.0
|
||||
resolution: "react-remove-scroll@npm:2.7.0"
|
||||
dependencies:
|
||||
react-remove-scroll-bar: "npm:^2.3.7"
|
||||
react-style-singleton: "npm:^2.2.3"
|
||||
tslib: "npm:^2.1.0"
|
||||
use-callback-ref: "npm:^1.3.3"
|
||||
use-sidecar: "npm:^1.1.3"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/6fa65227b101f097be17126dbefdaaa170b39f8e4f53b4e90f058501e14047215de7eea7ce4516aa18b9daaee5b32e84abf0360dd7f0156d8017da64c8cc84e0
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"react-resizable@npm:^3.0.5":
|
||||
version: 3.0.5
|
||||
resolution: "react-resizable@npm:3.0.5"
|
||||
@@ -16528,6 +16885,22 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"react-style-singleton@npm:^2.2.2, react-style-singleton@npm:^2.2.3":
|
||||
version: 2.2.3
|
||||
resolution: "react-style-singleton@npm:2.2.3"
|
||||
dependencies:
|
||||
get-nonce: "npm:^1.0.0"
|
||||
tslib: "npm:^2.0.0"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/62498094ff3877a37f351b29e6cad9e38b2eb1ac3c0cb27ebf80aee96554f80b35e17bdb552bcd7ac8b7cb9904fea93ea5668f2057c73d38f90b5d46bb9b27ab
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"react-swipeable@npm:^7.0.2":
|
||||
version: 7.0.2
|
||||
resolution: "react-swipeable@npm:7.0.2"
|
||||
@@ -18918,6 +19291,13 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"tslib@npm:^2.0.0, tslib@npm:^2.1.0, tslib@npm:^2.8.0":
|
||||
version: 2.8.1
|
||||
resolution: "tslib@npm:2.8.1"
|
||||
checksum: 10/3e2e043d5c2316461cb54e5c7fe02c30ef6dccb3384717ca22ae5c6b5bc95232a6241df19c622d9c73b809bea33b187f6dbc73030963e29950c2141bc32a79f7
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"tslib@npm:^2.0.3, tslib@npm:^2.3.0, tslib@npm:^2.4.0":
|
||||
version: 2.6.2
|
||||
resolution: "tslib@npm:2.6.2"
|
||||
@@ -18925,13 +19305,6 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"tslib@npm:^2.8.0":
|
||||
version: 2.8.1
|
||||
resolution: "tslib@npm:2.8.1"
|
||||
checksum: 10/3e2e043d5c2316461cb54e5c7fe02c30ef6dccb3384717ca22ae5c6b5bc95232a6241df19c622d9c73b809bea33b187f6dbc73030963e29950c2141bc32a79f7
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"tunnel-agent@npm:^0.6.0":
|
||||
version: 0.6.0
|
||||
resolution: "tunnel-agent@npm:0.6.0"
|
||||
@@ -19497,6 +19870,37 @@ __metadata:
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"use-callback-ref@npm:^1.3.3":
|
||||
version: 1.3.3
|
||||
resolution: "use-callback-ref@npm:1.3.3"
|
||||
dependencies:
|
||||
tslib: "npm:^2.0.0"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/adf06a7b6a27d3651c325ac9b66d2b82ccacaed7450b85b211d123e91d9a23cb5a587fcc6db5b4fd07ac7233e5abf024d30cf02ddc2ec46bca712151c0836151
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"use-sidecar@npm:^1.1.3":
|
||||
version: 1.1.3
|
||||
resolution: "use-sidecar@npm:1.1.3"
|
||||
dependencies:
|
||||
detect-node-es: "npm:^1.1.0"
|
||||
tslib: "npm:^2.0.0"
|
||||
peerDependencies:
|
||||
"@types/react": "*"
|
||||
react: ^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 || ^19.0.0-rc
|
||||
peerDependenciesMeta:
|
||||
"@types/react":
|
||||
optional: true
|
||||
checksum: 10/2fec05eb851cdfc4a4657b1dfb434e686f346c3265ffc9db8a974bb58f8128bd4a708a3cc00e8f51655fccf81822ed4419ebed42f41610589e3aab0cf2492edb
|
||||
languageName: node
|
||||
linkType: hard
|
||||
|
||||
"use-sync-external-store@npm:^1.4.0":
|
||||
version: 1.4.0
|
||||
resolution: "use-sync-external-store@npm:1.4.0"
|
||||
|
||||
Reference in New Issue
Block a user