Files
yudao-ui-admin-vben/apps/web-ele/src/views/mp/components/wx-location/wx-location.vue
2025-11-25 14:42:56 +08:00

74 lines
1.9 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<!--
微信消息 - 定位TODO @Dhb52 目前未启用@dylan看看目前是不是没用起来哈
-->
<script lang="ts" setup>
import type { WxLocationProps } from './types';
import { computed, onMounted, ref } from 'vue';
import { IconifyIcon } from '@vben/icons';
import { ElCol, ElLink, ElMessage, ElRow } from 'element-plus';
import { getTradeConfig } from '#/api/mall/trade/config';
defineOptions({ name: 'Location' });
const props = defineProps<WxLocationProps>();
const fetchedQqMapKey = ref('');
const resolvedQqMapKey = computed(
() => props.qqMapKey || fetchedQqMapKey.value || '',
);
const mapUrl = computed(() => {
return `https://map.qq.com/?type=marker&isopeninfowin=1&markertype=1&pointx=${props.locationY}&pointy=${props.locationX}&name=${props.label}&ref=yudao`;
});
const mapImageUrl = computed(() => {
return `https://apis.map.qq.com/ws/staticmap/v2/?zoom=10&markers=color:blue|label:A|${props.locationX},${props.locationY}&key=${resolvedQqMapKey.value}&size=250*180`;
});
async function fetchQqMapKey() {
try {
const data = await getTradeConfig();
fetchedQqMapKey.value = data.tencentLbsKey ?? '';
if (!fetchedQqMapKey.value) {
ElMessage.warning('请先配置腾讯位置服务密钥');
}
} catch {
ElMessage.error('获取腾讯位置服务密钥失败');
}
}
onMounted(async () => {
if (!props.qqMapKey) {
await fetchQqMapKey();
}
});
defineExpose({
locationX: props.locationX,
locationY: props.locationY,
label: props.label,
qqMapKey: resolvedQqMapKey,
});
</script>
<template>
<!-- 微信消息 - 定位 -->
<div>
<ElLink type="primary" target="_blank" :href="mapUrl">
<ElCol>
<ElRow>
<img :src="mapImageUrl" alt="地图位置" />
</ElRow>
<ElRow>
<IconifyIcon icon="lucide:map-pin" />
{{ label }}
</ElRow>
</ElCol>
</ElLink>
</div>
</template>