@patternfly/react-core
Version:
This library provides a set of common React components for use with the PatternFly reference implementation.
43 lines • 2.23 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.ContextSelectorItem = void 0;
const tslib_1 = require("tslib");
const React = tslib_1.__importStar(require("react"));
const context_selector_1 = tslib_1.__importDefault(require("@patternfly/react-styles/css/components/ContextSelector/context-selector"));
const react_styles_1 = require("@patternfly/react-styles");
const contextSelectorConstants_1 = require("./contextSelectorConstants");
class ContextSelectorItem extends React.Component {
constructor() {
super(...arguments);
this.ref = React.createRef();
}
componentDidMount() {
/* eslint-disable-next-line */
this.props.sendRef(this.props.index, this.ref.current);
}
render() {
// eslint-disable-next-line @typescript-eslint/no-unused-vars
const _a = this.props, { className, children, onClick, isDisabled, index, sendRef, href } = _a, props = tslib_1.__rest(_a, ["className", "children", "onClick", "isDisabled", "index", "sendRef", "href"]);
const Component = href ? 'a' : 'button';
const isDisabledLink = href && isDisabled;
return (React.createElement(contextSelectorConstants_1.ContextSelectorContext.Consumer, null, ({ onSelect }) => (React.createElement("li", { role: "none" },
React.createElement(Component, Object.assign({ className: react_styles_1.css(context_selector_1.default.contextSelectorMenuListItem, isDisabledLink && context_selector_1.default.modifiers.disabled, className), ref: this.ref, onClick: event => {
if (!isDisabled) {
onClick(event);
onSelect(event, children);
}
}, disabled: isDisabled && !href, href: href }, (isDisabledLink && { 'aria-disabled': true, tabIndex: -1 }), props), children)))));
}
}
exports.ContextSelectorItem = ContextSelectorItem;
ContextSelectorItem.displayName = 'ContextSelectorItem';
ContextSelectorItem.defaultProps = {
children: null,
className: '',
isDisabled: false,
onClick: () => undefined,
index: undefined,
sendRef: () => { },
href: null
};
//# sourceMappingURL=ContextSelectorItem.js.map
;