2021-01-31 23:40:39 -08:00
|
|
|
import { Typography, Switch, Button, Collapse } from 'antd';
|
|
|
|
import classNames from 'classnames';
|
2021-01-31 19:45:26 -08:00
|
|
|
import React, { useContext, useState, useEffect } from 'react';
|
2021-01-31 23:40:39 -08:00
|
|
|
import { UpdateArgs } from '../types/config-section';
|
2020-11-13 04:43:27 -08:00
|
|
|
import { ServerStatusContext } from '../utils/server-status-context';
|
2021-01-31 19:45:26 -08:00
|
|
|
import {
|
|
|
|
postConfigUpdateToAPI,
|
|
|
|
API_S3_INFO,
|
2021-01-31 23:40:39 -08:00
|
|
|
RESET_TIMEOUT,
|
|
|
|
S3_TEXT_FIELDS_INFO,
|
2021-01-31 19:45:26 -08:00
|
|
|
} from './components/config/constants';
|
2021-01-31 23:40:39 -08:00
|
|
|
import {
|
|
|
|
createInputStatus,
|
|
|
|
StatusState,
|
|
|
|
STATUS_ERROR,
|
|
|
|
STATUS_PROCESSING,
|
|
|
|
STATUS_SUCCESS,
|
|
|
|
} from '../utils/input-statuses';
|
|
|
|
import TextField from './components/config/form-textfield';
|
|
|
|
import InputStatusInfo from './components/config/input-status-info';
|
2021-01-31 19:45:26 -08:00
|
|
|
|
2021-01-31 23:40:39 -08:00
|
|
|
const { Title } = Typography;
|
|
|
|
const { Panel } = Collapse;
|
|
|
|
|
|
|
|
// we could probably add more detailed checks here
|
|
|
|
// `currentValues` is what's currently in the global store and in the db
|
|
|
|
function checkSaveable(formValues: any, currentValues: any) {
|
|
|
|
const { endpoint, accessKey, secret, bucket, region, enabled, servingEndpoint, acl } = formValues;
|
|
|
|
// if fields are filled out and different from what's in store, then return true
|
|
|
|
if (enabled) {
|
2021-02-01 00:01:38 -08:00
|
|
|
if (!!endpoint && !!accessKey && !!secret && !!bucket && !!region) {
|
2021-01-31 23:40:39 -08:00
|
|
|
if (
|
|
|
|
endpoint !== currentValues.endpoint ||
|
|
|
|
accessKey !== currentValues.accessKey ||
|
2021-02-01 00:01:38 -08:00
|
|
|
secret !== currentValues.secret ||
|
2021-01-31 23:40:39 -08:00
|
|
|
region !== currentValues.region ||
|
2021-02-01 00:01:38 -08:00
|
|
|
(!!currentValues.servingEndpoint && servingEndpoint !== currentValues.servingEndpoint) ||
|
|
|
|
(!!currentValues.acl && acl !== currentValues.acl)
|
2021-01-31 23:40:39 -08:00
|
|
|
) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if (enabled !== currentValues.enabled) {
|
|
|
|
return true;
|
2021-01-31 19:45:26 -08:00
|
|
|
}
|
2021-01-31 23:40:39 -08:00
|
|
|
return false;
|
|
|
|
}
|
2021-01-31 19:45:26 -08:00
|
|
|
|
2021-01-31 23:40:39 -08:00
|
|
|
function EditStorage() {
|
|
|
|
const [formDataValues, setFormDataValues] = useState(null);
|
|
|
|
const [submitStatus, setSubmitStatus] = useState<StatusState>(null);
|
2021-01-31 19:45:26 -08:00
|
|
|
|
2021-01-31 23:40:39 -08:00
|
|
|
const [shouldDisplayForm, setShouldDisplayForm] = useState(false);
|
|
|
|
const serverStatusData = useContext(ServerStatusContext);
|
|
|
|
const { serverConfig, setFieldInConfigState } = serverStatusData || {};
|
|
|
|
|
|
|
|
const { s3 } = serverConfig;
|
|
|
|
const {
|
|
|
|
accessKey = '',
|
|
|
|
acl = '',
|
|
|
|
bucket = '',
|
|
|
|
enabled = false,
|
|
|
|
endpoint = '',
|
|
|
|
region = '',
|
|
|
|
secret = '',
|
|
|
|
servingEndpoint = '',
|
|
|
|
} = s3;
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
setFormDataValues({
|
|
|
|
accessKey,
|
|
|
|
acl,
|
|
|
|
bucket,
|
|
|
|
enabled,
|
|
|
|
endpoint,
|
|
|
|
region,
|
|
|
|
secret,
|
|
|
|
servingEndpoint,
|
|
|
|
});
|
|
|
|
setShouldDisplayForm(enabled);
|
|
|
|
}, [s3]);
|
|
|
|
|
|
|
|
if (!formDataValues) {
|
|
|
|
return null;
|
2021-01-31 19:45:26 -08:00
|
|
|
}
|
|
|
|
|
2021-01-31 23:40:39 -08:00
|
|
|
let resetTimer = null;
|
|
|
|
const resetStates = () => {
|
|
|
|
setSubmitStatus(null);
|
|
|
|
resetTimer = null;
|
|
|
|
clearTimeout(resetTimer);
|
|
|
|
};
|
|
|
|
|
|
|
|
// update individual values in state
|
|
|
|
const handleFieldChange = ({ fieldName, value }: UpdateArgs) => {
|
|
|
|
setFormDataValues({
|
|
|
|
...formDataValues,
|
|
|
|
[fieldName]: value,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
// posts the whole state
|
|
|
|
const handleSave = async () => {
|
|
|
|
setSubmitStatus(createInputStatus(STATUS_PROCESSING));
|
|
|
|
const postValue = formDataValues;
|
|
|
|
|
|
|
|
await postConfigUpdateToAPI({
|
|
|
|
apiPath: API_S3_INFO,
|
|
|
|
data: { value: postValue },
|
|
|
|
onSuccess: () => {
|
|
|
|
setFieldInConfigState({ fieldName: 's3', value: postValue, path: '' });
|
|
|
|
setSubmitStatus(createInputStatus(STATUS_SUCCESS, 'Updated.'));
|
|
|
|
resetTimer = setTimeout(resetStates, RESET_TIMEOUT);
|
|
|
|
},
|
|
|
|
onError: (message: string) => {
|
|
|
|
setSubmitStatus(createInputStatus(STATUS_ERROR, message));
|
|
|
|
resetTimer = setTimeout(resetStates, RESET_TIMEOUT);
|
|
|
|
},
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
// toggle switch.
|
|
|
|
const handleSwitchChange = (storageEnabled: boolean) => {
|
|
|
|
setShouldDisplayForm(storageEnabled);
|
|
|
|
handleFieldChange({ fieldName: 'enabled', value: storageEnabled });
|
|
|
|
|
|
|
|
// if current data in current store says s3 is enabled,
|
|
|
|
// we should save this state
|
|
|
|
// if (!storageEnabled && s3.enabled) {
|
|
|
|
// handleSave();
|
|
|
|
// }
|
|
|
|
};
|
|
|
|
|
|
|
|
const containerClass = classNames({
|
|
|
|
'edit-storage-container': true,
|
|
|
|
enabled: shouldDisplayForm,
|
|
|
|
});
|
|
|
|
|
|
|
|
const isSaveable = checkSaveable(formDataValues, s3);
|
2021-01-26 21:13:07 -08:00
|
|
|
|
|
|
|
return (
|
2021-01-31 23:40:39 -08:00
|
|
|
<div className={containerClass}>
|
|
|
|
<div className="enable-switch">
|
|
|
|
<Switch
|
|
|
|
checked={formDataValues.enabled}
|
|
|
|
defaultChecked={formDataValues.enabled}
|
|
|
|
onChange={handleSwitchChange}
|
|
|
|
checkedChildren="ON"
|
|
|
|
unCheckedChildren="OFF"
|
|
|
|
/>{' '}
|
|
|
|
Enabled
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className="form-fields">
|
|
|
|
<div className="field-container">
|
|
|
|
<TextField
|
|
|
|
{...S3_TEXT_FIELDS_INFO.endpoint}
|
|
|
|
value={formDataValues.endpoint}
|
|
|
|
onChange={handleFieldChange}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<div className="field-container">
|
|
|
|
<TextField
|
|
|
|
{...S3_TEXT_FIELDS_INFO.accessKey}
|
|
|
|
value={formDataValues.accessKey}
|
|
|
|
onChange={handleFieldChange}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<div className="field-container">
|
|
|
|
<TextField
|
|
|
|
{...S3_TEXT_FIELDS_INFO.secret}
|
|
|
|
value={formDataValues.secret}
|
|
|
|
onChange={handleFieldChange}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<div className="field-container">
|
|
|
|
<TextField
|
|
|
|
{...S3_TEXT_FIELDS_INFO.bucket}
|
|
|
|
value={formDataValues.bucket}
|
|
|
|
onChange={handleFieldChange}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<div className="field-container">
|
|
|
|
<TextField
|
|
|
|
{...S3_TEXT_FIELDS_INFO.region}
|
|
|
|
value={formDataValues.region}
|
|
|
|
onChange={handleFieldChange}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
|
2021-02-01 00:01:38 -08:00
|
|
|
<Collapse className="advanced-section">
|
2021-01-31 23:40:39 -08:00
|
|
|
<Panel header="Advanced Settings" key="1">
|
|
|
|
<div className="field-container">
|
|
|
|
<TextField
|
|
|
|
{...S3_TEXT_FIELDS_INFO.acl}
|
|
|
|
value={formDataValues.acl}
|
|
|
|
onChange={handleFieldChange}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<div className="field-container">
|
|
|
|
<TextField
|
|
|
|
{...S3_TEXT_FIELDS_INFO.servingEndpoint}
|
|
|
|
value={formDataValues.servingEndpoint}
|
|
|
|
onChange={handleFieldChange}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</Panel>
|
|
|
|
</Collapse>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div className="button-container">
|
2021-02-01 00:01:38 -08:00
|
|
|
<Button type="primary" onClick={handleSave} disabled={!isSaveable}>
|
2021-01-31 23:40:39 -08:00
|
|
|
Save
|
|
|
|
</Button>
|
|
|
|
<InputStatusInfo status={submitStatus} />
|
|
|
|
</div>
|
|
|
|
</div>
|
2021-01-26 21:13:07 -08:00
|
|
|
);
|
2020-10-29 10:16:13 -07:00
|
|
|
}
|
|
|
|
|
2021-01-31 23:40:39 -08:00
|
|
|
export default function ConfigStorageInfo() {
|
2020-10-29 10:16:13 -07:00
|
|
|
return (
|
2021-01-31 23:40:39 -08:00
|
|
|
<>
|
|
|
|
<Title level={2}>Storage</Title>
|
|
|
|
<EditStorage />
|
|
|
|
</>
|
2020-10-29 10:22:31 -07:00
|
|
|
);
|
2020-10-29 10:16:13 -07:00
|
|
|
}
|