2012-03-13 03:06:01 +00:00
|
|
|
!SLIDE
|
|
|
|
# Sass
|
|
|
|
|
|
|
|
!SLIDE
|
|
|
|
# What is Sass?
|
2012-03-23 19:55:41 +00:00
|
|
|
## It's a preprocesor
|
2012-03-13 03:06:01 +00:00
|
|
|
|
|
|
|
!SLIDE
|
|
|
|
# What does it do?
|
|
|
|
|
|
|
|
* Variables `$foo`
|
|
|
|
* Mixins `@mixin`
|
|
|
|
* Functions
|
2012-03-13 15:49:37 +00:00
|
|
|
* Selector Inheritance `@extend, &`
|
2012-03-13 03:06:01 +00:00
|
|
|
* Control Directives `@if, @for, @each, @while`
|
2012-03-23 19:55:41 +00:00
|
|
|
* It's a language!
|
2012-03-13 03:06:01 +00:00
|
|
|
|
|
|
|
!SLIDE variables
|
|
|
|
# Variables
|
|
|
|
|
|
|
|
``` scss
|
|
|
|
|
|
|
|
$foo : #fffff;
|
|
|
|
$bar : (1px * 2em) / 4px;
|
|
|
|
|
|
|
|
```
|
|
|
|
|
2012-03-23 14:31:31 +00:00
|
|
|
!SLIDE
|
|
|
|
|
|
|
|
# Lists
|
|
|
|
|
|
|
|
``` css
|
|
|
|
border : 1px solid black;
|
|
|
|
```
|
|
|
|
|
|
|
|
!SLIDE
|
|
|
|
|
|
|
|
``` scss
|
|
|
|
$my-list : 1px solid black;
|
|
|
|
$my-list2 : 1px, solid, black;
|
|
|
|
$my-list3 : (1px solid black);
|
|
|
|
|
|
|
|
border : $my-list;
|
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
!SLIDE
|
|
|
|
|
2012-03-23 19:55:41 +00:00
|
|
|
# In Ruby
|
2012-03-23 14:31:31 +00:00
|
|
|
|
|
|
|
``` ruby
|
|
|
|
Sass::Script::List.new(['1px', 'solid', 'black'], ',')
|
|
|
|
```
|
|
|
|
|
|
|
|
!SLIDE
|
|
|
|
## List Functions
|
|
|
|
|
|
|
|
* `length($list)`
|
|
|
|
* `nth($list, $n)`
|
|
|
|
* `join($list1, $list2, [$separator])`
|
|
|
|
* More coming soon!
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-03-13 03:06:01 +00:00
|
|
|
!SLIDE mixins
|
|
|
|
|
|
|
|
# Functions and Mixins
|
|
|
|
|
|
|
|
``` scss
|
|
|
|
|
|
|
|
@function get-stops($colors, $stops) {
|
|
|
|
$out:();
|
|
|
|
@each $color in $colors {
|
|
|
|
$i: index($colors, $color);
|
|
|
|
$stop: 0% + nth($stops, $i);
|
|
|
|
$out: append($out, $color $stop, 'comma');
|
|
|
|
}
|
|
|
|
@return $out;
|
|
|
|
}
|
|
|
|
|
|
|
|
@mixin menu-level2-active {
|
|
|
|
$args: get-stops($menu-active-colors, $menu-active-stops);
|
|
|
|
@include background(linear-gradient($menu-active-direction, $args));
|
|
|
|
}
|
|
|
|
|
2012-03-13 15:49:37 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
!SLIDE inheritance
|
|
|
|
# Inheritance
|
|
|
|
``` scss
|
|
|
|
a {
|
|
|
|
color : $link-color;
|
|
|
|
|
|
|
|
&:hover {
|
|
|
|
color : $link-hover-color;
|
|
|
|
}
|
|
|
|
}
|
2012-03-21 17:09:22 +00:00
|
|
|
```
|
|
|
|
``` css
|
|
|
|
a { color : blue; }
|
|
|
|
a:hover { color : red; }
|
2012-03-13 15:49:37 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
!SLIDE extend
|
|
|
|
## Extend
|
|
|
|
``` scss
|
|
|
|
|
|
|
|
.foo {
|
|
|
|
font-size : 10px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.bar {
|
|
|
|
@extend .foo;
|
|
|
|
}
|
|
|
|
|
|
|
|
```
|
|
|
|
``` css
|
|
|
|
|
|
|
|
.foo, .bar {
|
|
|
|
font-size : 10px;
|
|
|
|
}
|
|
|
|
|
|
|
|
```
|
2012-03-23 14:31:31 +00:00
|
|
|
|
|
|
|
!SLIDE
|
2012-03-23 19:55:41 +00:00
|
|
|
## Extending with Ruby
|
2012-03-23 14:31:31 +00:00
|
|
|
|
|
|
|
``` ruby
|
|
|
|
def sprite(map, sprite, offset_x = ZERO, offset_y = ZERO)
|
|
|
|
sprite = convert_sprite_name(sprite)
|
|
|
|
verify_map(map)
|
|
|
|
unless sprite.is_a?(Sass::Script::String)
|
|
|
|
raise Sass::SyntaxError
|
|
|
|
end
|
|
|
|
url = sprite_url(map)
|
|
|
|
position = sprite_position(map, sprite, offset_x, offset_y)
|
|
|
|
Sass::Script::List.new([url] + position.value, :space)
|
|
|
|
end
|
|
|
|
Sass::Script::Functions.declare :sprite, [:map, :sprite]
|
|
|
|
Sass::Script::Functions.declare :sprite, [:map, :sprite, :offset_x]
|
|
|
|
Sass::Script::Functions.declare :sprite, [:map, :sprite, :offset_x, :offset_y]
|
|
|
|
```
|
|
|
|
|
|
|
|
!SLIDE
|
|
|
|
## Data types
|
|
|
|
|
|
|
|
* Bool
|
|
|
|
* Color
|
|
|
|
* List
|
|
|
|
* Number
|
|
|
|
* String
|