mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2026-02-27 12:16:36 +00:00
42 lines
1.3 KiB
JavaScript
42 lines
1.3 KiB
JavaScript
import React, { useEffect, useState } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import { HorizontalFormGroup } from '../../utils/HorizontalFormGroup';
|
|
|
|
const propTypes = {
|
|
onSubmit: PropTypes.func.isRequired,
|
|
initialValues: PropTypes.shape({
|
|
name: PropTypes.string.isRequired,
|
|
url: PropTypes.string.isRequired,
|
|
apiKey: PropTypes.string.isRequired,
|
|
}),
|
|
children: PropTypes.node.isRequired,
|
|
};
|
|
|
|
export const ServerForm = ({ onSubmit, initialValues, children }) => {
|
|
const [ name, setName ] = useState('');
|
|
const [ url, setUrl ] = useState('');
|
|
const [ apiKey, setApiKey ] = useState('');
|
|
const handleSubmit = (e) => {
|
|
e.preventDefault();
|
|
onSubmit({ name, url, apiKey });
|
|
};
|
|
|
|
useEffect(() => {
|
|
initialValues && setName(initialValues.name);
|
|
initialValues && setUrl(initialValues.url);
|
|
initialValues && setApiKey(initialValues.apiKey);
|
|
}, [ initialValues ]);
|
|
|
|
return (
|
|
<form onSubmit={handleSubmit}>
|
|
<HorizontalFormGroup value={name} onChange={setName}>Name</HorizontalFormGroup>
|
|
<HorizontalFormGroup type="url" value={url} onChange={setUrl}>URL</HorizontalFormGroup>
|
|
<HorizontalFormGroup value={apiKey} onChange={setApiKey}>API key</HorizontalFormGroup>
|
|
|
|
<div className="text-right">{children}</div>
|
|
</form>
|
|
);
|
|
};
|
|
|
|
ServerForm.propTypes = propTypes;
|