Compass Style Tiles
Create HTML and CSS Style Tiles with Sass & Compass
This is the development repo for the compass extension and rubygem: style-tiles.
This is currently under active development
Feedback is very welcome!
New Style Tiles is now a Compass extension!
Style Tiles has changed from a sass project to a compass extension. This makes it much easier to get started and to reuse. You can build a starter project using one line and start working on creating style tiles right away. See the installation section for details on getting started.
Background
I loved Samantha Warren's idea of style tiles. It seemed like the best answer to moving away from time-draining pixel perfect comps. However I'm designing in the browser more and more and I didn't want to go back into pixel based AdobeLand — Photoshop or Fireworks to create Style Tiles. Especially now that I am doing Responsive Web Design, I wanted to be designing and thinking in CSS and HTML. I thought this would be a perfect project for Sass and Compass.
Design Philosophy
Style Tiles should be primarily easy to share (i.e. easy for you to send to clients and easy for them to view it). You should be able to send your designs as easily as a static mockup image. Be it an email attachment or a link to any webserver where you uploaded your designs.
Build for rapid iteration
- Highly customizable use sass variables wherever much as possible
- Reuse the HTML No real need to edit the HTML
- Body copy is also controlled by sass variables
- 1 to 1 mapping single file to control each iteration
-
Easily iterated simply duplicate the
.scss
files
Use only HTML and CSS where possible
- Viewable Everywhere! No server-side technologies
- Modern browser support only (this ain't production code)
- Simple & clean HTML5
- Use CSS3 selectors and pseudo-classes (avoid classes or ids)
- No dependancies on other css frameworks (Bootstrap or Foundation etc.)
- Embed images and fonts in CSS (you don't need to zip up a lot of files and folders)
- Embed Styles in HTML One file per iteration to send with no nested folders
Style Tiles should be deployable as simple HTML and CSS. Style Tiles should be able to view from any folder on a desktop or any web server. To keep the CSS simple — Style Tiles need to be viewed in modern browsers: Firefox and Webkit based browsers. Viewable anywhere! I am using CSS rather than some server solution.
Project History
The idea for creating HTML and CSS style tiles had been brewing in my head for awhile. I started the initial development on the bus ride to Design 4 Drupal 2012. I presented the idea in a BoF on Compass and got some positive feedback and interest.
The first iteration was a straight-forward Sass-ified project (archived here). I was able to get the images and the fonts to using compass functions. However, I knew I need a custom function in the config.rb
to copy the current css and add it to a <style>
tag in the <head>
of the HTML document. Thankfully, Zellio contributed his Ruby knowledge and created that exact custom function.
I paused development for awhile to work on my Pattern Primer. That too started as a sass project and eventually it made sense to make it into a compass extension. Thanks to Sam Richard's Compass Extension Template I was easily able to create my Compass Pattern Primer extension. Returning to Design 4 Drupal in 2013 on the bus, I thought it was time to convert Style Tiles to a compass extension and here we are.
Installation
Style Tiles is a compass extension bundled as a Ruby gem.
gem install style-tiles
You'll need to install Sass and Compass Ruby Gems too. Documentation for installing and using these gems is pretty extensive.
How to Use it
There are a number of ways you can get started with Style Tiles.
Recommended: Create a new Compass project using Style Tiles scaffolding
compass create <MyProject> -r style-tiles -u style-tiles
cd <MyProject>
compass compile
-
Note: replace
<MyProject>
with name of your project (without the<
>
)* This will generate four stylesheets and the paste the styles into four corresponding html files (index, v1, v2, and v3).
Other ways to add Style Tiles to your compass project
compass create <MyProject> -r style-tiles
This creates a new Compass project using the compass standard scaffolding and adds require 'style-tiles'
to the config.rb
. However without the custom config.rb and html file you lose the benefit of adding your styles to the HTML and you don't have a starter scaffolding with variables examples.
Add Style Tiles to an existing project by adding the following to config.rb
require 'style-tiles'
Then import the Style Tile partial by adding at the top of your working file
@import "style-tiles";
Note: You'll need to restart compass watch
if it's running. And again without the custom config.rb and html file you lose the benefit of adding your styles to the HTML and you don't have a starter scaffolding with variables examples.
How It Works
There's an index page that links to the 3 version pages. Each page has it's own
stylesheet. When you compile compass
the CSS files are generated from the .scss
files in the sass
folder. The corresponding HTML files are generated from template.html
and the CSS is added to the <head>
of the HTML files.
Deploying the Styles Tiles
The HTML files are self-contained. All the images, and fonts are embedded in the style and the style is embedded in the HTML. However if you don't want to inline your images. Set $inline-images
to false
in your partials/variations/_v*.scss
and include the images folder. The same goes for fonts, set $inline-fonts
to false
.
Adding more Versions
More pages can be easily added by duplicating these files
-
sass/v3.scss
tosass/v4.scss
-
sass/paritals/variations/\_v3.scss
tosass/paritals/variations/\_v4.scss
Then you'll need to make some easy edits
- change
@import "partials/variations/\_v3";
to@import "partials/variations/\_v4";
insass/v4.scss
- edit the variables you want to change in
sass/paritals/variations/\_v4.scss
Displaying updated versions on the homepage
Update what versions are displayed by updating the $show-versions variables.
$show-versions: 1, 2, 3;
to
$show-versions: 1, 2, 3, 4;
or
$show-versions: 1, 3, 4;
etc.
What variables are available?
The full list of variables that are available is in the compass gem's stylesheets folder: style-tiles/core/_variables.scss
Code Examples
How the copy variables are transformed into CSS
Here's an example of how the content-before-after
mixin creates the pseudo
selector and adds whats in the variables in to the content attribute.
HTML
Source: v1.html
<hgroup>
<h1>Project Name: </h1>
<h2>Versions: </h2>
</hgroup>
...
<footer>
</footer>
Sass Variables
Source: sass/partials/variations/_v1.scss
$project-name: "Sassy Style Tiles";
$footer-text: '\2752\20 Designed by Grey Boxes \2751'; // ❒ Designed by Grey Boxes ❑
Sass Structure partial
Source: sass/partials/core/_structure.scss
section:nth-of-type(1) header hgroup {
...
h1 {
...
@include content-before-after($project-name, false, true);
}
}
footer {
...
@include content-before-after($footer-text, false, true);
}
Sass Mixin partial
Source: sass/partials/core/_mixins.scss
@mixin content-before-after($content, $before: default, $after:false ) {
@if $before { &:before { content: $content; } }
@if $after { &:after { content: $content; } }
}
Generated CSS
Source: css/v1.css
section:nth-of-type(1) header hgroup h1:after {
content: "Sassy Style Tiles";
}
...
footer:after {
content: "\2752\20 Designed by Grey Boxes \2751";
}
How the list of textures is transformed into the CSS
The texture-boxes
mixin takes an array (comma separated list) of image file
names that are in the images/textures
folder. It uses an
@each sass control directive
to generate the CSS. It then uses an
@if sass control directive
to see if you set the images to be inlined (base 64 encoded) into the CSS.
HTML
Source: template.html
<aside>
<h3>Textures</h3>
<figure>
</figure>
<figure>
</figure>
<figure>
</figure>
<figcaption></figcaption>
</aside>
Sass Variables
Source: sass/partials/variations/_v1.scss
$textures: "cotton-shirt.png", "denim.jpg";
$inline-images: true; // can be set to false
Sass Structure partial
Source: sass/partials/core/_structure.scss
aside {
...
&:nth-of-type(2) figure {
...
@include texture-boxes($textures, $inline-images);
}
}
Sass Mixin partial
Source: sass/partials/core/_mixins.scss
@mixin texture-boxes($textures, $inline-images: false) {
$i : 1;
@each $texture in $textures {
&:nth-of-type(#{$i}) {
border: $figure-border;
@if $inline-images { @include background-image(inline-image("textures/#{$texture}")); }
@else { background-image: image-url("textures/#{$texture}"); }
}
$i: $i + 1;
}
}
Generated CSS
Source: css/v1.css
/// When inline image is set to false
aside:nth-of-type(2) figure:nth-of-type(1) {
border: 0.063em #888888 solid;
background-image: url('../images/textures/cotton-shirt.png?1346169991');
}
aside:nth-of-type(2) figure:nth-of-type(2) {
border: 0.063em #888888 solid;
background-image: url('../images/textures/denim.jpg?1345644552');
}
/// When inline image is set to true
aside:nth-of-type(2) figure:nth-of-type(1) {
border: 0.063em #888888 solid;
background-image: url('
CAMAAABKCk6nAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA2FpVFh0WE1MO
mNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cm
VTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wd6c
mRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4g.....');
}
aside:nth-of-type(2) figure:nth-of-type(2) {
border: 0.063em #888888 solid;
background-image: url('
sABFEdWNreQABAAQAAAAZAAD/4QNvaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLwA8P3hwYWNr
ZXQgYmVnaW49Iu+7vyIgaWQ9Ilc1TTBNcENlaGlIenJlU3pOVGN6a2M5ZCI/PiA8eDp4bXBtZXRhI
HhtbG5zOng9ImFkb2JlOm5zOm1ldGEvIiB4OnhtcHRrPSJBZG9iZSBYTVAgQ29yZSA1LjAtYzA2MCA
2MS4xMzQ3NzcsIDIwMTAvMDIvMTItMTc6 MzI6MDAgICAgICAgICI+IDxy.....');
}
Planned Features
- Custom font support
Currently, the examples utilizes a few open source fonts (that are available at Google Fonts). I have added the option to inline the fonts but they will significantly increase the size of the css (rarely a good solution for production).
If people are interested I may expand to incorporating some other font services.
+ Way to control the what links are available on the index page.
The idea is that you may want to control the visibility of the links on the
index page. For example, on a second round of iteration you may not want the
link to version 2 (if the the clients rejected it) to be still visible. This will be forthcoming very soon.