Files
pgserver3.0/pgapp/pages/inquiry/detail.vue
annnj-company 130c1026c4 first commit
2026-04-17 18:29:53 +08:00

432 lines
14 KiB
Vue

<template>
<view class="inquiry-container">
<!---->
<view >
<uni-section title="银行信息" type="line">
<uni-card>
<view class="uni-flex uni-row" style="-webkit-justify-content: space-between;justify-content: space-between;">
<view style="width: 150rpx;">询价状态:</view>
<view class="btnInquiry" style="-webkit-flex: 1;flex: 1;" >{{inquiry.status_str}}</view>
</view>
<view class="uni-flex uni-row" style="-webkit-justify-content: space-between;justify-content: space-between;">
<view style="width: 150rpx;"> :</view>
<view style="-webkit-flex: 1;flex: 1;">{{inquiry.order_no}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">银行名称:</view>
<view style="-webkit-flex: 1;flex: 1;">{{inquiry.bank_name}}-{{inquiry.bank_branch_name}}-{{inquiry.bank_sub_name}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">询价时间:</view>
<view style="-webkit-flex: 1;flex: 1;">{{inquiry.create_time}}</view>
</view>
<view v-if="inquiry!=null&&inquiry.status!=1" class="uni-flex uni-row">
<view style="width: 150rpx;">回价时间:</view>
<view style="-webkit-flex: 1;flex: 1;">{{inquiry.response_time}}</view>
</view>
<view v-if="inquiry!=null&&inquiry.status!=1" class="uni-flex uni-row">
<view style="width: 150rpx;">回价员:</view>
<view style="-webkit-flex: 1;flex: 1;">{{inquiry.response_username}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">客户经理:</view>
<view style="-webkit-flex: 1;flex: 1;">{{inquiry.bank_customer_mgr_name}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">评估目的:</view>
<view style="-webkit-flex: 1;flex: 1;">{{inquiry.eva_purpose}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">物业数量:</view>
<view style="-webkit-flex: 1;flex: 1;">{{getEstateCount()}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">回价附件:</view>
<view style="-webkit-flex: 1;flex: 1;">
<view v-for="(file, index) in inquiry.return_price_attachments_list" :key="index">
<view class="uni-flex uni-row">
<view style="width: 250rpx;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;">{{file.name}}</view>
</view>
</view>
</view>
<view style="" v-if="inquiry.return_price_attachments_list.length>0">
<uni-button type="primary" plain size="mini" @click="previewFile(inquiry.return_price_attachments_list)">预览</uni-button>
</view>
</view>
</uni-card>
</uni-section>
<uni-section title="物业信息" type="line" style="position: relative;">
<uni-button type="primary" size="mini" style="position: absolute; right: 20px; top: 10px;" @click='showAllDetailsDialog'>
复制
</uni-button>
<view v-for='(item, index) in inquiry.inquiry_details' :key='index'>
<view class="detail">
<uni-card>
<view class="uni-flex uni-row" style="justify-content: flex-end;">
<view style="width: 440rpx;"></view>
</view>
<view :ref="`copyContainerRef${index}`">
<view class="uni-flex uni-row">
<view style="width: 150rpx;">物业名称{{index+1}}:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.property_full_name}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">面积():</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.size}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">所在地区:</view>
<view style="-webkit-flex: 1;flex: 1;">{{inquiry.city}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">房屋用途:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.usage}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">银行:</view>
<view style="-webkit-flex: 1;flex: 1;">{{inquiry.bank_name +"-"+ inquiry.bank_branch_name + inquiry.bank_sub_name}}</view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">评估目的:</view>
<view style="-webkit-flex: 1;flex: 1;">{{inquiry.eva_purpose}}</view>
</view>
<view v-if="item.eva_unit_price!=0" class="uni-flex uni-row">
<view style="width: 150rpx;">评估单价:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.eva_unit_price}} /</view>
</view>
<view v-if="item.eva_total_value!=0" class="uni-flex uni-row">
<view style="width: 150rpx;">评估总值:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.eva_total_value}} </view>
</view>
<view v-if="item.eva_net_value!=0" class="uni-flex uni-row">
<view style="width: 150rpx;">评估净值 1:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.eva_net_value}} </view>
</view>
<view v-if="item.eva_net_value2!=0" class="uni-flex uni-row">
<view style="width: 150rpx;">评估净值 2:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.eva_net_value2}} </view>
</view>
<view v-if="item.total_taxes1!=0&&item.total_taxes1!=null" class="uni-flex uni-row">
<view style="width: 150rpx;">税费 1:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.total_taxes1}} </view>
</view>
<view v-if="item.total_taxes2!=0&&item.total_taxes2" class="uni-flex uni-row">
<view style="width: 150rpx;">税费 2:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.total_taxes2}} </view>
</view>
<view class="uni-flex uni-row">
<view style="width: 150rpx;">产证附件:</view>
<view style="-webkit-flex: 1;flex: 1;">
<view v-for="(file, index) in item.attachments_list" :key="index">
<view class="uni-flex uni-row">
<view style="width: 250rpx;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;">{{file.name}}</view>
</view>
</view>
</view>
<view style="" v-if="item.attachments_list.length>0">
<uni-button type="primary" plain size="mini" @click="previewFile(item.attachments_list)">预览</uni-button>
</view>
</view>
</view>
<!-- <view v-if="item.!=0&&item." class="uni-flex uni-row">
<view style="width: 150rpx;">贷款成数:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.}} </view>
</view>
<view v-if="item.!=0&&item." class="uni-flex uni-row">
<view style="width: 150rpx;">贷款金额 2:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.}} </view>
</view>
<view v-if="item.!=0&&item." class="uni-flex uni-row">
<view style="width: 150rpx;">外部备注:</view>
<view style="-webkit-flex: 1;flex: 1;">{{item.}} </view>
</view> -->
<!-- <button v-if="inquiry!=null&&inquiry.status!=1" @click="showDialog(item)">复制询价条</button>-->
<!-- <quick-inquiry-info v-if="inquiryDetail!=null" :dialog-visible="dialogVisible" :inquiry-detail="inquiryDetail" @close-dialog="dialogVisible = false" @copy-to-clipboard="copyToClipboard" ></quick-inquiry-info> -->
<!-- <copy-inquiry-info v-if="inquiryDetail!=null" :dialog-visible="dialogVisible" :inquiry="inquiryDetail" @close-dialog="dialogVisible = false" @copy-to-clipboard="copyToClipboard" :detailIndex="detailIndex"></copy-inquiry-info>-->
<copy-inquiry-info v-if="inquiry.inquiry_details.length > 0" :dialog-visible="dialogVisible" :inquiry="inquiry" :list="inquiry.inquiry_details" @close-dialog="dialogVisible = false" @copy-to-clipboard="copyToClipboard"></copy-inquiry-info>
</uni-card>
</view>
</view>
</uni-section>
</view>
</view>
</template>
<script>
import { getUserID } from '@/utils/auth'
import { returnedPriceDetails,inquiryDetail } from '../../api/inquiry/inquiry'
// import QuickInquiryInfo from "./quickInquiryInfo.vue";
import CopyInquiryInfo from "./copyInquiryInfo.vue";
export default {
components: {
CopyInquiryInfo,
},
data() {
return {
keyword:'',
currentItem:{},
inquiry: [],
//inquiry_detail:this.$route.query.inquir_detail_item,
total:0,
evaluatePurposeList:[],
dialogVisible: false,
inquiryDetail: null,
list:[],
detailIndex:0
}
},
mounted() {
this.dialogVisible// dialogVisible, //是否
},
onLoad(options)
{
// 外部传入
let inquir_detail_item = JSON.parse(decodeURIComponent(options.inquir_detail_item));
this.inquiry = inquir_detail_item;
},
methods: {
// 获取物业数量
getEstateCount()
{
if( undefined != this.inquiry.inquiry_details)
{
return this.inquiry.inquiry_details.length
}
else{
return 0
}
},
showAllDetailsDialog(){
this.dialogVisible = true;
},
showDialog(index) {
// let detail = item;
// let params = { inquiry_id: this.inquiry.id, property_cert_info_id: detail.id };
// // 打开询价条窗口前向服务器请求数据
// inquiryDetail(params).then(response => {
// if (response && response.data) {
// this.inquiryDetail = response.data;
// console.log("showDialog(item) ",this.inquiryDetail)
// this.dialogVisible = true;
// }
// });
this.inquiryDetail = this.inquiry;
this.detailIndex = index;
console.log("showDialog(item) ",this.inquiryDetail)
this.dialogVisible = true;
},
openQuickInquiryInfo(item) {
let detail = item;
let params = { inquiry_id: this.inquiry.id, property_cert_info_id: detail.id };
inquiryDetail(params).then(response => {
if (response && response.data) {
this.$refs.quickInquiryInfo.open();
}
})
},
copyToClipboard() {
// 将多行输入框的内容复制到手机剪贴板上
uni.setClipboardData({
data: this.inquiryDetail,
success() {
uni.showToast({
title: '已复制',
duration: 2000
});
}
});
},
search() {
this.getWaitReturnPriceList(this.keyword);
},
newInquiry() {
this.$tab.navigateTo('/pages/inquiry/addInquiry')
},
// 请求详情
onRequestInquiryDetal() {
uni.navigateTo({
url: '/pages/inquiry/detail?inquiry_id=${this.currentItem.order_no}'
})
},
//询价待回价
getWaitReturnPriceList(keyword) {
let params = {
"page": 1,
"limit": 100,
"bank_id": "",
// "status": "1",
"type": "",
// "start_time": "2023-02-10",
// "end_time": "2023-05-11",
"eva_purpose": "",
"search_text": keyword,
"user_id": getUserID(),
"response_username": "",
"start_time_length": "",
"end_time_length": ""
}
waitReturnPrice(params).then(res => {
window.console.log(res)
this.list = res.data.data
this.total = res.data.count
}).catch(() => {
console.log('waitReturnPrice Error')
})
},
handleClick(item) {
this.currentItem = item
this.$refs.surveyType.open()
//this.$tab.navigateTo(`/pages/survey/detail?order_no==${item.order_no}&id=${item.id}&survey_id=${item.survey_id}&survey_type=${item.survey_type}`)
},
navSurvey(surveyType) {
let item = this.currentItem
if(surveyType == 'house') {
this.$tab.navigateTo(`/pages/survey/houseDetail?order_no==${item.order_no}&id=${item.id}&survey_id=${item.survey_id}&survey_type=1`)
}else if (surveyType == 'shop') {
this.$tab.navigateTo(`/pages/survey/shopDetail?order_no==${item.order_no}&id=${item.id}&survey_id=${item.survey_id}&survey_type=2`)
}
},
onCopyPress(index) {
const ref = `copyContainerRef${index}`;
const element = this.$refs[ref];
if (!element) {
uni.showToast({ title: '复制失败:未找到内容', icon: 'none' });
return;
}
const targetElement = Array.isArray(element) ? element[0] : element;
let textContent = '';
// 关键修改:使用 innerText 代替 textContent 保留换行符
if (targetElement instanceof HTMLElement) {
textContent = targetElement.textContent.trim();
} else if (targetElement && targetElement.$el) {
// 如果是 Vue 组件实例,获取其根元素的文本
textContent = targetElement.$el.textContent.trim();
}
console.log("textContent",textContent);
// 去除首尾空白并确保换行符统一为 \n
textContent = textContent.trim().replace(/。/g, '\n');
if (!textContent) {
uni.showToast({ title: '复制失败:无内容可复制', icon: 'none' });
return;
}
uni.setClipboardData({
data: textContent,
success() {
uni.showToast({ title: '复制成功', duration: 2000 });
},
fail(err) {
uni.showToast({ title: `复制失败:${err.errMsg}`, icon: 'none' });
}
});
},
previewFile(file) {
if(file.length == 0) {
uni.showToast({ title: '无图片可预览', icon: 'none' });
return;
}
const urls = file.filter(item => item.ext === 'jpg' || item.ext === 'png' || item.ext === 'jpeg')
.map(item => item.url);
uni.previewImage({
urls: urls,
longPressActions: {
itemList: ['保存图片'],
success: function(data) {
console.log('选中了第' + (data.tapIndex + 1) + '个按钮, 下标为:' + data.index)
},
fail: function(err) {
console.log(err.errMsg)
}
}
})
},
}
}
</script>
<style lang="scss" scoped>
page {
background-color: #f8f8f8;
}
.inquiry-container {
margin-bottom: 100rpx;
padding: 20rpx;
}
.toolbar {
margin-bottom: 50rpx;
padding: 10rpx;
}
.btn {
color: #ff6a00;
border:1px;
border-color: blue;
}
.btnInquiry {
color: #ff6a00;
}
.line {
width: 100%;
height: 5rpx;
background-color: #E6E6E6;
}
.line2 {
width: 100%;
height: 20rpx;
background-color: #F5F5F5;
}
.text-title {
color: #303133;
font-size: 32rpx;
font-weight: bold;
margin-left: 10rpx;
.iconfont {
font-size: 16px;
margin-right: 10rpx;
}
}
.text-item {
font-size: 28rpx;
padding: 24rpx;
}
.flex-item {
width: 33.3%;
height: 50rpx;
text-align: center;
//line-height: 200rpx;
}
</style>