feat: Dashboard - network overview - 新增app 部分功能完善
This commit is contained in:
@@ -213,8 +213,24 @@
|
|||||||
|
|
||||||
.body__searcher {
|
.body__searcher {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
right: 20px;
|
right: 28px;
|
||||||
top: 15px;
|
top: 15px;
|
||||||
|
width: 280px;
|
||||||
|
.el-input.el-input--mini {
|
||||||
|
.el-input__inner {
|
||||||
|
background: #FFFFFF;
|
||||||
|
border: 1px solid #DEDEDE;
|
||||||
|
box-shadow: 0 2px 4px 0 rgba(51,51,51,0.02);
|
||||||
|
border-radius: 14px;
|
||||||
|
}
|
||||||
|
&.el-input--prefix {
|
||||||
|
i {
|
||||||
|
color: #575757;
|
||||||
|
font-size: 16px;
|
||||||
|
font-weight: 600;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
.el-tabs__nav-wrap::after {
|
.el-tabs__nav-wrap::after {
|
||||||
height: 0;
|
height: 0;
|
||||||
@@ -244,6 +260,43 @@
|
|||||||
background: #FFFFFF;
|
background: #FFFFFF;
|
||||||
border: 1px solid #E2E5EC;
|
border: 1px solid #E2E5EC;
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
|
padding: 18px 16px;
|
||||||
|
cursor: pointer;
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
.body__app-title {
|
||||||
|
font-family: Helvetica-Bold;
|
||||||
|
font-size: 16px;
|
||||||
|
color: #353636;
|
||||||
|
font-weight: 700;
|
||||||
|
margin-bottom: 6px;
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
.body__app-title-left {
|
||||||
|
span {
|
||||||
|
i {
|
||||||
|
color: green;
|
||||||
|
margin-right: 2px;
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.body__app-title-right {
|
||||||
|
span {
|
||||||
|
i {
|
||||||
|
color: #046ECA;
|
||||||
|
margin-right: 2px;
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
.body__app-value {
|
||||||
|
font-size: 12px;
|
||||||
|
color: #717171;
|
||||||
|
line-height: 18px;
|
||||||
|
font-weight: 400;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -75,25 +75,43 @@
|
|||||||
<div class="add-app__header">
|
<div class="add-app__header">
|
||||||
<div class="header__title">{{$t('overall.add')}}</div>
|
<div class="header__title">{{$t('overall.add')}}</div>
|
||||||
<div class="header__operations">
|
<div class="header__operations">
|
||||||
<div class="header__operation header__operation--cancel">{{$t('overall.cancel')}}</div>
|
<div class="header__operation header__operation--cancel" @click="cancelApp">{{$t('overall.cancel')}}</div>
|
||||||
<div class="header__operation header__operation--save">{{$t('overall.save')}}</div>
|
<div class="header__operation header__operation--save">{{$t('overall.save')}}</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="add-app__body">
|
<div class="add-app__body">
|
||||||
<el-tabs v-model="appTypeTab">
|
<el-tabs v-model="appTypeTab" @tab-click="appTypeTabChange">
|
||||||
<el-tab-pane :label="$t('networkOverview.appType.provider')" :name="0">
|
<el-tab-pane :label="$t('networkOverview.appType.provider')" :name="0">
|
||||||
<div class="body__apps">
|
<div class="body__apps">
|
||||||
<div class="body__app" v-for="app in providerOptions" :key="app.name">{{app.name}},{{app.desc}}</div>
|
<div class="body__app" v-for="app in providerOptions" :key="app.name" @click="appCheckedChange(app, 0)">
|
||||||
|
<div class="body__app-title">
|
||||||
|
<div class="body__app-title-left">
|
||||||
|
<span><i class="cn-icon cn-icon-mining-pool"></i></span>
|
||||||
|
{{app.name}},{{app.desc}}
|
||||||
|
</div>
|
||||||
|
<div class="body__app-title-right" v-if="app.provideShow"><span><i class="cn-icon cn-icon-a-allclear"></i></span></div>
|
||||||
|
</div>
|
||||||
|
<div class="body__app-value">This is a description this is a description this is a description this is a description</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
<el-tab-pane :label="$t('networkOverview.appType.app')" :name="1">
|
<el-tab-pane :label="$t('networkOverview.appType.app')" :name="1">
|
||||||
<div class="body__apps">
|
<div class="body__apps">
|
||||||
<div class="body__app" v-for="app in appOptions" :key="app.name">{{app.name}},{{app.desc}}</div>
|
<div class="body__app" v-for="app in appOptions" :key="app.name" @click="appCheckedChange(app, 1)">
|
||||||
|
<div class="body__app-title">
|
||||||
|
<div class="body__app-title-left">
|
||||||
|
<span><i class="cn-icon cn-icon-mining-pool"></i></span>
|
||||||
|
{{app.name}},{{app.desc}}
|
||||||
|
</div>
|
||||||
|
<div class="body__app-title-right" v-if="app.appShow"><span><i class="cn-icon cn-icon-a-allclear"></i></span></div>
|
||||||
|
</div>
|
||||||
|
<div class="body__app-value">This is a description this is a description this is a description this is a description</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</el-tab-pane>
|
</el-tab-pane>
|
||||||
</el-tabs>
|
</el-tabs>
|
||||||
<div class="body__searcher">
|
<div class="body__searcher">
|
||||||
<el-input size="mini"></el-input>
|
<el-input v-model="searcherApp" @input="searcherAppChange" size="mini" :placeholder="$t('networkOverview.searcher')" prefix-icon="el-icon-search"></el-input>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@@ -114,7 +132,7 @@ export default {
|
|||||||
},
|
},
|
||||||
setup () {
|
setup () {
|
||||||
return {
|
return {
|
||||||
myChart: shallowRef(null)
|
myChart: shallowRef([])
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
data () {
|
data () {
|
||||||
@@ -137,7 +155,10 @@ export default {
|
|||||||
// add弹框中的可选项
|
// add弹框中的可选项
|
||||||
providerOptions: [],
|
providerOptions: [],
|
||||||
appOptions: [],
|
appOptions: [],
|
||||||
appTypeTab: 0
|
appTypeTab: 0,
|
||||||
|
appShowName: false,
|
||||||
|
searcherApp: '',
|
||||||
|
appShowTypeTab: 0
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
@@ -557,7 +578,7 @@ export default {
|
|||||||
},
|
},
|
||||||
initChart (obj) {
|
initChart (obj) {
|
||||||
const dom = document.getElementById(`chart${obj.name}`)
|
const dom = document.getElementById(`chart${obj.name}`)
|
||||||
this.myChart = echarts.init(dom)
|
this.myChart.push(echarts.init(dom))
|
||||||
this.chartOption = appListChartOption
|
this.chartOption = appListChartOption
|
||||||
const seriesTemplate = this.chartOption.series[0]
|
const seriesTemplate = this.chartOption.series[0]
|
||||||
this.chartOption.series = [{
|
this.chartOption.series = [{
|
||||||
@@ -580,7 +601,9 @@ export default {
|
|||||||
])
|
])
|
||||||
}
|
}
|
||||||
}]
|
}]
|
||||||
this.myChart.setOption(this.chartOption)
|
this.myChart.forEach(t => {
|
||||||
|
t.setOption(this.chartOption)
|
||||||
|
})
|
||||||
},
|
},
|
||||||
addApp () {
|
addApp () {
|
||||||
this.showAddApp = true
|
this.showAddApp = true
|
||||||
@@ -588,16 +611,50 @@ export default {
|
|||||||
for (let i = 0; i < 100; i++) {
|
for (let i = 0; i < 100; i++) {
|
||||||
this.appOptions.push({
|
this.appOptions.push({
|
||||||
name: letter[i % 26] + i,
|
name: letter[i % 26] + i,
|
||||||
desc: 'this is a really nice app'
|
desc: 'this is a really nice app',
|
||||||
|
appShow: false
|
||||||
})
|
})
|
||||||
this.providerOptions.push({
|
this.providerOptions.push({
|
||||||
name: letter[i % 26] + i,
|
name: letter[i % 26] + i,
|
||||||
desc: 'this is a really nice provider'
|
desc: 'this is a really nice provider',
|
||||||
|
provideShow: false
|
||||||
|
})
|
||||||
|
}
|
||||||
|
},
|
||||||
|
cancelApp () {
|
||||||
|
this.showAddApp = false
|
||||||
|
},
|
||||||
|
appTypeTabChange (val) {
|
||||||
|
this.appShowTypeTab = val.index
|
||||||
|
},
|
||||||
|
searcherAppChange (val) {
|
||||||
|
if (val) {
|
||||||
|
if (this.appShowTypeTab === 0) {
|
||||||
|
this.providerOptions = this.providerOptions.filter((t, i) => t.name.indexOf(val) > -1 || t.desc.indexOf(val) > -1)
|
||||||
|
} else if (this.appShowTypeTab === 1) {
|
||||||
|
this.appOptions = this.appOptions.filter((t, i) => t.name.indexOf(val) > -1 || t.desc.indexOf(val) > -1)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
appCheckedChange (app, num) {
|
||||||
|
if (num === 0) {
|
||||||
|
this.providerOptions.forEach(t => {
|
||||||
|
if (t.name === app.name && t.desc === app.desc) {
|
||||||
|
t.provideShow = !t.provideShow
|
||||||
|
}
|
||||||
|
})
|
||||||
|
} else if (num === 1) {
|
||||||
|
this.appOptions.forEach(t => {
|
||||||
|
if (t.name === app.name && t.desc === app.desc) {
|
||||||
|
t.appShow = !t.appShow
|
||||||
|
}
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
resize () {
|
resize () {
|
||||||
this.myChart.resize()
|
this.myChart.forEach(t => {
|
||||||
|
t.resize()
|
||||||
|
})
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
mounted () {
|
mounted () {
|
||||||
|
|||||||
Reference in New Issue
Block a user