forked from extern/bruno
50 lines
1.3 KiB
JavaScript
50 lines
1.3 KiB
JavaScript
|
import React, { useState } from 'react';
|
||
|
import classnames from 'classnames';
|
||
|
import QueryResult from '../QueryResult';
|
||
|
import StyledWrapper from './StyledWrapper';
|
||
|
|
||
|
const ResponsePane = ({rightPaneWidth, data, isLoading}) => {
|
||
|
const [selectedTab, setSelectedTab] = useState('response');
|
||
|
|
||
|
const getTabClassname = (tabName) => {
|
||
|
return classnames(`tab select-none ${tabName}`, {
|
||
|
'active': tabName === selectedTab
|
||
|
});
|
||
|
};
|
||
|
|
||
|
const getTabPanel = (tab) => {
|
||
|
switch(tab) {
|
||
|
case 'response': {
|
||
|
return (
|
||
|
<QueryResult
|
||
|
width={rightPaneWidth}
|
||
|
data={data}
|
||
|
isLoading={isLoading}
|
||
|
/>
|
||
|
);
|
||
|
}
|
||
|
case 'headers': {
|
||
|
return <div>Headers</div>;
|
||
|
}
|
||
|
|
||
|
default: {
|
||
|
return <div>404 | Not found</div>;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return (
|
||
|
<StyledWrapper className="">
|
||
|
<div className="flex items-center tabs mt-1" role="tablist">
|
||
|
<div className={getTabClassname('response')} role="tab" onClick={() => setSelectedTab('response')}>Response</div>
|
||
|
<div className={getTabClassname('headers')} role="tab" onClick={() => setSelectedTab('headers')}>Headers</div>
|
||
|
</div>
|
||
|
<section>
|
||
|
{getTabPanel(selectedTab)}
|
||
|
</section>
|
||
|
</StyledWrapper>
|
||
|
)
|
||
|
};
|
||
|
|
||
|
export default ResponsePane;
|