49 lines
1 KiB
React
49 lines
1 KiB
React
|
// @flow
|
||
|
import React from 'react';
|
||
|
import PublishForm from 'component/publishForm';
|
||
|
import Page from 'component/page';
|
||
|
import YrblWalletEmpty from 'component/yrblWalletEmpty';
|
||
|
import Spinner from 'component/spinner';
|
||
|
|
||
|
type Props = {
|
||
|
balance: number,
|
||
|
fetchingChannels: boolean,
|
||
|
};
|
||
|
|
||
|
function PublishPage(props: Props) {
|
||
|
const { balance, fetchingChannels } = props;
|
||
|
|
||
|
function scrollToTop() {
|
||
|
const mainContent = document.querySelector('main');
|
||
|
if (mainContent) {
|
||
|
// $FlowFixMe
|
||
|
mainContent.scrollTo({
|
||
|
top: 0,
|
||
|
behavior: 'smooth',
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return (
|
||
|
<Page
|
||
|
noFooter
|
||
|
noSideNavigation
|
||
|
backout={{
|
||
|
title: __('Upload'),
|
||
|
backLabel: __('Back'),
|
||
|
}}
|
||
|
>
|
||
|
{balance === 0 && <YrblWalletEmpty />}
|
||
|
{balance !== 0 && fetchingChannels ? (
|
||
|
<div className="main--empty">
|
||
|
<Spinner />
|
||
|
</div>
|
||
|
) : (
|
||
|
<PublishForm scrollToTop={scrollToTop} disabled={balance === 0} />
|
||
|
)}
|
||
|
</Page>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
export default PublishPage;
|