index.vue 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. <template>
  2. <view class="ezy-study-page">
  3. <view class="study-school-year">{{gradeTerm}}</view>
  4. <view class="ezy-study-wrap">
  5. <view class="chapter-box" @click="handleCheckCatalogue">{{infoData.numberStr}}</view>
  6. <view class="chapter-title-box">{{infoData.zhangName}}</view>
  7. <view>
  8. <view class="brand-item" v-for="(item,index) in infoData.jieList" :key="index" @click="listClick(item)"
  9. :class= "index ==0?'brand-active':''">
  10. <view class="brand-icon" v-if="index ==0">1</view>
  11. <view class="brand-lock" v-else></view>
  12. <view class="brand-content">{{item.jieName}}</view>
  13. </view>
  14. </view>
  15. </view>
  16. <!-- <uni-button style="margin-top: 200px;display: block;" @click="goKaoshi">goKaoshi</uni-button>
  17. -->
  18. <!-- <uni-button @click="handleCheckCatalogue">go catalogue</uni-button>
  19. <uni-button @click="goKaoshi">goKaoshi</uni-button>
  20. <!-- 蛋 -->
  21. <egg-dialog ref="eggDialogRef" @eggBtn="eggBtn"></egg-dialog>
  22. <catalogue ref="catalogueRef" :nianji="routeParams.nianji" :xueqi="routeParams.xueqi"
  23. @change-zhang="handleChangeZhang"></catalogue>
  24. <CustomTabBar></CustomTabBar>
  25. </view>
  26. </template>
  27. <script setup>
  28. import {
  29. userZhangFirstInfo,
  30. userZhangInfo,
  31. userLocate
  32. } from "@/api/learnPlan.js"
  33. import {
  34. reactive,
  35. ref,
  36. onMounted
  37. } from "vue";
  38. import {
  39. onLoad,
  40. } from '@dcloudio/uni-app';
  41. import catalogue from "@/components/catalogue/catalogue.vue";
  42. import CustomTabBar from '@/components/custom-tabbar/custom-tabbar.vue';
  43. import {
  44. getAuth
  45. } from '@/utils/auth.js';
  46. import eggDialog from './eggDialog.vue'
  47. const eggDialogRef = ref(null);
  48. const catalogueRef = ref(null);
  49. let gradeTerm = ref('');
  50. const selectZhang = ref(null);
  51. let infoData = reactive({
  52. jieList: [],
  53. haveFlag: '',
  54. nianji: '',
  55. number: '',
  56. xueqi: '',
  57. zhangId: '',
  58. zhangName: '',
  59. numberStr: '',
  60. });
  61. // 来自单元测试的路由参数缓存
  62. const gradeMapping = {
  63. 1: '一年级',
  64. 2: '二年级',
  65. 3: '三年级',
  66. 4: '四年级',
  67. 5: '五年级',
  68. 6: '六年级'
  69. };
  70. const termMapping = {
  71. 1: '上',
  72. 2: '下'
  73. };
  74. const routeParams = ref(null);
  75. onLoad((options) => {
  76. console.log(options)
  77. // 获取路由参数
  78. routeParams.value = options;
  79. // 选择年级进入调用此接口
  80. if (options.flag == 'selectGrades') {
  81. getZhangFirst()
  82. } else {
  83. getZhangInfo()
  84. }
  85. // 调用定位章节 (后台记录)
  86. // 蛋
  87. // eggDialogRef.value.eggShow();
  88. })
  89. function recordZhangJie() {
  90. let req = {
  91. nianji: routeParams.value.nianji,
  92. userId: JSON.parse(getAuth()).userId,
  93. zhangId: infoData.zhangId,
  94. xueqi: routeParams.value.xueqi,
  95. }
  96. userLocate(req).then(res => {
  97. })
  98. }
  99. function getZhangFirst() {
  100. let req = {
  101. nianji: routeParams.value.nianji,
  102. xueqi: routeParams.value.xueqi,
  103. }
  104. userZhangFirstInfo(req).then(res => {
  105. infoData.jieList = res.data.jieList
  106. infoData.haveFlag = res.data.haveFlag
  107. infoData.nianji = res.data.nianji
  108. infoData.number = res.data.number
  109. infoData.numberStr = res.data.numberStr
  110. infoData.xueqi = res.data.xueqi
  111. infoData.zhangId = res.data.zhangId
  112. infoData.zhangName = res.data.zhangName
  113. gradeTerm.value = translateData(res.data);
  114. recordZhangJie()
  115. })
  116. }
  117. function getZhangInfo() {
  118. let req = {
  119. nianji: routeParams.value.nianji,
  120. xueqi: routeParams.value.xueqi,
  121. zhangId: routeParams.value.zhangId,
  122. }
  123. userZhangInfo(req).then(res => {
  124. infoData.jieList = res.data.jieList
  125. infoData.haveFlag = res.data.haveFlag
  126. infoData.nianji = res.data.nianji
  127. infoData.number = res.data.number
  128. infoData.numberStr = res.data.numberStr
  129. infoData.xueqi = res.data.xueqi
  130. infoData.zhangId = res.data.zhangId
  131. infoData.zhangName = res.data.zhangName
  132. gradeTerm.value = translateData(res.data);
  133. recordZhangJie()
  134. })
  135. }
  136. function translateData(data) {
  137. return gradeMapping[data.nianji] + termMapping[data.xueqi]
  138. }
  139. function handleChangeZhang(data) {
  140. console.log("章", data);
  141. selectZhang.value = data;
  142. }
  143. function goKaoshi() {
  144. let zhangId = selectZhang.value.zhangId;
  145. let nianji = routeParams.value.nianji;
  146. let xueqi = routeParams.value.xueqi;
  147. uni.navigateTo({
  148. url: `/pages/unitTest/index?jieId=1&zhangId=${zhangId}&nianji=${nianji}&xueqi=${xueqi}`
  149. })
  150. }
  151. function listClick(data) {
  152. data.videoId = 'b997f16cb9cb474cb93526cff77d8801'
  153. data.progressMarkers = []
  154. data.zhangId = infoData.zhangId
  155. data.nianji = infoData.nianji
  156. data.xueqi = infoData.xueqi
  157. const pageData = {
  158. // videoId:data.videoId,
  159. videoId: 'b997f16cb9cb474cb93526cff77d8801',
  160. progressMarkers: [{
  161. offset: 30,
  162. isCustomized: true,
  163. coverUrl: 'https://alivc-demo-vod.aliyuncs.com/image/cover/9A3F562E595E4764AD1DD546FA52C6E5-6-2.png',
  164. title: 'test title',
  165. describe: 'test string',
  166. }, {
  167. offset: 150,
  168. isCustomized: true,
  169. coverUrl: 'https://alivc-demo-vod.aliyuncs.com/image/cover/1E7F402241CD4C0F94AD2BBB5CCC3EC7-6-2.png',
  170. title: 'test title',
  171. describe: 'test string',
  172. }, {
  173. offset: 250,
  174. isCustomized: true,
  175. coverUrl: 'https://alivc-demo-vod.aliyuncs.com/image/cover/553AEA01161342C8A2B1756E83B69B5B-6-2.png',
  176. title: 'test title',
  177. describe: 'test string',
  178. }, {
  179. offset: 550,
  180. isCustomized: true,
  181. coverUrl: 'https://alivc-demo-vod.aliyuncs.com/image/cover/553AEA01161342C8A2B1756E83B69B5B-6-2.png',
  182. title: 'test title',
  183. describe: 'test string',
  184. }, {
  185. offset: 320,
  186. isCustomized: true,
  187. coverUrl: 'https://alivc-demo-vod.aliyuncs.com/image/cover/553AEA01161342C8A2B1756E83B69B5B-6-2.png',
  188. title: 'test title',
  189. describe: 'test string',
  190. }, {
  191. offset: 650,
  192. isCustomized: true,
  193. coverUrl: 'https://alivc-demo-vod.aliyuncs.com/image/cover/553AEA01161342C8A2B1756E83B69B5B-6-2.png',
  194. title: 'test title',
  195. describe: 'test string',
  196. }],
  197. }
  198. uni.navigateTo({
  199. //url: '/pages/study/lookShipin?studyData=' + JSON.stringify(pageData)
  200. url: '/pages/study/lookShipin?studyData=' + JSON.stringify(data)
  201. })
  202. }
  203. function handleCheckCatalogue() {
  204. catalogueRef.value.showPopup();
  205. }
  206. function goBack() {
  207. uni.navigateBack()
  208. }
  209. function eggBtn() {
  210. console.log('点击:开启提分之旅');
  211. }
  212. </script>
  213. <style>
  214. </style>