gridle 1.0.6

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.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA512:
3
+ metadata.gz: 3e7f3698cd72415c66b25135e1a15fbf4c8ac8a35f94ebaae088c175f631ecd8529516e498b82ee8ccbf430eb35387e99034bd68f5aea28f819373919c637c2c
4
+ data.tar.gz: 1ca273584a19d04f0cd6e4729b9108cf50a129044f885b77f569b3775d16db5ace934ae33061a4de3c294ded3e25a9ebecc696dcbd014b7869289d3ab7c85526
5
+ SHA1:
6
+ metadata.gz: 00c4f50a3e1c5d897c9abe07fc5145c739ce99b0
7
+ data.tar.gz: ece8b4f437257d1aa38bb3f35d7872e19c5d12be
@@ -0,0 +1,30 @@
1
+ # All gems that are required for this extension to work should go here.
2
+ # These are the requires you would normally put in your config.rb file
3
+ # By default, you should always included Compass. Do not include your
4
+ # extension.
5
+ require 'compass'
6
+
7
+ # This tells Compass what your Compass extension is called, and where to find
8
+ # its files
9
+ # Replace 'extension' with the name of your extension. Spaces allowed.
10
+ extension_path = File.expand_path(File.join(File.dirname(__FILE__), ".."))
11
+ Compass::Frameworks.register('gridle', :path => extension_path)
12
+
13
+ # Version and date of version for your Compass extension.
14
+ # Replace Extension with the name of your extension
15
+ # Letters, numbers, and underscores only
16
+ # Version is a number. If a version contains alphas, it will be created as
17
+ # a prerelease version
18
+ # Date is in the form of YYYY-MM-DD
19
+ module Extension
20
+ VERSION = "1.0.6"
21
+ DATE = "2013-11-06"
22
+ end
23
+
24
+ # This is where any custom SassScript should be placed. The functions will be
25
+ # available on require of your extension without the need for users to import
26
+ # any partials. Uncomment below.
27
+
28
+ # module Sass::Script::Functions
29
+ #
30
+ # end
@@ -0,0 +1,4 @@
1
+ /**
2
+ * Imports :
3
+ */
4
+ @import 'gridle/gridle';
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports :
3
+ */
4
+ @import '12-columns';
5
+
6
+ /**
7
+ * Generate classes :
8
+ */
9
+ @include gridle_generate_classes();
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports :
3
+ */
4
+ @import '12-columns-responsive';
5
+
6
+ /**
7
+ * Generate classes :
8
+ */
9
+ @include gridle_generate_classes();
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Imports
3
+ */
4
+ @import 'gridle';
5
+
6
+ /**
7
+ * Configuration :
8
+ */
9
+ $gridle-columns-count : 12;
10
+
11
+ /**
12
+ * Register states :
13
+ */
14
+ @include gridle_register_default_states();
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports
3
+ */
4
+ @import 'gridle';
5
+
6
+ /**
7
+ * Configuration :
8
+ */
9
+ $gridle-columns-count : 12;
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports :
3
+ */
4
+ @import '16-columns';
5
+
6
+ /**
7
+ * Generate classes :
8
+ */
9
+ @include gridle_generate_classes();
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports :
3
+ */
4
+ @import '16-columns-responsive';
5
+
6
+ /**
7
+ * Generate classes :
8
+ */
9
+ @include gridle_generate_classes();
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Imports
3
+ */
4
+ @import 'gridle';
5
+
6
+ /**
7
+ * Configuration :
8
+ */
9
+ $gridle-columns-count : 16;
10
+
11
+ /**
12
+ * Register states :
13
+ */
14
+ @include gridle_register_default_states();
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports
3
+ */
4
+ @import 'gridle';
5
+
6
+ /**
7
+ * Configuration :
8
+ */
9
+ $gridle-columns-count : 16;
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports :
3
+ */
4
+ @import '24-columns';
5
+
6
+ /**
7
+ * Generate classes :
8
+ */
9
+ @include gridle_generate_classes();
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports :
3
+ */
4
+ @import '24-columns-responsive';
5
+
6
+ /**
7
+ * Generate classes :
8
+ */
9
+ @include gridle_generate_classes();
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Imports
3
+ */
4
+ @import 'gridle';
5
+
6
+ /**
7
+ * Configuration :
8
+ */
9
+ $gridle-columns-count : 24;
10
+
11
+ /**
12
+ * Register states :
13
+ */
14
+ @include gridle_register_default_states();
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports
3
+ */
4
+ @import 'gridle';
5
+
6
+ /**
7
+ * Configuration :
8
+ */
9
+ $gridle-columns-count : 24;
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports :
3
+ */
4
+ @import '960gs';
5
+
6
+ /**
7
+ * Generate classes :
8
+ */
9
+ @include gridle_generate_classes();
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Imports :
3
+ */
4
+ @import '960gs-responsive';
5
+
6
+ /**
7
+ * Generate classes :
8
+ */
9
+ @include gridle_generate_classes();
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Imports
3
+ */
4
+ @import 'gridle';
5
+
6
+ /**
7
+ * Configuration :
8
+ */
9
+ $gridle-columns-count : 12;
10
+ $gridle-gutter-width : 20px;
11
+
12
+ /**
13
+ * Register states :
14
+ */
15
+ @include gridle_register_default_states();
16
+
17
+ /**
18
+ * Fix width of container :
19
+ */
20
+ .container, .grid-container, .container-12, .c-12 {
21
+ max-width:960px;
22
+ margin:0 auto;
23
+ }
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Imports
3
+ */
4
+ @import 'gridle';
5
+
6
+ /**
7
+ * Configuration :
8
+ */
9
+ $gridle-columns-count : 12;
10
+ $gridle-gutter-width : 20px;
11
+
12
+ /**
13
+ * Fix width of container :
14
+ */
15
+ .container, .grid-container, .container-12, .c-12 {
16
+ max-width:960px;
17
+ margin:0 auto;
18
+ }
@@ -0,0 +1,1583 @@
1
+ // |------------------------------------------------------
2
+ // |------------------------------------------------------
3
+ // Gridle (.scss)
4
+ // Gridle is an one and unique grid system file that allows you to generate almost all
5
+ // grid you've ever dreamt about.
6
+ // |------------------------------------------------------
7
+ // |------------------------------------------------------
8
+
9
+ // |------------------------------------------------------
10
+ // |------------------------------------------------------
11
+ // Copyright (c) 2013 Olivier Bossel
12
+
13
+ // Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
14
+ // documentation files (the "Software"), to deal in the Software without restriction, including without limitation
15
+ // the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software,
16
+ // and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
17
+
18
+ // The above copyright notice and this permission notice shall be included in all copies or substantial portions
19
+ // of the Software.
20
+
21
+ // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
22
+ // TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
23
+ // THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF
24
+ // CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
25
+ // IN THE SOFTWARE.
26
+ // |------------------------------------------------------
27
+ // |------------------------------------------------------
28
+
29
+ // |------------------------------------------------------
30
+ // |------------------------------------------------------
31
+ // @created 25.03.13
32
+ // @updated 06.11.13
33
+ // @author Olivier Bossel <olivier.bossel@gmail.com>
34
+ // @version 1.0.5
35
+ // |------------------------------------------------------
36
+ // |------------------------------------------------------
37
+
38
+
39
+
40
+
41
+ // |------------------------------------------------------
42
+ // |------------------------------------------------------
43
+ // | Settings
44
+ // |------------------------------------------------------
45
+ // |------------------------------------------------------
46
+
47
+
48
+ // gridle configuration vars :
49
+ $gridle-columns-count : 12 !default;
50
+ $gridle-gutter-width : 20px !default;
51
+ $gridle-name-multiplicator : 1 !default;
52
+
53
+ $gridle-direction : ltr !default;
54
+
55
+ $gridle-debug : false !default;
56
+ $gridle-debug-show-class-names : true !default;
57
+
58
+ $gridle-ie7-support : true !default;
59
+
60
+ $gridle-html-states-classes : false !default;
61
+
62
+ $gridle-generate-helpers-classes : true !default;
63
+ $gridle-generate-push-classes : true !default;
64
+ $gridle-generate-pull-classes : true !default;
65
+ $gridle-generate-prefix-classes : true !default;
66
+ $gridle-generate-suffix-classes : true !default;
67
+
68
+ $gridle-generate-useful-states-classes : (retina, landscape) !default;// retina | landscape | portrait | print | tv
69
+
70
+
71
+
72
+
73
+ // |------------------------------------------------------
74
+ // |------------------------------------------------------
75
+ // | Variables
76
+ // |------------------------------------------------------
77
+ // |------------------------------------------------------
78
+
79
+
80
+
81
+ $_gridle-state-01-min-width : null !default;
82
+ $_gridle-state-01-max-width : null !default;
83
+ $_gridle-state-01-name : null !default;
84
+ $_gridle-state-01-query : null !default;
85
+ $_gridle-state-01-classes : true !default;
86
+
87
+ $_gridle-state-02-min-width : null !default;
88
+ $_gridle-state-02-max-width : null !default;
89
+ $_gridle-state-02-name : null !default;
90
+ $_gridle-state-02-query : null !default;
91
+ $_gridle-state-02-classes : true !default;
92
+
93
+ $_gridle-state-03-min-width : null !default;
94
+ $_gridle-state-03-max-width : null !default;
95
+ $_gridle-state-03-name : null !default;
96
+ $_gridle-state-03-query : null !default;
97
+ $_gridle-state-03-classes : true !default;
98
+
99
+ $_gridle-state-04-min-width : null !default;
100
+ $_gridle-state-04-max-width : null !default;
101
+ $_gridle-state-04-name : null !default;
102
+ $_gridle-state-04-query : null !default;
103
+ $_gridle-state-04-classes : true !default;
104
+
105
+ $_gridle-state-05-min-width : null !default;
106
+ $_gridle-state-05-max-width : null !default;
107
+ $_gridle-state-05-name : null !default;
108
+ $_gridle-state-05-query : null !default;
109
+ $_gridle-state-05-classes : true !default;
110
+
111
+ $_gridle-state-06-min-width : null !default;
112
+ $_gridle-state-06-max-width : null !default;
113
+ $_gridle-state-06-name : null !default;
114
+ $_gridle-state-06-query : null !default;
115
+ $_gridle-state-06-classes : true !default;
116
+
117
+ $_gridle-state-07-min-width : null !default;
118
+ $_gridle-state-07-max-width : null !default;
119
+ $_gridle-state-07-name : null !default;
120
+ $_gridle-state-07-query : null !default;
121
+ $_gridle-state-07-classes : true !default;
122
+
123
+ $_gridle-state-08-min-width : null !default;
124
+ $_gridle-state-08-max-width : null !default;
125
+ $_gridle-state-08-name : null !default;
126
+ $_gridle-state-08-query : null !default;
127
+ $_gridle-state-08-classes : true !default;
128
+
129
+ $_gridle-state-09-min-width : null !default;
130
+ $_gridle-state-09-max-width : null !default;
131
+ $_gridle-state-09-name : null !default;
132
+ $_gridle-state-09-query : null !default;
133
+ $_gridle-state-09-classes : true !default;
134
+
135
+ $_gridle-state-10-min-width : null !default;
136
+ $_gridle-state-10-max-width : null !default;
137
+ $_gridle-state-10-name : null !default;
138
+ $_gridle-state-10-query : null !default;
139
+ $_gridle-state-10-classes : true !default;
140
+
141
+ $_gridle-state-11-min-width : null !default;
142
+ $_gridle-state-11-max-width : null !default;
143
+ $_gridle-state-11-name : null !default;
144
+ $_gridle-state-11-query : null !default;
145
+ $_gridle-state-11-classes : true !default;
146
+
147
+ $_gridle-state-12-min-width : null !default;
148
+ $_gridle-state-12-max-width : null !default;
149
+ $_gridle-state-12-name : null !default;
150
+ $_gridle-state-12-query : null !default;
151
+ $_gridle-state-12-classes : true !default;
152
+
153
+ $_gridle-state-13-min-width : null !default;
154
+ $_gridle-state-13-max-width : null !default;
155
+ $_gridle-state-13-name : null !default;
156
+ $_gridle-state-13-query : null !default;
157
+ $_gridle-state-13-classes : true !default;
158
+
159
+ $_gridle-state-14-min-width : null !default;
160
+ $_gridle-state-14-max-width : null !default;
161
+ $_gridle-state-14-name : null !default;
162
+ $_gridle-state-14-query : null !default;
163
+ $_gridle-state-14-classes : true !default;
164
+
165
+ $_gridle-state-15-min-width : null !default;
166
+ $_gridle-state-15-max-width : null !default;
167
+ $_gridle-state-15-name : null !default;
168
+ $_gridle-state-15-query : null !default;
169
+ $_gridle-state-15-classes : true !default;
170
+
171
+
172
+
173
+
174
+ // |------------------------------------------------------
175
+ // |------------------------------------------------------
176
+ // | Silent classes
177
+ // |------------------------------------------------------
178
+ // |------------------------------------------------------
179
+
180
+
181
+ // Init gridle
182
+ // Creating the silent classes with user configuration :
183
+ %gridle-push-pull-debug-background-common {
184
+ background-size:50px 90%;
185
+ background-position:0 50%;
186
+ background-repeat:repeat-x;
187
+ }
188
+ %gridle-push-pull-common {
189
+ position:relative;
190
+ }
191
+ %gridle-container-common {
192
+ width:100%;
193
+
194
+ // For modern browser
195
+ &:before,
196
+ &:after {
197
+ content:"";
198
+ display:table;
199
+ }
200
+ &:after {
201
+ clear:both;
202
+ }
203
+ // For IE 6/7 (trigger hasLayout
204
+ & {
205
+ zoom:1;
206
+ }
207
+ }
208
+ %gridle-container-debug-common {
209
+ background-color:#f5f5f5;
210
+
211
+ &:before,
212
+ &:after {
213
+ content:"";
214
+ display:block;
215
+ background-image: url();
216
+ height:inherit;
217
+ text-align:center;
218
+ color:white;
219
+ font-size:11px;
220
+ -webkit-box-sizing: border-box;
221
+ -moz-box-sizing: border-box;
222
+ box-sizing: border-box;
223
+ }
224
+ }
225
+ %gridle-grid-debug-common {
226
+ &:before,
227
+ &:after {
228
+ content:"";
229
+ display:block;
230
+ background-image: url();
231
+ margin:10px 0;
232
+ padding:5px 0;
233
+ text-align:center;
234
+ color:white;
235
+ font-size:11px;
236
+ -webkit-box-sizing: border-box;
237
+ -moz-box-sizing: border-box;
238
+ box-sizing: border-box;
239
+ }
240
+ background-color:#daeff5;
241
+ }
242
+ %gridle-grid-common {
243
+ display:inline-block;
244
+ min-height:1px;
245
+ -webkit-box-sizing: border-box;
246
+ -moz-box-sizing: border-box;
247
+ box-sizing: border-box;
248
+ }
249
+ %gridle-prefix-debug-common {
250
+ background-color:#dae7e9 !important;
251
+ }
252
+ %gridle-suffix-debug-common {
253
+ background-color:#dae7e9 !important;
254
+ }
255
+
256
+
257
+
258
+
259
+ // |------------------------------------------------------
260
+ // |------------------------------------------------------
261
+ // | Common mixins
262
+ // |------------------------------------------------------
263
+ // |------------------------------------------------------
264
+
265
+
266
+ // Common css that cannot be extended cause of variables :
267
+ @mixin _gridle_grid_common() {
268
+ @extend %gridle-grid-common;
269
+ @if $gridle-direction == rtl {
270
+ float:right;
271
+ direction:rtl;
272
+ } @else {
273
+ float:left;
274
+ direction:ltr;
275
+ }
276
+ // set padding :;
277
+ padding:0 $gridle-gutter-width/2 !important;
278
+ @if $gridle-debug == true {
279
+ @extend %gridle-grid-debug-common;
280
+ }
281
+ }
282
+ @mixin _gridle_container_common() {
283
+ @extend %gridle-container-common;
284
+ // debug part :
285
+ @if ($gridle-debug == true) {
286
+ @extend %gridle-container-debug-common;
287
+ &:before {
288
+ @if $gridle-debug-show-class-names == true {
289
+ padding:10px $gridle-gutter-width/2;
290
+ content:"container-#{$gridle-columns-count}" !important;
291
+ }
292
+ }
293
+ &:after {
294
+ @if $gridle-debug-show-class-names == true {
295
+ padding:10px $gridle-gutter-width/2;
296
+ content:"end container-#{$gridle-columns-count}" !important;
297
+ }
298
+ }
299
+ }
300
+ }
301
+ @mixin _gridle_push_common() {
302
+ // extend common :
303
+ @extend %gridle-push-pull-common;
304
+ @if $gridle-debug == true {
305
+ @extend %gridle-push-pull-debug-background-common;
306
+ background-color:#f4efdf !important;
307
+ @if $gridle-direction == ltr {
308
+ background-image: url();
309
+ } @else {
310
+ background-image: url();
311
+ }
312
+ }
313
+ }
314
+ @mixin _gridle_pull_common() {
315
+ @extend %gridle-push-pull-common;
316
+ @if $gridle-debug == true {
317
+ @extend %gridle-push-pull-debug-background-common;
318
+ background-color:#cfe4d5 !important;
319
+ @if $gridle-direction == ltr {
320
+ background-image: url();
321
+ } @else {
322
+ background-image: url();
323
+ }
324
+ }
325
+ }
326
+ @mixin _gridle_prefix_common() {
327
+ @if $gridle-debug == true {
328
+ @extend %gridle-prefix-debug-common;
329
+ }
330
+ }
331
+ @mixin _gridle_suffix_common() {
332
+ @if $gridle-debug == true {
333
+ @extend %gridle-suffix-debug-common;
334
+ }
335
+ }
336
+
337
+
338
+
339
+
340
+ // |------------------------------------------------------
341
+ // |------------------------------------------------------
342
+ // | Functions
343
+ // |------------------------------------------------------
344
+ // |------------------------------------------------------
345
+
346
+
347
+ // Get column width :
348
+ @function gridle_get_columns_width(
349
+ $columns : 1
350
+ ) {
351
+ @return percentage(1 / $gridle-columns-count * $columns);
352
+ }
353
+ @function gridle_get_column_width(
354
+ $columns : 1
355
+ ) {
356
+ @return gridle_get_columns_width($columns);
357
+ }
358
+
359
+
360
+ // Get media query by state :
361
+ // @param String $state The state name
362
+ // @return String The query
363
+ @function _get_media_query_for_state(
364
+ $state
365
+ ) {
366
+ // get the index of state :
367
+ $idx : _gridle_get_media_query_index_by_name($state);
368
+
369
+ // check if media_min-width is null :
370
+ @if $state != null {
371
+
372
+ @if $idx != null {
373
+ // get vars :
374
+ $m : _gridle_get_media_query_vars($idx,"name");
375
+ $min-width : _gridle_get_media_query_vars($idx,"min-width");
376
+ $max-width : _gridle_get_media_query_vars($idx,"max-width");
377
+ $classes : _gridle_get_media_query_vars($idx,"classes");
378
+ $query : _gridle_get_media_query_vars($idx,"query");
379
+
380
+ // check if exist :
381
+ @if $m != null {
382
+ // check if query exist :
383
+ @if $query != null {
384
+ @return $query;
385
+ } @else {
386
+ // process max and min width :
387
+ @if $min-width == null { $min-width : 0; }
388
+ @if $max-width == null { $max-width : 99999px; }
389
+ // write media query :
390
+ @return "screen and (min-width: #{$min-width}) and (max-width: #{$max-width})";
391
+ }
392
+ }
393
+ } @else if $state == 'print' or $state == print {
394
+ @return "only print";
395
+ } @else if $state == 'tv' or $state == tv {
396
+ @return "only tv";
397
+ } @else if $state == 'portrait' or $state == portrait {
398
+ @return "only screen and (orientation: portrait)";
399
+ } @else if $state == 'landscape' or $state == landscape {
400
+ @return "only screen and (orientation: landscape)";
401
+ } @else if $state == 'retina' or $state == retina {
402
+ @return "only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)";
403
+ }
404
+ } @else {
405
+ @return null;
406
+ }
407
+ }
408
+
409
+
410
+ // Get the media queries variables :
411
+ // @param int $index The media query indes
412
+ // @param String $var The media query variable name
413
+ // @return String|int The variable value
414
+ @function _gridle_get_media_query_vars(
415
+ $index : 1,
416
+ $var : "name"
417
+ ) {
418
+ @if $index == 1 {
419
+ @if $var == "name" { @return $_gridle-state-01-name; }
420
+ @else if $var == "min-width" { @return $_gridle-state-01-min-width; }
421
+ @else if $var == "max-width" { @return $_gridle-state-01-max-width; }
422
+ @else if $var == "query" { @return $_gridle-state-01-query; }
423
+ @else if $var == "classes" { @return $_gridle-state-01-classes; }
424
+ } @else if $index == 2 {
425
+ @if $var == "name" { @return $_gridle-state-02-name; }
426
+ @else if $var == "min-width" { @return $_gridle-state-02-min-width; }
427
+ @else if $var == "max-width" { @return $_gridle-state-02-max-width; }
428
+ @else if $var == "query" { @return $_gridle-state-02-query; }
429
+ @else if $var == "classes" { @return $_gridle-state-02-classes; }
430
+ } @else if $index == 3 {
431
+ @if $var == "name" { @return $_gridle-state-03-name; }
432
+ @else if $var == "min-width" { @return $_gridle-state-03-min-width; }
433
+ @else if $var == "max-width" { @return $_gridle-state-03-max-width; }
434
+ @else if $var == "query" { @return $_gridle-state-03-query; }
435
+ @else if $var == "classes" { @return $_gridle-state-03-classes; }
436
+ } @else if $index == 4 {
437
+ @if $var == "name" { @return $_gridle-state-04-name; }
438
+ @else if $var == "min-width" { @return $_gridle-state-04-min-width; }
439
+ @else if $var == "max-width" { @return $_gridle-state-04-max-width; }
440
+ @else if $var == "query" { @return $_gridle-state-04-query; }
441
+ @else if $var == "classes" { @return $_gridle-state-04-classes; }
442
+ } @else if $index == 5 {
443
+ @if $var == "name" { @return $_gridle-state-05-name; }
444
+ @else if $var == "min-width" { @return $_gridle-state-05-min-width; }
445
+ @else if $var == "max-width" { @return $_gridle-state-05-max-width; }
446
+ @else if $var == "query" { @return $_gridle-state-05-query; }
447
+ @else if $var == "classes" { @return $_gridle-state-05-classes; }
448
+ } @else if $index == 6 {
449
+ @if $var == "name" { @return $_gridle-state-06-name; }
450
+ @else if $var == "min-width" { @return $_gridle-state-06-min-width; }
451
+ @else if $var == "max-width" { @return $_gridle-state-06-max-width; }
452
+ @else if $var == "query" { @return $_gridle-state-06-query; }
453
+ @else if $var == "classes" { @return $_gridle-state-06-classes; }
454
+ } @else if $index == 7 {
455
+ @if $var == "name" { @return $_gridle-state-07-name; }
456
+ @else if $var == "min-width" { @return $_gridle-state-07-min-width; }
457
+ @else if $var == "max-width" { @return $_gridle-state-07-max-width; }
458
+ @else if $var == "query" { @return $_gridle-state-07-query; }
459
+ @else if $var == "classes" { @return $_gridle-state-07-classes; }
460
+ } @else if $index == 8 {
461
+ @if $var == "name" { @return $_gridle-state-08-name; }
462
+ @else if $var == "min-width" { @return $_gridle-state-08-min-width; }
463
+ @else if $var == "max-width" { @return $_gridle-state-08-max-width; }
464
+ @else if $var == "query" { @return $_gridle-state-08-query; }
465
+ @else if $var == "classes" { @return $_gridle-state-08-classes; }
466
+ } @else if $index == 9 {
467
+ @if $var == "name" { @return $_gridle-state-09-name; }
468
+ @else if $var == "min-width" { @return $_gridle-state-09-min-width; }
469
+ @else if $var == "max-width" { @return $_gridle-state-09-max-width; }
470
+ @else if $var == "query" { @return $_gridle-state-09-query; }
471
+ @else if $var == "classes" { @return $_gridle-state-09-classes; }
472
+ } @else if $index == 10 {
473
+ @if $var == "name" { @return $_gridle-state-10-name; }
474
+ @else if $var == "min-width" { @return $_gridle-state-10-min-width; }
475
+ @else if $var == "max-width" { @return $_gridle-state-10-max-width; }
476
+ @else if $var == "query" { @return $_gridle-state-10-query; }
477
+ @else if $var == "classes" { @return $_gridle-state-10-classes; }
478
+ } @else if $index == 11 {
479
+ @if $var == "name" { @return $_gridle-state-11-name; }
480
+ @else if $var == "min-width" { @return $_gridle-state-11-min-width; }
481
+ @else if $var == "max-width" { @return $_gridle-state-11-max-width; }
482
+ @else if $var == "query" { @return $_gridle-state-11-query; }
483
+ @else if $var == "classes" { @return $_gridle-state-11-classes; }
484
+ } @else if $index == 12 {
485
+ @if $var == "name" { @return $_gridle-state-12-name; }
486
+ @else if $var == "min-width" { @return $_gridle-state-12-min-width; }
487
+ @else if $var == "max-width" { @return $_gridle-state-12-max-width; }
488
+ @else if $var == "query" { @return $_gridle-state-12-query; }
489
+ @else if $var == "classes" { @return $_gridle-state-12-classes; }
490
+ } @else if $index == 13 {
491
+ @if $var == "name" { @return $_gridle-state-13-name; }
492
+ @else if $var == "min-width" { @return $_gridle-state-13-min-width; }
493
+ @else if $var == "max-width" { @return $_gridle-state-13-max-width; }
494
+ @else if $var == "query" { @return $_gridle-state-13-query; }
495
+ @else if $var == "classes" { @return $_gridle-state-13-classes; }
496
+ } @else if $index == 14 {
497
+ @if $var == "name" { @return $_gridle-state-14-name; }
498
+ @else if $var == "min-width" { @return $_gridle-state-14-min-width; }
499
+ @else if $var == "max-width" { @return $_gridle-state-14-max-width; }
500
+ @else if $var == "query" { @return $_gridle-state-14-query; }
501
+ @else if $var == "classes" { @return $_gridle-state-14-classes; }
502
+ } @else if $index == 15 {
503
+ @if $var == "name" { @return $_gridle-state-15-name; }
504
+ @else if $var == "min-width" { @return $_gridle-state-15-min-width; }
505
+ @else if $var == "max-width" { @return $_gridle-state-15-max-width; }
506
+ @else if $var == "query" { @return $_gridle-state-15-query; }
507
+ @else if $var == "classes" { @return $_gridle-state-15-classes; }
508
+ }
509
+ }
510
+
511
+
512
+ // Get the index of an media query by name
513
+ // @param String $name The nme of the media query
514
+ // @return int The index of the media query
515
+ @function _gridle_get_media_query_index_by_name(
516
+ $name
517
+ ) {
518
+ @if $_gridle-state-01-name == $name { @return 1; }
519
+ @else if $_gridle-state-02-name == $name { @return 2; }
520
+ @else if $_gridle-state-03-name == $name { @return 3; }
521
+ @else if $_gridle-state-04-name == $name { @return 4; }
522
+ @else if $_gridle-state-05-name == $name { @return 5; }
523
+ @else if $_gridle-state-06-name == $name { @return 6; }
524
+ @else if $_gridle-state-07-name == $name { @return 7; }
525
+ @else if $_gridle-state-08-name == $name { @return 8; }
526
+ @else if $_gridle-state-09-name == $name { @return 9; }
527
+ @else if $_gridle-state-10-name == $name { @return 10; }
528
+ @else if $_gridle-state-11-name == $name { @return 11; }
529
+ @else if $_gridle-state-12-name == $name { @return 12; }
530
+ @else if $_gridle-state-13-name == $name { @return 13; }
531
+ @else if $_gridle-state-14-name == $name { @return 14; }
532
+ @else if $_gridle-state-15-name == $name { @return 15; }
533
+ @else { @return null; }
534
+ }
535
+
536
+
537
+
538
+
539
+ // |------------------------------------------------------
540
+ // |------------------------------------------------------
541
+ // | Mixins
542
+ // |------------------------------------------------------
543
+ // |------------------------------------------------------
544
+
545
+
546
+ // Register an state :
547
+ // @param String $name The state name
548
+ // @param int $min-width The min width
549
+ // @param int $max-width The max width
550
+ @mixin gridle_register_state(
551
+ $name,
552
+ $min-width-or-query : null,
553
+ $max-width-or-classes-generation : null,
554
+ $classes-generation : true
555
+ ) {
556
+
557
+ // register new state :
558
+ @if $_gridle-state-01-name == null {
559
+ $_gridle-state-01-name : $name;
560
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
561
+ $_gridle-state-01-min-width : $min-width-or-query;
562
+ $_gridle-state-01-max-width : $max-width-or-classes-generation;
563
+ $_gridle-state-01-classes : $classes-generation;
564
+ } @else if type-of($min-width-or-query) == string {
565
+ $_gridle-state-01-query : $min-width-or-query;
566
+ @if type-of($max-width-or-classes-generation) == bool {
567
+ $_gridle-state-01-classes : $max-width-or-classes-generation;
568
+ }
569
+ }
570
+ } @else if $_gridle-state-02-name == null {
571
+ $_gridle-state-02-name : $name;
572
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
573
+ $_gridle-state-02-min-width : $min-width-or-query;
574
+ $_gridle-state-02-max-width : $max-width-or-classes-generation;
575
+ $_gridle-state-02-classes : $classes-generation;
576
+ } @else if type-of($min-width-or-query) == string {
577
+ $_gridle-state-02-query : $min-width-or-query;
578
+ @if type-of($max-width-or-classes-generation) == bool {
579
+ $_gridle-state-02-classes : $max-width-or-classes-generation;
580
+ }
581
+ }
582
+ } @else if $_gridle-state-03-name == null {
583
+ $_gridle-state-03-name : $name;
584
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
585
+ $_gridle-state-03-min-width : $min-width-or-query;
586
+ $_gridle-state-03-max-width : $max-width-or-classes-generation;
587
+ $_gridle-state-03-classes : $classes-generation;
588
+ } @else if type-of($min-width-or-query) == string {
589
+ $_gridle-state-03-query : $min-width-or-query;
590
+ @if type-of($max-width-or-classes-generation) == bool {
591
+ $_gridle-state-03-classes : $max-width-or-classes-generation;
592
+ }
593
+ }
594
+ } @else if $_gridle-state-04-name == null {
595
+ $_gridle-state-04-name : $name;
596
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
597
+ $_gridle-state-04-min-width : $min-width-or-query;
598
+ $_gridle-state-04-max-width : $max-width-or-classes-generation;
599
+ $_gridle-state-04-classes : $classes-generation;
600
+ } @else if type-of($min-width-or-query) == string {
601
+ $_gridle-state-04-query : $min-width-or-query;
602
+ @if type-of($max-width-or-classes-generation) == bool {
603
+ $_gridle-state-04-classes : $max-width-or-classes-generation;
604
+ }
605
+ }
606
+ } @else if $_gridle-state-05-name == null {
607
+ $_gridle-state-05-name : $name;
608
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
609
+ $_gridle-state-05-min-width : $min-width-or-query;
610
+ $_gridle-state-05-max-width : $max-width-or-classes-generation;
611
+ $_gridle-state-05-classes : $classes-generation;
612
+ } @else if type-of($min-width-or-query) == string {
613
+ $_gridle-state-05-query : $min-width-or-query;
614
+ @if type-of($max-width-or-classes-generation) == bool {
615
+ $_gridle-state-05-classes : $max-width-or-classes-generation;
616
+ }
617
+ }
618
+ } @else if $_gridle-state-06-name == null {
619
+ $_gridle-state-06-name : $name;
620
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
621
+ $_gridle-state-06-min-width : $min-width-or-query;
622
+ $_gridle-state-06-max-width : $max-width-or-classes-generation;
623
+ $_gridle-state-06-classes : $classes-generation;
624
+ } @else if type-of($min-width-or-query) == string {
625
+ $_gridle-state-06-query : $min-width-or-query;
626
+ @if type-of($max-width-or-classes-generation) == bool {
627
+ $_gridle-state-06-classes : $max-width-or-classes-generation;
628
+ }
629
+ }
630
+ } @else if $_gridle-state-07-name == null {
631
+ $_gridle-state-07-name : $name;
632
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
633
+ $_gridle-state-07-min-width : $min-width-or-query;
634
+ $_gridle-state-07-max-width : $max-width-or-classes-generation;
635
+ $_gridle-state-07-classes : $classes-generation;
636
+ } @else if type-of($min-width-or-query) == string {
637
+ $_gridle-state-07-query : $min-width-or-query;
638
+ @if type-of($max-width-or-classes-generation) == bool {
639
+ $_gridle-state-07-classes : $max-width-or-classes-generation;
640
+ }
641
+ }
642
+ } @else if $_gridle-state-08-name == null {
643
+ $_gridle-state-08-name : $name;
644
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
645
+ $_gridle-state-08-min-width : $min-width-or-query;
646
+ $_gridle-state-08-max-width : $max-width-or-classes-generation;
647
+ $_gridle-state-08-classes : $classes-generation;
648
+ } @else if type-of($min-width-or-query) == string {
649
+ $_gridle-state-08-query : $min-width-or-query;
650
+ @if type-of($max-width-or-classes-generation) == bool {
651
+ $_gridle-state-08-classes : $max-width-or-classes-generation;
652
+ }
653
+ }
654
+ } @else if $_gridle-state-09-name == null {
655
+ $_gridle-state-09-name : $name;
656
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
657
+ $_gridle-state-09-min-width : $min-width-or-query;
658
+ $_gridle-state-09-max-width : $max-width-or-classes-generation;
659
+ $_gridle-state-09-classes : $classes-generation;
660
+ } @else if type-of($min-width-or-query) == string {
661
+ $_gridle-state-09-query : $min-width-or-query;
662
+ @if type-of($max-width-or-classes-generation) == bool {
663
+ $_gridle-state-09-classes : $max-width-or-classes-generation;
664
+ }
665
+ }
666
+ } @else if $_gridle-state-10-name == null {
667
+ $_gridle-state-10-name : $name;
668
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
669
+ $_gridle-state-10-min-width : $min-width-or-query;
670
+ $_gridle-state-10-max-width : $max-width-or-classes-generation;
671
+ $_gridle-state-10-classes : $classes-generation;
672
+ } @else if type-of($min-width-or-query) == string {
673
+ $_gridle-state-10-query : $min-width-or-query;
674
+ @if type-of($max-width-or-classes-generation) == bool {
675
+ $_gridle-state-10-classes : $max-width-or-classes-generation;
676
+ }
677
+ }
678
+ } @else if $_gridle-state-11-name == null {
679
+ $_gridle-state-11-name : $name;
680
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
681
+ $_gridle-state-11-min-width : $min-width-or-query;
682
+ $_gridle-state-11-max-width : $max-width-or-classes-generation;
683
+ $_gridle-state-11-classes : $classes-generation;
684
+ } @else if type-of($min-width-or-query) == string {
685
+ $_gridle-state-11-query : $min-width-or-query;
686
+ @if type-of($max-width-or-classes-generation) == bool {
687
+ $_gridle-state-11-classes : $max-width-or-classes-generation;
688
+ }
689
+ }
690
+ } @else if $_gridle-state-12-name == null {
691
+ $_gridle-state-12-name : $name;
692
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
693
+ $_gridle-state-12-min-width : $min-width-or-query;
694
+ $_gridle-state-12-max-width : $max-width-or-classes-generation;
695
+ $_gridle-state-12-classes : $classes-generation;
696
+ } @else if type-of($min-width-or-query) == string {
697
+ $_gridle-state-12-query : $min-width-or-query;
698
+ @if type-of($max-width-or-classes-generation) == bool {
699
+ $_gridle-state-12-classes : $max-width-or-classes-generation;
700
+ }
701
+ }
702
+ } @else if $_gridle-state-13-name == null {
703
+ $_gridle-state-13-name : $name;
704
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
705
+ $_gridle-state-13-min-width : $min-width-or-query;
706
+ $_gridle-state-13-max-width : $max-width-or-classes-generation;
707
+ $_gridle-state-13-classes : $classes-generation;
708
+ } @else if type-of($min-width-or-query) == string {
709
+ $_gridle-state-13-query : $min-width-or-query;
710
+ @if type-of($max-width-or-classes-generation) == bool {
711
+ $_gridle-state-13-classes : $max-width-or-classes-generation;
712
+ }
713
+ }
714
+ } @else if $_gridle-state-14-name == null {
715
+ $_gridle-state-14-name : $name;
716
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
717
+ $_gridle-state-14-min-width : $min-width-or-query;
718
+ $_gridle-state-14-max-width : $max-width-or-classes-generation;
719
+ $_gridle-state-14-classes : $classes-generation;
720
+ } @else if type-of($min-width-or-query) == string {
721
+ $_gridle-state-14-query : $min-width-or-query;
722
+ @if type-of($max-width-or-classes-generation) == bool {
723
+ $_gridle-state-14-classes : $max-width-or-classes-generation;
724
+ }
725
+ }
726
+ } @else if $_gridle-state-15-name == null {
727
+ $_gridle-state-15-name : $name;
728
+ @if type-of($min-width-or-query) == number and type-of($max-width-or-classes-generation) == number {
729
+ $_gridle-state-15-min-width : $min-width-or-query;
730
+ $_gridle-state-15-max-width : $max-width-or-classes-generation;
731
+ $_gridle-state-15-classes : $classes-generation;
732
+ } @else if type-of($min-width-or-query) == string {
733
+ $_gridle-state-15-query : $min-width-or-query;
734
+ @if type-of($max-width-or-classes-generation) == bool {
735
+ $_gridle-state-15-classes : $max-width-or-classes-generation;
736
+ }
737
+ }
738
+ }
739
+ }
740
+
741
+
742
+ // Register default states :
743
+ @mixin gridle_register_default_states() {
744
+ // register mobile and tablet states :
745
+ @include gridle_register_state("mobile",0,480px);
746
+ @include gridle_register_state("tablet",481px,1024px);
747
+ }
748
+
749
+
750
+ // Responsive helpers mixins :
751
+ // @param String $media The media name to response for
752
+ @mixin gridle_responseTo(
753
+ $state-or-min-width,
754
+ $max-width : null,
755
+ $has-parent : true
756
+ ) {
757
+
758
+ // get the index of state :
759
+ $idx : _gridle_get_media_query_index_by_name($state-or-min-width);
760
+
761
+ // check if is a state :
762
+ @if type-of($state-or-min-width) == string and $gridle-html-states-classes {
763
+ // html class :
764
+ @if $has-parent {
765
+ html.#{$state-or-min-width} & { @content; }
766
+ } @else {
767
+ html.#{$state-or-min-width} { @content; }
768
+ }
769
+ }
770
+
771
+ // check if media_min-width is null :
772
+ @if $state-or-min-width != null {
773
+
774
+ @if $idx != null {
775
+ // get vars :
776
+ $m : _gridle_get_media_query_vars($idx,"name");
777
+ $min-width : _gridle_get_media_query_vars($idx,"min-width");
778
+ $max-width : _gridle_get_media_query_vars($idx,"max-width");
779
+ $classes : _gridle_get_media_query_vars($idx,"classes");
780
+ $query : _gridle_get_media_query_vars($idx,"query");
781
+
782
+ // check if exist :
783
+ @if $m != null {
784
+ // check if query exist :
785
+ @if $query != null {
786
+ @media #{$query} {
787
+ @content;
788
+ }
789
+ } @else {
790
+ // process max and min width :
791
+ @if $min-width == null { $min-width : 0; }
792
+ @if $max-width == null { $max-width : 99999px; }
793
+ // write media query :
794
+ @media screen and (min-width: $min-width) and (max-width: $max-width) { @content; }
795
+ }
796
+ }
797
+ } @else if $state-or-min-width == 'print' or $state-or-min-width == print {
798
+ @media only print {
799
+ @content;
800
+ }
801
+ } @else if $state-or-min-width == 'tv' or $state-or-min-width == tv {
802
+ @media only tv {
803
+ @content;
804
+ }
805
+ } @else if $state-or-min-width == 'portrait' or $state-or-min-width == portrait {
806
+ @media only screen and (orientation: portrait) {
807
+ @content;
808
+ }
809
+ } @else if $state-or-min-width == 'landscape' or $state-or-min-width == landscape {
810
+ @media only screen and (orientation: landscape) {
811
+ @content;
812
+ }
813
+ } @else if $state-or-min-width == 'retina' or $state-or-min-width == retina {
814
+ @media only screen and (-webkit-min-device-pixel-ratio: 2),
815
+ only screen and ( min--moz-device-pixel-ratio: 2),
816
+ only screen and ( -o-min-device-pixel-ratio: 2/1),
817
+ only screen and ( min-device-pixel-ratio: 2),
818
+ only screen and ( min-resolution: 192dpi),
819
+ only screen and ( min-resolution: 2dppx)
820
+ {
821
+ @content;
822
+ }
823
+ } @else {
824
+ // check for min and max width :
825
+ @if $state-or-min-width != null and $max-width != null {
826
+ @media screen and (min-width: $state-or-min-width) and (max-width: $max-width) { @content; }
827
+ } @else if $state-or-min-width != null and $max-width == null {
828
+ @media screen and (min-width: $state-or-min-width) { @content; }
829
+ } @else if $state-or-min-width == null and $max-width != null {
830
+ @media screen and (max-width: $max-width) { @content; }
831
+ }
832
+ }
833
+ } @else {
834
+ @content;
835
+ }
836
+ }
837
+
838
+
839
+ // Container mixin :
840
+ @mixin gridle_container(
841
+ ) {
842
+ @include _gridle_container_common();
843
+ }
844
+
845
+
846
+ // Grid mixin :
847
+ // Set the width of the specified grid column :
848
+ // @param int $columns The columns to generate
849
+ @mixin gridle(
850
+ $columns : 12,
851
+ $state : null,
852
+ $debug-state : null
853
+ ) {
854
+ @include _gridle_grid_common();
855
+ @if $state {
856
+ @include gridle_responseTo($state) {
857
+ @include _gridle($columns, $state, $debug-state);
858
+ }
859
+ } @else {
860
+ @include _gridle($columns,$state,$debug-state);
861
+ }
862
+ }
863
+ @mixin _gridle(
864
+ $columns : 12,
865
+ $state : null,
866
+ $debug-state : null
867
+ ) {
868
+ // vars :
869
+ @if $debug-state == null { $debug-state : $state; }
870
+ $width : percentage(1 / $gridle-columns-count) * $columns;
871
+ width:$width;
872
+
873
+ // ie7 support :
874
+ @if $gridle-ie7-support == true {
875
+ *width: expression((this.parentNode.clientWidth/#{$gridle-columns-count}*#{$columns} - parseInt(this.currentStyle['paddingLeft']) - parseInt(this.currentStyle['paddingRight'])) + 'px');
876
+ }
877
+
878
+ // debug :
879
+ @if $gridle-debug == true and $gridle-debug-show-class-names == true {
880
+ &:before {
881
+ @if $debug-state != null {
882
+ content:"grid-#{$debug-state}-#{$columns * $gridle-name-multiplicator}";
883
+ } @else {
884
+ content:"grid-#{$columns * $gridle-name-multiplicator}";
885
+ }
886
+ }
887
+ &.grid-parent:before {
888
+ @if $debug-state != null {
889
+ content:"grid-parent-#{$debug-state}-#{$columns * $gridle-name-multiplicator}";
890
+ } @else {
891
+ content:"grid-parent-#{$columns * $gridle-name-multiplicator}";
892
+ }
893
+ }
894
+ }
895
+ }
896
+
897
+
898
+ // push :
899
+ // Push the element of the count of column wanted
900
+ // @param int $columns The columns to generate
901
+ // @param boolean $important Define if need to add !important at the end of the properties
902
+ @mixin gridle_push(
903
+ $columns : 12,
904
+ $state : null,
905
+ $debug-state : null
906
+ ) {
907
+ @include _gridle_push_common();
908
+ @if $state {
909
+ @include gridle_responseTo($state) {
910
+ @include _gridle_push($columns,$debug-state);
911
+ }
912
+ } @else {
913
+ @include _gridle_push($columns,$debug-state);
914
+ }
915
+ }
916
+ @mixin _gridle_push(
917
+ $columns : 12,
918
+ $debug-state : null
919
+ ) {
920
+ // vars :
921
+ $width : percentage(1 / $gridle-columns-count) * $columns;
922
+ @if $gridle-direction == rtl { $width : $width*-1; }
923
+ left:$width;
924
+
925
+ // debug css :
926
+ @if $gridle-debug == true {
927
+ @if $gridle-debug-show-class-names == true {
928
+ &:after {
929
+ @if $debug-state != null {
930
+ content:"push-#{$debug-state}-#{$columns * $gridle-name-multiplicator}" !important;
931
+ } @else {
932
+ content:"push-#{$columns * $gridle-name-multiplicator}" !important;
933
+ }
934
+ }
935
+ }
936
+ }
937
+ }
938
+
939
+
940
+ // pull :
941
+ // Pull the element of the count of column wanted
942
+ // @param int $columns The columns to generate
943
+ // @param boolean $important Define if need to add !important at the end of the properties
944
+ @mixin gridle_pull(
945
+ $columns : 12,
946
+ $state : null,
947
+ $debug-state : null
948
+ ) {
949
+ @include _gridle_pull_common();
950
+ @if $state {
951
+ @include gridle_responseTo($state) {
952
+ @include _gridle_pull($columns,$debug-state);
953
+ }
954
+ } @else {
955
+ @include _gridle_pull($columns,$debug-state);
956
+ }
957
+ }
958
+ @mixin _gridle_pull(
959
+ $columns : 12,
960
+ $debug-state : null
961
+ ) {
962
+ // vars :
963
+ $width : percentage(1 / $gridle-columns-count) * $columns;
964
+ @if $gridle-direction == rtl { $width : $width*-1; }
965
+ right:$width;
966
+
967
+ // debug css :
968
+ @if $gridle-debug == true {
969
+ @if $gridle-debug-show-class-names == true {
970
+ &:after {
971
+ @if $debug-state != null {
972
+ content:"pull-#{$debug-state}-#{$columns * $gridle-name-multiplicator}" !important;
973
+ } @else {
974
+ content:"pull-#{$columns * $gridle-name-multiplicator}" !important;
975
+ }
976
+ }
977
+ }
978
+ }
979
+ }
980
+
981
+
982
+ // push :
983
+ // Push the element of the count of column wanted
984
+ // @param int $columns The columns to generate
985
+ // @param boolean $important Define if need to add !important at the end of the properties
986
+ @mixin gridle_prefix(
987
+ $columns : 12,
988
+ $state : null,
989
+ $debug-state : null
990
+ ) {
991
+ @include _gridle_prefix_common();
992
+ @if $state {
993
+ @include gridle_responseTo($state) {
994
+ @include _gridle_prefix($columns,$debug-state);
995
+ }
996
+ } @else {
997
+ @include _gridle_prefix($columns,$debug-state);
998
+ }
999
+ }
1000
+ @mixin _gridle_prefix(
1001
+ $columns : 12,
1002
+ $debug-state : null
1003
+ ) {
1004
+ // vars :
1005
+ $width : percentage(1 / $gridle-columns-count) * $columns;
1006
+ @if $gridle-direction == rtl { margin-right:$width; }
1007
+ @else { margin-left:$width; }
1008
+
1009
+ // debug css :
1010
+ @if $gridle-debug == true {
1011
+ @if $gridle-debug-show-class-names == true {
1012
+ &:after {
1013
+ @if $debug-state != null {
1014
+ content:"prefix-#{$debug-state}-#{$columns * $gridle-name-multiplicator}" !important;
1015
+ } @else {
1016
+ content:"prefix-#{$columns * $gridle-name-multiplicator}" !important;
1017
+ }
1018
+ }
1019
+ }
1020
+ }
1021
+ }
1022
+
1023
+
1024
+ // pull :
1025
+ // Pull the element of the count of column wanted
1026
+ // @param int $columns The columns to generate
1027
+ // @param boolean $important Define if need to add !important at the end of the properties
1028
+ @mixin gridle_suffix(
1029
+ $columns : 12,
1030
+ $state : null
1031
+ ) {
1032
+ @include _gridle_suffix_common();
1033
+ @if $state {
1034
+ @include gridle_responseTo($state) {
1035
+ @include _gridle_suffix($columns,$state);
1036
+ }
1037
+ } @else {
1038
+ @include _gridle_suffix($columns,$state);
1039
+ }
1040
+ }
1041
+ @mixin _gridle_suffix(
1042
+ $columns : 12,
1043
+ $debug-state : null
1044
+ ) {
1045
+ // vars :
1046
+ $width : percentage(1 / $gridle-columns-count) * $columns;
1047
+ @if $gridle-direction == rtl { margin-left:$width; }
1048
+ @else { margin-right:$width; }
1049
+
1050
+ // debug css :
1051
+ @if $gridle-debug == true {
1052
+ @if $gridle-debug-show-class-names == true {
1053
+ &:after {
1054
+ @if $debug-state != null {
1055
+ content:"suffix-#{$debug-state}-#{$columns * $gridle-name-multiplicator}" !important;
1056
+ } @else {
1057
+ content:"suffix-#{$columns * $gridle-name-multiplicator}" !important;
1058
+ }
1059
+ }
1060
+ }
1061
+ }
1062
+ }
1063
+
1064
+
1065
+ // Grid centered :
1066
+ @mixin gridle_centered(
1067
+ $state : null
1068
+ ) {
1069
+ @if $state {
1070
+ @include gridle_responseTo($state) {
1071
+ @include _gridle_centered();
1072
+ }
1073
+ } @else {
1074
+ @include _gridle_centered();
1075
+ }
1076
+ }
1077
+ @mixin _gridle_centered() {
1078
+ display:block;
1079
+ float:none;
1080
+ margin-left:auto;
1081
+ margin-right:auto;
1082
+ clear:both;
1083
+ }
1084
+
1085
+
1086
+ // Grid parent :
1087
+ @mixin gridle_parent(
1088
+ $state : null
1089
+ ) {
1090
+ @if $state {
1091
+ @include gridle_responseTo($state) {
1092
+ @include _gridle_parent();
1093
+ }
1094
+ } @else {
1095
+ @include _gridle_parent();
1096
+ }
1097
+ }
1098
+ @mixin _gridle_parent() {
1099
+ padding-left:0 !important;
1100
+ padding-right:0 !important;
1101
+ }
1102
+
1103
+
1104
+ // Hide on :
1105
+ // @param String $media On what state
1106
+ @mixin gridle_hide(
1107
+ $state : null
1108
+ ) {
1109
+ @if $state {
1110
+ @include gridle_responseTo($state) {
1111
+ @include _gridle_hide();
1112
+ }
1113
+ } @else {
1114
+ @include _gridle_hide();
1115
+ }
1116
+ }
1117
+ @mixin _gridle_hide() {
1118
+ display:none;
1119
+ }
1120
+
1121
+
1122
+ // Not visible on :
1123
+ // @param String $media What to hide (one of the 3 state classes name)
1124
+ @mixin gridle_not_visible(
1125
+ $state : null
1126
+ ) {
1127
+ @if $state {
1128
+ @include gridle_responseTo($state) {
1129
+ @include _gridle_not_visible();
1130
+ }
1131
+ } @else {
1132
+ @include _gridle_not_visible();
1133
+ }
1134
+ }
1135
+ @mixin _gridle_not_visible() {
1136
+ visibility:hidden;
1137
+ }
1138
+
1139
+
1140
+ // Show on
1141
+ // @param String $media What to hide (one of the 3 state classes name)
1142
+ @mixin gridle_show(
1143
+ $state : null
1144
+ ) {
1145
+ @if $state {
1146
+ @include gridle_responseTo($state) {
1147
+ @include _gridle_show();
1148
+ }
1149
+ } @else {
1150
+ @include _gridle_show();
1151
+ }
1152
+ }
1153
+ @mixin _gridle_show() {
1154
+ display:block;
1155
+ }
1156
+
1157
+
1158
+ // Visible on :
1159
+ // @param String $media On what state
1160
+ @mixin gridle_visible(
1161
+ $state : null
1162
+ ) {
1163
+ @if $state {
1164
+ @include gridle_responseTo($state) {
1165
+ @include _gridle_visible();
1166
+ }
1167
+ } @else {
1168
+ @include _gridle_visible();
1169
+ }
1170
+ }
1171
+ @mixin _gridle_visible() {
1172
+ visibility:visible;
1173
+ }
1174
+
1175
+
1176
+ // Gridle Right :
1177
+ @mixin gridle_float(
1178
+ $float-direction : left,
1179
+ $state : null
1180
+ ) {
1181
+ @if $state {
1182
+ @include gridle_responseTo($state) {
1183
+ @include gridle_float($float-direction);
1184
+ }
1185
+ } @else {
1186
+ @include gridle_float($float-direction);
1187
+ }
1188
+ }
1189
+ @mixin gridle_float(
1190
+ $float-direction : left
1191
+ ) {
1192
+ float:#{$float-direction};
1193
+ }
1194
+
1195
+
1196
+ // Gridle clear :
1197
+ // @param String $clear-direction The direction to clear
1198
+ // @param String $state The state
1199
+ @mixin gridle_clear(
1200
+ $clear-direction : both,
1201
+ $state : null
1202
+ ) {
1203
+ @if $state {
1204
+ @include gridle_responseTo($state) {
1205
+ @include _gridle_clear($clear-direction);
1206
+ }
1207
+ } @else {
1208
+ @include _gridle_clear($clear-direction);
1209
+ }
1210
+ }
1211
+ @mixin _gridle_clear(
1212
+ $clear-direction : both
1213
+ ) {
1214
+ clear:#{$clear-direction};
1215
+ }
1216
+
1217
+
1218
+ // Gridle no gutter :
1219
+ // @param String $side The side to clear
1220
+ // @param String $state The state
1221
+ @mixin gridle_no_gutter(
1222
+ $side : null,
1223
+ $state : null
1224
+ ) {
1225
+ @if $state {
1226
+ @include gridle_responseTo($state) {
1227
+ @include _gridle_no_gutter($side);
1228
+ }
1229
+ } @else {
1230
+ @include _gridle_no_gutter($side);
1231
+ }
1232
+ }
1233
+ @mixin _gridle_no_gutter(
1234
+ $side : null
1235
+ ) {
1236
+
1237
+ @if $side == 'left' or $side == left {
1238
+ padding-left:0 !important;
1239
+ } @else if $side == 'right' or $side == right {
1240
+ padding-right:0 !important;
1241
+ } @else {
1242
+ padding-left:0 !important;
1243
+ padding-right:0 !important;
1244
+ }
1245
+ }
1246
+ @mixin gridle_no_margin(
1247
+ $side : null,
1248
+ $state : null
1249
+ ) {
1250
+ @include gridle_no_gutter($side, $state);
1251
+ }
1252
+
1253
+
1254
+ // Generate all helpers classes
1255
+ // All the classes generated are not wrapper in gridle_responseTo
1256
+ // in this mixin... Just the names are generated accordingly to the
1257
+ // requested state
1258
+ @mixin _gridle_generate_helper_classes (
1259
+ $state : null
1260
+ ) {
1261
+ $media : '';
1262
+ @if ($state != null) { $media : -#{$state}; }
1263
+ @else { $media : ''; }
1264
+
1265
+ .hide#{$media} {
1266
+ @include gridle_hide(null);
1267
+ }
1268
+ .not-visible#{$media} {
1269
+ @include gridle_not_visible(null);
1270
+ }
1271
+ .show#{$media} {
1272
+ @include gridle_show(null);
1273
+ }
1274
+ .visible#{$media} {
1275
+ @include gridle_visible(null);
1276
+ }
1277
+ .float#{$media}-left {
1278
+ @include gridle_float(left);
1279
+ }
1280
+ .float#{$media}-right {
1281
+ @include gridle_float(right);
1282
+ }
1283
+ .clear#{$media} {
1284
+ @include gridle_clear(both);
1285
+ }
1286
+ .clear#{$media}-left {
1287
+ @include gridle_clear(left);
1288
+ }
1289
+ .clear#{$media}-right {
1290
+ @include gridle_clear(right);
1291
+ }
1292
+ .no-gutter#{$media},
1293
+ .no-margin#{$media} {
1294
+ @include gridle_no_margin();
1295
+ }
1296
+ .no-gutter#{$media}-left,
1297
+ .no-margin#{$media}-left {
1298
+ @include gridle_no_margin(left);
1299
+ }
1300
+ .no-gutter#{$media}-right,
1301
+ .no-margin#{$media}-right {
1302
+ @include gridle_no_margin(right);
1303
+ }
1304
+ .auto-height#{$media} {
1305
+ height:inherit;
1306
+ }
1307
+ .centered#{$media} {
1308
+ @include gridle_centered(null);
1309
+ }
1310
+ [class*="grid-"].grid-parent#{$media} {
1311
+ @include gridle_parent(null);
1312
+ }
1313
+ }
1314
+
1315
+
1316
+ // gridle mixin :
1317
+ // Generate all the classes needed for a grid
1318
+ @mixin gridle_generate_classes(
1319
+ $scope : null
1320
+ ) {
1321
+ // check if a scope exist :
1322
+ @if $scope != null {
1323
+ // wrapp grid into scope :
1324
+ .#{$scope} {
1325
+ @include _gridle_generate_classes(true);
1326
+ }
1327
+ } @else {
1328
+ // generate classes :
1329
+ @include _gridle_generate_classes(false);
1330
+ }
1331
+ }
1332
+ @mixin _gridle_generate_classes(
1333
+ $has-parent
1334
+ ) {
1335
+
1336
+ // Windows 8 fix for snap mode :
1337
+ @media screen and (max-width: 400px) {
1338
+ @-ms-viewport { width: device-width; }
1339
+ }
1340
+
1341
+ // body media query content :
1342
+ $gridle-settings-states : "{";
1343
+
1344
+ // generate container class :
1345
+ $container-selector : ();
1346
+ $container-selector : $container-selector, unquote(".container, .grid-container, .container-#{$gridle-columns-count}");
1347
+ #{$container-selector} {
1348
+ @include gridle_container();
1349
+ }
1350
+
1351
+ // generate all grid-x classes :
1352
+ @for $i from 0 through $gridle-columns-count {
1353
+
1354
+ .grid-#{$i*$gridle-name-multiplicator} {
1355
+ @include _gridle($i);
1356
+ }
1357
+ @if $gridle-generate-push-classes == true {
1358
+ .push-#{$i*$gridle-name-multiplicator} {
1359
+ @include _gridle_push($i);
1360
+ }
1361
+ }
1362
+ @if $gridle-generate-pull-classes == true {
1363
+ .pull-#{$i*$gridle-name-multiplicator} {
1364
+ @include _gridle_pull($i);
1365
+ }
1366
+ }
1367
+ @if $gridle-generate-prefix-classes == true {
1368
+ .prefix-#{$i*$gridle-name-multiplicator} {
1369
+ @include _gridle_prefix($i);
1370
+ }
1371
+ }
1372
+ @if $gridle-generate-suffix-classes == true {
1373
+ .suffix-#{$i*$gridle-name-multiplicator} {
1374
+ @include _gridle_suffix($i);
1375
+ }
1376
+ }
1377
+ }
1378
+
1379
+ // helpers classes :
1380
+ @if $gridle-generate-helpers-classes == true {
1381
+ @include _gridle_generate_helper_classes();
1382
+ }
1383
+
1384
+ // generate all selector for extends :
1385
+ $push-common-selector : ();
1386
+ $pull-common-selector : ();
1387
+ $prefix-common-selector : ();
1388
+ $suffix-common-selector : ();
1389
+ $common-selector : ();
1390
+ @for $i from 0 through $gridle-columns-count {
1391
+ $push-common-selector : $push-common-selector, unquote(".push-#{$i*$gridle-name-multiplicator}");
1392
+ $pull-common-selector : $pull-common-selector, unquote(".pull-#{$i*$gridle-name-multiplicator}");
1393
+ $prefix-common-selector : $prefix-common-selector, unquote(".prefix-#{$i*$gridle-name-multiplicator}");
1394
+ $suffix-common-selector : $suffix-common-selector, unquote(".suffix-#{$i*$gridle-name-multiplicator}");
1395
+ $common-selector : $common-selector, unquote(".grid-#{$i*$gridle-name-multiplicator}");
1396
+
1397
+ // generate all classes for media queries :
1398
+ @for $j from 1 through 15 {
1399
+ // setup vars :
1400
+ $media : _gridle_get_media_query_vars($j,"name");
1401
+ $min-width : _gridle_get_media_query_vars($j,"min-width");
1402
+ $max-width : _gridle_get_media_query_vars($j,"max-width");
1403
+ $classes : _gridle_get_media_query_vars($j,"classes");
1404
+ @if $min-width == null { $min-width : 0; }
1405
+ @if $max-width == null { $max-width : 999999; }
1406
+
1407
+ // generate classes :
1408
+ @if $media != null and $classes == true {
1409
+
1410
+ $push-common-selector : $push-common-selector, unquote(".push-#{$media}-#{$i*$gridle-name-multiplicator}");
1411
+ $pull-common-selector : $pull-common-selector, unquote(".pull-#{$media}-#{$i*$gridle-name-multiplicator}");
1412
+ $prefix-common-selector : $prefix-common-selector, unquote(".prefix-#{$media}-#{$i*$gridle-name-multiplicator}");
1413
+ $suffix-common-selector : $suffix-common-selector, unquote(".suffix-#{$media}-#{$i*$gridle-name-multiplicator}");
1414
+ $common-selector : $common-selector, unquote(".grid-#{$media}-#{$i*$gridle-name-multiplicator}");
1415
+ }
1416
+ }
1417
+
1418
+ // generate all classes for usefull states :
1419
+ @if $gridle-generate-useful-states-classes != null {
1420
+ @each $state in $gridle-generate-useful-states-classes {
1421
+ $push-common-selector : $push-common-selector, unquote(".push-#{$state}-#{$i*$gridle-name-multiplicator}");
1422
+ $pull-common-selector : $pull-common-selector, unquote(".pull-#{$state}-#{$i*$gridle-name-multiplicator}");
1423
+ $prefix-common-selector : $prefix-common-selector, unquote(".prefix-#{$state}-#{$i*$gridle-name-multiplicator}");
1424
+ $suffix-common-selector : $suffix-common-selector, unquote(".suffix-#{$state}-#{$i*$gridle-name-multiplicator}");
1425
+ $common-selector : $common-selector, unquote(".grid-#{$state}-#{$i*$gridle-name-multiplicator}");
1426
+ }
1427
+ }
1428
+ }
1429
+
1430
+ // extends :
1431
+ #{$push-common-selector} {
1432
+ @include _gridle_push_common();
1433
+ }
1434
+ #{$pull-common-selector} {
1435
+ @include _gridle_pull_common();
1436
+ }
1437
+ #{$prefix-common-selector} {
1438
+ @include _gridle_prefix_common();
1439
+ }
1440
+ #{$suffix-common-selector} {
1441
+ @include _gridle_suffix_common();
1442
+ }
1443
+ #{$common-selector} {
1444
+ @include _gridle_grid_common();
1445
+ }
1446
+
1447
+ // generate all classes for differents media queries :
1448
+ @for $i from 1 through 15 {
1449
+ // setup vars :
1450
+ $media : _gridle_get_media_query_vars($i,"name");
1451
+ $min-width : _gridle_get_media_query_vars($i,"min-width");
1452
+ $max-width : _gridle_get_media_query_vars($i,"max-width");
1453
+ $classes : _gridle_get_media_query_vars($i,"classes");
1454
+
1455
+ // generate all media queries grid classes :
1456
+ @if $media != null and $classes == true {
1457
+
1458
+ // manage body query :
1459
+ $body-query : _get_media_query_for_state($media);
1460
+ @if ($body-query != null) {
1461
+ @if $i == 1 {
1462
+ $gridle-settings-states : "#{$gridle-settings-states}\"#{$media}\":\"#{$body-query}\"";
1463
+ } @else {
1464
+ $gridle-settings-states : "#{$gridle-settings-states},\"#{$media}\":\"#{$body-query}\"";
1465
+ }
1466
+ }
1467
+
1468
+ // generate all the classes :
1469
+ @include gridle_responseTo($media, null, $has-parent) {
1470
+
1471
+ @for $j from 0 through $gridle-columns-count {
1472
+
1473
+ .grid-#{$media}-#{$j*$gridle-name-multiplicator} {
1474
+ @include _gridle($j,$media);
1475
+ }
1476
+ @if $gridle-generate-push-classes == true {
1477
+ .push-#{$media}-#{$j*$gridle-name-multiplicator} {
1478
+ @include _gridle_push($j,$media);
1479
+ }
1480
+ }
1481
+ @if $gridle-generate-pull-classes == true {
1482
+ .pull-#{$media}-#{$j*$gridle-name-multiplicator} {
1483
+ @include _gridle_pull($j,$media);
1484
+ }
1485
+ }
1486
+ @if $gridle-generate-prefix-classes == true {
1487
+ .prefix-#{$media}-#{$j*$gridle-name-multiplicator} {
1488
+ @include _gridle_prefix($j,$media);
1489
+ }
1490
+ }
1491
+ @if $gridle-generate-suffix-classes == true {
1492
+ .suffix-#{$media}-#{$j*$gridle-name-multiplicator} {
1493
+ @include _gridle_suffix($j,$media);
1494
+ }
1495
+ }
1496
+ }
1497
+
1498
+ // media queries helpers classes :
1499
+ @if $gridle-generate-helpers-classes == true and $media != null {
1500
+ @include _gridle_generate_helper_classes($media);
1501
+ }
1502
+ }
1503
+ }
1504
+ }
1505
+
1506
+ // usefull states :
1507
+ @if $gridle-generate-useful-states-classes != null {
1508
+ @each $state in $gridle-generate-useful-states-classes {
1509
+
1510
+ // manage body query :
1511
+ $body-query : _get_media_query_for_state($state);
1512
+ @if ($body-query != null) {
1513
+ $gridle-settings-states : "#{$gridle-settings-states},\"#{$state}\":\"#{$body-query}\"";
1514
+ }
1515
+
1516
+ // creating classes :
1517
+ @include gridle_responseTo($state, null, $has-parent) {
1518
+
1519
+ @for $k from 0 through $gridle-columns-count {
1520
+
1521
+ .grid-#{$state}-#{$k*$gridle-name-multiplicator} {
1522
+ @include _gridle($k,$state);
1523
+ }
1524
+ @if $gridle-generate-push-classes == true {
1525
+ .push-#{$state}-#{$k*$gridle-name-multiplicator} {
1526
+ @include _gridle_push($k,$state);
1527
+ }
1528
+ }
1529
+ @if $gridle-generate-pull-classes == true {
1530
+ .pull-#{$state}-#{$k*$gridle-name-multiplicator} {
1531
+ @include _gridle_pull($k,$state);
1532
+ }
1533
+ }
1534
+ @if $gridle-generate-prefix-classes == true {
1535
+ .prefix-#{$state}-#{$k*$gridle-name-multiplicator} {
1536
+ @include _gridle_prefix($k,$state);
1537
+ }
1538
+ }
1539
+ @if $gridle-generate-suffix-classes == true {
1540
+ .suffix-#{$state}-#{$k*$gridle-name-multiplicator} {
1541
+ @include _gridle_suffix($k,$state);
1542
+ }
1543
+ }
1544
+ }
1545
+
1546
+ @if $gridle-generate-helpers-classes == true {
1547
+ @include _gridle_generate_helper_classes($state);
1548
+ }
1549
+ }
1550
+ }
1551
+ }
1552
+
1553
+ // generate settings json :
1554
+ $gridle-settings-states : "#{$gridle-settings-states}}";
1555
+ $gridle-settings : "{";
1556
+ $gridle-settings : "#{$gridle-settings} \"states\" : #{$gridle-settings-states}";
1557
+ $gridle-settings : "#{$gridle-settings}, \"columnsCount\" : #{$gridle-columns-count}";
1558
+ $gridle-settings : "#{$gridle-settings}, \"gutterWidth\" : \"#{$gridle-gutter-width}\"";
1559
+ $gridle-settings : "#{$gridle-settings}, \"nameMultiplicator\" : #{$gridle-name-multiplicator}";
1560
+ $gridle-settings : "#{$gridle-settings}, \"direction\" : \"#{$gridle-direction}\"";
1561
+ $gridle-settings : "#{$gridle-settings}, \"ie7Support\" : #{$gridle-ie7-support}";
1562
+ $gridle-settings : "#{$gridle-settings}, \"debug\" : #{$gridle-debug}";
1563
+ $gridle-settings : "#{$gridle-settings}, \"debugShowClassNames\" : #{$gridle-debug-show-class-names}";
1564
+ $gridle-settings : "#{$gridle-settings}, \"htmlStatesClasses\" : #{$gridle-html-states-classes}";
1565
+ $gridle-settings : "#{$gridle-settings}, \"generateHelpersClasses\" : #{$gridle-generate-helpers-classes}";
1566
+ $gridle-settings : "#{$gridle-settings}, \"generatePushClasses\" : #{$gridle-generate-push-classes}";
1567
+ $gridle-settings : "#{$gridle-settings}, \"generatePullClasses\" : #{$gridle-generate-pull-classes}";
1568
+ $gridle-settings : "#{$gridle-settings}, \"generatePrefixClasses\" : #{$gridle-generate-prefix-classes}";
1569
+ $gridle-settings : "#{$gridle-settings}, \"generateSuffixClasses\" : #{$gridle-generate-suffix-classes}";
1570
+ $useful-states-classes : "[";
1571
+ @for $i from 1 through length($gridle-generate-useful-states-classes) {
1572
+ @if $i > 1 {
1573
+ $useful-states-classes : "#{$useful-states-classes},";
1574
+ }
1575
+ $useful-states-classes : "#{$useful-states-classes}\"#{nth($gridle-generate-useful-states-classes,$i)}\"";
1576
+ }
1577
+ $useful-states-classes : "#{$useful-states-classes}]";
1578
+ $gridle-settings : "#{$gridle-settings}, \"generateUsefulStatesClasses\" : #{$useful-states-classes}";
1579
+ $gridle-settings : "#{$gridle-settings}}";
1580
+ #gridle-settings {
1581
+ content : $gridle-settings;
1582
+ }
1583
+ }