mirror of
https://github.com/getredash/redash.git
synced 2025-12-25 01:03:20 -05:00
80 lines
2.1 KiB
JavaScript
80 lines
2.1 KiB
JavaScript
import React from 'react';
|
|
import PropTypes from 'prop-types';
|
|
|
|
// PreviewCard
|
|
|
|
export function PreviewCard({ imageUrl, title, body, children, className, ...props }) {
|
|
return (
|
|
<div {...props} className={className + ' w-100 d-flex align-items-center'}>
|
|
<img src={imageUrl} width="32" height="32" className="profile__image--settings m-r-5" alt="Logo/Avatar" />
|
|
<div className="flex-fill">
|
|
<div>{title}</div>
|
|
{body && <div className="text-muted">{body}</div>}
|
|
</div>
|
|
{children}
|
|
</div>
|
|
);
|
|
}
|
|
|
|
PreviewCard.propTypes = {
|
|
imageUrl: PropTypes.string.isRequired,
|
|
title: PropTypes.node.isRequired,
|
|
body: PropTypes.node,
|
|
className: PropTypes.string,
|
|
children: PropTypes.node,
|
|
};
|
|
|
|
PreviewCard.defaultProps = {
|
|
body: null,
|
|
className: '',
|
|
children: null,
|
|
};
|
|
|
|
// UserPreviewCard
|
|
|
|
export function UserPreviewCard({ user, withLink, children, ...props }) {
|
|
const title = withLink ? <a href={'users/' + user.id}>{user.name}</a> : user.name;
|
|
return (
|
|
<PreviewCard {...props} imageUrl={user.profile_image_url} title={title} body={user.email}>
|
|
{children}
|
|
</PreviewCard>
|
|
);
|
|
}
|
|
|
|
UserPreviewCard.propTypes = {
|
|
user: PropTypes.shape({
|
|
profile_image_url: PropTypes.string.isRequired,
|
|
name: PropTypes.string.isRequired,
|
|
email: PropTypes.string.isRequired,
|
|
}).isRequired,
|
|
withLink: PropTypes.bool,
|
|
children: PropTypes.node,
|
|
};
|
|
|
|
UserPreviewCard.defaultProps = {
|
|
withLink: false,
|
|
children: null,
|
|
};
|
|
|
|
// DataSourcePreviewCard
|
|
|
|
export function DataSourcePreviewCard({ dataSource, withLink, children, ...props }) {
|
|
const imageUrl = `/static/images/db-logos/${dataSource.type}.png`;
|
|
const title = withLink ? <a href={'data_sources/' + dataSource.id}>{dataSource.name}</a> : dataSource.name;
|
|
return <PreviewCard {...props} imageUrl={imageUrl} title={title}>{children}</PreviewCard>;
|
|
}
|
|
|
|
DataSourcePreviewCard.propTypes = {
|
|
dataSource: PropTypes.shape({
|
|
name: PropTypes.string.isRequired,
|
|
type: PropTypes.string.isRequired,
|
|
}).isRequired,
|
|
withLink: PropTypes.bool,
|
|
children: PropTypes.node,
|
|
};
|
|
|
|
DataSourcePreviewCard.defaultProps = {
|
|
withLink: false,
|
|
children: null,
|
|
};
|