UNPKG

react-aria-components

Version:

A library of styleable components built using React Aria

228 lines (211 loc) • 10.7 kB
var $b856e6788a7ea5bf$exports = require("./Button.main.js"); var $3114c2382242bdc0$exports = require("./Collection.main.js"); var $c5ccf687772c0422$exports = require("./utils.main.js"); var $84ae0bf5bd8e2a5f$exports = require("./Label.main.js"); var $a03b42240404b420$exports = require("./ListBox.main.js"); var $a8a589c28affdc40$exports = require("./Text.main.js"); var $4TsYs$reactaria = require("react-aria"); var $4TsYs$reactariacollections = require("@react-aria/collections"); var $4TsYs$reactariautils = require("@react-aria/utils"); var $4TsYs$reactstately = require("react-stately"); var $4TsYs$react = require("react"); 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", () => $ecf55d0c218a575e$export$5b07b5dd2cbd96e3); $parcel$export(module.exports, "TagListContext", () => $ecf55d0c218a575e$export$e755ce3685dd0ca9); $parcel$export(module.exports, "TagGroup", () => $ecf55d0c218a575e$export$67ea30858aaf75e3); $parcel$export(module.exports, "TagList", () => $ecf55d0c218a575e$export$f9fef0f55402315b); $parcel$export(module.exports, "Tag", () => $ecf55d0c218a575e$export$3288d34c523a1192); /* * Copyright 2022 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 $ecf55d0c218a575e$export$5b07b5dd2cbd96e3 = /*#__PURE__*/ (0, $4TsYs$react.createContext)(null); const $ecf55d0c218a575e$export$e755ce3685dd0ca9 = /*#__PURE__*/ (0, $4TsYs$react.createContext)(null); const $ecf55d0c218a575e$export$67ea30858aaf75e3 = /*#__PURE__*/ (0, $4TsYs$react.forwardRef)(function TagGroup(props, ref) { [props, ref] = (0, $c5ccf687772c0422$exports.useContextProps)(props, ref, $ecf55d0c218a575e$export$5b07b5dd2cbd96e3); return /*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement((0, $4TsYs$reactariacollections.CollectionBuilder), { content: props.children }, (collection)=>/*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement($ecf55d0c218a575e$var$TagGroupInner, { props: props, forwardedRef: ref, collection: collection })); }); function $ecf55d0c218a575e$var$TagGroupInner({ props: props, forwardedRef: ref, collection: collection }) { let tagListRef = (0, $4TsYs$react.useRef)(null); let [labelRef, label] = (0, $c5ccf687772c0422$exports.useSlot)(!props['aria-label'] && !props['aria-labelledby']); let state = (0, $4TsYs$reactstately.useListState)({ ...props, children: undefined, collection: collection }); // Prevent DOM props from going to two places. let domProps = (0, $4TsYs$reactariautils.filterDOMProps)(props); let domPropOverrides = Object.fromEntries(Object.entries(domProps).map(([k])=>[ k, undefined ])); let { gridProps: gridProps, labelProps: labelProps, descriptionProps: descriptionProps, errorMessageProps: errorMessageProps } = (0, $4TsYs$reactaria.useTagGroup)({ ...props, ...domPropOverrides, label: label }, state, tagListRef); var _props_className; return /*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement("div", { ...domProps, ref: ref, slot: props.slot || undefined, className: (_props_className = props.className) !== null && _props_className !== void 0 ? _props_className : 'react-aria-TagGroup', style: props.style }, /*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement((0, $c5ccf687772c0422$exports.Provider), { values: [ [ (0, $84ae0bf5bd8e2a5f$exports.LabelContext), { ...labelProps, elementType: 'span', ref: labelRef } ], [ $ecf55d0c218a575e$export$e755ce3685dd0ca9, { ...gridProps, ref: tagListRef } ], [ (0, $a03b42240404b420$exports.ListStateContext), state ], [ (0, $a8a589c28affdc40$exports.TextContext), { slots: { description: descriptionProps, errorMessage: errorMessageProps } } ] ] }, props.children)); } const $ecf55d0c218a575e$export$f9fef0f55402315b = /*#__PURE__*/ (0, $4TsYs$react.forwardRef)(function TagList(props, ref) { let state = (0, $4TsYs$react.useContext)((0, $a03b42240404b420$exports.ListStateContext)); return state ? /*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement($ecf55d0c218a575e$var$TagListInner, { props: props, forwardedRef: ref }) : /*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement((0, $4TsYs$reactariacollections.Collection), props); }); function $ecf55d0c218a575e$var$TagListInner({ props: props, forwardedRef: forwardedRef }) { let state = (0, $4TsYs$react.useContext)((0, $a03b42240404b420$exports.ListStateContext)); let { CollectionRoot: CollectionRoot } = (0, $4TsYs$react.useContext)((0, $3114c2382242bdc0$exports.CollectionRendererContext)); let [gridProps, ref] = (0, $c5ccf687772c0422$exports.useContextProps)(props, forwardedRef, $ecf55d0c218a575e$export$e755ce3685dd0ca9); delete gridProps.items; delete gridProps.renderEmptyState; let { focusProps: focusProps, isFocused: isFocused, isFocusVisible: isFocusVisible } = (0, $4TsYs$reactaria.useFocusRing)(); let renderValues = { isEmpty: state.collection.size === 0, isFocused: isFocused, isFocusVisible: isFocusVisible, state: state }; let renderProps = (0, $c5ccf687772c0422$exports.useRenderProps)({ className: props.className, style: props.style, defaultClassName: 'react-aria-TagList', values: renderValues }); let persistedKeys = (0, $3114c2382242bdc0$exports.usePersistedKeys)(state.selectionManager.focusedKey); return /*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement("div", { ...(0, $4TsYs$reactariautils.mergeProps)(gridProps, focusProps), ...renderProps, ref: ref, "data-empty": state.collection.size === 0 || undefined, "data-focused": isFocused || undefined, "data-focus-visible": isFocusVisible || undefined }, state.collection.size === 0 && props.renderEmptyState ? props.renderEmptyState(renderValues) : /*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement(CollectionRoot, { collection: state.collection, persistedKeys: persistedKeys })); } const $ecf55d0c218a575e$export$3288d34c523a1192 = /*#__PURE__*/ (0, $4TsYs$reactariacollections.createLeafComponent)('item', (props, forwardedRef, item)=>{ let state = (0, $4TsYs$react.useContext)((0, $a03b42240404b420$exports.ListStateContext)); let ref = (0, $4TsYs$reactariautils.useObjectRef)(forwardedRef); let { focusProps: focusProps, isFocusVisible: isFocusVisible } = (0, $4TsYs$reactaria.useFocusRing)({ within: false }); let { rowProps: rowProps, gridCellProps: gridCellProps, removeButtonProps: removeButtonProps, ...states } = (0, $4TsYs$reactaria.useTag)({ item: item }, state, ref); let { hoverProps: hoverProps, isHovered: isHovered } = (0, $4TsYs$reactaria.useHover)({ isDisabled: !states.allowsSelection, onHoverStart: item.props.onHoverStart, onHoverChange: item.props.onHoverChange, onHoverEnd: item.props.onHoverEnd }); let renderProps = (0, $c5ccf687772c0422$exports.useRenderProps)({ ...props, id: undefined, children: item.rendered, defaultClassName: 'react-aria-Tag', values: { ...states, isFocusVisible: isFocusVisible, isHovered: isHovered, selectionMode: state.selectionManager.selectionMode, selectionBehavior: state.selectionManager.selectionBehavior } }); (0, $4TsYs$react.useEffect)(()=>{ if (!item.textValue && process.env.NODE_ENV !== 'production') console.warn('A `textValue` prop is required for <Tag> elements with non-plain text children for accessibility.'); }, [ item.textValue ]); return /*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement("div", { ref: ref, ...renderProps, ...(0, $4TsYs$reactariautils.mergeProps)((0, $4TsYs$reactariautils.filterDOMProps)(props), rowProps, focusProps, hoverProps), "data-selected": states.isSelected || undefined, "data-disabled": states.isDisabled || undefined, "data-hovered": isHovered || undefined, "data-focused": states.isFocused || undefined, "data-focus-visible": isFocusVisible || undefined, "data-pressed": states.isPressed || undefined, "data-allows-removing": states.allowsRemoving || undefined, "data-selection-mode": state.selectionManager.selectionMode === 'none' ? undefined : state.selectionManager.selectionMode }, /*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement("div", { ...gridCellProps, style: { display: 'contents' } }, /*#__PURE__*/ (0, ($parcel$interopDefault($4TsYs$react))).createElement((0, $c5ccf687772c0422$exports.Provider), { values: [ [ (0, $b856e6788a7ea5bf$exports.ButtonContext), { slots: { remove: removeButtonProps } } ], [ (0, $3114c2382242bdc0$exports.CollectionRendererContext), (0, $3114c2382242bdc0$exports.DefaultCollectionRenderer) ] ] }, renderProps.children))); }); //# sourceMappingURL=TagGroup.main.js.map