2026-04-26 18:39:09 +09:00
|
|
|
<!doctype html>
|
|
|
|
|
<html lang="ko">
|
|
|
|
|
<head>
|
|
|
|
|
<meta charset="utf-8" />
|
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
|
|
|
<title>Tutor Platform</title>
|
|
|
|
|
<link rel="stylesheet" href="/assets/styles.css" />
|
|
|
|
|
</head>
|
|
|
|
|
<body>
|
|
|
|
|
<main class="workspace">
|
|
|
|
|
<aside class="setup-pane" aria-label="Diagnostic setup">
|
|
|
|
|
<p class="eyebrow">Tutor Platform</p>
|
|
|
|
|
<h1>Interview practice</h1>
|
|
|
|
|
<p class="lede">Start a focused backend interview loop and turn one answer into evidence.</p>
|
|
|
|
|
|
|
|
|
|
<form id="session-form" class="stacked-form">
|
|
|
|
|
<label>
|
|
|
|
|
User ID
|
|
|
|
|
<input id="user-id" name="user_id" value="demo-user" autocomplete="off" />
|
|
|
|
|
</label>
|
|
|
|
|
<label>
|
|
|
|
|
Target role
|
|
|
|
|
<input id="target-role" name="target_role" value="junior backend developer" />
|
|
|
|
|
</label>
|
|
|
|
|
<label>
|
|
|
|
|
Stack
|
|
|
|
|
<input id="stack" name="stack" value="go, postgres" />
|
|
|
|
|
</label>
|
|
|
|
|
<label>
|
|
|
|
|
Timeline
|
|
|
|
|
<input id="timeline" name="interview_timeline" value="30 days" />
|
|
|
|
|
</label>
|
|
|
|
|
<button id="start-button" type="submit">Start diagnostic</button>
|
|
|
|
|
</form>
|
|
|
|
|
|
|
|
|
|
<p id="status-line" class="status-line" role="status">Ready</p>
|
|
|
|
|
<p id="error-line" class="error-line" role="alert"></p>
|
|
|
|
|
</aside>
|
|
|
|
|
|
|
|
|
|
<section class="practice-pane" aria-label="Diagnostic practice">
|
|
|
|
|
<div class="section-heading">
|
|
|
|
|
<p class="eyebrow">Diagnostic</p>
|
|
|
|
|
<h2 id="session-title">No active session</h2>
|
|
|
|
|
</div>
|
|
|
|
|
<div id="questions" class="question-list empty-state">
|
|
|
|
|
Start a diagnostic session to load interview questions.
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
<form id="answer-form" class="answer-form">
|
|
|
|
|
<label for="answer-text">Answer</label>
|
|
|
|
|
<textarea id="answer-text" rows="7" placeholder="Select a question, then answer with concrete production reasoning."></textarea>
|
|
|
|
|
<button id="answer-button" type="submit" disabled>Submit answer</button>
|
|
|
|
|
</form>
|
|
|
|
|
</section>
|
|
|
|
|
|
|
|
|
|
<aside class="feedback-pane" aria-label="Feedback">
|
|
|
|
|
<div class="section-heading">
|
|
|
|
|
<p class="eyebrow">Feedback</p>
|
|
|
|
|
<h2>Rubric result</h2>
|
|
|
|
|
</div>
|
|
|
|
|
<div id="feedback" class="feedback empty-state">
|
|
|
|
|
Submit an answer to see grade, evidence, and follow-up.
|
|
|
|
|
</div>
|
2026-04-26 18:41:13 +09:00
|
|
|
<div class="section-heading progress-heading">
|
|
|
|
|
<div>
|
|
|
|
|
<p class="eyebrow">Progress</p>
|
|
|
|
|
<h2>Learning state</h2>
|
|
|
|
|
</div>
|
|
|
|
|
<button id="refresh-progress" class="small-button" type="button" disabled>Refresh</button>
|
|
|
|
|
</div>
|
|
|
|
|
<div id="progress" class="feedback empty-state">
|
|
|
|
|
Answer once to update learner memory and readiness.
|
|
|
|
|
</div>
|
2026-04-26 18:39:09 +09:00
|
|
|
</aside>
|
|
|
|
|
</main>
|
|
|
|
|
<script src="/assets/app.js" type="module"></script>
|
|
|
|
|
</body>
|
|
|
|
|
</html>
|