- 在用户注册时支持从邀请参数中获取推荐人ID并绑定 - 修改管理员面板UI,添加统一扫码功能入口- 更新用户管理相关API地址,统一使用SERVER_API_URL - 调整优惠券卡片样式,移除小程序不支持的CSS属性 - 添加聊天会话和消息管理相关API模块 - 新增分销商银行卡管理API接口 - 修改系统用户模型,增加推荐人ID字段 - 更新广告位查询接口,支持根据code获取广告位 - 调整邀请绑定接口参数,将refereeId改为dealerId - 修改环境配置中的应用名称为"时里院子市集" - 移除分享到朋友圈的相关代码 - 添加管理员面板组件,提供统一扫码等管理功能 -修复用户管理API请求参数传递问题 - 添加聊天消息和会话管理的完整CRUD接口 - 更新系统用户相关接口URL,确保正确调用后端服务 - 添加分销商银行卡管理的完整API接口实现 - 修改邀请绑定接口,使用dealerId替代refereeId参数 - 修复扫码登录相关API的URL拼接问题 - 添加二维码内容解析功能,支持多种格式的token提取 - 更新用户信息模型,增加推荐人ID字段 -优化管理员面板样式和交互逻辑- 调整优惠券组件样式,兼容小程序环境限制- 修复用户管理模块的API调用问题 - 添加聊天相关数据模型和接口定义 - 更新环境配置中的应用名称 -修复邀请绑定相关的参数传递问题- 添加扫码登录状态枚举和相关数据结构定义- 优化管理员功能面板的UI展示和交互体验- 修复系统用户管理接口的请求参数问题 - 添加分销商银行卡管理相关接口实现- 调整聊天消息和会话管理接口的数据结构定义 -修复用户管理模块中的API调用路径问题 - 添加扫码登录相关工具函数,如设备信息获取等 - 更新邀请绑定接口的数据模型定义 -优化管理员面板组件的样式和功能实现 -修复系统用户管理接口中的参数传递问题 - 添加聊天相关模块的完整API接口实现 - 调整分销商银行卡管理模块的数据结构定义- 修复扫码登录相关接口的URL拼接问题- 更新用户管理模块中的API调用方式 - 添加聊天消息批量发送等相关接口实现- 修复邀请绑定接口中的参数名称问题- 优化管理员面板组件的功能和交互逻辑 - 调整系统用户管理接口的请求参数传递方式 - 添加分销商银行卡管理模块的完整接口实现 -修复聊天相关接口中的数据结构问题 - 更新扫码登录相关接口的数据模型定义 - 优化管理员功能面板的展示效果和用户体验
122 lines
3.6 KiB
TypeScript
122 lines
3.6 KiB
TypeScript
import {useEffect, useState} from 'react'
|
||
import {View, Text, Image} from '@tarojs/components'
|
||
import {Tabs} from '@nutui/nutui-react-taro'
|
||
import Taro from '@tarojs/taro'
|
||
import './index.scss'
|
||
import {listCmsWebsiteField} from "@/api/cms/cmsWebsiteField";
|
||
import {CmsWebsiteField} from "@/api/cms/cmsWebsiteField/model";
|
||
|
||
const WechatService = () => {
|
||
const [activeTab, setActiveTab] = useState('0')
|
||
const [codes, setCodes] = useState<CmsWebsiteField[]>([])
|
||
|
||
// 长按保存二维码到相册
|
||
const saveQRCodeToAlbum = (imageUrl: string) => {
|
||
// 首先下载图片到本地
|
||
Taro.downloadFile({
|
||
url: imageUrl,
|
||
success: (res) => {
|
||
if (res.statusCode === 200) {
|
||
// 保存图片到相册
|
||
Taro.saveImageToPhotosAlbum({
|
||
filePath: res.tempFilePath,
|
||
success: () => {
|
||
Taro.showToast({
|
||
title: '保存成功',
|
||
icon: 'success',
|
||
duration: 2000
|
||
})
|
||
},
|
||
fail: (error) => {
|
||
console.error('保存失败:', error)
|
||
if (error.errMsg.includes('auth deny')) {
|
||
Taro.showModal({
|
||
title: '提示',
|
||
content: '需要您授权保存图片到相册',
|
||
showCancel: true,
|
||
cancelText: '取消',
|
||
confirmText: '去设置',
|
||
success: (modalRes) => {
|
||
if (modalRes.confirm) {
|
||
Taro.openSetting()
|
||
}
|
||
}
|
||
})
|
||
} else {
|
||
Taro.showToast({
|
||
title: '保存失败',
|
||
icon: 'error',
|
||
duration: 2000
|
||
})
|
||
}
|
||
}
|
||
})
|
||
} else {
|
||
Taro.showToast({
|
||
title: '图片下载失败',
|
||
icon: 'error',
|
||
duration: 2000
|
||
})
|
||
}
|
||
},
|
||
fail: () => {
|
||
Taro.showToast({
|
||
title: '图片下载失败',
|
||
icon: 'error',
|
||
duration: 2000
|
||
})
|
||
}
|
||
})
|
||
}
|
||
|
||
const renderQRCode = (data: typeof codes[0]) => (
|
||
<View className="qr-container">
|
||
<View className="qr-content">
|
||
<View className="qr-code-wrapper">
|
||
<Image
|
||
src={`${data.value}`}
|
||
className="qr-code-image"
|
||
mode="aspectFit"
|
||
onLongPress={() => saveQRCodeToAlbum(`${data.value}`)}
|
||
/>
|
||
{data.style && <Text className="wechat-id">联系电话:{data.style}</Text>}
|
||
</View>
|
||
|
||
<View className="qr-tips">
|
||
<Text className="tip-title">使用说明:</Text>
|
||
<Text className="tip-item">1. 长按二维码保存到相册</Text>
|
||
<Text className="tip-item">2. 打开微信扫一扫</Text>
|
||
<Text className="tip-item">3. 选择相册中的二维码图片</Text>
|
||
<Text className="tip-item">4. 添加好友并发送验证消息</Text>
|
||
</View>
|
||
</View>
|
||
</View>
|
||
)
|
||
|
||
useEffect(() => {
|
||
listCmsWebsiteField({name: 'kefu'}).then(data => {
|
||
if (data) {
|
||
setCodes(data)
|
||
}
|
||
})
|
||
}, []);
|
||
|
||
return (
|
||
<View className="wechat-service-page">
|
||
<Tabs
|
||
value={activeTab}
|
||
onChange={(value) => setActiveTab(`${value}`)}
|
||
className="service-tabs"
|
||
>
|
||
{codes.map((item) => (
|
||
<Tabs.TabPane key={item.id} title={item.comments} value={item.id}>
|
||
{renderQRCode(item)}
|
||
</Tabs.TabPane>
|
||
))}
|
||
</Tabs>
|
||
</View>
|
||
)
|
||
}
|
||
|
||
export default WechatService
|