#Sassy Style Tiles
This is currently under development and is still very alpha! Feedback is very welcome!
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, as I'm designing in the browser more and more I didn't want to go back into pixel based AdobeLand — Photoshop or Fireworks. Especially now that I am doing Responsive Web Design, I wanted to be designing in CSS and HTML. I thought this would be a perfect project for Sass and Compass. So here's Sass-ified style tiles in HTML & CSS! It's still a work in progress and I am open to ideas how to improve it.
Style Tiles should be extremely easily deployed (i.e. easy to send to the client and easy for them to view).
- Use sass variables where possible
- Shouldn’t need to edit the HTML
- Copy should also be variables
- One file to control each iteration
- No server-side technologies
- Modern browser support only (not production code)
- Simple & clean HTML5
- Use CSS3 selectors and pseudo-classes (avoid classes or ids)
- No dependancies on other css frameworks (Bootstrap or Foundation)
Style Tiles should be deployable as simple HTML and CSS (perhaps JavaScript if there's becomes a good reason). Style Tiles should be able to run in any folder on a desktop or any web server. Style Tiles need to be viewed in modern browsers: Firefox and Webkit based browsers. Wherever possible I am using CSS rather than some server solution. Therefore can't be reliant on any server side technologies.
There's an index page that links to the 3 version pages. Each page has it's own stylesheet. The HTML is the exactly the same expect for the stylesheet link.
You can zip up all the html files and the css folder folder with the images. By Default all the images will be inlined in the stylesheets. However if you don't want to inline your images. Set $inline-images
to false
in the sass/core/_variables.scss and include the images folder.
More pages can be easily added by duplicating these files
- v3.html to v4.html
- sass/screen-v3.scss to sass/screen-v4.scss
- sass/paritals/screen/_v3.scss to sass/paritals/screen/_v4.scss
Then you'll need to make some easy edits
- change
<link rel="stylesheet" href="css/screen-v3.css">
to<link rel="stylesheet" href="css/screen-v4.css">
in v4.html. - change @import "partials/variations/_v3"; to @import "partials/variations/_v4"; in sass/screen-v4.scss
- edit the variables you want to change in sass/paritals/screen/_v4.scss.
- finally add or change the link on the index page
<li><a href="v3.html">Version 3</a></li>
to<li><a href="v4.html">Version 4</a></li>
The full list of variables that are available is in: sass/paritals/core/_variables.scss
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.
Source: v1.html
<hgroup>
<h1>Project Name: </h1>
<h2>Versions: </h2>
</hgroup>
...
<footer>
</footer>
Source: sass/partials/variations/_v1.scss
$project-name: "Sassy Style Tiles";
$footer-text: '\2752\20 Designed by Grey Boxes \2751'; // ❒ Designed by Grey Boxes ❑
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);
}
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; } }
}
Source: css/screen-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";
}
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.
Source: v1.html
<aside>
<h3>Textures</h3>
<figure>
</figure>
<figure>
</figure>
<figure>
</figure>
<figcaption></figcaption>
</aside>
Source: sass/partials/variations/_v1.scss
$textures: "cotton-shirt.png", "denim.jpg";
$inline-images: true; // can be set to false
Source: sass/partials/core/_structure.scss
aside {
...
&:nth-of-type(2) figure {
...
@include texture-boxes($textures, $inline-images);
}
}
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;
}
}
Source: css/screen-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.....');
}
- 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 (not a good solution for production).
If people are interested I may expand to incorporating some other type 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.