mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-12 12:28:42 +00:00
feat: init @toeverything/hooks package (#1788)
This commit is contained in:
@@ -27,6 +27,7 @@
|
|||||||
"@emotion/styled": "^11.10.6",
|
"@emotion/styled": "^11.10.6",
|
||||||
"@mui/material": "^5.11.15",
|
"@mui/material": "^5.11.15",
|
||||||
"@sentry/nextjs": "^7.46.0",
|
"@sentry/nextjs": "^7.46.0",
|
||||||
|
"@toeverything/hooks": "workspace:*",
|
||||||
"cmdk": "^0.2.0",
|
"cmdk": "^0.2.0",
|
||||||
"css-spring": "^4.1.0",
|
"css-spring": "^4.1.0",
|
||||||
"dayjs": "^1.11.7",
|
"dayjs": "^1.11.7",
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
import { Button, Input, Modal, ModalCloseButton } from '@affine/component';
|
import { Button, Input, Modal, ModalCloseButton } from '@affine/component';
|
||||||
import { Trans, useTranslation } from '@affine/i18n';
|
import { Trans, useTranslation } from '@affine/i18n';
|
||||||
import { WorkspaceFlavour } from '@affine/workspace/type';
|
import { WorkspaceFlavour } from '@affine/workspace/type';
|
||||||
|
import { useBlockSuiteWorkspaceName } from '@toeverything/hooks/use-blocksuite-workspace-name';
|
||||||
import { useCallback, useState } from 'react';
|
import { useCallback, useState } from 'react';
|
||||||
|
|
||||||
import { useBlockSuiteWorkspaceName } from '../../../../../../hooks/use-blocksuite-workspace-name';
|
|
||||||
import type { AffineOfficialWorkspace } from '../../../../../../shared';
|
import type { AffineOfficialWorkspace } from '../../../../../../shared';
|
||||||
import {
|
import {
|
||||||
StyledButtonContent,
|
StyledButtonContent,
|
||||||
|
|||||||
@@ -1,12 +1,12 @@
|
|||||||
import { Button, FlexWrapper, MuiFade } from '@affine/component';
|
import { Button, FlexWrapper, MuiFade } from '@affine/component';
|
||||||
import { useTranslation } from '@affine/i18n';
|
import { useTranslation } from '@affine/i18n';
|
||||||
import { WorkspaceFlavour } from '@affine/workspace/type';
|
import { WorkspaceFlavour } from '@affine/workspace/type';
|
||||||
|
import { useBlockSuiteWorkspaceName } from '@toeverything/hooks/use-blocksuite-workspace-name';
|
||||||
import type React from 'react';
|
import type React from 'react';
|
||||||
import { useState } from 'react';
|
import { useState } from 'react';
|
||||||
|
|
||||||
import { useIsWorkspaceOwner } from '../../../../../hooks/affine/use-is-workspace-owner';
|
import { useIsWorkspaceOwner } from '../../../../../hooks/affine/use-is-workspace-owner';
|
||||||
import { useBlockSuiteWorkspaceAvatarUrl } from '../../../../../hooks/use-blocksuite-workspace-avatar-url';
|
import { useBlockSuiteWorkspaceAvatarUrl } from '../../../../../hooks/use-blocksuite-workspace-avatar-url';
|
||||||
import { useBlockSuiteWorkspaceName } from '../../../../../hooks/use-blocksuite-workspace-name';
|
|
||||||
import { Upload } from '../../../../pure/file-upload';
|
import { Upload } from '../../../../pure/file-upload';
|
||||||
import {
|
import {
|
||||||
CloudWorkspaceIcon,
|
CloudWorkspaceIcon,
|
||||||
|
|||||||
@@ -1,11 +1,11 @@
|
|||||||
import { Content, FlexWrapper, styled } from '@affine/component';
|
import { Content, FlexWrapper, styled } from '@affine/component';
|
||||||
import { Trans, useTranslation } from '@affine/i18n';
|
import { Trans, useTranslation } from '@affine/i18n';
|
||||||
import { WorkspaceFlavour } from '@affine/workspace/type';
|
import { WorkspaceFlavour } from '@affine/workspace/type';
|
||||||
|
import { useBlockSuiteWorkspaceName } from '@toeverything/hooks/use-blocksuite-workspace-name';
|
||||||
import type React from 'react';
|
import type React from 'react';
|
||||||
|
|
||||||
import { useCurrentUser } from '../../../../../hooks/current/use-current-user';
|
import { useCurrentUser } from '../../../../../hooks/current/use-current-user';
|
||||||
import { useBlockSuiteWorkspaceAvatarUrl } from '../../../../../hooks/use-blocksuite-workspace-avatar-url';
|
import { useBlockSuiteWorkspaceAvatarUrl } from '../../../../../hooks/use-blocksuite-workspace-avatar-url';
|
||||||
import { useBlockSuiteWorkspaceName } from '../../../../../hooks/use-blocksuite-workspace-name';
|
|
||||||
import { WorkspaceAvatar } from '../../../../pure/footer';
|
import { WorkspaceAvatar } from '../../../../pure/footer';
|
||||||
import type { PanelProps } from '../../index';
|
import type { PanelProps } from '../../index';
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import type { EditorContainer } from '@blocksuite/editor';
|
import type { EditorContainer } from '@blocksuite/editor';
|
||||||
import type { Page } from '@blocksuite/store';
|
import type { Page } from '@blocksuite/store';
|
||||||
import { assertExists } from '@blocksuite/store';
|
import { assertExists } from '@blocksuite/store';
|
||||||
|
import { useBlockSuiteWorkspacePageTitle } from '@toeverything/hooks/use-blocksuite-workspace-page-title';
|
||||||
import { useAtomValue, useSetAtom } from 'jotai';
|
import { useAtomValue, useSetAtom } from 'jotai';
|
||||||
import dynamic from 'next/dynamic';
|
import dynamic from 'next/dynamic';
|
||||||
import Head from 'next/head';
|
import Head from 'next/head';
|
||||||
@@ -8,7 +9,6 @@ import type React from 'react';
|
|||||||
import { useCallback } from 'react';
|
import { useCallback } from 'react';
|
||||||
|
|
||||||
import { currentEditorAtom, workspacePreferredModeAtom } from '../atoms';
|
import { currentEditorAtom, workspacePreferredModeAtom } from '../atoms';
|
||||||
import { useBlockSuiteWorkspacePageTitle } from '../hooks/use-blocksuite-workspace-page-title';
|
|
||||||
import { usePageMeta } from '../hooks/use-page-meta';
|
import { usePageMeta } from '../hooks/use-page-meta';
|
||||||
import type { BlockSuiteWorkspace } from '../shared';
|
import type { BlockSuiteWorkspace } from '../shared';
|
||||||
import { PageNotFoundError } from './affine/affine-error-eoundary';
|
import { PageNotFoundError } from './affine/affine-error-eoundary';
|
||||||
|
|||||||
@@ -2,10 +2,10 @@ import { useTranslation } from '@affine/i18n';
|
|||||||
import { PermissionType } from '@affine/workspace/affine/api';
|
import { PermissionType } from '@affine/workspace/affine/api';
|
||||||
import { WorkspaceFlavour } from '@affine/workspace/type';
|
import { WorkspaceFlavour } from '@affine/workspace/type';
|
||||||
import { SettingsIcon } from '@blocksuite/icons';
|
import { SettingsIcon } from '@blocksuite/icons';
|
||||||
|
import { useBlockSuiteWorkspaceName } from '@toeverything/hooks/use-blocksuite-workspace-name';
|
||||||
import type React from 'react';
|
import type React from 'react';
|
||||||
import { useCallback } from 'react';
|
import { useCallback } from 'react';
|
||||||
|
|
||||||
import { useBlockSuiteWorkspaceName } from '../../../hooks/use-blocksuite-workspace-name';
|
|
||||||
import type { AllWorkspace } from '../../../shared';
|
import type { AllWorkspace } from '../../../shared';
|
||||||
import {
|
import {
|
||||||
CloudWorkspaceIcon,
|
CloudWorkspaceIcon,
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
import { CloudWorkspaceIcon, LocalWorkspaceIcon } from '@blocksuite/icons';
|
import { CloudWorkspaceIcon, LocalWorkspaceIcon } from '@blocksuite/icons';
|
||||||
|
import { useBlockSuiteWorkspaceName } from '@toeverything/hooks/use-blocksuite-workspace-name';
|
||||||
import type React from 'react';
|
import type React from 'react';
|
||||||
|
|
||||||
import { useCurrentWorkspace } from '../../../../hooks/current/use-current-workspace';
|
import { useCurrentWorkspace } from '../../../../hooks/current/use-current-workspace';
|
||||||
import { useBlockSuiteWorkspaceName } from '../../../../hooks/use-blocksuite-workspace-name';
|
|
||||||
import type { AllWorkspace } from '../../../../shared';
|
import type { AllWorkspace } from '../../../../shared';
|
||||||
import { WorkspaceAvatar } from '../../workspace-avatar';
|
import { WorkspaceAvatar } from '../../workspace-avatar';
|
||||||
import {
|
import {
|
||||||
|
|||||||
@@ -37,7 +37,6 @@ import {
|
|||||||
currentWorkspaceAtom,
|
currentWorkspaceAtom,
|
||||||
useCurrentWorkspace,
|
useCurrentWorkspace,
|
||||||
} from '../current/use-current-workspace';
|
} from '../current/use-current-workspace';
|
||||||
import { useBlockSuiteWorkspaceName } from '../use-blocksuite-workspace-name';
|
|
||||||
import { usePageMeta, usePageMetaHelper } from '../use-page-meta';
|
import { usePageMeta, usePageMetaHelper } from '../use-page-meta';
|
||||||
import {
|
import {
|
||||||
REDIRECT_TIMEOUT,
|
REDIRECT_TIMEOUT,
|
||||||
@@ -302,21 +301,6 @@ describe('useSyncRouterWithCurrentWorkspaceAndPage', () => {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('useBlockSuiteWorkspaceName', () => {
|
|
||||||
test('basic', async () => {
|
|
||||||
blockSuiteWorkspace.meta.setName('test 1');
|
|
||||||
const workspaceNameHook = renderHook(() =>
|
|
||||||
useBlockSuiteWorkspaceName(blockSuiteWorkspace)
|
|
||||||
);
|
|
||||||
expect(workspaceNameHook.result.current[0]).toBe('test 1');
|
|
||||||
blockSuiteWorkspace.meta.setName('test 2');
|
|
||||||
workspaceNameHook.rerender();
|
|
||||||
expect(workspaceNameHook.result.current[0]).toBe('test 2');
|
|
||||||
workspaceNameHook.result.current[1]('test 3');
|
|
||||||
expect(blockSuiteWorkspace.meta.name).toBe('test 3');
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('useRecentlyViewed', () => {
|
describe('useRecentlyViewed', () => {
|
||||||
test('basic', async () => {
|
test('basic', async () => {
|
||||||
const { ProviderWrapper, store } = await getJotaiContext();
|
const { ProviderWrapper, store } = await getJotaiContext();
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
import { Breadcrumbs, IconButton, ListSkeleton } from '@affine/component';
|
import { Breadcrumbs, IconButton, ListSkeleton } from '@affine/component';
|
||||||
import { SearchIcon } from '@blocksuite/icons';
|
import { SearchIcon } from '@blocksuite/icons';
|
||||||
|
import { useBlockSuiteWorkspaceName } from '@toeverything/hooks/use-blocksuite-workspace-name';
|
||||||
import { useAtomValue, useSetAtom } from 'jotai';
|
import { useAtomValue, useSetAtom } from 'jotai';
|
||||||
import dynamic from 'next/dynamic';
|
import dynamic from 'next/dynamic';
|
||||||
import { useRouter } from 'next/router';
|
import { useRouter } from 'next/router';
|
||||||
@@ -16,7 +17,6 @@ import { StyledTableContainer } from '../../components/blocksuite/block-suite-pa
|
|||||||
import { WorkspaceAvatar } from '../../components/pure/footer';
|
import { WorkspaceAvatar } from '../../components/pure/footer';
|
||||||
import { PageLoading } from '../../components/pure/loading';
|
import { PageLoading } from '../../components/pure/loading';
|
||||||
import { useBlockSuiteWorkspaceAvatarUrl } from '../../hooks/use-blocksuite-workspace-avatar-url';
|
import { useBlockSuiteWorkspaceAvatarUrl } from '../../hooks/use-blocksuite-workspace-avatar-url';
|
||||||
import { useBlockSuiteWorkspaceName } from '../../hooks/use-blocksuite-workspace-name';
|
|
||||||
import { PublicWorkspaceLayout } from '../../layouts/public-workspace-layout';
|
import { PublicWorkspaceLayout } from '../../layouts/public-workspace-layout';
|
||||||
import type { NextPageWithLayout } from '../../shared';
|
import type { NextPageWithLayout } from '../../shared';
|
||||||
import { NavContainer, StyledBreadcrumbs } from './[workspaceId]/[pageId]';
|
import { NavContainer, StyledBreadcrumbs } from './[workspaceId]/[pageId]';
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
import { Breadcrumbs, displayFlex, styled } from '@affine/component';
|
import { Breadcrumbs, displayFlex, styled } from '@affine/component';
|
||||||
import { useTranslation } from '@affine/i18n';
|
import { useTranslation } from '@affine/i18n';
|
||||||
import { PageIcon } from '@blocksuite/icons';
|
import { PageIcon } from '@blocksuite/icons';
|
||||||
|
import { useBlockSuiteWorkspaceName } from '@toeverything/hooks/use-blocksuite-workspace-name';
|
||||||
import { useAtomValue, useSetAtom } from 'jotai';
|
import { useAtomValue, useSetAtom } from 'jotai';
|
||||||
import Link from 'next/link';
|
import Link from 'next/link';
|
||||||
import { useRouter } from 'next/router';
|
import { useRouter } from 'next/router';
|
||||||
@@ -16,7 +17,6 @@ import { PageDetailEditor } from '../../../components/page-detail-editor';
|
|||||||
import { WorkspaceAvatar } from '../../../components/pure/footer';
|
import { WorkspaceAvatar } from '../../../components/pure/footer';
|
||||||
import { PageLoading } from '../../../components/pure/loading';
|
import { PageLoading } from '../../../components/pure/loading';
|
||||||
import { useBlockSuiteWorkspaceAvatarUrl } from '../../../hooks/use-blocksuite-workspace-avatar-url';
|
import { useBlockSuiteWorkspaceAvatarUrl } from '../../../hooks/use-blocksuite-workspace-avatar-url';
|
||||||
import { useBlockSuiteWorkspaceName } from '../../../hooks/use-blocksuite-workspace-name';
|
|
||||||
import { PublicWorkspaceLayout } from '../../../layouts/public-workspace-layout';
|
import { PublicWorkspaceLayout } from '../../../layouts/public-workspace-layout';
|
||||||
import type { NextPageWithLayout } from '../../../shared';
|
import type { NextPageWithLayout } from '../../../shared';
|
||||||
import { initPage } from '../../../utils';
|
import { initPage } from '../../../utils';
|
||||||
|
|||||||
7
packages/hooks/package.json
Normal file
7
packages/hooks/package.json
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
{
|
||||||
|
"name": "@toeverything/hooks",
|
||||||
|
"exports": {
|
||||||
|
"./*": "./src/*"
|
||||||
|
},
|
||||||
|
"private": true
|
||||||
|
}
|
||||||
62
packages/hooks/src/__tests__/index.spec.ts
Normal file
62
packages/hooks/src/__tests__/index.spec.ts
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
/**
|
||||||
|
* @vitest-environment happy-dom
|
||||||
|
*/
|
||||||
|
import 'fake-indexeddb/auto';
|
||||||
|
|
||||||
|
import { __unstableSchemas, AffineSchemas } from '@blocksuite/blocks/models';
|
||||||
|
import type { Page } from '@blocksuite/store';
|
||||||
|
import { assertExists } from '@blocksuite/store';
|
||||||
|
import { Workspace as BlockSuiteWorkspace } from '@blocksuite/store';
|
||||||
|
import { renderHook } from '@testing-library/react';
|
||||||
|
import { useBlockSuiteWorkspacePageTitle } from '@toeverything/hooks/use-blocksuite-workspace-page-title';
|
||||||
|
import { describe, expect, test } from 'vitest';
|
||||||
|
import { beforeEach } from 'vitest';
|
||||||
|
|
||||||
|
import { useBlockSuiteWorkspaceName } from '../use-blocksuite-workspace-name';
|
||||||
|
|
||||||
|
let blockSuiteWorkspace: BlockSuiteWorkspace;
|
||||||
|
|
||||||
|
beforeEach(async () => {
|
||||||
|
blockSuiteWorkspace = new BlockSuiteWorkspace({ id: 'test' })
|
||||||
|
.register(AffineSchemas)
|
||||||
|
.register(__unstableSchemas);
|
||||||
|
const initPage = (page: Page) => {
|
||||||
|
expect(page).not.toBeNull();
|
||||||
|
assertExists(page);
|
||||||
|
const pageBlockId = page.addBlock('affine:page', {
|
||||||
|
title: new page.Text(''),
|
||||||
|
});
|
||||||
|
const frameId = page.addBlock('affine:frame', {}, pageBlockId);
|
||||||
|
page.addBlock('affine:paragraph', {}, frameId);
|
||||||
|
};
|
||||||
|
initPage(blockSuiteWorkspace.createPage('page0'));
|
||||||
|
initPage(blockSuiteWorkspace.createPage('page1'));
|
||||||
|
initPage(blockSuiteWorkspace.createPage('page2'));
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('useBlockSuiteWorkspaceName', () => {
|
||||||
|
test('basic', async () => {
|
||||||
|
blockSuiteWorkspace.meta.setName('test 1');
|
||||||
|
const workspaceNameHook = renderHook(() =>
|
||||||
|
useBlockSuiteWorkspaceName(blockSuiteWorkspace)
|
||||||
|
);
|
||||||
|
expect(workspaceNameHook.result.current[0]).toBe('test 1');
|
||||||
|
blockSuiteWorkspace.meta.setName('test 2');
|
||||||
|
workspaceNameHook.rerender();
|
||||||
|
expect(workspaceNameHook.result.current[0]).toBe('test 2');
|
||||||
|
workspaceNameHook.result.current[1]('test 3');
|
||||||
|
expect(blockSuiteWorkspace.meta.name).toBe('test 3');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('useBlockSuiteWorkspacePageTitle', () => {
|
||||||
|
test('basic', async () => {
|
||||||
|
const pageTitleHook = renderHook(() =>
|
||||||
|
useBlockSuiteWorkspacePageTitle(blockSuiteWorkspace, 'page0')
|
||||||
|
);
|
||||||
|
expect(pageTitleHook.result.current).toBe('Untitled');
|
||||||
|
blockSuiteWorkspace.setPageMeta('page0', { title: '1' });
|
||||||
|
pageTitleHook.rerender();
|
||||||
|
expect(pageTitleHook.result.current).toBe('1');
|
||||||
|
});
|
||||||
|
});
|
||||||
@@ -1,11 +1,10 @@
|
|||||||
import { UNTITLED_WORKSPACE_NAME } from '@affine/env';
|
import { UNTITLED_WORKSPACE_NAME } from '@affine/env';
|
||||||
|
import type { Workspace } from '@blocksuite/store';
|
||||||
import { assertExists } from '@blocksuite/store';
|
import { assertExists } from '@blocksuite/store';
|
||||||
import { useCallback, useEffect, useState } from 'react';
|
import { useCallback, useEffect, useState } from 'react';
|
||||||
|
|
||||||
import type { BlockSuiteWorkspace } from '../shared';
|
|
||||||
|
|
||||||
export function useBlockSuiteWorkspaceName(
|
export function useBlockSuiteWorkspaceName(
|
||||||
blockSuiteWorkspace: BlockSuiteWorkspace | null
|
blockSuiteWorkspace: Workspace | null
|
||||||
) {
|
) {
|
||||||
const [name, set] = useState(
|
const [name, set] = useState(
|
||||||
() => blockSuiteWorkspace?.meta.name ?? UNTITLED_WORKSPACE_NAME
|
() => blockSuiteWorkspace?.meta.name ?? UNTITLED_WORKSPACE_NAME
|
||||||
@@ -1,21 +1,20 @@
|
|||||||
|
import type { Workspace } from '@blocksuite/store';
|
||||||
import { assertExists } from '@blocksuite/store';
|
import { assertExists } from '@blocksuite/store';
|
||||||
import { useEffect, useState } from 'react';
|
import { useEffect, useState } from 'react';
|
||||||
|
|
||||||
import type { BlockSuiteWorkspace } from '../shared';
|
|
||||||
|
|
||||||
export function useBlockSuiteWorkspacePageTitle(
|
export function useBlockSuiteWorkspacePageTitle(
|
||||||
blockSuiteWorkspace: BlockSuiteWorkspace,
|
blockSuiteWorkspace: Workspace,
|
||||||
pageId: string
|
pageId: string
|
||||||
) {
|
) {
|
||||||
const page = blockSuiteWorkspace.getPage(pageId);
|
const page = blockSuiteWorkspace.getPage(pageId);
|
||||||
const [title, setTitle] = useState(() => page?.meta.title || 'AFFiNE');
|
const [title, setTitle] = useState(() => page?.meta.title || 'AFFiNE');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const page = blockSuiteWorkspace.getPage(pageId);
|
const page = blockSuiteWorkspace.getPage(pageId);
|
||||||
setTitle(page?.meta.title || 'AFFiNE');
|
setTitle(page?.meta.title || 'Untitled');
|
||||||
const dispose = blockSuiteWorkspace.meta.pageMetasUpdated.on(() => {
|
const dispose = blockSuiteWorkspace.meta.pageMetasUpdated.on(() => {
|
||||||
const page = blockSuiteWorkspace.getPage(pageId);
|
const page = blockSuiteWorkspace.getPage(pageId);
|
||||||
assertExists(page);
|
assertExists(page);
|
||||||
setTitle(page?.meta.title || 'AFFiNE');
|
setTitle(page?.meta.title || 'Untitled');
|
||||||
});
|
});
|
||||||
return () => {
|
return () => {
|
||||||
dispose.dispose();
|
dispose.dispose();
|
||||||
4
packages/hooks/tsconfig.json
Normal file
4
packages/hooks/tsconfig.json
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
{
|
||||||
|
"extends": "../../tsconfig.json",
|
||||||
|
"include": ["./src"]
|
||||||
|
}
|
||||||
@@ -28,7 +28,8 @@
|
|||||||
"@affine/utils": ["./packages/utils"],
|
"@affine/utils": ["./packages/utils"],
|
||||||
"@affine/workspace/*": ["./packages/workspace/src/*"],
|
"@affine/workspace/*": ["./packages/workspace/src/*"],
|
||||||
"@affine-test/fixtures/*": ["./tests/fixtures/*"],
|
"@affine-test/fixtures/*": ["./tests/fixtures/*"],
|
||||||
"@toeverything/y-indexeddb": ["./packages/y-indexeddb/src"]
|
"@toeverything/y-indexeddb": ["./packages/y-indexeddb/src"],
|
||||||
|
"@toeverything/hooks/*": ["./packages/hooks/src/*"]
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"references": [
|
"references": [
|
||||||
@@ -44,6 +45,9 @@
|
|||||||
{
|
{
|
||||||
"path": "./packages/component"
|
"path": "./packages/component"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"path": "./packages/hooks"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"path": "./packages/i18n"
|
"path": "./packages/i18n"
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -203,6 +203,7 @@ __metadata:
|
|||||||
"@sentry/nextjs": ^7.46.0
|
"@sentry/nextjs": ^7.46.0
|
||||||
"@swc-jotai/debug-label": ^0.0.9
|
"@swc-jotai/debug-label": ^0.0.9
|
||||||
"@swc-jotai/react-refresh": ^0.0.7
|
"@swc-jotai/react-refresh": ^0.0.7
|
||||||
|
"@toeverything/hooks": "workspace:*"
|
||||||
"@types/react": ^18.0.31
|
"@types/react": ^18.0.31
|
||||||
"@types/react-dom": ^18.0.11
|
"@types/react-dom": ^18.0.11
|
||||||
"@types/webpack-env": ^1.18.0
|
"@types/webpack-env": ^1.18.0
|
||||||
@@ -6148,6 +6149,12 @@ __metadata:
|
|||||||
languageName: node
|
languageName: node
|
||||||
linkType: hard
|
linkType: hard
|
||||||
|
|
||||||
|
"@toeverything/hooks@workspace:*, @toeverything/hooks@workspace:packages/hooks":
|
||||||
|
version: 0.0.0-use.local
|
||||||
|
resolution: "@toeverything/hooks@workspace:packages/hooks"
|
||||||
|
languageName: unknown
|
||||||
|
linkType: soft
|
||||||
|
|
||||||
"@toeverything/y-indexeddb@workspace:*, @toeverything/y-indexeddb@workspace:packages/y-indexeddb":
|
"@toeverything/y-indexeddb@workspace:*, @toeverything/y-indexeddb@workspace:packages/y-indexeddb":
|
||||||
version: 0.0.0-use.local
|
version: 0.0.0-use.local
|
||||||
resolution: "@toeverything/y-indexeddb@workspace:packages/y-indexeddb"
|
resolution: "@toeverything/y-indexeddb@workspace:packages/y-indexeddb"
|
||||||
|
|||||||
Reference in New Issue
Block a user