Skip to content
Advertisement

Why clearInterval() is not working in timer Js?

I am training to work with js and one of the projects was a pomodoro timer. The timer works well from the main panel and stops and switches between tabs. But if you click on the clock button in the header and select any of the options there, then the timer does not stop and is not cleared when switching tabs, and plus when it ends, it goes into minus.

timerInt = setInterval(timerF, 1000);
  function timerF() {
    if (sec === 0) {
      sec = 59;
      min--;
    } else {
      sec--;
    }
    if (sec < 10) {
      timeSec.textContent = `0${sec}`;
    } else {
      timeSec.textContent = `${sec}`;
    }
    if (min < 10) {
      timeMin.textContent = `0${min}`;
    } else {
      timeMin.textContent = `${min}`;
    }
    if (sec <= 0 && min <= 0) {
      clearInterval(timerInt);
      timeSec.textContent = `00`;
      timeMin.textContent = `00`;
    }
  }

Here is the code that is executed when the first option is selected (20 min):

time1.addEventListener("click", function () {
  clearInterval(timerInt);
  timeChoose = 20;
  setTimes.classList.remove("active-time");
  startBtn.removeAttribute("disabled", "disabled");
  pomo.classList.add("active");
  longBreak.classList.remove("active");
  shortBreak.classList.remove("active");
  startBtn.classList.add("active-btn");
  timeSec.textContent = `00`;
  timeMin.textContent = `20`;
  startBtn.addEventListener("click", function () {
    timer(timeChoose);
    startBtn.setAttribute("disabled", "disabled");
  });
});

Link to an example page to make it easier to understand what I’m talking about and see the code. Please help me to make the timer work well after selection https://createchaoslab.github.io/pomo/

Advertisement

Answer

You calss Timer. But there is no timer function. Try this.

EDITED:

var tabs = document.querySelectorAll(".tab");
const first = document.querySelector(".first");
const timeMin = document.querySelector(".time-min");
const timeSec = document.querySelector(".time-sec");
var startBtn = document.querySelector(".start-btn");
const time1 = document.querySelector(".time1");
const time2 = document.querySelector(".time2");
const time3 = document.querySelector(".time3");
const setTimes = document.querySelector(".set-times");
const setTimesBtn = document.querySelector(".set-time img");
let timerInt;
let timeChoose=2;

function timer(timeChoose = 10) {
  let sec = 0;
  let min = timeChoose;
  timerInt = setInterval(timerF, 1000);
  function timerF() {
    if (sec == 0) {
      sec = 59;
      min--;
    } else {
      sec--;
    }

    if (sec < 10) {
      timeSec.innerHTML = `0${sec}`;
    } else {
      timeSec.innerHTML = `${sec}`;
    }
    if (min < 10) {
      timeMin.innerHTML = `0${min}`;
    } else {
      timeMin.innerHTML = `${min}`;
    }
    if (sec <= 0 && min <= 0) {
      clearInterval(timerInt);
      timeSec.innerHTML = `00`;
      timeMin.innerHTML = `00`;
    }
  }
}



tabs.forEach(tab => {
  tab.addEventListener('click', function handleClick(event) {
      clearInterval(timerInt);
    [].forEach.call(tabs, function(el) {
            el.classList.remove("active");
    });

    this.classList.add("active");
    if(this.classList.contains('first')){
      timeSec.innerHTML = `00`;
          if (timeChoose < 10) {
                timeMin.innerHTML = `0${timeChoose}`;
              } else {
                timeMin.innerHTML = `${timeChoose}`;
              }
            startBtn.classList.add("active-btn");
      startBtn.removeAttribute("disabled", "disabled");
    }
    else{
        if(this.classList.contains('second')){
          timeSec.innerHTML = `00`;
          timeMin.innerHTML = `01`;
          timer(1);
        }
        else{
          timeSec.innerHTML = `00`;
          timeMin.innerHTML = `04`;   
          timer(4);
        }
                startBtn.classList.remove("active-btn");
    }
  });
});

function setT(min) {
  clearInterval(timerInt);

  timeChoose = min;
    [].forEach.call(tabs, function(el) {
            el.classList.remove("active");
    });
    setTimes.classList.remove("active-time");
  startBtn.removeAttribute("disabled", "disabled");
      first.classList.add("active");
  startBtn.classList.add("active-btn");
  timeSec.innerHTML = `00`;
  timeMin.innerHTML = `${timeChoose}`;
}

time1.addEventListener("click", function () {
    setT(20);
});
 
time2.addEventListener("click", function () {
    setT(40);
});
time3.addEventListener("click", function () {
    setT(60);
});


startBtn.addEventListener("click", function () {
  timer(timeChoose);
  startBtn.setAttribute("disabled", "disabled");
});
setTimesBtn.addEventListener("click", function () {
  setTimes.classList.toggle("active-time");
});
body{
  background: rgb(221, 99, 0);
}

.header {
    border-bottom: 2px solid #fff;
    margin-bottom: 70px;
}

.header-inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.set-time {
    display: flex;

}

.set-time img {
    margin-left: 20px;
  width: 40px;
  height: 40px;
    cursor: pointer;
    padding: 0 10px;
}

.set-times {
    visibility: hidden;
}

.set-times>* {
    display: none;
}

.set-times.active-time>* {
    display: block;
}

.set-times.active-time {
    visibility: visible;
    background: #ff8100;
    display: flex;
    padding: 10px 30px;
    border-radius: 20px;
    transition: all.4s;
    -webkit-transition: all.4s;
    -moz-transition: all.4s;
    -ms-transition: all.4s;
    -o-transition: all.4s;
}

.time-var {
    padding: 0px 10px;
    font-size: 20px;
    color: #fff;
    transition: all .3s;
    -webkit-transition: all .3s;
    -moz-transition: all .3s;
    -ms-transition: all .3s;
    -o-transition: all .3s;
    letter-spacing: 1px;
    cursor: pointer;
}

.time-var:hover {
    background-color: #f5812e;
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    -ms-border-radius: 10px;
    -o-border-radius: 10px;

}

.time-var+.time-var {
    margin-left: 15px;
}

.tabs{
  display:block;
  position:relative;
  width: 100%;
  height: 40px;
  padding: 10px;
}
.tab{
  display: inline-block;
  text-align: center;
  width: 60px;
  transition: all .3s;
  font-size: 20px;
  font-weight: 700;
  color: #fff;
  padding: 7px 10px;
  margin: 0 10px;
  cursor: pointer;
  background-color: transparent;
  border: transparent;
  outline: none;
  -webkit-transition: all .3s;
}
.tab.active{
  background:rgb(168, 60, 18);
}
#text {
    display: flex;
    color: #fff;
    justify-content: center;
    align-items: center;
}

.start-btn.active-btn {
    margin-top: 10px;
    border-radius: 5px;
    background-color: rgb(255, 230, 210);
    color: rgb(221, 99, 0);
    font-size: 15px;
    border: transparent;
    outline: none;
    padding: 10px 20px;
    cursor: pointer;
    visibility: visible;
}
.start-btn {
    visibility: hidden;
}
<body>
    <header class="header">
      <div class="container">
        <div class="header-inner">
          <div class="set-time">
                        <div class="set-times">
                            <div class="time-var time1">20 min</div>
                            <div class="time-var time2">40 min</div>
                            <div class="time-var time3">60 min</div>
                        </div>
                        <img src="" alt="" />
                        
                    </div>
        </div>
      </div>
    </header>

<div class="tabs">
<div class="tab first active">
tab1
</div>
<div class="tab second">
tab2
</div>
<div class="tab third">
tab3
</div>
</div>
<div>


<div id="text">
<div class="time-min">02</div> :
<div class="time-sec">00</div>
</div>
<button class="start-btn active-btn">START</button>
</div>
</body>
User contributions licensed under: CC BY-SA
4 People found this is helpful
Advertisement