@datalayer/core 0.0.1 → 0.0.3
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 +187 -7
- package/lib/App.css +47 -0
- package/lib/App.d.ts +3 -0
- package/lib/App.js +21 -5
- package/lib/__tests__/App.test.d.ts +1 -0
- package/lib/__tests__/App.test.js +17 -0
- package/lib/__tests__/hooks.test.d.ts +1 -0
- package/lib/__tests__/hooks.test.js +19 -0
- package/lib/__tests__/index.test.d.ts +1 -0
- package/lib/__tests__/index.test.js +27 -0
- package/lib/__tests__/integration.test.d.ts +1 -0
- package/lib/__tests__/integration.test.js +57 -0
- package/lib/__tests__/utils.test.d.ts +1 -0
- package/lib/__tests__/utils.test.js +59 -0
- package/lib/api/DatalayerApi.d.ts +75 -0
- package/lib/api/DatalayerApi.js +145 -0
- package/lib/api/index.d.ts +3 -0
- package/lib/api/index.js +7 -0
- package/lib/api/jupyter/exec/Python.d.ts +5 -0
- package/lib/api/jupyter/exec/Python.js +100 -0
- package/lib/api/jupyter/exec/Snippets.d.ts +145 -0
- package/lib/api/jupyter/exec/Snippets.js +120 -0
- package/lib/api/jupyter/exec/index.d.ts +2 -0
- package/lib/api/jupyter/exec/index.js +6 -0
- package/lib/api/jupyter/index.d.ts +2 -0
- package/lib/api/jupyter/index.js +6 -0
- package/lib/api/jupyter/kernelsHandler.d.ts +8 -0
- package/lib/api/jupyter/kernelsHandler.js +39 -0
- package/lib/api/runtimes/actions.d.ts +102 -0
- package/lib/api/runtimes/actions.js +264 -0
- package/lib/api/runtimes/apis.d.ts +273 -0
- package/lib/api/runtimes/apis.js +5 -0
- package/lib/api/runtimes/index.d.ts +5 -0
- package/lib/api/runtimes/index.js +9 -0
- package/lib/api/runtimes/settings.d.ts +15 -0
- package/lib/api/runtimes/settings.js +31 -0
- package/lib/api/runtimes/snapshots.d.ts +25 -0
- package/lib/api/runtimes/snapshots.js +150 -0
- package/lib/api/runtimes/utils.d.ts +7 -0
- package/lib/api/runtimes/utils.js +17 -0
- package/lib/assets/react.svg +1 -0
- package/lib/components/avatars/BoringAvatar.d.ts +19 -0
- package/lib/components/avatars/BoringAvatar.js +44 -0
- package/lib/components/avatars/BoringAvatar.stories.d.ts +27 -0
- package/lib/components/avatars/BoringAvatar.stories.js +23 -0
- package/lib/components/avatars/UserProfileAvatar.d.ts +13 -0
- package/lib/components/avatars/UserProfileAvatar.js +32 -0
- package/lib/components/avatars/index.d.ts +2 -0
- package/lib/components/avatars/index.js +6 -0
- package/lib/components/banners/NoAutomationBanner.d.ts +2 -0
- package/lib/components/banners/NoAutomationBanner.js +13 -0
- package/lib/components/banners/index.d.ts +1 -0
- package/lib/components/banners/index.js +5 -0
- package/lib/components/buttons/DownloadCSVButton.d.ts +13 -0
- package/lib/components/buttons/DownloadCSVButton.js +16 -0
- package/lib/components/buttons/DownloadJsonButton.d.ts +16 -0
- package/lib/components/buttons/DownloadJsonButton.js +18 -0
- package/lib/components/buttons/LongActionButton.d.ts +28 -0
- package/lib/components/buttons/LongActionButton.js +24 -0
- package/lib/components/buttons/UploadButton.d.ts +37 -0
- package/lib/components/buttons/UploadButton.js +43 -0
- package/lib/components/buttons/VariantType.d.ts +1 -0
- package/lib/components/buttons/VariantType.js +5 -0
- package/lib/components/buttons/index.d.ts +5 -0
- package/lib/components/buttons/index.js +9 -0
- package/lib/components/checkout/StripeCheckout.d.ts +32 -0
- package/lib/components/checkout/StripeCheckout.js +95 -0
- package/lib/components/checkout/index.d.ts +1 -0
- package/lib/components/checkout/index.js +5 -0
- package/lib/components/confetti/ConfettiSuccess.d.ts +2 -0
- package/lib/components/confetti/ConfettiSuccess.js +12 -0
- package/lib/components/confetti/index.d.ts +1 -0
- package/lib/components/confetti/index.js +5 -0
- package/lib/components/context/OrganizationSelect.d.ts +2 -0
- package/lib/components/context/OrganizationSelect.js +35 -0
- package/lib/components/context/SpaceSelect.d.ts +2 -0
- package/lib/components/context/SpaceSelect.js +43 -0
- package/lib/components/context/index.d.ts +2 -0
- package/lib/components/context/index.js +6 -0
- package/lib/components/display/AvatarSkeleton.d.ts +5 -0
- package/lib/components/display/AvatarSkeleton.js +11 -0
- package/lib/components/display/CenteredSpinner.d.ts +14 -0
- package/lib/components/display/CenteredSpinner.js +20 -0
- package/lib/components/display/CodePreview.d.ts +4 -0
- package/lib/components/display/CodePreview.js +15 -0
- package/lib/components/display/DatalayerBox.d.ts +8 -0
- package/lib/components/display/DatalayerBox.js +28 -0
- package/lib/components/display/HorizontalCenter.d.ts +9 -0
- package/lib/components/display/HorizontalCenter.js +14 -0
- package/lib/components/display/JupyterDialog.d.ts +69 -0
- package/lib/components/display/JupyterDialog.js +115 -0
- package/lib/components/display/Markdown.d.ts +23 -0
- package/lib/components/display/Markdown.js +20 -0
- package/lib/components/display/NavLink.d.ts +9 -0
- package/lib/components/display/NavLink.js +17 -0
- package/lib/components/display/NotebookSkeleton.d.ts +2 -0
- package/lib/components/display/NotebookSkeleton.js +11 -0
- package/lib/components/display/Placeholder.d.ts +2 -0
- package/lib/components/display/Placeholder.js +9 -0
- package/lib/components/display/ToTopBranded.d.ts +2 -0
- package/lib/components/display/ToTopBranded.js +11 -0
- package/lib/components/display/VisuallyHidden.d.ts +5 -0
- package/lib/components/display/VisuallyHidden.js +24 -0
- package/lib/components/display/index.d.ts +12 -0
- package/lib/components/display/index.js +16 -0
- package/lib/components/echarts/EChartsReact.d.ts +11 -0
- package/lib/components/echarts/EChartsReact.js +53 -0
- package/lib/components/echarts/index.d.ts +1 -0
- package/lib/components/echarts/index.js +5 -0
- package/lib/components/flashes/FlashClosable.d.ts +22 -0
- package/lib/components/flashes/FlashClosable.js +64 -0
- package/lib/components/flashes/FlashDisclaimer.d.ts +2 -0
- package/lib/components/flashes/FlashDisclaimer.js +18 -0
- package/lib/components/flashes/FlashGuest.d.ts +2 -0
- package/lib/components/flashes/FlashGuest.js +30 -0
- package/lib/components/flashes/FlashSurveys.d.ts +6 -0
- package/lib/components/flashes/FlashSurveys.js +36 -0
- package/lib/components/flashes/FlashUnauthorized.d.ts +2 -0
- package/lib/components/flashes/FlashUnauthorized.js +18 -0
- package/lib/components/flashes/index.d.ts +6 -0
- package/lib/components/flashes/index.js +10 -0
- package/lib/components/flashes/surveys/Survey2025_1.d.ts +3 -0
- package/lib/components/flashes/surveys/Survey2025_1.js +129 -0
- package/lib/components/flashes/surveys/SurveyProps.d.ts +6 -0
- package/lib/components/flashes/surveys/SurveyProps.js +5 -0
- package/lib/components/flashes/surveys/index.d.ts +2 -0
- package/lib/components/flashes/surveys/index.js +6 -0
- package/lib/components/iam/ExternalTokenSilentLogin.d.ts +5 -0
- package/lib/components/iam/ExternalTokenSilentLogin.js +33 -0
- package/lib/components/iam/index.d.ts +1 -0
- package/lib/components/iam/index.js +5 -0
- package/lib/components/icons/ArtifactIcon.d.ts +10 -0
- package/lib/components/icons/ArtifactIcon.js +58 -0
- package/lib/components/icons/index.d.ts +1 -0
- package/lib/components/icons/index.js +5 -0
- package/lib/components/index.d.ts +1 -0
- package/lib/components/index.js +5 -0
- package/lib/components/labels/VisibilityLabel.d.ts +4 -0
- package/lib/components/labels/VisibilityLabel.js +17 -0
- package/lib/components/labels/index.d.ts +1 -0
- package/lib/components/labels/index.js +5 -0
- package/lib/components/landings/StepBlock.d.ts +11 -0
- package/lib/components/landings/StepBlock.js +12 -0
- package/lib/components/landings/index.d.ts +1 -0
- package/lib/components/landings/index.js +5 -0
- package/lib/components/navbar/NavigationVisbilityObserver.d.ts +5 -0
- package/lib/components/navbar/NavigationVisbilityObserver.js +58 -0
- package/lib/components/navbar/SubdomainNavBar.d.ts +81 -0
- package/lib/components/navbar/SubdomainNavBar.js +235 -0
- package/lib/components/navbar/SubdomainNavBar.module.css +718 -0
- package/lib/components/navbar/index.d.ts +2 -0
- package/lib/components/navbar/index.js +6 -0
- package/lib/components/nbgrader/NbGradesDetails.d.ts +5 -0
- package/lib/components/nbgrader/NbGradesDetails.js +17 -0
- package/lib/components/nbgrader/index.d.ts +1 -0
- package/lib/components/nbgrader/index.js +5 -0
- package/lib/components/notebooks/JupyterNotebook.d.ts +12 -0
- package/lib/components/notebooks/JupyterNotebook.js +36 -0
- package/lib/components/notebooks/JupyterNotebookToolbar.d.ts +2 -0
- package/lib/components/notebooks/JupyterNotebookToolbar.js +39 -0
- package/lib/components/notebooks/index.d.ts +2 -0
- package/lib/components/notebooks/index.js +6 -0
- package/lib/components/primer/Helper.d.ts +32 -0
- package/lib/components/primer/Helper.js +19 -0
- package/lib/components/primer/Portals.d.ts +9 -0
- package/lib/components/primer/Portals.js +26 -0
- package/lib/components/primer/Styles.d.ts +2 -0
- package/lib/components/primer/Styles.js +11 -0
- package/lib/components/primer/index.d.ts +2 -0
- package/lib/components/primer/index.js +6 -0
- package/lib/components/progress/ConsumptionBar.d.ts +40 -0
- package/lib/components/progress/ConsumptionBar.js +49 -0
- package/lib/components/progress/CreditsIndicator.d.ts +27 -0
- package/lib/components/progress/CreditsIndicator.js +24 -0
- package/lib/components/progress/ProgressBar.d.ts +2 -0
- package/lib/components/progress/ProgressBar.js +21 -0
- package/lib/components/progress/ProgressRing.d.ts +36 -0
- package/lib/components/progress/ProgressRing.js +31 -0
- package/lib/components/progress/Timer.d.ts +9 -0
- package/lib/components/progress/Timer.js +28 -0
- package/lib/components/progress/index.d.ts +5 -0
- package/lib/components/progress/index.js +9 -0
- package/lib/components/runtimes/RuntimeCellVariables.d.ts +39 -0
- package/lib/components/runtimes/RuntimeCellVariables.js +172 -0
- package/lib/components/runtimes/RuntimeCellVariablesDialog.d.ts +37 -0
- package/lib/components/runtimes/RuntimeCellVariablesDialog.js +101 -0
- package/lib/components/runtimes/RuntimeLauncherDialog.d.ts +53 -0
- package/lib/components/runtimes/RuntimeLauncherDialog.js +250 -0
- package/lib/components/runtimes/RuntimePickerBase.d.ts +69 -0
- package/lib/components/runtimes/RuntimePickerBase.js +109 -0
- package/lib/components/runtimes/RuntimePickerCell.d.ts +34 -0
- package/lib/components/runtimes/RuntimePickerCell.js +106 -0
- package/lib/components/runtimes/RuntimePickerNotebook.d.ts +42 -0
- package/lib/components/runtimes/RuntimePickerNotebook.js +168 -0
- package/lib/components/runtimes/RuntimeReservationControl.d.ts +47 -0
- package/lib/components/runtimes/RuntimeReservationControl.js +38 -0
- package/lib/components/runtimes/RuntimeSimplePicker.d.ts +34 -0
- package/lib/components/runtimes/RuntimeSimplePicker.js +156 -0
- package/lib/components/runtimes/RuntimeTransfer.d.ts +16 -0
- package/lib/components/runtimes/RuntimeTransfer.js +5 -0
- package/lib/components/runtimes/RuntimeUtils.d.ts +17 -0
- package/lib/components/runtimes/RuntimeUtils.js +168 -0
- package/lib/components/runtimes/RuntimeVariables.d.ts +38 -0
- package/lib/components/runtimes/RuntimeVariables.js +75 -0
- package/lib/components/runtimes/index.d.ts +11 -0
- package/lib/components/runtimes/index.js +15 -0
- package/lib/components/screenshot/ScreenCapture.d.ts +38 -0
- package/lib/components/screenshot/ScreenCapture.js +174 -0
- package/lib/components/screenshot/ScreenCaptureButton.d.ts +3 -0
- package/lib/components/screenshot/ScreenCaptureButton.js +21 -0
- package/lib/components/screenshot/index.d.ts +2 -0
- package/lib/components/screenshot/index.js +6 -0
- package/lib/components/snapshots/RuntimeSnapshotMenu.d.ts +36 -0
- package/lib/components/snapshots/RuntimeSnapshotMenu.js +164 -0
- package/lib/components/snapshots/index.d.ts +1 -0
- package/lib/components/snapshots/index.js +5 -0
- package/lib/components/snippets/SnippetDialog.d.ts +42 -0
- package/lib/components/snippets/SnippetDialog.js +42 -0
- package/lib/components/snippets/index.d.ts +1 -0
- package/lib/components/snippets/index.js +5 -0
- package/lib/components/storage/ContentsBrowser.d.ts +32 -0
- package/lib/components/storage/ContentsBrowser.js +255 -0
- package/lib/components/storage/ContentsItems.d.ts +58 -0
- package/lib/components/storage/ContentsItems.js +78 -0
- package/lib/components/storage/index.d.ts +2 -0
- package/lib/components/storage/index.js +6 -0
- package/lib/components/students/StudentItemStatus.d.ts +7 -0
- package/lib/components/students/StudentItemStatus.js +47 -0
- package/lib/components/students/index.d.ts +1 -0
- package/lib/components/students/index.js +5 -0
- package/lib/components/subnav/SubNav.d.ts +84 -0
- package/lib/components/subnav/SubNav.js +265 -0
- package/lib/components/subnav/SubNav.module.css +683 -0
- package/lib/components/subnav/index.d.ts +1 -0
- package/lib/components/subnav/index.js +5 -0
- package/lib/components/tables/DataTable.d.ts +5 -0
- package/lib/components/tables/DataTable.js +19 -0
- package/lib/components/tables/index.d.ts +1 -0
- package/lib/components/tables/index.js +5 -0
- package/lib/components/text-reveal/TextRevealAnimation.d.ts +6 -0
- package/lib/components/text-reveal/TextRevealAnimation.js +49 -0
- package/lib/components/text-reveal/TextRevealAnimation.module.css +43 -0
- package/lib/components/text-reveal/index.d.ts +1 -0
- package/lib/components/text-reveal/index.js +5 -0
- package/lib/components/text-reveal/useTextRevealAnimationLines.d.ts +4 -0
- package/lib/components/text-reveal/useTextRevealAnimationLines.js +47 -0
- package/lib/components/tokens/SpaceVariantToken.d.ts +5 -0
- package/lib/components/tokens/SpaceVariantToken.js +20 -0
- package/lib/components/tokens/index.d.ts +1 -0
- package/lib/components/tokens/index.js +5 -0
- package/lib/components/toolbars/AssignmentEditorToolbar.d.ts +4 -0
- package/lib/components/toolbars/AssignmentEditorToolbar.js +18 -0
- package/lib/components/toolbars/DocumentEditorToolbar.d.ts +2 -0
- package/lib/components/toolbars/DocumentEditorToolbar.js +12 -0
- package/lib/components/toolbars/NotebookEditorToolbar.d.ts +29 -0
- package/lib/components/toolbars/NotebookEditorToolbar.js +30 -0
- package/lib/components/toolbars/index.d.ts +3 -0
- package/lib/components/toolbars/index.js +7 -0
- package/lib/components/users/PeerIndicator.d.ts +18 -0
- package/lib/components/users/PeerIndicator.js +100 -0
- package/lib/components/users/index.d.ts +1 -0
- package/lib/components/users/index.js +5 -0
- package/lib/config/Configuration.d.ts +111 -0
- package/lib/config/Configuration.js +25 -0
- package/lib/config/index.d.ts +2 -0
- package/lib/config/index.js +6 -0
- package/lib/config/integrations/Loom.d.ts +1 -0
- package/lib/config/integrations/Loom.js +16 -0
- package/lib/config/integrations/index.d.ts +1 -0
- package/lib/config/integrations/index.js +5 -0
- package/lib/examples/CellExample.d.ts +6 -0
- package/lib/examples/CellExample.js +24 -0
- package/lib/examples/NotebookExample.d.ts +8 -0
- package/lib/examples/NotebookExample.js +22 -0
- package/lib/examples/NotebookExample1.ipynb.json +136 -0
- package/lib/hooks/assets/OutputshotPlaceholders.d.ts +19 -0
- package/lib/hooks/assets/OutputshotPlaceholders.js +23 -0
- package/lib/hooks/assets/index.d.ts +1 -0
- package/lib/hooks/assets/index.js +5 -0
- package/lib/hooks/index.d.ts +28 -0
- package/lib/hooks/index.js +33 -0
- package/lib/hooks/layouts/LayoutBackdrop.d.ts +2 -0
- package/lib/hooks/layouts/LayoutBackdrop.js +30 -0
- package/lib/hooks/layouts/LayoutScreenshot.css +58 -0
- package/lib/hooks/layouts/LayoutScreenshot.d.ts +3 -0
- package/lib/hooks/layouts/LayoutScreenshot.js +44 -0
- package/lib/hooks/layouts/index.d.ts +2 -0
- package/lib/hooks/layouts/index.js +6 -0
- package/lib/hooks/useAIAgents.d.ts +13 -0
- package/lib/hooks/useAIAgents.js +72 -0
- package/lib/hooks/useAuthorization.d.ts +19 -0
- package/lib/hooks/useAuthorization.js +124 -0
- package/lib/hooks/useBackdrop.d.ts +28 -0
- package/lib/hooks/useBackdrop.js +100 -0
- package/lib/hooks/useBackdropJupyterLab.d.ts +15 -0
- package/lib/hooks/useBackdropJupyterLab.js +51 -0
- package/lib/hooks/useCache.d.ts +306 -0
- package/lib/hooks/useCache.js +3098 -0
- package/lib/hooks/useCellOutputshot.d.ts +4 -0
- package/lib/hooks/useCellOutputshot.js +28 -0
- package/lib/hooks/useContainsFocus.d.ts +9 -0
- package/lib/hooks/useContainsFocus.js +43 -0
- package/lib/hooks/useDatalayer.d.ts +21 -0
- package/lib/hooks/useDatalayer.js +81 -0
- package/lib/hooks/useError.d.ts +9 -0
- package/lib/hooks/useError.js +26 -0
- package/lib/hooks/useExternalScript.d.ts +2 -0
- package/lib/hooks/useExternalScript.js +17 -0
- package/lib/hooks/useFocusTrap.d.ts +30 -0
- package/lib/hooks/useFocusTrap.js +48 -0
- package/lib/hooks/useIAM.d.ts +14 -0
- package/lib/hooks/useIAM.js +93 -0
- package/lib/hooks/useId.d.ts +19 -0
- package/lib/hooks/useId.js +100 -0
- package/lib/hooks/useIsomorphicLayoutEffect.d.ts +3 -0
- package/lib/hooks/useIsomorphicLayoutEffect.js +11 -0
- package/lib/hooks/useJupyterLabTheme.d.ts +6 -0
- package/lib/hooks/useJupyterLabTheme.js +24 -0
- package/lib/hooks/useKeyboardEscape.d.ts +1 -0
- package/lib/hooks/useKeyboardEscape.js +18 -0
- package/lib/hooks/useLocationHandles.d.ts +10 -0
- package/lib/hooks/useLocationHandles.js +22 -0
- package/lib/hooks/useNavigate.d.ts +2 -0
- package/lib/hooks/useNavigate.js +24 -0
- package/lib/hooks/useNotebookAIAgent.d.ts +8 -0
- package/lib/hooks/useNotebookAIAgent.js +54 -0
- package/lib/hooks/useOnClickOutside.d.ts +1 -0
- package/lib/hooks/useOnClickOutside.js +29 -0
- package/lib/hooks/useRef.d.ts +10 -0
- package/lib/hooks/useRef.js +17 -0
- package/lib/hooks/useRuntimes.d.ts +5 -0
- package/lib/hooks/useRuntimes.js +34 -0
- package/lib/hooks/useScreenshot.d.ts +21 -0
- package/lib/hooks/useScreenshot.js +60 -0
- package/lib/hooks/useToast.d.ts +42 -0
- package/lib/hooks/useToast.js +141 -0
- package/lib/hooks/useUpload.d.ts +7 -0
- package/lib/hooks/useUpload.js +46 -0
- package/lib/hooks/useUser.d.ts +3 -0
- package/lib/hooks/useUser.js +22 -0
- package/lib/hooks/useVisibilityObserver.d.ts +5 -0
- package/lib/hooks/useVisibilityObserver.js +42 -0
- package/lib/hooks/useWindowSize.d.ts +21 -0
- package/lib/hooks/useWindowSize.js +74 -0
- package/lib/i18n/Labels.d.ts +1 -0
- package/lib/i18n/Labels.js +5 -0
- package/lib/i18n/index.d.ts +1 -0
- package/lib/i18n/index.js +5 -0
- package/lib/index.css +73 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.js +6 -0
- package/lib/main.d.ts +1 -0
- package/lib/main.js +5 -2
- package/lib/mocks/components/FlashMock.d.ts +2 -0
- package/lib/mocks/components/FlashMock.js +13 -0
- package/lib/mocks/components/index.d.ts +1 -0
- package/lib/mocks/components/index.js +5 -0
- package/lib/mocks/hooks/index.d.ts +1 -0
- package/lib/mocks/hooks/index.js +5 -0
- package/lib/mocks/hooks/rests/index.d.ts +1 -0
- package/lib/mocks/hooks/rests/index.js +5 -0
- package/lib/mocks/hooks/rests/rests.d.ts +22 -0
- package/lib/mocks/hooks/rests/rests.js +32 -0
- package/lib/mocks/hooks/useDatalayerMock.d.ts +6 -0
- package/lib/mocks/hooks/useDatalayerMock.js +78 -0
- package/lib/mocks/index.d.ts +4 -0
- package/lib/mocks/index.js +9 -0
- package/lib/mocks/jupyter/index.d.ts +1 -0
- package/lib/mocks/jupyter/index.js +5 -0
- package/lib/mocks/models/CodeBlockMock.d.ts +1 -0
- package/lib/mocks/models/CodeBlockMock.js +5 -0
- package/lib/mocks/models/CodelineMock.d.ts +1 -0
- package/lib/mocks/models/CodelineMock.js +5 -0
- package/lib/mocks/models/CourseMock.d.ts +6 -0
- package/lib/mocks/models/CourseMock.js +29 -0
- package/lib/mocks/models/InviteMock.d.ts +6 -0
- package/lib/mocks/models/InviteMock.js +22 -0
- package/lib/mocks/models/JupyterLabUserMock.d.ts +2 -0
- package/lib/mocks/models/JupyterLabUserMock.js +17 -0
- package/lib/mocks/models/OrganisationMock.d.ts +5 -0
- package/lib/mocks/models/OrganisationMock.js +24 -0
- package/lib/mocks/models/SchoolMock.d.ts +6 -0
- package/lib/mocks/models/SchoolMock.js +25 -0
- package/lib/mocks/models/SpaceMock.d.ts +6 -0
- package/lib/mocks/models/SpaceMock.js +25 -0
- package/lib/mocks/models/TeamMock.d.ts +5 -0
- package/lib/mocks/models/TeamMock.js +26 -0
- package/lib/mocks/models/UserMock.d.ts +2 -0
- package/lib/mocks/models/UserMock.js +29 -0
- package/lib/mocks/models/index.d.ts +9 -0
- package/lib/mocks/models/index.js +13 -0
- package/lib/mocks/views/ActionMenuMock.d.ts +5 -0
- package/lib/mocks/views/ActionMenuMock.js +12 -0
- package/lib/mocks/views/ChartMock.d.ts +5 -0
- package/lib/mocks/views/ChartMock.js +15 -0
- package/lib/mocks/views/ChartMockOptions.d.ts +92 -0
- package/lib/mocks/views/ChartMockOptions.js +102 -0
- package/lib/mocks/views/DashboardMock.d.ts +2 -0
- package/lib/mocks/views/DashboardMock.js +118 -0
- package/lib/mocks/views/FormMock.d.ts +5 -0
- package/lib/mocks/views/FormMock.js +28 -0
- package/lib/mocks/views/TableMock.d.ts +5 -0
- package/lib/mocks/views/TableMock.js +155 -0
- package/lib/mocks/views/WipMock.d.ts +5 -0
- package/lib/mocks/views/WipMock.js +12 -0
- package/lib/mocks/views/index.d.ts +7 -0
- package/lib/mocks/views/index.js +11 -0
- package/lib/models/AIAgent.d.ts +17 -0
- package/lib/models/AIAgent.js +5 -0
- package/lib/models/Account.d.ts +4 -0
- package/lib/models/Account.js +5 -0
- package/lib/models/Assignment.d.ts +7 -0
- package/lib/models/Assignment.js +5 -0
- package/lib/models/Base.d.ts +16 -0
- package/lib/models/Base.js +5 -0
- package/lib/models/Cell.d.ts +8 -0
- package/lib/models/Cell.js +5 -0
- package/lib/models/CodeBlock.d.ts +10 -0
- package/lib/models/CodeBlock.js +5 -0
- package/lib/models/CodefeedBlocks.d.ts +7 -0
- package/lib/models/CodefeedBlocks.js +5 -0
- package/lib/models/Contact.d.ts +73 -0
- package/lib/models/Contact.js +90 -0
- package/lib/models/ContactEvent.d.ts +10 -0
- package/lib/models/ContactEvent.js +14 -0
- package/lib/models/ContactIAMProvider.d.ts +12 -0
- package/lib/models/ContactIAMProvider.js +20 -0
- package/lib/models/ContactTags.d.ts +23 -0
- package/lib/models/ContactTags.js +73 -0
- package/lib/models/Content.d.ts +5 -0
- package/lib/models/Content.js +5 -0
- package/lib/models/Course.d.ts +17 -0
- package/lib/models/Course.js +5 -0
- package/lib/models/Credits.d.ts +76 -0
- package/lib/models/Credits.js +11 -0
- package/lib/models/Dataset.d.ts +16 -0
- package/lib/models/Dataset.js +5 -0
- package/lib/models/Datasource.d.ts +11 -0
- package/lib/models/Datasource.js +14 -0
- package/lib/models/Dean.d.ts +3 -0
- package/lib/models/Dean.js +5 -0
- package/lib/models/Document.d.ts +8 -0
- package/lib/models/Document.js +5 -0
- package/lib/models/Environment.d.ts +82 -0
- package/lib/models/Environment.js +5 -0
- package/lib/models/Errors.d.ts +6 -0
- package/lib/models/Errors.js +13 -0
- package/lib/models/Exercise.d.ts +16 -0
- package/lib/models/Exercise.js +5 -0
- package/lib/models/GrowthKPI.d.ts +5 -0
- package/lib/models/GrowthKPI.js +9 -0
- package/lib/models/IAMProviderLinked.d.ts +9 -0
- package/lib/models/IAMProviderLinked.js +13 -0
- package/lib/models/IAMProviderPost.d.ts +8 -0
- package/lib/models/IAMProviderPost.js +22 -0
- package/lib/models/IAMProviderUsers.d.ts +49 -0
- package/lib/models/IAMProviderUsers.js +29 -0
- package/lib/models/IAMProvidersSpecs.d.ts +22 -0
- package/lib/models/IAMProvidersSpecs.js +72 -0
- package/lib/models/IAMToken.d.ts +11 -0
- package/lib/models/IAMToken.js +14 -0
- package/lib/models/Inbound.d.ts +25 -0
- package/lib/models/Inbound.js +29 -0
- package/lib/models/Instructor.d.ts +3 -0
- package/lib/models/Instructor.js +5 -0
- package/lib/models/Invite.d.ts +14 -0
- package/lib/models/Invite.js +24 -0
- package/lib/models/Item.d.ts +20 -0
- package/lib/models/Item.js +5 -0
- package/lib/models/ItemType.d.ts +2 -0
- package/lib/models/ItemType.js +5 -0
- package/lib/models/LandingRoles.d.ts +3 -0
- package/lib/models/LandingRoles.js +27 -0
- package/lib/models/Lesson.d.ts +5 -0
- package/lib/models/Lesson.js +5 -0
- package/lib/models/Library.d.ts +10 -0
- package/lib/models/Library.js +5 -0
- package/lib/models/Member.d.ts +3 -0
- package/lib/models/Member.js +5 -0
- package/lib/models/Notebook.d.ts +11 -0
- package/lib/models/Notebook.js +5 -0
- package/lib/models/Organization.d.ts +27 -0
- package/lib/models/Organization.js +36 -0
- package/lib/models/OrganizationMember.d.ts +6 -0
- package/lib/models/OrganizationMember.js +5 -0
- package/lib/models/Outbound.d.ts +41 -0
- package/lib/models/Outbound.js +45 -0
- package/lib/models/Page.d.ts +36 -0
- package/lib/models/Page.js +23 -0
- package/lib/models/PageTag.d.ts +19 -0
- package/lib/models/PageTag.js +26 -0
- package/lib/models/Profile.d.ts +1 -0
- package/lib/models/Profile.js +5 -0
- package/lib/models/Role.d.ts +9 -0
- package/lib/models/Role.js +5 -0
- package/lib/models/RolesOrganization.d.ts +9 -0
- package/lib/models/RolesOrganization.js +58 -0
- package/lib/models/RolesPlatform.d.ts +16 -0
- package/lib/models/RolesPlatform.js +142 -0
- package/lib/models/RolesTeam.d.ts +7 -0
- package/lib/models/RolesTeam.js +34 -0
- package/lib/models/Runtime.d.ts +123 -0
- package/lib/models/Runtime.js +18 -0
- package/lib/models/RuntimeSnapshot.d.ts +92 -0
- package/lib/models/RuntimeSnapshot.js +13 -0
- package/lib/models/School.d.ts +11 -0
- package/lib/models/School.js +5 -0
- package/lib/models/Secret.d.ts +10 -0
- package/lib/models/Secret.js +13 -0
- package/lib/models/Space.d.ts +34 -0
- package/lib/models/Space.js +39 -0
- package/lib/models/SpaceItem.d.ts +10 -0
- package/lib/models/SpaceItem.js +5 -0
- package/lib/models/SpaceMember.d.ts +6 -0
- package/lib/models/SpaceMember.js +5 -0
- package/lib/models/Student.d.ts +6 -0
- package/lib/models/Student.js +5 -0
- package/lib/models/StudentItem.d.ts +21 -0
- package/lib/models/StudentItem.js +5 -0
- package/lib/models/Survey.d.ts +20 -0
- package/lib/models/Survey.js +14 -0
- package/lib/models/Team.d.ts +22 -0
- package/lib/models/Team.js +32 -0
- package/lib/models/TeamMember.d.ts +6 -0
- package/lib/models/TeamMember.js +5 -0
- package/lib/models/URN.d.ts +63 -0
- package/lib/models/URN.js +40 -0
- package/lib/models/Usage.d.ts +46 -0
- package/lib/models/Usage.js +21 -0
- package/lib/models/User.d.ts +71 -0
- package/lib/models/User.js +98 -0
- package/lib/models/UserEvent.d.ts +10 -0
- package/lib/models/UserEvent.js +14 -0
- package/lib/models/UserOnboarding.d.ts +14 -0
- package/lib/models/UserOnboarding.js +19 -0
- package/lib/models/UserSettings.d.ts +16 -0
- package/lib/models/UserSettings.js +27 -0
- package/lib/models/WaitingListFormData.d.ts +6 -0
- package/lib/models/WaitingListFormData.js +5 -0
- package/lib/models/index.d.ts +65 -0
- package/lib/models/index.js +69 -0
- package/lib/routes/Routes.d.ts +3 -0
- package/lib/routes/Routes.js +7 -0
- package/lib/routes/index.d.ts +1 -0
- package/lib/routes/index.js +5 -0
- package/lib/state/State.d.ts +33 -0
- package/lib/state/State.js +44 -0
- package/lib/state/index.d.ts +3 -0
- package/lib/state/index.js +7 -0
- package/lib/state/storage/IAMStorage.d.ts +33 -0
- package/lib/state/storage/IAMStorage.js +76 -0
- package/lib/state/storage/index.d.ts +1 -0
- package/lib/state/storage/index.js +5 -0
- package/lib/state/substates/AIAgentState.d.ts +11 -0
- package/lib/state/substates/AIAgentState.js +40 -0
- package/lib/state/substates/CellState.d.ts +12 -0
- package/lib/state/substates/CellState.js +21 -0
- package/lib/state/substates/CoreState.d.ts +25 -0
- package/lib/state/substates/CoreState.js +88 -0
- package/lib/state/substates/DatasourceState.d.ts +11 -0
- package/lib/state/substates/DatasourceState.js +16 -0
- package/lib/state/substates/DocumentState.d.ts +10 -0
- package/lib/state/substates/DocumentState.js +14 -0
- package/lib/state/substates/GradeState.d.ts +10 -0
- package/lib/state/substates/GradeState.js +14 -0
- package/lib/state/substates/IAMState.d.ts +75 -0
- package/lib/state/substates/IAMState.js +291 -0
- package/lib/state/substates/JupyterLabState.d.ts +16 -0
- package/lib/state/substates/JupyterLabState.js +17 -0
- package/lib/state/substates/LayoutState.d.ts +62 -0
- package/lib/state/substates/LayoutState.js +74 -0
- package/lib/state/substates/NbformatState.d.ts +13 -0
- package/lib/state/substates/NbformatState.js +16 -0
- package/lib/state/substates/OrganizationState.d.ts +11 -0
- package/lib/state/substates/OrganizationState.js +16 -0
- package/lib/state/substates/RuntimesState.d.ts +88 -0
- package/lib/state/substates/RuntimesState.js +178 -0
- package/lib/state/substates/SpaceState.d.ts +11 -0
- package/lib/state/substates/SpaceState.js +16 -0
- package/lib/state/substates/SurveysState.d.ts +14 -0
- package/lib/state/substates/SurveysState.js +98 -0
- package/lib/state/substates/TeamState.d.ts +11 -0
- package/lib/state/substates/TeamState.js +17 -0
- package/lib/state/substates/index.d.ts +15 -0
- package/lib/state/substates/index.js +19 -0
- package/lib/stories/assets/accessibility.png +0 -0
- package/lib/stories/assets/accessibility.svg +1 -0
- package/lib/stories/assets/addon-library.png +0 -0
- package/lib/stories/assets/assets.png +0 -0
- package/lib/stories/assets/context.png +0 -0
- package/lib/stories/assets/discord.svg +1 -0
- package/lib/stories/assets/docs.png +0 -0
- package/lib/stories/assets/figma-plugin.png +0 -0
- package/lib/stories/assets/github.svg +1 -0
- package/lib/stories/assets/share.png +0 -0
- package/lib/stories/assets/styling.png +0 -0
- package/lib/stories/assets/testing.png +0 -0
- package/lib/stories/assets/theming.png +0 -0
- package/lib/stories/assets/tutorials.svg +1 -0
- package/lib/stories/assets/youtube.svg +1 -0
- package/lib/stories/button.css +35 -0
- package/lib/stories/header.css +37 -0
- package/lib/stories/page.css +73 -0
- package/lib/test-setup.d.ts +1 -0
- package/lib/test-setup.js +57 -0
- package/lib/theme/DatalayerTheme.d.ts +37 -0
- package/lib/theme/DatalayerTheme.js +62 -0
- package/lib/theme/DatalayerThemeProvider.d.ts +17 -0
- package/lib/theme/DatalayerThemeProvider.js +69 -0
- package/lib/theme/Palette.d.ts +5 -0
- package/lib/theme/Palette.js +22 -0
- package/lib/theme/index.d.ts +3 -0
- package/lib/theme/index.js +7 -0
- package/lib/utils/Array.d.ts +2 -0
- package/lib/utils/Array.js +16 -0
- package/lib/utils/Avatar.d.ts +9 -0
- package/lib/utils/Avatar.js +34 -0
- package/lib/utils/Browser.d.ts +3 -0
- package/lib/utils/Browser.js +63 -0
- package/lib/utils/Cells.d.ts +2 -0
- package/lib/utils/Cells.js +28 -0
- package/lib/utils/Cookie.d.ts +12 -0
- package/lib/utils/Cookie.js +48 -0
- package/lib/utils/Date.d.ts +2 -0
- package/lib/utils/Date.js +60 -0
- package/lib/utils/Download.d.ts +3 -0
- package/lib/utils/Download.js +48 -0
- package/lib/utils/DownloadFile.d.ts +10 -0
- package/lib/utils/DownloadFile.js +36 -0
- package/lib/utils/Env.d.ts +1 -0
- package/lib/utils/Env.js +7 -0
- package/lib/utils/File.d.ts +7 -0
- package/lib/utils/File.js +16 -0
- package/lib/utils/Format.d.ts +17 -0
- package/lib/utils/Format.js +54 -0
- package/lib/utils/Ids.d.ts +2 -0
- package/lib/utils/Ids.js +12 -0
- package/lib/utils/Jupyter.d.ts +1 -0
- package/lib/utils/Jupyter.js +12 -0
- package/lib/utils/Lazy.d.ts +8 -0
- package/lib/utils/Lazy.js +23 -0
- package/lib/utils/Msc.d.ts +16 -0
- package/lib/utils/Msc.js +28 -0
- package/lib/utils/Name.d.ts +7 -0
- package/lib/utils/Name.js +34 -0
- package/lib/utils/Notebook.d.ts +19 -0
- package/lib/utils/Notebook.js +37 -0
- package/lib/utils/Number.d.ts +1 -0
- package/lib/utils/Number.js +21 -0
- package/lib/utils/Plots.d.ts +16 -0
- package/lib/utils/Plots.js +56 -0
- package/lib/utils/Random.d.ts +1 -0
- package/lib/utils/Random.js +7 -0
- package/lib/utils/Screenshot.d.ts +1 -0
- package/lib/utils/Screenshot.js +27 -0
- package/lib/utils/Scroll.d.ts +2 -0
- package/lib/utils/Scroll.js +32 -0
- package/lib/utils/Sleep.d.ts +2 -0
- package/lib/utils/Sleep.js +8 -0
- package/lib/utils/Snapshot.d.ts +7 -0
- package/lib/utils/Snapshot.js +21 -0
- package/lib/utils/String.d.ts +1 -0
- package/lib/utils/String.js +13 -0
- package/lib/utils/Uri.d.ts +2 -0
- package/lib/utils/Uri.js +26 -0
- package/lib/utils/Validator.d.ts +12 -0
- package/lib/utils/Validator.js +44 -0
- package/lib/utils/WithSuspense.d.ts +2 -0
- package/lib/utils/WithSuspense.js +21 -0
- package/lib/utils/index.d.ts +26 -0
- package/lib/utils/index.js +31 -0
- package/package.json +86 -17
- package/style/animation/Animation.module.css +174 -0
- package/style/base.css +62 -3
- package/style/index.css +2 -3
- package/style/index.js +0 -7
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { ICheckoutPortal } from '../../models';
|
|
2
|
+
/**
|
|
3
|
+
* Price item interface
|
|
4
|
+
*/
|
|
5
|
+
export interface IPrice {
|
|
6
|
+
/**
|
|
7
|
+
* Price ID
|
|
8
|
+
*/
|
|
9
|
+
id: string;
|
|
10
|
+
/**
|
|
11
|
+
* Price user readable name
|
|
12
|
+
*/
|
|
13
|
+
name: string;
|
|
14
|
+
/**
|
|
15
|
+
* Cost in cents
|
|
16
|
+
*/
|
|
17
|
+
amount: number;
|
|
18
|
+
/**
|
|
19
|
+
* Cost currency
|
|
20
|
+
*/
|
|
21
|
+
currency: string;
|
|
22
|
+
/**
|
|
23
|
+
* Computational credits to receive
|
|
24
|
+
*/
|
|
25
|
+
credits: number;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Stripe checkout.
|
|
29
|
+
*/
|
|
30
|
+
export declare function StripeCheckout({ checkoutPortal }: {
|
|
31
|
+
checkoutPortal: ICheckoutPortal | null;
|
|
32
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2023-2025 Datalayer, Inc.
|
|
4
|
+
* Distributed under the terms of the Modified BSD License.
|
|
5
|
+
*/
|
|
6
|
+
import { createElement, useCallback, useEffect, useState } from 'react';
|
|
7
|
+
import { Button, Flash, FormControl, Spinner, Text } from '@primer/react';
|
|
8
|
+
import { Box } from "@datalayer/primer-addons";
|
|
9
|
+
import { useCache } from '../../hooks';
|
|
10
|
+
import { useIAMStore } from '../../state';
|
|
11
|
+
/**
|
|
12
|
+
* Stripe checkout.
|
|
13
|
+
*/
|
|
14
|
+
export function StripeCheckout({ checkoutPortal }) {
|
|
15
|
+
const { iamRunUrl } = useIAMStore();
|
|
16
|
+
const { createCheckoutSession, refreshStripePrices } = useCache();
|
|
17
|
+
const [stripe, setStripe] = useState(null);
|
|
18
|
+
const [components, setComponents] = useState(null);
|
|
19
|
+
const [items, setItems] = useState(null);
|
|
20
|
+
const [product, setProduct] = useState(null);
|
|
21
|
+
const [checkout, setCheckout] = useState(false);
|
|
22
|
+
// Refresh Stripe items.
|
|
23
|
+
useEffect(() => {
|
|
24
|
+
refreshStripePrices()
|
|
25
|
+
.then(response => {
|
|
26
|
+
if (response.success) {
|
|
27
|
+
setItems(response.prices);
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
setItems([]);
|
|
31
|
+
}
|
|
32
|
+
})
|
|
33
|
+
.catch(error => {
|
|
34
|
+
console.error('Failed to fetch product items.', error);
|
|
35
|
+
setItems([]);
|
|
36
|
+
});
|
|
37
|
+
}, []);
|
|
38
|
+
// Load stripe components.
|
|
39
|
+
useEffect(() => {
|
|
40
|
+
import('@stripe/react-stripe-js').then(module => {
|
|
41
|
+
setComponents(module);
|
|
42
|
+
});
|
|
43
|
+
}, []);
|
|
44
|
+
// Load stripe API
|
|
45
|
+
useEffect(() => {
|
|
46
|
+
if (checkoutPortal?.metadata?.stripe_key) {
|
|
47
|
+
import('@stripe/stripe-js').then(module => {
|
|
48
|
+
setStripe(module.loadStripe(checkoutPortal.metadata.stripe_key));
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
}, [checkoutPortal?.metadata?.stripe_key]);
|
|
52
|
+
const fetchClientSecret = useCallback(() => {
|
|
53
|
+
const location = document.location;
|
|
54
|
+
// Create a Checkout Session.
|
|
55
|
+
return createCheckoutSession(product, location);
|
|
56
|
+
}, [iamRunUrl, location, product?.id]);
|
|
57
|
+
const options = { fetchClientSecret };
|
|
58
|
+
let view = (_jsx(Box, { sx: { minHeight: '40px' }, children: _jsx(Spinner, {}) }));
|
|
59
|
+
if (checkout) {
|
|
60
|
+
if (stripe && components) {
|
|
61
|
+
view = createElement(Box, { id: 'checkout', sx: { flex: '1 1 auto' } }, createElement(components.EmbeddedCheckoutProvider, { stripe, options }, createElement(components.EmbeddedCheckout)));
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
else if (items) {
|
|
65
|
+
view = items.length ? (_jsxs(Box, { sx: { flex: '1 1 auto' }, onKeyDown: event => {
|
|
66
|
+
if (product && event.key === 'Enter') {
|
|
67
|
+
setCheckout(true);
|
|
68
|
+
}
|
|
69
|
+
}, children: [_jsx(Text, { as: "h3", children: "Choose a credits package" }), _jsx(Box, { role: "radiogroup", sx: {
|
|
70
|
+
display: 'grid',
|
|
71
|
+
gap: 'var(--stack-gap-normal)',
|
|
72
|
+
gridTemplateColumns: Array(items.length).fill('1fr').join(' '),
|
|
73
|
+
padding: 'var(--stack-padding-normal) 0'
|
|
74
|
+
}, children: items.map(item => (_jsx(Box, { role: "radio", "aria-labelledby": `checkout-price-${item.id}`, "aria-checked": product?.id === item.id, onClick: () => {
|
|
75
|
+
setProduct(item);
|
|
76
|
+
}, sx: {
|
|
77
|
+
borderStyle: 'solid',
|
|
78
|
+
borderRadius: 'var(--borderRadius-medium)',
|
|
79
|
+
borderWidth: 'var(--borderWidth-thick)',
|
|
80
|
+
borderColor: product?.id === item.id
|
|
81
|
+
? 'var(--borderColor-accent-emphasis)'
|
|
82
|
+
: 'var(--borderColor-default)',
|
|
83
|
+
padding: 'var(--stack-padding-condensed)',
|
|
84
|
+
cursor: 'pointer'
|
|
85
|
+
}, children: _jsxs(FormControl, { sx: {
|
|
86
|
+
alignItems: 'center'
|
|
87
|
+
}, children: [_jsx(FormControl.Label, { id: `checkout-price-${item.id}`, sx: { alignSelf: 'center' }, children: item.name }), _jsx(Text, { as: "p", children: new Intl.NumberFormat(undefined, {
|
|
88
|
+
style: 'currency',
|
|
89
|
+
currency: item.currency
|
|
90
|
+
}).format(item.amount / 100) }), _jsxs(Text, { as: "p", children: [item.credits, " credits"] })] }, item.id) }))) }), _jsx(Button, { variant: "primary", onClick: () => {
|
|
91
|
+
setCheckout(true);
|
|
92
|
+
}, disabled: product === null, sx: { float: 'right' }, children: "Checkout" })] })) : (_jsx(Box, { children: _jsx(Flash, { variant: "danger", children: "Unable to fetch the available products. Please try again later." }) }));
|
|
93
|
+
}
|
|
94
|
+
return view;
|
|
95
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './StripeCheckout';
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2023-2025 Datalayer, Inc.
|
|
4
|
+
* Distributed under the terms of the Modified BSD License.
|
|
5
|
+
*/
|
|
6
|
+
import { useWindowSize } from 'usehooks-ts';
|
|
7
|
+
import Confetti from 'react-confetti';
|
|
8
|
+
export const ConfettiSuccess = () => {
|
|
9
|
+
const { width, height } = useWindowSize();
|
|
10
|
+
return (_jsx(Confetti, { width: width, height: height }));
|
|
11
|
+
};
|
|
12
|
+
export default ConfettiSuccess;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './ConfettiSuccess';
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2023-2025 Datalayer, Inc.
|
|
4
|
+
* Distributed under the terms of the Modified BSD License.
|
|
5
|
+
*/
|
|
6
|
+
import { useState, useEffect, useCallback } from "react";
|
|
7
|
+
import { Select } from "@primer/react";
|
|
8
|
+
import { useCache, useUser } from "./../../hooks";
|
|
9
|
+
import { useLayoutStore } from "../../state";
|
|
10
|
+
const NO_ORGANIZATION_SELECTED_VALUE = "NO_ORGANIZATION_SELECTED_VALUE";
|
|
11
|
+
export const OrganizationSelect = () => {
|
|
12
|
+
const user = useUser();
|
|
13
|
+
const { organization, updateLayoutOrganization, updateLayoutSpace } = useLayoutStore();
|
|
14
|
+
const { refreshUserOrganizations, getUserOrganizations } = useCache();
|
|
15
|
+
const [organizations, setOrganizations] = useState(getUserOrganizations());
|
|
16
|
+
const [_, setSelection] = useState(organization);
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
refreshUserOrganizations(user).then(resp => {
|
|
19
|
+
if (resp.success) {
|
|
20
|
+
setOrganizations(getUserOrganizations());
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
}, [user]);
|
|
24
|
+
const onSelectionChange = useCallback((e) => {
|
|
25
|
+
const selectedOrganization = e.target.value;
|
|
26
|
+
const org = selectedOrganization === NO_ORGANIZATION_SELECTED_VALUE
|
|
27
|
+
? undefined
|
|
28
|
+
: organizations[parseInt(selectedOrganization, 10)];
|
|
29
|
+
setSelection(org);
|
|
30
|
+
updateLayoutOrganization(org);
|
|
31
|
+
updateLayoutSpace(undefined);
|
|
32
|
+
}, [setSelection, organizations]);
|
|
33
|
+
return (_jsx(_Fragment, { children: _jsxs(Select, { block: true, width: "medium", onChange: onSelectionChange, children: [_jsx(Select.Option, { value: NO_ORGANIZATION_SELECTED_VALUE, selected: organization === undefined, children: "Please select an organization..." }), organizations.map((org, index) => (_jsx(Select.Option, { value: `${index}`, selected: org.id === organization?.id, children: org.name })))] }) }));
|
|
34
|
+
};
|
|
35
|
+
export default OrganizationSelect;
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2023-2025 Datalayer, Inc.
|
|
4
|
+
* Distributed under the terms of the Modified BSD License.
|
|
5
|
+
*/
|
|
6
|
+
import { useState, useEffect, useCallback } from "react";
|
|
7
|
+
import { FormControl, Select } from "@primer/react";
|
|
8
|
+
import { Box } from "@datalayer/primer-addons";
|
|
9
|
+
import { useCache, useUser } from "./../../hooks";
|
|
10
|
+
import { useLayoutStore } from "../../state";
|
|
11
|
+
export const SpaceSelect = () => {
|
|
12
|
+
const user = useUser();
|
|
13
|
+
const { organization, space, updateLayoutSpace } = useLayoutStore();
|
|
14
|
+
const { refreshUserSpaces, getUserSpaces, refreshOrganizationSpaces, getOrganizationSpaces } = useCache();
|
|
15
|
+
const [spaces, setSpaces] = useState([]);
|
|
16
|
+
const [_, setSelection] = useState(space);
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
if (organization) {
|
|
19
|
+
refreshOrganizationSpaces(organization.id).then(resp => {
|
|
20
|
+
if (resp.success) {
|
|
21
|
+
setSpaces(getOrganizationSpaces(organization.id));
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
refreshUserSpaces().then(resp => {
|
|
27
|
+
if (resp.success) {
|
|
28
|
+
setSpaces(getUserSpaces());
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
}, [user, organization]);
|
|
33
|
+
const onSelectionChange = useCallback((e) => {
|
|
34
|
+
const selectedSpace = e.target.value;
|
|
35
|
+
const org = (selectedSpace === undefined)
|
|
36
|
+
? undefined
|
|
37
|
+
: spaces[parseInt(selectedSpace, 10)];
|
|
38
|
+
setSelection(org);
|
|
39
|
+
updateLayoutSpace(org);
|
|
40
|
+
}, [setSelection, spaces]);
|
|
41
|
+
return (_jsx(_Fragment, { children: _jsx(Box, { as: "form", children: _jsxs(FormControl, { children: [_jsx(FormControl.Label, { children: "Select a space" }), _jsx(FormControl.Caption, { children: "This will go with you while you navigate" }), _jsx(Select, { block: true, width: "medium", onChange: onSelectionChange, placeholder: "Please select an space...", children: spaces.map((sp, index) => (_jsx(Select.Option, { value: `${index}`, selected: sp.id === space?.id, children: sp.name }))) })] }) }) }));
|
|
42
|
+
};
|
|
43
|
+
export default SpaceSelect;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2023-2025 Datalayer, Inc.
|
|
4
|
+
* Distributed under the terms of the Modified BSD License.
|
|
5
|
+
*/
|
|
6
|
+
import { SkeletonAvatar } from "@primer/react/experimental";
|
|
7
|
+
export const AvatarSkeleton = (props) => {
|
|
8
|
+
const { size } = props;
|
|
9
|
+
return (_jsx(_Fragment, { children: _jsx(SkeletonAvatar, { size: size }) }));
|
|
10
|
+
};
|
|
11
|
+
export default AvatarSkeleton;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
declare const sizeMap: {
|
|
2
|
+
small: string;
|
|
3
|
+
medium: string;
|
|
4
|
+
large: string;
|
|
5
|
+
};
|
|
6
|
+
type ICenteredSpinnerProps = {
|
|
7
|
+
message?: string;
|
|
8
|
+
size?: keyof typeof sizeMap;
|
|
9
|
+
};
|
|
10
|
+
export declare const CenteredSpinner: {
|
|
11
|
+
(props: ICenteredSpinnerProps): import("react/jsx-runtime").JSX.Element;
|
|
12
|
+
defaultProps: Partial<ICenteredSpinnerProps>;
|
|
13
|
+
};
|
|
14
|
+
export default CenteredSpinner;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2023-2025 Datalayer, Inc.
|
|
4
|
+
* Distributed under the terms of the Modified BSD License.
|
|
5
|
+
*/
|
|
6
|
+
import { Spinner, Text } from "@primer/react";
|
|
7
|
+
import { Box } from "@datalayer/primer-addons";
|
|
8
|
+
export const CenteredSpinner = (props) => {
|
|
9
|
+
const { message, size } = props;
|
|
10
|
+
return (_jsxs(Box, { sx: {
|
|
11
|
+
display: 'flex',
|
|
12
|
+
alignItems: 'center',
|
|
13
|
+
justifyContent: 'center',
|
|
14
|
+
minHeight: '40px'
|
|
15
|
+
}, children: [_jsx(Spinner, { size: size }), message && _jsx(Text, { sx: { marginLeft: 3 }, children: message })] }));
|
|
16
|
+
};
|
|
17
|
+
CenteredSpinner.defaultProps = {
|
|
18
|
+
size: "medium",
|
|
19
|
+
};
|
|
20
|
+
export default CenteredSpinner;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2023-2025 Datalayer, Inc.
|
|
4
|
+
* Distributed under the terms of the Modified BSD License.
|
|
5
|
+
*/
|
|
6
|
+
export const CodePreview = (props) => {
|
|
7
|
+
const { code } = props;
|
|
8
|
+
return (_jsx("pre", { style: {
|
|
9
|
+
fontSize: "12px",
|
|
10
|
+
wordBreak: "break-all",
|
|
11
|
+
wordWrap: "break-word",
|
|
12
|
+
whiteSpace: "pre-wrap",
|
|
13
|
+
}, children: code }));
|
|
14
|
+
};
|
|
15
|
+
export default CodePreview;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
type DatalayerBoxProps = {
|
|
2
|
+
id?: string;
|
|
3
|
+
title: string;
|
|
4
|
+
linkLabel?: string;
|
|
5
|
+
linkRoute?: string;
|
|
6
|
+
};
|
|
7
|
+
export declare const DatalayerBox: (props: React.PropsWithChildren<DatalayerBoxProps>) => import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export default DatalayerBox;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2023-2025 Datalayer, Inc.
|
|
4
|
+
* Distributed under the terms of the Modified BSD License.
|
|
5
|
+
*/
|
|
6
|
+
import { Link, Text } from "@primer/react";
|
|
7
|
+
import { Box } from "@datalayer/primer-addons";
|
|
8
|
+
import { ArrowRightIcon } from "@primer/octicons-react";
|
|
9
|
+
import { useNavigate } from "../../hooks";
|
|
10
|
+
export const DatalayerBox = (props) => {
|
|
11
|
+
const { title, linkLabel, linkRoute, children } = props;
|
|
12
|
+
const navigate = useNavigate();
|
|
13
|
+
return (_jsxs(_Fragment, { children: [_jsxs(Box, { sx: {
|
|
14
|
+
display: "flex",
|
|
15
|
+
alignItems: "center",
|
|
16
|
+
justifyContent: "space-between",
|
|
17
|
+
paddingRight: 4
|
|
18
|
+
}, children: [_jsx(Text, { as: "h2", sx: { borderLeft: "6px solid #28b899", paddingLeft: 2 }, children: title }), linkRoute && linkLabel &&
|
|
19
|
+
_jsxs(Link, { href: "javascript: return false;", onClick: e => navigate(linkRoute), children: [linkLabel, _jsx(ArrowRightIcon, {})] })] }), _jsx(Box, { sx: {
|
|
20
|
+
borderColor: "border.default",
|
|
21
|
+
borderStyle: "solid",
|
|
22
|
+
borderWidth: "1",
|
|
23
|
+
borderRadius: "2",
|
|
24
|
+
padding: 4,
|
|
25
|
+
marginTop: 2,
|
|
26
|
+
}, children: children })] }));
|
|
27
|
+
};
|
|
28
|
+
export default DatalayerBox;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { PropsWithChildren } from "react";
|
|
2
|
+
type IHorizontalCenterProps = {
|
|
3
|
+
margin?: string;
|
|
4
|
+
};
|
|
5
|
+
export declare const HorizontalCenter: {
|
|
6
|
+
(props: PropsWithChildren<IHorizontalCenterProps>): import("react/jsx-runtime").JSX.Element;
|
|
7
|
+
defaultProps: IHorizontalCenterProps;
|
|
8
|
+
};
|
|
9
|
+
export default HorizontalCenter;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
export const HorizontalCenter = (props) => {
|
|
3
|
+
const { children, margin } = props;
|
|
4
|
+
return (_jsx("div", { style: {
|
|
5
|
+
display: 'flex',
|
|
6
|
+
alignItems: 'center',
|
|
7
|
+
justifyContent: 'center',
|
|
8
|
+
margin,
|
|
9
|
+
}, children: children }));
|
|
10
|
+
};
|
|
11
|
+
HorizontalCenter.defaultProps = {
|
|
12
|
+
margin: "0px",
|
|
13
|
+
};
|
|
14
|
+
export default HorizontalCenter;
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { JSXElementConstructor, PropsWithChildren } from 'react';
|
|
2
|
+
import { Dialog } from '@jupyterlab/apputils';
|
|
3
|
+
import { ReactWidget } from '@jupyterlab/ui-components';
|
|
4
|
+
import { DialogProps } from '@primer/react/experimental';
|
|
5
|
+
/**
|
|
6
|
+
* {@link JupyterDialog} options
|
|
7
|
+
*/
|
|
8
|
+
export interface IDialogWrapperOptions<T> {
|
|
9
|
+
/**
|
|
10
|
+
* Node to which the dialog will be attached
|
|
11
|
+
*/
|
|
12
|
+
host: HTMLElement;
|
|
13
|
+
/**
|
|
14
|
+
* React element factory for the dialog body.
|
|
15
|
+
*
|
|
16
|
+
* The body component is receiving two special props:
|
|
17
|
+
* - {@link willClose} A signal emitted when the dialog is closing;
|
|
18
|
+
* body is expected to call {@link setValue} in reaction.
|
|
19
|
+
* - {@link setValue} A callback to set the dialog body value.
|
|
20
|
+
*/
|
|
21
|
+
body: JSXElementConstructor<PropsWithChildren<DialogProps & {
|
|
22
|
+
setValue: (v: T | Error) => void;
|
|
23
|
+
}>>;
|
|
24
|
+
/**
|
|
25
|
+
* The checkbox to display in the footer. Default non checkbox.
|
|
26
|
+
*/
|
|
27
|
+
checkbox: Partial<Dialog.ICheckbox> | null;
|
|
28
|
+
/**
|
|
29
|
+
* The buttons to display.
|
|
30
|
+
*/
|
|
31
|
+
buttons: Dialog.IButton[];
|
|
32
|
+
/**
|
|
33
|
+
* The top level text for the dialog.
|
|
34
|
+
*/
|
|
35
|
+
title: string;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* A primer dialog mimicking the JupyterLab dialog interface
|
|
39
|
+
*/
|
|
40
|
+
export declare class JupyterDialog<T> extends ReactWidget {
|
|
41
|
+
protected body: JSXElementConstructor<PropsWithChildren<DialogProps & {
|
|
42
|
+
setValue: (v: T | Error) => void;
|
|
43
|
+
}>>;
|
|
44
|
+
protected checkbox: Partial<Dialog.ICheckbox> | null;
|
|
45
|
+
protected buttons: Dialog.IButton[];
|
|
46
|
+
protected host: HTMLElement;
|
|
47
|
+
protected dialogTitle?: string;
|
|
48
|
+
private _closing;
|
|
49
|
+
private _result;
|
|
50
|
+
/**
|
|
51
|
+
* Create a dialog instance.
|
|
52
|
+
*/
|
|
53
|
+
constructor(options?: Partial<IDialogWrapperOptions<T>>);
|
|
54
|
+
private _renderBody;
|
|
55
|
+
private _renderFooter;
|
|
56
|
+
protected render(): JSX.Element | null;
|
|
57
|
+
/**
|
|
58
|
+
* Launch the dialog as a modal window.
|
|
59
|
+
*
|
|
60
|
+
* @returns a promise that resolves with the result of the dialog.
|
|
61
|
+
*/
|
|
62
|
+
launch(): Promise<Dialog.IResult<T>>;
|
|
63
|
+
protected handleButton: (idx: number) => void;
|
|
64
|
+
protected setButton: (button: Dialog.IButton) => void;
|
|
65
|
+
protected setChecked: (c: boolean) => void;
|
|
66
|
+
protected setValue: (v: T | Error) => void;
|
|
67
|
+
close: () => void;
|
|
68
|
+
}
|
|
69
|
+
export default JupyterDialog;
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/*
|
|
3
|
+
* Copyright (c) 2023-2025 Datalayer, Inc.
|
|
4
|
+
* Distributed under the terms of the Modified BSD License.
|
|
5
|
+
*/
|
|
6
|
+
import { createElement, useState } from 'react';
|
|
7
|
+
import { Dialog } from '@jupyterlab/apputils';
|
|
8
|
+
import { ReactWidget } from '@jupyterlab/ui-components';
|
|
9
|
+
import { PromiseDelegate } from '@lumino/coreutils';
|
|
10
|
+
import { Widget } from '@lumino/widgets';
|
|
11
|
+
import { FocusKeys } from '@primer/behaviors';
|
|
12
|
+
import { Checkbox, FormControl, useFocusZone } from '@primer/react';
|
|
13
|
+
import { Dialog as PrimerDialog } from '@primer/react/experimental';
|
|
14
|
+
function DialogFooter(props) {
|
|
15
|
+
const { checkbox, footerButtons, setChecked } = props;
|
|
16
|
+
const [checked, setLocalChecked] = useState();
|
|
17
|
+
const { containerRef: footerRef } = useFocusZone({
|
|
18
|
+
bindKeys: FocusKeys.ArrowHorizontal | FocusKeys.Tab,
|
|
19
|
+
focusInStrategy: 'closest'
|
|
20
|
+
});
|
|
21
|
+
return (_jsxs(PrimerDialog.Footer, { className: "dla-dialog-footer", ref: footerRef, children: [checkbox &&
|
|
22
|
+
_jsxs(FormControl, { layout: "horizontal", children: [_jsx(Checkbox, { className: checkbox.className ?? '', checked: checked, defaultChecked: checkbox.checked, onChange: e => {
|
|
23
|
+
setLocalChecked(e.target.checked);
|
|
24
|
+
setChecked(e.target.checked);
|
|
25
|
+
}, title: checkbox.caption ?? '' }), _jsx(FormControl.Label, { children: checkbox.label ?? '' })] }), _jsx("div", { className: "dla-dialog-footer-spacer" }), footerButtons &&
|
|
26
|
+
_jsx(PrimerDialog.Buttons, { buttons: footerButtons })] }));
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* A primer dialog mimicking the JupyterLab dialog interface
|
|
30
|
+
*/
|
|
31
|
+
export class JupyterDialog extends ReactWidget {
|
|
32
|
+
body;
|
|
33
|
+
checkbox;
|
|
34
|
+
buttons;
|
|
35
|
+
host;
|
|
36
|
+
dialogTitle;
|
|
37
|
+
_closing = new PromiseDelegate();
|
|
38
|
+
_result = {
|
|
39
|
+
button: null,
|
|
40
|
+
isChecked: null,
|
|
41
|
+
value: null
|
|
42
|
+
};
|
|
43
|
+
/**
|
|
44
|
+
* Create a dialog instance.
|
|
45
|
+
*/
|
|
46
|
+
constructor(options = {}) {
|
|
47
|
+
super();
|
|
48
|
+
this.host = options.host ?? document.body;
|
|
49
|
+
this.body = options.body ?? (() => null);
|
|
50
|
+
this.checkbox = options.checkbox ?? null;
|
|
51
|
+
this.buttons = options.buttons ?? [
|
|
52
|
+
Dialog.cancelButton(),
|
|
53
|
+
Dialog.okButton()
|
|
54
|
+
];
|
|
55
|
+
this.dialogTitle = options.title;
|
|
56
|
+
}
|
|
57
|
+
_renderBody = (props) => (_jsx(PrimerDialog.Body, { children: createElement(this.body, {
|
|
58
|
+
...props,
|
|
59
|
+
setValue: this.setValue
|
|
60
|
+
}) }));
|
|
61
|
+
_renderFooter = (props) => (_jsx(DialogFooter, { ...props, checkbox: this.checkbox, setChecked: this.setChecked }));
|
|
62
|
+
render() {
|
|
63
|
+
return (_jsx(PrimerDialog, { sx: {
|
|
64
|
+
color: 'var(--fgColor-default)',
|
|
65
|
+
backgroundColor: 'var(--bgColor-default)',
|
|
66
|
+
fontFamily: 'var(--fontStack-system)',
|
|
67
|
+
fontSize: 'var(--text-body-size-medium)',
|
|
68
|
+
lineHeight: 'var(--text-body-lineHeight-medium)',
|
|
69
|
+
}, onClose: this.close, footerButtons: this.buttons.map((but, idx) => {
|
|
70
|
+
const footerButton = {
|
|
71
|
+
buttonType: but.displayType === 'default'
|
|
72
|
+
? but.accept ? 'primary' : 'default'
|
|
73
|
+
: 'danger',
|
|
74
|
+
onClick: () => { this.handleButton(idx); },
|
|
75
|
+
content: but.label,
|
|
76
|
+
'aria-label': but.ariaLabel,
|
|
77
|
+
autoFocus: but.accept
|
|
78
|
+
};
|
|
79
|
+
return footerButton;
|
|
80
|
+
}), renderBody: this._renderBody, renderFooter: this._renderFooter, title: this.dialogTitle }));
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Launch the dialog as a modal window.
|
|
84
|
+
*
|
|
85
|
+
* @returns a promise that resolves with the result of the dialog.
|
|
86
|
+
*/
|
|
87
|
+
async launch() {
|
|
88
|
+
Widget.attach(this, this.host);
|
|
89
|
+
await this._closing.promise;
|
|
90
|
+
return this._result;
|
|
91
|
+
}
|
|
92
|
+
handleButton = (idx) => {
|
|
93
|
+
this.setButton(this.buttons[idx]);
|
|
94
|
+
this.close();
|
|
95
|
+
};
|
|
96
|
+
setButton = (button) => {
|
|
97
|
+
this._result.button = button;
|
|
98
|
+
};
|
|
99
|
+
setChecked = (c) => {
|
|
100
|
+
this._result.isChecked = c;
|
|
101
|
+
};
|
|
102
|
+
setValue = (v) => {
|
|
103
|
+
if (v instanceof Error) {
|
|
104
|
+
this._closing.reject(v);
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
this._result.value = v;
|
|
108
|
+
}
|
|
109
|
+
};
|
|
110
|
+
close = () => {
|
|
111
|
+
Widget.detach(this);
|
|
112
|
+
this._closing.resolve();
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
export default JupyterDialog;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { IMarkdownParser, IRenderMime } from '@jupyterlab/rendermime';
|
|
2
|
+
/**
|
|
3
|
+
* {@link Markdown} properties
|
|
4
|
+
*/
|
|
5
|
+
export interface IMarkdownProps {
|
|
6
|
+
/**
|
|
7
|
+
* Text to render
|
|
8
|
+
*/
|
|
9
|
+
text: string;
|
|
10
|
+
/**
|
|
11
|
+
* Markdown parser
|
|
12
|
+
*/
|
|
13
|
+
markdownParser: IMarkdownParser;
|
|
14
|
+
/**
|
|
15
|
+
* HTML sanitizer; if not provided the produced HTML
|
|
16
|
+
* will not be sanitized.
|
|
17
|
+
*/
|
|
18
|
+
sanitizer?: IRenderMime.ISanitizer;
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Rendered text as Markdown
|
|
22
|
+
*/
|
|
23
|
+
export declare function Markdown(props: IMarkdownProps): JSX.Element;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useEffect, useState } from 'react';
|
|
3
|
+
/**
|
|
4
|
+
* Rendered text as Markdown
|
|
5
|
+
*/
|
|
6
|
+
export function Markdown(props) {
|
|
7
|
+
const { markdownParser, sanitizer, text } = props;
|
|
8
|
+
const [renderedText, setRenderedText] = useState('');
|
|
9
|
+
useEffect(() => {
|
|
10
|
+
markdownParser.render(text).then(r => {
|
|
11
|
+
if (sanitizer) {
|
|
12
|
+
setRenderedText(sanitizer.sanitize(r));
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
setRenderedText(r);
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
}, [markdownParser, sanitizer, text]);
|
|
19
|
+
return _jsx("div", { dangerouslySetInnerHTML: { __html: renderedText } });
|
|
20
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { type ReactNode } from 'react';
|
|
2
|
+
export type NavLinkProps = {
|
|
3
|
+
to: string;
|
|
4
|
+
children: ReactNode;
|
|
5
|
+
};
|
|
6
|
+
/**
|
|
7
|
+
* React router Link for primer NavList
|
|
8
|
+
*/
|
|
9
|
+
export declare const NavLink: import("react").ForwardRefExoticComponent<NavLinkProps & import("react").RefAttributes<HTMLAnchorElement>>;
|