Countdown

Animated countdown timers with days, hours, minutes, and seconds.

This component requires softui.js for interactive behavior.

Default

00
Years
:
00
Days
:
00
Hours
:
00
Minutes
:
00
Seconds
<!-- Absolute date -->
<div class="sui-countdown" data-date="2028-12-31T00:00:00">

<!-- Relative date: +2y, +30d, +6h, +45m, +30s -->
<div class="sui-countdown" data-date="+2y5d">
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-years>00</div>
    <span class="sui-countdown-label">Years</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-days>00</div>
    <span class="sui-countdown-label">Days</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-hours>00</div>
    <span class="sui-countdown-label">Hours</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-minutes>00</div>
    <span class="sui-countdown-label">Minutes</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-seconds>00</div>
    <span class="sui-countdown-label">Seconds</span>
  </div>
</div>

<!-- Listen for timer completion -->
<script>
  document.querySelector('.sui-countdown')
    .addEventListener('countdown:end', function() {
      alert('Timer finished!');
    });
</script>

Primary

00
Days
:
00
Hours
:
00
Minutes
:
00
Seconds
<div class="sui-countdown sui-countdown-primary" data-date="2026-12-31T00:00:00">
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-days>00</div>
    <span class="sui-countdown-label">Days</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-hours>00</div>
    <span class="sui-countdown-label">Hours</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-minutes>00</div>
    <span class="sui-countdown-label">Minutes</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-seconds>00</div>
    <span class="sui-countdown-label">Seconds</span>
  </div>
</div>

Inset

00
Days
:
00
Hours
:
00
Minutes
:
00
Seconds
<div class="sui-countdown sui-countdown-inset" data-date="2026-12-31T00:00:00">
  <!-- same structure as default -->
</div>

Bordered

00
Days
:
00
Hours
:
00
Minutes
:
00
Seconds
<div class="sui-countdown sui-countdown-bordered" data-date="2026-12-31T00:00:00">
  <!-- same structure as default -->
</div>

Small

00
Days
:
00
Hours
:
00
Min
:
00
Sec
<div class="sui-countdown sui-countdown-sm" data-date="2026-12-31T00:00:00">
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-days>00</div>
    <span class="sui-countdown-label">Days</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-hours>00</div>
    <span class="sui-countdown-label">Hours</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-minutes>00</div>
    <span class="sui-countdown-label">Min</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-seconds>00</div>
    <span class="sui-countdown-label">Sec</span>
  </div>
</div>

Large

00
Days
:
00
Hours
:
00
Minutes
:
00
Seconds
<div class="sui-countdown sui-countdown-lg sui-countdown-primary" data-date="2026-12-31T00:00:00">
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-days>00</div>
    <span class="sui-countdown-label">Days</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-hours>00</div>
    <span class="sui-countdown-label">Hours</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-minutes>00</div>
    <span class="sui-countdown-label">Minutes</span>
  </div>
  <span class="sui-countdown-separator">:</span>
  <div class="sui-countdown-unit">
    <div class="sui-countdown-value" data-seconds>00</div>
    <span class="sui-countdown-label">Seconds</span>
  </div>
</div>

Delete this item?

This action cannot be undone. This will permanently delete the item and remove all associated data.