diff --git a/apps/ui/src/modals/AIChatModal/components/ChatMessageList/components/AiMessageMarkdown.tsx b/apps/ui/src/modals/AIChatModal/components/ChatMessageList/components/AiMessageMarkdown.tsx index 1892a3fd6..b9053165b 100644 --- a/apps/ui/src/modals/AIChatModal/components/ChatMessageList/components/AiMessageMarkdown.tsx +++ b/apps/ui/src/modals/AIChatModal/components/ChatMessageList/components/AiMessageMarkdown.tsx @@ -1,7 +1,7 @@ import styled, { css } from 'styled-components' import ReactMarkdown from 'react-markdown' import { Prism as SyntaxHighlighter } from 'react-syntax-highlighter' -import { atomDark } from 'react-syntax-highlighter/dist/esm/styles/prism' +import { atomDark, prism } from 'react-syntax-highlighter/dist/esm/styles/prism' import remarkGfm from 'remark-gfm' import { useModal } from 'hooks' import { memo, useEffect, useState } from 'react' @@ -133,7 +133,7 @@ const AiMessageMarkdown = ({ isReply = false, children }: { isReply?: boolean; c return !inline && match ? ( { navigate('/api-key/create-api-key')} - leftIcon={Add} - size={Button.sizes?.SMALL} + size={Button.sizes?.MEDIUM} > {t('create-api-key')} diff --git a/apps/ui/src/pages/ApiKeys/CreateApiKey/CreateApikeysForm.tsx b/apps/ui/src/pages/ApiKeys/CreateApiKey/CreateApikeysForm.tsx index fa9a7433d..3fa0934cf 100644 --- a/apps/ui/src/pages/ApiKeys/CreateApiKey/CreateApikeysForm.tsx +++ b/apps/ui/src/pages/ApiKeys/CreateApiKey/CreateApikeysForm.tsx @@ -23,16 +23,15 @@ function CreateApiKeyForm() { -
+
Add API Key - Here is your API Key.
{isLoading ? : 'Save'} diff --git a/apps/ui/src/pages/Navigation/MainNavigation.tsx b/apps/ui/src/pages/Navigation/MainNavigation.tsx index cb5c2df9b..8e31f6cca 100644 --- a/apps/ui/src/pages/Navigation/MainNavigation.tsx +++ b/apps/ui/src/pages/Navigation/MainNavigation.tsx @@ -37,6 +37,7 @@ import Integrations from 'share-ui/components/Icon/Icons/components/integrations import FineTuning from 'share-ui/components/Icon/Icons/components/FineTuning' // eslint-disable-next-line import/no-named-as-default import Cloud from 'share-ui/components/Icon/Icons/components/Cloud' +import { API } from 'share-ui/components/Icon/Icons' const MainNavigation = ({ user }: { user: any }) => { const domainEnv = import.meta.env @@ -177,22 +178,10 @@ const MainNavigation = ({ user }: { user: any }) => { )} */} - {isModel && ( - - onHandleClick('/models')} - > - - {includes(active, 'models') && } - - - )} - onHandleClick('/pods')} + onClick={() => onHandleClick('/pods/create-pod')} > {includes(active, 'pods') && } @@ -214,6 +203,27 @@ const MainNavigation = ({ user }: { user: any }) => { )} + {isModel && ( + + onHandleClick('/models')} + > + + {includes(active, 'models') && } + + + )} + + + onHandleClick('/api-key')} + > + + + + {/* {isDiscover && ( ` border-radius: 100px; background: #000; - - span{ color: #FFF; } + path { stroke: #FFF; + } `} ` @@ -410,3 +420,8 @@ const StyledCorner = styled.div` top: 8px; /* Adjust this value based on your design */ right: -16px; /* Position the left corner */ ` +const StyledAPIIcon = styled(API)` + path { + fill: ${({ theme }) => theme.body.iconColor}; + } +` diff --git a/apps/ui/src/pages/Pods/FilterPods.tsx b/apps/ui/src/pages/Pods/FilterPods.tsx index 68b54549d..99628d5ff 100644 --- a/apps/ui/src/pages/Pods/FilterPods.tsx +++ b/apps/ui/src/pages/Pods/FilterPods.tsx @@ -1,130 +1,128 @@ -import Box from '@mui/material/Box'; -import Typography from '@mui/material/Typography'; +import Box from '@mui/material/Box' +import Typography from '@mui/material/Typography' import Slider from '@mui/material/Slider' // import ButtonGroup from '@mui/material/ButtonGroup'; -import Button from '@mui/material/Button'; -import ToggleButton from '@mui/material/ToggleButton'; -import ToggleButtonGroup from '@mui/material/ToggleButtonGroup'; +import Button from '@mui/material/Button' +import ToggleButton from '@mui/material/ToggleButton' +import ToggleButtonGroup from '@mui/material/ToggleButtonGroup' // import IconButton from '@mui/material/IconButton' // import Fingerprint from '@mui/icons-material/Fingerprint' import { black, white } from './styles' const sliderMarks = [ - { value: 1, label: '1' }, - { value: 2, label: '2' }, - { value: 3, label: '3' }, - { value: 4, label: '4' }, - { value: 5, label: '5' }, - { value: 8, label: '8' }, - { value: 10, label: '10' }, + { value: 1, label: '1' }, + { value: 2, label: '2' }, + { value: 3, label: '3' }, + { value: 4, label: '4' }, + { value: 5, label: '5' }, + { value: 8, label: '8' }, + { value: 10, label: '10' }, ] - const buttonStyles = { - color: black, - textTransform: 'capitalize', - fontSize: '0.8125rem', - fontWeight: 'bold', + color: black, + textTransform: 'capitalize', + fontSize: '0.8125rem', + fontWeight: 'bold', } const FilterPods = () => { - return ( - - - {}} - aria-label="Platform" - > - - GPU - - - - CPU - - - + return ( + + + {}} + aria-label='Platform' + > + + GPU + - - - - - + + CPU + + - - + + + + + - - - - - - Filter GPUs by VRAM - - `${value}`} - valueLabelDisplay="auto" - step={1} - max={10} - min={1} - marks={sliderMarks} - sx={{ color: black }} - size='small' - /> - + - ) + + + + + Filter GPUs by VRAM + + `${value}`} + valueLabelDisplay='auto' + step={1} + max={10} + min={1} + marks={sliderMarks} + sx={{ color: black }} + size='small' + /> + + + ) } -export default FilterPods \ No newline at end of file +export default FilterPods diff --git a/apps/ui/src/pages/Pods/Pods.tsx b/apps/ui/src/pages/Pods/Pods.tsx index e243779da..3fb674d69 100644 --- a/apps/ui/src/pages/Pods/Pods.tsx +++ b/apps/ui/src/pages/Pods/Pods.tsx @@ -10,14 +10,15 @@ import { import { useNavigate, useOutlet } from 'react-router-dom' import Box from '@mui/material/Box' import Typography from '@mui/material/Typography' +import ProgressBar from './ProsgressBar' const cpu = [ - { cpu: 'base:0.5.1-cpu', ram: '46 GB', running: true }, - { cpu: 'base:0.5.1-cpu', ram: '32 GB', running: false }, - { cpu: 'base:0.5.1-cpu', ram: '16 GB', running: true }, - { cpu: 'base:0.5.1-cpu', ram: '128 GB', running: false }, - { cpu: 'base:0.5.1-cpu', ram: '46 GB', running: false }, - { cpu: 'base:0.5.1-cpu', ram: '50 GB', running: true }, + { name: 'llm2 Fine-tune', cpu: 'base:0.5.1-cpu', ram: '46 GB', running: true, mem: 0 }, + { name: 'Tain OpenAI', cpu: 'base:0.5.1-cpu', ram: '32 GB', running: false, mem: 40 }, + { name: 'Meta Llama', cpu: 'base:0.5.1-cpu', ram: '16 GB', running: true, mem: 10 }, + { name: 'NV-Embed', cpu: 'base:0.5.1-cpu', ram: '128 GB', running: false, mem: 50 }, + { name: 'Tele-AI', cpu: 'base:0.5.1-cpu', ram: '46 GB', running: false, mem: 90 }, + { name: 'Nitral-AI', cpu: 'base:0.5.1-cpu', ram: '50 GB', running: true, mem: 5 }, ] const Pods = () => { @@ -28,7 +29,7 @@ const Pods = () => { - + navigate('/pods/create-pod')} /> @@ -55,7 +56,7 @@ const Pods = () => { > - Compute + {item.name} CPU: {item.cpu} RAM: {item.ram} diff --git a/apps/ui/src/pages/Pods/PodsContent.tsx b/apps/ui/src/pages/Pods/PodsContent.tsx index 1e0d11629..df3824b40 100644 --- a/apps/ui/src/pages/Pods/PodsContent.tsx +++ b/apps/ui/src/pages/Pods/PodsContent.tsx @@ -165,9 +165,7 @@ const PodsContent = () => { justifyContent: 'start', }} > - - Select an Instance - + @@ -210,7 +208,6 @@ const StyledContainer = styled.div` flex-direction: column; gap: 27px; max-width: 80rem; - margin-left: auto; margin-right: auto; @media (min-width: 960px) { padding-left: 36px; diff --git a/apps/ui/src/pages/Pods/PodsMainCard.tsx b/apps/ui/src/pages/Pods/PodsMainCard.tsx index d2cee1c9a..85d2541a7 100644 --- a/apps/ui/src/pages/Pods/PodsMainCard.tsx +++ b/apps/ui/src/pages/Pods/PodsMainCard.tsx @@ -24,6 +24,7 @@ import TypographyMUI from '@mui/material/Typography' import { textSlicer } from 'utils/textSlicer' import LinearProgress from '@mui/material/LinearProgress' import { ButtonPrimary } from 'components/Button/Button' +import ProgressBar from './ProsgressBar' type PodsMainCardProps = { name: string @@ -92,7 +93,7 @@ const PodsMainCard = ({ type={Typography.types.P} size={Typography.sizes.xss} /> - + - + @@ -111,7 +112,7 @@ const PodsMainCard = ({ type={Typography.types.P} size={Typography.sizes.xss} /> - + - +
diff --git a/apps/ui/src/pages/Pods/ProsgressBar.tsx b/apps/ui/src/pages/Pods/ProsgressBar.tsx new file mode 100644 index 000000000..19421b3da --- /dev/null +++ b/apps/ui/src/pages/Pods/ProsgressBar.tsx @@ -0,0 +1,7 @@ +import LinearProgress from '@mui/material/LinearProgress' + +const ProgressBar = ({ value }: { value: number }) => { + return +} + +export default ProgressBar diff --git a/apps/ui/src/pages/Pods/styles.ts b/apps/ui/src/pages/Pods/styles.ts index c8dbc8edb..43f8bb337 100644 --- a/apps/ui/src/pages/Pods/styles.ts +++ b/apps/ui/src/pages/Pods/styles.ts @@ -27,7 +27,6 @@ export const borderBoxStyles = { transition: 'box-shadow 300ms cubic-bezier(0.4, 0, 0.2, 1) 0ms', borderRadius: '10px', overflow: 'hidden', - border: '1px solid rgba(34, 51, 84, 0.2)', boxShadow: 'none', background: '', padding: '18px', diff --git a/apps/ui/src/pages/Subnets/SDKs.tsx b/apps/ui/src/pages/Subnets/SDKs.tsx new file mode 100644 index 000000000..14bdf7050 --- /dev/null +++ b/apps/ui/src/pages/Subnets/SDKs.tsx @@ -0,0 +1,86 @@ +import { SDK_DATA } from './constants' +import { useState } from 'react' +import styled from 'styled-components' + +import TypographyPrimary from 'components/Typography/Primary' +import Typography from 'share-ui/components/typography/Typography' + +import { StyledForm, StyledInnerFormWrapper } from './Subnets' + +import AiMessageMarkdown from 'modals/AIChatModal/components/ChatMessageList/components/AiMessageMarkdown' + +const SDKs = () => { + const [pickedData, setPickedData] = useState(SDK_DATA[0]) + + return ( + <> + + + + + {SDK_DATA.map(data => { + return ( + setPickedData(data)} + > + + + + + ) + })} + + + + + + + + + ) +} + +export default SDKs + +const StyledCard = styled.div<{ picked: boolean }>` + width: 150px; + height: 100px; + + border-radius: 10px; + border: 1px solid #d4d4d479; + + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; + + box-shadow: ${({ picked }) => (picked ? '0px 4px 4px 0px rgba(0, 0, 0, 0.2)' : 'none')}; + + &:hover { + box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.2); + } + + cursor: pointer; +` +const StyledCardsWrapper = styled.div` + display: flex; + flex-wrap: wrap; + gap: 16px; +` +const StyledImg = styled.img` + width: 40px; + height: 40px; + object-fit: contain; +` diff --git a/apps/ui/src/pages/Subnets/Subnets.tsx b/apps/ui/src/pages/Subnets/Subnets.tsx index 683fea15a..5c56096f7 100644 --- a/apps/ui/src/pages/Subnets/Subnets.tsx +++ b/apps/ui/src/pages/Subnets/Subnets.tsx @@ -25,6 +25,8 @@ import TextField from 'share-ui/components/TextField/TextField' import TypographySecondary from 'components/Typography/Secondary' import { fontSize, fontWeight } from '@mui/system' import { ButtonPrimary } from 'components/Button/Button' +import ProgressBar from 'pages/Pods/ProsgressBar' +import SDKs from './SDKs' const Subnets = () => { const [activeSubnet, setActiveSubnet] = useState(SUBNETS[0]) @@ -132,6 +134,51 @@ const Subnets = () => { + + + + + + + + + + + + + + + + + + + + @@ -162,11 +209,20 @@ const StyledWrapper = styled.div` height: 100%; padding-right: 20px; + + display: flex; + flex-direction: column; + gap: 20px; + + overflow: auto; + + padding-bottom: 100px; ` -const StyledForm = styled.div` +export const StyledForm = styled.div` width: 100%; /* max-width: 800px; */ + max-width: 80rem; margin-top: 20px; @@ -193,7 +249,7 @@ const StyledTextWrapper = styled.div` gap: 10px; ` -const StyledTextFieldWrapper = styled.div` +export const StyledTextFieldWrapper = styled.div` width: 100%; /* max-width: 800px; */ @@ -203,7 +259,7 @@ const StyledTextFieldWrapper = styled.div` font-weight: 500; ` -const StyledInnerFormWrapper = styled.div` +export const StyledInnerFormWrapper = styled.div` display: flex; flex-direction: column; gap: 10px; diff --git a/apps/ui/src/pages/Subnets/constants.ts b/apps/ui/src/pages/Subnets/constants.ts index fdd1bb815..0e7c2c760 100644 --- a/apps/ui/src/pages/Subnets/constants.ts +++ b/apps/ui/src/pages/Subnets/constants.ts @@ -253,3 +253,131 @@ export const SUBNETS = [ ], }, ] + +export const SDK_DATA = [ + { + name: 'Node.js', + logo: '', + code: ` + const { Apideck } = require('@apideck/node') + + const apideck = new Apideck({ + apiKey: '', + appId: '', + consumerId: '' + }) + + // Declare the Unified API you want to use + const { crm } = apideck + + // Override consumerId serviceId as declared in initial configuration for this operation. + const response = await crm.contactsAll({ + // serviceId: 'salesforce', // optional + limit: 10 + }) + + `, + }, + { + name: 'PHP', + logo: '', + code: ` + ', '', ''); + $apideck = new Apideck($config); + + $response = $apideck->getCrmApi()->contactsAll(false, null, null, null, null, 1); + + ?> + + `, + }, + { + name: '.NET', + logo: '', + code: ` + using Apideck.Api; + using Apideck.Client; + using Apideck.Model; + + namespace Example + { + public class CompaniesAllExample + { + public static void Main() + { + Configuration config = new Configuration(); + // Configure API key authorization: apiKey + config.AddApiKey("Authorization", "API_KEY"); + config.AddApiKeyPrefix("Authorization", "Bearer"); + + var apiInstance = new CrmApi(config); + var raw = false; // bool? | Include raw response. Mostly used for debugging purposes (optional) (default to false) + var consumerId = "CONSUMER_ID"; // string | ID of the consumer which you want to get or push data from (optional) + var appId = "APP_ID"; // string | The ID of your Unify application (optional) + var serviceId = "salesforce"; // string | Provide the service id you want to call (e.g., pipedrive). [See the full list in the connector section.](#section/Connectors) Only needed when a consumer has activated multiple integrations for a Unified API. (optional) + + try + { + Console.WriteLine("Calling Apideck"); + // List companies + GetCompaniesResponse result = apiInstance.CompaniesAll(raw, consumerId, appId, serviceId); + Console.WriteLine("Success", result); + } + catch (ApiException e) + { + Console.WriteLine("Exception when calling CrmApi.CompaniesAll: " + e.Message); + Console.WriteLine("Status Code: " + e.ErrorCode); + Console.WriteLine("Detail: " + e.ErrorContent); + } + } + } + } + + `, + }, + { + name: 'Python', + logo: '', + code: ` + import apideck + from apideck.api import crm_api + from apideck.model.contacts_sort import ContactsSort + from apideck.model.sort_direction import SortDirection + from pprint import pprint + + configuration = apideck.Configuration() + + configuration.api_key['apiKey'] = '' + configuration.api_key_prefix['apiKey'] = 'Bearer' + + with apideck.ApiClient(configuration) as api_client: + # Create an instance of the API class + api_instance = crm_api.CrmApi(api_client) + raw = False + consumer_id = '' + app_id = '' + service_id = '' + limit = 20 + + sort = ContactsSort( + by="name", + direction=SortDirection("asc"), + ) + + + try: + # List contacts + api_response = api_instance.contacts_all(raw=raw, consumer_id=consumer_id, app_id=app_id, service_id=service_id, limit=limit, sort=sort) + pprint(api_response) + except apideck.ApiException as e: + print("Exception when calling CrmApi->contacts_all: %s + " % e) + `, + }, +] diff --git a/apps/ui/src/routes/ChatRouteLayout.tsx b/apps/ui/src/routes/ChatRouteLayout.tsx index c4f906299..dec5b80bd 100644 --- a/apps/ui/src/routes/ChatRouteLayout.tsx +++ b/apps/ui/src/routes/ChatRouteLayout.tsx @@ -418,6 +418,7 @@ export const StyledContainer = styled.div` export const StyledLeftColumn = styled.div<{ isHidden?: boolean isSmallScreen?: boolean + customWidth?: number }>` overflow-y: auto; display: flex; @@ -427,8 +428,8 @@ export const StyledLeftColumn = styled.div<{ padding-top: 0px; height: 100%; - min-width: 270px; - max-width: 270px; + min-width: ${({ customWidth }) => (customWidth ? `${customWidth}px` : '270px')}; + max-width: ${({ customWidth }) => (customWidth ? `${customWidth}px` : '270px')}; transition: margin-left 0.3s ease-in-out;