2020-03-25 05:45:21 +00:00
|
|
|
import React, { useState } from 'react';
|
2020-03-20 10:06:14 +00:00
|
|
|
|
|
|
|
import Row from 'react-bootstrap/Row';
|
|
|
|
import Col from 'react-bootstrap/Col';
|
2020-03-25 05:45:21 +00:00
|
|
|
import { Spinner, Table } from 'react-bootstrap';
|
2020-03-20 10:06:14 +00:00
|
|
|
|
|
|
|
import SearchField from './SearchField.js';
|
|
|
|
|
|
|
|
const search = (prefix, api, setState) => {
|
2020-03-25 05:45:21 +00:00
|
|
|
setState({ data: undefined, loading: true });
|
|
|
|
const lookupSuccess = (response) => setState({ data: response.data, loading: false });
|
|
|
|
const lookupFail = (error) => {
|
|
|
|
setState({ data: undefined, loading: false });
|
|
|
|
|
|
|
|
setState(() => {
|
|
|
|
throw error;
|
|
|
|
});
|
|
|
|
};
|
|
|
|
return api.lookupStorage(prefix).then(lookupSuccess).catch(lookupFail);
|
|
|
|
};
|
|
|
|
|
|
|
|
const LookupStorageForm = ({ api }) => {
|
|
|
|
const [state, setState] = useState({ data: undefined, loading: false });
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div>
|
2020-04-08 11:45:51 +00:00
|
|
|
<SearchField
|
|
|
|
placeholder="lookup by prefix"
|
|
|
|
disabled={state.loading}
|
|
|
|
onSubmit={(data) => search(data.search, api, setState)}
|
|
|
|
/>
|
2020-03-25 05:45:21 +00:00
|
|
|
{state.loading && <Spinner animation="border" />}
|
|
|
|
{state.data && <Details data={state.data} />}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
const Details = ({ data }) => (
|
|
|
|
<Row>
|
|
|
|
<Col>
|
|
|
|
<Table size="sm" borderless>
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>
|
|
|
|
<strong>Key</strong>
|
|
|
|
</th>
|
|
|
|
<th>
|
|
|
|
<strong>Value</strong>
|
|
|
|
</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
{data.map((item, i) => (
|
|
|
|
<TableRow key={i} item={item} />
|
|
|
|
))}
|
|
|
|
</tbody>
|
|
|
|
</Table>
|
|
|
|
</Col>
|
|
|
|
</Row>
|
2020-03-20 10:06:14 +00:00
|
|
|
);
|
|
|
|
|
2020-03-25 05:45:21 +00:00
|
|
|
const TableRow = ({ item }) => (
|
|
|
|
<tr>
|
|
|
|
<td className="text-monospace">{item.prefix}</td>
|
|
|
|
<td className="text-monospace">{item.value}</td>
|
|
|
|
</tr>
|
2020-03-20 10:06:14 +00:00
|
|
|
);
|
|
|
|
|
2020-03-25 05:45:21 +00:00
|
|
|
export default LookupStorageForm;
|