From 6f2e1f380b4bfdcc43dcac731226ccab49e17706 Mon Sep 17 00:00:00 2001 From: Mr.Zhang <710666463@qq.com> Date: 星期四, 24 八月 2023 13:42:49 +0800 Subject: [PATCH] 大屏 --- screen_standard/src/components/AppLayout.vue | 128 ++++++++++++++++++++++++++++++------------ 1 files changed, 91 insertions(+), 37 deletions(-) diff --git a/screen_standard/src/components/AppLayout.vue b/screen_standard/src/components/AppLayout.vue index 117357e..fb9771d 100644 --- a/screen_standard/src/components/AppLayout.vue +++ b/screen_standard/src/components/AppLayout.vue @@ -2,7 +2,7 @@ <div class="content"> <div class="header"> <div class="header-item" style="font-size: 20px;"> - <el-dropdown trigger="click"> + <el-dropdown trigger="click" v-if="route.name=='home'"> <div class="eare-title"> {{ tempCom.name}} <div class="right-icon"> @@ -15,9 +15,11 @@ </el-dropdown-menu> </template> </el-dropdown> - + + <img v-else src="@/assets/img/btn_back@2x.png" style="width: 108px;height: 34px; margin-top: 14px;" @click="back"> </div> - <div class="title">DM浜戝伐鍘傝溅闂村ぇ灞�</div> + + <div class="title">{{ title }}</div> <div class="header-item right"> <img v-if="!isFull" src="@/assets/img/ic_fullscreen@2x.png" class="full-ic" @click="fullChange"> @@ -27,10 +29,9 @@ <div class="time">{{ tempDate.time }}</div> <div class="day">{{ `${tempDate.date} ${tempDate.day}` }}</div> </div> - <img src="@/assets/img/title_line@2x.png" class="right-line" alt=""> + <!-- <img src="@/assets/img/title_line@2x.png" class="right-line" alt=""> --> </div> </div> - <!-- 'background': `url(${getAssets(item.bgImg)})`, --> <div class="num-list"> <div v-for="(item, index) in layoutList" @@ -41,21 +42,26 @@ <img :src="getAssets(item.logo)" alt=""> <div class="item-right"> <div class="item-title">{{ item.name }}</div> - <div class="num-value">1</div> + <div class="num-value">{{ countList[index] }}</div> </div> - </div> </div> - <RouterView /> + <KeepAlive> + <router-view></router-view> + </KeepAlive> </div> </template> <script setup> import { getAssets } from '@/utils' -import { reactive, toRefs, onMounted } from 'vue'; -import { RouterView } from 'vue-router' - +import { getDepartmentList } from '@/utils/api.js' +import { reactive, toRefs, onMounted, computed } from 'vue'; +import { useCounterStore } from '@/stores/counter.js' +import { useRoute, useRouter } from 'vue-router' +const enterprise = useCounterStore() +const route = useRoute() +const router = useRouter() const layoutList = [ { bgImg: 'bg_zhixingzhong@2x.png', name: '鎵ц涓鍒掓暟(涓�)', logo: 'ic_zhixingzhong@2x.png' }, { bgImg: 'bg_yanqijihua@2x.png', name: '寤舵湡璁″垝鏁�(涓�)', logo: 'ic_yanqijihua@2x.png' }, @@ -63,6 +69,24 @@ { bgImg: 'bg_jinrishebei@2x.png', name: '浠婃棩鐢熶骇璁惧(鍙�)', logo: 'ic_jinrishebei@2x.png' }, { bgImg: 'bg_jinribuliang@2x.png', name: '浠婃棩涓嶈壇鍝佺巼(%)', logo: 'ic_jinribuliang@2x.png' }, ] +const ingNum = computed(() => { + return enterprise.ingNum +}) +const delayNum = computed(() => { + return enterprise.delayNum +}) +const prouserNum = computed(() => { + return enterprise.prouserNum +}) +const deviceNum = computed(() => { + return enterprise.deviceNum +}) +const unqualifiedRate = computed(() => { + return +enterprise.unqualifiedRate.toFixed(2) +}) +const title = computed(() => { + return enterprise.procedureName ? `${enterprise.procedureName}宸ュ簭鏁版嵁鐪嬫澘` : 'DM浜戝伐鍘傝溅闂村ぇ灞�' +}) const data = reactive({ tempCom: { name: '璞嗙背绉戞妧' }, isFull: false, @@ -70,27 +94,30 @@ time: '', date: '', day: '' - } + }, + comList: [], + countList: [ + ingNum||0, + delayNum||0, + prouserNum||0, + deviceNum||0, + unqualifiedRate||0 + ] }) -let { tempCom, isFull, tempDate } = toRefs(data) -const comList = [ - {name: '璞嗙背'}, - {name: '澶х背'}, - {name: '灏忕背'}, - {name: '榛勭背'}, -] +let { tempCom, isFull, tempDate, comList, countList } = toRefs(data) const selectCom = (item, index) => { data.tempCom = item + enterprise.setDepartId(data.tempCom.id) } const fullChange = () => { - data.isFull = !data.isFull + // data.isFull = !data.isFull let element = document.documentElement; - if (data.isFull) { // 鍏ㄥ睆 + if (!data.isFull) { // 鍏ㄥ睆 if (element.requestFullscreen) { element.requestFullscreen(); } else if (element.webkitRequestFullScreen) { @@ -112,41 +139,67 @@ document.msExitFullscreen(); } } - // data.isFull = !data.isFull + data.isFull = !data.isFull } onMounted(() => { - - const week = ['鏄熸湡涓�', '鏄熸湡浜�', '鏄熸湡涓�', '鏄熸湡鍥�', '鏄熸湡浜�', '鏄熸湡鍏�', '鏄熸湡鏃�',] + enterprise.setDepartId() + getDepartmentList(enterprise.companyId) + .then(res => { + data.comList = res + data.tempCom = res[0] + enterprise.setDepartId(data.tempCom.id) + }) + .catch(err => {}) + fullChange() + const week = ['鏄熸湡涓�', '鏄熸湡浜�', '鏄熸湡涓�', '鏄熸湡鍥�', '鏄熸湡浜�', '鏄熸湡鍏�', '鏄熸湡鏃�'] setInterval(() => { - let date = new Date() + let tempDate = new Date() + let month = tempDate.getMonth()+1 + let day = tempDate.getDate() + let hours = tempDate.getHours() + let minute = tempDate.getMinutes() + let seconds = tempDate.getSeconds() data.tempDate = { - time: `${date.getHours()}:${date.getMinutes()}:${date.getSeconds()}`, - date: `${date.getFullYear()}/${date.getMonth()+1}/${date.getDate()}`, - day: week[date.getDay()-1] + time: `${hours<10?`0${hours}`:hours}:${minute<10?`0${minute}`:minute}:${seconds<10?`0${seconds}`:seconds}`, + date: `${tempDate.getFullYear()}/${month<10?`0${month}`:month}/${day<10?`0${day}`:day}`, + day: week[tempDate.getDay()-1] } }, 1000) - // console.log(date.getDay()); - }) +const back = () => { + enterprise.setProcedureName('') + router.go(-1) +} </script> <style lang="scss" scoped> .content { - background-image: url('@/assets/img/bg@2x.png'); + background-image: url('@/assets/img/bg.png'); background-position: center; background-size: 100% 100%; background-repeat: no-repeat; + + // width: 1920px; + // height: 1080px; width: 100%; height: 100%; - padding: 30px; + padding: 20px 30px; overflow-y: scroll; + scrollbar-width:none; + -ms-overflow-style:none; + &::-webkit-scrollbar{ + width: 0; + } + display: flex; + flex-direction: column; + box-sizing: border-box; .header { background-image: url('@/assets/img/bg_maintitle@2x.png'); - background-size: 100% 74px; + background-size: 100% 70px; width: 100%; - height: 74px; + height: 70px; display: flex; padding-top: 1px; padding-left: 20px; @@ -214,14 +267,15 @@ } } .num-list { - margin-top: 24px; - margin-bottom: 27px; + margin-top: 20px; + margin-bottom: 20px; display: flex; justify-content: space-between; - height: 88px; + height: 80px; color: white; .num-item { width: calc(25% - 50px); + height: 80px; background-size: 100% 100%; margin-right: 25px; padding-left: 30px; -- Gitblit v1.9.3