463 lines
18 KiB
C#
463 lines
18 KiB
C#
|
|
using APT.BaseData.Domain.ApiModel;
|
|||
|
|
using APT.BaseData.Domain.Entities;
|
|||
|
|
using APT.BaseData.Domain.Entities.FM;
|
|||
|
|
using APT.BaseData.Domain.Enums;
|
|||
|
|
using APT.BaseData.Domain.IServices.FM;
|
|||
|
|
using APT.Infrastructure.Core;
|
|||
|
|
using APT.MS.Domain.Entities.FO;
|
|||
|
|
using APT.MS.Domain.Entities.SC;
|
|||
|
|
using APT.MS.Domain.Enums;
|
|||
|
|
using APT.Utility;
|
|||
|
|
using Microsoft.AspNetCore.Mvc;
|
|||
|
|
using System;
|
|||
|
|
using System.Collections.Generic;
|
|||
|
|
using System.Data;
|
|||
|
|
using System.IO;
|
|||
|
|
using System.Linq;
|
|||
|
|
|
|||
|
|
namespace APT.SC.WebApi.Controllers.Api.SC
|
|||
|
|
{
|
|||
|
|
[Route("api/SC/SCMTContent")]
|
|||
|
|
public class SCMTContentController : AuthorizeApiController<T_SC_MT_CONTENT>
|
|||
|
|
{
|
|||
|
|
public SCMTContentController()
|
|||
|
|
{
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
///
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="entity"></param>
|
|||
|
|
/// <returns></returns>
|
|||
|
|
[HttpPost, Route("FullUpdate")]
|
|||
|
|
public JsonActionResult<bool> FullUpdate([FromBody] T_SC_MT_CONTENT entity)
|
|||
|
|
{
|
|||
|
|
return SafeExecute<bool>(() =>
|
|||
|
|
{
|
|||
|
|
if (entity.MEETINGTYPE == 0)
|
|||
|
|
{
|
|||
|
|
throw new Exception("请选择会议类型!");
|
|||
|
|
}
|
|||
|
|
if (!entity.CONTENTNAME_ID.HasValue)
|
|||
|
|
{
|
|||
|
|
throw new Exception("请选择会议内容!");
|
|||
|
|
}
|
|||
|
|
if (entity.CHECKTYPE == 0)
|
|||
|
|
{
|
|||
|
|
throw new Exception("请选择题型!");
|
|||
|
|
}
|
|||
|
|
if (string.IsNullOrEmpty(entity.TITLE))
|
|||
|
|
{
|
|||
|
|
throw new Exception("请填写题目!");
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
var check = GetEntity<T_SC_MT_CONTENT>(e => e.ID != entity.ID && e.MEETINGTYPE == entity.MEETINGTYPE && e.CONTENTNAME_ID == entity.CONTENTNAME_ID && e.CHECKTYPE == entity.CHECKTYPE && e.TITLE == entity.TITLE && !e.IS_DELETED);
|
|||
|
|
if (check != null)
|
|||
|
|
{
|
|||
|
|
throw new Exception("会议意见基础库不能重复!");
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
var contentDetail = entity.Nav_ListContentDeal;
|
|||
|
|
this.UnifiedCommit(() =>
|
|||
|
|
{
|
|||
|
|
if (entity != null)
|
|||
|
|
UpdateEntityNoCommit(entity); //保存主表
|
|||
|
|
//保存新的
|
|||
|
|
if (contentDetail != null && contentDetail.Any())
|
|||
|
|
this.BantchSaveEntityNoCommit(contentDetail);
|
|||
|
|
});
|
|||
|
|
return true;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|
#region 自定义数据导入
|
|||
|
|
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 获取导入数据
|
|||
|
|
/// 参考 [Route("api/PF/Import")]
|
|||
|
|
/// </summary>
|
|||
|
|
/// <returns></returns>
|
|||
|
|
[HttpPost, Route("GetImportData")]
|
|||
|
|
public JsonActionResult<ImportDataModel> GetImportData()
|
|||
|
|
{
|
|||
|
|
return SafeExecute<ImportDataModel>(() =>
|
|||
|
|
{
|
|||
|
|
var httpRequest = this.HttpContext.Request;
|
|||
|
|
string orgIdStr = httpRequest.Form["OrgId"];// 获取 组织
|
|||
|
|
Guid? orgId = null;
|
|||
|
|
if (!string.IsNullOrEmpty(orgIdStr))
|
|||
|
|
orgId = new Guid(orgIdStr);
|
|||
|
|
else
|
|||
|
|
return null;
|
|||
|
|
ImportDataModel result = new ImportDataModel();
|
|||
|
|
var dic = Path.Combine(System.AppContext.BaseDirectory, "tempImportFiles");
|
|||
|
|
if (!Directory.Exists(dic))
|
|||
|
|
Directory.CreateDirectory(dic);
|
|||
|
|
foreach (var key in httpRequest.Form.Files) // 文件键
|
|||
|
|
{
|
|||
|
|
var postedFile = key; // 获取文件键对应的文件对象
|
|||
|
|
string filePath = Path.Combine(dic, DateTime.Now.ToString("yyyy_MM_dd_hh_mm_ss") + "_" + postedFile.FileName);
|
|||
|
|
Byte[] fileData = new Byte[postedFile.Length];
|
|||
|
|
Stream sr = postedFile.OpenReadStream();//创建数据流对象
|
|||
|
|
sr.Read(fileData, 0, (int)postedFile.Length);
|
|||
|
|
using (FileStream fs = new FileStream(filePath, FileMode.CreateNew))
|
|||
|
|
{
|
|||
|
|
fs.Write(fileData, 0, fileData.Length);
|
|||
|
|
fs.Flush();
|
|||
|
|
fs.Close();
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
//获取数据
|
|||
|
|
Dictionary<int, int> startRowIndexs = new Dictionary<int, int>();
|
|||
|
|
startRowIndexs.Add(0, 2);//根据Excel格式数据赋值
|
|||
|
|
var dataTables = FileUtils.ReadExcelByOledb(filePath, startRowIndexs);
|
|||
|
|
string Msg = string.Empty;
|
|||
|
|
|
|||
|
|
bool isOK = InsertModel(dataTables.Tables[0], orgId.Value, ref Msg);
|
|||
|
|
|
|||
|
|
try
|
|||
|
|
{
|
|||
|
|
System.IO.File.Delete(filePath);
|
|||
|
|
}
|
|||
|
|
catch { }
|
|||
|
|
|
|||
|
|
result.Data = Msg;
|
|||
|
|
result.MessageList = new List<string> { Msg };
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
return result;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/// <summary>
|
|||
|
|
/// 数据插入
|
|||
|
|
/// </summary>
|
|||
|
|
/// <param name="dtSource"></param>
|
|||
|
|
/// <param name="OrgID"></param>
|
|||
|
|
/// <param name="Msg"></param>
|
|||
|
|
/// <param name="rowIndex"></param>
|
|||
|
|
/// <returns></returns>
|
|||
|
|
/// <exception cref="Exception"></exception>
|
|||
|
|
public bool InsertModel(DataTable dtSource, Guid OrgID, ref string Msg, int rowIndex = 1)
|
|||
|
|
{
|
|||
|
|
//会议内容 会议类型 题型 题目 选项 (开发资料 可以直接导入)
|
|||
|
|
|
|||
|
|
if (dtSource == null || dtSource.Rows.Count < rowIndex + 1)
|
|||
|
|
{
|
|||
|
|
Msg = "未获取到导入数据";
|
|||
|
|
throw new Exception(Msg);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
//5列数据
|
|||
|
|
//1、会议内容 2、会议类型 3、题型 4、题目 5、选项
|
|||
|
|
|
|||
|
|
Dictionary<int, List<int>> dicIndexEmpty = new Dictionary<int, List<int>>();
|
|||
|
|
List<int> listTypeError = new List<int>();
|
|||
|
|
List<int> listCheckTypeError = new List<int>();
|
|||
|
|
|
|||
|
|
List<string> listMeetTingType = new List<string>() { "普通会议", "文件审核会", "文件评审会", "安委会", "基层安全会" };
|
|||
|
|
List<string> listCheckType = new List<string>() { "单选", "复选" };//题型
|
|||
|
|
|
|||
|
|
Dictionary<string, SCMEETINGTYPE> dicContentName = new Dictionary<string, SCMEETINGTYPE>();
|
|||
|
|
List<string> listContentName = new List<string>();
|
|||
|
|
#region 数据判断
|
|||
|
|
|
|||
|
|
//第一行是标题 跳过
|
|||
|
|
int rowAll = dtSource.Rows.Count;
|
|||
|
|
for (int i = rowIndex; i < rowAll; i++)
|
|||
|
|
{
|
|||
|
|
#region 不能为空
|
|||
|
|
|
|||
|
|
for (int j = 0; j < 5; j++)
|
|||
|
|
{
|
|||
|
|
List<int> listi = null;
|
|||
|
|
if (string.IsNullOrEmpty(dtSource.Rows[i][j].ToString().Trim()))
|
|||
|
|
{
|
|||
|
|
if (j == 0 && i != rowIndex)
|
|||
|
|
{
|
|||
|
|
//会议内容 合并 可以为空
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
if (listi == null)
|
|||
|
|
{
|
|||
|
|
listi = new List<int>();
|
|||
|
|
}
|
|||
|
|
listi.Add(j);
|
|||
|
|
}
|
|||
|
|
if (listi == null)
|
|||
|
|
continue;
|
|||
|
|
dicIndexEmpty.Add(i, listi);//有空的 直接添加
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
#endregion
|
|||
|
|
|
|||
|
|
#region 会议类型错误
|
|||
|
|
|
|||
|
|
if (!listMeetTingType.Contains(dtSource.Rows[i][1]) && !string.IsNullOrEmpty(dtSource.Rows[i][1].ToString().Trim()))
|
|||
|
|
{
|
|||
|
|
listTypeError.Add(i);
|
|||
|
|
}
|
|||
|
|
else
|
|||
|
|
{
|
|||
|
|
if (dicIndexEmpty.Count < 1 && listTypeError.Count < 1 && listCheckTypeError.Count < 1)
|
|||
|
|
{
|
|||
|
|
//有错 就不添加了
|
|||
|
|
if (!string.IsNullOrEmpty(dtSource.Rows[i][0].ToString().Trim()) && !dicContentName.ContainsKey(dtSource.Rows[i][0].ToString().Trim()))
|
|||
|
|
{
|
|||
|
|
dicContentName.Add(dtSource.Rows[i][0].ToString().Trim(), GetMeetingType(dtSource.Rows[i][1].ToString().Trim()).Value);
|
|||
|
|
listContentName.Add(dtSource.Rows[i][0].ToString().Trim());
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
#endregion
|
|||
|
|
|
|||
|
|
#region 题型错误
|
|||
|
|
|
|||
|
|
if (!listCheckType.Contains(dtSource.Rows[i][2]) && !string.IsNullOrEmpty(dtSource.Rows[i][2].ToString()))
|
|||
|
|
{
|
|||
|
|
listCheckTypeError.Add(i);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
#endregion
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
#endregion
|
|||
|
|
|
|||
|
|
#region 提示
|
|||
|
|
|
|||
|
|
// 行:1,列:2、3、4;行:2,列:1 不能为空!
|
|||
|
|
if (dicIndexEmpty.Count > 0)
|
|||
|
|
{
|
|||
|
|
int colIndex = 0;
|
|||
|
|
foreach (var item in dicIndexEmpty)
|
|||
|
|
{
|
|||
|
|
Msg += "行:" + item.Key + ",列:";
|
|||
|
|
colIndex = 0;
|
|||
|
|
foreach (var itemVal in item.Value)
|
|||
|
|
{
|
|||
|
|
Msg += (colIndex > 0 ? "、" : "") + itemVal;
|
|||
|
|
colIndex++;
|
|||
|
|
}
|
|||
|
|
Msg += ";";
|
|||
|
|
}
|
|||
|
|
Msg = Msg.Substring(0, Msg.Length - 1) + "不能为空!";
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
//行 会议类型错误
|
|||
|
|
string strTypeError = "";
|
|||
|
|
if (listTypeError.Count > 0)
|
|||
|
|
{
|
|||
|
|
strTypeError = "行:";
|
|||
|
|
for (int i = 0; i < listTypeError.Count; i++)
|
|||
|
|
{
|
|||
|
|
strTypeError += (i > 0 ? "、" : "") + listTypeError[i];
|
|||
|
|
}
|
|||
|
|
strTypeError += "会议类型有误!";
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
//行 会议类型错误
|
|||
|
|
string strCheckTypeError = "";
|
|||
|
|
if (listCheckTypeError.Count > 0)
|
|||
|
|
{
|
|||
|
|
strCheckTypeError = "行:";
|
|||
|
|
for (int i = 0; i < listCheckTypeError.Count; i++)
|
|||
|
|
{
|
|||
|
|
strCheckTypeError += (i > 0 ? "、" : "") + listCheckTypeError[i];
|
|||
|
|
}
|
|||
|
|
strCheckTypeError += "题型有误!";
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
if (!string.IsNullOrEmpty(strTypeError) || !string.IsNullOrEmpty(strCheckTypeError))
|
|||
|
|
{
|
|||
|
|
Msg = Msg + strTypeError + strCheckTypeError;
|
|||
|
|
}
|
|||
|
|
if (!string.IsNullOrEmpty(Msg))
|
|||
|
|
{
|
|||
|
|
throw new Exception(Msg);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
#endregion
|
|||
|
|
|
|||
|
|
#region 数据插入
|
|||
|
|
|
|||
|
|
List<T_SC_MT_CONTENT_NAME> listContentNameAdd = new List<T_SC_MT_CONTENT_NAME>();
|
|||
|
|
List<T_SC_MT_CONTENT> listContentAdd = new List<T_SC_MT_CONTENT>();
|
|||
|
|
List<T_SC_MT_CONTENT_DEAL> listContentDealAdd = new List<T_SC_MT_CONTENT_DEAL>();
|
|||
|
|
|
|||
|
|
var listModelContentName = GetEntities<T_SC_MT_CONTENT_NAME>(e => listContentName.Contains(e.NAME), null, null);
|
|||
|
|
List<T_SC_MT_CONTENT_NAME> listModelContentNames = new List<T_SC_MT_CONTENT_NAME>();
|
|||
|
|
if (listModelContentName != null && listModelContentName.Any())
|
|||
|
|
{
|
|||
|
|
listModelContentNames = listModelContentName.ToList();
|
|||
|
|
}
|
|||
|
|
DateTime dtNow = DateTime.Now;
|
|||
|
|
string strDtNow = dtNow.ToString("yyyyMMddHHmmss");
|
|||
|
|
int CONTENT_NO = 1;
|
|||
|
|
T_SC_MT_CONTENT_NAME modelName = null;
|
|||
|
|
for (int i = rowIndex; i < rowAll; i++)
|
|||
|
|
{
|
|||
|
|
if (!string.IsNullOrEmpty(dtSource.Rows[i][0].ToString().Trim()))
|
|||
|
|
{
|
|||
|
|
modelName = listModelContentNames.FirstOrDefault(e => e.NAME == dtSource.Rows[i][0].ToString().Trim() && e.MEETINGTYPE == GetMeetingType(dtSource.Rows[i][1].ToString().Trim()));
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
//空的话 保持和上一个一致
|
|||
|
|
|
|||
|
|
#region 会议内容名称
|
|||
|
|
|
|||
|
|
if (modelName == null)
|
|||
|
|
{
|
|||
|
|
modelName = new T_SC_MT_CONTENT_NAME();
|
|||
|
|
modelName.ID = Guid.NewGuid();
|
|||
|
|
modelName.CODE = strDtNow + i;
|
|||
|
|
modelName.NAME = dtSource.Rows[i][0].ToString().Trim();
|
|||
|
|
modelName.ENABLE_STATUS = FMEnableStatusEnum.启用;
|
|||
|
|
modelName.IS_DELETED = false;
|
|||
|
|
modelName.ORG_ID = OrgID;
|
|||
|
|
modelName.CREATE_TIME = dtNow;
|
|||
|
|
modelName.MEETINGTYPE = GetMeetingType(dtSource.Rows[i][1].ToString().Trim()).Value;
|
|||
|
|
//model.ENTITY_ORG_TPYE
|
|||
|
|
//model.FORM_ID
|
|||
|
|
//model.FLOW_STATUS
|
|||
|
|
//model.FLOW_SEND_STATUS
|
|||
|
|
//model.FLOW_ID
|
|||
|
|
//model.MODIFY_TIME
|
|||
|
|
//model.CREATER_ID
|
|||
|
|
//model.MODIFIER_ID
|
|||
|
|
listContentNameAdd.Add(modelName);
|
|||
|
|
listModelContentNames.Add(modelName);
|
|||
|
|
CONTENT_NO = 1;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
#endregion
|
|||
|
|
|
|||
|
|
#region 会议内容题型 题目
|
|||
|
|
|
|||
|
|
//会议 题目等 不考虑与数据库重复 直接插入
|
|||
|
|
|
|||
|
|
T_SC_MT_CONTENT modelContent = new T_SC_MT_CONTENT();
|
|||
|
|
modelContent.ID = Guid.NewGuid();
|
|||
|
|
modelContent.CODE = strDtNow + i;
|
|||
|
|
modelContent.CHECKTYPE = dtSource.Rows[i][2].ToString().Trim() == "复选" ? CHECKTYPE.Check : CHECKTYPE.TheRadio;
|
|||
|
|
modelContent.TITLE = dtSource.Rows[i][3].ToString().Trim();
|
|||
|
|
modelContent.IS_DELETED = false;
|
|||
|
|
modelContent.ORG_ID = OrgID;
|
|||
|
|
modelContent.CREATE_TIME = dtNow;
|
|||
|
|
modelContent.MEETINGTYPE = modelName.MEETINGTYPE;
|
|||
|
|
modelContent.CONTENTNAME_ID = modelName.ID;
|
|||
|
|
|
|||
|
|
modelContent.CONTENT_NO = CONTENT_NO;
|
|||
|
|
CONTENT_NO++;
|
|||
|
|
|
|||
|
|
//modelContent.ENTITY_ORG_TPYE
|
|||
|
|
//modelContent.FORM_ID
|
|||
|
|
//modelContent.FLOW_STATUS
|
|||
|
|
//modelContent.FLOW_SEND_STATUS
|
|||
|
|
//modelContent.FLOW_ID
|
|||
|
|
//modelContent.MODIFY_TIME
|
|||
|
|
//modelContent.CREATER_ID
|
|||
|
|
//modelContent.MODIFIER_ID
|
|||
|
|
|
|||
|
|
listContentAdd.Add(modelContent);//会议意见
|
|||
|
|
|
|||
|
|
#endregion
|
|||
|
|
|
|||
|
|
#region 会议选项
|
|||
|
|
|
|||
|
|
//"□安全生产法律法规与其他要求的相关规定
|
|||
|
|
//□风险控制要求
|
|||
|
|
//□事故应对措施
|
|||
|
|
//□员工的合理化建议
|
|||
|
|
//□工艺、设备安全技术改造"
|
|||
|
|
//是 / 部分 / 否
|
|||
|
|
//是 / 部分 / 否
|
|||
|
|
//是 / 部分 / 否
|
|||
|
|
//是 / 部分 / 否
|
|||
|
|
//点选,是 / 否
|
|||
|
|
//点选,是 / 否
|
|||
|
|
|
|||
|
|
string strDetails = dtSource.Rows[i][4].ToString().Trim();
|
|||
|
|
string[] details = strDetails.Split(new char[] { ' ', '/', ',', ',', '□', '点', '选', '\n' }, StringSplitOptions.RemoveEmptyEntries);
|
|||
|
|
if (details == null)
|
|||
|
|
{
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
else
|
|||
|
|
{
|
|||
|
|
for (int j = 0; j < details.Length; j++)
|
|||
|
|
{
|
|||
|
|
T_SC_MT_CONTENT_DEAL modelDetails = new T_SC_MT_CONTENT_DEAL();
|
|||
|
|
modelDetails.ID = Guid.NewGuid();
|
|||
|
|
modelDetails.CONTENT_ID = modelContent.ID;
|
|||
|
|
modelDetails.CONTENTDETAIL = details[j];
|
|||
|
|
modelDetails.PERSCORE = 0;
|
|||
|
|
modelDetails.IS_DELETED = false;
|
|||
|
|
modelDetails.ORG_ID = OrgID;
|
|||
|
|
modelDetails.CREATE_TIME = dtNow;
|
|||
|
|
modelDetails.CONTENT_DEAL_NO = (j + 1);
|
|||
|
|
//modelDetails.ENTITY_ORG_TPYE = ;
|
|||
|
|
//modelDetails.FORM_ID = ;
|
|||
|
|
//modelDetails.FLOW_STATUS = ;
|
|||
|
|
//modelDetails.FLOW_SEND_STATUS = ;
|
|||
|
|
//modelDetails.FLOW_ID = ;
|
|||
|
|
//modelDetails.MODIFY_TIME
|
|||
|
|
//modelDetails.CREATER_ID
|
|||
|
|
//modelDetails.MODIFIER_ID
|
|||
|
|
listContentDealAdd.Add(modelDetails);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
#endregion
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
#endregion
|
|||
|
|
|
|||
|
|
this.UnifiedCommit(() =>
|
|||
|
|
{
|
|||
|
|
if (listContentNameAdd != null && listContentNameAdd.Any())
|
|||
|
|
this.BantchSaveEntityNoCommit(listContentNameAdd);
|
|||
|
|
if (listContentAdd != null && listContentAdd.Any())
|
|||
|
|
this.BantchSaveEntityNoCommit(listContentAdd);
|
|||
|
|
if (listContentDealAdd != null && listContentDealAdd.Any())
|
|||
|
|
this.BantchSaveEntityNoCommit(listContentDealAdd);
|
|||
|
|
});
|
|||
|
|
Msg = "导入成功!";
|
|||
|
|
return true;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
|
|||
|
|
private SCMEETINGTYPE? GetMeetingType(string MeetingType)
|
|||
|
|
{
|
|||
|
|
SCMEETINGTYPE? result = null;
|
|||
|
|
switch (MeetingType)
|
|||
|
|
{
|
|||
|
|
case "普通会议":
|
|||
|
|
result = SCMEETINGTYPE.Ordinary;
|
|||
|
|
break;
|
|||
|
|
case "文件审核会":
|
|||
|
|
result = SCMEETINGTYPE.FileAudit;
|
|||
|
|
break;
|
|||
|
|
case "文件评审会":
|
|||
|
|
result = SCMEETINGTYPE.FileReView;
|
|||
|
|
break;
|
|||
|
|
case "安委会":
|
|||
|
|
result = SCMEETINGTYPE.SafetyBoard;
|
|||
|
|
break;
|
|||
|
|
case "基层安全会":
|
|||
|
|
result = SCMEETINGTYPE.BasicSecurity;
|
|||
|
|
break;
|
|||
|
|
default:
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
return result;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
#endregion
|
|||
|
|
|
|||
|
|
}
|
|||
|
|
}
|