You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

422 lines
38 KiB

<template>
<div class="my-project-container">
<div class="filter-view">
<div>
<span @click="switchDataShowTypeHandle('gird')">
<font-icon
:class="{'show-view-type-icon-active':dataShowType=='gird'}"
class="fas fa-th-large show-view-type-icon "
/>
</span>
<span @click="switchDataShowTypeHandle('table')">
<font-icon
:class="{'show-view-type-icon-active':dataShowType=='table'}"
class="fas fa-th-list show-view-type-icon"
/>
</span>
</div>
<el-form ref="form" label-width="100px">
<el-form-item label="项目更新时间">
<el-date-picker
v-model="queryParams.beginDateTime"
placeholder="选择开始时间"
style="width: 20%;"
type="datetime"
value-format="yyyy-MM-dd HH:mm:ss"
/>
<el-date-picker
v-model="queryParams.endDateTime"
:default-time="'23:59:59'"
placeholder="选择结束时间"
style="width: 20%;"
type="datetime"
value-format="yyyy-MM-dd HH:mm:ss"
/>
<el-input
v-model="queryParams.name"
placeholder="请输入项目名称" style="width: 20%; margin-left: 20px;" type="text"
/>
<el-button class="ml-20" type="primary" @click="queryProjectPage">查询</el-button>
</el-form-item>
<el-form-item label="项目状态">
<el-radio-group v-model="queryParams.status" size="small" @change="()=>{
this.queryParams.current=0
this.queryProjectPage()
}"
>
<el-radio-button v-for="status in projectStatusList" :key="status.code" :label="status.code">
{{ status.name }}
</el-radio-button>
</el-radio-group>
</el-form-item>
</el-form>
</div>
<div v-if="dataShowType=='gird'" class="project-grid-container">
<div
v-if="projectList.length"
v-loading="projectListLoading"
class="project-grid-view"
>
<div v-for="p in projectList" :key="p.id" class="project-grid-item-view pointer">
<el-row align="middle" justify="center" type="flex">
<el-col :span="5">
<span
:style="getStatusColorStyle(p.status)"
class="project-grid-view-status"
/>
</el-col>
<el-col :span="19">
<el-tooltip :content="p.name" placement="top">
<p class="project-title">
{{ p.name }}
</p>
</el-tooltip>
</el-col>
</el-row>
<img class="project-grid-view-preimg"
src=""
>
<p class="project-grid-view-time">创建时间{{ p.createdTime | formatDate }}</p>
<div class="gird-operating-btns">
<el-button type="text" @click="toProjectHandle(p.key,'editor')">
<i class="el-icon-edit" />
编辑
</el-button>
<span>
<el-button
v-if="p.status!=1" type="text" @click="toProjectHandle(p.key,'statistics')"
>
<i class="el-icon-data-analysis" />
统计
</el-button>
</span>
<el-popconfirm
v-if="p.status==2"
title="确定停止收集该项目吗?"
@confirm="stopProject(p.key)"
>
<el-button slot="reference"
class="pink-text-btn"
type="text"
>
<i class="el-icon-video-pause" />
停止
</el-button>
</el-popconfirm>
<el-popconfirm
v-if="p.status!=2"
title="确定删除该项目吗?"
@confirm="deleteProject(p.key)"
>
<el-button slot="reference"
class="pink-text-btn"
type="text"
>
<i class="el-icon-delete" />
删除
</el-button>
</el-popconfirm>
</div>
</div>
</div>
<div v-if="!projectListLoading&&projectList.length==0">
<data-empty />
</div>
</div>
<div v-if="dataShowType=='table'" class="project-table-view">
<el-table
:data="projectList"
border
empty-text="暂无数据"
highlight-current-row
stripe
style="width: 100%;"
>
<el-table-column
align="center"
label="标题"
prop="name"
show-overflow-tooltip
/>
<el-table-column
align="center"
label="描述"
prop="describe"
show-overflow-tooltip
/>
<el-table-column
align="center"
label="状态"
>
<template slot-scope="scope">
<span v-for="status in projectStatusList" :key="status.code">
<span
v-if="status.code==scope.row.status"
>
{{ status.name }}
</span>
</span>
</template>
</el-table-column>
<el-table-column
align="center"
label="创建时间"
prop="createdTime"
/>
<el-table-column
align="center"
label="更新时间"
prop="updatedTime"
/>
<el-table-column label="操作">
<template slot-scope="scope">
<el-button type="text"
@click="toProjectHandle(scope.row.key,'editor')"
>
编辑
</el-button>
<span>
<el-button
v-if="scope.row.status!=1"
class="green-text-btn"
type="text"
@click="toProjectHandle(scope.row.key,'statistics')"
>
统计
</el-button>
</span>
<el-popconfirm
v-if="scope.row.status==2"
title="确定停止收集该项目吗?"
@confirm="stopProject(scope.row.key)"
>
<el-button slot="reference"
class="pink-text-btn"
type="text"
>
停止
</el-button>
</el-popconfirm>
<el-popconfirm
v-if="scope.row.status!=2"
title="确定删除该项目吗?"
@confirm="deleteProject(scope.row.key)"
>
<el-button slot="reference"
class="pink-text-btn"
type="text"
>
删除
</el-button>
</el-popconfirm>
</template>
</el-table-column>
</el-table>
</div>
<div class="project-page-view">
<el-pagination
v-if="total>10"
:current-page.sync="queryParams.current"
:page-size.sync="queryParams.size"
:total="total"
background
layout="total, prev, pager, next"
@current-change="queryProjectPage"
/>
</div>
</div>
</template>
<script>
import dayjs from 'dayjs'
let projectStatusList = [
{code: 1, name: '未发布', color: '#006EFF'},
{code: 2, name: '收集中', color: '#34C82A'},
{code: 3, name: '已结束', color: '#955A45'}
]
export default {
name: 'MyProject',
filters: {
formatDate(time) {
return dayjs(time).format('YYYY/MM/DD')
}
},
data() {
return {
dataShowType: 'gird',
total: 0,
queryParams: {
current: 1,
size: 10,
name: '',
beginDateTime: null,
endDateTime: null,
status: null
},
projectStatusList: projectStatusList,
projectList: [],
projectListLoading: true
}
},
computed: {
getStatusColorStyle() {
return function(code) {
let color = this.projectStatusList.find(item => item.code == code).color
return {
backgroundColor: color,
borderColor: color
}
}
}
},
created() {
this.queryProjectPage()
},
methods: {
switchDataShowTypeHandle(type) {
this.dataShowType = type
},
toProjectHandle(key, type) {
this.$router.push({path: `/project/form/${type}`, query: {key: key, active: type}})
},
deleteProject(key) {
this.$api.post(`${process.env.VUE_APP_API_ROOT_TDUCK}/user/project/delete`, {'key': key}).then(res => {
if (res.data) {
this.msgSuccess('刪除成功')
this.queryProjectPage()
}
})
},
stopProject(key) {
this.$api.post(`${process.env.VUE_APP_API_ROOT_TDUCK}/user/project/stop`, {'key': key}).then(res => {
if (res.data) {
this.msgSuccess('停止成功')
this.queryProjectPage()
}
})
},
queryProjectPage() {
this.$api.get(`${process.env.VUE_APP_API_ROOT_TDUCK}/user/project/page`, {
params: this.queryParams
}).then(res => {
let {records, total, size} = res.data
this.projectList = records
this.total = total
this.queryParams.size = size
this.projectListLoading = false
})
}
}
}
</script>
<style lang="scss" scoped>
.my-project-container {
display: flex;
width: 100%;
height: 100%;
flex-direction: column;
align-items: center;
align-content: center;
}
.back-view {
display: flex;
width: 80%;
align-content: flex-start;
margin: 10px;
}
.filter-view {
margin-top: 20px;
display: flex;
flex-direction: row;
}
.show-view-type-icon {
color: white;
font-size: 18px;
-webkit-text-stroke: 0.5px #a8a8a8;
margin: 5px;
cursor: pointer;
}
.show-view-type-icon-active {
color: rgba(92, 155, 249, 100);
-webkit-text-stroke: 0.5px rgba(92, 155, 249, 100);
}
.project-grid-container {
margin-top: 20px;
display: flex;
width: 100%;
justify-content: center;
}
.project-grid-view {
display: flex;
width: 950px;
flex-direction: row;
flex-wrap: wrap;
}
.project-table-view {
margin-top: 20px;
width: 80%;
}
.project-grid-item-view {
width: 169px;
height: 199px;
line-height: 20px;
border-radius: 4px;
background-color: rgba(255, 255, 255, 100);
text-align: center;
margin: 10px;
position: relative;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12), 0 0 6px rgba(0, 0, 0, 0.04);
.project-title {
color: rgba(16, 16, 16, 100);
font-size: 14px;
text-align: left;
line-height: 20px;
max-height: 20px;
-webkit-box-orient: vertical;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.project-grid-view-status {
display: inline-block;
width: 7px;
height: 7px;
line-height: 20px;
background-color: rgba(0, 110, 255, 100);
text-align: center;
border: 1px solid rgba(0, 110, 255, 100);
border-radius: 20px;
}
}
.gird-operating-btns {
position: absolute;
width: 100%;
margin: 0;
padding: 0;
background-color: #f0f0f0;
bottom: 0;
display: none;
border: none;
}
.project-grid-item-view:hover .gird-operating-btns {
display: block;
}
.project-grid-view-preimg {
width: 143px;
height: 121px;
}
.project-grid-view-time {
color: rgba(144, 147, 153, 100);
font-size: 12px;
line-height: 20px;
text-align: center;
margin: 0;
}
.project-page-view {
margin-top: 30px;
}
</style>