Skip to content

Commit

Permalink
feat: 🎸 new dashboard ui
Browse files Browse the repository at this point in the history
  • Loading branch information
OdapX committed Apr 16, 2024
1 parent 82c0915 commit 6628d43
Show file tree
Hide file tree
Showing 39 changed files with 839 additions and 1,490 deletions.
3 changes: 1 addition & 2 deletions apps/dashboard/components/AgentDeployTab.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -123,8 +123,7 @@ function AgentDeployTab(props: Props) {
disableSubmitButton
cardProps={{
sx: {
maxWidth: 'md',
mx: 'auto',
maxWidth: '100%',
},
}}
>
Expand Down
1 change: 1 addition & 0 deletions apps/dashboard/components/ChatSection.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ function ChatSection({
rootSx={{
pt: 1,
height: '100%',
minHeight: '100%',
width: '200px',
}}
currentConversationId={currentConversationId}
Expand Down
50 changes: 45 additions & 5 deletions apps/dashboard/components/ConversationExport.tsx
Original file line number Diff line number Diff line change
@@ -1,22 +1,62 @@
import DownloadForOfflineRoundedIcon from '@mui/icons-material/DownloadForOfflineRounded';
import InfoRoundedIcon from '@mui/icons-material/InfoRounded';
import { Alert, Button, Card, Stack } from '@mui/joy';
import { Button } from '@mui/joy';
import axios from 'axios';
import { saveAs } from 'file-saver';
import { useState } from 'react';
import { toast } from 'react-hot-toast';
import { z } from 'zod';

interface Props {}
import {
ConversationChannel,
ConversationPriority,
MessageEval,
} from '@chaindesk/prisma';

export function ConversationExport({}: Props) {
interface Props {
channel?: ConversationChannel;
priority?: ConversationPriority;
agentId?: string;
assigneeId?: string;
messageEval?: MessageEval;
}

export function ConversationExport({
channel,
priority,
messageEval,
agentId,
assigneeId,
}: Props) {
const [isLoading, setIsLoading] = useState(false);
const exportConversations = async () => {
try {
const { success: validChannel } = z
.nativeEnum(ConversationChannel)
.safeParse(channel);
const { success: validEval } = z
.nativeEnum(MessageEval)
.safeParse(messageEval);
const { success: validPriority } = z
.nativeEnum(MessageEval)
.safeParse(priority);

const { success: validAgentId } = z.string().min(3).safeParse(agentId);
const { success: validAssigneeId } = z
.string()
.min(3)
.safeParse(assigneeId);

setIsLoading(true);
const { data } = await toast.promise(
axios.post(
'/api/conversations/export',
{},
{
...(validChannel ? { channel } : {}),
...(validPriority ? { priority } : {}),
...(validAgentId ? { agentId } : {}),
...(validAssigneeId ? { assigneeId } : {}),
...(validEval ? { messageEval } : {}),
},
{
responseType: 'blob',
}
Expand Down
41 changes: 22 additions & 19 deletions apps/dashboard/components/ConversationList.tsx
Original file line number Diff line number Diff line change
@@ -1,8 +1,5 @@
import AddCircleOutlineRoundedIcon from '@mui/icons-material/AddCircleOutlineRounded';
import AddRoundedIcon from '@mui/icons-material/AddRounded';
import Button from '@mui/joy/Button';
import Chip from '@mui/joy/Chip';
import Divider from '@mui/joy/Divider';
import List from '@mui/joy/List';
import ListDivider from '@mui/joy/ListDivider';
import ListItem from '@mui/joy/ListItem';
Expand All @@ -13,7 +10,7 @@ import Stack from '@mui/joy/Stack';
import { SxProps } from '@mui/joy/styles/types';
import Typography from '@mui/joy/Typography';
import { useRouter } from 'next/router';
import React, { useEffect, useRef } from 'react';
import React, { useEffect, useMemo, useRef } from 'react';
import InfiniteScroll from 'react-infinite-scroller';
import useSWR, { useSWRConfig } from 'swr';
import useSWRInfinite from 'swr/infinite';
Expand Down Expand Up @@ -65,8 +62,6 @@ const Item = (props: {
</Typography>
</ListItemButton>
</ListItem>

{/* <ListDivider /> */}
</React.Fragment>
);
};
Expand All @@ -80,6 +75,7 @@ function ConversationList({
}: Props) {
const scrollParentRef = useRef(null);
const router = useRouter();

const [state, setState] = useStateReducer({
hasMore: true,
hasLoadedOnce: false,
Expand All @@ -106,7 +102,7 @@ function ConversationList({
},
fetcher,
{
refreshInterval: 5000,
refreshInterval: router?.query?.conversationId ? 5000 : 500,
onSuccess: (data) => {
const id = data?.[0]?.[0]?.id;

Expand All @@ -117,19 +113,25 @@ function ConversationList({
}
);

const conversations = getConversationsQuery?.data?.flat?.() || [];
const conversations = useMemo(
() => getConversationsQuery?.data?.flat?.() || [],
[getConversationsQuery?.data]
);

const conversationsLength = useMemo(
() => conversations.length,
[conversations]
);

useEffect(() => {
const conversationId = (router.query.conversationId ||
conversations[0]?.id) as string;
if (router.query?.conversationId) {
handleSelectConversation?.(router.query.conversationId as string);
handleSelectConversation?.(conversationId);
} else {
handleSelectConversation?.(conversations[0]?.id);
handleSelectConversation?.(conversationId);
}
}, [getConversationsQuery?.data]);

if (!getConversationsQuery.isLoading && conversations.length === 0) {
return null;
}
}, [conversationsLength]);

return (
<Stack
Expand All @@ -139,7 +141,6 @@ function ConversationList({
borderColor: theme.palette.divider,
...(rootSx as any),
})}
// gap={1}
>
<Button
size="sm"
Expand All @@ -151,7 +152,7 @@ function ConversationList({
>
New Chat
</Button>
{/* <Divider /> */}

<List
slotProps={{
root: {
Expand Down Expand Up @@ -189,12 +190,14 @@ function ConversationList({
<ListItem>
<Skeleton variant="text" />
</ListItem>

{/* <ListDivider /> */}
</React.Fragment>
)) as any
}
>
{!router.query.conversationId && (
<Item id={'optimistic-id'} text={'new Chat'} selected={true} />
)}

{conversations?.map((each) => (
<Item
key={each.id}
Expand Down
16 changes: 1 addition & 15 deletions apps/dashboard/components/DatasourceForms/Base.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,6 @@ const DatasourceText = (props: {

return (
<Textarea
// maxRows={21}
minRows={4}
disabled={props.disabled}
{...methods.register('datasourceText')}
Expand Down Expand Up @@ -177,13 +176,6 @@ export default function BaseForm(props: Props) {
}
}

// const check = await axios.post('/api/datasources/check', payload);

// if (!check?.data?.valid) {
// alert(check?.data?.message);
// return;
// }

const datasource = await upsertDatasourceMutation.trigger(payload as any);

props?.onSubmitSuccess?.(datasource!);
Expand Down Expand Up @@ -234,13 +226,7 @@ export default function BaseForm(props: Props) {

{props.children}

<details>
<summary>Advanced Settings</summary>

<Stack sx={{ pl: 2, pt: 2 }}>
<DatasourceTagsInput />
</Stack>
</details>
<DatasourceTagsInput />

{!props.hideText && defaultValues?.datastoreId && defaultValues?.id && (
<details>
Expand Down
3 changes: 2 additions & 1 deletion apps/dashboard/components/DatastoreSettings.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -371,7 +371,8 @@ function DatastoreSettings() {
<Box
sx={(theme) => ({
maxWidth: '100%',
width: theme.breakpoints.values.md,
width: '100%',
px: 4,
mx: 'auto',
})}
>
Expand Down
2 changes: 1 addition & 1 deletion apps/dashboard/components/FormInstallTab.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ function FormInstallTab({ formId }: Props) {
`;

return (
<Card sx={{ maxWidth: 'md', mx: 'auto' }}>
<Card sx={{ mx: 'auto' }}>
<AccordionGroup size="lg">
<Accordion defaultExpanded>
<AccordionSummary>Web Component</AccordionSummary>
Expand Down
5 changes: 1 addition & 4 deletions apps/dashboard/components/FormSettingsTab.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -28,16 +28,13 @@ function FormSettingsTab({ formId }: Props) {
}

return (
<Stack sx={{ width: '100%', maxWidth: 'md', mx: 'auto', gap: 2 }}>
<Stack sx={{ width: '100%', mx: 'auto', gap: 2 }}>
<SettingCard
title="General Settings"
// description="Deploy your agent with the following widgets or integrations"
disableSubmitButton
cardProps={{
sx: {
width: '100%',
// maxWidth: 'md',
// mx: 'auto',
},
}}
>
Expand Down
6 changes: 5 additions & 1 deletion apps/dashboard/components/Layout/Header.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import { Box, BoxProps } from '@mui/joy';

export const HEADER_HEIGHT = 50;

export default function Header(props: BoxProps) {
return (
<Box
Expand All @@ -18,7 +20,9 @@ export default function Header(props: BoxProps) {
gridColumn: '1 / -1',
borderBottom: '1px solid',
borderColor: 'divider',
position: 'sticky',
position: 'relative',
height: HEADER_HEIGHT,
maxHeight: HEADER_HEIGHT,
top: 0,
zIndex: 1100,
},
Expand Down
Loading

0 comments on commit 6628d43

Please sign in to comment.