@react-spectrum/s2
Version:
Spectrum 2 UI components in React
713 lines (686 loc) • 32 kB
JavaScript
require("./TagGroup.css");
var $6e265ff388155b91$exports = require("./ActionButton.cjs");
var $7e7cdbd2b8ae2467$exports = require("../icons/AlertTriangle.cjs");
var $38071d9ce246d4cf$exports = require("./Avatar.cjs");
var $e991cbcdf82ced71$exports = require("./CenterBaseline.cjs");
var $4fb579ecc195bd2b$exports = require("./ClearButton.cjs");
var $a0b996a550bb0891$exports = require("./Field.cjs");
var $bfa4962d90c8af48$exports = require("./Form.cjs");
var $bde97c91243ed164$exports = require("../icons/Icon.cjs");
var $053b76ed3d29e13b$exports = require("./Image.cjs");
var $4526404114e78c80$exports = require("./intlStrings.cjs");
var $2061c83559b50a66$exports = require("./pressScale.cjs");
var $6367bc87eb7d24ad$exports = require("./Content.cjs");
var $ac757a4c2bd72aee$exports = require("../icons/useSpectrumContextProps.cjs");
var $chbGa$reactjsxruntime = require("react/jsx-runtime");
var $chbGa$reactariacomponents = require("react-aria-components");
var $chbGa$reactariacollections = require("@react-aria/collections");
var $chbGa$react = require("react");
var $chbGa$reactdom = require("react-dom");
var $chbGa$reactariautils = require("@react-aria/utils");
var $chbGa$reactspectrumutils = require("@react-spectrum/utils");
var $chbGa$reactariai18n = require("@react-aria/i18n");
function $parcel$interopDefault(a) {
return a && a.__esModule ? a.default : a;
}
function $parcel$export(e, n, v, s) {
Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true});
}
$parcel$export(module.exports, "TagGroupContext", () => $2e3ddd7543f4a901$export$5b07b5dd2cbd96e3);
$parcel$export(module.exports, "TagGroup", () => $2e3ddd7543f4a901$export$67ea30858aaf75e3);
$parcel$export(module.exports, "Tag", () => $2e3ddd7543f4a901$export$3288d34c523a1192);
/*
* Copyright 2024 Adobe. All rights reserved.
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. You may obtain a copy
* of the License at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
* OF ANY KIND, either express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
const $2e3ddd7543f4a901$export$5b07b5dd2cbd96e3 = /*#__PURE__*/ (0, $chbGa$react.createContext)(null);
const $2e3ddd7543f4a901$var$InternalTagGroupContext = /*#__PURE__*/ (0, $chbGa$react.createContext)({});
const $2e3ddd7543f4a901$export$67ea30858aaf75e3 = /*#__PURE__*/ (0, $chbGa$react.forwardRef)(function TagGroup(props, ref) {
[props, ref] = (0, $ac757a4c2bd72aee$exports.useSpectrumContextProps)(props, ref, $2e3ddd7543f4a901$export$5b07b5dd2cbd96e3);
props = (0, $bfa4962d90c8af48$exports.useFormProps)(props);
let { onRemove: onRemove } = props;
return /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)($2e3ddd7543f4a901$var$InternalTagGroupContext.Provider, {
value: {
onRemove: onRemove
},
children: /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $chbGa$reactariacollections.CollectionBuilder), {
content: /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $chbGa$reactariacollections.Collection), {
...props
}),
children: (collection)=>/*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)($2e3ddd7543f4a901$var$TagGroupInner, {
props: props,
forwardedRef: ref,
collection: collection
})
})
});
});
function $2e3ddd7543f4a901$var$TagGroupInner({ props: { label: label, description: description, labelPosition: labelPosition = 'top', labelAlign: labelAlign = 'start', isEmphasized: isEmphasized, isInvalid: isInvalid, errorMessage: errorMessage, UNSAFE_className: UNSAFE_className = '', UNSAFE_style: UNSAFE_style, size: size = 'M', ...props }, forwardedRef: ref, collection: collection }) {
let stringFormatter = (0, $chbGa$reactariai18n.useLocalizedStringFormatter)((0, ($parcel$interopDefault($4526404114e78c80$exports))), '@react-spectrum/s2');
let { maxRows: maxRows, groupActionLabel: groupActionLabel, onGroupAction: onGroupAction, renderEmptyState: renderEmptyState = ()=>stringFormatter.format('tag.noTags'), ...otherProps } = props;
let { direction: direction } = (0, $chbGa$reactariacomponents.useLocale)();
let containerRef = (0, $chbGa$react.useRef)(null);
let tagsRef = (0, $chbGa$react.useRef)(null);
let actionsRef = (0, $chbGa$react.useRef)(null);
let hiddenTagsRef = (0, $chbGa$react.useRef)(null);
let [tagState, setTagState] = (0, $chbGa$react.useState)({
visibleTagCount: collection.size,
showCollapseButton: false
});
let [isCollapsed, setIsCollapsed] = (0, $chbGa$react.useState)(maxRows != null);
let { onRemove: onRemove } = (0, $chbGa$react.useContext)($2e3ddd7543f4a901$var$InternalTagGroupContext);
let isEmpty = collection.size === 0;
let showCollapseToggleButton = tagState.showCollapseButton || tagState.visibleTagCount < collection.size;
let formContext = (0, $chbGa$react.useContext)((0, $bfa4962d90c8af48$exports.FormContext));
let domRef = (0, $chbGa$reactspectrumutils.useDOMRef)(ref);
let allItems = (0, $chbGa$react.useMemo)(()=>Array.from(collection), [
collection
]);
let items = (0, $chbGa$react.useMemo)(()=>Array.from(collection).slice(0, !isCollapsed ? collection.size : tagState.visibleTagCount), [
collection,
tagState.visibleTagCount,
isCollapsed
]);
let updateVisibleTagCount = ()=>{
if (maxRows == null) setTagState({
visibleTagCount: collection.size,
showCollapseButton: false
});
if (maxRows != null && maxRows > 0) {
let computeVisibleTagCount = ()=>{
let currContainerRef = hiddenTagsRef.current;
let currTagsRef = hiddenTagsRef.current;
let currActionsRef = actionsRef.current;
if (!currContainerRef || !currTagsRef || collection.size === 0 || currContainerRef.parentElement == null) return {
visibleTagCount: 0,
showCollapseButton: false
};
// Count rows and show tags until we hit the maxRows.
// I think this is still a safe assumption, and we don't need to queryAll for role=tag
let tags = [
...currTagsRef.children
];
let currY = -Infinity;
let rowCount = 0;
let index = 0;
let tagWidths = [];
for (let tag of tags){
let { width: width, y: y } = tag.getBoundingClientRect();
if (y !== currY) {
currY = y;
rowCount++;
}
if (rowCount > maxRows) break;
tagWidths.push(width);
index++;
}
// Remove tags until there is space for the collapse button and action button (if present) on the last row.
let buttons = currActionsRef ? [
...currActionsRef.children
] : [];
if (buttons.length > 0 && rowCount >= maxRows) {
let buttonsWidth = buttons.reduce((acc, curr)=>acc += curr.getBoundingClientRect().width, 0);
let margins = parseFloat(getComputedStyle(buttons[0]).marginInlineStart);
buttonsWidth += margins * 2;
let end = direction === 'ltr' ? 'right' : 'left';
let containerEnd = currContainerRef.parentElement?.getBoundingClientRect()[end] - margins;
let lastTagEnd = tags[index - 1]?.getBoundingClientRect()[end];
lastTagEnd += margins;
let availableWidth = containerEnd - lastTagEnd;
while(availableWidth <= buttonsWidth && index > 0){
let tagWidth = tagWidths.pop();
if (tagWidth != null) availableWidth += tagWidth;
index--;
}
}
return {
visibleTagCount: Math.max(index, 1),
showCollapseButton: index < collection.size
};
};
let result = computeVisibleTagCount();
(0, $chbGa$reactdom.flushSync)(()=>{
setTagState(result);
});
}
};
let updateVisibleTagCountEffect = (0, $chbGa$reactariautils.useEffectEvent)(updateVisibleTagCount);
(0, $chbGa$reactariautils.useResizeObserver)({
ref: maxRows != null ? containerRef : undefined,
onResize: updateVisibleTagCount
});
(0, $chbGa$reactariautils.useLayoutEffect)(()=>{
if (collection.size > 0 && maxRows != null && maxRows > 0) queueMicrotask(updateVisibleTagCountEffect);
}, [
collection.size,
maxRows
]);
(0, $chbGa$react.useEffect)(()=>{
// Recalculate visible tags when fonts are loaded.
document.fonts?.ready.then(()=>updateVisibleTagCountEffect());
}, []);
let handlePressCollapse = ()=>{
setIsCollapsed((prevCollapsed)=>!prevCollapsed);
};
let helpText = null;
if (!isInvalid && description) helpText = /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $6367bc87eb7d24ad$exports.Text), {
slot: "description",
styles: (0, $a0b996a550bb0891$exports.helpTextStyles)({
size: size
}),
children: description
});
else if (isInvalid) helpText = /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsxs)("div", {
className: (0, $a0b996a550bb0891$exports.helpTextStyles)({
size: size,
isInvalid: isInvalid
}),
children: [
/*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $e991cbcdf82ced71$exports.CenterBaseline), {
children: /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $7e7cdbd2b8ae2467$exports.default), {})
}),
/*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $6367bc87eb7d24ad$exports.Text), {
slot: "errorMessage",
children: errorMessage
})
]
});
return /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsxs)((0, $chbGa$reactariacomponents.TagGroup), {
...otherProps,
ref: domRef,
style: UNSAFE_style,
className: UNSAFE_className + function anonymous(props, overrides) {
let rules = " ";
let gridColumnStart = false;
let gridColumnEnd = false;
let matches = (overrides || '').matchAll(/(?:^|\s)(J|G|I|H|_u|_v|_s|__A|_d|_J|z|y|B|A|_P|_9|W|_l|_A|_z|_6|Z|N|L)[^\s]+/g);
for (let p of matches){
if (p[1] === "z") gridColumnStart = true;
if (p[1] === "y") gridColumnEnd = true;
rules += p[0];
}
rules += ' se1';
if (props.isInForm) {
if (!gridColumnStart) rules += ' z2mU1';
}
if (props.isInForm) {
if (props.labelPosition === "side") {
if (!gridColumnEnd) rules += ' yvoofG1';
}
}
if (props.isInForm) rules += ' DLwlgod1';
else {
if (props.labelPosition === "side") rules += ' DPlN5qb1';
else if (props.labelPosition === "top") rules += ' DM8Mfn1';
}
if (props.labelPosition === "side") rules += ' EPlN5qb1';
else if (props.labelPosition === "top") rules += ' E4w1sLc1';
if (props.labelPosition === "side") rules += ' CbRM95c1';
else if (props.labelPosition === "top") rules += ' Cxaocre1';
if (props.size === "XL") {
rules += ' -_6BNtrc-e1';
rules += ' vx1';
} else if (props.size === "L") {
rules += ' -_6BNtrc-d1';
rules += ' vx1';
} else if (props.size === "S") {
rules += ' -_6BNtrc-b1';
rules += ' vx1';
} else if (props.size === "XS") {
rules += ' -_6BNtrc-a1';
rules += ' vx1';
} else {
rules += ' -_6BNtrc-c1';
rules += ' vx1';
}
rules += ' ea1';
rules += ' _Fd1';
rules += ' _FnuYUweb1';
if (props.size === "XL") rules += ' -BhX7R-Fz1';
else if (props.size === "L") rules += ' -BhX7R-Fv1';
else if (props.size === "S") rules += ' -BhX7R-Fp1';
else if (props.size === "XS") rules += ' -BhX7R-Fn1';
else rules += ' -BhX7R-Fx1';
rules += ' -AJjOLd-UVkF0Db1';
rules += ' qg1';
rules += ' __ca1';
return rules;
}({
size: size,
labelPosition: labelPosition,
isInForm: !!formContext
}, props.styles),
children: [
/*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $a0b996a550bb0891$exports.FieldLabel), {
size: size,
labelPosition: labelPosition,
labelAlign: labelAlign,
contextualHelp: props.contextualHelp,
children: label
}),
/*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)("div", {
ref: containerRef,
className: function anonymous(props) {
let rules = " ";
rules += ' zXcEWr1';
rules += ' yXcEWr1';
rules += ' BXcEWr1';
rules += ' AXcEWr1';
rules += ' Nb1';
if (props.isEmpty) rules += ' Iy1';
else rules += ' Ib1';
if (props.isEmpty) rules += ' Hy1';
else rules += ' Hs1';
rules += ' _Pc1';
return rules;
}({
isEmpty: isEmpty
}),
children: /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $bfa4962d90c8af48$exports.FormContext).Provider, {
value: {
...formContext,
size: size
},
children: /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsxs)((0, $chbGa$reactariacomponents.Provider), {
values: [
[
(0, $chbGa$reactariacomponents.TextContext),
undefined
],
[
(0, $chbGa$reactariacomponents.ButtonContext),
undefined
],
[
$2e3ddd7543f4a901$export$5b07b5dd2cbd96e3,
{
size: size,
isEmphasized: isEmphasized
}
]
],
children: [
maxRows != null && /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)("div", {
// @ts-ignore
inert: (0, $chbGa$reactariautils.inertValue)(true),
ref: hiddenTagsRef,
className: " sf1 _wb1 uk1 ucJ9TBTb1 ud3Euai1 uea1 ugb1 uhd1 uje1 u2NhKxcl1 uic1 _Pa1 Wr1 _lr1 _6b1 _Nc1 Pc1 _Ia1",
children: allItems.map((item)=>{
// pull off individual props as an allow list, don't want refs or other props getting through
// eslint-disable-next-line @typescript-eslint/no-unused-vars
let { ref: ref, ...itemProps } = item.props;
return /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)("div", {
style: itemProps.UNSAFE_style,
className: itemProps.className({
size: size,
allowsRemoving: Boolean(onRemove)
}),
children: /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)($2e3ddd7543f4a901$var$TagWrapper, {
id: item.key,
textValue: item.textValue,
isInRealDOM: true,
size: size,
allowsRemoving: !!onRemove,
...itemProps,
children: itemProps.children({
size: size,
allowsRemoving: Boolean(onRemove),
isInCtx: true
})
}, item.key)
}, item.key);
})
}),
/*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $chbGa$reactariacomponents.TagList), {
ref: tagsRef,
items: items,
renderEmptyState: renderEmptyState,
className: " sf1 Nb1 uk1 ucJ9TBTb1 ud3Euai1 uea1 ugb1 uhd1 uje1 u2NhKxcl1 uic1 -_6BNtrc-c1 vx1 xb1 _xa1 _Fd1 _FnuYUweb1 pt1",
children: (item)=>/*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)($2e3ddd7543f4a901$export$3288d34c523a1192, {
...item.props,
id: item.key,
textValue: item.textValue
})
}),
!isEmpty && (showCollapseToggleButton || groupActionLabel) && /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)($2e3ddd7543f4a901$var$ActionGroup, {
collection: collection,
"aria-label": props['aria-label'],
"aria-labelledby": props['aria-labelledby'],
actionsRef: actionsRef,
tagState: tagState,
size: size,
isCollapsed: isCollapsed,
handlePressCollapse: handlePressCollapse,
onGroupAction: onGroupAction,
groupActionLabel: groupActionLabel
})
]
})
})
}),
helpText
]
});
}
function $2e3ddd7543f4a901$var$ActionGroup(props) {
let stringFormatter = (0, $chbGa$reactariai18n.useLocalizedStringFormatter)((0, ($parcel$interopDefault($4526404114e78c80$exports))), '@react-spectrum/s2');
let { actionsRef: actionsRef, tagState: tagState, size: size, isCollapsed: isCollapsed, handlePressCollapse: handlePressCollapse, onGroupAction: onGroupAction, groupActionLabel: groupActionLabel, collection: collection, // directly use aria-labelling from the TagGroup because we can't use the id from the TagList
// and we can't supply an id to the TagList because it'll cause an issue where all the tag ids flip back
// and forth with their prefix in an infinite loop
'aria-label': ariaLabel, 'aria-labelledby': ariaLabelledBy } = props;
let actionsId = (0, $chbGa$reactariautils.useId)();
// might need to localize the aria-label which concatenates with this label
let actionGroupLabel = stringFormatter.format('tag.actions');
return /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsxs)("div", {
role: "group",
ref: actionsRef,
id: actionsId,
"aria-label": ariaLabel ? `${ariaLabel} ${actionGroupLabel}` : actionGroupLabel,
"aria-labelledby": ariaLabelledBy ? ariaLabelledBy : undefined,
className: " sf1",
children: [
tagState.showCollapseButton && /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $6e265ff388155b91$exports.ActionButton), {
isQuiet: true,
size: size,
styles: " Js1 Gs1 Is1 Hs1",
UNSAFE_style: {
display: 'inline-flex'
},
onPress: handlePressCollapse,
children: isCollapsed ? stringFormatter.format('tag.showAllButtonLabel', {
tagCount: collection.size
}) : stringFormatter.format('tag.hideButtonLabel')
}),
groupActionLabel && onGroupAction && /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $6e265ff388155b91$exports.ActionButton), {
isQuiet: true,
size: size,
styles: " Js1 Gs1 Is1 Hs1",
UNSAFE_style: {
display: 'inline-flex'
},
onPress: ()=>onGroupAction?.(),
children: groupActionLabel
})
]
});
}
const $2e3ddd7543f4a901$var$tagStyles = function anonymous(props) {
let rules = " ";
if (props.isFocusVisible) rules += ' _Lf1';
else rules += ' _Le1';
rules += ' Oh1';
rules += ' Olc1';
rules += ' _Mc1';
rules += ' _Kd1';
if (props.size === "XL") {
rules += ' uk1';
rules += ' ucJ9TBTb1';
rules += ' ud3Euai1';
rules += ' uea1';
rules += ' ugb1';
rules += ' uhd1';
rules += ' uje1';
rules += ' u2NhKxcl1';
rules += ' uic1';
} else if (props.size === "L") {
rules += ' uk1';
rules += ' ucJ9TBTb1';
rules += ' ud3Euai1';
rules += ' uea1';
rules += ' ugb1';
rules += ' uhd1';
rules += ' uje1';
rules += ' u2NhKxcl1';
rules += ' uic1';
} else if (props.size === "S") {
rules += ' uk1';
rules += ' ucJ9TBTb1';
rules += ' ud3Euai1';
rules += ' uea1';
rules += ' ugb1';
rules += ' uhd1';
rules += ' uje1';
rules += ' u2NhKxcl1';
rules += ' uic1';
} else if (props.size === "XS") {
rules += ' uk1';
rules += ' ucJ9TBTb1';
rules += ' ud3Euai1';
rules += ' uea1';
rules += ' ugb1';
rules += ' uhd1';
rules += ' uje1';
rules += ' u2NhKxcl1';
rules += ' uic1';
} else {
rules += ' uk1';
rules += ' ucJ9TBTb1';
rules += ' ud3Euai1';
rules += ' uea1';
rules += ' ugb1';
rules += ' uhd1';
rules += ' uje1';
rules += ' u2NhKxcl1';
rules += ' uic1';
}
if (props.size === "XL") {
rules += ' -_6BNtrc-e1';
rules += ' vx1';
} else if (props.size === "L") {
rules += ' -_6BNtrc-d1';
rules += ' vx1';
} else if (props.size === "S") {
rules += ' -_6BNtrc-b1';
rules += ' vx1';
} else if (props.size === "XS") {
rules += ' -_6BNtrc-a1';
rules += ' vx1';
} else {
rules += ' -_6BNtrc-c1';
rules += ' vx1';
}
if (props.size === "XL") {
rules += ' xb1';
rules += ' _xa1';
} else if (props.size === "L") {
rules += ' xb1';
rules += ' _xa1';
} else if (props.size === "S") {
rules += ' xb1';
rules += ' _xa1';
} else if (props.size === "XS") {
rules += ' xb1';
rules += ' _xa1';
} else {
rules += ' xb1';
rules += ' _xa1';
}
if (props.size === "XL") {
rules += ' _Fd1';
rules += ' _FnuYUweb1';
} else if (props.size === "L") {
rules += ' _Fd1';
rules += ' _FnuYUweb1';
} else if (props.size === "S") {
rules += ' _Fd1';
rules += ' _FnuYUweb1';
} else if (props.size === "XS") {
rules += ' _Fd1';
rules += ' _FnuYUweb1';
} else {
rules += ' _Fd1';
rules += ' _FnuYUweb1';
}
if (props.isDisabled) rules += ' pp1';
else if (props.isSelected) {
if (props.isEmphasized) rules += ' px1';
else rules += ' pr1';
} else {
if (props.isPressed) rules += ' po1';
else if (props.isFocusVisible) rules += ' po1';
else if (props.isHovered) rules += ' po1';
else rules += ' pt1';
}
if (props.isDisabled) rules += ' plc1';
else if (props.isSelected) rules += ' ple1';
else rules += ' plb1';
rules += ' sh1';
rules += ' eb1';
rules += ' _oa1';
rules += ' Sv1';
rules += ' SgLWx3bd1';
if (props.allowsRemoving) rules += ' Rd1';
else rules += ' Rv1';
if (props.size === "XL") rules += ' Nl1';
else if (props.size === "L") rules += ' Nj1';
else if (props.size === "S") rules += ' Nf1';
else if (props.size === "XS") rules += ' Ne1';
else rules += ' Nk1';
if (props.size === "XL") rules += ' -SFnbic-_JaP8ec1';
else if (props.size === "L") rules += ' -SFnbic-_J0K2hn1';
else if (props.size === "S") rules += ' -SFnbic-_JJOW22b1';
else if (props.size === "XS") rules += ' -SFnbic-_JICefdd1';
else rules += ' -SFnbic-_Jb1';
rules += ' -Bu7z1c-ob1';
rules += ' oj1';
rules += ' nj1';
rules += ' kj1';
rules += ' jj1';
rules += ' qc1';
rules += ' qsd1';
rules += ' -Qg41Lb-IAxCW0c1';
rules += ' -Qg41Lb-gLWx3bIy1';
rules += ' FRuFGYc1';
rules += ' La1';
rules += ' _5c1';
rules += ' _Ca1';
rules += ' Yd1';
rules += ' Xb1';
rules += ' _2b1';
if (props.isDisabled) rules += ' gH1';
else if (props.isSelected) {
if (props.isEmphasized) {
if (props.isFocusVisible) rules += ' gUgARdd1';
else if (props.isPressed) rules += ' gUgARdd1';
else if (props.isHovered) rules += ' gUgARdd1';
else rules += ' g5qAiPc1';
} else {
if (props.isPressed) rules += ' gu1';
else if (props.isFocusVisible) rules += ' gu1';
else if (props.isHovered) rules += ' gu1';
else rules += ' g01';
}
} else if (props.isFocusVisible) rules += ' gF1';
else if (props.isHovered) rules += ' gF1';
else rules += ' gH1';
if (props.isSelected) rules += ' gle1';
else rules += ' glb1';
rules += ' _je1';
rules += ' Js1';
rules += ' Gs1';
rules += ' Is1';
rules += ' Hs1';
if (props.isLink) rules += ' ry1';
else rules += ' ri1';
rules += ' -_8sjo0b-t5ZbAob1';
if (props.size === "XL") rules += ' -F_-Fz1';
else if (props.size === "L") rules += ' -F_-Fv1';
else if (props.size === "S") rules += ' -F_-Fp1';
else if (props.size === "XS") rules += ' -F_-Fn1';
else rules += ' -F_-Fx1';
return rules;
};
const $2e3ddd7543f4a901$var$avatarSize = {
S: 16,
M: 20,
L: 24
};
const $2e3ddd7543f4a901$export$3288d34c523a1192 = /*#__PURE__*/ (0, $chbGa$react.forwardRef)(function Tag({ children: children, textValue: textValue, ...props }, ref) {
textValue ||= typeof children === 'string' ? children : undefined;
let ctx = (0, $chbGa$reactariacomponents.useSlottedContext)($2e3ddd7543f4a901$export$5b07b5dd2cbd96e3);
let isInRealDOM = Boolean(ctx?.size);
let { size: size, isEmphasized: isEmphasized } = ctx ?? {};
let domRef = (0, $chbGa$reactspectrumutils.useDOMRef)(ref);
let backupRef = (0, $chbGa$react.useRef)(null);
domRef = domRef || backupRef;
let isLink = props.href != null;
return /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $chbGa$reactariacomponents.Tag), {
textValue: textValue,
...props,
ref: domRef,
style: (0, $2061c83559b50a66$exports.pressScale)(domRef),
className: (renderProps)=>$2e3ddd7543f4a901$var$tagStyles({
size: size,
isEmphasized: isEmphasized,
isLink: isLink,
...renderProps
}),
children: (0, $chbGa$reactariacomponents.composeRenderProps)(children, (children, renderProps)=>/*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)($2e3ddd7543f4a901$var$TagWrapper, {
isInRealDOM: isInRealDOM,
isEmphasized: isEmphasized,
...renderProps,
children: typeof children === 'string' ? /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $6367bc87eb7d24ad$exports.Text), {
children: children
}) : children
}))
});
});
function $2e3ddd7543f4a901$var$TagWrapper({ children: children, isDisabled: isDisabled, allowsRemoving: allowsRemoving, isInRealDOM: isInRealDOM, isEmphasized: isEmphasized, isSelected: isSelected }) {
let { size: size = 'M' } = (0, $chbGa$reactariacomponents.useSlottedContext)($2e3ddd7543f4a901$export$5b07b5dd2cbd96e3) ?? {};
return /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsxs)((0, $chbGa$reactjsxruntime.Fragment), {
children: [
isInRealDOM && /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)("div", {
className: " sd1 Na1 eb1 Uc1 Usd1 qc1 qsd1 _yb1 g91",
children: /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $chbGa$reactariacomponents.Provider), {
values: [
[
(0, $6367bc87eb7d24ad$exports.TextContext),
{
styles: " _Jb1 _Nc1 Pc1 _Yb1 _7c1"
}
],
[
(0, $bde97c91243ed164$exports.IconContext),
{
render: (0, $e991cbcdf82ced71$exports.centerBaseline)({
slot: 'icon',
styles: " _Ja1"
}),
styles: " ZuUmpre1 FuUmpre1 I67logd1 _va1"
}
],
[
(0, $38071d9ce246d4cf$exports.AvatarContext),
{
size: $2e3ddd7543f4a901$var$avatarSize[size],
styles: " _Ja1"
}
],
[
(0, $053b76ed3d29e13b$exports.ImageContext),
{
styles: " ZuUmpre1 FuUmpre1 _va1 _Ja1 fa1 _Ha1 oa1 na1 ka1 ja1"
}
]
],
children: children
})
}),
!isInRealDOM && children,
allowsRemoving && isInRealDOM && /*#__PURE__*/ (0, $chbGa$reactjsxruntime.jsx)((0, $4fb579ecc195bd2b$exports.ClearButton), {
slot: "remove",
size: size,
isStaticColor: isEmphasized && isSelected,
isDisabled: isDisabled
})
]
});
}
//# sourceMappingURL=TagGroup.cjs.map