Skip to content

Commit

Permalink
Merge branch 'layer5io:master' into 496-meshery-ui-app
Browse files Browse the repository at this point in the history
  • Loading branch information
nebula-aac authored Dec 13, 2024
2 parents 16ab086 + 12bded0 commit 3a1ce3f
Show file tree
Hide file tree
Showing 9 changed files with 154 additions and 10 deletions.
5 changes: 5 additions & 0 deletions src/constants/iconsSizes.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,10 @@
// icon styles, setting general height and width properties to solves scaling and consistency problems

export const iconXSmall = {
height: 16,
width: 16
};

export const iconSmall = {
height: 20,
width: 20
Expand Down
6 changes: 3 additions & 3 deletions src/custom/CatalogDetail/ActionButton.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -76,15 +76,15 @@ const ActionButtons: React.FC<ActionButtonsProps> = ({
backgroundColor: 'transparent',
border: `1px solid ${theme.palette.border.normal}`,
gap: '10px',
color: charcoal[10]
color: theme.palette.text.default
}}
onClick={() =>
cleanedType === RESOURCE_TYPES.FILTERS
? downloadFilter(details.id, details.name)
: downloadYaml(details.pattern_file, details.name)
}
>
<Download width={24} height={24} fill={charcoal[10]} />
<Download width={24} height={24} fill={theme.palette.icon.default} />
Download
</ActionButton>

Expand All @@ -104,7 +104,7 @@ const ActionButtons: React.FC<ActionButtonsProps> = ({
<CircularProgress size={24} color={'inherit'} />
) : (
<>
<CopyIcon width={24} height={24} fill={charcoal[10]} />
<CopyIcon width={24} height={24} fill={theme.palette.icon.default} />
Clone
</>
)}
Expand Down
5 changes: 2 additions & 3 deletions src/custom/CustomTooltip/customTooltip.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ function CustomTooltip({
fontSize,
fontWeight = 400,
variant = 'standard',
bgColor = '#333333',
bgColor = '#141414',
...props
}: CustomTooltipProps): JSX.Element {
return (
Expand All @@ -35,8 +35,7 @@ function CustomTooltip({
fontWeight: { fontWeight },
borderRadius: '0.5rem',
padding: variant === 'standard' ? '0.9rem' : '0.5rem 0.75rem',
boxShadow:
'rgba(50, 50, 93, 0.25) 0px 2px 5px -1px, rgba(0, 0, 0, 0.3) 0px 1px 3px -1px'
boxShadow: 'rgba(0, 0, 0, 0.6) 0px 4px 10px, rgba(0, 0, 0, 0.5) 0px 2px 4px'
}
},
popper: {
Expand Down
2 changes: 2 additions & 0 deletions src/custom/UserSearchField/UserSearchField.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -136,6 +136,8 @@ const UserShareSearch: React.FC<UserSearchFieldProps> = ({
<Autocomplete
id="user-search-field"
sx={{ width: 'auto' }}
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
filterOptions={(x) => x}
options={options}
disableClearable
Expand Down
3 changes: 2 additions & 1 deletion src/custom/UserSearchField/index.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
import UserShareSearch from './UserSearchField';
import UserSearchField from './UserSearchFieldInput';

export { UserSearchField };
export { UserSearchField, UserShareSearch };
3 changes: 0 additions & 3 deletions src/custom/UserSearchField/index.tsx

This file was deleted.

135 changes: 135 additions & 0 deletions src/custom/VisibilityChipMenu/VisibilityChipMenu.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,135 @@
import ArrowDropDownIcon from '@mui/icons-material/ArrowDropDown';
import { Theme } from '@mui/material';
import { MouseEvent, useState } from 'react';
import { Button, Menu, MenuItem } from '../../base';
import { iconXSmall } from '../../constants/iconsSizes';
import { ALICE_BLUE, CHINESE_SILVER, NOT_FOUND, styled } from '../../theme';

interface VisibilityChipMenuProps {
value: string;
onChange: (value: string) => void;
options: [string, React.ElementType][];
enabled: boolean;
}

const StyledMenu = styled(Menu)(({ theme }) => ({
'& .MuiPaper-root': {
backgroundColor:
theme.palette.mode === 'light' ? ALICE_BLUE : theme.palette.background.constant?.table,
color: theme.palette.text.secondary,
border: `1px solid ${theme.palette.border.default}`,
borderRadius: '0.25rem',
padding: '0rem'
},
'& .MuiMenuItem-root': {
fontSize: '.9rem',
padding: '0.5rem',
'&:hover': {
backgroundColor: theme.palette.mode === 'light' ? CHINESE_SILVER : 'rgba(0, 179, 159, 0.25)'
}
},
//selected
'& .Mui-selected': {
backgroundColor: theme.palette.mode === 'light' ? CHINESE_SILVER : 'rgba(0, 179, 159, 0.25)'
},
'& .MuiList-padding': {
padding: '0px'
}
}));

const StyledButton = styled(Button)(() => ({
padding: '0px',
width: '100%'
}));

const StyledDiv = styled('div')(({ theme, enabled }: { theme?: Theme; enabled: boolean }) => ({
paddingLeft: '0.3rem',
height: '1.5rem',
paddingRight: enabled ? '0' : '0.3rem',
borderRadius: '0.25rem',
border: `1px solid ${NOT_FOUND}`,
background:
theme?.palette.mode === 'light' ? ALICE_BLUE : theme?.palette.background.constant?.table,

textTransform: 'uppercase',
color: theme?.palette.text.default,
display: 'flex',
justifyContent: 'center',
alignItems: 'center',
width: '3.8rem',
fontSize: '0.75rem',
fontFamily: theme?.typography.fontFamily
}));

const StyledMenuItem = styled(MenuItem)(({ theme }) => ({
textTransform: 'capitalize',
color: theme.palette.icon.default
}));

const StyledIcon = styled('div')({
marginRight: '0.5rem'
});

const VisibilityChipMenu: React.FC<VisibilityChipMenuProps> = ({
value,
onChange,
options,
enabled
}) => {
const [anchorEl, setAnchorEl] = useState<null | HTMLElement>(null);
const open = Boolean(anchorEl);
const close = (e: MouseEvent) => {
e.stopPropagation();
setAnchorEl(null);
};
const handleOpen = (e: MouseEvent<HTMLElement>) => {
e.stopPropagation();
if (!enabled) return;
setAnchorEl(e.currentTarget);
};
const handleChange = (e: MouseEvent, value: string) => {
e.stopPropagation();
onChange(value);
close(e);
};
return (
<>
<StyledButton
disabled={!enabled}
onClick={handleOpen}
data-testid={`design-visibility-${value.toLowerCase()}`}
>
<StyledDiv enabled={enabled}>
<span style={{ fontSize: '0.7rem' }}>{value}</span>
{enabled && <ArrowDropDownIcon style={{ ...iconXSmall }} />}
</StyledDiv>
</StyledButton>

<StyledMenu
open={open}
onClose={close}
anchorEl={anchorEl}
anchorReference="anchorPosition"
anchorPosition={{
top: (anchorEl?.getBoundingClientRect().bottom ?? 0) + 5,
left: (anchorEl?.getBoundingClientRect().left ?? 0) + 5
}}
>
{options.map(([visibility, Icon], index) => (
<StyledMenuItem
key={index}
data-testid={`visibility-toggle-${visibility.toLowerCase()}`}
onClick={(e) => handleChange(e, visibility)}
>
<StyledIcon>
<Icon width={16} height={16} />
</StyledIcon>
{visibility}
</StyledMenuItem>
))}
</StyledMenu>
</>
);
};

export default VisibilityChipMenu;
3 changes: 3 additions & 0 deletions src/custom/VisibilityChipMenu/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import VisibilityChipMenu from './VisibilityChipMenu';

export { VisibilityChipMenu };
2 changes: 2 additions & 0 deletions src/custom/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ import { TransferList } from './TransferModal/TransferList';
import { TransferListProps } from './TransferModal/TransferList/TransferList';
import UniversalFilter, { UniversalFilterProps } from './UniversalFilter';
import { UsersTable } from './UsersTable';
import { VisibilityChipMenu } from './VisibilityChipMenu';
export { CatalogCard } from './CatalogCard';
export { CatalogFilterSidebar } from './CatalogFilterSection';
export type { FilterListType } from './CatalogFilterSection';
Expand Down Expand Up @@ -100,6 +101,7 @@ export {
TransferList,
UniversalFilter,
UsersTable,
VisibilityChipMenu,
updateVisibleColumns,
useNotificationHandler,
useWindowDimensions,
Expand Down

0 comments on commit 3a1ce3f

Please sign in to comment.