sale.js 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224
  1. $(function () {
  2. openWebSocket();
  3. queryAssistantInfo();
  4. });
  5. window.onbeforeunload = function(){
  6. closeWebSocket();
  7. }
  8. function calculateGoodsPrice(r){
  9. var rMap = r.map;
  10. var barCode = r.goodsDetails.prodBarcode;
  11. var brand = r.goodsDetails.brand;
  12. console.log(rMap);
  13. if(rMap.yhq){
  14. for(var i in rMap.yhq){
  15. vm.coupons.set(i,rMap.yhq[i]);
  16. }
  17. }
  18. // 是否有满减活动
  19. if(rMap.mj){
  20. if(rMap.mj[barCode] && !vm.mj.get(barCode)){
  21. // 该商品是否已经有过满减活动
  22. vm.mj.set(barCode,rMap.mj[barCode]);
  23. }else if(rMap.mj[brand] && !vm.mj.get(brand)){
  24. // 该品牌是否已经有过满减活动
  25. vm.mj.set(brand,rMap.mj[brand]);
  26. }
  27. }
  28. if(rMap.mysy){
  29. // 买的条码, 买的数量,送的条码,送的数量
  30. var mysy = {
  31. buyNum:rMap.mysy.buyNum,
  32. giftBarcode:rMap.mysy.giftBarcode,
  33. sendNum:rMap.mysy.sendNum
  34. };
  35. vm.newMysy.set(rMap.mysy.barcode , mysy);
  36. vm.mysy.push(rMap.mysy[barCode]);
  37. }
  38. if(rMap.mz){
  39. if(rMap.mz[barCode] && !vm.mz.get(barCode)){
  40. // 该商品是否已经有过满赠活动
  41. vm.mz.set(barCode,rMap.mz[barCode]);
  42. }else if(rMap.mz[brand] && !vm.mz.get(brand)){
  43. // 该品牌是否已经有过满赠活动
  44. vm.mz.set(brand,rMap.mz[brand]);
  45. }
  46. }
  47. if(rMap.zhjsp){
  48. // 遍历该商品所有可能的组合价商品类型
  49. for(var data in rMap.zhjsp){
  50. if(!vm.zhjsp.get(data)){
  51. // 分割组合价商品的条码,并以 条码:0 放入map中
  52. var barCodeArray = data.toString().split(":");
  53. var dataMap = new Map();
  54. console.log(rMap.zhjsp[data]);
  55. // dataMap.set();
  56. for(var j = 0 ; j < barCodeArray.length ; j ++){
  57. dataMap.set(barCodeArray[j],0);
  58. }
  59. vm.combinationPrice.set(data,rMap.zhjsp[data][0].combinedPrice)
  60. vm.zhjsp.set(data,dataMap);
  61. }
  62. }
  63. }
  64. calculateGoodsByMj(r.goodsDetails);
  65. calculateGoodsByMysy(r.goodsDetails);
  66. calculateGoodsByMz(r.goodsDetails);
  67. calculateGoodsByZhjsp(r);
  68. }
  69. // ==================== 满减==========================
  70. // 满减
  71. function calculateGoodsByMj(goodsDetails){
  72. if(vm.mj.get(goodsDetails.prodBarcode)){
  73. fullReduction(goodsDetails,goodsDetails.prodBarcode);
  74. }else if(vm.mj.get(goodsDetails.brand)){
  75. fullReduction(goodsDetails,goodsDetails.brand);
  76. }
  77. }
  78. // 满减的计算内容
  79. function fullReduction(goodsDetails,key){
  80. // 获取满减条件金额
  81. var qualifiedAmount = vm.mj.get(key).qualifiedAmount;
  82. // 获取已累积金额
  83. var money = vm.accumulatedAmount.get(key);
  84. if(isNaN(money)){
  85. money = goodsDetails.retailPrice;
  86. }else{
  87. money = money + goodsDetails.retailPrice;
  88. }
  89. if(money >= qualifiedAmount){
  90. vm.reduceMoney += vm.mj.get(key).deductionAmount; // 达到满减金额,获取扣减的额度
  91. vm.mj.delete(key); // 获取后删除该商品的满减
  92. vm.accumulatedAmount.delete(key); // 删除满减的金额
  93. }else{
  94. vm.accumulatedAmount.set(key,money);
  95. }
  96. }
  97. // ============================= 满赠 ==============================
  98. // 满赠
  99. function calculateGoodsByMz(goodsDetails){
  100. // 1.满赠的商品是不是自己,遍历满赠商品数组
  101. isSend(vm.fullGiftCode,goodsDetails,"满赠");
  102. if(vm.mz.get(goodsDetails.prodBarcode)){
  103. fullGift(goodsDetails,goodsDetails.prodBarcode);
  104. }else if(vm.mz.get(goodsDetails.brand)){
  105. fullGift(goodsDetails,goodsDetails.brand);
  106. }
  107. }
  108. function fullGift(goodsDetails,key){
  109. // 获取满赠条件金额
  110. var qualifiedAmount = vm.mz.get(key).qualifiedAmount;
  111. // 获取已累积金额
  112. var money = vm.accumulatedAmountForFullGift.get(key);
  113. if(isNaN(money)){
  114. money = goodsDetails.retailPrice;
  115. }else{
  116. money = money + goodsDetails.retailPrice;
  117. }
  118. // 达到满赠的要求
  119. if(money >= qualifiedAmount){
  120. // 将满赠的商品放入数组中,重置金额
  121. vm.fullGiftCode.push(vm.mz.get(key).giftBarcode);
  122. vm.mz.delete(key); // 获取后删除该商品的满减
  123. vm.accumulatedAmountForFullGift.delete(key); // 删除满减的金额
  124. // 2.购物车的商品里面是否有满赠的商品
  125. shopCartContain(vm.fullGiftCode,goodsDetails,"满赠");
  126. }else{
  127. vm.accumulatedAmountForFullGift.set(key,money);
  128. }
  129. }
  130. // 买一送一
  131. function calculateGoodsByMysy(goodsDetails){
  132. console.log(vm.newMysy);
  133. var mysy = vm.newMysy.get(goodsDetails.prodBarcode);
  134. if(mysy){
  135. var buyNum = mysy.buyNum;
  136. // 证明是买一送一,并且达到买一送一的条件
  137. if(buyNum == 1 && vm.boughtNum.get(goodsDetails.prodBarcode)){
  138. // 设置赠品的单价
  139. goodsDetails.discountedPrice = goodsDetails.retailPrice;
  140. goodsDetails.actualPaymentAmount = 0;
  141. goodsDetails.activity = "买1送1";
  142. // 清除该商品买一送一条件
  143. vm.boughtNum.delete(goodsDetails.proBarcode);
  144. }
  145. // 如果不是买一送一,而是买n送n,先获取购物车已有该类型商品数量
  146. var boughtNum = vm.boughtNum.get(goodsDetails.prodBarcode);
  147. // 如果没有,置为1
  148. if(!boughtNum){
  149. vm.boughtNum.set(goodsDetails.prodBarcode , 1);
  150. return ;
  151. }
  152. // 走到这里,证明购买过该类型商品,且数量不是买一送一的
  153. // 如果相等,证明达到送的条件
  154. if(buyNum === boughtNum){
  155. goodsDetails.discountedPrice = goodsDetails.retailPrice;
  156. goodsDetails.actualPaymentAmount = 0;
  157. goodsDetails.activity = "买"+buyNum+"送1";
  158. // 清除该商品买一送一条件
  159. vm.boughtNum.delete(goodsDetails.proBarcode);
  160. }else{
  161. // 如果不相等,已经购买数量+1
  162. vm.boughtNum.set(goodsDetails.prodBarcode , boughtNum+1);
  163. }
  164. }
  165. // 判断当前商品是否为赠品
  166. // isSend(vm.mysy,goodsDetails,"买一送一");
  167. // 判断购物车里面是否有商品为赠品
  168. // shopCartContain(vm.mysy,goodsDetails,"买一送一");
  169. }
  170. // 判断当前商品是否为赠品
  171. function isSend(activity,goodsDetails,activityName){
  172. if(activity.indexOf(goodsDetails.prodBarcode) >= 0){
  173. // 如果符合条件,把赠送的条码给删除(一次性)
  174. var index = activity.indexOf(goodsDetails.prodBarcode);
  175. activity.splice(index,1);
  176. // 设置赠品的单价
  177. goodsDetails.discountedPrice = goodsDetails.retailPrice;
  178. goodsDetails.actualPaymentAmount = 0;
  179. goodsDetails.activity = activityName;
  180. }
  181. }
  182. // 判断购物车里面是否有商品为赠品
  183. function shopCartContain(activity,goodsDetails,activityName){
  184. if(vm.goodsList && vm.goodsList.length > 0 ){
  185. for(var i = 0 ; i < vm.goodsList.length ; i ++){
  186. // 如果有商品为赠品,则把价格置位0并跳出循环
  187. if(activity.indexOf(vm.goodsList[i].prodBarcode) >= 0 && vm.goodsList[i].actualPaymentAmount != 0){
  188. // 如果符合条件,把赠送的条码给删除(一次性)
  189. var index = vm.mysy.indexOf(goodsDetails.prodBarcode);
  190. activity.splice(index,1);
  191. vm.goodsList[i].discountedPrice = vm.goodsList[i].retailPrice;
  192. vm.goodsList[i].actualPaymentAmount = 0;
  193. vm.goodsList[i].activity = activityName;
  194. vm.discountedPrice = vm.discountedPrice + vm.goodsList[i].retailPrice ;
  195. vm.actualPrice = vm.actualPrice - vm.goodsList[i].retailPrice ;
  196. break;
  197. }
  198. }
  199. }
  200. }
  201. // ======================= 组合价商品 ============================
  202. // 组合价商品
  203. function calculateGoodsByZhjsp(r){
  204. var barCode = r.goodsDetails.prodBarcode;
  205. if(r.map.zhjsp){
  206. // 将有组合的商品设置为1 ps:{"flag" => 0, "4005808550739" => 1, "4305615120454" => 0}
  207. vm.zhjsp.forEach(function(value,key,map){
  208. // 将组合价中组合的产品出现的次数+1
  209. value.forEach(function(v, k ,m){
  210. if(k === barCode)
  211. m.set(k,v+1);
  212. });
  213. var flag = 1;
  214. // 判断是否有商品成功组合
  215. value.forEach(function(v, k ,m){
  216. if(v === 0)
  217. flag = 0;
  218. });
  219. if(flag === 1){
  220. var combinationPrice = vm.combinationPrice.get(key);
  221. var barCodeArr = key.toString().split(":");
  222. // 扫码的商品条码 barCode
  223. for(var i = 0 ; i < barCodeArr.length ; i ++){
  224. var oldCode = barCodeArr[i];
  225. if(oldCode === barCode){
  226. continue;
  227. }
  228. if(vm.compareCombinationPrice.get(oldCode) && vm.compareCombinationPrice.get(oldCode) > combinationPrice){
  229. // 获取原组合关系
  230. var relationshipKey = vm.combinationRelationship.get(oldCode);
  231. // 将价格设置回原来的价格
  232. var keyArr = relationshipKey.toString().split(":");
  233. // 遍历原来的组合
  234. for(var j = 0 ; j < keyArr.length ; j ++){
  235. // 遍历购物车中原来的商品,替换价格
  236. for(var k = 0 ; k < vm.goodsList.length ; k ++){
  237. if(vm.goodsList[k].prodBarcode === keyArr[j] && vm.goodsList[k].activity == "组合价"){
  238. vm.discountedPrice = vm.discountedPrice - vm.goodsList[k].discountedPrice ;
  239. vm.actualPrice = vm.actualPrice + vm.goodsList[k].discountedPrice ;
  240. vm.goodsList[k].discountedPrice = 0 ; // 优惠价格
  241. vm.goodsList[k].actualPaymentAmount = vm.goodsList[k].retailPrice; // 实际支付价格
  242. vm.goodsList[k].isCombination = 0;
  243. vm.goodsList[k].activity = "";
  244. vm.compareCombinationPrice.delete(vm.goodsList[k].prodBarcode);
  245. vm.combinationRelationship.delete(vm.goodsList[k].prodBarcode);
  246. }
  247. }
  248. }
  249. }
  250. }
  251. for( var i = 0 ; i < barCodeArr.length ; i ++ ){
  252. // 如果是扫描的产品,直接退出,因为购物车中无该产品
  253. if(barCodeArr[i] == barCode){
  254. r.goodsDetails.isCombination = 1;
  255. r.goodsDetails.discountedPrice = r.goodsDetails.retailPrice - combinationPrice; // 优惠价格
  256. r.goodsDetails.actualPaymentAmount = combinationPrice; // 实际支付价格
  257. r.goodsDetails.activity = "组合价";
  258. vm.compareCombinationPrice.set(barCode,r.goodsDetails.actualPaymentAmount);
  259. vm.combinationRelationship.set(barCode,key);
  260. continue;
  261. }
  262. for(var j = 0 ; j < vm.goodsList.length ; j ++){
  263. if(vm.goodsList[j].prodBarcode === barCodeArr[i] && !vm.goodsList[j].isCombination){
  264. vm.goodsList[j].discountedPrice = vm.goodsList[j].retailPrice ; // 优惠价格
  265. vm.goodsList[j].actualPaymentAmount = 0; // 实际支付价格
  266. vm.goodsList[j].isCombination = 1;
  267. vm.goodsList[j].activity = "组合价";
  268. vm.discountedPrice = vm.discountedPrice + vm.goodsList[j].retailPrice ; // 总的优惠金额
  269. vm.actualPrice = vm.actualPrice - vm.goodsList[j].retailPrice ; // 总的实际支付金额
  270. vm.compareCombinationPrice.set(vm.goodsList[j].prodBarcode,vm.goodsList[j].actualPaymentAmount);
  271. vm.combinationRelationship.set(vm.goodsList[j].prodBarcode,barCode,key);
  272. break;
  273. }
  274. }
  275. }
  276. // 扣减
  277. var updateMap = map.get(key);
  278. updateMap.forEach(function(v, k ,m){
  279. m.set(k,v-1);
  280. });
  281. }
  282. });
  283. }
  284. console.log(vm.compareCombinationPrice);
  285. }
  286. let vm = new Vue({
  287. el: '#rrapp',
  288. data: {
  289. showList: true,
  290. goodsDetail:false,
  291. title: null,
  292. goods:{},
  293. sysNotice: {},
  294. goodsList:[],
  295. orderInfo:[],
  296. userInfo:{},
  297. //user信息绑定集合
  298. userInfoBinding: {},
  299. sysUserInfo:{},
  300. storeName:null,
  301. prodBarcode:null,
  302. sessionId:null,
  303. pickUpCodeList:[],
  304. goodsDetailList:[],
  305. orderEntity:{},
  306. orderProcessRecord:{},
  307. tax:0,
  308. currentOrderNo:null,
  309. customname:'',
  310. customidcard:'',
  311. machineCode:'',
  312. storeId:null,
  313. index:0,
  314. max:0,
  315. totalPrice:0,
  316. discountedPrice:0,
  317. actualPrice:0,
  318. ruleValidate: {
  319. name: [
  320. {required: true, message: '名称不能为空', trigger: 'blur'}
  321. ]
  322. },
  323. q: {
  324. name: ''
  325. },
  326. // 买一送一
  327. mysy: [],
  328. newMysy: new Map(),
  329. boughtNum: new Map(),
  330. // 组合价
  331. zhjsp: new Map(),
  332. combinationPrice: new Map(), // 组合价商品的组合价
  333. compareCombinationPrice: new Map(), // 用于比较组合价
  334. combinationRelationship: new Map(), // 组合价格的组合关系
  335. // 满减
  336. mj: new Map(),
  337. accumulatedAmount: new Map(), // 累积金额(满减使用的)
  338. reduceMoney:0, // 满减金额
  339. showReduceMoney:0, // 用于展示的满减金额
  340. // 满赠
  341. mz: new Map(),
  342. accumulatedAmountForFullGift: new Map(), // 累积金额(满赠使用的)
  343. fullGiftCode:[],// 满赠商品条码
  344. // 优惠券
  345. coupons: new Map(),
  346. // 挂起订单集合
  347. pendingOrderMap: new Map(),
  348. // 挂起订单的key 在1~3循环
  349. pendingIndex:1,
  350. pendingOrderKeys:[],
  351. },
  352. methods: {
  353. query: function () {
  354. vm.storeId = sessionStorage.getItem("storeId");;
  355. var thisGoods = {};
  356. $.get("../goods/details/"+vm.prodBarcode+"/"+vm.storeId, function (r) {
  357. if (r.code == 0) {
  358. vm.prodBarcode = '';
  359. // r.goodsDetails.discountedPrice = 0;
  360. // r.goodsDetails.actualPaymentAmount = r.goodsDetails.retailPrice;
  361. calculateGoodsPrice(r);
  362. vm.goodsDetail = true;
  363. // thisGoods.name = r.goodsDetails.name;// thisGoods.primaryPicUrl = r.goodsDetails.primaryPicUrl; // thisGoods.retailPrice = r.goodsDetails.retailPrice;// thisGoods.specification = r.goodsDetails.specification; // thisGoods.prodBarcode = r.goodsDetails.prodBarcode;// thisGoods.stockNum = r.goodsDetails.stockNum;// thisGoods.goodsDesc = r.goodsDetails.goodsDesc;// thisGoods.sellVolume = 1;// thisGoods.id = vm.index++;
  364. r.goodsDetails.sellVolume = 1;
  365. r.goodsDetails.id = vm.index++;
  366. if(!vm.goodsList[vm.index]){
  367. vm.index = vm.max;
  368. }
  369. vm.max++;
  370. r.goodsDetails.goodsDesc = "";
  371. r.goodsDetails.discountedPrice = Math.round(r.goodsDetails.discountedPrice * 100) / 100;
  372. r.goodsDetails.actualPaymentAmount = Math.round(r.goodsDetails.actualPaymentAmount * 100) / 100;
  373. // r.goodsDetails.primaryPicUrl = "";
  374. var data = Object.assign({}, JSON.parse(JSON.stringify(r.goodsDetails)));
  375. vm.goodsList.push(data);
  376. vm.goods = r.goodsDetails;
  377. vm.totalPrice = (vm.totalPrice + r.goodsDetails.retailPrice);
  378. if(vm.reduceMoney > 0){
  379. vm.discountedPrice = vm.discountedPrice + r.goodsDetails.discountedPrice + vm.reduceMoney;
  380. vm.actualPrice = vm.actualPrice + r.goodsDetails.actualPaymentAmount - vm.reduceMoney;
  381. vm.showReduceMoney = vm.showReduceMoney + vm.reduceMoney;
  382. vm.reduceMoney = 0;
  383. }else{
  384. vm.discountedPrice = vm.discountedPrice + r.goodsDetails.discountedPrice ;
  385. vm.actualPrice = vm.actualPrice + r.goodsDetails.actualPaymentAmount ;
  386. }
  387. // 处理精度
  388. vm.totalPrice = Math.round(vm.totalPrice * 100) / 100;
  389. vm.discountedPrice = Math.round(vm.discountedPrice * 100) / 100;
  390. vm.actualPrice = Math.round(vm.actualPrice * 100) / 100;
  391. vm.showReduceMoney = Math.round(vm.showReduceMoney * 100) / 100;
  392. } else {
  393. alert(r.msg);
  394. }
  395. });
  396. },
  397. add:function(value){
  398. // 增加数量
  399. for(var i = 0 ; i < this.goodsList.length ; i++){
  400. if(this.goodsList[i].id == value){
  401. var goods = this.goodsList[i];
  402. goods.sellVolume = goods.sellVolume + 1;
  403. vm.totalPrice = vm.totalPrice + goods.retailPrice;
  404. break;
  405. }
  406. }
  407. },
  408. minus:function(value){
  409. // 减少数量
  410. for(var i = 0 ; i < this.goodsList.length ; i++){
  411. if(this.goodsList[i].id == value){
  412. var goods = this.goodsList[i];
  413. if(goods.sellVolume === 1){
  414. alert("数量至少为1个");
  415. return ;
  416. }
  417. goods.sellVolume = goods.sellVolume - 1;
  418. vm.totalPrice = vm.totalPrice - goods.retailPrice;
  419. break;
  420. }
  421. }
  422. },
  423. deleteItem:function(value){
  424. console.log(value);
  425. // 删除这条记录
  426. for(var i = 0 ; i < this.goodsList.length ; i++){
  427. if(this.goodsList[i].id == value){
  428. var goods = this.goodsList[i];
  429. vm.totalPrice = vm.totalPrice - (goods.retailPrice * goods.sellVolume);
  430. this.goodsList.splice(i,1);
  431. break;
  432. }
  433. }
  434. this.index = value;
  435. },
  436. clearGoodsList:function(){
  437. this.goodsList = [];
  438. vm.customClearData();
  439. },
  440. pendingOrder:function(){
  441. if(this.goodsList.length == 0){
  442. alert("购物车中没有商品");
  443. return;
  444. }
  445. console.log(vm.pendingOrderMap.size);
  446. if(vm.pendingOrderMap.size >= 3){
  447. alert("订单挂起最多支持3单");
  448. return;
  449. }
  450. vm.pendingOrderMap.set(vm.pendingIndex,this.goodsList);
  451. vm.pendingOrderKeys.push(vm.pendingIndex);
  452. var newIndex = ++vm.pendingIndex;
  453. vm.pendingIndex = newIndex > 3?1: newIndex;
  454. vm.clearGoodsList();
  455. },
  456. toResumePending:function(){
  457. if(vm.pendingOrderMap.size == 0){
  458. alert("当前没有挂起的订单");
  459. return ;
  460. }
  461. $('#pendignOrderModal').modal('show')
  462. },
  463. resumePending:function(key){
  464. if(vm.pendingOrderMap.size == 0){
  465. alert("当前没有挂起的订单");
  466. return ;
  467. }
  468. if(vm.goodsList.length > 0){
  469. alert("购物车中已有商品,不允许恢复!")
  470. return ;
  471. }
  472. vm.goodsList = vm.pendingOrderMap.get(key);
  473. // 清除恢复的数据
  474. vm.pendingOrderMap.delete(key);
  475. removeByValue(vm.pendingOrderKeys,key);
  476. $('#pendignOrderModal').modal('hide')
  477. },
  478. toOrderSubmit:function(){
  479. if(this.goodsList.length == 0){
  480. alert("请选择商品");
  481. return;
  482. }
  483. $('#myModal').modal('show')
  484. // 每次点击提交订单的时候清空姓名和身份证信息和手机号
  485. // vm.$refs.customName.value = "";
  486. // vm.$refs.customIDCard.value = "";
  487. // vm.$refs.customPhone.value = "";
  488. if(vm.$refs.couponSn)
  489. vm.$refs.couponSn.value = "";
  490. this.userInfo.couponSn = "";
  491. },
  492. submitOrder:function(){
  493. $('#payCode').unbind('keydown').keydown(function(event){});
  494. vm.machineCode = sessionStorage.getItem("machineCode");
  495. console.log(vm.machineCode);
  496. var param = {'userInfo':vm.userInfo,'payCode':this.$refs.payCode.currentValue,'goodsList':vm.goodsList,'sessionId':vm.sessionId,'machineCode':vm.machineCode};
  497. console.log(JSON.stringify(param));
  498. this.$refs.payCode.currentValue = '';
  499. $.ajax({
  500. type: "POST",
  501. url: "../order/orderConfirm",
  502. contentType: "application/json",
  503. data: JSON.stringify(param),
  504. success: function (r) {
  505. console.log(r);
  506. if (r.code == 0) {
  507. if (r.resultObj != null) {
  508. $(".form-group input[type=text]").each(function(){
  509. this.value = '';
  510. })
  511. // 打印取货码小票
  512. var content = getPrintContent(r.resultObj);
  513. console.log(content);
  514. printArea2(content);
  515. vm.goodsList = [];
  516. vm.customname = '' ;
  517. vm.customidcard = '';
  518. vm.customClearData();
  519. // alert('打印小票完成');
  520. }else{
  521. // alert("打印小票失败");
  522. }
  523. } else {
  524. alert(r.msg);
  525. }
  526. }
  527. });
  528. },customClearData: function(){
  529. vm.totalPrice = 0;
  530. vm.discountedPrice = 0;
  531. vm.actualPrice = 0;
  532. vm.goods={};
  533. vm.goodsDetail = false;
  534. // 买一送一
  535. vm.mysy = [];
  536. vm.newMysy = new Map();
  537. vm.boughtNum = new Map();
  538. // 组合价
  539. vm.zhjsp = new Map();
  540. vm.combinationPrice = new Map(); // 组合价商品的组合价
  541. // 满减
  542. vm.mj = new Map();
  543. vm.accumulatedAmount = new Map();// 累积金额(满减使用的)
  544. vm.reduceMoney = 0; // 满减金额
  545. vm.showReduceMoney = 0; // 用于展示的满减金额
  546. // 满赠
  547. vm.mz = new Map();
  548. vm.accumulatedAmountForFullGift = new Map(); // 累积金额(满赠使用的)
  549. vm.fullGiftCode = [];// 满赠商品条码
  550. // 优惠券
  551. vm.coupons = new Map();
  552. },
  553. queryIDCardInfo: function(){
  554. $.get("../order/queryIDCardInfo/"+vm.$refs.customPhone.value, function (r){
  555. if(r.code === 0){
  556. var data = r.userEntity;
  557. vm.$refs.customName.value = data.username;
  558. vm.$refs.customIDCard.value = data.idNo;
  559. }else{
  560. alert(r.msg);
  561. }
  562. });
  563. },
  564. getIDCardInfo: function(){
  565. $.post("http://127.0.0.1:8000/idcard/read", function (r){
  566. // var dataR = JSON.parse(r);
  567. // console.log(dataR)
  568. console.log(r)
  569. console.log(r.code)
  570. if(r.code == "0"){
  571. // if(!r.info){
  572. // alert("请连接设备或设备有问题,请联系管理员!");
  573. // return ;
  574. // }
  575. // var data = JSON.parse(r.info);
  576. // if(data.code=="0"){
  577. vm.$refs.customName.value = r.rows[0].data.name;
  578. vm.$refs.customIDCard.value = r.rows[0].data.id_no;
  579. // }else{
  580. // alert(data.msg);
  581. // return ;
  582. // }
  583. }else if(r.code=="-1"){
  584. alert(r.msg);
  585. return;
  586. }else{
  587. alert("请连接设备或设备有问题,请联系管理员!");
  588. }
  589. });
  590. },
  591. customPhoneBlur:function (){
  592. let customPhone = this.$refs.customPhone.value;
  593. if(customPhone){
  594. for(let key in this.userInfoBinding){
  595. if(customPhone == key){
  596. let userInfoBindingValue = this.userInfoBinding[key];
  597. this.$refs.customName.value = userInfoBindingValue.substring(0, userInfoBindingValue.length-18);
  598. this.$refs.customIDCard.value = userInfoBindingValue.substring(userInfoBindingValue.length-18);
  599. break;
  600. }
  601. }
  602. }
  603. },
  604. submitCustomInfo:function(){
  605. this.userInfo.customName = this.$refs.customName.value ;
  606. this.userInfo.customIDCard = this.$refs.customIDCard.value ;
  607. this.userInfo.customPhone = this.$refs.customPhone.value;
  608. if(this.$refs.couponSn)
  609. this.userInfo.couponSn = this.$refs.couponSn.value;
  610. var idcardReg = /^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$|^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/;
  611. if(!this.userInfo.customName){
  612. alert("姓名不能为空!");
  613. return ;
  614. }
  615. if(!idcardReg.test(this.userInfo.customIDCard)){
  616. alert("请输入正确的身份证号");
  617. return ;
  618. }
  619. if(!(/^1[3456789]\d{9}$/.test(this.userInfo.customPhone))){
  620. alert("手机号码有误,请重填");
  621. return ;
  622. }
  623. //将手机号与姓名身份证号进行绑定,下次填写手机号即可
  624. let userInfoBindingKey = this.userInfo.customPhone;
  625. let userInfoBindingValue = this.userInfo.customName+this.userInfo.customIDCard;
  626. this.userInfoBinding[userInfoBindingKey] = userInfoBindingValue;
  627. console.log(this.userInfo.couponSn);
  628. if(this.userInfo.couponSn && this.userInfo.couponSn != ""){
  629. var coupon = vm.coupons.get(this.userInfo.couponSn);
  630. if(coupon == null){
  631. alert("请输入正确的优惠券码");
  632. return ;
  633. }
  634. }
  635. $("#Send").attr("data-dismiss","modal");
  636. $('#payModal').modal('show');
  637. $("#payCode").keydown(function(e){
  638. if(e.keyCode==13){
  639. $("#submitOrder").click();
  640. event.preventDefault();
  641. }
  642. });
  643. $('body').on('hidden.bs.modal', '.modal', function () {
  644. $(this).removeData();
  645. });
  646. },
  647. queryOrderDetail:function(orderSn){
  648. var storeId = sessionStorage.getItem("storeId");;
  649. $.get("../order/orderDetail/"+orderSn, function (r) {
  650. if (r.code == 0) {
  651. vm.orderProcessRecord = r.resultObj.orderProcessRecordEntity;
  652. vm.orderEntity = r.resultObj.orderEntity;
  653. vm.goodsDetailList = r.resultObj.goodsList;
  654. vm.currentOrderNo = r.resultObj.orderEntity.id;
  655. vm.tax = r.resultObj.tax;
  656. if(vm.orderProcessRecord.eleOrderStartTime){
  657. vm.orderProcessRecord.eleOrderStartTime = parsedate(vm.orderProcessRecord.eleOrderStartTime);
  658. }
  659. if(vm.orderProcessRecord.paymentStartTime){
  660. vm.orderProcessRecord.paymentStartTime = parsedate(vm.orderProcessRecord.paymentStartTime);
  661. }
  662. if(vm.orderProcessRecord.waybillStartTime){
  663. vm.orderProcessRecord.waybillStartTime = parsedate(vm.orderProcessRecord.waybillStartTime);
  664. }
  665. if(vm.orderProcessRecord.customsSuccTime){
  666. vm.orderProcessRecord.customsSuccTime = parsedate(vm.orderProcessRecord.customsSuccTime);
  667. }
  668. if(vm.orderProcessRecord.addOrderStartTime){
  669. vm.orderProcessRecord.addOrderStartTime = parsedate(vm.orderProcessRecord.addOrderStartTime);
  670. }
  671. }
  672. });
  673. },
  674. verification:function(){
  675. if(vm.orderProcessRecord.isCustomsSend != 1){
  676. alert("请等待清关完成");
  677. return ;
  678. }
  679. confirm('确认核销吗?', function () {
  680. $.ajax({
  681. type: "POST",
  682. url: "../order/printMsgAndChangeCode",
  683. contentType: "application/json",
  684. data: JSON.stringify({'id':vm.currentOrderNo,'sessionId':vm.sessionId}),
  685. success: function (r) {
  686. if (r.ticket != null) {
  687. // printArea(r.ticket);
  688. var content = getPrintContentOrder(r.ticket);
  689. printArea(content);
  690. alert('打印小票完成');
  691. }else{
  692. alert("打印小票失败");
  693. }
  694. }
  695. });
  696. })
  697. },
  698. refundOrder:function(){
  699. confirm('确认退款吗?', function () {
  700. $.ajax({
  701. type: "POST",
  702. url: "../order/orderRefund",
  703. contentType: "application/json",
  704. data: JSON.stringify({'orderId':vm.currentOrderNo,'sessionId':vm.sessionId}),
  705. success: function (r) {
  706. if (r.code == 0) {
  707. alert("退款成功")
  708. }else{
  709. alert("退款失败,请联系管理员");
  710. }
  711. }
  712. });
  713. })
  714. },
  715. retrySendOrder:function(){
  716. },
  717. getInfo: function (id) {
  718. $.get("../sys/notice/info/" + id, function (r) {
  719. vm.sysNotice = r.sysNotice;
  720. });
  721. },
  722. reload: function (event) {
  723. vm.showList = false;
  724. vm.showViewList = true;
  725. vm.showSaveSupplierGoods = true;
  726. var page = $("#jqGrid").jqGrid('getGridParam', 'page');
  727. $("#jqGrid").jqGrid('setGridParam', {
  728. postData: {
  729. storeId: vm.q.storeId,
  730. goodsName: vm.q.goodsName,
  731. goodsSn: vm.q.goodsSn,
  732. productSn: vm.q.productSn, category: vm.q.category, categoryTwo: vm.q.categoryTwo, goodsBizType:vm.q.goodsBizType,
  733. thirdPartyMerchCode: vm.q.thirdPartyMerchCode
  734. },
  735. page: page
  736. }).trigger("reloadGrid");
  737. vm.handleReset('formValidate');
  738. },
  739. handleSubmit: function (name) {
  740. handleSubmitValidate(this, name, function () {
  741. vm.saveOrUpdate()
  742. });
  743. },
  744. handleReset: function (name) {
  745. handleResetForm(this, name);
  746. },
  747. logout: function () {
  748. confirm('注:您确定要安全退出本次登录吗?', function () {
  749. dialogLoading(true);
  750. setTimeout(function () {
  751. toUrl('../logout?_' + $.now());
  752. }, 500);
  753. });
  754. }
  755. }
  756. });
  757. function getPrintContent(ticket) {
  758. var content = "<div style=\"width: 250px;font-family: 微软雅黑;font-size: 15px;\">";
  759. // // 打印ogo
  760. // content += "<div style=\"text-align: center;width: 100%;height: 50px;\">";
  761. // // content += "<img src='./../../statics/img/cw_logo.png' />";
  762. // // content += "2222222222";
  763. // content += "<img src='/statics/img/cw_logo.png' style='width: 100%;height: 100%;' />";
  764. // content += "</div>";
  765. //小票头
  766. content += "<div style=\"text-align: center;width: 100%;font-weight:bold;font-size: 15px;\">";
  767. content += ticket.shopName
  768. content += "</div>";
  769. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  770. content += "<div style=\"width: 100%;margin:5px 0px;\">";
  771. /*content += "收银机号:" + ticket.salesNo;
  772. content += "</div>";
  773. content += "<div style=\"width: 100%;\">";*/
  774. content += "收银员:" + ticket.userName;
  775. content += "</div>";
  776. content += "<div style=\"width: 100%;font-size: 30px;margin:15px 0 10px 5px;\">";
  777. content += "取货码:" + ticket.code;
  778. content += "</div>";
  779. content += "<div style=\"width: 100%;margin:5px 0px;\">";
  780. content += "订单编号:" + ticket.orderNo;
  781. content += "</div>";
  782. content += "<div style=\"width: 100%;margin:5px 0px;\">";
  783. content += "打印日期:" + ticket.time;
  784. content += "</div>";
  785. content += "<div style=\"width: 100%;margin:5px 0px;font-size: 13px;\">";
  786. content += "该取货单号只有当天有效"
  787. content += "</div>";
  788. content += "</div>";
  789. return content;
  790. }
  791. var printAreaCount = 0;
  792. function printArea(content) {
  793. var idPrefix = "printArea_";
  794. removePrintArea(idPrefix + printAreaCount);
  795. printAreaCount++;
  796. var iframeId = idPrefix + printAreaCount;
  797. var iframeStyle = 'width:0px;height:0px;left:0px;top:0px;';
  798. iframe = document.createElement('IFRAME');
  799. $(iframe).attr({
  800. style: iframeStyle,
  801. id: iframeId
  802. });
  803. document.body.appendChild(iframe);
  804. var doc = iframe.contentWindow.document;
  805. doc.open();
  806. //$(document).find("link").filter(function () {
  807. //return $(this).attr("rel").toLowerCase() == "stylesheet";
  808. //}).each(
  809. //function () {
  810. //doc.write('<link type="text/css" rel="stylesheet" href="'
  811. //+ $(this).attr("href") + '" >');
  812. //});
  813. doc.write('<div class="">' + content
  814. + '</div>');
  815. doc.close();
  816. var frameWindow = iframe.contentWindow;
  817. frameWindow.close();
  818. frameWindow.focus();
  819. // frameWindow.print();
  820. frameWindow.print();
  821. }
  822. function printArea2(content) {
  823. var idPrefix = "printArea_";
  824. removePrintArea(idPrefix + printAreaCount);
  825. printAreaCount++;
  826. var iframeId = idPrefix + printAreaCount;
  827. var iframeStyle = 'width:0px;height:0px;left:0px;top:0px;';
  828. iframe = document.createElement('IFRAME');
  829. $(iframe).attr({
  830. style: iframeStyle,
  831. id: iframeId
  832. });
  833. document.body.appendChild(iframe);
  834. var doc = iframe.contentWindow.document;
  835. doc.open();
  836. //$(document).find("link").filter(function () {
  837. //return $(this).attr("rel").toLowerCase() == "stylesheet";
  838. //}).each(
  839. //function () {
  840. //doc.write('<link type="text/css" rel="stylesheet" href="'
  841. //+ $(this).attr("href") + '" >');
  842. //});
  843. doc.write('<div class="">' + content
  844. + '</div>');
  845. doc.close();
  846. var frameWindow = iframe.contentWindow;
  847. frameWindow.focus();
  848. frameWindow.print();
  849. frameWindow.print();
  850. frameWindow.close();
  851. }
  852. var removePrintArea = function (id) {
  853. $("iframe#" + id).remove();
  854. };
  855. var webSocket;
  856. function openWebSocket() {
  857. var storeId = sessionStorage.getItem("storeId");
  858. if ("WebSocket" in window) {
  859. console.log("当前浏览器支持WebSocket");
  860. //实现化WebSocket对象
  861. //指定要连接的服务器地址与端口建立连接
  862. //注意ws、wss使用不同的端口。我使用自签名的证书测试,
  863. //无法使用wss,浏览器打开WebSocket时报错
  864. //ws对应http、wss对应https。
  865. // webSocket = new WebSocket("ws://183.62.225.124:8080/ws/server/"+storeId);
  866. // webSocket = new WebSocket("ws://127.0.0.1:8080//ws/server/"+storeId);
  867. webSocket = new WebSocket("wss://cb.k1net.cn/ws/server/"+storeId);
  868. if (webSocket.readyState === webSocket.CONNECTING) {
  869. console.log('1.连接正在打开......');
  870. }
  871. // ---------- WebSocket 对象注册事件 ----------
  872. //连接打开事件
  873. webSocket.onopen = function () {
  874. if (webSocket.readyState === webSocket.OPEN) {
  875. console.log('2.连接已打开');
  876. }
  877. console.log('2.向服务端发送测试消息......');
  878. // webSocket.send("2.client发测试消息:Client sent test msg。");
  879. };
  880. //收到消息事件
  881. webSocket.onmessage = function (msg) {
  882. var data = Object.assign({}, JSON.parse(msg.data));
  883. console.log('3.接收到服务端信息......data:'+data);
  884. vm.sessionId = data.sessionId;
  885. vm.pickUpCodeList = [];
  886. if(data.pickUpCodeList.length > 0){
  887. for(var i = 0 ; i < data.pickUpCodeList.length ; i++){
  888. console.log(data.pickUpCodeList[i].storeId);
  889. if(data.pickUpCodeList[i].storeId === storeId){
  890. vm.pickUpCodeList.push(data.pickUpCodeList[i]);
  891. }
  892. }
  893. }
  894. // vm.pickUpCodeList = vm.pickUpCodeList.concat(data.pickUpCodeList);
  895. // console.log(vm.pickUpCodeList);
  896. // webSocket.send("2.client发测试消息:Client sent test msg。");
  897. };
  898. //连接关闭事件
  899. webSocket.onclose = function () {
  900. if (!webSocket) {
  901. console.log('4.Socket连接已关闭');
  902. }
  903. };
  904. //发生了错误事件
  905. webSocket.onerror = function () {
  906. console.log("5.Socket发生了错误");
  907. }
  908. } else {
  909. console.log("当前浏览器不支持WebSocket");
  910. return false;
  911. }
  912. }
  913. function sendMessage() {
  914. if(webSocket && webSocket.readyState === webSocket.OPEN) {
  915. webSocket.send("client manual send message.")
  916. } else {
  917. console.log('6.未创建WebSocket连接');
  918. }
  919. }
  920. function closeWebSocket() {
  921. if (webSocket != null) {
  922. webSocket.close();
  923. webSocket = null;
  924. }
  925. console.log("关闭WebSocket");
  926. }
  927. //窗口关闭时,关闭连接
  928. window.unload = function () {
  929. webSocket.close();
  930. };
  931. function parsedate(value){
  932. var date = new Date(value);
  933. var year = date.getFullYear();
  934. var month = date.getMonth()+1; //月份+1
  935. var day = date.getDate();
  936. var hour = date.getHours();
  937. var minutes = date.getMinutes();
  938. var second = date.getSeconds();
  939. return year+"-"+month+"-"+day+" "+hour+":"+minutes +":"+second;
  940. }
  941. function getPrintContentOrder(ticket) {
  942. var content = "<div style=\"width: 250px;font-family: 微软雅黑;font-size: 8px;\">";
  943. // 打印ogo
  944. content += "<div style=\"text-align: center;width: 100%;height: 100px;\">";
  945. content += "<img src='/statics/img/cw_logo2.png' style='width: 100%;height: 100%;' />";
  946. content += "</div>";
  947. //小票头
  948. content += "<div style=\"text-align: center;width: 100%;font-weight:bold;font-size: 13px;\">";
  949. content += ticket.ticketHead.title;
  950. content += "</div>";
  951. /*content += "<div style=\"width: 100%;\">";
  952. content += "会员:" + ticket.ticketHead.memberId;
  953. content += "</div>";*/
  954. content += "<div style=\"width: 100%;\">";
  955. content += "订单号:" + ticket.ticketHead.orderId;
  956. content += "</div>";
  957. content += "<div style=\"width: 100%;\">";
  958. content += "交易时间:" + ticket.ticketHead.tradeTime;
  959. content += "</div>";
  960. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  961. //商品信息
  962. content += "<table style=\"width: 100%;\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
  963. content += "<tr>";
  964. content += "<td style=\"width: 40%;text-align: left;font-size: 10px;font-weight: bold;\">商品名称</td>";
  965. content += "<td style=\"width: 17%;text-align: right;font-size: 10px;font-weight: bold;\">单价</td>";
  966. // content += "<td style=\"width: 16%;text-align: right;font-size: 10px;font-weight: bold;\">税费</td>";
  967. content += "<td style=\"width: 15%;text-align: right;font-size: 10px;font-weight: bold;\">数量</td>";
  968. content += "<td style=\"width: 18%;text-align: right;font-size: 10px;font-weight: bold;\">小计</td>";
  969. content += "</tr>";
  970. content += "</table>";
  971. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  972. content += "<table style=\"width: 100%;\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
  973. for (var i=0;i< ticket.goods.length;i++){
  974. content += "<tr>";
  975. content += "<td style=\"width: 40%;text-align: left;font-size: 8px;padding-top: 8px;\">";
  976. content += "<table style=\"width: 100%;\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
  977. content += "<tr>";
  978. content += "<td style=\"text-align: left;font-size: 8px;vertical-align:top;\">#</td>";
  979. content += "<td style=\"text-align: left;font-size: 8px;\">" + ticket.goods[i].gname + "</td>";
  980. content += "</tr>";
  981. content += "</table>";
  982. content += "</td>";
  983. content += "<td style=\"width: 17%;text-align: right;font-size: 8px;vertical-align:bottom;padding-top: 8px;\">" + ticket.goods[i].uprice + "</td>";
  984. // content += "<td style=\"width: 17%;text-align: right;font-size: 8px;vertical-align:bottom;padding-top: 8px;\">" + ticket.goods[i].taxation + "</td>";
  985. content += "<td style=\"width: 15%;text-align: right;font-size: 8px;vertical-align:bottom;padding-top: 8px;\">" + ticket.goods[i].num + "</td>";
  986. content += "<td style=\"width: 18%;text-align: right;font-size: 8px;vertical-align:bottom;padding-top: 8px;\">" + ticket.goods[i].subtotal + "</td>";
  987. content += "</tr>";
  988. }
  989. content += "</table>";
  990. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  991. //收银信息
  992. content += "<div style=\"width: 100%;\">";
  993. content += "<span style=\"float: left;width: 50%;text-align: left;\">商品合计:</span>";
  994. content += "<span style=\"float: left;width: 17%;text-align: left;\">" + ticket.cashInfo.goodsTotal + "件</span>";
  995. content += "<span style=\"float: right;width: 33%;text-align: right;\">" + ticket.cashInfo.total + "元</span>";
  996. content += "</div>";
  997. content += "<div style=\"width: 100%;\">";
  998. content += "<span style=\"float: left;width: 50%;text-align: left;\">税费合计:</span>";
  999. content += "<span style=\"float: left;width: 17%;text-align: left;\">" + ticket.cashInfo.goodsTotal + "件</span>";
  1000. content += "<span style=\"float: right;width: 33%;text-align: right;\">" + ticket.cashInfo.taxTotal + "元</span>";
  1001. content += "</div>";
  1002. content += "<div style=\"width: 100%;\">";
  1003. content += "<span style=\"float: left;width: 50%;text-align: left;\">实收:</span>";
  1004. content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.receipts + "元</span>";
  1005. content += "</div>";
  1006. // content += "<div style=\"width: 100%;\">";
  1007. // content += "<span style=\"float: left;width: 50%;text-align: left;\">找零:</span>";
  1008. // content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.oddChange + "元</span>";
  1009. // content += "</div>";
  1010. content += "<div style=\"width: 100%;\">";
  1011. content += "<span style=\"float: left;width: 50%;text-align: left;\">优惠券:</span>";
  1012. content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.coupon + "元</span>";
  1013. content += "</div>";
  1014. // content += "<div style=\"width: 100%;\">";
  1015. // content += "<span style=\"float: left;width: 50%;text-align: left;\">运费:</span>";
  1016. // content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.freight + "元</span>";
  1017. // content += "</div>";
  1018. content += "<div style=\"width: 100%;\">";
  1019. content += "<span style=\"float: left;width: 50%;text-align: left;\">支付渠道:</span>";
  1020. // 后期改成从系统中取
  1021. content += "<span style=\"float: right;width: 50%;text-align: right;\">" + "支付宝支付" + "</span>";
  1022. content += "</div>";
  1023. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  1024. //海关清单信息
  1025. content += "<div style=\"width: 100%;\">";
  1026. content += "订单号:" + ticket.cusListing.orderId;
  1027. content += "</div>";
  1028. content += "<div style=\"width: 100%;\">";
  1029. content += "运单编号:" + ticket.cusListing.waybillId;
  1030. content += "</div>";
  1031. content += "<div style=\"width: 100%;\">";
  1032. content += "海关清单号:" + ticket.cusListing.invtNo;
  1033. content += "</div>";
  1034. content += "<div style=\"width: 100%;\">";
  1035. content += "收货人:" + ticket.cusListing.consignee;
  1036. content += "</div>";
  1037. content += "<div style=\"width: 100%;\">";
  1038. content += "收货人电话:" + ticket.cusListing.consigneeTel;
  1039. content += "</div>";
  1040. content += "<div style=\"width: 100%;\">";
  1041. content += "始发地: 仓库地址 : 广东省深圳市南山区前海保税港区W104" ;
  1042. content += "</div>";
  1043. content += "<div style=\"width: 100%;\">";
  1044. content += "交货地:" + ticket.cusListing.deliveryAddress;
  1045. content += "</div>";
  1046. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  1047. content += "<div style=\"width: 100%;text-align: center;\">";
  1048. content += "购买跨境商品须知:"
  1049. content += "</div>";
  1050. content += "<div style=\"width: 100%;\">";
  1051. content += "1、凡购买跨境商品均不提供发票;<br> 2、单笔限购5000元,年交易限额2.6万元; <br> 3、所有订单经海关放行后方可提货; <br> 4、凭小票领取您的订单商品。"
  1052. content += "</div>";
  1053. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  1054. content += "<div style=\"width: 100%;text-align: center;\">";
  1055. content += "退换货须知:"
  1056. content += "</div>";
  1057. content += "<div style=\"width: 100%;\">";
  1058. content += "请您当面哦对小票,清点商品,在原包装完好,未拆封、无破损、原始小票等所有物件完全且不影响二次销售的情况下,支持七天无理由退货。食品(含保健品)为特殊商品,非质量原因不退换,希望您能谅解!"
  1059. content += "</div>";
  1060. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  1061. content += "<div style=\"width: 100%;\">";
  1062. // content += ticket.ticketFoot.summary;
  1063. content += "</div>";
  1064. content += "<div style=\"width: 100%;\">";
  1065. // content += "客服电话:" + ticket.ticketFoot.serviceTel;
  1066. content += "</div>";
  1067. content += "<div style=\"width: 100%;\">";
  1068. // content += "网址:" + ticket.ticketFoot.url1;
  1069. content += "</div>";
  1070. content += "<div style=\"width: 100%;\">";
  1071. content += ticket.ticketFoot.welcome;
  1072. content += "</div>";
  1073. content += "<div style=\"width: 100%;\">";
  1074. content += "惠州市惠城区港惠新天地负一层";
  1075. content += "</div>";
  1076. content += "<div style=\"width: 100%;\">";
  1077. content += "请当面清点所购商品,并保管好收银小票以做退换货凭证。";
  1078. content += "</div>";
  1079. // 打印二维码
  1080. content += "<div style=\"text-align: center;width: 100%;height: 250px;\">";
  1081. content += "<img src='/statics/img/cw_qrcode.png' style='width: 100%;height: 100%;' />";
  1082. content += "</div>";
  1083. content += "<div style=\"width: 100%;text-align: center;\">";
  1084. content += "全球精选,品质生活"
  1085. content += "</div>";
  1086. return content;
  1087. }
  1088. function queryAssistantInfo(){
  1089. $.get("../sys/user/info", function (r) {
  1090. if(r.code == 0){
  1091. vm.sysUserInfo = r.user;
  1092. $.get("../store/getStoresByMerch?merchSn="+r.user.merchSn+"&_=1590374349985",function(result){
  1093. if(result.code == 0){
  1094. for(var i = 0 ;i < result.list.length; i++){
  1095. if(result.list[i].id == r.user.storeId){
  1096. vm.storeName = result.list[i].storeName;
  1097. break;
  1098. }
  1099. }
  1100. }
  1101. });
  1102. }
  1103. });
  1104. }
  1105. function removeByValue(arr, val) {
  1106. var index = arr.indexOf(val);
  1107. if (index > -1) {
  1108. arr.splice(index, 1);
  1109. }
  1110. }