Power Theming
During my first week at Astonish Design, I was fortunate enough to attend an Austin Drupal Users Group meetup where Ian Carrico spoke about Power Themeing. Power Themeing, as Ian coined it, can be used by anyone who does theme work and writes CSS for any platform. This new way of thinking has catapulted me from the days of relying on someone else’s responsive framework (Twitter Bootstrap, HTML5 Boilerplate, etc), to writing my own in the same amount of time. Frameworks can be powerful, but I fear that they are holding back innovation.
In the current age of Responsive Web Design (RWD) and multiple browsers, the issue has been writing lengthy CSS, with multiple media queries, that respond to browser size and work everywhere, or fall back cleanly (non-CSS3 browsers). We also have to remember all the browser-specific CSS:
.gradient {<br> *zoom: 1;<br> -ms-filter: progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorstr='#FFAAAAAA', endColorstr='#FFEEEEEE');<br> filter: progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorstr='#FFAAAAAA', endColorstr='#FFEEEEEE');<br> background: #cccccc;<br> background: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #aaaaaa), color-stop(100%, #eeeeee));<br> background: -moz-linear-gradient(top, #aaaaaa, #eeeeee);<br> background: -o-linear-gradient(top, #aaaaaa, #eeeeee);<br> background: linear-gradient(top, #aaaaaa, #eeeeee);<br>}
Enter Compass with its wonderful extensions.
Compass
CSS as a language
Compass is a Ruby-based CSS authoring framework that uses Sass. Sass allows for variables, mixins, nesting, inheritance, and much more. These features reduce the amount of CSS you need to write. LESS is similar to Sass, but does not integrate with Compass. Compass takes Sass a step further. Compass adds multitudes of useful and intuitive functions. In addition, Compass can be set to watch for changes and automatically compile your Sass to CSS. See http://compass-style.org/help/ for a good introductory video. With Compass and Sass, our above background gradient CSS now looks like:
@import "compass"; // Called once<br>.gradient {<br> // IE; docs say this should go first<br> // (or better, placed in separate IE-only stylesheet):<br> @include filter-gradient(#aaaaaa, #eeeeee);<br> // Fallback:<br> background: #cccccc;<br> // CSS 3 plus vendor prefixes:<br> @include background(linear-gradient(top, #aaaaaa, #eeeeee));<br>}
I would like to point out that the ‘@include filter-gradient‘ uses the same colors, not IE specific ones. Also, comments are ignored during processing.
Another extremely useful aspect of Compass are Sass partials. Partials, named _file.scss, are easily called in include statements and are compiled into one CSS file. You can have dozens of Sass files to keep your Sass broken up how you like, but one CSS file. Developers can work on different files at the same time. Features or sections of a site can be broken up into separate files. Your workflow can dictate your own unique Sass partial structure.
Compass Extensions
A few Compass extensions that I have used and found useful:
Sassy Buttons - Sassy Buttons is a Compass extension that adds functions for super simple pure CSS buttons:
Sass:
.btn-test{<br> @include sassy-button("matte", 10px, 19px, #ff6f13);<br>}
CSS:
.btn-test {<br> font-size: 19px;<br> padding: 0.5em 1.5em;<br> display: inline-block;<br> cursor: pointer;<br> -webkit-border-radius: 10px;<br> -moz-border-radius: 10px;<br> -ms-border-radius: 10px;<br> -o-border-radius: 10px;<br> border-radius: 10px;<br> *zoom: 1;<br> filter: progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorstr='#FFFF6F13', endColorstr='#FFAC4300');<br> background: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #ff9e5f), color-stop(70%, #ff6f13));<br> background: -webkit-linear-gradient(#ff9e5f, #ff6f13 70%);<br> background: -moz-linear-gradient(#ff9e5f, #ff6f13 70%);<br> background: -o-linear-gradient(#ff9e5f, #ff6f13 70%);<br> background: linear-gradient(#ff9e5f, #ff6f13 70%);<br> -webkit-box-shadow: #ffccac 0 1px 0 inset;<br> -moz-box-shadow: #ffccac 0 1px 0 inset;<br> box-shadow: #ffccac 0 1px 0 inset;<br> border: 1px solid #f96100;<br> color: white;<br> text-shadow: #d75400 0 -1px 0;<br>}<br>.btn-test:hover {<br> text-decoration: none;<br>}<br>.btn-test:hover {<br> background-color: #f96100;<br> background: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(3%, #ff8e46), color-stop(75%, #f96100));<br> background: -webkit-linear-gradient(#ff8e46 3%, #f96100 75%);<br> background: -moz-linear-gradient(#ff8e46 3%, #f96100 75%);<br> background: -o-linear-gradient(#ff8e46 3%, #f96100 75%);<br> background: linear-gradient(#ff8e46 3%, #f96100 75%);<br>}<br>.btn-test:active {<br> -webkit-box-shadow: #e95b00 0 1px 2px inset;<br> -moz-box-shadow: #e95b00 0 1px 2px inset;<br> box-shadow: #e95b00 0 1px 2px inset;<br>}<br>.btn-test.disabled, .btn-test[disabled] {<br> opacity: 0.6;<br> background: #ff6f13;<br> cursor: default;<br> -webkit-box-shadow: none;<br> -moz-box-shadow: none;<br> box-shadow: none;<br>}<br>.btn-test::-moz-focus-inner {<br> padding: 0 !important;<br> margin: -1px !important;<br>}
Test Me
Breakpoint / Respond-To: Breakpoint allows you to easily define and call breakpoints in your CSS, but Respond-To allows you to semantically define and call numerous breakpoints. Usage Example and Breakpoint / Respond-To Comparison. Needless to say these extensions make responsive CSS super simple. Just call the function and the CSS will only be used at that breakpoint. No longer does your CSS need to be separated by media queries.
$breakpoints: 'full navigation, large' (700px 800px),<br> 'monochrome screen' (monochrome),<br> 'monochrome portrait, wide' (700px, orientation portrait, monochrome);<br>.respond {<br> // Normal CSS here.<br> @include respond-to('full navigation', 'large') {<br> // Conditional CSS here.<br> }<br>}
Susy: Susy is a Compass/Sass responsive grid extension with a complete responsive framework. See: http://susy.oddbird.net/guides/getting-started/
How-to blog post: http://sectionr.be/blog/
Cool things coming in the future for Susy: http://oddbird.net/2013/01/01/susy-next/
Here is a complete list of Compass extensions (unvetted): https://rubygems.org/search?query=compass
Drupal + Sass & Compass
How can this apply to Drupal?
All of the Compass goodness that has been mentioned so far has been rolled into a Drupal base theme called Aurora, which is maintained by Ian and Sam Richard. Aurora also has a distribution called Corona that is built on Susy. Corona runs as a sub theme of Aurora and can be deployed with one command via terminal. It comes fully laid out with theme structure and Sass partials in place. See Ian’s blog post for more about how to use Corona. Aurora has some exciting features like Modernizr and viewport overlay (screenshot) display for themeing help, it’s own Compass extension, and some promising JavaScript features in the works. In addition, you can enable the Borealis Suite for responsive images and semantic blocks.
References in short:
Power Theming: http://chinggizkhan.github.com/power-theming-drupal/
Sass: http://sass-lang.com/
Compass: http://compass-style.org/
Sassy Buttons: http://jaredhardy.com/sassy-buttons/
Respond-To: https://github.com/snugug/respond-to
Susy: http://susy.oddbird.net/
Aurora: http://drupal.org/project/aurora
Compass, Aurora, and Corona... Oh My!: http://fourkitchens.com/blog/2012/11/13/compass-aurora-and-corona-oh-my
Borealis Suite: http://drupal.org/project/borealis
.btn-test {
font-size: 19px;
padding: 0.5em 1.5em;
display: inline-block;
cursor: pointer;
-webkit-border-radius: 10px;
-moz-border-radius: 10px;
-ms-border-radius: 10px;
-o-border-radius: 10px;
border-radius: 10px;
*zoom: 1;
filter: progid:DXImageTransform.Microsoft.gradient(gradientType=0, startColorstr='#FFFF6F13', endColorstr='#FFAC4300');
background: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(0%, #ff9e5f), color-stop(70%, #ff6f13));
background: -webkit-linear-gradient(#ff9e5f, #ff6f13 70%);
background: -moz-linear-gradient(#ff9e5f, #ff6f13 70%);
background: -o-linear-gradient(#ff9e5f, #ff6f13 70%);
background: linear-gradient(#ff9e5f, #ff6f13 70%);
-webkit-box-shadow: #ffccac 0 1px 0 inset;
-moz-box-shadow: #ffccac 0 1px 0 inset;
box-shadow: #ffccac 0 1px 0 inset;
border: 1px solid #f96100;
color: white;
text-shadow: #d75400 0 -1px 0;
}
.btn-test:hover {
background-color: #f96100;
background: -webkit-gradient(linear, 50% 0%, 50% 100%, color-stop(3%, #ff8e46), color-stop(75%, #f96100));
background: -webkit-linear-gradient(#ff8e46 3%, #f96100 75%);
background: -moz-linear-gradient(#ff8e46 3%, #f96100 75%);
background: -o-linear-gradient(#ff8e46 3%, #f96100 75%);
background: linear-gradient(#ff8e46 3%, #f96100 75%);
text-decoration: none;
color: #fff !important;
}
.btn-test:active {
-webkit-box-shadow: #e95b00 0 1px 2px inset;
-moz-box-shadow: #e95b00 0 1px 2px inset;
box-shadow: #e95b00 0 1px 2px inset;
}
.btn-test.disabled, .btn-test[disabled] {
opacity: 0.6;
background: #ff6f13;
cursor: default;
-webkit-box-shadow: none;
-moz-box-shadow: none;
box-shadow: none;
}
.btn-test::-moz-focus-inner {
padding: 0 !important;
margin: -1px !important;
}
Category: DrupalMobileDrupal Planet