agents.java 47 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861
  1. package restcontroller.webmanage.sale.agents;
  2. import beans.accountbalance.Accountbalance;
  3. import beans.data.BatchDeleteErr;
  4. import beans.datacontrllog.DataContrlLog;
  5. import beans.dataextend.DataExtend;
  6. import beans.datatag.DataTag;
  7. import beans.datateam.DataTeam;
  8. import beans.enterprise.Enterprise;
  9. import beans.salearea.SaleArea;
  10. import com.alibaba.fastjson.JSONArray;
  11. import com.alibaba.fastjson.JSONObject;
  12. import common.Controller;
  13. import common.YosException;
  14. import common.annotation.*;
  15. import common.data.*;
  16. import org.apache.commons.lang.StringUtils;
  17. import org.apache.poi.ss.usermodel.CellStyle;
  18. import org.apache.poi.ss.usermodel.DataFormat;
  19. import org.apache.poi.xssf.usermodel.*;
  20. import restcontroller.R;
  21. import restcontroller.webmanage.executorService.Executor;
  22. import restcontroller.webmanage.sale.enterprisesaleclass.EnterpriseSaleClass;
  23. import restcontroller.webmanage.sale.enterprisetradefield.EnterpriseTradeField;
  24. import restcontroller.webmanage.sale.salearea.salearea;
  25. import java.math.BigDecimal;
  26. import java.util.ArrayList;
  27. import java.util.Arrays;
  28. import java.util.HashMap;
  29. @API(title = "经销商管理")
  30. public class agents extends Controller {
  31. public agents(JSONObject content) throws YosException {
  32. super(content);
  33. }
  34. @API(title = "经销商列表查询", apiversion = R.ID20230427101304.v1.class)
  35. @CACHEING
  36. public String query_agentList() throws YosException {
  37. /*
  38. 过滤条件设置
  39. */
  40. StringBuffer where = new StringBuffer(" 1=1 ");
  41. if (content.containsKey("where")) {
  42. JSONObject whereObject = content.getJSONObject("where");
  43. if (whereObject.containsKey("condition") && !"".equals(whereObject.getString("condition"))) {
  44. where.append(" and(");
  45. where.append("t2.phonenumber like'%").append(whereObject.getString("condition")).append("%' ");
  46. where.append("or t2.enterprisename like'%").append(whereObject.getString("condition")).append("%' ");
  47. where.append("or t1.agentnum like'%").append(whereObject.getString("condition")).append("%' ");
  48. where.append(")");
  49. }
  50. if (whereObject.containsKey("status") && !"".equals(whereObject.getString("status"))) {
  51. where.append(" and t1.status='").append(whereObject.getString("status")).append("' ");
  52. }
  53. }
  54. SQLFactory sqlFactory = new SQLFactory(this, "经销商列表查询", pageSize, pageNumber, pageSorting);
  55. sqlFactory.addParameter_SQL("where", where);
  56. sqlFactory.addParameter("siteid", siteid);
  57. Rows rows = dbConnect.runSqlQuery(sqlFactory.getSQL());
  58. return getSucReturnObject().setData(rows).toString();
  59. }
  60. @API(title = "经销商详情查询")
  61. @CACHEING
  62. @QUERYBYROWINDEX(uniquecolumnname = "sa_agentsid",listapiversion = {R.ID20221011144903.v1.class})
  63. public String query_agentMain() throws YosException {
  64. long sa_agentsid = content.getLongValue("sa_agentsid");
  65. SQLFactory sqlFactory = new SQLFactory(this, "经销商详情查询");
  66. sqlFactory.addParameter("sa_agentsid", sa_agentsid);
  67. sqlFactory.addParameter("siteid", siteid);
  68. Rows agentRows = dbConnect.runSqlQuery(sqlFactory.getSQL());
  69. Rows tradefieldidRows = dbConnect.runSqlQuery("select t1.sys_enterpriseid,t1.sa_agentsid,t1.sa_saleareaid,t1.tradefield,t3.areaname,t3.sa_saleareaids from sys_enterprise_tradefield t1 LEFT JOIN sa_salearea t3 ON t3.sa_saleareaid = t1.sa_saleareaid and t3.siteid = t1.siteid where t1.siteid ='" + siteid + "'");
  70. RowsMap rowsMap = tradefieldidRows.toRowsMap("sys_enterpriseid");
  71. for (Row agentRow : agentRows) {
  72. if (rowsMap.containsKey(agentRow.getString("sys_enterpriseid"))) {
  73. Rows rows = rowsMap.get(agentRow.getString("sys_enterpriseid"));
  74. if (rows.isNotEmpty()) {
  75. agentRow.put("tradefield", rows.toJsonArray("tradefield"));
  76. agentRow.put("areaname", rows.toJsonArray("areaname"));
  77. agentRow.put("sa_saleareaid", rows.get(0).getString("sa_saleareaid"));
  78. agentRow.put("sa_saleareaids", rows.get(0).getJSONArray("sa_saleareaids"));
  79. }
  80. } else {
  81. agentRow.put("tradefield", new JSONArray());
  82. agentRow.put("areaname", new JSONArray());
  83. agentRow.put("sa_saleareaid", "");
  84. agentRow.put("sa_saleareaids", new JSONArray());
  85. }
  86. agentRow.put("hrs", getEnterpriseHrs(agentRow.getLong("sys_enterpriseid")));
  87. SQLFactory salersql = new SQLFactory(this, "经销商详情查询_业务员查询");
  88. salersql.addParameter("siteid", siteid);
  89. salersql.addParameter_in("sa_saleareaid", SaleArea.getSaleAreaIds(this, agentRow.getLong("sys_enterpriseid")));
  90. Rows salerrows = dbConnect.runSqlQuery(salersql.getSQL());
  91. agentRow.put("salers", salerrows);
  92. }
  93. return getSucReturnObject().setData(agentRows.isNotEmpty() ? agentRows.get(0) : new Row()).toString();
  94. }
  95. @API(title = "经销商新增修改",intervaltime = 200)
  96. @CACHEING_CLEAN(apiClass = {EnterpriseTradeField.class}, cms = {@cm(clazz = agents.class, method = {"query_agentList", "query_agentMain"}), @cm(clazz = salearea.class, method = {"query_agent"}), @cm(clazz = salearea.class, method = {"query_agent"})})
  97. public String insertormodify_agent() throws YosException {
  98. long sa_agentsid = content.getLongValue("sa_agentsid");//新增时传0
  99. long sys_enterpriseid = content.getLongValue("sys_enterpriseid");
  100. long parentid = content.getLongValue("parentid");
  101. String agentnum = content.getString("agentnum", "sa_agents");
  102. String type = content.getString("type", "sa_agents");
  103. String signdate = content.getStringValue("signdate");
  104. long isallsale = content.getLongValue("isallsale");
  105. if (parentid != 0 && dbConnect.runSqlQuery("select * from sa_agents where siteid='" + siteid + "' and sa_agentsid=" + parentid).isEmpty()) {
  106. return getErrReturnObject().setErrMsg("指定的上级商户不存在").toString();
  107. }
  108. Rows rows = dbConnect.runSqlQuery("select sa_agentsid,sys_enterpriseid from sa_agents where agentnum='" + agentnum + "'");
  109. ArrayList<String> sqllist = new ArrayList<>();
  110. SQLFactory sqlFactory = new SQLFactory(this, "经销商新增");
  111. if (sa_agentsid <= 0 || dbConnect.runSqlQuery("select sa_agentsid from sa_agents where sa_agentsid=" + sa_agentsid).isEmpty()) {
  112. if (dbConnect.runSqlQuery("select sa_agentsid from sa_agents where sys_enterpriseid=" + sys_enterpriseid).isNotEmpty()) {
  113. return getErrReturnObject().setErrMsg("当前商户已经创建经销商档案,不可重复创建").toString();
  114. } else if (rows.isNotEmpty()) {
  115. return getErrReturnObject().setErrMsg("重复经销商编号,无法创建").toString();
  116. }
  117. sa_agentsid = createTableID("sa_agents");
  118. addAccount(sys_enterpriseid);
  119. Rows customersRows = dbConnect.runSqlQuery("SELECT sa_customersid from sa_customers WHERE sys_enterpriseid =" + sys_enterpriseid + " and siteid = '" + siteid + "'");
  120. if (customersRows.isNotEmpty()) {
  121. Long id = customersRows.get(0).getLong("sa_customersid");
  122. ArrayList<Long> userids = DataTeam.queryTeamRow(this, "sa_customers", id).toArrayList("userid", new ArrayList<>());
  123. Executor.sendEml(this, "customers_agent_add", id, userids);
  124. }
  125. } else {
  126. if (rows.isNotEmpty()) {
  127. if (rows.get(0).getLong("sa_agentsid") != sa_agentsid || rows.get(0).getLong("sys_enterpriseid") != sys_enterpriseid) {
  128. return getErrReturnObject().setErrMsg("重复经销商编号,无法修改").toString();
  129. }
  130. }
  131. sqlFactory = new SQLFactory(this, "经销商修改");
  132. }
  133. sqlFactory.addParameter("siteid", siteid);
  134. sqlFactory.addParameter("sa_agentsid", sa_agentsid);
  135. sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  136. sqlFactory.addParameter("username", username);
  137. sqlFactory.addParameter("changeuserid", userid);
  138. sqlFactory.addParameter("agentnum", agentnum);
  139. sqlFactory.addParameter("type", type);
  140. sqlFactory.addParameter("parentid", parentid == 0 ? "null" : String.valueOf(parentid));
  141. sqlFactory.addParameter("signdate", signdate.equals("") ? "null" : signdate);
  142. sqlFactory.addParameter("isservice", content.getLongValue("isservice", 0L));
  143. sqlFactory.addParameter("priceadjustment", content.getBigDecimalValue("priceadjustment"));
  144. sqllist.add(sqlFactory.getSQL());
  145. //扩展字段
  146. String erpagentnum = content.getStringValue("erpagentnum");
  147. String sql = "SELECT * from sys_dataextend WHERE ownertable='sys_enterprise' and ownerid=" + sys_enterpriseid + " and siteid = '" + siteid + "'";
  148. Rows extendRows = dbConnect.runSqlQuery(sql);
  149. Long sys_dataextendid = 0L;
  150. if (extendRows.isEmpty()) {
  151. sys_dataextendid = createTableID("sys_dataextend");
  152. sqlFactory = new SQLFactory(this, "经销商扩展字段新增");
  153. } else {
  154. sys_dataextendid = extendRows.get(0).getLong("sys_dataextendid");
  155. sqlFactory = new SQLFactory(this, "经销商扩展字段更新");
  156. }
  157. sqlFactory.addParameter("siteid", siteid);
  158. sqlFactory.addParameter("username", username);
  159. sqlFactory.addParameter("userid", userid);
  160. sqlFactory.addParameter("sys_dataextendid", sys_dataextendid);
  161. sqlFactory.addParameter("ownerid", sys_enterpriseid);
  162. sqlFactory.addParameter("ownertable", "sys_enterprise");
  163. sqlFactory.addParameter("erpagentnum", erpagentnum);
  164. sqllist.add(sqlFactory.getSQL());
  165. sqlFactory = new SQLFactory(this, "商户档案修改");
  166. sqlFactory.addParameter("limitreturnday", content.getLongValue("limitreturnday"));
  167. sqlFactory.addParameter("freefreightamount", content.getBigDecimalValue("freefreightamount"));
  168. //开票节点(1:订单审核:2:发货)
  169. sqlFactory.addParameter("invoicingpoint", content.getLongValue("invoicingpoint") == 0 ? 2 : content.getLongValue("invoicingpoint"));
  170. //是否需要经营授权,默认1
  171. sqlFactory.addParameter("saleclassauth", content.getBooleanValue("saleclassauth") == false ? 0 : 1);
  172. sqlFactory.addParameter("grade", content.getLongValue("grade"));
  173. sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  174. sqlFactory.addParameter("siteid", siteid);
  175. sqlFactory.addParameter("username", username);
  176. sqlFactory.addParameter("changeuserid", userid);
  177. sqllist.add(sqlFactory.getSQL());
  178. //企业信息同步到【我的客户】,并将该客户打上经销商标签,
  179. Rows customersRows = dbConnect.runSqlQuery("SELECT sa_customersid from sa_customers WHERE sys_enterpriseid =" + sys_enterpriseid + " and siteid = '" + siteid + "'");
  180. Long sa_customersid = 0L;
  181. if (customersRows.isNotEmpty()) {
  182. sa_customersid = customersRows.get(0).getLong("sa_customersid");
  183. sqlFactory = new SQLFactory(this, "客户更新");
  184. } else {
  185. sa_customersid = createTableID("sa_customers");
  186. sqlFactory = new SQLFactory(this, "客户新增");
  187. }
  188. Row enterpriseRow = Enterprise.getEnterprise(this, sys_enterpriseid);
  189. sqlFactory.addParameter("siteid", siteid);
  190. sqlFactory.addParameter("userid", userid);
  191. sqlFactory.addParameter("username", username);
  192. sqlFactory.addParameter("sa_customersid", sa_customersid);
  193. //上级客户ID
  194. sqlFactory.addParameter("parentid", "null");
  195. //合作企业档案ID
  196. sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  197. //客户类型
  198. sqlFactory.addParameter("type", "经销商(客户)");
  199. //客户池(公海池)ID
  200. sqlFactory.addParameter("sa_customerpoolid", 0);
  201. //客户来源
  202. sqlFactory.addParameter("source", "经销商同步");
  203. sqlFactory.addParameter("customergrade", "null");
  204. sqlFactory.addParameter("ispublic", 0);
  205. sqlFactory.addParameter("name", enterpriseRow.getString("enterprisename"));
  206. sqlFactory.addParameter("province", enterpriseRow.getString("province"));
  207. sqlFactory.addParameter("city", enterpriseRow.getString("city"));
  208. sqlFactory.addParameter("county", enterpriseRow.getString("county"));
  209. sqlFactory.addParameter("address", enterpriseRow.getString("address"));
  210. sqlFactory.addParameter("phonenumber", enterpriseRow.getString("phonenumber"));
  211. sqllist.add(sqlFactory.getSQL());
  212. JSONArray tradefields = content.getJSONArray("tradefields");
  213. Long sa_saleareaid = content.getLong("sa_saleareaid");
  214. sqllist.add("DELETE FROM sys_enterprise_tradefield WHERE sa_agentsid=" + sa_agentsid + " AND siteid = '" + siteid + "'");
  215. if (tradefields != null && !tradefields.isEmpty()) {
  216. for (Object object : tradefields) {
  217. String tradefield = String.valueOf(object);
  218. sqlFactory = new SQLFactory(this, "企业领域授权_新增");
  219. sqlFactory.addParameter("siteid", siteid);
  220. sqlFactory.addParameter("userid", userid);
  221. sqlFactory.addParameter("tradefield", tradefield);
  222. sqlFactory.addParameter("tradefieldmx", "");
  223. sqlFactory.addParameter("sa_saleareaid", sa_saleareaid);
  224. sqlFactory.addParameter("hrid", content.getLongValue("hrid"));
  225. sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  226. sqlFactory.addParameter("sa_agentsid", sa_agentsid);
  227. sqlFactory.addParameter("sys_enterprise_tradefieldid", createTableID("sys_enterprise_tradefield"));
  228. sqllist.add(sqlFactory.getSQL());
  229. }
  230. }
  231. dbConnect.runSqlUpdate(sqllist);
  232. content.put("sa_agentsid", sa_agentsid);
  233. //打经销商标签
  234. DataTag.createTag(this, "sa_customers", sa_customersid, "经销商");
  235. return query_agentMain();
  236. }
  237. @API(title = "经销商状态变更", apiversion = R.ID20230212101703.v1.class)
  238. @CACHEING_CLEAN(cms = {@cm(clazz = agents.class, method = {"query_agentList", "query_agentMain"}),
  239. @cm(clazz = EnterpriseSaleClass.class, method = {"queryList"})}, apiversions = {R.ID20221011144903.class, R.ID20221012164402.class})
  240. public String changeStatus() throws YosException {
  241. String status = content.getString("status");
  242. ArrayList<String> sqllist = new ArrayList<>();
  243. JSONArray array = content.getJSONArray("sa_agentsids");
  244. for (Object o : array) {
  245. long sa_agentsid = Long.parseLong(o.toString());
  246. sqllist.add("update sa_agents set status='" + status + "' where sa_agentsid=" + sa_agentsid);
  247. Rows customersRows = dbConnect.runSqlQuery("SELECT sa_customersid from sa_customers WHERE sys_enterpriseid in (SELECT sys_enterpriseid from sa_agents WHERE sa_agentsid=" + sa_agentsid + " and siteid='" + siteid + "' ) and siteid='" + siteid + "'");
  248. if (customersRows.isNotEmpty()) {
  249. Long sa_customersid = customersRows.get(0).getLong("sa_customersid");
  250. if (status.equals("启用")) {
  251. DataTag.createTag(this, "sa_customers", sa_customersid, "经销商");
  252. } else {
  253. DataTag.deleteTag(this, "sa_customers", sa_customersid, "经销商");
  254. }
  255. }
  256. }
  257. dbConnect.runSqlUpdate(sqllist);
  258. return getSucReturnObject().toString();
  259. }
  260. @API(title = "商户作废", apiversion = R.ID20221011145003.v1.class)
  261. @CACHEING_CLEAN(cms = {@cm(clazz = agents.class, method = {"query_agentList", "query_agentMain"}), @cm(clazz = salearea.class, method = {"query_agent"})})
  262. public String delete_agent() throws YosException {
  263. JSONArray sa_agentsids = content.getJSONArray("sa_agentsids");
  264. BatchDeleteErr batchDeleteErr = BatchDeleteErr.create(this, sa_agentsids.size());
  265. ArrayList<String> list = new ArrayList<>();
  266. ArrayList<Long> delagentsidList = new ArrayList<>();
  267. for (Object o : sa_agentsids) {
  268. long sa_agentsid = Long.parseLong(o.toString());
  269. Rows userRows = dbConnect.runSqlQuery("SELECT userid,t1.sys_enterpriseid FROM sys_enterprise_hr t1 INNER JOIN sa_agents t2 ON t2.sys_enterpriseid=t1.sys_enterpriseid WHERE t2.siteid='" + siteid + "' and t2.sa_agentsid='" + sa_agentsid + "'");
  270. ArrayList<String> useridlist = userRows.toArrayList("userid");
  271. useridlist.add("0");
  272. SQLFactory sqlFactory = new SQLFactory("sql:select * from sys_userrequestlog where userid!=0 and userid in $userid$");
  273. sqlFactory.addParameter_in("userid", useridlist);
  274. Rows logRows = dbConnect.runSqlQuery(sqlFactory.getSQL());
  275. if (logRows.isNotEmpty()) {
  276. batchDeleteErr.addErr(sys_enterpriseid, "该商户下属账号存在访问记录,不可进行作废操作");
  277. continue;
  278. }
  279. list.add("update sa_agents set status='作废' where siteid='" + siteid + "' and sa_agentsid=" + sa_agentsid);
  280. String replace = Arrays.toString(useridlist.toArray()).replace("[", "(").replace("]", ")");
  281. list.add("update sys_users set status='INACTIVE' where userid in" + replace);
  282. list.add(DataContrlLog.createLog(this, "sa_agents", sa_agentsid, "作废", "作废经销商至回收站").getSQL());
  283. delagentsidList.add(sa_agentsid);
  284. // {
  285. // SQLFactory deletesql = new SQLFactory("sql:delete from sa_agents where siteid='" + siteid + "' and sa_agentsid=" + sa_agentsid);
  286. // list.add(deletesql.getSQL());
  287. // }
  288. // {
  289. // SQLFactory deletesql = new SQLFactory("sql:DELETE from sys_enterprise_hr WHERE sys_enterpriseid in (SELECT sys_enterpriseid FROM sa_agents WHERE sa_agentsid = " + sa_agentsid + " AND siteid = '" + siteid + "')");
  290. // list.add(deletesql.getSQL());
  291. // }
  292. // if (useridlist.size() > 0) {
  293. // {
  294. // SQLFactory deletesql = new SQLFactory("sql:delete from sys_users where userid in $userid$");
  295. // deletesql.addParameter_in("userid", useridlist);
  296. // list.add(deletesql.getSQL());
  297. // }
  298. // {
  299. // SQLFactory deletesql = new SQLFactory("sql:delete from sys_usersite where userid in $userid$");
  300. // deletesql.addParameter_in("userid", useridlist);
  301. // list.add(deletesql.getSQL());
  302. // }
  303. // {
  304. // SQLFactory deletesql = new SQLFactory("sql:delete from sys_userrole where userid in $userid$");
  305. // deletesql.addParameter_in("userid", useridlist);
  306. // list.add(deletesql.getSQL());
  307. // }
  308. // }
  309. // //删除经销商标签
  310. // Row agentRow = getAgentByAgentid(sa_agentsid);
  311. // Long sys_enterpriseid = agentRow.isEmpty() ? 0 : agentRow.getLong("sys_enterpriseid");
  312. // if (sys_enterpriseid > 0) {
  313. // list.add("DELETE from sys_datatag WHERE tag='经销商' and ownertable='sa_customers' and siteid = '" + siteid + "' and ownerid in (SELECT sa_customersid FROM sa_customers WHERE sys_enterpriseid = " + sys_enterpriseid + " and siteid='" + siteid + "')");
  314. // }
  315. }
  316. dbConnect.runSqlUpdate(list);
  317. DataExtend.createDeleteReasonSql(this, "sa_agents", delagentsidList, content.getStringValue("deletereason"));
  318. return batchDeleteErr.getReturnObject().toString();
  319. }
  320. @API(title = "经销商联系人信息及地址信息新增修改", apiversion = R.ID20221009155703.v1.class)
  321. @CACHEING_CLEAN(apiversions = R.ID20221009155803.v1.class)
  322. public String insertormodify_agentEnterpriseContacts() throws YosException {
  323. long contactsid = content.getLongValue("contactsid");//新增时传0
  324. long sys_enterpriseid = content.getLongValue("sys_enterpriseid");
  325. String name = content.getString("name", "sys_enterprise_contacts");
  326. String sex = content.getString("sex", "sys_enterprise_contacts");
  327. String depname = content.getString("depname");
  328. String position = content.getString("position");
  329. long isleader = content.getLongValue("isleader");
  330. String birthday = content.getStringValue("birthday");
  331. String phonenumber = content.getString("phonenumber");
  332. String email = content.getString("email");
  333. String province = content.getString("province");
  334. String city = content.getString("city");
  335. String county = content.getString("county");
  336. String remarks = content.getString("remarks");
  337. String address = content.getString("address");
  338. long workaddress = content.getLongValue("workaddress");
  339. boolean isdefault = content.getBooleanValue("isdefault");
  340. ArrayList<String> sqllist = new ArrayList<>();
  341. if (contactsid <= 0 || dbConnect.runSqlQuery("select contactsid from sys_enterprise_contacts where contactsid=" + contactsid).isEmpty()) {
  342. contactsid = createTableID("sys_enterprise_contacts");
  343. SQLFactory sqlFactory = new SQLFactory(this, "联系人信息新增");
  344. sqlFactory.addParameter("siteid", siteid);
  345. sqlFactory.addParameter("contactsid", contactsid);
  346. sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  347. sqlFactory.addParameter("name", name);
  348. sqlFactory.addParameter("sex", sex);
  349. sqlFactory.addParameter("depname", depname);
  350. sqlFactory.addParameter("position", position);
  351. sqlFactory.addParameter("isleader", isleader);
  352. sqlFactory.addParameter("birthday", birthday.equals("") ? "null" : birthday);
  353. sqlFactory.addParameter("phonenumber", phonenumber);
  354. sqlFactory.addParameter("email", email);
  355. sqlFactory.addParameter("province", province);
  356. sqlFactory.addParameter("city", city);
  357. sqlFactory.addParameter("county", county);
  358. sqlFactory.addParameter("remarks", remarks);
  359. sqlFactory.addParameter("address", address);
  360. sqlFactory.addParameter("workaddress", workaddress);
  361. sqlFactory.addParameter("userid", userid);
  362. if (workaddress == 1) {
  363. sqlFactory.addParameter("isdefault", isdefault);
  364. if (isdefault) {
  365. sqllist.add("update sys_enterprise_contacts set isdefault=0 where contactsid !=" + contactsid + " and sys_enterpriseid=" + sys_enterpriseid);
  366. }
  367. } else {
  368. sqlFactory.addParameter("isdefault", 0);
  369. }
  370. sqllist.add(sqlFactory.getSQL());
  371. content.put("sys_enterpriseid", sys_enterpriseid);
  372. } else {
  373. SQLFactory sqlFactory = new SQLFactory(this, "联系人信息修改");
  374. sqlFactory.addParameter("siteid", siteid);
  375. sqlFactory.addParameter("contactsid", contactsid);
  376. sqlFactory.addParameter("name", name);
  377. sqlFactory.addParameter("sex", sex);
  378. sqlFactory.addParameter("depname", depname);
  379. sqlFactory.addParameter("position", position);
  380. sqlFactory.addParameter("isleader", isleader);
  381. sqlFactory.addParameter("birthday", birthday.equals("") ? "null" : birthday);
  382. sqlFactory.addParameter("phonenumber", phonenumber);
  383. sqlFactory.addParameter("email", email);
  384. sqlFactory.addParameter("province", province);
  385. sqlFactory.addParameter("city", city);
  386. sqlFactory.addParameter("county", county);
  387. sqlFactory.addParameter("remarks", remarks);
  388. sqlFactory.addParameter("address", address);
  389. sqlFactory.addParameter("workaddress", workaddress);
  390. sqlFactory.addParameter("userid", userid);
  391. if (workaddress == 1) {
  392. sqlFactory.addParameter("isdefault", isdefault);
  393. if (isdefault) {
  394. sqllist.add("update sys_enterprise_contacts set isdefault=0 where contactsid !=" + contactsid + " and sys_enterpriseid=" + sys_enterpriseid);
  395. }
  396. } else {
  397. sqlFactory.addParameter("isdefault", 0);
  398. }
  399. sqllist.add(sqlFactory.getSQL());
  400. }
  401. dbConnect.runSqlUpdate(sqllist);
  402. return getSucReturnObject().toString();
  403. }
  404. @API(title = "联系人信息列表查询", apiversion = R.ID20221009155803.v1.class)
  405. @CACHEING
  406. public String query_agentEnterpriseContactsList() throws YosException {
  407. /*
  408. 过滤条件设置
  409. */
  410. long sys_enterpriseid = content.getLongValue("sys_enterpriseid");
  411. StringBuffer where = new StringBuffer(" 1=1 ");
  412. if (content.containsKey("where")) {
  413. JSONObject whereObject = content.getJSONObject("where");
  414. if (whereObject.containsKey("condition") && !"".equals(whereObject.getString("condition"))) {
  415. where.append(" and(");
  416. where.append("t1.phonenumber like'%").append(whereObject.getString("condition")).append("%' ");
  417. where.append("or t1.name like'%").append(whereObject.getString("condition")).append("%' ");
  418. where.append(")");
  419. }
  420. if (whereObject.containsKey("workaddress") && !"".equals(whereObject.getString("workaddress"))) {
  421. where.append(" and t1.workaddress='" + whereObject.getString("workaddress") + "' ");
  422. }
  423. }
  424. SQLFactory sqlFactory = new SQLFactory(this, "联系人信息列表查询", pageSize, pageNumber, pageSorting);
  425. sqlFactory.addParameter_SQL("where", where);
  426. sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  427. sqlFactory.addParameter("siteid", siteid);
  428. Rows rows = dbConnect.runSqlQuery(sqlFactory.getSQL());
  429. return getSucReturnObject().setData(rows).toString();
  430. }
  431. @API(title = "查询订单收货人信息", apiversion = R.ID20230220002602.v1.class)
  432. @CACHEING
  433. public String queryList() throws YosException {
  434. /*
  435. 过滤条件设置
  436. */
  437. long sys_enterpriseid = content.getLongValue("sys_enterpriseid");
  438. StringBuffer where = new StringBuffer(" 1=1 ");
  439. if (content.containsKey("where")) {
  440. JSONObject whereObject = content.getJSONObject("where");
  441. if (whereObject.containsKey("condition") && !"".equals(whereObject.getString("condition"))) {
  442. where.append(" and(");
  443. where.append("t1.phonenumber like'%").append(whereObject.getString("condition")).append("%' ");
  444. where.append("or t1.name like'%").append(whereObject.getString("condition")).append("%' ");
  445. where.append(")");
  446. }
  447. }
  448. SQLFactory sqlFactory = new SQLFactory(this, "收货人列表查询");
  449. sqlFactory.addParameter_SQL("where", where);
  450. sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  451. sqlFactory.addParameter("siteid", siteid);
  452. Rows rows = dbConnect.runSqlQuery(sqlFactory.getSQL());
  453. return getSucReturnObject().setData(rows).toString();
  454. }
  455. @API(title = "联系人信息删除", apiversion = R.ID20221009155903.v1.class)
  456. @CACHEING_CLEAN(apiversions = R.ID20221009155803.v1.class)
  457. public String delete_agentEnterpriseContacts() throws YosException {
  458. long contactsid = content.getLongValue("contactsid");
  459. Rows rows = dbConnect.runSqlQuery("select contactsid,ifnull(isdefault,0) isdefault from sys_enterprise_contacts where contactsid=" + contactsid);
  460. if (!rows.isEmpty()) {
  461. if (rows.get(0).getBoolean("isdefault")) {
  462. return getErrReturnObject().setErrMsg("该地址信息为默认地址,无法删除").toString();
  463. }
  464. }
  465. dbConnect.runSqlUpdate("update sys_enterprise_contacts set deleted=1 where contactsid=" + contactsid);
  466. return getSucReturnObject().toString();
  467. }
  468. @API(title = "经销商账户余额查询", apiversion = R.ID20221009160003.v1.class)
  469. @CACHEING
  470. public String query_agentaccountbalance() throws YosException {
  471. long sys_enterpriseid = content.getLongValue("sys_enterpriseid");
  472. // SQLFactory sqlFactory = new SQLFactory(this, "经销商账户余额查询");
  473. // sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  474. // sqlFactory.addParameter("siteid", siteid);
  475. // Rows agentaccountbalanceRows = dbConnect.runSqlQuery(sqlFactory.getSQL());
  476. // if (!agentaccountbalanceRows.isEmpty()) {
  477. // for (Row row : agentaccountbalanceRows) {
  478. // row.put("balance", row.getBigDecimal("balance"));
  479. // row.put("creditquota", row.getBigDecimal("creditquota"));
  480. // }
  481. // }
  482. BigDecimal rebateBalance = Accountbalance.getRebateBalance(this, sys_enterpriseid);
  483. Rows rows = dbConnect.runSqlQuery("SELECT sa_accountclassid from sa_accountclass WHERE siteid = '" + siteid + "' and isrebate = 1");
  484. if (rows.isNotEmpty()) {
  485. Long sa_accountclassid = rows.get(0).getLong("sa_accountclassid");
  486. rows = dbConnect.runSqlQuery("SELECT * from sa_accountbalance WHERE sys_enterpriseid = " + sys_enterpriseid + " and siteid='" + siteid + "' and sa_accountclassid=" + sa_accountclassid);
  487. if (rows.isNotEmpty()) {
  488. Long sa_accountbalanceid = rows.get(0).getLong("sa_accountbalanceid");
  489. dbConnect.runSqlUpdate("UPDATE sa_accountbalance SET balance=" + rebateBalance + " WHERE sa_accountbalanceid= '" + sa_accountbalanceid + "' and siteid='" + siteid + "'");
  490. }
  491. }
  492. rows = dbConnect.runSqlQuery("SELECT accountno,accountname,sa_accountclassid,isrebate from sa_accountclass WHERE siteid = '" + siteid + "' and isused = 1");
  493. Rows balanceRows = dbConnect.runSqlQuery("SELECT sa_accountbalanceid,balance, creditquota,changeuserid,changeby,changedate,sa_accountclassid from sa_accountbalance WHERE siteid = '" + siteid + "' and sys_enterpriseid = " + sys_enterpriseid);
  494. for (Row row : rows) {
  495. row.put("sa_accountbalanceid", "");
  496. row.put("balance", "0");
  497. row.put("creditquota", "0");
  498. row.put("changeuserid", "");
  499. row.put("changeby", "");
  500. row.put("changedate", "");
  501. for (Row balanceRow : balanceRows) {
  502. if (row.getLong("sa_accountclassid") == balanceRow.getLong("sa_accountclassid")) {
  503. row.putAll(balanceRow);
  504. }
  505. }
  506. }
  507. return getSucReturnObject().setData(rows).toString();
  508. }
  509. /**
  510. * 添加默认的营销账户余额
  511. *
  512. * @return
  513. * @throws YosException
  514. */
  515. public void addAccount(Long sys_enterpriseid) throws YosException {
  516. ArrayList<String> sqlList = new ArrayList<>();
  517. Rows rows = dbConnect.runSqlQuery("SELECT sa_accountclassid from sa_accountclass WHERE isused = 1 and siteid ='" + siteid + "'");
  518. for (Row row : rows) {
  519. SQLFactory sqlFactory = new SQLFactory(this, "新增营销账户");
  520. sqlFactory.addParameter("sa_accountbalanceid", createTableID("sa_accountbalance"));
  521. sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  522. sqlFactory.addParameter("sa_accountclassid", row.getLong("sa_accountclassid"));
  523. sqlFactory.addParameter("siteid", siteid);
  524. sqlFactory.addParameter("userid", userid);
  525. sqlFactory.addParameter("username", username);
  526. sqlList.add(sqlFactory.getSQL());
  527. }
  528. dbConnect.runSqlUpdate(sqlList);
  529. }
  530. @API(title = "经销商档案导入模板下载", apiversion = R.ID20230311162904.v1.class)
  531. public String uploadAgents() throws YosException {
  532. ExcelFactory excelFactory = new ExcelFactory("货品档案导入模板");
  533. XSSFSheet sheet = excelFactory.getXssfWorkbook().createSheet("Sheet1");
  534. XSSFWorkbook xssfFWorkbook = excelFactory.getXssfWorkbook();
  535. CellStyle style = xssfFWorkbook.createCellStyle();
  536. DataFormat format = xssfFWorkbook.createDataFormat();
  537. style.setDataFormat(format.getFormat("@"));
  538. // 对单独某一列进行样式赋值,第一个参数为列数,第二个参数为样式
  539. for (int i = 0; i <= 16; i++) {
  540. sheet.setDefaultColumnStyle(i, style);
  541. }
  542. // 设置工作薄列宽
  543. ExportExcel.setBatchDetailSheetColumn1(sheet);// 设置工作薄列宽
  544. XSSFCellStyle titleCellStyle1 = ExportExcel.createTitleCellStyle1(xssfFWorkbook);
  545. XSSFCellStyle titleCellStyle2 = ExportExcel.createTitleCellStyle2(xssfFWorkbook);
  546. XSSFCellStyle titleCellStyle3 = ExportExcel.createTitleCellStyle3(xssfFWorkbook);
  547. XSSFCellStyle titleCellStyle4 = ExportExcel.createBodyCellStyle4(xssfFWorkbook);
  548. ExportExcel.batchDetail(sheet, titleCellStyle1, titleCellStyle2, titleCellStyle3, titleCellStyle4, xssfFWorkbook);
  549. Rows aa = uploadExcelToObs(excelFactory);
  550. String url = "";
  551. if (!aa.isEmpty()) {
  552. url = aa.get(0).getString("url");
  553. }
  554. return getSucReturnObject().setData(url).toString();
  555. }
  556. @API(title = "经销商档案导入", apiversion = R.ID20230311163004.v1.class)
  557. @CACHEING_CLEAN(cms = {@cm(clazz = agents.class, method = {"query_agentList", "query_agentMain"}), @cm(clazz = salearea.class, method = {"query_agent"}), @cm(clazz = salearea.class, method = {"query_agent"})})
  558. public String importAgents() {
  559. ArrayList<String> sqlList = new ArrayList<>();
  560. ExcelFactory e;
  561. try {
  562. // 华为云
  563. e = getPostExcelFactory(content.getLong("attachmentid"));
  564. // 本地
  565. //e = getPostExcelFactory();
  566. ArrayList<String> keys = new ArrayList<>();
  567. keys.add("agentnum");
  568. keys.add("enterprisename");
  569. keys.add("abbreviation");
  570. keys.add("province");
  571. keys.add("city");
  572. keys.add("county");
  573. keys.add("signdate");
  574. keys.add("contact");
  575. keys.add("phonenumber");
  576. keys.add("grade");
  577. keys.add("isservice");
  578. keys.add("type");
  579. keys.add("erpagentnum");
  580. keys.add("freefreightamount");
  581. keys.add("limitreturnday");
  582. keys.add("invoicingpoint");
  583. keys.add("saleclassauth");
  584. Rows rows = e.getSheetRows(0, keys, 3);
  585. boolean iserr = false;
  586. Rows rowserr = new Rows();
  587. Rows rowssuc = new Rows();
  588. ArrayList<String> agentsList = dbConnect.runSqlQuery("select agentnum from sa_agents where siteid='" + siteid + "'").toArrayList("agentnum");
  589. ArrayList<String> gradeList = dbConnect.runSqlQuery("select value from sys_optiontype t1 inner join sys_optiontypemx t2 on t1.optiontypeid=t2.optiontypeid where typename='agentgrade' and isused=1").toArrayList("value");
  590. RowsMap agentnumRowsMap = rows.toRowsMap("agentnum");
  591. for (Row row : rows) {
  592. if (StringUtils.isEmpty(row.getString("agentnum")) || StringUtils.isEmpty(row.getString("enterprisename")) || StringUtils.isEmpty(row.getString("grade"))) {
  593. iserr = true;
  594. row.put("msg", "错误信息:经销商编号/企业名称/企业等级不能为空");
  595. rowserr.add(row);
  596. continue;
  597. }
  598. if (agentnumRowsMap.get(row.getString("agentnum")).size() > 1) {
  599. iserr = true;
  600. row.put("msg", "错误信息:本次导入经销商档案存在重复的经销商编号");
  601. rowserr.add(row);
  602. continue;
  603. }
  604. if (agentsList.contains(row.getString("agentnum"))) {
  605. iserr = true;
  606. row.put("msg", "错误信息:经销商编号已存在");
  607. rowserr.add(row);
  608. continue;
  609. }
  610. if (!gradeList.contains(row.getString("grade"))) {
  611. iserr = true;
  612. row.put("msg", "错误信息:商户等级不存在");
  613. rowserr.add(row);
  614. }
  615. rowssuc.add(row);
  616. }
  617. if (iserr) {
  618. ExcelFactory excelFactory = new ExcelFactory("经销商导入错误信息");
  619. HashMap<String, String> map = new HashMap<String, String>();
  620. map.put("agentnum", "经销商编码");
  621. map.put("enterprisename", "企业名称");
  622. map.put("abbreviation", "经销商简称");
  623. map.put("province", "省");
  624. map.put("city", "市");
  625. map.put("county", "县");
  626. map.put("signdate", "签约日期");
  627. map.put("contact", "联系人");
  628. map.put("phonenumber", "联系电话");
  629. map.put("grade", "企业等级");
  630. map.put("isservice", "是否服务商");
  631. map.put("type", "经销商类型");
  632. map.put("erpagentnum", "erp编号");
  633. map.put("freefreightamount", "免运费金额");
  634. map.put("limitreturnday", "订单可退货天数");
  635. map.put("invoicingpoint", "是否订单审核可开票");
  636. map.put("saleclassauth", "是否授权所有营销类别");
  637. map.put("msg", "错误信息");
  638. ArrayList<String> colNameList = new ArrayList<String>();
  639. HashMap<String, Class> keytypemap = new HashMap<String, Class>();
  640. colNameList.add("agentnum");
  641. colNameList.add("enterprisename");
  642. colNameList.add("abbreviation");
  643. colNameList.add("province");
  644. colNameList.add("city");
  645. colNameList.add("county");
  646. colNameList.add("signdate");
  647. colNameList.add("contact");
  648. colNameList.add("phonenumber");
  649. colNameList.add("grade");
  650. colNameList.add("isservice");
  651. colNameList.add("type");
  652. colNameList.add("erpagentnum");
  653. colNameList.add("freefreightamount");
  654. colNameList.add("limitreturnday");
  655. colNameList.add("invoicingpoint");
  656. colNameList.add("saleclassauth");
  657. colNameList.add("msg");
  658. keytypemap.put("agentnum", String.class);
  659. keytypemap.put("enterprisename", String.class);
  660. keytypemap.put("abbreviation", String.class);
  661. keytypemap.put("province", String.class);
  662. keytypemap.put("city", String.class);
  663. keytypemap.put("county", String.class);
  664. keytypemap.put("signdate", String.class);
  665. keytypemap.put("contact", String.class);
  666. keytypemap.put("phonenumber", String.class);
  667. keytypemap.put("grade", String.class);
  668. keytypemap.put("isservice", String.class);
  669. keytypemap.put("type", String.class);
  670. keytypemap.put("erpagentnum", String.class);
  671. keytypemap.put("freefreightamount", String.class);
  672. keytypemap.put("limitreturnday", String.class);
  673. keytypemap.put("invoicingpoint", String.class);
  674. keytypemap.put("saleclassauth", String.class);
  675. keytypemap.put("msg", String.class);
  676. rowserr.setFieldList(colNameList);
  677. rowserr.setFieldTypeMap(keytypemap);
  678. addSheet(excelFactory, "Sheet1", rowserr, map);
  679. Rows aa = uploadExcelToObs(excelFactory);
  680. String url = "";
  681. if (!aa.isEmpty()) {
  682. url = aa.get(0).getString("url");
  683. }
  684. return getSucReturnObject().setData(url).toString();
  685. }
  686. if (!rowssuc.isEmpty()) {
  687. for (Row row : rowssuc) {
  688. Long sys_enterpriseid = createTableID("sys_enterprise");
  689. SQLFactory sqlFactory = new SQLFactory(this, "企业新增");
  690. sqlFactory.addParameter("siteid", siteid);
  691. sqlFactory.addParameter("userid", userid);
  692. sqlFactory.addParameter("username", username);
  693. sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  694. sqlFactory.addParameter("enterprisename", row.getString("enterprisename"));
  695. sqlFactory.addParameter("limitreturnday", row.getString("limitreturnday"));
  696. sqlFactory.addParameter("freefreightamount", row.getString("freefreightamount"));
  697. sqlFactory.addParameter("invoicingpoint", row.getString("invoicingpoint").equals("否") ? 2 : 1);
  698. sqlFactory.addParameter("abbreviation", row.getString("abbreviation"));
  699. sqlFactory.addParameter("grade", row.getString("grade"));
  700. sqlFactory.addParameter("saleclassauth", row.getString("saleclassauth").equals("否") ? 0 : 1);
  701. sqlFactory.addParameter("province", row.getString("province"));
  702. sqlFactory.addParameter("city", row.getString("city"));
  703. sqlFactory.addParameter("county", row.getString("county"));
  704. sqlFactory.addParameter("contact", row.getString("contact"));
  705. sqlFactory.addParameter("phonenumber", row.getString("phonenumber"));
  706. sqlList.add(sqlFactory.getSQL());
  707. Long sa_agentsid = createTableID("sa_agents");
  708. sqlFactory = new SQLFactory(this, "经销商导入新增");
  709. sqlFactory.addParameter("siteid", siteid);
  710. sqlFactory.addParameter("sa_agentsid", sa_agentsid);
  711. sqlFactory.addParameter("sys_enterpriseid", sys_enterpriseid);
  712. sqlFactory.addParameter("username", username);
  713. sqlFactory.addParameter("changeuserid", userid);
  714. sqlFactory.addParameter("agentnum", row.getString("agentnum"));
  715. sqlFactory.addParameter("type", row.getString("type"));
  716. sqlFactory.addParameter("parentid", 0);
  717. sqlFactory.addParameter("signdate", row.getString("signdate"));
  718. sqlFactory.addParameter("isservice", row.getString("isservice").equals("是") ? 1 : 0);
  719. sqlList.add(sqlFactory.getSQL());
  720. Long sys_dataextendid = createTableID("sys_dataextend");
  721. sqlFactory = new SQLFactory(this, "经销商扩展字段新增");
  722. sqlFactory.addParameter("siteid", siteid);
  723. sqlFactory.addParameter("userid", userid);
  724. sqlFactory.addParameter("username", username);
  725. sqlFactory.addParameter("ownerid", sys_enterpriseid);
  726. sqlFactory.addParameter("ownertable", "sys_enterprise");
  727. sqlFactory.addParameter("erpagentnum", row.getString("erpagentnum"));
  728. sqlFactory.addParameter("sys_dataextendid", sys_dataextendid);
  729. sqlList.add(sqlFactory.getSQL());
  730. sqlList.add(DataContrlLog.createLog(this, "sys_enterprise", sys_enterpriseid, "新增", "经销商档案导入").getSQL());
  731. sqlList.add(DataContrlLog.createLog(this, "sa_agents", sa_agentsid, "新增", "经销商档案导入").getSQL());
  732. }
  733. }
  734. if (!sqlList.isEmpty()) {
  735. dbConnect.runSqlUpdate(sqlList);
  736. }
  737. } catch (Exception e1) {
  738. e1.printStackTrace();
  739. return getErrReturnObject().setErrMsg(e1.getMessage()).toString();
  740. }
  741. return getSucReturnObject().toString();
  742. }
  743. public XSSFSheet addSheet(ExcelFactory excelFactory, String sheetname, Rows datarows,
  744. HashMap<String, String> titlemap) {
  745. ArrayList<String> keylist = datarows.getFieldList();
  746. XSSFSheet sheet = excelFactory.getXssfWorkbook().createSheet(sheetname);
  747. XSSFWorkbook xssfFWorkbook = excelFactory.getXssfWorkbook();
  748. XSSFCellStyle xssfCellStyle1 = xssfFWorkbook.createCellStyle();
  749. XSSFFont font = xssfFWorkbook.createFont();
  750. font.setColor((short) 0xa);
  751. font.setFontHeightInPoints((short) 12);
  752. font.setBold(true);
  753. xssfCellStyle1.setFont(font);
  754. CellStyle style = xssfFWorkbook.createCellStyle();
  755. DataFormat format = xssfFWorkbook.createDataFormat();
  756. style.setDataFormat(format.getFormat("@"));
  757. // 对单独某一列进行样式赋值,第一个参数为列数,第二个参数为样式
  758. for (int i = 0; i <= 17; i++) {
  759. sheet.setDefaultColumnStyle(i, style);
  760. }
  761. ExportExcel.setBatchDetailSheetColumn2(sheet);// 设置工作薄列宽
  762. XSSFCellStyle titleCellStyle1 = ExportExcel.createTitleCellStyle1(xssfFWorkbook);
  763. XSSFCellStyle titleCellStyle2 = ExportExcel.createTitleCellStyle2(xssfFWorkbook);
  764. XSSFCellStyle titleCellStyle3 = ExportExcel.createTitleCellStyle3(xssfFWorkbook);
  765. ExportExcel.batchDetailErr(sheet, titleCellStyle1, titleCellStyle2, titleCellStyle3, xssfFWorkbook);// 写入标题
  766. for (int n = 0; n < datarows.size(); n++) {
  767. Row row = datarows.get(n);
  768. XSSFRow datarow = sheet.createRow(n + 3);
  769. for (int i1 = 0; i1 < keylist.size(); i1++) {
  770. Class fieldclazztype = datarows.getFieldMeta(keylist.get(i1)).getFieldtype();
  771. if (fieldclazztype == Integer.class) {
  772. datarow.createCell(i1).setCellValue(row.getInteger((String) keylist.get(i1)).intValue());
  773. } else if (fieldclazztype == Long.class) {
  774. datarow.createCell(i1).setCellValue(row.getLong((String) keylist.get(i1)));
  775. } else if (fieldclazztype == Float.class) {
  776. datarow.createCell(i1).setCellValue(row.getFloat((String) keylist.get(i1)));
  777. } else if (fieldclazztype == Double.class) {
  778. datarow.createCell(i1).setCellValue(row.getDouble((String) keylist.get(i1)));
  779. } else {
  780. datarow.createCell(i1).setCellValue(row.getString((String) keylist.get(i1)));
  781. }
  782. if (i1 == 17) {
  783. datarow.getCell(i1).setCellStyle(xssfCellStyle1);
  784. }
  785. }
  786. }
  787. return sheet;
  788. }
  789. }