zen-grids 2.0.0.beta.1 → 2.0.0.beta.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (62) hide show
  1. checksums.yaml +7 -7
  2. data/.travis.yml +13 -0
  3. data/README.md +81 -0
  4. data/bower.json +14 -12
  5. data/sache.json +5 -0
  6. data/templates/project/_base-elements.scss +22 -0
  7. data/templates/project/_components.scss +73 -0
  8. data/templates/project/_init.scss +14 -4
  9. data/templates/project/_layouts.scss +143 -0
  10. data/templates/project/_visually-hidden.scss +2 -18
  11. data/templates/project/example.html +53 -24
  12. data/templates/project/manifest.rb +3 -2
  13. data/templates/project/styles.scss +3 -2
  14. data/tests/Gemfile +11 -0
  15. data/tests/README.md +16 -0
  16. data/tests/Rakefile +25 -0
  17. data/tests/config.rb +22 -0
  18. data/tests/controls/compass-compatibility.css +112 -0
  19. data/{templates/unit-tests/test-results → tests/controls}/function-zen-direction-switch.css +1 -1
  20. data/{templates/unit-tests/test-results → tests/controls}/function-zen-grid-item-width.css +0 -0
  21. data/{templates/unit-tests/test-results → tests/controls}/function-zen-half-gutter.css +0 -0
  22. data/{templates/unit-tests/test-results → tests/controls}/function-zen-unit-width.css +0 -0
  23. data/{templates/unit-tests/test-results → tests/controls}/zen-float.css +0 -0
  24. data/{templates/unit-tests/test-results/zen-grid-flow-item.css → tests/controls/zen-flow-item-width.css} +21 -55
  25. data/tests/controls/zen-grid-background.css +52 -0
  26. data/{templates/unit-tests/test-results → tests/controls}/zen-grid-container.css +20 -5
  27. data/{templates/unit-tests/test-results → tests/controls}/zen-grid-item-base.css +9 -12
  28. data/{templates/unit-tests/test-results → tests/controls}/zen-grid-item.css +14 -2
  29. data/{templates/unit-tests/test-results → tests/controls}/zen-new-row.css +0 -0
  30. data/tests/tests/compass-compatibility.scss +55 -0
  31. data/{templates/unit-tests/sass → tests/tests}/function-zen-direction-switch.scss +1 -0
  32. data/{templates/unit-tests/sass → tests/tests}/function-zen-grid-item-width.scss +6 -6
  33. data/{templates/unit-tests/sass → tests/tests}/function-zen-half-gutter.scss +2 -2
  34. data/{templates/unit-tests/sass → tests/tests}/function-zen-unit-width.scss +12 -12
  35. data/{templates/unit-tests/sass → tests/tests}/zen-float.scss +3 -3
  36. data/tests/tests/zen-flow-item-width.scss +85 -0
  37. data/tests/tests/zen-grid-background.scss +85 -0
  38. data/tests/tests/zen-grid-container.scss +49 -0
  39. data/tests/tests/zen-grid-item-base.scss +65 -0
  40. data/tests/tests/zen-grid-item.scss +101 -0
  41. data/{templates/unit-tests/sass → tests/tests}/zen-new-row.scss +3 -3
  42. data/tests/unit_tests.rb +57 -0
  43. data/zen-grids.gemspec +4 -45
  44. data/zen-grids/_background.scss +97 -157
  45. data/zen-grids/_flow.scss +39 -22
  46. data/zen-grids/_functions.scss +119 -0
  47. data/zen-grids/_grids.scss +71 -171
  48. data/zen-grids/_variables.scss +65 -0
  49. data/zen-grids/internal/_functions-compass-polyfill.scss +70 -0
  50. data/zen-grids/internal/_variables-background.scss +57 -0
  51. metadata +80 -69
  52. data/README.txt +0 -88
  53. data/templates/project/_layout.scss +0 -117
  54. data/templates/project/_modules.scss +0 -78
  55. data/templates/unit-tests/README.txt +0 -16
  56. data/templates/unit-tests/manifest.rb +0 -37
  57. data/templates/unit-tests/sass/zen-grid-background.scss +0 -80
  58. data/templates/unit-tests/sass/zen-grid-container.scss +0 -44
  59. data/templates/unit-tests/sass/zen-grid-flow-item.scss +0 -78
  60. data/templates/unit-tests/sass/zen-grid-item-base.scss +0 -59
  61. data/templates/unit-tests/sass/zen-grid-item.scss +0 -91
  62. data/templates/unit-tests/test-results/zen-grid-background.css +0 -60
@@ -0,0 +1,85 @@
1
+ /**
2
+ * @file
3
+ * Test zen-grid-background()
4
+ */
5
+
6
+ @import "zen-grids/background";
7
+
8
+ #test-zen-grid-background {
9
+ /* Test zen-grid-background() with 1 column grid and 20px gutter */
10
+ $zen-grid-numbers: top !global;
11
+ @include zen-grid-background();
12
+ $zen-grid-numbers: both !global;
13
+
14
+ /* Test zen-grid-background() with margin gutter method, 5 column grid and 5% gutter */
15
+ $zen-columns: 5 !global;
16
+ $zen-gutters: 5% !global;
17
+ $zen-gutter-method: margin !global;
18
+ $zen-grid-numbers: top !global;
19
+ @include zen-grid-background();
20
+ $zen-columns: 1 !global;
21
+ $zen-gutters: 20px !global;
22
+ $zen-gutter-method: padding !global;
23
+ $zen-grid-numbers: both !global;
24
+
25
+ // Turn off numbers for all other tests.
26
+ $zen-grid-numbers: none !global;
27
+
28
+ /* Test zen-grid-background() with 12 column grid and 20px gutter */
29
+ $zen-columns: 12 !global;
30
+ @include zen-grid-background();
31
+ $zen-columns: 1 !global;
32
+
33
+ /* Test zen-grid-background(), 5 column grid, 10% gutter and black grid color */
34
+ $zen-columns: 5 !global;
35
+ $zen-gutters: 10% !global;
36
+ $zen-grid-color: #000 !global;
37
+ @include zen-grid-background();
38
+ $zen-columns: 1 !global;
39
+ $zen-gutters: 20px !global;
40
+ $zen-grid-color: rgba(#ffdede, 0.8) !global;
41
+
42
+ /* Test zen-grid-background() with 5 column grid and 40px gutter */
43
+ $zen-columns: 5 !global;
44
+ $zen-gutters: 40px !global;
45
+ @include zen-grid-background();
46
+ $zen-columns: 1 !global;
47
+ $zen-gutters: 20px !global;
48
+
49
+ /* Test zen-grid-background(), 5 column grid and 10% gutter and $zen-switch-direction */
50
+ $zen-columns: 5 !global;
51
+ $zen-gutters: 10% !global;
52
+ $zen-switch-direction: true !global;
53
+ @include zen-grid-background();
54
+ $zen-columns: 1 !global;
55
+ $zen-gutters: 20px !global;
56
+ $zen-switch-direction: false !global;
57
+
58
+ /* Test zen-grid-background() with 5 column grid and 40px gutter and $zen-switch-direction */
59
+ $zen-columns: 5 !global;
60
+ $zen-gutters: 40px !global;
61
+ $zen-switch-direction: true !global;
62
+ @include zen-grid-background();
63
+ $zen-columns: 1 !global;
64
+ $zen-gutters: 20px !global;
65
+ $zen-switch-direction: false !global;
66
+
67
+ /* Test zen-grid-background() with $zen-grid-width: 1000px, 5 column grid and 40px gutter */
68
+ $zen-grid-width: 1000px !global;
69
+ $zen-columns: 5 !global;
70
+ $zen-gutters: 40px !global;
71
+ @include zen-grid-background();
72
+ $zen-grid-width: 100% !global;
73
+ $zen-columns: 1 !global;
74
+ $zen-gutters: 20px !global;
75
+
76
+ /* Test zen-grid-background() with all 24 grid numbers */
77
+ $zen-columns: 24 !global;
78
+ @include zen-grid-background();
79
+ $zen-columns: 1 !global;
80
+
81
+ /* Test zen-grid-background() with $display-zen-grid-background: false */
82
+ $display-zen-grid-background: false !global;
83
+ @include zen-grid-background();
84
+ $display-zen-grid-background: true !global;
85
+ }
@@ -0,0 +1,49 @@
1
+ /**
2
+ * @file
3
+ * Test zen-grid-container()
4
+ */
5
+
6
+ @import "zen-grids";
7
+
8
+ #test-zen-grid-container {
9
+ /* Test zen-grid-container() */
10
+ @include zen-grid-container();
11
+ }
12
+
13
+ #test-zen-grid-container-2 {
14
+ /* Test zen-grid-container() with IE 7 support */
15
+ $browser-minimum-versions: (ie: "7") !global;
16
+ @include zen-grid-container();
17
+ $browser-minimum-versions: (ie: null) !global;
18
+ }
19
+
20
+ #test-zen-grid-container-3 {
21
+ /* Test zen-grid-container() with IE 6 support */
22
+ $browser-minimum-versions: (ie: "6") !global;
23
+ @include zen-grid-container();
24
+ $browser-minimum-versions: (ie: null) !global;
25
+ }
26
+
27
+ #test-zen-grid-container-4 {
28
+ /* Test zen-grid-container() with $context: grid-item */
29
+ @include zen-grid-container(grid-item);
30
+ }
31
+
32
+ #test-zen-grid-container-5 {
33
+ /* Test zen-grid-container() with $context: flow and $gutters: 21px */
34
+ @include zen-grid-container(flow, $gutters: 21px);
35
+ }
36
+
37
+ #test-zen-grid-container-6 {
38
+ /* Test zen-grid-container() with $context: flow and $gutters: 21px and $zen-switch-direction: true */
39
+ $zen-switch-direction: true !global;
40
+ @include zen-grid-container(flow, $gutters: 21px);
41
+ $zen-switch-direction: false !global;
42
+ }
43
+
44
+ #test-zen-grid-container-7 {
45
+ /* Test zen-grid-container() with $zen-gutter-method: margin */
46
+ $zen-gutter-method: margin !global;
47
+ @include zen-grid-container();
48
+ $zen-gutter-method: padding !global;
49
+ }
@@ -0,0 +1,65 @@
1
+ /**
2
+ * @file
3
+ * Test zen-grid-item-base()
4
+ */
5
+
6
+ @import "zen-grids";
7
+
8
+ #test-zen-grid-item-base {
9
+ /* Test zen-grid-item-base() */
10
+ @include zen-grid-item-base();
11
+
12
+ /* Test zen-grid-item-base() with $zen-box-sizing: content-box */
13
+ $zen-box-sizing: content-box !global;
14
+ @include zen-grid-item-base();
15
+ $zen-box-sizing: border-box !global;
16
+
17
+ /* Test zen-grid-item-base() with $zen-box-sizing: universal-border-box */
18
+ $zen-box-sizing: universal-border-box !global;
19
+ @include zen-grid-item-base();
20
+ $zen-box-sizing: border-box !global;
21
+
22
+ /* Test zen-grid-item-base() with IE 7 support */
23
+ $browser-minimum-versions: (ie: "7") !global;
24
+ @warn "The following test will generate a warning.";
25
+ @include zen-grid-item-base();
26
+ $browser-minimum-versions: (ie: null) !global;
27
+
28
+ /* Test zen-grid-item-base() with $box-sizing-polyfill-path: "/boxsizing.htc" and IE 7 support */
29
+ $box-sizing-polyfill-path: "/boxsizing.htc" !global;
30
+ $browser-minimum-versions: (ie: "7") !global;
31
+ @include zen-grid-item-base();
32
+ $box-sizing-polyfill-path: "" !global;
33
+ $browser-minimum-versions: (ie: null) !global;
34
+
35
+ /* Test zen-grid-item-base() with $box-sizing-polyfill-path: "/boxsizing.htc" and IE 6 support */
36
+ $box-sizing-polyfill-path: "/boxsizing.htc" !global;
37
+ $browser-minimum-versions: (ie: "6") !global;
38
+ @include zen-grid-item-base();
39
+ $box-sizing-polyfill-path: "" !global;
40
+ $browser-minimum-versions: (ie: null) !global;
41
+
42
+ /* Test zen-grid-item-base() with $zen-gutters: 15px */
43
+ $zen-gutters: 15px !global;
44
+ @include zen-grid-item-base();
45
+ $zen-gutters: 20px !global;
46
+
47
+ /* Test zen-grid-item-base() with $zen-gutters: 15px and $zen-direction: right */
48
+ $zen-gutters: 15px !global;
49
+ $zen-direction: right !global;
50
+ @include zen-grid-item-base();
51
+ $zen-gutters: 20px !global;
52
+ $zen-direction: left !global;
53
+
54
+ /* Test zen-grid-item-base() with $zen-gutters: 15px and $zen-switch-direction: true */
55
+ $zen-gutters: 15px !global;
56
+ $zen-switch-direction: true !global;
57
+ @include zen-grid-item-base();
58
+ $zen-gutters: 20px !global;
59
+ $zen-switch-direction: false !global;
60
+
61
+ /* Test zen-grid-item-base() with $zen-gutter-method: margin */
62
+ $zen-gutter-method: margin !global;
63
+ @include zen-grid-item-base();
64
+ $zen-gutter-method: padding !global;
65
+ }
@@ -0,0 +1,101 @@
1
+ /**
2
+ * @file
3
+ * Test zen-grid-item()
4
+ */
5
+
6
+ @import "zen-grids";
7
+
8
+ #test-zen-grid-item {
9
+ /* Test zen-grid-item(6, 4) with 12 column grid and 20px gutter */
10
+ $zen-columns: 12 !global;
11
+ @include zen-grid-item(6, 4);
12
+ $zen-columns: 1 !global;
13
+
14
+ /* Test zen-grid-item(6, 4) with 12 column grid and 20px gutter and $zen-box-sizing: universal-border-box */
15
+ $zen-columns: 12 !global;
16
+ $zen-box-sizing: universal-border-box !global;
17
+ @include zen-grid-item(6, 4);
18
+ $zen-columns: 1 !global;
19
+ $zen-box-sizing: border-box !global;
20
+
21
+ /* Test zen-grid-item(3, 3) with box-sizing: content-box, 5 column grid and 10% gutter */
22
+ $zen-columns: 5 !global;
23
+ $zen-gutters: 10% !global;
24
+ $zen-box-sizing: content-box !global;
25
+ @include zen-grid-item(3, 3);
26
+ $zen-columns: 1 !global;
27
+ $zen-gutters: 20px !global;
28
+ $zen-box-sizing: border-box !global;
29
+
30
+ /* Turn off $zen-auto-include-grid-item-base */
31
+ $zen-auto-include-grid-item-base: false !global;
32
+
33
+ /* Test zen-grid-item(3, 3) with 5 column grid and 40px gutter */
34
+ $zen-columns: 5 !global;
35
+ $zen-gutters: 40px !global;
36
+ @include zen-grid-item(3, 3);
37
+ $zen-columns: 1 !global;
38
+ $zen-gutters: 20px !global;
39
+
40
+ /* Test zen-grid-item(3, 3, right) with 5 column grid and 40px gutter */
41
+ $zen-columns: 5 !global;
42
+ $zen-gutters: 40px !global;
43
+ @include zen-grid-item(3, 3, right);
44
+ $zen-columns: 1 !global;
45
+ $zen-gutters: 20px !global;
46
+
47
+ /* Test zen-grid-item(3, 3) with 5 column grid and 40px gutter and $zen-switch-direction */
48
+ $zen-columns: 5 !global;
49
+ $zen-gutters: 40px !global;
50
+ $zen-switch-direction: true !global;
51
+ @include zen-grid-item(3, 3);
52
+ $zen-columns: 1 !global;
53
+ $zen-gutters: 20px !global;
54
+ $zen-switch-direction: false !global;
55
+
56
+ /* Test zen-grid-item(3, 3, right) with 5 column grid and 40px gutter and $zen-switch-direction */
57
+ $zen-columns: 5 !global;
58
+ $zen-gutters: 40px !global;
59
+ $zen-switch-direction: true !global;
60
+ @include zen-grid-item(3, 3, right);
61
+ $zen-columns: 1 !global;
62
+ $zen-gutters: 20px !global;
63
+ $zen-switch-direction: false !global;
64
+
65
+ /* Test zen-grid-item(3, 2.5) with 5 column grid and 40px gutter */
66
+ $zen-columns: 5 !global;
67
+ $zen-gutters: 40px !global;
68
+ @include zen-grid-item(3, 2.5);
69
+ $zen-columns: 1 !global;
70
+ $zen-gutters: 20px !global;
71
+
72
+ /* Test zen-grid-item(3, 3) with $zen-grid-width: 1000px, 5 column grid and 40px gutter */
73
+ $zen-grid-width: 1000px !global;
74
+ $zen-columns: 5 !global;
75
+ $zen-gutters: 40px !global;
76
+ @include zen-grid-item(3, 3);
77
+ $zen-grid-width: 100% !global;
78
+ $zen-columns: 1 !global;
79
+ $zen-gutters: 20px !global;
80
+
81
+ /* Test zen-grid-item(3, 3) with $zen-gutter-method: margin, 5 column grid and 5% gutter */
82
+ $zen-gutter-method: margin !global;
83
+ $zen-columns: 5 !global;
84
+ $zen-gutters: 5% !global;
85
+ @include zen-grid-item(3, 3);
86
+ $zen-gutter-method: padding !global;
87
+ $zen-columns: 1 !global;
88
+ $zen-gutters: 20px !global;
89
+
90
+ /* Test zen-grid-item(3, 2.5) with $zen-gutter-method: margin, 5 column grid and 5% gutter */
91
+ $zen-gutter-method: margin !global;
92
+ $zen-columns: 5 !global;
93
+ $zen-gutters: 5% !global;
94
+ @include zen-grid-item(3, 2.5);
95
+ $zen-gutter-method: padding !global;
96
+ $zen-columns: 1 !global;
97
+ $zen-gutters: 20px !global;
98
+
99
+ /* Test zen-grid-item(1, 1) with $gutters: 10px and $zen-auto-include-grid-item-base: false */
100
+ @include zen-grid-item(1, 1, $gutters: 10px);
101
+ }
@@ -10,9 +10,9 @@
10
10
  @include zen-new-row();
11
11
 
12
12
  /* Test zen-new-row() with $zen-direction: right */
13
- $zen-direction: right;
13
+ $zen-direction: right !global;
14
14
  @include zen-new-row();
15
- $zen-direction: left;
15
+ $zen-direction: left !global;
16
16
 
17
17
  /* Test zen-new-row(left) */
18
18
  @include zen-new-row(left);
@@ -21,6 +21,6 @@
21
21
  @include zen-new-row(left, $switch-direction: TRUE);
22
22
 
23
23
  /* Test zen-new-row(left) with: $zen-switch-direction: TRUE; */
24
- $zen-switch-direction: TRUE;
24
+ $zen-switch-direction: TRUE !global;
25
25
  @include zen-new-row(left);
26
26
  }
@@ -0,0 +1,57 @@
1
+ # Navigator | Copyright 2013 Team Sass | MIT License | https://github.com/Team-Sass/navigator
2
+
3
+ require 'compass'
4
+ require 'compass/exec'
5
+ require 'test/unit'
6
+ require 'diffy'
7
+ require 'colorize'
8
+ require 'pathname'
9
+
10
+ class TestCompassOutput < Test::Unit::TestCase
11
+
12
+ Compass.add_configuration 'config.rb'
13
+ Compass.configuration.project_path = Dir.pwd
14
+
15
+ # Remove all current Diff files
16
+ Dir.glob("#{Dir.pwd}/output/**/*.css.diff").each { |f| File.delete(f) }
17
+
18
+ Compass.compiler.sass_files.each do |sass_file|
19
+ test_name = File.basename(sass_file, '.*')
20
+
21
+ define_method "test_#{test_name}_compile " do
22
+ # Compiled CSS file path
23
+ test_file_pwd = Compass.compiler.corresponding_css_file(sass_file)
24
+
25
+ # Relative path of compiled CSS file from Tests directory
26
+ relative_pwd = Pathname.new(test_file_pwd).relative_path_from(Pathname.new("#{Dir.pwd}/output")).to_s
27
+
28
+ # Control files path
29
+ control_file_pwd = "#{Dir.pwd}/controls/" + relative_pwd
30
+
31
+ # The base path of the sub folders, making the folders if needed
32
+ base_pwd = relative_pwd.sub(File.basename(relative_pwd), '')
33
+ FileUtils.mkdir_p "#{Dir.pwd}/output/#{base_pwd}"
34
+
35
+ # Compiles Sass file
36
+ Compass.compiler.compile sass_file, test_file_pwd # Raises exception upon error
37
+
38
+ begin
39
+ # Assert that our test output matches our control output
40
+ passed = assert FileUtils.compare_file(test_file_pwd, control_file_pwd), "Compiled output for #{File.basename(sass_file)} does not match control output!".red
41
+ ensure
42
+ # If there is a failure, generate a diff of the files and put it with the compiled file
43
+ if !passed
44
+ test_file = File.open(test_file_pwd).read;
45
+ control_file = File.open(control_file_pwd).read;
46
+ diff_pwd = "#{Dir.pwd}/output/#{relative_pwd}.diff"
47
+ diff_content = Diffy::Diff.new(control_file, test_file, :include_diff_info => true)
48
+
49
+ File.open(diff_pwd, 'w') { |f| f.write(diff_content.to_s(:text)) }
50
+
51
+ puts "Control->Compiled diff output to ".yellow + " tests/output/#{relative_pwd}.diff ".colorize( :color => :blue, :background => :black)
52
+ end
53
+ end
54
+ end
55
+ end
56
+ end
57
+
data/zen-grids.gemspec CHANGED
@@ -9,55 +9,14 @@ Gem::Specification.new do |s|
9
9
  s.homepage = 'http://zengrids.com'
10
10
  s.rubyforge_project =
11
11
 
12
- s.version = '2.0.0.beta.1'
13
- s.date = '2013-07-22'
12
+ s.version = '2.0.0.beta.2'
13
+ s.date = '2014-03-11'
14
14
  s.licenses = ['GPL-2']
15
15
 
16
16
  s.authors = ['John Albin Wilkins']
17
17
  s.email = 'virtually.johnalbin@gmail.com'
18
18
 
19
- s.add_runtime_dependency('sass', ">= 3.2")
19
+ s.add_runtime_dependency('sass', ">= 3.3")
20
20
 
21
- s.files = %w[
22
- bower.json
23
- LICENSE.txt
24
- README.txt
25
- lib/zen-grids.rb
26
- _zen-grids.scss
27
- zen-grids/_background.scss
28
- zen-grids/_flow.scss
29
- zen-grids/_grids.scss
30
- templates/project/_init.scss
31
- templates/project/_layout.scss
32
- templates/project/_modules.scss
33
- templates/project/_visually-hidden.scss
34
- templates/project/example.html
35
- templates/project/manifest.rb
36
- templates/project/styles.scss
37
- templates/unit-tests/manifest.rb
38
- templates/unit-tests/README.txt
39
- templates/unit-tests/sass/function-zen-direction-switch.scss
40
- templates/unit-tests/sass/function-zen-grid-item-width.scss
41
- templates/unit-tests/sass/function-zen-half-gutter.scss
42
- templates/unit-tests/sass/function-zen-unit-width.scss
43
- templates/unit-tests/sass/zen-new-row.scss
44
- templates/unit-tests/sass/zen-float.scss
45
- templates/unit-tests/sass/zen-grid-background.scss
46
- templates/unit-tests/sass/zen-grid-container.scss
47
- templates/unit-tests/sass/zen-grid-flow-item.scss
48
- templates/unit-tests/sass/zen-grid-item-base.scss
49
- templates/unit-tests/sass/zen-grid-item.scss
50
- templates/unit-tests/test-results/function-zen-direction-switch.css
51
- templates/unit-tests/test-results/function-zen-grid-item-width.css
52
- templates/unit-tests/test-results/function-zen-half-gutter.css
53
- templates/unit-tests/test-results/function-zen-unit-width.css
54
- templates/unit-tests/test-results/zen-new-row.css
55
- templates/unit-tests/test-results/zen-float.css
56
- templates/unit-tests/test-results/zen-grid-background.css
57
- templates/unit-tests/test-results/zen-grid-container.css
58
- templates/unit-tests/test-results/zen-grid-flow-item.css
59
- templates/unit-tests/test-results/zen-grid-item-base.css
60
- templates/unit-tests/test-results/zen-grid-item.css
61
- zen-grids.gemspec
62
- ]
21
+ s.files = `git ls-files -z`.split "\0"
63
22
  end
@@ -3,78 +3,14 @@
3
3
  //
4
4
 
5
5
 
6
- @import "grids";
7
- @import "compass/css3/images";
8
-
9
- // Specify the color of the background grid.
10
- $zen-grid-color : #ffdede !default;
11
-
12
- // Specify which set of numbers to display with the background grid. Can be set
13
- // to: both, top, or none.
14
- $zen-grid-numbers : both !default;
15
-
16
- // Create an image set of 25 numbers for the grid using data URIs. Users who are
17
- // crazy enough to use a 26-column grid or larger are free to extend this set.
18
- $zen-grid-number-images : () !default;
19
-
20
- // If the set is empty, add our default set of 25.
21
- @if length($zen-grid-number-images) == 0 {
22
- // The number 1.
23
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
24
- // The number 2.
25
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
26
- // The number 3.
27
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
28
- // The number 4.
29
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
30
- // The number 5.
31
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
32
- // The number 6.
33
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
34
- // The number 7.
35
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
36
- // The number 8.
37
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
38
- // The number 9.
39
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
40
- // The number 10.
41
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
42
- // The number 11.
43
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
44
- // The number 12.
45
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
46
- // The number 13.
47
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
48
- // The number 14.
49
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
50
- // The number 15.
51
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
52
- // The number 16.
53
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
54
- // The number 17.
55
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
56
- // The number 18.
57
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
58
- // The number 19.
59
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
60
- // The number 20.
61
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
62
- // The number 21.
63
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
64
- // The number 22.
65
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
66
- // The number 23.
67
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
68
- // The number 24.
69
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
70
- // The number 25.
71
- $zen-grid-number-images : append($zen-grid-number-images, url(''));
72
- }
6
+ @import "zen-grids/functions";
7
+ @import "zen-grids/internal/variables-background"; // Add the default set of background images.
8
+ @import "compass/css3/images"; // Unlike the rest of Zen Grids, this module requires Compass.
73
9
 
74
10
 
75
11
  //
76
12
  // Add a background grid image to an element's background.
77
- // @see http://zengrids.com/help/#zen-grid-background
13
+ // @see http://next.zengrids.com/reference/background/#zen-grid-background
78
14
  //
79
15
  @mixin zen-grid-background(
80
16
  $columns : $zen-columns,
@@ -87,113 +23,117 @@ $zen-grid-number-images : () !default;
87
23
  $switch-direction : $zen-switch-direction
88
24
  ) {
89
25
 
90
- $bg-images : ();
91
- $gradient : ();
92
- $left-half-gradient : ();
93
- $right-half-gradient : ();
26
+ // Check if the global variable is turning off background images.
27
+ @if $display-zen-grid-background {
94
28
 
95
- // Calculate half of the unit width.
96
- $unit-width : zen-unit-width($columns, $gutters, $gutter-method, $grid-width);
97
- $half-unit-width : $unit-width / 2;
29
+ $bg-images : ();
30
+ $gradient : ();
31
+ $left-half-gradient : ();
32
+ $right-half-gradient : ();
98
33
 
99
- // Determine the float direction.
100
- $dir : $direction;
101
- @if $switch-direction {
102
- $dir : zen-direction-switch($dir);
103
- }
34
+ // Calculate half of the unit width.
35
+ $unit-width : zen-unit-width($columns, $gutters, $gutter-method, $grid-width);
36
+ $half-unit-width : $unit-width / 2;
104
37
 
105
- @for $count from 1 through $columns {
106
- // First add the grid numbers to the background images list.
107
- $position: (2 * $count - 1) * $half-unit-width;
108
- @if $gutter-method == margin {
109
- $position: $position + ($count - 1) * $gutters;
38
+ // Determine the float direction.
39
+ $dir : $direction;
40
+ @if $switch-direction {
41
+ $dir : zen-direction-switch($dir);
110
42
  }
111
- $reverse-count: $columns + 1 - $count;
112
43
 
113
- @if $dir == left {
114
- @if $grid-numbers == both or $grid-numbers == top {
115
- $bg-images : append($bg-images, nth($zen-grid-number-images, $count) $position top no-repeat, comma);
44
+ @for $count from 1 through $columns {
45
+ // First add the grid numbers to the background images list.
46
+ $position: (2 * $count - 1) * $half-unit-width;
47
+ @if $gutter-method == margin {
48
+ $position: $position + ($count - 1) * $gutters;
116
49
  }
117
- @if $grid-numbers == both or $grid-numbers == bottom {
118
- $bg-images : append($bg-images, nth($zen-grid-number-images, $reverse-count) $position bottom no-repeat, comma);
119
- }
120
- }
121
- @else {
122
- @if $grid-numbers == both or $grid-numbers == bottom {
123
- $bg-images : append($bg-images, nth($zen-grid-number-images, $count) $position bottom no-repeat, comma);
50
+ $reverse-count: $columns + 1 - $count;
51
+
52
+ @if $dir == left {
53
+ @if $grid-numbers == both or $grid-numbers == top {
54
+ $bg-images : append($bg-images, nth($zen-grid-number-images, $count) $position top no-repeat, comma);
55
+ }
56
+ @if $grid-numbers == both or $grid-numbers == bottom {
57
+ $bg-images : append($bg-images, nth($zen-grid-number-images, $reverse-count) $position bottom no-repeat, comma);
58
+ }
124
59
  }
125
- @if $grid-numbers == both or $grid-numbers == top {
126
- $bg-images : append($bg-images, nth($zen-grid-number-images, $reverse-count) $position top no-repeat, comma);
60
+ @else {
61
+ @if $grid-numbers == both or $grid-numbers == bottom {
62
+ $bg-images : append($bg-images, nth($zen-grid-number-images, $count) $position bottom no-repeat, comma);
63
+ }
64
+ @if $grid-numbers == both or $grid-numbers == top {
65
+ $bg-images : append($bg-images, nth($zen-grid-number-images, $reverse-count) $position top no-repeat, comma);
66
+ }
127
67
  }
128
- }
129
68
 
130
- // Next, build the color stops for the column gradients.
131
- @if $gutter-method == margin {
132
- // If the gutter method is "margin", calculating the color stops is easy.
133
- @if $count < $columns {
134
- $stop: $count * $unit-width + ($count - 1) * $gutters;
135
- $gradient: append($gradient, $grid-color $stop, comma);
69
+ // Next, build the color stops for the column gradients.
70
+ @if $gutter-method == margin {
71
+ // If the gutter method is "margin", calculating the color stops is easy.
72
+ @if $count < $columns {
73
+ $stop: $count * $unit-width + ($count - 1) * $gutters;
74
+ $gradient: append($gradient, $grid-color $stop, comma);
75
+ $gradient: append($gradient, transparent $stop, comma);
76
+
77
+ $stop: $stop + $gutters;
78
+ $gradient: append($gradient, transparent $stop, comma);
79
+ $gradient: append($gradient, $grid-color $stop, comma);
80
+ }
81
+ }
82
+ @else if comparable($gutters, $grid-width) {
83
+ // If the gutter and grid width have the same units, calculating the color
84
+ // stops is easy.
85
+ $stop: ($count - 1) * $unit-width + zen-half-gutter($gutters);
136
86
  $gradient: append($gradient, transparent $stop, comma);
87
+ $gradient: append($gradient, $grid-color $stop, comma);
137
88
 
138
- $stop: $stop + $gutters;
139
- $gradient: append($gradient, transparent $stop, comma);
89
+ $stop: $count * $unit-width - zen-half-gutter($gutters);
140
90
  $gradient: append($gradient, $grid-color $stop, comma);
91
+ $gradient: append($gradient, transparent $stop, comma);
141
92
  }
142
- }
143
- @else if comparable($gutters, $grid-width) {
144
- // If the gutter and grid width have the same units, calculating the color
145
- // stops is easy.
146
- $stop: ($count - 1) * $unit-width + zen-half-gutter($gutters);
147
- $gradient: append($gradient, transparent $stop, comma);
148
- $gradient: append($gradient, $grid-color $stop, comma);
149
-
150
- $stop: $count * $unit-width - zen-half-gutter($gutters);
151
- $gradient: append($gradient, $grid-color $stop, comma);
152
- $gradient: append($gradient, transparent $stop, comma);
153
- }
154
- @else {
155
- // If the gutter and grid width have different units, things are tricky.
156
- // The CSS3 Gradient syntax doesn't allow for calc() to be used in color
157
- // stops, so we can't express the columns as 20% + 10px. Instead we are
158
- // going to divide all our columns in half and into 2 groups: one group
159
- // for the left halves of the columns and one group for the right halves.
160
- // Then we'll use background position to shift the left halves over to the
161
- // right by a half gutter width and shift the right halves over to the
162
- // left by a half gutter width and just let the two sets of gradients
163
- // overlap in the middle. Easy.
164
-
165
- // Build the color stops for the left halves of the column gradients.
166
- @if $count > 1 {
167
- $stop: (2 * $count - 2) * $half-unit-width;
168
- $left-half-gradient: append($left-half-gradient, transparent $stop, comma);
93
+ @else {
94
+ // If the gutter and grid width have different units, things are tricky.
95
+ // The CSS3 Gradient syntax doesn't allow for calc() to be used in color
96
+ // stops, so we can't express the columns as 20% + 10px. Instead we are
97
+ // going to divide all our columns in half and into 2 groups: one group
98
+ // for the left halves of the columns and one group for the right halves.
99
+ // Then we'll use background position to shift the left halves over to the
100
+ // right by a half gutter width and shift the right halves over to the
101
+ // left by a half gutter width and just let the two sets of gradients
102
+ // overlap in the middle. Easy.
103
+
104
+ // Build the color stops for the left halves of the column gradients.
105
+ @if $count > 1 {
106
+ $stop: (2 * $count - 2) * $half-unit-width;
107
+ $left-half-gradient: append($left-half-gradient, transparent $stop, comma);
108
+ $left-half-gradient: append($left-half-gradient, $grid-color $stop, comma);
109
+ }
110
+
111
+ $stop: (2 * $count - 1) * $half-unit-width;
169
112
  $left-half-gradient: append($left-half-gradient, $grid-color $stop, comma);
170
- }
171
-
172
- $stop: (2 * $count - 1) * $half-unit-width;
173
- $left-half-gradient: append($left-half-gradient, $grid-color $stop, comma);
174
- $left-half-gradient: append($left-half-gradient, transparent $stop, comma);
175
-
176
- // Build the color stops for the right halves of the column gradients.
177
- $right-half-gradient: append($right-half-gradient, transparent $stop, comma);
178
- $right-half-gradient: append($right-half-gradient, $grid-color $stop, comma);
113
+ $left-half-gradient: append($left-half-gradient, transparent $stop, comma);
179
114
 
180
- @if $count < $columns {
181
- $stop: (2 * $count) * $half-unit-width;
182
- $right-half-gradient: append($right-half-gradient, $grid-color $stop, comma);
115
+ // Build the color stops for the right halves of the column gradients.
183
116
  $right-half-gradient: append($right-half-gradient, transparent $stop, comma);
117
+ $right-half-gradient: append($right-half-gradient, $grid-color $stop, comma);
118
+
119
+ @if $count < $columns {
120
+ $stop: (2 * $count) * $half-unit-width;
121
+ $right-half-gradient: append($right-half-gradient, $grid-color $stop, comma);
122
+ $right-half-gradient: append($right-half-gradient, transparent $stop, comma);
123
+ }
184
124
  }
185
125
  }
186
- }
187
126
 
188
- // Last, add the gradient (or gradient halves) to the background images list.
189
- @if $gutter-method == margin or comparable($gutters, $grid-width) {
190
- $bg-images : append($bg-images, linear-gradient(left, $gradient) left top no-repeat, comma);
191
- }
192
- @else {
193
- $bg-images : append($bg-images, linear-gradient(left, $left-half-gradient) zen-half-gutter($gutters) top no-repeat, comma);
194
- $bg-images : append($bg-images, linear-gradient(left, $right-half-gradient) (-(zen-half-gutter($gutters))) top no-repeat, comma);
195
- }
127
+ // Last, add the gradient (or gradient halves) to the background images list.
128
+ @if $gutter-method == margin or comparable($gutters, $grid-width) {
129
+ $bg-images : append($bg-images, linear-gradient(left, $gradient) left top no-repeat, comma);
130
+ }
131
+ @else {
132
+ $bg-images : append($bg-images, linear-gradient(left, $left-half-gradient) zen-half-gutter($gutters) top no-repeat, comma);
133
+ $bg-images : append($bg-images, linear-gradient(left, $right-half-gradient) (-(zen-half-gutter($gutters))) top no-repeat, comma);
134
+ }
196
135
 
197
- // Apply the full list of background images.
198
- @include background($bg-images);
136
+ // Apply the full list of background images.
137
+ @include background($bg-images);
138
+ }
199
139
  }