344 lines
12 KiB
HTML
344 lines
12 KiB
HTML
|
{extend name="../../base/view/common/base" /}
|
||
|
{block name="style"}
|
||
|
<style>
|
||
|
.hover-view i,.hover-edit i{margin-left:4px; font-weight:800; cursor:pointer; opacity:0}
|
||
|
.hover-edit.hover-on i{opacity:1}
|
||
|
.layui-tab-title .layui-this{background-color:#fff;}
|
||
|
.layui-tab-card,.layui-card{box-shadow:0 0 0 0 rgb(0 0 0 / 10%); border-radius:0; border-top:none;}
|
||
|
.layui-card-tips {color: #969696;}
|
||
|
.layui-card-value {padding: 4px 0 16px;font-size: 18px;color: #1E9FFF;}
|
||
|
|
||
|
.content-content{line-height:1.6;}
|
||
|
.content-content p{margin-bottom:6px;}
|
||
|
.content-content img{max-width:100%; padding:8px; box-sizing: border-box;}
|
||
|
|
||
|
.comment-input .comment-image{width:40px; height:40px; border-radius:50%}
|
||
|
.comment-item .comment-avatar{width:50px; float:left}
|
||
|
.comment-item .comment-image{width:36px; height:36px; border-radius:50%}
|
||
|
.comment-item .comment-body{margin-left:50px;}
|
||
|
.comment-item .comment-content blockquote{border-left:3px solid #f1f1f1; padding:4px 8px;}
|
||
|
.comment-item .comment-actions a{color:#8c95a8; cursor:pointer; font-size:12px;}
|
||
|
.comment-item .comment-actions a:hover{color:#3582fb;}
|
||
|
.comment-meta span{font-size:12px;}
|
||
|
|
||
|
.log-item i{font-weight:800; color:#323232}
|
||
|
.log-content strong{margin:0 4px; color:#323232}
|
||
|
.layui-unselect dl {max-height:188px;}
|
||
|
</style>
|
||
|
{/block}
|
||
|
{block name="body"}
|
||
|
<div>
|
||
|
<div class="p-3 border-b">
|
||
|
<h2 class="pb-3 hover-edit">
|
||
|
<span class="font20" id="title_{$detail.id}" data-val="">{$detail.title}</span>
|
||
|
<i class="iconfont icon-wodedianping" title="编辑" data-name="title"></i>
|
||
|
</h2>
|
||
|
<div>
|
||
|
<span class="layui-badge layui-bg-gray">#P{$detail.id}</span>
|
||
|
<span class="mx-2">{$detail.admin_name}</span>
|
||
|
<span class="gray">创建于{$detail.times}<span id="editTips">{gt name="$detail.update_time" value="0"},最近更新于 {:time_trans($detail.update_time)}{/gt}</span></span>
|
||
|
{eq name="$detail.admin_id" value="$login_admin.id"}
|
||
|
<span class="layui-btn layui-btn-xs layui-btn-danger ml-4" id="delBtn"><i class="layui-icon"></i>删除</span>
|
||
|
{/eq}
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-row border-b" style="background-color:#fff;">
|
||
|
<div class="layui-col-md9 px-3 py-1 border-r">
|
||
|
<table class="layui-table layui-table-form">
|
||
|
<tr>
|
||
|
<td class="layui-td-gray">任务负责人</td>
|
||
|
<td class="hover-edit"><span id="director_uid_{$detail.id}"
|
||
|
data-val="{$detail.director_uid}">{$detail.director_name}</span><i
|
||
|
class="iconfont icon-wodedianping" title="编辑" data-name="director_uid"></i></td>
|
||
|
<td class="layui-td-gray">协作人</td>
|
||
|
<td class="hover-edit" colspan="5"><span id="assist_admin_ids_{$detail.id}"
|
||
|
data-val="{$detail.assist_admin_ids}">{$detail.assist_admin_names}</span><i
|
||
|
class="iconfont icon-wodedianping" title="编辑" data-name="assist_admin_ids"></i></td>
|
||
|
</td>
|
||
|
</tr>
|
||
|
<tr>
|
||
|
<td class="layui-td-gray-2">计划完成日期</td>
|
||
|
<td class="hover-edit"><span id="end_time_{$detail.id}" data-val="">{$detail.end_time|
|
||
|
date='Y-m-d'}</span>{gt name="$detail.delay" value="0"}<span class="layui-badge ml-2">逾期
|
||
|
{$detail.delay} 天</span>{/gt}<i class="iconfont icon-wodedianping" title="编辑"
|
||
|
data-name="end_time"></i></td>
|
||
|
<td class="layui-td-gray">预估工时</td>
|
||
|
<td class="hover-edit"><span id="plan_hours_{$detail.id}" data-val="">{$detail.plan_hours}</span><i
|
||
|
class="iconfont icon-wodedianping" title="编辑" data-name="plan_hours"></i></td>
|
||
|
<td class="layui-td-gray">工作类型</td>
|
||
|
<td class="hover-edit"><span id="cate_{$detail.id}"
|
||
|
data-val="{$detail.cate}">{$detail.cate_name}</span><i class="iconfont icon-wodedianping"
|
||
|
title="编辑" data-name="cate"></i></td>
|
||
|
<td class="layui-td-gray">优先级</td>
|
||
|
<td class="hover-edit"><span class="layui-color-{$detail.priority}" id="priority_{$detail.id}"
|
||
|
data-val="{$detail.priority}">{$detail.priority_name}</span><i
|
||
|
class="iconfont icon-wodedianping" title="编辑" data-name="priority"></i>
|
||
|
</td>
|
||
|
</tr>
|
||
|
<tr>
|
||
|
<td class="layui-td-gray-2">实际完成日期</td>
|
||
|
<td class="hover-edit">{eq name="$detail.over_time" value="0"}-{else/}{$detail.over_time|
|
||
|
date='Y-m-d'}{/eq}</td>
|
||
|
<td class="layui-td-gray">实际工时</td>
|
||
|
<td class="hover-edit">{eq name="$detail.work_hours" value="0"}-{else/}{$detail.work_hours}{/eq}
|
||
|
</td>
|
||
|
<td class="layui-td-gray">任务状态</td>
|
||
|
<td class="hover-edit">
|
||
|
<span class="layui-color-{$detail.flow_status}" id="flow_status_{$detail.id}"
|
||
|
data-val="{$detail.flow_status}">{$detail.flow_name}</span><i
|
||
|
class="iconfont icon-wodedianping" title="编辑" data-name="flow_status"></i>
|
||
|
</td>
|
||
|
<td class="layui-td-gray">完成进度</td>
|
||
|
<td class="hover-edit"><span class="layui-color-{$detail.done_ratio}" id="done_ratio_{$detail.id}" data-val="{$detail.done_ratio}">{$detail.done_ratio}%</span><i class="iconfont icon-wodedianping" title="编辑" data-name="done_ratio"></i>
|
||
|
</td>
|
||
|
</tr>
|
||
|
</table>
|
||
|
<div class="content hover-edit">
|
||
|
<h3 class="py-4">任务描述<i class="iconfont icon-wodedianping" title="编辑" data-name="content"></i></h3>
|
||
|
<div class="content-content" id="content_{$detail.id}" data-val="{$detail.content}">{$detail.content|raw}</div>
|
||
|
</div>
|
||
|
<div class="detail-file">
|
||
|
<h3 class="py-4">文件附件 <button type="button" class="layui-btn layui-btn-normal layui-btn-xs" id="uploadBtn" style="font-weight:400;">+ 上传</button></h3>
|
||
|
<div class="layui-row pb-2" id="fileBox">
|
||
|
{empty name="$file_array"}
|
||
|
<div style="line-height:1.5">
|
||
|
<div class="layui-data-none">暂无附件文件</div>
|
||
|
</div>
|
||
|
{/empty}
|
||
|
{volist name="$file_array" id="vo"}
|
||
|
<div class="layui-col-md6" id="uploadImg{$vo.id}">{:file_card($vo)}</div>
|
||
|
{/volist}
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-col-md3 p-4">
|
||
|
<div class="pb-4 hover-{$role_edit}">
|
||
|
<p class="gray mb-2">关联项目</p>
|
||
|
<span id="project_id_{$detail.id}" data-val="{$detail.project_id}">
|
||
|
{gt name="$detail.project_id" value="0"}{$detail.project_name}{else/}<span
|
||
|
class="gray">未设置</span>{/gt}
|
||
|
</span>
|
||
|
<i class="iconfont icon-wodedianping" title="编辑" data-name="project_id"></i>
|
||
|
</div>
|
||
|
|
||
|
<div class="pb-4 mt-3">
|
||
|
<h5 class="mb-1">工作记录<span class="layui-btn layui-btn-xs add-schedule right">+ 工作记录</span></h5>
|
||
|
<div id="schedule_{$detail.id}" style="line-height:1.5">
|
||
|
<div class="layui-data-none">暂无工作记录</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
<div class="layui-tab layui-tab-card" style="margin:0;" lay-filter="docDemoTabBrief">
|
||
|
<ul class="layui-tab-title">
|
||
|
<li class="layui-this">员工评论({$detail.comments})</li>
|
||
|
<li>操作日志({$detail.logs})</li>
|
||
|
</ul>
|
||
|
<div class="layui-tab-content py-1 px-3" style="background-color:#fff;">
|
||
|
<div class="layui-tab-item comment-list layui-show">
|
||
|
<div class="comment-input my-2">
|
||
|
<input type="text" id="commentInput" readonly placeholder="发表一下你的看法" class="layui-input" value="">
|
||
|
</div>
|
||
|
<div id="comment_task_{$detail.id}"></div>
|
||
|
</div>
|
||
|
<div class="layui-tab-item logs-list">
|
||
|
<div id="log_task_{$detail.id}"></div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
{/block}
|
||
|
<!-- /主体 -->
|
||
|
|
||
|
<!-- 脚本 -->
|
||
|
{block name="script"}
|
||
|
<script>
|
||
|
const admin_id = '{$detail.admin_id}';
|
||
|
const detail_id = '{$detail.id}';
|
||
|
const moduleInit = ['tool','employeepicker','oaEdit','oaSchedule','oaComment','oaTool'];
|
||
|
function gouguInit() {
|
||
|
const opsData = {
|
||
|
flow_status: [
|
||
|
{ 'id': 1, 'title': '未开始' },
|
||
|
{ 'id': 2, 'title': '进行中' },
|
||
|
{ 'id': 3, 'title': '已完成' },
|
||
|
{ 'id': 4, 'title': '不解决' },
|
||
|
{ 'id': 5, 'title': '已关闭' }
|
||
|
],
|
||
|
type: [
|
||
|
{ 'id': 1, 'title': '需求' },
|
||
|
{ 'id': 2, 'title': '设计' },
|
||
|
{ 'id': 3, 'title': '研发' },
|
||
|
{ 'id': 4, 'title': '缺陷' }
|
||
|
],
|
||
|
priority: [
|
||
|
{ 'id': 1, 'title': '低' },
|
||
|
{ 'id': 2, 'title': '中' },
|
||
|
{ 'id': 3, 'title': '高' },
|
||
|
{ 'id': 4, 'title': '紧急' }
|
||
|
],
|
||
|
done_ratio: [
|
||
|
{ 'id': 0, 'title': '0%' },
|
||
|
{ 'id': 20, 'title': '20%' },
|
||
|
{ 'id': 40, 'title': '40%' },
|
||
|
{ 'id': 50, 'title': '50%' },
|
||
|
{ 'id': 60, 'title': '60%' },
|
||
|
{ 'id': 80, 'title': '80%' },
|
||
|
{ 'id': 100, 'title': '100%' }
|
||
|
]
|
||
|
}
|
||
|
const edit = layui.oaEdit,work = layui.oaSchedule,comment = layui.oaComment, oaTool = layui.oaTool, tool = layui.tool;
|
||
|
|
||
|
$('.hover-edit').hover(function () {
|
||
|
$(this).addClass('hover-on');
|
||
|
}, function () {
|
||
|
$(this).removeClass('hover-on');
|
||
|
})
|
||
|
|
||
|
$('.hover-edit').on('click', 'i', function () {
|
||
|
let name = $(this).data('name');
|
||
|
let show_txt = $('#' + name + '_' + detail_id).text().replace(/[\r\n\t]/g, "");
|
||
|
let real_txt = $('#' + name + '_' + detail_id).data('val');
|
||
|
if (real_txt === '') {
|
||
|
real_txt = show_txt;
|
||
|
}
|
||
|
editShow(detail_id, name, show_txt, real_txt);
|
||
|
})
|
||
|
|
||
|
$('#delBtn').on('click', function () {
|
||
|
layer.confirm('确定要删除该任务吗?请慎重', { icon: 3, title: '提示' }, function (index) {
|
||
|
let callback = function (e) {
|
||
|
layer.closeAll();
|
||
|
layer.msg(e.msg);
|
||
|
parent.layui.taskTable.reload();
|
||
|
if (e.code == 0) {
|
||
|
parent.layui.tool.close(1000);
|
||
|
}
|
||
|
}
|
||
|
let postData = { "id": detail_id };
|
||
|
tool.delete("/project/task/delete", postData, callback);
|
||
|
});
|
||
|
})
|
||
|
|
||
|
oaTool.addFile({
|
||
|
type:1,
|
||
|
isSave:true,
|
||
|
uidDelete:true,
|
||
|
colmd:6,
|
||
|
ajaxDelete:function(file_id){
|
||
|
let callback = function (e) {
|
||
|
layer.msg(e.msg);
|
||
|
if (e.code == 0) {
|
||
|
$('#fileItem' + file_id).remove();
|
||
|
}
|
||
|
}
|
||
|
tool.delete("/project/api/delete_file", {id: file_id}, callback);
|
||
|
},
|
||
|
ajaxSave:function(res){
|
||
|
let callback = function (e) {
|
||
|
location.reload();
|
||
|
}
|
||
|
tool.post("/project/api/add_file", {'topic_id': detail_id, 'file_id': res.data.id, 'file_name': res.data.name, 'module': 'task' }, callback);
|
||
|
}
|
||
|
});
|
||
|
//工作记录相关
|
||
|
work.load(detail_id);
|
||
|
$('.add-schedule').on('click', function () {
|
||
|
work.add(detail_id,{'id':0});
|
||
|
})
|
||
|
|
||
|
//任务日志
|
||
|
comment.log(detail_id,'task');
|
||
|
|
||
|
//评论
|
||
|
comment.load(detail_id,'task');
|
||
|
$('#commentInput').on('click', function () {
|
||
|
comment.textarea(0,detail_id,0,0,'task','');
|
||
|
})
|
||
|
//回复
|
||
|
$('#comment_task_' + detail_id).on('click', '[data-event="replay"]', function () {
|
||
|
let pid = $(this).data('id');
|
||
|
let padmin_id = $(this).data('uid');
|
||
|
comment.textarea(0, detail_id, pid, padmin_id, 'task', '');
|
||
|
})
|
||
|
//编辑
|
||
|
$('#comment_task_' + detail_id).on('click', '[data-event="edit"]', function () {
|
||
|
let id = $(this).data('id');
|
||
|
let content = $('#comment_' + id).data('content');
|
||
|
comment.textarea(id, detail_id, 0, 0, 'task', content);
|
||
|
})
|
||
|
|
||
|
//删除
|
||
|
$('#comment_task_' + detail_id).on('click', '[data-event="del"]', function () {
|
||
|
let id = $(this).data('id');
|
||
|
comment.del(id, detail_id, 'task');
|
||
|
})
|
||
|
|
||
|
let loading = false;
|
||
|
let editPost = function (id, name, show_val, real_val) {
|
||
|
let callback = function (e) {
|
||
|
layer.closeAll();
|
||
|
if (e.code == 0) {
|
||
|
location.reload();
|
||
|
if (layui.pageTable) {
|
||
|
setTimeout(function () {
|
||
|
layui.pageTable.reload();
|
||
|
}, 400)
|
||
|
}
|
||
|
}
|
||
|
else {
|
||
|
layer.msg(e.msg);
|
||
|
}
|
||
|
}
|
||
|
let postData = { id: id };
|
||
|
postData[name] = real_val;
|
||
|
tool.post("/project/task/add", postData, callback);
|
||
|
}
|
||
|
|
||
|
function editShow(id, name, show_txt, real_txt) {
|
||
|
if (loading == true) {
|
||
|
return false;
|
||
|
}
|
||
|
if (name == "title" || name == "plan_hours") {
|
||
|
edit.text(id, name, real_txt, editPost);
|
||
|
}
|
||
|
if (name == "end_time") {
|
||
|
if (admin_id == login_admin) {
|
||
|
edit.date(id, name, real_txt, editPost);
|
||
|
} else {
|
||
|
layer.msg('您没权限修改,请联系创建人修改');
|
||
|
}
|
||
|
}
|
||
|
if (name == "director_uid") {
|
||
|
edit.employee_one(id, name, show_txt, real_txt, editPost);
|
||
|
}
|
||
|
if (name == "assist_admin_ids") {
|
||
|
edit.employee_more(id, name, show_txt, real_txt, editPost);
|
||
|
}
|
||
|
if (name == "flow_status" || name == "priority" || name == "done_ratio" || name == "type") {
|
||
|
edit.dropdown(id, name, real_txt, opsData[name], editPost);
|
||
|
}
|
||
|
if (name == "cate") {
|
||
|
loading = true;
|
||
|
tool.get("/api/index/get_work_cate", {}, function (res) {
|
||
|
let data = res.data;
|
||
|
loading = false;
|
||
|
edit.dropdown(id, name, real_txt, data, editPost, 0);
|
||
|
});
|
||
|
}
|
||
|
if (name == "project_id") {
|
||
|
if (admin_id == login_admin) {
|
||
|
edit.select_table(id, name, real_txt, "/project/api/get_project", editPost, 1);
|
||
|
} else {
|
||
|
layer.msg('您没权限修改,请联系创建人或负责人修改');
|
||
|
}
|
||
|
}
|
||
|
if (name == "content") {
|
||
|
edit.editor(id, name, real_txt, editPost);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
{/block}
|