mirror of
https://github.com/usebruno/bruno.git
synced 2026-06-28 23:24:05 +00:00
* feat: enhance variable highlighting in CodeMirror and update interpolation method * feat: add interpolate function to bru shim and corresponding tests - Implemented the `interpolate` function in the bru shim to handle variable interpolation. - Added a new test case for the `interpolate` function to verify its functionality with mock variables. * feat: enhance interpolate function to support object interpolation * feat: add translation support for pm.variables.replaceIn to bru.interpolate * revert: eslint config changes * revert: eslint config changes * fix: update method call to use correct interpolation function in Bru class * refactor: added jsdoc to codemirror highlighting code * fix: higlighting for multiline editor
82 lines
2.6 KiB
JavaScript
82 lines
2.6 KiB
JavaScript
import React from 'react';
|
|
import get from 'lodash/get';
|
|
import CodeEditor from 'components/CodeEditor';
|
|
import FormUrlEncodedParams from 'components/RequestPane/FormUrlEncodedParams';
|
|
import MultipartFormParams from 'components/RequestPane/MultipartFormParams';
|
|
import { useDispatch, useSelector } from 'react-redux';
|
|
import { useTheme } from 'providers/Theme';
|
|
import { updateRequestBody } from 'providers/ReduxStore/slices/collections';
|
|
import { sendRequest, saveRequest } from 'providers/ReduxStore/slices/collections/actions';
|
|
import StyledWrapper from './StyledWrapper';
|
|
import FileBody from '../FileBody/index';
|
|
|
|
const RequestBody = ({ item, collection }) => {
|
|
const dispatch = useDispatch();
|
|
const body = item.draft ? get(item, 'draft.request.body') : get(item, 'request.body');
|
|
const bodyMode = item.draft ? get(item, 'draft.request.body.mode') : get(item, 'request.body.mode');
|
|
const { displayedTheme } = useTheme();
|
|
const preferences = useSelector((state) => state.app.preferences);
|
|
|
|
const onEdit = (value) => {
|
|
dispatch(
|
|
updateRequestBody({
|
|
content: value,
|
|
itemUid: item.uid,
|
|
collectionUid: collection.uid
|
|
})
|
|
);
|
|
};
|
|
|
|
const onRun = () => dispatch(sendRequest(item, collection.uid));
|
|
const onSave = () => dispatch(saveRequest(item.uid, collection.uid));
|
|
|
|
if (['json', 'xml', 'text', 'sparql'].includes(bodyMode)) {
|
|
let codeMirrorMode = {
|
|
json: 'application/ld+json',
|
|
text: 'application/text',
|
|
xml: 'application/xml',
|
|
sparql: 'application/sparql-query'
|
|
};
|
|
|
|
let bodyContent = {
|
|
json: body.json,
|
|
text: body.text,
|
|
xml: body.xml,
|
|
sparql: body.sparql
|
|
};
|
|
|
|
return (
|
|
<StyledWrapper className="w-full">
|
|
<CodeEditor
|
|
collection={collection}
|
|
item={item}
|
|
theme={displayedTheme}
|
|
font={get(preferences, 'font.codeFont', 'default')}
|
|
fontSize={get(preferences, 'font.codeFontSize')}
|
|
value={bodyContent[bodyMode] || ''}
|
|
onEdit={onEdit}
|
|
onRun={onRun}
|
|
onSave={onSave}
|
|
mode={codeMirrorMode[bodyMode]}
|
|
enableVariableHighlighting={true}
|
|
/>
|
|
</StyledWrapper>
|
|
);
|
|
}
|
|
|
|
if (bodyMode === 'file') {
|
|
return <FileBody item={item} collection={collection} />;
|
|
}
|
|
|
|
if (bodyMode === 'formUrlEncoded') {
|
|
return <FormUrlEncodedParams item={item} collection={collection} />;
|
|
}
|
|
|
|
if (bodyMode === 'multipartForm') {
|
|
return <MultipartFormParams item={item} collection={collection} />;
|
|
}
|
|
|
|
return <StyledWrapper className="w-full">No Body</StyledWrapper>;
|
|
};
|
|
export default RequestBody;
|