Files
ebiz-h5/src/views/YB_APP/home.vue
liu.xiaofeng@ebiz-digits.com 8565c28d44 【银保app】修改首页样式
2022-11-28 18:31:53 +08:00

670 lines
24 KiB
Vue

<template>
<div class="public_container" :style="{paddingTop:marginTop+'px'}">
<div class="head">
<van-swipe :autoplay="3000" style="width: 100%;">
<van-swipe-item v-for="(item, index) in activity" :key="index" @touchstart="touchstart" @touchmove="touchmove" @touchend="touchend(item)">
<!-- <img :src="config.assetsUrl + item.img + '?v=' + thisGetTime" /> -->
<img :src="item.img">
</van-swipe-item>
</van-swipe>
</div>
<div class="iconPart1">
<van-notice-bar
:left-icon="png8"
:text='getCodeValue'
/>
</div>
<div class="top">
<div class="menu" v-for="(item, ind) in homePageIcon" :key="ind" @click="goDetail(item)">
<div class="menuImg">
<img :src="item.img">
</div>
<span class="menuName">{{ item.title }}</span>
</div>
</div>
<div class="echarts_con">
<div class="echarts_con_head">
<span class="echarts_con_head_tit">
<img src="@/assets/YB_APP/images/1.png">
<span class="echarts_con_head_tit_span">个人保费排行榜</span>
</span>
<span class="echarts_con_head_date">
{{calendarValue}}
</span>
</div>
<div class="echarts_con_buttonPart">
<span @click="changePersonalType('1')" v-if="activePersonalType == '1'" class="echarts_con_buttonPart_one">期交保费</span>
<span @click="changePersonalType('1')" v-if="activePersonalType == '2'" class="echarts_con_buttonPart_two">期交保费</span>
<span @click="changePersonalType('2')" v-if="activePersonalType == '2'" class="echarts_con_buttonPart_three">总保费</span>
<span @click="changePersonalType('2')" v-if="activePersonalType == '1'" class="echarts_con_buttonPart_four">总保费</span>
</div>
<div v-if="activePersonalType == '1' && ebizPremRankGMList.length != 0">
<div class="echarts_con_main">
<div class="echarts_con_main_part1">
<span class="echarts_con_main_part1_span1" style="background: #ffc71f;color: #fff;">{{ebizPremRankGMList[0].manageCom3.substring(0,2)}}</span>
<span class="echarts_con_main_part1_span2">{{ebizPremRankGMList[0].agentName}}</span>
</div>
<div class="mySelfEcharts_con">
<div class="ebizPremRankGMList0" ref="ebizPremRankGMList0"></div>
</div>
<div v-bind:class="{ 'colorThree': ebizPremRankGMList[0].prem <= 5, 'colorTwo': ebizPremRankGMList[0].prem > 5, 'colorOne': ebizPremRankGMList[0].prem >= 10 }" class="echarts_prem">{{ebizPremRankGMList[0].prem}}</div>
</div>
<div class="echarts_con_main">
<div class="echarts_con_main_part1">
<span class="echarts_con_main_part1_span1" style="background: #c0d4f4;color: #fff;">{{ebizPremRankGMList[1].manageCom3.substring(0,2)}}</span>
<span class="echarts_con_main_part1_span2">{{ebizPremRankGMList[1].agentName}}</span>
</div>
<div class="mySelfEcharts_con">
<div class="ebizPremRankGMList1" ref="ebizPremRankGMList1"></div>
</div>
<div v-bind:class="{ 'colorThree': ebizPremRankGMList[1].prem <= 5, 'colorTwo': ebizPremRankGMList[1].prem > 5, 'colorOne': ebizPremRankGMList[1].prem >= 10 }" class="echarts_prem">{{ebizPremRankGMList[1].prem}}</div>
</div>
<div class="echarts_con_main">
<div class="echarts_con_main_part1">
<span class="echarts_con_main_part1_span1" style="background: #c9b394;color: #fff;">{{ebizPremRankGMList[2].manageCom3.substring(0,2)}}</span>
<span class="echarts_con_main_part1_span2">{{ebizPremRankGMList[2].agentName}}</span>
</div>
<div class="mySelfEcharts_con">
<div class="ebizPremRankGMList2" ref="ebizPremRankGMList2"></div>
</div>
<div v-bind:class="{ 'colorThree': ebizPremRankGMList[2].prem <= 5, 'colorTwo': ebizPremRankGMList[2].prem > 5, 'colorOne': ebizPremRankGMList[2].prem >= 10 }" class="echarts_prem">{{ebizPremRankGMList[2].prem}}</div>
</div>
<div class="echarts_con_main">
<div class="echarts_con_main_part1">
<span class="echarts_con_main_part1_span1" style="background: #f6f6f6;color: #959595;">{{ebizPremRankGMList[3].manageCom3.substring(0,2)}}</span>
<span class="echarts_con_main_part1_span2">{{ebizPremRankGMList[3].agentName}}</span>
</div>
<div class="mySelfEcharts_con">
<div class="ebizPremRankGMList3" ref="ebizPremRankGMList3"></div>
</div>
<div v-bind:class="{ 'colorThree': ebizPremRankGMList[3].prem <= 5, 'colorTwo': ebizPremRankGMList[3].prem > 5, 'colorOne': ebizPremRankGMList[3].prem >= 10 }" class="echarts_prem">{{ebizPremRankGMList[3].prem}}</div>
</div>
<div class="echarts_con_main">
<div class="echarts_con_main_part1">
<span class="echarts_con_main_part1_span1" style="background: #f6f6f6;color: #959595;">{{ebizPremRankGMList[4].manageCom3.substring(0,2)}}</span>
<span class="echarts_con_main_part1_span2">{{ebizPremRankGMList[4].agentName}}</span>
</div>
<div class="mySelfEcharts_con">
<div class="ebizPremRankGMList4" ref="ebizPremRankGMList4"></div>
</div>
<div v-bind:class="{ 'colorThree': ebizPremRankGMList[4].prem <= 5, 'colorTwo': ebizPremRankGMList[4].prem > 5, 'colorOne': ebizPremRankGMList[4].prem >= 10 }" class="echarts_prem">{{ebizPremRankGMList[4].prem}}</div>
</div>
</div>
<div v-if="activePersonalType == '1' && ebizPremRankGMList.length == 0">
<img style="width:100%;" src="@/assets/YB_APP/images/7.png">
</div>
<div v-if="activePersonalType == '2' && ebizPremRankQJList.length != 0">
<div class="echarts_con_main">
<div class="echarts_con_main_part1">
<span class="echarts_con_main_part1_span1" style="background: #ffc71f;color: #fff;">{{ebizPremRankQJList[0].manageCom3.substring(0,2)}}</span>
<span class="echarts_con_main_part1_span2">{{ebizPremRankQJList[0].agentName}}</span>
</div>
<div class="mySelfEcharts_con">
<div class="ebizPremRankQJList0" ref="ebizPremRankQJList0"></div>
</div>
<div v-bind:class="{ 'colorThree': ebizPremRankQJList[0].prem <= 5, 'colorTwo': ebizPremRankQJList[0].prem > 5, 'colorOne': ebizPremRankQJList[0].prem >= 20 }" class="echarts_prem">{{ebizPremRankQJList[0].prem}}</div>
</div>
<div class="echarts_con_main">
<div class="echarts_con_main_part1">
<span class="echarts_con_main_part1_span1" style="background: #c0d4f4;color: #fff;">{{ebizPremRankQJList[1].manageCom3.substring(0,2)}}</span>
<span class="echarts_con_main_part1_span2">{{ebizPremRankQJList[1].agentName}}</span>
</div>
<div class="mySelfEcharts_con">
<div class="ebizPremRankQJList1" ref="ebizPremRankQJList1"></div>
</div>
<div v-bind:class="{ 'colorThree': ebizPremRankQJList[1].prem <= 5, 'colorTwo': ebizPremRankQJList[1].prem > 5, 'colorOne': ebizPremRankQJList[2].prem >= 20 }" class="echarts_prem">{{ebizPremRankQJList[1].prem}}</div>
</div>
<div class="echarts_con_main">
<div class="echarts_con_main_part1">
<span class="echarts_con_main_part1_span1" style="background: #c9b394;color: #fff;">{{ebizPremRankQJList[2].manageCom3.substring(0,2)}}</span>
<span class="echarts_con_main_part1_span2">{{ebizPremRankQJList[2].agentName}}</span>
</div>
<div class="mySelfEcharts_con">
<div class="ebizPremRankQJList2" ref="ebizPremRankQJList2"></div>
</div>
<div v-bind:class="{ 'colorThree': ebizPremRankQJList[2].prem <= 5, 'colorTwo': ebizPremRankQJList[2].prem > 5, 'colorOne': ebizPremRankQJList[2].prem >= 20 }" class="echarts_prem">{{ebizPremRankQJList[2].prem}}</div>
</div>
<div class="echarts_con_main">
<div class="echarts_con_main_part1">
<span class="echarts_con_main_part1_span1" style="background: #f6f6f6;color: #959595;">{{ebizPremRankQJList[3].manageCom3.substring(0,2)}}</span>
<span class="echarts_con_main_part1_span2">{{ebizPremRankQJList[3].agentName}}</span>
</div>
<div class="mySelfEcharts_con">
<div class="ebizPremRankQJList3" ref="ebizPremRankQJList3"></div>
</div>
<div v-bind:class="{ 'colorThree': ebizPremRankQJList[3].prem <= 5, 'colorTwo': ebizPremRankQJList[3].prem > 5, 'colorOne': ebizPremRankQJList[3].prem >= 20 }" class="echarts_prem">{{ebizPremRankQJList[3].prem}}</div>
</div>
<div class="echarts_con_main">
<div class="echarts_con_main_part1">
<span class="echarts_con_main_part1_span1" style="background: #f6f6f6;color: #959595;">{{ebizPremRankQJList[4].manageCom3.substring(0,2)}}</span>
<span class="echarts_con_main_part1_span2">{{ebizPremRankQJList[4].agentName}}</span>
</div>
<div class="mySelfEcharts_con">
<div class="ebizPremRankQJList4" ref="ebizPremRankQJList4"></div>
</div>
<div v-bind:class="{ 'colorThree': ebizPremRankQJList[4].prem <= 5, 'colorTwo': ebizPremRankQJList[4].prem > 5, 'colorOne': ebizPremRankQJList[4].prem >= 20 }" class="echarts_prem">{{ebizPremRankQJList[4].prem}}</div>
</div>
</div>
<div v-if="activePersonalType == '2' && ebizPremRankQJList.length == 0">
<img style="width:100%;" src="@/assets/YB_APP/images/7.png">
</div>
</div>
<div class="table_con">
<div class="table_con_main">
<span class="table_con_main_span">
<img src="@/assets/YB_APP/images/6.png">
<span class="table_con_main_span_name">实时出单榜</span>
</span>
<span style="color: #959595;">
数据截止时间 {{currentTime}}
</span>
</div>
<div class="tableDiv">
<table border="1" class="issueTable" style="width:100%;">
<tr style="background:#4d6cc4;width: 100%;">
<th style="width: 13%;">时间</th>
<th style="width: 13%;">分公司</th>
<th style="width: 13%;">机构</th>
<th style="width: 18%;">营业部</th>
<th style="width: 13%;">姓名</th>
<th style="width: 17%;">产品名称</th>
<th style="width: 13%;">保费</th>
</tr>
<tbody>
<tr v-if="tableData.length!=0" v-for="item in tableData">
<td>{{item.acceptTime}}</td>
<td>{{item.companyName}}</td>
<td>{{item.orgName}}</td>
<td>{{item.deptName}}</td>
<td>{{item.agentName}}</td>
<td>{{item.productName}}</td>
<td v-bind:class="{ 'colorThree': item.prem <= 5, 'colorTwo': item.prem > 5, 'colorOne': item.prem >= 20 }" style="white-space: nowrap;overflow: hidden;text-overflow: ellipsis;">{{item.prem}}</td>
</tr>
</tbody>
</table>
<div v-if="tableData.length == 0" class="noneDataDiv">
<img style="width:60%" src="@/assets/YB_APP/images/43.png">
<span class="noneDataDiv_span">暂无数据</span>
</div>
</div>
</div>
<van-popup v-model="calendarShow" position="bottom">
<van-datetime-picker
v-model="currentDate"
type="date"
title="选择日期"
:min-date="minDate"
:max-date="maxDate"
@cancel="handleCurrentDateCancel"
@confirm="handleCurrentDateConfirm"
/>
</van-popup>
</div>
</template>
<script>
import { homeConfigYB, getPremRankList, timelyContYB } from '@/api/YB_APP/index'
import { Swipe, SwipeItem, NoticeBar, Icon, Popup, DatetimePicker } from 'vant'
import config from '@/config'
import png8 from '@/assets/YB_APP/images/8.png';
import utils from '@/assets/js/utils/date-utils'
export default {
name: 'Home',
components: {
[Swipe.name]: Swipe,
[SwipeItem.name]: SwipeItem,
[NoticeBar.name]: NoticeBar,
[Icon.name]: Icon,
[Popup.name]: Popup,
},
data() {
return {
config,
currentDate:new Date(),
currentTime:'',
marginTop:'80',
getCodeValue:'',
png8,
activity: [],
homePageIcon:[],
ebizPremRankGMList:[],
ebizPremRankQJList:[],
tableData:[],
activePersonalType:'1',
calendarShow:false,
minDate: new Date(2019, 1, 1),
maxDate: new Date(2030, 12, 31),
calendarValue:'',
colorOne:false,
colorTwo:false,
colorThree:false,
thisValue:'12.9',
clickFlag:false,
}
},
mounted(){
this.currentTime = this.getNowDate()
let monthNum = new Date().getMonth()+1
let daysNum = new Date().getDate()
this.calendarValue = monthNum +'月'+daysNum+'日'
this.getHomeConfigYB()
this.getPremRankList()
this.getTimelyContYB()
this.setMarginTop()
if(this.thisValue >= 10){
this.colorOne = true
}
else if(this.thisValue >= 5 && this.thisValue < 10){
this.colorTwo = true
}
else if(this.thisValue < 5){
this.colorThree = true
}
},
methods:{
handleCurrentDateCancel() {
this.calendarShow = false
},
handleCurrentDateConfirm(e) {
this.calendarShow = false
// let titleTime = utils.formatDate(e, 'yyyy-MM')
// this.calendarValue = utils.formatDate(e, 'MM-dd')
let monthNum = utils.formatDate(e, 'MM')
let daysNum = utils.formatDate(e, 'dd')
this.calendarValue = monthNum+'月'+daysNum+'日'
this.getPremRankList()
},
getNowDate(){
let date = new Date();
let sign2 = ":";
let year = date.getFullYear() // 年
let month = date.getMonth() + 1; // 月
let day = date.getDate(); // 日
let hour = date.getHours(); // 时
let minutes = date.getMinutes(); // 分
let seconds = date.getSeconds() //秒
let weekArr = ['星期一', '星期二', '星期三', '星期四', '星期五', '星期六', '星期天'];
let week = weekArr[date.getDay()];
// 给一位数的数据前面加 “0”
if (month >= 1 && month <= 9) {
month = "0" + month;
}
if (day >= 0 && day <= 9) {
day = "0" + day;
}
if (hour >= 0 && hour <= 9) {
hour = "0" + hour;
}
if (minutes >= 0 && minutes <= 9) {
minutes = "0" + minutes;
}
if (seconds >= 0 && seconds <= 9) {
seconds = "0" + seconds;
}
return year + "-" + month + "-" + day + " " + hour + sign2 + minutes;
},
setMarginTop(){
EWebBridge.webCallAppInJs("top_bar_height").then(data => {
console.log(data,'top_bar_height')
if(data){
// 获取高度成功
let height = data.height
// 设置高度
this.marginTop = height + 10
}
})
},
getHomeConfigYB(){
let params = {
}
homeConfigYB(params).then(res=>{
if(res.result == 0){
this.activity = res.content.activity
if(res.content.getCodeValue.length!=0){
res.content.getCodeValue.forEach(item=>{
this.getCodeValue += item + ' '
})
}
this.homePageIcon = res.content.icon.homePageIcon
}else{
this.$toast(res.resultMessage)
}
})
},
getPremRankList(){
let params = {}
getPremRankList(params).then(res=>{
if(res.result == 0){
if(res.content.ebizPremRankGMList){
this.ebizPremRankGMList = res.content.ebizPremRankGMList
}
if(res.content.ebizPremRankQJList){
this.ebizPremRankQJList = res.content.ebizPremRankQJList
}
this.$nextTick(() => {
this.setAnimation()
})
}else{
this.$toast(res.resultMessage)
}
})
},
getTimelyContYB(){
let params = {}
timelyContYB(params).then(res=>{
if(res.result == 0){
this.tableData = res.content
}else{
this.$toast(res.resultMessage)
}
})
},
changePersonalType(type){
this.activePersonalType = type
this.$nextTick(() => {
this.setAnimation()
})
},
calendarOnConfirm(value){
this.calendarShow = false
this.calendarValue = `${value.getMonth() + 1}${value.getDate()}`
},
clickCalendar(){
this.calendarShow = true
},
setAnimation(){
if(this.activePersonalType == 1 && this.ebizPremRankGMList.length != 0){
this.ebizPremRankGMList.forEach((item,index)=>{
let ruleTrue1 = ` @keyframes changeWidth`+[index]+` { 0% {width: 0%;} 100% {width: `+item.prem/this.ebizPremRankGMList[0].prem*100+`%;} }`
let sheet1 = document.styleSheets[0]
sheet1.insertRule(ruleTrue1, 0)
this.$refs['ebizPremRankGMList'+index].style.width = parseInt(item.prem/this.ebizPremRankGMList[0].prem*100)+'%'
this.$refs['ebizPremRankGMList'+index].style.animation = "changeWidth"+index+" 2s forwards"
})
}
if(this.activePersonalType == 2 && this.ebizPremRankQJList.length != 0){
this.ebizPremRankQJList.forEach((item,index)=>{
let ruleTrue2 = ` @keyframes changeTotalWidth`+[index]+` { 0% {width: 0%;} 100% {width: `+item.prem/this.ebizPremRankQJList[0].prem*100+`%;} }`
let sheet2 = document.styleSheets[0]
sheet2.insertRule(ruleTrue2, 0)
this.$refs['ebizPremRankQJList'+index].style.width = parseInt(item.prem/this.ebizPremRankQJList[0].prem*100)+'%'
this.$refs['ebizPremRankQJList'+index].style.animation = "changeTotalWidth"+index+" 2s forwards"
})
}
},
goDetail(data){
console.log(data)
// if(data.route != null){
// window.location.href = 'http://www.baidu.com'
// }else{
// this.$toast('暂未开放')
// }
if(data.title == '业绩查询'){
this.$jump({
flag: 'h5',
extra: {
url: location.origin + '/#/YB_APP/performanceQuery',
},
routerInfo: {
path: '/YB_APP/performanceQuery',
},
})
}
if(data.title == '上头条'){
this.$jump({
flag: 'h5',
extra: {
url: location.origin + '/#/YB_APP/hitTheHeadlines',
},
routerInfo: {
path: '/YB_APP/hitTheHeadlines',
},
})
}
if(data.title == '续期管理'){
if(data.route){
let thisPath = data.route.substring(3)
this.$jump({
flag: 'h5',
extra: {
url: location.origin + data.route,
},
routerInfo: {
path: thisPath,
},
})
}
}
if(data.title == '保全中心'){
this.$toast('暂未开放')
}
},
touchstart(){
this.clickFlag = true
},
touchmove(){
this.clickFlag = false
},
touchend(data){
if(this.clickFlag){
let dataURL = JSON.parse(data.route).extra.url
if(dataURL){
let thisRoute = dataURL.substring(dataURL.lastIndexOf("/#")+2)
this.$jump({
flag: 'h5',
extra: {
url: location.origin + '/#' + thisRoute,
},
routerInfo: {
path: thisRoute,
},
})
}
}
}
},
}
</script>
<style lang="scss" scoped>
.public_container{
font-size: 12px;
height: 100vh;
width: 100vw;
background-image: url("../../assets/YB_APP/images/2.png");
background-repeat: no-repeat;
background-size: contain;
}
.head {
position: relative;
margin: 10px;border-radius: 5px;
/*box-shadow: 0px 5px 8px 0px #7a6fc1;*/
img {
width: 100%;
height: 100%;
border-radius: 5px;
}
/deep/ .van-swipe-item{
height: auto;
}
}
/deep/ .van-notice-bar{
border-radius: 5px;
}
.menuImg{
width:100%;display: flex;justify-content: center;margin-bottom: 5px;
/deep/ img{
width: 30px;
height: 30px;
}
}
.ebizPremRankGMList0,.ebizPremRankGMList1,.ebizPremRankGMList2,.ebizPremRankGMList3,.ebizPremRankGMList4,.ebizPremRankQJList0,.ebizPremRankQJList1,.ebizPremRankQJList2,.ebizPremRankQJList3,.ebizPremRankQJList4{
border-top-left-radius: 2px;
border-bottom-left-radius: 2px;
border-top-right-radius: 8px;
border-bottom-right-radius: 8px;
height: 14px;
background-image: linear-gradient(-90deg, #abbcff, #768bfe);
transition-timing-function: ease-out;
}
th{
height: 45px;
color: #fff;
}
table tbody tr:nth-child(odd){
background: #fff;
}
table tbody tr:nth-child(even){
background: #f9faff;
}
.issueTable{
border: 1px solid #ebedff;
border-collapse:collapse;
}
td{
text-align: center;
padding: 5px 0px;
line-height: 25px;
color: #7183b3;
border: 1px solid #ebedff;
border-collapse:collapse;
}
.colorThree{
color: #333;
}
.colorTwo{
color: #e1801d;
}
.colorOne{
color: #e51f14;
}
/deep/ .van-notice-bar{
background: linear-gradient(#f4f6ff,#fff);
color: #333;
letter-spacing: 1px;
}
/deep/ .van-icon__image{
width: 100%;
}
/deep/ .van-notice-bar__left-icon{
width: 50px;
}
/deep/ .van-notice-bar__wrap{
margin-left: 10px;
}
.noneDataDiv{
display:flex;justify-content:center;align-items:center;height:300px;position:relative;width:100%;
}
.noneDataDiv_span{
position:absolute;bottom:80px;left:calc(50% - 33px);
}
/deep/ .van-swipe-item{
img{
height:145px;
}
}
.iconPart1{
margin: 10px;border-radius: 5px;
}
.top{
display:flex;justify-content: space-between;margin: 10px;background: #fff;border-radius: 5px;align-items: center;padding: 15px;
}
.echarts_con{
margin: 10px;background: #fff;border-radius: 5px;padding: 15px;
}
.echarts_con_head{
display:flex;justify-content: space-between;align-items: center;
}
.echarts_con_head_tit{
display:flex;align-items: center;
}
.echarts_con_head_tit_span{
margin-left: 10px;font-size: 16px;font-weight: bold;
}
.echarts_con_head_date{
color: #2a409d;border:lpx solid #eee;padding: 6px 12px;border-radius: 15px;background: #f4f6ff;cursor: pointer;font-weight: bold;
}
.echarts_con_buttonPart{
margin:15px 0px;
}
.echarts_con_buttonPart_one{
padding: 8px;border-radius: 5px;background: #f6f6f6;font-weight: bold;cursor: pointer;
}
.echarts_con_buttonPart_two{
padding: 8px;border-radius: 5px;color: #8e8e8e;cursor: pointer;
}
.echarts_con_buttonPart_three{
padding: 8px;border-radius: 5px;background: #f6f6f6;margin-left: 10px;font-weight: bold;cursor: pointer;
}
.echarts_con_buttonPart_four{
padding: 8px;border-radius: 5px;color: #8e8e8e;margin-left: 10px;cursor: pointer;
}
.echarts_con_main{
display: flex;align-items: center;font-size:12px;
}
.echarts_con_main_part1{
width:100px;
}
.echarts_con_main_part1_span1{
padding: 3px 8px;border-radius: 10px;
}
.mySelfEcharts_con{
width:calc(100% - 150px);
margin: 10px 0px;
display: flex;
background:#f4f6ff;
border-top-left-radius: 2px;
border-bottom-left-radius: 2px;
border-top-right-radius: 8px;
border-bottom-right-radius: 8px;
}
.echarts_prem{
width: 60px;text-align: right;font-weight: bold;
}
.echarts_con_main_part1_span2{
margin-left:8px;font-weight: bold;color: #333;
}
.table_con{
margin: 10px;background: #fff;border-radius: 5px;padding: 15px;margin-bottom: 20px;
}
.table_con_main{
display:flex;justify-content: space-between;align-items: center;
}
.table_con_main_span{
display:flex;align-items: center;
}
.table_con_main_span_name{
margin-left: 10px;font-size: 16px;font-weight: bold;
}
.tableDiv{
margin-top: 15px;border-radius: 10px;overflow: hidden;width: 100%;
}
</style>