From 0afb2c0046b55c123eafb4ab9ee77efa68d12463 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Sat, 06 Jun 2026 17:15:31 +0000
Subject: [PATCH] =Starting the Favourites.js setup, converting previous Northeh stuff to new Registrar, fixing up Square.php integration to match

---
 inc/helpers/all.php |   31 ++++++++++++++++++++++++++++++-
 1 files changed, 30 insertions(+), 1 deletions(-)

diff --git a/inc/helpers/all.php b/inc/helpers/all.php
index 5b7f02b..0891fab 100644
--- a/inc/helpers/all.php
+++ b/inc/helpers/all.php
@@ -39,6 +39,10 @@
 //        delete_option($option);
         if (!get_option($option, false)) {
 			error_log('Calling do once: '.$option);
+			if (get_transient(BASE . $option)) {
+				return;
+			}
+			set_transient(BASE . $option, true, 120);
             $callback();
             update_option($option, true);
         }
@@ -50,10 +54,35 @@
 //    delete_option(BASE.'do_these_once');
     //Ensure we have the option starting with BASE
     $option = jvbCheckBase($option);
+//	delete_option($option);
+//	delete_option(BASE.'do_these_once');
     $options = get_option(BASE.'do_these_once', []);
 //    delete_option($option);
-    if (!array_key_exists($option, $options)) {
+    if (!array_key_exists($option, $options)) {// Prevent concurrent runs
         $options[$option] = $callback;
         update_option(BASE.'do_these_once', $options);
     }
 }
+
+
+function jvbResponse(bool $success, ?string $msg = null):array
+{
+	return [
+		'success'	=> $success,
+		'message'	=> is_null($msg) ? ($success ? 'Completed successfully' : 'Something went wrong') : $msg
+	];
+}
+
+function jvbTimelinePoints(int $ID, string $type, array $status = ['publish']):array
+{
+	$type = jvbCheckBase($type);
+	return get_children([
+		'post_parent'	=> $ID,
+		'orderby'		=> 'date',
+		'order'			=> 'ASC',
+		'posts_per_page'=> -1,
+		'post_status'	=> $status,
+		'fields'		=> 'ids',
+		'post_type'		=> $type
+	]);
+}

--
Gitblit v1.10.0