1000 lines
26 KiB
Vue
1000 lines
26 KiB
Vue
<template>
|
||
<div class="broadcast-details" :style="'height:'+windowH+'px'">
|
||
<view class="hd-wrapper" :class="active === true ? 'on' : ''">
|
||
<scroll-view scroll-y="true" style="height: 100%; overflow: hidden;" :scroll-top="scrollTop" scroll-with-animation="true">
|
||
<div class="broadcast-details_order">
|
||
<div class="broadcast-details_box" v-if="productId && productInfo.id">
|
||
<div class="broadcast_details_img">
|
||
<img :src="productInfo.image" />
|
||
</div>
|
||
<div class="broadcast_details_picBox">
|
||
<div class="broadcast_details_tit" v-text="productInfo.storeName"></div>
|
||
<div class="acea-row row-between">
|
||
<div class="broadcast_details_pic">
|
||
¥{{ productInfo.price
|
||
}}<span class="broadcast_details_pic_num">¥{{ productInfo.otPrice }}</span>
|
||
</div>
|
||
<div class="broadcast_details_btn" @click="sendProduct">
|
||
发送客服
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="broadcast_box" v-if="orderId && orderInfo.id">
|
||
<div class="broadcast-details_num broadcast_num">
|
||
<span>订单号:{{ orderInfo.order_id }}</span>
|
||
<span>{{ orderInfo.add_time_y }} {{ orderInfo.add_time_h }}</span>
|
||
</div>
|
||
<div class="broadcast-details_box">
|
||
<div class="broadcast_details_img">
|
||
<img :src="cartInfo.productInfo.image" />
|
||
<div class="broadcast_details_model">
|
||
{{ orderInfo.cartInfo ? orderInfo.cartInfo.length : 0 }}件商品
|
||
</div>
|
||
</div>
|
||
<div class="broadcast_details_picBox">
|
||
<div class="broadcast_details_tit">
|
||
{{ cartInfo.productInfo.store_name }}
|
||
</div>
|
||
<div class="acea-row row-between">
|
||
<div class="broadcast_details_pic">
|
||
¥{{ cartInfo.productInfo.price
|
||
}}<span class="broadcast_details_pic_num">¥{{ cartInfo.productInfo.ot_price }}</span>
|
||
</div>
|
||
<div class="broadcast_details_btn" @click="sendOrder">
|
||
发送客服
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="chat" ref="chat" >
|
||
<template v-for="item in history">
|
||
<div class="item acea-row row-top" v-if="item.uid === toUid" :key="item.id">
|
||
<div class="pictrue"><img :src="item.avatar" /></div>
|
||
<div class="text">
|
||
<div class="name">{{ item.nickname }}</div>
|
||
<div class="acea-row">
|
||
<!--商品链接-->
|
||
<div v-if="item.msn_type === 6 && item.orderInfo.id">
|
||
<router-link class="broadcast-details_num" :to="{
|
||
path: '/pages/admin/orderDetail/index?id=' + item.orderInfo.order_id
|
||
}">
|
||
<span>订单号:{{ item.orderInfo.order_id }}</span>
|
||
</router-link>
|
||
<div class="conter acea-row row-middle">
|
||
<div class="broadcast-details_order noPad" v-for="(val, inx) in item.orderInfo.cartInfo" :key="val.id">
|
||
<router-link class="broadcast-details_box noPad" :to="{ path: '/pages/goods_details/index?id=' + val.product_id }" v-if="inx == 0">
|
||
<div class="broadcast_details_img">
|
||
<img :src="val.productInfo.image" />
|
||
<div class="broadcast_details_model">
|
||
{{
|
||
item.orderInfo.cartInfo
|
||
? item.orderInfo.cartInfo.length
|
||
: 0
|
||
}}件商品
|
||
</div>
|
||
</div>
|
||
<div class="broadcast_details_picBox noPad">
|
||
<div class="broadcast_details_tit" v-text="val.productInfo.store_name"></div>
|
||
<div class="broadcast_details_pic">
|
||
¥{{ val.productInfo.price }}
|
||
</div>
|
||
</div>
|
||
</router-link>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<!--商品链接-->
|
||
<div class="conter acea-row row-middle" v-if="item.msn_type === 5">
|
||
<div class=" noPad">
|
||
<router-link class="acea-row row-column-around noPad" v-if="item.productInfo.id" :to="{ path: '/pages/goods_details/index?id=' + item.productInfo.id }">
|
||
<div class="broadcast_details_img_no">
|
||
<img :src="item.productInfo.image" />
|
||
</div>
|
||
<div class="broadcast_details_picBox_no noPad">
|
||
<div class="broadcast_details_pic">
|
||
¥{{ item.productInfo.price }}
|
||
</div>
|
||
<div class="broadcast_details_tit_no" v-text="item.productInfo.store_name"></div>
|
||
</div>
|
||
</router-link>
|
||
</div>
|
||
</div>
|
||
|
||
<div class="conter acea-row row-middle" v-if="item.msn_type === 4">
|
||
<img src="/static/images/signal2.gif" class="signal" style="margin-right: 0.27rem;" />12’’
|
||
</div>
|
||
|
||
<div class="conter acea-row row-middle" v-if="item.msn_type === 3">
|
||
<img :src="item.msn" />
|
||
</div>
|
||
|
||
<div class="conter acea-row row-middle" v-if="item.msn_type === 2">
|
||
<i class="em" :class="item.msn"></i>
|
||
</div>
|
||
|
||
<div class="conter acea-row row-middle" v-if="item.msn_type === 1">
|
||
{{ item.msn }}
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<div class="item acea-row row-top row-right" v-else :key="item.id">
|
||
<div class="text textR">
|
||
<div class="name">{{ item.nickname }}</div>
|
||
<div class="acea-row ">
|
||
<!--商品链接-->
|
||
<router-link v-if="item.msn_type === 6 && item.orderInfo.id" :to="{
|
||
path: '/pages/admin/orderDetail/index?id=' + item.orderInfo.order_id
|
||
}">
|
||
<div class="broadcast-details_num">
|
||
<span>订单号:{{ item.orderInfo.order_id }}</span>
|
||
</div>
|
||
<div class="conter acea-row row-middle">
|
||
<div class="broadcast-details_order noPad" v-for="(val, inx) in item.orderInfo.cartInfo" :key="val.id">
|
||
<div class="broadcast-details_box noPad" v-if="inx == 0">
|
||
<div class="broadcast_details_img">
|
||
<img :src="val.productInfo.image" />
|
||
<div class="broadcast_details_model">
|
||
{{
|
||
item.orderInfo.cartInfo
|
||
? item.orderInfo.cartInfo.length
|
||
: 0
|
||
}}件商品
|
||
</div>
|
||
</div>
|
||
<div class="broadcast_details_picBox noPad">
|
||
<div class="broadcast_details_tit" v-text="val.productInfo.store_name"></div>
|
||
<div class="broadcast_details_pic">
|
||
¥{{ val.productInfo.price }}
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</router-link>
|
||
|
||
<!--商品链接-->
|
||
<div class="conter acea-row row-middle" v-if="item.msn_type === 5">
|
||
<div class=" noPad">
|
||
<router-link class="acea-row row-column-around noPad" v-if="item.productInfo.id" :to="{ path: '/pages/goods_details/index?id=' + item.productInfo.id }">
|
||
<div class="broadcast_details_img_no">
|
||
<img :src="item.productInfo.image" />
|
||
</div>
|
||
<div class="broadcast_details_picBox_no noPad">
|
||
<div class="broadcast_details_pic">
|
||
¥{{ item.productInfo.price }}
|
||
</div>
|
||
<div class="broadcast_details_tit_no" v-text="item.productInfo.store_name"></div>
|
||
</div>
|
||
</router-link>
|
||
</div>
|
||
</div>
|
||
|
||
<div class="conter acea-row row-middle" v-if="item.msn_type === 3">
|
||
<img :src="item.msn" />
|
||
</div>
|
||
|
||
<div class="conter acea-row row-middle" v-if="item.msn_type === 2">
|
||
<i class="em" :class="item.msn"></i>
|
||
</div>
|
||
|
||
<div class="conter acea-row row-middle" v-if="item.msn_type === 1">
|
||
{{ item.msn }}
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<div class="pictrue"><img :src="item.avatar" /></div>
|
||
</div>
|
||
</template>
|
||
</div>
|
||
<div :style=" active === true
|
||
? 'height:' + footerConH + 'rem;'
|
||
: 'height:' + footerH + 'rem;'
|
||
"></div>
|
||
</scroll-view>
|
||
</view>
|
||
<div class="footerCon" :class="active === true ? 'on' : ''" :style="'transform: translate3d(0,' + percent + '%,0);'" ref="footerCon">
|
||
<form>
|
||
<div class="footer acea-row row-between row-bottom" ref="footer">
|
||
<!--<img-->
|
||
<!--:src="-->
|
||
<!--voice === true-->
|
||
<!--? require('@assets/images/keyboard.png')-->
|
||
<!--: require('@assets/images/voice.png')-->
|
||
<!--"-->
|
||
<!--@click="voiceBnt"-->
|
||
<!--/>-->
|
||
|
||
<img @click="uploadImg" src="/static/images/plus.png" />
|
||
<img :src="
|
||
active === true
|
||
? '/static/images/keyboard.png'
|
||
: '/static/images/face.png'
|
||
"
|
||
@click="emoticon" />
|
||
<div class="voice acea-row row-center-wrapper" v-if="voice" @touchstart.prevent="start" @touchmove.prevent="move"
|
||
@touchend.prevent="end">
|
||
{{ speak }}
|
||
</div>
|
||
<!-- <p contenteditable="true" class="input" ref="input" v-show="!voice" @keydown="keydown($event)" @keyup="keyup" @focus="focus"></p> -->
|
||
<input type="text" placeholder="请输入内容" class="input" ref="input" v-show="!voice" @input="bindInput" @keyup="keyup"
|
||
@focus="focus" cursor-spacing="20" v-model="textCon">
|
||
<div class="send" :class="sendColor === true ? 'font-color-red' : ''" @click="sendTest">
|
||
发送
|
||
</div>
|
||
</div>
|
||
</form>
|
||
<div class="banner slider-banner">
|
||
<swiper class="swiper-wrapper" :autoplay="autoplay" :circular="circular" :interval="interval" :duration="duration"
|
||
v-if="emojiGroup.length > 0">
|
||
<block v-for="(emojiList, index) in emojiGroup" :key="index">
|
||
<swiper-item>
|
||
<i class="em" :class="emoji" v-for="emoji in emojiList" :key="emoji" @click="addEmoji(emoji)"></i>
|
||
<img src="/static/images/del.png" class="emoji-outer" />
|
||
</swiper-item>
|
||
</block>
|
||
|
||
|
||
<!-- <swiper-slide class="swiper-slide acea-row" v-for="(emojiList, index) in emojiGroup" :key="index">
|
||
<i class="em" :class="emoji" v-for="emoji in emojiList" :key="emoji" @click="addEmoji(emoji)"></i>
|
||
<img src="/static/images/del.png" class="emoji-outer" />
|
||
</swiper-slide>
|
||
<div class="swiper-pagination" slot="pagination"></div> -->
|
||
</swiper>
|
||
</div>
|
||
</div>
|
||
<div class="recording" v-if="recording">
|
||
<img src="/static/images/recording.png" />
|
||
</div>
|
||
<home></home>
|
||
</div>
|
||
</template>
|
||
<script>
|
||
import emojiList from "@/utils/emoji";
|
||
import Socket from "@/libs/chat";
|
||
import {
|
||
getChatRecord
|
||
} from "@/api/user";
|
||
import {
|
||
getProductDetail
|
||
} from "@/api/store";
|
||
import {
|
||
getOrderDetail
|
||
} from "@/api/order";
|
||
import easyUpload from '@/components/easy-upload/easy-upload.vue'
|
||
import {
|
||
TOKENNAME,
|
||
HTTP_REQUEST_URL
|
||
} from '@/config/app.js';
|
||
import home from '@/components/home';
|
||
|
||
const chunk = function(arr, num) {
|
||
num = num * 1 || 1;
|
||
var ret = [];
|
||
arr.forEach(function(item, i) {
|
||
if (i % num === 0) {
|
||
ret.push([]);
|
||
}
|
||
ret[ret.length - 1].push(item);
|
||
});
|
||
return ret;
|
||
};
|
||
|
||
const NAME = "CustomerService";
|
||
|
||
export default {
|
||
name: NAME,
|
||
components: {
|
||
easyUpload,
|
||
home
|
||
},
|
||
props: {
|
||
couponList: {
|
||
type: Array,
|
||
default: () => []
|
||
}
|
||
},
|
||
data: function() {
|
||
return {
|
||
url: `${HTTP_REQUEST_URL}/api/upload/image`,
|
||
headers: {
|
||
"Authori-zation": "Bearer " + this.$store.state.app.token
|
||
},
|
||
emojiGroup: chunk(emojiList, 20),
|
||
active: false,
|
||
voice: false,
|
||
speak: "按住 说话",
|
||
recording: false,
|
||
swiperOption: {
|
||
pagination: {
|
||
el: ".swiper-pagination",
|
||
clickable: true
|
||
},
|
||
speed: 1000,
|
||
observer: true,
|
||
observeParents: true
|
||
},
|
||
percent: 0,
|
||
footerConH: 0,
|
||
footerH: 1.08,
|
||
socket: null,
|
||
toUid: 0,
|
||
page: 1,
|
||
limit: 30,
|
||
loading: false,
|
||
loaded: false,
|
||
history: [],
|
||
sendColor: false,
|
||
sendtxt: "",
|
||
productId: 0,
|
||
productInfo: {},
|
||
orderId: "",
|
||
orderInfo: {},
|
||
cartInfo: {},
|
||
autoplay: false,
|
||
circular: true,
|
||
interval: 3000,
|
||
duration: 500,
|
||
upload_max: 2, //图片大小
|
||
//上传的图片地址
|
||
uploadImages: [],
|
||
//展示的图片地址
|
||
uploads: [],
|
||
// 超出限制数组
|
||
exceeded_list: [],
|
||
windowH: 0,
|
||
isBQ: false,
|
||
scrollTop:0 ,//滚动距离
|
||
textCon:'' //文字
|
||
};
|
||
},
|
||
watch: {
|
||
$route(n) {
|
||
if (n.name === NAME) {
|
||
if (n.params.productId) this.productId = n.params.productId;
|
||
else this.productId = 0;
|
||
|
||
if (n.query.orderId) this.orderId = n.query.orderId;
|
||
else this.orderId = "";
|
||
}
|
||
}
|
||
},
|
||
beforeDestroy() {
|
||
this.socket && this.socket.close();
|
||
},
|
||
onLoad(option) {
|
||
let self = this
|
||
this.toUid = option.uid || 0;
|
||
this.productId = parseInt(option.productId) || 0;
|
||
this.orderId = option.orderId || ""
|
||
uni.getSystemInfo({
|
||
success: function(res) {
|
||
self.windowH = res.windowHeight
|
||
}
|
||
})
|
||
},
|
||
onReady: function() {
|
||
this.height();
|
||
this.getHistory();
|
||
this.getproductInfo();
|
||
this.getOrderInfo();
|
||
this.socket = new Socket();
|
||
this.socket.vm(this);
|
||
this.$on(["reply", "chat"], data => {
|
||
this.history.push(data);
|
||
this.$nextTick(function() {
|
||
window.scrollTo(0, document.documentElement.scrollHeight + 999);
|
||
});
|
||
});
|
||
this.$on("socket_error", () => {
|
||
this.$dialog.error("连接失败");
|
||
});
|
||
this.$on("err_tip", data => {
|
||
this.$dialog.error(data);
|
||
});
|
||
this.$on("socket_open", () => {
|
||
this.socket.send({
|
||
data: {
|
||
id: this.toUid
|
||
},
|
||
type: "to_chat"
|
||
});
|
||
});
|
||
document.addEventListener("scroll", this.scroll, false);
|
||
|
||
},
|
||
destroyed() {
|
||
document.removeEventListener("scroll", this.scroll);
|
||
},
|
||
methods: {
|
||
uploadImg() {
|
||
let self = this
|
||
uni.chooseImage({
|
||
count: 1, //默认1
|
||
sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
|
||
sourceType: ['album', 'camera'], //从相册选择
|
||
success: (res) => {
|
||
for (let i = 0; i < res.tempFiles.length; i++) {
|
||
if (Math.ceil(res.tempFiles[i].size / 1024) < this.upload_max * 1024) {
|
||
this.uploads.push(res.tempFiles[i].path)
|
||
this.uploadImages.push(res.tempFiles[i].path)
|
||
} else {
|
||
this.exceeded_list.push(i === 0 ? 1 : i + 1);
|
||
uni.showModal({
|
||
title: '提示',
|
||
content: `第${[...new Set(this.exceeded_list)].join(',')}张图片超出限制${this.upload_max}MB,已过滤`
|
||
});
|
||
}
|
||
}
|
||
uni.uploadFile({
|
||
url: self.url, //仅为示例,非真实的接口地址
|
||
filePath: self.uploadImages[0],
|
||
name: 'file',
|
||
header: {
|
||
"Authori-zation": "Bearer " + self.$store.state.app.token
|
||
},
|
||
//请求参数
|
||
success: (uploadFileRes) => {
|
||
let data = JSON.parse(uploadFileRes.data)
|
||
self.sendMsg(data.data.url, 3)
|
||
}
|
||
});
|
||
},
|
||
fail: (err) => {
|
||
uni.showModal({
|
||
content: JSON.stringify(err)
|
||
});
|
||
}
|
||
});
|
||
},
|
||
getOrderInfo() {
|
||
if (!this.orderId) return;
|
||
getOrderDetail(this.orderId).then(res => {
|
||
this.orderInfo = res.data;
|
||
if (this.orderInfo.add_time_h) {
|
||
this.orderInfo.add_time_h = this.orderInfo.add_time_h.substring(
|
||
0,
|
||
this.orderInfo.add_time_h.lastIndexOf(":")
|
||
);
|
||
}
|
||
if (this.orderInfo.cartInfo.length) {
|
||
this.cartInfo = this.orderInfo.cartInfo[0];
|
||
}
|
||
});
|
||
},
|
||
getproductInfo() {
|
||
let that = this;
|
||
if (!this.productId) return;
|
||
getProductDetail(this.productId).then(res => {
|
||
that.productInfo = res.data.storeInfo;
|
||
});
|
||
},
|
||
scroll() {
|
||
if (window.scrollY < 300 && !this.loaded && !this.loading)
|
||
this.getHistory();
|
||
},
|
||
imageuploaded(res) {
|
||
if (res.status !== 200) return this.$dialog.error(res || "上传图片失败");
|
||
this.sendMsg(res.data.url, 3);
|
||
},
|
||
getHistory() {
|
||
if (this.loading || this.loaded) return;
|
||
this.loading = true;
|
||
getChatRecord(this.toUid, {
|
||
page: this.page,
|
||
limit: this.limit
|
||
})
|
||
.then(({
|
||
data
|
||
}) => {
|
||
this.history = data.list.concat(this.history);
|
||
if (this.page === 1) {
|
||
this.$nextTick(function() {
|
||
window.scrollTo(0, document.documentElement.scrollHeight + 999);
|
||
this.height();
|
||
});
|
||
}
|
||
this.page++;
|
||
this.loading = false;
|
||
this.loaded = data.length < this.limit;
|
||
})
|
||
.catch(err => {
|
||
this.$dialog.error(err || "加载失败");
|
||
});
|
||
},
|
||
focus: function() {
|
||
this.active = false;
|
||
},
|
||
keyup: function() {
|
||
if (this.$refs.input.innerHTML.length > 0) {
|
||
this.sendColor = true;
|
||
} else {
|
||
this.sendColor = false;
|
||
}
|
||
},
|
||
addEmoji(name) {
|
||
this.sendMsg(name, 2);
|
||
},
|
||
sendMsg(msn, type) {
|
||
this.height();
|
||
this.socket.send({
|
||
data: {
|
||
msn,
|
||
type,
|
||
to_uid: this.toUid
|
||
},
|
||
type: "chat"
|
||
});
|
||
},
|
||
sendTest() {
|
||
this.sendMsg(this.textCon, 1);
|
||
this.textCon = ''
|
||
this.height();
|
||
},
|
||
sendProduct() {
|
||
this.sendMsg(this.productId, 5);
|
||
this.productId = 0;
|
||
this.productInfo = {};
|
||
},
|
||
sendOrder() {
|
||
this.sendMsg(this.orderId, 6);
|
||
this.orderId = 0;
|
||
this.orderInfo = {};
|
||
},
|
||
bindInput: function(e) {
|
||
if(e.detail.value){
|
||
this.sendColor = true
|
||
}else{
|
||
this.sendColor = false
|
||
}
|
||
this.height();
|
||
},
|
||
start() {
|
||
var that = this;
|
||
this.longClick = 0;
|
||
this.timeOutEvent = setTimeout(function() {
|
||
that.longClick = 1;
|
||
}, 500);
|
||
that.speak = "松开 结束";
|
||
that.recording = true;
|
||
},
|
||
move() {
|
||
clearTimeout(this.timeOutEvent);
|
||
this.timeOutEvent = 0;
|
||
},
|
||
end() {
|
||
clearTimeout(this.timeOutEvent);
|
||
if (this.timeOutEvent !== 0 && this.longClick === 0) {
|
||
//点击
|
||
//此处为点击事件----在此处添加跳转详情页
|
||
}
|
||
this.speak = "按住 说话";
|
||
this.recording = false;
|
||
return false;
|
||
},
|
||
voiceBnt: function() {
|
||
this.active = false;
|
||
if (this.voice === true) {
|
||
this.voice = false;
|
||
this.$nextTick(function() {
|
||
this.$refs.input.focus();
|
||
});
|
||
} else {
|
||
this.voice = true;
|
||
}
|
||
window.scrollTo(0, document.documentElement.scrollHeight);
|
||
this.percent = 0;
|
||
this.footerConH = 0;
|
||
this.footerH = 0;
|
||
this.$nextTick(function() {
|
||
this.height();
|
||
});
|
||
},
|
||
emoticon: function() {
|
||
this.voice = false;
|
||
if (this.active === true) {
|
||
this.active = false;
|
||
this.isBQ = false
|
||
// this.$nextTick(function() {
|
||
// this.$refs.input.focus();
|
||
// });
|
||
} else {
|
||
this.active = true;
|
||
this.isBQ = true
|
||
// this.$nextTick(function() {
|
||
// this.$refs.input.blur();
|
||
// });
|
||
}
|
||
this.height();
|
||
},
|
||
height() {
|
||
let scrollTop = 0
|
||
let footerConH = this.$refs.footerCon.offsetHeight;
|
||
let footerH = this.$refs.footer.offsetHeight;
|
||
let scale = 750 / window.screen.availWidth;
|
||
this.footerConH = (footerConH * scale) / 100;
|
||
this.footerH = (footerH * scale) / 100;
|
||
this.percent = ((this.footerConH - this.footerH) / this.footerConH) * 100;
|
||
setTimeout(res=>{
|
||
let info = uni.createSelectorQuery().select(".chat");
|
||
info.boundingClientRect(function(data) { //data - 各种参数
|
||
// 获取元素宽度
|
||
scrollTop = data.height
|
||
}).exec()
|
||
if(this.active){
|
||
this.scrollTop = scrollTop+500
|
||
}else{
|
||
this.scrollTop = scrollTop+100
|
||
}
|
||
},600)
|
||
|
||
|
||
},
|
||
}
|
||
};
|
||
</script>
|
||
|
||
<style lang="scss">
|
||
page {
|
||
width: 100%;
|
||
height: 100%;
|
||
}
|
||
|
||
/* #ifdef H5 */
|
||
@import url("@/plugin/emoji-awesome/css/google.min.css");
|
||
|
||
/* #endif */
|
||
.broadcast_num {
|
||
padding: 0 10rpx !important;
|
||
}
|
||
|
||
.noPad {
|
||
padding: 0 !important;
|
||
margin-bottom: 0 !important;
|
||
height: auto !important;
|
||
}
|
||
|
||
.broadcast-details_num {
|
||
width: 100%;
|
||
height: 80rpx;
|
||
line-height: 80rpx;
|
||
color: #000000;
|
||
font-size: 26rpx;
|
||
display: flex;
|
||
justify-content: space-between;
|
||
background: #fff;
|
||
border-bottom: 1px dashed rgba(0, 0, 0, 0.2);
|
||
padding: 0 24rpx;
|
||
}
|
||
|
||
.broadcast-details_order {
|
||
padding: 15rpx;
|
||
}
|
||
|
||
.broadcast-details_box {
|
||
padding: 24rpx;
|
||
display: flex;
|
||
background: #fff;
|
||
border-radius: 6px;
|
||
margin-bottom: 24rpx;
|
||
}
|
||
|
||
.broadcast_details_model {
|
||
width: 100%;
|
||
height: 43rpx;
|
||
background: rgba(0, 0, 0, 0.5);
|
||
border-radius: 0px 0px 8px 8px;
|
||
position: absolute;
|
||
z-index: 2;
|
||
bottom: 0;
|
||
font-size: 22rpx;
|
||
color: #fff;
|
||
text-align: center;
|
||
line-height: 43rpx;
|
||
}
|
||
|
||
.broadcast_details_img {
|
||
width: 140rpx;
|
||
height: 140rpx;
|
||
border-radius: 8px;
|
||
overflow: hidden;
|
||
position: relative;
|
||
}
|
||
|
||
.broadcast_details_img img {
|
||
width: 100%;
|
||
height: 100%;
|
||
}
|
||
|
||
.broadcast_details_img_no {
|
||
width: 100%;
|
||
height: auto;
|
||
border-radius: 8px 8px 0px 0px;
|
||
overflow: hidden;
|
||
margin-bottom: 10rpx;
|
||
}
|
||
|
||
.broadcast_details_picBox_no {
|
||
width: 100%;
|
||
}
|
||
|
||
.broadcast_details_img_no img {
|
||
width: 100%;
|
||
height: 100%;
|
||
}
|
||
|
||
.broadcast_details_tit {
|
||
font-size: 28rpx;
|
||
color: #333333;
|
||
height: 85rpx;
|
||
font-weight: 800;
|
||
overflow: hidden;
|
||
text-overflow: ellipsis;
|
||
display: -webkit-box;
|
||
-webkit-line-clamp: 2;
|
||
-webkit-box-orient: vertical;
|
||
text-align: left !important;
|
||
}
|
||
|
||
.broadcast_details_tit_no {
|
||
font-size: 28rpx;
|
||
color: #333333;
|
||
font-weight: 800;
|
||
text-align: left;
|
||
margin-top: 5rpx;
|
||
}
|
||
|
||
.broadcast_details_picBox {
|
||
width: 75%;
|
||
margin-left: 24rpx;
|
||
}
|
||
|
||
.broadcast_details_pic {
|
||
font-size: 36rpx;
|
||
color: $theme-color;
|
||
text-align: left;
|
||
}
|
||
|
||
.broadcast_details_pic_num {
|
||
text-decoration: line-through;
|
||
font-size: 28rpx;
|
||
color: rgba(0, 0, 0, 0.5);
|
||
margin-left: 0.1rem;
|
||
}
|
||
|
||
.broadcast_details_btn {
|
||
width: 160rpx;
|
||
height: 50rpx;
|
||
background: #e83323;
|
||
opacity: 1;
|
||
border-radius: 125rpx;
|
||
color: #fff;
|
||
font-size: 24rpx;
|
||
text-align: center;
|
||
line-height: 50rpx;
|
||
}
|
||
|
||
.broadcast-details .chat {
|
||
padding: 1rpx 23rpx 0 3rpx;
|
||
margin-bottom: 3rpx;
|
||
}
|
||
|
||
.broadcast-details .chat .item {
|
||
margin-top: 37rpx;
|
||
}
|
||
|
||
.broadcast-details .chat .item .pictrue {
|
||
width: 80rpx;
|
||
height: 80rpx;
|
||
margin-top: 10rpx;
|
||
}
|
||
|
||
.broadcast-details .chat .item .pictrue img {
|
||
width: 100%;
|
||
height: 100%;
|
||
border-radius: 50%;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text {
|
||
margin-left: 20rpx;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text.textR {
|
||
text-align: right;
|
||
margin: 0 20rpx 0 0;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text .name {
|
||
font-size: 24rpx;
|
||
color: #999;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text .name .return {
|
||
color: #509efb;
|
||
margin-left: 17rpx;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text.textR .name .return {
|
||
margin: 0 0.17rem 0 0;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text .conter {
|
||
background-color: #fff;
|
||
border-radius: 8rpx;
|
||
padding: 16rpx 20rpx;
|
||
font-size: 30rpx;
|
||
color: #333;
|
||
position: relative;
|
||
max-width: 496rpx;
|
||
margin-top: 2rpx;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text .spot {
|
||
width: 15rpx;
|
||
height: 15rpx;
|
||
background-color: #c00000;
|
||
border-radius: 50%;
|
||
margin-left: 20rpx;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text .conter:before {
|
||
position: absolute;
|
||
content: "";
|
||
width: 0;
|
||
height: 0;
|
||
border-bottom: 9rpx solid transparent;
|
||
border-right: 14rpx solid #fff;
|
||
border-top: 9rpx solid transparent;
|
||
left: -14rpx;
|
||
top: 25rpx;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text.textR .conter:before {
|
||
left: unset;
|
||
right: -14rpx;
|
||
transform: rotateY(180deg);
|
||
}
|
||
|
||
.broadcast-details .chat .item .text .conter img {
|
||
width: 100%;
|
||
display: block;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text .conter .signal {
|
||
width: 48rpx;
|
||
height: 48rpx;
|
||
}
|
||
|
||
.broadcast-details .chat .item .text .conter .signal.signalR {
|
||
transform: rotate(180deg);
|
||
-ms-transform: rotate(180deg);
|
||
-webkit-transform: rotate(180deg);
|
||
}
|
||
|
||
.broadcast-details .footerCon {
|
||
|
||
height: 100rpx;
|
||
width: 100%;
|
||
transition: all 0.005s cubic-bezier(0.25, 0.5, 0.5, 0.9);
|
||
background-color: #fff;
|
||
}
|
||
|
||
.broadcast-details .footerCon.on {
|
||
position: relative;
|
||
top: -300rpx;
|
||
transform: translate3d(0, 0, 0) !important;
|
||
}
|
||
|
||
.broadcast-details .footerCon .banner .swiper-slide {
|
||
flex-wrap: wrap;
|
||
-webkit-flex-wrap: wrap;
|
||
background-color: #fff;
|
||
padding-bottom: 50rpx;
|
||
border-top: 1px solid #f5f5f5;
|
||
}
|
||
|
||
.broadcast-details .footerCon .banner .swiper-slide .emoji-outer,
|
||
.swiper-slide .em {
|
||
display: block;
|
||
width: 50rpx;
|
||
height: 50rpx;
|
||
margin: 40rpx 0 0 50rpx;
|
||
}
|
||
|
||
.broadcast-details .footerCon .banner .swiper-container-horizontal>.swiper-pagination-bullets {
|
||
bottom: 10rpx;
|
||
}
|
||
|
||
.broadcast-details .footerCon .slider-banner .swiper-pagination-bullet-active {
|
||
background-color: #999;
|
||
}
|
||
|
||
.broadcast-details .recording {
|
||
width: 300rpx;
|
||
height: 300rpx;
|
||
position: fixed;
|
||
top: 40%;
|
||
left: 50%;
|
||
margin-left: -150rpx;
|
||
}
|
||
|
||
.broadcast-details .recording img {
|
||
width: 100%;
|
||
height: 100%;
|
||
}
|
||
|
||
.broadcast-details .footer {
|
||
width: 100%;
|
||
background-color: #fff;
|
||
padding: 17rpx 26rpx;
|
||
}
|
||
|
||
.broadcast-details .footer img {
|
||
width: 61rpx;
|
||
height: 60rpx;
|
||
display: block;
|
||
}
|
||
|
||
.broadcast-details .footer .input,
|
||
.broadcast-details .footer .voice {
|
||
width: 440rpx;
|
||
border-radius: 10rpx;
|
||
background-color: #e5e5e5;
|
||
/* padding: 17rpx 30rpx; */
|
||
height: 60rpx;
|
||
padding-left: 20rpx;
|
||
}
|
||
|
||
.input {}
|
||
|
||
.broadcast-details .footer .input {
|
||
max-height: 150rpx;
|
||
overflow-y: auto;
|
||
overflow-x: hidden;
|
||
}
|
||
|
||
.broadcast-details .footer .send {
|
||
width: 70rpx;
|
||
text-align: center;
|
||
height: 60rpx;
|
||
line-height: 60rpx;
|
||
font-weight: bold;
|
||
}
|
||
|
||
.em {
|
||
display: inline-block;
|
||
width: 50rpx;
|
||
height: 50rpx;
|
||
margin: 40rpx 0 0 50rpx;
|
||
}
|
||
|
||
.emoji-outer {
|
||
position: absolute;
|
||
right: 50rpx;
|
||
bottom: 30rpx;
|
||
width: 50rpx;
|
||
height: 50rpx;
|
||
}
|
||
|
||
.broadcast-details {
|
||
display: flex;
|
||
flex-direction: column;
|
||
width: 100%;
|
||
overflow: hidden;
|
||
.hd-wrapper {
|
||
flex: 1;
|
||
display: flex;
|
||
flex-direction: column;
|
||
overflow: hidden;
|
||
&.on{
|
||
padding-bottom: 300rpx;
|
||
}
|
||
}
|
||
}
|
||
</style>
|