Projet

Général

Profil

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

Thomas Jund, 25 mars 2021 12:54

Télécharger (3,26 ko)

Voir les différences:

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

 static/includes/_fx-grid.scss | 111 ++++++++++++++++++++++++++++++++++
 1 file changed, 111 insertions(+)
 create mode 100644 static/includes/_fx-grid.scss
static/includes/_fx-grid.scss
1
/*  ======
2
    grids - fx-grid.css
3

  
4
    flexbox grid system
5
    for multilines grid
6
===== */
7

  
8
// Publik vars
9
$fx-grid-gutter: 1.5rem !default;
10
$fx-grid-cell-min-size: 10em !default; // for .fx-grid--auto
11
$max-cols-xsmall : 3;
12
$max-cols-mobile : 6;
13
$max-cols-desktop : 9;
14

  
15
// Private vars
16
$fx-grid-half-gutter: $fx-grid-gutter / 2;
17

  
18
// custom media queries
19
//  @media ($max-mobile-viewport) {}
20
//  @media ($min-desktop-viewport) {}
21
$max-very-small-viewport: "max-width: #{$very-small-limit}";
22
$min-mobile-viewport: "min-width: #{$very-small-limit + 1}";
23
$min-desktop-viewport: "min-width: #{$mobile-limit + 1}";
24

  
25

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

  
37

  
38
  > * {
39
    margin-left: $fx-grid-half-gutter;
40
    margin-right: $fx-grid-half-gutter;
41
    flex-basis: calc(100% - #{$fx-grid-gutter});
42
    hyphens: auto;
43
  }
44
}
45

  
46

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

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

  
78
// custom grid cell size
79
.fx-grid,
80
[class*="fx-grid--"] {
81
  @for $i from 1 through $max-cols-xsmall {
82
    @for $j from 1 through $i {
83
      > .size--#{$j}-#{$i},
84
      > [class*="size--"][class*="--m#{$j}-#{$i}"] {
85
        flex-basis: calc( #{100%*$j/$i} - #{$fx-grid-gutter});
86
        flex-grow: 0;
87
      }
88
    }
89
  }
90
  @media ($min-mobile-viewport) {
91
    @for $i from 1 through $max-cols-mobile {
92
      @for $j from 1 through $i {
93
        > [class*="size--"][class*="--t#{$j}-#{$i}"] {
94
          flex-basis: calc( #{100%*$j/$i} - #{$fx-grid-gutter});
95
          flex-grow: 0;
96
        }
97
      }
98
    }
99
  }
100
  @media ($min-desktop-viewport) {
101
    @for $i from 1 through $max-cols-desktop {
102
      @for $j from 1 through $i {
103
        > [class*="size--"][class*="--d#{$j}-#{$i}"] {
104
          flex-basis: calc( #{100%*$j/$i} - #{$fx-grid-gutter});
105
          flex-grow: 0;
106
        }
107
      }
108
    }
109
  }
110

  
111
}
0
-