Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/redbaron76/navbar-native

a fully customizable navbar component for React-Native
https://github.com/redbaron76/navbar-native

Last synced: about 2 months ago
JSON representation

a fully customizable navbar component for React-Native

Awesome Lists containing this project

README

        

# NavbarNative
A **fully customizable** Navbar component for React-Native.
#### It works for both iOS and Android!

![navbar-native-intro](https://cloud.githubusercontent.com/assets/1061849/18530527/3bdab2b6-7ad2-11e6-95e4-1774e625080d.png)

![navbar-native-intro-android](https://cloud.githubusercontent.com/assets/1061849/18553248/0970cbd8-7b60-11e6-8b72-ec91f4d98671.png)

### Content
- [Installation](#installation)
- [Exported components](#exported-components)
- [Getting started](#getting-started)
- [Images as title](#image-as-title)
- [Transparent navbar](#transparent-navbar)
- [Container API](#container-api)
- [Navbar API](#navbar-api)
- [Demo](#demo)

### Installation
```bash
npm i navbar-native --save
```

### Pay attention
This package depends on the beautiful [Vector Icons for React Native](https://github.com/oblador/react-native-vector-icons).

After installing NavbarNative, in order to have **icons working**, please follow instructions about [HOW TO INSTALL AND LINK VECTOR ICONS](https://github.com/oblador/react-native-vector-icons) in your project.

### Exported components
This package exports two main components:

- **Container** - a container component to use as the first component in a __render()__ method. It accepts the "Navbar" component and the rest of the page content.
- **Navbar** - the components which generates the bar on top.

### Helper components

- **Icon** - a Vector Icons for React Native wrapper

### Getting started
Basically, the Navbar component accepts a **title** prop and **left** and/or **right** objects (or array of objects) which describe each button that the navbar has to render in the specific position.

#### Using icons
In order to use the correct set of icons, please use **ios-** prefix in _icon_ prop name for iOS and **md-** prefix for Android.

The following chunk of code shows a typical **iOS** NavbarNative usage:

```js
import React, { Component } from 'react';
import { View } from 'react-native';

import { Container, Navbar } from 'navbar-native';

class ReactNativeProject extends Component {
render() {
return (

{alert('Go back!')}
}}
right={[{
icon: "ios-search",
onPress: () => {alert('Search!')}
},{
icon: "ios-menu",
onPress: () => {alert('Toggle menu!')}
}]}
/>
... other stuff ...

);
}
}
```

### Image as a title

![image_list](https://cloud.githubusercontent.com/assets/1061849/18619404/6b15bb58-7dfb-11e6-917d-9c3ca6547f4f.png)

You can also use a **remote** or **local** image instead of the text title:

```js
class ReactNativeEmpty extends Component {
render() {
return (

{alert('Go back!')}
}}
right={[{
icon: "ios-search",
onPress: () => {alert('Search!')}
},{
icon: "ios-menu",
onPress: () => {alert('Toggle menu!')}
}]}
/>

);
}
}
```

### Image as background

![image-background](https://cloud.githubusercontent.com/assets/1061849/18619959/0e4003b2-7e09-11e6-9ec5-d88a43b0ed2c.png)

Images can be used in **background** also:

```js
class ReactNativeEmpty extends Component {
render() {
return (

{alert('Go back!')},
style:{color: 'white'}
}}
right={[{
icon: "ios-search",
iconColor: "white",
onPress: () => {alert('Search!')}
},{
icon: "ios-menu",
iconColor: "white",
onPress: () => {alert('Toggle menu!')}
}]}
/>

);
}
}
```

### Transparent Navbar

Do you need a **transparent** navbar and a full-page content beneath it? No problem! We've got you covered...

Just set `bgColor="transparent"` and `theme="dark"` and you can achieve something like this:

![transparent_navbar](https://cloud.githubusercontent.com/assets/1061849/18752282/39d75436-80e2-11e6-86a5-92c848446a6d.png)

### Using badges

![ios-badge](https://cloud.githubusercontent.com/assets/1061849/20268744/bd13b304-aa80-11e6-8628-73c49b6a9755.png)

```js
export default class ReactNativeEmpty extends Component {
render() {

const left = {
role: 'menu',
badge: {
value: 4,
bgColor: '#ffcc00',
textColor: 'black'
}
};

return (



);
}
}
```

### Container API
- **bgColor** - (String def. '#ffffff') - Background color for the Container, the one you see overscrolling
- **data** - (Array of strings or Array of Objects opt.) - data source for ListView
- **row** - (Function opt.) - A function that renders the single row element in ListView (accepts 'rowData', 'sectionID')
- **style** - (Object opt.) - Custom styles for the container
- **loading** - (Object opt.) - Prop to use in order to trigger the included loading screen [SPINNER INSTALLATION INSTRUCTIONS](https://github.com/maxs15/react-native-spinkit)
- **spinner** - (String def. 'ThreeBounce') - Type of spinner animation from [HERE](https://github.com/maxs15/react-native-spinkit)
- **spinnerColor** - (String def. '#ffffff') - Color of the spinner
- **spinnerSize** - (Number def. 50) - Size of the spinner
- **bgColor** - (String def. 'rgba(0,0,0,.8)') - Color to apply in the background
- **message** - (String opt.) - Loading text message to display
- **messageColor** - (String def. '#ffffff') - Color of the loading text message
- **styleContainer** - (Object opt.) - Additional style for the loading screen
- **styleText** - (Object opt.) - Additional style for the loading text
- **type** - ('scroll' or 'list' def. 'scroll') - How to render Container children content
- **height** - (Number def. screen height) - Set the height of the container

### Navbar API
- **theme** - ('light' or 'dark' - def. 'light' iOS / 'dark' Android) - Base theme for the NavigationBar
- **title** - (String or Component opt.) - The title element. Component needs to be styled accordingly.
- **titleColor** - (String opt.) - The title string color
- **bgColor** - (String def. light: ios #f2f2f2 android #f5f5f5 dark: ios #2b2b2b android #212121 ) - NavigationBar's background color
- **image** - (Object opt.) - Local/remote image instead of the title
- **source** - (require(String) for local or String for remote uri) - Local/remote image location
- **type** - ('local' or 'remote' def. 'local') - Origin of the image
- **resizeMode** - ('cover', 'contain', 'stretch', 'repeat', 'center' def. 'cover' local - 'contain' remote)
- **style** - (Object opt.) - Additional styles for image title
- **imageBackground** - (Object opt.) - Local/remote image in navbar background
- **source** - (String) - Local/remote image location
- **type** - ('local' or 'remote' def. 'local') - Origin of the image
- **resizeMode** - ('cover', 'contain', 'stretch', 'repeat', 'center' def. 'cover')
- **style** - (Object opt.) - Additional styles for image background
- **statusBar** - (Object opt.):
- **style** - ('light-content' or 'default') - Style of StatusBar
- **hidden** - (Boolean) - Show or not StatusBar
- **bgColor** - (String) - StatusBar background color
- **animation** - (Boolean def. true) - Animation between StatusBar transitions
- **transition** - ('fade' or 'slide' def. 'fade') - Type of StatusBar transition animation when hiding it
- **left / right** - (Object or Array of Objects or React component / return function):
- **icon** - (String opt.) - Vector Icon's icon name
- **iconFamily** - (String def. Ionicons) - Vector Icon's icon library
- **iconPos** - ('left' or 'right' def. left/right position) - Icon's position towards the label
- **iconSize** - (Number def. 30 ios - 28 android) - Icon's size
- **iconColor** - (String def. light: ios #387afe android #707070 dark: ios #ffffff android #ffffff ) - Icon's color
- **label** - (String opt.) - Button's label
- **badge** - (Number, String or Object opt.)
- **value** - (Number or String) - The value in the badge
- **bgColor** - (String opt.) - Badge background color
- **textColor** - (String opt.) - Badge text color
- **position** - ('left' or 'right' def. 'right') - Badge position in the button
- **onPress** - (Function) - onPress function handler
- **disabled** - (Boolean def. false) - It renders a button in a disabled status
- **role** - (String opt. - 'back' | 'close' | 'login' | 'menu') - Button's pre-defined aspect
- **style** - (Object opt.) - Button's override styles
- **style** - (Object) - Custom styles for the navbar
- **user** - (Object, Bool) - Authenticated user
- **elevation** - (Number) - (Android-only) Elevation of the toolbar

### Icon API
- **family** - (String def. 'Ionicons') - Font family for icons
- **name** - (String) - Name of the icon to show
- **color** - (String def. iOS '#387afe' android '#707070') - Color of the icon

### Demo

[MeteorNative](https://github.com/redbaron76/MeteorNative) is a full featured **boilerplate** which brings together **React-Native** and **Meteor js**.

In this project I implement **navbar-native** in many ways and you can see in action specific usages of this package.

![react-native-intro](https://cloud.githubusercontent.com/assets/1061849/18746036/5db45830-80c5-11e6-8222-1813798c8cd4.gif)