index.vue 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. <template>
  2. <div class="m-container">
  3. <h2>
  4. <el-page-header @back="onCancel" :content="studentName"></el-page-header>
  5. </h2>
  6. <div class="m-core">
  7. <!-- navMenu -->
  8. <tab-router
  9. v-model.trim="activeIndex"
  10. type="card"
  11. @tab-click="handleClick"
  12. >
  13. <el-tab-pane
  14. label="基本信息"
  15. lazy
  16. v-if="permissionList.studentInfo"
  17. name="1"
  18. >
  19. <studentInfo v-if="activeIndex == 1" />
  20. </el-tab-pane>
  21. <el-tab-pane
  22. label="乐团&课程"
  23. lazy
  24. v-if="permissionList.teamAndcourse"
  25. name="2"
  26. >
  27. <teamAndcourse v-if="activeIndex == 2" />
  28. </el-tab-pane>
  29. <el-tab-pane
  30. label="VIP课"
  31. lazy
  32. v-if="permissionList.studentVip"
  33. name="3"
  34. >
  35. <studentVip v-if="activeIndex == 3" />
  36. </el-tab-pane>
  37. <el-tab-pane
  38. label="对外课"
  39. lazy
  40. v-if="permissionList.studentOutList"
  41. name="4"
  42. >
  43. <studentOutList v-if="activeIndex == 4" />
  44. </el-tab-pane>
  45. <el-tab-pane
  46. label="网管课"
  47. lazy
  48. v-if="permissionList.studentNetwork"
  49. name="9"
  50. >
  51. <studentNetwork v-if="activeIndex == 9" />
  52. </el-tab-pane>
  53. <el-tab-pane
  54. label="课表详情"
  55. lazy
  56. v-if="permissionList.studentRecord"
  57. name="5"
  58. >
  59. <studentRecord v-if="activeIndex == 5" />
  60. </el-tab-pane>
  61. <el-tab-pane
  62. label="扣费记录"
  63. lazy
  64. v-if="permissionList.studentPayList"
  65. name="6"
  66. >
  67. <studentPayList v-if="activeIndex == 6" />
  68. </el-tab-pane>
  69. <el-tab-pane
  70. label="学员订单"
  71. lazy
  72. v-if="permissionList.studentOrder"
  73. name="7"
  74. >
  75. <studentOrder v-if="activeIndex == 7" />
  76. </el-tab-pane>
  77. <el-tab-pane
  78. label="学员提现"
  79. lazy
  80. v-if="permissionList.studentCashout"
  81. name="8"
  82. >
  83. <studentCashout v-if="activeIndex == 8" />
  84. </el-tab-pane>
  85. </tab-router>
  86. </div>
  87. </div>
  88. </template>
  89. <script>
  90. import studentInfo from "./components/studentInfo.vue";
  91. import teamAndcourse from "./components/teamAndcourse.vue";
  92. import studentRecord from "./components/studentRecord.vue";
  93. import studentPayList from "./components/studentPayList.vue";
  94. import studentVip from "./components/studentVip.vue";
  95. import studentOutList from "./components/studentOutList.vue";
  96. import studentOrder from "./components/studentOrder.vue";
  97. import studentCashout from "./components/studentCashout.vue";
  98. import studentNetwork from "./components/studentNetwork.vue";
  99. import { permission } from "@/utils/directivePage";
  100. export default {
  101. components: {
  102. teamAndcourse,
  103. studentRecord,
  104. studentPayList,
  105. studentInfo,
  106. studentVip,
  107. studentOrder,
  108. studentCashout,
  109. studentOutList,
  110. studentNetwork,
  111. },
  112. name: "studentDetail",
  113. data() {
  114. return {
  115. activeIndex: "1",
  116. // acitveStatus: [true, false, false, false, false, false, false]
  117. permissionList: {
  118. studentInfo: permission("/studentDetail/studentInfo"),
  119. teamAndcourse: permission("/studentDetail/teamAndcourse"),
  120. studentVip: permission("/studentDetail/studentVip"),
  121. studentRecord: permission("/studentDetail/studentRecord"),
  122. studentPayList: permission("/studentDetail/studentPayList"),
  123. studentOrder: permission("/studentDetail/studentOrder"),
  124. studentCashout: permission("/studentDetail/studentCashout"),
  125. studentOutList: permission("/studentDetail/studentOutList"), //
  126. studentNetwork: permission("/studentDetail/studentNetwork"),
  127. },
  128. studentName: "",
  129. };
  130. },
  131. mounted() {
  132. if (this.$route.query.search) {
  133. this.Fsearch = this.$route.query.search;
  134. }
  135. if (this.$route.query.rules) {
  136. this.Frules = this.$route.query.rules;
  137. }
  138. this.studentName = this.$route.query.username;
  139. },
  140. activated() {
  141. if (this.$route.query.search) {
  142. this.Fsearch = this.$route.query.search;
  143. }
  144. if (this.$route.query.rules) {
  145. this.Frules = this.$route.query.rules;
  146. }
  147. this.studentName = this.$route.query.username;
  148. },
  149. methods: {
  150. onCancel() {
  151. this.$store.dispatch("delVisitedViews", this.$route);
  152. this.$router.push({
  153. path: "/business/studentList",
  154. });
  155. },
  156. handleClick(val) {
  157. this.activeIndex = val.name;
  158. // this.acitveStatus[val.name - 1] = true
  159. },
  160. },
  161. };
  162. </script>
  163. <style lang="scss">
  164. </style>