|
|
<!DOCTYPE html> |
|
|
<html lang="ko"> |
|
|
<head> |
|
|
<meta charset="UTF-8"> |
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0"> |
|
|
<title>RAG ์ฑ๋ด - ์ฑํ
</title> |
|
|
<link rel="stylesheet" href="/static/css/style.css"> |
|
|
|
|
|
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="stylesheet"> |
|
|
|
|
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css"> |
|
|
|
|
|
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/styles/github.min.css"> |
|
|
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/marked/4.2.4/marked.min.js"></script> |
|
|
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/dompurify/2.4.1/purify.min.js"></script> |
|
|
</head> |
|
|
<body> |
|
|
<nav class="navbar navbar-expand-lg navbar-dark bg-dark"> |
|
|
<div class="container"> |
|
|
<a class="navbar-brand" href="/"> |
|
|
<i class="fas fa-robot me-2"></i>RAG ์ฑ๋ด |
|
|
</a> |
|
|
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarNav"> |
|
|
<span class="navbar-toggler-icon"></span> |
|
|
</button> |
|
|
<div class="collapse navbar-collapse" id="navbarNav"> |
|
|
<ul class="navbar-nav ms-auto"> |
|
|
<li class="nav-item"> |
|
|
<a class="nav-link" href="/"><i class="fas fa-home me-1"></i>ํ</a> |
|
|
</li> |
|
|
<li class="nav-item"> |
|
|
<a class="nav-link active" href="/chat"><i class="fas fa-comments me-1"></i>์ฑํ
</a> |
|
|
</li> |
|
|
<li class="nav-item"> |
|
|
<a class="nav-link" href="/knowledge"><i class="fas fa-database me-1"></i>์ง์๋ฒ ์ด์ค</a> |
|
|
</li> |
|
|
</ul> |
|
|
</div> |
|
|
</div> |
|
|
</nav> |
|
|
|
|
|
<div class="container mt-4"> |
|
|
<div class="row"> |
|
|
|
|
|
<div class="col-md-8"> |
|
|
<div class="card shadow-sm"> |
|
|
<div class="card-header bg-primary text-white"> |
|
|
<div class="d-flex justify-content-between align-items-center"> |
|
|
<div> |
|
|
<i class="fas fa-comments me-2"></i>์ฑํ
|
|
|
</div> |
|
|
<div> |
|
|
<button id="clearChat" class="btn btn-sm btn-light"> |
|
|
<i class="fas fa-trash me-1"></i>๋ํ ์ง์ฐ๊ธฐ |
|
|
</button> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
<div class="card-body"> |
|
|
<div id="chatMessages" class="chat-messages mb-3"></div> |
|
|
|
|
|
<div class="alert alert-info d-none" id="recordingAlert"> |
|
|
<i class="fas fa-microphone-alt me-2"></i>์์ฑ ๋
น์ ์ค... ํด๋ฆญํ์ฌ ์ค์ง |
|
|
</div> |
|
|
|
|
|
<div class="alert alert-warning d-none" id="processingAlert"> |
|
|
<div class="d-flex align-items-center"> |
|
|
<div class="spinner-border spinner-border-sm me-2" role="status"></div> |
|
|
<div>์์ฑ์ ์ฒ๋ฆฌ ์ค์
๋๋ค. ์ ์๋ง ๊ธฐ๋ค๋ ค์ฃผ์ธ์...</div> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
<div class="alert alert-warning d-none" id="typingAlert"> |
|
|
<div class="d-flex align-items-center"> |
|
|
<div class="spinner-border spinner-border-sm me-2" role="status"></div> |
|
|
<div>๋ต๋ณ์ ์์ฑํ๊ณ ์์ต๋๋ค...</div> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
<div id="chatForm"> |
|
|
<div class="input-group"> |
|
|
<textarea id="userInput" class="form-control" placeholder="์ง๋ฌธ์ ์
๋ ฅํ์ธ์..." rows="2"></textarea> |
|
|
<button type="button" id="micButton" class="btn btn-danger"> |
|
|
<i class="fas fa-microphone"></i> |
|
|
</button> |
|
|
<button type="button" id="sendButton" class="btn btn-primary"> |
|
|
<i class="fas fa-paper-plane"></i> |
|
|
</button> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
|
|
|
<div class="col-md-4"> |
|
|
<div class="card shadow-sm mb-4"> |
|
|
<div class="card-header bg-dark text-white"> |
|
|
<i class="fas fa-cog me-2"></i>์ค์ |
|
|
</div> |
|
|
<div class="card-body"> |
|
|
<div class="mb-3"> |
|
|
<label for="retrieverType" class="form-label">๊ฒ์ ์์ง</label> |
|
|
<select id="retrieverType" class="form-select"> |
|
|
<option value="reranker" selected>์ฌ์์ํ ๊ฒ์</option> |
|
|
<option value="vector">๋ฒกํฐ ๊ฒ์</option> |
|
|
</select> |
|
|
</div> |
|
|
<div class="mb-3"> |
|
|
<label for="topK" class="form-label">์ฐธ๊ณ ๋ฌธ์ ์ (Top-K)</label> |
|
|
<input type="number" class="form-control" id="topK" min="1" max="10" value="3"> |
|
|
</div> |
|
|
<div class="mb-3"> |
|
|
<label for="temperature" class="form-label">๋ค์์ฑ (Temperature)</label> |
|
|
<input type="range" class="form-range" id="temperature" min="0" max="1" step="0.1" value="0.7"> |
|
|
<div class="d-flex justify-content-between"> |
|
|
<small>์ ํ</small> |
|
|
<small id="temperatureValue">0.7</small> |
|
|
<small>์ฐฝ์์ </small> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
<div class="card shadow-sm mb-4"> |
|
|
<div class="card-header bg-dark text-white"> |
|
|
<i class="fas fa-info-circle me-2"></i>์ ๋ณด |
|
|
</div> |
|
|
<div class="card-body"> |
|
|
<h5 class="card-title">์ฌ์ฉ ๋ฐฉ๋ฒ</h5> |
|
|
<ul class="mb-0"> |
|
|
<li>ํ
์คํธ๋ฅผ ์
๋ ฅํ์ฌ ์ง๋ฌธํ๊ฑฐ๋</li> |
|
|
<li>๋ง์ดํฌ ๋ฒํผ์ ํด๋ฆญํ์ฌ ์์ฑ์ผ๋ก ์ง๋ฌธํ ์ ์์ต๋๋ค.</li> |
|
|
<li>VITO STT๋ก ์์ฑ์ด ํ
์คํธ๋ก ๋ณํ๋ฉ๋๋ค.</li> |
|
|
<li>๋ฌธ์๋ฅผ ์ฒจ๋ถํ๋ ค๋ฉด ์ง์๋ฒ ์ด์ค ๋ฉ๋ด๋ฅผ ์ด์ฉํ์ธ์.</li> |
|
|
</ul> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
<div class="card shadow-sm"> |
|
|
<div class="card-header bg-success text-white"> |
|
|
<i class="fas fa-book me-2"></i>์ฐธ๊ณ ๋ฌธ์ |
|
|
</div> |
|
|
<div class="card-body p-0"> |
|
|
<div id="sourceList" class="list-group list-group-flush"> |
|
|
<div class="list-group-item text-center text-muted"> |
|
|
<i>์ฐธ๊ณ ๋ฌธ์๊ฐ ์ฌ๊ธฐ์ ํ์๋ฉ๋๋ค</i> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
<footer class="bg-dark text-white text-center py-3 mt-5"> |
|
|
<div class="container"> |
|
|
<p class="mb-0">RAG ์ฑ๋ด ํด๋ผ์ด์ธํธ © 2025</p> |
|
|
</div> |
|
|
</footer> |
|
|
|
|
|
|
|
|
<template id="userMessageTemplate"> |
|
|
<div class="chat-message user-message mb-3"> |
|
|
<div class="d-flex"> |
|
|
<div class="message-avatar bg-primary text-white"> |
|
|
<i class="fas fa-user"></i> |
|
|
</div> |
|
|
<div class="message-content"> |
|
|
<div class="message-text"></div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</template> |
|
|
|
|
|
<template id="botMessageTemplate"> |
|
|
<div class="chat-message bot-message mb-3"> |
|
|
<div class="d-flex"> |
|
|
<div class="message-avatar bg-success text-white"> |
|
|
<i class="fas fa-robot"></i> |
|
|
</div> |
|
|
<div class="message-content"> |
|
|
<div class="message-text"></div> |
|
|
<div class="message-metadata mt-2 text-muted small"> |
|
|
<span class="message-sources"></span> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</div> |
|
|
</template> |
|
|
|
|
|
|
|
|
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/js/bootstrap.bundle.min.js"></script> |
|
|
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.7.0/highlight.min.js"></script> |
|
|
|
|
|
<script src="/static/js/chat.js"></script> |
|
|
</body> |
|
|
</html> |
|
|
|