bruno/renderer/components/RequestTabs/index.js

150 lines
5.7 KiB
JavaScript
Raw Normal View History

2021-12-03 21:33:46 +01:00
import React from 'react';
2022-03-11 17:49:11 +01:00
import find from 'lodash/find';
import filter from 'lodash/filter';
2021-12-03 21:33:46 +01:00
import classnames from 'classnames';
2022-03-08 05:02:31 +01:00
import { IconHome2 } from '@tabler/icons';
import { useSelector, useDispatch } from 'react-redux';
import { focusTab, closeTab } from 'providers/ReduxStore/slices/tabs';
import { findItemInCollection } from 'utils/collections';
2022-03-13 08:48:15 +01:00
import CollectionToolBar from './CollectionToolBar';
2021-12-03 21:33:46 +01:00
import StyledWrapper from './StyledWrapper';
2022-03-11 17:49:11 +01:00
const RequestTabs = () => {
const tabs = useSelector((state) => state.tabs.tabs);
const activeTabUid = useSelector((state) => state.tabs.activeTabUid);
const collections = useSelector((state) => state.collections.collections);
const dispatch = useDispatch();
2022-03-11 17:49:11 +01:00
const getTabClassname = (tab, index) => {
2021-12-03 21:33:46 +01:00
return classnames("request-tab select-none", {
'active': tab.uid === activeTabUid,
'last-tab': tabs && tabs.length && (index === tabs.length - 1)
2021-12-03 21:33:46 +01:00
});
};
const getMethodColor = (method) => {
let color = '';
switch(method) {
case 'GET': {
color = 'rgb(5, 150, 105)';
break;
}
case 'POST': {
color = '#8e44ad';
break;
}
}
return color;
};
const handleClick = (tab) => {
dispatch(focusTab({
uid: tab.uid
}));
2021-12-03 21:33:46 +01:00
};
const handleCloseClick = (event, tab) => {
event.stopPropagation();
event.preventDefault();
2022-03-18 20:35:43 +01:00
dispatch(closeTab({
tabUid: tab.uid
}))
2021-12-03 21:33:46 +01:00
};
const createNewTab = () => {
// todo
};
if(!activeTabUid) {
2022-03-11 17:49:11 +01:00
return null;
}
const activeTab = find(tabs, (t) => t.uid === activeTabUid);
if(!activeTab) {
return (
<StyledWrapper>
Something went wrong!
</StyledWrapper>
);
}
const activeCollection = find(collections, (c) => c.uid === activeTab.collectionUid);
const collectionRequestTabs = filter(tabs, (t) => t.collectionUid === activeTab.collectionUid);
const item = findItemInCollection(activeCollection, activeTab.uid);
2022-03-18 20:35:43 +01:00
if(!item || !item.uid) {
return (
<StyledWrapper>
Request not found!
</StyledWrapper>
);
}
const getRequestName = (tab) => {
const item = findItemInCollection(activeCollection, tab.uid);
2022-03-18 20:35:43 +01:00
return item ? item.name : '';
}
const getRequestMethod = (tab) => {
const item = findItemInCollection(activeCollection, tab.uid);
2022-03-18 20:35:43 +01:00
return item ? item.request.method : '';
}
2022-03-11 17:49:11 +01:00
2021-12-03 21:33:46 +01:00
return (
2022-03-11 17:49:11 +01:00
<StyledWrapper>
{collectionRequestTabs && collectionRequestTabs.length ? (
<>
2022-03-13 08:48:15 +01:00
<CollectionToolBar collection={activeCollection}/>
<div className="flex items-center">
2022-03-11 17:49:11 +01:00
<ul role="tablist">
<li className="select-none new-tab mr-1" onClick={createNewTab}>
<div className="flex items-center home-icon-container">
<IconHome2 size={18} strokeWidth={1.5}/>
</div>
</li>
{collectionRequestTabs && collectionRequestTabs.length ? collectionRequestTabs.map((tab, index) => {
return <li key={tab.uid} className={getTabClassname(tab, index)} role="tab" onClick={() => handleClick(tab)}>
2022-03-11 17:49:11 +01:00
<div className="flex items-center justify-between tab-container px-1">
<div className="flex items-center tab-label pl-2">
<span className="tab-method" style={{color: getMethodColor(getRequestMethod(tab))}}>{getRequestMethod(tab)}</span>
<span className="text-gray-700 ml-1 tab-name">{getRequestName(tab)}</span>
2022-03-11 17:49:11 +01:00
</div>
<div className="flex px-2 close-icon-container" onClick={(e) => handleCloseClick(e, tab)}>
{!tab.hasChanges ? (
2022-03-11 17:49:11 +01:00
<svg focusable="false"xmlns="http://www.w3.org/2000/svg" viewBox="0 0 320 512" className="close-icon">
<path fill="currentColor" d="M207.6 256l107.72-107.72c6.23-6.23 6.23-16.34 0-22.58l-25.03-25.03c-6.23-6.23-16.34-6.23-22.58 0L160 208.4 52.28 100.68c-6.23-6.23-16.34-6.23-22.58 0L4.68 125.7c-6.23 6.23-6.23 16.34 0 22.58L112.4 256 4.68 363.72c-6.23 6.23-6.23 16.34 0 22.58l25.03 25.03c6.23 6.23 16.34 6.23 22.58 0L160 303.6l107.72 107.72c6.23 6.23 16.34 6.23 22.58 0l25.03-25.03c6.23-6.23 6.23-16.34 0-22.58L207.6 256z"></path>
</svg>
) : (
2022-03-15 20:29:57 +01:00
<svg focusable="false" xmlns="http://www.w3.org/2000/svg" width="8" height="16" fill="#cc7b1b" className="has-changes-icon" viewBox="0 0 8 8">
2022-03-11 17:49:11 +01:00
<circle cx="4" cy="4" r="3"/>
</svg>
) }
</div>
</div>
</li>
}) : null}
<li className="select-none new-tab ml-1" onClick={createNewTab}>
<div className="flex items-center">
<svg xmlns="http://www.w3.org/2000/svg" width="22" height="22" fill="currentColor" viewBox="0 0 16 16">
<path d="M8 4a.5.5 0 0 1 .5.5v3h3a.5.5 0 0 1 0 1h-3v3a.5.5 0 0 1-1 0v-3h-3a.5.5 0 0 1 0-1h3v-3A.5.5 0 0 1 8 4z"/>
</svg>
2021-12-03 21:33:46 +01:00
</div>
2022-03-11 17:49:11 +01:00
</li>
<li className="select-none new-tab choose-request">
<div className="flex items-center">
<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" fill="currentColor" viewBox="0 0 16 16">
<path d="M3 9.5a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3zm5 0a1.5 1.5 0 1 1 0-3 1.5 1.5 0 0 1 0 3z"/>
</svg>
</div>
2022-03-11 17:49:11 +01:00
</li>
</ul>
</div>
</>
2022-01-06 19:37:32 +01:00
) : null}
2021-12-03 21:33:46 +01:00
</StyledWrapper>
);
};
export default RequestTabs;