<!DOCTYPE html>
|
<html>
|
<head>
|
<meta charset="utf-8" />
|
<title>工厂日历</title>
|
<link rel="stylesheet" href="../../../layuiadmin/layui/css/layui.css" media="all">
|
<link rel="stylesheet" href="../../../layuiadmin/style/admin.css" media="all">
|
<script src="../../../layuiadmin/layui/layui.js"></script>
|
<script src="../../../layuiadmin/Scripts/json2.js"></script>
|
<script src="../../../layuiadmin/Scripts/jquery-1.4.1.js"></script>
|
<script src="../../../layuiadmin/Scripts/webConfig.js"></script>
|
<script src="../../../layuiadmin/zgqCustom/zgqCustom.js"></script>
|
<script src="../../../layuiadmin/PubCustom.js"></script>
|
<script src="../../../layuiadmin/grwebapp.js"></script>
|
<script src="../../../layuiadmin/layui/layui1.js"></script>
|
<style>
|
/*树状图点击高亮变色*/
|
.layui-tree-set-active > .layui-tree-entry .layui-tree-main {
|
background: #aef0f7;
|
}
|
</style>
|
</head>
|
<body>
|
<div class="layui-fluid">
|
<div class="layui-col-md12">
|
<div class="layui-card" style="padding: 1px">
|
<div class="layui-card-body" style="padding: 1px;">
|
<form class="layui-form" action="" lay-filter="component-form-group">
|
<div class="layui-collapse">
|
<div class="layui-colla-item">
|
<div class="layui-colla-title layui-inline">
|
<div class="layui-inline">
|
<span>更多</span>
|
</div>
|
</div>
|
<div class="layui-inline">
|
<label class="layui-form-label" style="width: 85px;">生产资源代码</label>
|
<div class="layui-input-block" style="margin-left: 120px;">
|
<input type="text" class="layui-input" name="HNumber" id="HNumber">
|
</div>
|
</div>
|
<div class="layui-inline">
|
<label class="layui-form-label" style="width: 85px;">生产资源名称</label>
|
<div class="layui-input-block" style="margin-left: 120px;">
|
<input type="text" class="layui-input" name="HName" id="HName">
|
</div>
|
</div>
|
<div class="layui-inline">
|
<label class="layui-form-label">日期</label>
|
<div class="layui-input-block" style="width:100px">
|
<select name="HDate" lay-verify="required" id="HDate">
|
<!--动态获取日期-->
|
</select>
|
</div>
|
</div>
|
<button class="layui-btn layuiadmin-btn-order" type="button" lay-submit="" lay-filter="btnSearch" id="btnSearch">
|
<i class="layui-icon layui-icon-search layuiadmin-button-btn"></i>
|
</button>
|
<button class="layui-btn layuiadmin-btn-order" type="button" lay-submit="" lay-filter="btn_BulkEditWorkTime" id="btn_BulkEditWorkTime" style="padding:0 5px">批改上班工时</button>
|
<button class="layui-btn layuiadmin-btn-order" type="button" lay-submit="" lay-filter="btn_Import" id="btn_Import" style="padding:0 5px">导入</button>
|
<button class="layui-btn layuiadmin-btn-order" type="button" lay-submit="" lay-filter="btn_Exit" id="btn_Exit" style="padding:0 5px">退出</button>
|
<!--<button class="layui-btn layuiadmin-btn-order" type="button" lay-submit="" lay-filter="btnReSearch" id="btnReSearch" style="padding:0 5px">重置</button>-->
|
</div>
|
</div>
|
<div class="layui-row" style="padding:10px 0">
|
<div class="layui-col-xs2 layui-inline" style="border: solid 1.5px #e0d6d64d;">
|
<div id="TreeTable" class="demo-tree demo-tree-box" style="height: 1200px; overflow: scroll;"></div>
|
</div>
|
<div class="layui-col-xs8 layui-inline" style="padding-left: 10px; width: 83%">
|
<div>
|
<table class="layui-hide" id="mainTable1" lay-filter="mainTable1"></table>
|
<table class="layui-hide" id="mainTable2" lay-filter="mainTable2"></table>
|
<table class="layui-hide" id="mainTable3" lay-filter="mainTable3"></table>
|
<table class="layui-hide" id="mainTable4" lay-filter="mainTable4"></table>
|
<table class="layui-hide" id="mainTable5" lay-filter="mainTable5"></table>
|
<table class="layui-hide" id="mainTable6" lay-filter="mainTable6"></table>
|
<table class="layui-hide" id="mainTable7" lay-filter="mainTable7"></table>
|
<table class="layui-hide" id="mainTable8" lay-filter="mainTable8"></table>
|
<table class="layui-hide" id="mainTable9" lay-filter="mainTable9"></table>
|
<table class="layui-hide" id="mainTable10" lay-filter="mainTable10"></table>
|
<table class="layui-hide" id="mainTable11" lay-filter="mainTable11"></table>
|
<table class="layui-hide" id="mainTable12" lay-filter="mainTable12"></table>
|
</div>
|
</div>
|
</div>
|
|
</form>
|
</div>
|
</div>
|
</div>
|
</div>
|
</body>
|
</html>
|
<script>
|
layui.config({
|
base: '../../../layuiadmin/' //静态资源所在路径
|
}).extend({
|
index: 'lib/index', //主入口模块
|
}).use(['index', 'form', 'table', 'element', 'laypage', 'laydate','tree'], function () {
|
//#region 公共变量
|
var $ = layui.$
|
, admin = layui.admin
|
, layer = layui.layer
|
, table = layui.table
|
, form = layui.form
|
, element = layui.element
|
, laypage = layui.laypage
|
, laydate = layui.laydate
|
, util = layui.util
|
, tree = layui.tree
|
|
var params = getUrlVars();
|
var OperationType = params[params[0]]; //从参数中获取 数据类型 1添加 保存 2复制 3 编辑 4添加子工艺路线
|
|
var TagId = "";
|
var option1 = [];
|
var option2 = [];
|
var option3 = [];
|
var option4 = [];
|
var option5 = [];
|
var option6 = [];
|
var option7 = [];
|
var option8 = [];
|
var option9 = [];
|
var option10 = [];
|
var option11 = [];
|
var option12 = [];
|
//#endregion
|
|
//#region 进入页面即加载
|
|
set_ClearBill();
|
|
//#endregion
|
|
|
//#region 点击事件包括on form事件等
|
|
//行内鼠标离开事件
|
table.on('edit(mainTable1)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable2)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable3)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable4)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable5)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable6)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable7)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable8)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable9)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable10)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable11)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
table.on('edit(mainTable12)', function (obj) {
|
var hdate = obj.field;
|
var hvalue = obj.value;
|
|
Save(hdate, hvalue, TagId)
|
})
|
|
|
//快速过滤
|
form.on('submit(btnSearch)', function (data) {
|
var Year = new Date($("#HDate").val()).getFullYear();
|
var HNumber = $("#HNumber").val();
|
var HName = $("#HName").val();
|
var sWhere = "";
|
if (HNumber != "") {
|
sWhere += " and HNumber like'%" + HNumber + "%' ";
|
}
|
|
if (HName != "") {
|
sWhere += " and HName like'%" + HName + "%' ";
|
}
|
|
//初始化表格
|
set_InitGrid(Year, 1, "");
|
set_InitGrid(Year, 2, "");
|
set_InitGrid(Year, 3, "");
|
set_InitGrid(Year, 4, "");
|
set_InitGrid(Year, 5, "");
|
set_InitGrid(Year, 6, "");
|
set_InitGrid(Year, 7, "");
|
set_InitGrid(Year, 8, "");
|
set_InitGrid(Year, 9, "");
|
set_InitGrid(Year, 10, "");
|
set_InitGrid(Year, 11, "");
|
set_InitGrid(Year, 12, "");
|
get_Display_Tree(sWhere);
|
get_Display("");
|
});
|
|
//退出
|
form.on('submit(btn_Exit)', function (data) {
|
if (OperationType == 3) {
|
Pub_Close(1);
|
} else {
|
Pub_Close(2);
|
}
|
});
|
|
//批量修改上班工时
|
form.on('submit(btn_BulkEditWorkTime)', function (data) {
|
layer.open({
|
type: 2
|
, skin: "layui-layer-rim" //加上边框
|
, title: "批改上班工时" //标题
|
, closeBtn: 1 //窗体右上角关闭 的 样式
|
, shift: 2 //弹出动画
|
, area: ["50%", "80%"] //窗体大小
|
, maxmin: true //设置最大最小按钮是否显示
|
, content: ['./Sc_BulkEditWorkTime.html', "yes"]
|
})
|
});
|
|
//导入
|
form.on('submit(btn_Import)', function (data) {
|
layer.open({
|
type: 2
|
, skin: "layui-layer-rim" //加上边框
|
, title: "工厂日历导入" //标题
|
, closeBtn: 1 //窗体右上角关闭 的 样式
|
, shift: 2 //弹出动画
|
, area: ["100%", "100%"] //窗体大小
|
, maxmin: true //设置最大最小按钮是否显示
|
, content: ['./Sc_ShopCalendar_Excel.html', "yes"]
|
})
|
});
|
//#endregion
|
|
//#region 本页面所有被调用的方法
|
function set_ClearBill() {
|
getDate();
|
//获取年
|
var Year = new Date($("#HDate").val()).getFullYear();
|
//初始化表格
|
set_InitGrid(Year, 1,"");
|
set_InitGrid(Year, 2, "");
|
set_InitGrid(Year, 3, "");
|
set_InitGrid(Year, 4, "");
|
set_InitGrid(Year, 5, "");
|
set_InitGrid(Year, 6, "");
|
set_InitGrid(Year, 7, "");
|
set_InitGrid(Year, 8, "");
|
set_InitGrid(Year, 9, "");
|
set_InitGrid(Year, 10, "");
|
set_InitGrid(Year, 11, "");
|
set_InitGrid(Year, 12, "");
|
get_Display_Tree("");
|
get_Display("");
|
}
|
|
function getDate() {
|
var NowDate = new Date().getFullYear();
|
var sqlDate = '<option style="color:blue;" value="' + NowDate + '">' + NowDate +'</option>';
|
for (var i = 1; i <= 10; i++) {
|
sqlDate += '<option style="color:blue;" value="' + (NowDate - i) + '">' + (NowDate - i) + '</option>';
|
}
|
$("#HDate").empty();
|
$("#HDate").append(sqlDate);
|
form.render('select');
|
}
|
|
//月份
|
function set_InitGrid(Year,Month,num) {
|
var SumMonth = new Date(Year, Month, 0).getDate(); //动态获取月天数
|
var col = [];
|
var colData = "{";
|
col.push({ field: "月份", title: "月份", width: 60 })
|
colData += "\"月份\":\"" + Month+"月\",";
|
for (var j = 1; j <= SumMonth; j++) {
|
col.push({ field: Format(Year + '/' + Month + '/' + j, 'yyyy-MM-dd'), title: Format(Year + '/' + Month + '/' + j, 'dd'), width: 50, edit: 'text' })
|
colData += "\"" + Format(Year + '/' + Month + '/' + j, 'yyyy-MM-dd') + "\":\"" + num + "\",";
|
}
|
colData = colData.substr(0, colData.length - 1);
|
colData += "}";
|
var option = {
|
elem: '#mainTable' + Month
|
, cellMinWidth: 120
|
, limit: Number.MAX_VALUE // 数据表格默认全部显示
|
, height: 100
|
, cols: [col]
|
, data: [JSON.parse(colData)]
|
, done: function (res, curr, count) {
|
var NowDate = Format(new Date(), "yyyy-MM-dd");
|
var Month = new Date().getMonth() + 1 + "月";
|
|
for (var i in res.data) {
|
var item = res.data[i];
|
if (item["月份"] == Month) {
|
for (var j = 0; j < option.cols[0].length; j++) {
|
if (option.cols[0][j].field == NowDate) {
|
option.cols[0][j]["style"] = " background-color: #59c5ea";
|
}
|
}
|
}
|
}
|
}
|
};
|
table.render(option);
|
|
switch (Month) {
|
case 1 :
|
option1 = option;
|
break;
|
case 2:
|
option2 = option;
|
break;
|
case 3:
|
option3 = option;
|
break;
|
case 4:
|
option4= option;
|
break;
|
case 5:
|
option5= option;
|
break;
|
case 6:
|
option6= option;
|
break;
|
case 7:
|
option7= option;
|
break;
|
case 8:
|
option8= option;
|
break;
|
case 9:
|
option9= option;
|
break;
|
case 10:
|
option10= option;
|
break;
|
case 11:
|
option11= option;
|
break;
|
case 12:
|
option12= option;
|
break;
|
}
|
}
|
|
//查询数据
|
function get_Display(sWhere) {
|
var ajaxLoad = layer.load();
|
$.ajax({
|
url: GetWEBURL() + '/MaterOutEntryReport/Sc_ShopCalendar',
|
type: "GET",
|
async: false,
|
data: { "sWhere": sWhere, "user": sessionStorage["HUserName"]},
|
success: function (data1) {
|
if (data1.count == 1) {
|
var Year = new Date($("#HDate").val()).getFullYear();
|
var num = data1.data[0]["工时"];
|
if (data1.data.length != 0) {
|
set_InitGrid(Year, 1, num);
|
set_InitGrid(Year, 2, num);
|
set_InitGrid(Year, 3, num);
|
set_InitGrid(Year, 4, num);
|
set_InitGrid(Year, 5, num);
|
set_InitGrid(Year, 6, num);
|
set_InitGrid(Year, 7, num);
|
set_InitGrid(Year, 8, num);
|
set_InitGrid(Year, 9, num);
|
set_InitGrid(Year, 10, num);
|
set_InitGrid(Year, 11, num);
|
set_InitGrid(Year, 12, num);
|
for (var i = 0; i < data1.data.length; i++) {
|
var Month = new Date(data1.data[i]["日期"]).getMonth() + 1;
|
switch (Month) {
|
case 1:
|
option1.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 2:
|
option2.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 3:
|
option3.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 4:
|
option4.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 5:
|
option5.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 6:
|
option6.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 7:
|
option7.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 8:
|
option8.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 9:
|
option9.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 10:
|
option10.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 11:
|
option11.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
case 12:
|
option12.data[0][data1.data[i]["日期"]] = data1.data[i]["加班工时"];
|
break;
|
}
|
}
|
} else {
|
//num = 8;
|
set_InitGrid(Year, 1, num);
|
set_InitGrid(Year, 2, num);
|
set_InitGrid(Year, 3, num);
|
set_InitGrid(Year, 4, num);
|
set_InitGrid(Year, 5, num);
|
set_InitGrid(Year, 6, num);
|
set_InitGrid(Year, 7, num);
|
set_InitGrid(Year, 8, num);
|
set_InitGrid(Year, 9, num);
|
set_InitGrid(Year, 10, num);
|
set_InitGrid(Year, 11, num);
|
set_InitGrid(Year, 12, num);
|
}
|
table.render(option1);
|
table.render(option2);
|
table.render(option3);
|
table.render(option4);
|
table.render(option5);
|
table.render(option6);
|
table.render(option7);
|
table.render(option8);
|
table.render(option9);
|
table.render(option10);
|
table.render(option11);
|
table.render(option12);
|
layer.close(ajaxLoad);
|
} else {
|
layer.close(ajaxLoad);
|
layer.alert(data1.code + data1.Message, { icon: 5 });
|
}
|
}, error: function () {
|
layer.close(ajaxLoad);
|
layer.alert("接口请求失败!", { icon: 5 });
|
}
|
});
|
}
|
|
// 树状图查询
|
function get_Display_Tree(sWhere) {
|
var ajaxLoad = layer.load();
|
$.ajax({
|
url: GetWEBURL() + '/MaterOutEntryReport/Gy_SourceList',
|
type: "GET",
|
async: false,
|
data: { "HOrgid": sessionStorage["OrganizationID"], "sWhere": sWhere },
|
success: function (data1) {
|
if (data1.count == 1) {
|
layer.close(ajaxLoad);
|
var data = JSON.parse(data1.data);
|
MenuMain(data);
|
} else {
|
layer.close(ajaxLoad);
|
layer.alert(data1.code + data1.Message, { icon: 5 });
|
}
|
}, error: function () {
|
layer.close(ajaxLoad);
|
layer.alert("接口请求失败!", { icon: 5 });
|
}
|
});
|
}
|
|
//遍历生成主菜单
|
function MenuMain(data) {
|
var liStr = '[';
|
//遍历生成主菜单
|
for (var i = 0; i < data.length; i++) {
|
// 判断是否存在子菜单
|
if (data[i].children != null && data[i].children.length > 0) {
|
liStr += '{"title": "' + data[i].id + "-" + data[i].title + '", "id": "' + data[i].id + '","spread":true, "children":[ ';
|
// 遍历获取子菜单
|
for (var k = 0; k < data[i].children.length; k++) {
|
liStr += getChildMenu(data[i].children[k], 0);
|
}
|
liStr = liStr.substring(0, liStr.length - 1);
|
liStr += ']},';
|
} else {
|
liStr += '{"title": "' + data[i].id + "-" + data[i].title + '", "id": "' + data[i].id + '"},';
|
}
|
};
|
liStr = liStr.substring(0, liStr.length - 1);
|
liStr += "]";
|
var treeTable = JSON.parse(liStr);
|
tree.render({
|
elem: '#TreeTable' //默认是点击节点可进行收缩
|
, data: treeTable
|
, click: function (obj) {
|
|
//高亮变色
|
$(".layui-tree-set").removeClass('layui-tree-set-active');
|
obj.elem.addClass('layui-tree-set-active');
|
|
var data = obj.data; //获取当前点击的节点数据
|
TagId = data.id;
|
var sql = "";
|
var HDate = $("#HDate").val();
|
if (data.id == "0") {
|
sql = " and 日期 like'%" + HDate + "%'";
|
} else {
|
sql = " and HSourceID='" + data.id + "' and (日期 like'%" + HDate +"%' or 日期 is null or 日期 is not null)";
|
}
|
get_Display(sql);
|
}
|
});
|
}
|
|
// 递归生成子菜单
|
function getChildMenu(subMenu, num) {
|
num++;
|
var subStr = '';
|
if (subMenu.children != null && subMenu.children.length > 0) {
|
subStr += '{"title": "' + subMenu.id + "-" + subMenu.title + '", "id": "' + subMenu.id + '", "children":[';
|
for (var j = 0; j < subMenu.children.length; j++) {
|
subStr += getChildMenu(subMenu.children[j], num);
|
if (j + 1 == subMenu.children.length) {
|
subStr = subStr.substring(0, subStr.length - 1);
|
}
|
}
|
subStr += ']},';
|
} else {
|
subStr += '{"title": "' + subMenu.id + "-" + subMenu.title + '", "id": "' + subMenu.id + '"},';
|
}
|
return subStr;
|
}
|
|
//保存
|
function Save(hdate, hvalue, TagId) {
|
if (TagId == "") {
|
return layer.msg("请先选择生产资源!");
|
}
|
var reg = /^\d+(\.\d+)?$/;
|
if (reg.test(hvalue) == false || hvalue == "" || hvalue == "0") {
|
layer.msg("数量必须为数量或小数");
|
return false;
|
}
|
|
var sMainSub = hdate + ";" + hvalue + ";" + TagId + ";" + sessionStorage["HUserName"];
|
|
$.ajax({
|
url: GetWEBURL() + '/MaterOutEntryReport/Sc_ShopCalendarSave',
|
type: "POST",
|
async: false,
|
data: { "sMainSub": sMainSub },
|
success: function (data1) {
|
if (data1.count == 1) {
|
layer.msg(data1.Message);
|
} else {
|
layer.alert(data1.code + data1.Message, { icon: 5 });
|
}
|
}, error: function () {
|
layer.alert("接口请求失败!", { icon: 5 });
|
}
|
});
|
}
|
//#endregion
|
|
//获取参数
|
function getUrlVars() {
|
var vars = [], hash;
|
var hashes = window.location.href.slice(window.location.href.indexOf('?') + 1).split('&');
|
for (var i = 0; i < hashes.length; i++) {
|
hash = hashes[i].split('=');
|
vars.push(hash[0]);
|
vars[hash[0]] = hash[1];
|
}
|
return vars;
|
}
|
|
//以上是layui模块
|
});
|
|
|
|
|
</script>
|