微信

index.vue 6.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  1. <template>
  2. <div class="mainPage">
  3. <div class="banner">
  4. <div>
  5. <swiper :options="swiperOption" ref="mySwiper">
  6. <swiper-slide class="swiper-slide" v-for="(item,index) in projectInfo.CmsCaseImgs" :key="index">
  7. <img :src='item.CaseImageUrl' class="cover" alt="">
  8. </swiper-slide>
  9. </swiper>
  10. </div>
  11. </div>
  12. <p>{{projectInfo.DetailContent}}</p>
  13. <div class="list flex-h">
  14. <div class="flex-item">
  15. <div v-for="(item,index) in courseList" :key="index">
  16. <span>{{item.month+1}}月</span>
  17. <ul>
  18. <router-link tag="li" v-for="(subItem,subIndex) in item.list" :key="subIndex" :to="{name: 'majorProjectsDetail', query: {id: subItem.id}}" class="flex-h">
  19. <div class="flex-item">
  20. <div>
  21. <courseItem :data="subItem"></courseItem>
  22. </div>
  23. </div>
  24. </router-link>
  25. </ul>
  26. </div>
  27. <div class="cutLine"></div>
  28. <div>
  29. <span>关注我们</span>
  30. <ul>
  31. <li class="flex-h">
  32. <div class="bottom flex-item flex-h">
  33. <div class="flex-item flex-h">
  34. <div class="flex-item">
  35. <div>
  36. <span class="centerLabel">长按右方二维码<br>关注“城的空间”公众号</span>
  37. </div>
  38. </div>
  39. <div class="qrCode">
  40. <a><img src="" class="centerLabel cover" alt=""></a>
  41. </div>
  42. </div>
  43. </div>
  44. </li>
  45. </ul>
  46. </div>
  47. </div>
  48. </div>
  49. </div>
  50. </template>
  51. <script>
  52. import { swiper, swiperSlide } from 'vue-awesome-swiper'
  53. import 'swiper/dist/css/swiper.css'
  54. import { mapState, createNamespacedHelpers } from 'vuex'
  55. const { mapActions: mapProjectActions, mapState: mapProjectState } = createNamespacedHelpers('majorProjects')
  56. import courseItem from '../../../components/courseItem/index'
  57. export default {
  58. name: '',
  59. data () {
  60. return {
  61. swiperOption: {
  62. observer: true,
  63. autoplay: {
  64. disableOnInteraction: false,
  65. }
  66. },
  67. courseList: [], // 课程列表
  68. initList: [
  69. // { // 初始化课程列表
  70. // id: '',
  71. // title: '课程名称',
  72. // img: '',
  73. // time: '2018.04.04 18:30-20:00',
  74. // address: '南京南',
  75. // tag: ['儿童教育', '小小外交官'],
  76. // courseType: '团体课',
  77. // defaultPrice: '168/节',
  78. // getWay: 'ticket',
  79. // startDate: 1514779200000,
  80. // endDate: 1514781600000,
  81. // }, {
  82. // id: '',
  83. // title: '课程名称',
  84. // img: '',
  85. // time: '2018.04.04 18:30-20:00',
  86. // address: '南京南',
  87. // tag: ['儿童教育', '小小外交官'],
  88. // courseType: '团体课',
  89. // defaultPrice: '168/节',
  90. // getWay: 'ticket',
  91. // startDate: 1514779200000,
  92. // endDate: 1514781600000,
  93. // }, {
  94. // id: '',
  95. // title: '课程名称',
  96. // img: '',
  97. // time: '2018.04.04 18:30-20:00',
  98. // address: '南京南',
  99. // tag: ['儿童教育', '小小外交官'],
  100. // courseType: '团体课',
  101. // defaultPrice: '168/节',
  102. // getWay: 'ticket',
  103. // startDate: 1517460000000,
  104. // endDate: 1517467200000,
  105. // }, {
  106. // id: '',
  107. // title: '课程名称',
  108. // img: '',
  109. // time: '2018.04.04 18:30-20:00',
  110. // address: '南京南',
  111. // tag: ['儿童教育', '小小外交官'],
  112. // courseType: '团体课',
  113. // defaultPrice: '168/节',
  114. // getWay: 'ticket',
  115. // startDate: 1517460000000,
  116. // endDate: 1517467200000,
  117. // }
  118. ],
  119. }
  120. },
  121. computed: {
  122. ...mapState({
  123. orgid: x => x.app.orgId,
  124. fiveA: x => x.index.fiveA,
  125. banner: x => x.index.banner,
  126. message: x => x.index.message,
  127. project: x => x.index.project,
  128. cms: x => x.index.cms,
  129. }),
  130. ...mapProjectState({
  131. projectInfo: x => x.projectInfo
  132. }),
  133. MySwiper () {
  134. return this.$refs.mySwiper.swiper
  135. },
  136. },
  137. components: {
  138. courseItem,
  139. swiper,
  140. swiperSlide,
  141. },
  142. created () {
  143. this.initData()
  144. },
  145. methods: {
  146. ...mapProjectActions([
  147. 'getProjectInfo',
  148. ]),
  149. returnTag (arr) {
  150. var aArr = []
  151. for (var n = 0; n < arr.length; n++) {
  152. aArr.push(arr[n].TagName)
  153. }
  154. return aArr
  155. },
  156. returnNum (val) {
  157. return val > 9 ? val : '0' + val
  158. },
  159. returnDate (val) {
  160. val = new Date(val)
  161. return val.getFullYear() + '.' + this.returnNum(val.getMonth()+1) + '.' + this.returnNum(val.getDate())
  162. },
  163. initData () { // 初始化数据
  164. this.getProjectInfo({ id: this.$route.query.id }).then((res) => {
  165. // console.log(JSON.stringify(res))
  166. // this.initList
  167. var aArr = []
  168. for (var n = 0; n < res.Courses.length; n++) {
  169. aArr.push({
  170. id: res.Courses[n].CourseId,
  171. title: res.Courses[n].CourseName,
  172. img: res.Courses[n].CourseImg,
  173. time: this.returnDate(res.Courses[n].BeginDate) + '至' + this.returnDate(res.Courses[n].EndDate),
  174. address: res.CaseAddress == undefined ? '暂无数据' : res.CaseAddress,
  175. tag: this.returnTag(res.Courses[n].CourseTags),
  176. courseType: '团体课',
  177. defaultPrice: res.Courses[n].Price + '/节',
  178. getWay: 'ticket',
  179. startDate: new Date(res.Courses[n].BeginDate).getTime(),
  180. endDate: new Date(res.Courses[n].EndDate).getTime(),
  181. })
  182. }
  183. this.initList = aArr
  184. this.calcArr()
  185. })
  186. },
  187. calcArr () {
  188. let arr = []
  189. for (var n = 0; n < this.initList.length; n++) {
  190. arr.push(new Date(this.initList[n].startDate).getMonth())
  191. }
  192. for (var i = 0; i < arr.length; i++) {
  193. if (arr.indexOf(arr[i]) !== i) {
  194. arr.splice(i, 1)
  195. i--
  196. }
  197. }
  198. for (var i = 0; i < arr.length; i++) {
  199. this.courseList.push({
  200. month: arr[i],
  201. list: []
  202. })
  203. }
  204. for (var n = 0; n < this.initList.length; n++) {
  205. for (var i = 0; i < this.courseList.length; i++) {
  206. if (new Date(this.initList[n].startDate).getMonth() === this.courseList[i].month) {
  207. this.courseList[i].list.push(this.initList[n])
  208. }
  209. }
  210. }
  211. },
  212. }
  213. }
  214. </script>
  215. <!-- Add "scoped" attribute to limit CSS to this component only -->
  216. <style lang="scss" scoped>
  217. @import "page.scss";
  218. </style>