fix: ui style

This commit is contained in:
amhsirak
2025-08-25 19:37:49 +05:30
parent af8ddaf337
commit b134bd1c29

View File

@@ -1,14 +1,15 @@
import React from 'react'; import React from 'react';
import { import {
Box, Box,
Typography, Typography,
Button, Button,
IconButton, IconButton,
Divider, Divider,
useTheme useTheme
} from '@mui/material'; } from '@mui/material';
import { ArrowBack } from '@mui/icons-material'; import { ArrowBack } from '@mui/icons-material';
import { useNavigate, useLocation } from 'react-router-dom'; import { useNavigate, useLocation } from 'react-router-dom';
import { useTranslation } from 'react-i18next';
interface RobotConfigPageProps { interface RobotConfigPageProps {
title: string; title: string;
@@ -23,6 +24,7 @@ interface RobotConfigPageProps {
icon?: React.ReactNode; icon?: React.ReactNode;
onBackToSelection?: () => void; onBackToSelection?: () => void;
backToSelectionText?: string; backToSelectionText?: string;
onArrowBack?: () => void; // Optional prop for custom back action
} }
export const RobotConfigPage: React.FC<RobotConfigPageProps> = ({ export const RobotConfigPage: React.FC<RobotConfigPageProps> = ({
@@ -30,50 +32,72 @@ export const RobotConfigPage: React.FC<RobotConfigPageProps> = ({
children, children,
onSave, onSave,
onCancel, onCancel,
saveButtonText = "Save", saveButtonText,
cancelButtonText = "Cancel", cancelButtonText,
showSaveButton = true, showSaveButton = true,
showCancelButton = true, showCancelButton = true,
isLoading = false, isLoading = false,
icon, icon,
onBackToSelection, onBackToSelection,
backToSelectionText = "← Back" backToSelectionText,
onArrowBack,
}) => { }) => {
const navigate = useNavigate();
const location = useLocation();
const theme = useTheme(); const theme = useTheme();
const { t } = useTranslation();
const handleBack = () => { const handleBack = () => {
if (onCancel) { if (onCancel) {
onCancel(); onCancel();
} else {
// Try to determine the correct path based on current URL
const currentPath = location.pathname;
const basePath = currentPath.includes('/prebuilt-robots') ? '/prebuilt-robots' : '/robots';
navigate(basePath);
} }
}; };
return ( return (
<Box sx={{ <Box sx={{
maxWidth: 1000, maxWidth: 1000,
margin: 'auto', margin: '50px auto',
px: 4, maxHeight: '100vh',
py: 3,
minHeight: '80vh',
display: 'flex', display: 'flex',
flexDirection: 'column', flexDirection: 'column',
width: '1000px', width: '1000px',
height: '100%',
overflowY: 'auto', // Allow scrolling if content exceeds height
}}> }}>
<Box sx={{ {/* Header Section - Fixed Position */}
display: 'flex', <Box sx={{
alignItems: 'center', display: 'flex',
minHeight: '64px', alignItems: 'center',
maxHeight: '64px',
mb: 2, mb: 2,
flexShrink: 0 flexShrink: 0
}}> }}>
<IconButton <IconButton
onClick={handleBack} onClick={onArrowBack ? onArrowBack : handleBack}
sx={{ sx={{
mr: 2, ml: -1,
mr: 1,
color: theme.palette.text.primary, color: theme.palette.text.primary,
backgroundColor: 'transparent !important',
'&:hover': { '&:hover': {
bgcolor: theme.palette.action.hover backgroundColor: 'transparent !important',
} },
'&:active': {
backgroundColor: 'transparent !important',
},
'&:focus': {
backgroundColor: 'transparent !important',
},
'&:focus-visible': {
backgroundColor: 'transparent !important',
},
}} }}
disableRipple
> >
<ArrowBack /> <ArrowBack />
</IconButton> </IconButton>
@@ -82,9 +106,9 @@ export const RobotConfigPage: React.FC<RobotConfigPageProps> = ({
{icon} {icon}
</Box> </Box>
)} )}
<Typography <Typography
variant="h4" variant="h4"
sx={{ sx={{
fontWeight: 600, fontWeight: 600,
color: theme.palette.text.primary, color: theme.palette.text.primary,
lineHeight: 1.2 lineHeight: 1.2
@@ -95,29 +119,32 @@ export const RobotConfigPage: React.FC<RobotConfigPageProps> = ({
</Box> </Box>
<Divider sx={{ mb: 4, flexShrink: 0 }} /> <Divider sx={{ mb: 4, flexShrink: 0 }} />
<Box sx={{ {/* Content Section */}
<Box sx={{
flex: 1, flex: 1,
display: 'flex', display: 'flex',
flexDirection: 'column', flexDirection: 'column',
minHeight: 0 minHeight: 0,
mt: 2,
mb: 3,
}}> }}>
{children} {children}
</Box> </Box>
{/* Action Buttons */}
{(showSaveButton || showCancelButton || onBackToSelection) && ( {(showSaveButton || showCancelButton || onBackToSelection) && (
<Box <Box
sx={{ sx={{
display: 'flex', display: 'flex',
justifyContent: onBackToSelection ? 'space-between' : 'flex-end', justifyContent: onBackToSelection ? 'space-between' : 'flex-start',
gap: 2, gap: 2,
pt: 3, pt: 3, // Reduce padding top to minimize space above
mt: 2,
borderTop: `1px solid ${theme.palette.divider}`, borderTop: `1px solid ${theme.palette.divider}`,
flexShrink: 0, flexShrink: 0,
width: '100%', width: '100%',
px: 3
}} }}
> >
{/* Left side - Back to Selection button */}
{onBackToSelection && ( {onBackToSelection && (
<Button <Button
variant="outlined" variant="outlined"
@@ -128,44 +155,45 @@ export const RobotConfigPage: React.FC<RobotConfigPageProps> = ({
borderColor: '#ff00c3 !important', borderColor: '#ff00c3 !important',
backgroundColor: 'white !important', backgroundColor: 'white !important',
}} > }} >
{backToSelectionText} {backToSelectionText || t("buttons.back_arrow")}
</Button> </Button>
)} )}
{/* Right side - Save/Cancel buttons */}
<Box sx={{ display: 'flex', gap: 2 }}> <Box sx={{ display: 'flex', gap: 2 }}>
{showCancelButton && ( {showCancelButton && (
<Button <Button
variant="outlined" variant="outlined"
onClick={handleBack} onClick={handleBack}
disabled={isLoading} disabled={isLoading}
sx={{ sx={{
color: '#ff00c3 !important', color: '#ff00c3 !important',
borderColor: '#ff00c3 !important', borderColor: '#ff00c3 !important',
backgroundColor: 'white !important', backgroundColor: 'white !important',
}} > }} >
{cancelButtonText} {cancelButtonText || t("buttons.cancel")}
</Button> </Button>
)} )}
{showSaveButton && onSave && ( {showSaveButton && onSave && (
<Button <Button
variant="contained" variant="contained"
onClick={onSave} onClick={onSave}
disabled={isLoading} disabled={isLoading}
sx={{ sx={{
bgcolor: '#ff00c3', bgcolor: '#ff00c3',
'&:hover': { '&:hover': {
bgcolor: '#cc0099', bgcolor: '#cc0099',
boxShadow: 'none',
},
textTransform: 'none',
fontWeight: 500,
px: 3,
boxShadow: 'none', boxShadow: 'none',
}, }}
textTransform: 'none', >
fontWeight: 500, {isLoading ? t("buttons.saving") : (saveButtonText || t("buttons.save"))}
px: 3, </Button>
boxShadow: 'none', )}
}}
>
{isLoading ? 'Saving...' : saveButtonText}
</Button>
)}
</Box> </Box>
</Box> </Box>
)} )}