2022-06-02 15:24:11 -04:00
|
|
|
// @flow
|
|
|
|
import React from 'react';
|
|
|
|
import Button from 'component/button';
|
|
|
|
import { FormField } from 'component/common/form-components/form-field';
|
|
|
|
import { Form } from 'component/common/form-components/form';
|
|
|
|
import { withRouter } from 'react-router-dom';
|
|
|
|
|
|
|
|
// $FlowFixMe cannot resolve ...
|
|
|
|
import image from 'static/img/yrblhappy.svg';
|
|
|
|
import * as DAEMON_SETTINGS from 'constants/daemon_settings';
|
|
|
|
|
|
|
|
type SetDaemonSettingArg = boolean | string | number;
|
|
|
|
|
|
|
|
type Props = {
|
|
|
|
handleNextPage: () => void,
|
|
|
|
handleDone: () => void,
|
|
|
|
setDaemonSetting: (string, ?SetDaemonSettingArg) => void,
|
|
|
|
// --- select ---
|
|
|
|
diskSpace: DiskSpace, // KB
|
|
|
|
viewHostingLimit: number, // MB
|
|
|
|
autoHostingLimit: number,
|
|
|
|
viewBlobSpace: number,
|
|
|
|
autoBlobSpace: number,
|
|
|
|
privateBlobSpace: number,
|
|
|
|
saveBlobs: boolean,
|
|
|
|
};
|
|
|
|
|
|
|
|
const TWENTY_PERCENT = 0.2;
|
|
|
|
const TEN_PRECNT = 0.1;
|
|
|
|
|
|
|
|
function HostingSplash(props: Props) {
|
|
|
|
const {
|
|
|
|
handleNextPage,
|
|
|
|
diskSpace,
|
|
|
|
viewHostingLimit,
|
|
|
|
autoHostingLimit,
|
|
|
|
viewBlobSpace,
|
|
|
|
autoBlobSpace,
|
|
|
|
saveBlobs,
|
|
|
|
setDaemonSetting,
|
|
|
|
handleDone,
|
|
|
|
} = props;
|
|
|
|
|
2022-06-05 12:10:12 -04:00
|
|
|
const totalMB = diskSpace && Math.floor(diskSpace.total / 1024);
|
|
|
|
const freeMB = diskSpace && Math.floor(diskSpace.free / 1024);
|
2022-06-02 15:24:11 -04:00
|
|
|
const blobSpaceUsed = viewBlobSpace + autoBlobSpace;
|
|
|
|
|
|
|
|
const [hostingChoice, setHostingChoice] = React.useState('MANAGED');
|
|
|
|
function handleSubmit() {
|
|
|
|
if (hostingChoice === 'CUSTOM') {
|
|
|
|
handleNextPage();
|
|
|
|
} else {
|
|
|
|
handleAuto();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function getManagedLimitMB() {
|
|
|
|
const value =
|
|
|
|
freeMB > totalMB * TWENTY_PERCENT // lots of free space?
|
|
|
|
? blobSpaceUsed > totalMB * TEN_PRECNT // using more than 10%?
|
|
|
|
? (freeMB + blobSpaceUsed) / 2 // e.g. 40g used plus 30g free, knock back to 35g limit, freeing to 35g
|
|
|
|
: totalMB * TEN_PRECNT // let it go up to 10%
|
|
|
|
: (freeMB + blobSpaceUsed) / 2; // e.g. 40g used plus 10g free, knock back to 25g limit, freeing to 25g
|
|
|
|
return value > 10240 ? Math.floor(value / 1024) * 1024 : 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
function getAutoLimit() {
|
|
|
|
// return floor of 10% of total
|
|
|
|
const totalGB = Math.floor(getManagedLimitMB() / 1024); // eg, 25GB
|
|
|
|
return Math.floor(totalGB / 10) * 1024; // eg, 2 GB -> 2048MB
|
|
|
|
}
|
|
|
|
|
|
|
|
function getViewedLimit() {
|
|
|
|
return getManagedLimitMB() - getAutoLimit();
|
|
|
|
}
|
|
|
|
|
|
|
|
function getManagedCopy() {
|
|
|
|
if (viewHostingLimit || autoHostingLimit || !saveBlobs) {
|
|
|
|
return __("I'm happy with my settings");
|
|
|
|
} else if (getManagedLimitMB() > 0) {
|
|
|
|
return __(`Host up to %percent% of my drive (%limit% GB)`, {
|
|
|
|
percent: `${Math.round((Math.floor(getManagedLimitMB() / 1024) / Math.floor(totalMB / 1024)) * 100)}%`,
|
|
|
|
limit: Math.floor(getManagedLimitMB() / 1024),
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
return __(`Not now, my disk is almost full.`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function getManagedHelper() {
|
|
|
|
if (viewHostingLimit || autoHostingLimit || !saveBlobs) {
|
|
|
|
return __(`We've noticed you already have some settings.`);
|
|
|
|
} else if (getManagedLimitMB() > 0) {
|
|
|
|
return __(`Donate space without filling up your drive.`);
|
|
|
|
} else {
|
|
|
|
return __(`You can clear some space and check hosting settings later.`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
async function handleAuto() {
|
|
|
|
if (viewHostingLimit || autoHostingLimit || !saveBlobs) {
|
|
|
|
handleDone();
|
|
|
|
} else if (getManagedLimitMB() > 0) {
|
|
|
|
// limit to used // maybe move this to a single action function that doesn't live inside the component.
|
|
|
|
await setDaemonSetting(DAEMON_SETTINGS.BLOB_STORAGE_LIMIT_MB, getViewedLimit());
|
|
|
|
await setDaemonSetting(DAEMON_SETTINGS.NETWORK_STORAGE_LIMIT_MB, getAutoLimit());
|
|
|
|
handleDone();
|
|
|
|
} else {
|
|
|
|
// running low on space
|
|
|
|
handleDone();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<section className="main--contained">
|
|
|
|
<div className={'columns first-run__wrapper'}>
|
|
|
|
<div className={'first-run__left'}>
|
|
|
|
<div>
|
|
|
|
<h1 className="section__title--large">{__('Hosting')}</h1>
|
|
|
|
<h3 className="section__subtitle">
|
|
|
|
{__('Help creators and improve the P2P data network by hosting content.')}
|
|
|
|
</h3>
|
|
|
|
<fieldset>
|
|
|
|
<FormField
|
|
|
|
name={'managedhosting'}
|
|
|
|
type="radio"
|
|
|
|
checked={hostingChoice === 'MANAGED'}
|
|
|
|
label={getManagedCopy()}
|
|
|
|
helper={getManagedHelper()}
|
|
|
|
onChange={(e) => setHostingChoice('MANAGED')}
|
|
|
|
/>
|
|
|
|
<FormField
|
|
|
|
name={'customhosting'}
|
|
|
|
type="radio"
|
|
|
|
checked={hostingChoice === 'CUSTOM'}
|
|
|
|
label={<>{__('Custom')}</>}
|
|
|
|
helper={__(`You choose how much data to host.`)}
|
|
|
|
onChange={(e) => setHostingChoice('CUSTOM')}
|
|
|
|
/>
|
|
|
|
</fieldset>
|
|
|
|
</div>
|
|
|
|
<Form onSubmit={handleSubmit} className="section__body">
|
|
|
|
<div className={'card__actions'}>
|
|
|
|
<Button button="primary" label={hostingChoice === 'CUSTOM' ? __('Next') : __(`Let's go`)} type="submit" />
|
|
|
|
</div>
|
|
|
|
</Form>
|
|
|
|
</div>
|
|
|
|
<div className={'first-run__image-wrapper'}>
|
|
|
|
<img src={image} className="privacy-img" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
export default withRouter(HostingSplash);
|