mirror of
https://github.com/owncast/owncast.git
synced 2024-11-23 05:14:20 +03:00
d1f3fffe2f
* refactor: move/rename BanUserButton file * refactor: move/rename Chart file * refactor: update generic component filenames to PascalCase * refactor: update config component filenames to PascalCase * refactor: update AdminLayout component filename to PascalCase * refactor: update/move VideoJS component * chore(eslint): disable bad react/require-default-props rule * refactor: normalize ActionButton component * refactor: normalize ActionButtonRow component * refactor: normalize FollowButton component * refactor: normalize NotifyButton component * refactor: normalize ChatActionMessage component * refactor: normalize ChatContainer component * refactor: normalize ChatJoinMessage component * refactor: normalize ChatModerationActionMenu component * refactor: normalize ChatModerationDetailsModal component * refactor: normalize ChatModeratorNotification component * refactor: normalize ChatSocialMessage component * refactor: normalize ChatSystemMessage component * refactor: normalize ChatTextField component * refactor: normalize ChatUserBadge component * refactor: normalize ChatUserMessage component * refactor: normalize ContentHeader component * refactor: normalize OwncastLogo component * refactor: normalize UserDropdown component * chore(eslint): modify react/function-component-definition rule * refactor: normalize CodecSelector component * refactor: update a bunch of functional components using eslint * refactor: update a bunch of functional components using eslint, pt2 * refactor: update a bunch of functional components using eslint, pt3 * refactor: replace all component->component default imports with named imports * refactor: replace all component-stories->component default imports with named imports * refactor: remove default exports from most components * chore(eslint): add eslint config files for the components and pages dirs * fix: use-before-define error in ChatContainer * Fix ChatContainer import * Only process .tsx files in Next builds Co-authored-by: Gabe Kangas <gabek@real-ity.com>
70 lines
1.5 KiB
TypeScript
70 lines
1.5 KiB
TypeScript
import { FC } from 'react';
|
|
|
|
export type ImageAssetProps = {
|
|
name: string;
|
|
src: string;
|
|
};
|
|
|
|
export const ImageAsset: FC<ImageAssetProps> = ({ name, src }) => {
|
|
const containerStyle = {
|
|
borderRadius: '20px',
|
|
width: '12vw',
|
|
height: '12vw',
|
|
minWidth: '100px',
|
|
minHeight: '100px',
|
|
borderWidth: '1.5px',
|
|
borderStyle: 'solid',
|
|
borderColor: 'lightgray',
|
|
overflow: 'hidden',
|
|
margin: '0.3vw',
|
|
};
|
|
|
|
const colorDescriptionStyle = {
|
|
textAlign: 'center' as 'center',
|
|
color: 'gray',
|
|
fontSize: '0.8em',
|
|
};
|
|
|
|
const imageStyle = {
|
|
width: '100%',
|
|
height: '80%',
|
|
backgroundRepeat: 'no-repeat',
|
|
backgroundSize: 'contain',
|
|
backgroundPosition: 'center',
|
|
marginTop: '5px',
|
|
backgroundImage: `url(${src})`,
|
|
};
|
|
|
|
return (
|
|
<figure style={containerStyle}>
|
|
<a href={src} target="_blank" rel="noopener noreferrer">
|
|
<div style={imageStyle} />
|
|
<figcaption style={colorDescriptionStyle}>{name}</figcaption>
|
|
</a>
|
|
</figure>
|
|
);
|
|
};
|
|
|
|
const rowStyle = {
|
|
display: 'flex',
|
|
flexDirection: 'row' as 'row',
|
|
flexWrap: 'wrap' as 'wrap',
|
|
// justifyContent: 'space-around',
|
|
alignItems: 'center',
|
|
};
|
|
|
|
export const ImageRow = (props: ImageRowProps) => {
|
|
const { images } = props;
|
|
|
|
return (
|
|
<div style={rowStyle}>
|
|
{images.map(image => (
|
|
<ImageAsset key={image.src} src={image.src} name={image.name} />
|
|
))}
|
|
</div>
|
|
);
|
|
};
|
|
|
|
interface ImageRowProps {
|
|
images: ImageAssetProps[];
|
|
}
|