2019-12-07 23:58:37 +00:00
|
|
|
import React from 'react';
|
|
|
|
import TitledGreyBox from '@/components/elements/TitledGreyBox';
|
|
|
|
import { ServerContext } from '@/state/server';
|
|
|
|
import { useStoreState } from 'easy-peasy';
|
2019-12-10 06:03:10 +00:00
|
|
|
import RenameServerBox from '@/components/server/settings/RenameServerBox';
|
2020-03-28 23:47:32 +00:00
|
|
|
import FlashMessageRender from '@/components/FlashMessageRender';
|
2020-03-30 06:05:30 +01:00
|
|
|
import Can from '@/components/elements/Can';
|
2020-04-03 22:43:24 +01:00
|
|
|
import ReinstallServerBox from '@/components/server/settings/ReinstallServerBox';
|
2020-07-04 23:58:14 +01:00
|
|
|
import tw from 'twin.macro';
|
|
|
|
import Input from '@/components/elements/Input';
|
|
|
|
import Label from '@/components/elements/Label';
|
2020-07-05 02:46:09 +01:00
|
|
|
import { LinkButton } from '@/components/elements/Button';
|
2020-08-26 05:39:00 +01:00
|
|
|
import ServerContentBlock from '@/components/elements/ServerContentBlock';
|
2019-12-07 23:58:37 +00:00
|
|
|
|
|
|
|
export default () => {
|
2020-08-26 05:39:00 +01:00
|
|
|
const username = useStoreState(state => state.user.data!.username);
|
|
|
|
const id = ServerContext.useStoreState(state => state.server.data!.id);
|
|
|
|
const sftpIp = ServerContext.useStoreState(state => state.server.data!.sftpDetails.ip);
|
|
|
|
const sftpPort = ServerContext.useStoreState(state => state.server.data!.sftpDetails.port);
|
2019-12-07 23:58:37 +00:00
|
|
|
|
|
|
|
return (
|
2020-08-26 05:39:00 +01:00
|
|
|
<ServerContentBlock title={'Settings'}>
|
2020-07-04 23:58:14 +01:00
|
|
|
<FlashMessageRender byKey={'settings'} css={tw`mb-4`}/>
|
|
|
|
<div css={tw`md:flex`}>
|
2020-07-09 05:42:37 +01:00
|
|
|
<div css={tw`w-full md:flex-1 md:mr-10`}>
|
|
|
|
<Can action={'file.sftp'}>
|
|
|
|
<TitledGreyBox title={'SFTP Details'} css={tw`mb-6 md:mb-10`}>
|
2020-04-03 22:43:24 +01:00
|
|
|
<div>
|
2020-07-04 23:58:14 +01:00
|
|
|
<Label>Server Address</Label>
|
|
|
|
<Input
|
2020-04-03 22:43:24 +01:00
|
|
|
type={'text'}
|
2020-08-26 05:39:00 +01:00
|
|
|
value={`sftp://${sftpIp}:${sftpPort}`}
|
2020-07-04 23:58:14 +01:00
|
|
|
readOnly
|
2020-04-03 22:43:24 +01:00
|
|
|
/>
|
2020-03-30 06:05:30 +01:00
|
|
|
</div>
|
2020-07-04 23:58:14 +01:00
|
|
|
<div css={tw`mt-6`}>
|
|
|
|
<Label>Username</Label>
|
|
|
|
<Input
|
2020-04-03 22:43:24 +01:00
|
|
|
type={'text'}
|
2020-08-26 05:39:00 +01:00
|
|
|
value={`${username}.${id}`}
|
2020-07-04 23:58:14 +01:00
|
|
|
readOnly
|
2020-04-03 22:43:24 +01:00
|
|
|
/>
|
2020-03-30 06:05:30 +01:00
|
|
|
</div>
|
2020-07-04 23:58:14 +01:00
|
|
|
<div css={tw`mt-6 flex items-center`}>
|
|
|
|
<div css={tw`flex-1`}>
|
|
|
|
<div css={tw`border-l-4 border-cyan-500 p-3`}>
|
|
|
|
<p css={tw`text-xs text-neutral-200`}>
|
2020-04-03 22:43:24 +01:00
|
|
|
Your SFTP password is the same as the password you use to access this panel.
|
|
|
|
</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
2020-07-04 23:58:14 +01:00
|
|
|
<div css={tw`ml-4`}>
|
|
|
|
<LinkButton
|
|
|
|
isSecondary
|
2020-08-26 05:39:00 +01:00
|
|
|
href={`sftp://${username}.${id}@${sftpIp}:${sftpPort}`}
|
2020-04-03 22:43:24 +01:00
|
|
|
>
|
|
|
|
Launch SFTP
|
2020-07-04 23:58:14 +01:00
|
|
|
</LinkButton>
|
2020-04-03 22:43:24 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</TitledGreyBox>
|
2020-07-09 05:42:37 +01:00
|
|
|
</Can>
|
2020-07-10 03:56:46 +01:00
|
|
|
</div>
|
|
|
|
<div css={tw`w-full mt-6 md:flex-1 md:mt-0`}>
|
2020-04-03 22:43:24 +01:00
|
|
|
<Can action={'settings.rename'}>
|
2020-07-04 23:58:14 +01:00
|
|
|
<div css={tw`mb-6 md:mb-10`}>
|
2020-04-03 22:43:24 +01:00
|
|
|
<RenameServerBox/>
|
|
|
|
</div>
|
|
|
|
</Can>
|
|
|
|
<Can action={'settings.reinstall'}>
|
|
|
|
<ReinstallServerBox/>
|
|
|
|
</Can>
|
|
|
|
</div>
|
2019-12-10 06:03:10 +00:00
|
|
|
</div>
|
2020-08-26 05:39:00 +01:00
|
|
|
</ServerContentBlock>
|
2019-12-07 23:58:37 +00:00
|
|
|
);
|
|
|
|
};
|