view src/chat.js @ 12:2d4b3f003ec2

tts
author Franklin Schmidt <fschmidt@gmail.com>
date Thu, 24 Jul 2025 22:14:49 -0600
parents 003a90ce72d7
children 65bd7e245c63
line wrap: on
line source

'use strict';

function openRenameChat(name) {
	let dialog = document.querySelector('dialog[rename]');
	dialog.querySelector('input[name=name]').value = name;
	dialog.showModal();
}

function renameChat() {
	ajax(`rename_chat.js?chat=${chatId}`);
}

function saveRenameChat() {
	let dialog = document.querySelector('dialog[rename]');
	let name = dialog.querySelector('input[name=name]').value;
	ajax(`save_rename_chat.js?chat=${chatId}&name=${encodeURIComponent(name)}`);
	dialog.close();
}

function deleteChat() {
	let dialog = document.querySelector('dialog[delete]');
	dialog.showModal();
}

function doDeleteChat(el) {
	closeModal(el);
	ajax(`delete_chat.js?chat=${chatId}`);
}

function systemPrompt() {
	let dialog = document.querySelector('dialog[system_prompt]');
	dialog.showModal();
}

function showWaitingAiIcon() {
	document.querySelector('[waiting-ai-icon]').style.display = 'block';
}

function hideWaitingAiIcon() {
	document.querySelector('[waiting-ai-icon]').style.display = 'none';
}

function updateAi(html) {
	hideWaitingAiIcon();
	document.querySelector('div[messages]').innerHTML = html;
	handleMarkdown();
	document.querySelector('textarea').focus();
	window.scrollTo(0, document.body.scrollHeight);
/*
	let scroll = aiDialog.querySelector('[scroll]');
	setTimeout(function(){
		scroll.scrollTo(0,scroll.scrollHeight);
	});
*/
	let audios = document.querySelectorAll('audio');
	if( audios.length >= 1 ) {
		let audio = audios[audios.length-1];
		audio.play();
	}
}

const isMobile = 'ontouchstart' in window || navigator.maxTouchPoints > 0 || navigator.msMaxTouchPoints > 0;

function textareaKey(event) {
	if( event.keyCode===13 && !event.shiftKey && !event.ctrlKey && !isMobile ) {
		event.preventDefault();
		askAi();
	}
}

function fixTextarea(textarea) {
	textarea.style.height = 'initial';
	textarea.style.height = (textarea.scrollHeight+2) + 'px';
	textarea.scrollIntoViewIfNeeded(false);
}

function askAi() {
	let input = document.querySelector('textarea');
	let url = `ai_ask.js?chat=${chatId}&input=${encodeURIComponent(input.value)}`;
	ajax(url);
	input.value = '';
	fixTextarea(input);
	showWaitingAiIcon();
}