|
@@ -0,0 +1,486 @@
|
|
|
+<!doctype html>
|
|
|
+<html>
|
|
|
+<head>
|
|
|
+<meta charset="utf-8">
|
|
|
+<meta name="viewport" content="width=device-width,minimum-scale=1.0,maximum-scale=1.0" />
|
|
|
+<meta name="author" content="siweiyong 2602812659@qq.com"/>
|
|
|
+<title>设置商品</title>
|
|
|
+<link rel="stylesheet" href="../script/lib/miniui/themes/default/miniui.css">
|
|
|
+<link rel="stylesheet" href="../script/lib/layui/css/layui.css" />
|
|
|
+<link rel="stylesheet" href="../script/lib/cashier/common.css">
|
|
|
+<link rel="stylesheet" href="../script/lib/layui/admin/modules/plugin/formselects/formselects.css" media="all" />
|
|
|
+<script src="../script/lib/jquery/jquery.min.js"></script>
|
|
|
+<script src="../script/lib/miniui/miniui.js"></script>
|
|
|
+<script src="../script/lib/layui/layui.js"></script>
|
|
|
+<script><{Dever::script()}></script>
|
|
|
+<script src="../script/dever/core.js"></script>
|
|
|
+</head>
|
|
|
+<body style="background: #F6F7F9;">
|
|
|
+<div class="main">
|
|
|
+<form class="layui-form" lay-filter="form">
|
|
|
+ <div class="layui-row">
|
|
|
+ <div class="main_left layui-col-xs12 layui-col-md3">
|
|
|
+ <div class="layui-row">
|
|
|
+ <div class="top">
|
|
|
+ <i class="layui-icon layui-icon-app"></i>商品列表
|
|
|
+ </div>
|
|
|
+ <div class="left_main">
|
|
|
+ <input id="key" class="mini-textbox" onenter="onKeyEnter" value="请输入商品名称" onclick="setVal('key')"/>
|
|
|
+ <a class="mini-button" onclick="search()">查询</a>
|
|
|
+ <button class="layui-btn layui-btn-button" type="button" style="vertical-align: middle;margin-bottom: 2px;" onclick="addGoods()">一键添加</button>
|
|
|
+ <button class="layui-btn layui-btn-button" type="button" style="vertical-align: middle;margin-bottom: 2px;" onclick="delGoods()">一键删除</button>
|
|
|
+ <ul id="tree1" class="mini-tree" url="<{$url}>" showTreeIcon="true" textField="name" idField="id" expandOnLoad="true" onNodeClick="onNodeClick">
|
|
|
+ </ul>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="main_right layui-col-xs12 layui-col-md9">
|
|
|
+ <div class="layui-row">
|
|
|
+ <div class="top">
|
|
|
+ <div style="display:none;">
|
|
|
+ <label>选择商品分类:</label>
|
|
|
+ <div class="layui-input-inline">
|
|
|
+
|
|
|
+ <div><select xm-select="shop_id" xm-select-skin="normal" xm-select-search="<{$search}>" xm-select-search-type="dl" xm-select-radio="" class="update_value form-control layui-input layui-select" name="shop_id" id="shop_id" ></select></div>
|
|
|
+
|
|
|
+ </div>
|
|
|
+ <div class="layui-input-inline">
|
|
|
+ <button class="layui-btn layui-btn-button" type="button" style="vertical-align: middle;margin-bottom: 2px;" onclick="setShop()">确认选择</button>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="layui-input-inline" style="margin-left:20px">
|
|
|
+ <input id="search_key" class="mini-textbox" value="请输入商品名称" onclick="setVal('search_key')"/>
|
|
|
+ <a class="mini-button" onclick="searchGoods()">搜索</a>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="goods_list" style="height:645px;">
|
|
|
+ <table class="layui-table">
|
|
|
+ <thead>
|
|
|
+ <tr>
|
|
|
+ <th lay-data="{field:'id'}">商品ID</th>
|
|
|
+ <th lay-data="{field:'name'}">商品名称</th>
|
|
|
+ <th lay-data="{field:'total', edit: 'text'}">当前库存</th>
|
|
|
+ <th lay-data="{field:'price', edit: 'text'}">销售价</th>
|
|
|
+ <th lay-data="{field:'commission', edit: 'text'}">销售佣金</th>
|
|
|
+ <th lay-data="{field:'buy_price', edit: 'text'}">采购价</th>
|
|
|
+ <th lay-data="{field:'number', edit: 'text'}">采购起订数</th>
|
|
|
+ <th lay-data="{field:'operation'}">操作</th>
|
|
|
+ </tr>
|
|
|
+ </thead>
|
|
|
+ <tbody id="goods">
|
|
|
+
|
|
|
+ </tbody>
|
|
|
+ </table>
|
|
|
+ </div>
|
|
|
+ <div class="total ft16">
|
|
|
+ 合计:【<span> 当前总库存:<i class="totalNum">0</i> </span>】
|
|
|
+ </div>
|
|
|
+ <div class="towbtn">
|
|
|
+ <input type="button" id="settlement" value="确认设置">
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+</div>
|
|
|
+</form>
|
|
|
+</div>
|
|
|
+<script>
|
|
|
+ var form;
|
|
|
+ var goods = {};
|
|
|
+ var del_goods = {};
|
|
|
+ var tree = {};
|
|
|
+ var commission = '<{$info["commission"]}>';
|
|
|
+ layui.config(
|
|
|
+ {
|
|
|
+ base: '../script/lib/layui/admin/' //静态资源所在路径
|
|
|
+ ,version: true
|
|
|
+ }).extend(
|
|
|
+ {
|
|
|
+ index: 'lib/index', //主入口模块
|
|
|
+ formSelects: 'plugin/formselects/formselects'
|
|
|
+ }).use(['index', 'contlist', 'table', 'form', 'formSelects','layer'], function()
|
|
|
+ {
|
|
|
+ var table = layui.table;
|
|
|
+ form = layui.form;
|
|
|
+ var formSelects = layui.formSelects;
|
|
|
+
|
|
|
+ mini.parse();
|
|
|
+ tree = mini.get("tree1");
|
|
|
+ for (var i in tree.data) {
|
|
|
+ if (typeof(tree.data[i].children) == 'object') {
|
|
|
+ if (tree.data[i].children.length > 0) {
|
|
|
+ for (var j in tree.data[i].children) {
|
|
|
+ if(tree.data[i].children[j].select == 1) {
|
|
|
+ setGoods(tree.data[i].children[j]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else if(tree.data[i].select == 1) {
|
|
|
+ setGoods(tree.data[i]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ });
|
|
|
+
|
|
|
+ $(function()
|
|
|
+ {
|
|
|
+ $("#settlement").click(function(){
|
|
|
+ var url = '<{$submit}>';
|
|
|
+ var id = '<{$id}>';
|
|
|
+ var role = '<{$role}>';
|
|
|
+
|
|
|
+ layui.layer.confirm('确定进行此项设置吗?', function() {
|
|
|
+ var goods_string = JSON.stringify(goods);
|
|
|
+
|
|
|
+ var data = {};
|
|
|
+ data = {id:id, role:role, goods:goods_string};
|
|
|
+ $.post(url, data, function(t) {
|
|
|
+ t = JSON.parse(t);
|
|
|
+ if (t.status == 1) {
|
|
|
+ layui.layer.alert('商品设置成功', function(index){
|
|
|
+ if (t.data == 'refer') {
|
|
|
+ history.back();
|
|
|
+ } else {
|
|
|
+ location.href = t.data;
|
|
|
+ }
|
|
|
+ layer.close(index);
|
|
|
+ });
|
|
|
+ } else {
|
|
|
+ layui.layer.alert(t.msg);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ });
|
|
|
+ })
|
|
|
+
|
|
|
+ $("#goods").on("keyup", ".goods_num", function() {
|
|
|
+ var num = parseFloat($(this).val());
|
|
|
+ if (num < 0) {
|
|
|
+ num = 0;
|
|
|
+ $(this).val(0);
|
|
|
+ }
|
|
|
+ var id = $(this).parent().attr('value');
|
|
|
+ goods[id].num = num;
|
|
|
+ setTotal();
|
|
|
+ });
|
|
|
+
|
|
|
+ $("#goods").on("keyup", ".goods_min", function() {
|
|
|
+ var min = parseFloat($(this).val());
|
|
|
+ if (min < 0) {
|
|
|
+ min = 1;
|
|
|
+ $(this).val(1);
|
|
|
+ }
|
|
|
+ var id = $(this).parent().attr('value');
|
|
|
+ goods[id].min = min;
|
|
|
+ setTotal();
|
|
|
+ });
|
|
|
+ })
|
|
|
+
|
|
|
+ function search()
|
|
|
+ {
|
|
|
+ var key = mini.get("key").getValue();
|
|
|
+ if (key == "") {
|
|
|
+ tree.clearFilter();
|
|
|
+ } else {
|
|
|
+ key = key.toLowerCase();
|
|
|
+ tree.filter(function (node) {
|
|
|
+ var name = node.name ? node.name.toLowerCase() : "";
|
|
|
+ if (name.indexOf(key) != -1) {
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }
|
|
|
+ function onKeyEnter(e)
|
|
|
+ {
|
|
|
+ search();
|
|
|
+ }
|
|
|
+
|
|
|
+ function onNodeClick()
|
|
|
+ {
|
|
|
+ var tree=mini.get("tree1");
|
|
|
+ node=tree.getSelectedNode();
|
|
|
+ if(node.end) {
|
|
|
+ setGoods(node);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function setVal(e)
|
|
|
+ {
|
|
|
+ mini.get(e).setValue('');
|
|
|
+ }
|
|
|
+
|
|
|
+ function searchGoods()
|
|
|
+ {
|
|
|
+ var key = mini.get("search_key").getValue();
|
|
|
+
|
|
|
+ if (key == "") {
|
|
|
+ $(".mytr").show();
|
|
|
+ } else {
|
|
|
+ key = key.toLowerCase();
|
|
|
+ $(".mytr").show();
|
|
|
+ $(".goods_name").each(function(t) {
|
|
|
+ var name = $(this).html();
|
|
|
+ name = name.toLowerCase();
|
|
|
+ if (name.indexOf(key) == -1) {
|
|
|
+ $(this).parent().hide();
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ // 一键添加
|
|
|
+ function addGoods()
|
|
|
+ {
|
|
|
+ var key = mini.get("key").getValue();
|
|
|
+ if (key == '请输入商品名称') {
|
|
|
+ key = '';
|
|
|
+ }
|
|
|
+ if (key) {
|
|
|
+ key = key.toLowerCase();
|
|
|
+ }
|
|
|
+ for (var i in tree.data) {
|
|
|
+ if (typeof(tree.data[i].children) == 'object') {
|
|
|
+ if (tree.data[i].children.length > 0) {
|
|
|
+ for (var j in tree.data[i].children) {
|
|
|
+ if (key) {
|
|
|
+ var name = tree.data[i].children[j].name;
|
|
|
+ if (name.indexOf(key) != -1) {
|
|
|
+ setGoods(tree.data[i].children[j]);
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ setGoods(tree.data[i].children[j]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if (key) {
|
|
|
+ var name = tree.data[i].name;
|
|
|
+ if (name.indexOf(key) != -1) {
|
|
|
+ setGoods(tree.data[i]);
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ setGoods(tree.data[i]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ // 一键删除
|
|
|
+ function delGoods()
|
|
|
+ {
|
|
|
+ if (confirm('确定删除吗?')) {
|
|
|
+ var key = mini.get("key").getValue();
|
|
|
+ if (key == '请输入商品名称') {
|
|
|
+ key = '';
|
|
|
+ }
|
|
|
+ if (key) {
|
|
|
+ key = key.toLowerCase();
|
|
|
+ }
|
|
|
+ for (var i in tree.data) {
|
|
|
+ if (typeof(tree.data[i].children) == 'object') {
|
|
|
+ if (tree.data[i].children.length > 0) {
|
|
|
+ for (var j in tree.data[i].children) {
|
|
|
+ if (key) {
|
|
|
+ var name = tree.data[i].children[j].name;
|
|
|
+ if (name.indexOf(key) != -1) {
|
|
|
+ unsetGoods(tree.data[i].children[j]);
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ unsetGoods(tree.data[i].children[j]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if (key) {
|
|
|
+ var name = tree.data[i].name;
|
|
|
+ if (name.indexOf(key) != -1) {
|
|
|
+ unsetGoods(tree.data[i]);
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ unsetGoods(tree.data[i]);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ setTotal();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function unsetGoods(node)
|
|
|
+ {
|
|
|
+ if (node.id) {
|
|
|
+ if (goods[node.id]) {
|
|
|
+ goods[node.id].del = 2;
|
|
|
+ goods[node.id].num = 0;
|
|
|
+ goods[node.id].total = 0;
|
|
|
+ get(node.id).remove();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function setGoods(node)
|
|
|
+ {
|
|
|
+ if (node.id) {
|
|
|
+ var key = node.id;
|
|
|
+ if (!goods[key] || (goods[key] && goods[key].del == 2)) {
|
|
|
+ goods[key] = node;
|
|
|
+ goods[key].price = parseFloat(goods[key].price);
|
|
|
+ goods[key].type = parseInt(goods[key].type);
|
|
|
+ goods[key].total = parseFloat(goods[key].total);
|
|
|
+ goods[key].min = goods[key].min ? parseFloat(goods[key].min) : 1;
|
|
|
+ goods[key].num = 0;
|
|
|
+ goods[key].del = 1;
|
|
|
+ create(node);
|
|
|
+ setTotal();
|
|
|
+ } else if(node.type < 4) {
|
|
|
+ add(key);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function get(key)
|
|
|
+ {
|
|
|
+ return $('#goods_' + key);
|
|
|
+ }
|
|
|
+
|
|
|
+ function create(node)
|
|
|
+ {
|
|
|
+ if (!get(node.id).length) {
|
|
|
+ var select = '';
|
|
|
+ var addtr = '<tr class="mytr" id="goods_'+node.id+'">';
|
|
|
+ addtr += '<td class="goods_id">'+node.id+'</td>';
|
|
|
+ addtr += '<td class="goods_name">'+node.name+'</td>';
|
|
|
+ if (node.stock == 1) {
|
|
|
+ addtr += '<td class="goods_total">'+node.total+'</td>';
|
|
|
+ } else {
|
|
|
+ addtr += '<td class="goods_total"> - </td>';
|
|
|
+ }
|
|
|
+
|
|
|
+ addtr += '<td class="goods_prices">'+node.price+'</td>';
|
|
|
+ var commission_price = 0;
|
|
|
+ var commission_string = '';
|
|
|
+ if (commission == 0) {
|
|
|
+ commission_string = '0';
|
|
|
+ } else {
|
|
|
+ if (!node.commission) {
|
|
|
+ node.commission = '0';
|
|
|
+ }
|
|
|
+ commission_string = node.commission;
|
|
|
+ if (node.commission.indexOf('%') > -1) {
|
|
|
+ node.commission = node.commission.replace('%', '');
|
|
|
+ node.commission = parseFloat(node.commission);
|
|
|
+ commission_price = (node.commission/100) * parseFloat(node.price);
|
|
|
+ } else {
|
|
|
+ commission_price = parseFloat(node.commission);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (commission) {
|
|
|
+ commission_string += '+' + commission;
|
|
|
+ if (commission.indexOf('%') > -1) {
|
|
|
+ var commission_temp = commission.replace('%', '');
|
|
|
+ commission_temp = parseFloat(commission_temp);
|
|
|
+ commission_price += (commission_temp/100) * parseFloat(node.price);
|
|
|
+ } else {
|
|
|
+ commission_price += parseFloat(commission);
|
|
|
+ }
|
|
|
+ commission_price = commission_price.toFixed(2);
|
|
|
+ commission_string += '=' + commission_price;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ addtr += '<td class="goods_commission"><span>'+commission_string+'</span></td>';
|
|
|
+
|
|
|
+ addtr += '<td class="goods_prices">'+node.buy_price+'</td>';
|
|
|
+
|
|
|
+ addtr += '<td><div class="jiajian" value='+node.id+'><span class="jian" onclick="decMin(\''+node.id+'\')">-</span><input type="text" value="'+node.min+'" class="goods_min"><span class="jia" onclick="addMin(\''+node.id+'\')">+</span></div></td>';
|
|
|
+
|
|
|
+ if (node.total <= 0 || node.stock != 1) {
|
|
|
+ addtr += '<td><a class="delete_btn" onclick="del(\''+node.id+'\')">删除</a></td>';
|
|
|
+ } else {
|
|
|
+ addtr += '<td></td>';
|
|
|
+ }
|
|
|
+
|
|
|
+ addtr += '</tr>';
|
|
|
+ $("#goods").append(addtr);
|
|
|
+ form.render();
|
|
|
+ //$('.goods_price_template').change();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ function setPrice(e, id)
|
|
|
+ {
|
|
|
+ var val = e.val().split('_');
|
|
|
+ goods[id].price_template_id = val[0];
|
|
|
+ e.parent().find('span').html(val[1]);
|
|
|
+ //goods[id].min = val[2];
|
|
|
+ //e.parent().parent().find('.goods_min').val(val[2]);
|
|
|
+ }
|
|
|
+
|
|
|
+ function add(id)
|
|
|
+ {
|
|
|
+ goods[id].num += 1;
|
|
|
+ get(id).find('.goods_num').val(goods[id].num);
|
|
|
+ setTotal();
|
|
|
+ }
|
|
|
+
|
|
|
+ function dec(id)
|
|
|
+ {
|
|
|
+ goods[id].num -= 1;
|
|
|
+ if (goods[id].num < 1) {
|
|
|
+ goods[id].num = 0;
|
|
|
+ }
|
|
|
+
|
|
|
+ get(id).find('.goods_num').val(goods[id].num);
|
|
|
+ setTotal();
|
|
|
+ }
|
|
|
+
|
|
|
+ function addMin(id)
|
|
|
+ {
|
|
|
+ goods[id].min += 1;
|
|
|
+ get(id).find('.goods_min').val(goods[id].min);
|
|
|
+ setTotal();
|
|
|
+ }
|
|
|
+
|
|
|
+ function decMin(id)
|
|
|
+ {
|
|
|
+ goods[id].min -= 1;
|
|
|
+ if (goods[id].min < 1) {
|
|
|
+ goods[id].min = 0;
|
|
|
+ }
|
|
|
+
|
|
|
+ get(id).find('.goods_min').val(goods[id].min);
|
|
|
+ setTotal();
|
|
|
+ }
|
|
|
+
|
|
|
+ function del(id)
|
|
|
+ {
|
|
|
+ //if (confirm('确定删除吗?')) {
|
|
|
+ goods[id].del = 2;
|
|
|
+ goods[id].num = 0;
|
|
|
+ get(id).remove();
|
|
|
+ setTotal();
|
|
|
+ //}
|
|
|
+ }
|
|
|
+
|
|
|
+ function setTotal()
|
|
|
+ {
|
|
|
+ var cash = 0;
|
|
|
+ var total = 0;
|
|
|
+ for (var i in goods) {
|
|
|
+ total += goods[i].total;
|
|
|
+ }
|
|
|
+ $(".totalNum").html(total);
|
|
|
+ }
|
|
|
+
|
|
|
+ function setShop()
|
|
|
+ {
|
|
|
+ var shop_id = $('.xm-select-parent[fs_id="shop_id"] span[fsw="xm-select"]').attr('value');
|
|
|
+ if (!shop_id) {
|
|
|
+ layui.layer.alert('请选择门店');
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ layui.layer.confirm('确定切换门店吗?切换后现在选择的商品都将清空', function() {
|
|
|
+ location.href = '<{$host}>&id=' + shop_id;
|
|
|
+ });
|
|
|
+ }
|
|
|
+</script>
|
|
|
+</body>
|
|
|
+</html>
|