mirror of
https://github.com/usebruno/bruno.git
synced 2025-08-02 02:13:09 +02:00
* pr review changes * collection root object in export json * import environment updates * tests run execution order fix for collection runs * updated validations * folder/request pre-vars green/red color highlight * collection vars > request vars * chore: removed unused logic --------- Co-authored-by: Anoop M D <anoop.md1421@gmail.com>
152 lines
4.9 KiB
JavaScript
152 lines
4.9 KiB
JavaScript
import React from 'react';
|
|
import get from 'lodash/get';
|
|
import cloneDeep from 'lodash/cloneDeep';
|
|
import { IconTrash } from '@tabler/icons';
|
|
import { useDispatch } from 'react-redux';
|
|
import { useTheme } from 'providers/Theme';
|
|
import { addRequestHeader, updateRequestHeader, deleteRequestHeader } from 'providers/ReduxStore/slices/collections';
|
|
import { sendRequest, saveRequest } from 'providers/ReduxStore/slices/collections/actions';
|
|
import SingleLineEditor from 'components/SingleLineEditor';
|
|
import StyledWrapper from './StyledWrapper';
|
|
import { headers as StandardHTTPHeaders } from 'know-your-http-well';
|
|
import { MimeTypes } from 'utils/codemirror/autocompleteConstants';
|
|
const headerAutoCompleteList = StandardHTTPHeaders.map((e) => e.header);
|
|
|
|
const RequestHeaders = ({ item, collection }) => {
|
|
const dispatch = useDispatch();
|
|
const { storedTheme } = useTheme();
|
|
const headers = item.draft ? get(item, 'draft.request.headers') : get(item, 'request.headers');
|
|
|
|
const addHeader = () => {
|
|
dispatch(
|
|
addRequestHeader({
|
|
itemUid: item.uid,
|
|
collectionUid: collection.uid
|
|
})
|
|
);
|
|
};
|
|
|
|
const onSave = () => dispatch(saveRequest(item.uid, collection.uid));
|
|
const handleRun = () => dispatch(sendRequest(item, collection.uid));
|
|
const handleHeaderValueChange = (e, _header, type) => {
|
|
const header = cloneDeep(_header);
|
|
switch (type) {
|
|
case 'name': {
|
|
header.name = e.target.value;
|
|
break;
|
|
}
|
|
case 'value': {
|
|
header.value = e.target.value;
|
|
break;
|
|
}
|
|
case 'enabled': {
|
|
header.enabled = e.target.checked;
|
|
break;
|
|
}
|
|
}
|
|
dispatch(
|
|
updateRequestHeader({
|
|
header: header,
|
|
itemUid: item.uid,
|
|
collectionUid: collection.uid
|
|
})
|
|
);
|
|
};
|
|
|
|
const handleRemoveHeader = (header) => {
|
|
dispatch(
|
|
deleteRequestHeader({
|
|
headerUid: header.uid,
|
|
itemUid: item.uid,
|
|
collectionUid: collection.uid
|
|
})
|
|
);
|
|
};
|
|
|
|
return (
|
|
<StyledWrapper className="w-full">
|
|
<table>
|
|
<thead>
|
|
<tr>
|
|
<td>Name</td>
|
|
<td>Value</td>
|
|
<td></td>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{headers && headers.length
|
|
? headers.map((header) => {
|
|
return (
|
|
<tr key={header.uid}>
|
|
<td>
|
|
<SingleLineEditor
|
|
value={header.name}
|
|
theme={storedTheme}
|
|
onSave={onSave}
|
|
onChange={(newValue) =>
|
|
handleHeaderValueChange(
|
|
{
|
|
target: {
|
|
value: newValue
|
|
}
|
|
},
|
|
header,
|
|
'name'
|
|
)
|
|
}
|
|
autocomplete={headerAutoCompleteList}
|
|
onRun={handleRun}
|
|
collection={collection}
|
|
/>
|
|
</td>
|
|
<td>
|
|
<SingleLineEditor
|
|
value={header.value}
|
|
theme={storedTheme}
|
|
onSave={onSave}
|
|
onChange={(newValue) =>
|
|
handleHeaderValueChange(
|
|
{
|
|
target: {
|
|
value: newValue
|
|
}
|
|
},
|
|
header,
|
|
'value'
|
|
)
|
|
}
|
|
onRun={handleRun}
|
|
autocomplete={MimeTypes}
|
|
allowNewlines={true}
|
|
collection={collection}
|
|
item={item}
|
|
/>
|
|
</td>
|
|
<td>
|
|
<div className="flex items-center">
|
|
<input
|
|
type="checkbox"
|
|
checked={header.enabled}
|
|
tabIndex="-1"
|
|
className="mr-3 mousetrap"
|
|
onChange={(e) => handleHeaderValueChange(e, header, 'enabled')}
|
|
/>
|
|
<button tabIndex="-1" onClick={() => handleRemoveHeader(header)}>
|
|
<IconTrash strokeWidth={1.5} size={20} />
|
|
</button>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
);
|
|
})
|
|
: null}
|
|
</tbody>
|
|
</table>
|
|
<button className="btn-add-header text-link pr-2 py-3 mt-2 select-none" onClick={addHeader}>
|
|
+ Add Header
|
|
</button>
|
|
</StyledWrapper>
|
|
);
|
|
};
|
|
export default RequestHeaders;
|