mirror of
https://github.com/Tencent/tmagic-editor.git
synced 2025-04-06 03:57:56 +08:00
fix(playground,runtime): 拖动添加弹窗时初始位置不对
This commit is contained in:
parent
59e6aff70a
commit
41a8400095
@ -38,8 +38,8 @@ import { Coin, Connection, Document } from '@element-plus/icons-vue';
|
|||||||
import { ElMessage, ElMessageBox } from 'element-plus';
|
import { ElMessage, ElMessageBox } from 'element-plus';
|
||||||
import serialize from 'serialize-javascript';
|
import serialize from 'serialize-javascript';
|
||||||
|
|
||||||
import type { MenuBarData, MoveableOptions, TMagicEditor } from '@tmagic/editor';
|
import { editorService, MenuBarData, MoveableOptions, TMagicEditor } from '@tmagic/editor';
|
||||||
import type { Id } from '@tmagic/schema';
|
import type { Id, MContainer, MNode } from '@tmagic/schema';
|
||||||
import { NodeType } from '@tmagic/schema';
|
import { NodeType } from '@tmagic/schema';
|
||||||
import StageCore from '@tmagic/stage';
|
import StageCore from '@tmagic/stage';
|
||||||
import { asyncLoadJs } from '@tmagic/utils';
|
import { asyncLoadJs } from '@tmagic/utils';
|
||||||
@ -169,6 +169,22 @@ asyncLoadJs(`${VITE_ENTRY_PATH}/event/index.umd.js`).then(() => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
save();
|
save();
|
||||||
|
|
||||||
|
editorService.usePlugin({
|
||||||
|
beforeDoAdd: (config: MNode, parent?: MContainer | null) => {
|
||||||
|
if (config.type === 'overlay') {
|
||||||
|
config.style = {
|
||||||
|
...config.style,
|
||||||
|
left: 0,
|
||||||
|
top: 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
return [config, editorService.get('page')];
|
||||||
|
}
|
||||||
|
|
||||||
|
return [config, parent];
|
||||||
|
},
|
||||||
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss">
|
<style lang="scss">
|
||||||
|
@ -65,35 +65,31 @@ export default defineComponent({
|
|||||||
return nextTick().then(() => document.getElementById(`${id}`) as HTMLElement);
|
return nextTick().then(() => document.getElementById(`${id}`) as HTMLElement);
|
||||||
},
|
},
|
||||||
|
|
||||||
add({ config }: UpdateData) {
|
add({ config, parentId }: UpdateData) {
|
||||||
console.log('add config', config);
|
console.log('add config', config);
|
||||||
if (!root.value) throw new Error('error');
|
if (!root.value) throw new Error('error');
|
||||||
if (!selectedId.value) throw new Error('error');
|
if (!selectedId.value) throw new Error('error');
|
||||||
const path = getNodePath(selectedId.value, [root.value]);
|
const parent = getNodePath(parentId, [root.value]).pop();
|
||||||
const node = path.pop();
|
|
||||||
const parent = node?.items ? node : path.pop();
|
|
||||||
if (!parent) throw new Error('未找到父节点');
|
if (!parent) throw new Error('未找到父节点');
|
||||||
parent.items?.push(config);
|
parent.items?.push(config);
|
||||||
},
|
},
|
||||||
|
|
||||||
update({ config }: UpdateData) {
|
update({ config, parentId }: UpdateData) {
|
||||||
console.log('update config', config);
|
console.log('update config', config);
|
||||||
if (!root.value) throw new Error('error');
|
if (!root.value) throw new Error('error');
|
||||||
const path = getNodePath(config.id, [root.value]);
|
const node = getNodePath(config.id, [root.value]).pop();
|
||||||
const node = path.pop();
|
const parent = getNodePath(parentId, [root.value]).pop();
|
||||||
const parent = path.pop();
|
|
||||||
if (!node) throw new Error('未找到目标节点');
|
if (!node) throw new Error('未找到目标节点');
|
||||||
if (!parent) throw new Error('未找到父节点');
|
if (!parent) throw new Error('未找到父节点');
|
||||||
const index = parent.items?.findIndex((child: MNode) => child.id === node.id);
|
const index = parent.items?.findIndex((child: MNode) => child.id === node.id);
|
||||||
parent.items.splice(index, 1, reactive(config));
|
parent.items.splice(index, 1, reactive(config));
|
||||||
},
|
},
|
||||||
|
|
||||||
remove({ id }: RemoveData) {
|
remove({ id, parentId }: RemoveData) {
|
||||||
if (!root.value) throw new Error('error');
|
if (!root.value) throw new Error('error');
|
||||||
const path = getNodePath(id, [root.value]);
|
const node = getNodePath(id, [root.value]).pop();
|
||||||
const node = path.pop();
|
|
||||||
if (!node) throw new Error('未找到目标元素');
|
if (!node) throw new Error('未找到目标元素');
|
||||||
const parent = path.pop();
|
const parent = getNodePath(parentId, [root.value]).pop();
|
||||||
if (!parent) throw new Error('未找到父元素');
|
if (!parent) throw new Error('未找到父元素');
|
||||||
const index = parent.items?.findIndex((child: MNode) => child.id === node.id);
|
const index = parent.items?.findIndex((child: MNode) => child.id === node.id);
|
||||||
parent.items.splice(index, 1);
|
parent.items.splice(index, 1);
|
||||||
|
@ -65,35 +65,31 @@ export default defineComponent({
|
|||||||
return nextTick().then(() => document.getElementById(`${id}`) as HTMLElement);
|
return nextTick().then(() => document.getElementById(`${id}`) as HTMLElement);
|
||||||
},
|
},
|
||||||
|
|
||||||
add({ config }: UpdateData) {
|
add({ config, parentId }: UpdateData) {
|
||||||
console.log('add config', config);
|
console.log('add config', config);
|
||||||
if (!root.value) throw new Error('error');
|
if (!root.value) throw new Error('error');
|
||||||
if (!selectedId.value) throw new Error('error');
|
if (!selectedId.value) throw new Error('error');
|
||||||
const path = getNodePath(selectedId.value, [root.value]);
|
const parent = getNodePath(parentId, [root.value]).pop();
|
||||||
const node = path.pop();
|
|
||||||
const parent = node?.items ? node : path.pop();
|
|
||||||
if (!parent) throw new Error('未找到父节点');
|
if (!parent) throw new Error('未找到父节点');
|
||||||
parent.items?.push(config);
|
parent.items?.push(config);
|
||||||
},
|
},
|
||||||
|
|
||||||
update({ config }: UpdateData) {
|
update({ config, parentId }: UpdateData) {
|
||||||
console.log('update config', config);
|
console.log('update config', config);
|
||||||
if (!root.value) throw new Error('error');
|
if (!root.value) throw new Error('error');
|
||||||
const path = getNodePath(config.id, [root.value]);
|
const node = getNodePath(config.id, [root.value]).pop();
|
||||||
const node = path.pop();
|
const parent = getNodePath(parentId, [root.value]).pop();
|
||||||
const parent = path.pop();
|
|
||||||
if (!node) throw new Error('未找到目标节点');
|
if (!node) throw new Error('未找到目标节点');
|
||||||
if (!parent) throw new Error('未找到父节点');
|
if (!parent) throw new Error('未找到父节点');
|
||||||
const index = parent.items?.findIndex((child: MNode) => child.id === node.id);
|
const index = parent.items?.findIndex((child: MNode) => child.id === node.id);
|
||||||
parent.items.splice(index, 1, reactive(config));
|
parent.items.splice(index, 1, reactive(config));
|
||||||
},
|
},
|
||||||
|
|
||||||
remove({ id }: RemoveData) {
|
remove({ id, parentId }: RemoveData) {
|
||||||
if (!root.value) throw new Error('error');
|
if (!root.value) throw new Error('error');
|
||||||
const path = getNodePath(id, [root.value]);
|
const node = getNodePath(id, [root.value]).pop();
|
||||||
const node = path.pop();
|
|
||||||
if (!node) throw new Error('未找到目标元素');
|
if (!node) throw new Error('未找到目标元素');
|
||||||
const parent = path.pop();
|
const parent = getNodePath(parentId, [root.value]).pop();
|
||||||
if (!parent) throw new Error('未找到父元素');
|
if (!parent) throw new Error('未找到父元素');
|
||||||
const index = parent.items?.findIndex((child: MNode) => child.id === node.id);
|
const index = parent.items?.findIndex((child: MNode) => child.id === node.id);
|
||||||
parent.items.splice(index, 1);
|
parent.items.splice(index, 1);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user