360 lines
13 KiB
C#
360 lines
13 KiB
C#
|
using Learun.Application.Organization;
|
|||
|
using Learun.Application.TwoDevelopment.ZZDT_EC;
|
|||
|
using Learun.Util;
|
|||
|
using Learun.Util.SqlSugar;
|
|||
|
using Newtonsoft.Json.Linq;
|
|||
|
using System;
|
|||
|
using System.Collections.Generic;
|
|||
|
using System.Linq;
|
|||
|
using System.Web.Http;
|
|||
|
using System.Web.Mvc;
|
|||
|
using HttpGetAttribute = System.Web.Mvc.HttpGetAttribute;
|
|||
|
using HttpPostAttribute = System.Web.Mvc.HttpPostAttribute;
|
|||
|
|
|||
|
namespace Learun.Application.Web.Areas.ZZDT_EC.Controllers
|
|||
|
{
|
|||
|
/// <summary>
|
|||
|
/// 版 本 PIT-ADMS V7.0.3 敏捷开发框架
|
|||
|
/// Copyright (c) 2013-2018 Hexagon PPM
|
|||
|
/// 创 建:超级管理员
|
|||
|
/// 日 期:2022-02-23 11:30
|
|||
|
/// 描 述:属性表
|
|||
|
/// </summary>
|
|||
|
public class ec_propertyController : MvcControllerBase
|
|||
|
{
|
|||
|
private ec_propertyIBLL ec_propertyIBLL = new ec_propertyBLL();
|
|||
|
private ec_objecttypepIBLL ec_objecttypepIBLL = new ec_objecttypepBLL();
|
|||
|
#region 视图功能
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// 主页面
|
|||
|
/// <summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
public ActionResult Index()
|
|||
|
{
|
|||
|
return View();
|
|||
|
}
|
|||
|
/// <summary>
|
|||
|
/// 表单页
|
|||
|
/// <summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
public ActionResult Form()
|
|||
|
{
|
|||
|
return View();
|
|||
|
}
|
|||
|
/// <summary>
|
|||
|
/// 属性设置页面
|
|||
|
/// <summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
public ActionResult SelectProperty()
|
|||
|
{
|
|||
|
return View();
|
|||
|
}
|
|||
|
/// <summary>
|
|||
|
/// 设置对象类型 - 属性 的高级联动设置
|
|||
|
/// <summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
public ActionResult PropertyDependent()
|
|||
|
{
|
|||
|
return View();
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
///对象类型页面
|
|||
|
/// <summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
public ActionResult SelectObjectType()
|
|||
|
{
|
|||
|
return View();
|
|||
|
}
|
|||
|
#endregion
|
|||
|
|
|||
|
#region 获取数据
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// 获取页面显示列表数据
|
|||
|
/// <summary>
|
|||
|
/// <param name="queryJson">查询参数</param>
|
|||
|
/// <param name="engineDataID">工程数据ID</param>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult GetPageList(string pagination, string queryJson, string engineDataID = "", string caseID = "")
|
|||
|
{
|
|||
|
Pagination paginationobj = pagination.ToObject<Pagination>();
|
|||
|
paginationobj.sidx = "OrderID ";
|
|||
|
paginationobj.sord = "ASC";
|
|||
|
var data = ec_propertyIBLL.GetList(queryJson, engineDataID, paginationobj);
|
|||
|
var jsonData = new
|
|||
|
{
|
|||
|
rows = data,
|
|||
|
total = paginationobj.total,
|
|||
|
page = paginationobj.page,
|
|||
|
records = paginationobj.records
|
|||
|
};
|
|||
|
return Success(jsonData);
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// 用于 对象类型 - 属性设置
|
|||
|
/// <summary>
|
|||
|
/// <param name="queryJson">查询参数</param>
|
|||
|
/// <param name="engineDataID">工程数据ID</param>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult GetPageList2(string ProjectId, string ObjectTypeID, string PropertyGID)
|
|||
|
{
|
|||
|
if (string.IsNullOrEmpty(PropertyGID))
|
|||
|
{
|
|||
|
//没选择group时,不返回
|
|||
|
return Success(null);
|
|||
|
}
|
|||
|
var data = ec_propertyIBLL.GetObjectLinkedProps(ProjectId, ObjectTypeID, PropertyGID);
|
|||
|
|
|||
|
return Success(data);
|
|||
|
}
|
|||
|
/// <summary>
|
|||
|
/// 获取表单数据
|
|||
|
/// <summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult GetFormData(string keyValue, string ProjectId)
|
|||
|
{
|
|||
|
if (keyValue == GlobalObject.fakeID)
|
|||
|
{
|
|||
|
var settingTbName = ProjectSugar.TableName<ec_projectSettingsEntity>(ProjectId);
|
|||
|
var existvalue = SqlSugarHelper.Db.Queryable<ec_projectSettingsEntity>().AS(settingTbName).First(x => x.SettingName == GlobalObject.projSetting_TagNumber_CADBlockAlias);
|
|||
|
|
|||
|
var ec_propertyDataFake = new ec_propertyEntity()
|
|||
|
{
|
|||
|
PropertyID = GlobalObject.fakeID,
|
|||
|
PropertyGID = GlobalObject.fakeID,
|
|||
|
PropertyName = GlobalObject.propName_TagNumber,
|
|||
|
PropertyNameEN = GlobalObject.propName_TagNumber,
|
|||
|
PropertyType = "00001",//文本
|
|||
|
OrderID = 1,
|
|||
|
CADBlockAlias = existvalue == null ? "" : existvalue.SettingValue, //从项目设置来好了
|
|||
|
BasicGroup = 1
|
|||
|
};
|
|||
|
var jsonData2 = new
|
|||
|
{
|
|||
|
ec_property = ec_propertyDataFake,
|
|||
|
};
|
|||
|
return Success(jsonData2);
|
|||
|
}
|
|||
|
var ec_propertyData = ec_propertyIBLL.GetEntity(keyValue, ProjectId);
|
|||
|
//if (ec_propertyData.PropertyType == "00003")
|
|||
|
//{
|
|||
|
// ec_propertyData.DefaultValueEnum = ec_propertyData.DefaultValue;
|
|||
|
// ec_propertyData.DefaultValue = "";
|
|||
|
//}
|
|||
|
var jsonData = new
|
|||
|
{
|
|||
|
ec_property = ec_propertyData,
|
|||
|
};
|
|||
|
return Success(jsonData);
|
|||
|
}
|
|||
|
/// <summary>
|
|||
|
/// 获取左侧树形数据(属性的tree,根据属性组进行分组)
|
|||
|
/// <summary>
|
|||
|
/// <param name="ProjectId">项目ID</param>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult GetTree(string ProjectId)
|
|||
|
{
|
|||
|
var data = ec_propertyIBLL.GetTree(ProjectId);
|
|||
|
return Success(data);
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// 获取属性树形数据(第一级为属性组,第二级为属性)。
|
|||
|
/// 场合:
|
|||
|
/// 如,报表输出时的参数xue
|
|||
|
/// </summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult GetPropTreeData(string ProjectId, bool isShowCheck = false)
|
|||
|
{
|
|||
|
var data = ec_propertyIBLL.GetPropTreeData(ProjectId, isShowCheck);
|
|||
|
return Success(data);
|
|||
|
}
|
|||
|
/// <summary>
|
|||
|
/// 命名规则里用的数据,某个对象分类下拥有的属性
|
|||
|
/// </summary>
|
|||
|
/// <param name="ProjectId"></param>
|
|||
|
/// <param name="ObjectTypeId"></param>
|
|||
|
/// <param name="isShowCheck">前端是否会显示勾选框</param>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult GetPropTreeDataByType(string ProjectId, string ObjectTypeId, bool isShowCheck = false, string exceptionProp = "")
|
|||
|
{
|
|||
|
var data = ec_propertyIBLL.GetPropTreeDataByType(ProjectId, ObjectTypeId, isShowCheck, exceptionProp);
|
|||
|
return Success(data);
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// 获取对象类型属性表数据
|
|||
|
/// <summary>
|
|||
|
/// <param name="objectTypeID">对象类型ID</param>
|
|||
|
/// <param name="ProjectId">项目ID</param>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult GetObjectTypePById(string objectTypeID, string ProjectId)
|
|||
|
{
|
|||
|
var data = ec_objecttypepIBLL.GetObjectTypePById(objectTypeID, ProjectId);//网页端
|
|||
|
return Success(data);
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// 获取一个
|
|||
|
/// <summary>
|
|||
|
/// <param name="objectTypeID">对象类型ID</param>
|
|||
|
/// <param name="ProjectId">项目ID</param>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult GetObjectTypeP(string objectTypeID, string propertyID, string ProjectId)
|
|||
|
{
|
|||
|
var tb = ProjectSugar.TableName<ec_objecttypepEntity>(ProjectId);
|
|||
|
var data = SqlSugarHelper.Db.Queryable<ec_objecttypepEntity>().AS(tb).First(x => x.ObjectTypeID == objectTypeID && x.PropertyID == propertyID);
|
|||
|
return Success(data);
|
|||
|
}
|
|||
|
/// <summary>
|
|||
|
/// 获取属性反向关联的对象类型表数据
|
|||
|
/// <summary>
|
|||
|
/// <param name="propertyID">属性ID</param>
|
|||
|
/// <param name="ProjectId">项目ID</param>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpGet]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult GetObjectTypeAssigned2Property(string propertyID, string ProjectId)
|
|||
|
{
|
|||
|
var data = ec_objecttypepIBLL.GetPropertyByObjectId(propertyID, ProjectId);
|
|||
|
return Success(data);
|
|||
|
}
|
|||
|
#endregion
|
|||
|
|
|||
|
#region 提交数据
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// 删除实体数据
|
|||
|
/// <param name="keyValue">主键</param>
|
|||
|
/// <summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpPost]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult DeleteForm(string keyValue, string ProjectId)
|
|||
|
{
|
|||
|
ec_propertyIBLL.DeleteEntity(keyValue, ProjectId);
|
|||
|
return Success("删除成功!");
|
|||
|
}
|
|||
|
/// <summary>
|
|||
|
/// 保存实体数据(新增、修改)
|
|||
|
/// <param name="keyValue">主键</param>
|
|||
|
/// <summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpPost]
|
|||
|
[ValidateAntiForgeryToken]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult SaveForm(string keyValue, string strEntity, string ProjectId)
|
|||
|
{
|
|||
|
ec_propertyEntity entity = strEntity.ToObject<ec_propertyEntity>();
|
|||
|
//if (entity.PropertyType == "00003")
|
|||
|
//{
|
|||
|
// entity.DefaultValue = entity.DefaultValueEnum;
|
|||
|
//}
|
|||
|
//属性名称不允许重复
|
|||
|
if (keyValue == GlobalObject.fakeID)
|
|||
|
{
|
|||
|
var settringData = new ec_projectSettingsEntity();
|
|||
|
settringData.SettingName = GlobalObject.projSetting_TagNumber_CADBlockAlias;
|
|||
|
settringData.SettingValue = entity.CADBlockAlias;
|
|||
|
//只是为了保存位号的CAD
|
|||
|
var settingTbName = ProjectSugar.TableName<ec_projectSettingsEntity>(ProjectId);
|
|||
|
var existvalue = SqlSugarHelper.Db.Queryable<ec_projectSettingsEntity>().AS(settingTbName).First(x => x.SettingName == GlobalObject.projSetting_TagNumber_CADBlockAlias);
|
|||
|
if (existvalue == null)
|
|||
|
{
|
|||
|
settringData.SettingID = Guid.NewGuid().ToString();
|
|||
|
|
|||
|
SqlSugarHelper.Db.Insertable<ec_projectSettingsEntity>(settringData).AS(settingTbName).ExecuteCommand();
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
settringData.SettingID = existvalue.SettingID;
|
|||
|
SqlSugarHelper.Db.Updateable<ec_projectSettingsEntity>(settringData).AS(settingTbName).ExecuteCommand();
|
|||
|
}
|
|||
|
return Success("保存成功!");
|
|||
|
}
|
|||
|
var data = ec_propertyIBLL.GetList("{ProjectId:\"" + ProjectId + "\"}").ToList();
|
|||
|
data = data.FindAll(x => x.PropertyName == entity.PropertyName);
|
|||
|
if (data != null && data.Count > 0)
|
|||
|
{
|
|||
|
if (!string.IsNullOrEmpty(keyValue))
|
|||
|
{
|
|||
|
data = data.FindAll(x => x.PropertyID != keyValue);
|
|||
|
if (data != null && data.Count > 0)
|
|||
|
{
|
|||
|
return Fail("属性名称不允许重复!");
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
return Fail("属性名称不允许重复!");
|
|||
|
}
|
|||
|
}
|
|||
|
ec_propertyIBLL.SaveEntity(keyValue, entity, ProjectId);
|
|||
|
return Success("保存成功!");
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// 保存对象类型属性表数据(新增)
|
|||
|
/// <param name="objectTypeID">对象类型ID</param>
|
|||
|
/// <summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpPost]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult SaveObjectTypeP(string objectTypeID, string ProjectId, [FromBody] List<ec_objecttypepEntity> entityList)
|
|||
|
{
|
|||
|
//var asyncContent = Request.Content.ReadAsStringAsync().Result;
|
|||
|
//List<ec_enginedataEntity> entitys = asyncContent.ToObject<List<ec_enginedataEntity>>();
|
|||
|
|
|||
|
//List<ec_objecttypepEntity> entityList = strEntity.ToList<ec_objecttypepEntity>();
|
|||
|
if (entityList == null)
|
|||
|
{
|
|||
|
return Success("");
|
|||
|
}
|
|||
|
ec_objecttypepIBLL.SaveEntityByObjectType(objectTypeID, entityList, ProjectId);
|
|||
|
return Success("保存成功!");
|
|||
|
}
|
|||
|
|
|||
|
/// <summary>
|
|||
|
/// 网页上,属性界面去配置需要关联到哪些对象类型
|
|||
|
/// <param name="propertyID">属性ID</param>
|
|||
|
/// <summary>
|
|||
|
/// <returns></returns>
|
|||
|
[HttpPost]
|
|||
|
[AjaxOnly]
|
|||
|
public ActionResult SavePropertyO(string propertyID, string objectTypeIDs, string ProjectId)
|
|||
|
{
|
|||
|
ec_objecttypepIBLL.SaveEntityByProperty(propertyID, objectTypeIDs, ProjectId);
|
|||
|
return Success("保存成功!");
|
|||
|
}
|
|||
|
|
|||
|
#endregion
|
|||
|
|
|||
|
}
|
|||
|
}
|