App.vue 4.81 KB
<!--
 * @Author: hookehuyr hookehuyr@gmail.com
 * @Date: 2022-05-26 23:52:36
 * @LastEditors: hookehuyr hookehuyr@gmail.com
 * @LastEditTime: 2023-02-24 16:09:01
 * @FilePath: /data-table/src/App.vue
 * @Description:
-->
<template>
  <van-row v-if="is_pc">
    <van-col span="22" offset="1">
      <router-view></router-view>
    </van-col>
  </van-row>
  <router-view v-else></router-view>
</template>

<script setup>
import { mainStore, useTitle } from "@/utils/generatePackage";
import { computed, watchEffect, onMounted } from "vue";
import { useRoute, useRouter } from "vue-router";
import { Toast } from "vant";
// 会根据配置判断是否显示调试控件
// eslint-disable-next-line no-unused-vars
import vConsole from "@/utils/vconsole";
// 初始化WX环境
import wx from 'weixin-js-sdk'
import { wxJsAPI } from '@/api/wx/config'
import { apiList } from '@/api/wx/jsApiList.js'
import { wxInfo, getUrlParams } from "@/utils/tools";
import { styleColor } from "@/constant.js";
import { getFormSettingAPI } from "@/api/form.js";

// 使用 include + pinia 状态管理动态缓存页面
const store = mainStore();
const keepPages = computed(() => store.getKeepPages);

// // TAG: 全局设置页面标题
const $route = useRoute();
// watchEffect(() => useTitle("表单标题"));
// 监听路由变化
// 切换路由页面返回顶部
const $router = useRouter();
watch(
  () => $router.currentRoute.value,
  (newValue, oldValue) => {
    nextTick(() => {
      // document.getElementById('app')?.scrollIntoView();
    });
    // console.warn(wxInfo().isMobile);
  },
  { immediate: true }
);

// TAG: 全局配置Toast
// Toast.setDefaultOptions({
//   duration: 2000,
//   className: 'zIndex'
// });

// web端判断
const is_pc = computed(() => wxInfo().isPC);

// const stringify = (params) => {
//   const queryString = []
//   Object.keys(params || {}).forEach(k => {
//     queryString.push(k + '=' + params[k])
//   })

//   return '?' + queryString.join('&')
// }

onMounted(async () => {
  const code = getUrlParams(location.href) ? getUrlParams(location.href).code : '';
  // const raw_url = encodeURIComponent(location.origin + location.pathname + stringify($route.query)); // 未授权的地址
  // const wxJs = await wxJsAPI({ form_code: code, url: raw_url });
  // wxJs.data.jsApiList = apiList;
  // wx.config(wxJs.data);
  // wx.ready(() => {
  //   wx.scanQRCode({
  //     needResult: 1, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
  //     scanType: ["qrCode", "barCode"], // 可以指定扫二维码还是一维码,默认二者都有
  //     success: function (res) {
  //       if (res.errMsg === 'scanQRCode:ok') {
  //         let code = res.resultStr;
  //         let code_arr = code.split(",");
  //         console.warn(code_arr);
  //       } else {
  //         console.warn('扫描失败');
  //       }
  //     },
  //     error: function (res) {
  //       if (res.errMsg.indexOf('function_not_exist') > 0) {
  //         alert('版本过低请升级')
  //       }
  //       alert(res.errMsg);
  //     },
  //   });
  // });
  // wx.error((err) => {
  //   console.warn(err);
  // });
  // 数据收集设置
  const { data } = await getFormSettingAPI({ form_code: code });
  const form_setting = {};
  if (data.length) {
    Object.assign(form_setting, data[0]['property_list'], data[0]['extend']);
  }
  // 缓存表单设置
  store.changeFormSetting(form_setting);
  // 需要网页授权-必须要域名相同,需要上传到线上测试
  if (!import.meta.env.DEV && form_setting.wxzq_enable && !form_setting.x_field_weixin_openid) {
    $router.replace({
      path: '/auth',
      query: {
        href: location.hash,
        code
      }
    });
  } else {
    // 判断跳转页面
    if (form_setting.sjsj_enable && !form_setting.sjsj_enable) {
      // 表单已结束
      $router.push("/stop?status=disable");
    }
    // 开启后有开始和结束时间,不在时间范围的显示表单还未开始或者已经结束
    if (form_setting.sjsj_is_time_range && form_setting.sjsj_is_time_range) {
      // 未开始
      if (form_setting.server_time < form_setting.sjsj_begin_time) {
        $router.push("/stop?status=apply");
      }
      // 已结束
      if (form_setting.server_time > form_setting.sjsj_end_time) {
        $router.push("/stop?status=finish");
      }
    }
  }
});
</script>

<style lang="less">
@prefix: ~"@{namespace}-x";

html,
body {
  width: 100%;
  // height: 100%;
  color: @base-font-color;
  // background-color: #f7f8fa;
  // background-color: #fff9ef;
  padding: 0;
  margin: 0;
}

body {
  position: relative;
  p {
    margin: 0;
    padding: 0;
  }
}

#app {
  min-height: calc(100vh);
  position: relative;
}

.@{prefix} {
  color: red;
}

.global-center {
  position: relative;
  top: 50%;
  transform: translateY(-50%);
}

.zIndex {
  z-index: 4500 !important;
}
</style>