.
This commit is contained in:
		
							
								
								
									
										98
									
								
								qwen/nodejs/node_modules/eslint/lib/rules/jsx-quotes.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										98
									
								
								qwen/nodejs/node_modules/eslint/lib/rules/jsx-quotes.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,98 @@
 | 
			
		||||
/**
 | 
			
		||||
 * @fileoverview A rule to ensure consistent quotes used in jsx syntax.
 | 
			
		||||
 * @author Mathias Schreck <https://github.com/lo1tuma>
 | 
			
		||||
 * @deprecated in ESLint v8.53.0
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
"use strict";
 | 
			
		||||
 | 
			
		||||
//------------------------------------------------------------------------------
 | 
			
		||||
// Requirements
 | 
			
		||||
//------------------------------------------------------------------------------
 | 
			
		||||
 | 
			
		||||
const astUtils = require("./utils/ast-utils");
 | 
			
		||||
 | 
			
		||||
//------------------------------------------------------------------------------
 | 
			
		||||
// Constants
 | 
			
		||||
//------------------------------------------------------------------------------
 | 
			
		||||
 | 
			
		||||
const QUOTE_SETTINGS = {
 | 
			
		||||
    "prefer-double": {
 | 
			
		||||
        quote: "\"",
 | 
			
		||||
        description: "singlequote",
 | 
			
		||||
        convert(str) {
 | 
			
		||||
            return str.replace(/'/gu, "\"");
 | 
			
		||||
        }
 | 
			
		||||
    },
 | 
			
		||||
    "prefer-single": {
 | 
			
		||||
        quote: "'",
 | 
			
		||||
        description: "doublequote",
 | 
			
		||||
        convert(str) {
 | 
			
		||||
            return str.replace(/"/gu, "'");
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
//------------------------------------------------------------------------------
 | 
			
		||||
// Rule Definition
 | 
			
		||||
//------------------------------------------------------------------------------
 | 
			
		||||
 | 
			
		||||
/** @type {import('../shared/types').Rule} */
 | 
			
		||||
module.exports = {
 | 
			
		||||
    meta: {
 | 
			
		||||
        deprecated: true,
 | 
			
		||||
        replacedBy: [],
 | 
			
		||||
        type: "layout",
 | 
			
		||||
 | 
			
		||||
        docs: {
 | 
			
		||||
            description: "Enforce the consistent use of either double or single quotes in JSX attributes",
 | 
			
		||||
            recommended: false,
 | 
			
		||||
            url: "https://eslint.org/docs/latest/rules/jsx-quotes"
 | 
			
		||||
        },
 | 
			
		||||
 | 
			
		||||
        fixable: "whitespace",
 | 
			
		||||
 | 
			
		||||
        schema: [
 | 
			
		||||
            {
 | 
			
		||||
                enum: ["prefer-single", "prefer-double"]
 | 
			
		||||
            }
 | 
			
		||||
        ],
 | 
			
		||||
        messages: {
 | 
			
		||||
            unexpected: "Unexpected usage of {{description}}."
 | 
			
		||||
        }
 | 
			
		||||
    },
 | 
			
		||||
 | 
			
		||||
    create(context) {
 | 
			
		||||
        const quoteOption = context.options[0] || "prefer-double",
 | 
			
		||||
            setting = QUOTE_SETTINGS[quoteOption];
 | 
			
		||||
 | 
			
		||||
        /**
 | 
			
		||||
         * Checks if the given string literal node uses the expected quotes
 | 
			
		||||
         * @param {ASTNode} node A string literal node.
 | 
			
		||||
         * @returns {boolean} Whether or not the string literal used the expected quotes.
 | 
			
		||||
         * @public
 | 
			
		||||
         */
 | 
			
		||||
        function usesExpectedQuotes(node) {
 | 
			
		||||
            return node.value.includes(setting.quote) || astUtils.isSurroundedBy(node.raw, setting.quote);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return {
 | 
			
		||||
            JSXAttribute(node) {
 | 
			
		||||
                const attributeValue = node.value;
 | 
			
		||||
 | 
			
		||||
                if (attributeValue && astUtils.isStringLiteral(attributeValue) && !usesExpectedQuotes(attributeValue)) {
 | 
			
		||||
                    context.report({
 | 
			
		||||
                        node: attributeValue,
 | 
			
		||||
                        messageId: "unexpected",
 | 
			
		||||
                        data: {
 | 
			
		||||
                            description: setting.description
 | 
			
		||||
                        },
 | 
			
		||||
                        fix(fixer) {
 | 
			
		||||
                            return fixer.replaceText(attributeValue, setting.convert(attributeValue.raw));
 | 
			
		||||
                        }
 | 
			
		||||
                    });
 | 
			
		||||
                }
 | 
			
		||||
            }
 | 
			
		||||
        };
 | 
			
		||||
    }
 | 
			
		||||
};
 | 
			
		||||
		Reference in New Issue
	
	Block a user