index.vue 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. <template>
  2. <div class="app-container">
  3. <el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="80px">
  4. <el-form-item label="部门名称" prop="deptName">
  5. <el-input v-model="queryParams.deptName" placeholder="请输入部门名称" clearable @keyup.enter="handleQuery" />
  6. </el-form-item>
  7. <el-form-item label="队室/班组" prop="teamName">
  8. <el-input v-model="queryParams.teamName" placeholder="请输入队室/班组" clearable @keyup.enter="handleQuery" />
  9. </el-form-item>
  10. <el-form-item label="巡查人" prop="inspectorName">
  11. <el-input v-model="queryParams.inspectorName" placeholder="请输入巡查人" clearable @keyup.enter="handleQuery" />
  12. </el-form-item>
  13. <el-form-item label="责任人" prop="inspectedName">
  14. <el-input v-model="queryParams.inspectedName" placeholder="请输入责任人" clearable @keyup.enter="handleQuery" />
  15. </el-form-item>
  16. <el-form-item label="记录日期">
  17. <el-date-picker v-model="dateRange" type="daterange" value-format="YYYY-MM-DD"
  18. range-separator="-" start-placeholder="开始日期" end-placeholder="结束日期" clearable />
  19. </el-form-item>
  20. <el-form-item>
  21. <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
  22. <el-button icon="Refresh" @click="resetQuery">重置</el-button>
  23. </el-form-item>
  24. </el-form>
  25. <el-row :gutter="10" class="mb8">
  26. <el-col :span="1.5">
  27. <el-button type="warning" plain icon="Download" @click="handleExport"
  28. v-hasPermi="['ledger:supervisionProblem:export']">导出</el-button>
  29. </el-col>
  30. <right-toolbar v-model:showSearch="showSearch" @queryTable="getList" />
  31. </el-row>
  32. <el-table v-loading="loading" :data="list">
  33. <el-table-column label="记录日期" align="center" prop="recordDate" width="110">
  34. <template #default="{ row }">{{ parseTime(row.recordDate, '{y}-{m}-{d}') }}</template>
  35. </el-table-column>
  36. <el-table-column label="部门名称" align="center" prop="deptName" />
  37. <el-table-column label="队室/班组" align="center" prop="teamName" />
  38. <el-table-column label="小组" align="center" prop="groupName" />
  39. <el-table-column label="巡查人" align="center" prop="inspectorName" />
  40. <el-table-column label="责任人" align="center" prop="inspectedName" />
  41. <el-table-column label="问题类型" align="center" prop="problemType" />
  42. <el-table-column label="问题描述" align="center" prop="problemDesc" show-overflow-tooltip />
  43. <el-table-column label="问题地点" align="center" prop="location" />
  44. <el-table-column label="扣分" align="center" prop="deductScore">
  45. <template #default="{ row }">
  46. <span v-if="row.deductScore" style="color: #f56c6c;">-{{ row.deductScore }}</span>
  47. </template>
  48. </el-table-column>
  49. <el-table-column label="加分" align="center" prop="addScore">
  50. <template #default="{ row }">
  51. <span v-if="row.addScore" style="color: #67c23a;">+{{ row.addScore }}</span>
  52. </template>
  53. </el-table-column>
  54. <el-table-column label="评分维度" align="center" prop="scoreDimension" />
  55. <el-table-column label="附件" align="center" prop="evidenceFile">
  56. <template #default="{ row }">
  57. <el-link v-if="row.evidenceFile" :href="row.evidenceFile" target="_blank" type="primary">查看</el-link>
  58. <span v-else>-</span>
  59. </template>
  60. </el-table-column>
  61. </el-table>
  62. <pagination v-show="total > 0" :total="total" v-model:page="queryParams.pageNum"
  63. v-model:limit="queryParams.pageSize" @pagination="getList" />
  64. </div>
  65. </template>
  66. <script setup>
  67. import { ref, reactive, onMounted } from 'vue'
  68. import { listSupervisionProblem, exportSupervisionProblem } from '@/api/ledger/index'
  69. import { parseTime } from '@/utils/ruoyi'
  70. defineOptions({ name: 'LedgerSupervisionProblem' })
  71. const loading = ref(false)
  72. const list = ref([])
  73. const total = ref(0)
  74. const showSearch = ref(true)
  75. const dateRange = ref([])
  76. const queryRef = ref(null)
  77. const queryParams = reactive({
  78. pageNum: 1,
  79. pageSize: 10,
  80. deptName: '',
  81. teamName: '',
  82. inspectorName: '',
  83. inspectedName: ''
  84. })
  85. function getList() {
  86. loading.value = true
  87. const params = { ...queryParams }
  88. if (dateRange.value && dateRange.value.length === 2) {
  89. params['params[beginTime]'] = dateRange.value[0]
  90. params['params[endTime]'] = dateRange.value[1]
  91. }
  92. listSupervisionProblem(params).then(res => {
  93. list.value = res.rows
  94. total.value = res.total
  95. }).finally(() => { loading.value = false })
  96. }
  97. function handleQuery() {
  98. queryParams.pageNum = 1
  99. getList()
  100. }
  101. function resetQuery() {
  102. dateRange.value = []
  103. queryRef.value?.resetFields()
  104. handleQuery()
  105. }
  106. function handleExport() {
  107. const params = { ...queryParams }
  108. if (dateRange.value && dateRange.value.length === 2) {
  109. params['params[beginTime]'] = dateRange.value[0]
  110. params['params[endTime]'] = dateRange.value[1]
  111. }
  112. exportSupervisionProblem(params)
  113. }
  114. onMounted(getList)
  115. </script>