1
0
mirror of https://github.com/FatttSnake/Pinnacle-OA.git synced 2026-04-06 07:21:24 +08:00

temp 2023/5/3

This commit is contained in:
GGB
2023-05-03 15:38:49 +08:00
parent 9b33b1061d
commit 41b6c77509
15 changed files with 187 additions and 123 deletions

View File

@@ -0,0 +1,170 @@
<template>
<div class="main">
<div class="main-table">
<el-table :data="tableData" style="width: 100%">
<el-table-column prop="content" label="内容" width="800" />
<el-table-column prop="publisherName" label="发布者" width="120" />
<el-table-column prop="worker" label="工作人员" width="200">
<template #default="{ row }">
<span v-for="item in row.worker" :key="item.userId">
{{ item.username }},&nbsp;
</span>
</template>
</el-table-column>
<el-table-column prop="deadline" label="结束时间" width="200">
<template #default="scope">
{{ formatDate(scope.row.deadline) }}
</template>
</el-table-column>
<el-table-column fixed="right" prop="progress" label="进度" width="200">
<template #default="scope">
<el-progress
:text-inside="true"
:stroke-width="15"
:percentage="scope.row.progress"
/>
</template>
</el-table-column>
<el-table-column fixed="right" label="操作" width="150">
<template #default="scope">
<el-button link type="primary" size="large" @click="handleClick(scope.row)"
>编辑</el-button
>
<el-popconfirm
width="220"
confirm-button-text=""
cancel-button-text=""
icon-color="#00d4ff"
title="是否确定删除?"
@confirm="deleteConfirmEvent(scope.row)"
@cancel="deleteCancelEvent"
>
<template #reference>
<el-button link type="primary" size="default">删除</el-button>
</template>
</el-popconfirm>
</template>
</el-table-column>
</el-table>
</div>
<div class="main-add-content">
<div class="main-add-box">
<el-button size="large" @click="addVisible = true">添加</el-button>
</div>
<el-dialog v-model="addVisible" width="60%">
<edit-work @setDialogVisible="setDialogVisible" @addWork="addWork"></edit-work>
</el-dialog>
<el-dialog v-model="editVisible" width="60%">
<edit-work
:editForm="rowData"
@setDialogVisible="setDialogVisible"
@updateWork="updateWork"
></edit-work>
</el-dialog>
</div>
</div>
</template>
<script lang="ts">
import axios from 'axios'
import EditWork from '@/components/EditWork.vue'
export default {
name: 'AllTaskPage',
data() {
return {
tableData: [],
rowData: [],
addVisible: false,
editVisible: false
}
},
methods: {
formatDate(deadline) {
console.log(new Date(deadline).toLocaleString())
return new Date(deadline).toLocaleString()
},
handleClick(row) {
this.rowData = row
this.editVisible = true
console.log('click')
},
deleteConfirmEvent(row) {
this.deleteTableData(row)
console.log('delete confirm!')
},
deleteCancelEvent() {
console.log('delete cancel!')
},
completeConfirmEvent() {
console.log('complete confirm!')
},
completeCancelEvent() {
console.log('complete cancel!')
},
getTableData() {
axios
.get('http://localhost:8621/work')
.then((response) => {
console.log(response.data.data)
this.tableData = response.data.data
console.log(this.tableData)
})
.catch((reportError) => {
console.log(reportError)
})
},
deleteTableData(row) {
axios
.delete('http://localhost:8621/work/' + row.id)
.then((response) => {
this.getTableData()
console.log(response.data.data)
})
.catch((reportError) => {
console.log(reportError)
})
},
setDialogVisible(dialogVisible) {
console.log(dialogVisible)
this.addVisible = dialogVisible
this.editVisible = dialogVisible
this.getTableData()
},
updateWork(form) {
axios
.put('http://localhost:8621/work', form)
.then((response) => {
this.editVisible = false
this.getTableData()
})
.catch((reportError) => {
console.log(reportError)
})
},
addWork(form) {
console.log(form)
axios
.post('http://localhost:8621/work', form)
.then((response) => {
this.addVisible = false
this.getTableData()
console.log(response.data)
})
.catch((reportError) => {
console.log(reportError)
})
}
},
created() {
this.getTableData()
},
components: {
EditWork
}
}
</script>
<style scoped>
@import '@/assets/css/work/work.css';
</style>