| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298 |
- layui.define(['tool'], function (exports) {
- const tool = layui.tool,layer = layui.layer,form = layui.form,laydate = layui.laydate;
- const obj = {
- loading:false,
- load: function (tid) {
- let callback = function (res) {
- if (res.code == 0 && res.data.length > 0) {
- let itemSchedule = '';
- $.each(res.data, function (index, item) {
- itemSchedule += `
- <div class="pt-2">
- <p class="gray">${item.start_time}~${item.end_time},${item.labor_time}工时</p>
- <p><span class="blue">${item.name}:</span>${item.title}</p>
- </div>
- `;
- });
- $("#schedule_" + tid).html(itemSchedule);
- layer.closeAll();
- }
- }
- tool.get("/project/api/task_schedule", { tid: tid }, callback);
- },
- //保存
- save: function (postData) {
- let callback = function (e) {
- if (e.code == 0) {
- layer.closeAll();
- layer.msg(e.msg);
- if(layui.scheduleTable){
- layui.scheduleTable.reload();
- }
- else{
- setTimeout(function(){
- location.reload();
- },1000);
- }
- } else {
- layer.msg(e.msg);
- }
- }
- tool.post("/oa/schedule/add", postData, callback);
- },
- //查看
- view: function (detail) {
- let project = '';
- if(detail.tid>0){
- project = `<table class="layui-table" style="margin:12px 12px 0;">
- <tr>
- <td class="layui-td-gray">关联项目</td>
- <td>${detail.project}</td>
- </tr>
- <tr>
- <td class="layui-td-gray">关联任务</td>
- <td>${detail.task}</td>
- </tr>
- </table>`;
- }
- let content = `<div style="width:696px">
- <table class="layui-table" style="margin:12px 12px 0;">
- <tr>
- <td class="layui-td-gray">执行员工</td>
- <td>${detail.name}</td>
- <td class="layui-td-gray">所在部门</td>
- <td>${detail.department}</td>
- <td class="layui-td-gray">工作类别</td>
- <td>${detail.work_cate}</td>
- </tr>
- <tr>
- <td class="layui-td-gray">时间范围</td>
- <td colspan="3">${detail.start_time} 至 ${detail.end_time},共${detail.labor_time}工时</td>
- <td class="layui-td-gray">工作类型</td>
- <td>${detail.labor_type_string}</td>
- </tr>
- <tr>
- <td class="layui-td-gray">工作内容</td>
- <td colspan="5">${detail.title}</td>
- </tr>
- <tr>
- <td class="layui-td-gray">补充描述</td>
- <td colspan="5">${detail.remark}</td>
- </tr>
- </table>
- ${project}
- </div>`;
- $(parent.$('.express-close')).addClass('parent-colse');
- layer.open({
- type: 1,
- title: '工作记录详情',
- area: ['720px', '420px'],
- content: content,
- end: function(){
- $(parent.$('.express-close')).removeClass('parent-colse');
- },
- success: function () {
- },
- btn: ['关闭'],
- btnAlign: 'c',
- yes: function (idx) {
- layer.close(idx);
- }
- })
- },
- add: function (tid, schedule) {
- let that = this, detail = {}, title = '添加工作记录';
- if(that.loading == true){
- return false;
- }
- that.loading = true;
- let html_time = '';
- if (schedule['id'] > 0) {
- if(schedule['admin_id'] != login_admin){
- layer.msg('不能编辑他人的工作记录');
- that.loading = false;
- return false;
- }
- title = '编辑工作记录';
- detail['id'] = schedule['id'];
- detail['cid'] = schedule['cid'];
- detail['tid'] = schedule['tid'];
- detail['title'] = schedule['title'];
- detail['labor_type'] = schedule['labor_type'];
- detail['start_time_a'] = schedule['start_time_a'];
- detail['start_time_b'] = schedule['start_time_b'];
- detail['end_time_a'] = schedule['end_time_a'];
- detail['end_time_b'] = schedule['end_time_b'];
- detail['remark'] = schedule['remark'];
-
- html_time = detail.start_time_a+' '+detail.start_time_b+' 至 '+detail.end_time_b+',共'+schedule.labor_time+'工时';
- } else {
- detail['id'] = schedule['id'];
- detail['tid'] = tid;
- detail['cid'] = 1;
- detail['title'] = '';
- detail['labor_type'] = 0;
- detail['start_time_a'] = schedule['start_time_a']?schedule['start_time_a']:'';
- detail['start_time_b'] = '09:00';
- detail['end_time_a'] = schedule['end_time_a']?schedule['end_time_a']:'';
- detail['end_time_b'] = '09:30';
- detail['remark'] = '';
-
- html_time = `<input id="start_time_a" name="start_time_a" style="width:90px; display:inline-block;" autocomplete="off" class="layui-input" value="${detail.start_time_a}" readonly lay-verify="required" lay-reqText="请选择"><div style="display: inline-block; margin-left:3px; width: 80px;"><select lay-filter="start_time_b" id="start_time_b"></select></div> 至 <input id="end_time_a" name="end_time_a" style="width:90px; display:inline-block;" autocomplete="off" class="layui-input" value="${detail.end_time_a}" readonly lay-verify="required" lay-reqText="请选择"><div style="display: inline-block; margin-left:3px; width: 80px;"><select lay-filter="end_time_b" id="end_time_b"></select></div>`;
- }
- let callback = function(e){
- that.loading = false;
- if(e.code==0){
- let cate = e.data;
- let content = `<form class="layui-form" style="width:696px">
- <table class="layui-table" style="margin:12px 12px 0;">
- <tr>
- <td class="layui-td-gray">时间范围 <span style="color: red">*</span></td>
- <td>${html_time}</td>
- <td class="layui-td-gray">工作类别<font>*</font></td>
- <td style="width: 120px;"><select name="cid" lay-filter="work_cate" id="work_cate"></select></td>
- </tr>
- <tr>
- <td class="layui-td-gray">工作类型<font>*</font></td>
- <td colspan="3"><input type="radio" name="labor_type" lay-filter="labor_type" value="1" title="案头工作"><input type="radio" name="labor_type" value="2" lay-filter="labor_type" title="外勤工作"></td>
- </tr>
- <tr>
- <td class="layui-td-gray">工作内容 <span style="color: red">*</span></td>
- <td colspan="3"><input name="title" class="layui-input" value="${detail.title}" lay-verify="required" lay-reqText="请完成工作内容"></td>
- </tr>
- <tr>
- <td class="layui-td-gray">补充描述</td>
- <td colspan="3">
- <textarea name="remark" form-input="remark" class="layui-textarea" style="min-height:120px;">${detail.remark}</textarea>
- <input name="tid" type="hidden" value="${detail.tid}">
- </td>
- </tr>
- </table>
- </form>`;
- $(parent.$('.express-close')).addClass('parent-colse');
- layer.open({
- type: 1,
- title: title,
- area: ['720px', '420px'],
- content: content,
- end: function(){
- $(parent.$('.express-close')).removeClass('parent-colse');
- },
- success: function () {
- if (detail['id'] == 0) {
- //日期时间范围
- laydate.render({
- elem: '#start_time_a',
- type: 'date',
- min: -7,
- max: 0,
- format: 'yyyy-MM-dd',
- showBottom: false,
- done: function (a, b, c) {
- $('#end_time_a').val(a);
- detail.start_time_a = a;
- detail.end_time_a = a;
- }
- });
- //日期时间范围
- laydate.render({
- elem: '#end_time_a',
- type: 'date',
- min: -7,
- max: 0,
- format: 'yyyy-MM-dd',
- showBottom: false,
- done: function (a, b, c) {
- $('#start_time_a').val(a);
- detail.start_time_a = a;
- detail.end_time_a = a;
- }
- });
- $('#start_time_b,#end_time_b').empty();
- var hourArray = [];
- for (var h = 0; h < 24; h++) {
- var t = h < 10 ? '0' + h : h
- var t_1 = t + ':00', t_2 = t + ':15', t_3 = t + ':30', t_4 = t + ':45';
- hourArray.push(t_1, t_2, t_3, t_4);
- }
- var html_1 = '', html_2 = '', def_h1 = detail['start_time_b'], def_h2 = detail['end_time_b'];
- for (var s = 0; s < hourArray.length; s++) {
- var check_1 = '', check_2 = '';
- if (hourArray[s] == def_h1) {
- check_1 = 'selected';
- }
- if (hourArray[s] == def_h2) {
- check_2 = 'selected';
- }
- html_1 += '<option value="' + hourArray[s] + '" ' + check_1 + '>' + hourArray[s] + '</option>';
- html_2 += '<option value="' + hourArray[s] + '" ' + check_2 + '>' + hourArray[s] + '</option>';
- }
- $('#start_time_b').append(html_1);
- $('#end_time_b').append(html_2);
- }
- $("input[name=labor_type][value="+detail.labor_type+"]").prop("checked","true");
-
- var html_c='';
- for (var c = 0; c < cate.length; c++) {
- var check_c = '';
- if (cate[c].id == detail['cid']) {
- check_c = 'selected';
- }
- html_c += '<option value="' + cate[c].id + '" ' + check_c + '>' + cate[c].title + '</option>';
- }
- $('#work_cate').append(html_c);
-
- form.render();
- form.on('select(start_time_b)', function (data) {
- detail.start_time_b = data.value;
- });
- form.on('select(end_time_b)', function (data) {
- detail.end_time_b = data.value;
- });
- $('[name="title"]').on('input', function () {
- var _val = $(this).val();
- detail.title = _val;
- });
- form.on('radio(labor_type)', function(data){
- detail.labor_type=data.value;
- })
- form.on('select(work_cate)', function(data){
- detail.cid=data.value;
- })
- $('[form-input="remark"]').on('input', function () {
- var _val = $(this).val();
- detail.remark = _val;
- });
- },
- btn: ['确定提交'],
- btnAlign: 'c',
- yes: function (idx) {
- if (detail.start_time_a == '' || detail.end_time_a == '') {
- layer.msg('请选择工作时间范围');
- return;
- }
- if(detail.labor_type==0){
- layer.msg('请选择工作类型');
- return;
- }
- if (detail.title == '') {
- layer.msg('请填写工作内容');
- return;
- }
- that.save(detail);
- }
- })
- }
- }
- tool.get("/api/index/get_work_cate", {}, callback);
- }
- };
- exports('oaSchedule', obj);
- });
|