(() => { const menuController = window.WarpBoxUI?.bindMenuBar?.() || { close() {} }; const toastTarget = document.getElementById("toast"); const body = document.getElementById("users-body"); const search = document.getElementById("users-search"); const status = document.getElementById("users-status"); const role = document.getElementById("users-role-filter"); const sort = document.getElementById("users-sort"); const size = document.getElementById("users-size"); const masterCheck = document.getElementById("users-master-check"); const pageInfo = document.getElementById("users-page-info"); const visiblePill = document.getElementById("visible-pill"); const selectedPill = document.getElementById("users-selected-pill"); const prevBtn = document.getElementById("users-prev"); const nextBtn = document.getElementById("users-next"); const selectVisible = document.getElementById("select-visible"); const form = document.getElementById("users-form"); const modeInput = document.getElementById("users-mode"); const usernameInput = document.getElementById("users-username"); const emailInput = document.getElementById("users-email"); const roleInput = document.getElementById("users-role"); const planInput = document.getElementById("users-plan"); const statusLeft = document.getElementById("users-status-left"); if (!body || !search || !status || !role || !sort || !size) return; const users = [ { id: "u_admin", username: "admin", email: "admin@warpbox.local", status: "active", role: "admin", plan: "unlimited", boxes: 18, created: "2026-04-12", lastSeen: "active now" }, { id: "u_geo", username: "geo", email: "geo@example.test", status: "active", role: "uploader", plan: "trusted", boxes: 7, created: "2026-04-21", lastSeen: "today 12:10" }, { id: "u_reo", username: "reo", email: "reo@example.test", status: "active", role: "uploader", plan: "standard", boxes: 3, created: "2026-04-20", lastSeen: "today 09:44" }, { id: "u_teo", username: "teo", email: "teo@example.test", status: "active", role: "uploader", plan: "trusted", boxes: 5, created: "2026-04-19", lastSeen: "yesterday" }, { id: "u_mara", username: "mara", email: "mara@example.test", status: "pending", role: "viewer", plan: "guest-like", boxes: 0, created: "2026-04-28", lastSeen: "never" }, { id: "u_ion", username: "ion", email: "ion@example.test", status: "disabled", role: "uploader", plan: "standard", boxes: 2, created: "2026-04-01", lastSeen: "2026-04-15" }, { id: "u_sara", username: "sara", email: "sara@example.test", status: "active", role: "operator", plan: "trusted", boxes: 12, created: "2026-03-30", lastSeen: "today 08:25" }, { id: "u_vlad", username: "vlad", email: "vlad@example.test", status: "pending", role: "uploader", plan: "standard", boxes: 0, created: "2026-04-27", lastSeen: "never" }, { id: "u_lina", username: "lina", email: "lina@example.test", status: "active", role: "viewer", plan: "guest-like", boxes: 1, created: "2026-03-22", lastSeen: "2026-04-29" }, { id: "u_adi", username: "adi", email: "adi@example.test", status: "active", role: "uploader", plan: "standard", boxes: 4, created: "2026-02-18", lastSeen: "2026-04-26" }, { id: "u_nora", username: "nora", email: "nora@example.test", status: "disabled", role: "viewer", plan: "guest-like", boxes: 0, created: "2026-01-14", lastSeen: "2026-03-02" }, { id: "u_alex", username: "alex", email: "alex@example.test", status: "active", role: "uploader", plan: "trusted", boxes: 9, created: "2026-04-10", lastSeen: "2026-04-30" }, { id: "u_rina", username: "rina", email: "rina@example.test", status: "pending", role: "uploader", plan: "standard", boxes: 0, created: "2026-04-29", lastSeen: "never" }, { id: "u_mihai", username: "mihai", email: "mihai@example.test", status: "active", role: "operator", plan: "trusted", boxes: 6, created: "2026-02-08", lastSeen: "2026-04-22" } ]; const state = { page: 1, selected: new Set() }; function toast(message, type = "info") { if (window.WarpBoxUI) { window.WarpBoxUI.toast(message, type, { target: toastTarget, duration: 2200 }); return; } if (!toastTarget) return; toastTarget.textContent = message; toastTarget.classList.add("is-visible"); } function filtered() { const query = search.value.trim().toLowerCase(); const statusFilter = status.value; const roleFilter = role.value; const sortBy = sort.value; const rows = users.filter((user) => { const matchesQuery = !query || user.username.toLowerCase().includes(query) || user.email.toLowerCase().includes(query); const matchesStatus = statusFilter === "all" || user.status === statusFilter; const matchesRole = roleFilter === "all" || user.role === roleFilter; return matchesQuery && matchesStatus && matchesRole; }); rows.sort((a, b) => { if (sortBy === "createdDesc") return b.created.localeCompare(a.created); if (sortBy === "lastSeenDesc") return b.lastSeen.localeCompare(a.lastSeen); if (sortBy === "boxesDesc") return b.boxes - a.boxes; return a.username.localeCompare(b.username); }); return rows; } function paged(rows) { const perPage = Number(size.value || 12); const pages = Math.max(1, Math.ceil(rows.length / perPage)); if (state.page > pages) state.page = pages; if (state.page < 1) state.page = 1; const start = (state.page - 1) * perPage; return { rows: rows.slice(start, start + perPage), pages, start }; } function statusPill(value) { return `${value}`; } function renderRow(user) { const checked = state.selected.has(user.id) ? " checked" : ""; const row = document.createElement("tr"); row.innerHTML = `