Hd Admin Inserter Script -pastebin- -
// ----------------------------------------------------------------- // 5️⃣ Public API – expose a global function for manual init. // ----------------------------------------------------------------- window.HDAdminInserter = init: mountToolbar, // Allow runtime re‑configuration (e.g., after an AJAX login) updateConfig: (newCfg) => mountToolbar(newCfg) ;
HDAdminInserter.init( visibilityFn: () => myAuth.isAdmin() ); Pass a custom config object to HDAdminInserter.init before DOMContentLoaded , or call HDAdminInserter.updateConfig later:
// ----------------------------------------------------------------- // 3️⃣ Helper: create a button element from an item definition. // ----------------------------------------------------------------- const createButton = (item) => const btn = document.createElement('button'); btn.textContent = item.label; btn.title = item.tooltip ; HD Admin Inserter Script -PASTEBIN-
/** * HD Admin Inserter v1.2.0 * ------------------------------------------------- * A tiny vanilla‑JS utility to inject an admin toolbar * into any page. Designed for copy‑&‑paste from Pastebin. * * Author: YourName (originally posted on Pastebin) * License: MIT (feel free to modify & redistribute) */
HDAdminInserter.init({ mountPoint: '#app-root', items: [ label: '🚀 Deploy', tooltip: 'Trigger a production deploy', action: () => fetch('/api/deploy', method: 'POST') , // Keep the defaults by spreading them ... Designed for copy‑&‑paste from Pastebin
// Toolbar style – minimal CSS (you can override later via CSS file) style: ` #hd-admin-toolbar position: fixed; top: 0; left: 0; right: 0; background: #1e1e1e; color: #fafafa; padding: 8px 16px; font-family: system-ui, sans-serif; display: flex; align-items: center; z-index: 9999; box-shadow: 0 2px 6px rgba(0,0,0,.4); #hd-admin-toolbar button margin-right: 12px; background: #333; border: none; color: #fff; padding: 4px 10px; cursor: pointer; #hd-admin-toolbar button:hover background: #555; `,
// UI elements – each entry becomes a button. // `action` can be a string (function name) or a direct function. items: [ label: '🔧 Reload Config', tooltip: 'Pull fresh config from the server', action: () => fetchConfig() , label: '🗑️ Clear Cache', tooltip: 'Empty localStorage & sessionStorage', action: () => localStorage.clear(); sessionStorage.clear(); alert('Cache cleared'); , { label: '⚙️ Debug Mode', tooltip: 'Toggle console.debug output', toggle: true, stateKey: 'debugMode', // saved in localStorage action: (newState) => { console.debug = newState ? console.log : () => {}; localStorage.setItem('debugMode', newState); } } ] }; // `action` can be a string (function name)
// ----------------------------------------------------------------- // 4️⃣ Core: build and mount the toolbar. // ----------------------------------------------------------------- const mountToolbar = (config = {}) => const cfg = ...DEFAULT_CONFIG, ...config ;