123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608 |
- $(function () {
- openWebSocket();
- queryAssistantInfo();
- });
- let vm = new Vue({
- el: '#rrapp',
- data: {
- showList: true,
- goodsDetail:false,
- title: null,
- goods:{},
- sysNotice: {},
- goodsList:[],
- orderInfo:[],
- userInfo:{},
- sysUserInfo:{},
- storeName:null,
- prodBarcode:null,
- sessionId:null,
- pickUpCodeList:[],
- goodsDetailList:[],
- orderEntity:{},
- orderProcessRecord:{},
- tax:0,
- currentOrderNo:null,
- customname:'',
- customidcard:'',
- storeId:null,
- index:0,
- max:0,
- ruleValidate: {
- name: [
- {required: true, message: '名称不能为空', trigger: 'blur'}
- ]
- },
- q: {
- name: ''
- }
- },
- methods: {
- query: function () {
- vm.storeId = sessionStorage.getItem("storeId");;
- var thisGoods = {};
- $.get("../goods/details/"+vm.prodBarcode+"/"+vm.storeId, function (r) {
- if (r.code == 0) {
- vm.goodsDetail = true;
- 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.goodsDesc = r.goodsDetails.goodsDesc;
- thisGoods.sellVolume = 1;
- if(!vm.goodsList[vm.index]){
- vm.index = vm.max;
- }
- thisGoods.id = vm.index++;
- vm.max++;
- var data = Object.assign({}, JSON.parse(JSON.stringify(thisGoods)));
- vm.goodsList.push(data);
- vm.goods = thisGoods;
- } else {
- alert(r.msg);
- }
- });
- },
- add:function(value){
- // 增加数量
- var goods = this.goodsList[value];
- goods.sellVolume = goods.sellVolume + 1;
- },
- minus:function(value){
- // 减少数量
- var goods = this.goodsList[value];
- if(goods.sellVolume === 1){
- alert("数量至少为1个");
- return ;
- }
- goods.sellVolume = goods.sellVolume - 1;
- },
- deleteItem:function(value){
- // 删除这条记录
- this.goodsList.splice(value,1,"");
- this.index = value;
- },
- clearGoodsList:function(){
- this.goodsList = [];
- },
- toOrderSubmit:function(){
- if(this.goodsList.length == 0){
- alert("请选择商品");
- return;
- }
- $('#myModal').modal('show')
- },
- submitOrder:function(){
- $('#payCode').unbind('keydown').keydown(function(event){});
- var param = {'userInfo':vm.userInfo,'payCode':this.$refs.payCode.currentValue,'goodsList':vm.goodsList,'sessionId':vm.sessionId};
- this.$refs.payCode.currentValue = '';
- $.ajax({
- type: "POST",
- url: "../order/orderConfirm",
- contentType: "application/json",
- data: JSON.stringify(param),
- success: function (r) {
- console.log(r);
- if (r.code == 0) {
- if (r.resultObj != null) {
- $(".form-group input[type=text]").each(function(){
- this.value = '';
- })
- // 打印取货码小票
- var content = getPrintContent(r.resultObj);
- printArea(content);
- vm.goodsList = [];
- vm.customname = '' ;
- vm.customidcard = '';
- // alert('打印小票完成');
- }else{
- // alert("打印小票失败");
- }
- } else {
- alert(r.msg);
- }
- }
- });
- },
- getIDCardInfo: function(){
- console.log(1);
- $.get("../order/getIdCardInfo", function (r){
- if(r.code === 0){
- var data = JSON.parse(r.info);
- vm.customname = data.rows[0].data.name;
- vm.customidcard = data.rows[0].data.id_no;
- }
- });
- },
- submitCustomInfo:function(){
- this.userInfo.customName = vm.customname == '' ? this.$refs.customName.value :vm.customname;
- this.userInfo.customIDCard = vm.customidcard == '' ? this.$refs.customIDCard.value :vm.customidcard;
- this.userInfo.customPhone = this.$refs.customPhone.value;
- debugger
- 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)$/;
- if(!idcardReg.test(this.userInfo.customIDCard)){
- alert("请输入正确的身份证号");
- return ;
- }
- if(!(/^1[3456789]\d{9}$/.test(this.userInfo.customPhone))){
- alert("手机号码有误,请重填");
- return ;
- }
- $("#Send").attr("data-dismiss","modal");
- $('#payModal').modal('show');
- $("#payCode").keydown(function(e){
- if(e.keyCode==13){
- $("#submitOrder").click();
- event.preventDefault();
- }
- });
- $('body').on('hidden.bs.modal', '.modal', function () {
- $(this).removeData();
- });
- },
- queryOrderDetail:function(orderSn){
- var storeId = sessionStorage.getItem("storeId");;
- $.get("../order/orderDetail/"+orderSn, function (r) {
- if (r.code == 0) {
- vm.orderProcessRecord = r.resultObj.orderProcessRecordEntity;
- vm.orderEntity = r.resultObj.orderEntity;
- vm.goodsDetailList = r.resultObj.goodsList;
- vm.currentOrderNo = r.resultObj.orderEntity.id;
- vm.tax = r.resultObj.tax;
- if(vm.orderProcessRecord.eleOrderStartTime){
- vm.orderProcessRecord.eleOrderStartTime = parsedate(vm.orderProcessRecord.eleOrderStartTime);
- }
- if(vm.orderProcessRecord.paymentStartTime){
- vm.orderProcessRecord.paymentStartTime = parsedate(vm.orderProcessRecord.paymentStartTime);
- }
- if(vm.orderProcessRecord.waybillStartTime){
- vm.orderProcessRecord.waybillStartTime = parsedate(vm.orderProcessRecord.waybillStartTime);
- }
- if(vm.orderProcessRecord.customsSuccTime){
- vm.orderProcessRecord.customsSuccTime = parsedate(vm.orderProcessRecord.customsSuccTime);
- }
- if(vm.orderProcessRecord.addOrderStartTime){
- vm.orderProcessRecord.addOrderStartTime = parsedate(vm.orderProcessRecord.addOrderStartTime);
- }
- }
- });
- },
- verification:function(){
- if(vm.orderProcessRecord.isCustomsSend != 1){
- alert("请等待清关完成");
- return ;
- }
- confirm('确认核销吗?', function () {
- $.ajax({
- type: "POST",
- url: "../order/printMsgAndChangeCode",
- contentType: "application/json",
- data: JSON.stringify({'id':vm.currentOrderNo,'sessionId':vm.sessionId}),
- success: function (r) {
- if (r.ticket != null) {
- // printArea(r.ticket);
- var content = getPrintContentOrder(r.ticket);
- printArea(content);
- alert('打印小票完成');
- }else{
- alert("打印小票失败");
- }
- }
- });
- })
- },
- refundOrder:function(){
- confirm('确认退款吗?', function () {
- $.ajax({
- type: "POST",
- url: "../order/orderRefund",
- contentType: "application/json",
- data: JSON.stringify({'orderId':9000,'sessionId':vm.sessionId}),
- success: function (r) {
- if (r.code == 0) {
- alert("退款成功")
- }else{
- alert("退款失败,请联系管理员");
- }
- }
- });
- })
- },
- retrySendOrder:function(){
- },
- getInfo: function (id) {
- $.get("../sys/notice/info/" + id, function (r) {
- vm.sysNotice = r.sysNotice;
- });
- },
- reload: function (event) {
- vm.showList = false;
- vm.showViewList = true;
- vm.showSaveSupplierGoods = true;
- var page = $("#jqGrid").jqGrid('getGridParam', 'page');
- $("#jqGrid").jqGrid('setGridParam', {
- postData: {
- storeId: vm.q.storeId,
- goodsName: vm.q.goodsName,
- goodsSn: vm.q.goodsSn,
- productSn: vm.q.productSn, category: vm.q.category, categoryTwo: vm.q.categoryTwo, goodsBizType:vm.q.goodsBizType,
- thirdPartyMerchCode: vm.q.thirdPartyMerchCode
- },
- page: page
- }).trigger("reloadGrid");
- vm.handleReset('formValidate');
- },
- handleSubmit: function (name) {
- handleSubmitValidate(this, name, function () {
- vm.saveOrUpdate()
- });
- },
- handleReset: function (name) {
- handleResetForm(this, name);
- },
- logout: function () {
- confirm('注:您确定要安全退出本次登录吗?', function () {
- dialogLoading(true);
- setTimeout(function () {
- toUrl('../logout?_' + $.now());
- }, 500);
- });
- }
- }
- });
- function getPrintContent(ticket) {
- var content = "<div style=\"width: 250px;font-family: 微软雅黑;font-size: 8px;\">";
- //小票头
- content += "<div style=\"text-align: center;width: 100%;font-weight:bold;font-size: 13px;\">";
- content += ticket.shopName
- content += "</div>";
- content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
- content += "<div style=\"width: 100%;\">";
- content += "收银机号:" + ticket.salesNo;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "收银员:" + ticket.userName;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "取货码:" + ticket.code;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "该取货单号只有当天有效"
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "订单编号:" + ticket.orderNo;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "打印日期:" + ticket.time;
- content += "</div>";
- return content;
- }
- var printAreaCount = 0;
- function printArea(content) {
- var idPrefix = "printArea_";
- removePrintArea(idPrefix + printAreaCount);
- printAreaCount++;
- var iframeId = idPrefix + printAreaCount;
- var iframeStyle = 'position:absolute;width:0px;height:0px;left:-500px;top:-500px;';
- iframe = document.createElement('IFRAME');
- $(iframe).attr({
- style: iframeStyle,
- id: iframeId
- });
- document.body.appendChild(iframe);
- var doc = iframe.contentWindow.document;
- doc.open();
- //$(document).find("link").filter(function () {
- //return $(this).attr("rel").toLowerCase() == "stylesheet";
- //}).each(
- //function () {
- //doc.write('<link type="text/css" rel="stylesheet" href="'
- //+ $(this).attr("href") + '" >');
- //});
- doc.write('<div class="">' + content
- + '</div>');
- doc.close();
- var frameWindow = iframe.contentWindow;
- frameWindow.close();
- frameWindow.focus();
- frameWindow.print();
- frameWindow.print();
- }
- var removePrintArea = function (id) {
- $("iframe#" + id).remove();
- };
- var webSocket;
- function openWebSocket() {
- var storeId = sessionStorage.getItem("storeId");
- if ("WebSocket" in window) {
- console.log("当前浏览器支持WebSocket");
- //实现化WebSocket对象
- //指定要连接的服务器地址与端口建立连接
- //注意ws、wss使用不同的端口。我使用自签名的证书测试,
- //无法使用wss,浏览器打开WebSocket时报错
- //ws对应http、wss对应https。
- webSocket = new WebSocket("ws://183.62.225.124:8080/ws/server/"+storeId);
- // webSocket = new WebSocket("ws://127.0.0.1:8080/ws/server/"+storeId);
- if (webSocket.readyState === webSocket.CONNECTING) {
- console.log('1.连接正在打开......');
- }
- // ---------- WebSocket 对象注册事件 ----------
- //连接打开事件
- webSocket.onopen = function () {
- if (webSocket.readyState === webSocket.OPEN) {
- console.log('2.连接已打开');
- }
- console.log('2.向服务端发送测试消息......');
- // webSocket.send("2.client发测试消息:Client sent test msg。");
- };
- //收到消息事件
- webSocket.onmessage = function (msg) {
- var data = Object.assign({}, JSON.parse(msg.data));
- vm.sessionId = data.sessionId;
- vm.pickUpCodeList = [];
- if(data.pickUpCodeList.length > 0){
- console.log(storeId);
- for(var i = 0 ; i < data.pickUpCodeList.length ; i++){
- console.log(data.pickUpCodeList[i].storeId);
- if(data.pickUpCodeList[i].storeId === storeId){
- vm.pickUpCodeList.push(data.pickUpCodeList[i]);
- }
- }
- }
- // vm.pickUpCodeList = vm.pickUpCodeList.concat(data.pickUpCodeList);
- // console.log(vm.pickUpCodeList);
- // webSocket.send("2.client发测试消息:Client sent test msg。");
- };
- //连接关闭事件
- webSocket.onclose = function () {
- if (!webSocket) {
- console.log('4.Socket连接已关闭');
- }
- };
- //发生了错误事件
- webSocket.onerror = function () {
- console.log("5.Socket发生了错误");
- }
- } else {
- console.log("当前浏览器不支持WebSocket");
- return false;
- }
- }
- function sendMessage() {
- if(webSocket && webSocket.readyState === webSocket.OPEN) {
- webSocket.send("client manual send message.")
- } else {
- console.log('6.未创建WebSocket连接');
- }
- }
- function closeWebSocket() {
- if (webSocket != null) {
- webSocket.close();
- webSocket = null;
- }
- console.log("关闭WebSocket");
- }
- //窗口关闭时,关闭连接
- window.unload = function () {
- webSocket.close();
- };
- function parsedate(value){
- var date = new Date(value);
- var year = date.getFullYear();
- var month = date.getMonth()+1; //月份+1
- var day = date.getDate();
- var hour = date.getHours();
- var minutes = date.getMinutes();
- var second = date.getSeconds();
- return year+"-"+month+"-"+day+" "+hour+":"+minutes +":"+second;
- }
- function getPrintContentOrder(ticket) {
- var content = "<div style=\"width: 250px;font-family: 微软雅黑;font-size: 8px;\">";
- //小票头
- content += "<div style=\"text-align: center;width: 100%;font-weight:bold;font-size: 13px;\">";
- content += ticket.ticketHead.title;
- content += "</div>";
- /*content += "<div style=\"width: 100%;\">";
- content += "会员:" + ticket.ticketHead.memberId;
- content += "</div>";*/
- content += "<div style=\"width: 100%;\">";
- content += "订单号:" + ticket.ticketHead.orderId;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "交易时间:" + ticket.ticketHead.tradeTime;
- content += "</div>";
- content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
- //商品信息
- content += "<table style=\"width: 100%;\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
- content += "<tr>";
- content += "<td style=\"width: 50%;text-align: left;font-size: 10px;font-weight: bold;\">商品名称</td>";
- content += "<td style=\"width: 17%;text-align: right;font-size: 10px;font-weight: bold;\">单价</td>";
- content += "<td style=\"width: 15%;text-align: right;font-size: 10px;font-weight: bold;\">数量</td>";
- content += "<td style=\"width: 18%;text-align: right;font-size: 10px;font-weight: bold;\">小计</td>";
- content += "</tr>";
- content += "</table>";
- content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
- content += "<table style=\"width: 100%;\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
- for (var i=0;i< ticket.goods.length;i++){
- content += "<tr>";
- content += "<td style=\"width: 50%;text-align: left;font-size: 8px;padding-top: 8px;\">";
- content += "<table style=\"width: 100%;\" border=\"0\" cellspacing=\"0\" cellpadding=\"0\">";
- content += "<tr>";
- content += "<td style=\"text-align: left;font-size: 8px;vertical-align:top;\">#</td>";
- content += "<td style=\"text-align: left;font-size: 8px;\">" + ticket.goods[i].gname + "</td>";
- content += "</tr>";
- content += "</table>";
- content += "</td>";
- content += "<td style=\"width: 17%;text-align: right;font-size: 8px;vertical-align:bottom;padding-top: 8px;\">" + ticket.goods[i].uprice + "</td>";
- content += "<td style=\"width: 15%;text-align: right;font-size: 8px;vertical-align:bottom;padding-top: 8px;\">" + ticket.goods[i].num + "</td>";
- content += "<td style=\"width: 18%;text-align: right;font-size: 8px;vertical-align:bottom;padding-top: 8px;\">" + ticket.goods[i].subtotal + "元</td>";
- content += "</tr>";
- }
- content += "</table>";
- content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
- //收银信息
- content += "<div style=\"width: 100%;\">";
- content += "<span style=\"float: left;width: 50%;text-align: left;\">商品合计:</span>";
- content += "<span style=\"float: left;width: 17%;text-align: left;\">" + ticket.cashInfo.goodsTotal + "件</span>";
- content += "<span style=\"float: right;width: 33%;text-align: right;\">" + ticket.cashInfo.total + "元</span>";
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "<span style=\"float: left;width: 50%;text-align: left;\">实收:</span>";
- content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.receipts + "元</span>";
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "<span style=\"float: left;width: 50%;text-align: left;\">找零:</span>";
- content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.oddChange + "元</span>";
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "<span style=\"float: left;width: 50%;text-align: left;\">优惠券:</span>";
- content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.coupon + "元</span>";
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "<span style=\"float: left;width: 50%;text-align: left;\">运费:</span>";
- content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.freight + "元</span>";
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "<span style=\"float: left;width: 50%;text-align: left;\">支付渠道:</span>";
- content += "<span style=\"float: right;width: 50%;text-align: right;\">" + ticket.cashInfo.paymentMode + "</span>";
- content += "</div>";
- content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
- //海关清单信息
- content += "<div style=\"width: 100%;\">";
- content += "订单号:" + ticket.cusListing.orderId;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "运单编号:" + ticket.cusListing.waybillId;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "海关清单号:" + ticket.cusListing.invtNo;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "收货人:" + ticket.cusListing.consignee;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "收货人电话:" + ticket.cusListing.consigneeTel;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "始发地:" + ticket.cusListing.originAddress;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "交货地:" + ticket.cusListing.deliveryAddress;
- content += "</div>";
- content += "<div style=\"width: 100%;overflow:hidden;white-space: nowrap;\">--------------------------------------------------</div>";
- content += "<div style=\"width: 100%;\">";
- content += ticket.ticketFoot.summary;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "客服电话:" + ticket.ticketFoot.serviceTel;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += "网址:" + ticket.ticketFoot.url1;
- content += "</div>";
- content += "<div style=\"width: 100%;\">";
- content += ticket.ticketFoot.welcome;
- content += "</div>";
- return content;
- }
- function queryAssistantInfo(){
- $.get("../sys/user/info", function (r) {
- if(r.code == 0){
- vm.sysUserInfo = r.user;
- $.get("../store/getStoresByMerch?merchSn="+r.user.merchSn+"&_=1590374349985",function(result){
- if(result.code == 0){
- for(var i = 0 ;i < result.list.length; i++){
- if(result.list[i].id == r.user.storeId){
- vm.storeName = result.list[i].storeName;
- break;
- }
- }
- }
- });
- }
- });
- }
|