Browse Source

新增发布中不能增删题目功能

admin_zwk
zhaowenkang 5 months ago
parent
commit
cb72dfbb1b
  1. 40
      work/src/api/index.js
  2. 22
      work/src/stores/user.js
  3. 12
      work/src/views/AddWork.vue
  4. 53
      work/src/views/HomeWork.vue
  5. 73
      work/src/views/UpdateWork.vue
  6. 36
      work/src/views/WorkDetail.vue

40
work/src/api/index.js

@ -29,7 +29,7 @@ const service = axios.create({
axios.interceptors.request.use(config => { axios.interceptors.request.use(config => {
const token = useTokenStore(); const token = useTokenStore();
if (token) { if (token) {
config.headers['token'] = `${token}`;
config.headers.token = `${token}`;
} }
return config; return config;
}, error => { }, error => {
@ -40,18 +40,44 @@ service.interceptors.request.use(config => {
const token = useTokenStore(); const token = useTokenStore();
if (token) { if (token) {
// 一般后端会约定一个请求头的字段名来接收token,常见的如 'Authorization',并要求按照一定格式传递,比如 'Bearer <token>',这里按照此格式添加,你需要根据后端实际要求调整 // 一般后端会约定一个请求头的字段名来接收token,常见的如 'Authorization',并要求按照一定格式传递,比如 'Bearer <token>',这里按照此格式添加,你需要根据后端实际要求调整
config.headers['token'] = `${token}`;
config.headers.token = `${token}`;
} }
return config; return config;
}, error => { }, error => {
return Promise.reject(error); return Promise.reject(error);
}); });
// Axios的响应拦截器
service.interceptors.response.use(resp => {
return resp.data;
}, error => {
// // Axios的响应拦截器
// service.interceptors.response.use(resp => {
// return resp.data;
// }, error => {
// return Promise.reject(error);
// });
//响应拦截器
service.interceptors.response.use(response => {
return response.data;
}, error =>{
if(error.code == "500"){
ElMessage.error("服务器错误!");
}
const response = error.response;
if(error.response && error.response.status == 403){
//提示一下权限不足
ElMessage.warning(response.data.message);
} else if(response && response.status == 401){
//提示一下未登录
ElMessage.warning(response.data.message);
//跳转登录页面
const curURL = router.currentRoute.value.path;
if(curURL.startsWith('/')){
router.push('/login')
} else{
router.push('/login');
}
console.log();
}
return Promise.reject(error); return Promise.reject(error);
});
})
export default service; export default service;

22
work/src/stores/user.js

@ -0,0 +1,22 @@
import {defineStore} from 'pinia';
/*
使用pinia进行状态管理,不能刷新页面
Vue中将一些全局的数据保存在某个位置Vue项目的任何一个组件中都可以访问它
*/
export const useUserStore = defineStore('user',{
//状态管理
state:()=>({
user: JSON.parse(sessionStorage.getItem('user')),
}),
actions:{
changeUser(user){
this.user = user;
//长久保存token
sessionStorage.setItem('user', JSON.stringify(user)); //sessionStorage中只能保存字符串
},
clear(){
this.user = null;
sessionStorage.removeItem('user');
}
}
});

12
work/src/views/AddWork.vue

@ -95,6 +95,8 @@ import { ElMessage } from 'element-plus'
import LoginApi from '../api/LoginApi'; import LoginApi from '../api/LoginApi';
import axios from 'axios'; import axios from 'axios';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
import { useTokenStore } from '../stores/token';
import { useUserStore } from '../stores/user';
const router = useRouter(); const router = useRouter();
@ -288,8 +290,14 @@ onMounted(() => {
isHovered.value = Array(questions.value.length).fill(false); isHovered.value = Array(questions.value.length).fill(false);
}); });
//退
const logout = () => {
//退
function logout(){
//
const tokenStore = useTokenStore();
const userStore = useUserStore();
tokenStore.clear();
userStore.clear();
LoginApi.logout().then(res => { LoginApi.logout().then(res => {
console.log(res) console.log(res)
}) })

53
work/src/views/HomeWork.vue

@ -90,6 +90,9 @@ import ClassListApi from '../api/ClassListApi';
import axios from 'axios'; import axios from 'axios';
import { useRouter } from 'vue-router'; import { useRouter } from 'vue-router';
import LoginApi from '../api/LoginApi'; import LoginApi from '../api/LoginApi';
import { useTokenStore } from '../stores/token';
import { useUserStore } from '../stores/user';
const router = useRouter(); const router = useRouter();
const assignments = ref([]); const assignments = ref([]);
@ -159,22 +162,42 @@ const editAssignment = async (row) => {
console.log('获取数据出错:', error) console.log('获取数据出错:', error)
} }
}; };
// 退
const logout = () => {
// // 退
// const logout = () => {
// LoginApi.logout().then(res => {
// console.log(res);
// // axiostoken
// // axios.interceptors.request.eject(axios.interceptors.request.handlers.find(
// // handler => handler.fulfilled && handler.fulfilled.toString().includes('token')
// // ));
// config.headers['token'] = ` `;
// }).catch(err => {
// // 退
// ElMessage.error('退');
// }).finally(() => {
// //
// router.push('/');
// });
// }
// //退
// const logout = () => {
// LoginApi.logout().then(res => {
// console.log(res)
// })
// router.push('/')
// }
//退
function logout(){
//
const tokenStore = useTokenStore();
const userStore = useUserStore();
tokenStore.clear();
userStore.clear();
LoginApi.logout().then(res => { LoginApi.logout().then(res => {
console.log(res);
// axiostoken
// axios.interceptors.request.eject(axios.interceptors.request.handlers.find(
// handler => handler.fulfilled && handler.fulfilled.toString().includes('token')
// ));
config.headers['token'] = ` `;
}).catch(err => {
// 退
ElMessage.error('退出登录失败,请稍后重试');
}).finally(() => {
//
router.push('/');
});
console.log(res)
})
router.push('/')
} }
</script> </script>

73
work/src/views/UpdateWork.vue

@ -3,7 +3,7 @@
<el-container> <el-container>
<el-header class="header"> <el-header class="header">
<el-text class="header-text">抢点班作业后台管理</el-text> <el-text class="header-text">抢点班作业后台管理</el-text>
<el-button class="header-button" type="primary" text style="float: right;">退出登录</el-button>
<el-button class="header-button" type="primary" text style="float: right;" @click="logout">退出登录</el-button>
</el-header> </el-header>
<el-main class="main"> <el-main class="main">
<div class="main-title"> <div class="main-title">
@ -30,11 +30,12 @@
</el-form-item> </el-form-item>
<el-form-item label="关联文章"> <el-form-item label="关联文章">
<el-autocomplete v-model="articleTitle" :fetch-suggestions="queryArticleList" placeholder="请输入" <el-autocomplete v-model="articleTitle" :fetch-suggestions="queryArticleList" placeholder="请输入"
@select="handleSelectArticle" clearable/>
@select="handleSelectArticle" clearable />
</el-form-item> </el-form-item>
<el-form-item label="关联直播"> <el-form-item label="关联直播">
<el-select v-model="form.LiveId" placeholder="请选择" style="width: 100%" clearable @change="handleLiveChange">
<el-option v-for="item in live" :key="item.id" :label="item.name" :value="item.id"/>
<el-select v-model="form.LiveId" placeholder="请选择" style="width: 100%" clearable
@change="handleLiveChange">
<el-option v-for="item in live" :key="item.id" :label="item.name" :value="item.id" />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="选择类型"> <el-form-item label="选择类型">
@ -76,7 +77,7 @@
</div> </div>
</div> </div>
<div class="submit"> <div class="submit">
<el-button type="primary" :disabled="!form.Name||!form.picker" @click="onSubmit">确认</el-button>
<el-button type="primary" :disabled="!form.Name || !form.picker" @click="onSubmit">确认</el-button>
</div> </div>
</el-form> </el-form>
</div> </div>
@ -88,12 +89,16 @@
<script lang="ts" setup> <script lang="ts" setup>
import { ref, onMounted, computed } from 'vue' import { ref, onMounted, computed } from 'vue'
import { useRouter,useRoute } from 'vue-router';
import { useRouter, useRoute } from 'vue-router';
import AddWorkApi from '../api/AddWorkApi'; import AddWorkApi from '../api/AddWorkApi';
import _ from 'lodash'; import _ from 'lodash';
import dayjs from 'dayjs'; import dayjs from 'dayjs';
import ClassListApi from '../api/ClassListApi'; import ClassListApi from '../api/ClassListApi';
import { ElMessage } from 'element-plus'; import { ElMessage } from 'element-plus';
import LoginApi from '../api/LoginApi';
import { useTokenStore } from '../stores/token';
import { useUserStore } from '../stores/user';
const router = useRouter(); const router = useRouter();
const options = ref([ const options = ref([
@ -109,8 +114,8 @@ const options = ref([
]); ]);
const route = useRoute(); const route = useRoute();
const id=ref(route.params.id)
console.log(id.value+'============')
const id = ref(route.params.id)
console.log(id.value + '============')
// //
const homeworkData = ref<{ const homeworkData = ref<{
@ -126,7 +131,9 @@ const homeworkData = ref<{
id: string; id: string;
name: string; name: string;
}; };
status: number;
form: FormItemType[]; form: FormItemType[];
}>({ }>({
name: '', name: '',
startDate: '', startDate: '',
@ -140,6 +147,7 @@ const homeworkData = ref<{
id: '', id: '',
name: '' name: ''
}, },
status: 0,
form: [] form: []
}); });
@ -170,12 +178,16 @@ const form = ref({
Questions: [] Questions: []
}); });
// false
const isPublished = ref(0);
onMounted(async () => { onMounted(async () => {
try { try {
const response = await ClassListApi.getClassListOne(id.value); const response = await ClassListApi.getClassListOne(id.value);
homeworkData.value = response.data; homeworkData.value = response.data;
console.log(homeworkData.value) console.log(homeworkData.value)
form.value.Name = homeworkData.value.name; form.value.Name = homeworkData.value.name;
//
isPublished.value = homeworkData.value.status;
const start = dayjs(homeworkData.value.startDate).format('YYYY-MM-DD'); const start = dayjs(homeworkData.value.startDate).format('YYYY-MM-DD');
const end = dayjs(homeworkData.value.endDate).format('YYYY-MM-DD'); const end = dayjs(homeworkData.value.endDate).format('YYYY-MM-DD');
@ -231,15 +243,15 @@ const onSubmit = () => {
if (form.value.LiveId) { if (form.value.LiveId) {
// form.value.liveid使liveidArticleIdliveid // form.value.liveid使liveidArticleIdliveid
form.value.ArticleId = ''; form.value.ArticleId = '';
} else if (form.value.ArticleId) {
} else if (form.value.ArticleId) {
// 使idform.value.ArticleId // 使idform.value.ArticleId
} else if (homeworkData.value.article && homeworkData.value.article.id) {
} else if (homeworkData.value.article && homeworkData.value.article.id) {
// 使idhomeworkData.value.article.id // 使idhomeworkData.value.article.id
form.value.ArticleId = homeworkData.value.article.id; form.value.ArticleId = homeworkData.value.article.id;
}
}
if (typeof id.value === 'string') { if (typeof id.value === 'string') {
form.value.id = id.value; form.value.id = id.value;
}
}
ClassListApi.editWork(form.value) ClassListApi.editWork(form.value)
.then((response) => { .then((response) => {
console.log(response); console.log(response);
@ -250,7 +262,7 @@ const onSubmit = () => {
console.error('编辑失败', error); console.error('编辑失败', error);
ElMessage.error('编辑失败'); ElMessage.error('编辑失败');
}); });
console.log(id.value+'--------------')
console.log(id.value + '--------------')
console.log(form.value) console.log(form.value)
} }
const back = () => { const back = () => {
@ -328,27 +340,41 @@ const getQuestionTypeText = (type) => {
}; };
const addSingleChoice = () => { const addSingleChoice = () => {
if (isPublished.value === 1) {
ElMessage.warning('处于发布中,不能添加新题目');
} else {
questions.value.push({ questions.value.push({
type: 1, // 1 type: 1, // 1
description: '', description: '',
content: [{ "id": "", "text": "" },{ "id": "", "text": "" }]
content: [{ "id": "", "text": "" }, { "id": "", "text": "" }]
}); });
}
}; };
const addMultipleChoice = () => { const addMultipleChoice = () => {
if (isPublished.value === 1) {
ElMessage.warning('处于发布中,不能添加新题目');
} else {
questions.value.push({ questions.value.push({
type: 2, // 2 type: 2, // 2
description: '', description: '',
content: [{ "id": "", "text": "" },{ "id": "", "text": "" }]
content: [{ "id": "", "text": "" }, { "id": "", "text": "" }]
}); });
}
}; };
const addBlank = () => { const addBlank = () => {
if (isPublished.value === 1) {
ElMessage.warning('处于发布中,不能添加新题目');
} else {
questions.value.push({ questions.value.push({
type: 3, // 3 type: 3, // 3
description: '', description: '',
content: [{ "id": "", "text": "" }] content: [{ "id": "", "text": "" }]
}); });
}
}; };
const addOption = (questionIndex) => { const addOption = (questionIndex) => {
@ -365,7 +391,11 @@ const removeOption = (questionIndex, optionIndex) => {
}; };
const removeQuestion = (questionIndex) => { const removeQuestion = (questionIndex) => {
if(isPublished.value === 1){
ElMessage.warning('处于发布中,不能删除题目');
}else{
questions.value.splice(questionIndex, 1); questions.value.splice(questionIndex, 1);
}
}; };
// //
@ -390,6 +420,19 @@ onMounted(() => {
isHovered.value = Array(questions.value.length).fill(false); isHovered.value = Array(questions.value.length).fill(false);
}); });
//退
function logout() {
//
const tokenStore = useTokenStore();
const userStore = useUserStore();
tokenStore.clear();
userStore.clear();
LoginApi.logout().then(res => {
console.log(res)
})
router.push('/')
}
</script> </script>
<style scoped> <style scoped>

36
work/src/views/WorkDetail.vue

@ -92,6 +92,8 @@ import * as XLSX from 'xlsx';
import axios from 'axios'; import axios from 'axios';
import LoginApi from '../api/LoginApi'; import LoginApi from '../api/LoginApi';
import { useTokenStore } from '../stores/token'; import { useTokenStore } from '../stores/token';
import { useUserStore } from '../stores/user';
const router = useRouter(); const router = useRouter();
const back = () => { const back = () => {
@ -251,18 +253,32 @@ const exportData = async () => {
}; };
const tokenStore = useTokenStore(); const tokenStore = useTokenStore();
// 退
const logout = () => {
LoginApi.logout().then(res => {
console.log(tokenStore);
// // 退
// const logout = () => {
// LoginApi.logout().then(res => {
// console.log(tokenStore);
// tokenStore.clear();
// localStorage.removeItem('token');
// console.log(tokenStore);
// router.push('/');
// }).catch(err => {
// // 退
// ElMessage.error('退');
// })
// }
//退
function logout(){
//
const tokenStore = useTokenStore();
const userStore = useUserStore();
tokenStore.clear(); tokenStore.clear();
localStorage.removeItem('token');
console.log(tokenStore);
router.push('/');
}).catch(err => {
// 退
ElMessage.error('退出登录失败,请稍后重试');
userStore.clear();
LoginApi.logout().then(res => {
console.log(res)
}) })
router.push('/')
} }
</script> </script>

Loading…
Cancel
Save