From 7cdffc55a12a0c1a88745b5a4bc89ef509bd1944 Mon Sep 17 00:00:00 2001 From: allenve Date: Mon, 2 Dec 2024 16:47:18 +0800 Subject: [PATCH 1/8] =?UTF-8?q?fix:=20=E5=85=A8=E5=B1=80=E5=B9=BF=E6=92=AD?= =?UTF-8?q?=E4=BA=8B=E4=BB=B6=E5=8F=8A=E6=97=B6=E6=9B=B4=E6=96=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../amis-editor-core/src/component/Editor.tsx | 12 +++++ .../src/component/base/SchemaForm.tsx | 1 + packages/amis-editor-core/src/store/editor.ts | 11 ++++- .../otherActionsPanel/broadcast.tsx | 5 +-- .../src/renderer/event-control/helper.tsx | 3 -- .../src/renderer/event-control/index.tsx | 45 ++++++++++--------- 6 files changed, 47 insertions(+), 30 deletions(-) diff --git a/packages/amis-editor-core/src/component/Editor.tsx b/packages/amis-editor-core/src/component/Editor.tsx index 5862cb7ee82..a3e7ed95edb 100644 --- a/packages/amis-editor-core/src/component/Editor.tsx +++ b/packages/amis-editor-core/src/component/Editor.tsx @@ -206,6 +206,10 @@ export default class Editor extends Component { this.manager = new EditorManager(config, this.store, hostManager); + this.store.setGlobalEvents( + config.actionOptions?.globalEventGetter?.(this.manager) || [] + ); + // 子编辑器不再重新设置 editorStore if (!(props.isSubEditor && (window as any).editorStore)) { (window as any).editorStore = this.store; @@ -274,6 +278,14 @@ export default class Editor extends Component { if (props?.amisEnv?.replaceText !== prevProps?.amisEnv?.replaceText) { this.store.setAppCorpusData(props?.amisEnv?.replaceText); } + if ( + props.actionOptions?.globalEventGetter?.(this.manager) !== + prevProps.actionOptions?.globalEventGetter?.(this.manager) + ) { + this.store.setGlobalEvents( + props.actionOptions?.globalEventGetter?.(this.manager) || [] + ); + } } componentWillUnmount() { diff --git a/packages/amis-editor-core/src/component/base/SchemaForm.tsx b/packages/amis-editor-core/src/component/base/SchemaForm.tsx index 57c9c677dbc..433bb846d57 100644 --- a/packages/amis-editor-core/src/component/base/SchemaForm.tsx +++ b/packages/amis-editor-core/src/component/base/SchemaForm.tsx @@ -4,6 +4,7 @@ import {EditorManager} from '../../manager'; import {diff, getThemeConfig} from '../../util'; import { createObjectFromChain, + createObject, extractObjectChain, IFormStore, render, diff --git a/packages/amis-editor-core/src/store/editor.ts b/packages/amis-editor-core/src/store/editor.ts index 93d3a05c8b4..0cd5af54f42 100644 --- a/packages/amis-editor-core/src/store/editor.ts +++ b/packages/amis-editor-core/src/store/editor.ts @@ -37,7 +37,8 @@ import { ScaffoldForm, PopOverForm, DeleteEventContext, - BaseEventContext + BaseEventContext, + IGlobalEvent } from '../plugin'; import { JSONDuplicate, @@ -265,7 +266,9 @@ export const MainStore = types /** 应用语料 */ appCorpusData: types.optional(types.frozen(), {}), /** 应用多语言状态,用于其它组件进行订阅 */ - appLocaleState: types.optional(types.number, 0) + appLocaleState: types.optional(types.number, 0), + /** 全局广播事件 */ + globalEvents: types.optional(types.frozen>(), []) }) .views(self => { return { @@ -2348,6 +2351,10 @@ export const MainStore = types this.updateAppLocaleState(); }, + setGlobalEvents(events: IGlobalEvent[]) { + self.globalEvents = events; + }, + beforeDestroy() { lazyUpdateTargetName.cancel(); } diff --git a/packages/amis-editor/src/renderer/event-control/actionsPanelPlugins/otherActionsPanel/broadcast.tsx b/packages/amis-editor/src/renderer/event-control/actionsPanelPlugins/otherActionsPanel/broadcast.tsx index 3a07eb08ee8..bb71d8b5020 100644 --- a/packages/amis-editor/src/renderer/event-control/actionsPanelPlugins/otherActionsPanel/broadcast.tsx +++ b/packages/amis-editor/src/renderer/event-control/actionsPanelPlugins/otherActionsPanel/broadcast.tsx @@ -8,7 +8,7 @@ registerActionPanel('broadcast', { description: '触发全局广播事件', innerArgs: [], descDetail: (info: any, context: any, props: any) => { - const globalEvents = props.globalEvents || []; + const globalEvents = props.manager.store.globalEvents; const event = globalEvents.find( (item: any) => item.name === info?.eventName ); @@ -21,8 +21,7 @@ registerActionPanel('broadcast', { ); }, schema: (manager: EditorManager, data: any) => { - const globalEvents = - manager.config?.actionOptions?.globalEventGetter?.(manager) || []; + const globalEvents = manager.store.globalEvents; return { type: 'wrapper', body: [ diff --git a/packages/amis-editor/src/renderer/event-control/helper.tsx b/packages/amis-editor/src/renderer/event-control/helper.tsx index 56922fc9a24..6d841d3b654 100644 --- a/packages/amis-editor/src/renderer/event-control/helper.tsx +++ b/packages/amis-editor/src/renderer/event-control/helper.tsx @@ -953,8 +953,6 @@ export const getEventControlConfig = ( const actionTree = manager?.config.actionOptions?.actionTreeGetter ? manager?.config.actionOptions?.actionTreeGetter(ACTION_TYPE_TREE(manager)) : ACTION_TYPE_TREE(manager); - const globalEvents = - manager?.config.actionOptions?.globalEventGetter?.(manager); const allComponents = manager?.store?.getComponentTreeSource(); return { showOldEntry: @@ -966,7 +964,6 @@ export const getEventControlConfig = ( events: manager?.pluginEvents, actionTree, commonActions, - globalEvents, owner: '', addBroadcast: manager?.addBroadcast.bind(manager), removeBroadcast: manager?.removeBroadcast.bind(manager), diff --git a/packages/amis-editor/src/renderer/event-control/index.tsx b/packages/amis-editor/src/renderer/event-control/index.tsx index bcb59784328..e85eb57810a 100644 --- a/packages/amis-editor/src/renderer/event-control/index.tsx +++ b/packages/amis-editor/src/renderer/event-control/index.tsx @@ -62,10 +62,10 @@ import {updateComponentContext} from 'amis-editor-core'; import type {VariableItem} from 'amis-ui'; interface EventControlProps extends FormControlProps { + manager: EditorManager; actions: PluginActions; // 组件的动作列表 events: PluginEvents; // 组件的事件列表 actionTree: RendererPluginAction[]; // 动作树 - globalEvents?: IGlobalEvent[]; // 全局事件 commonActions?: {[propName: string]: RendererPluginAction}; // 公共动作Map value: ActionEventConfig; // 事件动作配置 onChange: ( @@ -140,6 +140,7 @@ interface EventControlState { type: 'update' | 'add'; appLocaleState?: number; actionRelations: any; + globalEvents: IGlobalEvent[]; } const dialogObjMap = { @@ -158,12 +159,14 @@ export class EventControl extends React.Component< } = {}; drag?: HTMLElement | null; unReaction: any; + unEventReaction: any; submitSubscribers: Array<(value: any) => any> = []; constructor(props: EventControlProps) { super(props); - const {events, value, data, rawType, globalEvents} = props; - + const {events, value, data, rawType} = props; + const editorStore = props.manager.store; + const globalEvents = editorStore.globalEvents; const eventPanelActive: { [prop: string]: boolean; } = {}; @@ -193,12 +196,13 @@ export class EventControl extends React.Component< actionData: undefined, type: 'add', appLocaleState: 0, - actionRelations: actionRelations ?? [] + actionRelations: actionRelations ?? [], + globalEvents: globalEvents }; } componentDidMount(): void { - const editorStore = (window as any).editorStore; + const editorStore = this.props.manager.store; this.unReaction = reaction( () => editorStore?.appLocaleState, () => { @@ -207,10 +211,19 @@ export class EventControl extends React.Component< }); } ); + this.unEventReaction = reaction( + () => editorStore.globalEvents, + () => { + this.setState({ + globalEvents: editorStore.globalEvents + }); + } + ); } componentWillUnmount() { this.unReaction?.(); + this.unEventReaction?.(); this.submitSubscribers = []; } @@ -228,21 +241,12 @@ export class EventControl extends React.Component< data?.type !== prevProps.data?.type || data?.onEvent !== prevProps.data?.onEvent ) { - const eventPanelActive: { - [prop: string]: boolean; - } = {}; const tmpEvents = events[ rawType || (!data.type || data.type === 'text' ? 'plain' : data.type) ] || []; const pluginEvents = typeof tmpEvents === 'function' ? tmpEvents(data) : [...tmpEvents]; - - // 事件配置面板不自动折叠 - // pluginEvents.forEach((event: RendererPluginEvent) => { - // eventPanelActive[event.eventName] = true; - // }); - const actionRelations = this.getActionRelations(); this.setState({ @@ -638,10 +642,9 @@ export class EventControl extends React.Component< actionTree, actions: pluginActions, commonActions, - allComponents, - globalEvents + allComponents } = this.props; - const {events, onEvent} = this.state; + const {events, onEvent, globalEvents} = this.state; const eventConfig = events.find( item => item.eventName === data.actionData!.eventKey ); @@ -771,7 +774,7 @@ export class EventControl extends React.Component< variables = (manager.dataSchema as DataSchema).getDataPropsAsOptions(); // 插入应用变量 - const appVariables: VariableItem[] = + const appVariables = manager?.variableManager?.getVariableFormulaOptions() || []; appVariables.forEach(item => { if (Array.isArray(item?.children) && item.children.length) { @@ -1079,14 +1082,12 @@ export class EventControl extends React.Component< actions: pluginActions, commonActions, getComponents, - allComponents, - render, - globalEvents = [], - subscribeSchemaSubmit + render } = this.props; const { onEvent, events: itemEvents, + globalEvents, eventPanelActive, showAcionDialog, showEventDialog, From 421f86d5fba1efe6282dbc6b5d6f8bcccc847d6f Mon Sep 17 00:00:00 2001 From: allenve Date: Mon, 2 Dec 2024 19:15:04 +0800 Subject: [PATCH 2/8] =?UTF-8?q?fix:=20=E4=BA=BA=E5=91=98=E7=BB=84=E4=BB=B6?= =?UTF-8?q?=E7=A7=BB=E5=8A=A8=E7=AB=AF=E6=94=AF=E6=8C=81=E7=A6=81=E7=94=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/amis-ui/src/components/UserSelect.tsx | 3 +++ packages/amis-ui/src/components/UserTabSelect.tsx | 3 +++ packages/amis/src/renderers/Form/UserSelect.tsx | 5 ++++- 3 files changed, 10 insertions(+), 1 deletion(-) diff --git a/packages/amis-ui/src/components/UserSelect.tsx b/packages/amis-ui/src/components/UserSelect.tsx index 2aa32d89416..eade24a6f97 100644 --- a/packages/amis-ui/src/components/UserSelect.tsx +++ b/packages/amis-ui/src/components/UserSelect.tsx @@ -45,6 +45,7 @@ export interface UserSelectProps controlled?: boolean; displayFields: Array; isTab?: boolean; + disabled?: boolean; fetcher?: ( api: Api, data?: any, @@ -995,6 +996,7 @@ export class UserSelect extends React.Component< showResultBox, labelField = 'label', valueField = 'value', + disabled, mobileUI } = this.props; @@ -1007,6 +1009,7 @@ export class UserSelect extends React.Component< className={cx('UserSelect-input', isOpened ? 'is-active' : '')} allowInput={false} result={this.getResult()} + disabled={disabled} itemRender={(option: any) => { if (labelField !== 'avatar') { return ( diff --git a/packages/amis-ui/src/components/UserTabSelect.tsx b/packages/amis-ui/src/components/UserTabSelect.tsx index 8c10022dd82..9f5f3c5fb7f 100644 --- a/packages/amis-ui/src/components/UserTabSelect.tsx +++ b/packages/amis-ui/src/components/UserTabSelect.tsx @@ -35,6 +35,7 @@ export interface UserTabSelectProps extends ThemeProps, LocaleProps { selection?: Array