mirror of
https://github.com/kuaifan/dootask.git
synced 2025-12-10 18:02:55 +00:00
241 lines
7.3 KiB
Vue
241 lines
7.3 KiB
Vue
<template>
|
|
<div class="task-deleted">
|
|
<div class="deleted-title">
|
|
{{$L('删除的任务')}}
|
|
<div class="title-icon">
|
|
<Loading v-if="loadIng > 0"/>
|
|
</div>
|
|
</div>
|
|
<div class="search-container lr">
|
|
<ul>
|
|
<li>
|
|
<div class="search-label">
|
|
{{$L("任务名")}}
|
|
</div>
|
|
<div class="search-content">
|
|
<Input v-model="keys.name" clearable/>
|
|
</div>
|
|
</li>
|
|
<li class="search-button">
|
|
<Tooltip
|
|
theme="light"
|
|
placement="right"
|
|
transfer-class-name="search-button-clear"
|
|
transfer>
|
|
<Button :loading="loadIng > 0" type="primary" icon="ios-search" @click="getLists">{{$L('搜索')}}</Button>
|
|
<div slot="content">
|
|
<Button :loading="loadIng > 0" type="text" @click="getLists">{{$L('刷新')}}</Button>
|
|
</div>
|
|
</Tooltip>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
<div class="table-page-box">
|
|
<Table
|
|
:columns="columns"
|
|
:data="list"
|
|
:loading="loadIng > 0"
|
|
:no-data-text="$L(noText)"
|
|
stripe/>
|
|
<Page
|
|
:total="total"
|
|
:current="page"
|
|
:page-size="pageSize"
|
|
:disabled="loadIng > 0"
|
|
:simple="windowMax768"
|
|
:page-size-opts="[10,20,30,50,100]"
|
|
show-elevator
|
|
show-sizer
|
|
show-total
|
|
@on-change="setPage"
|
|
@on-page-size-change="setPageSize"/>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import {mapState} from "vuex";
|
|
|
|
export default {
|
|
name: "TaskDeleted",
|
|
props: {
|
|
projectId: {
|
|
type: Number,
|
|
default: 0
|
|
},
|
|
},
|
|
data() {
|
|
return {
|
|
loadIng: 0,
|
|
|
|
keys: {},
|
|
|
|
columns: [],
|
|
list: [],
|
|
|
|
page: 1,
|
|
pageSize: 20,
|
|
total: 0,
|
|
noText: ''
|
|
}
|
|
},
|
|
mounted() {
|
|
|
|
},
|
|
computed: {
|
|
...mapState(['cacheTasks', 'windowMax768'])
|
|
},
|
|
watch: {
|
|
projectId: {
|
|
handler() {
|
|
this.getLists();
|
|
},
|
|
immediate: true
|
|
}
|
|
},
|
|
methods: {
|
|
initLanguage() {
|
|
this.columns = [
|
|
{
|
|
title: this.$L('ID'),
|
|
minWidth: 50,
|
|
maxWidth: 70,
|
|
key: 'id',
|
|
},
|
|
{
|
|
title: this.$L('任务名称'),
|
|
key: 'name',
|
|
minWidth: 200,
|
|
render: (h, {row}) => {
|
|
return h('AutoTip', row.name);
|
|
}
|
|
},
|
|
{
|
|
title: this.$L('创建时间'),
|
|
key: 'created_at',
|
|
width: 168,
|
|
},
|
|
{
|
|
title: this.$L('删除时间'),
|
|
key: 'deleted_at',
|
|
width: 168,
|
|
},
|
|
{
|
|
title: this.$L('删除人员'),
|
|
key: 'deleted_userid',
|
|
minWidth: 100,
|
|
render: (h, {row}) => {
|
|
if (!row.deleted_userid) {
|
|
return h('span', '-');
|
|
}
|
|
return h('UserAvatar', {
|
|
props: {
|
|
userid: row.deleted_userid,
|
|
size: 24,
|
|
showName: true
|
|
}
|
|
});
|
|
}
|
|
},
|
|
{
|
|
title: this.$L('操作'),
|
|
align: 'center',
|
|
width: 100,
|
|
render: (h, params) => {
|
|
const vNodes = [
|
|
h('Poptip', {
|
|
props: {
|
|
title: this.$L('你确定要还原删除吗?'),
|
|
confirm: true,
|
|
transfer: true,
|
|
placement: 'left',
|
|
},
|
|
style: {
|
|
fontSize: '13px',
|
|
cursor: 'pointer',
|
|
color: '#8bcf70',
|
|
},
|
|
on: {
|
|
'on-ok': () => {
|
|
this.recovery(params.row);
|
|
}
|
|
},
|
|
}, this.$L('还原')),
|
|
];
|
|
return h('TableAction', {
|
|
props: {
|
|
column: params.column
|
|
}
|
|
}, vNodes);
|
|
}
|
|
}
|
|
]
|
|
},
|
|
|
|
refresh() {
|
|
this.keys = {};
|
|
this.getLists()
|
|
},
|
|
|
|
getLists() {
|
|
if (!this.projectId) {
|
|
return;
|
|
}
|
|
this.loadIng++;
|
|
this.$store.dispatch("call", {
|
|
url: 'project/task/lists',
|
|
data: {
|
|
keys: this.keys,
|
|
project_id: this.projectId,
|
|
parent_id: -1,
|
|
deleted: 'yes',
|
|
sorts: {
|
|
deleted_at: 'desc'
|
|
},
|
|
page: Math.max(this.page, 1),
|
|
pagesize: Math.max($A.runNum(this.pageSize), 20),
|
|
},
|
|
}).then(({data}) => {
|
|
this.loadIng--;
|
|
this.page = data.current_page;
|
|
this.total = data.total;
|
|
this.list = data.data;
|
|
this.noText = '没有相关的数据';
|
|
}).catch(() => {
|
|
this.loadIng--;
|
|
this.noText = '数据加载失败';
|
|
})
|
|
},
|
|
|
|
setPage(page) {
|
|
this.page = page;
|
|
this.getLists();
|
|
},
|
|
|
|
setPageSize(pageSize) {
|
|
this.page = 1;
|
|
this.pageSize = pageSize;
|
|
this.getLists();
|
|
},
|
|
|
|
recovery(row) {
|
|
this.list = this.list.filter(({id}) => id != row.id);
|
|
this.loadIng++;
|
|
this.$store.dispatch("removeTask", {
|
|
task_id: row.id,
|
|
type: 'recovery'
|
|
}).then(({msg}) => {
|
|
$A.messageSuccess(msg);
|
|
this.loadIng--;
|
|
this.getLists();
|
|
this.$store.dispatch("openTask", row);
|
|
}).catch(({msg}) => {
|
|
$A.modalError(msg);
|
|
this.loadIng--;
|
|
this.getLists();
|
|
})
|
|
}
|
|
}
|
|
}
|
|
</script>
|