@oracle/oraclejet-preact 17.1.2 → 17.1.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.
- package/amd/{BarChart-aba4a793.js → BarChart-b75423c1.js} +2 -2
- package/amd/{BarChart-aba4a793.js.map → BarChart-b75423c1.js.map} +1 -1
- package/amd/{Chart-1046ac5b.js → Chart-96ea9fed.js} +2 -2
- package/amd/{Chart-1046ac5b.js.map → Chart-96ea9fed.js.map} +1 -1
- package/amd/{LineAreaChart-07630832.js → LineAreaChart-47b01e9e.js} +2 -2
- package/amd/{LineAreaChart-07630832.js.map → LineAreaChart-47b01e9e.js.map} +1 -1
- package/amd/PRIVATE_Chart.js +1 -1
- package/amd/TextArea-916c5bb1.js +2 -0
- package/amd/TextArea-916c5bb1.js.map +1 -0
- package/amd/TextAreaAutosize-1f47b470.js +2 -0
- package/amd/{TextAreaAutosize-e8dc13b4.js.map → TextAreaAutosize-1f47b470.js.map} +1 -1
- package/amd/Theme-redwood/theme.css +191 -191
- package/amd/Theme-stable/theme.css +239 -239
- package/amd/UNSAFE_BarChart/__test__/BarChart.spec.js +1 -1
- package/amd/UNSAFE_BarChart.js +1 -1
- package/amd/UNSAFE_DrawerPopup.js +1 -1
- package/amd/UNSAFE_LineAreaChart/__test__/LineChart.spec.js +1 -1
- package/amd/UNSAFE_LineAreaChart.js +1 -1
- package/amd/UNSAFE_TextArea.js +1 -1
- package/amd/UNSAFE_TextAreaAutosize.js +1 -1
- package/amd/hooks/UNSAFE_useContainerBreakpointValues.js +1 -1
- package/amd/hooks/UNSAFE_useSwipe.js +1 -1
- package/amd/useSwipe-d22a98f1.js +2 -0
- package/amd/{useSwipe-9600cd2e.js.map → useSwipe-d22a98f1.js.map} +1 -1
- package/cjs/{BarChart-6b34be7b.js → BarChart-f132cd7c.js} +2 -2
- package/cjs/{BarChart-6b34be7b.js.map → BarChart-f132cd7c.js.map} +1 -1
- package/cjs/{BaseCardView-55bc5e6f.js → BaseCardView-b5471a69.js} +2 -2
- package/cjs/{BaseCardView-55bc5e6f.js.map → BaseCardView-b5471a69.js.map} +1 -1
- package/cjs/{CardFlexView-ae79f8f1.js → CardFlexView-075d4013.js} +2 -2
- package/cjs/{CardFlexView-ae79f8f1.js.map → CardFlexView-075d4013.js.map} +1 -1
- package/cjs/{CardGridView-4936ffd6.js → CardGridView-3c07cf2a.js} +2 -2
- package/cjs/{CardGridView-4936ffd6.js.map → CardGridView-3c07cf2a.js.map} +1 -1
- package/cjs/{Chart-4eee682b.js → Chart-42a979a7.js} +2 -2
- package/cjs/{Chart-4eee682b.js.map → Chart-42a979a7.js.map} +1 -1
- package/cjs/GroupLoadingIndicator-397feb37.js +1 -1
- package/cjs/{Indexer-1dfa7ec4.js → Indexer-8ba89fa5.js} +2 -2
- package/cjs/{Indexer-1dfa7ec4.js.map → Indexer-8ba89fa5.js.map} +1 -1
- package/cjs/{InputDatePicker-c2ef8b45.js → InputDatePicker-fe21408c.js} +2 -2
- package/cjs/{InputDatePicker-c2ef8b45.js.map → InputDatePicker-fe21408c.js.map} +1 -1
- package/cjs/{LineAreaChart-28268084.js → LineAreaChart-4f443939.js} +2 -2
- package/cjs/{LineAreaChart-28268084.js.map → LineAreaChart-4f443939.js.map} +1 -1
- package/cjs/{List-2baf37ae.js → List-5374e621.js} +3 -4
- package/cjs/{List-2baf37ae.js.map → List-5374e621.js.map} +1 -1
- package/cjs/{ListView-4db96cfd.js → ListView-a8278334.js} +2 -2
- package/cjs/{ListView-4db96cfd.js.map → ListView-a8278334.js.map} +1 -1
- package/cjs/{LoadMoreCollection-73112ff0.js → LoadMoreCollection-69bc038c.js} +2 -2
- package/cjs/{LoadMoreCollection-73112ff0.js.map → LoadMoreCollection-69bc038c.js.map} +1 -1
- package/cjs/PRIVATE_BaseCardView.js +3 -3
- package/cjs/PRIVATE_Chart.js +4 -4
- package/cjs/PRIVATE_List.js +4 -4
- package/cjs/PRIVATE_LoadMoreCollection.js +2 -2
- package/cjs/PRIVATE_SelectCommon.js +5 -5
- package/cjs/PRIVATE_Table.js +3 -3
- package/cjs/PRIVATE_VirtualizedCollection.js +2 -2
- package/cjs/{SelectMultiple-2d4eba14.js → SelectMultiple-79cebd04.js} +2 -2
- package/cjs/{SelectMultiple-2d4eba14.js.map → SelectMultiple-79cebd04.js.map} +1 -1
- package/cjs/{SelectSingle-731c2ecd.js → SelectSingle-d8cf56db.js} +2 -2
- package/cjs/{SelectSingle-731c2ecd.js.map → SelectSingle-d8cf56db.js.map} +1 -1
- package/cjs/{Table-b137c360.js → Table-d70de040.js} +2 -2
- package/cjs/{Table-b137c360.js.map → Table-d70de040.js.map} +1 -1
- package/cjs/{TableView-3a1f0c38.js → TableView-d91ebb19.js} +2 -2
- package/cjs/{TableView-3a1f0c38.js.map → TableView-d91ebb19.js.map} +1 -1
- package/cjs/{TextArea-096f18ad.js → TextArea-792069d7.js} +22 -4
- package/cjs/TextArea-792069d7.js.map +1 -0
- package/cjs/{TextAreaAutosize-4d30faec.js → TextAreaAutosize-1989de68.js} +3 -3
- package/cjs/{TextAreaAutosize-4d30faec.js.map → TextAreaAutosize-1989de68.js.map} +1 -1
- package/cjs/Theme-redwood/theme.css +162 -162
- package/cjs/Theme-stable/theme.css +366 -366
- package/cjs/UNSAFE_BarChart/__test__/BarChart.spec.js +5 -5
- package/cjs/UNSAFE_BarChart.js +5 -5
- package/cjs/UNSAFE_CardFlexView.js +4 -4
- package/cjs/UNSAFE_CardGridView.js +4 -4
- package/cjs/UNSAFE_DrawerPopup.js +1 -1
- package/cjs/UNSAFE_ExpandableList.js +3 -3
- package/cjs/UNSAFE_Indexer.js +2 -2
- package/cjs/UNSAFE_InputDatePicker.js +90 -90
- package/cjs/UNSAFE_LineAreaChart/__test__/LineChart.spec.js +5 -5
- package/cjs/UNSAFE_LineAreaChart.js +5 -5
- package/cjs/UNSAFE_ListView.js +5 -5
- package/cjs/UNSAFE_SelectMultiple.js +6 -6
- package/cjs/UNSAFE_SelectSingle.js +6 -6
- package/cjs/UNSAFE_TableView.js +4 -4
- package/cjs/UNSAFE_TextArea.js +3 -4
- package/cjs/UNSAFE_TextArea.js.map +1 -1
- package/cjs/UNSAFE_TextAreaAutosize.js +3 -3
- package/cjs/UNSAFE_VirtualizedListView.js +5 -5
- package/cjs/{VirtualizedCollection-00aedb8b.js → VirtualizedCollection-9e8c48b9.js} +2 -2
- package/cjs/{VirtualizedCollection-00aedb8b.js.map → VirtualizedCollection-9e8c48b9.js.map} +1 -1
- package/cjs/{VirtualizedListView-75610c90.js → VirtualizedListView-16222e22.js} +2 -2
- package/cjs/{VirtualizedListView-75610c90.js.map → VirtualizedListView-16222e22.js.map} +1 -1
- package/cjs/hooks/UNSAFE_useSwipe.js +1 -1
- package/cjs/{useSelectCommon-12313cdd.js → useSelectCommon-309c1746.js} +2 -2
- package/cjs/{useSelectCommon-12313cdd.js.map → useSelectCommon-309c1746.js.map} +1 -1
- package/cjs/{useSwipe-45174423.js → useSwipe-d917dcba.js} +15 -15
- package/cjs/{useSwipe-45174423.js.map → useSwipe-d917dcba.js.map} +1 -1
- package/es/ActionCard-ba1c946e.js +1 -1
- package/es/AvatarVariants.styles.css +25 -25
- package/es/AvatarVariants.styles2.css +25 -25
- package/es/BadgeVariants.styles.css +14 -14
- package/es/BadgeVariants.styles2.css +14 -14
- package/es/BarChart-cbd9c2bf.js +2 -2
- package/es/BaseButton-5a3335d9.js +2 -2
- package/es/BaseCardView-e0e8a69b.js +6 -6
- package/es/{BaseCardViewSelectionTest-2159b609.js → BaseCardViewSelectionTest-120542e8.js} +6 -6
- package/es/{BaseCardViewSelectionTest-2159b609.js.map → BaseCardViewSelectionTest-120542e8.js.map} +1 -1
- package/es/BaseNavigationListItem-ac7ef3c3.js +1 -1
- package/es/ButtonSet-ac76e6e2.js +2 -2
- package/es/ButtonSetIconButton-9241b9fb.js +3 -3
- package/es/{Center-9f355d44.js → Center-8b48ab02.js} +2 -2
- package/es/{Center-9f355d44.js.map → Center-8b48ab02.js.map} +1 -1
- package/es/Chart-8922a0b3.js +9 -9
- package/es/CheckboxControl-f5e36d0d.js +6 -6
- package/es/CheckboxRadioField-bdda2573.js +6 -6
- package/es/Chip-f2df2078.js +1 -1
- package/es/ClearIcon-b5083cc8.js +1 -1
- package/es/CollapseIcon-de129943.js +1 -1
- package/es/Collapsible-09cc493a.js +2 -2
- package/es/CompactHelpSource-1686edf6.js +2 -2
- package/es/{CompactLabelAssistance-61df6dbf.js → CompactLabelAssistance-fa8264fa.js} +5 -5
- package/es/{CompactLabelAssistance-61df6dbf.js.map → CompactLabelAssistance-fa8264fa.js.map} +1 -1
- package/es/CompactUserAssistance-3a10afd4.js +4 -4
- package/es/ComponentMessageContainer-18e7fe34.js +4 -4
- package/es/ConveyorBeltItem-c8d4ba1b.js +2 -2
- package/es/ConveyorBeltVariants.styles.css +6 -6
- package/es/ConveyorBeltVariants.styles2.css +6 -6
- package/es/{DatePicker-d4e027c2.js → DatePicker-4fb6d86d.js} +6 -6
- package/es/{DatePicker-d4e027c2.js.map → DatePicker-4fb6d86d.js.map} +1 -1
- package/es/DatePickerHeader-79f0b61b.js +3 -3
- package/es/{Diagram-d7fdc75f.js → Diagram-6f1ad2ea.js} +5 -5
- package/es/{Diagram-d7fdc75f.js.map → Diagram-6f1ad2ea.js.map} +1 -1
- package/es/{Dialog-cf69547f.js → Dialog-5e92dcd1.js} +6 -6
- package/es/{Dialog-cf69547f.js.map → Dialog-5e92dcd1.js.map} +1 -1
- package/es/DirectionalCollapseArrowIcon-20259aab.js +1 -1
- package/es/DirectionalExpandArrowIcon-36ba273c.js +1 -1
- package/es/DragHandle-3b768189.js +1 -1
- package/es/{Dropdown-d017dd0a.js → Dropdown-f45f823c.js} +5 -5
- package/es/{Dropdown-d017dd0a.js.map → Dropdown-f45f823c.js.map} +1 -1
- package/es/{EnvironmentProvider-a3819bde.js → EnvironmentProvider-0fc2fd0c.js} +3 -3
- package/es/{EnvironmentProvider-a3819bde.js.map → EnvironmentProvider-0fc2fd0c.js.map} +1 -1
- package/es/FilePicker-f4582615.js +2 -2
- package/es/{Flex-2d51e914.js → Flex-8696b27b.js} +2 -2
- package/es/{Flex-2d51e914.js.map → Flex-8696b27b.js.map} +1 -1
- package/es/{Floating-aebc0f85.js → Floating-f9bbd276.js} +4 -4
- package/es/{Floating-aebc0f85.js.map → Floating-f9bbd276.js.map} +1 -1
- package/es/FormLayout-221e1aa8.js +1 -1
- package/es/Gantt-46f5f954.js +9 -9
- package/es/{Grid-c2385b22.js → Grid-7fd29a9e.js} +2 -2
- package/es/{Grid-c2385b22.js.map → Grid-7fd29a9e.js.map} +1 -1
- package/es/{Gridlines-0e7b33f5.js → Gridlines-dcdc34bc.js} +2 -2
- package/es/{Gridlines-0e7b33f5.js.map → Gridlines-dcdc34bc.js.map} +1 -1
- package/es/GroupLoadingIndicator-2bfdba44.js +1 -1
- package/es/{HighlightText-d505bf35.js → HighlightText-cc043982.js} +2 -2
- package/es/{HighlightText-d505bf35.js.map → HighlightText-cc043982.js.map} +1 -1
- package/es/Icon-4171c0d7.js +3 -3
- package/es/IconButton-451a225c.js +3 -3
- package/es/IconMenuButton-e46f8d54.js +4 -4
- package/es/IconProgressButton-8f2f6b27.js +3 -3
- package/es/IconSwitchButton-5ff7b0fe.js +3 -3
- package/es/IconToggleButton-375f006f.js +3 -3
- package/es/{IconUserAssistance-7cfd1ed2.js → IconUserAssistance-dd56b812.js} +3 -3
- package/es/{IconUserAssistance-7cfd1ed2.js.map → IconUserAssistance-dd56b812.js.map} +1 -1
- package/es/Indexer-658cee69.js +4 -4
- package/es/InlineHelpSource-fcdcd122.js +1 -1
- package/es/InlineUserAssistance-e6deb149.js +5 -5
- package/es/InputDateMask-3d511e39.js +7 -7
- package/es/{InputDatePicker-81a18a57.js → InputDatePicker-fe26a952.js} +10 -10
- package/es/{InputDatePicker-81a18a57.js.map → InputDatePicker-fe26a952.js.map} +1 -1
- package/es/InputPassword-47130b3c.js +4 -4
- package/es/InputText-4799b2ed.js +6 -6
- package/es/Label-ab276ca9.js +5 -5
- package/es/LabelValueLayout-bcf482be.js +1 -1
- package/es/{Layer-915d986a.js → Layer-71fc666f.js} +3 -3
- package/es/{Layer-915d986a.js.map → Layer-71fc666f.js.map} +1 -1
- package/es/{LayerHost-7a2149f5.js → LayerHost-15b42a3e.js} +2 -2
- package/es/{LayerHost-7a2149f5.js.map → LayerHost-15b42a3e.js.map} +1 -1
- package/es/{LayerManager-be34be40.js → LayerManager-af39e736.js} +2 -2
- package/es/{LayerManager-be34be40.js.map → LayerManager-af39e736.js.map} +1 -1
- package/es/Legend-ae0296f0.js +3 -3
- package/es/{LineAreaChart-85b37b1c.js → LineAreaChart-cfb9b43d.js} +3 -3
- package/es/{LineAreaChart-85b37b1c.js.map → LineAreaChart-cfb9b43d.js.map} +1 -1
- package/es/Link-9072aa54.js +1 -1
- package/es/LinkVariants.styles.css +14 -14
- package/es/LinkVariants.styles2.css +14 -14
- package/es/List-1d23e84f.js +5 -5
- package/es/{ListItemLayout-01286b56.js → ListItemLayout-32895900.js} +2 -2
- package/es/{ListItemLayout-01286b56.js.map → ListItemLayout-32895900.js.map} +1 -1
- package/es/ListView-8eba90e8.js +3 -3
- package/es/{LiveRegion-5302331c.js → LiveRegion-cb4f8a54.js} +2 -2
- package/es/{LiveRegion-5302331c.js.map → LiveRegion-cb4f8a54.js.map} +1 -1
- package/es/{MaxLengthLiveRegion-9b386b63.js → MaxLengthLiveRegion-59087064.js} +3 -3
- package/es/{MaxLengthLiveRegion-9b386b63.js.map → MaxLengthLiveRegion-59087064.js.map} +1 -1
- package/es/{Menu-e44a3e0b.js → Menu-b5deea24.js} +8 -8
- package/es/{Menu-e44a3e0b.js.map → Menu-b5deea24.js.map} +1 -1
- package/es/MenuButton-49b7965d.js +3 -3
- package/es/MenuItem-be46866f.js +1 -1
- package/es/Message-322f8d63.js +2 -2
- package/es/{MessageLayer-f09b0a1b.js → MessageLayer-34a390eb.js} +6 -6
- package/es/{MessageLayer-f09b0a1b.js.map → MessageLayer-34a390eb.js.map} +1 -1
- package/es/MessageToast-66bdffe6.js +8 -8
- package/es/MessagesManager-a1c3e92e.js +3 -3
- package/es/MeterBar-9ad34b98.js +5 -5
- package/es/MeterBarVariants.styles.css +4 -4
- package/es/MeterBarVariants.styles2.css +4 -4
- package/es/MeterCircle-6bd257c8.js +5 -5
- package/es/{Modal-862b8167.js → Modal-3fd86d5a.js} +3 -3
- package/es/{Modal-862b8167.js.map → Modal-3fd86d5a.js.map} +1 -1
- package/es/{MonthView-3d90f424.js → MonthView-c3b82ace.js} +4 -4
- package/es/{MonthView-3d90f424.js.map → MonthView-c3b82ace.js.map} +1 -1
- package/es/NavigationListItem-a336f06f.js +5 -5
- package/es/NumberInputText-eca11601.js +6 -6
- package/es/OverflowTabBarItem-12249753.js +3 -3
- package/es/PRIVATE_BaseCardView.js +20 -20
- package/es/PRIVATE_Chart.js +30 -30
- package/es/PRIVATE_CheckboxControl.js +22 -22
- package/es/PRIVATE_CheckboxRadioField.js +23 -23
- package/es/PRIVATE_ClearIcon.js +17 -17
- package/es/PRIVATE_DatePickerHeader.js +19 -19
- package/es/PRIVATE_DatePickerLayout.js +4 -4
- package/es/PRIVATE_EmbeddedIconButton.js +3 -3
- package/es/PRIVATE_FormControls.js +19 -19
- package/es/PRIVATE_IconSwitchButton.js +15 -15
- package/es/PRIVATE_Icons/CheckboxMixed.js +15 -15
- package/es/PRIVATE_Icons/CheckboxOff.js +15 -15
- package/es/PRIVATE_Icons/CheckboxOn.js +15 -15
- package/es/PRIVATE_Icons/RadiobuttonOff.js +15 -15
- package/es/PRIVATE_Icons/RadiobuttonOn.js +15 -15
- package/es/PRIVATE_Icons/WarningS.js +15 -15
- package/es/PRIVATE_List.js +19 -19
- package/es/PRIVATE_Message.js +18 -18
- package/es/PRIVATE_MessageLayer.js +11 -11
- package/es/PRIVATE_MonthView.js +7 -7
- package/es/PRIVATE_MonthYearGridView.js +7 -7
- package/es/PRIVATE_PlotArea.js +4 -4
- package/es/PRIVATE_RevealToggleIcon.js +16 -16
- package/es/PRIVATE_SelectCommon.js +28 -28
- package/es/PRIVATE_StyledCheckbox.js +15 -15
- package/es/PRIVATE_Table.js +18 -18
- package/es/PRIVATE_ThemedIcons/CalendarIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/ChartMarqueeSelectIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/ChartPanIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/ChartZoomIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/CheckIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/CheckboxMixedIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/CheckboxOffIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/CheckboxOnIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/CloseIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/CollapseIcon.js +16 -16
- package/es/PRIVATE_ThemedIcons/CollapseUpIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/DecrementIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/DeleteIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/DirectionalCollapseArrowIcon.js +16 -16
- package/es/PRIVATE_ThemedIcons/DirectionalExpandArrowIcon.js +16 -16
- package/es/PRIVATE_ThemedIcons/DropdownArrowIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/ExpandIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/HelpIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/IncrementIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/MenuButtonDropdownIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/MessageConfirmationIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/MessageErrorIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/MessageInfoIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/MessageWarningIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/MinusIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/NavDownIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/PlusIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/RadioOffIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/RadioOnIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/SortAscendingIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/SortDefaultIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/SortDescendingIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/ViewHideIcon.js +15 -15
- package/es/PRIVATE_ThemedIcons/ViewIcon.js +15 -15
- package/es/PRIVATE_TimeComponent.js +18 -18
- package/es/PRIVATE_VisTabularDatatip.js +4 -4
- package/es/PictoChart-3dd90503.js +6 -6
- package/es/{PieChart-d4f63bd8.js → PieChart-cdb56906.js} +5 -5
- package/es/{PieChart-d4f63bd8.js.map → PieChart-cdb56906.js.map} +1 -1
- package/es/{Popup-7cc4028b.js → Popup-8becd87a.js} +9 -9
- package/es/{Popup-7cc4028b.js.map → Popup-8becd87a.js.map} +1 -1
- package/es/{ProgressBar-d647bba4.js → ProgressBar-2565d814.js} +3 -3
- package/es/{ProgressBar-d647bba4.js.map → ProgressBar-2565d814.js.map} +1 -1
- package/es/ProgressButton-645ce827.js +3 -3
- package/es/ProgressButtonLabelLayout-6cf150e0.js +3 -3
- package/es/{ProgressCircle-13dc0e4f.js → ProgressCircle-c7f945c0.js} +2 -2
- package/es/{ProgressCircle-13dc0e4f.js.map → ProgressCircle-c7f945c0.js.map} +1 -1
- package/es/ProgressCircleVariants.styles.css +4 -4
- package/es/ProgressCircleVariants.styles2.css +4 -4
- package/es/RadioItem-af1bbece.js +6 -6
- package/es/RatingGauge-82a6a416.js +7 -7
- package/es/RatingGaugeVariants.styles.css +15 -15
- package/es/RatingGaugeVariants.styles2.css +15 -15
- package/es/ReadonlyTextFieldInput-a15badb6.js +1 -1
- package/es/RemovableNavigationListItem-7032ce3e.js +1 -1
- package/es/RemovableTabBarItem-16d04210.js +2 -2
- package/es/ReorderableTabBar-981af0f2.js +2 -2
- package/es/RevealToggleIcon-563c241c.js +1 -1
- package/es/SectionalLegend-a9b719ff.js +4 -4
- package/es/{SectionedContent-7e36073f.js → SectionedContent-237bf539.js} +5 -5
- package/es/{SectionedContent-7e36073f.js.map → SectionedContent-237bf539.js.map} +1 -1
- package/es/SelectMultiple-c1264885.js +8 -8
- package/es/SelectSingle-8336ec24.js +7 -7
- package/es/{SelectionCard-a27bce15.js → SelectionCard-1711aae6.js} +2 -2
- package/es/{SelectionCard-a27bce15.js.map → SelectionCard-1711aae6.js.map} +1 -1
- package/es/Selector-9f40e909.js +1 -1
- package/es/{SelectorAll-40c76f0b.js → SelectorAll-42ce8707.js} +7 -7
- package/es/{SelectorAll-40c76f0b.js.map → SelectorAll-42ce8707.js.map} +1 -1
- package/es/{Sheet-34f3bcb4.js → Sheet-f7117b12.js} +3 -3
- package/es/{Sheet-34f3bcb4.js.map → Sheet-f7117b12.js.map} +1 -1
- package/es/SplitMenuButton-74913bcc.js +3 -3
- package/es/SplitMenuButtonTheme.styles.css +4 -4
- package/es/SplitMenuButtonTheme.styles2.css +4 -4
- package/es/StyledTextField-9df27ab4.js +3 -3
- package/es/Submenu-c6663c1d.js +1 -1
- package/es/TabBar-90cea652.js +6 -6
- package/es/TabBarItem-ba695c75.js +3 -3
- package/es/TabBarLayout-8caaa060.js +1 -1
- package/es/TabBarMixed-52ac388e.js +6 -6
- package/es/{TabBarMixedSeparator-16c88691.js → TabBarMixedSeparator-da56f4c0.js} +2 -2
- package/es/{TabBarMixedSeparator-16c88691.js.map → TabBarMixedSeparator-da56f4c0.js.map} +1 -1
- package/es/Table-3d484e2c.js +8 -8
- package/es/TagCloud-823b3d82.js +9 -9
- package/es/TextArea-6f18b955.js +5 -5
- package/es/TextAreaAutosize-4cf2754b.js +5 -5
- package/es/TextField-d4b4661d.js +3 -3
- package/es/TextFieldInput-84280715.js +1 -1
- package/es/Theme-redwood/theme.css +468 -468
- package/es/Theme-stable/theme.css +405 -405
- package/es/TimeComponentCanvas2D-72f4af98.js +5 -5
- package/es/Toolbar-85379f64.js +1 -1
- package/es/TrainVariants.styles.css +6 -6
- package/es/TrainVariants.styles2.css +6 -6
- package/es/{TruncatingBadge-e5f38bc8.js → TruncatingBadge-7eb77ed3.js} +4 -4
- package/es/{TruncatingBadge-e5f38bc8.js.map → TruncatingBadge-7eb77ed3.js.map} +1 -1
- package/es/{TruncatingText-c3719839.js → TruncatingText-93807530.js} +4 -4
- package/es/{TruncatingText-c3719839.js.map → TruncatingText-93807530.js.map} +1 -1
- package/es/UNSAFE_ActionCard.js +2 -2
- package/es/UNSAFE_Avatar/themes/redwood/AvatarTheme.js +1 -1
- package/es/UNSAFE_Avatar/themes/redwood/AvatarVariants.css.js +1 -1
- package/es/UNSAFE_Avatar/themes/stable/AvatarTheme.js +1 -1
- package/es/UNSAFE_Avatar/themes/stable/AvatarVariants.css.js +1 -1
- package/es/UNSAFE_Avatar.js +1 -1
- package/es/UNSAFE_Badge/themes/redwood/BadgeTheme.js +1 -1
- package/es/UNSAFE_Badge/themes/redwood/BadgeVariants.css.js +1 -1
- package/es/UNSAFE_Badge/themes/stable/BadgeTheme.js +1 -1
- package/es/UNSAFE_Badge/themes/stable/BadgeVariants.css.js +1 -1
- package/es/UNSAFE_Badge.js +1 -1
- package/es/UNSAFE_BarChart/__test__/BarChart.spec.js +30 -30
- package/es/UNSAFE_BarChart.js +30 -30
- package/es/UNSAFE_BaseButton.js +3 -3
- package/es/UNSAFE_Button.js +3 -3
- package/es/UNSAFE_ButtonLayout/tests/ButtonLayout.spec.js +20 -20
- package/es/UNSAFE_ButtonSet.js +4 -4
- package/es/UNSAFE_ButtonSetButton.js +3 -3
- package/es/UNSAFE_ButtonSetIconButton.js +15 -15
- package/es/UNSAFE_ButtonSetItem.js +15 -15
- package/es/UNSAFE_ButtonSetMultiple.js +4 -4
- package/es/UNSAFE_ButtonSetSingle.js +4 -4
- package/es/UNSAFE_CardFlexView.js +20 -20
- package/es/UNSAFE_CardGridView.js +20 -20
- package/es/UNSAFE_Center.js +5 -5
- package/es/UNSAFE_ChartWithLegend.js +4 -4
- package/es/UNSAFE_Checkbox.js +22 -22
- package/es/UNSAFE_CheckboxItem.js +23 -23
- package/es/UNSAFE_CheckboxSet.js +22 -22
- package/es/UNSAFE_Chip.js +2 -2
- package/es/UNSAFE_Collapsible.js +17 -17
- package/es/UNSAFE_ComponentMessage.js +18 -18
- package/es/UNSAFE_ConveyorBelt/themes/redwood/ConveyorBeltTheme.js +1 -1
- package/es/UNSAFE_ConveyorBelt/themes/redwood/ConveyorBeltVariants.css.js +1 -1
- package/es/UNSAFE_ConveyorBelt/themes/stable/ConveyorBeltTheme.js +1 -1
- package/es/UNSAFE_ConveyorBelt/themes/stable/ConveyorBeltVariants.css.js +1 -1
- package/es/UNSAFE_ConveyorBelt.js +16 -16
- package/es/UNSAFE_DatePicker.js +24 -24
- package/es/UNSAFE_Diagram.js +15 -15
- package/es/UNSAFE_Dialog.js +11 -11
- package/es/UNSAFE_DragHandle.js +16 -16
- package/es/UNSAFE_DrawerLayout.js +11 -11
- package/es/UNSAFE_DrawerPopup.js +11 -11
- package/es/UNSAFE_Dropdown.js +12 -12
- package/es/UNSAFE_Environment.js +4 -4
- package/es/UNSAFE_ExpandableList.js +22 -22
- package/es/UNSAFE_FilePicker.js +4 -4
- package/es/UNSAFE_Flex.js +4 -4
- package/es/UNSAFE_Floating.js +10 -10
- package/es/UNSAFE_FormLayout.js +2 -2
- package/es/UNSAFE_Gantt.js +22 -22
- package/es/UNSAFE_Grid.js +4 -4
- package/es/UNSAFE_HighlightText.js +4 -4
- package/es/UNSAFE_Icon.js +15 -15
- package/es/UNSAFE_IconButton.js +15 -15
- package/es/UNSAFE_IconMenuButton.js +19 -19
- package/es/UNSAFE_IconProgressButton.js +20 -20
- package/es/UNSAFE_IconToggleButton.js +15 -15
- package/es/UNSAFE_Indexer.js +6 -6
- package/es/UNSAFE_InputDateMask.js +23 -23
- package/es/UNSAFE_InputDatePicker.js +112 -112
- package/es/UNSAFE_InputPassword.js +22 -22
- package/es/UNSAFE_InputSensitiveText.js +24 -24
- package/es/UNSAFE_InputText.js +25 -25
- package/es/UNSAFE_Label.js +22 -22
- package/es/UNSAFE_LabelValueLayout.js +4 -4
- package/es/UNSAFE_LabelledLink.js +25 -25
- package/es/UNSAFE_Layer.js +7 -7
- package/es/UNSAFE_Legend.js +22 -22
- package/es/UNSAFE_LineAreaChart/__test__/LineChart.spec.js +30 -30
- package/es/UNSAFE_LineAreaChart.js +31 -31
- package/es/UNSAFE_Link/themes/redwood/LinkTheme.js +1 -1
- package/es/UNSAFE_Link/themes/redwood/LinkVariants.css.js +1 -1
- package/es/UNSAFE_Link/themes/stable/LinkTheme.js +1 -1
- package/es/UNSAFE_Link/themes/stable/LinkVariants.css.js +1 -1
- package/es/UNSAFE_Link.js +3 -3
- package/es/UNSAFE_ListItemLayout.js +5 -5
- package/es/UNSAFE_ListView.js +25 -25
- package/es/UNSAFE_LiveRegion.js +4 -4
- package/es/UNSAFE_Menu.js +21 -21
- package/es/UNSAFE_MenuButton.js +19 -19
- package/es/UNSAFE_MessageBanner.js +18 -18
- package/es/UNSAFE_MessageToast.js +21 -21
- package/es/UNSAFE_MeterBar/themes/redwood/MeterBarTheme.js +1 -1
- package/es/UNSAFE_MeterBar/themes/redwood/MeterBarVariants.css.js +1 -1
- package/es/UNSAFE_MeterBar/themes/stable/MeterBarTheme.js +1 -1
- package/es/UNSAFE_MeterBar/themes/stable/MeterBarVariants.css.js +1 -1
- package/es/UNSAFE_MeterBar.js +17 -17
- package/es/UNSAFE_MeterCircle.js +16 -16
- package/es/UNSAFE_Modal.js +7 -7
- package/es/UNSAFE_NavigationList.js +20 -20
- package/es/UNSAFE_NavigationListCommon.js +18 -18
- package/es/UNSAFE_NumberInputText.js +24 -24
- package/es/UNSAFE_OverflowTabBar.js +25 -25
- package/es/UNSAFE_PictoChart.js +13 -13
- package/es/UNSAFE_PieChart/__test__/PieChart.spec.js +14 -14
- package/es/UNSAFE_PieChart.js +14 -14
- package/es/UNSAFE_Popup.js +15 -15
- package/es/UNSAFE_ProgressBar.js +5 -5
- package/es/UNSAFE_ProgressButton.js +20 -20
- package/es/UNSAFE_ProgressButtonLabelLayout.js +11 -11
- package/es/UNSAFE_ProgressCircle/themes/redwood/ProgressCircleTheme.js +1 -1
- package/es/UNSAFE_ProgressCircle/themes/redwood/ProgressCircleVariants.css.js +1 -1
- package/es/UNSAFE_ProgressCircle/themes/stable/ProgressCircleTheme.js +1 -1
- package/es/UNSAFE_ProgressCircle/themes/stable/ProgressCircleVariants.css.js +1 -1
- package/es/UNSAFE_ProgressCircle.js +5 -5
- package/es/UNSAFE_RadioItem.js +22 -22
- package/es/UNSAFE_RadioSet.js +22 -22
- package/es/UNSAFE_RatingGauge/themes/redwood/RatingGaugeTheme.js +1 -1
- package/es/UNSAFE_RatingGauge/themes/redwood/RatingGaugeVariants.css.js +1 -1
- package/es/UNSAFE_RatingGauge/themes/stable/RatingGaugeTheme.js +1 -1
- package/es/UNSAFE_RatingGauge/themes/stable/RatingGaugeVariants.css.js +1 -1
- package/es/UNSAFE_RatingGauge.js +17 -17
- package/es/UNSAFE_ReorderableTabBar.js +21 -21
- package/es/UNSAFE_SectionalLegend.js +23 -23
- package/es/UNSAFE_SelectMultiple.js +31 -31
- package/es/UNSAFE_SelectSingle.js +31 -31
- package/es/UNSAFE_SelectionCard.js +4 -4
- package/es/UNSAFE_Selector.js +15 -15
- package/es/UNSAFE_SelectorAll.js +19 -19
- package/es/UNSAFE_Sheet/__test__/Sheet.spec.js +13 -13
- package/es/UNSAFE_Sheet.js +10 -10
- package/es/UNSAFE_SplitMenuButton/themes/redwood/SplitMenuButtonTheme.css.js +1 -1
- package/es/UNSAFE_SplitMenuButton/themes/stable/SplitMenuButtonTheme.css.js +1 -1
- package/es/UNSAFE_SplitMenuButton.js +20 -20
- package/es/UNSAFE_TabBar.js +26 -26
- package/es/UNSAFE_TabBarCommon.js +25 -25
- package/es/UNSAFE_TabBarMixed.js +29 -29
- package/es/UNSAFE_TableView.js +18 -18
- package/es/UNSAFE_TagCloud.js +22 -22
- package/es/UNSAFE_TextArea.js +24 -24
- package/es/UNSAFE_TextAreaAutosize.js +24 -24
- package/es/UNSAFE_TextField.js +7 -7
- package/es/UNSAFE_ToggleButton.js +3 -3
- package/es/UNSAFE_Toolbar/tests/Toolbar.spec.js +22 -22
- package/es/UNSAFE_Toolbar.js +4 -4
- package/es/UNSAFE_Train/themes/redwood/TrainTheme.js +1 -1
- package/es/UNSAFE_Train/themes/redwood/TrainVariants.css.js +1 -1
- package/es/UNSAFE_Train/themes/stable/TrainTheme.js +1 -1
- package/es/UNSAFE_Train/themes/stable/TrainVariants.css.js +1 -1
- package/es/UNSAFE_Train.js +17 -17
- package/es/UNSAFE_TruncatingBadge.js +18 -18
- package/es/UNSAFE_TruncatingText.js +17 -17
- package/es/UNSAFE_UserAssistance.js +23 -23
- package/es/UNSAFE_View.js +7 -7
- package/es/UNSAFE_VirtualizedListView.js +19 -19
- package/es/UNSAFE_VisProgressiveLoader/__test__/VisProgressiveLoader.spec.js +8 -8
- package/es/UNSAFE_VisProgressiveLoader.js +6 -6
- package/es/UNSAFE_VisStatusMessage.js +6 -6
- package/es/UNSAFE_WindowOverlay.js +4 -4
- package/es/{View-a8a64eb1.js → View-63980a9b.js} +5 -5
- package/es/{View-a8a64eb1.js.map → View-63980a9b.js.map} +1 -1
- package/es/{VisNoData-673b58e9.js → VisNoData-da540cbd.js} +3 -3
- package/es/{VisNoData-673b58e9.js.map → VisNoData-da540cbd.js.map} +1 -1
- package/es/{VisProgressiveLoader-66dde1ff.js → VisProgressiveLoader-2b2103c8.js} +3 -3
- package/es/{VisProgressiveLoader-66dde1ff.js.map → VisProgressiveLoader-2b2103c8.js.map} +1 -1
- package/es/{VisTabularDatatip-6aa607bb.js → VisTabularDatatip-2ae7ee48.js} +2 -2
- package/es/{VisTabularDatatip-6aa607bb.js.map → VisTabularDatatip-2ae7ee48.js.map} +1 -1
- package/es/{WindowOverlay-de5d0819.js → WindowOverlay-9b43e658.js} +2 -2
- package/es/{WindowOverlay-de5d0819.js.map → WindowOverlay-9b43e658.js.map} +1 -1
- package/es/{YearsGridView-5b5c1746.js → YearsGridView-37dfce0c.js} +4 -4
- package/es/{YearsGridView-5b5c1746.js.map → YearsGridView-37dfce0c.js.map} +1 -1
- package/es/hoc/PRIVATE_withDirectionIcon.js +4 -4
- package/es/hoc/PRIVATE_withThemeIcon.js +3 -3
- package/es/hoc/UNSAFE_withThemeProps.js +3 -3
- package/es/hooks/PRIVATE_useChartContextMenu.js +18 -18
- package/es/hooks/PRIVATE_useChartDatatip.js +13 -13
- package/es/hooks/PRIVATE_useChartEvents.js +17 -17
- package/es/hooks/PRIVATE_useChartMarquee.js +17 -17
- package/es/hooks/PRIVATE_useCssVars.js +7 -7
- package/es/hooks/PRIVATE_useCurrentKey.js +4 -4
- package/es/hooks/PRIVATE_useDatatip.js +11 -11
- package/es/hooks/PRIVATE_useFloating.js +4 -4
- package/es/hooks/PRIVATE_useReorderable.js +4 -4
- package/es/hooks/PRIVATE_useRovingTabIndexContainer.js +4 -4
- package/es/hooks/PRIVATE_useSelection.js +4 -4
- package/es/hooks/PRIVATE_useTabBar.js +5 -5
- package/es/hooks/PRIVATE_useVisContextMenu.js +18 -18
- package/es/hooks/PRIVATE_useVisEvents.js +4 -4
- package/es/hooks/PRIVATE_useVisMeterEvents.js +13 -13
- package/es/hooks/PRIVATE_useVisSelection.js +12 -12
- package/es/hooks/UNSAFE_useColorScheme.js +3 -3
- package/es/hooks/UNSAFE_useCurrentBgColor.js +3 -3
- package/es/hooks/UNSAFE_useDensity.js +3 -3
- package/es/hooks/UNSAFE_useOutsideClick.js +7 -7
- package/es/hooks/UNSAFE_usePrefixSuffix.js +4 -4
- package/es/hooks/UNSAFE_useScale.js +3 -3
- package/es/hooks/UNSAFE_useSwipe.js +1 -1
- package/es/hooks/UNSAFE_useTestId.js +3 -3
- package/es/hooks/UNSAFE_useTheme.js +3 -3
- package/es/hooks/UNSAFE_useThemeInterpolations.js +5 -5
- package/es/hooks/UNSAFE_useTooltip.js +16 -16
- package/es/hooks/UNSAFE_useTranslationBundle.js +3 -3
- package/es/hooks/UNSAFE_useUser.js +3 -3
- package/es/{index-fee93bf9.js → index-e65c9009.js} +2 -2
- package/es/index-e65c9009.js.map +1 -0
- package/es/listViewSelectionTests-0dfdcc5d.js +4 -4
- package/es/{render-d92a7051.js → render-ff141a3d.js} +3 -3
- package/es/{render-d92a7051.js.map → render-ff141a3d.js.map} +1 -1
- package/es/{tabbableUtils-1b4c2eea.js → tabbableUtils-375a33ee.js} +3 -3
- package/es/{tabbableUtils-1b4c2eea.js.map → tabbableUtils-375a33ee.js.map} +1 -1
- package/es/{testData-ca9503e6.js → testData-748c19ef.js} +3 -3
- package/es/{testData-ca9503e6.js.map → testData-748c19ef.js.map} +1 -1
- package/es/{tooltipUtils-06c93436.js → tooltipUtils-1131b3ca.js} +5 -5
- package/es/{tooltipUtils-06c93436.js.map → tooltipUtils-1131b3ca.js.map} +1 -1
- package/es/useCellNavigation-00d575ca.js +1 -1
- package/es/useChartContextMenu-8c49f584.js +3 -3
- package/es/{useChartDatatip-82dba484.js → useChartDatatip-25f6bc69.js} +4 -4
- package/es/{useChartDatatip-82dba484.js.map → useChartDatatip-25f6bc69.js.map} +1 -1
- package/es/useChartMarquee-08025a83.js +1 -1
- package/es/{useColorScheme-f69d53b5.js → useColorScheme-d8a80e2b.js} +2 -2
- package/es/{useColorScheme-f69d53b5.js.map → useColorScheme-d8a80e2b.js.map} +1 -1
- package/es/useContextMenu-12845847.js +3 -3
- package/es/{useCssVars-48595cd2.js → useCssVars-8e6932f8.js} +5 -5
- package/es/{useCssVars-48595cd2.js.map → useCssVars-8e6932f8.js.map} +1 -1
- package/es/{useCurrentBgColor-894d059b.js → useCurrentBgColor-5418492b.js} +2 -2
- package/es/{useCurrentBgColor-894d059b.js.map → useCurrentBgColor-5418492b.js.map} +1 -1
- package/es/{useCurrentKey-55123e83.js → useCurrentKey-76e7d7b1.js} +2 -2
- package/es/{useCurrentKey-55123e83.js.map → useCurrentKey-76e7d7b1.js.map} +1 -1
- package/es/{useDatatip-01d7ddeb.js → useDatatip-73566627.js} +4 -4
- package/es/{useDatatip-01d7ddeb.js.map → useDatatip-73566627.js.map} +1 -1
- package/es/{useDensity-04a01caf.js → useDensity-64ecb649.js} +2 -2
- package/es/{useDensity-04a01caf.js.map → useDensity-64ecb649.js.map} +1 -1
- package/es/{useFloating-c9278755.js → useFloating-d60cc8b4.js} +2 -2
- package/es/{useFloating-c9278755.js.map → useFloating-d60cc8b4.js.map} +1 -1
- package/es/{useKeyboardEvents-b02e5fda.js → useKeyboardEvents-5c311766.js} +2 -2
- package/es/{useKeyboardEvents-b02e5fda.js.map → useKeyboardEvents-5c311766.js.map} +1 -1
- package/es/useLegendContextMenu-926aca66.js +5 -5
- package/es/{useMeterDatatip-43e31c05.js → useMeterDatatip-2cedbd5c.js} +3 -3
- package/es/{useMeterDatatip-43e31c05.js.map → useMeterDatatip-2cedbd5c.js.map} +1 -1
- package/es/{useOutsideClick-388c62bd.js → useOutsideClick-725542a2.js} +2 -2
- package/es/{useOutsideClick-388c62bd.js.map → useOutsideClick-725542a2.js.map} +1 -1
- package/es/{usePopupAnimation-b4577940.js → usePopupAnimation-340f04b6.js} +2 -2
- package/es/{usePopupAnimation-b4577940.js.map → usePopupAnimation-340f04b6.js.map} +1 -1
- package/es/{usePrefixSuffix-995d4cda.js → usePrefixSuffix-435a9c59.js} +2 -2
- package/es/{usePrefixSuffix-995d4cda.js.map → usePrefixSuffix-435a9c59.js.map} +1 -1
- package/es/useReorderableItem-c715c504.js +2 -2
- package/es/{useRovingTabIndexContainer-097f96a6.js → useRovingTabIndexContainer-b9833086.js} +2 -2
- package/es/{useRovingTabIndexContainer-097f96a6.js.map → useRovingTabIndexContainer-b9833086.js.map} +1 -1
- package/es/{useScale-3b323ab2.js → useScale-c86ecc6e.js} +2 -2
- package/es/{useScale-3b323ab2.js.map → useScale-c86ecc6e.js.map} +1 -1
- package/es/useSelectCommon-7ebc86eb.js +11 -11
- package/es/{useSelectDrill-8b53d932.js → useSelectDrill-fbe57d95.js} +3 -3
- package/es/{useSelectDrill-8b53d932.js.map → useSelectDrill-fbe57d95.js.map} +1 -1
- package/es/{useSelection-7c94a24f.js → useSelection-1e1e89df.js} +2 -2
- package/es/{useSelection-7c94a24f.js.map → useSelection-1e1e89df.js.map} +1 -1
- package/es/{useSelection-b7c3e75e.js → useSelection-dfbd140d.js} +5 -5
- package/es/{useSelection-b7c3e75e.js.map → useSelection-dfbd140d.js.map} +1 -1
- package/es/{useSwipe-818b0c1c.js → useSwipe-b5c1b9ad.js} +15 -15
- package/es/{useSwipe-818b0c1c.js.map → useSwipe-b5c1b9ad.js.map} +1 -1
- package/es/{useTabBar-6c6847ef.js → useTabBar-b826570d.js} +2 -2
- package/es/{useTabBar-6c6847ef.js.map → useTabBar-b826570d.js.map} +1 -1
- package/es/{useTestId-af32a9eb.js → useTestId-3bc3958c.js} +2 -2
- package/es/{useTestId-af32a9eb.js.map → useTestId-3bc3958c.js.map} +1 -1
- package/es/{useTheme-73aca0e4.js → useTheme-4b0f211c.js} +2 -2
- package/es/{useTheme-73aca0e4.js.map → useTheme-4b0f211c.js.map} +1 -1
- package/es/{useThemeInterpolations-4f6cc83c.js → useThemeInterpolations-41ac870d.js} +4 -4
- package/es/{useThemeInterpolations-4f6cc83c.js.map → useThemeInterpolations-41ac870d.js.map} +1 -1
- package/es/{useTooltip-e258ea41.js → useTooltip-227887ea.js} +2 -2
- package/es/{useTooltip-e258ea41.js.map → useTooltip-227887ea.js.map} +1 -1
- package/es/{useTooltipControlled-50d5dac9.js → useTooltipControlled-7ccb5919.js} +5 -5
- package/es/{useTooltipControlled-50d5dac9.js.map → useTooltipControlled-7ccb5919.js.map} +1 -1
- package/es/{useTranslationBundle-6da03e52.js → useTranslationBundle-98df6291.js} +2 -2
- package/es/{useTranslationBundle-6da03e52.js.map → useTranslationBundle-98df6291.js.map} +1 -1
- package/es/{useUser-bca8cf2d.js → useUser-a15426fc.js} +2 -2
- package/es/{useUser-bca8cf2d.js.map → useUser-a15426fc.js.map} +1 -1
- package/es/{useVisEvents-cd3616aa.js → useVisEvents-ff4204b5.js} +2 -2
- package/es/{useVisEvents-cd3616aa.js.map → useVisEvents-ff4204b5.js.map} +1 -1
- package/es/utils/PRIVATE_tooltipUtils.js +13 -13
- package/es/utils/PRIVATE_visTestUtils.js +6 -6
- package/es/{withDirectionIcon-389870a2.js → withDirectionIcon-90d7c798.js} +2 -2
- package/es/{withDirectionIcon-389870a2.js.map → withDirectionIcon-90d7c798.js.map} +1 -1
- package/es/withThemeProps-6545df54.js +2 -2
- package/package.json +2 -2
- package/amd/MaxLengthCounter-caafceef.js +0 -2
- package/amd/MaxLengthCounter-caafceef.js.map +0 -1
- package/amd/TextArea-259d741c.js +0 -2
- package/amd/TextArea-259d741c.js.map +0 -1
- package/amd/TextAreaAutosize-e8dc13b4.js +0 -2
- package/amd/useSwipe-9600cd2e.js +0 -2
- package/cjs/MaxLengthCounter-a5370f66.js +0 -27
- package/cjs/MaxLengthCounter-a5370f66.js.map +0 -1
- package/cjs/TextArea-096f18ad.js.map +0 -1
- package/es/index-fee93bf9.js.map +0 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define(['exports', 'preact/jsx-runtime', './useUser-85c781ea', 'preact', './PRIVATE_Chart/themes/ChartStyles.css', './classNames-08d99695', './layoutUtils-ac40a238', './useTranslationBundle-516b1b83', './dataStyleUtils-012386a4', './accUtils-1557920a', './colorUtils-7c069766', './Chart-
|
|
2
|
-
//# sourceMappingURL=BarChart-
|
|
1
|
+
define(['exports', 'preact/jsx-runtime', './useUser-85c781ea', 'preact', './PRIVATE_Chart/themes/ChartStyles.css', './classNames-08d99695', './layoutUtils-ac40a238', './useTranslationBundle-516b1b83', './dataStyleUtils-012386a4', './accUtils-1557920a', './colorUtils-7c069766', './Chart-96ea9fed'], (function(e,t,i,s,r,n,o,a,l,d,u,c){"use strict";const g=2,h=.25;function x(e,t,i,s,r,n,o){const a=n?1:s,l=g*r,d=(t*(1-i)-(a-1)*l)/a;if(n)return{barWidth:d,offset:-1*d/2,itemsGaps:l};const u=t/2,c=t*(i/2)+e*(d+g*r);return{barWidth:d,offset:o?u-c-d:c-u,itemsGaps:l}}const f=1.5,I=2.5;function m(e){return e.isSelected||e.isFocused?t.jsx(p,{...e}):t.jsx("rect",{x:e.x,y:e.y,"data-oj-series-index":e.seriesIndex,"data-oj-group-index":e.groupIndex,"data-oj-object":"bar","aria-label":e["aria-label"],role:e["aria-label"]?"img":void 0,id:e.activeId,style:{width:e.width,height:e.height,fill:e.fill,stroke:e.stroke,strokeWidth:e.strokeWidth},class:n.classNames([e.isPointerEnabled?r.styles.cursorEnable:void 0,e.isDimmed?r.styles.dimmed:void 0])})}function p(e){const{x:i,y:s,width:o,height:a,fill:l,isSelected:d,isFocused:u}=e,c=d?I:f;return t.jsxs("g",{id:e.activeId,"data-oj-object":"bar","data-oj-series-index":e.seriesIndex,"data-oj-group-index":e.groupIndex,className:e.isDimmed?r.styles.dimmed:"",role:e["aria-label"]?"img":void 0,"aria-label":e["aria-label"],children:[t.jsx("rect",{x:i,y:s,class:n.classNames([d?r.styles.selectedBorder:""]),style:{width:o,height:a,fill:!d&&u?l:void 0}}),t.jsx("rect",{x:i+c,y:s+c,class:n.classNames([r.styles.contrastBorder,e.isPointerEnabled?r.styles.cursorEnable:void 0]),style:{width:o-2*c,height:a-2*c,fill:l}})]})}function b(e,t,i){return{fill:e.color||t.color||i,stroke:e.borderColor||t.borderColor}}function y(e,t,i,s,r){let n,o,a,l,d=e,u=t,c=t-e;return c<1&&(d=Math.floor(d),u=d+1,c=1),r?(o=d,n=i>s?s:i,a=Math.abs(s-i),l=Math.abs(u-d)):(n=d,o=i>s?s:i,a=Math.abs(u-d),l=Math.abs(s-i)),{x:n,y:o,width:a,height:l}}function S(e,t,i,s,r,n,o){let a,l;return i?(a=t.transform(e<0?n:o),n+=e<0?e:0,o+=e>0?e:0,l=t.transform(e<0?n:o),a+=l>a?r:-r):(a=s?t.range()[0]:t.transform(0),l=t.transform(e)),{baselineCoord:a,endCoord:l}}function v(e,t,i,s,r,n,o){const{baselineCoord:a,endCoord:l}=S(e,t,i,s,r,n,o);return(a+l)/2}const w=2;function D(e,t,i,s,r,n){if(!n)return{};const o=function(e,t,i,s){return e?i&&!t||!i&&t?s.x:s.x+s.width:i?s.height+s.y:s.y}(e,t,i,s);return"insideBarEdge"===r?{y:e?s.y+s.height/2:o+(i?-1:1)*(n.height/2+w+2),x:e?o-(i&&!t||!i&&t?-1:1)*(n.width/2+w):s.x+s.width/2}:"outsideBarEdge"===r?{y:e?s.y+s.height/2:o-(i?-1:1)*(n.height/2+w),x:e?o+(i&&!t||!i&&t?-1:1)*(n.width/2+w):s.x+s.width/2}:{x:s.x+s.width/2,y:s.y+s.height/2}}const j=(e,t,i,s,r,n)=>({y:s?e:t-(i?-1:1)*(n.height/2+w),x:s?t+(i&&!r||!i&&r?-1:1)*(n.width/2+w):e});function C({groupCenter:e,getStackLabel:i,group:s,posValue:n,negValue:o,posItemsData:a,yScale:l,isHoriz:d,isRtl:u,negItemsData:c,defaultFontSize:g,labelStyle:h,getTextDimensions:x}){const f=i({group:s,value:n,data:a}),I={fontSize:g,fontWeight:"bold",...h},m=o<0?i?.({group:s,value:o,data:c}):"",p=j(e,l.transform(n),!1,d,u,x(f,I)),b=j(e,l.transform(o),!0,d,u,x(m,I));return t.jsxs(t.Fragment,{children:[t.jsx("text",{class:r.styles.stackLabelStyle,style:I,...p,children:f}),t.jsx("text",{class:r.styles.stackLabelStyle,style:I,...b,children:m})]})}function k({item:e,seriesColor:i,isStacked:s,defaultFontSize:n,barDim:o,isRtl:a,isHoriz:l,getTextDimensions:d}){let c=null;const g=!e.labelPosition||"outsideBarEdge"===e.labelPosition&&s?"center":e.labelPosition,h=e.label,x=e.color||i;if("none"!=g&&h&&d&&(!s||"outsideBarEdge"!==g)){const i={fontSize:n,fill:s||!("outsideBarEdge"===g)?u.getContrastingTextColor(x):void 0,...e.labelStyle},f=function(e,t,i,s){return e?!(t.height>i.height)&&("outsideBarEdge"==s||t.width<i.width):!(t.width>i.width)&&("outsideBarEdge"==s||t.height<i.height)}(l,d(h,i),o,g||"center");c=f?t.jsx("text",{class:r.styles.dataLabelStyle,style:i,...D(l,a,e.value<0,o,g||"center",d?.(h,i)),children:h}):null}return c}function F({yScale:e,xScale:i,colors:r,series:n,groupIndex:u,hiddenIds:c,barGapRatio:g,dataItemGaps:h,groupWidth:f,highlightedIds:I,selectedIds:p,isPointInsideMarquee:v,orientation:w,isLog:D,activeId:j,getDataItem:F,isRtl:A,isStacked:E,isSelectionEnabled:T,focusedItemInfo:G,hoveredItemInfo:P,isDrillEnabled:z,group:B,timeAxisType:L,getTextDimensions:R,defaultFontSize:M,stacklabelStyle:N,getStackLabel:W}){const q="horizontal"===w,U=[],V=n.length;let H=D?e.domain()[0]:0,$=0;const _=[],J=[],K=a.useTranslationBundle("@oracle/oraclejet-preact"),O=E&&!!W&&"mixedFrequency"!=L;let Q="mixedFrequency"!=L?i.transform(null!=L?new Date(B.id).getTime():u):void 0;for(let a=0;a<V;a+=1){const w=F(a,u);if(!w||c?.has(w.id)||D&&w.value<=0)continue;"mixedFrequency"===L&&(Q=o.getMixedFreqGroupCenter(i,w));const C=G?.groupIndex===u&&G?.seriesIndex===a&&G?.isFocusVisible,N=P?.groupIndex===u&&P?.seriesIndex===a&&P?.isCurrent,W=!!C||!!N&&T,X=C&&G.isCurrent||N,Y=void 0===I||I.has(w.id),Z="on"===w.drilling||"off"!=w.drilling&&z,{barWidth:ee,offset:te,itemsGaps:ie}=x(a,f,g,V,h,E,A),se=Q+te,re=se+ee,{baselineCoord:ne,endCoord:oe}=S(w.value,e,E,D,ie,$,H);$+=w.value<0?w.value:0,H+=w.value>0?w.value:0,O&&(w.value>=0?_.push(w):J.push(w));const ae=b(w,n[a],r?.[a]),le=y(se,re,oe,ne,q),de=v?v?.(w.id,{x:le.x+le.width/2,y:le.y}):p?.has(w.id),ue=d.supportsMobileScreenReader||X?l.getItemAriaLabel(K,n[a].name||n[a].id.toString(),B.name||B.id,w.value,T,!!de,Z,w.accessibleLabel):"";U.push(t.jsxs(t.Fragment,{children:[s.createElement(m,{...le,...ae,seriesIndex:a,groupIndex:u,isFocused:W,activeId:X?j:"","aria-label":ue,isDimmed:!Y,isSelected:!!de,isPointerEnabled:Z||T,key:`${u};${a}`}),t.jsx(k,{item:w,isRtl:A,seriesColor:r[a%12],isStacked:E,defaultFontSize:M,barDim:le,isHoriz:q,getTextDimensions:R})]}))}return t.jsxs(t.Fragment,{children:[U,O&&R&&t.jsx(C,{group:B,isRtl:A,yScale:e,getStackLabel:W,defaultFontSize:M,getTextDimensions:R,posItemsData:_,negItemsData:J,isHoriz:q,groupCenter:Q,labelStyle:N,posValue:H,negValue:$})]})}function A(e,t,i,s){const r=l.getNextItemInGroup(e,i,s);if(r)return r;if(e.groupIndex<t){let r={seriesIndex:0,groupIndex:e.groupIndex+1};if(s(r.seriesIndex,r.groupIndex))return r;if(r=A(r,t,i,s),r)return r}return e}function E(e,t,i,s){const r=l.getPrevItemInGroup(e,s);if(r)return r;if(e.groupIndex>t){let r={groupIndex:e.groupIndex-1,seriesIndex:i-1};if(s(r.seriesIndex,r.groupIndex))return r;if(r=E(r,t,i,s),r)return r}return e}e.BarChart=function({width:e,height:s,selectedIds:r=[],hiddenIds:n=[],highlightedIds:a,hideAndShowBehavior:d="none",orientation:u="vertical",yAxis:g,series:f,groups:I,isStacked:m=!1,getDataItem:p,selectionMode:b="none",drilling:w="off",dataItemGaps:D=.5,...j}){const{direction:C}=i.useUser(),k="rtl"===C,T=new Set(n),G="horizontal"===u,P=j.xAxis?.timeAxisType,z=new Set(r),B=new Set(a);return t.jsx(c.Chart,{width:e,height:s,selectedIds:z,hiddenIds:n,hideAndShowBehavior:d,orientation:u,yAxis:g,series:f,groups:I,isStacked:m,getDataItem:p,selectionMode:b,drilling:w,renderGridLinesInFront:!1,findNearest:(e,t,i,s)=>{const r=function(e,t,i,s,r,n){return o=>{const{offset:a,barWidth:l}=x(o,e,t,i,s,r,n);return{offset:a,dataWidth:l}}}(i,s,f.length,D,m,k);return o.findNearestDataPoint(f,I,e,t,p,m,r,v,"log"===g?.scale,D,T,P)},getDataItemPos:(e,t,i,s)=>function(e,t,i,s,r,n,o,a,l,d,u,c,g,h){return(f,I)=>{const m=e.length;let p=0,b=0;for(let e=0;e<m;e+=1){const v=i(e,I);let w=I;if(h){const e="mixedFrequency"===h?i(f,I)?.x:t[I].id;w=new Date(e).getTime()}if(!v||n?.has(v.id)||d&&v.value<=0)continue;const D=s.transform(w),{barWidth:j,offset:C,itemsGaps:k}=x(e,a,l,m,o,u,c),F=D+C,A=F+j,{baselineCoord:E,endCoord:T}=S(v.value,r,u,d,k,b,p);if(b+=v.value<0?v.value:0,p+=v.value>0?v.value:0,f===e)return y(F,A,T,E,g)}}}(f,I,p,e,t,T,D,i,s,"log"===g?.scale,m,k,G,P),getNavUtil:(e,t)=>function(e,t,i,s,r,n){const o=(t,i)=>{const s=e(t,i);return Boolean(s)};return(e,a)=>{if(!r&&("ArrowDown"===a||"ArrowUp"===a))return e;let d;const u={groupIndex:e.groupIndex,seriesIndex:e.seriesIndex};return u.groupIndex<i?(u.groupIndex=i,u):u.groupIndex>s?(u.groupIndex=s,u):(r?d="ArrowLeft"===a?n?l.getNextItemInSeries(u,s,o):l.getPrevItemInSeries(u,i,o):"ArrowRight"===a?n?l.getPrevItemInSeries(u,i,o):l.getNextItemInSeries(u,s,o):"ArrowDown"===a?l.getPrevItemInGroup(u,o):l.getNextItemInGroup(u,t,o):"ArrowRight"===a?d=n?E(u,i,t,o):A(u,s,t,o):"ArrowLeft"===a&&(d=n?A(u,s,t,o):E(u,i,t,o)),d||u)}}(p,f.length,e,t,m,k),getGapRatio:(e,t)=>function(e,t,i){return e?.37+.26/(i-t+1):h}(m,e,t),getMarkerInfo:(e,t)=>({color:l.getItemColor(e,t,f,p),type:l.getMarkerType(e,t,"bar",p)}),isRtl:k,offset:.5,...j,children:({xStartIndex:e,xEndIndex:i,xScale:s,yScale:r,gapRatio:n,activeId:o,focusedItemInfo:l,hoveredItemInfo:d,groupWidth:c,isPointInsideMarquee:h,getTextDimensions:x,defaultFontSize:y,colors:S})=>t.jsx(t.Fragment,{children:I.slice(e,i+1).map(((i,v)=>t.jsx(F,{yScale:r,xScale:s,groupIndex:v+e,selectedIds:z,hiddenIds:T,highlightedIds:a?B:a,isDrillEnabled:"on"===w,series:f,barGapRatio:n,dataItemGaps:D,isPointInsideMarquee:h,isStacked:m,groupWidth:c,group:I[v],timeAxisType:j.xAxis?.timeAxisType,colors:S,activeId:o,isLog:"log"===g?.scale,orientation:u,getDataItem:p,isSelectionEnabled:"none"!=b,isRtl:k,focusedItemInfo:l,hoveredItemInfo:d,getTextDimensions:x,defaultFontSize:y,getStackLabel:j.getStackLabel})))})})}}));
|
|
2
|
+
//# sourceMappingURL=BarChart-b75423c1.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BarChart-aba4a793.js","sources":["../../src/UNSAFE_BarChart/utils/barSeriesUtils.ts","../../src/UNSAFE_BarChart/Bar.tsx","../../src/UNSAFE_BarChart/utils/barItemUtils.ts","../../src/UNSAFE_BarChart/utils/barLayoutUtils.ts","../../src/UNSAFE_BarChart/utils/barItemLabelUtils.ts","../../src/UNSAFE_BarChart/BarChartStackLabel.tsx","../../src/UNSAFE_BarChart/BarLabel.tsx","../../src/UNSAFE_BarChart/BarGroup.tsx","../../src/UNSAFE_BarChart/utils/barNavUtils.ts","../../src/UNSAFE_BarChart/BarChart.tsx"],"sourcesContent":["/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nconst IDEAL_DATA_ITEM_GAP = 2;\nconst DEFAULT_BAR_GAP_RATIO = 0.25;\n\n/**\n * The function that calculates the barWidth and offset from group center for each series.\n * @param groupWidth The width of the group.\n * @param noOfSeries The number of series present in the chart.\n * @param barGapRatio The ratio of gap to groupWidth.\n * @param dataItemGaps The ratio that determines the gap between the bars.\n */\nexport function getBarGapsInfo(\n seriesIndex: number,\n groupWidth: number,\n barGapRatio: number,\n numOfSeries: number,\n dataItemGaps: number,\n isStacked: boolean,\n isRtl: boolean\n) {\n const numSeries = isStacked ? 1 : numOfSeries;\n const itemsGaps = IDEAL_DATA_ITEM_GAP * dataItemGaps;\n const barWidth = (groupWidth * (1 - barGapRatio) - (numSeries - 1) * itemsGaps) / numSeries;\n if (isStacked) {\n return { barWidth, offset: (-1 * barWidth) / 2, itemsGaps };\n }\n const center = groupWidth / 2;\n const seriesStart =\n groupWidth * (barGapRatio / 2) + seriesIndex * (barWidth + IDEAL_DATA_ITEM_GAP * dataItemGaps);\n const offset = isRtl ? center - seriesStart - barWidth : seriesStart - center;\n\n return { barWidth, offset, itemsGaps };\n}\n\n/**\n * Returns the bar gap ratio.\n * @param isStacked Whether the chart is a stacked bar chart.\n * @param startIndex The viewport start index.\n * @param endIndex The viewport end index.\n */\nexport function getBarGapRatio(isStacked: boolean, startIndex: number, endIndex: number) {\n const noOfGroups = endIndex - startIndex + 1;\n // logic from legacy\n return isStacked ? 0.37 + 0.26 / noOfGroups : DEFAULT_BAR_GAP_RATIO;\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { styles } from '../PRIVATE_Chart/themes/ChartStyles.css';\nimport { ColorProps } from '../utils/UNSAFE_interpolations/colors';\nimport { classNames } from '../utils/UNSAFE_classNames';\n\ntype BarProps = {\n x: number;\n y: number;\n width: number;\n height: number;\n isSelected: boolean;\n isFocused: boolean;\n isDimmed: boolean;\n activeId?: string;\n isPointerEnabled: boolean;\n fill: ColorProps['color'];\n stroke?: ColorProps['color'];\n strokeWidth?: number;\n seriesIndex: number;\n groupIndex: number;\n 'aria-label'?: string;\n};\n\nconst HOVERED_INNER_INSET = 1.5;\nconst SELECTED_INNER_INSET = 2.5;\n\n/**\n * The rect representing the bar item.\n * @param props\n * @returns\n */\nexport function Bar(props: BarProps) {\n const isInteractive = props.isSelected || props.isFocused;\n\n if (isInteractive) {\n return <InteractiveBar {...props} />;\n }\n\n return (\n <rect\n x={props.x}\n y={props.y}\n data-oj-series-index={props.seriesIndex}\n data-oj-group-index={props.groupIndex}\n data-oj-object=\"bar\"\n aria-label={props['aria-label']}\n role={props['aria-label'] ? 'img' : undefined}\n id={props.activeId}\n style={{\n width: props.width,\n height: props.height,\n fill: props.fill,\n stroke: props.stroke,\n strokeWidth: props.strokeWidth\n }}\n class={classNames([\n props.isPointerEnabled ? styles.cursorEnable : undefined,\n props.isDimmed ? styles.dimmed : undefined\n ])}\n />\n );\n}\n\n/**\n * The selected or hovered selected bar.\n */\nexport function InteractiveBar(props: BarProps) {\n const { x, y, width, height, fill, isSelected, isFocused } = props;\n const inset = isSelected ? SELECTED_INNER_INSET : HOVERED_INNER_INSET;\n return (\n <g\n id={props.activeId}\n data-oj-object=\"bar\"\n data-oj-series-index={props.seriesIndex}\n data-oj-group-index={props.groupIndex}\n className={props.isDimmed ? styles.dimmed : ''}\n role={props['aria-label'] ? 'img' : undefined}\n aria-label={props['aria-label']}>\n <rect\n x={x}\n y={y}\n class={classNames([isSelected ? styles.selectedBorder : ''])}\n style={{\n width: width,\n height: height,\n fill: !isSelected && isFocused ? fill : undefined\n }}></rect>\n <rect\n x={x + inset}\n y={y + inset}\n class={classNames([\n styles.contrastBorder,\n props.isPointerEnabled ? styles.cursorEnable : undefined\n ])}\n style={{\n width: width - 2 * inset,\n height: height - 2 * inset,\n fill: fill\n }}></rect>\n </g>\n );\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { ColorProps } from '../../utils/UNSAFE_interpolations/colors';\nimport { BarItemData, BarSeriesData } from '../barChart.types';\n\nexport function getBarProps<K, D>(\n item: BarItemData<K>,\n series: BarSeriesData<K, D>,\n seriesColor: ColorProps['color']\n) {\n const fill = item.color || series.color || seriesColor;\n const stroke = item.borderColor || series.borderColor;\n return { fill, stroke };\n}\n\n/**\n * Returns the coordinate of bar rect.\n * @param x1 The bar start coordinate in x axis.\n * @param x2 The bar end coordinate in x axis.\n * @param endCoord The coordinate of bar top in y axis.\n * @param baselineCoord The coordinate of bar base in y axis.\n * @param isHoriz Whether the chart is horizontal chart.\n * @returns\n */\nexport function getRectCoord(\n x1: number,\n x2: number,\n endCoord: number,\n baselineCoord: number,\n isHoriz: boolean\n) {\n let x: number;\n let y: number;\n let width: number;\n let height: number;\n\n let x_1 = x1;\n let x_2 = x2;\n\n // Bar width has to be at least 1px to prevent disappearing bars\n let barWidth = x2 - x1;\n if (barWidth < 1) {\n x_1 = Math.floor(x_1);\n x_2 = x_1 + 1;\n barWidth = 1;\n }\n\n if (!isHoriz) {\n x = x_1;\n y = endCoord > baselineCoord ? baselineCoord : endCoord;\n width = Math.abs(x_2 - x_1);\n height = Math.abs(baselineCoord - endCoord);\n } else {\n y = x_1;\n x = endCoord > baselineCoord ? baselineCoord : endCoord;\n width = Math.abs(baselineCoord - endCoord);\n height = Math.abs(x_2 - x_1);\n }\n\n return { x, y, width, height };\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { getBarGapsInfo } from './barSeriesUtils';\nimport { getRectCoord } from './barItemUtils';\nimport { BarSeriesData } from '../barChart.types';\nimport { ChartItemData, Scale, Group } from '../../utils/UNSAFE_visTypes/chart';\n\n/**\n * Returns the base and end coordinate of the bar.\n * @param value The value of the bar item.\n * @param yScale The yscale.\n * @param isStacked Whether the bar chart is stacked or not.\n * @param isLog Whether the y axis is in log scale.\n * @param itemsGaps The gap between data item.\n * @param negCummulativeValue The negative cummulative value of the group.\n * @param posCummulativeValue The positive cummulative value of the group.\n * @returns\n */\nexport function getBaseAndEndCoord(\n value: number,\n yScale: Scale,\n isStacked: boolean,\n isLog: boolean,\n itemsGaps: number,\n negCummulativeValue: number,\n posCummulativeValue: number\n) {\n let baselineCoord;\n let endCoord;\n if (isStacked) {\n baselineCoord = yScale.transform(value < 0 ? negCummulativeValue : posCummulativeValue);\n negCummulativeValue += value < 0 ? value : 0;\n posCummulativeValue += value > 0 ? value : 0;\n endCoord = yScale.transform(value < 0 ? negCummulativeValue : posCummulativeValue);\n\n baselineCoord += endCoord > baselineCoord ? itemsGaps : -itemsGaps;\n } else {\n baselineCoord = isLog ? yScale.range()[0] : yScale.transform(0);\n endCoord = yScale.transform(value);\n }\n return { baselineCoord, endCoord };\n}\n\nexport function getBarPosition<K extends string | number, D extends ChartItemData<K>>(\n series: BarSeriesData<K, D>[],\n groups: Group[],\n getDataItem: (seriesIndex: number, groupIndex: number) => D | undefined,\n xScale: Scale,\n yScale: Scale,\n hiddenIds: Set<number | string> | undefined,\n dataItemGaps: number,\n groupWidth: number,\n barGapRatio: number,\n isLog: boolean,\n isStacked: boolean,\n isRtl: boolean,\n isHoriz: boolean,\n timeAxisType?: 'mixedFrequency' | 'enabled' | 'skipGaps'\n) {\n return (seriesIndex: number, groupIndex: number) => {\n const numOfSeries = series.length;\n let posCumulativeValue = 0;\n let negCumulativeValue = 0;\n for (let index = 0; index < numOfSeries; index += 1) {\n const item = getDataItem(index, groupIndex);\n let xVal = groupIndex;\n if (timeAxisType) {\n const val =\n timeAxisType === 'mixedFrequency'\n ? getDataItem(seriesIndex, groupIndex)?.x\n : groups[groupIndex].id;\n xVal = new Date(val!).getTime();\n }\n if (!item || hiddenIds?.has(item.id) || (isLog && item.value <= 0)) {\n continue;\n }\n const groupCenter = xScale.transform(xVal);\n const { barWidth, offset, itemsGaps } = getBarGapsInfo(\n index,\n groupWidth,\n barGapRatio,\n numOfSeries,\n dataItemGaps,\n isStacked,\n isRtl\n );\n const x1 = groupCenter + offset;\n const x2 = x1 + barWidth;\n\n const { baselineCoord, endCoord } = getBaseAndEndCoord(\n item.value,\n yScale,\n isStacked,\n isLog,\n itemsGaps,\n negCumulativeValue,\n posCumulativeValue\n );\n negCumulativeValue += item.value < 0 ? item.value : 0;\n posCumulativeValue += item.value > 0 ? item.value : 0;\n\n if (seriesIndex === index) {\n return getRectCoord(x1, x2, endCoord, baselineCoord, isHoriz);\n }\n }\n return;\n };\n}\n\n/**\n * Returns the center coordinate of the bar item.\n * @param value\n * @param yScale\n * @param isStacked\n * @param isLog\n * @param dataItemGaps\n * @param negCummValue\n * @param posCummValue\n * @returns\n */\nexport function getBarCenterCoordinate(\n value: number,\n yScale: Scale,\n isStacked: boolean,\n isLog: boolean,\n dataItemGaps: number,\n negCummValue: number,\n posCummValue: number\n) {\n const { baselineCoord, endCoord } = getBaseAndEndCoord(\n value,\n yScale,\n isStacked,\n isLog,\n dataItemGaps,\n negCummValue,\n posCummValue\n );\n return (baselineCoord + endCoord) / 2;\n}\n\nexport function getSeriesOffsetAndWidth(\n groupWidth: number,\n barGapRatio: number,\n numOfSeries: number,\n dataItemGaps: number,\n isStacked: boolean,\n isRtl: boolean\n) {\n return (seriesIndex: number) => {\n const { offset, barWidth } = getBarGapsInfo(\n seriesIndex,\n groupWidth,\n barGapRatio,\n numOfSeries,\n dataItemGaps,\n isStacked,\n isRtl\n );\n return { offset, dataWidth: barWidth };\n };\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { Dimension } from '../../utils/UNSAFE_visTypes/common';\n\nconst LABEL_OFFSET = 2;\n\nfunction getValueCoord(isHoriz: boolean, isRtl: boolean, isNegative: boolean, barDims: Dimension) {\n if (isHoriz) {\n return (isNegative && !isRtl) || (!isNegative && isRtl) ? barDims.x : barDims.x + barDims.width;\n }\n return isNegative ? barDims.height + barDims.y : barDims.y;\n}\n\nexport function getLabelProps(\n isHoriz: boolean,\n isRtl: boolean,\n isNegative: boolean,\n barDims: Dimension,\n dataLabelPosition: 'insideBarEdge' | 'outsideBarEdge' | 'center',\n labelDims?: Dimension\n) {\n if (!labelDims) {\n return {};\n }\n\n const valueCoord = getValueCoord(isHoriz, isRtl, isNegative, barDims);\n\n if (dataLabelPosition === 'insideBarEdge') {\n return {\n y: isHoriz\n ? barDims.y + barDims.height / 2\n : valueCoord + (isNegative ? -1 : 1) * (labelDims.height / 2 + LABEL_OFFSET + 2),\n x: isHoriz\n ? valueCoord -\n ((isNegative && !isRtl) || (!isNegative && isRtl) ? -1 : 1) *\n (labelDims.width / 2 + LABEL_OFFSET)\n : barDims.x + barDims.width / 2\n };\n }\n\n if (dataLabelPosition === 'outsideBarEdge') {\n return {\n y: isHoriz\n ? barDims.y + barDims.height / 2\n : valueCoord - (isNegative ? -1 : 1) * (labelDims.height / 2 + LABEL_OFFSET),\n x: isHoriz\n ? valueCoord +\n ((isNegative && !isRtl) || (!isNegative && isRtl) ? -1 : 1) *\n (labelDims.width / 2 + LABEL_OFFSET)\n : barDims.x + barDims.width / 2\n };\n }\n\n return {\n x: barDims.x + barDims.width / 2,\n y: barDims.y + barDims.height / 2\n };\n}\n\nexport function canFitLabel(\n isHoriz: boolean,\n labelDims: Dimension,\n barDims: Dimension,\n labelPos: 'insideBarEdge' | 'outsideBarEdge' | 'center'\n) {\n if (isHoriz) {\n if (labelDims.height > barDims.height) {\n return false;\n }\n if (labelPos != 'outsideBarEdge') {\n return labelDims.width < barDims.width;\n }\n return true;\n }\n\n if (labelDims.width > barDims.width) {\n return false;\n }\n\n if (labelPos != 'outsideBarEdge') {\n return labelDims.height < barDims.height;\n }\n return true;\n}\n\nexport const getStackLabelProps = (\n groupCenterCoord: number,\n valueCoord: number,\n isNegative: boolean,\n isHoriz: boolean,\n isRtl: boolean,\n labelDims: Dimension\n) => {\n return {\n y: isHoriz\n ? groupCenterCoord\n : valueCoord - (isNegative ? -1 : 1) * (labelDims.height / 2 + LABEL_OFFSET),\n x: isHoriz\n ? valueCoord +\n ((isNegative && !isRtl) || (!isNegative && isRtl) ? -1 : 1) *\n (labelDims.width / 2 + LABEL_OFFSET)\n : groupCenterCoord\n };\n};\n","import { Scale, Group } from '#utils/UNSAFE_visTypes/chart';\nimport { Dimension } from '#utils/UNSAFE_visTypes/common';\nimport { styles } from '#PRIVATE_Chart/themes/ChartStyles.css';\nimport { VisTextStyle } from '#utils/UNSAFE_visUtils';\nimport { BarChartProps, BarItemData } from './barChart.types';\nimport { getStackLabelProps } from './utils/barItemLabelUtils';\nimport { Font } from '#hooks/PRIVATE_useTextDimensions/textDimensionsUtils';\n\ntype Props<K, D extends BarItemData<K>> = {\n groupCenter: number;\n labelStyle?: VisTextStyle;\n yScale: Scale;\n defaultFontSize: string;\n getStackLabel: NonNullable<BarChartProps<K, D>['getStackLabel']>;\n group: Group;\n isRtl: boolean;\n posValue: number;\n negValue: number;\n posItemsData: D[];\n isHoriz: boolean;\n negItemsData: D[];\n getTextDimensions: (text: string, font: Font) => Dimension;\n};\n\nexport function StackLabels<K, D extends BarItemData<K>>({\n groupCenter,\n getStackLabel,\n group,\n posValue,\n negValue,\n posItemsData,\n yScale,\n isHoriz,\n isRtl,\n negItemsData,\n defaultFontSize,\n labelStyle,\n getTextDimensions\n}: Props<K, D>) {\n const positiveStackLabel = getStackLabel({\n group,\n value: posValue,\n data: posItemsData\n });\n\n // default style used for text dims calc. should match with styles.stackLabelStyle\n const stackLabelStyle = { fontSize: defaultFontSize, fontWeight: 'bold', ...labelStyle };\n\n const negativeStackLabel =\n negValue < 0\n ? getStackLabel?.({\n group,\n value: negValue,\n data: negItemsData\n })\n : '';\n\n const posProps = getStackLabelProps(\n groupCenter,\n yScale.transform(posValue),\n false,\n isHoriz,\n isRtl,\n getTextDimensions(positiveStackLabel, stackLabelStyle)\n );\n const negProps = getStackLabelProps(\n groupCenter,\n yScale.transform(negValue),\n true,\n isHoriz,\n isRtl,\n getTextDimensions(negativeStackLabel, stackLabelStyle)\n );\n\n return (\n <>\n <text class={styles.stackLabelStyle} style={stackLabelStyle} {...posProps}>\n {positiveStackLabel}\n </text>\n <text class={styles.stackLabelStyle} style={stackLabelStyle} {...negProps}>\n {negativeStackLabel}\n </text>\n </>\n );\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { Dimension } from '#utils/UNSAFE_visTypes/common';\nimport { Font } from '#hooks/PRIVATE_useTextDimensions';\nimport { BarItemData } from './barChart.types';\nimport { styles } from '#PRIVATE_Chart/themes/ChartStyles.css';\nimport { canFitLabel, getLabelProps } from './utils/barItemLabelUtils';\nimport { VNode } from 'preact';\nimport { getContrastingTextColor } from '#utils/PRIVATE_colorUtils/colorUtils';\n\ntype Props<K> = {\n item: BarItemData<K>;\n seriesColor?: string;\n isStacked: boolean;\n defaultFontSize: string;\n isHoriz: boolean;\n barDim: Dimension;\n getTextDimensions?: (text: string, style: Font) => Dimension;\n isRtl: boolean;\n};\n\nexport function BarLabel<K>({\n item,\n seriesColor,\n isStacked,\n defaultFontSize,\n barDim,\n isRtl,\n isHoriz,\n getTextDimensions\n}: Props<K>) {\n let label: VNode | null = null;\n const position =\n !item.labelPosition || (item.labelPosition === 'outsideBarEdge' && isStacked)\n ? 'center'\n : item.labelPosition;\n const labelString = item.label;\n const color = item.color || seriesColor;\n const needsContrastColor = isStacked || !(position === 'outsideBarEdge');\n\n if (\n position != 'none' &&\n labelString &&\n getTextDimensions &&\n !(isStacked && position === 'outsideBarEdge')\n ) {\n const labelStyle = {\n fontSize: defaultFontSize,\n fill: needsContrastColor ? getContrastingTextColor(color!) : undefined,\n ...item.labelStyle\n };\n const labelDims = getTextDimensions(labelString, labelStyle);\n const canFit = canFitLabel(isHoriz, labelDims, barDim, position || 'center');\n label = canFit ? (\n <text\n class={styles.dataLabelStyle}\n style={labelStyle}\n {...getLabelProps(\n isHoriz,\n isRtl,\n item.value < 0,\n barDim,\n position || 'center',\n getTextDimensions?.(labelString, labelStyle)\n )}>\n {labelString}\n </text>\n ) : null;\n }\n\n return label;\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { Bar } from './Bar';\nimport { BarItemData, BarSeriesData, StackLabelContext } from './barChart.types';\nimport { getBarProps, getRectCoord } from './utils/barItemUtils';\nimport { ColorProps } from '../utils/UNSAFE_interpolations/colors';\nimport { getBarGapsInfo } from './utils/barSeriesUtils';\nimport { getBaseAndEndCoord } from './utils/barLayoutUtils';\nimport { getMixedFreqGroupCenter } from '../utils/PRIVATE_chartUtils/layoutUtils';\nimport { Info, Scale, Group } from '../utils/UNSAFE_visTypes/chart';\nimport { Dimension } from '../utils/UNSAFE_visTypes/common';\nimport { useTranslationBundle } from '../hooks/UNSAFE_useTranslationBundle';\nimport type { BundleType } from '../resources/nls/bundle';\nimport { getItemAriaLabel } from '../utils/PRIVATE_chartUtils/accUtils';\nimport { VisTextStyle, supportsMobileScreenReader } from '../utils/UNSAFE_visUtils';\nimport { Font } from '../hooks/PRIVATE_useTextDimensions';\nimport { StackLabels } from './BarChartStackLabel';\nimport { BarLabel } from './BarLabel';\n\ntype BarGroupProps<K, D> = {\n yScale: Scale;\n xScale: Scale;\n colors: ColorProps['color'][];\n series: BarSeriesData<K, D>[];\n group: Group;\n timeAxisType?: 'enabled' | 'skipGaps' | 'mixedFrequency';\n focusedItemInfo?: Info;\n hoveredItemInfo?: Info;\n isSelectionEnabled: boolean;\n selectedIds?: Set<K>;\n hiddenIds?: Set<K>;\n highlightedIds?: Set<K>;\n groupIndex: number;\n barGapRatio: number;\n dataItemGaps: number;\n groupWidth: number;\n isStacked: boolean;\n activeId?: string;\n orientation: 'horizontal' | 'vertical';\n isDrillEnabled: boolean;\n isLog: boolean;\n isRtl: boolean;\n getDataItem: (seriesIndex: number, groupIndex: number) => D | undefined;\n isPointInsideMarquee: ((id: K, point: { x: number; y: number }) => boolean) | undefined;\n getTextDimensions?: (text: string, style: Font) => Dimension;\n defaultFontSize: string;\n stacklabelStyle?: VisTextStyle;\n getStackLabel?: (context: StackLabelContext<D>) => string;\n};\n\nexport function BarGroup<K extends string | number, D extends BarItemData<K>>({\n yScale,\n xScale,\n colors,\n series,\n groupIndex,\n hiddenIds,\n barGapRatio,\n dataItemGaps,\n groupWidth,\n highlightedIds,\n selectedIds,\n isPointInsideMarquee,\n orientation,\n isLog,\n activeId,\n getDataItem,\n isRtl,\n isStacked,\n isSelectionEnabled,\n focusedItemInfo,\n hoveredItemInfo,\n isDrillEnabled,\n group,\n timeAxisType,\n getTextDimensions,\n defaultFontSize,\n stacklabelStyle,\n getStackLabel\n}: BarGroupProps<K, D>) {\n const isHoriz = orientation === 'horizontal';\n const items = [];\n const numSeries = series.length;\n\n let posCumulativeValue = isLog ? yScale.domain()[0] : 0;\n let negCumulativeValue = 0;\n\n const positiveValueItems: D[] = [];\n const negativeValueItems: D[] = [];\n\n const translations = useTranslationBundle<BundleType>('@oracle/oraclejet-preact');\n const isStackLabelRendered = isStacked && !!getStackLabel && timeAxisType != 'mixedFrequency';\n\n let groupCenter =\n timeAxisType != 'mixedFrequency'\n ? xScale.transform(timeAxisType != undefined ? new Date(group.id).getTime() : groupIndex)\n : undefined;\n\n for (let seriesIndex = 0; seriesIndex < numSeries; seriesIndex += 1) {\n const item = getDataItem(seriesIndex, groupIndex);\n if (!item || hiddenIds?.has(item.id) || (isLog && item.value <= 0)) {\n continue;\n }\n\n if (timeAxisType === 'mixedFrequency') {\n groupCenter = getMixedFreqGroupCenter<K, D>(xScale, item);\n }\n\n const isFocused =\n focusedItemInfo?.groupIndex === groupIndex &&\n focusedItemInfo?.seriesIndex === seriesIndex &&\n focusedItemInfo?.isFocusVisible;\n const isHovered =\n hoveredItemInfo?.groupIndex === groupIndex &&\n hoveredItemInfo?.seriesIndex === seriesIndex &&\n hoveredItemInfo?.isCurrent;\n const isFocusVisible = !!isFocused || (!!isHovered && isSelectionEnabled);\n const isActive = (isFocused && focusedItemInfo.isCurrent) || isHovered;\n const isHighlighted = highlightedIds === undefined || highlightedIds.has(item.id);\n\n const isDrillable = item.drilling === 'on' || (item.drilling != 'off' && isDrillEnabled);\n\n const { barWidth, offset, itemsGaps } = getBarGapsInfo(\n seriesIndex,\n groupWidth,\n barGapRatio,\n numSeries,\n dataItemGaps,\n isStacked,\n isRtl\n );\n const x1 = groupCenter! + offset;\n const x2 = x1 + barWidth;\n\n const { baselineCoord, endCoord } = getBaseAndEndCoord(\n item.value,\n yScale,\n isStacked,\n isLog,\n itemsGaps,\n negCumulativeValue,\n posCumulativeValue\n );\n\n negCumulativeValue += item.value < 0 ? item.value : 0;\n posCumulativeValue += item.value > 0 ? item.value : 0;\n\n if (isStackLabelRendered) {\n if (item.value >= 0) {\n positiveValueItems.push(item);\n } else {\n negativeValueItems.push(item);\n }\n }\n\n const barprops = getBarProps(item, series[seriesIndex], colors?.[seriesIndex]);\n const rectParam = getRectCoord(x1, x2, endCoord, baselineCoord, isHoriz);\n const isSelected = isPointInsideMarquee\n ? isPointInsideMarquee?.(item.id, {\n x: rectParam.x + rectParam.width / 2,\n y: rectParam.y\n })\n : selectedIds?.has(item.id!);\n\n const ariaLabel =\n supportsMobileScreenReader || isActive\n ? getItemAriaLabel(\n translations,\n series[seriesIndex].name || series[seriesIndex].id.toString(),\n group.name || group.id,\n item.value,\n isSelectionEnabled,\n !!isSelected,\n isDrillable,\n item.accessibleLabel\n )\n : '';\n\n items.push(\n <>\n <Bar\n {...rectParam}\n {...barprops}\n seriesIndex={seriesIndex}\n groupIndex={groupIndex}\n isFocused={isFocusVisible}\n activeId={isActive ? activeId : ''}\n aria-label={ariaLabel}\n isDimmed={!isHighlighted}\n isSelected={!!isSelected}\n isPointerEnabled={isDrillable || isSelectionEnabled}\n key={`${groupIndex};${seriesIndex}`}\n />\n <BarLabel\n item={item}\n isRtl={isRtl}\n seriesColor={colors[seriesIndex % 12]}\n isStacked={isStacked}\n defaultFontSize={defaultFontSize}\n barDim={rectParam}\n isHoriz={isHoriz}\n getTextDimensions={getTextDimensions}\n />\n </>\n );\n }\n\n return (\n <>\n {items}\n {isStackLabelRendered && getTextDimensions && (\n <StackLabels\n group={group}\n isRtl={isRtl}\n yScale={yScale}\n getStackLabel={getStackLabel}\n defaultFontSize={defaultFontSize}\n getTextDimensions={getTextDimensions}\n posItemsData={positiveValueItems}\n negItemsData={negativeValueItems}\n isHoriz={isHoriz}\n groupCenter={groupCenter!}\n labelStyle={stacklabelStyle}\n posValue={posCumulativeValue}\n negValue={negCumulativeValue}\n />\n )}\n </>\n );\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { ChartItemData, Info, ItemInfo } from '../../utils/UNSAFE_visTypes/chart';\nimport {\n getNextItemInGroup,\n getNextItemInSeries,\n getPrevItemInGroup,\n getPrevItemInSeries\n} from '../../utils/PRIVATE_chartUtils/navUtils';\n\ntype isItemNavigableType = (seriesIndex: number, groupIndex: number) => boolean;\n\n/**\n * Get next item in unstacked bar chart.\n * @param info\n * @param viewportEndIndex\n * @param numSeries\n * @param isNavigable\n * @returns\n */\nexport function getNextItem(\n info: ItemInfo,\n viewportEndIndex: number,\n numSeries: number,\n isNavigable: isItemNavigableType\n): ItemInfo {\n const nextItemInGroup = getNextItemInGroup(info, numSeries, isNavigable);\n if (nextItemInGroup) return nextItemInGroup;\n\n if (info.groupIndex < viewportEndIndex) {\n let nextItem = { seriesIndex: 0, groupIndex: info.groupIndex + 1 };\n if (isNavigable(nextItem.seriesIndex, nextItem.groupIndex)) return nextItem;\n nextItem = getNextItem(nextItem, viewportEndIndex, numSeries, isNavigable);\n if (nextItem) return nextItem;\n }\n return info;\n}\n\n/**\n * Get prev item in unstacked bar chart.\n * @param info\n * @param viewportStartIndex\n * @param numSeries\n * @param isNavigable\n * @returns\n */\nexport function getPreviousItem(\n info: ItemInfo,\n viewportStartIndex: number,\n numSeries: number,\n isNavigable: (seriesIndex: number, groupIndex: number) => boolean\n) {\n const prevItemInGroup = getPrevItemInGroup(info, isNavigable);\n if (prevItemInGroup) return prevItemInGroup;\n\n if (info.groupIndex > viewportStartIndex) {\n let prevItem = { groupIndex: info.groupIndex - 1, seriesIndex: numSeries - 1 };\n if (isNavigable(prevItem.seriesIndex, prevItem.groupIndex)) return prevItem;\n prevItem = getPreviousItem(prevItem, viewportStartIndex, numSeries, isNavigable);\n if (prevItem) return prevItem;\n }\n return info;\n}\n\nexport function getBarChartNavUtil<K, D extends ChartItemData<K>>(\n getDataItem: (seriesIndex: number, groupIndex: number) => D | undefined,\n numSeries: number,\n viewportStartIndex: number,\n viewportEndIndex: number,\n isStacked: boolean,\n isRtl: boolean\n) {\n const isItemNavigable = (seriesIndex: number, groupIndex: number) => {\n const barItem = getDataItem(seriesIndex, groupIndex);\n return Boolean(barItem);\n };\n\n const getNextChartItem = (\n itemInfo: Info,\n arrow: 'ArrowLeft' | 'ArrowRight' | 'ArrowDown' | 'ArrowUp'\n ): Info => {\n if (!isStacked && (arrow === 'ArrowDown' || arrow === 'ArrowUp')) {\n return itemInfo;\n }\n let newInfo: Info | undefined;\n // TODO: this is just to keep typescript happy.\n // figure out consistent typing while doing type cleanup.\n const info = {\n groupIndex: itemInfo.groupIndex!,\n seriesIndex: itemInfo.seriesIndex!\n };\n\n if (info.groupIndex! < viewportStartIndex) {\n info.groupIndex = viewportStartIndex;\n return info;\n } else if (info.groupIndex! > viewportEndIndex) {\n info.groupIndex = viewportEndIndex;\n return info;\n }\n\n if (isStacked) {\n if (arrow === 'ArrowLeft') {\n newInfo = isRtl\n ? getNextItemInSeries(info, viewportEndIndex, isItemNavigable)\n : getPrevItemInSeries(info, viewportStartIndex, isItemNavigable);\n } else if (arrow === 'ArrowRight') {\n newInfo = isRtl\n ? getPrevItemInSeries(info, viewportStartIndex, isItemNavigable)\n : getNextItemInSeries(info, viewportEndIndex, isItemNavigable);\n } else if (arrow === 'ArrowDown') {\n newInfo = getPrevItemInGroup(info, isItemNavigable);\n } else {\n newInfo = getNextItemInGroup(info, numSeries, isItemNavigable);\n }\n } else {\n if (arrow === 'ArrowRight') {\n newInfo = isRtl\n ? getPreviousItem(info, viewportStartIndex, numSeries, isItemNavigable)\n : getNextItem(info, viewportEndIndex, numSeries, isItemNavigable);\n } else if (arrow === 'ArrowLeft') {\n newInfo = isRtl\n ? getNextItem(info, viewportEndIndex, numSeries, isItemNavigable)\n : getPreviousItem(info, viewportStartIndex, numSeries, isItemNavigable);\n }\n }\n return newInfo || info;\n };\n\n return getNextChartItem;\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { BarChartProps, BarItemData } from './barChart.types';\nimport { getBarGapRatio } from './utils/barSeriesUtils';\nimport { useUser } from '../hooks/UNSAFE_useUser';\nimport { BarGroup } from './BarGroup';\nimport { findNearestDataPoint } from '../utils/PRIVATE_chartUtils/layoutUtils';\nimport {\n getBarCenterCoordinate,\n getBarPosition,\n getSeriesOffsetAndWidth\n} from './utils/barLayoutUtils';\nimport { getBarChartNavUtil } from './utils/barNavUtils';\nimport { Chart } from '../PRIVATE_Chart';\nimport { TimeAxisProps, Scale } from '../utils/UNSAFE_visTypes/chart';\nimport { getItemColor, getMarkerType } from '../utils/PRIVATE_chartUtils/dataStyleUtils';\n\n/* bar chart start and end axis offset */\nconst AXIS_OFFSET = 0.5;\n\n/**\n * A Bar chart displays information graphically using rectangular bars with heights or lengths proportional to the values that they represent,\n * making relationships among the data easier to understand.\n */\nexport function BarChart<K extends string | number, D extends BarItemData<K>>({\n width,\n height,\n selectedIds = [],\n hiddenIds = [],\n highlightedIds,\n hideAndShowBehavior = 'none',\n orientation = 'vertical',\n yAxis,\n series,\n groups,\n isStacked = false,\n getDataItem,\n selectionMode = 'none',\n drilling = 'off',\n dataItemGaps = 0.5,\n ...props\n}: BarChartProps<K, D>) {\n const { direction } = useUser();\n const isRtl = direction === 'rtl';\n const hiddenSet = new Set(hiddenIds);\n const isHoriz = orientation === 'horizontal';\n const timeAxisType = (props.xAxis as TimeAxisProps)?.timeAxisType;\n const selectedSet = new Set(selectedIds);\n const highlightedSet = new Set(highlightedIds);\n const getGapRatio = (startIndex: number, endIndex: number) => {\n return getBarGapRatio(isStacked, startIndex, endIndex);\n };\n const getNextChartItemFunc = (startIndex: number, endIndex: number) => {\n return getBarChartNavUtil(getDataItem, series.length, startIndex, endIndex, isStacked, isRtl);\n };\n const getDataItemPos = (xScale: Scale, yScale: Scale, groupWidth: number, gapRatio: number) => {\n return getBarPosition(\n series,\n groups,\n getDataItem,\n xScale,\n yScale,\n hiddenSet,\n dataItemGaps,\n groupWidth,\n gapRatio,\n yAxis?.scale === 'log',\n isStacked,\n isRtl,\n isHoriz,\n timeAxisType\n );\n };\n\n const findNearest = (xScale: Scale, yScale: Scale, groupWidth: number, gapRatio: number) => {\n const getSeriesDataInfo = getSeriesOffsetAndWidth(\n groupWidth,\n gapRatio,\n series.length,\n dataItemGaps,\n isStacked,\n isRtl\n );\n return findNearestDataPoint(\n series,\n groups,\n xScale,\n yScale,\n getDataItem,\n isStacked,\n getSeriesDataInfo,\n getBarCenterCoordinate,\n yAxis?.scale === 'log',\n dataItemGaps,\n hiddenSet,\n timeAxisType\n );\n };\n\n const getMarkerColorAndType = (seriesIndex: number, groupIndex: number) => {\n return {\n color: getItemColor<K, D>(seriesIndex, groupIndex, series, getDataItem),\n type: getMarkerType<K>(seriesIndex, groupIndex, 'bar', getDataItem)\n };\n };\n\n return (\n <Chart\n width={width}\n height={height}\n selectedIds={selectedSet}\n hiddenIds={hiddenIds}\n hideAndShowBehavior={hideAndShowBehavior}\n orientation={orientation}\n yAxis={yAxis}\n series={series}\n groups={groups}\n isStacked={isStacked}\n getDataItem={getDataItem}\n selectionMode={selectionMode}\n drilling={drilling}\n renderGridLinesInFront={false}\n findNearest={findNearest}\n getDataItemPos={getDataItemPos}\n getNavUtil={getNextChartItemFunc}\n getGapRatio={getGapRatio}\n getMarkerInfo={getMarkerColorAndType}\n isRtl={isRtl}\n offset={AXIS_OFFSET}\n {...props}>\n {({\n xStartIndex,\n xEndIndex,\n xScale,\n yScale,\n gapRatio,\n activeId,\n focusedItemInfo,\n hoveredItemInfo,\n groupWidth,\n isPointInsideMarquee,\n getTextDimensions,\n defaultFontSize,\n colors\n }) => {\n return (\n <>\n {groups.slice(xStartIndex, xEndIndex + 1).map((_, index) => (\n <BarGroup\n yScale={yScale}\n xScale={xScale}\n groupIndex={index + xStartIndex}\n selectedIds={selectedSet}\n hiddenIds={hiddenSet}\n highlightedIds={highlightedIds ? highlightedSet : highlightedIds}\n isDrillEnabled={drilling === 'on'}\n series={series}\n barGapRatio={gapRatio}\n dataItemGaps={dataItemGaps}\n isPointInsideMarquee={isPointInsideMarquee}\n isStacked={isStacked}\n groupWidth={groupWidth}\n group={groups[index]}\n timeAxisType={(props.xAxis as TimeAxisProps)?.timeAxisType}\n colors={colors}\n activeId={activeId}\n isLog={yAxis?.scale === 'log'}\n orientation={orientation}\n getDataItem={getDataItem}\n isSelectionEnabled={selectionMode != 'none'}\n isRtl={isRtl}\n focusedItemInfo={focusedItemInfo}\n hoveredItemInfo={hoveredItemInfo}\n getTextDimensions={getTextDimensions}\n defaultFontSize={defaultFontSize}\n getStackLabel={props.getStackLabel}\n />\n ))}\n </>\n );\n }}\n </Chart>\n );\n}\n"],"names":["IDEAL_DATA_ITEM_GAP","DEFAULT_BAR_GAP_RATIO","getBarGapsInfo","seriesIndex","groupWidth","barGapRatio","numOfSeries","dataItemGaps","isStacked","isRtl","numSeries","itemsGaps","barWidth","offset","center","seriesStart","HOVERED_INNER_INSET","SELECTED_INNER_INSET","Bar","props","isSelected","isFocused","_jsx","jsx","InteractiveBar","x","y","groupIndex","role","undefined","id","activeId","style","width","height","fill","stroke","strokeWidth","class","classNames","isPointerEnabled","styles","cursorEnable","isDimmed","dimmed","inset","_jsxs","jsxs","className","children","selectedBorder","contrastBorder","getBarProps","item","series","seriesColor","color","borderColor","getRectCoord","x1","x2","endCoord","baselineCoord","isHoriz","x_1","x_2","Math","floor","abs","getBaseAndEndCoord","value","yScale","isLog","negCummulativeValue","posCummulativeValue","transform","range","getBarCenterCoordinate","negCummValue","posCummValue","LABEL_OFFSET","getLabelProps","isNegative","barDims","dataLabelPosition","labelDims","valueCoord","getValueCoord","getStackLabelProps","groupCenterCoord","StackLabels","groupCenter","getStackLabel","group","posValue","negValue","posItemsData","negItemsData","defaultFontSize","labelStyle","getTextDimensions","positiveStackLabel","data","stackLabelStyle","fontSize","fontWeight","negativeStackLabel","posProps","negProps","_Fragment","Fragment","BarLabel","barDim","label","position","labelPosition","labelString","getContrastingTextColor","canFit","labelPos","canFitLabel","dataLabelStyle","BarGroup","xScale","colors","hiddenIds","highlightedIds","selectedIds","isPointInsideMarquee","orientation","getDataItem","isSelectionEnabled","focusedItemInfo","hoveredItemInfo","isDrillEnabled","timeAxisType","stacklabelStyle","items","length","posCumulativeValue","domain","negCumulativeValue","positiveValueItems","negativeValueItems","translations","useTranslationBundle","isStackLabelRendered","Date","getTime","has","getMixedFreqGroupCenter","isFocusVisible","isHovered","isCurrent","isActive","isHighlighted","isDrillable","drilling","push","barprops","rectParam","ariaLabel","supportsMobileScreenReader","getItemAriaLabel","name","toString","accessibleLabel","_createElement","key","getNextItem","info","viewportEndIndex","isNavigable","nextItemInGroup","getNextItemInGroup","nextItem","getPreviousItem","viewportStartIndex","prevItemInGroup","getPrevItemInGroup","prevItem","hideAndShowBehavior","yAxis","groups","selectionMode","direction","useUser","hiddenSet","Set","xAxis","selectedSet","highlightedSet","Chart","renderGridLinesInFront","findNearest","gapRatio","getSeriesDataInfo","dataWidth","getSeriesOffsetAndWidth","findNearestDataPoint","scale","getDataItemPos","index","xVal","val","getBarPosition","getNavUtil","startIndex","endIndex","isItemNavigable","barItem","Boolean","itemInfo","arrow","newInfo","getNextItemInSeries","getPrevItemInSeries","getBarChartNavUtil","getGapRatio","getBarGapRatio","getMarkerInfo","getItemColor","type","getMarkerType","xStartIndex","xEndIndex","slice","map","_"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"BarChart-b75423c1.js","sources":["../../src/UNSAFE_BarChart/utils/barSeriesUtils.ts","../../src/UNSAFE_BarChart/Bar.tsx","../../src/UNSAFE_BarChart/utils/barItemUtils.ts","../../src/UNSAFE_BarChart/utils/barLayoutUtils.ts","../../src/UNSAFE_BarChart/utils/barItemLabelUtils.ts","../../src/UNSAFE_BarChart/BarChartStackLabel.tsx","../../src/UNSAFE_BarChart/BarLabel.tsx","../../src/UNSAFE_BarChart/BarGroup.tsx","../../src/UNSAFE_BarChart/utils/barNavUtils.ts","../../src/UNSAFE_BarChart/BarChart.tsx"],"sourcesContent":["/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nconst IDEAL_DATA_ITEM_GAP = 2;\nconst DEFAULT_BAR_GAP_RATIO = 0.25;\n\n/**\n * The function that calculates the barWidth and offset from group center for each series.\n * @param groupWidth The width of the group.\n * @param noOfSeries The number of series present in the chart.\n * @param barGapRatio The ratio of gap to groupWidth.\n * @param dataItemGaps The ratio that determines the gap between the bars.\n */\nexport function getBarGapsInfo(\n seriesIndex: number,\n groupWidth: number,\n barGapRatio: number,\n numOfSeries: number,\n dataItemGaps: number,\n isStacked: boolean,\n isRtl: boolean\n) {\n const numSeries = isStacked ? 1 : numOfSeries;\n const itemsGaps = IDEAL_DATA_ITEM_GAP * dataItemGaps;\n const barWidth = (groupWidth * (1 - barGapRatio) - (numSeries - 1) * itemsGaps) / numSeries;\n if (isStacked) {\n return { barWidth, offset: (-1 * barWidth) / 2, itemsGaps };\n }\n const center = groupWidth / 2;\n const seriesStart =\n groupWidth * (barGapRatio / 2) + seriesIndex * (barWidth + IDEAL_DATA_ITEM_GAP * dataItemGaps);\n const offset = isRtl ? center - seriesStart - barWidth : seriesStart - center;\n\n return { barWidth, offset, itemsGaps };\n}\n\n/**\n * Returns the bar gap ratio.\n * @param isStacked Whether the chart is a stacked bar chart.\n * @param startIndex The viewport start index.\n * @param endIndex The viewport end index.\n */\nexport function getBarGapRatio(isStacked: boolean, startIndex: number, endIndex: number) {\n const noOfGroups = endIndex - startIndex + 1;\n // logic from legacy\n return isStacked ? 0.37 + 0.26 / noOfGroups : DEFAULT_BAR_GAP_RATIO;\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { styles } from '../PRIVATE_Chart/themes/ChartStyles.css';\nimport { ColorProps } from '../utils/UNSAFE_interpolations/colors';\nimport { classNames } from '../utils/UNSAFE_classNames';\n\ntype BarProps = {\n x: number;\n y: number;\n width: number;\n height: number;\n isSelected: boolean;\n isFocused: boolean;\n isDimmed: boolean;\n activeId?: string;\n isPointerEnabled: boolean;\n fill: ColorProps['color'];\n stroke?: ColorProps['color'];\n strokeWidth?: number;\n seriesIndex: number;\n groupIndex: number;\n 'aria-label'?: string;\n};\n\nconst HOVERED_INNER_INSET = 1.5;\nconst SELECTED_INNER_INSET = 2.5;\n\n/**\n * The rect representing the bar item.\n * @param props\n * @returns\n */\nexport function Bar(props: BarProps) {\n const isInteractive = props.isSelected || props.isFocused;\n\n if (isInteractive) {\n return <InteractiveBar {...props} />;\n }\n\n return (\n <rect\n x={props.x}\n y={props.y}\n data-oj-series-index={props.seriesIndex}\n data-oj-group-index={props.groupIndex}\n data-oj-object=\"bar\"\n aria-label={props['aria-label']}\n role={props['aria-label'] ? 'img' : undefined}\n id={props.activeId}\n style={{\n width: props.width,\n height: props.height,\n fill: props.fill,\n stroke: props.stroke,\n strokeWidth: props.strokeWidth\n }}\n class={classNames([\n props.isPointerEnabled ? styles.cursorEnable : undefined,\n props.isDimmed ? styles.dimmed : undefined\n ])}\n />\n );\n}\n\n/**\n * The selected or hovered selected bar.\n */\nexport function InteractiveBar(props: BarProps) {\n const { x, y, width, height, fill, isSelected, isFocused } = props;\n const inset = isSelected ? SELECTED_INNER_INSET : HOVERED_INNER_INSET;\n return (\n <g\n id={props.activeId}\n data-oj-object=\"bar\"\n data-oj-series-index={props.seriesIndex}\n data-oj-group-index={props.groupIndex}\n className={props.isDimmed ? styles.dimmed : ''}\n role={props['aria-label'] ? 'img' : undefined}\n aria-label={props['aria-label']}>\n <rect\n x={x}\n y={y}\n class={classNames([isSelected ? styles.selectedBorder : ''])}\n style={{\n width: width,\n height: height,\n fill: !isSelected && isFocused ? fill : undefined\n }}></rect>\n <rect\n x={x + inset}\n y={y + inset}\n class={classNames([\n styles.contrastBorder,\n props.isPointerEnabled ? styles.cursorEnable : undefined\n ])}\n style={{\n width: width - 2 * inset,\n height: height - 2 * inset,\n fill: fill\n }}></rect>\n </g>\n );\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { ColorProps } from '../../utils/UNSAFE_interpolations/colors';\nimport { BarItemData, BarSeriesData } from '../barChart.types';\n\nexport function getBarProps<K, D>(\n item: BarItemData<K>,\n series: BarSeriesData<K, D>,\n seriesColor: ColorProps['color']\n) {\n const fill = item.color || series.color || seriesColor;\n const stroke = item.borderColor || series.borderColor;\n return { fill, stroke };\n}\n\n/**\n * Returns the coordinate of bar rect.\n * @param x1 The bar start coordinate in x axis.\n * @param x2 The bar end coordinate in x axis.\n * @param endCoord The coordinate of bar top in y axis.\n * @param baselineCoord The coordinate of bar base in y axis.\n * @param isHoriz Whether the chart is horizontal chart.\n * @returns\n */\nexport function getRectCoord(\n x1: number,\n x2: number,\n endCoord: number,\n baselineCoord: number,\n isHoriz: boolean\n) {\n let x: number;\n let y: number;\n let width: number;\n let height: number;\n\n let x_1 = x1;\n let x_2 = x2;\n\n // Bar width has to be at least 1px to prevent disappearing bars\n let barWidth = x2 - x1;\n if (barWidth < 1) {\n x_1 = Math.floor(x_1);\n x_2 = x_1 + 1;\n barWidth = 1;\n }\n\n if (!isHoriz) {\n x = x_1;\n y = endCoord > baselineCoord ? baselineCoord : endCoord;\n width = Math.abs(x_2 - x_1);\n height = Math.abs(baselineCoord - endCoord);\n } else {\n y = x_1;\n x = endCoord > baselineCoord ? baselineCoord : endCoord;\n width = Math.abs(baselineCoord - endCoord);\n height = Math.abs(x_2 - x_1);\n }\n\n return { x, y, width, height };\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { getBarGapsInfo } from './barSeriesUtils';\nimport { getRectCoord } from './barItemUtils';\nimport { BarSeriesData } from '../barChart.types';\nimport { ChartItemData, Scale, Group } from '../../utils/UNSAFE_visTypes/chart';\n\n/**\n * Returns the base and end coordinate of the bar.\n * @param value The value of the bar item.\n * @param yScale The yscale.\n * @param isStacked Whether the bar chart is stacked or not.\n * @param isLog Whether the y axis is in log scale.\n * @param itemsGaps The gap between data item.\n * @param negCummulativeValue The negative cummulative value of the group.\n * @param posCummulativeValue The positive cummulative value of the group.\n * @returns\n */\nexport function getBaseAndEndCoord(\n value: number,\n yScale: Scale,\n isStacked: boolean,\n isLog: boolean,\n itemsGaps: number,\n negCummulativeValue: number,\n posCummulativeValue: number\n) {\n let baselineCoord;\n let endCoord;\n if (isStacked) {\n baselineCoord = yScale.transform(value < 0 ? negCummulativeValue : posCummulativeValue);\n negCummulativeValue += value < 0 ? value : 0;\n posCummulativeValue += value > 0 ? value : 0;\n endCoord = yScale.transform(value < 0 ? negCummulativeValue : posCummulativeValue);\n\n baselineCoord += endCoord > baselineCoord ? itemsGaps : -itemsGaps;\n } else {\n baselineCoord = isLog ? yScale.range()[0] : yScale.transform(0);\n endCoord = yScale.transform(value);\n }\n return { baselineCoord, endCoord };\n}\n\nexport function getBarPosition<K extends string | number, D extends ChartItemData<K>>(\n series: BarSeriesData<K, D>[],\n groups: Group[],\n getDataItem: (seriesIndex: number, groupIndex: number) => D | undefined,\n xScale: Scale,\n yScale: Scale,\n hiddenIds: Set<number | string> | undefined,\n dataItemGaps: number,\n groupWidth: number,\n barGapRatio: number,\n isLog: boolean,\n isStacked: boolean,\n isRtl: boolean,\n isHoriz: boolean,\n timeAxisType?: 'mixedFrequency' | 'enabled' | 'skipGaps'\n) {\n return (seriesIndex: number, groupIndex: number) => {\n const numOfSeries = series.length;\n let posCumulativeValue = 0;\n let negCumulativeValue = 0;\n for (let index = 0; index < numOfSeries; index += 1) {\n const item = getDataItem(index, groupIndex);\n let xVal = groupIndex;\n if (timeAxisType) {\n const val =\n timeAxisType === 'mixedFrequency'\n ? getDataItem(seriesIndex, groupIndex)?.x\n : groups[groupIndex].id;\n xVal = new Date(val!).getTime();\n }\n if (!item || hiddenIds?.has(item.id) || (isLog && item.value <= 0)) {\n continue;\n }\n const groupCenter = xScale.transform(xVal);\n const { barWidth, offset, itemsGaps } = getBarGapsInfo(\n index,\n groupWidth,\n barGapRatio,\n numOfSeries,\n dataItemGaps,\n isStacked,\n isRtl\n );\n const x1 = groupCenter + offset;\n const x2 = x1 + barWidth;\n\n const { baselineCoord, endCoord } = getBaseAndEndCoord(\n item.value,\n yScale,\n isStacked,\n isLog,\n itemsGaps,\n negCumulativeValue,\n posCumulativeValue\n );\n negCumulativeValue += item.value < 0 ? item.value : 0;\n posCumulativeValue += item.value > 0 ? item.value : 0;\n\n if (seriesIndex === index) {\n return getRectCoord(x1, x2, endCoord, baselineCoord, isHoriz);\n }\n }\n return;\n };\n}\n\n/**\n * Returns the center coordinate of the bar item.\n * @param value\n * @param yScale\n * @param isStacked\n * @param isLog\n * @param dataItemGaps\n * @param negCummValue\n * @param posCummValue\n * @returns\n */\nexport function getBarCenterCoordinate(\n value: number,\n yScale: Scale,\n isStacked: boolean,\n isLog: boolean,\n dataItemGaps: number,\n negCummValue: number,\n posCummValue: number\n) {\n const { baselineCoord, endCoord } = getBaseAndEndCoord(\n value,\n yScale,\n isStacked,\n isLog,\n dataItemGaps,\n negCummValue,\n posCummValue\n );\n return (baselineCoord + endCoord) / 2;\n}\n\nexport function getSeriesOffsetAndWidth(\n groupWidth: number,\n barGapRatio: number,\n numOfSeries: number,\n dataItemGaps: number,\n isStacked: boolean,\n isRtl: boolean\n) {\n return (seriesIndex: number) => {\n const { offset, barWidth } = getBarGapsInfo(\n seriesIndex,\n groupWidth,\n barGapRatio,\n numOfSeries,\n dataItemGaps,\n isStacked,\n isRtl\n );\n return { offset, dataWidth: barWidth };\n };\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { Dimension } from '../../utils/UNSAFE_visTypes/common';\n\nconst LABEL_OFFSET = 2;\n\nfunction getValueCoord(isHoriz: boolean, isRtl: boolean, isNegative: boolean, barDims: Dimension) {\n if (isHoriz) {\n return (isNegative && !isRtl) || (!isNegative && isRtl) ? barDims.x : barDims.x + barDims.width;\n }\n return isNegative ? barDims.height + barDims.y : barDims.y;\n}\n\nexport function getLabelProps(\n isHoriz: boolean,\n isRtl: boolean,\n isNegative: boolean,\n barDims: Dimension,\n dataLabelPosition: 'insideBarEdge' | 'outsideBarEdge' | 'center',\n labelDims?: Dimension\n) {\n if (!labelDims) {\n return {};\n }\n\n const valueCoord = getValueCoord(isHoriz, isRtl, isNegative, barDims);\n\n if (dataLabelPosition === 'insideBarEdge') {\n return {\n y: isHoriz\n ? barDims.y + barDims.height / 2\n : valueCoord + (isNegative ? -1 : 1) * (labelDims.height / 2 + LABEL_OFFSET + 2),\n x: isHoriz\n ? valueCoord -\n ((isNegative && !isRtl) || (!isNegative && isRtl) ? -1 : 1) *\n (labelDims.width / 2 + LABEL_OFFSET)\n : barDims.x + barDims.width / 2\n };\n }\n\n if (dataLabelPosition === 'outsideBarEdge') {\n return {\n y: isHoriz\n ? barDims.y + barDims.height / 2\n : valueCoord - (isNegative ? -1 : 1) * (labelDims.height / 2 + LABEL_OFFSET),\n x: isHoriz\n ? valueCoord +\n ((isNegative && !isRtl) || (!isNegative && isRtl) ? -1 : 1) *\n (labelDims.width / 2 + LABEL_OFFSET)\n : barDims.x + barDims.width / 2\n };\n }\n\n return {\n x: barDims.x + barDims.width / 2,\n y: barDims.y + barDims.height / 2\n };\n}\n\nexport function canFitLabel(\n isHoriz: boolean,\n labelDims: Dimension,\n barDims: Dimension,\n labelPos: 'insideBarEdge' | 'outsideBarEdge' | 'center'\n) {\n if (isHoriz) {\n if (labelDims.height > barDims.height) {\n return false;\n }\n if (labelPos != 'outsideBarEdge') {\n return labelDims.width < barDims.width;\n }\n return true;\n }\n\n if (labelDims.width > barDims.width) {\n return false;\n }\n\n if (labelPos != 'outsideBarEdge') {\n return labelDims.height < barDims.height;\n }\n return true;\n}\n\nexport const getStackLabelProps = (\n groupCenterCoord: number,\n valueCoord: number,\n isNegative: boolean,\n isHoriz: boolean,\n isRtl: boolean,\n labelDims: Dimension\n) => {\n return {\n y: isHoriz\n ? groupCenterCoord\n : valueCoord - (isNegative ? -1 : 1) * (labelDims.height / 2 + LABEL_OFFSET),\n x: isHoriz\n ? valueCoord +\n ((isNegative && !isRtl) || (!isNegative && isRtl) ? -1 : 1) *\n (labelDims.width / 2 + LABEL_OFFSET)\n : groupCenterCoord\n };\n};\n","import { Scale, Group } from '#utils/UNSAFE_visTypes/chart';\nimport { Dimension } from '#utils/UNSAFE_visTypes/common';\nimport { styles } from '#PRIVATE_Chart/themes/ChartStyles.css';\nimport { VisTextStyle } from '#utils/UNSAFE_visUtils';\nimport { BarChartProps, BarItemData } from './barChart.types';\nimport { getStackLabelProps } from './utils/barItemLabelUtils';\nimport { Font } from '#hooks/PRIVATE_useTextDimensions/textDimensionsUtils';\n\ntype Props<K, D extends BarItemData<K>> = {\n groupCenter: number;\n labelStyle?: VisTextStyle;\n yScale: Scale;\n defaultFontSize: string;\n getStackLabel: NonNullable<BarChartProps<K, D>['getStackLabel']>;\n group: Group;\n isRtl: boolean;\n posValue: number;\n negValue: number;\n posItemsData: D[];\n isHoriz: boolean;\n negItemsData: D[];\n getTextDimensions: (text: string, font: Font) => Dimension;\n};\n\nexport function StackLabels<K, D extends BarItemData<K>>({\n groupCenter,\n getStackLabel,\n group,\n posValue,\n negValue,\n posItemsData,\n yScale,\n isHoriz,\n isRtl,\n negItemsData,\n defaultFontSize,\n labelStyle,\n getTextDimensions\n}: Props<K, D>) {\n const positiveStackLabel = getStackLabel({\n group,\n value: posValue,\n data: posItemsData\n });\n\n // default style used for text dims calc. should match with styles.stackLabelStyle\n const stackLabelStyle = { fontSize: defaultFontSize, fontWeight: 'bold', ...labelStyle };\n\n const negativeStackLabel =\n negValue < 0\n ? getStackLabel?.({\n group,\n value: negValue,\n data: negItemsData\n })\n : '';\n\n const posProps = getStackLabelProps(\n groupCenter,\n yScale.transform(posValue),\n false,\n isHoriz,\n isRtl,\n getTextDimensions(positiveStackLabel, stackLabelStyle)\n );\n const negProps = getStackLabelProps(\n groupCenter,\n yScale.transform(negValue),\n true,\n isHoriz,\n isRtl,\n getTextDimensions(negativeStackLabel, stackLabelStyle)\n );\n\n return (\n <>\n <text class={styles.stackLabelStyle} style={stackLabelStyle} {...posProps}>\n {positiveStackLabel}\n </text>\n <text class={styles.stackLabelStyle} style={stackLabelStyle} {...negProps}>\n {negativeStackLabel}\n </text>\n </>\n );\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { Dimension } from '#utils/UNSAFE_visTypes/common';\nimport { Font } from '#hooks/PRIVATE_useTextDimensions';\nimport { BarItemData } from './barChart.types';\nimport { styles } from '#PRIVATE_Chart/themes/ChartStyles.css';\nimport { canFitLabel, getLabelProps } from './utils/barItemLabelUtils';\nimport { VNode } from 'preact';\nimport { getContrastingTextColor } from '#utils/PRIVATE_colorUtils/colorUtils';\n\ntype Props<K> = {\n item: BarItemData<K>;\n seriesColor?: string;\n isStacked: boolean;\n defaultFontSize: string;\n isHoriz: boolean;\n barDim: Dimension;\n getTextDimensions?: (text: string, style: Font) => Dimension;\n isRtl: boolean;\n};\n\nexport function BarLabel<K>({\n item,\n seriesColor,\n isStacked,\n defaultFontSize,\n barDim,\n isRtl,\n isHoriz,\n getTextDimensions\n}: Props<K>) {\n let label: VNode | null = null;\n const position =\n !item.labelPosition || (item.labelPosition === 'outsideBarEdge' && isStacked)\n ? 'center'\n : item.labelPosition;\n const labelString = item.label;\n const color = item.color || seriesColor;\n const needsContrastColor = isStacked || !(position === 'outsideBarEdge');\n\n if (\n position != 'none' &&\n labelString &&\n getTextDimensions &&\n !(isStacked && position === 'outsideBarEdge')\n ) {\n const labelStyle = {\n fontSize: defaultFontSize,\n fill: needsContrastColor ? getContrastingTextColor(color!) : undefined,\n ...item.labelStyle\n };\n const labelDims = getTextDimensions(labelString, labelStyle);\n const canFit = canFitLabel(isHoriz, labelDims, barDim, position || 'center');\n label = canFit ? (\n <text\n class={styles.dataLabelStyle}\n style={labelStyle}\n {...getLabelProps(\n isHoriz,\n isRtl,\n item.value < 0,\n barDim,\n position || 'center',\n getTextDimensions?.(labelString, labelStyle)\n )}>\n {labelString}\n </text>\n ) : null;\n }\n\n return label;\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { Bar } from './Bar';\nimport { BarItemData, BarSeriesData, StackLabelContext } from './barChart.types';\nimport { getBarProps, getRectCoord } from './utils/barItemUtils';\nimport { ColorProps } from '../utils/UNSAFE_interpolations/colors';\nimport { getBarGapsInfo } from './utils/barSeriesUtils';\nimport { getBaseAndEndCoord } from './utils/barLayoutUtils';\nimport { getMixedFreqGroupCenter } from '../utils/PRIVATE_chartUtils/layoutUtils';\nimport { Info, Scale, Group } from '../utils/UNSAFE_visTypes/chart';\nimport { Dimension } from '../utils/UNSAFE_visTypes/common';\nimport { useTranslationBundle } from '../hooks/UNSAFE_useTranslationBundle';\nimport type { BundleType } from '../resources/nls/bundle';\nimport { getItemAriaLabel } from '../utils/PRIVATE_chartUtils/accUtils';\nimport { VisTextStyle, supportsMobileScreenReader } from '../utils/UNSAFE_visUtils';\nimport { Font } from '../hooks/PRIVATE_useTextDimensions';\nimport { StackLabels } from './BarChartStackLabel';\nimport { BarLabel } from './BarLabel';\n\ntype BarGroupProps<K, D> = {\n yScale: Scale;\n xScale: Scale;\n colors: ColorProps['color'][];\n series: BarSeriesData<K, D>[];\n group: Group;\n timeAxisType?: 'enabled' | 'skipGaps' | 'mixedFrequency';\n focusedItemInfo?: Info;\n hoveredItemInfo?: Info;\n isSelectionEnabled: boolean;\n selectedIds?: Set<K>;\n hiddenIds?: Set<K>;\n highlightedIds?: Set<K>;\n groupIndex: number;\n barGapRatio: number;\n dataItemGaps: number;\n groupWidth: number;\n isStacked: boolean;\n activeId?: string;\n orientation: 'horizontal' | 'vertical';\n isDrillEnabled: boolean;\n isLog: boolean;\n isRtl: boolean;\n getDataItem: (seriesIndex: number, groupIndex: number) => D | undefined;\n isPointInsideMarquee: ((id: K, point: { x: number; y: number }) => boolean) | undefined;\n getTextDimensions?: (text: string, style: Font) => Dimension;\n defaultFontSize: string;\n stacklabelStyle?: VisTextStyle;\n getStackLabel?: (context: StackLabelContext<D>) => string;\n};\n\nexport function BarGroup<K extends string | number, D extends BarItemData<K>>({\n yScale,\n xScale,\n colors,\n series,\n groupIndex,\n hiddenIds,\n barGapRatio,\n dataItemGaps,\n groupWidth,\n highlightedIds,\n selectedIds,\n isPointInsideMarquee,\n orientation,\n isLog,\n activeId,\n getDataItem,\n isRtl,\n isStacked,\n isSelectionEnabled,\n focusedItemInfo,\n hoveredItemInfo,\n isDrillEnabled,\n group,\n timeAxisType,\n getTextDimensions,\n defaultFontSize,\n stacklabelStyle,\n getStackLabel\n}: BarGroupProps<K, D>) {\n const isHoriz = orientation === 'horizontal';\n const items = [];\n const numSeries = series.length;\n\n let posCumulativeValue = isLog ? yScale.domain()[0] : 0;\n let negCumulativeValue = 0;\n\n const positiveValueItems: D[] = [];\n const negativeValueItems: D[] = [];\n\n const translations = useTranslationBundle<BundleType>('@oracle/oraclejet-preact');\n const isStackLabelRendered = isStacked && !!getStackLabel && timeAxisType != 'mixedFrequency';\n\n let groupCenter =\n timeAxisType != 'mixedFrequency'\n ? xScale.transform(timeAxisType != undefined ? new Date(group.id).getTime() : groupIndex)\n : undefined;\n\n for (let seriesIndex = 0; seriesIndex < numSeries; seriesIndex += 1) {\n const item = getDataItem(seriesIndex, groupIndex);\n if (!item || hiddenIds?.has(item.id) || (isLog && item.value <= 0)) {\n continue;\n }\n\n if (timeAxisType === 'mixedFrequency') {\n groupCenter = getMixedFreqGroupCenter<K, D>(xScale, item);\n }\n\n const isFocused =\n focusedItemInfo?.groupIndex === groupIndex &&\n focusedItemInfo?.seriesIndex === seriesIndex &&\n focusedItemInfo?.isFocusVisible;\n const isHovered =\n hoveredItemInfo?.groupIndex === groupIndex &&\n hoveredItemInfo?.seriesIndex === seriesIndex &&\n hoveredItemInfo?.isCurrent;\n const isFocusVisible = !!isFocused || (!!isHovered && isSelectionEnabled);\n const isActive = (isFocused && focusedItemInfo.isCurrent) || isHovered;\n const isHighlighted = highlightedIds === undefined || highlightedIds.has(item.id);\n\n const isDrillable = item.drilling === 'on' || (item.drilling != 'off' && isDrillEnabled);\n\n const { barWidth, offset, itemsGaps } = getBarGapsInfo(\n seriesIndex,\n groupWidth,\n barGapRatio,\n numSeries,\n dataItemGaps,\n isStacked,\n isRtl\n );\n const x1 = groupCenter! + offset;\n const x2 = x1 + barWidth;\n\n const { baselineCoord, endCoord } = getBaseAndEndCoord(\n item.value,\n yScale,\n isStacked,\n isLog,\n itemsGaps,\n negCumulativeValue,\n posCumulativeValue\n );\n\n negCumulativeValue += item.value < 0 ? item.value : 0;\n posCumulativeValue += item.value > 0 ? item.value : 0;\n\n if (isStackLabelRendered) {\n if (item.value >= 0) {\n positiveValueItems.push(item);\n } else {\n negativeValueItems.push(item);\n }\n }\n\n const barprops = getBarProps(item, series[seriesIndex], colors?.[seriesIndex]);\n const rectParam = getRectCoord(x1, x2, endCoord, baselineCoord, isHoriz);\n const isSelected = isPointInsideMarquee\n ? isPointInsideMarquee?.(item.id, {\n x: rectParam.x + rectParam.width / 2,\n y: rectParam.y\n })\n : selectedIds?.has(item.id!);\n\n const ariaLabel =\n supportsMobileScreenReader || isActive\n ? getItemAriaLabel(\n translations,\n series[seriesIndex].name || series[seriesIndex].id.toString(),\n group.name || group.id,\n item.value,\n isSelectionEnabled,\n !!isSelected,\n isDrillable,\n item.accessibleLabel\n )\n : '';\n\n items.push(\n <>\n <Bar\n {...rectParam}\n {...barprops}\n seriesIndex={seriesIndex}\n groupIndex={groupIndex}\n isFocused={isFocusVisible}\n activeId={isActive ? activeId : ''}\n aria-label={ariaLabel}\n isDimmed={!isHighlighted}\n isSelected={!!isSelected}\n isPointerEnabled={isDrillable || isSelectionEnabled}\n key={`${groupIndex};${seriesIndex}`}\n />\n <BarLabel\n item={item}\n isRtl={isRtl}\n seriesColor={colors[seriesIndex % 12]}\n isStacked={isStacked}\n defaultFontSize={defaultFontSize}\n barDim={rectParam}\n isHoriz={isHoriz}\n getTextDimensions={getTextDimensions}\n />\n </>\n );\n }\n\n return (\n <>\n {items}\n {isStackLabelRendered && getTextDimensions && (\n <StackLabels\n group={group}\n isRtl={isRtl}\n yScale={yScale}\n getStackLabel={getStackLabel}\n defaultFontSize={defaultFontSize}\n getTextDimensions={getTextDimensions}\n posItemsData={positiveValueItems}\n negItemsData={negativeValueItems}\n isHoriz={isHoriz}\n groupCenter={groupCenter!}\n labelStyle={stacklabelStyle}\n posValue={posCumulativeValue}\n negValue={negCumulativeValue}\n />\n )}\n </>\n );\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { ChartItemData, Info, ItemInfo } from '../../utils/UNSAFE_visTypes/chart';\nimport {\n getNextItemInGroup,\n getNextItemInSeries,\n getPrevItemInGroup,\n getPrevItemInSeries\n} from '../../utils/PRIVATE_chartUtils/navUtils';\n\ntype isItemNavigableType = (seriesIndex: number, groupIndex: number) => boolean;\n\n/**\n * Get next item in unstacked bar chart.\n * @param info\n * @param viewportEndIndex\n * @param numSeries\n * @param isNavigable\n * @returns\n */\nexport function getNextItem(\n info: ItemInfo,\n viewportEndIndex: number,\n numSeries: number,\n isNavigable: isItemNavigableType\n): ItemInfo {\n const nextItemInGroup = getNextItemInGroup(info, numSeries, isNavigable);\n if (nextItemInGroup) return nextItemInGroup;\n\n if (info.groupIndex < viewportEndIndex) {\n let nextItem = { seriesIndex: 0, groupIndex: info.groupIndex + 1 };\n if (isNavigable(nextItem.seriesIndex, nextItem.groupIndex)) return nextItem;\n nextItem = getNextItem(nextItem, viewportEndIndex, numSeries, isNavigable);\n if (nextItem) return nextItem;\n }\n return info;\n}\n\n/**\n * Get prev item in unstacked bar chart.\n * @param info\n * @param viewportStartIndex\n * @param numSeries\n * @param isNavigable\n * @returns\n */\nexport function getPreviousItem(\n info: ItemInfo,\n viewportStartIndex: number,\n numSeries: number,\n isNavigable: (seriesIndex: number, groupIndex: number) => boolean\n) {\n const prevItemInGroup = getPrevItemInGroup(info, isNavigable);\n if (prevItemInGroup) return prevItemInGroup;\n\n if (info.groupIndex > viewportStartIndex) {\n let prevItem = { groupIndex: info.groupIndex - 1, seriesIndex: numSeries - 1 };\n if (isNavigable(prevItem.seriesIndex, prevItem.groupIndex)) return prevItem;\n prevItem = getPreviousItem(prevItem, viewportStartIndex, numSeries, isNavigable);\n if (prevItem) return prevItem;\n }\n return info;\n}\n\nexport function getBarChartNavUtil<K, D extends ChartItemData<K>>(\n getDataItem: (seriesIndex: number, groupIndex: number) => D | undefined,\n numSeries: number,\n viewportStartIndex: number,\n viewportEndIndex: number,\n isStacked: boolean,\n isRtl: boolean\n) {\n const isItemNavigable = (seriesIndex: number, groupIndex: number) => {\n const barItem = getDataItem(seriesIndex, groupIndex);\n return Boolean(barItem);\n };\n\n const getNextChartItem = (\n itemInfo: Info,\n arrow: 'ArrowLeft' | 'ArrowRight' | 'ArrowDown' | 'ArrowUp'\n ): Info => {\n if (!isStacked && (arrow === 'ArrowDown' || arrow === 'ArrowUp')) {\n return itemInfo;\n }\n let newInfo: Info | undefined;\n // TODO: this is just to keep typescript happy.\n // figure out consistent typing while doing type cleanup.\n const info = {\n groupIndex: itemInfo.groupIndex!,\n seriesIndex: itemInfo.seriesIndex!\n };\n\n if (info.groupIndex! < viewportStartIndex) {\n info.groupIndex = viewportStartIndex;\n return info;\n } else if (info.groupIndex! > viewportEndIndex) {\n info.groupIndex = viewportEndIndex;\n return info;\n }\n\n if (isStacked) {\n if (arrow === 'ArrowLeft') {\n newInfo = isRtl\n ? getNextItemInSeries(info, viewportEndIndex, isItemNavigable)\n : getPrevItemInSeries(info, viewportStartIndex, isItemNavigable);\n } else if (arrow === 'ArrowRight') {\n newInfo = isRtl\n ? getPrevItemInSeries(info, viewportStartIndex, isItemNavigable)\n : getNextItemInSeries(info, viewportEndIndex, isItemNavigable);\n } else if (arrow === 'ArrowDown') {\n newInfo = getPrevItemInGroup(info, isItemNavigable);\n } else {\n newInfo = getNextItemInGroup(info, numSeries, isItemNavigable);\n }\n } else {\n if (arrow === 'ArrowRight') {\n newInfo = isRtl\n ? getPreviousItem(info, viewportStartIndex, numSeries, isItemNavigable)\n : getNextItem(info, viewportEndIndex, numSeries, isItemNavigable);\n } else if (arrow === 'ArrowLeft') {\n newInfo = isRtl\n ? getNextItem(info, viewportEndIndex, numSeries, isItemNavigable)\n : getPreviousItem(info, viewportStartIndex, numSeries, isItemNavigable);\n }\n }\n return newInfo || info;\n };\n\n return getNextChartItem;\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { BarChartProps, BarItemData } from './barChart.types';\nimport { getBarGapRatio } from './utils/barSeriesUtils';\nimport { useUser } from '../hooks/UNSAFE_useUser';\nimport { BarGroup } from './BarGroup';\nimport { findNearestDataPoint } from '../utils/PRIVATE_chartUtils/layoutUtils';\nimport {\n getBarCenterCoordinate,\n getBarPosition,\n getSeriesOffsetAndWidth\n} from './utils/barLayoutUtils';\nimport { getBarChartNavUtil } from './utils/barNavUtils';\nimport { Chart } from '../PRIVATE_Chart';\nimport { TimeAxisProps, Scale } from '../utils/UNSAFE_visTypes/chart';\nimport { getItemColor, getMarkerType } from '../utils/PRIVATE_chartUtils/dataStyleUtils';\n\n/* bar chart start and end axis offset */\nconst AXIS_OFFSET = 0.5;\n\n/**\n * A Bar chart displays information graphically using rectangular bars with heights or lengths proportional to the values that they represent,\n * making relationships among the data easier to understand.\n */\nexport function BarChart<K extends string | number, D extends BarItemData<K>>({\n width,\n height,\n selectedIds = [],\n hiddenIds = [],\n highlightedIds,\n hideAndShowBehavior = 'none',\n orientation = 'vertical',\n yAxis,\n series,\n groups,\n isStacked = false,\n getDataItem,\n selectionMode = 'none',\n drilling = 'off',\n dataItemGaps = 0.5,\n ...props\n}: BarChartProps<K, D>) {\n const { direction } = useUser();\n const isRtl = direction === 'rtl';\n const hiddenSet = new Set(hiddenIds);\n const isHoriz = orientation === 'horizontal';\n const timeAxisType = (props.xAxis as TimeAxisProps)?.timeAxisType;\n const selectedSet = new Set(selectedIds);\n const highlightedSet = new Set(highlightedIds);\n const getGapRatio = (startIndex: number, endIndex: number) => {\n return getBarGapRatio(isStacked, startIndex, endIndex);\n };\n const getNextChartItemFunc = (startIndex: number, endIndex: number) => {\n return getBarChartNavUtil(getDataItem, series.length, startIndex, endIndex, isStacked, isRtl);\n };\n const getDataItemPos = (xScale: Scale, yScale: Scale, groupWidth: number, gapRatio: number) => {\n return getBarPosition(\n series,\n groups,\n getDataItem,\n xScale,\n yScale,\n hiddenSet,\n dataItemGaps,\n groupWidth,\n gapRatio,\n yAxis?.scale === 'log',\n isStacked,\n isRtl,\n isHoriz,\n timeAxisType\n );\n };\n\n const findNearest = (xScale: Scale, yScale: Scale, groupWidth: number, gapRatio: number) => {\n const getSeriesDataInfo = getSeriesOffsetAndWidth(\n groupWidth,\n gapRatio,\n series.length,\n dataItemGaps,\n isStacked,\n isRtl\n );\n return findNearestDataPoint(\n series,\n groups,\n xScale,\n yScale,\n getDataItem,\n isStacked,\n getSeriesDataInfo,\n getBarCenterCoordinate,\n yAxis?.scale === 'log',\n dataItemGaps,\n hiddenSet,\n timeAxisType\n );\n };\n\n const getMarkerColorAndType = (seriesIndex: number, groupIndex: number) => {\n return {\n color: getItemColor<K, D>(seriesIndex, groupIndex, series, getDataItem),\n type: getMarkerType<K>(seriesIndex, groupIndex, 'bar', getDataItem)\n };\n };\n\n return (\n <Chart\n width={width}\n height={height}\n selectedIds={selectedSet}\n hiddenIds={hiddenIds}\n hideAndShowBehavior={hideAndShowBehavior}\n orientation={orientation}\n yAxis={yAxis}\n series={series}\n groups={groups}\n isStacked={isStacked}\n getDataItem={getDataItem}\n selectionMode={selectionMode}\n drilling={drilling}\n renderGridLinesInFront={false}\n findNearest={findNearest}\n getDataItemPos={getDataItemPos}\n getNavUtil={getNextChartItemFunc}\n getGapRatio={getGapRatio}\n getMarkerInfo={getMarkerColorAndType}\n isRtl={isRtl}\n offset={AXIS_OFFSET}\n {...props}>\n {({\n xStartIndex,\n xEndIndex,\n xScale,\n yScale,\n gapRatio,\n activeId,\n focusedItemInfo,\n hoveredItemInfo,\n groupWidth,\n isPointInsideMarquee,\n getTextDimensions,\n defaultFontSize,\n colors\n }) => {\n return (\n <>\n {groups.slice(xStartIndex, xEndIndex + 1).map((_, index) => (\n <BarGroup\n yScale={yScale}\n xScale={xScale}\n groupIndex={index + xStartIndex}\n selectedIds={selectedSet}\n hiddenIds={hiddenSet}\n highlightedIds={highlightedIds ? highlightedSet : highlightedIds}\n isDrillEnabled={drilling === 'on'}\n series={series}\n barGapRatio={gapRatio}\n dataItemGaps={dataItemGaps}\n isPointInsideMarquee={isPointInsideMarquee}\n isStacked={isStacked}\n groupWidth={groupWidth}\n group={groups[index]}\n timeAxisType={(props.xAxis as TimeAxisProps)?.timeAxisType}\n colors={colors}\n activeId={activeId}\n isLog={yAxis?.scale === 'log'}\n orientation={orientation}\n getDataItem={getDataItem}\n isSelectionEnabled={selectionMode != 'none'}\n isRtl={isRtl}\n focusedItemInfo={focusedItemInfo}\n hoveredItemInfo={hoveredItemInfo}\n getTextDimensions={getTextDimensions}\n defaultFontSize={defaultFontSize}\n getStackLabel={props.getStackLabel}\n />\n ))}\n </>\n );\n }}\n </Chart>\n );\n}\n"],"names":["IDEAL_DATA_ITEM_GAP","DEFAULT_BAR_GAP_RATIO","getBarGapsInfo","seriesIndex","groupWidth","barGapRatio","numOfSeries","dataItemGaps","isStacked","isRtl","numSeries","itemsGaps","barWidth","offset","center","seriesStart","HOVERED_INNER_INSET","SELECTED_INNER_INSET","Bar","props","isSelected","isFocused","_jsx","jsx","InteractiveBar","x","y","groupIndex","role","undefined","id","activeId","style","width","height","fill","stroke","strokeWidth","class","classNames","isPointerEnabled","styles","cursorEnable","isDimmed","dimmed","inset","_jsxs","jsxs","className","children","selectedBorder","contrastBorder","getBarProps","item","series","seriesColor","color","borderColor","getRectCoord","x1","x2","endCoord","baselineCoord","isHoriz","x_1","x_2","Math","floor","abs","getBaseAndEndCoord","value","yScale","isLog","negCummulativeValue","posCummulativeValue","transform","range","getBarCenterCoordinate","negCummValue","posCummValue","LABEL_OFFSET","getLabelProps","isNegative","barDims","dataLabelPosition","labelDims","valueCoord","getValueCoord","getStackLabelProps","groupCenterCoord","StackLabels","groupCenter","getStackLabel","group","posValue","negValue","posItemsData","negItemsData","defaultFontSize","labelStyle","getTextDimensions","positiveStackLabel","data","stackLabelStyle","fontSize","fontWeight","negativeStackLabel","posProps","negProps","_Fragment","Fragment","BarLabel","barDim","label","position","labelPosition","labelString","getContrastingTextColor","canFit","labelPos","canFitLabel","dataLabelStyle","BarGroup","xScale","colors","hiddenIds","highlightedIds","selectedIds","isPointInsideMarquee","orientation","getDataItem","isSelectionEnabled","focusedItemInfo","hoveredItemInfo","isDrillEnabled","timeAxisType","stacklabelStyle","items","length","posCumulativeValue","domain","negCumulativeValue","positiveValueItems","negativeValueItems","translations","useTranslationBundle","isStackLabelRendered","Date","getTime","has","getMixedFreqGroupCenter","isFocusVisible","isHovered","isCurrent","isActive","isHighlighted","isDrillable","drilling","push","barprops","rectParam","ariaLabel","supportsMobileScreenReader","getItemAriaLabel","name","toString","accessibleLabel","_createElement","key","getNextItem","info","viewportEndIndex","isNavigable","nextItemInGroup","getNextItemInGroup","nextItem","getPreviousItem","viewportStartIndex","prevItemInGroup","getPrevItemInGroup","prevItem","hideAndShowBehavior","yAxis","groups","selectionMode","direction","useUser","hiddenSet","Set","xAxis","selectedSet","highlightedSet","Chart","renderGridLinesInFront","findNearest","gapRatio","getSeriesDataInfo","dataWidth","getSeriesOffsetAndWidth","findNearestDataPoint","scale","getDataItemPos","index","xVal","val","getBarPosition","getNavUtil","startIndex","endIndex","isItemNavigable","barItem","Boolean","itemInfo","arrow","newInfo","getNextItemInSeries","getPrevItemInSeries","getBarChartNavUtil","getGapRatio","getBarGapRatio","getMarkerInfo","getItemColor","type","getMarkerType","xStartIndex","xEndIndex","slice","map","_"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define(['exports', 'preact/jsx-runtime', './PRIVATE_Chart/themes/ChartStyles.css', './TrackResizeContainer-74ef32df', './useTextDimensions-b37344b4', './useCssVars-c043f8da', 'preact/hooks', './Gridlines-b1d59999', './useId-c9578d26', './Axis-6cddf1d3', './useChartViewport-ca564baa', './layoutUtils-ac40a238', './useChartNav-5ff92999', './mergeProps-bcfa6a92', './
|
|
2
|
-
//# sourceMappingURL=Chart-
|
|
1
|
+
define(['exports', 'preact/jsx-runtime', './PRIVATE_Chart/themes/ChartStyles.css', './TrackResizeContainer-74ef32df', './useTextDimensions-b37344b4', './useCssVars-c043f8da', 'preact/hooks', './Gridlines-b1d59999', './useId-c9578d26', './Axis-6cddf1d3', './useChartViewport-ca564baa', './layoutUtils-ac40a238', './useChartNav-5ff92999', './mergeProps-bcfa6a92', './useSelectDrill-a7d833b6', './useUser-85c781ea', './useTestId-3a316499', './cssUtils-577028f8', './useChartContextMenu-673e3de0', './eventsUtils-5d567a9d', './accUtils-1557920a', 'preact/compat', './LayerHost-e95c5f30', 'css!./LayerStyles.styles.css', './Floating-a658b79c', 'css!./useDatatip.styles.css', './datatipUtils-1b8ab042', './util-5bb1f200', './useTooltip-6a5fedfa', './logger-0f873e29', 'css!./TooltipContentStyles.styles.css', 'module', './hooks/UNSAFE_useTooltip/themes/redwood/TooltipContentVariants.css', './tooltipUtils-3b34c2bc', './useChartMarquee-62e7676c', './useVisTouchResponse-36416652', './stringUtils-0ae982c2', './ScrollBar-4046f84f'], (function(e,t,o,s,i,r,n,a,l,d,u,c,p,x,g,f,h,I,m,C,y,S,b,v,A,D,M,P,T,w,R,V,E,G,N,j,k,F){"use strict";function U(e,t,o){const s=e.groupIndex+1;if(!(s>=t))return o(s)?{groupIndex:s}:U({groupIndex:s},t,o)}function z(e,t){const o=e.groupIndex-1;if(!(o<0))return t(o)?{groupIndex:o}:z({groupIndex:o},t)}const B=I.getChartVars();function L({width:e,height:s,selectedIds:I,hiddenIds:y,hideAndShowBehavior:S="none",orientation:b="vertical",xAxis:v,yAxis:A,plotArea:D,dragMode:M="user",series:w,groups:R,isStacked:V=!1,getDataItem:E,selectionMode:G="none",drilling:L="off",dataCursorPosition:q,onSelectionChange:H,isDataCursorEnabled:O,dataCursorStyle:W,onViewportChange:$,onDataCursorPositionChange:_,onItemDrill:Y,onGroupDrill:Z,onItemHover:J,onItemFocus:K,datatip:Q,zoomAndScroll:X="off",offset:ee,getNavUtil:te,getDataItemPos:oe,getGapRatio:se,valueFormats:ie,findNearest:re,getMarkerInfo:ne,isRtl:ae,children:le,testId:de,renderGridLinesInFront:ue,contextMenuConfig:ce,...pe}){const xe=h.useTestId(de),ge=n.useRef(null),fe="horizontal"===b,{xAxisPosition:he,yAxisPosition:Ie}=c.getAxesPosition(A,fe,ae),{resolvedVars:me,cssContent:Ce}=r.useCssVars(B),ye=Array.from(Array(12)).map(((e,t)=>me[`color${t+1}`])),{textMeasureContent:Se,getTextDimensions:be}=i.useTextDimensions();let ve=c.getAvailSpace(e,s);const Ae=c.getScrollBarSpace(ve,X,he);let De=Ae.scrollDims;ve=Ae.availSpace;const Me=new Set(y),{locale:Pe}=f.useUser(),{xProps:Te,xScale:we,xViewportExtent:Re,xAxisExtent:Ve,xIndexExtent:Ee,yViewportExtent:Ge,yAxisExtent:Ne,groupWidth:je,yProps:ke,yScale:Fe,yMaxDim:Ue,yMajorTicks:ze,yMinorTicks:Be,plotAreaSpace:Le,idToDataMap:qe,formatAxisLabel:He,formatYValue:Oe}=c.getLayoutInfo(w,R,E,v,A,ve,Me,S,fe,ae,V,me.labelFontSize,ee,Pe,be);De=c.updateScrollBarSpace(De,"bottom"===he,ae,Ue);const We=se(Ee.startIndex,Ee.endIndex),$e=te(Ee.startIndex,Ee.endIndex),_e=Te.tickLabels.map((({index:e})=>e+Ee.startIndex)),{getNextNavGroup:Ye,getDefaultNavGroup:Ze}=function(e,t,o,s,i){const r=o=>{const i=e[t[o]].drilling;return("on"===s||"groupsOnly"===s)&&"off"!=i},n=e=>o.startIndex>t[e.groupIndex]?(e.groupIndex=0,e):o.endIndex<t[e.groupIndex]?(e.groupIndex=t.length-1,e):void 0;return{getDefaultNavGroup:n,getNextNavGroup:(e,o)=>{let s=n(e);return s||(s="ArrowRight"===o?i?z(e,r):U(e,t.length,r):i?U(e,t.length,r):z(e,r),s||e)}}}(R,_e,Ee,L,ae),{cursor:Je,marqueeProps:Ke,marqueeContent:Qe,toggleButtonContent:Xe,isPointInsideMarquee:et,dragMode:tt}=N.useChartMarquee({plotAreaSpace:Le,dragMode:M,chartWidth:e,isMultiSelection:"multiple"===G,onViewportChange:$,isZoomScroll:"live"===X,xAxisExtent:Ve,xScale:we,selectedIds:I,getDataById:e=>qe.get(e),onSelectionChange:H,viewportMax:Re.viewportMax,viewportMin:Re.viewportMin,isRtl:ae}),{touchResponse:ot,touchResponseStyle:st}=j.useVisTouchResponse({type:"auto",supportsTouchDragGestures:"off"!==tt,rootRef:ge}),{activeId:it,focusedItemInfo:rt,hoveredItemInfo:nt,focusedGroupInfo:at,navProps:lt,onFocusUpdate:dt}=p.useChartNav({rootRef:ge,getNextChartItem:$e,getNextNavGroup:Ye,getDefaultNavGroup:Ze,touchResponse:ot,onItemHover:J,onItemFocus:K,drilling:L,xIndexExtent:Ee}),{tooltipContent:ut,tooltipProps:ct}=function({getTextAndBounds:e,width:t,isRtl:o}){const[s,i]=n.useState(),r=n.useRef(),{tooltipContent:a,tooltipProps:l}=T.useTooltip({text:s,position:"top-start",offset:P.calculateOffset(o,t,r.current)});return{tooltipContent:a,tooltipProps:x.mergeProps({onPointerMove:t=>{const o=e(t.target);o?(r.current=o.bounds,i(o.text)):i(void 0)}},l)}}({getTextAndBounds:e=>{if(e!=ge.current){const t=C.getElementData(ge,e),o=t?.ojText;if(!o)return;if(o===v?.title)return{text:o,bounds:Te.titleProps?.dims};if(o===A?.title)return{text:o,bounds:ke.titleProps?.dims};if(t?.ojGroupIndex){const e=parseInt(t.ojGroupIndex);return{bounds:Te.tickLabels[e].dims,text:o}}}if(e===ge.current&&at.isFocusVisible){const e=R[at.groupIndex];return{bounds:Te.tickLabels[at.groupIndex].dims,text:e.name||e.id}}},width:e,isRtl:ae}),{selectDrillProps:pt,selectionContent:xt}=g.useSelectDrill({selectionMode:G,selection:[...I],onChange:H,rootRef:ge,drilling:L,onItemDrill:Y,onGroupDrill:Z,focusedGroupInfo:at,focusedItemInfo:rt,groups:R,getDataItem:E,getDataById:e=>qe.get(e)}),gt=u.useChartViewport({rootRef:ge,width:e,height:s,xViewportExtent:Re,yViewportExtent:Ge,xAxisExtent:Ve,yAxisExtent:Ne,xScale:we,yScale:Fe,plotAreaSpace:Le,isRtl:ae,isHoriz:fe,zoomAndScroll:X,onViewportChange:$}),ft=re(we,Fe,je,We),ht=oe(we,Fe,je,We),{datatipContent:It,dataCursorContent:mt,datatipProps:{"aria-describedby":Ct,...yt}}=g.useChartDatatipAndCursor({series:w,groups:R,width:e,height:s,findNearest:ft,plotAreaSpace:Le,onDataCursorPositionChange:_,isDataCursorEnabled:O,dataCursorPosition:q,dataCursorStyle:W,hoveredItemInfo:nt,focusedItemInfo:rt,getDataItem:E,getMarkerInfo:ne,getDataItemPos:ht,datatip:Q,valueFormats:ie,isHoriz:fe,touchResponse:ot,isDisabled:"off"!=tt,xScale:we,yScale:Fe,timeAxisType:v?.timeAxisType,formatAxisLabel:He,formatYValue:Oe}),St=l.useId(),{viewportMin:bt,viewportMax:vt}=Re,{startIndex:At,endIndex:Dt}=Ee,Mt=t.jsx(a.Gridlines,{plotArea:D,yMinorTicks:Be,xScale:we,yScale:Fe,isLog:"log"===A?.scale,xViewportMin:bt,xViewportMax:vt,yTicks:ze,yAxisPosition:Ie}),{contextMenuContent:Pt,contextMenuProps:Tt}=m.useChartContextMenu({series:w,groups:R,getDataItem:E,focusedItemInfo:rt,rootRef:ge,xAxisTitle:v?.title,yAxisTitle:A?.title,contextMenuConfig:ce,onContextMenuDismissed:e=>{"keyboard"===e&&dt()}}),wt=x.mergeProps(lt,pt,gt,yt,Ke,ct,Tt);return t.jsxs("div",{tabIndex:0,ref:ge,"aria-activedescendant":it,"aria-label":pe["aria-label"],"aria-labelledby":pe["aria-labelledby"],"aria-describedby":k.merge([pe["aria-describedby"],Ct]),style:st,role:"application",className:o.styles.baseChartStyle,...xe,...wt,children:[t.jsxs("svg",{width:"100%",height:"100%",children:[t.jsx("clipPath",{id:`${St}`,children:t.jsx("rect",{...Le})}),t.jsx(a.PlotArea,{color:D?.color,yScale:Fe,cursor:Je,isLog:"log"===A?.scale,availSpace:Le,xAxisPosition:he}),!ue&&Mt,t.jsx(d.Axis,{...ke,axisPosition:Ie,isRtl:ae}),t.jsx(d.Axis,{...Te,isRtl:ae,axisPosition:he,isTextInteractive:e=>{if(null!=v?.timeAxisType)return!1;const t=R[e].drilling;return"on"===t||"off"!=t&&("on"===L||"groupsOnly"===L)},activeId:it,focusedGroupIndex:at.isFocusVisible?at.groupIndex:void 0}),t.jsxs("g",{"clip-path":`url(#${St})`,children:[le({xStartIndex:At,xEndIndex:Dt,colors:ye,xScale:we,yScale:Fe,isPointInsideMarquee:et,defaultFontSize:me.labelFontSize,gapRatio:We,activeId:it,focusedItemInfo:rt,hoveredItemInfo:nt,getTextDimensions:be,groupWidth:je}),ue&&Mt,mt]}),"live"===X&&t.jsx(F.ScrollBar,{availSpace:De,isRtl:ae,viewport:Re,axisExtent:Ve,isHoriz:"bottom"===he}),Qe]}),Xe,Se,Ce,It,ut,Pt,xt]})}e.Chart=function({width:e,height:i,...r}){return t.jsx(s.TrackResizeContainer,{width:e,height:i,class:o.dimensionStyle,children:(e,o)=>e||o?t.jsx(L,{width:e,height:o,...r}):void 0})}}));
|
|
2
|
+
//# sourceMappingURL=Chart-96ea9fed.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Chart-1046ac5b.js","sources":["../../src/PRIVATE_Axis/utils/axisNavUtils.ts","../../src/PRIVATE_Chart/ChartWithDimensions.tsx","../../src/PRIVATE_VisSVGText/useTextTruncation.ts","../../src/PRIVATE_Chart/Chart.tsx"],"sourcesContent":["/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { Group, ChartGroupInfo } from '../../utils/UNSAFE_visTypes/chart';\ntype isGroupNavigableType = (groupIndex: number) => boolean;\n\nexport function getNextGroup(\n info: ChartGroupInfo,\n viewportEndIndex: number,\n isGroupNavigable: isGroupNavigableType\n): ChartGroupInfo | undefined {\n const groupIndex = info.groupIndex + 1;\n if (groupIndex >= viewportEndIndex) {\n return;\n }\n\n if (isGroupNavigable(groupIndex)) {\n return { groupIndex };\n }\n return getNextGroup({ groupIndex }, viewportEndIndex, isGroupNavigable);\n}\n\nexport function getPreviousGroup(\n info: ChartGroupInfo,\n isGroupNavigable: isGroupNavigableType\n): ChartGroupInfo | undefined {\n const groupIndex = info.groupIndex - 1;\n if (groupIndex < 0) {\n return;\n }\n if (isGroupNavigable(groupIndex)) {\n return { groupIndex };\n }\n return getPreviousGroup({ groupIndex }, isGroupNavigable);\n}\n\nexport function getGroupNavUtil(\n groups: Group[],\n renderedGroups: number[],\n xIndexExtent: { startIndex: number; endIndex: number },\n drilling: 'on' | 'off' | 'groupsOnly',\n isRtl: boolean\n) {\n const isGroupNavigable = (groupIndex: number) => {\n const groupsDrilling = groups[renderedGroups[groupIndex]].drilling;\n return (drilling === 'on' || drilling === 'groupsOnly') && groupsDrilling != 'off';\n };\n\n const getDefaultNavGroup = (info: ChartGroupInfo) => {\n if (xIndexExtent.startIndex > renderedGroups[info.groupIndex]) {\n info.groupIndex = 0;\n return info;\n } else if (xIndexExtent.endIndex < renderedGroups[info.groupIndex]) {\n info.groupIndex = renderedGroups.length - 1;\n return info;\n }\n return;\n };\n\n const getNextNavGroup = (info: ChartGroupInfo, arrow: 'ArrowRight' | 'ArrowLeft') => {\n let nextGroup = getDefaultNavGroup(info);\n\n if (nextGroup) return nextGroup;\n\n if (arrow === 'ArrowRight') {\n nextGroup = isRtl\n ? getPreviousGroup(info, isGroupNavigable)\n : getNextGroup(info, renderedGroups.length, isGroupNavigable);\n } else {\n nextGroup = isRtl\n ? getNextGroup(info, renderedGroups.length, isGroupNavigable)\n : getPreviousGroup(info, isGroupNavigable);\n }\n return nextGroup || info;\n };\n\n return { getDefaultNavGroup, getNextNavGroup };\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { useTextDimensions } from '../hooks/PRIVATE_useTextDimensions';\nimport { useCssVars } from '../hooks/PRIVATE_useCssVars/useCssVars';\nimport { styles } from './themes/ChartStyles.css';\nimport { useRef } from 'preact/hooks';\nimport { PlotArea } from '../PRIVATE_PlotArea';\nimport { useId } from '../hooks/UNSAFE_useId';\nimport { Axis } from '../PRIVATE_Axis/Axis';\nimport { useChartViewport } from '../hooks/PRIVATE_useChartViewport';\nimport {\n getAvailSpace,\n getLayoutInfo,\n getScrollBarSpace,\n updateScrollBarSpace\n} from '../utils/PRIVATE_chartUtils/layoutUtils';\nimport { useChartNav } from '../hooks/PRIVATE_useChartNav/useChartNav';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { getAxesPosition } from '../PRIVATE_Axis/utils/axisUtils';\nimport { ScrollBar } from '../PRIVATE_ChartScrollBar';\nimport { useSelectDrill } from '../hooks/PRIVATE_useChartEvents/useSelectDrill';\nimport { useChartDatatipAndCursor } from '../hooks/PRIVATE_useChartEvents/useDatatipAndCursor';\nimport { getGroupNavUtil } from '../PRIVATE_Axis/utils/axisNavUtils';\nimport { ChartItemData, TimeAxisProps } from '../utils/UNSAFE_visTypes/chart';\nimport { Gridlines } from '../PRIVATE_PlotArea/Gridlines';\nimport { useUser } from '../hooks/UNSAFE_useUser';\nimport { useTestId } from '../hooks/UNSAFE_useTestId';\nimport { getChartVars } from '../utils/PRIVATE_chartUtils';\nimport { useChartContextMenu } from '#hooks/PRIVATE_useChartContextMenu';\nimport { getElementData } from '#utils/UNSAFE_visUtils';\nimport { useTextTruncation } from '#PRIVATE_VisSVGText/useTextTruncation';\nimport { useChartMarquee } from '#hooks/PRIVATE_useChartMarquee';\nimport { ChartProps } from './Chart';\nimport type { gestureTypes } from '#hooks/PRIVATE_useVisContextMenu';\nimport { useVisTouchResponse } from '#hooks/PRIVATE_useVisTouchResponse';\nimport { merge } from '#utils/UNSAFE_stringUtils';\n\ntype ChartWithDimensionsProps<K, D> = Omit<ChartProps<K, D>, 'width' | 'height'> & {\n width: number;\n height: number;\n};\n\nconst chartVars = getChartVars();\n\nexport function ChartWithDimensions<K extends string | number, D extends ChartItemData<K>>({\n width,\n height,\n selectedIds,\n hiddenIds,\n hideAndShowBehavior = 'none',\n orientation = 'vertical',\n xAxis,\n yAxis,\n plotArea,\n dragMode = 'user',\n series,\n groups,\n isStacked = false,\n getDataItem,\n selectionMode = 'none',\n drilling = 'off',\n dataCursorPosition,\n onSelectionChange,\n isDataCursorEnabled,\n dataCursorStyle,\n onViewportChange,\n onDataCursorPositionChange,\n onItemDrill,\n onGroupDrill,\n onItemHover,\n onItemFocus,\n datatip,\n zoomAndScroll = 'off',\n offset,\n getNavUtil,\n getDataItemPos,\n getGapRatio,\n valueFormats,\n findNearest,\n getMarkerInfo,\n isRtl,\n children,\n testId,\n renderGridLinesInFront,\n contextMenuConfig,\n ...props\n}: ChartWithDimensionsProps<K, D>) {\n const testIdProps = useTestId(testId);\n const rootRef = useRef<HTMLDivElement>(null);\n const isHoriz = orientation === 'horizontal';\n const { xAxisPosition, yAxisPosition } = getAxesPosition(yAxis, isHoriz, isRtl);\n const { resolvedVars, cssContent } = useCssVars(chartVars);\n const colors = Array.from(Array(12)).map((_, index) => {\n return resolvedVars[`color${index + 1}`];\n });\n const { textMeasureContent, getTextDimensions } = useTextDimensions();\n let availSpace = getAvailSpace(width, height);\n const updatedSpace = getScrollBarSpace(availSpace, zoomAndScroll, xAxisPosition);\n let scrollDims = updatedSpace.scrollDims;\n availSpace = updatedSpace.availSpace;\n const hiddenSet = new Set(hiddenIds);\n const { locale } = useUser();\n const {\n xProps,\n xScale,\n xViewportExtent,\n xAxisExtent,\n xIndexExtent,\n yViewportExtent,\n yAxisExtent,\n groupWidth,\n yProps,\n yScale,\n yMaxDim,\n yMajorTicks,\n yMinorTicks,\n plotAreaSpace,\n idToDataMap,\n formatAxisLabel,\n formatYValue\n } = getLayoutInfo<K, D>(\n series,\n groups,\n getDataItem,\n xAxis,\n yAxis,\n availSpace,\n hiddenSet,\n hideAndShowBehavior,\n isHoriz,\n isRtl,\n isStacked,\n resolvedVars['labelFontSize'],\n offset,\n locale,\n getTextDimensions\n );\n\n scrollDims = updateScrollBarSpace(scrollDims, xAxisPosition === 'bottom', isRtl, yMaxDim);\n\n const gapRatio = getGapRatio(xIndexExtent.startIndex, xIndexExtent.endIndex);\n\n const getNextChartItem = getNavUtil(xIndexExtent.startIndex, xIndexExtent.endIndex);\n\n const renderedGroupsIndex = xProps.tickLabels.map(({ index }) => index + xIndexExtent.startIndex);\n const { getNextNavGroup, getDefaultNavGroup } = getGroupNavUtil(\n groups,\n renderedGroupsIndex,\n xIndexExtent,\n drilling,\n isRtl\n );\n\n const {\n cursor,\n marqueeProps,\n marqueeContent,\n toggleButtonContent,\n isPointInsideMarquee,\n dragMode: mode\n } = useChartMarquee<K, D>({\n plotAreaSpace,\n dragMode,\n chartWidth: width,\n isMultiSelection: selectionMode === 'multiple',\n onViewportChange,\n isZoomScroll: zoomAndScroll === 'live',\n xAxisExtent,\n xScale,\n selectedIds,\n getDataById: (id) => idToDataMap.get(id),\n onSelectionChange,\n viewportMax: xViewportExtent.viewportMax,\n viewportMin: xViewportExtent.viewportMin,\n isRtl\n });\n\n const { touchResponse, touchResponseStyle } = useVisTouchResponse({\n type: 'auto',\n supportsTouchDragGestures: mode !== 'off',\n rootRef\n });\n\n const { activeId, focusedItemInfo, hoveredItemInfo, focusedGroupInfo, navProps, onFocusUpdate } =\n useChartNav({\n rootRef,\n getNextChartItem,\n getNextNavGroup,\n getDefaultNavGroup,\n touchResponse,\n onItemHover,\n onItemFocus,\n drilling,\n xIndexExtent\n });\n\n const onContextMenuDismissed = (gesture: gestureTypes) => {\n if (gesture === 'keyboard') {\n onFocusUpdate();\n }\n };\n\n const getTextAndBounds = (target: EventTarget | null) => {\n if (target != rootRef.current) {\n const dataSet = getElementData(rootRef, target as HTMLElement);\n const text = dataSet?.['ojText']!;\n\n if (!text) {\n return;\n }\n\n if (text === xAxis?.title) {\n return {\n text,\n bounds: xProps.titleProps?.dims\n };\n } else if (text === yAxis?.title) {\n return {\n text,\n bounds: yProps.titleProps?.dims\n };\n } else if (dataSet?.['ojGroupIndex']) {\n const index = parseInt(dataSet['ojGroupIndex']);\n return {\n bounds: xProps.tickLabels[index].dims,\n text: text!\n };\n }\n }\n\n if (target === rootRef.current && focusedGroupInfo.isFocusVisible) {\n const group = groups[focusedGroupInfo.groupIndex];\n return {\n bounds: xProps.tickLabels[focusedGroupInfo.groupIndex].dims,\n text: group.name || group.id\n };\n }\n return;\n };\n\n const { tooltipContent, tooltipProps } = useTextTruncation({\n getTextAndBounds,\n width,\n isRtl\n });\n\n const { selectDrillProps, selectionContent } = useSelectDrill<K, D>({\n selectionMode,\n selection: [...selectedIds],\n onChange: onSelectionChange,\n rootRef,\n drilling,\n onItemDrill,\n onGroupDrill,\n focusedGroupInfo,\n focusedItemInfo,\n groups,\n getDataItem,\n getDataById: (id) => idToDataMap.get(id)\n });\n\n const viewportProps = useChartViewport({\n rootRef,\n width,\n height,\n xViewportExtent,\n yViewportExtent,\n xAxisExtent,\n yAxisExtent,\n xScale,\n yScale,\n plotAreaSpace,\n isRtl,\n isHoriz,\n zoomAndScroll,\n onViewportChange\n });\n\n const findNearestData = findNearest(xScale as any, yScale, groupWidth, gapRatio);\n const getDataItemPosition = getDataItemPos(xScale as any, yScale, groupWidth, gapRatio);\n\n const {\n datatipContent,\n dataCursorContent,\n datatipProps: { 'aria-describedby': datatipAriaDescribedby, ...datatipProps }\n } = useChartDatatipAndCursor<K, D>({\n series,\n groups,\n width,\n height,\n findNearest: findNearestData,\n plotAreaSpace,\n onDataCursorPositionChange,\n isDataCursorEnabled,\n dataCursorPosition,\n dataCursorStyle,\n hoveredItemInfo,\n focusedItemInfo,\n getDataItem,\n getMarkerInfo,\n getDataItemPos: getDataItemPosition,\n datatip,\n valueFormats,\n isHoriz,\n touchResponse,\n isDisabled: mode != 'off',\n xScale: xScale as any,\n yScale,\n timeAxisType: (xAxis as TimeAxisProps)?.timeAxisType,\n formatAxisLabel,\n formatYValue\n });\n\n const isGroupInteractive = (index: number) => {\n if ((xAxis as TimeAxisProps)?.timeAxisType != null) {\n return false;\n }\n const groupDrill = groups[index].drilling;\n if (groupDrill === 'on') {\n return true;\n }\n\n if (groupDrill != 'off' && (drilling === 'on' || drilling === 'groupsOnly')) {\n return true;\n }\n return false;\n };\n\n const plotAreaClipPathId = useId();\n const { viewportMin: xViewportMin, viewportMax: xViewportMax } = xViewportExtent;\n const { startIndex: xStartIndex, endIndex: xEndIndex } = xIndexExtent;\n const gridLines = (\n <Gridlines\n plotArea={plotArea}\n yMinorTicks={yMinorTicks}\n xScale={xScale}\n yScale={yScale}\n isLog={yAxis?.scale === 'log'}\n xViewportMin={xViewportMin}\n xViewportMax={xViewportMax}\n yTicks={yMajorTicks}\n yAxisPosition={yAxisPosition}\n />\n );\n const { contextMenuContent, contextMenuProps } = useChartContextMenu<K, D>({\n series,\n groups,\n getDataItem,\n focusedItemInfo,\n rootRef,\n xAxisTitle: xAxis?.title,\n yAxisTitle: yAxis?.title,\n contextMenuConfig,\n onContextMenuDismissed\n });\n\n const eventsProps = mergeProps(\n navProps,\n selectDrillProps,\n viewportProps,\n datatipProps,\n marqueeProps,\n tooltipProps,\n contextMenuProps\n );\n\n return (\n <div\n tabIndex={0}\n ref={rootRef}\n aria-activedescendant={activeId}\n aria-label={props['aria-label']}\n aria-labelledby={props['aria-labelledby']}\n aria-describedby={merge([props['aria-describedby'], datatipAriaDescribedby])}\n style={touchResponseStyle}\n role=\"application\"\n className={styles.baseChartStyle}\n {...testIdProps}\n {...eventsProps}>\n <svg width=\"100%\" height=\"100%\">\n <clipPath id={`${plotAreaClipPathId}`}>\n <rect {...plotAreaSpace}></rect>\n </clipPath>\n <PlotArea\n color={plotArea?.color}\n yScale={yScale}\n cursor={cursor}\n isLog={yAxis?.scale === 'log'}\n availSpace={plotAreaSpace}\n xAxisPosition={xAxisPosition}\n />\n {!renderGridLinesInFront && gridLines}\n <Axis {...(yProps as any)} axisPosition={yAxisPosition} isRtl={isRtl} />\n <Axis\n {...xProps}\n isRtl={isRtl}\n axisPosition={xAxisPosition}\n isTextInteractive={isGroupInteractive}\n activeId={activeId}\n focusedGroupIndex={\n focusedGroupInfo.isFocusVisible ? focusedGroupInfo.groupIndex : undefined\n }\n />\n <g clip-path={`url(#${plotAreaClipPathId})`}>\n {children({\n xStartIndex,\n xEndIndex,\n colors,\n xScale: xScale as any,\n yScale,\n isPointInsideMarquee,\n defaultFontSize: resolvedVars['labelFontSize'],\n gapRatio,\n activeId,\n focusedItemInfo,\n hoveredItemInfo,\n getTextDimensions,\n groupWidth\n })}\n {renderGridLinesInFront && gridLines}\n {dataCursorContent}\n </g>\n {zoomAndScroll === 'live' && (\n <ScrollBar\n availSpace={scrollDims}\n isRtl={isRtl}\n viewport={xViewportExtent}\n axisExtent={xAxisExtent}\n isHoriz={xAxisPosition === 'bottom'}\n />\n )}\n {marqueeContent}\n </svg>\n {toggleButtonContent}\n {textMeasureContent}\n {cssContent}\n {datatipContent}\n {tooltipContent}\n {contextMenuContent}\n {selectionContent}\n </div>\n );\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { Dimension } from '#utils/UNSAFE_visTypes/common';\nimport { calculateOffset } from '#hooks/PRIVATE_useDatatip';\nimport { useTooltip } from '#hooks/UNSAFE_useTooltip';\nimport { mergeProps } from '#utils/UNSAFE_mergeProps';\nimport { useRef, useState } from 'preact/hooks';\n\ntype Props = {\n getTextAndBounds: (target: EventTarget | null) =>\n | {\n text?: string;\n bounds?: Dimension;\n }\n | undefined;\n isRtl: boolean;\n width: number;\n};\n\nexport function useTextTruncation({ getTextAndBounds, width, isRtl }: Props) {\n const [text, setText] = useState<string>();\n const bounds = useRef<Dimension>();\n\n const { tooltipContent, tooltipProps } = useTooltip({\n text,\n position: 'top-start',\n offset: calculateOffset(isRtl, width, bounds.current)\n });\n\n const onPointerMove = (event: Event) => {\n const textAndBounds = getTextAndBounds(event.target);\n\n if (textAndBounds) {\n bounds.current = textAndBounds.bounds;\n setText(textAndBounds.text);\n } else {\n setText(undefined);\n }\n };\n\n return {\n tooltipContent,\n tooltipProps: mergeProps({ onPointerMove }, tooltipProps)\n };\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { dimensionStyle } from './themes/ChartStyles.css';\nimport { TrackResizeContainer } from '../PRIVATE_TrackResizeContainer';\nimport { ChartWithDimensions } from './ChartWithDimensions';\nimport {\n ChartItemData,\n ChartCommonProps,\n ChartSeriesData,\n GetNextChartItemType,\n Info,\n Scale,\n getDataPosType\n} from '../utils/UNSAFE_visTypes/chart';\nimport { Dimension, MarkerShapes } from '#utils/UNSAFE_visTypes/common';\nimport { VNode } from 'preact';\nimport { Property } from 'csstype';\n\nexport type ChartProps<K, D> = {\n selectedIds: Set<K>;\n getGapRatio: (startIndex: number, endIndex: number) => number;\n getNavUtil: (startIndex: number, endIndex: number) => GetNextChartItemType;\n getDataItemPos: (\n xScale: Scale,\n yScale: Scale,\n groupWidth: number,\n gapRatio: number\n ) => getDataPosType;\n findNearest: (\n xScale: Scale,\n yScale: Scale,\n groupWidth: number,\n gapRatio: number\n ) => (\n x: number,\n y: number\n ) =>\n | {\n seriesIndex: number;\n groupIndex: number;\n y: number | undefined;\n x: number;\n }\n | undefined;\n children: (context: {\n xStartIndex: number;\n xEndIndex: number;\n xScale: Scale;\n yScale: Scale;\n gapRatio: number;\n activeId?: string;\n focusedItemInfo: Info;\n hoveredItemInfo?: Info;\n groupWidth: number;\n isPointInsideMarquee: ((id: K, point: { x: number; y: number }) => boolean) | undefined;\n getTextDimensions?: (text: string, style: Record<string, any>) => Dimension;\n defaultFontSize: string;\n colors: string[];\n }) => VNode;\n offset: number;\n series: ChartSeriesData<K, D>[];\n isRtl: boolean;\n renderGridLinesInFront: boolean;\n getMarkerInfo: (\n seriesIndex: number,\n groupIndex: number\n ) => { color: Property.Color | undefined; type?: MarkerShapes };\n} & Omit<ChartCommonProps<K, D>, 'highlightedIds' | 'hoverBehavior' | 'selectedIds'>;\n\nexport function Chart<K extends string | number, D extends ChartItemData<K>>({\n width,\n height,\n ...props\n}: ChartProps<K, D>) {\n // TODO: reevaluate how we handle empty data\n return (\n <TrackResizeContainer width={width} height={height} class={dimensionStyle}>\n {(width, height) =>\n width || height ? (\n <ChartWithDimensions width={width} height={height} {...props} />\n ) : undefined\n }\n </TrackResizeContainer>\n );\n}\n"],"names":["getNextGroup","info","viewportEndIndex","isGroupNavigable","groupIndex","getPreviousGroup","chartVars","getChartVars","ChartWithDimensions","width","height","selectedIds","hiddenIds","hideAndShowBehavior","orientation","xAxis","yAxis","plotArea","dragMode","series","groups","isStacked","getDataItem","selectionMode","drilling","dataCursorPosition","onSelectionChange","isDataCursorEnabled","dataCursorStyle","onViewportChange","onDataCursorPositionChange","onItemDrill","onGroupDrill","onItemHover","onItemFocus","datatip","zoomAndScroll","offset","getNavUtil","getDataItemPos","getGapRatio","valueFormats","findNearest","getMarkerInfo","isRtl","children","testId","renderGridLinesInFront","contextMenuConfig","props","testIdProps","useTestId","rootRef","useRef","isHoriz","xAxisPosition","yAxisPosition","getAxesPosition","resolvedVars","cssContent","useCssVars","colors","Array","from","map","_","index","textMeasureContent","getTextDimensions","useTextDimensions","availSpace","getAvailSpace","updatedSpace","getScrollBarSpace","scrollDims","hiddenSet","Set","locale","useUser","xProps","xScale","xViewportExtent","xAxisExtent","xIndexExtent","yViewportExtent","yAxisExtent","groupWidth","yProps","yScale","yMaxDim","yMajorTicks","yMinorTicks","plotAreaSpace","idToDataMap","formatAxisLabel","formatYValue","getLayoutInfo","updateScrollBarSpace","gapRatio","startIndex","endIndex","getNextChartItem","renderedGroupsIndex","tickLabels","getNextNavGroup","getDefaultNavGroup","renderedGroups","groupsDrilling","length","arrow","nextGroup","getGroupNavUtil","cursor","marqueeProps","marqueeContent","toggleButtonContent","isPointInsideMarquee","mode","useChartMarquee","chartWidth","isMultiSelection","isZoomScroll","getDataById","id","get","viewportMax","viewportMin","touchResponse","touchResponseStyle","useVisTouchResponse","type","supportsTouchDragGestures","activeId","focusedItemInfo","hoveredItemInfo","focusedGroupInfo","navProps","onFocusUpdate","useChartNav","tooltipContent","tooltipProps","getTextAndBounds","text","setText","useState","bounds","useTooltip","position","calculateOffset","current","mergeProps","onPointerMove","event","textAndBounds","target","undefined","useTextTruncation","dataSet","getElementData","title","titleProps","dims","parseInt","isFocusVisible","group","name","selectDrillProps","selectionContent","useSelectDrill","selection","onChange","viewportProps","useChartViewport","findNearestData","getDataItemPosition","datatipContent","dataCursorContent","datatipProps","datatipAriaDescribedby","useChartDatatipAndCursor","isDisabled","timeAxisType","plotAreaClipPathId","useId","xViewportMin","xViewportMax","xStartIndex","xEndIndex","gridLines","_jsx","Gridlines","isLog","scale","yTicks","contextMenuContent","contextMenuProps","useChartContextMenu","xAxisTitle","yAxisTitle","onContextMenuDismissed","gesture","eventsProps","_jsxs","jsxs","tabIndex","ref","merge","style","role","className","styles","baseChartStyle","jsx","PlotArea","color","Axis","axisPosition","isTextInteractive","groupDrill","focusedGroupIndex","defaultFontSize","ScrollBar","viewport","axisExtent","TrackResizeContainer","class","dimensionStyle"],"mappings":"koCAUgBA,EACdC,EACAC,EACAC,GAEA,MAAMC,EAAaH,EAAKG,WAAa,EACrC,KAAIA,GAAcF,GAIlB,OAAIC,EAAiBC,GACZ,CAAEA,cAEJJ,EAAa,CAAEI,cAAcF,EAAkBC,EACxD,CAEgB,SAAAE,EACdJ,EACAE,GAEA,MAAMC,EAAaH,EAAKG,WAAa,EACrC,KAAIA,EAAa,GAGjB,OAAID,EAAiBC,GACZ,CAAEA,cAEJC,EAAiB,CAAED,cAAcD,EAC1C,CCUA,MAAMG,EAAYC,EAAYA,eAExB,SAAUC,GAA2EC,MACzFA,EAAKC,OACLA,EAAMC,YACNA,EAAWC,UACXA,EAASC,oBACTA,EAAsB,OAAMC,YAC5BA,EAAc,WAAUC,MACxBA,EAAKC,MACLA,EAAKC,SACLA,EAAQC,SACRA,EAAW,OAAMC,OACjBA,EAAMC,OACNA,EAAMC,UACNA,GAAY,EAAKC,YACjBA,EAAWC,cACXA,EAAgB,OAAMC,SACtBA,EAAW,MAAKC,mBAChBA,EAAkBC,kBAClBA,EAAiBC,oBACjBA,EAAmBC,gBACnBA,EAAeC,iBACfA,EAAgBC,2BAChBA,EAA0BC,YAC1BA,EAAWC,aACXA,EAAYC,YACZA,EAAWC,YACXA,EAAWC,QACXA,EAAOC,cACPA,EAAgB,MAAKC,OACrBA,GAAMC,WACNA,GAAUC,eACVA,GAAcC,YACdA,GAAWC,aACXA,GAAYC,YACZA,GAAWC,cACXA,GAAaC,MACbA,GAAKC,SACLA,GAAQC,OACRA,GAAMC,uBACNA,GAAsBC,kBACtBA,MACGC,KAEH,MAAMC,GAAcC,YAAUL,IACxBM,GAAUC,SAAuB,MACjCC,GAA0B,eAAhBxC,GACVyC,cAAEA,GAAaC,cAAEA,IAAkBC,EAAeA,gBAACzC,EAAOsC,GAASV,KACnEc,aAAEA,GAAYC,WAAEA,IAAeC,EAAUA,WAACtD,GAC1CuD,GAASC,MAAMC,KAAKD,MAAM,KAAKE,KAAI,CAACC,EAAGC,IACpCR,GAAa,QAAQQ,EAAQ,QAEhCC,mBAAEA,GAAkBC,kBAAEA,IAAsBC,EAAiBA,oBACnE,IAAIC,GAAaC,EAAAA,cAAc9D,EAAOC,GACtC,MAAM8D,GAAeC,EAAiBA,kBAACH,GAAYlC,EAAemB,IAClE,IAAImB,GAAaF,GAAaE,WAC9BJ,GAAaE,GAAaF,WAC1B,MAAMK,GAAY,IAAIC,IAAIhE,IACpBiE,OAAEA,IAAWC,EAAAA,WACbC,OACJA,GAAMC,OACNA,GAAMC,gBACNA,GAAeC,YACfA,GAAWC,aACXA,GAAYC,gBACZA,GAAeC,YACfA,GAAWC,WACXA,GAAUC,OACVA,GAAMC,OACNA,GAAMC,QACNA,GAAOC,YACPA,GAAWC,YACXA,GAAWC,cACXA,GAAaC,YACbA,GAAWC,gBACXA,GAAeC,aACfA,IACEC,EAAAA,cACF7E,EACAC,EACAE,EACAP,EACAC,EACAsD,GACAK,GACA9D,EACAyC,GACAV,GACAvB,EACAqC,GAA4B,cAC5BrB,GACAwC,GACAT,IAGFM,GAAauB,EAAoBA,qBAACvB,GAA8B,WAAlBnB,GAA4BX,GAAO6C,IAEjF,MAAMS,GAAW1D,GAAY2C,GAAagB,WAAYhB,GAAaiB,UAE7DC,GAAmB/D,GAAW6C,GAAagB,WAAYhB,GAAaiB,UAEpEE,GAAsBvB,GAAOwB,WAAWvC,KAAI,EAAGE,WAAYA,EAAQiB,GAAagB,cAChFK,gBAAEA,GAAeC,mBAAEA,ID/GrB,SACJrF,EACAsF,EACAvB,EACA3D,EACAoB,GAEA,MAAMzC,EAAoBC,IACxB,MAAMuG,EAAiBvF,EAAOsF,EAAetG,IAAaoB,SAC1D,OAAqB,OAAbA,GAAkC,eAAbA,IAAgD,OAAlBmF,CAAuB,EAG9EF,EAAsBxG,GACtBkF,EAAagB,WAAaO,EAAezG,EAAKG,aAChDH,EAAKG,WAAa,EACXH,GACEkF,EAAaiB,SAAWM,EAAezG,EAAKG,aACrDH,EAAKG,WAAasG,EAAeE,OAAS,EACnC3G,QAFF,EAwBT,MAAO,CAAEwG,qBAAoBD,gBAjBL,CAACvG,EAAsB4G,KAC7C,IAAIC,EAAYL,EAAmBxG,GAEnC,OAAI6G,IAGFA,EADY,eAAVD,EACUjE,EACRvC,EAAiBJ,EAAME,GACvBH,EAAaC,EAAMyG,EAAeE,OAAQzG,GAElCyC,EACR5C,EAAaC,EAAMyG,EAAeE,OAAQzG,GAC1CE,EAAiBJ,EAAME,GAEtB2G,GAAa7G,EAAI,EAI5B,CCsEkD8G,CAC9C3F,EACAkF,GACAnB,GACA3D,EACAoB,KAGIoE,OACJA,GAAMC,aACNA,GAAYC,eACZA,GAAcC,oBACdA,GAAmBC,qBACnBA,GACAlG,SAAUmG,IACRC,kBAAsB,CACxB1B,iBACA1E,WACAqG,WAAY9G,EACZ+G,iBAAoC,aAAlBjG,EAClBM,mBACA4F,aAAgC,SAAlBrF,EACd8C,eACAF,UACArE,cACA+G,YAAcC,GAAO9B,GAAY+B,IAAID,GACrCjG,oBACAmG,YAAa5C,GAAgB4C,YAC7BC,YAAa7C,GAAgB6C,YAC7BlF,YAGImF,cAAEA,GAAaC,mBAAEA,IAAuBC,sBAAoB,CAChEC,KAAM,OACNC,0BAAoC,QAATd,GAC3BjE,cAGIgF,SAAEA,GAAQC,gBAAEA,GAAeC,gBAAEA,GAAeC,iBAAEA,GAAgBC,SAAEA,GAAQC,cAAEA,IAC9EC,cAAY,CACVtF,WACAiD,oBACAG,mBACAC,sBACAsB,iBACA9F,cACAC,cACAV,WACA2D,mBA+CEwD,eAAEA,GAAcC,aAAEA,IC7NpB,UAA4BC,iBAAEA,EAAgBpI,MAAEA,EAAKmC,MAAEA,IAC3D,MAAOkG,EAAMC,GAAWC,EAAQA,WAC1BC,EAAS5F,EAAAA,UAETsF,eAAEA,EAAcC,aAAEA,GAAiBM,aAAW,CAClDJ,OACAK,SAAU,YACV9G,OAAQ+G,EAAAA,gBAAgBxG,EAAOnC,EAAOwI,EAAOI,WAc/C,MAAO,CACLV,iBACAC,aAAcU,EAAUA,WAAC,CAAEC,cAbNC,IACrB,MAAMC,EAAgBZ,EAAiBW,EAAME,QAEzCD,GACFR,EAAOI,QAAUI,EAAcR,OAC/BF,EAAQU,EAAcX,OAEtBC,OAAQY,EACT,GAK2Cf,GAEhD,CDoM2CgB,CAAkB,CACzDf,iBAvCwBa,IACxB,GAAIA,GAAUtG,GAAQiG,QAAS,CAC7B,MAAMQ,EAAUC,EAAAA,eAAe1G,GAASsG,GAClCZ,EAAOe,GAAkB,OAE/B,IAAKf,EACH,OAGF,GAAIA,IAAS/H,GAAOgJ,MAClB,MAAO,CACLjB,OACAG,OAAQlE,GAAOiF,YAAYC,MAExB,GAAInB,IAAS9H,GAAO+I,MACzB,MAAO,CACLjB,OACAG,OAAQ1D,GAAOyE,YAAYC,MAExB,GAAIJ,GAAwB,aAAG,CACpC,MAAM3F,EAAQgG,SAASL,EAAsB,cAC7C,MAAO,CACLZ,OAAQlE,GAAOwB,WAAWrC,GAAO+F,KACjCnB,KAAMA,EAET,CACF,CAED,GAAIY,IAAWtG,GAAQiG,SAAWd,GAAiB4B,eAAgB,CACjE,MAAMC,EAAQhJ,EAAOmH,GAAiBnI,YACtC,MAAO,CACL6I,OAAQlE,GAAOwB,WAAWgC,GAAiBnI,YAAY6J,KACvDnB,KAAMsB,EAAMC,MAAQD,EAAMzC,GAE7B,CACM,EAKPlH,QACAmC,YAGI0H,iBAAEA,GAAgBC,iBAAEA,IAAqBC,iBAAqB,CAClEjJ,gBACAkJ,UAAW,IAAI9J,GACf+J,SAAUhJ,EACV0B,WACA5B,WACAO,cACAC,eACAuG,oBACAF,mBACAjH,SACAE,cACAoG,YAAcC,GAAO9B,GAAY+B,IAAID,KAGjCgD,GAAgBC,EAAAA,iBAAiB,CACrCxH,WACA3C,QACAC,SACAuE,mBACAG,mBACAF,eACAG,eACAL,UACAQ,UACAI,iBACAhD,SACAU,WACAlB,gBACAP,qBAGIgJ,GAAkBnI,GAAYsC,GAAeQ,GAAQF,GAAYY,IACjE4E,GAAsBvI,GAAeyC,GAAeQ,GAAQF,GAAYY,KAExE6E,eACJA,GAAcC,kBACdA,GACAC,cAAgB,mBAAoBC,MAA2BD,KAC7DE,2BAA+B,CACjChK,SACAC,SACAX,QACAC,SACAgC,YAAamI,GACbjF,iBACA9D,6BACAH,sBACAF,qBACAG,kBACA0G,mBACAD,mBACA/G,cACAqB,iBACAJ,eAAgBuI,GAChB3I,UACAM,gBACAa,WACAyE,iBACAqD,WAAoB,OAAR/D,GACZrC,OAAQA,GACRQ,UACA6F,aAAetK,GAAyBsK,aACxCvF,mBACAC,kBAkBIuF,GAAqBC,EAAAA,SACnBzD,YAAa0D,GAAc3D,YAAa4D,IAAiBxG,IACzDkB,WAAYuF,GAAatF,SAAUuF,IAAcxG,GACnDyG,GACJC,EAAAA,IAACC,EAASA,UACR,CAAA7K,SAAUA,EACV0E,YAAaA,GACbX,OAAQA,GACRQ,OAAQA,GACRuG,MAAwB,QAAjB/K,GAAOgL,MACdR,aAAcA,GACdC,aAAcA,GACdQ,OAAQvG,GACRlC,cAAeA,MAGb0I,mBAAEA,GAAkBC,iBAAEA,IAAqBC,sBAA0B,CACzEjL,SACAC,SACAE,cACA+G,mBACAjF,WACAiJ,WAAYtL,GAAOgJ,MACnBuC,WAAYtL,GAAO+I,MACnB/G,qBACAuJ,uBA7J8BC,IACd,aAAZA,GACF/D,IACD,IA6JGgE,GAAcnD,aAClBd,GACA8B,GACAK,GACAM,GACAhE,GACA2B,GACAuD,IAGF,OACEO,EACEC,KAAA,MAAA,CAAAC,SAAU,EACVC,IAAKzJ,GAAO,wBACWgF,GACX,aAAAnF,GAAM,gCACDA,GAAM,sCACL6J,QAAM,CAAC7J,GAAM,oBAAqBiI,KACpD6B,MAAO/E,GACPgF,KAAK,cACLC,UAAWC,SAAOC,kBACdjK,MACAuJ,GAAW5J,SAAA,CACf6J,EAAAA,KAAK,MAAA,CAAAjM,MAAM,OAAOC,OAAO,iBACvBmL,MAAU,WAAA,CAAAlE,GAAI,GAAG2D,KAAoBzI,SACnCgJ,iBAAUjG,OAEZiG,EAAAuB,IAACC,WAAQ,CACPC,MAAOrM,GAAUqM,MACjB9H,OAAQA,GACRwB,OAAQA,GACR+E,MAAwB,QAAjB/K,GAAOgL,MACd1H,WAAYsB,GACZrC,cAAeA,MAEfR,IAA0B6I,GAC5BC,EAAAA,IAAC0B,EAAAA,SAAUhI,GAAgBiI,aAAchK,GAAeZ,MAAOA,KAC/DiJ,MAAC0B,EAAAA,KACK,IAAAxI,GACJnC,MAAOA,GACP4K,aAAcjK,GACdkK,kBApFoBvJ,IAC1B,GAA8C,MAAzCnD,GAAyBsK,aAC5B,OAAO,EAET,MAAMqC,EAAatM,EAAO8C,GAAO1C,SACjC,MAAmB,OAAfkM,GAIc,OAAdA,IAAqC,OAAblM,GAAkC,eAAbA,EAGrC,EAyEN4G,SAAUA,GACVuF,kBACEpF,GAAiB4B,eAAiB5B,GAAiBnI,gBAAauJ,IAGpE+C,EAAcC,KAAA,IAAA,CAAA,YAAA,QAAQrB,MAAqBzI,SAAA,CACxCA,GAAS,CACR6I,eACAC,aACA9H,UACAmB,OAAQA,GACRQ,UACA4B,wBACAwG,gBAAiBlK,GAA4B,cAC7CwC,YACAkC,YACAC,mBACAC,mBACAlE,qBACAkB,gBAEDvC,IAA0B6I,GAC1BZ,MAEgB,SAAlB5I,GACCyJ,EAACuB,IAAAS,EAASA,UACR,CAAAvJ,WAAYI,GACZ9B,MAAOA,GACPkL,SAAU7I,GACV8I,WAAY7I,GACZ5B,QAA2B,WAAlBC,KAGZ2D,MAEFC,GACAhD,GACAR,GACAoH,GACApC,GACAuD,GACA3B,KAGP,SErXM,UAAuE9J,MAC3EA,EAAKC,OACLA,KACGuC,IAGH,OACE4I,MAACmC,EAAAA,qBAAoB,CAACvN,MAAOA,EAAOC,OAAQA,EAAQuN,MAAOC,EAAcA,eAAArL,SACtE,CAACpC,EAAOC,IACPD,GAASC,EACPmL,EAAAuB,IAAC5M,EAAoB,CAAAC,MAAOA,EAAOC,OAAQA,KAAYuC,SACrD0G,GAIZ"}
|
|
1
|
+
{"version":3,"file":"Chart-96ea9fed.js","sources":["../../src/PRIVATE_Axis/utils/axisNavUtils.ts","../../src/PRIVATE_Chart/ChartWithDimensions.tsx","../../src/PRIVATE_VisSVGText/useTextTruncation.ts","../../src/PRIVATE_Chart/Chart.tsx"],"sourcesContent":["/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\nimport { Group, ChartGroupInfo } from '../../utils/UNSAFE_visTypes/chart';\ntype isGroupNavigableType = (groupIndex: number) => boolean;\n\nexport function getNextGroup(\n info: ChartGroupInfo,\n viewportEndIndex: number,\n isGroupNavigable: isGroupNavigableType\n): ChartGroupInfo | undefined {\n const groupIndex = info.groupIndex + 1;\n if (groupIndex >= viewportEndIndex) {\n return;\n }\n\n if (isGroupNavigable(groupIndex)) {\n return { groupIndex };\n }\n return getNextGroup({ groupIndex }, viewportEndIndex, isGroupNavigable);\n}\n\nexport function getPreviousGroup(\n info: ChartGroupInfo,\n isGroupNavigable: isGroupNavigableType\n): ChartGroupInfo | undefined {\n const groupIndex = info.groupIndex - 1;\n if (groupIndex < 0) {\n return;\n }\n if (isGroupNavigable(groupIndex)) {\n return { groupIndex };\n }\n return getPreviousGroup({ groupIndex }, isGroupNavigable);\n}\n\nexport function getGroupNavUtil(\n groups: Group[],\n renderedGroups: number[],\n xIndexExtent: { startIndex: number; endIndex: number },\n drilling: 'on' | 'off' | 'groupsOnly',\n isRtl: boolean\n) {\n const isGroupNavigable = (groupIndex: number) => {\n const groupsDrilling = groups[renderedGroups[groupIndex]].drilling;\n return (drilling === 'on' || drilling === 'groupsOnly') && groupsDrilling != 'off';\n };\n\n const getDefaultNavGroup = (info: ChartGroupInfo) => {\n if (xIndexExtent.startIndex > renderedGroups[info.groupIndex]) {\n info.groupIndex = 0;\n return info;\n } else if (xIndexExtent.endIndex < renderedGroups[info.groupIndex]) {\n info.groupIndex = renderedGroups.length - 1;\n return info;\n }\n return;\n };\n\n const getNextNavGroup = (info: ChartGroupInfo, arrow: 'ArrowRight' | 'ArrowLeft') => {\n let nextGroup = getDefaultNavGroup(info);\n\n if (nextGroup) return nextGroup;\n\n if (arrow === 'ArrowRight') {\n nextGroup = isRtl\n ? getPreviousGroup(info, isGroupNavigable)\n : getNextGroup(info, renderedGroups.length, isGroupNavigable);\n } else {\n nextGroup = isRtl\n ? getNextGroup(info, renderedGroups.length, isGroupNavigable)\n : getPreviousGroup(info, isGroupNavigable);\n }\n return nextGroup || info;\n };\n\n return { getDefaultNavGroup, getNextNavGroup };\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { useTextDimensions } from '../hooks/PRIVATE_useTextDimensions';\nimport { useCssVars } from '../hooks/PRIVATE_useCssVars/useCssVars';\nimport { styles } from './themes/ChartStyles.css';\nimport { useRef } from 'preact/hooks';\nimport { PlotArea } from '../PRIVATE_PlotArea';\nimport { useId } from '../hooks/UNSAFE_useId';\nimport { Axis } from '../PRIVATE_Axis/Axis';\nimport { useChartViewport } from '../hooks/PRIVATE_useChartViewport';\nimport {\n getAvailSpace,\n getLayoutInfo,\n getScrollBarSpace,\n updateScrollBarSpace\n} from '../utils/PRIVATE_chartUtils/layoutUtils';\nimport { useChartNav } from '../hooks/PRIVATE_useChartNav/useChartNav';\nimport { mergeProps } from '../utils/UNSAFE_mergeProps';\nimport { getAxesPosition } from '../PRIVATE_Axis/utils/axisUtils';\nimport { ScrollBar } from '../PRIVATE_ChartScrollBar';\nimport { useSelectDrill } from '../hooks/PRIVATE_useChartEvents/useSelectDrill';\nimport { useChartDatatipAndCursor } from '../hooks/PRIVATE_useChartEvents/useDatatipAndCursor';\nimport { getGroupNavUtil } from '../PRIVATE_Axis/utils/axisNavUtils';\nimport { ChartItemData, TimeAxisProps } from '../utils/UNSAFE_visTypes/chart';\nimport { Gridlines } from '../PRIVATE_PlotArea/Gridlines';\nimport { useUser } from '../hooks/UNSAFE_useUser';\nimport { useTestId } from '../hooks/UNSAFE_useTestId';\nimport { getChartVars } from '../utils/PRIVATE_chartUtils';\nimport { useChartContextMenu } from '#hooks/PRIVATE_useChartContextMenu';\nimport { getElementData } from '#utils/UNSAFE_visUtils';\nimport { useTextTruncation } from '#PRIVATE_VisSVGText/useTextTruncation';\nimport { useChartMarquee } from '#hooks/PRIVATE_useChartMarquee';\nimport { ChartProps } from './Chart';\nimport type { gestureTypes } from '#hooks/PRIVATE_useVisContextMenu';\nimport { useVisTouchResponse } from '#hooks/PRIVATE_useVisTouchResponse';\nimport { merge } from '#utils/UNSAFE_stringUtils';\n\ntype ChartWithDimensionsProps<K, D> = Omit<ChartProps<K, D>, 'width' | 'height'> & {\n width: number;\n height: number;\n};\n\nconst chartVars = getChartVars();\n\nexport function ChartWithDimensions<K extends string | number, D extends ChartItemData<K>>({\n width,\n height,\n selectedIds,\n hiddenIds,\n hideAndShowBehavior = 'none',\n orientation = 'vertical',\n xAxis,\n yAxis,\n plotArea,\n dragMode = 'user',\n series,\n groups,\n isStacked = false,\n getDataItem,\n selectionMode = 'none',\n drilling = 'off',\n dataCursorPosition,\n onSelectionChange,\n isDataCursorEnabled,\n dataCursorStyle,\n onViewportChange,\n onDataCursorPositionChange,\n onItemDrill,\n onGroupDrill,\n onItemHover,\n onItemFocus,\n datatip,\n zoomAndScroll = 'off',\n offset,\n getNavUtil,\n getDataItemPos,\n getGapRatio,\n valueFormats,\n findNearest,\n getMarkerInfo,\n isRtl,\n children,\n testId,\n renderGridLinesInFront,\n contextMenuConfig,\n ...props\n}: ChartWithDimensionsProps<K, D>) {\n const testIdProps = useTestId(testId);\n const rootRef = useRef<HTMLDivElement>(null);\n const isHoriz = orientation === 'horizontal';\n const { xAxisPosition, yAxisPosition } = getAxesPosition(yAxis, isHoriz, isRtl);\n const { resolvedVars, cssContent } = useCssVars(chartVars);\n const colors = Array.from(Array(12)).map((_, index) => {\n return resolvedVars[`color${index + 1}`];\n });\n const { textMeasureContent, getTextDimensions } = useTextDimensions();\n let availSpace = getAvailSpace(width, height);\n const updatedSpace = getScrollBarSpace(availSpace, zoomAndScroll, xAxisPosition);\n let scrollDims = updatedSpace.scrollDims;\n availSpace = updatedSpace.availSpace;\n const hiddenSet = new Set(hiddenIds);\n const { locale } = useUser();\n const {\n xProps,\n xScale,\n xViewportExtent,\n xAxisExtent,\n xIndexExtent,\n yViewportExtent,\n yAxisExtent,\n groupWidth,\n yProps,\n yScale,\n yMaxDim,\n yMajorTicks,\n yMinorTicks,\n plotAreaSpace,\n idToDataMap,\n formatAxisLabel,\n formatYValue\n } = getLayoutInfo<K, D>(\n series,\n groups,\n getDataItem,\n xAxis,\n yAxis,\n availSpace,\n hiddenSet,\n hideAndShowBehavior,\n isHoriz,\n isRtl,\n isStacked,\n resolvedVars['labelFontSize'],\n offset,\n locale,\n getTextDimensions\n );\n\n scrollDims = updateScrollBarSpace(scrollDims, xAxisPosition === 'bottom', isRtl, yMaxDim);\n\n const gapRatio = getGapRatio(xIndexExtent.startIndex, xIndexExtent.endIndex);\n\n const getNextChartItem = getNavUtil(xIndexExtent.startIndex, xIndexExtent.endIndex);\n\n const renderedGroupsIndex = xProps.tickLabels.map(({ index }) => index + xIndexExtent.startIndex);\n const { getNextNavGroup, getDefaultNavGroup } = getGroupNavUtil(\n groups,\n renderedGroupsIndex,\n xIndexExtent,\n drilling,\n isRtl\n );\n\n const {\n cursor,\n marqueeProps,\n marqueeContent,\n toggleButtonContent,\n isPointInsideMarquee,\n dragMode: mode\n } = useChartMarquee<K, D>({\n plotAreaSpace,\n dragMode,\n chartWidth: width,\n isMultiSelection: selectionMode === 'multiple',\n onViewportChange,\n isZoomScroll: zoomAndScroll === 'live',\n xAxisExtent,\n xScale,\n selectedIds,\n getDataById: (id) => idToDataMap.get(id),\n onSelectionChange,\n viewportMax: xViewportExtent.viewportMax,\n viewportMin: xViewportExtent.viewportMin,\n isRtl\n });\n\n const { touchResponse, touchResponseStyle } = useVisTouchResponse({\n type: 'auto',\n supportsTouchDragGestures: mode !== 'off',\n rootRef\n });\n\n const { activeId, focusedItemInfo, hoveredItemInfo, focusedGroupInfo, navProps, onFocusUpdate } =\n useChartNav({\n rootRef,\n getNextChartItem,\n getNextNavGroup,\n getDefaultNavGroup,\n touchResponse,\n onItemHover,\n onItemFocus,\n drilling,\n xIndexExtent\n });\n\n const onContextMenuDismissed = (gesture: gestureTypes) => {\n if (gesture === 'keyboard') {\n onFocusUpdate();\n }\n };\n\n const getTextAndBounds = (target: EventTarget | null) => {\n if (target != rootRef.current) {\n const dataSet = getElementData(rootRef, target as HTMLElement);\n const text = dataSet?.['ojText']!;\n\n if (!text) {\n return;\n }\n\n if (text === xAxis?.title) {\n return {\n text,\n bounds: xProps.titleProps?.dims\n };\n } else if (text === yAxis?.title) {\n return {\n text,\n bounds: yProps.titleProps?.dims\n };\n } else if (dataSet?.['ojGroupIndex']) {\n const index = parseInt(dataSet['ojGroupIndex']);\n return {\n bounds: xProps.tickLabels[index].dims,\n text: text!\n };\n }\n }\n\n if (target === rootRef.current && focusedGroupInfo.isFocusVisible) {\n const group = groups[focusedGroupInfo.groupIndex];\n return {\n bounds: xProps.tickLabels[focusedGroupInfo.groupIndex].dims,\n text: group.name || group.id\n };\n }\n return;\n };\n\n const { tooltipContent, tooltipProps } = useTextTruncation({\n getTextAndBounds,\n width,\n isRtl\n });\n\n const { selectDrillProps, selectionContent } = useSelectDrill<K, D>({\n selectionMode,\n selection: [...selectedIds],\n onChange: onSelectionChange,\n rootRef,\n drilling,\n onItemDrill,\n onGroupDrill,\n focusedGroupInfo,\n focusedItemInfo,\n groups,\n getDataItem,\n getDataById: (id) => idToDataMap.get(id)\n });\n\n const viewportProps = useChartViewport({\n rootRef,\n width,\n height,\n xViewportExtent,\n yViewportExtent,\n xAxisExtent,\n yAxisExtent,\n xScale,\n yScale,\n plotAreaSpace,\n isRtl,\n isHoriz,\n zoomAndScroll,\n onViewportChange\n });\n\n const findNearestData = findNearest(xScale as any, yScale, groupWidth, gapRatio);\n const getDataItemPosition = getDataItemPos(xScale as any, yScale, groupWidth, gapRatio);\n\n const {\n datatipContent,\n dataCursorContent,\n datatipProps: { 'aria-describedby': datatipAriaDescribedby, ...datatipProps }\n } = useChartDatatipAndCursor<K, D>({\n series,\n groups,\n width,\n height,\n findNearest: findNearestData,\n plotAreaSpace,\n onDataCursorPositionChange,\n isDataCursorEnabled,\n dataCursorPosition,\n dataCursorStyle,\n hoveredItemInfo,\n focusedItemInfo,\n getDataItem,\n getMarkerInfo,\n getDataItemPos: getDataItemPosition,\n datatip,\n valueFormats,\n isHoriz,\n touchResponse,\n isDisabled: mode != 'off',\n xScale: xScale as any,\n yScale,\n timeAxisType: (xAxis as TimeAxisProps)?.timeAxisType,\n formatAxisLabel,\n formatYValue\n });\n\n const isGroupInteractive = (index: number) => {\n if ((xAxis as TimeAxisProps)?.timeAxisType != null) {\n return false;\n }\n const groupDrill = groups[index].drilling;\n if (groupDrill === 'on') {\n return true;\n }\n\n if (groupDrill != 'off' && (drilling === 'on' || drilling === 'groupsOnly')) {\n return true;\n }\n return false;\n };\n\n const plotAreaClipPathId = useId();\n const { viewportMin: xViewportMin, viewportMax: xViewportMax } = xViewportExtent;\n const { startIndex: xStartIndex, endIndex: xEndIndex } = xIndexExtent;\n const gridLines = (\n <Gridlines\n plotArea={plotArea}\n yMinorTicks={yMinorTicks}\n xScale={xScale}\n yScale={yScale}\n isLog={yAxis?.scale === 'log'}\n xViewportMin={xViewportMin}\n xViewportMax={xViewportMax}\n yTicks={yMajorTicks}\n yAxisPosition={yAxisPosition}\n />\n );\n const { contextMenuContent, contextMenuProps } = useChartContextMenu<K, D>({\n series,\n groups,\n getDataItem,\n focusedItemInfo,\n rootRef,\n xAxisTitle: xAxis?.title,\n yAxisTitle: yAxis?.title,\n contextMenuConfig,\n onContextMenuDismissed\n });\n\n const eventsProps = mergeProps(\n navProps,\n selectDrillProps,\n viewportProps,\n datatipProps,\n marqueeProps,\n tooltipProps,\n contextMenuProps\n );\n\n return (\n <div\n tabIndex={0}\n ref={rootRef}\n aria-activedescendant={activeId}\n aria-label={props['aria-label']}\n aria-labelledby={props['aria-labelledby']}\n aria-describedby={merge([props['aria-describedby'], datatipAriaDescribedby])}\n style={touchResponseStyle}\n role=\"application\"\n className={styles.baseChartStyle}\n {...testIdProps}\n {...eventsProps}>\n <svg width=\"100%\" height=\"100%\">\n <clipPath id={`${plotAreaClipPathId}`}>\n <rect {...plotAreaSpace}></rect>\n </clipPath>\n <PlotArea\n color={plotArea?.color}\n yScale={yScale}\n cursor={cursor}\n isLog={yAxis?.scale === 'log'}\n availSpace={plotAreaSpace}\n xAxisPosition={xAxisPosition}\n />\n {!renderGridLinesInFront && gridLines}\n <Axis {...(yProps as any)} axisPosition={yAxisPosition} isRtl={isRtl} />\n <Axis\n {...xProps}\n isRtl={isRtl}\n axisPosition={xAxisPosition}\n isTextInteractive={isGroupInteractive}\n activeId={activeId}\n focusedGroupIndex={\n focusedGroupInfo.isFocusVisible ? focusedGroupInfo.groupIndex : undefined\n }\n />\n <g clip-path={`url(#${plotAreaClipPathId})`}>\n {children({\n xStartIndex,\n xEndIndex,\n colors,\n xScale: xScale as any,\n yScale,\n isPointInsideMarquee,\n defaultFontSize: resolvedVars['labelFontSize'],\n gapRatio,\n activeId,\n focusedItemInfo,\n hoveredItemInfo,\n getTextDimensions,\n groupWidth\n })}\n {renderGridLinesInFront && gridLines}\n {dataCursorContent}\n </g>\n {zoomAndScroll === 'live' && (\n <ScrollBar\n availSpace={scrollDims}\n isRtl={isRtl}\n viewport={xViewportExtent}\n axisExtent={xAxisExtent}\n isHoriz={xAxisPosition === 'bottom'}\n />\n )}\n {marqueeContent}\n </svg>\n {toggleButtonContent}\n {textMeasureContent}\n {cssContent}\n {datatipContent}\n {tooltipContent}\n {contextMenuContent}\n {selectionContent}\n </div>\n );\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { Dimension } from '#utils/UNSAFE_visTypes/common';\nimport { calculateOffset } from '#hooks/PRIVATE_useDatatip';\nimport { useTooltip } from '#hooks/UNSAFE_useTooltip';\nimport { mergeProps } from '#utils/UNSAFE_mergeProps';\nimport { useRef, useState } from 'preact/hooks';\n\ntype Props = {\n getTextAndBounds: (target: EventTarget | null) =>\n | {\n text?: string;\n bounds?: Dimension;\n }\n | undefined;\n isRtl: boolean;\n width: number;\n};\n\nexport function useTextTruncation({ getTextAndBounds, width, isRtl }: Props) {\n const [text, setText] = useState<string>();\n const bounds = useRef<Dimension>();\n\n const { tooltipContent, tooltipProps } = useTooltip({\n text,\n position: 'top-start',\n offset: calculateOffset(isRtl, width, bounds.current)\n });\n\n const onPointerMove = (event: Event) => {\n const textAndBounds = getTextAndBounds(event.target);\n\n if (textAndBounds) {\n bounds.current = textAndBounds.bounds;\n setText(textAndBounds.text);\n } else {\n setText(undefined);\n }\n };\n\n return {\n tooltipContent,\n tooltipProps: mergeProps({ onPointerMove }, tooltipProps)\n };\n}\n","/**\n * @license\n * Copyright (c) %FIRST_YEAR% %CURRENT_YEAR%, Oracle and/or its affiliates.\n * Licensed under The Universal Permissive License (UPL), Version 1.0\n * as shown at https://oss.oracle.com/licenses/upl/\n * @ignore\n */\n\nimport { dimensionStyle } from './themes/ChartStyles.css';\nimport { TrackResizeContainer } from '../PRIVATE_TrackResizeContainer';\nimport { ChartWithDimensions } from './ChartWithDimensions';\nimport {\n ChartItemData,\n ChartCommonProps,\n ChartSeriesData,\n GetNextChartItemType,\n Info,\n Scale,\n getDataPosType\n} from '../utils/UNSAFE_visTypes/chart';\nimport { Dimension, MarkerShapes } from '#utils/UNSAFE_visTypes/common';\nimport { VNode } from 'preact';\nimport { Property } from 'csstype';\n\nexport type ChartProps<K, D> = {\n selectedIds: Set<K>;\n getGapRatio: (startIndex: number, endIndex: number) => number;\n getNavUtil: (startIndex: number, endIndex: number) => GetNextChartItemType;\n getDataItemPos: (\n xScale: Scale,\n yScale: Scale,\n groupWidth: number,\n gapRatio: number\n ) => getDataPosType;\n findNearest: (\n xScale: Scale,\n yScale: Scale,\n groupWidth: number,\n gapRatio: number\n ) => (\n x: number,\n y: number\n ) =>\n | {\n seriesIndex: number;\n groupIndex: number;\n y: number | undefined;\n x: number;\n }\n | undefined;\n children: (context: {\n xStartIndex: number;\n xEndIndex: number;\n xScale: Scale;\n yScale: Scale;\n gapRatio: number;\n activeId?: string;\n focusedItemInfo: Info;\n hoveredItemInfo?: Info;\n groupWidth: number;\n isPointInsideMarquee: ((id: K, point: { x: number; y: number }) => boolean) | undefined;\n getTextDimensions?: (text: string, style: Record<string, any>) => Dimension;\n defaultFontSize: string;\n colors: string[];\n }) => VNode;\n offset: number;\n series: ChartSeriesData<K, D>[];\n isRtl: boolean;\n renderGridLinesInFront: boolean;\n getMarkerInfo: (\n seriesIndex: number,\n groupIndex: number\n ) => { color: Property.Color | undefined; type?: MarkerShapes };\n} & Omit<ChartCommonProps<K, D>, 'highlightedIds' | 'hoverBehavior' | 'selectedIds'>;\n\nexport function Chart<K extends string | number, D extends ChartItemData<K>>({\n width,\n height,\n ...props\n}: ChartProps<K, D>) {\n // TODO: reevaluate how we handle empty data\n return (\n <TrackResizeContainer width={width} height={height} class={dimensionStyle}>\n {(width, height) =>\n width || height ? (\n <ChartWithDimensions width={width} height={height} {...props} />\n ) : undefined\n }\n </TrackResizeContainer>\n );\n}\n"],"names":["getNextGroup","info","viewportEndIndex","isGroupNavigable","groupIndex","getPreviousGroup","chartVars","getChartVars","ChartWithDimensions","width","height","selectedIds","hiddenIds","hideAndShowBehavior","orientation","xAxis","yAxis","plotArea","dragMode","series","groups","isStacked","getDataItem","selectionMode","drilling","dataCursorPosition","onSelectionChange","isDataCursorEnabled","dataCursorStyle","onViewportChange","onDataCursorPositionChange","onItemDrill","onGroupDrill","onItemHover","onItemFocus","datatip","zoomAndScroll","offset","getNavUtil","getDataItemPos","getGapRatio","valueFormats","findNearest","getMarkerInfo","isRtl","children","testId","renderGridLinesInFront","contextMenuConfig","props","testIdProps","useTestId","rootRef","useRef","isHoriz","xAxisPosition","yAxisPosition","getAxesPosition","resolvedVars","cssContent","useCssVars","colors","Array","from","map","_","index","textMeasureContent","getTextDimensions","useTextDimensions","availSpace","getAvailSpace","updatedSpace","getScrollBarSpace","scrollDims","hiddenSet","Set","locale","useUser","xProps","xScale","xViewportExtent","xAxisExtent","xIndexExtent","yViewportExtent","yAxisExtent","groupWidth","yProps","yScale","yMaxDim","yMajorTicks","yMinorTicks","plotAreaSpace","idToDataMap","formatAxisLabel","formatYValue","getLayoutInfo","updateScrollBarSpace","gapRatio","startIndex","endIndex","getNextChartItem","renderedGroupsIndex","tickLabels","getNextNavGroup","getDefaultNavGroup","renderedGroups","groupsDrilling","length","arrow","nextGroup","getGroupNavUtil","cursor","marqueeProps","marqueeContent","toggleButtonContent","isPointInsideMarquee","mode","useChartMarquee","chartWidth","isMultiSelection","isZoomScroll","getDataById","id","get","viewportMax","viewportMin","touchResponse","touchResponseStyle","useVisTouchResponse","type","supportsTouchDragGestures","activeId","focusedItemInfo","hoveredItemInfo","focusedGroupInfo","navProps","onFocusUpdate","useChartNav","tooltipContent","tooltipProps","getTextAndBounds","text","setText","useState","bounds","useTooltip","position","calculateOffset","current","mergeProps","onPointerMove","event","textAndBounds","target","undefined","useTextTruncation","dataSet","getElementData","title","titleProps","dims","parseInt","isFocusVisible","group","name","selectDrillProps","selectionContent","useSelectDrill","selection","onChange","viewportProps","useChartViewport","findNearestData","getDataItemPosition","datatipContent","dataCursorContent","datatipProps","datatipAriaDescribedby","useChartDatatipAndCursor","isDisabled","timeAxisType","plotAreaClipPathId","useId","xViewportMin","xViewportMax","xStartIndex","xEndIndex","gridLines","_jsx","Gridlines","isLog","scale","yTicks","contextMenuContent","contextMenuProps","useChartContextMenu","xAxisTitle","yAxisTitle","onContextMenuDismissed","gesture","eventsProps","_jsxs","jsxs","tabIndex","ref","merge","style","role","className","styles","baseChartStyle","jsx","PlotArea","color","Axis","axisPosition","isTextInteractive","groupDrill","focusedGroupIndex","defaultFontSize","ScrollBar","viewport","axisExtent","TrackResizeContainer","class","dimensionStyle"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
define(['exports', 'preact/jsx-runtime', './layoutUtils-ac40a238', './dataStyleUtils-012386a4', './Common/themes/themeContract.css', './Marker-8ff23a04', 'css!./SvgShapesStyles.styles.css', './useTranslationBundle-516b1b83', './accUtils-1557920a', './useUser-85c781ea', './colorUtils-a785c4c4', './utils-5077c092', './PRIVATE_Chart/themes/ChartStyles.css', './Chart-
|
|
2
|
-
//# sourceMappingURL=LineAreaChart-
|
|
1
|
+
define(['exports', 'preact/jsx-runtime', './layoutUtils-ac40a238', './dataStyleUtils-012386a4', './Common/themes/themeContract.css', './Marker-8ff23a04', 'css!./SvgShapesStyles.styles.css', './useTranslationBundle-516b1b83', './accUtils-1557920a', './useUser-85c781ea', './colorUtils-a785c4c4', './utils-5077c092', './PRIVATE_Chart/themes/ChartStyles.css', './Chart-96ea9fed'], (function(e,t,i,r,n,s,o,a,l,d,c,g,h,m){"use strict";function u({yScale:e,lineType:i="straight",color:s,isHorizontal:o,isLog:a,areaColorOpacity:l,lineSegments:d,bottomCoords:c,isHighlighted:g,isBottomSegmentCurved:h,seriesIndex:m}){const u={fill:s,opacity:g?l:`calc(${n.dvtVars.dimmedOpacity} * ${l})`};return t.jsx(t.Fragment,{children:d.map((n=>{if(n.length<2)return;let s;if(c)s=c;else{const t=e.transform(a?e.domain()[0]:0);s=o?[[t,n[0][1]],[t,n[n.length-1][1]]]:[[n[0][0],t],[n[n.length-1][0],t]]}const l=r.getCmdsForArea(n,s,i,o,h);return t.jsx("path",{d:l,style:u,"data-oj-series-index":m,"data-oj-object":"area"})}))})}const I=10;function x({yScale:e,xScale:n,color:o,seriesIndex:d,startIndex:c,endIndex:g,hiddenIds:h,selectedIds:m,orientation:u,isLog:x,data:p,markerType:y,getDataItem:f,focusedItemIndex:S,hoveredItemIndex:C,isDrillEnabled:v,activeId:j,isSelectionEnabled:k,timeAxisType:b,isPointInsideMarquee:A,series:T,groups:D}){const M="horizontal"===u,L=[],F=a.useTranslationBundle("@oracle/oraclejet-preact");for(let a=c;a<g+1;a++){const c=f(d,a),g=p[a];if(!c||null==g||h?.has(c.id)||x&&g<=0)continue;const u=M?e.transform(g):i.getGroupCenterCoord(D[a],a,n,c,b),w=M?i.getGroupCenterCoord(D[a],a,n,c,b):e.transform(g),E=S===a,R=C===a,H=!(!m?.has(c.id)&&!A?.(c.id,{x:u,y:w})),P="on"===c.drilling||"off"!=c.drilling&&v,{fill:U,stroke:W,outerStroke:z}=r.getMarkerFillAndStroke(!!c.isMarkerDisplayed,k,R,E,H,o,c.markerColor),N=c.isMarkerDisplayed&&c.markerType||y,B=E||R,V=l.supportsMobileScreenReader||B?r.getItemAriaLabel(F,T.name||T.id.toString(),D[a].name||D[a].id,c.value,k,H,P,c.accessibleLabel):void 0,q={"data-oj-series-index":d,"data-oj-group-index":a,"data-oj-object":"item",id:B?j:void 0,role:V?"img":void 0,"aria-label":V},G=(c.markerSize||I)+2*s.MARKER_PADDING;L.push(t.jsx(s.Marker,{type:N,tx:u,ty:w,isInteractive:P||k,scale:1,fill:U,stroke:W,outerStroke:z,width:G,height:G,dataInfo:q,preserveRectAspectRatio:!0}))}return t.jsx(t.Fragment,{children:L})}function p({color:e,isHorizontal:i,lineType:s="straight",lineColor:o,lineStyle:a,lineWidth:l=3,isHighlighted:d,lineSegmentCoords:c,seriesIndex:m}){const u={stroke:o||e,strokeDasharray:"dotted"===a?3:"dashed"===a?6:void 0,strokeWidth:l,fill:g.rgba(n.colorSchemeVars.palette.neutral[0],0)};return t.jsx(t.Fragment,{children:c.map((e=>{if(e.length<2)return;const n=r.getCmdsForLine(e,s,i);return"straight"===s?t.jsx("polyline",{points:n,style:u,className:d?void 0:h.styles.dimmed,"data-oj-series-index":m,"data-oj-object":"line"}):t.jsx("path",{d:n,style:u,className:d?void 0:h.styles.dimmed,"data-oj-series-index":m,"data-oj-object":"line"})}))})}e.LineAreaChart=function({width:e,height:s,selectedIds:o=[],hiddenIds:a=[],highlightedIds:l,hideAndShowBehavior:g="none",orientation:h="vertical",yAxis:I,series:y,groups:f,isStacked:S=!1,getDataItem:C,selectionMode:v="none",drilling:j="off",type:k="line",...b}){const{direction:A}=d.useUser(),T="rtl"===A,D="log"===I?.scale,M=b.xAxis?.timeAxisType,L=new Set(a),F=new Set(o),w=new Set(l),E="horizontal"===h,R=c.getColorRamp(),H=S?r.getCumulativeSeries(y.length,f.length,C,L,D):r.getSeriesData(y?.length,f?.length,C,L,D),P=(e,t)=>S?{...C(e,t),value:H[e][t]}:C(e,t),U=r.getMarkers(),W="lineWithArea"===k?.2:1,z="area"===k||"lineWithArea"===k,N="area"===k,B=[];return t.jsx(m.Chart,{width:e,height:s,selectedIds:F,hiddenIds:a,hideAndShowBehavior:g,orientation:h,yAxis:I,series:y,groups:f,selectionMode:v,drilling:j,isStacked:S,getDataItem:C,findNearest:(e,t)=>i.findNearestDataPoint(y,f,e,t,P,S,(()=>({offset:0,dataWidth:0})),((e,t)=>t.transform(e)),D,0,L,M),getDataItemPos:(e,t)=>(i,r)=>{const n=H[i][r];if(null==n)return;let s=r;if(M){const e="mixedFrequency"===M?C(i,r)?.x:f[r].id;s=new Date(e).getTime()}return{x:E?t.transform(n):e.transform(s),y:E?e.transform(s):t.transform(n),height:0,width:0}},getMarkerInfo:(e,t)=>({color:r.getItemColor(e,t,y,C),type:r.getMarkerType(e,t,"lineWithArea",C)}),renderGridLinesInFront:z,getNavUtil:(e,t)=>r.getLineAreaChartNavUtil(C,y.length,e,t,S,T,E),getGapRatio:()=>1,offset:.2,isRtl:T,...b,children:({xStartIndex:e,xEndIndex:i,xScale:s,yScale:o,activeId:a,focusedItemInfo:d,hoveredItemInfo:c,isPointInsideMarquee:g})=>t.jsxs(t.Fragment,{children:[H.map(((m,I)=>{if(0===m.length)return;const k=y[I],A=r.getLineAreaSegments(o,s,m,e,i,E,D,f,I,P,M);B[I]=A[0];const T="curved"===k.lineType&&S&&H.length>1&&I>0,L=void 0===l||w.has(k.id),V=S&&0!=I?B.reduce(((e,t,i)=>i>=I?e:t.length>0?i:e),0):void 0;return t.jsxs(t.Fragment,{children:[z&&t.jsx(u,{yScale:o,lineType:k.lineType,color:k.areaColor||R[I%R.length],isHorizontal:E,areaColorOpacity:W,isBottomSegmentCurved:T,bottomCoords:void 0!==V&&B[V].some((e=>null!=e))?B[V]:void 0,lineSegments:A,isLog:D,isHighlighted:L,seriesIndex:I}),t.jsx(p,{lineType:k.lineType,lineColor:N?n.colorSchemeVars.dvt.contrastLine:k.lineColor,lineWidth:N?S?2.5:1.25:k.lineWidth,lineStyle:k.lineStyle,color:k.lineColor||R[I%R.length],lineSegmentCoords:A,isHorizontal:E,isHighlighted:L,seriesIndex:I}),!S&&t.jsx(x,{yScale:o,xScale:s,groups:f,series:k,timeAxisType:M,data:m,color:k.lineColor||k.areaColor||R[I%R.length],seriesIndex:I,startIndex:e,endIndex:i,markerType:U[I%U.length],orientation:h,isLog:D,activeId:a,getDataItem:C,isPointInsideMarquee:g,selectedIds:F,focusedItemIndex:d.seriesIndex!==I||!d.isFocusVisible||b.isDataCursorEnabled&&b.dataCursorStyle?.isMarkerDisplayed?void 0:d.groupIndex,hoveredItemIndex:c?.isCurrent&&c.seriesIndex===I?c.groupIndex:void 0,isSelectionEnabled:"single"===v||"multiple"===v,isDrillEnabled:"on"===j})]})})),S&&H.map(((r,n)=>{if(0===r.length)return;const l=y[n];return t.jsx(x,{yScale:o,series:y[n],xScale:s,groups:f,timeAxisType:M,data:r,color:l.lineColor||l.areaColor||R[n%R.length],seriesIndex:n,isPointInsideMarquee:g,startIndex:e,endIndex:i,markerType:U[n%U.length],orientation:h,isLog:D,activeId:a,getDataItem:C,selectedIds:F,focusedItemIndex:d.seriesIndex===n&&d.isFocusVisible?d.groupIndex:void 0,hoveredItemIndex:c?.isCurrent&&c.seriesIndex===n?c.groupIndex:void 0,isSelectionEnabled:"single"===v||"multiple"===v,isDrillEnabled:"on"===j})}))]})})}}));
|
|
2
|
+
//# sourceMappingURL=LineAreaChart-47b01e9e.js.map
|