0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-06 22:40:14 -05:00
ghost/core/client/README.md
Fabian Becker ea7c29bd7d Implement grunt dev task
closes #18
- Update grunt-contrib-watch to 0.6.0
- Add watch/dev task to Gruntfile
- Add Ruby to README
2014-03-15 16:52:32 +01:00

7.2 KiB

Ghost-UI

[Travis] [SauceLabs]

Ghost-UI is the user interface framework which is used to build the Ghost blogging platform, created and maintained by a passionate group of designers and front-end developers with the support and involvement of the Ghost community. It is structurally based on the Bootstrap framework.

Note: This repository is currently a reasonably broken work in progress. It's brand new, and we're just getting everything set up for the first time.

Table of Contents

Quick Start

Three quick start options are available:

What's Included

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:

ghost-ui/
├── css/
│   ├── ghost-ui.css
│   └── ghost-ui.min.css
├── js/
│   ├── ghost-ui.js
│   └── ghost-ui.min.js
└── fonts/
    ├── tbc.eot
    ├── tbc.svg
    ├── tbc.ttf
    └── tbc.woff

We provide compiled CSS and JS (ghost-ui.*), as well as compiled and minified CSS and JS (ghost-ui.min.*). Fonts from are also included.

Bugs and Feature Requests

Have a bug or a feature request? Please first read the issue guidelines and search for existing and closed issues. If your problem or idea is not addressed yet, please open a new issue.

Documentation

The documentation, included in this repo in the root directory, is built with Jekyll and publicly hosted on GitHub Pages at http://ui.ghost.org. The docs may also be run locally.

Running Documentation Locally

  1. If necessary, install Jekyll (requires v1.x).
  • Windows users: Read this unofficial guide to get Jekyll up and running without problems. We use Pygments for syntax highlighting, so make sure to read the sections on installing Python and Pygments.
  1. From the root /ghost-ui directory, run jekyll serve in the command line.
  • Windows users: While we use Jekyll's encoding setting, you might still need to change the command prompt's character encoding (code page) to UTF-8 so Jekyll runs without errors. For Ruby 2.0.0, run chcp 65001 first. For Ruby 1.9.3, you can alternatively do SET LANG=en_EN.UTF-8.
  1. Open http://localhost:9001 in your browser.

Learn more about using Jekyll by reading its documentation.

Compiling CSS and JavaScript

Ghost-UI uses Grunt with convenient methods for working with the framework. It's how we compile our code, run tests, and more. To use it, install the required dependencies as directed below and then check out the available Grunt commands.

Install Dependencies

From the command line:

  1. Install Ruby and bundler globally with gem install bundler.
  2. Install Ruby dependencies with bundle install.
  3. Install grunt-cli globally with npm install -g grunt-cli.
  4. Navigate to the root /Ghost-UI directory, then run npm install. npm will look at package.json and automatically install the necessary local dependencies listed there.

When completed, you'll be able to run the various Grunt commands provided from the command line.

Unfamiliar with npm? Don't have node installed? That's a-okay. npm is the node.js package manager, it allows you to install and easily manage development dependencies. Download and install node.js before proceeding.

Available Grunt Commands

$ grunt

Run grunt to run tests locally and compile the CSS and JavaScript into /dist. Uses Sass and UglifyJS.

$ grunt dist

grunt dist creates the /dist directory with compiled files. Uses Sass and UglifyJS.

$ grunt test

Runs JSHint and QUnit tests headlessly in PhantomJS (used for CI).

$ grunt dev

This is a convenience method for watching development files and automatically building them whenever they change.

Hooking Ghost-UI up to Ghost

Want to see your Ghost-UI changes working live in your local development copy of Ghost? Check out a copy of both repositories and follow these instructions:

Inside the Ghost-UI repo:

  • $ bower link
  • $ grunt dev

Inside the Ghost repo:

  • $ bower link ghost-ui
  • $ grunt dev

Now whenever you save a file in Ghost-UI - the changes will filter into the core Ghost repository.

Troubleshooting Dependencies

Should you encounter problems with installing dependencies or running Grunt commands, uninstall all previous dependency versions (global and local). Then, rerun npm install.

Contributing

Please read through our contributing guidelines. Included are directions for opening issues, coding standards, and notes on development. If your pull request contains JavaScript patches or features, you must include relevant unit tests.

Community

Keep track of development and community news.

Versioning

NB: Pre-1.0 we're play pretty fast and loose with Semver

For transparency into our release cycle and in striving to maintain backward compatibility, Ghost-UI is maintained under the Semantic Versioning guidelines.

Releases will be numbered with the following format:

<major>.<minor>.<patch>

And constructed with the following guidelines:

  • Breaking backward compatibility bumps the major while resetting minor and patch
  • New additions without breaking backward compatibility bumps the minor while resetting the patch
  • Bug fixes and misc changes bumps only the patch

For more information on SemVer, please visit http://semver.org/.

Copyright (c) 2013-2014 Ghost Foundation - Released under the MIT license.