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");
|
2025-12-10 06:08:01 +07:00
|
|
|
|
if (toast) {
|
2025-12-10 06:26:53 +07:00
|
|
|
|
toast.classList.add("is-dismissing");
|
|
|
|
|
|
|
2025-12-10 06:08:01 +07:00
|
|
|
|
// Remove from DOM after animation
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
toast.remove();
|
|
|
|
|
|
}, 300);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|