todayclass-box.vue 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. <template>
  2. <!-- 今日课程 -->
  3. <view>
  4. <!-- 课程列表 -->
  5. <view style="margin-bottom: 20rpx;">
  6. <!-- 插画 -->
  7. <view class="detail-image" v-if="classCurrent === -1" :style="{backgroundImage:`url(${image.none})`}">
  8. </view>
  9. <view v-if="classCurrent === -1">
  10. <view class="class-block">
  11. <view class="block-title">自由安排</view>
  12. <view class="block-tag-box">
  13. <view class="block-tag">已下课</view>
  14. </view>
  15. <view class="block-subtitle">休息时间</view>
  16. <view style="display: flex; align-items: center;" @click="navClass">
  17. <view class="t-icon t-icon-fenlei" style="width: 40rpx;height: 40rpx;"></view>
  18. <view style="font-size: 30rpx;color: #4169E1;margin-left: 10rpx;">课程列表</view>
  19. </view>
  20. </view>
  21. </view>
  22. <!-- 课程列表 -->
  23. <view v-if="classCurrent != -1">
  24. <!-- 上上节 -->
  25. <view class="class-block" v-if="classCurrent === classList.length">
  26. <view class="block-title">{{classList[classCurrent-3].name}}</view>
  27. <view class="block-tag-box">
  28. <view class="block-tag">{{classList[classCurrent-3].teacher}}</view>
  29. </view>
  30. <view class="block-subtitle">更早</view>
  31. <view class="block-title">{{classList[classCurrent-3].time}}</view>
  32. <view class="btn" @click="navVideoBefore(classCurrent-3)">
  33. <view class="t-icon t-icon-bofang3"></view>
  34. </view>
  35. </view>
  36. <!-- 上节 -->
  37. <view class="class-block" v-if="classCurrent >= 2">
  38. <view class="block-title">{{classList[classCurrent-2].name}}</view>
  39. <view class="block-tag-box">
  40. <view class="block-tag">{{classList[classCurrent-2].teacher}}</view>
  41. </view>
  42. <view class="block-subtitle">上节</view>
  43. <view class="block-title">{{classList[classCurrent-2].time}}</view>
  44. <view class="btn" @click="navVideoBefore(classCurrent-2)">
  45. <view class="t-icon t-icon-bofang3"></view>
  46. </view>
  47. </view>
  48. <!-- 当前 -->
  49. <view class="class-block" style="background-color: #FFF;">
  50. <view class="block-title" style="color: #4169E1;">{{classList[classCurrent-1].name}}</view>
  51. <view class="block-tag-box">
  52. <view class="block-tag">{{classList[classCurrent-1].teacher}}</view>
  53. </view>
  54. <view class="block-index">当前</view>
  55. <view class="block-title" style="color: #4169E1;">{{classList[classCurrent-1].time}}</view>
  56. <view class="btn" style="background-color: #ff5959" @click="navVideoNow(classCurrent-1)">
  57. <view class="t-icon t-icon-zhibo"></view>
  58. </view>
  59. </view>
  60. <!-- 下节 -->
  61. <view class="class-block" v-if="!(classCurrent === classList.length)">
  62. <view class="block-title">{{classList[classCurrent].name}}</view>
  63. <view class="block-tag-box">
  64. <view class="block-tag">{{classList[classCurrent].teacher}}</view>
  65. </view>
  66. <view class="block-subtitle">下节</view>
  67. <view class="block-title">{{classList[classCurrent].time}}</view>
  68. <view class="btn" style="background-color: #aaaaaa">
  69. <view class="t-icon t-icon-daojishi"></view>
  70. </view>
  71. </view>
  72. <!-- 下下节 -->
  73. <view class="class-block" v-if="classCurrent === 1">
  74. <view class="block-title">{{classList[classCurrent+1].name}}</view>
  75. <view class="block-tag-box">
  76. <view class="block-tag">{{classList[classCurrent+1].teacher}}</view>
  77. </view>
  78. <view class="block-subtitle">更晚</view>
  79. <view class="block-title">{{classList[classCurrent+1].time}}</view>
  80. <view class="btn" style="background-color: #aaaaaa">
  81. <view class="t-icon t-icon-daojishi"></view>
  82. </view>
  83. </view>
  84. </view>
  85. </view>
  86. </view>
  87. </template>
  88. <script>
  89. import {
  90. mapState,
  91. mapMutations
  92. } from 'vuex'
  93. export default {
  94. name: "todayclass-box",
  95. computed: {
  96. ...mapState('m_children', ['classList']),
  97. },
  98. props: {
  99. classCurrent: {
  100. type: Number,
  101. default () {
  102. return -1
  103. }
  104. },
  105. },
  106. data() {
  107. return {
  108. image: {
  109. none: 'https://image.meiye.art/pic_1631411820764Vm5iw82gnV2lVKWRokFmU',
  110. class: 'https://image.meiye.art/pic_1631411821366fqhkuMI110LbOlAIdv1SV',
  111. },
  112. };
  113. },
  114. watch: {
  115. classCurrent() {
  116. this.setClassCurrent()
  117. }
  118. },
  119. methods: {
  120. ...mapMutations('m_children',['updateClassCurrent']),
  121. //获取首页课程数据
  122. setClassCurrent() {
  123. this.updateClassCurrent(this.classCurrent)
  124. },
  125. navClass() {
  126. uni.navigateTo({
  127. url: '/subpkg/classlist/classlist'
  128. })
  129. },
  130. navVideoBefore(index) {
  131. uni.navigateTo({
  132. url: `/subpkg/video/videopage?info=${index}`
  133. })
  134. },
  135. navVideoNow(index) {
  136. uni.navigateTo({
  137. url: `/subpkg/video/livepage?info=${index}`
  138. })
  139. },
  140. },
  141. created() {
  142. this.setClassCurrent()
  143. }
  144. }
  145. </script>
  146. <style lang="scss">
  147. @import '@/pages/common/blockmsg.scss';
  148. .detail-image {
  149. margin-top: -50rpx;
  150. width: 100%;
  151. height: 450rpx;
  152. background-size: 100%;
  153. background-repeat: no-repeat;
  154. }
  155. .block-index {
  156. font-size: 22rpx;
  157. color: $color-mixblue;
  158. }
  159. .t-icon {
  160. width: 46rpx;
  161. height: 46rpx;
  162. }
  163. .btn{
  164. display: flex;
  165. align-items: center;
  166. justify-content: center;
  167. background-color: $color-green;
  168. width: 100rpx;
  169. height: 60rpx;
  170. border-radius: 8rpx;
  171. }
  172. </style>