create: history generate view
This commit is contained in:
parent
8486ce3c6b
commit
b61eb644d2
|
|
@ -284,6 +284,19 @@
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
|
<li class="nav-item">
|
||||||
|
<div class="row align-items-start">
|
||||||
|
<div class="col-2">
|
||||||
|
<i class="fas fa-history"
|
||||||
|
style="margin-top: 12px; margin-left: 15px; color: #676767;"></i>
|
||||||
|
</div>
|
||||||
|
<div class="col">
|
||||||
|
<a class="nav-link" href="{{ route('literacy_teacher_generate_questions_history') }}"
|
||||||
|
style="color: #34364A;">Generated History</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</li>
|
||||||
|
|
||||||
<li class="nav-item">
|
<li class="nav-item">
|
||||||
<div class="row align-items-start">
|
<div class="row align-items-start">
|
||||||
<div class="col-2">
|
<div class="col-2">
|
||||||
|
|
@ -338,16 +351,43 @@
|
||||||
|
|
||||||
<!-- Form untuk generate question -->
|
<!-- Form untuk generate question -->
|
||||||
<form id="aiForm" class="mt-4">
|
<form id="aiForm" class="mt-4">
|
||||||
|
@csrf
|
||||||
<div class="card mt-2">
|
<div class="card mt-2">
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="material_id" class="form-label">Pilih Materi</label>
|
||||||
|
<select class="form-select" id="material_id" name="material_id" required>
|
||||||
|
<option value="">-- Pilih Materi --</option>
|
||||||
|
@foreach($materials as $material)
|
||||||
|
<option value="{{ $material->id }}">{{ $material->title }}</option>
|
||||||
|
@endforeach
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="question_type" class="form-label">Tipe Soal</label>
|
||||||
|
<select class="form-select" id="question_type" name="question_type" required>
|
||||||
|
<option value="">-- Pilih Tipe Soal --</option>
|
||||||
|
<option value="multiple_choice">Pilihan Ganda</option>
|
||||||
|
<option value="essay">Isian</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="mb-3">
|
||||||
|
<label for="question_count" class="form-label">Jumlah Soal</label>
|
||||||
|
<input type="number" class="form-control" id="question_count"
|
||||||
|
name="question_count" min="1" max="20" value="5" required>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div
|
<div
|
||||||
style="border: 1px solid #ccc; border-radius: 8px; padding: 1rem; background: #f8f9fa; max-height: 300px; overflow-y: auto;">
|
style="border: 1px solid #ccc; border-radius: 8px; padding: 1rem; background: #f8f9fa; max-height: 300px; overflow-y: auto;">
|
||||||
<pre style="margin: 0;">
|
<pre style="margin: 0;">
|
||||||
<code id="content" contenteditable="true" style="white-space: pre-wrap; outline: none;">
|
<code id="content" style="white-space: pre-wrap;">
|
||||||
{{ $latestGeneratedText->generate_text ?? '' }}
|
{{ $latestGeneratedText->generate_text ?? 'Hasil generate soal akan muncul di sini...' }}
|
||||||
</code>
|
</code>
|
||||||
</pre>
|
</pre>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="mt-3">
|
<div class="mt-3">
|
||||||
<button type="submit" class="btn btn-primary">Generate</button>
|
<button type="submit" class="btn btn-primary">Generate</button>
|
||||||
<button type="button" class="btn btn-secondary" id="resetButton">Reset</button>
|
<button type="button" class="btn btn-secondary" id="resetButton">Reset</button>
|
||||||
|
|
@ -411,6 +451,61 @@ class="mt-4">
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
document.addEventListener('DOMContentLoaded', function () {
|
||||||
|
const aiForm = document.getElementById('aiForm');
|
||||||
|
const contentElement = document.getElementById('content');
|
||||||
|
const resetButton = document.getElementById('resetButton');
|
||||||
|
|
||||||
|
aiForm.addEventListener('submit', async function (event) {
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
const formData = new FormData(aiForm);
|
||||||
|
contentElement.innerText = "Menghasilkan pertanyaan...";
|
||||||
|
|
||||||
|
try {
|
||||||
|
let payload = {
|
||||||
|
material_id: document.getElementById('material_id').value,
|
||||||
|
question_type: document.getElementById('question_type').value,
|
||||||
|
question_count: parseInt(document.getElementById('question_count').value)
|
||||||
|
};
|
||||||
|
|
||||||
|
let response = await fetch("{{ route('literacy_teacher_generate_from_ai') }}", {
|
||||||
|
method: "POST",
|
||||||
|
headers: {
|
||||||
|
"Content-Type": "application/json",
|
||||||
|
"X-CSRF-TOKEN": '{{ csrf_token() }}',
|
||||||
|
"Accept": "application/json",
|
||||||
|
},
|
||||||
|
body: JSON.stringify(payload)
|
||||||
|
});
|
||||||
|
|
||||||
|
let data = await response.json();
|
||||||
|
|
||||||
|
if (response.ok) {
|
||||||
|
// Mengubah output untuk menggunakan label yang lebih user-friendly
|
||||||
|
let formattedText = data.generated_questions;
|
||||||
|
if (formattedText) {
|
||||||
|
formattedText = formattedText.replace(/Soal Pilihan Ganda:/g, '**Soal Pilihan Ganda:**');
|
||||||
|
formattedText = formattedText.replace(/Soal Isian:/g, '**Soal Isian:**');
|
||||||
|
}
|
||||||
|
contentElement.innerText = formattedText || "Soal berhasil dibuat, tapi tidak ada data.";
|
||||||
|
} else {
|
||||||
|
contentElement.innerText = "Error: " + (data.message || "Terjadi kesalahan.");
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
contentElement.innerText = "Gagal menghubungi server!";
|
||||||
|
console.error("Error:", error);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
resetButton.addEventListener('click', function () {
|
||||||
|
contentElement.innerText = 'Hasil generate soal akan muncul di sini...';
|
||||||
|
});
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
{{--
|
||||||
<script>
|
<script>
|
||||||
document.addEventListener('DOMContentLoaded', function () {
|
document.addEventListener('DOMContentLoaded', function () {
|
||||||
const aiForm = document.getElementById('aiForm');
|
const aiForm = document.getElementById('aiForm');
|
||||||
|
|
@ -459,7 +554,7 @@ class="mt-4">
|
||||||
contentElement.innerText = ''; // Clear the content
|
contentElement.innerText = ''; // Clear the content
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
</script>
|
</script> --}}
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
document.addEventListener("DOMContentLoaded", function () {
|
document.addEventListener("DOMContentLoaded", function () {
|
||||||
|
|
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
<div class="modal-dialog" role="document">
|
<div class="modal-dialog" role="document">
|
||||||
<div class="modal-content">
|
<div class="modal-content">
|
||||||
<div class="modal-header">
|
<div class="modal-header">
|
||||||
<h5 class="modal-title">Detail Hasil Generated</h5>
|
<h5 class="modal-title">Detail Hasil Generatedd</h5>
|
||||||
<button type="button" class="close" data-dismiss="modal">×</button>
|
<button type="button" class="close" data-dismiss="modal">×</button>
|
||||||
</div>
|
</div>
|
||||||
<div class="modal-body">
|
<div class="modal-body">
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user