mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
251 lines
5.1 KiB
Vue
251 lines
5.1 KiB
Vue
// Licensed to the Apache Software Foundation (ASF) under one
|
|
// or more contributor license agreements. See the NOTICE file
|
|
// distributed with this work for additional information
|
|
// regarding copyright ownership. The ASF licenses this file
|
|
// to you under the Apache License, Version 2.0 (the
|
|
// "License"); you may not use this file except in compliance
|
|
// with the License. You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing,
|
|
// software distributed under the License is distributed on an
|
|
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
// KIND, either express or implied. See the License for the
|
|
// specific language governing permissions and limitations
|
|
// under the License.
|
|
|
|
<template>
|
|
<div class="page-header">
|
|
<div class="page-header-index-wide">
|
|
<a-breadcrumb class="breadcrumb">
|
|
<a-breadcrumb-item v-for="(item, index) in breadList" :key="index">
|
|
<router-link
|
|
v-if="item.name"
|
|
:to="{ path: item.path === '' ? '/' : item.path }"
|
|
>
|
|
<a-icon v-if="index == 0" :type="item.meta.icon" />
|
|
{{ item.meta.title }}
|
|
</router-link>
|
|
<span v-else-if="$route.params.id">{{ $route.params.id }}</span>
|
|
<span v-else>{{ item.meta.title }}</span>
|
|
</a-breadcrumb-item>
|
|
</a-breadcrumb>
|
|
|
|
<div class="detail">
|
|
<div class="main" v-if="!$route.meta.hiddenHeaderContent">
|
|
<div class="row">
|
|
<img v-if="logo" :src="logo" class="logo"/>
|
|
<h1 v-if="title" class="title">{{ title }}</h1>
|
|
<div class="action">
|
|
<slot name="action"></slot>
|
|
</div>
|
|
</div>
|
|
<div>
|
|
<slot name="pageMenu"></slot>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
import Breadcrumb from '@/components/widgets/Breadcrumb'
|
|
|
|
export default {
|
|
name: 'PageHeader',
|
|
components: {
|
|
's-breadcrumb': Breadcrumb
|
|
},
|
|
props: {
|
|
title: {
|
|
type: String,
|
|
default: '',
|
|
required: false
|
|
},
|
|
breadcrumb: {
|
|
type: Array,
|
|
default: null,
|
|
required: false
|
|
},
|
|
logo: {
|
|
type: String,
|
|
default: '',
|
|
required: false
|
|
},
|
|
avatar: {
|
|
type: String,
|
|
default: '',
|
|
required: false
|
|
}
|
|
},
|
|
data () {
|
|
return {
|
|
name: '',
|
|
breadList: []
|
|
}
|
|
},
|
|
created () {
|
|
this.getBreadcrumb()
|
|
},
|
|
methods: {
|
|
getBreadcrumb () {
|
|
this.breadList = []
|
|
|
|
this.name = this.$route.name
|
|
this.$route.matched.forEach((item) => {
|
|
// item.name !== 'index' && this.breadList.push(item)
|
|
this.breadList.push(item)
|
|
})
|
|
}
|
|
},
|
|
watch: {
|
|
$route () {
|
|
this.getBreadcrumb()
|
|
}
|
|
}
|
|
}
|
|
</script>
|
|
|
|
<style lang="less" scoped>
|
|
|
|
.page-header {
|
|
background: #fff;
|
|
padding: 16px 32px 0;
|
|
border-bottom: 1px solid #e8e8e8;
|
|
|
|
.breadcrumb {
|
|
margin-bottom: 16px;
|
|
}
|
|
|
|
.detail {
|
|
display: flex;
|
|
/*margin-bottom: 16px;*/
|
|
|
|
.avatar {
|
|
flex: 0 1 72px;
|
|
margin: 0 24px 8px 0;
|
|
|
|
& > span {
|
|
border-radius: 72px;
|
|
display: block;
|
|
width: 72px;
|
|
height: 72px;
|
|
}
|
|
}
|
|
|
|
.main {
|
|
width: 100%;
|
|
flex: 0 1 auto;
|
|
|
|
.row {
|
|
display: flex;
|
|
width: 100%;
|
|
|
|
.avatar {
|
|
margin-bottom: 16px;
|
|
}
|
|
}
|
|
|
|
.title {
|
|
font-size: 20px;
|
|
font-weight: 500;
|
|
|
|
font-size: 20px;
|
|
line-height: 28px;
|
|
font-weight: 500;
|
|
color: rgba(0,0,0,.85);
|
|
margin-bottom: 16px;
|
|
flex: auto;
|
|
|
|
}
|
|
.logo {
|
|
width: 28px;
|
|
height: 28px;
|
|
border-radius: 4px;
|
|
margin-right: 16px;
|
|
}
|
|
.content, .headerContent {
|
|
flex: auto;
|
|
color: rgba(0,0,0,.45);
|
|
line-height: 22px;
|
|
|
|
.link {
|
|
margin-top: 16px;
|
|
line-height: 24px;
|
|
|
|
a {
|
|
font-size: 14px;
|
|
margin-right: 32px;
|
|
}
|
|
}
|
|
}
|
|
.extra {
|
|
flex: 0 1 auto;
|
|
margin-left: 88px;
|
|
min-width: 242px;
|
|
text-align: right;
|
|
}
|
|
.action {
|
|
margin-left: 56px;
|
|
min-width: 266px;
|
|
flex: 0 1 auto;
|
|
text-align: right;
|
|
&:empty {
|
|
display: none;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
.mobile .page-header {
|
|
|
|
.main {
|
|
|
|
.row {
|
|
flex-wrap: wrap;
|
|
|
|
.avatar {
|
|
flex: 0 1 25%;
|
|
margin: 0 2% 8px 0;
|
|
}
|
|
|
|
.content, .headerContent {
|
|
flex: 0 1 70%;
|
|
|
|
.link {
|
|
margin-top: 16px;
|
|
line-height: 24px;
|
|
|
|
a {
|
|
font-size: 14px;
|
|
margin-right: 10px;
|
|
}
|
|
}
|
|
}
|
|
|
|
.extra {
|
|
flex: 1 1 auto;
|
|
margin-left: 0;
|
|
min-width: 0;
|
|
text-align: right;
|
|
}
|
|
|
|
.action {
|
|
margin-left: unset;
|
|
min-width: 266px;
|
|
flex: 0 1 auto;
|
|
text-align: left;
|
|
margin-bottom: 12px;
|
|
|
|
&:empty {
|
|
display: none;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</style>
|