diff --git a/README.md b/README.md index ccfbe57..ce4a269 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ [Live demo](http://nigelotoole.github.io/pixel-borders/) -## A SASS mixin to add pixelated borders to HTML elements, which can be customized for different sizes, colour coding,inset borders. +## A SASS mixin to add pixelated borders to HTML elements, which can be customized for different sizes, styles and colour coding. ## Installation @@ -14,10 +14,16 @@ $ npm install pixel-borders --save-dev ### Import -After adding the repo as a dependency you can import it into your SASS files. Alternatively you can download the pixel-borders.scss from this repo and add it to your project folder directly. +After installation you can import it into your SASS files with the statement below. ```scss -@import "node_modules/pixel-borders/src/styles/pixel-borders.scss"; +@import "pixel-borders/src/styles/pixel-borders.scss"; +``` + +You can also just import the mixins without the demo styles. + +```scss +@import "pixel-borders/src/styles/pixel-borders/pixel-borders-mixins"; ``` #### Pixel borders mixin options diff --git a/docs/index.html b/docs/index.html index 804b33f..4d90134 100644 --- a/docs/index.html +++ b/docs/index.html @@ -3,7 +3,7 @@ - Pixel borders - A SASS mixin to add pixelated borders to HTML elements + Pixel borders - SASS mixin to add pixelated borders to HTML elements @@ -30,7 +30,7 @@
-

A SASS mixin to add pixelated borders to HTML elements, which can be customized for different sizes, colour coding,inset borders.

+

A SASS mixin to add pixelated borders to HTML elements, which can be customized for different sizes, styles and colour coding.

@@ -84,9 +84,13 @@

Import

-

After adding the repo as a dependency you can import it into your SASS files. Alternatively you can download the pixel-borders.scss from this repo and add it to your project folder directly.

+

After installation you can import it into your SASS files with the statement below. Alternatively you can download the pixel-borders.scss from this repo and add it to your project folder directly.

-
@import "node_modules/pixel-borders/src/styles/pixel-borders.scss";
+
@import "pixel-borders/src/styles/pixel-borders.scss";
+ +

You can also just import the mixins without the demo styles.

+ +
@import "pixel-borders/src/styles/pixel-borders/pixel-borders-mixins";

Pixel borders mixin options

diff --git a/docs/styles/pixel-borders.css b/docs/styles/pixel-borders.css index 4233d02..7dd70ad 100644 --- a/docs/styles/pixel-borders.css +++ b/docs/styles/pixel-borders.css @@ -441,4 +441,4 @@ background-color: #e45b3f; } -/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["pixel-borders.scss","pixel-borders.css"],"names":[],"mappings":"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","file":"pixel-borders.css","sourcesContent":["// Generate SVG image for pixelated corners\n@function pixel-borders-image($corner-size, $color) {\n  $svg: '';\n  $svg-path: '';\n  $svg-size: $corner-size * 6;\n  $color: str-replace('' + $color, '#', '%23');\n\n  @if $corner-size == 1 {\n    $svg-path: 'M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z';\n  } @else {\n    $svg-path: 'M2 2h2v2H2zM4 0h2v2H4zM10 4h2v2h-2zM0 4h2v2H0zM6 0h2v2H6zM8 2h2v2H8zM8 8h2v2H8zM6 10h2v2H6zM0 6h2v2H0zM10 6h2v2h-2zM4 10h2v2H4zM2 8h2v2H2z';\n  }\n\n  $svg: 'data:image/svg+xml,<svg xmlns=\\'http://www.w3.org/2000/svg\\' width=\\'#{$svg-size}\\' height=\\'#{$svg-size}\\'><path d=\\'#{$svg-path}\\' fill=\\'#{$color}\\' /></svg>';\n\n  @return $svg;\n}\n\n\n// String replace function - replace `$search` with `$replace` in `$string`\n@function str-replace($string, $search, $replace: '') {\n  $index: str-index($string, $search);\n\n  @if $index {\n    @return str-slice($string, 1, $index - 1) + $replace + str-replace(str-slice($string, $index + str-length($search)), $search, $replace);\n  }\n\n  @return $string;\n}\n\n\n// Pixel border\n@mixin pixel-borders($corner-size: 1, $border-size: 4px, $border-color: #000, $border-inset-color: false) {\n\n  @supports (border-image-source: none) {\n    border-radius: ($border-size * ($corner-size + 2)) + ($corner-size * 2);\n  }\n\n  border-style: solid;\n  border-width: $border-size;\n  border-color: $border-color;\n\n  border-image-slice: $corner-size * 2;\n  border-image-width: $corner-size;\n  border-image-outset: 0;\n\n  border-image-source: url(pixel-borders-image($corner-size, $border-color));\n\n  @if $border-inset-color {\n    @include pixel-inset-border($border-size, $border-inset-color);\n  }\n\n}\n\n\n// Pixel inset border\n@mixin pixel-inset-border($border-inset-size: 4px, $border-inset-color: #ddd, $border-inset-sides: 'bottom-right', $border-inset-color-br: false, $border-inset-color-tl: false) {\n\n  $box-shadow: '';\n  @if not($border-inset-color-br) {\n    $border-inset-color-br: $border-inset-color;\n  }\n\n  @if not($border-inset-color-tl) {\n    $border-inset-color-tl: $border-inset-color;\n  }\n\n  position: relative;\n\n  &::after {\n    content: '';\n    position: absolute;\n    z-index: 0;\n    bottom: 0;\n    right: 0;\n    width: 100%;\n    height: 100%;\n\n    @if $border-inset-sides == 'bottom-right' or $border-inset-sides == false {\n      $box-shadow: inset -#{$border-inset-size} -#{$border-inset-size} $border-inset-color-br;\n    }\n\n    @if $border-inset-sides == 'top-left' {\n      $box-shadow: inset $border-inset-size $border-inset-size $border-inset-color-tl;\n    }\n\n    @if $border-inset-sides == 'all' {\n      $box-shadow: inset -#{$border-inset-size} -#{$border-inset-size} $border-inset-color-br, inset $border-inset-size $border-inset-size $border-inset-color-tl;\n    }\n\n    box-shadow: $box-shadow;\n  }\n\n}\n\n\n\n// Pixel box - Colours for border and inset are calculated using $background-color unless $border-color is passed\n@mixin pixel-box($corner-size, $border-size, $background-color, $border-color: false, $border-inset: true, $border-inset-size: false, $border-inset-color: false, $border-inset-sides: false, $border-inset-color-br: false, $border-inset-color-tl: false) {\n  \n  $background-color-hover: darken($background-color, 5);\n\n  @if not($border-color) {\n    $border-color: darken($background-color, 20);\n  }\n\n  @include pixel-borders($corner-size: $corner-size, $border-size: $border-size, $border-color: $border-color);\n\n  @if $border-inset-sides == 'all' and not($border-inset-color) {\n    $border-inset-color-br: darken($background-color, 10);\n    $border-inset-color-tl: lighten($background-color, 15);\n  }\n\n  @if not($border-inset-color) { \n    $border-inset-color: darken($background-color, 10);\n  }\n\n  @if $border-inset-sides == 'top-left' {\n    $border-inset-color: lighten($background-color, 15);\n  }\n\n\n  @if $border-inset { \n    @include pixel-inset-border($border-inset-size: $border-size, $border-inset-color: $border-inset-color, $border-inset-sides: $border-inset-sides, $border-inset-color-br: $border-inset-color-br, $border-inset-color-tl: $border-inset-color-tl);\n  }\n\n  background-color: $background-color;\n\n  &:hover, &:focus {\n    background-color: $background-color-hover;\n  }\n\n}\n\n\n\n// ----- Demo styles -----\n.pixel-borders {\n  position: relative;\n  display: inline-block;\n  margin: 0 15px 15px 0;\n  padding: 15px 20px;\n  background-color: #fff;\n  font-family: \"Press Start 2P\", Arial Black, Arial Bold, Arial, sans-serif;\n}\n\n\n// Simple examples with default styling\n.pixel-borders--1 {\n  @include pixel-borders();\n}\n\n.pixel-borders--1-inset {\n  @include pixel-borders($border-inset-color: #ddd);\n}\n\n\n.pixel-borders--2 {\n  @include pixel-borders($corner-size: 2);\n}\n\n.pixel-borders--2-inset {\n  @include pixel-borders($corner-size: 2);\n\n  &::after {\n    @include pixel-borders($corner-size: 1, $border-color: #ddd);\n\n    content: '';\n    position: absolute;\n    z-index: 0;\n    bottom: 0;\n    right: 0;\n    border-image-width: 0 1 1 0;\n    width: calc(100% - 4px);\n    height: calc(100% - 4px);\n  }\n}\n\n\n\n// Examples using the pixel box mixin to colour code the elements\n.pixel-box--light {\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #fff);\n}\n\n.pixel-box--primary {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #209cee);\n}\n\n.pixel-box--success {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #92cc41);\n} \n\n.pixel-box--warning {\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #f7d51d);\n} \n\n.pixel-box--error {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #e76e55);\n} \n\n\n// Custom examples to show flexibility of the mixins\n.pixel-box--light-custom {\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #fff, $border-inset-color: #999, $border-inset-sides: 'all');\n}\n\n.pixel-box--primary-custom {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #209cee, $border-inset: false);\n}\n\n.pixel-box--success-custom {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #92cc41, $border-inset-sides: 'top-left');\n} \n\n.pixel-box--warning-custom {\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #f7d51d, $border-inset-sides: 'all');\n} \n\n.pixel-box--error-custom {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #e76e55, $border-color: #000);\n} \n",".pixel-borders {\n  position: relative;\n  display: inline-block;\n  margin: 0 15px 15px 0;\n  padding: 15px 20px;\n  background-color: #fff;\n  font-family: \"Press Start 2P\", Arial Black, Arial Bold, Arial, sans-serif;\n}\n\n.pixel-borders--1 {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #000;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23000' /></svg>\");\n}\n\n@supports (border-image-source: none) {\n  .pixel-borders--1 {\n    border-radius: 14px;\n  }\n}\n\n.pixel-borders--1-inset {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #000;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23000' /></svg>\");\n  position: relative;\n}\n\n@supports (border-image-source: none) {\n  .pixel-borders--1-inset {\n    border-radius: 14px;\n  }\n}\n\n.pixel-borders--1-inset::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #ddd;\n}\n\n.pixel-borders--2 {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #000;\n  border-image-slice: 4;\n  border-image-width: 2;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12'><path d='M2 2h2v2H2zM4 0h2v2H4zM10 4h2v2h-2zM0 4h2v2H0zM6 0h2v2H6zM8 2h2v2H8zM8 8h2v2H8zM6 10h2v2H6zM0 6h2v2H0zM10 6h2v2h-2zM4 10h2v2H4zM2 8h2v2H2z' fill='%23000' /></svg>\");\n}\n\n@supports (border-image-source: none) {\n  .pixel-borders--2 {\n    border-radius: 20px;\n  }\n}\n\n.pixel-borders--2-inset {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #000;\n  border-image-slice: 4;\n  border-image-width: 2;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12'><path d='M2 2h2v2H2zM4 0h2v2H4zM10 4h2v2h-2zM0 4h2v2H0zM6 0h2v2H6zM8 2h2v2H8zM8 8h2v2H8zM6 10h2v2H6zM0 6h2v2H0zM10 6h2v2h-2zM4 10h2v2H4zM2 8h2v2H2z' fill='%23000' /></svg>\");\n}\n\n@supports (border-image-source: none) {\n  .pixel-borders--2-inset {\n    border-radius: 20px;\n  }\n}\n\n.pixel-borders--2-inset::after {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #ddd;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23ddd' /></svg>\");\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  border-image-width: 0 1 1 0;\n  width: calc(100% - 4px);\n  height: calc(100% - 4px);\n}\n\n@supports (border-image-source: none) {\n  .pixel-borders--2-inset::after {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--light {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #cccccc;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23cccccc' /></svg>\");\n  position: relative;\n  background-color: #fff;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--light {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--light::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #e6e5e5;\n}\n\n.pixel-box--light:hover, .pixel-box--light:focus {\n  background-color: #f2f2f2;\n}\n\n.pixel-box--primary {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #0c639c;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%230c639c' /></svg>\");\n  position: relative;\n  background-color: #209cee;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--primary {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--primary::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #1081cb;\n}\n\n.pixel-box--primary:hover, .pixel-box--primary:focus {\n  background-color: #1190e3;\n}\n\n.pixel-box--success {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #5b8423;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%235b8423' /></svg>\");\n  position: relative;\n  background-color: #92cc41;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--success {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--success::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #77ac2e;\n}\n\n.pixel-box--success:hover, .pixel-box--success:focus {\n  background-color: #85c034;\n}\n\n.pixel-box--warning {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #a88f06;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23a88f06' /></svg>\");\n  position: relative;\n  background-color: #f7d51d;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--warning {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--warning::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #d9b908;\n}\n\n.pixel-box--warning:hover, .pixel-box--warning:focus {\n  background-color: #f2ce09;\n}\n\n.pixel-box--error {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #bc361a;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23bc361a' /></svg>\");\n  position: relative;\n  background-color: #e76e55;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--error {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--error::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #e14828;\n}\n\n.pixel-box--error:hover, .pixel-box--error:focus {\n  background-color: #e45b3f;\n}\n\n.pixel-box--light-custom {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #cccccc;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23cccccc' /></svg>\");\n  position: relative;\n  background-color: #fff;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--light-custom {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--light-custom::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #999, inset 4px 4px #999;\n}\n\n.pixel-box--light-custom:hover, .pixel-box--light-custom:focus {\n  background-color: #f2f2f2;\n}\n\n.pixel-box--primary-custom {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #0c639c;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%230c639c' /></svg>\");\n  background-color: #209cee;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--primary-custom {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--primary-custom:hover, .pixel-box--primary-custom:focus {\n  background-color: #1190e3;\n}\n\n.pixel-box--success-custom {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #5b8423;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%235b8423' /></svg>\");\n  position: relative;\n  background-color: #92cc41;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--success-custom {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--success-custom::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset 4px 4px #b5dc7d;\n}\n\n.pixel-box--success-custom:hover, .pixel-box--success-custom:focus {\n  background-color: #85c034;\n}\n\n.pixel-box--warning-custom {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #a88f06;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23a88f06' /></svg>\");\n  position: relative;\n  background-color: #f7d51d;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--warning-custom {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--warning-custom::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #d9b908, inset 4px 4px #fae367;\n}\n\n.pixel-box--warning-custom:hover, .pixel-box--warning-custom:focus {\n  background-color: #f2ce09;\n}\n\n.pixel-box--error-custom {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #000;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23000' /></svg>\");\n  position: relative;\n  background-color: #e76e55;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--error-custom {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--error-custom::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #e14828;\n}\n\n.pixel-box--error-custom:hover, .pixel-box--error-custom:focus {\n  background-color: #e45b3f;\n}\n"]} */ +/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["pixel-borders/_pixel-borders.scss","pixel-borders.css","pixel-borders/_pixel-borders-mixins.scss"],"names":[],"mappings":"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","file":"pixel-borders.css","sourcesContent":["// ----- Border styles -----\n.pixel-borders {\n  position: relative;\n  display: inline-block;\n  margin: 0 15px 15px 0;\n  padding: 15px 20px;\n  background-color: #fff;\n  font-family: \"Press Start 2P\", Arial Black, Arial Bold, Arial, sans-serif;\n}\n\n\n// One pixel borders\n.pixel-borders--1 {\n  @include pixel-borders();\n}\n\n.pixel-borders--1-inset {\n  @include pixel-borders($border-inset-color: #ddd);\n}\n\n\n// Two pixel borders\n.pixel-borders--2 {\n  @include pixel-borders($corner-size: 2);\n}\n\n.pixel-borders--2-inset {\n  @include pixel-borders($corner-size: 2);\n\n  &::after {\n    @include pixel-borders($corner-size: 1, $border-color: #ddd);\n\n    content: '';\n    position: absolute;\n    z-index: 0;\n    bottom: 0;\n    right: 0;\n    border-image-width: 0 1 1 0;\n    width: calc(100% - 4px);\n    height: calc(100% - 4px);\n  }\n}\n\n\n\n// Examples using the pixel box mixin to colour code the elements\n.pixel-box--light {\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #fff);\n}\n\n.pixel-box--primary {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #209cee);\n}\n\n.pixel-box--success {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #92cc41);\n} \n\n.pixel-box--warning {\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #f7d51d);\n} \n\n.pixel-box--error {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #e76e55);\n} \n\n\n// Custom examples to show flexibility of the mixins\n.pixel-box--light-custom {\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #fff, $border-inset-color: #999, $border-inset-sides: 'all');\n}\n\n.pixel-box--primary-custom {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #209cee, $border-inset: false);\n}\n\n.pixel-box--success-custom {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #92cc41, $border-inset-sides: 'top-left');\n} \n\n.pixel-box--warning-custom {\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #f7d51d, $border-inset-sides: 'all');\n} \n\n.pixel-box--error-custom {\n  color: #fff;\n  @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #e76e55, $border-color: #000);\n} \n",".pixel-borders {\n  position: relative;\n  display: inline-block;\n  margin: 0 15px 15px 0;\n  padding: 15px 20px;\n  background-color: #fff;\n  font-family: \"Press Start 2P\", Arial Black, Arial Bold, Arial, sans-serif;\n}\n\n.pixel-borders--1 {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #000;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23000' /></svg>\");\n}\n\n@supports (border-image-source: none) {\n  .pixel-borders--1 {\n    border-radius: 14px;\n  }\n}\n\n.pixel-borders--1-inset {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #000;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23000' /></svg>\");\n  position: relative;\n}\n\n@supports (border-image-source: none) {\n  .pixel-borders--1-inset {\n    border-radius: 14px;\n  }\n}\n\n.pixel-borders--1-inset::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #ddd;\n}\n\n.pixel-borders--2 {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #000;\n  border-image-slice: 4;\n  border-image-width: 2;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12'><path d='M2 2h2v2H2zM4 0h2v2H4zM10 4h2v2h-2zM0 4h2v2H0zM6 0h2v2H6zM8 2h2v2H8zM8 8h2v2H8zM6 10h2v2H6zM0 6h2v2H0zM10 6h2v2h-2zM4 10h2v2H4zM2 8h2v2H2z' fill='%23000' /></svg>\");\n}\n\n@supports (border-image-source: none) {\n  .pixel-borders--2 {\n    border-radius: 20px;\n  }\n}\n\n.pixel-borders--2-inset {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #000;\n  border-image-slice: 4;\n  border-image-width: 2;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12'><path d='M2 2h2v2H2zM4 0h2v2H4zM10 4h2v2h-2zM0 4h2v2H0zM6 0h2v2H6zM8 2h2v2H8zM8 8h2v2H8zM6 10h2v2H6zM0 6h2v2H0zM10 6h2v2h-2zM4 10h2v2H4zM2 8h2v2H2z' fill='%23000' /></svg>\");\n}\n\n@supports (border-image-source: none) {\n  .pixel-borders--2-inset {\n    border-radius: 20px;\n  }\n}\n\n.pixel-borders--2-inset::after {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #ddd;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23ddd' /></svg>\");\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  border-image-width: 0 1 1 0;\n  width: calc(100% - 4px);\n  height: calc(100% - 4px);\n}\n\n@supports (border-image-source: none) {\n  .pixel-borders--2-inset::after {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--light {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #cccccc;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23cccccc' /></svg>\");\n  position: relative;\n  background-color: #fff;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--light {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--light::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #e6e5e5;\n}\n\n.pixel-box--light:hover, .pixel-box--light:focus {\n  background-color: #f2f2f2;\n}\n\n.pixel-box--primary {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #0c639c;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%230c639c' /></svg>\");\n  position: relative;\n  background-color: #209cee;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--primary {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--primary::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #1081cb;\n}\n\n.pixel-box--primary:hover, .pixel-box--primary:focus {\n  background-color: #1190e3;\n}\n\n.pixel-box--success {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #5b8423;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%235b8423' /></svg>\");\n  position: relative;\n  background-color: #92cc41;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--success {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--success::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #77ac2e;\n}\n\n.pixel-box--success:hover, .pixel-box--success:focus {\n  background-color: #85c034;\n}\n\n.pixel-box--warning {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #a88f06;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23a88f06' /></svg>\");\n  position: relative;\n  background-color: #f7d51d;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--warning {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--warning::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #d9b908;\n}\n\n.pixel-box--warning:hover, .pixel-box--warning:focus {\n  background-color: #f2ce09;\n}\n\n.pixel-box--error {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #bc361a;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23bc361a' /></svg>\");\n  position: relative;\n  background-color: #e76e55;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--error {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--error::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #e14828;\n}\n\n.pixel-box--error:hover, .pixel-box--error:focus {\n  background-color: #e45b3f;\n}\n\n.pixel-box--light-custom {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #cccccc;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23cccccc' /></svg>\");\n  position: relative;\n  background-color: #fff;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--light-custom {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--light-custom::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #999, inset 4px 4px #999;\n}\n\n.pixel-box--light-custom:hover, .pixel-box--light-custom:focus {\n  background-color: #f2f2f2;\n}\n\n.pixel-box--primary-custom {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #0c639c;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%230c639c' /></svg>\");\n  background-color: #209cee;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--primary-custom {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--primary-custom:hover, .pixel-box--primary-custom:focus {\n  background-color: #1190e3;\n}\n\n.pixel-box--success-custom {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #5b8423;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%235b8423' /></svg>\");\n  position: relative;\n  background-color: #92cc41;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--success-custom {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--success-custom::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset 4px 4px #b5dc7d;\n}\n\n.pixel-box--success-custom:hover, .pixel-box--success-custom:focus {\n  background-color: #85c034;\n}\n\n.pixel-box--warning-custom {\n  border-style: solid;\n  border-width: 4px;\n  border-color: #a88f06;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23a88f06' /></svg>\");\n  position: relative;\n  background-color: #f7d51d;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--warning-custom {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--warning-custom::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #d9b908, inset 4px 4px #fae367;\n}\n\n.pixel-box--warning-custom:hover, .pixel-box--warning-custom:focus {\n  background-color: #f2ce09;\n}\n\n.pixel-box--error-custom {\n  color: #fff;\n  border-style: solid;\n  border-width: 4px;\n  border-color: #000;\n  border-image-slice: 2;\n  border-image-width: 1;\n  border-image-outset: 0;\n  border-image-source: url(\"data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='6' height='6'><path d='M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z' fill='%23000' /></svg>\");\n  position: relative;\n  background-color: #e76e55;\n}\n\n@supports (border-image-source: none) {\n  .pixel-box--error-custom {\n    border-radius: 14px;\n  }\n}\n\n.pixel-box--error-custom::after {\n  content: '';\n  position: absolute;\n  z-index: 0;\n  bottom: 0;\n  right: 0;\n  width: 100%;\n  height: 100%;\n  box-shadow: inset -4px -4px #e14828;\n}\n\n.pixel-box--error-custom:hover, .pixel-box--error-custom:focus {\n  background-color: #e45b3f;\n}\n","// Generate SVG image for pixelated corners\n@function pixel-borders-image($corner-size, $color) {\n  $svg: '';\n  $svg-path: '';\n  $svg-size: $corner-size * 6;\n  $color: str-replace('' + $color, '#', '%23');\n\n  @if $corner-size == 1 {\n    $svg-path: 'M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z';\n  } @else {\n    $svg-path: 'M2 2h2v2H2zM4 0h2v2H4zM10 4h2v2h-2zM0 4h2v2H0zM6 0h2v2H6zM8 2h2v2H8zM8 8h2v2H8zM6 10h2v2H6zM0 6h2v2H0zM10 6h2v2h-2zM4 10h2v2H4zM2 8h2v2H2z';\n  }\n\n  $svg: 'data:image/svg+xml,<svg xmlns=\\'http://www.w3.org/2000/svg\\' width=\\'#{$svg-size}\\' height=\\'#{$svg-size}\\'><path d=\\'#{$svg-path}\\' fill=\\'#{$color}\\' /></svg>';\n\n  @return $svg;\n}\n\n\n// String replace function - replace `$search` with `$replace` in `$string`\n@function str-replace($string, $search, $replace: '') {\n  $index: str-index($string, $search);\n\n  @if $index {\n    @return str-slice($string, 1, $index - 1) + $replace + str-replace(str-slice($string, $index + str-length($search)), $search, $replace);\n  }\n\n  @return $string;\n}\n\n\n// Pixel border\n@mixin pixel-borders($corner-size: 1, $border-size: 4px, $border-color: #000, $border-inset-color: false) {\n\n  @supports (border-image-source: none) {\n    border-radius: ($border-size * ($corner-size + 2)) + ($corner-size * 2);\n  }\n\n  border-style: solid;\n  border-width: $border-size;\n  border-color: $border-color;\n\n  border-image-slice: $corner-size * 2;\n  border-image-width: $corner-size;\n  border-image-outset: 0;\n\n  border-image-source: url(pixel-borders-image($corner-size, $border-color));\n\n  @if $border-inset-color {\n    @include pixel-inset-border($border-size, $border-inset-color);\n  }\n\n}\n\n\n// Pixel inset border\n@mixin pixel-inset-border($border-inset-size: 4px, $border-inset-color: #ddd, $border-inset-sides: 'bottom-right', $border-inset-color-br: false, $border-inset-color-tl: false) {\n\n  $box-shadow: '';\n  @if not($border-inset-color-br) {\n    $border-inset-color-br: $border-inset-color;\n  }\n\n  @if not($border-inset-color-tl) {\n    $border-inset-color-tl: $border-inset-color;\n  }\n\n  position: relative;\n\n  &::after {\n    content: '';\n    position: absolute;\n    z-index: 0;\n    bottom: 0;\n    right: 0;\n    width: 100%;\n    height: 100%;\n\n    @if $border-inset-sides == 'bottom-right' or $border-inset-sides == false {\n      $box-shadow: inset -#{$border-inset-size} -#{$border-inset-size} $border-inset-color-br;\n    }\n\n    @if $border-inset-sides == 'top-left' {\n      $box-shadow: inset $border-inset-size $border-inset-size $border-inset-color-tl;\n    }\n\n    @if $border-inset-sides == 'all' {\n      $box-shadow: inset -#{$border-inset-size} -#{$border-inset-size} $border-inset-color-br, inset $border-inset-size $border-inset-size $border-inset-color-tl;\n    }\n\n    box-shadow: $box-shadow;\n  }\n\n}\n\n\n\n// Pixel box - Colours for border and inset are calculated using $background-color unless $border-color is passed\n@mixin pixel-box($corner-size, $border-size, $background-color, $border-color: false, $border-inset: true, $border-inset-size: false, $border-inset-color: false, $border-inset-sides: false, $border-inset-color-br: false, $border-inset-color-tl: false) {\n  \n  $background-color-hover: darken($background-color, 5);\n\n  @if not($border-color) {\n    $border-color: darken($background-color, 20);\n  }\n\n  @include pixel-borders($corner-size: $corner-size, $border-size: $border-size, $border-color: $border-color);\n\n  @if $border-inset-sides == 'all' and not($border-inset-color) {\n    $border-inset-color-br: darken($background-color, 10);\n    $border-inset-color-tl: lighten($background-color, 15);\n  }\n\n  @if not($border-inset-color) { \n    $border-inset-color: darken($background-color, 10);\n  }\n\n  @if $border-inset-sides == 'top-left' {\n    $border-inset-color: lighten($background-color, 15);\n  }\n\n\n  @if $border-inset { \n    @include pixel-inset-border($border-inset-size: $border-size, $border-inset-color: $border-inset-color, $border-inset-sides: $border-inset-sides, $border-inset-color-br: $border-inset-color-br, $border-inset-color-tl: $border-inset-color-tl);\n  }\n\n  background-color: $background-color;\n\n  &:hover, &:focus {\n    background-color: $background-color-hover;\n  }\n\n}\n"]} */ diff --git a/docs/styles/site.css b/docs/styles/site.css index 4efd582..c1fd0f9 100644 --- a/docs/styles/site.css +++ b/docs/styles/site.css @@ -571,4 +571,4 @@ pre { margin: 0; } -/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["_normalize.scss","site.css","site.scss"],"names":[],"mappings":"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","file":"site.css","sourcesContent":["/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */\n\n/* Document\n   ========================================================================== */\n\n/**\n * 1. Correct the line height in all browsers.\n * 2. Prevent adjustments of font size after orientation changes in iOS.\n */\n\nhtml {\n  line-height: 1.15; /* 1 */\n  -webkit-text-size-adjust: 100%; /* 2 */\n}\n\n/* Sections\n   ========================================================================== */\n\n/**\n * Remove the margin in all browsers.\n */\n\nbody {\n  margin: 0;\n}\n\n/**\n * Render the `main` element consistently in IE.\n */\n\nmain {\n  display: block;\n}\n\n/**\n * Correct the font size and margin on `h1` elements within `section` and\n * `article` contexts in Chrome, Firefox, and Safari.\n */\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/* Grouping content\n   ========================================================================== */\n\n/**\n * 1. Add the correct box sizing in Firefox.\n * 2. Show the overflow in Edge and IE.\n */\n\nhr {\n  box-sizing: content-box; /* 1 */\n  height: 0; /* 1 */\n  overflow: visible; /* 2 */\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\n\npre {\n  font-family: monospace, monospace; /* 1 */\n  font-size: 1em; /* 2 */\n}\n\n/* Text-level semantics\n   ========================================================================== */\n\n/**\n * Remove the gray background on active links in IE 10.\n */\n\na {\n  background-color: transparent;\n}\n\n/**\n * 1. Remove the bottom border in Chrome 57-\n * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n */\n\nabbr[title] {\n  border-bottom: none; /* 1 */\n  text-decoration: underline; /* 2 */\n  text-decoration: underline dotted; /* 2 */\n}\n\n/**\n * Add the correct font weight in Chrome, Edge, and Safari.\n */\n\nb,\nstrong {\n  font-weight: bolder;\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace; /* 1 */\n  font-size: 1em; /* 2 */\n}\n\n/**\n * Add the correct font size in all browsers.\n */\n\nsmall {\n  font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` elements from affecting the line height in\n * all browsers.\n */\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\n/* Embedded content\n   ========================================================================== */\n\n/**\n * Remove the border on images inside links in IE 10.\n */\n\nimg {\n  border-style: none;\n}\n\n/* Forms\n   ========================================================================== */\n\n/**\n * 1. Change the font styles in all browsers.\n * 2. Remove the margin in Firefox and Safari.\n */\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit; /* 1 */\n  font-size: 100%; /* 1 */\n  line-height: 1.15; /* 1 */\n  margin: 0; /* 2 */\n}\n\n/**\n * Show the overflow in IE.\n * 1. Show the overflow in Edge.\n */\n\nbutton,\ninput { /* 1 */\n  overflow: visible;\n}\n\n/**\n * Remove the inheritance of text transform in Edge, Firefox, and IE.\n * 1. Remove the inheritance of text transform in Firefox.\n */\n\nbutton,\nselect { /* 1 */\n  text-transform: none;\n}\n\n/**\n * Correct the inability to style clickable types in iOS and Safari.\n */\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button;\n}\n\n/**\n * Remove the inner border and padding in Firefox.\n */\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\n/**\n * Restore the focus styles unset by the previous rule.\n */\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\n/**\n * Correct the padding in Firefox.\n */\n\nfieldset {\n  padding: 0.35em 0.75em 0.625em;\n}\n\n/**\n * 1. Correct the text wrapping in Edge and IE.\n * 2. Correct the color inheritance from `fieldset` elements in IE.\n * 3. Remove the padding so developers are not caught out when they zero out\n *    `fieldset` elements in all browsers.\n */\n\nlegend {\n  box-sizing: border-box; /* 1 */\n  color: inherit; /* 2 */\n  display: table; /* 1 */\n  max-width: 100%; /* 1 */\n  padding: 0; /* 3 */\n  white-space: normal; /* 1 */\n}\n\n/**\n * Add the correct vertical alignment in Chrome, Firefox, and Opera.\n */\n\nprogress {\n  vertical-align: baseline;\n}\n\n/**\n * Remove the default vertical scrollbar in IE 10+.\n */\n\ntextarea {\n  overflow: auto;\n}\n\n/**\n * 1. Add the correct box sizing in IE 10.\n * 2. Remove the padding in IE 10.\n */\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box; /* 1 */\n  padding: 0; /* 2 */\n}\n\n/**\n * Correct the cursor style of increment and decrement buttons in Chrome.\n */\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Correct the odd appearance in Chrome and Safari.\n * 2. Correct the outline style in Safari.\n */\n\n[type=\"search\"] {\n  -webkit-appearance: textfield; /* 1 */\n  outline-offset: -2px; /* 2 */\n}\n\n/**\n * Remove the inner padding in Chrome and Safari on macOS.\n */\n\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * 1. Correct the inability to style clickable types in iOS and Safari.\n * 2. Change font properties to `inherit` in Safari.\n */\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button; /* 1 */\n  font: inherit; /* 2 */\n}\n\n/* Interactive\n   ========================================================================== */\n\n/*\n * Add the correct display in Edge, IE 10+, and Firefox.\n */\n\ndetails {\n  display: block;\n}\n\n/*\n * Add the correct display in all browsers.\n */\n\nsummary {\n  display: list-item;\n}\n\n/* Misc\n   ========================================================================== */\n\n/**\n * Add the correct display in IE 10+.\n */\n\ntemplate {\n  display: none;\n}\n\n/**\n * Add the correct display in IE 10.\n */\n\n[hidden] {\n  display: none;\n}\n","/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */\n/* Document\n   ========================================================================== */\n/**\n * 1. Correct the line height in all browsers.\n * 2. Prevent adjustments of font size after orientation changes in iOS.\n */\nhtml {\n  line-height: 1.15;\n  /* 1 */\n  -webkit-text-size-adjust: 100%;\n  /* 2 */\n}\n\n/* Sections\n   ========================================================================== */\n/**\n * Remove the margin in all browsers.\n */\nbody {\n  margin: 0;\n}\n\n/**\n * Render the `main` element consistently in IE.\n */\nmain {\n  display: block;\n}\n\n/**\n * Correct the font size and margin on `h1` elements within `section` and\n * `article` contexts in Chrome, Firefox, and Safari.\n */\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/* Grouping content\n   ========================================================================== */\n/**\n * 1. Add the correct box sizing in Firefox.\n * 2. Show the overflow in Edge and IE.\n */\nhr {\n  box-sizing: content-box;\n  /* 1 */\n  height: 0;\n  /* 1 */\n  overflow: visible;\n  /* 2 */\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\npre {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/* Text-level semantics\n   ========================================================================== */\n/**\n * Remove the gray background on active links in IE 10.\n */\na {\n  background-color: transparent;\n}\n\n/**\n * 1. Remove the bottom border in Chrome 57-\n * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n */\nabbr[title] {\n  border-bottom: none;\n  /* 1 */\n  text-decoration: underline;\n  /* 2 */\n  text-decoration: underline dotted;\n  /* 2 */\n}\n\n/**\n * Add the correct font weight in Chrome, Edge, and Safari.\n */\nb,\nstrong {\n  font-weight: bolder;\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/**\n * Add the correct font size in all browsers.\n */\nsmall {\n  font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` elements from affecting the line height in\n * all browsers.\n */\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\n/* Embedded content\n   ========================================================================== */\n/**\n * Remove the border on images inside links in IE 10.\n */\nimg {\n  border-style: none;\n}\n\n/* Forms\n   ========================================================================== */\n/**\n * 1. Change the font styles in all browsers.\n * 2. Remove the margin in Firefox and Safari.\n */\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit;\n  /* 1 */\n  font-size: 100%;\n  /* 1 */\n  line-height: 1.15;\n  /* 1 */\n  margin: 0;\n  /* 2 */\n}\n\n/**\n * Show the overflow in IE.\n * 1. Show the overflow in Edge.\n */\nbutton,\ninput {\n  /* 1 */\n  overflow: visible;\n}\n\n/**\n * Remove the inheritance of text transform in Edge, Firefox, and IE.\n * 1. Remove the inheritance of text transform in Firefox.\n */\nbutton,\nselect {\n  /* 1 */\n  text-transform: none;\n}\n\n/**\n * Correct the inability to style clickable types in iOS and Safari.\n */\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button;\n}\n\n/**\n * Remove the inner border and padding in Firefox.\n */\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\n/**\n * Restore the focus styles unset by the previous rule.\n */\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\n/**\n * Correct the padding in Firefox.\n */\nfieldset {\n  padding: 0.35em 0.75em 0.625em;\n}\n\n/**\n * 1. Correct the text wrapping in Edge and IE.\n * 2. Correct the color inheritance from `fieldset` elements in IE.\n * 3. Remove the padding so developers are not caught out when they zero out\n *    `fieldset` elements in all browsers.\n */\nlegend {\n  box-sizing: border-box;\n  /* 1 */\n  color: inherit;\n  /* 2 */\n  display: table;\n  /* 1 */\n  max-width: 100%;\n  /* 1 */\n  padding: 0;\n  /* 3 */\n  white-space: normal;\n  /* 1 */\n}\n\n/**\n * Add the correct vertical alignment in Chrome, Firefox, and Opera.\n */\nprogress {\n  vertical-align: baseline;\n}\n\n/**\n * Remove the default vertical scrollbar in IE 10+.\n */\ntextarea {\n  overflow: auto;\n}\n\n/**\n * 1. Add the correct box sizing in IE 10.\n * 2. Remove the padding in IE 10.\n */\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box;\n  /* 1 */\n  padding: 0;\n  /* 2 */\n}\n\n/**\n * Correct the cursor style of increment and decrement buttons in Chrome.\n */\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Correct the odd appearance in Chrome and Safari.\n * 2. Correct the outline style in Safari.\n */\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  /* 1 */\n  outline-offset: -2px;\n  /* 2 */\n}\n\n/**\n * Remove the inner padding in Chrome and Safari on macOS.\n */\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * 1. Correct the inability to style clickable types in iOS and Safari.\n * 2. Change font properties to `inherit` in Safari.\n */\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  /* 1 */\n  font: inherit;\n  /* 2 */\n}\n\n/* Interactive\n   ========================================================================== */\n/*\n * Add the correct display in Edge, IE 10+, and Firefox.\n */\ndetails {\n  display: block;\n}\n\n/*\n * Add the correct display in all browsers.\n */\nsummary {\n  display: list-item;\n}\n\n/* Misc\n   ========================================================================== */\n/**\n * Add the correct display in IE 10+.\n */\ntemplate {\n  display: none;\n}\n\n/**\n * Add the correct display in IE 10.\n */\n[hidden] {\n  display: none;\n}\n\n*,\n*:before,\n*:after {\n  box-sizing: border-box;\n}\n\nbody {\n  font-family: \"Lato\", -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,\"Helvetica Neue\",Arial,\"Noto Sans\",sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",\"Segoe UI Symbol\",\"Noto Color Emoji\";\n  font-size: 1rem;\n  font-weight: 400;\n  line-height: 1.5;\n  color: #333;\n  background-color: #fff;\n}\n\na {\n  color: #1976D2;\n  text-decoration: none;\n  transition: color 0.3s;\n}\n\na:hover, a:focus {\n  color: #2196F3;\n}\n\nh1, h2, h3, h4, h5, h6 {\n  font-weight: 300;\n}\n\nh1 small, h2 small, h3 small, h4 small, h5 small, h6 small {\n  font-size: 60%;\n}\n\nh1, h2 {\n  margin: 0 0 1rem 0;\n}\n\nh3, h4, h5, h6 {\n  margin: 0 0 .5rem 0;\n}\n\nh1 {\n  font-size: 2.5rem;\n}\n\nh2 {\n  font-size: 2rem;\n}\n\nh3 {\n  font-size: 1.75rem;\n}\n\nh4 {\n  font-size: 1.5rem;\n}\n\nh5 {\n  font-size: 1.25rem;\n}\n\nh6 {\n  font-size: 1rem;\n}\n\np {\n  margin: 0 0 1rem 0;\n}\n\nstrong, th {\n  font-weight: 800;\n}\n\npre, code {\n  font-family: 'Cutive Mono', monospace;\n  background-color: #f3f3f3;\n}\n\npre {\n  display: block;\n  padding: .75rem 1rem;\n  margin: 0 0 1.5rem 0;\n  overflow: auto;\n  font-size: 1rem;\n  word-break: break-all;\n  word-wrap: break-word;\n  border: 1px solid #bbb;\n  border-radius: 4px;\n}\n\n.table {\n  width: 100%;\n  margin: 0 0 1rem 0;\n  border-collapse: collapse;\n}\n\n.table th, .table td {\n  padding: .25rem .5rem;\n  text-align: left;\n  vertical-align: top;\n  border: 1px solid #ddd;\n}\n\n.fullwidth .container {\n  width: 100%;\n  padding-top: 2rem;\n  padding-bottom: 2rem;\n}\n\n.fullwidth--sm .container {\n  padding-top: 1rem;\n  padding-bottom: 1rem;\n}\n\n.container {\n  width: 100%;\n  max-width: 1140px;\n  margin: 0 auto;\n  padding-left: 1rem;\n  padding-right: 1rem;\n}\n\n.subsection {\n  margin: 0 0 2rem 0;\n}\n\n.separator {\n  border-bottom: 1px solid #ddd;\n}\n\n.header {\n  position: sticky;\n  top: 0;\n  z-index: 100;\n  width: 100%;\n  padding: .5rem 0;\n  color: #fff;\n  background-color: #1976D2;\n  box-shadow: 0 0 6px 6px rgba(0, 0, 0, 0.1);\n}\n\n@media (min-width: 768px) {\n  .header {\n    padding: 1rem 0;\n  }\n}\n\n.header .container {\n  display: flex;\n}\n\n@media (max-width: 767px) {\n  .header .container {\n    flex-flow: column;\n  }\n}\n\n@media (min-width: 768px) {\n  .header .container {\n    align-items: center;\n  }\n}\n\n.logo-text {\n  margin: 0;\n}\n\n@media (max-width: 767px) {\n  .logo-text {\n    font-size: 1.75rem;\n  }\n}\n\n.header--links .btn-demo {\n  margin: .5rem 0;\n}\n\n.header--links .btn-demo:last-child {\n  margin-left: .5rem;\n}\n\n@media (min-width: 768px) {\n  .header--links {\n    margin-left: auto;\n  }\n}\n\n.footer {\n  text-align: center;\n}\n\n.btn-demo {\n  display: inline-block;\n  text-align: center;\n  vertical-align: middle;\n  cursor: pointer;\n  border: 1px solid #bbb;\n  padding: 4px 12px 6px 12px;\n  font-size: 18px;\n  background-color: #fff;\n  border-radius: 4px;\n  transition: background-color .3s, color .3s;\n}\n\n.btn-demo:hover, .btn-demo:active {\n  background-color: #f3f3f3;\n}\n\n.btn-demo--white {\n  color: #fff;\n  border-color: #fff;\n  background-color: transparent;\n}\n\n.m-0 {\n  margin: 0;\n}\n","// ----- Demo site styles -----\n@import \"normalize\";\n\n\n\n// ----- Base styles -----\n\n*,\n*:before,\n*:after {\n  box-sizing: border-box;\n}\n\nbody {\n  font-family: \"Lato\", -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,\"Helvetica Neue\",Arial,\"Noto Sans\",sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",\"Segoe UI Symbol\",\"Noto Color Emoji\";\n  font-size: 1rem;\n  font-weight: 400;\n  line-height: 1.5;\n  color: #333;\n  background-color: #fff;\n}\n\n\na {\n  color: #1976D2;\n  text-decoration: none;\n  transition: color 0.3s;\n\n  &:hover, &:focus {\n    color: #2196F3;\n  }\n}\n\n// Type\nh1, h2, h3, h4, h5, h6 {\n  font-weight: 300;\n\n  small {\n    font-size: 60%;\n  }\n}\n\nh1, h2 {\n  margin: 0 0 1rem 0;\n}\n\nh3, h4, h5, h6 {\n  margin: 0 0 .5rem 0;\n}\n\nh1 { font-size: 2.5rem; }\nh2 { font-size: 2rem; }\nh3 { font-size: 1.75rem; }\nh4 { font-size: 1.5rem; }\nh5 { font-size: 1.25rem; }\nh6 { font-size: 1rem; }\n\np {\n  margin: 0 0 1rem 0;\n}\n\nstrong, th {\n  font-weight: 800;\n}\n\npre, code {\n  font-family: 'Cutive Mono', monospace;\n  background-color: #f3f3f3;\n}\n\npre {\n  display: block;\n  padding: .75rem 1rem;\n  margin: 0 0 1.5rem 0;\n  overflow: auto;\n  font-size: 1rem;\n  word-break: break-all;\n  word-wrap: break-word;\n  border: 1px solid #bbb;\n  border-radius: 4px;\n}\n\n.table {\n  width: 100%;\n  margin: 0 0 1rem 0;\n  border-collapse: collapse;\n\n  th, td {\n    padding: .25rem .5rem;\n    text-align: left;\n    vertical-align: top;\n    border: 1px solid #ddd;\n  }\n}\n\n\n\n// ----- Layout -----\n.fullwidth {\n  .container {\n    width: 100%;\n    padding-top: 2rem;\n    padding-bottom: 2rem;\n  }\n}\n\n.fullwidth--sm {\n  .container {\n    padding-top: 1rem;\n    padding-bottom: 1rem;\n  }\n}\n\n  .container {\n    width: 100%;\n    max-width: 1140px;\n    margin: 0 auto;\n    padding-left: 1rem;\n    padding-right: 1rem;\n  }\n\n    .subsection {\n      margin: 0 0 2rem 0;\n    }\n\n\n.separator {\n  border-bottom: 1px solid #ddd;\n}\n\n\n\n// ----- Header and footer -----\n.header {\n  position: sticky;\n  top: 0;\n  z-index: 100;\n  width: 100%;\n  padding: .5rem 0;\n  color: #fff;\n  background-color: #1976D2;\n  box-shadow: 0 0 6px 6px rgba(0,0,0,0.1);\n\n  @media (min-width: 768px) {\n    padding: 1rem 0;\n  }\n\n\n  .container {\n    display: flex;\n\n    @media (max-width: 767px) {\n      flex-flow: column;\n    }\n\n    @media (min-width: 768px) {\n      align-items: center;\n    }\n  }\n\n}\n\n  .logo-text {\n    margin: 0;\n\n    @media (max-width: 767px) {\n      font-size: 1.75rem;\n    }\n  }\n\n  .header--links {\n\n    .btn-demo {\n      margin: .5rem 0;\n\n      &:last-child {\n        margin-left: .5rem;\n      }\n    }\n\n    @media (min-width: 768px) {\n      margin-left: auto;\n    }\n  }\n\n\n.footer {\n  text-align: center;\n}\n\n\n\n// ----- Buttons -----\n.btn-demo {\n  display: inline-block;\n  text-align: center;\n  vertical-align: middle;\n  cursor: pointer;\n  border: 1px solid #bbb;\n  padding: 4px 12px 6px 12px;\n  font-size: 18px;\n  background-color: #fff;\n  border-radius: 4px;\n  transition: background-color .3s, color .3s;\n\n  &:hover, &:active {\n    background-color: #f3f3f3;\n  }\n}\n\n.btn-demo--white {\n  color: #fff;\n  border-color: #fff;\n  background-color: transparent;\n}\n\n\n\n// ----- Utilities -----\n.m-0 {\n  margin: 0;\n}\n"]} */ +/*# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["site/_normalize.scss","site.css","site/_site.scss"],"names":[],"mappings":"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","file":"site.css","sourcesContent":["/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */\n\n/* Document\n   ========================================================================== */\n\n/**\n * 1. Correct the line height in all browsers.\n * 2. Prevent adjustments of font size after orientation changes in iOS.\n */\n\nhtml {\n  line-height: 1.15; /* 1 */\n  -webkit-text-size-adjust: 100%; /* 2 */\n}\n\n/* Sections\n   ========================================================================== */\n\n/**\n * Remove the margin in all browsers.\n */\n\nbody {\n  margin: 0;\n}\n\n/**\n * Render the `main` element consistently in IE.\n */\n\nmain {\n  display: block;\n}\n\n/**\n * Correct the font size and margin on `h1` elements within `section` and\n * `article` contexts in Chrome, Firefox, and Safari.\n */\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/* Grouping content\n   ========================================================================== */\n\n/**\n * 1. Add the correct box sizing in Firefox.\n * 2. Show the overflow in Edge and IE.\n */\n\nhr {\n  box-sizing: content-box; /* 1 */\n  height: 0; /* 1 */\n  overflow: visible; /* 2 */\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\n\npre {\n  font-family: monospace, monospace; /* 1 */\n  font-size: 1em; /* 2 */\n}\n\n/* Text-level semantics\n   ========================================================================== */\n\n/**\n * Remove the gray background on active links in IE 10.\n */\n\na {\n  background-color: transparent;\n}\n\n/**\n * 1. Remove the bottom border in Chrome 57-\n * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n */\n\nabbr[title] {\n  border-bottom: none; /* 1 */\n  text-decoration: underline; /* 2 */\n  text-decoration: underline dotted; /* 2 */\n}\n\n/**\n * Add the correct font weight in Chrome, Edge, and Safari.\n */\n\nb,\nstrong {\n  font-weight: bolder;\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace; /* 1 */\n  font-size: 1em; /* 2 */\n}\n\n/**\n * Add the correct font size in all browsers.\n */\n\nsmall {\n  font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` elements from affecting the line height in\n * all browsers.\n */\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\n/* Embedded content\n   ========================================================================== */\n\n/**\n * Remove the border on images inside links in IE 10.\n */\n\nimg {\n  border-style: none;\n}\n\n/* Forms\n   ========================================================================== */\n\n/**\n * 1. Change the font styles in all browsers.\n * 2. Remove the margin in Firefox and Safari.\n */\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit; /* 1 */\n  font-size: 100%; /* 1 */\n  line-height: 1.15; /* 1 */\n  margin: 0; /* 2 */\n}\n\n/**\n * Show the overflow in IE.\n * 1. Show the overflow in Edge.\n */\n\nbutton,\ninput { /* 1 */\n  overflow: visible;\n}\n\n/**\n * Remove the inheritance of text transform in Edge, Firefox, and IE.\n * 1. Remove the inheritance of text transform in Firefox.\n */\n\nbutton,\nselect { /* 1 */\n  text-transform: none;\n}\n\n/**\n * Correct the inability to style clickable types in iOS and Safari.\n */\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button;\n}\n\n/**\n * Remove the inner border and padding in Firefox.\n */\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\n/**\n * Restore the focus styles unset by the previous rule.\n */\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\n/**\n * Correct the padding in Firefox.\n */\n\nfieldset {\n  padding: 0.35em 0.75em 0.625em;\n}\n\n/**\n * 1. Correct the text wrapping in Edge and IE.\n * 2. Correct the color inheritance from `fieldset` elements in IE.\n * 3. Remove the padding so developers are not caught out when they zero out\n *    `fieldset` elements in all browsers.\n */\n\nlegend {\n  box-sizing: border-box; /* 1 */\n  color: inherit; /* 2 */\n  display: table; /* 1 */\n  max-width: 100%; /* 1 */\n  padding: 0; /* 3 */\n  white-space: normal; /* 1 */\n}\n\n/**\n * Add the correct vertical alignment in Chrome, Firefox, and Opera.\n */\n\nprogress {\n  vertical-align: baseline;\n}\n\n/**\n * Remove the default vertical scrollbar in IE 10+.\n */\n\ntextarea {\n  overflow: auto;\n}\n\n/**\n * 1. Add the correct box sizing in IE 10.\n * 2. Remove the padding in IE 10.\n */\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box; /* 1 */\n  padding: 0; /* 2 */\n}\n\n/**\n * Correct the cursor style of increment and decrement buttons in Chrome.\n */\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Correct the odd appearance in Chrome and Safari.\n * 2. Correct the outline style in Safari.\n */\n\n[type=\"search\"] {\n  -webkit-appearance: textfield; /* 1 */\n  outline-offset: -2px; /* 2 */\n}\n\n/**\n * Remove the inner padding in Chrome and Safari on macOS.\n */\n\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * 1. Correct the inability to style clickable types in iOS and Safari.\n * 2. Change font properties to `inherit` in Safari.\n */\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button; /* 1 */\n  font: inherit; /* 2 */\n}\n\n/* Interactive\n   ========================================================================== */\n\n/*\n * Add the correct display in Edge, IE 10+, and Firefox.\n */\n\ndetails {\n  display: block;\n}\n\n/*\n * Add the correct display in all browsers.\n */\n\nsummary {\n  display: list-item;\n}\n\n/* Misc\n   ========================================================================== */\n\n/**\n * Add the correct display in IE 10+.\n */\n\ntemplate {\n  display: none;\n}\n\n/**\n * Add the correct display in IE 10.\n */\n\n[hidden] {\n  display: none;\n}\n","/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */\n/* Document\n   ========================================================================== */\n/**\n * 1. Correct the line height in all browsers.\n * 2. Prevent adjustments of font size after orientation changes in iOS.\n */\nhtml {\n  line-height: 1.15;\n  /* 1 */\n  -webkit-text-size-adjust: 100%;\n  /* 2 */\n}\n\n/* Sections\n   ========================================================================== */\n/**\n * Remove the margin in all browsers.\n */\nbody {\n  margin: 0;\n}\n\n/**\n * Render the `main` element consistently in IE.\n */\nmain {\n  display: block;\n}\n\n/**\n * Correct the font size and margin on `h1` elements within `section` and\n * `article` contexts in Chrome, Firefox, and Safari.\n */\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\n/* Grouping content\n   ========================================================================== */\n/**\n * 1. Add the correct box sizing in Firefox.\n * 2. Show the overflow in Edge and IE.\n */\nhr {\n  box-sizing: content-box;\n  /* 1 */\n  height: 0;\n  /* 1 */\n  overflow: visible;\n  /* 2 */\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\npre {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/* Text-level semantics\n   ========================================================================== */\n/**\n * Remove the gray background on active links in IE 10.\n */\na {\n  background-color: transparent;\n}\n\n/**\n * 1. Remove the bottom border in Chrome 57-\n * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n */\nabbr[title] {\n  border-bottom: none;\n  /* 1 */\n  text-decoration: underline;\n  /* 2 */\n  text-decoration: underline dotted;\n  /* 2 */\n}\n\n/**\n * Add the correct font weight in Chrome, Edge, and Safari.\n */\nb,\nstrong {\n  font-weight: bolder;\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  /* 1 */\n  font-size: 1em;\n  /* 2 */\n}\n\n/**\n * Add the correct font size in all browsers.\n */\nsmall {\n  font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` elements from affecting the line height in\n * all browsers.\n */\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\nsup {\n  top: -0.5em;\n}\n\n/* Embedded content\n   ========================================================================== */\n/**\n * Remove the border on images inside links in IE 10.\n */\nimg {\n  border-style: none;\n}\n\n/* Forms\n   ========================================================================== */\n/**\n * 1. Change the font styles in all browsers.\n * 2. Remove the margin in Firefox and Safari.\n */\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit;\n  /* 1 */\n  font-size: 100%;\n  /* 1 */\n  line-height: 1.15;\n  /* 1 */\n  margin: 0;\n  /* 2 */\n}\n\n/**\n * Show the overflow in IE.\n * 1. Show the overflow in Edge.\n */\nbutton,\ninput {\n  /* 1 */\n  overflow: visible;\n}\n\n/**\n * Remove the inheritance of text transform in Edge, Firefox, and IE.\n * 1. Remove the inheritance of text transform in Firefox.\n */\nbutton,\nselect {\n  /* 1 */\n  text-transform: none;\n}\n\n/**\n * Correct the inability to style clickable types in iOS and Safari.\n */\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button;\n}\n\n/**\n * Remove the inner border and padding in Firefox.\n */\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\n/**\n * Restore the focus styles unset by the previous rule.\n */\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\n/**\n * Correct the padding in Firefox.\n */\nfieldset {\n  padding: 0.35em 0.75em 0.625em;\n}\n\n/**\n * 1. Correct the text wrapping in Edge and IE.\n * 2. Correct the color inheritance from `fieldset` elements in IE.\n * 3. Remove the padding so developers are not caught out when they zero out\n *    `fieldset` elements in all browsers.\n */\nlegend {\n  box-sizing: border-box;\n  /* 1 */\n  color: inherit;\n  /* 2 */\n  display: table;\n  /* 1 */\n  max-width: 100%;\n  /* 1 */\n  padding: 0;\n  /* 3 */\n  white-space: normal;\n  /* 1 */\n}\n\n/**\n * Add the correct vertical alignment in Chrome, Firefox, and Opera.\n */\nprogress {\n  vertical-align: baseline;\n}\n\n/**\n * Remove the default vertical scrollbar in IE 10+.\n */\ntextarea {\n  overflow: auto;\n}\n\n/**\n * 1. Add the correct box sizing in IE 10.\n * 2. Remove the padding in IE 10.\n */\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box;\n  /* 1 */\n  padding: 0;\n  /* 2 */\n}\n\n/**\n * Correct the cursor style of increment and decrement buttons in Chrome.\n */\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Correct the odd appearance in Chrome and Safari.\n * 2. Correct the outline style in Safari.\n */\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  /* 1 */\n  outline-offset: -2px;\n  /* 2 */\n}\n\n/**\n * Remove the inner padding in Chrome and Safari on macOS.\n */\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * 1. Correct the inability to style clickable types in iOS and Safari.\n * 2. Change font properties to `inherit` in Safari.\n */\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  /* 1 */\n  font: inherit;\n  /* 2 */\n}\n\n/* Interactive\n   ========================================================================== */\n/*\n * Add the correct display in Edge, IE 10+, and Firefox.\n */\ndetails {\n  display: block;\n}\n\n/*\n * Add the correct display in all browsers.\n */\nsummary {\n  display: list-item;\n}\n\n/* Misc\n   ========================================================================== */\n/**\n * Add the correct display in IE 10+.\n */\ntemplate {\n  display: none;\n}\n\n/**\n * Add the correct display in IE 10.\n */\n[hidden] {\n  display: none;\n}\n\n*,\n*:before,\n*:after {\n  box-sizing: border-box;\n}\n\nbody {\n  font-family: \"Lato\", -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,\"Helvetica Neue\",Arial,\"Noto Sans\",sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",\"Segoe UI Symbol\",\"Noto Color Emoji\";\n  font-size: 1rem;\n  font-weight: 400;\n  line-height: 1.5;\n  color: #333;\n  background-color: #fff;\n}\n\na {\n  color: #1976D2;\n  text-decoration: none;\n  transition: color 0.3s;\n}\n\na:hover, a:focus {\n  color: #2196F3;\n}\n\nh1, h2, h3, h4, h5, h6 {\n  font-weight: 300;\n}\n\nh1 small, h2 small, h3 small, h4 small, h5 small, h6 small {\n  font-size: 60%;\n}\n\nh1, h2 {\n  margin: 0 0 1rem 0;\n}\n\nh3, h4, h5, h6 {\n  margin: 0 0 .5rem 0;\n}\n\nh1 {\n  font-size: 2.5rem;\n}\n\nh2 {\n  font-size: 2rem;\n}\n\nh3 {\n  font-size: 1.75rem;\n}\n\nh4 {\n  font-size: 1.5rem;\n}\n\nh5 {\n  font-size: 1.25rem;\n}\n\nh6 {\n  font-size: 1rem;\n}\n\np {\n  margin: 0 0 1rem 0;\n}\n\nstrong, th {\n  font-weight: 800;\n}\n\npre, code {\n  font-family: 'Cutive Mono', monospace;\n  background-color: #f3f3f3;\n}\n\npre {\n  display: block;\n  padding: .75rem 1rem;\n  margin: 0 0 1.5rem 0;\n  overflow: auto;\n  font-size: 1rem;\n  word-break: break-all;\n  word-wrap: break-word;\n  border: 1px solid #bbb;\n  border-radius: 4px;\n}\n\n.table {\n  width: 100%;\n  margin: 0 0 1rem 0;\n  border-collapse: collapse;\n}\n\n.table th, .table td {\n  padding: .25rem .5rem;\n  text-align: left;\n  vertical-align: top;\n  border: 1px solid #ddd;\n}\n\n.fullwidth .container {\n  width: 100%;\n  padding-top: 2rem;\n  padding-bottom: 2rem;\n}\n\n.fullwidth--sm .container {\n  padding-top: 1rem;\n  padding-bottom: 1rem;\n}\n\n.container {\n  width: 100%;\n  max-width: 1140px;\n  margin: 0 auto;\n  padding-left: 1rem;\n  padding-right: 1rem;\n}\n\n.subsection {\n  margin: 0 0 2rem 0;\n}\n\n.separator {\n  border-bottom: 1px solid #ddd;\n}\n\n.header {\n  position: sticky;\n  top: 0;\n  z-index: 100;\n  width: 100%;\n  padding: .5rem 0;\n  color: #fff;\n  background-color: #1976D2;\n  box-shadow: 0 0 6px 6px rgba(0, 0, 0, 0.1);\n}\n\n@media (min-width: 768px) {\n  .header {\n    padding: 1rem 0;\n  }\n}\n\n.header .container {\n  display: flex;\n}\n\n@media (max-width: 767px) {\n  .header .container {\n    flex-flow: column;\n  }\n}\n\n@media (min-width: 768px) {\n  .header .container {\n    align-items: center;\n  }\n}\n\n.logo-text {\n  margin: 0;\n}\n\n@media (max-width: 767px) {\n  .logo-text {\n    font-size: 1.75rem;\n  }\n}\n\n.header--links .btn-demo {\n  margin: .5rem 0;\n}\n\n.header--links .btn-demo:last-child {\n  margin-left: .5rem;\n}\n\n@media (min-width: 768px) {\n  .header--links {\n    margin-left: auto;\n  }\n}\n\n.footer {\n  text-align: center;\n}\n\n.btn-demo {\n  display: inline-block;\n  text-align: center;\n  vertical-align: middle;\n  cursor: pointer;\n  border: 1px solid #bbb;\n  padding: 4px 12px 6px 12px;\n  font-size: 18px;\n  background-color: #fff;\n  border-radius: 4px;\n  transition: background-color .3s, color .3s;\n}\n\n.btn-demo:hover, .btn-demo:active {\n  background-color: #f3f3f3;\n}\n\n.btn-demo--white {\n  color: #fff;\n  border-color: #fff;\n  background-color: transparent;\n}\n\n.m-0 {\n  margin: 0;\n}\n","// ----- Base styles -----\n\n*,\n*:before,\n*:after {\n  box-sizing: border-box;\n}\n\nbody {\n  font-family: \"Lato\", -apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,\"Helvetica Neue\",Arial,\"Noto Sans\",sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",\"Segoe UI Symbol\",\"Noto Color Emoji\";\n  font-size: 1rem;\n  font-weight: 400;\n  line-height: 1.5;\n  color: #333;\n  background-color: #fff;\n}\n\n\na {\n  color: #1976D2;\n  text-decoration: none;\n  transition: color 0.3s;\n\n  &:hover, &:focus {\n    color: #2196F3;\n  }\n}\n\n// Type\nh1, h2, h3, h4, h5, h6 {\n  font-weight: 300;\n\n  small {\n    font-size: 60%;\n  }\n}\n\nh1, h2 {\n  margin: 0 0 1rem 0;\n}\n\nh3, h4, h5, h6 {\n  margin: 0 0 .5rem 0;\n}\n\nh1 { font-size: 2.5rem; }\nh2 { font-size: 2rem; }\nh3 { font-size: 1.75rem; }\nh4 { font-size: 1.5rem; }\nh5 { font-size: 1.25rem; }\nh6 { font-size: 1rem; }\n\np {\n  margin: 0 0 1rem 0;\n}\n\nstrong, th {\n  font-weight: 800;\n}\n\npre, code {\n  font-family: 'Cutive Mono', monospace;\n  background-color: #f3f3f3;\n}\n\npre {\n  display: block;\n  padding: .75rem 1rem;\n  margin: 0 0 1.5rem 0;\n  overflow: auto;\n  font-size: 1rem;\n  word-break: break-all;\n  word-wrap: break-word;\n  border: 1px solid #bbb;\n  border-radius: 4px;\n}\n\n.table {\n  width: 100%;\n  margin: 0 0 1rem 0;\n  border-collapse: collapse;\n\n  th, td {\n    padding: .25rem .5rem;\n    text-align: left;\n    vertical-align: top;\n    border: 1px solid #ddd;\n  }\n}\n\n\n\n// ----- Layout -----\n.fullwidth {\n  .container {\n    width: 100%;\n    padding-top: 2rem;\n    padding-bottom: 2rem;\n  }\n}\n\n.fullwidth--sm {\n  .container {\n    padding-top: 1rem;\n    padding-bottom: 1rem;\n  }\n}\n\n  .container {\n    width: 100%;\n    max-width: 1140px;\n    margin: 0 auto;\n    padding-left: 1rem;\n    padding-right: 1rem;\n  }\n\n    .subsection {\n      margin: 0 0 2rem 0;\n    }\n\n\n.separator {\n  border-bottom: 1px solid #ddd;\n}\n\n\n\n// ----- Header and footer -----\n.header {\n  position: sticky;\n  top: 0;\n  z-index: 100;\n  width: 100%;\n  padding: .5rem 0;\n  color: #fff;\n  background-color: #1976D2;\n  box-shadow: 0 0 6px 6px rgba(0,0,0,0.1);\n\n  @media (min-width: 768px) {\n    padding: 1rem 0;\n  }\n\n\n  .container {\n    display: flex;\n\n    @media (max-width: 767px) {\n      flex-flow: column;\n    }\n\n    @media (min-width: 768px) {\n      align-items: center;\n    }\n  }\n\n}\n\n  .logo-text {\n    margin: 0;\n\n    @media (max-width: 767px) {\n      font-size: 1.75rem;\n    }\n  }\n\n  .header--links {\n\n    .btn-demo {\n      margin: .5rem 0;\n\n      &:last-child {\n        margin-left: .5rem;\n      }\n    }\n\n    @media (min-width: 768px) {\n      margin-left: auto;\n    }\n  }\n\n\n.footer {\n  text-align: center;\n}\n\n\n\n// ----- Buttons -----\n.btn-demo {\n  display: inline-block;\n  text-align: center;\n  vertical-align: middle;\n  cursor: pointer;\n  border: 1px solid #bbb;\n  padding: 4px 12px 6px 12px;\n  font-size: 18px;\n  background-color: #fff;\n  border-radius: 4px;\n  transition: background-color .3s, color .3s;\n\n  &:hover, &:active {\n    background-color: #f3f3f3;\n  }\n}\n\n.btn-demo--white {\n  color: #fff;\n  border-color: #fff;\n  background-color: transparent;\n}\n\n\n\n// ----- Utilities -----\n.m-0 {\n  margin: 0;\n}\n"]} */ diff --git a/gulpfile.js b/gulpfile.js index 639be3a..91ab6b6 100644 --- a/gulpfile.js +++ b/gulpfile.js @@ -1,11 +1,12 @@ // ----- Imports and variables ------ const { src, dest, watch, series, parallel, lastRun } = require('gulp'); const gulpLoadPlugins = require('gulp-load-plugins'); +const $ = gulpLoadPlugins(); const browserSync = require('browser-sync'); +const server = browserSync.create(); const del = require('del'); const { argv } = require('yargs'); -const $ = gulpLoadPlugins(); -const server = browserSync.create(); +const autoprefixer = require('autoprefixer'); const port = argv.port || 9000; @@ -16,61 +17,31 @@ const isDev = !isProd && !isTest; const paths = { src: 'src', dest: 'docs', - tmp: '.tmp', - gulp: './tasks/gulp' + tmp: '.tmp' }; -// ----- Import tasks ------ -function getTask(task) { - return require(`${paths.gulp}/${task}.js`)({ src, dest }, $, paths, isProd, server); -} +// ----- Tasks ------ +function styles() { + return src(`${paths.src}/styles/*.scss`) + .pipe($.plumber()) + .pipe($.if(!isProd, $.sourcemaps.init())) + .pipe($.sass.sync({ + outputStyle: 'expanded', + precision: 10, + includePaths: ['.'] + }) + .on('error', $.sass.logError)) + .pipe($.postcss([ + autoprefixer() + ])) + .pipe($.if(!isProd, $.sourcemaps.write())) + .pipe(dest(`${paths.tmp}/styles`)) + .pipe(server.reload({stream: true})); +}; -const { styles } = getTask('styles'); exports.styles = styles; -const { images } = getTask('images'); -exports.images = images; - - -// ----- Build tasks ------ -function compress() { - return src([`${paths.src}/*.html`, `${paths.tmp}/*/**/*.{html,css,js}`]) - // .pipe($.useref({searchPath: [`${paths.tmp}`, `${paths.src}`, '.']})) - // .pipe($.if(/\.js$/, $.uglify({compress: {drop_console: true}}))) - // .pipe($.if(/\.css$/, $.postcss([cssnano({safe: true, autoprefixer: false})]))) - // .pipe($.if(/\.html$/, $.htmlmin({ - // collapseWhitespace: true, - // minifyCSS: true, - // minifyJS: {compress: {drop_console: true}}, - // processConditionalComments: true, - // removeComments: true, - // removeEmptyAttributes: true, - // removeScriptTypeAttributes: true, - // removeStyleLinkTypeAttributes: true - // }))) - .pipe(dest(`${paths.dest}`)); -} - -function clean() { - return del([`${paths.tmp}`, `${paths.dest}`]) -} -exports.clean = clean; - -function measureSize() { - return src(`${paths.dest}/**/*`) - .pipe($.size({title: 'build', gzip: true})); -} - -const build = series( - clean, - parallel( - series(parallel(styles), compress), - images - ), - measureSize -); - // ----- Serve tasks ------ function startAppServer() { @@ -89,23 +60,30 @@ function startAppServer() { }); watch([ - `${paths.src}/*.html`, - `${paths.src}/images/**/*` + `${paths.src}/*.html` ]).on('change', server.reload); watch(`${paths.src}/**/*.scss`, styles); } -let serve; -if (isDev) { - serve = series(clean, parallel(styles), startAppServer); -} else if (isProd) { - serve = series(build, startDistServer); -} - +let serve = series(clean, styles, startAppServer); exports.serve = serve; + +// ----- Build tasks ------ +function compress() { + return src([`${paths.src}/*.html`, `${paths.tmp}/*/**/*.{html,css,js}`]) + .pipe(dest(`${paths.dest}`)); +} + +function clean() { + return del([`${paths.tmp}`, `${paths.dest}`]) +} + +exports.clean = clean; + +const build = series(clean, styles, compress); + exports.build = build; -exports.dist = build; exports.default = build; diff --git a/package-lock.json b/package-lock.json index 5f2cd7c..77e2973 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "pixel-borders", - "version": "1.0.0", + "version": "1.1.0", "lockfileVersion": 1, "requires": true, "dependencies": { @@ -56,13 +56,13 @@ "dev": true }, "accepts": { - "version": "1.3.5", - "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.5.tgz", - "integrity": "sha1-63d99gEXI6OxTopywIBcjoZ0a9I=", + "version": "1.3.7", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", + "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", "dev": true, "requires": { - "mime-types": "~2.1.18", - "negotiator": "0.6.1" + "mime-types": "~2.1.24", + "negotiator": "0.6.2" } }, "acorn": { @@ -162,27 +162,6 @@ "normalize-path": "^2.1.1" }, "dependencies": { - "micromatch": { - "version": "3.1.10", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", - "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", - "dev": true, - "requires": { - "arr-diff": "^4.0.0", - "array-unique": "^0.3.2", - "braces": "^2.3.1", - "define-property": "^2.0.2", - "extend-shallow": "^3.0.2", - "extglob": "^2.0.4", - "fragment-cache": "^0.2.1", - "kind-of": "^6.0.2", - "nanomatch": "^1.2.9", - "object.pick": "^1.3.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.2" - } - }, "normalize-path": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", @@ -270,12 +249,6 @@ "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", "dev": true }, - "array-differ": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/array-differ/-/array-differ-1.0.0.tgz", - "integrity": "sha1-7/UuN1gknTO+QCuLuOVkuytdQDE=", - "dev": true - }, "array-each": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/array-each/-/array-each-1.0.1.tgz", @@ -375,12 +348,6 @@ "integrity": "sha512-wGUIVQXuehL5TCqQun8OW81jGzAWycqzFF8lFp+GOM5BXLYj3bKNsYC4daB7n6XjCqxQA/qgTJ+8ANR3acjrog==", "dev": true }, - "arrify": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", - "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", - "dev": true - }, "asn1": { "version": "0.2.4", "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", @@ -429,9 +396,9 @@ } }, "async-each": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.2.tgz", - "integrity": "sha512-6xrbvN0MOBKSJDdonmSSz2OwFSgxRaVtBDes26mj9KIGtDo+g9xosFRSC+i1gQh2oAN/tQ62AI/pGZGQjVOiRg==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz", + "integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==", "dev": true }, "async-each-series": { @@ -474,13 +441,13 @@ "dev": true }, "autoprefixer": { - "version": "9.5.0", - "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-9.5.0.tgz", - "integrity": "sha512-hMKcyHsZn5+qL6AUeP3c8OyuteZ4VaUlg+fWbyl8z7PqsKHF/Bf8/px3K6AT8aMzDkBo8Bc11245MM+itDBOxQ==", + "version": "9.5.1", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-9.5.1.tgz", + "integrity": "sha512-KJSzkStUl3wP0D5sdMlP82Q52JLy5+atf2MHAre48+ckWkXgixmfHyWmA77wFDy6jTHU6mIgXv6hAQ2mf1PjJQ==", "dev": true, "requires": { - "browserslist": "^4.4.2", - "caniuse-lite": "^1.0.30000947", + "browserslist": "^4.5.4", + "caniuse-lite": "^1.0.30000957", "normalize-range": "^0.1.2", "num2fraction": "^1.2.2", "postcss": "^7.0.14", @@ -690,13 +657,13 @@ } }, "browser-sync": { - "version": "2.26.3", - "resolved": "https://registry.npmjs.org/browser-sync/-/browser-sync-2.26.3.tgz", - "integrity": "sha512-VLzpjCA4uXqfzkwqWtMM6hvPm2PNHp2RcmzBXcbi6C9WpkUhhFb8SVAr4CFrCsFxDg+oY6HalOjn8F+egyvhag==", + "version": "2.26.5", + "resolved": "https://registry.npmjs.org/browser-sync/-/browser-sync-2.26.5.tgz", + "integrity": "sha512-zVa6MmadAFgl5Uk53Yy5cw5tGTO7xSGAWK3Yx70GJ1t5jK+r6B4q3xq+1XbYfLt1SbeFg7WoNWneNhMT4B9jFw==", "dev": true, "requires": { - "browser-sync-client": "^2.26.2", - "browser-sync-ui": "^2.26.2", + "browser-sync-client": "^2.26.4", + "browser-sync-ui": "^2.26.4", "bs-recipes": "1.3.4", "bs-snippet-injector": "^2.0.1", "chokidar": "^2.0.4", @@ -711,7 +678,7 @@ "http-proxy": "1.15.2", "immutable": "^3", "localtunnel": "1.9.1", - "micromatch": "2.3.11", + "micromatch": "^3.1.10", "opn": "5.3.0", "portscanner": "2.1.1", "qs": "6.2.3", @@ -752,9 +719,9 @@ } }, "browser-sync-client": { - "version": "2.26.2", - "resolved": "https://registry.npmjs.org/browser-sync-client/-/browser-sync-client-2.26.2.tgz", - "integrity": "sha512-FEuVJD41fI24HJ30XOT2RyF5WcnEtdJhhTqeyDlnMk/8Ox9MZw109rvk9pdfRWye4soZLe+xcAo9tHSMxvgAdw==", + "version": "2.26.4", + "resolved": "https://registry.npmjs.org/browser-sync-client/-/browser-sync-client-2.26.4.tgz", + "integrity": "sha512-mQiDp5/tf79VezDS5j/EExU4Ze6f5DQYuL0Z7VdJgBbNLTHDfkYGi2R620qc6HkY9XZA0m4/UwihT7J42RBIJA==", "dev": true, "requires": { "etag": "1.8.1", @@ -764,9 +731,9 @@ } }, "browser-sync-ui": { - "version": "2.26.2", - "resolved": "https://registry.npmjs.org/browser-sync-ui/-/browser-sync-ui-2.26.2.tgz", - "integrity": "sha512-LF7GMWo8ELOE0eAlxuRCfnGQT1ZxKP9flCfGgZdXFc6BwmoqaJHlYe7MmVvykKkXjolRXTz8ztXAKGVqNwJ3EQ==", + "version": "2.26.4", + "resolved": "https://registry.npmjs.org/browser-sync-ui/-/browser-sync-ui-2.26.4.tgz", + "integrity": "sha512-u20P3EsZoM8Pt+puoi3BU3KlbQAH1lAcV+/O4saF26qokrBqIDotmGonfWwoRbUmdxZkM9MBmA0K39ZTG1h4sA==", "dev": true, "requires": { "async-each-series": "0.1.1", @@ -778,14 +745,14 @@ } }, "browserslist": { - "version": "4.5.4", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.5.4.tgz", - "integrity": "sha512-rAjx494LMjqKnMPhFkuLmLp8JWEX0o8ADTGeAbOqaF+XCvYLreZrG5uVjnPBlAQ8REZK4pzXGvp0bWgrFtKaag==", + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.6.0.tgz", + "integrity": "sha512-Jk0YFwXBuMOOol8n6FhgkDzn3mY9PYLYGk29zybF05SbRTsMgPqmTNeQQhOghCxq5oFqAXE3u4sYddr4C0uRhg==", "dev": true, "requires": { - "caniuse-lite": "^1.0.30000955", - "electron-to-chromium": "^1.3.122", - "node-releases": "^1.1.13" + "caniuse-lite": "^1.0.30000967", + "electron-to-chromium": "^1.3.133", + "node-releases": "^1.1.19" } }, "bs-recipes": { @@ -813,9 +780,9 @@ "dev": true }, "bytes": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", - "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", + "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", "dev": true }, "cache-base": { @@ -866,9 +833,9 @@ } }, "caniuse-lite": { - "version": "1.0.30000957", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000957.tgz", - "integrity": "sha512-8wxNrjAzyiHcLXN/iunskqQnJquQQ6VX8JHfW5kLgAPRSiSuKZiNfmIkP5j7jgyXqAQBSoXyJxfnbCFS0ThSiQ==", + "version": "1.0.30000971", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000971.tgz", + "integrity": "sha512-TQFYFhRS0O5rdsmSbF1Wn+16latXYsQJat66f7S7lizXW1PVpWJeZw9wqqVLIjuxDRz7s7xRUj13QCfd8hKn6g==", "dev": true }, "caseless": { @@ -900,9 +867,9 @@ } }, "chokidar": { - "version": "2.1.5", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.5.tgz", - "integrity": "sha512-i0TprVWp+Kj4WRPtInjexJ8Q+BqTE909VpH8xVhXrJkoc5QC8VO9TryGOqTr+2hljzc1sC62t22h5tZePodM/A==", + "version": "2.1.6", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.6.tgz", + "integrity": "sha512-V2jUo67OKkc6ySiRpJrjlpJKl9kDuG+Xb8VgsGzb+aEouhgS1D0weyPU4lEzdAcsCAvrih2J2BqyXqHWvVLw5g==", "dev": true, "requires": { "anymatch": "^2.0.0", @@ -997,17 +964,6 @@ "arr-map": "^2.0.2", "for-own": "^1.0.0", "make-iterator": "^1.0.0" - }, - "dependencies": { - "for-own": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", - "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", - "dev": true, - "requires": { - "for-in": "^1.0.1" - } - } } }, "collection-visit": { @@ -1042,9 +998,9 @@ "dev": true }, "combined-stream": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.7.tgz", - "integrity": "sha512-brWl9y6vOB1xYPZcpZde3N9zDByXTosAeMDo4p1wzo6UMOX4vumB+TP1RZ76sfE6Md68Q0NJSrE/gbezd4Ul+w==", + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", "dev": true, "requires": { "delayed-stream": "~1.0.0" @@ -1419,12 +1375,6 @@ "integrity": "sha1-p2o+0YVb56ASu4rBbLgPPADcKPA=", "dev": true }, - "duplexer": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz", - "integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=", - "dev": true - }, "duplexify": { "version": "3.7.1", "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.7.1.tgz", @@ -1482,9 +1432,9 @@ "dev": true }, "electron-to-chromium": { - "version": "1.3.124", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.124.tgz", - "integrity": "sha512-glecGr/kFdfeXUHOHAWvGcXrxNU+1wSO/t5B23tT1dtlvYB26GY8aHzZSWD7HqhqC800Lr+w/hQul6C5AF542w==", + "version": "1.3.136", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.136.tgz", + "integrity": "sha512-xHkYkbEi4kI+2w5v6yBGCQTRXL7N0PWscygTFZu/1bArnPSo2WR9xjdw4m06RR4J5PncrWJcuOVv+MAG2mK5JQ==", "dev": true }, "encodeurl": { @@ -1571,9 +1521,9 @@ } }, "es5-ext": { - "version": "0.10.49", - "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.49.tgz", - "integrity": "sha512-3NMEhi57E31qdzmYp2jwRArIUsj1HI/RxbQ4bgnSB+AIKIxsAmTiK83bYMifIcpWvEc3P1X30DhUKOqEtF/kvg==", + "version": "0.10.50", + "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.50.tgz", + "integrity": "sha512-KMzZTPBkeQV/JcSQhI5/z6d9VWJ3EnQ194USTUwIYZ2ZbpN8+SGXQKt1h68EX44+qt+Fzr8DO17vnxrw7c3agw==", "dev": true, "requires": { "es6-iterator": "~2.0.3", @@ -1976,35 +1926,12 @@ "is-glob": "^4.0.0", "micromatch": "^3.0.4", "resolve-dir": "^1.0.1" - }, - "dependencies": { - "micromatch": { - "version": "3.1.10", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", - "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", - "dev": true, - "requires": { - "arr-diff": "^4.0.0", - "array-unique": "^0.3.2", - "braces": "^2.3.1", - "define-property": "^2.0.2", - "extend-shallow": "^3.0.2", - "extglob": "^2.0.4", - "fragment-cache": "^0.2.1", - "kind-of": "^6.0.2", - "nanomatch": "^1.2.9", - "object.pick": "^1.3.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.2" - } - } } }, "fined": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/fined/-/fined-1.1.1.tgz", - "integrity": "sha512-jQp949ZmEbiYHk3gkbdtpJ0G1+kgtLQBNdP5edFP7Fh+WAYceLQz6yO1SBj72Xkg8GVyTB3bBzAYrHJVh5Xd5g==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/fined/-/fined-1.2.0.tgz", + "integrity": "sha512-ZYDqPLGxDkDhDZBjZBb+oD1+j0rA4E0pXY50eplAAOPg2N/gUBSSk5IM1/QhPfyVo19lJ+CvXpqfvk+b2p/8Ng==", "dev": true, "requires": { "expand-tilde": "^2.0.2", @@ -2063,9 +1990,9 @@ "dev": true }, "for-own": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", - "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", + "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", "dev": true, "requires": { "for-in": "^1.0.1" @@ -2143,14 +2070,14 @@ "dev": true }, "fsevents": { - "version": "1.2.7", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.7.tgz", - "integrity": "sha512-Pxm6sI2MeBD7RdD12RYsqaP0nMiwx8eZBXCa6z2L+mRHm2DYrOYwihmhjpkdjUHwQhslWQjRpEgNq4XvBmaAuw==", + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.9.tgz", + "integrity": "sha512-oeyj2H3EjjonWcFjD5NvZNE9Rqe4UW+nQBU2HNeKw0koVLEFIhtyETyAakeAM3de7Z/SW5kcA+fZUait9EApnw==", "dev": true, "optional": true, "requires": { - "nan": "^2.9.2", - "node-pre-gyp": "^0.10.0" + "nan": "^2.12.1", + "node-pre-gyp": "^0.12.0" }, "dependencies": { "abbrev": { @@ -2228,12 +2155,12 @@ "optional": true }, "debug": { - "version": "2.6.9", + "version": "4.1.1", "bundled": true, "dev": true, "optional": true, "requires": { - "ms": "2.0.0" + "ms": "^2.1.1" } }, "deep-extend": { @@ -2404,24 +2331,24 @@ } }, "ms": { - "version": "2.0.0", + "version": "2.1.1", "bundled": true, "dev": true, "optional": true }, "needle": { - "version": "2.2.4", + "version": "2.3.0", "bundled": true, "dev": true, "optional": true, "requires": { - "debug": "^2.1.2", + "debug": "^4.1.0", "iconv-lite": "^0.4.4", "sax": "^1.2.4" } }, "node-pre-gyp": { - "version": "0.10.3", + "version": "0.12.0", "bundled": true, "dev": true, "optional": true, @@ -2449,13 +2376,13 @@ } }, "npm-bundled": { - "version": "1.0.5", + "version": "1.0.6", "bundled": true, "dev": true, "optional": true }, "npm-packlist": { - "version": "1.2.0", + "version": "1.4.1", "bundled": true, "dev": true, "optional": true, @@ -2594,7 +2521,7 @@ "optional": true }, "semver": { - "version": "5.6.0", + "version": "5.7.0", "bundled": true, "dev": true, "optional": true @@ -2691,9 +2618,9 @@ } }, "fstream": { - "version": "1.0.11", - "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", - "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", + "version": "1.0.12", + "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.12.tgz", + "integrity": "sha512-WvJ193OHa0GHPEL+AycEJgxvBEwyfRkN1vhjca23OaPVMCaLCXTd5qAu82AjTcgP1UJmytkOKb63Ypde7raDIg==", "dev": true, "requires": { "graceful-fs": "^4.1.2", @@ -2782,9 +2709,9 @@ } }, "glob": { - "version": "7.1.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", - "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", + "version": "7.1.4", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", + "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", "dev": true, "requires": { "fs.realpath": "^1.0.0", @@ -2948,21 +2875,21 @@ "dev": true }, "gulp": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/gulp/-/gulp-4.0.0.tgz", - "integrity": "sha1-lXZsYB2t5Kd+0+eyttwDiBtZY2Y=", + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/gulp/-/gulp-4.0.2.tgz", + "integrity": "sha512-dvEs27SCZt2ibF29xYgmnwwCYZxdxhQ/+LFWlbAW8y7jt68L/65402Lz3+CKy0Ov4rOs+NERmDq7YlZaDqUIfA==", "dev": true, "requires": { - "glob-watcher": "^5.0.0", - "gulp-cli": "^2.0.0", - "undertaker": "^1.0.0", + "glob-watcher": "^5.0.3", + "gulp-cli": "^2.2.0", + "undertaker": "^1.2.1", "vinyl-fs": "^3.0.0" } }, "gulp-cli": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/gulp-cli/-/gulp-cli-2.1.0.tgz", - "integrity": "sha512-txzgdFVlEPShBZus6JJyGyKJoBVDq6Do0ZQgIgx5RAsmhNVTDjymmOxpQvo3c20m66FldilS68ZXj2Q9w5dKbA==", + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/gulp-cli/-/gulp-cli-2.2.0.tgz", + "integrity": "sha512-rGs3bVYHdyJpLqR0TUBnlcZ1O5O++Zs4bA0ajm+zr3WFCfiSLjGwoCBqFs18wzN+ZxahT9DkOK5nDf26iDsWjA==", "dev": true, "requires": { "ansi-colors": "^1.0.1", @@ -3017,17 +2944,6 @@ } } }, - "gulp-filter": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/gulp-filter/-/gulp-filter-5.1.0.tgz", - "integrity": "sha1-oF4Rr/sHz33PQafeHLe2OsN4PnM=", - "dev": true, - "requires": { - "multimatch": "^2.0.0", - "plugin-error": "^0.1.2", - "streamfilter": "^1.0.5" - } - }, "gulp-if": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/gulp-if/-/gulp-if-2.0.2.tgz", @@ -3054,12 +2970,32 @@ "resolve": "^1.1.7" }, "dependencies": { + "arr-diff": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", + "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", + "dev": true, + "requires": { + "arr-flatten": "^1.0.1" + } + }, "array-unique": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", "dev": true }, + "braces": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", + "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", + "dev": true, + "requires": { + "expand-range": "^1.8.1", + "preserve": "^0.2.0", + "repeat-element": "^1.1.2" + } + }, "detect-file": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/detect-file/-/detect-file-0.1.0.tgz", @@ -3069,6 +3005,15 @@ "fs-exists-sync": "^0.1.0" } }, + "expand-brackets": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", + "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", + "dev": true, + "requires": { + "is-posix-bracket": "^0.1.0" + } + }, "expand-tilde": { "version": "1.2.2", "resolved": "https://registry.npmjs.org/expand-tilde/-/expand-tilde-1.2.2.tgz", @@ -3078,6 +3023,15 @@ "os-homedir": "^1.0.1" } }, + "extglob": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", + "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", + "dev": true, + "requires": { + "is-extglob": "^1.0.0" + } + }, "findup-sync": { "version": "0.4.3", "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-0.4.3.tgz", @@ -3133,6 +3087,45 @@ "integrity": "sha1-3hqm1j6indJIc3tp8f+LgALSEIw=", "dev": true }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, + "requires": { + "is-buffer": "^1.1.5" + } + }, + "micromatch": { + "version": "2.3.11", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", + "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", + "dev": true, + "requires": { + "arr-diff": "^2.0.0", + "array-unique": "^0.2.1", + "braces": "^1.8.2", + "expand-brackets": "^0.1.4", + "extglob": "^0.3.1", + "filename-regex": "^2.0.0", + "is-extglob": "^1.0.0", + "is-glob": "^2.0.1", + "kind-of": "^3.0.2", + "normalize-path": "^2.0.1", + "object.omit": "^2.0.0", + "parse-glob": "^3.0.4", + "regex-cache": "^0.4.2" + } + }, + "normalize-path": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", + "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "dev": true, + "requires": { + "remove-trailing-separator": "^1.0.1" + } + }, "resolve-dir": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/resolve-dir/-/resolve-dir-0.1.1.tgz", @@ -3265,21 +3258,6 @@ } } }, - "gulp-size": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/gulp-size/-/gulp-size-3.0.0.tgz", - "integrity": "sha1-yxrI5rqD3t5SQwxH/QOTJPAD/4I=", - "dev": true, - "requires": { - "chalk": "^2.3.0", - "fancy-log": "^1.3.2", - "gzip-size": "^4.1.0", - "plugin-error": "^0.1.2", - "pretty-bytes": "^4.0.2", - "stream-counter": "^1.0.0", - "through2": "^2.0.0" - } - }, "gulp-sourcemaps": { "version": "2.6.5", "resolved": "https://registry.npmjs.org/gulp-sourcemaps/-/gulp-sourcemaps-2.6.5.tgz", @@ -3308,24 +3286,6 @@ "glogg": "^1.0.0" } }, - "gzip-size": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/gzip-size/-/gzip-size-4.1.0.tgz", - "integrity": "sha1-iuCWJX6r59acRb4rZ8RIEk/7UXw=", - "dev": true, - "requires": { - "duplexer": "^0.1.1", - "pify": "^3.0.0" - }, - "dependencies": { - "pify": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", - "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", - "dev": true - } - } - }, "har-schema": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", @@ -3441,15 +3401,16 @@ "dev": true }, "http-errors": { - "version": "1.6.3", - "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", - "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", + "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", "dev": true, "requires": { "depd": "~1.1.2", "inherits": "2.0.3", - "setprototypeof": "1.1.0", - "statuses": ">= 1.4.0 < 2" + "setprototypeof": "1.1.1", + "statuses": ">= 1.5.0 < 2", + "toidentifier": "1.0.0" }, "dependencies": { "statuses": { @@ -3482,9 +3443,9 @@ } }, "iconv-lite": { - "version": "0.4.23", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.23.tgz", - "integrity": "sha512-neyTUVFtahjf0mB3dZT77u+8O0QB89jFdnBkd5P1JgYPbPaia3gXXOVL2fq8VyU2gMMD7SaN7QukTB/pmXYvDA==", + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", "dev": true, "requires": { "safer-buffer": ">= 2.1.2 < 3" @@ -3890,9 +3851,9 @@ "dev": true }, "js-yaml": { - "version": "3.13.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.0.tgz", - "integrity": "sha512-pZZoSxcCYco+DIKBTimr67J6Hy+EYGZDY/HCWC+iAEA9h1ByhMXAIVUXMcMFpOCxQ/xjXmPI2MkDL5HRm5eFrQ==", + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", + "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", "dev": true, "requires": { "argparse": "^1.0.7", @@ -4108,12 +4069,6 @@ "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", "dev": true }, - "lodash.assign": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/lodash.assign/-/lodash.assign-4.2.0.tgz", - "integrity": "sha1-DZnzzNem0mHRm9rrkkUAXShYCOc=", - "dev": true - }, "lodash.clonedeep": { "version": "4.5.0", "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", @@ -4126,12 +4081,6 @@ "integrity": "sha1-+4m2WpqAKBgz8LdHizpRBPiY67M=", "dev": true }, - "lodash.mergewith": { - "version": "4.6.1", - "resolved": "https://registry.npmjs.org/lodash.mergewith/-/lodash.mergewith-4.6.1.tgz", - "integrity": "sha512-eWw5r+PYICtEBgrBE5hhlT6aAa75f411bgDz/ZL2KZqYV03USvucsxcHUIlGTDTECs1eunpI7HOV7U+WLDvNdQ==", - "dev": true - }, "loud-rejection": { "version": "1.6.0", "resolved": "https://registry.npmjs.org/loud-rejection/-/loud-rejection-1.6.0.tgz", @@ -4232,27 +4181,6 @@ "requires": { "is-extglob": "^2.1.0" } - }, - "micromatch": { - "version": "3.1.10", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", - "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", - "dev": true, - "requires": { - "arr-diff": "^4.0.0", - "array-unique": "^0.3.2", - "braces": "^2.3.1", - "define-property": "^2.0.2", - "extend-shallow": "^3.0.2", - "extglob": "^2.0.4", - "fragment-cache": "^0.2.1", - "kind-of": "^6.0.2", - "nanomatch": "^1.2.9", - "object.pick": "^1.3.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.2" - } } } }, @@ -4317,103 +4245,24 @@ } }, "micromatch": { - "version": "2.3.11", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", - "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", + "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", "dev": true, "requires": { - "arr-diff": "^2.0.0", - "array-unique": "^0.2.1", - "braces": "^1.8.2", - "expand-brackets": "^0.1.4", - "extglob": "^0.3.1", - "filename-regex": "^2.0.0", - "is-extglob": "^1.0.0", - "is-glob": "^2.0.1", - "kind-of": "^3.0.2", - "normalize-path": "^2.0.1", - "object.omit": "^2.0.0", - "parse-glob": "^3.0.4", - "regex-cache": "^0.4.2" - }, - "dependencies": { - "arr-diff": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", - "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", - "dev": true, - "requires": { - "arr-flatten": "^1.0.1" - } - }, - "array-unique": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", - "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", - "dev": true - }, - "braces": { - "version": "1.8.5", - "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", - "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", - "dev": true, - "requires": { - "expand-range": "^1.8.1", - "preserve": "^0.2.0", - "repeat-element": "^1.1.2" - } - }, - "expand-brackets": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", - "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", - "dev": true, - "requires": { - "is-posix-bracket": "^0.1.0" - } - }, - "extglob": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", - "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", - "dev": true, - "requires": { - "is-extglob": "^1.0.0" - } - }, - "is-extglob": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", - "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", - "dev": true - }, - "is-glob": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", - "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", - "dev": true, - "requires": { - "is-extglob": "^1.0.0" - } - }, - "kind-of": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - }, - "normalize-path": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", - "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", - "dev": true, - "requires": { - "remove-trailing-separator": "^1.0.1" - } - } + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" } }, "mime": { @@ -4423,18 +4272,18 @@ "dev": true }, "mime-db": { - "version": "1.38.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.38.0.tgz", - "integrity": "sha512-bqVioMFFzc2awcdJZIzR3HjZFX20QhilVS7hytkKrv7xFAn8bM1gzc/FOX2awLISvWe0PV8ptFKcon+wZ5qYkg==", + "version": "1.40.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", + "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==", "dev": true }, "mime-types": { - "version": "2.1.22", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.22.tgz", - "integrity": "sha512-aGl6TZGnhm/li6F7yx82bJiBZwgiEa4Hf6CNr8YO+r5UHr53tSTYZb102zyU50DOWWKeOv0uQLRL0/9EiKWCog==", + "version": "2.1.24", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", + "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", "dev": true, "requires": { - "mime-db": "~1.38.0" + "mime-db": "1.40.0" } }, "mimic-fn": { @@ -4508,18 +4357,6 @@ "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", "dev": true }, - "multimatch": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/multimatch/-/multimatch-2.1.0.tgz", - "integrity": "sha1-nHkGoi+0wCkZ4vX3UWG0zb1LKis=", - "dev": true, - "requires": { - "array-differ": "^1.0.0", - "array-union": "^1.0.1", - "arrify": "^1.0.0", - "minimatch": "^3.0.0" - } - }, "mute-stdout": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/mute-stdout/-/mute-stdout-1.0.1.tgz", @@ -4527,9 +4364,9 @@ "dev": true }, "nan": { - "version": "2.13.2", - "resolved": "https://registry.npmjs.org/nan/-/nan-2.13.2.tgz", - "integrity": "sha512-TghvYc72wlMGMVMluVo9WRJc0mB8KxxF/gZ4YYFy7V2ZQX9l7rgbPg7vjS9mt6U5HXODVFVI2bOduCzwOMv/lw==", + "version": "2.14.0", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.0.tgz", + "integrity": "sha512-INOFj37C7k3AfaNTtX8RhsTw7qRy7eLET14cROi9+5HAVbbHuIWUHEauBv5qT4Av2tWasiTY1Jw6puUNqRJXQg==", "dev": true }, "nanomatch": { @@ -4552,9 +4389,9 @@ } }, "negotiator": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", - "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=", + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", + "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==", "dev": true }, "next-tick": { @@ -4598,18 +4435,18 @@ } }, "node-releases": { - "version": "1.1.13", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.13.tgz", - "integrity": "sha512-fKZGviSXR6YvVPyc011NHuJDSD8gFQvLPmc2d2V3BS4gr52ycyQ1Xzs7a8B+Ax3Ni/W+5h1h4SqmzeoA8WZRmA==", + "version": "1.1.21", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.21.tgz", + "integrity": "sha512-TwnURTCjc8a+ElJUjmDqU6+12jhli1Q61xOQmdZ7ECZVBZuQpN/1UnembiIHDM1wCcfLvh5wrWXUF5H6ufX64Q==", "dev": true, "requires": { "semver": "^5.3.0" } }, "node-sass": { - "version": "4.11.0", - "resolved": "https://registry.npmjs.org/node-sass/-/node-sass-4.11.0.tgz", - "integrity": "sha512-bHUdHTphgQJZaF1LASx0kAviPH7sGlcyNhWade4eVIpFp6tsn7SV8xNMTbsQFpEV9VXpnwTTnNYlfsZXgGgmkA==", + "version": "4.12.0", + "resolved": "https://registry.npmjs.org/node-sass/-/node-sass-4.12.0.tgz", + "integrity": "sha512-A1Iv4oN+Iel6EPv77/HddXErL2a+gZ4uBeZUy+a8O35CFYTXhgA8MgLCWBtwpGZdCvTvQ9d+bQxX/QC36GDPpQ==", "dev": true, "requires": { "async-foreach": "^0.1.3", @@ -4619,12 +4456,10 @@ "get-stdin": "^4.0.1", "glob": "^7.0.3", "in-publish": "^2.0.0", - "lodash.assign": "^4.2.0", - "lodash.clonedeep": "^4.3.2", - "lodash.mergewith": "^4.6.0", + "lodash": "^4.17.11", "meow": "^3.7.0", "mkdirp": "^0.5.1", - "nan": "^2.10.0", + "nan": "^2.13.2", "node-gyp": "^3.8.0", "npmlog": "^4.0.0", "request": "^2.88.0", @@ -4704,9 +4539,9 @@ "dev": true }, "now-and-later": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/now-and-later/-/now-and-later-2.0.0.tgz", - "integrity": "sha1-vGHLtFbXnLMiB85HygUTb/Ln1u4=", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/now-and-later/-/now-and-later-2.0.1.tgz", + "integrity": "sha512-KGvQ0cB70AQfg107Xvs/Fbu+dGmZoTRJp2TaPwcwQm3/7PteUyN2BCgk8KBMPGBUXZdVwyWS8fDCGFygBm19UQ==", "dev": true, "requires": { "once": "^1.3.2" @@ -4795,9 +4630,9 @@ } }, "object-keys": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.0.tgz", - "integrity": "sha512-6OO5X1+2tYkNyNEx6TsCxEqFfRWaqx6EtMiSbGrw8Ob8v9Ne+Hl8rBAgLBZn5wjEz3s/s6U1WXFUFOcxxAwUpg==", + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", "dev": true }, "object-path": { @@ -4837,17 +4672,6 @@ "array-slice": "^1.0.0", "for-own": "^1.0.0", "isobject": "^3.0.0" - }, - "dependencies": { - "for-own": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", - "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", - "dev": true, - "requires": { - "for-in": "^1.0.1" - } - } } }, "object.map": { @@ -4858,17 +4682,6 @@ "requires": { "for-own": "^1.0.0", "make-iterator": "^1.0.0" - }, - "dependencies": { - "for-own": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", - "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", - "dev": true, - "requires": { - "for-in": "^1.0.1" - } - } } }, "object.omit": { @@ -4879,6 +4692,17 @@ "requires": { "for-own": "^0.1.4", "is-extendable": "^0.1.1" + }, + "dependencies": { + "for-own": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", + "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", + "dev": true, + "requires": { + "for-in": "^1.0.1" + } + } } }, "object.pick": { @@ -4898,17 +4722,6 @@ "requires": { "for-own": "^1.0.0", "make-iterator": "^1.0.0" - }, - "dependencies": { - "for-own": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", - "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", - "dev": true, - "requires": { - "for-in": "^1.0.1" - } - } } }, "on-finished": { @@ -4997,9 +4810,9 @@ "dev": true }, "p-is-promise": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-2.0.0.tgz", - "integrity": "sha512-pzQPhYMCAgLAKPWD2jC3Se9fEfrD9npNos0y150EeqZll7akhEgGhTW/slB6lHku8AvYGiJ+YJ5hfHKePPgFWg==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-2.1.0.tgz", + "integrity": "sha512-Y3W0wlRPK8ZMRbNq97l4M5otioeA5lm1z7bkNkxCka8HSPjR0xRWmpCmc9utiaLP9Jb1eD8BgeIxTW4AIF45Pg==", "dev": true }, "p-limit": { @@ -5112,9 +4925,9 @@ } }, "parseurl": { - "version": "1.3.2", - "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.2.tgz", - "integrity": "sha1-/CidTtiZMRlGDBViUyYs3I3mW/M=", + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", "dev": true }, "pascalcase": { @@ -5284,9 +5097,9 @@ "dev": true }, "postcss": { - "version": "7.0.14", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.14.tgz", - "integrity": "sha512-NsbD6XUUMZvBxtQAJuWDJeeC4QFsmWsfozWxCJPWf3M55K9iu2iMDaKqyoOdTJ1R4usBXuxlVFAIo8rZPQD4Bg==", + "version": "7.0.16", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.16.tgz", + "integrity": "sha512-MOo8zNSlIqh22Uaa3drkdIAgUGEL+AD1ESiSdmElLUmE2uVDo1QloiT/IfW9qRw8Gw+Y/w69UVMGwbufMSftxA==", "dev": true, "requires": { "chalk": "^2.4.2", @@ -5316,12 +5129,6 @@ "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", "dev": true }, - "pretty-bytes": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/pretty-bytes/-/pretty-bytes-4.0.2.tgz", - "integrity": "sha1-sr+C5zUNZcbDOqlaqlpPYyf2HNk=", - "dev": true - }, "pretty-hrtime": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/pretty-hrtime/-/pretty-hrtime-1.0.3.tgz", @@ -5399,20 +5206,20 @@ } }, "range-parser": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", - "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", "dev": true }, "raw-body": { - "version": "2.3.3", - "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.3.3.tgz", - "integrity": "sha512-9esiElv1BrZoI3rCDuOuKCBRbuApGGaDPQfjSflGxdy4oyzqghxu6klEkkVIvBje+FF0BX9coEv8KqW6X/7njw==", + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", + "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", "dev": true, "requires": { - "bytes": "3.0.0", - "http-errors": "1.6.3", - "iconv-lite": "0.4.23", + "bytes": "3.1.0", + "http-errors": "1.7.2", + "iconv-lite": "0.4.24", "unpipe": "1.0.0" } }, @@ -5469,29 +5276,6 @@ "graceful-fs": "^4.1.11", "micromatch": "^3.1.10", "readable-stream": "^2.0.2" - }, - "dependencies": { - "micromatch": { - "version": "3.1.10", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", - "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", - "dev": true, - "requires": { - "arr-diff": "^4.0.0", - "array-unique": "^0.3.2", - "braces": "^2.3.1", - "define-property": "^2.0.2", - "extend-shallow": "^3.0.2", - "extglob": "^2.0.4", - "fragment-cache": "^0.2.1", - "kind-of": "^6.0.2", - "nanomatch": "^1.2.9", - "object.pick": "^1.3.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.2" - } - } } }, "rechoir": { @@ -5658,9 +5442,9 @@ "dev": true }, "resolve": { - "version": "1.10.0", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.0.tgz", - "integrity": "sha512-3sUr9aq5OfSg2S9pNtPA9hL1FVEAjvfOC4leW0SNf/mpnaakz2a9femSd6LqAww2RaFctwyf1lCqnTHuF1rxDg==", + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.11.0.tgz", + "integrity": "sha512-WL2pBDjqT6pGUNSUzMw00o4T7If+z4H2x3Gz893WoUQ5KW8Vr9txp00ykiP16VBaZF5+j/OcXJHZ9+PCvdiDKw==", "dev": true, "requires": { "path-parse": "^1.0.6" @@ -5879,6 +5663,24 @@ "ms": "2.0.0" } }, + "http-errors": { + "version": "1.6.3", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", + "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", + "dev": true, + "requires": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.0", + "statuses": ">= 1.4.0 < 2" + } + }, + "setprototypeof": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", + "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==", + "dev": true + }, "statuses": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.4.0.tgz", @@ -5910,6 +5712,30 @@ "requires": { "ms": "2.0.0" } + }, + "http-errors": { + "version": "1.6.3", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", + "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", + "dev": true, + "requires": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.0", + "statuses": ">= 1.4.0 < 2" + } + }, + "setprototypeof": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", + "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==", + "dev": true + }, + "statuses": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", + "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", + "dev": true } } }, @@ -5961,9 +5787,9 @@ } }, "setprototypeof": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", - "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==", + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", + "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==", "dev": true }, "shebang-command": { @@ -6285,9 +6111,9 @@ } }, "spdx-license-ids": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.3.tgz", - "integrity": "sha512-uBIcIl3Ih6Phe3XHK1NqboJLdGfwr1UN3k6wSD1dZpmPsIkb8AGNbZYJ1fOBk834+Gxy8rpfDxrS6XLEMZMY2g==", + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.4.tgz", + "integrity": "sha512-7j8LYJLeY/Yb6ACbQ7F76qy5jHkp0U6jgBfJsk97bwWlVUnUWsAgpyaCvo17h0/RQGnQ036tVDomiwoI4pDkQA==", "dev": true }, "split-string": { @@ -6364,12 +6190,6 @@ "readable-stream": "^2.0.1" } }, - "stream-counter": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/stream-counter/-/stream-counter-1.0.0.tgz", - "integrity": "sha1-kc8lac5NxQYf6816yyY5SloRR1E=", - "dev": true - }, "stream-exhaust": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/stream-exhaust/-/stream-exhaust-1.0.2.tgz", @@ -6392,15 +6212,6 @@ "limiter": "^1.0.5" } }, - "streamfilter": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/streamfilter/-/streamfilter-1.0.7.tgz", - "integrity": "sha512-Gk6KZM+yNA1JpW0KzlZIhjo3EaBJDkYfXtYSbOwNIQ7Zd6006E6+sCFlW1NDvFG/vnXhKmw6TJJgiEQg/8lXfQ==", - "dev": true, - "requires": { - "readable-stream": "^2.0.2" - } - }, "string-width": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", @@ -6486,13 +6297,13 @@ "dev": true }, "tar": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", - "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.2.tgz", + "integrity": "sha512-FCEhQ/4rE1zYv9rYXJw/msRqsnmlje5jHP6huWeBZ704jUTy02c5AZyWujpMR1ax6mVw9NyJMfuK2CMDWVIfgA==", "dev": true, "requires": { "block-stream": "*", - "fstream": "^1.0.2", + "fstream": "^1.0.12", "inherits": "2" } }, @@ -6648,6 +6459,12 @@ "through2": "^2.0.3" } }, + "toidentifier": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", + "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", + "dev": true + }, "tough-cookie": { "version": "2.4.3", "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", @@ -6721,9 +6538,9 @@ "dev": true }, "undertaker": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/undertaker/-/undertaker-1.2.0.tgz", - "integrity": "sha1-M52kZGJS0ILcN45wgGcpl1DhG0k=", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/undertaker/-/undertaker-1.2.1.tgz", + "integrity": "sha512-71WxIzDkgYk9ZS+spIB8iZXchFhAdEo2YU8xYqBYJ39DIUIqziK78ftm26eecoIY49X0J2MLhG4hr18Yp6/CMA==", "dev": true, "requires": { "arr-flatten": "^1.0.1", @@ -6892,9 +6709,9 @@ "dev": true }, "v8flags": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/v8flags/-/v8flags-3.1.2.tgz", - "integrity": "sha512-MtivA7GF24yMPte9Rp/BWGCYQNaUj86zeYxV/x2RRJMKagImbbv3u8iJC57lNhWLPcGLJmHcHmFWkNsplbbLWw==", + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/v8flags/-/v8flags-3.1.3.tgz", + "integrity": "sha512-amh9CCg3ZxkzQ48Mhcb8iX7xpAfYJgePHxWMQCBWECpOSqJUXgY26ncA61UTV0BkPqfhcy6mzwCIoP4ygxpW8w==", "dev": true, "requires": { "homedir-polyfill": "^1.0.1" diff --git a/package.json b/package.json index 5e4262d..b950a6a 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "pixel-borders", - "description": "A SASS mixin to add pixelated borders to HTML elements.", - "version": "1.0.1", + "description": "SASS mixin to add pixelated borders to HTML elements.", + "version": "1.1.0", "main": "src/styles/pixel-borders.scss", "repository": { "type": "git", @@ -24,31 +24,28 @@ "engines": { "node": ">=4" }, - "devDependencies": { - "autoprefixer": "^9.4.4", - "browser-sync": "^2.2.1", - "cross-env": "^5.2.0", - "del": "^3.0.0", - "gulp": "^4.0.0", - "gulp-cli": "^2.0.1", - "gulp-filter": "^5.1.0", - "gulp-if": "^2.0.2", - "gulp-load-plugins": "^1.2.4", - "gulp-plumber": "^1.0.1", - "gulp-postcss": "^8.0.0", - "gulp-sass": "^4.0.2", - "gulp-size": "^3.0.0", - "gulp-sourcemaps": "^2.2.0", - "yargs": "12.0.5" - }, - "scripts": { - "start": "gulp serve", - "build": "cross-env NODE_ENV=production gulp", - "tasks": "gulp --tasks" - }, "browserslist": [ "> 1%", "last 2 versions", "Firefox ESR" - ] + ], + "devDependencies": { + "autoprefixer": "^9.4.4", + "browser-sync": "^2.26.5", + "cross-env": "^5.2.0", + "del": "^3.0.0", + "gulp": "^4.0.0", + "gulp-cli": "^2.0.1", + "gulp-if": "^2.0.2", + "gulp-load-plugins": "^1.5", + "gulp-plumber": "^1.0.1", + "gulp-postcss": "^8.0.0", + "gulp-sass": "^4.0.2", + "gulp-sourcemaps": "^2.2.0", + "yargs": "^12.0.5" + }, + "scripts": { + "start": "gulp serve", + "build": "cross-env NODE_ENV=production gulp" + } } diff --git a/src/index.html b/src/index.html index 804b33f..806ac82 100644 --- a/src/index.html +++ b/src/index.html @@ -3,7 +3,7 @@ - Pixel borders - A SASS mixin to add pixelated borders to HTML elements + Pixel borders - SASS mixin to add pixelated borders to HTML elements @@ -30,7 +30,7 @@
-

A SASS mixin to add pixelated borders to HTML elements, which can be customized for different sizes, colour coding,inset borders.

+

A SASS mixin to add pixelated borders to HTML elements, which can be customized for different sizes, styles and colour coding.

@@ -84,9 +84,13 @@

Import

-

After adding the repo as a dependency you can import it into your SASS files. Alternatively you can download the pixel-borders.scss from this repo and add it to your project folder directly.

+

After installation you can import it into your SASS files with the statement below.

-
@import "node_modules/pixel-borders/src/styles/pixel-borders.scss";
+
@import "pixel-borders/src/styles/pixel-borders.scss";
+ +

You can also just import the mixins without the demo styles.

+ +
@import "pixel-borders/src/styles/pixel-borders/pixel-borders-mixins";

Pixel borders mixin options

diff --git a/src/styles/pixel-borders.scss b/src/styles/pixel-borders.scss index 1d04195..1184ca9 100644 --- a/src/styles/pixel-borders.scss +++ b/src/styles/pixel-borders.scss @@ -1,228 +1,2 @@ -// Generate SVG image for pixelated corners -@function pixel-borders-image($corner-size, $color) { - $svg: ''; - $svg-path: ''; - $svg-size: $corner-size * 6; - $color: str-replace('' + $color, '#', '%23'); - - @if $corner-size == 1 { - $svg-path: 'M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z'; - } @else { - $svg-path: 'M2 2h2v2H2zM4 0h2v2H4zM10 4h2v2h-2zM0 4h2v2H0zM6 0h2v2H6zM8 2h2v2H8zM8 8h2v2H8zM6 10h2v2H6zM0 6h2v2H0zM10 6h2v2h-2zM4 10h2v2H4zM2 8h2v2H2z'; - } - - $svg: 'data:image/svg+xml,'; - - @return $svg; -} - - -// String replace function - replace `$search` with `$replace` in `$string` -@function str-replace($string, $search, $replace: '') { - $index: str-index($string, $search); - - @if $index { - @return str-slice($string, 1, $index - 1) + $replace + str-replace(str-slice($string, $index + str-length($search)), $search, $replace); - } - - @return $string; -} - - -// Pixel border -@mixin pixel-borders($corner-size: 1, $border-size: 4px, $border-color: #000, $border-inset-color: false) { - - @supports (border-image-source: none) { - border-radius: ($border-size * ($corner-size + 2)) + ($corner-size * 2); - } - - border-style: solid; - border-width: $border-size; - border-color: $border-color; - - border-image-slice: $corner-size * 2; - border-image-width: $corner-size; - border-image-outset: 0; - - border-image-source: url(pixel-borders-image($corner-size, $border-color)); - - @if $border-inset-color { - @include pixel-inset-border($border-size, $border-inset-color); - } - -} - - -// Pixel inset border -@mixin pixel-inset-border($border-inset-size: 4px, $border-inset-color: #ddd, $border-inset-sides: 'bottom-right', $border-inset-color-br: false, $border-inset-color-tl: false) { - - $box-shadow: ''; - @if not($border-inset-color-br) { - $border-inset-color-br: $border-inset-color; - } - - @if not($border-inset-color-tl) { - $border-inset-color-tl: $border-inset-color; - } - - position: relative; - - &::after { - content: ''; - position: absolute; - z-index: 0; - bottom: 0; - right: 0; - width: 100%; - height: 100%; - - @if $border-inset-sides == 'bottom-right' or $border-inset-sides == false { - $box-shadow: inset -#{$border-inset-size} -#{$border-inset-size} $border-inset-color-br; - } - - @if $border-inset-sides == 'top-left' { - $box-shadow: inset $border-inset-size $border-inset-size $border-inset-color-tl; - } - - @if $border-inset-sides == 'all' { - $box-shadow: inset -#{$border-inset-size} -#{$border-inset-size} $border-inset-color-br, inset $border-inset-size $border-inset-size $border-inset-color-tl; - } - - box-shadow: $box-shadow; - } - -} - - - -// Pixel box - Colours for border and inset are calculated using $background-color unless $border-color is passed -@mixin pixel-box($corner-size, $border-size, $background-color, $border-color: false, $border-inset: true, $border-inset-size: false, $border-inset-color: false, $border-inset-sides: false, $border-inset-color-br: false, $border-inset-color-tl: false) { - - $background-color-hover: darken($background-color, 5); - - @if not($border-color) { - $border-color: darken($background-color, 20); - } - - @include pixel-borders($corner-size: $corner-size, $border-size: $border-size, $border-color: $border-color); - - @if $border-inset-sides == 'all' and not($border-inset-color) { - $border-inset-color-br: darken($background-color, 10); - $border-inset-color-tl: lighten($background-color, 15); - } - - @if not($border-inset-color) { - $border-inset-color: darken($background-color, 10); - } - - @if $border-inset-sides == 'top-left' { - $border-inset-color: lighten($background-color, 15); - } - - - @if $border-inset { - @include pixel-inset-border($border-inset-size: $border-size, $border-inset-color: $border-inset-color, $border-inset-sides: $border-inset-sides, $border-inset-color-br: $border-inset-color-br, $border-inset-color-tl: $border-inset-color-tl); - } - - background-color: $background-color; - - &:hover, &:focus { - background-color: $background-color-hover; - } - -} - - - -// ----- Demo styles ----- -.pixel-borders { - position: relative; - display: inline-block; - margin: 0 15px 15px 0; - padding: 15px 20px; - background-color: #fff; - font-family: "Press Start 2P", Arial Black, Arial Bold, Arial, sans-serif; -} - - -// Simple examples with default styling -.pixel-borders--1 { - @include pixel-borders(); -} - -.pixel-borders--1-inset { - @include pixel-borders($border-inset-color: #ddd); -} - - -.pixel-borders--2 { - @include pixel-borders($corner-size: 2); -} - -.pixel-borders--2-inset { - @include pixel-borders($corner-size: 2); - - &::after { - @include pixel-borders($corner-size: 1, $border-color: #ddd); - - content: ''; - position: absolute; - z-index: 0; - bottom: 0; - right: 0; - border-image-width: 0 1 1 0; - width: calc(100% - 4px); - height: calc(100% - 4px); - } -} - - - -// Examples using the pixel box mixin to colour code the elements -.pixel-box--light { - @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #fff); -} - -.pixel-box--primary { - color: #fff; - @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #209cee); -} - -.pixel-box--success { - color: #fff; - @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #92cc41); -} - -.pixel-box--warning { - @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #f7d51d); -} - -.pixel-box--error { - color: #fff; - @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #e76e55); -} - - -// Custom examples to show flexibility of the mixins -.pixel-box--light-custom { - @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #fff, $border-inset-color: #999, $border-inset-sides: 'all'); -} - -.pixel-box--primary-custom { - color: #fff; - @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #209cee, $border-inset: false); -} - -.pixel-box--success-custom { - color: #fff; - @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #92cc41, $border-inset-sides: 'top-left'); -} - -.pixel-box--warning-custom { - @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #f7d51d, $border-inset-sides: 'all'); -} - -.pixel-box--error-custom { - color: #fff; - @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #e76e55, $border-color: #000); -} +@import "pixel-borders/pixel-borders-mixins"; +@import "pixel-borders/pixel-borders"; diff --git a/src/styles/pixel-borders/_pixel-borders-mixins.scss b/src/styles/pixel-borders/_pixel-borders-mixins.scss new file mode 100644 index 0000000..6d4ee62 --- /dev/null +++ b/src/styles/pixel-borders/_pixel-borders-mixins.scss @@ -0,0 +1,133 @@ +// Generate SVG image for pixelated corners +@function pixel-borders-image($corner-size, $color) { + $svg: ''; + $svg-path: ''; + $svg-size: $corner-size * 6; + $color: str-replace('' + $color, '#', '%23'); + + @if $corner-size == 1 { + $svg-path: 'M0 2h2v2H0zM2 0h2v2H2zM4 2h2v2H4zM2 4h2v2H2z'; + } @else { + $svg-path: 'M2 2h2v2H2zM4 0h2v2H4zM10 4h2v2h-2zM0 4h2v2H0zM6 0h2v2H6zM8 2h2v2H8zM8 8h2v2H8zM6 10h2v2H6zM0 6h2v2H0zM10 6h2v2h-2zM4 10h2v2H4zM2 8h2v2H2z'; + } + + $svg: 'data:image/svg+xml,'; + + @return $svg; +} + + +// String replace function - replace `$search` with `$replace` in `$string` +@function str-replace($string, $search, $replace: '') { + $index: str-index($string, $search); + + @if $index { + @return str-slice($string, 1, $index - 1) + $replace + str-replace(str-slice($string, $index + str-length($search)), $search, $replace); + } + + @return $string; +} + + +// Pixel border +@mixin pixel-borders($corner-size: 1, $border-size: 4px, $border-color: #000, $border-inset-color: false) { + + @supports (border-image-source: none) { + border-radius: ($border-size * ($corner-size + 2)) + ($corner-size * 2); + } + + border-style: solid; + border-width: $border-size; + border-color: $border-color; + + border-image-slice: $corner-size * 2; + border-image-width: $corner-size; + border-image-outset: 0; + + border-image-source: url(pixel-borders-image($corner-size, $border-color)); + + @if $border-inset-color { + @include pixel-inset-border($border-size, $border-inset-color); + } + +} + + +// Pixel inset border +@mixin pixel-inset-border($border-inset-size: 4px, $border-inset-color: #ddd, $border-inset-sides: 'bottom-right', $border-inset-color-br: false, $border-inset-color-tl: false) { + + $box-shadow: ''; + @if not($border-inset-color-br) { + $border-inset-color-br: $border-inset-color; + } + + @if not($border-inset-color-tl) { + $border-inset-color-tl: $border-inset-color; + } + + position: relative; + + &::after { + content: ''; + position: absolute; + z-index: 0; + bottom: 0; + right: 0; + width: 100%; + height: 100%; + + @if $border-inset-sides == 'bottom-right' or $border-inset-sides == false { + $box-shadow: inset -#{$border-inset-size} -#{$border-inset-size} $border-inset-color-br; + } + + @if $border-inset-sides == 'top-left' { + $box-shadow: inset $border-inset-size $border-inset-size $border-inset-color-tl; + } + + @if $border-inset-sides == 'all' { + $box-shadow: inset -#{$border-inset-size} -#{$border-inset-size} $border-inset-color-br, inset $border-inset-size $border-inset-size $border-inset-color-tl; + } + + box-shadow: $box-shadow; + } + +} + + + +// Pixel box - Colours for border and inset are calculated using $background-color unless $border-color is passed +@mixin pixel-box($corner-size, $border-size, $background-color, $border-color: false, $border-inset: true, $border-inset-size: false, $border-inset-color: false, $border-inset-sides: false, $border-inset-color-br: false, $border-inset-color-tl: false) { + + $background-color-hover: darken($background-color, 5); + + @if not($border-color) { + $border-color: darken($background-color, 20); + } + + @include pixel-borders($corner-size: $corner-size, $border-size: $border-size, $border-color: $border-color); + + @if $border-inset-sides == 'all' and not($border-inset-color) { + $border-inset-color-br: darken($background-color, 10); + $border-inset-color-tl: lighten($background-color, 15); + } + + @if not($border-inset-color) { + $border-inset-color: darken($background-color, 10); + } + + @if $border-inset-sides == 'top-left' { + $border-inset-color: lighten($background-color, 15); + } + + + @if $border-inset { + @include pixel-inset-border($border-inset-size: $border-size, $border-inset-color: $border-inset-color, $border-inset-sides: $border-inset-sides, $border-inset-color-br: $border-inset-color-br, $border-inset-color-tl: $border-inset-color-tl); + } + + background-color: $background-color; + + &:hover, &:focus { + background-color: $background-color-hover; + } + +} diff --git a/src/styles/pixel-borders/_pixel-borders.scss b/src/styles/pixel-borders/_pixel-borders.scss new file mode 100644 index 0000000..8f33466 --- /dev/null +++ b/src/styles/pixel-borders/_pixel-borders.scss @@ -0,0 +1,93 @@ +// ----- Border styles ----- +.pixel-borders { + position: relative; + display: inline-block; + margin: 0 15px 15px 0; + padding: 15px 20px; + background-color: #fff; + font-family: "Press Start 2P", Arial Black, Arial Bold, Arial, sans-serif; +} + + +// One pixel borders +.pixel-borders--1 { + @include pixel-borders(); +} + +.pixel-borders--1-inset { + @include pixel-borders($border-inset-color: #ddd); +} + + +// Two pixel borders +.pixel-borders--2 { + @include pixel-borders($corner-size: 2); +} + +.pixel-borders--2-inset { + @include pixel-borders($corner-size: 2); + + &::after { + @include pixel-borders($corner-size: 1, $border-color: #ddd); + + content: ''; + position: absolute; + z-index: 0; + bottom: 0; + right: 0; + border-image-width: 0 1 1 0; + width: calc(100% - 4px); + height: calc(100% - 4px); + } +} + + + +// Examples using the pixel box mixin to colour code the elements +.pixel-box--light { + @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #fff); +} + +.pixel-box--primary { + color: #fff; + @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #209cee); +} + +.pixel-box--success { + color: #fff; + @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #92cc41); +} + +.pixel-box--warning { + @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #f7d51d); +} + +.pixel-box--error { + color: #fff; + @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #e76e55); +} + + +// Custom examples to show flexibility of the mixins +.pixel-box--light-custom { + @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #fff, $border-inset-color: #999, $border-inset-sides: 'all'); +} + +.pixel-box--primary-custom { + color: #fff; + @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #209cee, $border-inset: false); +} + +.pixel-box--success-custom { + color: #fff; + @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #92cc41, $border-inset-sides: 'top-left'); +} + +.pixel-box--warning-custom { + @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #f7d51d, $border-inset-sides: 'all'); +} + +.pixel-box--error-custom { + color: #fff; + @include pixel-box($corner-size: 1, $border-size: 4px, $background-color: #e76e55, $border-color: #000); +} diff --git a/src/styles/site.scss b/src/styles/site.scss index 98a5021..caf294e 100644 --- a/src/styles/site.scss +++ b/src/styles/site.scss @@ -1,222 +1,2 @@ -// ----- Demo site styles ----- -@import "normalize"; - - - -// ----- Base styles ----- - -*, -*:before, -*:after { - box-sizing: border-box; -} - -body { - font-family: "Lato", -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji"; - font-size: 1rem; - font-weight: 400; - line-height: 1.5; - color: #333; - background-color: #fff; -} - - -a { - color: #1976D2; - text-decoration: none; - transition: color 0.3s; - - &:hover, &:focus { - color: #2196F3; - } -} - -// Type -h1, h2, h3, h4, h5, h6 { - font-weight: 300; - - small { - font-size: 60%; - } -} - -h1, h2 { - margin: 0 0 1rem 0; -} - -h3, h4, h5, h6 { - margin: 0 0 .5rem 0; -} - -h1 { font-size: 2.5rem; } -h2 { font-size: 2rem; } -h3 { font-size: 1.75rem; } -h4 { font-size: 1.5rem; } -h5 { font-size: 1.25rem; } -h6 { font-size: 1rem; } - -p { - margin: 0 0 1rem 0; -} - -strong, th { - font-weight: 800; -} - -pre, code { - font-family: 'Cutive Mono', monospace; - background-color: #f3f3f3; -} - -pre { - display: block; - padding: .75rem 1rem; - margin: 0 0 1.5rem 0; - overflow: auto; - font-size: 1rem; - word-break: break-all; - word-wrap: break-word; - border: 1px solid #bbb; - border-radius: 4px; -} - -.table { - width: 100%; - margin: 0 0 1rem 0; - border-collapse: collapse; - - th, td { - padding: .25rem .5rem; - text-align: left; - vertical-align: top; - border: 1px solid #ddd; - } -} - - - -// ----- Layout ----- -.fullwidth { - .container { - width: 100%; - padding-top: 2rem; - padding-bottom: 2rem; - } -} - -.fullwidth--sm { - .container { - padding-top: 1rem; - padding-bottom: 1rem; - } -} - - .container { - width: 100%; - max-width: 1140px; - margin: 0 auto; - padding-left: 1rem; - padding-right: 1rem; - } - - .subsection { - margin: 0 0 2rem 0; - } - - -.separator { - border-bottom: 1px solid #ddd; -} - - - -// ----- Header and footer ----- -.header { - position: sticky; - top: 0; - z-index: 100; - width: 100%; - padding: .5rem 0; - color: #fff; - background-color: #1976D2; - box-shadow: 0 0 6px 6px rgba(0,0,0,0.1); - - @media (min-width: 768px) { - padding: 1rem 0; - } - - - .container { - display: flex; - - @media (max-width: 767px) { - flex-flow: column; - } - - @media (min-width: 768px) { - align-items: center; - } - } - -} - - .logo-text { - margin: 0; - - @media (max-width: 767px) { - font-size: 1.75rem; - } - } - - .header--links { - - .btn-demo { - margin: .5rem 0; - - &:last-child { - margin-left: .5rem; - } - } - - @media (min-width: 768px) { - margin-left: auto; - } - } - - -.footer { - text-align: center; -} - - - -// ----- Buttons ----- -.btn-demo { - display: inline-block; - text-align: center; - vertical-align: middle; - cursor: pointer; - border: 1px solid #bbb; - padding: 4px 12px 6px 12px; - font-size: 18px; - background-color: #fff; - border-radius: 4px; - transition: background-color .3s, color .3s; - - &:hover, &:active { - background-color: #f3f3f3; - } -} - -.btn-demo--white { - color: #fff; - border-color: #fff; - background-color: transparent; -} - - - -// ----- Utilities ----- -.m-0 { - margin: 0; -} +@import "site/normalize"; +@import "site/site"; diff --git a/src/styles/_normalize.scss b/src/styles/site/_normalize.scss similarity index 100% rename from src/styles/_normalize.scss rename to src/styles/site/_normalize.scss diff --git a/src/styles/site/_site.scss b/src/styles/site/_site.scss new file mode 100644 index 0000000..5c0defb --- /dev/null +++ b/src/styles/site/_site.scss @@ -0,0 +1,217 @@ +// ----- Base styles ----- + +*, +*:before, +*:after { + box-sizing: border-box; +} + +body { + font-family: "Lato", -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji"; + font-size: 1rem; + font-weight: 400; + line-height: 1.5; + color: #333; + background-color: #fff; +} + + +a { + color: #1976D2; + text-decoration: none; + transition: color 0.3s; + + &:hover, &:focus { + color: #2196F3; + } +} + +// Type +h1, h2, h3, h4, h5, h6 { + font-weight: 300; + + small { + font-size: 60%; + } +} + +h1, h2 { + margin: 0 0 1rem 0; +} + +h3, h4, h5, h6 { + margin: 0 0 .5rem 0; +} + +h1 { font-size: 2.5rem; } +h2 { font-size: 2rem; } +h3 { font-size: 1.75rem; } +h4 { font-size: 1.5rem; } +h5 { font-size: 1.25rem; } +h6 { font-size: 1rem; } + +p { + margin: 0 0 1rem 0; +} + +strong, th { + font-weight: 800; +} + +pre, code { + font-family: 'Cutive Mono', monospace; + background-color: #f3f3f3; +} + +pre { + display: block; + padding: .75rem 1rem; + margin: 0 0 1.5rem 0; + overflow: auto; + font-size: 1rem; + word-break: break-all; + word-wrap: break-word; + border: 1px solid #bbb; + border-radius: 4px; +} + +.table { + width: 100%; + margin: 0 0 1rem 0; + border-collapse: collapse; + + th, td { + padding: .25rem .5rem; + text-align: left; + vertical-align: top; + border: 1px solid #ddd; + } +} + + + +// ----- Layout ----- +.fullwidth { + .container { + width: 100%; + padding-top: 2rem; + padding-bottom: 2rem; + } +} + +.fullwidth--sm { + .container { + padding-top: 1rem; + padding-bottom: 1rem; + } +} + + .container { + width: 100%; + max-width: 1140px; + margin: 0 auto; + padding-left: 1rem; + padding-right: 1rem; + } + + .subsection { + margin: 0 0 2rem 0; + } + + +.separator { + border-bottom: 1px solid #ddd; +} + + + +// ----- Header and footer ----- +.header { + position: sticky; + top: 0; + z-index: 100; + width: 100%; + padding: .5rem 0; + color: #fff; + background-color: #1976D2; + box-shadow: 0 0 6px 6px rgba(0,0,0,0.1); + + @media (min-width: 768px) { + padding: 1rem 0; + } + + + .container { + display: flex; + + @media (max-width: 767px) { + flex-flow: column; + } + + @media (min-width: 768px) { + align-items: center; + } + } + +} + + .logo-text { + margin: 0; + + @media (max-width: 767px) { + font-size: 1.75rem; + } + } + + .header--links { + + .btn-demo { + margin: .5rem 0; + + &:last-child { + margin-left: .5rem; + } + } + + @media (min-width: 768px) { + margin-left: auto; + } + } + + +.footer { + text-align: center; +} + + + +// ----- Buttons ----- +.btn-demo { + display: inline-block; + text-align: center; + vertical-align: middle; + cursor: pointer; + border: 1px solid #bbb; + padding: 4px 12px 6px 12px; + font-size: 18px; + background-color: #fff; + border-radius: 4px; + transition: background-color .3s, color .3s; + + &:hover, &:active { + background-color: #f3f3f3; + } +} + +.btn-demo--white { + color: #fff; + border-color: #fff; + background-color: transparent; +} + + + +// ----- Utilities ----- +.m-0 { + margin: 0; +} diff --git a/tasks/gulp/images.js b/tasks/gulp/images.js deleted file mode 100644 index 0da6095..0000000 --- a/tasks/gulp/images.js +++ /dev/null @@ -1,18 +0,0 @@ -// Task type: Images: File copying, no processing, Icons: Processing nunjucks and data.json into HTML -// Src: /src -// Dest: Images: /dist, Icons: /tmp - - -const { lastRun } = require('gulp'); - -module.exports = function({ src, dest }, $, paths, isProd, server) { - - function images() { - return src([`${paths.src}/images/**/*`], { since: lastRun(images) }) - .pipe(dest(`${paths.dest}/images`)); - }; - - return { - images - }; -}; diff --git a/tasks/gulp/styles.js b/tasks/gulp/styles.js deleted file mode 100644 index 4d5be28..0000000 --- a/tasks/gulp/styles.js +++ /dev/null @@ -1,30 +0,0 @@ -// Task type: Processing sass -// Src: /src -// Dest: /tmp - -const autoprefixer = require('autoprefixer'); - -module.exports = function({ src, dest }, $, paths, isProd, server) { - - function styles() { - return src(`${paths.src}/styles/*.scss`) - .pipe($.plumber()) - .pipe($.if(!isProd, $.sourcemaps.init())) - .pipe($.sass.sync({ - outputStyle: 'expanded', - precision: 10, - includePaths: ['.'] - }) - .on('error', $.sass.logError)) - .pipe($.postcss([ - autoprefixer() - ])) - .pipe($.if(!isProd, $.sourcemaps.write())) - .pipe(dest(`${paths.tmp}/styles`)) - .pipe(server.reload({stream: true})); - }; - - return { - styles - }; -};