Files

81 lines
2.0 KiB
JavaScript
Raw Permalink Normal View History

2025-12-09 00:47:23 +07:00
/**
* terminal.css - Terminal CSS Component Library
* JavaScript Utilities
* Version: 3.0.0
*/
/**
* Toggle FAQ item
* @param {HTMLElement} element - The FAQ question element that was clicked
*/
function toggleFaq(element) {
const faqItem = element.parentElement;
2025-12-10 06:26:53 +07:00
const wasActive = faqItem.classList.contains("is-active");
2025-12-09 00:47:23 +07:00
// Close all FAQ items
2025-12-10 06:26:53 +07:00
document.querySelectorAll(".faq-item").forEach((item) => {
item.classList.remove("is-active");
2025-12-09 00:47:23 +07:00
});
2025-12-10 06:26:53 +07:00
2025-12-09 00:47:23 +07:00
// Open clicked item if it wasn't active
if (!wasActive) {
2025-12-10 06:26:53 +07:00
faqItem.classList.add("is-active");
2025-12-09 00:47:23 +07:00
}
}
/**
* Show a toast notification
* @param {string} type - Toast type: 'primary', 'success', 'danger', 'warning', 'info'
* @param {string} title - Toast title
* @param {string} message - Toast message
* @param {number} duration - Duration in milliseconds (default: 5000)
*/
function showToast(type, title, message, duration = 5000) {
2025-12-10 06:26:53 +07:00
const container = document.getElementById("toastContainer");
2025-12-09 00:47:23 +07:00
// Create toast element
2025-12-10 06:26:53 +07:00
const toast = document.createElement("div");
2025-12-09 00:47:23 +07:00
toast.className = `toast is-${type}`;
2025-12-10 06:26:53 +07:00
2025-12-09 00:47:23 +07:00
// Icon mapping
const icons = {
2025-12-10 06:26:53 +07:00
primary: "▸",
success: "✓",
danger: "✕",
warning: "⚠",
info: "",
2025-12-09 00:47:23 +07:00
};
2025-12-10 06:26:53 +07:00
2025-12-09 00:47:23 +07:00
toast.innerHTML = `
2025-12-10 06:26:53 +07:00
<div class="toast-icon">${icons[type] || "▸"}</div>
2025-12-09 00:47:23 +07:00
<div class="toast-content">
<div class="toast-title">${title}</div>
<div class="toast-message">${message}</div>
</div>
<button class="toast-close" onclick="dismissToast(this)">×</button>
`;
2025-12-10 06:26:53 +07:00
2025-12-09 00:47:23 +07:00
container.appendChild(toast);
2025-12-10 06:26:53 +07:00
2025-12-09 00:47:23 +07:00
// Auto dismiss after duration
setTimeout(() => {
2025-12-10 06:26:53 +07:00
dismissToast(toast.querySelector(".toast-close"));
2025-12-09 00:47:23 +07:00
}, duration);
}
/**
* Dismiss a toast notification
* @param {HTMLElement} closeButton - The close button element that was clicked
*/
function dismissToast(closeButton) {
2025-12-10 06:26:53 +07:00
const toast = closeButton.closest(".toast");
if (toast) {
2025-12-10 06:26:53 +07:00
toast.classList.add("is-dismissing");
// Remove from DOM after animation
setTimeout(() => {
toast.remove();
}, 300);
}
}