agents.java 47 KB

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