todayclass-box.vue 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  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 class="btn-text">已出勤</view>
  35. </view>
  36. </view>
  37. <!-- 上节 -->
  38. <view class="class-block" v-if="classCurrent >= 2">
  39. <view class="block-title">{{classList[classCurrent-2].name}}</view>
  40. <view class="block-tag-box">
  41. <view class="block-tag">{{classList[classCurrent-2].teacher}}</view>
  42. </view>
  43. <view class="block-subtitle">上节</view>
  44. <view class="block-title">{{classList[classCurrent-2].time}}</view>
  45. <view class="btn" @click="navVideoBefore(classCurrent-2)">
  46. <!-- <view class="t-icon t-icon-bofang3"></view> -->
  47. <view class="btn-text">已出勤</view>
  48. </view>
  49. </view>
  50. <!-- 当前 -->
  51. <view class="class-block" style="background-color: #FFF;">
  52. <view class="block-title" style="color: #4169E1;">{{classList[classCurrent-1].name}}</view>
  53. <view class="block-tag-box">
  54. <view class="block-tag">{{classList[classCurrent-1].teacher}}</view>
  55. </view>
  56. <view class="block-index">当前</view>
  57. <view class="block-title" style="color: #4169E1;">{{classList[classCurrent-1].time}}</view>
  58. <view class="btn" style="background-color: #ff5959" @click="navVideoNow(classCurrent-1)">
  59. <!-- <view class="t-icon t-icon-zhibo"></view> -->
  60. <view class="btn-text">正出勤</view>
  61. </view>
  62. </view>
  63. <!-- 下节 -->
  64. <view class="class-block" v-if="!(classCurrent === classList.length)">
  65. <view class="block-title">{{classList[classCurrent].name}}</view>
  66. <view class="block-tag-box">
  67. <view class="block-tag">{{classList[classCurrent].teacher}}</view>
  68. </view>
  69. <view class="block-subtitle">下节</view>
  70. <view class="block-title">{{classList[classCurrent].time}}</view>
  71. <view class="btn" style="background-color: #aaaaaa">
  72. <!-- <view class="t-icon t-icon-daojishi"></view> -->
  73. <view class="btn-text">未开始</view>
  74. </view>
  75. </view>
  76. <!-- 下下节 -->
  77. <view class="class-block" v-if="classCurrent === 1">
  78. <view class="block-title">{{classList[classCurrent+1].name}}</view>
  79. <view class="block-tag-box">
  80. <view class="block-tag">{{classList[classCurrent+1].teacher}}</view>
  81. </view>
  82. <view class="block-subtitle">更晚</view>
  83. <view class="block-title">{{classList[classCurrent+1].time}}</view>
  84. <view class="btn" style="background-color: #aaaaaa">
  85. <!-- <view class="t-icon t-icon-daojishi"></view> -->
  86. <view class="btn-text">未开始</view>
  87. </view>
  88. </view>
  89. </view>
  90. </view>
  91. </view>
  92. </template>
  93. <script>
  94. import {
  95. mapState,
  96. mapMutations
  97. } from 'vuex'
  98. export default {
  99. name: "todayclass-box",
  100. computed: {
  101. ...mapState('m_children', ['classList']),
  102. },
  103. props: {
  104. classCurrent: {
  105. type: Number,
  106. default () {
  107. return -1
  108. }
  109. },
  110. },
  111. data() {
  112. return {
  113. image: {
  114. none: 'https://image.meiye.art/pic_1631411820764Vm5iw82gnV2lVKWRokFmU',
  115. class: 'https://image.meiye.art/pic_1631411821366fqhkuMI110LbOlAIdv1SV',
  116. },
  117. };
  118. },
  119. watch: {
  120. classCurrent() {
  121. this.setClassCurrent()
  122. }
  123. },
  124. methods: {
  125. ...mapMutations('m_children',['updateClassCurrent']),
  126. //获取首页课程数据
  127. setClassCurrent() {
  128. this.updateClassCurrent(this.classCurrent)
  129. },
  130. navClass() {
  131. uni.navigateTo({
  132. url: '/subpkg/classlist/classlist'
  133. })
  134. },
  135. navVideoBefore(index) {
  136. uni.navigateTo({
  137. url: `/subpkg/video/videopage?info=${index}`
  138. })
  139. },
  140. navVideoNow(index) {
  141. uni.navigateTo({
  142. url: `/subpkg/video/livepage?info=${index}`
  143. })
  144. },
  145. },
  146. created() {
  147. this.setClassCurrent()
  148. }
  149. }
  150. </script>
  151. <style lang="scss">
  152. @import '@/pages/common/blockmsg.scss';
  153. .detail-image {
  154. margin-top: -50rpx;
  155. width: 100%;
  156. height: 450rpx;
  157. background-size: 100%;
  158. background-repeat: no-repeat;
  159. }
  160. .block-index {
  161. font-size: 22rpx;
  162. color: $color-mixblue;
  163. }
  164. .t-icon {
  165. width: 46rpx;
  166. height: 46rpx;
  167. }
  168. .btn{
  169. display: flex;
  170. align-items: center;
  171. justify-content: center;
  172. background-color: $color-green;
  173. width: 120rpx;
  174. height: 60rpx;
  175. border-radius: 8rpx;
  176. .btn-text{
  177. color: #FFF;
  178. font-weight: bold;
  179. font-size: 30rpx;
  180. }
  181. }
  182. </style>