maxkb/ui/src/views/chat/user-login/scanCompinents/larkQrCode.vue

67 lines
1.9 KiB
Vue

<template>
<div class="flex-center mb-16">
<img src="@/assets/logo/logo_lark.svg " alt="" width="24px" class="mr-4"/>
<h2>{{ $t('views.system.authentication.scanTheQRCode.larkQrCode') }}</h2>
</div>
<div id="lark-qr" class="lark-qrName"></div>
</template>
<script lang="ts" setup>
import {useScriptTag} from '@vueuse/core'
import {onMounted} from 'vue'
import {useRoute} from "vue-router";
const route = useRoute()
const {
params: {accessToken},
} = route as any
const {load} = useScriptTag(
'https://lf-package-cn.feishucdn.com/obj/feishu-static/lark/passport/qrcode/LarkSSOSDKWebQRCode-1.0.3.js'
)
const props = defineProps<{
config: {
app_secret: string
app_key: string
}
}>()
const initActive = async () => {
const scriptLoaded = await load(true)
if (!scriptLoaded) {
console.error('飞书二维码 SDK 加载失败')
return
}
const data = {
agentId: props.config.app_key,
appSecret: props.config.app_secret
}
const redirectUrl = encodeURIComponent(`${window.location.origin}/chat/api/auth/lark?accessToken=${accessToken}`)
//const redirectUrl = encodeURIComponent(`http://127.0.0.1:8080/chat/api/auth/lark?accessToken=${accessToken}`)
const url = `https://passport.feishu.cn/suite/passport/oauth/authorize?client_id=${data.agentId}&redirect_uri=${redirectUrl}&response_type=code&state=fit2cloud-lark-qr`
const QRLoginObj = window.QRLogin({
id: 'lark-qr',
goto: url,
width: '266',
height: '266',
style: 'width:280px;height:280px;border:1px solid #e8e8e8;margin:0 auto;border-radius:8px;'
})
window.addEventListener('message', async (event: any) => {
if (QRLoginObj.matchOrigin(event.origin) && QRLoginObj.matchData(event.data)) {
const loginTmpCode = event.data.tmp_code
window.location.replace(`${url}&tmp_code=${loginTmpCode}`)
}
})
}
onMounted(() => {
initActive()
})
</script>
<style scoped lang="scss"></style>