generated from layer5io/layer5-repo-template
-
Notifications
You must be signed in to change notification settings - Fork 113
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #872 from amitamrutiya/custom-formatters
Create custom formatters and the resource data extract hooks for the resource detail view
- Loading branch information
Showing
15 changed files
with
2,486 additions
and
3 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
import { ChartOptions, bb } from 'billboard.js'; | ||
import { memo, useEffect, useRef } from 'react'; | ||
|
||
interface BBChartProps { | ||
options: ChartOptions; | ||
} | ||
|
||
const BBChart = ({ options }: BBChartProps) => { | ||
const _chartRef = useRef<HTMLDivElement | null>(null); | ||
|
||
useEffect(() => { | ||
if (!_chartRef.current) return; | ||
|
||
const chart = bb.generate({ | ||
bindto: _chartRef.current, | ||
...options | ||
}); | ||
|
||
return () => { | ||
chart.destroy(); | ||
}; | ||
}, [options]); | ||
|
||
return <div ref={_chartRef} onClickCapture={(e) => e.stopPropagation()} />; | ||
}; | ||
|
||
export default memo(BBChart); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
import BBChart from './BBChart'; | ||
|
||
export { BBChart }; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,168 @@ | ||
import React from 'react'; | ||
import { Grid, IconButton, Typography } from '../../base'; | ||
import { iconSmall } from '../../constants/iconsSizes'; | ||
import { CopyIcon } from '../../icons'; | ||
import { useTheme } from '../../theme'; | ||
import { CustomTooltip } from './../CustomTooltip'; | ||
import { NumberState } from './Formatter'; | ||
import { | ||
Details, | ||
ElementDataWrap, | ||
Heading, | ||
KeyValueGrid, | ||
KeyValueGridCell, | ||
KeyValueGridTitle, | ||
LongWrap, | ||
StyledNumberBox, | ||
Title, | ||
VariableSubfield, | ||
Wrap | ||
} from './styles'; | ||
import { | ||
ActionIconButtonProps, | ||
CategoryProps, | ||
CopyToClipboardProps, | ||
EnvironmentVariablesProps, | ||
KeyValueProps, | ||
LongDetailsProps, | ||
NumberStateFormatterProps, | ||
PrimaryDetailsProps, | ||
SectionHeadingProps | ||
} from './types'; | ||
import { splitCamelCaseString } from './utils.js'; | ||
|
||
export const PrimaryDetails: React.FC<PrimaryDetailsProps> = ({ title, value, hide = false }) => { | ||
const titleFormatted = splitCamelCaseString(title); | ||
const show = hide === false ? hide : true; | ||
|
||
if (!value || value === ` `) { | ||
return null; | ||
} | ||
|
||
if (show) { | ||
return ( | ||
<Details noPadding={true}> | ||
<Wrap> | ||
<Typography variant="body1">{titleFormatted}: </Typography> | ||
<ElementDataWrap>{value}</ElementDataWrap> | ||
</Wrap> | ||
</Details> | ||
); | ||
} | ||
return null; | ||
}; | ||
|
||
export const CopyToClipboard: React.FC<CopyToClipboardProps> = ({ data }) => { | ||
const theme = useTheme(); | ||
const copyToClipboard = () => { | ||
navigator.clipboard.writeText(data); | ||
}; | ||
|
||
return ( | ||
<span | ||
style={{ | ||
display: 'flex', | ||
alignItems: 'center', | ||
cursor: 'pointer' | ||
}} | ||
> | ||
<IconButton onClickCapture={copyToClipboard} style={{ paddingBlock: '4px' }}> | ||
<CopyIcon height={20} width={20} fill={theme.palette.icon.secondary} /> | ||
</IconButton> | ||
</span> | ||
); | ||
}; | ||
|
||
export const SectionHeading: React.FC<SectionHeadingProps> = ({ children }) => { | ||
return <Typography variant="body1">{children + ':'}</Typography>; | ||
}; | ||
|
||
export const LongDetails: React.FC<LongDetailsProps> = ({ title, value }) => { | ||
const titleFormatted = splitCamelCaseString(title); | ||
|
||
if (!value || value === ` `) { | ||
return null; | ||
} | ||
|
||
return ( | ||
<Details noPadding={true}> | ||
<LongWrap> | ||
<SectionHeading>{titleFormatted}</SectionHeading> | ||
{/* <CodeFormatter data={value} /> */} | ||
</LongWrap> | ||
</Details> | ||
); | ||
}; | ||
|
||
export const EnvironmentVariables: React.FC<EnvironmentVariablesProps> = ({ title, value }) => { | ||
return ( | ||
<Details noPadding> | ||
<LongWrap> | ||
<VariableSubfield> | ||
{title}:{value} | ||
</VariableSubfield> | ||
</LongWrap> | ||
</Details> | ||
); | ||
}; | ||
|
||
export const Category: React.FC<CategoryProps> = ({ title, hide = false }) => { | ||
const show = hide === false ? hide : true; | ||
|
||
if (show) { | ||
return ( | ||
<Heading> | ||
<Title>{title}</Title> | ||
</Heading> | ||
); | ||
} | ||
return null; | ||
}; | ||
|
||
export const NumberStateFormatter: React.FC<NumberStateFormatterProps> = ({ data }) => { | ||
if (!data) { | ||
return null; | ||
} | ||
|
||
return ( | ||
<StyledNumberBox> | ||
{data.map((item) => ( | ||
<NumberState | ||
key={item.title} | ||
title={item.title} | ||
value={item.value} | ||
quantity={item.quantity} | ||
/> | ||
))} | ||
</StyledNumberBox> | ||
); | ||
}; | ||
|
||
export const ActionIconButton: React.FC<ActionIconButtonProps> = ({ title, Icon, onClick }) => { | ||
const theme = useTheme(); | ||
return ( | ||
<CustomTooltip title={title}> | ||
<div> | ||
<IconButton size="small" onClickCapture={onClick}> | ||
<Icon {...iconSmall} fill={theme.palette.icon.default} /> | ||
</IconButton> | ||
</div> | ||
</CustomTooltip> | ||
); | ||
}; | ||
|
||
export const KeyValueInRow: React.FC<KeyValueProps> = ({ Key, Value }) => { | ||
if (!Value || !Key) return null; | ||
return ( | ||
<KeyValueGrid container> | ||
<React.Fragment key={Key}> | ||
<KeyValueGridCell item xs={3}> | ||
<KeyValueGridTitle>{Key}</KeyValueGridTitle> | ||
</KeyValueGridCell> | ||
<Grid item xs={9}> | ||
<div>{React.isValidElement(Value) ? Value : String(Value)}</div> | ||
</Grid> | ||
</React.Fragment> | ||
</KeyValueGrid> | ||
); | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
/* eslint-disable @typescript-eslint/no-explicit-any */ | ||
import { OperatorDataContainer } from './styles'; | ||
import { isEmptyAtAllDepths } from './utils'; | ||
|
||
interface OperatorDataFormatterProps { | ||
data: any; | ||
FormatStructuredData: any; | ||
propertyFormatter: any; | ||
} | ||
|
||
export const OperatorDataFormatter = ({ | ||
data, | ||
FormatStructuredData, | ||
propertyFormatter | ||
}: OperatorDataFormatterProps) => { | ||
if (!data || isEmptyAtAllDepths(data)) { | ||
return null; | ||
} | ||
|
||
return ( | ||
<OperatorDataContainer> | ||
<FormatStructuredData data={data} propertyFormatters={propertyFormatter} isLevel={false} /> | ||
</OperatorDataContainer> | ||
); | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
import ExpandLessIcon from '@mui/icons-material/ExpandLess'; | ||
import ExpandMoreIcon from '@mui/icons-material/ExpandMore'; | ||
import { iconMedium } from '../../constants/iconsSizes'; | ||
import { useTheme } from '../../theme'; | ||
|
||
interface ExpandArrowProps { | ||
expanded: boolean; | ||
} | ||
|
||
const ExpandArrow: React.FC<ExpandArrowProps> = ({ expanded }) => { | ||
const theme = useTheme(); | ||
return expanded ? ( | ||
<ExpandLessIcon fill={theme.palette.icon.default} {...iconMedium} /> | ||
) : ( | ||
<ExpandMoreIcon fill={theme.palette.icon.default} {...iconMedium} /> | ||
); | ||
}; | ||
|
||
export default ExpandArrow; |
Oops, something went wrong.