hookehuyr

✨ feat(单行文本控件): 联调扫描二维码功能

......@@ -2,7 +2,7 @@
* @Author: hookehuyr hookehuyr@gmail.com
* @Date: 2022-05-26 23:52:36
* @LastEditors: hookehuyr hookehuyr@gmail.com
* @LastEditTime: 2023-02-24 16:09:01
* @LastEditTime: 2023-03-01 15:45:20
* @FilePath: /data-table/src/App.vue
* @Description:
-->
......@@ -27,7 +27,7 @@ import vConsole from "@/utils/vconsole";
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 { wxInfo, getUrlParams, stringifyQuery } from "@/utils/tools";
import { styleColor } from "@/constant.js";
import { getFormSettingAPI } from "@/api/form.js";
......@@ -61,45 +61,9 @@ watch(
// 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 raw_url = encodeURIComponent(location.pathname + location.hash);
// 数据收集设置
const { data } = await getFormSettingAPI({ form_code: code });
const form_setting = {};
......@@ -135,6 +99,18 @@ onMounted(async () => {
}
}
}
// 微信分享打开并且openid存在时,开启wx授权功能
if (form_setting.wxzq_enable && form_setting.x_field_weixin_openid) {
const wxJs = await wxJsAPI({ form_code: code, url: raw_url });
wxJs.data.jsApiList = apiList;
wx.config(wxJs.data);
wx.ready(() => {
wx.showAllNonBaseMenuItem();
});
wx.error((err) => {
console.warn(err);
});
}
});
</script>
......
<!--
* @Date: 2022-08-29 14:31:20
* @LastEditors: hookehuyr hookehuyr@gmail.com
* @LastEditTime: 2023-02-24 16:47:46
* @LastEditTime: 2023-03-01 16:09:00
* @FilePath: /data-table/src/components/TextField/index.vue
* @Description: 单行文本输入框
-->
......@@ -39,25 +39,34 @@ const HideShow = computed(() => {
})
const $route = useRoute();
// TODO: 等待真实数据进行判断,默认条形码识别
const test = $route.query.test;
const scan_type_code = ref(2);
const scanType = (scan_type_code) => {
switch (scan_type_code) {
case 0:
return ["qrCode", "barCode"]
case 1:
return ["qrCode"]
case 2:
return ["barCode"]
}
}
const clickRightIcon = async () => {
const code = getUrlParams(location.href) ? getUrlParams(location.href).code : '';
const raw_url = encodeURIComponent(location.pathname + stringifyQuery($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"], // 可以指定扫二维码还是一维码,默认二者都有
scanType: scanType(scan_type_code.value), // 可以指定扫二维码还是一维码,默认二者都有
success: function (res) {
if (res.errMsg === 'scanQRCode:ok') {
let code = res.resultStr;
let code_arr = code.split(",");
console.warn(code_arr);
props.item.value = code_arr[1];
showSuccessToast('扫描成功')
} else {
console.warn('扫描失败');
console.warn(res);
showFailToast('扫描失败')
}
},
error: function (res) {
......@@ -68,9 +77,6 @@ const clickRightIcon = async () => {
},
});
});
wx.error((err) => {
console.warn(err);
});
}
</script>
......