feat(core): support create new template in starter-bar (#10570)

This commit is contained in:
CatsJuice
2025-03-06 02:05:29 +00:00
parent fbb6df3da8
commit 6b08e3f5d4
3 changed files with 51 additions and 37 deletions

View File

@@ -6,14 +6,19 @@ import {
Scrollable,
} from '@affine/component';
import { useAsyncCallback } from '@affine/core/components/hooks/affine-async-hooks';
import { inferOpenMode } from '@affine/core/utils';
import { useI18n } from '@affine/i18n';
import { DualLinkIcon, InformationIcon } from '@blocksuite/icons/rc';
import {
DualLinkIcon,
InformationIcon,
TemplateIcon,
} from '@blocksuite/icons/rc';
import { useLiveData, useService } from '@toeverything/infra';
import { useState } from 'react';
import { useCallback, useState } from 'react';
import { type DocRecord } from '../../doc';
import { type DocRecord, DocsService } from '../../doc';
import { DocDisplayMetaService } from '../../doc-display-meta';
import { WorkbenchLink } from '../../workbench';
import { WorkbenchLink, WorkbenchService } from '../../workbench';
import { TemplateDocService } from '../services/template-doc';
import * as styles from './styles.css';
interface CommonProps {
@@ -143,3 +148,28 @@ export const TemplateListMenu = ({
</Menu>
);
};
export const TemplateListMenuAdd = () => {
const t = useI18n();
const docsService = useService(DocsService);
const workbench = useService(WorkbenchService).workbench;
const createNewTemplate = useCallback(
(e: React.MouseEvent<HTMLDivElement>) => {
const record = docsService.createDoc({ isTemplate: true });
workbench.openDoc(record.id, { at: inferOpenMode(e) });
},
[docsService, workbench]
);
return (
<MenuItem
data-testid="template-doc-item-create"
prefixIcon={<TemplateIcon />}
onClick={createNewTemplate}
onAuxClick={createNewTemplate}
>
{t['com.affine.template-list.create-new']()}
</MenuItem>
);
};