AitableController.java 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  1. package com.malk.eastar.controller;
  2. import com.alibaba.fastjson.JSONArray;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.malk.eastar.service.AitableService;
  5. import com.malk.eastar.service.DDCoreClient;
  6. import com.malk.eastar.service.YidaService;
  7. import com.malk.server.common.McException;
  8. import com.malk.server.common.McR;
  9. import com.malk.utils.UtilMap;
  10. import lombok.extern.slf4j.Slf4j;
  11. import org.apache.commons.lang3.StringUtils;
  12. import org.springframework.beans.factory.annotation.Autowired;
  13. import org.springframework.web.bind.annotation.PostMapping;
  14. import org.springframework.web.bind.annotation.RequestBody;
  15. import org.springframework.web.bind.annotation.RequestMapping;
  16. import org.springframework.web.bind.annotation.RestController;
  17. import java.util.HashMap;
  18. import java.util.List;
  19. import java.util.Map;
  20. @Slf4j
  21. @RestController
  22. @RequestMapping("/aitable")
  23. public class AitableController {
  24. @Autowired
  25. private AitableService aitableService;
  26. @Autowired
  27. private YidaService yidaService;
  28. @Autowired
  29. private DDCoreClient ddCoreClient;
  30. /**
  31. * 新建客户
  32. * @param data
  33. * @return
  34. */
  35. @PostMapping("/newCustomer")
  36. McR createNewCustomer(@RequestBody JSONObject data) {
  37. log.info("新建客户, {}", data);
  38. McException.assertParamException_Null(data, "yidaInstanceId");
  39. String yidaInstanceId = UtilMap.getString(data, "yidaInstanceId"); //宜搭实例ID
  40. String yidaCustomerName = UtilMap.getString(data, "yidaCustomerName"); //客户公司名(英文名)
  41. String yidaBusinessUserId = UtilMap.getString(data, "yidaBusinessUserId"); //业务userId
  42. String yidaCustomerLevel = UtilMap.getString(data, "yidaCustomerLevel"); //客户潜在等级
  43. String yidaNewOrOld = UtilMap.getString(data, "yidaNewOrOld"); //新老客户
  44. String yidaCustomerStatus = UtilMap.getString(data, "yidaCustomerStatus"); //客户情况
  45. String yidaCountryOrRegion = UtilMap.getString(data, "yidaCountryOrRegion"); //客户国家/地区
  46. List<String> yidaProductTypes = UtilMap.getList(data, "yidaProductTypes"); //主要品类
  47. Map<String,Object> fields = new HashMap<>();
  48. try {
  49. fields.put("20rO7zS",yidaCustomerName); //客户公司名【基础】
  50. fields.put("qgOhsh1",yidaCustomerLevel); //客户分级【客户】
  51. fields.put("3Y796Wb",yidaNewOrOld); //新老客户?【客户】
  52. fields.put("jIS3Gbd",yidaCustomerStatus); //客户情况
  53. fields.put("JjVfpWO",yidaCountryOrRegion); //客户国家/地区【客户】
  54. fields.put("6rCZkSN",yidaProductTypes); //客户标签【客户】
  55. if(yidaBusinessUserId != null && !yidaBusinessUserId.isEmpty()){
  56. JSONArray user = new JSONArray();
  57. JSONObject unionId = new JSONObject();
  58. unionId.put("unionId",ddCoreClient.getUnionIdByUserId(yidaBusinessUserId));
  59. user.add(unionId);
  60. fields.put("ynNC3Kq",JSONObject.toJSONString(user)); //业务【人事】
  61. }
  62. String aitableId = aitableService.querySys1CustomerIdByName(yidaCustomerName);
  63. if(aitableId == null || aitableId.isEmpty()){
  64. aitableId = aitableService.addSys1CustomerData(fields);
  65. }else{
  66. log.info("客户["+yidaCustomerName+"]在项目总表已存在,不再新增");
  67. }
  68. yidaService.updateCustomerRelatedAitableId(yidaInstanceId, aitableId);
  69. return McR.success();
  70. } catch (Exception e) {
  71. return McR.error("400",e.getMessage());
  72. }
  73. }
  74. /**
  75. * 客户已建联
  76. * @param data
  77. * @return
  78. */
  79. @PostMapping("/establishedContact")
  80. McR establishedContactCustomer(@RequestBody JSONObject data) {
  81. log.info("客户已建联, {}", data);
  82. McException.assertParamException_Null(data, "aitableId");
  83. String aitableId = UtilMap.getString(data, "aitableId");
  84. Map<String,Object> fields = new HashMap<>();
  85. try {
  86. fields.put("jIS3Gbd","已建联"); //客户情况
  87. aitableService.updateSys1CustomerData(aitableId,fields);
  88. return McR.success();
  89. } catch (Exception e) {
  90. return McR.error("400",e.getMessage());
  91. }
  92. }
  93. /**
  94. * 业务员变更
  95. * @param data
  96. * @return
  97. */
  98. @PostMapping("/chanegBusinessUser")
  99. McR changeCustomerBusinessUser(@RequestBody JSONObject data) {
  100. log.info("业务员变更, {}", data);
  101. McException.assertParamException_Null(data, "aitableId");
  102. String aitableId = UtilMap.getString(data, "aitableId");
  103. String yidaBusinessUserId = UtilMap.getString(data, "yidaBusinessUserId"); //业务userId
  104. Map<String,Object> fields = new HashMap<>();
  105. try {
  106. JSONArray user = new JSONArray();
  107. if(yidaBusinessUserId == null || yidaBusinessUserId.isEmpty()){
  108. log.info("业务userId为空,将业务置空");
  109. }else{
  110. JSONObject unionId = new JSONObject();
  111. unionId.put("unionId",ddCoreClient.getUnionIdByUserId(yidaBusinessUserId));
  112. user.add(unionId);
  113. }
  114. fields.put("ynNC3Kq",JSONObject.toJSONString(user)); //业务【人事】
  115. aitableService.updateSys1CustomerData(aitableId,fields);
  116. return McR.success();
  117. } catch (Exception e) {
  118. return McR.error("400",e.getMessage());
  119. }
  120. }
  121. /**
  122. * 客户变更
  123. * @param data
  124. * @return
  125. */
  126. @PostMapping("/changeCustomer")
  127. McR changeCustomerBasicInfo(@RequestBody JSONObject data) {
  128. log.info("客户变更, {}", data);
  129. McException.assertParamException_Null(data, "aitableId");
  130. String aitableId = UtilMap.getString(data, "aitableId");
  131. String yidaCustomerLevel = UtilMap.getString(data, "yidaCustomerLevel"); //客户潜在等级
  132. String yidaNewOrOld = UtilMap.getString(data, "yidaNewOrOld"); //新老客户
  133. Map<String,Object> fields = new HashMap<>();
  134. try {
  135. if(StringUtils.isNotEmpty(yidaCustomerLevel)){
  136. fields.put("qgOhsh1",yidaCustomerLevel); //客户分级【客户】
  137. }
  138. if(StringUtils.isNotEmpty(yidaNewOrOld)){
  139. fields.put("3Y796Wb",yidaNewOrOld); //新老客户?【客户】
  140. }
  141. aitableService.updateSys1CustomerData(aitableId,fields);
  142. return McR.success();
  143. } catch (Exception e) {
  144. return McR.error("400",e.getMessage());
  145. }
  146. }
  147. /**
  148. * 新建商机
  149. * @param data
  150. * @return
  151. */
  152. @PostMapping("/newOpportunity")
  153. McR createNewOpportunity(@RequestBody JSONObject data) {
  154. log.info("新建商机, {}", data);
  155. McException.assertParamException_Null(data, "yidaInstanceId");
  156. String yidaInstanceId = UtilMap.getString(data, "yidaInstanceId"); //宜搭实例ID
  157. String yidaProjectCode = UtilMap.getString(data, "yidaProjectCode"); //项目编号
  158. String yidaProjectName = UtilMap.getString(data, "yidaProjectName"); //项目名称
  159. String yidaOrderCompletionRate = UtilMap.getString(data, "yidaOrderCompletionRate"); //成单情况
  160. String yidaEstimatedOrderDate = UtilMap.getString(data, "yidaEstimatedOrderDate"); //预计成单日期
  161. String yidaOrderAmount = UtilMap.getString(data, "yidaOrderAmount"); //预计项目金额
  162. String aiTableCustomerID = UtilMap.getString(data, "aiTableCustomerID"); //客户AI表格映射ID
  163. String yidaCustomerName = UtilMap.getString(data, "yidaCustomerName"); //客户公司名
  164. String yidaBusinessUserId = UtilMap.getString(data, "yidaBusinessUserId"); //业务
  165. Map<String,Object> fields = new HashMap<>();
  166. try {
  167. if(yidaProjectCode==null || yidaProjectCode.isEmpty()){
  168. yidaProjectCode = yidaService.queryProjectCode(yidaInstanceId);
  169. }
  170. fields.put("zP1nHJs",yidaProjectCode); //项目编号 - S1【基础】
  171. fields.put("P3XtfD8",yidaProjectName); //项目名称 - S1【基础】
  172. fields.put("KDAelfq",yidaOrderCompletionRate); //成单情况【商机进度】
  173. fields.put("m34IbuX",Long.parseLong(yidaEstimatedOrderDate)); //预计成单日期 - S1~2【商机进度】
  174. fields.put("MYBeHPG",yidaOrderAmount); //订单金额 - S2~3【销售数据】
  175. JSONObject bidirectionalLink = new JSONObject();
  176. String[] linkedRecordIds = new String[]{aiTableCustomerID};
  177. bidirectionalLink.put("linkedRecordIds",linkedRecordIds);
  178. fields.put("F7zdGI6",bidirectionalLink); //客户公司名 - S1【基础】
  179. JSONArray user = new JSONArray();
  180. JSONObject unionId = new JSONObject();
  181. unionId.put("unionId",ddCoreClient.getUnionIdByUserId(yidaBusinessUserId));
  182. user.add(unionId);
  183. fields.put("Iz0yaro",JSONObject.toJSONString(user)); //业务 - S1【人事】
  184. String aitableId = aitableService.addSys1SaleData(fields);
  185. yidaService.updateSaleProjectRelatedAitableId(yidaInstanceId, aitableId);
  186. return McR.success();
  187. } catch (Exception e) {
  188. return McR.error("400",e.getMessage());
  189. }
  190. }
  191. /**
  192. * 销售项目变更
  193. * @param data
  194. * @return
  195. */
  196. @PostMapping("/changeOpportunity")
  197. McR changeSaleProject(@RequestBody JSONObject data) {
  198. log.info("销售项目变更, {}", data);
  199. McException.assertParamException_Null(data, "aitableId");
  200. String aitableId = UtilMap.getString(data, "aitableId");
  201. String yidaSaleProjectStatus = UtilMap.getString(data, "yidaSaleProjectStatus"); //销售项目状态
  202. String yidaOrderAmount = UtilMap.getString(data, "yidaOrderAmount"); //预计项目金额
  203. String yidaActualOrderDate = UtilMap.getString(data, "yidaActualOrderDate"); //实际成单日期
  204. Map<String,Object> fields = new HashMap<>();
  205. try {
  206. String aiTableOrderStatus = ""; //订单状态 - S1~3【商机进度】
  207. String aiTableOpportunityStage = ""; //商机阶段 - S1~3【商机进度】
  208. if(yidaSaleProjectStatus != null && !yidaSaleProjectStatus.isEmpty()){
  209. if("报价中".equals(yidaSaleProjectStatus)){
  210. aiTableOrderStatus = "2、报价中";
  211. aiTableOpportunityStage = "RFQ";
  212. }else if("提前打样 / 修图".equals(yidaSaleProjectStatus)){
  213. aiTableOrderStatus = "3、提前打样 / 修图";
  214. }else if("订单确认".equals(yidaSaleProjectStatus)){
  215. aiTableOrderStatus = "4、订单确认";
  216. aiTableOpportunityStage = "已成单";
  217. }else if("已立项".equals(yidaSaleProjectStatus)){
  218. aiTableOrderStatus = "5、已立项";
  219. }else if("暂停".equals(yidaSaleProjectStatus)){
  220. aiTableOrderStatus = "6、暂停";
  221. }else if("已完成".equals(yidaSaleProjectStatus)){
  222. aiTableOrderStatus = "7、已完成";
  223. }else if("已终止".equals(yidaSaleProjectStatus)){
  224. aiTableOrderStatus = "8、已终止";
  225. aiTableOpportunityStage = "已丢单";
  226. }
  227. fields.put("31G4UB7",aiTableOrderStatus); //订单状态 - S1~3【商机进度】
  228. if(StringUtils.isNotEmpty(aiTableOpportunityStage)){
  229. fields.put("LQF6OWD",aiTableOpportunityStage); //商机阶段 - S1~3【商机进度】
  230. }
  231. if(StringUtils.isNotEmpty(yidaActualOrderDate)){
  232. fields.put("VBsHxPE",Long.parseLong(yidaActualOrderDate)); //实际成单日期 - S3【销售数据】
  233. }
  234. if(StringUtils.isNotEmpty(yidaOrderAmount)){
  235. fields.put("MYBeHPG",Double.parseDouble(yidaOrderAmount)); //订单金额 - S2~3【销售数据】
  236. }
  237. aitableService.updateSys1SaleData(aitableId,fields);
  238. }else if(yidaOrderAmount != null && !yidaOrderAmount.isEmpty()){ //成单预测
  239. fields.put("MYBeHPG",Double.parseDouble(yidaOrderAmount)); //订单金额 - S2~3【销售数据】
  240. aitableService.updateSys1SaleData(aitableId,fields);
  241. }
  242. return McR.success();
  243. } catch (Exception e) {
  244. return McR.error("400",e.getMessage());
  245. }
  246. }
  247. }