From fe10cf437b17a2ea0ef63373cae2e5790ebc3930 Mon Sep 17 00:00:00 2001
From: cuiqian2004 <cuiqian2004@163.com>
Date: 星期四, 31 七月 2025 18:22:52 +0800
Subject: [PATCH] action 处理

---
 pages/modal/form/index.vue |  281 +++++++++++++++++++++++++++++++-------------------------
 1 files changed, 156 insertions(+), 125 deletions(-)

diff --git a/pages/modal/form/index.vue b/pages/modal/form/index.vue
index 3d77b3a..a49833b 100644
--- a/pages/modal/form/index.vue
+++ b/pages/modal/form/index.vue
@@ -1,8 +1,9 @@
 <template>
-	<view class="uni-page-modal-form">
+	<view class="uni-page-modal-form" :class="largeMode?'large-mode':''">
 		<view class="view-content">
 			<!-- 琛ㄥご鏍峰紡 -->
-			<OIForm ref="refBaseForm" class="v-head-style" :form="head_styledef.form" :focusId="focusFieldId"
+			<OIForm ref="refBaseForm" class="v-head-style" :form="head_styledef.form"
+				:hiddenIds="head_styledef.hiddenIds ?head_styledef.hiddenIds :[] " :focusId="focusFieldId"
 				@on-click="onClick" @on-focus="ontap" @on-change="onEnterChange" @on-click-prefix="classAttr_extButton"
 				@on-click-suffix="classAttr_extButton"></OIForm>
 		</view>
@@ -43,7 +44,7 @@
 <script>
 	import {
 		Base64
-	} from  '@/js/Base64.js';
+	} from '@/js/Base64.js';
 	import {
 		dictGetInfo
 	} from "@/api/mobox.js"
@@ -64,6 +65,7 @@
 		},
 		data() {
 			return {
+				largeMode: getApp().globalData.largeMode || false,
 				okLoading: false,
 				title: this.translateSys('add2'),
 				type: '',
@@ -293,6 +295,25 @@
 								}
 							}
 						}
+						const app = getApp()
+						if (app.globalData.bindClasses) {
+							styledefHead.form.items.push({
+								name: "Input",
+								label: this.translate("classes"),
+								labelWidth: 100,
+								disabled: true,
+								value: app.globalData.classes,
+								setting: {
+									width: 100,
+									height: 50,
+								},
+								bind: {
+									attr: "",
+								},
+								fieldId: "S_CLASSES",
+							})
+							styledefHead.form.model["S_CLASSES"] = app.globalData.classes
+						}
 
 					}
 					this.setData({
@@ -451,6 +472,7 @@
 							var tip = result.info ? typeof result.info ==
 								'string' ? result.info :
 								result.info.join('<br/>') : '';
+							tip = tip || result.err_info
 							if (tip) uni.showModal({
 								title: this.translateSys('tip'),
 								content: tip,
@@ -458,9 +480,21 @@
 								confirmText: this.translateSys(
 									'close')
 							});
+							if (result.result_type == 2) {
 
-							if (result.result_type == 0 && result.action) {
-								result.action.forEach(item => {
+							} else if (typeof result.result == 'string') {
+								if (result.result) {
+									uni.showModal({
+										title: this.translateSys('tip'),
+										content: result.result,
+										showCancel: false,
+										confirmText: this.translateSys('close')
+									});
+								}
+							}
+							try {
+								var actionList = result.action || []
+								actionList.forEach(item => {
 
 									if (item.action_type ==
 										"set_dlg_current_edit_attr"
@@ -489,22 +523,26 @@
 										// value = {"attr":"xxx", "value":"xxx"}
 										var data = item.value;
 										$this.setFormValues(data)
+									} else if (action.action_type == 'set_dlg_attr_show') {
+										var data = action.value;
+
+										$this.setFormItemVisible(data)
 									}
 								});
-							} else {
 
-								if (result.info) {
-									uni.showModal({
-										title: this.translateSys(
-											"error") + "4.3",
-										content: result.info,
-										showCancel: false,
-										confirmText: this
-											.translateSys('close')
-									});
-								}
+							} catch (ex) {
+								let actionList = (result.action || []).map(a => a.action_type).join(';')
+								let tip = typeof ex == 'string' ? ex : ex.message
+								tip = `鎵ц鑴氭湰杩斿洖鐨�{actionList}鏃跺嚭鐜板紓甯革紝璇锋鏌ヨ剼鏈繑鍥炵殑鏁版嵁鏍煎紡鏄惁姝g‘銆�{tip}`
+								uni.showModal({
+									title: this.translateSys('tip'),
+									content: tip,
+									showCancel: false,
+									confirmText: this.translateSys('close')
+								});
+								console.log(ex)
+								return
 							}
-
 						}
 
 					}
@@ -529,8 +567,8 @@
 				//console.log(e.target)
 				this.focusOldFieldId = item.fieldId
 				getApp().onScan((result) => {
-					console.log(result.decodedata);
-					item.value = result.decodedata;
+					console.log(result);
+					item.value = result;
 					var $this = this;
 					let newVal = item.value.trim()
 					if (newVal) {
@@ -756,6 +794,7 @@
 								var tip = result.info ? typeof result.info ==
 									'string' ? result.info :
 									result.info.join('<br/>') : '';
+								tip = tip || result.err_info
 								if (tip) uni.showModal({
 									title: this.translateSys('tip'),
 									content: tip,
@@ -763,9 +802,21 @@
 									confirmText: this.translateSys(
 										'close')
 								});
+								if (result.result_type == 2) {
 
-								if (result.result_type == 0 && result.action) {
-									result.action.forEach(item => {
+								} else if (typeof result.result == 'string') {
+									if (result.result) {
+										uni.showModal({
+											title: this.translateSys('tip'),
+											content: result.result,
+											showCancel: false,
+											confirmText: this.translateSys('close')
+										});
+									}
+								}
+								try {
+									var actionList = result.action || []
+									actionList.forEach(item => {
 
 										if (item.action_type ==
 											"set_dlg_current_edit_attr"
@@ -794,21 +845,29 @@
 											// value = {"attr":"xxx", "value":"xxx"}
 											var data = item.value;
 											$this.setFormValues(data)
+										} else if (action.action_type ==
+											'set_dlg_attr_show') {
+											var data = action.value;
+
+											$this.setFormItemVisible(data)
 										}
 									});
-								} else {
 
-									if (result.info) {
-										uni.showModal({
-											title: this.translateSys(
-												"error") + "4.3",
-											content: result.info,
-											showCancel: false,
-											confirmText: this
-												.translateSys('close')
-										});
-									}
+								} catch (ex) {
+									let actionList = (result.action || []).map(a => a.action_type)
+										.join(';')
+									let tip = typeof ex == 'string' ? ex : ex.message
+									tip = `鎵ц鑴氭湰杩斿洖鐨�{actionList}鏃跺嚭鐜板紓甯革紝璇锋鏌ヨ剼鏈繑鍥炵殑鏁版嵁鏍煎紡鏄惁姝g‘銆�{tip}`
+									uni.showModal({
+										title: this.translateSys('tip'),
+										content: tip,
+										showCancel: false,
+										confirmText: this.translateSys('close')
+									});
+									console.log(ex)
+									return
 								}
+
 
 							}
 
@@ -870,7 +929,8 @@
 											if (col.useDict) {
 												col.dict = dictItemList;
 											} else {
-												col.selections = dictItemList;
+												col.selections =
+													dictItemList;
 											}
 										}
 									}
@@ -900,11 +960,32 @@
 
 					//鍒ゆ柇琛ㄥ崟閲屾槸鍚︽湁杩斿洖瀛楁锛屾病鏈夊氨瑁呰浇鍒癿odel閲岋紝鐐瑰嚮纭畾鎻愪氦鐨勬椂鍊欏甫涓婅繖浜涙暟鎹� 				})
-				console.log(head_styledef)
 				this.setData({
 					head_styledef: head_styledef
 				})
 			},
+			setFormItemVisible(attrs) {
+				if (!Array.isArray(attrs)) {
+					return
+				}
+				const head_styledef = this.head_styledef
+				if (!head_styledef.hiddenIds) {
+					head_styledef.hiddenIds = []
+				}
+				attrs.forEach((attr) => {
+					let index = head_styledef.hiddenIds.findIndex((id) => id == attr.attr);
+					if (attr.show) {
+						if (index > -1) head_styledef.hiddenIds.splice(index, 1);
+					} else {
+						if (index == -1) head_styledef.hiddenIds.push(attr.attr);
+					}
+				});
+				this.setData({
+					head_styledef: head_styledef
+				})
+
+			},
+
 			popupChange(e) {
 				console.log('褰撳墠妯″紡锛� + e.type + ',鐘舵�锛� + e.show);
 			},
@@ -1087,43 +1168,8 @@
 									$this.setFormValues(result)
 								} else if (action.action_type == 'set_dlg_attr_show') {
 									var result = action.value;
-									result.forEach(async (attr, key) => {
-										$this.head_styledef.form.items
-											.forEach(
-												async (ele,
-													index) => {
-													//鍒ゆ柇鏄惁鏄爡鏍艰〃鍗�-													if (ele.name != 'Layout') {
-														if (ele.fieldId == attr
-															.attr) {
-															ele.show = attr
-																.show;
-														}
-													} else if (ele.name ==
-														'Layout') {
-														ele.setting.colList
-															.forEach(
-																col => {
-																	if (col) {
-																		if (col
-																			.fieldId ==
-																			attr
-																			.attr
-																		) {
-																			col.show =
-																				attr
-																				.show;
-																		}
-																	}
-																});
-													}
-												});
-									});
-									var head_styledef = JSON.parse(JSON.stringify($this.$data
-										.head_styledef));
-									$this.head_styledef = [];
-									$this.head_styledef = head_styledef;
-									// console.log($this.head_styledef);
+
+									$this.setFormItemVisible(result)
 								} else if (action.action_type == 'set_global_attr') {
 									$this.global_attr = action.value || [];
 								} else {
@@ -1337,7 +1383,8 @@
 											$this.setData({
 												check_list: val.config
 											})
-											if (val.config.appear_style == 'sideslip') //鍒ゆ柇鏄惁鏄晶婊�+											if (val.config.appear_style ==
+												'sideslip') //鍒ゆ柇鏄惁鏄晶婊� 												$this.setData({
 													popupType: "right"
 												})
@@ -1357,7 +1404,8 @@
 												popupParam: popupParam
 											})
 										}
-									} else if (action.action_type == 'open_project_query_dlg') {
+									} else if (action.action_type ==
+										'open_project_query_dlg') {
 										//console.log(action.value.select_range);
 										//console.log(action.value.mulit_select);
 										var priRel = '-1';
@@ -1422,7 +1470,8 @@
 											title: $this.translateSys("tip"),
 											content: $this.translateSys(
 													"quotation_mark_left") +
-												action.action_type + $this.translateSys(
+												action.action_type + $this
+												.translateSys(
 													"quotation_mark_right") + $this
 												.translate(
 													"tip_action_unprocessed"),
@@ -1646,8 +1695,10 @@
 							value: obj_attr[a],
 						})),
 					};
-					let global_attr = Base64.encode(JSON.stringify(this.global_attr))
-					let data_json = Base64.encode(JSON.stringify(this.data_json))
+					let global_attr = Base64.encode(JSON.stringify(this
+						.global_attr))
+					let data_json = Base64.encode(JSON.stringify(this
+						.data_json))
 					let ext_info = Base64.encode(JSON.stringify(this.ext_info))
 					var dataInfo = {
 						ed_type: "0",
@@ -1666,7 +1717,8 @@
 						data_json,
 						ext_info,
 						compose_info: '',
-						input_param: Base64.encode(JSON.stringify(input_param)),
+						input_param: Base64.encode(JSON.stringify(
+							input_param)),
 					};
 					await runCustomEvent(dataInfo)
 					return true
@@ -1724,7 +1776,8 @@
 						.global_attr))
 					let data_json = Base64.encode(JSON.stringify(this
 						.data_json))
-					let ext_info = Base64.encode(JSON.stringify(this.ext_info))
+					let ext_info = Base64.encode(JSON.stringify(this
+						.ext_info))
 
 					await runCustomEvent({
 						ed_type: 0,
@@ -1743,9 +1796,11 @@
 					let exStr = JSON.stringify(ex)
 					if (exStr == "{}")
 						exStr = ex
-					let tip = typeof ex.errMsg == "string" ? ex.errMsg : exStr
+					let tip = typeof ex.errMsg == "string" ? ex
+						.errMsg : exStr
 					uni.showModal({
-						title: this.translateSys("tip") + "8.1",
+						title: this.translateSys("tip") +
+							"8.1",
 						content: tip,
 						showCancel: false,
 						confirmText: this.translateSys('close')
@@ -1759,18 +1814,22 @@
 					var obj_attr = this.head_styledef.form.model;
 					let inputParam = {
 						id: "",
-						attrs: Object.keys(obj_attr).map((a) => ({
-							attr: a,
-							value: obj_attr[a],
-						})),
+						attrs: Object.keys(obj_attr).map((a) =>
+							({
+								attr: a,
+								value: obj_attr[a],
+							})),
 					};
 					let input_param = Base64.encode(JSON.stringify(
 						inputParam));
-					let global_attr = Base64.encode(JSON.stringify(this
+					let global_attr = Base64.encode(JSON.stringify(
+						this
 						.global_attr))
-					let data_json = Base64.encode(JSON.stringify(this
+					let data_json = Base64.encode(JSON.stringify(
+						this
 						.data_json))
-					let ext_info = Base64.encode(JSON.stringify(this
+					let ext_info = Base64.encode(JSON.stringify(
+						this
 						.ext_info))
 
 					await runCustomEvent({
@@ -1790,13 +1849,16 @@
 					let exStr = JSON.stringify(ex)
 					if (exStr == "{}")
 						exStr = ex
-					let tip = typeof ex.errMsg == "string" ? ex.errMsg :
+					let tip = typeof ex.errMsg == "string" ? ex
+						.errMsg :
 						exStr
 					uni.showModal({
-						title: this.translateSys("tip") + "8.2",
+						title: this.translateSys("tip") +
+							"8.2",
 						content: tip,
 						showCancel: false,
-						confirmText: this.translateSys('close')
+						confirmText: this.translateSys(
+							'close')
 					});
 					return false
 				}
@@ -1804,9 +1866,11 @@
 			showError(ex) {
 				uni.showModal({
 					title: this.translateSys('error'),
-					content: typeof ex == "string" ? ex : typeof ex.errMsg == "string" ? ex.errMsg : "",
+					content: typeof ex == "string" ? ex : typeof ex.errMsg == "string" ? ex
+						.errMsg : "",
 					showCancel: false,
-					confirmText: this.translateSys('cancel')
+					confirmText: this.translateSys(
+						'cancel')
 				})
 			},
 			translate(t) {
@@ -1838,39 +1902,6 @@
 			flex-direction: column;
 		}
 
-		.v-head-style {
-			width: 98%;
-
-			.uni-forms-item {
-				margin-bottom: 11rpx;
-			}
-
-			.input-wrapper {
-				border: 1px solid #d5d5d5;
-				width: 100%;
-				display: flex;
-				flex-direction: row;
-
-				.uni-input {
-					flex: 1;
-					padding: 12rpx 8rpx;
-					color: #2d8cf0;
-					// height: 40rpx;
-					// line-height: 40rpx;
-				}
-
-				.uni-icon {
-
-					padding: 10rpx 5rpx;
-					font-size: 32rpx;
-					color: rgb(192, 196, 204);
-				}
-			}
-
-			.input-wrapper:hover {
-				border: 1px solid rgb(41, 121, 255);
-			}
-		}
 
 		.view-content {
 			display: flex;

--
Gitblit v1.9.1