2019-05-08 16:47:39 -06:00
|
|
|
// @flow
|
|
|
|
import * as React from 'react';
|
2019-11-24 22:17:38 -07:00
|
|
|
import Villain from 'villain-react';
|
|
|
|
import 'villain-react/dist/style.css';
|
2019-05-08 16:47:39 -06:00
|
|
|
|
|
|
|
type Props = {
|
2019-11-24 22:17:38 -07:00
|
|
|
theme: string,
|
2020-04-21 00:16:39 -07:00
|
|
|
source: string,
|
2019-05-08 16:47:39 -06:00
|
|
|
};
|
|
|
|
|
2019-11-24 22:17:38 -07:00
|
|
|
let workerUrl = 'webworkers/worker-bundle.js';
|
|
|
|
|
2019-06-04 14:32:42 -04:00
|
|
|
if (process.env.NODE_ENV !== 'production') {
|
|
|
|
// Don't add a leading slash in production because electron treats it as an absolute path
|
2019-11-24 22:17:38 -07:00
|
|
|
workerUrl = `/${workerUrl}`;
|
2019-06-04 14:32:42 -04:00
|
|
|
}
|
|
|
|
|
2019-05-16 00:32:53 -06:00
|
|
|
class ComicBookViewer extends React.PureComponent<Props> {
|
2019-05-08 16:47:39 -06:00
|
|
|
render() {
|
2020-04-21 00:16:39 -07:00
|
|
|
const { source } = this.props || {};
|
2019-11-24 22:17:38 -07:00
|
|
|
// Archive source
|
2020-04-21 00:16:39 -07:00
|
|
|
const file = `file://${source}`;
|
2019-11-24 22:17:38 -07:00
|
|
|
// Villain options
|
|
|
|
const opts = {
|
|
|
|
theme: this.props.theme === 'dark' ? 'Dark' : 'Light',
|
|
|
|
allowFullScreen: true,
|
|
|
|
autoHideControls: false,
|
|
|
|
allowGlobalShortcuts: true,
|
|
|
|
};
|
2019-05-16 00:32:53 -06:00
|
|
|
|
2020-04-25 20:55:23 -05:00
|
|
|
return (
|
|
|
|
<div className="file-render__viewer file-render__viewer--comic">
|
|
|
|
<Villain source={file} className={'comic-viewer'} options={opts} workerUrl={workerUrl} />
|
|
|
|
</div>
|
|
|
|
);
|
2019-05-08 16:47:39 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ComicBookViewer;
|