| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221 | import {  useMessage,  NImage,  NScrollbar,  NSpin,  NModal,  NButton} from 'naive-ui';import { defineComponent, onMounted, reactive, ref } from 'vue';import styles from '@/views/classList/index.module.less';import TrainType from '@/views/attend-class/model/train-type';import defultHeade from '@/components/layout/images/teacherIcon.png';import noSub from '@/views/classList/images/nosub.png';import qualified from '@/views/classList/images/qualified.png';import unqualified from '@/views/classList/images/unqualified.png';import { evaluateDifficult } from '/src/utils/contants';import dayjs from 'dayjs';import { getTrainingStudentDetail } from '../../classList/api';import CommentWork from './comment-work';export default defineComponent({  props: {    activeRow: {      type: Object,      default: () => ({ id: '' })    },    total: {      type: Number,      default: 0    },    current: {      type: Number,      default: 0    }  },  name: 'studentTraomomhDetails',  emits: ['close'],  setup(props, { emit, expose }) {    const showModalMask = ref(false);    const loading = ref(false);    const teacherInfo = ref({      teacherName: '',      createTime: '',      expireDate: '',      teacherAvatar: '',      studentLessonTrainingDetails: [] as any    } as any);    // const message = useMessage();    // const foemsRef = ref();    const typeFormat = (trainingType: string, configJson: any) => {      let tList: string[] = [];      if (trainingType === 'EVALUATION') {        tList = [          `${evaluateDifficult[configJson.evaluateDifficult]}`,          configJson.practiceChapterBegin || configJson.practiceChapterEnd            ? `${configJson.practiceChapterBegin}-${configJson.practiceChapterEnd}小节`            : '全部小节',          // `速度${configJson.evaluateSpeed}`,          `${configJson.trainingTimes}分合格`        ];        // console.log('configJson.evaluateDifficult--', tList);      } else {        tList = [          `${configJson.practiceChapterBegin}-${configJson.practiceChapterEnd}小节`,          `速度${configJson.practiceSpeed}`,          `${configJson.trainingTimes}分钟`        ];        // console.log('configJson.evaluateDifficult', tList);      }      return tList;    };    const getTrainingDetail = async (id: any) => {      loading.value = true;      try {        const res = await getTrainingStudentDetail({          studentLessonTrainingId: id        });        const arr = res.data.studentLessonTrainingDetails.map((item: any) => {          const tList = typeFormat(            item.trainingType,            JSON.parse(item.trainingContent)          );          return {            ...item,            coverImg: item.titleImg,            allTimes: JSON.parse(item.trainingContent).trainingTimes,            typeList: tList || []          };        });        teacherInfo.value = {          ...res.data,          studentLessonTrainingDetails: arr        };        console.log(teacherInfo.value, ' teacherInfo.value');      } catch (e) {        console.log(e);      }      loading.value = false;    };    expose({ getTrainingDetail });    onMounted(() => {      getTrainingDetail(props.activeRow.id);    });    return () => (      <div class={[styles.trainingDetails]}>        <NSpin show={loading.value}>          <div class={styles.studentList}>            <div class={styles.studentHeaderWrap}>              <div class={styles.studentHeader}>                <div class={styles.studentHeaderBorder}>                  <NImage                    class={styles.studentHeaderImg}                    src={                      teacherInfo.value.teacherAvatar                        ? teacherInfo.value.teacherAvatar                        : defultHeade                    }                    previewDisabled></NImage>                </div>              </div>              <div class={styles.workafterInfo}>                <h4>                  {teacherInfo.value.teacherName}{' '}                  <div                    class={[                      styles.workafterInfoDot,                      styles.workafterTeacherInfoDot                    ]}>                    老师                  </div>                </h4>                <p>                  开始时间:                  {teacherInfo.value.createTime                    ? dayjs(new Date(teacherInfo.value.createTime)).format(                        'YYYY-MM-DD HH:mm'                      )                    : '--'}{' '}                  | 结束时间:                  {teacherInfo.value.expireDate                    ? dayjs(new Date(teacherInfo.value.expireDate)).format(                        'YYYY-MM-DD HH:mm'                      )                    : '--'}                </p>              </div>            </div>            {teacherInfo.value.trainingStatus == 'UNSUBMITTED' ? (              <NImage                previewDisabled                class={styles.workStatus}                src={noSub}></NImage>            ) : null}            {teacherInfo.value.trainingStatus == 'SUBMITTED' ? (              <NImage                previewDisabled                class={styles.workStatus}                src={unqualified}></NImage>            ) : null}            {teacherInfo.value.trainingStatus == 'TARGET' ? (              <NImage                previewDisabled                class={styles.workStatus}                src={qualified}></NImage>            ) : null}          </div>          {teacherInfo.value.trainingStatus !== 'UNSUBMITTED' && (            <NButton              onClick={() => (showModalMask.value = true)}              class={styles.commentBtnGroup}>              <div class={styles.text}>                <i class={teacherInfo.value.comment && styles.look}></i>                {teacherInfo.value.comment ? '查看评语' : '点评作业'}              </div>            </NButton>          )}          <NScrollbar style="max-height:400px" trigger="none">            <div class={styles.workList}>              {teacherInfo.value.studentLessonTrainingDetails.map(                (item: any) => (                  <TrainType                    style={{ marginBottom: '20px' }}                    isDisabled={true}                    isDelete={false}                    isCLassWork={false}                    item={item}></TrainType>                )              )}            </div>          </NScrollbar>        </NSpin>        <NModal v-model:show={showModalMask.value}>          <CommentWork            comment={teacherInfo.value.comment}            workInfo={{              isLook: teacherInfo.value.comment ? true : false,              studentAvatar: teacherInfo.value.studentAvatar,              studentName: teacherInfo.value.studentName,              submitTime: teacherInfo.value.submitTime,              studentLessonTrainingId: teacherInfo.value.studentLessonTrainingId            }}            onClose={() => (showModalMask.value = false)}            onConfrim={() => {              getTrainingDetail(props.activeRow.id);              showModalMask.value = false;            }}          />        </NModal>      </div>    );  }});
 |