@blocksuite/block-std
Advanced tools
Comparing version 0.0.0-20230720161412-7c6791e1-nightly to 0.0.0-20230721134812-6e0e3bef-nightly
@@ -14,3 +14,3 @@ import { UIEventState } from './base.js'; | ||
export declare class PointerEventState extends UIEventState { | ||
readonly type = "pointerState"; | ||
type: string; | ||
raw: PointerEvent; | ||
@@ -36,3 +36,3 @@ point: Point; | ||
export declare class KeyboardEventState extends UIEventState { | ||
readonly type = "keyboardState"; | ||
type: string; | ||
raw: KeyboardEvent; | ||
@@ -39,0 +39,0 @@ constructor({ event }: KeyboardEventStateOptions); |
export * from './event/index.js'; | ||
export * from './selection/index.js'; | ||
export * from './service/index.js'; | ||
@@ -3,0 +4,0 @@ export * from './spec/index.js'; |
export * from './event/index.js'; | ||
export * from './selection/index.js'; | ||
export * from './service/index.js'; | ||
@@ -3,0 +4,0 @@ export * from './spec/index.js'; |
@@ -5,2 +5,4 @@ export declare abstract class BaseSelection { | ||
constructor(blockId: string); | ||
is<T extends BlockSuiteSelectionType>(type: T): this is BlockSuiteSelectionInstance[T]; | ||
get type(): BlockSuiteSelectionType; | ||
abstract equals(other: BaseSelection): boolean; | ||
@@ -7,0 +9,0 @@ abstract toJSON(): Record<string, unknown>; |
@@ -5,2 +5,9 @@ export class BaseSelection { | ||
} | ||
is(type) { | ||
return this.type === type; | ||
} | ||
get type() { | ||
return this.constructor | ||
.type; | ||
} | ||
static fromJSON(_) { | ||
@@ -7,0 +14,0 @@ throw new Error('You must override this method'); |
@@ -1,2 +0,2 @@ | ||
import type { Workspace } from '@blocksuite/store'; | ||
import type { Page, Workspace } from '@blocksuite/store'; | ||
import { DisposableGroup, Slot } from '@blocksuite/store'; | ||
@@ -10,17 +10,24 @@ import type { BaseSelection } from './base.js'; | ||
export declare class SelectionManager { | ||
private _workspace; | ||
root: HTMLElement; | ||
workspace: Workspace; | ||
disposables: DisposableGroup; | ||
_selectionConstructors: Record<string, SelectionConstructor>; | ||
private _selectionConstructors; | ||
private _oldSelections; | ||
slots: { | ||
changed: Slot<BaseSelection[]>; | ||
}; | ||
constructor(workspace: Workspace); | ||
register(ctor: SelectionConstructor): void; | ||
constructor(root: HTMLElement, workspace: Workspace); | ||
register(ctor: SelectionConstructor | SelectionConstructor[]): this; | ||
private get _store(); | ||
private _setupDefaultSelections; | ||
getInstance<T extends BlockSuiteSelectionType>(type: T, ...args: ConstructorParameters<BlockSuiteSelection[T]>): BlockSuiteSelectionInstance[T]; | ||
get selections(): BaseSelection[]; | ||
setSelections(selections: BaseSelection[]): void; | ||
get value(): BaseSelection[]; | ||
set(selections: BaseSelection[]): void; | ||
update(fn: (currentSelections: BaseSelection[]) => BaseSelection[]): void; | ||
clear(): void; | ||
get remoteSelections(): { | ||
[k: string]: Record<string, unknown>[]; | ||
}; | ||
mount(page: Page): void; | ||
unmount(): void; | ||
dispose(): void; | ||
@@ -27,0 +34,0 @@ } |
import { DisposableGroup, Slot } from '@blocksuite/store'; | ||
import { BlockSelection, TextSelection } from './variants/index.js'; | ||
export class SelectionManager { | ||
constructor(workspace) { | ||
constructor(root, workspace) { | ||
this.root = root; | ||
this.workspace = workspace; | ||
this.disposables = new DisposableGroup(); | ||
this._selectionConstructors = {}; | ||
this._oldSelections = []; | ||
this.slots = { | ||
changed: new Slot(), | ||
}; | ||
this._workspace = workspace; | ||
this._setupDefaultSelections(); | ||
} | ||
register(ctor) { | ||
this._selectionConstructors[ctor.type] = ctor; | ||
[ctor].flat().forEach(ctor => { | ||
this._selectionConstructors[ctor.type] = ctor; | ||
}); | ||
return this; | ||
} | ||
get _store() { | ||
return this._workspace.awarenessStore; | ||
return this.workspace.awarenessStore; | ||
} | ||
_setupDefaultSelections() { | ||
this.register([TextSelection, BlockSelection]); | ||
} | ||
getInstance(type, ...args) { | ||
@@ -24,3 +34,3 @@ const ctor = this._selectionConstructors[type]; | ||
} | ||
get selections() { | ||
get value() { | ||
return this._store.getLocalSelection().map(json => { | ||
@@ -34,6 +44,14 @@ const ctor = this._selectionConstructors[json.type]; | ||
} | ||
setSelections(selections) { | ||
set(selections) { | ||
this._oldSelections = this.value; | ||
this._store.setLocalSelection(selections.map(s => s.toJSON())); | ||
this.slots.changed.emit(selections); | ||
} | ||
update(fn) { | ||
const selections = fn(this.value); | ||
this.set(selections); | ||
} | ||
clear() { | ||
this.set([]); | ||
} | ||
get remoteSelections() { | ||
@@ -44,2 +62,21 @@ return Object.fromEntries(Array.from(this._store.getStates().entries()) | ||
} | ||
mount(page) { | ||
if (this.disposables.disposed) { | ||
this.disposables = new DisposableGroup(); | ||
} | ||
page.history.on('stack-item-added', (event) => { | ||
event.stackItem.meta.set('selection-state', this._oldSelections); | ||
}); | ||
page.history.on('stack-item-popped', (event) => { | ||
const selection = event.stackItem.meta.get('selection-state'); | ||
if (selection) { | ||
this.set(selection); | ||
} | ||
}); | ||
} | ||
unmount() { | ||
this.clear(); | ||
this.slots.changed.dispose(); | ||
this.disposables.dispose(); | ||
} | ||
dispose() { | ||
@@ -46,0 +83,0 @@ Object.values(this.slots).forEach(slot => slot.dispose()); |
import { BaseSelection } from '../base.js'; | ||
export declare class BlockSelection extends BaseSelection { | ||
static readonly type = "block"; | ||
static type: string; | ||
equals(other: BaseSelection): boolean; | ||
@@ -5,0 +5,0 @@ toJSON(): Record<string, unknown>; |
import { BaseSelection } from '../base.js'; | ||
export type TextRangePoint = { | ||
blockId: string; | ||
path: string[]; | ||
index: number; | ||
length: number; | ||
}; | ||
export type TextSelectionProps = { | ||
from: TextRangePoint; | ||
to: TextRangePoint | null; | ||
}; | ||
export declare class TextSelection extends BaseSelection { | ||
static readonly type = "text"; | ||
from: number; | ||
to: number; | ||
constructor(blockId: string, from: number, to: number); | ||
static type: string; | ||
from: TextRangePoint; | ||
to: TextRangePoint | null; | ||
constructor({ from, to }: TextSelectionProps); | ||
empty(): boolean; | ||
private _equalPoint; | ||
equals(other: BaseSelection): boolean; | ||
@@ -9,0 +20,0 @@ toJSON(): Record<string, unknown>; |
import { BaseSelection } from '../base.js'; | ||
export class TextSelection extends BaseSelection { | ||
constructor(blockId, from, to) { | ||
super(blockId); | ||
constructor({ from, to }) { | ||
super(from.blockId); | ||
this.from = from; | ||
@@ -9,9 +9,15 @@ this.to = to; | ||
empty() { | ||
return this.from === this.to; | ||
return !!this.to; | ||
} | ||
_equalPoint(a, b) { | ||
if (a && b) { | ||
return (a.blockId === b.blockId && a.index === b.index && a.length === b.length); | ||
} | ||
return a === b; | ||
} | ||
equals(other) { | ||
if (other instanceof TextSelection) { | ||
return (other.blockId === this.blockId && | ||
other.from === this.from && | ||
other.to === this.to); | ||
this._equalPoint(other.from, this.from) && | ||
this._equalPoint(other.to, this.to)); | ||
} | ||
@@ -23,3 +29,2 @@ return false; | ||
type: 'text', | ||
blockId: this.blockId, | ||
from: this.from, | ||
@@ -30,3 +35,6 @@ to: this.to, | ||
static fromJSON(json) { | ||
return new TextSelection(json.blockId, json.from, json.to); | ||
return new TextSelection({ | ||
from: json.from, | ||
to: json.to, | ||
}); | ||
} | ||
@@ -33,0 +41,0 @@ } |
import type { BaseBlockModel } from '@blocksuite/store'; | ||
import { DisposableGroup } from '@blocksuite/store'; | ||
import type { UIEventDispatcher } from '../event/index.js'; | ||
import type { EventName, UIEventHandler } from '../event/index.js'; | ||
import type { BlockStore } from '../store/index.js'; | ||
export interface BlockServiceOptions { | ||
uiEventDispatcher: UIEventDispatcher; | ||
store: BlockStore; | ||
} | ||
export declare class BlockService<Model extends BaseBlockModel = BaseBlockModel> { | ||
disposables: DisposableGroup; | ||
uiEventDispatcher: UIEventDispatcher; | ||
readonly store: BlockStore; | ||
readonly disposables: DisposableGroup; | ||
constructor(options: BlockServiceOptions); | ||
get workspace(): import("@blocksuite/store").Workspace; | ||
get page(): import("@blocksuite/store").Page; | ||
get selectionManager(): import("../index.js").SelectionManager; | ||
get uiEventDispatcher(): import("../event/dispatcher.js").UIEventDispatcher; | ||
dispose(): void; | ||
@@ -13,0 +17,0 @@ mounted(): void; |
@@ -5,4 +5,16 @@ import { DisposableGroup } from '@blocksuite/store'; | ||
this.disposables = new DisposableGroup(); | ||
this.uiEventDispatcher = options.uiEventDispatcher; | ||
this.store = options.store; | ||
} | ||
get workspace() { | ||
return this.store.workspace; | ||
} | ||
get page() { | ||
return this.store.page; | ||
} | ||
get selectionManager() { | ||
return this.store.selectionManager; | ||
} | ||
get uiEventDispatcher() { | ||
return this.store.uiEventDispatcher; | ||
} | ||
// life cycle start | ||
@@ -9,0 +21,0 @@ dispose() { |
import type { BlockSchemaType } from '@blocksuite/store'; | ||
import type { BlockServiceConstructor } from '../service/index.js'; | ||
export interface BlockView<ComponentType = unknown> { | ||
export interface BlockView<ComponentType = unknown, WidgetNames extends string = string> { | ||
component: ComponentType; | ||
widgets?: ComponentType[]; | ||
widgets?: Record<WidgetNames, ComponentType>; | ||
} | ||
export interface BlockSpec<ComponentType = unknown> { | ||
export interface BlockSpec<ComponentType = unknown, WidgetNames extends string = string> { | ||
schema: BlockSchemaType; | ||
service?: BlockServiceConstructor; | ||
view: BlockView<ComponentType>; | ||
view: BlockView<ComponentType, WidgetNames>; | ||
} | ||
//# sourceMappingURL=index.d.ts.map |
@@ -0,16 +1,26 @@ | ||
import type { Page, Workspace } from '@blocksuite/store'; | ||
import type { UIEventDispatcher } from '../event/index.js'; | ||
import type { SelectionManager } from '../selection/index.js'; | ||
import type { BlockService } from '../service/index.js'; | ||
import type { BlockSpec } from '../spec/index.js'; | ||
export interface BlockStoreOptions { | ||
root: HTMLElement; | ||
uiEventDispatcher: UIEventDispatcher; | ||
selectionManager: SelectionManager; | ||
workspace: Workspace; | ||
page: Page; | ||
} | ||
export declare class BlockStore<ComponentType = unknown> { | ||
page: Page; | ||
readonly workspace: Workspace; | ||
readonly uiEventDispatcher: UIEventDispatcher; | ||
readonly selectionManager: SelectionManager; | ||
readonly root: HTMLElement; | ||
private _specs; | ||
private _services; | ||
private readonly _uiEventDispatcher; | ||
constructor(options: BlockStoreOptions); | ||
applySpecs(specs: Array<BlockSpec<ComponentType>>): void; | ||
dispose(): void; | ||
getView(flavour: string): import("../spec/index.js").BlockView<ComponentType> | null; | ||
getService(flavour: string): BlockService<import("@blocksuite/store/base.js").BaseBlockModel<object>> | undefined; | ||
getView(flavour: string): import("../spec/index.js").BlockView<ComponentType, string> | null; | ||
getService(flavour: string): BlockService<import("@blocksuite/store").BaseBlockModel<object>> | undefined; | ||
private _diffServices; | ||
@@ -17,0 +27,0 @@ private get _serviceOptions(); |
@@ -5,3 +5,7 @@ export class BlockStore { | ||
this._services = new Map(); | ||
this._uiEventDispatcher = options.uiEventDispatcher; | ||
this.root = options.root; | ||
this.workspace = options.workspace; | ||
this.page = options.page; | ||
this.uiEventDispatcher = options.uiEventDispatcher; | ||
this.selectionManager = options.selectionManager; | ||
} | ||
@@ -58,3 +62,3 @@ applySpecs(specs) { | ||
return { | ||
uiEventDispatcher: this._uiEventDispatcher, | ||
store: this, | ||
}; | ||
@@ -61,0 +65,0 @@ } |
{ | ||
"name": "@blocksuite/block-std", | ||
"version": "0.0.0-20230720161412-7c6791e1-nightly", | ||
"version": "0.0.0-20230721134812-6e0e3bef-nightly", | ||
"description": "Std for blocksuite blocks", | ||
@@ -12,9 +12,9 @@ "main": "dist/index.js", | ||
"peerDependencies": { | ||
"@blocksuite/store": "0.0.0-20230720161412-7c6791e1-nightly" | ||
"@blocksuite/store": "0.0.0-20230721134812-6e0e3bef-nightly" | ||
}, | ||
"dependencies": { | ||
"@blocksuite/global": "0.0.0-20230720161412-7c6791e1-nightly" | ||
"@blocksuite/global": "0.0.0-20230721134812-6e0e3bef-nightly" | ||
}, | ||
"devDependencies": { | ||
"@blocksuite/store": "0.0.0-20230720161412-7c6791e1-nightly" | ||
"@blocksuite/store": "0.0.0-20230721134812-6e0e3bef-nightly" | ||
}, | ||
@@ -21,0 +21,0 @@ "exports": { |
@@ -14,3 +14,3 @@ import { UIEventState } from './base.js'; | ||
export class PointerEventState extends UIEventState { | ||
override readonly type = 'pointerState'; | ||
override type = 'pointerState'; | ||
@@ -66,3 +66,3 @@ raw: PointerEvent; | ||
export class KeyboardEventState extends UIEventState { | ||
override readonly type = 'keyboardState'; | ||
override type = 'keyboardState'; | ||
@@ -69,0 +69,0 @@ raw: KeyboardEvent; |
export * from './event/index.js'; | ||
export * from './selection/index.js'; | ||
export * from './service/index.js'; | ||
export * from './spec/index.js'; | ||
export * from './store/index.js'; |
@@ -0,1 +1,6 @@ | ||
type SelectionConstructor<T = unknown> = { | ||
new (...args: unknown[]): T; | ||
type: string; | ||
}; | ||
export abstract class BaseSelection { | ||
@@ -8,2 +13,13 @@ static readonly type: string; | ||
is<T extends BlockSuiteSelectionType>( | ||
type: T | ||
): this is BlockSuiteSelectionInstance[T] { | ||
return this.type === type; | ||
} | ||
get type(): BlockSuiteSelectionType { | ||
return (this.constructor as SelectionConstructor) | ||
.type as BlockSuiteSelectionType; | ||
} | ||
abstract equals(other: BaseSelection): boolean; | ||
@@ -10,0 +26,0 @@ |
@@ -1,5 +0,6 @@ | ||
import type { Workspace } from '@blocksuite/store'; | ||
import type { Page, StackItem, Workspace } from '@blocksuite/store'; | ||
import { DisposableGroup, Slot } from '@blocksuite/store'; | ||
import type { BaseSelection } from './base.js'; | ||
import { BlockSelection, TextSelection } from './variants/index.js'; | ||
@@ -15,6 +16,5 @@ interface SelectionConstructor { | ||
export class SelectionManager { | ||
private _workspace: Workspace; | ||
disposables = new DisposableGroup(); | ||
_selectionConstructors: Record<string, SelectionConstructor> = {}; | ||
private _selectionConstructors: Record<string, SelectionConstructor> = {}; | ||
private _oldSelections: BaseSelection[] = []; | ||
@@ -25,14 +25,21 @@ slots = { | ||
constructor(workspace: Workspace) { | ||
this._workspace = workspace; | ||
constructor(public root: HTMLElement, public workspace: Workspace) { | ||
this._setupDefaultSelections(); | ||
} | ||
register(ctor: SelectionConstructor) { | ||
this._selectionConstructors[ctor.type] = ctor; | ||
register(ctor: SelectionConstructor | SelectionConstructor[]) { | ||
[ctor].flat().forEach(ctor => { | ||
this._selectionConstructors[ctor.type] = ctor; | ||
}); | ||
return this; | ||
} | ||
private get _store() { | ||
return this._workspace.awarenessStore; | ||
return this.workspace.awarenessStore; | ||
} | ||
private _setupDefaultSelections() { | ||
this.register([TextSelection, BlockSelection]); | ||
} | ||
getInstance<T extends BlockSuiteSelectionType>( | ||
@@ -49,3 +56,3 @@ type: T, | ||
get selections() { | ||
get value() { | ||
return this._store.getLocalSelection().map(json => { | ||
@@ -60,3 +67,4 @@ const ctor = this._selectionConstructors[json.type as string]; | ||
setSelections(selections: BaseSelection[]) { | ||
set(selections: BaseSelection[]) { | ||
this._oldSelections = this.value; | ||
this._store.setLocalSelection(selections.map(s => s.toJSON())); | ||
@@ -66,2 +74,11 @@ this.slots.changed.emit(selections); | ||
update(fn: (currentSelections: BaseSelection[]) => BaseSelection[]) { | ||
const selections = fn(this.value); | ||
this.set(selections); | ||
} | ||
clear() { | ||
this.set([]); | ||
} | ||
get remoteSelections() { | ||
@@ -75,2 +92,23 @@ return Object.fromEntries( | ||
mount(page: Page) { | ||
if (this.disposables.disposed) { | ||
this.disposables = new DisposableGroup(); | ||
} | ||
page.history.on('stack-item-added', (event: { stackItem: StackItem }) => { | ||
event.stackItem.meta.set('selection-state', this._oldSelections); | ||
}); | ||
page.history.on('stack-item-popped', (event: { stackItem: StackItem }) => { | ||
const selection = event.stackItem.meta.get('selection-state'); | ||
if (selection) { | ||
this.set(selection as BaseSelection[]); | ||
} | ||
}); | ||
} | ||
unmount() { | ||
this.clear(); | ||
this.slots.changed.dispose(); | ||
this.disposables.dispose(); | ||
} | ||
dispose() { | ||
@@ -77,0 +115,0 @@ Object.values(this.slots).forEach(slot => slot.dispose()); |
import { BaseSelection } from '../base.js'; | ||
export class BlockSelection extends BaseSelection { | ||
static override readonly type = 'block'; | ||
static override type = 'block'; | ||
@@ -6,0 +6,0 @@ override equals(other: BaseSelection): boolean { |
import { BaseSelection } from '../base.js'; | ||
export type TextRangePoint = { | ||
blockId: string; | ||
path: string[]; | ||
index: number; | ||
length: number; | ||
}; | ||
export type TextSelectionProps = { | ||
from: TextRangePoint; | ||
to: TextRangePoint | null; | ||
}; | ||
export class TextSelection extends BaseSelection { | ||
static override readonly type = 'text'; | ||
static override type = 'text'; | ||
from: number; | ||
from: TextRangePoint; | ||
to: number; | ||
to: TextRangePoint | null; | ||
constructor(blockId: string, from: number, to: number) { | ||
super(blockId); | ||
constructor({ from, to }: TextSelectionProps) { | ||
super(from.blockId); | ||
this.from = from; | ||
@@ -17,5 +29,18 @@ this.to = to; | ||
empty(): boolean { | ||
return this.from === this.to; | ||
return !!this.to; | ||
} | ||
private _equalPoint( | ||
a: TextRangePoint | null, | ||
b: TextRangePoint | null | ||
): boolean { | ||
if (a && b) { | ||
return ( | ||
a.blockId === b.blockId && a.index === b.index && a.length === b.length | ||
); | ||
} | ||
return a === b; | ||
} | ||
override equals(other: BaseSelection): boolean { | ||
@@ -25,4 +50,4 @@ if (other instanceof TextSelection) { | ||
other.blockId === this.blockId && | ||
other.from === this.from && | ||
other.to === this.to | ||
this._equalPoint(other.from, this.from) && | ||
this._equalPoint(other.to, this.to) | ||
); | ||
@@ -32,7 +57,5 @@ } | ||
} | ||
override toJSON(): Record<string, unknown> { | ||
return { | ||
type: 'text', | ||
blockId: this.blockId, | ||
from: this.from, | ||
@@ -44,7 +67,6 @@ to: this.to, | ||
static override fromJSON(json: Record<string, unknown>): TextSelection { | ||
return new TextSelection( | ||
json.blockId as string, | ||
json.from as number, | ||
json.to as number | ||
); | ||
return new TextSelection({ | ||
from: json.from as TextRangePoint, | ||
to: json.to as TextRangePoint | null, | ||
}); | ||
} | ||
@@ -51,0 +73,0 @@ } |
import type { BaseBlockModel } from '@blocksuite/store'; | ||
import { DisposableGroup } from '@blocksuite/store'; | ||
import type { UIEventDispatcher } from '../event/index.js'; | ||
import type { EventName, UIEventHandler } from '../event/index.js'; | ||
import type { BlockStore } from '../store/index.js'; | ||
export interface BlockServiceOptions { | ||
// TODO: add these | ||
// selectionManager; | ||
// transformer; | ||
uiEventDispatcher: UIEventDispatcher; | ||
store: BlockStore; | ||
} | ||
export class BlockService<Model extends BaseBlockModel = BaseBlockModel> { | ||
disposables = new DisposableGroup(); | ||
uiEventDispatcher: UIEventDispatcher; | ||
readonly store: BlockStore; | ||
readonly disposables = new DisposableGroup(); | ||
constructor(options: BlockServiceOptions) { | ||
this.uiEventDispatcher = options.uiEventDispatcher; | ||
this.store = options.store; | ||
} | ||
get workspace() { | ||
return this.store.workspace; | ||
} | ||
get page() { | ||
return this.store.page; | ||
} | ||
get selectionManager() { | ||
return this.store.selectionManager; | ||
} | ||
get uiEventDispatcher() { | ||
return this.store.uiEventDispatcher; | ||
} | ||
// life cycle start | ||
@@ -24,0 +36,0 @@ dispose() { |
@@ -5,11 +5,17 @@ import type { BlockSchemaType } from '@blocksuite/store'; | ||
export interface BlockView<ComponentType = unknown> { | ||
export interface BlockView< | ||
ComponentType = unknown, | ||
WidgetNames extends string = string | ||
> { | ||
component: ComponentType; | ||
widgets?: ComponentType[]; | ||
widgets?: Record<WidgetNames, ComponentType>; | ||
} | ||
export interface BlockSpec<ComponentType = unknown> { | ||
export interface BlockSpec< | ||
ComponentType = unknown, | ||
WidgetNames extends string = string | ||
> { | ||
schema: BlockSchemaType; | ||
service?: BlockServiceConstructor; | ||
view: BlockView<ComponentType>; | ||
view: BlockView<ComponentType, WidgetNames>; | ||
} |
@@ -0,2 +1,5 @@ | ||
import type { Page, Workspace } from '@blocksuite/store'; | ||
import type { UIEventDispatcher } from '../event/index.js'; | ||
import type { SelectionManager } from '../selection/index.js'; | ||
import type { BlockService, BlockServiceOptions } from '../service/index.js'; | ||
@@ -6,11 +9,24 @@ import type { BlockSpec } from '../spec/index.js'; | ||
export interface BlockStoreOptions { | ||
root: HTMLElement; | ||
uiEventDispatcher: UIEventDispatcher; | ||
selectionManager: SelectionManager; | ||
workspace: Workspace; | ||
page: Page; | ||
} | ||
export class BlockStore<ComponentType = unknown> { | ||
page: Page; | ||
readonly workspace: Workspace; | ||
readonly uiEventDispatcher: UIEventDispatcher; | ||
readonly selectionManager: SelectionManager; | ||
readonly root: HTMLElement; | ||
private _specs: Map<string, BlockSpec<ComponentType>> = new Map(); | ||
private _services: Map<string, BlockService> = new Map(); | ||
private readonly _uiEventDispatcher: UIEventDispatcher; | ||
constructor(options: BlockStoreOptions) { | ||
this._uiEventDispatcher = options.uiEventDispatcher; | ||
this.root = options.root; | ||
this.workspace = options.workspace; | ||
this.page = options.page; | ||
this.uiEventDispatcher = options.uiEventDispatcher; | ||
this.selectionManager = options.selectionManager; | ||
} | ||
@@ -82,3 +98,3 @@ | ||
return { | ||
uiEventDispatcher: this._uiEventDispatcher, | ||
store: this, | ||
}; | ||
@@ -85,0 +101,0 @@ } |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
279466
1657
+ Added@blocksuite/global@0.0.0-20230721134812-6e0e3bef-nightly(transitive)
+ Added@blocksuite/store@0.0.0-20230721134812-6e0e3bef-nightly(transitive)
+ Added@blocksuite/virgo@0.0.0-20230721134812-6e0e3bef-nightly(transitive)
- Removed@blocksuite/global@0.0.0-20230720161412-7c6791e1-nightly(transitive)
- Removed@blocksuite/store@0.0.0-20230720161412-7c6791e1-nightly(transitive)
- Removed@blocksuite/virgo@0.0.0-20230720161412-7c6791e1-nightly(transitive)
Updated@blocksuite/global@0.0.0-20230721134812-6e0e3bef-nightly