1577 lines
79 KiB
C#
1577 lines
79 KiB
C#
using APT.BaseData.Domain.ApiModel;
|
||
using APT.BaseData.Domain.Entities;
|
||
using APT.BaseData.Domain.Enums;
|
||
using APT.BaseData.Domain.IServices;
|
||
using APT.Infrastructure.Core;
|
||
using APT.BaseData.Domain.IServices.EX;
|
||
using APT.Utility;
|
||
using System;
|
||
using System.Collections.Generic;
|
||
using System.ComponentModel;
|
||
using System.Linq;
|
||
using System.Linq.Expressions;
|
||
using System.Reflection;
|
||
using APT.Infrastructure.Api;
|
||
using APT.Infrastructure.Core.Refctor;
|
||
|
||
namespace APT.BaseData.Services.Services.EX
|
||
{
|
||
public class EntityOperateService : CommonService, IEntityOperateService
|
||
{
|
||
public EntityOperateService(IRepository repository)
|
||
: base(repository)
|
||
{
|
||
|
||
}
|
||
|
||
/// <summary>
|
||
/// 获取实体字段信息
|
||
/// </summary>
|
||
/// <param name="entityName"></param>
|
||
/// <param name="isOnlyBaseType">仅获取基础类型</param>
|
||
/// <returns></returns>
|
||
public List<EntityFieldModel> GetEntityFields(string entityName, bool isOnlyBaseType)
|
||
{
|
||
if (string.IsNullOrEmpty(entityName)) return null;
|
||
var type = DataHelper.GetTypeByEntityName(entityName);
|
||
if (type == null)
|
||
return null;
|
||
|
||
List<EntityFieldModel> result = new List<EntityFieldModel>();
|
||
foreach (var property in type.GetProperties())
|
||
{
|
||
string fullTypeName = property.PropertyType.FullName;
|
||
if (fullTypeName.IndexOf("List", StringComparison.OrdinalIgnoreCase) >= 0) continue;
|
||
if (isOnlyBaseType && property.PropertyType.IsClass) continue;
|
||
|
||
EntityFieldModel entityField = new EntityFieldModel();
|
||
string propertyTypeName = property.PropertyType.Name;
|
||
if (string.Compare(propertyTypeName, "GUID", true) == 0 || fullTypeName.IndexOf("Guid", StringComparison.OrdinalIgnoreCase) > -1)
|
||
entityField.TypeName = "Guid";
|
||
else if (string.Compare(propertyTypeName, "DateTime", true) == 0 || fullTypeName.IndexOf("DateTime", StringComparison.OrdinalIgnoreCase) > -1)
|
||
entityField.TypeName = "DateTime";
|
||
else if (string.Compare(propertyTypeName, "bool", true) == 0 || string.Compare(propertyTypeName, "boolean", true) == 0 || fullTypeName.IndexOf("bool", StringComparison.OrdinalIgnoreCase) > -1)
|
||
entityField.TypeName = "bool";
|
||
else if (string.Compare(propertyTypeName, "int", true) == 0 || fullTypeName.IndexOf("int", StringComparison.OrdinalIgnoreCase) > -1)
|
||
entityField.TypeName = "int";
|
||
else if (string.Compare(propertyTypeName, "decimal", true) == 0 || fullTypeName.IndexOf("decimal", StringComparison.OrdinalIgnoreCase) > -1)
|
||
entityField.TypeName = "decimal";
|
||
else if (string.Compare(propertyTypeName, "string", true) == 0 || fullTypeName.IndexOf("string", StringComparison.OrdinalIgnoreCase) > -1)
|
||
entityField.TypeName = "string";
|
||
else
|
||
entityField.TypeName = propertyTypeName;
|
||
|
||
entityField.FieldName = property.Name;
|
||
|
||
EnumNameAttribute enumNameAttr = null;
|
||
object[] attrs = property.GetCustomAttributes(typeof(EnumNameAttribute), true);
|
||
if (attrs.Length == 1)
|
||
enumNameAttr = (EnumNameAttribute)attrs[0];
|
||
|
||
if (enumNameAttr != null)
|
||
entityField.EnumName = enumNameAttr.EnumName;
|
||
|
||
DescriptionAttribute descriptAttr = null;
|
||
object[] descAttrs = property.GetCustomAttributes(typeof(DescriptionAttribute), true);
|
||
if (descAttrs.Length == 1)
|
||
descriptAttr = (DescriptionAttribute)descAttrs[0];
|
||
|
||
if (descriptAttr != null)
|
||
entityField.Label = descriptAttr.Description;
|
||
|
||
if (string.IsNullOrEmpty(entityField.Label))
|
||
entityField.Label = entityField.FieldName;
|
||
result.Add(entityField);
|
||
}
|
||
return result;
|
||
}
|
||
|
||
|
||
/// <summary>
|
||
/// 根据表名获取实体查询字段信息
|
||
/// </summary>
|
||
/// <param name="tableName">表名</param>
|
||
/// <param name="fieldNamePrefix">字段前缀</param>
|
||
/// <param name="lablePrefix">显示名称前缀</param>
|
||
/// <param name="expandFields">展开字段列表</param>
|
||
/// <returns></returns>
|
||
public List<EntityFieldByQueryFieldModel> GetEntityFieldsByTableName(string tableName, string fieldNamePrefix, string lablePrefix, List<string> expandFields)
|
||
{
|
||
Dictionary<string, byte> existFields = new Dictionary<string, byte>();
|
||
return this.DoGetQueryFieldsByTableName(tableName, fieldNamePrefix, lablePrefix, existFields, expandFields);
|
||
}
|
||
|
||
/// <summary>
|
||
/// 根据查询表ID获取实体查询字段信息
|
||
/// </summary>
|
||
/// <param name="formId">查询表单ID</param>
|
||
/// <param name="code">查询字段CODE</param>
|
||
/// <param name="fieldNamePrefix">字段前缀</param>
|
||
/// <param name="lablePrefix">显示名称前缀</param>
|
||
/// <param name="expandFields">展开字段列表</param>
|
||
/// <returns></returns>
|
||
public List<EntityFieldByQueryFieldModel> GetEntityFieldsByQueryFormId(Guid formId, string code, string fieldNamePrefix, string lablePrefix, List<string> expandFields, BaseFilter filter)
|
||
{
|
||
T_PF_FORM form = this.GetEntityByRedis<T_PF_FORM>(formId, filter.GetOrgId());
|
||
if (form == null)
|
||
throw new Exception("无效表单");
|
||
List<EntityFieldByQueryFieldModel> result = new List<EntityFieldByQueryFieldModel>();
|
||
Dictionary<string, byte> existFields = new Dictionary<string, byte>();
|
||
string tableName = form.TABLE_NAME;
|
||
filter.Sort = "NUM";
|
||
//Expression<Func<T_PF_FORM_QUERY, bool>> queryExpression = t => t.PAGE_FORM_ID == form.ID;
|
||
var formQuerys = this.GetEntitiesByRedis<T_PF_FORM_QUERY>(i => i.ORG_ID == filter.GetOrgId(), new BaseFilter(filter.GetOrgId()), form.ID.ToString());
|
||
var formQuery = formQuerys.FirstOrDefault();
|
||
if (formQuery != null)
|
||
{
|
||
if (!string.IsNullOrEmpty(formQuery.TABLE_NAME))
|
||
tableName = formQuery.TABLE_NAME;
|
||
var querys = this.GetEntitiesByRedis<T_PF_QUERY>(i => i.ORG_ID == filter.GetOrgId(), new BaseFilter(filter.GetOrgId()), formQuery.ID.ToString());
|
||
if (!string.IsNullOrEmpty(code))
|
||
querys = querys.Where(i => i.CODE == code).ToList();
|
||
|
||
if (querys != null && querys.Any())
|
||
{
|
||
querys.ForEach(t =>
|
||
{
|
||
if (existFields.ContainsKey(t.QUERY_NAME)) return;
|
||
EntityFieldByQueryFieldModel field = new EntityFieldByQueryFieldModel();
|
||
field.DataType = t.DATA_TYPE;
|
||
field.FieldName = t.QUERY_NAME;
|
||
field.Label = t.LABEL;
|
||
field.ShowLabel = t.LABEL;
|
||
field.EnumName = t.ENUM_NAME;
|
||
field.OpDefault = t.OP_DEFAULT;
|
||
field.Num = t.NUM;
|
||
field.IsSysField = true;
|
||
field.IsCustom = t.IS_CUSTOM;
|
||
field.IsSysParam = t.IS_SYS_PARAM == null ? false : t.IS_SYS_PARAM.Value;
|
||
field.CaseType = t.CASE.Value;
|
||
field.IsRequire = t.IS_REQUIRE ?? false;
|
||
existFields.Add(t.QUERY_NAME, 0);
|
||
result.Add(field);
|
||
});
|
||
}
|
||
}
|
||
var temps = this.DoGetQueryFieldsByTableName(tableName, fieldNamePrefix, lablePrefix, existFields, expandFields);
|
||
if (temps != null && temps.Any())
|
||
result.AddRange(temps);
|
||
return result;
|
||
}
|
||
|
||
|
||
/// <summary>
|
||
/// 根据表名实际获取查询字段
|
||
/// </summary>
|
||
/// <param name="tableName"></param>
|
||
/// <param name="fieldNamePrefix"></param>
|
||
/// <param name="lablePrefix"></param>
|
||
/// <param name="existFields"></param>
|
||
/// <param name="expandFields"></param>
|
||
/// <param name="entityOperateService"></param>
|
||
/// <returns></returns>
|
||
private List<EntityFieldByQueryFieldModel> DoGetQueryFieldsByTableName(string tableName, string fieldNamePrefix, string lablePrefix,
|
||
Dictionary<string, byte> existFields, List<string> expandFields)
|
||
{
|
||
if (string.IsNullOrEmpty(tableName))
|
||
return null;
|
||
List<EntityFieldByQueryFieldModel> result = new List<EntityFieldByQueryFieldModel>();
|
||
var tmpFields = this.GetEntityFields(tableName, false);
|
||
if (tmpFields != null && tmpFields.Any())
|
||
{
|
||
int i = 1;
|
||
tmpFields.ForEach(t =>
|
||
{
|
||
if (string.Compare(t.FieldName, "FLOW_STATUS", true) == 0
|
||
|| string.Compare(t.FieldName, "FLOW_SEND_STATUS", true) == 0
|
||
|| string.Compare(t.FieldName, "IS_DELETED", true) == 0
|
||
|| string.Compare(t.FieldName, "TEXT", true) == 0
|
||
|| string.Compare(t.FieldName, "IS_LEAF", true) == 0
|
||
|| string.Compare(t.FieldName, "SysParams", true) == 0
|
||
|| string.Compare(t.FieldName, "FLOW_ID", true) == 0)
|
||
return;
|
||
if (string.Compare(t.TypeName, "GUID", true) == 0)
|
||
return;
|
||
string fieldName = (!string.IsNullOrEmpty(fieldNamePrefix) ? (fieldNamePrefix + ".") : string.Empty) + t.FieldName;
|
||
if (existFields.ContainsKey(fieldName)) return;
|
||
existFields.Add(fieldName, 0);
|
||
int dataType = 100;
|
||
if (string.Compare(t.TypeName, "DateTime", true) == 0)
|
||
dataType = (int)PFDataTypeEnum.日期区间;
|
||
else if (string.Compare(t.TypeName, "bool", true) == 0)
|
||
dataType = (int)PFDataTypeEnum.布尔;
|
||
else if (string.Compare(t.TypeName, "int", true) == 0)
|
||
{
|
||
if (string.IsNullOrEmpty(t.EnumName))
|
||
dataType = (int)PFDataTypeEnum.数值;
|
||
else
|
||
dataType = (int)PFDataTypeEnum.下拉多选;
|
||
}
|
||
else if (string.Compare(t.TypeName, "decimal", true) == 0)
|
||
dataType = (int)PFDataTypeEnum.数值;
|
||
else if (string.Compare(t.TypeName, "string", true) == 0)
|
||
dataType = (int)PFDataTypeEnum.字符;
|
||
|
||
EntityFieldByQueryFieldModel field = new EntityFieldByQueryFieldModel();
|
||
field.FieldName = fieldName;
|
||
field.Label = t.Label;
|
||
field.ShowLabel = !string.IsNullOrEmpty(lablePrefix) && dataType != 100 ? lablePrefix + t.Label : t.Label;
|
||
field.EnumName = t.EnumName;
|
||
field.IsLeaf = dataType != 100;
|
||
if (dataType == (int)PFDataTypeEnum.字符)
|
||
field.OpDefault = "9";
|
||
else if (dataType != 0)
|
||
field.OpDefault = "1";
|
||
field.DataType = dataType;
|
||
field.TypeName = t.TypeName;
|
||
field.Num = i;
|
||
if (fieldName.EndsWith("CODE", StringComparison.OrdinalIgnoreCase))
|
||
field.CaseType = (int)FMCaseProcEnum.转大写;
|
||
if (!field.IsLeaf && expandFields != null && expandFields.Any())
|
||
{
|
||
if (expandFields.Any(t1 => string.Compare(t1, field.FieldName, true) == 0))
|
||
{
|
||
var children = DoGetQueryFieldsByTableName(t.TypeName, field.FieldName, field.Label, existFields, expandFields);
|
||
if (children != null && children.Any())
|
||
field.Children = children;
|
||
}
|
||
}
|
||
result.Add(field);
|
||
i++;
|
||
});
|
||
}
|
||
return result;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 根据表名初始化表单配置
|
||
/// </summary>
|
||
/// <param name="orgId"></param>
|
||
/// <param name="tableName"></param>
|
||
/// <param name="userId"></param>
|
||
/// <param name="configType"></param>
|
||
public void InitFormConfigByName(Guid orgId, string tableName,
|
||
Guid? userId, PFInitFormConfigTypeEnum configType,
|
||
Guid? menuParentId, string menuName, string menuIcon, bool isAddSend = false)
|
||
{
|
||
var formService = APT.Infrastructure.Api.ServiceLocator.Instance.GetService<IPFFormService>();
|
||
|
||
tableName = string.IsNullOrEmpty(tableName) ? tableName : tableName.Trim();
|
||
if (string.IsNullOrEmpty(tableName)) return;
|
||
var newName = tableName.ToLower();
|
||
var newNameAry = newName.Split(new char[] { '_' });
|
||
string moduleName = string.Empty;
|
||
if (newNameAry.Any() && newNameAry.Length >= 2)
|
||
moduleName = newNameAry[1].ToUpper();
|
||
var tableType = DataHelper.GetTypeByEntityName(tableName);
|
||
if (string.IsNullOrEmpty(moduleName) || tableType == null) throw new Exception("无效表名");
|
||
|
||
FormConfigDbModel dbModel = new FormConfigDbModel();
|
||
var moduleType = formService.GetModelTypeByName(tableName);
|
||
var intModelType = (int)moduleType;
|
||
int codeIndex = 0;
|
||
T_PF_FORM editForm = null;
|
||
T_PF_FORM tableForm = null;
|
||
T_PF_FORM treeForm = null;
|
||
|
||
//获取当前模块最大表单编号
|
||
var lastForm = this.GetEntity<T_PF_FORM>(t => t.PLATFORM_TYPE == (int)PFPlatTypeEnum.后台 && t.CODE.StartsWith(moduleName) && !t.CODE.Contains("_"), new BaseFilter(orgId)
|
||
{
|
||
Sort = "CODE",
|
||
Order = DbOrder.DESC
|
||
});
|
||
if (lastForm != null)
|
||
{
|
||
var index = lastForm.CODE.IndexOf(moduleName);
|
||
if (index == -1) throw new Exception("数据异常");
|
||
codeIndex = LibUtils.ToInt(lastForm.CODE.Substring(index + moduleName.Length));
|
||
}
|
||
var typeDescriptionAttr = GetAttributeByType<DescriptionAttribute>(tableType);
|
||
|
||
//如果表是MesTreeEntityBase的派生类,则按照树页面生成,否则按列表页,编辑页生成
|
||
if (configType == PFInitFormConfigTypeEnum.默认 && tableType.IsSubclassOf(typeof(MesTreeEntityBase)) ||
|
||
configType == PFInitFormConfigTypeEnum.树页面)
|
||
{
|
||
//treeForm = this.GetEntity<T_PF_FORM>(t => t.PLATFORM_TYPE == (int)PFPlatTypeEnum.后台 &&
|
||
// t.FORM_TYPE == (int)PFFormTypeEnum.树形编辑页 && t.TABLE_NAME == tableName, new BaseFilter(orgId));
|
||
if (treeForm == null)
|
||
{
|
||
codeIndex++;
|
||
treeForm = new T_PF_FORM();
|
||
treeForm.ORG_ID = orgId;
|
||
treeForm.CODE = moduleName + codeIndex.PadLeft(3, '0');
|
||
treeForm.PLATFORM_TYPE = (int)PFPlatTypeEnum.后台;
|
||
treeForm.FORM_TYPE = (int)PFFormTypeEnum.树形编辑页;
|
||
treeForm.MODULE_TYPE = (int)moduleType;
|
||
treeForm.TABLE_NAME = tableName;
|
||
dbModel.AddForms.Add(treeForm);
|
||
}
|
||
else
|
||
{
|
||
if (treeForm == null) return;
|
||
if (!dbModel.UpdateForms.Any(t => t.ID == treeForm.ID)) dbModel.UpdateForms.Add(treeForm);
|
||
}
|
||
var typeClassTreeAttr = this.GetAttributeByType<FormClassTreeAttribute>(tableType);
|
||
if (typeClassTreeAttr != null && !string.IsNullOrEmpty(typeClassTreeAttr.DisplayName))
|
||
treeForm.NAME = typeClassTreeAttr.DisplayName;
|
||
else if (typeDescriptionAttr != null)
|
||
treeForm.NAME = typeDescriptionAttr.Description;
|
||
else
|
||
treeForm.NAME = tableName;
|
||
|
||
DoInitFormConfigByName(tableType, treeForm, null, treeForm,
|
||
null, null, null, 0, string.Empty, string.Empty, dbModel);
|
||
|
||
}
|
||
else
|
||
{
|
||
if (configType == PFInitFormConfigTypeEnum.默认 ||
|
||
configType == PFInitFormConfigTypeEnum.列表_编辑页 ||
|
||
configType == PFInitFormConfigTypeEnum.仅列表页)
|
||
{
|
||
//列表表单
|
||
//tableForm = this.GetEntity<T_PF_FORM>(t => t.PLATFORM_TYPE == (int)PFPlatTypeEnum.后台 &&
|
||
// t.FORM_TYPE == (int)PFFormTypeEnum.列表表单 && t.TABLE_NAME == tableName, new BaseFilter(orgId));
|
||
if (tableForm == null)
|
||
{
|
||
codeIndex++;
|
||
tableForm = new T_PF_FORM();
|
||
tableForm.ORG_ID = orgId;
|
||
tableForm.CODE = moduleName + codeIndex.PadLeft(3, '0');
|
||
tableForm.PLATFORM_TYPE = (int)PFPlatTypeEnum.后台;
|
||
tableForm.FORM_TYPE = (int)PFFormTypeEnum.列表表单;
|
||
tableForm.MODULE_TYPE = (int)moduleType;
|
||
tableForm.TABLE_NAME = tableName;
|
||
dbModel.AddForms.Add(tableForm);
|
||
}
|
||
else
|
||
{
|
||
if (tableForm != null && !dbModel.UpdateForms.Any(t => t.ID == tableForm.ID)) dbModel.UpdateForms.Add(tableForm);
|
||
}
|
||
var typeClassTableAttr = this.GetAttributeByType<FormClassTableAttribute>(tableType);
|
||
if (typeClassTableAttr != null && !string.IsNullOrEmpty(typeClassTableAttr.DisplayName))
|
||
tableForm.NAME = typeClassTableAttr.DisplayName;
|
||
else if (typeDescriptionAttr != null)
|
||
tableForm.NAME = typeDescriptionAttr.Description + "列表";
|
||
else
|
||
tableForm.NAME = tableName + "列表";
|
||
}
|
||
if (configType == PFInitFormConfigTypeEnum.默认 ||
|
||
configType == PFInitFormConfigTypeEnum.列表_编辑页 ||
|
||
configType == PFInitFormConfigTypeEnum.仅编辑页)
|
||
{
|
||
//编辑表单
|
||
//editForm = this.GetEntity<T_PF_FORM>(t => t.PLATFORM_TYPE == (int)PFPlatTypeEnum.后台 &&
|
||
// t.FORM_TYPE == (int)PFFormTypeEnum.编辑表单 && t.TABLE_NAME == tableName, new BaseFilter(orgId));
|
||
if (editForm == null)
|
||
{
|
||
codeIndex++;
|
||
editForm = new T_PF_FORM();
|
||
editForm.ORG_ID = orgId;
|
||
editForm.CODE = moduleName + codeIndex.PadLeft(3, '0');
|
||
editForm.PLATFORM_TYPE = (int)PFPlatTypeEnum.后台;
|
||
editForm.FORM_TYPE = (int)PFFormTypeEnum.编辑表单;
|
||
editForm.MODULE_TYPE = (int)moduleType;
|
||
editForm.TABLE_NAME = tableName;
|
||
if (isAddSend)
|
||
{
|
||
editForm.JS_FILES = editForm.CODE + ".js";
|
||
}
|
||
dbModel.AddForms.Add(editForm);
|
||
}
|
||
else
|
||
{
|
||
if (editForm != null && !dbModel.UpdateForms.Any(t => t.ID == editForm.ID)) dbModel.UpdateForms.Add(editForm);
|
||
}
|
||
var typeClassEditAttr = this.GetAttributeByType<FormClassEditAttribute>(tableType);
|
||
if (typeClassEditAttr != null && !string.IsNullOrEmpty(typeClassEditAttr.DisplayName))
|
||
editForm.NAME = typeClassEditAttr.DisplayName;
|
||
else if (typeDescriptionAttr != null)
|
||
editForm.NAME = typeDescriptionAttr.Description + "编辑";
|
||
else
|
||
editForm.NAME = tableName + "编辑";
|
||
}
|
||
DoInitFormConfigByName(tableType, editForm, tableForm, null,
|
||
null, null, null, 0, string.Empty, string.Empty, dbModel, isAddSend, moduleName);
|
||
|
||
}
|
||
|
||
#region 列表页查询
|
||
if (tableForm != null)
|
||
{
|
||
T_PF_FORM_QUERY formQuery = null;
|
||
//this.GetEntity<T_PF_FORM_QUERY>(t => t.PAGE_FORM_ID == tableForm.ID);
|
||
List<T_PF_QUERY> querys = null;
|
||
if (formQuery == null)
|
||
{
|
||
formQuery = new T_PF_FORM_QUERY();
|
||
formQuery.ORG_ID = tableForm.ORG_ID;
|
||
formQuery.PAGE_FORM_ID = tableForm.ID;
|
||
dbModel.AddFormQuerys.Add(formQuery);
|
||
}
|
||
else
|
||
{
|
||
if (!dbModel.UpdateFormQuerys.Any(t => t.ID == formQuery.ID)) dbModel.UpdateFormQuerys.Add(formQuery);
|
||
querys = this.GetEntities<T_PF_QUERY>(t => t.PAGE_FORM_QUERY_ID == formQuery.ID).ToList();
|
||
}
|
||
formQuery.LABEL = "默认";
|
||
formQuery.TABLE_NAME = tableName;
|
||
|
||
int queryNum = querys != null && querys.Any() ? querys.Max(t => t.NUM) + 1 : 1;
|
||
foreach (var property in tableType.GetProperties())
|
||
{
|
||
int dataType = (int)PFDataTypeEnum.字符;
|
||
string enumName = string.Empty;
|
||
string queryName = property.Name;
|
||
string label = string.Empty;
|
||
int queryCase = 0;
|
||
string otherQueryName = string.Empty;
|
||
string otherLabel = string.Empty;
|
||
int otherQueryCase = 0;
|
||
|
||
var queryAttr = this.GetAttributeByProperty<FormFieldQueryAttribute>(property);
|
||
var queryDescAttr = this.GetAttributeByProperty<DescriptionAttribute>(property);
|
||
if (queryAttr != null && !string.IsNullOrEmpty(queryAttr.DisplayName))
|
||
label = queryAttr.DisplayName;
|
||
else if (queryDescAttr != null)
|
||
label = queryDescAttr.Description;
|
||
else
|
||
label = queryName;
|
||
|
||
var realPropertyType = property.PropertyType.GetNonNummableType();
|
||
if (queryAttr == null && (string.Compare(property.Name, "CODE", true) == 0 ||
|
||
string.Compare(property.Name, "NAME", true) == 0))
|
||
queryAttr = new FormFieldQueryAttribute();
|
||
if (queryAttr != null)
|
||
{
|
||
if (string.Compare(property.Name, "CODE", true) == 0)
|
||
queryCase = (int)FMCaseProcEnum.转大写;
|
||
if (realPropertyType == typeof(int) || realPropertyType.IsEnum)
|
||
{
|
||
EnumNameAttribute enumNameAttr = this.GetAttributeByProperty<EnumNameAttribute>(property);
|
||
string tempEnumName = enumNameAttr != null ? enumNameAttr.EnumName : ((realPropertyType.IsEnum) ? realPropertyType.Name : string.Empty);
|
||
if (string.IsNullOrEmpty(tempEnumName))
|
||
dataType = (int)PFDataTypeEnum.数值;
|
||
else
|
||
{
|
||
enumName = tempEnumName;
|
||
dataType = (int)PFDataTypeEnum.枚举;
|
||
}
|
||
}
|
||
else if (realPropertyType == typeof(decimal))
|
||
{
|
||
dataType = (int)PFDataTypeEnum.数值;
|
||
}
|
||
else if (realPropertyType == typeof(bool))
|
||
{
|
||
dataType = (int)PFDataTypeEnum.布尔;
|
||
}
|
||
else if (realPropertyType == typeof(DateTime))
|
||
{
|
||
dataType = (int)PFDataTypeEnum.日期区间;
|
||
}
|
||
else if (realPropertyType == typeof(Guid) ||
|
||
realPropertyType != typeof(string) && realPropertyType.IsClass)
|
||
{
|
||
string navTableName = string.Empty;
|
||
string idName = string.Empty;
|
||
string navFieldName = string.Empty;
|
||
GetNavInfoByProperty(tableType, tableName, property, property.Name, realPropertyType, ref navTableName,
|
||
ref idName, ref navFieldName);
|
||
if (!string.IsNullOrEmpty(navTableName))
|
||
{
|
||
var navType = DataHelper.GetTypeByEntityName(navTableName);
|
||
var navCodeP = navType.GetProperty("CODE");
|
||
var navNameP = navType.GetProperty("NAME");
|
||
if (navCodeP == null)
|
||
navCodeP = navType.GetProperty("PDT_CODE");
|
||
if (navCodeP != null && navNameP != null)
|
||
{
|
||
queryName = navFieldName + "." + navNameP.Name;
|
||
otherQueryName = navFieldName + "." + navCodeP.Name;
|
||
otherLabel = label + "编号";
|
||
otherQueryCase = (int)FMCaseProcEnum.转大写;
|
||
label += "名称";
|
||
}
|
||
else if (navCodeP == null && navNameP != null)
|
||
{
|
||
queryName = navFieldName + "." + navNameP.Name;
|
||
label += "名称";
|
||
}
|
||
else if (navCodeP != null && navNameP == null)
|
||
{
|
||
queryName = navFieldName + "." + navCodeP.Name;
|
||
label += "编号";
|
||
queryCase = (int)FMCaseProcEnum.转大写;
|
||
}
|
||
}
|
||
}
|
||
|
||
var query = querys == null ? null : querys.FirstOrDefault(t => t.QUERY_NAME == queryName);
|
||
if (query == null)
|
||
{
|
||
query = new T_PF_QUERY();
|
||
query.ORG_ID = formQuery.ORG_ID;
|
||
query.PAGE_FORM_ID = formQuery.PAGE_FORM_ID;
|
||
query.PAGE_FORM_QUERY_ID = formQuery.ID;
|
||
query.QUERY_NAME = queryName;
|
||
query.DATA_TYPE = dataType;
|
||
if (queryAttr != null && queryAttr.Num != 0)
|
||
query.NUM = queryAttr.Num;
|
||
else
|
||
{
|
||
query.NUM = queryNum;
|
||
queryNum += 5;
|
||
}
|
||
dbModel.AddQuerys.Add(query);
|
||
}
|
||
else
|
||
{
|
||
if (!dbModel.UpdateQuerys.Any(t => t.ID == query.ID)) dbModel.UpdateQuerys.Add(query);
|
||
}
|
||
|
||
query.LABEL = label;
|
||
query.ENUM_NAME = enumName;
|
||
query.CASE = queryCase;
|
||
|
||
if (!string.IsNullOrEmpty(otherQueryName))
|
||
{
|
||
var codeQuery = querys == null ? null : querys.FirstOrDefault(t => t.QUERY_NAME == otherQueryName);
|
||
if (codeQuery == null)
|
||
{
|
||
codeQuery = new T_PF_QUERY();
|
||
codeQuery.ORG_ID = query.ORG_ID;
|
||
CopyUtils.CopyObject(codeQuery, query);
|
||
if (queryAttr != null && queryAttr.Num != 0)
|
||
codeQuery.NUM = queryAttr.Num + 1;
|
||
else
|
||
{
|
||
codeQuery.NUM = queryNum;
|
||
queryNum += 5;
|
||
}
|
||
codeQuery.QUERY_NAME = otherQueryName;
|
||
codeQuery.CASE = otherQueryCase;
|
||
dbModel.AddQuerys.Add(codeQuery);
|
||
}
|
||
else
|
||
{
|
||
if (!dbModel.UpdateQuerys.Any(t => t.ID == codeQuery.ID)) dbModel.UpdateQuerys.Add(codeQuery);
|
||
}
|
||
|
||
codeQuery.LABEL = otherLabel;
|
||
codeQuery.DATA_TYPE = (int)PFDataTypeEnum.字符;
|
||
}
|
||
}
|
||
}
|
||
|
||
}
|
||
#endregion
|
||
|
||
#region 添加表单按钮
|
||
//列表页
|
||
if (dbModel.AddTables.Any())
|
||
{
|
||
int btnNum = 0;
|
||
dbModel.AddTables.ForEach(t =>
|
||
{
|
||
if (t.PARENT_ID != null) return;
|
||
|
||
//新增
|
||
var addBtn = new T_PF_BTN();
|
||
addBtn.ORG_ID = t.ORG_ID;
|
||
addBtn.PAGE_TABLE_ID = t.ID;
|
||
addBtn.PAGE_ID = t.ID;
|
||
addBtn.LABEL = "新增";
|
||
addBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.列表页;
|
||
addBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.按钮;
|
||
addBtn.BTN_TYPE = (int)PFBtnTypeEnum.新增;
|
||
addBtn.CSS = "primary";
|
||
addBtn.ICON = "plus";
|
||
addBtn.IS_RULE = true;
|
||
if (editForm != null)
|
||
addBtn.FORM_CODE = editForm.CODE;
|
||
btnNum++;
|
||
addBtn.NUM = btnNum;
|
||
dbModel.AddBtns.Add(addBtn);
|
||
|
||
//编辑
|
||
var rowEditBtn = new T_PF_BTN();
|
||
rowEditBtn.ORG_ID = t.ORG_ID;
|
||
rowEditBtn.PAGE_TABLE_ID = t.ID;
|
||
rowEditBtn.PAGE_ID = t.ID;
|
||
rowEditBtn.LABEL = "编辑";
|
||
rowEditBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.列表页;
|
||
rowEditBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.行按钮;
|
||
rowEditBtn.BTN_TYPE = (int)PFBtnTypeEnum.编辑;
|
||
rowEditBtn.CSS = "primary";
|
||
rowEditBtn.ICON = "edit";
|
||
rowEditBtn.IS_RULE = true;
|
||
if (editForm != null)
|
||
rowEditBtn.FORM_CODE = editForm.CODE;
|
||
btnNum++;
|
||
rowEditBtn.NUM = btnNum;
|
||
dbModel.AddBtns.Add(rowEditBtn);
|
||
|
||
//删除
|
||
var deleteBtn = new T_PF_BTN();
|
||
deleteBtn.ORG_ID = t.ORG_ID;
|
||
deleteBtn.PAGE_TABLE_ID = t.ID;
|
||
deleteBtn.PAGE_ID = t.ID;
|
||
deleteBtn.LABEL = "删除";
|
||
deleteBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.列表页;
|
||
deleteBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.按钮;
|
||
deleteBtn.BTN_TYPE = (int)PFBtnTypeEnum.删除;
|
||
deleteBtn.CSS = "danger";
|
||
deleteBtn.ICON = "delete";
|
||
deleteBtn.IS_RULE = true;
|
||
btnNum++;
|
||
deleteBtn.NUM = btnNum;
|
||
dbModel.AddBtns.Add(deleteBtn);
|
||
|
||
//行项删除
|
||
var rowDeleteBtn = new T_PF_BTN();
|
||
rowDeleteBtn.ORG_ID = t.ORG_ID;
|
||
rowDeleteBtn.PAGE_TABLE_ID = t.ID;
|
||
rowDeleteBtn.PAGE_ID = t.ID;
|
||
rowDeleteBtn.LABEL = "删除";
|
||
rowDeleteBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.列表页;
|
||
rowDeleteBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.行按钮;
|
||
rowDeleteBtn.BTN_TYPE = (int)PFBtnTypeEnum.删除;
|
||
rowDeleteBtn.CSS = "danger";
|
||
rowDeleteBtn.ICON = "delete";
|
||
rowEditBtn.IS_RULE = true;
|
||
btnNum++;
|
||
rowDeleteBtn.NUM = btnNum;
|
||
dbModel.AddBtns.Add(rowDeleteBtn);
|
||
|
||
|
||
//导出
|
||
var outportBtn = new T_PF_BTN();
|
||
outportBtn.ORG_ID = t.ORG_ID;
|
||
outportBtn.PAGE_TABLE_ID = t.ID;
|
||
outportBtn.PAGE_ID = t.ID;
|
||
outportBtn.LABEL = "导出";
|
||
outportBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.列表页;
|
||
outportBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.按钮;
|
||
outportBtn.BTN_TYPE = (int)PFBtnTypeEnum.导出;
|
||
outportBtn.CSS = "default";
|
||
outportBtn.ICON = "export2";
|
||
outportBtn.IS_RULE = true;
|
||
btnNum++;
|
||
outportBtn.NUM = btnNum;
|
||
dbModel.AddBtns.Add(outportBtn);
|
||
|
||
});
|
||
}
|
||
|
||
//树页面
|
||
if (dbModel.AddTrees.Any())
|
||
{
|
||
int btnNum = 0;
|
||
dbModel.AddTrees.ForEach(t =>
|
||
{
|
||
//新增
|
||
var addBtn = new T_PF_BTN();
|
||
addBtn.ORG_ID = t.ORG_ID;
|
||
addBtn.PAGE_EDIT_ID = t.ID;
|
||
addBtn.PAGE_ID = t.ID;
|
||
addBtn.LABEL = "新增";
|
||
addBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.编辑页;
|
||
addBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.按钮;
|
||
addBtn.BTN_TYPE = (int)PFBtnTypeEnum.新增;
|
||
addBtn.CSS = "primary";
|
||
addBtn.ICON = "plus";
|
||
btnNum++;
|
||
addBtn.NUM = btnNum;
|
||
addBtn.IS_RULE = true;
|
||
dbModel.AddBtns.Add(addBtn);
|
||
|
||
//删除
|
||
var deleteBtn = new T_PF_BTN();
|
||
deleteBtn.ORG_ID = t.ORG_ID;
|
||
deleteBtn.PAGE_EDIT_ID = t.ID;
|
||
deleteBtn.PAGE_ID = t.ID;
|
||
deleteBtn.LABEL = "删除";
|
||
deleteBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.列表页;
|
||
deleteBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.按钮;
|
||
deleteBtn.BTN_TYPE = (int)PFBtnTypeEnum.删除;
|
||
deleteBtn.CSS = "danger";
|
||
deleteBtn.ICON = "delete";
|
||
deleteBtn.IS_RULE = true;
|
||
btnNum++;
|
||
deleteBtn.NUM = btnNum;
|
||
dbModel.AddBtns.Add(deleteBtn);
|
||
});
|
||
}
|
||
|
||
//编辑页
|
||
if (dbModel.AddEdits.Any())
|
||
{
|
||
int btnNum = 0;
|
||
dbModel.AddEdits.ForEach(t =>
|
||
{
|
||
if (t.PARENT_ID == null)
|
||
{
|
||
if (!isAddSend)
|
||
{
|
||
//保存
|
||
var saveBtn = new T_PF_BTN();
|
||
saveBtn.ORG_ID = t.ORG_ID;
|
||
saveBtn.PAGE_EDIT_ID = t.ID;
|
||
saveBtn.PAGE_ID = t.ID;
|
||
saveBtn.LABEL = "保存";
|
||
saveBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.编辑页;
|
||
saveBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.按钮;
|
||
saveBtn.BTN_TYPE = (int)PFBtnTypeEnum.保存;
|
||
saveBtn.CSS = "primary";
|
||
saveBtn.ICON = "save";
|
||
saveBtn.IS_RULE = true;
|
||
btnNum++;
|
||
saveBtn.NUM = btnNum;
|
||
dbModel.AddBtns.Add(saveBtn);
|
||
}
|
||
else
|
||
{
|
||
//保存
|
||
var saveBtn = new T_PF_BTN();
|
||
saveBtn.ORG_ID = t.ORG_ID;
|
||
saveBtn.PAGE_EDIT_ID = t.ID;
|
||
saveBtn.PAGE_ID = t.ID;
|
||
saveBtn.LABEL = "保存";
|
||
saveBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.编辑页;
|
||
saveBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.按钮;
|
||
saveBtn.BTN_TYPE = (int)PFBtnTypeEnum.保存;
|
||
saveBtn.CSS = "primary";
|
||
saveBtn.ICON = "save";
|
||
saveBtn.IS_RULE = true;
|
||
saveBtn.CUSTOM_PARAMS = "0";
|
||
btnNum++;
|
||
saveBtn.NUM = btnNum;
|
||
dbModel.AddBtns.Add(saveBtn);
|
||
|
||
//保存并发送
|
||
var saveBtnSnd = new T_PF_BTN();
|
||
saveBtnSnd.ORG_ID = t.ORG_ID;
|
||
saveBtnSnd.PAGE_EDIT_ID = t.ID;
|
||
saveBtnSnd.PAGE_ID = t.ID;
|
||
saveBtnSnd.LABEL = "保存并发送";
|
||
saveBtnSnd.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.编辑页;
|
||
saveBtnSnd.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.按钮;
|
||
saveBtnSnd.BTN_TYPE = (int)PFBtnTypeEnum.保存;
|
||
saveBtnSnd.CSS = "primary";
|
||
saveBtnSnd.ICON = "save";
|
||
saveBtnSnd.IS_RULE = true;
|
||
saveBtnSnd.CUSTOM_PARAMS = "10";
|
||
btnNum++;
|
||
saveBtnSnd.NUM = btnNum;
|
||
dbModel.AddBtns.Add(saveBtnSnd);
|
||
}
|
||
}
|
||
else
|
||
{
|
||
//新增
|
||
var addBtn = new T_PF_BTN();
|
||
addBtn.ORG_ID = t.ORG_ID;
|
||
addBtn.PAGE_EDIT_ID = t.ID;
|
||
addBtn.PAGE_ID = t.ID;
|
||
addBtn.LABEL = "新增";
|
||
addBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.编辑页;
|
||
addBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.按钮;
|
||
addBtn.BTN_TYPE = (int)PFBtnTypeEnum.新增;
|
||
addBtn.CSS = "primary";
|
||
addBtn.ICON = "plus";
|
||
addBtn.IS_RULE = true;
|
||
btnNum++;
|
||
addBtn.NUM = btnNum;
|
||
dbModel.AddBtns.Add(addBtn);
|
||
|
||
//删除
|
||
var deleteBtn = new T_PF_BTN();
|
||
deleteBtn.ORG_ID = t.ORG_ID;
|
||
deleteBtn.PAGE_EDIT_ID = t.ID;
|
||
deleteBtn.PAGE_ID = t.ID;
|
||
deleteBtn.LABEL = "删除";
|
||
deleteBtn.BTN_PAGE_TYPE = (int)PFBtnPageTypeEnum.列表页;
|
||
deleteBtn.BTN_FUN_TYPE = (int)PFBtnFuncTypeEnum.按钮;
|
||
deleteBtn.BTN_TYPE = (int)PFBtnTypeEnum.删除;
|
||
deleteBtn.CSS = "danger";
|
||
deleteBtn.ICON = "delete";
|
||
deleteBtn.IS_RULE = true;
|
||
btnNum++;
|
||
deleteBtn.NUM = btnNum;
|
||
dbModel.AddBtns.Add(deleteBtn);
|
||
|
||
}
|
||
});
|
||
}
|
||
|
||
#endregion
|
||
#region 菜单
|
||
if (dbModel.AddForms.Any() && menuParentId != null)
|
||
{
|
||
var maxMenu = this.GetEntity<T_PF_MENU>(t => t.PARENT_ID == menuParentId, new BaseFilter(orgId)
|
||
{
|
||
Sort = "NUM",
|
||
Order = DbOrder.DESC
|
||
});
|
||
dbModel.AddForms.ForEach(t =>
|
||
{
|
||
if (t.FORM_TYPE == (int)PFFormTypeEnum.编辑表单) return;
|
||
T_PF_MENU menu = new T_PF_MENU();
|
||
menu.ORG_ID = t.ORG_ID;
|
||
menu.PARENT_ID = menuParentId;
|
||
menu.IS_PERMISSION_MENU = true;
|
||
menu.ENABLE_STATUS = (int)FMEnableStatusEnum.启用;
|
||
if (string.IsNullOrEmpty(menuName))
|
||
menu.NAME = t.NAME;
|
||
else
|
||
menu.NAME = menuName;
|
||
menu.MENU_FORM_ID = t.ID;
|
||
menu.ICON = menuIcon;
|
||
if (maxMenu != null)
|
||
menu.NUM = maxMenu.NUM + 1;
|
||
menu.REMARK = "一键生成菜单";
|
||
dbModel.AddMenus.Add(menu);
|
||
|
||
});
|
||
}
|
||
|
||
#endregion
|
||
|
||
#region 保存
|
||
UnifiedCommit(() =>
|
||
{
|
||
this.BantchAddEntityNoCommit(dbModel.AddForms);
|
||
this.BantchAddEntityNoCommit(dbModel.AddParamItems);
|
||
this.BantchAddEntityNoCommit(dbModel.AddParamSchemes);
|
||
this.BantchAddEntityNoCommit(dbModel.AddParamSchemeDetails);
|
||
this.TreeBantchAddEntityNoCommit(dbModel.AddEdits);
|
||
this.BantchAddEntityNoCommit(dbModel.AddEditPanels);
|
||
this.BantchAddEntityNoCommit(dbModel.AddTablePanels);
|
||
this.BantchAddEntityNoCommit(dbModel.AddEditColumns);
|
||
this.BantchAddEntityNoCommit(dbModel.AddEditColumnFilters);
|
||
this.BantchAddEntityNoCommit(dbModel.AddEditColumnFillMaps);
|
||
this.BantchAddEntityNoCommit(dbModel.AddEditColumnFillMapDs);
|
||
this.BantchAddEntityNoCommit(dbModel.AddCustoms);
|
||
this.BantchAddEntityNoCommit(dbModel.AddCharts);
|
||
this.BantchAddEntityNoCommit(dbModel.AddChartParams);
|
||
this.TreeBantchAddEntityNoCommit(dbModel.AddTables);
|
||
this.BantchAddEntityNoCommit(dbModel.AddColums);
|
||
this.BantchAddEntityNoCommit(dbModel.AddColumFilters);
|
||
this.BantchAddEntityNoCommit(dbModel.AddTableParams);
|
||
this.BantchAddEntityNoCommit(dbModel.AddFormQuerys);
|
||
this.BantchAddEntityNoCommit(dbModel.AddQuerys);
|
||
this.BantchAddEntityNoCommit(dbModel.AddTrees);
|
||
this.BantchAddEntityNoCommit(dbModel.AddTreeColumns);
|
||
this.BantchAddEntityNoCommit(dbModel.AddBtns);
|
||
this.BantchAddEntityNoCommit(dbModel.AddMenus);
|
||
|
||
|
||
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateForms);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateParamItems);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateParamSchemes);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateParamSchemeDetails);
|
||
this.TreeBantchUpdateEntityNoCommit(dbModel.UpdateEdits);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateEditPanels);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateTablePanels);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateEditColumns);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateEditColumnFilters);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateEditColumnFillMaps);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateEditColumnFillMapDs);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateCustoms);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateCharts);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateChartParams);
|
||
this.TreeBantchUpdateEntityNoCommit(dbModel.UpdateTables);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateColums);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateColumFilters);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateTableParams);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateFormQuerys);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateQuerys);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateTrees);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateTreeColumns);
|
||
this.BantchUpdateEntityNoCommit(dbModel.UpdateBtns);
|
||
|
||
|
||
});
|
||
#endregion
|
||
|
||
#region 表单版本升级
|
||
List<Guid> versionFormIds = new List<Guid>();
|
||
List<T_PF_PAGE_TABLE> versionPageTables = new List<T_PF_PAGE_TABLE>();
|
||
List<T_PF_COLUMN> versionColumns = new List<T_PF_COLUMN>();
|
||
List<T_PF_PAGE_TABLE_PANEL> versionPageTablePanels = new List<T_PF_PAGE_TABLE_PANEL>();
|
||
|
||
if (treeForm != null) versionFormIds.Add(treeForm.ID);
|
||
if (editForm != null) versionFormIds.Add(editForm.ID);
|
||
if (tableForm != null) versionFormIds.Add(tableForm.ID);
|
||
if (dbModel.AddTables.Any()) versionPageTables.AddRange(dbModel.AddTables);
|
||
if (dbModel.UpdateTables.Any()) versionPageTables.AddRange(dbModel.UpdateTables);
|
||
if (dbModel.AddColums.Any()) versionColumns.AddRange(dbModel.AddColums);
|
||
if (dbModel.UpdateColums.Any()) versionColumns.AddRange(dbModel.UpdateColums);
|
||
if (dbModel.AddTablePanels.Any()) versionPageTablePanels.AddRange(dbModel.AddTablePanels);
|
||
if (dbModel.UpdateTablePanels.Any()) versionPageTablePanels.AddRange(dbModel.UpdateTablePanels);
|
||
|
||
formService.AddFormConfigVersion(versionFormIds, versionPageTables, versionColumns,
|
||
versionPageTablePanels, null);
|
||
#endregion
|
||
}
|
||
|
||
private string GetApiPrefixByName(string tableName)
|
||
{
|
||
var newName = tableName.ToLower();
|
||
var newNameAry = newName.Split(new char[] { '_' });
|
||
var fixName = "";
|
||
string moduleName = string.Empty;
|
||
if (newNameAry.Any() && newNameAry.Length >= 2)
|
||
{
|
||
moduleName = newNameAry[1].ToUpper();
|
||
for (var n = 2; n < newNameAry.Length; n++)
|
||
fixName += System.Threading.Thread.CurrentThread.CurrentCulture.TextInfo.ToTitleCase(newNameAry[n]);
|
||
}
|
||
if (string.IsNullOrEmpty(moduleName) || string.IsNullOrEmpty(fixName)) return string.Empty;
|
||
return moduleName + "/" + fixName + "/";
|
||
}
|
||
|
||
private T GetAttributeByType<T>(Type type) where T : Attribute
|
||
{
|
||
T attr = null;
|
||
object[] attrs = type.GetCustomAttributes(typeof(T), true);
|
||
if (attrs.Length == 1)
|
||
attr = (T)attrs[0];
|
||
return attr;
|
||
}
|
||
|
||
private T GetAttributeByProperty<T>(PropertyInfo property) where T : Attribute
|
||
{
|
||
T attr = null;
|
||
object[] attrs = property.GetCustomAttributes(typeof(T), true);
|
||
if (attrs.Length == 1)
|
||
attr = (T)attrs[0];
|
||
return attr;
|
||
}
|
||
|
||
/// <summary>
|
||
/// 初始化表单配置
|
||
/// </summary>
|
||
/// <param name="type"></param>
|
||
/// <param name="editForm"></param>
|
||
/// <param name="tableForm"></param>
|
||
/// <param name="treeForm"></param>
|
||
/// <param name="parentPageEdit"></param>
|
||
/// <param name="parentPageTable"></param>
|
||
/// <param name="parentPageTree"></param>
|
||
/// <param name="num"></param>
|
||
/// <param name="relationFieldName"></param>
|
||
/// <param name="navPropertyName"></param>
|
||
/// <param name="dbModel"></param>
|
||
private void DoInitFormConfigByName(Type type, T_PF_FORM editForm,
|
||
T_PF_FORM tableForm, T_PF_FORM treeForm, T_PF_PAGE_EDIT parentPageEdit, T_PF_PAGE_TABLE parentPageTable,
|
||
T_PF_PAGE_TREE parentPageTree,
|
||
int num, string relationFieldName, string navPropertyName, FormConfigDbModel dbModel, bool isAddSend = false, string FormCode = "")
|
||
{
|
||
if (type == null ||
|
||
tableForm == null && treeForm == null && editForm == null) return;
|
||
string tableName = type.Name;
|
||
string apiPrefix = GetApiPrefixByName(tableName);
|
||
var typeDescriptionAttr = GetAttributeByType<DescriptionAttribute>(type);
|
||
int listNum = 0;
|
||
|
||
num++;
|
||
|
||
//编辑
|
||
T_PF_PAGE_EDIT pageEdit = null;
|
||
List<T_PF_EDIT_COLUMN> pageEditColumns = null;
|
||
if (editForm != null)
|
||
{
|
||
if (parentPageEdit == null && string.IsNullOrEmpty(apiPrefix)) return;
|
||
|
||
pageEdit = this.GetEntity<T_PF_PAGE_EDIT>(t => t.PAGE_FORM_ID == editForm.ID
|
||
&& t.EDIT_NAME == tableName);
|
||
if (pageEdit == null)
|
||
{
|
||
pageEdit = new T_PF_PAGE_EDIT();
|
||
pageEdit.ORG_ID = editForm.ORG_ID;
|
||
pageEdit.PAGE_FORM_ID = editForm.ID;
|
||
pageEdit.CODE = tableName;
|
||
pageEdit.EDIT_NAME = tableName;
|
||
pageEdit.NUM = num;
|
||
if (parentPageEdit == null)
|
||
{
|
||
if (isAddSend)
|
||
{
|
||
string TempApi = apiPrefix.Replace(FormCode + "/", FormCode + "/" + FormCode);
|
||
pageEdit.API_URL = TempApi + "FullUpdate";
|
||
}
|
||
else
|
||
pageEdit.API_URL = apiPrefix + "Update";
|
||
|
||
pageEdit.QUERY_API_URL = apiPrefix + "Get";
|
||
}
|
||
dbModel.AddEdits.Add(pageEdit);
|
||
//子表处理
|
||
}
|
||
else
|
||
{
|
||
if (!dbModel.UpdateEdits.Any(t => t.ID == pageEdit.ID)) dbModel.UpdateEdits.Add(pageEdit);
|
||
pageEditColumns = this.GetEntities<T_PF_EDIT_COLUMN>(t => t.PAGE_EDIT_ID == pageEdit.ID).ToList();
|
||
}
|
||
|
||
var typeClassEditAttr = this.GetAttributeByType<FormClassEditAttribute>(type);
|
||
if (typeClassEditAttr != null && !string.IsNullOrEmpty(typeClassEditAttr.DisplayName))
|
||
pageEdit.LABEL_NAME = typeClassEditAttr.DisplayName;
|
||
else if (typeDescriptionAttr != null)
|
||
pageEdit.LABEL_NAME = typeDescriptionAttr.Description;
|
||
else
|
||
pageEdit.LABEL_NAME = tableName;
|
||
|
||
if (parentPageEdit != null)
|
||
{
|
||
pageEdit.PARENT_ID = parentPageEdit.ID;
|
||
pageEdit.RELATION_FIELD = relationFieldName;
|
||
pageEdit.NAV_PROPERTY = navPropertyName;
|
||
}
|
||
|
||
}
|
||
|
||
//列表
|
||
T_PF_PAGE_TABLE pageTable = null;
|
||
List<T_PF_COLUMN> pageColumns = null;
|
||
if (tableForm != null)
|
||
{
|
||
if (string.IsNullOrEmpty(apiPrefix)) return;
|
||
pageTable = this.GetEntity<T_PF_PAGE_TABLE>(t => t.PAGE_FORM_ID == tableForm.ID
|
||
&& t.DATA_TABLE == tableName);
|
||
if (pageTable == null)
|
||
{
|
||
pageTable = new T_PF_PAGE_TABLE();
|
||
pageTable.ORG_ID = tableForm.ORG_ID;
|
||
pageTable.PAGE_FORM_ID = tableForm.ID;
|
||
pageTable.CODE = tableName;
|
||
pageTable.TABLE_NAME = tableName;
|
||
pageTable.DATA_TABLE = tableName;
|
||
pageTable.SHOW_CHECK = true;
|
||
pageTable.API_URL = apiPrefix + "OrderPaged";
|
||
pageTable.DEL_API_URL = apiPrefix + "Delete";
|
||
pageTable.BATCH_DEL_API_URL = apiPrefix + "BatchDelete";
|
||
pageTable.NUM = num;
|
||
pageTable.IS_SHOW_ROW_NO = true;
|
||
dbModel.AddTables.Add(pageTable);
|
||
}
|
||
else
|
||
{
|
||
if (!dbModel.UpdateTables.Any(t => t.ID == pageTable.ID)) dbModel.UpdateTables.Add(pageTable);
|
||
pageColumns = this.GetEntities<T_PF_COLUMN>(t => t.PAGE_TABLE_ID == pageTable.ID).ToList();
|
||
}
|
||
|
||
var typeClassTableAttr = this.GetAttributeByType<FormClassTableAttribute>(type);
|
||
if (typeClassTableAttr != null && !string.IsNullOrEmpty(typeClassTableAttr.DisplayName))
|
||
pageTable.LABEL_NAME = typeClassTableAttr.DisplayName;
|
||
else if (typeDescriptionAttr != null)
|
||
pageTable.LABEL_NAME = typeDescriptionAttr.Description;
|
||
else
|
||
pageTable.LABEL_NAME = tableName;
|
||
|
||
if (parentPageTable != null)
|
||
pageTable.PARENT_ID = parentPageTable.ID;
|
||
pageTable.RELATION_FIELD = relationFieldName;
|
||
}
|
||
|
||
|
||
//树
|
||
T_PF_PAGE_TREE pageTree = null;
|
||
List<T_PF_TREE_COLUMN> pageTreeColumns = null;
|
||
if (treeForm != null)
|
||
{
|
||
if (string.IsNullOrEmpty(apiPrefix)) return;
|
||
pageTree = this.GetEntity<T_PF_PAGE_TREE>(t => t.PAGE_FORM_ID == treeForm.ID);
|
||
if (pageTree == null)
|
||
{
|
||
pageTree = new T_PF_PAGE_TREE();
|
||
pageTree.ORG_ID = treeForm.ORG_ID;
|
||
pageTree.PAGE_FORM_ID = treeForm.ID;
|
||
pageTree.QUERY_API_URL = apiPrefix + "OrderEntities";
|
||
pageTree.BATCH_DEL_API_URL = apiPrefix + "BatchDelete";
|
||
pageTree.NUM = num;
|
||
dbModel.AddTrees.Add(pageTree);
|
||
}
|
||
else
|
||
{
|
||
if (!dbModel.UpdateTrees.Any(t => t.ID == pageTree.ID)) dbModel.UpdateTrees.Add(pageTree);
|
||
pageTreeColumns = this.GetEntities<T_PF_TREE_COLUMN>(t => t.PAGE_TREE_ID == pageTree.ID).ToList();
|
||
}
|
||
var typeClassTreeAttr = this.GetAttributeByType<FormClassTreeAttribute>(type);
|
||
if (typeClassTreeAttr != null && !string.IsNullOrEmpty(typeClassTreeAttr.DisplayName))
|
||
pageTree.LABEL_NAME = typeClassTreeAttr.DisplayName;
|
||
else if (typeDescriptionAttr != null)
|
||
pageTree.LABEL_NAME = typeDescriptionAttr.Description;
|
||
else
|
||
pageTree.LABEL_NAME = tableName;
|
||
}
|
||
|
||
|
||
int editFieldNum = pageEditColumns != null && pageEditColumns.Any() ? (pageEditColumns.Max(t => t.NUM) + 1) : 1;
|
||
int tableFieldNum = pageColumns != null && pageColumns.Any() ? (pageColumns.Max(t => t.NUM) + 1) : 1;
|
||
int treeFieldNum = pageTreeColumns != null && pageTreeColumns.Any() ? (pageTreeColumns.Max(t => t.NUM) + 1) : 1;
|
||
|
||
//循环获取字段配置数据
|
||
foreach (var property in type.GetProperties())
|
||
{
|
||
var tableAttr = this.GetAttributeByProperty<FormFieldTableAttribute>(property);
|
||
var editAttr = this.GetAttributeByProperty<FormFieldEditAttribute>(property);
|
||
var treeAttr = this.GetAttributeByProperty<FormFieldTreeAttribute>(property);
|
||
var requireAttr = this.GetAttributeByProperty<DataFieldRequireAttribute>(property);
|
||
|
||
var propertyType = property.PropertyType;
|
||
var propertyDescAttr = this.GetAttributeByProperty<DescriptionAttribute>(property);
|
||
string fieldName = property.Name;
|
||
if (string.Compare(fieldName, "CODE", true) == 0)
|
||
{
|
||
if (tableAttr == null)
|
||
tableAttr = new FormFieldTableAttribute();
|
||
if (editAttr == null)
|
||
editAttr = new FormFieldEditAttribute();
|
||
}
|
||
else if (string.Compare(fieldName, "NAME", true) == 0)
|
||
{
|
||
if (tableAttr == null)
|
||
tableAttr = new FormFieldTableAttribute();
|
||
if (editAttr == null)
|
||
editAttr = new FormFieldEditAttribute();
|
||
if (treeAttr == null)
|
||
treeAttr = new FormFieldTreeAttribute();
|
||
}
|
||
else if (string.Compare(fieldName, "REMARK", true) == 0)
|
||
{
|
||
if (editAttr == null)
|
||
editAttr = new FormFieldEditAttribute();
|
||
}
|
||
else if (string.Compare(fieldName, "ENABLE_STATUS", true) == 0)
|
||
{
|
||
if (tableAttr == null)
|
||
tableAttr = new FormFieldTableAttribute();
|
||
if (editAttr == null)
|
||
editAttr = new FormFieldEditAttribute();
|
||
}
|
||
else if (string.Compare(fieldName, "ORDER_STATUS", true) == 0)
|
||
{
|
||
if (tableAttr == null)
|
||
tableAttr = new FormFieldTableAttribute();
|
||
}
|
||
|
||
|
||
//列表
|
||
if (propertyType.IsGenericType && typeof(System.Collections.IEnumerable).IsAssignableFrom(propertyType))
|
||
{
|
||
var tempTableForm = tableAttr != null ? tableForm : null;
|
||
var tempEditForm = editAttr != null ? editForm : null;
|
||
if (tempTableForm != null || tempEditForm != null)
|
||
{
|
||
var genArgs = propertyType.GetGenericArguments();
|
||
if (genArgs != null && genArgs.Any())
|
||
{
|
||
string idName = string.Empty;
|
||
var foreignForMasterAttr = this.GetAttributeByProperty<DataFieldForeignKeyForMasterAttribute>(property);
|
||
if (foreignForMasterAttr != null)
|
||
idName = foreignForMasterAttr.IdFieldName;
|
||
else
|
||
{
|
||
var fkeyP = this.UnitOfWork.GetModelForeignKey(tableName, property.Name);
|
||
if (fkeyP != null)
|
||
idName = fkeyP.ForeignFieldName;
|
||
}
|
||
DoInitFormConfigByName(genArgs[0], tempEditForm, tempTableForm, null, pageEdit, pageTable, pageTree,
|
||
listNum, idName, property.Name, dbModel);
|
||
listNum++;
|
||
}
|
||
}
|
||
}
|
||
else
|
||
{
|
||
|
||
var realPropertyType = property.PropertyType.GetNonNummableType();
|
||
#region 编辑属性
|
||
if (editAttr != null && pageEdit != null)
|
||
{
|
||
bool required = requireAttr != null ? requireAttr.IsRequire : false;
|
||
int codeRuleType = 0, controlType = (int)PFControlTypeEnum.文本输入, editColCase = 0;
|
||
bool editable = true;
|
||
string enumName = null, inputIdField = null, inputDataApi = null, inputFilterField = null,
|
||
inputLableFiled = null, inputShowField = null, inputNavFiled = null, inputSaveField = null,
|
||
showFormCode = null, showIdField = null;
|
||
string colFieldName = fieldName;
|
||
bool isAddEnableStatusFilter = false;
|
||
int dataFileLen = 500;
|
||
if (realPropertyType == typeof(string))
|
||
{
|
||
var codeRuleAttr = this.GetAttributeByProperty<CodeRuleAttribute>(property);
|
||
if (codeRuleAttr != null && codeRuleAttr.CodeRuleTypes != null && codeRuleAttr.CodeRuleTypes.Any())
|
||
{
|
||
required = true;
|
||
editable = false;
|
||
codeRuleType = codeRuleAttr.CodeRuleTypes[0];
|
||
controlType = (int)PFControlTypeEnum.系统序列号控件;
|
||
editColCase = (int)FMCaseProcEnum.转大写;
|
||
}
|
||
else
|
||
{
|
||
if (string.Compare(fieldName, "REMARK", true) == 0)
|
||
{
|
||
if (parentPageEdit == null)
|
||
controlType = (int)PFControlTypeEnum.长文本域;
|
||
}
|
||
else
|
||
{
|
||
if (string.Compare(fieldName, "NAME", true) == 0)
|
||
required = true;
|
||
else if (string.Compare(fieldName, "CODE", true) == 0)
|
||
{
|
||
editColCase = (int)FMCaseProcEnum.转大写;
|
||
required = true;
|
||
}
|
||
}
|
||
}
|
||
|
||
var dataFileLength = this.GetAttributeByProperty<DataFieldLengthAttribute>(property);
|
||
if (dataFileLength != null)
|
||
{
|
||
dataFileLen = dataFileLength.Length;
|
||
}
|
||
}
|
||
else if (realPropertyType == typeof(int) || realPropertyType.IsEnum)
|
||
{
|
||
EnumNameAttribute enumNameAttr = this.GetAttributeByProperty<EnumNameAttribute>(property);
|
||
string tempEnumName = enumNameAttr != null ? enumNameAttr.EnumName : ((realPropertyType.IsEnum) ? realPropertyType.Name : string.Empty);
|
||
if (string.IsNullOrEmpty(tempEnumName))
|
||
controlType = (int)PFControlTypeEnum.数值类型;
|
||
else
|
||
{
|
||
enumName = tempEnumName;
|
||
controlType = (int)PFControlTypeEnum.下拉选择;
|
||
}
|
||
}
|
||
else if (realPropertyType == typeof(decimal))
|
||
{
|
||
controlType = (int)PFControlTypeEnum.数值类型;
|
||
}
|
||
else if (realPropertyType == typeof(bool))
|
||
{
|
||
controlType = (int)PFControlTypeEnum.单项选框;
|
||
}
|
||
else if (realPropertyType == typeof(DateTime))
|
||
{
|
||
controlType = (int)PFControlTypeEnum.日期选择;
|
||
}
|
||
else if (realPropertyType == typeof(Guid) ||
|
||
realPropertyType != typeof(string) && realPropertyType.IsClass)
|
||
{
|
||
string navTableName = string.Empty;
|
||
string idName = string.Empty;
|
||
string navFieldName = string.Empty;
|
||
GetNavInfoByProperty(type, tableName, property, fieldName, realPropertyType, ref navTableName,
|
||
ref idName, ref navFieldName);
|
||
|
||
if (!string.IsNullOrEmpty(navTableName))
|
||
{
|
||
var navType = DataHelper.GetTypeByEntityName(navTableName);
|
||
inputDataApi = GetApiPrefixByName(navTableName) + "OrderPaged";
|
||
var navCodeP = navType.GetProperty("CODE");
|
||
var navNameP = navType.GetProperty("NAME");
|
||
if (navCodeP == null)
|
||
navCodeP = navType.GetProperty("PDT_CODE");
|
||
if (navCodeP != null && navNameP != null)
|
||
{
|
||
colFieldName = navFieldName + "." + navNameP.Name;
|
||
inputNavFiled = "ID," + navNameP.Name;
|
||
inputSaveField = idName + "," + colFieldName;
|
||
}
|
||
else if (navCodeP == null && navNameP != null)
|
||
{
|
||
colFieldName = navFieldName + "." + navNameP.Name;
|
||
inputFilterField = navNameP.Name;
|
||
inputLableFiled = navNameP.Name;
|
||
inputShowField = navNameP.Name;
|
||
inputNavFiled = "ID," + navNameP.Name;
|
||
inputSaveField = idName + "," + colFieldName;
|
||
}
|
||
else if (navCodeP != null && navNameP == null)
|
||
{
|
||
colFieldName = navFieldName + "." + navCodeP.Name;
|
||
inputFilterField = navCodeP.Name;
|
||
inputLableFiled = navCodeP.Name;
|
||
inputShowField = navCodeP.Name;
|
||
inputNavFiled = "ID," + navCodeP.Name;
|
||
inputSaveField = idName + "," + colFieldName;
|
||
}
|
||
|
||
isAddEnableStatusFilter = navType.GetProperty("ENABLE_STATUS") != null;
|
||
|
||
var f = this.GetEntity<T_PF_FORM>(t => t.TABLE_NAME == navTableName &&
|
||
t.ENABLE_STATUS == 0 && t.FORM_TYPE != (int)PFFormTypeEnum.列表表单 &&
|
||
t.FORM_TYPE != (int)PFFormTypeEnum.图表表单);
|
||
if (f != null)
|
||
{
|
||
showFormCode = f.CODE;
|
||
showIdField = idName;
|
||
}
|
||
}
|
||
inputIdField = idName;
|
||
controlType = (int)PFControlTypeEnum.分页下拉;
|
||
if (!string.IsNullOrEmpty(idName))
|
||
{
|
||
var idP = type.GetProperty(idName);
|
||
if (idP != null && requireAttr == null)
|
||
{
|
||
var tempRequireAttr = this.GetAttributeByProperty<DataFieldRequireAttribute>(idP);
|
||
if (tempRequireAttr != null)
|
||
required = tempRequireAttr.IsRequire;
|
||
}
|
||
if (idP != null && !idP.PropertyType.IsNullableType())
|
||
required = true;
|
||
}
|
||
}
|
||
|
||
|
||
var editColumn = pageEditColumns == null ? null : pageEditColumns.FirstOrDefault(t => t.FIELD_NAME == colFieldName);
|
||
if (editColumn == null)
|
||
{
|
||
editColumn = new T_PF_EDIT_COLUMN();
|
||
editColumn.ORG_ID = pageEdit.ORG_ID;
|
||
editColumn.PAGE_EDIT_ID = pageEdit.ID;
|
||
editColumn.FIELD_NAME = colFieldName;
|
||
editColumn.IS_DEFAULT = true;
|
||
editColumn.MAX_LEN = dataFileLen;
|
||
editColumn.TYPE_NAME = realPropertyType.Name;
|
||
if (editAttr != null && editAttr.Num != 0)
|
||
editColumn.NUM = editAttr.Num;
|
||
else
|
||
{
|
||
editColumn.NUM = editFieldNum;
|
||
editFieldNum += 10;
|
||
}
|
||
editColumn.REQUIRED = required;
|
||
editColumn.EDITABLE = editable;
|
||
editColumn.CODE_RULE_TYPE = codeRuleType;
|
||
editColumn.CONTROL_TYPE = controlType;
|
||
editColumn.CASE = editColCase;
|
||
|
||
editColumn.INPUT_DATA_API = inputDataApi;
|
||
editColumn.INPUT_FILTER_FIELD = inputFilterField;
|
||
editColumn.INPUT_LABEL_FIELD = inputLableFiled;
|
||
editColumn.INPUT_SHOW_FIELD = inputShowField;
|
||
editColumn.INPUT_NAV_FIELD = inputNavFiled;
|
||
editColumn.INPUT_SAVE_FIELD = inputSaveField;
|
||
editColumn.INPUT_ID_FIELD = inputIdField;
|
||
|
||
dbModel.AddEditColumns.Add(editColumn);
|
||
|
||
if (isAddEnableStatusFilter)
|
||
{
|
||
var editColumnFilter = new T_PF_EDIT_COLUMN_FILTER();
|
||
editColumnFilter.ORG_ID = editColumn.ORG_ID;
|
||
editColumnFilter.EDIT_COLUMN_ID = editColumn.ID;
|
||
editColumnFilter.PAGE_EDIT_ID = editColumn.PAGE_EDIT_ID;
|
||
editColumnFilter.FIELD_NAME = "ENABLE_STATUS";
|
||
editColumnFilter.OPERATION = 1;
|
||
editColumnFilter.VALUE = "0";
|
||
dbModel.AddEditColumnFilters.Add(editColumnFilter);
|
||
}
|
||
}
|
||
else
|
||
{
|
||
if (!dbModel.UpdateEditColumns.Any(t => t.ID == editColumn.ID)) dbModel.UpdateEditColumns.Add(editColumn);
|
||
}
|
||
|
||
editColumn.LABEL = !string.IsNullOrEmpty(editAttr.DisplayName) ? editAttr.DisplayName :
|
||
(propertyDescAttr != null ? propertyDescAttr.Description : colFieldName);
|
||
editColumn.ENUM = enumName;
|
||
editColumn.SHOW_FORM_CODE = showFormCode;
|
||
editColumn.SHOW_ID_FIELD = showIdField;
|
||
|
||
}
|
||
#endregion
|
||
|
||
#region 列表属性
|
||
if (tableAttr != null && pageTable != null)
|
||
{
|
||
bool isDefault = true;
|
||
int controlType = 0;
|
||
string enumName = null, showFormCode = null, showIdField = null;
|
||
string colFieldName = fieldName;
|
||
|
||
if (string.Compare(fieldName, "REMARK", true) == 0)
|
||
{
|
||
controlType = (int)PFColumnControlTypeEnum.文本_最大10字符;
|
||
}
|
||
else if (realPropertyType == typeof(int) || realPropertyType.IsEnum)
|
||
{
|
||
EnumNameAttribute enumNameAttr = this.GetAttributeByProperty<EnumNameAttribute>(property);
|
||
enumName = enumNameAttr != null ? enumNameAttr.EnumName : ((realPropertyType.IsEnum) ? realPropertyType.Name : string.Empty);
|
||
|
||
}
|
||
else if (realPropertyType == typeof(Guid) ||
|
||
realPropertyType.IsClass && realPropertyType != typeof(string))
|
||
{
|
||
string navTableName = string.Empty;
|
||
string idName = string.Empty;
|
||
string navFieldName = string.Empty;
|
||
GetNavInfoByProperty(type, tableName, property, fieldName, realPropertyType, ref navTableName,
|
||
ref idName, ref navFieldName);
|
||
|
||
if (string.IsNullOrEmpty(navFieldName))
|
||
isDefault = false;
|
||
|
||
if (!string.IsNullOrEmpty(navTableName))
|
||
{
|
||
var navType = DataHelper.GetTypeByEntityName(navTableName);
|
||
var navCodeP = navType.GetProperty("CODE");
|
||
var navNameP = navType.GetProperty("NAME");
|
||
if (navCodeP == null)
|
||
navCodeP = navType.GetProperty("PDT_CODE");
|
||
if (navCodeP != null && navNameP != null)
|
||
{
|
||
colFieldName = navFieldName + "." + navNameP.Name;
|
||
}
|
||
else if (navCodeP == null && navNameP != null)
|
||
{
|
||
colFieldName = navFieldName + "." + navNameP.Name;
|
||
}
|
||
else if (navCodeP != null && navNameP == null)
|
||
{
|
||
colFieldName = navFieldName + "." + navCodeP.Name;
|
||
}
|
||
|
||
var f = this.GetEntity<T_PF_FORM>(t => t.TABLE_NAME == navTableName &&
|
||
t.ENABLE_STATUS == 0 && t.FORM_TYPE != (int)PFFormTypeEnum.列表表单 &&
|
||
t.FORM_TYPE != (int)PFFormTypeEnum.图表表单);
|
||
if (f != null)
|
||
{
|
||
showFormCode = f.CODE;
|
||
showIdField = idName;
|
||
}
|
||
}
|
||
}
|
||
|
||
|
||
var column = pageColumns == null ? null : pageColumns.FirstOrDefault(t => t.FIELD_NAME == colFieldName);
|
||
if (column == null)
|
||
{
|
||
column = new T_PF_COLUMN();
|
||
column.ORG_ID = pageTable.ORG_ID;
|
||
column.PAGE_TABLE_ID = pageTable.ID;
|
||
column.FIELD_NAME = colFieldName;
|
||
column.IS_DEFAULT = isDefault;
|
||
column.CONTROL_TYPE = controlType;
|
||
if (tableAttr != null && tableAttr.Num != 0)
|
||
column.NUM = tableAttr.Num;
|
||
else
|
||
{
|
||
column.NUM = tableFieldNum;
|
||
tableFieldNum += 10;
|
||
}
|
||
dbModel.AddColums.Add(column);
|
||
}
|
||
else
|
||
{
|
||
if (!dbModel.UpdateColums.Any(t => t.ID == column.ID)) dbModel.UpdateColums.Add(column);
|
||
}
|
||
|
||
column.LABEL = !string.IsNullOrEmpty(tableAttr.DisplayName) ? tableAttr.DisplayName :
|
||
(propertyDescAttr != null ? propertyDescAttr.Description : fieldName);
|
||
column.ENUM = enumName;
|
||
column.SHOW_FORM_CODE = showFormCode;
|
||
column.SHOW_ID_FIELD = showIdField;
|
||
}
|
||
#endregion
|
||
|
||
#region 树属性
|
||
if (treeAttr != null && pageTree != null)
|
||
{
|
||
|
||
var treeColumn = pageTreeColumns == null ? null : pageTreeColumns.FirstOrDefault(t => t.FIELD_NAME == fieldName);
|
||
if (treeColumn == null)
|
||
{
|
||
treeColumn = new T_PF_TREE_COLUMN();
|
||
treeColumn.ORG_ID = pageTree.ORG_ID;
|
||
treeColumn.PAGE_TREE_ID = pageTree.ID;
|
||
treeColumn.FIELD_NAME = fieldName;
|
||
if (treeAttr != null && treeAttr.Num != 0)
|
||
treeColumn.NUM = treeAttr.Num;
|
||
else
|
||
{
|
||
treeColumn.NUM = treeFieldNum;
|
||
treeFieldNum += 10;
|
||
}
|
||
dbModel.AddTreeColumns.Add(treeColumn);
|
||
}
|
||
else
|
||
{
|
||
if (!dbModel.UpdateTreeColumns.Any(t => t.ID == treeColumn.ID)) dbModel.UpdateTreeColumns.Add(treeColumn);
|
||
}
|
||
|
||
if (realPropertyType == typeof(int) || realPropertyType.IsEnum)
|
||
{
|
||
EnumNameAttribute enumNameAttr = this.GetAttributeByProperty<EnumNameAttribute>(property);
|
||
treeColumn.ENUM = enumNameAttr != null ? enumNameAttr.EnumName : ((realPropertyType.IsEnum) ? realPropertyType.Name : string.Empty);
|
||
|
||
}
|
||
}
|
||
#endregion
|
||
|
||
}
|
||
|
||
|
||
}
|
||
}
|
||
|
||
private void GetNavInfoByProperty(Type tableType, string tableName, PropertyInfo property,
|
||
string fieldName, Type realPropertyType, ref string navTableName,
|
||
ref string idName, ref string navFieldName)
|
||
{
|
||
if (realPropertyType == typeof(Guid))
|
||
{
|
||
var keyP = this.GetAttributeByProperty<DataFieldForeignKeyAttribute>(property);
|
||
if (keyP != null)
|
||
navFieldName = keyP.NavFieldName;
|
||
else
|
||
{
|
||
var keyModel = this.UnitOfWork.GetModelForeignKeyById(tableName, fieldName);
|
||
if (keyModel != null)
|
||
navFieldName = keyModel.ForeignNavName;
|
||
}
|
||
if (!string.IsNullOrEmpty(navFieldName))
|
||
{
|
||
var navP = tableType.GetProperty(navFieldName);
|
||
if (navP != null)
|
||
navTableName = navP.PropertyType.Name;
|
||
}
|
||
idName = fieldName;
|
||
}
|
||
else
|
||
{
|
||
navTableName = realPropertyType.Name;
|
||
navFieldName = fieldName;
|
||
foreach (var pp in tableType.GetProperties())
|
||
{
|
||
var keyPP = this.GetAttributeByProperty<DataFieldForeignKeyAttribute>(pp);
|
||
if (keyPP != null && string.Compare(keyPP.NavFieldName, fieldName, true) == 0)
|
||
idName = pp.Name;
|
||
}
|
||
if (string.IsNullOrEmpty(idName))
|
||
{
|
||
var keyModel = this.UnitOfWork.GetModelForeignKey(tableName, navFieldName);
|
||
if (keyModel != null)
|
||
idName = keyModel.ForeignFieldName;
|
||
}
|
||
}
|
||
}
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
}
|
||
}
|