Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Simplify responsive utilities with $responsive-variants #545

Merged
merged 33 commits into from
Oct 18, 2018
Merged
Show file tree
Hide file tree
Changes from 32 commits
Commits
Show all changes
33 commits
Select commit Hold shift + click to select a range
f3c9bca
support empty string in breakpoint() mixin
shawnbot Jul 18, 2018
92a2cef
add $responsive-variants map
shawnbot Jul 18, 2018
b632983
add docs for $responsive-variants
shawnbot Jul 18, 2018
182cd2e
use $responsive-variants for .float-*
shawnbot Jul 18, 2018
94748cf
use $responsive-variants and list for .d-*
shawnbot Jul 18, 2018
f3b8e57
use $responsive-variants for .direction-*
shawnbot Jul 18, 2018
957e55c
use $responsive-variants in .border-*, .rounded-*;
shawnbot Jul 18, 2018
2a8647f
add .rounded-<edge> utility docs
shawnbot Jul 18, 2018
cff39b5
line up border-color util parens
shawnbot Jul 18, 2018
6bf88ce
use $responsive-variants for margin utils
shawnbot Jul 18, 2018
c73a52b
use $responsive-variants for padding utils
shawnbot Jul 18, 2018
ac762d2
fix #472
shawnbot Jul 18, 2018
55cde57
remove variable interpolations in padding utils
shawnbot Jul 18, 2018
3bdccf9
add caution bits for $responsive-variants
shawnbot Jul 18, 2018
034e76a
nix unnecessary interpolations in comments
shawnbot Jul 18, 2018
05c8d29
use $responsive-variants for flex utils
shawnbot Jul 18, 2018
4b6cdb0
use $responsive-variants for .text-*
shawnbot Jul 18, 2018
7341f7f
normalize whitespace
shawnbot Jul 18, 2018
4124a31
update package-lock.json
shawnbot Jul 20, 2018
6d5983f
Merge remote-tracking branch 'origin/master' into responsive-variants
shawnbot Aug 23, 2018
314eeb4
move responsive border docs from marketing to core
shawnbot Aug 23, 2018
eea1415
[breaking] remove responsive borders from marketing-utilities
shawnbot Aug 23, 2018
92fd60c
move responsive borders from marketing into primer-utilities
shawnbot Aug 23, 2018
2ebc81a
Merge branch 'release-10.9.0' into responsive-variants
shawnbot Oct 15, 2018
96d1e4f
make mx-auto responsive a la #577
shawnbot Oct 16, 2018
9c312fb
Merge remote-tracking branch 'origin/release-10.9.0' into responsive-…
shawnbot Oct 17, 2018
4c975aa
Update modules/primer-layout/lib/grid-offset.scss
Oct 17, 2018
957fa8b
rebuild package-lock
shawnbot Oct 17, 2018
11fe822
Merge pull request #582 from primer/offset-is-important-v2
shawnbot Oct 17, 2018
3173ad7
Merge remote-tracking branch 'origin/release-10.9.0' into responsive-…
shawnbot Oct 18, 2018
6e98ed2
move links to the bottom
shawnbot Oct 18, 2018
52f468c
update package-lock
shawnbot Oct 18, 2018
4cfa9b8
Merge branch 'release-10.9.0' into responsive-variants
shawnbot Oct 18, 2018
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 4 additions & 4 deletions .github/CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -1,9 +1,5 @@
## Contributing

[fork]: https://github.com/primer/primer/fork
[pr]: https://github.com/primer/primer/compare
[style]: https://styleguide.github.com/primer/principles/

Hi there! We're thrilled that you'd like to contribute to this project. Your help is essential for keeping it great.

## Using the issue tracker
Expand Down Expand Up @@ -185,3 +181,7 @@ This section is targeted at maintainers of primer, to instruct them on the proce
- [Contributing to Open Source on GitHub](https://guides.github.com/activities/contributing-to-open-source/)
- [Using Pull Requests](https://help.github.com/articles/using-pull-requests/)
- [GitHub Help](https://help.github.com)

[fork]: https://github.com/primer/primer/fork
[pr]: https://github.com/primer/primer/compare
[style]: https://styleguide.github.com/primer/principles/
35 changes: 12 additions & 23 deletions modules/primer-layout/lib/grid-offset.scss
Original file line number Diff line number Diff line change
@@ -1,30 +1,19 @@
// Optional offset options to work with grid.scss

// Offset Columns
.offset-1 { margin-left: (1 / 12 * 100%); }
.offset-2 { margin-left: (2 / 12 * 100%); }
.offset-3 { margin-left: (3 / 12 * 100%); }
.offset-4 { margin-left: (4 / 12 * 100%); }
.offset-5 { margin-left: (5 / 12 * 100%); }
.offset-6 { margin-left: (6 / 12 * 100%); }
.offset-7 { margin-left: (7 / 12 * 100%); }
.offset-8 { margin-left: (8 / 12 * 100%); }
.offset-9 { margin-left: (9 / 12 * 100%); }
.offset-10 { margin-left: (10 / 12 * 100%); }
.offset-11 { margin-left: (11 / 12 * 100%); }

@each $breakpoint in map-keys($breakpoints) {
@each $breakpoint, $variant in $responsive-variants {
@include breakpoint($breakpoint) {
.offset-#{$breakpoint}-1 { margin-left: (1 / 12 * 100%); }
.offset-#{$breakpoint}-2 { margin-left: (2 / 12 * 100%); }
.offset-#{$breakpoint}-3 { margin-left: (3 / 12 * 100%); }
.offset-#{$breakpoint}-4 { margin-left: (4 / 12 * 100%); }
.offset-#{$breakpoint}-5 { margin-left: (5 / 12 * 100%); }
.offset-#{$breakpoint}-6 { margin-left: (6 / 12 * 100%); }
.offset-#{$breakpoint}-7 { margin-left: (7 / 12 * 100%); }
.offset-#{$breakpoint}-8 { margin-left: (8 / 12 * 100%); }
.offset-#{$breakpoint}-9 { margin-left: (9 / 12 * 100%); }
.offset-#{$breakpoint}-10 { margin-left: (10 / 12 * 100%); }
.offset-#{$breakpoint}-11 { margin-left: (11 / 12 * 100%); }
.offset#{$variant}-1 { margin-left: (1 / 12 * 100%) !important; }
.offset#{$variant}-2 { margin-left: (2 / 12 * 100%) !important; }
.offset#{$variant}-3 { margin-left: (3 / 12 * 100%) !important; }
.offset#{$variant}-4 { margin-left: (4 / 12 * 100%) !important; }
.offset#{$variant}-5 { margin-left: (5 / 12 * 100%) !important; }
.offset#{$variant}-6 { margin-left: (6 / 12 * 100%) !important; }
.offset#{$variant}-7 { margin-left: (7 / 12 * 100%) !important; }
.offset#{$variant}-8 { margin-left: (8 / 12 * 100%) !important; }
.offset#{$variant}-9 { margin-left: (9 / 12 * 100%) !important; }
.offset#{$variant}-10 { margin-left: (10 / 12 * 100%) !important; }
.offset#{$variant}-11 { margin-left: (11 / 12 * 100%) !important; }
}
}
10 changes: 0 additions & 10 deletions modules/primer-marketing-utilities/docs/borders.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,16 +7,6 @@ The following border utilities are meant to used in addition to those within pri

{:toc}

## Responsive borders

Top, right, bottom, and left border utilities are can be used responsively to add or remove borders to an element at different screensizes.

```html
<div class="border-top border-sm-right border-md-bottom border-lg-top-0">
.border-top-0
</div>
```

## Border Colors

### White border with alpha transparency
Expand Down
20 changes: 3 additions & 17 deletions modules/primer-marketing-utilities/lib/borders.scss
Original file line number Diff line number Diff line change
@@ -1,20 +1,6 @@
// Border utilities
// stylelint-disable block-opening-brace-space-before, primer/selector-no-utility, comment-empty-line-before

// Responsive border utilities

@each $breakpoint in map-keys($breakpoints) {
@include breakpoint($breakpoint) {
.border-#{$breakpoint}-top { border-top: $border !important; }
.border-#{$breakpoint}-right { border-right: $border !important; }
.border-#{$breakpoint}-bottom { border-bottom: $border !important; }
.border-#{$breakpoint}-left { border-left: $border !important; }
.border-#{$breakpoint}-top-0 { border-top: 0 !important; }
.border-#{$breakpoint}-right-0 { border-right: 0 !important; }
.border-#{$breakpoint}-bottom-0 { border-bottom: 0 !important; }
.border-#{$breakpoint}-left-0 { border-left: 0 !important; }
}
}

/* Use with .border to turn the border rgba white 0.15 */
.border-white-fade { border-color: $white-fade-15 !important; }
.border-white-fade {
border-color: $white-fade-15 !important;
}
26 changes: 26 additions & 0 deletions modules/primer-support/docs/breakpoints.md
Original file line number Diff line number Diff line change
Expand Up @@ -58,3 +58,29 @@ Media queries are scoped from each breakpoint and upwards. In the example below,
@include breakpoint(md) { font-size: 32px; }
}
```

## Responsive variants
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These docs should live in the contributing section of the style guide.

The `$responsive-variants` variable is a mapping of breakpoints to classname variants, and should be used like so:

```scss
@each $breakpoint, $variant in $responsive-variants {
@include breakpoint($breakpoint) {
// Note: the first iteration gets `$variant == ""`
.overflow#{$variant}-auto { overflow: auto; }
}
}
```

The resulting CSS would be:

```css
.overflow-auto { overflow: auto; }
@media (min-width: 544px) { .overflow-sm-auto { overflow: auto; } }
@media (min-width: 768px) { .overflow-md-auto { overflow: auto; } }
@media (min-width: 1012px) { .overflow-lg-auto { overflow: auto; } }
@media (min-width: 1280px) { .overflow-xl-auto { overflow: auto; } }
```

#### Caution!
1. Don't precede the `#{$variation}` interpolation with a hyphen because the first value of `$variant` will be an empty string.
1. For consistency, please put the `@include breakpoint($breakpoint)` call directly inside the `$responsive-variants` loop. This will help keep file sizes small by "batching" selectors in shared `@media` queries.
30 changes: 18 additions & 12 deletions modules/primer-support/lib/mixins/layout.scss
Original file line number Diff line number Diff line change
@@ -1,21 +1,27 @@
// Responsive media queries

@mixin breakpoint($breakpoint) {
// Retrieves the value from the key
$value: map-get($breakpoints, $breakpoint);

// If the key exists in the map
@if $value != null {
// Prints a media query based on the value
@media (min-width: $value) {
@content;
}
@if $breakpoint == "" {
@content;
}

// If the key doesn't exist in the map
@else {
@warn "Unfortunately, no value could be retrieved from `#{$breakpoint}`. "
+ "Please make sure it is defined in `$breakpoints` map.";
// Retrieves the value from the key
$value: map-get($breakpoints, $breakpoint);

// If the key exists in the map
@if $value != null {
// Prints a media query based on the value
@media (min-width: $value) {
@content;
}
}

// If the key doesn't exist in the map
@else {
@warn "Unfortunately, no value could be retrieved from `#{$breakpoint}`. "
+ "Please make sure it is defined in `$breakpoints` map.";
}
}
}

Expand Down
5 changes: 5 additions & 0 deletions modules/primer-support/lib/variables/layout.scss
Original file line number Diff line number Diff line change
Expand Up @@ -65,3 +65,8 @@ $breakpoints: (
// Extra large screen / wide desktop
xl: $width-xl
) !default;

$responsive-variants: ("": "");
shawnbot marked this conversation as resolved.
Show resolved Hide resolved
@each $key in map-keys($breakpoints) {
$responsive-variants: map-merge($responsive-variants, ($key: "-#{$key}"));
}
28 changes: 28 additions & 0 deletions modules/primer-utilities/docs/borders.md
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@ Override default border colors with blue, green, red, purple, yellow, and gray b
```

### Borders with alpha transparency

Use `border-black-fade` to add an rgba black border with an alpha transparency of `0.15`. This is useful when you want a border that tints the background color. The shade of black we use matches the hue of the GitHub dark header and our gray color palette: `rgba(27,31,35, 0.15)`.

```html
Expand Down Expand Up @@ -125,3 +126,30 @@ Use the following utilities to add or remove rounded corners: `rounded-0` remove
.circle
</div>
```

You can also add rounded corners to each edge (top, right, bottom, left) with the following utilities:

```html
<div class="border rounded-top mb-2">
.rounded-top
</div>
<div class="border rounded-right mb-2">
.rounded-right
</div>
<div class="border rounded-bottom mb-2">
.rounded-bottom
</div>
<div class="border rounded-left mb-2">
.rounded-left
</div>
```

## Responsive borders

Top, right, bottom, and left border utilities are can be used responsively to add or remove borders to an element at different screensizes.

```html
<div class="border-top border-sm-right border-md-bottom border-lg-top-0">
.border-top-0
</div>
```
107 changes: 71 additions & 36 deletions modules/primer-utilities/lib/borders.scss
Original file line number Diff line number Diff line change
@@ -1,65 +1,100 @@
// Border utilities
// stylelint-disable block-opening-brace-space-before, primer/selector-no-utility, comment-empty-line-before

/* Add a gray border */
.border { border: $border !important; }
/* Add a gray border to the top */
.border-top { border-top: $border !important; }
/* Add a gray border to the right */
.border-right { border-right: $border !important; }
/* Add a gray border to the bottom */
.border-bottom { border-bottom: $border !important; }
/* Add a gray border to the left */
.border-left { border-left: $border !important; }
/* Add a gray border on all sides */
.border { border: $border !important; }

/* Add a gray border to the left and right */
.border-y {
border-top: $border !important;
border-bottom: $border !important;
}

/* Remove borders from all sides */
.border-0 { border: 0 !important; }

.border-dashed { border-style: dashed !important; }

/* Use with .border to turn the border blue */
.border-blue { border-color: $border-blue !important; }
.border-blue { border-color: $border-blue !important; }
/* Use with .border to turn the border blue-light */
.border-blue-light { border-color: $border-blue-light !important; }
/* Use with .border to turn the border green */
.border-green { border-color: $border-green !important; }
.border-green { border-color: $border-green !important; }
/* Use with .border to turn the border green light */
.border-green-light { border-color: $border-green-light !important; }
/* Use with .border to turn the border red */
.border-red { border-color: $border-red !important; }
.border-red { border-color: $border-red !important; }
/* Use with .border to turn the border red-light */
.border-red-light { border-color: $border-red-light !important; }
/* Use with .border to turn the border purple */
.border-purple { border-color: $border-purple !important; }
.border-purple { border-color: $border-purple !important; }
/* Use with .border to turn the border yellow */
.border-yellow { border-color: $border-yellow !important; }
.border-yellow { border-color: $border-yellow !important; }
/* Use with .border to turn the border gray-light */
.border-gray-light { border-color: $border-gray-light !important; }
.border-gray-light { border-color: $border-gray-light !important; }
/* Use with .border to turn the border gray-dark */
.border-gray-dark { border-color: $border-gray-dark !important; }
.border-gray-dark { border-color: $border-gray-dark !important; }
/* Use with .border to turn the border rgba black 0.15 */
.border-black-fade { border-color: $border-black-fade !important; }
.border-black-fade { border-color: $border-black-fade !important; }

$edges: (
top: (top-left, top-right),
right: (top-right, bottom-right),
bottom: (bottom-right, bottom-left),
left: (bottom-left, top-left)
);

@each $breakpoint, $variant in $responsive-variants {
@include breakpoint($breakpoint) {
/* Add a gray border */
/* Add a gray border to the top */
.border#{$variant}-top { border-top: $border !important; }
/* Add a gray border to the right */
.border#{$variant}-right { border-right: $border !important; }
/* Add a gray border to the bottom */
.border#{$variant}-bottom { border-bottom: $border !important; }
/* Add a gray border to the left */
.border#{$variant}-left { border-left: $border !important; }

/* Remove the top border */
.border#{$variant}-top-0 { border-top: 0 !important; }
/* Remove the right border */
.border#{$variant}-right-0 { border-right: 0 !important; }
/* Remove the bottom border */
.border#{$variant}-bottom-0 { border-bottom: 0 !important; }
/* Remove the left border */
.border#{$variant}-left-0 { border-left: 0 !important; }

// Without borders
/* Remove all borders */
.border-0 { border: 0 !important; }
/* Remove the top border */
.border-top-0 { border-top: 0 !important; }
/* Remove the right border */
.border-right-0 { border-right: 0 !important; }
/* Remove the bottom border */
.border-bottom-0 { border-bottom: 0 !important; }
/* Remove the left border */
.border-left-0 { border-left: 0 !important; }
// Rounded corners
/* Remove the border-radius */
.rounded#{$variant}-0 { border-radius: 0 !important; }
/* Add a border-radius to all corners */
.rounded#{$variant}-1 { border-radius: $border-radius !important; }
/* Add a 2x border-radius to all corners */
.rounded#{$variant}-2 { border-radius: $border-radius * 2 !important; }

@each $edge, $corners in $edges {
.rounded#{$variant}-#{$edge}-0 {
@each $corner in $corners {
border-#{$corner}-radius: 0;
}
}

.rounded#{$variant}-#{$edge}-1 {
@each $corner in $corners {
border-#{$corner}-radius: $border-radius;
}
}

.rounded#{$variant}-#{$edge}-2 {
@each $corner in $corners {
border-#{$corner}-radius: $border-radius * 2;
}
}
}
}
}

// Rounded corners
/* Remove the border-radius */
.rounded-0 { border-radius: 0 !important; }
/* Add a border-radius to all corners */
.rounded-1 { border-radius: $border-radius !important; }
/* Add a 2x border-radius to all corners */
.rounded-2 { border-radius: $border-radius * 2 !important; }
/* Add a 50% border-radius to make something into a circle */
.circle { border-radius: 50% !important; }
Loading