31 changed files with 1063 additions and 162 deletions
@ -0,0 +1,33 @@ |
|||||||
|
<template> |
||||||
|
<view class="view"> |
||||||
|
<slot></slot> |
||||||
|
<view class="safe" v-if="isFit"></view> |
||||||
|
</view> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script> |
||||||
|
export default { |
||||||
|
name: 'cs-bottom-wrapper', |
||||||
|
data() { |
||||||
|
return {} |
||||||
|
}, |
||||||
|
computed: { |
||||||
|
isFit() { |
||||||
|
return uni.getStorageSync('SYSTEM').includes('iOS') |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
</script> |
||||||
|
|
||||||
|
<style lang="scss" scoped> |
||||||
|
.view { |
||||||
|
position: absolute; |
||||||
|
bottom: 0; |
||||||
|
left: 0; |
||||||
|
width: 100%; |
||||||
|
background-color: #fff; |
||||||
|
.safe { |
||||||
|
height: 25px; |
||||||
|
} |
||||||
|
} |
||||||
|
</style> |
After Width: | Height: | Size: 5.9 KiB |
After Width: | Height: | Size: 955 B |
After Width: | Height: | Size: 44 KiB |
After Width: | Height: | Size: 77 KiB |
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -1,3 +1,15 @@ |
|||||||
page { |
page { |
||||||
background-color: #f9f9f9; |
background-color: #f9f9f9; |
||||||
|
position: relative; |
||||||
|
} |
||||||
|
|
||||||
|
button { |
||||||
|
padding-left: 0; |
||||||
|
padding-right: 0; |
||||||
|
font-size: 16px; |
||||||
|
line-height: inherit; |
||||||
|
&::after { |
||||||
|
content: ''; |
||||||
|
display: none; |
||||||
|
} |
||||||
} |
} |
||||||
|
@ -1,46 +1,103 @@ |
|||||||
<template> |
<template> |
||||||
<view class="wd-flex wd-flex-col wd-flex-center" style="height: 100%; gap: 10px"> |
<view class="waiting"> |
||||||
<icon type="waiting" size="40" /> |
<u--image |
||||||
<button @tap="btnLogin">允许登陆</button> |
src="/static/favicon.png" |
||||||
</view> |
width="144px" |
||||||
|
height="144px" |
||||||
|
mode="aspectFit" |
||||||
|
:fade="true" |
||||||
|
duration="200" |
||||||
|
></u--image> |
||||||
|
<button |
||||||
|
class="login" |
||||||
|
@click="login" |
||||||
|
:loading="loading" |
||||||
|
loadingText="授权中..." |
||||||
|
v-if="!isLogin" |
||||||
|
> |
||||||
|
授权登录 |
||||||
|
</button> |
||||||
|
<text v-else class="title">登录成功</text> |
||||||
|
</view> |
||||||
</template> |
</template> |
||||||
|
|
||||||
<script> |
<script> |
||||||
import { |
import { getAccessToken, getOpenId } from '@/utils/auth' |
||||||
getAccessToken,getOpenId |
import { qrLogin } from '@/api/login' |
||||||
} from '@/utils/auth' |
|
||||||
import {qrLogin}from '@/api/login' |
|
||||||
|
|
||||||
export default { |
export default { |
||||||
data() { |
data() { |
||||||
return { |
return { |
||||||
scene:"" |
scene: '', |
||||||
} |
loading: false, |
||||||
}, |
isLogin: false |
||||||
onShow(res) { |
} |
||||||
console.log(res) |
}, |
||||||
}, |
methods: { |
||||||
|
login() { |
||||||
methods: { |
if (!this.scene) { |
||||||
btnLogin() { |
uni |
||||||
|
.showModal({ |
||||||
const openid = getOpenId() |
content: '链接失效,请重新扫码', |
||||||
console.log('登陆信息发送', this.scene) |
showCancel: false |
||||||
console.log('opeid', openid) |
}) |
||||||
qrLogin({ |
.then(() => { |
||||||
code:this.scene, |
uni.exitMiniProgram({ |
||||||
openid:getAccessToken() |
success: res => { |
||||||
}) |
console.log(res) |
||||||
} |
} |
||||||
}, |
}) |
||||||
|
}) |
||||||
onLoad(query) { |
} else { |
||||||
// scene 需要使用 decodeURIComponent 才能获取到生成二维码时传入的 scene |
this.loading = true |
||||||
this.scene = decodeURIComponent(query.scene) |
qrLogin({ |
||||||
|
code: this.scene, |
||||||
} |
openid: getAccessToken() |
||||||
|
}).then(res => { |
||||||
} |
this.loading = false |
||||||
|
this.isLogin = true |
||||||
|
uni.exitMiniProgram() |
||||||
|
}) |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
onLoad(query) { |
||||||
|
// scene 需要使用 decodeURIComponent 才能获取到生成二维码时传入的 scene |
||||||
|
this.scene = decodeURIComponent(query.scene) |
||||||
|
} |
||||||
|
} |
||||||
</script> |
</script> |
||||||
|
|
||||||
<style lang="scss"></style> |
<style lang="scss" scoped> |
||||||
|
.waiting { |
||||||
|
height: 100vh; |
||||||
|
display: flex; |
||||||
|
flex-flow: column nowrap; |
||||||
|
justify-content: center; |
||||||
|
align-items: center; |
||||||
|
background: #17c653; |
||||||
|
gap: 40px; |
||||||
|
.login { |
||||||
|
display: flex; |
||||||
|
padding: var(--Number-12px, 12px) var(--Number-40px, 40px); |
||||||
|
justify-content: center; |
||||||
|
align-items: center; |
||||||
|
border-radius: var(--Number-120px, 120px); |
||||||
|
background: var(--LightMode-Light-Light, #fff); |
||||||
|
box-shadow: 0px 3px 4px 0px rgba(0, 0, 0, 0.03); |
||||||
|
color: var(--LightMode-Success-Success, #17c653); |
||||||
|
font-family: 'PingFang SC'; |
||||||
|
font-size: 16px; |
||||||
|
font-style: normal; |
||||||
|
font-weight: 500; |
||||||
|
line-height: normal; |
||||||
|
} |
||||||
|
.title { |
||||||
|
font-family: 'PingFang SC'; |
||||||
|
font-size: 16px; |
||||||
|
font-style: normal; |
||||||
|
font-weight: 500; |
||||||
|
line-height: normal; |
||||||
|
} |
||||||
|
} |
||||||
|
</style> |
||||||
|
@ -0,0 +1,464 @@ |
|||||||
|
<template> |
||||||
|
<view class="view-container"> |
||||||
|
<view class="box"> |
||||||
|
<view class="header"> |
||||||
|
<view class="wd-font-800">执法签到</view> |
||||||
|
<view class="refresh" @tap="refresh"> |
||||||
|
<image |
||||||
|
src="/static/images/icon/refresh.png" |
||||||
|
mode="aspectFit" |
||||||
|
style="width: 16px; height: 16px" |
||||||
|
></image> |
||||||
|
刷新 |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
<view class="row codeview"> |
||||||
|
<image :src="miniCode" mode="aspectFill" class="code"></image> |
||||||
|
<view class="info"> |
||||||
|
<view class=""> |
||||||
|
<view class="wd-font-800">执法协同人员请</view> |
||||||
|
<view class="wd-font-800">扫描二维码签到</view> |
||||||
|
<view class="wd-font-800 wd-mt-8" style="color: #f8285a"> |
||||||
|
(要求2人以上) |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
<view |
||||||
|
class="wd-font-800" |
||||||
|
style="color: #17c653; text-decoration: underline" |
||||||
|
@tap="showTip = true" |
||||||
|
> |
||||||
|
无法正常签到? |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
<view class="row" v-if="list.length == 0"> |
||||||
|
<view class="emty"> |
||||||
|
<image |
||||||
|
class="image" |
||||||
|
src="/static/images/emty.png" |
||||||
|
mode="aspectFill" |
||||||
|
></image> |
||||||
|
<text class="wd-text-14" style="color: #99a1b7"> |
||||||
|
暂无处理结果 |
||||||
|
</text> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
<view class="locate-record row" v-for="item in list" :key="item.id"> |
||||||
|
<view class="info"> |
||||||
|
<u-avatar |
||||||
|
:src="item.avtar" |
||||||
|
size="40px" |
||||||
|
shape="circle" |
||||||
|
></u-avatar> |
||||||
|
<view> |
||||||
|
<view style="margin-bottom: 4px"> |
||||||
|
<text style="font-weight: 800">{{ item.realName }}</text> |
||||||
|
<text style="font-size: 13px; color: #4b5675"> |
||||||
|
{{ item.deptName }} |
||||||
|
</text> |
||||||
|
</view> |
||||||
|
<view style="font-size: 13px; color: #4b5675"> |
||||||
|
{{ $util.formatDate(item.time, 'YYYY年M月D日 hh:mm') }} |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
<view class="wd-flex wd-flex-center" style="gap: 4px"> |
||||||
|
<u-icon |
||||||
|
name="checkmark-circle-fill" |
||||||
|
size="16" |
||||||
|
color="#17C653" |
||||||
|
></u-icon> |
||||||
|
<text class="wd-text-13">已签到</text> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
|
||||||
|
<cs-bottom-wrapper v-if="showBtn"> |
||||||
|
<view class="operation"> |
||||||
|
<button |
||||||
|
class="btn green" |
||||||
|
v-if="distance < radius" |
||||||
|
@tap="locate" |
||||||
|
:loading="loading" |
||||||
|
> |
||||||
|
确认签到 |
||||||
|
</button> |
||||||
|
<view class="btn grey" v-else>不在签到范围</view> |
||||||
|
</view> |
||||||
|
</cs-bottom-wrapper> |
||||||
|
|
||||||
|
<u-modal |
||||||
|
:show="showTip" |
||||||
|
width="295px" |
||||||
|
closeOnClickOverlay |
||||||
|
@close="showTip = false" |
||||||
|
> |
||||||
|
<view class="tip"> |
||||||
|
<view class="header"> |
||||||
|
<view>如无法签到 请确认以下</view> |
||||||
|
<view>功能是否正常启用?</view> |
||||||
|
</view> |
||||||
|
<view class="info"> |
||||||
|
<view class="msg"> |
||||||
|
<u-icon name="wifi" color="#17C653" size="20"></u-icon> |
||||||
|
开启手机设置GPS定位功能 |
||||||
|
</view> |
||||||
|
<view class="msg"> |
||||||
|
<u-icon name="wifi" color="#17C653" size="20"></u-icon> |
||||||
|
开启手机授权微信定位功能 |
||||||
|
</view> |
||||||
|
<view class="msg"> |
||||||
|
<u-icon name="wifi" color="#17C653" size="20"></u-icon> |
||||||
|
开启右上角小程序定位功能 |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
</view> |
||||||
|
<template #confirmButton> |
||||||
|
<view class="wd-flex wd-flex-center"> |
||||||
|
<view class="confirm-btn" @tap="showTip = false">确认</view> |
||||||
|
</view> |
||||||
|
</template> |
||||||
|
</u-modal> |
||||||
|
|
||||||
|
<van-action-sheet :show="showModel"> |
||||||
|
<view class="model-view"> |
||||||
|
<image |
||||||
|
class="image" |
||||||
|
src="/static/images/task/position.png" |
||||||
|
mode="aspectFill" |
||||||
|
></image> |
||||||
|
<view class="open-setting" @tap="openSetting()">开启定位</view> |
||||||
|
</view> |
||||||
|
</van-action-sheet> |
||||||
|
</view> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script> |
||||||
|
import TencentMap from '@/static/js/qqmap-wx-jssdk.min.js' |
||||||
|
import { getMiniCode } from '@/utils/getCode.js' |
||||||
|
import { InspectionsApi } from '@/api/inspections/index.js' |
||||||
|
import { getEnterPrise } from '@/api/enterprise/index.js' |
||||||
|
export default { |
||||||
|
data() { |
||||||
|
return { |
||||||
|
showModel: false, |
||||||
|
inspectionsId: '', |
||||||
|
miniCode: '', |
||||||
|
enterpriseGps: '', |
||||||
|
location: {}, |
||||||
|
distance: '', |
||||||
|
radius: 1000000, // 打卡范围 |
||||||
|
showTip: false, |
||||||
|
list: [], |
||||||
|
loading: false, |
||||||
|
share: { |
||||||
|
title: '', |
||||||
|
path: '', |
||||||
|
imageUrl: '' |
||||||
|
} |
||||||
|
} |
||||||
|
}, |
||||||
|
computed: { |
||||||
|
showBtn() { |
||||||
|
return ( |
||||||
|
this.list.findIndex(i => i.userId == this.$store.getters.userId) < |
||||||
|
-1 |
||||||
|
) |
||||||
|
} |
||||||
|
}, |
||||||
|
onLoad(res) { |
||||||
|
if (res.scene) { |
||||||
|
const data = decodeURIComponent(res.scene) |
||||||
|
const obj = {} |
||||||
|
data.split('&').forEach(i => { |
||||||
|
const arr = i.split('=') |
||||||
|
obj[arr[0]] = arr[1] |
||||||
|
}) |
||||||
|
this.inspectionsId = obj.inspectionsId |
||||||
|
this.enterpriseId = obj.enterpriseId |
||||||
|
} else { |
||||||
|
this.inspectionsId = res.inspectionsId |
||||||
|
this.enterpriseId = res.enterpriseId |
||||||
|
} |
||||||
|
this.share = { |
||||||
|
title: '', |
||||||
|
path: `/sub/task/locate?inspectionsId=${this.inspectionsId}&enterpriseId=${this.enterpriseId}`, |
||||||
|
imageUrl: require('@/static/images/locateImage.png') |
||||||
|
} |
||||||
|
this.init() |
||||||
|
}, |
||||||
|
onReady() { |
||||||
|
this.useAuth() |
||||||
|
}, |
||||||
|
onShareAppMessage() { |
||||||
|
return this.share |
||||||
|
}, |
||||||
|
onShareTimeline() { |
||||||
|
return this.share |
||||||
|
}, |
||||||
|
methods: { |
||||||
|
async init() { |
||||||
|
const miniCode = await getMiniCode({ |
||||||
|
scene: `inspectionsId=${this.inspectionsId}&enterpriseId=${this.enterpriseId}`, |
||||||
|
page: 'sub/task/locate', |
||||||
|
check_path: false, |
||||||
|
env_version: 'develop', |
||||||
|
is_hyaline: true |
||||||
|
}) |
||||||
|
const enterprise = await getEnterPrise(this.enterpriseId) |
||||||
|
this.enterprisesName = enterprise.data.enterprisesName |
||||||
|
this.enterpriseGps = enterprise.data.gpsLocation |
||||||
|
uni.setNavigationBarTitle({ |
||||||
|
title: this.enterprisesName |
||||||
|
}) |
||||||
|
this.share.title = `执法签到-${this.enterprisesName}` |
||||||
|
this.getLocateList() |
||||||
|
this.miniCode = miniCode |
||||||
|
}, |
||||||
|
async getLocateList() { |
||||||
|
const res = await InspectionsApi.getLocate(this.inspectionsId) |
||||||
|
//找到专管员签到状态 |
||||||
|
const isLead = res.data.findIndex(i => { |
||||||
|
i.userId == this.$store.getters.userId && i.isInspect |
||||||
|
}) |
||||||
|
console.log(isLead) |
||||||
|
this.list = res.data |
||||||
|
}, |
||||||
|
useAuth() { |
||||||
|
const that = this |
||||||
|
uni.getSetting({ |
||||||
|
success: res => { |
||||||
|
// 如果有授权直接获取位置,没有则拉起授权 |
||||||
|
res.authSetting['scope.userLocation'] |
||||||
|
? _getLocation() |
||||||
|
: _getAuth() |
||||||
|
} |
||||||
|
}) |
||||||
|
/** |
||||||
|
* 打开微信设置 |
||||||
|
*/ |
||||||
|
function _getAuth() { |
||||||
|
uni.authorize({ |
||||||
|
scope: 'scope.userLocation', |
||||||
|
success: res => { |
||||||
|
_getLocation() |
||||||
|
}, |
||||||
|
fail: () => { |
||||||
|
that.showModel = true |
||||||
|
} |
||||||
|
}) |
||||||
|
} |
||||||
|
function _getLocation() { |
||||||
|
uni.getLocation({ |
||||||
|
type: 'gcj02', |
||||||
|
success: res => { |
||||||
|
that.location = { |
||||||
|
latitude: res.latitude, |
||||||
|
longitude: res.longitude |
||||||
|
} |
||||||
|
|
||||||
|
that.getDistance() |
||||||
|
}, |
||||||
|
fail: err => { |
||||||
|
that.showTip = true |
||||||
|
uni.showToast({ |
||||||
|
icon: 'none', |
||||||
|
title: '获取定位失败' |
||||||
|
}) |
||||||
|
} |
||||||
|
}) |
||||||
|
} |
||||||
|
}, |
||||||
|
openSetting() { |
||||||
|
const that = this |
||||||
|
uni.openSetting({ |
||||||
|
success: res => { |
||||||
|
that.showModel = false |
||||||
|
that.useAuth() |
||||||
|
} |
||||||
|
}) |
||||||
|
}, |
||||||
|
getDistance() { |
||||||
|
const that = this |
||||||
|
const map = new TencentMap({ |
||||||
|
key: 'PQ5BZ-GZ5C7-RTMXB-HSAPB-3TOAV-5CBLZ' |
||||||
|
}) |
||||||
|
map.calculateDistance({ |
||||||
|
mode: 'straight', |
||||||
|
form: this.location, |
||||||
|
to: this.enterpriseGps, |
||||||
|
success: res => { |
||||||
|
that.distance = res.result.elements[0].distance |
||||||
|
} |
||||||
|
}) |
||||||
|
}, |
||||||
|
refresh() { |
||||||
|
this.getDistance() |
||||||
|
this.getLocateList() |
||||||
|
}, |
||||||
|
async locate() { |
||||||
|
this.loading = true |
||||||
|
const res = await InspectionsApi.locate({ |
||||||
|
inspectionsId: this.inspectionsId |
||||||
|
}) |
||||||
|
this.loading = false |
||||||
|
uni.showToast({ |
||||||
|
icon: 'none', |
||||||
|
title: res.data |
||||||
|
}) |
||||||
|
this.refresh() |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
</script> |
||||||
|
|
||||||
|
<style lang="scss" scoped> |
||||||
|
.view-container { |
||||||
|
height: 100vh; |
||||||
|
padding: 12px; |
||||||
|
|
||||||
|
.box { |
||||||
|
background-color: #fff; |
||||||
|
border-radius: $cs-border-radius; |
||||||
|
padding: 16px; |
||||||
|
display: flex; |
||||||
|
flex-flow: column nowrap; |
||||||
|
gap: 12px; |
||||||
|
} |
||||||
|
.header { |
||||||
|
display: flex; |
||||||
|
align-items: center; |
||||||
|
justify-content: space-between; |
||||||
|
.refresh { |
||||||
|
display: flex; |
||||||
|
align-items: center; |
||||||
|
gap: 4px; |
||||||
|
color: $cs-color-main; |
||||||
|
font-weight: bold; |
||||||
|
} |
||||||
|
} |
||||||
|
.row { |
||||||
|
border-radius: var(--Number-8px, 8px); |
||||||
|
border: 1px solid var(--LightMode-Grey-Grey-100, #f9f9f9); |
||||||
|
background: var(--LightMode-Light-Light, #fff); |
||||||
|
padding: 16px; |
||||||
|
} |
||||||
|
.codeview { |
||||||
|
display: flex; |
||||||
|
justify-content: space-between; |
||||||
|
.code { |
||||||
|
width: 320rpx; |
||||||
|
height: 320rpx; |
||||||
|
} |
||||||
|
.info { |
||||||
|
display: flex; |
||||||
|
flex-direction: column; |
||||||
|
justify-content: space-between; |
||||||
|
gap: 80rpx; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
.locate-record { |
||||||
|
display: flex; |
||||||
|
justify-content: space-between; |
||||||
|
.info { |
||||||
|
display: flex; |
||||||
|
justify-content: space-between; |
||||||
|
align-items: center; |
||||||
|
gap: 12px; |
||||||
|
} |
||||||
|
} |
||||||
|
.emty { |
||||||
|
display: flex; |
||||||
|
flex-direction: column; |
||||||
|
align-items: center; |
||||||
|
gap: 12px; |
||||||
|
padding: 24px 12px; |
||||||
|
border-radius: 8px; |
||||||
|
.image { |
||||||
|
width: 64px; |
||||||
|
height: 64px; |
||||||
|
} |
||||||
|
} |
||||||
|
.operation { |
||||||
|
padding: 12px; |
||||||
|
display: flex; |
||||||
|
align-items: center; |
||||||
|
justify-content: center; |
||||||
|
gap: 12px; |
||||||
|
.btn { |
||||||
|
flex: 1; |
||||||
|
border-radius: 8px; |
||||||
|
display: flex; |
||||||
|
padding: 12px 0; |
||||||
|
align-items: center; |
||||||
|
justify-content: center; |
||||||
|
} |
||||||
|
.green { |
||||||
|
background-color: $cs-color-main; |
||||||
|
color: #fff; |
||||||
|
} |
||||||
|
.grey { |
||||||
|
background: #f1f1f4; |
||||||
|
color: #99a1b7; |
||||||
|
} |
||||||
|
} |
||||||
|
.model-view { |
||||||
|
height: 700rpx; |
||||||
|
display: flex; |
||||||
|
flex-direction: column; |
||||||
|
align-items: center; |
||||||
|
gap: 24px; |
||||||
|
.image { |
||||||
|
width: 470rpx; |
||||||
|
height: 420rpx; |
||||||
|
} |
||||||
|
.open-setting { |
||||||
|
padding: var(--Number-12px, 12px) var(--Number-48px, 48px); |
||||||
|
gap: 10px; |
||||||
|
border-radius: var(--Number-120px, 120px); |
||||||
|
background: var(--LightMode-Success-Success, #17c653); |
||||||
|
color: #fff; |
||||||
|
font-size: 16px; |
||||||
|
font-weight: 500; |
||||||
|
/* Widget Shadow */ |
||||||
|
box-shadow: 0px 3px 4px 0px rgba(0, 0, 0, 0.03); |
||||||
|
} |
||||||
|
} |
||||||
|
.confirm-btn { |
||||||
|
background-color: $cs-color-main; |
||||||
|
padding: 12px 40px; |
||||||
|
color: #fff; |
||||||
|
font-size: 16px; |
||||||
|
font-weight: 600; |
||||||
|
border-radius: 120px; |
||||||
|
} |
||||||
|
.tip { |
||||||
|
display: flex; |
||||||
|
flex-flow: column nowrap; |
||||||
|
gap: 24px; |
||||||
|
.header { |
||||||
|
display: flex; |
||||||
|
flex-flow: column nowrap; |
||||||
|
justify-content: center; |
||||||
|
align-items: center; |
||||||
|
color: #17c653; |
||||||
|
font-style: italic; |
||||||
|
font-weight: bold; |
||||||
|
} |
||||||
|
.info { |
||||||
|
display: flex; |
||||||
|
flex-flow: column nowrap; |
||||||
|
justify-content: center; |
||||||
|
align-items: center; |
||||||
|
color: #071437; |
||||||
|
gap: 16px; |
||||||
|
.msg { |
||||||
|
display: flex; |
||||||
|
justify-content: center; |
||||||
|
align-items: center; |
||||||
|
gap: 4px; |
||||||
|
} |
||||||
|
} |
||||||
|
} |
||||||
|
</style> |
@ -0,0 +1,44 @@ |
|||||||
|
let AccessToken |
||||||
|
|
||||||
|
function getAccessToken() { |
||||||
|
return new Promise((resolve, reject) => { |
||||||
|
uni.request({ |
||||||
|
url: 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=wx6d80755768234f3b&secret=c8180f2ab1b8454d403c7aa336782e21', |
||||||
|
method: "GET", |
||||||
|
success(res) { |
||||||
|
resolve(res.data.access_token) |
||||||
|
}, |
||||||
|
fail(err) { |
||||||
|
console.error(err) |
||||||
|
resolve(false) |
||||||
|
} |
||||||
|
}) |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
function getCode(data, token) { |
||||||
|
return new Promise((resolve) => { |
||||||
|
uni.request({ |
||||||
|
url: `https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=${token}`, |
||||||
|
method: "POST", |
||||||
|
responseType: "arraybuffer", |
||||||
|
data: JSON.stringify(data), |
||||||
|
success(res) { |
||||||
|
resolve(res) |
||||||
|
}, |
||||||
|
fail(err) { |
||||||
|
console.error(err) |
||||||
|
resolve(false) |
||||||
|
} |
||||||
|
}) |
||||||
|
}) |
||||||
|
} |
||||||
|
|
||||||
|
export async function getMiniCode(data) { |
||||||
|
const token = await getAccessToken() |
||||||
|
const code = await getCode(data, token) |
||||||
|
const arrayBuffer = new Uint8Array(code.data) |
||||||
|
const base64 = wx.arrayBufferToBase64(arrayBuffer) |
||||||
|
return `data:image/jpeg;base64,${base64}` |
||||||
|
} |
Loading…
Reference in new issue