1
0
mirror of https://github.com/usebruno/bruno.git synced 2025-03-09 03:51:53 +01:00

improve: script ui

This commit is contained in:
Pooja Belaramani 2025-01-22 14:07:58 +05:30
parent fee631d496
commit 3d6ebe67b7
2 changed files with 80 additions and 34 deletions
packages/bruno-app/src/components/RequestPane/Script

View File

@ -1,12 +1,41 @@
import styled from 'styled-components'; import styled from 'styled-components';
const StyledWrapper = styled.div` const StyledWrapper = styled.div`
div.CodeMirror { height: 100%;
height: inherit;
.script-tabs {
display: flex;
gap: 1px;
padding: 0 1px;
border-bottom: 1px solid ${(props) => props.theme.requestTabs.bottomBorder};
} }
div.title { .tab {
color: var(--color-tab-inactive); padding: 8px 16px;
font-size: 13px;
background: transparent;
border: none;
cursor: pointer;
color: ${(props) => props.theme.requestTabs.color};
border-bottom: 2px solid transparent;
transition: all 0.2s ease;
position: relative;
&:hover {
color: ${(props) => props.theme.requestTabs.icon.hoverColor};
background: ${(props) => props.theme.requestTabs.icon.hoverBg};
}
&.active {
color: ${(props) => props.theme.tabs.active.color};
border-bottom: solid 2px ${(props) => props.theme.tabs.active.border};
background: ${(props) => props.theme.requestTabs.active.bg};
}
}
div.CodeMirror {
height: calc(100vh - 290px);
background: ${(props) => props.theme.codemirror.bg};
} }
`; `;

View File

@ -1,4 +1,4 @@
import React from 'react'; import React, { useState } from 'react';
import get from 'lodash/get'; import get from 'lodash/get';
import { useDispatch, useSelector } from 'react-redux'; import { useDispatch, useSelector } from 'react-redux';
import CodeEditor from 'components/CodeEditor'; import CodeEditor from 'components/CodeEditor';
@ -8,6 +8,7 @@ import { useTheme } from 'providers/Theme';
import StyledWrapper from './StyledWrapper'; import StyledWrapper from './StyledWrapper';
const Script = ({ item, collection }) => { const Script = ({ item, collection }) => {
const [activeTab, setActiveTab] = useState('pre-request');
const dispatch = useDispatch(); const dispatch = useDispatch();
const requestScript = item.draft ? get(item, 'draft.request.script.req') : get(item, 'request.script.req'); const requestScript = item.draft ? get(item, 'draft.request.script.req') : get(item, 'request.script.req');
const responseScript = item.draft ? get(item, 'draft.request.script.res') : get(item, 'request.script.res'); const responseScript = item.draft ? get(item, 'draft.request.script.res') : get(item, 'request.script.res');
@ -39,9 +40,24 @@ const Script = ({ item, collection }) => {
const onSave = () => dispatch(saveRequest(item.uid, collection.uid)); const onSave = () => dispatch(saveRequest(item.uid, collection.uid));
return ( return (
<StyledWrapper className="w-full flex flex-col"> <StyledWrapper className="w-full flex flex-col mt-4">
<div className="flex flex-col flex-1 mt-2 gap-y-2"> <div className="script-tabs">
<div className="title text-xs">Pre Request</div> <button
className={`tab ${activeTab === 'pre-request' ? 'active' : ''}`}
onClick={() => setActiveTab('pre-request')}
>
Pre Request
</button>
<button
className={`tab ${activeTab === 'post-response' ? 'active' : ''}`}
onClick={() => setActiveTab('post-response')}
>
Post Response
</button>
</div>
<div className="flex flex-col flex-1 mt-2">
{activeTab === 'pre-request' && (
<CodeEditor <CodeEditor
collection={collection} collection={collection}
value={requestScript || ''} value={requestScript || ''}
@ -53,9 +69,9 @@ const Script = ({ item, collection }) => {
onRun={onRun} onRun={onRun}
onSave={onSave} onSave={onSave}
/> />
</div> )}
<div className="flex flex-col flex-1 mt-2 gap-y-2">
<div className="title text-xs">Post Response</div> {activeTab === 'post-response' && (
<CodeEditor <CodeEditor
collection={collection} collection={collection}
value={responseScript || ''} value={responseScript || ''}
@ -67,6 +83,7 @@ const Script = ({ item, collection }) => {
onRun={onRun} onRun={onRun}
onSave={onSave} onSave={onSave}
/> />
)}
</div> </div>
</StyledWrapper> </StyledWrapper>
); );