Skip to content

Commit

Permalink
refactor(editor): use spec builder
Browse files Browse the repository at this point in the history
  • Loading branch information
Saul-Mirone committed Dec 30, 2024
1 parent e3b6841 commit 29dbd06
Show file tree
Hide file tree
Showing 10 changed files with 64 additions and 83 deletions.
9 changes: 5 additions & 4 deletions blocksuite/affine/shared/src/utils/spec/spec-builder.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,10 @@ export class SpecBuilder {
this._value = this._value.filter(extension => extension !== target);
}

replace(target: ExtensionType, newExtension: ExtensionType) {
this._value = this._value.map(extension =>
extension === target ? newExtension : extension
);
replace(target: ExtensionType[], newExtension: ExtensionType[]) {
this._value = [
...this._value.filter(extension => !target.includes(extension)),
...newExtension,
];
}
}
4 changes: 2 additions & 2 deletions blocksuite/blocks/src/_specs/common.ts
Original file line number Diff line number Diff line change
Expand Up @@ -54,15 +54,15 @@ export const CommonBlockSpecs: ExtensionType[] = [
].flat();

export const PageFirstPartyBlockSpecs: ExtensionType[] = [
...CommonBlockSpecs,
CommonBlockSpecs,
NoteBlockSpec,
PageSurfaceBlockSpec,
PageSurfaceRefBlockSpec,
FontLoaderService,
].flat();

export const EdgelessFirstPartyBlockSpecs: ExtensionType[] = [
...CommonBlockSpecs,
CommonBlockSpecs,

EdgelessNoteBlockSpec,
EdgelessSurfaceBlockSpec,
Expand Down
2 changes: 1 addition & 1 deletion blocksuite/blocks/src/_specs/preset/edgeless-specs.ts
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ export const EdgelessBuiltInManager: ExtensionType[] = [

export const EdgelessEditorBlockSpecs: ExtensionType[] = [
EdgelessRootBlockSpec,
...EdgelessFirstPartyBlockSpecs,
EdgelessFirstPartyBlockSpecs,
EdgelessToolExtension,
EdgelessBuiltInManager,
].flat();
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { FileDropExtension } from '@blocksuite/affine-components/drag-indicator';
import {
DNDAPIExtension,
DocDisplayMetaService,
DocModeService,
EmbedOptionService,
PageViewportServiceExtension,
Expand Down Expand Up @@ -99,7 +98,6 @@ const EdgelessCommonExtension: ExtensionType[] = [
ToolController,
DNDAPIExtension,
PageViewportServiceExtension,
DocDisplayMetaService,
RootBlockAdapterExtensions,
FileDropExtension,
].flat();
Expand Down
2 changes: 0 additions & 2 deletions blocksuite/blocks/src/root-block/page/page-root-spec.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import { FileDropExtension } from '@blocksuite/affine-components/drag-indicator';
import {
DNDAPIExtension,
DocDisplayMetaService,
DocModeService,
EmbedOptionService,
PageViewportServiceExtension,
Expand Down Expand Up @@ -70,7 +69,6 @@ const PageCommonExtension: ExtensionType[] = [
DocModeService,
ThemeService,
EmbedOptionService,
DocDisplayMetaService,
PageViewportServiceExtension,
];

Expand Down
7 changes: 5 additions & 2 deletions blocksuite/presets/src/editors/editor-container.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import {
} from '@blocksuite/block-std';
import {
type AbstractEditor,
DocDisplayMetaService,
type DocMode,
EdgelessEditorBlockSpecs,
PageEditorBlockSpecs,
Expand Down Expand Up @@ -91,12 +92,14 @@ export class AffineEditorContainer
private readonly _doc = signal<Doc>();

private readonly _edgelessSpecs = signal<ExtensionType[]>(
EdgelessEditorBlockSpecs
EdgelessEditorBlockSpecs.concat(DocDisplayMetaService)
);

private readonly _mode = signal<DocMode>('page');

private readonly _pageSpecs = signal<ExtensionType[]>(PageEditorBlockSpecs);
private readonly _pageSpecs = signal<ExtensionType[]>(
PageEditorBlockSpecs.concat(DocDisplayMetaService)
);

private readonly _specs = computed(() =>
this._mode.value === 'page'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import {
DividerBlockSpec,
EditPropsStore,
EmbedExtensions,
FontLoaderService,
ImageBlockSpec,
LatexBlockSpec,
ListBlockSpec,
Expand All @@ -36,6 +37,7 @@ const CommonBlockSpecs: ExtensionType[] = [
BookmarkBlockSpec,
AttachmentBlockSpec,
AdapterFactoryExtensions,
FontLoaderService,
].flat();

export const DefaultBlockSpecs: ExtensionType[] = [
Expand Down
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
import {
AIEdgelessRootBlockSpec,
AIPageRootBlockSpec,
AICodeBlockSpec,
AIImageBlockSpec,
AIParagraphBlockSpec,
} from '@affine/core/blocksuite/presets/ai';
import { AIChatBlockSpec } from '@affine/core/blocksuite/presets/blocks';
import { DocService, DocsService } from '@affine/core/modules/doc';
import { DocDisplayMetaService } from '@affine/core/modules/doc-display-meta';
import { EditorSettingService } from '@affine/core/modules/editor-setting';
import { FeatureFlagService } from '@affine/core/modules/feature-flag';
import { AppThemeService } from '@affine/core/modules/theme';
import { mixpanel } from '@affine/track';
import {
Expand All @@ -18,18 +19,17 @@ import type {
DocDisplayMetaExtension,
DocDisplayMetaParams,
RootBlockConfig,
SpecBuilder,
TelemetryEventMap,
ThemeExtension,
} from '@blocksuite/affine/blocks';
import {
CodeBlockSpec,
ColorScheme,
DocDisplayMetaProvider,
EdgelessBuiltInManager,
EdgelessRootBlockSpec,
EdgelessToolExtension,
EditorSettingExtension,
FontLoaderService,
PageRootBlockSpec,
ImageBlockSpec,
ParagraphBlockSpec,
TelemetryProvider,
ThemeExtensionIdentifier,
} from '@blocksuite/affine/blocks';
Expand Down Expand Up @@ -258,36 +258,24 @@ export const extendEdgelessPreviewSpec = (function () {
};
})();

export function createPageRootBlockSpec(
framework: FrameworkProvider
): ExtensionType[] {
const featureFlagService = framework.get(FeatureFlagService);
const enableAI = featureFlagService.flags.enable_ai.value;
return [
enableAI ? AIPageRootBlockSpec : PageRootBlockSpec,
FontLoaderService,
getThemeExtension(framework),
getFontConfigExtension(),
getTelemetryExtension(),
getEditorConfigExtension(framework),
buildDocDisplayMetaExtension(framework),
].flat();
export function enableAffineExtension(
framework: FrameworkProvider,
specBuilder: SpecBuilder
): void {
specBuilder.extend(
[
getThemeExtension(framework),
getFontConfigExtension(),
getTelemetryExtension(),
getEditorConfigExtension(framework),
buildDocDisplayMetaExtension(framework),
].flat()
);
}

export function createEdgelessRootBlockSpec(
framework: FrameworkProvider
): ExtensionType[] {
const featureFlagService = framework.get(FeatureFlagService);
const enableAI = featureFlagService.flags.enable_ai.value;
return [
enableAI ? AIEdgelessRootBlockSpec : EdgelessRootBlockSpec,
FontLoaderService,
getThemeExtension(framework),
EdgelessToolExtension,
EdgelessBuiltInManager,
getFontConfigExtension(),
getTelemetryExtension(),
getEditorConfigExtension(framework),
buildDocDisplayMetaExtension(framework),
].flat();
export function enableAIExtension(specBuilder: SpecBuilder): void {
specBuilder.replace(CodeBlockSpec, AICodeBlockSpec);
specBuilder.replace(ImageBlockSpec, AIImageBlockSpec);
specBuilder.replace(ParagraphBlockSpec, AIParagraphBlockSpec);
specBuilder.extend(AIChatBlockSpec);
}
Original file line number Diff line number Diff line change
@@ -1,36 +1,31 @@
import { AIEdgelessRootBlockSpec } from '@affine/core/blocksuite/presets/ai';
import { FeatureFlagService } from '@affine/core/modules/feature-flag';
import { builtInTemplates as builtInEdgelessTemplates } from '@affine/templates/edgeless';
import { builtInTemplates as builtInStickersTemplates } from '@affine/templates/stickers';
import type { ExtensionType } from '@blocksuite/affine/block-std';
import type { TemplateManager } from '@blocksuite/affine/blocks';
import {
EdgelessNoteBlockSpec,
EdgelessSurfaceBlockSpec,
EdgelessSurfaceRefBlockSpec,
EdgelessRootBlockSpec,
EdgelessTemplatePanel,
EdgelessTextBlockSpec,
FrameBlockSpec,
SpecProvider,
} from '@blocksuite/affine/blocks';
import { type FrameworkProvider } from '@toeverything/infra';

import { AIBlockSpecs, DefaultBlockSpecs } from './common';
import { createEdgelessRootBlockSpec } from './custom/root-block';
import { enableAffineExtension, enableAIExtension } from './custom/root-block';

export function createEdgelessModeSpecs(
framework: FrameworkProvider
): ExtensionType[] {
const featureFlagService = framework.get(FeatureFlagService);
const enableAI = featureFlagService.flags.enable_ai.value;
return [
...(enableAI ? AIBlockSpecs : DefaultBlockSpecs),
EdgelessSurfaceBlockSpec,
EdgelessSurfaceRefBlockSpec,
FrameBlockSpec,
EdgelessTextBlockSpec,
EdgelessNoteBlockSpec,
// special
createEdgelessRootBlockSpec(framework),
].flat();
const edgelessSpec = SpecProvider.getInstance().getSpec('edgeless');
enableAffineExtension(framework, edgelessSpec);
if (enableAI) {
enableAIExtension(edgelessSpec);
edgelessSpec.replace(EdgelessRootBlockSpec, AIEdgelessRootBlockSpec);
}

return edgelessSpec.value;
}

export function effects() {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,26 +1,22 @@
import { AIPageRootBlockSpec } from '@affine/core/blocksuite/presets/ai';
import { FeatureFlagService } from '@affine/core/modules/feature-flag';
import type { ExtensionType } from '@blocksuite/affine/block-std';
import {
NoteBlockSpec,
PageSurfaceBlockSpec,
PageSurfaceRefBlockSpec,
} from '@blocksuite/affine/blocks';
import { PageRootBlockSpec, SpecProvider } from '@blocksuite/affine/blocks';
import { type FrameworkProvider } from '@toeverything/infra';

import { AIBlockSpecs, DefaultBlockSpecs } from './common';
import { createPageRootBlockSpec } from './custom/root-block';
import { enableAffineExtension, enableAIExtension } from './custom/root-block';

export function createPageModeSpecs(
framework: FrameworkProvider
): ExtensionType[] {
const featureFlagService = framework.get(FeatureFlagService);
const enableAI = featureFlagService.flags.enable_ai.value;
return [
...(enableAI ? AIBlockSpecs : DefaultBlockSpecs),
PageSurfaceBlockSpec,
PageSurfaceRefBlockSpec,
NoteBlockSpec,
// special
createPageRootBlockSpec(framework),
].flat();
const provider = SpecProvider.getInstance();
const pageSpec = provider.getSpec('page');
enableAffineExtension(framework, pageSpec);
if (enableAI) {
enableAIExtension(pageSpec);
pageSpec.replace(PageRootBlockSpec, AIPageRootBlockSpec);
}
return pageSpec.value;
}

0 comments on commit 29dbd06

Please sign in to comment.