sale.js 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968
  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. vm.mysy.push(rMap.mysy[barCode]);
  30. }
  31. if(rMap.mz){
  32. if(rMap.mz[barCode] && !vm.mz.get(barCode)){
  33. // 该商品是否已经有过满赠活动
  34. vm.mz.set(barCode,rMap.mz[barCode]);
  35. }else if(rMap.mz[brand] && !vm.mz.get(brand)){
  36. // 该品牌是否已经有过满赠活动
  37. vm.mz.set(brand,rMap.mz[brand]);
  38. }
  39. }
  40. if(rMap.zhjsp){
  41. // 遍历该商品所有可能的组合价商品类型
  42. for(var data in rMap.zhjsp){
  43. if(!vm.zhjsp.get(data)){
  44. // 分割组合价商品的条码,并以 条码:0 放入map中
  45. var barCodeArray = data.toString().split(":");
  46. var dataMap = new Map();
  47. console.log(rMap.zhjsp[data]);
  48. // dataMap.set();
  49. for(var j = 0 ; j < barCodeArray.length ; j ++){
  50. dataMap.set(barCodeArray[j],0);
  51. }
  52. vm.combinationPrice.set(data,rMap.zhjsp[data][0].combinedPrice)
  53. vm.zhjsp.set(data,dataMap);
  54. }
  55. }
  56. }
  57. calculateGoodsByMj(r.goodsDetails);
  58. calculateGoodsByMysy(r.goodsDetails);
  59. calculateGoodsByMz(r.goodsDetails);
  60. calculateGoodsByZhjsp(r);
  61. }
  62. // ==================== 满减==========================
  63. // 满减
  64. function calculateGoodsByMj(goodsDetails){
  65. if(vm.mj.get(goodsDetails.prodBarcode)){
  66. fullReduction(goodsDetails,goodsDetails.prodBarcode);
  67. }else if(vm.mj.get(goodsDetails.brand)){
  68. fullReduction(goodsDetails,goodsDetails.brand);
  69. }
  70. }
  71. // 满减的计算内容
  72. function fullReduction(goodsDetails,key){
  73. // 获取满减条件金额
  74. var qualifiedAmount = vm.mj.get(key).qualifiedAmount;
  75. // 获取已累积金额
  76. var money = vm.accumulatedAmount.get(key);
  77. if(isNaN(money)){
  78. money = goodsDetails.retailPrice;
  79. }else{
  80. money = money + goodsDetails.retailPrice;
  81. }
  82. if(money >= qualifiedAmount){
  83. vm.reduceMoney += vm.mj.get(key).deductionAmount; // 达到满减金额,获取扣减的额度
  84. vm.mj.delete(key); // 获取后删除该商品的满减
  85. vm.accumulatedAmount.delete(key); // 删除满减的金额
  86. }else{
  87. vm.accumulatedAmount.set(key,money);
  88. }
  89. }
  90. // ============================= 满赠 ==============================
  91. // 满赠
  92. function calculateGoodsByMz(goodsDetails){
  93. // 1.满赠的商品是不是自己,遍历满赠商品数组
  94. isSend(vm.fullGiftCode,goodsDetails,"满赠");
  95. if(vm.mz.get(goodsDetails.prodBarcode)){
  96. fullGift(goodsDetails,goodsDetails.prodBarcode);
  97. }else if(vm.mz.get(goodsDetails.brand)){
  98. fullGift(goodsDetails,goodsDetails.brand);
  99. }
  100. }
  101. function fullGift(goodsDetails,key){
  102. // 获取满赠条件金额
  103. var qualifiedAmount = vm.mz.get(key).qualifiedAmount;
  104. // 获取已累积金额
  105. var money = vm.accumulatedAmountForFullGift.get(key);
  106. if(isNaN(money)){
  107. money = goodsDetails.retailPrice;
  108. }else{
  109. money = money + goodsDetails.retailPrice;
  110. }
  111. // 达到满赠的要求
  112. if(money >= qualifiedAmount){
  113. // 将满赠的商品放入数组中,重置金额
  114. vm.fullGiftCode.push(vm.mz.get(key).giftBarcode);
  115. vm.mz.delete(key); // 获取后删除该商品的满减
  116. vm.accumulatedAmountForFullGift.delete(key); // 删除满减的金额
  117. // 2.购物车的商品里面是否有满赠的商品
  118. shopCartContain(vm.fullGiftCode,goodsDetails,"满赠");
  119. }else{
  120. vm.accumulatedAmountForFullGift.set(key,money);
  121. }
  122. }
  123. // 买一送一
  124. function calculateGoodsByMysy(goodsDetails){
  125. // 判断当前商品是否为赠品
  126. isSend(vm.mysy,goodsDetails,"买一送一");
  127. // 判断购物车里面是否有商品为赠品
  128. shopCartContain(vm.mysy,goodsDetails,"买一送一");
  129. }
  130. // 判断当前商品是否为赠品
  131. function isSend(activity,goodsDetails,activityName){
  132. if(activity.indexOf(goodsDetails.prodBarcode) >= 0){
  133. // 如果符合条件,把赠送的条码给删除(一次性)
  134. var index = activity.indexOf(goodsDetails.prodBarcode);
  135. activity.splice(index,1);
  136. // 设置赠品的单价
  137. goodsDetails.discountedPrice = goodsDetails.retailPrice;
  138. goodsDetails.actualPaymentAmount = 0;
  139. goodsDetails.activity = activityName;
  140. }
  141. }
  142. // 判断购物车里面是否有商品为赠品
  143. function shopCartContain(activity,goodsDetails,activityName){
  144. if(vm.goodsList && vm.goodsList.length > 0 ){
  145. for(var i = 0 ; i < vm.goodsList.length ; i ++){
  146. // 如果有商品为赠品,则把价格置位0并跳出循环
  147. if(activity.indexOf(vm.goodsList[i].prodBarcode) >= 0 && vm.goodsList[i].actualPaymentAmount != 0){
  148. // 如果符合条件,把赠送的条码给删除(一次性)
  149. var index = vm.mysy.indexOf(goodsDetails.prodBarcode);
  150. activity.splice(index,1);
  151. vm.goodsList[i].discountedPrice = vm.goodsList[i].retailPrice;
  152. vm.goodsList[i].actualPaymentAmount = 0;
  153. vm.goodsList[i].activity = activityName;
  154. vm.discountedPrice = vm.discountedPrice + vm.goodsList[i].retailPrice ;
  155. vm.actualPrice = vm.actualPrice - vm.goodsList[i].retailPrice ;
  156. break;
  157. }
  158. }
  159. }
  160. }
  161. // ======================= 组合价商品 ============================
  162. // 组合价商品
  163. function calculateGoodsByZhjsp(r){
  164. var barCode = r.goodsDetails.prodBarcode;
  165. if(r.map.zhjsp){
  166. // 将有组合的商品设置为1 ps:{"flag" => 0, "4005808550739" => 1, "4305615120454" => 0}
  167. vm.zhjsp.forEach(function(value,key,map){
  168. // 将组合价中组合的产品出现的次数+1
  169. value.forEach(function(v, k ,m){
  170. if(k === barCode)
  171. m.set(k,v+1);
  172. });
  173. var flag = 1;
  174. // 判断是否有商品成功组合
  175. value.forEach(function(v, k ,m){
  176. if(v === 0)
  177. flag = 0;
  178. });
  179. if(flag === 1){
  180. var combinationPrice = vm.combinationPrice.get(key);
  181. var barCodeArr = key.toString().split(":");
  182. for( var j = 0 ; j < barCodeArr.length ; j ++ ){
  183. // 如果是扫描的产品,直接退出,因为购物车中无该产品
  184. if(barCodeArr[j] == barCode){
  185. r.goodsDetails.isCombination = 1;
  186. r.goodsDetails.discountedPrice = r.goodsDetails.retailPrice - combinationPrice; // 优惠价格
  187. r.goodsDetails.actualPaymentAmount = combinationPrice; // 实际支付价格
  188. r.goodsDetails.activity = "组合价";
  189. continue;
  190. }
  191. for(var i = 0 ; i < vm.goodsList.length ; i ++){
  192. if(vm.goodsList[i].prodBarcode === barCodeArr[j] && !vm.goodsList[i].isCombination){
  193. // 如果符合条件,把赠送的条码给删除(一次性)
  194. vm.goodsList[i].discountedPrice = vm.goodsList[i].retailPrice ; // 优惠价格
  195. vm.goodsList[i].actualPaymentAmount = 0; // 实际支付价格
  196. vm.goodsList[i].isCombination = 1;
  197. vm.goodsList[i].activity = "组合价";
  198. break;
  199. }
  200. }
  201. }
  202. // 扣减
  203. var updateMap = map.get(key);
  204. updateMap.forEach(function(v, k ,m){
  205. m.set(k,v-1);
  206. });
  207. }
  208. });
  209. }
  210. }
  211. let vm = new Vue({
  212. el: '#rrapp',
  213. data: {
  214. showList: true,
  215. goodsDetail:false,
  216. title: null,
  217. goods:{},
  218. sysNotice: {},
  219. goodsList:[],
  220. orderInfo:[],
  221. userInfo:{},
  222. sysUserInfo:{},
  223. storeName:null,
  224. prodBarcode:null,
  225. sessionId:null,
  226. pickUpCodeList:[],
  227. goodsDetailList:[],
  228. orderEntity:{},
  229. orderProcessRecord:{},
  230. tax:0,
  231. currentOrderNo:null,
  232. customname:'',
  233. customidcard:'',
  234. machineCode:'',
  235. storeId:null,
  236. index:0,
  237. max:0,
  238. totalPrice:0,
  239. discountedPrice:0,
  240. actualPrice:0,
  241. ruleValidate: {
  242. name: [
  243. {required: true, message: '名称不能为空', trigger: 'blur'}
  244. ]
  245. },
  246. q: {
  247. name: ''
  248. },
  249. // 买一送一
  250. mysy: [],
  251. // 组合价
  252. zhjsp: new Map(),
  253. combinationPrice: new Map(), // 组合价商品的组合价
  254. // 满减
  255. mj: new Map(),
  256. accumulatedAmount: new Map(), // 累积金额(满减使用的)
  257. reduceMoney:0, // 满减金额
  258. showReduceMoney:0, // 用于展示的满减金额
  259. // 满赠
  260. mz: new Map(),
  261. accumulatedAmountForFullGift: new Map(), // 累积金额(满赠使用的)
  262. fullGiftCode:[],// 满赠商品条码
  263. // 优惠券
  264. coupons: new Map(),
  265. },
  266. methods: {
  267. query: function () {
  268. vm.storeId = sessionStorage.getItem("storeId");;
  269. var thisGoods = {};
  270. $.get("../goods/details/"+vm.prodBarcode+"/"+vm.storeId, function (r) {
  271. if (r.code == 0) {
  272. // r.goodsDetails.discountedPrice = 0;
  273. // r.goodsDetails.actualPaymentAmount = r.goodsDetails.retailPrice;
  274. calculateGoodsPrice(r);
  275. vm.goodsDetail = true;
  276. // 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++;
  277. r.goodsDetails.sellVolume = 1;
  278. r.goodsDetails.id = vm.index++;
  279. if(!vm.goodsList[vm.index]){
  280. vm.index = vm.max;
  281. }
  282. vm.max++;
  283. r.goodsDetails.goodsDesc = "";
  284. // r.goodsDetails.primaryPicUrl = "";
  285. var data = Object.assign({}, JSON.parse(JSON.stringify(r.goodsDetails)));
  286. vm.goodsList.push(data);
  287. vm.goods = r.goodsDetails;
  288. vm.totalPrice = (vm.totalPrice + r.goodsDetails.retailPrice);
  289. if(vm.reduceMoney > 0){
  290. vm.discountedPrice = vm.discountedPrice + r.goodsDetails.discountedPrice + vm.reduceMoney;
  291. vm.actualPrice = vm.actualPrice + r.goodsDetails.actualPaymentAmount - vm.reduceMoney;
  292. vm.showReduceMoney = vm.showReduceMoney + vm.reduceMoney;
  293. vm.reduceMoney = 0;
  294. }else{
  295. vm.discountedPrice = vm.discountedPrice + r.goodsDetails.discountedPrice ;
  296. vm.actualPrice = vm.actualPrice + r.goodsDetails.actualPaymentAmount ;
  297. }
  298. // 处理精度
  299. vm.totalPrice = Math.round(vm.totalPrice * 100) / 100;
  300. vm.discountedPrice = Math.round(vm.discountedPrice * 100) / 100;
  301. vm.actualPrice = Math.round(vm.actualPrice * 100) / 100;
  302. vm.showReduceMoney = Math.round(vm.showReduceMoney * 100) / 100;
  303. } else {
  304. alert(r.msg);
  305. }
  306. });
  307. },
  308. add:function(value){
  309. // 增加数量
  310. for(var i = 0 ; i < this.goodsList.length ; i++){
  311. if(this.goodsList[i].id == value){
  312. var goods = this.goodsList[i];
  313. goods.sellVolume = goods.sellVolume + 1;
  314. vm.totalPrice = vm.totalPrice + goods.retailPrice;
  315. break;
  316. }
  317. }
  318. },
  319. minus:function(value){
  320. // 减少数量
  321. for(var i = 0 ; i < this.goodsList.length ; i++){
  322. if(this.goodsList[i].id == value){
  323. var goods = this.goodsList[i];
  324. if(goods.sellVolume === 1){
  325. alert("数量至少为1个");
  326. return ;
  327. }
  328. goods.sellVolume = goods.sellVolume - 1;
  329. vm.totalPrice = vm.totalPrice - goods.retailPrice;
  330. break;
  331. }
  332. }
  333. },
  334. deleteItem:function(value){
  335. console.log(value);
  336. // 删除这条记录
  337. for(var i = 0 ; i < this.goodsList.length ; i++){
  338. if(this.goodsList[i].id == value){
  339. var goods = this.goodsList[i];
  340. vm.totalPrice = vm.totalPrice - (goods.retailPrice * goods.sellVolume);
  341. this.goodsList.splice(i,1);
  342. break;
  343. }
  344. }
  345. this.index = value;
  346. },
  347. clearGoodsList:function(){
  348. this.goodsList = [];
  349. vm.totalPrice = 0;
  350. },
  351. toOrderSubmit:function(){
  352. if(this.goodsList.length == 0){
  353. alert("请选择商品");
  354. return;
  355. }
  356. $('#myModal').modal('show')
  357. },
  358. submitOrder:function(){
  359. $('#payCode').unbind('keydown').keydown(function(event){});
  360. vm.machineCode = sessionStorage.getItem("machineCode");
  361. console.log(vm.machineCode);
  362. var param = {'userInfo':vm.userInfo,'payCode':this.$refs.payCode.currentValue,'goodsList':vm.goodsList,'sessionId':vm.sessionId,'machineCode':vm.machineCode};
  363. console.log(JSON.stringify(param));
  364. this.$refs.payCode.currentValue = '';
  365. $.ajax({
  366. type: "POST",
  367. url: "../order/orderConfirm",
  368. contentType: "application/json",
  369. data: JSON.stringify(param),
  370. success: function (r) {
  371. console.log(r);
  372. if (r.code == 0) {
  373. if (r.resultObj != null) {
  374. $(".form-group input[type=text]").each(function(){
  375. this.value = '';
  376. })
  377. // 打印取货码小票
  378. var content = getPrintContent(r.resultObj);
  379. printArea2(content);
  380. vm.goodsList = [];
  381. vm.customname = '' ;
  382. vm.customidcard = '';
  383. vm.totalPrice = 0;
  384. vm.discountedPrice = 0;
  385. vm.actualPrice = 0;
  386. // 买一送一
  387. vm.mysy = [];
  388. // 组合价
  389. vm.zhjsp = new Map();
  390. vm.combinationPrice = new Map(); // 组合价商品的组合价
  391. // 满减
  392. vm.mj = new Map();
  393. vm.accumulatedAmount = new Map();// 累积金额(满减使用的)
  394. vm.reduceMoney = 0; // 满减金额
  395. vm.showReduceMoney = 0; // 用于展示的满减金额
  396. // 满赠
  397. vm.mz = new Map();
  398. vm.accumulatedAmountForFullGift = new Map(); // 累积金额(满赠使用的)
  399. vm.fullGiftCode = [];// 满赠商品条码
  400. // 优惠券
  401. vm.coupons = new Map();
  402. // alert('打印小票完成');
  403. }else{
  404. // alert("打印小票失败");
  405. }
  406. } else {
  407. alert(r.msg);
  408. }
  409. }
  410. });
  411. },
  412. getIDCardInfo: function(){
  413. $.get("../order/getIdCardInfo", function (r){
  414. if(r.code === 0){
  415. if(!r.info){
  416. alert("请连接设备或设备有问题,请联系管理员!");
  417. return ;
  418. }
  419. var data = JSON.parse(r.info);
  420. vm.$refs.customName.value = data.rows[0].data.name;
  421. vm.$refs.customIDCard.value = data.rows[0].data.id_no;
  422. }else{
  423. alter("请连接设备或设备有问题,请联系管理员!");
  424. }
  425. });
  426. },
  427. submitCustomInfo:function(){
  428. this.userInfo.customName = this.$refs.customName.value ;
  429. this.userInfo.customIDCard = this.$refs.customIDCard.value ;
  430. this.userInfo.customPhone = this.$refs.customPhone.value;
  431. if(this.$refs.couponSn)
  432. this.userInfo.couponSn = this.$refs.couponSn.value;
  433. 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)$/;
  434. /*if(!this.userInfo.customName){
  435. alert("姓名不能为空!");
  436. return ;
  437. }
  438. if(!idcardReg.test(this.userInfo.customIDCard)){
  439. alert("请输入正确的身份证号");
  440. return ;
  441. }
  442. if(!(/^1[3456789]\d{9}$/.test(this.userInfo.customPhone))){
  443. alert("手机号码有误,请重填");
  444. return ;
  445. }*/
  446. if(this.userInfo.couponSn){
  447. var coupon = vm.coupons.get(this.userInfo.couponSn);
  448. if(coupon == null){
  449. alert("请输入正确的优惠券码");
  450. return ;
  451. }
  452. }
  453. $("#Send").attr("data-dismiss","modal");
  454. $('#payModal').modal('show');
  455. $("#payCode").keydown(function(e){
  456. if(e.keyCode==13){
  457. $("#submitOrder").click();
  458. event.preventDefault();
  459. }
  460. });
  461. $('body').on('hidden.bs.modal', '.modal', function () {
  462. $(this).removeData();
  463. });
  464. },
  465. queryOrderDetail:function(orderSn){
  466. var storeId = sessionStorage.getItem("storeId");;
  467. $.get("../order/orderDetail/"+orderSn, function (r) {
  468. if (r.code == 0) {
  469. vm.orderProcessRecord = r.resultObj.orderProcessRecordEntity;
  470. vm.orderEntity = r.resultObj.orderEntity;
  471. vm.goodsDetailList = r.resultObj.goodsList;
  472. vm.currentOrderNo = r.resultObj.orderEntity.id;
  473. vm.tax = r.resultObj.tax;
  474. if(vm.orderProcessRecord.eleOrderStartTime){
  475. vm.orderProcessRecord.eleOrderStartTime = parsedate(vm.orderProcessRecord.eleOrderStartTime);
  476. }
  477. if(vm.orderProcessRecord.paymentStartTime){
  478. vm.orderProcessRecord.paymentStartTime = parsedate(vm.orderProcessRecord.paymentStartTime);
  479. }
  480. if(vm.orderProcessRecord.waybillStartTime){
  481. vm.orderProcessRecord.waybillStartTime = parsedate(vm.orderProcessRecord.waybillStartTime);
  482. }
  483. if(vm.orderProcessRecord.customsSuccTime){
  484. vm.orderProcessRecord.customsSuccTime = parsedate(vm.orderProcessRecord.customsSuccTime);
  485. }
  486. if(vm.orderProcessRecord.addOrderStartTime){
  487. vm.orderProcessRecord.addOrderStartTime = parsedate(vm.orderProcessRecord.addOrderStartTime);
  488. }
  489. }
  490. });
  491. },
  492. verification:function(){
  493. if(vm.orderProcessRecord.isCustomsSend != 1){
  494. alert("请等待清关完成");
  495. return ;
  496. }
  497. confirm('确认核销吗?', function () {
  498. $.ajax({
  499. type: "POST",
  500. url: "../order/printMsgAndChangeCode",
  501. contentType: "application/json",
  502. data: JSON.stringify({'id':vm.currentOrderNo,'sessionId':vm.sessionId}),
  503. success: function (r) {
  504. if (r.ticket != null) {
  505. // printArea(r.ticket);
  506. var content = getPrintContentOrder(r.ticket);
  507. printArea(content);
  508. alert('打印小票完成');
  509. }else{
  510. alert("打印小票失败");
  511. }
  512. }
  513. });
  514. })
  515. },
  516. refundOrder:function(){
  517. confirm('确认退款吗?', function () {
  518. $.ajax({
  519. type: "POST",
  520. url: "../order/orderRefund",
  521. contentType: "application/json",
  522. data: JSON.stringify({'orderId':9000,'sessionId':vm.sessionId}),
  523. success: function (r) {
  524. if (r.code == 0) {
  525. alert("退款成功")
  526. }else{
  527. alert("退款失败,请联系管理员");
  528. }
  529. }
  530. });
  531. })
  532. },
  533. retrySendOrder:function(){
  534. },
  535. getInfo: function (id) {
  536. $.get("../sys/notice/info/" + id, function (r) {
  537. vm.sysNotice = r.sysNotice;
  538. });
  539. },
  540. reload: function (event) {
  541. vm.showList = false;
  542. vm.showViewList = true;
  543. vm.showSaveSupplierGoods = true;
  544. var page = $("#jqGrid").jqGrid('getGridParam', 'page');
  545. $("#jqGrid").jqGrid('setGridParam', {
  546. postData: {
  547. storeId: vm.q.storeId,
  548. goodsName: vm.q.goodsName,
  549. goodsSn: vm.q.goodsSn,
  550. productSn: vm.q.productSn, category: vm.q.category, categoryTwo: vm.q.categoryTwo, goodsBizType:vm.q.goodsBizType,
  551. thirdPartyMerchCode: vm.q.thirdPartyMerchCode
  552. },
  553. page: page
  554. }).trigger("reloadGrid");
  555. vm.handleReset('formValidate');
  556. },
  557. handleSubmit: function (name) {
  558. handleSubmitValidate(this, name, function () {
  559. vm.saveOrUpdate()
  560. });
  561. },
  562. handleReset: function (name) {
  563. handleResetForm(this, name);
  564. },
  565. logout: function () {
  566. confirm('注:您确定要安全退出本次登录吗?', function () {
  567. dialogLoading(true);
  568. setTimeout(function () {
  569. toUrl('../logout?_' + $.now());
  570. }, 500);
  571. });
  572. }
  573. }
  574. });
  575. function getPrintContent(ticket) {
  576. var content = "<div style=\"width: 250px;font-family: 微软雅黑;font-size: 15px;\">";
  577. //小票头
  578. content += "<div style=\"text-align: center;width: 100%;font-weight:bold;font-size: 15px;\">";
  579. content += ticket.shopName
  580. content += "</div>";
  581. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  582. content += "<div style=\"width: 100%;margin:5px 0px;\">";
  583. /*content += "收银机号:" + ticket.salesNo;
  584. content += "</div>";
  585. content += "<div style=\"width: 100%;\">";*/
  586. content += "收银员:" + ticket.userName;
  587. content += "</div>";
  588. content += "<div style=\"width: 100%;font-size: 30px;margin:15px 0 10px 5px;\">";
  589. content += "取货码:" + ticket.code;
  590. content += "</div>";
  591. content += "<div style=\"width: 100%;margin:5px 0px;\">";
  592. content += "订单编号:" + ticket.orderNo;
  593. content += "</div>";
  594. content += "<div style=\"width: 100%;margin:5px 0px;\">";
  595. content += "打印日期:" + ticket.time;
  596. content += "</div>";
  597. content += "<div style=\"width: 100%;margin:5px 0px;font-size: 13px;\">";
  598. content += "该取货单号只有当天有效"
  599. content += "</div>";
  600. return content;
  601. }
  602. var printAreaCount = 0;
  603. function printArea(content) {
  604. var idPrefix = "printArea_";
  605. removePrintArea(idPrefix + printAreaCount);
  606. printAreaCount++;
  607. var iframeId = idPrefix + printAreaCount;
  608. var iframeStyle = 'width:0px;height:0px;left:0px;top:0px;';
  609. iframe = document.createElement('IFRAME');
  610. $(iframe).attr({
  611. style: iframeStyle,
  612. id: iframeId
  613. });
  614. document.body.appendChild(iframe);
  615. var doc = iframe.contentWindow.document;
  616. doc.open();
  617. //$(document).find("link").filter(function () {
  618. //return $(this).attr("rel").toLowerCase() == "stylesheet";
  619. //}).each(
  620. //function () {
  621. //doc.write('<link type="text/css" rel="stylesheet" href="'
  622. //+ $(this).attr("href") + '" >');
  623. //});
  624. doc.write('<div class="">' + content
  625. + '</div>');
  626. doc.close();
  627. var frameWindow = iframe.contentWindow;
  628. frameWindow.close();
  629. frameWindow.focus();
  630. // frameWindow.print();
  631. frameWindow.print();
  632. }
  633. function printArea2(content) {
  634. var idPrefix = "printArea_";
  635. removePrintArea(idPrefix + printAreaCount);
  636. printAreaCount++;
  637. var iframeId = idPrefix + printAreaCount;
  638. var iframeStyle = 'width:0px;height:0px;left:0px;top:0px;';
  639. iframe = document.createElement('IFRAME');
  640. $(iframe).attr({
  641. style: iframeStyle,
  642. id: iframeId
  643. });
  644. document.body.appendChild(iframe);
  645. var doc = iframe.contentWindow.document;
  646. doc.open();
  647. //$(document).find("link").filter(function () {
  648. //return $(this).attr("rel").toLowerCase() == "stylesheet";
  649. //}).each(
  650. //function () {
  651. //doc.write('<link type="text/css" rel="stylesheet" href="'
  652. //+ $(this).attr("href") + '" >');
  653. //});
  654. doc.write('<div class="">' + content
  655. + '</div>');
  656. doc.close();
  657. var frameWindow = iframe.contentWindow;
  658. frameWindow.close();
  659. frameWindow.focus();
  660. frameWindow.print();
  661. frameWindow.print();
  662. }
  663. var removePrintArea = function (id) {
  664. $("iframe#" + id).remove();
  665. };
  666. var webSocket;
  667. function openWebSocket() {
  668. var storeId = sessionStorage.getItem("storeId");
  669. if ("WebSocket" in window) {
  670. console.log("当前浏览器支持WebSocket");
  671. //实现化WebSocket对象
  672. //指定要连接的服务器地址与端口建立连接
  673. //注意ws、wss使用不同的端口。我使用自签名的证书测试,
  674. //无法使用wss,浏览器打开WebSocket时报错
  675. //ws对应http、wss对应https。
  676. // webSocket = new WebSocket("ws://183.62.225.124:8080/ws/server/"+storeId);
  677. webSocket = new WebSocket("ws://localhost:8080//ws/server/"+storeId);
  678. if (webSocket.readyState === webSocket.CONNECTING) {
  679. console.log('1.连接正在打开......');
  680. }
  681. // ---------- WebSocket 对象注册事件 ----------
  682. //连接打开事件
  683. webSocket.onopen = function () {
  684. if (webSocket.readyState === webSocket.OPEN) {
  685. console.log('2.连接已打开');
  686. }
  687. console.log('2.向服务端发送测试消息......');
  688. // webSocket.send("2.client发测试消息:Client sent test msg。");
  689. };
  690. //收到消息事件
  691. webSocket.onmessage = function (msg) {
  692. var data = Object.assign({}, JSON.parse(msg.data));
  693. vm.sessionId = data.sessionId;
  694. vm.pickUpCodeList = [];
  695. if(data.pickUpCodeList.length > 0){
  696. for(var i = 0 ; i < data.pickUpCodeList.length ; i++){
  697. console.log(data.pickUpCodeList[i].storeId);
  698. if(data.pickUpCodeList[i].storeId === storeId){
  699. vm.pickUpCodeList.push(data.pickUpCodeList[i]);
  700. }
  701. }
  702. }
  703. // vm.pickUpCodeList = vm.pickUpCodeList.concat(data.pickUpCodeList);
  704. // console.log(vm.pickUpCodeList);
  705. // webSocket.send("2.client发测试消息:Client sent test msg。");
  706. };
  707. //连接关闭事件
  708. webSocket.onclose = function () {
  709. if (!webSocket) {
  710. console.log('4.Socket连接已关闭');
  711. }
  712. };
  713. //发生了错误事件
  714. webSocket.onerror = function () {
  715. console.log("5.Socket发生了错误");
  716. }
  717. } else {
  718. console.log("当前浏览器不支持WebSocket");
  719. return false;
  720. }
  721. }
  722. function sendMessage() {
  723. if(webSocket && webSocket.readyState === webSocket.OPEN) {
  724. webSocket.send("client manual send message.")
  725. } else {
  726. console.log('6.未创建WebSocket连接');
  727. }
  728. }
  729. function closeWebSocket() {
  730. if (webSocket != null) {
  731. webSocket.close();
  732. webSocket = null;
  733. }
  734. console.log("关闭WebSocket");
  735. }
  736. //窗口关闭时,关闭连接
  737. window.unload = function () {
  738. webSocket.close();
  739. };
  740. function parsedate(value){
  741. var date = new Date(value);
  742. var year = date.getFullYear();
  743. var month = date.getMonth()+1; //月份+1
  744. var day = date.getDate();
  745. var hour = date.getHours();
  746. var minutes = date.getMinutes();
  747. var second = date.getSeconds();
  748. return year+"-"+month+"-"+day+" "+hour+":"+minutes +":"+second;
  749. }
  750. function getPrintContentOrder(ticket) {
  751. var content = "<div style=\"width: 250px;font-family: 微软雅黑;font-size: 8px;\">";
  752. //小票头
  753. content += "<div style=\"text-align: center;width: 100%;font-weight:bold;font-size: 13px;\">";
  754. content += ticket.ticketHead.title;
  755. content += "</div>";
  756. /*content += "<div style=\"width: 100%;\">";
  757. content += "会员:" + ticket.ticketHead.memberId;
  758. content += "</div>";*/
  759. content += "<div style=\"width: 100%;\">";
  760. content += "订单号:" + ticket.ticketHead.orderId;
  761. content += "</div>";
  762. content += "<div style=\"width: 100%;\">";
  763. content += "交易时间:" + ticket.ticketHead.tradeTime;
  764. content += "</div>";
  765. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  766. //商品信息
  767. content += "<table style=\"width: 100%;\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
  768. content += "<tr>";
  769. content += "<td style=\"width: 50%;text-align: left;font-size: 10px;font-weight: bold;\">商品名称</td>";
  770. content += "<td style=\"width: 17%;text-align: right;font-size: 10px;font-weight: bold;\">单价</td>";
  771. content += "<td style=\"width: 15%;text-align: right;font-size: 10px;font-weight: bold;\">数量</td>";
  772. content += "<td style=\"width: 18%;text-align: right;font-size: 10px;font-weight: bold;\">小计</td>";
  773. content += "</tr>";
  774. content += "</table>";
  775. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  776. content += "<table style=\"width: 100%;\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
  777. for (var i=0;i< ticket.goods.length;i++){
  778. content += "<tr>";
  779. content += "<td style=\"width: 50%;text-align: left;font-size: 8px;padding-top: 8px;\">";
  780. content += "<table style=\"width: 100%;\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
  781. content += "<tr>";
  782. content += "<td style=\"text-align: left;font-size: 8px;vertical-align:top;\">#</td>";
  783. content += "<td style=\"text-align: left;font-size: 8px;\">" + ticket.goods[i].gname + "</td>";
  784. content += "</tr>";
  785. content += "</table>";
  786. content += "</td>";
  787. content += "<td style=\"width: 17%;text-align: right;font-size: 8px;vertical-align:bottom;padding-top: 8px;\">" + ticket.goods[i].uprice + "</td>";
  788. content += "<td style=\"width: 15%;text-align: right;font-size: 8px;vertical-align:bottom;padding-top: 8px;\">" + ticket.goods[i].num + "</td>";
  789. content += "<td style=\"width: 18%;text-align: right;font-size: 8px;vertical-align:bottom;padding-top: 8px;\">" + ticket.goods[i].subtotal + "元</td>";
  790. content += "</tr>";
  791. }
  792. content += "</table>";
  793. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  794. //收银信息
  795. content += "<div style=\"width: 100%;\">";
  796. content += "<span style=\"float: left;width: 50%;text-align: left;\">商品合计:</span>";
  797. content += "<span style=\"float: left;width: 17%;text-align: left;\">" + ticket.cashInfo.goodsTotal + "件</span>";
  798. content += "<span style=\"float: right;width: 33%;text-align: right;\">" + ticket.cashInfo.total + "元</span>";
  799. content += "</div>";
  800. content += "<div style=\"width: 100%;\">";
  801. content += "<span style=\"float: left;width: 50%;text-align: left;\">实收:</span>";
  802. content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.receipts + "元</span>";
  803. content += "</div>";
  804. content += "<div style=\"width: 100%;\">";
  805. content += "<span style=\"float: left;width: 50%;text-align: left;\">找零:</span>";
  806. content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.oddChange + "元</span>";
  807. content += "</div>";
  808. content += "<div style=\"width: 100%;\">";
  809. content += "<span style=\"float: left;width: 50%;text-align: left;\">优惠券:</span>";
  810. content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.coupon + "元</span>";
  811. content += "</div>";
  812. content += "<div style=\"width: 100%;\">";
  813. content += "<span style=\"float: left;width: 50%;text-align: left;\">运费:</span>";
  814. content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.freight + "元</span>";
  815. content += "</div>";
  816. content += "<div style=\"width: 100%;\">";
  817. content += "<span style=\"float: left;width: 50%;text-align: left;\">支付渠道:</span>";
  818. content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.paymentMode + "</span>";
  819. content += "</div>";
  820. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  821. //海关清单信息
  822. content += "<div style=\"width: 100%;\">";
  823. content += "订单号:" + ticket.cusListing.orderId;
  824. content += "</div>";
  825. content += "<div style=\"width: 100%;\">";
  826. content += "运单编号:" + ticket.cusListing.waybillId;
  827. content += "</div>";
  828. content += "<div style=\"width: 100%;\">";
  829. content += "海关清单号:" + ticket.cusListing.invtNo;
  830. content += "</div>";
  831. content += "<div style=\"width: 100%;\">";
  832. content += "收货人:" + ticket.cusListing.consignee;
  833. content += "</div>";
  834. content += "<div style=\"width: 100%;\">";
  835. content += "收货人电话:" + ticket.cusListing.consigneeTel;
  836. content += "</div>";
  837. content += "<div style=\"width: 100%;\">";
  838. content += "始发地:" + ticket.cusListing.originAddress;
  839. content += "</div>";
  840. content += "<div style=\"width: 100%;\">";
  841. content += "交货地:" + ticket.cusListing.deliveryAddress;
  842. content += "</div>";
  843. content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
  844. content += "<div style=\"width: 100%;\">";
  845. content += ticket.ticketFoot.summary;
  846. content += "</div>";
  847. content += "<div style=\"width: 100%;\">";
  848. content += "客服电话:" + ticket.ticketFoot.serviceTel;
  849. content += "</div>";
  850. content += "<div style=\"width: 100%;\">";
  851. content += "网址:" + ticket.ticketFoot.url1;
  852. content += "</div>";
  853. content += "<div style=\"width: 100%;\">";
  854. content += ticket.ticketFoot.welcome;
  855. content += "</div>";
  856. return content;
  857. }
  858. function queryAssistantInfo(){
  859. $.get("../sys/user/info", function (r) {
  860. if(r.code == 0){
  861. vm.sysUserInfo = r.user;
  862. $.get("../store/getStoresByMerch?merchSn="+r.user.merchSn+"&_=1590374349985",function(result){
  863. if(result.code == 0){
  864. for(var i = 0 ;i < result.list.length; i++){
  865. if(result.list[i].id == r.user.storeId){
  866. vm.storeName = result.list[i].storeName;
  867. break;
  868. }
  869. }
  870. }
  871. });
  872. }
  873. });
  874. }