From b46bc2dba51a3885a68e4c58316b41a31ea16bb2 Mon Sep 17 00:00:00 2001
From: loulijun2021 <1694218219@qq.com>
Date: 星期二, 14 二月 2023 13:35:03 +0800
Subject: [PATCH] 1.存货档案修改
---
src/views/kb/cgdd.vue | 207 ++++++++++++++++++++++++++++++++++++++-------------
1 files changed, 153 insertions(+), 54 deletions(-)
diff --git a/src/views/kb/cgdd.vue b/src/views/kb/cgdd.vue
index ee9fd37..3c48a08 100644
--- a/src/views/kb/cgdd.vue
+++ b/src/views/kb/cgdd.vue
@@ -3,14 +3,19 @@
<div class="kb_dashboard">
<div class="kb_header">
<div class="flex_c_c" style="letter-spacing: 3px;margin-left: 1px;">
- 閲囪喘璁㈠崟璺熻釜绠$悊鐪嬫澘
+ 閲囪喘璺熻釜鐪嬫澘
</div>
<div class="kb_headerPic" />
<div class="kb_headTime">
<span>{{ headTime }}</span>
</div>
</div>
-
+ <MarqueeTips
+ :content="MarqueeTipsContent"
+ class="MarqueeTipsContentClass"
+ style="top:100px"
+ :speed="180"
+ />
<div class="kb_content">
<div class="kb_left">
<!-- 1-->
@@ -39,7 +44,7 @@
<!-- 2-->
<div class="kb_left_bottom kb_pd10">
<div class="kb_left_bottom_content">
- <div class="content_head kb_title_text">閲囪喘鍒拌揣璺熻釜</div>
+ <div class="content_head kb_title_text">閲囪喘鍒拌揣璺熻釜 <div style="margin-left: 30px">{{ number1 }} 鍗�</div></div>
<div class="content_body">
<el-table
ref="tableData"
@@ -58,12 +63,16 @@
<el-table-column
prop="PurchaseOrder"
label="閲囪喘璁㈠崟"
- width="163"
- />
+ width="203"
+ >
+ <template slot-scope="{row}">
+ <div class="ellipsis">{{ row.PurchaseOrder }}</div>
+ </template>
+ </el-table-column>
<el-table-column
prop="suppername"
label="渚涘簲鍟�"
- width="125"
+ width="163"
>
<template slot-scope="{row}">
<div v-if="row.suppername" class="ellipsis">{{ row.suppername }}</div>
@@ -73,37 +82,42 @@
<el-table-column
prop="username"
label="閲囪喘鍛�"
- width="68"
+ width="78"
>
<template slot-scope="{row}">
<div v-if="row.username">{{ row.username }}</div>
<div v-else>/</div>
</template>
</el-table-column>
- <el-table-column
- prop="partcode"
- label="浜у搧缂栫爜"
- width="108"
- />
+ <!-- <el-table-column-->
+ <!-- prop="partcode"-->
+ <!-- label="浜у搧缂栫爜"-->
+ <!-- width="108"-->
+ <!-- />-->
<el-table-column
prop="partname"
label="浜у搧鍚嶇О"
- width="155"
- />
- <el-table-column
- prop="partspec"
- label="瑙勬牸鍨嬪彿"
- width="130"
+ width="175"
>
<template slot-scope="{row}">
- <div v-if="row.partspec" class="ellipsis">{{ row.partspec }}</div>
- <div v-else>/</div>
+ <div v-if="row.partname" class="ellipsis">{{ row.partname }}</div>
+ <div v-else />
</template>
</el-table-column>
+ <!-- <el-table-column-->
+ <!-- prop="partspec"-->
+ <!-- label="瑙勬牸鍨嬪彿"-->
+ <!-- width="130"-->
+ <!-- >-->
+ <!-- <template slot-scope="{row}">-->
+ <!-- <div v-if="row.partspec" class="ellipsis">{{ row.partspec }}</div>-->
+ <!-- <div v-else>/</div>-->
+ <!-- </template>-->
+ <!-- </el-table-column>-->
<el-table-column
prop="quantity"
label="璁㈠崟鏁伴噺"
- width="74"
+ width="94"
>
<template slot-scope="{row}">
<div v-if="row.quantity">{{ parseFloat(row.quantity) }}</div>
@@ -113,7 +127,7 @@
<el-table-column
prop="checktype"
label="妫�楠岀姸鎬�"
- width="84"
+ width="94"
>
<template slot-scope="{row}">
<div v-if="row.checktype===null">鏈楠�</div>
@@ -123,12 +137,12 @@
<el-table-column
prop="checkuser"
label="妫�楠屼汉鍛�"
- width="84"
+ width="94"
/>
<el-table-column
prop="quantity1"
label="宸叉敹鏁伴噺"
- width="74"
+ width="94"
>
<template slot-scope="{row}">
<div v-if="row.quantity1">{{ parseFloat(row.quantity1) }}</div>
@@ -137,7 +151,7 @@
</el-table-column>
<el-table-column
label="鏈敹鏁伴噺"
- width="74"
+ width="94"
>
<template slot-scope="{row}">
<div v-if="row.quantity- row.quantity1">{{ parseFloat(row.quantity- row.quantity1) }}</div>
@@ -147,7 +161,7 @@
<el-table-column
prop="acceptDate"
label="棰勮浜ゆ湡"
- width="95"
+ width="115"
>
<template slot-scope="{row}">
<div v-if="row.acceptDate">{{ row.acceptDate.substring(0, 10) }}</div>
@@ -157,7 +171,7 @@
<el-table-column
prop="warning"
label="寤舵湡澶╂暟"
- width="84"
+ width="114"
>
<template slot-scope="{row}">
<div v-if="parseFloat(row.warning)<0" style="color: red">{{ Math.abs(parseFloat(row.warning)) }}</div>
@@ -183,15 +197,16 @@
:header-cell-style="headerCellStyle"
:cell-style="cellStyle"
:row-class-name="tableRowClassName"
- height="923"
+ height="865"
>
<el-table-column
type="index"
label="搴忓彿"
- width="90"
+ width="70"
>
<template slot-scope="{row}">
<div>NO.{{ row.index }}</div>
+ <!-- <div>NO.100</div>-->
</template>
</el-table-column>
<!-- <el-table-column-->
@@ -202,17 +217,26 @@
<el-table-column
prop="suppercode"
label="渚涘簲鍟嗙紪鐮�"
- width="170"
- />
+ width="130"
+ >
+ <template slot-scope="{row}">
+ <div v-if="row.suppercode" class="ellipsis">{{ row.suppercode }}</div>
+ <div v-else />
+ </template>
+ </el-table-column>
<el-table-column
prop="suppername"
- width="183"
+ width="283"
label="渚涘簲鍟嗗悕绉�"
- />
+ >
+ <template slot-scope="{row}">
+ <div class="ellipsis">{{ row.suppername }}</div>
+ </template>
+ </el-table-column>
<el-table-column
prop="cont"
- label="寤舵湡娆℃暟"
- width="90"
+ label="娆℃暟"
+ width="50"
/>
</el-table>
</div>
@@ -230,51 +254,113 @@
import { bar02, loadEcharts, pie01 } from '@/utils/myEcharts'
import * as echarts from 'echarts'
import { PurchaseLeftBottom, PurchaseLeftTop, PurchaseRight } from '@/api/dzkb'
+import MarqueeTips from 'vue-marquee-tips'
export default {
name: 'Index2',
+ components: {
+ MarqueeTips
+ },
data() {
return {
+ onLine: navigator.onLine, // 鐩戝惉缃戠粶鏄惁鍦ㄧ嚎
+
headTime: '',
purchaseLeftTopData: [],
tableData: [],
- tableDataRank: []
+ tableDataRank: [],
+ number1: '',
+
+ MarqueeTipsContent: '', // 鍏憡
+ speed: 100, // 鍏憡鎾斁鐨勯�熷害
+
+ PurchaseLeftTop: null,
+ PurchaseLeftBottom: null,
+ PurchaseRight: null
}
},
created() {
setInterval(this.getNowTime, 1000)
+
+ // 涓ゅ皬鏃剁湅鏉垮埛鏂颁竴娆�
+ setInterval(() => {
+ window.location.reload()
+ }, 1000 * 60 * 120)
},
mounted() {
- this.getPurchaseLeftTop()
- this.getPurchaseLeftBottom()
- this.getPurchaseRight()
+ window.addEventListener('online', this.updateOnlineStatus)
+ window.addEventListener('offline', this.updateOnlineStatus)
+ this.updateOnlineStatus({ type: this.onLine ? 'online' : 'offline', isFirst: true })
+ },
+ beforeDestroy() {
+ window.removeEventListener('online', this.updateOnlineStatus)
+ window.removeEventListener('offline', this.updateOnlineStatus)
},
methods: {
+ // 鏇存柊缃戠粶鐘舵��
+ updateOnlineStatus(e) {
+ if (e.isFirst) {
+ this.getPurchaseLeftTop()
+ this.getPurchaseLeftBottom()
+ this.getPurchaseRight()
+ // this.getMarqueeTipsContent()
+ } else {
+ const loading = this.$loading({
+ lock: true,
+ text: '鏂綉浜嗭紝姝e湪鎷煎懡鑱旂綉涓紝璇锋鏌ョ綉缁滄槸鍚︽甯�...',
+ spinner: 'el-icon-loading',
+ customClass: 'osloading',
+ background: 'rgba(0, 0, 0, 0.7)'
+ })
+ const { type } = e
+ this.onLine = type === 'online'
+ if (this.onLine) {
+ this.getPurchaseLeftTop()
+ this.getPurchaseLeftBottom()
+ this.getPurchaseRight()
+ // this.getMarqueeTipsContent()
+ loading.close()
+ this.$message.success('缃戠粶杩炴帴鎴愬姛锛�')
+ } else {
+ clearInterval(this.PurchaseLeftTop)
+ clearInterval(this.PurchaseLeftBottom)
+ clearInterval(this.PurchaseRight)
+ this.$message.error('缃戠粶鎺夌嚎锛岃鍏虫敞缃戠粶鐘舵�侊紒')
+ }
+ }
+ },
+
+ // 鑾峰彇鍏憡
+ getMarqueeTipsContent() {
+ // this.MarqueeTipsContent = '鍚勪綅鍛樺伐浠細鏍规嵁涓婄骇鐨勯�氱煡锛岀粨鍚堟垜浼佸疄闄呮儏鍐碉紝鐜板皢20xx骞寸殑鍏冩棪鏀惧亣閫氱煡濡備笅锛氫竴銆�1鏈�1鏃ヨ嚦1鏈�3鏃ユ斁鍋囪皟浼戯紝鍏�3澶┿��1鏈�4鏃ユ寮忎笂鐝�備簩銆佽妭鍋囨棩鏈熼棿锛屽悇鐝粍瑕佷弗鏍艰惤瀹炰笂绾х殑閲嶈鎸囩ず绮剧锛屾寜鐓т笂绾х殑鍏蜂綋瑕佹眰锛岃鐪熸姄濂借惤瀹炶妭鏃ユ湡闂村�肩彮澶囧嫟宸ヤ綔锛岀‘淇濊妭鏃ユ湡闂翠紒涓氬悇椤瑰伐浣滄甯歌繍杞�倄x浼佷笟20xx骞�12鏈�28鏃�'
+ // const spance = ' '.padStart(this.MarqueeTipsContent.length * 2, ' ')
+ // this.MarqueeTipsContent = this.MarqueeTipsContent + spance
+ // this.speed = this.MarqueeTipsContent.length / 10
+ },
getPurchaseLeftTop() {
PurchaseLeftTop().then(res => {
this.purchaseLeftTopData = res.data[0]
// console.log(this.purchaseLeftTopData)
})
- setInterval(() => {
+ this.PurchaseLeftTop = setInterval(() => {
PurchaseLeftTop().then(res => {
this.purchaseLeftTopData = res.data[0]
})
}, 1000 * 6)
},
-
getPurchaseLeftBottom() {
PurchaseLeftBottom().then(res => {
this.tableData = res.data
+ this.number1 = this.tableData.length
const divData = this.$refs.tableData.bodyWrapper
// 鎷垮埌鍏冪礌鍚庯紝瀵瑰厓绱犺繘琛屽畾鏃跺鍔犺窛绂婚《閮ㄨ窛绂伙紝瀹炵幇婊氬姩鏁堟灉(姝ら厤缃负姣�100姣绉诲姩1鍍忕礌)
- setInterval(() => {
+ this.PurchaseLeftBottom = setInterval(() => {
// 鍏冪礌鑷璺濈椤堕儴1鍍忕礌
- // divData.scrollTop += divData.scrollHeight / this.tableDataRank.length
divData.scrollTop += 1
// 鍒ゆ柇鍏冪礌鏄惁婊氬姩鍒板簳閮�(鍙楂樺害+璺濈椤堕儴=鏁翠釜楂樺害)
if (divData.clientHeight + divData.scrollTop === divData.scrollHeight) {
@@ -282,21 +368,23 @@
divData.scrollTop = 0
PurchaseLeftBottom().then(res => {
this.tableData = res.data
+ this.number1 = this.tableData.length
+ if (this.tableData.length > 14) {
+ clearInterval(this.PurchaseLeftBottom)
+ this.getPurchaseLeftBottom()
+ }
})
}
- }, this.tableData.length <= 14 ? 1000 * 6 : 100)
+ }, this.tableData.length <= 14 ? 1000 * 3 : 100)
})
},
-
getPurchaseRight() {
PurchaseRight().then(res => {
this.tableDataRank = res.data
-
const divData = this.$refs.tableDataRank.bodyWrapper
// 鎷垮埌鍏冪礌鍚庯紝瀵瑰厓绱犺繘琛屽畾鏃跺鍔犺窛绂婚《閮ㄨ窛绂伙紝瀹炵幇婊氬姩鏁堟灉(姝ら厤缃负姣�100姣绉诲姩1鍍忕礌)
- setInterval(() => {
+ this.PurchaseRight = setInterval(() => {
// 鍏冪礌鑷璺濈椤堕儴1鍍忕礌
- // divData.scrollTop += divData.scrollHeight / this.tableDataRank.length
divData.scrollTop += 1
// 鍒ゆ柇鍏冪礌鏄惁婊氬姩鍒板簳閮�(鍙楂樺害+璺濈椤堕儴=鏁翠釜楂樺害)
if (divData.clientHeight + divData.scrollTop === divData.scrollHeight) {
@@ -304,9 +392,13 @@
divData.scrollTop = 0
PurchaseRight().then(res => {
this.tableDataRank = res.data
+ if (this.tableDataRank.length > 21) {
+ clearInterval(this.PurchaseRight)
+ this.getPurchaseRight()
+ }
})
}
- }, this.tableDataRank.length <= 22 ? 1000 * 6 : 100)
+ }, this.tableDataRank.length <= 21 ? 1000 * 3 : 100)
})
},
@@ -383,11 +475,12 @@
height: 345px;
display: flex;
flex-direction: column;
- justify-content: space-around;
+ //justify-content: space-around;
+ justify-content: flex-end;
.kb_left_top_block {
width: 100%;
- height: 267px;
+ height: 237px;
display: flex;
//border: 1px solid rgba(255, 255, 255, 0.6);
justify-content: space-around;
@@ -413,10 +506,12 @@
.number {
margin-top: -50px;
font-size: 18px;
+ font-size: 20px;
}
.text{
margin-top: 50px;
+ font-size: 20px;
}
}
}
@@ -432,9 +527,10 @@
flex-direction: column;
.content_head {
+ display: flex;
color: #00ffff;
line-height: 20px;
- font-size: 18px;
+ //font-size: 18px;
margin-bottom: 10px;
margin-top: -10px;
}
@@ -451,7 +547,8 @@
height: 100%;
.kb_right_top {
- height: 964px;
+ height: 906px;
+ margin-top: 58px;
width: 100%;
.kb_right_top_content {
@@ -462,7 +559,7 @@
.content_head {
color: #00ffff;
line-height: 20px;
- font-size: 18px;
+ //font-size: 18px;
margin-bottom: 10px;
margin-top: -10px;
}
@@ -491,5 +588,7 @@
::v-deep .cell {
padding: 0 !important;
+ font-size: 18px;
}
+
</style>
--
Gitblit v1.9.3