agents.java 50 KB

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