Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: jetbrain modal #5253

Merged
merged 79 commits into from
Jan 20, 2025
Merged
Show file tree
Hide file tree
Changes from 44 commits
Commits
Show all changes
79 commits
Select commit Hold shift + click to select a range
7a506a3
feat: basic style and logic of modal
mlhiter Nov 29, 2024
cdab0f1
style: blue style
mlhiter Nov 29, 2024
5253b1e
fix: hydro bug
mlhiter Nov 29, 2024
c50588a
style: copy hover style
mlhiter Nov 29, 2024
b218461
fix: copy error bug
mlhiter Nov 29, 2024
5b81255
fix: workdir bug
mlhiter Nov 29, 2024
1d5ef5f
style: space adjust
mlhiter Nov 29, 2024
eed0826
fix: download sshkey file bug
mlhiter Nov 29, 2024
8b63bed
feat: cover css
mlhiter Nov 29, 2024
6385e12
feat: dymatic inject info to image and text
mlhiter Dec 2, 2024
726f1cc
chore: text bug
mlhiter Dec 2, 2024
f7b7072
fix: gateway url bug
mlhiter Dec 2, 2024
6a6c107
fix: text i18n perf
mlhiter Dec 2, 2024
0d19341
chore: text adjust
mlhiter Dec 3, 2024
3ef6be7
chore: icon adjust to upperRight
mlhiter Dec 3, 2024
cac8b3e
feat: add close button
mlhiter Dec 3, 2024
b5b9ab7
fix: ts lint bug
mlhiter Dec 11, 2024
10371a3
feat: jetbrain modal basic style
mlhiter Dec 11, 2024
fdf44f8
feat: basic style
mlhiter Dec 12, 2024
0fa6f24
feat: tab and code
mlhiter Dec 12, 2024
ab314fc
feat: script feat
mlhiter Dec 12, 2024
b2d385d
fix: modal scroll bug
mlhiter Dec 12, 2024
7abea0e
fix: style bug
mlhiter Dec 12, 2024
53dea53
feat: copy code
mlhiter Dec 12, 2024
a375974
feat: download function
mlhiter Dec 12, 2024
fd7729a
feat: connect style
mlhiter Dec 12, 2024
8217149
feat: detail sshconfig
mlhiter Dec 12, 2024
cbae1e8
feat: basic execCommand logic
mlhiter Dec 12, 2024
bdb3bb3
feat: basic connection logic
mlhiter Dec 17, 2024
bb370d7
fix: 无法解决,遂退一步
mlhiter Dec 17, 2024
c330992
fix: connect error
mlhiter Dec 18, 2024
0167aa7
fix: macos script bug
mlhiter Dec 18, 2024
79300b3
fix: windows script test and fix
mlhiter Dec 18, 2024
778c46d
feat: default system
mlhiter Dec 20, 2024
eff6651
fix: powershell text bug
mlhiter Dec 20, 2024
eb057f6
fix: show h bug
mlhiter Dec 20, 2024
b086bcb
style: some transition
mlhiter Dec 20, 2024
7c8978e
fix: macos script bug
mlhiter Dec 20, 2024
9366ec7
fix: windows script re-test and fix
mlhiter Dec 20, 2024
da76b56
feat: verify connection
mlhiter Dec 20, 2024
80d19b8
fix: webpack build error
mlhiter Dec 20, 2024
1120c36
fix: webpack build error return
mlhiter Dec 20, 2024
f410456
feat: check connection
mlhiter Dec 20, 2024
d2e0589
style: arrow style perf
mlhiter Dec 20, 2024
139ae46
Merge branch 'main' into feature/jetbrain-modal
mlhiter Dec 27, 2024
8a914a3
fix: basic type bug
mlhiter Dec 27, 2024
356ccbf
fix: runtimeType and runtimeVersion bug
mlhiter Dec 30, 2024
6e18e43
style: idebutton style adjust
mlhiter Jan 2, 2025
20655e9
chore: build error
mlhiter Jan 3, 2025
9920c7b
fix: 妥协之举
mlhiter Jan 3, 2025
a877df5
fix: some style adjust and text adjust
mlhiter Jan 9, 2025
fa8f40f
feat: config confirm
mlhiter Jan 9, 2025
f67324e
chore: remove more action
mlhiter Jan 9, 2025
10eae68
fix: online code
mlhiter Jan 10, 2025
549e9b6
feat: tabs style
mlhiter Jan 10, 2025
2e54d3b
fix: detail sshConnection bug
mlhiter Jan 13, 2025
40d2b1f
style: modal style fix
mlhiter Jan 13, 2025
84cc497
Merge branch 'main' into feature/jetbrain-modal
mlhiter Jan 13, 2025
e77c8ef
fix: style adjust
mlhiter Jan 13, 2025
58f80d4
Merge branch 'main' into feature/jetbrain-modal
mlhiter Jan 13, 2025
fca6629
fix: build bug
mlhiter Jan 13, 2025
2f69ac3
fix: test deal bug
mlhiter Jan 13, 2025
4c2ee5e
chore: prettier manual
mlhiter Jan 13, 2025
ecf01d6
style: another adjust
mlhiter Jan 13, 2025
63b1ad0
style: style minH perf
mlhiter Jan 13, 2025
1ca7f62
fix: again connect bug
mlhiter Jan 14, 2025
29708b2
style: hit box to right
mlhiter Jan 14, 2025
2a89a78
feat: check bin script
mlhiter Jan 15, 2025
c3a3a30
fix: hard code to soft code
mlhiter Jan 15, 2025
27587f9
Revert "chore: prettier manual"
mlhiter Jan 15, 2025
ae0164f
chore: remove unused png
mlhiter Jan 15, 2025
25793df
fix: ide basePath select
mlhiter Jan 15, 2025
d50b5d9
chore: i18n adjust
mlhiter Jan 15, 2025
49b7323
style: style perf
mlhiter Jan 15, 2025
cdd0418
style: another perf
mlhiter Jan 15, 2025
3507131
fix: i18n
mlhiter Jan 15, 2025
c9d766d
fix: style
mlhiter Jan 15, 2025
1b4683c
fix: style and some i18n
mlhiter Jan 15, 2025
48c1173
fix: bug
mlhiter Jan 15, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 15 additions & 0 deletions frontend/providers/devbox/api/devbox.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import {
import { GET, POST, DELETE } from '@/services/request'
import { KBDevboxType, KBDevboxReleaseType } from '@/types/k8s'
import { MonitorDataResult, MonitorQueryKey } from '@/types/monitor'
import { AxiosProgressEvent } from 'axios'

export const getMyDevboxList = () =>
GET<KBDevboxType[]>('/api/getDevboxList').then((data): DevboxListItemType[] =>
Expand Down Expand Up @@ -88,3 +89,17 @@ export const getAppsByDevboxId = (devboxId: string) =>
GET<V1Deployment & V1StatefulSet[]>('/api/getAppsByDevboxId', { devboxId }).then((res) =>
res.map(adaptAppListItem)
)

export const execCommandInDevboxPod = (data: {
devboxName: string
command: string
idePath: string
onDownloadProgress: (progressEvent: AxiosProgressEvent) => void
signal: AbortSignal
}) =>
POST('/api/execCommandInDevboxPod', data, {
// responseType: 'stream',
timeout: 0,
onDownloadProgress: data.onDownloadProgress,
signal: data.signal
})
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ import MyIcon from '@/components/Icon'
import IDEButton from '@/components/IDEButton'
import PodLineChart from '@/components/PodLineChart'
import DevboxStatusTag from '@/components/DevboxStatusTag'
import ReleaseModal from '@/components/modals/releaseModal'
import ReleaseModal from '@/components/modals/ReleaseModal'

const DelModal = dynamic(() => import('@/components/modals/DelModal'))

Expand Down Expand Up @@ -217,6 +217,7 @@ const DevboxList = ({
<Flex>
<IDEButton
devboxName={item.name}
runtimeType={item.runtimeType}
runtimeVersion={item.runtimeVersion}
sshPort={item.sshPort}
status={item.status}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,13 @@ import { useTranslations } from 'next-intl'
import { useSearchParams } from 'next/navigation'
import { Box, Center, Flex, Grid, useTheme } from '@chakra-ui/react'

import { useRouter } from '@/i18n'
import Code from '@/components/Code'
import MyIcon from '@/components/Icon'

import { useRouter } from '@/i18n'
import { obj2Query } from '@/utils/tools'
import type { YamlItemType } from '@/types'
import { useCopyData } from '@/utils/tools'
import YamlCode from '@/components/YamlCode/index'

import styles from './index.module.scss'

Expand Down Expand Up @@ -111,7 +112,7 @@ const Yaml = ({ yamlList = [], pxVal }: { yamlList: YamlItemType[]; pxVal: numbe
</Center>
</Flex>
<Box flex={1} h={0} overflow={'auto'} bg={'#ffffff'} p={4}>
<YamlCode className={styles.code} content={yamlList[selectedIndex].value} />
<Code className={styles.code} content={yamlList[selectedIndex].value} language="yaml" />
</Box>
</Flex>
)}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,16 @@
import { useMessage } from '@sealos/ui'
import { useTranslations } from 'next-intl'
import React, { useCallback, useState } from 'react'
import { Box, Text, Flex, Image, Spinner, Tooltip } from '@chakra-ui/react'
import { Box, Text, Flex, Image, Spinner, Tooltip, Button } from '@chakra-ui/react'

import MyIcon from '@/components/Icon'

import { DevboxDetailType } from '@/types/devbox'

import SshConnectModal from '@/components/modals/SshConnectModal'
import { useEnvStore } from '@/stores/env'
import { useDevboxStore } from '@/stores/devbox'
import { useRuntimeStore } from '@/stores/runtime'
import { downLoadBlob } from '@/utils/tools'
import { getSSHConnectionInfo, getSSHRuntimeInfo } from '@/api/devbox'
import { JetBrainsGuideData } from '@/components/IDEButton'

const BasicInfo = () => {
const t = useTranslations()
Expand All @@ -20,6 +21,40 @@ const BasicInfo = () => {
const { getRuntimeDetailLabel } = useRuntimeStore()

const [loading, setLoading] = useState(false)
const [onOpenSsHConnect, setOnOpenSsHConnect] = useState(false)
const [sshConfigData, setSshConfigData] = useState<JetBrainsGuideData | null>(null)

const handleOneClickConfig = useCallback(async () => {
const { base64PrivateKey, userName, token } = await getSSHConnectionInfo({
devboxName: devboxDetail?.name,
runtimeName: devboxDetail?.runtimeVersion
})
const { workingDir } = await getSSHRuntimeInfo(devboxDetail?.runtimeVersion)
const sshPrivateKey = Buffer.from(base64PrivateKey, 'base64').toString('utf-8')

if (!devboxDetail?.sshPort) return

setSshConfigData({
devboxName: devboxDetail?.name,
runtimeType: devboxDetail?.runtimeType,
privateKey: sshPrivateKey,
userName,
token,
workingDir,
host: env.sealosDomain,
port: devboxDetail?.sshPort.toString(),
configHost: `${env.sealosDomain}_${env.namespace}_${devboxDetail?.name}`
})

setOnOpenSsHConnect(true)
}, [
devboxDetail?.name,
devboxDetail?.runtimeType,
devboxDetail?.runtimeVersion,
devboxDetail?.sshPort,
env.namespace,
env.sealosDomain
])

const handleCopySSHCommand = useCallback(() => {
const sshCommand = `ssh -i yourPrivateKeyPath ${devboxDetail?.sshConfig?.sshUser}@${env.sealosDomain} -p ${devboxDetail.sshPort}`
Expand All @@ -33,28 +68,6 @@ const BasicInfo = () => {
})
}, [devboxDetail?.sshConfig?.sshUser, devboxDetail.sshPort, env.sealosDomain, toast, t])

const handleDownloadConfig = useCallback(
async (config: DevboxDetailType['sshConfig']) => {
setLoading(true)

const privateKey = config?.sshPrivateKey as string

const blob = new Blob([privateKey], { type: 'application/octet-stream' })
const url = window.URL.createObjectURL(blob)
const a = document.createElement('a')
a.style.display = 'none'
a.href = url
a.download = devboxDetail.name
document.body.appendChild(a)
a.click()
window.URL.revokeObjectURL(url)
document.body.removeChild(a)

setLoading(false)
},
[devboxDetail]
)

return (
<Flex borderRadius="lg" bg={'white'} p={4} flexDirection={'column'} h={'100%'}>
{/* basic info */}
Expand Down Expand Up @@ -134,19 +147,34 @@ const BasicInfo = () => {
</Flex>
</Flex>
{/* ssh config */}
<Flex mb={3} mt={4}>
<MyIcon
name="link"
w={'15px'}
h={'15px'}
mr={'4px'}
<Flex mb={3} mt={4} alignItems={'center'} justify={'space-between'}>
<Flex>
<MyIcon
name="link"
w={'15px'}
h={'15px'}
mr={'4px'}
color={'grayModern.600'}
mt={'1px'}
ml={'1px'}
/>
<Box color={'grayModern.600'} fontSize={'base'} fontWeight={'bold'}>
{t('ssh_config')}
</Box>
</Flex>
<Button
size={'sm'}
leftIcon={<MyIcon name="settings" w={'16px'} />}
bg={'white'}
color={'grayModern.600'}
mt={'1px'}
ml={'1px'}
/>
<Box color={'grayModern.600'} fontSize={'base'} fontWeight={'bold'}>
{t('ssh_config')}
</Box>
border={'1px solid'}
borderColor={'grayModern.200'}
_hover={{
color: 'brightBlue.600'
}}
onClick={() => handleOneClickConfig()}>
{t('one_click_config')}
</Button>
</Flex>
<Flex bg={'grayModern.50'} p={4} borderRadius={'lg'} gap={4} flexDirection={'column'}>
<Flex>
Expand Down Expand Up @@ -202,9 +230,16 @@ const BasicInfo = () => {
<MyIcon
cursor={'pointer'}
name="download"
color={'grayModern.600'}
w={'16px'}
h={'16px'}
onClick={() => handleDownloadConfig(devboxDetail?.sshConfig)}
onClick={() =>
downLoadBlob(
devboxDetail?.sshConfig?.sshPrivateKey as string,
'application/octet-stream',
`${devboxDetail?.name}`
)
}
/>
</Flex>
</Tooltip>
Expand Down Expand Up @@ -273,6 +308,17 @@ const BasicInfo = () => {
</Flex>
</Flex>
</Flex>
{onOpenSsHConnect && sshConfigData && (
<SshConnectModal
jetbrainsGuideData={sshConfigData}
onSuccess={() => {
setOnOpenSsHConnect(false)
}}
onClose={() => {
setOnOpenSsHConnect(false)
}}
/>
)}
</Flex>
)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -160,6 +160,7 @@ const Header = ({
<Flex gap={5}>
<Box>
<IDEButton
runtimeType={devboxDetail.runtimeType}
devboxName={devboxDetail.name}
runtimeVersion={devboxDetail.runtimeVersion}
sshPort={devboxDetail.sshPort as number}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import { Box, Button, Flex, MenuButton, Text, useDisclosure } from '@chakra-ui/r
import MyIcon from '@/components/Icon'
import MyTable from '@/components/MyTable'
import DevboxStatusTag from '@/components/DevboxStatusTag'
import ReleaseModal from '@/components/modals/releaseModal'
import ReleaseModal from '@/components/modals/ReleaseModal'
import EditVersionDesModal from '@/components/modals/EditVersionDesModal'

import { DevboxVersionListItemType } from '@/types/devbox'
Expand Down
2 changes: 1 addition & 1 deletion frontend/providers/devbox/app/[lang]/(platform)/layout.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ export default function PlatformLayout({ children }: { children: React.ReactNode
})
} catch (error) {
changeI18n({
currentLanguage: 'zh'
currentLanguage: 'en'
})
}
})()
Expand Down
Loading
Loading