Files
AFFiNE-Mirror/blocksuite/affine/block-image/src/image-spec.ts
2025-01-09 11:49:23 +00:00

33 lines
965 B
TypeScript

import {
BlockViewExtension,
CommandExtension,
FlavourExtension,
WidgetViewMapExtension,
} from '@blocksuite/block-std';
import type { ExtensionType } from '@blocksuite/store';
import { literal } from 'lit/static-html.js';
import { ImageBlockAdapterExtensions } from './adapters/extension.js';
import { commands } from './commands/index.js';
import { ImageBlockService, ImageDropOption } from './image-service.js';
export const ImageBlockSpec: ExtensionType[] = [
FlavourExtension('affine:image'),
ImageBlockService,
CommandExtension(commands),
BlockViewExtension('affine:image', model => {
const parent = model.doc.getParent(model.id);
if (parent?.flavour === 'affine:surface') {
return literal`affine-edgeless-image`;
}
return literal`affine-image`;
}),
WidgetViewMapExtension('affine:image', {
imageToolbar: literal`affine-image-toolbar-widget`,
}),
ImageDropOption,
ImageBlockAdapterExtensions,
].flat();