From 42fa8304ddb811b0f725f245130f70c0f5e86a6c Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Tue, 04 Nov 2025 06:12:02 +0000
Subject: [PATCH] =Refactored LoginManager to be more extensible and configurable, as well as an AjaxRateLimiter

---
 assets/js/dash/UtilityFunctions.js |   79 +++++++--------------------------------
 1 files changed, 15 insertions(+), 64 deletions(-)

diff --git a/assets/js/dash/UtilityFunctions.js b/assets/js/dash/UtilityFunctions.js
index 1d3197d..4c337dd 100644
--- a/assets/js/dash/UtilityFunctions.js
+++ b/assets/js/dash/UtilityFunctions.js
@@ -1,63 +1,3 @@
-// Theme switching functionality
-document.addEventListener('DOMContentLoaded', function() {
-	console.log('Theme switch initiated');
-	const themeSwitch = document.getElementById('theme-switch');
-
-	if (!themeSwitch) return;
-
-	// Initialize theme from localStorage or system preference
-	const prefersDark = window.matchMedia('(prefers-color-scheme: dark)');
-	const storedTheme = localStorage.getItem('theme');
-
-	if (storedTheme) {
-		document.documentElement.classList.toggle('dark', storedTheme === 'dark');
-		themeSwitch.checked = storedTheme === 'dark';
-	} else {
-		document.documentElement.classList.toggle('dark', prefersDark.matches);
-		themeSwitch.checked = prefersDark.matches;
-	}
-
-	// Handle theme switch changes
-	themeSwitch.addEventListener('change', async function () {
-		const isDark = this.checked;
-		document.documentElement.classList.toggle('dark', isDark);
-		localStorage.setItem('theme', isDark ? 'dark' : 'light');
-
-		// If user is logged in, save preference
-		if (jvbSettings.currentUser !== null) {
-			try {
-				await fetch(`${jvbSettings.api}settings`, {
-					method: 'POST',
-					headers: {
-						'Content-Type': 'application/json',
-						'X-WP-Nonce': jvbSettings.nonce,
-						'action_nonce': jvbSettings.dash,
-					},
-					body: JSON.stringify({
-						dark_mode: isDark
-					})
-				});
-			} catch (error) {
-				console.error('Failed to save theme preference:', error);
-			}
-		}
-
-		// Update label
-		const label = document.getElementById('theme-switch');
-		if (label) {
-			label.title = isDark ? 'Toggle Light Mode' : 'Toggle Dark Mode';
-		}
-	});
-
-	// Handle system theme changes
-	prefersDark.addEventListener('change', (e) => {
-		if (!localStorage.getItem('theme')) {
-			const isDark = e.matches;
-			document.documentElement.classList.toggle('dark', isDark);
-			themeSwitch.checked = isDark;
-		}
-	});
-});
 
 /**
  *
@@ -480,7 +420,22 @@
 window.showToast = function(message, type='success', actions={}){
 	window.jvbNotifications.showToast(message, type, actions);
 }
+window.dateFormatter = new Intl.DateTimeFormat('en-CA', {
+		year: 'numeric',
+		month: 'long',
+		day: 'numeric',
+		hour: '2-digit',
+		minute: '2-digit',
+		second: '2-digit',
+		timeZoneName: 'short'
+	});
 
+window.formatDate = function(date) {
+	if (!(date instanceof Date && !isNaN(date))) {
+		date = new Date(date);
+	}
+	return window.dateFormatter.format(date);
+}
 
 /**
  * Outputs the set text as if a typewriter were writing it
@@ -861,8 +816,6 @@
 
 	schedule(key, callback, delay = 1000) {
 		this.cancel(key);
-		console.log('Scheduling action: ', key);
-		console.log('With callback', callback);
 		this.timeouts.set(key, setTimeout(() => {
 			callback();
 			this.timeouts.delete(key);
@@ -871,7 +824,6 @@
 
 	cancel(key) {
 		if (this.timeouts.has(key)) {
-			console.log('Cancelling ', key);
 			clearTimeout(this.timeouts.get(key));
 			this.timeouts.delete(key);
 		}
@@ -879,7 +831,6 @@
 
 	cleanup() {
 		for (let timeout of this.timeouts.values()) {
-			console.log('clearing timeout: ', timeout);
 			clearTimeout(timeout);
 		}
 		this.timeouts.clear();

--
Gitblit v1.10.0