nifi/nifi-site/README.md

214 lines
6.1 KiB
Markdown

<!--
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
# About
[Apache NiFi project] (http://nifi.apache.org).
## Getting Started
The site is built using [grunt][] task runner, [bower][] package manager for
the web, and [npm][] package manager for node. npm is used to manage the
node modules required for building this site. bower is used to manage the
front end packages that the site will depend on.
Before installing bower and grunt, the NodeJS Package Manager (npm) must
be installed. For instructions on installing npm, see [npm-install][]
Both grunt and bower can be installed via npm once, it is installed.
```
sudo npm install -g grunt-cli
```
```
sudo npm install -g bower
```
To download the front end packages required for this site run the following
command from the nifi-site directory.
```bash
bower install
```
To install the node modules required to build this site run the following
command from the nifi-site directory.
```bash
npm install
```
The site is built using [foundation][], a responsive front end framework.
Consequently, the site is using [sass][] and [compass][] for CSS pre-processing.
This will also require ruby to be installed, as it is a a pre-requisite for sass and compass.
After installing Ruby, sass can be installed via:
```
gem install sass
```
Compass will require that the `ruby-devel` package also be installed. This is typically
accomplished by running
```
sudo yum install ruby-devel
```
for Fedora users or
```
sudo apt-get install ruby-dev
```
for Ubuntu users.
The compass gem can then be installed:
```
gem install compass
```
For Ubuntu users, it may also be necessary to install the `nodejs-legacy` package in order for
grunt to run properly:
```
sudo apt-get install nodejs-legacy
```
Now that the necessary gems are installed, it is important that the gems' executable directory is
in the user's PATH. For example:
```
export PATH=$PATH:/home/username/bin
```
**NOTE:** it is important that the fully qualified directory name be used. Simply using `~/bin` will
result in errors when running Grunt, such as:
```Running "compass:dist" (compass) task```
```Warning: You need to have Ruby and Compass installed and in your system PATH for this task to work.
More info: https://github.com/gruntjs/grunt-contrib-compass Use --force to continue.
```
```
Aborted due to warnings.
```
It is recommended that you update your environment's configuration so that this is always in your PATH,
as this will be required every time that grunt is run.
[grunt]: http://gruntjs.com/
[bower]: http://bower.io/
[npm]: http://www.npmjs.com/
[foundation]: http://foundation.zurb.com/
[sass]: http://sass-lang.com/
[compass]: http://compass-style.org/
[npm-install]: https://github.com/joyent/node/wiki/installing-node.js-via-package-manager
## Grunt Tasks
To build the site run the default grunt task. This will assemble the site and
place the resulting site in the dist folder. Part of this assembly is actually
building the various guides and Rest Api documentation bundled in the application.
Because of this, Maven must be installed and available on the PATH. Additionally Java
must be installed in order for the Maven build to succeed. Refer to the [NiFi][]
documentation for minimum requirements for Maven and Java.
[NiFi]: https://nifi.apache.org/quickstart.html
```bash
grunt
```
If developing new content/features for the site, it may be helpful to run
the dev task which will build the site and continue to watch the source
files for changes. Any changes will cause the site to be rebuilt.
```bash
grunt dev
```
To deploy new changes to the live site, run the deploy task
```bash
grunt deploy
```
This will go through each step required to deploy changes to the site. Updates
are performed by committing to a SVN repository. This means that svn must be installed
and available on the PATH. Additionally, it requires SVN 1.6+. The deployment
process will show the files being committed and provide an option to view a diff,
proceed with the commit, or abort.
## Source overview
### src/includes
Contains fragments that will be included on all pages of the site. Most notably
here is the topbar.hbs that defines the Menus on the top of the site. If a new
page is being added or removed it is done here.
### src/pages/html
Contains pages that are written in HTML. Any new HTML based content should reside here.
### src/pages/markdown
Contains pages that are written in Markdown. Any new Markdown based content should
reside here.
## Application Style Properties
### Font
- Oswald: http://www.google.com/fonts/specimen/Oswald
### Colors
- 'ni': #7A96A4
- 'fi': #0F3541
- Toolbox: #7299AC
- Toolbar: #A0BAC7
- Flow Status: #D9E4E8
- Utilities: #81A0B4
## Technologies & Resources
- HTML5
- CSS3
- Foundation
- jQuery
- Modernizr
- Google Fonts API
- Web Font Loader
- FontAwesome
## License
Except as otherwise noted this software is licensed under the
[Apache License, Version 2.0](http://www.apache.org/licenses/LICENSE-2.0.html)
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.