mirror of https://github.com/vector-im/riot-web
				
				
				
			
		
			
				
	
	
		
			86 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
module.exports = {
 | 
						|
    plugins: ["matrix-org"],
 | 
						|
    extends: [
 | 
						|
        "plugin:matrix-org/babel",
 | 
						|
        "plugin:matrix-org/react",
 | 
						|
    ],
 | 
						|
    env: {
 | 
						|
        browser: true,
 | 
						|
        node: true,
 | 
						|
    },
 | 
						|
    globals: {
 | 
						|
        LANGUAGES_FILE: "readonly",
 | 
						|
    },
 | 
						|
    rules: {
 | 
						|
        // Things we do that break the ideal style
 | 
						|
        "no-constant-condition": "off",
 | 
						|
        "prefer-promise-reject-errors": "off",
 | 
						|
        "no-async-promise-executor": "off",
 | 
						|
        "quotes": "off",
 | 
						|
        "no-extra-boolean-cast": "off",
 | 
						|
 | 
						|
        // Bind or arrow functions in props causes performance issues (but we
 | 
						|
        // currently use them in some places).
 | 
						|
        // It's disabled here, but we should using it sparingly.
 | 
						|
        "react/jsx-no-bind": "off",
 | 
						|
        "react/jsx-key": ["error"],
 | 
						|
 | 
						|
        "no-restricted-properties": [
 | 
						|
            "error",
 | 
						|
            ...buildRestrictedPropertiesOptions(
 | 
						|
                ["window.innerHeight", "window.innerWidth", "window.visualViewport"],
 | 
						|
                "Use UIStore to access window dimensions instead.",
 | 
						|
            ),
 | 
						|
            ...buildRestrictedPropertiesOptions(
 | 
						|
                ["*.mxcUrlToHttp", "*.getHttpUriForMxc"],
 | 
						|
                "Use Media helper instead to centralise access for customisation.",
 | 
						|
            ),
 | 
						|
        ],
 | 
						|
    },
 | 
						|
    overrides: [{
 | 
						|
        files: [
 | 
						|
            "src/**/*.{ts,tsx}",
 | 
						|
            "test/**/*.{ts,tsx}",
 | 
						|
        ],
 | 
						|
        extends: [
 | 
						|
            "plugin:matrix-org/typescript",
 | 
						|
            "plugin:matrix-org/react",
 | 
						|
        ],
 | 
						|
        rules: {
 | 
						|
            // Things we do that break the ideal style
 | 
						|
            "prefer-promise-reject-errors": "off",
 | 
						|
            "quotes": "off",
 | 
						|
            "no-extra-boolean-cast": "off",
 | 
						|
 | 
						|
            // Remove Babel things manually due to override limitations
 | 
						|
            "@babel/no-invalid-this": ["off"],
 | 
						|
 | 
						|
            // We're okay being explicit at the moment
 | 
						|
            "@typescript-eslint/no-empty-interface": "off",
 | 
						|
            // We disable this while we're transitioning
 | 
						|
            "@typescript-eslint/no-explicit-any": "off",
 | 
						|
            // We'd rather not do this but we do
 | 
						|
            "@typescript-eslint/ban-ts-comment": "off",
 | 
						|
        },
 | 
						|
    }],
 | 
						|
    settings: {
 | 
						|
        react: {
 | 
						|
            version: "detect",
 | 
						|
        }
 | 
						|
    }
 | 
						|
};
 | 
						|
 | 
						|
function buildRestrictedPropertiesOptions(properties, message) {
 | 
						|
    return properties.map(prop => {
 | 
						|
        let [object, property] = prop.split(".");
 | 
						|
        if (object === "*") {
 | 
						|
            object = undefined;
 | 
						|
        }
 | 
						|
        return {
 | 
						|
            object,
 | 
						|
            property,
 | 
						|
            message,
 | 
						|
        };
 | 
						|
    });
 | 
						|
}
 |