refactor
This commit is contained in:
		| @@ -1,93 +0,0 @@ | ||||
| <template> | ||||
|   <div :class="className" :style="{height:height,width:width}"></div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import echarts from 'echarts' | ||||
| require('echarts/theme/macarons') // echarts 主题 | ||||
|  | ||||
| const animationDuration = 3000 | ||||
| export default { | ||||
|   props: { | ||||
|     className: { | ||||
|       type: String, | ||||
|       default: 'chart' | ||||
|     }, | ||||
|     width: { | ||||
|       type: String, | ||||
|       default: '100%' | ||||
|     }, | ||||
|     height: { | ||||
|       type: String, | ||||
|       default: '300px' | ||||
|     } | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       chart: null | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
|     this.initChart() | ||||
|   }, | ||||
|   beforeDestroy() { | ||||
|     if (!this.chart) { | ||||
|       return | ||||
|     } | ||||
|     this.chart.dispose() | ||||
|     this.chart = null | ||||
|   }, | ||||
|   methods: { | ||||
|     initChart() { | ||||
|       this.chart = echarts.init(this.$el, 'macarons') | ||||
|  | ||||
|       this.chart.setOption({ | ||||
|         tooltip: { | ||||
|           trigger: 'axis', | ||||
|           axisPointer: { // 坐标轴指示器,坐标轴触发有效 | ||||
|             type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' | ||||
|           } | ||||
|         }, | ||||
|         grid: { | ||||
|           left: '3%', | ||||
|           right: '4%', | ||||
|           bottom: '3%', | ||||
|           containLabel: true | ||||
|         }, | ||||
|         xAxis: [{ | ||||
|           type: 'category', | ||||
|           data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'], | ||||
|           axisTick: { | ||||
|             alignWithLabel: true | ||||
|           } | ||||
|         }], | ||||
|         yAxis: [{ | ||||
|           type: 'value' | ||||
|         }], | ||||
|         series: [{ | ||||
|           name: 'pageA', | ||||
|           type: 'bar', | ||||
|           stack: 'vistors', | ||||
|           barWidth: '60%', | ||||
|           data: [79, 52, 200, 334, 390, 330, 220], | ||||
|           animationDuration | ||||
|         }, { | ||||
|           name: 'pageB', | ||||
|           type: 'bar', | ||||
|           stack: 'vistors', | ||||
|           barWidth: '60%', | ||||
|           data: [80, 52, 200, 334, 390, 330, 220], | ||||
|           animationDuration | ||||
|         }, { | ||||
|           name: 'pageC', | ||||
|           type: 'bar', | ||||
|           stack: 'vistors', | ||||
|           barWidth: '60%', | ||||
|           data: [30, 52, 200, 334, 390, 330, 220], | ||||
|           animationDuration | ||||
|         }] | ||||
|       }) | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
| @@ -1,100 +1,32 @@ | ||||
| <template> | ||||
| 	<div class="dashboard-editor-container"> | ||||
| 		<a href="https://github.com/PanJiaChen/vue-element-admin" target="_blank" class="github-corner" aria-label="View source on Github"> | ||||
| 			<svg width="80" height="80" viewBox="0 0 250 250" style="fill:#4AB7BD; color:#fff; position: absolute; top: 50px; border: 0; right: 0;" | ||||
| 			  aria-hidden="true"> | ||||
| 				<path d="M0,0 L115,115 L130,115 L142,142 L250,250 L250,0 Z"></path> | ||||
| 				<path d="M128.3,109.0 C113.8,99.7 119.0,89.6 119.0,89.6 C122.0,82.7 120.5,78.6 120.5,78.6 C119.2,72.0 123.4,76.3 123.4,76.3 C127.3,80.9 125.5,87.3 125.5,87.3 C122.9,97.6 130.6,101.9 134.4,103.2" | ||||
| 				  fill="currentColor" style="transform-origin: 130px 106px;" class="octo-arm"></path> | ||||
| 				<path d="M115.0,115.0 C114.9,115.1 118.7,116.5 119.8,115.4 L133.7,101.6 C136.9,99.2 139.9,98.4 142.2,98.6 C133.8,88.0 127.5,74.4 143.8,58.0 C148.5,53.4 154.0,51.2 159.7,51.0 C160.3,49.4 163.2,43.6 171.4,40.1 C171.4,40.1 176.1,42.5 178.8,56.2 C183.1,58.6 187.2,61.8 190.9,65.4 C194.5,69.0 197.7,73.2 200.1,77.6 C213.8,80.2 216.3,84.9 216.3,84.9 C212.7,93.1 206.9,96.0 205.4,96.6 C205.1,102.4 203.0,107.8 198.3,112.5 C181.9,128.9 168.3,122.5 157.7,114.1 C157.9,116.9 156.7,120.9 152.7,124.9 L141.0,136.5 C139.8,137.7 141.6,141.9 141.8,141.8 Z" | ||||
| 				  fill="currentColor" class="octo-body"></path> | ||||
| 			</svg> | ||||
| 		</a> | ||||
| 		<el-row class="btn-group"> | ||||
| 			<el-col :span="4" class='text-center'> | ||||
| 				<router-link class="pan-btn blue-btn" to="/components/index">Components</router-link> | ||||
| 			</el-col> | ||||
| 			<el-col :span="4" class='text-center'> | ||||
| 				<router-link class="pan-btn light-blue-btn" to="/charts/index">Charts</router-link> | ||||
| 			</el-col> | ||||
| 			<el-col :span="4" class='text-center'> | ||||
| 				<router-link class="pan-btn pink-btn" to="/excel/download">Excel</router-link> | ||||
| 			</el-col> | ||||
| 			<el-col :span="4" class='text-center'> | ||||
| 				<router-link class="pan-btn green-btn" to="/example/table/table">Table</router-link> | ||||
| 			</el-col> | ||||
| 			<el-col :span="4" class='text-center'> | ||||
| 				<router-link class="pan-btn tiffany-btn" to="/example/form/edit">Form</router-link> | ||||
| 			</el-col> | ||||
| 			<el-col :span="4" class='text-center'> | ||||
| 				<router-link class="pan-btn yellow-btn" to="/theme/index">Theme</router-link> | ||||
| 			</el-col> | ||||
| 		</el-row> | ||||
|  | ||||
| 		<el-row> | ||||
| 			<el-col :span="6"> | ||||
| 				<el-card class="box-card"> | ||||
| 					<div slot="header" class="box-card-header"> | ||||
| 						<pan-thumb class="panThumb" :image="avatar"> 你的权限: | ||||
| 							<span class="pan-info-roles" :key='item' v-for="item in roles">{{item}}</span> | ||||
| 						</pan-thumb> | ||||
| 					</div> | ||||
| 					<span class="display_name">{{name}}</span> | ||||
| 					<div class="info-item"> | ||||
| 						<countTo class="info-item-num" :startVal='0' :endVal='statisticsData.article_count' :duration='3400'></countTo> | ||||
| 						<span class="info-item-text">文章</span> | ||||
| 						<icon-svg icon-class="a" class="dashboard-editor-icon"></icon-svg> | ||||
| 					</div> | ||||
| 					<div class="info-item"> | ||||
| 						<countTo class="info-item-num" :startVal='0' :endVal='statisticsData.pageviews_count' :duration='3600'></countTo> | ||||
| 						<span class="info-item-text">浏览量</span> | ||||
| 						<icon-svg icon-class="b" class="dashboard-editor-icon"></icon-svg> | ||||
| 					</div> | ||||
| 				</el-card> | ||||
| 			</el-col> | ||||
|  | ||||
| 			<el-col :span="8"> | ||||
| 				<pie-chart></pie-chart> | ||||
| 			</el-col> | ||||
|  | ||||
| 			<el-col :span="10"> | ||||
| 				<bar-chart></bar-chart> | ||||
| 			</el-col> | ||||
| 		</el-row> | ||||
|  | ||||
| 		<el-row :gutter="20"> | ||||
| 			<el-col :span="15"> | ||||
| 				<line-chart></line-chart> | ||||
| 			</el-col> | ||||
| 			<el-col :span="9"> | ||||
| 				<todo-list></todo-list> | ||||
| 			</el-col> | ||||
| 		</el-row> | ||||
|  | ||||
| 	</div> | ||||
|   <div class="dashboard-editor-container"> | ||||
|     <div class=" clearfix"> | ||||
|       <pan-thumb style="float: left" :image="avatar"> 你的权限: | ||||
|         <span class="pan-info-roles" :key='item' v-for="item in roles">{{item}}</span> | ||||
|       </pan-thumb> | ||||
|       <github></github> | ||||
|       <div class="info-container"> | ||||
|         <span class="display_name">{{name}}</span> | ||||
|         <span style='font-size:20px;padding-top:20px;display:inline-block;'>普通编辑dashboard</span> | ||||
|       </div> | ||||
|     </div> | ||||
|     <div> | ||||
|       <img class='emptyGif' :src="emptyGif"> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import { mapGetters } from 'vuex' | ||||
| import panThumb from 'components/PanThumb' | ||||
| import pieChart from './pieChart' | ||||
| import barChart from './barChart' | ||||
| import lineChart from './lineChart' | ||||
| import countTo from 'vue-count-to' | ||||
| import todoList from 'components/TodoList' | ||||
| import PanThumb from '@/components/PanThumb' | ||||
| import Github from '@/components/Github' | ||||
|  | ||||
| export default { | ||||
|   name: 'dashboard-editor', | ||||
|   components: { panThumb, countTo, pieChart, lineChart, barChart, todoList }, | ||||
|   components: { PanThumb, Github }, | ||||
|   data() { | ||||
|     return { | ||||
|       statisticsData: { | ||||
|         article_count: 1024, | ||||
|         comment_count: 102400, | ||||
|         latest_article: [], | ||||
|         month_article_count: 28, | ||||
|         pageviews_count: 1024 | ||||
|       } | ||||
|       emptyGif: 'https://wpimg.wallstcn.com/0e03b7da-db9e-4819-ba10-9016ddfdaed3' | ||||
|     } | ||||
|   }, | ||||
|   computed: { | ||||
| @@ -108,35 +40,35 @@ export default { | ||||
| </script> | ||||
|  | ||||
| <style rel="stylesheet/scss" lang="scss" scoped> | ||||
| .dashboard-editor-container { | ||||
|     margin: 30px; | ||||
|     .btn-group { | ||||
|         margin-bottom: 60px; | ||||
|     } | ||||
|     .box-card-header { | ||||
|         position: relative; | ||||
|         height: 160px; | ||||
|     } | ||||
|     .panThumb { | ||||
|         z-index: 100; | ||||
|         height: 150px; | ||||
|         width: 150px; | ||||
|         position: absolute; | ||||
|         left: 0px; | ||||
|         right: 0px; | ||||
|         margin: auto; | ||||
|     } | ||||
|     .display_name{ | ||||
|         font-size: 30px; | ||||
|         display: block; | ||||
|     } | ||||
|     .info-item{ | ||||
|         display: inline-block; | ||||
|         margin-top: 10px; | ||||
|         font-size: 14px; | ||||
|         &:last-of-type{ | ||||
|             margin-left: 15px; | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 	.emptyGif { | ||||
| 		display: block; | ||||
| 		width: 45%; | ||||
| 		margin: 0 auto; | ||||
| 	} | ||||
|  | ||||
| 	.dashboard-editor-container { | ||||
| 		background-color: #e3e3e3; | ||||
| 		min-height: 100vh; | ||||
| 		margin-top: -50px; | ||||
| 		padding: 100px 60px 0px; | ||||
| 		.pan-info-roles { | ||||
| 			font-size: 12px; | ||||
| 			font-weight: 700; | ||||
| 			color: #333; | ||||
| 			display: block; | ||||
| 		} | ||||
| 		.info-container { | ||||
| 			position: relative; | ||||
| 			margin-left: 190px; | ||||
| 			height: 150px; | ||||
| 			line-height: 200px; | ||||
| 			.display_name { | ||||
| 				font-size: 48px; | ||||
| 				line-height: 48px; | ||||
| 				color: #212121; | ||||
| 				position: absolute; | ||||
| 				top: 25px; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| </style> | ||||
|   | ||||
| @@ -1,122 +0,0 @@ | ||||
| <template> | ||||
|   <div :class="className" :style="{height:height,width:width}"></div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import echarts from 'echarts' | ||||
| require('echarts/theme/macarons') // echarts 主题 | ||||
| import { debounce } from 'utils' | ||||
|  | ||||
| export default { | ||||
|   props: { | ||||
|     className: { | ||||
|       type: String, | ||||
|       default: 'chart' | ||||
|     }, | ||||
|     width: { | ||||
|       type: String, | ||||
|       default: '100%' | ||||
|     }, | ||||
|     height: { | ||||
|       type: String, | ||||
|       default: '350px' | ||||
|     }, | ||||
|     autoResize: { | ||||
|       type: Boolean, | ||||
|       default: true | ||||
|     } | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       chart: null | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
|     this.initChart() | ||||
|     if (this.autoResize) { | ||||
|       this.__resizeHanlder = debounce(() => { | ||||
|         if (this.chart) { | ||||
|           this.chart.resize() | ||||
|         } | ||||
|       }, 100) | ||||
|       window.addEventListener('resize', this.__resizeHanlder) | ||||
|     } | ||||
|  | ||||
|       // 监听侧边栏的变化 | ||||
|     const sidebarElm = document.getElementsByClassName('sidebar-container')[0] | ||||
|     sidebarElm.addEventListener('transitionend', this.__resizeHanlder) | ||||
|   }, | ||||
|   beforeDestroy() { | ||||
|     if (!this.chart) { | ||||
|       return | ||||
|     } | ||||
|     if (this.autoResize) { | ||||
|       window.removeEventListener('resize', this.__resizeHanlder) | ||||
|     } | ||||
|  | ||||
|     const sidebarElm = document.getElementsByClassName('sidebar-container')[0] | ||||
|     sidebarElm.removeEventListener('transitionend', this.__resizeHanlder) | ||||
|  | ||||
|     this.chart.dispose() | ||||
|     this.chart = null | ||||
|   }, | ||||
|   methods: { | ||||
|     initChart() { | ||||
|       this.chart = echarts.init(this.$el, 'macarons') | ||||
|  | ||||
|       this.chart.setOption({ | ||||
|         xAxis: { | ||||
|           data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'], | ||||
|           boundaryGap: false | ||||
|         }, | ||||
|         grid: { | ||||
|           left: 10, | ||||
|           right: 10, | ||||
|           bottom: 20, | ||||
|           containLabel: true | ||||
|         }, | ||||
|  | ||||
|         tooltip: { | ||||
|           trigger: 'axis', | ||||
|           axisPointer: { | ||||
|             type: 'cross' | ||||
|           } | ||||
|         }, | ||||
|         yAxis: {}, | ||||
|         series: [{ | ||||
|           name: 'visitors', | ||||
|           itemStyle: { | ||||
|             normal: { | ||||
|               areaStyle: {} | ||||
|             } | ||||
|           }, | ||||
|           smooth: true, | ||||
|           type: 'line', | ||||
|           data: [100, 120, 161, 134, 105, 160, 165], | ||||
|           animationDuration: 2600, | ||||
|           animationEasing: 'cubicInOut' | ||||
|         }, | ||||
|         { | ||||
|           name: 'buyers', | ||||
|           smooth: true, | ||||
|           type: 'line', | ||||
|           itemStyle: { | ||||
|             normal: { | ||||
|               color: 'rgba(2, 197, 233, 0.2)', | ||||
|               lineStyle: { | ||||
|                 color: 'rgba(2, 197, 233, 0.2)' | ||||
|               }, | ||||
|               areaStyle: { | ||||
|                 color: 'rgba(99,194,255, 0.6)' | ||||
|               } | ||||
|             } | ||||
|           }, | ||||
|           data: [120, 82, 91, 154, 162, 140, 130], | ||||
|           animationDuration: 2000, | ||||
|           animationEasing: 'quadraticOut' | ||||
|         }] | ||||
|       }) | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
| @@ -1,79 +0,0 @@ | ||||
| <template> | ||||
|   <div :class="className" :style="{height:height,width:width}"></div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import echarts from 'echarts' | ||||
| require('echarts/theme/macarons') // echarts 主题 | ||||
|  | ||||
| export default { | ||||
|   props: { | ||||
|     className: { | ||||
|       type: String, | ||||
|       default: 'chart' | ||||
|     }, | ||||
|     width: { | ||||
|       type: String, | ||||
|       default: '100%' | ||||
|     }, | ||||
|     height: { | ||||
|       type: String, | ||||
|       default: '300px' | ||||
|     } | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       chart: null | ||||
|     } | ||||
|   }, | ||||
|   mounted() { | ||||
|     this.initChart() | ||||
|   }, | ||||
|   beforeDestroy() { | ||||
|     if (!this.chart) { | ||||
|       return | ||||
|     } | ||||
|     this.chart.dispose() | ||||
|     this.chart = null | ||||
|   }, | ||||
|   methods: { | ||||
|     initChart() { | ||||
|       this.chart = echarts.init(this.$el, 'macarons') | ||||
|  | ||||
|       this.chart.setOption({ | ||||
|         title: { | ||||
|           text: 'WEEKLY WRITE ARTICLES', | ||||
|           x: 'center' | ||||
|         }, | ||||
|         tooltip: { | ||||
|           trigger: 'item', | ||||
|           formatter: '{a} <br/>{b} : {c} ({d}%)' | ||||
|         }, | ||||
|         legend: { | ||||
|           x: 'center', | ||||
|           y: 'bottom', | ||||
|           data: ['industries', 'technology', 'forex', 'gold', 'forecasts', 'markets'] | ||||
|         }, | ||||
|         calculable: true, | ||||
|         series: [ | ||||
|           { | ||||
|             name: 'WEEKLY WRITE ARTICLES', | ||||
|             type: 'pie', | ||||
|             roseType: 'radius', | ||||
|             data: [ | ||||
|                 { value: 320, name: 'industries' }, | ||||
|                 { value: 240, name: 'technology' }, | ||||
|                 { value: 149, name: 'forex' }, | ||||
|                 { value: 100, name: 'gold' }, | ||||
|                 { value: 59, name: 'forecasts' }, | ||||
|                 { value: 49, name: 'markets' } | ||||
|             ], | ||||
|             animationEasing: 'cubicInOut', | ||||
|             animationDuration: 2600 | ||||
|           } | ||||
|         ] | ||||
|       }) | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
		Reference in New Issue
	
	Block a user