fetch('/settings') .then(response => response.text()) .then(html => { document.getElementById('settings').innerHTML = html; backendInput = document.getElementById('backend'); modelInput = document.getElementById('model'); personalityInput = document.getElementById('personalities'); languageInput = document.getElementById('language'); voiceInput = document.getElementById('voice'); seedInput = document.getElementById('seed'); tempInput = document.getElementById('temp'); nPredictInput = document.getElementById('n-predict'); topKInput = document.getElementById('top-k'); topPInput = document.getElementById('top-p'); repeatPenaltyInput = document.getElementById('repeat-penalty'); repeatLastNInput = document.getElementById('repeat-last-n'); temperatureValue = document.getElementById('temperature-value'); n_predictValue = document.getElementById('n-predict-value'); topkValue = document.getElementById('top-k-value'); toppValue = document.getElementById('top-p-value'); repeatPenaltyValue = document.getElementById('repeat-penalty-value'); repeatLastNValue = document.getElementById('repeat-last-n'); tempInput.addEventListener('input',() => { temperatureValue.textContent =`Temperature(${tempInput.value})` }) nPredictInput.addEventListener('input',() => { n_predictValue.textContent =`N Predict(${nPredictInput.value})` }) topKInput.addEventListener('input',() => { topkValue.textContent =`Top-K(${topKInput.value})` }) topPInput.addEventListener('input',() => { toppValue.textContent =`Top-P(${topPInput.value})` }) repeatPenaltyInput.addEventListener('input',() => { repeatPenaltyValue.textContent =`Repeat penalty(${repeatPenaltyInput.value})` }) repeatLastNInput.addEventListener('input',() => { repeatLastNValue.textContent =`Repeat last N(${repeatLastNInput.value})` }) fetch('/get_config') .then((response) => response.json()) .then((data) => { console.log(data); backendInput.value = data["backend"] modelInput.value = data["model"] personalityInput.value = data["personality"] languageInput.value = data["language"] voiceInput.value = data["voice"] seedInput.value = data["seed"] tempInput.value = data["temp"] nPredictInput.value = data["n_predict"] topKInput.value = data["top_k"] topPInput.value = data["top_p"] repeatPenaltyInput.textContent = data["repeat_penalty"] repeatLastNInput.textContent = data["repeat_last_n"] temperatureValue.textContent =`Temperature(${data["temp"]})` n_predictValue.textContent =`N Predict(${data["n_predict"]})` topkValue.textContent =`Top-K(${data["top_k"]})` toppValue.textContent =`Top-P(${data["top_p"]})` repeatPenaltyValue.textContent =`Repeat penalty(${data["repeat_penalty"]})` repeatLastNValue.textContent =`Repeat last N(${data["repeat_last_n"]})` }) .catch((error) => { console.error('Error:', error); }); const submitButton = document.getElementById('submit-model-params'); submitButton.addEventListener('click', (event) => { // Prevent default form submission event.preventDefault(); // Get form values and put them in an object const formValues = { seed: seedInput.value, backend: backendInput.value, model: modelInput.value, personality: personalityInput.value, language: languageInput.value, voice: voiceInput.value, temp: tempInput.value, nPredict: nPredictInput.value, topK: topKInput.value, topP: topPInput.value, repeatPenalty: repeatPenaltyInput.value, repeatLastN: repeatLastNInput.value }; console.log(formValues); // Use fetch to send form values to Flask endpoint fetch('/update_model_params', { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify(formValues), }) .then((response) => response.json()) .then((data) => { console.log(data); alert("Configuration set successfully") }) .catch((error) => { console.error('Error:', error); alert("Error setting configuration") }); }); }) .catch(error => { console.error('Error loading settings page:', error); }); function populate_models(){ // Get a reference to the