index.vue 3.2 KB
Newer Older
fxy060608's avatar
fxy060608 已提交
1 2 3 4 5 6 7 8
<template>
  <uni-app :class="{'uni-app--showtabbar':showTabBar}">
    <!-- <transition :name="transitionName"> -->
    <!-- TODO -->
    <keep-alive :include="keepAliveInclude">
      <router-view :key="key" />
    </keep-alive>
    <!-- </transition> -->
9 10 11
    <tab-bar
      v-if="hasTabBar"
      v-show="showTabBar"
fxy060608's avatar
fxy060608 已提交
12
      v-bind="tabBar" />
Q
qiang 已提交
13
    <toast
fxy060608's avatar
fxy060608 已提交
14
      v-if="$options.components.Toast"
15
      v-bind="showToast"/>
Q
qiang 已提交
16
    <action-sheet
fxy060608's avatar
fxy060608 已提交
17
      v-if="$options.components.ActionSheet"
18
      v-bind="showActionSheet"
fxy060608's avatar
fxy060608 已提交
19
      @close="_onActionSheetClose" />
Q
qiang 已提交
20
    <modal
fxy060608's avatar
fxy060608 已提交
21
      v-if="$options.components.Modal"
22
      v-bind="showModal"
fxy060608's avatar
fxy060608 已提交
23 24 25 26
      @close="_onModalClose" />
  </uni-app>
</template>
<script>
fxy060608's avatar
fxy060608 已提交
27 28 29 30
import {
  isPlainObject
} from 'uni-shared'

fxy060608's avatar
fxy060608 已提交
31 32 33 34 35 36
import {
  TABBAR_HEIGHT
} from 'uni-helpers/constants'

import components from './components'

fxy060608's avatar
fxy060608 已提交
37
import mixins from 'uni-h5-app-mixins'
fxy060608's avatar
fxy060608 已提交
38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73

export default {
  name: 'App',
  components,
  mixins,
  props: {
    keepAliveInclude: {
      type: Array,
      default: function () {
        return []
      }
    }
  },
  data () {
    return {
      transitionName: 'fade',
      hideTabBar: false,
      tabBar: __uniConfig.tabBar || {}
    }
  },
  computed: {
    key () {
      return this.$route.meta.name + '-' + this.$route.params.__id__ + '-' + (__uniConfig.reLaunch || 1)
    },
    hasTabBar () {
      return __uniConfig.tabBar && __uniConfig.tabBar.list && __uniConfig.tabBar.list.length
    },
    showTabBar () {
      return this.$route.meta.isTabBar && !this.hideTabBar
    }
  },
  watch: {
    $route (newRoute, oldRoute) {
      UniServiceJSBridge.emit('onHidePopup')
    },
    hideTabBar (newVal, oldVal) {
fxy060608's avatar
fxy060608 已提交
74 75
      // TODO 不支持 css 变量时
      if (uni.canIUse('css.var')) {
Q
qiang 已提交
76 77 78
        const windowBottomValue = !newVal ? (TABBAR_HEIGHT) : 0
        const envMethod = uni.canIUse('css.env') ? 'env' : (uni.canIUse('css.constant') ? 'constant' : '')
        const windowBottom = windowBottomValue && envMethod ? `calc(${windowBottomValue}px + ${envMethod}(safe-area-inset-bottom))` : `${windowBottomValue}px`
fxy060608's avatar
fxy060608 已提交
79 80
        document.documentElement.style.setProperty('--window-bottom', windowBottom)
        console.debug(`uni.${windowBottom ? 'showTabBar' : 'hideTabBar'}:--window-bottom=${windowBottom}`)
fxy060608's avatar
fxy060608 已提交
81
      }
82 83
      // 触发 resize 事件
      window.dispatchEvent(new CustomEvent('resize'))
fxy060608's avatar
fxy060608 已提交
84 85 86
    }
  },
  created () {
fxy060608's avatar
fxy060608 已提交
87 88
    if (uni.canIUse('css.var')) {
      document.documentElement.style.setProperty('--status-bar-height', '0px')
fxy060608's avatar
fxy060608 已提交
89 90 91
    }
  },
  mounted () {
fxy060608's avatar
fxy060608 已提交
92 93 94 95 96
    window.addEventListener('message', function (evt) {
      if (isPlainObject(evt.data) && evt.data.type === 'WEB_INVOKE_APPSERVICE') {
        UniServiceJSBridge.emit('onWebInvokeAppService', evt.data.data, evt.data.pageId)
      }
    })
fxy060608's avatar
fxy060608 已提交
97 98 99 100 101 102 103 104 105 106 107
    document.addEventListener('visibilitychange', function () {
      if (document.visibilityState === 'visible') {
        UniServiceJSBridge.emit('onAppEnterForeground')
      } else {
        UniServiceJSBridge.emit('onAppEnterBackground')
      }
    })
  }
}
</script>

Q
qiang 已提交
108
<style>
fxy060608's avatar
fxy060608 已提交
109
  @import "~uni-core/view/index.css";
fxy060608's avatar
fxy060608 已提交
110 111 112 113 114 115
	uni-app {
		display: block;
		box-sizing: border-box;
		width: 100%;
		height: 100%;
	}
116
</style>