lanan-repair-app/components/VNavigationBar.vue

153 lines
3.5 KiB
Vue
Raw Normal View History

2024-10-09 13:34:36 +08:00
<template>
2024-10-13 23:24:23 +08:00
<!-- header -->
<view>
<view :style="{ height: homeHeaderPaddingTop + 'px', backgroundColor }"></view>
<view :class="{leftTitle: leftTitle}"
:style="{ backgroundColor, height: homeHeaderMenuHeight + 'px' }" class="navigationBar">
<template v-if="leftTitle">
<view :style="{ color: titleColor }" class="navigationBarTitle">
{{ title ? title : '' }}
</view>
</template>
<template v-else>
<view class="navigationBarBack" @click="back">
<slot name="back">
<uni-icons :color="titleColor" size="24"
type="left"></uni-icons>
</slot>
</view>
<view :style="{ color: titleColor }" class="navigationBarTitle">
{{ title }}
</view>
2024-10-24 18:14:26 +08:00
<view v-if="showClear" @click="clearNoReadFun" class="navigationBarIcon" :style="{ color: titleColor }">
<image src="@/static/images/clear.png" mode="" class="clear-icon"></image>
</view>
2024-10-26 13:30:00 +08:00
<view v-if="addWares" @click="addNewWares" class="navigationBarIcon" style="position: absolute;right: 22px;font-size: 18px">
新增
</view>
2024-12-04 14:51:44 +08:00
<view v-if="houseAddNewWares" @click="addNewWaresHouse" class="navigationBarIcon" style="position: absolute;right: 22px;font-size: 18px">
新增配件
</view>
2024-10-13 23:24:23 +08:00
</template>
<view class="navigationBarBackExtra">
<slot name="extra">
</slot>
</view>
</view>
</view>
2024-10-09 13:34:36 +08:00
</template>
<script>
2024-10-13 23:24:23 +08:00
/* 计算标题位置 */
import {getWXStatusHeight} from "@/utils/utils";
2024-10-09 13:34:36 +08:00
2024-10-13 23:24:23 +08:00
export default {
props: {
backgroundColor: {
type: String,
default: '#317DFA'
},
title: String,
titleColor: {
type: String,
default: '#fff'
},
leftTitle: {
type: Boolean,
default: false
2024-10-24 18:14:26 +08:00
},
showClear: {
type: Boolean,
default: false
2024-10-26 13:30:00 +08:00
},
//新增配件
addWares:{
type: Boolean,
default: false
2024-12-04 14:51:44 +08:00
},
houseAddNewWares:{
type: Boolean,
default: false
2024-10-13 23:24:23 +08:00
}
},
mounted() {
// #ifdef MP
const {
barHeight,
barTop,
menuButtonLeft
} = getWXStatusHeight()
console.log('barHeight, barTop, menuButtonLeft: ', barHeight, barTop, menuButtonLeft);
this.homeHeaderPaddingTop = barTop || 0
this.homeHeaderMenuHeight = barHeight
this.homeHeaderMenuLeft = menuButtonLeft - 6
// #endif
},
data() {
return {
// #ifdef MP
homeHeaderPaddingTop: 0,
homeHeaderMenuHeight: 0,
homeHeaderMenuLeft: 0,
// #endif
// #ifdef APP || H5
homeHeaderPaddingTop: 20,
homeHeaderMenuHeight: 50,
homeHeaderMenuLeft: 0
// #endif
}
},
methods: {
back() {
uni.navigateBack()
2024-10-24 18:14:26 +08:00
},
clearNoReadFun(){
this.$emit('clearNoRead')
2024-10-26 13:30:00 +08:00
},
addNewWares(){
this.$emit('addNewWares')
2024-12-04 14:51:44 +08:00
},
addNewWaresHouse(){
this.$emit('addNewWaresHouse')
2024-10-13 23:24:23 +08:00
}
}
}
2024-10-09 13:34:36 +08:00
</script>
<style lang="scss" scoped>
2024-10-13 23:24:23 +08:00
.navigationBar {
position: relative;
display: flex;
align-items: center;
justify-content: center;
2024-10-09 13:34:36 +08:00
2024-10-13 23:24:23 +08:00
&.leftTitle {
justify-content: start;
padding-left: 28rpx;
}
2024-10-09 13:34:36 +08:00
2024-10-13 23:24:23 +08:00
.navigationBarBack {
position: absolute;
left: 20rpx;
}
2024-10-09 13:34:36 +08:00
2024-10-13 23:24:23 +08:00
.navigationBarBackExtra {
position: absolute;
right: 20rpx;
}
2024-10-09 13:34:36 +08:00
2024-10-13 23:24:23 +08:00
.navigationBarTitle {
font-size: 36rpx;
font-weight: bold;
}
2024-10-24 18:14:26 +08:00
.navigationBarIcon {
display: flex;
}
.clear-icon{
width: 40rpx;
height: 40rpx;
border-radius: 50%;
}
2024-10-13 23:24:23 +08:00
}
</style>