|
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- // @ts-nocheck
-
- 'use strict';
-
- const _ = require('lodash');
- const isAutoprefixable = require('../../utils/isAutoprefixable');
- const optionsMatches = require('../../utils/optionsMatches');
- const report = require('../../utils/report');
- const ruleMessages = require('../../utils/ruleMessages');
- const validateOptions = require('../../utils/validateOptions');
- const vendor = require('../../utils/vendor');
-
- const ruleName = 'property-no-vendor-prefix';
-
- const messages = ruleMessages(ruleName, {
- rejected: (property) => `Unexpected vendor-prefix "${property}"`,
- });
-
- function rule(actual, options, context) {
- return (root, result) => {
- const validOptions = validateOptions(
- result,
- ruleName,
- { actual },
- {
- optional: true,
- actual: options,
- possible: {
- ignoreProperties: [_.isString, _.isRegExp],
- },
- },
- );
-
- if (!validOptions) {
- return;
- }
-
- root.walkDecls((decl) => {
- const prop = decl.prop;
- const unprefixedProp = vendor.unprefixed(prop);
-
- //return early if property is to be ignored
- if (optionsMatches(options, 'ignoreProperties', unprefixedProp)) {
- return;
- }
-
- // Make sure there's a vendor prefix,
- // but this isn't a custom property
-
- if (prop[0] !== '-' || prop[1] === '-') {
- return;
- }
-
- if (!isAutoprefixable.property(prop)) {
- return;
- }
-
- if (context.fix) {
- decl.prop = isAutoprefixable.unprefix(decl.prop);
-
- return;
- }
-
- report({
- message: messages.rejected(prop),
- node: decl,
- result,
- ruleName,
- });
- });
- };
- }
-
- rule.ruleName = ruleName;
- rule.messages = messages;
- module.exports = rule;
|