翠屏区智慧广电示范区
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

1031 lines
48 KiB

<template>
<!-- 图书馆 -->
<div class="eb-container" ref="appRef">
<MainTitle class="title" :title="title"></MainTitle>
<div class="main-container">
<div class="left-box">
<div class="base-info">
<div class="title-box-samll">
<span>基本概况</span>
</div>
<div class="content-info">
<div class="data-item">
<img
:src="require('@/assets/screenView/xiaqu.png')"
/>
<div class="content">
<span>建筑面积()</span>
<span>{{
baseInfo[0] && baseInfo[0].value
}}</span>
</div>
</div>
<div class="data-item">
<img
:src="require('@/assets/screenView/gendi.png')"
/>
<div class="content">
<span>馆内座位()</span>
<span>{{
baseInfo[1] && baseInfo[1].value
}}</span>
</div>
</div>
<div class="data-item">
<img
:src="require('@/assets/screenView/hushu.png')"
/>
<div class="content">
<span>现有图书()</span>
<span>{{
baseInfo[2] && baseInfo[2].value
}}</span>
</div>
</div>
<div class="data-item">
<img
:src="require('@/assets/screenView/renkou.png')"
/>
<div class="content">
<span>馆藏图书()</span>
<span>{{
baseInfo[3] && baseInfo[3].value
}}</span>
</div>
</div>
</div>
</div>
<div class="activity-info">
<div class="title-box-samll">
<span>活动信息</span>
</div>
<div class="content-info" id="barChart"></div>
</div>
<div class="hot-rank">
<div class="title-box-samll">
<span>热度排行</span>
</div>
<div class="content-info">
<vue-seamless-scroll
:data="rankList"
:class-option="rankOption"
style="width: 100%; height: 100%; overflow: hidden"
>
<div class="hot-scenic-info">
<div
class="hot-scenic-item"
v-for="(item, index) in rankList"
:key="index"
>
<div class="ranking">
No.{{ index + 1 }}
</div>
<div class="scenicNmae">
{{ item.label }}
</div>
<div class="numvote">{{ item.value }}</div>
</div>
</div>
</vue-seamless-scroll>
</div>
</div>
</div>
<div class="center-box">
<div class="video-box">
<common-live-player :video-url="videoUrl" :live="true" :muted="false"></common-live-player>
<div class="video-list" @click="changeVideo($event)">
<vue-seamless-scroll
:data="videoList"
:class-option="videoOption"
style="width: 100%; height: 100%; overflow: hidden"
>
<div class="list">
<div
class="video-item"
v-for="(item, index) in videoList"
:key="index"
:data-index="index"
>
<img :src="item.coverImage" :data-index="index" />
<div class="title" :data-index="index">{{ item.title }}</div>
</div>
</div>
</vue-seamless-scroll>
</div>
</div>
<div class="books">
<div class="title-box-medium" style="width: 860px;">
<span>图书推荐</span>
</div>
<div class="content-info" @click="openInfo($event, bookList)">
<vue-seamless-scroll
:data="bookList"
:class-option="bookOption"
style="width: 100%; height: 100%; overflow: hidden"
>
<div class="list">
<div
class="book-item"
v-for="(item, index) in bookList"
:key="index"
:data-index="index"
>
<img :src="item.coverImage" :data-index="index" />
<span class="title" :data-index="index">{{ item.title }}</span>
</div>
</div>
</vue-seamless-scroll>
</div>
</div>
</div>
<div class="right-box">
<div class="borrowing-info">
<div class="title-box-samll">
<span>借阅分析</span>
</div>
<div class="content-info">
<div class="data-item">
<img
:src="require('@/assets/screenView/xiaqu.png')"
/>
<div class="content">
<span>今日读者(人)</span>
<span>{{
borrowList[0] && borrowList[0].value
}}</span>
</div>
</div>
<div class="data-item">
<img
:src="require('@/assets/screenView/gendi.png')"
/>
<div class="content">
<span>本月读者(人)</span>
<span>{{
borrowList[1] && borrowList[1].value
}}</span>
</div>
</div>
<div class="data-item">
<img
:src="require('@/assets/screenView/hushu.png')"
/>
<div class="content">
<span>本月借阅(本)</span>
<span>{{
borrowList[2] && borrowList[2].value
}}</span>
</div>
</div>
<div class="data-item">
<img
:src="require('@/assets/screenView/renkou.png')"
/>
<div class="content">
<span>本月归还(本)</span>
<span>{{
borrowList[3] && borrowList[3].value
}}</span>
</div>
</div>
</div>
</div>
<div class="classify-info">
<div class="title-box-samll">
<span>图书分类</span>
</div>
<div class="content-info" id="lineChart"></div>
</div>
<div class="info-list">
<div class="title-box-samll">
<span>图书馆资讯</span>
</div>
<div class="content-info" @click="openInfo($event, queryContentInfoList)">
<vue-seamless-scroll
:data="queryContentInfoList"
:class-option="infoOption"
style="width: 100%; height: 100%; overflow: hidden"
>
<div class="list">
<div
class="info-item"
style="
display: flex;
overflow: hidden;
gap: 15px;
margin-bottom: 10px;
"
v-for="(
item, index
) in queryContentInfoList"
:key="index"
:data-index="index"
>
<img
:src="item.coverImage"
style="width: 50%; height: 120px"
:data-index="index"
/>
<div
style="
width: 50%;
display: flex;
flex-direction: column;
justify-content: space-between;
"
:data-index="index"
>
<div
style="font-size: 16px"
class="title"
:data-index="index"
>
{{ item.title }}
</div>
<div
style="
margin-top: 10px;
font-size: 14px;
color: #c1c1c1;
"
:data-index="index"
>
{{ item.createTime }}
</div>
</div>
</div>
</div>
</vue-seamless-scroll>
</div>
</div>
</div>
</div>
<div class="page-bottom-bg"></div>
<div class="page-left-bg"></div>
<div class="page-right-bg"></div>
<common-modal v-model="imgTextModal" @close="imgTextModal = false" :title="info.title" width="600">
<modalDetail :current-activity="info" :imgTextModal="imgTextModal"></modalDetail>
</common-modal>
</div>
</template>
<script>
import { useIndex } from "../../utils/utilsDramAdmin";
import MainTitle from "./components/MainTitle.vue";
import { echartsFocus, echartsClear } from "@/utils/autoEcharts";
import * as echarts from "echarts";
import vueSeamlessScroll from "vue-seamless-scroll";
import CommonLivePlayer from "@/views/common-components/common-live-player.vue";
import commonModal from '@/views/common-components/common-modal.vue'
import modalDetail from './components/modalDetail.vue'
export default {
name: "LibraryCenter",
components: { MainTitle, vueSeamlessScroll, CommonLivePlayer, commonModal, modalDetail },
data() {
return {
title: "翠屏区图书馆",
areaCode: "2021030823390054",
baseInfo: [],
borrowList: [],
rankList: [],
rankOption: {
step: 0.2, // 数值越大速度滚动越快
limitMoveNum: 4, // 开始无缝滚动的数据量 this.dataList.length
hoverStop: true, // 是否开启鼠标悬停stop
direction: 1, // 0向下 1向上 2向左 3向右
openWatch: true, // 开启数据实时监控刷新dom
singleHeight: 0, // 单步运动停止的高度(默认值0是无缝不停止的滚动) direction => 0/1
singleWidth: 0, // 单步运动停止的宽度(默认值0是无缝不停止的滚动) direction => 2/3
waitTime: 1000, // 单步运动停止的时间(默认值1000ms)
},
videoList: [],
videoOption: {
step: 0.2, // 数值越大速度滚动越快
limitMoveNum: 4, // 开始无缝滚动的数据量 this.dataList.length
hoverStop: true, // 是否开启鼠标悬停stop
direction: 2, // 0向下 1向上 2向左 3向右
openWatch: true, // 开启数据实时监控刷新dom
singleHeight: 0, // 单步运动停止的高度(默认值0是无缝不停止的滚动) direction => 0/1
singleWidth: 0, // 单步运动停止的宽度(默认值0是无缝不停止的滚动) direction => 2/3
waitTime: 1000, // 单步运动停止的时间(默认值1000ms)
},
bookList: [],
bookOption: {
step: 0.2, // 数值越大速度滚动越快
limitMoveNum: 4, // 开始无缝滚动的数据量 this.dataList.length
hoverStop: true, // 是否开启鼠标悬停stop
direction: 2, // 0向下 1向上 2向左 3向右
openWatch: true, // 开启数据实时监控刷新dom
singleHeight: 0, // 单步运动停止的高度(默认值0是无缝不停止的滚动) direction => 0/1
singleWidth: 0, // 单步运动停止的宽度(默认值0是无缝不停止的滚动) direction => 2/3
waitTime: 1000, // 单步运动停止的时间(默认值1000ms)
},
queryContentInfoList: [],
infoOption: {
step: 0.2, // 数值越大速度滚动越快
limitMoveNum: 4, // 开始无缝滚动的数据量 this.dataList.length
hoverStop: true, // 是否开启鼠标悬停stop
direction: 1, // 0向下 1向上 2向左 3向右
openWatch: true, // 开启数据实时监控刷新dom
singleHeight: 0, // 单步运动停止的高度(默认值0是无缝不停止的滚动) direction => 0/1
singleWidth: 0, // 单步运动停止的宽度(默认值0是无缝不停止的滚动) direction => 2/3
waitTime: 1000, // 单步运动停止的时间(默认值1000ms)
},
videoUrl: "",
imgTextModal: false,
info: {}
};
},
computed: {},
created() {},
beforeDestroy() {
echartsClear();
},
mounted() {
const { calcRate, windowDraw } = useIndex(this.$refs.appRef);
calcRate();
windowDraw();
this.queryContentInfo();
this.queryVideo()
// 基本概况
this.initDataInfo("libarayBaseInfo", data => {
this.baseInfo = data
})
// 活动信息
this.initDataInfo("libarayActivity", data => {
let xData = data.map(item => item.label)
let yData = data.map(item => Number(item.value))
this.initBarChart(xData, yData)
})
// 热度排行
this.initDataInfo("libarayHotRank", data => {
this.rankList = data
})
// 借阅分析
this.initDataInfo("libarayPersonSpecial", data => {
this.borrowList = data
})
// 图书分类
this.initDataInfo("libarayclassify", data => {
let xData = data.map(item => item.label)
let yData = data.map(item => Number(item.value))
this.initlineChart2(xData, yData)
})
// 图书推荐
this.queryRecommend()
},
beforeDestroy() {},
methods: {
initBarChart(xData, yData) {
let myChart = echarts.init(document.getElementById("barChart"));
let option = {
tooltip: {
trigger: "axis",
axisPointer: {
type: "cross",
label: {
backgroundColor: "#6a7985",
},
},
},
xAxis: {
type: "category",
axisLabel: {
margin: 10,
interval: 0,
color: "#ffffff",
textStyle: {
fontSize: 12,
},
},
data: xData,
},
yAxis: {
type: "value",
splitLine: {
show: true,
lineStyle: {
type: "dashed",
color: "#35414c",
},
},
axisLabel: {
color: "#ffffff",
textStyle: {
fontSize: 12,
},
},
},
grid: {
top: "10%",
bottom: "15%",
width: "87%",
height: "75%",
},
series: [
{
data: yData,
type: "bar",
barWidth: "16px",
itemStyle: {
color: new echarts.graphic.LinearGradient(
0,
1,
0,
0,
[
{
offset: 1,
color: "#105071",
},
{
offset: 0,
color: "#1892c2",
},
]
),
},
},
],
};
myChart.setOption(option);
echartsFocus(myChart, xData.length);
},
initlineChart2(xData, yData) {
let myChart = echarts.init(document.getElementById("lineChart"));
let num = 0;
yData.forEach((item) => {
num = num + Number(item);
});
let img =
"";
let data = [];
for (let i = 0; i < yData.length; i++) {
data.push({
value: yData[i],
name: xData[i],
itemStyle: {
normal: {
borderWidth: 1,
shadowBlur: 20,
},
},
});
}
var seriesOption = [
{
name: "",
type: "pie",
clockWise: false,
center: ["21%", "50%"],
radius: [70, 84],
hoverAnimation: false,
itemStyle: {
normal: {
label: {
show: false,
position: "outside",
color: "#ddd",
formatter: function (params) {
var percent = 0;
var total = 0;
for (var i = 0; i < yData.length; i++) {
total += yData[i];
}
percent = (
(params.value / total) *
100
).toFixed(0);
if (params.name !== "") {
return (
params.name +
"\n" +
"\n" +
"占百分比:" +
percent +
"%"
);
} else {
return "";
}
},
},
labelLine: {
length: 30,
length2: 100,
show: true,
color: "#00ffff",
},
},
},
data: data,
},
];
let option = {
title: [
{
text: "{name|" + num + "本" + "}",
top: "center",
left: "10%",
textStyle: {
rich: {
name: {
fontSize: 18,
fontWeight: "bold",
color: "#fff",
padding: [0, 0, 0, 0],
},
val: {
fontSize: 14,
fontWeight: "bold",
color: "#fff",
padding: [0, 0, 5, 0],
},
},
},
},
],
graphic: {
elements: [
{
type: "image",
z: 3,
style: {
image: img,
width: 110,
height: 110,
},
left: "8%",
top: "center",
position: [100, 100],
},
],
},
tooltip: {
show: true,
},
legend: {
show: true,
data: xData,
left: "50%",
width: "50%",
icon: "circle",
itemHeight: "12",
textStyle: {
color: "#FFF",
fontSize: "10px",
},
},
toolbox: {
show: false,
},
series: seriesOption,
};
myChart.setOption(option);
echartsFocus(myChart, xData.length);
},
queryContentInfo() {
this.$http
.post(
"/content/queryContentInfo",
this.common.request({
areaCode: "",
hasParent: "0",
page: 1,
typeCode: "TSGINFO",
pageSize: 10,
})
)
.then((res) => {
if (res.data.code === 200) {
this.queryContentInfoList = res.data.data.records;
}
});
},
queryRecommend() {
this.$http
.post(
"/content/queryContentInfo",
this.common.request({
areaCode: "",
hasParent: "0",
page: 1,
typeCode: "RECOMMEND",
pageSize: 10,
})
)
.then((res) => {
if (res.data.code === 200) {
this.bookList = res.data.data.records;
}
});
},
// 获取数据
initDataInfo(type, callback) {
let params = {
page: 1,
pageSize: 100,
areaCode: this.areaCode,
type,
};
this.$http
.post("screen/getScreenSurveyPage", this.common.request(params))
.then((res) => {
if (res.data.code === 200) {
let data = res.data.data.records;
callback(data);
}
});
},
// 查询视频
queryVideo() {
this.$http.post("/screen/getScreenVideoList", this.common.request({ areaCode: this.areaCode, type: "libaray", state: "0" }))
.then(res => {
if (res.data.code === 200) {
this.videoList = res.data.data.length && res.data.data
this.videoUrl = this.videoList[0].urlList
}
})
},
// 切换视频
changeVideo(e){
let index = e.target.dataset.index
let data = this.videoList[index]
this.videoUrl = data.urlList
},
// 打开资讯
openInfo(e, list){
let index = e.target.dataset.index
let data = list[index]
if (data.contentType == "3") {
this.common.openWindow(data);
} else {
this.info = data
this.imgTextModal = true
}
}
},
};
</script>
<style lang="less" scoped>
@import "../../styles/pbStyle.less";
.eb-container {
width: 1920px;
height: 1080px;
transform: scale(var(--scale)) translate(-50%, -50%);
transform-origin: 0 0;
position: absolute;
left: 50%;
top: 50%;
background-image: url("../../assets/largeScreen/page-bg.png");
background-size: 100%;
.main-container {
width: 1804px;
height: 920px;
position: absolute;
top: 100px;
left: 50%;
transform: translateX(-50%);
display: flex;
justify-content: space-between;
.left-box {
width: 458px;
height: 100%;
display: flex;
flex-direction: column;
justify-content: space-between;
.base-info {
width: 100%;
height: 250px;
.content-info {
.content-pub-style(100%, calc(100% - 44px));
padding: 20px;
display: grid;
grid-template-columns: 50% 50%;
grid-template-rows: 50% 50%;
.data-item {
// width: 188px;
// height: 53px;
// margin-bottom: 20px;
display: flex;
justify-content: center;
align-items: center;
img {
width: 60px;
height: 60px;
}
.content {
width: 130px;
height: 53px;
display: flex;
flex-direction: column;
justify-content: space-between;
margin-left: 10px;
span:nth-child(1) {
font-family: "PingFang SC";
font-size: 16px;
font-weight: 400;
color: #ffffff;
text-align: left;
}
span:nth-child(2) {
font-family: "DIN";
font-size: 28px;
font-weight: 400;
color: #ffffff;
text-align: left;
}
}
}
}
}
.activity-info {
width: 100%;
height: 300px;
.content-info {
.content-pub-style(100%, calc(100% - 44px));
}
}
.hot-rank {
width: 100%;
height: 350px;
.content-info {
.content-pub-style(100%, calc(100% - 44px));
.hot-scenic-info {
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
.hot-scenic-item {
display: flex;
align-items: center;
width: 430px;
height: 34px;
margin-bottom: 10px;
background-image: url("../../assets/screenView/hot.png");
background-size: 100%;
justify-content: space-between;
position: relative;
.ranking {
width: 93px;
height: 34px;
font-family: "YouSheBiaoTiHei";
font-size: 18px;
text-align: center;
color: #c3d4ea;
background-image: url("../../assets/screenView/NoDefault.png");
background-size: 100% 100%;
}
.scenicNmae {
font-family: "YouSheBiaoTiHei";
font-size: 16px;
font-weight: 400;
color: #ffffff;
width: 60%;
height: 100%;
display: flex;
justify-content: center;
align-items: center;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
position: absolute;
left: 100px;
}
.numvote {
font-family: "Furore";
font-size: 16px;
font-weight: 400;
text-align: right;
color: #ffffff;
padding-right: 15px;
}
}
.hot-scenic-item:nth-child(1) .ranking {
width: 93px;
height: 34px;
background-image: url("../../assets/screenView/No1.png");
background-size: 100% 100%;
}
.hot-scenic-item:nth-child(2) .ranking {
width: 93px;
height: 34px;
background-image: url("../../assets/screenView/No2.png");
background-size: 100% 100%;
}
.hot-scenic-item:nth-child(3) .ranking {
width: 93px;
height: 34px;
background-image: url("../../assets/screenView/No3.png");
background-size: 100% 100%;
}
}
}
}
}
.center-box {
width: 860px;
height: 100%;
display: flex;
flex-direction: column;
justify-content: space-between;
.video-box {
width: 100%;
height: 650px;
display: flex;
flex-direction: column;
justify-content: space-between;
.video-list {
width: 100%;
height: 150px;
.list {
height: 100%;
display: flex;
.video-item {
width: 260px;
height: 100%;
margin-right: 10px;
position: relative;
img {
width: 100%;
height: 150px;
border-radius: 8px;
}
.title {
position: absolute;
left: 0;
bottom: 5px;
width: 100%;
height: 30px;
border-radius: 0 0 8px 8px;
background-color: rgba(0, 0, 0, 0.2);
display: flex;
justify-content: center;
align-items: center;
color: #fff;
font-size: 14px;
}
}
}
}
}
.books {
width: 100%;
height: 250px;
display: flex;
flex-direction: column;
justify-content: space-between;
.content-info {
.content-pub-style(100%, calc(100% - 50px));
background: unset;
.list {
height: 100%;
display: flex;
.book-item {
width: 116px;
height: 100%;
margin-right: 10px;
display: flex;
flex-direction: column;
img {
width: 100%;
height: 180px;
border-radius: 4px;
}
.title {
width: 100%;
height: 20px;
display: flex;
justify-content: center;
align-items: center;
color: #fff;
font-size: 14px;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
}
}
}
}
}
.right-box {
width: 458px;
height: 100%;
display: flex;
flex-direction: column;
justify-content: space-between;
.borrowing-info {
width: 100%;
height: 250px;
.content-info {
.content-pub-style(100%, calc(100% - 44px));
padding: 20px;
display: grid;
grid-template-columns: 50% 50%;
grid-template-rows: 50% 50%;
.data-item {
// width: 188px;
// height: 53px;
// margin-bottom: 20px;
display: flex;
justify-content: center;
align-items: center;
img {
width: 60px;
height: 60px;
}
.content {
width: 130px;
height: 53px;
display: flex;
flex-direction: column;
justify-content: space-between;
margin-left: 10px;
span:nth-child(1) {
font-family: "PingFang SC";
font-size: 16px;
font-weight: 400;
color: #ffffff;
text-align: left;
}
span:nth-child(2) {
font-family: "DIN";
font-size: 28px;
font-weight: 400;
color: #ffffff;
text-align: left;
}
}
}
}
}
.classify-info {
width: 100%;
height: 300px;
.content-info {
.content-pub-style(100%, calc(100% - 44px));
padding: 10px;
}
}
.info-list {
width: 100%;
height: 350px;
.content-info {
.content-pub-style(100%, calc(100% - 44px));
padding: 10px;
color: #ffffff;
.list {
width: 100%;
display: flex;
flex-direction: column;
align-items: center;
.info-item {
width: 100%;
height: 120px;
position: relative;
margin-right: 20px;
.title {
display: -webkit-box; /* 必须结合的属性 ,将对象作为弹性伸缩盒子模型显示 。*/
-webkit-box-orient: vertical; /* 必须结合的属性 ,设置或检索伸缩盒对象的子元素的排列方式 。*/
text-overflow: ellipsis; /* 可以用来多行文本的情况下,用省略号“…”隐藏超出范围的文本 。*/
-webkit-line-clamp: 2;
overflow: hidden;
}
}
}
}
}
}
}
}
</style>