123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990 |
- // @ts-nocheck
-
- 'use strict';
-
- const _ = require('lodash');
- const isAutoprefixable = require('../../utils/isAutoprefixable');
- const isStandardSyntaxDeclaration = require('../../utils/isStandardSyntaxDeclaration');
- const isStandardSyntaxProperty = require('../../utils/isStandardSyntaxProperty');
- const optionsMatches = require('../../utils/optionsMatches');
- const report = require('../../utils/report');
- const ruleMessages = require('../../utils/ruleMessages');
- const styleSearch = require('style-search');
- const validateOptions = require('../../utils/validateOptions');
- const vendor = require('../../utils/vendor');
-
- const ruleName = 'value-no-vendor-prefix';
-
- const messages = ruleMessages(ruleName, {
- rejected: (value) => `Unexpected vendor-prefix "${value}"`,
- });
-
- const valuePrefixes = ['-webkit-', '-moz-', '-ms-', '-o-'];
-
- function rule(actual, options, context) {
- return (root, result) => {
- const validOptions = validateOptions(
- result,
- ruleName,
- { actual },
- {
- optional: true,
- actual: options,
- possible: {
- ignoreValues: [_.isString],
- },
- },
- );
-
- if (!validOptions) {
- return;
- }
-
- root.walkDecls((decl) => {
- if (
- !isStandardSyntaxDeclaration(decl) ||
- !isStandardSyntaxProperty(decl.prop) ||
- !decl.value.startsWith('-')
- ) {
- return;
- }
-
- const prop = decl.prop;
- const value = decl.value;
- const unprefixedValue = vendor.unprefixed(value);
-
- //return early if value is to be ignored
- if (optionsMatches(options, 'ignoreValues', unprefixedValue)) {
- return;
- }
-
- // Search the full declaration in order to get an accurate index
-
- styleSearch({ source: value.toLowerCase(), target: valuePrefixes }, (match) => {
- const fullIdentifier = /^(-[a-z-]+)\b/i.exec(value.slice(match.startIndex))[1];
-
- if (!isAutoprefixable.propertyValue(prop, fullIdentifier)) {
- return;
- }
-
- if (context.fix) {
- decl.value = isAutoprefixable.unprefix(decl.value);
-
- return;
- }
-
- report({
- message: messages.rejected(fullIdentifier),
- node: decl,
- index: prop.length + (decl.raws.between || '').length + match.startIndex,
- result,
- ruleName,
- });
- });
- });
- };
- }
-
- rule.ruleName = ruleName;
- rule.messages = messages;
- module.exports = rule;
|