|
@@ -0,0 +1,388 @@
|
|
|
+<!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:'old_cost_price', edit: 'text'}">成本价</th>
|
|
|
+ <th lay-data="{field:'cost_price', edit: 'text'}">新成本价</th>
|
|
|
+ <th lay-data="{field:'operation'}">操作</th>
|
|
|
+ </tr>
|
|
|
+ </thead>
|
|
|
+ <tbody id="goods">
|
|
|
+
|
|
|
+ </tbody>
|
|
|
+ </table>
|
|
|
+ </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", ".cost_price", function() {
|
|
|
+ var num = parseFloat($(this).val());
|
|
|
+ var id = $(this).parent().attr('value');
|
|
|
+ goods[id].cost_price = num;
|
|
|
+ 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].old_cost_price = parseFloat(goods[key].old_cost_price);
|
|
|
+ goods[key].cost_price = parseFloat(goods[key].cost_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>';
|
|
|
+
|
|
|
+ addtr += '<td class="goods_prices">'+node.old_cost_price+'</td>';
|
|
|
+
|
|
|
+ addtr += '<td class="cost_price" value='+node.id+'><input type="tel" class="layui-input cost_price" value="'+node.cost_price+'" /></td>';
|
|
|
+
|
|
|
+ addtr += '<td><a class="delete_btn" onclick="del(\''+node.id+'\')">删除</a></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 del(id)
|
|
|
+ {
|
|
|
+ //if (confirm('确定删除吗?')) {
|
|
|
+ goods[id].del = 2;
|
|
|
+ goods[id].num = 0;
|
|
|
+ get(id).remove();
|
|
|
+ setTotal();
|
|
|
+ //}
|
|
|
+ }
|
|
|
+
|
|
|
+ function setTotal()
|
|
|
+ {
|
|
|
+
|
|
|
+ }
|
|
|
+</script>
|
|
|
+</body>
|
|
|
+</html>
|