UNPKG

@primer/components

Version:
57 lines (54 loc) 3.1 kB
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } import React, { forwardRef } from 'react'; import styled from 'styled-components'; import { get } from '../constants'; import TokenBase, { isTokenInteractive } from './TokenBase'; import RemoveTokenButton from './_RemoveTokenButton'; const tokenBorderWidthPx = 1; const DefaultTokenStyled = styled(TokenBase).withConfig({ displayName: "Token__DefaultTokenStyled", componentId: "sc-1dg52pw-0" })(["background-color:", ";border-color:", ";border-style:solid;border-width:1px;color:", ";max-width:100%;padding-right:", ";&:hover{background-color:", ";box-shadow:", ";color:", ";}"], get('colors.neutral.subtle'), props => props.isSelected ? get('colors.fg.default') : get('colors.border.subtle'), props => props.isSelected ? get('colors.fg.default') : get('colors.fg.muted'), props => !props.hideRemoveButton ? 0 : undefined, props => isTokenInteractive(props) ? get('colors.neutral.muted') : undefined, props => isTokenInteractive(props) ? get('colors.shadow.medium') : undefined, props => isTokenInteractive(props) ? get('colors.fg.default') : undefined); const TokenTextContainer = styled('span').withConfig({ displayName: "Token__TokenTextContainer", componentId: "sc-1dg52pw-1" })(["flex-grow:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;"]); const LeadingVisualContainer = styled('span').withConfig({ displayName: "Token__LeadingVisualContainer", componentId: "sc-1dg52pw-2" })(["flex-shrink:0;line-height:0;"]); const Token = /*#__PURE__*/forwardRef((props, forwardedRef) => { const { as, handleRemove, id, leadingVisual: LeadingVisual, ref, text, variant, hideRemoveButton, ...rest } = props; const hasMultipleActionTargets = isTokenInteractive(props) && Boolean(handleRemove) && !hideRemoveButton; const handleRemoveClick = e => { e.stopPropagation(); handleRemove && handleRemove(); }; return /*#__PURE__*/React.createElement(DefaultTokenStyled, _extends({ as: as, handleRemove: handleRemove, hideRemoveButton: hideRemoveButton || !handleRemove, id: id === null || id === void 0 ? void 0 : id.toString(), text: text, ref: forwardedRef, variant: variant }, rest), LeadingVisual ? /*#__PURE__*/React.createElement(LeadingVisualContainer, null, /*#__PURE__*/React.createElement(LeadingVisual, null)) : null, /*#__PURE__*/React.createElement(TokenTextContainer, null, text), !hideRemoveButton && handleRemove ? /*#__PURE__*/React.createElement(RemoveTokenButton, { borderOffset: tokenBorderWidthPx, parentTokenTag: as || 'span', onClick: handleRemoveClick, variant: variant, parentTokenIsInteractive: isTokenInteractive(props), "aria-hidden": hasMultipleActionTargets ? "true" : "false" }) : null); }); export default Token;