@rio-cloud/uikit-mcp 1.0.0 → 1.1.0
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/README.md +75 -40
- package/dist/doc-metadata.json +1872 -0
- package/dist/docs/components/accentBar.md +582 -0
- package/dist/docs/components/activity.md +330 -0
- package/dist/docs/components/animatedNumber.md +88 -0
- package/dist/docs/components/animatedTextReveal.md +381 -0
- package/dist/docs/components/animations.md +459 -0
- package/dist/docs/components/appHeader.md +737 -0
- package/dist/docs/components/appLayout.md +2016 -0
- package/dist/docs/components/appNavigationBar.md +274 -0
- package/dist/docs/components/areaCharts.md +828 -0
- package/dist/docs/components/aspectRatioPlaceholder.md +106 -0
- package/dist/docs/components/assetTree.md +3223 -0
- package/dist/docs/components/autosuggests.md +1177 -0
- package/dist/docs/components/avatar.md +206 -0
- package/dist/docs/components/banner.md +668 -0
- package/dist/docs/components/barCharts.md +2785 -0
- package/dist/docs/components/barList.md +517 -0
- package/dist/docs/components/basicMap.md +167 -0
- package/dist/docs/components/bottomSheet.md +721 -0
- package/dist/docs/components/button.md +775 -0
- package/dist/docs/components/buttonToolbar.md +134 -0
- package/dist/docs/components/calendarStripe.md +525 -0
- package/dist/docs/components/card.md +86 -0
- package/dist/docs/components/carousel.md +128 -0
- package/dist/docs/components/chartColors.md +716 -0
- package/dist/docs/components/chartsGettingStarted.md +28 -0
- package/dist/docs/components/chat.md +932 -0
- package/dist/docs/components/checkbox.md +996 -0
- package/dist/docs/components/clearableInput.md +806 -0
- package/dist/docs/components/collapse.md +189 -0
- package/dist/docs/components/composedCharts.md +424 -0
- package/dist/docs/components/contentLoader.md +674 -0
- package/dist/docs/components/dataTabs.md +1251 -0
- package/dist/docs/components/datepickers.md +2543 -0
- package/dist/docs/components/dialogs.md +2244 -0
- package/dist/docs/components/divider.md +219 -0
- package/dist/docs/components/dropdowns.md +17550 -0
- package/dist/docs/components/editableContent.md +1127 -0
- package/dist/docs/components/expander.md +970 -0
- package/dist/docs/components/fade.md +836 -0
- package/dist/docs/components/fadeExpander.md +180 -0
- package/dist/docs/components/fadeUp.md +396 -0
- package/dist/docs/components/feedback.md +758 -0
- package/dist/docs/components/filePickers.md +370 -0
- package/dist/docs/components/formLabel.md +251 -0
- package/dist/docs/components/fullscreenMap.md +10 -0
- package/dist/docs/components/groupedItemList.md +1001 -0
- package/dist/docs/components/iconList.md +306 -0
- package/dist/docs/components/imagePreloader.md +167 -0
- package/dist/docs/components/labeledElement.md +115 -0
- package/dist/docs/components/licensePlate.md +412 -0
- package/dist/docs/components/lineCharts.md +2014 -0
- package/dist/docs/components/listMenu.md +392 -0
- package/dist/docs/components/loadMore.md +219 -0
- package/dist/docs/components/mainNavigation.md +129 -0
- package/dist/docs/components/mapCircle.md +93 -0
- package/dist/docs/components/mapCluster.md +337 -0
- package/dist/docs/components/mapContext.md +284 -0
- package/dist/docs/components/mapDraggableMarker.md +150 -0
- package/dist/docs/components/mapGettingStarted.md +39 -0
- package/dist/docs/components/mapInfoBubble.md +135 -0
- package/dist/docs/components/mapLayerGroup.md +94 -0
- package/dist/docs/components/mapMarker.md +1814 -0
- package/dist/docs/components/mapPolygon.md +959 -0
- package/dist/docs/components/mapRoute.md +3816 -0
- package/dist/docs/components/mapRouteGenerator.md +6 -0
- package/dist/docs/components/mapSettings.md +1040 -0
- package/dist/docs/components/mapUtils.md +132 -0
- package/dist/docs/components/multiselects.md +1921 -0
- package/dist/docs/components/noData.md +210 -0
- package/dist/docs/components/notifications.md +314 -0
- package/dist/docs/components/numbercontrol.md +706 -0
- package/dist/docs/components/onboarding.md +297 -0
- package/dist/docs/components/page.md +241 -0
- package/dist/docs/components/pager.md +133 -0
- package/dist/docs/components/pieCharts.md +1284 -0
- package/dist/docs/components/popover.md +222 -0
- package/dist/docs/components/position.md +50 -0
- package/dist/docs/components/radialBarCharts.md +3663 -0
- package/dist/docs/components/radiobutton.md +1271 -0
- package/dist/docs/components/releaseNotes.md +135 -0
- package/dist/docs/components/resizer.md +162 -0
- package/dist/docs/components/responsiveColumnStripe.md +435 -0
- package/dist/docs/components/responsiveVideo.md +71 -0
- package/dist/docs/components/rioglyph.md +331 -0
- package/dist/docs/components/rules.md +965 -0
- package/dist/docs/components/saveableInput.md +1721 -0
- package/dist/docs/components/selects.md +1993 -0
- package/dist/docs/components/sidebar.md +332 -0
- package/dist/docs/components/sliders.md +376 -0
- package/dist/docs/components/smoothScrollbars.md +1180 -0
- package/dist/docs/components/spinners.md +506 -0
- package/dist/docs/components/states.md +1176 -0
- package/dist/docs/components/statsWidgets.md +636 -0
- package/dist/docs/components/statusBar.md +644 -0
- package/dist/docs/components/stepButton.md +61 -0
- package/dist/docs/components/steppedProgressBars.md +1064 -0
- package/dist/docs/components/subNavigation.md +470 -0
- package/dist/docs/components/supportMarker.md +115 -0
- package/dist/docs/components/svgImage.md +248 -0
- package/dist/docs/components/switch.md +554 -0
- package/dist/docs/components/tables.md +8 -0
- package/dist/docs/components/tagManager.md +476 -0
- package/dist/docs/components/tags.md +785 -0
- package/dist/docs/components/teaser.md +925 -0
- package/dist/docs/components/timeline.md +514 -0
- package/dist/docs/components/timepicker.md +262 -0
- package/dist/docs/components/toggleButton.md +178 -0
- package/dist/docs/components/tooltip.md +454 -0
- package/dist/docs/components/virtualList.md +483 -0
- package/dist/docs/foundations.md +20901 -0
- package/dist/docs/start/changelog.md +439 -0
- package/dist/docs/start/goodtoknow.md +14 -0
- package/dist/docs/start/guidelines/color-combinations.md +678 -0
- package/dist/docs/start/guidelines/custom-css.md +42 -0
- package/dist/docs/start/guidelines/custom-rioglyph.md +35 -0
- package/dist/docs/start/guidelines/formatting.md +587 -0
- package/dist/docs/start/guidelines/iframe.md +323 -0
- package/dist/docs/start/guidelines/obfuscate-data.md +30 -0
- package/dist/docs/start/guidelines/print-css.md +36 -0
- package/dist/docs/start/guidelines/spinner.md +710 -0
- package/dist/docs/start/guidelines/supported-browsers.md +10 -0
- package/dist/docs/start/guidelines/writing.md +635 -0
- package/dist/docs/start/howto.md +187 -0
- package/dist/docs/start/intro.md +43 -0
- package/dist/docs/start/responsiveness.md +98 -0
- package/dist/docs/templates/common-table.md +1111 -0
- package/dist/docs/templates/detail-views.md +942 -0
- package/dist/docs/templates/expandable-details.md +228 -0
- package/dist/docs/templates/feature-cards.md +549 -0
- package/dist/docs/templates/form-summary.md +199 -0
- package/dist/docs/templates/form-toggle.md +367 -0
- package/dist/docs/templates/list-blocks.md +1021 -0
- package/dist/docs/templates/loading-progress.md +109 -0
- package/dist/docs/templates/options-panel.md +152 -0
- package/dist/docs/templates/panel-variants.md +164 -0
- package/dist/docs/templates/progress-cards.md +607 -0
- package/dist/docs/templates/progress-success.md +142 -0
- package/dist/docs/templates/settings-form.md +434 -0
- package/dist/docs/templates/stats-blocks.md +1381 -0
- package/dist/docs/templates/table-panel.md +184 -0
- package/dist/docs/templates/table-row-animation.md +317 -0
- package/dist/docs/templates/usage-cards.md +227 -0
- package/dist/docs/utilities/deviceUtils.md +123 -0
- package/dist/docs/utilities/featureToggles.md +90 -0
- package/dist/docs/utilities/fuelTypeUtils.md +186 -0
- package/dist/docs/utilities/routeUtils.md +138 -0
- package/dist/docs/utilities/useAfterMount.md +66 -0
- package/dist/docs/utilities/useAutoAnimate.md +193 -0
- package/dist/docs/utilities/useAverage.md +95 -0
- package/dist/docs/utilities/useClickOutside.md +61 -0
- package/dist/docs/utilities/useClipboard.md +93 -0
- package/dist/docs/utilities/useCount.md +178 -0
- package/dist/docs/utilities/useDarkMode.md +49 -0
- package/dist/docs/utilities/useDebugInfo.md +126 -0
- package/dist/docs/utilities/useEffectOnce.md +58 -0
- package/dist/docs/utilities/useElapsedTime.md +58 -0
- package/dist/docs/utilities/useElementSize.md +71 -0
- package/dist/docs/utilities/useEsc.md +58 -0
- package/dist/docs/utilities/useEvent.md +64 -0
- package/dist/docs/utilities/useFocusTrap.md +85 -0
- package/dist/docs/utilities/useFullscreen.md +198 -0
- package/dist/docs/utilities/useHover.md +55 -0
- package/dist/docs/utilities/useIncomingPostMessages.md +237 -0
- package/dist/docs/utilities/useInterval.md +85 -0
- package/dist/docs/utilities/useIsFocusWithin.md +114 -0
- package/dist/docs/utilities/useKey.md +151 -0
- package/dist/docs/utilities/useLocalStorage.md +91 -0
- package/dist/docs/utilities/useLocationSuggestions.md +114 -0
- package/dist/docs/utilities/useMax.md +62 -0
- package/dist/docs/utilities/useMin.md +78 -0
- package/dist/docs/utilities/useMutationObserver.md +113 -0
- package/dist/docs/utilities/useOnScreen.md +138 -0
- package/dist/docs/utilities/useOnlineStatus.md +49 -0
- package/dist/docs/utilities/usePostMessage.md +117 -0
- package/dist/docs/utilities/usePostMessageSender.md +257 -0
- package/dist/docs/utilities/usePrevious.md +101 -0
- package/dist/docs/utilities/useResizeObserver.md +151 -0
- package/dist/docs/utilities/useScrollPosition.md +252 -0
- package/dist/docs/utilities/useSearch.md +228 -0
- package/dist/docs/utilities/useSorting.md +389 -0
- package/dist/docs/utilities/useStateWithValidation.md +83 -0
- package/dist/docs/utilities/useSum.md +155 -0
- package/dist/docs/utilities/useTableExport.md +404 -0
- package/dist/docs/utilities/useTableSelection.md +1120 -0
- package/dist/docs/utilities/useTimeout.md +55 -0
- package/dist/docs/utilities/useToggle.md +115 -0
- package/dist/docs/utilities/useWindowResize.md +70 -0
- package/dist/index.mjs +271 -0
- package/dist/search-synonyms.json +134 -0
- package/dist/version.json +4 -0
- package/package.json +23 -19
- package/bin/uikit-mcp.mjs +0 -23
- package/data/pages/Components/components/accentbar.json +0 -207
- package/data/pages/Components/components/activity.json +0 -87
- package/data/pages/Components/components/animatednumber.json +0 -99
- package/data/pages/Components/components/animations.json +0 -87
- package/data/pages/Components/components/appheader.json +0 -291
- package/data/pages/Components/components/applayout.json +0 -1198
- package/data/pages/Components/components/appnavigationbar.json +0 -327
- package/data/pages/Components/components/areacharts.json +0 -563
- package/data/pages/Components/components/aspectratioplaceholder.json +0 -75
- package/data/pages/Components/components/assettree.json +0 -3080
- package/data/pages/Components/components/autosuggests.json +0 -710
- package/data/pages/Components/components/avatar.json +0 -157
- package/data/pages/Components/components/banner.json +0 -599
- package/data/pages/Components/components/barcharts.json +0 -1507
- package/data/pages/Components/components/barlist.json +0 -223
- package/data/pages/Components/components/basicmap.json +0 -68
- package/data/pages/Components/components/bottomsheet.json +0 -601
- package/data/pages/Components/components/button.json +0 -583
- package/data/pages/Components/components/buttontoolbar.json +0 -63
- package/data/pages/Components/components/calendarstripe.json +0 -235
- package/data/pages/Components/components/card.json +0 -69
- package/data/pages/Components/components/carousel.json +0 -39
- package/data/pages/Components/components/chartcolors.json +0 -34
- package/data/pages/Components/components/chartsgettingstarted.json +0 -32
- package/data/pages/Components/components/chat.json +0 -39
- package/data/pages/Components/components/checkbox.json +0 -847
- package/data/pages/Components/components/clearableinput.json +0 -789
- package/data/pages/Components/components/collapse.json +0 -175
- package/data/pages/Components/components/composedcharts.json +0 -159
- package/data/pages/Components/components/contentloader.json +0 -233
- package/data/pages/Components/components/datatabs.json +0 -680
- package/data/pages/Components/components/datepickers.json +0 -287
- package/data/pages/Components/components/dialogs.json +0 -1492
- package/data/pages/Components/components/divider.json +0 -93
- package/data/pages/Components/components/dropdowns.json +0 -936
- package/data/pages/Components/components/editablecontent.json +0 -1117
- package/data/pages/Components/components/expander.json +0 -377
- package/data/pages/Components/components/fade.json +0 -403
- package/data/pages/Components/components/fadeexpander.json +0 -75
- package/data/pages/Components/components/fadeup.json +0 -127
- package/data/pages/Components/components/feedback.json +0 -269
- package/data/pages/Components/components/filepickers.json +0 -269
- package/data/pages/Components/components/formlabel.json +0 -115
- package/data/pages/Components/components/fullscreenmap.json +0 -22
- package/data/pages/Components/components/groupeditemlist.json +0 -323
- package/data/pages/Components/components/iconlist.json +0 -45
- package/data/pages/Components/components/imagepreloader.json +0 -81
- package/data/pages/Components/components/labeledelement.json +0 -75
- package/data/pages/Components/components/licenseplate.json +0 -69
- package/data/pages/Components/components/linecharts.json +0 -987
- package/data/pages/Components/components/listmenu.json +0 -313
- package/data/pages/Components/components/loadmore.json +0 -175
- package/data/pages/Components/components/mainnavigation.json +0 -39
- package/data/pages/Components/components/mapcircle.json +0 -34
- package/data/pages/Components/components/mapcluster.json +0 -51
- package/data/pages/Components/components/mapcontext.json +0 -105
- package/data/pages/Components/components/mapdraggablemarker.json +0 -34
- package/data/pages/Components/components/mapgettingstarted.json +0 -27
- package/data/pages/Components/components/mapgroup.json +0 -1198
- package/data/pages/Components/components/mapinfobubble.json +0 -34
- package/data/pages/Components/components/maplayergroup.json +0 -34
- package/data/pages/Components/components/mapmarker.json +0 -700
- package/data/pages/Components/components/mappolygon.json +0 -45
- package/data/pages/Components/components/maproute.json +0 -623
- package/data/pages/Components/components/maproutegenerator.json +0 -16
- package/data/pages/Components/components/mapsettings.json +0 -51
- package/data/pages/Components/components/maputils.json +0 -34
- package/data/pages/Components/components/multiselects.json +0 -1451
- package/data/pages/Components/components/nodata.json +0 -139
- package/data/pages/Components/components/notifications.json +0 -65
- package/data/pages/Components/components/numbercontrol.json +0 -301
- package/data/pages/Components/components/onboarding.json +0 -302
- package/data/pages/Components/components/page.json +0 -197
- package/data/pages/Components/components/pager.json +0 -93
- package/data/pages/Components/components/piecharts.json +0 -731
- package/data/pages/Components/components/popover.json +0 -251
- package/data/pages/Components/components/position.json +0 -69
- package/data/pages/Components/components/radialbarcharts.json +0 -1304
- package/data/pages/Components/components/radiobutton.json +0 -1105
- package/data/pages/Components/components/releasenotes.json +0 -44
- package/data/pages/Components/components/resizer.json +0 -93
- package/data/pages/Components/components/responsivecolumnstripe.json +0 -123
- package/data/pages/Components/components/responsivevideo.json +0 -75
- package/data/pages/Components/components/rioglyph.json +0 -93
- package/data/pages/Components/components/rules.json +0 -410
- package/data/pages/Components/components/saveableinput.json +0 -703
- package/data/pages/Components/components/selects.json +0 -701
- package/data/pages/Components/components/sidebar.json +0 -243
- package/data/pages/Components/components/sliders.json +0 -235
- package/data/pages/Components/components/smoothscrollbars.json +0 -335
- package/data/pages/Components/components/spinners.json +0 -343
- package/data/pages/Components/components/states.json +0 -1705
- package/data/pages/Components/components/statswidgets.json +0 -314
- package/data/pages/Components/components/statusbar.json +0 -177
- package/data/pages/Components/components/stepbutton.json +0 -57
- package/data/pages/Components/components/steppedprogressbars.json +0 -417
- package/data/pages/Components/components/subnavigation.json +0 -107
- package/data/pages/Components/components/supportmarker.json +0 -45
- package/data/pages/Components/components/svgimage.json +0 -81
- package/data/pages/Components/components/switch.json +0 -111
- package/data/pages/Components/components/tables.json +0 -144
- package/data/pages/Components/components/tagmanager.json +0 -86
- package/data/pages/Components/components/tags.json +0 -146
- package/data/pages/Components/components/teaser.json +0 -188
- package/data/pages/Components/components/timeline.json +0 -45
- package/data/pages/Components/components/timepicker.json +0 -163
- package/data/pages/Components/components/togglebutton.json +0 -247
- package/data/pages/Components/components/tooltip.json +0 -270
- package/data/pages/Components/components/virtuallist.json +0 -175
- package/data/pages/Foundations/foundations.json +0 -2475
- package/data/pages/Getting-started/start/changelog.json +0 -22
- package/data/pages/Getting-started/start/goodtoknow.json +0 -32
- package/data/pages/Getting-started/start/guidelines/color-combinations.json +0 -58
- package/data/pages/Getting-started/start/guidelines/custom-css.json +0 -27
- package/data/pages/Getting-started/start/guidelines/custom-rioglyph.json +0 -22
- package/data/pages/Getting-started/start/guidelines/formatting.json +0 -97
- package/data/pages/Getting-started/start/guidelines/iframe.json +0 -93
- package/data/pages/Getting-started/start/guidelines/obfuscate-data.json +0 -22
- package/data/pages/Getting-started/start/guidelines/print-css.json +0 -37
- package/data/pages/Getting-started/start/guidelines/spinner.json +0 -144
- package/data/pages/Getting-started/start/guidelines/supported-browsers.json +0 -22
- package/data/pages/Getting-started/start/guidelines/writing.json +0 -242
- package/data/pages/Getting-started/start/howto.json +0 -72
- package/data/pages/Getting-started/start/intro.json +0 -37
- package/data/pages/Getting-started/start/responsiveness.json +0 -52
- package/data/pages/Templates/templates/common-table.json +0 -39
- package/data/pages/Templates/templates/detail-views.json +0 -71
- package/data/pages/Templates/templates/expandable-details.json +0 -39
- package/data/pages/Templates/templates/feature-cards.json +0 -103
- package/data/pages/Templates/templates/form-summary.json +0 -39
- package/data/pages/Templates/templates/form-toggle.json +0 -39
- package/data/pages/Templates/templates/list-blocks.json +0 -119
- package/data/pages/Templates/templates/loading-progress.json +0 -39
- package/data/pages/Templates/templates/options-panel.json +0 -39
- package/data/pages/Templates/templates/panel-variants.json +0 -39
- package/data/pages/Templates/templates/progress-cards.json +0 -71
- package/data/pages/Templates/templates/progress-success.json +0 -39
- package/data/pages/Templates/templates/settings-form.json +0 -39
- package/data/pages/Templates/templates/stats-blocks.json +0 -135
- package/data/pages/Templates/templates/table-panel.json +0 -39
- package/data/pages/Templates/templates/table-row-animation.json +0 -39
- package/data/pages/Templates/templates/usage-cards.json +0 -39
- package/data/pages/Utilities/utilities/deviceutils.json +0 -39
- package/data/pages/Utilities/utilities/featuretoggles.json +0 -42
- package/data/pages/Utilities/utilities/fueltypeutils.json +0 -118
- package/data/pages/Utilities/utilities/routeutils.json +0 -34
- package/data/pages/Utilities/utilities/useaftermount.json +0 -63
- package/data/pages/Utilities/utilities/useaverage.json +0 -86
- package/data/pages/Utilities/utilities/useclickoutside.json +0 -69
- package/data/pages/Utilities/utilities/useclipboard.json +0 -57
- package/data/pages/Utilities/utilities/usecount.json +0 -92
- package/data/pages/Utilities/utilities/usedarkmode.json +0 -50
- package/data/pages/Utilities/utilities/usedebuginfo.json +0 -63
- package/data/pages/Utilities/utilities/useeffectonce.json +0 -57
- package/data/pages/Utilities/utilities/useelapsedtime.json +0 -57
- package/data/pages/Utilities/utilities/useelementsize.json +0 -63
- package/data/pages/Utilities/utilities/useesc.json +0 -57
- package/data/pages/Utilities/utilities/useevent.json +0 -75
- package/data/pages/Utilities/utilities/usefocustrap.json +0 -57
- package/data/pages/Utilities/utilities/usefullscreen.json +0 -197
- package/data/pages/Utilities/utilities/usehover.json +0 -57
- package/data/pages/Utilities/utilities/useinterval.json +0 -63
- package/data/pages/Utilities/utilities/useisfocuswithin.json +0 -75
- package/data/pages/Utilities/utilities/usekey.json +0 -75
- package/data/pages/Utilities/utilities/uselocalstorage.json +0 -69
- package/data/pages/Utilities/utilities/uselocationsuggestions.json +0 -110
- package/data/pages/Utilities/utilities/usemax.json +0 -86
- package/data/pages/Utilities/utilities/usemin.json +0 -86
- package/data/pages/Utilities/utilities/usemutationobserver.json +0 -69
- package/data/pages/Utilities/utilities/useonlinestatus.json +0 -39
- package/data/pages/Utilities/utilities/useonscreen.json +0 -63
- package/data/pages/Utilities/utilities/usepostmessage.json +0 -80
- package/data/pages/Utilities/utilities/useprevious.json +0 -63
- package/data/pages/Utilities/utilities/useresizeobserver.json +0 -65
- package/data/pages/Utilities/utilities/usescrollposition.json +0 -103
- package/data/pages/Utilities/utilities/usesearch.json +0 -197
- package/data/pages/Utilities/utilities/usesorting.json +0 -139
- package/data/pages/Utilities/utilities/usestatewithvalidation.json +0 -69
- package/data/pages/Utilities/utilities/usesum.json +0 -86
- package/data/pages/Utilities/utilities/usetableexport.json +0 -87
- package/data/pages/Utilities/utilities/usetableselection.json +0 -311
- package/data/pages/Utilities/utilities/usetimeout.json +0 -63
- package/data/pages/Utilities/utilities/usetoggle.json +0 -75
- package/data/pages/Utilities/utilities/usewindowresize.json +0 -63
- package/data/version.json +0 -4
- package/docs/content-schema.md +0 -147
- package/docs/navigation-inventory.json +0 -1310
- package/docs/search-synonyms.json +0 -43
- package/server/index.mjs +0 -268
- package/server/lib/load-docs.mjs +0 -48
- package/server/lib/normalise-doc.mjs +0 -220
- package/server/lib/render-markdown.mjs +0 -82
- package/server/lib/search-index.mjs +0 -49
- package/server/lib/types.js +0 -99
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
# MainNavigation
|
|
2
|
+
|
|
3
|
+
*Category:* Components
|
|
4
|
+
*Section:* Navigation
|
|
5
|
+
*Source:* https://uikit.developers.rio.cloud/#components/mainNavigation
|
|
6
|
+
*Captured:* 2025-12-12T12:38:07.047Z
|
|
7
|
+
|
|
8
|
+
## MainNavigation
|
|
9
|
+
|
|
10
|
+
> There is no dedicated MainNavigation Component. The navigation items are part of the ApplicationHeader
|
|
11
|
+
|
|
12
|
+
### Example: Example 1
|
|
13
|
+
|
|
14
|
+
RIO Service
|
|
15
|
+
|
|
16
|
+
Navigation 1
|
|
17
|
+
Navigation 2
|
|
18
|
+
Navigation 3
|
|
19
|
+
|
|
20
|
+
#### Summary
|
|
21
|
+
|
|
22
|
+
RIO Service
|
|
23
|
+
|
|
24
|
+
Navigation 1
|
|
25
|
+
Navigation 2
|
|
26
|
+
Navigation 3
|
|
27
|
+
|
|
28
|
+
#### React (tsx)
|
|
29
|
+
|
|
30
|
+
```tsx
|
|
31
|
+
import { NavLink } from 'react-router-dom';
|
|
32
|
+
|
|
33
|
+
import ApplicationLayout from '@rio-cloud/rio-uikit/ApplicationLayout';
|
|
34
|
+
import ApplicationHeader from '@rio-cloud/rio-uikit/ApplicationHeader';
|
|
35
|
+
|
|
36
|
+
const navItems = [
|
|
37
|
+
{ key: '1', route: <NavLink to='/components/appLayout'>Navigation 1</NavLink> },
|
|
38
|
+
{
|
|
39
|
+
key: '2',
|
|
40
|
+
route: (
|
|
41
|
+
<NavLink to='/2' onClick={event => event.preventDefault()}>
|
|
42
|
+
Navigation 2
|
|
43
|
+
</NavLink>
|
|
44
|
+
),
|
|
45
|
+
},
|
|
46
|
+
{
|
|
47
|
+
key: '3',
|
|
48
|
+
route: (
|
|
49
|
+
<NavLink to='/3' onClick={event => event.preventDefault()}>
|
|
50
|
+
Navigation 3
|
|
51
|
+
</NavLink>
|
|
52
|
+
),
|
|
53
|
+
},
|
|
54
|
+
];
|
|
55
|
+
|
|
56
|
+
export default () => (
|
|
57
|
+
<ApplicationLayout className='bg-lighter'>
|
|
58
|
+
<ApplicationLayout.Header>
|
|
59
|
+
<ApplicationHeader label='RIO Service' navItems={navItems} />
|
|
60
|
+
</ApplicationLayout.Header>
|
|
61
|
+
<ApplicationLayout.Body className='uikitDemo'>
|
|
62
|
+
<div className='dummy-class' />
|
|
63
|
+
</ApplicationLayout.Body>
|
|
64
|
+
</ApplicationLayout>
|
|
65
|
+
);
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
#### HTML (html)
|
|
69
|
+
|
|
70
|
+
```html
|
|
71
|
+
<div class="ApplicationLayout bg-lighter" style="--ApplicationLayoutBodyBottomBarHeight: 54px;">
|
|
72
|
+
<div class="ApplicationLayoutHeader" id="ApplicationLayoutHeader">
|
|
73
|
+
<nav class="ApplicationHeader user-select-none">
|
|
74
|
+
<div class="navbar-header">
|
|
75
|
+
<span class="navbar-brand home-icon">
|
|
76
|
+
</span>
|
|
77
|
+
</div>
|
|
78
|
+
<ul class="ModuleNavigation AppMenu user-select-none pointer-events-none">
|
|
79
|
+
<li class="dropdown">
|
|
80
|
+
<a class="ModuleNavigation-dropdown dropdown-toggle justify-content-between inactive" role="button" id="basic-nav-dropdown">
|
|
81
|
+
<span>RIO Service</span>
|
|
82
|
+
</a>
|
|
83
|
+
</li>
|
|
84
|
+
</ul>
|
|
85
|
+
<ul class="SubmoduleNavigation nav">
|
|
86
|
+
<li class="submodule " data-nav-item-key="1">
|
|
87
|
+
<a href="#components/appLayout">Navigation 1</a>
|
|
88
|
+
</li>
|
|
89
|
+
<li class="submodule " data-nav-item-key="2">
|
|
90
|
+
<a href="#2">Navigation 2</a>
|
|
91
|
+
</li>
|
|
92
|
+
<li class="submodule " data-nav-item-key="3">
|
|
93
|
+
<a href="#3">Navigation 3</a>
|
|
94
|
+
</li>
|
|
95
|
+
</ul>
|
|
96
|
+
<ul class="ApplicationActionBar nav navbar-nav navbar-right ">
|
|
97
|
+
</ul>
|
|
98
|
+
</nav>
|
|
99
|
+
</div>
|
|
100
|
+
<div class="ApplicationLayoutBody uikitDemo">
|
|
101
|
+
<div class="module-content-wrapper">
|
|
102
|
+
<div class="module-content smooth-scrollbar-wrapper" style="position: relative; overflow: hidden; width: 100%; height: 100%;">
|
|
103
|
+
<div class="scrollbar-view" style="position: absolute; inset: 0px; overflow: scroll; margin-right: 0px; margin-bottom: 0px;">
|
|
104
|
+
<div class="scrollbar-content-wrapper">
|
|
105
|
+
<div class="scrollbar-content">
|
|
106
|
+
<div class="dummy-class">
|
|
107
|
+
</div>
|
|
108
|
+
</div>
|
|
109
|
+
</div>
|
|
110
|
+
</div>
|
|
111
|
+
<div class="scrollbar-track-horizontal scrollbar-track-size-large scrollbar-track-offset" style="position: absolute; height: 6px; display: none;">
|
|
112
|
+
<div class="scrollbar-thumb-horizontal scrollbar-thumb-size-large" style="position: relative; display: block; height: 100%;">
|
|
113
|
+
</div>
|
|
114
|
+
</div>
|
|
115
|
+
<div class="scrollbar-track-vertical scrollbar-track-size-large scrollbar-track-offset" style="position: absolute; width: 6px; display: none;">
|
|
116
|
+
<div class="scrollbar-thumb-vertical scrollbar-thumb-size-large" style="position: relative; display: block; width: 100%;">
|
|
117
|
+
</div>
|
|
118
|
+
</div>
|
|
119
|
+
</div>
|
|
120
|
+
</div>
|
|
121
|
+
<span class="scroll-to-top">
|
|
122
|
+
<button type="button" class="btn btn-primary btn-icon-only">
|
|
123
|
+
<span class="rioglyph rioglyph-arrow-up">
|
|
124
|
+
</span>
|
|
125
|
+
</button>
|
|
126
|
+
</span>
|
|
127
|
+
</div>
|
|
128
|
+
</div>
|
|
129
|
+
```
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
# Circle
|
|
2
|
+
|
|
3
|
+
*Category:* Components
|
|
4
|
+
*Section:* Map
|
|
5
|
+
*Source:* https://uikit.developers.rio.cloud/#components/mapCircle
|
|
6
|
+
*Captured:* 2025-12-12T12:39:15.145Z
|
|
7
|
+
|
|
8
|
+
## Circle
|
|
9
|
+
|
|
10
|
+
### Example: Example 1
|
|
11
|
+
|
|
12
|
+
Terms of use© 1987–2025 HERE
|
|
13
|
+
|
|
14
|
+
10 km
|
|
15
|
+
|
|
16
|
+
Choose view
|
|
17
|
+
Map view
|
|
18
|
+
Satellite
|
|
19
|
+
|
|
20
|
+
Traffic conditions
|
|
21
|
+
Show traffic incidents
|
|
22
|
+
|
|
23
|
+
#### Summary
|
|
24
|
+
|
|
25
|
+
Terms of use© 1987–2025 HERE
|
|
26
|
+
|
|
27
|
+
10 km
|
|
28
|
+
|
|
29
|
+
Choose view
|
|
30
|
+
Map view
|
|
31
|
+
Satellite
|
|
32
|
+
|
|
33
|
+
Traffic conditions
|
|
34
|
+
Show traffic incidents
|
|
35
|
+
|
|
36
|
+
#### React (tsx)
|
|
37
|
+
|
|
38
|
+
```tsx
|
|
39
|
+
import Map from '@rio-cloud/rio-uikit/Map';
|
|
40
|
+
import EventUtils from '@rio-cloud/rio-uikit/EventUtils';
|
|
41
|
+
import MapSettings from '@rio-cloud/rio-uikit/MapSettings';
|
|
42
|
+
import MapTypeSettings from '@rio-cloud/rio-uikit/MapTypeSettings';
|
|
43
|
+
import Circle from '@rio-cloud/rio-uikit/Circle';
|
|
44
|
+
import type { MapEvent } from '@rio-cloud/rio-uikit/mapTypes';
|
|
45
|
+
|
|
46
|
+
import { UIKIT_DEMO_CREDENTIALS_ARE_NOT_ALLOWED_IN_PROD_ENVIRONMENT } from '../uikit_demo_credentials';
|
|
47
|
+
|
|
48
|
+
const STROKE_COLOR = 'rgba(90, 72, 118, 1)';
|
|
49
|
+
const FILL_COLOR = 'rgba(90, 72, 118, 0.3)';
|
|
50
|
+
|
|
51
|
+
const CircleExample = () => {
|
|
52
|
+
const position = { lat: 48.1351, lng: 11.582 };
|
|
53
|
+
|
|
54
|
+
const eventListenerMap = {
|
|
55
|
+
[EventUtils.TAP]: (event: MapEvent) => console.log(event),
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
return (
|
|
59
|
+
<Map
|
|
60
|
+
credentials={UIKIT_DEMO_CREDENTIALS_ARE_NOT_ALLOWED_IN_PROD_ENVIRONMENT}
|
|
61
|
+
center={position}
|
|
62
|
+
zoom={10}
|
|
63
|
+
height={300}
|
|
64
|
+
mapSettings={
|
|
65
|
+
<MapSettings
|
|
66
|
+
options={[
|
|
67
|
+
<MapTypeSettings
|
|
68
|
+
key='mapTypeSettings'
|
|
69
|
+
tooltip='Change map type'
|
|
70
|
+
dropdownHeaderText='Map views'
|
|
71
|
+
defaultTypeLabel='Default view'
|
|
72
|
+
truckTypeLabel='Truck view'
|
|
73
|
+
terrainTypeLabel='Terrain view'
|
|
74
|
+
satelliteTypeLabel='Satellite view'
|
|
75
|
+
nightTypeLabel='Night view'
|
|
76
|
+
/>,
|
|
77
|
+
]}
|
|
78
|
+
/>
|
|
79
|
+
}
|
|
80
|
+
>
|
|
81
|
+
<Circle
|
|
82
|
+
position={position}
|
|
83
|
+
radius={5_000}
|
|
84
|
+
style={{ strokeColor: STROKE_COLOR, fillColor: FILL_COLOR }}
|
|
85
|
+
precision={30}
|
|
86
|
+
eventListenerMap={eventListenerMap}
|
|
87
|
+
/>
|
|
88
|
+
</Map>
|
|
89
|
+
);
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
export default CircleExample;
|
|
93
|
+
```
|
|
@@ -0,0 +1,337 @@
|
|
|
1
|
+
# Clusters
|
|
2
|
+
|
|
3
|
+
*Category:* Components
|
|
4
|
+
*Section:* Map
|
|
5
|
+
*Source:* https://uikit.developers.rio.cloud/#components/mapCluster
|
|
6
|
+
*Captured:* 2025-12-12T12:39:13.237Z
|
|
7
|
+
|
|
8
|
+
## Clusters
|
|
9
|
+
|
|
10
|
+
### Example: Example 1
|
|
11
|
+
|
|
12
|
+
Terms of use© 1987–2025 HERE
|
|
13
|
+
|
|
14
|
+
50 km
|
|
15
|
+
|
|
16
|
+
Choose view
|
|
17
|
+
Map view
|
|
18
|
+
Satellite
|
|
19
|
+
|
|
20
|
+
Traffic conditions
|
|
21
|
+
Show traffic incidents
|
|
22
|
+
|
|
23
|
+
Regenerate dataToggle cluster
|
|
24
|
+
|
|
25
|
+
#### Summary
|
|
26
|
+
|
|
27
|
+
Terms of use© 1987–2025 HERE
|
|
28
|
+
|
|
29
|
+
50 km
|
|
30
|
+
|
|
31
|
+
Choose view
|
|
32
|
+
Map view
|
|
33
|
+
Satellite
|
|
34
|
+
|
|
35
|
+
Traffic conditions
|
|
36
|
+
Show traffic incidents
|
|
37
|
+
|
|
38
|
+
Regenerate dataToggle cluster
|
|
39
|
+
|
|
40
|
+
#### React (tsx)
|
|
41
|
+
|
|
42
|
+
```tsx
|
|
43
|
+
import { useState, useMemo } from 'react';
|
|
44
|
+
|
|
45
|
+
import Button from '@rio-cloud/rio-uikit/Button';
|
|
46
|
+
import Map from '@rio-cloud/rio-uikit/Map';
|
|
47
|
+
import MarkerLayer from '@rio-cloud/rio-uikit/MarkerLayer';
|
|
48
|
+
import EventUtils from '@rio-cloud/rio-uikit/EventUtils';
|
|
49
|
+
import MapSettings from '@rio-cloud/rio-uikit/MapSettings';
|
|
50
|
+
import MapTypeSettings from '@rio-cloud/rio-uikit/MapTypeSettings';
|
|
51
|
+
import MapClusterSettings from '@rio-cloud/rio-uikit/MapClusterSettings';
|
|
52
|
+
import SingleMapMarker from '@rio-cloud/rio-uikit/SingleMapMarker';
|
|
53
|
+
import ClusterMapMarker from '@rio-cloud/rio-uikit/ClusterMapMarker';
|
|
54
|
+
import type { MapEvent, Point } from '@rio-cloud/rio-uikit/mapTypes';
|
|
55
|
+
|
|
56
|
+
import { UIKIT_DEMO_CREDENTIALS_ARE_NOT_ALLOWED_IN_PROD_ENVIRONMENT } from '../uikit_demo_credentials';
|
|
57
|
+
import type { Asset } from '../settings/demoData';
|
|
58
|
+
|
|
59
|
+
const position = { lat: 49.1351, lng: 12.582 };
|
|
60
|
+
const NUM = 100;
|
|
61
|
+
|
|
62
|
+
const regenerateData = () =>
|
|
63
|
+
Array.from({ length: NUM * 2 }, (_, index) => {
|
|
64
|
+
const lat = position.lat + Math.random() * 6 - 3;
|
|
65
|
+
const lng = position.lng + Math.random() * 10 - 5;
|
|
66
|
+
return { lat, lng, data: `data-${index - NUM}`, name: `Asset ${index - NUM}`, type: 'truck' };
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
const ClustersExample = () => {
|
|
70
|
+
const [data, setData] = useState(regenerateData());
|
|
71
|
+
const [showCluster, setShowCluster] = useState(true);
|
|
72
|
+
|
|
73
|
+
const simpleTheme = useMemo(
|
|
74
|
+
() => ({
|
|
75
|
+
getNoisePresentation: ({ name, numberWarnings, numberExceptions, type }: Asset) => (
|
|
76
|
+
<SingleMapMarker
|
|
77
|
+
iconNames={[type]}
|
|
78
|
+
name={name}
|
|
79
|
+
warningCount={numberWarnings}
|
|
80
|
+
exceptionCount={numberExceptions}
|
|
81
|
+
/>
|
|
82
|
+
),
|
|
83
|
+
getClusterPresentation: (assets: Asset[]) => (
|
|
84
|
+
<ClusterMapMarker
|
|
85
|
+
count={assets.length}
|
|
86
|
+
warningCount={Math.floor((assets.length * 10) / 3)}
|
|
87
|
+
exceptionCount={Math.floor((assets.length * 10) / 5)}
|
|
88
|
+
/>
|
|
89
|
+
),
|
|
90
|
+
}),
|
|
91
|
+
[]
|
|
92
|
+
);
|
|
93
|
+
|
|
94
|
+
const handleClusterEvent = (event: MapEvent) => {
|
|
95
|
+
const target = event.target.getData();
|
|
96
|
+
event.stopPropagation();
|
|
97
|
+
|
|
98
|
+
if (target.isCluster()) {
|
|
99
|
+
console.log('cluster event:', event.type);
|
|
100
|
+
target.forEachDataPoint((point: Point) => console.log(point.getData()));
|
|
101
|
+
} else {
|
|
102
|
+
console.log('noise point event:', event.type, target.getData());
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
|
|
106
|
+
const handleToggleCluster = () => setShowCluster(!showCluster);
|
|
107
|
+
|
|
108
|
+
const handleClusterChange = (newShowCluster: boolean) => setShowCluster(newShowCluster);
|
|
109
|
+
|
|
110
|
+
const handleRegenerateDataButtonClick = () => {
|
|
111
|
+
setData(regenerateData);
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
const eventListenerMap = EventUtils.createTapOnDblTapPreventer({
|
|
115
|
+
[EventUtils.TAP]: handleClusterEvent,
|
|
116
|
+
[EventUtils.DBL_TAP]: handleClusterEvent,
|
|
117
|
+
});
|
|
118
|
+
|
|
119
|
+
return (
|
|
120
|
+
<>
|
|
121
|
+
<Map
|
|
122
|
+
credentials={UIKIT_DEMO_CREDENTIALS_ARE_NOT_ALLOWED_IN_PROD_ENVIRONMENT}
|
|
123
|
+
center={position}
|
|
124
|
+
zoom={8}
|
|
125
|
+
height={400}
|
|
126
|
+
showCluster={showCluster}
|
|
127
|
+
onShowClusterChange={handleClusterChange}
|
|
128
|
+
mapSettings={
|
|
129
|
+
<MapSettings
|
|
130
|
+
options={[
|
|
131
|
+
<MapTypeSettings
|
|
132
|
+
key='mapTypeSettings'
|
|
133
|
+
tooltip='Change map type'
|
|
134
|
+
dropdownHeaderText='Map views'
|
|
135
|
+
defaultTypeLabel='Default view'
|
|
136
|
+
truckTypeLabel='Truck view'
|
|
137
|
+
terrainTypeLabel='Terrain view'
|
|
138
|
+
satelliteTypeLabel='Satellite view'
|
|
139
|
+
nightTypeLabel='Night view'
|
|
140
|
+
/>,
|
|
141
|
+
<MapClusterSettings
|
|
142
|
+
key='mapClusterSettings'
|
|
143
|
+
tooltip='Enable or disable marker cluster'
|
|
144
|
+
dropdownHeaderText='Vehicle cluster'
|
|
145
|
+
clusterEnabledLabel='Enable cluster'
|
|
146
|
+
clusterDisabledLabel='Disable cluster'
|
|
147
|
+
/>,
|
|
148
|
+
]}
|
|
149
|
+
/>
|
|
150
|
+
}
|
|
151
|
+
>
|
|
152
|
+
<MarkerLayer data={data} eventListenerMap={eventListenerMap} simpleTheme={simpleTheme} />
|
|
153
|
+
</Map>
|
|
154
|
+
<div className='btn-toolbar margin-top-10'>
|
|
155
|
+
<Button onClick={handleRegenerateDataButtonClick}>Regenerate data</Button>
|
|
156
|
+
<Button onClick={handleToggleCluster}>Toggle cluster</Button>
|
|
157
|
+
</div>
|
|
158
|
+
</>
|
|
159
|
+
);
|
|
160
|
+
};
|
|
161
|
+
|
|
162
|
+
export default ClustersExample;
|
|
163
|
+
```
|
|
164
|
+
|
|
165
|
+
## Clusters with POIs
|
|
166
|
+
|
|
167
|
+
### Example: Example 2
|
|
168
|
+
|
|
169
|
+
Terms of use© 1987–2025 HERE
|
|
170
|
+
|
|
171
|
+
50 km
|
|
172
|
+
|
|
173
|
+
Choose view
|
|
174
|
+
Map view
|
|
175
|
+
Satellite
|
|
176
|
+
|
|
177
|
+
Traffic conditions
|
|
178
|
+
Show traffic incidents
|
|
179
|
+
|
|
180
|
+
Regenerate data
|
|
181
|
+
|
|
182
|
+
#### Summary
|
|
183
|
+
|
|
184
|
+
Terms of use© 1987–2025 HERE
|
|
185
|
+
|
|
186
|
+
50 km
|
|
187
|
+
|
|
188
|
+
Choose view
|
|
189
|
+
Map view
|
|
190
|
+
Satellite
|
|
191
|
+
|
|
192
|
+
Traffic conditions
|
|
193
|
+
Show traffic incidents
|
|
194
|
+
|
|
195
|
+
Regenerate data
|
|
196
|
+
|
|
197
|
+
#### React (tsx)
|
|
198
|
+
|
|
199
|
+
```tsx
|
|
200
|
+
import { useState, useMemo } from 'react';
|
|
201
|
+
|
|
202
|
+
import Button from '@rio-cloud/rio-uikit/Button';
|
|
203
|
+
import Map from '@rio-cloud/rio-uikit/Map';
|
|
204
|
+
import MarkerLayer from '@rio-cloud/rio-uikit/MarkerLayer';
|
|
205
|
+
import EventUtils from '@rio-cloud/rio-uikit/EventUtils';
|
|
206
|
+
import MapSettings from '@rio-cloud/rio-uikit/MapSettings';
|
|
207
|
+
import MapTypeSettings from '@rio-cloud/rio-uikit/MapTypeSettings';
|
|
208
|
+
import SingleMapMarker from '@rio-cloud/rio-uikit/SingleMapMarker';
|
|
209
|
+
import ClusterMapMarker from '@rio-cloud/rio-uikit/ClusterMapMarker';
|
|
210
|
+
import type { MapEvent, Point } from '@rio-cloud/rio-uikit/mapTypes';
|
|
211
|
+
|
|
212
|
+
import { UIKIT_DEMO_CREDENTIALS_ARE_NOT_ALLOWED_IN_PROD_ENVIRONMENT } from '../uikit_demo_credentials';
|
|
213
|
+
import type { Asset } from '../settings/demoData';
|
|
214
|
+
|
|
215
|
+
const position = { lat: 49.1351, lng: 12.582 };
|
|
216
|
+
const NUM = 500;
|
|
217
|
+
|
|
218
|
+
type Poi = {
|
|
219
|
+
data: string;
|
|
220
|
+
name: string;
|
|
221
|
+
type: string;
|
|
222
|
+
};
|
|
223
|
+
|
|
224
|
+
const regenerateAssetData = () =>
|
|
225
|
+
Array.from({ length: NUM * 2 }, (_, index) => {
|
|
226
|
+
const lat = position.lat + Math.random() * 6 - 3;
|
|
227
|
+
const lng = position.lng + Math.random() * 10 - 5;
|
|
228
|
+
return { lat, lng, data: `data-${index - NUM}`, name: `Asset ${index - NUM}`, type: 'truck' };
|
|
229
|
+
});
|
|
230
|
+
|
|
231
|
+
const regeneratePoiData = () =>
|
|
232
|
+
Array.from({ length: NUM * 2 }, (_, index) => {
|
|
233
|
+
const lat = position.lat + Math.random() * 6 - 3;
|
|
234
|
+
const lng = position.lng + Math.random() * 10 - 5;
|
|
235
|
+
return { lat, lng, data: `data-${index - NUM}`, name: `Poi ${index - NUM}`, type: 'pushpin' };
|
|
236
|
+
});
|
|
237
|
+
|
|
238
|
+
const ClustersExample = () => {
|
|
239
|
+
const [assets, setAssets] = useState(regenerateAssetData());
|
|
240
|
+
const [pois, setPois] = useState(regeneratePoiData());
|
|
241
|
+
|
|
242
|
+
const assetTheme = useMemo(
|
|
243
|
+
() => ({
|
|
244
|
+
getNoisePresentation: ({ name, numberWarnings, numberExceptions, type }: Asset) => (
|
|
245
|
+
<SingleMapMarker
|
|
246
|
+
iconNames={[type]}
|
|
247
|
+
name={name}
|
|
248
|
+
warningCount={numberWarnings}
|
|
249
|
+
exceptionCount={numberExceptions}
|
|
250
|
+
/>
|
|
251
|
+
),
|
|
252
|
+
getClusterPresentation: ({ length }: Asset[]) => (
|
|
253
|
+
<ClusterMapMarker
|
|
254
|
+
count={length}
|
|
255
|
+
warningCount={Math.floor((length * 10) / 3)}
|
|
256
|
+
exceptionCount={Math.floor((length * 10) / 5)}
|
|
257
|
+
/>
|
|
258
|
+
),
|
|
259
|
+
}),
|
|
260
|
+
[]
|
|
261
|
+
);
|
|
262
|
+
|
|
263
|
+
const poiTheme = useMemo(
|
|
264
|
+
() => ({
|
|
265
|
+
getNoisePresentation: ({ name }: Poi) => (
|
|
266
|
+
<SingleMapMarker iconNames={['pushpin']} name={name} markerColor='bg-map-marker-poi' />
|
|
267
|
+
),
|
|
268
|
+
getClusterPresentation: ({ length }: Poi[]) => (
|
|
269
|
+
<ClusterMapMarker iconName='pushpin' markerColor='bg-map-marker-poi' count={length} />
|
|
270
|
+
),
|
|
271
|
+
}),
|
|
272
|
+
[]
|
|
273
|
+
);
|
|
274
|
+
|
|
275
|
+
const handleClusterEvent = (event: MapEvent) => {
|
|
276
|
+
const target = event.target.getData();
|
|
277
|
+
event.stopPropagation();
|
|
278
|
+
|
|
279
|
+
if (target.isCluster()) {
|
|
280
|
+
console.log('cluster event:', event.type);
|
|
281
|
+
target.forEachDataPoint((point: Point) => console.log(point.getData()));
|
|
282
|
+
} else {
|
|
283
|
+
console.log('noise point event:', event.type, target.getData());
|
|
284
|
+
}
|
|
285
|
+
};
|
|
286
|
+
|
|
287
|
+
const handleRegenerateDataButtonClick = () => {
|
|
288
|
+
setAssets(regenerateAssetData);
|
|
289
|
+
setPois(regeneratePoiData);
|
|
290
|
+
};
|
|
291
|
+
|
|
292
|
+
const eventListenerMap = EventUtils.createTapOnDblTapPreventer({
|
|
293
|
+
[EventUtils.TAP]: handleClusterEvent,
|
|
294
|
+
[EventUtils.DBL_TAP]: handleClusterEvent,
|
|
295
|
+
});
|
|
296
|
+
|
|
297
|
+
return (
|
|
298
|
+
<>
|
|
299
|
+
<Map
|
|
300
|
+
credentials={UIKIT_DEMO_CREDENTIALS_ARE_NOT_ALLOWED_IN_PROD_ENVIRONMENT}
|
|
301
|
+
center={position}
|
|
302
|
+
zoom={8}
|
|
303
|
+
height={400}
|
|
304
|
+
mapSettings={
|
|
305
|
+
<MapSettings
|
|
306
|
+
options={[
|
|
307
|
+
<MapTypeSettings
|
|
308
|
+
key='mapTypeSettings'
|
|
309
|
+
tooltip='Change map type'
|
|
310
|
+
dropdownHeaderText='Map views'
|
|
311
|
+
defaultTypeLabel='Default view'
|
|
312
|
+
truckTypeLabel='Truck view'
|
|
313
|
+
terrainTypeLabel='Terrain view'
|
|
314
|
+
satelliteTypeLabel='Satellite view'
|
|
315
|
+
nightTypeLabel='Night view'
|
|
316
|
+
/>,
|
|
317
|
+
]}
|
|
318
|
+
/>
|
|
319
|
+
}
|
|
320
|
+
>
|
|
321
|
+
<MarkerLayer
|
|
322
|
+
data={pois}
|
|
323
|
+
simpleTheme={poiTheme}
|
|
324
|
+
clusterDissolvable={false}
|
|
325
|
+
eventListenerMap={eventListenerMap}
|
|
326
|
+
/>
|
|
327
|
+
<MarkerLayer data={assets} simpleTheme={assetTheme} eventListenerMap={eventListenerMap} />
|
|
328
|
+
</Map>
|
|
329
|
+
<div className='btn-toolbar margin-top-10'>
|
|
330
|
+
<Button onClick={handleRegenerateDataButtonClick}>Regenerate data</Button>
|
|
331
|
+
</div>
|
|
332
|
+
</>
|
|
333
|
+
);
|
|
334
|
+
};
|
|
335
|
+
|
|
336
|
+
export default ClustersExample;
|
|
337
|
+
```
|