Projet

Général

Profil

0001-scss-new-grid-system-with-flexbox-52336.patch

Thomas Jund, 29 juin 2021 16:11

Télécharger (3,7 ko)

Voir les différences:

Subject: [PATCH] scss: new grid system with flexbox (#52336)

 static/includes/_fx-grid.scss | 109 ++++++++++++++++++++++++++++++++++
 static/includes/_publik.scss  |   1 +
 2 files changed, 110 insertions(+)
 create mode 100644 static/includes/_fx-grid.scss
static/includes/_fx-grid.scss
1
// ======
2
//	fx-grid.css
3
//	flexbox grid system
4
// =====
5

  
6
// Internal parameters variables
7
$fx-grid-gutter: 1.5rem !default;
8
$fx-grid-cell-min-size: 10em !default; // for .fx-grid--auto
9
$fx-grid-mobile-limit: $very-small-limit !default;
10
$fx-grid-tablet-limit: $mobile-limit !default;
11
$max-cols-mobile : 3 !default;
12
$max-cols-tablet : 6 !default;
13
$max-cols-desktop : 9 !default;
14

  
15
// Computed variables, they should not be redefined.
16
$fx-grid-half-gutter: $fx-grid-gutter / 2;
17

  
18
//	custom media queries
19
//		ex. @media ($max-grid-mobile-viewport) {}
20
$max-grid-mobile-viewport: "max-width: #{$fx-grid-mobile-limit}";
21
$min-grid-tablet-viewport: "min-width: #{min-desktop-viewport($fx-grid-mobile-limit)}";
22
$min-grid-desktop-viewport: "min-width: #{min-desktop-viewport($fx-grid-tablet-limit)}";
23

  
24

  
25
.fx-grid,
26
[class*="fx-grid--"] {
27
	display: flex;
28
	flex-wrap: wrap;
29
	margin: 0;
30
	padding: 0;
31
	margin-left: -1 * $fx-grid-half-gutter;
32
	margin-right: -1 * $fx-grid-half-gutter;
33
	/* if flex item are list */
34
	list-style-type: none;
35

  
36
	> * {
37
		box-sizing: border-box; // for gadjo
38
		margin-left: $fx-grid-half-gutter;
39
		margin-right: $fx-grid-half-gutter;
40
		flex-basis: calc(100% - #{$fx-grid-gutter});
41
		hyphens: auto;
42
	}
43
}
44

  
45

  
46
// mode auto
47
.fx-grid--auto {
48
	> * {
49
		flex-basis: $fx-grid-cell-min-size;
50
		flex-shrink: 1;
51
		flex-grow: 1;
52
	}
53
}
54

  
55
// mode cols
56
@for $i from 2 through $max-cols-mobile {
57
	.fx-grid--#{$i} > *,
58
	[class*="fx-grid--"][class*="--m#{$i}"] > * {
59
		flex-basis: calc(#{100%/$i} - #{$fx-grid-gutter});
60
	}
61
}
62
@media ($min-grid-tablet-viewport) {
63
		@for $i from 2 through $max-cols-tablet {
64
		[class*="fx-grid--"][class*="--t#{$i}"] > * {
65
			flex-basis: calc(#{100%/$i} - #{$fx-grid-gutter});
66
		}
67
	}
68
}
69
@media ($min-grid-desktop-viewport) {
70
		@for $i from 2 through $max-cols-desktop {
71
		[class*="fx-grid--"][class*="--d#{$i}"] > * {
72
			flex-basis: calc(#{100%/$i} - #{$fx-grid-gutter});
73
		}
74
	}
75
}
76

  
77
// custom grid cell size
78
.fx-grid,
79
[class*="fx-grid--"] {
80
	@for $i from 1 through $max-cols-mobile {
81
		@for $j from 1 through $i {
82
			> .size--#{$j}-#{$i},
83
			> [class*="size--"][class*="--m#{$j}-#{$i}"] {
84
				flex-basis: calc( #{100%*$j/$i} - #{$fx-grid-gutter});
85
				flex-grow: 0;
86
			}
87
		}
88
	}
89
	@media ($min-grid-tablet-viewport) {
90
		@for $i from 1 through $max-cols-tablet {
91
			@for $j from 1 through $i {
92
				> [class*="size--"][class*="--t#{$j}-#{$i}"] {
93
					flex-basis: calc( #{100%*$j/$i} - #{$fx-grid-gutter});
94
					flex-grow: 0;
95
				}
96
			}
97
		}
98
	}
99
	@media ($min-grid-desktop-viewport) {
100
		@for $i from 1 through $max-cols-desktop {
101
			@for $j from 1 through $i {
102
				> [class*="size--"][class*="--d#{$j}-#{$i}"] {
103
					flex-basis: calc( #{100%*$j/$i} - #{$fx-grid-gutter});
104
					flex-grow: 0;
105
				}
106
			}
107
		}
108
	}
109
}
static/includes/_publik.scss
2 2
@import 'general';
3 3
@import 'title';
4 4
@import 'layout';
5
@import 'fx-grid';
5 6
@import 'header';
6 7
@import 'nav';
7 8
@import 'cells';
8
-