lbry-desktop/ui/component/viewers/documentViewer.jsx

114 lines
2.8 KiB
React
Raw Normal View History

// @flow
import React from 'react';
import LoadingScreen from 'component/common/loading-screen';
import MarkdownPreview from 'component/common/markdown-preview';
2019-11-07 14:39:22 -05:00
import CodeViewer from 'component/viewers/codeViewer';
import * as https from 'https';
2019-03-26 23:40:02 -05:00
type Props = {
2018-07-27 19:42:35 -06:00
theme: string,
source: {
file: (?string) => any,
stream: string,
fileType: string,
contentType: string,
},
};
type State = {
error: boolean,
loading: boolean,
content: ?string,
};
class DocumentViewer extends React.PureComponent<Props, State> {
constructor(props: Props) {
super(props);
this.state = {
error: false,
loading: true,
content: null,
};
}
componentDidMount() {
const { source } = this.props;
// @if TARGET='app'
if (source && source.file) {
const stream = source.file('utf8');
let data = '';
stream.on('data', chunk => {
data += chunk;
});
stream.on('end', () => {
this.setState({ content: data, loading: false });
});
stream.on('error', () => {
this.setState({ error: true, loading: false });
});
}
// @endif
// @if TARGET='web'
if (source && source.stream) {
https.get(
source.stream,
function(response) {
if (response.statusCode === 200) {
2019-11-27 11:53:41 -05:00
let data = '';
response.on('data', function(chunk) {
2019-11-27 11:53:41 -05:00
data += chunk;
});
response.on(
'end',
function() {
2019-11-27 11:53:41 -05:00
this.setState({ content: data, loading: false });
}.bind(this)
);
} else {
this.setState({ error: true, loading: false });
}
}.bind(this)
);
}
// @endif
}
renderDocument() {
2018-07-26 18:24:00 -06:00
let viewer = null;
const { content } = this.state;
2018-07-27 19:42:35 -06:00
const { source, theme } = this.props;
const { fileType, contentType } = source;
2018-07-26 18:24:00 -06:00
const markdownType = ['md', 'markdown'];
if (markdownType.includes(fileType) || contentType === 'text/markdown' || contentType === 'text/md') {
2018-07-26 18:24:00 -06:00
// Render markdown
2019-12-03 11:41:44 -05:00
viewer = <MarkdownPreview content={content} />;
} else {
2018-07-26 18:24:00 -06:00
// Render plain text
2019-11-07 14:39:22 -05:00
viewer = <CodeViewer value={content} contentType={contentType} theme={theme} />;
}
2018-07-26 18:24:00 -06:00
return viewer;
}
render() {
const { error, loading, content } = this.state;
const isReady = content && !error;
2018-07-27 19:54:06 -06:00
const errorMessage = __("Sorry, looks like we can't load the document.");
return (
2019-08-13 01:35:13 -04:00
<div className="file-render__viewer--document">
2020-01-06 13:32:35 -05:00
{loading && !error && <div className="placeholder--text-document" />}
{error && <LoadingScreen status={errorMessage} spinner={!error} />}
2019-11-07 14:39:22 -05:00
{isReady && this.renderDocument()}
</div>
);
}
}
export default DocumentViewer;