Pre Merge pull request !154 from binny1024/dev-express-callphone
commit
899857f51a
|
@ -0,0 +1,81 @@
|
||||||
|
<template>
|
||||||
|
<view class="content-container">
|
||||||
|
<span v-for="(part, index) in formattedContent" :key="index"
|
||||||
|
@click="handleClick(part)"
|
||||||
|
:class="{'highlight-number': part.isNumber, 'phone-number': part.isPhone}">
|
||||||
|
{{ part.text }}
|
||||||
|
</span>
|
||||||
|
</view>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
export default {
|
||||||
|
name: 'HighlightNumber',
|
||||||
|
props: {
|
||||||
|
content: {
|
||||||
|
type: String,
|
||||||
|
required: true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
computed: {
|
||||||
|
formattedContent() {
|
||||||
|
const phoneRegex = /(1[3-9]\d{9})/g;
|
||||||
|
const numberRegex = /(\d+)/g;
|
||||||
|
let text = this.content;
|
||||||
|
let result = [];
|
||||||
|
let match;
|
||||||
|
|
||||||
|
// Step 1: 提取手机号
|
||||||
|
while ((match = phoneRegex.exec(text)) !== null) {
|
||||||
|
if (match.index > 0) {
|
||||||
|
const before = text.slice(0, match.index);
|
||||||
|
result.push(...this.splitAndPush(before, false, false));
|
||||||
|
}
|
||||||
|
result.push({ text: match[0], isNumber: true, isPhone: true });
|
||||||
|
text = text.slice(match.index + match[0].length);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Step 2: 提取普通数字
|
||||||
|
while ((match = numberRegex.exec(text)) !== null) {
|
||||||
|
if (match.index > 0) {
|
||||||
|
const before = text.slice(0, match.index);
|
||||||
|
result.push(...this.splitAndPush(before, false, false));
|
||||||
|
}
|
||||||
|
result.push({ text: match[0], isNumber: true });
|
||||||
|
text = text.slice(match.index + match[0].length);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Step 3: 添加剩余文本
|
||||||
|
if (text.length > 0) {
|
||||||
|
result.push(...this.splitAndPush(text, false, false));
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
splitAndPush(str, isNumber = false, isPhone = false) {
|
||||||
|
return str.split('').map(char => ({ text: char, isNumber, isPhone }));
|
||||||
|
},
|
||||||
|
handleClick(part) {
|
||||||
|
if (part.isPhone) {
|
||||||
|
this.$emit('phone-click', { phoneNumber: part.text });
|
||||||
|
} else if (part.isNumber) {
|
||||||
|
this.$emit('number-click', { number: part.text });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.highlight-number {
|
||||||
|
color: #ff5722;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
.phone-number {
|
||||||
|
color: #007AFF;
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -38,7 +38,11 @@
|
||||||
<!-- <view class="log-msg-title ss-m-b-20">-->
|
<!-- <view class="log-msg-title ss-m-b-20">-->
|
||||||
<!-- {{ item.status_text }}-->
|
<!-- {{ item.status_text }}-->
|
||||||
<!-- </view>-->
|
<!-- </view>-->
|
||||||
<view class="log-msg-desc ss-m-b-16">{{ item.content }}</view>
|
<!-- <view class="log-msg-desc ss-m-b-16">{{ item.content }}</view>-->
|
||||||
|
<view class="log-msg-desc ss-m-b-16">
|
||||||
|
<highlight-number :content="item.content" @phone-click="handlePhoneClick" />
|
||||||
|
<!-- <rich-text :nodes="item.content"></rich-text>-->
|
||||||
|
</view>
|
||||||
<view class="log-msg-date ss-m-b-40">
|
<view class="log-msg-date ss-m-b-40">
|
||||||
{{ sheep.$helper.timeFormat(item.time, 'yyyy-mm-dd hh:MM:ss') }}
|
{{ sheep.$helper.timeFormat(item.time, 'yyyy-mm-dd hh:MM:ss') }}
|
||||||
</view>
|
</view>
|
||||||
|
@ -54,6 +58,7 @@
|
||||||
import { onLoad } from '@dcloudio/uni-app';
|
import { onLoad } from '@dcloudio/uni-app';
|
||||||
import { computed, reactive } from 'vue';
|
import { computed, reactive } from 'vue';
|
||||||
import OrderApi from '@/sheep/api/trade/order';
|
import OrderApi from '@/sheep/api/trade/order';
|
||||||
|
import HighlightNumber from '@/pages/components/HighlightNumberText.vue';
|
||||||
|
|
||||||
const state = reactive({
|
const state = reactive({
|
||||||
info: [],
|
info: [],
|
||||||
|
@ -74,7 +79,7 @@
|
||||||
|
|
||||||
async function getExpressDetail(id) {
|
async function getExpressDetail(id) {
|
||||||
const { data } = await OrderApi.getOrderExpressTrackList(id);
|
const { data } = await OrderApi.getOrderExpressTrackList(id);
|
||||||
state.tracks = data.reverse();
|
state.tracks = data;
|
||||||
}
|
}
|
||||||
|
|
||||||
async function getOrderDetail(id) {
|
async function getOrderDetail(id) {
|
||||||
|
@ -86,53 +91,117 @@
|
||||||
getExpressDetail(options.id);
|
getExpressDetail(options.id);
|
||||||
getOrderDetail(options.id);
|
getOrderDetail(options.id);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
function handlePhoneClick(data) {
|
||||||
|
handleClick(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
function handleClick(data) {
|
||||||
|
const phoneNumber = data.phoneNumber;
|
||||||
|
|
||||||
|
if (!phoneNumber) return;
|
||||||
|
|
||||||
|
// 获取当前平台
|
||||||
|
const platform = uni.getSystemInfoSync().platform.toLowerCase();
|
||||||
|
|
||||||
|
if (platform === 'devtools') {
|
||||||
|
uni.showToast({ title: '真机才可拨打电话', icon: 'none' });
|
||||||
|
handleCopy(phoneNumber);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (platform === 'wechat') {
|
||||||
|
uni.showToast({ title: '请手动拨打', icon: 'none' });
|
||||||
|
handleCopy(phoneNumber);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
uni.makePhoneCall({
|
||||||
|
phoneNumber: phoneNumber,
|
||||||
|
success: () => {
|
||||||
|
console.log('拨打电话成功');
|
||||||
|
},
|
||||||
|
fail: (err) => {
|
||||||
|
console.error('拨打电话失败', err);
|
||||||
|
uni.showToast({ title: '拨号失败,请手动拨打', icon: 'none' });
|
||||||
|
handleCopy(phoneNumber);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
function handleCopy(text) {
|
||||||
|
uni.setClipboardData({
|
||||||
|
data: text,
|
||||||
|
success: () => {
|
||||||
|
uni.showToast({ title: '已复制到剪贴板', icon: 'success' });
|
||||||
|
},
|
||||||
|
fail: () => {
|
||||||
|
uni.showToast({ title: '复制失败', icon: 'none' });
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
|
.highlight {
|
||||||
|
color: red; /* 高亮颜色 */
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
.swiper-box {
|
.swiper-box {
|
||||||
width: 200rpx;
|
width: 200rpx;
|
||||||
height: 200rpx;
|
height: 200rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.log-card {
|
.log-card {
|
||||||
border-top: 2rpx solid rgba(#dfdfdf, 0.5);
|
border-top: 2rpx solid rgba(#dfdfdf, 0.5);
|
||||||
padding: 20rpx;
|
padding: 20rpx;
|
||||||
background: #fff;
|
background: #fff;
|
||||||
margin-bottom: 20rpx;
|
margin-bottom: 20rpx;
|
||||||
|
|
||||||
.log-card-img {
|
.log-card-img {
|
||||||
width: 200rpx;
|
width: 200rpx;
|
||||||
height: 200rpx;
|
height: 200rpx;
|
||||||
margin-right: 20rpx;
|
margin-right: 20rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.log-card-msg {
|
.log-card-msg {
|
||||||
font-size: 28rpx;
|
font-size: 28rpx;
|
||||||
font-weight: 500;
|
font-weight: 500;
|
||||||
width: 490rpx;
|
width: 490rpx;
|
||||||
color: #333333;
|
color: #333333;
|
||||||
|
|
||||||
.warning-color {
|
.warning-color {
|
||||||
color: #999;
|
color: #999;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.log-content {
|
.log-content {
|
||||||
padding: 34rpx 20rpx 0rpx 20rpx;
|
padding: 34rpx 20rpx 0rpx 20rpx;
|
||||||
background: #fff;
|
background: #fff;
|
||||||
|
|
||||||
.log-content-box {
|
.log-content-box {
|
||||||
align-items: stretch;
|
align-items: stretch;
|
||||||
}
|
}
|
||||||
|
|
||||||
.log-icon {
|
.log-icon {
|
||||||
height: inherit;
|
height: inherit;
|
||||||
|
|
||||||
.cicon-title {
|
.cicon-title {
|
||||||
color: #ccc;
|
color: #ccc;
|
||||||
font-size: 40rpx;
|
font-size: 40rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.activity-color {
|
.activity-color {
|
||||||
color: #f0c785;
|
color: #f0c785;
|
||||||
font-size: 40rpx;
|
font-size: 40rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.info-color {
|
.info-color {
|
||||||
color: #ccc;
|
color: #ccc;
|
||||||
font-size: 40rpx;
|
font-size: 40rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.line {
|
.line {
|
||||||
width: 1px;
|
width: 1px;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
|
@ -146,16 +215,18 @@
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
color: #333333;
|
color: #333333;
|
||||||
}
|
}
|
||||||
|
|
||||||
.log-msg-desc {
|
.log-msg-desc {
|
||||||
font-size: 24rpx;
|
font-size: 24rpx;
|
||||||
font-weight: 400;
|
font-weight: 400;
|
||||||
color: #333333;
|
color: #333333;
|
||||||
line-height: 36rpx;
|
line-height: 36rpx;
|
||||||
}
|
}
|
||||||
|
|
||||||
.log-msg-date {
|
.log-msg-date {
|
||||||
font-size: 24rpx;
|
font-size: 24rpx;
|
||||||
font-weight: 500;
|
font-weight: 500;
|
||||||
color: #999999;
|
color: #000000;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue