//Criar uma funcao anonima para nao ser acessivel ao client const KeypadSimplesIP = (function () { const simplesipStateCall = (initialStateCall) => { let stateCall = initialStateCall; function getStateCall() { return stateCall; } function setStateCall(newStateCall) { stateCall = newStateCall; 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"); }); }); //================================================================== const simplesipCreateContainer = () => { 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"); simplesipCreateTitles(simplesipContainer); updateUI = function () { const currentStateCall = stateCurrent.getStateCall(); //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); break; case "outgoingcall": simplesipCreateOutgoingCall(simplesipContainer); break; case "incomingcall": simplesipCreateIncomingCall(simplesipContainer); break; case "incall": simplesipCreateInCall(simplesipContainer); break; default: simplesipCreateKeypad(simplesipContainer); break; } document.body.appendChild(simplesipContainer); }; updateUI(); return { simplesipCreateContainer }; }; const simplesipCreateInCall = (container) => { const simplesipInCall = document.createElement("div"); simplesipInCall.classList.add("simplesipInCall"); simplesipInCall.id = "simplesipInCall"; simplesipCreateDisplay(container); simplesipCreateTimer(simplesipInCall); //Adiciona o numero que ligou ao display const display = document.getElementById("display"); display.textContent = storedNumberCall; display.style.marginTop = 30 + "px"; const bnEndCall = createButtonEndCall(handleEndCall); const bnMute = createButtonMute(handleMute); const displayInCall = document.createElement("div"); displayInCall.classList.add("displayInCall"); displayInCall.id = "displayInCall"; displayInCall.appendChild(bnMute); displayInCall.appendChild(bnEndCall); simplesipInCall.appendChild(displayInCall); container.appendChild(simplesipInCall); }; 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.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) => { const numberOutgoingCall = document.createElement("div"); numberOutgoingCall.classList.add("numberOutgoingCall"); numberOutgoingCall.id = "numberOutgoingCall"; numberOutgoingCall.textContent = "Recebendo chamada de " + "999000999"; container.appendChild(numberOutgoingCall); const simplesipIncomingCall = document.createElement("div"); simplesipIncomingCall.classList.add("simplesipIncomingCall"); simplesipIncomingCall.id = "simplesipIncomingCall"; const bnAcceptCall = createButtonCall(handleAcceptCall); const bnEndCall = createButtonEndCall(handleEndCall); 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) => { document.removeEventListener("keydown", handleKeyPress); const numberOutgoingCall = document.createElement("div"); numberOutgoingCall.classList.add("numberOutgoingCall"); 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.id = "simplesipOutgoingCall"; const bnEndCall = createButtonEndCall(handleEndCall); bnEndCall.classList.add("animationHover"); bnEndCall.style.gridColumn = 2; simplesipOutgoingCall.appendChild(bnEndCall); container.appendChild(simplesipOutgoingCall); }; function handleEndCall() { restartTimer(); storedNumberCall = ""; stateCurrent.setStateCall("home"); } function handleAcceptCall() { startTimer(); stateCurrent.setStateCall("incall"); } function handleMute() {} const simplesipCreateDisplayContainer = (header) => { const simplesipDisplayContainer = document.createElement("div"); simplesipDisplayContainer.classList.add("displayContainer"); simplesipDisplayContainer.id = "displayContainer"; //add display ao container simplesipCreateDisplay(simplesipDisplayContainer); header.appendChild(simplesipDisplayContainer); }; // 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); } //chama funcao para verificar se tem texto e exibir botao clear haveTextAndClearDisplay(); }; function haveTextAndClearDisplay() { const display = document.getElementById("display"); const haveText = display.textContent; const displayContainer = document.getElementById("displayContainer"); if (haveText.length == 1) { simplesipCreateClearDisplay(displayContainer); } } const clearDisplay = () => { const display = document.getElementById("display"); const clearDisplay = document.getElementById("clearDisplay"); const currentContent = display.textContent; const newContent = currentContent.slice(0, -1); display.innerText = newContent; if (display.textContent.length == 0) { if (clearDisplay) clearDisplay.parentElement.removeChild(clearDisplay); } function clearAll() { display.innerText = ""; } return { clearAll }; }; const simplesipCreateHead = (container) => { const simplesipHead = document.createElement("div"); simplesipHead.classList.add("simplesipHead"); simplesipHead.id = "simplesipHead"; //add agentLocal display simplesipCreateLocalAgentDisplay(simplesipHead); simplesipCreateDisplayContainer(simplesipHead); container.appendChild(simplesipHead); }; 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") ); // Atualiza conforme o parâmetro passado switch (status) { case "online": // Verifica se o primeiro elemento de circleElements não é undefined if (circleElements[0]) { circleElements[0].classList.add("online"); } break; case "away": if (circleElements[0]) { circleElements[0].classList.add("away"); } break; case "busy": if (circleElements[0]) { circleElements[0].classList.add("busy"); } break; default: // Lidar com o caso padrão break; } } }; const simplesipCreateLocalAgentDisplay = (header) => { const agentLocalDisplay = document.createElement("div"); agentLocalDisplay.id = "agentLocalDisplay"; const statusAgent = document.createElement("div"); 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 = "matheo ADM"; agentLocalDisplay.appendChild(nameAgent); header.appendChild(agentLocalDisplay); }; const simplesipCreateClearDisplay = (header) => { const simplesipClearDisplay = document.createElement("div"); simplesipClearDisplay.id = "clearDisplay"; const clearDisplayImg = document.createElement("img"); clearDisplayImg.src = limparDisplayImg; clearDisplayImg.width = 30; clearDisplayImg.height = 30; simplesipClearDisplay.addEventListener("click", () => { clearDisplay(); }); 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); }; const simplesipCreateTitles = (container) => { const simplesipTitle = document.createElement("div"); simplesipTitle.classList.add("simplesipTitles"); simplesipTitle.id = "simplesipTitles"; //add logo da simplesip simplesipCreateLogo(simplesipTitle); simplesipTitle.addEventListener("click", handleMinimize); container.appendChild(simplesipTitle); }; 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); simplesipCreateMinimize(titles); }; const simplesipCreateMinimize = (titles) => { //add div-bn const divButton = document.createElement("div"); divButton.classList.add("divButton"); //add button const simplesipMinimize = document.createElement("button"); simplesipMinimize.classList.add("bn-minimize"); simplesipMinimize.id = "bn-minimize"; const simplesipMinimizeImage = document.createElement("img"); document.addEventListener("keydown", handleKeyPress); simplesipMinimizeImage.src = minimizarImg; simplesipMinimizeImage.width = 20; simplesipMinimizeImage.height = 22; simplesipMinimize.appendChild(simplesipMinimizeImage); divButton.appendChild(simplesipMinimize); titles.appendChild(divButton); }; 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 img = document.getElementById("bn-minimize").querySelector("img"); if (isKeyPadMinimized) { img.src = minimizarImg; document.addEventListener("keydown", handleKeyPress); } else { img.src = maximizeImg; document.removeEventListener("keydown", handleKeyPress); } isKeyPadMinimized = !isKeyPadMinimized; }; const simplesipCreateDisplay = (header) => { const simplesipDisplay = document.createElement("div"); simplesipDisplay.id = "display"; 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 storedNumberCall = ""; const handleCall = () => { const numberCall = document.getElementById("display").textContent; if (numberCall) { storedNumberCall = numberCall; } stateCurrent.setStateCall("outgoingcall"); }; 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); if (formatado) { document.getElementById("timer").textContent = formatado; } } function pad(num) { return num < 10 ? "0" + num : num; } const simplesipCreateKeypad = (container) => { const simplesipKeypad = document.createElement("div"); simplesipKeypad.classList.add("simplesipKeypad"); 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); 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) { display.append(keyPress); } //chama funcao para verificar se tem texto e exibir botao clear haveTextAndClearDisplay(); } else if (keyPress === "Backspace") { clearDisplay(); } else if (keyPress === "Enter") { handleCall(); } else { console.log("Tecla inválida!"); } }; window.onload = simplesipCreateContainer; const muteImg = ""; const rejeitarChamadaImg = ""; const fazerChamadaImg = ""; const limparDisplayImg = ""; const logoSimplesImg = ""; const minimizarImg = ""; const maximizeImg = ""; })();