index.vue 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. <template>
  2. <div class="full">
  3. <div class="p-l-base p-t-medium-base fill-blank">
  4. <base-form size="small" :label-width="useVW(66)" :model="model" :items="items">
  5. <template #form-item-search>
  6. <el-button :loading="loading" type="primary" @click="onSearch">查询</el-button>
  7. </template>
  8. </base-form>
  9. </div>
  10. <div class="p-base flex justify-between">
  11. <el-card class="flex-1" shadow="never">
  12. <base-table
  13. :columns="columns1"
  14. :data="selfCheckAnalysisList"
  15. highlight-current-row
  16. @current-change="onCheckSelfCheckAnalysis"
  17. @row-dblclick="onSelfCheckAnalysisDBClick"
  18. ></base-table>
  19. </el-card>
  20. <el-card class="flex-1 m-l-base m-r-base center-card" shadow="never">
  21. <base-table
  22. :columns="columns2"
  23. highlight-current-row
  24. :data="selfCheckAnalysisDiffList"
  25. @current-change="onCheckSelfCheckAnalysisDiff"
  26. ></base-table>
  27. </el-card>
  28. <el-card class="flex-1" shadow="never">
  29. <base-table :columns="columns3" :data="papers" @row-dblclick="onPaperDBClick"></base-table>
  30. </el-card>
  31. </div>
  32. </div>
  33. </template>
  34. <script setup lang="ts" name="QualitySelfCheck">
  35. /** 自查一致性分析 */
  36. import { reactive, watch, computed, ref } from 'vue'
  37. import { useRouter } from 'vue-router'
  38. import { ElButton, ElCard } from 'element-plus'
  39. import { omit } from 'lodash-es'
  40. import BaseForm from '@/components/element/BaseForm.vue'
  41. import BaseTable from '@/components/element/BaseTable.vue'
  42. import useFetch from '@/hooks/useFetch'
  43. import useForm from '@/hooks/useForm'
  44. import useVW from '@/hooks/useVW'
  45. import useOptions from '@/hooks/useOptions'
  46. import useTableCheck from '@/hooks/useTableCheck'
  47. import type { ExtractApiParams, ExtractApiResponse } from '@/api/api'
  48. import type { EpFormItem, EpTableColumn } from 'global-type'
  49. const { push } = useRouter()
  50. type FormModel = Omit<ExtractApiParams<'selfCheckAnalysis'>, 'startTime' | 'endTime'>
  51. const { subjectList, mainQuestionList, groupListWithAll, dataModel, onOptionInit, changeModelValue } = useOptions([
  52. 'subject',
  53. 'question',
  54. 'group',
  55. ])
  56. const model = reactive<FormModel & { time: string }>({
  57. time: '',
  58. subjectCode: dataModel.subject || '',
  59. questionMainNumber: dataModel.question,
  60. markingGroupNumber: dataModel.group,
  61. })
  62. watch(dataModel, () => {
  63. model.subjectCode = dataModel.subject || ''
  64. model.questionMainNumber = dataModel.question
  65. model.markingGroupNumber = dataModel.group
  66. })
  67. const { defineColumn, _ } = useForm()
  68. const OneRowSpan4 = defineColumn(_, 'row-1', { span: 4 })
  69. const OneRowSpan6 = defineColumn(_, 'row-1', { span: 6 })
  70. const items = computed<EpFormItem[]>(() => {
  71. return [
  72. OneRowSpan4({
  73. label: '科目',
  74. slotType: 'select',
  75. prop: 'subjectCode',
  76. labelWidth: useVW(52),
  77. slot: { options: subjectList.value, onChange: changeModelValue('subject'), disabled: true },
  78. }),
  79. OneRowSpan4({
  80. label: '大题',
  81. slotType: 'select',
  82. prop: 'questionMainNumber',
  83. slot: { options: mainQuestionList.value, onChange: changeModelValue('question'), disabled: true },
  84. }),
  85. OneRowSpan4({
  86. label: '小组',
  87. slotType: 'select',
  88. prop: 'markingGroupNumber',
  89. slot: { options: groupListWithAll.value, onChange: changeModelValue('group') },
  90. }),
  91. OneRowSpan6({
  92. label: '时间',
  93. slotType: 'dateTime',
  94. prop: 'time',
  95. slot: {
  96. type: 'datetimerange',
  97. valueFormat: 'YYYYMMDDHHmmss',
  98. },
  99. }),
  100. OneRowSpan4({ slotName: 'search' }),
  101. ]
  102. })
  103. const { fetch: selfCheckAnalysis, result: selfCheckAnalysisList, loading } = useFetch('selfCheckAnalysis')
  104. const { onCurrentChange: onCheckSelfCheckAnalysis, current: currentSelfCheckAnalysis } =
  105. useTableCheck(selfCheckAnalysisList)
  106. const columns1: EpTableColumn<ExtractArrayValue<ExtractApiResponse<'selfCheckAnalysis'>>>[] = [
  107. { label: '序号', type: 'index', width: 100 },
  108. { label: '评卷员', prop: 'markerName' },
  109. { label: '自查份数', prop: 'checkCount' },
  110. { label: '平均离差', prop: 'avgDiff' },
  111. ]
  112. const {
  113. fetch: getSelfCheckAnalysisDiffList,
  114. result: selfCheckAnalysisDiffList,
  115. reset,
  116. } = useFetch('selfCheckAnalysisDiffList')
  117. const { onCurrentChange: onCheckSelfCheckAnalysisDiff, current: currentSelfCheckAnalysisDiffItem } =
  118. useTableCheck(selfCheckAnalysisDiffList)
  119. const columns2: EpTableColumn<ExtractArrayValue<ExtractApiResponse<'selfCheckAnalysisDiffList'>>>[] = [
  120. { label: '离差值', prop: 'diff' },
  121. {
  122. label: '离差个数',
  123. formatter(row) {
  124. return `${row.papers?.length}`
  125. },
  126. },
  127. ]
  128. const papers = computed(() => {
  129. return currentSelfCheckAnalysisDiffItem?.value?.papers || []
  130. })
  131. const columns3: EpTableColumn[] = [
  132. { label: '密号', prop: 'secretNumber' },
  133. { label: '分数', prop: 'markScore' },
  134. { label: '上次分数', prop: 'lastMarkScore' },
  135. { label: '评卷时间', prop: 'markTime' },
  136. ]
  137. watch(currentSelfCheckAnalysis, () => {
  138. reset()
  139. if (currentSelfCheckAnalysis.value) {
  140. getSelfCheckAnalysisDiffList({
  141. subjectCode: model.subjectCode,
  142. questionMainNumber: model.questionMainNumber,
  143. markerId: currentSelfCheckAnalysis.value.markerId,
  144. })
  145. }
  146. })
  147. function onSearch() {
  148. selfCheckAnalysis({ ...omit(model, 'time'), startTime: model.time[0], endTime: model.time[1] })
  149. }
  150. /** 自查一致性列表双击 */
  151. const onSelfCheckAnalysisDBClick = () => {
  152. push({
  153. name: 'QualitySelfCheckDetail',
  154. query: {
  155. ...omit(model, 'time'),
  156. startTime: model.time[0],
  157. endTime: model.time[1],
  158. },
  159. })
  160. }
  161. /** 试卷列表双击 */
  162. const onPaperDBClick = (row: ExtractArrayValue<typeof papers.value>) => {
  163. push({
  164. name: 'QualitySelfCheckDetail',
  165. query: {
  166. ...omit(model, 'time'),
  167. startTime: model.time[0],
  168. endTime: model.time[1],
  169. taskId: row.taskId,
  170. },
  171. })
  172. }
  173. onOptionInit(onSearch)
  174. </script>
  175. <style scoped lang="scss">
  176. .center-card {
  177. min-width: 260px;
  178. max-width: 260px;
  179. }
  180. </style>