mirror of
https://github.com/Tencent/tmagic-editor.git
synced 2025-04-05 07:27:09 +08:00
feat(core, editor): 删除公共的点击事件实现,由组件自行添加
This commit is contained in:
parent
5ba2a73c70
commit
c8e1cffca9
@ -32,38 +32,11 @@ import {
|
|||||||
type EventActionItem,
|
type EventActionItem,
|
||||||
type EventConfig,
|
type EventConfig,
|
||||||
} from '@tmagic/schema';
|
} from '@tmagic/schema';
|
||||||
import { DATA_SOURCE_FIELDS_CHANGE_EVENT_PREFIX, getIdFromEl } from '@tmagic/utils';
|
import { DATA_SOURCE_FIELDS_CHANGE_EVENT_PREFIX } from '@tmagic/utils';
|
||||||
|
|
||||||
import type { default as TMagicApp } from './App';
|
import type { default as TMagicApp } from './App';
|
||||||
import FlowState from './FlowState';
|
import FlowState from './FlowState';
|
||||||
import type { default as TMagicNode } from './Node';
|
import type { default as TMagicNode } from './Node';
|
||||||
import { COMMON_EVENT_PREFIX, isCommonMethod, triggerCommonMethod } from './utils';
|
|
||||||
|
|
||||||
const getCommonEventName = (commonEventName: string) => {
|
|
||||||
if (commonEventName.startsWith(COMMON_EVENT_PREFIX)) return commonEventName;
|
|
||||||
return `${COMMON_EVENT_PREFIX}${commonEventName}`;
|
|
||||||
};
|
|
||||||
|
|
||||||
// 点击在组件内的某个元素上,需要向上寻找到当前组件
|
|
||||||
const getDirectComponent = (element: HTMLElement | null, app: TMagicApp): TMagicNode | undefined => {
|
|
||||||
if (!element) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const id = getIdFromEl()(element);
|
|
||||||
|
|
||||||
if (!id) {
|
|
||||||
return getDirectComponent(element.parentElement, app);
|
|
||||||
}
|
|
||||||
|
|
||||||
const node = app.getNode(
|
|
||||||
id,
|
|
||||||
element.dataset.tmagicIteratorContainerId?.split(','),
|
|
||||||
element.dataset.tmagicIteratorIndex?.split(',').map((i) => globalThis.parseInt(i, 10)),
|
|
||||||
);
|
|
||||||
|
|
||||||
return node;
|
|
||||||
};
|
|
||||||
|
|
||||||
export default class EventHelper extends EventEmitter {
|
export default class EventHelper extends EventEmitter {
|
||||||
public app: TMagicApp;
|
public app: TMagicApp;
|
||||||
@ -75,19 +48,11 @@ export default class EventHelper extends EventEmitter {
|
|||||||
super();
|
super();
|
||||||
|
|
||||||
this.app = app;
|
this.app = app;
|
||||||
|
|
||||||
if (app.jsEngine === 'browser') {
|
|
||||||
globalThis.document.body.addEventListener('click', this.commonClickEventHandler);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public destroy() {
|
public destroy() {
|
||||||
this.removeNodeEvents();
|
this.removeNodeEvents();
|
||||||
this.removeAllListeners();
|
this.removeAllListeners();
|
||||||
|
|
||||||
if (this.app.jsEngine === 'browser') {
|
|
||||||
globalThis.document.body.removeEventListener('click', this.commonClickEventHandler);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public bindNodeEvents(node: TMagicNode) {
|
public bindNodeEvents(node: TMagicNode) {
|
||||||
@ -243,10 +208,6 @@ export default class EventHelper extends EventEmitter {
|
|||||||
const toNode = this.app.getNode(to);
|
const toNode = this.app.getNode(to);
|
||||||
if (!toNode) throw `ID为${to}的组件不存在`;
|
if (!toNode) throw `ID为${to}的组件不存在`;
|
||||||
|
|
||||||
if (isCommonMethod(methodName)) {
|
|
||||||
return triggerCommonMethod(methodName, toNode);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (toNode.instance) {
|
if (toNode.instance) {
|
||||||
if (typeof toNode.instance[methodName] === 'function') {
|
if (typeof toNode.instance[methodName] === 'function') {
|
||||||
await toNode.instance[methodName](fromCpt, ...args);
|
await toNode.instance[methodName](fromCpt, ...args);
|
||||||
@ -259,17 +220,4 @@ export default class EventHelper extends EventEmitter {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private commonClickEventHandler = (e: MouseEvent) => {
|
|
||||||
if (!e.target) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const node = getDirectComponent(e.target as HTMLElement, this.app);
|
|
||||||
|
|
||||||
const eventName = `${getCommonEventName('click')}_${node?.data.id}`;
|
|
||||||
if (node?.eventKeys.has(eventName)) {
|
|
||||||
this.emit(node.eventKeys.get(eventName)!, node);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
@ -18,8 +18,6 @@
|
|||||||
import { JsEngine } from '@tmagic/schema';
|
import { JsEngine } from '@tmagic/schema';
|
||||||
import { isNumber } from '@tmagic/utils';
|
import { isNumber } from '@tmagic/utils';
|
||||||
|
|
||||||
import type { default as TMagicNode } from './Node';
|
|
||||||
|
|
||||||
export const style2Obj = (style: string) => {
|
export const style2Obj = (style: string) => {
|
||||||
if (typeof style !== 'string') {
|
if (typeof style !== 'string') {
|
||||||
return style;
|
return style;
|
||||||
@ -119,47 +117,7 @@ export const transformStyle = (style: Record<string, any> | string, jsEngine: Js
|
|||||||
export const COMMON_EVENT_PREFIX = 'magic:common:events:';
|
export const COMMON_EVENT_PREFIX = 'magic:common:events:';
|
||||||
export const COMMON_METHOD_PREFIX = 'magic:common:actions:';
|
export const COMMON_METHOD_PREFIX = 'magic:common:actions:';
|
||||||
|
|
||||||
export const CommonMethod = {
|
|
||||||
SHOW: 'show',
|
|
||||||
HIDE: 'hide',
|
|
||||||
SCROLL_TO_VIEW: 'scrollIntoView',
|
|
||||||
SCROLL_TO_TOP: 'scrollToTop',
|
|
||||||
};
|
|
||||||
|
|
||||||
export const isCommonMethod = (methodName: string) => methodName.startsWith(COMMON_METHOD_PREFIX);
|
|
||||||
|
|
||||||
export const triggerCommonMethod = (methodName: string, node: TMagicNode) => {
|
|
||||||
const { instance } = node;
|
|
||||||
|
|
||||||
if (!instance) return;
|
|
||||||
|
|
||||||
switch (methodName.replace(COMMON_METHOD_PREFIX, '')) {
|
|
||||||
case CommonMethod.SHOW:
|
|
||||||
instance.show();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CommonMethod.HIDE:
|
|
||||||
instance.hide();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CommonMethod.SCROLL_TO_VIEW:
|
|
||||||
instance.$el?.scrollIntoView({ behavior: 'smooth' });
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CommonMethod.SCROLL_TO_TOP:
|
|
||||||
window.scrollTo({ top: 0, behavior: 'smooth' });
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export interface EventOption {
|
export interface EventOption {
|
||||||
label: string;
|
label: string;
|
||||||
value: string;
|
value: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
export const DEFAULT_EVENTS: EventOption[] = [{ label: '点击', value: `${COMMON_EVENT_PREFIX}click` }];
|
|
||||||
|
|
||||||
export const DEFAULT_METHODS: EventOption[] = [];
|
|
||||||
|
@ -19,11 +19,9 @@
|
|||||||
import { reactive } from 'vue';
|
import { reactive } from 'vue';
|
||||||
import { cloneDeep } from 'lodash-es';
|
import { cloneDeep } from 'lodash-es';
|
||||||
|
|
||||||
import { DEFAULT_EVENTS, DEFAULT_METHODS, EventOption } from '@tmagic/core';
|
import { type EventOption } from '@tmagic/core';
|
||||||
import { toLine } from '@tmagic/utils';
|
import { toLine } from '@tmagic/utils';
|
||||||
|
|
||||||
import type { ComponentGroup } from '@editor/type';
|
|
||||||
|
|
||||||
import BaseService from './BaseService';
|
import BaseService from './BaseService';
|
||||||
|
|
||||||
let eventMap: Record<string, EventOption[]> = reactive({});
|
let eventMap: Record<string, EventOption[]> = reactive({});
|
||||||
@ -34,20 +32,6 @@ class Events extends BaseService {
|
|||||||
super([]);
|
super([]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public init(componentGroupList: ComponentGroup[]) {
|
|
||||||
componentGroupList.forEach((group) => {
|
|
||||||
group.items.forEach((element) => {
|
|
||||||
const type = toLine(element.type);
|
|
||||||
if (!this.getEvent(type)) {
|
|
||||||
this.setEvent(type, DEFAULT_EVENTS);
|
|
||||||
}
|
|
||||||
if (!this.getMethod(type)) {
|
|
||||||
this.setMethod(type, DEFAULT_METHODS);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public setEvents(events: Record<string, EventOption[]>) {
|
public setEvents(events: Record<string, EventOption[]>) {
|
||||||
Object.keys(events).forEach((type: string) => {
|
Object.keys(events).forEach((type: string) => {
|
||||||
this.setEvent(toLine(type), events[type] || []);
|
this.setEvent(toLine(type), events[type] || []);
|
||||||
@ -55,11 +39,11 @@ class Events extends BaseService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public setEvent(type: string, events: EventOption[]) {
|
public setEvent(type: string, events: EventOption[]) {
|
||||||
eventMap[toLine(type)] = [...DEFAULT_EVENTS, ...events];
|
eventMap[toLine(type)] = [...events];
|
||||||
}
|
}
|
||||||
|
|
||||||
public getEvent(type: string): EventOption[] {
|
public getEvent(type: string): EventOption[] {
|
||||||
return cloneDeep(eventMap[toLine(type)] || DEFAULT_EVENTS);
|
return cloneDeep(eventMap[toLine(type)]) || [];
|
||||||
}
|
}
|
||||||
|
|
||||||
public setMethods(methods: Record<string, EventOption[]>) {
|
public setMethods(methods: Record<string, EventOption[]>) {
|
||||||
@ -69,11 +53,11 @@ class Events extends BaseService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public setMethod(type: string, method: EventOption[]) {
|
public setMethod(type: string, method: EventOption[]) {
|
||||||
methodMap[toLine(type)] = [...DEFAULT_METHODS, ...method];
|
methodMap[toLine(type)] = [...method];
|
||||||
}
|
}
|
||||||
|
|
||||||
public getMethod(type: string) {
|
public getMethod(type: string) {
|
||||||
return cloneDeep(methodMap[toLine(type)] || DEFAULT_METHODS);
|
return cloneDeep(methodMap[toLine(type)]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public resetState() {
|
public resetState() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user