123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203 |
- <template>
- <div class="full">
- <div class="p-l-base p-t-medium-base fill-blank">
- <base-form size="small" :label-width="useVW(66)" :model="model" :items="items">
- <template #form-item-search>
- <el-button :loading="loading" type="primary" @click="onSearch">查询</el-button>
- </template>
- </base-form>
- </div>
- <div class="p-base flex justify-between">
- <el-card class="flex-1" shadow="never">
- <base-table
- :columns="columns1"
- :data="selfCheckAnalysisList"
- highlight-current-row
- @current-change="onCheckSelfCheckAnalysis"
- @row-dblclick="onSelfCheckAnalysisDBClick"
- ></base-table>
- </el-card>
- <el-card class="flex-1 m-l-base m-r-base center-card" shadow="never">
- <base-table
- :columns="columns2"
- highlight-current-row
- :data="selfCheckAnalysisDiffList"
- @current-change="onCheckSelfCheckAnalysisDiff"
- ></base-table>
- </el-card>
- <el-card class="flex-1" shadow="never">
- <base-table :columns="columns3" :data="papers" @row-dblclick="onPaperDBClick"></base-table>
- </el-card>
- </div>
- </div>
- </template>
- <script setup lang="ts" name="QualitySelfCheck">
- /** 自查一致性分析 */
- import { reactive, watch, computed, ref } from 'vue'
- import { useRouter } from 'vue-router'
- import { ElButton, ElCard } from 'element-plus'
- import { omit } from 'lodash-es'
- import BaseForm from '@/components/element/BaseForm.vue'
- import BaseTable from '@/components/element/BaseTable.vue'
- import useFetch from '@/hooks/useFetch'
- import useForm from '@/hooks/useForm'
- import useVW from '@/hooks/useVW'
- import useOptions from '@/hooks/useOptions'
- import useTableCheck from '@/hooks/useTableCheck'
- import type { ExtractApiParams, ExtractApiResponse } from '@/api/api'
- import type { EpFormItem, EpTableColumn } from 'global-type'
- const { push } = useRouter()
- type FormModel = Omit<ExtractApiParams<'selfCheckAnalysis'>, 'startTime' | 'endTime'>
- const { subjectList, mainQuestionList, groupListWithAll, dataModel, onOptionInit, changeModelValue } = useOptions([
- 'subject',
- 'question',
- 'group',
- ])
- const model = reactive<FormModel & { time: string }>({
- time: '',
- subjectCode: dataModel.subject || '',
- questionMainNumber: dataModel.question,
- markingGroupNumber: dataModel.group,
- })
- watch(dataModel, () => {
- model.subjectCode = dataModel.subject || ''
- model.questionMainNumber = dataModel.question
- model.markingGroupNumber = dataModel.group
- })
- const { defineColumn, _ } = useForm()
- const OneRowSpan4 = defineColumn(_, 'row-1', { span: 4 })
- const OneRowSpan6 = defineColumn(_, 'row-1', { span: 6 })
- const items = computed<EpFormItem[]>(() => {
- return [
- OneRowSpan4({
- label: '科目',
- slotType: 'select',
- prop: 'subjectCode',
- labelWidth: useVW(52),
- slot: { options: subjectList.value, onChange: changeModelValue('subject'), disabled: true },
- }),
- OneRowSpan4({
- label: '大题',
- slotType: 'select',
- prop: 'questionMainNumber',
- slot: { options: mainQuestionList.value, onChange: changeModelValue('question'), disabled: true },
- }),
- OneRowSpan4({
- label: '小组',
- slotType: 'select',
- prop: 'markingGroupNumber',
- slot: { options: groupListWithAll.value, onChange: changeModelValue('group') },
- }),
- OneRowSpan6({
- label: '时间',
- slotType: 'dateTime',
- prop: 'time',
- slot: {
- type: 'datetimerange',
- valueFormat: 'YYYYMMDDHHmmss',
- },
- }),
- OneRowSpan4({ slotName: 'search' }),
- ]
- })
- const { fetch: selfCheckAnalysis, result: selfCheckAnalysisList, loading } = useFetch('selfCheckAnalysis')
- const { onCurrentChange: onCheckSelfCheckAnalysis, current: currentSelfCheckAnalysis } =
- useTableCheck(selfCheckAnalysisList)
- const columns1: EpTableColumn<ExtractArrayValue<ExtractApiResponse<'selfCheckAnalysis'>>>[] = [
- { label: '序号', type: 'index', width: 100 },
- { label: '评卷员', prop: 'markerName' },
- { label: '自查份数', prop: 'checkCount' },
- { label: '平均离差', prop: 'avgDiff' },
- ]
- const {
- fetch: getSelfCheckAnalysisDiffList,
- result: selfCheckAnalysisDiffList,
- reset,
- } = useFetch('selfCheckAnalysisDiffList')
- const { onCurrentChange: onCheckSelfCheckAnalysisDiff, current: currentSelfCheckAnalysisDiffItem } =
- useTableCheck(selfCheckAnalysisDiffList)
- const columns2: EpTableColumn<ExtractArrayValue<ExtractApiResponse<'selfCheckAnalysisDiffList'>>>[] = [
- { label: '离差值', prop: 'diff' },
- {
- label: '离差个数',
- formatter(row) {
- return `${row.papers?.length}`
- },
- },
- ]
- const papers = computed(() => {
- return currentSelfCheckAnalysisDiffItem?.value?.papers || []
- })
- const columns3: EpTableColumn[] = [
- { label: '密号', prop: 'secretNumber' },
- { label: '分数', prop: 'markScore' },
- { label: '上次分数', prop: 'lastMarkScore' },
- { label: '评卷时间', prop: 'markTime' },
- ]
- watch(currentSelfCheckAnalysis, () => {
- reset()
- if (currentSelfCheckAnalysis.value) {
- getSelfCheckAnalysisDiffList({
- subjectCode: model.subjectCode,
- questionMainNumber: model.questionMainNumber,
- markerId: currentSelfCheckAnalysis.value.markerId,
- })
- }
- })
- function onSearch() {
- selfCheckAnalysis({ ...omit(model, 'time'), startTime: model.time[0], endTime: model.time[1] })
- }
- /** 自查一致性列表双击 */
- const onSelfCheckAnalysisDBClick = () => {
- push({
- name: 'QualitySelfCheckDetail',
- query: {
- ...omit(model, 'time'),
- startTime: model.time[0],
- endTime: model.time[1],
- },
- })
- }
- /** 试卷列表双击 */
- const onPaperDBClick = (row: ExtractArrayValue<typeof papers.value>) => {
- push({
- name: 'QualitySelfCheckDetail',
- query: {
- ...omit(model, 'time'),
- startTime: model.time[0],
- endTime: model.time[1],
- taskId: row.taskId,
- },
- })
- }
- onOptionInit(onSearch)
- </script>
- <style scoped lang="scss">
- .center-card {
- min-width: 260px;
- max-width: 260px;
- }
- </style>
|