From 07925905f1a596e20e980de6d42db217abb753b0 Mon Sep 17 00:00:00 2001
From: cuiqian2004 <cuiqian2004@163.com>
Date: 星期五, 12 十二月 2025 18:06:11 +0800
Subject: [PATCH] plugin

---
 pages/modal/3202.vue |  850 ++++++++++++++++++++++++++-----------------------------
 1 files changed, 402 insertions(+), 448 deletions(-)

diff --git a/pages/modal/3202.vue b/pages/modal/3202.vue
index 5ac47af..c12cac2 100644
--- a/pages/modal/3202.vue
+++ b/pages/modal/3202.vue
@@ -18,7 +18,7 @@
 									<button size="mini" v-for="(btn,btnIndex) in rowButtons" :key="btnIndex"
 										type="primary" @click="onRowBtnClick(btn, ii)">
 										<text v-if="btn.Style == 'img' || btn.Style == 'img_text'" class="img"></text>
-										{{btn.ShowName}}
+										{{btn.ShowName || ""}}
 									</button>
 								</div>
 							</div>
@@ -38,6 +38,12 @@
 		Base64
 	} from '@/js/Base64.js';
 	import classUtils from "@/js/utils.js"
+	import {
+		showInfo,
+		showError,
+		showLoading,
+		hideLoading
+	} from "@/js/Page.js"
 	import {
 		appGetInfo,
 		dictGetInfo
@@ -102,31 +108,49 @@
 			rowButtons() {
 				return this.param?.ListItem_Button || [];
 			},
+			initialEvent() {
+				let event = (this.head_styledef.event || []).find((e) => e.event_id == "initial");
+				return {
+					id: event?.scrip_id || "",
+					name: event?.scrip_name || "",
+				};
+			},
 
 		},
-		async onLoad(options) {
-			// console.log(options);
+		onReady() {
 			uni.setNavigationBarTitle({
-				title: options.titlename
+				title: this.title 
 			}); //璁剧疆椤堕儴鏍囬 
-			this.title = options.titlename;
-			this.param = JSON.parse(options.param);
-			this.styledef = {};
-			this.head_styledef = {
-				form: {
-					items: []
-				}
-			};
-			this.detail1_styledef = {};
-			this.detail1StyleDefList = [];
-			this.items = [];
-			this.active_id = '';
-			this.activeItem = {};
-			this.click_item_view = false
-			if (this.param?.ClickItem_Event?.id)
-				this.click_item_view = true
-			await this.Detail1_UIstyleGetInfo(this.param.ClsID, this.param.ListItem_Panel.id);
-			this.initial()
+		},
+		async onLoad(options) {
+			try {
+				showLoading("loading...")
+				// console.log(options);
+		
+				this.title = options.titlename;
+				this.param = JSON.parse(options.param);
+				const paramValue = options.paramValue ? JSON.parse(options.paramValue) : undefined
+				this.styledef = {};
+				this.head_styledef = {
+					form: {
+						items: []
+					}
+				};
+				this.detail1_styledef = {};
+				this.detail1StyleDefList = [];
+				this.items = [];
+				this.active_id = '';
+				this.activeItem = {};
+				this.click_item_view = false
+				if (this.param?.ClickItem_Event?.id)
+					this.click_item_view = true
+				await this.Detail1_UIstyleGetInfo(this.param.ClsID, this.param.ListItem_Panel.id);
+				this.initial(paramValue)
+				hideLoading()
+			} catch (ex) {
+				hideLoading()
+				showError(ex, this.translateSys("error"));
+			}
 
 		},
 		methods: {
@@ -153,7 +177,7 @@
 				});
 			},
 			//鍒濆鍖�-			async initial() {
+			async initial(paramValue) {
 				this.refreshing = true
 				await this.Head_UIStyleGetInfo(this.param.ClsID, this.param.Input_Panel.id);
 				this.wheres = '';
@@ -162,7 +186,152 @@
 				this.query_id = "";
 				this.detail1StyleDefList = [];
 				this.refreshing = false
+				if (paramValue) {
 
+					this.setFormValues(paramValue)
+				}
+				await this.loadInitialEvent();
+			},
+			async loadInitialEvent() {
+
+				try {
+					const event = this.initialEvent
+					if (event.id) {
+						var obj_attr = this.head_styledef.form.model;
+						console.log(obj_attr);
+						var input_param = Base64.encode(
+							JSON.stringify({
+								id: "",
+								attrs: Object.keys(obj_attr).map((a) => ({
+									attr: a,
+									value: obj_attr[a] || "",
+								}))
+							})
+						);
+						var $this = this;
+						var dataInfo = {
+							ed_type: 0,
+							start_transaction: true,
+							class_id: this.head_styledef.form.clsId,
+							class_name: '',
+							event_id: event.id,
+							event_name: '',
+							data_obj_id: '',
+							obj_attr: obj_attr,
+							prj_id: '',
+							ref_cls_id: '',
+							rel_obj_id: '',
+							user_login: '',
+							data_json: '',
+							compose_info: '',
+							ext_info: '',
+							global_attr: '',
+							input_param: input_param,
+						};
+						runCustomEvent(dataInfo).then(result => {
+							console.log(result);
+
+							if (result.ret != 0 && result.ret != 1) {
+								let cls_name = result.event_info?.cls_name
+								let event_name = result.event_info?.event_name
+								tip = result.err_info ? typeof result.err_info == 'string' ? result.err_info :
+									result
+									.err_info
+									.join('\n') : ''
+								if (result.ret == 801) {
+									if (this.param.Only_Script_Error) {
+										let pos = tip.indexOf("锛�);
+										if (pos > -1) tip = tip.substring(pos + 1);
+									}
+								}
+								if (cls_name && event_name) tip =
+									`鎵ц鈥�{cls_name}鈥濇暟鎹被鐨勨�${event_name}鈥濊剼鏈椂杩斿洖閿欒锛�{tip}`
+								if (result.ret == 801) showInfo(tip)
+								else showError(`${tip}锛屾彁绀猴細${result.ret}`, this.translateSys('tip'))
+								this.saving = false
+								return false
+							} else {
+								var tip = result.info ? typeof result.info == 'string' ? result.info :
+									result.info.join('\n') : '';
+								tip = tip || result.err_info
+								let time = result.info_time || 0
+								if (time)
+									showError(tip, this.translateSys('tip'))
+								else
+									showInfo(tip)
+								if ([0, 2, 3, 4, -1].includes(result.result_type)) {
+									if (result.result_type == 2) {
+
+									} else if (typeof result.result == 'string') {
+										showInfo(result.result)
+
+									}
+									try {
+										var actionlist = result.action || []
+										for (var j = 0; j < actionlist.length; j++) {
+											var action = actionlist[j];
+											var action_type = action.action_type;
+											var value = action.value;
+
+											if (action_type == "set_query_condition") {
+												$this.wheres = value.condition;
+												$this.orderby = value.order ? value.order : ""
+												$this.pageindex = 1;
+												$this.query_id = "";
+												$this.detail1StyleDefList = [];
+												$this.loadDataGetList();
+											} else if (action_type ==
+												"set_dlg_attr") {
+												$this.setFormValues(action.value)
+											} else if (action_type == "set_subtable_page_content") {
+												if (value.clear_confirm != false && value.clear == true &&
+													$this.detail1StyleDefList.length > 0
+												) { //鍒ゆ柇鏄惁娓呯┖椤电鍐呭,姝e湪鐮佺洏鏄惁鏈夋暟鎹�+													uni.showModal({
+														title: this.translateSys('tip'),
+														content: this.translate(
+															"are_you_sure_clear_data"),
+														cancelText: $this.translateSys('ok'),
+														confirmText: $this.translateSys('cancel'),
+														success: function(res) {
+															if (res.cancel) {
+																$this.detail1StyleDefList = [];
+																$this.viewAceionContent(value);
+															} else if (res.confirm) {
+																$this.detail1StyleDefList = [];
+																$this.viewAceionContent(value);
+															}
+														}
+													});
+												} else {
+													$this.detail1StyleDefList = [];
+													$this.viewAceionContent(value);
+												}
+											}
+										}
+
+									} catch (ex) {
+										let actionList = (result.action || []).map(a => a.action_type).join(
+											';')
+										let tip = typeof ex == 'string' ? ex : ex.message
+										tip = `鎵ц鑴氭湰杩斿洖鐨�{actionList}鏃跺嚭鐜板紓甯革紝璇锋鏌ヨ剼鏈繑鍥炵殑鏁版嵁鏍煎紡鏄惁姝g‘銆�{tip}`
+										showError(tip, this.translateSys('tip'))
+										return
+									}
+								}
+
+							}
+
+
+						}).catch(ex => {
+							// console.log(ex);
+							showError(ex, this.translateSys("error") + "8.1")
+						});
+					}
+				} catch (ex) {
+					showError(ex, this.translateSys('error') + "8.2")
+
+				}
 			},
 
 			//婊氬姩鍒板簳閮ㄥ悗鎳掑姞杞芥暟鎹�@@ -252,13 +421,7 @@
 					}
 				} catch (ex) {
 					// console.log(ex);
-					let tip = typeof ex.errMsg == "string" ? ex.errMsg : ex
-					uni.showModal({
-						title: this.translateSys("error") + "1.1",
-						content: tip,
-						showCancel: false,
-						confirmText: this.translateSys('close')
-					});
+					showError(ex, this.translateSys('error') + "1.1")
 				}
 
 			},
@@ -283,13 +446,7 @@
 					$this.detail1_styledef.SelBut_Checked = false;
 				} catch (ex) {
 					// console.log(ex);
-					let tip = typeof ex.errMsg == "string" ? ex.errMsg : ex
-					uni.showModal({
-						title: this.translateSys("error") + "1.1",
-						content: tip,
-						showCancel: false,
-						confirmText: this.translateSys('close')
-					});
+					showError(ex, this.translateSys('error') + "1.1")
 				}
 
 
@@ -327,12 +484,7 @@
 					}
 				} catch (ex) {
 					// console.log(ex);
-					uni.showModal({
-						title: this.translateSys("error") + "3",
-						content: ex.errMsg,
-						showCancel: false,
-						confirmText: this.translateSys('close')
-					});
+					showError(ex, this.translateSys('error') + "3")
 				}
 			},
 
@@ -434,21 +586,10 @@
 
 					}).catch(ex => {
 						// console.log(ex);
-						uni.showModal({
-							title: this.translateSys("error") + "5.1",
-							content: ex.errMsg,
-							showCancel: false,
-							confirmText: this.translateSys('close')
-						});
+						showError(ex, this.translateSys("error") + "5.1")
 					});
 				} catch (ex) {
-					var tip = typeof ex == "string" ? ex : ex.message;
-					uni.showModal({
-						title: this.translateSys("error") + "5.2",
-						content: tip,
-						showCancel: false,
-						confirmText: this.translateSys('close')
-					});
+					showError(ex, this.translateSys('error') + "5.2")
 				}
 			},
 			//鍒锋柊
@@ -456,10 +597,19 @@
 				this.initial()
 			},
 			//鐐瑰嚮鏄剧ず娴忚瀵硅薄鏄剧ず椤甸潰
-			async onViewPageClick(style) {
+			onViewPageClick(style) {
+				this.handleButtonClick((done) => {
+					this.viewPageClick(style);
+					setTimeout(() => {
+						done(); // 閲嶇疆鐘舵�
+					}, 1000);
+				});
+			},
+			async viewPageClick(style) {
 				if (!this.clickItemEvent.id) {
 					return;
 				}
+				showLoading("loading...")
 				const $this = this
 
 				var obj_attr = this.head_styledef.form.model;
@@ -500,66 +650,40 @@
 					data_json,
 				}).then(result => {
 					// console.log(result);
+					hideLoading()
 					if (result.ret != 0 && result.ret != 1) {
-						var tip = result.err_info ? typeof result
-							.err_info ==
-							'string' ?
-							result
-							.err_info : result.err_info.join(
-								'<br/>') : '';
+						let cls_name = result.event_info?.cls_name
+						let event_name = result.event_info?.event_name
+						tip = result.err_info ? typeof result.err_info == 'string' ? result.err_info : result
+							.err_info
+							.join('\n') : ''
 						if (result.ret == 801) {
 							if (this.param.Only_Script_Error) {
 								let pos = tip.indexOf("锛�);
-								if (pos > -1) tip = tip.substring(
-									pos + 1);
+								if (pos > -1) tip = tip.substring(pos + 1);
 							}
-							uni.showModal({
-								title: this.translateSys(
-									"tip"),
-								content: tip,
-								showCancel: false,
-								confirmText: this
-									.translateSys('close')
-							});
-						} else uni.showModal({
-							title: this.translateSys(
-								"tip"),
-							content: tip + ',' + this
-								.translateSys('tip') +
-								':' +
-								result
-								.ret,
-							showCancel: false,
-							confirmText: this.translateSys(
-								'close')
-						});
-						return false;
+						}
+						if (cls_name && event_name) tip = `鎵ц鈥�{cls_name}鈥濇暟鎹被鐨勨�${event_name}鈥濊剼鏈椂杩斿洖閿欒锛�{tip}`
+						if (result.ret == 801) showInfo(tip)
+						else showError(`${tip}锛屾彁绀猴細${result.ret}`, this.translateSys('tip'))
+						this.saving = false
+						return false
 					} else {
-						var tip = result.info ? typeof result
-							.info == 'string' ? result
-							.info :
-							result.info.join('<br/>') : '';
+						var tip = result.info ? typeof result.info == 'string' ? result.info :
+							result.info.join('\n') : '';
 						tip = tip || result.err_info
-						if (tip) uni.showModal({
-							title: this.translateSys(
-								"tip"),
-							content: tip,
-							showCancel: false,
-							confirmText: this.translateSys(
-								'close')
-						});
+						let time = result.info_time || 0
+						if (time)
+							showError(tip, this.translateSys('tip'))
+						else
+							showInfo(tip)
+
 						if ([0, 2, 3, 4, -1].includes(result.result_type)) {
 							if (result.result_type == 2) {
 
 							} else if (typeof result.result == 'string') {
-								if (result.result) {
-									uni.showModal({
-										title: this.translateSys('tip'),
-										content: result.result,
-										showCancel: false,
-										confirmText: this.translateSys('close')
-									});
-								}
+								showInfo(result.result)
+
 							}
 							try {
 								var actionList = result.action || []
@@ -570,10 +694,9 @@
 										uni.navigateTo({
 											url: `../modal/3202_view?param=${JSON.stringify($this.param)}&titlename=${data.page?.page_name || ""}&dataObj=${JSON.stringify(data)}`,
 											events: {
-												// 涓烘寚瀹氫簨浠舵坊鍔犱竴涓洃鍚櫒锛岃幏鍙栬鎵撳紑椤甸潰浼犻�鍒板綋鍓嶉〉闈㈢殑鏁版嵁
-												ExitViewEvent: function(data) {
-													console.log(data);
-													this.runCustomEvent(data);
+												ExitViewPage: function() {
+
+													$this.loadInitialEvent()
 												}
 											}
 										});
@@ -583,13 +706,7 @@
 								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)
+								showError(tip, this.translateSys('tip'))
 								return
 							}
 						}
@@ -599,14 +716,8 @@
 
 				}).catch(ex => {
 					// console.log(ex);
-					uni.showModal({
-						title: this.translateSys("error") +
-							"8.1",
-						content: ex.errMsg,
-						showCancel: false,
-						confirmText: this.translateSys(
-							'close')
-					});
+					hideLoading()
+					showError(ex, this.translateSys("error") + "8.1")
 				});
 			},
 			onRowBtnClick(btn, index) {
@@ -652,18 +763,14 @@
 					const style = this.detail1StyleDefList[index];
 					this.relatedFunction(btn, style, enviroment);
 				} else {
-					uni.showModal({
-						title: this.translateSys("tip"),
-						content: this.translateSys("unrealized"),
-						showCancel: false,
-						confirmText: this.translateSys('close')
-					});
+					showInfo(this.translateSys("unrealized"))
+
 				}
 			},
 			//鎵ц瑙﹀彂浜嬩欢
 			async triggerEvent(btn, style, enviroment) {
 				const $this = this
-
+				showLoading("loading...")
 				var obj_attr = this.head_styledef.form.model;
 				// console.log(obj_attr);
 				var input_param = Base64.encode(
@@ -701,67 +808,40 @@
 					input_param,
 					data_json,
 				}).then(result => {
+					hideLoading()
 					// console.log(result);
 					if (result.ret != 0 && result.ret != 1) {
-						var tip = result.err_info ? typeof result
-							.err_info ==
-							'string' ?
-							result
-							.err_info : result.err_info.join(
-								'<br/>') : '';
+						let cls_name = result.event_info?.cls_name
+						let event_name = result.event_info?.event_name
+						tip = result.err_info ? typeof result.err_info == 'string' ? result.err_info : result
+							.err_info
+							.join('\n') : ''
 						if (result.ret == 801) {
 							if (this.param.Only_Script_Error) {
 								let pos = tip.indexOf("锛�);
-								if (pos > -1) tip = tip.substring(
-									pos + 1);
+								if (pos > -1) tip = tip.substring(pos + 1);
 							}
-							uni.showModal({
-								title: this.translateSys(
-									"tip"),
-								content: tip,
-								showCancel: false,
-								confirmText: this
-									.translateSys('close')
-							});
-						} else uni.showModal({
-							title: this.translateSys(
-								"tip"),
-							content: tip + ',' + this
-								.translateSys('tip') +
-								':' +
-								result
-								.ret,
-							showCancel: false,
-							confirmText: this.translateSys(
-								'close')
-						});
-						return false;
+						}
+						if (cls_name && event_name) tip = `鎵ц鈥�{cls_name}鈥濇暟鎹被鐨勨�${event_name}鈥濊剼鏈椂杩斿洖閿欒锛�{tip}`
+						if (result.ret == 801) showInfo(tip)
+						else showError(`${tip}锛屾彁绀猴細${result.ret}`, this.translateSys('tip'))
+						this.saving = false
+						return false
 					} else {
-						var tip = result.info ? typeof result
-							.info == 'string' ? result
-							.info :
-							result.info.join('<br/>') : '';
+						var tip = result.info ? typeof result.info == 'string' ? result.info :
+							result.info.join('\n') : '';
 						tip = tip || result.err_info
-						if (tip) uni.showModal({
-							title: this.translateSys(
-								"tip"),
-							content: tip,
-							showCancel: false,
-							confirmText: this.translateSys(
-								'close')
-						});
+						let time = result.info_time || 0
+						if (time)
+							showError(tip, this.translateSys('tip'))
+						else
+							showInfo(tip)
 						if ([0, 2, 3, 4, -1].includes(result.result_type)) {
 							if (result.result_type == 2) {
 
 							} else if (typeof result.result == 'string') {
-								if (result.result) {
-									uni.showModal({
-										title: this.translateSys('tip'),
-										content: result.result,
-										showCancel: false,
-										confirmText: this.translateSys('close')
-									});
-								}
+								showInfo(result.result)
+
 							}
 							try {
 								var actionList = result.action || []
@@ -773,11 +853,16 @@
 											url: `../modal/3202_view?param=${JSON.stringify($this.param)}&titlename=${data.page?.page_name || ""}&dataObj=${JSON.stringify(data)}`,
 											events: {
 												// 涓烘寚瀹氫簨浠舵坊鍔犱竴涓洃鍚櫒锛岃幏鍙栬鎵撳紑椤甸潰浼犻�鍒板綋鍓嶉〉闈㈢殑鏁版嵁
-												ExitViewEvent: function(data) {
-													console.log(data);
-													this.runCustomEvent(data);
+												ExitViewPage: function() {
+
+													$this.loadInitialEvent()
 												}
 											}
+										});
+									} else if (item.action_type == "goback_to_pre_page") {
+										//杩斿洖涓婁竴椤�+										uni.navigateBack({
+											delta: 1, //杩斿洖灞傛暟锛�鍒欎笂涓婇〉
 										});
 									}
 								})
@@ -785,13 +870,7 @@
 								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)
+								showError(tip, this.translateSys('tip'))
 								return
 							}
 						}
@@ -801,14 +880,8 @@
 
 				}).catch(ex => {
 					// console.log(ex);
-					uni.showModal({
-						title: this.translateSys("error") +
-							"8.1",
-						content: ex.errMsg,
-						showCancel: false,
-						confirmText: this.translateSys(
-							'close')
-					});
+					hideLoading()
+					showError(ex, this.translateSys("error") + "8.1")
 				});
 			},
 			async relatedFunction(btn, style, enviroment) {
@@ -821,6 +894,7 @@
 						defCode == "3037" ||
 						defCode == "3200" ||
 						defCode == "3201" ||
+						defCode == "3202" ||
 						defCode == "5600" ||
 						defCode == "5601" ||
 						defCode == "5602"
@@ -847,62 +921,51 @@
 									paramStr);
 							}
 							if (!param) {
-								uni.showModal({
-									title: this.translateSys("tip"),
-									content: this.translate(
-										'tip_no_app_param'),
-									showCancel: false,
-									confirmText: this.translateSys(
-										'close')
-								});
+								showInfo(this.translate("tip_no_app_param"))
+
 								return;
 							}
+							const attrValues = []
 
+							style.form.items.forEach(item => {
+								if (item.name == "Layout") { //鍒ゆ柇鏄惁鏄爡鏍忔牸寮�+									item.setting.colList.forEach(col => {
+										if (col != null) {
+											attrValues.push({
+												attr: col.fieldId,
+												value: col.value || ""
+											})
+										}
+
+									});
+								} else
+									attrValues.push({
+										attr: item.fieldId,
+										value: item.value || ""
+									})
+							});
 							uni.navigateTo({
 								url: '../modal/' + name + '?param=' +
 									param + "&titlename=" +
 									appName +
 									"&type=relatedFunction&paramValue=" +
-									JSON.stringify(style
-										.form),
+									JSON.stringify(attrValues),
 								events: {
-									relatedFunction: function(data) {
-										console.log(data);
-										$this.Refresh();
-									},
+
 								}
 							});
 						} else {
-							uni.showModal({
-								title: this.translateSys("error"),
-								content: this.translate(
-									"function_not_exist"),
-								showCancel: false,
-								confirmText: this.translateSys('close')
-							});
+							showInfo(this.translate("function_not_exist"))
+
 						}
 
 					} else {
-						uni.showModal({
-							title: this.translateSys("error"),
-							content: this.translate("cannot_related_function"),
-							showCancel: false,
-							confirmText: this.translateSys('close')
-						});
+						showInfo(this.translate("cannot_related_function"))
+
 
 					}
 				} catch (ex) {
-					console.log(ex);
-					let exStr = JSON.stringify(ex)
-					if (exStr == "{}")
-						exStr = ex
-					let tip = typeof ex.errMsg == "string" ? ex.errMsg : exStr
-					uni.showModal({
-						title: this.translateSys("error"),
-						content: tip,
-						showCancel: false,
-						confirmText: this.translateSys('close')
-					});
+					showError(ex, this.translateSys('error'))
 					return undefined
 				}
 			},
@@ -980,6 +1043,7 @@
 			async onChange(event) {
 				try {
 					if (event.id) {
+						showLoading("loading...")
 						var obj_attr = this.head_styledef.form.model;
 						console.log(obj_attr);
 						var input_param = Base64.encode(
@@ -1012,66 +1076,41 @@
 						};
 						runCustomEvent(dataInfo).then(result => {
 							console.log(result);
+							hideLoading()
 							if (result.ret != 0 && result.ret != 1) {
-								var tip = result.err_info ? typeof result
-									.err_info ==
-									'string' ?
+								let cls_name = result.event_info?.cls_name
+								let event_name = result.event_info?.event_name
+								tip = result.err_info ? typeof result.err_info == 'string' ? result.err_info :
 									result
-									.err_info : result.err_info.join(
-										'<br/>') : '';
+									.err_info
+									.join('\n') : ''
 								if (result.ret == 801) {
 									if (this.param.Only_Script_Error) {
 										let pos = tip.indexOf("锛�);
-										if (pos > -1) tip = tip.substring(
-											pos + 1);
+										if (pos > -1) tip = tip.substring(pos + 1);
 									}
-									uni.showModal({
-										title: this.translateSys(
-											"tip"),
-										content: tip,
-										showCancel: false,
-										confirmText: this
-											.translateSys('close')
-									});
-								} else uni.showModal({
-									title: this.translateSys(
-										"tip"),
-									content: tip + ',' + this
-										.translateSys('tip') +
-										':' +
-										result
-										.ret,
-									showCancel: false,
-									confirmText: this.translateSys(
-										'close')
-								});
-								return false;
+								}
+								if (cls_name && event_name) tip =
+									`鎵ц鈥�{cls_name}鈥濇暟鎹被鐨勨�${event_name}鈥濊剼鏈椂杩斿洖閿欒锛�{tip}`
+								if (result.ret == 801) showInfo(tip)
+								else showError(`${tip}锛屾彁绀猴細${result.ret}`, this.translateSys('tip'))
+								this.saving = false
+								return false
 							} else {
-								var tip = result.info ? typeof result
-									.info == 'string' ? result
-									.info :
-									result.info.join('<br/>') : '';
+								var tip = result.info ? typeof result.info == 'string' ? result.info :
+									result.info.join('\n') : '';
 								tip = tip || result.err_info
-								if (tip) uni.showModal({
-									title: this.translateSys(
-										"tip"),
-									content: tip,
-									showCancel: false,
-									confirmText: this.translateSys(
-										'close')
-								});
+								let time = result.info_time || 0
+								if (time)
+									showError(tip, this.translateSys('tip'))
+								else
+									showInfo(tip)
 								if ([0, 2, 3, 4, -1].includes(result.result_type)) {
 									if (result.result_type == 2) {
 
 									} else if (typeof result.result == 'string') {
-										if (result.result) {
-											uni.showModal({
-												title: this.translateSys('tip'),
-												content: result.result,
-												showCancel: false,
-												confirmText: this.translateSys('close')
-											});
-										}
+										showInfo(result.result)
+
 									}
 									try {
 										var actionlist = result.action || []
@@ -1079,6 +1118,7 @@
 											var action = actionlist[j];
 											var action_type = action.action_type;
 											var value = action.value;
+
 											if (action_type == "set_query_condition") {
 												$this.wheres = value.condition;
 												$this.orderby = value.order ? value.order : ""
@@ -1086,6 +1126,9 @@
 												$this.query_id = "";
 												$this.detail1StyleDefList = [];
 												$this.loadDataGetList();
+											} else if (action_type ==
+												"set_dlg_attr") {
+												$this.setFormValues(action.value)
 											} else if (action_type == "set_subtable_page_content") {
 												if (value.clear_confirm != false && value.clear == true &&
 													$this.detail1StyleDefList.length > 0
@@ -1118,13 +1161,7 @@
 											';')
 										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)
+										showError(tip, this.translateSys('tip'))
 										return
 									}
 								}
@@ -1134,36 +1171,20 @@
 
 						}).catch(ex => {
 							// console.log(ex);
-							uni.showModal({
-								title: this.translateSys("error") +
-									"8.1",
-								content: ex.errMsg,
-								showCancel: false,
-								confirmText: this.translateSys(
-									'close')
-							});
+							hideLoading()
+							showError(ex, this.translateSys("error") + "8.1")
 						});
 					}
 				} catch (ex) {
-					var tip = typeof ex == "string" ? ex : ex.message;
-					uni.showModal({
-						title: this.translateSys("error") + "8.2",
-						content: this.translate(
-								'execute_after_change_event_failed') + this
-							.translateSys(
-								"comma") +
-							this.translate('reason') + this.translateSys(
-								"colon") + tip,
-						showCancel: false,
-						confirmText: this.translateSys('close')
-					});
+					hideLoading()
+					showError(ex, this.translateSys('error') + "8.2")
 
 				}
 			},
 			setFormValues(attrs) {
 				const head_styledef = this.head_styledef
-				if (JSON.stringify(attrs) == '{}') {
-					return;
+				if (!Array.isArray(attrs)) {
+					return
 				}
 				console.log(attrs)
 				attrs.forEach(async (attr, key) => {
@@ -1336,145 +1357,78 @@
 			async runCustomEvent(dataInfo) {
 				try {
 					var $this = this;
-					runCustomEvent(dataInfo).then(result => {
-						console.log(result);
+					const result = await runCustomEvent(dataInfo)
+					console.log(result);
 
-						if (result.ret != 0 && result.ret != 1) {
-							var tip = result.err_info ? typeof result
-								.err_info ==
-								'string' ?
-								result
-								.err_info : result.err_info.join(
-									'<br/>') : '';
-							if (result.ret == 801) {
-								if (this.param.Only_Script_Error) {
-									let pos = tip.indexOf("锛�);
-									if (pos > -1) tip = tip.substring(
-										pos + 1);
-								}
-								uni.showModal({
-									title: this.translateSys(
-										"tip"),
-									content: tip,
-									showCancel: false,
-									confirmText: this
-										.translateSys('close')
-								});
-							} else uni.showModal({
-								title: this.translateSys(
-									"tip"),
-								content: tip + ',' + this
-									.translateSys('tip') +
-									':' +
-									result.ret,
-								showCancel: false,
-								confirmText: this.translateSys(
-									'close')
-							});
-							return false;
-						} else {
-							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,
-								showCancel: false,
-								confirmText: this.translateSys(
-									'close')
-							});
-							if ([0, 2, 3, 4, -1].includes(result.result_type)) {
-								if (result.result_type == 2) {
+					if (result.ret != 0 && result.ret != 1) {
+						let cls_name = result.event_info?.cls_name
+						let event_name = result.event_info?.event_name
+						tip = result.err_info ? typeof result.err_info == 'string' ? result.err_info :
+							result
+							.err_info
+							.join('\n') : ''
+						if (result.ret == 801) {
+							if (this.param.Only_Script_Error) {
+								let pos = tip.indexOf("锛�);
+								if (pos > -1) tip = tip.substring(pos + 1);
+							}
+						}
+						if (cls_name && event_name) tip =
+							`鎵ц鈥�{cls_name}鈥濇暟鎹被鐨勨�${event_name}鈥濊剼鏈椂杩斿洖閿欒锛�{tip}`
+						if (result.ret == 801) showInfo(tip)
+						else showError(`${tip}锛屾彁绀猴細${result.ret}`, this.translateSys('tip'))
+						this.saving = false
+						return false
+					} else {
+						var tip = result.info ? typeof result.info == 'string' ? result.info :
+							result.info.join('\n') : '';
+						tip = tip || result.err_info
+						let time = result.info_time || 0
+						if (time)
+							showError(tip, this.translateSys('tip'))
+						else
+							showInfo(tip)
+						if ([0, 2, 3, 4, -1].includes(result.result_type)) {
+							if (result.result_type == 2) {
 
-								} 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 ==
-											"goback_to_pre_page") { //杩斿洖涓婁竴椤�-											var value = item.value;
-											uni.navigateBack({
-												delta: 1, //杩斿洖灞傛暟锛�鍒欎笂涓婇〉
-											});
-										} else {
-											uni.showModal({
-												title: this
-													.translateSys(
-														"tip"
-													),
-												content: this
-													.translateSys(
-														"quotation_mark_left"
-													) +
-													item
-													.action_type +
-													this
-													.translateSys(
-														"quotation_mark_right"
-													) +
-													this
-													.translate(
-														"tip_action_unprocessed"
-													),
-												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
-								}
+							} else if (typeof result.result == 'string') {
+								showInfo(result.result)
+
 							}
 
+							var actionList = result.action || []
+							actionList.forEach(item => {
+								if (item.action_type ==
+									"goback_to_pre_page") { //杩斿洖涓婁竴椤�+									var value = item.value;
+									uni.navigateBack({
+										delta: 1, //杩斿洖灞傛暟锛�鍒欎笂涓婇〉
+									});
+								} else {
+									showInfo(this
+										.translateSys(
+											"quotation_mark_left"
+										) +
+										item
+										.action_type +
+										this
+										.translateSys(
+											"quotation_mark_right"
+										) +
+										this
+										.translate(
+											"tip_action_unprocessed"
+										))
+
+								}
+							});
+
 						}
-					}).catch(ex => {
-						// console.log(ex);
-						uni.showModal({
-							title: this.translateSys("error") +
-								"9.1",
-							content: ex.errMsg,
-							showCancel: false,
-							confirmText: this.translateSys(
-								'close')
-						});
-					});
+
+					}
+
 				} catch (ex) {
-					var tip = typeof ex == "string" ? ex : ex.message;
-					uni.showModal({
-						title: this.translateSys("error") + "9.2",
-						content: this.translate('execute_event_failed') +
-							this.translateSys(
-								"comma") +
-							this.translate('reason') + this.translateSys(
-								"colon") + tip,
-						showCancel: false,
-						confirmText: this.translateSys('close')
-					});
+					showError(ex, this.translateSys('error') + "9.2")
 
 				}
 			},
@@ -1807,7 +1761,7 @@
 			// justify-content: right;
 
 			button {
-				 line-height:1.6;
+				line-height: 1.6;
 				// border: none;
 				// margin-right: 10rpx;
 				// text-align: center;

--
Gitblit v1.9.1