123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387 |
- <script setup lang="ts">
- import { ref, getCurrentInstance, reactive } from "vue";
- import { useRouter } from "vue-router";
- import request, { download } from '~/utils/request';
- import { pick } from 'lodash-es';
- import { ElMessage } from 'element-plus'
- import type { FormInstance, FormRules } from 'element-plus'
- import type { AxiosRequestConfig } from 'axios'
- // #region (constant)
- const TABLE_KEY = 'xjk_id'
- const URL_CUT = '/xdjx/jsrkgl_kcgl'
- const URL_CUT_REF = ref(URL_CUT)
- const URL_SUBMIT_KEY = URL_CUT.split('/').join('_').slice(1)
- const instance = getCurrentInstance()
- const router = useRouter()
- // #endregion
- // #region (variable)
- const loading_table = ref(true)
- let whichDialogSubmit: 'add' | 'edit'
- // #endregion
- // #region (type)
- type TYPE_TABLE_FIELD = {
- [TABLE_KEY]: string;
- 'xjk_kcmc': string; // 课程名称
- 'grade_id': string; // 年级编号
- 'grade_name': string; // 年级名称
- 'class_id': string; // 班级编号
- 'class_name': string; // 班级名称
- 'subject_id': string; // 学科编号
- 'subject_name': string; // 学科名称
- 'xjk_rkjs': string; // 任课教师
- 'xjk_rkjs_json': string; // 任课教师JSON
- 'xjj_zgbh':string // 职工编号
- }
- // #endregion
- // #region (props)
- // #endregion
- // #region (query row)
- const queryForm_Data = ref<Partial<TYPE_TABLE_FIELD> & { keyword?: string }>({})
- const handleQueryFormBtn_search = () => {
- queryApi()
- }
- const handleQueryFormBtn_clear = () => {
- queryForm_Data.value = {}
- }
- // #endregion
- // #region (table selection)
- const multipleSelection = ref<TYPE_TABLE_FIELD[]>([])
- const handleSelectionChange = (val: TYPE_TABLE_FIELD[]) => {
- multipleSelection.value = val
- }
- // #endregion
- // #region (table row)
- const handleTableRowBtn_import = async ({ file }: { file: File }) => {
- const res = await API_MAP['import']({ file })
- if (res.code === '1') {
- queryApi()
- ElMessage.success(res.msg)
- }
- }
- const handleTableRowBtn_export = () => {
- exportApi()
- }
- const handleTableRowBtn_add = () => {
- whichDialogSubmit = 'add'
- dialogForm_Data.value = {}
- dialogVisible_addOrEdit.value = true
- }
- const handleTableRowBtn_delete = async () => {
- await deleteApi(multipleSelection.value.map((item: TYPE_TABLE_FIELD) => item[TABLE_KEY]))
- queryApi()
- }
- // #endregion
- // #region (table body)
- const tableData = ref<TYPE_TABLE_FIELD[]>([])
- const DetailName = '-JSRKGL-KCGL'
- const DetailParam = 'aid'
- const handleTableColBtn_edit = async (scope: { row: TYPE_TABLE_FIELD }) => {
- whichDialogSubmit = 'edit'
- const res = await detailApi(scope.row[TABLE_KEY])
- dialogForm_Data.value = (res.data.one_info)
- dialogVisible_addOrEdit.value = true
- }
- const handleTableColBtn_audit = (scope: { row: TYPE_TABLE_FIELD }) => {
- whichDialogSubmit = 'edit'
- dialogForm_Data.value = pick(scope.row, [`${TABLE_KEY}`, ...Object.keys(dialogForm_Rules_audit)])
- dialogVisible_audit.value = true
- }
- const handleTableColBtn_detail = (scope: { row: TYPE_TABLE_FIELD }) => {
- router.push({ name: DetailName, params: { [DetailParam]: scope.row[TABLE_KEY] } })
- }
- const handleTableColBtn_delete = async (scope: { row: TYPE_TABLE_FIELD }) => {
- await deleteApi(scope.row[TABLE_KEY])
- queryApi()
- }
- // #endregion
- // #region (pagination)
- const total = ref(0)
- const limit = ref(10)
- const currentPage = ref(1)
- function handleCurrentChange() {
- queryApi()
- }
- // #endregion
- // #region (dialog base)
- const dialogForm_Data = ref<Partial<TYPE_TABLE_FIELD> & { keyword?: string }>({})
- const handleDialogFormBtn_submit = async (formRefKey: string,extendData?:Partial<TYPE_TABLE_FIELD>) => {
- const isValid = await (instance?.refs[formRefKey] as FormInstance).validate((valid: boolean) => valid)
- if (isValid) {
- await API_MAP[whichDialogSubmit](<TYPE_TABLE_FIELD>({...dialogForm_Data.value,...extendData}))
- handleDialogFormBtn_cancel()
- queryApi()
- }
- }
- const handleDialogFormBtn_cancel = (formRefKey?: string) => {
- dialogVisible_addOrEdit.value = false
- dialogVisible_audit.value = false
- }
- // #endregion
- // #region (dialog add/edit)
- const dialogVisible_addOrEdit = ref<boolean>(false)
- const dialogForm_Ref_addOrEdit = ref<FormInstance>()
- const dialogForm_Rules_addOrEdit = reactive({
- 'xjk_kcmc': { required: true, message: '课程名称不能为空', trigger: 'submit' },
- // 'grade_id': { required: true, message: '年级编号不能为空', trigger: 'submit' },
- // 'grade_name': { required: true, message: '年级名称不能为空', trigger: 'submit' },
- 'class_id': { required: true, message: '班级编号不能为空', trigger: 'submit' },
- // 'class_name': { required: true, message: '班级名称不能为空', trigger: 'submit' },
- 'subject_id': { required: true, message: '学科编号不能为空', trigger: 'submit' },
- 'subject_name': { required: true, message: '学科名称不能为空', trigger: 'submit' },
- 'xjk_rkjs': { required: true, message: '任课教师不能为空', trigger: 'submit' },
- 'xjk_rkjs_json': { required: true, message: '任课教师JSON不能为空', trigger: 'submit' },
- })
- // #endregion
- // #region (dialog audit)
- const dialogVisible_audit = ref<boolean>(false)
- const dialogForm_Field_audit = reactive<{
- FLAG: keyof TYPE_TABLE_FIELD,
- REASON?: keyof TYPE_TABLE_FIELD
- }>({
- FLAG: 'xjk_id',
- REASON: 'xjk_id'
- })
- const dialogForm_Ref_audit = ref<FormInstance>()
- const dialogForm_Rules_audit = reactive<FormRules>({
- 'xjk_kcmc': { required: true, message: '课程名称不能为空', trigger: 'submit' },
- 'grade_id': { required: true, message: '年级编号不能为空', trigger: 'submit' },
- 'grade_name': { required: true, message: '年级名称不能为空', trigger: 'submit' },
- 'class_id': { required: true, message: '班级编号不能为空', trigger: 'submit' },
- 'class_name': { required: true, message: '班级名称不能为空', trigger: 'submit' },
- 'subject_id': { required: true, message: '学科编号不能为空', trigger: 'submit' },
- 'subject_name': { required: true, message: '学科名称不能为空', trigger: 'submit' },
- 'xjk_rkjs': { required: true, message: '任课教师不能为空', trigger: 'submit' },
- 'xjk_rkjs_json': { required: true, message: '任课教师JSON不能为空', trigger: 'submit' },
- })
- // #endregion
- // #region (request api):
- function queryApi() {
- loading_table.value = true
- return request({
- url: URL_CUT + '/index',
- data: {
- ...queryForm_Data.value,
- limit: limit.value,
- page: currentPage.value
- }
- }).then((response: { data: { total_rows: string, page_data: TYPE_TABLE_FIELD[] } }) => {
- const { data } = response
- total.value = parseInt(data.total_rows)
- tableData.value = data.page_data
- return response
- }).then(() => {
- loading_table.value = false
- })
- }
- function addApi(data: TYPE_TABLE_FIELD) {
- return request({
- url: URL_CUT + '/add',
- data: {
- [URL_SUBMIT_KEY]: data,
- }
- })
- }
- function editApi(data: Partial<TYPE_TABLE_FIELD>) {
- return request({
- url: URL_CUT + '/edit',
- data: {
- [TABLE_KEY]: data[TABLE_KEY],
- [URL_SUBMIT_KEY]: pick(data, ['xjk_kcmc', 'grade_id', 'grade_name', 'class_id', 'class_name', 'subject_id', 'subject_name', 'xjk_rkjs', 'xjk_rkjs_json','xjj_zgbh']),
- }
- })
- }
- function deleteApi(id: string | string[]) {
- return request({
- url: URL_CUT + '/delete',
- data: {
- [TABLE_KEY]: id,
- }
- })
- }
- function detailApi(id: string) {
- return request({
- url: URL_CUT + '/detail',
- data: {
- [TABLE_KEY]: id,
- }
- })
- }
- function importApi(data: { file: File }) {
- return request({
- $type: 'import',
- url: URL_CUT + '/import',
- data
- } as AxiosRequestConfig)
- }
- function exportApi() {
- return download(URL_CUT + '/index', queryForm_Data.value)
- }
- const API_MAP = {
- query: queryApi,
- add: addApi,
- edit: editApi,
- delete: deleteApi,
- detail: detailApi,
- import: importApi,
- export: exportApi,
- }
- // #endregion
- // #region (page init)
- function init() {
- queryApi()
- }
- init()
- // #endregion
- </script>
- <template>
- <div class="card flex-grow flex flex-col">
- <el-form inline :model="queryForm_Data">
- <el-form-item label="关键字">
- <el-input v-model="queryForm_Data.keyword" clearable />
- </el-form-item>
- <!-- <el-form-item label="课程名称"><el-input v-model="queryForm_Data.xjk_kcmc" clearable /></el-form-item> -->
- <!-- <el-form-item label="年级编号"><el-input v-model="queryForm_Data.grade_id" clearable /></el-form-item> -->
- <!-- <el-form-item label="年级名称"><el-input v-model="queryForm_Data.grade_name" clearable /></el-form-item> -->
- <!-- <el-form-item label="班级编号"><el-input v-model="queryForm_Data.class_id" clearable /></el-form-item> -->
- <!-- <el-form-item label="班级名称"><el-input v-model="queryForm_Data.class_name" clearable /></el-form-item> -->
- <!-- <el-form-item label="学科编号"><el-input v-model="queryForm_Data.subject_id" clearable /></el-form-item> -->
- <!-- <el-form-item label="学科名称"><el-input v-model="queryForm_Data.subject_name" clearable /></el-form-item> -->
- <!-- <el-form-item label="任课教师"><el-input v-model="queryForm_Data.xjk_rkjs" clearable /></el-form-item> -->
- <!-- <el-form-item label="任课教师JSON"><el-input v-model="queryForm_Data.xjk_rkjs_json" type="textarea" /></el-form-item> -->
- <el-form-item>
- <el-button @click="handleQueryFormBtn_search" type="primary">搜索</el-button>
- <el-button @click="handleQueryFormBtn_clear" type="warning">清空</el-button>
- </el-form-item>
- </el-form>
- <div class="divider"></div>
- <div>
- <import-button :url="URL_CUT_REF"></import-button>
- <!-- <el-button @click="handleTableRowBtn_export" type="success">导出</el-button> -->
- <el-button @click="handleTableRowBtn_add" type="primary">新增</el-button>
- <!-- <el-button @click="handleTableRowBtn_delete" type="danger">删除</el-button> -->
- </div>
- <div class="divider"></div>
- <div class="flex-auto">
- <el-table :data="tableData" @selection-change="handleSelectionChange" v-loading="loading_table"
- element-loading-background="#ffffff70">
- <el-table-column type="selection"></el-table-column><el-table-column type="index" label="序号" width="60" :index="(i: number) => (currentPage - 1) * limit + i + 1" />
- <el-table-column prop="xjk_kcmc" label="课程名称" width="auto" show-overflow-tooltip></el-table-column>
- <!-- <el-table-column prop="grade_id" label="年级编号" width="auto" show-overflow-tooltip></el-table-column> -->
- <el-table-column prop="grade_name" label="年级名称" width="auto" show-overflow-tooltip></el-table-column>
- <!-- <el-table-column prop="class_id" label="班级编号" width="auto" show-overflow-tooltip></el-table-column> -->
- <el-table-column prop="class_name" label="班级名称" width="auto" show-overflow-tooltip></el-table-column>
- <!-- <el-table-column prop="subject_id" label="学科编号" width="auto" show-overflow-tooltip></el-table-column> -->
- <el-table-column prop="subject_name" label="学科名称" width="auto" show-overflow-tooltip></el-table-column>
- <!-- <el-table-column prop="xjk_rkjs" label="任课教师" width="auto" show-overflow-tooltip></el-table-column> -->
- <el-table-column prop="xjk_rkjs_json" label="任课教师" width="auto" show-overflow-tooltip></el-table-column>
- <el-table-column label="操作" fixed="right">
- <template #default="scope">
- <el-button link :auto-insert-space="false" @click="handleTableColBtn_edit(scope)" type="primary" >编辑</el-button>
- <!-- <el-button link :auto-insert-space="false" @click="handleTableColBtn_audit(scope)" type="primary" >审核</el-button> -->
- <!-- <el-button link :auto-insert-space="false" @click="handleTableColBtn_detail(scope)" type="primary" >详情</el-button> -->
- <el-button link :auto-insert-space="false" @click="handleTableColBtn_delete(scope)" type="primary" >删除
- </el-button>
- </template>
- </el-table-column>
- </el-table>
- </div>
- <div class="flex justify-end mt-10 py-4">
- <el-pagination :page-size="limit" v-model:current-page="currentPage" @current-change="handleCurrentChange"
- background layout="total, prev, pager, next" :total="total" />
- </div>
- </div>
- <el-dialog v-model="dialogVisible_addOrEdit" append-to-body destroy-on-close>
- <el-form :model="dialogForm_Data" ref="dialogForm_Ref_addOrEdit" :rules="dialogForm_Rules_addOrEdit"
- label-width="120px">
- <el-form-item label="课程名称" prop="xjk_kcmc">
- <el-input v-model="dialogForm_Data.xjk_kcmc" clearable />
- </el-form-item>
- <!-- <el-form-item label="年级编号" prop="grade_id">
- <el-input v-model="dialogForm_Data.grade_id" clearable />
- </el-form-item> -->
- <!-- <el-form-item label="年级名称" prop="grade_name">
- <el-input v-model="dialogForm_Data.grade_name" clearable />
- </el-form-item> -->
- <!-- <el-form-item label="班级编号" prop="class_id">
- <el-input v-model="dialogForm_Data.class_id" clearable />
- </el-form-item> -->
- <el-form-item label="班级名称" prop="class_name">
- <!-- <el-input v-model="dialogForm_Data.class_name" clearable /> -->
- <remote-cascader-class v-model="dialogForm_Data.class_id" v-model:modelName="dialogForm_Data.class_name"
- v-model:gradeId="dialogForm_Data.grade_id" v-model:gradeName="dialogForm_Data.grade_name">
- </remote-cascader-class>
- </el-form-item>
- <!-- <el-form-item label="学科编号" prop="subject_id">
- <el-input v-model="dialogForm_Data.subject_id" clearable />
- </el-form-item> -->
- <el-form-item label="学科名称" prop="subject_name">
- <!-- <el-input v-model="dialogForm_Data.subject_name" clearable /> -->
- <remote-select to="subject" v-model="dialogForm_Data.subject_id" v-model:modelName="dialogForm_Data.subject_name"></remote-select>
- </el-form-item>
- <el-form-item label="任课教师" prop="xjk_rkjs">
- <!-- <el-input v-model="dialogForm_Data.xjk_rkjs" type="textarea" /> -->
- <remote-multi-select url="/xdbg/jzggl_jsgl/index" :fields="['xjj_zgbh','xjj_xm']" v-model="dialogForm_Data.xjk_rkjs" v-model:model-name="dialogForm_Data.xjk_rkjs_json" ></remote-multi-select>
- </el-form-item>
- <!-- <el-form-item label="任课教师JSON" prop="xjk_rkjs_json">
- <el-input v-model="dialogForm_Data.xjk_rkjs_json" type="textarea" />
- </el-form-item> -->
- <div class="flex justify-center">
- <el-button @click="handleDialogFormBtn_submit('dialogForm_Ref_addOrEdit')" type="primary">提交</el-button>
- <el-button @click="handleDialogFormBtn_cancel('dialogForm_Ref_addOrEdit')" type="default">取消</el-button>
- </div>
- </el-form>
- </el-dialog>
- <el-dialog v-model="dialogVisible_audit" append-to-body destroy-on-close>
- <el-form :model="dialogForm_Data" ref="dialogForm_Ref_audit" :rules="dialogForm_Rules_audit" label-width="120px">
- <el-form-item label="状态">
- <el-radio-group v-model="dialogForm_Data[dialogForm_Field_audit.FLAG]">
- <el-radio label="1">通过</el-radio>
- <el-radio label="2">未通过</el-radio>
- </el-radio-group>
- </el-form-item>
- <!-- <el-form-item label="原因" v-show="dialogForm_Data[dialogForm_Field_audit.FLAG] === '1'">
- <el-input type="textarea" v-model="dialogForm_Data[dialogForm_Field_audit.REASON]" :rows="5" />
- </el-form-item> -->
- <div class="flex justify-center">
- <el-button @click="handleDialogFormBtn_submit('dialogForm_Ref_audit')" type="primary">提交</el-button>
- <el-button @click="handleDialogFormBtn_cancel('dialogForm_Ref_audit')" type="default">取消</el-button>
- </div>
- </el-form>
- </el-dialog>
- </template>
|