EndCheck.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376
  1. <template>
  2. <div class="radius-base">
  3. <div class="fill-blank radius-base p-t-base">
  4. <base-form :items="items" :model="model" :label-width="'80px'" size="small">
  5. <template #form-item-button>
  6. <el-button type="primary" @click="onStartCheck">开始检查</el-button>
  7. </template>
  8. </base-form>
  9. </div>
  10. <div class="m-t-base flex">
  11. <div class="radius-base fill-blank p-base overflow-hidden flex-1">
  12. <div class="flex items-center m-b-base table-title">
  13. <span class="label">在评卷员手中</span>
  14. <span class="data-count">{{ unMarkPaperList?.result?.length }}</span>
  15. <el-button :disabled="!multipleSelection1.length" type="primary" size="small" @click="onTaskChangeMarker"
  16. >任务指定</el-button
  17. >
  18. </div>
  19. <!-- <base-table
  20. ref="table1"
  21. v-loading="loading1"
  22. border
  23. stripe
  24. size="small"
  25. :columns="columns1"
  26. :data="unMarkPaperList?.result"
  27. highlight-current-row
  28. @current-change="onCheckTask"
  29. ></base-table> -->
  30. <div class="table-wrap">
  31. <base-table
  32. ref="table1"
  33. v-loading="loading1"
  34. border
  35. stripe
  36. size="small"
  37. :columns="columns1"
  38. :data="unMarkPaperList?.result"
  39. @selection-change="handleSelectionChange1"
  40. ></base-table>
  41. </div>
  42. </div>
  43. <div class="radius-base fill-blank p-base overflow-hidden m-l-base flex-1">
  44. <div class="flex items-center m-b-base table-title">
  45. <span class="label">打回中的试卷</span>
  46. <span class="data-count">{{ unMarkBackPaperList?.result?.length }}</span>
  47. <el-button :disabled="!multipleSelection2.length" type="primary" size="small" @click="onTaskChangeMarker2"
  48. >任务指定</el-button
  49. >
  50. </div>
  51. <!-- <base-table
  52. ref="table2"
  53. v-loading="loading4"
  54. border
  55. stripe
  56. size="small"
  57. :columns="columns1"
  58. :data="unMarkBackPaperList?.result"
  59. highlight-current-row
  60. @current-change="onCheckTask2"
  61. ></base-table> -->
  62. <div class="table-wrap">
  63. <base-table
  64. ref="table2"
  65. v-loading="loading4"
  66. border
  67. stripe
  68. size="small"
  69. :columns="columns1"
  70. :data="unMarkBackPaperList?.result"
  71. @selection-change="handleSelectionChange2"
  72. ></base-table>
  73. </div>
  74. </div>
  75. <div class="radius-base fill-blank p-base overflow-hidden m-l-base flex-1">
  76. <div class="flex items-center m-b-base table-title">
  77. <span class="label">未处理问题卷</span>
  78. <span class="data-count">{{ unProcessProblemList?.length }}</span>
  79. </div>
  80. <div class="table-wrap">
  81. <base-table
  82. v-loading="loading2"
  83. border
  84. stripe
  85. size="small"
  86. :columns="columns2"
  87. :data="unProcessProblemList"
  88. ></base-table>
  89. </div>
  90. </div>
  91. <div class="radius-base fill-blank p-base overflow-hidden m-l-base flex-1">
  92. <div class="flex items-center m-b-base table-title">
  93. <span class="label">未处理雷同卷</span>
  94. <span class="data-count">{{ unProcessSimilarList?.length }}</span>
  95. </div>
  96. <div class="table-wrap">
  97. <base-table
  98. v-loading="loading3"
  99. border
  100. stripe
  101. size="small"
  102. :columns="columns3"
  103. :data="unProcessSimilarList"
  104. ></base-table>
  105. </div>
  106. </div>
  107. </div>
  108. </div>
  109. <base-dialog
  110. v-model="visibleChangeMarker"
  111. title="任务指定评卷员"
  112. destroy-on-close
  113. @close="changeMarkerModel.loginName = ''"
  114. >
  115. <base-form
  116. ref="formRef"
  117. size="small"
  118. :rules="rules"
  119. :model="changeMarkerModel"
  120. :items="changeMarkerItems"
  121. ></base-form>
  122. <template #footer>
  123. <confirm-button around @confirm="onSubmitChangeMarker" @cancel="visibleChangeMarker = false"></confirm-button>
  124. </template>
  125. </base-dialog>
  126. <base-dialog
  127. v-model="visibleChangeMarker2"
  128. title="任务指定评卷员"
  129. destroy-on-close
  130. @close="changeMarkerModel2.loginName = ''"
  131. >
  132. <base-form
  133. ref="formRef"
  134. size="small"
  135. :rules="rules"
  136. :model="changeMarkerModel2"
  137. :items="changeMarkerItems2"
  138. ></base-form>
  139. <template #footer>
  140. <confirm-button around @confirm="onSubmitChangeMarker2" @cancel="visibleChangeMarker2 = false"></confirm-button>
  141. </template>
  142. </base-dialog>
  143. </template>
  144. <script setup lang="ts" name="EndCheck">
  145. /** 收尾检查 */
  146. import { reactive, ref, computed, watch } from 'vue'
  147. import { ElButton, ElMessage } from 'element-plus'
  148. import BaseForm from '@/components/element/BaseForm.vue'
  149. import BaseTable from '@/components/element/BaseTable.vue'
  150. import BaseDialog from '@/components/element/BaseDialog.vue'
  151. import ConfirmButton from '@/components/common/ConfirmButton.vue'
  152. import useFetch from '@/hooks/useFetch'
  153. import useOptions from '@/hooks/useOptions'
  154. import useVW from '@/hooks/useVW'
  155. import useForm from '@/hooks/useForm'
  156. import type { ExtractApiParams, ExtractMultipleApiResponse } from '@/api/api'
  157. import type { EpFormItem, EpTableColumn, EpFormRules } from 'global-type'
  158. const table1 = ref()
  159. const table2 = ref()
  160. const multipleSelection1 = ref<any[]>([])
  161. const multipleSelection2 = ref<any[]>([])
  162. const handleSelectionChange1 = (val: any[]) => {
  163. multipleSelection1.value = val
  164. }
  165. const handleSelectionChange2 = (val: any[]) => {
  166. multipleSelection2.value = val
  167. }
  168. /** 指定评卷员 */
  169. const visibleChangeMarker = ref<boolean>(false)
  170. const visibleChangeMarker2 = ref<boolean>(false)
  171. const changeMarkerModel = reactive({ loginName: '' })
  172. const changeMarkerModel2 = reactive({ loginName: '' })
  173. const { formRef, elFormRef } = useForm()
  174. const changeMarkerItems: EpFormItem[] = [{ label: '请输入指定评卷员账号', prop: 'loginName', slotType: 'input' }]
  175. const changeMarkerItems2: EpFormItem[] = [{ label: '请输入指定评卷员账号', prop: 'loginName', slotType: 'input' }]
  176. const rules: EpFormRules = {
  177. loginName: [{ required: true, message: '请输入指定评卷员账号' }],
  178. }
  179. const { mainQuestionList, groupListWithAll, onOptionInit, dataModel, changeModelValue } = useOptions([
  180. 'question',
  181. 'group',
  182. ])
  183. /** 搜索 */
  184. const model = reactive<ExtractApiParams<'unProcessProblemList'>>({
  185. markingGroupNumber: dataModel.group,
  186. questionMainNumber: dataModel.question,
  187. subjectCode: dataModel.subject || '',
  188. })
  189. const { fetch: getUnMarkPaperList, result: unMarkPaperList, loading: loading1 } = useFetch('unMarkPaperList')
  190. const {
  191. fetch: getUnMarkBackPaperList,
  192. result: unMarkBackPaperList,
  193. loading: loading4,
  194. } = useFetch('unMarkBackPaperList')
  195. const {
  196. fetch: getUnProcessProblemList,
  197. result: unProcessProblemList,
  198. loading: loading2,
  199. } = useFetch('unProcessProblemList')
  200. const {
  201. fetch: getUnProcessSimilarList,
  202. result: unProcessSimilarList,
  203. loading: loading3,
  204. } = useFetch('unProcessSimilarList')
  205. watch(dataModel, () => {
  206. model.subjectCode = dataModel.subject || ''
  207. model.questionMainNumber = dataModel.question
  208. model.markingGroupNumber = dataModel.group
  209. })
  210. const { defineColumn, _ } = useForm()
  211. const OneRow = defineColumn(_, 'row-1', { span: 6 })
  212. const btnRow = defineColumn(_, 'row-1', { span: 2 })
  213. const items = computed<EpFormItem[]>(() => [
  214. OneRow({
  215. label: '大题',
  216. prop: 'questionMainNumber',
  217. slotType: 'select',
  218. labelWidth: '60px',
  219. slot: {
  220. options: mainQuestionList.value,
  221. onChange: changeModelValue('question'),
  222. disabled: true,
  223. },
  224. }),
  225. OneRow({
  226. label: '小组',
  227. prop: 'markingGroupNumber',
  228. slotType: 'select',
  229. labelWidth: '60px',
  230. slot: {
  231. options: groupListWithAll.value,
  232. onChange: changeModelValue('group'),
  233. },
  234. }),
  235. btnRow({
  236. slotName: 'button',
  237. labelWidth: '20px',
  238. }),
  239. ])
  240. /** 未评卷 table */
  241. const columns1: EpTableColumn[] = [
  242. { type: 'selection', width: 55 },
  243. {
  244. label: '评卷员',
  245. prop: 'markerName',
  246. formatter(row) {
  247. return `${row.loginName}-${row.markerName}`
  248. },
  249. },
  250. { label: '密号', prop: 'secretNumber' },
  251. { label: '大题', prop: 'questionMainName' },
  252. ]
  253. /** 未处理问题卷table */
  254. const columns2: EpTableColumn[] = [
  255. { label: '密号', prop: 'secretNumber' },
  256. { label: '大题', prop: 'questionMainName' },
  257. ]
  258. /** 未处理雷同卷table */
  259. const columns3: EpTableColumn[] = [
  260. { label: '密号', prop: 'secretNumber' },
  261. { label: '雷同密号', prop: 'sameSecretNumber' },
  262. { label: '大题', prop: 'questionMainName' },
  263. ]
  264. /** 开始检查 */
  265. const onStartCheck = () => {
  266. // getUnMarkPaperList({ pageNumber: 1, pageSize: 20, ...model })
  267. getUnMarkPaperList({ pageNumber: 1, pageSize: 999999, ...model })
  268. // getUnMarkBackPaperList({ pageNumber: 1, pageSize: 20, ...model })
  269. getUnMarkBackPaperList({ pageNumber: 1, pageSize: 999999, ...model })
  270. getUnProcessProblemList(model)
  271. getUnProcessSimilarList(model)
  272. }
  273. const currentTask = ref<ExtractMultipleApiResponse<'unMarkPaperList'>>()
  274. const currentTask2 = ref<ExtractMultipleApiResponse<'unMarkPaperList'>>()
  275. const onCheckTask = (row: ExtractMultipleApiResponse<'unMarkPaperList'>) => {
  276. currentTask.value = row
  277. }
  278. const onCheckTask2 = (row: ExtractMultipleApiResponse<'unMarkPaperList'>) => {
  279. currentTask2.value = row
  280. }
  281. /** 任务指定评卷员 */
  282. const onTaskChangeMarker = () => {
  283. visibleChangeMarker.value = true
  284. }
  285. const onTaskChangeMarker2 = () => {
  286. visibleChangeMarker2.value = true
  287. }
  288. const onSubmitChangeMarker = async () => {
  289. try {
  290. // if (!currentTask.value) {
  291. // return ElMessage.error('点击表格行选择评卷任务')
  292. // }
  293. const valid = await elFormRef?.value?.validate()
  294. if (valid) {
  295. if (multipleSelection1.value?.find((item: any) => item.loginName == changeMarkerModel.loginName)) {
  296. return ElMessage.error('任务指定不可指定给原评卷人')
  297. }
  298. await useFetch('changeTaskMarker').fetch({
  299. // taskId: currentTask.value.taskId,
  300. taskIds: multipleSelection1.value.map((item: any) => item.taskId),
  301. loginName: changeMarkerModel.loginName,
  302. })
  303. visibleChangeMarker.value = false
  304. onStartCheck()
  305. }
  306. } catch (error) {
  307. console.error(error)
  308. }
  309. }
  310. const onSubmitChangeMarker2 = async () => {
  311. try {
  312. // if (!currentTask2.value) {
  313. // return ElMessage.error('点击表格行选择评卷任务')
  314. // }
  315. const valid = await elFormRef?.value?.validate()
  316. if (valid) {
  317. if (multipleSelection2.value?.find((item: any) => item.loginName == changeMarkerModel2.loginName)) {
  318. return ElMessage.error('任务指定不可指定给原评卷人')
  319. }
  320. await useFetch('changeBackTaskMarker').fetch({
  321. // taskId: currentTask2.value.taskId,
  322. taskIds: multipleSelection2.value.map((item: any) => item.taskId),
  323. loginName: changeMarkerModel2.loginName,
  324. })
  325. visibleChangeMarker2.value = false
  326. onStartCheck()
  327. }
  328. } catch (error) {
  329. console.error(error)
  330. }
  331. }
  332. onOptionInit(onStartCheck)
  333. </script>
  334. <style scoped lang="scss">
  335. .table-wrap {
  336. height: calc(100vh - 280px);
  337. overflow: auto;
  338. }
  339. .table-title {
  340. .label {
  341. font-size: $SmallFont;
  342. color: $RegularFontColor;
  343. }
  344. .data-count {
  345. padding: 4px 10px;
  346. margin: 0 12px;
  347. border: $OnePixelLine;
  348. border-radius: 4px;
  349. font-size: $MediumFont;
  350. color: $NormalColor;
  351. }
  352. }
  353. </style>