From 4b1de563f78498a79c83d91048efc5be15b7089a Mon Sep 17 00:00:00 2001 From: Jaanus Sellin Date: Thu, 5 Sep 2024 10:35:43 +0300 Subject: [PATCH] feat: add sdk example box (#8092) ![image](https://github.com/user-attachments/assets/472dcbb2-d981-4d7c-8bbf-b97a6ee4c186) --- .../src/component/onboarding/SelectSdk.tsx | 4 +- .../ProjectOnboarding/ProjectOnboarding.tsx | 10 +-- .../ProjectOnboarding/SdkExample.tsx | 73 +++++++++++++++++++ .../ProjectOnboarding/WelcomeToProject.tsx | 1 + 4 files changed, 78 insertions(+), 10 deletions(-) create mode 100644 frontend/src/component/project/Project/PaginatedProjectFeatureToggles/ProjectOnboarding/SdkExample.tsx diff --git a/frontend/src/component/onboarding/SelectSdk.tsx b/frontend/src/component/onboarding/SelectSdk.tsx index dbb2b1e2d1..52a6d467db 100644 --- a/frontend/src/component/onboarding/SelectSdk.tsx +++ b/frontend/src/component/onboarding/SelectSdk.tsx @@ -67,7 +67,7 @@ const StyledAvatar = styled(Avatar)(({ theme }) => ({ boxShadow: theme.shadows[2], })); -const serverSdks: { name: ServerSdkName; icon: string }[] = [ +export const serverSdks: { name: ServerSdkName; icon: string }[] = [ { name: 'Node', icon: node }, { name: 'Golang', icon: go }, { name: 'Ruby', icon: ruby }, @@ -78,7 +78,7 @@ const serverSdks: { name: ServerSdkName; icon: string }[] = [ { name: 'Python', icon: python }, ]; -const clientSdks: { name: ClientSdkName; icon: string }[] = [ +export const clientSdks: { name: ClientSdkName; icon: string }[] = [ { name: 'Javascript', icon: javascript }, { name: 'React', icon: react }, { name: 'Vue', icon: vue }, diff --git a/frontend/src/component/project/Project/PaginatedProjectFeatureToggles/ProjectOnboarding/ProjectOnboarding.tsx b/frontend/src/component/project/Project/PaginatedProjectFeatureToggles/ProjectOnboarding/ProjectOnboarding.tsx index c46a1f9fdb..d00324eedf 100644 --- a/frontend/src/component/project/Project/PaginatedProjectFeatureToggles/ProjectOnboarding/ProjectOnboarding.tsx +++ b/frontend/src/component/project/Project/PaginatedProjectFeatureToggles/ProjectOnboarding/ProjectOnboarding.tsx @@ -1,5 +1,6 @@ import { styled } from '@mui/material'; import { WelcomeToProject } from './WelcomeToProject'; +import { SdkExample } from './SdkExample'; interface IProjectOnboardingProps { projectId: string; @@ -12,13 +13,6 @@ const Container = styled('div')(({ theme }) => ({ gap: theme.spacing(2), })); -const SdkExample = styled('div')(({ theme }) => ({ - flexBasis: '30%', - padding: theme.spacing(2), - backgroundColor: theme.palette.background.paper, - borderRadius: theme.shape.borderRadiusLarge, -})); - export const ProjectOnboarding = ({ projectId, setConnectSdkOpen, @@ -29,7 +23,7 @@ export const ProjectOnboarding = ({ projectId={projectId} setConnectSdkOpen={setConnectSdkOpen} /> - View SDK example + ); }; diff --git a/frontend/src/component/project/Project/PaginatedProjectFeatureToggles/ProjectOnboarding/SdkExample.tsx b/frontend/src/component/project/Project/PaginatedProjectFeatureToggles/ProjectOnboarding/SdkExample.tsx new file mode 100644 index 0000000000..e7d41de738 --- /dev/null +++ b/frontend/src/component/project/Project/PaginatedProjectFeatureToggles/ProjectOnboarding/SdkExample.tsx @@ -0,0 +1,73 @@ +import { type SelectChangeEvent, styled, Typography } from '@mui/material'; +import { Link } from 'react-router-dom'; +import Select from 'component/common/select'; +import { useState } from 'react'; +import { clientSdks, serverSdks } from '../../../../onboarding/SelectSdk'; + +const Container = styled('div')(({ theme }) => ({ + display: 'flex', + flexDirection: 'column', + backgroundColor: theme.palette.background.paper, + flexBasis: '30%', + borderRadius: theme.shape.borderRadiusLarge, +})); + +const TitleBox = styled('div')(({ theme }) => ({ + padding: theme.spacing(2, 7, 2, 7), + borderBottom: '1px solid', + borderColor: theme.palette.divider, + minHeight: '80px', + alignItems: 'center', + display: 'flex', +})); + +const ContentBox = styled('div')(({ theme }) => ({ + padding: theme.spacing(3, 2, 6, 8), + display: 'flex', + gap: theme.spacing(3), + flexDirection: 'column', +})); + +const StyledLink = styled(Link)({ + fontWeight: 'bold', + textDecoration: 'none', +}); + +export const SdkExample = () => { + const allSdks = [...serverSdks, ...clientSdks]; + + const sdkOptions = allSdks.map((sdk) => ({ + key: sdk.name, + label: sdk.name, + })); + + const [selectedSdk, setSelectedSdk] = useState(sdkOptions[0].key); + + const onChange = (event: SelectChangeEvent) => { + setSelectedSdk(event.target.value); + }; + return ( + + + View SDK Example + + + + + See an example implementation of your preferred SDK. + +