@oracle/oraclejet-preact 20.0.2 → 20.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (120) hide show
  1. package/amd/{BarChart-f429b382.js → BarChart-994cb8f0.js} +2 -2
  2. package/amd/{BarChart-f429b382.js.map → BarChart-994cb8f0.js.map} +1 -1
  3. package/amd/{Chart-57965de4.js → Chart-d9eafc7a.js} +2 -2
  4. package/amd/{Chart-57965de4.js.map → Chart-d9eafc7a.js.map} +1 -1
  5. package/amd/{ComboChart-c42ed049.js → ComboChart-5a6f6c8a.js} +2 -2
  6. package/amd/{ComboChart-c42ed049.js.map → ComboChart-5a6f6c8a.js.map} +1 -1
  7. package/amd/ExpandableList-233c279e.js +2 -0
  8. package/amd/{ExpandableList-a9a86ad8.js.map → ExpandableList-233c279e.js.map} +1 -1
  9. package/amd/{InlineSelectSingle-7c1cc5b5.js → InlineSelectSingle-87bc8a45.js} +2 -2
  10. package/amd/{InlineSelectSingle-7c1cc5b5.js.map → InlineSelectSingle-87bc8a45.js.map} +1 -1
  11. package/amd/{LineAreaChart-48efb7f7.js → LineAreaChart-47fc17d2.js} +2 -2
  12. package/amd/{LineAreaChart-48efb7f7.js.map → LineAreaChart-47fc17d2.js.map} +1 -1
  13. package/amd/ListView-02a92d18.js +2 -0
  14. package/amd/{ListView-6d21e8f9.js.map → ListView-02a92d18.js.map} +1 -1
  15. package/amd/PRIVATE_Chart.js +1 -1
  16. package/amd/PRIVATE_SelectCommon.js +1 -1
  17. package/amd/{ScatterChart-6427e7ec.js → ScatterChart-7bd0f601.js} +2 -2
  18. package/amd/{ScatterChart-6427e7ec.js.map → ScatterChart-7bd0f601.js.map} +1 -1
  19. package/amd/{SelectMobileFieldInput-d499ef86.js → SelectMobileFieldInput-4795a794.js} +2 -2
  20. package/amd/{SelectMobileFieldInput-d499ef86.js.map → SelectMobileFieldInput-4795a794.js.map} +1 -1
  21. package/amd/{SelectMultiple-cc9bffc6.js → SelectMultiple-e216b16c.js} +2 -2
  22. package/amd/{SelectMultiple-cc9bffc6.js.map → SelectMultiple-e216b16c.js.map} +1 -1
  23. package/amd/{SelectSingle-2bb35b67.js → SelectSingle-d53cf202.js} +2 -2
  24. package/amd/{SelectSingle-2bb35b67.js.map → SelectSingle-d53cf202.js.map} +1 -1
  25. package/amd/Theme-redwood/theme.css +209 -209
  26. package/amd/Theme-stable/theme.css +160 -160
  27. package/amd/UNSAFE_BarChart/__test__/BarChart.spec.js +1 -1
  28. package/amd/UNSAFE_BarChart.js +1 -1
  29. package/amd/UNSAFE_ComboChart.js +1 -1
  30. package/amd/UNSAFE_ExpandableList.js +1 -1
  31. package/amd/UNSAFE_InlineSelectSingle.js +1 -1
  32. package/amd/UNSAFE_LineAreaChart.js +1 -1
  33. package/amd/UNSAFE_ListView.js +1 -1
  34. package/amd/UNSAFE_ScatterChart.js +1 -1
  35. package/amd/UNSAFE_SelectMultiple.js +1 -1
  36. package/amd/UNSAFE_SelectSingle.js +1 -1
  37. package/amd/UNSAFE_VirtualizedListView.js +1 -1
  38. package/amd/VirtualizedListView-a0f338c2.js +2 -0
  39. package/amd/{VirtualizedListView-1ae7151d.js.map → VirtualizedListView-a0f338c2.js.map} +1 -1
  40. package/amd/{useDisplayValue-0e90bf4c.js → useDisplayValue-9b671893.js} +2 -2
  41. package/amd/{useDisplayValue-0e90bf4c.js.map → useDisplayValue-9b671893.js.map} +1 -1
  42. package/amd/useSelectCommon-f33709d2.js +2 -0
  43. package/amd/{useSelectCommon-a02ddf3c.js.map → useSelectCommon-f33709d2.js.map} +1 -1
  44. package/cjs/{BaseCardView-c0909427.js → BaseCardView-ba63723a.js} +4 -1
  45. package/cjs/{BaseCardView-c0909427.js.map → BaseCardView-ba63723a.js.map} +1 -1
  46. package/cjs/PRIVATE_BaseCardView.js +1 -1
  47. package/cjs/PRIVATE_TableList.js +4 -4
  48. package/cjs/SegmentStyles.styles.css +9 -12
  49. package/cjs/SegmentStyles.styles2.css +12 -9
  50. package/cjs/{TabBar-27ae2c21.js → TabBar-4bc753a9.js} +3 -1
  51. package/{es/TabBar-67ca442c.js.map → cjs/TabBar-4bc753a9.js.map} +1 -1
  52. package/cjs/Theme-redwood/theme.css +146 -146
  53. package/cjs/Theme-stable/theme.css +311 -311
  54. package/cjs/UNSAFE_CardFlexView.js +1 -1
  55. package/cjs/UNSAFE_CardGridView.js +1 -1
  56. package/cjs/UNSAFE_ListView.js +53 -53
  57. package/cjs/UNSAFE_OverflowTabBar.js +10 -10
  58. package/cjs/UNSAFE_ReorderableTabBar.js +12 -12
  59. package/cjs/UNSAFE_TabBar.js +10 -10
  60. package/cjs/UNSAFE_TabBarMixed.js +8 -8
  61. package/es/{BaseCardView-b3d8bae0.js → BaseCardView-85b9a71e.js} +1 -4
  62. package/es/{BaseCardView-b3d8bae0.js.map → BaseCardView-85b9a71e.js.map} +1 -1
  63. package/es/ButtonLayoutVariants.styles.css +2 -2
  64. package/es/ButtonLayoutVariants.styles2.css +2 -2
  65. package/es/{Chart-b866a74c.js → Chart-8c63da28.js} +2 -2
  66. package/es/{Chart-b866a74c.js.map → Chart-8c63da28.js.map} +1 -1
  67. package/es/CheckboxSetContext-1be56556.js +9 -0
  68. package/es/CheckboxSetContext-1be56556.js.map +1 -0
  69. package/es/{ColorPicker-ae648c4c.js → ColorPicker-fa103067.js} +2 -2
  70. package/es/{ColorPicker-ae648c4c.js.map → ColorPicker-fa103067.js.map} +1 -1
  71. package/es/PRIVATE_BaseCardView.js +1 -1
  72. package/es/PRIVATE_Chart.js +4 -4
  73. package/es/PRIVATE_CollapsibleNavigationList.js +25 -25
  74. package/es/PRIVATE_TableList.js +4 -4
  75. package/es/SegmentStyles.styles.css +12 -9
  76. package/es/SegmentStyles.styles2.css +9 -12
  77. package/es/{TabBar-67ca442c.js → TabBar-10488830.js} +1 -3
  78. package/{cjs/TabBar-27ae2c21.js.map → es/TabBar-10488830.js.map} +1 -1
  79. package/es/Theme-redwood/theme.css +506 -506
  80. package/es/Theme-stable/theme.css +427 -427
  81. package/es/UNSAFE_BarChart.js +4 -4
  82. package/es/UNSAFE_ButtonLayout/themes/redwood/ButtonLayoutTheme.js +1 -1
  83. package/es/UNSAFE_ButtonLayout/themes/redwood/ButtonLayoutVariants.css.js +1 -1
  84. package/es/UNSAFE_ButtonLayout/themes/stable/ButtonLayoutTheme.js +1 -1
  85. package/es/UNSAFE_ButtonLayout/themes/stable/ButtonLayoutVariants.css.js +1 -1
  86. package/es/UNSAFE_ButtonLayout.js +1 -1
  87. package/es/UNSAFE_CardFlexView.js +1 -1
  88. package/es/UNSAFE_CardGridView.js +1 -1
  89. package/es/UNSAFE_CheckboxItem.js +61 -122
  90. package/es/UNSAFE_CheckboxItem.js.map +1 -1
  91. package/es/UNSAFE_CheckboxSet.js +49 -15
  92. package/es/UNSAFE_CheckboxSet.js.map +1 -1
  93. package/es/UNSAFE_ColorPicker.js +25 -25
  94. package/es/UNSAFE_ComboChart.js +4 -4
  95. package/es/UNSAFE_FlatTreeView.js +14 -14
  96. package/es/UNSAFE_InputColor.js +2 -2
  97. package/es/UNSAFE_InputDateMask/themes/SegmentStyles.css.js +1 -1
  98. package/es/UNSAFE_InputDateMask.js +1 -1
  99. package/es/UNSAFE_InputDatePicker.js +1 -1
  100. package/es/UNSAFE_InputTimeMask/themes/SegmentStyles.css.js +1 -1
  101. package/es/UNSAFE_InputTimeMask.js +1 -1
  102. package/es/UNSAFE_LineAreaChart.js +4 -4
  103. package/es/UNSAFE_ListView.js +53 -53
  104. package/es/UNSAFE_OverflowTabBar.js +10 -10
  105. package/es/UNSAFE_ReorderableTabBar.js +12 -12
  106. package/es/UNSAFE_RichCheckboxSet.js +42 -46
  107. package/es/UNSAFE_RichCheckboxSet.js.map +1 -1
  108. package/es/UNSAFE_RichSelectionItem.js +89 -152
  109. package/es/UNSAFE_RichSelectionItem.js.map +1 -1
  110. package/es/UNSAFE_ScatterChart.js +4 -4
  111. package/es/UNSAFE_TabBar.js +10 -10
  112. package/es/UNSAFE_TabBarMixed.js +8 -8
  113. package/es/UNSAFE_Toolbar.js +1 -1
  114. package/package.json +2 -2
  115. package/amd/ExpandableList-a9a86ad8.js +0 -2
  116. package/amd/ListView-6d21e8f9.js +0 -2
  117. package/amd/VirtualizedListView-1ae7151d.js +0 -2
  118. package/amd/useSelectCommon-a02ddf3c.js +0 -2
  119. package/es/CheckboxSet-3aab5935.js +0 -51
  120. package/es/CheckboxSet-3aab5935.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"BaseCardView-c0909427.js","sources":["../../src/PRIVATE_BaseCardView/BaseCardViewUtils.ts","../../src/PRIVATE_BaseCardView/BaseCardViewReorderableItem.tsx","../../src/PRIVATE_BaseCardView/BaseCardViewItem.tsx","../../src/PRIVATE_BaseCardView/BaseCardViewLayout.tsx","../../src/PRIVATE_BaseCardView/BaseCardViewSkeletonContainer.tsx","../../src/PRIVATE_BaseCardView/BaseCardViewSkeleton.tsx","../../src/PRIVATE_BaseCardView/useCardViewReorder.ts","../../src/PRIVATE_BaseCardView/BaseCardView.tsx"],"sourcesContent":["import { Size } from '../utils/UNSAFE_size';\n\n/**\n * Item selector for CardView components\n */\nexport const CARDVIEW_ITEM_SELECTOR = '[data-oj-card-item]';\n\nexport const emptyKeys = { all: false, keys: new Set() };\nexport type GutterSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\n\n/**\n * A mapping of gutterSize to concrete size in pixels\n */\nexport const gutterSizeToPX: Record<string, number> = {\n xs: 12,\n sm: 16,\n md: 24,\n lg: 48,\n xl: 64\n};\n\nexport const getGapSize = (gutterSize?: GutterSize) => {\n const px = gutterSizeToPX[gutterSize || 'sm'];\n const gap = `${px / 4}x` as Size;\n return gap;\n};\n\nexport const getColCount = (gapWidth: number, cardWidth?: number, rootWidth?: number) => {\n if (!cardWidth || !rootWidth) return 0;\n\n // if we have n cards, we have n-1 gaps\n const colCount = Math.floor((rootWidth + gapWidth) / (gapWidth + cardWidth));\n return Math.max(1, colCount);\n};\n","import { useRef, useCallback, useEffect } from 'preact/hooks';\nimport { useReorderableItem } from '../hooks/PRIVATE_useReorderable';\nimport { useUser } from '../hooks/UNSAFE_useUser';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { ReorderableItemProps } from '../UNSAFE_Collection/Reorderable.types';\nimport { multiVariantStyles, styles } from './themes/BaseCardViewStyles.css';\nimport { CARDVIEW_ITEM_SELECTOR, GutterSize } from './BaseCardViewUtils';\nimport { useReorderableContext } from '#hooks/PRIVATE_useReorderable/useReorderableContext';\nimport { isKeyDefined } from '../utils/UNSAFE_keys';\n\ntype BaseItemProps<K> = {\n itemKey: K;\n itemIndex: number;\n isCurrentKey: boolean;\n};\n\nexport type BaseCardViewReorderableItemProps<K> = ReorderableItemProps<K> & {\n gutterSize: GutterSize;\n columns: number;\n};\n\n/**\n * The internal component used to render a reorderable item in CardView.\n */\nexport function BaseCardViewReorderableItem<K extends string | number>({\n children,\n itemKey,\n itemIndex,\n isCurrentKey,\n dragKey,\n setDragKey,\n onReorder,\n rootRef,\n gutterSize,\n columns\n}: BaseCardViewReorderableItemProps<K> & BaseItemProps<K>) {\n const itemRef = useRef<HTMLDivElement | null>(null);\n const isOneColumn = columns === 1;\n const isFirstColumn = itemIndex % columns === 0;\n const isLastColumn = itemIndex % columns === columns - 1;\n const variantClasses = multiVariantStyles({\n itemOverlayFront: gutterSize\n });\n const variantClassesVertical = multiVariantStyles({\n itemOverlayFrontVertical: gutterSize\n });\n const itemStyles = {\n itemOverlayFront: isOneColumn ? variantClassesVertical : variantClasses,\n itemOverlayRear: isOneColumn ? styles.itemOverlayRearVertical : styles.itemOverlayRear,\n itemDragger: styles.itemDragger\n };\n const getItem = useCallback(\n () => itemRef?.current?.closest(CARDVIEW_ITEM_SELECTOR) as HTMLElement,\n []\n );\n const setTransferData = useCallback(\n (event: DragEvent) => {\n event.dataTransfer?.setData('text/cardview-items-key', JSON.stringify(itemKey));\n },\n [itemKey]\n );\n const { rootProps, isDragged, overlayZoneBeforeProps, overlayZoneAfterProps } =\n useReorderableItem({\n isDisabled: onReorder ? false : true,\n dragKey,\n setDragKey,\n onReorder,\n rootRef,\n ref: itemRef,\n getItem,\n setTransferData,\n itemStyles,\n itemSelector: CARDVIEW_ITEM_SELECTOR,\n isVertical: isOneColumn\n });\n\n // TODO: remove this as part of JET-70023\n const { currentItemKey } = useReorderableContext();\n useEffect(() => {\n if (isCurrentKey) {\n currentItemKey.current = itemKey;\n }\n }, [isCurrentKey, itemKey, currentItemKey]);\n\n const { direction } = useUser();\n const isRtl = direction === 'rtl';\n\n const overlayZoneBeforeClass = classNames([\n overlayZoneBeforeProps?.class,\n !isOneColumn && !isRtl && isFirstColumn && styles.itemOverlayFrontEdge,\n !isOneColumn && isRtl && isLastColumn && styles.itemOverlayFrontEdge\n ]);\n\n const overlayZoneAfterClass = classNames([\n overlayZoneAfterProps?.class,\n !isOneColumn && !isRtl && isLastColumn && styles.itemOverlayRearEdge,\n !isOneColumn && isRtl && isFirstColumn && styles.itemOverlayRearEdge\n ]);\n\n return (\n <div {...rootProps}>\n {children}\n {!isDragged && isKeyDefined(dragKey) && (\n <>\n <div {...overlayZoneBeforeProps} class={overlayZoneBeforeClass}></div>\n <div {...overlayZoneAfterProps} class={overlayZoneAfterClass}></div>\n </>\n )}\n </div>\n );\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { ComponentChildren } from 'preact';\nimport { memo } from 'preact/compat';\nimport {\n useRef,\n useCallback,\n useLayoutEffect,\n useMemo,\n useEffect,\n StateUpdater,\n Dispatch,\n MutableRef\n} from 'preact/hooks';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { mergeRefs } from '../utils/PRIVATE_refUtils';\nimport { warn } from '../utils/UNSAFE_logger';\nimport { allTabbableElements } from '../utils/PRIVATE_tabbableUtils';\nimport { useId } from '../hooks/UNSAFE_useId';\nimport { useAnimation, UseAnimationConfig } from '../hooks/UNSAFE_useAnimation';\nimport { useResizeObserver } from '../hooks/UNSAFE_useResizeObserver';\nimport { TabbableModeContext } from '../hooks/UNSAFE_useTabbableMode';\nimport { FocusTrap } from '../UNSAFE_FocusTrap';\nimport { SelectionMode, ListItemRendererContext, SelectionDetail } from '../UNSAFE_Collection';\nimport { multiVariantStyles, styles } from './themes/BaseCardViewStyles.css';\nimport {\n BaseCardViewReorderableItem,\n BaseCardViewReorderableItemProps\n} from './BaseCardViewReorderableItem';\nimport { containsKey, isSameKey, Keys } from '../utils/UNSAFE_keys';\nimport { getItemContext } from '../utils/PRIVATE_collectionUtils';\n\n/**\n * Props for the BaseCardViewItem Component\n */\nexport type Props<K, D> = {\n children: (context: ListItemRendererContext<K, D>) => ComponentChildren;\n itemKey: K;\n itemData: D;\n itemIndex: number;\n isTabbable: boolean;\n isCurrentKey: boolean;\n isFocused: boolean;\n isFocusRingVisible: boolean;\n selectedKeys: Keys<K>;\n selectionMode: SelectionMode;\n onSelectionChange?: (detail: SelectionDetail<K>) => void;\n focusBehavior: 'card' | 'content';\n setIsFocusBehaviorValid?: Dispatch<StateUpdater<boolean>>;\n initialAnimation?: 'slideUp' | 'slideDown';\n isGridLayout?: boolean;\n updateCardSize?: (width: number, height: number) => void;\n onAnimationBusyStart?: () => void;\n onAnimationBusyEnd?: () => void;\n} & {\n reorderItemProps?: Omit<BaseCardViewReorderableItemProps<K>, 'children'>;\n};\n\n/**\n * The internal component used to render a single item in CardView.\n */\nfunction BaseCardViewItem<K extends string | number, D>({\n children,\n itemKey,\n itemData,\n itemIndex,\n isTabbable,\n isCurrentKey,\n isFocused,\n isFocusRingVisible,\n selectedKeys,\n selectionMode,\n onSelectionChange,\n focusBehavior,\n setIsFocusBehaviorValid,\n initialAnimation,\n isGridLayout,\n updateCardSize,\n reorderItemProps,\n onAnimationBusyStart,\n onAnimationBusyEnd\n}: Props<K, D>) {\n const rootRef = useRef<HTMLDivElement>(null);\n const timeoutRef = useRef<ReturnType<typeof setTimeout>>();\n\n const isItemFocused = isFocused && isFocusRingVisible;\n const variantClasses = multiVariantStyles({\n itemFocused: focusBehavior === 'card' && isItemFocused ? 'isItemFocused' : 'isNotItemFocused',\n itemInitialOpacity: initialAnimation ? 'isTransparent' : 'isNotTransparent',\n itemInGridLayout: isGridLayout ? 'isInGridLayout' : 'isNotInGridLayout'\n });\n const classes = classNames([styles.itemStyle, variantClasses]);\n\n /*********************************** Tabbable Mode ***********************************/\n\n // don't bubble Arrow Up/Down/Left/Right events to parent when in isTabbable mode\n // this bubbling causes the outer CollectionFocus ring to change index while in the isTabbable mode.\n const handleKeyDown = (event: KeyboardEvent) => {\n if (\n focusBehavior === 'card' &&\n isTabbable &&\n (event.key === 'ArrowDown' ||\n event.key === 'ArrowUp' ||\n event.key === 'ArrowLeft' ||\n event.key === 'ArrowRight')\n ) {\n event.stopPropagation();\n }\n };\n\n /************************************ Card Size ************************************/\n\n const handleResize = useCallback(\n (entry: ResizeObserverEntry) => {\n updateCardSize?.(entry.contentRect.width, entry.contentRect.height);\n },\n [updateCardSize]\n );\n\n const nullRef = useRef<HTMLDivElement>(null);\n useResizeObserver(updateCardSize ? rootRef : nullRef, handleResize);\n\n /********************************* Focus Behavior *********************************/\n\n useLayoutEffect(() => {\n if (focusBehavior === 'content' && isItemFocused) {\n // rootRef is cardview item, its first child is the focus trap div, so its first grand child\n // is the actual content\n const content = rootRef.current?.firstElementChild?.firstElementChild as HTMLElement;\n const focusable = allTabbableElements(content, true, true);\n if (focusable.length === 0 || focusable.length > 1) {\n warn(\n `${focusable.length} focusable elements are detected in the card. 'content' focusBehavior is intended only for use when the card has single focusable element. Please specify one focusable element in the card or switch the focusBehavior to 'card'.`\n );\n setIsFocusBehaviorValid?.(false);\n } else {\n focusable[0].focus();\n }\n }\n }, [focusBehavior, isItemFocused, setIsFocusBehaviorValid]);\n\n /******************************** Initial Animation ********************************/\n\n // animation for slide up/down\n const { nodeRef: nodeRefSlide, controller: controllerSlide } = useAnimation<\n 'slideUp' | 'slideDown' | 'none',\n HTMLDivElement\n >(initialAnimation || 'none', animationConfigSlide(itemIndex));\n\n // animation for opacity change\n const { nodeRef: nodeRefOpacity, controller: controllerOpacity } = useAnimation<\n 'opacity' | 'none',\n HTMLDivElement\n >(\n (initialAnimation && 'opacity') || 'none',\n animationConfigOpacity(itemIndex, timeoutRef, onAnimationBusyEnd)\n );\n\n if (initialAnimation) {\n onAnimationBusyStart?.();\n }\n\n // max cap for animation is 1s\n useEffect(() => {\n if (initialAnimation !== undefined) {\n timeoutRef.current = setTimeout(() => {\n controllerSlide.cancel();\n controllerOpacity.cancel();\n if (rootRef.current) {\n rootRef.current.style.opacity = '1';\n }\n onAnimationBusyEnd?.();\n }, 1000);\n }\n }, [controllerOpacity, controllerSlide, initialAnimation, onAnimationBusyEnd]);\n\n // TODO: issue track in JET-57681, we currently have two useAnimation() because the opacity and\n // slide up/down have different durations, and the current API couldn't handle this case, we will\n // update this once the API is updated\n\n /********************************** Child Component **********************************/\n const itemRefs = useMemo(() => {\n // NOTE: spot an issue when we click the cards during animation is processing, the cards would not finish\n // the current animations and stay as what it is, e.g. leave itself as half transparent.\n // need to remove nodeRefSlide and nodeRefOpacity to avoid this issue.\n if (initialAnimation === undefined) {\n return mergeRefs(rootRef);\n }\n return mergeRefs(rootRef, nodeRefSlide, nodeRefOpacity);\n }, [rootRef, nodeRefSlide, nodeRefOpacity, initialAnimation]);\n\n const rendererContext = getItemContext<K, D>(\n { data: { data: itemData, metadata: { key: itemKey } }, index: itemIndex },\n selectedKeys,\n selectionMode === 'multiple',\n onSelectionChange\n );\n\n const childrenComponent = reorderItemProps ? (\n <BaseCardViewReorderableItem\n {...reorderItemProps}\n itemKey={itemKey}\n itemIndex={itemIndex}\n isCurrentKey={isCurrentKey}>\n {children(rendererContext)}\n </BaseCardViewReorderableItem>\n ) : (\n children(rendererContext)\n );\n\n return (\n <div\n id={useId()}\n ref={itemRefs}\n class={classes}\n role=\"gridcell\"\n data-oj-card-item=\"\"\n data-oj-key={itemKey}\n onKeyDown={handleKeyDown}\n aria-selected={selectionMode === 'none' ? undefined : containsKey(selectedKeys, itemKey)}\n {...(typeof itemKey === 'number' && { 'data-oj-key-type': 'number' })}>\n <TabbableModeContext.Provider value={{ isTabbable }}>\n <FocusTrap isDisabled={!isTabbable} restoreFocusRef={false}>\n {childrenComponent}\n </FocusTrap>\n </TabbableModeContext.Provider>\n </div>\n );\n}\n\nconst animationConfigSlide = (\n index: number\n): UseAnimationConfig<'slideUp' | 'slideDown' | 'none', HTMLDivElement> => {\n return {\n animationStates: {\n slideUp: {\n from: {\n translateY: '50px'\n },\n to: {\n translateY: '0px'\n },\n options: {\n duration: 300,\n delay: index * 50,\n easing: [0, 0, 0.2, 1]\n }\n },\n slideDown: {\n from: {\n translateY: '-50px'\n },\n to: {\n translateY: '0'\n },\n options: {\n duration: 300,\n delay: index * 50,\n easing: [0, 0, 0.2, 1]\n }\n }\n },\n isAnimatedOnMount: true\n };\n};\n\nconst animationConfigOpacity = (\n index: number,\n timeoutRef: MutableRef<ReturnType<typeof setTimeout> | undefined>,\n onAnimationBusyEnd?: () => void\n): UseAnimationConfig<'opacity' | 'none', HTMLDivElement> => {\n return {\n animationStates: {\n opacity: {\n from: {\n opacity: 0\n },\n to: {\n opacity: 1\n },\n options: {\n duration: 150,\n delay: index * 50,\n easing: 'linear'\n }\n }\n },\n isAnimatedOnMount: true,\n onAnimationEnd: () => {\n onAnimationBusyEnd?.();\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n }\n };\n};\n\n/**\n * Compare the equality between two reorderItemProps, especially useful for memoized items\n */\nconst _compareReorderItemProps = (\n props1: Props<string | number, unknown>['reorderItemProps'],\n props2: Props<string | number, unknown>['reorderItemProps']\n) => {\n return (\n props1?.['dragKey'] === props2?.['dragKey'] &&\n props1?.['setDragKey'] === props2?.['setDragKey'] &&\n props1?.['columns'] === props2?.['columns'] &&\n props1?.['gutterSize'] === props2?.['gutterSize'] &&\n props1?.['rootRef'] === props2?.['rootRef']\n );\n};\n\nexport const MemoizeBaseCardViewItem = memo(\n BaseCardViewItem,\n (prev: Props<string | number, unknown>, next: Props<string | number, unknown>) => {\n if (prev && next) {\n return (\n prev.children === next.children &&\n prev.itemKey === next.itemKey &&\n prev.itemData === next.itemData &&\n prev.itemIndex === next.itemIndex &&\n prev.isTabbable === next.isTabbable &&\n prev.isCurrentKey === next.isCurrentKey &&\n prev.isFocused === next.isFocused &&\n prev.isFocusRingVisible === next.isFocusRingVisible &&\n prev.initialAnimation === next.initialAnimation &&\n prev.focusBehavior === next.focusBehavior &&\n isSameKey(prev.selectedKeys, next.selectedKeys) &&\n prev.selectionMode === next.selectionMode &&\n prev.onSelectionChange === next.onSelectionChange &&\n prev.setIsFocusBehaviorValid === next.setIsFocusBehaviorValid &&\n prev.isGridLayout === next.isGridLayout &&\n prev.updateCardSize === next.updateCardSize &&\n prev.onAnimationBusyStart === next.onAnimationBusyStart &&\n prev.onAnimationBusyEnd === next.onAnimationBusyEnd &&\n _compareReorderItemProps(prev.reorderItemProps, next.reorderItemProps)\n );\n }\n return false;\n }\n);\n","import { ComponentChildren } from 'preact';\nimport { Grid } from '../UNSAFE_Grid';\nimport { Flex } from '../UNSAFE_Flex';\nimport { GutterSize } from './BaseCardViewUtils';\nimport { cardViewVars } from './themes/BaseCardViewContract.css';\n\ntype Props = {\n children: ComponentChildren;\n layout: 'grid' | 'flex';\n gutterSize: GutterSize;\n columns: number;\n};\n\nexport function BaseCardViewLayout({ children, layout, gutterSize, columns }: Props) {\n const gap = cardViewVars.gutterSize[gutterSize];\n if (layout === 'grid') {\n return columns < 1 ? null : (\n <Grid gridTemplateColumns={`repeat(${columns}, 1fr)`} gap={gap}>\n {children}\n </Grid>\n );\n } else {\n return (\n <Flex wrap=\"wrap\" gap={gap}>\n {children}\n </Flex>\n );\n }\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { ComponentChildren, Fragment } from 'preact';\nimport { useState, useEffect } from 'preact/hooks';\nimport { LOADMORE_STYLE_CLASS } from '../PRIVATE_LoadMoreCollection';\n\ntype Props = {\n /**\n * Allows to pass skeletons\n **/\n children: ComponentChildren;\n};\n\n/**\n * Allows to specify the time delay for rendering the component\n **/\nconst timerValue = 50;\n\n/**\n * BaseCardViewSkeletonContainer renders skeletons after 50ms threshold defined in the Redwood spec\n **/\nexport function BaseCardViewSkeletonContainer({ children }: Props) {\n const [isVisible, setIsVisible] = useState(false);\n\n useEffect(() => {\n setTimeout(() => {\n setIsVisible(true);\n }, timerValue);\n }, []);\n\n return isVisible ? <Fragment>{children}</Fragment> : <div class={LOADMORE_STYLE_CLASS}></div>;\n}\n","import { Size } from '../utils/UNSAFE_size';\nimport { Skeleton } from '../UNSAFE_Skeleton';\nimport { LOADMORE_STYLE_CLASS } from '../PRIVATE_LoadMoreCollection';\nimport { BaseCardViewSkeletonContainer } from './BaseCardViewSkeletonContainer';\nimport { SkeletonRendererContext } from '../UNSAFE_CardFlexView';\nimport { ComponentChildren } from 'preact';\n\nconst DEFAULT_SKELETON_NUMBER = 25;\nconst DEFAULT_SKELETON_WIDTH = '80x';\nconst DEFAULT_SKELETON_HEIGHT = '85x';\n\ntype SkeletonProps = {\n layout: 'flex' | 'grid';\n colCount: number;\n totalCount: number;\n cardWidth?: number;\n cardHeight?: number;\n};\n\n/**\n * A function that returns an array of skeletons based on count\n * @param count the number of skeletons\n */\nconst getSkeletonsByCount = (\n layout: 'flex' | 'grid',\n count = DEFAULT_SKELETON_NUMBER,\n width?: Size,\n height?: Size,\n isUnique = true\n) => {\n const sw = width || (layout === 'flex' ? DEFAULT_SKELETON_WIDTH : '100%');\n const sh = height || DEFAULT_SKELETON_HEIGHT;\n\n return [...Array(count)].map((_v, i) => (\n // create unique keys if needed, otherwise the animations won't start at the same time, because the old copy of skeletons\n // could be reused, even the key is specified by useId(), combine count with time to make the key unique.\n <Skeleton\n key={isUnique && `${i}${new Date().getTime()}`}\n width={sw}\n height={sh}\n borderRadius=\"6px\"\n />\n ));\n};\n\n/**\n * When there is no data (i.e. data is an empty array or null, and hasMore is false), we will show 25 card skeletons with default size\n */\nexport const InitialLoadSkeletons = (props: { layout: SkeletonProps['layout'] }) => (\n <BaseCardViewSkeletonContainer>{getSkeletonsByCount(props.layout)}</BaseCardViewSkeletonContainer>\n);\n\n/**\n * When we are fetching the initial data (i.e. data is an empty array, and hasMore is true), we will show 25 card skeletons with default size,\n * because we don't know the card dimension at this time. Since there is more data to load, we will specify LOADMORE_STYLE_CLASS on skeletons\n */\nexport const DefaultLoadMoreSkeletons = (props: { layout: SkeletonProps['layout'] }) => {\n const firstSkeleton = (\n <div class={LOADMORE_STYLE_CLASS}>{getSkeletonsByCount(props.layout, 1)}</div>\n );\n const otherSkeletons = getSkeletonsByCount(props.layout, DEFAULT_SKELETON_NUMBER - 1);\n const skeletons = [firstSkeleton, ...otherSkeletons];\n return <BaseCardViewSkeletonContainer>{skeletons}</BaseCardViewSkeletonContainer>;\n};\n\n/**\n * During the render that we measure and update card dimension, we will hide skeletons temporarily\n * to avoid showing incorrect skeletons\n */\nconst InvisibleSkeletons = () => {\n return <div class={LOADMORE_STYLE_CLASS}></div>;\n};\n\nexport const LoadMoreSkeletons = (props: SkeletonProps) => {\n if (props.colCount < 1 || props.cardWidth == null || props.cardHeight == null) {\n // if column count / card width / card height are invalid, we will show the invisible skeletons\n return <InvisibleSkeletons />;\n } else {\n // after initial renders, show skeletons with correct dimension and count\n const skeletons = [];\n\n const firstRowColCount = props.colCount - (props.totalCount % props.colCount);\n const isOnlyOneRow = firstRowColCount === props.colCount;\n\n const cardWidth = `calc(${props.cardWidth}px)` as Size;\n const cardHeight = props.cardHeight\n ? (`calc(${props.cardHeight}px)` as Size)\n : DEFAULT_SKELETON_HEIGHT;\n\n const width: Size = props.layout === 'flex' ? cardWidth : '100%';\n const height: Size = props.layout === 'flex' || isOnlyOneRow ? cardHeight : '100%';\n\n // first row\n const firstSkeleton = (\n <div class={LOADMORE_STYLE_CLASS}>{getSkeletonsByCount(props.layout, 1, width, height)}</div>\n );\n skeletons.push(firstSkeleton);\n skeletons.push(getSkeletonsByCount(props.layout, firstRowColCount - 1, width, height));\n\n // second row\n if (!isOnlyOneRow) {\n skeletons.push(getSkeletonsByCount(props.layout, props.colCount, width, cardHeight));\n }\n\n return <BaseCardViewSkeletonContainer>{skeletons}</BaseCardViewSkeletonContainer>;\n }\n};\n\nexport const CustomInitialSkeletions = (props: {\n skeletonRenderer: (context: SkeletonRendererContext) => ComponentChildren;\n}) => {\n const context: SkeletonRendererContext = { loadingStatus: 'initial' };\n return (\n <BaseCardViewSkeletonContainer>\n {renderMultipleSkeletons(context, 25, props.skeletonRenderer)}\n </BaseCardViewSkeletonContainer>\n );\n};\n\nexport const CustomLoadMoreSkeletons = (\n props: {\n isRenderAsInitial: boolean;\n skeletonRenderer: (context: SkeletonRendererContext) => ComponentChildren;\n } & SkeletonProps\n) => {\n const skeletons = [];\n if (props.isRenderAsInitial) {\n const context: SkeletonRendererContext = { loadingStatus: 'initial' };\n skeletons.push(<div class={LOADMORE_STYLE_CLASS}>{props.skeletonRenderer(context)}</div>);\n skeletons.push(renderMultipleSkeletons(context, 24, props.skeletonRenderer));\n } else {\n if (props.colCount === 0) {\n return null;\n }\n const cardWidth = `calc(${props.cardWidth}px)` as Size;\n const cardHeight = `calc(${props.cardHeight}px)` as Size;\n const firstRowColCount = props.colCount - (props.totalCount % props.colCount);\n const isOnlyOneRow = firstRowColCount === props.colCount;\n const context: SkeletonRendererContext = {\n loadingStatus: 'loadMore',\n height: props.layout === 'flex' || isOnlyOneRow ? cardHeight : '100%',\n width: props.layout === 'flex' ? cardWidth : '100%'\n };\n skeletons.push(<div class={LOADMORE_STYLE_CLASS}>{props.skeletonRenderer(context)}</div>);\n skeletons.push(\n Array(renderMultipleSkeletons(context, firstRowColCount - 1, props.skeletonRenderer))\n );\n if (!isOnlyOneRow) {\n skeletons.push(renderMultipleSkeletons(context, props.colCount, props.skeletonRenderer));\n }\n }\n return <BaseCardViewSkeletonContainer>{skeletons}</BaseCardViewSkeletonContainer>;\n};\n\nconst renderMultipleSkeletons = (\n context: SkeletonRendererContext,\n count: number,\n skeletonRenderer: (context: SkeletonRendererContext) => ComponentChildren\n) => {\n return Array(count).fill(skeletonRenderer(context));\n};\n","import type { RefObject } from 'preact';\nimport { useState } from 'preact/hooks';\nimport { dragToScroll } from '../utils/PRIVATE_collectionUtils';\nimport { useReorderable } from '../hooks/PRIVATE_useReorderable';\nimport { Props } from '../UNSAFE_CardFlexView';\nimport { CARDVIEW_ITEM_SELECTOR, GutterSize } from './BaseCardViewUtils';\n\ntype useCardViewReorderProps<K, D> = Pick<Props<K, D>, 'onReorder'> & {\n gutterSize: GutterSize;\n columns: number;\n rootRef: RefObject<HTMLDivElement>;\n scrollCurrItemIntoView: RefObject<boolean>;\n};\n\nexport const useCardViewReorder = <K extends string | number, D>({\n onReorder,\n gutterSize,\n columns,\n rootRef,\n scrollCurrItemIntoView\n}: useCardViewReorderProps<K, D>) => {\n const isReorderEnabled = onReorder != undefined;\n\n const [dragKey, setDragKey] = useState<K | undefined>(undefined);\n const { reorderProps, reorderContext, reorderInstructionsId, reorderInstructions } =\n useReorderable({\n onReorder,\n rootRef,\n itemSelector: CARDVIEW_ITEM_SELECTOR,\n isDisabled: !isReorderEnabled,\n columns\n });\n\n if (!isReorderEnabled) {\n return {\n reorderProps,\n reorderContext,\n reorderInstructionsId,\n reorderInstructions\n } as const;\n }\n\n const handleDragOver = (event: DragEvent) => {\n dragToScroll(event, dragKey !== undefined, rootRef.current);\n // during mouse reordering, the drag item might not be the same as current item,\n // so we should disallow current item scroll into view\n scrollCurrItemIntoView.current = false;\n };\n\n const reorderEventProps = { ...reorderProps, onDragOver: handleDragOver };\n\n const reorderItemProps = {\n dragKey,\n setDragKey,\n onReorder,\n rootRef,\n gutterSize,\n columns\n };\n\n return {\n reorderProps: reorderEventProps,\n reorderItemProps,\n reorderContext,\n reorderInstructionsId,\n reorderInstructions\n } as const;\n};\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { Fragment } from 'preact';\nimport { forwardRef, ForwardedRef } from 'preact/compat';\nimport { useRef, useCallback, useEffect, useState, useImperativeHandle } from 'preact/hooks';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { Keys } from '../utils/UNSAFE_keys';\nimport {\n getPrevNextKeyByCount,\n getViewportConfig,\n findElementByKey,\n keyExtractor,\n handleSelectionRange\n} from '../utils/PRIVATE_collectionUtils';\n\nimport { useNavigation } from '../hooks/PRIVATE_useListCommon';\nimport { useSelection, SelectionRangeDetail } from '../hooks/PRIVATE_useSelection';\nimport { ReorderableContext } from '../hooks/PRIVATE_useReorderable';\nimport { ItemContext, SelectionDetail } from '../UNSAFE_Collection';\nimport { HiddenAccessible } from '../UNSAFE_HiddenAccessible';\nimport { LoadMoreCollection } from '../PRIVATE_LoadMoreCollection';\nimport { styles } from './themes/BaseCardViewStyles.css';\nimport { Props } from '../UNSAFE_CardFlexView';\nimport { MemoizeBaseCardViewItem } from './BaseCardViewItem';\nimport { BaseCardViewLayout } from './BaseCardViewLayout';\nimport {\n DefaultLoadMoreSkeletons,\n LoadMoreSkeletons,\n InitialLoadSkeletons,\n CustomInitialSkeletions,\n CustomLoadMoreSkeletons\n} from './BaseCardViewSkeleton';\nimport { gutterSizeToPX, emptyKeys, CARDVIEW_ITEM_SELECTOR } from './BaseCardViewUtils';\nimport { useCardViewReorder } from './useCardViewReorder';\n// TODO: add this import due to issue JET-67485, need to update once Stable is introduced\nimport './themes/redwood/BaseCardViewBaseTheme.css';\nimport { useAddBusyState } from '#hooks/PRIVATE_useAddBusyState';\nimport { getClientHints } from '#utils/PRIVATE_clientHints';\nimport { classNames } from '#utils/UNSAFE_classNames';\n\n/**\n * Props specific for the GradGridBaseImpl Component\n */\ntype BaseCardViewImplProps<K, D> = Props<K, D> & {\n /**\n * Provide the number of columns to render;\n */\n columns: number;\n /**\n * The layout of the BaseCardView. When we use CardGridView as parent, we will use grid layout;\n * when we use CardFlexView as parent, we will use flex layout.\n */\n layout: 'grid' | 'flex';\n /**\n * Card dimension, including width and height\n */\n cardSize: { width?: number; height?: number };\n /**\n * A callback function to update card dimension, including width and height\n */\n updateCardSize: (width: number, height: number) => void;\n};\n\nconst BaseCardViewImpl = forwardRef(\n <K extends string | number, D>(\n {\n children,\n data,\n onLoadMore = () => {},\n hasMore = false,\n getRowKey,\n currentItemOverride,\n onPersistCurrentItem,\n selectionMode = 'none',\n selectedKeys = emptyKeys as Keys<K>,\n onSelectionChange,\n onReorder,\n viewportConfig,\n focusBehavior = 'card',\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n 'aria-describedby': ariaDescribedBy,\n initialAnimation = 'slideUp',\n gutterSize = 'sm',\n columns,\n layout,\n cardSize,\n updateCardSize,\n skeletonRenderer\n }: BaseCardViewImplProps<K, D>,\n ref?: ForwardedRef<HTMLDivElement>\n ) => {\n const rootRef = useRef<HTMLDivElement>(null);\n useImperativeHandle(ref!, () => rootRef.current!, [rootRef]);\n\n // tracking the anchor key which is used for shift+click selection\n const anchorKey = useRef<K | undefined>();\n\n const gutterSizePX = gutterSizeToPX[gutterSize];\n const layoutProps = { layout, columns, gutterSize };\n\n //setup busy start and busy end callbacks for the initial animation\n const { onBusyStart: onAnimationBusyStart, onBusyEnd: onAnimationBusyEnd } = useAddBusyState(\n 'handling initial animation'\n );\n const isInitialAnimation = useRef(true);\n useEffect(() => {\n if (cardSize.height != undefined && cardSize.width != undefined) {\n isInitialAnimation.current = false;\n }\n }, [cardSize]);\n\n const ariaMultiSelectable = selectionMode === 'none' ? undefined : selectionMode === 'multiple';\n const ariaRowcount = 1;\n const ariaColcount = data ? data.length : -1;\n\n const [isFocusBehaviorValid, setIsFocusBehaviorValid] = useState(true);\n const validFocusBehavior = isFocusBehaviorValid ? focusBehavior : 'card';\n\n // ensure current item is scrolled into view when current item is updated\n // during reordering, enable that during keyboard reordering, disable that during mouse reordering\n const scrollCurrItemIntoView = useRef(false);\n const isReorderEnabled = onReorder != undefined;\n\n const isFetching = useRef(false);\n\n /*****************************************************************************************/\n /*********************** Current Key, Focus Ring and Tabbable Mode ***********************/\n /*****************************************************************************************/\n\n const arrowKeyAndHandlers = {\n ArrowUp: (key?: K) => getPrevNextKeyByCount(data, getRowKey, key, -columns),\n ArrowDown: (key?: K) => getPrevNextKeyByCount(data, getRowKey, key, columns),\n ArrowLeft: (key?: K) => getPrevNextKeyByCount(data, getRowKey, key, -1),\n ArrowRight: (key?: K) => getPrevNextKeyByCount(data, getRowKey, key, 1)\n };\n\n const {\n navigationProps,\n currentKey,\n isCurrentItemOverridden,\n showFocusRing,\n isCurrentTabbableKey\n } = useNavigation(\n data,\n rootRef,\n idExtractor,\n CARDVIEW_ITEM_SELECTOR,\n arrowKeyAndHandlers,\n currentItemOverride,\n onPersistCurrentItem,\n viewportConfig,\n undefined,\n selectionMode !== 'multiple',\n validFocusBehavior === 'card',\n validFocusBehavior === 'card',\n false\n );\n\n /*****************************************************************************************/\n /*************************************** Selection ***************************************/\n /*****************************************************************************************/\n\n const handleSelectionChange = useCallback(\n (detail: SelectionDetail<K>) => {\n if (onSelectionChange) {\n if (detail.value.all === false && detail.value.keys.size > 0) {\n // during regular selection, the last key selected by a user gesture is the anchor key\n anchorKey.current = Array.from(detail.value.keys.values()).pop();\n }\n onSelectionChange(detail);\n }\n },\n [anchorKey, onSelectionChange]\n );\n\n const handleSelectionRangeChange = useCallback(\n (detail: SelectionRangeDetail<K>) => {\n if (data && onSelectionChange) {\n const value = handleSelectionRange(detail, data, getRowKey);\n // for non-virtualized CardView, value should always be an array\n if (Array.isArray(value)) {\n if (detail.eventType === 'shiftSpace') {\n // during range selection by shift+space, the first key selected by a user gesture is the anchor key\n anchorKey.current = detail.value.start;\n } else {\n // during range selection by shift+click/arrow keys, the last key selected by a user gesture is the anchor key\n anchorKey.current = detail.value.end;\n }\n onSelectionChange({ value: { all: false, keys: new Set(value) }, target: null });\n }\n }\n },\n [data, onSelectionChange, getRowKey]\n );\n\n const { selectionProps } = useSelection(\n (element: HTMLElement) => {\n if (element === rootRef.current) {\n return currentKey === undefined ? null : currentKey;\n }\n return keyExtractor(element, CARDVIEW_ITEM_SELECTOR) as K;\n },\n selectedKeys,\n selectionMode,\n false,\n 'toggle',\n handleSelectionChange,\n anchorKey.current,\n currentKey,\n (currentKey: K | undefined, isPrev: boolean) =>\n getPrevNextKeyByCount(data, getRowKey, currentKey, isPrev ? -columns : columns),\n (currentKey: K | undefined, isPrev: boolean) =>\n getPrevNextKeyByCount(data, getRowKey, currentKey, isPrev ? -1 : 1),\n (key: K) => {\n if (rootRef.current) {\n const elem = findElementByKey(rootRef.current, key, CARDVIEW_ITEM_SELECTOR);\n if (elem) {\n elem.scrollIntoView({ block: 'nearest' });\n }\n }\n },\n handleSelectionRangeChange\n );\n\n /*****************************************************************************************/\n /**************************************** Reorder ****************************************/\n /*****************************************************************************************/\n\n const {\n reorderProps,\n reorderItemProps,\n reorderContext,\n reorderInstructionsId,\n reorderInstructions\n } = useCardViewReorder({\n onReorder,\n gutterSize,\n columns,\n rootRef,\n scrollCurrItemIntoView\n });\n\n const reorderAcc = isReorderEnabled && (\n <>\n <span id={reorderInstructionsId}>\n <HiddenAccessible>{reorderInstructions}</HiddenAccessible>\n </span>\n </>\n );\n\n const handleKeyDown = (event: KeyboardEvent) => {\n // for content focusBehavior, when users tab out, we need to focus back to card grid, to ensure\n // the tabbing order works properly, otherwise the focus might get stuck at the current item\n if (validFocusBehavior === 'content' && event.key === 'Tab') {\n rootRef.current?.focus({ preventScroll: true });\n }\n // during keyboard reordering, the current item should be scrolled into view\n const keyHandlers = ['ArrowLeft', 'ArrowRight', 'ArrowUp', 'ArrowDown'];\n if (\n isReorderEnabled &&\n (event.metaKey || event.ctrlKey) &&\n event.shiftKey &&\n keyHandlers.includes(event.key)\n ) {\n scrollCurrItemIntoView.current = true;\n }\n };\n\n useEffect(() => {\n if (isReorderEnabled && currentKey != null && rootRef.current) {\n const elem = findElementByKey(rootRef.current, currentKey, CARDVIEW_ITEM_SELECTOR);\n // make sure current item is visible during reordering\n // scroll the current item into view only when the current item is updated internally\n if (elem && scrollCurrItemIntoView.current && !isCurrentItemOverridden) {\n elem.scrollIntoView({ block: 'nearest' });\n scrollCurrItemIntoView.current = false;\n }\n }\n // since the currentKey will not change during keyboard reordering,\n // listen to data to ensure cardview scroll into view\n }, [currentKey, data, isReorderEnabled, isCurrentItemOverridden]);\n\n /*****************************************************************************************/\n /************************************* Load More *****************************************/\n /*****************************************************************************************/\n\n const handleLoadMore = useCallback(() => {\n // check isFetching to avoid multiple load more at the same time (details in JET-61117)\n if (!isFetching.current) {\n isFetching.current = true;\n onLoadMore();\n }\n }, [isFetching, onLoadMore]);\n\n useEffect(() => {\n isFetching.current = false;\n // listen to data and hasMore because when one of them gets updated, the fetching is done\n }, [data, hasMore]);\n\n /*****************************************************************************************/\n /************************************ Child Component ************************************/\n /*****************************************************************************************/\n\n const childrenComponent = (context: ItemContext<D>) => {\n const itemKey = getRowKey(context.data);\n const isTabbable = isCurrentTabbableKey(itemKey);\n const isFocused = currentKey === itemKey && !isTabbable;\n const isFocusRingVisible = isFocused && showFocusRing;\n const isLastCard = data ? context.index === data.length - 1 : false;\n return (\n <MemoizeBaseCardViewItem<K, D>\n key={itemKey}\n itemKey={itemKey}\n isCurrentKey={currentKey === itemKey}\n itemData={context.data}\n itemIndex={context.index}\n isTabbable={isTabbable}\n isFocused={isFocused}\n isFocusRingVisible={isFocusRingVisible}\n isGridLayout={layout === 'grid'}\n selectedKeys={selectedKeys}\n selectionMode={selectionMode}\n onSelectionChange={onSelectionChange}\n focusBehavior={validFocusBehavior}\n {...(context.index === 0 && isInitialAnimation.current && { onAnimationBusyStart })}\n {...(isLastCard && isInitialAnimation.current && { onAnimationBusyEnd })}\n {...(focusBehavior === 'content' && { setIsFocusBehaviorValid })}\n {...(isInitialAnimation.current && { initialAnimation })}\n {...(context.index === 0 && !cardSize.width && { updateCardSize })}\n {...(isReorderEnabled && { reorderItemProps })}>\n {children}\n </MemoizeBaseCardViewItem>\n );\n };\n\n // todo: issue track in JET-57952, need a way to show the skeletons in keyboard navigation\n const skeletons = data ? (\n !data.length && hasMore ? (\n skeletonRenderer ? (\n <CustomLoadMoreSkeletons\n layout={layout}\n colCount={columns}\n totalCount={data.length}\n cardWidth={cardSize.width}\n cardHeight={cardSize.height}\n isRenderAsInitial={true}\n skeletonRenderer={skeletonRenderer}\n />\n ) : (\n <DefaultLoadMoreSkeletons layout={layout} />\n )\n ) : skeletonRenderer ? (\n <CustomLoadMoreSkeletons\n layout={layout}\n colCount={columns}\n totalCount={data.length}\n cardWidth={cardSize.width}\n cardHeight={cardSize.height}\n isRenderAsInitial={false}\n skeletonRenderer={skeletonRenderer}\n />\n ) : (\n <LoadMoreSkeletons\n layout={layout}\n colCount={columns}\n totalCount={data.length}\n cardWidth={cardSize.width}\n cardHeight={cardSize.height}\n />\n )\n ) : null;\n\n viewportConfig = getViewportConfig(rootRef, viewportConfig);\n const collectionComponent = (\n <div role=\"row\">\n <BaseCardViewLayout {...layoutProps}>\n <LoadMoreCollection\n data={data}\n hasMore={hasMore}\n onLoadMore={handleLoadMore}\n loadMoreIndicator={skeletons}\n loadMoreThreshold={gutterSizePX + 4} // gap size + padding\n viewportConfig={viewportConfig}>\n {childrenComponent}\n </LoadMoreCollection>\n </BaseCardViewLayout>\n </div>\n );\n\n const initialLoadSkeletons = (\n <BaseCardViewLayout {...layoutProps}>\n {skeletonRenderer ? (\n <CustomInitialSkeletions skeletonRenderer={skeletonRenderer} />\n ) : (\n <InitialLoadSkeletons layout={layout} />\n )}\n </BaseCardViewLayout>\n );\n const allowBrowserContextMenu = !(\n getClientHints().platform === 'ios' || getClientHints().platform === 'android'\n );\n\n const classArray = [styles.baseStyle];\n if (!allowBrowserContextMenu) {\n classArray.push(styles.userSelect);\n }\n const classes = classNames(classArray);\n\n return (\n <div\n {...mergeProps(navigationProps, selectionProps, reorderProps, {\n onKeyDown: handleKeyDown\n })}\n ref={rootRef}\n role=\"grid\"\n class={classes}\n tabIndex={0}\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledBy}\n aria-describedby={\n isReorderEnabled ? reorderInstructionsId + ' ' + ariaDescribedBy : ariaDescribedBy\n }\n aria-multiselectable={ariaMultiSelectable}\n aria-rowcount={ariaRowcount}\n aria-colcount={ariaColcount}>\n <ReorderableContext.Provider value={reorderContext}>\n {!data ? (\n initialLoadSkeletons\n ) : data.length || hasMore ? (\n collectionComponent\n ) : (\n <Fragment />\n )}\n </ReorderableContext.Provider>\n {reorderAcc}\n </div>\n );\n }\n);\n\nconst idExtractor = (elem: Element) => elem.id;\n\n/**\n * Props specific for the BaseCardView\n */\ntype BaseCardViewProps<K, D> = BaseCardViewImplProps<K, D> & {\n ref?: ForwardedRef<HTMLDivElement>;\n};\n\n/**\n * Cast BaseCardViewImpl to generic type, because BaseCardViewImpl would infer the generic type to specific type,\n * i.e infer <K extends string | number, D> to <string | number, unknown>, which will cause type issues in the parent component\n */\nexport const BaseCardView = BaseCardViewImpl as <K extends string | number, D>(\n props: BaseCardViewProps<K, D>\n) => JSX.Element;\n"],"names":["useRef","multiVariantStyles","styles","useCallback","useReorderableItem","useReorderableContext","useEffect","useUser","classNames","_jsxs","isKeyDefined","_Fragment","_jsx","useResizeObserver","useLayoutEffect","allTabbableElements","warn","useAnimation","useMemo","mergeRefs","getItemContext","useId","containsKey","TabbableModeContext","FocusTrap","memo","isSameKey","cardViewVars","Grid","Flex","useState","Fragment","LOADMORE_STYLE_CLASS","Skeleton","useReorderable","dragToScroll","forwardRef","useImperativeHandle","useAddBusyState","getPrevNextKeyByCount","useNavigation","handleSelectionRange","useSelection","keyExtractor","findElementByKey","HiddenAccessible","getViewportConfig","LoadMoreCollection","getClientHints","mergeProps","ReorderableContext"],"mappings":"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"}
1
+ {"version":3,"file":"BaseCardView-ba63723a.js","sources":["../../src/PRIVATE_BaseCardView/BaseCardViewUtils.ts","../../src/PRIVATE_BaseCardView/BaseCardViewReorderableItem.tsx","../../src/PRIVATE_BaseCardView/BaseCardViewItem.tsx","../../src/PRIVATE_BaseCardView/BaseCardViewLayout.tsx","../../src/PRIVATE_BaseCardView/BaseCardViewSkeletonContainer.tsx","../../src/PRIVATE_BaseCardView/BaseCardViewSkeleton.tsx","../../src/PRIVATE_BaseCardView/useCardViewReorder.ts","../../src/PRIVATE_BaseCardView/BaseCardView.tsx"],"sourcesContent":["import { Size } from '../utils/UNSAFE_size';\n\n/**\n * Item selector for CardView components\n */\nexport const CARDVIEW_ITEM_SELECTOR = '[data-oj-card-item]';\n\nexport const emptyKeys = { all: false, keys: new Set() };\nexport type GutterSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\n\n/**\n * A mapping of gutterSize to concrete size in pixels\n */\nexport const gutterSizeToPX: Record<string, number> = {\n xs: 12,\n sm: 16,\n md: 24,\n lg: 48,\n xl: 64\n};\n\nexport const getGapSize = (gutterSize?: GutterSize) => {\n const px = gutterSizeToPX[gutterSize || 'sm'];\n const gap = `${px / 4}x` as Size;\n return gap;\n};\n\nexport const getColCount = (gapWidth: number, cardWidth?: number, rootWidth?: number) => {\n if (!cardWidth || !rootWidth) return 0;\n\n // if we have n cards, we have n-1 gaps\n const colCount = Math.floor((rootWidth + gapWidth) / (gapWidth + cardWidth));\n return Math.max(1, colCount);\n};\n","import { useRef, useCallback, useEffect } from 'preact/hooks';\nimport { useReorderableItem } from '../hooks/PRIVATE_useReorderable';\nimport { useUser } from '../hooks/UNSAFE_useUser';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { ReorderableItemProps } from '../UNSAFE_Collection/Reorderable.types';\nimport { multiVariantStyles, styles } from './themes/BaseCardViewStyles.css';\nimport { CARDVIEW_ITEM_SELECTOR, GutterSize } from './BaseCardViewUtils';\nimport { useReorderableContext } from '#hooks/PRIVATE_useReorderable/useReorderableContext';\nimport { isKeyDefined } from '../utils/UNSAFE_keys';\n\ntype BaseItemProps<K> = {\n itemKey: K;\n itemIndex: number;\n isCurrentKey: boolean;\n};\n\nexport type BaseCardViewReorderableItemProps<K> = ReorderableItemProps<K> & {\n gutterSize: GutterSize;\n columns: number;\n};\n\n/**\n * The internal component used to render a reorderable item in CardView.\n */\nexport function BaseCardViewReorderableItem<K extends string | number>({\n children,\n itemKey,\n itemIndex,\n isCurrentKey,\n dragKey,\n setDragKey,\n onReorder,\n rootRef,\n gutterSize,\n columns\n}: BaseCardViewReorderableItemProps<K> & BaseItemProps<K>) {\n const itemRef = useRef<HTMLDivElement | null>(null);\n const isOneColumn = columns === 1;\n const isFirstColumn = itemIndex % columns === 0;\n const isLastColumn = itemIndex % columns === columns - 1;\n const variantClasses = multiVariantStyles({\n itemOverlayFront: gutterSize\n });\n const variantClassesVertical = multiVariantStyles({\n itemOverlayFrontVertical: gutterSize\n });\n const itemStyles = {\n itemOverlayFront: isOneColumn ? variantClassesVertical : variantClasses,\n itemOverlayRear: isOneColumn ? styles.itemOverlayRearVertical : styles.itemOverlayRear,\n itemDragger: styles.itemDragger\n };\n const getItem = useCallback(\n () => itemRef?.current?.closest(CARDVIEW_ITEM_SELECTOR) as HTMLElement,\n []\n );\n const setTransferData = useCallback(\n (event: DragEvent) => {\n event.dataTransfer?.setData('text/cardview-items-key', JSON.stringify(itemKey));\n },\n [itemKey]\n );\n const { rootProps, isDragged, overlayZoneBeforeProps, overlayZoneAfterProps } =\n useReorderableItem({\n isDisabled: onReorder ? false : true,\n dragKey,\n setDragKey,\n onReorder,\n rootRef,\n ref: itemRef,\n getItem,\n setTransferData,\n itemStyles,\n itemSelector: CARDVIEW_ITEM_SELECTOR,\n isVertical: isOneColumn\n });\n\n // TODO: remove this as part of JET-70023\n const { currentItemKey } = useReorderableContext();\n useEffect(() => {\n if (isCurrentKey) {\n currentItemKey.current = itemKey;\n }\n }, [isCurrentKey, itemKey, currentItemKey]);\n\n const { direction } = useUser();\n const isRtl = direction === 'rtl';\n\n const overlayZoneBeforeClass = classNames([\n overlayZoneBeforeProps?.class,\n !isOneColumn && !isRtl && isFirstColumn && styles.itemOverlayFrontEdge,\n !isOneColumn && isRtl && isLastColumn && styles.itemOverlayFrontEdge\n ]);\n\n const overlayZoneAfterClass = classNames([\n overlayZoneAfterProps?.class,\n !isOneColumn && !isRtl && isLastColumn && styles.itemOverlayRearEdge,\n !isOneColumn && isRtl && isFirstColumn && styles.itemOverlayRearEdge\n ]);\n\n return (\n <div {...rootProps}>\n {children}\n {!isDragged && isKeyDefined(dragKey) && (\n <>\n <div {...overlayZoneBeforeProps} class={overlayZoneBeforeClass}></div>\n <div {...overlayZoneAfterProps} class={overlayZoneAfterClass}></div>\n </>\n )}\n </div>\n );\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { ComponentChildren } from 'preact';\nimport { memo } from 'preact/compat';\nimport {\n useRef,\n useCallback,\n useLayoutEffect,\n useMemo,\n useEffect,\n StateUpdater,\n Dispatch,\n MutableRef\n} from 'preact/hooks';\nimport { classNames } from '../utils/UNSAFE_classNames';\nimport { mergeRefs } from '../utils/PRIVATE_refUtils';\nimport { warn } from '../utils/UNSAFE_logger';\nimport { allTabbableElements } from '../utils/PRIVATE_tabbableUtils';\nimport { useId } from '../hooks/UNSAFE_useId';\nimport { useAnimation, UseAnimationConfig } from '../hooks/UNSAFE_useAnimation';\nimport { useResizeObserver } from '../hooks/UNSAFE_useResizeObserver';\nimport { TabbableModeContext } from '../hooks/UNSAFE_useTabbableMode';\nimport { FocusTrap } from '../UNSAFE_FocusTrap';\nimport { SelectionMode, ListItemRendererContext, SelectionDetail } from '../UNSAFE_Collection';\nimport { multiVariantStyles, styles } from './themes/BaseCardViewStyles.css';\nimport {\n BaseCardViewReorderableItem,\n BaseCardViewReorderableItemProps\n} from './BaseCardViewReorderableItem';\nimport { containsKey, isSameKey, Keys } from '../utils/UNSAFE_keys';\nimport { getItemContext } from '../utils/PRIVATE_collectionUtils';\n\n/**\n * Props for the BaseCardViewItem Component\n */\nexport type Props<K, D> = {\n children: (context: ListItemRendererContext<K, D>) => ComponentChildren;\n itemKey: K;\n itemData: D;\n itemIndex: number;\n isTabbable: boolean;\n isCurrentKey: boolean;\n isFocused: boolean;\n isFocusRingVisible: boolean;\n selectedKeys: Keys<K>;\n selectionMode: SelectionMode;\n onSelectionChange?: (detail: SelectionDetail<K>) => void;\n focusBehavior: 'card' | 'content';\n setIsFocusBehaviorValid?: Dispatch<StateUpdater<boolean>>;\n initialAnimation?: 'slideUp' | 'slideDown';\n isGridLayout?: boolean;\n updateCardSize?: (width: number, height: number) => void;\n onAnimationBusyStart?: () => void;\n onAnimationBusyEnd?: () => void;\n} & {\n reorderItemProps?: Omit<BaseCardViewReorderableItemProps<K>, 'children'>;\n};\n\n/**\n * The internal component used to render a single item in CardView.\n */\nfunction BaseCardViewItem<K extends string | number, D>({\n children,\n itemKey,\n itemData,\n itemIndex,\n isTabbable,\n isCurrentKey,\n isFocused,\n isFocusRingVisible,\n selectedKeys,\n selectionMode,\n onSelectionChange,\n focusBehavior,\n setIsFocusBehaviorValid,\n initialAnimation,\n isGridLayout,\n updateCardSize,\n reorderItemProps,\n onAnimationBusyStart,\n onAnimationBusyEnd\n}: Props<K, D>) {\n const rootRef = useRef<HTMLDivElement>(null);\n const timeoutRef = useRef<ReturnType<typeof setTimeout>>();\n\n const isItemFocused = isFocused && isFocusRingVisible;\n const variantClasses = multiVariantStyles({\n itemFocused: focusBehavior === 'card' && isItemFocused ? 'isItemFocused' : 'isNotItemFocused',\n itemInitialOpacity: initialAnimation ? 'isTransparent' : 'isNotTransparent',\n itemInGridLayout: isGridLayout ? 'isInGridLayout' : 'isNotInGridLayout'\n });\n const classes = classNames([styles.itemStyle, variantClasses]);\n\n /*********************************** Tabbable Mode ***********************************/\n\n // don't bubble Arrow Up/Down/Left/Right events to parent when in isTabbable mode\n // this bubbling causes the outer CollectionFocus ring to change index while in the isTabbable mode.\n const handleKeyDown = (event: KeyboardEvent) => {\n if (\n focusBehavior === 'card' &&\n isTabbable &&\n (event.key === 'ArrowDown' ||\n event.key === 'ArrowUp' ||\n event.key === 'ArrowLeft' ||\n event.key === 'ArrowRight')\n ) {\n event.stopPropagation();\n }\n };\n\n /************************************ Card Size ************************************/\n\n const handleResize = useCallback(\n (entry: ResizeObserverEntry) => {\n updateCardSize?.(entry.contentRect.width, entry.contentRect.height);\n },\n [updateCardSize]\n );\n\n const nullRef = useRef<HTMLDivElement>(null);\n useResizeObserver(updateCardSize ? rootRef : nullRef, handleResize);\n\n /********************************* Focus Behavior *********************************/\n\n useLayoutEffect(() => {\n if (focusBehavior === 'content' && isItemFocused) {\n // rootRef is cardview item, its first child is the focus trap div, so its first grand child\n // is the actual content\n const content = rootRef.current?.firstElementChild?.firstElementChild as HTMLElement;\n const focusable = allTabbableElements(content, true, true);\n if (focusable.length === 0 || focusable.length > 1) {\n warn(\n `${focusable.length} focusable elements are detected in the card. 'content' focusBehavior is intended only for use when the card has single focusable element. Please specify one focusable element in the card or switch the focusBehavior to 'card'.`\n );\n setIsFocusBehaviorValid?.(false);\n } else {\n focusable[0].focus();\n }\n }\n }, [focusBehavior, isItemFocused, setIsFocusBehaviorValid]);\n\n /******************************** Initial Animation ********************************/\n\n // animation for slide up/down\n const { nodeRef: nodeRefSlide, controller: controllerSlide } = useAnimation<\n 'slideUp' | 'slideDown' | 'none',\n HTMLDivElement\n >(initialAnimation || 'none', animationConfigSlide(itemIndex));\n\n // animation for opacity change\n const { nodeRef: nodeRefOpacity, controller: controllerOpacity } = useAnimation<\n 'opacity' | 'none',\n HTMLDivElement\n >(\n (initialAnimation && 'opacity') || 'none',\n animationConfigOpacity(itemIndex, timeoutRef, onAnimationBusyEnd)\n );\n\n if (initialAnimation) {\n onAnimationBusyStart?.();\n }\n\n // max cap for animation is 1s\n useEffect(() => {\n if (initialAnimation !== undefined) {\n timeoutRef.current = setTimeout(() => {\n controllerSlide.cancel();\n controllerOpacity.cancel();\n if (rootRef.current) {\n rootRef.current.style.opacity = '1';\n }\n onAnimationBusyEnd?.();\n }, 1000);\n }\n }, [controllerOpacity, controllerSlide, initialAnimation, onAnimationBusyEnd]);\n\n // TODO: issue track in JET-57681, we currently have two useAnimation() because the opacity and\n // slide up/down have different durations, and the current API couldn't handle this case, we will\n // update this once the API is updated\n\n /********************************** Child Component **********************************/\n const itemRefs = useMemo(() => {\n // NOTE: spot an issue when we click the cards during animation is processing, the cards would not finish\n // the current animations and stay as what it is, e.g. leave itself as half transparent.\n // need to remove nodeRefSlide and nodeRefOpacity to avoid this issue.\n if (initialAnimation === undefined) {\n return mergeRefs(rootRef);\n }\n return mergeRefs(rootRef, nodeRefSlide, nodeRefOpacity);\n }, [rootRef, nodeRefSlide, nodeRefOpacity, initialAnimation]);\n\n const rendererContext = getItemContext<K, D>(\n { data: { data: itemData, metadata: { key: itemKey } }, index: itemIndex },\n selectedKeys,\n selectionMode === 'multiple',\n onSelectionChange\n );\n\n const childrenComponent = reorderItemProps ? (\n <BaseCardViewReorderableItem\n {...reorderItemProps}\n itemKey={itemKey}\n itemIndex={itemIndex}\n isCurrentKey={isCurrentKey}>\n {children(rendererContext)}\n </BaseCardViewReorderableItem>\n ) : (\n children(rendererContext)\n );\n\n return (\n <div\n id={useId()}\n ref={itemRefs}\n class={classes}\n role=\"gridcell\"\n data-oj-card-item=\"\"\n data-oj-key={itemKey}\n onKeyDown={handleKeyDown}\n aria-selected={selectionMode === 'none' ? undefined : containsKey(selectedKeys, itemKey)}\n {...(typeof itemKey === 'number' && { 'data-oj-key-type': 'number' })}>\n <TabbableModeContext.Provider value={{ isTabbable }}>\n <FocusTrap isDisabled={!isTabbable} restoreFocusRef={false}>\n {childrenComponent}\n </FocusTrap>\n </TabbableModeContext.Provider>\n </div>\n );\n}\n\nconst animationConfigSlide = (\n index: number\n): UseAnimationConfig<'slideUp' | 'slideDown' | 'none', HTMLDivElement> => {\n return {\n animationStates: {\n slideUp: {\n from: {\n translateY: '50px'\n },\n to: {\n translateY: '0px'\n },\n options: {\n duration: 300,\n delay: index * 50,\n easing: [0, 0, 0.2, 1]\n }\n },\n slideDown: {\n from: {\n translateY: '-50px'\n },\n to: {\n translateY: '0'\n },\n options: {\n duration: 300,\n delay: index * 50,\n easing: [0, 0, 0.2, 1]\n }\n }\n },\n isAnimatedOnMount: true\n };\n};\n\nconst animationConfigOpacity = (\n index: number,\n timeoutRef: MutableRef<ReturnType<typeof setTimeout> | undefined>,\n onAnimationBusyEnd?: () => void\n): UseAnimationConfig<'opacity' | 'none', HTMLDivElement> => {\n return {\n animationStates: {\n opacity: {\n from: {\n opacity: 0\n },\n to: {\n opacity: 1\n },\n options: {\n duration: 150,\n delay: index * 50,\n easing: 'linear'\n }\n }\n },\n isAnimatedOnMount: true,\n onAnimationEnd: () => {\n onAnimationBusyEnd?.();\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current);\n }\n }\n };\n};\n\n/**\n * Compare the equality between two reorderItemProps, especially useful for memoized items\n */\nconst _compareReorderItemProps = (\n props1: Props<string | number, unknown>['reorderItemProps'],\n props2: Props<string | number, unknown>['reorderItemProps']\n) => {\n return (\n props1?.['dragKey'] === props2?.['dragKey'] &&\n props1?.['setDragKey'] === props2?.['setDragKey'] &&\n props1?.['columns'] === props2?.['columns'] &&\n props1?.['gutterSize'] === props2?.['gutterSize'] &&\n props1?.['rootRef'] === props2?.['rootRef']\n );\n};\n\nexport const MemoizeBaseCardViewItem = memo(\n BaseCardViewItem,\n (prev: Props<string | number, unknown>, next: Props<string | number, unknown>) => {\n if (prev && next) {\n return (\n prev.children === next.children &&\n prev.itemKey === next.itemKey &&\n prev.itemData === next.itemData &&\n prev.itemIndex === next.itemIndex &&\n prev.isTabbable === next.isTabbable &&\n prev.isCurrentKey === next.isCurrentKey &&\n prev.isFocused === next.isFocused &&\n prev.isFocusRingVisible === next.isFocusRingVisible &&\n prev.initialAnimation === next.initialAnimation &&\n prev.focusBehavior === next.focusBehavior &&\n isSameKey(prev.selectedKeys, next.selectedKeys) &&\n prev.selectionMode === next.selectionMode &&\n prev.onSelectionChange === next.onSelectionChange &&\n prev.setIsFocusBehaviorValid === next.setIsFocusBehaviorValid &&\n prev.isGridLayout === next.isGridLayout &&\n prev.updateCardSize === next.updateCardSize &&\n prev.onAnimationBusyStart === next.onAnimationBusyStart &&\n prev.onAnimationBusyEnd === next.onAnimationBusyEnd &&\n _compareReorderItemProps(prev.reorderItemProps, next.reorderItemProps)\n );\n }\n return false;\n }\n);\n","import { ComponentChildren } from 'preact';\nimport { Grid } from '../UNSAFE_Grid';\nimport { Flex } from '../UNSAFE_Flex';\nimport { GutterSize } from './BaseCardViewUtils';\nimport { cardViewVars } from './themes/BaseCardViewContract.css';\n\ntype Props = {\n children: ComponentChildren;\n layout: 'grid' | 'flex';\n gutterSize: GutterSize;\n columns: number;\n};\n\nexport function BaseCardViewLayout({ children, layout, gutterSize, columns }: Props) {\n const gap = cardViewVars.gutterSize[gutterSize];\n if (layout === 'grid') {\n return columns < 1 ? null : (\n <Grid gridTemplateColumns={`repeat(${columns}, 1fr)`} gap={gap}>\n {children}\n </Grid>\n );\n } else {\n return (\n <Flex wrap=\"wrap\" gap={gap}>\n {children}\n </Flex>\n );\n }\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { ComponentChildren, Fragment } from 'preact';\nimport { useState, useEffect } from 'preact/hooks';\nimport { LOADMORE_STYLE_CLASS } from '../PRIVATE_LoadMoreCollection';\n\ntype Props = {\n /**\n * Allows to pass skeletons\n **/\n children: ComponentChildren;\n};\n\n/**\n * Allows to specify the time delay for rendering the component\n **/\nconst timerValue = 50;\n\n/**\n * BaseCardViewSkeletonContainer renders skeletons after 50ms threshold defined in the Redwood spec\n **/\nexport function BaseCardViewSkeletonContainer({ children }: Props) {\n const [isVisible, setIsVisible] = useState(false);\n\n useEffect(() => {\n setTimeout(() => {\n setIsVisible(true);\n }, timerValue);\n }, []);\n\n return isVisible ? <Fragment>{children}</Fragment> : <div class={LOADMORE_STYLE_CLASS}></div>;\n}\n","import { Size } from '../utils/UNSAFE_size';\nimport { Skeleton } from '../UNSAFE_Skeleton';\nimport { LOADMORE_STYLE_CLASS } from '../PRIVATE_LoadMoreCollection';\nimport { BaseCardViewSkeletonContainer } from './BaseCardViewSkeletonContainer';\nimport { SkeletonRendererContext } from '../UNSAFE_CardFlexView';\nimport { ComponentChildren } from 'preact';\n\nconst DEFAULT_SKELETON_NUMBER = 25;\nconst DEFAULT_SKELETON_WIDTH = '80x';\nconst DEFAULT_SKELETON_HEIGHT = '85x';\n\ntype SkeletonProps = {\n layout: 'flex' | 'grid';\n colCount: number;\n totalCount: number;\n cardWidth?: number;\n cardHeight?: number;\n};\n\n/**\n * A function that returns an array of skeletons based on count\n * @param count the number of skeletons\n */\nconst getSkeletonsByCount = (\n layout: 'flex' | 'grid',\n count = DEFAULT_SKELETON_NUMBER,\n width?: Size,\n height?: Size,\n isUnique = true\n) => {\n const sw = width || (layout === 'flex' ? DEFAULT_SKELETON_WIDTH : '100%');\n const sh = height || DEFAULT_SKELETON_HEIGHT;\n\n return [...Array(count)].map((_v, i) => (\n // create unique keys if needed, otherwise the animations won't start at the same time, because the old copy of skeletons\n // could be reused, even the key is specified by useId(), combine count with time to make the key unique.\n <Skeleton\n key={isUnique && `${i}${new Date().getTime()}`}\n width={sw}\n height={sh}\n borderRadius=\"6px\"\n />\n ));\n};\n\n/**\n * When there is no data (i.e. data is an empty array or null, and hasMore is false), we will show 25 card skeletons with default size\n */\nexport const InitialLoadSkeletons = (props: { layout: SkeletonProps['layout'] }) => (\n <BaseCardViewSkeletonContainer>{getSkeletonsByCount(props.layout)}</BaseCardViewSkeletonContainer>\n);\n\n/**\n * When we are fetching the initial data (i.e. data is an empty array, and hasMore is true), we will show 25 card skeletons with default size,\n * because we don't know the card dimension at this time. Since there is more data to load, we will specify LOADMORE_STYLE_CLASS on skeletons\n */\nexport const DefaultLoadMoreSkeletons = (props: { layout: SkeletonProps['layout'] }) => {\n const firstSkeleton = (\n <div class={LOADMORE_STYLE_CLASS}>{getSkeletonsByCount(props.layout, 1)}</div>\n );\n const otherSkeletons = getSkeletonsByCount(props.layout, DEFAULT_SKELETON_NUMBER - 1);\n const skeletons = [firstSkeleton, ...otherSkeletons];\n return <BaseCardViewSkeletonContainer>{skeletons}</BaseCardViewSkeletonContainer>;\n};\n\n/**\n * During the render that we measure and update card dimension, we will hide skeletons temporarily\n * to avoid showing incorrect skeletons\n */\nconst InvisibleSkeletons = () => {\n return <div class={LOADMORE_STYLE_CLASS}></div>;\n};\n\nexport const LoadMoreSkeletons = (props: SkeletonProps) => {\n if (props.colCount < 1 || props.cardWidth == null || props.cardHeight == null) {\n // if column count / card width / card height are invalid, we will show the invisible skeletons\n return <InvisibleSkeletons />;\n } else {\n // after initial renders, show skeletons with correct dimension and count\n const skeletons = [];\n\n const firstRowColCount = props.colCount - (props.totalCount % props.colCount);\n const isOnlyOneRow = firstRowColCount === props.colCount;\n\n const cardWidth = `calc(${props.cardWidth}px)` as Size;\n const cardHeight = props.cardHeight\n ? (`calc(${props.cardHeight}px)` as Size)\n : DEFAULT_SKELETON_HEIGHT;\n\n const width: Size = props.layout === 'flex' ? cardWidth : '100%';\n const height: Size = props.layout === 'flex' || isOnlyOneRow ? cardHeight : '100%';\n\n // first row\n const firstSkeleton = (\n <div class={LOADMORE_STYLE_CLASS}>{getSkeletonsByCount(props.layout, 1, width, height)}</div>\n );\n skeletons.push(firstSkeleton);\n skeletons.push(getSkeletonsByCount(props.layout, firstRowColCount - 1, width, height));\n\n // second row\n if (!isOnlyOneRow) {\n skeletons.push(getSkeletonsByCount(props.layout, props.colCount, width, cardHeight));\n }\n\n return <BaseCardViewSkeletonContainer>{skeletons}</BaseCardViewSkeletonContainer>;\n }\n};\n\nexport const CustomInitialSkeletions = (props: {\n skeletonRenderer: (context: SkeletonRendererContext) => ComponentChildren;\n}) => {\n const context: SkeletonRendererContext = { loadingStatus: 'initial' };\n return (\n <BaseCardViewSkeletonContainer>\n {renderMultipleSkeletons(context, 25, props.skeletonRenderer)}\n </BaseCardViewSkeletonContainer>\n );\n};\n\nexport const CustomLoadMoreSkeletons = (\n props: {\n isRenderAsInitial: boolean;\n skeletonRenderer: (context: SkeletonRendererContext) => ComponentChildren;\n } & SkeletonProps\n) => {\n const skeletons = [];\n if (props.isRenderAsInitial) {\n const context: SkeletonRendererContext = { loadingStatus: 'initial' };\n skeletons.push(<div class={LOADMORE_STYLE_CLASS}>{props.skeletonRenderer(context)}</div>);\n skeletons.push(renderMultipleSkeletons(context, 24, props.skeletonRenderer));\n } else {\n if (props.colCount === 0) {\n return null;\n }\n const cardWidth = `calc(${props.cardWidth}px)` as Size;\n const cardHeight = `calc(${props.cardHeight}px)` as Size;\n const firstRowColCount = props.colCount - (props.totalCount % props.colCount);\n const isOnlyOneRow = firstRowColCount === props.colCount;\n const context: SkeletonRendererContext = {\n loadingStatus: 'loadMore',\n height: props.layout === 'flex' || isOnlyOneRow ? cardHeight : '100%',\n width: props.layout === 'flex' ? cardWidth : '100%'\n };\n skeletons.push(<div class={LOADMORE_STYLE_CLASS}>{props.skeletonRenderer(context)}</div>);\n skeletons.push(\n Array(renderMultipleSkeletons(context, firstRowColCount - 1, props.skeletonRenderer))\n );\n if (!isOnlyOneRow) {\n skeletons.push(renderMultipleSkeletons(context, props.colCount, props.skeletonRenderer));\n }\n }\n return <BaseCardViewSkeletonContainer>{skeletons}</BaseCardViewSkeletonContainer>;\n};\n\nconst renderMultipleSkeletons = (\n context: SkeletonRendererContext,\n count: number,\n skeletonRenderer: (context: SkeletonRendererContext) => ComponentChildren\n) => {\n return Array(count).fill(skeletonRenderer(context));\n};\n","import type { RefObject } from 'preact';\nimport { useState } from 'preact/hooks';\nimport { dragToScroll } from '../utils/PRIVATE_collectionUtils';\nimport { useReorderable } from '../hooks/PRIVATE_useReorderable';\nimport { Props } from '../UNSAFE_CardFlexView';\nimport { CARDVIEW_ITEM_SELECTOR, GutterSize } from './BaseCardViewUtils';\n\ntype useCardViewReorderProps<K, D> = Pick<Props<K, D>, 'onReorder'> & {\n gutterSize: GutterSize;\n columns: number;\n rootRef: RefObject<HTMLDivElement>;\n scrollCurrItemIntoView: RefObject<boolean>;\n};\n\nexport const useCardViewReorder = <K extends string | number, D>({\n onReorder,\n gutterSize,\n columns,\n rootRef,\n scrollCurrItemIntoView\n}: useCardViewReorderProps<K, D>) => {\n const isReorderEnabled = onReorder != undefined;\n\n const [dragKey, setDragKey] = useState<K | undefined>(undefined);\n const { reorderProps, reorderContext, reorderInstructionsId, reorderInstructions } =\n useReorderable({\n onReorder,\n rootRef,\n itemSelector: CARDVIEW_ITEM_SELECTOR,\n isDisabled: !isReorderEnabled,\n columns\n });\n\n if (!isReorderEnabled) {\n return {\n reorderProps,\n reorderContext,\n reorderInstructionsId,\n reorderInstructions\n } as const;\n }\n\n const handleDragOver = (event: DragEvent) => {\n dragToScroll(event, dragKey !== undefined, rootRef.current);\n // during mouse reordering, the drag item might not be the same as current item,\n // so we should disallow current item scroll into view\n scrollCurrItemIntoView.current = false;\n };\n\n const reorderEventProps = { ...reorderProps, onDragOver: handleDragOver };\n\n const reorderItemProps = {\n dragKey,\n setDragKey,\n onReorder,\n rootRef,\n gutterSize,\n columns\n };\n\n return {\n reorderProps: reorderEventProps,\n reorderItemProps,\n reorderContext,\n reorderInstructionsId,\n reorderInstructions\n } as const;\n};\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { Fragment } from 'preact';\nimport { forwardRef, ForwardedRef } from 'preact/compat';\nimport { useRef, useCallback, useEffect, useState, useImperativeHandle } from 'preact/hooks';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { Keys } from '../utils/UNSAFE_keys';\nimport {\n getPrevNextKeyByCount,\n getViewportConfig,\n findElementByKey,\n keyExtractor,\n handleSelectionRange\n} from '../utils/PRIVATE_collectionUtils';\n\nimport { useNavigation } from '../hooks/PRIVATE_useListCommon';\nimport { useSelection, SelectionRangeDetail } from '../hooks/PRIVATE_useSelection';\nimport { ReorderableContext } from '../hooks/PRIVATE_useReorderable';\nimport { ItemContext, SelectionDetail } from '../UNSAFE_Collection';\nimport { HiddenAccessible } from '../UNSAFE_HiddenAccessible';\nimport { LoadMoreCollection } from '../PRIVATE_LoadMoreCollection';\nimport { styles } from './themes/BaseCardViewStyles.css';\nimport { Props } from '../UNSAFE_CardFlexView';\nimport { MemoizeBaseCardViewItem } from './BaseCardViewItem';\nimport { BaseCardViewLayout } from './BaseCardViewLayout';\nimport {\n DefaultLoadMoreSkeletons,\n LoadMoreSkeletons,\n InitialLoadSkeletons,\n CustomInitialSkeletions,\n CustomLoadMoreSkeletons\n} from './BaseCardViewSkeleton';\nimport { gutterSizeToPX, emptyKeys, CARDVIEW_ITEM_SELECTOR } from './BaseCardViewUtils';\nimport { useCardViewReorder } from './useCardViewReorder';\n// TODO: add this import due to issue JET-67485, need to update once Stable is introduced\nimport './themes/redwood/BaseCardViewBaseTheme.css';\nimport { useAddBusyState } from '#hooks/PRIVATE_useAddBusyState';\nimport { getClientHints } from '#utils/PRIVATE_clientHints';\nimport { classNames } from '#utils/UNSAFE_classNames';\n\n/**\n * Props specific for the GradGridBaseImpl Component\n */\ntype BaseCardViewImplProps<K, D> = Props<K, D> & {\n /**\n * Provide the number of columns to render;\n */\n columns: number;\n /**\n * The layout of the BaseCardView. When we use CardGridView as parent, we will use grid layout;\n * when we use CardFlexView as parent, we will use flex layout.\n */\n layout: 'grid' | 'flex';\n /**\n * Card dimension, including width and height\n */\n cardSize: { width?: number; height?: number };\n /**\n * A callback function to update card dimension, including width and height\n */\n updateCardSize: (width: number, height: number) => void;\n};\n\nconst BaseCardViewImpl = forwardRef(\n <K extends string | number, D>(\n {\n children,\n data,\n onLoadMore = () => {},\n hasMore = false,\n getRowKey,\n currentItemOverride,\n onPersistCurrentItem,\n selectionMode = 'none',\n selectedKeys = emptyKeys as Keys<K>,\n onSelectionChange,\n onReorder,\n viewportConfig,\n focusBehavior = 'card',\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n 'aria-describedby': ariaDescribedBy,\n initialAnimation = 'slideUp',\n gutterSize = 'sm',\n columns,\n layout,\n cardSize,\n updateCardSize,\n skeletonRenderer\n }: BaseCardViewImplProps<K, D>,\n ref?: ForwardedRef<HTMLDivElement>\n ) => {\n const rootRef = useRef<HTMLDivElement>(null);\n useImperativeHandle(ref!, () => rootRef.current!, [rootRef]);\n\n // tracking the anchor key which is used for shift+click selection\n const anchorKey = useRef<K | undefined>();\n\n const gutterSizePX = gutterSizeToPX[gutterSize];\n const layoutProps = { layout, columns, gutterSize };\n\n //setup busy start and busy end callbacks for the initial animation\n const { onBusyStart: onAnimationBusyStart, onBusyEnd: onAnimationBusyEnd } = useAddBusyState(\n 'handling initial animation'\n );\n const isInitialAnimation = useRef(true);\n useEffect(() => {\n if (cardSize.height != undefined && cardSize.width != undefined) {\n isInitialAnimation.current = false;\n }\n }, [cardSize]);\n\n const ariaMultiSelectable = selectionMode === 'none' ? undefined : selectionMode === 'multiple';\n const ariaRowcount = 1;\n const ariaColcount = data ? data.length : -1;\n\n const [isFocusBehaviorValid, setIsFocusBehaviorValid] = useState(true);\n const validFocusBehavior = isFocusBehaviorValid ? focusBehavior : 'card';\n\n // ensure current item is scrolled into view when current item is updated\n // during reordering, enable that during keyboard reordering, disable that during mouse reordering\n const scrollCurrItemIntoView = useRef(false);\n const isReorderEnabled = onReorder != undefined;\n\n const isFetching = useRef(false);\n\n /*****************************************************************************************/\n /*********************** Current Key, Focus Ring and Tabbable Mode ***********************/\n /*****************************************************************************************/\n\n const arrowKeyAndHandlers = {\n ArrowUp: (key?: K) => getPrevNextKeyByCount(data, getRowKey, key, -columns),\n ArrowDown: (key?: K) => getPrevNextKeyByCount(data, getRowKey, key, columns),\n ArrowLeft: (key?: K) => getPrevNextKeyByCount(data, getRowKey, key, -1),\n ArrowRight: (key?: K) => getPrevNextKeyByCount(data, getRowKey, key, 1)\n };\n\n const {\n navigationProps,\n currentKey,\n isCurrentItemOverridden,\n showFocusRing,\n isCurrentTabbableKey\n } = useNavigation(\n data,\n rootRef,\n idExtractor,\n CARDVIEW_ITEM_SELECTOR,\n arrowKeyAndHandlers,\n currentItemOverride,\n onPersistCurrentItem,\n viewportConfig,\n undefined,\n selectionMode !== 'multiple',\n validFocusBehavior === 'card',\n validFocusBehavior === 'card',\n false\n );\n\n /*****************************************************************************************/\n /*************************************** Selection ***************************************/\n /*****************************************************************************************/\n\n const handleSelectionChange = useCallback(\n (detail: SelectionDetail<K>) => {\n if (onSelectionChange) {\n if (detail.value.all === false && detail.value.keys.size > 0) {\n // during regular selection, the last key selected by a user gesture is the anchor key\n anchorKey.current = Array.from(detail.value.keys.values()).pop();\n }\n onSelectionChange(detail);\n }\n },\n [anchorKey, onSelectionChange]\n );\n\n const handleSelectionRangeChange = useCallback(\n (detail: SelectionRangeDetail<K>) => {\n if (data && onSelectionChange) {\n const value = handleSelectionRange(detail, data, getRowKey);\n // for non-virtualized CardView, value should always be an array\n if (Array.isArray(value)) {\n if (detail.eventType === 'shiftSpace') {\n // during range selection by shift+space, the first key selected by a user gesture is the anchor key\n anchorKey.current = detail.value.start;\n } else {\n // during range selection by shift+click/arrow keys, the last key selected by a user gesture is the anchor key\n anchorKey.current = detail.value.end;\n }\n onSelectionChange({ value: { all: false, keys: new Set(value) }, target: null });\n }\n }\n },\n [data, onSelectionChange, getRowKey]\n );\n\n const { selectionProps } = useSelection(\n (element: HTMLElement) => {\n if (element === rootRef.current) {\n return currentKey === undefined ? null : currentKey;\n }\n return keyExtractor(element, CARDVIEW_ITEM_SELECTOR) as K;\n },\n selectedKeys,\n selectionMode,\n false,\n 'toggle',\n handleSelectionChange,\n anchorKey.current,\n currentKey,\n (currentKey: K | undefined, isPrev: boolean) =>\n getPrevNextKeyByCount(data, getRowKey, currentKey, isPrev ? -columns : columns),\n (currentKey: K | undefined, isPrev: boolean) =>\n getPrevNextKeyByCount(data, getRowKey, currentKey, isPrev ? -1 : 1),\n (key: K) => {\n if (rootRef.current) {\n const elem = findElementByKey(rootRef.current, key, CARDVIEW_ITEM_SELECTOR);\n if (elem) {\n elem.scrollIntoView({ block: 'nearest' });\n }\n }\n },\n handleSelectionRangeChange\n );\n\n /*****************************************************************************************/\n /**************************************** Reorder ****************************************/\n /*****************************************************************************************/\n\n const {\n reorderProps,\n reorderItemProps,\n reorderContext,\n reorderInstructionsId,\n reorderInstructions\n } = useCardViewReorder({\n onReorder,\n gutterSize,\n columns,\n rootRef,\n scrollCurrItemIntoView\n });\n\n const reorderAcc = isReorderEnabled && (\n <>\n <span id={reorderInstructionsId}>\n <HiddenAccessible>{reorderInstructions}</HiddenAccessible>\n </span>\n </>\n );\n\n const handleKeyDown = (event: KeyboardEvent) => {\n // for content focusBehavior, when users tab out, we need to focus back to card grid, to ensure\n // the tabbing order works properly, otherwise the focus might get stuck at the current item\n if (validFocusBehavior === 'content' && event.key === 'Tab') {\n rootRef.current?.focus({ preventScroll: true });\n }\n // during keyboard reordering, the current item should be scrolled into view\n const keyHandlers = ['ArrowLeft', 'ArrowRight', 'ArrowUp', 'ArrowDown'];\n if (\n isReorderEnabled &&\n (event.metaKey || event.ctrlKey) &&\n event.shiftKey &&\n keyHandlers.includes(event.key)\n ) {\n scrollCurrItemIntoView.current = true;\n }\n };\n\n useEffect(() => {\n if (isReorderEnabled && currentKey != null && rootRef.current) {\n const elem = findElementByKey(rootRef.current, currentKey, CARDVIEW_ITEM_SELECTOR);\n // make sure current item is visible during reordering\n // scroll the current item into view only when the current item is updated internally\n if (elem && scrollCurrItemIntoView.current && !isCurrentItemOverridden) {\n elem.scrollIntoView({ block: 'nearest' });\n scrollCurrItemIntoView.current = false;\n }\n }\n // since the currentKey will not change during keyboard reordering,\n // listen to data to ensure cardview scroll into view\n }, [currentKey, data, isReorderEnabled, isCurrentItemOverridden]);\n\n /*****************************************************************************************/\n /************************************* Load More *****************************************/\n /*****************************************************************************************/\n\n const handleLoadMore = useCallback(() => {\n // check isFetching to avoid multiple load more at the same time (details in JET-61117)\n if (!isFetching.current) {\n isFetching.current = true;\n onLoadMore();\n }\n }, [isFetching, onLoadMore]);\n\n useEffect(() => {\n isFetching.current = false;\n // listen to data and hasMore because when one of them gets updated, the fetching is done\n }, [data, hasMore]);\n\n /*****************************************************************************************/\n /************************************ Child Component ************************************/\n /*****************************************************************************************/\n\n const childrenComponent = (context: ItemContext<D>) => {\n const itemKey = getRowKey(context.data);\n const isTabbable = isCurrentTabbableKey(itemKey);\n const isFocused = currentKey === itemKey && !isTabbable;\n const isFocusRingVisible = isFocused && showFocusRing;\n const isLastCard = data ? context.index === data.length - 1 : false;\n return (\n <MemoizeBaseCardViewItem<K, D>\n key={itemKey}\n itemKey={itemKey}\n isCurrentKey={currentKey === itemKey}\n itemData={context.data}\n itemIndex={context.index}\n isTabbable={isTabbable}\n isFocused={isFocused}\n isFocusRingVisible={isFocusRingVisible}\n isGridLayout={layout === 'grid'}\n selectedKeys={selectedKeys}\n selectionMode={selectionMode}\n onSelectionChange={onSelectionChange}\n focusBehavior={validFocusBehavior}\n {...(context.index === 0 && isInitialAnimation.current && { onAnimationBusyStart })}\n {...(isLastCard && isInitialAnimation.current && { onAnimationBusyEnd })}\n {...(focusBehavior === 'content' && { setIsFocusBehaviorValid })}\n {...(isInitialAnimation.current && { initialAnimation })}\n {...(context.index === 0 && !cardSize.width && { updateCardSize })}\n {...(isReorderEnabled && { reorderItemProps })}>\n {children}\n </MemoizeBaseCardViewItem>\n );\n };\n\n // todo: issue track in JET-57952, need a way to show the skeletons in keyboard navigation\n const skeletons = data ? (\n !data.length && hasMore ? (\n skeletonRenderer ? (\n <CustomLoadMoreSkeletons\n layout={layout}\n colCount={columns}\n totalCount={data.length}\n cardWidth={cardSize.width}\n cardHeight={cardSize.height}\n isRenderAsInitial={true}\n skeletonRenderer={skeletonRenderer}\n />\n ) : (\n <DefaultLoadMoreSkeletons layout={layout} />\n )\n ) : skeletonRenderer ? (\n <CustomLoadMoreSkeletons\n layout={layout}\n colCount={columns}\n totalCount={data.length}\n cardWidth={cardSize.width}\n cardHeight={cardSize.height}\n isRenderAsInitial={false}\n skeletonRenderer={skeletonRenderer}\n />\n ) : (\n <LoadMoreSkeletons\n layout={layout}\n colCount={columns}\n totalCount={data.length}\n cardWidth={cardSize.width}\n cardHeight={cardSize.height}\n />\n )\n ) : null;\n\n viewportConfig = getViewportConfig(rootRef, viewportConfig);\n const collectionComponent = (\n <div role=\"row\">\n <BaseCardViewLayout {...layoutProps}>\n <LoadMoreCollection\n data={data}\n hasMore={hasMore}\n onLoadMore={handleLoadMore}\n loadMoreIndicator={skeletons}\n loadMoreThreshold={gutterSizePX + 4} // gap size + padding\n viewportConfig={viewportConfig}>\n {childrenComponent}\n </LoadMoreCollection>\n </BaseCardViewLayout>\n </div>\n );\n\n const initialLoadSkeletons = (\n <BaseCardViewLayout {...layoutProps}>\n {skeletonRenderer ? (\n <CustomInitialSkeletions skeletonRenderer={skeletonRenderer} />\n ) : (\n <InitialLoadSkeletons layout={layout} />\n )}\n </BaseCardViewLayout>\n );\n const allowBrowserContextMenu = !(\n getClientHints().platform === 'ios' || getClientHints().platform === 'android'\n );\n\n const classArray = [styles.baseStyle];\n if (!allowBrowserContextMenu) {\n classArray.push(styles.userSelect);\n }\n const classes = classNames(classArray);\n\n return (\n <div\n {...mergeProps(navigationProps, selectionProps, reorderProps, {\n onKeyDown: handleKeyDown\n })}\n ref={rootRef}\n role=\"grid\"\n class={classes}\n tabIndex={0}\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledBy}\n aria-describedby={\n isReorderEnabled ? reorderInstructionsId + ' ' + ariaDescribedBy : ariaDescribedBy\n }\n aria-multiselectable={ariaMultiSelectable}\n aria-rowcount={ariaRowcount}\n aria-colcount={ariaColcount}>\n <ReorderableContext.Provider value={reorderContext}>\n {!data ? (\n initialLoadSkeletons\n ) : data.length || hasMore ? (\n collectionComponent\n ) : (\n <Fragment />\n )}\n </ReorderableContext.Provider>\n {reorderAcc}\n </div>\n );\n }\n);\n\nconst idExtractor = (elem: Element) => elem.id;\n\n/**\n * Props specific for the BaseCardView\n */\ntype BaseCardViewProps<K, D> = BaseCardViewImplProps<K, D> & {\n ref?: ForwardedRef<HTMLDivElement>;\n};\n\n/**\n * Cast BaseCardViewImpl to generic type, because BaseCardViewImpl would infer the generic type to specific type,\n * i.e infer <K extends string | number, D> to <string | number, unknown>, which will cause type issues in the parent component\n */\nexport const BaseCardView = BaseCardViewImpl as <K extends string | number, D>(\n props: BaseCardViewProps<K, D>\n) => JSX.Element;\n"],"names":["useRef","multiVariantStyles","styles","useCallback","useReorderableItem","useReorderableContext","useEffect","useUser","classNames","_jsxs","isKeyDefined","_Fragment","_jsx","useResizeObserver","useLayoutEffect","allTabbableElements","warn","useAnimation","useMemo","mergeRefs","getItemContext","useId","containsKey","TabbableModeContext","FocusTrap","memo","isSameKey","cardViewVars","Grid","Flex","useState","Fragment","LOADMORE_STYLE_CLASS","Skeleton","useReorderable","dragToScroll","forwardRef","useImperativeHandle","useAddBusyState","getPrevNextKeyByCount","useNavigation","handleSelectionRange","useSelection","keyExtractor","findElementByKey","HiddenAccessible","getViewportConfig","LoadMoreCollection","getClientHints","mergeProps","ReorderableContext"],"mappings":"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"}
@@ -3,7 +3,7 @@
3
3
 
4
4
  Object.defineProperty(exports, '__esModule', { value: true });
5
5
 
6
- var BaseCardView = require('./BaseCardView-c0909427.js');
6
+ var BaseCardView = require('./BaseCardView-ba63723a.js');
7
7
  require('preact/jsx-runtime');
8
8
  require('preact');
9
9
  require('preact/compat');
@@ -43,6 +43,8 @@ var useInteractionStyle = require('./useInteractionStyle-c203a8a0.js');
43
43
  var Selector = require('./Selector-6550b8e0.js');
44
44
  var PRIVATE_TableCommon_themes_Common_css = require('./PRIVATE_TableCommon/themes/Common.css.js');
45
45
  var PRIVATE_TableList_themes_ListCellStyles_css = require('./PRIVATE_TableList/themes/ListCellStyles.css.js');
46
+ require('./StyledCheckbox-9047ed7d.js');
47
+
46
48
  var PRIVATE_TableList_themes_ListSkeletonStyles_css = require('./PRIVATE_TableList/themes/ListSkeletonStyles.css.js');
47
49
  var dimensions$1 = require('./dimensions-6101ca1f.js');
48
50
  var mergeInterpolations = require('./mergeInterpolations-6727b536.js');
@@ -95,7 +97,8 @@ require('./useToggle-3ebba7d8.js');
95
97
  require('./useActive-6770f917.js');
96
98
  require('./BaseSelector-2dc69917.js');
97
99
  require('./useFocus-1b288fb9.js');
98
- require('./StyledCheckbox-9047ed7d.js');
100
+ require('./PRIVATE_BaseSelector/themes/SelectorStyles.css.js');
101
+
99
102
  require('./Check-1272bb86.js');
100
103
  require('./Icon-56789beb.js');
101
104
  require('./size-1914356b.js');
@@ -130,9 +133,6 @@ require('./UNSAFE_Checkbox/themes/redwood/CheckboxIconVariants.css.js');
130
133
 
131
134
  require('./useTabbableMode-dbd254e8.js');
132
135
 
133
- require('./PRIVATE_BaseSelector/themes/SelectorStyles.css.js');
134
-
135
-
136
136
 
137
137
  require('./mergeDeepWithKey-210b024d.js');
138
138
  require('./_isObject-28636267.js');
@@ -1,4 +1,4 @@
1
- .SegmentStyles_base__51w8ze0 {
1
+ .SegmentStyles_base__kzheun0 {
2
2
  caret-color: transparent;
3
3
  text-align: end;
4
4
  -webkit-tap-highlight-color: transparent;
@@ -6,35 +6,32 @@
6
6
  user-select: none;
7
7
  -webkit-user-select: none;
8
8
  }
9
- .SegmentStyles_base__51w8ze0:focus-visible {
9
+ .SegmentStyles_base__kzheun0:focus-visible {
10
10
  outline: none;
11
11
  }
12
- .SegmentStyles_literalBase__51w8ze1 {
12
+ .SegmentStyles_literalBase__kzheun1 {
13
13
  white-space: pre;
14
14
  -webkit-user-select: none;
15
15
  -moz-user-select: none;
16
16
  user-select: none;
17
17
  }
18
- .SegmentStyles_placeholder__51w8ze2 {
18
+ .SegmentStyles_placeholder__kzheun2 {
19
19
  color: var(--oj-c-text-icon-secondary);
20
20
  text-align: start;
21
21
  }
22
- .SegmentStyles_space__51w8ze3 {
23
- width: 4px;
24
- }
25
- .SegmentStyles_selected__51w8ze4 {
22
+ .SegmentStyles_selected__kzheun3 {
26
23
  background-color: var(--oj-c-surface-selected);
27
24
  border-color: var(--oj-c-border-selected);
28
25
  }
29
- .SegmentStyles_highlighted__51w8ze5 {
26
+ .SegmentStyles_highlighted__kzheun4 {
30
27
  background-color: var(--oj-c-surface-selected);
31
28
  }
32
- .SegmentStyles_hidden__51w8ze6 {
29
+ .SegmentStyles_hidden__kzheun5 {
33
30
  display: none;
34
31
  }
35
- .SegmentStyles_notHidden__51w8ze7 {
32
+ .SegmentStyles_notHidden__kzheun6 {
36
33
  display: block;
37
34
  }
38
- .SegmentStyles_accessibleTouchTarget__51w8ze8 {
35
+ .SegmentStyles_accessibleTouchTarget__kzheun7 {
39
36
  min-width: 24px;
40
37
  }
@@ -1,4 +1,4 @@
1
- .SegmentStyles_base__kzheun0 {
1
+ .SegmentStyles_base__51w8ze0 {
2
2
  caret-color: transparent;
3
3
  text-align: end;
4
4
  -webkit-tap-highlight-color: transparent;
@@ -6,32 +6,35 @@
6
6
  user-select: none;
7
7
  -webkit-user-select: none;
8
8
  }
9
- .SegmentStyles_base__kzheun0:focus-visible {
9
+ .SegmentStyles_base__51w8ze0:focus-visible {
10
10
  outline: none;
11
11
  }
12
- .SegmentStyles_literalBase__kzheun1 {
12
+ .SegmentStyles_literalBase__51w8ze1 {
13
13
  white-space: pre;
14
14
  -webkit-user-select: none;
15
15
  -moz-user-select: none;
16
16
  user-select: none;
17
17
  }
18
- .SegmentStyles_placeholder__kzheun2 {
18
+ .SegmentStyles_placeholder__51w8ze2 {
19
19
  color: var(--oj-c-text-icon-secondary);
20
20
  text-align: start;
21
21
  }
22
- .SegmentStyles_selected__kzheun3 {
22
+ .SegmentStyles_space__51w8ze3 {
23
+ width: 4px;
24
+ }
25
+ .SegmentStyles_selected__51w8ze4 {
23
26
  background-color: var(--oj-c-surface-selected);
24
27
  border-color: var(--oj-c-border-selected);
25
28
  }
26
- .SegmentStyles_highlighted__kzheun4 {
29
+ .SegmentStyles_highlighted__51w8ze5 {
27
30
  background-color: var(--oj-c-surface-selected);
28
31
  }
29
- .SegmentStyles_hidden__kzheun5 {
32
+ .SegmentStyles_hidden__51w8ze6 {
30
33
  display: none;
31
34
  }
32
- .SegmentStyles_notHidden__kzheun6 {
35
+ .SegmentStyles_notHidden__51w8ze7 {
33
36
  display: block;
34
37
  }
35
- .SegmentStyles_accessibleTouchTarget__kzheun7 {
38
+ .SegmentStyles_accessibleTouchTarget__51w8ze8 {
36
39
  min-width: 24px;
37
40
  }
@@ -39,6 +39,8 @@ require('./CollectionInteractionContext-f84ff7a1.js');
39
39
 
40
40
  require('./Sheet-1d6e8cf8.js');
41
41
 
42
+ require('./StyledCheckbox-9047ed7d.js');
43
+
42
44
  var UNSAFE_TabBar_themes_TabBarStyles_css = require('./UNSAFE_TabBar/themes/TabBarStyles.css.js');
43
45
  var useTabBar = require('./useTabBar-35b73d10.js');
44
46
  var TabBarContextMenu = require('./TabBarContextMenu-d9bf65c2.js');
@@ -68,4 +70,4 @@ const TabBar = compat.forwardRef(({ children, layout = 'stretch', display = 'sta
68
70
  });
69
71
 
70
72
  exports.TabBar = TabBar;
71
- //# sourceMappingURL=TabBar-27ae2c21.js.map
73
+ //# sourceMappingURL=TabBar-4bc753a9.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TabBar-67ca442c.js","sources":["../../src/UNSAFE_TabBar/TabBar.tsx"],"sourcesContent":["import type { ComponentChildren, Ref, RefObject } from 'preact';\nimport { HiddenAccessible } from '../UNSAFE_HiddenAccessible';\nimport { LiveRegion } from '../UNSAFE_LiveRegion';\nimport { TabBarContext, TabBarLayout, TabBarContextMenuConfig } from '../UNSAFE_TabBarCommon';\nimport { styles } from './themes/TabBarStyles.css';\nimport { TestIdProps } from '../hooks/UNSAFE_useTestId';\nimport { useTabBar } from '../hooks/PRIVATE_useTabBar';\nimport { forwardRef } from 'preact/compat';\nimport { TabBarContextMenu } from './TabBarContextMenu';\nexport {\n TabBarItem,\n RemovableTabBarItem,\n OverflowTabBarItem,\n TabBarContext,\n useTabBarContext,\n TabBarLayout,\n useProgressiveTruncation,\n TabBarLinkItem\n} from '../UNSAFE_TabBarCommon';\n\n/**\n * type for payload of current key change event handler\n */\nexport type CurrentKeyDetail<K> = {\n value: K;\n};\n\n/**\n * type for payload of selection change event handler\n */\ntype SelectionDetail<K> = {\n value: K;\n};\n\n/**\n * type for payload of remove event handler\n */\ntype RemoveDetail<K> = {\n value: K;\n};\n\ntype DisplayProps =\n | {\n /**\n * Controls the content layout of the TabBarItem: 'standard' lays out the contents horizontally,\n *'icons' hides the label,\n */\n display?: 'standard' | 'icons';\n /**\n * The size indicates how tall the TabBarItem is rendered.\n * Note: It is not possible to specify 'size' when 'display=\"stacked\".\n */\n size?: 'md' | 'lg';\n }\n | {\n /**\n *'stacked' stacks the icon on top of the label.\n * Note: It is not possible to specify 'size' when 'display=\"stacked\".\n */\n display?: 'stacked';\n size?: 'never';\n };\n\nexport type TabBarProps<K extends string | number> = DisplayProps & {\n /**\n * A set of TabBarItem(s) that TabBar will hold\n */\n children: ComponentChildren;\n /**\n * Whether to stretch the tab bar items to occupy available space or to condense items\n */\n layout?: 'stretch' | 'condense';\n /**\n * The position of the TabBar. Valid Values: top and bottom.\n * 'top' is used when TabBar is placed on top of content section and the selection\n * indicator would be placed below the TabBarItem.\n * 'bottom' is used when TabBar is placed on bottom of content section and the selection\n * indicator would be placed above the TabBarItem.\n */\n edge?: 'top' | 'bottom';\n /**\n * Key of the selected item.\n */\n selection?: K;\n /**\n * Callback function to handle when user selects a tab.\n * The callback is also invoked when a user selects a tab that is already selected.\n */\n onSelect?: <K extends string | number>(detail: SelectionDetail<K>) => void;\n /**\n * Callback function to handle remove\n */\n onRemove?: <K extends string | number>(detail: RemoveDetail<K>) => void;\n /**\n * Accepts the ID of an element that provides instructions for interaction with the TabBar.\n */\n 'aria-describedby'?: string;\n /**\n * An aria-label which defines a string value that labels this TabBar.\n * Either aria-label or aria-labelledby should be specified in order to make TabBar accessible.\n */\n 'aria-label'?: string;\n\n /**\n * An aria-labelledby which identifies the element(s) that labels this TabBar.\n * Either aria-label or aria-labelledby should be specified in order to make TabBar accessible.\n */\n 'aria-labelledby'?: string;\n\n /**\n * Configuration used to specify a context menu.\n */\n contextMenuConfig?: TabBarContextMenuConfig<K>;\n};\n/**\n * A tab bar allows navigation between different content sections.\n */\nexport const TabBar = forwardRef(\n <K extends string | number>(\n {\n children,\n layout = 'stretch',\n display = 'standard',\n size = 'md',\n edge = 'top',\n selection,\n onSelect,\n onRemove,\n 'aria-describedby': ariaDescribedBy,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledby,\n contextMenuConfig\n }: TabBarProps<K> & TestIdProps,\n ref?: Ref<HTMLDivElement>\n ) => {\n const rootRef = ref as RefObject<HTMLDivElement>;\n\n const {\n rootProps,\n tabBarContext,\n menuProps,\n contextMenuContext,\n contextMenuDescription,\n contextMenuDescriptionId,\n accStatusInfo\n } = useTabBar({\n class: styles.tabBarBase,\n edge: edge,\n onRemove,\n onSelect,\n ref: rootRef,\n selection,\n size,\n children,\n contextMenuConfig\n });\n\n const isContextMenuAvailable = contextMenuConfig != null;\n\n return (\n <>\n <TabBarContext.Provider value={tabBarContext}>\n <div\n {...rootProps}\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledby}\n aria-haspopup={contextMenuConfig != null ? true : false}\n aria-describedby={\n isContextMenuAvailable && contextMenuDescriptionId\n ? ariaDescribedBy\n ? `${ariaDescribedBy} ${contextMenuDescriptionId}`\n : contextMenuDescriptionId\n : ariaDescribedBy\n }>\n <TabBarLayout layout={layout} display={display}>\n {children}\n </TabBarLayout>\n </div>\n </TabBarContext.Provider>\n {isContextMenuAvailable && contextMenuDescriptionId && (\n <span id={contextMenuDescriptionId}>\n <HiddenAccessible>{contextMenuDescription}</HiddenAccessible>\n </span>\n )}\n {isContextMenuAvailable && accStatusInfo && <LiveRegion>{accStatusInfo}</LiveRegion>}\n {isContextMenuAvailable && (\n <TabBarContextMenu\n {...menuProps}\n contextMenuConfig={contextMenuConfig}\n contextMenuContext={contextMenuContext!}\n />\n )}\n </>\n );\n }\n);\n"],"names":["_jsxs","_Fragment","_jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkHA;;AAEG;MACU,MAAM,GAAG,UAAU,CAC9B,CACE,EACE,QAAQ,EACR,MAAM,GAAG,SAAS,EAClB,OAAO,GAAG,UAAU,EACpB,IAAI,GAAG,IAAI,EACX,IAAI,GAAG,KAAK,EACZ,SAAS,EACT,QAAQ,EACR,QAAQ,EACR,kBAAkB,EAAE,eAAe,EACnC,YAAY,EAAE,SAAS,EACvB,iBAAiB,EAAE,cAAc,EACjC,iBAAiB,EACY,EAC/B,GAAyB,KACvB;IACF,MAAM,OAAO,GAAG,GAAgC,CAAC;AAEjD,IAAA,MAAM,EACJ,SAAS,EACT,aAAa,EACb,SAAS,EACT,kBAAkB,EAClB,sBAAsB,EACtB,wBAAwB,EACxB,aAAa,EACd,GAAG,SAAS,CAAC;QACZ,KAAK,EAAE,MAAM,CAAC,UAAU;AACxB,QAAA,IAAI,EAAE,IAAI;QACV,QAAQ;QACR,QAAQ;AACR,QAAA,GAAG,EAAE,OAAO;QACZ,SAAS;QACT,IAAI;QACJ,QAAQ;QACR,iBAAiB;AAClB,KAAA,CAAC,CAAC;AAEH,IAAA,MAAM,sBAAsB,GAAG,iBAAiB,IAAI,IAAI,CAAC;AAEzD,IAAA,QACEA,IAAA,CAAAC,QAAA,EAAA,EAAA,QAAA,EAAA,CACEC,GAAC,CAAA,aAAa,CAAC,QAAQ,EAAA,EAAC,KAAK,EAAE,aAAa,EAAA,QAAA,EAC1CA,GACM,CAAA,KAAA,EAAA,EAAA,GAAA,SAAS,gBACD,SAAS,EAAA,iBAAA,EACJ,cAAc,EAAA,eAAA,EAChB,iBAAiB,IAAI,IAAI,GAAG,IAAI,GAAG,KAAK,EAErD,kBAAA,EAAA,sBAAsB,IAAI,wBAAwB;AAChD,0BAAE,eAAe;AACf,8BAAE,CAAA,EAAG,eAAe,CAAA,CAAA,EAAI,wBAAwB,CAAE,CAAA;AAClD,8BAAE,wBAAwB;AAC5B,0BAAE,eAAe,EAErB,QAAA,EAAAA,GAAA,CAAC,YAAY,EAAA,EAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAC3C,QAAA,EAAA,QAAQ,EACI,CAAA,EAAA,CACX,EACiB,CAAA,EACxB,sBAAsB,IAAI,wBAAwB,KACjDA,GAAM,CAAA,MAAA,EAAA,EAAA,EAAE,EAAE,wBAAwB,EAChC,QAAA,EAAAA,GAAA,CAAC,gBAAgB,EAAE,EAAA,QAAA,EAAA,sBAAsB,EAAoB,CAAA,EAAA,CACxD,CACR,EACA,sBAAsB,IAAI,aAAa,IAAIA,GAAC,CAAA,UAAU,EAAE,EAAA,QAAA,EAAA,aAAa,EAAc,CAAA,EACnF,sBAAsB,KACrBA,GAAC,CAAA,iBAAiB,EACZ,EAAA,GAAA,SAAS,EACb,iBAAiB,EAAE,iBAAiB,EACpC,kBAAkB,EAAE,kBAAmB,EAAA,CACvC,CACH,CAAA,EAAA,CACA,EACH;AACJ,CAAC;;;;"}
1
+ {"version":3,"file":"TabBar-4bc753a9.js","sources":["../../src/UNSAFE_TabBar/TabBar.tsx"],"sourcesContent":["import type { ComponentChildren, Ref, RefObject } from 'preact';\nimport { HiddenAccessible } from '../UNSAFE_HiddenAccessible';\nimport { LiveRegion } from '../UNSAFE_LiveRegion';\nimport { TabBarContext, TabBarLayout, TabBarContextMenuConfig } from '../UNSAFE_TabBarCommon';\nimport { styles } from './themes/TabBarStyles.css';\nimport { TestIdProps } from '../hooks/UNSAFE_useTestId';\nimport { useTabBar } from '../hooks/PRIVATE_useTabBar';\nimport { forwardRef } from 'preact/compat';\nimport { TabBarContextMenu } from './TabBarContextMenu';\nexport {\n TabBarItem,\n RemovableTabBarItem,\n OverflowTabBarItem,\n TabBarContext,\n useTabBarContext,\n TabBarLayout,\n useProgressiveTruncation,\n TabBarLinkItem\n} from '../UNSAFE_TabBarCommon';\n\n/**\n * type for payload of current key change event handler\n */\nexport type CurrentKeyDetail<K> = {\n value: K;\n};\n\n/**\n * type for payload of selection change event handler\n */\ntype SelectionDetail<K> = {\n value: K;\n};\n\n/**\n * type for payload of remove event handler\n */\ntype RemoveDetail<K> = {\n value: K;\n};\n\ntype DisplayProps =\n | {\n /**\n * Controls the content layout of the TabBarItem: 'standard' lays out the contents horizontally,\n *'icons' hides the label,\n */\n display?: 'standard' | 'icons';\n /**\n * The size indicates how tall the TabBarItem is rendered.\n * Note: It is not possible to specify 'size' when 'display=\"stacked\".\n */\n size?: 'md' | 'lg';\n }\n | {\n /**\n *'stacked' stacks the icon on top of the label.\n * Note: It is not possible to specify 'size' when 'display=\"stacked\".\n */\n display?: 'stacked';\n size?: 'never';\n };\n\nexport type TabBarProps<K extends string | number> = DisplayProps & {\n /**\n * A set of TabBarItem(s) that TabBar will hold\n */\n children: ComponentChildren;\n /**\n * Whether to stretch the tab bar items to occupy available space or to condense items\n */\n layout?: 'stretch' | 'condense';\n /**\n * The position of the TabBar. Valid Values: top and bottom.\n * 'top' is used when TabBar is placed on top of content section and the selection\n * indicator would be placed below the TabBarItem.\n * 'bottom' is used when TabBar is placed on bottom of content section and the selection\n * indicator would be placed above the TabBarItem.\n */\n edge?: 'top' | 'bottom';\n /**\n * Key of the selected item.\n */\n selection?: K;\n /**\n * Callback function to handle when user selects a tab.\n * The callback is also invoked when a user selects a tab that is already selected.\n */\n onSelect?: <K extends string | number>(detail: SelectionDetail<K>) => void;\n /**\n * Callback function to handle remove\n */\n onRemove?: <K extends string | number>(detail: RemoveDetail<K>) => void;\n /**\n * Accepts the ID of an element that provides instructions for interaction with the TabBar.\n */\n 'aria-describedby'?: string;\n /**\n * An aria-label which defines a string value that labels this TabBar.\n * Either aria-label or aria-labelledby should be specified in order to make TabBar accessible.\n */\n 'aria-label'?: string;\n\n /**\n * An aria-labelledby which identifies the element(s) that labels this TabBar.\n * Either aria-label or aria-labelledby should be specified in order to make TabBar accessible.\n */\n 'aria-labelledby'?: string;\n\n /**\n * Configuration used to specify a context menu.\n */\n contextMenuConfig?: TabBarContextMenuConfig<K>;\n};\n/**\n * A tab bar allows navigation between different content sections.\n */\nexport const TabBar = forwardRef(\n <K extends string | number>(\n {\n children,\n layout = 'stretch',\n display = 'standard',\n size = 'md',\n edge = 'top',\n selection,\n onSelect,\n onRemove,\n 'aria-describedby': ariaDescribedBy,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledby,\n contextMenuConfig\n }: TabBarProps<K> & TestIdProps,\n ref?: Ref<HTMLDivElement>\n ) => {\n const rootRef = ref as RefObject<HTMLDivElement>;\n\n const {\n rootProps,\n tabBarContext,\n menuProps,\n contextMenuContext,\n contextMenuDescription,\n contextMenuDescriptionId,\n accStatusInfo\n } = useTabBar({\n class: styles.tabBarBase,\n edge: edge,\n onRemove,\n onSelect,\n ref: rootRef,\n selection,\n size,\n children,\n contextMenuConfig\n });\n\n const isContextMenuAvailable = contextMenuConfig != null;\n\n return (\n <>\n <TabBarContext.Provider value={tabBarContext}>\n <div\n {...rootProps}\n aria-label={ariaLabel}\n aria-labelledby={ariaLabelledby}\n aria-haspopup={contextMenuConfig != null ? true : false}\n aria-describedby={\n isContextMenuAvailable && contextMenuDescriptionId\n ? ariaDescribedBy\n ? `${ariaDescribedBy} ${contextMenuDescriptionId}`\n : contextMenuDescriptionId\n : ariaDescribedBy\n }>\n <TabBarLayout layout={layout} display={display}>\n {children}\n </TabBarLayout>\n </div>\n </TabBarContext.Provider>\n {isContextMenuAvailable && contextMenuDescriptionId && (\n <span id={contextMenuDescriptionId}>\n <HiddenAccessible>{contextMenuDescription}</HiddenAccessible>\n </span>\n )}\n {isContextMenuAvailable && accStatusInfo && <LiveRegion>{accStatusInfo}</LiveRegion>}\n {isContextMenuAvailable && (\n <TabBarContextMenu\n {...menuProps}\n contextMenuConfig={contextMenuConfig}\n contextMenuContext={contextMenuContext!}\n />\n )}\n </>\n );\n }\n);\n"],"names":["forwardRef","useTabBar","styles","_jsxs","_Fragment","_jsx","TabBarContext","TabBarLayout","HiddenAccessible","LiveRegion","TabBarContextMenu"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkHA;;AAEG;MACU,MAAM,GAAGA,iBAAU,CAC9B,CACE,EACE,QAAQ,EACR,MAAM,GAAG,SAAS,EAClB,OAAO,GAAG,UAAU,EACpB,IAAI,GAAG,IAAI,EACX,IAAI,GAAG,KAAK,EACZ,SAAS,EACT,QAAQ,EACR,QAAQ,EACR,kBAAkB,EAAE,eAAe,EACnC,YAAY,EAAE,SAAS,EACvB,iBAAiB,EAAE,cAAc,EACjC,iBAAiB,EACY,EAC/B,GAAyB,KACvB;IACF,MAAM,OAAO,GAAG,GAAgC,CAAC;AAEjD,IAAA,MAAM,EACJ,SAAS,EACT,aAAa,EACb,SAAS,EACT,kBAAkB,EAClB,sBAAsB,EACtB,wBAAwB,EACxB,aAAa,EACd,GAAGC,mBAAS,CAAC;QACZ,KAAK,EAAEC,4CAAM,CAAC,UAAU;AACxB,QAAA,IAAI,EAAE,IAAI;QACV,QAAQ;QACR,QAAQ;AACR,QAAA,GAAG,EAAE,OAAO;QACZ,SAAS;QACT,IAAI;QACJ,QAAQ;QACR,iBAAiB;AAClB,KAAA,CAAC,CAAC;AAEH,IAAA,MAAM,sBAAsB,GAAG,iBAAiB,IAAI,IAAI,CAAC;AAEzD,IAAA,QACEC,eAAA,CAAAC,mBAAA,EAAA,EAAA,QAAA,EAAA,CACEC,cAAC,CAAAC,0BAAa,CAAC,QAAQ,EAAA,EAAC,KAAK,EAAE,aAAa,EAAA,QAAA,EAC1CD,cACM,CAAA,KAAA,EAAA,EAAA,GAAA,SAAS,gBACD,SAAS,EAAA,iBAAA,EACJ,cAAc,EAAA,eAAA,EAChB,iBAAiB,IAAI,IAAI,GAAG,IAAI,GAAG,KAAK,EAErD,kBAAA,EAAA,sBAAsB,IAAI,wBAAwB;AAChD,0BAAE,eAAe;AACf,8BAAE,CAAA,EAAG,eAAe,CAAA,CAAA,EAAI,wBAAwB,CAAE,CAAA;AAClD,8BAAE,wBAAwB;AAC5B,0BAAE,eAAe,EAErB,QAAA,EAAAA,cAAA,CAACE,yBAAY,EAAA,EAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAC3C,QAAA,EAAA,QAAQ,EACI,CAAA,EAAA,CACX,EACiB,CAAA,EACxB,sBAAsB,IAAI,wBAAwB,KACjDF,cAAM,CAAA,MAAA,EAAA,EAAA,EAAE,EAAE,wBAAwB,EAChC,QAAA,EAAAA,cAAA,CAACG,iCAAgB,EAAE,EAAA,QAAA,EAAA,sBAAsB,EAAoB,CAAA,EAAA,CACxD,CACR,EACA,sBAAsB,IAAI,aAAa,IAAIH,cAAC,CAAAI,qBAAU,EAAE,EAAA,QAAA,EAAA,aAAa,EAAc,CAAA,EACnF,sBAAsB,KACrBJ,cAAC,CAAAK,mCAAiB,EACZ,EAAA,GAAA,SAAS,EACb,iBAAiB,EAAE,iBAAiB,EACpC,kBAAkB,EAAE,kBAAmB,EAAA,CACvC,CACH,CAAA,EAAA,CACA,EACH;AACJ,CAAC;;;;"}