Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/trendmicro-frontend/react-navbar

React Navbar component
https://github.com/trendmicro-frontend/react-navbar

Last synced: 11 days ago
JSON representation

React Navbar component

Awesome Lists containing this project

README

        

# react-navbar [![build status](https://travis-ci.org/trendmicro-frontend/react-navbar.svg?branch=master)](https://travis-ci.org/trendmicro-frontend/react-navbar) [![Coverage Status](https://coveralls.io/repos/github/trendmicro-frontend/react-navbar/badge.svg?branch=master)](https://coveralls.io/github/trendmicro-frontend/react-navbar?branch=master)

[![NPM](https://nodei.co/npm/@trendmicro/react-navbar.png?downloads=true&stars=true)](https://nodei.co/npm/@trendmicro/react-navbar/)

React Navbar

Demo: https://trendmicro-frontend.github.io/react-navbar

## Installation

1. Install the latest version of [react](https://github.com/facebook/react), [react-sticky@5](https://github.com/captivationsoftware/react-sticky), and [react-navbar](https://github.com/trendmicro-frontend/react-navbar):

```
npm install --save react react-sticky@5 @trendmicro/react-navbar
```

2. At this point you can import `@trendmicro/react-navbar` and all dependent styles in your application as follows:

```js
import Navbar from '@trendmicro/react-navbar';

// Be sure to include styles at some point, probably during your bootstraping
import '@trendmicro/react-dropdown/dist/react-dropdown.css';
import '@trendmicro/react-navs/dist/react-navs.css';
import '@trendmicro/react-navbar/dist/react-navbar.css';
```

## Usage

### Sticky Navigation Bar

#### StickyNavbar.jsx
```js
import Anchor from '@trendmicro/react-anchor';
import Dropdown from '@trendmicro/react-dropdown';
import Navbar from '@trendmicro/react-navbar';
import { Nav, NavDropdown, NavItem, MenuItem } from '@trendmicro/react-navs';
import PropTypes from 'prop-types';
import React from 'react';
import { StickyContainer, Sticky } from 'react-sticky';
import styles from './index.styl';

const noop = () => {};

const PageContent = () => (



Page Content




);

const StickyNavbar = ({ state, actions }) => {
return (




Product Name














Menu Item 1
Menu Item 2
Menu Item 3
Menu Item 4


Menu Item 1
Menu Item 2
Menu Item 3

Menu item 4

Second level item one


Second level item two








);
};

StickyNavbar.propTypes = {
state: PropTypes.object,
actions: PropTypes.object
};

export default StickyNavbar;
```

#### app.jsx
```js
import React from 'react';
import ReactDOM from 'react-dom';
import StickyNavbar from './StickyNavbar.jsx';

class App extends React.Component {
state = {
tab: ''
};
actions = {
selectTab: (eventKey, event) => {
if (!eventKey) {
return;
}

const tab = eventKey.replace(/\..+/g, '');
this.setState({ tab });
}
};

render() {
return (

)
}
}

ReactDOM.render(, document.getElementById('container'));
```

#### index.styl
```css
.site-header {
position: relative;
padding: 0 20px;
height: 64px;
margin-bottom: 0;
background-color: #fff;

a:link,
a:hover,
a:active,
a:visited,
a:focus {
color: #222;
text-decoration: none;
}

.banner {
width: 32px;
height: 32px;
margin: 16px 0;
margin-right: 10px;
background: url("./tball.svg") center left no-repeat;
float: left;
}
.title {
padding: 16px 0;
font-family: "Interstate-Light", Arial, "Helvetica Neue", Helvetica, sans-serif;
font-size: 26px;
font-weight: 200;
letter-spacing: -.03em;
white-space: nowrap;
}
}
```

#### [tball.svg](examples/tball.svg?raw=true)

![image](https://cloud.githubusercontent.com/assets/447801/24544119/b27ce2ba-1634-11e7-984d-aa58ca6c5934.png)

## API

### Properties

Name | Type | Default | Description
:--- | :--- | :------ | :----------

## License

MIT