2020-12-30 01:32:46 +00:00
|
|
|
import {
|
|
|
|
ref,
|
|
|
|
inject,
|
|
|
|
reactive,
|
|
|
|
} from 'vue';
|
2021-03-08 15:29:35 +00:00
|
|
|
import { BlockLibrary } from './types';
|
2020-12-30 13:34:23 +00:00
|
|
|
import { Mode, SbMode } from './mode';
|
2020-12-30 01:32:46 +00:00
|
|
|
|
2021-03-08 15:29:35 +00:00
|
|
|
export const SymBlockLibrary = Symbol('Schlechtenburg block library');
|
2020-12-30 01:32:46 +00:00
|
|
|
export function useDynamicBlocks() {
|
|
|
|
const mode = inject(Mode, ref(SbMode.Edit));
|
2021-03-08 15:29:35 +00:00
|
|
|
const customBlocks: BlockLibrary = inject(SymBlockLibrary, reactive({}));
|
2021-02-22 23:12:06 +00:00
|
|
|
const getBlock = (name: string) => customBlocks[name];
|
2020-12-30 01:32:46 +00:00
|
|
|
|
|
|
|
return {
|
|
|
|
mode,
|
|
|
|
customBlocks,
|
|
|
|
getBlock,
|
|
|
|
};
|
|
|
|
}
|