Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/fourtyone11/origin-hugo-theme.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'assets/node_modules/stylelint-scss')
-rw-r--r--assets/node_modules/stylelint-scss/CHANGELOG.md346
-rw-r--r--assets/node_modules/stylelint-scss/LICENSE21
-rw-r--r--assets/node_modules/stylelint-scss/README.md299
-rw-r--r--assets/node_modules/stylelint-scss/dist/index.js20
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-each-key-value-single-line/index.js109
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-else-closing-brace-newline-after/index.js55
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-else-closing-brace-space-after/index.js46
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-else-empty-line-before/index.js57
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-else-if-parentheses-space-before/index.js65
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-extend-no-missing-placeholder/index.js46
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-function-named-arguments/index.js115
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-function-parentheses-space-before/index.js61
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-function-pattern/index.js56
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-if-closing-brace-newline-after/index.js124
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-if-closing-brace-space-after/index.js105
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-if-no-null/index.js61
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-import-no-partial-leading-underscore/index.js60
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension-blacklist/index.js80
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension-whitelist/index.js82
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension/index.js85
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-mixin-argumentless-call-parentheses/index.js69
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-mixin-named-arguments/index.js118
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-mixin-parentheses-space-before/index.js61
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-mixin-pattern/index.js56
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-rule-conditional-no-parentheses/index.js86
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/at-rule-no-unknown/index.js67
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/comment-no-loud/index.js50
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/declaration-nested-properties-no-divided-groups/index.js76
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/declaration-nested-properties/index.js154
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/dimension-no-non-numeric-values/index.js102
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-newline-after/index.js112
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-space-after/index.js129
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-space-before/index.js51
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/dollar-variable-default/index.js63
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/dollar-variable-empty-line-before/index.js126
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/dollar-variable-no-missing-interpolation/index.js146
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/dollar-variable-pattern/index.js66
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-empty-line-before/index.js107
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-inline/index.js83
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-whitespace-inside/index.js76
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/function-color-relative/index.js57
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/function-quote-no-quoted-strings-inside/index.js79
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/function-unquote-no-unquoted-strings-inside/index.js79
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/index.js168
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/map-keys-quotes/index.js99
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/media-feature-value-dollar-variable/index.js75
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/no-dollar-variables/index.js47
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/no-duplicate-dollar-variables/index.js66
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/no-duplicate-mixins/index.js56
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/operator-no-newline-after/index.js80
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/operator-no-newline-before/index.js80
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/operator-no-unspaced/index.js268
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/partial-no-import/index.js80
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/percent-placeholder-pattern/index.js99
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/selector-nest-combinators/index.js139
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/selector-no-redundant-nesting-selector/index.js69
-rw-r--r--assets/node_modules/stylelint-scss/dist/rules/selector-no-union-class-name/index.js88
-rw-r--r--assets/node_modules/stylelint-scss/dist/testUtils/basicChecks.js16
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/addEmptyLineBefore.js23
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/atRuleBaseName.js16
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/atRuleParamIndex.js23
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/beforeBlockString.js47
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/blockString.js31
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/configurationError.js18
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/declarationValueIndex.js18
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/eachRoot.js23
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/findCommentsInRaws.js227
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/hasBlock.js16
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/hasEmptyLine.js16
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/hasInterpolatingAmpersand.js37
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/hasInterpolation.js31
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/hasLessInterpolation.js16
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/hasPsvInterpolation.js15
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/hasScssInterpolation.js15
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/hasTplInterpolation.js16
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/index.js231
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/isCustomPropertySet.js23
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/isInlineComment.js21
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/isNativeCssFunction.js17
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/isSingleLineString.js17
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/isStandardRule.js75
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/isStandardSelector.js30
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/isStandardSyntaxProperty.js40
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/isStandardSyntaxSelector.js45
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/isWhitespace.js16
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/namespace.js11
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/optionsHaveException.js19
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/optionsHaveIgnored.js19
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/parseFunctionArguments.js77
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/parseNestedPropRoot.js87
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/parseSelector.js20
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/rawNodeString.js23
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/removeEmptyLinesBefore.js18
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/sassValueParser/index.js933
-rw-r--r--assets/node_modules/stylelint-scss/dist/utils/whitespaceChecker.js371
-rw-r--r--assets/node_modules/stylelint-scss/docs/examples/README.md5
-rw-r--r--assets/node_modules/stylelint-scss/docs/examples/if-else.md148
l---------assets/node_modules/stylelint-scss/node_modules/.bin/stylelint1
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/API.md873
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/CHANGELOG.md479
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/LICENSE-MIT22
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/README.md49
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/attributes.js477
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/classes.js216
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/combinators.js148
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/comments.js38
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/container.js393
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/escapes.js19
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/exceptions.js24
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/guards.js118
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/id.js229
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/lossy.js88
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/namespaces.js66
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/nesting.js40
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/node.js139
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/nonstandard.js38
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/parser.js259
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/postcss.js46
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/pseudos.js98
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/sourceIndex.js229
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/stripComments.js17
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/tags.js35
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/universal.js32
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/util/helpers.js90
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/index.js22
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/parser.js1223
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/processor.js208
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/attribute.js516
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/className.js69
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/combinator.js31
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/comment.js31
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/constructors.js102
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/container.js398
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/guards.js64
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/id.js37
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/index.js24
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/namespace.js101
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/nesting.js32
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/node.js237
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/pseudo.js38
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/root.js60
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/selector.js31
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/string.js31
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/tag.js31
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/types.js28
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/universal.js32
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/sortAscending.js13
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/tokenTypes.js95
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/tokenize.js268
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/ensureObject.js22
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/getProp.js24
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/index.js22
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/stripComments.js27
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/unesc.js20
l---------assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/node_modules/.bin/cssesc1
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/package.json76
-rw-r--r--assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/postcss-selector-parser.d.ts499
-rw-r--r--assets/node_modules/stylelint-scss/package.json180
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-each-key-value-single-line/README.md67
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-else-closing-brace-newline-after/README.md74
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-else-closing-brace-space-after/README.md131
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-else-empty-line-before/README.md69
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-else-if-parentheses-space-before/README.md58
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-extend-no-missing-placeholder/README.md49
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-function-named-arguments/README.md131
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-function-parentheses-space-before/README.md50
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-function-pattern/README.md29
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-if-closing-brace-newline-after/README.md60
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-if-closing-brace-space-after/README.md100
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-if-no-null/README.md44
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-import-no-partial-leading-underscore/README.md59
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension-blacklist/README.md70
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension-whitelist/README.md78
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension/README.md116
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-mixin-argumentless-call-parentheses/README.md47
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-mixin-named-arguments/README.md102
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-mixin-parentheses-space-before/README.md58
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-mixin-pattern/README.md29
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-rule-conditional-no-parentheses/README.md43
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/at-rule-no-unknown/README.md76
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/comment-no-loud/README.md33
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/declaration-nested-properties-no-divided-groups/README.md68
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/declaration-nested-properties/README.md153
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/dimension-no-non-numeric-values/README.md93
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-newline-after/README.md85
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-space-after/README.md139
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-space-before/README.md73
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/dollar-variable-default/README.md25
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/dollar-variable-empty-line-before/README.md205
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/dollar-variable-no-missing-interpolation/README.md111
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/dollar-variable-pattern/README.md69
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/double-slash-comment-empty-line-before/README.md151
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/double-slash-comment-inline/README.md110
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/double-slash-comment-whitespace-inside/README.md60
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/function-color-relative/README.md83
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/function-quote-no-quoted-strings-inside/README.md46
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/function-unquote-no-unquoted-strings-inside/README.md46
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/map-keys-quotes/README.md26
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/media-feature-value-dollar-variable/README.md86
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/no-dollar-variables/README.md38
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/no-duplicate-dollar-variables/README.md143
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/no-duplicate-mixins/README.md83
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/operator-no-newline-after/README.md54
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/operator-no-newline-before/README.md55
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/operator-no-unspaced/README.md100
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/partial-no-import/README.md69
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/percent-placeholder-pattern/README.md57
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/selector-nest-combinators/README.md221
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/selector-no-redundant-nesting-selector/README.md61
-rw-r--r--assets/node_modules/stylelint-scss/src/rules/selector-no-union-class-name/README.md46
210 files changed, 0 insertions, 21155 deletions
diff --git a/assets/node_modules/stylelint-scss/CHANGELOG.md b/assets/node_modules/stylelint-scss/CHANGELOG.md
deleted file mode 100644
index 5ff2a03..0000000
--- a/assets/node_modules/stylelint-scss/CHANGELOG.md
+++ /dev/null
@@ -1,346 +0,0 @@
-# 3.14.2
-
-- Fixed: `operator-no-unspaced` ignore operators inside `@at-root`.
-
-# 3.14.1
-
-- Fixed: `at-import-partial-extension` don't warn for urls that have commas in them.
-
-# 3.14.0
-
-- Added: support for stylelint version 13.
-- Fixed: avoid possible breaking changes in the future by not using stylelint's internal utility functions.
-
-# 3.13.0
-
-- Added: support for stylelint version 12.
-- Fixed: duplicate warnings in `at-rule-no-unknown` rule.
-
-# 3.12.1
-
-- Fixed: `at-rule-conditional-no-parentheses` don't warn for function calls.
-- Fixed: `map-keys-quotes` ignore math operators inside map values.
-- Fixed: `operator-no-unspaced` was looking for operators inside `@forward` and `@use`.
-
-# 3.12.0
-
-- Added: `no-duplicate-mixins` rule.
-- Added: `at-rule-no-unknown` support for Sass' `@forward` and `@use`.
-
-# 3.11.1
-
-- Fixed: `selector-nest-combinators` warning for `@keyframes`.
-
-# 3.11.0
-
-- Added: support for stylelint version 11.
-
-# 3.10.1
-
-- Fixed: broken linting reporting for `dimension-no-non-numeric-values` rule.
-
-# 3.10.0
-
-- Added: `at-if-no-null`rule.
-- Added: `at-import-partial-extension` rule.
-- Added: `at-rule-conditional-no-parentheses` rule.
-- Added: `dimension-no-non-numeric-values` rule.
-
-# 3.9.4
-
-- Fixed: `selector-nest-combinators` rule throwing an error when using nested props.
-
-# 3.9.3
-
-- Fixed: `map-keys-quotes` warning for unquoted numeric keys.
-
-# 3.9.2
-
-- Fixed: `selector-no-union-class-name` throwing an error when using nested `@`-rules.
-
-# 3.9.1
-
-- Fixed: `selector-no-union-class-name` false positives for id, attribute, and pseudo selectors.
-
-# 3.9.0
-
-- Added: `selector-no-union-class-name` rule.
-- Added: `function-color-relative` rule.
-- Added: `comment-no-loud` rule.
-- Added: `map-keys-quotes` rule.
-- Fixed: typo in error message for `at-else-empty-line-before` and `dollar-variable-empty-line-before` rules.
-
-# 3.8.0
-
-- Added: `function-unquote-no-unquoted-strings-inside` rule.
-- Fixed: wrong message name for `at-each-key-value-single-line` rule.
-
-# 3.7.0
-
-- Added: `at-each-key-value-single-line` rule.
-- Added: `function-quote-no-quoted-strings-inside` rule.
-
-# 3.6.1
-
-- Fixed: `double-slash-comment-empty-line-before` autofix not working in certain situations.
-
-# 3.6.0
-
-- Added: support for stylelint version 10.
-
-# 3.5.4
-
-- Fixed: `dollar-variable-colon-newline-after` no longer warns for multiline variables that use `!default`.
-
-# 3.5.3
-
-- Fixed: `operator-no-unspaced` no longer warns for valid absolute urls and urls with interpolation.
-
-# 3.5.2
-
-- Fixed: handle SCSS interpolation in `selector-nest-combinators` rule.
-
-# 3.5.1
-
-- Fixed: error messages for `selector-nest-combinators` rule.
-
-# 3.5.0
-
-- Added: `selector-nest-combinators` rule.
-
-# 3.4.4
-
-- Updated: `postcss-selector-parser` dependency to 5.0.0 (major version bump) with a memory leak fix and other bug fixes.
-
-# 3.4.3
-
-- Fixed: `double-slash-comment-whitespace-inside` fix error being thrown when using two backslashes inside a string.
-
-# 3.4.2
-
-- Fixed: `operator-no-unspaced` no longer warns for relative url paths.
-
-# 3.4.1
-
-- Fixed: `at-function-named-arguments` was not correctly handling functions inside Sass maps.
-
-# 3.4.0
-
-- Added: `at-mixin-argumentless-call-parentheses` autofix (#280).
-- Fixed: `partial-no-import` correctly handle import parameters with urls (#283).
-
-# 3.3.2
-
-- Fixed: Account for hyphens in function names (`at-function-parentheses-space-before`) and mixin (`at-mixin-parentheses-space-before`) names.
-
-# 3.3.1
-
-- Fixed: `at-function-named-arguments` correctly parse function arguments with trailing commas.
-
-# 3.3.0
-
-- Added: `at-function-named-arguments` add `ignoreFunctions` option.
-- Fixed: `at-function-named-arguments` correctly parse data uris as function parameters.
-
-# 3.2.0
-
-- Added: `no-dollar-variables` rule.
-- Added: `ignoreInside` and `ignoreInsideAtRules` options to `no-duplicate-dollar-variables` rule.
-- Fixed: `operator-no-unspaced` no longer warns for `unicode-range` property.
-
-# 3.1.3
-
-- Fixed: compatibility with non css syntaxes for `operator-no-newline-after` and `operator-no-newline-before` rules.
-
-# 3.1.2
-
-- Fixed: compatibility with non css syntaxes.
-
-# 3.1.1
-
-- Fixed: `operator-no-newline-before` and `operator-no-unspaced` rules were throwing an error when using CSS custom properties.
-
-# 3.1.0
-
-- Added: `no-duplicate-dollar-variables` rule.
-
-# 3.0.1
-
-- Fixed: `at-function-named-arguments` now ignores Sass maps.
-
-# 3.0.0
-
-- Removed: Node.JS 4.x support. Node.js 6.x or greater is now required (#213).
-- Added: `at-else-empty-line-before` autofix (#221).
-- Added: `at-else-if-parentheses-space-before` autofix (#222).
-- Added: `at-function-parentheses-space-before` autofix (#223).
-- Added: `at-mixin-parentheses-space-before` autofix (#224).
-- Added: `dollar-variable-empty-line-before` autofix (#226).
-- Added: `dollar-variable-colon-space-after` autofix (#227).
-- Added: `dollar-variable-colon-space-before` autofix (#227).
-- Added: `at-else-closing-brace-space-after` autofix (#228).
-- Added: `at-if-else-closing-brace-space-after` autofix (#228).
-- Added: `at-else-closing-brace-newline-after` autofix (#229).
-- Added: `at-if-closing-brace-newline-after` autofix (#229).
-- Added: `double-slash-comment-empty-line-before` autofix (#230).
-- Added: `dollar-variable-colon-newline-after` autofix (#231).
-
-# 2.5.0
-
-- Added: `at-least-one-space` option to `dollar-variable-colon-space-after` rule.
-- Fixed: `dollar-variable-colon-newline-after` now does not require a newline for Sass maps and multiline variables with parentheses when `always-multi-line` option is used.
-
-# 2.4.0
-
-- Added: support for stylelint version 9.
-- Fixed: `dollar-variable-colon-newline-after` now allows multiline variables when `always` option is used.
-
-# 2.3.0
-
-- Added: `dollar-variable-default` rule.
-
-# 2.2.0
-
-- Added: `at-function-named-arguments` rule.
-- Added: `at-mixin-named-arguments` rule.
-
-# 2.1.0
-
-- Added: `at-else-if-parentheses-space-before` rule.
-- Added: `at-function-parentheses-space-before` rule.
-- Added: `at-mixin-parentheses-space-before` rule.
-
-# 2.0.1
-
-- Fixed: `selector-no-redundant-nesting-selector` now handles multiple nested selectors.
-
-# 2.0.0
-
-This version updates stylelint to version 8 and removes 2 rules that were deprecated in earlier versions.
-
-- Breaking changes:
- - Updated: stylelint dependency from version 7 to version 8.
- - Changed: stylelint is now listed in `peerDependencies` instead of `dependencies`. This means that you need to have `stylelint` installed in your project before using `stylelint-scss`.
- - Changed: white/blacklists and ignore\* options to be case sensitive by default. See https://github.com/stylelint/stylelint/pull/2709
- - Removed: 2 deprecated rules
- - `at-import-no-partial-extension`
- - `at-mixin-no-argumentless-call-parentheses`
-
-# 1.5.2
-
-- Fixed: `operator-no-unspaced` support escaped operators by handling them in `sassValueParser`.
-- Fixed: `declaration-nested-properties` support escaped selectors by checking for escaped characters in `parseNestedPropRoot`.
-
-# 1.5.1
-
-- Fixed: `at-rule-no-unknown` add missing export to `ruleName`.
-- Fixed: `at-rule-no-unknown` add options validation.
-
-# 1.5.0
-
-- Added: `at-rule-no-unknown` rule.
-
-# 1.4.4
-
-- Fixed: `at-if-closing-brace-newline-after`: support `@elseif`.
-
-# 1.4.3
-
-- Fixed: `at-mixin-no-argumentless-call-parentheses` messages
-
-# 1.4.2:
-
-- Fixed: false positives in inline comment detecting by `findCommentsInRaws` if a comment is the first/last in a file/line
-- Fixed: `findCommentsInRaws` error in function detection
-
-# 1.4.1
-
-- Fixed: mixed import names for `at-else-closing-brace-space-after` and `at-else-empty-line-before` rules.
-- Fixed: false positives for nested props rules (`:not()`-like selectors, strings, numbers).
-
-# 1.4.0
-
-- Added: `at-else-closing-brace-newline-after` rule.
-- Added: `at-else-closing-brace-space-after` rule.
-- Added: `at-if-closing-brace-newline-after` rule.
-- Added: `at-if-closing-brace-space-after` rule.
-- Added: `at-else-empty-line-before` rule.
-- Added: `declaration-nested-properties` rule.
-- Added: `declaration-nested-properties-no-divided-groups` rule.
-- Added: `dollar-variable-empty-line-before` rule.
-- Added: `ignore: "local"|"global"` to the `dollar-variable-pattern` rule.
-- Added: `docs` folder to `npm` package.
-- Removed: `src` folder from `npm` package.
-- Removed: NodeJS 0.12.x support, stylelint-scss now requires NodeJS > 4.2.1 LTS or greater
-
-# 1.3.4
-
-- Fixed: parsing `-` and `+` at the operation start in `operator-` rules.
-- Fixed: `findCommentsInRaws` false positives on comments inside strings (applicable to rules `double-slash-comment-inline`, `double-slash-comment-whitespace-inside`, `operator-no-unspaced`).
-
-# 1.3.3
-
-- Fixed: parsing `%` character by `operator-` rules.
-- Fixed: false positives on `operator-` rules.
-
-# 1.3.2
-
-- Fixed: `findCommentsInRaws` fail on parsing selectors like `p:not(.not-p)` (applicable to rules `double-slash-comment-inline`, `double-slash-comment-whitespace-inside`, `operator-no-unspaced`).
-- Fixed: 'double-slash-comment-whitespace-inside' false positives on empty comments (e.g. `//`).
-- Fixed: `findCommentsInRaws` giving wrong column number (applicable to rules `double-slash-comment-inline`, `double-slash-comment-whitespace-inside`, `operator-no-unspaced`).
-
-# 1.3.1
-
-- Fixed: `findCommentsInRaws` for multiline CSS comments and text for //-comments (`double-slash-comment-` rules and `operator-no-unspaced` rule).
-
-# 1.3.0
-
-- Added: `at-mixin-argumentless-call-parentheses` rule (with "always"/"never" behavior as a replacement for `at-mixin-no-argumentless-call-parentheses`).
-- Added: `dollar-variable-colon-newline-after` rule.
-- Added: `dollar-variable-colon-space-after` rule.
-- Added: `dollar-variable-colon-space-before` rule.
-- Added: `double-slash-comment-empty-line-before` rule.
-- Added: `double-slash-comment-inline` rule.
-- Added: `double-slash-comment-whitespace-inside` rule.
-- Added: `operator-no-newline-after` rule.
-- Added: `operator-no-newline-before` rule.
-- Added: `operator-no-unspaced` rule.
-- Deprecated: `at-mixin-no-argumentless-call-parentheses`.
-- Fixed: `partial-no-import` failing when linting a code string (not in an actual file, e.g. via stylelilnt Node API).
-- Updated stylelint dependency to version 7.
-
-# 1.2.1
-
-- Fixed: `at-function-pattern`, `at-mixin-pattern` failing if there are parens inside a parameters list.
-
-# 1.2.0
-
-- Added: `partial-no-import` rule.
-- Added: `media-feature-value-dollar-variable` rule.
-- Added: `at-import-partial-extension-blacklist` rule.
-- Added: `at-import-partial-extension-whitelist` rule.
-- Deprecated: `at-import-no-partial-extension` rule.
-- Fixed: `dollar-variable-no-missing-interpolation` was throwing an error on older Node.js versions.
-
-# 1.1.1
-
-- Fixed: newlines inside braces in `at-function-pattern`, `at-mixin-pattern`.
-- Fixed: false positives and false negatives in `selector-no-redundant-nesting-selector`.
-
-# 1.1.0
-
-- Added: `at-mixin-no-argumentless-call-parentheses` rule.
-- Added: `at-import-no-partial-leading-underscore` rule.
-- Added: `at-import-no-partial-extension` rule.
-- Added: `percent-placeholder-pattern` rule.
-- Fixed: `selector-no-redundant-nesting-selector` no longer warns about BEM syntax.
-- Fixed: bug causing rules to ignore severity levels `warning` / `error` and report `ignore` instead.
-
-# 1.0.0
-
-- Added: `at-extend-no-missing-placeholder` rule.
-- Added: `at-function-pattern` rule.
-- Added: `at-mixin-pattern` rule.
-- Added: `dollar-variable-no-missing-interpolation` rule.
-- Added: `dollar-variable-pattern` rule.
-- Added: `selector-no-redundant-nesting-selector` rule.
diff --git a/assets/node_modules/stylelint-scss/LICENSE b/assets/node_modules/stylelint-scss/LICENSE
deleted file mode 100644
index 9f82c82..0000000
--- a/assets/node_modules/stylelint-scss/LICENSE
+++ /dev/null
@@ -1,21 +0,0 @@
-The MIT License (MIT)
-
-Copyright (c) 2016 Krister Kari
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is
-furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in all
-copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
-SOFTWARE.
diff --git a/assets/node_modules/stylelint-scss/README.md b/assets/node_modules/stylelint-scss/README.md
deleted file mode 100644
index a5c643c..0000000
--- a/assets/node_modules/stylelint-scss/README.md
+++ /dev/null
@@ -1,299 +0,0 @@
-# stylelint-scss
-
-[![NPM version](https://img.shields.io/npm/v/stylelint-scss.svg)](https://www.npmjs.com/package/stylelint-scss)
-[![Build Status](https://github.com/kristerkari/stylelint-scss/workflows/Tests/badge.svg)](https://github.com/kristerkari/stylelint-scss/actions?workflow=Tests)
-[![Coverage Status](https://img.shields.io/coveralls/github/kristerkari/stylelint-scss/master.svg)](https://coveralls.io/github/kristerkari/stylelint-scss?branch=master)
-[![contributions welcome](https://img.shields.io/badge/contributions-welcome-brightgreen.svg?style=flat)](https://egghead.io/courses/how-to-contribute-to-an-open-source-project-on-github)
-[![Downloads per month](https://img.shields.io/npm/dm/stylelint-scss.svg)](https://npmcharts.com/compare/stylelint-scss)
-
-A collection of SCSS specific linting rules for [stylelint](https://github.com/stylelint/stylelint) (in a form of a plugin).
-
-## Purpose
-
-stylelint by itself supports [SCSS syntax](https://stylelint.io/user-guide/css-processors#parsing-non-standard-syntax) very well (as well as other preprocessors' syntaxes). Moreover, it introduces some specific rules that can be used to lint SCSS, e.g. to limit [`nesting`](https://stylelint.io/user-guide/rules/max-nesting-depth), control the way [`@-rules`](https://stylelint.io/user-guide/rules#at-rule) are written. Yet stylelint is in general focused on standard CSS.
-
-stylelint-scss introduces rules specific to SCSS syntax. That said, the rules from this plugin can be used with other syntaxes, like Less or some PostCSS syntaxes. That's why the rules' names are not tied to SCSS only (`at-function-pattern` instead of `scss-function-pattern`).
-
-The plugin follows stylelint's guidelines (about [rule names](https://stylelint.io/user-guide/about-rules), testing and [so on](https://github.com/stylelint/stylelint/tree/master/docs/developer-guide)).
-
-## Installation and usage
-
-stylelint-scss is a plugin for [stylelint](https://stylelint.io/user-guide), so it's meant to be used with it.
-
-First, install stylelint-scss (and stylelint, if you haven't done so yet) via NPM:
-
-```
-npm install stylelint stylelint-scss
-```
-
-Create the `.stylelintrc.json` config file (or open the existing one), add `stylelint-scss` to the plugins array and the rules you need to the rules list. All rules from stylelint-scss need to be namespaced with `scss`.
-
-```json
-{
- "plugins": [
- "stylelint-scss"
- ],
- "rules": {
- "scss/dollar-variable-pattern": "^foo",
- "scss/selector-no-redundant-nesting-selector": true,
- ...
- }
-}
-```
-
-Please refer to [stylelint docs](https://stylelint.io/user-guide) for the detailed info on using this linter.
-
-## List of rules
-
-Here are stylelint-scss' rules, grouped by the [_thing_](http://apps.workflower.fi/vocabs/css/en) they apply to (just like in [stylelint](https://stylelint.io/user-guide/about-rules)).
-
-Please also see the [example configs](./docs/examples/) for special cases.
-
-### `@`-each
-
-- [`at-each-key-value-single-line`](./src/rules/at-each-key-value-single-line/README.md): This is a rule that checks for situations where users have done a loop using map-keys and grabbed the value for that key inside of the loop.
-
-### `@`-else
-
-- [`at-else-closing-brace-newline-after`](./src/rules/at-else-closing-brace-newline-after/README.md): Require or disallow a newline after the closing brace of `@else` statements (Autofixable).
-- [`at-else-closing-brace-space-after`](./src/rules/at-else-closing-brace-space-after/README.md): Require a single space or disallow whitespace after the closing brace of `@else` statements (Autofixable).
-- [`at-else-empty-line-before`](./src/rules/at-else-empty-line-before/README.md): Require an empty line or disallow empty lines before `@`-else (Autofixable).
-- [`at-else-if-parentheses-space-before`](./src/rules/at-else-if-parentheses-space-before/README.md): Require or disallow a space before `@else if` parentheses (Autofixable).
-
-### `@`-extend
-
-- [`at-extend-no-missing-placeholder`](./src/rules/at-extend-no-missing-placeholder/README.md): Disallow at-extends (`@extend`) with missing placeholders.
-
-### `@`-function
-
-- [`at-function-named-arguments`](./src/rules/at-function-named-arguments/README.md): Require named parameters in SCSS function call rule.
-- [`at-function-parentheses-space-before`](./src/rules/at-function-parentheses-space-before/README.md): Require or disallow a space before `@function` parentheses (Autofixable).
-- [`at-function-pattern`](./src/rules/at-function-pattern/README.md): Specify a pattern for Sass/SCSS-like function names.
-
-### `@`-if
-
-- [`at-if-closing-brace-newline-after`](./src/rules/at-if-closing-brace-newline-after/README.md): Require or disallow a newline after the closing brace of `@if` statements (Autofixable).
-- [`at-if-closing-brace-space-after`](./src/rules/at-if-closing-brace-space-after/README.md): Require a single space or disallow whitespace after the closing brace of `@if` statements (Autofixable).
-- [`at-if-no-null`](./src/rules/at-if-no-null/README.md): Disallow `null` in `@if` statements.
-
-### `@`-import
-
-- [`at-import-no-partial-leading-underscore`](./src/rules/at-import-no-partial-leading-underscore/README.md): Disallow leading underscore in partial names in `@import`.
-- [`at-import-partial-extension`](./src/rules/at-import-partial-extension/README.md): Require or disallow extension in `@import` commands.
-- [`at-import-partial-extension-blacklist`](./src/rules/at-import-partial-extension-blacklist/README.md): Specify blacklist of disallowed file extensions for partial names in `@import` commands.
-- [`at-import-partial-extension-whitelist`](./src/rules/at-import-partial-extension-whitelist/README.md): Specify whitelist of allowed file extensions for partial names in `@import` commands.
-
-### `@`-mixin
-
-- [`at-mixin-argumentless-call-parentheses`](./src/rules/at-mixin-argumentless-call-parentheses/README.md): Require or disallow parentheses in argumentless `@mixin` calls (Autofixable).
-- [`at-mixin-named-arguments`](./src/rules/at-mixin-named-arguments/README.md): Require named parameters in at-mixin call rule.
-- [`at-mixin-parentheses-space-before`](./src/rules/at-mixin-parentheses-space-before/README.md): Require or disallow a space before `@mixin` parentheses (Autofixable).
-- [`at-mixin-pattern`](./src/rules/at-mixin-pattern/README.md): Specify a pattern for Sass/SCSS-like mixin names.
-
-### `@`-rule
-
-- [`at-rule-conditional-no-parentheses`](./src/rules/at-rule-conditional-no-parentheses/README.md): Disallow parentheses in conditional @ rules (if, elsif, while).
-- [`at-rule-no-unknown`](./src/rules/at-rule-no-unknown/README.md): Disallow unknown at-rules. Should be used **instead of** stylelint's [at-rule-no-unknown](https://stylelint.io/user-guide/rules/at-rule-no-unknown).
-
-### `$`-variable
-
-- [`dollar-variable-colon-newline-after`](./src/rules/dollar-variable-colon-newline-after/README.md): Require a newline after the colon in `$`-variable declarations (Autofixable).
-- [`dollar-variable-colon-space-after`](./src/rules/dollar-variable-colon-space-after/README.md): Require or disallow whitespace after the colon in `$`-variable declarations (Autofixable).
-- [`dollar-variable-colon-space-before`](./src/rules/dollar-variable-colon-space-before/README.md): Require a single space or disallow whitespace before the colon in `$`-variable declarations (Autofixable).
-- [`dollar-variable-default`](./src/rules/dollar-variable-default/README.md): Require `!default` flag for `$`-variable declarations.
-- [`dollar-variable-empty-line-before`](./src/rules/dollar-variable-empty-line-before/README.md): Require a single empty line or disallow empty lines before `$`-variable declarations (Autofixable).
-- [`dollar-variable-no-missing-interpolation`](./src/rules/dollar-variable-no-missing-interpolation/README.md): Disallow Sass variables that are used without interpolation with CSS features that use custom identifiers.
-- [`dollar-variable-pattern`](./src/rules/dollar-variable-pattern/README.md): Specify a pattern for Sass-like variables.
-
-### `%`-placeholder
-
-- [`percent-placeholder-pattern`](./src/rules/percent-placeholder-pattern/README.md): Specify a pattern for `%`-placeholders.
-
-### `//`-comment
-
-- [`double-slash-comment-empty-line-before`](./src/rules/double-slash-comment-empty-line-before/README.md): Require or disallow an empty line before `//`-comments (Autofixable).
-- [`double-slash-comment-inline`](./src/rules/double-slash-comment-inline/README.md): Require or disallow `//`-comments to be inline comments.
-- [`double-slash-comment-whitespace-inside`](./src/rules/double-slash-comment-whitespace-inside/README.md): Require or disallow whitespace after the `//` in `//`-comments
-
-### Comment
-
-- [`comment-no-loud`](./src/rules/comment-no-loud/README.md): Disallow `/*`-comments.
-
-### Declaration
-
-- [`declaration-nested-properties`](./src/rules/declaration-nested-properties/README.md): Require or disallow properties with `-` in their names to be in a form of a nested group.
-- [`declaration-nested-properties-no-divided-groups`](./src/rules/declaration-nested-properties-no-divided-groups/README.md): Disallow nested properties of the same "namespace" be divided into multiple groups.
-
-### Dimension
-
-- [`dimension-no-non-numeric-values`](./src/rules/dimension-no-non-numeric-values/README.md): Disallow non-numeric values when interpolating a value with a unit.
-
-### Function
-
-- [`function-color-relative`](./src/rules/function-color-relative/README.md): Encourage the use of the [scale-color](https://sass-lang.com/documentation/modules/color#scale-color) function over regular color functions.
-- [`function-quote-no-quoted-strings-inside`](./src/rules/function-quote-no-quoted-strings-inside/README.md): Disallow quoted strings inside the [quote function](https://sass-lang.com/documentation/modules/string#quote) (Autofixable).
-- [`function-unquote-no-unquoted-strings-inside`](./src/rules/function-unquote-no-unquoted-strings-inside/README.md): Disallow unquoted strings inside the [unquote function](https://sass-lang.com/documentation/modules/string#unquote) (Autofixable).
-
-### Map
-
-- [`map-keys-quotes`](./src/rules/map-keys-quotes/README.md): Require quoted keys in Sass maps.
-
-### Media feature
-
-- [`media-feature-value-dollar-variable`](./src/rules/media-feature-value-dollar-variable/README.md): Require a media feature value be a `$`-variable or disallow `$`-variables in media feature values.
-
-### Operator
-
-- [`operator-no-newline-after`](./src/rules/operator-no-newline-after/README.md): Disallow linebreaks after Sass operators.
-- [`operator-no-newline-before`](./src/rules/operator-no-newline-before/README.md): Disallow linebreaks before Sass operators.
-- [`operator-no-unspaced`](./src/rules/operator-no-unspaced/README.md): Disallow unspaced operators in Sass operations.
-
-### Partial
-
-- [`partial-no-import`](./src/rules/partial-no-import/README.md): Disallow non-CSS `@import`s in partial files.
-
-### Selector
-
-- [`selector-nest-combinators`](./src/rules/selector-nest-combinators/README.md): Require or disallow nesting of combinators in selectors.
-- [`selector-no-redundant-nesting-selector`](./src/rules/selector-no-redundant-nesting-selector/README.md): Disallow redundant nesting selectors (`&`).
-- [`selector-no-union-class-name`](./src/rules/selector-no-union-class-name/README.md): Disallow union class names with the parent selector (`&`).
-
-### General / Sheet
-
-- [`no-dollar-variables`](./src/rules/no-dollar-variables/README.md): Disallow dollar variables within a stylesheet.
-- [`no-duplicate-dollar-variables`](./src/rules/no-duplicate-dollar-variables/README.md): Disallow duplicate dollar variables within a stylesheet.
-- [`no-duplicate-mixins`](./src/rules/no-duplicate-mixins/README.md): Disallow duplicate mixins within a stylesheet.
-
-## Help out
-
-There work on the plugin's rules is still in progress, so if you feel like it, you're welcome to help out in any of these (the plugin follows stylelint guidelines so most part of this is based on its docs):
-
-- Create, enhance, and debug rules (see stylelint's guide to "[Working on rules](https://github.com/stylelint/stylelint/blob/master/docs/developer-guide/rules.md)").
-- Improve documentation.
-- Chime in on any open issue or pull request.
-- Open new issues about your ideas on new rules, or for how to improve the existing ones, and pull requests to show us how your idea works.
-- Add new tests to absolutely anything.
-- Work on improving performance of rules.
-- Contribute to [stylelint](https://github.com/stylelint/stylelint)
-- Spread the word.
-
-We communicate via [issues](https://github.com/kristerkari/stylelint-scss/issues) and [pull requests](https://github.com/kristerkari/stylelint-scss/pulls).
-
-There is also [stackoverflow](https://stackoverflow.com/questions/tagged/stylelint), which would be the preferred QA forum.
-
-## Contributors
-
-Thanks goes to these wonderful people:
-
-<table>
-<thead>
-<tr>
-<th style="text-align:center"><a href="https://github.com/kristerkari"><img alt="kristerkari" src="https://avatars0.githubusercontent.com/u/993108?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/dryoma"><img alt="dryoma" src="https://avatars2.githubusercontent.com/u/11942776?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/rambleraptor"><img alt="rambleraptor" src="https://avatars1.githubusercontent.com/u/1325798?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/XhmikosR"><img alt="XhmikosR" src="https://avatars2.githubusercontent.com/u/349621?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/pipopotamasu"><img alt="pipopotamasu" src="https://avatars0.githubusercontent.com/u/14048211?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/evilebottnawi"><img alt="evilebottnawi" src="https://avatars3.githubusercontent.com/u/4567934?v=4&s=80" width="80"></a></th>
-</tr>
-</thead>
-<tbody>
-<tr>
-<td style="text-align:center"><a href="https://github.com/kristerkari">kristerkari</a></td>
-<td style="text-align:center"><a href="https://github.com/dryoma">dryoma</a></td>
-<td style="text-align:center"><a href="https://github.com/rambleraptor">rambleraptor</a></td>
-<td style="text-align:center"><a href="https://github.com/XhmikosR">XhmikosR</a></td>
-<td style="text-align:center"><a href="https://github.com/pipopotamasu">pipopotamasu</a></td>
-<td style="text-align:center"><a href="https://github.com/evilebottnawi">evilebottnawi</a></td>
-</tr>
-</tbody>
-</table>
-<table>
-<thead>
-<tr>
-<th style="text-align:center"><a href="https://github.com/OriR"><img alt="OriR" src="https://avatars3.githubusercontent.com/u/2384068?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/ntwb"><img alt="ntwb" src="https://avatars2.githubusercontent.com/u/1016458?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/ricardogobbosouza"><img alt="ricardogobbosouza" src="https://avatars3.githubusercontent.com/u/13064722?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/bjankord"><img alt="bjankord" src="https://avatars1.githubusercontent.com/u/633148?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/thibaudcolas"><img alt="thibaudcolas" src="https://avatars1.githubusercontent.com/u/877585?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/AndyOGo"><img alt="AndyOGo" src="https://avatars1.githubusercontent.com/u/914443?v=4&s=80" width="80"></a></th>
-</tr>
-</thead>
-<tbody>
-<tr>
-<td style="text-align:center"><a href="https://github.com/OriR">OriR</a></td>
-<td style="text-align:center"><a href="https://github.com/ntwb">ntwb</a></td>
-<td style="text-align:center"><a href="https://github.com/ricardogobbosouza">ricardogobbosouza</a></td>
-<td style="text-align:center"><a href="https://github.com/bjankord">bjankord</a></td>
-<td style="text-align:center"><a href="https://github.com/thibaudcolas">thibaudcolas</a></td>
-<td style="text-align:center"><a href="https://github.com/AndyOGo">AndyOGo</a></td>
-</tr>
-</tbody>
-</table>
-<table>
-<thead>
-<tr>
-<th style="text-align:center"><a href="https://github.com/niksy"><img alt="niksy" src="https://avatars3.githubusercontent.com/u/389286?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/lxsymington"><img alt="lxsymington" src="https://avatars3.githubusercontent.com/u/15095115?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/vseventer"><img alt="vseventer" src="https://avatars2.githubusercontent.com/u/638323?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/Deimos"><img alt="Deimos" src="https://avatars0.githubusercontent.com/u/9033?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/diego-codes"><img alt="diego-codes" src="https://avatars0.githubusercontent.com/u/5973294?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/jantimon"><img alt="jantimon" src="https://avatars2.githubusercontent.com/u/4113649?v=4&s=80" width="80"></a></th>
-</tr>
-</thead>
-<tbody>
-<tr>
-<td style="text-align:center"><a href="https://github.com/niksy">niksy</a></td>
-<td style="text-align:center"><a href="https://github.com/lxsymington">lxsymington</a></td>
-<td style="text-align:center"><a href="https://github.com/vseventer">vseventer</a></td>
-<td style="text-align:center"><a href="https://github.com/Deimos">Deimos</a></td>
-<td style="text-align:center"><a href="https://github.com/diego-codes">diego-codes</a></td>
-<td style="text-align:center"><a href="https://github.com/jantimon">jantimon</a></td>
-</tr>
-</tbody>
-</table>
-<table>
-<thead>
-<tr>
-<th style="text-align:center"><a href="https://github.com/stormwarning"><img alt="stormwarning" src="https://avatars1.githubusercontent.com/u/999825?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/keegan-lillo"><img alt="keegan-lillo" src="https://avatars0.githubusercontent.com/u/3537963?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/manovotny"><img alt="manovotny" src="https://avatars2.githubusercontent.com/u/446260?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/paulgv"><img alt="paulgv" src="https://avatars0.githubusercontent.com/u/4895885?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/sajadtorkamani"><img alt="sajadtorkamani" src="https://avatars1.githubusercontent.com/u/9380313?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/srawlins"><img alt="srawlins" src="https://avatars3.githubusercontent.com/u/103167?v=4&s=80" width="80"></a></th>
-</tr>
-</thead>
-<tbody>
-<tr>
-<td style="text-align:center"><a href="https://github.com/stormwarning">stormwarning</a></td>
-<td style="text-align:center"><a href="https://github.com/keegan-lillo">keegan-lillo</a></td>
-<td style="text-align:center"><a href="https://github.com/manovotny">manovotny</a></td>
-<td style="text-align:center"><a href="https://github.com/paulgv">paulgv</a></td>
-<td style="text-align:center"><a href="https://github.com/sajadtorkamani">sajadtorkamani</a></td>
-<td style="text-align:center"><a href="https://github.com/srawlins">srawlins</a></td>
-</tr>
-</tbody>
-</table>
-<table>
-<thead>
-<tr>
-<th style="text-align:center"><a href="https://github.com/YozhikM"><img alt="YozhikM" src="https://avatars0.githubusercontent.com/u/27273025?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/YodaDaCoda"><img alt="YodaDaCoda" src="https://avatars0.githubusercontent.com/u/365349?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/freezy-sk"><img alt="freezy-sk" src="https://avatars0.githubusercontent.com/u/661637?v=4&s=80" width="80"></a></th>
-<th style="text-align:center"><a href="https://github.com/jeddy3"><img alt="jeddy3" src="https://avatars0.githubusercontent.com/u/808227?v=4&s=80" width="80"></a></th>
-</tr>
-</thead>
-<tbody>
-<tr>
-<td style="text-align:center"><a href="https://github.com/YozhikM">YozhikM</a></td>
-<td style="text-align:center"><a href="https://github.com/YodaDaCoda">YodaDaCoda</a></td>
-<td style="text-align:center"><a href="https://github.com/freezy-sk">freezy-sk</a></td>
-<td style="text-align:center"><a href="https://github.com/jeddy3">jeddy3</a></td>
-</tr>
-</tbody>
-</table>
-
-## Important documents
-
-- [Changelog](./CHANGELOG.md)
-- [Contributing](./CONTRIBUTING.md)
-- [License](./LICENSE)
diff --git a/assets/node_modules/stylelint-scss/dist/index.js b/assets/node_modules/stylelint-scss/dist/index.js
deleted file mode 100644
index f1bc0cc..0000000
--- a/assets/node_modules/stylelint-scss/dist/index.js
+++ /dev/null
@@ -1,20 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("./utils");
-
-var _rules = _interopRequireDefault(require("./rules"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var rulesPlugins = Object.keys(_rules["default"]).map(function (ruleName) {
- return (0, _stylelint.createPlugin)((0, _utils.namespace)(ruleName), _rules["default"][ruleName]);
-});
-var _default = rulesPlugins;
-exports["default"] = _default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-each-key-value-single-line/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-each-key-value-single-line/index.js
deleted file mode 100644
index 60c232c..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-each-key-value-single-line/index.js
+++ /dev/null
@@ -1,109 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("at-each-key-value-single-line");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Use @each $key, $value in $map syntax instead of $value: map-get($map, $key)"
-});
-
-exports.messages = messages;
-
-function _default(primary) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: primary
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkAtRules("each", function (rule) {
- var parts = separateEachParams(rule.params); // If loop is fetching both key + value, return
-
- if (parts[0].length === 2) {
- return;
- } // If didn't call map-keys, return.
-
-
- if (!didCallMapKeys(parts[1])) {
- return;
- } // Loop over decls inside of each statement and loop for variable assignments.
-
-
- rule.walkDecls(function (innerDecl) {
- // Check that this decl is a map-get call
- if (innerDecl.prop[0] !== "$") {
- return;
- }
-
- if (!didCallMapGet(innerDecl.value)) {
- return;
- } // Check map_name + key_name match.
-
-
- var map_get_parts = mapGetParameters(innerDecl.value); // Check map names match.
-
- if (map_get_parts[0] !== mapName(parts[1])) {
- return;
- } // Match key names match.
-
-
- if (map_get_parts[1] !== parts[0][0]) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.expected,
- node: rule,
- result: result,
- ruleName: ruleName
- });
- });
- });
- };
-} // Takes in a param string from node.params
-// Returns: [[key variable, value variable], map_decl] (all Strings)
-
-
-function separateEachParams(paramString) {
- var parts = paramString.split("in");
- return [parts[0].split(",").map(function (s) {
- return s.trim();
- }), parts[1].trim()];
-}
-
-function didCallMapKeys(map_decl) {
- return map_decl.match(/map-keys\(.*\)/);
-}
-
-function didCallMapGet(map_decl) {
- return map_decl.match(/map-get\((.*),(.*)\)/);
-} // Fetch the name of the map from a map-keys() call.
-
-
-function mapName(map_decl) {
- if (didCallMapKeys(map_decl)) {
- return map_decl.match(/map-keys\((.*)\)/)[1];
- } else {
- return map_decl;
- }
-} // Returns the parameters of a map-get call
-// Returns [map variable, key_variable]
-
-
-function mapGetParameters(mapGetDecl) {
- var parts = mapGetDecl.match(/map-get\((.*), ?(.*)\)/);
- return [parts[1], parts[2]];
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-else-closing-brace-newline-after/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-else-closing-brace-newline-after/index.js
deleted file mode 100644
index 42c05fe..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-else-closing-brace-newline-after/index.js
+++ /dev/null
@@ -1,55 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var _lodash = require("lodash");
-
-var _atIfClosingBraceNewlineAfter = require("../at-if-closing-brace-newline-after");
-
-var ruleName = (0, _utils.namespace)("at-else-closing-brace-newline-after");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: 'Expected newline after "}" of @else statement',
- rejected: 'Unexpected newline after "}" of @else statement'
-});
-
-exports.messages = messages;
-
-function _default(expectation, options, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always-last-in-chain"]
- }, {
- actual: options,
- possible: {
- disableFix: _lodash.isBoolean
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- (0, _atIfClosingBraceNewlineAfter.sassConditionalBraceNLAfterChecker)({
- root: root,
- result: result,
- ruleName: ruleName,
- atRuleName: "else",
- expectation: expectation,
- messages: messages,
- context: context,
- options: options
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-else-closing-brace-space-after/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-else-closing-brace-space-after/index.js
deleted file mode 100644
index 2506992..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-else-closing-brace-space-after/index.js
+++ /dev/null
@@ -1,46 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var _atIfClosingBraceSpaceAfter = require("../at-if-closing-brace-space-after");
-
-var ruleName = (0, _utils.namespace)("at-else-closing-brace-space-after");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: 'Expected single space after "}" of @else statement',
- rejected: 'Unexpected space after "}" of @else statement'
-});
-
-exports.messages = messages;
-
-function _default(expectation, _, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always-intermediate", "never-intermediate"]
- });
-
- if (!validOptions) {
- return;
- }
-
- (0, _atIfClosingBraceSpaceAfter.sassConditionalBraceSpaceAfterChecker)({
- root: root,
- result: result,
- ruleName: ruleName,
- atRuleName: "else",
- expectation: expectation,
- messages: messages,
- context: context
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-else-empty-line-before/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-else-empty-line-before/index.js
deleted file mode 100644
index 875cfd4..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-else-empty-line-before/index.js
+++ /dev/null
@@ -1,57 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var ruleName = (0, _utils.namespace)("at-else-empty-line-before");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: "Unexpected empty line before @else"
-});
-
-exports.messages = messages;
-
-function _default(expectation, _, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["never"]
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkAtRules(function (atrule) {
- if (atrule.name !== "else") {
- return;
- } // Don't need to ignore "the first rule in a stylesheet", etc, cases
- // because @else should always go after @if
-
-
- if (!(0, _utils.hasEmptyLine)(atrule.raws.before)) {
- return;
- }
-
- if (context.fix) {
- atrule.raws.before = " ";
- return;
- }
-
- _stylelint.utils.report({
- message: messages.rejected,
- node: atrule,
- result: result,
- ruleName: ruleName
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-else-if-parentheses-space-before/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-else-if-parentheses-space-before/index.js
deleted file mode 100644
index e085765..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-else-if-parentheses-space-before/index.js
+++ /dev/null
@@ -1,65 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("at-else-if-parentheses-space-before");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejectedBefore: function rejectedBefore() {
- return "Unexpected whitespace before parentheses in else-if declaration";
- },
- expectedBefore: function expectedBefore() {
- return "Expected a single space before parentheses in else-if declaration";
- }
-});
-
-exports.messages = messages;
-
-function _default(value, _, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: value,
- possible: ["always", "never"]
- });
-
- if (!validOptions) {
- return;
- }
-
- var match = /^if\s*?\(/;
- var replacement = value === "always" ? "if (" : "if(";
- var checker = (0, _utils.whitespaceChecker)("space", value, messages).before;
- root.walkAtRules("else", function (decl) {
- // return early if the else-if statement is not surrounded by parentheses
- if (!match.test(decl.params)) {
- return;
- }
-
- if (context.fix) {
- decl.params = decl.params.replace(match, replacement);
- }
-
- checker({
- source: decl.params,
- index: decl.params.indexOf("("),
- err: function err(message) {
- return _stylelint.utils.report({
- message: message,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- }
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-extend-no-missing-placeholder/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-extend-no-missing-placeholder/index.js
deleted file mode 100644
index ca6d679..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-extend-no-missing-placeholder/index.js
+++ /dev/null
@@ -1,46 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("at-extend-no-missing-placeholder");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: "Expected a placeholder selector (e.g. %placeholder) to be used in @extend"
-});
-
-exports.messages = messages;
-
-function _default(actual) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: actual
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkAtRules("extend", function (atrule) {
- var isPlaceholder = atrule.params.trim()[0] === "%";
- var isInterpolation = /^#{.+}/.test(atrule.params.trim());
-
- if (!isPlaceholder && !isInterpolation) {
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- node: atrule,
- message: messages.rejected
- });
- }
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-function-named-arguments/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-function-named-arguments/index.js
deleted file mode 100644
index 49053f5..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-function-named-arguments/index.js
+++ /dev/null
@@ -1,115 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _lodash = require("lodash");
-
-var _postcssValueParser = _interopRequireDefault(require("postcss-value-parser"));
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("at-function-named-arguments");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected a named parameter to be used in function call",
- rejected: "Unexpected a named parameter in function call"
-});
-
-exports.messages = messages;
-var isScssVarRegExp = /^\$\S*/;
-
-function _default(expectation, options) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- }, {
- actual: options,
- possible: {
- ignore: ["single-argument"],
- ignoreFunctions: [_lodash.isString]
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- var shouldIgnoreSingleArgument = (0, _utils.optionsHaveIgnored)(options, "single-argument");
- root.walkDecls(function (decl) {
- (0, _postcssValueParser["default"])(decl.value).walk(function (node) {
- if (node.type !== "function" || (0, _utils.isNativeCssFunction)(node.value) || node.value === "") {
- return;
- }
-
- var hasFuncIgnored = options && options.ignoreFunctions && options.ignoreFunctions.some(function (f) {
- var isRegex = /^\/.*\//.test(f);
-
- if (!isRegex) {
- return f === node.value;
- }
-
- var parts = f.split("/");
- return new RegExp(parts[1], parts[2] || "").test(node.value);
- });
-
- if (hasFuncIgnored) {
- return;
- }
-
- var args = (0, _utils.parseFunctionArguments)(_postcssValueParser["default"].stringify(node));
- var isSingleArgument = args.length === 1;
-
- if (isSingleArgument && shouldIgnoreSingleArgument) {
- return;
- }
-
- args.forEach(function (arg) {
- switch (expectation) {
- case "never":
- {
- if (!arg.key) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.rejected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
-
- break;
- }
-
- case "always":
- {
- if (arg.key && isScssVarRegExp.test(arg.key)) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.expected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
-
- break;
- }
- }
- });
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-function-parentheses-space-before/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-function-parentheses-space-before/index.js
deleted file mode 100644
index 4b9d750..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-function-parentheses-space-before/index.js
+++ /dev/null
@@ -1,61 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("at-function-parentheses-space-before");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejectedBefore: function rejectedBefore() {
- return "Unexpected whitespace before parentheses in function declaration";
- },
- expectedBefore: function expectedBefore() {
- return "Expected a single space before parentheses in function declaration";
- }
-});
-
-exports.messages = messages;
-
-function _default(value, _, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: value,
- possible: ["always", "never"]
- });
-
- if (!validOptions) {
- return;
- }
-
- var match = /^([\w-]+)\s*?\(/;
- var replacement = value === "always" ? "$1 (" : "$1(";
- var checker = (0, _utils.whitespaceChecker)("space", value, messages).before;
- root.walkAtRules("function", function (decl) {
- if (context.fix) {
- decl.params = decl.params.replace(match, replacement);
- return;
- }
-
- checker({
- source: decl.params,
- index: decl.params.indexOf("("),
- err: function err(message) {
- return _stylelint.utils.report({
- message: message,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- }
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-function-pattern/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-function-pattern/index.js
deleted file mode 100644
index e922680..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-function-pattern/index.js
+++ /dev/null
@@ -1,56 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _lodash = require("lodash");
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("at-function-pattern");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected @function name to match specified pattern"
-});
-
-exports.messages = messages;
-
-function _default(pattern) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: pattern,
- possible: [_lodash.isRegExp, _lodash.isString]
- });
-
- if (!validOptions) {
- return;
- }
-
- var regexpPattern = (0, _lodash.isString)(pattern) ? new RegExp(pattern) : pattern;
- root.walkAtRules(function (decl) {
- if (decl.name !== "function") {
- return;
- } // Stripping the function of its arguments
-
-
- var funcName = decl.params.replace(/(\s*?)\((?:\s|\S)*\)/g, "");
-
- if (regexpPattern.test(funcName)) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.expected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-if-closing-brace-newline-after/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-if-closing-brace-newline-after/index.js
deleted file mode 100644
index 767eabf..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-if-closing-brace-newline-after/index.js
+++ /dev/null
@@ -1,124 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.sassConditionalBraceNLAfterChecker = sassConditionalBraceNLAfterChecker;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var _lodash = require("lodash");
-
-var ruleName = (0, _utils.namespace)("at-if-closing-brace-newline-after");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: 'Expected newline after "}" of @if statement',
- rejected: 'Unexpected newline after "}" of @if statement'
-});
-
-exports.messages = messages;
-
-function _default(expectation, options, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always-last-in-chain"]
- }, {
- actual: options,
- possible: {
- disableFix: _lodash.isBoolean
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- sassConditionalBraceNLAfterChecker({
- root: root,
- result: result,
- ruleName: ruleName,
- atRuleName: "if",
- expectation: expectation,
- messages: messages,
- context: context,
- options: options
- });
- };
-}
-/**
- * The core logic for this rule. Can be imported by other rules with similar
- * logic, namely at-else-closing-brace-newline-after
- *
- * @param {Object} args -- Named arguments object
- * @param {PostCSS root} args.root
- * @param {PostCSS result} args.result
- * @param {String ruleName} args.ruleName - needed for `report` function
- * @param {String} args.atRuleName - the name of the at-rule to be checked, e.g. "if", "else"
- * @param {Object} args.messages - returned by stylelint.utils.ruleMessages
- * @return {undefined}
- */
-
-
-function sassConditionalBraceNLAfterChecker(_ref) {
- var root = _ref.root,
- result = _ref.result,
- ruleName = _ref.ruleName,
- atRuleName = _ref.atRuleName,
- expectation = _ref.expectation,
- messages = _ref.messages,
- context = _ref.context,
- options = _ref.options;
- var shouldFix = context.fix && (!options || options.disableFix !== true);
-
- function complain(node, message, index, fixValue) {
- if (shouldFix) {
- node.next().raws.before = fixValue;
- return;
- }
-
- _stylelint.utils.report({
- result: result,
- ruleName: ruleName,
- node: node,
- message: message,
- index: index
- });
- }
-
- root.walkAtRules(function (atrule) {
- // Do nothing if it's not an @if
- if (atrule.name !== atRuleName) {
- return;
- }
-
- var nextNode = atrule.next();
-
- if (!nextNode) {
- return;
- }
-
- var nextBefore = nextNode.raws.before;
- var hasNewLinesBeforeNext = nextBefore && !(0, _utils.isSingleLineString)(nextBefore);
- var reportIndex = atrule.toString().length;
-
- if (expectation === "always-last-in-chain") {
- // If followed by @else, no newline is needed
- if (nextNode.type === "atrule" && (nextNode.name === "else" || nextNode.name === "elseif")) {
- if (hasNewLinesBeforeNext) {
- complain(atrule, messages.rejected, reportIndex, " ");
- }
- } else {
- if (!hasNewLinesBeforeNext) {
- complain(atrule, messages.expected, reportIndex, context.newline);
- }
- }
- }
- });
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-if-closing-brace-space-after/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-if-closing-brace-space-after/index.js
deleted file mode 100644
index 4950e1b..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-if-closing-brace-space-after/index.js
+++ /dev/null
@@ -1,105 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.sassConditionalBraceSpaceAfterChecker = sassConditionalBraceSpaceAfterChecker;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var ruleName = (0, _utils.namespace)("at-if-closing-brace-space-after");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: 'Expected single space after "}" of @if statement',
- rejected: 'Unexpected space after "}" of @if statement'
-});
-
-exports.messages = messages;
-
-function _default(expectation, _, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always-intermediate", "never-intermediate"]
- });
-
- if (!validOptions) {
- return;
- }
-
- sassConditionalBraceSpaceAfterChecker({
- root: root,
- result: result,
- ruleName: ruleName,
- atRuleName: "if",
- expectation: expectation,
- messages: messages,
- context: context
- });
- };
-}
-/**
- * The core logic for this rule. Can be imported by other rules with similar
- * logic, namely at-else-closing-brace-space-after
- *
- * @param {Object} args -- Named arguments object
- * @param {PostCSS root} args.root
- * @param {PostCSS result} args.result
- * @param {String ruleName} args.ruleName - needed for `report` function
- * @param {String} args.atRuleName - the name of the at-rule to be checked, e.g. "if", "else"
- * @param {Object} args.messages - returned by stylelint.utils.ruleMessages
- * @return {undefined}
- */
-
-
-function sassConditionalBraceSpaceAfterChecker(_ref) {
- var root = _ref.root,
- result = _ref.result,
- ruleName = _ref.ruleName,
- atRuleName = _ref.atRuleName,
- expectation = _ref.expectation,
- messages = _ref.messages,
- context = _ref.context;
-
- function complain(node, message, index, fixValue) {
- if (context.fix) {
- node.next().raws.before = fixValue;
- return;
- }
-
- _stylelint.utils.report({
- result: result,
- ruleName: ruleName,
- node: node,
- message: message,
- index: index
- });
- }
-
- root.walkAtRules(function (atrule) {
- // Do nothing if it's not an @if
- if (atrule.name !== atRuleName) {
- return;
- }
-
- var nextNode = atrule.next();
- var hasSpaceAfter = nextNode && nextNode.raws.before === " ";
- var hasWhiteSpaceAfter = nextNode && nextNode.raws.before !== "";
- var reportIndex = atrule.toString().length; // When followed by an @else
-
- if (nextNode && nextNode.type === "atrule" && nextNode.name === "else") {
- // A single space is needed
- if (expectation === "always-intermediate" && !hasSpaceAfter) {
- complain(atrule, messages.expected, reportIndex, " ");
- } else if (expectation === "never-intermediate" && hasWhiteSpaceAfter) {
- // No whitespace is needed
- complain(atrule, messages.rejected, reportIndex, "");
- }
- }
- });
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-if-no-null/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-if-no-null/index.js
deleted file mode 100644
index 95e4933..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-if-no-null/index.js
+++ /dev/null
@@ -1,61 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var ruleName = (0, _utils.namespace)("at-if-no-null");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- equals_null: "Expected @if not statement rather than @if statement == null",
- not_equals_null: "Expected @if statement rather than @if statement != null"
-});
-
-exports.messages = messages;
-
-function _default(expectation) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkAtRules(function (atrule) {
- // Do nothing if it's not an @if
- if (atrule.name !== "if") {
- return;
- } // If rule != null and (expr), skip
-
-
- if (atrule.params.match(/\(?[ \t]*.* != null and .*\)?/)) {
- return;
- }
-
- if (atrule.params.match(/\(?[ \t]*.* == null[ \t]*\)?/)) {
- _stylelint.utils.report({
- message: messages.equals_null,
- node: atrule,
- result: result,
- ruleName: ruleName
- });
- } else if (atrule.params.match(/\(?[ \t]*.* != null[ \t]*\)?/)) {
- _stylelint.utils.report({
- message: messages.not_equals_null,
- node: atrule,
- result: result,
- ruleName: ruleName
- });
- }
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-import-no-partial-leading-underscore/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-import-no-partial-leading-underscore/index.js
deleted file mode 100644
index cdc82a7..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-import-no-partial-leading-underscore/index.js
+++ /dev/null
@@ -1,60 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("at-import-no-partial-leading-underscore");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Unexpected leading underscore in imported partial name"
-});
-
-exports.messages = messages;
-
-function _default(actual) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: actual
- });
-
- if (!validOptions) {
- return;
- }
-
- function checkPathForUnderscore(path, decl) {
- // Stripping trailing quotes and whitespaces, if any
- var pathStripped = path.replace(/^\s*?("|')\s*/, "").replace(/\s*("|')\s*?$/, ""); // Searching a _ at the start of filename
-
- if (pathStripped.search(/(?:^|\/|\\)_[^/]+$/) === -1) {
- return;
- } // Skipping importing CSS: url(), ".css", URI with a protocol, media
-
-
- if (pathStripped.slice(0, 4) === "url(" || pathStripped.slice(-4) === ".css" || pathStripped.search("//") !== -1 || pathStripped.search(/(?:\s|[,)"'])\w+$/) !== -1) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.expected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- }
-
- root.walkAtRules("import", function (decl) {
- // Processing comma-separated lists of import paths
- decl.params.split(",").forEach(function (path) {
- checkPathForUnderscore(path, decl);
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension-blacklist/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension-blacklist/index.js
deleted file mode 100644
index 80ea0f8..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension-blacklist/index.js
+++ /dev/null
@@ -1,80 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _lodash = require("lodash");
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var _path = _interopRequireDefault(require("path"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("at-import-partial-extension-blacklist");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: function rejected(ext) {
- return "Unexpected extension \".".concat(ext, "\" in imported partial name");
- }
-});
-
-exports.messages = messages;
-
-function _default(blacklistOption) {
- var blacklist = [].concat(blacklistOption);
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: blacklistOption,
- possible: [_lodash.isString, _lodash.isRegExp]
- });
-
- if (!validOptions) {
- return;
- }
-
- function checkPathForUnderscore(path, decl) {
- // Stripping trailing quotes and whitespaces, if any
- var pathStripped = path.replace(/^\s*?("|')\s*/, "").replace(/\s*("|')\s*?$/, "");
-
- var extension = _path["default"].extname(pathStripped).slice(1); // Save this separately to be able to pass the original string to report()
-
-
- var extensionNormalized = extension.toLowerCase(); // If the extension is empty
-
- if (!extension) {
- return;
- } // Skipping importing CSS: url(), ".css", URI with a protocol, media
-
-
- if (pathStripped.slice(0, 4) === "url(" || pathStripped.slice(-4) === ".css" || pathStripped.search("//") !== -1 || pathStripped.search(/(?:\s|[,)"'])\w+$/) !== -1) {
- return;
- }
-
- blacklist.forEach(function (ext) {
- if ((0, _lodash.isString)(ext) && extensionNormalized === ext || (0, _lodash.isRegExp)(ext) && extensionNormalized.search(ext) !== -1) {
- _stylelint.utils.report({
- message: messages.rejected(extension),
- node: decl,
- word: extension,
- result: result,
- ruleName: ruleName
- });
- }
- });
- }
-
- root.walkAtRules("import", function (atRule) {
- // Processing comma-separated lists of import paths
- atRule.params.split(",").forEach(function (path) {
- checkPathForUnderscore(path, atRule);
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension-whitelist/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension-whitelist/index.js
deleted file mode 100644
index e725f2c..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension-whitelist/index.js
+++ /dev/null
@@ -1,82 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _lodash = require("lodash");
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var _path = _interopRequireDefault(require("path"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("at-import-partial-extension-whitelist");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: function rejected(ext) {
- return "Unexpected extension \".".concat(ext, "\" in imported partial name");
- }
-});
-
-exports.messages = messages;
-
-function _default(whitelistOption) {
- var whitelist = [].concat(whitelistOption);
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: whitelistOption,
- possible: [_lodash.isString, _lodash.isRegExp]
- });
-
- if (!validOptions) {
- return;
- }
-
- function checkPathForUnderscore(path, decl) {
- // Stripping trailing quotes and whitespaces, if any
- var pathStripped = path.replace(/^\s*?("|')\s*/, "").replace(/\s*("|')\s*?$/, "");
-
- var extension = _path["default"].extname(pathStripped).slice(1); // Save this separately to be able to pass the original string to report()
-
-
- var extensionNormalized = extension.toLowerCase(); // If the extension is empty
-
- if (!extension) {
- return;
- } // Skipping importing CSS: url(), ".css", URI with a protocol, media
-
-
- if (pathStripped.slice(0, 4) === "url(" || pathStripped.slice(-4) === ".css" || pathStripped.search("//") !== -1 || pathStripped.search(/(?:\s|[,)"'])\w+$/) !== -1) {
- return;
- }
-
- if (whitelist.some(function (ext) {
- return (0, _lodash.isString)(ext) && extensionNormalized === ext || (0, _lodash.isRegExp)(ext) && extensionNormalized.search(ext) !== -1;
- })) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.rejected(extension),
- node: decl,
- word: extension,
- result: result,
- ruleName: ruleName
- });
- }
-
- root.walkAtRules("import", function (atRule) {
- // Processing comma-separated lists of import paths
- atRule.params.split(",").forEach(function (path) {
- checkPathForUnderscore(path, atRule);
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension/index.js
deleted file mode 100644
index 9d86967..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-import-partial-extension/index.js
+++ /dev/null
@@ -1,85 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _path = _interopRequireDefault(require("path"));
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("at-import-partial-extension");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected @import to have an extension",
- rejected: function rejected(ext) {
- return "Unexpected extension \".".concat(ext, "\" in @import");
- }
-}); // https://drafts.csswg.org/mediaqueries/#media-types
-
-
-exports.messages = messages;
-var mediaQueryTypes = ["all", "print", "screen", "speech", "tv", "tty", "projection", "handheld", "braille", "embossed", "aural"];
-var mediaQueryTypesRE = new RegExp("(".concat(mediaQueryTypes.join("|"), ")$"), "i");
-
-var stripPath = function stripPath(path) {
- return path.replace(/^\s*?("|')\s*/, "").replace(/\s*("|')\s*?$/, "");
-};
-
-function _default(expectation) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkAtRules("import", function (decl) {
- var paths = decl.params.split(/["']\s*,/).filter(function (path) {
- return !mediaQueryTypesRE.test(path.trim());
- }); // Processing comma-separated lists of import paths
-
- paths.forEach(function (path) {
- // Stripping trailing quotes and whitespaces, if any
- var pathStripped = stripPath(path); // Skipping importing CSS: url(), ".css", URI with a protocol
-
- if (pathStripped.slice(0, 4) === "url(" || pathStripped.slice(-4) === ".css" || pathStripped.search("//") !== -1) {
- return;
- }
-
- var extension = _path["default"].extname(pathStripped).slice(1);
-
- if (!extension && expectation === "always") {
- _stylelint.utils.report({
- message: messages.expected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
-
- return;
- }
-
- if (extension && expectation === "never") {
- _stylelint.utils.report({
- message: messages.rejected(extension),
- node: decl,
- word: extension,
- result: result,
- ruleName: ruleName
- });
- }
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-mixin-argumentless-call-parentheses/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-mixin-argumentless-call-parentheses/index.js
deleted file mode 100644
index 58ffbf0..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-mixin-argumentless-call-parentheses/index.js
+++ /dev/null
@@ -1,69 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("at-mixin-argumentless-call-parentheses");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: function expected(mixin) {
- return "Expected parentheses in mixin \"".concat(mixin, "\" call");
- },
- rejected: function rejected(mixin) {
- return "Unexpected parentheses in argumentless mixin \"".concat(mixin, "\" call");
- }
-});
-
-exports.messages = messages;
-
-function _default(value, _, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: value,
- possible: ["always", "never"]
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkAtRules("include", function (mixinCall) {
- // If it is "No parens in argumentless calls"
- if (value === "never" && mixinCall.params.search(/\(\s*?\)\s*?$/) === -1) {
- return;
- } // If it is "Always use parens"
-
-
- if (value === "always" && mixinCall.params.search(/\(/) !== -1) {
- return;
- }
-
- if (context.fix) {
- if (value === "always") {
- mixinCall.params = "".concat(mixinCall.params, " ()");
- } else {
- mixinCall.params = mixinCall.params.replace(/\s*\([\s\S]*?\)$/, "");
- }
-
- return;
- }
-
- var mixinName = /\s*(\S*?)\s*(?:\(|$)/.exec(mixinCall.params)[1];
-
- _stylelint.utils.report({
- message: messages[value === "never" ? "rejected" : "expected"](mixinName),
- node: mixinCall,
- result: result,
- ruleName: ruleName
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-mixin-named-arguments/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-mixin-named-arguments/index.js
deleted file mode 100644
index 4ba96e5..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-mixin-named-arguments/index.js
+++ /dev/null
@@ -1,118 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }
-
-function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); }
-
-function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); }
-
-function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }
-
-var ruleName = (0, _utils.namespace)("at-mixin-named-arguments");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected a named parameter to be used in at-include call",
- rejected: "Unexpected a named parameter in at-include call"
-});
-
-exports.messages = messages;
-var hasArgumentsRegExp = /\((.*)\)$/;
-var isScssVarRegExp = /^\$\S*/;
-
-function _default(expectation, options) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- }, {
- actual: options,
- possible: {
- ignore: ["single-argument"]
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- var shouldIgnoreSingleArgument = (0, _utils.optionsHaveIgnored)(options, "single-argument");
- root.walkAtRules("include", function (atRule) {
- var argsString = atRule.params.replace(/\n/g, " ").match(hasArgumentsRegExp); // Ignore @include that does not contain arguments.
-
- if (!argsString || argsString.index === -1 || argsString[0].length === 2) {
- return;
- }
-
- var args = argsString[1] // Create array of arguments.
- .split(",") // Create a key-value array for every argument.
- .map(function (argsString) {
- return argsString.split(":").map(function (argsKeyValuePair) {
- return argsKeyValuePair.trim();
- });
- }).reduce(function (resultArray, keyValuePair) {
- var pair = {
- value: keyValuePair[1] || keyValuePair[0]
- };
-
- if (keyValuePair[1]) {
- pair.key = keyValuePair[0];
- }
-
- return [].concat(_toConsumableArray(resultArray), [pair]);
- }, []);
- var isSingleArgument = args.length === 1;
-
- if (isSingleArgument && shouldIgnoreSingleArgument) {
- return;
- }
-
- args.forEach(function (arg) {
- switch (expectation) {
- case "never":
- {
- if (!arg.key) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.rejected,
- node: atRule,
- result: result,
- ruleName: ruleName
- });
-
- break;
- }
-
- case "always":
- {
- if (arg.key && isScssVarRegExp.test(arg.key)) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.expected,
- node: atRule,
- result: result,
- ruleName: ruleName
- });
-
- break;
- }
- }
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-mixin-parentheses-space-before/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-mixin-parentheses-space-before/index.js
deleted file mode 100644
index bc29a60..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-mixin-parentheses-space-before/index.js
+++ /dev/null
@@ -1,61 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("at-mixin-parentheses-space-before");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejectedBefore: function rejectedBefore() {
- return "Unexpected whitespace before parentheses in mixin declaration";
- },
- expectedBefore: function expectedBefore() {
- return "Expected a single space before parentheses in mixin declaration";
- }
-});
-
-exports.messages = messages;
-
-function _default(value, _, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: value,
- possible: ["always", "never"]
- });
-
- if (!validOptions) {
- return;
- }
-
- var match = /^([\w-]+)\s*?\(/;
- var replacement = value === "always" ? "$1 (" : "$1(";
- var checker = (0, _utils.whitespaceChecker)("space", value, messages).before;
- root.walkAtRules("mixin", function (decl) {
- if (context.fix) {
- decl.params = decl.params.replace(match, replacement);
- return;
- }
-
- checker({
- source: decl.params,
- index: decl.params.indexOf("("),
- err: function err(message) {
- return _stylelint.utils.report({
- message: message,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- }
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-mixin-pattern/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-mixin-pattern/index.js
deleted file mode 100644
index c5fe357..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-mixin-pattern/index.js
+++ /dev/null
@@ -1,56 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _lodash = require("lodash");
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("at-mixin-pattern");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected @mixin name to match specified pattern"
-});
-
-exports.messages = messages;
-
-function _default(pattern) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: pattern,
- possible: [_lodash.isRegExp, _lodash.isString]
- });
-
- if (!validOptions) {
- return;
- }
-
- var regexpPattern = (0, _lodash.isString)(pattern) ? new RegExp(pattern) : pattern;
- root.walkAtRules(function (decl) {
- if (decl.name !== "mixin") {
- return;
- } // Stripping the mixin of its arguments
-
-
- var mixinName = decl.params.replace(/(\s*?)\((?:\s|\S)*\)/g, "");
-
- if (regexpPattern.test(mixinName)) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.expected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-rule-conditional-no-parentheses/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-rule-conditional-no-parentheses/index.js
deleted file mode 100644
index 95e7728..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-rule-conditional-no-parentheses/index.js
+++ /dev/null
@@ -1,86 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread(); }
-
-function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance"); }
-
-function _iterableToArray(iter) { if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); }
-
-function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } }
-
-var ruleName = (0, _utils.namespace)("at-rule-conditional-no-parentheses");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: "Unexpected () used to surround statements for @-rules"
-}); // postcss picks up else-if as else.
-
-
-exports.messages = messages;
-var conditional_rules = ["if", "while", "else"];
-
-function report(atrule, result) {
- _stylelint.utils.report({
- message: messages.rejected,
- node: atrule,
- result: result,
- ruleName: ruleName
- });
-}
-
-function fix(atrule) {
- var regex = /(if)? ?\((.*)\)/; // 2 regex groups: 'if ' and cond.
-
- var groups = atrule.params.match(regex).slice(1);
- atrule.params = _toConsumableArray(new Set(groups)).join(" ");
-}
-
-function _default(primary, _unused, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: primary
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkAtRules(function (atrule) {
- // Check if this is a conditional rule.
- if (!conditional_rules.includes(atrule.name)) {
- return;
- } // Else uses a different regex
- // params are of format "`if (cond)` or `if cond`
- // instead of `(cond)` or `cond`"
-
-
- if (atrule.name === "else") {
- if (atrule.params.match(/ ?if ?\(.*\) ?$/)) {
- if (context.fix) {
- fix(atrule);
- } else {
- report(atrule, result);
- }
- }
- } else {
- if (atrule.params.trim().match(/^\(.*\)$/)) {
- if (context.fix) {
- fix(atrule);
- } else {
- report(atrule, result);
- }
- }
- }
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/at-rule-no-unknown/index.js b/assets/node_modules/stylelint-scss/dist/rules/at-rule-no-unknown/index.js
deleted file mode 100644
index 9a833c1..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/at-rule-no-unknown/index.js
+++ /dev/null
@@ -1,67 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _lodash = require("lodash");
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var sassAtRules = ["at-root", "content", "debug", "each", "else", "else if", "error", "extend", "for", "forward", "function", "if", "import", "include", "media", "mixin", "return", "use", "warn", "while"];
-var ruleToCheckAgainst = "at-rule-no-unknown";
-var ruleName = (0, _utils.namespace)(ruleToCheckAgainst);
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: _stylelint.rules[ruleToCheckAgainst].messages.rejected
-});
-
-exports.messages = messages;
-
-function _default(primaryOption, secondaryOptions) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: primaryOption
- }, {
- actual: secondaryOptions,
- possible: {
- ignoreAtRules: [_lodash.isRegExp, _lodash.isString]
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- var optionsAtRules = secondaryOptions && secondaryOptions.ignoreAtRules;
- var ignoreAtRules = sassAtRules.concat(optionsAtRules || []);
- var defaultedOptions = Object.assign({}, secondaryOptions, {
- ignoreAtRules: ignoreAtRules
- });
-
- _stylelint.utils.checkAgainstRule({
- ruleName: ruleToCheckAgainst,
- ruleSettings: [primaryOption, defaultedOptions],
- root: root
- }, function (warning) {
- var name = warning.node.name;
-
- if (!ignoreAtRules.includes(name)) {
- _stylelint.utils.report({
- message: messages.rejected("@".concat(name)),
- ruleName: ruleName,
- result: result,
- node: warning.node,
- line: warning.line,
- column: warning.column
- });
- }
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/comment-no-loud/index.js b/assets/node_modules/stylelint-scss/dist/rules/comment-no-loud/index.js
deleted file mode 100644
index c2bec06..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/comment-no-loud/index.js
+++ /dev/null
@@ -1,50 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("comment-no-loud");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected // for comments instead of /*"
-});
-
-exports.messages = messages;
-
-function rule(primary) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: primary
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkComments(function (comment) {
- if (isLoudComment(comment)) {
- _stylelint.utils.report({
- message: messages.expected,
- node: comment,
- result: result,
- ruleName: ruleName
- });
- }
- });
- };
-}
-
-function isLoudComment(comment) {
- var regex = new RegExp(/^[ \t\n]*\/\*/);
- return regex.test(comment.source.input.css);
-}
-
-var _default = rule;
-exports["default"] = _default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/declaration-nested-properties-no-divided-groups/index.js b/assets/node_modules/stylelint-scss/dist/rules/declaration-nested-properties-no-divided-groups/index.js
deleted file mode 100644
index 680335d..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/declaration-nested-properties-no-divided-groups/index.js
+++ /dev/null
@@ -1,76 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var hasOwnProp = Object.prototype.hasOwnProperty;
-var ruleName = (0, _utils.namespace)("declaration-nested-properties-no-divided-groups");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: function expected(prop) {
- return "Expected all nested properties of \"".concat(prop, "\" namespace to be in one nested group");
- }
-});
-
-exports.messages = messages;
-
-function _default(expectation) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walk(function (item) {
- if (item.type !== "rule" && item.type !== "atrule") {
- return;
- }
-
- var nestedGroups = {}; // Find all nested property groups
-
- item.each(function (decl) {
- if (decl.type !== "rule") {
- return;
- }
-
- var testForProp = (0, _utils.parseNestedPropRoot)(decl.selector);
-
- if (testForProp && testForProp.propName !== undefined) {
- var ns = testForProp.propName.value;
-
- if (!hasOwnProp.call(nestedGroups, ns)) {
- nestedGroups[ns] = [];
- }
-
- nestedGroups[ns].push(decl);
- }
- });
- Object.keys(nestedGroups).forEach(function (namespace) {
- // Only warn if there are more than one nested groups with equal namespaces
- if (nestedGroups[namespace].length === 1) {
- return;
- }
-
- nestedGroups[namespace].forEach(function (group) {
- _stylelint.utils.report({
- message: messages.expected(namespace),
- node: group,
- result: result,
- ruleName: ruleName
- });
- });
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/declaration-nested-properties/index.js b/assets/node_modules/stylelint-scss/dist/rules/declaration-nested-properties/index.js
deleted file mode 100644
index efe8c48..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/declaration-nested-properties/index.js
+++ /dev/null
@@ -1,154 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var hasOwnProp = Object.prototype.hasOwnProperty;
-var ruleName = (0, _utils.namespace)("declaration-nested-properties");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: function expected(prop) {
- return "Expected property \"".concat(prop, "\" to be in a nested form");
- },
- rejected: function rejected(prop) {
- return "Unexpected nested property \"".concat(prop, "\"");
- }
-});
-
-exports.messages = messages;
-
-function _default(expectation, options) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- }, {
- actual: options,
- possible: {
- except: ["only-of-namespace"]
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- if (expectation === "always") {
- root.walk(function (item) {
- if (item.type !== "rule" && item.type !== "atrule") {
- return;
- }
-
- var warningCandidates = {};
- item.each(function (decl) {
- var prop = decl.prop,
- type = decl.type,
- selector = decl.selector; // Looking for namespaced non-nested properties
- // Namespaced prop is basically a prop with a `-` in a name, e.g. `margin-top`
-
- if (type === "decl") {
- if (!(0, _utils.isStandardSyntaxProperty)(prop)) {
- return;
- } // Add simple namespaced prop decls to warningCandidates.ns
- // (prop names with browser prefixes are ignored)
-
-
- var seekNamespace = /^([a-zA-Z0-9]+)-/.exec(prop);
-
- if (seekNamespace && seekNamespace[1]) {
- var ns = seekNamespace[1];
-
- if (!hasOwnProp.call(warningCandidates, ns)) {
- warningCandidates[ns] = [];
- }
-
- warningCandidates[ns].push({
- node: decl
- });
- }
- } // Nested props, `prop: [value] { <nested decls> }`
-
-
- if (type === "rule") {
- // `background:red {` - selector;
- // `background: red {` - nested prop; space is decisive here
- var testForProp = (0, _utils.parseNestedPropRoot)(selector);
-
- if (testForProp && testForProp.propName !== undefined) {
- var _ns = testForProp.propName.value;
-
- if (!hasOwnProp.call(warningCandidates, _ns)) {
- warningCandidates[_ns] = [];
- }
-
- warningCandidates[_ns].push({
- node: decl,
- nested: true
- });
- }
- }
- }); // Now check if the found properties deserve warnings
-
- Object.keys(warningCandidates).forEach(function (namespace) {
- var exceptIfOnlyOfNs = (0, _utils.optionsHaveException)(options, "only-of-namespace");
- var moreThanOneProp = warningCandidates[namespace].length > 1;
- warningCandidates[namespace].forEach(function (candidate) {
- if (candidate.nested === true) {
- if (exceptIfOnlyOfNs) {
- // If there is only one prop inside a nested prop - warn (reverse "always")
- if (candidate.nested === true && candidate.node.nodes.length === 1) {
- _stylelint.utils.report({
- message: messages.rejected(namespace),
- node: candidate.node,
- result: result,
- ruleName: ruleName
- });
- }
- }
- } else {
- // Don't warn on non-nested namespaced props if there are
- // less than 2 of them, and except: "only-of-namespace" is set
- if (exceptIfOnlyOfNs && !moreThanOneProp) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.expected(candidate.node.prop),
- node: candidate.node,
- result: result,
- ruleName: ruleName
- });
- }
- });
- });
- });
- } else if (expectation === "never") {
- root.walk(function (item) {
- // Just check if there are ANY nested props
- if (item.type === "rule") {
- // `background:red {` - selector;
- // `background: red {` - nested prop; space is decisive here
- var testForProp = (0, _utils.parseNestedPropRoot)(item.selector);
-
- if (testForProp && testForProp.propName !== undefined) {
- _stylelint.utils.report({
- message: messages.rejected(testForProp.propName.value),
- result: result,
- ruleName: ruleName,
- node: item
- });
- }
- }
- });
- }
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/dimension-no-non-numeric-values/index.js b/assets/node_modules/stylelint-scss/dist/rules/dimension-no-non-numeric-values/index.js
deleted file mode 100644
index be962f9..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/dimension-no-non-numeric-values/index.js
+++ /dev/null
@@ -1,102 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = rule;
-exports.units = exports.messages = exports.ruleName = void 0;
-
-var _postcssValueParser = _interopRequireDefault(require("postcss-value-parser"));
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("dimension-no-non-numeric-values");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: function rejected(unit) {
- return "Expected \"$value * 1".concat(unit, "\" instead of \"#{$value}").concat(unit, "\". Consider writing \"value\" in terms of ").concat(unit, " originally.");
- }
-});
-
-exports.messages = messages;
-var units = [// Font-relative lengths:
-// https://www.w3.org/TR/css-values-4/#font-relative-lengths
-"em", "ex", "cap", "ch", "ic", "rem", "lh", "rlh", // Viewport-relative lengths:
-// https://www.w3.org/TR/css-values-4/#viewport-relative-lengths
-"vw", "vh", "vi", "vb", "vmin", "vmax", // Absolute lengths:
-// https://www.w3.org/TR/css-values-4/#absolute-lengths
-"cm", "mm", "Q", "in", "pc", "pt", "px", // Angle units:
-// https://www.w3.org/TR/css-values-4/#angles
-"deg", "grad", "rad", "turn", // Duration units:
-// https://www.w3.org/TR/css-values-4/#time
-"s", "ms", // Frequency units:
-// https://www.w3.org/TR/css-values-4/#frequency
-"Hz", "kHz", // Resolution units:
-// https://www.w3.org/TR/css-values-4/#resolution
-"dpi", "dpcm", "dppx", "x", // Flexible lengths:
-// https://www.w3.org/TR/css-grid-1/#fr-unit
-"fr"];
-exports.units = units;
-
-function rule(primary) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: primary
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkDecls(function (decl) {
- (0, _postcssValueParser["default"])(decl.value).walk(function (node) {
- // All words are non-quoted, while strings are quoted.
- // If quoted, it's probably a deliberate non-numeric dimension.
- if (node.type !== "word") {
- return;
- }
-
- if (!isInterpolated(node.value)) {
- return;
- }
-
- var regex = new RegExp("#{[$a-z_0-9 +-]*}(".concat(units.join("|"), ");?"));
- var matchUnit = decl.value.match(regex);
- var unit = matchUnit[1];
- var offset = decl.value.indexOf(unit);
-
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- message: messages.rejected(unit),
- index: (0, _utils.declarationValueIndex)(decl) + offset,
- node: decl
- });
- });
- });
- };
-}
-
-function isInterpolated(value) {
- var _boolean = false; // ValueParser breaks up interpolation with math into multiple, fragmented
- // segments (#{$value, +, 2}px). The easiest way to detect this is to look for a fragmented
- // interpolated section.
-
- if (value.match(/^#{\$[a-z]*$/)) {
- return true;
- }
-
- units.forEach(function (unit) {
- var regex = new RegExp("^#{[$a-z_0-9 +-]*}".concat(unit, ";?$"));
-
- if (value.match(regex)) {
- _boolean = true;
- }
- });
- return _boolean;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-newline-after/index.js b/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-newline-after/index.js
deleted file mode 100644
index 03b9a43..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-newline-after/index.js
+++ /dev/null
@@ -1,112 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _lodash = require("lodash");
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("dollar-variable-colon-newline-after");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expectedAfter: function expectedAfter() {
- return 'Expected newline after ":"';
- },
- expectedAfterMultiLine: function expectedAfterMultiLine() {
- return 'Expected newline after ":" with a multi-line value';
- }
-});
-
-exports.messages = messages;
-
-function _default(expectation, options, context) {
- var checker = (0, _utils.whitespaceChecker)("newline", expectation, messages);
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "always-multi-line"]
- }, {
- actual: options,
- possible: {
- disableFix: _lodash.isBoolean
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- var shouldFix = context.fix && (!options || options.disableFix !== true);
- root.walkDecls(function (decl) {
- if (!decl.prop || decl.prop[0] !== "$") {
- return;
- }
-
- var value = decl.value.trim();
- var startsWithParen = value[0] === "(";
- var endsWithParen = value[value.length - 1] === ")";
- var endsWithDefault = /\)\s*!default$/.test(value);
- var isMultilineVarWithParens = startsWithParen && (endsWithParen || endsWithDefault) && !(0, _utils.isSingleLineString)(value);
-
- if (isMultilineVarWithParens) {
- return;
- } // Get the raw $var, and only that
-
-
- var endOfPropIndex = (0, _utils.declarationValueIndex)(decl) + decl.raw("between").length - 1; // `$var:`, `$var :`
-
- var propPlusColon = decl.toString().slice(0, endOfPropIndex);
-
- var _loop2 = function _loop2(i, l) {
- if (propPlusColon[i] !== ":") {
- return "continue";
- }
-
- var indexToCheck = propPlusColon.substr(propPlusColon[i], 3) === "/*" ? propPlusColon.indexOf("*/", i) + 1 : i;
- checker.afterOneOnly({
- source: propPlusColon,
- index: indexToCheck,
- lineCheckStr: decl.value,
- err: function err(m) {
- if (shouldFix) {
- var nextLinePrefix = expectation === "always" ? decl.raws.before.replace(context.newline, "") : decl.value.split(context.newline)[1].replace(/^(\s+).*$/, function (_, whitespace) {
- return whitespace;
- });
- decl.raws.between = decl.raws.between.replace(/:(.*)$/, ":".concat(context.newline).concat(nextLinePrefix));
- return;
- }
-
- _stylelint.utils.report({
- message: m,
- node: decl,
- index: indexToCheck,
- result: result,
- ruleName: ruleName
- });
- }
- });
- return "break";
- };
-
- _loop: for (var i = 0, l = propPlusColon.length; i < l; i++) {
- var _ret = _loop2(i, l);
-
- switch (_ret) {
- case "continue":
- continue;
-
- case "break":
- break _loop;
- }
- }
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-space-after/index.js b/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-space-after/index.js
deleted file mode 100644
index f797589..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-space-after/index.js
+++ /dev/null
@@ -1,129 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.variableColonSpaceChecker = variableColonSpaceChecker;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var ruleName = (0, _utils.namespace)("dollar-variable-colon-space-after");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expectedAfter: function expectedAfter() {
- return 'Expected single space after ":"';
- },
- rejectedAfter: function rejectedAfter() {
- return 'Unexpected whitespace after ":"';
- },
- expectedAfterSingleLine: function expectedAfterSingleLine() {
- return 'Expected single space after ":" with a single-line value';
- },
- expectedAfterAtLeast: function expectedAfterAtLeast() {
- return 'Expected at least one space after ":"';
- }
-});
-
-exports.messages = messages;
-
-function _default(expectation, _, context) {
- var checker = (0, _utils.whitespaceChecker)("space", expectation, messages);
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never", "always-single-line", "at-least-one-space"]
- });
-
- if (!validOptions) {
- return;
- }
-
- variableColonSpaceChecker({
- root: root,
- result: result,
- locationChecker: checker.after,
- checkedRuleName: ruleName,
- position: "after",
- expectation: expectation,
- context: context
- });
- };
-}
-
-function variableColonSpaceChecker(_ref) {
- var locationChecker = _ref.locationChecker,
- root = _ref.root,
- result = _ref.result,
- checkedRuleName = _ref.checkedRuleName,
- position = _ref.position,
- expectation = _ref.expectation,
- context = _ref.context;
- root.walkDecls(function (decl) {
- if (decl.prop === undefined || decl.prop[0] !== "$") {
- return;
- }
-
- if (context && context.fix) {
- if (expectation === "always-single-line" && !(0, _utils.isSingleLineString)(decl.value)) {
- return;
- }
-
- if (position === "before") {
- var replacement = expectation === "never" ? ":" : " :";
- decl.raws.between = decl.raws.between.replace(/\s*:/, replacement);
- } else if (position === "after") {
- var match = expectation === "at-least-one-space" ? /:(?! )/ : /:\s*/;
-
- var _replacement = expectation === "never" ? ":" : ": ";
-
- decl.raws.between = decl.raws.between.replace(match, _replacement);
- }
-
- return;
- } // Get the raw $var, and only that
-
-
- var endOfPropIndex = (0, _utils.declarationValueIndex)(decl) + decl.raw("between").length - 1; // `$var:`, `$var :`
-
- var propPlusColon = decl.toString().slice(0, endOfPropIndex);
-
- var _loop2 = function _loop2(i) {
- if (propPlusColon[i] !== ":") {
- return "continue";
- }
-
- locationChecker({
- source: propPlusColon,
- index: i,
- lineCheckStr: decl.value,
- err: function err(m) {
- _stylelint.utils.report({
- message: m,
- node: decl,
- index: i,
- result: result,
- ruleName: checkedRuleName
- });
- }
- });
- return "break";
- };
-
- _loop: for (var i = 0; i < propPlusColon.length; i++) {
- var _ret = _loop2(i);
-
- switch (_ret) {
- case "continue":
- continue;
-
- case "break":
- break _loop;
- }
- }
- });
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-space-before/index.js b/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-space-before/index.js
deleted file mode 100644
index d83ed18..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-colon-space-before/index.js
+++ /dev/null
@@ -1,51 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var _dollarVariableColonSpaceAfter = require("../dollar-variable-colon-space-after");
-
-var ruleName = (0, _utils.namespace)("dollar-variable-colon-space-before");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expectedBefore: function expectedBefore() {
- return 'Expected single space before ":"';
- },
- rejectedBefore: function rejectedBefore() {
- return 'Unexpected whitespace before ":"';
- }
-});
-
-exports.messages = messages;
-
-function _default(expectation, _, context) {
- var checker = (0, _utils.whitespaceChecker)("space", expectation, messages);
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- });
-
- if (!validOptions) {
- return;
- }
-
- (0, _dollarVariableColonSpaceAfter.variableColonSpaceChecker)({
- root: root,
- result: result,
- locationChecker: checker.before,
- checkedRuleName: ruleName,
- position: "before",
- expectation: expectation,
- context: context
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-default/index.js b/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-default/index.js
deleted file mode 100644
index 4cca8b2..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-default/index.js
+++ /dev/null
@@ -1,63 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("dollar-variable-default");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: function expected(variable) {
- return "Expected !default flag for \"".concat(variable, "\"");
- }
-});
-
-exports.messages = messages;
-
-function _default(primaryOption, secondaryOptions) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: primaryOption
- }, {
- actual: secondaryOptions,
- possible: {
- ignore: ["local"]
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkDecls(function (decl) {
- // not variable
- if (decl.prop[0] !== "$") {
- return;
- } // "ignore" options
-
-
- if ((0, _utils.optionsHaveIgnored)(secondaryOptions, "local") && decl.parent.type !== "root") {
- return;
- }
-
- if (decl.value.toLowerCase().includes("!default")) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.expected(decl.prop),
- node: decl,
- result: result,
- ruleName: ruleName
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-empty-line-before/index.js b/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-empty-line-before/index.js
deleted file mode 100644
index c6ab2f3..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-empty-line-before/index.js
+++ /dev/null
@@ -1,126 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var _lodash = require("lodash");
-
-var ruleName = (0, _utils.namespace)("dollar-variable-empty-line-before");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected an empty line before $-variable",
- rejected: "Unexpected empty line before $-variable"
-});
-
-exports.messages = messages;
-
-function _default(expectation, options, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- }, {
- actual: options,
- possible: {
- except: ["first-nested", "after-comment", "after-dollar-variable"],
- ignore: ["after-comment", "inside-single-line-block"],
- disableFix: _lodash.isBoolean
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- var fix = function fix(decl, match, replace) {
- decl.raws.before = decl.raws.before.replace(new RegExp("^".concat(match)), replace);
- };
-
- var hasNewline = function hasNewline(str) {
- return str.includes(context.newline);
- };
-
- root.walkDecls(function (decl) {
- if (!isDollarVar(decl)) {
- return;
- } // Always ignore the first $var in a stylesheet
-
-
- if (decl === root.first) {
- return;
- } // If ignoring vars after comments is set
-
-
- if ((0, _utils.optionsHaveIgnored)(options, "after-comment") && decl.prev() && decl.prev().type === "comment") {
- return;
- } // If ignoring single-line blocks
-
-
- if ((0, _utils.optionsHaveIgnored)(options, "inside-single-line-block") && decl.parent.type !== "root" && (0, _utils.isSingleLineString)((0, _utils.blockString)(decl.parent))) {
- return;
- }
-
- var expectHasEmptyLineBefore = expectation === "always"; // Reverse for a variable that is a first child of its parent
-
- if ((0, _utils.optionsHaveException)(options, "first-nested") && decl === decl.parent.first) {
- expectHasEmptyLineBefore = !expectHasEmptyLineBefore;
- } // Reverse if after a comment
-
-
- if ((0, _utils.optionsHaveException)(options, "after-comment") && decl.prev() && decl.prev().type === "comment") {
- expectHasEmptyLineBefore = !expectHasEmptyLineBefore;
- } // Reverse if after another $-variable
-
-
- if ((0, _utils.optionsHaveException)(options, "after-dollar-variable") && decl.prev() && isDollarVar(decl.prev())) {
- expectHasEmptyLineBefore = !expectHasEmptyLineBefore;
- }
-
- var before = decl.raws.before;
-
- if (expectHasEmptyLineBefore === (0, _utils.hasEmptyLine)(before)) {
- return;
- }
-
- var isFixDisabled = options && options.disableFix === true;
-
- if (context.fix && !isFixDisabled) {
- if (expectHasEmptyLineBefore && !(0, _utils.hasEmptyLine)(before)) {
- fix(decl, context.newline, context.newline + context.newline);
-
- if ((0, _utils.optionsHaveException)(options, "first-nested") && !hasNewline(before)) {
- fix(decl, "\\s+", context.newline + context.newline);
- }
-
- return;
- }
-
- if (!expectHasEmptyLineBefore && (0, _utils.hasEmptyLine)(before)) {
- fix(decl, "\\n\\r\\n", "\r\n");
- fix(decl, context.newline + context.newline, context.newline);
- return;
- }
- }
-
- _stylelint.utils.report({
- message: expectHasEmptyLineBefore ? messages.expected : messages.rejected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- });
- };
-}
-
-function isDollarVar(node) {
- return node.prop && node.prop[0] === "$";
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-no-missing-interpolation/index.js b/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-no-missing-interpolation/index.js
deleted file mode 100644
index 58dd4ec..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-no-missing-interpolation/index.js
+++ /dev/null
@@ -1,146 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var _postcssValueParser = _interopRequireDefault(require("postcss-value-parser"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("dollar-variable-no-missing-interpolation");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: function rejected(n, v) {
- return "Expected variable ".concat(v, " to be interpolated when using it with ").concat(n);
- }
-}); // https://developer.mozilla.org/en/docs/Web/CSS/custom-ident#Lists_of_excluded_values
-
-
-exports.messages = messages;
-var customIdentProps = ["animation", "animation-name", "counter-reset", "counter-increment", "list-style-type", "will-change"]; // https://developer.mozilla.org/en/docs/Web/CSS/At-rule
-
-var customIdentAtRules = ["counter-style", "keyframes", "supports"];
-
-function isAtRule(type) {
- return type === "atrule";
-}
-
-function isCustomIdentAtRule(node) {
- return isAtRule(node.type) && customIdentAtRules.includes(node.name);
-}
-
-function isCustomIdentProp(node) {
- return customIdentProps.includes(node.prop);
-}
-
-function isAtSupports(node) {
- return isAtRule(node.type) && node.name === "supports";
-}
-
-function isSassVar(value) {
- return value[0] === "$";
-}
-
-function isStringVal(value) {
- return /^("|').*("|')$/.test(value);
-}
-
-function toRegex(arr) {
- return new RegExp("(".concat(arr.join("|"), ")"));
-}
-
-function _default(actual) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: actual
- });
-
- if (!validOptions) {
- return;
- }
-
- var stringVars = [];
- var vars = [];
-
- function findVars(node) {
- node.walkDecls(function (decl) {
- var prop = decl.prop,
- value = decl.value;
-
- if (!isSassVar(prop) || vars.includes(prop)) {
- return;
- }
-
- if (isStringVal(value)) {
- stringVars.push(prop);
- }
-
- vars.push(prop);
- });
- }
-
- findVars(root);
- root.walkRules(findVars);
-
- if (!vars.length) {
- return;
- }
-
- function shouldReport(node, value) {
- if (isAtSupports(node) || isCustomIdentProp(node)) {
- return stringVars.includes(value);
- }
-
- if (isCustomIdentAtRule(node)) {
- return vars.includes(value);
- }
-
- return false;
- }
-
- function report(node, value) {
- var name = node.name,
- prop = node.prop,
- type = node.type;
- var nodeName = isAtRule(type) ? "@".concat(name) : prop;
-
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- node: node,
- message: messages.rejected(nodeName, value)
- });
- }
-
- function exitEarly(node) {
- return node.type !== "word" || !node.value;
- }
-
- function walkValues(node, value) {
- (0, _postcssValueParser["default"])(value).walk(function (valNode) {
- var value = valNode.value;
-
- if (exitEarly(valNode) || !shouldReport(node, value)) {
- return;
- }
-
- report(node, value);
- });
- }
-
- root.walkDecls(toRegex(customIdentProps), function (decl) {
- walkValues(decl, decl.value);
- });
- root.walkAtRules(toRegex(customIdentAtRules), function (atRule) {
- walkValues(atRule, atRule.params);
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-pattern/index.js b/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-pattern/index.js
deleted file mode 100644
index ca6580d..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/dollar-variable-pattern/index.js
+++ /dev/null
@@ -1,66 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _lodash = require("lodash");
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("dollar-variable-pattern");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected $ variable name to match specified pattern"
-});
-
-exports.messages = messages;
-
-function _default(pattern, options) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: pattern,
- possible: [_lodash.isRegExp, _lodash.isString]
- }, {
- actual: options,
- possible: {
- ignore: ["local", "global"]
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- var regexpPattern = (0, _lodash.isString)(pattern) ? new RegExp(pattern) : pattern;
- root.walkDecls(function (decl) {
- var prop = decl.prop;
-
- if (prop[0] !== "$") {
- return;
- } // If local or global variables need to be ignored
-
-
- if ((0, _utils.optionsHaveIgnored)(options, "global") && decl.parent.type === "root" || (0, _utils.optionsHaveIgnored)(options, "local") && decl.parent.type !== "root") {
- return;
- }
-
- if (regexpPattern.test(prop.slice(1))) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.expected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-empty-line-before/index.js b/assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-empty-line-before/index.js
deleted file mode 100644
index a0a3448..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-empty-line-before/index.js
+++ /dev/null
@@ -1,107 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("double-slash-comment-empty-line-before");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected empty line before comment",
- rejected: "Unexpected empty line before comment"
-});
-
-exports.messages = messages;
-var stylelintCommandPrefix = "stylelint-";
-
-function _default(expectation, options, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- }, {
- actual: options,
- possible: {
- except: ["first-nested"],
- ignore: ["stylelint-commands", "between-comments"]
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkComments(function (comment) {
- // Only process // comments
- if (!comment.raws.inline && !comment.inline) {
- return;
- }
-
- if ((0, _utils.isInlineComment)(comment)) {
- return;
- } // Ignore the first node
-
-
- if (comment === root.first) {
- return;
- } // Optionally ignore stylelint commands
-
-
- if (comment.text.indexOf(stylelintCommandPrefix) === 0 && (0, _utils.optionsHaveIgnored)(options, "stylelint-commands")) {
- return;
- } // Optionally ignore newlines between comments
-
-
- var prev = comment.prev();
-
- if (prev && prev.type === "comment" && (0, _utils.optionsHaveIgnored)(options, "between-comments")) {
- return;
- }
-
- var before = comment.raw("before");
-
- var expectEmptyLineBefore = function () {
- if ((0, _utils.optionsHaveException)(options, "first-nested") && comment.parent !== root && comment === comment.parent.first) {
- return false;
- }
-
- return expectation === "always";
- }();
-
- var hasEmptyLineBefore = before.search(/\n\s*?\n/) !== -1; // Return if the expectation is met
-
- if (expectEmptyLineBefore === hasEmptyLineBefore) {
- return;
- }
-
- if (context.fix) {
- if (expectEmptyLineBefore && !hasEmptyLineBefore) {
- (0, _utils.addEmptyLineBefore)(comment, context.newline);
- return;
- }
-
- if (!expectEmptyLineBefore && hasEmptyLineBefore) {
- (0, _utils.removeEmptyLinesBefore)(comment, context.newline);
- return;
- }
- }
-
- var message = expectEmptyLineBefore ? messages.expected : messages.rejected;
-
- _stylelint.utils.report({
- message: message,
- node: comment,
- result: result,
- ruleName: ruleName
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-inline/index.js b/assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-inline/index.js
deleted file mode 100644
index 6a55466..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-inline/index.js
+++ /dev/null
@@ -1,83 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var ruleName = (0, _utils.namespace)("double-slash-comment-inline");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected //-comment to be inline comment",
- rejected: "Unexpected inline //-comment"
-});
-
-exports.messages = messages;
-var stylelintCommandPrefix = "stylelint-";
-
-function _default(expectation, options) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- }, {
- actual: options,
- possible: {
- ignore: ["stylelint-commands"]
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- (0, _utils.eachRoot)(root, checkRoot);
-
- function checkRoot(root) {
- var rootString = root.source.input.css;
-
- if (rootString.trim() === "") {
- return;
- }
-
- var comments = (0, _utils.findCommentsInRaws)(rootString);
- comments.forEach(function (comment) {
- // Only process // comments
- if (comment.type !== "double-slash") {
- return;
- } // Optionally ignore stylelint commands
-
-
- if (comment.text.indexOf(stylelintCommandPrefix) === 0 && (0, _utils.optionsHaveIgnored)(options, "stylelint-commands")) {
- return;
- }
-
- var isInline = comment.inlineAfter || comment.inlineBefore;
- var message;
-
- if (isInline && expectation === "never") {
- message = messages.rejected;
- } else if (!isInline && expectation === "always") {
- message = messages.expected;
- } else {
- return;
- }
-
- _stylelint.utils.report({
- message: message,
- node: root,
- index: comment.source.start,
- result: result,
- ruleName: ruleName
- });
- });
- }
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-whitespace-inside/index.js b/assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-whitespace-inside/index.js
deleted file mode 100644
index 59faf89..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/double-slash-comment-whitespace-inside/index.js
+++ /dev/null
@@ -1,76 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _utils = require("../../utils");
-
-var _stylelint = require("stylelint");
-
-var ruleName = (0, _utils.namespace)("double-slash-comment-whitespace-inside");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected a space after //",
- rejected: "Unexpected space after //"
-});
-
-exports.messages = messages;
-
-function _default(expectation) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- });
-
- if (!validOptions) {
- return;
- }
-
- (0, _utils.eachRoot)(root, checkRoot);
-
- function checkRoot(root) {
- var rootString = root.source.input.css;
-
- if (rootString.trim() === "") {
- return;
- }
-
- var comments = (0, _utils.findCommentsInRaws)(rootString);
- comments.forEach(function (comment) {
- // Only process // comments
- if (comment.type !== "double-slash") {
- return;
- } // if it's `//` - no warning whatsoever; if `// ` - then trailing
- // whitespace rule will govern this
-
-
- if (comment.text === "") {
- return;
- }
-
- var message;
-
- if (expectation === "never" && comment.raws.left !== "") {
- message = messages.rejected;
- } else if (comment.raws.left === "" && expectation === "always") {
- message = messages.expected;
- } else {
- return;
- }
-
- _stylelint.utils.report({
- message: message,
- node: root,
- index: comment.source.start + comment.raws.startToken.length,
- result: result,
- ruleName: ruleName
- });
- });
- }
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/function-color-relative/index.js b/assets/node_modules/stylelint-scss/dist/rules/function-color-relative/index.js
deleted file mode 100644
index b245a23..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/function-color-relative/index.js
+++ /dev/null
@@ -1,57 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var _postcssValueParser = _interopRequireDefault(require("postcss-value-parser"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("function-color-relative");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: "Expected the scale-color function to be used"
-});
-
-exports.messages = messages;
-var function_names = ["saturate", "desaturate", "darken", "lighten", "opacify", "fade-in", "transparentize", "fade-out"];
-
-function rule(primary) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: primary
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkDecls(function (decl) {
- (0, _postcssValueParser["default"])(decl.value).walk(function (node) {
- // Verify that we're only looking at functions.
- if (node.type !== "function" || node.value === "") {
- return;
- }
-
- if (function_names.includes(node.value)) {
- _stylelint.utils.report({
- message: messages.rejected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- }
- });
- });
- };
-}
-
-var _default = rule;
-exports["default"] = _default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/function-quote-no-quoted-strings-inside/index.js b/assets/node_modules/stylelint-scss/dist/rules/function-quote-no-quoted-strings-inside/index.js
deleted file mode 100644
index 377e121..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/function-quote-no-quoted-strings-inside/index.js
+++ /dev/null
@@ -1,79 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var _postcssValueParser = _interopRequireDefault(require("postcss-value-parser"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("function-quote-no-quoted-strings-inside");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: "Quote function used with an already-quoted string"
-});
-
-exports.messages = messages;
-
-function rule(primary, _, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: primary
- });
-
- if (!validOptions) {
- return;
- } // Setup variable naming.
-
-
- var vars = {};
- root.walkDecls(function (decl) {
- if (decl.prop[0] !== "$") {
- return;
- }
-
- (0, _postcssValueParser["default"])(decl.value).walk(function (node) {
- vars[decl.prop] = node.type;
- });
- });
- root.walkDecls(function (decl) {
- (0, _postcssValueParser["default"])(decl.value).walk(function (node) {
- // Verify that we're only looking at functions.
- if (node.type !== "function" || (0, _utils.isNativeCssFunction)(node.value) || node.value === "") {
- return;
- } // Verify we're only looking at quote() calls.
-
-
- if (node.value !== "quote") {
- return;
- } // Report error if first character is a quote.
- // postcss-value-parser represents quoted strings as type 'string' (as opposed to word)
-
-
- if (node.nodes[0].quote || vars[node.nodes[0].value] === "string") {
- if (context.fix) {
- var contents = /quote\((.*)\)/.exec(decl.value);
- decl.value = contents[1];
- } else {
- _stylelint.utils.report({
- message: messages.rejected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- }
- }
- });
- });
- };
-}
-
-var _default = rule;
-exports["default"] = _default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/function-unquote-no-unquoted-strings-inside/index.js b/assets/node_modules/stylelint-scss/dist/rules/function-unquote-no-unquoted-strings-inside/index.js
deleted file mode 100644
index 38d2ca3..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/function-unquote-no-unquoted-strings-inside/index.js
+++ /dev/null
@@ -1,79 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var _postcssValueParser = _interopRequireDefault(require("postcss-value-parser"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("function-unquote-no-unquoted-strings-inside");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: "Unquote function used with an already-unquoted string"
-});
-
-exports.messages = messages;
-
-function rule(primary, _, context) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: primary
- });
-
- if (!validOptions) {
- return;
- } // Setup variable naming.
-
-
- var vars = {};
- root.walkDecls(function (decl) {
- if (decl.prop[0] !== "$") {
- return;
- }
-
- (0, _postcssValueParser["default"])(decl.value).walk(function (node) {
- vars[decl.prop] = node.type;
- });
- });
- root.walkDecls(function (decl) {
- (0, _postcssValueParser["default"])(decl.value).walk(function (node) {
- // Verify that we're only looking at functions.
- if (node.type !== "function" || (0, _utils.isNativeCssFunction)(node.value) || node.value === "") {
- return;
- } // Verify we're only looking at quote() calls.
-
-
- if (node.value !== "unquote") {
- return;
- } // Report error if first character is a quote.
- // postcss-value-parser represents quoted strings as type 'string' (as opposed to word)
-
-
- if (!node.nodes[0].quote && node.nodes[0].value[0] !== "$" || vars[node.nodes[0].value] === "word") {
- if (context.fix) {
- var contents = /unquote\((.*)\)/.exec(decl.value);
- decl.value = contents[1];
- } else {
- _stylelint.utils.report({
- message: messages.rejected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- }
- }
- });
- });
- };
-}
-
-var _default = rule;
-exports["default"] = _default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/index.js b/assets/node_modules/stylelint-scss/dist/rules/index.js
deleted file mode 100644
index 2257614..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/index.js
+++ /dev/null
@@ -1,168 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = void 0;
-
-var _atEachKeyValueSingleLine = _interopRequireDefault(require("./at-each-key-value-single-line"));
-
-var _atElseClosingBraceNewlineAfter = _interopRequireDefault(require("./at-else-closing-brace-newline-after"));
-
-var _atElseClosingBraceSpaceAfter = _interopRequireDefault(require("./at-else-closing-brace-space-after"));
-
-var _atElseEmptyLineBefore = _interopRequireDefault(require("./at-else-empty-line-before"));
-
-var _atElseIfParenthesesSpaceBefore = _interopRequireDefault(require("./at-else-if-parentheses-space-before"));
-
-var _atExtendNoMissingPlaceholder = _interopRequireDefault(require("./at-extend-no-missing-placeholder"));
-
-var _atFunctionNamedArguments = _interopRequireDefault(require("./at-function-named-arguments"));
-
-var _atFunctionParenthesesSpaceBefore = _interopRequireDefault(require("./at-function-parentheses-space-before"));
-
-var _atFunctionPattern = _interopRequireDefault(require("./at-function-pattern"));
-
-var _atIfClosingBraceNewlineAfter = _interopRequireDefault(require("./at-if-closing-brace-newline-after"));
-
-var _atIfClosingBraceSpaceAfter = _interopRequireDefault(require("./at-if-closing-brace-space-after"));
-
-var _atIfNoNull = _interopRequireDefault(require("./at-if-no-null"));
-
-var _atImportNoPartialLeadingUnderscore = _interopRequireDefault(require("./at-import-no-partial-leading-underscore"));
-
-var _atImportPartialExtension = _interopRequireDefault(require("./at-import-partial-extension"));
-
-var _atImportPartialExtensionBlacklist = _interopRequireDefault(require("./at-import-partial-extension-blacklist"));
-
-var _atImportPartialExtensionWhitelist = _interopRequireDefault(require("./at-import-partial-extension-whitelist"));
-
-var _atMixinArgumentlessCallParentheses = _interopRequireDefault(require("./at-mixin-argumentless-call-parentheses"));
-
-var _atMixinNamedArguments = _interopRequireDefault(require("./at-mixin-named-arguments"));
-
-var _atMixinParenthesesSpaceBefore = _interopRequireDefault(require("./at-mixin-parentheses-space-before"));
-
-var _atMixinPattern = _interopRequireDefault(require("./at-mixin-pattern"));
-
-var _atRuleConditionalNoParentheses = _interopRequireDefault(require("./at-rule-conditional-no-parentheses"));
-
-var _atRuleNoUnknown = _interopRequireDefault(require("./at-rule-no-unknown"));
-
-var _commentNoLoud = _interopRequireDefault(require("./comment-no-loud"));
-
-var _declarationNestedProperties = _interopRequireDefault(require("./declaration-nested-properties"));
-
-var _declarationNestedPropertiesNoDividedGroups = _interopRequireDefault(require("./declaration-nested-properties-no-divided-groups"));
-
-var _dimensionNoNonNumericValues = _interopRequireDefault(require("./dimension-no-non-numeric-values"));
-
-var _dollarVariableColonNewlineAfter = _interopRequireDefault(require("./dollar-variable-colon-newline-after"));
-
-var _dollarVariableColonSpaceAfter = _interopRequireDefault(require("./dollar-variable-colon-space-after"));
-
-var _dollarVariableColonSpaceBefore = _interopRequireDefault(require("./dollar-variable-colon-space-before"));
-
-var _dollarVariableDefault = _interopRequireDefault(require("./dollar-variable-default"));
-
-var _dollarVariableEmptyLineBefore = _interopRequireDefault(require("./dollar-variable-empty-line-before"));
-
-var _dollarVariableNoMissingInterpolation = _interopRequireDefault(require("./dollar-variable-no-missing-interpolation"));
-
-var _dollarVariablePattern = _interopRequireDefault(require("./dollar-variable-pattern"));
-
-var _doubleSlashCommentEmptyLineBefore = _interopRequireDefault(require("./double-slash-comment-empty-line-before"));
-
-var _doubleSlashCommentInline = _interopRequireDefault(require("./double-slash-comment-inline"));
-
-var _doubleSlashCommentWhitespaceInside = _interopRequireDefault(require("./double-slash-comment-whitespace-inside"));
-
-var _functionColorRelative = _interopRequireDefault(require("./function-color-relative"));
-
-var _functionQuoteNoQuotedStringsInside = _interopRequireDefault(require("./function-quote-no-quoted-strings-inside"));
-
-var _functionUnquoteNoUnquotedStringsInside = _interopRequireDefault(require("./function-unquote-no-unquoted-strings-inside"));
-
-var _mapKeysQuotes = _interopRequireDefault(require("./map-keys-quotes"));
-
-var _mediaFeatureValueDollarVariable = _interopRequireDefault(require("./media-feature-value-dollar-variable"));
-
-var _noDollarVariables = _interopRequireDefault(require("./no-dollar-variables"));
-
-var _noDuplicateDollarVariables = _interopRequireDefault(require("./no-duplicate-dollar-variables"));
-
-var _noDuplicateMixins = _interopRequireDefault(require("./no-duplicate-mixins"));
-
-var _operatorNoNewlineAfter = _interopRequireDefault(require("./operator-no-newline-after"));
-
-var _operatorNoNewlineBefore = _interopRequireDefault(require("./operator-no-newline-before"));
-
-var _operatorNoUnspaced = _interopRequireDefault(require("./operator-no-unspaced"));
-
-var _partialNoImport = _interopRequireDefault(require("./partial-no-import"));
-
-var _percentPlaceholderPattern = _interopRequireDefault(require("./percent-placeholder-pattern"));
-
-var _selectorNestCombinators = _interopRequireDefault(require("./selector-nest-combinators"));
-
-var _selectorNoRedundantNestingSelector = _interopRequireDefault(require("./selector-no-redundant-nesting-selector"));
-
-var _selectorNoUnionClassName = _interopRequireDefault(require("./selector-no-union-class-name"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var _default = {
- "at-extend-no-missing-placeholder": _atExtendNoMissingPlaceholder["default"],
- "at-else-closing-brace-newline-after": _atElseClosingBraceNewlineAfter["default"],
- "at-else-closing-brace-space-after": _atElseClosingBraceSpaceAfter["default"],
- "at-else-empty-line-before": _atElseEmptyLineBefore["default"],
- "at-else-if-parentheses-space-before": _atElseIfParenthesesSpaceBefore["default"],
- "at-function-named-arguments": _atFunctionNamedArguments["default"],
- "at-function-parentheses-space-before": _atFunctionParenthesesSpaceBefore["default"],
- "at-function-pattern": _atFunctionPattern["default"],
- "at-if-closing-brace-newline-after": _atIfClosingBraceNewlineAfter["default"],
- "at-if-closing-brace-space-after": _atIfClosingBraceSpaceAfter["default"],
- "at-if-no-null": _atIfNoNull["default"],
- "at-import-no-partial-leading-underscore": _atImportNoPartialLeadingUnderscore["default"],
- "at-import-partial-extension": _atImportPartialExtension["default"],
- "at-import-partial-extension-blacklist": _atImportPartialExtensionBlacklist["default"],
- "at-import-partial-extension-whitelist": _atImportPartialExtensionWhitelist["default"],
- "at-mixin-argumentless-call-parentheses": _atMixinArgumentlessCallParentheses["default"],
- "at-mixin-named-arguments": _atMixinNamedArguments["default"],
- "at-mixin-parentheses-space-before": _atMixinParenthesesSpaceBefore["default"],
- "at-mixin-pattern": _atMixinPattern["default"],
- "at-each-key-value-single-line": _atEachKeyValueSingleLine["default"],
- "at-rule-conditional-no-parentheses": _atRuleConditionalNoParentheses["default"],
- "at-rule-no-unknown": _atRuleNoUnknown["default"],
- "comment-no-loud": _commentNoLoud["default"],
- "declaration-nested-properties": _declarationNestedProperties["default"],
- "declaration-nested-properties-no-divided-groups": _declarationNestedPropertiesNoDividedGroups["default"],
- "dimension-no-non-numeric-values": _dimensionNoNonNumericValues["default"],
- "dollar-variable-colon-newline-after": _dollarVariableColonNewlineAfter["default"],
- "dollar-variable-colon-space-after": _dollarVariableColonSpaceAfter["default"],
- "dollar-variable-colon-space-before": _dollarVariableColonSpaceBefore["default"],
- "dollar-variable-default": _dollarVariableDefault["default"],
- "dollar-variable-empty-line-before": _dollarVariableEmptyLineBefore["default"],
- "dollar-variable-no-missing-interpolation": _dollarVariableNoMissingInterpolation["default"],
- "dollar-variable-pattern": _dollarVariablePattern["default"],
- "double-slash-comment-empty-line-before": _doubleSlashCommentEmptyLineBefore["default"],
- "double-slash-comment-inline": _doubleSlashCommentInline["default"],
- "double-slash-comment-whitespace-inside": _doubleSlashCommentWhitespaceInside["default"],
- "function-quote-no-quoted-strings-inside": _functionQuoteNoQuotedStringsInside["default"],
- "function-unquote-no-unquoted-strings-inside": _functionUnquoteNoUnquotedStringsInside["default"],
- "function-color-relative": _functionColorRelative["default"],
- "map-keys-quotes": _mapKeysQuotes["default"],
- "media-feature-value-dollar-variable": _mediaFeatureValueDollarVariable["default"],
- "no-dollar-variables": _noDollarVariables["default"],
- "no-duplicate-dollar-variables": _noDuplicateDollarVariables["default"],
- "no-duplicate-mixins": _noDuplicateMixins["default"],
- "operator-no-newline-after": _operatorNoNewlineAfter["default"],
- "operator-no-newline-before": _operatorNoNewlineBefore["default"],
- "operator-no-unspaced": _operatorNoUnspaced["default"],
- "percent-placeholder-pattern": _percentPlaceholderPattern["default"],
- "partial-no-import": _partialNoImport["default"],
- "selector-nest-combinators": _selectorNestCombinators["default"],
- "selector-no-redundant-nesting-selector": _selectorNoRedundantNestingSelector["default"],
- "selector-no-union-class-name": _selectorNoUnionClassName["default"]
-};
-exports["default"] = _default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/map-keys-quotes/index.js b/assets/node_modules/stylelint-scss/dist/rules/map-keys-quotes/index.js
deleted file mode 100644
index 401666a..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/map-keys-quotes/index.js
+++ /dev/null
@@ -1,99 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = exports.messages = exports.ruleName = void 0;
-
-var _postcssValueParser = _interopRequireDefault(require("postcss-value-parser"));
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("map-keys-quotes");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Expected keys in map to be quoted."
-});
-
-exports.messages = messages;
-var mathOperators = ["+", "/", "-", "*", "%"];
-
-function rule(primary) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: primary,
- possible: ["always"]
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkDecls(function (decl) {
- if (decl.prop[0] !== "$") {
- return;
- }
-
- (0, _postcssValueParser["default"])(decl.value).walk(function (node) {
- if (node.type === "function" && node.value === "" && isMap(node.nodes)) {
- // Identify all of the map-keys and see if they're strings (not words).
- var mapKeys = returnMapKeys(node.nodes);
- mapKeys.forEach(function (map_key) {
- if (mathOperators.includes(map_key.value)) {
- return;
- }
-
- if (map_key.type === "word" && isNaN(map_key.value)) {
- _stylelint.utils.report({
- message: messages.expected,
- node: decl,
- result: result,
- ruleName: ruleName
- });
- }
- });
- }
- });
- });
- };
-} // Takes in a list of map nodes and identifies if they are a map.
-// A map is identified by the pattern: [string/word colon(div) anything comma(div) ...]
-
-
-function isMap(nodes) {
- if (nodes.length < 4) {
- return false;
- }
-
- if (nodes[0].type !== "word" && nodes[0].type !== "string") {
- return false;
- }
-
- if (nodes[1].value !== ":") {
- return false;
- }
-
- if (nodes[3].value !== ",") {
- return false;
- }
-
- return true;
-}
-
-function returnMapKeys(array) {
- var new_array = [];
-
- for (var i = 0; i < array.length; i += 4) {
- new_array.push(array[i]);
- }
-
- return new_array;
-}
-
-var _default = rule;
-exports["default"] = _default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/media-feature-value-dollar-variable/index.js b/assets/node_modules/stylelint-scss/dist/rules/media-feature-value-dollar-variable/index.js
deleted file mode 100644
index 7c7268f..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/media-feature-value-dollar-variable/index.js
+++ /dev/null
@@ -1,75 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("media-feature-value-dollar-variable");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: "Unexpected dollar-variable as a media feature value",
- expected: "Expected a dollar-variable (e.g. $var) to be used as a media feature value"
-});
-
-exports.messages = messages;
-
-function _default(expectation) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- });
-
- if (!validOptions) {
- return;
- }
-
- var valueRegex = /:(?:\s*?)(\S.+?)(:?\s*?)\)/; // In `(max-width: 10px )` find `: 10px )`.
- // Got to go with that (the global search doesn't remember parens' insides)
- // and parse it again afterwards to remove trailing junk
-
- var valueRegexGlobal = new RegExp(valueRegex.source, "g"); // `$var-name_sth`
-
- var variableRegex = /^\$[A-Za-z_0-9-]+$/; // `#{$var-name_sth}`
-
- var interpolationVarRegex = /^#\{\s*?\$[A-Za-z_0-9]+\s*?\}$/;
- root.walkAtRules("media", function (atRule) {
- var found = atRule.params.match(valueRegexGlobal); // If there are no values
-
- if (!found || !found.length) {
- return;
- }
-
- found.forEach(function (found) {
- // ... parse `: 10px )` to `10px`
- var valueParsed = found.match(valueRegex)[1]; // Just a shorthand to stylelint.utils.report()
-
- function complain(message) {
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- node: atRule,
- word: valueParsed,
- message: message
- });
- } // A value should be a single variable
- // or it should be a single variable inside Sass interpolation
-
-
- if (expectation === "always" && !(valueParsed.search(variableRegex) !== -1 || valueParsed.search(interpolationVarRegex) !== -1)) {
- complain(messages.expected);
- } else if (expectation === "never" && valueParsed.includes("$")) {
- // "Never" means no variables at all (functions allowed)
- complain(messages.rejected);
- }
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/no-dollar-variables/index.js b/assets/node_modules/stylelint-scss/dist/rules/no-dollar-variables/index.js
deleted file mode 100644
index ed0ed25..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/no-dollar-variables/index.js
+++ /dev/null
@@ -1,47 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("no-dollar-variables");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: function rejected(variable) {
- return "Unexpected dollar variable ".concat(variable);
- }
-});
-
-exports.messages = messages;
-
-function _default(value) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: value
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkDecls(function (decl) {
- if (decl.prop[0] !== "$") {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.rejected(decl.prop),
- node: decl,
- result: result,
- ruleName: ruleName
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/no-duplicate-dollar-variables/index.js b/assets/node_modules/stylelint-scss/dist/rules/no-duplicate-dollar-variables/index.js
deleted file mode 100644
index 557ef86..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/no-duplicate-dollar-variables/index.js
+++ /dev/null
@@ -1,66 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _lodash = require("lodash");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("no-duplicate-dollar-variables");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: function rejected(variable) {
- return "Unexpected duplicate dollar variable ".concat(variable);
- }
-});
-
-exports.messages = messages;
-
-function _default(value, secondaryOptions) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: value
- }, {
- actual: secondaryOptions,
- possible: {
- ignoreInside: ["at-rule", "nested-at-rule"],
- ignoreInsideAtRules: [_lodash.isString]
- },
- optional: true
- });
-
- if (!validOptions) {
- return;
- }
-
- var vars = {};
- root.walkDecls(function (decl) {
- var isVar = decl.prop[0] === "$";
- var isInsideIgnoredAtRule = decl.parent.type === "atrule" && secondaryOptions && secondaryOptions.ignoreInside && secondaryOptions.ignoreInside === "at-rule";
- var isInsideIgnoredNestedAtRule = decl.parent.type === "atrule" && decl.parent.parent.type !== "root" && secondaryOptions && secondaryOptions.ignoreInside && secondaryOptions.ignoreInside === "nested-at-rule";
- var isInsideIgnoredSpecifiedAtRule = decl.parent.type === "atrule" && secondaryOptions && secondaryOptions.ignoreInsideAtRules && secondaryOptions.ignoreInsideAtRules.includes(decl.parent.name);
-
- if (!isVar || isInsideIgnoredAtRule || isInsideIgnoredNestedAtRule || isInsideIgnoredSpecifiedAtRule) {
- return;
- }
-
- if (vars[decl.prop]) {
- _stylelint.utils.report({
- message: messages.rejected(decl.prop),
- node: decl,
- result: result,
- ruleName: ruleName
- });
- }
-
- vars[decl.prop] = true;
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/no-duplicate-mixins/index.js b/assets/node_modules/stylelint-scss/dist/rules/no-duplicate-mixins/index.js
deleted file mode 100644
index 8c84fe9..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/no-duplicate-mixins/index.js
+++ /dev/null
@@ -1,56 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("no-duplicate-mixins");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: function rejected(mixin) {
- return "Unexpected duplicate mixin ".concat(mixin);
- }
-});
-
-exports.messages = messages;
-
-function _default(value) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: value
- });
-
- if (!validOptions) {
- return;
- }
-
- var mixins = {};
- root.walkAtRules(function (decl) {
- var isMixin = decl.name === "mixin";
-
- if (!isMixin) {
- return;
- }
-
- var mixinName = (0, _utils.atRuleBaseName)(decl);
-
- if (mixins[mixinName]) {
- _stylelint.utils.report({
- message: messages.rejected(mixinName),
- node: decl,
- result: result,
- ruleName: ruleName
- });
- }
-
- mixins[mixinName] = true;
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/operator-no-newline-after/index.js b/assets/node_modules/stylelint-scss/dist/rules/operator-no-newline-after/index.js
deleted file mode 100644
index 727bef8..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/operator-no-newline-after/index.js
+++ /dev/null
@@ -1,80 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var _operatorNoUnspaced = require("../operator-no-unspaced");
-
-var ruleName = (0, _utils.namespace)("operator-no-newline-after");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: function rejected(operator) {
- return "Unexpected newline after \"".concat(operator, "\"");
- }
-});
-
-exports.messages = messages;
-
-/**
- * The checker function: whether there is a newline before THAT operator.
- */
-function checkNewlineBefore(_ref) {
- var string = _ref.string,
- globalIndex = _ref.globalIndex,
- startIndex = _ref.startIndex,
- endIndex = _ref.endIndex,
- node = _ref.node,
- result = _ref.result;
- var symbol = string.substring(startIndex, endIndex + 1);
- var newLineBefore = false;
- var index = endIndex + 1;
-
- while (index && (0, _utils.isWhitespace)(string[index])) {
- if (string[index] === "\n") {
- newLineBefore = true;
- break;
- }
-
- index++;
- }
-
- if (newLineBefore) {
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- node: node,
- message: messages.rejected(symbol),
- index: endIndex + globalIndex
- });
- }
-}
-
-function _default(expectation) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation
- });
-
- if (!validOptions) {
- return;
- }
-
- (0, _utils.eachRoot)(root, checkRoot);
-
- function checkRoot(root) {
- (0, _operatorNoUnspaced.calculationOperatorSpaceChecker)({
- root: root,
- result: result,
- checker: checkNewlineBefore
- });
- }
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/operator-no-newline-before/index.js b/assets/node_modules/stylelint-scss/dist/rules/operator-no-newline-before/index.js
deleted file mode 100644
index 12dd6a0..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/operator-no-newline-before/index.js
+++ /dev/null
@@ -1,80 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var _operatorNoUnspaced = require("../operator-no-unspaced");
-
-var ruleName = (0, _utils.namespace)("operator-no-newline-before");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: function rejected(operator) {
- return "Unexpected newline before \"".concat(operator, "\"");
- }
-});
-
-exports.messages = messages;
-
-/**
- * The checker function: whether there is a newline before THAT operator.
- */
-function checkNewlineBefore(_ref) {
- var string = _ref.string,
- globalIndex = _ref.globalIndex,
- startIndex = _ref.startIndex,
- endIndex = _ref.endIndex,
- node = _ref.node,
- result = _ref.result;
- var symbol = string.substring(startIndex, endIndex + 1);
- var newLineBefore = false;
- var index = startIndex - 1;
-
- while (index && (0, _utils.isWhitespace)(string[index])) {
- if (string[index] === "\n") {
- newLineBefore = true;
- break;
- }
-
- index--;
- }
-
- if (newLineBefore) {
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- node: node,
- message: messages.rejected(symbol),
- index: endIndex + globalIndex
- });
- }
-}
-
-function _default(expectation) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation
- });
-
- if (!validOptions) {
- return;
- }
-
- (0, _utils.eachRoot)(root, checkRoot);
-
- function checkRoot(root) {
- (0, _operatorNoUnspaced.calculationOperatorSpaceChecker)({
- root: root,
- result: result,
- checker: checkNewlineBefore
- });
- }
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/operator-no-unspaced/index.js b/assets/node_modules/stylelint-scss/dist/rules/operator-no-unspaced/index.js
deleted file mode 100644
index 2389fee..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/operator-no-unspaced/index.js
+++ /dev/null
@@ -1,268 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.calculationOperatorSpaceChecker = calculationOperatorSpaceChecker;
-exports.messages = exports.ruleName = void 0;
-
-var _postcssMediaQueryParser = _interopRequireDefault(require("postcss-media-query-parser"));
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("operator-no-unspaced");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expectedAfter: function expectedAfter(operator) {
- return "Expected single space after \"".concat(operator, "\"");
- },
- expectedBefore: function expectedBefore(operator) {
- return "Expected single space before \"".concat(operator, "\"");
- }
-});
-/**
- * The actual check for are there (un)necessary whitespaces
- */
-
-
-exports.messages = messages;
-
-function checkSpaces(_ref) {
- var string = _ref.string,
- globalIndex = _ref.globalIndex,
- startIndex = _ref.startIndex,
- endIndex = _ref.endIndex,
- node = _ref.node,
- result = _ref.result;
- var symbol = string.substring(startIndex, endIndex + 1);
- var beforeOk = string[startIndex - 1] === " " && !(0, _utils.isWhitespace)(string[startIndex - 2]) || newlineBefore(string, startIndex - 1);
-
- if (!beforeOk) {
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- node: node,
- message: messages.expectedBefore(symbol),
- index: startIndex + globalIndex
- });
- }
-
- var afterOk = string[endIndex + 1] === " " && !(0, _utils.isWhitespace)(string[endIndex + 2]) || string[endIndex + 1] === "\n" || string.substr(endIndex + 1, 2) === "\r\n";
-
- if (!afterOk) {
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- node: node,
- message: messages.expectedAfter(symbol),
- index: endIndex + globalIndex
- });
- }
-}
-
-function newlineBefore(str, startIndex) {
- var index = startIndex;
-
- while (index && (0, _utils.isWhitespace)(str[index])) {
- if (str[index] === "\n") return true;
- index--;
- }
-
- return false;
-}
-
-function _default(expectation) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation
- });
-
- if (!validOptions) {
- return;
- }
-
- (0, _utils.eachRoot)(root, checkRoot);
-
- function checkRoot(root) {
- var rootString = root.source.input.css;
-
- if (rootString.trim() === "") {
- return;
- }
-
- calculationOperatorSpaceChecker({
- root: root,
- result: result,
- checker: checkSpaces
- });
- }
- };
-}
-/**
- * The core rule logic function. This one can be imported by some other rules
- * that work with Sass operators
- *
- * @param {Object} args -- Named arguments object
- * @param {PostCSS Root} args.root
- * @param {PostCSS Result} args.result
- * @param {function} args.checker -- the function that is run against all the
- * operators found in the input. Takes these arguments:
- * {Object} cbArgs -- Named arguments object
- * {string} cbArgs.string -- the input string (suspected operation)
- * {number} cbArgs.globalIndex -- the string's index in a global input
- * {number} cbArgs.startIndex -- the start index of a sybmol to inspect
- * {number} cbArgs.endIndex -- the end index of a sybmol to inspect
- * (two indexes needed to allow for `==`, `!=`, etc.)
- * {PostCSS Node} cbArgs.node -- for stylelint.utils.report
- * {PostCSS Result} cbArgs.result -- for stylelint.utils.report
- */
-
-
-function calculationOperatorSpaceChecker(_ref2) {
- var root = _ref2.root,
- result = _ref2.result,
- checker = _ref2.checker;
-
- /**
- * Takes a string, finds all occurencies of Sass interpolaion in it, then
- * finds all operators inside that interpolation
- *
- * @return {array} An array of ojbects { string, operators } - effectively,
- * a list of operators for each Sass interpolation occurence
- */
- function findInterpolation(string, startIndex) {
- var interpolationRegex = /#{(.*?)}/g;
- var results = []; // Searching for interpolation
-
- var match = interpolationRegex.exec(string);
- startIndex = !isNaN(startIndex) ? Number(startIndex) : 0;
-
- while (match !== null) {
- results.push({
- source: match[0],
- operators: (0, _utils.findOperators)({
- string: match[0],
- globalIndex: match.index + startIndex
- })
- });
- match = interpolationRegex.exec(string);
- }
-
- return results;
- }
-
- root.walk(function (item) {
- if (item.prop === "unicode-range") {
- return;
- }
-
- var results = []; // Check a value (`10px` in `width: 10px;`)
-
- if (item.value !== undefined) {
- results.push({
- source: item.value,
- operators: (0, _utils.findOperators)({
- string: item.value,
- globalIndex: (0, _utils.declarationValueIndex)(item),
- // For Sass variable values some special rules apply
- isAfterColon: item.prop[0] === "$"
- })
- });
- } // Property name
-
-
- if (item.prop !== undefined) {
- results = results.concat(findInterpolation(item.prop));
- } // Selector
-
-
- if (item.selector !== undefined) {
- results = results.concat(findInterpolation(item.selector));
- }
-
- if (item.type === "atrule") {
- // @forward, @use and @at-root
- if (item.name === "forward" || item.name === "use" || item.name === "at-root") {
- return;
- } // Media queries
-
-
- if (item.name === "media" || item.name === "import") {
- (0, _postcssMediaQueryParser["default"])(item.params).walk(function (node) {
- var type = node.type;
-
- if (["keyword", "media-type", "media-feature"].includes(type)) {
- results = results.concat(findInterpolation(node.value, (0, _utils.atRuleParamIndex)(item) + node.sourceIndex));
- } else if (["value", "url"].includes(type)) {
- results.push({
- source: node.value,
- operators: (0, _utils.findOperators)({
- string: node.value,
- globalIndex: (0, _utils.atRuleParamIndex)(item) + node.sourceIndex,
- isAfterColon: true
- })
- });
- }
- });
- } else {
- // Function and mixin definitions and other rules
- results.push({
- source: item.params,
- operators: (0, _utils.findOperators)({
- string: item.params,
- globalIndex: (0, _utils.atRuleParamIndex)(item),
- isAfterColon: true
- })
- });
- }
- } // All the strings have been parsed, now run whitespace checking
-
-
- results.forEach(function (el) {
- // Only if there are operators within a string
- if (el.operators && el.operators.length > 0) {
- el.operators.forEach(function (operator) {
- checker({
- string: el.source,
- globalIndex: operator.globalIndex,
- startIndex: operator.startIndex,
- endIndex: operator.endIndex,
- node: item,
- result: result
- });
- });
- }
- });
- }); // Checking interpolation inside comments
- // We have to give up on PostCSS here because it skips some inline comments
-
- (0, _utils.findCommentsInRaws)(root.source.input.css).forEach(function (comment) {
- var startIndex = comment.source.start + comment.raws.startToken.length + comment.raws.left.length;
-
- if (comment.type !== "css") {
- return;
- }
-
- findInterpolation(comment.text).forEach(function (el) {
- // Only if there are operators within a string
- if (el.operators && el.operators.length > 0) {
- el.operators.forEach(function (operator) {
- checker({
- string: el.source,
- globalIndex: operator.globalIndex + startIndex,
- startIndex: operator.startIndex,
- endIndex: operator.endIndex,
- node: root,
- result: result
- });
- });
- }
- });
- });
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/partial-no-import/index.js b/assets/node_modules/stylelint-scss/dist/rules/partial-no-import/index.js
deleted file mode 100644
index 045f7ea..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/partial-no-import/index.js
+++ /dev/null
@@ -1,80 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _path = _interopRequireDefault(require("path"));
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("partial-no-import");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: "Unexpected @import in a partial"
-});
-
-exports.messages = messages;
-
-function _default(on) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: on
- });
-
- if (!validOptions) {
- return;
- }
-
- if (root.source.input.file === undefined || !root.source.input.file) {
- result.warn("The 'partial-no-import' rule won't work if linting in a code string without an actual file.");
- return;
- }
-
- var fileName = _path["default"].basename(root.source.input.file);
-
- var extName = _path["default"].extname(root.source.input.file);
-
- function checkImportForCSS(path, decl) {
- // Stripping trailing quotes and whitespaces, if any
- var pathStripped = path.replace(/^\s*?("|')\s*/, "").replace(/\s*("|')\s*?$/, ""); // Skipping importing empty import, CSS: url(), ".css", URI with a protocol, media
-
- if (pathStripped.trim() === "" || pathStripped.slice(0, 4) === "url(" || pathStripped.slice(-4) === ".css" || pathStripped.search("//") !== -1 || pathStripped.search(/(?:\s|[,)"'])\w+$/) !== -1) {
- return;
- }
-
- _stylelint.utils.report({
- message: messages.expected,
- node: decl,
- index: decl.params.indexOf(path),
- result: result,
- ruleName: ruleName
- });
- } // Usual CSS file
-
-
- if (extName === ".css") {
- return;
- } // Not a partial
-
-
- if (fileName[0] !== "_") {
- return;
- }
-
- root.walkAtRules("import", function (mixinCall) {
- // Check if @import is treated as CSS import; report only if not
- // Processing comma-separated lists of import paths
- mixinCall.params.split(/["']\s*,/).forEach(function (path) {
- checkImportForCSS(path, mixinCall);
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/percent-placeholder-pattern/index.js b/assets/node_modules/stylelint-scss/dist/rules/percent-placeholder-pattern/index.js
deleted file mode 100644
index 830d472..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/percent-placeholder-pattern/index.js
+++ /dev/null
@@ -1,99 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _lodash = require("lodash");
-
-var _postcssResolveNestedSelector = _interopRequireDefault(require("postcss-resolve-nested-selector"));
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-var ruleName = (0, _utils.namespace)("percent-placeholder-pattern");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expected: function expected(placeholder) {
- return "Expected %-placeholder \"%".concat(placeholder, "\" to match specified pattern");
- }
-});
-
-exports.messages = messages;
-
-function _default(pattern) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: pattern,
- possible: [_lodash.isRegExp, _lodash.isString]
- });
-
- if (!validOptions) {
- return;
- }
-
- var placeholderPattern = (0, _lodash.isString)(pattern) ? new RegExp(pattern) : pattern; // Checking placeholder definitions (looking among regular rules)
-
- root.walkRules(function (rule) {
- var selector = rule.selector; // Just a shorthand for calling `parseSelector`
-
- function parse(selector) {
- (0, _utils.parseSelector)(selector, result, rule, function (s) {
- return checkSelector(s, rule);
- });
- } // If it's a custom prop or a less mixin
-
-
- if (!(0, _utils.isStandardRule)(rule)) {
- return;
- } // If the selector has interpolation
-
-
- if (!(0, _utils.isStandardSelector)(selector)) {
- return;
- } // Nested selectors are processed in steps, as nesting levels are resolved.
- // Here we skip processing intermediate parts of selectors (to process only fully resolved selectors)
- // if (rule.nodes.some(node => node.type === "rule" || node.type === "atrule")) { return }
- // Only resolve selectors that have an interpolating "&"
-
-
- if ((0, _utils.hasInterpolatingAmpersand)(selector)) {
- (0, _postcssResolveNestedSelector["default"])(selector, rule).forEach(parse);
- } else {
- parse(selector);
- }
- });
-
- function checkSelector(fullSelector, rule) {
- // postcss-selector-parser gives %placeholders' nodes a "tag" type
- fullSelector.walkTags(function (compoundSelector) {
- var value = compoundSelector.value,
- sourceIndex = compoundSelector.sourceIndex;
-
- if (value[0] !== "%") {
- return;
- }
-
- var placeholder = value.slice(1);
-
- if (placeholderPattern.test(placeholder)) {
- return;
- }
-
- _stylelint.utils.report({
- result: result,
- ruleName: ruleName,
- message: messages.expected(placeholder),
- node: rule,
- index: sourceIndex
- });
- });
- }
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/selector-nest-combinators/index.js b/assets/node_modules/stylelint-scss/dist/rules/selector-nest-combinators/index.js
deleted file mode 100644
index 3a85306..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/selector-nest-combinators/index.js
+++ /dev/null
@@ -1,139 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("selector-nest-combinators");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- expectedInterpolation: "Expected interpolation to be in a nested form",
- expected: function expected(combinator, type) {
- return "Expected combinator \"".concat(combinator, "\" of type \"").concat(type, "\" to be in a nested form");
- },
- rejected: "Unexpected nesting found in selector"
-});
-
-exports.messages = messages;
-
-function _default(expectation) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: expectation,
- possible: ["always", "never"]
- });
-
- if (!validOptions) {
- return;
- }
-
- function precedesParentSelector(current) {
- do {
- current = current.next();
-
- if (current.type === "nesting") {
- return true;
- }
- } while (current.next());
-
- return false;
- } // attribute, class, combinator, comment, id, nesting, pseudo, root, selector, string, tag, or universal
-
-
- var chainingTypes = ["attribute", "class", "id", "pseudo", "tag", "universal"];
- var interpolationRe = /#{.+?}$/;
- root.walkRules(function (rule) {
- if (rule.parent && rule.parent.type === "atrule" && rule.parent.name === "keyframes") {
- return;
- }
-
- if (typeof rule.selector === "string") {
- var isNestedProperty = rule.selector.slice(-1) === ":";
-
- if (isNestedProperty) {
- return;
- }
- }
-
- (0, _utils.parseSelector)(rule.selector, result, rule, function (fullSelector) {
- var message;
- fullSelector.walk(function (node) {
- if (node.value === "}") {
- return;
- }
-
- if (expectation === "always") {
- if (node.type === "selector") {
- return;
- }
-
- if (node.parent && node.parent.type === "selector" && node.parent.parent && node.parent.parent.type === "pseudo") {
- return;
- }
-
- if (!node.prev()) {
- return;
- }
-
- if (node.next() && precedesParentSelector(node)) {
- return;
- }
-
- if (node.type === "combinator") {
- if (!chainingTypes.includes(node.next().type)) {
- return;
- }
-
- if (!chainingTypes.includes(node.prev().type)) {
- return;
- }
- }
-
- if (chainingTypes.includes(node.type) && !chainingTypes.includes(node.prev().type)) {
- return;
- }
-
- if (node.type !== "combinator" && !chainingTypes.includes(node.type)) {
- return;
- }
-
- var hasInterpolation = interpolationRe.test(rule.selector);
-
- if (node.type !== "combinator" && hasInterpolation) {
- return;
- }
-
- if (hasInterpolation) {
- message = messages.expectedInterpolation;
- } else {
- message = messages.expected(node.value, node.type);
- }
- }
-
- if (expectation === "never") {
- if (rule.parent.type === "root" || rule.parent.type === "atrule") {
- return;
- }
-
- message = messages.rejected;
- }
-
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- node: rule,
- message: message,
- index: node.sourceIndex
- });
- });
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/selector-no-redundant-nesting-selector/index.js b/assets/node_modules/stylelint-scss/dist/rules/selector-no-redundant-nesting-selector/index.js
deleted file mode 100644
index 0a8cf13..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/selector-no-redundant-nesting-selector/index.js
+++ /dev/null
@@ -1,69 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("selector-no-redundant-nesting-selector");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: "Unnecessary nesting selector (&)"
-});
-
-exports.messages = messages;
-
-function _default(actual) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: actual
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkRules(/&/, function (rule) {
- (0, _utils.parseSelector)(rule.selector, result, rule, function (fullSelector) {
- // "Ampersand followed by a combinator followed by non-combinator non-ampersand and not the selector end"
- fullSelector.walkNesting(function (node) {
- var prev = node.prev();
-
- if (prev) {
- return;
- }
-
- var next = node.next();
-
- if (!next && node.parent.parent.nodes.length > 1) {
- return;
- }
-
- if (next && next.type !== "combinator") {
- return;
- }
-
- var nextNext = next ? next.next() : null;
-
- if (nextNext && (nextNext.type === "combinator" || nextNext.type === "nesting")) {
- return;
- }
-
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- node: rule,
- message: messages.rejected,
- index: node.sourceIndex
- });
- });
- });
- });
- };
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/rules/selector-no-union-class-name/index.js b/assets/node_modules/stylelint-scss/dist/rules/selector-no-union-class-name/index.js
deleted file mode 100644
index cfb1ed1..0000000
--- a/assets/node_modules/stylelint-scss/dist/rules/selector-no-union-class-name/index.js
+++ /dev/null
@@ -1,88 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-exports.messages = exports.ruleName = void 0;
-
-var _postcssSelectorParser = require("postcss-selector-parser");
-
-var _stylelint = require("stylelint");
-
-var _utils = require("../../utils");
-
-var ruleName = (0, _utils.namespace)("selector-no-union-class-name");
-exports.ruleName = ruleName;
-
-var messages = _stylelint.utils.ruleMessages(ruleName, {
- rejected: "Unexpected union class name with the parent selector (&)"
-});
-
-exports.messages = messages;
-var validNestingTypes = [_postcssSelectorParser.isClassName, _postcssSelectorParser.isCombinator, _postcssSelectorParser.isAttribute, _postcssSelectorParser.isIdentifier, _postcssSelectorParser.isPseudoClass, _postcssSelectorParser.isPseudoElement];
-
-function _default(actual) {
- return function (root, result) {
- var validOptions = _stylelint.utils.validateOptions(result, ruleName, {
- actual: actual
- });
-
- if (!validOptions) {
- return;
- }
-
- root.walkRules(/&/, function (rule) {
- var parentNodes = [];
- var selector = getSelectorFromRule(rule.parent);
-
- if (selector) {
- (0, _utils.parseSelector)(selector, result, rule, function (fullSelector) {
- fullSelector.walk(function (node) {
- return parentNodes.push(node);
- });
- });
- }
-
- if (parentNodes.length === 0) return;
- var lastParentNode = parentNodes[parentNodes.length - 1];
- if (!(0, _postcssSelectorParser.isClassName)(lastParentNode)) return;
- (0, _utils.parseSelector)(rule.selector, result, rule, function (fullSelector) {
- fullSelector.walkNesting(function (node) {
- var next = node.next();
- if (!next) return;
- if (validNestingTypes.some(function (isType) {
- return isType(next);
- })) return;
-
- _stylelint.utils.report({
- ruleName: ruleName,
- result: result,
- node: rule,
- message: messages.rejected,
- index: node.sourceIndex
- });
- });
- });
- });
- };
-}
-/**
- * Searches for the closest rule which
- * has a selector and returns the selector
- * @returns {string|undefined}
- */
-
-
-function getSelectorFromRule(rule) {
- // All non at-rules have their own selector
- if (rule.selector !== undefined) {
- return rule.selector;
- } // At-rules like @mixin don't have a selector themself
- // but their parents might have one
-
-
- if (rule.parent) {
- return getSelectorFromRule(rule.parent);
- }
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/testUtils/basicChecks.js b/assets/node_modules/stylelint-scss/dist/testUtils/basicChecks.js
deleted file mode 100644
index b912b66..0000000
--- a/assets/node_modules/stylelint-scss/dist/testUtils/basicChecks.js
+++ /dev/null
@@ -1,16 +0,0 @@
-"use strict";
-
-// These should pass for *almost* every rule
-module.exports = [{
- code: "",
- description: "empty stylesheet"
-}, {
- code: "a {}",
- description: "empty rule"
-}, {
- code: '@import "foo.css";',
- description: "blockless statement"
-}, {
- code: ":global {}",
- description: "CSS Modules global empty rule set"
-}]; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/addEmptyLineBefore.js b/assets/node_modules/stylelint-scss/dist/utils/addEmptyLineBefore.js
deleted file mode 100644
index 406ce3f..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/addEmptyLineBefore.js
+++ /dev/null
@@ -1,23 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports.addEmptyLineBefore = addEmptyLineBefore;
-
-// Add an empty line before a node. Mutates the node.
-function addEmptyLineBefore(node
-/*: postcss$node*/
-, newline
-/*: '\n' | '\r\n'*/
-)
-/*: postcss$node*/
-{
- if (!/\r?\n/.test(node.raws.before)) {
- node.raws.before = newline.repeat(2) + node.raws.before;
- } else {
- node.raws.before = node.raws.before.replace(/(\r?\n)/, "".concat(newline, "$1"));
- }
-
- return node;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/atRuleBaseName.js b/assets/node_modules/stylelint-scss/dist/utils/atRuleBaseName.js
deleted file mode 100644
index 183d661..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/atRuleBaseName.js
+++ /dev/null
@@ -1,16 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Get an at rule's base name
- *
- * @param {AtRule} atRule
- * @return {string} The name
- */
-function _default(atRule) {
- return atRule.params.replace(/\([^)]*\)/, "").trim();
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/atRuleParamIndex.js b/assets/node_modules/stylelint-scss/dist/utils/atRuleParamIndex.js
deleted file mode 100644
index f6bfa22..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/atRuleParamIndex.js
+++ /dev/null
@@ -1,23 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Get the index of a media query's params
- *
- * @param {AtRule} atRule
- * @return {int} The index
- */
-function _default(atRule) {
- // Initial 1 is for the `@`
- var index = 1 + atRule.name.length;
-
- if (atRule.raw("afterName")) {
- index += atRule.raw("afterName").length;
- }
-
- return index;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/beforeBlockString.js b/assets/node_modules/stylelint-scss/dist/utils/beforeBlockString.js
deleted file mode 100644
index c5f82e8..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/beforeBlockString.js
+++ /dev/null
@@ -1,47 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Given a CSS statement, return the string before the block.
- * For rules, this is the selector list (and surrounding whitespace).
- * For at-rules, this is the name and params (and surrounding whitespace).
- *
- * If there is no block, return empty string.
- *
- * @param {Rule|AtRule} statement - postcss rule or at-rule node
- * @param {object} options
- * @param {boolean} [options.noRawBefore] - Leave out the `before` string
- * @return {string}
- */
-function _default(statement) {
- var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
- noRawBefore = _ref.noRawBefore;
-
- var result = "";
-
- if (statement.type !== "rule" && statement.type !== "atrule") {
- return result;
- }
-
- if (!noRawBefore) {
- result += statement.raws.before;
- }
-
- if (statement.type === "rule") {
- result += statement.selector;
- } else {
- result += "@".concat(statement.name).concat(statement.raws.afterName).concat(statement.params);
- }
-
- var between = statement.raws.between;
-
- if (between !== undefined) {
- result += between;
- }
-
- return result;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/blockString.js b/assets/node_modules/stylelint-scss/dist/utils/blockString.js
deleted file mode 100644
index f722477..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/blockString.js
+++ /dev/null
@@ -1,31 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-var _beforeBlockString = _interopRequireDefault(require("./beforeBlockString"));
-
-var _hasBlock = _interopRequireDefault(require("./hasBlock"));
-
-var _rawNodeString = _interopRequireDefault(require("./rawNodeString"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-/**
- * Return a CSS statement's block -- the string that starts with `{` and ends with `}`.
- *
- * If the statement has no block (e.g. `@import url(foo.css);`),
- * return undefined.
- *
- * @param {Rule|AtRule} statement - postcss rule or at-rule node
- * @return {string|undefined}
- */
-function _default(statement) {
- if (!(0, _hasBlock["default"])(statement)) {
- return;
- }
-
- return (0, _rawNodeString["default"])(statement).slice((0, _beforeBlockString["default"])(statement).length);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/configurationError.js b/assets/node_modules/stylelint-scss/dist/utils/configurationError.js
deleted file mode 100644
index e0eb053..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/configurationError.js
+++ /dev/null
@@ -1,18 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Create configurationError from text and set CLI exit code
- *
- * @param {string} text
- * @return {Error} - The error, with text and exit code
- */
-function _default(text) {
- var err = new Error(text);
- err.code = 78;
- return err;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/declarationValueIndex.js b/assets/node_modules/stylelint-scss/dist/utils/declarationValueIndex.js
deleted file mode 100644
index 3521a90..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/declarationValueIndex.js
+++ /dev/null
@@ -1,18 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Get the index of a declaration's value
- *
- * @param {Decl} decl
- * @return {int} The index
- */
-function _default(decl) {
- var beforeColon = decl.toString().indexOf(":");
- var afterColon = decl.raw("between").length - decl.raw("between").indexOf(":");
- return beforeColon + afterColon;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/eachRoot.js b/assets/node_modules/stylelint-scss/dist/utils/eachRoot.js
deleted file mode 100644
index 0162f53..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/eachRoot.js
+++ /dev/null
@@ -1,23 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Executes a provided function once for each CSS block element.
- *
- * @param {Root|Document} root - root element of file.
- * @param {function} cb - Function to execute for each CSS block element
- */
-function _default(root, cb) {
- // class `Document` is a part of `postcss-html`,
- // It is collection of roots in HTML File.
- // See: https://github.com/gucong3000/postcss-html/blob/master/lib/document.js
- if (root.constructor.name === "Document") {
- root.nodes.forEach(cb);
- } else {
- cb(root);
- }
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/findCommentsInRaws.js b/assets/node_modules/stylelint-scss/dist/utils/findCommentsInRaws.js
deleted file mode 100644
index b44c8fd..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/findCommentsInRaws.js
+++ /dev/null
@@ -1,227 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = findCommentsInRaws;
-
-/**
- * Finds comments, both CSS comments and double slash ones, in a CSS string
- * This helper exists because PostCSS drops some inline comments (those
- * between seelctors, property values, etc.)
- * https://github.com/postcss/postcss/issues/845#issuecomment-232306259
- *
- * @param [string] rawString -- the source raw CSS string
- * @return [array] array of objects with these props:
- * � type -- "css" or "double-slash"
- * � source: { start, end }
- * IMPORTANT: the function itself considers \r as a character, and counts
- * it for `start` and `end`. But if their values are passed to PostCSS's
- * result.warn(), than "\r\n" is consideren ONE CHAR (newline)!
- * � raws
- * raws.startToken -- `/*`, `/**`, `/**!`, etc.
- * raws.left -- whitespace after the comment opening marker
- * raws.text -- the full comment, including markers (//, /*)
- * raws.right -- whitespace before the comment closing marker
- * raws.endToken -- `*\/`, `**\/` for CSS comments
- * � text -- the comment text only, excluding //, /*, trailing whitespaces
- * � inlineAfter -- true, if there is something before the comment on
- * the same line
- * � inlineBefore -- true, if there is something after the comment on
- * the same line
- */
-function findCommentsInRaws(rawString) {
- var result = [];
- var comment = {}; // Keeps track of which structure the parser is inside (string, comment,
- // url function, parens). E.g., /* comment */ inside a string doesn't
- // constitute a comment, so as url(//path)
-
- var modesEntered = [{
- mode: "normal",
- character: null
- }];
- var commentStart = null; // postcss-scss transforms //-comments into CSS comments, like so:
- // `// comment` -> `/* comment*/`. So to have a correct intex we need to
- // keep track on the added `*/` sequences
-
- var offset = 0;
-
- for (var i = 0; i < rawString.length; i++) {
- var character = rawString[i];
- var prevChar = i > 0 ? rawString[i - 1] : null;
- var nextChar = i + 1 < rawString.length ? rawString[i + 1] : null;
- var lastModeIndex = modesEntered.length - 1;
- var mode = modesEntered[lastModeIndex] && modesEntered[lastModeIndex].mode;
-
- switch (character) {
- // If entering/exiting a string
- case '"':
- case "'":
- {
- if (mode === "comment") {
- break;
- }
-
- if (mode === "string" && modesEntered[lastModeIndex].character === character && prevChar !== "\\") {
- // Exiting a string
- modesEntered.pop();
- } else {
- // Entering a string
- modesEntered.push({
- mode: "string",
- character: character
- });
- }
-
- break;
- }
- // Entering url, other function or parens (only url matters)
-
- case "(":
- {
- if (mode === "comment" || mode === "string") {
- break;
- }
-
- var functionNameRegSearch = /(?:^|(?:\n)|(?:\r)|(?:\s-)|[:\s,.(){}*+/%])([a-zA-Z0-9_-]*)$/.exec(rawString.substring(0, i)); // A `\S(` can be in, say, `@media(`
-
- if (!functionNameRegSearch) {
- modesEntered.push({
- mode: "parens",
- character: "("
- });
- break;
- }
-
- var functionName = functionNameRegSearch[1];
- modesEntered.push({
- mode: functionName === "url" ? "url" : "parens",
- character: "("
- });
- break;
- }
- // Exiting url, other function or parens
-
- case ")":
- {
- if (mode === "comment" || mode === "string") {
- break;
- }
-
- modesEntered.pop();
- break;
- }
- // checking for comment
-
- case "/":
- {
- // Break if the / is inside a comment because we leap over the second
- // slash in // and in */, so the / is not from a marker. Also break
- // if inside a string
- if (mode === "comment" || mode === "string") {
- break;
- }
-
- if (nextChar === "*") {
- modesEntered.push({
- mode: "comment",
- character: "/*"
- });
- comment = {
- type: "css",
- source: {
- start: i + offset
- },
- // If i is 0 then the file/the line starts with this comment
- inlineAfter: i > 0 && rawString.substring(0, i).search(/\n\s*$/) === -1
- };
- commentStart = i; // Skip the next iteration as the * is already checked
-
- i++;
- } else if (nextChar === "/") {
- // `url(//path/to/file)` has no comment
- if (mode === "url") {
- break;
- }
-
- modesEntered.push({
- mode: "comment",
- character: "//"
- });
- comment = {
- type: "double-slash",
- source: {
- start: i + offset
- },
- // If i is 0 then the file/the line starts with this comment
- inlineAfter: i > 0 && rawString.substring(0, i).search(/\n\s*$/) === -1
- };
- commentStart = i; // Skip the next iteration as the second slash in // is already checked
-
- i++;
- }
-
- break;
- }
- // Might be a closing `*/`
-
- case "*":
- {
- if (mode === "comment" && modesEntered[lastModeIndex].character === "/*" && nextChar === "/") {
- comment.source.end = i + 1 + offset;
- var commentRaw = rawString.substring(commentStart, i + 2);
- var matches = /^(\/\*+[!#]{0,1})(\s*)([\s\S]*?)(\s*?)(\*+\/)$/.exec(commentRaw);
- modesEntered.pop();
- comment.raws = {
- startToken: matches[1],
- left: matches[2],
- text: commentRaw,
- right: matches[4],
- endToken: matches[5]
- };
- comment.text = matches[3];
- comment.inlineBefore = rawString.substring(i + 2).search(/^\s*?\S+\s*?\n/) !== -1;
- result.push(Object.assign({}, comment));
- comment = {}; // Skip the next loop as the / in */ is already checked
-
- i++;
- }
-
- break;
- }
-
- default:
- {
- var isNewline = character === "\r" && rawString[i + 1] === "\n" || character === "\n" && rawString[i - 1] !== "\r"; // //-comments end before newline and if the code string ends
-
- if (isNewline || i === rawString.length - 1) {
- if (mode === "comment" && modesEntered[lastModeIndex].character === "//") {
- comment.source.end = (isNewline ? i - 1 : i) + offset;
-
- var _commentRaw = rawString.substring(commentStart, isNewline ? i : i + 1);
-
- var _matches = /^(\/+)(\s*)(.*?)(\s*?)$/.exec(_commentRaw);
-
- modesEntered.pop();
- comment.raws = {
- startToken: _matches[1],
- left: _matches[2],
- text: _commentRaw,
- right: _matches[4]
- };
- comment.text = _matches[3];
- comment.inlineBefore = false;
- result.push(Object.assign({}, comment));
- comment = {}; // Compensate for the `*/` added by postcss-scss
-
- offset += 2;
- }
- }
-
- break;
- }
- }
- }
-
- return result;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/hasBlock.js b/assets/node_modules/stylelint-scss/dist/utils/hasBlock.js
deleted file mode 100644
index 1d21418..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/hasBlock.js
+++ /dev/null
@@ -1,16 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check if a statement has an block (empty or otherwise).
- *
- * @param {Rule|AtRule} statement - postcss rule or at-rule node
- * @return {boolean} True if `statement` has a block (empty or otherwise)
- */
-function _default(statement) {
- return statement.nodes !== undefined;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/hasEmptyLine.js b/assets/node_modules/stylelint-scss/dist/utils/hasEmptyLine.js
deleted file mode 100644
index 9f313ab..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/hasEmptyLine.js
+++ /dev/null
@@ -1,16 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check if a string contains at least one empty line
- *
- * @param {string} input
- * @return {boolean}
- */
-function _default(string) {
- return string && (string.includes("\n\n") || string.includes("\n\r\n"));
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/hasInterpolatingAmpersand.js b/assets/node_modules/stylelint-scss/dist/utils/hasInterpolatingAmpersand.js
deleted file mode 100644
index e2113ac..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/hasInterpolatingAmpersand.js
+++ /dev/null
@@ -1,37 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check whether a selector has an interpolating ampersand
- * An "interpolating ampersand" is an "&" used to interpolate within another
- * simple selector (e.g. `&-modifier`), rather than an "&" that stands
- * on its own as a simple selector (e.g. `& .child`)
- *
- * @param {string} selector
- * @return {boolean} If `true`, the selector has an interpolating ampersand
- */
-function _default(selector) {
- for (var i = 0; i < selector.length; i++) {
- if (selector[i] !== "&") {
- continue;
- }
-
- if (selector[i - 1] !== undefined && !isCombinator(selector[i - 1])) {
- return true;
- }
-
- if (selector[i + 1] !== undefined && !isCombinator(selector[i + 1])) {
- return true;
- }
- }
-
- return false;
-}
-
-function isCombinator(x) {
- return /[\s+>~]/.test(x);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/hasInterpolation.js b/assets/node_modules/stylelint-scss/dist/utils/hasInterpolation.js
deleted file mode 100644
index 5cf5dc2..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/hasInterpolation.js
+++ /dev/null
@@ -1,31 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-var _hasLessInterpolation = _interopRequireDefault(require("./hasLessInterpolation"));
-
-var _hasPsvInterpolation = _interopRequireDefault(require("./hasPsvInterpolation"));
-
-var _hasScssInterpolation = _interopRequireDefault(require("./hasScssInterpolation"));
-
-var _hasTplInterpolation = _interopRequireDefault(require("./hasTplInterpolation"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-/**
- * Check whether a string has interpolation
- *
- * @param {string} string
- * @return {boolean} If `true`, a string has interpolation
- */
-function _default(string) {
- // SCSS or Less interpolation
- if ((0, _hasLessInterpolation["default"])(string) || (0, _hasScssInterpolation["default"])(string) || (0, _hasTplInterpolation["default"])(string) || (0, _hasPsvInterpolation["default"])(string)) {
- return true;
- }
-
- return false;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/hasLessInterpolation.js b/assets/node_modules/stylelint-scss/dist/utils/hasLessInterpolation.js
deleted file mode 100644
index 32dabbf..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/hasLessInterpolation.js
+++ /dev/null
@@ -1,16 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check whether a string has less interpolation
- *
- * @param {string} string
- * @return {boolean} If `true`, a string has less interpolation
- */
-function _default(string) {
- return /@{.+?}/.test(string);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/hasPsvInterpolation.js b/assets/node_modules/stylelint-scss/dist/utils/hasPsvInterpolation.js
deleted file mode 100644
index 849de31..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/hasPsvInterpolation.js
+++ /dev/null
@@ -1,15 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check whether a string has postcss-simple-vars interpolation
- *
- * @param {string} string
- */
-function _default(string) {
- return /\$\(.+?\)/.test(string);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/hasScssInterpolation.js b/assets/node_modules/stylelint-scss/dist/utils/hasScssInterpolation.js
deleted file mode 100644
index f6fa421..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/hasScssInterpolation.js
+++ /dev/null
@@ -1,15 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check whether a string has scss interpolation
- *
- * @param {string} string
- */
-function _default(string) {
- return /#{.+?}/.test(string);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/hasTplInterpolation.js b/assets/node_modules/stylelint-scss/dist/utils/hasTplInterpolation.js
deleted file mode 100644
index b1ecb67..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/hasTplInterpolation.js
+++ /dev/null
@@ -1,16 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check whether a string has JS template literal interpolation or HTML-like template
- *
- * @param {string} string
- * @return {boolean} If `true`, a string has template literal interpolation
- */
-function _default(string) {
- return /{.+?}/.test(string);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/index.js b/assets/node_modules/stylelint-scss/dist/utils/index.js
deleted file mode 100644
index 8481111..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/index.js
+++ /dev/null
@@ -1,231 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-Object.defineProperty(exports, "addEmptyLineBefore", {
- enumerable: true,
- get: function get() {
- return _addEmptyLineBefore.addEmptyLineBefore;
- }
-});
-Object.defineProperty(exports, "atRuleBaseName", {
- enumerable: true,
- get: function get() {
- return _atRuleBaseName["default"];
- }
-});
-Object.defineProperty(exports, "atRuleParamIndex", {
- enumerable: true,
- get: function get() {
- return _atRuleParamIndex["default"];
- }
-});
-Object.defineProperty(exports, "beforeBlockString", {
- enumerable: true,
- get: function get() {
- return _beforeBlockString["default"];
- }
-});
-Object.defineProperty(exports, "blockString", {
- enumerable: true,
- get: function get() {
- return _blockString["default"];
- }
-});
-Object.defineProperty(exports, "declarationValueIndex", {
- enumerable: true,
- get: function get() {
- return _declarationValueIndex["default"];
- }
-});
-Object.defineProperty(exports, "eachRoot", {
- enumerable: true,
- get: function get() {
- return _eachRoot["default"];
- }
-});
-Object.defineProperty(exports, "findCommentsInRaws", {
- enumerable: true,
- get: function get() {
- return _findCommentsInRaws["default"];
- }
-});
-Object.defineProperty(exports, "hasBlock", {
- enumerable: true,
- get: function get() {
- return _hasBlock["default"];
- }
-});
-Object.defineProperty(exports, "hasEmptyLine", {
- enumerable: true,
- get: function get() {
- return _hasEmptyLine["default"];
- }
-});
-Object.defineProperty(exports, "hasInterpolatingAmpersand", {
- enumerable: true,
- get: function get() {
- return _hasInterpolatingAmpersand["default"];
- }
-});
-Object.defineProperty(exports, "isInlineComment", {
- enumerable: true,
- get: function get() {
- return _isInlineComment["default"];
- }
-});
-Object.defineProperty(exports, "isNativeCssFunction", {
- enumerable: true,
- get: function get() {
- return _isNativeCssFunction["default"];
- }
-});
-Object.defineProperty(exports, "isSingleLineString", {
- enumerable: true,
- get: function get() {
- return _isSingleLineString["default"];
- }
-});
-Object.defineProperty(exports, "isStandardRule", {
- enumerable: true,
- get: function get() {
- return _isStandardRule["default"];
- }
-});
-Object.defineProperty(exports, "isStandardSelector", {
- enumerable: true,
- get: function get() {
- return _isStandardSelector["default"];
- }
-});
-Object.defineProperty(exports, "isStandardSyntaxProperty", {
- enumerable: true,
- get: function get() {
- return _isStandardSyntaxProperty["default"];
- }
-});
-Object.defineProperty(exports, "isWhitespace", {
- enumerable: true,
- get: function get() {
- return _isWhitespace["default"];
- }
-});
-Object.defineProperty(exports, "namespace", {
- enumerable: true,
- get: function get() {
- return _namespace["default"];
- }
-});
-Object.defineProperty(exports, "optionsHaveException", {
- enumerable: true,
- get: function get() {
- return _optionsHaveException["default"];
- }
-});
-Object.defineProperty(exports, "optionsHaveIgnored", {
- enumerable: true,
- get: function get() {
- return _optionsHaveIgnored["default"];
- }
-});
-Object.defineProperty(exports, "parseFunctionArguments", {
- enumerable: true,
- get: function get() {
- return _parseFunctionArguments.parseFunctionArguments;
- }
-});
-Object.defineProperty(exports, "parseNestedPropRoot", {
- enumerable: true,
- get: function get() {
- return _parseNestedPropRoot["default"];
- }
-});
-Object.defineProperty(exports, "parseSelector", {
- enumerable: true,
- get: function get() {
- return _parseSelector["default"];
- }
-});
-Object.defineProperty(exports, "rawNodeString", {
- enumerable: true,
- get: function get() {
- return _rawNodeString["default"];
- }
-});
-Object.defineProperty(exports, "removeEmptyLinesBefore", {
- enumerable: true,
- get: function get() {
- return _removeEmptyLinesBefore.removeEmptyLinesBefore;
- }
-});
-Object.defineProperty(exports, "findOperators", {
- enumerable: true,
- get: function get() {
- return _sassValueParser["default"];
- }
-});
-Object.defineProperty(exports, "whitespaceChecker", {
- enumerable: true,
- get: function get() {
- return _whitespaceChecker["default"];
- }
-});
-
-var _addEmptyLineBefore = require("./addEmptyLineBefore");
-
-var _atRuleBaseName = _interopRequireDefault(require("./atRuleBaseName"));
-
-var _atRuleParamIndex = _interopRequireDefault(require("./atRuleParamIndex"));
-
-var _beforeBlockString = _interopRequireDefault(require("./beforeBlockString"));
-
-var _blockString = _interopRequireDefault(require("./blockString"));
-
-var _declarationValueIndex = _interopRequireDefault(require("./declarationValueIndex"));
-
-var _eachRoot = _interopRequireDefault(require("./eachRoot"));
-
-var _findCommentsInRaws = _interopRequireDefault(require("./findCommentsInRaws"));
-
-var _hasBlock = _interopRequireDefault(require("./hasBlock"));
-
-var _hasEmptyLine = _interopRequireDefault(require("./hasEmptyLine"));
-
-var _hasInterpolatingAmpersand = _interopRequireDefault(require("./hasInterpolatingAmpersand"));
-
-var _isInlineComment = _interopRequireDefault(require("./isInlineComment"));
-
-var _isNativeCssFunction = _interopRequireDefault(require("./isNativeCssFunction"));
-
-var _isSingleLineString = _interopRequireDefault(require("./isSingleLineString"));
-
-var _isStandardRule = _interopRequireDefault(require("./isStandardRule"));
-
-var _isStandardSelector = _interopRequireDefault(require("./isStandardSelector"));
-
-var _isStandardSyntaxProperty = _interopRequireDefault(require("./isStandardSyntaxProperty"));
-
-var _isWhitespace = _interopRequireDefault(require("./isWhitespace"));
-
-var _namespace = _interopRequireDefault(require("./namespace"));
-
-var _optionsHaveException = _interopRequireDefault(require("./optionsHaveException"));
-
-var _optionsHaveIgnored = _interopRequireDefault(require("./optionsHaveIgnored"));
-
-var _parseFunctionArguments = require("./parseFunctionArguments");
-
-var _parseNestedPropRoot = _interopRequireDefault(require("./parseNestedPropRoot"));
-
-var _parseSelector = _interopRequireDefault(require("./parseSelector"));
-
-var _rawNodeString = _interopRequireDefault(require("./rawNodeString"));
-
-var _removeEmptyLinesBefore = require("./removeEmptyLinesBefore");
-
-var _sassValueParser = _interopRequireDefault(require("./sassValueParser"));
-
-var _whitespaceChecker = _interopRequireDefault(require("./whitespaceChecker"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/isCustomPropertySet.js b/assets/node_modules/stylelint-scss/dist/utils/isCustomPropertySet.js
deleted file mode 100644
index 32aa0ce..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/isCustomPropertySet.js
+++ /dev/null
@@ -1,23 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-var _lodash = require("lodash");
-
-var _hasBlock = _interopRequireDefault(require("./hasBlock"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-/**
- * Check whether a Node is a custom property set
- *
- * @param {import('postcss').Rule} node
- * @returns {boolean}
- */
-function _default(node) {
- var selector = (0, _lodash.get)(node, "raws.selector.raw", node.selector);
- return node.type === "rule" && (0, _hasBlock["default"])(node) && selector.startsWith("--") && selector.endsWith(":");
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/isInlineComment.js b/assets/node_modules/stylelint-scss/dist/utils/isInlineComment.js
deleted file mode 100644
index 2b6d9d0..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/isInlineComment.js
+++ /dev/null
@@ -1,21 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = isInlineComment;
-
-/**
- * Check if a comment is inline one (i.e. on the same line as some non-comment
- * code). Only works with comments that are not ignored by PostCSS. To work
- * with those that are ignored use `findCommentInRaws`
- *
- * @param {Comment} comment - PostCSS comment node
- * @return {boolean} true, if the comment is an inline one
- */
-function isInlineComment(comment) {
- var nextNode = comment.next();
- var isBeforeSomething = !!nextNode && nextNode.type !== "comment" && comment.source.end.line === nextNode.source.start.line;
- var isAfterSomething = comment.raws.before.search(/\n/) === -1;
- return isAfterSomething || isBeforeSomething;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/isNativeCssFunction.js b/assets/node_modules/stylelint-scss/dist/utils/isNativeCssFunction.js
deleted file mode 100644
index f15c0b4..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/isNativeCssFunction.js
+++ /dev/null
@@ -1,17 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = isNativeCssFunction;
-var nativeCssFunctions = new Set(["annotation", "attr", "blur", "brightness", "calc", "character-variant", "circle", "contrast", "cross-fade", "cubic-bezier", "drop-shadow", "element", "ellipse", "fit-content", "format", "frames", "grayscale", "hsl", "hsla", "hue-rotate", "image", "image-set", "inset", "invert", "leader", "linear-gradient", "local", "matrix", "matrix3d", "minmax", "opacity", "ornaments", "perspective", "polygon", "radial-gradient", "rect", "repeat", "repeating-linear-gradient", "repeating-radial-gradient", "rgb", "rgba", "rotate", "rotate3d", "rotateX", "rotatex", "rotateY", "rotatey", "rotateZ", "rotatez", "saturate", "scale", "scale3d", "scaleX", "scalex", "scaleY", "scaley", "scaleZ", "scalez", "sepia", "skew", "skewX", "skewY", "steps", "styleset", "stylistic", "swash", "symbols", "target-counter", "target-counters", "target-text", "translate", "translate3d", "translateX", "translatex", "translateY", "translatey", "translateZ", "translatez", "url", "var"]);
-/**
- * Check if a function name is a native CSS function name.
- *
- * @param {string} functionName The name to check.
- * @returns {boolean} Whether or not the given function name is a native CSS function name.
- */
-
-function isNativeCssFunction(functionName) {
- return nativeCssFunctions.has(functionName);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/isSingleLineString.js b/assets/node_modules/stylelint-scss/dist/utils/isSingleLineString.js
deleted file mode 100644
index 8bc344e..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/isSingleLineString.js
+++ /dev/null
@@ -1,17 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check if a string is a single line (i.e. does not contain
- * any newline characters).
- *
- * @param {string} input
- * @return {boolean}
- */
-function _default(input) {
- return !/[\n\r]/.test(input);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/isStandardRule.js b/assets/node_modules/stylelint-scss/dist/utils/isStandardRule.js
deleted file mode 100644
index c33170f..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/isStandardRule.js
+++ /dev/null
@@ -1,75 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-var _lodash = require("lodash");
-
-var _isCustomPropertySet = _interopRequireDefault(require("./isCustomPropertySet"));
-
-var _isStandardSelector = _interopRequireDefault(require("./isStandardSelector"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-/**
- * Check whether a Node is a standard rule
- *
- * @param {import('postcss').Rule} rule
- * @returns {boolean}
- */
-function _default(rule) {
- // Get full selector
- var selector = (0, _lodash.get)(rule, "raws.selector.raw", rule.selector);
-
- if (!(0, _isStandardSelector["default"])(rule.selector)) {
- return false;
- } // Custom property set (e.g. --custom-property-set: {})
-
-
- if ((0, _isCustomPropertySet["default"])(rule)) {
- return false;
- } // Called Less mixin (e.g. a { .mixin() })
- // @ts-ignore TODO TYPES support LESS and SASS types somehow
-
-
- if (rule.mixin) {
- return false;
- } // Less detached rulesets
-
-
- if (selector.startsWith("@") && selector.endsWith(":")) {
- return false;
- } // Ignore Less &:extend rule
- // @ts-ignore TODO TYPES support LESS and SASS types somehow
-
-
- if (rule.extend) {
- return false;
- } // Ignore mixin or &:extend rule
- // https://github.com/shellscape/postcss-less/blob/master/lib/less-parser.js#L52
- // @ts-ignore TODO TYPES support LESS and SASS types somehow
-
-
- if (rule.params && rule.params[0]) {
- return false;
- } // Non-outputting Less mixin definition (e.g. .mixin() {})
-
-
- if (selector.endsWith(")") && !selector.includes(":")) {
- return false;
- } // Less guards
-
-
- if (/when\s+(not\s+)*\(/.test(selector)) {
- return false;
- } // Ignore Scss nested properties
-
-
- if (selector.endsWith(":")) {
- return false;
- }
-
- return true;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/isStandardSelector.js b/assets/node_modules/stylelint-scss/dist/utils/isStandardSelector.js
deleted file mode 100644
index 4f27e11..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/isStandardSelector.js
+++ /dev/null
@@ -1,30 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-var _isStandardSyntaxSelector = _interopRequireDefault(require("./isStandardSyntaxSelector"));
-
-var _hasInterpolation = _interopRequireDefault(require("./hasInterpolation"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-/**
- * Check whether a selector is standard
- *
- * @param {string} selector
- * @return {boolean} If `true`, the selector is standard
- */
-function _default(selector) {
- var standardSyntaxSelector = (0, _isStandardSyntaxSelector["default"])(selector); // SCSS placeholder selectors
-
- if (!standardSyntaxSelector) {
- if (selector.indexOf("%") === 0 && !(0, _hasInterpolation["default"])(selector)) {
- return true;
- }
- }
-
- return standardSyntaxSelector;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/isStandardSyntaxProperty.js b/assets/node_modules/stylelint-scss/dist/utils/isStandardSyntaxProperty.js
deleted file mode 100644
index 48bba67..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/isStandardSyntaxProperty.js
+++ /dev/null
@@ -1,40 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-var _hasInterpolation = _interopRequireDefault(require("./hasInterpolation"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-/**
- * Check whether a property is standard
- *
- * @param {string} property
- * @returns {boolean}
- */
-function _default(property) {
- // SCSS var (e.g. $var: x), list (e.g. $list: (x)) or map (e.g. $map: (key:value))
- if (property.startsWith("$")) {
- return false;
- } // Less var (e.g. @var: x)
-
-
- if (property.startsWith("@")) {
- return false;
- } // Less append property value with space (e.g. transform+_: scale(2))
-
-
- if (property.endsWith("+") || property.endsWith("+_")) {
- return false;
- } // SCSS or Less interpolation
-
-
- if ((0, _hasInterpolation["default"])(property)) {
- return false;
- }
-
- return true;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/isStandardSyntaxSelector.js b/assets/node_modules/stylelint-scss/dist/utils/isStandardSyntaxSelector.js
deleted file mode 100644
index 895ccb1..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/isStandardSyntaxSelector.js
+++ /dev/null
@@ -1,45 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-var _hasInterpolation = _interopRequireDefault(require("./hasInterpolation"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-/**
- * Check whether a selector is standard
- *
- * @param {string} selector
- * @returns {boolean}
- */
-function _default(selector) {
- // SCSS or Less interpolation
- if ((0, _hasInterpolation["default"])(selector)) {
- return false;
- } // SCSS placeholder selectors
-
-
- if (selector.startsWith("%")) {
- return false;
- } // Less :extend()
-
-
- if (/:extend(\(.*?\))?/.test(selector)) {
- return false;
- } // Less mixin with resolved nested selectors (e.g. .foo().bar or .foo(@a, @b)[bar])
-
-
- if (/\.[a-z0-9-_]+\(.*\).+/i.test(selector)) {
- return false;
- } // ERB template tags
-
-
- if (selector.includes("<%") || selector.includes("%>")) {
- return false;
- }
-
- return true;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/isWhitespace.js b/assets/node_modules/stylelint-scss/dist/utils/isWhitespace.js
deleted file mode 100644
index cbe2b72..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/isWhitespace.js
+++ /dev/null
@@ -1,16 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check if a character is whitespace.
- *
- * @param {string} char - A single character
- * @return {boolean}
- */
-function _default(_char) {
- return [" ", "\n", "\t", "\r", "\f"].includes(_char);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/namespace.js b/assets/node_modules/stylelint-scss/dist/utils/namespace.js
deleted file mode 100644
index 5de58b2..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/namespace.js
+++ /dev/null
@@ -1,11 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = namespace;
-var prefix = "scss";
-
-function namespace(ruleName) {
- return "".concat(prefix, "/").concat(ruleName);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/optionsHaveException.js b/assets/node_modules/stylelint-scss/dist/utils/optionsHaveException.js
deleted file mode 100644
index b1bf7d4..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/optionsHaveException.js
+++ /dev/null
@@ -1,19 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check if an options object contains a certain `except` keyword.
- * It will look for an `except` property whose value should
- * be an array of keywords.
- *
- * @param {object} options
- * @param {string} exceptionName
- * @return {boolean}
- */
-function _default(options, exceptionName) {
- return options && options.except && options.except.includes(exceptionName);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/optionsHaveIgnored.js b/assets/node_modules/stylelint-scss/dist/utils/optionsHaveIgnored.js
deleted file mode 100644
index 1dbc53e..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/optionsHaveIgnored.js
+++ /dev/null
@@ -1,19 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Check if an options object contains a certain `ignore` keyword.
- * It will look for an `ignore` property whose value should
- * be an array of keywords.
- *
- * @param {object} options
- * @param {string} ignoredName
- * @return {boolean}
- */
-function _default(options, ignoredName) {
- return options && options.ignore && options.ignore.includes(ignoredName);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/parseFunctionArguments.js b/assets/node_modules/stylelint-scss/dist/utils/parseFunctionArguments.js
deleted file mode 100644
index 3c9d19a..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/parseFunctionArguments.js
+++ /dev/null
@@ -1,77 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports.groupByKeyValue = groupByKeyValue;
-exports.mapToKeyValue = mapToKeyValue;
-exports.parseFunctionArguments = parseFunctionArguments;
-
-var _postcssValueParser = _interopRequireDefault(require("postcss-value-parser"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-function groupByKeyValue(nodes) {
- if (!nodes) {
- return [];
- }
-
- var groupIndex = 0;
- return nodes.reduce(function (acc, node, nodeIndex) {
- var isComma = node.type === "div" && node.value === ",";
- var skipTrailingComma = isComma && nodeIndex === nodes.length - 1;
-
- if (skipTrailingComma) {
- return acc;
- }
-
- if (isComma) {
- groupIndex++;
- }
-
- acc[groupIndex] = acc[groupIndex] || [];
-
- if (!isComma) {
- acc[groupIndex].push(node);
- }
-
- return acc;
- }, []);
-}
-
-function mapToKeyValue(nodes) {
- var keyVal = nodes.reduce(function (acc, curr, i) {
- if (acc.length === 1) {
- return acc;
- }
-
- var nextNode = nodes[i + 1];
- var isNextNodeColon = nextNode && nextNode.type === "div" && nextNode.value === ":";
-
- if (isNextNodeColon) {
- acc.push({
- key: _postcssValueParser["default"].stringify(nodes[i]),
- value: _postcssValueParser["default"].stringify(nodes.slice(2))
- });
- return acc;
- }
-
- acc.push({
- value: _postcssValueParser["default"].stringify(nodes)
- });
- return acc;
- }, []);
- return keyVal[0];
-}
-
-function parseFunctionArguments(value) {
- var parsed = (0, _postcssValueParser["default"])(value);
-
- if (!parsed.nodes[0] || parsed.nodes[0].type !== "function") {
- return [];
- }
-
- return parsed.nodes.map(function (node) {
- return groupByKeyValue(node.nodes).map(mapToKeyValue);
- })[0];
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/parseNestedPropRoot.js b/assets/node_modules/stylelint-scss/dist/utils/parseNestedPropRoot.js
deleted file mode 100644
index cc8c4fa..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/parseNestedPropRoot.js
+++ /dev/null
@@ -1,87 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = parseNestedPropRoot;
-
-/**
- * Attempts to parse a selector as if it"s a root for a group of nested props
- * E.g.: `margin: {`, `font: 10px/1.1 Arial {` ("{" excluded)
- */
-function parseNestedPropRoot(propString) {
- var modesEntered = [{
- mode: "normal",
- character: null,
- isCalculationEnabled: true
- }];
- var result = {};
- var lastModeIndex = 0;
- var propName = "";
-
- for (var i = 0; i < propString.length; i++) {
- var character = propString[i];
- var prevCharacter = propString[i - 1]; // If entering/exiting a string
-
- if (character === '"' || character === "'") {
- if (modesEntered[lastModeIndex].isCalculationEnabled === true) {
- modesEntered.push({
- mode: "string",
- isCalculationEnabled: false,
- character: character
- });
- lastModeIndex++;
- } else if (modesEntered[lastModeIndex].mode === "string" && modesEntered[lastModeIndex].character === character && prevCharacter !== "\\") {
- modesEntered.pop();
- lastModeIndex--;
- }
- } // If entering/exiting interpolation
-
-
- if (character === "{") {
- modesEntered.push({
- mode: "interpolation",
- isCalculationEnabled: true
- });
- lastModeIndex++;
- } else if (character === "}") {
- modesEntered.pop();
- lastModeIndex--;
- } // Check for : outside fn call, string or interpolation. It must be at the
- // end of a string or have a whitespace between it and following value
-
-
- if (modesEntered[lastModeIndex].mode === "normal" && character === ":" && prevCharacter !== "\\") {
- var propValueStr = propString.substring(i + 1);
-
- if (propValueStr.length) {
- var propValue = {
- before: /^(\s*)/.exec(propValueStr)[1],
- value: propValueStr.trim()
- }; // It's a declaration if 1) there is a whitespace after :, or
- // 2) the value is a number with/without a unit (starts with a number
- // or a dot), or
- // 3) the value is a variable (starts with $), or
- // 4) the value a string, surprisingly
-
- if (propValue.before === "" && !/^[0-9.$'"]/.test(propValue.value)) {
- return null;
- } // +1 for the colon
-
-
- propValue.sourceIndex = propValue.before.length + i + 1;
- result.propValue = propValue;
- }
-
- result.propName = {
- after: /(\s*)$/.exec(propName)[1],
- value: propName.trim()
- };
- return result;
- }
-
- propName += character;
- }
-
- return null;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/parseSelector.js b/assets/node_modules/stylelint-scss/dist/utils/parseSelector.js
deleted file mode 100644
index 3d3fbfc..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/parseSelector.js
+++ /dev/null
@@ -1,20 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-var _postcssSelectorParser = _interopRequireDefault(require("postcss-selector-parser"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-function _default(selector, result, node, cb) {
- try {
- (0, _postcssSelectorParser["default"])(cb).process(selector);
- } catch (e) {
- result.warn("Cannot parse selector", {
- node: node
- });
- }
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/rawNodeString.js b/assets/node_modules/stylelint-scss/dist/utils/rawNodeString.js
deleted file mode 100644
index a4496b5..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/rawNodeString.js
+++ /dev/null
@@ -1,23 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-/**
- * Stringify PostCSS node including its raw "before" string.
- *
- * @param {Node} node - Any PostCSS node
- * @return {string}
- */
-function _default(node) {
- var result = "";
-
- if (node.raws.before) {
- result += node.raws.before;
- }
-
- result += node.toString();
- return result;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/removeEmptyLinesBefore.js b/assets/node_modules/stylelint-scss/dist/utils/removeEmptyLinesBefore.js
deleted file mode 100644
index 29a75a1..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/removeEmptyLinesBefore.js
+++ /dev/null
@@ -1,18 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports.removeEmptyLinesBefore = removeEmptyLinesBefore;
-
-// Remove empty lines before a node. Mutates the node.
-function removeEmptyLinesBefore(node
-/*: postcss$node*/
-, newline
-/*: '\n' | '\r\n'*/
-)
-/*: postcss$node*/
-{
- node.raws.before = node.raws.before.replace(/(\r?\n\s*\r?\n)+/g, newline);
- return node;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/sassValueParser/index.js b/assets/node_modules/stylelint-scss/dist/utils/sassValueParser/index.js
deleted file mode 100644
index 8328a46..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/sassValueParser/index.js
+++ /dev/null
@@ -1,933 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = findOperators;
-exports.mathOperatorCharType = mathOperatorCharType;
-
-/**
- * Processes a string and finds Sass operators in it
- *
- * @param {Object} args - Named arguments object
- * @param {String} args.string - the input string
- * @param {Number} args.index - the position of args.string from the start of the line
- * @param {Boolean} args.isAfterColon - pass "true" if the string is
- * a variable value, a mixin/function parameter default.
- * In such cases + and / tend to be operations more often
- * @param {Function} args.callback - will be called on every instance of
- * an operator. Accepts parameters:
- * • string - the default source string
- * • globalIndex - the string's position in the outer input
- * • startIndex - index in string, where the operator starts
- * • endIndex - index in string, where the operator ends (for `==`, etc.)
- *
- * @return {Array} array of { symbol, globalIndex, startIndex, endIndex }
- * for each operator found within a string
- */
-function findOperators(_ref) {
- var string = _ref.string,
- globalIndex = _ref.globalIndex,
- isAfterColon = _ref.isAfterColon,
- callback = _ref.callback;
- var mathOperators = ["+", "/", "-", "*", "%"]; // A stack of modes activated for the current char: string, interpolation
- // Calculations inside strings are not processed, so spaces are not linted
-
- var modesEntered = [{
- mode: "normal",
- isCalculationEnabled: true,
- character: null
- }];
- var result = [];
- var lastModeIndex = 0;
-
- for (var i = 0; i < string.length; i++) {
- var character = string[i];
- var substringStartingWithIndex = string.substring(i);
- var lastMode = modesEntered[lastModeIndex]; // If entering/exiting a string
-
- if (character === '"' || character === "'") {
- if (lastMode && lastMode.isCalculationEnabled === true) {
- modesEntered.push({
- mode: "string",
- isCalculationEnabled: false,
- character: character
- });
- lastModeIndex++;
- } else if (lastMode && lastMode.mode === "string" && lastMode.character === character && string[i - 1] !== "\\") {
- modesEntered.pop();
- lastModeIndex--;
- }
- } // If entering/exiting interpolation (may be inside a string)
- // Comparing with length-2 because `#{` at the very end doesnt matter
-
-
- if (character === "#" && i + 1 < string.length - 2 && string[i + 1] === "{") {
- modesEntered.push({
- mode: "interpolation",
- isCalculationEnabled: true
- });
- lastModeIndex++;
- } else if (character === "}") {
- modesEntered.pop();
- lastModeIndex--;
- } // Don't lint if inside a string
-
-
- if (lastMode && lastMode.isCalculationEnabled === false) {
- continue;
- } // If it's a math operator
-
-
- if (mathOperators.includes(character) && mathOperatorCharType(string, i, isAfterColon) === "op" || // or is "<" or ">"
- substringStartingWithIndex.search(/^[<>]([^=]|$)/) !== -1) {
- result.push({
- symbol: string[i],
- globalIndex: globalIndex,
- startIndex: i,
- endIndex: i
- });
-
- if (callback) {
- callback(string, globalIndex, i, i);
- }
- } // "<=", ">=", "!=", "=="
-
-
- if (substringStartingWithIndex.search(/^[><=!]=/) !== -1) {
- result.push({
- symbol: string[i],
- globalIndex: globalIndex,
- startIndex: i,
- endIndex: i + 1
- });
-
- if (callback) {
- callback(string, globalIndex, i, i + 1);
- }
- }
- } // result.length > 0 && console.log(string, result)
-
-
- return result;
-}
-/**
- * Checks if a character is an operator, a sign (+ or -), or part of a string
- *
- * @param {String} string - the source string
- * @param {Number} index - the index of the character in string to check
- * @param {Boolean} isAfterColon - if the value string a variable
- * value, a mixin/function parameter default. In such cases + and / tend
- * to be operations more often
- * @return {String|false}
- * • "op", if the character is a operator in a math/string operation
- * • "sign" if it is a + or - before a numeric,
- * • "char" if it is a part of a string,
- * • false - if it is none from above (most likely an error)
- */
-
-
-function mathOperatorCharType(string, index, isAfterColon) {
- // !Checking here to prevent unnecessary calculations and deep recursion
- // when calling isPrecedingOperator()
- if (!["+", "/", "-", "*", "%"].includes(string[index])) {
- return "char";
- }
-
- var character = string[index];
- var prevCharacter = string[index - 1];
-
- if (prevCharacter !== "\\") {
- // ---- Processing + characters
- if (character === "+") {
- return checkPlus(string, index, isAfterColon);
- } // ---- Processing - characters
-
-
- if (character === "-") {
- return checkMinus(string, index);
- } // ---- Processing * character
-
-
- if (character === "*") {
- return "op";
- } // ---- Processing % character
-
-
- if (character === "%") {
- return checkPercent(string, index);
- } // ---- Processing / character
- // https://sass-lang.com/documentation/operators/numeric#slash-separated-values
-
-
- if (character === "/") {
- return checkSlash(string, index, isAfterColon);
- }
- }
-
- return "char";
-} // --------------------------------------------------------------------------
-// Functions for checking particular characters (+, -, /)
-// --------------------------------------------------------------------------
-
-/**
- * Checks the specified `+` char type: operator, sign (+ or -), part of string
- *
- * @param {String} string - the source string
- * @param {Number} index - the index of the character in string to check
- * @param {Boolean} isAftercolon - if the value string a variable
- * value, a mixin/function parameter default. In such cases + is always an
- * operator if surrounded by numbers/values with units
- * @return {String|false}
- * • "op", if the character is a operator in a math/string operation
- * • "sign" if it is a sign before a positive number,
- * • false - if it is none from above (most likely an error)
- */
-
-
-function checkPlus(string, index, isAftercolon) {
- var before = string.substring(0, index);
- var after = string.substring(index + 1); // If the character is at the beginning of the input
-
- var isAtStart_ = isAtStart(string, index); // If the character is at the end of the input
-
- var isAtEnd_ = isAtEnd(string, index);
- var isWhitespaceBefore = before.search(/\s$/) !== -1;
- var isWhitespaceAfter = after.search(/^\s/) !== -1;
- var isValueWithUnitAfter_ = isValueWithUnitAfter(after);
- var isNumberAfter_ = isNumberAfter(after);
- var isInterpolationAfter_ = isInterpolationAfter(after); // The early check above helps prevent deep recursion here
-
- var isPrecedingOperator_ = isPrecedingOperator(string, index);
-
- if (isAtStart_) {
- // console.log("+, `+<sth>` or `+ <sth>`")
- return "sign";
- } // E.g. `1+1`, `string+#fff`
-
-
- if (!isAtStart_ && !isWhitespaceBefore && !isAtEnd_ && !isWhitespaceAfter) {
- // E.g. `1-+1`
- if (isPrecedingOperator_) {
- // console.log('1+1')
- return "sign";
- } // console.log("+, no spaces")
-
-
- return "op";
- } // e.g. `something +something`
-
-
- if (!isAtEnd_ && !isWhitespaceAfter) {
- // e.g. `+something`, ` ... , +something`, etc.
- if (isNoOperandBefore(string, index)) {
- // console.log("+, nothing before")
- return "sign";
- } // e.g. `sth +10px`, `sth +1`
-
-
- if (isValueWithUnitAfter_.is && !isValueWithUnitAfter_.opsBetween || isNumberAfter_.is && !isNumberAfter_.opsBetween) {
- if (isAftercolon === true) {
- // console.log(": 10px +1")
- return "op";
- } // e.g. `(sth +10px)`, `fun(sth +1)`
-
-
- if (isInsideParens(string, index) || isInsideFunctionCall(string, index).is) {
- // console.log("+10px or +1, inside function or parens")
- return "op";
- } // e.g. `#{10px +1}`
-
-
- if (isInsideInterpolation(string, index)) {
- // console.log('+, #{10px +1}')
- return "op";
- } // console.log('+, default')
-
-
- return "sign";
- } // e.g. `sth +#fff`, `sth +string`, `sth +#{...}`, `sth +$var`
-
-
- if (isStringAfter(after) || isHexColorAfter(after) || after[0] === "$" || isInterpolationAfter_.is && !isInterpolationAfter_.opsBefore) {
- // e.g. `sth+ +string`
- if (isPrecedingOperator_) {
- // console.log("+10px or +1, before is an operator")
- return "sign";
- } // console.log("+#000, +string, +#{sth}, +$var")
-
-
- return "op";
- } // console.log('sth +sth, default')
-
-
- return "op";
- } // If the + is after a value, e.g. `$var+`
-
-
- if (!isAtStart_ && !isWhitespaceBefore) {
- // It is always an operator. Prior to Sass 4, `#{...}+` was differernt,
- // but that's not logical and had been fixed.
- // console.log('1+ sth')
- return "op";
- } // If it has whitespaces on both sides
- // console.log('sth + sth')
-
-
- return "op";
-}
-/**
- * Checks the specified `-` character: operator, sign (+ or -), part of string
- *
- * @param {String} string - the source string
- * @param {Number} index - the index of the character in string to check
- * @return {String|false}
- * • "op", if the character is a operator in a math/string operation
- * • "sign" if it is a sign before a negative number,
- * • "char" if it is a part of a string or identifier,
- * • false - if it is none from above (most likely an error)
- */
-
-
-function checkMinus(string, index) {
- var before = string.substring(0, index);
- var after = string.substring(index + 1); // If the character is at the beginning of the input
-
- var isAtStart_ = isAtStart(string, index); // If the character is at the end of the input
-
- var isAtEnd_ = isAtEnd(string, index);
- var isWhitespaceBefore = before.search(/\s$/) !== -1;
- var isWhitespaceAfter = after.search(/^\s/) !== -1;
- var isValueWithUnitAfter_ = isValueWithUnitAfter(after);
- var isValueWithUnitBefore_ = isValueWithUnitBefore(before);
- var isNumberAfter_ = isNumberAfter(after);
- var isNumberBefore_ = isNumberBefore(before);
- var isInterpolationAfter_ = isInterpolationAfter(after);
- var isParensAfter_ = isParensAfter(after);
- var isParensBefore_ = isParensBefore(before); // The early check above helps prevent deep recursion here
-
- var isPrecedingOperator_ = isPrecedingOperator(string, index);
-
- if (isAtStart_) {
- // console.log("-, -<sth> or - <sth>")
- return "sign";
- } // `10 - 11`
-
-
- if (!isAtEnd_ && !isAtStart_ && isWhitespaceBefore && isWhitespaceAfter) {
- // console.log("-, Op: 10px - 10px")
- return "op";
- } // e.g. `something -10px`
-
-
- if (!isAtEnd_ && !isAtStart_ && isWhitespaceBefore && !isWhitespaceAfter) {
- if (isParensAfter_.is && !isParensAfter_.opsBefore) {
- // console.log("-, Op: <sth> -(...)")
- return "op";
- } // e.g. `#{10px -1}`
-
-
- if (isInsideInterpolation(string, index)) {
- return "op";
- } // e.g. `sth -1px`, `sth -1`.
- // Always a sign, even inside parens/function args
-
-
- if (isValueWithUnitAfter_.is && !isValueWithUnitAfter_.opsBetween || isNumberAfter_.is && !isNumberAfter_.opsBetween) {
- // console.log("-, sign: -1px or -1")
- return "sign";
- } // e.g. `sth --1`, `sth +-2px`
-
-
- if (isValueWithUnitAfter_.is && isValueWithUnitAfter_.opsBetween || isNumberAfter_.is && isNumberAfter_.opsBetween) {
- // console.log("-, op: --1px or --1")
- return "op";
- } // `<sth> -string`, `<sth> -#{...}`
-
-
- if (isStringAfter(after) || isInterpolationAfter_.is && !isInterpolationAfter_.opsBefore) {
- // console.log("-, char: -#{...}")
- return "char";
- } // e.g. `#0af -#f0a`, and edge-cases can take a hike
-
-
- if (isHexColorAfter(after) && isHexColorBefore(before.trim())) {
- // console.log("-, op: #fff-, -#fff")
- return "op";
- } // If the - is before a variable, than it's most likely an operator
-
-
- if (after[0] === "$") {
- if (isPrecedingOperator_) {
- // console.log("-, sign: -$var, another operator before")
- return "sign";
- } // console.log("-, op: -$var, NO other operator before")
-
-
- return "op";
- } // By default let's make it an sign for now
- // console.log('-, sign: default in <sth> -<sth>')
-
-
- return "sign";
- } // No whitespace before,
- // e.g. `10x- something`
-
-
- if (!isAtEnd_ && !isAtStart_ && !isWhitespaceBefore && isWhitespaceAfter) {
- if (isParensBefore_) {
- // console.log('-, op: `(...)- <sth>`')
- return "op";
- } // e.g. `#{10px- 1}`
-
-
- if (isInsideInterpolation(string, index)) {
- return "op";
- }
-
- if (isNumberBefore(before) || isHexColorBefore(before)) {
- // console.log('`-, op: 10- <sth>, #aff- <sth>`')
- return "op";
- } // console.log('-, char: default in <sth>- <sth>')
-
-
- return "char";
- } // NO Whitespace,
- // e.g. `10px-1`
-
-
- if (!isAtEnd_ && !isAtStart_ && !isWhitespaceBefore && !isWhitespaceAfter) {
- // console.log('no spaces')
- // `<something>-1`, `<something>-10px`
- if (isValueWithUnitAfter_.is && !isValueWithUnitAfter_.opsBetween || isNumberAfter_.is && !isNumberAfter_.opsBetween) {
- // `10px-1`, `1-10px`, `1-1`, `1x-1x`
- if (isValueWithUnitBefore_ || isNumberBefore_) {
- // console.log("-, op: 1-10px")
- return "op";
- } // The - could be a "sign" here, but for now "char" does the job
-
- } // `1-$var`
-
-
- if (isNumberBefore_ && after[0] === "$") {
- // console.log("-, op: 1-$var")
- return "op";
- } // `fn()-10px`
-
-
- if (isFunctionBefore(before) && (isNumberAfter_.is && !isNumberAfter_.opsBetween || isValueWithUnitAfter_.is && !isValueWithUnitAfter_.opsBetween)) {
- // console.log("-, op: fn()-10px")
- return "op";
- }
- } // And in all the other cases it's a characher inside a string
- // console.log("-, default: char")
-
-
- return "char";
-}
-/**
- * Checks the specified `/` character: operator, sign (+ or -), part of string
- *
- * @param {String} string - the source string
- * @param {Number} index - the index of the character in string to check
- * @param {Boolean} isAfterColon - if the value string a variable
- * value, a mixin/function parameter default. In such cases / is always an
- * operator if surrounded by numbers/values with units
- * @return {String|false}
- * • "op", if the character is a operator in a math/string operation
- * • "char" if it gets compiled as-is, e.g. `font: 10px/1.2;`,
- * • false - if it is none from above (most likely an error)
- */
-
-
-function checkSlash(string, index, isAfterColon) {
- // Trimming these, as spaces before/after a slash don't matter
- var before = string.substring(0, index).trim();
- var after = string.substring(index + 1).trim();
- var isValueWithUnitAfter_ = isValueWithUnitAfter(after);
- var isValueWithUnitBefore_ = isValueWithUnitBefore(before);
- var isNumberAfter_ = isNumberAfter(after);
- var isNumberBefore_ = isNumberBefore(before);
- var isParensAfter_ = isParensAfter(after);
- var isParensBefore_ = isParensBefore(before); // FIRST OFF. Interpolation on any of the sides is a NO-GO for division op
-
- if (isInterpolationBefore(before).is || isInterpolationAfter(after).is) {
- // console.log("/, interpolation")
- return "char";
- } // having a dot before propbably means a relative path.
- // e.g. url(../../image.png)
-
-
- if (isDotBefore(before)) {
- return "char";
- } // e.g. `(1px/1)`, `fn(7 / 15)`, but not `url(8/11)`
-
-
- var isInsideFn = isInsideFunctionCall(string, index);
-
- if (isInsideFn.is && isInsideFn.fn === "url" && isProtocolBefore(before)) {
- return "char";
- } // e.g. `10px/normal`
-
-
- if (isStringBefore(before).is || isStringAfter(after)) {
- // console.log("/, string")
- return "char";
- } // For all other value options (numbers, value+unit, hex color)
- // `$var/1`, `#fff/-$var`
- // Here we don't care if there is a sign before the var
-
-
- if (isVariableBefore(before) || isVariableAfter(after).is) {
- // console.log("/, variable")
- return "op";
- }
-
- if (isFunctionBefore(before) || isFunctionAfter(after).is) {
- // console.log("/, function as operand")
- return "op";
- }
-
- if (isParensBefore_ || isParensAfter_.is) {
- // console.log("/, function as operand")
- return "op";
- } // `$var: 10px/2; // 5px`
-
-
- if (isAfterColon === true && (isValueWithUnitAfter_.is || isNumberAfter_.is) && (isValueWithUnitBefore_ || isNumberBefore_)) {
- return "op";
- } // Quick check of the following operator symbol - if it is a math operator
-
-
- if ( // +, *, % count as operators unless after interpolation or at the start
- before.search(/[^{,(}\s]\s*[+*%]\s*[^(){},]+$/) !== -1 || // We consider minus as op only if surrounded by whitespaces (` - `);
- before.search(/[^{,(}\s]\s+-\s+[^(){},]+$/) !== -1 || // `10/2 * 3`, `10/2 % 3`, with or without spaces
- after.search(/^[^(){},]+[*%]/) !== -1 || // `10px/2px+1`, `10px/2px+ 1`
- after.search(/^[^(){},\s]+[+]/) !== -1 || // Anything but `10px/2px +1`, `10px/2px +1px`
- after.search(/^[^(){},\s]+\s+(\+\D)/) !== -1 || // Following ` -`: only if `$var` after (`10/10 -$var`)
- after.search(/^[^(){},\s]+\s+-(\$|\s)/) !== -1 || // Following `-`: only if number after (`10s/10s-10`, `10s/10s-.1`)
- after.search(/^[^(){},\s]+-(\.){0,1}\d/) !== -1 || // Or if there is a number before anything but string after (not `10s/1-str`,)
- after.search(/^(\d*\.){0,1}\d+-\s*[^#a-zA-Z_\s]/) !== -1) {
- // console.log("/, math op around")
- return "op";
- }
-
- if (isInsideParens(string, index) || isInsideFn.is && isInsideFn.fn !== "url") {
- // console.log("/, parens or function arg")
- return "op";
- } // console.log("/, default")
-
-
- return "char";
-}
-/**
- * Checks the specified `%` character: operator or part of value
- *
- * @param {String} string - the source string
- * @param {Number} index - the index of the character in string to check
- * @return {String|false}
- * • "op", if the character is a operator in a math/string operation
- * • "char" if it gets compiled as-is, e.g. `width: 10%`,
- * • false - if it is none from above (most likely an error)
- */
-
-
-function checkPercent(string, index) {
- // Trimming these, as spaces before/after a slash don't matter
- var before = string.substring(0, index);
- var after = string.substring(index + 1); // If the character is at the beginning of the input
-
- var isAtStart_ = isAtStart(string, index); // If the character is at the end of the input
-
- var isAtEnd_ = isAtEnd(string, index);
- var isWhitespaceBefore = before.search(/\s$/) !== -1;
- var isWhitespaceAfter = after.search(/^\s/) !== -1;
- var isParensBefore_ = isParensBefore(before); // FIRST OFF. Interpolation on any of the sides is a NO-GO
-
- if (isInterpolationBefore(before.trim()).is || isInterpolationAfter(after.trim()).is) {
- // console.log("%, interpolation")
- return "char";
- }
-
- if (isAtStart_ || isAtEnd_) {
- // console.log("%, start/end")
- return "char";
- } // In `<sth> %<sth>` it's most likely an operator (except for inteprolation
- // checked above)
-
-
- if (isWhitespaceBefore && !isWhitespaceAfter) {
- // console.log("%, `<sth> %<sth>`")
- return "op";
- } // `$var% 1`, `$var%1`, `$var%-1`
-
-
- if (isVariableBefore(before) || isParensBefore_) {
- // console.log("%, after a variable, function or parens")
- return "op";
- } // in all other cases in `<sth>% <sth>` it is most likely a unit
-
-
- if (!isWhitespaceBefore && isWhitespaceAfter) {
- // console.log("%, `<sth>% <sth>`")
- return "char";
- } // console.log("%, default")
-
-
- return "char";
-} // --------------------------------------------------------------------------
-// Lots of elementary helpers
-// --------------------------------------------------------------------------
-
-
-function isAtStart(string, index) {
- var before = string.substring(0, index).trim();
- return before.length === 0 || before.search(/[({,]$/) !== -1;
-}
-
-function isAtEnd(string, index) {
- var after = string.substring(index + 1).trim();
- return after.length === 0 || after.search(/^[,)}]/) !== -1;
-}
-
-function isInsideParens(string, index) {
- var before = string.substring(0, index).trim();
- var after = string.substring(index + 1).trim();
-
- if (before.search(/(?:^|[,{]|\s)\(\s*[^(){},]+$/) !== -1 && after.search(/^[^(){},\s]+\s*\)/) !== -1) {
- return true;
- }
-
- return false;
-}
-
-function isInsideInterpolation(string, index) {
- var before = string.substring(0, index).trim();
-
- if (before.search(/#\{[^}]*$/) !== -1) {
- return true;
- }
-
- return false;
-}
-/**
- * Checks if the character is inside a function agruments
- *
- * @param {String} string - the input string
- * @param {Number} index - current character index
- * @return {Object} return
- * {Boolean} return.is - if inside a function arguments
- * {String} return.fn - function name
- */
-
-
-function isInsideFunctionCall(string, index) {
- var result = {
- is: false,
- fn: null
- };
- var before = string.substring(0, index).trim();
- var after = string.substring(index + 1).trim();
- var beforeMatch = before.match(/([a-zA-Z_-][a-zA-Z0-9_-]*)\([^(){},]+$/);
-
- if (beforeMatch && beforeMatch[0] && after.search(/^[^(,]+\)/) !== -1) {
- result.is = true;
- result.fn = beforeMatch[1];
- }
-
- return result;
-}
-/**
- * Checks if there is a string before the character.
- * Also checks if there is a math operator in between
- *
- * @param {String} before - the input string that preceses the character
- * @return {Object} return
- * {Boolean} return.is - if there is a string
- * {String} return.opsBetween - if there are operators in between
- */
-
-
-function isStringBefore(before) {
- var result = {
- is: false,
- opsBetween: false
- };
- var stringOpsClipped = before.replace(/(\s*[+/*%]|\s+-)+$/, "");
-
- if (stringOpsClipped !== before) {
- result.opsBetween = true;
- } // If it is quoted
-
-
- if (stringOpsClipped[stringOpsClipped.length - 1] === '"' || stringOpsClipped[stringOpsClipped.length - 1] === "'") {
- result.is = true;
- } else if (stringOpsClipped.search(/(?:^|[/(){},: ])([a-zA-Z_][a-zA-Z_0-9-]*|-+[a-zA-Z_]+[a-zA-Z_0-9-]*)$/) !== -1) {
- // First pattern: a1, a1a, a-1,
- result.is = true;
- }
-
- return result;
-}
-
-function isStringAfter(after) {
- var stringTrimmed = after.trim(); // If it is quoted
-
- if (stringTrimmed[0] === '"' || stringTrimmed[0] === "'") return true; // e.g. `a1`, `a1a`, `a-1`, and even `--s323`
-
- if (stringTrimmed.search(/^([a-zA-Z_][a-zA-Z_0-9-]*|-+[a-zA-Z_]+[a-zA-Z_0-9-]*)(?:$|[)}, ])/) !== -1) return true;
- return false;
-}
-
-function isInterpolationAfter(after) {
- var result = {
- is: false,
- opsBetween: false
- };
- var matches = after.match(/^\s*([+/*%-]\s*)*#{/);
-
- if (matches) {
- if (matches[0]) {
- result.is = true;
- }
-
- if (matches[1]) {
- result.opsBetween = true;
- }
- }
-
- return result;
-}
-
-function isParensAfter(after) {
- var result = {
- is: false,
- opsBetween: false
- };
- var matches = after.match(/^\s*([+/*%-]\s*)*\(/);
-
- if (matches) {
- if (matches[0]) {
- result.is = true;
- }
-
- if (matches[1]) {
- result.opsBetween = true;
- }
- }
-
- return result;
-}
-
-function isParensBefore(before) {
- return before.search(/\)\s*$/) !== -1;
-}
-/**
- * Checks if there is an interpolation before the character.
- * Also checks if there is a math operator in between
- *
- * @param {String} before - the input string that preceses the character
- * @return {Object} return
- * {Boolean} return.is - if there is an interpolation
- * {String} return.opsBetween - if there are operators in between
- */
-
-
-function isInterpolationBefore(before) {
- var result = {
- is: false,
- opsBetween: false
- }; // Removing preceding operators if any
-
- var beforeOpsClipped = before.replace(/(\s*[+/*%-])+$/, "");
-
- if (beforeOpsClipped !== before) {
- result.opsBetween = true;
- }
-
- if (beforeOpsClipped[beforeOpsClipped.length - 1] === "}") {
- result.is = true;
- }
-
- return result;
-}
-
-function isValueWithUnitBefore(before) {
- // 1px, 0.1p-x, .2p-, 11.2pdf-df1df_
- // Surprisingly, ` d.10px` - .10px is separated from a sequence
- // and is considered a value with a unit
- if (before.trim().search(/(^|[/(, ]|\.)\d[a-zA-Z_0-9-]+$/) !== -1) {
- return true;
- }
-
- return false;
-}
-
-function isValueWithUnitAfter(after) {
- var result = {
- is: false,
- opsBetween: false
- }; // 1px, 0.1p-x, .2p-, 11.2pdf-dfd1f_
- // Again, ` d.10px` - .10px is separated from a sequence
- // and is considered a value with a unit
-
- var matches = after.match(/^\s*([+/*%-]\s*)*(\d+(\.\d+){0,1}|\.\d+)[a-zA-Z_0-9-]+(?:$|[)}, ])/);
-
- if (matches) {
- if (matches[0]) {
- result.is = true;
- }
-
- if (matches[1]) {
- result.opsBetween = true;
- }
- }
-
- return result;
-}
-
-function isNumberAfter(after) {
- var result = {
- is: false,
- opsBetween: false
- };
- var matches = after.match(/^\s*([+/*%-]\s*)*(\d+(\.\d+){0,1}|\.\d+)(?:$|[)}, ])/);
-
- if (matches) {
- if (matches[0]) {
- result.is = true;
- }
-
- if (matches[1]) {
- result.opsBetween = true;
- }
- }
-
- return result;
-}
-
-function isNumberBefore(before) {
- if (before.trim().search(/(?:^|[/(){},\s])(\d+(\.\d+){0,1}|\.\d+)$/) !== -1) {
- return true;
- }
-
- return false;
-}
-
-function isVariableBefore(before) {
- return before.trim().search(/\$[a-zA-Z_0-9-]+$/) !== -1;
-}
-
-function isVariableAfter(after) {
- var result = {
- is: false,
- opsBetween: false
- };
- var matches = after.match(/^\s*([+/*%-]\s*)*\$/);
-
- if (matches) {
- if (matches[0]) {
- result.is = true;
- }
-
- if (matches[1]) {
- result.opsBetween = true;
- }
- }
-
- return result;
-}
-
-function isDotBefore(before) {
- return before.slice(-1) === ".";
-}
-
-function isProtocolBefore(before) {
- return before.search(/https?:/) !== -1;
-}
-
-function isFunctionBefore(before) {
- return before.trim().search(/[a-zA-Z0-9_-]\(.*?\)\s*$/) !== -1;
-}
-
-function isFunctionAfter(after) {
- var result = {
- is: false,
- opsBetween: false
- }; // `-fn()` is a valid function name, so if a - should be a sign/operator,
- // it must have a space after
-
- var matches = after.match(/^\s*(-\s+|[+/*%]\s*)*[a-zA-Z_-][a-zA-Z_0-9-]*\(/);
-
- if (matches) {
- if (matches[0]) {
- result.is = true;
- }
-
- if (matches[1]) {
- result.opsBetween = true;
- }
- }
-
- return result;
-}
-/**
- * Checks if the input string is a hex color value
- *
- * @param {String} string - the input
- * @return {Boolean} true, if the input is a hex color
- */
-
-
-function isHexColor(string) {
- return string.trim().search(/^#([0-9a-fA-F]{3}|[0-9a-fA-F]{6})$/) !== -1;
-}
-
-function isHexColorAfter(after) {
- var afterTrimmed = after.match(/(.*?)(?:[)},+/*%-]|\s|$)/)[1].trim();
- return isHexColor(afterTrimmed);
-}
-
-function isHexColorBefore(before) {
- if (before.search(/(?:[/(){},+*%-\s]|^)#([0-9a-fA-F]{3}|[0-9a-fA-F]{6})$/) !== -1) {
- return true;
- }
-
- return false;
-}
-/**
- * Checks if there is no operand before the currenc char
- * In other words, the current char is at the start of a possible operation,
- * e.g. at the string start, after the opening paren or after a comma
- *
- * @param {String} string - the input string
- * @param {Number} index - current char's position in string
- * @return {Boolean}
- */
-
-
-function isNoOperandBefore(string, index) {
- var before = string.substring(0, index).trim();
- return before.length === 0 || before.search(/[({,]&/) !== -1;
-}
-
-function isPrecedingOperator(string, index) {
- var prevCharIndex = -1;
-
- for (var i = index - 1; i >= 0; i--) {
- if (string[i].search(/\s/) === -1) {
- prevCharIndex = i;
- break;
- }
- }
-
- if (prevCharIndex === -1) {
- return false;
- }
-
- if (mathOperatorCharType(string, prevCharIndex) === "op") {
- return true;
- }
-
- return false;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/dist/utils/whitespaceChecker.js b/assets/node_modules/stylelint-scss/dist/utils/whitespaceChecker.js
deleted file mode 100644
index dfa0e88..0000000
--- a/assets/node_modules/stylelint-scss/dist/utils/whitespaceChecker.js
+++ /dev/null
@@ -1,371 +0,0 @@
-"use strict";
-
-Object.defineProperty(exports, "__esModule", {
- value: true
-});
-exports["default"] = _default;
-
-var _isWhitespace = _interopRequireDefault(require("./isWhitespace"));
-
-var _isSingleLineString = _interopRequireDefault(require("./isSingleLineString"));
-
-var _configurationError = _interopRequireDefault(require("./configurationError"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
-
-/**
- * Create a whitespaceChecker, which exposes the following functions:
- * - `before()`
- * - `beforeAllowingIndentation()`
- * - `after()`
- * - `afterOneOnly()`
- *
- * @param {"space"|"newline"} targetWhitespace - This is a keyword instead
- * of the actual character (e.g. " ") in order to accommodate
- * different styles of newline ("\n" vs "\r\n")
- * @param {
- * "always"|"never"
- * |"always-single-line"|"always-multi-line"
- * | "never-single-line"|"never-multi-line"
- * } expectation
- * @param {object} messages - An object of message functions;
- * calling `before*()` or `after*()` and the `expectation` that is passed
- * determines which message functions are required
- * @param {function} [messages.expectedBefore]
- * @param {function} [messages.rejectedBefore]
- * @param {function} [messages.expectedAfter]
- * @param {function} [messages.rejectedAfter]
- * @param {function} [messages.expectedBeforeSingleLine]
- * @param {function} [messages.rejectedBeforeSingleLine]
- * @param {function} [messages.expectedBeforeMultiLine]
- * @param {function} [messages.rejectedBeforeMultiLine]
- * @return {object} The checker, with its exposed checking functions
- */
-function _default(targetWhitespace, expectation, messages) {
- // Keep track of active arguments in order to avoid passing
- // too much stuff around, making signatures long and confusing.
- // This variable gets reset anytime a checking function is called.
- var activeArgs;
- /**
- * Check for whitespace *before* a character.
- *
- * @param {object} args - Named arguments object
- * @param {string} args.source - The source string
- * @param {number} args.index - The index of the character to check before
- * @param {function} args.err - If a violation is found, this callback
- * will be invoked with the relevant warning message.
- * Typically this callback will report() the violation.
- * @param {function} args.errTarget - If a violation is found, this string
- * will be sent to the relevant warning message.
- * @param {string} [args.lineCheckStr] - Single- and multi-line checkers
- * will use this string to determine whether they should proceed,
- * i.e. if this string is one line only, single-line checkers will check,
- * multi-line checkers will ignore.
- * If none is passed, they will use `source`.
- * @param {boolean} [args.onlyOneChar=false] - Only check *one* character before.
- * By default, "always-*" checks will look for the `targetWhitespace` one
- * before and then ensure there is no whitespace two before. This option
- * bypasses that second check.
- * @param {boolean} [args.allowIndentation=false] - Allow arbitrary indentation
- * between the `targetWhitespace` (almost definitely a newline) and the `index`.
- * With this option, the checker will see if a newline *begins* the whitespace before
- * the `index`.
- */
-
- function before(_ref) {
- var source = _ref.source,
- index = _ref.index,
- err = _ref.err,
- errTarget = _ref.errTarget,
- lineCheckStr = _ref.lineCheckStr,
- _ref$onlyOneChar = _ref.onlyOneChar,
- onlyOneChar = _ref$onlyOneChar === void 0 ? false : _ref$onlyOneChar,
- _ref$allowIndentation = _ref.allowIndentation,
- allowIndentation = _ref$allowIndentation === void 0 ? false : _ref$allowIndentation;
- activeArgs = {
- source: source,
- index: index,
- err: err,
- errTarget: errTarget,
- onlyOneChar: onlyOneChar,
- allowIndentation: allowIndentation
- };
-
- switch (expectation) {
- case "always":
- expectBefore();
- break;
-
- case "never":
- rejectBefore();
- break;
-
- case "always-single-line":
- if (!(0, _isSingleLineString["default"])(lineCheckStr || source)) {
- return;
- }
-
- expectBefore(messages.expectedBeforeSingleLine);
- break;
-
- case "never-single-line":
- if (!(0, _isSingleLineString["default"])(lineCheckStr || source)) {
- return;
- }
-
- rejectBefore(messages.rejectedBeforeSingleLine);
- break;
-
- case "always-multi-line":
- if ((0, _isSingleLineString["default"])(lineCheckStr || source)) {
- return;
- }
-
- expectBefore(messages.expectedBeforeMultiLine);
- break;
-
- case "never-multi-line":
- if ((0, _isSingleLineString["default"])(lineCheckStr || source)) {
- return;
- }
-
- rejectBefore(messages.rejectedBeforeMultiLine);
- break;
-
- default:
- throw (0, _configurationError["default"])("Unknown expectation \"".concat(expectation, "\""));
- }
- }
- /**
- * Check for whitespace *after* a character.
- *
- * Parameters are pretty much the same as for `before()`, above, just substitute
- * the word "after" for "before".
- */
-
-
- function after(_ref2) {
- var source = _ref2.source,
- index = _ref2.index,
- err = _ref2.err,
- errTarget = _ref2.errTarget,
- lineCheckStr = _ref2.lineCheckStr,
- _ref2$onlyOneChar = _ref2.onlyOneChar,
- onlyOneChar = _ref2$onlyOneChar === void 0 ? false : _ref2$onlyOneChar;
- activeArgs = {
- source: source,
- index: index,
- err: err,
- errTarget: errTarget,
- onlyOneChar: onlyOneChar
- };
-
- switch (expectation) {
- case "always":
- expectAfter();
- break;
-
- case "never":
- rejectAfter();
- break;
-
- case "always-single-line":
- if (!(0, _isSingleLineString["default"])(lineCheckStr || source)) {
- return;
- }
-
- expectAfter(messages.expectedAfterSingleLine);
- break;
-
- case "never-single-line":
- if (!(0, _isSingleLineString["default"])(lineCheckStr || source)) {
- return;
- }
-
- rejectAfter(messages.rejectedAfterSingleLine);
- break;
-
- case "always-multi-line":
- if ((0, _isSingleLineString["default"])(lineCheckStr || source)) {
- return;
- }
-
- expectAfter(messages.expectedAfterMultiLine);
- break;
-
- case "never-multi-line":
- if ((0, _isSingleLineString["default"])(lineCheckStr || source)) {
- return;
- }
-
- rejectAfter(messages.rejectedAfterMultiLine);
- break;
-
- case "at-least-one-space":
- expectAfter(messages.expectedAfterAtLeast);
- break;
-
- default:
- throw (0, _configurationError["default"])("Unknown expectation \"".concat(expectation, "\""));
- }
- }
-
- function beforeAllowingIndentation(obj) {
- before(Object.assign({}, obj, {
- allowIndentation: true
- }));
- }
-
- function expectBefore() {
- var messageFunc = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : messages.expectedBefore;
-
- if (activeArgs.allowIndentation) {
- expectBeforeAllowingIndentation(messageFunc);
- return;
- }
-
- var _activeArgs = activeArgs,
- source = _activeArgs.source,
- index = _activeArgs.index;
- var oneCharBefore = source[index - 1];
- var twoCharsBefore = source[index - 2];
-
- if (!isValue(oneCharBefore)) {
- return;
- }
-
- if (targetWhitespace === "newline") {
- // If index is preceeded by a Windows CR-LF ...
- if (oneCharBefore === "\n" && twoCharsBefore === "\r") {
- if (activeArgs.onlyOneChar || !(0, _isWhitespace["default"])(source[index - 3])) {
- return;
- }
- } // If index is followed by a Unix LF ...
-
-
- if (oneCharBefore === "\n" && twoCharsBefore !== "\r") {
- if (activeArgs.onlyOneChar || !(0, _isWhitespace["default"])(twoCharsBefore)) {
- return;
- }
- }
- }
-
- if (targetWhitespace === "space" && oneCharBefore === " ") {
- if (activeArgs.onlyOneChar || !(0, _isWhitespace["default"])(twoCharsBefore)) {
- return;
- }
- }
-
- activeArgs.err(messageFunc(activeArgs.errTarget ? activeArgs.errTarget : source[index]));
- }
-
- function expectBeforeAllowingIndentation() {
- var messageFunc = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : messages.expectedBefore;
- var _activeArgs2 = activeArgs,
- source = _activeArgs2.source,
- index = _activeArgs2.index,
- err = _activeArgs2.err;
-
- var expectedChar = function () {
- if (targetWhitespace === "newline") {
- return "\n";
- }
-
- if (targetWhitespace === "space") {
- return " ";
- }
- }();
-
- var i = index - 1;
-
- while (source[i] !== expectedChar) {
- if (source[i] === "\t" || source[i] === " ") {
- i--;
- continue;
- }
-
- err(messageFunc(activeArgs.errTarget ? activeArgs.errTarget : source[index]));
- return;
- }
- }
-
- function rejectBefore() {
- var messageFunc = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : messages.rejectedBefore;
- var _activeArgs3 = activeArgs,
- source = _activeArgs3.source,
- index = _activeArgs3.index;
- var oneCharBefore = source[index - 1];
-
- if (isValue(oneCharBefore) && (0, _isWhitespace["default"])(oneCharBefore)) {
- activeArgs.err(messageFunc(activeArgs.errTarget ? activeArgs.errTarget : source[index]));
- }
- }
-
- function afterOneOnly(obj) {
- after(Object.assign({}, obj, {
- onlyOneChar: true
- }));
- }
-
- function expectAfter() {
- var messageFunc = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : messages.expectedAfter;
- var _activeArgs4 = activeArgs,
- source = _activeArgs4.source,
- index = _activeArgs4.index;
- var oneCharAfter = index + 1 < source.length ? source[index + 1] : "";
- var twoCharsAfter = index + 2 < source.length ? source[index + 2] : "";
-
- if (!isValue(oneCharAfter)) {
- return;
- }
-
- if (targetWhitespace === "newline") {
- // If index is followed by a Windows CR-LF ...
- if (oneCharAfter === "\r" && twoCharsAfter === "\n") {
- var threeCharsAfter = index + 3 < source.length ? source[index + 3] : "";
-
- if (activeArgs.onlyOneChar || !(0, _isWhitespace["default"])(threeCharsAfter)) {
- return;
- }
- } // If index is followed by a Unix LF ...
-
-
- if (oneCharAfter === "\n") {
- if (activeArgs.onlyOneChar || !(0, _isWhitespace["default"])(twoCharsAfter)) {
- return;
- }
- }
- }
-
- if (targetWhitespace === "space" && oneCharAfter === " ") {
- if (expectation === "at-least-one-space" || activeArgs.onlyOneChar || !(0, _isWhitespace["default"])(twoCharsAfter)) {
- return;
- }
- }
-
- activeArgs.err(messageFunc(activeArgs.errTarget ? activeArgs.errTarget : source[index]));
- }
-
- function rejectAfter() {
- var messageFunc = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : messages.rejectedAfter;
- var _activeArgs5 = activeArgs,
- source = _activeArgs5.source,
- index = _activeArgs5.index;
- var oneCharAfter = index + 1 < source.length ? source[index + 1] : "";
-
- if (isValue(oneCharAfter) && (0, _isWhitespace["default"])(oneCharAfter)) {
- activeArgs.err(messageFunc(activeArgs.errTarget ? activeArgs.errTarget : source[index]));
- }
- }
-
- return {
- before: before,
- beforeAllowingIndentation: beforeAllowingIndentation,
- after: after,
- afterOneOnly: afterOneOnly
- };
-}
-
-function isValue(x) {
- return x !== undefined && x !== null;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/docs/examples/README.md b/assets/node_modules/stylelint-scss/docs/examples/README.md
deleted file mode 100644
index afb1e3a..0000000
--- a/assets/node_modules/stylelint-scss/docs/examples/README.md
+++ /dev/null
@@ -1,5 +0,0 @@
-# Example configs
-
-This dir contains examples of `.stylelintrc` configuration file for several use cases.
-
-* [Rules for `@if`/`@else` statements](./if-else.md)
diff --git a/assets/node_modules/stylelint-scss/docs/examples/if-else.md b/assets/node_modules/stylelint-scss/docs/examples/if-else.md
deleted file mode 100644
index b9a73e0..0000000
--- a/assets/node_modules/stylelint-scss/docs/examples/if-else.md
+++ /dev/null
@@ -1,148 +0,0 @@
-# `@if`/`@else`
-
-A stylesheet author might want to treat `@if` and `@else` in a special manner, for example `@else` should be on the same line as its `@if`'s closing brace while all the other blocks and at-rules has to have newline after their closing brace. stylelint-scss has some rules for this, but from the core stylelint's point of view, `@if` and `@else` SCSS statements are pretty much regular at-rules, so they comply to corresponding `at-rule-...` and `block-...` rules. Below are some configurations that might help you achieve the needed patterns.
-
----
-
-**Config 1**: `@else` is on the same line as the preceding `@if`/`@else`'s `}`, space between them. Empty line before all at-rules (except `@else`), space before `{`, newline after all `}` except `@if`'s and `@else`'s.
-
-```json
-{
- "plugins": [
- "stylelint-scss"
- ],
- "rules": {
- "at-rule-empty-line-before": [
- "always", {
- "ignoreAtRules": [ "else" ]
- }
- ],
- "block-opening-brace-space-before": "always",
- "block-closing-brace-newline-after": [
- "always", {
- "ignoreAtRules": [ "if", "else" ]
- }
- ],
- "at-rule-name-space-after": "always",
- "rule-empty-line-before": "always",
- "scss/at-else-closing-brace-newline-after": "always-last-in-chain",
- "scss/at-else-closing-brace-space-after": "always-intermediate",
- "scss/at-else-empty-line-before": "never",
- "scss/at-if-closing-brace-newline-after": "always-last-in-chain",
- "scss/at-if-closing-brace-space-after": "always-intermediate"
- }
-}
-```
-
-This code is considered **valid**
-```scss
-@if {
- // ...
-}
-
-a {}
-
-@if {
- // ...
-} @else {
- // ...
-}
-
-a {}
-
-@if {
- // ...
-} @else if {
- // ...
-} @else {
- // ...
-}
-
-@if {
- // ...
-} @else
-if {
- // ...
-} @else {
- // ...
-}
-
-a {}
-```
-
-These patterns are considered **non-valid**:
-
-```scss
-@if {
- // ...
-} a {}
-```
-```scss
-@if {
- // ...
-}@else {
- // ...
-}
-```
-```scss
-@if {
- // ...
-} @else if{
- // ...
-} @else {
- // ...
-}
-```
-```scss
-@if {
- // ...
-} @else if{
- // ...
-} @else {
- // ...
-}
-```
-
----
-
-**Config 2**: `@else` is on a newline, no empty line before it.
-
-```json
-{
- "plugins": [
- "stylelint-scss"
- ],
- "rules": {
- "at-rule-empty-line-before": [
- "always", {
- "ignoreAtRules": [ "else" ]
- }
- ],
- "at-rule-name-space-after": "always",
- "block-opening-brace-space-before": "always",
- "block-closing-brace-newline-after": "always",
- "at-else-empty-line-before": "never"
- }
-}
-```
-
-This code is considered **valid**:
-```scss
-@if {
- // ...
-}
-@else {
- // ...
-}
-```
-
-This code is considered **non-valid**:
-```scss
-@if {
- // ...
-}
-
-@else {
- // ...
-}
-```
diff --git a/assets/node_modules/stylelint-scss/node_modules/.bin/stylelint b/assets/node_modules/stylelint-scss/node_modules/.bin/stylelint
deleted file mode 120000
index 32ec801..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/.bin/stylelint
+++ /dev/null
@@ -1 +0,0 @@
-../../../stylelint/bin/stylelint.js \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/API.md b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/API.md
deleted file mode 100644
index ceee157..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/API.md
+++ /dev/null
@@ -1,873 +0,0 @@
-# API Documentation
-
-*Please use only this documented API when working with the parser. Methods
-not documented here are subject to change at any point.*
-
-## `parser` function
-
-This is the module's main entry point.
-
-```js
-const parser = require('postcss-selector-parser');
-```
-
-### `parser([transform], [options])`
-
-Creates a new `processor` instance
-
-```js
-const processor = parser();
-```
-
-Or, with optional transform function
-
-```js
-const transform = selectors => {
- selectors.walkUniversals(selector => {
- selector.remove();
- });
-};
-
-const processor = parser(transform)
-
-// Example
-const result = processor.processSync('*.class');
-// => .class
-```
-
-[See processor documentation](#processor)
-
-Arguments:
-
-* `transform (function)`: Provide a function to work with the parsed AST.
-* `options (object)`: Provide default options for all calls on the returned `Processor`.
-
-### `parser.attribute([props])`
-
-Creates a new attribute selector.
-
-```js
-parser.attribute({attribute: 'href'});
-// => [href]
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-### `parser.className([props])`
-
-Creates a new class selector.
-
-```js
-parser.className({value: 'button'});
-// => .button
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-### `parser.combinator([props])`
-
-Creates a new selector combinator.
-
-```js
-parser.combinator({value: '+'});
-// => +
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-Notes:
-* **Descendant Combinators** The value of descendant combinators created by the
- parser always just a single space (`" "`). For descendant selectors with no
- comments, additional space is now stored in `node.spaces.before`. Depending
- on the location of comments, additional spaces may be stored in
- `node.raws.spaces.before`, `node.raws.spaces.after`, or `node.raws.value`.
-* **Named Combinators** Although, nonstandard and unlikely to ever become a standard,
- named combinators like `/deep/` and `/for/` are parsed as combinators. The
- `node.value` is name after being unescaped and normalized as lowercase. The
- original value for the combinator name is stored in `node.raws.value`.
-
-
-### `parser.comment([props])`
-
-Creates a new comment.
-
-```js
-parser.comment({value: '/* Affirmative, Dave. I read you. */'});
-// => /* Affirmative, Dave. I read you. */
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-### `parser.id([props])`
-
-Creates a new id selector.
-
-```js
-parser.id({value: 'search'});
-// => #search
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-### `parser.nesting([props])`
-
-Creates a new nesting selector.
-
-```js
-parser.nesting();
-// => &
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-### `parser.pseudo([props])`
-
-Creates a new pseudo selector.
-
-```js
-parser.pseudo({value: '::before'});
-// => ::before
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-### `parser.root([props])`
-
-Creates a new root node.
-
-```js
-parser.root();
-// => (empty)
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-### `parser.selector([props])`
-
-Creates a new selector node.
-
-```js
-parser.selector();
-// => (empty)
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-### `parser.string([props])`
-
-Creates a new string node.
-
-```js
-parser.string();
-// => (empty)
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-### `parser.tag([props])`
-
-Creates a new tag selector.
-
-```js
-parser.tag({value: 'button'});
-// => button
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-### `parser.universal([props])`
-
-Creates a new universal selector.
-
-```js
-parser.universal();
-// => *
-```
-
-Arguments:
-
-* `props (object)`: The new node's properties.
-
-## Node types
-
-### `node.type`
-
-A string representation of the selector type. It can be one of the following;
-`attribute`, `class`, `combinator`, `comment`, `id`, `nesting`, `pseudo`,
-`root`, `selector`, `string`, `tag`, or `universal`. Note that for convenience,
-these constants are exposed on the main `parser` as uppercased keys. So for
-example you can get `id` by querying `parser.ID`.
-
-```js
-parser.attribute({attribute: 'href'}).type;
-// => 'attribute'
-```
-
-### `node.parent`
-
-Returns the parent node.
-
-```js
-root.nodes[0].parent === root;
-```
-
-### `node.toString()`, `String(node)`, or `'' + node`
-
-Returns a string representation of the node.
-
-```js
-const id = parser.id({value: 'search'});
-console.log(String(id));
-// => #search
-```
-
-### `node.next()` & `node.prev()`
-
-Returns the next/previous child of the parent node.
-
-```js
-const next = id.next();
-if (next && next.type !== 'combinator') {
- throw new Error('Qualified IDs are not allowed!');
-}
-```
-
-### `node.replaceWith(node)`
-
-Replace a node with another.
-
-```js
-const attr = selectors.first.first;
-const className = parser.className({value: 'test'});
-attr.replaceWith(className);
-```
-
-Arguments:
-
-* `node`: The node to substitute the original with.
-
-### `node.remove()`
-
-Removes the node from its parent node.
-
-```js
-if (node.type === 'id') {
- node.remove();
-}
-```
-
-### `node.clone()`
-
-Returns a copy of a node, detached from any parent containers that the
-original might have had.
-
-```js
-const cloned = parser.id({value: 'search'});
-String(cloned);
-
-// => #search
-```
-
-### `node.isAtPosition(line, column)`
-
-Return a `boolean` indicating whether this node includes the character at the
-position of the given line and column. Returns `undefined` if the nodes lack
-sufficient source metadata to determine the position.
-
-Arguments:
-
-* `line`: 1-index based line number relative to the start of the selector.
-* `column`: 1-index based column number relative to the start of the selector.
-
-### `node.spaces`
-
-Extra whitespaces around the node will be moved into `node.spaces.before` and
-`node.spaces.after`. So for example, these spaces will be moved as they have
-no semantic meaning:
-
-```css
- h1 , h2 {}
-```
-
-For descendent selectors, the value is always a single space.
-
-```css
-h1 h2 {}
-```
-
-Additional whitespace is found in either the `node.spaces.before` and `node.spaces.after` depending on the presence of comments or other whitespace characters. If the actual whitespace does not start or end with a single space, the node's raw value is set to the actual space(s) found in the source.
-
-### `node.source`
-
-An object describing the node's start/end, line/column source position.
-
-Within the following CSS, the `.bar` class node ...
-
-```css
-.foo,
- .bar {}
-```
-
-... will contain the following `source` object.
-
-```js
-source: {
- start: {
- line: 2,
- column: 3
- },
- end: {
- line: 2,
- column: 6
- }
-}
-```
-
-### `node.sourceIndex`
-
-The zero-based index of the node within the original source string.
-
-Within the following CSS, the `.baz` class node will have a `sourceIndex` of `12`.
-
-```css
-.foo, .bar, .baz {}
-```
-
-## Container types
-
-The `root`, `selector`, and `pseudo` nodes have some helper methods for working
-with their children.
-
-### `container.nodes`
-
-An array of the container's children.
-
-```js
-// Input: h1 h2
-selectors.at(0).nodes.length // => 3
-selectors.at(0).nodes[0].value // => 'h1'
-selectors.at(0).nodes[1].value // => ' '
-```
-
-### `container.first` & `container.last`
-
-The first/last child of the container.
-
-```js
-selector.first === selector.nodes[0];
-selector.last === selector.nodes[selector.nodes.length - 1];
-```
-
-### `container.at(index)`
-
-Returns the node at position `index`.
-
-```js
-selector.at(0) === selector.first;
-selector.at(0) === selector.nodes[0];
-```
-
-Arguments:
-
-* `index`: The index of the node to return.
-
-### `container.atPosition(line, column)`
-
-Returns the node at the source position `index`.
-
-```js
-selector.at(0) === selector.first;
-selector.at(0) === selector.nodes[0];
-```
-
-Arguments:
-
-* `index`: The index of the node to return.
-
-### `container.index(node)`
-
-Return the index of the node within its container.
-
-```js
-selector.index(selector.nodes[2]) // => 2
-```
-
-Arguments:
-
-* `node`: A node within the current container.
-
-### `container.length`
-
-Proxy to the length of the container's nodes.
-
-```js
-container.length === container.nodes.length
-```
-
-### `container` Array iterators
-
-The container class provides proxies to certain Array methods; these are:
-
-* `container.map === container.nodes.map`
-* `container.reduce === container.nodes.reduce`
-* `container.every === container.nodes.every`
-* `container.some === container.nodes.some`
-* `container.filter === container.nodes.filter`
-* `container.sort === container.nodes.sort`
-
-Note that these methods only work on a container's immediate children; recursive
-iteration is provided by `container.walk`.
-
-### `container.each(callback)`
-
-Iterate the container's immediate children, calling `callback` for each child.
-You may return `false` within the callback to break the iteration.
-
-```js
-let className;
-selectors.each((selector, index) => {
- if (selector.type === 'class') {
- className = selector.value;
- return false;
- }
-});
-```
-
-Note that unlike `Array#forEach()`, this iterator is safe to use whilst adding
-or removing nodes from the container.
-
-Arguments:
-
-* `callback (function)`: A function to call for each node, which receives `node`
- and `index` arguments.
-
-### `container.walk(callback)`
-
-Like `container#each`, but will also iterate child nodes as long as they are
-`container` types.
-
-```js
-selectors.walk((selector, index) => {
- // all nodes
-});
-```
-
-Arguments:
-
-* `callback (function)`: A function to call for each node, which receives `node`
- and `index` arguments.
-
-This iterator is safe to use whilst mutating `container.nodes`,
-like `container#each`.
-
-### `container.walk` proxies
-
-The container class provides proxy methods for iterating over types of nodes,
-so that it is easier to write modules that target specific selectors. Those
-methods are:
-
-* `container.walkAttributes`
-* `container.walkClasses`
-* `container.walkCombinators`
-* `container.walkComments`
-* `container.walkIds`
-* `container.walkNesting`
-* `container.walkPseudos`
-* `container.walkTags`
-* `container.walkUniversals`
-
-### `container.split(callback)`
-
-This method allows you to split a group of nodes by returning `true` from
-a callback. It returns an array of arrays, where each inner array corresponds
-to the groups that you created via the callback.
-
-```js
-// (input) => h1 h2>>h3
-const list = selectors.first.split(selector => {
- return selector.type === 'combinator';
-});
-
-// (node values) => [['h1', ' '], ['h2', '>>'], ['h3']]
-```
-
-Arguments:
-
-* `callback (function)`: A function to call for each node, which receives `node`
- as an argument.
-
-### `container.prepend(node)` & `container.append(node)`
-
-Add a node to the start/end of the container. Note that doing so will set
-the parent property of the node to this container.
-
-```js
-const id = parser.id({value: 'search'});
-selector.append(id);
-```
-
-Arguments:
-
-* `node`: The node to add.
-
-### `container.insertBefore(old, new)` & `container.insertAfter(old, new)`
-
-Add a node before or after an existing node in a container:
-
-```js
-selectors.walk(selector => {
- if (selector.type !== 'class') {
- const className = parser.className({value: 'theme-name'});
- selector.parent.insertAfter(selector, className);
- }
-});
-```
-
-Arguments:
-
-* `old`: The existing node in the container.
-* `new`: The new node to add before/after the existing node.
-
-### `container.removeChild(node)`
-
-Remove the node from the container. Note that you can also use
-`node.remove()` if you would like to remove just a single node.
-
-```js
-selector.length // => 2
-selector.remove(id)
-selector.length // => 1;
-id.parent // undefined
-```
-
-Arguments:
-
-* `node`: The node to remove.
-
-### `container.removeAll()` or `container.empty()`
-
-Remove all children from the container.
-
-```js
-selector.removeAll();
-selector.length // => 0
-```
-
-## Root nodes
-
-A root node represents a comma separated list of selectors. Indeed, all
-a root's `toString()` method does is join its selector children with a ','.
-Other than this, it has no special functionality and acts like a container.
-
-### `root.trailingComma`
-
-This will be set to `true` if the input has a trailing comma, in order to
-support parsing of legacy CSS hacks.
-
-## Selector nodes
-
-A selector node represents a single complex selector. For example, this
-selector string `h1 h2 h3, [href] > p`, is represented as two selector nodes.
-It has no special functionality of its own.
-
-## Pseudo nodes
-
-A pseudo selector extends a container node; if it has any parameters of its
-own (such as `h1:not(h2, h3)`), they will be its children. Note that the pseudo
-`value` will always contain the colons preceding the pseudo identifier. This
-is so that both `:before` and `::before` are properly represented in the AST.
-
-## Attribute nodes
-
-### `attribute.quoted`
-
-Returns `true` if the attribute's value is wrapped in quotation marks, false if it is not.
-Remains `undefined` if there is no attribute value.
-
-```css
-[href=foo] /* false */
-[href='foo'] /* true */
-[href="foo"] /* true */
-[href] /* undefined */
-```
-
-### `attribute.qualifiedAttribute`
-
-Returns the attribute name qualified with the namespace if one is given.
-
-### `attribute.offsetOf(part)`
-
- Returns the offset of the attribute part specified relative to the
- start of the node of the output string. This is useful in raising
- error messages about a specific part of the attribute, especially
- in combination with `attribute.sourceIndex`.
-
- Returns `-1` if the name is invalid or the value doesn't exist in this
- attribute.
-
- The legal values for `part` are:
-
- * `"ns"` - alias for "namespace"
- * `"namespace"` - the namespace if it exists.
- * `"attribute"` - the attribute name
- * `"attributeNS"` - the start of the attribute or its namespace
- * `"operator"` - the match operator of the attribute
- * `"value"` - The value (string or identifier)
- * `"insensitive"` - the case insensitivity flag
-
-### `attribute.raws.unquoted`
-
-Returns the unquoted content of the attribute's value.
-Remains `undefined` if there is no attribute value.
-
-```css
-[href=foo] /* foo */
-[href='foo'] /* foo */
-[href="foo"] /* foo */
-[href] /* undefined */
-```
-
-### `attribute.spaces`
-
-Like `node.spaces` with the `before` and `after` values containing the spaces
-around the element, the parts of the attribute can also have spaces before
-and after them. The for each of `attribute`, `operator`, `value` and
-`insensitive` there is corresponding property of the same nam in
-`node.spaces` that has an optional `before` or `after` string containing only
-whitespace.
-
-Note that corresponding values in `attributes.raws.spaces` contain values
-including any comments. If set, these values will override the
-`attribute.spaces` value. Take care to remove them if changing
-`attribute.spaces`.
-
-### `attribute.raws`
-
-The raws object stores comments and other information necessary to re-render
-the node exactly as it was in the source.
-
-If a comment is embedded within the identifiers for the `namespace`, `attribute`
-or `value` then a property is placed in the raws for that value containing the full source of the propery including comments.
-
-If a comment is embedded within the space between parts of the attribute
-then the raw for that space is set accordingly.
-
-Setting an attribute's property `raws` value to be deleted.
-
-For now, changing the spaces required also updating or removing any of the
-raws values that override them.
-
-Example: `[ /*before*/ href /* after-attr */ = /* after-operator */ te/*inside-value*/st/* wow */ /*omg*/i/*bbq*/ /*whodoesthis*/]` would parse as:
-
-```js
-{
- attribute: "href",
- operatator: "=",
- value: "test",
- spaces: {
- before: '',
- after: '',
- attribute: { before: ' ', after: ' ' },
- operator: { after: ' ' },
- value: { after: ' ' },
- insensitive: { after: ' ' }
- },
- raws: {
- spaces: {
- attribute: { before: ' /*before*/ ', after: ' /* after-attr */ ' },
- operator: { after: ' /* after-operator */ ' },
- value: { after: '/* wow */ /*omg*/' },
- insensitive: { after: '/*bbq*/ /*whodoesthis*/' }
- },
- unquoted: 'test',
- value: 'te/*inside-value*/st'
- }
-}
-```
-
-## `Processor`
-
-### `ProcessorOptions`
-
-* `lossless` - When `true`, whitespace is preserved. Defaults to `true`.
-* `updateSelector` - When `true`, if any processor methods are passed a postcss
- `Rule` node instead of a string, then that Rule's selector is updated
- with the results of the processing. Defaults to `true`.
-
-### `process|processSync(selectors, [options])`
-
-Processes the `selectors`, returning a string from the result of processing.
-
-Note: when the `updateSelector` option is set, the rule's selector
-will be updated with the resulting string.
-
-**Example:**
-
-```js
-const parser = require("postcss-selector-parser");
-const processor = parser();
-
-let result = processor.processSync(' .class');
-console.log(result);
-// => .class
-
-// Asynchronous operation
-let promise = processor.process(' .class').then(result => {
- console.log(result)
- // => .class
-});
-
-// To have the parser normalize whitespace values, utilize the options
-result = processor.processSync(' .class ', {lossless: false});
-console.log(result);
-// => .class
-
-// For better syntax errors, pass a PostCSS Rule node.
-const postcss = require('postcss');
-rule = postcss.rule({selector: ' #foo > a, .class '});
-processor.process(rule, {lossless: false, updateSelector: true}).then(result => {
- console.log(result);
- // => #foo>a,.class
- console.log("rule:", rule.selector);
- // => rule: #foo>a,.class
-})
-```
-
-Arguments:
-
-* `selectors (string|postcss.Rule)`: Either a selector string or a PostCSS Rule
- node.
-* `[options] (object)`: Process options
-
-
-### `ast|astSync(selectors, [options])`
-
-Like `process()` and `processSync()` but after
-processing the `selectors` these methods return the `Root` node of the result
-instead of a string.
-
-Note: when the `updateSelector` option is set, the rule's selector
-will be updated with the resulting string.
-
-### `transform|transformSync(selectors, [options])`
-
-Like `process()` and `processSync()` but after
-processing the `selectors` these methods return the value returned by the
-processor callback.
-
-Note: when the `updateSelector` option is set, the rule's selector
-will be updated with the resulting string.
-
-### Error Handling Within Selector Processors
-
-The root node passed to the selector processor callback
-has a method `error(message, options)` that returns an
-error object. This method should always be used to raise
-errors relating to the syntax of selectors. The options
-to this method are passed to postcss's error constructor
-([documentation](http://api.postcss.org/Container.html#error)).
-
-#### Async Error Example
-
-```js
-let processor = (root) => {
- return new Promise((resolve, reject) => {
- root.walkClasses((classNode) => {
- if (/^(.*)[-_]/.test(classNode.value)) {
- let msg = "classes may not have underscores or dashes in them";
- reject(root.error(msg, {
- index: classNode.sourceIndex + RegExp.$1.length + 1,
- word: classNode.value
- }));
- }
- });
- resolve();
- });
-};
-
-const postcss = require("postcss");
-const parser = require("postcss-selector-parser");
-const selectorProcessor = parser(processor);
-const plugin = postcss.plugin('classValidator', (options) => {
- return (root) => {
- let promises = [];
- root.walkRules(rule => {
- promises.push(selectorProcessor.process(rule));
- });
- return Promise.all(promises);
- };
-});
-postcss(plugin()).process(`
-.foo-bar {
- color: red;
-}
-`.trim(), {from: 'test.css'}).catch((e) => console.error(e.toString()));
-
-// CssSyntaxError: classValidator: ./test.css:1:5: classes may not have underscores or dashes in them
-//
-// > 1 | .foo-bar {
-// | ^
-// 2 | color: red;
-// 3 | }
-```
-
-#### Synchronous Error Example
-
-```js
-let processor = (root) => {
- root.walkClasses((classNode) => {
- if (/.*[-_]/.test(classNode.value)) {
- let msg = "classes may not have underscores or dashes in them";
- throw root.error(msg, {
- index: classNode.sourceIndex,
- word: classNode.value
- });
- }
- });
-};
-
-const postcss = require("postcss");
-const parser = require("postcss-selector-parser");
-const selectorProcessor = parser(processor);
-const plugin = postcss.plugin('classValidator', (options) => {
- return (root) => {
- root.walkRules(rule => {
- selectorProcessor.processSync(rule);
- });
- };
-});
-postcss(plugin()).process(`
-.foo-bar {
- color: red;
-}
-`.trim(), {from: 'test.css'}).catch((e) => console.error(e.toString()));
-
-// CssSyntaxError: classValidator: ./test.css:1:5: classes may not have underscores or dashes in them
-//
-// > 1 | .foo-bar {
-// | ^
-// 2 | color: red;
-// 3 | }
-```
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/CHANGELOG.md b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/CHANGELOG.md
deleted file mode 100644
index 8aeec16..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/CHANGELOG.md
+++ /dev/null
@@ -1,479 +0,0 @@
-# 6.0.2
-
-- Fixed an issue with parsing and stringifying an empty attribute value
-
-# 6.0.1
-
-- Fixed an issue with unicode surrogate pair parsing
-
-# 6.0.0
-
-- Updated: `cssesc` to 3.0.0 (major)
-- Fixed: Issues with escaped `id` and `class` selectors
-
-# 5.0.0
-
-- Allow escaped dot within class name.
-- Update PostCSS to 7.0.7 (patch)
-
-# 5.0.0-rc.4
-
-- Fixed an issue where comments immediately after an insensitive (in attribute)
- were not parsed correctly.
-- Updated `cssesc` to 2.0.0 (major).
-- Removed outdated integration tests.
-- Added tests for custom selectors, tags with attributes, the universal
- selector with pseudos, and tokens after combinators.
-
-# 5.0.0-rc.1
-
-To ease adoption of the v5.0 release, we have relaxed the node version
-check performed by npm at installation time to allow for node 4, which
-remains officially unsupported, but likely to continue working for the
-time being.
-
-# 5.0.0-rc.0
-
-This release has **BREAKING CHANGES** that were required to fix regressions
-in 4.0.0 and to make the Combinator Node API consistent for all combinator
-types. Please read carefully.
-
-## Summary of Changes
-
-* The way a descendent combinator that isn't a single space character (E.g. `.a .b`) is stored in the AST has changed.
-* Named Combinators (E.g. `.a /for/ .b`) are now properly parsed as a combinator.
-* It is now possible to look up a node based on the source location of a character in that node and to query nodes if they contain some character.
-* Several bug fixes that caused the parser to hang and run out of memory when a `/` was encountered have been fixed.
-* The minimum supported version of Node is now `v6.0.0`.
-
-### Changes to the Descendent Combinator
-
-In prior releases, the value of a descendant combinator with multiple spaces included all the spaces.
-
-* `.a .b`: Extra spaces are now stored as space before.
- - Old & Busted:
- - `combinator.value === " "`
- - New hotness:
- - `combinator.value === " " && combinator.spaces.before === " "`
-* `.a /*comment*/.b`: A comment at the end of the combinator causes extra space to become after space.
- - Old & Busted:
- - `combinator.value === " "`
- - `combinator.raws.value === " /*comment/"`
- - New hotness:
- - `combinator.value === " "`
- - `combinator.spaces.after === " "`
- - `combinator.raws.spaces.after === " /*comment*/"`
-* `.a<newline>.b`: whitespace that doesn't start or end with a single space character is stored as a raw value.
- - Old & Busted:
- - `combinator.value === "\n"`
- - `combinator.raws.value === undefined`
- - New hotness:
- - `combinator.value === " "`
- - `combinator.raws.value === "\n"`
-
-### Support for "Named Combinators"
-
-Although, nonstandard and unlikely to ever become a standard, combinators like `/deep/` and `/for/` are now properly supported.
-
-Because they've been taken off the standardization track, there is no spec-official name for combinators of the form `/<ident>/`. However, I talked to [Tab Atkins](https://twitter.com/tabatkins) and we agreed to call them "named combinators" so now they are called that.
-
-Before this release such named combinators were parsed without intention and generated three nodes of type `"tag"` where the first and last nodes had a value of `"/"`.
-
-* `.a /for/ .b` is parsed as a combinator.
- - Old & Busted:
- - `root.nodes[0].nodes[1].type === "tag"`
- - `root.nodes[0].nodes[1].value === "/"`
- - New hotness:
- - `root.nodes[0].nodes[1].type === "combinator"`
- - `root.nodes[0].nodes[1].value === "/for/"`
-* `.a /F\6fR/ .b` escapes are handled and uppercase is normalized.
- - Old & Busted:
- - `root.nodes[0].nodes[2].type === "tag"`
- - `root.nodes[0].nodes[2].value === "F\\6fR"`
- - New hotness:
- - `root.nodes[0].nodes[1].type === "combinator"`
- - `root.nodes[0].nodes[1].value === "/for/"`
- - `root.nodes[0].nodes[1].raws.value === "/F\\6fR/"`
-
-### Source position checks and lookups
-
-A new API was added to look up a node based on the source location.
-
-```js
-const selectorParser = require("postcss-selector-parser");
-// You can find the most specific node for any given character
-let combinator = selectorParser.astSync(".a > .b").atPosition(1,4);
-combinator.toString() === " > ";
-// You can check if a node includes a specific character
-// Whitespace surrounding the node that is owned by that node
-// is included in the check.
-[2,3,4,5,6].map(column => combinator.isAtPosition(1, column));
-// => [false, true, true, true, false]
-```
-
-# 4.0.0
-
-This release has **BREAKING CHANGES** that were required to fix bugs regarding values with escape sequences. Please read carefully.
-
-* **Identifiers with escapes** - CSS escape sequences are now hidden from the public API by default.
- The normal value of a node like a class name or ID, or an aspect of a node such as attribute
- selector's value, is unescaped. Escapes representing Non-ascii characters are unescaped into
- unicode characters. For example: `bu\tton, .\31 00, #i\2764\FE0Fu, [attr="value is \"quoted\""]`
- will parse respectively to the values `button`, `100`, `i❤️u`, `value is "quoted"`.
- The original escape sequences for these values can be found in the corresponding property name
- in `node.raws`. Where possible, deprecation warnings were added, but the nature
- of escape handling makes it impossible to detect what is escaped or not. Our expectation is
- that most users are neither expecting nor handling escape sequences in their use of this library,
- and so for them, this is a bug fix. Users who are taking care to handle escapes correctly can
- now update their code to remove the escape handling and let us do it for them.
-
-* **Mutating values with escapes** - When you make an update to a node property that has escape handling
- The value is assumed to be unescaped, and any special characters are escaped automatically and
- the corresponding `raws` value is immediately updated. This can result in changes to the original
- escape format. Where the exact value of the escape sequence is important there are methods that
- allow both values to be set in conjunction. There are a number of new convenience methods for
- manipulating values that involve escapes, especially for attributes values where the quote mark
- is involved. See https://github.com/postcss/postcss-selector-parser/pull/133 for an extensive
- write-up on these changes.
-
-
-**Upgrade/API Example**
-
-In `3.x` there was no unescape handling and internal consistency of several properties was the caller's job to maintain. It was very easy for the developer
-to create a CSS file that did not parse correctly when some types of values
-were in use.
-
-```js
-const selectorParser = require("postcss-selector-parser");
-let attr = selectorParser.attribute({attribute: "id", operator: "=", value: "a-value"});
-attr.value; // => "a-value"
-attr.toString(); // => [id=a-value]
-// Add quotes to an attribute's value.
-// All these values have to be set by the caller to be consistent:
-// no internal consistency is maintained.
-attr.raws.unquoted = attr.value
-attr.value = "'" + attr.value + "'";
-attr.value; // => "'a-value'"
-attr.quoted = true;
-attr.toString(); // => "[id='a-value']"
-```
-
-In `4.0` there is a convenient API for setting and mutating values
-that may need escaping. Especially for attributes.
-
-```js
-const selectorParser = require("postcss-selector-parser");
-
-// The constructor requires you specify the exact escape sequence
-let className = selectorParser.className({value: "illegal class name", raws: {value: "illegal\\ class\\ name"}});
-className.toString(); // => '.illegal\\ class\\ name'
-
-// So it's better to set the value as a property
-className = selectorParser.className();
-// Most properties that deal with identifiers work like this
-className.value = "escape for me";
-className.value; // => 'escape for me'
-className.toString(); // => '.escape\\ for\\ me'
-
-// emoji and all non-ascii are escaped to ensure it works in every css file.
-className.value = "😱🦄😍";
-className.value; // => '😱🦄😍'
-className.toString(); // => '.\\1F631\\1F984\\1F60D'
-
-// you can control the escape sequence if you want, or do bad bad things
-className.setPropertyAndEscape('value', 'xxxx', 'yyyy');
-className.value; // => "xxxx"
-className.toString(); // => ".yyyy"
-
-// Pass a value directly through to the css output without escaping it.
-className.setPropertyWithoutEscape('value', '$REPLACE_ME$');
-className.value; // => "$REPLACE_ME$"
-className.toString(); // => ".$REPLACE_ME$"
-
-// The biggest changes are to the Attribute class
-// passing quoteMark explicitly is required to avoid a deprecation warning.
-let attr = selectorParser.attribute({attribute: "id", operator: "=", value: "a-value", quoteMark: null});
-attr.toString(); // => "[id=a-value]"
-// Get the value with quotes on it and any necessary escapes.
-// This is the same as reading attr.value in 3.x.
-attr.getQuotedValue(); // => "a-value";
-attr.quoteMark; // => null
-
-// Add quotes to an attribute's value.
-attr.quoteMark = "'"; // This is all that's required.
-attr.toString(); // => "[id='a-value']"
-attr.quoted; // => true
-// The value is still the same, only the quotes have changed.
-attr.value; // => a-value
-attr.getQuotedValue(); // => "'a-value'";
-
-// deprecated assignment, no warning because there's no escapes
-attr.value = "new-value";
-// no quote mark is needed so it is removed
-attr.getQuotedValue(); // => "new-value";
-
-// deprecated assignment,
-attr.value = "\"a 'single quoted' value\"";
-// > (node:27859) DeprecationWarning: Assigning an attribute a value containing characters that might need to be escaped is deprecated. Call attribute.setValue() instead.
-attr.getQuotedValue(); // => '"a \'single quoted\' value"';
-// quote mark inferred from first and last characters.
-attr.quoteMark; // => '"'
-
-// setValue takes options to make manipulating the value simple.
-attr.setValue('foo', {smart: true});
-// foo doesn't require any escapes or quotes.
-attr.toString(); // => '[id=foo]'
-attr.quoteMark; // => null
-
-// An explicit quote mark can be specified
-attr.setValue('foo', {quoteMark: '"'});
-attr.toString(); // => '[id="foo"]'
-
-// preserves quote mark by default
-attr.setValue('bar');
-attr.toString(); // => '[id="bar"]'
-attr.quoteMark = null;
-attr.toString(); // => '[id=bar]'
-
-// with no arguments, it preserves quote mark even when it's not a great idea
-attr.setValue('a value \n that should be quoted');
-attr.toString(); // => '[id=a\\ value\\ \\A\\ that\\ should\\ be\\ quoted]'
-
-// smart preservation with a specified default
-attr.setValue('a value \n that should be quoted', {smart: true, preferCurrentQuoteMark: true, quoteMark: "'"});
-// => "[id='a value \\A that should be quoted']"
-attr.quoteMark = '"';
-// => '[id="a value \\A that should be quoted"]'
-
-// this keeps double quotes because it wants to quote the value and the existing value has double quotes.
-attr.setValue('this should be quoted', {smart: true, preferCurrentQuoteMark: true, quoteMark: "'"});
-// => '[id="this should be quoted"]'
-
-// picks single quotes because the value has double quotes
-attr.setValue('a "double quoted" value', {smart: true, preferCurrentQuoteMark: true, quoteMark: "'"});
-// => "[id='a "double quoted" value']"
-
-// setPropertyAndEscape lets you do anything you want. Even things that are a bad idea and illegal.
-attr.setPropertyAndEscape('value', 'xxxx', 'the password is 42');
-attr.value; // => "xxxx"
-attr.toString(); // => "[id=the password is 42]"
-
-// Pass a value directly through to the css output without escaping it.
-attr.setPropertyWithoutEscape('value', '$REPLACEMENT$');
-attr.value; // => "$REPLACEMENT$"
-attr.toString(); // => "[id=$REPLACEMENT$]"
-```
-
-# 3.1.2
-
-* Fix: Removed dot-prop dependency since it's no longer written in es5.
-
-# 3.1.1
-
-* Fix: typescript definitions weren't in the published package.
-
-# 3.1.0
-
-* Fixed numerous bugs in attribute nodes relating to the handling of comments
- and whitespace. There's significant changes to `attrNode.spaces` and `attrNode.raws` since the `3.0.0` release.
-* Added `Attribute#offsetOf(part)` to get the offset location of
- attribute parts like `"operator"` and `"value"`. This is most
- often added to `Attribute#sourceIndex` for error reporting.
-
-# 3.0.0
-
-## Breaking changes
-
-* Some tweaks to the tokenizer/attribute selector parsing mean that whitespace
- locations might be slightly different to the 2.x code.
-* Better attribute selector parsing with more validation; postcss-selector-parser
- no longer uses regular expressions to parse attribute selectors.
-* Added an async API (thanks to @jacobp100); the default `process` API is now
- async, and the sync API is now accessed through `processSync` instead.
-* `process()` and `processSync()` now return a string instead of the Processor
- instance.
-* Tweaks handling of Less interpolation (thanks to @jwilsson).
-* Removes support for Node 0.12.
-
-## Other changes
-
-* `ast()` and `astSync()` methods have been added to the `Processor`. These
- return the `Root` node of the selectors after processing them.
-* `transform()` and `transformSync()` methods have been added to the
- `Processor`. These return the value returned by the processor callback
- after processing the selectors.
-* Set the parent when inserting a node (thanks to @chriseppstein).
-* Correctly adjust indices when using insertBefore/insertAfter (thanks to @tivac).
-* Fixes handling of namespaces with qualified tag selectors.
-* `process`, `ast` and `transform` (and their sync variants) now accept a
- `postcss` rule node. When provided, better errors are generated and selector
- processing is automatically set back to the rule selector (unless the `updateSelector` option is set to `false`.)
-* Now more memory efficient when tokenizing selectors.
-
-### Upgrade hints
-
-The pattern of:
-
-`rule.selector = processor.process(rule.selector).result.toString();`
-
-is now:
-
-`processor.processSync(rule)`
-
-# 2.2.3
-
-* Resolves an issue where the parser would not reduce multiple spaces between an
- ampersand and another simple selector in lossy mode (thanks to @adam-26).
-
-# 2.2.2
-
-* No longer hangs on an unescaped semicolon; instead the parser will throw
- an exception for these cases.
-
-# 2.2.1
-
-* Allows a consumer to specify whitespace tokens when creating a new Node
- (thanks to @Semigradsky).
-
-# 2.2.0
-
-* Added a new option to normalize whitespace when parsing the selector string
- (thanks to @adam-26).
-
-# 2.1.1
-
-* Better unquoted value handling within attribute selectors
- (thanks to @evilebottnawi).
-
-# 2.1.0
-
-* Added: Use string constants for all node types & expose them on the main
- parser instance (thanks to @Aweary).
-
-# 2.0.0
-
-This release contains the following breaking changes:
-
-* Renamed all `eachInside` iterators to `walk`. For example, `eachTag` is now
- `walkTags`, and `eachInside` is now `walk`.
-* Renamed `Node#removeSelf()` to `Node#remove()`.
-* Renamed `Container#remove()` to `Container#removeChild()`.
-* Renamed `Node#raw` to `Node#raws` (thanks to @davidtheclark).
-* Now parses `&` as the *nesting* selector, rather than a *tag* selector.
-* Fixes misinterpretation of Sass interpolation (e.g. `#{foo}`) as an
- id selector (thanks to @davidtheclark).
-
-and;
-
-* Fixes parsing of attribute selectors with equals signs in them
- (e.g. `[data-attr="foo=bar"]`) (thanks to @montmanu).
-* Adds `quoted` and `raw.unquoted` properties to attribute nodes
- (thanks to @davidtheclark).
-
-# 1.3.3
-
-* Fixes an infinite loop on `)` and `]` tokens when they had no opening pairs.
- Now postcss-selector-parser will throw when it encounters these lone tokens.
-
-# 1.3.2
-
-* Now uses plain integers rather than `str.charCodeAt(0)` for compiled builds.
-
-# 1.3.1
-
-* Update flatten to v1.x (thanks to @shinnn).
-
-# 1.3.0
-
-* Adds a new node type, `String`, to fix a crash on selectors such as
- `foo:bar("test")`.
-
-# 1.2.1
-
-* Fixes a crash when the parser encountered a trailing combinator.
-
-# 1.2.0
-
-* A more descriptive error is thrown when the parser expects to find a
- pseudo-class/pseudo-element (thanks to @ashelley).
-* Adds support for line/column locations for selector nodes, as well as a
- `Node#sourceIndex` method (thanks to @davidtheclark).
-
-# 1.1.4
-
-* Fixes a crash when a selector started with a `>` combinator. The module will
- now no longer throw if a selector has a leading/trailing combinator node.
-
-# 1.1.3
-
-* Fixes a crash on `@` tokens.
-
-# 1.1.2
-
-* Fixes an infinite loop caused by using parentheses in a non-pseudo element
- context.
-
-# 1.1.1
-
-* Fixes a crash when a backslash ended a selector string.
-
-# 1.1.0
-
-* Adds support for replacing multiple nodes at once with `replaceWith`
- (thanks to @jonathantneal).
-* Parser no longer throws on sequential IDs and trailing commas, to support
- parsing of selector hacks.
-
-# 1.0.1
-
-* Fixes using `insertAfter` and `insertBefore` during iteration.
-
-# 1.0.0
-
-* Adds `clone` and `replaceWith` methods to nodes.
-* Adds `insertBefore` and `insertAfter` to containers.
-* Stabilises API.
-
-# 0.0.5
-
-* Fixes crash on extra whitespace inside a pseudo selector's parentheses.
-* Adds sort function to the container class.
-* Enables the parser to pass its input through without transforming.
-* Iteration-safe `each` and `eachInside`.
-
-# 0.0.4
-
-* Tidy up redundant duplication.
-* Fixes a bug where the parser would loop infinitely on universal selectors
- inside pseudo selectors.
-* Adds `length` getter and `eachInside`, `map`, `reduce` to the container class.
-* When a selector has been removed from the tree, the root node will no longer
- cast it to a string.
-* Adds node type iterators to the container class (e.g. `eachComment`).
-* Adds filter function to the container class.
-* Adds split function to the container class.
-* Create new node types by doing `parser.id(opts)` etc.
-* Adds support for pseudo classes anywhere in the selector.
-
-# 0.0.3
-
-* Adds `next` and `prev` to the node class.
-* Adds `first` and `last` getters to the container class.
-* Adds `every` and `some` iterators to the container class.
-* Add `empty` alias for `removeAll`.
-* Combinators are now types of node.
-* Fixes the at method so that it is not an alias for `index`.
-* Tidy up creation of new nodes in the parser.
-* Refactors how namespaces are handled for consistency & less redundant code.
-* Refactors AST to use `nodes` exclusively, and eliminates excessive nesting.
-* Fixes nested pseudo parsing.
-* Fixes whitespace parsing.
-
-# 0.0.2
-
-* Adds support for namespace selectors.
-* Adds support for selectors joined by escaped spaces - such as `.\31\ 0`.
-
-# 0.0.1
-
-* Initial release.
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/LICENSE-MIT b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/LICENSE-MIT
deleted file mode 100644
index fd0e863..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/LICENSE-MIT
+++ /dev/null
@@ -1,22 +0,0 @@
-Copyright (c) Ben Briggs <beneb.info@gmail.com> (http://beneb.info)
-
-Permission is hereby granted, free of charge, to any person
-obtaining a copy of this software and associated documentation
-files (the "Software"), to deal in the Software without
-restriction, including without limitation the rights to use,
-copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the
-Software is furnished to do so, subject to the following
-conditions:
-
-The above copyright notice and this permission notice shall be
-included in all copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
-OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
-NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
-HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
-WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
-FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
-OTHER DEALINGS IN THE SOFTWARE.
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/README.md b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/README.md
deleted file mode 100644
index 18a01c5..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/README.md
+++ /dev/null
@@ -1,49 +0,0 @@
-# postcss-selector-parser [![Build Status](https://travis-ci.org/postcss/postcss-selector-parser.svg?branch=master)](https://travis-ci.org/postcss/postcss-selector-parser)
-
-> Selector parser with built in methods for working with selector strings.
-
-## Install
-
-With [npm](https://npmjs.com/package/postcss-selector-parser) do:
-
-```
-npm install postcss-selector-parser
-```
-
-## Quick Start
-
-```js
-const parser = require('postcss-selector-parser');
-const transform = selectors => {
- selectors.walk(selector => {
- // do something with the selector
- console.log(String(selector))
- });
-};
-
-const transformed = parser(transform).processSync('h1, h2, h3');
-```
-
-To normalize selector whitespace:
-
-```js
-const parser = require('postcss-selector-parser');
-const normalized = parser().processSync('h1, h2, h3', {lossless: false});
-// -> h1,h2,h3
-```
-
-Async support is provided through `parser.process` and will resolve a Promise
-with the resulting selector string.
-
-## API
-
-Please see [API.md](API.md).
-
-## Credits
-
-* Huge thanks to Andrey Sitnik (@ai) for work on PostCSS which helped
- accelerate this module's development.
-
-## License
-
-MIT
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/attributes.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/attributes.js
deleted file mode 100644
index a7b275f..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/attributes.js
+++ /dev/null
@@ -1,477 +0,0 @@
-"use strict";
-
-var _process = _interopRequireDefault(require("process"));
-
-var _attribute = _interopRequireDefault(require("../selectors/attribute"));
-
-var _helpers = require("./util/helpers");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-_process.default.throwDeprecation = true;
-(0, _helpers.test)('attribute selector', '[href]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'attribute');
- t.falsy(tree.nodes[0].nodes[0].quoted);
-});
-(0, _helpers.test)('attribute selector spaces (before)', '[ href]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.attribute.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'attribute');
- t.falsy(tree.nodes[0].nodes[0].quoted);
-});
-(0, _helpers.test)('attribute selector spaces (after)', '[href ]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.attribute.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'attribute');
- t.falsy(tree.nodes[0].nodes[0].quoted);
-});
-(0, _helpers.test)('attribute selector spaces with namespace (both)', '[ foo|bar ]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].ns, 'foo');
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'bar');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.attribute.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.attribute.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'attribute');
- t.falsy(tree.nodes[0].nodes[0].quoted);
-});
-(0, _helpers.test)('attribute selector spaces (both)', '[ href ]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.attribute.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.attribute.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'attribute');
- t.falsy(tree.nodes[0].nodes[0].quoted);
-});
-(0, _helpers.test)('multiple attribute selectors', '[href][class][name]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[1].attribute, 'class');
- t.deepEqual(tree.nodes[0].nodes[2].attribute, 'name');
-});
-(0, _helpers.test)('select elements with or without a namespace', '[*|href]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, '*');
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
-});
-(0, _helpers.test)('namespace with escapes', '[\\31 \\#\\32 |href]', function (t, tree) {
- var attr = tree.nodes[0].nodes[0];
- t.deepEqual(attr.namespace, '1#2');
- t.deepEqual(attr.raws.namespace, '\\31 \\#\\32 ');
- attr.namespace = "foo";
- t.deepEqual(attr.namespace, 'foo');
- t.deepEqual(attr.raws.namespace, undefined);
- attr.namespace = "1";
- t.deepEqual(attr.namespace, '1');
- t.deepEqual(attr.raws.namespace, '\\31');
-});
-(0, _helpers.test)('attribute selector with a empty value', '[href=""]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].value, '');
- t.true(tree.nodes[0].nodes[0].quoted);
-});
-(0, _helpers.test)('attribute selector with a value', '[name=james]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'name');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'james');
- t.falsy(tree.nodes[0].nodes[0].quoted);
-});
-(0, _helpers.test)('attribute selector with quoted value', '[name="james"]', function (t, tree) {
- var attr = tree.nodes[0].nodes[0];
- t.deepEqual(attr.attribute, 'name');
- t.deepEqual(attr.operator, '=');
- t.deepEqual(attr.value, 'james');
- t.deepEqual(attr.quoteMark, '"');
- t.truthy(attr.quoted);
- t.deepEqual(attr.getQuotedValue(), '"james"');
-});
-(0, _helpers.test)('attribute selector with escaped quote', '[title="Something \\"weird\\""]', function (t, tree) {
- var attr = tree.nodes[0].nodes[0];
- t.deepEqual(attr.value, 'Something "weird"');
- t.deepEqual(attr.getQuotedValue(), '\"Something \\"weird\\"\"');
- t.deepEqual(attr.getQuotedValue({
- smart: true
- }), '\'Something "weird"\'');
- t.deepEqual(attr.getQuotedValue({
- quoteMark: null
- }), 'Something\\ \\"weird\\"');
- t.deepEqual(attr.quoteMark, '"');
- t.truthy(attr.quoted);
- t.deepEqual(attr.raws.value, '"Something \\"weird\\""');
- t.deepEqual(tree.toString(), '[title="Something \\"weird\\""]');
-});
-(0, _helpers.test)('attribute selector with escaped colon', '[ng\\:cloak]', function (t, tree) {
- t.deepEqual(tree.toString(), '[ng\\:cloak]');
- var attr = tree.nodes[0].nodes[0];
- t.deepEqual(attr.raws.attribute, 'ng\\:cloak');
- t.deepEqual(attr.attribute, 'ng:cloak');
-});
-(0, _helpers.test)('attribute selector with short hex escape', '[ng\\3a cloak]', function (t, tree) {
- t.deepEqual(tree.toString(), '[ng\\3a cloak]');
- var attr = tree.nodes[0].nodes[0];
- t.deepEqual(attr.raws.attribute, 'ng\\3a cloak');
- t.deepEqual(attr.attribute, 'ng:cloak');
-});
-(0, _helpers.test)('attribute selector with hex escape', '[ng\\00003acloak]', function (t, tree) {
- t.deepEqual(tree.toString(), '[ng\\00003acloak]');
- var attr = tree.nodes[0].nodes[0];
- t.deepEqual(attr.raws.attribute, 'ng\\00003acloak');
- t.deepEqual(attr.attribute, 'ng:cloak');
-});
-(0, _helpers.test)('assign attribute name requiring escape', '[ng\\:cloak]', function (t, tree) {
- var attr = tree.nodes[0].nodes[0];
- attr.attribute = "ng:foo";
- t.deepEqual(attr.raws.attribute, 'ng\\:foo');
- t.deepEqual(attr.attribute, 'ng:foo');
- t.deepEqual(tree.toString(), '[ng\\:foo]');
-});
-(0, _helpers.test)('multiple attribute selectors + combinator', '[href][class][name] h1 > h2', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[2].attribute, 'name');
- t.deepEqual(tree.nodes[0].nodes[3].value, ' ');
- t.deepEqual(tree.nodes[0].nodes[5].value, '>');
- t.deepEqual(tree.nodes[0].nodes[6].value, 'h2');
-});
-(0, _helpers.test)('attribute, class, combinator', '[href] > h2.test', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[1].value, '>');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'h2');
- t.deepEqual(tree.nodes[0].nodes[3].value, 'test');
-});
-(0, _helpers.test)('attribute selector with quoted value & combinator', '[name="james"] > h1', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'james');
- t.deepEqual(tree.nodes[0].nodes[0].quoteMark, '"');
- t.deepEqual(tree.nodes[0].nodes[1].value, '>');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'h1');
-});
-(0, _helpers.test)('multiple quoted attribute selectors', '[href*="test.com"][rel=\'external\'][id][class~="test"] > [name]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'test.com');
- t.is(tree.nodes[0].nodes[0].quoteMark, '"');
- t.deepEqual(tree.nodes[0].nodes[1].attribute, 'rel');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'external');
- t.is(tree.nodes[0].nodes[1].quoteMark, "'");
- t.deepEqual(tree.nodes[0].nodes[2].attribute, 'id');
- t.falsy(tree.nodes[0].nodes[2].value, 'should not have a value');
- t.is(tree.nodes[0].nodes[2].quoteMark, undefined, 'should not have a quoteMark set');
- t.deepEqual(tree.nodes[0].nodes[3].attribute, 'class');
- t.deepEqual(tree.nodes[0].nodes[3].value, 'test');
- t.deepEqual(tree.nodes[0].nodes[3].quoteMark, '"');
- t.deepEqual(tree.nodes[0].nodes[4].value, '>');
- t.deepEqual(tree.nodes[0].nodes[5].attribute, 'name');
- t.falsy(tree.nodes[0].nodes[5].value, 'should not have a value');
- t.is(tree.nodes[0].nodes[5].quoteMark, undefined, 'should not have a quoteMark set');
-});
-(0, _helpers.test)('more attribute operators', '[href*=test],[href^=test],[href$=test],[href|=test]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].operator, '*=');
- t.deepEqual(tree.nodes[1].nodes[0].operator, '^=');
- t.deepEqual(tree.nodes[2].nodes[0].operator, '$=');
- t.deepEqual(tree.nodes[3].nodes[0].operator, '|=');
-});
-(0, _helpers.test)('attribute selector with quoted value containing "="', '[data-weird-attr="Something=weird"]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'data-weird-attr');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'Something=weird');
- t.is(tree.nodes[0].nodes[0].quoteMark, '"');
- t.deepEqual(tree.nodes[0].nodes[0].getQuotedValue(), '"Something=weird"');
-});
-var selector = '[data-weird-attr*="Something=weird"],' + '[data-weird-attr^="Something=weird"],' + '[data-weird-attr$="Something=weird"],' + '[data-weird-attr|="Something=weird"]';
-(0, _helpers.test)('more attribute selector with quoted value containing "="', selector, function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'data-weird-attr');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '*=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'Something=weird');
- t.deepEqual(tree.nodes[1].nodes[0].attribute, 'data-weird-attr');
- t.deepEqual(tree.nodes[1].nodes[0].operator, '^=');
- t.deepEqual(tree.nodes[1].nodes[0].value, 'Something=weird');
- t.deepEqual(tree.nodes[2].nodes[0].attribute, 'data-weird-attr');
- t.deepEqual(tree.nodes[2].nodes[0].operator, '$=');
- t.deepEqual(tree.nodes[2].nodes[0].value, 'Something=weird');
- t.deepEqual(tree.nodes[3].nodes[0].attribute, 'data-weird-attr');
- t.deepEqual(tree.nodes[3].nodes[0].operator, '|=');
- t.deepEqual(tree.nodes[3].nodes[0].value, 'Something=weird');
-});
-(0, _helpers.test)('attribute selector with quoted value containing multiple "="', '[data-weird-attr="Something=weird SomethingElse=weirder"]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'data-weird-attr');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'Something=weird SomethingElse=weirder');
-});
-selector = '[data-weird-attr*="Something=weird SomethingElse=weirder"],' + '[data-weird-attr^="Something=weird SomethingElse=weirder"],' + '[data-weird-attr$="Something=weird SomethingElse=weirder"],' + '[data-weird-attr|="Something=weird SomethingElse=weirder"]';
-(0, _helpers.test)('more attribute selector with quoted value containing multiple "="', selector, function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'data-weird-attr');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '*=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'Something=weird SomethingElse=weirder');
- t.deepEqual(tree.nodes[1].nodes[0].attribute, 'data-weird-attr');
- t.deepEqual(tree.nodes[1].nodes[0].operator, '^=');
- t.deepEqual(tree.nodes[1].nodes[0].value, 'Something=weird SomethingElse=weirder');
- t.deepEqual(tree.nodes[2].nodes[0].attribute, 'data-weird-attr');
- t.deepEqual(tree.nodes[2].nodes[0].operator, '$=');
- t.deepEqual(tree.nodes[2].nodes[0].value, 'Something=weird SomethingElse=weirder');
- t.deepEqual(tree.nodes[3].nodes[0].attribute, 'data-weird-attr');
- t.deepEqual(tree.nodes[3].nodes[0].operator, '|=');
- t.deepEqual(tree.nodes[3].nodes[0].value, 'Something=weird SomethingElse=weirder');
-});
-(0, _helpers.test)('multiple attribute selectors with quoted value containing "="', '[data-weird-foo="foo=weird"][data-weird-bar="bar=weird"]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo=weird');
- t.deepEqual(tree.nodes[0].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[0].nodes[1].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'bar=weird');
-});
-(0, _helpers.test)('multiple attribute selectors with value containing escaped "="', '[data-weird-foo=foo\\=weird][data-weird-bar=bar\\3d weird]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo=weird');
- t.deepEqual(tree.nodes[0].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[0].nodes[1].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'bar=weird');
-});
-selector = '[data-weird-foo*="foo2=weirder"][data-weird-bar*="bar2=weirder"],' + '[data-weird-foo^="foo2=weirder"][data-weird-bar^="bar2=weirder"],' + '[data-weird-foo$="foo2=weirder"][data-weird-bar$="bar2=weirder"],' + '[data-weird-foo|="foo2=weirder"][data-weird-bar|="bar2=weirder"]';
-(0, _helpers.test)('more multiple attribute selectors with quoted value containing "="', selector, function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '*=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo2=weirder');
- t.deepEqual(tree.nodes[0].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[0].nodes[1].operator, '*=');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'bar2=weirder');
- t.deepEqual(tree.nodes[1].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[1].nodes[0].operator, '^=');
- t.deepEqual(tree.nodes[1].nodes[0].value, 'foo2=weirder');
- t.deepEqual(tree.nodes[1].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[1].nodes[1].operator, '^=');
- t.deepEqual(tree.nodes[1].nodes[1].value, 'bar2=weirder');
- t.deepEqual(tree.nodes[2].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[2].nodes[0].operator, '$=');
- t.deepEqual(tree.nodes[2].nodes[0].value, 'foo2=weirder');
- t.deepEqual(tree.nodes[2].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[2].nodes[1].operator, '$=');
- t.deepEqual(tree.nodes[2].nodes[1].value, 'bar2=weirder');
- t.deepEqual(tree.nodes[3].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[3].nodes[0].operator, '|=');
- t.deepEqual(tree.nodes[3].nodes[0].value, 'foo2=weirder');
- t.deepEqual(tree.nodes[3].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[3].nodes[1].operator, '|=');
- t.deepEqual(tree.nodes[3].nodes[1].value, 'bar2=weirder');
-});
-(0, _helpers.test)('multiple attribute selectors with quoted value containing multiple "="', '[data-weird-foo="foo1=weirder foo2=weirder"][data-weird-bar="bar1=weirder bar2=weirder"]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo1=weirder foo2=weirder');
- t.deepEqual(tree.nodes[0].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[0].nodes[1].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'bar1=weirder bar2=weirder');
-});
-selector = '[data-weird-foo*="foo1=weirder foo2=weirder"][data-weird-bar*="bar1=weirder bar2=weirder"],' + '[data-weird-foo^="foo1=weirder foo2=weirder"][data-weird-bar^="bar1=weirder bar2=weirder"],' + '[data-weird-foo$="foo1=weirder foo2=weirder"][data-weird-bar$="bar1=weirder bar2=weirder"],' + '[data-weird-foo|="foo1=weirder foo2=weirder"][data-weird-bar|="bar1=weirder bar2=weirder"]';
-(0, _helpers.test)('more multiple attribute selectors with quoted value containing multiple "="', selector, function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '*=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo1=weirder foo2=weirder');
- t.deepEqual(tree.nodes[0].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[0].nodes[1].operator, '*=');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'bar1=weirder bar2=weirder');
- t.deepEqual(tree.nodes[1].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[1].nodes[0].operator, '^=');
- t.deepEqual(tree.nodes[1].nodes[0].value, 'foo1=weirder foo2=weirder');
- t.deepEqual(tree.nodes[1].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[1].nodes[1].operator, '^=');
- t.deepEqual(tree.nodes[1].nodes[1].value, 'bar1=weirder bar2=weirder');
- t.deepEqual(tree.nodes[2].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[2].nodes[0].operator, '$=');
- t.deepEqual(tree.nodes[2].nodes[0].value, 'foo1=weirder foo2=weirder');
- t.deepEqual(tree.nodes[2].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[2].nodes[1].operator, '$=');
- t.deepEqual(tree.nodes[2].nodes[1].value, 'bar1=weirder bar2=weirder');
- t.deepEqual(tree.nodes[3].nodes[0].attribute, 'data-weird-foo');
- t.deepEqual(tree.nodes[3].nodes[0].operator, '|=');
- t.deepEqual(tree.nodes[3].nodes[0].value, 'foo1=weirder foo2=weirder');
- t.deepEqual(tree.nodes[3].nodes[1].attribute, 'data-weird-bar');
- t.deepEqual(tree.nodes[3].nodes[1].operator, '|=');
- t.deepEqual(tree.nodes[3].nodes[1].value, 'bar1=weirder bar2=weirder');
-});
-(0, _helpers.test)('spaces in attribute selectors', 'h1[ href *= "test" ]', function (t, tree) {
- var attr = tree.nodes[0].nodes[1];
- t.deepEqual(attr.attribute, 'href');
- t.deepEqual(attr.spaces.attribute.before, ' ');
- t.deepEqual(attr.spaces.attribute.after, ' ');
- t.deepEqual(attr.operator, '*=');
- t.deepEqual(attr.spaces.operator.after, ' ');
- t.deepEqual(attr.value, 'test');
- t.deepEqual(attr.spaces.value.after, ' ');
- t.truthy(tree.nodes[0].nodes[1].quoted);
-});
-(0, _helpers.test)('insensitive attribute selector 1', '[href="test" i]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'test');
- t.deepEqual(tree.nodes[0].nodes[0].insensitive, true);
- t.deepEqual(tree.nodes[0].nodes[0].insensitive, true);
-});
-(0, _helpers.test)('insensitive attribute selector with a empty value', '[href="" i]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].value, '');
- t.deepEqual(tree.nodes[0].nodes[0].insensitive, true);
- t.true(tree.nodes[0].nodes[0].quoted);
-});
-(0, _helpers.test)('insensitive attribute selector 2', '[href=TEsT i ]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'TEsT');
- t.deepEqual(tree.nodes[0].nodes[0].insensitive, true);
- t.deepEqual(tree.nodes[0].nodes[0].spaces.value.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.insensitive.after, ' ');
-});
-(0, _helpers.test)('insensitive attribute selector 3', '[href=test i]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'test');
- t.deepEqual(tree.nodes[0].nodes[0].insensitive, true);
-});
-(0, _helpers.test)('capitalized insensitive attribute selector 3', '[href=test I]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'test');
- t.deepEqual(tree.nodes[0].nodes[0].insensitive, true);
-});
-(0, _helpers.test)('extraneous non-combinating whitespace', ' [href] , [class] ', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.after, ' ');
- t.deepEqual(tree.nodes[1].nodes[0].attribute, 'class');
- t.deepEqual(tree.nodes[1].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[1].nodes[0].spaces.after, ' ');
-});
-(0, _helpers.test)('comments within attribute selectors', '[href/* wow */=/* wow */test]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'test');
- t.deepEqual(tree.nodes[0].nodes[0].raws.attribute, 'href/* wow */');
- t.deepEqual(tree.nodes[0].nodes[0].raws.operator, '=/* wow */');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'test');
-});
-(0, _helpers.test)('comments within attribute selectors (2)', '[/* wow */href=test/* wow */]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'test');
- t.deepEqual(tree.nodes[0].nodes[0].raws.spaces.attribute.before, '/* wow */');
- t.deepEqual(tree.nodes[0].nodes[0].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'test/* wow */');
-});
-(0, _helpers.test)('comments within attribute selectors (3)', '[href=test/* wow */i]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'testi');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'test/* wow */i');
- t.falsy(tree.nodes[0].nodes[0].insensitive);
-});
-(0, _helpers.test)('comments within attribute selectors (4)', '[ /*before*/ href /* after-attr */ = /* after-operator */ te/*inside-value*/st/* wow */ /*omg*/i/*bbq*/ /*whodoesthis*/]', function (t, tree) {
- var attr = tree.nodes[0].nodes[0];
- t.deepEqual(attr.attribute, 'href');
- t.deepEqual(attr.value, 'test');
- t.deepEqual(attr.getQuotedValue(), 'test');
- t.deepEqual(attr.raws.value, 'te/*inside-value*/st');
- t.deepEqual(attr.raws.spaces.value.after, '/* wow */ /*omg*/');
- t.truthy(attr.insensitive);
- t.deepEqual(attr.offsetOf("attribute"), 13);
- t.deepEqual(attr.offsetOf("operator"), 35);
- t.deepEqual(attr.offsetOf("insensitive"), 95);
- t.deepEqual(attr.raws.spaces.insensitive.after, '/*bbq*/ /*whodoesthis*/');
- attr.value = "foo";
- t.is(attr.raws.value, undefined);
-});
-(0, _helpers.test)('non standard modifiers', '[href="foo" y]', function (t, tree) {
- var attr = tree.atPosition(1, 13);
- t.deepEqual(attr.insensitive, false);
- t.deepEqual(attr.insensitiveFlag, '');
- t.deepEqual(attr.raws.insensitiveFlag, 'y');
- t.deepEqual(tree.toString(), '[href="foo" y]');
-});
-(0, _helpers.test)('comment after insensitive(non space)', '[href="foo" i/**/]', function (t, tree) {
- // https://github.com/postcss/postcss-selector-parser/issues/150
- var attr = tree.atPosition(1, 13);
- t.deepEqual(attr.insensitive, true);
- t.deepEqual(attr.insensitiveFlag, 'i');
- t.is(attr.raws.insensitiveFlag, undefined);
- t.deepEqual(attr.raws.spaces.insensitive.after, '/**/');
- t.deepEqual(tree.toString(), '[href="foo" i/**/]');
-});
-(0, _helpers.test)('comment after insensitive(space after)', '[href="foo" i/**/ ]', function (t, tree) {
- var attr = tree.atPosition(1, 13);
- t.deepEqual(attr.insensitive, true);
- t.deepEqual(attr.insensitiveFlag, 'i');
- t.deepEqual(attr.raws.spaces.insensitive.after, '/**/ ');
- t.deepEqual(tree.toString(), '[href="foo" i/**/ ]');
-});
-(0, _helpers.test)('comment after insensitive(space before)', '[href="foo" i /**/]', function (t, tree) {
- var attr = tree.atPosition(1, 13);
- t.deepEqual(attr.insensitive, true);
- t.deepEqual(attr.insensitiveFlag, 'i');
- t.deepEqual(attr.raws.spaces.insensitive.after, ' /**/');
- t.deepEqual(tree.toString(), '[href="foo" i /**/]');
-});
-var testDeprecation = (0, _helpers.nodeVersionAtLeast)('7.0.0') || (0, _helpers.nodeVersionBefore)('6.0.0') ? _helpers.test : _helpers.test.skip;
-testDeprecation('deprecated constructor', '', function (t) {
- t.throws(function () {
- return new _attribute.default({
- value: '"foo"',
- attribute: "data-bar"
- });
- }, "Constructing an Attribute selector with a value without specifying quoteMark is deprecated. Note: The value should be unescaped now.");
-});
-testDeprecation('deprecated get of raws.unquoted ', '', function (t) {
- t.throws(function () {
- var attr = new _attribute.default({
- value: 'foo',
- quoteMark: '"',
- attribute: "data-bar"
- });
- return attr.raws.unquoted;
- }, "attr.raws.unquoted is deprecated. Call attr.value instead.");
-});
-testDeprecation('deprecated set of raws.unquoted ', '', function (t) {
- t.throws(function () {
- var attr = new _attribute.default({
- value: 'foo',
- quoteMark: '"',
- attribute: "data-bar"
- });
- attr.raws.unquoted = 'fooooo';
- }, "Setting attr.raws.unquoted is deprecated and has no effect. attr.value is unescaped by default now.");
-});
-testDeprecation('smart quotes', '[data-foo=bar]', function (t, tree) {
- var attr = tree.nodes[0].nodes[0];
- attr.setValue('changed', {
- quoteMark: '"'
- });
- t.deepEqual(attr.toString(), '[data-foo="changed"]');
- attr.setValue('changed again', {
- quoteMark: "'",
- preferCurrentQuoteMark: true
- });
- t.deepEqual(attr.toString(), '[data-foo="changed again"]');
- attr.setValue('smart-ident', {
- smart: true
- });
- t.deepEqual(attr.toString(), '[data-foo=smart-ident]');
- attr.setValue('smart quoted', {
- smart: true
- });
- t.deepEqual(attr.toString(), '[data-foo=smart\\ quoted]');
- attr.setValue('smart quoted three spaces', {
- smart: true
- });
- t.deepEqual(attr.toString(), '[data-foo="smart quoted three spaces"]');
- attr.setValue('smart quoted three spaces', {
- smart: true,
- quoteMark: "'"
- });
- t.deepEqual(attr.toString(), "[data-foo='smart quoted three spaces']");
- attr.setValue("smart with 'single quotes'", {
- smart: true
- });
- t.deepEqual(attr.toString(), "[data-foo=\"smart with 'single quotes'\"]");
- attr.setValue('smart with "double quotes"', {
- smart: true
- });
- t.deepEqual(attr.toString(), "[data-foo='smart with \"double quotes\"']");
-});
-testDeprecation('set Attribute#quoteMark', '[data-foo=bar]', function (t, tree) {
- var attr = tree.nodes[0].nodes[0];
- attr.quoteMark = '"';
- t.deepEqual(attr.toString(), '[data-foo="bar"]');
- attr.quoteMark = "'";
- t.deepEqual(attr.toString(), "[data-foo='bar']");
- attr.quoteMark = null;
- t.deepEqual(attr.toString(), "[data-foo=bar]");
- attr.value = "has space";
- t.deepEqual(attr.toString(), "[data-foo=has\\ space]");
- attr.quoteMark = '"';
- t.deepEqual(attr.toString(), '[data-foo="has space"]');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/classes.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/classes.js
deleted file mode 100644
index 003d6b3..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/classes.js
+++ /dev/null
@@ -1,216 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('class name', '.one', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'one');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
-});
-(0, _helpers.test)('multiple class names', '.one.two.three', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'one');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'two');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'three');
-});
-(0, _helpers.test)('qualified class', 'button.btn-primary', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'tag');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'class');
-});
-(0, _helpers.test)('escaped numbers in class name', '.\\31\\ 0', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].value, '1 0');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\31\\ 0');
-});
-(0, _helpers.test)('extraneous non-combinating whitespace', ' .h1 , .h2 ', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.after, ' ');
- t.deepEqual(tree.nodes[1].nodes[0].value, 'h2');
- t.deepEqual(tree.nodes[1].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[1].nodes[0].spaces.after, ' ');
-});
-(0, _helpers.test)('Less interpolation within a class', '.foo@{bar}', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes.length, 1);
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo@{bar}');
-});
-(0, _helpers.test)('ClassName#set value', ".fo\\o", function (t, selectors) {
- var className = selectors.first.first;
- t.deepEqual(className.raws, {
- value: "fo\\o"
- });
- className.value = "bar";
- t.deepEqual(className.raws, {});
-});
-(0, _helpers.test)('escaped dot in class name', '.foo\\.bar', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo.bar');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'foo\\.bar');
-});
-(0, _helpers.test)('class selector with escaping', '.♥', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '♥');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
-});
-(0, _helpers.test)('class selector with escaping (1)', '.©', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '©');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
-});
-(0, _helpers.test)('class selector with escaping (2)', '.“‘’”', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '“‘’”');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
-});
-(0, _helpers.test)('class selector with escaping (3)', '.☺☃', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '☺☃');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
-});
-(0, _helpers.test)('class selector with escaping (4)', '.⌘⌥', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '⌘⌥');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
-});
-(0, _helpers.test)('class selector with escaping (5)', '.𝄞♪♩♫♬', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '𝄞♪♩♫♬');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
-});
-(0, _helpers.test)('class selector with escaping (6)', '.💩', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '💩');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
-});
-(0, _helpers.test)('class selector with escaping (7)', '.\\?', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '?');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\?');
-});
-(0, _helpers.test)('class selector with escaping (8)', '.\\@', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '@');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\@');
-});
-(0, _helpers.test)('class selector with escaping (9)', '.\\.', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '.');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\.');
-});
-(0, _helpers.test)('class selector with escaping (10)', '.\\3A \\)', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ':)');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\3A \\)');
-});
-(0, _helpers.test)('class selector with escaping (11)', '.\\3A \\`\\(', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ':`(');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\3A \\`\\(');
-});
-(0, _helpers.test)('class selector with escaping (12)', '.\\31 23', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '123');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\31 23');
-});
-(0, _helpers.test)('class selector with escaping (13)', '.\\31 a2b3c', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '1a2b3c');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\31 a2b3c');
-});
-(0, _helpers.test)('class selector with escaping (14)', '.\\<p\\>', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '<p>');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\<p\\>');
-});
-(0, _helpers.test)('class selector with escaping (15)', '.\\<\\>\\<\\<\\<\\>\\>\\<\\>', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '<><<<>><>');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\<\\>\\<\\<\\<\\>\\>\\<\\>');
-});
-(0, _helpers.test)('class selector with escaping (16)', '.\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\[\\>\\+\\+\\+\\+\\+\\+\\+\\>\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\>\\+\\+\\+\\>\\+\\<\\<\\<\\<\\-\\]\\>\\+\\+\\.\\>\\+\\.\\+\\+\\+\\+\\+\\+\\+\\.\\.\\+\\+\\+\\.\\>\\+\\+\\.\\<\\<\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\.\\>\\.\\+\\+\\+\\.\\-\\-\\-\\-\\-\\-\\.\\-\\-\\-\\-\\-\\-\\-\\-\\.\\>\\+\\.\\>\\.', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '++++++++++[>+++++++>++++++++++>+++>+<<<<-]>++.>+.+++++++..+++.>++.<<+++++++++++++++.>.+++.------.--------.>+.>.');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\[\\>\\+\\+\\+\\+\\+\\+\\+\\>\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\>\\+\\+\\+\\>\\+\\<\\<\\<\\<\\-\\]\\>\\+\\+\\.\\>\\+\\.\\+\\+\\+\\+\\+\\+\\+\\.\\.\\+\\+\\+\\.\\>\\+\\+\\.\\<\\<\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\.\\>\\.\\+\\+\\+\\.\\-\\-\\-\\-\\-\\-\\.\\-\\-\\-\\-\\-\\-\\-\\-\\.\\>\\+\\.\\>\\.');
-});
-(0, _helpers.test)('class selector with escaping (17)', '.\\#', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '#');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\#');
-});
-(0, _helpers.test)('class selector with escaping (18)', '.\\#\\#', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '##');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\#\\#');
-});
-(0, _helpers.test)('class selector with escaping (19)', '.\\#\\.\\#\\.\\#', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '#.#.#');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\#\\.\\#\\.\\#');
-});
-(0, _helpers.test)('class selector with escaping (20)', '.\\_', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '_');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\_');
-});
-(0, _helpers.test)('class selector with escaping (21)', '.\\{\\}', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '{}');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\{\\}');
-});
-(0, _helpers.test)('class selector with escaping (22)', '.\\#fake\\-id', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '#fake-id');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\#fake\\-id');
-});
-(0, _helpers.test)('class selector with escaping (23)', '.foo\\.bar', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo.bar');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'foo\\.bar');
-});
-(0, _helpers.test)('class selector with escaping (24)', '.\\3A hover', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ':hover');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\3A hover');
-});
-(0, _helpers.test)('class selector with escaping (25)', '.\\3A hover\\3A focus\\3A active', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ':hover:focus:active');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\3A hover\\3A focus\\3A active');
-});
-(0, _helpers.test)('class selector with escaping (26)', '.\\[attr\\=value\\]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '[attr=value]');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\[attr\\=value\\]');
-});
-(0, _helpers.test)('class selector with escaping (27)', '.f\\/o\\/o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f/o/o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\/o\\/o');
-});
-(0, _helpers.test)('class selector with escaping (28)', '.f\\\\o\\\\o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f\\o\\o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\\\o\\\\o');
-});
-(0, _helpers.test)('class selector with escaping (29)', '.f\\*o\\*o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f*o*o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\*o\\*o');
-});
-(0, _helpers.test)('class selector with escaping (30)', '.f\\!o\\!o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f!o!o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\!o\\!o');
-});
-(0, _helpers.test)('class selector with escaping (31)', '.f\\\'o\\\'o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f\'o\'o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\\'o\\\'o');
-});
-(0, _helpers.test)('class selector with escaping (32)', '.f\\~o\\~o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f~o~o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\~o\\~o');
-});
-(0, _helpers.test)('class selector with escaping (33)', '.f\\+o\\+o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f+o+o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\+o\\+o');
-});
-(0, _helpers.test)('class selector with escaping (34)', '.\\1D306', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '𝌆');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\1D306');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/combinators.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/combinators.js
deleted file mode 100644
index 93de971..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/combinators.js
+++ /dev/null
@@ -1,148 +0,0 @@
-"use strict";
-
-var _types = require("../selectors/types");
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('multiple combinating spaces', 'h1 h2', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[1].value, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].toString(), ' ');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'h2');
-});
-(0, _helpers.test)('column combinator', '.selected||td', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'selected');
- t.deepEqual(tree.nodes[0].nodes[1].value, '||');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'td');
-});
-(0, _helpers.test)('column combinator (2)', '.selected || td', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'selected');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].value, '||');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'td');
-});
-(0, _helpers.test)('descendant combinator', 'h1 h2', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[1].value, ' ');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'h2');
-});
-(0, _helpers.test)('multiple descendant combinators', 'h1 h2 h3 h4', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].value, ' ', 'should have a combinator');
- t.deepEqual(tree.nodes[0].nodes[3].value, ' ', 'should have a combinator');
- t.deepEqual(tree.nodes[0].nodes[5].value, ' ', 'should have a combinator');
-});
-(0, _helpers.test)('adjacent sibling combinator', 'h1~h2', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[1].value, '~');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'h2');
-});
-(0, _helpers.test)('adjacent sibling combinator (2)', 'h1 ~h2', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].value, '~');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'h2');
-});
-(0, _helpers.test)('adjacent sibling combinator (3)', 'h1~ h2', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[1].value, '~');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'h2');
-});
-(0, _helpers.test)('adjacent sibling combinator (4)', 'h1 ~ h2', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].value, '~');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'h2');
-});
-(0, _helpers.test)('adjacent sibling combinator (5)', 'h1~h2~h3', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[1].value, '~');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'h2');
- t.deepEqual(tree.nodes[0].nodes[3].value, '~');
- t.deepEqual(tree.nodes[0].nodes[4].value, 'h3');
-});
-(0, _helpers.test)('piercing combinator', '.a >>> .b', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'a');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].value, '>>>');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'b');
-});
-(0, _helpers.test)('named combinators', 'a /deep/ b', function (t, tree) {
- var nodes = tree.nodes[0].nodes;
- t.deepEqual(nodes[0].value, 'a');
- t.deepEqual(nodes[1].type, _types.COMBINATOR);
- t.deepEqual(nodes[1].toString(), ' /deep/ ');
- t.deepEqual(nodes[1].value, '/deep/');
- t.deepEqual(nodes[2].value, 'b');
-});
-(0, _helpers.test)('named combinators with escapes', 'a /dee\\p/ b', function (t, tree) {
- var nodes = tree.nodes[0].nodes;
- t.deepEqual(nodes[0].value, 'a');
- t.deepEqual(nodes[1].type, _types.COMBINATOR);
- t.deepEqual(nodes[1].toString(), ' /dee\\p/ ');
- t.deepEqual(nodes[1].value, '/deep/');
- t.deepEqual(nodes[2].value, 'b');
-});
-(0, _helpers.test)('named combinators with escapes and uppercase', 'a /DeE\\p/ b', function (t, tree) {
- var nodes = tree.nodes[0].nodes;
- t.deepEqual(nodes[0].value, 'a');
- t.deepEqual(nodes[1].type, _types.COMBINATOR);
- t.deepEqual(nodes[1].toString(), ' /DeE\\p/ ');
- t.deepEqual(nodes[1].value, '/deep/');
- t.deepEqual(nodes[2].value, 'b');
-});
-(0, _helpers.test)('multiple combinators', 'h1~h2>h3', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].value, '~', 'should have a combinator');
- t.deepEqual(tree.nodes[0].nodes[3].value, '>', 'should have a combinator');
-});
-(0, _helpers.test)('multiple combinators with whitespaces', 'h1 + h2 > h3', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].value, '+', 'should have a combinator');
- t.deepEqual(tree.nodes[0].nodes[3].value, '>', 'should have a combinator');
-});
-(0, _helpers.test)('multiple combinators with whitespaces (2)', 'h1+ h2 >h3', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].value, '+', 'should have a combinator');
- t.deepEqual(tree.nodes[0].nodes[3].value, '>', 'should have a combinator');
-});
-(0, _helpers.test)('trailing combinator & spaces', 'p + ', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'p', 'should be a paragraph');
- t.deepEqual(tree.nodes[0].nodes[1].value, '+', 'should have a combinator');
-});
-(0, _helpers.test)('trailing sibling combinator', 'p ~', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'p', 'should be a paragraph');
- t.deepEqual(tree.nodes[0].nodes[1].value, '~', 'should have a combinator');
-});
-(0, _helpers.test)('ending in comment has no trailing combinator', ".bar /* comment 3 */", function (t, tree) {
- var nodeTypes = tree.nodes[0].map(function (n) {
- return n.type;
- });
- t.deepEqual(nodeTypes, ["class"]);
-});
-(0, _helpers.test)('The combinating space is not a space character', ".bar\n.baz", function (t, tree) {
- var nodeTypes = tree.nodes[0].map(function (n) {
- return n.type;
- });
- t.deepEqual(nodeTypes, ["class", "combinator", "class"]);
- t.deepEqual(tree.nodes[0].nodes[1].value, ' ', 'should have a combinator');
- t.deepEqual(tree.nodes[0].nodes[1].raws.value, '\n', 'should have a raw combinator value');
-});
-(0, _helpers.test)('with spaces and a comment has only one combinator', ".bar /* comment 3 */ > .foo", function (t, tree) {
- var nodeTypes = tree.nodes[0].map(function (n) {
- return n.type;
- });
- t.deepEqual(nodeTypes, ["class", "combinator", "class"]);
-});
-(0, _helpers.test)('with a meaningful comment in the middle of a compound selector', "div/* wtf */.foo", function (t, tree) {
- var nodeTypes = tree.nodes[0].map(function (n) {
- return n.type;
- });
- t.deepEqual(nodeTypes, ["tag", "comment", "class"]);
-});
-(0, _helpers.test)('with a comment in the middle of a descendant selector', "div/* wtf */ .foo", function (t, tree) {
- var nodeTypes = tree.nodes[0].map(function (n) {
- return n.type;
- });
- t.deepEqual(nodeTypes, ["tag", "comment", "combinator", "class"]);
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/comments.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/comments.js
deleted file mode 100644
index 83463b5..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/comments.js
+++ /dev/null
@@ -1,38 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('comments', '/*test comment*/h2', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '/*test comment*/');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'h2');
-});
-(0, _helpers.test)('comments (2)', '.a /*test comment*/label', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'combinator');
- t.deepEqual(tree.nodes[0].nodes[1].value, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].rawSpaceAfter, ' /*test comment*/');
- t.deepEqual(tree.nodes[0].nodes[2].type, 'tag');
-});
-(0, _helpers.test)('comments (3)', '.a /*test comment*/ label', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'combinator');
- t.deepEqual(tree.nodes[0].nodes[1].value, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].rawSpaceBefore, ' /*test comment*/ ');
- t.deepEqual(tree.nodes[0].nodes[2].type, 'tag');
-});
-(0, _helpers.test)('multiple comments and other things', 'h1/*test*/h2/*test*/.test/*test*/', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'tag', 'should have a tag');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'comment', 'should have a comment');
- t.deepEqual(tree.nodes[0].nodes[2].type, 'tag', 'should have a tag');
- t.deepEqual(tree.nodes[0].nodes[3].type, 'comment', 'should have a comment');
- t.deepEqual(tree.nodes[0].nodes[4].type, 'class', 'should have a class name');
- t.deepEqual(tree.nodes[0].nodes[5].type, 'comment', 'should have a comment');
-});
-(0, _helpers.test)('ending in comment', ".bar /* comment 3 */", function (t, tree) {
- var classname = tree.nodes[0].nodes[0];
- t.deepEqual(classname.type, 'class', 'should have a tag');
- t.deepEqual(classname.spaces.after, ' ');
- t.deepEqual(classname.raws.spaces.after, ' /* comment 3 */');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/container.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/container.js
deleted file mode 100644
index ff1bb71..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/container.js
+++ /dev/null
@@ -1,393 +0,0 @@
-"use strict";
-
-var _ava = _interopRequireDefault(require("ava"));
-
-var _ = _interopRequireDefault(require(".."));
-
-var _helpers = require("./util/helpers");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-(0, _ava.default)('container#append', function (t) {
- var out = (0, _helpers.parse)('h1', function (selectors) {
- var selector = selectors.first;
- var clone = selector.first.clone({
- value: 'h2'
- });
- selectors.append(clone);
- });
- t.deepEqual(out, 'h1,h2');
-});
-(0, _ava.default)('container#prepend', function (t) {
- var out = (0, _helpers.parse)('h2', function (selectors) {
- var selector = selectors.first;
- var clone = selector.first.clone({
- value: 'h1'
- });
- selectors.prepend(clone);
- });
- t.deepEqual(out, 'h1,h2');
-});
-(0, _ava.default)('container#each', function (t) {
- var str = '';
- (0, _helpers.parse)('h1, h2:not(h3, h4)', function (selectors) {
- selectors.each(function (selector) {
- if (selector.first.type === 'tag') {
- str += selector.first.value;
- }
- });
- });
- t.deepEqual(str, 'h1h2');
-});
-(0, _ava.default)('container#each (safe iteration)', function (t) {
- var out = (0, _helpers.parse)('.x, .y', function (selectors) {
- selectors.each(function (selector) {
- selector.parent.insertBefore(selector, _.default.className({
- value: 'b'
- }));
- selector.parent.insertAfter(selector, _.default.className({
- value: 'a'
- }));
- });
- });
- t.deepEqual(out, '.b,.x,.a,.b, .y,.a');
-});
-(0, _ava.default)('container#each (early exit)', function (t) {
- var str = '';
- (0, _helpers.parse)('h1, h2, h3, h4', function (selectors) {
- var eachReturn = selectors.each(function (selector) {
- var tag = selector.first.value;
- str += tag;
- return tag !== 'h2';
- });
- t.false(eachReturn);
- });
- t.deepEqual(str, 'h1h2');
-});
-(0, _ava.default)('container#walk', function (t) {
- var str = '';
- (0, _helpers.parse)('h1, h2:not(h3, h4)', function (selectors) {
- selectors.walk(function (selector) {
- if (selector.type === 'tag') {
- str += selector.value;
- }
- });
- });
- t.deepEqual(str, 'h1h2h3h4');
-});
-(0, _ava.default)('container#walk (safe iteration)', function (t) {
- var out = (0, _helpers.parse)('[class] + *[href] *:not(*.green)', function (selectors) {
- selectors.walkUniversals(function (selector) {
- var next = selector.next();
-
- if (next && next.type !== 'combinator') {
- selector.remove();
- }
- });
- });
- t.deepEqual(out, '[class] + [href] :not(.green)');
-});
-(0, _ava.default)('container#walk (early exit)', function (t) {
- var str = '';
- (0, _helpers.parse)('h1, h2:not(h3, h4)', function (selectors) {
- var walkReturn = selectors.walk(function (selector) {
- if (selector.type === 'tag') {
- var tag = selector.value;
- str += tag;
- return tag !== 'h3';
- }
- });
- t.false(walkReturn);
- });
- t.deepEqual(str, 'h1h2h3');
-});
-(0, _ava.default)('container#walkAttribute', function (t) {
- var out = (0, _helpers.parse)('[href][class].class', function (selectors) {
- selectors.walkAttributes(function (attr) {
- if (attr.attribute === 'class') {
- attr.remove();
- }
- });
- });
- t.deepEqual(out, '[href].class');
-});
-(0, _ava.default)('container#walkClass', function (t) {
- var out = (0, _helpers.parse)('.one, .two, .three:not(.four, .five)', function (selectors) {
- selectors.walkClasses(function (className) {
- className.value = className.value.slice(0, 1);
- });
- });
- t.deepEqual(out, '.o, .t, .t:not(.f, .f)');
-});
-(0, _ava.default)('container#walkCombinator', function (t) {
- var out = (0, _helpers.parse)('h1 h2 h3 h4', function (selectors) {
- selectors.walkCombinators(function (comment) {
- comment.remove();
- });
- });
- t.deepEqual(out, 'h1h2h3h4');
-});
-(0, _ava.default)('container#walkComment', function (t) {
- var out = (0, _helpers.parse)('.one/*test*/.two', function (selectors) {
- selectors.walkComments(function (comment) {
- comment.remove();
- });
- });
- t.deepEqual(out, '.one.two');
-});
-(0, _ava.default)('container#walkId', function (t) {
- var out = (0, _helpers.parse)('h1#one, h2#two', function (selectors) {
- selectors.walkIds(function (id) {
- id.value = id.value.slice(0, 1);
- });
- });
- t.deepEqual(out, 'h1#o, h2#t');
-});
-(0, _ava.default)('container#walkNesting', function (t) {
- var out = (0, _helpers.parse)('& h1', function (selectors) {
- selectors.walkNesting(function (node) {
- node.replaceWith(_.default.tag({
- value: 'body'
- }));
- });
- });
- t.deepEqual(out, 'body h1');
-});
-(0, _ava.default)('container#walkPseudo', function (t) {
- var out = (0, _helpers.parse)('a:before, a:after', function (selectors) {
- selectors.walkPseudos(function (pseudo) {
- pseudo.value = pseudo.value.slice(0, 2);
- });
- });
- t.deepEqual(out, 'a:b, a:a');
-});
-(0, _ava.default)('container#walkTag', function (t) {
- var out = (0, _helpers.parse)('1 2 3', function (selectors) {
- selectors.walkTags(function (tag) {
- tag.value = 'h' + tag.value;
- });
- });
- t.deepEqual(out, 'h1 h2 h3');
-});
-(0, _ava.default)('container#walkUniversal', function (t) {
- var out = (0, _helpers.parse)('*.class,*.class,*.class', function (selectors) {
- selectors.walkUniversals(function (universal) {
- universal.remove();
- });
- });
- t.deepEqual(out, '.class,.class,.class');
-});
-(0, _ava.default)('container#map', function (t) {
- (0, _helpers.parse)('1 2 3', function (selectors) {
- var arr = selectors.first.map(function (selector) {
- if (/[0-9]/.test(selector.value)) {
- return 'h' + selector.value;
- }
-
- return selector.value;
- });
- t.deepEqual(arr, ['h1', ' ', 'h2', ' ', 'h3']);
- });
-});
-(0, _ava.default)('container#every', function (t) {
- (0, _helpers.parse)('.one.two.three', function (selectors) {
- var allClasses = selectors.first.every(function (selector) {
- return selector.type === 'class';
- });
- t.truthy(allClasses);
- });
-});
-(0, _ava.default)('container#some', function (t) {
- (0, _helpers.parse)('one#two.three', function (selectors) {
- var someClasses = selectors.first.some(function (selector) {
- return selector.type === 'class';
- });
- t.truthy(someClasses);
- });
-});
-(0, _ava.default)('container#reduce', function (t) {
- (0, _helpers.parse)('h1, h2, h3, h4', function (selectors) {
- var str = selectors.reduce(function (memo, selector) {
- if (selector.first.type === 'tag') {
- memo += selector.first.value;
- }
-
- return memo;
- }, '');
- t.deepEqual(str, 'h1h2h3h4');
- });
-});
-(0, _ava.default)('container#filter', function (t) {
- (0, _helpers.parse)('h1, h2, c1, c2', function (selectors) {
- var ast = selectors.filter(function (selector) {
- return ~selector.first.value.indexOf('h');
- });
- t.deepEqual(String(ast), 'h1, h2');
- });
-});
-(0, _ava.default)('container#split', function (t) {
- (0, _helpers.parse)('h1 h2 >> h3', function (selectors) {
- var list = selectors.first.split(function (selector) {
- return selector.value === '>>';
- }).map(function (group) {
- return group.map(String);
- });
- t.deepEqual(list, [['h1', ' ', 'h2', ' >> '], ['h3']]);
- t.deepEqual(list.length, 2);
- });
-});
-(0, _ava.default)('container#sort', function (t) {
- var out = (0, _helpers.parse)('h2,h3,h1,h4', function (selectors) {
- selectors.sort(function (a, b) {
- return a.first.value.slice(-1) - b.first.value.slice(-1);
- });
- });
- t.deepEqual(out, 'h1,h2,h3,h4');
-});
-(0, _ava.default)('container#at', function (t) {
- (0, _helpers.parse)('h1, h2, h3', function (selectors) {
- t.deepEqual(selectors.at(1).first.value, 'h2');
- });
-});
-(0, _ava.default)('container#first, container#last', function (t) {
- (0, _helpers.parse)('h1, h2, h3, h4', function (selectors) {
- t.deepEqual(selectors.first.first.value, 'h1');
- t.deepEqual(selectors.last.last.value, 'h4');
- });
-});
-(0, _ava.default)('container#index', function (t) {
- (0, _helpers.parse)('h1 h2 h3', function (selectors) {
- var middle = selectors.first.at(1);
- t.deepEqual(selectors.first.index(middle), 1);
- });
-});
-(0, _ava.default)('container#length', function (t) {
- (0, _helpers.parse)('h1, h2, h3', function (selectors) {
- t.deepEqual(selectors.length, 3);
- });
-});
-(0, _ava.default)('container#removeChild', function (t) {
- var out = (0, _helpers.parse)('h1.class h2.class h3.class', function (selectors) {
- selectors.walk(function (selector) {
- if (selector.type === 'class') {
- selector.parent.removeChild(selector);
- }
- });
- });
- t.deepEqual(out, 'h1 h2 h3');
-});
-(0, _ava.default)('container#removeAll, container#empty', function (t) {
- var wipe = function wipe(method) {
- return function (selectors) {
- return selectors[method]();
- };
- };
-
- var out1 = (0, _helpers.parse)('h1 h2, h2 h3, h3 h4', wipe('empty'));
- var out2 = (0, _helpers.parse)('h1 h2, h2 h3, h3 h4', wipe('removeAll'));
- t.deepEqual(out1, '');
- t.deepEqual(out2, '');
-});
-(0, _ava.default)('container#insertBefore', function (t) {
- var out = (0, _helpers.parse)('h2', function (selectors) {
- var selector = selectors.first;
- var clone = selector.first.clone({
- value: 'h1'
- });
- selectors.insertBefore(selector, clone);
- });
- t.deepEqual(out, 'h1,h2');
-});
-(0, _ava.default)('container#insertBefore and node#remove', function (t) {
- var out = (0, _helpers.parse)('h2', function (selectors) {
- var selector = selectors.first;
-
- var newSel = _.default.tag({
- value: 'h1'
- });
-
- selectors.insertBefore(selector, newSel);
- newSel.remove();
- });
- t.deepEqual(out, 'h2');
-});
-(0, _ava.default)('container#insertAfter', function (t) {
- var out = (0, _helpers.parse)('h1', function (selectors) {
- var selector = selectors.first;
- var clone = selector.first.clone({
- value: 'h2'
- });
- selectors.insertAfter(selector, clone);
- });
- t.deepEqual(out, 'h1,h2');
-});
-(0, _ava.default)('container#insertAfter and node#remove', function (t) {
- var out = (0, _helpers.parse)('h2', function (selectors) {
- var selector = selectors.first;
-
- var newSel = _.default.tag({
- value: 'h1'
- });
-
- selectors.insertAfter(selector, newSel);
- newSel.remove();
- });
- t.deepEqual(out, 'h2');
-});
-(0, _ava.default)('container#insertAfter (during iteration)', function (t) {
- var out = (0, _helpers.parse)('h1, h2, h3', function (selectors) {
- selectors.walkTags(function (selector) {
- var attribute = _.default.attribute({
- attribute: 'class'
- });
-
- selector.parent.insertAfter(selector, attribute);
- });
- });
- t.deepEqual(out, 'h1[class], h2[class], h3[class]');
-});
-(0, _ava.default)('Container#atPosition first pseudo', function (t) {
- (0, _helpers.parse)(':not(.foo),\n#foo > :matches(ol, ul)', function (root) {
- var node = root.atPosition(1, 1);
- t.deepEqual(node.type, "pseudo");
- t.deepEqual(node.toString(), ":not(.foo)");
- });
-});
-(0, _ava.default)('Container#atPosition class in pseudo', function (t) {
- (0, _helpers.parse)(':not(.foo),\n#foo > :matches(ol, ul)', function (root) {
- var node = root.atPosition(1, 6);
- t.deepEqual(node.type, "class");
- t.deepEqual(node.toString(), ".foo");
- });
-});
-(0, _ava.default)('Container#atPosition id in second selector', function (t) {
- (0, _helpers.parse)(':not(.foo),\n#foo > :matches(ol, ul)', function (root) {
- var node = root.atPosition(2, 1);
- t.deepEqual(node.type, "id");
- t.deepEqual(node.toString(), "\n#foo");
- });
-});
-(0, _ava.default)('Container#atPosition combinator in second selector', function (t) {
- (0, _helpers.parse)(':not(.foo),\n#foo > :matches(ol, ul)', function (root) {
- var node = root.atPosition(2, 6);
- t.deepEqual(node.type, "combinator");
- t.deepEqual(node.toString(), " > ");
- var nodeSpace = root.atPosition(2, 5);
- t.deepEqual(nodeSpace.type, "selector");
- t.deepEqual(nodeSpace.toString(), "\n#foo > :matches(ol, ul)");
- });
-});
-(0, _ava.default)('Container#atPosition tag in second selector pseudo', function (t) {
- (0, _helpers.parse)(':not(.foo),\n#foo > :matches(ol, ul)', function (root) {
- var node = root.atPosition(2, 17);
- t.deepEqual(node.type, "tag");
- t.deepEqual(node.toString(), "ol");
- });
-});
-(0, _ava.default)('Container#atPosition comma in second selector pseudo', function (t) {
- (0, _helpers.parse)(':not(.foo),\n#foo > :matches(ol, ul)', function (root) {
- var node = root.atPosition(2, 19);
- t.deepEqual(node.type, "pseudo");
- t.deepEqual(node.toString(), ":matches(ol, ul)");
- });
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/escapes.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/escapes.js
deleted file mode 100644
index cebabd9..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/escapes.js
+++ /dev/null
@@ -1,19 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('escaped semicolon in class', '.\\;', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ';');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\;');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
-});
-(0, _helpers.test)('escaped semicolon in id', '#\\;', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ';');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\;');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
-}); // This is a side-effect of allowing media queries to be parsed. Not sure it shouldn't just be an error.
-
-(0, _helpers.test)('bare parens capture contents as a string', '(h1)', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '(h1)');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'string');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/exceptions.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/exceptions.js
deleted file mode 100644
index 5f7c41c..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/exceptions.js
+++ /dev/null
@@ -1,24 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-// Unclosed elements
-(0, _helpers.throws)('unclosed string', 'a[href="wow]');
-(0, _helpers.throws)('unclosed comment', '/* oops');
-(0, _helpers.throws)('unclosed pseudo element', 'button::');
-(0, _helpers.throws)('unclosed pseudo class', 'a:');
-(0, _helpers.throws)('unclosed attribute selector', '[name="james"][href');
-(0, _helpers.throws)('no opening parenthesis', ')');
-(0, _helpers.throws)('no opening parenthesis (2)', ':global.foo)');
-(0, _helpers.throws)('no opening parenthesis (3)', 'h1:not(h2:not(h3)))');
-(0, _helpers.throws)('no opening square bracket', ']');
-(0, _helpers.throws)('no opening square bracket (2)', ':global.foo]');
-(0, _helpers.throws)('no opening square bracket (3)', '[global]]');
-(0, _helpers.throws)('bad pseudo element', 'button::"after"');
-(0, _helpers.throws)('missing closing parenthesis in pseudo', ':not([attr="test"]:not([attr="test"])');
-(0, _helpers.throws)('bad syntax', '-moz-osx-font-smoothing: grayscale');
-(0, _helpers.throws)('bad syntax (2)', '! .body');
-(0, _helpers.throws)('missing backslash for semicolon', '.;');
-(0, _helpers.throws)('missing backslash for semicolon (2)', '.\;');
-(0, _helpers.throws)('unexpected / foo', '-Option\/root', "Unexpected '/'. Escaping special characters with \\ may help.");
-(0, _helpers.throws)('bang in selector', '.foo !optional', "Unexpected '!'. Escaping special characters with \\ may help."); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/guards.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/guards.js
deleted file mode 100644
index b2045ca..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/guards.js
+++ /dev/null
@@ -1,118 +0,0 @@
-"use strict";
-
-var _ = _interopRequireDefault(require("../"));
-
-var _helpers = require("./util/helpers");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-var node = function node(tree, n) {
- if (n === void 0) {
- n = 0;
- }
-
- return tree.nodes[0].nodes[n];
-};
-
-(0, _helpers.test)('attribute guard', '[foo]', function (t, tree) {
- var n = node(tree);
- t.true(_.default.isNode(n));
- t.false(_.default.isAttribute(undefined));
- t.true(_.default.isAttribute(n));
- t.false(_.default.isContainer(n));
- t.true(_.default.isNamespace(n));
-});
-(0, _helpers.test)('className guard', '.foo', function (t, tree) {
- var n = node(tree);
- t.true(_.default.isNode(n));
- t.false(_.default.isClassName(undefined));
- t.true(_.default.isClassName(n));
- t.false(_.default.isContainer(n));
- t.false(_.default.isNamespace(n));
-});
-(0, _helpers.test)('combinator guard', '.foo > .bar', function (t, tree) {
- var n = node(tree, 1);
- t.true(_.default.isNode(n));
- t.false(_.default.isCombinator(undefined));
- t.true(_.default.isCombinator(n));
- t.false(_.default.isContainer(n));
- t.false(_.default.isNamespace(n));
-});
-(0, _helpers.test)('comment guard', '/* foo */.foo > .bar', function (t, tree) {
- var n = node(tree);
- t.true(_.default.isNode(n));
- t.false(_.default.isComment(undefined));
- t.true(_.default.isComment(n));
- t.false(_.default.isContainer(n));
- t.false(_.default.isNamespace(n));
-});
-(0, _helpers.test)('id guard', '#ident', function (t, tree) {
- var n = node(tree);
- t.true(_.default.isNode(n));
- t.false(_.default.isIdentifier(undefined));
- t.true(_.default.isIdentifier(n));
- t.false(_.default.isContainer(n));
- t.false(_.default.isNamespace(n));
-});
-(0, _helpers.test)('nesting guard', '&.foo', function (t, tree) {
- var n = node(tree);
- t.true(_.default.isNode(n));
- t.false(_.default.isNesting(undefined));
- t.true(_.default.isNesting(n));
- t.false(_.default.isContainer(n));
- t.false(_.default.isNamespace(n));
-});
-(0, _helpers.test)('pseudo class guard', ':hover', function (t, tree) {
- var n = node(tree);
- t.true(_.default.isNode(n));
- t.false(_.default.isPseudo(undefined));
- t.true(_.default.isPseudo(n));
- t.true(_.default.isPseudoClass(n));
- t.false(_.default.isPseudoElement(n));
- t.true(_.default.isContainer(n));
- t.false(_.default.isNamespace(n));
-});
-(0, _helpers.test)('pseudo element guard', '::first-line', function (t, tree) {
- var n = node(tree);
- t.true(_.default.isNode(n));
- t.false(_.default.isPseudo(undefined));
- t.true(_.default.isPseudo(n));
- t.false(_.default.isPseudoClass(n));
- t.true(_.default.isPseudoElement(n));
- t.true(_.default.isContainer(n));
- t.false(_.default.isNamespace(n));
-});
-(0, _helpers.test)('special pseudo element guard', ':before:after', function (t, tree) {
- [node(tree), node(tree, 1)].forEach(function (n) {
- t.true(_.default.isPseudo(n));
- t.false(_.default.isPseudoClass(n));
- t.true(_.default.isPseudoElement(n));
- t.true(_.default.isContainer(n));
- t.false(_.default.isNamespace(n));
- });
-});
-(0, _helpers.test)('string guard', '"string"', function (t, tree) {
- var n = node(tree);
- t.true(_.default.isNode(n));
- t.false(_.default.isString(undefined));
- t.true(_.default.isString(n));
- t.false(_.default.isContainer(n));
- t.false(_.default.isNamespace(n));
-});
-(0, _helpers.test)('tag guard', 'h1', function (t, tree) {
- var n = node(tree);
- t.false(_.default.isNode(undefined));
- t.true(_.default.isNode(n));
- t.false(_.default.isTag(undefined));
- t.true(_.default.isTag(n));
- t.false(_.default.isContainer(n));
- t.true(_.default.isNamespace(n));
-});
-(0, _helpers.test)('universal guard', '*', function (t, tree) {
- var n = node(tree);
- t.true(_.default.isNode(n));
- t.false(_.default.isUniversal(undefined));
- t.true(_.default.isUniversal(n));
- t.false(_.default.isContainer(n));
- t.false(_.default.isNamespace(n));
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/id.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/id.js
deleted file mode 100644
index 73386f6..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/id.js
+++ /dev/null
@@ -1,229 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('id selector', '#one', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'one');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
-});
-(0, _helpers.test)('id hack', '#one#two', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'id');
-});
-(0, _helpers.test)('id and class names mixed', '#one.two.three', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'one');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'two');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'three');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[2].type, 'class');
-});
-(0, _helpers.test)('qualified id', 'button#one', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'tag');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'id');
-});
-(0, _helpers.test)('qualified id & class name', 'h1#one.two', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'tag');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[2].type, 'class');
-});
-(0, _helpers.test)('extraneous non-combinating whitespace', ' #h1 , #h2 ', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.after, ' ');
- t.deepEqual(tree.nodes[1].nodes[0].value, 'h2');
- t.deepEqual(tree.nodes[1].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[1].nodes[0].spaces.after, ' ');
-});
-(0, _helpers.test)('Sass interpolation within a class', '.#{foo}', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes.length, 1);
- t.deepEqual(tree.nodes[0].nodes[0].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[0].value, '#{foo}');
-});
-(0, _helpers.test)('Sass interpolation within an id', '#foo#{bar}', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes.length, 1);
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo#{bar}');
-});
-(0, _helpers.test)('Less interpolation within an id', '#foo@{bar}', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes.length, 1);
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo@{bar}');
-});
-(0, _helpers.test)('id selector with escaping', '#\\#test', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '#test');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\#test');
-});
-(0, _helpers.test)('id selector with escaping (2)', '#-a-b-c-', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '-a-b-c-');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
-});
-(0, _helpers.test)('id selector with escaping (3)', '#u-m\\00002b', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'u-m+');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'u-m\\00002b');
-});
-(0, _helpers.test)('id selector with escaping (4)', '#♥', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '♥');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
-});
-(0, _helpers.test)('id selector with escaping (5)', '#©', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '©');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
-});
-(0, _helpers.test)('id selector with escaping (6)', '#“‘’”', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '“‘’”');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
-});
-(0, _helpers.test)('id selector with escaping (7)', '#☺☃', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '☺☃');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
-});
-(0, _helpers.test)('id selector with escaping (8)', '#⌘⌥', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '⌘⌥');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
-});
-(0, _helpers.test)('id selector with escaping (9)', '#𝄞♪♩♫♬', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '𝄞♪♩♫♬');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
-});
-(0, _helpers.test)('id selector with escaping (10)', '#💩', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '💩');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
-});
-(0, _helpers.test)('id selector with escaping (11)', '#\\?', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '?');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\?');
-});
-(0, _helpers.test)('id selector with escaping (12)', '#\\@', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '@');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\@');
-});
-(0, _helpers.test)('id selector with escaping (13)', '#\\.', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '.');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\.');
-});
-(0, _helpers.test)('id selector with escaping (14)', '#\\3A \\)', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ':)');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\3A \\)');
-});
-(0, _helpers.test)('id selector with escaping (15)', '#\\3A \\`\\(', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ':`(');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\3A \\`\\(');
-});
-(0, _helpers.test)('id selector with escaping (16)', '#\\31 23', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '123');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\31 23');
-});
-(0, _helpers.test)('id selector with escaping (17)', '#\\31 a2b3c', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '1a2b3c');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\31 a2b3c');
-});
-(0, _helpers.test)('id selector with escaping (18)', '#\\<p\\>', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '<p>');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\<p\\>');
-});
-(0, _helpers.test)('id selector with escaping (19)', '#\\<\\>\\<\\<\\<\\>\\>\\<\\>', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '<><<<>><>');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\<\\>\\<\\<\\<\\>\\>\\<\\>');
-});
-(0, _helpers.test)('id selector with escaping (20)', '#\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\[\\>\\+\\+\\+\\+\\+\\+\\+\\>\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\>\\+\\+\\+\\>\\+\\<\\<\\<\\<\\-\\]\\>\\+\\+\\.\\>\\+\\.\\+\\+\\+\\+\\+\\+\\+\\.\\.\\+\\+\\+\\.\\>\\+\\+\\.\\<\\<\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\.\\>\\.\\+\\+\\+\\.\\-\\-\\-\\-\\-\\-\\.\\-\\-\\-\\-\\-\\-\\-\\-\\.\\>\\+\\.\\>\\.', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '++++++++++[>+++++++>++++++++++>+++>+<<<<-]>++.>+.+++++++..+++.>++.<<+++++++++++++++.>.+++.------.--------.>+.>.');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\[\\>\\+\\+\\+\\+\\+\\+\\+\\>\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\>\\+\\+\\+\\>\\+\\<\\<\\<\\<\\-\\]\\>\\+\\+\\.\\>\\+\\.\\+\\+\\+\\+\\+\\+\\+\\.\\.\\+\\+\\+\\.\\>\\+\\+\\.\\<\\<\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\+\\.\\>\\.\\+\\+\\+\\.\\-\\-\\-\\-\\-\\-\\.\\-\\-\\-\\-\\-\\-\\-\\-\\.\\>\\+\\.\\>\\.');
-});
-(0, _helpers.test)('id selector with escaping (21)', '#\\#', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '#');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\#');
-});
-(0, _helpers.test)('id selector with escaping (22)', '#\\#\\#', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '##');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\#\\#');
-});
-(0, _helpers.test)('id selector with escaping (23)', '#\\#\\.\\#\\.\\#', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '#.#.#');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\#\\.\\#\\.\\#');
-});
-(0, _helpers.test)('id selector with escaping (24)', '#\\_', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '_');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\_');
-});
-(0, _helpers.test)('id selector with escaping (25)', '#\\{\\}', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '{}');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\{\\}');
-});
-(0, _helpers.test)('id selector with escaping (26)', '#\\.fake\\-class', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '.fake-class');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\.fake\\-class');
-});
-(0, _helpers.test)('id selector with escaping (27)', '#foo\\.bar', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'foo.bar');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'foo\\.bar');
-});
-(0, _helpers.test)('id selector with escaping (28)', '#\\3A hover', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ':hover');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\3A hover');
-});
-(0, _helpers.test)('id selector with escaping (29)', '#\\3A hover\\3A focus\\3A active', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ':hover:focus:active');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\3A hover\\3A focus\\3A active');
-});
-(0, _helpers.test)('id selector with escaping (30)', '#\\[attr\\=value\\]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '[attr=value]');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, '\\[attr\\=value\\]');
-});
-(0, _helpers.test)('id selector with escaping (31)', '#f\\/o\\/o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f/o/o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\/o\\/o');
-});
-(0, _helpers.test)('id selector with escaping (32)', '#f\\\\o\\\\o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f\\o\\o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\\\o\\\\o');
-});
-(0, _helpers.test)('id selector with escaping (33)', '#f\\*o\\*o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f*o*o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\*o\\*o');
-});
-(0, _helpers.test)('id selector with escaping (34)', '#f\\!o\\!o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f!o!o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\!o\\!o');
-});
-(0, _helpers.test)('id selector with escaping (35)', '#f\\\'o\\\'o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f\'o\'o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\\'o\\\'o');
-});
-(0, _helpers.test)('id selector with escaping (36)', '#f\\~o\\~o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f~o~o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\~o\\~o');
-});
-(0, _helpers.test)('id selector with escaping (37)', '#f\\+o\\+o', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'f+o+o');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'id');
- t.deepEqual(tree.nodes[0].nodes[0].raws.value, 'f\\+o\\+o');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/lossy.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/lossy.js
deleted file mode 100644
index bfec388..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/lossy.js
+++ /dev/null
@@ -1,88 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.testLossy = exports.parse = void 0;
-
-var _ava = _interopRequireDefault(require("ava"));
-
-var _index = _interopRequireDefault(require("../index"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-var parse = function parse(input, options, transform) {
- return (0, _index.default)(transform).processSync(input, options);
-};
-
-exports.parse = parse;
-
-var testLossy = function testLossy(t, input, expected) {
- var result = parse(input, {
- lossless: false
- });
- t.deepEqual(result, expected);
-};
-
-exports.testLossy = testLossy;
-(0, _ava.default)('combinator, descendant - single', testLossy, '.one .two', '.one .two');
-(0, _ava.default)('combinator, descendant - multiple', testLossy, '.one .two', '.one .two');
-(0, _ava.default)('combinator, child - space before', testLossy, '.one >.two', '.one>.two');
-(0, _ava.default)('combinator, child - space after', testLossy, '.one> .two', '.one>.two');
-(0, _ava.default)('combinator, sibling - space before', testLossy, '.one ~.two', '.one~.two');
-(0, _ava.default)('combinator, sibling - space after', testLossy, '.one~ .two', '.one~.two');
-(0, _ava.default)('combinator, adj sibling - space before', testLossy, '.one +.two', '.one+.two');
-(0, _ava.default)('combinator, adj sibling - space after', testLossy, '.one+ .two', '.one+.two');
-(0, _ava.default)('classes, extraneous spaces', testLossy, ' .h1 , .h2 ', '.h1,.h2');
-(0, _ava.default)('ids, extraneous spaces', testLossy, ' #h1 , #h2 ', '#h1,#h2');
-(0, _ava.default)('attribute, spaces in selector', testLossy, 'h1[ href *= "test" ]', 'h1[href*="test"]');
-(0, _ava.default)('attribute, insensitive flag 1', testLossy, '[href="test" i ]', '[href="test"i]');
-(0, _ava.default)('attribute, insensitive flag 2', testLossy, '[href=TEsT i ]', '[href=TEsT i]');
-(0, _ava.default)('attribute, insensitive flag 3', testLossy, '[href=test i ]', '[href=test i]');
-(0, _ava.default)('attribute, extreneous whitespace', testLossy, ' [href] , [class] ', '[href],[class]');
-(0, _ava.default)('namespace, space before', testLossy, ' postcss|button', 'postcss|button');
-(0, _ava.default)('namespace, space after', testLossy, 'postcss|button ', 'postcss|button');
-(0, _ava.default)('namespace - all elements, space before', testLossy, ' postcss|*', 'postcss|*');
-(0, _ava.default)('namespace - all elements, space after', testLossy, 'postcss|* ', 'postcss|*');
-(0, _ava.default)('namespace - all namespaces, space before', testLossy, ' *|button', '*|button');
-(0, _ava.default)('namespace - all namespaces, space after', testLossy, '*|button ', '*|button');
-(0, _ava.default)('namespace - all elements in all namespaces, space before', testLossy, ' *|*', '*|*');
-(0, _ava.default)('namespace - all elements in all namespaces, space after', testLossy, '*|* ', '*|*');
-(0, _ava.default)('namespace - all elements without namespace, space before', testLossy, ' |*', '|*');
-(0, _ava.default)('namespace - all elements without namespace, space after', testLossy, '|* ', '|*');
-(0, _ava.default)('namespace - tag with no namespace, space before', testLossy, ' |button', '|button');
-(0, _ava.default)('namespace - tag with no namespace, space after', testLossy, '|button ', '|button');
-(0, _ava.default)('namespace - inside attribute, space before', testLossy, ' [ postcss|href=test]', '[postcss|href=test]');
-(0, _ava.default)('namespace - inside attribute, space after', testLossy, '[postcss|href= test ] ', '[postcss|href=test]');
-(0, _ava.default)('namespace - inside attribute (2), space before', testLossy, ' [ postcss|href]', '[postcss|href]');
-(0, _ava.default)('namespace - inside attribute (2), space after', testLossy, '[postcss|href ] ', '[postcss|href]');
-(0, _ava.default)('namespace - inside attribute (3), space before', testLossy, ' [ *|href=test]', '[*|href=test]');
-(0, _ava.default)('namespace - inside attribute (3), space after', testLossy, '[*|href= test ] ', '[*|href=test]');
-(0, _ava.default)('namespace - inside attribute (4), space after', testLossy, '[|href= test ] ', '[|href=test]');
-(0, _ava.default)('tag - extraneous whitespace', testLossy, ' h1 , h2 ', 'h1,h2');
-(0, _ava.default)('tag - trailing comma', testLossy, 'h1, ', 'h1,');
-(0, _ava.default)('tag - trailing comma (1)', testLossy, 'h1,', 'h1,');
-(0, _ava.default)('tag - trailing comma (2)', testLossy, 'h1', 'h1');
-(0, _ava.default)('tag - trailing slash (1)', testLossy, 'h1\\ ', 'h1\\ ');
-(0, _ava.default)('tag - trailing slash (2)', testLossy, 'h1\\ h2\\', 'h1\\ h2\\');
-(0, _ava.default)('universal - combinator', testLossy, ' * + * ', '*+*');
-(0, _ava.default)('universal - extraneous whitespace', testLossy, ' * , * ', '*,*');
-(0, _ava.default)('universal - qualified universal selector', testLossy, '*[href] *:not(*.green)', '*[href] *:not(*.green)');
-(0, _ava.default)('nesting - spacing before', testLossy, ' &.class', '&.class');
-(0, _ava.default)('nesting - spacing after', testLossy, '&.class ', '&.class');
-(0, _ava.default)('nesting - spacing between', testLossy, '& .class ', '& .class');
-(0, _ava.default)('pseudo (single) - spacing before', testLossy, ' :after', ':after');
-(0, _ava.default)('pseudo (single) - spacing after', testLossy, ':after ', ':after');
-(0, _ava.default)('pseudo (double) - spacing before', testLossy, ' ::after', '::after');
-(0, _ava.default)('pseudo (double) - spacing after', testLossy, '::after ', '::after');
-(0, _ava.default)('pseudo - multiple', testLossy, ' *:target::before , a:after ', '*:target::before,a:after');
-(0, _ava.default)('pseudo - negated', testLossy, 'h1:not( .heading )', 'h1:not(.heading)');
-(0, _ava.default)('pseudo - negated with combinators (1)', testLossy, 'h1:not(.heading > .title) > h1', 'h1:not(.heading>.title)>h1');
-(0, _ava.default)('pseudo - negated with combinators (2)', testLossy, '.foo:nth-child(2n + 1)', '.foo:nth-child(2n+1)');
-(0, _ava.default)('pseudo - extra whitespace', testLossy, 'a:not( h2 )', 'a:not(h2)');
-(0, _ava.default)('comments - comment inside descendant selector', testLossy, "div /* wtf */.foo", "div /* wtf */.foo");
-(0, _ava.default)('comments - comment inside complex selector', testLossy, "div /* wtf */ > .foo", "div/* wtf */>.foo");
-(0, _ava.default)('comments - comment inside compound selector with space', testLossy, "div /* wtf */ .foo", "div /* wtf */.foo");
-(0, _ava.default)('@words - space before', testLossy, ' @media', '@media');
-(0, _ava.default)('@words - space after', testLossy, '@media ', '@media');
-(0, _ava.default)('@words - maintains space between', testLossy, '@media (min-width: 700px) and (orientation: landscape)', '@media (min-width: 700px) and (orientation: landscape)');
-(0, _ava.default)('@words - extraneous space between', testLossy, '@media (min-width: 700px) and (orientation: landscape)', '@media (min-width: 700px) and (orientation: landscape)');
-(0, _ava.default)('@words - multiple', testLossy, '@media (min-width: 700px), (min-height: 400px)', '@media (min-width: 700px),(min-height: 400px)'); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/namespaces.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/namespaces.js
deleted file mode 100644
index 15333e6..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/namespaces.js
+++ /dev/null
@@ -1,66 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('match tags in the postcss namespace', 'postcss|button', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, 'postcss');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'button');
-});
-(0, _helpers.test)('match everything in the postcss namespace', 'postcss|*', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, 'postcss');
- t.deepEqual(tree.nodes[0].nodes[0].value, '*');
-});
-(0, _helpers.test)('match any namespace', '*|button', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, '*');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'button');
-});
-(0, _helpers.test)('match all elements within the postcss namespace', 'postcss|*', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, 'postcss');
- t.deepEqual(tree.nodes[0].nodes[0].value, '*');
-});
-(0, _helpers.test)('match all elements in all namespaces', '*|*', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, '*');
- t.deepEqual(tree.nodes[0].nodes[0].value, '*');
-});
-(0, _helpers.test)('match all elements without a namespace', '|*', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, true);
- t.deepEqual(tree.nodes[0].nodes[0].value, '*');
-});
-(0, _helpers.test)('match tags with no namespace', '|button', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, true);
- t.deepEqual(tree.nodes[0].nodes[0].value, 'button');
-});
-(0, _helpers.test)('match namespace inside attribute selector', '[postcss|href=test]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, 'postcss');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'test');
-});
-(0, _helpers.test)('match namespace inside attribute selector (2)', '[postcss|href]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, 'postcss');
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
-});
-(0, _helpers.test)('match namespace inside attribute selector (3)', '[*|href]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, '*');
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
-});
-(0, _helpers.test)('match default namespace inside attribute selector', '[|href]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, true);
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
-});
-(0, _helpers.test)('match default namespace inside attribute selector with spaces', '[ |href ]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, true);
- t.deepEqual(tree.nodes[0].nodes[0].attribute, 'href');
-});
-(0, _helpers.test)('namespace with qualified id selector', 'ns|h1#foo', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, 'ns');
-});
-(0, _helpers.test)('namespace with qualified class selector', 'ns|h1.foo', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].namespace, 'ns');
-});
-(0, _helpers.test)('ns alias for namespace', 'f\\oo|h1.foo', function (t, tree) {
- var tag = tree.nodes[0].nodes[0];
- t.deepEqual(tag.namespace, 'foo');
- t.deepEqual(tag.ns, 'foo');
- tag.ns = "bar";
- t.deepEqual(tag.namespace, 'bar');
- t.deepEqual(tag.ns, 'bar');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/nesting.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/nesting.js
deleted file mode 100644
index e3c164a..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/nesting.js
+++ /dev/null
@@ -1,40 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('nesting selector', '&', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '&');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'nesting');
-});
-(0, _helpers.test)('nesting selector followed by a class', '& .class', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '&');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'nesting');
- t.deepEqual(tree.nodes[0].nodes[1].value, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'combinator');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'class');
- t.deepEqual(tree.nodes[0].nodes[2].type, 'class');
-});
-(0, _helpers.test)('&foo', '&foo', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '&');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'nesting');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'foo');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'tag');
-});
-(0, _helpers.test)('&-foo', '&-foo', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '&');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'nesting');
- t.deepEqual(tree.nodes[0].nodes[1].value, '-foo');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'tag');
-});
-(0, _helpers.test)('&_foo', '&_foo', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '&');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'nesting');
- t.deepEqual(tree.nodes[0].nodes[1].value, '_foo');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'tag');
-});
-(0, _helpers.test)('&|foo', '&|foo', function (t, tree) {
- var element = tree.nodes[0].nodes[0];
- t.deepEqual(element.value, 'foo');
- t.deepEqual(element.type, 'tag');
- t.deepEqual(element.namespace, '&');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/node.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/node.js
deleted file mode 100644
index 6590bf4..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/node.js
+++ /dev/null
@@ -1,139 +0,0 @@
-"use strict";
-
-var _ava = _interopRequireDefault(require("ava"));
-
-var _ = _interopRequireDefault(require(".."));
-
-var _helpers = require("./util/helpers");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-(0, _ava.default)('node#clone', function (t) {
- (0, _helpers.parse)('[href="test"]', function (selectors) {
- var selector = selectors.first.first;
- var clone = selector.clone();
- delete selector.parent;
- t.deepEqual(clone, selectors.first.first);
- });
-});
-(0, _ava.default)('node#clone of attribute', function (t) {
- (0, _helpers.parse)('[href=test]', function (selectors) {
- var selector = selectors.first.first;
- var clone = selector.clone();
- delete selector.parent;
- t.deepEqual(clone, selectors.first.first);
- });
-});
-(0, _ava.default)('node#replaceWith', function (t) {
- var out = (0, _helpers.parse)('[href="test"]', function (selectors) {
- var attr = selectors.first.first;
-
- var id = _.default.id({
- value: 'test'
- });
-
- var className = _.default.className({
- value: 'test'
- });
-
- attr.replaceWith(id, className);
- });
- t.deepEqual(out, '#test.test');
-});
-(0, _ava.default)('Node#appendToPropertyAndEscape', function (t) {
- var out = (0, _helpers.parse)('.fo\\o', function (selectors) {
- var className = selectors.first.first;
- t.deepEqual(className.raws, {
- value: "fo\\o"
- });
- className.appendToPropertyAndEscape("value", "bar", "ba\\r");
- t.deepEqual(className.raws, {
- value: "fo\\oba\\r"
- });
- });
- t.deepEqual(out, '.fo\\oba\\r');
-});
-(0, _ava.default)('Node#setPropertyAndEscape with existing raws', function (t) {
- var out = (0, _helpers.parse)('.fo\\o', function (selectors) {
- var className = selectors.first.first;
- t.deepEqual(className.raws, {
- value: "fo\\o"
- });
- className.setPropertyAndEscape("value", "bar", "ba\\r");
- t.deepEqual(className.raws, {
- value: "ba\\r"
- });
- });
- t.deepEqual(out, '.ba\\r');
-});
-(0, _ava.default)('Node#setPropertyAndEscape without existing raws', function (t) {
- var out = (0, _helpers.parse)('.foo', function (selectors) {
- var className = selectors.first.first;
- t.deepEqual(className.raws, undefined);
- className.setPropertyAndEscape("value", "bar", "ba\\r");
- t.deepEqual(className.raws, {
- value: "ba\\r"
- });
- });
- t.deepEqual(out, '.ba\\r');
-});
-(0, _ava.default)('Node#setPropertyWithoutEscape with existing raws', function (t) {
- var out = (0, _helpers.parse)('.fo\\o', function (selectors) {
- var className = selectors.first.first;
- t.deepEqual(className.raws, {
- value: "fo\\o"
- });
- className.setPropertyWithoutEscape("value", "w+t+f");
- t.deepEqual(className.raws, {});
- });
- t.deepEqual(out, '.w+t+f');
-});
-(0, _ava.default)('Node#setPropertyWithoutEscape without existing raws', function (t) {
- var out = (0, _helpers.parse)('.foo', function (selectors) {
- var className = selectors.first.first;
- t.deepEqual(className.raws, undefined);
- className.setPropertyWithoutEscape("value", "w+t+f");
- t.deepEqual(className.raws, {});
- t.deepEqual(className.value, "w+t+f");
- });
- t.deepEqual(out, '.w+t+f');
-});
-(0, _ava.default)('Node#isAtPosition', function (t) {
- (0, _helpers.parse)(':not(.foo),\n#foo > :matches(ol, ul)', function (root) {
- t.deepEqual(root.isAtPosition(1, 1), true);
- t.deepEqual(root.isAtPosition(1, 10), true);
- t.deepEqual(root.isAtPosition(2, 23), true);
- t.deepEqual(root.isAtPosition(2, 24), false);
- var selector = root.first;
- t.deepEqual(selector.isAtPosition(1, 1), true);
- t.deepEqual(selector.isAtPosition(1, 10), true);
- t.deepEqual(selector.isAtPosition(1, 11), false);
- var pseudoNot = selector.first;
- t.deepEqual(pseudoNot.isAtPosition(1, 1), true);
- t.deepEqual(pseudoNot.isAtPosition(1, 7), true);
- t.deepEqual(pseudoNot.isAtPosition(1, 10), true);
- t.deepEqual(pseudoNot.isAtPosition(1, 11), false);
- var notSelector = pseudoNot.first;
- t.deepEqual(notSelector.isAtPosition(1, 1), false);
- t.deepEqual(notSelector.isAtPosition(1, 4), false);
- t.deepEqual(notSelector.isAtPosition(1, 5), true);
- t.deepEqual(notSelector.isAtPosition(1, 6), true);
- t.deepEqual(notSelector.isAtPosition(1, 9), true);
- t.deepEqual(notSelector.isAtPosition(1, 10), true);
- t.deepEqual(notSelector.isAtPosition(1, 11), false);
- var notClass = notSelector.first;
- t.deepEqual(notClass.isAtPosition(1, 5), false);
- t.deepEqual(notClass.isAtPosition(1, 6), true);
- t.deepEqual(notClass.isAtPosition(1, 9), true);
- t.deepEqual(notClass.isAtPosition(1, 10), false);
- var secondSel = root.at(1);
- t.deepEqual(secondSel.isAtPosition(1, 11), false);
- t.deepEqual(secondSel.isAtPosition(2, 1), true);
- t.deepEqual(secondSel.isAtPosition(2, 23), true);
- t.deepEqual(secondSel.isAtPosition(2, 24), false);
- var combinator = secondSel.at(1);
- t.deepEqual(combinator.isAtPosition(2, 5), false);
- t.deepEqual(combinator.isAtPosition(2, 6), true);
- t.deepEqual(combinator.isAtPosition(2, 7), false);
- });
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/nonstandard.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/nonstandard.js
deleted file mode 100644
index 599e64d..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/nonstandard.js
+++ /dev/null
@@ -1,38 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('non-standard selector', '.icon.is-$(network)', function (t, tree) {
- var class1 = tree.nodes[0].nodes[0];
- t.deepEqual(class1.value, 'icon');
- t.deepEqual(class1.type, 'class');
- var class2 = tree.nodes[0].nodes[1];
- t.deepEqual(class2.value, 'is-$(network)');
- t.deepEqual(class2.type, 'class');
-});
-(0, _helpers.test)('at word in selector', 'em@il.com', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'em@il');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'com');
-});
-(0, _helpers.test)('leading combinator', '> *', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '>');
- t.deepEqual(tree.nodes[0].nodes[1].value, '*');
-});
-(0, _helpers.test)('sass escapes', '.#{$classname}', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes.map(function (n) {
- return n.type;
- }), ["class"]);
- t.deepEqual(tree.nodes[0].nodes[0].value, "#{$classname}");
-});
-(0, _helpers.test)('sass escapes (2)', '[lang=#{$locale}]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes.map(function (n) {
- return n.type;
- }), ["attribute"]);
- t.deepEqual(tree.nodes[0].nodes[0].value, "#{$locale}");
-});
-(0, _helpers.test)('placeholder', '%foo', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes.map(function (n) {
- return n.type;
- }), ["tag"]);
- t.deepEqual(tree.nodes[0].nodes[0].value, "%foo");
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/parser.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/parser.js
deleted file mode 100644
index 2154036..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/parser.js
+++ /dev/null
@@ -1,259 +0,0 @@
-"use strict";
-
-var _ava = _interopRequireDefault(require("ava"));
-
-var _index = _interopRequireDefault(require("../index"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-// Node creation
-var nodeTypes = [['attribute', '[href]', {
- attribute: 'href'
-}], ['className', '.classy', {
- value: 'classy'
-}], ['combinator', ' >> ', {
- value: '>>',
- spaces: {
- before: ' ',
- after: ' '
- }
-}], ['comment', '/* comment */', {
- value: '/* comment */'
-}], ['id', '#test', {
- value: 'test'
-}], ['nesting', '&'], ['pseudo', '::before', {
- value: '::before'
-}], ['string', '"wow"', {
- value: '"wow"'
-}], ['tag', 'button', {
- value: 'button'
-}], ['universal', '*']];
-nodeTypes.forEach(function (type) {
- (0, _ava.default)("parser#" + type[0], function (t) {
- var node = _index.default[type[0]](type[2] || {});
-
- t.deepEqual(String(node), type[1]);
- });
-});
-(0, _ava.default)('string constants', function (t) {
- t.truthy(_index.default.TAG);
- t.truthy(_index.default.STRING);
- t.truthy(_index.default.SELECTOR);
- t.truthy(_index.default.ROOT);
- t.truthy(_index.default.PSEUDO);
- t.truthy(_index.default.NESTING);
- t.truthy(_index.default.ID);
- t.truthy(_index.default.COMMENT);
- t.truthy(_index.default.COMBINATOR);
- t.truthy(_index.default.CLASS);
- t.truthy(_index.default.ATTRIBUTE);
- t.truthy(_index.default.UNIVERSAL);
-});
-(0, _ava.default)('construct a whole tree', function (t) {
- var root = _index.default.root();
-
- var selector = _index.default.selector();
-
- selector.append(_index.default.id({
- value: 'tree'
- }));
- root.append(selector);
- t.deepEqual(String(root), '#tree');
-});
-(0, _ava.default)('no operation', function (t) {
- t.notThrows(function () {
- return (0, _index.default)().processSync('h1 h2 h3');
- });
-});
-(0, _ava.default)('empty selector string', function (t) {
- t.notThrows(function () {
- return (0, _index.default)(function (selectors) {
- selectors.walk(function (selector) {
- selector.type = 'tag';
- });
- }).processSync('');
- });
-});
-(0, _ava.default)('async parser', function (t) {
- return (0, _index.default)(function (selectors) {
- return new Promise(function (res) {
- setTimeout(function () {
- selectors.first.nodes[0].value = 'bar';
- res();
- }, 1);
- });
- }).process('foo').then(function (result) {
- t.deepEqual(result, 'bar');
- });
-});
-(0, _ava.default)('parse errors with the async parser', function (t) {
- return (0, _index.default)(function (selectors) {
- return new Promise(function (res) {
- setTimeout(function () {
- selectors.first.nodes[0].value = 'bar';
- res();
- }, 1);
- });
- }).process('a b: c').catch(function (err) {
- return t.truthy(err);
- });
-});
-(0, _ava.default)('parse errors within the async processor', function (t) {
- return (0, _index.default)(function (selectors) {
- return new Promise(function (res, rej) {
- setTimeout(function () {
- rej(selectors.error("async error"));
- }, 1);
- });
- }).process('.foo').catch(function (err) {
- return t.truthy(err);
- });
-});
-(0, _ava.default)('parse errors within the async processor before the promise returns', function (t) {
- return (0, _index.default)(function (selectors) {
- throw selectors.error("async error");
- }).process('.foo').catch(function (err) {
- return t.truthy(err);
- });
-});
-(0, _ava.default)('returning a promise to the sync processor fails', function (t) {
- t.throws(function () {
- return (0, _index.default)(function () {
- return new Promise(function (res) {
- setTimeout(function () {
- res();
- }, 1);
- });
- }).processSync('.foo');
- });
-});
-(0, _ava.default)('Passing a rule works async', function (t) {
- var rule = {
- selector: '.foo'
- };
- return (0, _index.default)(function (root) {
- return new Promise(function (res) {
- setTimeout(function () {
- root.walkClasses(function (node) {
- node.value = "bar";
- });
- res();
- }, 1);
- });
- }).process(rule).then(function (newSel) {
- t.deepEqual(newSel, ".bar");
- t.deepEqual(rule.selector, ".bar");
- });
-});
-(0, _ava.default)('Passing a rule with mutation disabled works async', function (t) {
- var rule = {
- selector: '.foo'
- };
- return (0, _index.default)(function (root) {
- return new Promise(function (res) {
- setTimeout(function () {
- root.walkClasses(function (node) {
- node.value = "bar";
- });
- res();
- }, 1);
- });
- }).process(rule, {
- updateSelector: false
- }).then(function (newSel) {
- t.deepEqual(newSel, ".bar");
- t.deepEqual(rule.selector, ".foo");
- });
-});
-(0, _ava.default)('Passing a rule with mutation works sync', function (t) {
- var rule = {
- selector: '.foo'
- };
- var newSel = (0, _index.default)(function (root) {
- root.walkClasses(function (node) {
- node.value = "bar";
- });
- }).processSync(rule, {
- updateSelector: true
- });
- t.deepEqual(newSel, ".bar");
- t.deepEqual(rule.selector, ".bar");
-});
-(0, _ava.default)('Transform a selector synchronously', function (t) {
- var rule = {
- selector: '.foo'
- };
- var count = (0, _index.default)(function (root) {
- var classCount = 0;
- root.walkClasses(function (node) {
- classCount++;
- node.value = "bar";
- });
- return classCount;
- }).transformSync(rule, {
- updateSelector: true
- });
- t.deepEqual(count, 1);
- t.deepEqual(rule.selector, ".bar");
-});
-(0, _ava.default)('Transform a selector asynchronously', function (t) {
- var rule = {
- selector: '.foo'
- };
- return (0, _index.default)(function (root) {
- return new Promise(function (res) {
- setTimeout(function () {
- var classCount = 0;
- root.walkClasses(function (node) {
- classCount++;
- node.value = "bar";
- });
- res(classCount);
- }, 1);
- });
- }).transform(rule, {
- updateSelector: true
- }).then(function (count) {
- t.deepEqual(count, 1);
- t.deepEqual(rule.selector, ".bar");
- });
-});
-(0, _ava.default)('get AST of a selector synchronously', function (t) {
- var rule = {
- selector: '.foo'
- };
- var ast = (0, _index.default)(function (root) {
- var classCount = 0;
- root.walkClasses(function (node) {
- classCount++;
- node.value = "bar";
- });
- return classCount;
- }).astSync(rule, {
- updateSelector: true
- });
- t.deepEqual(ast.nodes[0].nodes[0].value, "bar");
- t.deepEqual(rule.selector, ".bar");
-});
-(0, _ava.default)('get AST a selector asynchronously', function (t) {
- var rule = {
- selector: '.foo'
- };
- return (0, _index.default)(function (root) {
- return new Promise(function (res) {
- setTimeout(function () {
- var classCount = 0;
- root.walkClasses(function (node) {
- classCount++;
- node.value = "bar";
- });
- res(classCount);
- }, 1);
- });
- }).ast(rule, {
- updateSelector: true
- }).then(function (ast) {
- t.deepEqual(ast.nodes[0].nodes[0].value, "bar");
- t.deepEqual(rule.selector, ".bar");
- });
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/postcss.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/postcss.js
deleted file mode 100644
index d7175f7..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/postcss.js
+++ /dev/null
@@ -1,46 +0,0 @@
-"use strict";
-
-var _ava = _interopRequireDefault(require("ava"));
-
-var _postcss = _interopRequireDefault(require("postcss"));
-
-var _helpers = require("./util/helpers");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-var cse = 'CssSyntaxError';
-
-function showCode(t, selector) {
- var rule = _postcss.default.parse(selector).first;
-
- try {
- (0, _helpers.parse)(rule);
- } catch (e) {
- if (e.name !== cse) {
- return;
- } // Removes ANSI codes from snapshot tests as it makes them illegible.
- // The formatting of this error is otherwise identical to e.toString()
-
-
- t.snapshot(cse + ": " + e.message + "\n\n" + e.showSourceCode(false) + "\n");
- }
-}
-
-(0, _ava.default)('missing open square bracket', showCode, 'a b c] {}');
-(0, _ava.default)('missing open parenthesis', showCode, 'a b c) {}');
-(0, _ava.default)('missing pseudo class or pseudo element', showCode, 'a b c: {}');
-(0, _ava.default)('space in between colon and word (incorrect pseudo)', showCode, 'a b: c {}');
-(0, _ava.default)('string after colon (incorrect pseudo)', showCode, 'a b:"wow" {}'); // attribute selectors
-
-(0, _ava.default)('bad string attribute', showCode, '["hello"] {}');
-(0, _ava.default)('bad string attribute with value', showCode, '["foo"=bar] {}');
-(0, _ava.default)('bad parentheses', showCode, '[foo=(bar)] {}');
-(0, _ava.default)('bad lonely asterisk', showCode, '[*] {}');
-(0, _ava.default)('bad lonely pipe', showCode, '[|] {}');
-(0, _ava.default)('bad lonely caret', showCode, '[^] {}');
-(0, _ava.default)('bad lonely dollar', showCode, '[$] {}');
-(0, _ava.default)('bad lonely tilde', showCode, '[~] {}');
-(0, _ava.default)('bad lonely equals', showCode, '[=] {}');
-(0, _ava.default)('bad lonely operator', showCode, '[*=] {}');
-(0, _ava.default)('bad lonely operator (2)', showCode, '[|=] {}');
-(0, _ava.default)('bad doubled operator', showCode, '[href=foo=bar] {}'); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/pseudos.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/pseudos.js
deleted file mode 100644
index d316a0c..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/pseudos.js
+++ /dev/null
@@ -1,98 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('pseudo element (single colon)', 'h1:after', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'tag');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'pseudo');
- t.deepEqual(tree.nodes[0].nodes[1].value, ':after');
-});
-(0, _helpers.test)('pseudo element (double colon)', 'h1::after', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'tag');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'pseudo');
- t.deepEqual(tree.nodes[0].nodes[1].value, '::after');
-});
-(0, _helpers.test)('multiple pseudo elements', '*:target::before, a:after', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '*');
- t.deepEqual(tree.nodes[0].nodes[1].value, ':target');
- t.deepEqual(tree.nodes[0].nodes[2].value, '::before');
- t.deepEqual(tree.nodes[1].nodes[1].value, ':after');
-});
-(0, _helpers.test)('negation pseudo element', 'h1:not(.heading)', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].value, ':not');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].value, 'heading');
-});
-(0, _helpers.test)('negation pseudo element (2)', 'h1:not(.heading, .title, .content)', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].value, ':not');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].value, 'heading');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[1].nodes[0].value, 'title');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[2].nodes[0].value, 'content');
-});
-(0, _helpers.test)('negation pseudo element (3)', 'h1:not(.heading > .title) > h1', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].value, 'heading');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[1].value, '>');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[2].value, 'title');
- t.deepEqual(tree.nodes[0].nodes[2].value, '>');
- t.deepEqual(tree.nodes[0].nodes[3].value, 'h1');
-});
-(0, _helpers.test)('negation pseudo element (4)', 'h1:not(h2:not(h3))', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[1].nodes[0].nodes[0].value, 'h3');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[1].nodes[0].nodes[0].parent.type, 'selector');
-});
-(0, _helpers.test)('pseudo class in the middle of a selector', 'a:link.external', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'tag');
- t.deepEqual(tree.nodes[0].nodes[0].value, 'a');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'pseudo');
- t.deepEqual(tree.nodes[0].nodes[1].value, ':link');
- t.deepEqual(tree.nodes[0].nodes[2].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[2].value, 'external');
-});
-(0, _helpers.test)('extra whitespace inside parentheses', 'a:not( h2 )', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].value, 'h2');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].spaces.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].spaces.before, ' ');
-});
-(0, _helpers.test)('escaped numbers in class name with pseudo', 'a:before.\\31\\ 0', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[2].type, 'class');
- t.deepEqual(tree.nodes[0].nodes[2].value, '1 0');
- t.deepEqual(tree.nodes[0].nodes[2].raws.value, '\\31\\ 0');
-});
-(0, _helpers.test)('nested pseudo', '.btn-group>.btn:last-child:not(:first-child)', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[4].value, ':not');
-});
-(0, _helpers.test)('extraneous non-combinating whitespace', ' h1:after , h2:after ', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[1].value, ':after');
- t.deepEqual(tree.nodes[0].nodes[1].spaces.after, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[1].nodes[1].value, ':after');
- t.deepEqual(tree.nodes[1].nodes[1].spaces.after, ' ');
-});
-(0, _helpers.test)('negation pseudo element with quotes', 'h1:not(".heading")', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].value, ':not');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].value, '".heading"');
-});
-(0, _helpers.test)('negation pseudo element with single quotes', "h1:not('.heading')", function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].value, ':not');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].value, "'.heading'");
-});
-(0, _helpers.test)('Issue #116', "svg:not(:root)", function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].value, ':not');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].value, ':root');
-});
-(0, _helpers.test)('alone pseudo class', ':root', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'pseudo');
- t.deepEqual(tree.nodes[0].nodes[0].value, ':root');
-});
-(0, _helpers.test)('non standard pseudo (@custom-selector)', ":--foobar, a", function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, ':--foobar');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'pseudo');
- t.deepEqual(tree.nodes[1].nodes[0].value, 'a');
- t.deepEqual(tree.nodes[1].nodes[0].type, 'tag');
-});
-(0, _helpers.test)('non standard pseudo (@custom-selector) (1)', "a, :--foobar", function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'a');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'tag');
- t.deepEqual(tree.nodes[1].nodes[0].value, ':--foobar');
- t.deepEqual(tree.nodes[1].nodes[0].type, 'pseudo');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/sourceIndex.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/sourceIndex.js
deleted file mode 100644
index 766d59f..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/sourceIndex.js
+++ /dev/null
@@ -1,229 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('universal selector', '*', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0);
-});
-(0, _helpers.test)('lobotomized owl selector', ' * + * ', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 2);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 2);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 1);
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 4);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 4);
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 3);
- t.deepEqual(tree.nodes[0].nodes[2].source.start.column, 6);
- t.deepEqual(tree.nodes[0].nodes[2].source.end.column, 6);
- t.deepEqual(tree.nodes[0].nodes[2].sourceIndex, 5);
-});
-(0, _helpers.test)('comment', '/**\n * Hello!\n */', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 3);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0);
-});
-(0, _helpers.test)('comment & universal selectors', '*/*test*/*', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0);
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 2);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 9);
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 1);
- t.deepEqual(tree.nodes[0].nodes[2].source.start.column, 10);
- t.deepEqual(tree.nodes[0].nodes[2].source.end.column, 10);
- t.deepEqual(tree.nodes[0].nodes[2].sourceIndex, 9);
-});
-(0, _helpers.test)('tag selector', 'h1', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 2);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0);
-});
-(0, _helpers.test)('id selector', '#id', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 3);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0);
-});
-(0, _helpers.test)('tag selector followed by id selector', 'h1, #id', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 2);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0);
- t.deepEqual(tree.nodes[1].nodes[0].source.start.column, 5);
- t.deepEqual(tree.nodes[1].nodes[0].source.end.column, 7);
- t.deepEqual(tree.nodes[1].nodes[0].sourceIndex, 4);
-});
-(0, _helpers.test)('multiple id selectors', '#one#two', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 4);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0);
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 5);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 8);
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 4);
-});
-(0, _helpers.test)('multiple id selectors (2)', '#one#two#three#four', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[2].source.start.column, 9);
- t.deepEqual(tree.nodes[0].nodes[2].source.end.column, 14);
- t.deepEqual(tree.nodes[0].nodes[2].sourceIndex, 8);
- t.deepEqual(tree.nodes[0].nodes[3].source.start.column, 15);
- t.deepEqual(tree.nodes[0].nodes[3].source.end.column, 19);
- t.deepEqual(tree.nodes[0].nodes[3].sourceIndex, 14);
-});
-(0, _helpers.test)('multiple id selectors (3)', '#one#two,#three#four', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 5);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 8);
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 4);
- t.deepEqual(tree.nodes[1].nodes[1].source.start.column, 16);
- t.deepEqual(tree.nodes[1].nodes[1].source.end.column, 20);
- t.deepEqual(tree.nodes[1].nodes[1].sourceIndex, 15);
-});
-(0, _helpers.test)('multiple class selectors', '.one.two,.three.four', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 5);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 8);
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 4);
- t.deepEqual(tree.nodes[1].nodes[1].source.start.column, 16);
- t.deepEqual(tree.nodes[1].nodes[1].source.end.column, 20);
- t.deepEqual(tree.nodes[1].nodes[1].sourceIndex, 15);
-});
-(0, _helpers.test)('attribute selector', '[name="james"]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.line, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 14);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0);
-});
-(0, _helpers.test)('multiple attribute selectors', '[name="james"][name="ed"],[name="snakeman"][name="a"]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.line, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.line, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 14);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0);
- t.deepEqual(tree.nodes[0].nodes[1].source.start.line, 1);
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 15);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.line, 1);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 25);
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 14);
- t.deepEqual(tree.nodes[1].nodes[0].source.start.line, 1);
- t.deepEqual(tree.nodes[1].nodes[0].source.start.column, 27);
- t.deepEqual(tree.nodes[1].nodes[0].source.end.line, 1);
- t.deepEqual(tree.nodes[1].nodes[0].source.end.column, 43);
- t.deepEqual(tree.nodes[1].nodes[0].sourceIndex, 26);
- t.deepEqual(tree.nodes[1].nodes[1].source.start.line, 1);
- t.deepEqual(tree.nodes[1].nodes[1].source.start.column, 44);
- t.deepEqual(tree.nodes[1].nodes[1].source.end.line, 1);
- t.deepEqual(tree.nodes[1].nodes[1].source.end.column, 53);
- t.deepEqual(tree.nodes[1].nodes[1].sourceIndex, 43);
-});
-(0, _helpers.test)('pseudo-class', 'h1:first-child', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].source.start.line, 1);
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 3);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 14);
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 2);
-});
-(0, _helpers.test)('pseudo-class with argument', 'h1:not(.strudel, .food)', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].source.start.line, 1);
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 3);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 23);
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 2);
-});
-(0, _helpers.test)('pseudo-element', 'h1::before', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].source.start.line, 1);
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 3);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 10);
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 2);
-});
-(0, _helpers.test)('multiple pseudos', 'h1:not(.food)::before, a:first-child', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].source.start.line, 1);
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 3);
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 13);
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 2);
- t.deepEqual(tree.nodes[0].nodes[2].source.start.line, 1);
- t.deepEqual(tree.nodes[0].nodes[2].source.start.column, 14);
- t.deepEqual(tree.nodes[0].nodes[2].source.end.column, 21);
- t.deepEqual(tree.nodes[0].nodes[2].sourceIndex, 13);
- t.deepEqual(tree.nodes[1].nodes[1].source.start.line, 1);
- t.deepEqual(tree.nodes[1].nodes[1].source.start.column, 25);
- t.deepEqual(tree.nodes[1].nodes[1].source.end.column, 36);
- t.deepEqual(tree.nodes[1].nodes[1].sourceIndex, 24);
-});
-(0, _helpers.test)('combinators', 'div > h1 span', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].source.start.line, 1, "> start line");
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 5, "> start column");
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 5, "> end column");
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 4, "> sourceIndex");
- t.deepEqual(tree.nodes[0].nodes[3].source.start.line, 1, "' ' start line");
- t.deepEqual(tree.nodes[0].nodes[3].source.start.column, 9, "' ' start column");
- t.deepEqual(tree.nodes[0].nodes[3].source.end.column, 9, "' ' end column");
- t.deepEqual(tree.nodes[0].nodes[3].sourceIndex, 8, "' ' sourceIndex");
-});
-(0, _helpers.test)('combinators surrounded by superfluous spaces', 'div > h1 ~ span a', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].source.start.line, 1, "> start line");
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 7, "> start column");
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 7, "> end column");
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 6, "> sourceIndex");
- t.deepEqual(tree.nodes[0].nodes[3].source.start.line, 1, "~ start line");
- t.deepEqual(tree.nodes[0].nodes[3].source.start.column, 13, "~ start column");
- t.deepEqual(tree.nodes[0].nodes[3].source.end.column, 13, "~ end column");
- t.deepEqual(tree.nodes[0].nodes[3].sourceIndex, 12, "~ sourceIndex");
- t.deepEqual(tree.nodes[0].nodes[5].source.start.line, 1, "' ' start line");
- t.deepEqual(tree.nodes[0].nodes[5].source.start.column, 21, "' ' start column");
- t.deepEqual(tree.nodes[0].nodes[5].source.end.column, 23, "' ' end column");
- t.deepEqual(tree.nodes[0].nodes[5].sourceIndex, 20, "' ' sourceIndex");
-});
-(0, _helpers.test)('multiple id selectors on different lines', '#one,\n#two', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.line, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 4);
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0);
- t.deepEqual(tree.nodes[1].nodes[0].source.start.line, 2);
- t.deepEqual(tree.nodes[1].nodes[0].source.start.column, 1);
- t.deepEqual(tree.nodes[1].nodes[0].source.end.column, 4);
- t.deepEqual(tree.nodes[1].nodes[0].sourceIndex, 6);
-});
-(0, _helpers.test)('multiple id selectors on different CRLF lines', '#one,\r\n#two,\r\n#three', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.line, 1, '#one start line');
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 1, '#one start column');
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 4, '#one end column');
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 0, '#one sourceIndex');
- t.deepEqual(tree.nodes[1].nodes[0].source.start.line, 2, '#two start line');
- t.deepEqual(tree.nodes[1].nodes[0].source.start.column, 1, '#two start column');
- t.deepEqual(tree.nodes[1].nodes[0].source.end.column, 4, '#two end column');
- t.deepEqual(tree.nodes[1].nodes[0].sourceIndex, 7, '#two sourceIndex');
- t.deepEqual(tree.nodes[2].nodes[0].source.start.line, 3, '#three start line');
- t.deepEqual(tree.nodes[2].nodes[0].source.start.column, 1, '#three start column');
- t.deepEqual(tree.nodes[2].nodes[0].source.end.column, 6, '#three end column');
- t.deepEqual(tree.nodes[2].nodes[0].sourceIndex, 14, '#three sourceIndex');
-});
-(0, _helpers.test)('id, tag, pseudo, and class selectors on different lines with indentation', '\t#one,\n\th1:after,\n\t\t.two', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].source.start.line, 1, '#one start line');
- t.deepEqual(tree.nodes[0].nodes[0].source.start.column, 2, '#one start column');
- t.deepEqual(tree.nodes[0].nodes[0].source.end.column, 5, '#one end column');
- t.deepEqual(tree.nodes[0].nodes[0].sourceIndex, 1, '#one sourceIndex');
- t.deepEqual(tree.nodes[1].nodes[0].source.start.line, 2, 'h1 start line');
- t.deepEqual(tree.nodes[1].nodes[0].source.start.column, 2, 'h1 start column');
- t.deepEqual(tree.nodes[1].nodes[0].source.end.column, 3, 'h1 end column');
- t.deepEqual(tree.nodes[1].nodes[0].sourceIndex, 8, 'h1 sourceIndex');
- t.deepEqual(tree.nodes[1].nodes[1].source.start.line, 2, ':after start line');
- t.deepEqual(tree.nodes[1].nodes[1].source.start.column, 4, ':after start column');
- t.deepEqual(tree.nodes[1].nodes[1].source.end.column, 9, ':after end column');
- t.deepEqual(tree.nodes[1].nodes[1].sourceIndex, 10, ':after sourceIndex');
- t.deepEqual(tree.nodes[2].nodes[0].source.start.line, 3, '.two start line');
- t.deepEqual(tree.nodes[2].nodes[0].source.start.column, 3, '.two start column');
- t.deepEqual(tree.nodes[2].nodes[0].source.end.column, 6, '.two end column');
- t.deepEqual(tree.nodes[2].nodes[0].sourceIndex, 20, '.two sourceIndex');
-});
-(0, _helpers.test)('pseudo with arguments spanning multiple lines', 'h1:not(\n\t.one,\n\t.two\n)', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[1].source.start.line, 1, ':not start line');
- t.deepEqual(tree.nodes[0].nodes[1].source.start.column, 3, ':not start column');
- t.deepEqual(tree.nodes[0].nodes[1].source.end.line, 4, ':not end line');
- t.deepEqual(tree.nodes[0].nodes[1].source.end.column, 1, ':not end column');
- t.deepEqual(tree.nodes[0].nodes[1].sourceIndex, 2, ':not sourceIndex');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].source.start.line, 2, '.one start line');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].source.start.column, 2, '.one start column');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].source.end.line, 2, '.one end line');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].source.end.column, 5, '.one end column');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[0].nodes[0].sourceIndex, 9, '.one sourceIndex');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[1].nodes[0].source.start.line, 3, '.two start line');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[1].nodes[0].source.start.column, 2, '.two start column');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[1].nodes[0].source.end.line, 3, '.two end line');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[1].nodes[0].source.end.column, 5, '.two end column');
- t.deepEqual(tree.nodes[0].nodes[1].nodes[1].nodes[0].sourceIndex, 16, '.two sourceIndex');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/stripComments.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/stripComments.js
deleted file mode 100644
index 2d6eb9a..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/stripComments.js
+++ /dev/null
@@ -1,17 +0,0 @@
-"use strict";
-
-var _ava = _interopRequireDefault(require("ava"));
-
-var _stripComments = _interopRequireDefault(require("../../src/util/stripComments"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-(0, _ava.default)("stripComments()", function (t) {
- t.deepEqual((0, _stripComments.default)("aaa/**/bbb"), "aaabbb");
- t.deepEqual((0, _stripComments.default)("aaa/*bbb"), "aaa");
- t.deepEqual((0, _stripComments.default)("aaa/*xxx*/bbb"), "aaabbb");
- t.deepEqual((0, _stripComments.default)("aaa/*/xxx/*/bbb"), "aaabbb");
- t.deepEqual((0, _stripComments.default)("aaa/*x*/bbb/**/"), "aaabbb");
- t.deepEqual((0, _stripComments.default)("/**/aaa/*x*/bbb/**/"), "aaabbb");
- t.deepEqual((0, _stripComments.default)("/**/"), "");
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/tags.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/tags.js
deleted file mode 100644
index b6f5aa4..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/tags.js
+++ /dev/null
@@ -1,35 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('tag selector', 'h1', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'tag');
-});
-(0, _helpers.test)('multiple tag selectors', 'h1, h2', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[1].nodes[0].value, 'h2');
-});
-(0, _helpers.test)('extraneous non-combinating whitespace', ' h1 , h2 ', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.after, ' ');
- t.deepEqual(tree.nodes[1].nodes[0].value, 'h2');
- t.deepEqual(tree.nodes[1].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[1].nodes[0].spaces.after, ' ');
-});
-(0, _helpers.test)('tag with trailing comma', 'h1,', function (t, tree) {
- t.deepEqual(tree.trailingComma, true);
-});
-(0, _helpers.test)('tag with trailing slash', 'h1\\', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'h1\\');
-});
-(0, _helpers.test)('tag with attribute', 'label[for="email"]', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, 'label');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'tag');
- t.deepEqual(tree.nodes[0].nodes[1].value, 'email');
- t.deepEqual(tree.nodes[0].nodes[1].attribute, 'for');
- t.deepEqual(tree.nodes[0].nodes[1].operator, '=');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'attribute');
- t.deepEqual(tree.nodes[0].nodes[1].quoteMark, '"');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/universal.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/universal.js
deleted file mode 100644
index 019c003..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/universal.js
+++ /dev/null
@@ -1,32 +0,0 @@
-"use strict";
-
-var _helpers = require("./util/helpers");
-
-(0, _helpers.test)('universal selector', '*', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '*');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'universal');
-});
-(0, _helpers.test)('lobotomized owl', '* + *', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].type, 'universal');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'combinator');
- t.deepEqual(tree.nodes[0].nodes[2].type, 'universal');
-});
-(0, _helpers.test)('extraneous non-combinating whitespace', ' * , * ', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '*');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[0].nodes[0].spaces.after, ' ');
- t.deepEqual(tree.nodes[1].nodes[0].value, '*');
- t.deepEqual(tree.nodes[1].nodes[0].spaces.before, ' ');
- t.deepEqual(tree.nodes[1].nodes[0].spaces.after, ' ');
-});
-(0, _helpers.test)('qualified universal selector', '*[href] *:not(*.green)', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '*');
- t.deepEqual(tree.nodes[0].nodes[3].value, '*');
- t.deepEqual(tree.nodes[0].nodes[4].nodes[0].nodes[0].value, '*');
-});
-(0, _helpers.test)('universal selector with pseudo', '*::--webkit-media-controls-play-button', function (t, tree) {
- t.deepEqual(tree.nodes[0].nodes[0].value, '*');
- t.deepEqual(tree.nodes[0].nodes[0].type, 'universal');
- t.deepEqual(tree.nodes[0].nodes[1].value, '::--webkit-media-controls-play-button');
- t.deepEqual(tree.nodes[0].nodes[1].type, 'pseudo');
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/util/helpers.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/util/helpers.js
deleted file mode 100644
index 3bf9c0d..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/__tests__/util/helpers.js
+++ /dev/null
@@ -1,90 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.test = test;
-exports.nodeVersionAtLeast = nodeVersionAtLeast;
-exports.nodeVersionBefore = nodeVersionBefore;
-exports.throws = exports.parse = void 0;
-
-var _process = _interopRequireDefault(require("process"));
-
-var _util = _interopRequireDefault(require("util"));
-
-var _ava = _interopRequireDefault(require("ava"));
-
-var _semver = _interopRequireDefault(require("semver"));
-
-var _index = _interopRequireDefault(require("../../index"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-var parse = function parse(input, transform) {
- return (0, _index.default)(transform).processSync(input);
-};
-
-exports.parse = parse;
-
-function test(spec, input, callback, only, disabled, serial) {
- var _this = this;
-
- if (only === void 0) {
- only = false;
- }
-
- if (disabled === void 0) {
- disabled = false;
- }
-
- if (serial === void 0) {
- serial = false;
- }
-
- var tester = only ? _ava.default.only : _ava.default;
- tester = disabled ? tester.skip : tester;
- tester = serial ? tester.serial : tester;
-
- if (callback) {
- tester(spec + " (tree)", function (t) {
- var tree = (0, _index.default)().astSync(input);
-
- var debug = _util.default.inspect(tree, false, null);
-
- return callback.call(_this, t, tree, debug);
- });
- }
-
- tester(spec + " (toString)", function (t) {
- var result = (0, _index.default)().processSync(input);
- t.deepEqual(result, input);
- });
-}
-
-test.only = function (spec, input, callback) {
- return test(spec, input, callback, true);
-};
-
-test.skip = function (spec, input, callback) {
- return test(spec, input, callback, false, true);
-};
-
-test.serial = function (spec, input, callback) {
- return test(spec, input, callback, false, false, true);
-};
-
-var throws = function throws(spec, input, validator) {
- (0, _ava.default)(spec + " (throws)", function (t) {
- t.throws(function () {
- return (0, _index.default)().processSync(input);
- }, validator || Error);
- });
-};
-
-exports.throws = throws;
-
-function nodeVersionAtLeast(version) {
- return _semver.default.gte(_process.default.versions.node, version);
-}
-
-function nodeVersionBefore(version) {
- return _semver.default.lt(_process.default.versions.node, version);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/index.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/index.js
deleted file mode 100644
index ac33ec0..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/index.js
+++ /dev/null
@@ -1,22 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _processor = _interopRequireDefault(require("./processor"));
-
-var selectors = _interopRequireWildcard(require("./selectors"));
-
-function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-var parser = function parser(processor) {
- return new _processor.default(processor);
-};
-
-Object.assign(parser, selectors);
-delete parser.__esModule;
-var _default = parser;
-exports.default = _default;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/parser.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/parser.js
deleted file mode 100644
index 927d18a..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/parser.js
+++ /dev/null
@@ -1,1223 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _indexesOf = _interopRequireDefault(require("indexes-of"));
-
-var _uniq = _interopRequireDefault(require("uniq"));
-
-var _root = _interopRequireDefault(require("./selectors/root"));
-
-var _selector = _interopRequireDefault(require("./selectors/selector"));
-
-var _className = _interopRequireDefault(require("./selectors/className"));
-
-var _comment = _interopRequireDefault(require("./selectors/comment"));
-
-var _id = _interopRequireDefault(require("./selectors/id"));
-
-var _tag = _interopRequireDefault(require("./selectors/tag"));
-
-var _string = _interopRequireDefault(require("./selectors/string"));
-
-var _pseudo = _interopRequireDefault(require("./selectors/pseudo"));
-
-var _attribute = _interopRequireWildcard(require("./selectors/attribute"));
-
-var _universal = _interopRequireDefault(require("./selectors/universal"));
-
-var _combinator = _interopRequireDefault(require("./selectors/combinator"));
-
-var _nesting = _interopRequireDefault(require("./selectors/nesting"));
-
-var _sortAscending = _interopRequireDefault(require("./sortAscending"));
-
-var _tokenize = _interopRequireWildcard(require("./tokenize"));
-
-var tokens = _interopRequireWildcard(require("./tokenTypes"));
-
-var types = _interopRequireWildcard(require("./selectors/types"));
-
-var _util = require("./util");
-
-var _WHITESPACE_TOKENS, _Object$assign;
-
-function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
-
-function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
-
-var WHITESPACE_TOKENS = (_WHITESPACE_TOKENS = {}, _WHITESPACE_TOKENS[tokens.space] = true, _WHITESPACE_TOKENS[tokens.cr] = true, _WHITESPACE_TOKENS[tokens.feed] = true, _WHITESPACE_TOKENS[tokens.newline] = true, _WHITESPACE_TOKENS[tokens.tab] = true, _WHITESPACE_TOKENS);
-var WHITESPACE_EQUIV_TOKENS = Object.assign({}, WHITESPACE_TOKENS, (_Object$assign = {}, _Object$assign[tokens.comment] = true, _Object$assign));
-
-function tokenStart(token) {
- return {
- line: token[_tokenize.FIELDS.START_LINE],
- column: token[_tokenize.FIELDS.START_COL]
- };
-}
-
-function tokenEnd(token) {
- return {
- line: token[_tokenize.FIELDS.END_LINE],
- column: token[_tokenize.FIELDS.END_COL]
- };
-}
-
-function getSource(startLine, startColumn, endLine, endColumn) {
- return {
- start: {
- line: startLine,
- column: startColumn
- },
- end: {
- line: endLine,
- column: endColumn
- }
- };
-}
-
-function getTokenSource(token) {
- return getSource(token[_tokenize.FIELDS.START_LINE], token[_tokenize.FIELDS.START_COL], token[_tokenize.FIELDS.END_LINE], token[_tokenize.FIELDS.END_COL]);
-}
-
-function getTokenSourceSpan(startToken, endToken) {
- if (!startToken) {
- return undefined;
- }
-
- return getSource(startToken[_tokenize.FIELDS.START_LINE], startToken[_tokenize.FIELDS.START_COL], endToken[_tokenize.FIELDS.END_LINE], endToken[_tokenize.FIELDS.END_COL]);
-}
-
-function unescapeProp(node, prop) {
- var value = node[prop];
-
- if (typeof value !== "string") {
- return;
- }
-
- if (value.indexOf("\\") !== -1) {
- (0, _util.ensureObject)(node, 'raws');
- node[prop] = (0, _util.unesc)(value);
-
- if (node.raws[prop] === undefined) {
- node.raws[prop] = value;
- }
- }
-
- return node;
-}
-
-var Parser =
-/*#__PURE__*/
-function () {
- function Parser(rule, options) {
- if (options === void 0) {
- options = {};
- }
-
- this.rule = rule;
- this.options = Object.assign({
- lossy: false,
- safe: false
- }, options);
- this.position = 0;
- this.css = typeof this.rule === 'string' ? this.rule : this.rule.selector;
- this.tokens = (0, _tokenize.default)({
- css: this.css,
- error: this._errorGenerator(),
- safe: this.options.safe
- });
- var rootSource = getTokenSourceSpan(this.tokens[0], this.tokens[this.tokens.length - 1]);
- this.root = new _root.default({
- source: rootSource
- });
- this.root.errorGenerator = this._errorGenerator();
- var selector = new _selector.default({
- source: {
- start: {
- line: 1,
- column: 1
- }
- }
- });
- this.root.append(selector);
- this.current = selector;
- this.loop();
- }
-
- var _proto = Parser.prototype;
-
- _proto._errorGenerator = function _errorGenerator() {
- var _this = this;
-
- return function (message, errorOptions) {
- if (typeof _this.rule === 'string') {
- return new Error(message);
- }
-
- return _this.rule.error(message, errorOptions);
- };
- };
-
- _proto.attribute = function attribute() {
- var attr = [];
- var startingToken = this.currToken;
- this.position++;
-
- while (this.position < this.tokens.length && this.currToken[_tokenize.FIELDS.TYPE] !== tokens.closeSquare) {
- attr.push(this.currToken);
- this.position++;
- }
-
- if (this.currToken[_tokenize.FIELDS.TYPE] !== tokens.closeSquare) {
- return this.expected('closing square bracket', this.currToken[_tokenize.FIELDS.START_POS]);
- }
-
- var len = attr.length;
- var node = {
- source: getSource(startingToken[1], startingToken[2], this.currToken[3], this.currToken[4]),
- sourceIndex: startingToken[_tokenize.FIELDS.START_POS]
- };
-
- if (len === 1 && !~[tokens.word].indexOf(attr[0][_tokenize.FIELDS.TYPE])) {
- return this.expected('attribute', attr[0][_tokenize.FIELDS.START_POS]);
- }
-
- var pos = 0;
- var spaceBefore = '';
- var commentBefore = '';
- var lastAdded = null;
- var spaceAfterMeaningfulToken = false;
-
- while (pos < len) {
- var token = attr[pos];
- var content = this.content(token);
- var next = attr[pos + 1];
-
- switch (token[_tokenize.FIELDS.TYPE]) {
- case tokens.space:
- // if (
- // len === 1 ||
- // pos === 0 && this.content(next) === '|'
- // ) {
- // return this.expected('attribute', token[TOKEN.START_POS], content);
- // }
- spaceAfterMeaningfulToken = true;
-
- if (this.options.lossy) {
- break;
- }
-
- if (lastAdded) {
- (0, _util.ensureObject)(node, 'spaces', lastAdded);
- var prevContent = node.spaces[lastAdded].after || '';
- node.spaces[lastAdded].after = prevContent + content;
- var existingComment = (0, _util.getProp)(node, 'raws', 'spaces', lastAdded, 'after') || null;
-
- if (existingComment) {
- node.raws.spaces[lastAdded].after = existingComment + content;
- }
- } else {
- spaceBefore = spaceBefore + content;
- commentBefore = commentBefore + content;
- }
-
- break;
-
- case tokens.asterisk:
- if (next[_tokenize.FIELDS.TYPE] === tokens.equals) {
- node.operator = content;
- lastAdded = 'operator';
- } else if ((!node.namespace || lastAdded === "namespace" && !spaceAfterMeaningfulToken) && next) {
- if (spaceBefore) {
- (0, _util.ensureObject)(node, 'spaces', 'attribute');
- node.spaces.attribute.before = spaceBefore;
- spaceBefore = '';
- }
-
- if (commentBefore) {
- (0, _util.ensureObject)(node, 'raws', 'spaces', 'attribute');
- node.raws.spaces.attribute.before = spaceBefore;
- commentBefore = '';
- }
-
- node.namespace = (node.namespace || "") + content;
- var rawValue = (0, _util.getProp)(node, 'raws', 'namespace') || null;
-
- if (rawValue) {
- node.raws.namespace += content;
- }
-
- lastAdded = 'namespace';
- }
-
- spaceAfterMeaningfulToken = false;
- break;
-
- case tokens.dollar:
- if (lastAdded === "value") {
- var oldRawValue = (0, _util.getProp)(node, 'raws', 'value');
- node.value += "$";
-
- if (oldRawValue) {
- node.raws.value = oldRawValue + "$";
- }
-
- break;
- }
-
- // Falls through
-
- case tokens.caret:
- if (next[_tokenize.FIELDS.TYPE] === tokens.equals) {
- node.operator = content;
- lastAdded = 'operator';
- }
-
- spaceAfterMeaningfulToken = false;
- break;
-
- case tokens.combinator:
- if (content === '~' && next[_tokenize.FIELDS.TYPE] === tokens.equals) {
- node.operator = content;
- lastAdded = 'operator';
- }
-
- if (content !== '|') {
- spaceAfterMeaningfulToken = false;
- break;
- }
-
- if (next[_tokenize.FIELDS.TYPE] === tokens.equals) {
- node.operator = content;
- lastAdded = 'operator';
- } else if (!node.namespace && !node.attribute) {
- node.namespace = true;
- }
-
- spaceAfterMeaningfulToken = false;
- break;
-
- case tokens.word:
- if (next && this.content(next) === '|' && attr[pos + 2] && attr[pos + 2][_tokenize.FIELDS.TYPE] !== tokens.equals && // this look-ahead probably fails with comment nodes involved.
- !node.operator && !node.namespace) {
- node.namespace = content;
- lastAdded = 'namespace';
- } else if (!node.attribute || lastAdded === "attribute" && !spaceAfterMeaningfulToken) {
- if (spaceBefore) {
- (0, _util.ensureObject)(node, 'spaces', 'attribute');
- node.spaces.attribute.before = spaceBefore;
- spaceBefore = '';
- }
-
- if (commentBefore) {
- (0, _util.ensureObject)(node, 'raws', 'spaces', 'attribute');
- node.raws.spaces.attribute.before = commentBefore;
- commentBefore = '';
- }
-
- node.attribute = (node.attribute || "") + content;
-
- var _rawValue = (0, _util.getProp)(node, 'raws', 'attribute') || null;
-
- if (_rawValue) {
- node.raws.attribute += content;
- }
-
- lastAdded = 'attribute';
- } else if (!node.value && node.value !== "" || lastAdded === "value" && !spaceAfterMeaningfulToken) {
- var _unescaped = (0, _util.unesc)(content);
-
- var _oldRawValue = (0, _util.getProp)(node, 'raws', 'value') || '';
-
- var oldValue = node.value || '';
- node.value = oldValue + _unescaped;
- node.quoteMark = null;
-
- if (_unescaped !== content || _oldRawValue) {
- (0, _util.ensureObject)(node, 'raws');
- node.raws.value = (_oldRawValue || oldValue) + content;
- }
-
- lastAdded = 'value';
- } else {
- var insensitive = content === 'i' || content === "I";
-
- if ((node.value || node.value === '') && (node.quoteMark || spaceAfterMeaningfulToken)) {
- node.insensitive = insensitive;
-
- if (!insensitive || content === "I") {
- (0, _util.ensureObject)(node, 'raws');
- node.raws.insensitiveFlag = content;
- }
-
- lastAdded = 'insensitive';
-
- if (spaceBefore) {
- (0, _util.ensureObject)(node, 'spaces', 'insensitive');
- node.spaces.insensitive.before = spaceBefore;
- spaceBefore = '';
- }
-
- if (commentBefore) {
- (0, _util.ensureObject)(node, 'raws', 'spaces', 'insensitive');
- node.raws.spaces.insensitive.before = commentBefore;
- commentBefore = '';
- }
- } else if (node.value || node.value === '') {
- lastAdded = 'value';
- node.value += content;
-
- if (node.raws.value) {
- node.raws.value += content;
- }
- }
- }
-
- spaceAfterMeaningfulToken = false;
- break;
-
- case tokens.str:
- if (!node.attribute || !node.operator) {
- return this.error("Expected an attribute followed by an operator preceding the string.", {
- index: token[_tokenize.FIELDS.START_POS]
- });
- }
-
- var _unescapeValue = (0, _attribute.unescapeValue)(content),
- unescaped = _unescapeValue.unescaped,
- quoteMark = _unescapeValue.quoteMark;
-
- node.value = unescaped;
- node.quoteMark = quoteMark;
- lastAdded = 'value';
- (0, _util.ensureObject)(node, 'raws');
- node.raws.value = content;
- spaceAfterMeaningfulToken = false;
- break;
-
- case tokens.equals:
- if (!node.attribute) {
- return this.expected('attribute', token[_tokenize.FIELDS.START_POS], content);
- }
-
- if (node.value) {
- return this.error('Unexpected "=" found; an operator was already defined.', {
- index: token[_tokenize.FIELDS.START_POS]
- });
- }
-
- node.operator = node.operator ? node.operator + content : content;
- lastAdded = 'operator';
- spaceAfterMeaningfulToken = false;
- break;
-
- case tokens.comment:
- if (lastAdded) {
- if (spaceAfterMeaningfulToken || next && next[_tokenize.FIELDS.TYPE] === tokens.space || lastAdded === 'insensitive') {
- var lastComment = (0, _util.getProp)(node, 'spaces', lastAdded, 'after') || '';
- var rawLastComment = (0, _util.getProp)(node, 'raws', 'spaces', lastAdded, 'after') || lastComment;
- (0, _util.ensureObject)(node, 'raws', 'spaces', lastAdded);
- node.raws.spaces[lastAdded].after = rawLastComment + content;
- } else {
- var lastValue = node[lastAdded] || '';
- var rawLastValue = (0, _util.getProp)(node, 'raws', lastAdded) || lastValue;
- (0, _util.ensureObject)(node, 'raws');
- node.raws[lastAdded] = rawLastValue + content;
- }
- } else {
- commentBefore = commentBefore + content;
- }
-
- break;
-
- default:
- return this.error("Unexpected \"" + content + "\" found.", {
- index: token[_tokenize.FIELDS.START_POS]
- });
- }
-
- pos++;
- }
-
- unescapeProp(node, "attribute");
- unescapeProp(node, "namespace");
- this.newNode(new _attribute.default(node));
- this.position++;
- }
- /**
- * return a node containing meaningless garbage up to (but not including) the specified token position.
- * if the token position is negative, all remaining tokens are consumed.
- *
- * This returns an array containing a single string node if all whitespace,
- * otherwise an array of comment nodes with space before and after.
- *
- * These tokens are not added to the current selector, the caller can add them or use them to amend
- * a previous node's space metadata.
- *
- * In lossy mode, this returns only comments.
- */
- ;
-
- _proto.parseWhitespaceEquivalentTokens = function parseWhitespaceEquivalentTokens(stopPosition) {
- if (stopPosition < 0) {
- stopPosition = this.tokens.length;
- }
-
- var startPosition = this.position;
- var nodes = [];
- var space = "";
- var lastComment = undefined;
-
- do {
- if (WHITESPACE_TOKENS[this.currToken[_tokenize.FIELDS.TYPE]]) {
- if (!this.options.lossy) {
- space += this.content();
- }
- } else if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.comment) {
- var spaces = {};
-
- if (space) {
- spaces.before = space;
- space = "";
- }
-
- lastComment = new _comment.default({
- value: this.content(),
- source: getTokenSource(this.currToken),
- sourceIndex: this.currToken[_tokenize.FIELDS.START_POS],
- spaces: spaces
- });
- nodes.push(lastComment);
- }
- } while (++this.position < stopPosition);
-
- if (space) {
- if (lastComment) {
- lastComment.spaces.after = space;
- } else if (!this.options.lossy) {
- var firstToken = this.tokens[startPosition];
- var lastToken = this.tokens[this.position - 1];
- nodes.push(new _string.default({
- value: '',
- source: getSource(firstToken[_tokenize.FIELDS.START_LINE], firstToken[_tokenize.FIELDS.START_COL], lastToken[_tokenize.FIELDS.END_LINE], lastToken[_tokenize.FIELDS.END_COL]),
- sourceIndex: firstToken[_tokenize.FIELDS.START_POS],
- spaces: {
- before: space,
- after: ''
- }
- }));
- }
- }
-
- return nodes;
- }
- /**
- *
- * @param {*} nodes
- */
- ;
-
- _proto.convertWhitespaceNodesToSpace = function convertWhitespaceNodesToSpace(nodes, requiredSpace) {
- var _this2 = this;
-
- if (requiredSpace === void 0) {
- requiredSpace = false;
- }
-
- var space = "";
- var rawSpace = "";
- nodes.forEach(function (n) {
- var spaceBefore = _this2.lossySpace(n.spaces.before, requiredSpace);
-
- var rawSpaceBefore = _this2.lossySpace(n.rawSpaceBefore, requiredSpace);
-
- space += spaceBefore + _this2.lossySpace(n.spaces.after, requiredSpace && spaceBefore.length === 0);
- rawSpace += spaceBefore + n.value + _this2.lossySpace(n.rawSpaceAfter, requiredSpace && rawSpaceBefore.length === 0);
- });
-
- if (rawSpace === space) {
- rawSpace = undefined;
- }
-
- var result = {
- space: space,
- rawSpace: rawSpace
- };
- return result;
- };
-
- _proto.isNamedCombinator = function isNamedCombinator(position) {
- if (position === void 0) {
- position = this.position;
- }
-
- return this.tokens[position + 0] && this.tokens[position + 0][_tokenize.FIELDS.TYPE] === tokens.slash && this.tokens[position + 1] && this.tokens[position + 1][_tokenize.FIELDS.TYPE] === tokens.word && this.tokens[position + 2] && this.tokens[position + 2][_tokenize.FIELDS.TYPE] === tokens.slash;
- };
-
- _proto.namedCombinator = function namedCombinator() {
- if (this.isNamedCombinator()) {
- var nameRaw = this.content(this.tokens[this.position + 1]);
- var name = (0, _util.unesc)(nameRaw).toLowerCase();
- var raws = {};
-
- if (name !== nameRaw) {
- raws.value = "/" + nameRaw + "/";
- }
-
- var node = new _combinator.default({
- value: "/" + name + "/",
- source: getSource(this.currToken[_tokenize.FIELDS.START_LINE], this.currToken[_tokenize.FIELDS.START_COL], this.tokens[this.position + 2][_tokenize.FIELDS.END_LINE], this.tokens[this.position + 2][_tokenize.FIELDS.END_COL]),
- sourceIndex: this.currToken[_tokenize.FIELDS.START_POS],
- raws: raws
- });
- this.position = this.position + 3;
- return node;
- } else {
- this.unexpected();
- }
- };
-
- _proto.combinator = function combinator() {
- var _this3 = this;
-
- if (this.content() === '|') {
- return this.namespace();
- } // We need to decide between a space that's a descendant combinator and meaningless whitespace at the end of a selector.
-
-
- var nextSigTokenPos = this.locateNextMeaningfulToken(this.position);
-
- if (nextSigTokenPos < 0 || this.tokens[nextSigTokenPos][_tokenize.FIELDS.TYPE] === tokens.comma) {
- var nodes = this.parseWhitespaceEquivalentTokens(nextSigTokenPos);
-
- if (nodes.length > 0) {
- var last = this.current.last;
-
- if (last) {
- var _this$convertWhitespa = this.convertWhitespaceNodesToSpace(nodes),
- space = _this$convertWhitespa.space,
- rawSpace = _this$convertWhitespa.rawSpace;
-
- if (rawSpace !== undefined) {
- last.rawSpaceAfter += rawSpace;
- }
-
- last.spaces.after += space;
- } else {
- nodes.forEach(function (n) {
- return _this3.newNode(n);
- });
- }
- }
-
- return;
- }
-
- var firstToken = this.currToken;
- var spaceOrDescendantSelectorNodes = undefined;
-
- if (nextSigTokenPos > this.position) {
- spaceOrDescendantSelectorNodes = this.parseWhitespaceEquivalentTokens(nextSigTokenPos);
- }
-
- var node;
-
- if (this.isNamedCombinator()) {
- node = this.namedCombinator();
- } else if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.combinator) {
- node = new _combinator.default({
- value: this.content(),
- source: getTokenSource(this.currToken),
- sourceIndex: this.currToken[_tokenize.FIELDS.START_POS]
- });
- this.position++;
- } else if (WHITESPACE_TOKENS[this.currToken[_tokenize.FIELDS.TYPE]]) {// pass
- } else if (!spaceOrDescendantSelectorNodes) {
- this.unexpected();
- }
-
- if (node) {
- if (spaceOrDescendantSelectorNodes) {
- var _this$convertWhitespa2 = this.convertWhitespaceNodesToSpace(spaceOrDescendantSelectorNodes),
- _space = _this$convertWhitespa2.space,
- _rawSpace = _this$convertWhitespa2.rawSpace;
-
- node.spaces.before = _space;
- node.rawSpaceBefore = _rawSpace;
- }
- } else {
- // descendant combinator
- var _this$convertWhitespa3 = this.convertWhitespaceNodesToSpace(spaceOrDescendantSelectorNodes, true),
- _space2 = _this$convertWhitespa3.space,
- _rawSpace2 = _this$convertWhitespa3.rawSpace;
-
- if (!_rawSpace2) {
- _rawSpace2 = _space2;
- }
-
- var spaces = {};
- var raws = {
- spaces: {}
- };
-
- if (_space2.endsWith(' ') && _rawSpace2.endsWith(' ')) {
- spaces.before = _space2.slice(0, _space2.length - 1);
- raws.spaces.before = _rawSpace2.slice(0, _rawSpace2.length - 1);
- } else if (_space2.startsWith(' ') && _rawSpace2.startsWith(' ')) {
- spaces.after = _space2.slice(1);
- raws.spaces.after = _rawSpace2.slice(1);
- } else {
- raws.value = _rawSpace2;
- }
-
- node = new _combinator.default({
- value: ' ',
- source: getTokenSourceSpan(firstToken, this.tokens[this.position - 1]),
- sourceIndex: firstToken[_tokenize.FIELDS.START_POS],
- spaces: spaces,
- raws: raws
- });
- }
-
- if (this.currToken && this.currToken[_tokenize.FIELDS.TYPE] === tokens.space) {
- node.spaces.after = this.optionalSpace(this.content());
- this.position++;
- }
-
- return this.newNode(node);
- };
-
- _proto.comma = function comma() {
- if (this.position === this.tokens.length - 1) {
- this.root.trailingComma = true;
- this.position++;
- return;
- }
-
- this.current._inferEndPosition();
-
- var selector = new _selector.default({
- source: {
- start: tokenStart(this.tokens[this.position + 1])
- }
- });
- this.current.parent.append(selector);
- this.current = selector;
- this.position++;
- };
-
- _proto.comment = function comment() {
- var current = this.currToken;
- this.newNode(new _comment.default({
- value: this.content(),
- source: getTokenSource(current),
- sourceIndex: current[_tokenize.FIELDS.START_POS]
- }));
- this.position++;
- };
-
- _proto.error = function error(message, opts) {
- throw this.root.error(message, opts);
- };
-
- _proto.missingBackslash = function missingBackslash() {
- return this.error('Expected a backslash preceding the semicolon.', {
- index: this.currToken[_tokenize.FIELDS.START_POS]
- });
- };
-
- _proto.missingParenthesis = function missingParenthesis() {
- return this.expected('opening parenthesis', this.currToken[_tokenize.FIELDS.START_POS]);
- };
-
- _proto.missingSquareBracket = function missingSquareBracket() {
- return this.expected('opening square bracket', this.currToken[_tokenize.FIELDS.START_POS]);
- };
-
- _proto.unexpected = function unexpected() {
- return this.error("Unexpected '" + this.content() + "'. Escaping special characters with \\ may help.", this.currToken[_tokenize.FIELDS.START_POS]);
- };
-
- _proto.namespace = function namespace() {
- var before = this.prevToken && this.content(this.prevToken) || true;
-
- if (this.nextToken[_tokenize.FIELDS.TYPE] === tokens.word) {
- this.position++;
- return this.word(before);
- } else if (this.nextToken[_tokenize.FIELDS.TYPE] === tokens.asterisk) {
- this.position++;
- return this.universal(before);
- }
- };
-
- _proto.nesting = function nesting() {
- if (this.nextToken) {
- var nextContent = this.content(this.nextToken);
-
- if (nextContent === "|") {
- this.position++;
- return;
- }
- }
-
- var current = this.currToken;
- this.newNode(new _nesting.default({
- value: this.content(),
- source: getTokenSource(current),
- sourceIndex: current[_tokenize.FIELDS.START_POS]
- }));
- this.position++;
- };
-
- _proto.parentheses = function parentheses() {
- var last = this.current.last;
- var unbalanced = 1;
- this.position++;
-
- if (last && last.type === types.PSEUDO) {
- var selector = new _selector.default({
- source: {
- start: tokenStart(this.tokens[this.position - 1])
- }
- });
- var cache = this.current;
- last.append(selector);
- this.current = selector;
-
- while (this.position < this.tokens.length && unbalanced) {
- if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.openParenthesis) {
- unbalanced++;
- }
-
- if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.closeParenthesis) {
- unbalanced--;
- }
-
- if (unbalanced) {
- this.parse();
- } else {
- this.current.source.end = tokenEnd(this.currToken);
- this.current.parent.source.end = tokenEnd(this.currToken);
- this.position++;
- }
- }
-
- this.current = cache;
- } else {
- // I think this case should be an error. It's used to implement a basic parse of media queries
- // but I don't think it's a good idea.
- var parenStart = this.currToken;
- var parenValue = "(";
- var parenEnd;
-
- while (this.position < this.tokens.length && unbalanced) {
- if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.openParenthesis) {
- unbalanced++;
- }
-
- if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.closeParenthesis) {
- unbalanced--;
- }
-
- parenEnd = this.currToken;
- parenValue += this.parseParenthesisToken(this.currToken);
- this.position++;
- }
-
- if (last) {
- last.appendToPropertyAndEscape("value", parenValue, parenValue);
- } else {
- this.newNode(new _string.default({
- value: parenValue,
- source: getSource(parenStart[_tokenize.FIELDS.START_LINE], parenStart[_tokenize.FIELDS.START_COL], parenEnd[_tokenize.FIELDS.END_LINE], parenEnd[_tokenize.FIELDS.END_COL]),
- sourceIndex: parenStart[_tokenize.FIELDS.START_POS]
- }));
- }
- }
-
- if (unbalanced) {
- return this.expected('closing parenthesis', this.currToken[_tokenize.FIELDS.START_POS]);
- }
- };
-
- _proto.pseudo = function pseudo() {
- var _this4 = this;
-
- var pseudoStr = '';
- var startingToken = this.currToken;
-
- while (this.currToken && this.currToken[_tokenize.FIELDS.TYPE] === tokens.colon) {
- pseudoStr += this.content();
- this.position++;
- }
-
- if (!this.currToken) {
- return this.expected(['pseudo-class', 'pseudo-element'], this.position - 1);
- }
-
- if (this.currToken[_tokenize.FIELDS.TYPE] === tokens.word) {
- this.splitWord(false, function (first, length) {
- pseudoStr += first;
-
- _this4.newNode(new _pseudo.default({
- value: pseudoStr,
- source: getTokenSourceSpan(startingToken, _this4.currToken),
- sourceIndex: startingToken[_tokenize.FIELDS.START_POS]
- }));
-
- if (length > 1 && _this4.nextToken && _this4.nextToken[_tokenize.FIELDS.TYPE] === tokens.openParenthesis) {
- _this4.error('Misplaced parenthesis.', {
- index: _this4.nextToken[_tokenize.FIELDS.START_POS]
- });
- }
- });
- } else {
- return this.expected(['pseudo-class', 'pseudo-element'], this.currToken[_tokenize.FIELDS.START_POS]);
- }
- };
-
- _proto.space = function space() {
- var content = this.content(); // Handle space before and after the selector
-
- if (this.position === 0 || this.prevToken[_tokenize.FIELDS.TYPE] === tokens.comma || this.prevToken[_tokenize.FIELDS.TYPE] === tokens.openParenthesis) {
- this.spaces = this.optionalSpace(content);
- this.position++;
- } else if (this.position === this.tokens.length - 1 || this.nextToken[_tokenize.FIELDS.TYPE] === tokens.comma || this.nextToken[_tokenize.FIELDS.TYPE] === tokens.closeParenthesis) {
- this.current.last.spaces.after = this.optionalSpace(content);
- this.position++;
- } else {
- this.combinator();
- }
- };
-
- _proto.string = function string() {
- var current = this.currToken;
- this.newNode(new _string.default({
- value: this.content(),
- source: getTokenSource(current),
- sourceIndex: current[_tokenize.FIELDS.START_POS]
- }));
- this.position++;
- };
-
- _proto.universal = function universal(namespace) {
- var nextToken = this.nextToken;
-
- if (nextToken && this.content(nextToken) === '|') {
- this.position++;
- return this.namespace();
- }
-
- var current = this.currToken;
- this.newNode(new _universal.default({
- value: this.content(),
- source: getTokenSource(current),
- sourceIndex: current[_tokenize.FIELDS.START_POS]
- }), namespace);
- this.position++;
- };
-
- _proto.splitWord = function splitWord(namespace, firstCallback) {
- var _this5 = this;
-
- var nextToken = this.nextToken;
- var word = this.content();
-
- while (nextToken && ~[tokens.dollar, tokens.caret, tokens.equals, tokens.word].indexOf(nextToken[_tokenize.FIELDS.TYPE])) {
- this.position++;
- var current = this.content();
- word += current;
-
- if (current.lastIndexOf('\\') === current.length - 1) {
- var next = this.nextToken;
-
- if (next && next[_tokenize.FIELDS.TYPE] === tokens.space) {
- word += this.requiredSpace(this.content(next));
- this.position++;
- }
- }
-
- nextToken = this.nextToken;
- }
-
- var hasClass = (0, _indexesOf.default)(word, '.').filter(function (i) {
- return word[i - 1] !== '\\';
- });
- var hasId = (0, _indexesOf.default)(word, '#').filter(function (i) {
- return word[i - 1] !== '\\';
- }); // Eliminate Sass interpolations from the list of id indexes
-
- var interpolations = (0, _indexesOf.default)(word, '#{');
-
- if (interpolations.length) {
- hasId = hasId.filter(function (hashIndex) {
- return !~interpolations.indexOf(hashIndex);
- });
- }
-
- var indices = (0, _sortAscending.default)((0, _uniq.default)([0].concat(hasClass, hasId)));
- indices.forEach(function (ind, i) {
- var index = indices[i + 1] || word.length;
- var value = word.slice(ind, index);
-
- if (i === 0 && firstCallback) {
- return firstCallback.call(_this5, value, indices.length);
- }
-
- var node;
- var current = _this5.currToken;
- var sourceIndex = current[_tokenize.FIELDS.START_POS] + indices[i];
- var source = getSource(current[1], current[2] + ind, current[3], current[2] + (index - 1));
-
- if (~hasClass.indexOf(ind)) {
- var classNameOpts = {
- value: value.slice(1),
- source: source,
- sourceIndex: sourceIndex
- };
- node = new _className.default(unescapeProp(classNameOpts, "value"));
- } else if (~hasId.indexOf(ind)) {
- var idOpts = {
- value: value.slice(1),
- source: source,
- sourceIndex: sourceIndex
- };
- node = new _id.default(unescapeProp(idOpts, "value"));
- } else {
- var tagOpts = {
- value: value,
- source: source,
- sourceIndex: sourceIndex
- };
- unescapeProp(tagOpts, "value");
- node = new _tag.default(tagOpts);
- }
-
- _this5.newNode(node, namespace); // Ensure that the namespace is used only once
-
-
- namespace = null;
- });
- this.position++;
- };
-
- _proto.word = function word(namespace) {
- var nextToken = this.nextToken;
-
- if (nextToken && this.content(nextToken) === '|') {
- this.position++;
- return this.namespace();
- }
-
- return this.splitWord(namespace);
- };
-
- _proto.loop = function loop() {
- while (this.position < this.tokens.length) {
- this.parse(true);
- }
-
- this.current._inferEndPosition();
-
- return this.root;
- };
-
- _proto.parse = function parse(throwOnParenthesis) {
- switch (this.currToken[_tokenize.FIELDS.TYPE]) {
- case tokens.space:
- this.space();
- break;
-
- case tokens.comment:
- this.comment();
- break;
-
- case tokens.openParenthesis:
- this.parentheses();
- break;
-
- case tokens.closeParenthesis:
- if (throwOnParenthesis) {
- this.missingParenthesis();
- }
-
- break;
-
- case tokens.openSquare:
- this.attribute();
- break;
-
- case tokens.dollar:
- case tokens.caret:
- case tokens.equals:
- case tokens.word:
- this.word();
- break;
-
- case tokens.colon:
- this.pseudo();
- break;
-
- case tokens.comma:
- this.comma();
- break;
-
- case tokens.asterisk:
- this.universal();
- break;
-
- case tokens.ampersand:
- this.nesting();
- break;
-
- case tokens.slash:
- case tokens.combinator:
- this.combinator();
- break;
-
- case tokens.str:
- this.string();
- break;
- // These cases throw; no break needed.
-
- case tokens.closeSquare:
- this.missingSquareBracket();
-
- case tokens.semicolon:
- this.missingBackslash();
-
- default:
- this.unexpected();
- }
- }
- /**
- * Helpers
- */
- ;
-
- _proto.expected = function expected(description, index, found) {
- if (Array.isArray(description)) {
- var last = description.pop();
- description = description.join(', ') + " or " + last;
- }
-
- var an = /^[aeiou]/.test(description[0]) ? 'an' : 'a';
-
- if (!found) {
- return this.error("Expected " + an + " " + description + ".", {
- index: index
- });
- }
-
- return this.error("Expected " + an + " " + description + ", found \"" + found + "\" instead.", {
- index: index
- });
- };
-
- _proto.requiredSpace = function requiredSpace(space) {
- return this.options.lossy ? ' ' : space;
- };
-
- _proto.optionalSpace = function optionalSpace(space) {
- return this.options.lossy ? '' : space;
- };
-
- _proto.lossySpace = function lossySpace(space, required) {
- if (this.options.lossy) {
- return required ? ' ' : '';
- } else {
- return space;
- }
- };
-
- _proto.parseParenthesisToken = function parseParenthesisToken(token) {
- var content = this.content(token);
-
- if (token[_tokenize.FIELDS.TYPE] === tokens.space) {
- return this.requiredSpace(content);
- } else {
- return content;
- }
- };
-
- _proto.newNode = function newNode(node, namespace) {
- if (namespace) {
- if (/^ +$/.test(namespace)) {
- if (!this.options.lossy) {
- this.spaces = (this.spaces || '') + namespace;
- }
-
- namespace = true;
- }
-
- node.namespace = namespace;
- unescapeProp(node, "namespace");
- }
-
- if (this.spaces) {
- node.spaces.before = this.spaces;
- this.spaces = '';
- }
-
- return this.current.append(node);
- };
-
- _proto.content = function content(token) {
- if (token === void 0) {
- token = this.currToken;
- }
-
- return this.css.slice(token[_tokenize.FIELDS.START_POS], token[_tokenize.FIELDS.END_POS]);
- };
-
- /**
- * returns the index of the next non-whitespace, non-comment token.
- * returns -1 if no meaningful token is found.
- */
- _proto.locateNextMeaningfulToken = function locateNextMeaningfulToken(startPosition) {
- if (startPosition === void 0) {
- startPosition = this.position + 1;
- }
-
- var searchPosition = startPosition;
-
- while (searchPosition < this.tokens.length) {
- if (WHITESPACE_EQUIV_TOKENS[this.tokens[searchPosition][_tokenize.FIELDS.TYPE]]) {
- searchPosition++;
- continue;
- } else {
- return searchPosition;
- }
- }
-
- return -1;
- };
-
- _createClass(Parser, [{
- key: "currToken",
- get: function get() {
- return this.tokens[this.position];
- }
- }, {
- key: "nextToken",
- get: function get() {
- return this.tokens[this.position + 1];
- }
- }, {
- key: "prevToken",
- get: function get() {
- return this.tokens[this.position - 1];
- }
- }]);
-
- return Parser;
-}();
-
-exports.default = Parser;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/processor.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/processor.js
deleted file mode 100644
index 048b1ef..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/processor.js
+++ /dev/null
@@ -1,208 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _parser = _interopRequireDefault(require("./parser"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-var Processor =
-/*#__PURE__*/
-function () {
- function Processor(func, options) {
- this.func = func || function noop() {};
-
- this.funcRes = null;
- this.options = options;
- }
-
- var _proto = Processor.prototype;
-
- _proto._shouldUpdateSelector = function _shouldUpdateSelector(rule, options) {
- if (options === void 0) {
- options = {};
- }
-
- var merged = Object.assign({}, this.options, options);
-
- if (merged.updateSelector === false) {
- return false;
- } else {
- return typeof rule !== "string";
- }
- };
-
- _proto._isLossy = function _isLossy(options) {
- if (options === void 0) {
- options = {};
- }
-
- var merged = Object.assign({}, this.options, options);
-
- if (merged.lossless === false) {
- return true;
- } else {
- return false;
- }
- };
-
- _proto._root = function _root(rule, options) {
- if (options === void 0) {
- options = {};
- }
-
- var parser = new _parser.default(rule, this._parseOptions(options));
- return parser.root;
- };
-
- _proto._parseOptions = function _parseOptions(options) {
- return {
- lossy: this._isLossy(options)
- };
- };
-
- _proto._run = function _run(rule, options) {
- var _this = this;
-
- if (options === void 0) {
- options = {};
- }
-
- return new Promise(function (resolve, reject) {
- try {
- var root = _this._root(rule, options);
-
- Promise.resolve(_this.func(root)).then(function (transform) {
- var string = undefined;
-
- if (_this._shouldUpdateSelector(rule, options)) {
- string = root.toString();
- rule.selector = string;
- }
-
- return {
- transform: transform,
- root: root,
- string: string
- };
- }).then(resolve, reject);
- } catch (e) {
- reject(e);
- return;
- }
- });
- };
-
- _proto._runSync = function _runSync(rule, options) {
- if (options === void 0) {
- options = {};
- }
-
- var root = this._root(rule, options);
-
- var transform = this.func(root);
-
- if (transform && typeof transform.then === "function") {
- throw new Error("Selector processor returned a promise to a synchronous call.");
- }
-
- var string = undefined;
-
- if (options.updateSelector && typeof rule !== "string") {
- string = root.toString();
- rule.selector = string;
- }
-
- return {
- transform: transform,
- root: root,
- string: string
- };
- }
- /**
- * Process rule into a selector AST.
- *
- * @param rule {postcss.Rule | string} The css selector to be processed
- * @param options The options for processing
- * @returns {Promise<parser.Root>} The AST of the selector after processing it.
- */
- ;
-
- _proto.ast = function ast(rule, options) {
- return this._run(rule, options).then(function (result) {
- return result.root;
- });
- }
- /**
- * Process rule into a selector AST synchronously.
- *
- * @param rule {postcss.Rule | string} The css selector to be processed
- * @param options The options for processing
- * @returns {parser.Root} The AST of the selector after processing it.
- */
- ;
-
- _proto.astSync = function astSync(rule, options) {
- return this._runSync(rule, options).root;
- }
- /**
- * Process a selector into a transformed value asynchronously
- *
- * @param rule {postcss.Rule | string} The css selector to be processed
- * @param options The options for processing
- * @returns {Promise<any>} The value returned by the processor.
- */
- ;
-
- _proto.transform = function transform(rule, options) {
- return this._run(rule, options).then(function (result) {
- return result.transform;
- });
- }
- /**
- * Process a selector into a transformed value synchronously.
- *
- * @param rule {postcss.Rule | string} The css selector to be processed
- * @param options The options for processing
- * @returns {any} The value returned by the processor.
- */
- ;
-
- _proto.transformSync = function transformSync(rule, options) {
- return this._runSync(rule, options).transform;
- }
- /**
- * Process a selector into a new selector string asynchronously.
- *
- * @param rule {postcss.Rule | string} The css selector to be processed
- * @param options The options for processing
- * @returns {string} the selector after processing.
- */
- ;
-
- _proto.process = function process(rule, options) {
- return this._run(rule, options).then(function (result) {
- return result.string || result.root.toString();
- });
- }
- /**
- * Process a selector into a new selector string synchronously.
- *
- * @param rule {postcss.Rule | string} The css selector to be processed
- * @param options The options for processing
- * @returns {string} the selector after processing.
- */
- ;
-
- _proto.processSync = function processSync(rule, options) {
- var result = this._runSync(rule, options);
-
- return result.string || result.root.toString();
- };
-
- return Processor;
-}();
-
-exports.default = Processor;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/attribute.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/attribute.js
deleted file mode 100644
index 8d9c280..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/attribute.js
+++ /dev/null
@@ -1,516 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.unescapeValue = unescapeValue;
-exports.default = void 0;
-
-var _cssesc = _interopRequireDefault(require("cssesc"));
-
-var _unesc = _interopRequireDefault(require("../util/unesc"));
-
-var _namespace = _interopRequireDefault(require("./namespace"));
-
-var _types = require("./types");
-
-var _CSSESC_QUOTE_OPTIONS;
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
-
-function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var _require = require("util"),
- deprecate = _require.deprecate;
-
-var WRAPPED_IN_QUOTES = /^('|")(.*)\1$/;
-var warnOfDeprecatedValueAssignment = deprecate(function () {}, "Assigning an attribute a value containing characters that might need to be escaped is deprecated. " + "Call attribute.setValue() instead.");
-var warnOfDeprecatedQuotedAssignment = deprecate(function () {}, "Assigning attr.quoted is deprecated and has no effect. Assign to attr.quoteMark instead.");
-var warnOfDeprecatedConstructor = deprecate(function () {}, "Constructing an Attribute selector with a value without specifying quoteMark is deprecated. Note: The value should be unescaped now.");
-
-function unescapeValue(value) {
- var deprecatedUsage = false;
- var quoteMark = null;
- var unescaped = value;
- var m = unescaped.match(WRAPPED_IN_QUOTES);
-
- if (m) {
- quoteMark = m[1];
- unescaped = m[2];
- }
-
- unescaped = (0, _unesc.default)(unescaped);
-
- if (unescaped !== value) {
- deprecatedUsage = true;
- }
-
- return {
- deprecatedUsage: deprecatedUsage,
- unescaped: unescaped,
- quoteMark: quoteMark
- };
-}
-
-function handleDeprecatedContructorOpts(opts) {
- if (opts.quoteMark !== undefined) {
- return opts;
- }
-
- if (opts.value === undefined) {
- return opts;
- }
-
- warnOfDeprecatedConstructor();
-
- var _unescapeValue = unescapeValue(opts.value),
- quoteMark = _unescapeValue.quoteMark,
- unescaped = _unescapeValue.unescaped;
-
- if (!opts.raws) {
- opts.raws = {};
- }
-
- if (opts.raws.value === undefined) {
- opts.raws.value = opts.value;
- }
-
- opts.value = unescaped;
- opts.quoteMark = quoteMark;
- return opts;
-}
-
-var Attribute =
-/*#__PURE__*/
-function (_Namespace) {
- _inheritsLoose(Attribute, _Namespace);
-
- function Attribute(opts) {
- var _this;
-
- if (opts === void 0) {
- opts = {};
- }
-
- _this = _Namespace.call(this, handleDeprecatedContructorOpts(opts)) || this;
- _this.type = _types.ATTRIBUTE;
- _this.raws = _this.raws || {};
- Object.defineProperty(_this.raws, 'unquoted', {
- get: deprecate(function () {
- return _this.value;
- }, "attr.raws.unquoted is deprecated. Call attr.value instead."),
- set: deprecate(function () {
- return _this.value;
- }, "Setting attr.raws.unquoted is deprecated and has no effect. attr.value is unescaped by default now.")
- });
- _this._constructed = true;
- return _this;
- }
- /**
- * Returns the Attribute's value quoted such that it would be legal to use
- * in the value of a css file. The original value's quotation setting
- * used for stringification is left unchanged. See `setValue(value, options)`
- * if you want to control the quote settings of a new value for the attribute.
- *
- * You can also change the quotation used for the current value by setting quoteMark.
- *
- * Options:
- * * quoteMark {'"' | "'" | null} - Use this value to quote the value. If this
- * option is not set, the original value for quoteMark will be used. If
- * indeterminate, a double quote is used. The legal values are:
- * * `null` - the value will be unquoted and characters will be escaped as necessary.
- * * `'` - the value will be quoted with a single quote and single quotes are escaped.
- * * `"` - the value will be quoted with a double quote and double quotes are escaped.
- * * preferCurrentQuoteMark {boolean} - if true, prefer the source quote mark
- * over the quoteMark option value.
- * * smart {boolean} - if true, will select a quote mark based on the value
- * and the other options specified here. See the `smartQuoteMark()`
- * method.
- **/
-
-
- var _proto = Attribute.prototype;
-
- _proto.getQuotedValue = function getQuotedValue(options) {
- if (options === void 0) {
- options = {};
- }
-
- var quoteMark = this._determineQuoteMark(options);
-
- var cssescopts = CSSESC_QUOTE_OPTIONS[quoteMark];
- var escaped = (0, _cssesc.default)(this._value, cssescopts);
- return escaped;
- };
-
- _proto._determineQuoteMark = function _determineQuoteMark(options) {
- return options.smart ? this.smartQuoteMark(options) : this.preferredQuoteMark(options);
- }
- /**
- * Set the unescaped value with the specified quotation options. The value
- * provided must not include any wrapping quote marks -- those quotes will
- * be interpreted as part of the value and escaped accordingly.
- */
- ;
-
- _proto.setValue = function setValue(value, options) {
- if (options === void 0) {
- options = {};
- }
-
- this._value = value;
- this._quoteMark = this._determineQuoteMark(options);
-
- this._syncRawValue();
- }
- /**
- * Intelligently select a quoteMark value based on the value's contents. If
- * the value is a legal CSS ident, it will not be quoted. Otherwise a quote
- * mark will be picked that minimizes the number of escapes.
- *
- * If there's no clear winner, the quote mark from these options is used,
- * then the source quote mark (this is inverted if `preferCurrentQuoteMark` is
- * true). If the quoteMark is unspecified, a double quote is used.
- *
- * @param options This takes the quoteMark and preferCurrentQuoteMark options
- * from the quoteValue method.
- */
- ;
-
- _proto.smartQuoteMark = function smartQuoteMark(options) {
- var v = this.value;
- var numSingleQuotes = v.replace(/[^']/g, '').length;
- var numDoubleQuotes = v.replace(/[^"]/g, '').length;
-
- if (numSingleQuotes + numDoubleQuotes === 0) {
- var escaped = (0, _cssesc.default)(v, {
- isIdentifier: true
- });
-
- if (escaped === v) {
- return Attribute.NO_QUOTE;
- } else {
- var pref = this.preferredQuoteMark(options);
-
- if (pref === Attribute.NO_QUOTE) {
- // pick a quote mark that isn't none and see if it's smaller
- var quote = this.quoteMark || options.quoteMark || Attribute.DOUBLE_QUOTE;
- var opts = CSSESC_QUOTE_OPTIONS[quote];
- var quoteValue = (0, _cssesc.default)(v, opts);
-
- if (quoteValue.length < escaped.length) {
- return quote;
- }
- }
-
- return pref;
- }
- } else if (numDoubleQuotes === numSingleQuotes) {
- return this.preferredQuoteMark(options);
- } else if (numDoubleQuotes < numSingleQuotes) {
- return Attribute.DOUBLE_QUOTE;
- } else {
- return Attribute.SINGLE_QUOTE;
- }
- }
- /**
- * Selects the preferred quote mark based on the options and the current quote mark value.
- * If you want the quote mark to depend on the attribute value, call `smartQuoteMark(opts)`
- * instead.
- */
- ;
-
- _proto.preferredQuoteMark = function preferredQuoteMark(options) {
- var quoteMark = options.preferCurrentQuoteMark ? this.quoteMark : options.quoteMark;
-
- if (quoteMark === undefined) {
- quoteMark = options.preferCurrentQuoteMark ? options.quoteMark : this.quoteMark;
- }
-
- if (quoteMark === undefined) {
- quoteMark = Attribute.DOUBLE_QUOTE;
- }
-
- return quoteMark;
- };
-
- _proto._syncRawValue = function _syncRawValue() {
- var rawValue = (0, _cssesc.default)(this._value, CSSESC_QUOTE_OPTIONS[this.quoteMark]);
-
- if (rawValue === this._value) {
- if (this.raws) {
- delete this.raws.value;
- }
- } else {
- this.raws.value = rawValue;
- }
- };
-
- _proto._handleEscapes = function _handleEscapes(prop, value) {
- if (this._constructed) {
- var escaped = (0, _cssesc.default)(value, {
- isIdentifier: true
- });
-
- if (escaped !== value) {
- this.raws[prop] = escaped;
- } else {
- delete this.raws[prop];
- }
- }
- };
-
- _proto._spacesFor = function _spacesFor(name) {
- var attrSpaces = {
- before: '',
- after: ''
- };
- var spaces = this.spaces[name] || {};
- var rawSpaces = this.raws.spaces && this.raws.spaces[name] || {};
- return Object.assign(attrSpaces, spaces, rawSpaces);
- };
-
- _proto._stringFor = function _stringFor(name, spaceName, concat) {
- if (spaceName === void 0) {
- spaceName = name;
- }
-
- if (concat === void 0) {
- concat = defaultAttrConcat;
- }
-
- var attrSpaces = this._spacesFor(spaceName);
-
- return concat(this.stringifyProperty(name), attrSpaces);
- }
- /**
- * returns the offset of the attribute part specified relative to the
- * start of the node of the output string.
- *
- * * "ns" - alias for "namespace"
- * * "namespace" - the namespace if it exists.
- * * "attribute" - the attribute name
- * * "attributeNS" - the start of the attribute or its namespace
- * * "operator" - the match operator of the attribute
- * * "value" - The value (string or identifier)
- * * "insensitive" - the case insensitivity flag;
- * @param part One of the possible values inside an attribute.
- * @returns -1 if the name is invalid or the value doesn't exist in this attribute.
- */
- ;
-
- _proto.offsetOf = function offsetOf(name) {
- var count = 1;
-
- var attributeSpaces = this._spacesFor("attribute");
-
- count += attributeSpaces.before.length;
-
- if (name === "namespace" || name === "ns") {
- return this.namespace ? count : -1;
- }
-
- if (name === "attributeNS") {
- return count;
- }
-
- count += this.namespaceString.length;
-
- if (this.namespace) {
- count += 1;
- }
-
- if (name === "attribute") {
- return count;
- }
-
- count += this.stringifyProperty("attribute").length;
- count += attributeSpaces.after.length;
-
- var operatorSpaces = this._spacesFor("operator");
-
- count += operatorSpaces.before.length;
- var operator = this.stringifyProperty("operator");
-
- if (name === "operator") {
- return operator ? count : -1;
- }
-
- count += operator.length;
- count += operatorSpaces.after.length;
-
- var valueSpaces = this._spacesFor("value");
-
- count += valueSpaces.before.length;
- var value = this.stringifyProperty("value");
-
- if (name === "value") {
- return value ? count : -1;
- }
-
- count += value.length;
- count += valueSpaces.after.length;
-
- var insensitiveSpaces = this._spacesFor("insensitive");
-
- count += insensitiveSpaces.before.length;
-
- if (name === "insensitive") {
- return this.insensitive ? count : -1;
- }
-
- return -1;
- };
-
- _proto.toString = function toString() {
- var _this2 = this;
-
- var selector = [this.rawSpaceBefore, '['];
- selector.push(this._stringFor('qualifiedAttribute', 'attribute'));
-
- if (this.operator && (this.value || this.value === '')) {
- selector.push(this._stringFor('operator'));
- selector.push(this._stringFor('value'));
- selector.push(this._stringFor('insensitiveFlag', 'insensitive', function (attrValue, attrSpaces) {
- if (attrValue.length > 0 && !_this2.quoted && attrSpaces.before.length === 0 && !(_this2.spaces.value && _this2.spaces.value.after)) {
- attrSpaces.before = " ";
- }
-
- return defaultAttrConcat(attrValue, attrSpaces);
- }));
- }
-
- selector.push(']');
- selector.push(this.rawSpaceAfter);
- return selector.join('');
- };
-
- _createClass(Attribute, [{
- key: "quoted",
- get: function get() {
- var qm = this.quoteMark;
- return qm === "'" || qm === '"';
- },
- set: function set(value) {
- warnOfDeprecatedQuotedAssignment();
- }
- /**
- * returns a single (`'`) or double (`"`) quote character if the value is quoted.
- * returns `null` if the value is not quoted.
- * returns `undefined` if the quotation state is unknown (this can happen when
- * the attribute is constructed without specifying a quote mark.)
- */
-
- }, {
- key: "quoteMark",
- get: function get() {
- return this._quoteMark;
- }
- /**
- * Set the quote mark to be used by this attribute's value.
- * If the quote mark changes, the raw (escaped) value at `attr.raws.value` of the attribute
- * value is updated accordingly.
- *
- * @param {"'" | '"' | null} quoteMark The quote mark or `null` if the value should be unquoted.
- */
- ,
- set: function set(quoteMark) {
- if (!this._constructed) {
- this._quoteMark = quoteMark;
- return;
- }
-
- if (this._quoteMark !== quoteMark) {
- this._quoteMark = quoteMark;
-
- this._syncRawValue();
- }
- }
- }, {
- key: "qualifiedAttribute",
- get: function get() {
- return this.qualifiedName(this.raws.attribute || this.attribute);
- }
- }, {
- key: "insensitiveFlag",
- get: function get() {
- return this.insensitive ? 'i' : '';
- }
- }, {
- key: "value",
- get: function get() {
- return this._value;
- }
- /**
- * Before 3.0, the value had to be set to an escaped value including any wrapped
- * quote marks. In 3.0, the semantics of `Attribute.value` changed so that the value
- * is unescaped during parsing and any quote marks are removed.
- *
- * Because the ambiguity of this semantic change, if you set `attr.value = newValue`,
- * a deprecation warning is raised when the new value contains any characters that would
- * require escaping (including if it contains wrapped quotes).
- *
- * Instead, you should call `attr.setValue(newValue, opts)` and pass options that describe
- * how the new value is quoted.
- */
- ,
- set: function set(v) {
- if (this._constructed) {
- var _unescapeValue2 = unescapeValue(v),
- deprecatedUsage = _unescapeValue2.deprecatedUsage,
- unescaped = _unescapeValue2.unescaped,
- quoteMark = _unescapeValue2.quoteMark;
-
- if (deprecatedUsage) {
- warnOfDeprecatedValueAssignment();
- }
-
- if (unescaped === this._value && quoteMark === this._quoteMark) {
- return;
- }
-
- this._value = unescaped;
- this._quoteMark = quoteMark;
-
- this._syncRawValue();
- } else {
- this._value = v;
- }
- }
- }, {
- key: "attribute",
- get: function get() {
- return this._attribute;
- },
- set: function set(name) {
- this._handleEscapes("attribute", name);
-
- this._attribute = name;
- }
- }]);
-
- return Attribute;
-}(_namespace.default);
-
-exports.default = Attribute;
-Attribute.NO_QUOTE = null;
-Attribute.SINGLE_QUOTE = "'";
-Attribute.DOUBLE_QUOTE = '"';
-var CSSESC_QUOTE_OPTIONS = (_CSSESC_QUOTE_OPTIONS = {
- "'": {
- quotes: 'single',
- wrap: true
- },
- '"': {
- quotes: 'double',
- wrap: true
- }
-}, _CSSESC_QUOTE_OPTIONS[null] = {
- isIdentifier: true
-}, _CSSESC_QUOTE_OPTIONS);
-
-function defaultAttrConcat(attrValue, attrSpaces) {
- return "" + attrSpaces.before + attrValue + attrSpaces.after;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/className.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/className.js
deleted file mode 100644
index d79247d..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/className.js
+++ /dev/null
@@ -1,69 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _cssesc = _interopRequireDefault(require("cssesc"));
-
-var _util = require("../util");
-
-var _node = _interopRequireDefault(require("./node"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
-
-function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var ClassName =
-/*#__PURE__*/
-function (_Node) {
- _inheritsLoose(ClassName, _Node);
-
- function ClassName(opts) {
- var _this;
-
- _this = _Node.call(this, opts) || this;
- _this.type = _types.CLASS;
- _this._constructed = true;
- return _this;
- }
-
- var _proto = ClassName.prototype;
-
- _proto.toString = function toString() {
- return [this.rawSpaceBefore, String('.' + this.stringifyProperty("value")), this.rawSpaceAfter].join('');
- };
-
- _createClass(ClassName, [{
- key: "value",
- set: function set(v) {
- if (this._constructed) {
- var escaped = (0, _cssesc.default)(v, {
- isIdentifier: true
- });
-
- if (escaped !== v) {
- (0, _util.ensureObject)(this, "raws");
- this.raws.value = escaped;
- } else if (this.raws) {
- delete this.raws.value;
- }
- }
-
- this._value = v;
- },
- get: function get() {
- return this._value;
- }
- }]);
-
- return ClassName;
-}(_node.default);
-
-exports.default = ClassName;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/combinator.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/combinator.js
deleted file mode 100644
index 479cc4b..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/combinator.js
+++ /dev/null
@@ -1,31 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _node = _interopRequireDefault(require("./node"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var Combinator =
-/*#__PURE__*/
-function (_Node) {
- _inheritsLoose(Combinator, _Node);
-
- function Combinator(opts) {
- var _this;
-
- _this = _Node.call(this, opts) || this;
- _this.type = _types.COMBINATOR;
- return _this;
- }
-
- return Combinator;
-}(_node.default);
-
-exports.default = Combinator;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/comment.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/comment.js
deleted file mode 100644
index a104b69..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/comment.js
+++ /dev/null
@@ -1,31 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _node = _interopRequireDefault(require("./node"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var Comment =
-/*#__PURE__*/
-function (_Node) {
- _inheritsLoose(Comment, _Node);
-
- function Comment(opts) {
- var _this;
-
- _this = _Node.call(this, opts) || this;
- _this.type = _types.COMMENT;
- return _this;
- }
-
- return Comment;
-}(_node.default);
-
-exports.default = Comment;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/constructors.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/constructors.js
deleted file mode 100644
index 6c5a3b6..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/constructors.js
+++ /dev/null
@@ -1,102 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.universal = exports.tag = exports.string = exports.selector = exports.root = exports.pseudo = exports.nesting = exports.id = exports.comment = exports.combinator = exports.className = exports.attribute = void 0;
-
-var _attribute = _interopRequireDefault(require("./attribute"));
-
-var _className = _interopRequireDefault(require("./className"));
-
-var _combinator = _interopRequireDefault(require("./combinator"));
-
-var _comment = _interopRequireDefault(require("./comment"));
-
-var _id = _interopRequireDefault(require("./id"));
-
-var _nesting = _interopRequireDefault(require("./nesting"));
-
-var _pseudo = _interopRequireDefault(require("./pseudo"));
-
-var _root = _interopRequireDefault(require("./root"));
-
-var _selector = _interopRequireDefault(require("./selector"));
-
-var _string = _interopRequireDefault(require("./string"));
-
-var _tag = _interopRequireDefault(require("./tag"));
-
-var _universal = _interopRequireDefault(require("./universal"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-var attribute = function attribute(opts) {
- return new _attribute.default(opts);
-};
-
-exports.attribute = attribute;
-
-var className = function className(opts) {
- return new _className.default(opts);
-};
-
-exports.className = className;
-
-var combinator = function combinator(opts) {
- return new _combinator.default(opts);
-};
-
-exports.combinator = combinator;
-
-var comment = function comment(opts) {
- return new _comment.default(opts);
-};
-
-exports.comment = comment;
-
-var id = function id(opts) {
- return new _id.default(opts);
-};
-
-exports.id = id;
-
-var nesting = function nesting(opts) {
- return new _nesting.default(opts);
-};
-
-exports.nesting = nesting;
-
-var pseudo = function pseudo(opts) {
- return new _pseudo.default(opts);
-};
-
-exports.pseudo = pseudo;
-
-var root = function root(opts) {
- return new _root.default(opts);
-};
-
-exports.root = root;
-
-var selector = function selector(opts) {
- return new _selector.default(opts);
-};
-
-exports.selector = selector;
-
-var string = function string(opts) {
- return new _string.default(opts);
-};
-
-exports.string = string;
-
-var tag = function tag(opts) {
- return new _tag.default(opts);
-};
-
-exports.tag = tag;
-
-var universal = function universal(opts) {
- return new _universal.default(opts);
-};
-
-exports.universal = universal; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/container.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/container.js
deleted file mode 100644
index 53b552d..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/container.js
+++ /dev/null
@@ -1,398 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _node = _interopRequireDefault(require("./node"));
-
-var types = _interopRequireWildcard(require("./types"));
-
-function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
-
-function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var Container =
-/*#__PURE__*/
-function (_Node) {
- _inheritsLoose(Container, _Node);
-
- function Container(opts) {
- var _this;
-
- _this = _Node.call(this, opts) || this;
-
- if (!_this.nodes) {
- _this.nodes = [];
- }
-
- return _this;
- }
-
- var _proto = Container.prototype;
-
- _proto.append = function append(selector) {
- selector.parent = this;
- this.nodes.push(selector);
- return this;
- };
-
- _proto.prepend = function prepend(selector) {
- selector.parent = this;
- this.nodes.unshift(selector);
- return this;
- };
-
- _proto.at = function at(index) {
- return this.nodes[index];
- };
-
- _proto.index = function index(child) {
- if (typeof child === 'number') {
- return child;
- }
-
- return this.nodes.indexOf(child);
- };
-
- _proto.removeChild = function removeChild(child) {
- child = this.index(child);
- this.at(child).parent = undefined;
- this.nodes.splice(child, 1);
- var index;
-
- for (var id in this.indexes) {
- index = this.indexes[id];
-
- if (index >= child) {
- this.indexes[id] = index - 1;
- }
- }
-
- return this;
- };
-
- _proto.removeAll = function removeAll() {
- for (var _iterator = this.nodes, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
- var _ref;
-
- if (_isArray) {
- if (_i >= _iterator.length) break;
- _ref = _iterator[_i++];
- } else {
- _i = _iterator.next();
- if (_i.done) break;
- _ref = _i.value;
- }
-
- var node = _ref;
- node.parent = undefined;
- }
-
- this.nodes = [];
- return this;
- };
-
- _proto.empty = function empty() {
- return this.removeAll();
- };
-
- _proto.insertAfter = function insertAfter(oldNode, newNode) {
- newNode.parent = this;
- var oldIndex = this.index(oldNode);
- this.nodes.splice(oldIndex + 1, 0, newNode);
- newNode.parent = this;
- var index;
-
- for (var id in this.indexes) {
- index = this.indexes[id];
-
- if (oldIndex <= index) {
- this.indexes[id] = index + 1;
- }
- }
-
- return this;
- };
-
- _proto.insertBefore = function insertBefore(oldNode, newNode) {
- newNode.parent = this;
- var oldIndex = this.index(oldNode);
- this.nodes.splice(oldIndex, 0, newNode);
- newNode.parent = this;
- var index;
-
- for (var id in this.indexes) {
- index = this.indexes[id];
-
- if (index <= oldIndex) {
- this.indexes[id] = index + 1;
- }
- }
-
- return this;
- };
-
- _proto._findChildAtPosition = function _findChildAtPosition(line, col) {
- var found = undefined;
- this.each(function (node) {
- if (node.atPosition) {
- var foundChild = node.atPosition(line, col);
-
- if (foundChild) {
- found = foundChild;
- return false;
- }
- } else if (node.isAtPosition(line, col)) {
- found = node;
- return false;
- }
- });
- return found;
- }
- /**
- * Return the most specific node at the line and column number given.
- * The source location is based on the original parsed location, locations aren't
- * updated as selector nodes are mutated.
- *
- * Note that this location is relative to the location of the first character
- * of the selector, and not the location of the selector in the overall document
- * when used in conjunction with postcss.
- *
- * If not found, returns undefined.
- * @param {number} line The line number of the node to find. (1-based index)
- * @param {number} col The column number of the node to find. (1-based index)
- */
- ;
-
- _proto.atPosition = function atPosition(line, col) {
- if (this.isAtPosition(line, col)) {
- return this._findChildAtPosition(line, col) || this;
- } else {
- return undefined;
- }
- };
-
- _proto._inferEndPosition = function _inferEndPosition() {
- if (this.last && this.last.source && this.last.source.end) {
- this.source = this.source || {};
- this.source.end = this.source.end || {};
- Object.assign(this.source.end, this.last.source.end);
- }
- };
-
- _proto.each = function each(callback) {
- if (!this.lastEach) {
- this.lastEach = 0;
- }
-
- if (!this.indexes) {
- this.indexes = {};
- }
-
- this.lastEach++;
- var id = this.lastEach;
- this.indexes[id] = 0;
-
- if (!this.length) {
- return undefined;
- }
-
- var index, result;
-
- while (this.indexes[id] < this.length) {
- index = this.indexes[id];
- result = callback(this.at(index), index);
-
- if (result === false) {
- break;
- }
-
- this.indexes[id] += 1;
- }
-
- delete this.indexes[id];
-
- if (result === false) {
- return false;
- }
- };
-
- _proto.walk = function walk(callback) {
- return this.each(function (node, i) {
- var result = callback(node, i);
-
- if (result !== false && node.length) {
- result = node.walk(callback);
- }
-
- if (result === false) {
- return false;
- }
- });
- };
-
- _proto.walkAttributes = function walkAttributes(callback) {
- var _this2 = this;
-
- return this.walk(function (selector) {
- if (selector.type === types.ATTRIBUTE) {
- return callback.call(_this2, selector);
- }
- });
- };
-
- _proto.walkClasses = function walkClasses(callback) {
- var _this3 = this;
-
- return this.walk(function (selector) {
- if (selector.type === types.CLASS) {
- return callback.call(_this3, selector);
- }
- });
- };
-
- _proto.walkCombinators = function walkCombinators(callback) {
- var _this4 = this;
-
- return this.walk(function (selector) {
- if (selector.type === types.COMBINATOR) {
- return callback.call(_this4, selector);
- }
- });
- };
-
- _proto.walkComments = function walkComments(callback) {
- var _this5 = this;
-
- return this.walk(function (selector) {
- if (selector.type === types.COMMENT) {
- return callback.call(_this5, selector);
- }
- });
- };
-
- _proto.walkIds = function walkIds(callback) {
- var _this6 = this;
-
- return this.walk(function (selector) {
- if (selector.type === types.ID) {
- return callback.call(_this6, selector);
- }
- });
- };
-
- _proto.walkNesting = function walkNesting(callback) {
- var _this7 = this;
-
- return this.walk(function (selector) {
- if (selector.type === types.NESTING) {
- return callback.call(_this7, selector);
- }
- });
- };
-
- _proto.walkPseudos = function walkPseudos(callback) {
- var _this8 = this;
-
- return this.walk(function (selector) {
- if (selector.type === types.PSEUDO) {
- return callback.call(_this8, selector);
- }
- });
- };
-
- _proto.walkTags = function walkTags(callback) {
- var _this9 = this;
-
- return this.walk(function (selector) {
- if (selector.type === types.TAG) {
- return callback.call(_this9, selector);
- }
- });
- };
-
- _proto.walkUniversals = function walkUniversals(callback) {
- var _this10 = this;
-
- return this.walk(function (selector) {
- if (selector.type === types.UNIVERSAL) {
- return callback.call(_this10, selector);
- }
- });
- };
-
- _proto.split = function split(callback) {
- var _this11 = this;
-
- var current = [];
- return this.reduce(function (memo, node, index) {
- var split = callback.call(_this11, node);
- current.push(node);
-
- if (split) {
- memo.push(current);
- current = [];
- } else if (index === _this11.length - 1) {
- memo.push(current);
- }
-
- return memo;
- }, []);
- };
-
- _proto.map = function map(callback) {
- return this.nodes.map(callback);
- };
-
- _proto.reduce = function reduce(callback, memo) {
- return this.nodes.reduce(callback, memo);
- };
-
- _proto.every = function every(callback) {
- return this.nodes.every(callback);
- };
-
- _proto.some = function some(callback) {
- return this.nodes.some(callback);
- };
-
- _proto.filter = function filter(callback) {
- return this.nodes.filter(callback);
- };
-
- _proto.sort = function sort(callback) {
- return this.nodes.sort(callback);
- };
-
- _proto.toString = function toString() {
- return this.map(String).join('');
- };
-
- _createClass(Container, [{
- key: "first",
- get: function get() {
- return this.at(0);
- }
- }, {
- key: "last",
- get: function get() {
- return this.at(this.length - 1);
- }
- }, {
- key: "length",
- get: function get() {
- return this.nodes.length;
- }
- }]);
-
- return Container;
-}(_node.default);
-
-exports.default = Container;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/guards.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/guards.js
deleted file mode 100644
index 8cf7bcf..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/guards.js
+++ /dev/null
@@ -1,64 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.isNode = isNode;
-exports.isPseudoElement = isPseudoElement;
-exports.isPseudoClass = isPseudoClass;
-exports.isContainer = isContainer;
-exports.isNamespace = isNamespace;
-exports.isUniversal = exports.isTag = exports.isString = exports.isSelector = exports.isRoot = exports.isPseudo = exports.isNesting = exports.isIdentifier = exports.isComment = exports.isCombinator = exports.isClassName = exports.isAttribute = void 0;
-
-var _types = require("./types");
-
-var _IS_TYPE;
-
-var IS_TYPE = (_IS_TYPE = {}, _IS_TYPE[_types.ATTRIBUTE] = true, _IS_TYPE[_types.CLASS] = true, _IS_TYPE[_types.COMBINATOR] = true, _IS_TYPE[_types.COMMENT] = true, _IS_TYPE[_types.ID] = true, _IS_TYPE[_types.NESTING] = true, _IS_TYPE[_types.PSEUDO] = true, _IS_TYPE[_types.ROOT] = true, _IS_TYPE[_types.SELECTOR] = true, _IS_TYPE[_types.STRING] = true, _IS_TYPE[_types.TAG] = true, _IS_TYPE[_types.UNIVERSAL] = true, _IS_TYPE);
-
-function isNode(node) {
- return typeof node === "object" && IS_TYPE[node.type];
-}
-
-function isNodeType(type, node) {
- return isNode(node) && node.type === type;
-}
-
-var isAttribute = isNodeType.bind(null, _types.ATTRIBUTE);
-exports.isAttribute = isAttribute;
-var isClassName = isNodeType.bind(null, _types.CLASS);
-exports.isClassName = isClassName;
-var isCombinator = isNodeType.bind(null, _types.COMBINATOR);
-exports.isCombinator = isCombinator;
-var isComment = isNodeType.bind(null, _types.COMMENT);
-exports.isComment = isComment;
-var isIdentifier = isNodeType.bind(null, _types.ID);
-exports.isIdentifier = isIdentifier;
-var isNesting = isNodeType.bind(null, _types.NESTING);
-exports.isNesting = isNesting;
-var isPseudo = isNodeType.bind(null, _types.PSEUDO);
-exports.isPseudo = isPseudo;
-var isRoot = isNodeType.bind(null, _types.ROOT);
-exports.isRoot = isRoot;
-var isSelector = isNodeType.bind(null, _types.SELECTOR);
-exports.isSelector = isSelector;
-var isString = isNodeType.bind(null, _types.STRING);
-exports.isString = isString;
-var isTag = isNodeType.bind(null, _types.TAG);
-exports.isTag = isTag;
-var isUniversal = isNodeType.bind(null, _types.UNIVERSAL);
-exports.isUniversal = isUniversal;
-
-function isPseudoElement(node) {
- return isPseudo(node) && node.value && (node.value.startsWith("::") || node.value === ":before" || node.value === ":after");
-}
-
-function isPseudoClass(node) {
- return isPseudo(node) && !isPseudoElement(node);
-}
-
-function isContainer(node) {
- return !!(isNode(node) && node.walk);
-}
-
-function isNamespace(node) {
- return isAttribute(node) || isTag(node);
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/id.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/id.js
deleted file mode 100644
index d93afad..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/id.js
+++ /dev/null
@@ -1,37 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _node = _interopRequireDefault(require("./node"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var ID =
-/*#__PURE__*/
-function (_Node) {
- _inheritsLoose(ID, _Node);
-
- function ID(opts) {
- var _this;
-
- _this = _Node.call(this, opts) || this;
- _this.type = _types.ID;
- return _this;
- }
-
- var _proto = ID.prototype;
-
- _proto.toString = function toString() {
- return [this.rawSpaceBefore, String('#' + this.stringifyProperty("value")), this.rawSpaceAfter].join('');
- };
-
- return ID;
-}(_node.default);
-
-exports.default = ID;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/index.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/index.js
deleted file mode 100644
index bc5bc37..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/index.js
+++ /dev/null
@@ -1,24 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-
-var _types = require("./types");
-
-Object.keys(_types).forEach(function (key) {
- if (key === "default" || key === "__esModule") return;
- exports[key] = _types[key];
-});
-
-var _constructors = require("./constructors");
-
-Object.keys(_constructors).forEach(function (key) {
- if (key === "default" || key === "__esModule") return;
- exports[key] = _constructors[key];
-});
-
-var _guards = require("./guards");
-
-Object.keys(_guards).forEach(function (key) {
- if (key === "default" || key === "__esModule") return;
- exports[key] = _guards[key];
-}); \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/namespace.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/namespace.js
deleted file mode 100644
index 6cc6a27..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/namespace.js
+++ /dev/null
@@ -1,101 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _cssesc = _interopRequireDefault(require("cssesc"));
-
-var _util = require("../util");
-
-var _node = _interopRequireDefault(require("./node"));
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
-
-function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var Namespace =
-/*#__PURE__*/
-function (_Node) {
- _inheritsLoose(Namespace, _Node);
-
- function Namespace() {
- return _Node.apply(this, arguments) || this;
- }
-
- var _proto = Namespace.prototype;
-
- _proto.qualifiedName = function qualifiedName(value) {
- if (this.namespace) {
- return this.namespaceString + "|" + value;
- } else {
- return value;
- }
- };
-
- _proto.toString = function toString() {
- return [this.rawSpaceBefore, this.qualifiedName(this.stringifyProperty("value")), this.rawSpaceAfter].join('');
- };
-
- _createClass(Namespace, [{
- key: "namespace",
- get: function get() {
- return this._namespace;
- },
- set: function set(namespace) {
- if (namespace === true || namespace === "*" || namespace === "&") {
- this._namespace = namespace;
-
- if (this.raws) {
- delete this.raws.namespace;
- }
-
- return;
- }
-
- var escaped = (0, _cssesc.default)(namespace, {
- isIdentifier: true
- });
- this._namespace = namespace;
-
- if (escaped !== namespace) {
- (0, _util.ensureObject)(this, "raws");
- this.raws.namespace = escaped;
- } else if (this.raws) {
- delete this.raws.namespace;
- }
- }
- }, {
- key: "ns",
- get: function get() {
- return this._namespace;
- },
- set: function set(namespace) {
- this.namespace = namespace;
- }
- }, {
- key: "namespaceString",
- get: function get() {
- if (this.namespace) {
- var ns = this.stringifyProperty("namespace");
-
- if (ns === true) {
- return '';
- } else {
- return ns;
- }
- } else {
- return '';
- }
- }
- }]);
-
- return Namespace;
-}(_node.default);
-
-exports.default = Namespace;
-;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/nesting.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/nesting.js
deleted file mode 100644
index 4cdfb10..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/nesting.js
+++ /dev/null
@@ -1,32 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _node = _interopRequireDefault(require("./node"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var Nesting =
-/*#__PURE__*/
-function (_Node) {
- _inheritsLoose(Nesting, _Node);
-
- function Nesting(opts) {
- var _this;
-
- _this = _Node.call(this, opts) || this;
- _this.type = _types.NESTING;
- _this.value = '&';
- return _this;
- }
-
- return Nesting;
-}(_node.default);
-
-exports.default = Nesting;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/node.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/node.js
deleted file mode 100644
index 9236311..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/node.js
+++ /dev/null
@@ -1,237 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _util = require("../util");
-
-function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
-
-function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
-
-var cloneNode = function cloneNode(obj, parent) {
- if (typeof obj !== 'object' || obj === null) {
- return obj;
- }
-
- var cloned = new obj.constructor();
-
- for (var i in obj) {
- if (!obj.hasOwnProperty(i)) {
- continue;
- }
-
- var value = obj[i];
- var type = typeof value;
-
- if (i === 'parent' && type === 'object') {
- if (parent) {
- cloned[i] = parent;
- }
- } else if (value instanceof Array) {
- cloned[i] = value.map(function (j) {
- return cloneNode(j, cloned);
- });
- } else {
- cloned[i] = cloneNode(value, cloned);
- }
- }
-
- return cloned;
-};
-
-var Node =
-/*#__PURE__*/
-function () {
- function Node(opts) {
- if (opts === void 0) {
- opts = {};
- }
-
- Object.assign(this, opts);
- this.spaces = this.spaces || {};
- this.spaces.before = this.spaces.before || '';
- this.spaces.after = this.spaces.after || '';
- }
-
- var _proto = Node.prototype;
-
- _proto.remove = function remove() {
- if (this.parent) {
- this.parent.removeChild(this);
- }
-
- this.parent = undefined;
- return this;
- };
-
- _proto.replaceWith = function replaceWith() {
- if (this.parent) {
- for (var index in arguments) {
- this.parent.insertBefore(this, arguments[index]);
- }
-
- this.remove();
- }
-
- return this;
- };
-
- _proto.next = function next() {
- return this.parent.at(this.parent.index(this) + 1);
- };
-
- _proto.prev = function prev() {
- return this.parent.at(this.parent.index(this) - 1);
- };
-
- _proto.clone = function clone(overrides) {
- if (overrides === void 0) {
- overrides = {};
- }
-
- var cloned = cloneNode(this);
-
- for (var name in overrides) {
- cloned[name] = overrides[name];
- }
-
- return cloned;
- }
- /**
- * Some non-standard syntax doesn't follow normal escaping rules for css.
- * This allows non standard syntax to be appended to an existing property
- * by specifying the escaped value. By specifying the escaped value,
- * illegal characters are allowed to be directly inserted into css output.
- * @param {string} name the property to set
- * @param {any} value the unescaped value of the property
- * @param {string} valueEscaped optional. the escaped value of the property.
- */
- ;
-
- _proto.appendToPropertyAndEscape = function appendToPropertyAndEscape(name, value, valueEscaped) {
- if (!this.raws) {
- this.raws = {};
- }
-
- var originalValue = this[name];
- var originalEscaped = this.raws[name];
- this[name] = originalValue + value; // this may trigger a setter that updates raws, so it has to be set first.
-
- if (originalEscaped || valueEscaped !== value) {
- this.raws[name] = (originalEscaped || originalValue) + valueEscaped;
- } else {
- delete this.raws[name]; // delete any escaped value that was created by the setter.
- }
- }
- /**
- * Some non-standard syntax doesn't follow normal escaping rules for css.
- * This allows the escaped value to be specified directly, allowing illegal
- * characters to be directly inserted into css output.
- * @param {string} name the property to set
- * @param {any} value the unescaped value of the property
- * @param {string} valueEscaped the escaped value of the property.
- */
- ;
-
- _proto.setPropertyAndEscape = function setPropertyAndEscape(name, value, valueEscaped) {
- if (!this.raws) {
- this.raws = {};
- }
-
- this[name] = value; // this may trigger a setter that updates raws, so it has to be set first.
-
- this.raws[name] = valueEscaped;
- }
- /**
- * When you want a value to passed through to CSS directly. This method
- * deletes the corresponding raw value causing the stringifier to fallback
- * to the unescaped value.
- * @param {string} name the property to set.
- * @param {any} value The value that is both escaped and unescaped.
- */
- ;
-
- _proto.setPropertyWithoutEscape = function setPropertyWithoutEscape(name, value) {
- this[name] = value; // this may trigger a setter that updates raws, so it has to be set first.
-
- if (this.raws) {
- delete this.raws[name];
- }
- }
- /**
- *
- * @param {number} line The number (starting with 1)
- * @param {number} column The column number (starting with 1)
- */
- ;
-
- _proto.isAtPosition = function isAtPosition(line, column) {
- if (this.source && this.source.start && this.source.end) {
- if (this.source.start.line > line) {
- return false;
- }
-
- if (this.source.end.line < line) {
- return false;
- }
-
- if (this.source.start.line === line && this.source.start.column > column) {
- return false;
- }
-
- if (this.source.end.line === line && this.source.end.column < column) {
- return false;
- }
-
- return true;
- }
-
- return undefined;
- };
-
- _proto.stringifyProperty = function stringifyProperty(name) {
- return this.raws && this.raws[name] || this[name];
- };
-
- _proto.toString = function toString() {
- return [this.rawSpaceBefore, String(this.stringifyProperty("value")), this.rawSpaceAfter].join('');
- };
-
- _createClass(Node, [{
- key: "rawSpaceBefore",
- get: function get() {
- var rawSpace = this.raws && this.raws.spaces && this.raws.spaces.before;
-
- if (rawSpace === undefined) {
- rawSpace = this.spaces && this.spaces.before;
- }
-
- return rawSpace || "";
- },
- set: function set(raw) {
- (0, _util.ensureObject)(this, "raws", "spaces");
- this.raws.spaces.before = raw;
- }
- }, {
- key: "rawSpaceAfter",
- get: function get() {
- var rawSpace = this.raws && this.raws.spaces && this.raws.spaces.after;
-
- if (rawSpace === undefined) {
- rawSpace = this.spaces.after;
- }
-
- return rawSpace || "";
- },
- set: function set(raw) {
- (0, _util.ensureObject)(this, "raws", "spaces");
- this.raws.spaces.after = raw;
- }
- }]);
-
- return Node;
-}();
-
-exports.default = Node;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/pseudo.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/pseudo.js
deleted file mode 100644
index 820338b..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/pseudo.js
+++ /dev/null
@@ -1,38 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _container = _interopRequireDefault(require("./container"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var Pseudo =
-/*#__PURE__*/
-function (_Container) {
- _inheritsLoose(Pseudo, _Container);
-
- function Pseudo(opts) {
- var _this;
-
- _this = _Container.call(this, opts) || this;
- _this.type = _types.PSEUDO;
- return _this;
- }
-
- var _proto = Pseudo.prototype;
-
- _proto.toString = function toString() {
- var params = this.length ? '(' + this.map(String).join(',') + ')' : '';
- return [this.rawSpaceBefore, this.stringifyProperty("value"), params, this.rawSpaceAfter].join('');
- };
-
- return Pseudo;
-}(_container.default);
-
-exports.default = Pseudo;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/root.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/root.js
deleted file mode 100644
index bbc619f..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/root.js
+++ /dev/null
@@ -1,60 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _container = _interopRequireDefault(require("./container"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
-
-function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var Root =
-/*#__PURE__*/
-function (_Container) {
- _inheritsLoose(Root, _Container);
-
- function Root(opts) {
- var _this;
-
- _this = _Container.call(this, opts) || this;
- _this.type = _types.ROOT;
- return _this;
- }
-
- var _proto = Root.prototype;
-
- _proto.toString = function toString() {
- var str = this.reduce(function (memo, selector) {
- memo.push(String(selector));
- return memo;
- }, []).join(',');
- return this.trailingComma ? str + ',' : str;
- };
-
- _proto.error = function error(message, options) {
- if (this._error) {
- return this._error(message, options);
- } else {
- return new Error(message);
- }
- };
-
- _createClass(Root, [{
- key: "errorGenerator",
- set: function set(handler) {
- this._error = handler;
- }
- }]);
-
- return Root;
-}(_container.default);
-
-exports.default = Root;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/selector.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/selector.js
deleted file mode 100644
index 618238b..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/selector.js
+++ /dev/null
@@ -1,31 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _container = _interopRequireDefault(require("./container"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var Selector =
-/*#__PURE__*/
-function (_Container) {
- _inheritsLoose(Selector, _Container);
-
- function Selector(opts) {
- var _this;
-
- _this = _Container.call(this, opts) || this;
- _this.type = _types.SELECTOR;
- return _this;
- }
-
- return Selector;
-}(_container.default);
-
-exports.default = Selector;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/string.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/string.js
deleted file mode 100644
index b8526fa..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/string.js
+++ /dev/null
@@ -1,31 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _node = _interopRequireDefault(require("./node"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var String =
-/*#__PURE__*/
-function (_Node) {
- _inheritsLoose(String, _Node);
-
- function String(opts) {
- var _this;
-
- _this = _Node.call(this, opts) || this;
- _this.type = _types.STRING;
- return _this;
- }
-
- return String;
-}(_node.default);
-
-exports.default = String;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/tag.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/tag.js
deleted file mode 100644
index 2d95176..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/tag.js
+++ /dev/null
@@ -1,31 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _namespace = _interopRequireDefault(require("./namespace"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var Tag =
-/*#__PURE__*/
-function (_Namespace) {
- _inheritsLoose(Tag, _Namespace);
-
- function Tag(opts) {
- var _this;
-
- _this = _Namespace.call(this, opts) || this;
- _this.type = _types.TAG;
- return _this;
- }
-
- return Tag;
-}(_namespace.default);
-
-exports.default = Tag;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/types.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/types.js
deleted file mode 100644
index ab897b8..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/types.js
+++ /dev/null
@@ -1,28 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.UNIVERSAL = exports.ATTRIBUTE = exports.CLASS = exports.COMBINATOR = exports.COMMENT = exports.ID = exports.NESTING = exports.PSEUDO = exports.ROOT = exports.SELECTOR = exports.STRING = exports.TAG = void 0;
-var TAG = 'tag';
-exports.TAG = TAG;
-var STRING = 'string';
-exports.STRING = STRING;
-var SELECTOR = 'selector';
-exports.SELECTOR = SELECTOR;
-var ROOT = 'root';
-exports.ROOT = ROOT;
-var PSEUDO = 'pseudo';
-exports.PSEUDO = PSEUDO;
-var NESTING = 'nesting';
-exports.NESTING = NESTING;
-var ID = 'id';
-exports.ID = ID;
-var COMMENT = 'comment';
-exports.COMMENT = COMMENT;
-var COMBINATOR = 'combinator';
-exports.COMBINATOR = COMBINATOR;
-var CLASS = 'class';
-exports.CLASS = CLASS;
-var ATTRIBUTE = 'attribute';
-exports.ATTRIBUTE = ATTRIBUTE;
-var UNIVERSAL = 'universal';
-exports.UNIVERSAL = UNIVERSAL; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/universal.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/universal.js
deleted file mode 100644
index c83905e..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/selectors/universal.js
+++ /dev/null
@@ -1,32 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = void 0;
-
-var _namespace = _interopRequireDefault(require("./namespace"));
-
-var _types = require("./types");
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
-function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
-
-var Universal =
-/*#__PURE__*/
-function (_Namespace) {
- _inheritsLoose(Universal, _Namespace);
-
- function Universal(opts) {
- var _this;
-
- _this = _Namespace.call(this, opts) || this;
- _this.type = _types.UNIVERSAL;
- _this.value = '*';
- return _this;
- }
-
- return Universal;
-}(_namespace.default);
-
-exports.default = Universal;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/sortAscending.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/sortAscending.js
deleted file mode 100644
index 7af2fec..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/sortAscending.js
+++ /dev/null
@@ -1,13 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = sortAscending;
-
-function sortAscending(list) {
- return list.sort(function (a, b) {
- return a - b;
- });
-}
-
-;
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/tokenTypes.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/tokenTypes.js
deleted file mode 100644
index 48314b9..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/tokenTypes.js
+++ /dev/null
@@ -1,95 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.combinator = exports.word = exports.comment = exports.str = exports.tab = exports.newline = exports.feed = exports.cr = exports.backslash = exports.bang = exports.slash = exports.doubleQuote = exports.singleQuote = exports.space = exports.greaterThan = exports.pipe = exports.equals = exports.plus = exports.caret = exports.tilde = exports.dollar = exports.closeSquare = exports.openSquare = exports.closeParenthesis = exports.openParenthesis = exports.semicolon = exports.colon = exports.comma = exports.at = exports.asterisk = exports.ampersand = void 0;
-var ampersand = 38; // `&`.charCodeAt(0);
-
-exports.ampersand = ampersand;
-var asterisk = 42; // `*`.charCodeAt(0);
-
-exports.asterisk = asterisk;
-var at = 64; // `@`.charCodeAt(0);
-
-exports.at = at;
-var comma = 44; // `,`.charCodeAt(0);
-
-exports.comma = comma;
-var colon = 58; // `:`.charCodeAt(0);
-
-exports.colon = colon;
-var semicolon = 59; // `;`.charCodeAt(0);
-
-exports.semicolon = semicolon;
-var openParenthesis = 40; // `(`.charCodeAt(0);
-
-exports.openParenthesis = openParenthesis;
-var closeParenthesis = 41; // `)`.charCodeAt(0);
-
-exports.closeParenthesis = closeParenthesis;
-var openSquare = 91; // `[`.charCodeAt(0);
-
-exports.openSquare = openSquare;
-var closeSquare = 93; // `]`.charCodeAt(0);
-
-exports.closeSquare = closeSquare;
-var dollar = 36; // `$`.charCodeAt(0);
-
-exports.dollar = dollar;
-var tilde = 126; // `~`.charCodeAt(0);
-
-exports.tilde = tilde;
-var caret = 94; // `^`.charCodeAt(0);
-
-exports.caret = caret;
-var plus = 43; // `+`.charCodeAt(0);
-
-exports.plus = plus;
-var equals = 61; // `=`.charCodeAt(0);
-
-exports.equals = equals;
-var pipe = 124; // `|`.charCodeAt(0);
-
-exports.pipe = pipe;
-var greaterThan = 62; // `>`.charCodeAt(0);
-
-exports.greaterThan = greaterThan;
-var space = 32; // ` `.charCodeAt(0);
-
-exports.space = space;
-var singleQuote = 39; // `'`.charCodeAt(0);
-
-exports.singleQuote = singleQuote;
-var doubleQuote = 34; // `"`.charCodeAt(0);
-
-exports.doubleQuote = doubleQuote;
-var slash = 47; // `/`.charCodeAt(0);
-
-exports.slash = slash;
-var bang = 33; // `!`.charCodeAt(0);
-
-exports.bang = bang;
-var backslash = 92; // '\\'.charCodeAt(0);
-
-exports.backslash = backslash;
-var cr = 13; // '\r'.charCodeAt(0);
-
-exports.cr = cr;
-var feed = 12; // '\f'.charCodeAt(0);
-
-exports.feed = feed;
-var newline = 10; // '\n'.charCodeAt(0);
-
-exports.newline = newline;
-var tab = 9; // '\t'.charCodeAt(0);
-// Expose aliases primarily for readability.
-
-exports.tab = tab;
-var str = singleQuote; // No good single character representation!
-
-exports.str = str;
-var comment = -1;
-exports.comment = comment;
-var word = -2;
-exports.word = word;
-var combinator = -3;
-exports.combinator = combinator; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/tokenize.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/tokenize.js
deleted file mode 100644
index e890e9c..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/tokenize.js
+++ /dev/null
@@ -1,268 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = tokenize;
-exports.FIELDS = void 0;
-
-var t = _interopRequireWildcard(require("./tokenTypes"));
-
-var _unescapable, _wordDelimiters;
-
-function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
-
-var unescapable = (_unescapable = {}, _unescapable[t.tab] = true, _unescapable[t.newline] = true, _unescapable[t.cr] = true, _unescapable[t.feed] = true, _unescapable);
-var wordDelimiters = (_wordDelimiters = {}, _wordDelimiters[t.space] = true, _wordDelimiters[t.tab] = true, _wordDelimiters[t.newline] = true, _wordDelimiters[t.cr] = true, _wordDelimiters[t.feed] = true, _wordDelimiters[t.ampersand] = true, _wordDelimiters[t.asterisk] = true, _wordDelimiters[t.bang] = true, _wordDelimiters[t.comma] = true, _wordDelimiters[t.colon] = true, _wordDelimiters[t.semicolon] = true, _wordDelimiters[t.openParenthesis] = true, _wordDelimiters[t.closeParenthesis] = true, _wordDelimiters[t.openSquare] = true, _wordDelimiters[t.closeSquare] = true, _wordDelimiters[t.singleQuote] = true, _wordDelimiters[t.doubleQuote] = true, _wordDelimiters[t.plus] = true, _wordDelimiters[t.pipe] = true, _wordDelimiters[t.tilde] = true, _wordDelimiters[t.greaterThan] = true, _wordDelimiters[t.equals] = true, _wordDelimiters[t.dollar] = true, _wordDelimiters[t.caret] = true, _wordDelimiters[t.slash] = true, _wordDelimiters);
-var hex = {};
-var hexChars = "0123456789abcdefABCDEF";
-
-for (var i = 0; i < hexChars.length; i++) {
- hex[hexChars.charCodeAt(i)] = true;
-}
-/**
- * Returns the last index of the bar css word
- * @param {string} css The string in which the word begins
- * @param {number} start The index into the string where word's first letter occurs
- */
-
-
-function consumeWord(css, start) {
- var next = start;
- var code;
-
- do {
- code = css.charCodeAt(next);
-
- if (wordDelimiters[code]) {
- return next - 1;
- } else if (code === t.backslash) {
- next = consumeEscape(css, next) + 1;
- } else {
- // All other characters are part of the word
- next++;
- }
- } while (next < css.length);
-
- return next - 1;
-}
-/**
- * Returns the last index of the escape sequence
- * @param {string} css The string in which the sequence begins
- * @param {number} start The index into the string where escape character (`\`) occurs.
- */
-
-
-function consumeEscape(css, start) {
- var next = start;
- var code = css.charCodeAt(next + 1);
-
- if (unescapable[code]) {// just consume the escape char
- } else if (hex[code]) {
- var hexDigits = 0; // consume up to 6 hex chars
-
- do {
- next++;
- hexDigits++;
- code = css.charCodeAt(next + 1);
- } while (hex[code] && hexDigits < 6); // if fewer than 6 hex chars, a trailing space ends the escape
-
-
- if (hexDigits < 6 && code === t.space) {
- next++;
- }
- } else {
- // the next char is part of the current word
- next++;
- }
-
- return next;
-}
-
-var FIELDS = {
- TYPE: 0,
- START_LINE: 1,
- START_COL: 2,
- END_LINE: 3,
- END_COL: 4,
- START_POS: 5,
- END_POS: 6
-};
-exports.FIELDS = FIELDS;
-
-function tokenize(input) {
- var tokens = [];
- var css = input.css.valueOf();
- var _css = css,
- length = _css.length;
- var offset = -1;
- var line = 1;
- var start = 0;
- var end = 0;
- var code, content, endColumn, endLine, escaped, escapePos, last, lines, next, nextLine, nextOffset, quote, tokenType;
-
- function unclosed(what, fix) {
- if (input.safe) {
- // fyi: this is never set to true.
- css += fix;
- next = css.length - 1;
- } else {
- throw input.error('Unclosed ' + what, line, start - offset, start);
- }
- }
-
- while (start < length) {
- code = css.charCodeAt(start);
-
- if (code === t.newline) {
- offset = start;
- line += 1;
- }
-
- switch (code) {
- case t.space:
- case t.tab:
- case t.newline:
- case t.cr:
- case t.feed:
- next = start;
-
- do {
- next += 1;
- code = css.charCodeAt(next);
-
- if (code === t.newline) {
- offset = next;
- line += 1;
- }
- } while (code === t.space || code === t.newline || code === t.tab || code === t.cr || code === t.feed);
-
- tokenType = t.space;
- endLine = line;
- endColumn = next - offset - 1;
- end = next;
- break;
-
- case t.plus:
- case t.greaterThan:
- case t.tilde:
- case t.pipe:
- next = start;
-
- do {
- next += 1;
- code = css.charCodeAt(next);
- } while (code === t.plus || code === t.greaterThan || code === t.tilde || code === t.pipe);
-
- tokenType = t.combinator;
- endLine = line;
- endColumn = start - offset;
- end = next;
- break;
- // Consume these characters as single tokens.
-
- case t.asterisk:
- case t.ampersand:
- case t.bang:
- case t.comma:
- case t.equals:
- case t.dollar:
- case t.caret:
- case t.openSquare:
- case t.closeSquare:
- case t.colon:
- case t.semicolon:
- case t.openParenthesis:
- case t.closeParenthesis:
- next = start;
- tokenType = code;
- endLine = line;
- endColumn = start - offset;
- end = next + 1;
- break;
-
- case t.singleQuote:
- case t.doubleQuote:
- quote = code === t.singleQuote ? "'" : '"';
- next = start;
-
- do {
- escaped = false;
- next = css.indexOf(quote, next + 1);
-
- if (next === -1) {
- unclosed('quote', quote);
- }
-
- escapePos = next;
-
- while (css.charCodeAt(escapePos - 1) === t.backslash) {
- escapePos -= 1;
- escaped = !escaped;
- }
- } while (escaped);
-
- tokenType = t.str;
- endLine = line;
- endColumn = start - offset;
- end = next + 1;
- break;
-
- default:
- if (code === t.slash && css.charCodeAt(start + 1) === t.asterisk) {
- next = css.indexOf('*/', start + 2) + 1;
-
- if (next === 0) {
- unclosed('comment', '*/');
- }
-
- content = css.slice(start, next + 1);
- lines = content.split('\n');
- last = lines.length - 1;
-
- if (last > 0) {
- nextLine = line + last;
- nextOffset = next - lines[last].length;
- } else {
- nextLine = line;
- nextOffset = offset;
- }
-
- tokenType = t.comment;
- line = nextLine;
- endLine = nextLine;
- endColumn = next - nextOffset;
- } else if (code === t.slash) {
- next = start;
- tokenType = code;
- endLine = line;
- endColumn = start - offset;
- end = next + 1;
- } else {
- next = consumeWord(css, start);
- tokenType = t.word;
- endLine = line;
- endColumn = next - offset;
- }
-
- end = next + 1;
- break;
- } // Ensure that the token structure remains consistent
-
-
- tokens.push([tokenType, // [0] Token type
- line, // [1] Starting line
- start - offset, // [2] Starting column
- endLine, // [3] Ending line
- endColumn, // [4] Ending column
- start, // [5] Start position / Source index
- end]); // Reset offset for the next token
-
- if (nextOffset) {
- offset = nextOffset;
- nextOffset = null;
- }
-
- start = end;
- }
-
- return tokens;
-} \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/ensureObject.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/ensureObject.js
deleted file mode 100644
index 548b107..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/ensureObject.js
+++ /dev/null
@@ -1,22 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = ensureObject;
-
-function ensureObject(obj) {
- for (var _len = arguments.length, props = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
- props[_key - 1] = arguments[_key];
- }
-
- while (props.length > 0) {
- var prop = props.shift();
-
- if (!obj[prop]) {
- obj[prop] = {};
- }
-
- obj = obj[prop];
- }
-}
-
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/getProp.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/getProp.js
deleted file mode 100644
index fd44505..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/getProp.js
+++ /dev/null
@@ -1,24 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = getProp;
-
-function getProp(obj) {
- for (var _len = arguments.length, props = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
- props[_key - 1] = arguments[_key];
- }
-
- while (props.length > 0) {
- var prop = props.shift();
-
- if (!obj[prop]) {
- return undefined;
- }
-
- obj = obj[prop];
- }
-
- return obj;
-}
-
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/index.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/index.js
deleted file mode 100644
index d7a37bd..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/index.js
+++ /dev/null
@@ -1,22 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.stripComments = exports.ensureObject = exports.getProp = exports.unesc = void 0;
-
-var _unesc = _interopRequireDefault(require("./unesc"));
-
-exports.unesc = _unesc.default;
-
-var _getProp = _interopRequireDefault(require("./getProp"));
-
-exports.getProp = _getProp.default;
-
-var _ensureObject = _interopRequireDefault(require("./ensureObject"));
-
-exports.ensureObject = _ensureObject.default;
-
-var _stripComments = _interopRequireDefault(require("./stripComments"));
-
-exports.stripComments = _stripComments.default;
-
-function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/stripComments.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/stripComments.js
deleted file mode 100644
index 7f4defe..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/stripComments.js
+++ /dev/null
@@ -1,27 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = stripComments;
-
-function stripComments(str) {
- var s = "";
- var commentStart = str.indexOf("/*");
- var lastEnd = 0;
-
- while (commentStart >= 0) {
- s = s + str.slice(lastEnd, commentStart);
- var commentEnd = str.indexOf("*/", commentStart + 2);
-
- if (commentEnd < 0) {
- return s;
- }
-
- lastEnd = commentEnd + 2;
- commentStart = str.indexOf("/*", lastEnd);
- }
-
- s = s + str.slice(lastEnd);
- return s;
-}
-
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/unesc.js b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/unesc.js
deleted file mode 100644
index ae12869..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/dist/util/unesc.js
+++ /dev/null
@@ -1,20 +0,0 @@
-"use strict";
-
-exports.__esModule = true;
-exports.default = unesc;
-var whitespace = '[\\x20\\t\\r\\n\\f]';
-var unescapeRegExp = new RegExp('\\\\([\\da-f]{1,6}' + whitespace + '?|(' + whitespace + ')|.)', 'ig');
-
-function unesc(str) {
- return str.replace(unescapeRegExp, function (_, escaped, escapedWhitespace) {
- var high = '0x' + escaped - 0x10000; // NaN means non-codepoint
- // Workaround erroneous numeric interpretation of +"0x"
- // eslint-disable-next-line no-self-compare
-
- return high !== high || escapedWhitespace ? escaped : high < 0 ? // BMP codepoint
- String.fromCharCode(high + 0x10000) : // Supplemental Plane codepoint (surrogate pair)
- String.fromCharCode(high >> 10 | 0xd800, high & 0x3ff | 0xdc00);
- });
-}
-
-module.exports = exports.default; \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/node_modules/.bin/cssesc b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/node_modules/.bin/cssesc
deleted file mode 120000
index eeeb3a5..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/node_modules/.bin/cssesc
+++ /dev/null
@@ -1 +0,0 @@
-../../../../../cssesc/bin/cssesc \ No newline at end of file
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/package.json b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/package.json
deleted file mode 100644
index 6a17320..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/package.json
+++ /dev/null
@@ -1,76 +0,0 @@
-{
- "name": "postcss-selector-parser",
- "version": "6.0.2",
- "devDependencies": {
- "@babel/cli": "^7.2.3",
- "@babel/core": "^7.3.4",
- "@babel/plugin-proposal-class-properties": "^7.3.4",
- "@babel/preset-env": "^7.3.4",
- "@babel/register": "^7.0.0",
- "ava": "^1.3.1",
- "babel-eslint": "^10.0.1",
- "babel-plugin-add-module-exports": "^1.0.0",
- "coveralls": "^3.0.3",
- "del-cli": "^1.1.0",
- "eslint": "^5.15.1",
- "eslint-plugin-babel": "^5.3.0",
- "eslint-plugin-import": "^2.16.0",
- "glob": "^7.1.3",
- "minimist": "^1.2.0",
- "nyc": "^13.3.0",
- "postcss": "^7.0.14",
- "semver": "^5.6.0"
- },
- "main": "dist/index.js",
- "types": "postcss-selector-parser.d.ts",
- "files": [
- "API.md",
- "CHANGELOG.md",
- "LICENSE-MIT",
- "dist",
- "postcss-selector-parser.d.ts"
- ],
- "scripts": {
- "pretest": "eslint src",
- "prepare": "del-cli dist && BABEL_ENV=publish babel src --out-dir dist --ignore /__tests__/",
- "lintfix": "eslint --fix src",
- "report": "nyc report --reporter=html",
- "test": "nyc ava src/__tests__/*.js",
- "testone": "ava"
- },
- "dependencies": {
- "cssesc": "^3.0.0",
- "indexes-of": "^1.0.1",
- "uniq": "^1.0.1"
- },
- "license": "MIT",
- "engines": {
- "node": ">=4"
- },
- "homepage": "https://github.com/postcss/postcss-selector-parser",
- "contributors": [
- {
- "name": "Ben Briggs",
- "email": "beneb.info@gmail.com",
- "url": "http://beneb.info"
- },
- {
- "name": "Chris Eppstein",
- "email": "chris@eppsteins.net",
- "url": "http://twitter.com/chriseppstein"
- }
- ],
- "repository": "postcss/postcss-selector-parser",
- "ava": {
- "require": [
- "@babel/register"
- ],
- "concurrency": 5
- },
- "nyc": {
- "exclude": [
- "node_modules",
- "**/__tests__"
- ]
- }
-}
diff --git a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/postcss-selector-parser.d.ts b/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/postcss-selector-parser.d.ts
deleted file mode 100644
index 52bdb77..0000000
--- a/assets/node_modules/stylelint-scss/node_modules/postcss-selector-parser/postcss-selector-parser.d.ts
+++ /dev/null
@@ -1,499 +0,0 @@
-// Type definitions for postcss-selector-parser 2.2.3
-// Definitions by: Chris Eppstein <chris@eppsteins.net>
-
-/*~ Note that ES6 modules cannot directly export callable functions.
- *~ This file should be imported using the CommonJS-style:
- *~ import x = require('someLibrary');
- *~
- *~ Refer to the documentation to understand common
- *~ workarounds for this limitation of ES6 modules.
- */
-
-/*~ This declaration specifies that the function
- *~ is the exported object from the file
- */
-export = parser;
-
-// TODO: Conditional types in TS 1.8 will really clean this up.
-declare function parser(): parser.Processor<never>;
-declare function parser<Transform>(processor: parser.AsyncProcessor<Transform>): parser.Processor<Transform, never>;
-declare function parser(processor: parser.AsyncProcessor<void>): parser.Processor<never, never>;
-declare function parser<Transform>(processor: parser.SyncProcessor<Transform>): parser.Processor<Transform>;
-declare function parser(processor: parser.SyncProcessor<void>): parser.Processor<never>;
-declare function parser<Transform>(processor?: parser.SyncProcessor<Transform> | parser.AsyncProcessor<Transform>): parser.Processor<Transform>;
-
-/*~ If you want to expose types from your module as well, you can
- *~ place them in this block. Often you will want to describe the
- *~ shape of the return type of the function; that type should
- *~ be declared in here, as this example shows.
- */
-declare namespace parser {
- /* copied from postcss -- so we don't need to add a dependency */
- type ErrorOptions = {
- plugin?: string;
- word?: string;
- index?: number
- };
- /* the bits we use of postcss.Rule, copied from postcss -- so we don't need to add a dependency */
- type PostCSSRuleNode = {
- selector: string
- /**
- * @returns postcss.CssSyntaxError but it's a complex object, caller
- * should cast to it if they have a dependency on postcss.
- */
- error(message: string, options?: ErrorOptions): Error;
- };
- /** Accepts a string */
- type Selectors = string | PostCSSRuleNode
- type ProcessorFn<ReturnType = void> = (root: parser.Root) => ReturnType;
- type SyncProcessor<Transform = void> = ProcessorFn<Transform>;
- type AsyncProcessor<Transform = void> = ProcessorFn<PromiseLike<Transform>>;
-
- const TAG: "tag";
- const STRING: "string";
- const SELECTOR: "selector";
- const ROOT: "root";
- const PSEUDO: "pseudo";
- const NESTING: "nesting";
- const ID: "id";
- const COMMENT: "comment";
- const COMBINATOR: "combinator";
- const CLASS: "class";
- const ATTRIBUTE: "attribute";
- const UNIVERSAL: "universal";
-
- interface NodeTypes {
- tag: Tag,
- string: String,
- selector: Selector,
- root: Root,
- pseudo: Pseudo,
- nesting: Nesting,
- id: Identifier,
- comment: Comment,
- combinator: Combinator,
- class: ClassName,
- attribute: Attribute,
- universal: Universal
- }
-
- type Node = NodeTypes[keyof NodeTypes];
-
- function isNode(node: any): node is Node;
-
- interface Options {
- /**
- * Preserve whitespace when true. Default: false;
- */
- lossless: boolean;
- /**
- * When true and a postcss.Rule is passed, set the result of
- * processing back onto the rule when done. Default: false.
- */
- updateSelector: boolean;
- }
- class Processor<
- TransformType = never,
- SyncSelectorsType extends Selectors | never = Selectors
- > {
- res: Root;
- readonly result: String;
- ast(selectors: Selectors, options?: Partial<Options>): Promise<Root>;
- astSync(selectors: SyncSelectorsType, options?: Partial<Options>): Root;
- transform(selectors: Selectors, options?: Partial<Options>): Promise<TransformType>;
- transformSync(selectors: SyncSelectorsType, options?: Partial<Options>): TransformType;
- process(selectors: Selectors, options?: Partial<Options>): Promise<string>;
- processSync(selectors: SyncSelectorsType, options?: Partial<Options>): string;
- }
- interface ParserOptions {
- css: string;
- error: (message: string, options: ErrorOptions) => Error;
- options: Options;
- }
- class Parser {
- input: ParserOptions;
- lossy: boolean;
- position: number;
- root: Root;
- selectors: string;
- current: Selector;
- constructor(input: ParserOptions);
- /**
- * Raises an error, if the processor is invoked on
- * a postcss Rule node, a better error message is raised.
- */
- error(message: string, options?: ErrorOptions): void;
- }
- interface NodeSource {
- start?: {
- line: number,
- column: number
- },
- end?: {
- line: number,
- column: number
- }
- }
- interface SpaceAround {
- before: string;
- after: string;
- }
- interface Spaces extends SpaceAround {
- [spaceType: string]: string | Partial<SpaceAround> | undefined;
- }
- interface NodeOptions<Value = string> {
- value: Value;
- spaces?: Partial<Spaces>;
- source?: NodeSource;
- sourceIndex?: number;
- }
- interface Base<
- Value extends string | undefined = string,
- ParentType extends Container | undefined = Container | undefined
- > {
- type: keyof NodeTypes;
- parent: ParentType;
- value: Value;
- spaces: Spaces;
- source?: NodeSource;
- sourceIndex: number;
- rawSpaceBefore: string;
- rawSpaceAfter: string;
- remove(): Node;
- replaceWith(...nodes: Node[]): Node;
- next(): Node;
- prev(): Node;
- clone(opts: {[override: string]:any}): Node;
- /**
- * Return whether this node includes the character at the position of the given line and column.
- * Returns undefined if the nodes lack sufficient source metadata to determine the position.
- * @param line 1-index based line number relative to the start of the selector.
- * @param column 1-index based column number relative to the start of the selector.
- */
- isAtPosition(line: number, column: number): boolean | undefined;
- /**
- * Some non-standard syntax doesn't follow normal escaping rules for css,
- * this allows the escaped value to be specified directly, allowing illegal characters to be
- * directly inserted into css output.
- * @param name the property to set
- * @param value the unescaped value of the property
- * @param valueEscaped optional. the escaped value of the property.
- */
- setPropertyAndEscape(name: string, value: any, valueEscaped: string): void;
- /**
- * When you want a value to passed through to CSS directly. This method
- * deletes the corresponding raw value causing the stringifier to fallback
- * to the unescaped value.
- * @param name the property to set.
- * @param value The value that is both escaped and unescaped.
- */
- setPropertyWithoutEscape(name: string, value: any): void;
- /**
- * Some non-standard syntax doesn't follow normal escaping rules for css.
- * This allows non standard syntax to be appended to an existing property
- * by specifying the escaped value. By specifying the escaped value,
- * illegal characters are allowed to be directly inserted into css output.
- * @param {string} name the property to set
- * @param {any} value the unescaped value of the property
- * @param {string} valueEscaped optional. the escaped value of the property.
- */
- appendToPropertyAndEscape(name: string, value: any, valueEscaped: string): void;
- toString(): string;
- }
- interface ContainerOptions extends NodeOptions {
- nodes?: Array<Node>;
- }
- interface Container<Value extends string | undefined = string> extends Base<Value> {
- nodes: Array<Node>;
- append(selector: Selector): Container;
- prepend(selector: Selector): Container;
- at(index: number): Node;
- /**
- * Return the most specific node at the line and column number given.
- * The source location is based on the original parsed location, locations aren't
- * updated as selector nodes are mutated.
- *
- * Note that this location is relative to the location of the first character
- * of the selector, and not the location of the selector in the overall document
- * when used in conjunction with postcss.
- *
- * If not found, returns undefined.
- * @param line The line number of the node to find. (1-based index)
- * @param col The column number of the node to find. (1-based index)
- */
- atPosition(line: number, column: number): Node;
- index(child: Node): number;
- readonly first: Node;
- readonly last: Node;
- readonly length: number;
- removeChild(child: Node): Container;
- removeAll(): Container;
- empty(): Container;
- insertAfter(oldNode: Node, newNode: Node): Container;
- insertBefore(oldNode: Node, newNode: Node): Container;
- each(callback: (node: Node) => boolean | void): boolean | undefined;
- walk(callback: (node: Node) => boolean | void): boolean | undefined;
- walkAttributes(callback: (node: Node) => boolean | void): boolean | undefined;
- walkClasses(callback: (node: Node) => boolean | void): boolean | undefined;
- walkCombinators(callback: (node: Node) => boolean | void): boolean | undefined;
- walkComments(callback: (node: Node) => boolean | void): boolean | undefined;
- walkIds(callback: (node: Node) => boolean | void): boolean | undefined;
- walkNesting(callback: (node: Node) => boolean | void): boolean | undefined;
- walkPseudos(callback: (node: Node) => boolean | void): boolean | undefined;
- walkTags(callback: (node: Node) => boolean | void): boolean | undefined;
- split(callback: (node: Node) => boolean): [Node[], Node[]];
- map(callback: (node: Node) => Node): Node[];
- reduce<T>(callback: (node: Node) => Node, memo: T): T;
- every(callback: (node: Node) => boolean): boolean;
- some(callback: (node: Node) => boolean): boolean;
- filter(callback: (node: Node) => boolean): Node[];
- sort(callback: (nodeA: Node, nodeB: Node) => number): Node[];
- toString(): string;
- }
- function isContainer(node: any): node is Root | Selector | Pseudo;
-
- interface NamespaceOptions<Value extends string | undefined = string> extends NodeOptions<Value> {
- namespace?: string | true;
- }
- interface Namespace<Value extends string | undefined = string> extends Base<Value> {
- /** alias for namespace */
- ns: string | true;
- /**
- * namespace prefix.
- */
- namespace: string | true;
- /**
- * If a namespace exists, prefix the value provided with it, separated by |.
- */
- qualifiedName(value: string): string;
- /**
- * A string representing the namespace suitable for output.
- */
- readonly namespaceString: string;
- }
- function isNamespace(node: any): node is Attribute | Tag;
-
- interface Root extends Container<undefined> {
- type: "root";
- /**
- * Raises an error, if the processor is invoked on
- * a postcss Rule node, a better error message is raised.
- */
- error(message: string, options?: ErrorOptions): Error;
- nodeAt(line: number, column: number): Node
- }
- function root(opts: ContainerOptions): Root;
- function isRoot(node: any): node is Root;
-
- interface Selector extends Container {
- type: "selector";
- }
- function selector(opts: ContainerOptions): Selector;
- function isSelector(node: any): node is Selector;
-
- interface Combinator extends Base {
- type: "combinator"
- }
- function combinator(opts: NodeOptions): Combinator;
- function isCombinator(node: any): node is Combinator;
-
- interface ClassName extends Base {
- type: "class";
- }
- function className(opts: NamespaceOptions): ClassName;
- function isClassName(node: any): node is ClassName;
-
- type AttributeOperator = "=" | "~=" | "|=" | "^=" | "$=" | "*=";
- type QuoteMark = '"' | "'" | null;
- interface PreferredQuoteMarkOptions {
- quoteMark?: QuoteMark;
- preferCurrentQuoteMark?: boolean;
- }
- interface SmartQuoteMarkOptions extends PreferredQuoteMarkOptions {
- smart?: boolean;
- }
- interface AttributeOptions extends NamespaceOptions<string | undefined> {
- attribute: string;
- operator?: AttributeOperator;
- insensitive?: boolean;
- quoteMark?: QuoteMark;
- /** @deprecated Use quoteMark instead. */
- quoted?: boolean;
- spaces?: {
- before?: string;
- after?: string;
- attribute?: Partial<SpaceAround>;
- operator?: Partial<SpaceAround>;
- value?: Partial<SpaceAround>;
- insensitive?: Partial<SpaceAround>;
- }
- raws: {
- unquoted?: string;
- attribute?: string;
- operator?: string;
- value?: string;
- insensitive?: string;
- spaces?: {
- attribute?: Partial<Spaces>;
- operator?: Partial<Spaces>;
- value?: Partial<Spaces>;
- insensitive?: Partial<Spaces>;
- }
- };
- }
- interface Attribute extends Namespace<string | undefined> {
- type: "attribute";
- attribute: string;
- operator?: AttributeOperator;
- insensitive?: boolean;
- quoteMark: QuoteMark;
- quoted?: boolean;
- spaces: {
- before: string;
- after: string;
- attribute?: Partial<Spaces>;
- operator?: Partial<Spaces>;
- value?: Partial<Spaces>;
- insensitive?: Partial<Spaces>;
- }
- raws: {
- /** @deprecated The attribute value is unquoted, use that instead.. */
- unquoted?: string;
- attribute?: string;
- operator?: string;
- /** The value of the attribute with quotes and escapes. */
- value?: string;
- insensitive?: string;
- spaces?: {
- attribute?: Partial<Spaces>;
- operator?: Partial<Spaces>;
- value?: Partial<Spaces>;
- insensitive?: Partial<Spaces>;
- }
- };
- /**
- * The attribute name after having been qualified with a namespace.
- */
- readonly qualifiedAttribute: string;
-
- /**
- * The case insensitivity flag or an empty string depending on whether this
- * attribute is case insensitive.
- */
- readonly insensitiveFlag : 'i' | '';
-
- /**
- * Returns the attribute's value quoted such that it would be legal to use
- * in the value of a css file. The original value's quotation setting
- * used for stringification is left unchanged. See `setValue(value, options)`
- * if you want to control the quote settings of a new value for the attribute or
- * `set quoteMark(mark)` if you want to change the quote settings of the current
- * value.
- *
- * You can also change the quotation used for the current value by setting quoteMark.
- **/
- getQuotedValue(options?: SmartQuoteMarkOptions): string;
-
- /**
- * Set the unescaped value with the specified quotation options. The value
- * provided must not include any wrapping quote marks -- those quotes will
- * be interpreted as part of the value and escaped accordingly.
- * @param value
- */
- setValue(value: string, options?: SmartQuoteMarkOptions): void;
-
- /**
- * Intelligently select a quoteMark value based on the value's contents. If
- * the value is a legal CSS ident, it will not be quoted. Otherwise a quote
- * mark will be picked that minimizes the number of escapes.
- *
- * If there's no clear winner, the quote mark from these options is used,
- * then the source quote mark (this is inverted if `preferCurrentQuoteMark` is
- * true). If the quoteMark is unspecified, a double quote is used.
- **/
- smartQuoteMark(options: PreferredQuoteMarkOptions): QuoteMark;
-
- /**
- * Selects the preferred quote mark based on the options and the current quote mark value.
- * If you want the quote mark to depend on the attribute value, call `smartQuoteMark(opts)`
- * instead.
- */
- preferredQuoteMark(options: PreferredQuoteMarkOptions): QuoteMark
-
- /**
- * returns the offset of the attribute part specified relative to the
- * start of the node of the output string.
- *
- * * "ns" - alias for "namespace"
- * * "namespace" - the namespace if it exists.
- * * "attribute" - the attribute name
- * * "attributeNS" - the start of the attribute or its namespace
- * * "operator" - the match operator of the attribute
- * * "value" - The value (string or identifier)
- * * "insensitive" - the case insensitivity flag;
- * @param part One of the possible values inside an attribute.
- * @returns -1 if the name is invalid or the value doesn't exist in this attribute.
- */
- offsetOf(part: "ns" | "namespace" | "attribute" | "attributeNS" | "operator" | "value" | "insensitive"): number;
- }
- function attribute(opts: AttributeOptions): Attribute;
- function isAttribute(node: any): node is Attribute;
-
- interface Pseudo extends Container {
- type: "pseudo";
- }
- function pseudo(opts: ContainerOptions): Pseudo;
- /**
- * Checks wether the node is the Psuedo subtype of node.
- */
- function isPseudo(node: any): node is Pseudo;
-
- /**
- * Checks wether the node is, specifically, a pseudo element instead of
- * pseudo class.
- */
- function isPseudoElement(node: any): node is Pseudo;
-
- /**
- * Checks wether the node is, specifically, a pseudo class instead of
- * pseudo element.
- */
- function isPseudoClass(node: any): node is Pseudo;
-
-
- interface Tag extends Namespace {
- type: "tag";
- }
- function tag(opts: NamespaceOptions): Tag;
- function isTag(node: any): node is Tag;
-
- interface Comment extends Base {
- type: "comment";
- }
- function comment(opts: NodeOptions): Comment;
- function isComment(node: any): node is Comment;
-
- interface Identifier extends Base {
- type: "id";
- }
- function id(opts: any): any;
- function isIdentifier(node: any): node is Identifier;
-
- interface Nesting extends Base {
- type: "nesting";
- }
- function nesting(opts: any): any;
- function isNesting(node: any): node is Nesting;
-
- interface String extends Base {
- type: "string";
- }
- function string(opts: NodeOptions): String;
- function isString(node: any): node is String;
-
- interface Universal extends Base {
- type: "universal";
- }
- function universal(opts?: NamespaceOptions): any;
- function isUniversal(node: any): node is Universal;
-}
diff --git a/assets/node_modules/stylelint-scss/package.json b/assets/node_modules/stylelint-scss/package.json
deleted file mode 100644
index 7f48fd1..0000000
--- a/assets/node_modules/stylelint-scss/package.json
+++ /dev/null
@@ -1,180 +0,0 @@
-{
- "name": "stylelint-scss",
- "description": "A collection of SCSS specific rules for stylelint",
- "version": "3.14.2",
- "author": "Krister Kari",
- "babel": {
- "presets": [
- "@babel/env"
- ]
- },
- "bugs": {
- "url": "https://github.com/kristerkari/stylelint-scss/issues"
- },
- "dependencies": {
- "lodash": "^4.17.15",
- "postcss-media-query-parser": "^0.2.3",
- "postcss-resolve-nested-selector": "^0.1.1",
- "postcss-selector-parser": "^6.0.2",
- "postcss-value-parser": "^4.0.2"
- },
- "devDependencies": {
- "@babel/cli": "^7.8.3",
- "@babel/core": "^7.8.3",
- "@babel/preset-env": "^7.8.3",
- "babel-plugin-istanbul": "^6.0.0",
- "babel-preset-jest": "^25.1.0",
- "eslint": "^6.8.0",
- "eslint-config-stylelint": "^11.1.0",
- "eslint-plugin-lodash": "^6.0.0",
- "github-contributors-list": "^1.2.4",
- "husky": "^4.2.0",
- "jest": "^25.1.0",
- "jest-cli": "^25.1.0",
- "lint-staged": "^10.0.2",
- "npmpub": "^5.0.0",
- "postcss": "^7.0.26",
- "postcss-scss": "^2.0.0",
- "prettier": "^1.19.1",
- "rimraf": "^3.0.0",
- "stylelint": "^13.0.0"
- },
- "peerDependencies": {
- "stylelint": "^8.0.0 || ^9.0.0 || ^10.0.0 || ^11.0.0 || ^12.0.0 || ^13.0.0"
- },
- "engines": {
- "node": ">=8"
- },
- "eslintConfig": {
- "extends": [
- "eslint:recommended",
- "stylelint"
- ],
- "parserOptions": {
- "sourceType": "module",
- "ecmaVersion": 6
- },
- "env": {
- "es6": true,
- "jest": true,
- "node": true
- },
- "plugins": [
- "lodash"
- ],
- "globals": {
- "testRule": true
- },
- "rules": {
- "eqeqeq": "error",
- "no-use-before-define": [
- "error",
- "nofunc"
- ],
- "sort-requires/sort-requires": "error",
- "strict": [
- "error",
- "global"
- ],
- "arrow-spacing": "error",
- "no-var": "error",
- "object-shorthand": "error",
- "prefer-const": "error",
- "template-curly-spacing": "error",
- "lodash/callback-binding": "error",
- "lodash/collection-method-value": "error",
- "lodash/collection-return": "error",
- "lodash/no-double-unwrap": "error",
- "lodash/no-extra-args": "error",
- "lodash/no-unbound-this": "error",
- "lodash/unwrap": "error",
- "lodash/preferred-alias": "error",
- "node/no-unsupported-features/es-syntax": [
- "error",
- {
- "version": ">=8.0.0",
- "ignores": [
- "modules"
- ]
- }
- ]
- }
- },
- "files": [
- "dist",
- "docs",
- "src/**/README.md",
- "!**/__tests__"
- ],
- "homepage": "https://github.com/kristerkari/stylelint-scss#readme",
- "keywords": [
- "css",
- "csslint",
- "lint",
- "linter",
- "stylelint",
- "stylelint-plugin"
- ],
- "license": "MIT",
- "main": "dist/index.js",
- "repository": {
- "type": "git",
- "url": "git+https://github.com/kristerkari/stylelint-scss.git"
- },
- "jest": {
- "clearMocks": true,
- "collectCoverage": false,
- "collectCoverageFrom": [
- "src/**/*.js",
- "!src/testUtils/*.js"
- ],
- "coverageDirectory": "./.coverage/",
- "coverageReporters": [
- "lcov",
- "text"
- ],
- "coverageThreshold": {
- "global": {
- "branches": 75,
- "functions": 75,
- "lines": 75,
- "statements": 75
- }
- },
- "setupFiles": [
- "./jest-setup.js"
- ],
- "testEnvironment": "node",
- "roots": [
- "src"
- ],
- "testRegex": ".*\\.test\\.js$|src/.*/__tests__/.*\\.js$",
- "transform": {
- "^.+\\.jsx?$": "./babel-jest.js"
- }
- },
- "scripts": {
- "prebuild": "rimraf dist",
- "build": "babel src --out-dir dist",
- "lint": "eslint . --ignore-path .gitignore",
- "prettify": "prettier --write \"src/**/*.js\"",
- "prepublishOnly": "npm run build",
- "pretest": "npm run lint",
- "release": "npmpub",
- "jest": "jest",
- "test": "npm run jest -- --coverage",
- "watch": "npm run jest -- --watch",
- "test-rule": "npm run jest",
- "test-util": "npm run jest"
- },
- "lint-staged": {
- "**/*.{js,json}": [
- "prettier --write"
- ]
- },
- "husky": {
- "hooks": {
- "pre-commit": "lint-staged"
- }
- }
-}
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-each-key-value-single-line/README.md b/assets/node_modules/stylelint-scss/src/rules/at-each-key-value-single-line/README.md
deleted file mode 100644
index 0483d27..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-each-key-value-single-line/README.md
+++ /dev/null
@@ -1,67 +0,0 @@
-# at-each-key-value-single-line
-
-This is a rule that checks for situations where users have:
-
-- Done a loop using map-keys
-- Grabbed the value for that key inside of the loop.
-
-```scss
-$font-weights: (
- "regular": 400,
- "medium": 500,
- "bold": 700
-);
-@each $key in map-keys($font-weights) {
- $value: map-get($font-weights, $key);
- /** ↑
- * This call should be consolidated into the @each call.
- **/
-}
-```
-
-## Options
-
-### `true`
-
-The following patterns are considered violations:
-
-```scss
-$font-weights: (
- "regular": 400,
- "medium": 500,
- "bold": 700
-);
-@each $key in map-keys($font-weights) {
- $value: map-get($font-weights, $key);
-}
-```
-
-The following patterns are _not_ considered violations:
-
-```scss
-$font-weights: ("regular": 400, "medium": 500, "bold": 700);
-@each $key, $value in $font-weights {...}
-```
-
-```scss
-$font-weights: (
- "regular": 400,
- "medium": 500,
- "bold": 700
-);
-$other-weights: (
- "regular": 400,
- "medium": 500,
- "bold": 700
-);
-
-@each $key, $value in map-keys($font-weights) {
- $value: map-get($other-weights, $key);
-}
-```
-
-```scss
-$font-weights: ("regular": 400, "medium": 500, "bold": 700);
-
-@each $key, $value in map-keys($font-weights) {...}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-else-closing-brace-newline-after/README.md b/assets/node_modules/stylelint-scss/src/rules/at-else-closing-brace-newline-after/README.md
deleted file mode 100644
index e5e2d7f..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-else-closing-brace-newline-after/README.md
+++ /dev/null
@@ -1,74 +0,0 @@
-# at-else-closing-brace-newline-after
-
-Require or disallow a newline after the closing brace of `@else` statements.
-
-```scss
-@if (@a == 0) {
-
-} @else if (@a == 1){ }
-@else { } ↑
-/** ↑ ↑
- * The newline after these braces */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-This rule might have conflicts with stylelint's core rule [`block-closing-brace-newline-after`](https://stylelint.io/user-guide/rules/block-closing-brace-newline-after) if it doesn't have `"ignoreAtRules": ["else"]` in a `.stylelintrc` config file. That's because an `@else { ... }` statement can be successfully parsed as an at-rule with a block. You might also want to set `"ignoreAtRules": ["else"]` for another stylelint's core rule - [`at-rule-empty-line-before`](https://stylelint.io/user-guide/rules/at-rule-empty-line-before) that could be forcing empty lines before at-rules (including `@else`s that follow `@if`s or other `@else`s).
-
-This rule doesn't have usual `"always"` and `"never"` main option values, because if you don't need special behavior for `@if` and `@else` you could just use [`block-closing-brace-newline-after`](https://stylelint.io/user-guide/rules/block-closing-brace-newline-after) set to `"always"` or any other value.
-
-## Options
-
-`string`: `"always-last-in-chain"`
-
-### `"always-last-in-chain"`
-
-There *must always* be a newline after the closing brace of `@else` that is the last statement in a conditional statement chain (i.e. has no `@else` right after it). If it's not, there *must not* be a newline.
-
-The following patterns are considered warnings:
-
-```scss
-a {
- @if ($x == 1) {
- // ...
- } @else {
- // ...
- } width: 10px; // No @else after, so should have a newline
-}
-
-@if ($x == 1) {
- // ...
-} @else if { } // Has @else after it, so shouldn't have a newline
-@else { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- @if ($x == 1) {} @else {}
- width: 10px;
-}
-
-a {
- @if ($x == 1) {
- // ...
- } @else if {
- // ...
- } @else {}
-
- width: 10px;
-}
-
-a {
- @if ($x == 1) { } @else if { }@else { }
-
- width: 10px;
-}
-```
-
-## Optional secondary options
-
-### `disableFix: true`
-
-Disables autofixing for this rule.
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-else-closing-brace-space-after/README.md b/assets/node_modules/stylelint-scss/src/rules/at-else-closing-brace-space-after/README.md
deleted file mode 100644
index 720deaa..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-else-closing-brace-space-after/README.md
+++ /dev/null
@@ -1,131 +0,0 @@
-# at-else-closing-brace-space-after
-
-Require a single space or disallow whitespace after the closing brace of `@else` statements.
-
-```scss
-@if ($a == 0) { }
-@else if ($x == 2) { }
- ↑
-/** ↑
- * The space after this brace */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-This rule might have conflicts with stylelint's core [`block-closing-brace-space-after`](https://stylelint.io/user-guide/rules/block-closing-brace-space-after) rule if the latter is set up in your `.stylelintrc` config file.
-
-## Options
-
-`string`: `"always-intermediate"|"never-intermediate"`
-
-### `"always-intermediate"`
-
-There *must always* be a single space after the closing brace of `@else` that is not the last statement in a conditional statement chain (i.e. does have another `@else` right after it).
-
-The following patterns are considered warnings:
-
-```scss
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-}@else {}
-
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-}
-@else { }
-
-// `@else if` has a space and a newline after the closing brace
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-}
-@else { }
-
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-} @else { } // Two spaces
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-} @else {}
-
-a {
- @if ($x == 1) {
- // ...
- } @else ($x == 2) {
- // ...
- }
- width: 10px;
-}
-
-@if ($x == 1) { } @else if ($x == 2) {
- // ...
-} @include x;
-
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-} @include x;
-```
-
-### `"never-intermediate"`
-
-There *must never* be a whitespace after the closing brace of `@else` that is not the last statement in a conditional statement chain (i.e. does have another `@else` right after it).
-
-The following patterns are considered warnings:
-
-```scss
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-} @else {}
-
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-}
-@else { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@if ($x == 1) {
- // ...
-}@else {}
-
-a {
- @if ($x == 1) {
- // ...
- } @else if ($x == 2) {
- // ...
- }
- width: 10px;
-}
-
-@if ($x == 1) { } @else if ($x == 2) {
- // ...
-}@include x;
-
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-} @include x;
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-else-empty-line-before/README.md b/assets/node_modules/stylelint-scss/src/rules/at-else-empty-line-before/README.md
deleted file mode 100644
index 9961fe6..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-else-empty-line-before/README.md
+++ /dev/null
@@ -1,69 +0,0 @@
-# at-else-empty-line-before
-
-Require an empty line or disallow empty lines before `@`-else.
-
-```scss
-@if ($a == 0) { }
- /* ← */
-@else if ($x == 2) { } ↑
- ↑
-/** ↑
- * This empty line */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-`@if` and `@else` statements might need to have different behavior than all the other at-rules. For that you might need to set `"ignoreAtRules": ["else"]` for stylelint's core rule [`at-rule-empty-line-before`](https://stylelint.io/user-guide/rules/at-rule-empty-line-before). But that would make you unable to disallow empty lines before `@else` while forcing it to be on a new line. This rule is designed to solve exactly that.
-
-## Options
-
-`string`: `"never"`
-
-There is no `"always"`, `"always-single-line"` options, because for such cases stylelint's `at-rule-empty-line-before` would work.
-
-### `"never"`
-
-There *must never* be an empty line before `@else` statements.
-
-The following patterns are considered warnings:
-
-```scss
-@if ($x == 1) {
- // ...
-}
-
-@else {}
-```
-```scss
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-}
-
-
-@else { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@if ($x == 1) {
- // ...
-} @else if ($x == 2) {
- // ...
-} @else {}
-
-a {
- @if ($x == 1) {
- // ...
- }
- @else ($x == 2) {
- // ...
- }
-}
-```
-
-## Caveats
-
-If you use autofix, this rule could clash with [`at-mixin-parentheses-space-before`](https://github.com/kristerkari/stylelint-scss/tree/master/src/rules/at-mixin-parentheses-space-before) rule.
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-else-if-parentheses-space-before/README.md b/assets/node_modules/stylelint-scss/src/rules/at-else-if-parentheses-space-before/README.md
deleted file mode 100644
index b56af2b..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-else-if-parentheses-space-before/README.md
+++ /dev/null
@@ -1,58 +0,0 @@
-# at-else-if-parentheses-space-before
-
-Require or disallow a space before `@else if` parentheses.
-
-```scss
-@else if ($condition) { }
-/** ↑
- * The space before this parenthesis */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-There *must always* be exactly one space between the `@else if` and the condition opening parenthesis.
-
-*Note: This rule does not enforce parentheses to be present.*
-
-The following patterns are considered warnings:
-
-```scss
-@else if($condition) { }
-```
-```scss
-@else if ($condition) { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@else if ($condition) { }
-```
-```scss
-@else if $condition { }
-```
-
-### `"never"`
-
-There *must never* be whitespace between the `@else if` and the condition opening parenthesis.
-
-The following patterns are considered warnings:
-
-```scss
-@else if ($condition) { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@else if($condition) { }
-```
-```scss
-@else if $condition { }
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-extend-no-missing-placeholder/README.md b/assets/node_modules/stylelint-scss/src/rules/at-extend-no-missing-placeholder/README.md
deleted file mode 100644
index b4f4c91..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-extend-no-missing-placeholder/README.md
+++ /dev/null
@@ -1,49 +0,0 @@
-# at-extend-no-missing-placeholder
-
-Disallow at-extends (`@extend`) with missing placeholders.
-
-Using a class selector with the `@extend` directive usually results in more generated CSS than when using a placeholder selector. Furthermore, Sass specifically introduced placeholder selectors in order to be used with `@extend`.
-
-See [Mastering Sass extends and placeholders](http://8gramgorilla.com/mastering-sass-extends-and-placeholders/).
-
-```scss
-.foo {
- @extend %bar
-// ↑
-// This is a placeholder selector
-}
-```
-
-The following patterns are considered warnings:
-
-```scss
-p {
- @extend .some-class;
-}
-```
-
-```scss
-p {
- @extend #some-identifer;
-}
-```
-
-```scss
-p {
- @extend .blah-#{$dynamically_generated_name};
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-p {
- @extend %placeholder;
-}
-```
-
-```scss
-p {
- @extend #{$dynamically_generated_placeholder_name};
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-function-named-arguments/README.md b/assets/node_modules/stylelint-scss/src/rules/at-function-named-arguments/README.md
deleted file mode 100644
index 9ed7101..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-function-named-arguments/README.md
+++ /dev/null
@@ -1,131 +0,0 @@
-# at-function-named-arguments
-
-Require named parameters in SCSS function call rule.
-
-```scss
-animation: animation($duration: 250ms) {
-// ↑
-// Require or disallow this
-```
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `always`
-
-The following patterns are considered warnings:
-
-```scss
-.foo {
- animation: animation(250ms, 100ms, infinite);
-}
-```
-
-```scss
-.foo {
- animation: animation(250ms);
-}
-```
-
-```scss
-.foo {
- border: reset($value: 20, "bar", $color: #fff);
-}
-```
-
-The following patterns are _not_ considered warnings:
-
-```scss
-.foo {
- animation: animation($duration: 250ms);
-}
-```
-
-```scss
-.foo {
- animation: animation($duration: 250ms, $delay: 100ms, $direction: infinite);
-}
-```
-
-### `never`
-
-The following patterns are considered warnings:
-
-```scss
-.foo {
- border: reset($value: 20);
-}
-```
-
-```scss
-.foo {
- animation: animation($duration: 250ms, $delay: 100ms, $direction: infinite);
-}
-```
-
-```scss
-.foo {
- border: reset($value: 20, "bar", $color: #fff);
-}
-```
-
-The following patterns are _not_ considered warnings:
-
-```scss
-.foo {
- animation: animation(250ms, 100ms, infinite);
-}
-```
-
-## Optional secondary options
-
-### `"ignore": ["single-argument"]`
-
-Given:
-
-```json
-{ "ignore": ["single-argument"] }
-```
-
-The following patterns are _not_ considered warnings:
-
-```scss
-.foo {
- @include animation($duration: 250ms);
-}
-```
-
-```scss
-.foo {
- @include reset(20);
-}
-```
-
-### `ignoreFunctions: ["/regex/", "string"]`
-
-Given:
-
-```js
-["always", { ignoreFunctions: ["/^my-/i", "custom"] }];
-```
-
-The following patterns are _not_ considered warnings:
-
-```scss
-.foo {
- border: custom(20, 30);
-}
-```
-
-```scss
-.foo {
- border: my-func(20, 30);
-}
-```
-
-```scss
-.foo {
- border: MY-FUNC(20, 30);
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-function-parentheses-space-before/README.md b/assets/node_modules/stylelint-scss/src/rules/at-function-parentheses-space-before/README.md
deleted file mode 100644
index 9d4d362..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-function-parentheses-space-before/README.md
+++ /dev/null
@@ -1,50 +0,0 @@
-# at-function-parentheses-space-before
-
-Require or disallow a space before `@function` parentheses.
-
-```scss
-@function foo ($arg) { }
-/** ↑
- * The space before this parenthesis */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-There *must always* be exactly one space between the function name and the opening parenthesis.
-
-The following patterns are considered warnings:
-
-```scss
-@function foo($arg) { }
-```
-```scss
-@function foo ($arg) { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@function foo ($arg) { }
-```
-
-### `"never"`
-
-There *must never* be any whitespace between the function name and the opening parenthesis.
-
-The following patterns are considered warnings:
-
-```scss
-@function foo ($arg) { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@function foo($arg) { }
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-function-pattern/README.md b/assets/node_modules/stylelint-scss/src/rules/at-function-pattern/README.md
deleted file mode 100644
index 0aaf58e..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-function-pattern/README.md
+++ /dev/null
@@ -1,29 +0,0 @@
-# at-function-pattern
-
-Specify a pattern for Sass/SCSS-like function names.
-
-```scss
-@function grid-width($n) {
-/** ↑
- * The pattern of this */
-```
-
-## Options
-
-`regex` or `string`
-
-A string will be translated into a RegExp like so `new RegExp(yourString)` — so be sure to escape properly.
-
-### E.g. `/foo-.+/`
-
-The following patterns are considered warnings:
-
-```scss
-@function boo-bar ($n) {
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@function foo-bar ($n){
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-if-closing-brace-newline-after/README.md b/assets/node_modules/stylelint-scss/src/rules/at-if-closing-brace-newline-after/README.md
deleted file mode 100644
index 79f79b0..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-if-closing-brace-newline-after/README.md
+++ /dev/null
@@ -1,60 +0,0 @@
-# at-if-closing-brace-newline-after
-
-Require or disallow a newline after the closing brace of `@if` statements.
-
-```scss
-@if ($a == 0) { }
- ↑
-/** ↑
- * The newline after this brace */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-This rule might have conflicts with stylelint's core rule [`block-closing-brace-newline-after`](https://stylelint.io/user-guide/rules/block-closing-brace-newline-after) if it doesn't have `"ignoreAtRules": ["if"]` in a `.stylelintrc` config file. That's because an `@if { ... }` statement can be successfully parsed as an at-rule with a block. You might also want to set `"ignoreAtRules": ["else"]` for another stylelint's core rule - [`at-rule-empty-line-before`](https://stylelint.io/user-guide/rules/at-rule-empty-line-before) that could be forcing empty lines before at-rules (including `@else`s that follow `@if`s or other `@else`s).
-
-This rule doesn't have usual `"always"` and `"never"` main option values, because if you don't need special behavior for `@if` and `@else` you could just use [`block-closing-brace-newline-after`](https://stylelint.io/user-guide/rules/block-closing-brace-newline-after) set to `"always"` or any other value.
-
-## Options
-
-`string`: `"always-last-in-chain"`
-
-### `"always-last-in-chain"`
-
-There *must always* be a newline after the closing brace of `@if` that is the last statement in a conditional statement chain (i.e. has no `@else` right after it). If it's not, there *must not* be a newline.
-
-The following patterns are considered warnings:
-
-```scss
-a {
- @if ($x == 1) {
- // ...
- } width: 10px; // No @else - should have a newline
-}
-
-@if ($x == 1) {
- // ...
-} // Has @else - shouldn't have a newline
-@else { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- @if ($x == 1) {}
- width: 10px;
-}
-
-@if ($x == 1) {
- // ...
-} @else {} // Has @else, so no newline needed
-
-@if ($x == 1) { }@else { }
-```
-
-## Optional secondary options
-
-### `disableFix: true`
-
-Disables autofixing for this rule.
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-if-closing-brace-space-after/README.md b/assets/node_modules/stylelint-scss/src/rules/at-if-closing-brace-space-after/README.md
deleted file mode 100644
index de93f77..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-if-closing-brace-space-after/README.md
+++ /dev/null
@@ -1,100 +0,0 @@
-# at-if-closing-brace-space-after
-
-Require a single space or disallow whitespace after the closing brace of `@if` statements.
-
-```scss
-@if ($a == 0) { }
- ↑
-/** ↑
- * The space after this brace */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-This rule might have conflicts with stylelint's core [`block-closing-brace-space-after`](https://stylelint.io/user-guide/rules/block-closing-brace-space-after) rule if the latter is set up in your `.stylelintrc` config file.
-
-## Options
-
-`string`: `"always-intermediate"|"never-intermediate"`
-
-### `"always-intermediate"`
-
-There *must always* be a single space after the closing brace of `@if` that is not the last statement in a conditional statement chain (i.e. does have `@else` right after it).
-
-The following patterns are considered warnings:
-
-```scss
-@if ($x == 1) {
- // ...
-}@else {}
-
-@if ($x == 1) {
- // ...
-}
-@else { }
-
-// `@if` has a space and a newline after the closing brace
-@if ($x == 1) {
- // ...
-}
-@else { }
-
-@if ($x == 1) {
- // ...
-} @else { } // Two spaces
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@if ($x == 1) {
- // ...
-} @else {}
-
-a {
- @if ($x == 1) {}
- width: 10px;
-}
-
-@if ($x == 1) { }@include x;
-
-@if ($x == 1) {
- // ...
-} @include x;
-```
-
-### `"never-intermediate"`
-
-There *must never* be a whitespace after the closing brace of `@if` that is not the last statement in a conditional statement chain (i.e. does have `@else` right after it).
-
-The following patterns are considered warnings:
-
-```scss
-@if ($x == 1) {
- // ...
-} @else {}
-
-@if ($x == 1) {
- // ...
-}
-@else { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@if ($x == 1) {
- // ...
-}@else {}
-
-a {
- @if ($x == 1) {}
- width: 10px;
-}
-
-@if ($x == 1) { }@include x;
-
-@if ($x == 1) {
- // ...
-} @include x;
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-if-no-null/README.md b/assets/node_modules/stylelint-scss/src/rules/at-if-no-null/README.md
deleted file mode 100644
index 66a1edb..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-if-no-null/README.md
+++ /dev/null
@@ -1,44 +0,0 @@
-# at-if-no-null
-
-Check for equality to null is unnecessarily explicit since `null` is falsey in Sass.
-
-```scss
-a {
- @if $x == null {}
-/** ↑ ↑
- * == or != null is unncessary */
-}
-```
-
-## Options
-
-true
-
-### `true`
-
-The following patterns are considered warnings:
-```scss
-a {
- @if $x == null {}
-}
-```
-
-```scss
-a {
- @if $x != null {}
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- @if $x {}
-}
-```
-
-```scss
-a {
- @if not $x {}
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-import-no-partial-leading-underscore/README.md b/assets/node_modules/stylelint-scss/src/rules/at-import-no-partial-leading-underscore/README.md
deleted file mode 100644
index a12c207..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-import-no-partial-leading-underscore/README.md
+++ /dev/null
@@ -1,59 +0,0 @@
-# at-import-no-partial-leading-underscore
-
-Disallow leading underscore in partial names in `@import`.
-
-```scss
-@import "path/to/_file"
-/** ↑
- * Disallow this */
-```
-
-The rule ignores [cases](https://sass-lang.com/documentation/at-rules/import) when Sass considers an `@import` command just a plain CSS import:
-
-* If the file’s extension is `.css`.
-* If the filename begins with `http://` (or any other protocol).
-* If the filename is a `url()`.
-* If the `@import` has any media queries.
-
-
-The following patterns are considered warnings:
-
-```scss
-@import "_foo";
-```
-
-```scss
-@import "path/_fff";
-```
-
-```scss
-@import "path\\_fff"; /* Windows delimiters */
-```
-
-```scss
-@import "df/fff", '_1.scss';
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@import "_path/fff"; /* underscore in a directory name, not in a partial name */
-```
-
-```scss
-@import url("path/_file.css"); /* has url(), so doesn't count as a partial @import */
-```
-
-```scss
-@import "_file.css"; /* Has ".css" extension, so doesn't count as a partial @import */
-```
-
-```scss
-/* Both are URIs, so don't count as partial @imports */
-@import "http://_file.scss";
-@import "//_file.scss";
-```
-
-```scss
-@import "_file.scss" screen; /* Has a media query, so doesn't count as a partial @import */
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension-blacklist/README.md b/assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension-blacklist/README.md
deleted file mode 100644
index 11b9c0a..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension-blacklist/README.md
+++ /dev/null
@@ -1,70 +0,0 @@
-# at-import-partial-extension-blacklist
-
-Specify blacklist of disallowed file extensions for partial names in `@import` commands.
-
-```scss
-@import "file.scss"
-/** ↑
- * Blacklist of these */
-```
-
-The rule ignores [cases](https://sass-lang.com/documentation/at-rules/import) when Sass considers an `@import` command just a plain CSS import:
-
-* If the file’s extension is `.css`.
-* If the filename begins with `http://` (or any other protocol).
-* If the filename is a `url()`.
-* If the `@import` has any media queries.
-
-## Options
-
-`array`: `["array", "of", "extensions"]`
-
-Each value is either a string or a regexp.
-
-Given:
-
-```js
-["scss", /less/]
-```
-
-The following patterns are considered warnings:
-
-```scss
-@import "foo.scss";
-```
-
-```scss
-@import "path/fff.less";
-```
-
-```scss
-@import "path\\fff.ruthless";
-```
-
-```scss
-@import "df/fff", '1.SCSS';
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@import "path/fff";
-```
-
-```scss
-@import url("path/_file.css"); /* has url(), so doesn't count as a partial @import */
-```
-
-```scss
-@import "file.css"; /* Has ".css" extension, so doesn't count as a partial @import */
-```
-
-```scss
-/* Both are URIs, so don't count as partial @imports */
-@import "http://_file.scss";
-@import "//_file.scss";
-```
-
-```scss
-@import "file.scss" screen; /* Has a media query, so doesn't count as a partial @import */
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension-whitelist/README.md b/assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension-whitelist/README.md
deleted file mode 100644
index 58cbd56..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension-whitelist/README.md
+++ /dev/null
@@ -1,78 +0,0 @@
-# at-import-partial-extension-whitelist
-
-Specify whitelist of allowed file extensions for partial names in `@import` commands.
-
-```scss
-@import "file.scss"
-/** ↑
- * Whitelist of these */
-```
-
-The rule ignores [cases](https://sass-lang.com/documentation/at-rules/import) when Sass considers an `@import` command just a plain CSS import:
-
-* If the file’s extension is `.css`.
-* If the filename begins with `http://` (or any other protocol).
-* If the filename is a `url()`.
-* If the `@import` has any media queries.
-
-## Options
-
-`array`: `["array", "of", "extensions"]`
-
-Each value is either a string or a regexp.
-
-Given:
-
-```js
-["scss", /less/]
-```
-
-The following patterns are considered warnings:
-
-```scss
-@import "file.sass";
-```
-
-```scss
-@import "file1", "file.stylus";
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@import "path/fff";
-```
-
-```scss
-@import "foo.scss";
-```
-
-```scss
-@import "path/fff.less";
-```
-
-```scss
-@import "path\\fff.ruthless";
-```
-
-```scss
-@import "df/fff", '1.SCSS';
-```
-
-```scss
-@import url("path/_file.css"); /* has url(), so doesn't count as a partial @import */
-```
-
-```scss
-@import "file.css"; /* Has ".css" extension, so doesn't count as a partial @import */
-```
-
-```scss
-/* Both are URIs, so don't count as partial @imports */
-@import "http://_file.scss";
-@import "//_file.scss";
-```
-
-```scss
-@import "file.scss" screen; /* Has a media query, so doesn't count as a partial @import */
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension/README.md b/assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension/README.md
deleted file mode 100644
index 56603f5..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-import-partial-extension/README.md
+++ /dev/null
@@ -1,116 +0,0 @@
-# at-import-partial-extension
-
-Require or disallow extension in `@import` commands.
-
-```scss
-@import "file.scss";
-/** ↑
- * This extension */
-```
-
-The rule ignores [cases](https://sass-lang.com/documentation/at-rules/import) when Sass considers an `@import` command just a plain CSS import:
-
-- If the file’s extension is `.css`.
-- If the filename begins with `http://` (or any other protocol).
-- If the filename is a `url()`.
-- If the `@import` has any media queries.
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-The following patterns are considered warnings:
-
-```scss
-@import "foo";
-```
-
-```scss
-@import "path/fff";
-```
-
-```scss
-@import "path\\fff";
-```
-
-```scss
-@import "df/fff", "1.SCSS";
-```
-
-The following patterns are _not_ considered warnings:
-
-```scss
-@import "fff.scss";
-```
-
-```scss
-@import "path/fff.scss";
-```
-
-```scss
-@import url("path/_file.css"); /* has url(), so doesn't count as a partial @import */
-```
-
-```scss
-@import "file.css"; /* Has ".css" extension, so doesn't count as a partial @import */
-```
-
-```scss
-/* Both are URIs, so don't count as partial @imports */
-@import "http://_file.scss";
-@import "//_file.scss";
-```
-
-```scss
-@import "file.scss" screen; /* Has a media query, so doesn't count as a partial @import */
-```
-
-### `"never"`
-
-The following patterns are considered warnings:
-
-```scss
-@import "foo.scss";
-```
-
-```scss
-@import "path/fff.less";
-```
-
-```scss
-@import "path\\fff.ruthless";
-```
-
-```scss
-@import "df/fff", "1.SCSS";
-```
-
-The following patterns are _not_ considered warnings:
-
-```scss
-@import "foo";
-```
-
-```scss
-@import "path/fff";
-```
-
-```scss
-@import url("path/_file.css"); /* has url(), so doesn't count as a partial @import */
-```
-
-```scss
-@import "file.css"; /* Has ".css" extension, so doesn't count as a partial @import */
-```
-
-```scss
-/* Both are URIs, so don't count as partial @imports */
-@import "http://_file.scss";
-@import "//_file.scss";
-```
-
-```scss
-@import "file.scss" screen; /* Has a media query, so doesn't count as a partial @import */
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-mixin-argumentless-call-parentheses/README.md b/assets/node_modules/stylelint-scss/src/rules/at-mixin-argumentless-call-parentheses/README.md
deleted file mode 100644
index 0ee3d05..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-mixin-argumentless-call-parentheses/README.md
+++ /dev/null
@@ -1,47 +0,0 @@
-# at-mixin-argumentless-call-parentheses
-
-Require or disallow parentheses in argumentless `@mixin` calls.
-
-```scss
-@include mixin-name() {
-/** ↑
- * Such mixin calls */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-There *must always* be parentheses in mixin calls, even if no arguments are passed.
-
-The following patterns are considered warnings:
-
-```scss
-@include mixin-name;
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@include mixin-name();
-```
-
-### `"never"`
-
-There *must never* be parentheses when calling a mixin without arguments.
-
-The following patterns are considered warnings:
-
-```scss
-@include mixin-name();
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@include mixin-name;
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-mixin-named-arguments/README.md b/assets/node_modules/stylelint-scss/src/rules/at-mixin-named-arguments/README.md
deleted file mode 100644
index 4eafe20..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-mixin-named-arguments/README.md
+++ /dev/null
@@ -1,102 +0,0 @@
-# at-mixin-named-arguments
-
-Require named parameters in at-mixin call rule.
-
-```scss
-@include animation($duration: 250ms) {
-// ↑
-// Require or disallow this
-```
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `always`
-
-The following patterns are considered warnings:
-
-```scss
-.foo {
- @include animation(250ms, 100ms, infinite);
-}
-```
-
-```scss
-.foo {
- @include animation(250ms);
-}
-```
-
-```scss
-.foo {
- @include reset($value: 20, 'bar', $color: #FFF);
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-.foo {
- @include animation($duration: 250ms);
-}
-```
-
-```scss
-.foo {
- @include animation($duration: 250ms, $delay: 100ms, $direction: infinite);
-}
-```
-
-### `never`
-
-The following patterns are considered warnings:
-
-```scss
-.foo {
- @include reset($value: 20);
-}
-```
-
-```scss
-.foo {
- @include animation($duration: 250ms, $delay: 100ms, $direction: infinite);
-}
-```
-
-```scss
-.foo {
- @include reset($value: 20, 'bar', $color: #FFF);
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-.foo {
- @include animation(250ms, 100ms, infinite);
-}
-```
-
-## Optional secondary options
-
-### `"ignore": ["single-argument"]`
-
-Given:
-```json
-{ "ignore": ["single-argument"] }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-.foo {
- @include animation($duration: 250ms);
-}
-```
-
-```scss
-.foo {
- @include reset(20);
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-mixin-parentheses-space-before/README.md b/assets/node_modules/stylelint-scss/src/rules/at-mixin-parentheses-space-before/README.md
deleted file mode 100644
index 39253ab..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-mixin-parentheses-space-before/README.md
+++ /dev/null
@@ -1,58 +0,0 @@
-# at-mixin-parentheses-space-before
-
-Require or disallow a space before `@mixin` parentheses.
-
-```scss
-@mixin foo ($arg) { }
-/** ↑
- * The space before this parenthesis */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-There *must always* be exactly one space between the mixin name and the opening parenthesis.
-
-*Note: This rule does not enforce parentheses to be present in a declaration without arguments.*
-
-The following patterns are considered warnings:
-
-```scss
-@mixin foo($arg) { }
-```
-```scss
-@mixin foo ($arg) { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@mixin foo ($arg) { }
-```
-```scss
-@mixin foo { }
-```
-
-### `"never"`
-
-There *must never* be any whitespace between the mixin name and the opening parenthesis.
-
-The following patterns are considered warnings:
-
-```scss
-@mixin foo ($arg) { }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@mixin foo($arg) { }
-```
-```scss
-@mixin foo { }
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-mixin-pattern/README.md b/assets/node_modules/stylelint-scss/src/rules/at-mixin-pattern/README.md
deleted file mode 100644
index 786b2f0..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-mixin-pattern/README.md
+++ /dev/null
@@ -1,29 +0,0 @@
-# at-mixin-pattern
-
-Specify a pattern for Sass/SCSS-like mixin names.
-
-```scss
-@mixin complex-object ($items: 10) {
-/** ↑
- * The pattern of this */
-```
-
-## Options
-
-`regex` or `string`
-
-A string will be translated into a RegExp like so `new RegExp(yourString)` — so be sure to escape properly.
-
-### E.g. `/foo-.+/`
-
-The following patterns are considered warnings:
-
-```scss
-@mixin boo-bar {
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@mixin foo-bar {
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-rule-conditional-no-parentheses/README.md b/assets/node_modules/stylelint-scss/src/rules/at-rule-conditional-no-parentheses/README.md
deleted file mode 100644
index cc981f3..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-rule-conditional-no-parentheses/README.md
+++ /dev/null
@@ -1,43 +0,0 @@
-# at-rule-conditional-no-parentheses
-
-Disallow parentheses in conditional @ rules (if, elsif, while)
-
-```css
- @if (true) {}
-/** ↑ ↑
- * Get rid of parentheses like this. */
-```
-
-
-
-## Options
-
-### `true`
-
-The following patterns are considered warnings:
-
-```scss
-@if(true)
-```
-
-```scss
-@else if(true)
-```
-
-```scss
-@while(true)
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@if true
-```
-
-```scss
-@else if true
-```
-
-```scss
-@while true
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/at-rule-no-unknown/README.md b/assets/node_modules/stylelint-scss/src/rules/at-rule-no-unknown/README.md
deleted file mode 100644
index 3b0932e..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/at-rule-no-unknown/README.md
+++ /dev/null
@@ -1,76 +0,0 @@
-# at-rule-no-unknown
-
-Disallow unknown at-rules. Should be used **instead of** stylelint's [at-rule-no-unknown](https://stylelint.io/user-guide/rules/at-rule-no-unknown).
-
-```css
- @unknown (max-width: 960px) {}
-/** ↑
- * At-rules like this */
-```
-
-This rule is basically a wrapper around the mentioned core rule, but with added SCSS-specific `@`-directives. So if you use the core rule, `@if`, `@extend` and other Sass-y things will get warnings. You must disable stylelint's core rule to make this rule work:
-
-```json
-{
- "rules": {
- "at-rule-no-unknown": null,
- "scss/at-rule-no-unknown": true
- }
-}
-```
-
-## Options
-
-### `true`
-
-The following patterns are considered warnings:
-
-```css
-@unknown {}
-```
-
-The following patterns are *not* considered warnings:
-
-```css
-@function foo () {}
-```
-
-```css
-@while ($i == 1) {}
-```
-
-```css
-@media (max-width: 960px) {}
-```
-
-```css
-@if ($i) {} @else {}
-```
-
-## Optional secondary options
-
-### `ignoreAtRules: ["/regex/", "string"]`
-
-Given:
-
-```js
-["/^my-/i", "custom"]
-```
-
-The following patterns are *not* considered warnings:
-
-```css
-@my-at-rule "x.css";
-```
-
-```css
-@my-other-at-rule {}
-```
-
-```css
-@MY-OTHER-AT-RULE {}
-```
-
-```css
-@custom {}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/comment-no-loud/README.md b/assets/node_modules/stylelint-scss/src/rules/comment-no-loud/README.md
deleted file mode 100644
index c75232e..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/comment-no-loud/README.md
+++ /dev/null
@@ -1,33 +0,0 @@
-# comment-no-loud
-
-Disallow `/*`-comments.
-
-```scss
-/* Comment */
-// ↑ ↑
-// This line
-```
-
-This rule only works on CSS comments (`/* */`) and ignores all double-slash (`//`) comments.
-
-## Options
-
-### `true`
-
-The following patterns are considered violations:
-
-```scss
-/* comment */
-```
-
-```scss
-/*
- * comment
-*/
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-// comment
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/declaration-nested-properties-no-divided-groups/README.md b/assets/node_modules/stylelint-scss/src/rules/declaration-nested-properties-no-divided-groups/README.md
deleted file mode 100644
index c96e431..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/declaration-nested-properties-no-divided-groups/README.md
+++ /dev/null
@@ -1,68 +0,0 @@
-# declaration-nested-properties-no-divided-groups
-
-Disallow nested properties of the same "namespace" be divided into multiple groups.
-
-```scss
-/* Such groups: */
-font: { /* `font` is a "namespace" */
- size: 16px;
- weight: 700;
-}
-```
-
-A "namespace" is everything before the first `-` in property names, e.g. `margin` in `margin-bottom`. It is the "namespace" that is used as a root identifier for a nested properties group (`font` in the example above).
-
-[Sass official docs on nested properties](https://sass-lang.com/documentation/style-rules/declarations#nesting).
-
-The following patterns are considered warnings:
-
-```scss
-a {
- background: url(img.png) center {
- size: auto;
- }
- background: {
- repeat: no-repeat;
- }
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- background: url(img.png) center {
- size: auto;
- }
- background-repeat: no-repeat;
-}
-```
-
-```scss
-a {
- background: url(img.png) center no-repeat {
- color: red;
- }
- margin: 10px {
- left: 1px;
- }
-}
-```
-
-```scss
-a {
- background: url(img.png) center {
- size: auto;
- }
- background :red {
- repeat: no-repeat;
- }
-}
-/* There is no space after the colon in `background :red` so it is considered A SELECTOR and is compiled into:
-
-a background :red {
- color: blue;
-}
-
-*/
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/declaration-nested-properties/README.md b/assets/node_modules/stylelint-scss/src/rules/declaration-nested-properties/README.md
deleted file mode 100644
index 5776e3c..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/declaration-nested-properties/README.md
+++ /dev/null
@@ -1,153 +0,0 @@
-# declaration-nested-properties
-
-Require or disallow properties with `-` in their names to be in a form of a nested group.
-
-```scss
-/* This is properties nesting: */
-font: {
- size: 16px;
- weight: 700;
-}
-```
-
-[Sass official docs on nested properties](https://sass-lang.com/documentation/style-rules/declarations#nesting).
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-*Every property* with a `-` in its name *must be* inside a nested property group.
-
-Property names with browser prefixes are ignored with `always`.
-
-The following patterns are considered warnings:
-
-```scss
-a {
- margin-left: 10px;
-}
-```
-
-```scss
-a {
- font: {
- size: 10px;
- }
- font-weight: 400; // This one should be nested either
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- margin: {
- left: 10px;
- }
-}
-```
-
-```scss
-a {
- font: 10px/1.1 Arial {
- weight: bold;
- }
-}
-```
-
-```scss
-a {
- -webkit-box-sizing: border-box;
- -webkit-box-shadow: 1px 0 0 red;
-}
-```
-
-### `"never"`
-
-Nested properties are not allowed.
-
-The following patterns are considered warnings:
-
-```scss
-a {
- margin: {
- left: 10px;
- }
-}
-```
-
-```scss
-a {
- background: red {
- repeat: no-repeat;
- }
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- background-color: red;
- background-repeat: no-repeat;
-}
-```
-
-```scss
-a {
- background:red {
- color: blue;
- }
-}
-
-/* There is no space after the colon in `background:red` so it is considered A SELECTOR and is compiled into:
-
-a background:red {
- color: blue;
-}
-
-*/
-```
-
-## Optional options
-
-### `except: ["only-of-namespace"]`
-
-*Works only* with `"always"` and reverses its effect for a property if it is the only one with the corresponding "namespace" (e.g. `margin` in `margin-top`) in a ruleset.
-
-The following patterns are considered warnings:
-
-```scss
-a {
- font-family: Arial, sans-serif;
- font-size: 10px;
-}
-```
-
-```scss
-a {
- font: {
- size: 10px; // Only one rule nested (reverse "always")
- }
-}
-```
-
-```scss
-a {
- font: {
- size: 10px; // Prop 1, ...
- }
- font-weight: 400; // ... prop 2, so must be nested as well
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- position: absolute;
- background-color: red; // no other `background-` properties in a ruleset
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/dimension-no-non-numeric-values/README.md b/assets/node_modules/stylelint-scss/src/rules/dimension-no-non-numeric-values/README.md
deleted file mode 100644
index 985444f..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/dimension-no-non-numeric-values/README.md
+++ /dev/null
@@ -1,93 +0,0 @@
-# dimension-no-non-numeric-values
-
-Interpolating a value with a unit (e.g. `#{$value}px`) results in a
-_string_ value, not as numeric value. This value then cannot be used in
-numerical operations. It is better to use arithmetic to apply a unit to a
-number (e.g. `$value * 1px`).
-
-This rule requires that all interpolation for values should be in the format `$value * 1<unit>` instead of `#{value}<unit>`
-
-```scss
-$value: 4;
-
-p {
- padding: #{value}px;
-// ↑ ↑
-// should be $value * 1px
-}
-```
-
-## Options
-
-### `true`
-
-The following patterns are considered violations:
-
-```scss
-$value: 4;
-
-p {
- padding: #{value}px;
-}
-```
-
-The following patterns are _not_ considered violations:
-
-```scss
-$value: 4;
-
-p {
- padding: $value * 1px;
-}
-```
-
-## List of units
-Font-relative lengths ([link](https://www.w3.org/TR/css-values-4/#font-relative-lengths))
-* em
-* ex
-* cap
-* ch
-* ic
-* rem
-* lh
-* rlh
-
-Viewport-relative lengths ([link](https://www.w3.org/TR/css-values-4/#viewport-relative-lengths))
-* vw
-* vh
-* vi
-* vb
-* vmin
-* vmax
-
-Absolute lengths ([link](https://www.w3.org/TR/css-values-4/#absolute-lengths))
-* cm
-* mm
-* Q
-* in
-* pc
-* pt
-* px
-
-Angle units ([link](https://www.w3.org/TR/css-values-4/#angles))
-* deg
-* grad
-* rad
-* turn
-
-Duration units ([link](https://www.w3.org/TR/css-values-4/#time))
-* s
-* ms
-
-Frequency units ([link](https://www.w3.org/TR/css-values-4/#frequency))
-* Hz
-* kHz
-
-Resolution units ([link](https://www.w3.org/TR/css-values-4/#resolution))
-* dpi
-* dpcm
-* dppx
-* x
-
-Flexible lengths ([link](https://www.w3.org/TR/css-grid-1/#fr-unit))
-* fr
diff --git a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-newline-after/README.md b/assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-newline-after/README.md
deleted file mode 100644
index 238218b..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-newline-after/README.md
+++ /dev/null
@@ -1,85 +0,0 @@
-# dollar-variable-colon-newline-after
-
-Require a newline after the colon in `$`-variable declarations.
-
-```scss
-$box-shadow:
- 0 0 0 1px #5b9dd9,
- 0 0 2px 1px rgba(30, 140, 190, 0.8);
- /* ↑ */
-/** ↑
- * The newline after this colon */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-## Options
-
-`string`: `"always"|"always-multi-line"`
-
-### `"always"`
-
-There *must always* be a newline after the colon.
-
-The following patterns are considered warnings:
-
-```scss
-$var:100px;
-```
-
-```scss
-a { $var:100px; }
-```
-
-```scss
-$var: 100px;
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-$var:
- 100px;
-```
-
-```scss
-a {
- $var:
- 100px;
-}
-```
-
-### `"always-multi-line"`
-
-There *must always* be a newline after the colon *if the variable value is multi-line*.
-
-The following patterns are considered warnings:
-
-```scss
-$box-shadow: 0 0 0 1px #5b9dd9,
- 0 0 2px 1px rgba(30, 140, 190, 0.8);
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-$box-shadow:
- 0 0 0 1px #5b9dd9,
- 0 0 2px 1px rgba(30, 140, 190, 0.8);
-```
-
-```scss
-$box-shadow:
- 0 0 0 1px #5b9dd9, 0 0 2px 1px rgba(30, 140, 190, 0.8);
-// The VALUE is single-line, so a newline after the colon is ignored by this rule.
-```
-
-```scss
-$var: 100px;
-```
-
-## Optional secondary options
-
-### `disableFix: true`
-
-Disables autofixing for this rule.
diff --git a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-space-after/README.md b/assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-space-after/README.md
deleted file mode 100644
index df0d41c..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-space-after/README.md
+++ /dev/null
@@ -1,139 +0,0 @@
-# dollar-variable-colon-space-after
-
-Require or disallow whitespace after the colon in `$`-variable declarations.
-
-```scss
-$variable: 10px;
-/** ↑
- * The space after this colon */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-## Options
-
-`string`: `"always"|"never"|"always-single-line"|"at-least-one-space"`
-
-### `"always"`
-
-There *must always* be a single space after the colon.
-
-The following patterns are considered warnings:
-
-```scss
-a { $var :10px }
-```
-
-```scss
-$var:10px;
-```
-
-```scss
-$var:
- 10px;
-// a newline is not a space
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a { $var : 10px }
-```
-
-```scss
-$var: 10px;
-```
-
-### `"never"`
-
-There *must never* be whitespace after the colon.
-
-The following patterns are considered warnings:
-
-```scss
-$var: 10px;
-```
-
-```scss
-$var:
-10px;
-```
-
-```scss
-a { $var :10px }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-$var :10px;
-```
-
-```scss
-a { $var:10px }
-```
-
-### `"always-single-line"`
-
-There *must always* be a single space after the colon *if the variable value is single-line*.
-
-The following patterns are considered warnings:
-
-```scss
-$box-shadow:0 0 0 1px #5b9dd9, 0 0 2px 1px rgba(30, 140, 190, 0.8);
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- $box-shadow: 0 0 0 1px #5b9dd9, 0 0 2px 1px rgba(30, 140, 190, 0.8);
-}
-```
-
-```scss
-$box-shadow:
- 0 0 0 1px #5b9dd9,
- 0 0 2px 1px rgba(30, 140, 190, 0.8);
-```
-
-```scss
-a {
- $box-shadow:0 0 0 1px #5b9dd9,
- 0 0 2px 1px rgba(30, 140, 190, 0.8);
-}
-```
-
-### `"at-least-one-space"`
-
-There must always be *at least* a single space after the colon.
-
-The following patterns are considered warnings:
-
-```scss
-a { $var :10px }
-```
-
-```scss
-$var:10px;
-```
-
-```scss
-$var:
- 10px;
-// a newline is not a space
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a { $var : 10px }
-```
-
-```scss
-$var: 10px;
-```
-
-```scss
-$var: 10px;
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-space-before/README.md b/assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-space-before/README.md
deleted file mode 100644
index 536a70f..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-colon-space-before/README.md
+++ /dev/null
@@ -1,73 +0,0 @@
-# dollar-variable-colon-space-before
-
-Require a single space or disallow whitespace before the colon in `$`-variable declarations.
-
-```scss
-$variable: 10px;
-/** ↑
- * The space before this colon */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-## Options
-
-`string`: `"always"|"never"
-
-### `"always"`
-
-There *must always* be a single space before the colon.
-
-The following patterns are considered warnings:
-
-```scss
-a { $var: 10px }
-```
-
-```scss
-$var:10px;
-```
-
-```scss
-$var :10px;
-```
-
-```scss
-$var
-:10px;
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a { $var : 10px }
-```
-
-```scss
-$var :10px;
-```
-
-### `"never"`
-
-There *must never* be whitespace before the colon.
-
-The following patterns are considered warnings:
-
-```scss
-$var :10px;
-```
-
-```scss
-a { $var
-:10px }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-$var:10px;
-```
-
-```scss
-a { $var: 10px }
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-default/README.md b/assets/node_modules/stylelint-scss/src/rules/dollar-variable-default/README.md
deleted file mode 100644
index a75649a..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-default/README.md
+++ /dev/null
@@ -1,25 +0,0 @@
-# dollar-variable-default
-
-Require `!default` flag for `$`-variable declarations
-
-```scss
-$variable: 10px !default;
-/** ↑
- * This is variable with default value */
-```
-
-## Optional Options
-
-### `ignore: "local"`
-
-Makes this rule ignore local variables (variables defined inside a rule/mixin/function, etc.).
-
-The following patterns are *not* considered warnings:
-
-```scss
-$var: 10px !default;
-
-a {
- $local-var: 10px;
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-empty-line-before/README.md b/assets/node_modules/stylelint-scss/src/rules/dollar-variable-empty-line-before/README.md
deleted file mode 100644
index 92e5f0e..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-empty-line-before/README.md
+++ /dev/null
@@ -1,205 +0,0 @@
-# dollar-variable-empty-line-before
-
-Require an empty line or disallow empty lines before `$`-variable declarations.
-
-If the `$`-variable declaration is the first declaration in a file, it's ignored.
-
-```scss
- /* ← */
-$width: 10px; ↑
-/** ↑
- * This empty line */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-There *must always* be one empty line before a `$`-variable declaration.
-
-The following patterns are considered warnings:
-
-```scss
-@import '1.css';
-$var2: 200px;
-```
-
-```scss
-a {
- $var: 1;
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-$var: 100px; // The first declaration in a stylesheet
-```
-
-```scss
-a { color: red; }
-
-$var: 1;
-```
-
-### `"never"`
-
-There *must never* be an empty line before a `$`-variable declaration.
-
-The following patterns are considered warnings:
-
-```scss
-a { color: red; }
-
-$var: 1;
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-$var: 100px;
-$var2: 200px;
-```
-
-```scss
-a {
- width: auto;
-}
-$var: 1;
-```
-
-## Optional secondary options
-
-### `except: ["first-nested", "after-comment", "after-dollar-variable"]`
-
-### `"first-nested"`
-
-Reverse the primary option for a `$`-variable declaration if it's the first child of its parent.
-
-For example, with `"always"`:
-
-The following patterns are considered warnings:
-
-```scss
-a {
-
- $var: 1;
- color: red;
-}
-
-b {
- color: red;
-
- $var: 1;
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- $var: 1;
- color: red;
-}
-
-b {
- color: red;
- $var: 1;
-}
-```
-
-### `"after-comment"`
-
-Reverse the primary option for `$`-variable declarations that go after comments.
-
-For example, with `"always"`:
-
-The following patterns are considered warnings:
-
-```scss
-a {
- // comment
-
- $var: 1;
-}
-
-b {
- /* comment */
-
- $var: 1;
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- // comment
- $var: 1;
-}
-```
-
-### `"after-dollar-variable"`
-
-Reverse the primary option for `$`-variable declarations that go right after another `$`-variable declaration.
-
-For example, with `"always"`:
-
-The following patterns are considered warnings:
-
-```scss
-a {
-
- $var: 1; // this one is ok
-
- $var1: 2; // and this one shouldn't have a preceding empty line
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
-
- $var: 1;
- $var1: 2;
-}
-```
-
-### `ignore: ["after-comment", "inside-single-line-block"]`
-
-### `"after-comment"`
-
-Ignore `$`-variables that go after a comment.
-
-For example, with `"always"`:
-
-The following patterns are *not* considered warnings:
-
-```scss
-// comment
-$var: 1
-
-/* comment */
-$var2: 1;
-```
-
-### `"inside-single-line-block"`
-
-Ignore `$`-variables that are inside single-line blocks.
-
-For example, with `"always"`:
-
-The following patterns are *not* considered warnings:
-
-```scss
-a { $var: 10; }
-```
-
-### `disableFix: true`
-
-Disables autofixing for this rule.
diff --git a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-no-missing-interpolation/README.md b/assets/node_modules/stylelint-scss/src/rules/dollar-variable-no-missing-interpolation/README.md
deleted file mode 100644
index 61dfbd0..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-no-missing-interpolation/README.md
+++ /dev/null
@@ -1,111 +0,0 @@
-# dollar-variable-no-missing-interpolation
-
-Disallow Sass variables that are used without interpolation with CSS features that use custom identifiers.
-
-```scss
-.class {
- $var: "my-anim";
- animation-name: $var;
-// ↑
-// This variable needs to be interpolated
-// because its value is a string
-}
-```
-
-Sass variables that contain a custom identifier as a string always require interpolation when used. Some CSS [at-rules](https://css-tricks.com/the-at-rules-of-css/) require variable interpolation even when the custom identifier value is not a string.
-
-For example, your CSS animation could look like this:
-
-```scss
-animation: myAnim 5s;
-```
-
-When you store your custom identifier as string in a Sass variable...
-
-```scss
-$myVar: "myAnim";
-```
-
-...then you need to make sure that the variable is interpolated when it gets used:
-
-```scss
-animation: #{$myVar} 5s;
-```
-
-If you do not interpolate the variable, Sass will compile your animation name to a string, producing invalid CSS:
-
-```scss
-animation: "myAnim" 5s;
-```
-
-This rule can only check for variables that are defined inside the same file where they are used.
-
-The following patterns are considered warnings:
-
-```scss
-$var: my-anim;
-
-@keyframes $var {}
-```
-
-```scss
-$var: "circled-digits";
-
-@counter-style $var {
- system: fixed;
- symbols: ➀ ➁ ➂;
- suffix: ' ';
- speak-as: numbers;
-}
-```
-
-```scss
-$var: "my-counter";
-
-body {
- counter-reset: $var;
-}
-```
-
-```scss
-$var: "my-anim";
-
-@supports (animation-name: $var) {
- @keyframes {}
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-$var: my-anim;
-
-@keyframes #{$var} {}
-```
-
-```scss
-$var: circled-digits;
-
-@counter-style #{$var} {
- system: fixed;
- symbols: ➀ ➁ ➂;
- suffix: ' ';
- speak-as: numbers;
-}
-```
-
-```scss
-$var: my-counter;
-
-body {
- counter-reset: $var;
-}
-```
-
-```scss
-$var: my-anim;
-
-@supports (animation-name: $var) {
- @keyframes {}
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-pattern/README.md b/assets/node_modules/stylelint-scss/src/rules/dollar-variable-pattern/README.md
deleted file mode 100644
index a7ba429..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/dollar-variable-pattern/README.md
+++ /dev/null
@@ -1,69 +0,0 @@
-# dollar-variable-pattern
-
-Specify a pattern for Sass-like variables.
-
-```scss
-a { $foo: 1px; }
-/** ↑
- * The pattern of this */
-```
-
-## Options
-
-`regex` or `string`
-
-A string will be translated into a RegExp like so `new RegExp(yourString)` — so be sure to escape properly.
-
-### E.g. `/foo-.+/`
-
-The following patterns are considered warnings:
-
-```scss
-a { $boo-bar: 0; }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a { $foo-bar: 0; }
-```
-
-## Optional Options
-
-### `ignore: "local"|"global"`
-
-#### `"local"`
-
-Makes this rule ignore local variables (variables defined inside a rule/mixin/function, etc.).
-
-For example, with `/^foo-/`:
-
-The following patterns are *not* considered warnings:
-
-```scss
-$foo-name00: 10px;
-```
-
-```scss
-a {
- $bar-name01: 10px;
-}
-```
-
-#### `"global"`
-
-Makes this rule ignore global variables (variables defined in the stylesheet root).
-
-For example, with `/^foo-/`:
-
-The following patterns are *not* considered warnings:
-
-```scss
-$bar-name01: 10px;
-```
-
-```scss
-a {
- $foo-name02: 10px;
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/double-slash-comment-empty-line-before/README.md b/assets/node_modules/stylelint-scss/src/rules/double-slash-comment-empty-line-before/README.md
deleted file mode 100644
index 2c79b9c..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/double-slash-comment-empty-line-before/README.md
+++ /dev/null
@@ -1,151 +0,0 @@
-# double-slash-comment-empty-line-before
-
-Require or disallow an empty line before `//`-comments.
-
-```scss
-a {}
- /* ← */
-// comment /* ↑ */
-/** ↑
-* This line */
-```
-
-The `--fix` option on the [command line](https://github.com/stylelint/stylelint/blob/master/docs/user-guide/cli.md#autofixing-errors) can automatically fix all of the problems reported by this rule.
-
-This rule only works with SCSS-like [single-line comments](https://sass-lang.com/documentation/syntax/comments) and ignores:
-* comments that are the very first nodes in a file;
-* CSS comments (`/* */`);
-* comments that are on the same line as some non-comment code (inline comments).
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-There *must always* be an empty line before `//`-comments.
-
-The following patterns are considered warnings:
-
-```scss
-a {}
-// comment
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {}
-
-// comment
-```
-
-```scss
-a {} // comment
-```
-
-### `"never"`
-
-There *must never* be an empty line before `//`-comments.
-
-The following patterns are considered warnings:
-
-```scss
-a {}
-
-// comment
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {}
-// comment
-```
-
-```scss
-a {} // comment
-```
-
-## Optional options
-
-### `except: ["first-nested"]`
-
-Reverse the primary option for `//`-comments that are nested and the first child of their parent node.
-
-For example, with `"always"`:
-
-The following patterns are considered warnings:
-
-```scss
-a {
-
- // comment
- color: pink;
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- // comment
- color: pink;
-}
-```
-
-### `ignore: ["between-comments", "stylelint-commands"]`
-
-#### `"between-comments"`
-
-Don't require an empty line before `//`-comments that are placed after other `//`-comments or CSS comments.
-
-For example, with `"always"`:
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- background: pink;
-
- // comment
- // comment
- color: #eee;
-}
-```
-
-```scss
-a {
- background: pink;
-
- /* comment */
- // comment
- color: #eee;
-}
-```
-
-#### `"stylelint-commands"`
-
-Ignore `//`-comments that deliver commands to stylelint, e.g. `// stylelint-disable color-no-hex`.
-
-For example, with `"always"`:
-
-The following patterns are considered warnings:
-
-```scss
-a {
- background: pink;
- // not a stylelint command
- color: #eee;
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- background: pink;
- // stylelint-disable color-no-hex
- color: pink;
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/double-slash-comment-inline/README.md b/assets/node_modules/stylelint-scss/src/rules/double-slash-comment-inline/README.md
deleted file mode 100644
index c4ddef6..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/double-slash-comment-inline/README.md
+++ /dev/null
@@ -1,110 +0,0 @@
-# double-slash-comment-inline
-
-Require or disallow `//`-comments to be inline comments.
-
-```scss
-a {
- width: 10px; // inline-comment
-/* ↑
- * Such comments */
-```
-
-An inline comment in terms of this rule is a comment that is placed on the same line with any other code, either before or after it.
-
-This rule only works with SCSS-like [single-line comments](https://sass-lang.com/documentation/syntax/comments) and ignores CSS comments (`/* */`).
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-`//`-comments *must always* be inline comments.
-
-The following patterns are considered warnings:
-
-```scss
-// comment
-a { width: 10px; }
-```
-
-```scss
-a {
- // comment
- width: 10px;
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a { // comment
- width: 10px;
-}
-```
-
-```scss
-a {
- width: 10px; // comment
-}
-```
-
-```scss
-a, // comment
-b {
- width: 10px;
-}
-```
-
-### `"never"`
-
-`//`-comments *must never* be inline comments.
-
-The following patterns are considered warnings:
-
-```scss
-a {
- width: 10px; // comment
-}
-```
-
-```scss
-a, // comment
-b {
- width: 10px;
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-// comment
-a { width: 10px; }
-```
-
-```scss
-a {
- // comment
- width: 10px;
-}
-```
-
-## Optional options
-
-### `ignore: ["stylelint-commands"]`
-
-#### `"stylelint-commands"`
-
-Ignore `//`-comments that deliver commands to stylelint, e.g. `// stylelint-disable color-no-hex`.
-
-For example, with `"always"`:
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- background: pink;
- // stylelint-disable color-no-hex
- color: pink;
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/double-slash-comment-whitespace-inside/README.md b/assets/node_modules/stylelint-scss/src/rules/double-slash-comment-whitespace-inside/README.md
deleted file mode 100644
index f10b23b..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/double-slash-comment-whitespace-inside/README.md
+++ /dev/null
@@ -1,60 +0,0 @@
-# double-slash-comment-whitespace-inside
-
-Require or disallow whitespace after the `//` in `//`-comments
-
-```scss
-a {
- width: 10px; // inline-comment
-/* ↑
- * Such whitespace */
-```
-
-This rule only works with SCSS-like [single-line comments](https://sass-lang.com/documentation/syntax/comments) and ignores CSS comments (`/* */`).
-
-Any number of slases are allowed at the beginning of the comment. So `/// comment` is treated the same way as `// comment`.
-
-Note that a newline is not possible as a whitespace in terms of this rule as `//`-comments are intended to be single-line.
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-There *must always* be whitespace after the `//` inside `//`-comments.
-
-The following patterns are considered warnings:
-
-```scss
-//comment
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-// comment
-```
-
-```scss
-/// comment
-```
-
-### `"never"`
-
-There *must never* be whitespace after the `//` inside `//`-comments.
-
-The following patterns are considered warnings:
-
-```scss
-// comment
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-//comment
-```
-
-```scss
-///comment
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/function-color-relative/README.md b/assets/node_modules/stylelint-scss/src/rules/function-color-relative/README.md
deleted file mode 100644
index b4a904c..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/function-color-relative/README.md
+++ /dev/null
@@ -1,83 +0,0 @@
-# function-color-relative
-
-Encourage the use of the [scale-color](https://sass-lang.com/documentation/modules/color#scale-color) over:
-
-* [darken](https://sass-lang.com/documentation/modules/color#darken)
-* [desaturate](https://sass-lang.com/documentation/modules/color#desaturate)
-* [fade-in](https://sass-lang.com/documentation/modules/color#fade-in)
-* [fade-out](https://sass-lang.com/documentation/modules/color#fade-out)
-* [lighten](https://sass-lang.com/documentation/modules/color#lighten)
-* [opacify](https://sass-lang.com/documentation/modules/color#opacify)
-* [saturate](https://sass-lang.com/documentation/modules/color#saturate)
-* [transparentize](https://sass-lang.com/documentation/modules/color#transparentize)
-
-```scss
-p {
- color: saturate(blue, 20%);
- /** ↑ ↑
- * This function should be scalar-color
- */
-}
-```
-
-## Options
-
-### `true`
-
-The following patterns are considered violations:
-
-```scss
-p {
- color: saturate(blue, 20%);
-}
-```
-
-```scss
-p {
- color: desaturate(blue, 20%);
-}
-```
-
-```scss
-p {
- color: darken(blue, .2);
-}
-```
-
-```scss
-p {
- color: lighten(blue, .2);
-}
-```
-
-```scss
-p {
- color: opacify(blue, .2);
-}
-```
-
-```scss
-p {
- color: fade-in(blue, .2);
-}
-```
-
-```scss
-p {
- color: transparentize(blue, .2);
-}
-```
-
-```scss
-p {
- color: fade-out(blue, .2);
-}
-```
-
-The following patterns are _not_ considered violations:
-
-```scss
- p {
- color: scale-color(blue, $alpha: -40%);
- }
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/function-quote-no-quoted-strings-inside/README.md b/assets/node_modules/stylelint-scss/src/rules/function-quote-no-quoted-strings-inside/README.md
deleted file mode 100644
index b26b03d..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/function-quote-no-quoted-strings-inside/README.md
+++ /dev/null
@@ -1,46 +0,0 @@
-# function-quote-no-quoted-strings-inside
-
-Disallow quoted strings inside the [quote function](https://sass-lang.com/documentation/modules/string#quote)
-
-```scss
-p {
- font-family: quote("Helvetica");
- /** ↑ ↑
- * These quotes are unnecessary
- */
-}
-```
-
-## Options
-
-### `true`
-
-The following patterns are considered violations:
-
-```scss
-a {
- font-family: quote("Helvetica");
-}
-```
-
-```scss
-$font: "Helvetica";
-p {
- font-family: quote($font);
-}
-```
-
-The following patterns are _not_ considered violations:
-
-```scss
-a {
- color: quote(blue);
-}
-```
-
-```scss
-$font: Helvetica;
-p {
- font-family: quote($font);
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/function-unquote-no-unquoted-strings-inside/README.md b/assets/node_modules/stylelint-scss/src/rules/function-unquote-no-unquoted-strings-inside/README.md
deleted file mode 100644
index 79537d9..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/function-unquote-no-unquoted-strings-inside/README.md
+++ /dev/null
@@ -1,46 +0,0 @@
-# function-unquote-no-unquoted-strings-inside
-
-Disallow unquoted strings inside the [unquote function](https://sass-lang.com/documentation/modules/string#unquote)
-
-```scss
-p {
- font-family: unquote(Helvetica);
- /** ↑ ↑
- * This function call is unnecessary
- */
-}
-```
-
-## Options
-
-### `true`
-
-The following patterns are considered violations:
-
-```scss
-a {
- font-family: unquote(Helvetica);
-}
-```
-
-```scss
-$font: Helvetica;
-p {
- font-family: unquote($font);
-}
-```
-
-The following patterns are _not_ considered violations:
-
-```scss
-a {
- color: unquote("blue");
-}
-```
-
-```scss
-$font: "Helvetica";
-p {
- font-family: unquote($font);
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/map-keys-quotes/README.md b/assets/node_modules/stylelint-scss/src/rules/map-keys-quotes/README.md
deleted file mode 100644
index 087177e..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/map-keys-quotes/README.md
+++ /dev/null
@@ -1,26 +0,0 @@
-# map-keys-quotes
-
-Require quoted keys in Sass maps.
-
-```scss
-$test: (Helvetica: 14px, Arial: 25px);
- /** ↑ ↑
- * These words should be quoted.
- */
-```
-
-## Options
-
-### `always`
-
-The following patterns are considered violations:
-
-```scss
-$test: (Helvetica: 14px, Arial: 25px);
-```
-
-The following patterns are _not_ considered violations:
-
-```scss
-$test: ("foo": 14px, "bar": 25px);
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/media-feature-value-dollar-variable/README.md b/assets/node_modules/stylelint-scss/src/rules/media-feature-value-dollar-variable/README.md
deleted file mode 100644
index 5977554..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/media-feature-value-dollar-variable/README.md
+++ /dev/null
@@ -1,86 +0,0 @@
-# media-feature-value-dollar-variable
-
-Require a media feature value be a `$`-variable or disallow `$`-variables in media feature values.
-
-```scss
-@media (max-width: $var) { a { color: red; } }
-// ↑
-// Require or disallow this
-}
-```
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-A media feature value *must consist* of just a single `$`-variable (possibly with inteprolation).
-
-The following patterns are considered warnings:
-
-```scss
-@media (max-width: 300px) { b { color: red; } }
-```
-
-```scss
-@media (max-width: $var + 10px) { b { color: red; } }
-```
-
-```scss
-@media screen and (max-width: $var), or (min-width: 100px){ b { color: red; } }
-```
-
-```scss
-@media screen and (max-width: #{$val} + 10px) { a { display: none; } }
-```
-
-```scss
-@media screen and (max-width: #{$val + $x} ) { a { display: none; } }
-```
-
-```scss
-@media screen and (min-width: funcName($p)){ b { color: red; } }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@media ( max-width: $var ) {b { color: red; }}
-```
-
-```scss
-@media ( max-width: #{$var}) {b { color: red; }}
-```
-
-### `"never"`
-
-There *must never* be a `$`-variable in a media feature value. Even as a parameter to a function call.
-
-The following patterns are considered warnings:
-
-```scss
-@media screen and (min-width: $var){ b { color: red; } }
-```
-
-```scss
-@media screen and (min-width: 100px + $var){ b { color: red; } }
-```
-
-```scss
-@media screen and (min-width: funcName($var)){ b { color: red; } }
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-@media screen and (min-width: 100px){ b { color: red; } }
-```
-
-```scss
-@media screen and (min-width: 100px + 10px){ b { color: red; } }
-```
-
-```scss
-@media screen and (min-width: funcName(10px)){ b { color: red; } }
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/no-dollar-variables/README.md b/assets/node_modules/stylelint-scss/src/rules/no-dollar-variables/README.md
deleted file mode 100644
index bb282bf..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/no-dollar-variables/README.md
+++ /dev/null
@@ -1,38 +0,0 @@
-# no-dollar-variables
-
-Disallow dollar variables within a stylesheet.
-
-```scss
- $a: 1;
-/** ↑
- * These dollar variables */
-```
-
-## Options
-
-### `true`
-
-The following patterns are considered violations:
-
-```scss
-$a: 1;
-```
-
-```scss
-$a: 1;
-$b: 2;
-```
-
-```scss
-.b {
- $a: 1;
-}
-```
-
-The following patterns are *not* considered violations:
-
-```scss
-a {
- color: blue;
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/no-duplicate-dollar-variables/README.md b/assets/node_modules/stylelint-scss/src/rules/no-duplicate-dollar-variables/README.md
deleted file mode 100644
index 4a03860..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/no-duplicate-dollar-variables/README.md
+++ /dev/null
@@ -1,143 +0,0 @@
-# no-duplicate-dollar-variables
-
-Disallow duplicate dollar variables within a stylesheet.
-
-```scss
- $a: 1;
- $a: 2;
-/** ↑
- * These are duplicates */
-```
-
-## Options
-
-### `true`
-
-The following patterns are considered violations:
-
-```scss
-$a: 1;
-$a: 2;
-```
-
-```scss
-$a: 1;
-$b: 2;
-$a: 3;
-```
-
-```scss
-$a: 1;
-.b {
- $a: 1;
-}
-```
-
-```scss
-$a: 1;
-.b {
- .c {
- $a: 1;
- }
-}
-```
-
-```scss
-$a: 1;
-@mixin b {
- $a: 1;
-}
-```
-
-The following patterns are _not_ considered violations:
-
-```scss
-$a: 1;
-$b: 2;
-```
-
-```scss
-$a: 1;
-.b {
- $b: 2;
-}
-```
-
-### `ignoreInside: ["at-rule", "nested-at-rule"]`
-
-#### `"at-rule"`
-
-Ignores dollar variables that are inside both nested and non-nested at-rules (`@media`, `@mixin`, etc.).
-
-Given:
-
-```json
-{ "ignoreInside": ["at-rule"] }
-```
-
-The following patterns are _not_ considered warnings:
-
-```scss
-$a: 1;
-@mixin c {
- $a: 1;
-}
-```
-
-```scss
-$a: 1;
-.b {
- @mixin c {
- $a: 1;
- }
-}
-```
-
-#### `"nested-at-rule"`
-
-Ignores dollar variables that are inside nested at-rules (`@media`, `@mixin`, etc.).
-
-Given:
-
-```json
-{ "ignoreInside": ["nested-at-rule"] }
-```
-
-The following patterns are _not_ considered warnings:
-
-```scss
-$a: 1;
-.b {
- @mixin c {
- $a: 1;
- }
-}
-```
-
-### `ignoreInsideAtRules: ["array", "of", "at-rules"]`
-
-Ignores all variables that are inside specified at-rules.
-
-Given:
-
-```json
-{ "ignoreInsideAtRules": ["if", "mixin"] }
-```
-
-The following patterns are _not_ considered warnings:
-
-```scss
-$a: 1;
-
-@mixin b {
- $a: 2;
-}
-```
-
-```scss
-$a: 1;
-
-@if (true) {
- $a: 2;
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/no-duplicate-mixins/README.md b/assets/node_modules/stylelint-scss/src/rules/no-duplicate-mixins/README.md
deleted file mode 100644
index cdb7bb2..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/no-duplicate-mixins/README.md
+++ /dev/null
@@ -1,83 +0,0 @@
-# no-duplicate-mixins
-
-Disallow duplicate mixins within a stylesheet.
-
-```scss
-@mixin font-size-default {
- font-size: 16px;
-}
-@mixin font-size-default {
- font-size: 18px;
-}
-/** ↑
- * These are duplicates */
-```
-
-## Options
-
-### `true`
-
-The following patterns are considered violations:
-
-```scss
-@mixin font-size-default {
- font-size: 16px;
-}
-@mixin font-size-default {
- font-size: 18px;
-}
-```
-
-```scss
-@mixin font-size-default {
- font-size: 16px;
-}
-@mixin font-size-sm {
- font-size: 14px;
-}
-@mixin font-size-default {
- font-size: 18px;
-}
-```
-
-```scss
-@mixin font-size {
- font-size: 16px;
-}
-@mixin font-size($var) {
- font-size: $var;
-}
-```
-
-```scss
-@mixin font-size($property, $value) {
- #{$property}: $value;
-}
-@mixin font-size($var) {
- font-size: $var;
-}
-```
-
-```scss
-@mixin font-size {
- color: blue;
-}
-
-.b {
- @mixin font-size {
- color: red;
- }
- @include font-size;
-}
-```
-
-The following patterns are _not_ considered violations:
-
-```scss
-@mixin font-size-default {
- font-size: 16px;
-}
-@mixin font-size-lg {
- font-size: 18px;
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/operator-no-newline-after/README.md b/assets/node_modules/stylelint-scss/src/rules/operator-no-newline-after/README.md
deleted file mode 100644
index 677f1e6..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/operator-no-newline-after/README.md
+++ /dev/null
@@ -1,54 +0,0 @@
-# operator-no-newline-after
-
-Disallow linebreaks after Sass operators.
-
-```scss
-a { width: 10px + $n; }
-/** ↑
- * Linebreaks after this */
-```
-
-This rule checks math operators (`+`, `-`, `/`, `*`, `%`) and comparison operators (`>`, `<`, `!=`, `==`, `>=`, `<=`).
-
-Not all symbols that correspond to math operators are actually considered operators by Sass. Some of the exceptions are:
-
-* `+` and `-` as signs before values;
-* `+` and `-` as signs in [space-delimited lists](https://sass-lang.com/documentation/operators/string);
-* `-` as part of [a string](https://sass-lang.com/documentation/operators/string) or [a Sass identifier](https://sass-lang.com/documentation/operators/numeric#unary-operators), e.g. a variable;
-* `/` as a CSS delimiter in property values like `font: 10px/1.2 Arial;` ([read more](https://sass-lang.com/documentation/operators/numeric#slash-separated-values)).
-
-For more details refer to [Sass official documentation](https://sass-lang.com/documentation). An online Sass compiler - [Sassmeister](https://www.sassmeister.com/) - could also come in handy.
-
-The following patterns are considered warnings:
-
-```scss
-a { width: 10 +
-1; }
-```
-
-```scss
-a {
- width: 10 +
- 1;
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- width: str- // not a math operator, ignored
- some;
-}
-```
-
-```scss
-a { width: 10px - 1; }
-```
-
-```scss
-a {
- width: 10px * 1.7 // the newline is not right after the operator
- + 1;
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/operator-no-newline-before/README.md b/assets/node_modules/stylelint-scss/src/rules/operator-no-newline-before/README.md
deleted file mode 100644
index 81b358a..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/operator-no-newline-before/README.md
+++ /dev/null
@@ -1,55 +0,0 @@
-# operator-no-newline-before
-
-Disallow linebreaks before Sass operators.
-
-```scss
-a { width: 10px
- + $n; }
-/** ↑
- * Linebreaks before this */
-```
-
-This rule checks math operators (`+`, `-`, `/`, `*`, `%`) and comparison operators (`>`, `<`, `!=`, `==`, `>=`, `<=`).
-
-Not all symbols that correspond to math operators are actually considered operators by Sass. Some of the exceptions are:
-
-* `+` and `-` as signs before values;
-* `+` and `-` as signs in [space-delimited lists](https://sass-lang.com/documentation/operators/string);
-* `-` as part of [a string](https://sass-lang.com/documentation/operators/string) or [a Sass identifier](https://sass-lang.com/documentation/operators/numeric#unary-operators), e.g. a variable;
-* `/` as a CSS delimiter in property values like `font: 10px/1.2 Arial;` ([read more](https://sass-lang.com/documentation/operators/numeric#slash-separated-values)).
-
-For more details refer to [Sass official documentation](https://sass-lang.com/documentation). An online Sass compiler - [Sassmeister](https://www.sassmeister.com/) - could also come in handy.
-
-The following patterns are considered warnings:
-
-```scss
-a { width: 10
-+ 1; }
-```
-
-```scss
-a {
- width: 10
- + 1;
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a {
- width: 10px
- -1; // not a math operator, ignored
-}
-```
-
-```scss
-a { width: 10px - 1; }
-```
-
-```scss
-a {
- width: 100px +
- $var * 0.5625; // the newline is not right before the operator
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/operator-no-unspaced/README.md b/assets/node_modules/stylelint-scss/src/rules/operator-no-unspaced/README.md
deleted file mode 100644
index 4bef685..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/operator-no-unspaced/README.md
+++ /dev/null
@@ -1,100 +0,0 @@
-# operator-no-unspaced
-
-Disallow unspaced operators in Sass operations.
-
-```scss
-a { width: 10px*$n; }
-/** ↑
- * The space around this operator */
-```
-
-This rule checks math operators (`+`, `-`, `/`, `*`, `%`) and comparison operators (`>`, `<`, `!=`, `==`, `>=`, `<=`).
-
-Not all symbols that correspond to math operators are actually considered operators by Sass. Some of the exceptions are:
-
-* `+` and `-` as signs before values;
-* `+` and `-` as signs in [space-delimited lists](https://sass-lang.com/documentation/operators/string);
-* `-` as part of [a string](https://sass-lang.com/documentation/operators/string) or [a Sass identifier](https://sass-lang.com/documentation/operators/numeric#unary-operators), e.g. a variable;
-* `/` as a CSS delimiter in property values like `font: 10px/1.2 Arial;` ([read more](https://sass-lang.com/documentation/operators/numeric#slash-separated-values)).
-
-For more details refer to [Sass official documentation](https://sass-lang.com/documentation/file.SASS_REFERENCE.html). An online Sass compiler - [Sassmeister](https://www.sassmeister.com/) - could also come in handy.
-
-The following patterns are considered warnings:
-
-```scss
-a { width: 10+1; }
-```
-
-```scss
-a { width: 10+ 1; }
-```
-
-```scss
-a { width: 10-1; }
-```
-
-```scss
-a { width: 10px* 1.5; }
-```
-
-```scss
-@if ($var==10) { ... }
-```
-
-```scss
-a { width: 10px * 1.5; } // More than one space
-```
-
-```scss
-a { width: (10) /1; } // Has a value inside parens on one side, so is an operation
-```
-
-```scss
-// Operations can be inside interpolation in selectors, property names, etc.
-.class#{1 +1}name {
- color: red;
-}
-
-p {
- background-#{\"col\" +\"or\"}: red;
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-a { width: 10 * 1; }
-```
-
-```scss
-a { width: 10 +1; } // A space-delimited Sass list
-```
-
-```scss
-// A space-delimited Sass list, in "10px-" "10" is a number, "px-" is a unit
-a { width: 10px- 1; }
-```
-
-```scss
-a { width: 10px/1; } // Compiled as CSS, as in "font: 10px/1 ..."
-```
-
-```scss
-a { width: (10) /#{1}; } // Has interpolation on one of the sides, so not an operation
-```
-
-```scss
-a { width: $var-1; } // "$var-1" is a variable name
-```
-
-```scss
-a { width: "10*1"; } // Inside a string, ignored
-```
-
-```scss
-// Linebreak will do as a whitespace; indentation before "-" and trailing spaces after "1" are left to the corresponding stylelint rules
-a {
- width: 1
- - a;
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/partial-no-import/README.md b/assets/node_modules/stylelint-scss/src/rules/partial-no-import/README.md
deleted file mode 100644
index 4a280b4..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/partial-no-import/README.md
+++ /dev/null
@@ -1,69 +0,0 @@
-# partial-no-import
-
-Disallow non-CSS `@import`s in partial files.
-
-```scss
-// path/to/_file.scss:
-/* ↑ in partial files */
-
- @import "path/to/file.scss"
-/*↑ Disallow imports */
-```
-
-The rule skips CSS files (doesn't report any `@import`s in them).
-
-The rule also ignores [cases](https://sass-lang.com/documentation/at-rules/import) when Sass considers an `@import` command just a plain CSS import:
-
-* If the file’s extension is `.css`.
-* If the filename begins with `http://` (or any other protocol).
-* If the filename is a `url()`.
-* If the `@import` has any media queries.
-
-The following patterns are considered warnings:
-
-```scss
-// path/to/_file.scss:
-
-@import "foo.scss";
-```
-
-```scss
-// path/to/_file.less:
-@import "path/fff.less";
-```
-
-```scss
-// path/to/_file.scss:
-@import "path\\fff.supa";
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-// path/to/file.scss:
-@import "path/fff";
-
-/* @import in a file that is not a partial */
-```
-
-```scss
-// path/to/_file.scss:
-@import url("path/_file.css"); /* has url(), so doesn't count as a partial @import */
-```
-
-```scss
-// path/to/_file.scss:
-@import "file.css"; /* Has ".css" extension, so doesn't count as a partial @import */
-```
-
-```scss
-// path/to/_file.scss:
-@import "http://_file.scss";
-@import "//_file.scss";
-/* Both are URIs, so don't count as partial @imports */
-```
-
-```scss
-// path/to/_file.scss:
-@import "file.scss" screen; /* Has a media query, so doesn't count as a partial @import */
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/percent-placeholder-pattern/README.md b/assets/node_modules/stylelint-scss/src/rules/percent-placeholder-pattern/README.md
deleted file mode 100644
index d4e85c2..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/percent-placeholder-pattern/README.md
+++ /dev/null
@@ -1,57 +0,0 @@
-# percent-placeholder-pattern
-
-Specify a pattern for `%`-placeholders.
-
-```scss
- %foobar { display: flex; }
-/** ↑
- * The pattern of this */
-```
-
-## Options
-
-`regex` or `string`
-
-A string will be translated into a RegExp like so `new RegExp(yourString)` — so be sure to escape properly.
-
-Nested selectors will be resolved before checking.
-
-The selector value *after `%`* will be checked. No need to include `%` in your pattern.
-
-### E.g. `/^foo-[a-z]+$/`
-
-The following patterns are considered warnings:
-
-```scss
-%myriad { display: flex; }
-```
-
-```scss
-%foo-bar {
- &-supa { display: flex; } /* %foo-bar matches, but %foo-bar-supa doesn't */
-}
-```
-
-```scss
-%foo- { /* %foo- on the 1st leves doesn't match */
- &bar { display: flex; }
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-%foo-aimp { display: flex; }
-```
-
-```scss
-%foo-bar {
- &lignt { display: flex; }
-}
-```
-
-```scss
-.p {
- @extend %mathy; // The rule only checks placeholder definitions
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/selector-nest-combinators/README.md b/assets/node_modules/stylelint-scss/src/rules/selector-nest-combinators/README.md
deleted file mode 100644
index 8c6f94d..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/selector-nest-combinators/README.md
+++ /dev/null
@@ -1,221 +0,0 @@
-# selector-nest-combinators
-
-Require or disallow nesting of combinators in selectors
-
-```scss
-/* Examples of selectors without nesting of combinators */
-.foo .bar {}
-
-.foo.bar {}
-
-.foo > .bar {}
-
-.foo:hover {}
-
-/* Corresponding selectors with combinators nested */
-.foo {
- .bar {}
-}
-
-.foo {
- &.bar {}
-}
-
-.foo {
- & > .bar {}
-}
-
-.foo {
- &:hover {}
-}
-```
-
-## Options
-
-`string`: `"always"|"never"`
-
-### `"always"`
-
-*Every combinator* in a selector *must be* nested where possible without altering the existing resolved selector.
-
-Sections of selectors preceding a parent selector are ignored with `always`.
-e.g.
-
-```scss
-.foo {
- .bar.baz & {}
-}
-```
-
-Sections of selectors within pseudo selectors are also ignored with `always`.
-e.g.
-
-```scss
-.foo {
- &:not(.bar .baz) {}
-}
-```
-
-while this could be refactored to:
-
-```scss
-.bar {
- .baz {
- .foo:not(&) {}
- }
-}
-```
-
-There are variances in the way this is compiled between compilers, therefore for the purposes of this rule the selector sections within pseudo selectors are being ignored.
-
-The following patterns are considered warnings:
-
-```scss
-.foo .bar {}
-```
-
-```scss
-.foo.bar {}
-```
-
-```scss
-.foo > .bar {}
-```
-
-```scss
-.foo:hover {}
-```
-
-```scss
-a[href] {}
-```
-
-```scss
-* + li {}
-```
-
-```scss
-:nth-child(2n - 1):last-child {}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-.foo {
- .bar {}
-}
-```
-
-```scss
-.foo {
- &.bar {}
-}
-```
-
-```scss
-.foo {
- & > .bar {}
-}
-```
-
-```scss
-.foo {
- &:hover {}
-}
-```
-
-```scss
-a {
- &[href] {}
-}
-```
-
-```scss
-* {
- & + li {}
-}
-```
-
-```scss
-:nth-child(2n - 1) {
- &:last-child {}
-}
-```
-
-### `"never"`
-
-Nested of selectors are not allowed.
-
-The following patterns are considered warnings:
-
-```scss
-.foo {
- .bar {}
-}
-```
-
-```scss
-.foo {
- &.bar {}
-}
-```
-
-```scss
-.foo {
- & > .bar {}
-}
-```
-
-```scss
-.foo {
- &:hover {}
-}
-```
-
-```scss
-a {
- &[href] {}
-}
-```
-
-```scss
-* {
- & + li {}
-}
-```
-
-```scss
-:nth-child(2n - 1) {
- &:last-child {}
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-.foo .bar {}
-```
-
-```scss
-.foo.bar {}
-```
-
-```scss
-.foo > .bar {}
-```
-
-```scss
-.foo:hover {}
-```
-
-```scss
-a[href] {}
-```
-
-```scss
-* + li {}
-```
-
-```scss
-:nth-child(2n - 1):last-child {}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/selector-no-redundant-nesting-selector/README.md b/assets/node_modules/stylelint-scss/src/rules/selector-no-redundant-nesting-selector/README.md
deleted file mode 100644
index af07ba2..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/selector-no-redundant-nesting-selector/README.md
+++ /dev/null
@@ -1,61 +0,0 @@
-# selector-no-redundant-nesting-selector
-
-Disallow redundant nesting selectors (`&`).
-
-```scss
-p {
- & a {}
-//↑
-// This type of selector
-}
-```
-
-The following patterns are considered warnings:
-
-```scss
-p {
- & a {}
-}
-```
-
-```scss
-p {
- & > a {}
-}
-```
-
-```scss
-p {
- & .class {}
-}
-```
-
-```scss
-p {
- & + .foo {}
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-p {
- &.foo {}
-}
-```
-
-```scss
-p {
- .foo > & {}
-}
-```
-
-```scss
-p {
- &,
- .foo,
- .bar {
- margin: 0;
- }
-}
-```
diff --git a/assets/node_modules/stylelint-scss/src/rules/selector-no-union-class-name/README.md b/assets/node_modules/stylelint-scss/src/rules/selector-no-union-class-name/README.md
deleted file mode 100644
index ef773c9..0000000
--- a/assets/node_modules/stylelint-scss/src/rules/selector-no-union-class-name/README.md
+++ /dev/null
@@ -1,46 +0,0 @@
-# selector-no-union-class-name
-
-Disallow union class names with the parent selector (`&`).
-
-```scss
-.class {
- &-union {
-//↑
-// This type usage of `&`
- }
-}
-```
-
-The following patterns are considered warnings:
-
-```scss
-.class {
- &-union {}
-}
-```
-
-```scss
-.class {
- &_union {}
-}
-```
-
-```scss
-.class {
- &union {}
-}
-```
-
-The following patterns are *not* considered warnings:
-
-```scss
-.class {
- &.foo {}
-}
-```
-
-```scss
-.class {
- & p {}
-}
-```