blob: f5bb5a482c9874d0776f17a31351920eff433861 [file] [log] [blame]
// 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 id="userLayout" :class="['user-layout', device]">
<div class="user-layout-container">
<div class="user-layout-header">
<img
v-if="$config.banner"
:style="{
width: $config.theme['@banner-width'],
height: $config.theme['@banner-height']
}"
:src="$config.banner"
class="user-layout-logo"
alt="logo">
</div>
<route-view></route-view>
</div>
</div>
</template>
<script>
import RouteView from '@/layouts/RouteView'
import { mixinDevice } from '@/utils/mixin.js'
export default {
name: 'UserLayout',
components: { RouteView },
mixins: [mixinDevice],
data () {
return {}
},
mounted () {
document.body.classList.add('userLayout')
},
beforeDestroy () {
document.body.classList.remove('userLayout')
}
}
</script>
<style lang="less" scoped>
.user-layout {
height: 100%;
background: #fff;
&-container {
padding: 3rem 0;
width: 100%;
@media (min-height:600px) {
padding: 0;
position: relative;
top: 50%;
transform: translateY(-50%);
margin-top: -50px;
}
}
&-logo {
border-style: none;
margin: 0 auto 2rem;
display: block;
.mobile & {
max-width: 300px;
margin-bottom: 1rem;
}
}
}
</style>