1 |
|
2 |
|
3 | 'use strict';
|
4 |
|
5 | const _ = require('lodash');
|
6 | const isAutoprefixable = require('../../utils/isAutoprefixable');
|
7 | const optionsMatches = require('../../utils/optionsMatches');
|
8 | const postcss = require('postcss');
|
9 | const report = require('../../utils/report');
|
10 | const ruleMessages = require('../../utils/ruleMessages');
|
11 | const validateOptions = require('../../utils/validateOptions');
|
12 |
|
13 | const ruleName = 'property-no-vendor-prefix';
|
14 |
|
15 | const messages = ruleMessages(ruleName, {
|
16 | rejected: (property) => `Unexpected vendor-prefix "${property}"`,
|
17 | });
|
18 |
|
19 | function rule(actual, options, context) {
|
20 | return (root, result) => {
|
21 | const validOptions = validateOptions(
|
22 | result,
|
23 | ruleName,
|
24 | { actual },
|
25 | {
|
26 | optional: true,
|
27 | actual: options,
|
28 | possible: {
|
29 | ignoreProperties: [_.isString, _.isRegExp],
|
30 | },
|
31 | },
|
32 | );
|
33 |
|
34 | if (!validOptions) {
|
35 | return;
|
36 | }
|
37 |
|
38 | root.walkDecls((decl) => {
|
39 | const prop = decl.prop;
|
40 | const unprefixedProp = postcss.vendor.unprefixed(prop);
|
41 |
|
42 |
|
43 | if (optionsMatches(options, 'ignoreProperties', unprefixedProp)) {
|
44 | return;
|
45 | }
|
46 |
|
47 |
|
48 |
|
49 |
|
50 | if (prop[0] !== '-' || prop[1] === '-') {
|
51 | return;
|
52 | }
|
53 |
|
54 | if (!isAutoprefixable.property(prop)) {
|
55 | return;
|
56 | }
|
57 |
|
58 | if (context.fix) {
|
59 | decl.prop = isAutoprefixable.unprefix(decl.prop);
|
60 |
|
61 | return;
|
62 | }
|
63 |
|
64 | report({
|
65 | message: messages.rejected(prop),
|
66 | node: decl,
|
67 | result,
|
68 | ruleName,
|
69 | });
|
70 | });
|
71 | };
|
72 | }
|
73 |
|
74 | rule.ruleName = ruleName;
|
75 | rule.messages = messages;
|
76 | module.exports = rule;
|