ctfx.vue 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234
  1. <script setup lang='ts'>
  2. import { Search } from '@element-plus/icons-vue'
  3. import { RouteLocationRaw, useRouter } from 'vue-router'
  4. import { Grade, Status, Subject } from '~/store/info'
  5. import user from '~/store/user'
  6. import { download } from "~/utils/request";
  7. const router = useRouter()
  8. function routerPush(_route: RouteLocationRaw) {
  9. router.push(_route)
  10. }
  11. const tableData = ref([])
  12. const total = ref(0)
  13. const multipleSelection = ref([])
  14. const handleSelectionChange = (val) => {
  15. multipleSelection.value = val
  16. }
  17. const queryForm = reactive({
  18. dc_grade_id: undefined,
  19. dc_subject_id: undefined,
  20. dc_check: undefined,
  21. dc_keyword: undefined,
  22. page: 1
  23. })
  24. watch(queryForm, () => {
  25. doQuery()
  26. }, { deep: true, immediate: true })
  27. function doQuery() {
  28. request({
  29. url: '/dyaw/ctfx/index',
  30. data: {
  31. ...queryForm,
  32. // 管理员不需要传递sm_id
  33. // sm_id: user.sm_info.sm_id,
  34. // create_user_id: user.user_id
  35. }
  36. }).then(res => {
  37. if (res.code === "1") {
  38. tableData.value = res.data.page_data
  39. total.value = parseInt(res.data.total_rows)
  40. }
  41. })
  42. }
  43. function doDelete() {
  44. if (multipleSelection.value.length === 0)
  45. return ElMessage.error('请先勾选删除的数据')
  46. request({
  47. url: '/dyaw/ctfx/delete',
  48. data: {
  49. dc_id: multipleSelection.value.map(item => item.dc_id)
  50. }
  51. }).then(
  52. res => {
  53. if (res.code === "1") {
  54. ElMessage.success('删除成功')
  55. doQuery()
  56. }
  57. }
  58. )
  59. }
  60. function doExport() {
  61. if (multipleSelection.value.length === 0)
  62. return ElMessage.error('请先勾选导出的数据')
  63. download('/dyaw/ctfx/index',
  64. {
  65. dc_id: multipleSelection.value.map(item => item.dc_id).join(','),
  66. site: 'dyaw'
  67. }
  68. )
  69. }
  70. function allExport(){
  71. download('/dyaw/ctfx/index',
  72. {
  73. site: 'dyaw'
  74. }
  75. )
  76. }
  77. function formatTime(s: string) {
  78. return (new Date(s * 1000)).toLocaleString()
  79. }
  80. const dialogFormVisible = ref(false)
  81. const dialogForm = reactive({
  82. dc_id: undefined,
  83. dc_check: '1',
  84. dc_check_desc: ''
  85. })
  86. function doJudge(id) {
  87. // init doJudge
  88. dialogForm.dc_id = id
  89. dialogForm.dc_check = '1'
  90. dialogForm.dc_check_desc = ''
  91. dialogFormVisible.value = true
  92. }
  93. function doSubmit() {
  94. request({
  95. url: '/dyaw/ctfx/edit',
  96. data: {
  97. dc_id: dialogForm.dc_id,
  98. dyaw_ctfx: {
  99. dc_check: dialogForm.dc_check,
  100. dc_check_desc: dialogForm.dc_check_desc,
  101. dc_check_user_id: user.user_id
  102. }
  103. }
  104. }).then(
  105. res => {
  106. if (res.code === "1") {
  107. ElMessage.success('审核成功')
  108. dialogFormVisible.value = false
  109. doQuery()
  110. }
  111. }
  112. )
  113. }
  114. </script>
  115. <template>
  116. <div class="w-full h-640px flex flex-col">
  117. <div class="flex justify-end items-center">
  118. <div class="flex space-x-2">
  119. <el-select clearable size="large" placeholder="年级" v-model="queryForm.dc_grade_id">
  120. <el-option v-for="({ grade_id, grade_name }) in Grade" :key="grade_id" :label="grade_name" :value="grade_id" />
  121. </el-select>
  122. <el-select clearable size="large" placeholder="科目" v-model="queryForm.dc_subject_id">
  123. <el-option v-for="({ subject_id, subject_name }) in Subject" :key="subject_id" :label="subject_name"
  124. :value="subject_id" />
  125. </el-select>
  126. <el-select clearable size="large" placeholder="状态" v-model="queryForm.dc_check">
  127. <el-option v-for="(k) in Object.keys(Status)" :key="k" :label="Status[k]" :value="k" />
  128. </el-select>
  129. <el-input clearable size="large" placeholder="关键字搜索" class="max-w-240px" :suffix-icon="Search"
  130. v-model="queryForm.dc_keyword"></el-input>
  131. <el-button size="large" type="danger" @click="doDelete">删除</el-button>
  132. <el-button size="large" type="primary" @click="allExport">全部导出</el-button>
  133. <el-button size="large" type="primary" @click="doExport">批量导出</el-button>
  134. </div>
  135. </div>
  136. <div class="flex-auto flex-col flex mt-4 justify-between">
  137. <el-table ref="multipleTableRef" :data="tableData" style="width: 100%" @selection-change="handleSelectionChange">
  138. <el-table-column type="selection" width="55" />
  139. <el-table-column property="dc_title" label="标题" width="auto" show-overflow-tooltip />
  140. <el-table-column property="dc_grade_name" label="年级" width="120" />
  141. <el-table-column property="dc_subject_name" label="科目" width="120" />
  142. <el-table-column property="dc_keyword" label="关键词" width="180" />
  143. <el-table-column property="create_user_realname" label="上传教师" width="120" />
  144. <el-table-column property="sm_name" label="学校" width="120" />
  145. <el-table-column property="create_dateline" label="上传时间" width="180">
  146. <template #default="{ row }">
  147. <span>{{ formatTime(row.create_dateline) }}</span>
  148. </template>
  149. </el-table-column>
  150. <el-table-column property="name" label="状态" width="120">
  151. <template #default="{ row }">
  152. <span
  153. :class="row.dc_check === '1' ? 'text-green-500' : row.dc_check === '2' ? 'text-red-500' : 'text-blue-500'">{{
  154. Status[row.dc_check] }}</span>
  155. </template>
  156. </el-table-column>
  157. <el-table-column fixed="right" label="操作" width="120">
  158. <template #default="{ row }">
  159. <el-button link type="primary" size="small" :disabled="row.dc_check !== '0'"
  160. @click="doJudge(row.dc_id)">审核</el-button>
  161. <el-button link type="primary" size="small"
  162. @click="routerPush({ name: 'admin_back_ctfx_detail', params: { id: row.dc_id } })">查看</el-button>
  163. </template>
  164. </el-table-column>
  165. </el-table>
  166. <div class="flex justify-end mt-6">
  167. <el-pagination v-model:current-page="queryForm.page" background layout="prev, pager, next"
  168. :total="total"></el-pagination>
  169. </div>
  170. </div>
  171. <el-dialog v-model="dialogFormVisible" title="审核">
  172. <el-form :model="dialogForm">
  173. <el-form-item label="审核结果">
  174. <el-radio-group v-model="dialogForm.dc_check">
  175. <el-radio label="1">通过</el-radio>
  176. <el-radio label="2">不通过</el-radio>
  177. </el-radio-group>
  178. </el-form-item>
  179. <el-form-item label="处理意见" v-show="dialogForm.dc_check === '2'">
  180. <el-input v-model="dialogForm.dc_check_desc" type="textarea" :rows="5" />
  181. </el-form-item>
  182. </el-form>
  183. <template #footer>
  184. <div class="w-full justify-end space-x-4">
  185. <el-button @click="dialogFormVisible = false">取消</el-button>
  186. <el-button type="primary" @click="doSubmit">
  187. 提交
  188. </el-button>
  189. </div>
  190. </template>
  191. </el-dialog>
  192. </div>
  193. </template>
  194. <style scoped lang="scss">
  195. .tab_selected {
  196. color: #007DFF;
  197. &::after {
  198. content: '-';
  199. color: transparent;
  200. position: absolute;
  201. left: -5px;
  202. right: -5px;
  203. bottom: -4px;
  204. height: 15px;
  205. background: rgba(0, 125, 255, 0.30);
  206. border-radius: 8px;
  207. }
  208. }
  209. </style>