let isRead = true;
let isChoose = true;
let reader = window.speechSynthesis; // 全局定义朗读者,以便朗读和暂停
let current_position = 0; // 朗读文本的当前位置
let original_position = 0; // 朗读文本的初始位置
let to_speak = ""; // 朗读的初始内容

function getWord() {
    return window.getSelection ? window.getSelection() : document.selection.createRange().text;
}

function fillInWord() {
    let word = getWord();
    if (isRead) {read(word);}
    if (!isChoose) {return;}
    const element = document.getElementById("selected-words");
    element.value = element.value + " " + word;
}

document
    .getElementById("text-content")
    .addEventListener("click", fillInWord, false);

function makeUtterance(str, rate) {
    let msg = new SpeechSynthesisUtterance(str);
    msg.rate = rate;
    msg.lang = "en-US"; // TODO: add language options menu
    msg.onboundary = function(ev) {
        if (ev.name === "word") {
            current_position = ev.charIndex;
        }
    };
    return msg;
}

const sliderValue = document.getElementById("rangeValue"); // 显示值
const inputSlider = document.getElementById("rangeComponent"); // 滑块元素
inputSlider.oninput = function(){
    let value = inputSlider.value; // 获取滑块的值
    sliderValue.textContent = value + "×";
    if (!reader.speaking) {return;}
    reader.cancel();
    let msg = makeUtterance(
        to_speak.substring(original_position + current_position),
        value
    );
    original_position = original_position + current_position;
    current_position = 0;
    reader.speak(msg);
};

function read(s) {
    to_speak = s.toString();
    original_position = 0;
    current_position = 0;
    let msg = makeUtterance(to_speak, inputSlider.value);
    reader.speak(msg);
}

function onReadClick() {
    isRead = !isRead;
    if (!isRead) {
        reader.cancel();
    }
}

function onChooseClick() {
    isChoose = !isChoose;
}

function stopRead() {
    reader.cancel();
}