NewOrderController.java 108 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156
  1. package com.caimei.modules.order.web;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.caimei.constants.NewPayWay;
  4. import com.caimei.dfs.image.beens.ImageUploadInfo;
  5. import com.caimei.modules.bulkpurchase.entity.BpClause;
  6. import com.caimei.modules.bulkpurchase.entity.CmFinanceCharge;
  7. import com.caimei.modules.bulkpurchase.service.BpClauseService;
  8. import com.caimei.modules.bulkpurchase.service.CmFinanceChargeService;
  9. import com.caimei.modules.bulkpurchase.service.PurchaseProductService;
  10. import com.caimei.modules.common.utils.ExcelUtil;
  11. import com.caimei.modules.common.utils.UploadUtils;
  12. import com.caimei.modules.coupon.entity.CmCouponOrderRecord;
  13. import com.caimei.modules.coupon.service.CmCouponService;
  14. import com.caimei.modules.order.dao.CmDiscernReceiptDao;
  15. import com.caimei.modules.order.dao.CmReceiptOrderRelationDao;
  16. import com.caimei.modules.order.dao.CmReturnedPurchaseDao;
  17. import com.caimei.modules.order.dao.NewOrderProductDao;
  18. import com.caimei.modules.order.entity.*;
  19. import com.caimei.modules.order.service.*;
  20. import com.caimei.modules.order.utils.OrderUtil;
  21. import com.caimei.modules.product.dao.CmPromotionDao;
  22. import com.caimei.modules.product.dao.ProductDao;
  23. import com.caimei.modules.product.entity.CmPromotion;
  24. import com.caimei.modules.product.entity.Product;
  25. import com.caimei.modules.product.entity.RepeatPurchasePrice;
  26. import com.caimei.modules.product.entity.RepeatPurchasePriceHistory;
  27. import com.caimei.modules.product.service.CmSecondHandDetailService;
  28. import com.caimei.modules.product.service.RepeatPurchasePriceHistoryService;
  29. import com.caimei.modules.product.service.RepeatPurchasePriceService;
  30. import com.caimei.modules.project.dao.ClubDao;
  31. import com.caimei.modules.project.model.ClubModel;
  32. import com.caimei.modules.sys.utils.UploadImageUtils;
  33. import com.caimei.modules.user.dao.CmUserDao;
  34. import com.caimei.modules.user.entity.*;
  35. import com.caimei.modules.user.service.CmMessageService;
  36. import com.caimei.modules.user.service.CmUserOrganizeService;
  37. import com.caimei.modules.user.service.CmUserService;
  38. import com.caimei.modules.user.service.NewCmShopService;
  39. import com.caimei.modules.user.utils.UserType;
  40. import com.caimei.po.ProductLadderPrice;
  41. import com.caimei.utils.AppKeys;
  42. import com.caimei.utils.AppUtils;
  43. import com.caimei.utils.MathUtil;
  44. import com.caimei.utils.StringUtil;
  45. import com.google.common.collect.Lists;
  46. import com.thinkgem.jeesite.common.config.Global;
  47. import com.thinkgem.jeesite.common.mapper.JsonMapper;
  48. import com.thinkgem.jeesite.common.persistence.Page;
  49. import com.thinkgem.jeesite.common.utils.Encodes;
  50. import com.thinkgem.jeesite.common.utils.StringUtils;
  51. import com.thinkgem.jeesite.common.web.BaseController;
  52. import org.apache.commons.collections.CollectionUtils;
  53. import org.apache.poi.hssf.usermodel.*;
  54. import org.apache.poi.hssf.util.HSSFColor;
  55. import org.apache.poi.ss.util.CellRangeAddress;
  56. import org.apache.shiro.authz.annotation.RequiresPermissions;
  57. import org.springframework.beans.factory.annotation.Autowired;
  58. import org.springframework.stereotype.Controller;
  59. import org.springframework.ui.Model;
  60. import org.springframework.web.bind.annotation.*;
  61. import org.springframework.web.servlet.mvc.support.RedirectAttributes;
  62. import javax.annotation.Resource;
  63. import javax.servlet.http.HttpServletRequest;
  64. import javax.servlet.http.HttpServletResponse;
  65. import java.io.ByteArrayOutputStream;
  66. import java.math.BigDecimal;
  67. import java.text.SimpleDateFormat;
  68. import java.util.*;
  69. import java.util.stream.IntStream;
  70. /**
  71. * 订单模块重构-订单Controller
  72. *
  73. * @author lwt
  74. * @version 2018-07-23
  75. */
  76. @Controller
  77. @RequestMapping(value = "${adminPath}/order")
  78. public class NewOrderController extends BaseController {
  79. @Resource
  80. private NewOrderService newOrderService;
  81. @Resource
  82. private BpClauseService bpClauseService;
  83. @Resource
  84. private NewOrderProductService newOrderProductService;
  85. @Autowired
  86. private NewReceiptListService newReceiptListService;
  87. @Resource
  88. private NewShopOrderService newShopOrderService;
  89. @Resource
  90. private CmFinanceChargeService cmFinanceChargeService;
  91. @Resource
  92. private OrderUserInfoService orderUserInfoService;
  93. @Resource
  94. private CmMessageService cmMessageService;
  95. @Resource
  96. private ClubDao clubDao;
  97. @Autowired
  98. private ProductDao productDao;
  99. @Resource
  100. private CmProductSnService cmProductSnService;
  101. @Autowired
  102. private NewOrderProductDao newOrderProductDao;
  103. @Resource
  104. private CmReturnedPurchaseDao cmReturnedPurchaseDao;
  105. @Resource
  106. private CmUserService cmUserService;
  107. @Resource
  108. private RepeatPurchasePriceService repeatPurchasePriceService;
  109. @Resource
  110. private NewCmShopService newCmShopService;
  111. @Resource
  112. private RepeatPurchasePriceHistoryService repeatPurchasePriceHistoryService;
  113. @Resource
  114. private NewOrderConfigService newOrderConfigService;
  115. @Resource
  116. private CmDiscernReceiptService cmDiscernReceiptService;
  117. @Resource
  118. private CmUserDao cmUserDao;
  119. @Resource
  120. private CmReturnedPurchaseService cmReturnedPurchaseService;
  121. @Resource
  122. private CmReceiptOrderRelationDao cmReceiptOrderRelationDao;
  123. @Autowired
  124. private CmUserOrganizeService cmUserOrganizeService;
  125. @Autowired
  126. private CmSecondHandDetailService cmSecondHandDetailService;
  127. @Autowired
  128. private CmDiscernReceiptDao cmDiscernReceiptDao;
  129. @Autowired
  130. private CmReceiptOrderRelationService cmReceiptOrderRelationService;
  131. @Resource
  132. private CmPromotionDao cmPromotionDao;
  133. @Autowired
  134. private PurchaseProductService purchaseProductService;
  135. @Autowired
  136. private CmCouponService cmCouponService;
  137. @ModelAttribute
  138. public NewOrder get(@RequestParam(required = false) String id) {
  139. NewOrder entity = null;
  140. if (StringUtils.isNotBlank(id)) {
  141. entity = newOrderService.get(id);
  142. }
  143. if (entity == null) {
  144. entity = new NewOrder();
  145. }
  146. return entity;
  147. }
  148. @RequiresPermissions("order:order:view")
  149. @RequestMapping("orderList")
  150. public String orderList(NewOrder order, HttpServletRequest request, HttpServletResponse response, Model model) {
  151. if (null != order.getStartTime() && !"".equals(order.getStartTime()) && !order.getStartTime().endsWith("00:00:00")) {
  152. model.addAttribute("startTime", order.getStartTime());
  153. order.setStartTime(order.getStartTime().trim() + " 00:00:00");
  154. }
  155. if (null != order.getEndTime() && !"".equals(order.getEndTime()) && !order.getEndTime().endsWith("23:59:59")) {
  156. model.addAttribute("endTime", order.getEndTime());
  157. order.setEndTime(order.getEndTime().trim() + " 23:59:59");
  158. }
  159. if (null != order.getStartConfirmTime() && !"".equals(order.getStartConfirmTime()) && !order.getStartConfirmTime().endsWith("00:00:00")) {
  160. model.addAttribute("startConfirmTime", order.getStartConfirmTime());
  161. order.setStartConfirmTime(order.getStartConfirmTime().trim() + " 00:00:00");
  162. }
  163. if (null != order.getEndConfirmTime() && !"".equals(order.getEndConfirmTime()) && !order.getEndConfirmTime().endsWith("23:59:59")) {
  164. model.addAttribute("endConfirmTime", order.getEndConfirmTime());
  165. order.setEndConfirmTime(order.getEndConfirmTime().trim() + " 23:59:59");
  166. }
  167. if (null != order.getStartRefundTime() && !"".equals(order.getStartRefundTime()) && !order.getStartRefundTime().endsWith("00:00:00")) {
  168. model.addAttribute("startRefundTime", order.getStartRefundTime());
  169. order.setStartRefundTime(order.getStartRefundTime().trim() + " 00:00:00");
  170. }
  171. if (null != order.getEndRefundTime() && !"".equals(order.getEndRefundTime()) && !order.getEndRefundTime().endsWith("23:59:59")) {
  172. model.addAttribute("endRefundTime", order.getEndRefundTime());
  173. order.setEndRefundTime(order.getEndRefundTime().trim() + " 23:59:59");
  174. }
  175. model.addAttribute("orderRefundType", order.getOrderRefundType());
  176. if (null != order.getBuyer()) {
  177. order.setBuyer(order.getBuyer().trim());
  178. }
  179. if (null != order.getReceiver()) {
  180. order.setReceiver(order.getReceiver().trim());
  181. }
  182. //查询内部处理了已收,未付统计(包含运费)
  183. Page<NewOrder> page = newOrderService.findPage(new Page<>(request, response, 20), order);
  184. //获取组织列表
  185. List<CmUserOrganize> cmUserOrganizeList = cmUserOrganizeService.findOrganize();
  186. model.addAttribute("cmUserOrganizeList", cmUserOrganizeList);
  187. //获取上线协销人员,排除采美默认协销经理
  188. List<NewCmSp> serviceProviderList = newOrderService.findServiceProviderList();
  189. model.addAttribute("serviceProviderList", serviceProviderList);
  190. model.addAttribute("page", page);
  191. return "modules/order/newOrderList";
  192. }
  193. @RequiresPermissions("order:order:edit")
  194. @RequestMapping(value = "form")
  195. public String form(NewOrder newOrder, Model model, HttpServletRequest request) {
  196. BpClause bpClause = new BpClause();
  197. bpClause.setEnabledStatus("1");
  198. List<BpClause> bpClauses = bpClauseService.findList(bpClause);
  199. model.addAttribute("bpClauses", bpClauses);
  200. if (null != newOrder.getClauseID() && StringUtils.equals("1", newOrder.getConfirmFlag())) {//订单,且确认
  201. BpClause bpClause1 = bpClauseService.get(newOrder.getClauseID().toString());
  202. model.addAttribute("bpClause", bpClause1);
  203. }
  204. if (null != newOrder) {
  205. //根据订单产品
  206. List<NewOrderProduct> orderProducts = newOrder.getOrderProduct();
  207. if (null != orderProducts && orderProducts.size() > 0) {
  208. BigDecimal alreadyShopOtherPay = new BigDecimal(0);
  209. for (NewOrderProduct orderProduct : orderProducts) {
  210. //重新赋值
  211. alreadyShopOtherPay = BigDecimal.ZERO;
  212. orderProduct.setShopFeeFlag("0");
  213. //获取订单商品的应付信息
  214. List<CmFinanceCharge> cmFinanceCharges = cmFinanceChargeService.findListByProductId(orderProduct.getId());
  215. if (null != cmFinanceCharges && cmFinanceCharges.size() > 0) {
  216. for (int i = 0; i < cmFinanceCharges.size(); i++) { //一个产品多个出账记录
  217. if ("3".equals(cmFinanceCharges.get(i).getStatus())) {
  218. alreadyShopOtherPay = MathUtil.add(alreadyShopOtherPay, cmFinanceCharges.get(i).getShopFee());//已审核通过付给供应商金额
  219. }
  220. }
  221. } else {
  222. orderProduct.setShopFeeFlag("0");//没有 则可以修改应付供应商
  223. }
  224. //金额不为空 且 金额相等
  225. if (BigDecimal.valueOf(orderProduct.getShopFee()).compareTo(alreadyShopOtherPay) == 0 && alreadyShopOtherPay.compareTo(BigDecimal.ZERO) != 0) {
  226. orderProduct.setShopFeeFlag("1");//审核通过 不可修改
  227. }
  228. // 促销
  229. CmPromotion orderPromotions = null;
  230. if (null != orderProduct.getOrderPromotionsId()) {
  231. orderPromotions = cmPromotionDao.findOrderPromotions(orderProduct.getOrderPromotionsId());
  232. if (null != orderPromotions) {
  233. orderProduct.setPromotionsId(orderPromotions.getPromotionsId());
  234. orderProduct.setLadderPriceFlag(0);
  235. }
  236. }
  237. Product product = productDao.get(orderProduct.getProductID().toString());
  238. orderProduct.setCommodityType(product.getCommodityType());
  239. if (null == orderPromotions) {
  240. if (1 == orderProduct.getLadderPriceFlag() && "1".equals(product.getLadderPriceFlag())) {
  241. // 查询商品当前阶梯价格
  242. List<ProductLadderPrice> ladderPriceList = purchaseProductService.findLadderPriceList(orderProduct.getProductID().longValue());
  243. if (null != ladderPriceList && ladderPriceList.size() > 0) {
  244. IntStream.range(0, ladderPriceList.size()).forEach(i -> {
  245. if (i == ladderPriceList.size() - 1) {
  246. ladderPriceList.get(i).setBuyNumRangeShow("≥" + ladderPriceList.get(i).getBuyNum());
  247. } else {
  248. String buyNumRangeShow = ladderPriceList.get(i).getBuyNum() + "~" + (ladderPriceList.get(i + 1).getBuyNum() - 1);
  249. ladderPriceList.get(i).setBuyNumRangeShow(buyNumRangeShow);
  250. }
  251. });
  252. orderProduct.setLadderPriceList(ladderPriceList);
  253. }
  254. } else {
  255. orderProduct.setLadderPriceFlag(0);
  256. orderProduct.setIsActProduct("0");
  257. }
  258. }
  259. //是否有优惠券可以查看
  260. Boolean couponsLogo = cmCouponService.setCouponsLogo(newOrder.getUserID(), orderProduct.getProductID(), orderProduct.getShopID(), product.getCommodityType());
  261. if (couponsLogo) {
  262. orderProduct.setCouponsLogo(2);
  263. } else {
  264. orderProduct.setCouponsLogo(1);
  265. }
  266. }
  267. }
  268. if (null != newOrder.getOrderID() && null != newOrder.getClauseName()) {
  269. newOrderService.updateClauseContent(newOrder);
  270. }
  271. if (StringUtil.isEmpty(newOrder.getOrderTime())) {
  272. newOrder.setOrderTime(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
  273. }
  274. if (null == newOrder.getOrderID()) {
  275. newOrder.setOrderSource("4");
  276. }
  277. }
  278. model.addAttribute("order", newOrder);
  279. return "modules/order/orderForm";
  280. }
  281. @RequiresPermissions("order:order:edit")
  282. @RequestMapping(value = "secondeProductOrderForm")
  283. public String secondeProductOrderForm(NewOrder newOrder, Model model, HttpServletRequest request) {
  284. BpClause bpClause = new BpClause();
  285. bpClause.setEnabledStatus("1");
  286. List<BpClause> bpClauses = bpClauseService.findList(bpClause);
  287. model.addAttribute("bpClauses", bpClauses);
  288. if (null != newOrder.getClauseID() && StringUtils.equals("1", newOrder.getConfirmFlag())) {//订单,且确认
  289. BpClause bpClause1 = bpClauseService.get(newOrder.getClauseID().toString());
  290. model.addAttribute("bpClause", bpClause1);
  291. }
  292. if (null != newOrder) {
  293. //根据订单产品
  294. List<NewOrderProduct> orderProducts = newOrder.getOrderProduct();
  295. if (null != orderProducts && orderProducts.size() > 0) {
  296. BigDecimal alreadyShopOtherPay = new BigDecimal(0);
  297. for (NewOrderProduct orderProduct : orderProducts) {
  298. //重新赋值
  299. alreadyShopOtherPay = BigDecimal.ZERO;
  300. orderProduct.setShopFeeFlag("0");
  301. //获取订单商品的应付信息
  302. List<CmFinanceCharge> cmFinanceCharges = cmFinanceChargeService.findListByProductId(orderProduct.getId());
  303. if (null != cmFinanceCharges && cmFinanceCharges.size() > 0) {
  304. for (int i = 0; i < cmFinanceCharges.size(); i++) { //一个产品多个出账记录
  305. if ("3".equals(cmFinanceCharges.get(i).getStatus())) {
  306. alreadyShopOtherPay = MathUtil.add(alreadyShopOtherPay, cmFinanceCharges.get(i).getShopFee());//已审核通过付给供应商金额
  307. }
  308. }
  309. } else {
  310. orderProduct.setShopFeeFlag("0");//没有 则可以修改应付供应商
  311. }
  312. //金额不为空 且 金额相等
  313. if (new BigDecimal(orderProduct.getShopFee()).compareTo(alreadyShopOtherPay) == 0 && alreadyShopOtherPay.compareTo(BigDecimal.ZERO) != 0) {
  314. orderProduct.setShopFeeFlag("1");//审核通过 不可修改
  315. }
  316. }
  317. }
  318. if (null != newOrder.getOrderID() && null != newOrder.getClauseName()) {
  319. newOrderService.updateClauseContent(newOrder);
  320. }
  321. if (StringUtil.isEmpty(newOrder.getOrderTime())) {
  322. newOrder.setOrderTime(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()));
  323. }
  324. }
  325. model.addAttribute("order", newOrder);
  326. return "modules/order/secondProductOrderForm";
  327. }
  328. @RequiresPermissions("order:order:edit")
  329. @RequestMapping(value = "save")
  330. public String save(NewOrder newOrder, Model model, RedirectAttributes redirectAttributes, HttpServletRequest request) {
  331. // 是否为二手订单(二手订单只存在一个商品)
  332. boolean isSecondHandOrder = false;
  333. if (!beanValidator(model, newOrder)) {
  334. return form(newOrder, model, request);
  335. }
  336. if (CollectionUtils.isEmpty(newOrder.getOrderProduct())) {
  337. model.addAttribute("message", "保存失败商品不能为空");
  338. return form(newOrder, model, request);
  339. } else {
  340. List<NewOrderProduct> orderProductList = Lists.newArrayList();
  341. for (NewOrderProduct newOrderProduct : newOrder.getOrderProduct()) {
  342. if (StringUtils.isNotEmpty(newOrderProduct.getEnabledStatus())) {
  343. NewOrderProduct o = (NewOrderProduct) JsonMapper.fromJsonString(newOrderProduct.getEnabledStatus(), NewOrderProduct.class);
  344. JSONObject jsonObject = JSONObject.parseObject(newOrderProduct.getEnabledStatus());
  345. String productId = jsonObject.getString("productId");
  346. if (productId != null && !"".equals(productId)) {
  347. o.setProductID(Integer.valueOf(productId));
  348. }
  349. String shopId = jsonObject.getString("shopId");
  350. if (shopId != null && !"".equals(shopId)) {
  351. o.setShopID(Integer.valueOf(shopId));
  352. }
  353. String singleShopFee = jsonObject.getString("shopFee1");
  354. if (singleShopFee != null && !"".equals(singleShopFee)) {
  355. o.setSingleShopFee(Double.valueOf(singleShopFee));
  356. }
  357. String singleOtherFee = jsonObject.getString("otherFee1");
  358. if (singleOtherFee != null && !"".equals(singleOtherFee)) {
  359. o.setSingleOtherFee(Double.valueOf(singleOtherFee));
  360. }
  361. String singleCmFee = jsonObject.getString("cmFee1");
  362. if (singleCmFee != null && !"".equals(singleCmFee)) {
  363. o.setSingleCmFee(Double.valueOf(singleCmFee));
  364. }
  365. String productType = jsonObject.getString("productType");
  366. if (productType != null && !"".equals(productType)) {
  367. o.setProductType(Integer.valueOf(productType));
  368. }
  369. String ladderPriceFlag = jsonObject.getString("ladderPriceFlag");
  370. if (ladderPriceFlag != null && !"".equals(ladderPriceFlag)) {
  371. o.setLadderPriceFlag(Integer.valueOf(ladderPriceFlag));
  372. }
  373. if ("0".equals(productType)) {
  374. o.setPreferential((o.getPrice() - o.getDiscountPrice()) * o.getNum());//折扣
  375. o.setDiscountFee(BigDecimal.valueOf(o.getTotalFee()).subtract(BigDecimal.valueOf(o.getShouldPayFee())).doubleValue());//经理折扣
  376. o.setTotalAmount(o.getPrice() * o.getNum());//商品总金额
  377. //设置订单商品的默认应付税费(只有默认的时候应付税费才等于应收税费)
  378. if (o.getShouldPayTotalTax() == null) {
  379. o.setSingleShouldPayTotalTax(o.getAddedValueTax());
  380. o.setShouldPayTotalTax(o.getTotalAddedValueTax());
  381. }
  382. } else {
  383. o.setPreferential(0d);
  384. o.setDiscount(100d);
  385. o.setDiscountFee(0d);
  386. o.setTotalAmount(0d);
  387. o.setShouldPayFee(0d);
  388. o.setSingleShouldPayTotalTax(0d);
  389. o.setShouldPayTotalTax(0d);
  390. o.setCmFee(0d);
  391. o.setTotalFee(0d);
  392. o.setTotalAddedValueTax(0d);
  393. o.setAddedValueTax(0d);
  394. o.setTaxRate(0d);
  395. }
  396. o.setPresentNum(0);
  397. o.setNotOutStore(o.getNum());
  398. o.setStatus(0);//订单商品待付款
  399. if (o.getPayStatus() == null) {
  400. o.setPayStatus("0"); //默认值为未付款(0 未进账 1 待财务审核 2 已进账)
  401. }
  402. Integer promotionsId = o.getPromotionsId() != null ? o.getPromotionsId() : 0;
  403. o.setPromotionsId(promotionsId);
  404. orderProductList.add(o);
  405. String productCategory = o.getProductCategory();
  406. if (StringUtils.equals(productCategory, "2")) {
  407. isSecondHandOrder = true;
  408. newOrder.setRebateFlag("0");
  409. }
  410. }
  411. }
  412. if (CollectionUtils.isNotEmpty(orderProductList)) {
  413. newOrder.setOrderProduct(orderProductList);
  414. }
  415. }
  416. Date date = new Date();
  417. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  418. String time = sdf.format(date);
  419. if (isSecondHandOrder) {
  420. newOrder.setSecondHandOrderFlag("1");
  421. } else {
  422. newOrder.setSecondHandOrderFlag("0");
  423. }
  424. //后台添加订单状态为0;待确认
  425. if (StringUtils.isEmpty(newOrder.getStatus())) {
  426. newOrder.setStatus("0");
  427. }
  428. if (newOrder.getPayableAmount() == 0 && newOrder.getPayTotalFee() == 0) {
  429. // 订单状态
  430. newOrder.setStatus("31");
  431. newOrder.setReceiptStatus("3");
  432. newOrder.setPayFlag("1");
  433. newOrder.setConfirmFlag("1");//标记为确认订单
  434. newOrder.setConfirmTime(time);
  435. }
  436. //后台添加订单订单提交类型;后台提交4
  437. if (StringUtils.isEmpty(newOrder.getOrderSubmitType())) {
  438. newOrder.setOrderSubmitType("4");
  439. }
  440. //如果是[5:外单]类型则订单状态直接为交易完成
  441. if (StringUtils.equals("5", newOrder.getOrderSource())) {
  442. newOrder.setConfirmFlag("1");//标记为确认订单
  443. newOrder.setConfirmTime(time);
  444. }
  445. if (StringUtils.equals("1", newOrder.getCooFreeFlag())) {
  446. //如果是分期订单
  447. newOrder.setCooFreeFlag("0");
  448. newOrder.setCooFreeRate(0);
  449. newOrder.setCooFreeAmount(0.00d);
  450. }
  451. if (newOrder.getOrderID() == null) {
  452. // lwt 订单的下单时间和单号 都再订单保存后再展示
  453. newOrder.setOrderNo(OrderUtil.geneAdminOrderNo());
  454. newOrder.setOrderType("0"); // 订单类型 协销订单 0 普通订单 1
  455. newOrder.setOrderSubmitType("4");
  456. newOrder.setSplitFlag("1"); //订单可拆分
  457. }
  458. if (newOrder.getClauseID() == null) {
  459. newOrder.setClauseID(1); //没有选择条款的话 默认就是无条款
  460. }
  461. BpClause clause = bpClauseService.get(newOrder.getClauseID().toString());
  462. newOrder.setClauseContent(clause.getContent());
  463. newOrder.setClauseName(clause.getName());
  464. //保存订单
  465. newOrderService.save(newOrder);
  466. if (newOrder.getOrderID() != null) {
  467. //订单重新保存后则修改订单商品需供应商确认
  468. newOrderProductService.updateShopConfigFlag(newOrder.getOrderID());
  469. }
  470. addMessage(redirectAttributes, "保存订单成功");
  471. return "redirect:" + Global.getAdminPath() + "/order/orderList";
  472. }
  473. @RequiresPermissions("order:order:edit")
  474. @RequestMapping("printOrder")
  475. public String printOrder(Integer orderID, Integer shopOrderID, Model model) {
  476. if (shopOrderID != null) {
  477. NewShopOrder shopOrder = newShopOrderService.findByShopOrderID(shopOrderID);
  478. NewOrder order = newOrderService.findByOrderID(shopOrder.getOrderID());
  479. String payWay = order.getPayWay();
  480. if (payWay != null) {
  481. for (NewPayWay type : NewPayWay.values()) {
  482. if (payWay.contains(type.getCode() + ""))
  483. payWay = payWay.replaceAll(type.getCode() + "", type.getDesc());
  484. }
  485. order.setPayWay(payWay);
  486. } else {
  487. order.setPayWay("-");
  488. }
  489. OrderUserInfo orderUserInfo = orderUserInfoService.findByOrderID(order.getOrderID());
  490. model.addAttribute("shopOrder", shopOrder);
  491. model.addAttribute("order", order);
  492. model.addAttribute("orderUserInfo", orderUserInfo);
  493. return "modules/order/printSubOrder";
  494. }
  495. if (orderID != null) {
  496. NewOrder order = newOrderService.get(orderID + "");
  497. order.getOrderProduct().forEach(o -> {
  498. if (o.getOrderPromotionsId() != null) {
  499. CmPromotion promotions = cmPromotionDao.findOrderPromotions(o.getOrderPromotionsId());
  500. if (promotions != null && "1".equals(promotions.getMode())) {
  501. o.setDiscountPrice(promotions.getTouchPrice());
  502. }
  503. }
  504. });
  505. order.getNewShopOrders().removeIf(so -> so.getPostFeeCos().equals("1"));
  506. model.addAttribute("order", order);
  507. return "modules/order/printOrder";
  508. }
  509. return "modules/order/printOrder";
  510. }
  511. /**
  512. * 普通订单商品修改
  513. *
  514. * @param model
  515. * @return
  516. */
  517. @RequiresPermissions("order:order:edit")
  518. @RequestMapping("modifyProduct")
  519. public String modifyProduct(Model model, Integer orderID) {
  520. NewOrder order = newOrderService.get(orderID.toString());
  521. model.addAttribute("order", order);
  522. return "modules/order/modifyProduct";
  523. }
  524. /**
  525. * 协销订单确认
  526. *
  527. * @param model
  528. * @return
  529. */
  530. @RequiresPermissions("order:order:confirmOrder")
  531. @RequestMapping("confirmOrder")
  532. public String confirmOrder(Integer orderID, Model model, RedirectAttributes redirectAttributes) {
  533. NewOrder order = newOrderService.get(orderID + "");
  534. //优惠券确认消耗
  535. CmCouponOrderRecord orderRecord = order.getCouponOrderRecord();
  536. if (order.getCouponAmount() > 0 && orderRecord != null) {
  537. Boolean isCoupon = newOrderService.updateClubCoupon(orderRecord.getClubCouponId(), orderID);
  538. if (!isCoupon) {
  539. addMessage(redirectAttributes, "订单内优惠券已被使用");
  540. return "redirect:" + Global.getAdminPath() + "/order/detail/?id=" + orderID;
  541. }
  542. }
  543. //————————————————————————————-----
  544. //确认订单时处理买家商品价格库信息
  545. final Integer userID;
  546. if ("6".equals(order.getOrderSubmitType())) {
  547. userID = order.getUserID();
  548. } else {
  549. Integer clubId = order.getClubID();
  550. ClubModel clubByUserId = clubDao.getClubByUserId(Integer.parseInt(clubId.toString()));
  551. userID = clubByUserId.getUserID();
  552. }
  553. List<NewOrderProduct> orderProduct = order.getOrderProduct();
  554. if (CollectionUtils.isNotEmpty(orderProduct) && orderProduct.size() > 0) {
  555. for (NewOrderProduct op : orderProduct) {
  556. String isActProduct = op.getIsActProduct();
  557. //活动商品和阶梯商品不写入价格库
  558. if (StringUtil.equals("0", isActProduct)) {
  559. String buyAgainFlag = op.getBuyAgainFlag();
  560. //对于可以复购的商品添加买家商品价格,提供再次购买商品使用(如果不存在没有改买家商品价格则不能购买该商品)
  561. if (StringUtils.isNotEmpty(buyAgainFlag) && StringUtils.equals("1", buyAgainFlag)) {
  562. Product product = productDao.get(op.getProductID().toString());
  563. if (null != product) {
  564. String costPrice = product.getCostPrice();//成本价
  565. //version 4.6.0 写入复购价格库
  566. Double buyPrice = op.getDiscountPrice(); //该商品的购买价
  567. Date now = new Date();
  568. Date begin = product.getBeginTime();
  569. Date end = product.getEndTime();
  570. CmUser u = cmUserService.get(userID + "");
  571. if ("1".equals(product.getLadderPriceFlag()) ||
  572. ("1".equals(product.getActFlag()) &&
  573. "1001".equals(product.getActType()) &&
  574. new Date().after(begin) && now.before(end))) {
  575. //如果商品启用了阶梯价格或者团购活动,那么不使用购买价格而是用用户对应身份的非活动价格参与复购价格库计算
  576. //确认用户类型
  577. Integer userType = 1;//查看价格用户类型(1:游客,2:普通用户,3:会员)
  578. if ("10".equals(u.getRegisterUserTypeID())) {//普通用户或者游客
  579. boolean isVisitor = newOrderService.isVisitor(userID.toString());//是否是游客
  580. if (isVisitor) {
  581. userType = 1;
  582. buyPrice = product.getPrice8().doubleValue();
  583. } else {
  584. userType = 2;
  585. buyPrice = product.getPrice0().doubleValue();
  586. }
  587. } else {
  588. //未冻结 上线会所 上线创客查看会员价
  589. if (AppKeys.FLAG_YES.equals(u.getValidFlag()) &&
  590. (UserType.isClub(u.getRegisterUserTypeID())
  591. && (StringUtils.isNotEmpty(u.getClubStatus()) &&
  592. ("40".equals(u.getClubStatus()) || "90".equals(u.getClubStatus())))
  593. )) {
  594. userType = 3;
  595. buyPrice = product.getPrice1().doubleValue();
  596. }
  597. //普通用户 非上线创客会所 供应商 已冻结用户 展示普通价
  598. else {
  599. userType = 2;
  600. buyPrice = product.getPrice0().doubleValue();
  601. }
  602. }
  603. }
  604. Integer clubID = null;
  605. Integer uID = null;
  606. if (UserType.isClub(u.getRegisterUserTypeID())) {
  607. clubID = StringUtils.isEmpty(u.getClubID()) ? null : Integer.valueOf(u.getClubID());
  608. } else {
  609. uID = u.getUserID();
  610. }
  611. // 当前购买价格与成本价比较
  612. String costCheckFlag = product.getCostCheckFlag();//成本价选中标志:1固定成本 2比例成本
  613. if ("2".equals(costCheckFlag)) {
  614. costPrice = MathUtil.div(MathUtil.mul(product.getPrice1().doubleValue(), product.getCostProportional()), 100).toString();
  615. if ("0".equals(costPrice)) costPrice = op.getCostPrice().toString();
  616. }
  617. //购买价大于成本价,采美赚钱 就写入复购价格库
  618. SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  619. String strDate = formatter.format(new Date());
  620. String flag = "0";
  621. if (StringUtils.isNotBlank(costPrice) && buyPrice > Double.valueOf(costPrice)) {
  622. // 查询复购价格库 比较复购价格库中的购买价格与这一次的购买价格
  623. RepeatPurchasePrice p = repeatPurchasePriceService.getLastBuyPrice(clubID, uID, product.getProductID());
  624. if (p == null) {
  625. NewCmShop shop = newCmShopService.get(product.getShopID().toString());
  626. p = new RepeatPurchasePrice();
  627. p.setClubId(clubID);
  628. p.setUserId(u.getUserID());
  629. p.setCurrentPrice(buyPrice.toString());
  630. p.setCreateTime(strDate);
  631. p.setProductId(product.getProductID());
  632. p.setOrderId(orderID.toString());
  633. p.setShopId(shop == null ? null : shop.getShopID());
  634. p.setShopName(shop == null ? "" : shop.getName());
  635. p.setTaxRate(String.valueOf(op.getTaxRate()));
  636. repeatPurchasePriceService.insert(p);
  637. } else if (StringUtils.isNotBlank(p.getCurrentPrice()) && buyPrice < Double.valueOf(p.getCurrentPrice())) { // 这一次的购买价格小于复购价格库中的价格
  638. p.setCurrentPrice(buyPrice.toString());
  639. p.setOrderId(orderID.toString());
  640. p.setTaxRate(String.valueOf(op.getTaxRate()));
  641. repeatPurchasePriceService.update(p);
  642. }
  643. flag = "1";
  644. }
  645. RepeatPurchasePriceHistory r = new RepeatPurchasePriceHistory();
  646. r.setClubId(clubID);
  647. r.setUserId(u.getUserID());
  648. r.setPrice(buyPrice.toString());
  649. r.setOrderId(orderID);
  650. r.setCurrentCostPrice(costPrice);
  651. r.setCreateTime(strDate);
  652. r.setProductId(product.getProductID());
  653. r.setValid(flag);
  654. repeatPurchasePriceHistoryService.insert(r);
  655. }
  656. }
  657. }
  658. // 二手商品确认商品如果是二手仪器则需要把该二手商品置为已售
  659. if (StringUtils.equals(op.getSecondHandType(), "1") && StringUtils.equals("2", op.getProductCategory())) {
  660. cmSecondHandDetailService.updatSecondHnadproductSold(op.getProductID());
  661. }
  662. }
  663. }
  664. //————————————————————————————-----
  665. CmMessage msg = new CmMessage();
  666. msg.setAddTime(com.caimei.utils.DateUtils.getDateTime());
  667. msg.setContent("您有一笔订单等待支付,快去订单列表进行支付。");
  668. msg.setTitle("订单确认结果");
  669. msg.setToUserID(order.getUserID());
  670. msg.setMessageTypeID("1");
  671. msg.setReadFlag("0");
  672. cmMessageService.save(msg);
  673. newOrderService.confirmOrder(orderID);
  674. //确认订单的时候将用户余额修改为抵扣之后金额(协销下单,后台下单--待确认订单)注意用户自己下单的时候直接则两个金额同时减少,取消同时回滚
  675. Double balancePayFee = order.getBalancePayFee();
  676. CmUser u = cmUserService.get(userID + "");
  677. if (null != u && null != balancePayFee) {
  678. Double userMoney = u.getUserMoney();
  679. if (null != userMoney) {
  680. u.setUserMoney(userMoney - balancePayFee);
  681. cmUserDao.updateMoney(u);
  682. }
  683. }
  684. addMessage(redirectAttributes, "确认订单成功");
  685. return "redirect:" + Global.getAdminPath() + "/order/detail/?id=" + orderID;
  686. }
  687. /**
  688. * 取消订单
  689. *
  690. * @return
  691. */
  692. @RequiresPermissions("order:order:edit")
  693. @RequestMapping("cancelOrder")
  694. public String cancelOrder(Integer orderID, RedirectAttributes redirectAttributes) {
  695. newOrderService.cancelOrder(orderID);
  696. addMessage(redirectAttributes, "取消订单成功");
  697. return "redirect:" + Global.getAdminPath() + "/order/detail/?id=" + orderID;
  698. }
  699. /**
  700. * 确认收货
  701. *
  702. * @param shopOrderID
  703. * @param redirectAttributes
  704. * @return
  705. */
  706. @RequiresPermissions("order:order:edit")
  707. @RequestMapping("confirmReceipt")
  708. public String confirmReceipt(Integer shopOrderID, RedirectAttributes redirectAttributes) {
  709. newShopOrderService.confirmReceipt(shopOrderID);
  710. addMessage(redirectAttributes, "确认收货成功");
  711. return "redirect:" + Global.getAdminPath() + "/order/detailPage/?shopOrderID=" + shopOrderID;
  712. }
  713. /**
  714. * 去子订单orderProduct页面
  715. *
  716. * @return
  717. */
  718. @RequiresPermissions("order:order:edit")
  719. @RequestMapping("toDeliveryPage")
  720. public String toDeliveryPage(NewOrder order, Model model) {
  721. List<NewOrderProduct> orderProduct = order.getOrderProduct();
  722. if (CollectionUtils.isNotEmpty(orderProduct))
  723. orderProduct.removeIf(p -> p.getProductID().intValue() == 999);
  724. for (NewOrderProduct newOrderProduct : orderProduct) {
  725. Integer cancelNum = newOrderProductDao.getActualCancelNum(newOrderProduct.getOrderProductID());
  726. cancelNum = cancelNum == null ? 0 : cancelNum;
  727. //统计未发货数量
  728. newOrderProduct.setNotOutStore(newOrderProduct.getNotOutStore() - cancelNum);
  729. }
  730. model.addAttribute("order", order);
  731. return "modules/order/ship";
  732. }
  733. /**
  734. * 填写物流信息页面
  735. *
  736. * @param params key = orderProdductID value = 发货数量
  737. * @return
  738. */
  739. @RequiresPermissions("order:order:edit")
  740. @RequestMapping("addLogisticsInfo")
  741. @ResponseBody
  742. public Map<String, Object> addLogisticsInfo(Model model, @RequestBody Map<String, String> params) {
  743. Map<String, Object> r = new HashMap<>();
  744. // 参数转换
  745. List<NewOrderProduct> orderProductList = new ArrayList<>();
  746. for (Map.Entry<String, String> entry : params.entrySet()) {
  747. NewOrderProduct orderProduct = newOrderProductService.get(entry.getKey());
  748. orderProduct.setDeliveryNum(Integer.valueOf(entry.getValue()));
  749. orderProductList.add(orderProduct);
  750. }
  751. model.addAttribute("orderProductList", orderProductList);
  752. r.put("data", orderProductList);
  753. return r;
  754. }
  755. @RequestMapping("toShipLogistic")
  756. public String toShipLogistic(Integer orderID, Model model) {
  757. model.addAttribute("orderID", orderID);
  758. return "modules/order/shipLogistic";
  759. }
  760. private String setImagePath(String path) {
  761. //获取文件服务器地址
  762. String photoServer = Global.getConfig("photoServer");
  763. ImageUploadInfo saveImageSerivce = new ImageUploadInfo();
  764. if (StringUtils.isNotBlank(path) && !path.startsWith("http:") && !path.startsWith("https:")) {
  765. path = Encodes.urlDecode(path);
  766. String realPath = UploadImageUtils.getAbsolutePath(path);
  767. int pointerIndex = realPath.lastIndexOf(".");
  768. try {
  769. saveImageSerivce = UploadUtils.saveImageSerivce(realPath, pointerIndex, realPath);
  770. return photoServer + saveImageSerivce.getSource();
  771. } catch (Exception e) {
  772. return path;
  773. }
  774. }
  775. return path;
  776. }
  777. /**
  778. * 发货
  779. *
  780. * @param params 参数 包含 shopOrderID子订单ID, key = orderProductID value = 发货数量 物流单号信息 key = 物流公司 value = 快递单号
  781. * @return
  782. */
  783. @RequiresPermissions("order:order:edit")
  784. @RequestMapping("delivery")
  785. @ResponseBody
  786. public Map<String, Object> delivery(@RequestBody Map<String, Object> params) {
  787. logger.info("delivery params===== " + params);
  788. Map<Integer, Integer> orderProductMap = new HashMap<>();
  789. Map<Integer, List<NewOrderProduct>> deliveryData = new HashMap<>(); //eg: {shopOrderID : [orderProductList], }
  790. Map<String, List<String>> logisticsInfo = new HashMap<>();
  791. String remarks = null;
  792. String[] images = new String[0];
  793. // 参数转换
  794. for (Map.Entry<String, Object> entry : params.entrySet()) {
  795. if (entry.getKey().contains("orderProductID")) {
  796. orderProductMap.put(Integer.valueOf(entry.getKey().split("_")[1]), Integer.valueOf(entry.getValue().toString()));
  797. }
  798. if (entry.getKey().contains("logisticsInfo")) {
  799. List<String> logisticsNus = Arrays.asList(entry.getValue().toString().split("_"));
  800. logisticsInfo.put(entry.getKey().split("_")[1], logisticsNus);
  801. }
  802. if (entry.getKey().contains("remarks")) {
  803. remarks = entry.getValue().toString();
  804. }
  805. if (entry.getKey().contains("remarkImages")) {
  806. images = entry.getValue().toString().split("##");
  807. }
  808. }
  809. String[] imgPath = new String[images.length];
  810. if (images.length > 0) {
  811. for (int i = 0; i < imgPath.length; i++) {
  812. imgPath[i] = setImagePath(images[i]);
  813. }
  814. }
  815. String remarkImage = StringUtils.join(imgPath, "##");
  816. Map<String, Object> result = new HashMap<>();
  817. List<NewOrderProduct> orderProducts = new ArrayList<>();
  818. for (Map.Entry<Integer, Integer> entry : orderProductMap.entrySet()) {
  819. NewOrderProduct o = newOrderProductService.get(String.valueOf(entry.getKey()));
  820. if (o.getNotOutStore() - entry.getValue() < 0) {
  821. result.put("success", false);
  822. result.put("msg", "发货数量异常");
  823. return result;
  824. }
  825. o.setNotOutStore(o.getNotOutStore() - entry.getValue());
  826. o.setThisTimePostNum(entry.getValue()); //这一次的发货数量
  827. if (o.getNotOutStore().intValue() == 0) {
  828. // 订单商品 已经发完
  829. o.setStatus(3);
  830. } else {
  831. // 订单商品 还没发完
  832. o.setStatus(4);
  833. }
  834. orderProducts.add(o);
  835. if (deliveryData.get(o.getShopOrderID()) == null) {
  836. List<NewOrderProduct> ops = new ArrayList<>();
  837. deliveryData.put(o.getShopOrderID(), ops);
  838. ops.add(o);
  839. } else {
  840. List<NewOrderProduct> ops = deliveryData.get(o.getShopOrderID());
  841. ops.add(o);
  842. }
  843. }
  844. //物流批次id
  845. String logisticsBatchId;
  846. try {
  847. logisticsBatchId = newOrderService.delivery(deliveryData, orderProducts, orderProductMap, logisticsInfo, remarks, remarkImage);
  848. } catch (Exception e) {
  849. logger.info(e.toString(), e);
  850. result.put("success", false);
  851. result.put("msg", e.getMessage());
  852. return result;
  853. }
  854. result.put("success", true);
  855. result.put("logisticsBatchId", logisticsBatchId);
  856. return result;
  857. }
  858. /**
  859. * 订单拆分
  860. *
  861. * @return
  862. */
  863. @RequiresPermissions("order:order:edit")
  864. @RequestMapping("splitOrder")
  865. @ResponseBody
  866. public Map<String, Object> splitOrder(@RequestBody Map<String, Map<String, String>> p) {
  867. Map<String, Object> map = new HashMap<>();
  868. try {
  869. for (Map.Entry<String, Map<String, String>> b : p.entrySet()) {
  870. Map<String, String> params = new HashMap<>();
  871. params.put("shopOrderID", b.getKey().split("_")[1]);
  872. for (Map.Entry<String, String> e : b.getValue().entrySet()) {
  873. params.put(e.getKey(), e.getValue());
  874. }
  875. Integer shopOrderID = null; //子订单ID
  876. Map<Integer, Integer> orderProductMap = new HashMap<>();
  877. for (Map.Entry<String, String> entry : params.entrySet()) {
  878. if ("shopOrderID".equals(entry.getKey()))
  879. shopOrderID = Integer.valueOf(entry.getValue());
  880. if (entry.getKey().contains("orderProductID"))
  881. orderProductMap.put(Integer.valueOf(entry.getKey().split("_")[1]), Integer.valueOf(entry.getValue()));
  882. }
  883. if (shopOrderID == null) {
  884. logger.info("参数错误shopOrderID == null了");
  885. map.put("success", false);
  886. map.put("msg", "参数错误");
  887. return map;
  888. }
  889. // 无收款记录的订单可对该订单下的商品可根据数量拆成一个订单
  890. // 还需要加上有无收款记录的判断
  891. List<Integer> receiptID = cmDiscernReceiptService.getReceiptRecords(shopOrderID);
  892. if (CollectionUtils.isNotEmpty(receiptID)) {
  893. //查到了收款记录仪 不能进行拆单操作了
  894. logger.info("收款记录ID ----->" + StringUtil.join(receiptID, ","));
  895. map.put("success", false);
  896. map.put("msg", "订单进行过收款操作, 无法拆分");
  897. return map;
  898. }
  899. List<NewOrderProduct> oldOrderProductList = new ArrayList<>();
  900. List<NewOrderProduct> newOrderProductList = new ArrayList<>();
  901. List<NewCmFinanceReceipts> cfrBakList = new ArrayList<>();
  902. for (Map.Entry<Integer, Integer> entry : orderProductMap.entrySet()) {
  903. if (entry.getValue() == null || entry.getValue() == 0) {
  904. continue;// 拆分数量为零则跳过
  905. }
  906. NewOrderProduct dbOrderProduct = newOrderProductService.get(entry.getKey() + "");
  907. int allNum = dbOrderProduct.getNum() + dbOrderProduct.getPresentNum();// 商品订单里面的总的商品数量(含赠品)
  908. double productNum = dbOrderProduct.getNum().doubleValue();// 商品订单里面的总的商品数量(不含赠品)
  909. NewOrderProduct newOrderProduct = newOrderProductService.get(entry.getKey() + "");
  910. newOrderProduct.setOrderProductID(null);
  911. newOrderProduct.setShopOrderID(null);
  912. newOrderProduct.setShopOrderNo(null);
  913. if (entry.getValue() >= dbOrderProduct.getNum()) { // 购买数量(含赠品)数量拆分
  914. // 拆分数量 >= 购买数量(不含赠品)
  915. newOrderProduct.setNum(dbOrderProduct.getNum());
  916. newOrderProduct.setPresentNum(entry.getValue() - dbOrderProduct.getNum());
  917. int dbOrderProductNum = dbOrderProduct.getNum();
  918. dbOrderProduct.setNum(0);
  919. dbOrderProduct.setPresentNum(dbOrderProduct.getPresentNum() - (entry.getValue() - dbOrderProductNum));
  920. if (dbOrderProduct.getNum().intValue() == 0 && dbOrderProduct.getPresentNum().intValue() == 0) {
  921. dbOrderProduct.setDelFlag("1");
  922. List<NewOrderProduct> orderProducts = newOrderProductService.findListByShopOrderID(shopOrderID); //子订单商品
  923. if (CollectionUtils.isNotEmpty(orderProducts) && orderProducts.size() == 1) { // 子订单里面只有一类订单商品
  924. // 别把商品全部拆走啦
  925. map.put("success", false);
  926. map.put("msg", "别把商品全部拆走啦");
  927. return map;
  928. }
  929. }
  930. } else {
  931. newOrderProduct.setNum(entry.getValue());
  932. newOrderProduct.setPresentNum(0);
  933. dbOrderProduct.setNum(dbOrderProduct.getNum() - entry.getValue());
  934. }
  935. dbOrderProduct.setNotOutStore(dbOrderProduct.getNotOutStore() - entry.getValue()); //未发货数量
  936. newOrderProduct.setNotOutStore(entry.getValue()); //未发货数量
  937. //总税费 TotalAddedValueTax
  938. Double oldAddedValueTax = dbOrderProduct.getTotalAddedValueTax();
  939. Double newAddedValueTax = newOrderProduct.getTotalAddedValueTax();
  940. dbOrderProduct.setTotalAddedValueTax(oldAddedValueTax * (dbOrderProduct.getNum() / productNum)); //单个税费 * 购买数量(不含赠品)
  941. newOrderProduct.setTotalAddedValueTax(newAddedValueTax * (newOrderProduct.getNum() / productNum)); //单个税费 * 购买数量(不含赠品)
  942. //总应付税费 shouldPayTotalTax---获取老的应付税费(不能使用单个计算,因为单个税费不包含经理折扣)
  943. Double oldshouldPayTotalTax = dbOrderProduct.getShouldPayTotalTax();
  944. Double NewhouldPayTotalTax = newOrderProduct.getShouldPayTotalTax();
  945. dbOrderProduct.setShouldPayTotalTax(oldshouldPayTotalTax * (dbOrderProduct.getNum() / productNum)); //单个税费 * 购买数量(不含赠品)
  946. newOrderProduct.setShouldPayTotalTax(NewhouldPayTotalTax * (newOrderProduct.getNum() / productNum)); //单个税费 * 购买数量(不含赠品)
  947. // 总价 totalFee
  948. dbOrderProduct.setTotalFee(dbOrderProduct.getDiscountPrice() * dbOrderProduct.getNum() + (dbOrderProduct.getAddedValueTax() * dbOrderProduct.getNum())); //折后单价 * 购买数量(不含赠品) + 税费
  949. newOrderProduct.setTotalFee(newOrderProduct.getDiscountPrice() * newOrderProduct.getNum() + (newOrderProduct.getAddedValueTax() * newOrderProduct.getNum())); //折后单价 * 购买数量(不含赠品)+ 税费
  950. //todo 5.0.0 经理折扣在订单商品中移除
  951. // 经理折扣 discountFee
  952. dbOrderProduct.setDiscountFee(dbOrderProduct.getDiscountFee() * (MathUtil.div(dbOrderProduct.getNum(), productNum).doubleValue())); // 按拆单前后购买数量的比例来分经理折扣
  953. // cfrOld.setDeductionAmount(dbOrderProduct.getDiscountFee().toString());
  954. newOrderProduct.setDiscountFee(newOrderProduct.getDiscountFee() * (MathUtil.div(newOrderProduct.getNum(), productNum).doubleValue())); // 按拆单前后购买数量的比例来分经理折扣
  955. // cfrNew.setDeductionAmount(newOrderProduct.getDiscountFee().toString());
  956. // 优惠 preferential
  957. dbOrderProduct.setPreferential((dbOrderProduct.getPrice() - dbOrderProduct.getDiscountPrice()) * dbOrderProduct.getNum()); // 优惠 (price - discountPrice) * num
  958. newOrderProduct.setPreferential((newOrderProduct.getPrice() - newOrderProduct.getDiscountPrice()) * newOrderProduct.getNum()); // 优惠 (price - discountPrice) * num
  959. // 应付金额
  960. dbOrderProduct.setShouldPayFee(dbOrderProduct.getTotalFee() - dbOrderProduct.getDiscountFee()); //应付金额 = totalFee - discountFee'
  961. // cfrOld.setShouldPayAmount(dbOrderProduct.getShouldPayFee().toString());
  962. newOrderProduct.setShouldPayFee(newOrderProduct.getTotalFee() - newOrderProduct.getDiscountFee()); //应付金额 = totalFee - discountFee'
  963. // cfrNew.setShouldPayAmount(newOrderProduct.getShouldPayFee().toString());
  964. // 应付供应商
  965. dbOrderProduct.setShopFee(dbOrderProduct.getSingleShopFee() * (dbOrderProduct.getNum() + dbOrderProduct.getPresentNum()));
  966. newOrderProduct.setShopFee(newOrderProduct.getSingleShopFee() * (newOrderProduct.getNum() + newOrderProduct.getPresentNum())); // 后台拆单后订单有采美 发货 应付金额全部给采美
  967. // 应付第三方(不能使用单个计算,因为单个税费不包含经理折扣)
  968. Double oldOtherFee = dbOrderProduct.getOtherFee();
  969. Double newOtherFee = newOrderProduct.getOtherFee();
  970. dbOrderProduct.setOtherFee((oldOtherFee / productNum) * dbOrderProduct.getNum());
  971. newOrderProduct.setOtherFee((newOtherFee / productNum) * newOrderProduct.getNum()); // 后台拆单后订单有采美 发货 应付金额全部给采美
  972. // 应付采美
  973. Double oldCmFee = dbOrderProduct.getCmFee();
  974. Double newCmFee = newOrderProduct.getCmFee();
  975. dbOrderProduct.setCmFee((oldCmFee / productNum) * dbOrderProduct.getNum());
  976. newOrderProduct.setCmFee((newCmFee / productNum) * newOrderProduct.getNum());
  977. //重新计算orderProduct总价
  978. dbOrderProduct.setTotalAmount(dbOrderProduct.getNum() * dbOrderProduct.getPrice());
  979. // cfrOld.setTotalAmount(dbOrderProduct.getTotalAmount().toString());
  980. newOrderProduct.setTotalAmount(newOrderProduct.getNum() * newOrderProduct.getPrice());
  981. // cfrNew.setTotalAmount(newOrderProduct.getTotalAmount().toString());
  982. newOrderProduct.setShopID(1000); // shopID = 1000 数据库固定数据表示采美
  983. oldOrderProductList.add(dbOrderProduct);
  984. newOrderProductList.add(newOrderProduct);
  985. }
  986. NewShopOrder dbShopOrder = newShopOrderService.findByShopOrderID(shopOrderID);
  987. // 我要把没有参与拆单的订单商品 添加到oldOrderProductList 里面重新统计订单金额
  988. loopA:
  989. for (NewOrderProduct nop : dbShopOrder.getNewOrderProducts()) {
  990. loopB:
  991. for (NewOrderProduct old : oldOrderProductList) {
  992. if (old.getOrderProductID().intValue() == nop.getOrderProductID().intValue()) {
  993. continue loopA;
  994. }
  995. }
  996. oldOrderProductList.add(nop); // looB 正常结束 说明这个nop没有参与拆单
  997. }
  998. newOrderService.splitOrder(shopOrderID, oldOrderProductList, newOrderProductList, cfrBakList);
  999. }
  1000. map.put("success", true);
  1001. } catch (Exception e) {
  1002. logger.debug(e.toString(), e);
  1003. map.put("success", false);
  1004. map.put("msg", "拆分失败");
  1005. }
  1006. return map;
  1007. }
  1008. /**
  1009. * 获取子订单所有的发货记录
  1010. *
  1011. * @param shopOrderID
  1012. * @return
  1013. */
  1014. @RequiresPermissions("order:order:edit")
  1015. @RequestMapping("logisticsList")
  1016. public String logisticsList(Integer shopOrderID, Model model) {
  1017. List<List<NewOrderProduct>> logisticsList = newOrderProductService.logisticsList(shopOrderID);
  1018. model.addAttribute("logisticsList", logisticsList);
  1019. return "modules/order/addLogistics";
  1020. }
  1021. /**
  1022. * 发货完成以后去追加物流信息的页面,并且展示已有的物流单号
  1023. *
  1024. * @param logisticsBatchID 发货批次ID
  1025. * @return
  1026. */
  1027. @RequiresPermissions("order:order:edit")
  1028. @RequestMapping("toAppendLogisticsInfo")
  1029. public String toAppendLogisticsInfo(String logisticsBatchID, Model model) {
  1030. List<NewOrderProduct> opInfo = newShopOrderService.getBatchInfo(logisticsBatchID);
  1031. Map<String, List<String>> loInfo = newShopOrderService.getLogisticsInfo(logisticsBatchID);
  1032. model.addAttribute("opInfo", opInfo);
  1033. model.addAttribute("loInfo", loInfo);
  1034. model.addAttribute("logisticsBatchID", logisticsBatchID);
  1035. return "modules/order/appendShipLogistic";
  1036. }
  1037. /**
  1038. * 已经发货后追加物流信息
  1039. * params = {logisticsBatchID : 发货批次, remarks: 备注, logisticsInfo_快递公司名称: 单号_单号_.... }
  1040. *
  1041. * @return
  1042. */
  1043. @RequiresPermissions("order:order:edit")
  1044. @RequestMapping("appendLogisticsInfo")
  1045. @ResponseBody
  1046. public Map<String, Object> appendLogisticsInfo(@RequestBody Map<String, String> params) {
  1047. Map<String, Object> result = new HashMap<>();
  1048. String logisticsBatchID = null;
  1049. String remarks = null;
  1050. Map<String, List<String>> logisticsInfo = new HashMap<>();//物流编码
  1051. // 参数转换
  1052. for (Map.Entry<String, String> entry : params.entrySet()) {
  1053. if ("logisticsBatchID".equals(entry.getKey()))
  1054. logisticsBatchID = entry.getValue();
  1055. if ("remarks".equals(entry.getKey()))
  1056. remarks = entry.getValue();
  1057. if (entry.getKey().contains("logisticsInfo")) {
  1058. List<String> logisticsNus = Arrays.asList(entry.getValue().split("_"));
  1059. logisticsInfo.put(entry.getKey().split("_")[1], logisticsNus);
  1060. }
  1061. }
  1062. try {
  1063. Integer shopOrderID = newShopOrderService.appendLogisticsInfo(logisticsBatchID, logisticsInfo, remarks);
  1064. result.put("shopOrderID", shopOrderID);
  1065. result.put("success", true);
  1066. } catch (Exception e) {
  1067. result.put("success", false);
  1068. logger.debug(e.toString(), e);
  1069. result.put("msg", "数据异常");
  1070. }
  1071. return result;
  1072. }
  1073. /**
  1074. * 根据订单类型以及状态去不同的详情页
  1075. * (这是5.0.0以前的订单详情页面)
  1076. *
  1077. * @param order
  1078. * @return
  1079. */
  1080. @RequiresPermissions("order:order:edit")
  1081. @RequestMapping("detailPage")
  1082. public String detailPage(NewOrder order, Integer shopOrderID, Model model) {
  1083. if (order.getOrderID() != null) {
  1084. model.addAttribute("orderID", order.getOrderID());
  1085. model.addAttribute("orderProducts", order.getOrderProduct());
  1086. } else {
  1087. model.addAttribute("shopOrderID", shopOrderID);
  1088. }
  1089. NewShopOrder shopOrder = null;
  1090. if (shopOrderID != null) {
  1091. shopOrder = newShopOrderService.findByShopOrderID(shopOrderID);
  1092. order = newOrderService.get(shopOrder.getOrderID().toString());
  1093. model.addAttribute("orderProducts", shopOrder.getNewOrderProducts());
  1094. model.addAttribute("snOrderProducts", shopOrder.getSnOrderProducts());
  1095. }
  1096. if (shopOrderID != null && shopOrder.getSnOrderProducts() != null && shopOrder.getSnOrderProducts().size() > 0) {
  1097. //查询是否输入过SN码
  1098. List<CmProductSn> listSign = cmProductSnService.findSnByShopOrderID(shopOrderID);
  1099. if (null != listSign && listSign.size() > 0) {
  1100. model.addAttribute("listSign", listSign);
  1101. }
  1102. }
  1103. String payWay = order.getPayWay();
  1104. if (payWay != null) {
  1105. for (NewPayWay type : NewPayWay.values()) {
  1106. if (payWay.contains(type.getCode() + ""))
  1107. payWay = payWay.replaceAll(type.getCode() + "", type.getDesc());
  1108. }
  1109. order.setPayWay(payWay);
  1110. } else {
  1111. order.setPayWay("-");
  1112. }
  1113. model.addAttribute("orderUserInfo", order.getBpOrderUserinfo());
  1114. model.addAttribute("shopOrder", shopOrder);
  1115. model.addAttribute("order", order);
  1116. if ("0".equals(order.getOrderType())) {
  1117. // 协销订单
  1118. return "modules/order/bpOrderDetail";
  1119. } else {
  1120. // 普通订单
  1121. return "modules/order/normalOrderDetail";
  1122. }
  1123. }
  1124. /**
  1125. * 订单详情页 5.0.0版本 x
  1126. * 这个是新改的协销订单的详情页面
  1127. *
  1128. * @param order
  1129. * @return
  1130. */
  1131. @RequiresPermissions("order:order:view")
  1132. @RequestMapping("detail")
  1133. public String detail(NewOrder order, Model model) {
  1134. BpClause bpClause = new BpClause();
  1135. bpClause.setEnabledStatus("1");
  1136. List<BpClause> bpClauses = bpClauseService.findList(bpClause);
  1137. model.addAttribute("bpClauses", bpClauses);
  1138. //获取订单是否可以申请付款
  1139. List<Integer> oId = new ArrayList<>();
  1140. oId.add(order.getOrderID());
  1141. List<Integer> orderIdsInApplyReturn = cmReturnedPurchaseDao.findOrderIDsInApplyReturnFlag(oId);
  1142. if (CollectionUtils.isNotEmpty(orderIdsInApplyReturn) && orderIdsInApplyReturn.size() > 0) {
  1143. order.setApplyReturnedPurchaseFlag("0");
  1144. } else {
  1145. order.setApplyReturnedPurchaseFlag("1");
  1146. }
  1147. //判断是否有在收款审核的订单
  1148. List<Integer> ids = cmReceiptOrderRelationDao.toAudit(order.getOrderID());
  1149. if (ids != null && ids.size() > 0) {
  1150. order.setToAudit("1");
  1151. }
  1152. //一个子订单只有一个商品时,不可拆分
  1153. int count = 0;
  1154. for (NewShopOrder newShopOrder : order.getNewShopOrders()) {
  1155. if (newShopOrder.getShopID() != 998) {
  1156. count++;
  1157. }
  1158. }
  1159. if (order.getProductCount() == null) {
  1160. order.setProductCount(1);
  1161. }
  1162. if (order.getProductCount() <= count) {
  1163. order.setSplitFlag("0");
  1164. }
  1165. //是否抹平支付过(抹平最多只允许存在一次)
  1166. CmDiscernReceipt cmDiscernReceipt = cmDiscernReceiptDao.findSmoothoutInfo(order.getOrderID().toString());
  1167. if (null != cmDiscernReceipt) {
  1168. order.setAssociationType(cmDiscernReceipt.getAssociationType());
  1169. String confirmType = cmDiscernReceipt.getConfirmType();
  1170. order.setConfirmType(confirmType);
  1171. // 是否是一比款收了多个订单
  1172. if (StringUtils.equals(confirmType, "1") || StringUtils.equals(confirmType, "2") || StringUtils.equals(confirmType, "3")) {
  1173. List<CmReceiptOrderRelation> byReceiptList = cmReceiptOrderRelationService.findByReceiptID(cmDiscernReceipt.getId());
  1174. if (CollectionUtils.isNotEmpty(byReceiptList) && byReceiptList.size() > 1) {
  1175. order.setReceiptOrderFlag(true);
  1176. }
  1177. }
  1178. }
  1179. // 订单已收款才会出现抹平或者多收退余额,(已收再退款或者撤销退款订单即使存在抹平也需要当未抹平重新计算付款)
  1180. String receiptStatus = order.getReceiptStatus();
  1181. if (StringUtils.equals("3", receiptStatus)) {
  1182. if (null != cmDiscernReceipt) {
  1183. String confirmType = cmDiscernReceipt.getConfirmType();
  1184. order.setConfirmType(confirmType);
  1185. double associateAmount = cmDiscernReceiptDao.getAssociateAmount(String.valueOf(order.getOrderID()));
  1186. order.setOrderReceivedAmount(associateAmount);
  1187. //大额退余额
  1188. if (StringUtils.equals("3", confirmType)) {
  1189. String id = cmDiscernReceipt.getId();
  1190. double returnBalanceAmount = cmDiscernReceiptDao.getReturnBalanceAmount(id);
  1191. order.setReturnBalanceAmount(returnBalanceAmount);
  1192. }
  1193. }
  1194. }
  1195. //商城小程序下单时,获取下单门店的名称
  1196. if (order.getOrganizeID() >= 3 && order.getOrganizeStoreId() != null) {
  1197. String organizeStoreName = cmUserDao.getOrganizeStoreName(order.getOrganizeStoreId());
  1198. order.setOrganizeStoreName(organizeStoreName);
  1199. }
  1200. model.addAttribute("order", order);
  1201. if ("0".equals(order.getStatus())) {
  1202. try {
  1203. NewOrderConfig confirmOverTime = newOrderConfigService.getValueByKey("confirmOverTime");
  1204. Double value = confirmOverTime.getValue(); //待确认超过 value 小时自动取消订单
  1205. GregorianCalendar gc = new GregorianCalendar();
  1206. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  1207. Date orderTime = sdf.parse(order.getOrderTime());
  1208. gc.setTime(orderTime);
  1209. gc.add(Calendar.HOUR, value.intValue());
  1210. Date time = gc.getTime();
  1211. String ot = sdf.format(time);
  1212. if (time.after(new Date()))
  1213. model.addAttribute("time", ot);
  1214. } catch (Exception e) {
  1215. e.printStackTrace();
  1216. }
  1217. }
  1218. CmReturnedPurchase cmReturnedPurchase = new CmReturnedPurchase();
  1219. cmReturnedPurchase.setStatus("2");
  1220. cmReturnedPurchase.setOrderID(order.getOrderID());
  1221. List<CmReturnedPurchase> dataList = cmReturnedPurchaseService.getReturnedPurchaseList(cmReturnedPurchase);
  1222. Double returnedPurchaseFee = 0D; //退款(退货)总金额
  1223. Double refundFee = 0D; //退款总额(给买家)
  1224. for (CmReturnedPurchase bean : dataList) {
  1225. if (!bean.getStatus().equals("3")) {
  1226. returnedPurchaseFee += bean.getReturnedPurchaseFee();
  1227. refundFee += bean.getRefundFee();
  1228. }
  1229. }
  1230. double returnValue = 0d; //退货价值
  1231. if (order.getDiscountFee() >= returnedPurchaseFee) {
  1232. returnValue = 0d; //如果经理折扣大于退款(退货)总金额之和 那么先抵扣经理折扣 退款价值为0
  1233. } else {
  1234. returnValue = returnedPurchaseFee - order.getDiscountFee(); //抵用完经理折扣后才是真实价值
  1235. }
  1236. //订单已收金额
  1237. Double receiptAmount = cmDiscernReceiptService.findOrderReceipt(order.getOrderID());
  1238. model.addAttribute("returnValue", returnValue);
  1239. model.addAttribute("receiptAmount", receiptAmount == null ? 0 : receiptAmount);
  1240. model.addAttribute("returnedPurchaseFee", returnedPurchaseFee);
  1241. return "modules/order/orderDetail";
  1242. }
  1243. /**
  1244. * 去拆分订单详情页 5.0.0版本
  1245. *
  1246. * @param order
  1247. * @return
  1248. */
  1249. @RequiresPermissions("order:order:edit")
  1250. @RequestMapping("toSplit")
  1251. public String toSplit(NewOrder order, Model model) {
  1252. BpClause bpClause = new BpClause();
  1253. bpClause.setEnabledStatus("1");
  1254. List<BpClause> bpClauses = bpClauseService.findList(bpClause);
  1255. model.addAttribute("bpClauses", bpClauses);
  1256. model.addAttribute("order", order);
  1257. return "modules/order/splitPage";
  1258. }
  1259. /**
  1260. * 普通订单修改
  1261. *
  1262. * @param order
  1263. * @param model
  1264. * @return
  1265. */
  1266. @RequiresPermissions("order:order:edit")
  1267. @RequestMapping("normalOrderModify")
  1268. public String normalOrderModify(NewOrder order, Model model) {
  1269. model.addAttribute("order", order);
  1270. return "modules/order/modifyProduct";
  1271. }
  1272. /**
  1273. * 更新普通订单
  1274. *
  1275. * @param newOrder
  1276. * @param model
  1277. * @return
  1278. */
  1279. @RequiresPermissions("order:order:edit")
  1280. @RequestMapping("updateNormalOrder")
  1281. public String updateNormalOrder(NewOrder newOrder, Model model) {
  1282. if (!beanValidator(model, newOrder)) {
  1283. return normalOrderModify(newOrder, model);
  1284. }
  1285. if (CollectionUtils.isEmpty(newOrder.getOrderProduct())) {
  1286. model.addAttribute("message", "保存失败商品不能为空");
  1287. return normalOrderModify(newOrder, model);
  1288. } else {
  1289. List<NewOrderProduct> orderProductList = Lists.newArrayList();
  1290. for (NewOrderProduct newOrderProduct : newOrder.getOrderProduct()) {
  1291. if (StringUtils.isNotEmpty(newOrderProduct.getEnabledStatus())) {
  1292. NewOrderProduct o = (NewOrderProduct) JsonMapper.fromJsonString(newOrderProduct.getEnabledStatus(), NewOrderProduct.class);
  1293. Integer presentNum = o.getPresentNum() != null ? o.getPresentNum() : 0;
  1294. o.setPreferential((o.getPrice() - o.getDiscountPrice()) * o.getNum());//折扣
  1295. o.setDiscountFee(o.getTotalFee() - o.getShouldPayFee());//经理折扣
  1296. o.setTotalAmount(o.getPrice() * o.getNum());//商品总金额
  1297. o.setNotOutStore(o.getNum() + presentNum);
  1298. orderProductList.add(o);
  1299. }
  1300. }
  1301. if (CollectionUtils.isNotEmpty(orderProductList)) {
  1302. newOrder.setOrderProduct(orderProductList);
  1303. }
  1304. }
  1305. //更新订单
  1306. newOrderService.updateNormalOrder(newOrder);
  1307. return "redirect:" + Global.getAdminPath() + "/order/detailPage/?id=" + newOrder.getOrderID();
  1308. }
  1309. /**
  1310. * 物流详情展示
  1311. * <p>
  1312. * // * @param shopOrderID
  1313. *
  1314. * @param model
  1315. * @return
  1316. */
  1317. @RequiresPermissions("order:order:edit")
  1318. @RequestMapping("logisticsDetails")
  1319. public String logisticsDetails(Integer orderID, String logisticsBatchID, Model model) {
  1320. List<LogisticsInfoVo> logisticsInfoVos = new ArrayList<>();
  1321. logisticsInfoVos = newShopOrderService.logisticsDetails(orderID, logisticsBatchID);
  1322. model.addAttribute("orderID", orderID);
  1323. model.addAttribute("logisticsInfoVos", logisticsInfoVos);
  1324. return "modules/order/logisticsDetails";
  1325. }
  1326. /**
  1327. * 删除订单
  1328. *
  1329. * @return
  1330. */
  1331. @RequiresPermissions("order:order:delete")
  1332. @RequestMapping("deleteOrder")
  1333. public String deleteOrder(NewOrder order, Integer shopOrderID) {
  1334. if (order.getOrderID() != null) {
  1335. newOrderService.deleteOrder(order);
  1336. } else if (shopOrderID != null) {
  1337. newShopOrderService.deleteOrder(shopOrderID);
  1338. }
  1339. return "redirect:" + Global.getAdminPath() + "/order/orderList";
  1340. }
  1341. // 保存订单条款信息
  1342. @RequestMapping(value = "editclausecontent")
  1343. public String editclausecontent(NewOrder order, Model model) {
  1344. model.addAttribute("order", order);
  1345. return "modules/order/orderClause";
  1346. }
  1347. @RequestMapping(value = "saveClause")
  1348. public String saveClause(NewOrder order, RedirectAttributes redirectAttributes, HttpServletRequest request) {
  1349. String clauseContent = request.getParameter("clauseContent");
  1350. String clauseName = request.getParameter("clauseName");
  1351. order.setClauseContent(clauseContent);
  1352. order.setClauseName(clauseName);
  1353. newOrderService.updateClauseContent(order);
  1354. if (order.getOrderID() == null) {
  1355. //订单重新保存后则修改订单商品需供应商确认
  1356. newOrderProductService.updateShopConfigFlag(order.getOrderID());
  1357. }
  1358. return "redirect:" + Global.getAdminPath() + "/order/orderList";
  1359. }
  1360. /**
  1361. * 导出订单信息
  1362. *
  1363. * @param contractOrder
  1364. * @param shopOrderID
  1365. * @return
  1366. */
  1367. @RequiresPermissions("order:order:export")
  1368. @RequestMapping(value = "exportOrderInfo")
  1369. public void exportOrderInfo(NewOrder contractOrder, Integer shopOrderID, RedirectAttributes redirectAttributes, HttpServletResponse response) {
  1370. //获取订单数据
  1371. String fileName = contractOrder.getOrderID() + "-" + contractOrder.getBpOrderUserinfo().getName() + "-采美365网购订单.xls";
  1372. String template = Global.getConfig("export.template");
  1373. String templateFileName = template + "/new_bpstages_template.xls";
  1374. try {
  1375. List<NewOrderProduct> products = newOrderProductService.findWithOrderID(contractOrder.getOrderID());
  1376. for (NewOrderProduct orderProduct2 : products) {
  1377. //如果 =0 则设置为 0 方便页面判断
  1378. BigDecimal totalPay = new BigDecimal(orderProduct2.getTotalFee());
  1379. if (totalPay.compareTo(BigDecimal.ZERO) == 0) {
  1380. orderProduct2.setTotalFee(0D);
  1381. }
  1382. //设置税费
  1383. if (null == orderProduct2.getAddedValueTax() || "".equals(orderProduct2.getAddedValueTax()) || new BigDecimal(orderProduct2.getAddedValueTax()).compareTo(BigDecimal.ZERO) == 0) {
  1384. orderProduct2.setAddedValueTax(0D);
  1385. }
  1386. String image = orderProduct2.getImage();
  1387. //设置图片完整路径
  1388. orderProduct2.setImage(AppUtils.getProductImageURL(image, 0, Global.getConfig("wwwServer")));
  1389. }
  1390. List<NewOrderProduct> products1 = newOrderProductService.findByOrderIdGroupByShopId(contractOrder.getOrderID());
  1391. StringBuffer shopNameInfo = new StringBuffer();
  1392. //设置供应商信息
  1393. for (NewOrderProduct orderProduct1 : products1) {
  1394. shopNameInfo.append(orderProduct1.getShopName() + "、");
  1395. }
  1396. shopNameInfo.setLength(shopNameInfo.length() - 1);
  1397. contractOrder.setShopNameInfo(shopNameInfo.toString());
  1398. //设置订单商品信息
  1399. contractOrder.setOrderProduct(products);
  1400. BigDecimal stagesTotalFee = new BigDecimal(0);
  1401. StringBuffer buffer = new StringBuffer();
  1402. //设置list数据
  1403. List<NewOrder> list = Lists.newArrayList();
  1404. contractOrder.setClauseContent(StringUtils.replaceHtml(contractOrder.getClauseContent()));
  1405. list.add(contractOrder);
  1406. new ExcelUtil().createExcel(templateFileName, list, fileName, response);
  1407. } catch (Exception e) {
  1408. addMessage(redirectAttributes, "订单信息导出失败!" + e.getMessage());
  1409. e.printStackTrace();
  1410. }
  1411. }
  1412. /**
  1413. * 对账订单
  1414. *
  1415. * @param endTime 收款结束
  1416. * @param startTime 收款开始
  1417. * @param searchflag 0搜索,1导出
  1418. * @return
  1419. */
  1420. @RequiresPermissions("order:order:edit")
  1421. @RequestMapping("checkAccount")
  1422. public String checkAccount(String startTime, String endTime, Page page, String searchflag, Model model, RedirectAttributes redirectAttributes, HttpServletResponse response) {
  1423. if (StringUtils.isNotEmpty(startTime)) {
  1424. model.addAttribute("startTime", startTime);
  1425. startTime = startTime + " 00:00:00";
  1426. }
  1427. if (StringUtils.isNotEmpty(endTime)) {
  1428. model.addAttribute("endTime", endTime);
  1429. endTime = endTime + " 23:59:59";
  1430. }
  1431. NewReceiptList nr = new NewReceiptList();
  1432. nr.setStartTime(startTime);
  1433. nr.setEndTime(endTime);
  1434. page.setPageSize(10);
  1435. nr.setPage(page);
  1436. List<NewReceiptList> checkAccountList = newReceiptListService.findCheckAccountList(nr);
  1437. if (StringUtils.isNotEmpty(searchflag) && searchflag.length() != 2) {//导出操作
  1438. NewReceiptList nrExcel = new NewReceiptList();
  1439. nrExcel.setStartTime(startTime);
  1440. nrExcel.setEndTime(endTime);
  1441. List<NewReceiptList> excelList = newReceiptListService.findCheckAccountList(nrExcel);
  1442. setInit(excelList);
  1443. try {
  1444. excel(response, excelList);
  1445. } catch (Exception e) {
  1446. addMessage(redirectAttributes, "采美财务对账列表!" + e.getMessage());
  1447. e.printStackTrace();
  1448. }
  1449. }
  1450. setInit(checkAccountList);//初始化列表数据
  1451. page.setList(checkAccountList);
  1452. model.addAttribute("page", page);
  1453. return "modules/order/checkAccountOrder";
  1454. }
  1455. public void setInit(List<NewReceiptList> checkAccountList) {
  1456. if (CollectionUtils.isNotEmpty(checkAccountList)) {
  1457. for (NewReceiptList neList : checkAccountList) {
  1458. //统计订单已收总金额(已收商品金额+已收运费)
  1459. String received = neList.getReceived();//已收商品金额
  1460. neList.setReceivedTotal(received);//给定已收总金额默认值(协销订单没有运费,以及普通订单未付款或者到付情况下已收总金额=已收商品金额)
  1461. String orderTypeSys = neList.getOrderTypeSys();//订单类型---协销订单:0 ;普通订单:1
  1462. String status = neList.getStatus();//0, "待付款" 1,"待确认" 2, "已付款" "6, "交易关闭
  1463. String freight = neList.getFreight();//运费
  1464. String freePostFlag = neList.getFreePostFlag();//免邮标志 运费:-1到付,0包邮,1需要运费
  1465. if (StringUtils.equals(orderTypeSys, "1")) {//普通订单
  1466. if (StringUtils.equals(status, "2")) {//已付款
  1467. if (StringUtils.equals(freePostFlag, "1")) {//需要运费
  1468. double receivedD = Double.parseDouble(received);
  1469. double freightD = Double.parseDouble(freight);
  1470. double newReceivedTotal = receivedD + freightD;
  1471. neList.setReceivedTotal(String.valueOf(newReceivedTotal));//如果存在已付款的订单并且存在运费则已收金额需要加上运费
  1472. }
  1473. }
  1474. }
  1475. //订单全年99包邮处理
  1476. List<NewOrderProduct> orderProductList = newOrderProductDao.findListByOrderID(neList.getOrderId());
  1477. if (CollectionUtils.isNotEmpty(orderProductList) && orderProductList.size() > 0) {
  1478. for (NewOrderProduct nop : orderProductList) {
  1479. Integer orderProductID = nop.getProductID();
  1480. if (4413 == orderProductID) {
  1481. neList.setPostageFlag("1");//该订单是否包含99元包邮劵商品:0不是,1是99包邮劵
  1482. }
  1483. }
  1484. }
  1485. Map<String, Integer> typeMap = new HashMap<>();//存在同一个付款方式,过滤
  1486. //设置支付方式(客户付款)
  1487. String payWay = neList.getPayWay();
  1488. String payways = "";
  1489. if (StringUtils.isNotEmpty(payWay)) {
  1490. String[] split = payWay.split(",");
  1491. if (null != split) {
  1492. for (int i = 0; i < split.length; i++) {
  1493. Integer s = Integer.parseInt(split[i]);
  1494. String newPayWayName = NewPayWay.getNewPayWayName(s) + ",";
  1495. payways += newPayWayName;
  1496. }
  1497. }
  1498. }
  1499. if (null != payways && payways.length() > 0)
  1500. neList.setPayWay(payways.substring(0, payways.length() - 1));
  1501. //设置交易方式(付给供应商)
  1502. String transactionType = newReceiptListService.findTransactionType(neList.getOrderNo());
  1503. if (StringUtils.isNotEmpty(transactionType)) {
  1504. String[] split = transactionType.split(",");
  1505. if (null != split) {
  1506. for (int i = 0; i < split.length; i++) {
  1507. Integer s = Integer.parseInt(split[i]);
  1508. typeMap.put("" + s, s);
  1509. }
  1510. }
  1511. }
  1512. String transactionTypes = "";
  1513. if (null != typeMap) {
  1514. for (Integer s : typeMap.values()) {
  1515. if (102 == s) {
  1516. transactionTypes += "线下-建设银行7297,";
  1517. } else if (103 == s) {
  1518. transactionTypes += "线下-中信银行0897,";
  1519. } else if (104 == s) {
  1520. transactionTypes += "线下-中信银行7172,";
  1521. } else if (105 == s) {
  1522. transactionTypes += "线上-易宝支付,";
  1523. } else if (106 == s) {
  1524. transactionTypes += "线下-广发银行0115,";
  1525. } else if (101 == s) {
  1526. transactionTypes += "____________";
  1527. }
  1528. }
  1529. }
  1530. if (null != transactionTypes && transactionTypes.length() > 0)
  1531. neList.setTransactionType(transactionTypes.substring(0, transactionTypes.length() - 1));
  1532. //设置三个应付信息
  1533. NewReceiptList orderFees = newReceiptListService.findOrderFees(neList.getOrderId());
  1534. if (null != orderFees) {
  1535. neList.setTaxFee(orderFees.getTaxFee());
  1536. neList.setShopFee(orderFees.getShopFee());
  1537. neList.setOtherFee(orderFees.getOtherFee());
  1538. neList.setCmFee(orderFees.getCmFee());
  1539. } else {
  1540. neList.setTaxFee("0");
  1541. neList.setShopFee("0");
  1542. neList.setOtherFee("0");
  1543. neList.setCmFee("0");
  1544. }
  1545. //设置订单对应的供应商信息
  1546. List<NewOrderShop> newOrderShop = newReceiptListService.findNewOrderShop(neList.getOrderId());
  1547. neList.setNewOrderShopList(newOrderShop);
  1548. }
  1549. }
  1550. }
  1551. public void excel(HttpServletResponse response, List<NewReceiptList> excelList) {
  1552. //创建一个webbook,对应一个Excel文件
  1553. HSSFWorkbook wb = new HSSFWorkbook();
  1554. //在webbook中添加一个sheet,对应Excel文件中的sheet
  1555. HSSFSheet sheet = wb.createSheet("采美财务对账订单");
  1556. //创建单元格,并设置值表头 设置表头居中
  1557. HSSFCellStyle style = wb.createCellStyle();
  1558. style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//垂直
  1559. style.setAlignment(HSSFCellStyle.ALIGN_CENTER);//水平
  1560. style.setFillForegroundColor(HSSFColor.ORANGE.index);
  1561. HSSFCellStyle textStyle = wb.createCellStyle();
  1562. // textStyle.setf
  1563. // textStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 左右居中
  1564. // textStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 上下居中
  1565. //设置列宽(第几列,宽度)receivedTotal
  1566. sheet.setColumnWidth(0, 1500);//订单ID
  1567. sheet.setColumnWidth(1, 4800);//订单编号
  1568. sheet.setColumnWidth(2, 4800);//订单日期
  1569. sheet.setColumnWidth(3, 4800);//收款日期
  1570. sheet.setColumnWidth(4, 5000);//支付方式
  1571. sheet.setColumnWidth(5, 5000);//客户(会所)
  1572. sheet.setColumnWidth(6, 3200);//订单实付金额
  1573. sheet.setColumnWidth(7, 3200);//已收总金额
  1574. sheet.setColumnWidth(8, 3200);//已收商品金额
  1575. sheet.setColumnWidth(9, 3200);//已收运费
  1576. sheet.setColumnWidth(10, 5000);//付款方式
  1577. sheet.setColumnWidth(11, 3200);//应付税费
  1578. sheet.setColumnWidth(12, 3200);//应付供应商
  1579. sheet.setColumnWidth(13, 6000);//供应商名称
  1580. sheet.setColumnWidth(14, 3200);//支付类型
  1581. sheet.setColumnWidth(15, 3200);//已付金额
  1582. sheet.setColumnWidth(16, 3200);//应付第三方
  1583. sheet.setColumnWidth(17, 3200);//应付采美
  1584. sheet.setDefaultRowHeight((short) 0x270);//设置行高----貌似没有效果,所以下面每行独立设置行高
  1585. //第一行(表头)
  1586. String[] head = new String[]{"订单ID", "订单编号", "订单日期", "收款日期", "支付方式", "客户(会所)", "订单实付金额", "已收总金额", "已收商品金额", "已收运费", "付款方式", "应付税费", "应付供应商", "供应商名称", "支付类型", "已付金额", "应付第三方", "应付采美"};//在excel中的第4行每列的参数
  1587. HSSFCell cell;
  1588. HSSFRow row = sheet.createRow(0);
  1589. for (int i = 0; i < head.length; i++) {
  1590. cell = row.createCell(i);
  1591. row.setHeight((short) 0x270);
  1592. cell.setCellValue(head[i]);
  1593. cell.setCellStyle(style);
  1594. }
  1595. Integer currentUseRow = 1;//当前已使用行号(表头存在一行从1开始)
  1596. Integer currentMergeStartRow = 1;//开始合并行号
  1597. //循环遍历所有集合数据
  1598. if (CollectionUtils.isNotEmpty(excelList)) {
  1599. for (NewReceiptList rp : excelList) {
  1600. List<NewOrderShop> newOrderShopList = rp.getNewOrderShopList();
  1601. if (CollectionUtils.isNotEmpty(newOrderShopList)) {
  1602. int size = newOrderShopList.size() * 2;
  1603. for (int i = 0; i < newOrderShopList.size() * 2; i++) {
  1604. String shopName = "";
  1605. //String shopFees = newOrderShopList.get(i).getShopFees();//已付供应商金额
  1606. //1、首先求解本次遍历的i原始值是多少(列如:i=0[0/1],i=1[2/3],i=2[4/5]当为[]中的值时i的原始值如i)(相邻两行需相同,合并所需)
  1607. //1.1、求解公式集合原始i的值【为基数时:遍历i的值 减 1 除 2 、为偶数时:遍历i的值 除 2】
  1608. if (0 == i) {
  1609. shopName = newOrderShopList.get(i).getShopName();
  1610. } else {
  1611. int valuei = i;
  1612. boolean isEven = false;//是否是偶数,默认基数
  1613. isEven = i % 2 == 0 ? true : false;//是否是偶数
  1614. if (isEven) {//偶数
  1615. valuei = i / 2;
  1616. } else {//基数
  1617. valuei = (i - 1) / 2;
  1618. }
  1619. shopName = newOrderShopList.get(valuei).getShopName();
  1620. }
  1621. HSSFRow row2 = sheet.createRow(currentUseRow);
  1622. row2.setHeight((short) 0x270);
  1623. //创建订单ID列
  1624. cell = row2.createCell(0);
  1625. cell.setCellValue(rp.getOrderId());
  1626. cell.setCellStyle(textStyle);
  1627. //创建订单编号列
  1628. cell = row2.createCell(1);
  1629. cell.setCellValue(rp.getOrderNo());
  1630. cell.setCellStyle(textStyle);
  1631. //创建订单日期列
  1632. cell = row2.createCell(2);
  1633. String createTime = "———————";
  1634. if (null != rp.getCreateDate()) {
  1635. createTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(rp.getCreateDate());
  1636. }
  1637. cell.setCellValue(createTime);
  1638. cell.setCellStyle(textStyle);
  1639. //创建收款日期列
  1640. cell = row2.createCell(3);
  1641. String PayTime = "———————";
  1642. if (null != rp.getPayTime()) {
  1643. PayTime = rp.getPayTime();
  1644. }
  1645. cell.setCellValue(PayTime);
  1646. cell.setCellStyle(textStyle);
  1647. //创建支付方式列
  1648. cell = row2.createCell(4);
  1649. String payWay = "———————";
  1650. if (StringUtils.isNotEmpty(rp.getPayWay())) {
  1651. payWay = rp.getPayWay();
  1652. }
  1653. cell.setCellValue(payWay);
  1654. cell.setCellStyle(textStyle);
  1655. //创建客户(会所)列
  1656. cell = row2.createCell(5);
  1657. cell.setCellValue(rp.getName());
  1658. cell.setCellStyle(textStyle);
  1659. //创建订单实付金额列
  1660. cell = row2.createCell(6);
  1661. String payTotalFee = "0";
  1662. if (null != rp.getReceived()) {
  1663. payTotalFee = String.format("%.2f", Double.parseDouble(rp.getPayTotalFee()));
  1664. }
  1665. String postageFlag = rp.getPostageFlag();//该订单是否包含99元包邮劵商品:0不是,1是99包邮劵
  1666. if (StringUtils.equals("1", postageFlag)) {
  1667. payTotalFee = payTotalFee + "(含99元包邮劵)";
  1668. }
  1669. cell.setCellValue(payTotalFee);
  1670. cell.setCellStyle(textStyle);
  1671. //创建已收总金额列
  1672. cell = row2.createCell(7);
  1673. String receivedTotal = "0";
  1674. if (null != rp.getReceivedTotal()) {
  1675. receivedTotal = String.format("%.2f", Double.parseDouble(rp.getReceivedTotal()));
  1676. }
  1677. cell.setCellValue(receivedTotal);
  1678. cell.setCellStyle(textStyle);
  1679. //创建已收商品金额列
  1680. cell = row2.createCell(8);
  1681. String received = "0";
  1682. if (null != rp.getReceived()) {
  1683. received = String.format("%.2f", Double.parseDouble(rp.getReceived()));
  1684. }
  1685. cell.setCellValue(received);
  1686. cell.setCellStyle(textStyle);
  1687. //创建已收运费列
  1688. cell = row2.createCell(9);
  1689. String freight = "0";//默认运费
  1690. String status = rp.getStatus();//状态:0, "待付款" 1,"待确认" 2, "已付款" "6, "交易关闭
  1691. String freePostFlag = rp.getFreePostFlag();//免邮标志 运费:-1到付,0包邮,1需要运费
  1692. //没区分协销或者普通订单,因为协销订单运费默认为0不影响
  1693. if (StringUtils.equals(status, "2")) {//已付款
  1694. if (StringUtils.equals(freePostFlag, "-1")) {//-1到付
  1695. freight = "到付";
  1696. } else if (StringUtils.equals(freePostFlag, "0")) {//0包邮
  1697. freight = "包邮";
  1698. } else if (StringUtils.equals(freePostFlag, "1")) {//运费
  1699. freight = rp.getFreight();
  1700. }
  1701. } else {//未付款
  1702. if (StringUtils.equals(freePostFlag, "-1")) {//-1到付
  1703. freight = "到付";
  1704. } else if (StringUtils.equals(freePostFlag, "0")) {//0包邮
  1705. freight = "包邮";
  1706. } else if (StringUtils.equals(freePostFlag, "1")) {//运费
  1707. freight = "0";
  1708. }
  1709. }
  1710. cell.setCellValue(freight);
  1711. cell.setCellStyle(textStyle);
  1712. //创建付款方式列
  1713. cell = row2.createCell(10);
  1714. String transactionType = "———————";
  1715. if (null != rp.getTransactionType()) {
  1716. transactionType = rp.getTransactionType();
  1717. }
  1718. cell.setCellValue(transactionType);
  1719. cell.setCellStyle(textStyle);
  1720. //创建应付税费列
  1721. cell = row2.createCell(11);
  1722. String taxFee = "0";
  1723. if (null != rp.getTaxFee()) {
  1724. taxFee = String.format("%.2f", Double.parseDouble(rp.getTaxFee()));
  1725. }
  1726. cell.setCellValue(taxFee);
  1727. cell.setCellStyle(textStyle);
  1728. //创建应付供应商列
  1729. cell = row2.createCell(12);
  1730. String shopFee = "0";
  1731. if (null != rp.getShopFee()) {
  1732. shopFee = String.format("%.2f", Double.parseDouble(rp.getShopFee()));
  1733. }
  1734. cell.setCellValue(shopFee);
  1735. cell.setCellStyle(textStyle);
  1736. //11创建动态已收供应商列
  1737. cell = row2.createCell(13);//供应商名称
  1738. cell.setCellValue(shopName);
  1739. //公式解析等同上解释---(每个供应商存在两个账:公、私账)---遍历对应公私账的列数
  1740. if (0 == i) {//公账
  1741. cell = row2.createCell(14);//支付类型
  1742. cell.setCellValue("公账");
  1743. String publicAccount = newOrderShopList.get(i).getPublicAccount();
  1744. if (StringUtils.isEmpty(publicAccount)) {
  1745. publicAccount = "0";
  1746. }
  1747. cell = row2.createCell(15);//已付金额
  1748. cell.setCellValue(publicAccount);
  1749. } else {
  1750. int valuei = i;
  1751. boolean isEven = false;//是否是偶数,默认基数
  1752. isEven = i % 2 == 0 ? true : false;//是否是偶数
  1753. if (isEven) {//偶数(公账)
  1754. valuei = i / 2;
  1755. cell = row2.createCell(14);//支付类型
  1756. cell.setCellValue("公账");
  1757. String publicAccount = newOrderShopList.get(valuei).getPublicAccount();
  1758. if (StringUtils.isEmpty(publicAccount)) {
  1759. publicAccount = "0";
  1760. }
  1761. cell = row2.createCell(15);//已付金额
  1762. cell.setCellValue(publicAccount);
  1763. } else {//基数(私账)
  1764. valuei = (i - 1) / 2;
  1765. cell = row2.createCell(14);//支付类型
  1766. cell.setCellValue("私账");
  1767. String privateAccount = newOrderShopList.get(valuei).getPrivateAccount();
  1768. if (StringUtils.isEmpty(privateAccount)) {
  1769. privateAccount = "0";
  1770. }
  1771. cell = row2.createCell(15);//已付金额
  1772. cell.setCellValue(privateAccount);
  1773. }
  1774. }
  1775. //创建应付三方
  1776. cell = row2.createCell(16);//应付三方
  1777. String otherFee = "0";
  1778. if (null != rp.getOtherFee()) {
  1779. otherFee = String.format("%.2f", Double.parseDouble(rp.getOtherFee()));
  1780. }
  1781. cell.setCellValue(otherFee);
  1782. cell.setCellStyle(textStyle);
  1783. //创建应付采美
  1784. cell = row2.createCell(17);
  1785. String cmFee = "0";
  1786. if (null != rp.getCmFee()) {
  1787. cmFee = String.format("%.2f", Double.parseDouble(rp.getCmFee()));
  1788. }
  1789. cell.setCellValue(cmFee);
  1790. cell.setCellStyle(textStyle);
  1791. currentUseRow += 1;//供应商大小*2决定的存在的行数(累计统计)
  1792. }
  1793. //合并订单数据(除供应商名称和已付金额外都合并)
  1794. for (int j = currentMergeStartRow; j < currentUseRow; j++) {
  1795. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 0, 0));//起始行号,终止行号, 起始列号,终止列号
  1796. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 1, 1));//起始行号,终止行号, 起始列号,终止列号
  1797. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 2, 2));//起始行号,终止行号, 起始列号,终止列号
  1798. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 3, 3));//起始行号,终止行号, 起始列号,终止列号
  1799. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 4, 4));//起始行号,终止行号, 起始列号,终止列号
  1800. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 5, 5));//起始行号,终止行号, 起始列号,终止列号
  1801. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 6, 6));//起始行号,终止行号, 起始列号,终止列号
  1802. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 7, 7));//起始行号,终止行号, 起始列号,终止列号
  1803. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 8, 8));//起始行号,终止行号, 起始列号,终止列号
  1804. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 9, 9));//起始行号,终止行号, 起始列号,终止列号
  1805. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 10, 10));//起始行号,终止行号, 起始列号,终止列号
  1806. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 11, 11));//起始行号,终止行号, 起始列号,终止列号
  1807. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 12, 12));//起始行号,终止行号, 起始列号,终止列号
  1808. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 16, 16));//起始行号,终止行号, 起始列号,终止列号
  1809. sheet.addMergedRegion(new CellRangeAddress(j, currentUseRow - 1, 17, 17));//起始行号,终止行号, 起始列号,终止列号
  1810. }
  1811. currentMergeStartRow += size;//提供下一个订单出账合并使用
  1812. }
  1813. }
  1814. }
  1815. try {
  1816. ByteArrayOutputStream os = new ByteArrayOutputStream();
  1817. wb.write(os);
  1818. //调用浏览器自带的下载器,要先将数据转成byte流
  1819. String fileName = "采美订单对账列表.xls";
  1820. byte[] content = os.toByteArray();
  1821. response.setContentType("application/x-download");
  1822. response.setHeader("Content-disposition", "attachment; filename=" + Encodes.urlEncode(fileName));
  1823. response.getOutputStream().write(content);
  1824. response.getOutputStream().flush();
  1825. response.getOutputStream().close();
  1826. os.flush();
  1827. os.close();
  1828. } catch (Exception e) {
  1829. e.printStackTrace();
  1830. }
  1831. }
  1832. /**
  1833. * date 2019-1-28
  1834. * 最新的导出功能 以子订单来导出
  1835. * 导出子订单信息
  1836. *
  1837. * @param shopOrderID
  1838. * @return
  1839. */
  1840. @RequiresPermissions("order:order:export")
  1841. @RequestMapping(value = "exportSubOrder")
  1842. public void exportSubOrder(Integer shopOrderID, RedirectAttributes redirectAttributes, HttpServletResponse response) {
  1843. //获取订单数据
  1844. if (shopOrderID != null) {
  1845. NewShopOrder shopOrder = newShopOrderService.findByShopOrderID(shopOrderID);
  1846. if (shopOrder == null) {
  1847. addMessage(redirectAttributes, "参数异常, 订单信息导出失败!");
  1848. return;
  1849. }
  1850. NewOrder order = newOrderService.get(shopOrder.getOrderID().toString());
  1851. String fileName = order.getOrderID() + "-" + order.getBpOrderUserinfo().getName() + "-采美365网购订单.xls";
  1852. String template = Global.getConfig("export.template");
  1853. String templateFileName = template + "/shopOrder_template.xls";
  1854. OrderUserInfo orderUserInfo = orderUserInfoService.findByOrderID(order.getOrderID());
  1855. Map data = new HashMap<String, Object>();
  1856. data.put("shopOrder", shopOrder);
  1857. data.put("order", order);
  1858. data.put("orderUserInfo", orderUserInfo);
  1859. new ExcelUtil().createExcel(templateFileName, data, fileName, response);
  1860. } else {
  1861. addMessage(redirectAttributes, "参数异常, 订单信息导出失败!");
  1862. return;
  1863. }
  1864. }
  1865. /**
  1866. * 导出订单信息
  1867. *
  1868. * @param order
  1869. * @return
  1870. */
  1871. @RequiresPermissions("order:order:export")
  1872. @RequestMapping(value = "exportOrder")
  1873. public void exportOrder(NewOrder order, RedirectAttributes redirectAttributes, HttpServletResponse response) {
  1874. //获取订单数据
  1875. String fileName = order.getOrderID() + "-" + order.getBpOrderUserinfo().getName() + "-采美365网购订单.xls";
  1876. String template = Global.getConfig("export.template");
  1877. String templateFileName = template + "/order_info_template.xls";
  1878. try {
  1879. //freight 运费要算一下 ,totalAddedValueTax
  1880. Map data = new HashMap<String, Object>();
  1881. data.put("order", order);
  1882. new ExcelUtil().createExcel(templateFileName, data, fileName, response);
  1883. } catch (Exception e) {
  1884. addMessage(redirectAttributes, "订单信息导出失败!" + e.getMessage());
  1885. e.printStackTrace();
  1886. }
  1887. }
  1888. /**
  1889. * @return
  1890. */
  1891. @RequiresPermissions("order:order:edit")
  1892. @RequestMapping(value = "postageOrderForm")
  1893. public String postageOrderForm(NewOrder newOrder, Model model) {
  1894. newOrder.setFreight(10D);
  1895. model.addAttribute("order", newOrder);
  1896. return "modules/order/postageOrderForm";
  1897. }
  1898. @RequiresPermissions("order:order:edit")
  1899. @RequestMapping(value = "postageOrderSave")
  1900. public String postageOrderSave(NewOrder newOrder, Model model, RedirectAttributes redirectAttributes, HttpServletRequest request) {
  1901. if (!beanValidator(model, newOrder)) {
  1902. return form(newOrder, model, request);
  1903. }
  1904. //保存订单
  1905. newOrderService.postageOrderSave(newOrder);
  1906. addMessage(redirectAttributes, "保存订单成功");
  1907. return "redirect:" + Global.getAdminPath() + "/order/orderList";
  1908. }
  1909. /**
  1910. * 编辑经理折扣
  1911. */
  1912. @RequiresPermissions("order:order:edit")
  1913. @RequestMapping(value = "DiscountFee")
  1914. public String editDiscountFee(NewOrder newOrder, Model model, RedirectAttributes redirectAttributes) {
  1915. NewOrder order = newOrderService.editDiscountFee(newOrder);
  1916. model.addAttribute("order", order);
  1917. return "modules/order/newOrderEdit";
  1918. }
  1919. /**
  1920. * 保存经理折扣
  1921. */
  1922. @RequiresPermissions("order:order:edit")
  1923. @ResponseBody
  1924. @RequestMapping(value = "saveDiscountFee")
  1925. public Map<String, Object> saveDiscountFee(NewOrder newOrder) {
  1926. Map<String, Object> map = new HashMap();
  1927. try {
  1928. newOrderService.saveDiscountFee(newOrder);
  1929. map.put("success", true);
  1930. map.put("msg", "修改经理折扣成功");
  1931. } catch (Exception e) {
  1932. map.put("success", false);
  1933. map.put("msg", "修改经理折扣失败");
  1934. }
  1935. return map;
  1936. }
  1937. /**
  1938. * 供应商订单二维码
  1939. */
  1940. @ResponseBody
  1941. @RequestMapping("/shopOrderLink")
  1942. public Map<String, Object> shopOrderLink(Integer shopOrderId) {
  1943. Map<String, Object> map = new HashMap<>();
  1944. if (null == shopOrderId) {
  1945. map.put("success", false);
  1946. map.put("msg", "参数异常");
  1947. return map;
  1948. }
  1949. return newOrderService.shopOrderLink(shopOrderId);
  1950. }
  1951. /**
  1952. * 抹平收款数据显示
  1953. */
  1954. @ResponseBody
  1955. @RequestMapping("/gatheringData")
  1956. public Map<String, Object> gatheringData(Integer orderId) {
  1957. Map<String, Object> map = new HashMap<>();
  1958. if (null == orderId) {
  1959. map.put("success", false);
  1960. map.put("msg", "参数异常");
  1961. return map;
  1962. }
  1963. return newOrderService.gatheringData(orderId);
  1964. }
  1965. /**
  1966. * 抹平收款
  1967. */
  1968. @RequestMapping("/smoothOutCollection")
  1969. public void smoothOutCollection(CmDiscernReceipt discernReceipt) {
  1970. newOrderService.smoothOutCollection(discernReceipt);
  1971. }
  1972. /**
  1973. * 余额抵扣
  1974. */
  1975. @RequestMapping("balanceDeduction")
  1976. public String balanceDeduction(Integer orderID, RedirectAttributes redirectAttributes) {
  1977. newOrderService.balanceDeduction(orderID);
  1978. addMessage(redirectAttributes, "余额抵扣成功");
  1979. return "redirect:" + Global.getAdminPath() + "/order/orderList";
  1980. }
  1981. /**
  1982. * 转为返佣订单
  1983. */
  1984. @RequestMapping("modifyRebate")
  1985. public String modifyRebate(Integer orderId) {
  1986. newOrderService.modifyRebate(orderId);
  1987. return "redirect:" + Global.getAdminPath() + "/order/orderList";
  1988. }
  1989. /**
  1990. * 商品资质列表
  1991. */
  1992. @RequestMapping("qualificationList")
  1993. public String qualificationList(Integer logisticsBatchId, Model model) {
  1994. List<LogisticsRecord> logisticsRecords = newOrderService.qualificationList(logisticsBatchId);
  1995. model.addAttribute("logisticsRecords", logisticsRecords);
  1996. Integer orderId = 0;
  1997. if (logisticsRecords != null && logisticsRecords.size() > 0) {
  1998. orderId = logisticsRecords.get(0).getOrderID();
  1999. }
  2000. model.addAttribute("orderId", orderId);
  2001. return "modules/order/qualification";
  2002. }
  2003. /**
  2004. * 商品资质编辑页面
  2005. */
  2006. @RequestMapping("qualificationForm")
  2007. public String qualificationForm(Integer recordId, Model model) {
  2008. LogisticsRecord logisticsRecord = newOrderService.qualificationForm(recordId);
  2009. model.addAttribute("logisticsRecord", logisticsRecord);
  2010. model.addAttribute("recordId", recordId);
  2011. return "modules/order/qualificationForm";
  2012. }
  2013. /**
  2014. * 商品资质保存
  2015. */
  2016. @RequestMapping("saveQualification")
  2017. public String saveQualification(LogisticsRecord logisticsRecord, RedirectAttributes redirectAttributes) {
  2018. newOrderService.saveQualification(logisticsRecord);
  2019. addMessage(redirectAttributes, "上传商品资质成功");
  2020. return "redirect:" + Global.getAdminPath() + "/order/qualificationList?logisticsBatchId=" + logisticsRecord.getLogisticsBatchID();
  2021. }
  2022. /**
  2023. * 查看商品资质
  2024. */
  2025. @RequestMapping("qualificationInfo")
  2026. public String qualificationInfo(Integer logisticsBatchId, Integer orderId, Model model) {
  2027. List<LogisticsRecord> recordList = newOrderService.qualificationInfo(logisticsBatchId);
  2028. model.addAttribute("recordList", recordList);
  2029. if (recordList != null && recordList.size() > 0) {
  2030. model.addAttribute("shopName", recordList.get(0).getShopName());
  2031. SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  2032. String uploadTime = format.format(recordList.get(0).getUploadTime());
  2033. model.addAttribute("uploadTime", uploadTime);
  2034. }
  2035. model.addAttribute("logisticsBatchId", logisticsBatchId);
  2036. model.addAttribute("orderId", orderId);
  2037. return "modules/order/qualificationInfo";
  2038. }
  2039. /**
  2040. * 获取当前机构下所有已领取优惠券
  2041. */
  2042. @ResponseBody
  2043. @RequestMapping("clubCouponList")
  2044. public Map<String, Object> clubCouponList(Integer userId) {
  2045. Map<String, Object> map = new HashMap<>();
  2046. if (null == userId) {
  2047. map.put("code", -1);
  2048. map.put("msg", "参数异常");
  2049. return map;
  2050. }
  2051. return newOrderService.clubCouponList(userId);
  2052. }
  2053. }