From 98f494cf633e3acf5c20f3e9de0d708f2a6c2045 Mon Sep 17 00:00:00 2001
From: ZhangXianQiang <1135831638@qq.com>
Date: 星期五, 05 七月 2024 09:39:59 +0800
Subject: [PATCH] feat:视频浏览

---
 src/views/grade-list/data-list/index.vue |   76 +++++++++++++++++++++++++++++++-------
 1 files changed, 62 insertions(+), 14 deletions(-)

diff --git a/src/views/grade-list/data-list/index.vue b/src/views/grade-list/data-list/index.vue
index ce5c3bb..fc82f87 100644
--- a/src/views/grade-list/data-list/index.vue
+++ b/src/views/grade-list/data-list/index.vue
@@ -1,11 +1,11 @@
 <template>
   <div class="list-container w-full h-full">
     <el-scrollbar>
-      <el-card shadow="hover" class="mb-3">
+      <el-card shadow="hover" class="mb-3" v-for="item in props.dataList">
         <div class="item flex justify-between items-center">
           <div class="left-container flex flex-col justify-between">
             <div class="top-container flex items-center">
-              <div class="title mr-5 text-xl font-bold">娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯</div>
+              <div class="title mr-5 text-xl font-bold">{{ item.examName }}</div>
               <div class="tag">
                 <el-tag type="primary" effect="light" round>
                   宸叉壒鏀�
@@ -13,31 +13,33 @@
               </div>
             </div>
             <div class="mid-container flex items-center my-4 text-gray-700">
-              <el-icon class="mr-1"><Timer /></el-icon>
+              <el-icon class="mr-1">
+                <Timer />
+              </el-icon>
               <div class="time">
-                鑰冭瘯鏃堕棿: 2024-6-5 08:00 ~ 2024-6-5 10:00
+                浜ゅ嵎鏃堕棿: {{ item.submitTime }}
               </div>
             </div>
             <div class="bottom-container flex text-sm text-gray-400 mb-3">
               <div class="bottom-item">
-                鎬诲垎: 100
+                鎬诲垎: {{ item.totalScore }}
               </div>
               <div class="bottom-item">
-                棰樻暟: 20
+                棰樻暟: {{ item.questionCount }}
               </div>
               <div class="bottom-item">
-                绛旈鏃堕棿: 20鍒嗛挓
+                绛旈鏃堕棿: {{ item.doTime / 60 }}鍒嗛挓
               </div>
             </div>
 
             <div class="grade-container flex items-center text-red-600">
               <div class="grade-label mr-1">鎴愮哗:</div>
-              <div class="grade-num text-lg font-bold">60</div>
+              <div class="grade-num text-lg font-bold">{{ item.score }}</div>
             </div>
           </div>
           <div class="right-container">
             <div class="button-container">
-              <el-button type="primary" size="large" @click="checkExam">鏌ョ湅璇曞嵎</el-button>
+              <el-button type="primary" size="large" @click="checkExam(item)">鏌ョ湅璇曞嵎</el-button>
             </div>
           </div>
         </div>
@@ -48,13 +50,58 @@
 </template>
 
 <script setup>
-import {ref} from 'vue';
+import { ref } from 'vue';
 import { Timer } from '@element-plus/icons-vue';
-import {useRouter} from 'vue-router';
-const router = useRouter();
+import { useRouter } from 'vue-router';
+import { useGradeStore } from '@/store/index.js';
+import { getGradeInfo } from '@/api/modules/grade.js';
 
-const checkExam = () => {
-  router.push('/grade');
+const gradeStore = useGradeStore();
+
+const router = useRouter();
+const props = defineProps({
+  dataList: {
+    type: Array,
+    default: () => []
+  }
+});
+
+const stateList = {
+  1: {
+    text: '鏈紑濮�',
+    type: 'primary',
+    disabled: true
+  },
+  'ing': {
+    text: '杩涜涓�',
+    type: 'success',
+    disabled: false
+  },
+  'finished': {
+    text: '宸茬粨鏉�',
+    type: 'info',
+    disabled: true
+  }
+};
+const loading = ref(false);
+
+
+const checkExam = (item) => {
+  getGradeInfo(item.id).then((res) => {
+    console.log(res.data);
+    const {id,examName, score,navbar,titleItems} = res.data;
+    gradeStore.setExamInfo({
+      id,
+      examName,
+      score,
+      navbar
+    });
+    gradeStore.setExamDetail(titleItems);
+    gradeStore.initExam();
+    router.push('/grade');
+  }).catch(err => {
+
+  });
 }
 
 </script>
@@ -64,6 +111,7 @@
   width: 100%;
   min-height: 120px;
 }
+
 .bottom-item {
   margin-right: 30px;
 }

--
Gitblit v1.8.0