Browse Source

公共样式修改

pull/27/head
zq 5 months ago
parent
commit
de09420b18
  1. 98
      src/components/GlobalLoading1.vue
  2. 67
      src/components/GuipTable.vue
  3. 26
      src/style/theme/common.scss

98
src/components/GlobalLoading1.vue

@ -0,0 +1,98 @@
<template>
<div class="content-loading-overlay" v-if="isLoading">
<div class="loading-content">
<div ref="animationContainer" class="animation-container"></div>
</div>
</div>
<div v-else>
<slot></slot>
</div>
</template>
<script>
import lottie from 'lottie-web'
import { mapState } from 'vuex'
import defaultAnimation from '@/assets/loadingAni.json' // JSON
export default {
name: 'Loading',
data() {
return {
anim: null
}
},
computed: {
...mapState(['isLoading', 'loadingText'])
},
watch: {
isLoading(newVal) {
if (newVal) {
this.$nextTick(()=>{
this.playAnimation()
})
} else {
this.stopAnimation()
}
}
},
mounted() {
if (this.isLoading) {
this.playAnimation()
}
},
beforeDestroy() {
this.stopAnimation()
},
methods: {
playAnimation() {
this.anim = lottie.loadAnimation({
container: this.$refs.animationContainer,
renderer: 'svg',
loop: true,
autoplay: true,
animationData: defaultAnimation // JSON
})
if (this.anim) {
this.anim.play()
}
},
stopAnimation() {
if (this.anim) {
this.anim.stop()
}
}
}
}
</script>
<style scoped>
.content-loading-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(255, 255, 255, 0.8);
z-index: 1000;
/* 确保高于内容 */
display: flex;
justify-content: center;
align-items: center;
}
.loading-content {
text-align: center;
}
.animation-container {
width: 180px;
height: 180px;
margin: 0 auto;
}
.loading-text {
margin-top: 20px;
font-size: 16px;
color: #333;
}
</style>

67
src/components/GuipTable.vue

@ -1,21 +1,24 @@
<template> <template>
<el-table ref="guiptable" :data="tableData" height="250" :border="border" @selection-change="handleSelectionChange" <global-loading>
:style="{ width: width ? width : '100%' }"> <el-table ref="guiptable" :data="tableData" :border="border" @selection-change="handleSelectionChange"
:style="{ width: width ? width : '100%', height: height ? height : '100%' }" v-loading="loading">
<!-- 多选 --> <!-- 多选 -->
<template v-if="multiple"> <template v-if="multiple">
<el-table-column type="selection" width="55"> <el-table-column type="selection" width="55">
</el-table-column> </el-table-column>
</template> </template>
<!-- 自定义header --> <!-- 自定义header -->
<template v-if="autoColumn"> <slot></slot>
<slot name="header"></slot> <!-- <template v-if="autoColumn">
</template> <slot name="headerTop"></slot>
</template> -->
<!-- 通过json数据遍历渲染 --> <!-- 通过json数据遍历渲染 -->
<template v-if="columns"> <template v-if="columns">
<el-table-column v-for="column in columns" :key="column.prop" :prop="column.prop" :label="column.label" <el-table-column v-for="column in columns" :key="column.prop" :prop="column.prop" :label="column.label"
:width="column.width"> :width="column.width">
<template #default="{ row }" v-if="column.popover"> <template #default="{ row }" v-if="column.popover">
<el-popover :visible="row[`popoverVisible_${column.prop}`]" class="tablePopover" placement="top" trigger="click"> <el-popover :visible="row[`popoverVisible_${column.prop}`]" class="tablePopover" placement="top"
trigger="click">
<!-- 自定义内容插槽 --> <!-- 自定义内容插槽 -->
<slot :name="`popover-content-${column.prop}`" :row="row" :column="column"> <slot :name="`popover-content-${column.prop}`" :row="row" :column="column">
<div> <div>
@ -37,27 +40,40 @@
</el-table-column> </el-table-column>
</template> </template>
<template #empty>
<!-- <div v-if="loading">
<i class="el-icon-loading"></i>
<span>数据加载中...</span>
</div> -->
<!-- <div class="custom-empty">
<img src="@/assets/table_empty.png" alt="无数据" class="empty-image">
<p class="empty-text">暂无数据</p>
</div> -->
<el-empty :image="emptyImg"></el-empty>
</template>
</el-table> </el-table>
</global-loading>
</template> </template>
<script> <script>
import GuipButton from '@/components/GuipButton.vue'; import GuipButton from '@/components/GuipButton.vue';
import GlobalLoading from '@/components/GlobalLoading1.vue'
export default { export default {
name: 'GuipTextarea', name: 'GuipTextarea',
props: ['tableData', 'width', 'autoColumn', 'columns', 'border', 'multiple'], props: ['tableData', 'loading', 'width', 'height', 'autoColumn', 'columns', 'border', 'multiple'],
data() { data() {
return { return {
emptyImg:require('@/assets/table_empty.png')
// loading:false
} }
}, },
components: { components: {
GuipButton GuipButton,
GlobalLoading
}, },
mounted(){ mounted() {
}, },
methods: { methods: {
handleSelectionChange(row) { handleSelectionChange(row) {
@ -83,4 +99,29 @@ export default {
} }
</script> </script>
<style scoped> <style scoped>
.custom-empty {
text-align: center;
display: flex;
flex-direction: column;
align-items: center;
}
.empty-image {
width: 160px;
height: 160px;
}
.empty-text {
color: #626573;
letter-spacing: 0.08em;
height: 18px;
line-height: 18px;
}
.el-empty{
padding: 0;
}
::v-deep .el-empty__description{
line-height: 20px;
margin-top: 0;
}
</style> </style>

26
src/style/theme/common.scss

@ -638,6 +638,20 @@ body {
// table start // table start
.el-table{
min-height: 258px;
th,td{
font-size: 14px;
font-weight: normal;
letter-spacing: 0.08em;
color: #1E2226;
height: 56px;
padding: 18px 16px !important;
box-sizing: border-box !important;
}
td{
}
}
.el-table--enable-row-hover .el-table__body tr:hover>td.el-table__cell { .el-table--enable-row-hover .el-table__body tr:hover>td.el-table__cell {
background-color: #F6F7FA; background-color: #F6F7FA;
} }
@ -674,12 +688,22 @@ body {
padding-left: 16px; padding-left: 16px;
padding-right: 16px; padding-right: 16px;
} }
.el-table .el-form-item { .el-table .el-form-item {
margin-bottom: 0; margin-bottom: 0;
} }
// 表格行内小图标 默认隐藏
.svg-icon-wrapper{
display: none !important;
}
//划过时 显示
.el-table__row:hover{
.svg-icon-wrapper{
display: block !important;
}
}
// table end // table end
.el-pagination { .el-pagination {
margin-top: 16px; margin-top: 16px;
display: flex; display: flex;

Loading…
Cancel
Save