aboutsummaryrefslogtreecommitdiff
path: root/app/View
diff options
context:
space:
mode:
authorfloppydiskette <git@diskfloppy.me>2024-08-08 15:35:48 +0100
committerfloppydiskette <git@diskfloppy.me>2024-08-08 15:35:48 +0100
commit74bca7ac803aeea3d5091344b99520687e3a3bd1 (patch)
tree8a63a2341303daac4ac621f8f4962a81d684e88a /app/View
parent9900446d9590024c34f55a45055776a396fb694e (diff)
parent14d3ed966bbafbcb01182df26fbbe1d5a211f4c2 (diff)
Merge branch 'redesign'
Diffstat (limited to 'app/View')
-rw-r--r--app/View/Components/DiscordStatus.php66
-rw-r--r--app/View/Components/Navbar.php2
-rw-r--r--app/View/Components/NeverSaid.php34
-rw-r--r--app/View/Components/TohQuote.php35
-rw-r--r--app/View/Components/Weather.php44
5 files changed, 180 insertions, 1 deletions
diff --git a/app/View/Components/DiscordStatus.php b/app/View/Components/DiscordStatus.php
new file mode 100644
index 0000000..fac06ae
--- /dev/null
+++ b/app/View/Components/DiscordStatus.php
@@ -0,0 +1,66 @@
+<?php
+
+namespace App\View\Components;
+
+use Closure;
+use Illuminate\Contracts\View\View;
+use Illuminate\Support\Facades\Cache;
+use Illuminate\Support\Facades\Config;
+use Illuminate\Support\Facades\Http;
+use Illuminate\View\Component;
+
+class DiscordStatus extends Component
+{
+ /**
+ * Create a new component instance.
+ */
+ public function __construct()
+ {
+ //
+ }
+
+ /**
+ * Returns current Discord presence from Lanyard API
+ * @return array|mixed
+ */
+ public function getDiscordPresence(): mixed {
+ // If it's already cached just return that
+ if (Cache::has('discord_presence')) {
+ return Cache::get('discord_presence');
+ }
+
+ $response = Http::get('https://api.lanyard.rest/v1/users/' . Config::get('services.lanyard.user_id'));
+ $data = $response->json();
+ $presence = $data["data"];
+ Cache::put('discord_presence', $presence, now()->addSeconds(60));
+ return $presence;
+ }
+
+ public function getOnlineStatus(): array {
+ $presence = $this->getDiscordPresence();
+ return match ($presence["discord_status"]) {
+ "online", "dnd" => [
+ "text" => "online",
+ "color" => "#02c83a"
+ ],
+ "idle" => [
+ "text" => "away",
+ "color" => "#d77c20"
+ ],
+ default => [
+ "text" => "offline",
+ "color" => "#ca3329"
+ ],
+ };
+ }
+
+ /**
+ * Get the view / contents that represent the component.
+ */
+ public function render(): View|Closure|string
+ {
+ return view('components.discord-status', [
+ 'status' => $this->getOnlineStatus(),
+ ]);
+ }
+}
diff --git a/app/View/Components/Navbar.php b/app/View/Components/Navbar.php
index a19db3b..7f119fe 100644
--- a/app/View/Components/Navbar.php
+++ b/app/View/Components/Navbar.php
@@ -22,6 +22,6 @@ class Navbar extends Component
*/
public function render(): View|Closure|string
{
- return view('components.navbar');
+ return view('components.navigation');
}
}
diff --git a/app/View/Components/NeverSaid.php b/app/View/Components/NeverSaid.php
new file mode 100644
index 0000000..c9e1006
--- /dev/null
+++ b/app/View/Components/NeverSaid.php
@@ -0,0 +1,34 @@
+<?php
+
+namespace App\View\Components;
+
+use Closure;
+use Illuminate\Contracts\View\View;
+use Illuminate\View\Component;
+
+class NeverSaid extends Component
+{
+ /**
+ * Create a new component instance.
+ */
+ public function __construct()
+ {
+ //
+ }
+
+ function returnQuote(): array {
+ $quotes = config('quotes.neversaid');
+ $index = rand(0, count($quotes) - 1);
+ return $quotes[$index];
+ }
+
+ /**
+ * Get the view / contents that represent the component.
+ */
+ public function render(): View|Closure|string
+ {
+ return view('components.never-said', [
+ "quote" => $this->returnQuote()
+ ]);
+ }
+}
diff --git a/app/View/Components/TohQuote.php b/app/View/Components/TohQuote.php
new file mode 100644
index 0000000..a53d713
--- /dev/null
+++ b/app/View/Components/TohQuote.php
@@ -0,0 +1,35 @@
+<?php
+
+namespace App\View\Components;
+
+use Closure;
+use Illuminate\Contracts\View\View;
+use Illuminate\View\Component;
+
+class TohQuote extends Component
+{
+ /**
+ * Create a new component instance.
+ */
+ public function __construct()
+ {
+ //
+ }
+
+ function returnQuote(): array {
+ $quotes = config('quotes.toh');
+ $index = rand(0, count($quotes) - 1);
+ return $quotes[$index];
+ }
+
+
+ /**
+ * Get the view / contents that represent the component.
+ */
+ public function render(): View|Closure|string
+ {
+ return view('components.toh-quote',[
+ 'quote' => $this->returnQuote()
+ ]);
+ }
+}
diff --git a/app/View/Components/Weather.php b/app/View/Components/Weather.php
new file mode 100644
index 0000000..69be9fd
--- /dev/null
+++ b/app/View/Components/Weather.php
@@ -0,0 +1,44 @@
+<?php
+
+namespace App\View\Components;
+
+use Closure;
+use Illuminate\Contracts\View\View;
+use Illuminate\Support\Facades\Cache;
+use Illuminate\Support\Facades\Config;
+use Illuminate\Support\Facades\Http;
+use Illuminate\View\Component;
+
+class Weather extends Component
+{
+ /**
+ * Create a new component instance.
+ */
+ public function __construct()
+ {
+ //
+ }
+
+ public function getWeatherData(): mixed {
+ // If it's already cached just return that
+ if (Cache::has('weather_data')) {
+ return Cache::get('weather_data');
+ }
+
+ $response = Http::get('http://'. Config::get('services.weatherlink') . '/v1/current_conditions');
+ $data = $response->json();
+ $conditions = $data["data"]["conditions"];
+ Cache::put('weather_data', $conditions, now()->addSeconds(60));
+ return $conditions;
+ }
+
+ /**
+ * Get the view / contents that represent the component.
+ */
+ public function render(): View|Closure|string
+ {
+ return view('components.weather', [
+ 'conditions' => $this->getWeatherData(),
+ ]);
+ }
+}