navigationStyle: 'custom'

import React, { forwardRef, Ref, useEffect, useImperativeHandle, useState } from 'react'
import { View, Text, Image } from '@tarojs/components'

import Taro from '@tarojs/taro';
import './nav-bar.less'

const backIcon = ''
interface NavBarProps {
  title: string;
  children?: React.ReactNode;
  showBack?: boolean;
}
export interface NavBarRef {
  /**
   * 导航栏高度
   */
  navHeight: number;
}
function NavBar(props: NavBarProps, ref: Ref<NavBarRef>) {
  const { title, children, showBack = true } = props;
  const [navHeight, setNavHeight] = useState(0)
  const [navPaddingRight, setNavPaddingRight] = useState(0)
  const [navPaddingLeft, setNavPaddingLeft] = useState(0)
  const [navPaddingTop, setNavPaddingTop] = useState(0)
  const [leftWidth, setLeftWidth] = useState(0)
  const [leftHeight, setLeftHeight] = useState(0)
  useImperativeHandle(ref, () => ({
    navHeight,
  }), [navHeight])
  useEffect(() => {
    //  计算导航栏高度 
    const systemInfo = Taro.getWindowInfo();  //  获取系统信息
    const menuButtonInfo = Taro.getMenuButtonBoundingClientRect(); // 获取胶囊信息
    const statusBarHeight = systemInfo.statusBarHeight || 0; // 状态栏高度
    const menuButtonHeight = menuButtonInfo.height; // 胶囊高度
    const menuButtonTop = menuButtonInfo.top; // 胶囊top
    const menuButtonRight = menuButtonInfo.right; // 胶囊right
    const navBarHeight = statusBarHeight + menuButtonHeight + (menuButtonTop - statusBarHeight) * 2; // 导航栏高度
    const paddingRight = systemInfo.screenWidth - menuButtonRight; // 导航栏右侧padding
    const paddingTop = statusBarHeight; // 导航栏上边padding
    setNavHeight(navBarHeight)
    setNavPaddingLeft(paddingRight)
    setNavPaddingRight(paddingRight + menuButtonInfo.width)
    setNavPaddingTop(paddingTop)
    setLeftWidth(menuButtonInfo.width)
    setLeftHeight(menuButtonInfo.height)
  }, [])
  return (
    <View className='nav_bar'
      style={{
        height: navHeight + 'px',
        paddingRight: navPaddingRight + 'px',
        paddingLeft: navPaddingLeft + 'px',
        paddingTop: navPaddingTop + 'px'
      }}
    >
      <View
        className='back'
        style={{
          width: leftWidth + 'px',
          height: leftHeight + 'px',
        }}
      >
        {
          showBack && <Image src={backIcon} className='back_icon' />
        }
      </View>
      <View className='middle'>
        {
          title ? <Text className='title'>{title}</Text> : children
        }
      </View>

    </View>
  )
}

export default forwardRef(NavBar)
.nav_bar {
  position: fixed;
  width: 100%;
  display: flex !important;
  align-items: center;
  box-sizing: border-box;
  background-color: white;
  z-index: 999;
  .back {
    display: flex;
    align-items: center;
    border-radius: 999px;
    background-color: white;
    font-size: 28px;
    color: #333;
    .back_icon {
      width: 40px;
      height: 40px;
    }
  }
  .middle {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    .title {
      font-size: 32px;
      font-weight: bold;
      color: black;
    }
  }
}