Skip to content

Latest commit

 

History

History
117 lines (67 loc) · 3.82 KB

README.md

File metadata and controls

117 lines (67 loc) · 3.82 KB

Hadron

What is this?

This is a simple HTML prototype written in HAML or ERB that is designed to be viewed with Serve.

What is Serve? Serve is an open-source rapid prototyping framework for Web applications. It makes it easy to prototype functionality without writing a single line of backend code.

How do I install and run Serve?

Serve is distributed as a Ruby gem to make it easy to get up and running. You must have Ruby installed in order to download and use Serve. The Ruby download page provides instructions for getting Ruby setup on different platforms:

http://www.ruby-lang.org/en/downloads/

After you have Ruby installed, open up the command prompt and type:

gem install serve

(OSX and Unix users may need to prefix the command with sudo.)

After Serve is installed, you can start it up in a given directory like this:

serve

This will start Serve on port 4000. You can now view the prototype in your Web browser at this URL:

http://localhost:4000

Compass and Sass

This prototype uses Compass and Sass to generate CSS. Both are distributed as Ruby gems and can be easily installed from the command prompt. Since the Compass gem depends on Sass, you can install them both with one command:

gem install compass

Learn more about Sass:

http://sass-lang.org

Learn more about Compass:

http://compass-style.org

Rack and Passenger

Astute users may notice that this project is also a simple Rack application. This means that it is easy to deploy it on Passenger or in any other Rack-friendly environment. Rack it up with the rackup command. For more information about using Serve and Passenger see:

http://bit.ly/serve-and-passenger

Exporting

To export your project, use the new "export" command:

serve export project output

Where "project" is the path to the project and "output" is the path to the directory where you would like your HTML and CSS generated.

Using Partials Across Multiple Layouts & Subdirectories

In your prototype, it may become necessary to create a more formalized tree structure for your content. For instance, say we have the following, simplistic site map:

<home>
|----<about>
|    |----<mission and history>
|----<news>
     |----<brand new website launch!>

It may be necessary to have a different layout for each of home, about and news. To do this, you will need to create subdirectories. For example, since about and mission & history are both basic pages in this scenario, you may want to create a new directory within the views directory called "about" and place both about.html.erb and mission-and-history.html.erb in it.

You will also need to copy _layout.html.erb from the views directory into your new subdirectory. If you do not copy this file over, the _layout.html.erb will be inherited from the closest parent directory.

To create a new layout for your basic pages, in the views/layouts directory create a copy of the default.html.erb file, renaming it to a descriptive title, such as basic-page.html.erb. Feel free to edit it as you see fit.

Now go back to your _layout.html.erb in the subdirectory you made earlier, and alter it to say

<%= render "/layouts/basic-page" %>

To maintain reuse partials regardless of where your page lives within the tree structure default.html.erb, be sure to use the absolute path of your partials. For instance, use

<%= render "/footer" %>

rather than,

<%= render "footer" %>

This will keep your serve instance running smoothly across advanced tree structures and multiple page layouts.

Learning More

You can learn more about Serve on the GitHub project page:

http://github.com/jlong/serve