CardIndex.vue 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <template>
  2. <el-container direction="vertical">
  3. <el-tabs type="border-card" style="height: 100%;" v-model="selectedTab">
  4. <el-tab-pane label="Поиск"></el-tab-pane>
  5. <el-tab-pane label="Автор"></el-tab-pane>
  6. <el-tab-pane label="Книга"></el-tab-pane>
  7. <el-tab-pane label="История"></el-tab-pane>
  8. <router-view></router-view>
  9. </el-tabs>
  10. </el-container>
  11. </template>
  12. <script>
  13. //-----------------------------------------------------------------------------
  14. import Vue from 'vue';
  15. import Component from 'vue-class-component';
  16. import _ from 'lodash';
  17. const tab2Route = [
  18. '/cardindex/search',
  19. '/cardindex/card',
  20. '/cardindex/book',
  21. '/cardindex/history',
  22. ];
  23. let lastActiveTab = null;
  24. export default @Component({
  25. watch: {
  26. selectedTab: function(newValue, oldValue) {
  27. lastActiveTab = newValue;
  28. const t = Number(newValue);
  29. if (tab2Route[t] !== this.curRoute) {
  30. this.$router.replace(tab2Route[t]);
  31. }
  32. },
  33. curRoute: function(newValue, oldValue) {
  34. this.setTabByRoute(newValue);
  35. },
  36. },
  37. })
  38. class CardIndex extends Vue {
  39. selectedTab = null;
  40. mounted() {
  41. this.setTabByRoute(this.curRoute);
  42. if (lastActiveTab !== null)
  43. this.selectedTab = lastActiveTab;
  44. }
  45. setTabByRoute(route) {
  46. const t = _.indexOf(tab2Route, route);
  47. if (t >= 0 && t !== this.selectedTab) {
  48. this.selectedTab = t.toString();
  49. }
  50. }
  51. get curRoute() {
  52. const m = this.$route.path.match(/^(\/[^\/]*\/[^\/]*).*$/i);
  53. return (m ? m[1] : this.$route.path);
  54. }
  55. }
  56. //-----------------------------------------------------------------------------
  57. </script>
  58. <style scoped>
  59. </style>