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
- };
-};