lbry-desktop/ui/component/channelAbout/view.jsx

64 lines
1.7 KiB
React
Raw Normal View History

2019-05-06 22:35:04 -04:00
// @flow
import React, { Fragment } from 'react';
import MarkdownPreview from 'component/common/markdown-preview';
2020-02-14 11:52:54 -05:00
import ClaimTags from 'component/claimTags';
2019-05-06 22:35:04 -04:00
type Props = {
2020-02-14 11:52:54 -05:00
uri: string,
2019-05-06 22:35:04 -04:00
description: ?string,
email: ?string,
website: ?string,
};
const formatEmail = (email: string) => {
if (email) {
const protocolRegex = new RegExp('^mailto:', 'i');
const protocol = protocolRegex.exec(email);
return protocol ? email : `mailto:${email}`;
}
return null;
};
2019-05-06 22:35:04 -04:00
function ChannelContent(props: Props) {
2020-02-14 11:52:54 -05:00
const { uri, description, email, website } = props;
2019-05-06 22:35:04 -04:00
const showAbout = description || email || website;
return (
2020-01-03 11:36:15 -05:00
<section className="section">
2019-06-11 14:10:58 -04:00
{!showAbout && <h2 className="main--empty empty">{__('Nothing here yet')}</h2>}
2019-05-06 22:35:04 -04:00
{showAbout && (
<Fragment>
{description && (
2019-11-22 16:13:00 -05:00
<div className="media__info-text media__info-text--constrained">
2019-12-03 11:41:44 -05:00
<MarkdownPreview content={description} />
</div>
)}
2019-05-06 22:35:04 -04:00
{email && (
<Fragment>
2019-11-22 16:13:00 -05:00
<label>{__('Contact')}</label>
<div className="media__info-text">
2019-12-03 11:41:44 -05:00
<MarkdownPreview content={formatEmail(email)} />
</div>
2019-05-06 22:35:04 -04:00
</Fragment>
)}
{website && (
<Fragment>
2019-11-22 16:13:00 -05:00
<label>{__('Site')}</label>
<div className="media__info-text">
2019-12-03 11:41:44 -05:00
<MarkdownPreview content={website} />
</div>
2019-05-06 22:35:04 -04:00
</Fragment>
)}
2020-02-14 11:52:54 -05:00
<label>{__('Tags')}</label>
<div className="media__info-text">
<ClaimTags uri={uri} type="large" />
</div>
2019-05-06 22:35:04 -04:00
</Fragment>
)}
</section>
);
}
export default ChannelContent;