forked from sombochea/verdaccio-ui
87 lines
2.3 KiB
TypeScript
87 lines
2.3 KiB
TypeScript
import React from 'react';
|
|
import styled from '@emotion/styled';
|
|
import { useTranslation } from 'react-i18next';
|
|
|
|
import Avatar from '../../muiComponents/Avatar';
|
|
import Text from '../../muiComponents/Text';
|
|
import ListItem from '../../muiComponents/ListItem';
|
|
import ListItemText from '../../muiComponents/ListItemText';
|
|
import { isURL } from '../../utils/url';
|
|
import CopyToClipBoard from '../CopyToClipBoard';
|
|
import List from '../../muiComponents/List';
|
|
import { DetailContext } from '../../pages/Version';
|
|
import { Theme } from '../../design-tokens/theme';
|
|
|
|
import git from './img/git.png';
|
|
|
|
const StyledText = styled(Text)<{ theme?: Theme }>(props => ({
|
|
fontWeight: props.theme && props.theme.fontWeight.bold,
|
|
textTransform: 'capitalize',
|
|
}));
|
|
|
|
const GithubLink = styled('a')<{ theme?: Theme }>(props => ({
|
|
color: props.theme && props.theme.palette.primary.main,
|
|
}));
|
|
|
|
const RepositoryListItem = styled(ListItem)({
|
|
padding: 0,
|
|
':hover': {
|
|
backgroundColor: 'transparent',
|
|
},
|
|
});
|
|
|
|
const RepositoryListItemText = styled(ListItemText)({
|
|
padding: '0 10px',
|
|
margin: 0,
|
|
});
|
|
|
|
const RepositoryAvatar = styled(Avatar)({
|
|
borderRadius: '0px',
|
|
padding: '0',
|
|
img: {
|
|
backgroundColor: 'transparent',
|
|
},
|
|
});
|
|
|
|
const Repository: React.FC = () => {
|
|
const detailContext = React.useContext(DetailContext);
|
|
const { t } = useTranslation();
|
|
|
|
const { packageMeta } = detailContext;
|
|
|
|
if (!packageMeta?.latest?.repository?.url || !isURL(packageMeta.latest.repository.url)) {
|
|
return null;
|
|
}
|
|
|
|
const { url } = packageMeta.latest.repository;
|
|
|
|
const getCorrectRepositoryURL = (): string => {
|
|
if (!url.includes('git+')) {
|
|
return url;
|
|
}
|
|
|
|
return url.split('git+')[1];
|
|
};
|
|
|
|
const repositoryURL = getCorrectRepositoryURL();
|
|
|
|
return (
|
|
<List dense={true} subheader={<StyledText variant="subtitle1">{t('sidebar.repository.title')}</StyledText>}>
|
|
<RepositoryListItem button={true}>
|
|
<RepositoryAvatar src={git} />
|
|
<RepositoryListItemText
|
|
primary={
|
|
<CopyToClipBoard text={repositoryURL}>
|
|
<GithubLink href={repositoryURL} target="_blank">
|
|
{repositoryURL}
|
|
</GithubLink>
|
|
</CopyToClipBoard>
|
|
}
|
|
/>
|
|
</RepositoryListItem>
|
|
</List>
|
|
);
|
|
};
|
|
|
|
export default Repository;
|