浏览代码

Merge branch 'hqyDev' of http://git.dayaedu.com/lex/h5-colexiu into jenkins

黄琪勇 1 年之前
父节点
当前提交
576917fabe
共有 44 个文件被更改,包括 480 次插入329 次删除
  1. 2 1
      package.json
  2. 10 3
      src/components/col-header/index.module.less
  3. 8 3
      src/components/col-result/index.module.less
  4. 3 2
      src/components/col-search/index.module.less
  5. 1 0
      src/helpers/request.ts
  6. 1 1
      src/router/routes-student.ts
  7. 14 0
      src/router/routes-teacher.ts
  8. 1 1
      src/router/routes-tenant.ts
  9. 27 18
      src/tenant/exercise-record/exercis-detail.module.less
  10. 3 3
      src/tenant/exercise-record/exercis-detail.tsx
  11. 二进制
      src/tenant/exercise-record/images/icon-subject.png
  12. 二进制
      src/tenant/images/bg-image-1.png
  13. 二进制
      src/tenant/images/bg.png
  14. 5 4
      src/tenant/music/component/song/index.module.less
  15. 18 14
      src/tenant/music/component/song/index.tsx
  16. 二进制
      src/tenant/music/courseList/image/bg.png
  17. 二进制
      src/tenant/music/courseList/image/icon-list.png
  18. 二进制
      src/tenant/music/courseList/image/paly.png
  19. 35 17
      src/tenant/music/courseList/index.module.less
  20. 13 11
      src/tenant/music/courseList/index.tsx
  21. 2 2
      src/tenant/music/coursewarePlay/component/video-play.tsx
  22. 2 3
      src/tenant/music/coursewarePlay/component/video.module.less
  23. 0 0
      src/tenant/music/coursewarePlay/image/icons.json
  24. 25 20
      src/tenant/music/coursewarePlay/index.tsx
  25. 二进制
      src/tenant/music/lessonCourseware/component/CourseItem/image/bg.png
  26. 14 11
      src/tenant/music/lessonCourseware/component/CourseItem/index.module.less
  27. 19 18
      src/tenant/music/lessonCourseware/index.module.less
  28. 6 3
      src/tenant/music/lessonCourseware/index.tsx
  29. 0 0
      src/tenant/music/music-detail/animate/refresh_anim.json
  30. 2 2
      src/tenant/music/music-detail/download.module.less
  31. 4 3
      src/tenant/music/music-detail/new-index.module.less
  32. 5 4
      src/tenant/music/music-detail/new-index.tsx
  33. 25 11
      src/tenant/music/personal/index.module.less
  34. 1 1
      src/tenant/music/personal/tenant-album.tsx
  35. 29 27
      src/tenant/music/search/index.module.less
  36. 12 11
      src/tenant/music/train-list/index.module.less
  37. 2 1
      src/tenant/music/train-list/index.tsx
  38. 二进制
      src/tenant/music/train-tool/images/icon-timer.png
  39. 63 23
      src/tenant/music/train-tool/index.module.less
  40. 108 93
      src/tenant/music/train-tool/index.tsx
  41. 13 16
      src/tenant/trade/index.module.less
  42. 1 1
      src/tenant/trade/index.tsx
  43. 1 1
      src/views/article-center/help-center.tsx
  44. 5 0
      yarn.lock

+ 2 - 1
package.json

@@ -54,7 +54,8 @@
     "vue-echarts": "^6.2.3",
     "vue-echarts": "^6.2.3",
     "vue-router": "^4.0.12",
     "vue-router": "^4.0.12",
     "vue3-lottie": "^2.3.0",
     "vue3-lottie": "^2.3.0",
-    "vuex": "^4.0.2"
+    "vuex": "^4.0.2",
+    "yet-another-abortcontroller-polyfill": "^0.0.4"
   },
   },
   "devDependencies": {
   "devDependencies": {
     "@babel/core": "^7.16.5",
     "@babel/core": "^7.16.5",

+ 10 - 3
src/components/col-header/index.module.less

@@ -2,12 +2,19 @@
   --van-font-weight-bold: 600;
   --van-font-weight-bold: 600;
 
 
   :global {
   :global {
-
+    .van-nav-bar__left{
+      padding: 0 13px;
+    }
     .van-nav-bar__title,
     .van-nav-bar__title,
     .van-icon {
     .van-icon {
       color: inherit;
       color: inherit;
     }
     }
-
+    .van-nav-bar__title{
+      font-size: 18px;
+    }
+    .van-icon{
+      font-size: 24px;
+    }
     .van-nav-bar__right {
     .van-nav-bar__right {
       &>div {
       &>div {
         line-height: 0;
         line-height: 0;
@@ -27,4 +34,4 @@
   // :global(.van-nav-bar--fixed) {
   // :global(.van-nav-bar--fixed) {
   //   box-shadow: 10px 10px 10px var(--box-shadow-color);
   //   box-shadow: 10px 10px 10px var(--box-shadow-color);
   // }
   // }
-}
+}

+ 8 - 3
src/components/col-result/index.module.less

@@ -21,6 +21,7 @@
     }
     }
 
 
     .van-empty__description {
     .van-empty__description {
+      margin-top: 8px;
       padding: 0 30px;
       padding: 0 30px;
     }
     }
   }
   }
@@ -28,8 +29,12 @@
   .SMALL {
   .SMALL {
     :global {
     :global {
       .van-empty__image {
       .van-empty__image {
-        width: 182px;
-        height: 161px;
+        width: 220px;
+        height: 195px;
+      }
+      .van-empty__description {
+        margin-top: -15px;
+        padding: 0 30px;
       }
       }
     }
     }
   }
   }
@@ -46,4 +51,4 @@
       }
       }
     }
     }
   }
   }
-}
+}

+ 3 - 2
src/components/col-search/index.module.less

@@ -1,7 +1,7 @@
 :global {
 :global {
   .van-search {
   .van-search {
-    padding-left: 14px;
-    padding-right: 14px;
+    padding-left: 13px;
+    padding-right: 13px;
 
 
     input {
     input {
       -webkit-user-select: text !important;
       -webkit-user-select: text !important;
@@ -112,6 +112,7 @@
     height: 28px;
     height: 28px;
     padding: 0;
     padding: 0;
     font-size: 14px;
     font-size: 14px;
+    font-weight: 500;
     --van-button-mini-height: 28px;
     --van-button-mini-height: 28px;
     --van-font-size-xs: 14px;
     --van-font-size-xs: 14px;
     line-height: 1;
     line-height: 1;

+ 1 - 0
src/helpers/request.ts

@@ -4,6 +4,7 @@ import { browser, openLoading, closeLoading } from '@/helpers/utils'
 import { setLogout, setLoginError } from '@/state'
 import { setLogout, setLoginError } from '@/state'
 import { postMessage } from './native-message'
 import { postMessage } from './native-message'
 import { Toast } from 'vant'
 import { Toast } from 'vant'
+import 'yet-another-abortcontroller-polyfill'
 
 
 export interface SearchInitParams {
 export interface SearchInitParams {
   rows?: string | number
   rows?: string | number

+ 1 - 1
src/router/routes-student.ts

@@ -93,7 +93,7 @@ export default [
         name: 'memberRecord',
         name: 'memberRecord',
         component: () => import('@/student/member-center/member-record'),
         component: () => import('@/student/member-center/member-record'),
         meta: {
         meta: {
-          title: '练统计'
+          title: '练统计'
         }
         }
       },
       },
       {
       {

+ 14 - 0
src/router/routes-teacher.ts

@@ -325,6 +325,20 @@ export default [
         meta: {
         meta: {
           title: '训练教程'
           title: '训练教程'
         }
         }
+      },
+      {
+        path: '/courseList',
+        component: () => import('@/tenant/music/courseList'),
+        meta: {
+          title: '教程详情'
+        }
+      },
+      {
+        path: '/coursewarePlay',
+        component: () => import('@/tenant/music/coursewarePlay'),
+        meta: {
+          title: '教程播放'
+        }
       }
       }
     ]
     ]
   },
   },

+ 1 - 1
src/router/routes-tenant.ts

@@ -274,7 +274,7 @@ export default [
         name: 'memberRecord',
         name: 'memberRecord',
         component: () => import('@/tenant/exercise-record/exercis-detail'),
         component: () => import('@/tenant/exercise-record/exercis-detail'),
         meta: {
         meta: {
-          title: '练统计'
+          title: '练统计'
         }
         }
       },
       },
       {
       {

+ 27 - 18
src/tenant/exercise-record/exercis-detail.module.less

@@ -1,19 +1,31 @@
 .exercisContainer {
 .exercisContainer {
   :global {
   :global {
-
     .van-calendar__day--end,
     .van-calendar__day--end,
     .van-calendar__day--start,
     .van-calendar__day--start,
     .van-calendar__day--start-end,
     .van-calendar__day--start-end,
     .van-calendar__day--multiple-middle,
     .van-calendar__day--multiple-middle,
     .van-calendar__day--multiple-selected {
     .van-calendar__day--multiple-selected {
-      background: #FF5074;
+      background: #ff5074;
     }
     }
 
 
     .van-overlay,
     .van-overlay,
     .van-popup {
     .van-popup {
       z-index: 99999999 !important;
       z-index: 99999999 !important;
+      .van-calendar__header-title,
+      .van-calendar__header-subtitle {
+        color: #131415;
+      }
+      .van-calendar__weekday {
+        color: #333;
+      }
+      .van-calendar__day--middle,
+      .van-calendar__day--end {
+        font-weight: 500;
+      }
+      .van-popup__close-icon {
+        color: rgba(0, 0, 0, 0.4);
+      }
     }
     }
-
   }
   }
 
 
   .bgImg {
   .bgImg {
@@ -41,7 +53,6 @@
     }
     }
   }
   }
 
 
-
   .level {
   .level {
     margin-top: -4px;
     margin-top: -4px;
     width: 44px;
     width: 44px;
@@ -104,15 +115,16 @@
   .subjectTag {
   .subjectTag {
     font-size: 12px;
     font-size: 12px;
     font-weight: 500;
     font-weight: 500;
-    color: #FE2451;
-    padding: 1px 7px;
+    color: #fe2451;
+    padding: 3px 7px;
     background: rgba(255, 255, 255, 0.3);
     background: rgba(255, 255, 255, 0.3);
     border-radius: 20px;
     border-radius: 20px;
-    border: 1px solid #FFFFFF;
+    border: 1px solid #ffffff;
     display: inline-flex;
     display: inline-flex;
     align-items: center;
     align-items: center;
-    line-height: 1;
-
+    .name{
+      line-height: 1;
+    }
     .iconSubject {
     .iconSubject {
       width: 13px;
       width: 13px;
       height: 13px;
       height: 13px;
@@ -195,7 +207,7 @@
         top: 12px;
         top: 12px;
         width: 1px;
         width: 1px;
         height: 35px;
         height: 35px;
-        background-color: #E0E5E8;
+        background-color: #e0e5e8;
       }
       }
     }
     }
 
 
@@ -234,7 +246,6 @@
       }
       }
     }
     }
   }
   }
-
 }
 }
 
 
 .trainWeek {
 .trainWeek {
@@ -265,19 +276,19 @@
       margin-right: 20px;
       margin-right: 20px;
 
 
       .DataTopRightDot {
       .DataTopRightDot {
-        background-color: #FF7AA7;
+        background-color: #ff7aa7;
       }
       }
     }
     }
 
 
     &:last-child {
     &:last-child {
       .DataTopRightDot {
       .DataTopRightDot {
-        background-color: #3583FA;
+        background-color: #3583fa;
       }
       }
     }
     }
 
 
     &.DataTopRightItemDis {
     &.DataTopRightItemDis {
       .DataTopRightDot {
       .DataTopRightDot {
-        background-color: #e8e8e8 !important
+        background-color: #e8e8e8 !important;
       }
       }
     }
     }
 
 
@@ -307,8 +318,6 @@
       font-size: 14px;
       font-size: 14px;
       color: rgba(19, 20, 21, 0.6);
       color: rgba(19, 20, 21, 0.6);
 
 
-
-
       .iconArrow {
       .iconArrow {
         display: inline-block;
         display: inline-block;
         width: 9px;
         width: 9px;
@@ -322,11 +331,11 @@
 }
 }
 
 
 .fullRefresh {
 .fullRefresh {
-  min-height: calc(100vh - var(--header-height) - 275px)
+  min-height: calc(100vh - var(--header-height) - 275px);
 }
 }
 
 
 .emptyContainer {
 .emptyContainer {
   height: calc(100vh - var(--header-height) - 275px);
   height: calc(100vh - var(--header-height) - 275px);
   display: flex;
   display: flex;
   align-items: center;
   align-items: center;
-}
+}

+ 3 - 3
src/tenant/exercise-record/exercis-detail.tsx

@@ -267,17 +267,17 @@ export default defineComponent({
                 title: () => (
                 title: () => (
                   <div class={styles.userInfo}>
                   <div class={styles.userInfo}>
                     <span class={styles.name}>{userInfo.value.username}</span>
                     <span class={styles.name}>{userInfo.value.username}</span>
-                    <Image
+                    {/* <Image
                       class={styles.level}
                       class={styles.level}
                       src={userInfo.value.isVip ? iconLogoActive : iconLogo}
                       src={userInfo.value.isVip ? iconLogoActive : iconLogo}
-                    />
+                    /> */}
                   </div>
                   </div>
                 ),
                 ),
                 label: () => (
                 label: () => (
                   <div class={styles.subjectName}>
                   <div class={styles.subjectName}>
                     <span class={styles.subjectTag}>
                     <span class={styles.subjectTag}>
                       <img src={iconSubject} class={styles.iconSubject} />
                       <img src={iconSubject} class={styles.iconSubject} />
-                      {userInfo.value.subjectName}
+                      <div class={styles.name}>{userInfo.value.subjectName}</div>
                     </span>
                     </span>
                   </div>
                   </div>
                 )
                 )

二进制
src/tenant/exercise-record/images/icon-subject.png


二进制
src/tenant/images/bg-image-1.png


二进制
src/tenant/images/bg.png


+ 5 - 4
src/tenant/music/component/song/index.module.less

@@ -96,6 +96,7 @@
       }
       }
 
 
       .tags {
       .tags {
+        margin-right: 6px;
 
 
         &>span {
         &>span {
           display: inline-block;
           display: inline-block;
@@ -115,9 +116,9 @@
     }
     }
 
 
     .title {
     .title {
-      max-width: 165px;
+      max-width: 220px;
       font-size: 16px;
       font-size: 16px;
-      font-weight: bold;
+      font-weight: 600;
       color: #1a1a1a;
       color: #1a1a1a;
       margin-right: 6px;
       margin-right: 6px;
     }
     }
@@ -161,7 +162,7 @@
 .collection {
 .collection {
   width: 15px;
   width: 15px;
   height: 16px;
   height: 16px;
-  margin-right: 4px;
+  margin-right: 6px;
 }
 }
 
 
 .musicInfo {
 .musicInfo {
@@ -271,4 +272,4 @@
   height: 15px;
   height: 15px;
   margin-right: 5px;
   margin-right: 5px;
   flex-shrink: 0;
   flex-shrink: 0;
-}
+}

+ 18 - 14
src/tenant/music/component/song/index.tsx

@@ -60,20 +60,20 @@ export default defineComponent({
     //   }
     //   }
     // }
     // }
 
 
-    const list = computed(() => {
-      return props.list.map(n => {
-        // if (typeof n.paymentType === 'string')
-        //   n.paymentType = n.paymentType.split(',')
-        n.subjectNames = n.musicSubjectName
-        return { ...n }
-      })
-    })
+    // const list = computed(() => {
+    //   return props.list.map(n => {
+    //     // if (typeof n.paymentType === 'string')
+    //     //   n.paymentType = n.paymentType.split(',')
+    //     n.subjectNames = n.musicSubjectName
+    //     return { ...n }
+    //   })
+    // })
 
 
     return () => {
     return () => {
       return (
       return (
         <div class={styles.theSong}>
         <div class={styles.theSong}>
-          {list.value.map((n: any, index: number) => (
-            <div class={styles.item} onClick={() => emit('detail', n)}>
+          {props.list.map((n: any, index: number) => (
+            <div class={[styles.item,'songItem']} onClick={() => emit('detail', n)}>
               {props.showNumber && <div class={styles.num}>{index + 1}</div>}
               {props.showNumber && <div class={styles.num}>{index + 1}</div>}
               {props.showTitleImg && (
               {props.showTitleImg && (
                 <div class={styles.cover}>
                 <div class={styles.cover}>
@@ -108,10 +108,14 @@ export default defineComponent({
                   )}
                   )}
 
 
                   <div class={styles.tags}>
                   <div class={styles.tags}>
-                    {n.subjectNames &&
-                      n.subjectNames
-                        ?.split(',')
-                        .map((name: any) => <span>{name}</span>)}
+                    {n.subjectNames
+                      ? n.subjectNames
+                          ?.split(',')
+                          .map((name: any) => <span>{name}</span>)
+                      : n.musicSubjectName &&
+                        n.musicSubjectName
+                          ?.split(',')
+                          .map((name: any) => <span>{name}</span>)}
                     {n.musicSheetType === 'CONCERT' && <span>合奏</span>}
                     {n.musicSheetType === 'CONCERT' && <span>合奏</span>}
                   </div>
                   </div>
 
 

二进制
src/tenant/music/courseList/image/bg.png


二进制
src/tenant/music/courseList/image/icon-list.png


二进制
src/tenant/music/courseList/image/paly.png


+ 35 - 17
src/tenant/music/courseList/index.module.less

@@ -1,7 +1,7 @@
 .courseList {
 .courseList {
   min-height: 100vh;
   min-height: 100vh;
   background-image: url('../../images/bg.png');
   background-image: url('../../images/bg.png');
-  background-size: 100% 214px;
+  background-size: 100% 346px;
   background-repeat: no-repeat;
   background-repeat: no-repeat;
   box-sizing: border-box;
   box-sizing: border-box;
 }
 }
@@ -17,12 +17,9 @@
     margin-right: 30px;
     margin-right: 30px;
     border-radius: 2px;
     border-radius: 2px;
     overflow: hidden;
     overflow: hidden;
-    box-shadow: 0px 2px 6px 0px rgba(221, 168, 133, 0.67);
     overflow: hidden;
     overflow: hidden;
-    background: url('');
-    background-repeat: no-repeat;
-    background-position: center;
-    background-size: 50%;
+    background: url('./image/bg.png') no-repeat;
+    background-size: 100% 100%;
     flex-shrink: 0;
     flex-shrink: 0;
 
 
     & > img {
     & > img {
@@ -152,19 +149,38 @@
   }
   }
 }
 }
 
 
-.basePlay {
-  width: 20px;
-  height: 20px;
-}
 .circleProgress {
 .circleProgress {
-  width: 20px;
-  height: 20px;
+  width: 24px;
+  height: 24px;
+  position: relative;
+  .basePlay {
+    width: 20px;
+    height: 20px;
+    position: absolute;
+    left: 50%;
+    top: 50%;
+    transform: translate(-50%, -50%);
+  }
   :global {
   :global {
     .van-circle {
     .van-circle {
+      position: absolute;
+      left: 50%;
+      top: 50%;
+      transform: translate(-50%, -50%);
       width: 20px;
       width: 20px;
       height: 20px;
       height: 20px;
     }
     }
   }
   }
+  .tips {
+    position: absolute;
+    left: 50%;
+    top: 50%;
+    transform: translate(-50%, -50%);
+    width: 6.5px;
+    height: 6.5px;
+    background: #b3b3b3;
+    border-radius: 1px;
+  }
 }
 }
 .periodItem {
 .periodItem {
   width: 36px;
   width: 36px;
@@ -182,7 +198,7 @@
 
 
 .courseDialog {
 .courseDialog {
   width: 305px;
   width: 305px;
-
+  box-sizing: border-box;
   :global {
   :global {
     .van-dialog__header {
     .van-dialog__header {
       // padding-top: 0;
       // padding-top: 0;
@@ -285,6 +301,7 @@
     align-items: center;
     align-items: center;
 
 
     & > button {
     & > button {
+      height: 40px;
       flex: 1;
       flex: 1;
       font-weight: 400;
       font-weight: 400;
       font-size: 16px !important;
       font-size: 16px !important;
@@ -300,11 +317,12 @@
   border-color: #dbdbdb;
   border-color: #dbdbdb;
 }
 }
 .btnRight {
 .btnRight {
-  background: linear-gradient(270deg, #ff204b 0%, #fe5b71 100%);
+  background: #fe2451;
+  border-color: #fe2451;
 }
 }
 .finch {
 .finch {
   width: 150px;
   width: 150px;
-  margin: 80px auto 0;
+  margin: 140px auto 0;
 }
 }
 
 
 .finchLoad {
 .finchLoad {
@@ -319,8 +337,8 @@
 
 
   :global {
   :global {
     .van-button {
     .van-button {
-      font-size: 16px;
-      font-weight: 600;
+      font-size: 18px;
+      font-weight: 500;
       color: #ffffff;
       color: #ffffff;
       line-height: 25px;
       line-height: 25px;
     }
     }

+ 13 - 11
src/tenant/music/courseList/index.tsx

@@ -2,7 +2,7 @@ import request from '@/helpers/request'
 import { state } from '@/state'
 import { state } from '@/state'
 import { Button, Cell, CellGroup, Popup, Dialog, Toast, Circle } from 'vant'
 import { Button, Cell, CellGroup, Popup, Dialog, Toast, Circle } from 'vant'
 import { Vue3Lottie } from 'vue3-lottie'
 import { Vue3Lottie } from 'vue3-lottie'
-import AstronautJSON from '../music-detail/animate/bigLoad.json'
+import AstronautJSON from '../music-detail/animate/refresh_anim.json'
 import {
 import {
   defineComponent,
   defineComponent,
   onMounted,
   onMounted,
@@ -52,7 +52,7 @@ export default defineComponent({
     const getDetail = async () => {
     const getDetail = async () => {
       try {
       try {
         const res: any = await request.post(
         const res: any = await request.post(
-          `/api-student/tenantAlbumMusic/getLessonCoursewareDetail`,
+          apiSuffix.value + `/tenantAlbumMusic/getLessonCoursewareDetail`,
           {
           {
             data: {
             data: {
               lessonCoursewareId: route.query.id,
               lessonCoursewareId: route.query.id,
@@ -69,7 +69,8 @@ export default defineComponent({
       data.loading = true
       data.loading = true
       try {
       try {
         const res: any = await request.get(
         const res: any = await request.get(
-          '/api-student/tenantAlbumMusic/getLessonCoursewareCourseList/' +
+          apiSuffix.value +
+            '/tenantAlbumMusic/getLessonCoursewareCourseList/' +
             route.query.id
             route.query.id
         )
         )
         if (Array.isArray(res?.data)) {
         if (Array.isArray(res?.data)) {
@@ -444,23 +445,24 @@ export default defineComponent({
                                 ) : (
                                 ) : (
                                   ''
                                   ''
                                 )}
                                 )}
-                                {/* {item.downloadStatus == 1 && (
+                                {item.downloadStatus == 1 && (
                                   <div class={styles.downloading}>{`${
                                   <div class={styles.downloading}>{`${
                                     item.progress || 0
                                     item.progress || 0
                                   }%`}</div>
                                   }%`}</div>
-                                )} */}
+                                )}
                               </div>
                               </div>
                             </div>
                             </div>
                           ),
                           ),
                           value: () => (
                           value: () => (
                             <>
                             <>
                               {item.knowledgePointList ? (
                               {item.knowledgePointList ? (
-                                <>
+                                <div class={styles.circleProgress}>
                                   {item.hasCache ||
                                   {item.hasCache ||
                                   item.downloadStatus !== 1 ? (
                                   item.downloadStatus !== 1 ? (
                                     <img class={styles.basePlay} src={play} />
                                     <img class={styles.basePlay} src={play} />
                                   ) : (
                                   ) : (
-                                    <div class={styles.circleProgress}>
+                                    <>
+                                      <div class={styles.tips}></div>
                                       <Circle
                                       <Circle
                                         v-model:current-rate={item.progress}
                                         v-model:current-rate={item.progress}
                                         rate={item.progress}
                                         rate={item.progress}
@@ -469,9 +471,9 @@ export default defineComponent({
                                         layer-color={'#B3B3B3'}
                                         layer-color={'#B3B3B3'}
                                         color={'#FE2451'}
                                         color={'#FE2451'}
                                       />
                                       />
-                                    </div>
+                                    </>
                                   )}
                                   )}
-                                </>
+                                </div>
                               ) : (
                               ) : (
                                 ''
                                 ''
                               )}
                               )}
@@ -492,7 +494,7 @@ export default defineComponent({
               animationData={AstronautJSON}
               animationData={AstronautJSON}
               class={styles.finch}
               class={styles.finch}
             ></Vue3Lottie>
             ></Vue3Lottie>
-            <p class={styles.finchLoad}>加载中...</p>
+            {/* <p class={styles.finchLoad}>加载中...</p> */}
           </div>
           </div>
         )}
         )}
         {!data.loading && !data.list.length && (
         {!data.loading && !data.list.length && (
@@ -505,7 +507,7 @@ export default defineComponent({
                 round
                 round
                 block
                 block
                 type="primary"
                 type="primary"
-                color="linear-gradient(270deg, #FF3C81 0%, #FF76A6 100%)"
+                color="linear-gradient(270deg, #FF204B 0%, #FE5B71 100%)"
                 onClick={() => {
                 onClick={() => {
                   if (!browser().isApp) {
                   if (!browser().isApp) {
                     onDownloadApp()
                     onDownloadApp()

+ 2 - 2
src/tenant/music/coursewarePlay/component/video-play.tsx

@@ -437,7 +437,7 @@ export default defineComponent({
               }}
               }}
             ></i>
             ></i>
             <Slider
             <Slider
-              min={0.6}
+              min={0.5}
               max={1.5}
               max={1.5}
               step={0.1}
               step={0.1}
               v-model={data.defaultSpeed}
               v-model={data.defaultSpeed}
@@ -462,7 +462,7 @@ export default defineComponent({
             <i
             <i
               class={[styles.iconCut]}
               class={[styles.iconCut]}
               onClick={() => {
               onClick={() => {
-                if (data.defaultSpeed <= 0.6) {
+                if (data.defaultSpeed <= 0.5) {
                   return
                   return
                 }
                 }
                 if (videoItem.value) {
                 if (videoItem.value) {

文件差异内容过多而无法显示
+ 2 - 3
src/tenant/music/coursewarePlay/component/video.module.less


文件差异内容过多而无法显示
+ 0 - 0
src/tenant/music/coursewarePlay/image/icons.json


+ 25 - 20
src/tenant/music/coursewarePlay/index.tsx

@@ -25,6 +25,7 @@ import {
 import MusicScore from './component/musicScore'
 import MusicScore from './component/musicScore'
 import iconDian from './image/icon-dian.svg'
 import iconDian from './image/icon-dian.svg'
 import iconPoint from './image/icon-point.svg'
 import iconPoint from './image/icon-point.svg'
+import { state as baseState } from '@/state'
 import {
 import {
   iconUp,
   iconUp,
   iconDown,
   iconDown,
@@ -48,6 +49,9 @@ import VideoPlay from './component/video-play'
 export default defineComponent({
 export default defineComponent({
   name: 'CoursewarePlay',
   name: 'CoursewarePlay',
   setup() {
   setup() {
+    const apiSuffix = ref(
+      baseState.platformType === 'STUDENT' ? '/api-student' : '/api-teacher'
+    )
     const pageVisibility = usePageVisibility()
     const pageVisibility = usePageVisibility()
     /** 页面显示和隐藏 */
     /** 页面显示和隐藏 */
     watch(
     watch(
@@ -264,7 +268,7 @@ export default defineComponent({
           }
           }
         })
         })
         //检测是否录屏
         //检测是否录屏
-        handleLimitScreenRecord()
+        // handleLimitScreenRecord()
         setTimeout(() => {
         setTimeout(() => {
           data.animationState = 'end'
           data.animationState = 'end'
         }, 500)
         }, 500)
@@ -273,7 +277,8 @@ export default defineComponent({
     const getDetail = async () => {
     const getDetail = async () => {
       try {
       try {
         const res: any = await request.get(
         const res: any = await request.get(
-          `/api-student/tenantAlbumMusic/getLessonCourseDetail/${route.query.id}`,
+          apiSuffix.value +
+            `/tenantAlbumMusic/getLessonCourseDetail/${route.query.id}`,
           {
           {
             hideLoading: true
             hideLoading: true
           }
           }
@@ -430,27 +435,27 @@ export default defineComponent({
       // getCourseSchedule();
       // getCourseSchedule();
       window.addEventListener('message', iframeHandle)
       window.addEventListener('message', iframeHandle)
       // 禁止录屏 ios
       // 禁止录屏 ios
-      listenerMessage('setVideoPlayer', result => {
-        if (result?.content?.status == 'pause') {
-          handleLimitScreenRecord()
-        }
-      })
-      // 禁止录屏 安卓
-      postMessage({
-        api: 'limitScreenRecord',
-        content: {
-          type: 1
-        }
-      })
+      // listenerMessage('setVideoPlayer', result => {
+      //   if (result?.content?.status == 'pause') {
+      //     handleLimitScreenRecord()
+      //   }
+      // })
+      // // 禁止录屏 安卓
+      // postMessage({
+      //   api: 'limitScreenRecord',
+      //   content: {
+      //     type: 1
+      //   }
+      // })
     })
     })
     onBeforeUnmount(() => {
     onBeforeUnmount(() => {
       // 取消 禁止录屏
       // 取消 禁止录屏
-      postMessage({
-        api: 'limitScreenRecord',
-        content: {
-          type: 0
-        }
-      })
+      // postMessage({
+      //   api: 'limitScreenRecord',
+      //   content: {
+      //     type: 0
+      //   }
+      // })
     })
     })
     const playRef = ref()
     const playRef = ref()
     // 返回
     // 返回

二进制
src/tenant/music/lessonCourseware/component/CourseItem/image/bg.png


+ 14 - 11
src/tenant/music/lessonCourseware/component/CourseItem/index.module.less

@@ -2,7 +2,7 @@
   position: relative;
   position: relative;
   background: rgba(255, 255, 255, 0.6);
   background: rgba(255, 255, 255, 0.6);
   border-radius: 10px;
   border-radius: 10px;
-  border: 2px solid #FFFFFF;
+  border: 2px solid #ffffff;
   min-height: 200px;
   min-height: 200px;
   display: flex;
   display: flex;
   flex-wrap: wrap;
   flex-wrap: wrap;
@@ -41,7 +41,7 @@
 
 
 .item {
 .item {
   margin: 20px 0 0 0;
   margin: 20px 0 0 0;
-  padding: 0 8px;
+  padding: 0 12px;
   width: 33.333%;
   width: 33.333%;
 
 
   .cover {
   .cover {
@@ -93,26 +93,25 @@
 
 
   .coverImg {
   .coverImg {
     width: 100%;
     width: 100%;
-    background: url('');
-    background-repeat: no-repeat;
-    background-position: center;
-    background-size: 50%;
+    background: url('./image/bg.png') no-repeat;
+    background-size: 100% 100%;
     border-radius: 2px;
     border-radius: 2px;
     overflow: hidden;
     overflow: hidden;
 
 
-    &>img {
+    & > img {
       display: block;
       display: block;
       width: 100%;
       width: 100%;
       height: 120px;
       height: 120px;
       opacity: 0;
       opacity: 0;
-      transition: opacity .3s;
+      transition: opacity 0.3s;
     }
     }
 
 
     :global {
     :global {
       .van-image__loading {
       .van-image__loading {
         position: relative;
         position: relative;
         height: 120px;
         height: 120px;
-        animation: van-skeleton-blink var(--van-skeleton-duration) ease-in-out infinite;
+        animation: van-skeleton-blink var(--van-skeleton-duration) ease-in-out
+          infinite;
       }
       }
     }
     }
 
 
@@ -122,14 +121,18 @@
       left: 5px;
       left: 5px;
       width: 5px;
       width: 5px;
       height: 100%;
       height: 100%;
-      background: linear-gradient(270deg, rgba(0, 0, 0, 0.25) 0%, rgba(0, 0, 0, 0.03) 100%);
+      background: linear-gradient(
+        270deg,
+        rgba(0, 0, 0, 0.25) 0%,
+        rgba(0, 0, 0, 0.03) 100%
+      );
       box-shadow: 0px 2px 6px 0px rgba(0, 0, 0, 0.2);
       box-shadow: 0px 2px 6px 0px rgba(0, 0, 0, 0.2);
       z-index: 1;
       z-index: 1;
     }
     }
   }
   }
 
 
   .name {
   .name {
-    width: 109%;
+    width: 100%;
     line-height: 18px;
     line-height: 18px;
     font-weight: 400;
     font-weight: 400;
     font-size: 13px;
     font-size: 13px;

+ 19 - 18
src/tenant/music/lessonCourseware/index.module.less

@@ -5,8 +5,8 @@
 
 
   :global {
   :global {
     .van-sticky {
     .van-sticky {
-      // background: url('../../images/bg.png') no-repeat top center;
-      // background-size: 100% 214px;
+      background: url('../../images/bg.png') no-repeat top center;
+      background-size: 100% 346px;
     }
     }
 
 
     .van-search__content {
     .van-search__content {
@@ -29,6 +29,7 @@
       background-color: transparent;
       background-color: transparent;
       box-shadow: none;
       box-shadow: none;
       padding-right: 15px;
       padding-right: 15px;
+      height: 36px;
     }
     }
 
 
     .van-dropdown-menu__title {
     .van-dropdown-menu__title {
@@ -101,7 +102,7 @@
 .search {
 .search {
   :global {
   :global {
     .van-search {
     .van-search {
-      height: calc(var(--van-dropdown-menu-height) + 20px);
+      padding-top: 4px;
     }
     }
   }
   }
 }
 }
@@ -110,7 +111,7 @@
   top: 0;
   top: 0;
   left: 0;
   left: 0;
   width: 100%;
   width: 100%;
-  height: 214px;
+  height: 346px;
   // object-fit: cover;
   // object-fit: cover;
   z-index: -1;
   z-index: -1;
 }
 }
@@ -122,20 +123,20 @@
       display: none;
       display: none;
     }
     }
   }
   }
-}
-.courseItem.courseItem1 {
-  background: initial;
-  border: initial;
-  padding: 0 10px 20px;
-  :global {
-    .courseItem:nth-child(1) {
-      margin-top: 10px;
-    }
-    .courseItem:nth-child(2) {
-      margin-top: 10px;
-    }
-    .courseItem:nth-child(3) {
-      margin-top: 10px;
+  .courseItem {
+    background: initial;
+    border: initial;
+    padding: 0 4px 20px;
+    :global {
+      .courseItem:nth-child(1) {
+        margin-top: 6px !important;
+      }
+      .courseItem:nth-child(2) {
+        margin-top: 6px !important;
+      }
+      .courseItem:nth-child(3) {
+        margin-top: 6px !important;
+      }
     }
     }
   }
   }
 }
 }

+ 6 - 3
src/tenant/music/lessonCourseware/index.tsx

@@ -108,6 +108,9 @@ export default defineComponent({
             rows: 20
             rows: 20
           }
           }
         })
         })
+        if (params.subjectList?.length > 0 && res.data.pageNo === 1) {
+          return
+        }
         const result = (params.subjectList || []).concat(res.data?.rows || [])
         const result = (params.subjectList || []).concat(res.data?.rows || [])
         params.subjectList = result
         params.subjectList = result
         params.page = res.data.pageNo + 1
         params.page = res.data.pageNo + 1
@@ -178,7 +181,7 @@ export default defineComponent({
             >
             >
               {params.subjectList.length ? (
               {params.subjectList.length ? (
                 <CourseItem
                 <CourseItem
-                  class={[styles.courseItem, styles.courseItem1]}
+                  class={[styles.courseItem]}
                   list={params.subjectList.map(item => {
                   list={params.subjectList.map(item => {
                     return {
                     return {
                       name: item.musicSheetName,
                       name: item.musicSheetName,
@@ -199,8 +202,8 @@ export default defineComponent({
               ) : (
               ) : (
                 !loading.value && (
                 !loading.value && (
                   <ColResult
                   <ColResult
-                    tips="暂无教"
-                    classImgSize="SMALL"
+                    tips="暂无教"
+                    classImgSize="CERT"
                     btnStatus={false}
                     btnStatus={false}
                   />
                   />
                 )
                 )

文件差异内容过多而无法显示
+ 0 - 0
src/tenant/music/music-detail/animate/refresh_anim.json


+ 2 - 2
src/tenant/music/music-detail/download.module.less

@@ -37,8 +37,8 @@
 
 
 .downloadBtn {
 .downloadBtn {
   box-shadow: 0px 2px 7px 0px rgba(45, 199, 170, 0.25);
   box-shadow: 0px 2px 7px 0px rgba(45, 199, 170, 0.25);
-  font-size: 14px;
+  font-size: 16px;
   font-weight: 600;
   font-weight: 600;
   color: #ffffff;
   color: #ffffff;
   line-height: 20px;
   line-height: 20px;
-}
+}

+ 4 - 3
src/tenant/music/music-detail/new-index.module.less

@@ -349,6 +349,7 @@
   }
   }
 
 
   .musicTitle {
   .musicTitle {
+    padding-top: 4px;
     font-weight: 600;
     font-weight: 600;
     text-align: center;
     text-align: center;
     font-size: 16px;
     font-size: 16px;
@@ -363,7 +364,7 @@
 
 
   .finch {
   .finch {
     width: 150px;
     width: 150px;
-    margin: 80px auto 0;
+    margin: 150px auto 0;
   }
   }
 
 
   .finchLoad {
   .finchLoad {
@@ -428,8 +429,8 @@
 
 
   :global {
   :global {
     .van-button {
     .van-button {
-      font-size: 16px;
-      font-weight: 600;
+      font-size: 18px;
+      font-weight: 500;
       color: #FFFFFF;
       color: #FFFFFF;
       line-height: 25px;
       line-height: 25px;
     }
     }

+ 5 - 4
src/tenant/music/music-detail/new-index.tsx

@@ -42,7 +42,7 @@ import { getRandomKey, musicBuy } from '../music'
 import { getOssUploadUrl, state } from '@/state'
 import { getOssUploadUrl, state } from '@/state'
 import { browser, moneyFormat } from '@/helpers/utils'
 import { browser, moneyFormat } from '@/helpers/utils'
 import { orderStatus } from '@/views/order-detail/orderStatus'
 import { orderStatus } from '@/views/order-detail/orderStatus'
-import AstronautJSON from './animate/bigLoad.json'
+import AstronautJSON from './animate/refresh_anim.json'
 import ColShare from '@/components/col-share'
 import ColShare from '@/components/col-share'
 import iconListen from './images/icon_listen.png'
 import iconListen from './images/icon_listen.png'
 import iconTeacher from '@common/images/icon_teacher.png'
 import iconTeacher from '@common/images/icon_teacher.png'
@@ -414,6 +414,7 @@ export default defineComponent({
       }
       }
     }
     }
     onMounted(async () => {
     onMounted(async () => {
+      postMessage({ api: 'setStatusBarTextColor', content: { statusBarTextColor: true } })
       await FetchList()
       await FetchList()
       const { height } = useRect(headers as any)
       const { height } = useRect(headers as any)
       const footer = useRect(footers as any)
       const footer = useRect(footers as any)
@@ -427,9 +428,9 @@ export default defineComponent({
       window.addEventListener('message', showLoading)
       window.addEventListener('message', showLoading)
     })
     })
     onUnmounted(() => {
     onUnmounted(() => {
+      postMessage({ api: 'setStatusBarTextColor', content: { statusBarTextColor: false } })
       window.removeEventListener('message', showLoading)
       window.removeEventListener('message', showLoading)
     })
     })
-
     const toggleFavorite = async () => {
     const toggleFavorite = async () => {
       try {
       try {
         await request.post('/music/sheet/favorite/' + musicDetail.value?.id, {
         await request.post('/music/sheet/favorite/' + musicDetail.value?.id, {
@@ -1029,7 +1030,7 @@ export default defineComponent({
                     animationData={AstronautJSON}
                     animationData={AstronautJSON}
                     class={styles.finch}
                     class={styles.finch}
                   ></Vue3Lottie>
                   ></Vue3Lottie>
-                  <p class={styles.finchLoad}>加载中...</p>
+                  {/* <p class={styles.finchLoad}>加载中...</p> */}
                 </div>
                 </div>
               )}
               )}
               <iframe
               <iframe
@@ -1052,7 +1053,7 @@ export default defineComponent({
                     animationData={AstronautJSON}
                     animationData={AstronautJSON}
                     class={styles.finch}
                     class={styles.finch}
                   ></Vue3Lottie>
                   ></Vue3Lottie>
-                  <p class={styles.finchLoad}>加载中...</p>
+                  {/* <p class={styles.finchLoad}>加载中...</p> */}
                 </>
                 </>
               ) : (
               ) : (
                 <div class={styles.empty}>
                 <div class={styles.empty}>

+ 25 - 11
src/tenant/music/personal/index.module.less

@@ -20,9 +20,14 @@
     }
     }
 
 
     .van-tabs__line {
     .van-tabs__line {
+      display: none;
       width: 24px;
       width: 24px;
       height: 4px;
       height: 4px;
-      background: linear-gradient(90deg, #FF3C81 0%, rgba(255, 118, 166, 0.5) 100%) !important;
+      background: linear-gradient(
+        90deg,
+        #ff3c81 0%,
+        rgba(255, 118, 166, 0.5) 100%
+      ) !important;
       border-radius: 36px 36px 0px 0px;
       border-radius: 36px 36px 0px 0px;
     }
     }
 
 
@@ -31,8 +36,6 @@
     }
     }
   }
   }
 
 
-
-
   :global {
   :global {
     .van-sticky {
     .van-sticky {
       background: url('../../images/bg-image-1.png') no-repeat top center;
       background: url('../../images/bg-image-1.png') no-repeat top center;
@@ -54,7 +57,6 @@
         color: rgba(0, 0, 0, 0.4) !important;
         color: rgba(0, 0, 0, 0.4) !important;
       }
       }
     }
     }
-
   }
   }
 
 
   .bgImg {
   .bgImg {
@@ -81,7 +83,9 @@
   background-color: #fff;
   background-color: #fff;
   margin: 0 14px 14px;
   margin: 0 14px 14px;
 }
 }
-
+.practice {
+  margin-bottom: 0;
+}
 .personalSong {
 .personalSong {
   margin: 14px;
   margin: 14px;
 }
 }
@@ -91,7 +95,7 @@
 }
 }
 
 
 .tennatCellGroup {
 .tennatCellGroup {
-  margin: 12px;
+  margin: 7px 12px 12px;
   border-radius: 16px;
   border-radius: 16px;
 
 
   :global {
   :global {
@@ -102,7 +106,7 @@
 
 
     .van-cell__right-icon {
     .van-cell__right-icon {
       font-size: 16px;
       font-size: 16px;
-      color: #DADADA;
+      color: #dadada;
     }
     }
   }
   }
 
 
@@ -114,10 +118,10 @@
   }
   }
 
 
   .tenantCoverImg {
   .tenantCoverImg {
-    width: 98px;
-    height: 98px;
+    width: 88px;
+    height: 88px;
     border-radius: 12px;
     border-radius: 12px;
-    margin-right: 16px;
+    margin-right: 12px;
     overflow: hidden;
     overflow: hidden;
   }
   }
 
 
@@ -129,6 +133,11 @@
       font-weight: 500;
       font-weight: 500;
       color: #131415;
       color: #131415;
       line-height: 24px;
       line-height: 24px;
+      display: -webkit-box;
+      overflow: hidden;
+      text-overflow: ellipsis;
+      -webkit-line-clamp: 2;
+      -webkit-box-orient: vertical;
     }
     }
 
 
     p {
     p {
@@ -136,6 +145,11 @@
       font-size: 13px;
       font-size: 13px;
       color: #777777;
       color: #777777;
       line-height: 24px;
       line-height: 24px;
+      display: -webkit-box;
+      overflow: hidden;
+      text-overflow: ellipsis;
+      -webkit-line-clamp: 1;
+      -webkit-box-orient: vertical;
     }
     }
   }
   }
-}
+}

+ 1 - 1
src/tenant/music/personal/tenant-album.tsx

@@ -91,7 +91,7 @@ export default defineComponent({
                       title: () => (
                       title: () => (
                         <div class={styles.tenantContent}>
                         <div class={styles.tenantContent}>
                           <h2>{item.name}</h2>
                           <h2>{item.name}</h2>
-                          <p class="van-multi-ellipsis--l2">{item.describe}</p>
+                          <p>{item.describe}</p>
                         </div>
                         </div>
                       )
                       )
                     }}
                     }}

+ 29 - 27
src/tenant/music/search/index.module.less

@@ -17,7 +17,7 @@ body {
       box-shadow: 10px 10px 10px var(--box-shadow-color);
       box-shadow: 10px 10px 10px var(--box-shadow-color);
     }
     }
 
 
-    >div {
+    > div {
       background-color: var(--base-bg);
       background-color: var(--base-bg);
     }
     }
 
 
@@ -36,7 +36,6 @@ body {
         padding-right: 0;
         padding-right: 0;
       }
       }
 
 
-
       .van-dropdown-menu__bar {
       .van-dropdown-menu__bar {
         background-color: transparent;
         background-color: transparent;
         box-shadow: none;
         box-shadow: none;
@@ -44,11 +43,12 @@ body {
       }
       }
 
 
       .van-dropdown-menu__title {
       .van-dropdown-menu__title {
-        padding-left: 0
+        padding-left: 0;
       }
       }
 
 
       .van-dropdown-menu__title:after {
       .van-dropdown-menu__title:after {
-        border-color: transparent transparent rgba(0, 0, 0, 0.4) rgba(0, 0, 0, 0.4);
+        border-color: transparent transparent rgba(0, 0, 0, 0.4)
+          rgba(0, 0, 0, 0.4);
       }
       }
 
 
       .van-dropdown-item__content {
       .van-dropdown-item__content {
@@ -56,12 +56,12 @@ body {
       }
       }
 
 
       .van-dropdown-menu__title--active::after {
       .van-dropdown-menu__title--active::after {
-        border-color: transparent transparent #FE2451 #FE2451;
+        border-color: transparent transparent #fe2451 #fe2451;
       }
       }
     }
     }
 
 
     .titleActive {
     .titleActive {
-      color: #FE2451;
+      color: #fe2451;
     }
     }
   }
   }
 
 
@@ -73,7 +73,6 @@ body {
     }
     }
   }
   }
 
 
-
   .keywordTitle {
   .keywordTitle {
     display: flex;
     display: flex;
     align-items: center;
     align-items: center;
@@ -131,7 +130,7 @@ body {
         justify-content: center;
         justify-content: center;
         background-color: #fff;
         background-color: #fff;
         font-size: 12px;
         font-size: 12px;
-        color: #93959F;
+        color: #93959f;
       }
       }
     }
     }
   }
   }
@@ -141,7 +140,6 @@ body {
     font-size: 14px;
     font-size: 14px;
 
 
     :global {
     :global {
-
       .van-list__loading,
       .van-list__loading,
       .van-list__finished-text,
       .van-list__finished-text,
       .van-list__error-text {
       .van-list__error-text {
@@ -155,7 +153,6 @@ body {
   }
   }
 }
 }
 
 
-
 .sticky {
 .sticky {
   :global {
   :global {
     .van-sticky {
     .van-sticky {
@@ -176,10 +173,9 @@ body {
       }
       }
 
 
       .van-field__clear {
       .van-field__clear {
-        color: #C1BDC1 !important;
+        color: #c1bdc1 !important;
       }
       }
     }
     }
-
   }
   }
 }
 }
 
 
@@ -216,7 +212,11 @@ body {
     .van-tabs__line {
     .van-tabs__line {
       width: 24px;
       width: 24px;
       height: 4px;
       height: 4px;
-      background: linear-gradient(90deg, #FF3C81 0%, rgba(255, 118, 166, 0.5) 100%) !important;
+      background: linear-gradient(
+        90deg,
+        #ff3c81 0%,
+        rgba(255, 118, 166, 0.5) 100%
+      ) !important;
       border-radius: 36px 36px 0px 0px;
       border-radius: 36px 36px 0px 0px;
       bottom: 22px;
       bottom: 22px;
     }
     }
@@ -235,14 +235,13 @@ body {
 
 
 .alubmGroupSearch {
 .alubmGroupSearch {
   :global {
   :global {
-    .van-list>div {
+    .van-list > div {
       margin-top: 8px;
       margin-top: 8px;
     }
     }
   }
   }
 }
 }
 
 
 .hotMusic {
 .hotMusic {
-
   padding-bottom: 20px;
   padding-bottom: 20px;
 
 
   .swipeItem .swipeChild {
   .swipeItem .swipeChild {
@@ -258,7 +257,6 @@ body {
     margin-left: 14px;
     margin-left: 14px;
   }
   }
 
 
-
   .swipeItem {
   .swipeItem {
     border-radius: 10px;
     border-radius: 10px;
     overflow: hidden;
     overflow: hidden;
@@ -285,7 +283,7 @@ body {
 
 
   .swipe {
   .swipe {
     font-size: 14px;
     font-size: 14px;
-    color: #6A6C77;
+    color: #6a6c77;
     line-height: 20px;
     line-height: 20px;
     max-width: 80%;
     max-width: 80%;
     white-space: nowrap;
     white-space: nowrap;
@@ -299,7 +297,7 @@ body {
       font-family: PingFangSC-Medium, PingFang SC;
       font-family: PingFangSC-Medium, PingFang SC;
       font-weight: 600;
       font-weight: 600;
 
 
-      color: #8A8C95;
+      color: #8a8c95;
       // margin-right: 20px;
       // margin-right: 20px;
       width: 21px;
       width: 21px;
     }
     }
@@ -309,11 +307,11 @@ body {
       width: 16px;
       width: 16px;
       line-height: 16px;
       line-height: 16px;
       text-align: center;
       text-align: center;
-      background: #FE2451;
+      background: #fe2451;
       border-radius: 4px;
       border-radius: 4px;
       font-size: 12px;
       font-size: 12px;
       font-weight: 500;
       font-weight: 500;
-      color: #FFFFFF;
+      color: #ffffff;
       vertical-align: middle;
       vertical-align: middle;
       margin-left: 4px;
       margin-left: 4px;
       transform: scale(0.9);
       transform: scale(0.9);
@@ -323,13 +321,12 @@ body {
       color: #131415;
       color: #131415;
 
 
       .num {
       .num {
-        color: #FE2451;
+        color: #fe2451;
       }
       }
     }
     }
   }
   }
 }
 }
 
 
-
 // 搜索结果样式
 // 搜索结果样式
 .searchResult {
 .searchResult {
   position: fixed;
   position: fixed;
@@ -340,9 +337,9 @@ body {
   overflow: hidden;
   overflow: hidden;
   bottom: 0;
   bottom: 0;
   padding-top: var(--header-height);
   padding-top: var(--header-height);
-  background: url('../../images/bg-image-search.png') no-repeat top center #f8f8f8;
+  background: url('../../images/bg-image-search.png') no-repeat top center
+    #f8f8f8;
   background-size: 100% 214px;
   background-size: 100% 214px;
-
 }
 }
 
 
 .searchGroups {
 .searchGroups {
@@ -367,7 +364,7 @@ body {
     }
     }
 
 
     span span {
     span span {
-      color: #FE2451;
+      color: #fe2451;
     }
     }
   }
   }
 
 
@@ -376,6 +373,11 @@ body {
     height: 16px;
     height: 16px;
     margin-right: 10px;
     margin-right: 10px;
   }
   }
+  :global {
+    .col-result-container {
+      margin-top: 40px;
+    }
+  }
 }
 }
 
 
 .searchAlbum {
 .searchAlbum {
@@ -384,8 +386,8 @@ body {
   :global {
   :global {
     .van-list {
     .van-list {
       padding: 0 13px;
       padding: 0 13px;
-      background: #FFFFFF;
+      background: #ffffff;
       border-radius: 16px;
       border-radius: 16px;
     }
     }
   }
   }
-}
+}

+ 12 - 11
src/tenant/music/train-list/index.module.less

@@ -5,8 +5,8 @@
 
 
   :global {
   :global {
     .van-sticky {
     .van-sticky {
-      // background: url('../../images/bg.png') no-repeat top center;
-      // background-size: 100% 214px;
+      background: url('../../images/bg.png') no-repeat top center;
+      background-size: 100% 346px;
     }
     }
 
 
     .van-search__content {
     .van-search__content {
@@ -29,6 +29,7 @@
       background-color: transparent;
       background-color: transparent;
       box-shadow: none;
       box-shadow: none;
       padding-right: 15px;
       padding-right: 15px;
+      height: 36px;
     }
     }
 
 
     .van-dropdown-menu__title {
     .van-dropdown-menu__title {
@@ -54,14 +55,14 @@
     }
     }
   }
   }
 
 
-  .titleActive {
-    color: #fe2451;
-  }
+  // .titleActive {
+  //   color: #fe2451;
+  // }
 }
 }
 .search {
 .search {
   :global {
   :global {
     .van-search {
     .van-search {
-      height: calc(var(--van-dropdown-menu-height) + 20px);
+      padding-top: 4px;
     }
     }
   }
   }
 }
 }
@@ -185,7 +186,7 @@
   padding: 0 12px;
   padding: 0 12px;
   border-radius: 18px;
   border-radius: 18px;
   background-color: #fff;
   background-color: #fff;
-  margin: 6px;
+  margin: 6px 12px 0px 12px;
   min-height: 40vh;
   min-height: 40vh;
   :global {
   :global {
     .van-list__loading {
     .van-list__loading {
@@ -199,7 +200,7 @@
   top: 0;
   top: 0;
   left: 0;
   left: 0;
   width: 100%;
   width: 100%;
-  height: 214px;
+  height: 346px;
   // object-fit: cover;
   // object-fit: cover;
   z-index: -1;
   z-index: -1;
 }
 }
@@ -266,7 +267,7 @@
 }
 }
 
 
 .searchResult {
 .searchResult {
-  padding: 16px 16px 12px;
+  padding: 16px 13px 12px;
   overflow: hidden;
   overflow: hidden;
   margin-bottom: 20px;
   margin-bottom: 20px;
   border-bottom: 1px solid #f2f2f2;
   border-bottom: 1px solid #f2f2f2;
@@ -281,8 +282,8 @@
 
 
 .radio-group {
 .radio-group {
   display: flex;
   display: flex;
-  margin-top: 10px;
-  margin-bottom: 20px;
+  margin-top: 12px;
+  margin-bottom: 7px;
   flex-wrap: wrap;
   flex-wrap: wrap;
 
 
   .radio:first-child {
   .radio:first-child {

+ 2 - 1
src/tenant/music/train-list/index.tsx

@@ -289,6 +289,7 @@ export default defineComponent({
                 }} */}
                 }} */}
               </ColHeader>
               </ColHeader>
               <Search
               <Search
+                placeholder={'请输入曲谱关键词'}
                 class={styles.search}
                 class={styles.search}
                 onSearch={onSearch}
                 onSearch={onSearch}
                 type="tenant"
                 type="tenant"
@@ -490,7 +491,7 @@ export default defineComponent({
                 !loading.value && (
                 !loading.value && (
                   <ColResult
                   <ColResult
                     tips="暂无曲目"
                     tips="暂无曲目"
-                    classImgSize="SMALL"
+                    classImgSize="CERT"
                     btnStatus={false}
                     btnStatus={false}
                   />
                   />
                 )
                 )

二进制
src/tenant/music/train-tool/images/icon-timer.png


+ 63 - 23
src/tenant/music/train-tool/index.module.less

@@ -1,3 +1,13 @@
+.trainTool {
+  .theSticky {
+    :global {
+      .van-sticky {
+        background: url('./images/music-bg.png') no-repeat top center;
+        background-size: 100% 365px;
+      }
+    }
+  }
+}
 .musicContent {
 .musicContent {
   position: absolute;
   position: absolute;
   top: 0;
   top: 0;
@@ -14,7 +24,6 @@
   background-size: cover;
   background-size: cover;
 }
 }
 
 
-
 .bgImg {
 .bgImg {
   position: absolute;
   position: absolute;
   left: 0;
   left: 0;
@@ -51,7 +60,7 @@
 
 
   :global {
   :global {
     .swiper {
     .swiper {
-      --swiper-theme-color: #FE2451 !important;
+      --swiper-theme-color: #fe2451 !important;
       --swiper-pagination-bottom: 0px !important;
       --swiper-pagination-bottom: 0px !important;
       --swiper-pagination-bullet-size: 6px !important;
       --swiper-pagination-bullet-size: 6px !important;
       padding-bottom: 15px;
       padding-bottom: 15px;
@@ -64,7 +73,7 @@
     }
     }
 
 
     .swiper-pagination-bullet-active {
     .swiper-pagination-bullet-active {
-      background-color: #FE2451;
+      background-color: #fe2451;
     }
     }
 
 
     .swiper-container {
     .swiper-container {
@@ -93,7 +102,6 @@
       width: 53%;
       width: 53%;
     }
     }
 
 
-
     .swiper-slide-active,
     .swiper-slide-active,
     .swiper-slide-duplicate-active {
     .swiper-slide-duplicate-active {
       transform: scale(1) !important;
       transform: scale(1) !important;
@@ -107,8 +115,8 @@
     z-index: 11;
     z-index: 11;
     font-size: 12px;
     font-size: 12px;
     font-weight: 500;
     font-weight: 500;
-    color: #FFFFFF;
-    background: linear-gradient(270deg, #FF7B57 0%, #FF3460 100%);
+    color: #ffffff;
+    background: linear-gradient(270deg, #ff7b57 0%, #ff3460 100%);
     border-radius: 0px 0px 0px 6px;
     border-radius: 0px 0px 0px 6px;
     padding: 3px 6px 2px;
     padding: 3px 6px 2px;
   }
   }
@@ -125,8 +133,6 @@
 
 
     --van-image-error-icon-size: 130px;
     --van-image-error-icon-size: 130px;
 
 
-
-
     &::after {
     &::after {
       content: '';
       content: '';
       position: absolute;
       position: absolute;
@@ -151,7 +157,11 @@
           top: 0;
           top: 0;
           bottom: 0;
           bottom: 0;
           width: 9px;
           width: 9px;
-          background: linear-gradient(270deg, rgba(0, 0, 0, 0.18) 0%, rgba(255, 255, 255, 0) 100%);
+          background: linear-gradient(
+            270deg,
+            rgba(0, 0, 0, 0.18) 0%,
+            rgba(255, 255, 255, 0) 100%
+          );
         }
         }
       }
       }
     }
     }
@@ -202,7 +212,7 @@
   }
   }
 
 
   .alumTitle {
   .alumTitle {
-    padding: 0 16px;
+    padding: 0 20px;
     padding-bottom: 8px;
     padding-bottom: 8px;
     font-size: 16px;
     font-size: 16px;
     font-weight: 600;
     font-weight: 600;
@@ -217,7 +227,6 @@
     text-align: center;
     text-align: center;
     min-height: 64px;
     min-height: 64px;
 
 
-
     .des {
     .des {
       padding: 0 16px;
       padding: 0 16px;
       font-size: 12px;
       font-size: 12px;
@@ -238,12 +247,11 @@
   font-size: 13px;
   font-size: 13px;
   padding: 0 12px;
   padding: 0 12px;
 
 
-
   .albumTimer {
   .albumTimer {
     display: flex;
     display: flex;
     align-items: center;
     align-items: center;
     font-weight: 500;
     font-weight: 500;
-    color: #5E3314;
+    color: #5e3314;
     line-height: 1;
     line-height: 1;
   }
   }
 
 
@@ -253,7 +261,6 @@
     margin-right: 6px;
     margin-right: 6px;
   }
   }
 
 
-
   .originPrice {
   .originPrice {
     font-weight: 500;
     font-weight: 500;
     color: rgba(38, 38, 38, 0.4);
     color: rgba(38, 38, 38, 0.4);
@@ -261,17 +268,17 @@
   }
   }
 
 
   .currentPrice {
   .currentPrice {
-    padding: 4px 7px;
+    padding: 3px 7px;
     border-radius: 20px;
     border-radius: 20px;
     background: #262626;
     background: #262626;
-
     margin-left: 6px;
     margin-left: 6px;
+    display: inline-block;
 
 
     span {
     span {
       font-weight: 500;
       font-weight: 500;
-      color: #FFE1AE;
+      color: #ffe1ae;
       line-height: 18px;
       line-height: 18px;
-      background: linear-gradient(180deg, #FFFFFF 0%, #FFC76C 100%);
+      background: linear-gradient(180deg, #ffffff 0%, #ffc76c 100%);
       -webkit-background-clip: text;
       -webkit-background-clip: text;
       -webkit-text-fill-color: transparent;
       -webkit-text-fill-color: transparent;
     }
     }
@@ -283,7 +290,7 @@
   z-index: 12;
   z-index: 12;
   background-color: #fff;
   background-color: #fff;
   border-radius: 16px;
   border-radius: 16px;
-  min-height: 40vh; //calc(100vh - 210px - var(--header-height));
+  min-height: 50vh; //calc(100vh - 210px - var(--header-height));
 
 
   --van-cell-background-color: transparent;
   --van-cell-background-color: transparent;
   --van-cell-font-size: 16px;
   --van-cell-font-size: 16px;
@@ -292,6 +299,13 @@
   --van-cell-icon-size: 10px;
   --van-cell-icon-size: 10px;
 
 
   :global {
   :global {
+    .van-tabs {
+      padding-bottom: 16px;
+    }
+    .van-tabs__nav {
+      padding-left: 6px;
+      padding-right: 6px;
+    }
     .van-tab {
     .van-tab {
       font-size: 16px !important;
       font-size: 16px !important;
       margin-top: 15px;
       margin-top: 15px;
@@ -301,17 +315,22 @@
     .van-tab--active {
     .van-tab--active {
       font-size: 16px !important;
       font-size: 16px !important;
       color: #131415;
       color: #131415;
+      font-weight: 600;
     }
     }
 
 
     .van-tabs__line {
     .van-tabs__line {
       width: 24px;
       width: 24px;
       height: 4px;
       height: 4px;
-      background: linear-gradient(90deg, #FF3C5E 0%, rgba(255, 118, 155,0.5) 100%) !important;
+      background: linear-gradient(
+        90deg,
+        #ff3c5e 0%,
+        rgba(255, 118, 155, 0.5) 100%
+      ) !important;
       border-radius: 36px 36px 0px 0px;
       border-radius: 36px 36px 0px 0px;
     }
     }
 
 
     .van-tab--shrink {
     .van-tab--shrink {
-      padding: 0 12px 0 12px;
+      padding: 0 14px 0 14px;
     }
     }
 
 
     .van-button--plain.van-button--primary {
     .van-button--plain.van-button--primary {
@@ -322,14 +341,35 @@
       background-color: #fff;
       background-color: #fff;
     }
     }
   }
   }
-
   .alumnList {
   .alumnList {
     padding: 0 15px;
     padding: 0 15px;
+    &.alumnListCourseware {
+      padding: 0 3px 3px;
+    }
+    :global {
+      .van-empty {
+        margin-top: -24px;
+      }
+      .songItem {
+        &:first-child {
+          padding-top: 0;
+        }
+      }
+      .courseItem:nth-child(1) {
+        margin-top: 0 !important;
+      }
+      .courseItem:nth-child(2) {
+        margin-top: 0 !important;
+      }
+      .courseItem:nth-child(3) {
+        margin-top: 0 !important;
+      }
+    }
   }
   }
 }
 }
 
 
 .btnGroup {
 .btnGroup {
-  border-top: 1px solid #F2F2F2;
+  border-top: 1px solid #f2f2f2;
   background-color: #fff;
   background-color: #fff;
   padding-top: 12px;
   padding-top: 12px;
   padding-left: 25px;
   padding-left: 25px;

+ 108 - 93
src/tenant/music/train-tool/index.tsx

@@ -1,4 +1,12 @@
-import { computed, defineComponent, onMounted, reactive, ref, watch } from 'vue'
+import {
+  computed,
+  defineComponent,
+  onMounted,
+  reactive,
+  ref,
+  watch,
+  nextTick
+} from 'vue'
 import {
 import {
   Image,
   Image,
   Tabs,
   Tabs,
@@ -40,8 +48,12 @@ import CourseItem from '../lessonCourseware/component/CourseItem'
 export default defineComponent({
 export default defineComponent({
   name: 'train-tool',
   name: 'train-tool',
   setup() {
   setup() {
-    const subjectType = sessionStorage.getItem('tool-subject-type')
+    const sessionStorageToolSubject =
+      sessionStorage.getItem('tool-subject-type')
+    const toolSubject =
+      sessionStorageToolSubject && JSON.parse(sessionStorageToolSubject)
     sessionStorage.removeItem('tool-subject-type')
     sessionStorage.removeItem('tool-subject-type')
+
     const route = useRoute()
     const route = useRoute()
     const router = useRouter()
     const router = useRouter()
     const background = ref<string>('rgba(55, 205, 177, 0)')
     const background = ref<string>('rgba(55, 205, 177, 0)')
@@ -50,7 +62,8 @@ export default defineComponent({
       details: {} as any,
       details: {} as any,
       buy: route.query.buy as any,
       buy: route.query.buy as any,
       albumId: route.query.albumId || null,
       albumId: route.query.albumId || null,
-      activeTab: route.query.subjectType || 'SUBJECT',
+      activeTab:
+        toolSubject?.activeTab || route.query.subjectType || 'COURSEWARE', // 有缓存 默认用缓存,之后用请求头,最后默认
       loadingAlbum: false,
       loadingAlbum: false,
       loading: false,
       loading: false,
       finished: false,
       finished: false,
@@ -66,7 +79,8 @@ export default defineComponent({
       ablumStatus: false,
       ablumStatus: false,
       heightV: 0,
       heightV: 0,
       hasBuyStatus: true, // 是否能继续购买
       hasBuyStatus: true, // 是否能继续购买
-      albumList: [] as any // 专辑列表
+      albumList: [] as any, // 专辑列表
+      initialSlide: 0
     })
     })
     const params = reactive({
     const params = reactive({
       page: 1,
       page: 1,
@@ -78,7 +92,7 @@ export default defineComponent({
 
 
     const isSingleAlbum = computed(() => {
     const isSingleAlbum = computed(() => {
       const query = route.query
       const query = route.query
-      if (query.taId || query.albumId) {
+      if (query.taId || (query.albumId && state.buy === '1')) {
         return true
         return true
       } else {
       } else {
         return false
         return false
@@ -103,20 +117,32 @@ export default defineComponent({
             apiSuffix.value +
             apiSuffix.value +
             `/tenantGroupAlbum/buyAlbumInfo?tenantGroupAlbumId=${
             `/tenantGroupAlbum/buyAlbumInfo?tenantGroupAlbumId=${
               route.query.taId || ''
               route.query.taId || ''
-            }&tenantAlbumId=${state.albumId || ''}`
+            }`
+          //&tenantAlbumId=${state.albumId || ''}
           // if (state.albumId) {
           // if (state.albumId) {
           //   url = url + '?albumId=' + state.albumId
           //   url = url + '?albumId=' + state.albumId
           // }
           // }
           const { data } = await request.get(url)
           const { data } = await request.get(url)
           state.albumList = data || []
           state.albumList = data || []
           if (state.albumList.length > 0) {
           if (state.albumList.length > 0) {
-            state.details = state.albumList[0]
+            let index = 0
+            // 以缓存为优先 其次 请求头 state.albumId
+            if (toolSubject?.tenantGroupAlbumId || state.albumId) {
+              index = state.albumList.findIndex(item => {
+                return toolSubject?.tenantGroupAlbumId
+                  ? item.tenantGroupAlbumId === toolSubject?.tenantGroupAlbumId
+                  : item.id == state.albumId // 这里不全等 因为state.albumId为字符串 id为number
+              })
+              index < 0 && (index = 0)
+            }
+            state.initialSlide = index //默认展示第几个
+            state.details = state.albumList[index] // 有缓存  就用缓存里面的数据
           } else {
           } else {
             // state.albumList
             // state.albumList
             if (!browser().isApp) {
             if (!browser().isApp) {
               Dialog.alert({
               Dialog.alert({
                 title: '提示',
                 title: '提示',
-                message: '该专辑不可购买',
+                message: '该教程不可购买',
                 confirmButtonText: '确定',
                 confirmButtonText: '确定',
                 confirmButtonColor: '#2dc7aa'
                 confirmButtonColor: '#2dc7aa'
               }).then(() => {
               }).then(() => {
@@ -145,46 +171,10 @@ export default defineComponent({
     watch(
     watch(
       () => state.details,
       () => state.details,
       () => {
       () => {
-        state.ensembleCounts = state.details?.ensembleCounts <= 0 ? false : true
-        state.subjectCounts = state.details?.subjectCounts <= 0 ? false : true
-        state.musicCounts = state.details?.musicCounts <= 0 ? false : true
-        state.coursewareCounts =
-          state.details?.coursewareCounts <= 0 ? false : true
-        if (state.subjectCounts) {
-          state.activeTab = 'SUBJECT'
-        } else if (state.musicCounts) {
-          state.activeTab = 'MUSIC'
-        } else if (state.ensembleCounts) {
-          state.activeTab = 'ENSEMBLE'
-        } else if (state.coursewareCounts) {
-          state.activeTab = 'COURSEWARE'
-        }
-        // 带的参数
-        if (route.query.subjectType == 'SUBJECT' && state.subjectCounts) {
-          state.activeTab = 'SUBJECT'
-        } else if (route.query.subjectType == 'MUSIC' && state.musicCounts) {
-          state.activeTab = 'MUSIC'
-        } else if (
-          route.query.subjectType == 'ENSEMBLE' &&
-          state.ensembleCounts
-        ) {
-          state.activeTab = 'ENSEMBLE'
-        } else if (
-          route.query.subjectType == 'COURSEWARE' &&
-          state.coursewareCounts
-        ) {
-          state.activeTab = 'COURSEWARE'
-        }
-        // subjectType 缓存
-        if (subjectType == 'SUBJECT' && state.subjectCounts) {
-          state.activeTab = 'SUBJECT'
-        } else if (subjectType == 'MUSIC' && state.musicCounts) {
-          state.activeTab = 'MUSIC'
-        } else if (subjectType == 'ENSEMBLE' && state.ensembleCounts) {
-          state.activeTab = 'ENSEMBLE'
-        } else if (subjectType == 'COURSEWARE' && state.coursewareCounts) {
-          state.activeTab = 'COURSEWARE'
-        }
+        state.ensembleCounts = state.details?.ensembleCounts ? true : false
+        state.subjectCounts = state.details?.subjectCounts ? true : false
+        state.musicCounts = state.details?.musicCounts ? true : false
+        state.coursewareCounts = state.details?.coursewareCounts ? true : false
         if (state.details.buyTimesFlag) {
         if (state.details.buyTimesFlag) {
           if (state.details.buyedTimes >= state.details.buyTimes) {
           if (state.details.buyedTimes >= state.details.buyTimes) {
             state.hasBuyStatus = false
             state.hasBuyStatus = false
@@ -196,10 +186,10 @@ export default defineComponent({
         }
         }
       }
       }
     )
     )
-
+    let listController
     const FetchList = async (hideLoading = false) => {
     const FetchList = async (hideLoading = false) => {
-      if (state.loading) {
-        return
+      if (listController) {
+        listController.abort()
       }
       }
       state.loading = true
       state.loading = true
       state.isError = false
       state.isError = false
@@ -210,11 +200,14 @@ export default defineComponent({
       }
       }
 
 
       try {
       try {
+        listController = new AbortController()
+        const { signal } = listController
         const { data } = await request.post(
         const { data } = await request.post(
           `${apiSuffix.value}/tenantAlbumMusic/page`,
           `${apiSuffix.value}/tenantAlbumMusic/page`,
           {
           {
             hideLoading,
             hideLoading,
-            data: tempParams
+            data: tempParams,
+            signal
           }
           }
         )
         )
         if (state.list.length > 0 && data.pageNo === 1) {
         if (state.list.length > 0 && data.pageNo === 1) {
@@ -233,14 +226,14 @@ export default defineComponent({
     }
     }
 
 
     onMounted(async () => {
     onMounted(async () => {
-      useEventListener(document, 'scroll', evt => {
-        const { y } = useWindowScroll()
-        if (y.value > 20) {
-          background.value = `rgba(255, 255, 255)`
-        } else {
-          background.value = 'transparent'
-        }
-      })
+      // useEventListener(document, 'scroll', evt => {
+      //   const { y } = useWindowScroll()
+      //   if (y.value > 20) {
+      //     background.value = `rgba(255, 255, 255)`
+      //   } else {
+      //     background.value = 'transparent'
+      //   }
+      // })
 
 
       state.loading = true
       state.loading = true
       state.loadingAlbum = true
       state.loadingAlbum = true
@@ -253,7 +246,15 @@ export default defineComponent({
       document.body.scrollIntoView()
       document.body.scrollIntoView()
       window.scrollTo(1, 0)
       window.scrollTo(1, 0)
     })
     })
-
+    function handleChangeActiveTab() {
+      state.activeTab = state.details?.coursewareCounts
+        ? 'COURSEWARE'
+        : state.details?.subjectCounts
+        ? 'SUBJECT'
+        : state.details?.musicCounts
+        ? 'MUSIC'
+        : 'ENSEMBLE'
+    }
     const onSubmit = async () => {
     const onSubmit = async () => {
       const album = state.details
       const album = state.details
       const details = state.details
       const details = state.details
@@ -341,6 +342,7 @@ export default defineComponent({
         {!state.loading && !state.details.id && state.buy != '1' ? (
         {!state.loading && !state.details.id && state.buy != '1' ? (
           <>
           <>
             <TheSticky
             <TheSticky
+              class={styles.theSticky}
               position="top"
               position="top"
               onBarHeight={(height: any) => {
               onBarHeight={(height: any) => {
                 console.log(height, 'height', height)
                 console.log(height, 'height', height)
@@ -358,7 +360,7 @@ export default defineComponent({
                 }}
                 }}
               >
               >
                 <ColResult
                 <ColResult
-                  tips="暂无专辑"
+                  tips="暂无教程"
                   classImgSize="SMALL"
                   classImgSize="SMALL"
                   btnStatus={false}
                   btnStatus={false}
                 />
                 />
@@ -369,6 +371,7 @@ export default defineComponent({
           !state.loadingAlbum && (
           !state.loadingAlbum && (
             <>
             <>
               <TheSticky
               <TheSticky
+                class={styles.theSticky}
                 position="top"
                 position="top"
                 onBarHeight={(height: any) => {
                 onBarHeight={(height: any) => {
                   state.heightV = height
                   state.heightV = height
@@ -412,34 +415,27 @@ export default defineComponent({
                     state.albumList &&
                     state.albumList &&
                     state.albumList.length > 0 && (
                     state.albumList.length > 0 && (
                       <Swiper
                       <Swiper
+                        initialSlide={state.initialSlide}
                         watchSlidesProgress={true}
                         watchSlidesProgress={true}
                         slidesPerView={'auto'}
                         slidesPerView={'auto'}
                         centeredSlides={true}
                         centeredSlides={true}
                         modules={[Pagination]}
                         modules={[Pagination]}
                         pagination={{ clickable: true }}
                         pagination={{ clickable: true }}
-                        // onSlideChange={(swiper: any) => {}}
-                        onTransitionEnd={(swiper: any) => {
+                        // onTransitionEnd={(swiper: any) => {}} onSlideChange
+                        onSlideChange={(swiper: any) => {
                           state.details = state.albumList[swiper.activeIndex]
                           state.details = state.albumList[swiper.activeIndex]
-                          state.ensembleCounts =
-                            state.details?.ensembleCounts <= 0 ? false : true
-                          state.subjectCounts =
-                            state.details?.subjectCounts <= 0 ? false : true
-                          state.musicCounts =
-                            state.details?.musicCounts <= 0 ? false : true
-                          state.coursewareCounts =
-                            state.details?.coursewareCounts <= 0 ? false : true
-                          if (state.subjectCounts) {
-                            state.activeTab = 'SUBJECT'
-                          } else if (state.musicCounts) {
-                            state.activeTab = 'MUSIC'
-                          } else if (state.ensembleCounts) {
-                            state.activeTab = 'ENSEMBLE'
-                          } else if (state.coursewareCounts) {
-                            state.activeTab = 'COURSEWARE'
-                          }
-                          params.page = 1
-                          state.list = []
-                          FetchList(true)
+                          // 等tab渲染完了之后再切换 不然tab会自动重新赋值
+                          nextTick(() => {
+                            // 当有初始值的时候不刷新
+                            if (state.initialSlide) {
+                              state.initialSlide = 0
+                              return
+                            }
+                            handleChangeActiveTab()
+                            params.page = 1
+                            state.list = []
+                            FetchList(true)
+                          })
                         }}
                         }}
                       >
                       >
                         {state.albumList.map((album: any) => (
                         {state.albumList.map((album: any) => (
@@ -515,13 +511,16 @@ export default defineComponent({
                     lineWidth={20}
                     lineWidth={20}
                     shrink
                     shrink
                     v-model:active={state.activeTab}
                     v-model:active={state.activeTab}
-                    onChange={val => {
-                      state.activeTab = val
+                    onClick-tab={val => {
+                      state.activeTab = val.name
                       params.page = 1
                       params.page = 1
                       state.list = []
                       state.list = []
                       FetchList()
                       FetchList()
                     }}
                     }}
                   >
                   >
+                    {state.coursewareCounts && (
+                      <Tab title="云教程" name="COURSEWARE"></Tab>
+                    )}
                     {state.subjectCounts && (
                     {state.subjectCounts && (
                       <Tab title="声部练习" name="SUBJECT"></Tab>
                       <Tab title="声部练习" name="SUBJECT"></Tab>
                     )}
                     )}
@@ -531,13 +530,17 @@ export default defineComponent({
                     {state.ensembleCounts && (
                     {state.ensembleCounts && (
                       <Tab title="合奏练习" name="ENSEMBLE"></Tab>
                       <Tab title="合奏练习" name="ENSEMBLE"></Tab>
                     )}
                     )}
-                    {state.coursewareCounts && (
-                      <Tab title="云教程" name="COURSEWARE"></Tab>
-                    )}
                   </Tabs>
                   </Tabs>
                 </Sticky>
                 </Sticky>
 
 
-                <div class={styles.alumnList}>
+                <div
+                  class={[
+                    styles.alumnList,
+                    state.activeTab === 'COURSEWARE'
+                      ? styles.alumnListCourseware
+                      : ''
+                  ]}
+                >
                   <List
                   <List
                     loading={state.loading}
                     loading={state.loading}
                     finished={state.finished}
                     finished={state.finished}
@@ -559,7 +562,11 @@ export default defineComponent({
                           onItemClick={row => {
                           onItemClick={row => {
                             sessionStorage.setItem(
                             sessionStorage.setItem(
                               'tool-subject-type',
                               'tool-subject-type',
-                              state.activeTab as any
+                              JSON.stringify({
+                                activeTab: state.activeTab,
+                                tenantGroupAlbumId:
+                                  state.details.tenantGroupAlbumId
+                              })
                             )
                             )
                             router.push({
                             router.push({
                               path: '/courseList',
                               path: '/courseList',
@@ -578,7 +585,11 @@ export default defineComponent({
                           onDetail={(item: any) => {
                           onDetail={(item: any) => {
                             sessionStorage.setItem(
                             sessionStorage.setItem(
                               'tool-subject-type',
                               'tool-subject-type',
-                              state.activeTab as any
+                              JSON.stringify({
+                                activeTab: state.activeTab,
+                                tenantGroupAlbumId:
+                                  state.details.tenantGroupAlbumId
+                              })
                             )
                             )
                             router.push({
                             router.push({
                               path: '/music-detail',
                               path: '/music-detail',
@@ -594,7 +605,11 @@ export default defineComponent({
                     ) : (
                     ) : (
                       !state.loading && (
                       !state.loading && (
                         <ColResult
                         <ColResult
-                          tips="暂无曲目" //暂无教程
+                          tips={
+                            state.activeTab === 'COURSEWARE'
+                              ? '暂无教材'
+                              : '暂无曲目'
+                          }
                           classImgSize="SMALL"
                           classImgSize="SMALL"
                           btnStatus={false}
                           btnStatus={false}
                         />
                         />

+ 13 - 16
src/tenant/trade/index.module.less

@@ -17,14 +17,13 @@
       }
       }
 
 
       .van-field__clear {
       .van-field__clear {
-        color: #C1BDC1 !important;
+        color: #c1bdc1 !important;
       }
       }
     }
     }
 
 
     .van-search {
     .van-search {
       padding-bottom: 0;
       padding-bottom: 0;
     }
     }
-
   }
   }
 }
 }
 
 
@@ -34,7 +33,6 @@
   color: #131415;
   color: #131415;
 
 
   :global {
   :global {
-
     .van-list__loading,
     .van-list__loading,
     .van-list__finished-text,
     .van-list__finished-text,
     .van-list__error-text {
     .van-list__error-text {
@@ -47,7 +45,6 @@
   }
   }
 }
 }
 
 
-
 .bgImg {
 .bgImg {
   position: fixed;
   position: fixed;
   top: 0;
   top: 0;
@@ -84,7 +81,11 @@
     .van-tabs__line {
     .van-tabs__line {
       width: 24px;
       width: 24px;
       height: 4px;
       height: 4px;
-      background: linear-gradient(90deg, #FF3C81 0%, rgba(255, 118, 166, 0.5) 100%) !important;
+      background: linear-gradient(
+        90deg,
+        #ff3c5e 0%,
+        rgba(255, 118, 155, 0.5) 100%
+      ) !important;
       border-radius: 36px 36px 0px 0px;
       border-radius: 36px 36px 0px 0px;
     }
     }
 
 
@@ -133,7 +134,6 @@
   // }
   // }
 }
 }
 
 
-
 .tradeList {
 .tradeList {
   padding-top: 16px;
   padding-top: 16px;
 
 
@@ -179,7 +179,6 @@
     color: #131415;
     color: #131415;
     line-height: 24px;
     line-height: 24px;
 
 
-
     .name {
     .name {
       max-width: 160px;
       max-width: 160px;
     }
     }
@@ -202,7 +201,6 @@
     .d {
     .d {
       max-width: 160px;
       max-width: 160px;
     }
     }
-
   }
   }
 
 
   .paymentPrice {
   .paymentPrice {
@@ -218,7 +216,7 @@
     span {
     span {
       font-family: DINAlternate-Bold, DINAlternate;
       font-family: DINAlternate-Bold, DINAlternate;
       font-weight: bold;
       font-weight: bold;
-      color: #FE2451;
+      color: #fe2451;
       font-size: 20px;
       font-size: 20px;
       padding-left: 4px;
       padding-left: 4px;
 
 
@@ -233,11 +231,11 @@
 
 
   .songLength {
   .songLength {
     border-radius: 4px;
     border-radius: 4px;
-    border: 1px solid #FE2451;
+    border: 1px solid #fe2451;
     font-size: 12px;
     font-size: 12px;
     font-family: PingFangSC-Regular, PingFang SC;
     font-family: PingFangSC-Regular, PingFang SC;
     font-weight: 400;
     font-weight: 400;
-    color: #FE2451;
+    color: #fe2451;
     line-height: 16px;
     line-height: 16px;
     padding: 1px 6px;
     padding: 1px 6px;
   }
   }
@@ -257,21 +255,20 @@
       padding: 7px 16px;
       padding: 7px 16px;
     }
     }
 
 
-    .van-button+.van-button {
+    .van-button + .van-button {
       margin-left: 10px;
       margin-left: 10px;
     }
     }
   }
   }
 }
 }
 
 
-
 .orderDetailGroup {
 .orderDetailGroup {
   margin: 0 12px 12px;
   margin: 0 12px 12px;
-  background: #FFFFFF;
+  background: #ffffff;
   border-radius: 10px;
   border-radius: 10px;
 }
 }
 
 
 .optionGroup {
 .optionGroup {
-  background: #FFFFFF;
+  background: #ffffff;
   border-radius: 10px;
   border-radius: 10px;
   margin: 12px;
   margin: 12px;
   padding-top: 15px;
   padding-top: 15px;
@@ -320,4 +317,4 @@
       /* CSS 3 (and 2.1 as well, actually) */
       /* CSS 3 (and 2.1 as well, actually) */
     }
     }
   }
   }
-}
+}

+ 1 - 1
src/tenant/trade/index.tsx

@@ -360,7 +360,7 @@ export default defineComponent({
           ) : (
           ) : (
             <ColResult
             <ColResult
               btnStatus={false}
               btnStatus={false}
-              classImgSize="SMALL"
+              classImgSize="CERT"
               tips={state.type === 'buy' ? '暂无购买记录' : '暂无退款记录'}
               tips={state.type === 'buy' ? '暂无购买记录' : '暂无退款记录'}
             />
             />
           )}
           )}

+ 1 - 1
src/views/article-center/help-center.tsx

@@ -121,7 +121,7 @@ export default defineComponent({
             ))}
             ))}
           </List>
           </List>
         ) : (
         ) : (
-          <ColResult btnStatus={false} classImgSize="SMALL" tips="暂无内容" />
+          <ColResult btnStatus={false} classImgSize="CERT" tips="暂无内容" />
         )}
         )}
       </div>
       </div>
     )
     )

+ 5 - 0
yarn.lock

@@ -5541,6 +5541,11 @@ yargs@^15.3.1:
     y18n "^4.0.0"
     y18n "^4.0.0"
     yargs-parser "^18.1.2"
     yargs-parser "^18.1.2"
 
 
+yet-another-abortcontroller-polyfill@^0.0.4:
+  version "0.0.4"
+  resolved "https://registry.npmmirror.com/yet-another-abortcontroller-polyfill/-/yet-another-abortcontroller-polyfill-0.0.4.tgz#ce2270e564a4f2d07351812f599e10143526f98b"
+  integrity sha512-6do/P+mjm7FDUD+q8FrZ0ClMIbjGuKyWuWm3Vz2O7QmVf73HVLYIDV6toS7T0qoH1yeI2HPb8VgJp7w+zcVWvA==
+
 yorkie@^2.0.0:
 yorkie@^2.0.0:
   version "2.0.0"
   version "2.0.0"
   resolved "https://registry.npmmirror.com/yorkie/-/yorkie-2.0.0.tgz"
   resolved "https://registry.npmmirror.com/yorkie/-/yorkie-2.0.0.tgz"

部分文件因为文件数量过多而无法显示