Files
AFFiNE-Mirror/blocksuite/affine/blocks/block-divider/src/adapters/html.ts
2025-03-08 12:00:34 +08:00

54 lines
1.3 KiB
TypeScript

import { DividerBlockSchema } from '@blocksuite/affine-model';
import {
BlockHtmlAdapterExtension,
type BlockHtmlAdapterMatcher,
HastUtils,
} from '@blocksuite/affine-shared/adapters';
import { nanoid } from '@blocksuite/store';
export const dividerBlockHtmlAdapterMatcher: BlockHtmlAdapterMatcher = {
flavour: DividerBlockSchema.model.flavour,
toMatch: o => HastUtils.isElement(o.node) && o.node.tagName === 'hr',
fromMatch: o => o.node.flavour === DividerBlockSchema.model.flavour,
toBlockSnapshot: {
enter: (o, context) => {
if (!HastUtils.isElement(o.node)) {
return;
}
const { walkerContext } = context;
walkerContext
.openNode(
{
type: 'block',
id: nanoid(),
flavour: 'affine:divider',
props: {},
children: [],
},
'children'
)
.closeNode();
},
},
fromBlockSnapshot: {
enter: (_, context) => {
const { walkerContext } = context;
walkerContext
.openNode(
{
type: 'element',
tagName: 'hr',
properties: {},
children: [],
},
'children'
)
.closeNode();
},
},
};
export const DividerBlockHtmlAdapterExtension = BlockHtmlAdapterExtension(
dividerBlockHtmlAdapterMatcher
);