From 22f32b8a34c5eb819e00709f11a70064c44fe7c0 Mon Sep 17 00:00:00 2001 From: fujianchao Date: Fri, 13 Dec 2024 15:11:22 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20crud=E7=9A=84=E5=8D=A1=E7=89=87?= =?UTF-8?q?=E9=A3=8E=E6=A0=BC=E6=94=AF=E6=8C=81=E8=A1=8C=E7=82=B9=E5=87=BB?= =?UTF-8?q?=EF=BC=8C=E9=80=89=E6=8B=A9=E8=A1=A8=E6=A0=BC=E9=A1=B9=EF=BC=8C?= =?UTF-8?q?=E8=A1=8C=E6=8E=92=E5=BA=8F=E4=BA=8B=E4=BB=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/amis/src/renderers/Action.tsx | 1 + packages/amis/src/renderers/Card.tsx | 2 ++ packages/amis/src/renderers/Cards.tsx | 40 ++++++++++++++++++++++++-- 3 files changed, 41 insertions(+), 2 deletions(-) diff --git a/packages/amis/src/renderers/Action.tsx b/packages/amis/src/renderers/Action.tsx index 9c1094f9a41..4fd72457f30 100644 --- a/packages/amis/src/renderers/Action.tsx +++ b/packages/amis/src/renderers/Action.tsx @@ -993,6 +993,7 @@ export class ActionRenderer extends React.Component { let confirmText: string = ''; // 有些组件虽然要求这里忽略二次确认,但是如果配了事件动作还是需要在这里等待二次确认提交才可以 if ( + !this.props.customVerify && // customVerify 外部透传过来的验证,勿删 (!ignoreConfirm || hasOnEvent) && action.confirmText && env.confirm && diff --git a/packages/amis/src/renderers/Card.tsx b/packages/amis/src/renderers/Card.tsx index 39f7805d29d..ea0dca74116 100644 --- a/packages/amis/src/renderers/Card.tsx +++ b/packages/amis/src/renderers/Card.tsx @@ -303,6 +303,7 @@ export class CardRenderer extends React.Component { itemAction, onAction, onCheck, + onClick, selectable, checkOnItemClick } = this.props; @@ -326,6 +327,7 @@ export class CardRenderer extends React.Component { } selectable && checkOnItemClick && onCheck?.(item); + onClick && onClick(item); } handleAction(e: React.UIEvent, action: ActionObject, ctx: object) { diff --git a/packages/amis/src/renderers/Cards.tsx b/packages/amis/src/renderers/Cards.tsx index a1391febab5..02c3988300e 100644 --- a/packages/amis/src/renderers/Cards.tsx +++ b/packages/amis/src/renderers/Cards.tsx @@ -236,6 +236,7 @@ export default class Cards extends React.Component { this.handleAction = this.handleAction.bind(this); this.handleCheck = this.handleCheck.bind(this); + this.handleClick = this.handleClick.bind(this); this.handleCheckAll = this.handleCheckAll.bind(this); this.handleQuickChange = this.handleQuickChange.bind(this); this.handleSave = this.handleSave.bind(this); @@ -367,6 +368,32 @@ export default class Cards extends React.Component { handleCheck(item: IItem) { item.toggle(); this.syncSelected(); + + const {store, dispatchEvent} = this.props; + const selectItems = store.selectedItems.map(row => row.data); + const unSelectItems = store.unSelectedItems.map(row => row.data); + + dispatchEvent( + //增删改查卡片模式选择表格项 + 'selectedChange', + createObject(store.data, { + selectedItems: selectItems, + unSelectedItems: unSelectItems, + item: item.data + }) + ); + } + + handleClick(item: IItem) { + const {dispatchEvent, data} = this.props; + return dispatchEvent( + //增删改查卡片模式单击卡片 + 'rowClick', + createObject(data, { + item: item.data, + index: item.index + }) + ); } handleCheckAll() { @@ -475,9 +502,17 @@ export default class Cards extends React.Component { ); } - handleSaveOrder() { - const {store, onSaveOrder} = this.props; + async handleSaveOrder() { + const {store, onSaveOrder, data, dispatchEvent} = this.props; + const movedItems = store.movedItems.map(item => item.data); + const rendererEvent = await dispatchEvent( + 'orderChange', + createObject(data, {movedItems}) + ); + if (rendererEvent?.prevented) { + return; + } if (!onSaveOrder || !store.movedItems.length) { return; } @@ -909,6 +944,7 @@ export default class Cards extends React.Component { data: item.locals, onAction: this.handleAction, onCheck: this.handleCheck, + onClick: this.handleClick, onQuickChange: store.dragging ? null : this.handleQuickChange };