| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250 | 
							- <template>
 
-   <view
 
-     class="page-app"
 
-     :class="['theme-' + sys.mode, 'main-' + sys.theme, 'font-' + sys.fontSize]"
 
-   >
 
-     <view class="page-main" :style="[bgMain]">
 
-       <!-- 默认通用顶部导航栏 -->
 
-       <su-navbar
 
-         v-if="navbar === 'normal'"
 
-         :title="title"
 
-         statusBar
 
-         :color="color"
 
-         :tools="tools"
 
-         :opacityBgUi="opacityBgUi"
 
-         @search="(e) => emits('search', e)"
 
-         :defaultSearch="defaultSearch"
 
-       />
 
-       <!-- 装修组件导航栏-普通 -->
 
-       <s-custom-navbar
 
-         v-else-if="navbar === 'custom' && navbarMode === 'normal'"
 
-         :data="navbarStyle"
 
-         :showLeftButton="showLeftButton"
 
-       />
 
-       <view class="page-body" :style="[bgBody]">
 
-         <!-- 沉浸式头部 -->
 
-         <su-inner-navbar v-if="navbar === 'inner'" :title="title" />
 
-         <view
 
-           v-if="navbar === 'inner'"
 
-           :style="[{ paddingTop: sheep.$platform.navbar + 'px' }]"
 
-         ></view>
 
-         <!-- 装修组件导航栏-沉浸式 -->
 
-         <s-custom-navbar v-if="navbar === 'custom' && navbarMode === 'inner'" :data="navbarStyle" :showLeftButton="showLeftButton" />
 
-         <!-- 页面内容插槽 -->
 
-         <slot />
 
-         <!-- 悬浮按钮 -->
 
-         <s-float-menu v-if="showFloatButton"></s-float-menu>
 
-         <!-- 底部导航 -->
 
-         <s-tabbar v-if="tabbar !== ''" :path="tabbar" />
 
-       </view>
 
-     </view>
 
-     <view class="page-modal">
 
-       <!-- 全局授权弹窗 -->
 
-       <s-auth-modal />
 
-       <!-- 全局分享弹窗 -->
 
-       <s-share-modal :shareInfo="shareInfo" />
 
-       <!-- 全局快捷入口 -->
 
-       <s-menu-tools />
 
-     </view>
 
-   </view>
 
- </template>
 
- <script setup>
 
-   /**
 
-    * 模板组件 - 提供页面公共组件,属性,方法
 
-    */
 
-   import { computed, reactive, ref } from 'vue';
 
-   import sheep from '@/sheep';
 
-   import { isEmpty } from 'lodash';
 
-   import { onShow } from '@dcloudio/uni-app';
 
-   // #ifdef MP-WEIXIN
 
-   import { onShareAppMessage } from '@dcloudio/uni-app';
 
-   // #endif
 
-   const props = defineProps({
 
-     title: {
 
-       type: String,
 
-       default: '',
 
-     },
 
-     navbar: {
 
-       type: String,
 
-       default: 'normal',
 
-     },
 
-     opacityBgUi: {
 
-       type: String,
 
-       default: 'bg-white',
 
-     },
 
-     color: {
 
-       type: String,
 
-       default: '',
 
-     },
 
-     tools: {
 
-       type: String,
 
-       default: 'title',
 
-     },
 
-     keyword: {
 
-       type: String,
 
-       default: '',
 
-     },
 
-     navbarStyle: {
 
-       type: Object,
 
-       default: () => ({
 
-         mode: '',
 
-         type: '',
 
-         color: '',
 
-         src: '',
 
-         list: [],
 
-         alwaysShow: 0,
 
-       }),
 
-     },
 
-     bgStyle: {
 
-       type: Object,
 
-       default: () => ({
 
-         src: '',
 
-         color: 'var(--ui-BG-1)',
 
-       }),
 
-     },
 
-     tabbar: {
 
-       type: [String, Boolean],
 
-       default: '',
 
-     },
 
-     onShareAppMessage: {
 
-       type: [Boolean, Object],
 
-       default: true,
 
-     },
 
-     leftWidth: {
 
-       type: [Number, String],
 
-       default: 100,
 
-     },
 
-     rightWidth: {
 
-       type: [Number, String],
 
-       default: 100,
 
-     },
 
-     defaultSearch: {
 
-       type: String,
 
-       default: '',
 
-     },
 
-     //展示悬浮按钮
 
-     showFloatButton: {
 
-       type: Boolean,
 
-       default: false,
 
-     },
 
-     //展示返回按钮
 
-     showLeftButton: {
 
-       type: Boolean,
 
-       default: false,
 
-     },
 
-   });
 
-   const emits = defineEmits(['search']);
 
-   const sysStore = sheep.$store('sys');
 
-   const userStore = sheep.$store('user');
 
-   const appStore = sheep.$store('app');
 
-   const modalStore = sheep.$store('modal');
 
-   const sys = computed(() => sysStore);
 
-   // 导航栏模式(因为有自定义导航栏 需要计算)
 
-   const navbarMode = computed(() => {
 
-     if (props.navbar === 'normal' || props.navbarStyle.mode === 'normal') {
 
-       return 'normal';
 
-     }
 
-     return 'inner';
 
-   });
 
-   // 背景1
 
-   const bgMain = computed(() => {
 
-     if (navbarMode.value === 'inner') {
 
-       return {
 
-         background: `${props.bgStyle.color} url(${sheep.$url.cdn(
 
-           props.bgStyle.src,
 
-         )}) no-repeat top center / 100% auto`,
 
-       };
 
-     }
 
-     return {};
 
-   });
 
-   // 背景2
 
-   const bgBody = computed(() => {
 
-     if (navbarMode.value === 'normal') {
 
-       return {
 
-         background: `${props.bgStyle.color} url(${sheep.$url.cdn(
 
-           props.bgStyle.src,
 
-         )}) no-repeat top center / 100% auto`,
 
-       };
 
-     }
 
-     return {};
 
-   });
 
-   // 分享信息
 
-   const shareInfo = computed(() => {
 
-     if (props.onShareAppMessage === true) {
 
-       return sheep.$platform.share.getShareInfo();
 
-     } else {
 
-       if (!isEmpty(props.onShareAppMessage)) {
 
-         sheep.$platform.share.updateShareInfo(props.onShareAppMessage);
 
-         return props.onShareAppMessage;
 
-       }
 
-     }
 
-     return {};
 
-   });
 
-   // #ifdef MP-WEIXIN
 
-   // 微信小程序分享
 
-   onShareAppMessage(() => {
 
-     return {
 
-       title: shareInfo.value.title,
 
-       path: shareInfo.value.path,
 
-       imageUrl: shareInfo.value.image,
 
-     };
 
-   });
 
-   // #endif
 
-   onShow(() => {
 
-     if (!isEmpty(shareInfo.value)) {
 
-       sheep.$platform.share.updateShareInfo(shareInfo.value);
 
-     }
 
-   });
 
- </script>
 
- <style lang="scss" scoped>
 
-   .page-app {
 
-     position: relative;
 
-     color: var(--ui-TC);
 
-     background-color: var(--ui-BG-1) !important;
 
-     z-index: 2;
 
-     display: flex;
 
-     width: 100%;
 
-     height: 100vh;
 
-     .page-main {
 
-       position: absolute;
 
-       z-index: 1;
 
-       width: 100%;
 
-       min-height: 100%;
 
-       display: flex;
 
-       flex-direction: column;
 
-       .page-body {
 
-         width: 100%;
 
-         position: relative;
 
-         z-index: 1;
 
-         flex: 1;
 
-       }
 
-       .page-img {
 
-         width: 100vw;
 
-         height: 100vh;
 
-         position: absolute;
 
-         top: 0;
 
-         left: 0;
 
-         z-index: 0;
 
-       }
 
-     }
 
-   }
 
- </style>
 
 
  |