Permalink
Cannot retrieve contributors at this time
72 lines (68 sloc)
2.9 KB
Name already in use
A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
codeql-action/node_modules/eslint-plugin-jsx-a11y/lib/rules/click-events-have-key-events.js
Go to fileThis commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
"use strict"; | |
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports["default"] = void 0; | |
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); | |
var _ariaQuery = require("aria-query"); | |
var _jsxAstUtils = require("jsx-ast-utils"); | |
var _arrayIncludes = _interopRequireDefault(require("array-includes")); | |
var _schemas = require("../util/schemas"); | |
var _getElementType = _interopRequireDefault(require("../util/getElementType")); | |
var _isHiddenFromScreenReader = _interopRequireDefault(require("../util/isHiddenFromScreenReader")); | |
var _isInteractiveElement = _interopRequireDefault(require("../util/isInteractiveElement")); | |
var _isPresentationRole = _interopRequireDefault(require("../util/isPresentationRole")); | |
/** | |
* @fileoverview Enforce a clickable non-interactive element has at least 1 keyboard event listener. | |
* @author Ethan Cohen | |
*/ | |
// ---------------------------------------------------------------------------- | |
// Rule Definition | |
// ---------------------------------------------------------------------------- | |
var errorMessage = 'Visible, non-interactive elements with click handlers must have at least one keyboard listener.'; | |
var schema = (0, _schemas.generateObjSchema)(); | |
var domElements = (0, _toConsumableArray2["default"])(_ariaQuery.dom.keys()); | |
var _default = { | |
meta: { | |
docs: { | |
url: 'https://github.com/jsx-eslint/eslint-plugin-jsx-a11y/tree/HEAD/docs/rules/click-events-have-key-events.md', | |
description: 'Enforce a clickable non-interactive element has at least one keyboard event listener.' | |
}, | |
schema: [schema] | |
}, | |
create: function create(context) { | |
var elementType = (0, _getElementType["default"])(context); | |
return { | |
JSXOpeningElement: function JSXOpeningElement(node) { | |
var props = node.attributes; | |
if ((0, _jsxAstUtils.getProp)(props, 'onclick') === undefined) { | |
return; | |
} | |
var type = elementType(node); | |
var requiredProps = ['onkeydown', 'onkeyup', 'onkeypress']; | |
if (!(0, _arrayIncludes["default"])(domElements, type)) { | |
// Do not test higher level JSX components, as we do not know what | |
// low-level DOM element this maps to. | |
return; | |
} | |
if ((0, _isHiddenFromScreenReader["default"])(type, props) || (0, _isPresentationRole["default"])(type, props)) { | |
return; | |
} | |
if ((0, _isInteractiveElement["default"])(type, props)) { | |
return; | |
} | |
if ((0, _jsxAstUtils.hasAnyProp)(props, requiredProps)) { | |
return; | |
} | |
// Visible, non-interactive elements with click handlers require one keyboard event listener. | |
context.report({ | |
node, | |
message: errorMessage | |
}); | |
} | |
}; | |
} | |
}; | |
exports["default"] = _default; | |
module.exports = exports.default; |