Last active
March 11, 2022 13:15
-
-
Save BenMorel/e9e34c08360ebbbd0634 to your computer and use it in GitHub Desktop.
SCSS mixin to support vh and vw units on all iOS Safari versions. Based on an idea by Patrick Burtchaell's: https://gist.github.com/pburtchaell/e702f441ba9b3f76f587
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
/** | |
* Fix for vw, vh, vmin, vmax on iOS 7. | |
* http://caniuse.com/#feat=viewport-units | |
* | |
* This fix works by replacing viewport units with px values on known screen sizes. | |
* | |
* iPhone 6 and 6 Plus cannot run iOS 7, so are not targeted by this fix. | |
* Target devices running iOS 8+ will incidentally execute the media query, | |
* but this will still produce the expected result; so this is not a problem. | |
* | |
* As an example, replace: | |
* | |
* height: 50vh; | |
* font-size: 5vmin; | |
* | |
* with: | |
* | |
* @include viewport-unit(height, 50vh); | |
* @include viewport-unit(font-size, 5vmin); | |
*/ | |
@mixin viewport-unit($property, $value) { | |
#{$property}: $value; | |
$unit: unit($value); | |
@if (index((vw, vh, vmin, vmax), $unit) != null) { | |
$devices: ( | |
(768px, 1024px), // iPad (all versions) | |
(320px, 480px), // iPhone 4 | |
(320px, 568px) // iPhone 5, 5C, 5S | |
); | |
@each $device in $devices { | |
$device-width: nth($device, 1); | |
$device-height: nth($device, 2); | |
$device-query: "only screen and (-webkit-min-device-pixel-ratio: 1)"; | |
$device-query: "#{$device-query} and (device-width: #{$device-width})"; | |
$device-query: "#{$device-query} and (device-height: #{$device-height})"; | |
$percent: $value / ($value * 0 + 1); // see https://github.com/sass/sass/issues/533 | |
$percent-width: $device-width * $percent / 100; | |
$percent-height: $device-height * $percent / 100; | |
@if ($unit == vmin or $unit == vmax) { | |
@media #{$device-query} { | |
#{$property}: if($unit == vmin, $percent-width, $percent-height); | |
} | |
} | |
@else { | |
@media #{$device-query} and (orientation: portrait) { | |
#{$property}: if($unit == vw, $percent-width, $percent-height); | |
} | |
@media #{$device-query} and (orientation: landscape) { | |
#{$property}: if($unit == vw, $percent-height, $percent-width); | |
} | |
} | |
} | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
can you plz explain how i can change the mixing to get height with minus calculation like height: calc(100vh - 680px);