mirror of
				https://github.com/youzan/vant.git
				synced 2025-10-22 11:54:02 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			90 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { use, noop } from '../utils';
 | |
| import { inherit } from '../utils/functional';
 | |
| import Icon from '../icon';
 | |
| 
 | |
| // Types
 | |
| import { CreateElement, RenderContext } from 'vue/types';
 | |
| import { ScopedSlot, DefaultSlots } from '../utils/types';
 | |
| 
 | |
| export type NavBarProps = {
 | |
|   title?: string;
 | |
|   fixed?: boolean;
 | |
|   zIndex: number;
 | |
|   border: boolean;
 | |
|   leftText?: string;
 | |
|   rightText?: string;
 | |
|   leftArrow?: boolean;
 | |
| };
 | |
| 
 | |
| export type NavBarSlots = DefaultSlots & {
 | |
|   left?: ScopedSlot;
 | |
|   title?: ScopedSlot;
 | |
|   right?: ScopedSlot;
 | |
| };
 | |
| 
 | |
| export type NavBarEvents = {
 | |
|   'click-left'?(event: Event): void;
 | |
|   'click-right'?(event: Event): void;
 | |
| };
 | |
| 
 | |
| const [sfc, bem] = use('nav-bar');
 | |
| 
 | |
| function NavBar(
 | |
|   h: CreateElement,
 | |
|   props: NavBarProps,
 | |
|   slots: NavBarSlots,
 | |
|   ctx: RenderContext<NavBarProps>
 | |
| ) {
 | |
|   return (
 | |
|     <div
 | |
|       class={[
 | |
|         bem({ fixed: props.fixed }),
 | |
|         { 'van-hairline--bottom': props.border }
 | |
|       ]}
 | |
|       style={{ zIndex: props.zIndex }}
 | |
|       {...inherit(ctx)}
 | |
|     >
 | |
|       <div class={bem('left')} onClick={ctx.listeners['click-left'] || noop}>
 | |
|         {slots.left
 | |
|           ? slots.left()
 | |
|           : [
 | |
|             props.leftArrow && (
 | |
|               <Icon class={bem('arrow')} name="arrow-left" />
 | |
|             ),
 | |
|             props.leftText && (
 | |
|               <span class={bem('text')}>{props.leftText}</span>
 | |
|             )
 | |
|           ]}
 | |
|       </div>
 | |
|       <div class={[bem('title'), 'van-ellipsis']}>
 | |
|         {slots.title ? slots.title() : props.title}
 | |
|       </div>
 | |
|       <div class={bem('right')} onClick={ctx.listeners['click-right'] || noop}>
 | |
|         {slots.right
 | |
|           ? slots.right()
 | |
|           : props.rightText && (
 | |
|               <span class={bem('text')}>{props.rightText}</span>
 | |
|           )}
 | |
|       </div>
 | |
|     </div>
 | |
|   );
 | |
| }
 | |
| 
 | |
| NavBar.props = {
 | |
|   title: String,
 | |
|   fixed: Boolean,
 | |
|   leftText: String,
 | |
|   rightText: String,
 | |
|   leftArrow: Boolean,
 | |
|   border: {
 | |
|     type: Boolean,
 | |
|     default: true
 | |
|   },
 | |
|   zIndex: {
 | |
|     type: Number,
 | |
|     default: 1
 | |
|   }
 | |
| };
 | |
| 
 | |
| export default sfc<NavBarProps, NavBarEvents>(NavBar);
 | 
