refactor(editor): rename doc to blocks (#9510)

This commit is contained in:
Saul-Mirone
2025-01-03 12:49:33 +00:00
parent 2074bda8ff
commit 4457cb7266
99 changed files with 271 additions and 256 deletions

View File

@@ -5,7 +5,7 @@ import { assert, beforeEach, describe, expect, it, vi } from 'vitest';
import { applyUpdate, encodeStateAsUpdate } from 'yjs';
import { COLLECTION_VERSION, PAGE_VERSION } from '../consts.js';
import type { BlockModel, BlockSchemaType, Doc } from '../index.js';
import type { BlockModel, Blocks, BlockSchemaType } from '../index.js';
import { Schema } from '../index.js';
import type { DocMeta } from '../store/workspace.js';
import { TestWorkspace } from '../test/test-workspace.js';
@@ -54,7 +54,7 @@ function waitOnce<T>(slot: Slot<T>) {
return new Promise<T>(resolve => slot.once(val => resolve(val)));
}
function createRoot(doc: Doc) {
function createRoot(doc: Blocks) {
doc.addBlock('affine:page');
if (!doc.root) throw new Error('root not found');
return doc.root;

View File

@@ -1,6 +1,6 @@
import { BlockSuiteError } from '@blocksuite/global/exceptions';
import type { Doc } from '../store/index.js';
import type { Blocks } from '../store/index.js';
import type { AssetsManager } from '../transformer/assets.js';
import type { DraftModel, Job, Slice } from '../transformer/index.js';
import type {
@@ -93,7 +93,7 @@ export abstract class BaseAdapter<AdapterTarget = unknown> {
| Promise<FromBlockSnapshotResult<AdapterTarget>>
| FromBlockSnapshotResult<AdapterTarget>;
async fromDoc(doc: Doc) {
async fromDoc(doc: Blocks) {
try {
const docSnapshot = this.job.docToSnapshot(doc);
if (!docSnapshot) return;
@@ -138,7 +138,7 @@ export abstract class BaseAdapter<AdapterTarget = unknown> {
async toBlock(
payload: ToBlockSnapshotPayload<AdapterTarget>,
doc: Doc,
doc: Blocks,
parent?: string,
index?: number
) {
@@ -175,7 +175,7 @@ export abstract class BaseAdapter<AdapterTarget = unknown> {
async toSlice(
payload: ToSliceSnapshotPayload<AdapterTarget>,
doc: Doc,
doc: Blocks,
parent?: string,
index?: number
) {

View File

@@ -7,7 +7,7 @@ import { z } from 'zod';
import { Boxed } from '../reactive/boxed.js';
import { Text } from '../reactive/text.js';
import type { YBlock } from '../store/doc/block/index.js';
import type { Doc } from '../store/index.js';
import type { Blocks } from '../store/index.js';
import type { BaseBlockTransformer } from '../transformer/base.js';
const FlavourSchema = z.string();
@@ -160,7 +160,7 @@ export class BlockModel<
/**
* @deprecated use doc instead
*/
page!: Doc;
page!: Blocks;
private readonly _childModels = computed(() => {
const value: BlockModel[] = [];
@@ -224,7 +224,7 @@ export class BlockModel<
return this.page;
}
set doc(doc: Doc) {
set doc(doc: Blocks) {
this.page = doc;
}

View File

@@ -8,7 +8,7 @@ import type { BlockModel } from '../../schema/base.js';
import type { IdGenerator } from '../../utils/id-generator.js';
import type { AwarenessStore, BlockSuiteDoc } from '../../yjs/index.js';
import type { GetDocOptions, Workspace } from '../workspace.js';
import { Doc } from './doc.js';
import { Blocks } from './doc.js';
import type { YBlock } from './index.js';
import type { Query } from './query.js';
@@ -40,9 +40,9 @@ export class BlockCollection {
private readonly _collection: Workspace;
private readonly _docMap = {
undefined: new Map<string, Doc>(),
true: new Map<string, Doc>(),
false: new Map<string, Doc>(),
undefined: new Map<string, Blocks>(),
true: new Map<string, Blocks>(),
false: new Map<string, Blocks>(),
};
// doc/space container.
@@ -324,7 +324,7 @@ export class BlockCollection {
return this._docMap[readonlyKey].get(key)!;
}
const doc = new Doc({
const doc = new Blocks({
blockCollection: this,
schema: this.collection.schema,
readonly,

View File

@@ -1,6 +1,6 @@
import type { Schema } from '../../../schema/index.js';
import { BlockViewType } from '../consts.js';
import type { Doc } from '../doc.js';
import type { Blocks } from '../doc.js';
import { SyncController } from './sync-controller.js';
import type { BlockOptions, YBlock } from './types.js';
@@ -38,7 +38,7 @@ export class Block {
constructor(
readonly schema: Schema,
readonly yBlock: YBlock,
readonly doc?: Doc,
readonly doc?: Blocks,
readonly options: BlockOptions = {}
) {
const onChange = !options.onChange

View File

@@ -12,7 +12,7 @@ import {
} from '../../../reactive/index.js';
import { BlockModel, internalPrimitives } from '../../../schema/base.js';
import type { Schema } from '../../../schema/schema.js';
import type { Doc } from '../doc.js';
import type { Blocks } from '../doc.js';
import type { YBlock } from './types.js';
/**
@@ -103,7 +103,7 @@ export class SyncController {
constructor(
readonly schema: Schema,
readonly yBlock: YBlock,
readonly doc?: Doc,
readonly doc?: Blocks,
readonly onChange?: (key: string, value: unknown) => void
) {
const { id, flavour, version, yChildren, props } = this._parseYBlock();

View File

@@ -18,7 +18,7 @@ type DocOptions = {
query?: Query;
};
export class Doc {
export class Blocks {
private readonly _runQuery = (block: Block) => {
runQuery(this._query, block);
};

View File

@@ -5,7 +5,7 @@ import type { Schema } from '../schema/schema.js';
import type { IdGenerator } from '../utils/id-generator.js';
import type { AwarenessStore } from '../yjs/awareness.js';
import type { BlockSuiteDoc } from '../yjs/doc.js';
import type { Doc } from './doc/doc.js';
import type { Blocks } from './doc/doc.js';
import type { BlockCollection } from './doc/index.js';
import type { Query } from './doc/query.js';
@@ -78,8 +78,8 @@ export interface Workspace {
docRemoved: Slot<string>;
};
createDoc(options?: CreateDocOptions): Doc;
getDoc(docId: string, options?: GetDocOptions): Doc | null;
createDoc(options?: CreateDocOptions): Blocks;
getDoc(docId: string, options?: GetDocOptions): Blocks | null;
removeDoc(docId: string): void;
dispose(): void;

View File

@@ -18,8 +18,8 @@ import { Awareness } from 'y-protocols/awareness.js';
import type { Schema } from '../schema/index.js';
import {
BlockCollection,
type Blocks,
type CreateDocOptions,
type Doc,
DocCollectionMeta,
type GetDocOptions,
type Workspace,
@@ -208,7 +208,7 @@ export class TestWorkspace implements Workspace {
tags: [],
});
this.slots.docCreated.emit(docId);
return this.getDoc(docId, { query, readonly }) as Doc;
return this.getDoc(docId, { query, readonly }) as Blocks;
}
dispose() {
@@ -230,7 +230,7 @@ export class TestWorkspace implements Workspace {
return space ?? null;
}
getDoc(docId: string, options?: GetDocOptions): Doc | null {
getDoc(docId: string, options?: GetDocOptions): Blocks | null {
const collection = this.getBlockCollection(docId);
return collection?.getDoc(options) ?? null;
}

View File

@@ -2,7 +2,7 @@ import { BlockSuiteError, ErrorCode } from '@blocksuite/global/exceptions';
import { nextTick, Slot } from '@blocksuite/global/utils';
import type { BlockModel, BlockSchemaType, Schema } from '../schema/index.js';
import type { Doc } from '../store/index.js';
import type { Blocks } from '../store/index.js';
import { AssetsManager } from './assets.js';
import { BaseBlockTransformer } from './base.js';
import type { DraftModel } from './draft.js';
@@ -78,7 +78,7 @@ export class Job {
}
};
docToSnapshot = (doc: Doc): DocSnapshot | undefined => {
docToSnapshot = (doc: Blocks): DocSnapshot | undefined => {
try {
this._slots.beforeExport.emit({
type: 'page',
@@ -154,7 +154,7 @@ export class Job {
snapshotToBlock = async (
snapshot: BlockSnapshot,
doc: Doc,
doc: Blocks,
parent?: string,
index?: number
): Promise<BlockModel | undefined> => {
@@ -170,7 +170,9 @@ export class Job {
}
};
snapshotToDoc = async (snapshot: DocSnapshot): Promise<Doc | undefined> => {
snapshotToDoc = async (
snapshot: DocSnapshot
): Promise<Blocks | undefined> => {
try {
this._slots.beforeImport.emit({
type: 'page',
@@ -222,7 +224,7 @@ export class Job {
snapshotToSlice = async (
snapshot: SliceSnapshot,
doc: Doc,
doc: Blocks,
parent?: string,
index?: number
): Promise<Slice | undefined> => {
@@ -418,7 +420,7 @@ export class Job {
}
}
private _exportDocMeta(doc: Doc): DocSnapshot['meta'] {
private _exportDocMeta(doc: Blocks): DocSnapshot['meta'] {
const docMeta = doc.meta;
if (!docMeta) {
@@ -466,7 +468,7 @@ export class Job {
private async _insertBlockTree(
nodes: DraftBlockTreeNode[],
doc: Doc,
doc: Blocks,
parentId?: string,
startIndex?: number,
counter: number = 0
@@ -555,7 +557,7 @@ export class Job {
private async _snapshotToBlock(
snapshot: BlockSnapshot,
doc: Doc,
doc: Blocks,
parent?: string,
index?: number
): Promise<BlockModel | null> {

View File

@@ -1,6 +1,6 @@
import type { Slot } from '@blocksuite/global/utils';
import type { Doc } from '../store/index.js';
import type { Blocks } from '../store/index.js';
import type { AssetsManager } from './assets.js';
import type { DraftModel } from './draft.js';
import type { Slice } from './slice.js';
@@ -38,7 +38,7 @@ export type BeforeExportPayload =
type: 'block';
}
| {
page: Doc;
page: Blocks;
type: 'page';
}
| {
@@ -60,7 +60,7 @@ export type FinalPayload =
| {
snapshot: DocSnapshot;
type: 'page';
page: Doc;
page: Blocks;
}
| {
snapshot: SliceSnapshot;

View File

@@ -1,4 +1,4 @@
import type { Doc } from '../store/index.js';
import type { Blocks } from '../store/index.js';
import type { DraftModel } from './draft.js';
type SliceData = {
@@ -22,7 +22,7 @@ export class Slice {
constructor(readonly data: SliceData) {}
static fromModels(doc: Doc, models: DraftModel[]) {
static fromModels(doc: Blocks, models: DraftModel[]) {
return new Slice({
content: models,
workspaceId: doc.collection.id,

View File

@@ -1,6 +1,6 @@
import { z } from 'zod';
import type { Doc } from '../store/doc/doc.js';
import type { Blocks } from '../store/doc/doc.js';
import type { DocMeta, DocsPropertiesMeta } from '../store/workspace.js';
export type BlockSnapshot = {
@@ -75,7 +75,7 @@ export interface BlobCRUD {
}
export interface DocCRUD {
create: (id: string) => Doc;
get: (id: string) => Doc | null;
create: (id: string) => Blocks;
get: (id: string) => Blocks | null;
delete: (id: string) => void;
}