A simple yet powerful countdown plugin, with no dependencies. Create beautiful countdowns with ease!
- Zero dependencies
- TypeScript support
- Multiple module formats (ES, UMD, CommonJS)
- Multiple themes included
- Lightweight and performant
- Count up or down functionality
- UTC support
- Highly customizable
- Control API (stop, resume, update)
- Comprehensive event callbacks
npm install simplycountdown.js
# or
yarn add simplycountdown.js
# or
bun install simplycountdown.js
<!-- ...YOUR HTML CODE -->
<div class="my-super-countdown simply-countdown-circle"></div>
<!-- YOUR HTML CODE... -->
In this example you will have to target .my-super-countdown
and will apply the circle theme.
import simplyCountdown from "simplycountdown.js";
simplyCountdown(".my-super-countdown", {
year: 2025,
month: 12,
day: 25,
});
If you want to import and compile the TypeScript source files directly, you can include the source files in your project:
import simplyCountdown from "simplycountdown.js/src/core/simplyCountdown";
const simplyCountdown = require("simplycountdown");
simplyCountdown(".my-super-countdown", {
year: 2025,
month: 12,
day: 25,
});
<script src="path/to/simplyCountdown.umd.js"></script>
<script>
simplyCountdown(".my-super-countdown", {
year: 2025,
month: 12,
day: 25,
});
</script>
// .my-super-countdown is an example
// you can target any HTML element with any CSS selector
simplyCountdown(".my-super-countdown", {
// Target date (Required)
year: 2025, // Target year [YYYY]
month: 12, // Target month [1-12]
day: 25, // Target day [1-31]
hours: 0, // Target hours [0-23]
minutes: 0, // Target minutes [0-59]
seconds: 0, // Target seconds [0-59]
// Words customization
words: {
days: {
// Function to handle pluralization
lambda: (root, count) => (count > 1 ? root + "s" : root),
root: "day", // Base word for days
},
hours: {
lambda: (root, count) => (count > 1 ? root + "s" : root),
root: "hour",
},
minutes: {
lambda: (root, count) => (count > 1 ? root + "s" : root),
root: "minute",
},
seconds: {
lambda: (root, count) => (count > 1 ? root + "s" : root),
root: "second",
},
},
// Display options
plural: true, // Enable/disable pluralization
inline: false, // Display inline (true) or in blocks (false)
inlineSeparator: ", ", // Separator for inline display
enableUtc: false, // Use UTC time instead of local time
// Styling classes
inlineClass: "simply-countdown-inline", // Class for inline display
sectionClass: "simply-section", // Class for each time unit section
amountClass: "simply-amount", // Class for number display
wordClass: "simply-word", // Class for word display
// Formatting options
zeroPad: false, // Add leading zeros to numbers (e.g., 05 instead of 5)
countUp: false, // Count up from target date instead of down to it
removeZeroUnits: false, // Hide time units when they reach zero
refresh: 1000, // Update interval in milliseconds (1 second = 1000)
// Event handlers
onEnd: () => {
// Callback function when countdown ends
console.log("Countdown finished!");
},
onStop: () => {}, // Callback when countdown is stopped
onResume: () => {}, // Callback when countdown is resumed
onUpdate: (params) => {}, // Callback when countdown is updated
});
The plugin generates the following HTML structure:
<div class="simply-countdown">
<div class="simply-section">
<div>
<span class="simply-amount">24</span>
<span class="simply-word">days</span>
</div>
</div>
<!-- Similar sections for hours, minutes, seconds -->
</div>
<div class="simply-countdown simply-countdown-inline">24 days, 3 hours, 45 minutes, 12 seconds</div>
The library comes with several built-in themes:
default.css
- Classic theme with clean, modern designdark.css
- Dark mode themecircle.css
- Circular display with modern aestheticscyber.css
- Cyberpunk-inspired designlosange.css
- Diamond-shaped display
To use a theme, include its CSS file:
<link rel="stylesheet" href="path/to/themes/default.css" />
SimplyCountdown.js includes several pre-built themes to enhance your countdown's appearance. Each theme is designed for different visual styles and use cases.
Note: All themes are available in both standard (
.css
) and minified (.min.css
) formats for production use.
-
Default Theme (
dist/themes/default.css
)- Apply class:
simply-countdown
- Clean, modern design with flat colors
- Apply class:
-
Dark Theme (
dist/themes/dark.css
)- Apply class:
simply-countdown-dark
- Sleek dark mode appearance with light text
- Apply class:
-
Cyberpunk Theme (
dist/themes/cyber.css
)- Apply class:
simply-countdown-cyber
- Futuristic, neon-inspired design with glowing effects
- Apply class:
-
Circle Theme (
dist/themes/circle.css
)- Apply class:
simply-countdown-circle
- Modern circular display with rounded sections
- Apply class:
-
Losange Theme (
dist/themes/losange.css
)- Apply class:
simply-countdown-losange
- losange display with rotated sections
- Apply class:
- Import Theme CSS
<link rel="stylesheet" href="path/to/themes/default.css" />
- Apply Theme
Simply include the CSS file in your HTML document, and the theme will be applied automatically to your countdown elements.
You can customize any theme by overriding the CSS classes. The base structure for customization is:
.custom-countdown-theme {
/* Main countdown container */
}
.custom-countdown-theme > .simply-section {
/* Individual time unit blocks */
}
.custom-countdown-theme > .simply-section > div {
/* Inner container for amount and word */
}
.custom-countdown-theme > .simply-section .simply-amount,
.custom-countdown-theme > .simply-section .simply-word {
/* Common styles for numbers and labels */
}
.custom-countdown-theme > .simply-section .simply-amount {
/* Number display */
}
.custom-countdown-theme > .simply-section .simply-word {
/* Label text */
}
These base classes provide a foundation for creating your own custom themes or modifying existing ones.
simplyCountdown("#newyear", {
year: 2025,
month: 1,
day: 1,
enableUtc: true,
zeroPad: true,
onEnd: () => {
alert("Happy New Year!");
},
});
simplyCountdown("#timer", {
year: 2024,
month: 1,
day: 1,
countUp: true,
zeroPad: true,
removeZeroUnits: true,
});
simplyCountdown("#inline", {
year: 2025,
month: 12,
day: 25,
inline: true,
inlineSeparator: " | ",
words: {
days: {
lambda: (root, count) => (count === 1 ? "day" : "days"),
root: "day",
},
hours: {
lambda: (root, count) => (count === 1 ? "hour" : "hours"),
root: "hour",
},
minutes: {
lambda: (root, count) => (count === 1 ? "minute" : "minutes"),
root: "minute",
},
seconds: {
lambda: (root, count) => (count === 1 ? "second" : "seconds"),
root: "second",
},
},
});
The plugin accepts various selector types:
// CSS selector string
simplyCountdown("#countdown", parameters);
// Single DOM element
simplyCountdown(document.getElementById("countdown"), parameters);
// Multiple elements
simplyCountdown(document.querySelectorAll(".countdown"), parameters);
The countdown instance returns a controller object that allows you to manipulate the countdown:
// Initialize countdown
const countdown = simplyCountdown("#mycountdown", parameters);
// Stop the countdown
countdown.pause();
// Resume countdown
countdown.resume();
// Update countdown parameters
countdown.update({
year: 2026,
month: 1,
day: 1,
});
// Chain control methods
countdown.pause();
countdown.resume();
countdown.update({ year: 2026, hours: 12, minutes: 51 });
npm run dev
: Start development server for the documentation site & Core library (port 3000)npm run build
: Build everything (library, themes, and documentation)npm run preview
: Preview the documentation site
npm run build:lib
: Build the library (ES and UMD formats)npm run build:themes
: Build CSS themesnpm run build:docs
: Build the documentation site
npm run test
: Run testsnpm run test:watch
: Run tests in watch modenpm run dist:test
: Generate test files for different module formatsnpm run dist:test:serve
: Generate and serve test files locally
Test different usecases using:
npm run dist:test:serve
Available test files:
- ES Module (
index.es.html
) - UMD Global (
index.umd-global.html
) - UMD AMD/RequireJS (
index.umd-amd.html
) - UMD CommonJS (
index.umd-commonjs.html
) - UMD Dynamic Loading (
index.umd-dynamic.html
)
The library supports all modern browsers (Chrome, Firefox, Safari, Edge) and IE11+.
jQuery is no longer supported in simplyCountdown to reduce dependencies and improve performance. This change ensures a more lightweight and modern library.
Note: You can still use simplyCountdown in your jQuery projects by using the vanilla JavaScript syntax instead of the jQuery-specific one:
- Old jQuery-compatible syntax:
$('.some-countdowns').simplyCountdown(options)
- New vanilla JavaScript syntax:
simplyCountdown('.some-countdowns', options)
The build process has been migrated from Gulp to Vite. Vite offers faster builds, better development server capabilities, and improved support for modern JavaScript features.
The source code has been rewritten in TypeScript to enhance code quality, provide better type checking, and improve developer experience.
A new documentation website has been launched to provide comprehensive guides, examples, and API references. This site aims to make it easier for developers to integrate and use simplyCountdown.
The distribution files have been reorganized to include multiple module formats (ES, UMD, CommonJS) and themes. This change ensures compatibility with various development environments and build tools.
The package manager has been switched from npm to Bun for faster installs and improved performance. Bun offers a more efficient and modern package management experience.
MIT © 2015-present - Vincent Loy-Serre