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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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
  }