gridle 1.1.0 → 1.2.0

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