Dashboard sipadu mbip
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

AbstractNavItem.js 1.9KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import _extends from "@babel/runtime/helpers/esm/extends";
  2. import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/esm/objectWithoutPropertiesLoose";
  3. import classNames from 'classnames';
  4. import React, { useContext } from 'react';
  5. import useEventCallback from '@restart/hooks/useEventCallback';
  6. import NavContext from './NavContext';
  7. import SelectableContext, { makeEventKey } from './SelectableContext';
  8. var defaultProps = {
  9. disabled: false
  10. };
  11. var AbstractNavItem = React.forwardRef(function (_ref, ref) {
  12. var active = _ref.active,
  13. className = _ref.className,
  14. tabIndex = _ref.tabIndex,
  15. eventKey = _ref.eventKey,
  16. onSelect = _ref.onSelect,
  17. onClick = _ref.onClick,
  18. Component = _ref.as,
  19. props = _objectWithoutPropertiesLoose(_ref, ["active", "className", "tabIndex", "eventKey", "onSelect", "onClick", "as"]);
  20. var navKey = makeEventKey(eventKey, props.href);
  21. var parentOnSelect = useContext(SelectableContext);
  22. var navContext = useContext(NavContext);
  23. var isActive = active;
  24. if (navContext) {
  25. if (!props.role && navContext.role === 'tablist') props.role = 'tab';
  26. props['data-rb-event-key'] = navKey;
  27. props.id = navContext.getControllerId(navKey);
  28. props['aria-controls'] = navContext.getControlledId(navKey);
  29. isActive = active == null && navKey != null ? navContext.activeKey === navKey : active;
  30. }
  31. if (props.role === 'tab') {
  32. props.tabIndex = isActive ? tabIndex : -1;
  33. props['aria-selected'] = isActive;
  34. }
  35. var handleOnclick = useEventCallback(function (e) {
  36. if (onClick) onClick(e);
  37. if (navKey == null) return;
  38. if (onSelect) onSelect(navKey, e);
  39. if (parentOnSelect) parentOnSelect(navKey, e);
  40. });
  41. return React.createElement(Component, _extends({}, props, {
  42. ref: ref,
  43. onClick: handleOnclick,
  44. className: classNames(className, isActive && 'active')
  45. }));
  46. });
  47. AbstractNavItem.defaultProps = defaultProps;
  48. export default AbstractNavItem;