// ==UserScript== // @name 中烟新商盟小助手 // @namespace https://github.com/sdokio // @version 0.0.1 // @author SoyaDokio // @description 中烟新商盟订烟时删除所有订购量为0的行 // @homepage https://github.com/sdokio/UserScript // @icon  // @supportURL https://github.com/sdokio/UserScript/issues/new/choose // @license MIT // @match *://*.xinshangmeng.com/eciop/orderForCC/cgtListForCC.htm* // @match *://*.xinshangmeng.com/eciop/orderForCC/cgtCartForCC.htm* // @run-at document-idle // @grant GM_addStyle // @grant GM_getValue // @grant GM_setValue // @grant GM_xmlhttpRequest // @note 2022/01/23 0.1.1 初版发布 // ==/UserScript== (function() { "use strict"; main(); function main() { if (document.location.host.indexOf('xinshangmeng.com') > -1) { if (document.location.pathname === '/eciop/orderForCC/cgtListForCC.htm') { var cgtCode = '6901028180580';// 蓝楼 getCgtLmt(cgtCode); // 暂时不可用,原因仍需调查 // appendButtonSetAllReq(); } else if (document.location.pathname === '/eciop/orderForCC/cgtCartForCC.htm') { appendButtonRemoveAll(); } } } // 获取指定商品的可用量 function getCgtLmt(cgtCode) { GM_xmlhttpRequest({ url: getlink + 'order/cgtCo.do', method: 'POST', headers: {'Content-Type': 'application/x-www-form-urlencoded'}, data: 'method=getBusiCgtLmt' + '&orgCode=' + porgCode + '&custCode=' + pcustCode + '&cgtCode=' + cgtCode + '&orderId=' + document.querySelector('#coNum').value + '&orderDate=' + porderDate + '&zone=' + porgCode + '&v=' + new Date().getTime() + '&_view=async', onload: function(data) { console.log(data.responseText); var cgtLmt = JSON.parse(data.responseText)[0].QTY_LMT; var cgtReq = Math.ceil(cgtLmt * 1.5); console.log('cgtReq=' + cgtReq); setOrdQty(cgtCode, 55, !1, cgtReq); } }); } // 收藏指定商品 function addFav() { var inXml = ""; inXml = '<xsm><fav_info org_code="' + orgCode + '" cust_code="' + custCode + '">', inXml = inXml + '<cgt cgt_code="' + cgtCode + '" cgt_name="' + cgtName + '" qty="1" seq="999" note=""></cgt>', inXml += "</fav_info></xsm>", inXml = encodeURI(inXml); GM_xmlhttpRequest({ url: getlink + 'order/cgtCo.do' + 'method=addFav' + '&zone=' + porgCode + '&v=' + new Date().getTime() + '&_view=async', method: 'POST', headers: {'Content-Type': 'application/x-www-form-urlencoded'}, data: {inXml: inXml}, onload: function(data) { console.log(data.responseText); var cgtLmt = JSON.parse(data.responseText)[0].QTY_LMT; var cgtReq = Math.ceil(cgtLmt * 1.5); console.log('cgtReq=' + cgtReq); setOrdQty(cgtCode, 55, !1, cgtReq); } }); } // 添加按钮:【一键订满】 function appendButtonSetAllReq() { // 判断是否为目标页面 if (document.location.pathname.indexOf('/cgtListForCC.htm') == -1) { return; } // 获取加入购物车按钮 var smt = document.querySelector('#smt'); if (!smt) return; var eleParent = smt.parentElement; if (!eleParent) return; // 添加一键订满按钮 var btnSetAllReq = document.createElement('input'); btnSetAllReq.className = 'xsm-order-check-box-input m110'; btnSetAllReq.type = 'button'; btnSetAllReq.value = '一键订满'; btnSetAllReq.style += ';font-size: 18px;margin-right: 10px;'; btnSetAllReq.addEventListener('click', setAllReqWithThreeSecondTimesOfKyl); eleParent.appendChild(btnSetAllReq); } // 添加按钮:【没货全删】 function appendButtonRemoveAll() { // 判断是否为目标页面 if (document.location.pathname.indexOf('/cgtCartForCC.htm') == -1) { return; } // 获取继续购物按钮 var addbtn = document.querySelector('#addbtn'); if (!addbtn) return; var eleParent = addbtn.parentElement; if (!eleParent) return; // 添加一键全删按钮 var btnRemoveAll = document.createElement('input'); btnRemoveAll.className = 'xsm-order-check-box-input m110'; btnRemoveAll.type = 'button'; btnRemoveAll.value = '一键全删'; btnRemoveAll.style += ';font-size: 18px;'; btnRemoveAll.addEventListener('click', removeAllWithKylZero); eleParent.appendChild(btnRemoveAll); } // 一键全订1.5倍可用量(限收收藏) function setAllReqWithThreeSecondTimesOfKyl() { console.log('function BIND testing'); var times = 1.5; setAllReqWithSpecificTimesOfKyl(times); } // 设定可用量的指定倍数的需求量(仅限已收藏商品)(若含小数则个位进1) // 例:商品1的可用量为1时,将订购量设为1x[指定倍数] // 商品1的可用量为5时,将订购量设为5x[指定倍数] function setAllReqWithSpecificTimesOfKyl(times) { // 若尚未勾选“仅显示收藏”则勾选它 var chkIsFav = document.querySelector('#isFav'); if (chkIsFav && !chkIsFav.checked) { chkIsFav.click(); } // 把每行需求量的“+”号都点一下 var rows = document.querySelector('#newul').querySelectorAll('li');// 每个商品是一行 for (var row of rows) { var reqQty = row.querySelector('.cgt-col-req-qty');// 可编辑的需求量 if (reqQty.style.display != 'none') { reqQty.querySelector('.adda').click(); } } // 随便点一下好让最后一个输入框失焦 // rows.click();// 这行似乎无效,且当商品总行数只有1行时下面代码会失效 // 把每行的订购量都设定为该行可用量的指定倍数 for (var row of rows) { var qtlLmt = row.querySelector('.cgt-col-qtl-lmt');// 可用量 qtlLmt = parseInt(qtlLmt.innerText.trim()); var req = 1; if (qtlLmt > 0) { req = Math.ceil(qtlLmt * times); } if (req > 1) { var ordQty = row.querySelector('.cgt-col-ord-qty');// 可编辑的订购量 ordQty.querySelector('input[name="ord_qty"]').value = req; } } } // 一键全删订购量为0商品 function removeAllWithKylZero() { var ord = '0'; removeAllWithKyl(ord); } // 删除订购量为指定值的所有商品 function removeAllWithKyl(ord) { // 依次点击每一个可用量为0的行的删除按钮 var rows = document.getElementById('uladd').children; for (var i = rows.length - 1; i >= 0; i--) { var spans = rows[i].getElementsByTagName('span'); for (var span of spans) { if (span.id.startsWith('qty_lmt') && span.innerText.trim() == ord) { rows[i].getElementsByClassName('operation')[0].getElementsByClassName('delCgt')[0].click(); } } } // 隐藏黑色半透明背景 var _interval1 = setInterval(function() { var eleLastChild = document.body.lastChild; if (eleLastChild.tagName === 'DIV' && eleLastChild.style.zIndex === '9999') { eleLastChild.remove(); } }, 50); // 隐藏弹窗 var _interval2 = setInterval(function() { var eleDivs = document.getElementsByClassName('ui_success'); for (var eleDiv of eleDivs) { eleDiv.remove(); } }, 50); setTimeout(function() { clearInterval(_interval1); clearInterval(_interval2); }, 3000); } })();