mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-13 21:05:19 +00:00
feat(editor): replace slot with rxjs subject (#10768)
This commit is contained in:
106
blocksuite/framework/global/src/disposable/index.ts
Normal file
106
blocksuite/framework/global/src/disposable/index.ts
Normal file
@@ -0,0 +1,106 @@
|
||||
import { Subject, Subscription } from 'rxjs';
|
||||
|
||||
type DisposeCallback = () => void;
|
||||
|
||||
export interface Disposable {
|
||||
dispose: DisposeCallback;
|
||||
}
|
||||
|
||||
export type DisposableMember =
|
||||
| Disposable
|
||||
| Subscription
|
||||
| Subject<any>
|
||||
| DisposeCallback;
|
||||
|
||||
export class DisposableGroup {
|
||||
private _disposables: DisposableMember[] = [];
|
||||
|
||||
private _disposed = false;
|
||||
|
||||
get disposed() {
|
||||
return this._disposed;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add to group to be disposed with others.
|
||||
* This will be immediately disposed if this group has already been disposed.
|
||||
*/
|
||||
add(d: DisposableMember) {
|
||||
if (this._disposed) {
|
||||
disposeMember(d);
|
||||
return;
|
||||
}
|
||||
this._disposables.push(d);
|
||||
}
|
||||
|
||||
addFromEvent<N extends keyof WindowEventMap>(
|
||||
element: Window,
|
||||
eventName: N,
|
||||
handler: (e: WindowEventMap[N]) => void,
|
||||
options?: boolean | AddEventListenerOptions
|
||||
): void;
|
||||
addFromEvent<N extends keyof DocumentEventMap>(
|
||||
element: Document,
|
||||
eventName: N,
|
||||
handler: (e: DocumentEventMap[N]) => void,
|
||||
eventOptions?: boolean | AddEventListenerOptions
|
||||
): void;
|
||||
addFromEvent<N extends keyof HTMLElementEventMap>(
|
||||
element: HTMLElement,
|
||||
eventName: N,
|
||||
handler: (e: HTMLElementEventMap[N]) => void,
|
||||
eventOptions?: boolean | AddEventListenerOptions
|
||||
): void;
|
||||
addFromEvent<N extends keyof VisualViewportEventMap>(
|
||||
element: VisualViewport,
|
||||
eventName: N,
|
||||
handler: (e: VisualViewportEventMap[N]) => void,
|
||||
eventOptions?: boolean | AddEventListenerOptions
|
||||
): void;
|
||||
addFromEvent<N extends keyof VirtualKeyboardEventMap>(
|
||||
element: VirtualKeyboard,
|
||||
eventName: N,
|
||||
handler: (e: VirtualKeyboardEventMap[N]) => void,
|
||||
eventOptions?: boolean | AddEventListenerOptions
|
||||
): void;
|
||||
|
||||
addFromEvent(
|
||||
target: HTMLElement | Window | Document | VisualViewport | VirtualKeyboard,
|
||||
type: string,
|
||||
handler: (e: Event) => void,
|
||||
eventOptions?: boolean | AddEventListenerOptions
|
||||
) {
|
||||
this.add({
|
||||
dispose: () => {
|
||||
target.removeEventListener(type, handler as () => void, eventOptions);
|
||||
},
|
||||
});
|
||||
target.addEventListener(type, handler as () => void, eventOptions);
|
||||
}
|
||||
|
||||
dispose() {
|
||||
disposeAll(this._disposables);
|
||||
this._disposables = [];
|
||||
this._disposed = true;
|
||||
}
|
||||
}
|
||||
|
||||
export function disposeMember(disposable: DisposableMember) {
|
||||
try {
|
||||
if (disposable instanceof Subscription) {
|
||||
disposable.unsubscribe();
|
||||
} else if (disposable instanceof Subject) {
|
||||
disposable.complete();
|
||||
} else if (typeof disposable === 'function') {
|
||||
disposable();
|
||||
} else {
|
||||
disposable.dispose();
|
||||
}
|
||||
} catch (e) {
|
||||
console.error(e);
|
||||
}
|
||||
}
|
||||
|
||||
function disposeAll(disposables: DisposableMember[]) {
|
||||
disposables.forEach(disposeMember);
|
||||
}
|
||||
Reference in New Issue
Block a user