鄂尔多斯-招源科技

CustomerController.cs 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  1. 
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Web;
  6. using System.Web.Mvc;
  7. using CallCenterApi.Interface.Controllers.Base;
  8. using System.Data;
  9. using CallCenter.Utility;
  10. using CallCenterApi.Common;
  11. using CallCenterApi.DB;
  12. using CallCenterApi.Interface.Models.Filter;
  13. using CallCenterApi.Interface.Models.Input;
  14. using CallCenterApi.Interface.Models.Dto;
  15. using System.Data.SqlClient;
  16. using System.Text;
  17. namespace CallCenterApi.Interface.Controllers.customer
  18. {
  19. //[Authority]
  20. public class CustomerController : BaseController
  21. {
  22. private readonly BLL.T_Cus_CustomerBase customerBaseBLL = new BLL.T_Cus_CustomerBase();
  23. private readonly BLL.T_Cus_CustomerField customerFieldBLL = new BLL.T_Cus_CustomerField();
  24. private readonly BLL.T_Cus_CustomerExpand customerExpandBLL = new BLL.T_Cus_CustomerExpand();
  25. /// <summary>
  26. /// 获取客户列表
  27. /// </summary>
  28. /// <returns></returns>
  29. public ActionResult GetList(FilterCustomer filter)
  30. {
  31. string sql = " F_DeleteFlag=0 ";
  32. DataTable dt = new DataTable();
  33. string strname = HttpUtility.UrlDecode(RequestString.GetQueryString("name"));
  34. string strtel = HttpUtility.UrlDecode(RequestString.GetQueryString("tel"));
  35. string strstarttime = HttpUtility.UrlDecode(RequestString.GetQueryString("starttime"));
  36. string strendtime = HttpUtility.UrlDecode(RequestString.GetQueryString("endtime"));
  37. //系统列+自定义列 实体
  38. var columnList = customerFieldBLL.GetList().Where(x => x.F_IsShowOnList > 0).OrderBy(x => x.F_Sort).ToList();
  39. //系统列+自定义列 字符串
  40. var headList = columnList.Select(x => x.F_Name).ToList();
  41. //自定义列字段名
  42. var customerColumnArr = columnList.Where(x => x.F_FieldType == 1).Select(x => x.F_DBFieldName).ToList();
  43. //需要搜索的自定义列
  44. var searchFieldList = columnList.Where(x => x.F_Search > 0).ToList();
  45. StringBuilder sb = new StringBuilder();
  46. if (filter.Fields.Length > 0 && filter.FieldValues.Length > 0 && filter.Fields.Length == filter.FieldValues.Length)
  47. {
  48. for (int i = 0; i < filter.Fields.Length; i++)
  49. {
  50. if (i == filter.Fields.Length - 1)
  51. {
  52. sb.Append($" {filter.Fields[i]}='{filter.FieldValues[i]}' ");
  53. continue;
  54. }
  55. sb.Append($" {filter.Fields[i]}='{filter.FieldValues[i]}', ");
  56. }
  57. }
  58. //搜索
  59. List<string> customerIdList = new List<string>();
  60. DataTable dt1 = new DataTable();
  61. if (!string.IsNullOrWhiteSpace(sb.ToString()))
  62. {
  63. dt1 = DbHelperSQL.Query($"select F_CustomerId FROM T_Cus_CustomerExpand where {sb.ToString()}").Tables[0];
  64. }
  65. else
  66. {
  67. dt1 = DbHelperSQL.Query($"select F_CustomerId FROM T_Cus_CustomerExpand ").Tables[0];
  68. }
  69. foreach (DataRow row in dt1.Rows)
  70. {
  71. customerIdList.Add(row["F_CustomerId"].ToString());
  72. }
  73. //获取主表数据
  74. var customerListAll = customerBaseBLL.DataTableToList(customerBaseBLL.GetList(sql).Tables[0]);
  75. var customerList = customerListAll.Where(x => customerIdList.Contains(x.F_Id))
  76. .Skip((filter.PageIndex - 1) * filter.PageSize).Take(filter.PageSize).ToList();
  77. //获取主表数据ID
  78. var customerIdArr = customerList.OrderByDescending(x => x.F_AddTime).Select(x => "'" + x.F_Id + "'").ToArray();
  79. DataTable customerExpandList = new DataTable();
  80. if (customerIdArr.Length > 0)
  81. {
  82. //根据主表数据ID获取自定义字段数据
  83. customerExpandList = DbHelperSQL.Query($"select F_CustomerId, {string.Join(",", customerColumnArr)} from T_Cus_CustomerExpand where F_CustomerId IN ({string.Join(",", customerIdArr)}) ").Tables[0];
  84. }
  85. else
  86. {
  87. customerExpandList = DbHelperSQL.Query("SET FMTONLY ON;SELECT * FROM T_Cus_CustomerExpand ;SET FMTONLY OFF; ").Tables[0];
  88. }
  89. //组织数据
  90. List<CustomerDto> dataList = new List<CustomerDto>();
  91. foreach (var c in customerList)
  92. {
  93. var model = new CustomerDto();
  94. model.id = c.F_Id;
  95. var e = customerExpandList.Select($"F_CustomerId='{c.F_Id}'");
  96. List<string> strList1 = new List<string>()
  97. {
  98. c.F_Name, c.F_PhoneNum1, c.F_PhoneNum2, c.F_Address, c.F_CusType.ToString(), c.F_AddAgentId.ToString(), c.F_AddTime.ToString("yyyy-MM-dd HH:mm:ss"), c.F_Remark
  99. };
  100. List<string> strList2 = new List<string>();
  101. if (e.Count() > 0)
  102. {
  103. foreach (var item in customerColumnArr)
  104. {
  105. strList2.Add(e[0][item].ToString());
  106. }
  107. }
  108. else
  109. {
  110. foreach (var item in customerColumnArr)
  111. {
  112. strList2.Add("");
  113. }
  114. }
  115. strList1.AddRange(strList2);
  116. model.dataarr = strList1;
  117. dataList.Add(model);
  118. }
  119. return Success("获取成功", new
  120. {
  121. headlist = headList,
  122. datalist = dataList,
  123. search = searchFieldList
  124. });
  125. }
  126. /// <summary>
  127. /// 获取客户信息
  128. /// </summary>
  129. /// <returns></returns>
  130. public ActionResult GetCustomer(string id)
  131. {
  132. if (string.IsNullOrWhiteSpace(id))
  133. return Error("参数错误");
  134. var userModel = customerBaseBLL.GetModel(id);
  135. if (userModel == null)
  136. return Error("获取失败,该客户信息不存在");
  137. //系统列+自定义列 实体
  138. var columnList = customerFieldBLL.GetList().Where(x => x.F_IsShowOnList > 0).OrderBy(x => x.F_Sort).ToList();
  139. //系统列+自定义列 字符串
  140. var headList = columnList.Select(x => x.F_Name).ToList();
  141. //系统列+自定义列 字段名
  142. var nameList = columnList.Select(x => x.F_DBFieldName).ToList();
  143. //自定义列字段名
  144. var customerColumnArr = columnList.Where(x => x.F_FieldType == 1).Select(x => x.F_DBFieldName).ToList();
  145. //自定义列值
  146. var expand = DbHelperSQL.Query("select top 1 * from T_Cus_CustomerExpand where F_CustomerId=@F_CustomerId", new SqlParameter("@F_CustomerId", userModel.F_Id)).Tables[0].Rows[0];
  147. List<string> strList1 = new List<string>()
  148. {
  149. userModel.F_Name, userModel.F_PhoneNum1, userModel.F_PhoneNum2, userModel.F_Address, userModel.F_CusType.ToString(), userModel.F_AddAgentId.ToString(), userModel.F_AddTime.ToString("yyyy-MM-dd HH:mm:ss"), userModel.F_Remark
  150. };
  151. List<string> strList2 = new List<string>();
  152. foreach (var item in customerColumnArr)
  153. {
  154. strList2.Add(expand[item].ToString());
  155. }
  156. strList1.AddRange(strList2);
  157. return Success("获取成功", new
  158. {
  159. namelist = nameList,
  160. headlist = headList,
  161. datalist = strList1
  162. });
  163. }
  164. /// <summary>
  165. /// 添加/修改客户信息
  166. /// </summary>
  167. /// <returns></returns>
  168. public ActionResult AddCustomer(CustomerInput input)
  169. {
  170. Model.T_Cus_CustomerBase model = new Model.T_Cus_CustomerBase();
  171. BLL.T_Cus_CustomerBase bll = new BLL.T_Cus_CustomerBase();
  172. if (!string.IsNullOrWhiteSpace(input.Id))
  173. {
  174. model.F_Name = input.Name;
  175. model.F_Address = input.Address;
  176. model.F_CusType = input.CusType;
  177. model.F_YHFKId = input.YHFKId;
  178. model.F_YHFKName = input.YHFKName;
  179. model.F_Remark = input.Remark;
  180. model.F_PhoneNum1 = input.PhoneNum1;
  181. model.F_PhoneNum2 = input.PhoneNum2;
  182. model.F_AddAgentId = CurrentUser.UserData.F_UserId;
  183. model.F_DeptId = CurrentUser.UserData.F_DeptId;
  184. if (bll.Add(model) > 0)
  185. return Success("新增成功!");
  186. return Error("新增失败!");
  187. }
  188. model = bll.GetModel(input.Id);
  189. if (model == null)
  190. return Error("修改失败,该客户信息不存在");
  191. model.F_Name = input.Name;
  192. model.F_Address = input.Address;
  193. model.F_CusType = input.CusType;
  194. model.F_YHFKId = input.YHFKId;
  195. model.F_YHFKName = input.YHFKName;
  196. model.F_Remark = input.Remark;
  197. model.F_PhoneNum1 = input.PhoneNum1;
  198. model.F_PhoneNum2 = input.PhoneNum2;
  199. if (bll.Update(model))
  200. return Success("修改成功!");
  201. return Error("修改失败!");
  202. }
  203. /// <summary>
  204. /// 删除客户
  205. /// </summary>
  206. /// <param name="ids"></param>
  207. /// <returns></returns>
  208. public ActionResult DelCustomer(string[] ids)
  209. {
  210. if (ids != null && ids.Length > 0)
  211. {
  212. string idd = " ";
  213. foreach (string str in ids)
  214. {
  215. idd += str + ",";
  216. }
  217. string sql = "update T_Cus_CustomerBase set F_DeleteFlag=1 where F_Id in(" + idd.TrimEnd(',') + ")";
  218. if (!string.IsNullOrEmpty(idd.Trim()))
  219. return Error("请选择用户");
  220. if (DbHelperSQL.ExecuteSql(sql) > 0)
  221. return Success("设置成功");
  222. return Error("设置失败");
  223. }
  224. return Error("获取参数失败");
  225. }
  226. public ActionResult GetCustomerField()
  227. {
  228. //系统列+自定义列 实体
  229. var columnList = customerFieldBLL.GetList().Where(x => x.F_IsShowOnList > 0).OrderBy(x => x.F_Sort).ToList();
  230. //系统列+自定义列 字符串
  231. var headList = columnList.Select(x => x.F_Name).ToList();
  232. //系统列+自定义列 字段名
  233. var nameList = columnList.Select(x => x.F_DBFieldName).ToList();
  234. //自定义列字段名
  235. var customerColumnArr = columnList.Where(x => x.F_FieldType == 1).Select(x => x.F_DBFieldName).ToList();
  236. return Success("", new
  237. {
  238. namelist = nameList,
  239. headlist = headList,
  240. });
  241. }
  242. }
  243. }