Visit.cs 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. using Abp;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Data;
  5. using System.Linq;
  6. using System.Text;
  7. using System.Threading.Tasks;
  8. namespace DataTransmission.Joint
  9. {
  10. public class Visit
  11. {
  12. private readonly CommonTool tool = new CommonTool();
  13. public DataTable GetVisit(string flowId) {
  14. var conn = tool.GetConSqlServer();
  15. var appraiseSql = $@"SELECT * FROM dbo.Flow18_AppraiseList FA
  16. LEFT JOIN dbo.Flow15_PubList FP ON FA.FALT_FlowID =FP.FPLT_FlowID
  17. LEFT JOIN dbo.Flow18_AppraiseExpand FAE ON FAE.FAED_FALTID = FA.FALT_ListID
  18. LEFT JOIN SYS15_DICT SD ON SD.SDICT_Key='Appraise_DissType' AND SD.SDICT_PID!=0 AND FAE.FAED_DissTypeID = SD.SDICT_ID
  19. LEFT JOIN dbo.SYS09_BMDIR SBM ON FA.FALT_AppBMID = SBM.SBM_ID
  20. WHERE FALT_FlowID = {flowId} AND FA.FALT_AppFlag = 1 ";
  21. return tool.GetDataTable(appraiseSql, conn);
  22. }
  23. public string GetVisitSql(DataTable data,DataRow row,string VisitId, string orderId,DataTable org,DataTable user) {
  24. var num = 0;
  25. var pgVisitSql = string.Empty;
  26. var pgVisitDetail = string.Empty;
  27. foreach (DataRow item in data.Rows)
  28. {
  29. DataRow ogrRow = org.AsEnumerable().First(x => x.Field<int?>("oldBmid").ToString() == item["FALT_AppBMID"].ToString());
  30. var VisitOrgCode = string.IsNullOrEmpty(ogrRow?["Id"].ToString()) ? item["FALT_AppBMID"].ToString() : ogrRow?["Id"].ToString();
  31. if (num == 0)
  32. {
  33. var EmployeeId = item["FALT_UserID"].ToString();
  34. try
  35. {
  36. DataRow userRow = user.AsEnumerable().First(x => x.Field<int?>("OldUserId").ToString() == item["FALT_UserID"].ToString());
  37. EmployeeId = string.IsNullOrEmpty(userRow?["Id"].ToString()) ? "NULL" : userRow?["Id"].ToString();
  38. }
  39. catch (Exception e)
  40. {
  41. tool.SaveLog(" VisitMessage :" + e.Message + ";" + row["FALT_UserID"].ToString() + " ;", 1);
  42. }
  43. //主表
  44. pgVisitSql = $@"INSERT INTO ""public"".""order_visit"" (""Id"", ""No"", ""OrderId"", ""VisitState"", ""VisitType"", ""PublishTime"", ""EmployeeId"", ""IsPutThrough"", ""VisitTime"", ""CreationTime"", ""CreatorOrgId"",
  45. ""CreatorId"", ""AreaId"", ""NowEvaluate"", ""AgainState"", ""CreatorOrgName"", ""CreatorName"", ""CreatorOrgLevel"", ""IsCanHandle"", ""CallId"", ""IsCanAiVisit"", ""FirstVisitTime"", ""LastVisitTime"",
  46. ""AiVisitCount"") VALUES ('{VisitId}', '{row["FSH_Code"].ToString().Trim()}', '{orderId}', 30, 10, '{item["FPLT_PubDate"]}', '{EmployeeId}', 't', '{item["FALT_CallDate"]}', '{item["FALT_InsertDate"]}', '', '', '', '{{""Key"":""{GetSatisfaction(item["FALT_AppTypeName"].ToString())}"",""Value"":""{item["FALT_AppTypeName"]}""}}',
  47. 0, '市民热线服务系统', '', 0, 'f', NULL, 'f', NULL, NULL, 0);
  48. ";
  49. var seatsDetailId = SequentialGuidGenerator.Instance.Create().ToString("D");
  50. //明细表
  51. pgVisitDetail = $@"INSERT INTO ""public"".""order_visit_detail"" (""Id"", ""VisitId"", ""VoiceEvaluate"", ""SeatEvaluate"", ""OrgProcessingResults"", ""OrgNoSatisfiedReason"", ""OrgHandledAttitude"", ""VisitContent"", ""VisitOrgCode"",
  52. ""VisitOrgName"", ""CreationTime"", ""CreatorOrgId"", ""CreatorId"", ""AreaId"", ""VisitTarget"", ""CreatorOrgName"", ""CreatorName"", ""CreatorOrgLevel"") VALUES
  53. ('{seatsDetailId}', '{VisitId}', {GetSatisfaction(item["FALT_SeatsTypeName"].ToString())}, {GetSatisfaction(item["FALT_SeatsTypeName"].ToString())}, NULL, NULL,NULL,
  54. '{item["FALT_ZxRemark"]}', NULL,NULL, '{item["FALT_InsertDate"]}', '', '', '', 10, '市民热线服务系统', '', 1)";
  55. }
  56. //部门
  57. var bmDetailId = SequentialGuidGenerator.Instance.Create().ToString("D");
  58. var OrgNoSatisfiedReason = "NULL";
  59. if ((item["FALT_AppTypeName"].ToString() == "非常不满意" || item["FALT_AppTypeName"].ToString() == "非常不满意") && !string.IsNullOrEmpty(item["SDICT_Name"].ToString()))
  60. {
  61. OrgNoSatisfiedReason = $@" '[{{""Key"":""{GetDissatisfiedReason(item["SDICT_Name"].ToString())}"",""Value"":""{item["SDICT_Name"].ToString()}""}}]'";
  62. }
  63. pgVisitDetail += $@",('{bmDetailId}', '{VisitId}', NULL, NULL, '{{""Key"":""{GetSatisfaction(item["FALT_AppTypeName"].ToString())}"",""Value"":""{item["FALT_AppTypeName"]}""}}',{OrgNoSatisfiedReason},
  64. '{{""Key"":""{GetSatisfaction(item["FALT_AppTypeBName"].ToString())}"",""Value"":""{item["FALT_AppTypeBName"]}""}}', '{item["FALT_ZxRemark"]}', '{VisitOrgCode}', '{item["SBM_Name"]}', '{item["FALT_InsertDate"]}', '', '', '', 20, '市民热线服务系统', '', 1)";
  65. num++;
  66. }
  67. pgVisitDetail += ";";
  68. return pgVisitSql + pgVisitDetail;
  69. }
  70. private string GetSatisfaction(string name)
  71. {
  72. var satisfaction = string.Empty;
  73. switch (name)
  74. {
  75. case "非常不满意":
  76. satisfaction = "1";
  77. break;
  78. case "不满意":
  79. satisfaction = "2";
  80. break;
  81. case "一般":
  82. satisfaction = "3";
  83. break;
  84. case "满意":
  85. satisfaction = "4";
  86. break;
  87. case "非常满意":
  88. satisfaction = "5";
  89. break;
  90. case "未接通":
  91. satisfaction = "6";
  92. break;
  93. case "未做评价":
  94. satisfaction = "7";
  95. break;
  96. case "视为满意":
  97. satisfaction = "-1";
  98. break;
  99. case "默认满意":
  100. satisfaction = "0";
  101. break;
  102. default:
  103. satisfaction = "-2";
  104. break;
  105. }
  106. return satisfaction;
  107. }
  108. private string GetDissatisfiedReason(string name)
  109. {
  110. var dissatisfiedReason = string.Empty;
  111. switch (name)
  112. {
  113. case "回复敷衍":
  114. dissatisfiedReason = "1";
  115. break;
  116. case "办件推诿":
  117. dissatisfiedReason = "2";
  118. break;
  119. case "未有效处理工单问题":
  120. dissatisfiedReason = "3";
  121. break;
  122. case "处理案件力度不够":
  123. dissatisfiedReason = "4";
  124. break;
  125. case "未与市民联系":
  126. dissatisfiedReason = "5";
  127. break;
  128. case "阶段性回复":
  129. dissatisfiedReason = "6";
  130. break;
  131. case "未回复":
  132. dissatisfiedReason = "7";
  133. break;
  134. default:
  135. dissatisfiedReason = "8";
  136. break;
  137. }
  138. return dissatisfiedReason;
  139. }
  140. }
  141. }