Compare commits
	
		
			5 Commits
		
	
	
		
			0fc3502cdd
			...
			bbdd8156ef
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | bbdd8156ef | ||
|   | 7663345f28 | ||
|   | af407925c4 | ||
|   | f414bca291 | ||
|   | 162a246cfb | 
| @ -62,4 +62,17 @@ public class HitRegistrationStudentInfo extends BaseEntity | ||||
| 
 | ||||
|     /** 逻辑删除0未删除1真删除 */ | ||||
|     private Integer delFlag; | ||||
| 
 | ||||
|     /** 盲样收件人 */ | ||||
|     @Excel(name = "盲样收件人") | ||||
|     private String sampleConcat; | ||||
| 
 | ||||
|     /** 盲样收件人电话 */ | ||||
|     @Excel(name = "盲样收件人电话") | ||||
|     private String sampleNumber; | ||||
| 
 | ||||
|     /** 盲样邮寄地址 */ | ||||
|     @Excel(name = "盲样邮寄地址") | ||||
|     private String sampleAddress; | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -71,6 +71,18 @@ public class HitRegistrationStudentInfoVo extends BaseEntity { | ||||
|     @Excel(name = "指导老师") | ||||
|     private List<String> guideNames; | ||||
| 
 | ||||
|     /** 盲样收件人 */ | ||||
|     @Excel(name = "盲样收件人") | ||||
|     private String sampleConcat; | ||||
| 
 | ||||
|     /** 盲样收件人电话 */ | ||||
|     @Excel(name = "盲样收件人电话") | ||||
|     private String sampleNumber; | ||||
| 
 | ||||
|     /** 盲样邮寄地址 */ | ||||
|     @Excel(name = "盲样邮寄地址") | ||||
|     private String sampleAddress; | ||||
| 
 | ||||
|     /** 时间 */ | ||||
|     private Date createTime; | ||||
| } | ||||
|  | ||||
| @ -34,11 +34,11 @@ public class HitRegistrationStudentInfoExport{ | ||||
|     private String teamName; | ||||
| 
 | ||||
|     /** 大赛名称 */ | ||||
|     @Excel(name = "大赛名称") | ||||
| //    @Excel(name = "大赛名称") | ||||
|     private String competitionName; | ||||
| 
 | ||||
|     /** 大赛类型("0":团队赛,"1":个人赛,默认"0") */ | ||||
|     @Excel(name = "大赛类型", readConverterExp = "0=团队赛,1=个人赛") | ||||
| //    @Excel(name = "大赛类型", readConverterExp = "0=团队赛,1=个人赛") | ||||
|     private String competitionType; | ||||
| 
 | ||||
|     /** 带队老师姓名集合 */ | ||||
| @ -48,4 +48,16 @@ public class HitRegistrationStudentInfoExport{ | ||||
|     /** 指导老师姓名集合 */ | ||||
|     @Excel(name = "指导老师") | ||||
|     private String guideNames; | ||||
| 
 | ||||
|     /** 盲样收件人 */ | ||||
|     @Excel(name = "盲样收件人") | ||||
|     private String sampleConcat; | ||||
| 
 | ||||
|     /** 盲样收件人电话 */ | ||||
|     @Excel(name = "盲样收件人电话") | ||||
|     private String sampleNumber; | ||||
| 
 | ||||
|     /** 盲样邮寄地址 */ | ||||
|     @Excel(name = "盲样邮寄地址") | ||||
|     private String sampleAddress; | ||||
| } | ||||
|  | ||||
| @ -22,10 +22,13 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         <result property="createBy"    column="create_by"    /> | ||||
|         <result property="updateTime"    column="update_time"    /> | ||||
|         <result property="updateBy"    column="update_by"    /> | ||||
|         <result property="sampleConcat"    column="sample_concat"    /> | ||||
|         <result property="sampleNumber"    column="sample_number"    /> | ||||
|         <result property="sampleAddress"    column="sample_address"    /> | ||||
|     </resultMap> | ||||
| 
 | ||||
|     <sql id="selectHitRegistrationStudentInfoVo"> | ||||
|         select id, competition_id, stu_name, stu_gender, stu_major, stu_number, school_name, division, team_name, leader_ids, guide_ids, remark, del_flag, create_time, create_by, update_time, update_by from hit_registration_student_info | ||||
|         select id, sample_concat, sample_number, sample_address, competition_id, stu_name, stu_gender, stu_major, stu_number, school_name, division, team_name, leader_ids, guide_ids, remark, del_flag, create_time, create_by, update_time, update_by from hit_registration_student_info | ||||
|     </sql> | ||||
| 
 | ||||
|     <select id="selectHitRegistrationStudentInfoList" parameterType="HitRegistrationStudentInfo" resultMap="HitRegistrationStudentInfoResult"> | ||||
| @ -69,6 +72,9 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|             <if test="createBy != null">create_by,</if> | ||||
|             <if test="updateTime != null">update_time,</if> | ||||
|             <if test="updateBy != null">update_by,</if> | ||||
|             <if test="sampleConcat != null">sample_concat,</if> | ||||
|             <if test="sampleNumber != null">sample_number,</if> | ||||
|             <if test="sampleAddress != null">sample_address,</if> | ||||
|          </trim> | ||||
|         <trim prefix="values (" suffix=")" suffixOverrides=","> | ||||
|             <if test="id != null">#{id},</if> | ||||
| @ -88,6 +94,9 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|             <if test="createBy != null">#{createBy},</if> | ||||
|             <if test="updateTime != null">#{updateTime},</if> | ||||
|             <if test="updateBy != null">#{updateBy},</if> | ||||
|             <if test="sampleConcat != null">#{sampleConcat},</if> | ||||
|             <if test="sampleNumber != null">#{sampleNumber},</if> | ||||
|             <if test="sampleAddress != null">#{sampleAddress},</if> | ||||
|          </trim> | ||||
|     </insert> | ||||
| 
 | ||||
| @ -128,10 +137,10 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
| <!--    自定义--> | ||||
|     <sql id="selectHitRegistrationStudentInfoVoNew"> | ||||
|         select | ||||
|             id, competition_id, stu_name, stu_gender, stu_major, stu_number, school_name, division, team_name, leader_ids, guide_ids, remark,del_flag, create_time, create_by, update_time, update_by,competition_name, competition_type, leader_names, guide_names | ||||
|             id, sample_concat, sample_number, sample_address, competition_id, stu_name, stu_gender, stu_major, stu_number, school_name, division, team_name, leader_ids, guide_ids, remark,del_flag, create_time, create_by, update_time, update_by,competition_name, competition_type, leader_names, guide_names | ||||
|         from | ||||
|             (SELECT | ||||
|                  s.id, s.competition_id, s.stu_name, s.stu_gender, s.stu_major, s.stu_number, s.school_name, s.division, s.team_name, s.leader_ids, s.guide_ids, s.remark, s.del_flag, s.create_time, s.create_by, s.update_time, s.update_by,c.competition_name, c.competition_type, | ||||
|                  s.id, s.competition_id, s.stu_name, s.stu_gender, s.stu_major, s.stu_number, s.school_name, s.division, s.team_name, s.leader_ids, s.guide_ids, s.remark, s.del_flag, s.create_time, s.create_by, s.update_time, s.update_by,c.competition_name, c.competition_type, s.sample_concat, s.sample_number, s.sample_address, | ||||
|                  CONCAT('[', | ||||
|                         GROUP_CONCAT(JSON_QUOTE(t.teacher_name) ORDER BY t.teacher_name SEPARATOR ','), | ||||
|                         ']') AS leader_names | ||||
| @ -177,6 +186,9 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         <result property="updateBy"    column="update_by"    /> | ||||
|         <result property="competitionName"    column="competition_name"    /> | ||||
|         <result property="competitionType"    column="competition_type"    /> | ||||
|         <result property="sampleConcat"    column="sample_concat"    /> | ||||
|         <result property="sampleNumber"    column="sample_number"    /> | ||||
|         <result property="sampleAddress"    column="sample_address"    /> | ||||
|         <result property="leaderNames"    column="leader_names" javaType="java.util.List" typeHandler="com.ruoyi.system.handler.MysqlTypeHandler"   /> | ||||
|         <result property="guideNames"    column="guide_names" javaType="java.util.List" typeHandler="com.ruoyi.system.handler.MysqlTypeHandler"    /> | ||||
|     </resultMap> | ||||
| @ -194,5 +206,6 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|         <if test="teachName != null  and teachName != ''"> and (leader_names like concat('%', #{teachName}, '%') or guide_names like concat('%', #{teachName}, '%'))</if> | ||||
|         <if test="competitionType != null">and competition_type = #{competitionType}</if> | ||||
|         <if test="createTime != null">and YEAR(create_time) = YEAR(#{createTime})</if> | ||||
|         order by create_time desc | ||||
|     </select> | ||||
| </mapper> | ||||
| @ -37,6 +37,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" | ||||
|             <if test="imitationCount != null "> and imitation_count = #{imitationCount}</if> | ||||
|             <if test="imitationType != null "> and imitation_type = #{imitationType}</if> | ||||
|         </where> | ||||
|         order by create_time desc | ||||
|     </select> | ||||
|      | ||||
|     <select id="selectImitationById" parameterType="Long" resultMap="ImitationResult"> | ||||
|  | ||||
| @ -50,3 +50,5 @@ export function getTeachInfoByIds(ids){ | ||||
|     method: "get", | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										17
									
								
								ruoyi-ui/src/api/officialWebsite/registerStudent.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								ruoyi-ui/src/api/officialWebsite/registerStudent.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,17 @@ | ||||
| import request from '@/utils/request' | ||||
| 
 | ||||
| export function addTeacher(data){ | ||||
|   return request({ | ||||
|     url: "/api/registerStudent/addTeach", | ||||
|     method: "post", | ||||
|     data | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| export function register(data){ | ||||
|   return request({ | ||||
|     url: "/api/registerStudent", | ||||
|     method: "post", | ||||
|     data | ||||
|   }) | ||||
| } | ||||
| @ -9,20 +9,6 @@ | ||||
|           @keyup.enter.native="handleQuery" | ||||
|         /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="学生性别" prop="stuGender"> | ||||
|         <el-select | ||||
|           v-model="queryParams.stuGender" | ||||
|           placeholder="内容类型" | ||||
|           clearable | ||||
|           style="width: 125px"> | ||||
|           <el-option | ||||
|             v-for="dict in dict.type.sys_user_sex" | ||||
|             :key="dict.value" | ||||
|             :label="dict.label" | ||||
|             :value="dict.value" | ||||
|           /> | ||||
|         </el-select> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="学生专业" prop="stuMajor"> | ||||
|         <el-input | ||||
|           v-model="queryParams.stuMajor" | ||||
| @ -47,20 +33,20 @@ | ||||
|           @keyup.enter.native="handleQuery" | ||||
|         /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="大赛类型" prop=""> | ||||
|         <el-select | ||||
|           v-model="queryParams.competitionType" | ||||
|           placeholder="大赛类型" | ||||
|           clearable | ||||
|           style="width: 125px"> | ||||
|           <el-option | ||||
|             v-for="dict in dict.type.competition_type" | ||||
|             :key="dict.value" | ||||
|             :label="dict.label" | ||||
|             :value="dict.value" | ||||
|           /> | ||||
|         </el-select> | ||||
|       </el-form-item> | ||||
| <!--      <el-form-item label="大赛类型" prop="">--> | ||||
| <!--        <el-select--> | ||||
| <!--          v-model="queryParams.competitionType"--> | ||||
| <!--          placeholder="大赛类型"--> | ||||
| <!--          clearable--> | ||||
| <!--          style="width: 125px">--> | ||||
| <!--          <el-option--> | ||||
| <!--            v-for="dict in dict.type.competition_type"--> | ||||
| <!--            :key="dict.value"--> | ||||
| <!--            :label="dict.label"--> | ||||
| <!--            :value="dict.value"--> | ||||
| <!--          />--> | ||||
| <!--        </el-select>--> | ||||
| <!--      </el-form-item>--> | ||||
|       <el-form-item label="所属赛区" prop="division"> | ||||
|         <el-input | ||||
|           v-model="queryParams.division" | ||||
| @ -85,14 +71,14 @@ | ||||
|           @keyup.enter.native="handleQuery" | ||||
|         /> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="大赛名称" prop="competitionName"> | ||||
|         <el-input | ||||
|           v-model="queryParams.competitionName" | ||||
|           placeholder="请输入团队名称" | ||||
|           clearable | ||||
|           @keyup.enter.native="handleQuery" | ||||
|         /> | ||||
|       </el-form-item> | ||||
| <!--      <el-form-item label="大赛名称" prop="competitionName">--> | ||||
| <!--        <el-input--> | ||||
| <!--          v-model="queryParams.competitionName"--> | ||||
| <!--          placeholder="请输入团队名称"--> | ||||
| <!--          clearable--> | ||||
| <!--          @keyup.enter.native="handleQuery"--> | ||||
| <!--        />--> | ||||
| <!--      </el-form-item>--> | ||||
|       <el-form-item label="大赛年份" prop="competitionYear"> | ||||
|         <el-select v-model="queryParams.createTime" placeholder="请选择"> | ||||
|           <el-option | ||||
| @ -103,6 +89,20 @@ | ||||
|           </el-option> | ||||
|         </el-select> | ||||
|       </el-form-item> | ||||
|       <el-form-item label="学生性别" prop="stuGender"> | ||||
|         <el-select | ||||
|           v-model="queryParams.stuGender" | ||||
|           placeholder="学生性别" | ||||
|           clearable | ||||
|           style="width: 125px"> | ||||
|           <el-option | ||||
|             v-for="dict in dict.type.sys_user_sex" | ||||
|             :key="dict.value" | ||||
|             :label="dict.label" | ||||
|             :value="dict.value" | ||||
|           /> | ||||
|         </el-select> | ||||
|       </el-form-item> | ||||
|       <el-form-item> | ||||
|         <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button> | ||||
|         <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置刷新</el-button> | ||||
| @ -148,8 +148,8 @@ | ||||
|       <el-table-column type="selection" width="55" align="center" /> | ||||
|       <el-table-column type="expand"> | ||||
|         <template slot-scope="props"> | ||||
|           <el-descriptions title="学生信息" style="margin-left: 100px"> | ||||
|             <el-descriptions-item label="比赛名称">{{props.row.competitionName}}</el-descriptions-item> | ||||
|           <el-descriptions title="学生信息" style="margin-left: 10%"> | ||||
| <!--            <el-descriptions-item label="比赛名称">{{props.row.competitionName}}</el-descriptions-item>--> | ||||
|             <el-descriptions-item label="学生姓名">{{props.row.stuName}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="学生性别"> | ||||
|               <dict-tag :options="dict.type.sys_user_sex" :value="props.row.stuGender"/> | ||||
| @ -160,23 +160,28 @@ | ||||
|             <el-descriptions-item label="所属赛区">{{props.row.division}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="团队名称">{{props.row.teamName}}</el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <el-descriptions :title="'领队教师' + (index + 1)"  v-for="(item, index) in leaderTeachList" style="margin-left: 100px" v-show="leaderTeachList !== null && leaderTeachList.length !== 0"> | ||||
|           <el-descriptions :title="'领队教师' + (index + 1)"  v-for="(item, index) in leaderTeachList" style="margin-left: 10%" v-show="leaderTeachList !== null && leaderTeachList.length !== 0"> | ||||
|             <el-descriptions-item label="教师姓名">{{item.teacherName}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="教师职务">{{item.teacherJob}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="教师手机号">{{item.teacherNumber}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="教师邮箱">{{item.teacherEmail}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="教师所在系及专业">{{item.teacherSchool}}</el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <el-descriptions :title="'指导教师' + (index + 1)"  v-for="(item, index) in guideTeachList" style="margin-left: 100px" v-show="guideTeachList !== null && guideTeachList.length !== 0"> | ||||
|           <el-descriptions :title="'指导教师' + (index + 1)"  v-for="(item, index) in guideTeachList" style="margin-left: 10%" v-show="guideTeachList !== null && guideTeachList.length !== 0"> | ||||
|             <el-descriptions-item label="教师姓名">{{item.teacherName}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="教师职务">{{item.teacherJob}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="教师手机号">{{item.teacherNumber}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="教师邮箱">{{item.teacherEmail}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="教师所在系及专业">{{item.teacherSchool}}</el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|           <el-descriptions title="盲样邮寄地址" style="margin-left: 10%"> | ||||
|             <el-descriptions-item label="收件人">{{props.row.sampleConcat}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="联系电话">{{props.row.sampleNumber}}</el-descriptions-item> | ||||
|             <el-descriptions-item label="邮寄地址">{{props.row.sampleAddress}}</el-descriptions-item> | ||||
|           </el-descriptions> | ||||
|         </template> | ||||
|       </el-table-column> | ||||
|       <el-table-column label="比赛名称" align="center" prop="competitionName" /> | ||||
| <!--      <el-table-column label="比赛名称" align="center" prop="competitionName" />--> | ||||
|       <el-table-column label="学生姓名" align="center" prop="stuName" /> | ||||
|       <el-table-column label="学生性别" align="center" prop="stuGender" width="100px"> | ||||
|         <template slot-scope="scope"> | ||||
|  | ||||
| @ -86,7 +86,7 @@ | ||||
|       <div class="list"> | ||||
|         <swiper ref="mySwiper" :options="swiperOptions1" style="width: 100%"> | ||||
|           <swiper-slide class="gongao-item" v-for="item in this.noticeList"  @click="goDeatail(item)"> | ||||
|             <div class="bj"> | ||||
|             <div class="bj" @click="goDeatail(item)"> | ||||
|               <div class="tt">{{ item.contentTitle }}</div> | ||||
|               <div class="p"> | ||||
|                 <div class="tags"> | ||||
| @ -306,8 +306,7 @@ export default { | ||||
|       imitationId(data.id).then(res=>{ | ||||
|         console.log(res,'调用成功') | ||||
|       }) | ||||
|       window.open(data.link, '_blank'); | ||||
| 
 | ||||
|       window.open(data.imitationLink, '_blank'); | ||||
|     }, | ||||
|     goDeatail(data){ | ||||
|       console.log(data) | ||||
| @ -734,6 +733,9 @@ export default { | ||||
| .gongao .list .gongao-item .bj { | ||||
|   padding: 20px; | ||||
| } | ||||
| .bj:hover{ | ||||
|   cursor: pointer; | ||||
| } | ||||
| .gongao .list .gongao-item .tt { | ||||
|   font-size: 20px; | ||||
|   line-height: 28px; | ||||
|  | ||||
| @ -46,7 +46,7 @@ | ||||
|           <a href="">版权所有:{{ this.baseInfo.copyrightInfo }}</a> | ||||
|           <a href="">备案信息:{{ this.baseInfo.recordInfo }}</a> | ||||
|         </div> | ||||
|         <div class="right"> | ||||
|         <div class="right" @click="toTop"> | ||||
|           <div class="">返回顶部</div> | ||||
|           <img src="../../../assets/gw/top.png" alt=""> | ||||
|         </div> | ||||
| @ -73,6 +73,9 @@ export default { | ||||
|         this.baseInfo = res.data | ||||
|         this.baseInfo.webImg = process.env.VUE_APP_BASE_API + this.baseInfo.webImg | ||||
|       }) | ||||
|     }, | ||||
|     toTop(){ | ||||
|       window.scrollTo({ top: 0, behavior: 'smooth' }); | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| @ -10,7 +10,7 @@ | ||||
| 
 | ||||
|     <div class="navigation"> | ||||
|       <div class="content"> | ||||
|         <div class="left"> <img src="../../assets/gw/home.png" alt=""> | ||||
|         <div class="left"><img src="../../assets/gw/home.png" alt=""> | ||||
|           <p><span href="/">首页</span><i class="el-icon-arrow-right"></i> <span href="">合作企业</span></p> | ||||
|         </div> | ||||
|         <!-- <div class="nav-item" v-for="(item, index) in nav" v-bind:class="[index === currentActive ? 'active' : '']" | ||||
| @ -49,7 +49,7 @@ | ||||
|       </div> --> | ||||
|       <div class="item" v-for="(item, index) in teachingAchievements" :key="index"> | ||||
|         <div class="img"> | ||||
|           <img :src="imgurl + item.contentImg" alt=""> | ||||
|           <img :src="imgurl + item.imageUrl" alt=""> | ||||
|         </div> | ||||
|         <div class="tt">{{ item.contentTitle }}</div> | ||||
| 
 | ||||
| @ -57,8 +57,9 @@ | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="page-box"> | ||||
|       <el-pagination background layout="prev, pager, next" :total="1000" class=""> | ||||
|       </el-pagination> | ||||
| <!--      <el-pagination background layout="prev, pager, next" :total="1000" class="">--> | ||||
| <!--      </el-pagination>--> | ||||
| <!--      <page-util :category-id="categoryId" @event-message="handleDataFromPage" />--> | ||||
|     </div> | ||||
| 
 | ||||
|     <footers></footers> | ||||
| @ -66,18 +67,21 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import { Swiper, SwiperSlide } from "vue-awesome-swiper"; | ||||
| import {Swiper, SwiperSlide} from "vue-awesome-swiper"; | ||||
| import "swiper/css/swiper.min.css"; | ||||
| import { getPageData, getPageColumn } from "@/api/officialWebsite/getPageData"; | ||||
| import {getPageData, getPageColumn} from "@/api/officialWebsite/getPageData"; | ||||
| import headers from '@/views/officialWebsite/Components/header.vue' | ||||
| import footers from '@/views/officialWebsite/Components/footer.vue' | ||||
| import { getTab, getbanner, getinfo } from "@/api/gw/home"; | ||||
| import {getTab, getbanner, getinfo} from "@/api/gw/home"; | ||||
| import PageUtil from '@/views/officialWebsite/Components/page' | ||||
| 
 | ||||
| export default { | ||||
|   components: { | ||||
|     Swiper, | ||||
|     SwiperSlide, | ||||
|     headers, | ||||
|     footers | ||||
|     footers, | ||||
|     "page-util": PageUtil | ||||
|   }, | ||||
|   name: 'HelloWorld', | ||||
|   props: { | ||||
| @ -94,16 +98,14 @@ export default { | ||||
|       ], | ||||
|       currentActive: 0, | ||||
|       isMounted: false, | ||||
| 
 | ||||
|       categoryId: "", | ||||
|     } | ||||
|   }, | ||||
|   created() { | ||||
|     // 页面加载完毕调用 | ||||
|     this.initPageData(); | ||||
|   }, | ||||
|   computed: { | ||||
| 
 | ||||
|   }, | ||||
|   computed: {}, | ||||
| 
 | ||||
|   methods: { | ||||
|     // 触发导航 | ||||
| @ -115,24 +117,29 @@ export default { | ||||
|     }, | ||||
| 
 | ||||
|     initPageData() { | ||||
|       let routeParam = { | ||||
|         "categoryId": this.$route.query.id, | ||||
|         "pageNum": 1, | ||||
|         "pageSize": 10 | ||||
|       } | ||||
|       getPageColumn(routeParam).then(response => { | ||||
|         // this.categoryId = response.data[0].id | ||||
|         response.data.forEach(cloumnItem => { | ||||
|           this.nav.push(cloumnItem); | ||||
| 
 | ||||
| let routeParam = { | ||||
|   "categoryId": this.$route.query.id, | ||||
|   "pageNum": 1, | ||||
|   "pageSize": 10 | ||||
| } | ||||
| getPageColumn(routeParam).then(response => { | ||||
|   response.data.forEach(cloumnItem => { | ||||
|     this.nav.push(cloumnItem); | ||||
| 
 | ||||
|       cloumnItem.children.list.forEach(element => { | ||||
|         this.teachingAchievements.push(element); | ||||
|           cloumnItem.children.list.forEach(element => { | ||||
|             this.teachingAchievements.push(element); | ||||
|           }); | ||||
|           // cloumnItem.categoryName | ||||
|         }); | ||||
|       }); | ||||
|     // cloumnItem.categoryName | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
| }, | ||||
|     }, | ||||
|     handleDataFromPage(data){ | ||||
|       // this.nav[this.currentActive].children.list = data | ||||
|       // console.log(data) | ||||
|       this.teachingAchievements = data | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| } | ||||
| @ -175,8 +182,7 @@ getPageColumn(routeParam).then(response => { | ||||
| 
 | ||||
| /* 选中的页码按钮样式 */ | ||||
| ::v-deep .el-pagination .el-pager .active { | ||||
|   background-color: #005375; | ||||
|   ; | ||||
|   background-color: #005375;; | ||||
|   /* 背景颜色 */ | ||||
|   color: #fff; | ||||
|   /* 文字颜色 */ | ||||
| @ -200,6 +206,7 @@ getPageColumn(routeParam).then(response => { | ||||
| ::v-deep .el-pagination .btn-prev .el-icon { | ||||
|   font-size: 18px; | ||||
| } | ||||
| 
 | ||||
| .top-box { | ||||
|   width: 100%; | ||||
|   /* height: 1000px; */ | ||||
| @ -337,13 +344,12 @@ getPageColumn(routeParam).then(response => { | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| .list { | ||||
|   width: 80%; | ||||
|   margin: 30px auto; | ||||
|   display: flex; | ||||
|   flex-wrap: wrap; | ||||
|   justify-content: space-between; | ||||
|   /*justify-content: space-between;*/ | ||||
|   margin-top: 50px; | ||||
| 
 | ||||
| } | ||||
| @ -352,6 +358,7 @@ getPageColumn(routeParam).then(response => { | ||||
|   width: 23%; | ||||
|   height: 220px; | ||||
|   margin-bottom: 30px; | ||||
|   margin-right: 2%; | ||||
|   position: relative; | ||||
|   background-color: #fff; | ||||
|   overflow: hidden; | ||||
| @ -412,7 +419,8 @@ getPageColumn(routeParam).then(response => { | ||||
|   /* align-items: center; */ | ||||
| } | ||||
| 
 | ||||
| .index-footer .footer .logo .footer-contact {} | ||||
| .index-footer .footer .logo .footer-contact { | ||||
| } | ||||
| 
 | ||||
| .index-footer .footer .logo .footer-contact .p { | ||||
|   display: inline-block; | ||||
|  | ||||
| @ -22,122 +22,223 @@ | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="committee-cont"> | ||||
|       <div class="tabber-box " v-if="currentActive == 5" > | ||||
|         <div class="titel_">赛区参赛报名表(本科组)</div> | ||||
|         <el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="180px" class="demo-ruleForm"> | ||||
|           <div style="display: flex;"> | ||||
|             <el-form-item label="所属赛区" prop="name"> | ||||
|               <el-input style="width: 300px" v-model="ruleForm.name"></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="学校及院系名称" prop="name"> | ||||
|               <el-input style="width: 300px" v-model="ruleForm.name"></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="参赛团队名称" prop="name"> | ||||
|               <el-input style="width: 300px" v-model="ruleForm.name"></el-input> | ||||
|       <div class="tabber-box " v-if="currentActive == 6" > | ||||
|         <el-form ref="form" :model="ruleForm" label-width="120px" :rules="rules" class="demo-ruleForm"> | ||||
|           <h1 class="tab_title">参赛报名表(本科组)</h1> | ||||
| 
 | ||||
|           <!-- 基础信息--> | ||||
|           <div class="kuang"> | ||||
|           <el-row :gutter="20"> | ||||
|             <el-col :span="8"> | ||||
|               <el-form-item label="所属赛区" prop="division"> | ||||
|                 <el-input v-model="ruleForm.division"></el-input> | ||||
|               </el-form-item> | ||||
|             </el-col> | ||||
|             <el-col :span="8"> | ||||
|               <el-form-item label="学校及院系名称" prop="schoolName"> | ||||
|                 <el-input v-model="ruleForm.schoolName"></el-input> | ||||
|               </el-form-item> | ||||
|             </el-col> | ||||
|             <el-col :span="8"> | ||||
|               <el-form-item label="参赛团队名称" prop="teamName"> | ||||
|                 <el-input v-model="ruleForm.teamName"></el-input> | ||||
|               </el-form-item> | ||||
|             </el-col> | ||||
|           </el-row> | ||||
|           </div> | ||||
|           <!-- 领队老师信息--> | ||||
|           <div class="kuang "> | ||||
|           <h2 class="tab_title tab_down_line">领队老师</h2> | ||||
|           <el-row :gutter="20"> | ||||
|             <el-col :span="8"> | ||||
|               <el-form-item label="姓名" prop="teachers.0.teacherName"> | ||||
|                 <el-input v-model="ruleForm.teachers[0].teacherName"></el-input> | ||||
|               </el-form-item> | ||||
|             </el-col> | ||||
|             <el-col :span="8"> | ||||
|               <el-form-item label="职务" prop="teachers.0.teacherJob"> | ||||
|                 <el-input v-model="ruleForm.teachers[0].teacherJob"></el-input> | ||||
|               </el-form-item> | ||||
|             </el-col> | ||||
|             <el-col :span="8"> | ||||
|               <el-form-item label="手机号" prop="teachers.0.teacherNumber"> | ||||
|                 <el-input v-model="ruleForm.teachers[0].teacherNumber"></el-input> | ||||
|               </el-form-item> | ||||
|             </el-col> | ||||
|             <el-col :span="8"> | ||||
|               <el-form-item label="E-mail" prop="teachers.0.teacherEmail"> | ||||
|                 <el-input v-model="ruleForm.teachers[0].teacherEmail"></el-input> | ||||
|               </el-form-item> | ||||
|             </el-col> | ||||
|             <el-col :span="8"> | ||||
|               <el-form-item label="所在系及专业" prop="teachers.0.teacherSchool"> | ||||
|                 <el-input v-model="ruleForm.teachers[0].teacherSchool"></el-input> | ||||
|               </el-form-item> | ||||
|             </el-col> | ||||
|           </el-row> | ||||
|           </div> | ||||
| 
 | ||||
|           <!-- 指导老师①信息--> | ||||
|           <div class="kuang "> | ||||
|             <h2 class="tab_title tab_down_line">指导老师①</h2> | ||||
|             <el-row :gutter="20"> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="姓名" prop="teachers.1.teacherName"> | ||||
|                   <el-input v-model="ruleForm.teachers[1].teacherName"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="职务" prop="teachers.1.teacherJob"> | ||||
|                   <el-input v-model="ruleForm.teachers[1].teacherJob"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="手机号" prop="teachers.1.teacherNumber"> | ||||
|                   <el-input v-model="ruleForm.teachers[1].teacherNumber"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="E-mail" prop="teachers.1.teacherEmail"> | ||||
|                   <el-input v-model="ruleForm.teachers[1].teacherEmail"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="所在系及专业" prop="teachers.1.teacherSchool"> | ||||
|                   <el-input v-model="ruleForm.teachers[1].teacherSchool"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|             </el-row> | ||||
|           </div> | ||||
| 
 | ||||
|           <!-- 指导老师②信息--> | ||||
|           <div class="kuang "> | ||||
|             <h2 class="tab_title tab_down_line">指导老师②</h2> | ||||
|             <el-row :gutter="20"> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="姓名" prop="teachers.2.teacherName"> | ||||
|                   <el-input v-model="ruleForm.teachers[2].teacherName"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="职务" prop="teachers.2.teacherJob"> | ||||
|                   <el-input v-model="ruleForm.teachers[2].teacherJob"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="手机号" prop="teachers.2.teacherNumber"> | ||||
|                   <el-input v-model="ruleForm.teachers[2].teacherNumber"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="E-mail" prop="teachers.2.teacherEmail"> | ||||
|                   <el-input v-model="ruleForm.teachers[2].teacherEmail"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="所在系及专业" prop="teachers.2.teacherSchool"> | ||||
|                   <el-input v-model="ruleForm.teachers[2].teacherSchool"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|             </el-row> | ||||
|           </div> | ||||
| 
 | ||||
|           <!-- 参赛人信息--> | ||||
|           <div class="kuang "> | ||||
|             <h2 class="tab_title tab_down_line">参赛人信息</h2> | ||||
|             <el-row :gutter="20"> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="姓名" prop="stuName"> | ||||
|                   <el-input v-model="ruleForm.stuName"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="性别" prop="stuGender"> | ||||
|                   <el-select | ||||
|                     v-model="ruleForm.stuGender" | ||||
|                     placeholder="学生性别" | ||||
|                     clearable | ||||
|                     style="width: 125px"> | ||||
|                     <el-option | ||||
|                       v-for="dict in dict.type.sys_user_sex" | ||||
|                       :key="dict.value" | ||||
|                       :label="dict.label" | ||||
|                       :value="dict.value" | ||||
|                     /> | ||||
|                   </el-select> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="专业" prop="stuMajor"> | ||||
|                   <el-input v-model="ruleForm.stuMajor"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="手机号" prop="stuNumber"> | ||||
|                   <el-input v-model="ruleForm.stuNumber"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|             </el-row> | ||||
|           </div> | ||||
| 
 | ||||
|           <!-- 盲样邮寄地址 --> | ||||
|           <div class="kuang"> | ||||
|             <h2 class="tab_title tab_down_line">盲样邮寄地址</h2> | ||||
|             <el-row :gutter="20"> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="收件人" prop="sampleConcat"> | ||||
|                   <el-input v-model="ruleForm.sampleConcat"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="联系电话" prop="sampleNumber"> | ||||
|                   <el-input v-model="ruleForm.sampleNumber"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|               <el-col :span="8"> | ||||
|                 <el-form-item label="邮寄地址" prop="sampleAddress"> | ||||
|                   <el-input v-model="ruleForm.sampleAddress"></el-input> | ||||
|                 </el-form-item> | ||||
|               </el-col> | ||||
|             </el-row> | ||||
|           </div> | ||||
| 
 | ||||
|           <!-- 提交按钮 --> | ||||
|           <div style="text-align: center"> | ||||
|             <el-form-item> | ||||
|               <el-button style="margin-left: -120px" type="primary" @click="submitForm">提交</el-button> | ||||
|             </el-form-item> | ||||
|           </div> | ||||
| 
 | ||||
|           <div style="width: 100%;display: flex;align-items: center;justify-content: space-between;padding: 4px 10px"> | ||||
|             <div style="font-size: 16px;font-weight: bold"> | ||||
|               教师信息 | ||||
|             </div> | ||||
| 
 | ||||
|             <el-button type="primary" icon="el-icon-plus">新增</el-button> | ||||
| 
 | ||||
|           </div> | ||||
|           <div class="kuang" v-for="(item, index) in ruleForm.teacherlsit" :key="index" > | ||||
|             <div class="d-s"> | ||||
|               <el-form-item label="领队教师姓名" prop="name"> | ||||
|                 <el-input v-model="item.name" style="width: 260px"></el-input> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="领队教师职务" prop="name"> | ||||
|                 <el-input v-model="item.duties" style="width: 260px"></el-input> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="领队教师手机" prop="name"> | ||||
|                 <el-input v-model="item.tel" style="width: 260px"></el-input> | ||||
|               </el-form-item> | ||||
|             </div> | ||||
|             <div class="d-s"> | ||||
|               <el-form-item label="领队教师E-mail" prop="name"> | ||||
|                 <el-input v-model="item.Email" style="width: 260px"></el-input> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="领队教师所在系及专业" prop="name"> | ||||
|                 <el-input v-model="item.details" style="width: 260px"></el-input> | ||||
|               </el-form-item> | ||||
|             </div> | ||||
|           </div> | ||||
|           <div style="width: 100%;display: flex;align-items: center;justify-content: space-between;padding: 4px 10px"> | ||||
|             <div style="font-size: 16px;font-weight: bold"> | ||||
|               参赛队员信息 | ||||
|             </div> | ||||
| 
 | ||||
|             <el-button type="primary" icon="el-icon-plus">新增</el-button> | ||||
| 
 | ||||
|           </div> | ||||
|           <div class="kuang" v-for="(item, index) in ruleForm.studentlist" :key="index" > | ||||
|             <div class="d-s"> | ||||
|               <el-form-item label="参赛队员姓名" prop="name"> | ||||
|                 <el-input v-model="item.name" style="width: 260px"></el-input> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="参赛队员性别" prop="name"> | ||||
|                 <el-input v-model="item.duties" style="width: 260px"></el-input> | ||||
|               </el-form-item> | ||||
|               <el-form-item label="参赛队员手机号" prop="name"> | ||||
|                 <el-input v-model="item.tel" style="width: 260px"></el-input> | ||||
|               </el-form-item> | ||||
|             </div> | ||||
|             <div class="d-s"> | ||||
|               <el-form-item label="参赛队员专业" prop="name"> | ||||
|                 <el-input v-model="item.details" style="width: 260px"></el-input> | ||||
|               </el-form-item> | ||||
| 
 | ||||
|             </div> | ||||
|           </div> | ||||
|           <div style="width: 100%;display: flex;align-items: center;justify-content: space-between;padding: 4px 10px"> | ||||
|             <div style="font-size: 16px;font-weight: bold"> | ||||
|               盲样邮寄地址 | ||||
|             </div> | ||||
| 
 | ||||
|           </div> | ||||
|           <div class="d-s"> | ||||
|             <el-form-item label="盲样收件人及联系电话" prop="name"> | ||||
|               <el-input style="width: 300px" v-model="ruleForm.name"></el-input> | ||||
|             </el-form-item> | ||||
|             <el-form-item label="邮寄地址" prop="name"> | ||||
|               <el-input style="width: 300px" v-model="ruleForm.name"></el-input> | ||||
|             </el-form-item> | ||||
|           </div> | ||||
| 
 | ||||
|         </el-form> | ||||
|         <div style="display: flex;justify-content: center"> | ||||
|           <el-button type="primary" >确认提交</el-button> | ||||
|         </div> | ||||
| 
 | ||||
|       </div> | ||||
|       <!-- main --> | ||||
|       <div v-if="currentActive == 3" v-html="nav[3].children.list[0].contentDetail"></div> | ||||
|       <div v-if="currentActive == 3" v-html="nav[currentActive].children.list[0].contentDetail"></div> | ||||
|       <div v-for="(item, index) in nav " :key=index> | ||||
|         <div class="about-conts-item1" v-if="currentActive == index"> | ||||
|           <div  v-if="currentActive == 0 || currentActive == 1  " class="neirong" v-html="pageContextList[index]"></div> | ||||
| 
 | ||||
|         </div> | ||||
|       </div> | ||||
|       <div v-if="currentActive  == 2 " class="wrapbox"> | ||||
|         <div class="rsr"    v-for="(item,index) in nav[2].children.list" @click="goDeatail(item)" > | ||||
|         <div class="rsr"    v-for="(item,index) in nav[currentActive].children.list" @click="goDeatail(item)" > | ||||
|           <img  :src=" imgurl + item.contentImg" style="width: 255px;height: 220px"> | ||||
|           <div class="size-t">{{item.contentTitle}}</div> | ||||
|         </div> | ||||
|       </div> | ||||
|       <div v-if="currentActive  == 4 " class="wrapbox"> | ||||
|         <div class="rsr"   v-for="(item,index) in nav[2].children.list" @click="goDeatail(item)" > | ||||
|         <div class="newRsr"   v-for="(item,index) in nav[currentActive].children.list" @click="goDeatail(item)" > | ||||
|           <img  :src=" imgurl + item.contentImg" style="width: 255px;height: 220px"> | ||||
|           <div class="size-t">{{item.contentTitle}}</div> | ||||
|         </div> | ||||
|       </div> | ||||
|       <div v-show="currentActive == 2 || currentActive ==4" > | ||||
|       <div v-if="currentActive  == 5 " class="wrapbox"> | ||||
|         <div class="noticeRsr"   v-for="(item,index) in noticeList" @click="goDeatail(item)" > | ||||
|             <div >{{item.contentTitle}}</div> | ||||
|             <div >{{item.publishDate}}</div> | ||||
|         </div> | ||||
|       </div> | ||||
|       <div v-show="currentActive == 2 || currentActive == 4 || currentActive === 5" > | ||||
|           <page-util :category-id="categoryId" @event-message="handleDataFromPage" /> | ||||
|       </div> | ||||
|       <div class="anniu" v-show="currentActive == 1 " >去报名</div> | ||||
|       <div class="anniu" v-if="registerStatus == 1 && currentActive == 0" @click="toRegister" >去报名</div> | ||||
|     </div> | ||||
| 
 | ||||
|     <footers></footers> | ||||
| @ -151,6 +252,8 @@ import { getPageData, getPageColumn,getbaseInfo } from "@/api/officialWebsite/ge | ||||
| import footers from '@/views/officialWebsite/Components/footer.vue' | ||||
| import headers from '@/views/officialWebsite/Components/header.vue' | ||||
| import PageUtil from '@/views/officialWebsite/Components/page' | ||||
| import {addTeacher, register} from '@/api/officialWebsite/registerStudent' | ||||
| import {getTab, getbanner} from '@/api/gw/home' | ||||
| export default { | ||||
|   components: { | ||||
|     headers, | ||||
| @ -159,6 +262,7 @@ export default { | ||||
|     SwiperSlide, | ||||
|     "page-util": PageUtil | ||||
|   }, | ||||
|   dicts: ["sys_user_sex"], | ||||
|   name: 'HelloWorld', | ||||
|   props: { | ||||
|     msg: String | ||||
| @ -168,19 +272,72 @@ export default { | ||||
|       registerStatus:0, | ||||
|       imgurl:process.env.VUE_APP_BASE_API, | ||||
|       ruleForm: { | ||||
| 
 | ||||
|         name: '', | ||||
|         teacherlsit:[ | ||||
|           {} | ||||
|         division: null, | ||||
|         schoolName: null, | ||||
|         teamName: null, | ||||
|         teachers: [ | ||||
|           { | ||||
|             teacherName: null, | ||||
|             teacherJob: null, | ||||
|             teacherNumber: null, | ||||
|             teacherEmail: null, | ||||
|             teacherSchool: null | ||||
|           }, | ||||
|           { | ||||
|             teacherName: null, | ||||
|             teacherJob: null, | ||||
|             teacherNumber: null, | ||||
|             teacherEmail: null, | ||||
|             teacherSchool: null | ||||
|           }, | ||||
|           { | ||||
|             teacherName: null, | ||||
|             teacherJob: null, | ||||
|             teacherNumber: null, | ||||
|             teacherEmail: null, | ||||
|             teacherSchool: null | ||||
|           } | ||||
|         ], | ||||
|         studentlist:[ | ||||
|           {} | ||||
|         ] | ||||
|         stuName: null, | ||||
|         stuGender: null, | ||||
|         stuMajor: null, | ||||
|         stuNumber: null, | ||||
|         leaderIds: [], | ||||
|         guideIds: [], | ||||
|         sampleConcat: null, | ||||
|         sampleNumber: null, | ||||
|         sampleAddress: null | ||||
|       }, | ||||
|       rules: { | ||||
|         name: [ | ||||
|           { required: true, message: '请输入活动名称', trigger: 'blur' }, | ||||
|           { min: 3, max: 5, message: '长度在 3 到 5 个字符', trigger: 'blur' } | ||||
|         stuName: [ | ||||
|           { required: true, message: "姓名不能为空", trigger: "blur" } | ||||
|         ], | ||||
|         stuGender: [ | ||||
|           { required: true, message: "性别不能为空", trigger: "blur" } | ||||
|         ], | ||||
|         stuMajor: [ | ||||
|           { required: true, message: "专业不能为空", trigger: "blur" } | ||||
|         ], | ||||
|         stuNumber: [ | ||||
|           { required: true, message: "手机号不能为空", trigger: "blur" } | ||||
|         ], | ||||
|         schoolName: [ | ||||
|           { required: true, message: "学校及院系名称不能为空", trigger: "blur" } | ||||
|         ], | ||||
|         division: [ | ||||
|           { required: true, message: "所属赛区不能为空", trigger: "blur" } | ||||
|         ], | ||||
|         teamName: [ | ||||
|           { required: true, message: "参赛团队名称不能为空", trigger: "blur" } | ||||
|         ], | ||||
|         sampleConcat: [ | ||||
|           { required: true, message: "收件人不能为空", trigger: "blur" } | ||||
|         ], | ||||
|         sampleNumber: [ | ||||
|           { required: true, message: "联系电话不能为空", trigger: "blur" } | ||||
|         ], | ||||
|         sampleAddress: [ | ||||
|           { required: true, message: "邮寄地址不能为空", trigger: "blur" } | ||||
|         ], | ||||
|       }, | ||||
|       pageContextList: [], | ||||
| @ -195,6 +352,7 @@ export default { | ||||
|       isMounted: false, | ||||
|       input4: "", | ||||
|       categoryId: "", | ||||
|       noticeList:[], | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
| @ -204,7 +362,9 @@ export default { | ||||
|   computed: { | ||||
| 
 | ||||
|   }, | ||||
| 
 | ||||
|   created() { | ||||
|     this.createRules() | ||||
|   }, | ||||
|   methods: { | ||||
|     goDeatail(data){ | ||||
|       // console.log(data) | ||||
| @ -218,6 +378,25 @@ export default { | ||||
|         window.open(data.link, '_blank'); | ||||
|       } | ||||
|     }, | ||||
|     createRules(){ | ||||
|       for (let i =  0; i < 3; i++){ | ||||
|         this.rules[`teachers.${i}.teacherName`] = [ | ||||
|           {required: true, message: '姓名不能为空', trigger: "blur"} | ||||
|         ] | ||||
|         this.rules[`teachers.${i}.teacherJob`] = [ | ||||
|           {required: true, message: '职务不能为空', trigger: "blur"} | ||||
|         ] | ||||
|         this.rules[`teachers.${i}.teacherNumber`] = [ | ||||
|           {required: true, message: '电话不能为空', trigger: "blur"} | ||||
|         ] | ||||
|         this.rules[`teachers.${i}.teacherEmail`] = [ | ||||
|           {required: true, message: 'mail不能为空', trigger: "blur"} | ||||
|         ] | ||||
|         this.rules[`teachers.${i}.teacherSchool`] = [ | ||||
|           {required: true, message: '所在系及专业不能为空', trigger: "blur"} | ||||
|         ] | ||||
|       } | ||||
|     }, | ||||
|     // 触发导航 | ||||
|     getCurrentActive(value) { | ||||
|       if (this.currentActive == value) { | ||||
| @ -225,7 +404,7 @@ export default { | ||||
|       } | ||||
| 
 | ||||
|       this.currentActive = value | ||||
|       this.categoryId = this.nav[value].id | ||||
|       this.categoryId = value === 5 ? this.getNoticeId() : this.nav[value].id; | ||||
|       // console.log(this.nav,'nav' ) | ||||
|     }, | ||||
|     initPageData() { | ||||
| @ -257,12 +436,97 @@ export default { | ||||
|       }); | ||||
| 
 | ||||
| 
 | ||||
|     }, | ||||
|     getNoticeId(){ | ||||
|       getTab().then(res => { | ||||
|         const query = { | ||||
|           "categoryId": res.data[0].id, | ||||
|           "pageNum": 1, | ||||
|           "pageSize": 10 | ||||
|         } | ||||
|         getbanner(query).then(res => { | ||||
|           this.categoryId = res.data[1].id | ||||
|         }) | ||||
|       }) | ||||
|     }, | ||||
|     handleDataFromPage(data){ | ||||
|       if (this.currentActive === 2 || this.currentActive == 4){ | ||||
|         this.nav[this.currentActive].children.list = data | ||||
|       } | ||||
|     } | ||||
|       if (this.currentActive === 5){ | ||||
|         console.log(data) | ||||
|         this.noticeList = data | ||||
|       } | ||||
|     }, | ||||
|     toRegister(){ | ||||
|       if (this.registerStatus === '1') this.currentActive = 6; | ||||
|     }, | ||||
|     submitForm(){ | ||||
|       this.$refs["form"].validate(valid => { | ||||
|         if (valid){ | ||||
|           const leader = this.ruleForm.teachers[0] | ||||
|           const guides = this.ruleForm.teachers.slice(1) | ||||
|           addTeacher(leader).then(res => { | ||||
|             this.ruleForm.leaderIds.push(res.data) | ||||
|           }) | ||||
|           guides.forEach(item => { | ||||
|             addTeacher(item).then(res => { | ||||
|               this.ruleForm.guideIds.push(res.data) | ||||
|             }) | ||||
|           }) | ||||
|           register(this.ruleForm).then(res => { | ||||
|             if (res.code === 200){ | ||||
|               this.reset(); | ||||
|               this.$modal.msgSuccess("报名成功") | ||||
|             }else ( | ||||
|               this.$modal.msgError("报名失败") | ||||
|             ) | ||||
|           }) | ||||
|         }else { | ||||
|           this.$modal.msgError("信息未填完整") | ||||
|         } | ||||
|       }) | ||||
|     }, | ||||
|     reset(){ | ||||
|       this.ruleForm = { | ||||
|         division: null, | ||||
|           schoolName: null, | ||||
|           teamName: null, | ||||
|           teachers: [ | ||||
|           { | ||||
|             teacherName: null, | ||||
|             teacherJob: null, | ||||
|             teacherNumber: null, | ||||
|             teacherEmail: null, | ||||
|             teacherSchool: null | ||||
|           }, | ||||
|           { | ||||
|             teacherName: null, | ||||
|             teacherJob: null, | ||||
|             teacherNumber: null, | ||||
|             teacherEmail: null, | ||||
|             teacherSchool: null | ||||
|           }, | ||||
|           { | ||||
|             teacherName: null, | ||||
|             teacherJob: null, | ||||
|             teacherNumber: null, | ||||
|             teacherEmail: null, | ||||
|             teacherSchool: null | ||||
|           } | ||||
|         ], | ||||
|           stuName: null, | ||||
|           stuGender: null, | ||||
|           stuMajor: null, | ||||
|           stuNumber: null, | ||||
|           leaderIds: [], | ||||
|           guideIds: [], | ||||
|           sampleConcat: null, | ||||
|           sampleNumber: null, | ||||
|           sampleAddress: null | ||||
|       } | ||||
|       this.resetForm("form"); | ||||
|     }, | ||||
|   } | ||||
| 
 | ||||
| } | ||||
| @ -404,6 +668,10 @@ export default { | ||||
| .rsr{ | ||||
|   width: 20%; | ||||
| } | ||||
| .newRsr{ | ||||
|   width: 25%; | ||||
|   text-align: center; | ||||
| } | ||||
| .ny-banner { | ||||
|   width: 100%; | ||||
| } | ||||
| @ -735,4 +1003,29 @@ export default { | ||||
|   height: 50px; | ||||
|   text-align: center; | ||||
| } | ||||
| .tab_title{ | ||||
|   display: inline-block; | ||||
|   width: 100%; | ||||
|   text-align: center; | ||||
|   margin: 0 0 1rem 0; | ||||
|   padding: 0.5rem; | ||||
| } | ||||
| .tab_down_line{ | ||||
|   border-bottom: 1px solid #ccc; | ||||
| } | ||||
| .neirong{ | ||||
|   width: 100%; /* 或者使用具体的像素值 */ | ||||
|   height: 100%; /* 或者使用具体的像素值 */ | ||||
| } | ||||
| .noticeRsr{ | ||||
|   width: 100%; | ||||
|   padding: 1rem; | ||||
|   display: flex; | ||||
|   justify-content: space-between; | ||||
|   font-size: 20px; | ||||
| } | ||||
| .noticeRsr:hover{ | ||||
|   color: #00A0E8; | ||||
|   cursor: pointer; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -591,5 +591,6 @@ export default { | ||||
| .page-box{ | ||||
|   width: 80%; | ||||
|   margin: 10px auto; | ||||
|   text-align: center; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -313,6 +313,7 @@ export default { | ||||
| .page-box{ | ||||
|   width: 82%; | ||||
|   margin: 10px auto; | ||||
|   text-align: center; | ||||
| } | ||||
| 
 | ||||
| .news .news-item { | ||||
|  | ||||
| @ -340,6 +340,7 @@ export default { | ||||
| .page-box{ | ||||
|   width: 82%; | ||||
|   margin: 10px auto; | ||||
|   text-align: center; | ||||
| } | ||||
| 
 | ||||
| .teaching .teaching-list { | ||||
|  | ||||
| @ -139,7 +139,7 @@ export default { | ||||
|         imitationId(data.id).then(res=>{ | ||||
|           console.log(res,'调用成功') | ||||
|         }) | ||||
|         window.open(data.link, '_blank'); | ||||
|         window.open(data.imitationLink, '_blank'); | ||||
| 
 | ||||
|     }, | ||||
| 
 | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user