parisma 16f671cd8f feat(editor): 代码块支持传递参数 (merge request !9)
Squash merge branch 'feature/parisma_codeDraft' into 'master'
1、 table支持items为函数
2、代码块支持传递参数
2022-11-15 08:48:19 +00:00

105 lines
2.5 KiB
TypeScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*
* Tencent is pleased to support the open source community by making TMagicEditor available.
*
* Copyright (C) 2021 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
export enum NodeType {
CONTAINER = 'container',
PAGE = 'page',
ROOT = 'app',
}
export type Id = string | number;
export interface EventItemConfig {
/** 被选中组件ID */
to: Id;
/** 被选中组件名称 */
name: string;
/** 触发事件后执行被选中组件的方法 */
method: string;
}
export interface MComponent {
/** 组件ID默认为${type}_${number}}形式, 如page_123 */
id: Id;
/** 组件类型 */
type?: string;
/** 组件显示名称 */
name?: string;
/** 组件根Dom上的class */
className?: string;
/* 关联事件集合 */
events?: EventItemConfig[];
/** 组件根Dom的style */
style?: {
[key: string]: any;
};
[key: string]: any;
}
export interface MContainer extends MComponent {
/** 容器类型,默认为'container' */
type?: NodeType.CONTAINER | string;
/** 容器子元素 */
items: (MComponent | MContainer)[];
}
export interface MPage extends MContainer {
/** 页面类型 */
type: NodeType.PAGE;
}
export interface MApp extends MComponent {
/** App页面类型app作为整个结构的根节点有且只有一个 */
type: NodeType.ROOT;
/** */
items: MPage[];
/** 代码块 */
codeBlocks?: CodeBlockDSL;
}
export interface CodeBlockDSL {
[id: Id]: CodeBlockContent;
}
export interface CodeBlockContent {
/** 代码块名称 */
name: string;
/** 代码块内容 */
content: any;
/** 参数定义 */
params: CodeParam[] | [];
/** 扩展字段 */
[propName: string]: any;
}
export interface CodeParam {
/** 参数名 */
name: string;
}
export interface PastePosition {
left?: number;
top?: number;
}
export type MNode = MComponent | MContainer | MPage | MApp;
export enum HookType {
/** 代码块钩子标识 */
CODE = 'code',
}