From ea9ab51324547ce3264e73931018a3e477c7a7b6 Mon Sep 17 00:00:00 2001
From: shicf <shi_chongfu@163.com>
Date: 星期三, 25 九月 2024 11:24:52 +0800
Subject: [PATCH] 表单获取

---
 src/main/java/com/product/mobile/core/entity/FaceFieldEntity.java          |   62 +++++++++++----
 src/main/java/com/product/mobile/core/service/SysMessageService.java       |    2 
 src/main/java/com/product/mobile/core/service/SystemTableMetaService.java  |    2 
 src/main/java/com/product/mobile/core/service/FaceMobileService.java       |  129 +++++++++++++++++++++++++++++++
 src/main/java/com/product/mobile/core/controller/FaceMobileController.java |   12 ++
 5 files changed, 185 insertions(+), 22 deletions(-)

diff --git a/src/main/java/com/product/mobile/core/controller/FaceMobileController.java b/src/main/java/com/product/mobile/core/controller/FaceMobileController.java
index 749054a..2a4ea8a 100644
--- a/src/main/java/com/product/mobile/core/controller/FaceMobileController.java
+++ b/src/main/java/com/product/mobile/core/controller/FaceMobileController.java
@@ -1,5 +1,6 @@
 package com.product.mobile.core.controller;
 
+import com.product.common.lang.StringUtils;
 import com.product.core.entity.FieldSetEntity;
 import com.product.core.exception.BaseException;
 import com.product.mobile.core.config.MobileCoreCode;
@@ -57,7 +58,16 @@
 		try {
 			//涓嶉獙璇佷紶鍏ョ殑琛ㄥ悕 鍙兘浼氭槸 product_sys_flow_task/product_sys_flow_detail
 			FieldSetEntity fse = BaseUtil.getFieldSetEntity(request);
-			return BaseUtil.success(faceMobileService.getFlowFaceField(fse));
+//			//閫氳繃瀹℃壒浠诲姟鐨剈uid鏉ユ煡琛ㄥ崟淇℃伅
+//			if (StringUtils.isEmpty(fse.getString("table_uuid")) && StringUtils.isEmpty(fse.getString("table_name"))) {
+//				return BaseUtil.success(faceMobileService.getFlowFaceField(fse));
+//			}else {
+//				//閫氳繃涓氬姟琛ㄤ俊鎭煡琛ㄥ崟淇℃伅
+//				return BaseUtil.success(faceMobileService.getFaceFieldByTable(fse));
+//			}
+			
+			return BaseUtil.success(faceMobileService.getFaceConfig(fse));
+			
 		} catch (BaseException e) {
 			e.printStackTrace();
 			return error(e);
diff --git a/src/main/java/com/product/mobile/core/entity/FaceFieldEntity.java b/src/main/java/com/product/mobile/core/entity/FaceFieldEntity.java
index 840e556..04c68bf 100644
--- a/src/main/java/com/product/mobile/core/entity/FaceFieldEntity.java
+++ b/src/main/java/com/product/mobile/core/entity/FaceFieldEntity.java
@@ -1,7 +1,6 @@
 package com.product.mobile.core.entity;
 
 import java.util.List;
-import java.util.Map;
 
 /**
  * @Author cheng
@@ -9,8 +8,10 @@
  * @Desc
  */
 public class FaceFieldEntity {
+	
+	private String table;
 
-	private String fieldName;
+	private String field;
 
 	/**
 	 * 鏄惁蹇呭~
@@ -19,12 +20,12 @@
 	/**
 	 * 鏄剧ず鍚嶇О
 	 */
-	private String label;
+	private String name;
 
 	/**
 	 * 鍙傜収鍚嶇О
 	 */
-	private String advanceName;
+	private String prompt;
 
 	/**
 	 * 缁勪欢绫诲瀷
@@ -86,13 +87,35 @@
 
 	private List<FaceFieldEntity> subField;
 
+	private String type;
+	
+	private String length;
 
-	public String getFieldName() {
-		return fieldName;
+	public String getType() {
+		return type;
+	}
+	
+
+	public String getLength() {
+		return length;
 	}
 
-	public void setFieldName(String fieldName) {
-		this.fieldName = fieldName;
+
+	public void setLength(String length) {
+		this.length = length;
+	}
+
+
+	public void setType(String fieldType) {
+		this.type = fieldType;
+	}
+
+	public String getField() {
+		return field;
+	}
+
+	public void setField(String fieldName) {
+		this.field = fieldName;
 	}
 
 	public String getRequired() {
@@ -103,20 +126,20 @@
 		this.required = required;
 	}
 
-	public String getLabel() {
-		return label;
+	public String getName() {
+		return name;
 	}
 
-	public void setLabel(String label) {
-		this.label = label;
+	public void setName(String label) {
+		this.name = label;
 	}
 
-	public String getAdvanceName() {
-		return advanceName;
+	public String getPrompt() {
+		return prompt;
 	}
 
-	public void setAdvanceName(String advanceName) {
-		this.advanceName = advanceName;
+	public void setPrompt(String advanceName) {
+		this.prompt = advanceName;
 	}
 
 	public String getComponentType() {
@@ -230,4 +253,11 @@
 	public void setSubField(List<FaceFieldEntity> subField) {
 		this.subField = subField;
 	}
+		public String getTable() {
+		return table;
+	}
+
+	public void setTable(String tableUuid) {
+		this.table = tableUuid;
+	}
 }
diff --git a/src/main/java/com/product/mobile/core/service/FaceMobileService.java b/src/main/java/com/product/mobile/core/service/FaceMobileService.java
index d87f095..e35c3a7 100644
--- a/src/main/java/com/product/mobile/core/service/FaceMobileService.java
+++ b/src/main/java/com/product/mobile/core/service/FaceMobileService.java
@@ -34,7 +34,129 @@
 
 	@Resource
 	FlowDetailService flowDetailService;
-
+	
+	///鑾峰彇琛ㄥ崟鎬诲叆鍙�
+	/**
+	 * 
+	 * @param fse浼犲叆琛ㄥ悕锛屾垨 琛║UID
+	 * @return
+	 */
+	public List<FaceFieldEntity> getFaceConfig(FieldSetEntity fse) {
+	
+		String tableUuid=fse.getString("table_uuid");
+		if (tableUuid==null && StringUtils.isNotEmpty(fse.getString("uuid"))
+				&& StringUtils.isEmpty(fse.getString("table_name"))) {
+			//閫氳繃涓氬姟琛ㄤ俊鎭煡琛ㄥ崟淇℃伅
+			FieldSetEntity detailFse = getBaseDao().getFieldSetEntity(CmnConst.TABLE_FLOW_DETAIL, fse.getString(CmnConst.FIELD_UUID), false);
+			if(detailFse!=null) {
+				//鑾峰彇琛ㄥ悕
+				fse.setValue("table_name", detailFse.getString("table_name"));
+			}
+			
+		}
+		//閫氳繃瀹℃壒浠诲姟鐨剈uid鏉ユ煡琛ㄥ崟淇℃伅
+		if (tableUuid==null && StringUtils.isNotEmpty(fse.getString("table_name"))) {
+			FieldSetEntity tableInfo = BaseUtil.getSingleInfoByCache("鎵�鏈夎〃淇℃伅", new String[]{fse.getString("table_name")});
+			if (!FieldSetEntity.isEmpty(tableInfo)) {
+				tableUuid = tableInfo.getString("uuid");
+				fse.setValue("table_uuid", tableUuid);
+			}
+		}
+		
+		if(tableUuid!=null) {
+			
+			FieldSetEntity tableInfo = BaseUtil.getSingleInfoByCache("鎵�鏈夎〃淇℃伅(uuid)", new String[]{tableUuid});
+			if (!FieldSetEntity.isEmpty(tableInfo)) {
+				//鑾峰彇琛ㄥ悕
+				fse.setValue("table_name", tableInfo.getString("table_name"));
+			}
+		}
+		
+		List<FaceFieldEntity> ls=getFaceFieldByTable(fse);
+		
+		addproperty(tableUuid,fse.getString("table_name"),ls);
+		//鎵�鏈夎〃鍗晆uid鑷姩娣诲姞锛屽苟涓篽idden
+		return ls;
+		
+	}
+	//閫掑綊鎶婁富琛ㄥ拰瀛愯〃鐨勫瓧娈靛睘鎬ф坊鍔犺繘鍘伙紝濡傛灉娌℃湁閰嶈〃鍗曪紝鍒欏彇琛ㄦ暟鎹粨鏋勮繘琛屽睍绀�
+	/**
+	 * 
+	 * @param ls鏌ュ嚭鏉ョ殑琛ㄥ崟淇℃伅
+	 * @param tables 璁板綍鐨勬墍鏈夎〃锛屽搴旂殑琛ㄥ崟淇℃伅
+	 */
+	private void  addproperty(String table_uuid,String table_name,List<FaceFieldEntity> ls) {
+		if(ls==null) {
+			ls=new ArrayList<FaceFieldEntity>();
+		}
+		if(ls.size()>0) {
+			for(int i=0;i<ls.size();i++) {
+				String subTableName=ls.get(i).getSubTableName();///鍙兘鏄瓙琛�
+				if(StringUtils.isEmpty(subTableName)) {///涓昏〃瀛楁
+					DataTableEntity dt = DataPoolCacheImpl.getInstance().getCacheData("琛ㄥ瓧娈典俊鎭�"
+							,new String[] {table_uuid,ls.get(i).getField()});
+					
+					if(!DataTableEntity.isEmpty(dt)) {
+//						if(StringUtils.isEmpty(ls.get(i).getType())) {
+//							ls.get(i).setType(dt.getFieldSetEntity(0).getString("field_type"));
+//						}
+						if(StringUtils.isEmpty(ls.get(i).getPrompt()) && 
+								!StringUtils.isEmpty(dt.getFieldSetEntity(0).getString("field_reference"))) {
+							ls.get(i).setPrompt(dt.getFieldSetEntity(0).getString("field_reference"));
+						}
+						if(StringUtils.isEmpty(ls.get(i).getRequired()) && 
+								!StringUtils.isEmpty(dt.getFieldSetEntity(0).getString("is_required"))) {
+							ls.get(i).setRequired(dt.getFieldSetEntity(0).getString("is_required"));
+						}
+						if(StringUtils.isEmpty(ls.get(i).getName()) && 
+								!StringUtils.isEmpty(dt.getFieldSetEntity(0).getString("field_show_name"))) {
+							ls.get(i).setName(dt.getFieldSetEntity(0).getString("field_show_name"));
+						}
+					}
+					ls.get(i).setTable(table_name);
+				}else {
+					//============鎶婂瓙琛ㄥ瓧娈典篃澶勭悊涓�涓�
+					//瀛愯〃
+					FieldSetEntity tableInfo = BaseUtil.getSingleInfoByCache("鎵�鏈夎〃淇℃伅", new String[]{subTableName});
+					if (!FieldSetEntity.isEmpty(tableInfo)) {
+						addproperty(tableInfo.getString("uuid"),tableInfo.getString("table_name"),ls.get(i).getSubField());
+					}
+				}
+				
+			}
+			DataTableEntity dt = DataPoolCacheImpl.getInstance().getCacheData("琛ㄥ瓧娈典俊鎭�",new String[] {table_uuid,"uuid"});
+			if(!DataTableEntity.isEmpty(dt)) {
+				FaceFieldEntity uuid=new FaceFieldEntity();
+				uuid.setField("uuid");
+				uuid.setType("String");
+				uuid.setTable(table_name);
+				uuid.setDisabled("0");
+				ls.add(uuid);
+			}
+			
+		}else {///浠ヨ〃鍗曡璁′负鍑嗭紝濡傛灉娌℃湁閰嶇疆琛ㄥ崟锛屽垯浠ユ暟鎹〃涓哄噯锛屽叏閮ㄤ繚鐣�
+			DataTableEntity dte = DataPoolCacheImpl.getInstance().getCacheData("鎵�鏈夊瓧娈典俊鎭苟鎸夎〃鍒嗙粍",new String[] {table_uuid});
+			for(int j=0;j<dte.getRows();j++) {
+				FaceFieldEntity uuid=new FaceFieldEntity();
+				FieldSetEntity f=dte.getFieldSetEntity(j);
+				if("pk".equals(f.getString("field_type")) 
+						||"updated_by".equals(f.getString("field_name"))
+						||"uuid".equals(f.getString("field_name"))
+						||"updated_utc_datetime".equals(f.getString("field_name"))) {
+					continue;
+				}
+				uuid.setPrompt(f.getString("field_reference"));
+				uuid.setName(f.getString("field_show_name"));
+				uuid.setField(f.getString("field_name"));
+				uuid.setType(f.getString("field_type"));
+				uuid.setTable(table_name);
+				ls.add(uuid);
+			}
+		}
+	}
+	
+	
+	
 	public List<FaceFieldEntity> getFaceFieldByTable(FieldSetEntity fse) {
 		String tableUuid = fse.getString("table_uuid");
 		String tableName = fse.getString("table_name");
@@ -48,6 +170,7 @@
 			throw new BaseException(MobileCoreCode.SYSTEM_FORM_COUNT);
 		}
 		FieldSetEntity faceFse = getBaseDao().getFieldSetByFilter("product_sys_face", "table_uuid=?", new Object[]{tableUuid}, true);
+		faceFse.setTableName(tableName);
 		return getFaceField(faceFse);
 	}
 
@@ -244,7 +367,7 @@
 				}
 				if ("__vModel__".equals(setEntity.getString("property_name"))) {
 					result.add(faceFieldEntity);
-					propertyName = "fieldName";
+					propertyName = "field";
 				} else if ("defaultNow".equals(propertyName)) {
 					propertyName = "defaultValue";
 				} else if ("__config__".equals(propertyName)) {
@@ -266,7 +389,7 @@
 
 				}
 			}
-			if (StringUtils.isEmpty(faceFieldEntity.getFieldName())) {
+			if (StringUtils.isEmpty(faceFieldEntity.getField())) {
 				return;
 			}
 			if (parentGroup == other) {
diff --git a/src/main/java/com/product/mobile/core/service/SysMessageService.java b/src/main/java/com/product/mobile/core/service/SysMessageService.java
index 447cc98..48cc1eb 100644
--- a/src/main/java/com/product/mobile/core/service/SysMessageService.java
+++ b/src/main/java/com/product/mobile/core/service/SysMessageService.java
@@ -82,7 +82,7 @@
     		ps.add(type);
     	}
         StringBuilder sql = new StringBuilder();
-        sql.append("\nselect  SUBSTRING(message_type,1,1)  message_type, count(*) num from product_db_lift.product_sys_message m inner join product_db_lift.product_sys_message_user u on u.message_uuid=m.uuid  \r\n"
+        sql.append("\nselect  SUBSTRING(message_type,1,1)  message_type, count(*) num from product_sys_message m inner join product_sys_message_user u on u.message_uuid=m.uuid  \r\n"
         		+ "and u.user_id=? and u.read_type=?").append(f).append(" group by  SUBSTRING(message_type,1,1)  ");
         DataTableEntity dte = baseDao.listTable(sql.toString(),ps.toArray(),Integer.MAX_VALUE, 1);
         return dte;
diff --git a/src/main/java/com/product/mobile/core/service/SystemTableMetaService.java b/src/main/java/com/product/mobile/core/service/SystemTableMetaService.java
index b006ad9..064a472 100644
--- a/src/main/java/com/product/mobile/core/service/SystemTableMetaService.java
+++ b/src/main/java/com/product/mobile/core/service/SystemTableMetaService.java
@@ -36,7 +36,7 @@
    
     	Map<Object,Object> vs=fse.getValues();
 		StringBuilder b=new StringBuilder();
-		b.append("select t.table_name,f.field_name,f.field_length,f.field_show_name,f.field_type,f.field_reference,f.is_more_value,f.is_required from product_sys_datamodel_field f left join product_sys_datamodel_table t on f.table_uuid=t.uuid");
+		b.append("select t.table_name,f.field_name,f.field_length,f.field_show_name,f.field_type,f.field_reference,f.is_required from product_sys_datamodel_field f left join product_sys_datamodel_table t on f.table_uuid=t.uuid");
 		List<Object> ps=new ArrayList<>();
     	if(vs!=null && vs.size()>0) {
     		b.append(" where ");

--
Gitblit v1.9.2