-
Notifications
You must be signed in to change notification settings - Fork 55
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: html base pixel unit: changes the base from 16 to 10 (#34)
Match the pixel base of vscode
- Loading branch information
1 parent
8595831
commit 61b4825
Showing
11 changed files
with
156 additions
and
163 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,101 @@ | ||
$html-font-size: 16px; | ||
@function stripUnit($value) { | ||
@return calc($value / ($value * 0 + 1px)); | ||
// Extend sass-rem https://github.com/pierreburel/sass-rem | ||
// Update $baseline to set base pixel value | ||
|
||
@use 'sass:list'; | ||
@use 'sass:map'; | ||
@use 'sass:math'; | ||
@use 'sass:meta'; | ||
|
||
$baseline: 10px !default; | ||
$fallback: false !default; | ||
$px-only: false !default; | ||
|
||
// Dart Sass <1.33.0 compatibility | ||
@function _divide($a, $b) { | ||
@if map.has-key(meta.module-functions('math'), 'div') { | ||
@return math.div($a, $b); | ||
} | ||
|
||
@return $a / $b; | ||
} | ||
@function rem($pxValue) { | ||
@return #{calc(stripUnit($pxValue) / stripUnit($html-font-size))}rem; | ||
|
||
@function _convert($to, $values...) { | ||
$result: (); | ||
$separator: list.separator($values); | ||
|
||
@each $value in $values { | ||
@if meta.type-of($value) == | ||
'number' and | ||
math.unit($value) == | ||
'rem' and | ||
$to == | ||
'px' | ||
{ | ||
$result: list.append( | ||
$result, | ||
_divide($value, 1rem) * $baseline, | ||
$separator | ||
); | ||
} @else if | ||
meta.type-of($value) == | ||
'number' and | ||
math.unit($value) == | ||
'px' and | ||
$to == | ||
'rem' | ||
{ | ||
$result: list.append( | ||
$result, | ||
_divide($value, $baseline) * 1rem, | ||
$separator | ||
); | ||
} @else if meta.type-of($value) == 'list' { | ||
$result: list.append($result, _convert($to, $value...), $separator); | ||
} @else { | ||
$result: list.append($result, $value, $separator); | ||
} | ||
} | ||
|
||
@return if(list.length($result) == 1, list.nth($result, 1), $result); | ||
} | ||
|
||
@function convert($values...) { | ||
@if $px-only { | ||
@return _convert(px, $values...); | ||
} @else { | ||
@return _convert(rem, $values...); | ||
} | ||
} | ||
|
||
@mixin convert($properties, $values...) { | ||
@if meta.type-of($properties) == 'map' { | ||
@each $property, $values in $properties { | ||
@include convert($property, $values); | ||
} | ||
} @else { | ||
@each $property in $properties { | ||
@if $fallback or $px-only { | ||
#{$property}: _convert(px, $values...); | ||
} | ||
@if not $px-only { | ||
#{$property}: _convert(rem, $values...); | ||
} | ||
} | ||
} | ||
} | ||
|
||
@function rem($values...) { | ||
@return convert($values...); | ||
} | ||
|
||
@mixin rem($properties, $values...) { | ||
@include convert($properties, $values...); | ||
} | ||
|
||
@mixin baseline($zoom: 100%) { | ||
font-size: _divide($zoom, 16px) * $baseline; | ||
} | ||
|
||
html { | ||
@include baseline; | ||
} |
Oops, something went wrong.