zj-page-layout.vue 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. <template>
  2. <view class="app-container" :class="hasFooter || isTabbar ? '':'pb'"
  3. :style="{background: bgColor, height: 'calc(100vh - ' + aHeight + 'px)'}">
  4. <u-loading-page color="#333333" fontSize="17" icon-size="44" :loading="isLoading"></u-loading-page>
  5. <block v-if="!isLoading">
  6. <view class="header-container">
  7. <slot name="header"></slot>
  8. </view>
  9. <view class="content-container">
  10. <template v-if="isScroll">
  11. <scroll-view scroll-y enable-flex refresher-enabled style="width: 100%; height: 100%; box-sizing: border-box;"
  12. :refresher-background="refresherBackground" @scrolltoupper="(...p)=>{$emit('scrolltoupper',p)}"
  13. @scrolltolower="(...p)=>{$emit('scrolltolower',p)}" @scroll="(...p)=>{$emit('scroll',p)}"
  14. @refresherpulling="(...p)=>{$emit('refresherpulling',p)}"
  15. @refresherrefresh="(...p)=>{$emit('refresherrefresh',p)}"
  16. @refresherrestore="(...p)=>{$emit('refresherrestore',p)}"
  17. @refresherabort="(...p)=>{$emit('refresherabort',p)}" :refresher-triggered="refresherTriggered">
  18. <slot></slot>
  19. </scroll-view>
  20. </template>
  21. <template v-else>
  22. <view style="width: 100%; height: 100%; box-sizing: border-box; overflow-y: scroll;">
  23. <slot></slot>
  24. </view>
  25. </template>
  26. </view>
  27. <view class="footer-container" v-if="hasFooter">
  28. <slot name="footer"></slot>
  29. </view>
  30. </block>
  31. </view>
  32. </template>
  33. <script>
  34. export default {
  35. props: {
  36. bgColor: {
  37. type: String,
  38. default: '#F7F8FF',
  39. },
  40. refresherBackground: {
  41. type: String,
  42. default: '#F7F8FF',
  43. },
  44. hasFooter: {
  45. type: Boolean,
  46. default: false,
  47. },
  48. isScroll: {
  49. type: Boolean,
  50. default: false,
  51. },
  52. refresherTriggered: {
  53. type: Boolean,
  54. default: false,
  55. },
  56. isLoading: {
  57. type: Boolean,
  58. default: false,
  59. },
  60. isWxCustomPage: {
  61. type: Boolean,
  62. default: false,
  63. },
  64. },
  65. computed: {
  66. isTabbar() {
  67. let pages = getCurrentPages();
  68. if (pages.length > 0) {
  69. let prevPage = pages[pages.length - 1];
  70. if (prevPage.route === 'pages/index/index' || prevPage.route === 'pages/workorder/index' || prevPage.route ===
  71. 'pages/goods/index' || prevPage.route === 'pages/mine/index') {
  72. return true;
  73. } else {
  74. return false;
  75. }
  76. }
  77. },
  78. aHeight() {
  79. let num = 0;
  80. // #ifdef H5
  81. if(this.isWxCustomPage) {
  82. num = 50;
  83. } else if (this.isTabbar) {
  84. num = 0+50;
  85. } else {
  86. num = 0;
  87. }
  88. // #endif
  89. return num;
  90. },
  91. }
  92. }
  93. </script>
  94. <style lang="scss" scoped>
  95. ::v-deep .u-loading-page {
  96. z-index: 999999;
  97. }
  98. .app-container {
  99. width: 100%;
  100. height: 100vh;
  101. box-sizing: border-box;
  102. display: flex;
  103. flex-direction: column;
  104. &.pb {
  105. padding-bottom: env(safe-area-inset-bottom);
  106. }
  107. .header-container {
  108. flex-shrink: 0;
  109. }
  110. .content-container {
  111. flex: 1;
  112. height: 0;
  113. }
  114. .footer-container {
  115. flex-shrink: 0;
  116. padding-bottom: env(safe-area-inset-bottom);
  117. background: #ffffff;
  118. box-sizing: border-box;
  119. box-shadow: $bottom-shadow;
  120. position: relative;
  121. z-index: 1;
  122. }
  123. }
  124. </style>