feat: implement test cases tab with styling and functionality for displaying test cases
This commit is contained in:
@@ -18,6 +18,7 @@ const CodeChallenge = () => {
|
||||
const [timeRemaining, setTimeRemaining] = useState(null);
|
||||
const [terminalInput, setTerminalInput] = useState('');
|
||||
const [waitingForInput, setWaitingForInput] = useState(false);
|
||||
const [activeTab, setActiveTab] = useState('console'); // 'console' or 'testcases'
|
||||
const socketRef = useRef(null);
|
||||
const terminalInputRef = useRef(null);
|
||||
const { token } = useAuth();
|
||||
@@ -729,27 +730,6 @@ const CodeChallenge = () => {
|
||||
{currentQuestion.constraints && <p><strong>Constraints:</strong> {currentQuestion.constraints}</p>}
|
||||
{currentQuestion.marks && <p><strong>Points:</strong> {currentQuestion.marks}</p>}
|
||||
</div>
|
||||
|
||||
{currentQuestion.test_cases && currentQuestion.test_cases.length > 0 && (
|
||||
<div className="test-cases-section">
|
||||
<h3>Example Test Cases:</h3>
|
||||
{currentQuestion.test_cases.slice(0, 2).map((testCase, idx) => (
|
||||
<div key={idx} className="test-case-card">
|
||||
<div className="test-case-label">Example {idx + 1}</div>
|
||||
<div className="test-case-content">
|
||||
<div className="test-case-item">
|
||||
<span className="test-label">Input:</span>
|
||||
<code className="test-value">{testCase.input}</code>
|
||||
</div>
|
||||
<div className="test-case-item">
|
||||
<span className="test-label">Expected Output:</span>
|
||||
<code className="test-value">{testCase.expected_output}</code>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
))}
|
||||
</div>
|
||||
)}
|
||||
</div>
|
||||
);
|
||||
}
|
||||
@@ -954,55 +934,106 @@ const CodeChallenge = () => {
|
||||
<div className="console-section">
|
||||
<div className="console-header">
|
||||
<div className="console-tabs">
|
||||
<button className="console-tab console-tab-active">
|
||||
<button
|
||||
className={`console-tab ${activeTab === 'console' ? 'console-tab-active' : ''}`}
|
||||
onClick={() => setActiveTab('console')}
|
||||
>
|
||||
<span>Console</span>
|
||||
</button>
|
||||
<button className="console-tab">
|
||||
<span>Testcases</span>
|
||||
<button
|
||||
className={`console-tab ${activeTab === 'testcases' ? 'console-tab-active' : ''}`}
|
||||
onClick={() => setActiveTab('testcases')}
|
||||
>
|
||||
<span>Test Cases</span>
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
<div
|
||||
className="console-content"
|
||||
onClick={() => {
|
||||
if (waitingForInput && terminalInputRef.current) {
|
||||
terminalInputRef.current.focus();
|
||||
}
|
||||
}}
|
||||
style={{ cursor: waitingForInput ? 'text' : 'default' }}
|
||||
>
|
||||
{terminalOutput.length === 0 ? (
|
||||
<div className="console-placeholder">
|
||||
Console output will appear here...
|
||||
</div>
|
||||
) : (
|
||||
<>
|
||||
{terminalOutput.map((line, index) => (
|
||||
<div
|
||||
key={index}
|
||||
className={`console-line ${line.type}`}
|
||||
>
|
||||
{line.content}
|
||||
</div>
|
||||
))}
|
||||
{waitingForInput && (
|
||||
<div className="console-line console-input-line">
|
||||
<form onSubmit={handleTerminalInput} className="console-input-form">
|
||||
<span className="console-cursor">{'> '}</span>
|
||||
<input
|
||||
ref={terminalInputRef}
|
||||
type="text"
|
||||
value={terminalInput}
|
||||
onChange={(e) => setTerminalInput(e.target.value)}
|
||||
className="console-input"
|
||||
autoFocus
|
||||
/>
|
||||
</form>
|
||||
</div>
|
||||
)}
|
||||
</>
|
||||
)}
|
||||
</div>
|
||||
|
||||
{/* Console Tab Content */}
|
||||
{activeTab === 'console' && (
|
||||
<div
|
||||
className="console-content"
|
||||
onClick={() => {
|
||||
if (waitingForInput && terminalInputRef.current) {
|
||||
terminalInputRef.current.focus();
|
||||
}
|
||||
}}
|
||||
style={{ cursor: waitingForInput ? 'text' : 'default' }}
|
||||
>
|
||||
{terminalOutput.length === 0 ? (
|
||||
<div className="console-placeholder">
|
||||
Console output will appear here...
|
||||
</div>
|
||||
) : (
|
||||
<>
|
||||
{terminalOutput.map((line, index) => (
|
||||
<div
|
||||
key={index}
|
||||
className={`console-line ${line.type}`}
|
||||
>
|
||||
{line.content}
|
||||
</div>
|
||||
))}
|
||||
{waitingForInput && (
|
||||
<div className="console-line console-input-line">
|
||||
<form onSubmit={handleTerminalInput} className="console-input-form">
|
||||
<span className="console-cursor">{'> '}</span>
|
||||
<input
|
||||
ref={terminalInputRef}
|
||||
type="text"
|
||||
value={terminalInput}
|
||||
onChange={(e) => setTerminalInput(e.target.value)}
|
||||
className="console-input"
|
||||
autoFocus
|
||||
/>
|
||||
</form>
|
||||
</div>
|
||||
)}
|
||||
</>
|
||||
)}
|
||||
</div>
|
||||
)}
|
||||
|
||||
{/* Test Cases Tab Content */}
|
||||
{activeTab === 'testcases' && (
|
||||
<div className="console-content testcases-tab-content">
|
||||
{(() => {
|
||||
const currentQuestion = getCurrentQuestion();
|
||||
if (currentQuestion?.test_cases && currentQuestion.test_cases.length > 0) {
|
||||
return (
|
||||
<div className="testcases-container">
|
||||
{currentQuestion.test_cases.map((testCase, idx) => (
|
||||
<div key={testCase.id || idx} className="testcase-item">
|
||||
<div className="testcase-header">
|
||||
<span className="testcase-title">Test Case {idx + 1}</span>
|
||||
{testCase.is_sample && (
|
||||
<span className="testcase-badge">Sample</span>
|
||||
)}
|
||||
</div>
|
||||
<div className="testcase-body">
|
||||
<div className="testcase-field">
|
||||
<div className="testcase-field-label">Input:</div>
|
||||
<pre className="testcase-field-value">{testCase.input}</pre>
|
||||
</div>
|
||||
<div className="testcase-field">
|
||||
<div className="testcase-field-label">Expected Output:</div>
|
||||
<pre className="testcase-field-value">{testCase.expected_output}</pre>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
))}
|
||||
</div>
|
||||
);
|
||||
} else {
|
||||
return (
|
||||
<div className="console-placeholder">
|
||||
No test cases available for this question.
|
||||
</div>
|
||||
);
|
||||
}
|
||||
})()}
|
||||
</div>
|
||||
)}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user