feat: Dashboard - network overview - 新增app 部分功能完善

This commit is contained in:
@changcode
2022-07-21 18:23:33 +08:00
parent 0991842763
commit e33dbe2ea2
2 changed files with 123 additions and 13 deletions

View File

@@ -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;
}
} }
} }
} }

View File

@@ -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 () {