Using PatternFly - Quick Start Guide
This reference implementation of PatternFly is based on Bootstrap v3. Think of PatternFly as a "skinned" version of Bootstrap with additional components and customizations. PatternFly is meant to be used as a replacement for Bootstrap, so please don't include the Bootstrap CSS if you are including the PatternFly CSS in your project.
Within the download you'll find the following directories and files, logically grouping common assets and providing both compiled and minified variations. You'll see something like this:
patternfly/
└── dist/
├── css/
│ │── patternfly.min.css (* need to include)
│ └── patternfly-additions.min.css (* need to include)
├── fonts/
│ └── font and icon libraries (included via above CSS)
├── img/
│ └── branding materials and loading indicators
├── js/
│ └── patternfly.min.js (may need to include if you are using PatternFly jQuery Sidebar, Popovers or Datatables)
├── less/
│ └── variables, mixin, and component Less files (may need to include if you want to customize the already built CSS)
├── sass/
│ └── variables, mixin, and component Sass files (may need to include if you want to customize the already built CSS)
└── tests/
└── example markup source files
We provide compiled CSS and JS (patternfly.*
), as well as compiled and minified CSS and JS (patternfly.min.*
). CSS source maps (patternfly.*.map
) are available for use with certain browsers' developer tools. Fonts from OpenSans, FontAwesome, PatternFly Icons are included, as well as numerous other 3rd party JS components and libraries.
-
Ensure you have installed the following utilities:
-
Git: a free and open source distributed version control system.
- Unfamiliar with Git? Try using GitHub for Windows or GitHub for Mac.
-
Node.js: a software platform that is used to build server-side applications.
-
Grunt: a JavaScript task runner.
$ sudo npm install -g grunt-cli
-
-
Add PatternFly as a dependency for your project and you'll receive all the libraries you'll need:
$ npm install patternfly --save
For full install options see the README
-
Add the following CSS includes to your HTML file(s), adjusting path where needed:
<!-- PatternFly Styles --> <!-- Note: No other CSS files are needed regardless of what other JS packages located in patternfly/components that you decide to pull in --> <link rel="stylesheet" href="node_modules/patternfly/dist/css/patternfly.min.css"> <link rel="stylesheet" href="node_modules/patternfly/dist/css/patternfly-additions.min.css">
-
Add the following script includes to your HTML file(s), adjusting where necessary to pull in only what you need:
<!-- jQuery --> <script src="node_modules/patternfly/node_modules/jquery/dist/jquery.min.js"></script> <!-- Bootstrap JS --> <script src="node_modules/patternfly/node_modules/bootstrap/dist/js/bootstrap.min.js"></script> <!-- C3, D3 - Charting Libraries --> <script src="node_modules/patternfly/node_modules/c3/c3.min.js"></script> <script src="node_modules/patternfly/node_modules/d3/d3.min.js"></script> <!-- Datatables, jQuery Grid Component --> <!-- Note: jquery.dataTables.js must occur in the html source before patternfly*.js.--> <script src="node_modules/patternfly/node_modules/datatables/media/js/jquery.dataTables.min.js"></script> <script src="node_modules/patternfly/node_modules/drmonty-datatables-colvis/js/dataTables.colVis.js"></script> <script src="node_modules/patternfly/node_modules/datatables.net-colreorder/js/dataTables.colReorder.js"></script> <!-- PatternFly Custom Componets - Sidebar, Popovers and Datatables Customizations --> <!-- Note: jquery.dataTables.js must occur in the html source before patternfly*.js.--> <script src="node_modules/patternfly/node_modules/patternfly/dist/js/patternfly.min.js"></script> <!-- Bootstrap Combobox --> <script src="node_modules/patternfly/node_modules/patternfly-bootstrap-combobox/js/bootstrap-combobox.js"></script> <!-- Bootstrap Date Picker --> <script src="node_modules/patternfly/node_modules/bootstrap-datepicker/dist/js/bootstrap-datepicker.min.js"></script> <!-- Moment - required by Bootstrap Date Time Picker --> <script src="node_modules/patternfly/node_modules/moment/min/moment.min.js"></script> <!-- Bootstrap Date Time Picker - requires Moment --> <script src="node_modules/patternfly/node_modules/eonasdan-bootstrap-datetimepicker/build/js/bootstrap-datetimepicker.min.js"></script> <!-- Bootstrap Select --> <script src="node_modules/patternfly/node_modules/bootstrap-select/dist/js/bootstrap-select.min.js"></script> <!-- Bootstrap Switch --> <script src="node_modules/patternfly/node_modules/bootstrap-switch/dist/js/bootstrap-switch.min.js"></script> <!-- Bootstrap Touchspin --> <script src="node_modules/patternfly/node_modules/bootstrap-touchspin/dist/jquery.bootstrap-touchspin.min.js"></script> <!-- Bootstrap Tree View --> <script src="node_modules/patternfly/node_modules/patternfly-bootstrap-treeview/dist/bootstrap-treeview.min.js"></script> <!-- Google Code Prettify - Syntax highlighting of code snippets --> <script src="node_modules/patternfly/node_modules/google-code-prettify/bin/prettify.min.js"></script> <!-- MatchHeight - Used to make sure dashboard cards are the same height --> <script src="node_modules/patternfly/node_modules/jquery-match-height/jquery.matchHeight-min.js"></script> <!-- Angular Application? You May Want to Consider Pulling Angular-PatternFly And Angular-UI Bootstrap instead of bootstrap.js --> <!-- See /~https://github.com/patternfly/angular-patternfly for more information -->
-
Prefer to use Bower? You can install patternfly using Bower (although NPM is recommended). Add the following style and script includes from
bower_components
to your HTML file(s), adjusting where necessary to pull in only what you need:<!-- PatternFly Styles --> <!-- Note: No other CSS files are needed regardless of what other JS packages located in patternfly/components that you decide to pull in --> <link rel="stylesheet" href="bower_components/patternfly/dist/css/patternfly.min.css"> <link rel="stylesheet" href="bower_components/patternfly/dist/css/patternfly-additions.min.css"> <!-- jQuery --> <script src="bower_components/jquery/dist/jquery.min.js"></script> <!-- Bootstrap JS --> <script src="bower_components/bootstrap/dist/js/bootstrap.min.js"></script> <!-- C3, D3 - Charting Libraries --> <script src="bower_components/c3/c3.min.js"></script> <script src="bower_components/d3/d3.min.js"></script> <!-- Datatables, jQuery Grid Component --> <!-- Note: jquery.dataTables.js must occur in the html source before patternfly*.js.--> <script src="bower_components/datatables/media/js/jquery.dataTables.min.js"></script> <script src="bower_components/datatables-colvis/js/dataTables.colVis.js"></script> <script src="bower_components/datatables-colreorder/js/dataTables.colReorder.js"></script> <!-- PatternFly Custom Componets - Sidebar, Popovers and Datatables Customizations --> <!-- Note: jquery.dataTables.js must occur in the html source before patternfly*.js.--> <script src="bower_components/patternfly/dist/js/patternfly.min.js"></script> <!-- Bootstrap Combobox --> <script src="bower_components/bootstrap-combobox/js/bootstrap-combobox.js"></script> <!-- Bootstrap Date Time Picker - requires Moment --> <script src="bower_components/moment/min/moment.min.js"></script> <!-- Bootstrap Date Picker --> <script src="bower_components/bootstrap-datepicker/dist/js/bootstrap-datepicker.min.js"></script> <!-- Bootstrap Select --> <script src="bower_components/bootstrap-select/dist/js/bootstrap-select.min.js"></script> <!-- Bootstrap Switch --> <script src="bower_components/bootstrap-switch/dist/js/bootstrap-switch.min.js"></script> <!-- Bootstrap Touchspin --> <script src="bower_components/bootstrap-touchspin/dist/jquery.bootstrap-touchspin.min.js"></script> <!-- Bootstrap Tree View --> <script src="bower_components/patternfly-bootstrap-treeview/dist/bootstrap-treeview.min.js"></script> <!-- Google Code Prettify - Syntax highlighting of code snippets --> <script src="bower_components/google-code-prettify/bin/prettify.min.js"></script> <!-- MatchHeight - Used to make sure dashboard cards are the same height --> <script src="bower_components/matchHeight/jquery.matchHeight-min.js"></script> <!-- Angular Application? You May Want to Consider Pulling Angular-PatternFly And Angular-UI Bootstrap instead of bootstrap.js --> <!-- See /~https://github.com/patternfly/angular-patternfly for more information -->
-
Enjoy!!!
PatternFly includes LESS and SASS files for those that need to add their own customizations. When importing PatternFly LESS or SASS into your application, there are a few configuration steps that need to be made to ensure that paths to all resources are properly resolved.
If you used bower to install PatternFly, then you will need to replace
node_modules
paths from these instructions with the equivalentbower_components
path.
-
Import the two main PatternFly LESS files:
@import 'patternfly/dist/less/patternfly.less'; @import 'patternfly/dist/less/patternfly-additions.less';
-
Add
node_modules/
to the LESS compiler's search path options. -
LESS compiler references for a few common build tools:
-
Import the main PatternFly SASS file:
@import 'patternfly';
-
Add the following paths to the SASS compiler's search path options:
node_modules/patternfly/dist/sass
node_modules/bootstrap-sass/assets/stylesheets
- ** If installed in PatternFly private dependency tree:node_modules/patternfly/node_modules/bootstrap-sass/assets/stylesheets
node_modules/font-awesome-sass/assets/stylesheets
- ** If installed in PatternFly private dependency tree:``node_modules/patternfly/node_modules/font-awesome-sass/assets/stylesheets`
** In some cases, bootstrap-sass and font-awesome-sass might be installed into a private dependency tree within
node_modules/patternfly
. If this is the case, adjust the path to those dependencies accordingly.
- SASS compiler references for a few common build tools:
PatternFly uses some static font and image files. If you see 404 errors in your browser relating to these files, you may need to make some adjustments to ensure path references in the compiled css are correct. In our LESS and SASS, the font-path
and img-path
variables are used to define relative paths to these static files. The default values of these variables are ../fonts
and ../img
, respectively. These relative paths may not resolve in the context of your application, so you may need to override these variables or copy the PatternFly static files as part of your build.