You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

1107 lines
153 KiB

//Criar uma funcao anonima para nao ser acessivel ao client
const KeypadSimplesIP = (function () {
// Função para verificar e definir o tema inicial
const initialThemeMode = sessionStorage.getItem("themeMode") || "light";
const simplesipStateCall = (initialStateCall) => {
let stateCall = initialStateCall;
function getStateCall() {
return stateCall;
}
function setStateCall(newStateCall) {
stateCall = newStateCall;
loadThemeMode();
updateUI();
return stateCall;
}
return { getStateCall, setStateCall };
};
//definir os states para cada fase da chamada do keypad
const stateCurrent = simplesipStateCall("home");
const simplesipButtons = [
"1",
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
"*",
"0",
"#",
];
//Listeners para testes==============================================
document.addEventListener("DOMContentLoaded", function () {
document.getElementById("home").addEventListener("click", () => {
stateCurrent.setStateCall("home");
});
document.getElementById("outgoingcall").addEventListener("click", () => {
stateCurrent.setStateCall("outgoingcall");
});
document.getElementById("incall").addEventListener("click", () => {
stateCurrent.setStateCall("incall");
});
document.getElementById("incomingcall").addEventListener("click", () => {
stateCurrent.setStateCall("incomingcall");
});
document.getElementById("online").addEventListener("click", () => {
defineStatusAgent("online");
});
document.getElementById("busy").addEventListener("click", () => {
defineStatusAgent("busy");
});
document.getElementById("away").addEventListener("click", () => {
defineStatusAgent("away");
});
});
//==================================================================
//RECEBENDO CHAMADA
let otherNumber = "Indefinido";
UASimplesIP.simplesipEvento.on("incomingcall", function (callerNumber) {
if (otherNumber) {
otherNumber = callerNumber;
}
stateCurrent.setStateCall("incomingcall");
});
//FAZENDO CHAMADA
UASimplesIP.simplesipEvento.on("outgoingcall", function (callerNumber) {
if (otherNumber) {
otherNumber = callerNumber;
}
stateCurrent.setStateCall("outgoingcall");
});
//EM CHAMADA
UASimplesIP.simplesipEvento.on("incall", function () {
stateCurrent.setStateCall("incall");
});
//NA HOME
UASimplesIP.simplesipEvento.on("confirmedEnded", function () {
stateCurrent.setStateCall("home");
});
UASimplesIP.simplesipEvento.on("home", function () {
stateCurrent.setStateCall("home");
});
//==================================================================
const simplesipCreateContainer = (themeMode) => {
let simplesipContainer = document.querySelector(".simplesipContainer");
// Verifica se já existe um container, e se existir, remove-o
if (simplesipContainer) {
simplesipContainer.remove();
}
simplesipContainer = document.createElement("div");
simplesipContainer.classList.add("simplesipContainer");
simplesipContainer.classList.add(themeMode);
simplesipContainer.id = "simplesipContainer";
simplesipCreateTitles(simplesipContainer, themeMode);
updateUI = function () {
const currentStateCall = stateCurrent.getStateCall();
document.addEventListener("keydown", handleKeyPress); // Ao
//cada vez que irei atualizar a tela eu devo remover todo o html do filho
// e só assim posso estar criando uma nova tela, para n gerar conflitos e bugs
let titles = document.querySelector(".simplesipTitles");
if (titles) {
// Remover todos os próximos irmãos de titles
let proximoIrmao = titles.nextSibling;
while (proximoIrmao) {
let irmaoRemovido = proximoIrmao;
proximoIrmao = proximoIrmao.nextSibling;
irmaoRemovido.parentNode.removeChild(irmaoRemovido);
}
}
switch (currentStateCall) {
case "home":
simplesipCreateKeypad(simplesipContainer, themeMode);
break;
case "outgoingcall":
simplesipCreateOutgoingCall(simplesipContainer, themeMode);
break;
case "incomingcall":
simplesipCreateIncomingCall(simplesipContainer, themeMode);
break;
case "incall":
simplesipCreateInCall(simplesipContainer, themeMode);
restartTimer();
startTimer();
break;
case "config":
simplesipCreateConfigScreen(simplesipContainer, themeMode);
break;
default:
simplesipCreateKeypad(simplesipContainer, themeMode);
break;
}
document.body.appendChild(simplesipContainer);
defineStatusAgent(currentStatus); //sempre atualiza o status do agente ao mudar de tela
};
updateUI();
return { simplesipCreateContainer };
};
const simplesipCreateConfigScreen = (container, themeMode) => {
document.removeEventListener("keydown", handleKeyPress);
const configScreen = document.createElement("div");
configScreen.classList.add("configScreen");
configScreen.classList.add(themeMode);
configScreen.id = "configScreen";
const titleConfig = document.createElement("div");
titleConfig.id = "titleConfig";
titleConfig.textContent = "Configurações do usuário";
const formScreen = document.createElement("form");
formScreen.id = "form";
formScreen.method = "post";
formScreen.action = "";
const btnSave = document.createElement("button");
btnSave.classList.add("animationHover");
btnSave.id = "btnSave";
btnSave.type = "submit";
btnSave.textContent = "Conectar";
const btnCancel = document.createElement("button");
btnCancel.classList.add("animationHover");
btnCancel.id = "btnCancel";
btnCancel.type = "button";
btnCancel.textContent = "Cancelar";
btnCancel.addEventListener("click", () => {
stateCurrent.setStateCall("home");
});
const divDados = document.createElement("div");
divDados.classList.add("divDados");
const divUnregister = document.createElement("div");
divUnregister.classList.add("divUnregister");
const textoUnregister = document.createElement("p");
textoUnregister.textContent = "Apagar ramal";
const unregisterBtn = document.createElement("button");
unregisterBtn.id = "unregister";
unregisterBtn.addEventListener("click", () => {
inputServidor.querySelector("input").value = "";
inputPorta.querySelector("input").value = "";
inputNome.querySelector("input").value = "";
inputRamal.querySelector("input").value = "";
inputSenha.querySelector("input").value = "";
UASimplesIP.config.NOME = "";
UASimplesIP.config.PORTA = "";
UASimplesIP.config.SENHA = "";
UASimplesIP.config.SERVIDOR = "";
UASimplesIP.config.RAMAL = "";
localStorage.clear();
currentStatus = "unknown";
stateCurrent.setStateCall("home");
UASimplesIP.unregister();
});
divUnregister.appendChild(textoUnregister);
divUnregister.appendChild(unregisterBtn);
// Função para criar elementos <label> com suas respectivas legendas
const createLabelAndInput = (
labelText,
inputName,
inputType,
placeholder
) => {
const label = document.createElement("label");
label.textContent = labelText;
const input = document.createElement("input");
input.name = inputName;
input.type = inputType;
input.placeholder = placeholder;
const divInputGroup = document.createElement("div");
divInputGroup.classList.add("input-group");
divInputGroup.appendChild(label);
divInputGroup.appendChild(input);
return divInputGroup;
};
// Criar inputs com suas respectivas legendas
const inputServidor = createLabelAndInput(
"Servidor*",
"servidor",
"text",
"0.0.0.0"
);
const inputPorta = createLabelAndInput("Porta", "porta", "text", "8088");
const inputNome = createLabelAndInput(
"Nome",
"nome",
"text",
"Insira o nome do agente"
);
const inputRamal = createLabelAndInput(
"Ramal*",
"ramal",
"text",
"Insira o ramal do agente"
);
const inputSenha = createLabelAndInput(
"Senha*",
"senha",
"password",
"Insira a senha do ramal"
);
// Adicionar botões ao formulário
const divBtns = document.createElement("div");
divBtns.classList.add("divBtns");
divBtns.appendChild(btnCancel);
divBtns.appendChild(btnSave);
divDados.appendChild(inputServidor);
divDados.appendChild(inputPorta);
divDados.appendChild(inputNome);
divDados.appendChild(inputRamal);
divDados.appendChild(inputSenha);
configScreen.appendChild(titleConfig);
configScreen.appendChild(divUnregister);
formScreen.appendChild(divDados);
formScreen.appendChild(divBtns);
configScreen.appendChild(formScreen);
container.appendChild(configScreen);
// Função para preencher os inputs com os valores do localStorage
const fillInputsFromLocalStorage = () => {
inputServidor.querySelector("input").value =
localStorage.getItem("servidor") || "";
inputPorta.querySelector("input").value =
localStorage.getItem("porta") || "";
inputNome.querySelector("input").value =
localStorage.getItem("nome") || "";
inputRamal.querySelector("input").value =
localStorage.getItem("ramal") || "";
inputSenha.querySelector("input").value =
localStorage.getItem("senha") || "";
};
// Preencha os inputs com os valores armazenados no localStorage
fillInputsFromLocalStorage();
// Adicione um ouvinte de eventos para o evento submit do formulário
formScreen.addEventListener("submit", function (event) {
event.preventDefault(); // Evita que o formulário seja enviado normalmente
// Coleta os valores dos inputs
const servidor = inputServidor.querySelector("input").value;
const porta = inputPorta.querySelector("input").value;
const nome = inputNome.querySelector("input").value;
const ramal = inputRamal.querySelector("input").value;
const senha = inputSenha.querySelector("input").value;
// Armazena os valores no localStorage
localStorage.setItem("servidor", servidor);
localStorage.setItem("porta", porta);
localStorage.setItem("nome", nome);
localStorage.setItem("ramal", ramal);
localStorage.setItem("senha", senha);
// Salva primeiramente os valores nas configurações do agente
UASimplesIP.config.PROTOCOLO = "ws";
UASimplesIP.config.SERVIDOR = servidor;
UASimplesIP.config.PORTA = porta;
UASimplesIP.config.NOME = nome;
UASimplesIP.config.RAMAL = ramal;
UASimplesIP.config.SENHA = senha;
if (servidor === "" || ramal === "" || senha === "") {
simplesipCreateAlert(
container,
"Por favor, insira os dados necessários"
);
} else {
stateCurrent.setStateCall("home");
UASimplesIP.start();
}
});
};
// Variável para controlar se uma tela de alerta já está sendo exibida
let isAlertDisplayed = false;
const simplesipCreateAlert = (container, message) => {
// Verifica se uma tela de alerta já está sendo exibida
if (isAlertDisplayed) {
return; // Sai da função se uma tela de alerta já estiver sendo exibida
}
const createAlert = document.createElement("div");
createAlert.classList.add("alertScreen");
const iconAlert = document.createElement("img");
iconAlert.src = alertImg;
const textAlert = document.createElement("p");
textAlert.textContent = message;
createAlert.appendChild(iconAlert);
createAlert.appendChild(textAlert);
const btnAlert = document.createElement("button");
btnAlert.id = "btnAlert";
btnAlert.textContent = "OK";
btnAlert.addEventListener("click", () => {
// Remove a tela de alerta ao clicar no botão "OK"
container.removeChild(createAlert);
// Atualiza a variável para indicar que a tela de alerta foi removida
isAlertDisplayed = false;
});
createAlert.appendChild(btnAlert);
// Adiciona a tela de alerta ao contêiner
container.appendChild(createAlert);
// Atualiza a variável para indicar que uma tela de alerta está sendo exibida
isAlertDisplayed = true;
};
const simplesipCreateInCall = (container, themeMode) => {
const simplesipInCall = document.createElement("div");
simplesipInCall.classList.add("simplesipInCall");
simplesipInCall.classList.add(themeMode);
simplesipInCall.id = "simplesipInCall";
//Adiciona o numero que ligou ao display
const bnEndCall = createButtonEndCall(handleEndCall);
const bnMute = createButtonMute(handleMute);
const bnKeypad = createButtonKeypad(handleKeypad);
const bnTransfer = createButtonTransfer(handleTransfer);
const keyPadIncall = createKeypadIncall();
//Configura outro display pra mostrar com quem está falando
const displayOtherNumber = document.createElement("div");
const userIcon = document.createElement("img");
userIcon.src = userImg;
userIcon.width = 20;
userIcon.height = 20;
displayOtherNumber.appendChild(userIcon);
displayOtherNumber.classList.add("displayOtherNumber");
displayOtherNumber.id = "displayOtherNumber";
displayOtherNumber.appendChild(userIcon);
const otherNumberText = document.createElement("span");
otherNumberText.textContent = otherNumber;
displayOtherNumber.appendChild(otherNumberText);
//Cria display que mostra todas as opções da chamada
const displayInCall = document.createElement("div");
displayInCall.classList.add("displayInCall");
displayInCall.id = "displayInCall";
displayInCall.appendChild(bnMute);
displayInCall.appendChild(bnKeypad);
displayInCall.appendChild(bnTransfer);
displayInCall.appendChild(bnEndCall);
simplesipCreateDisplayContainer(container, themeMode);
const display = document.getElementById("displayContainer");
simplesipInCall.appendChild(displayOtherNumber);
simplesipCreateTimer(simplesipInCall);
simplesipInCall.appendChild(keyPadIncall);
simplesipInCall.appendChild(displayInCall);
container.appendChild(simplesipInCall);
//classe adicionada para adaptar o display durante a ligação
display.classList.add("incallDisplay");
};
const createKeypadIncall = () => {
const keyPadIncall = document.createElement("div");
keyPadIncall.classList.add("keyPadIncall");
keyPadIncall.id = "keyPadIncall";
simplesipButtons.forEach((element) => {
const simplesipButton = document.createElement("button");
simplesipButton.textContent = element;
simplesipButton.classList.add("simplesip-bn");
simplesipButton.addEventListener("click", () => handleClick(element));
keyPadIncall.appendChild(simplesipButton);
});
return keyPadIncall;
};
const createButtonKeypad = (event) => {
const buttonKeypad = document.createElement("button");
buttonKeypad.classList.add("buttonKeypad");
buttonKeypad.id = "buttonKeypad";
const buttonKeypadImg = document.createElement("img");
buttonKeypadImg.src = keypadImg;
buttonKeypadImg.width = 30;
buttonKeypadImg.height = 30;
buttonKeypad.appendChild(buttonKeypadImg);
buttonKeypad.addEventListener("click", () => {
event();
});
return buttonKeypad;
};
const createButtonTransfer = (event) => {
const buttonTransfer = document.createElement("button");
buttonTransfer.classList.add("transfer");
buttonTransfer.id = "transfer";
const buttonTransferImg = document.createElement("img");
buttonTransferImg.src = transferImg;
buttonTransferImg.width = 30;
buttonTransferImg.height = 30;
buttonTransfer.appendChild(buttonTransferImg);
buttonTransfer.addEventListener("click", () => {
event();
});
return buttonTransfer;
};
const createButtonMute = (event) => {
const buttonMute = document.createElement("button");
buttonMute.classList.add("mute");
buttonMute.id = "mute";
const buttonMuteImg = document.createElement("img");
buttonMuteImg.src = muteImg;
buttonMuteImg.width = 30;
buttonMuteImg.height = 30;
buttonMute.appendChild(buttonMuteImg);
buttonMute.addEventListener("click", () => {
event();
});
return buttonMute;
};
const createButtonEndCall = (event) => {
const buttonEndCall = document.createElement("button");
buttonEndCall.classList.add("endCall");
buttonEndCall.classList.add("animationHover");
buttonEndCall.id = "endCall";
const buttonEndCallImg = document.createElement("img");
buttonEndCallImg.src = rejeitarChamadaImg;
buttonEndCallImg.width = 30;
buttonEndCallImg.height = 30;
buttonEndCall.appendChild(buttonEndCallImg);
buttonEndCall.addEventListener("click", () => {
event();
});
return buttonEndCall;
};
const createButtonCall = (event) => {
const simplesipButtonTelephone = document.createElement("button");
simplesipButtonTelephone.classList.add("telephone");
simplesipButtonTelephone.classList.add("animationHover");
simplesipButtonTelephone.id = "telephone";
simplesipButtonTelephone.addEventListener("click", () => {
event();
});
const simplesipButtonTelephoneImg = document.createElement("img");
simplesipButtonTelephoneImg.src = fazerChamadaImg;
simplesipButtonTelephoneImg.width = 30;
simplesipButtonTelephoneImg.height = 30;
simplesipButtonTelephone.appendChild(simplesipButtonTelephoneImg);
return simplesipButtonTelephone;
};
const simplesipCreateIncomingCall = (container, themeMode) => {
const numberIncomingCall = document.createElement("div");
numberIncomingCall.classList.add("numberIncomingCall");
numberIncomingCall.classList.add(themeMode);
numberIncomingCall.id = "numberIncomingCall";
numberIncomingCall.textContent = "Recebendo chamada de " + otherNumber;
container.appendChild(numberIncomingCall);
const simplesipIncomingCall = document.createElement("div");
simplesipIncomingCall.classList.add("simplesipIncomingCall");
simplesipIncomingCall.classList.add(themeMode);
simplesipIncomingCall.id = "simplesipIncomingCall";
const bnAcceptCall = createButtonCall(handleAcceptCall);
const bnEndCall = createButtonEndCall(handleRejectCall);
bnAcceptCall.style.gridColumn = 1;
bnAcceptCall.style.animation = "pulse 1s infinite ease-in-out";
bnEndCall.style.gridColumn = 2;
bnEndCall.style.animation = "pulse 1s infinite ease-in-out";
simplesipIncomingCall.appendChild(bnAcceptCall);
simplesipIncomingCall.appendChild(bnEndCall);
container.appendChild(simplesipIncomingCall);
};
const simplesipCreateOutgoingCall = (container, themeMode) => {
document.removeEventListener("keydown", handleKeyPress);
const numberOutgoingCall = document.createElement("div");
numberOutgoingCall.classList.add("numberOutgoingCall");
numberOutgoingCall.classList.add(themeMode);
numberOutgoingCall.id = "numberOutgoingCall";
if (storedNumberCall != "") {
numberOutgoingCall.textContent = "Ligando para " + storedNumberCall;
} else {
numberOutgoingCall.textContent = "Digite um número e tente novamente";
}
container.appendChild(numberOutgoingCall);
const simplesipOutgoingCall = document.createElement("div");
simplesipOutgoingCall.classList.add("simplesipOutgoingCall");
simplesipOutgoingCall.classList.add(themeMode);
simplesipOutgoingCall.id = "simplesipOutgoingCall";
const bnEndCall = createButtonEndCall(handleEndCall);
bnEndCall.classList.add("animationHover");
bnEndCall.style.gridColumn = 2;
simplesipOutgoingCall.appendChild(bnEndCall);
container.appendChild(simplesipOutgoingCall);
};
let storedNumberCall = "";
const handleCall = () => {
const container = document.getElementById("simplesipContainer");
const numberCall = document.getElementById("display").textContent;
if (numberCall !== "") {
storedNumberCall = numberCall;
UASimplesIP.simplesipEvento.on("error", function () {
simplesipCreateAlert(
container,
"Conecte-se a um ramal antes de fazer uma chamada"
);
});
UASimplesIP.realizaUmaChamada(storedNumberCall);
} else {
//manda o usuario para mensagem de que precisa inserir um numero
stateCurrent.setStateCall("outgoingcall");
}
};
function handleEndCall() {
UASimplesIP.simplesipEvento.emit("endCall");
storedNumberCall = "";
stateCurrent.setStateCall("home");
}
function handleAcceptCall() {
UASimplesIP.simplesipEvento.emit("accepted");
}
function handleRejectCall() {
UASimplesIP.simplesipEvento.emit("rejected");
stateCurrent.setStateCall("home");
}
let keypadVisible = false;
function handleKeypad() {
UASimplesIP.simplesipEvento.emit("");
if (keypadVisible) {
document.getElementById("keyPadIncall").style.visibility = "hidden";
keypadVisible = false;
document.removeEventListener("keydown", handleKeyPress);
} else {
document.getElementById("keyPadIncall").style.visibility = "visible";
keypadVisible = true;
document.addEventListener("keydown", handleKeyPress);
}
}
function handleTransfer() {
UASimplesIP.simplesipEvento.emit("");
}
function handleMute() {
UASimplesIP.simplesipEvento.emit("mute");
document.getElementById("mute").children[0].src = unmuteImg;
document.getElementById("mute").removeEventListener("click", handleMute);
document.getElementById("mute").addEventListener("click", handleUnmute);
}
function handleUnmute() {
UASimplesIP.simplesipEvento.emit("unmute");
document.getElementById("mute").children[0].src = muteImg;
document.getElementById("mute").removeEventListener("click", handleUnmute);
document.getElementById("mute").addEventListener("click", handleMute);
}
const simplesipCreateDisplayContainer = (header, themeMode) => {
const simplesipDisplayContainer = document.createElement("div");
simplesipDisplayContainer.classList.add("displayContainer");
simplesipDisplayContainer.classList.add(themeMode);
simplesipDisplayContainer.id = "displayContainer";
//add display ao container
simplesipCreateDisplay(simplesipDisplayContainer, themeMode);
simplesipCreateClearDisplay(simplesipDisplayContainer, themeMode);
header.appendChild(simplesipDisplayContainer);
};
const simplesipCreateClearDisplay = (header, themeMode) => {
const simplesipClearDisplay = document.createElement("div");
simplesipClearDisplay.id = "clearDisplay";
const clearDisplayImg = document.createElement("img");
clearDisplayImg.id = "clearDisplayImg";
clearDisplayImg.src =
themeMode === "dark" ? limparDisplayLightImg : limparDisplayDarkImg;
clearDisplayImg.width = 30;
clearDisplayImg.height = 30;
simplesipClearDisplay.addEventListener("click", () => {
clearDisplay();
haveTextAndClearDisplay(display);
});
simplesipClearDisplay.addEventListener("mousedown", function () {
press = true;
setTimeout(function () {
if (press) {
clearDisplay().clearAll();
}
}, 1400);
});
simplesipClearDisplay.addEventListener("mouseup", function () {
press = false;
});
simplesipClearDisplay.appendChild(clearDisplayImg);
header.appendChild(simplesipClearDisplay);
};
// Função para lidar com cliques nos botões
const handleClick = (buttonValue) => {
const display = document.getElementById("display");
const maxLength = 11;
if (display.innerText.length <= maxLength) {
display.append(buttonValue);
if (stateCurrent.getStateCall() === "incall") {
UASimplesIP.simplesipEvento.emit("sendDTMF", buttonValue);
}
}
//chama funcao para verificar se tem texto e exibir botao clear
haveTextAndClearDisplay(display);
};
function haveTextAndClearDisplay(display) {
const haveText = display.textContent;
const clearDisplay = document.getElementById("clearDisplay");
if (haveText.length == 1) {
clearDisplay.style.display = "flex";
clearDisplay.style.opacity = 1;
clearDisplay.style.transition = "opacity 0.3s ease";
clearDisplay.style.cursor = "pointer";
} else if (haveText.length == 0) {
clearDisplay.style.display = "flex";
clearDisplay.style.opacity = 0;
clearDisplay.style.cursor = "";
}
}
const clearDisplay = () => {
const display = document.getElementById("display");
const currentContent = display.textContent;
const newContent = currentContent.slice(0, -1);
display.innerText = newContent;
function clearAll() {
display.innerText = "";
}
return { clearAll };
};
const simplesipCreateHead = (container, themeMode) => {
const simplesipHead = document.createElement("div");
simplesipHead.classList.add("simplesipHead");
simplesipHead.classList.add(themeMode);
simplesipHead.id = "simplesipHead";
//add agentLocal display
simplesipCreateLocalAgentDisplay(simplesipHead);
simplesipCreateDisplayContainer(simplesipHead, themeMode);
container.appendChild(simplesipHead);
};
var currentStatus = "unknown";
// Ouvindo o evento 'statusChange' emitido pelo JSSIP
UASimplesIP.simplesipEvento.on("statusChange", (newStatus) => {
currentStatus = newStatus;
defineStatusAgent(currentStatus);
});
const defineStatusAgent = (status) => {
const circleElements = document.querySelectorAll(".circle");
// Verifica se circleElements não é undefined e se tem comprimento maior que zero
if (circleElements && circleElements.length > 0) {
// Remove qualquer uma dessas classes antes de atualizar
circleElements.forEach((circle) =>
circle.classList.remove("online", "away", "busy", "unknown", "error")
);
// Atualiza conforme o parâmetro passado
switch (status) {
case "registered":
if (circleElements[0]) {
circleElements[0].classList.add("online");
}
break;
case "registrationFailed":
if (circleElements[0]) {
circleElements[0].classList.add("busy");
}
break;
case "unregistered":
if (circleElements[0]) {
circleElements[0].classList.add("unknown");
}
break;
default:
circleElements[0].classList.add("default");
break;
}
}
};
const simplesipCreateLocalAgentDisplay = (header) => {
const agentLocalDisplay = document.createElement("div");
agentLocalDisplay.id = "agentLocalDisplay";
const statusAgent = document.createElement("div");
statusAgent.classList.add("statusAgent");
const nameAgent = document.createElement("div");
nameAgent.id = "agentName";
const defaultCircle = document.createElement("div");
defaultCircle.classList.add("circle");
//add o circulo de status
statusAgent.appendChild(defaultCircle);
agentLocalDisplay.appendChild(statusAgent);
//add name agent
nameAgent.textContent = UASimplesIP.config.NOME
? UASimplesIP.config.NOME
: "Agente";
agentLocalDisplay.appendChild(nameAgent);
header.appendChild(agentLocalDisplay);
};
const simplesipCreateTitles = (container, themeMode) => {
const simplesipTitle = document.createElement("div");
simplesipTitle.classList.add("simplesipTitles");
simplesipTitle.classList.add(themeMode);
simplesipTitle.id = "simplesipTitles";
//add logo da simplesip
simplesipCreateLogo(simplesipTitle);
container.appendChild(simplesipTitle);
};
const simplesipCreateThemeButton = (titles) => {
const themeMode = document.createElement("div");
themeMode.classList.add("themeMode");
themeMode.classList.add("animationHover");
themeMode.id = "themeMode";
const themeModeImg = document.createElement("img");
themeModeImg.src = darkModeImg;
themeMode.appendChild(themeModeImg);
themeMode.addEventListener("click", () => {
toggleThemeMode();
});
titles.appendChild(themeMode);
};
const simplesipCreateConfigButton = (titles) => {
const configBtn = document.createElement("div");
configBtn.classList.add("configBtn");
configBtn.classList.add("animationHover");
configBtn.id = "configBtn";
const configBtnImg = document.createElement("img");
configBtnImg.src = engrenagem;
configBtn.appendChild(configBtnImg);
configBtn.addEventListener("click", () => {
handleConfigBtn();
});
titles.appendChild(configBtn);
};
const simplesipCreateLogo = (titles) => {
const simplesipLogo = document.createElement("img");
simplesipLogo.alt = "Logo da SimplesIP";
simplesipLogo.src = logoSimplesImg;
simplesipLogo.width = 30;
simplesipLogo.height = 30;
//add titulo da simplesip
const titulo = document.createElement("p");
titulo.textContent = "Simples IP Softphone";
const divLogo = document.createElement("div");
divLogo.classList.add("divLogo");
divLogo.appendChild(simplesipLogo);
divLogo.appendChild(titulo);
titles.appendChild(divLogo);
simplesipCreateThemeButton(titles);
simplesipCreateConfigButton(titles);
simplesipCreateMinimize(titles);
};
function handleConfigBtn() {
stateCurrent.setStateCall("config");
}
function toggleThemeMode() {
const elementosDoKeyPad = document.querySelectorAll(
"#simplesipContainer *"
);
elementosDoKeyPad.forEach(function (elemento) {
if (elemento.classList.contains("light")) {
const clearDisplayImg = document.getElementById("clearDisplayImg");
if (clearDisplayImg) {
clearDisplayImg.src = limparDisplayLightImg;
}
elemento.classList.replace("light", "dark");
} else if (elemento.classList.contains("dark")) {
const clearDisplayImg = document.getElementById("clearDisplayImg");
if (clearDisplayImg) {
clearDisplayImg.src = limparDisplayDarkImg;
}
elemento.classList.replace("dark", "light");
}
});
const simplesipContainer = document.querySelector("#simplesipContainer");
simplesipContainer.classList.toggle("light");
simplesipContainer.classList.toggle("dark");
let isDarkMode = document
.querySelector("#simplesipContainer")
.classList.contains("dark");
sessionStorage.setItem("themeMode", isDarkMode ? "dark" : "light");
location.reload(false);
}
const loadThemeMode = () => {
const themeMode = sessionStorage.getItem("themeMode");
const simplesipContainer = document.querySelector("#simplesipContainer");
if (themeMode === "dark") {
simplesipContainer.classList.add("dark");
simplesipContainer.classList.remove("light");
} else {
simplesipContainer.classList.add("light");
simplesipContainer.classList.remove("dark");
}
// Aplicar o tema apenas onde há uma classe light ou dark
const elementosComClasse = document.querySelectorAll(
"#simplesipContainer .light, #simplesipContainer .dark"
);
elementosComClasse.forEach(function (elemento) {
if (themeMode === "dark") {
elemento.classList.add("dark");
elemento.classList.remove("light");
} else {
elemento.classList.add("light");
elemento.classList.remove("dark");
}
});
};
const simplesipCreateMinimize = (titles) => {
//add button
const simplesipMinimize = document.createElement("button");
simplesipMinimize.classList.add("btn-minimize");
simplesipMinimize.id = "btn-minimize";
simplesipMinimize.addEventListener("click", handleMinimize);
titles.appendChild(simplesipMinimize);
};
let isKeyPadMinimized = false;
const handleMinimize = () => {
let nextElement =
document.getElementById("simplesipTitles").nextElementSibling;
let nextElementId = "";
let content = "";
while (nextElement !== null) {
nextElementId = nextElement.id;
content = document.getElementById(nextElementId);
content.style.display = isKeyPadMinimized ? "" : "none";
nextElement = nextElement.nextElementSibling;
}
const btnMinimize = document.getElementById("btn-minimize");
isKeyPadMinimized = !isKeyPadMinimized; // Inverter a variável aqui
if (isKeyPadMinimized) {
btnMinimize.classList.remove("btn-minimize");
btnMinimize.classList.add("btn-expand");
document.removeEventListener("keydown", handleKeyPress);
} else {
btnMinimize.classList.remove("btn-expand");
btnMinimize.classList.add("btn-minimize");
document.addEventListener("keydown", handleKeyPress);
}
};
const simplesipCreateDisplay = (header, themeMode) => {
const simplesipDisplay = document.createElement("div");
simplesipDisplay.id = "display";
simplesipDisplay.classList.add("display");
simplesipDisplay.classList.add(themeMode);
header.appendChild(simplesipDisplay);
};
const simplesipCreateTimer = (header) => {
const simplesipTimer = document.createElement("div");
simplesipTimer.classList.add("timer");
simplesipTimer.id = "timer";
simplesipTimer.textContent = "00:00:00";
header.appendChild(simplesipTimer);
};
let segundos = 0;
let minutos = 0;
let horas = 0;
let timer;
function startTimer() {
if (!timer) {
// Verifica se o timer já está em execução
timer = setInterval(attTimer, 1000);
}
}
function restartTimer() {
if (timer) {
clearInterval(timer);
segundos = 0;
minutos = 0;
horas = 0;
document.getElementById("timer").textContent = "00:00:00";
timer = null;
}
}
function stopTimer() {
clearInterval(timer);
}
function attTimer() {
segundos++;
if (segundos >= 60) {
segundos = 0;
minutos++;
if (minutos >= 60) {
minutos = 0;
horas++;
}
}
const formatado = pad(horas) + ":" + pad(minutos) + ":" + pad(segundos);
let timer = document.getElementById("timer");
if (timer) {
timer.textContent = formatado;
}
}
function pad(num) {
return num < 10 ? "0" + num : num;
}
const simplesipCreateKeypad = (container, themeMode) => {
const simplesipKeypad = document.createElement("div");
simplesipKeypad.classList.add("simplesipKeypad");
simplesipKeypad.classList.add(themeMode);
simplesipKeypad.id = "simplesipKeypad";
simplesipButtons.forEach((element) => {
const simplesipButton = document.createElement("button");
simplesipButton.textContent = element;
simplesipButton.classList.add("simplesip-bn");
simplesipButton.addEventListener("click", () => handleClick(element));
simplesipKeypad.appendChild(simplesipButton);
});
const bnAcceptCall = createButtonCall(handleCall);
bnAcceptCall.style.gridColumn = 2;
simplesipKeypad.appendChild(bnAcceptCall);
simplesipCreateHead(container, themeMode);
container.appendChild(simplesipKeypad);
};
const handleKeyPress = (event) => {
const display = document.getElementById("display");
const maxLength = 11;
const keyPress = event.key;
if (/[0-9 * #]/.test(keyPress)) {
if (display.innerText.length <= maxLength) {
if (stateCurrent.getStateCall() === "incall") {
UASimplesIP.simplesipEvento.emit("sendDTMF", keyPress);
}
display.append(keyPress);
}
//chama funcao para verificar se tem texto e exibir botao clear
} else if (keyPress === "Backspace") {
clearDisplay();
} else if (keyPress === "Enter" && stateCurrent.getStateCall() === "home") {
handleCall();
}
haveTextAndClearDisplay(display);
};
const loadConfig = () => {
const configuration = UASimplesIP.config;
configuration.PROTOCOLO = "ws";
configuration.SERVIDOR = localStorage.getItem("servidor") || "";
configuration.PORTA = localStorage.getItem("porta") || "";
configuration.NOME = localStorage.getItem("nome") || "";
configuration.RAMAL = localStorage.getItem("ramal") || "";
configuration.SENHA = localStorage.getItem("senha") || "";
};
const userImg =
"";
const transferImg =
"";
const keypadImg =
"";
const alertImg =
"";
const engrenagem =
"";
const darkModeImg =
"";
const muteImg =
"";
const rejeitarChamadaImg =
"";
const fazerChamadaImg =
"";
const limparDisplayDarkImg =
"";
const limparDisplayLightImg =
"";
const logoSimplesImg =
"";
const unmuteImg =
"";
window.onload = loadConfig();
window.onload = simplesipCreateContainer(initialThemeMode);
})();