]> jfr.im git - irc/unrealircd/unrealircd-webpanel.git/blobdiff - index.php
Overview buttons fully operational
[irc/unrealircd/unrealircd-webpanel.git] / index.php
index dd0d60fe3f4b24a9cb23543304ffa9e3fdece57a..61fef15b2ab0ba6efdcce9224442d75267921a85 100644 (file)
--- a/index.php
+++ b/index.php
@@ -2,23 +2,38 @@
 require_once "common.php";
 require_once "header.php";
 
-rpc_pop_lists();
+$stats = $rpc->query("stats.get", []);
 ?>
 
 <h2>Network Overview</h2>
 
-<div class="container mt-5">
+<?php
+$array_of_stats = (array)$stats;
 
-       <div class="row">
-               <div class="col-sm">
+/* What if someone wants to add their own stats... */
+Hook::run(HOOKTYPE_PRE_OVERVIEW_CARD, $array_of_stats);
+
+/* This makes sure that a plugin which called the parameter
+ * by reference can add/update the stats for display here.
+*/
+$stats = (object) $array_of_stats;
+
+
+?>
+<div class="container">
+
+       <div class="row mt-3">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-success text-white">
                                        <div class="row">
                                                <div class="col">
-                                                       <i class="fa fa-users fa-3x"></i>
+                                                       <i class="fa fa-users fa-3x"></i><span class="position-absolute badge rounded-pill badge-warning">
+                                                       <?php echo "Record: ".$stats->user->record; ?>
+                                               </span>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$user); ?></h3>
+                                                       <h3 class="display-4"><?php echo $stats->user->total; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -31,8 +46,10 @@ rpc_pop_lists();
                                        </div>
                                </div>
                        </div>
+                       
+
                </div>
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-primary text-white">
                                        <div class="row">
@@ -40,7 +57,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-hashtag fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$channel); ?></h3>
+                                                       <h3 class="display-4"><?php echo $stats->channel->total; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -54,7 +71,7 @@ rpc_pop_lists();
                                </div>
                        </div>
                </div>
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-warning">
                                        <div class="row">
@@ -62,7 +79,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-shield-halved fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo RPC_List::$opercount; ?></h3>
+                                                       <h3 class="display-4"><?php echo $stats->user->oper; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -71,14 +88,13 @@ rpc_pop_lists();
                                                <div class="col">
                                                        <h6>Opers</h6>
                                                </div>
-                                               <!-- TODO: Filter opers in user list and make this do that -->
-                                               <div class="col"><a class="btn btn-secondary disabled" href="#">View</a></div>
+                                               <div class="col"><a class="btn btn-primary" href="<?php echo BASE_URL."users/?operonly"; ?>">View</a></div>
                                        </div>
                                </div>
                        </div>
                </div>
 
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-secondary text-white">
                                        <div class="row">
@@ -86,7 +102,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-network-wired fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$server); ?></h3>
+                                                       <h3 class="display-4"><?php echo $stats->server->total; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -95,7 +111,7 @@ rpc_pop_lists();
                                                <div class="col">
                                                        <h6>Servers</h6>
                                                </div>
-                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>network">View</a></div>
+                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>servers">View</a></div>
                                        </div>
                                </div>
                        </div>
@@ -105,7 +121,7 @@ rpc_pop_lists();
 <div class="container mt-3">
 
        <div class="row">
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-danger text-white">
                                        <div class="row">
@@ -113,7 +129,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-ban fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$tkl); ?></h3>
+                                                       <h3 class="display-4"><?php echo $stats->server_ban->server_ban; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -122,12 +138,12 @@ rpc_pop_lists();
                                                <div class="col">
                                                        <h6>Server Bans</h6>
                                                </div>
-                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>server_bans.php">View</a></div>
+                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>server-bans">View</a></div>
                                        </div>
                                </div>
                        </div>
                </div>
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-secondary text-white">
                                        <div class="row">
@@ -135,7 +151,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-filter fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$spamfilter); ?></h3>
+                                                       <h3 class="display-4"><?php echo $stats->server_ban->spamfilter; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -149,7 +165,7 @@ rpc_pop_lists();
                                </div>
                        </div>
                </div>
-               <div class="col-sm">
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header bg-primary text-white">
                                        <div class="row">
@@ -157,7 +173,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-door-open fa-3x"></i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo count(RPC_List::$exception); ?></h3>
+                                                       <h3 class="display-4"><?php echo $stats->server_ban->server_ban_exception; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -167,16 +183,25 @@ rpc_pop_lists();
                                                <div class="col">
                                                        <h6>Server Ban Exceptions</h6>
                                                </div>
-                                               <div class="col"> <a class="btn btn-secondary disabled" href="#">View</a></div>
+                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL; ?>server-bans/ban-exceptions.php">View</a></div>
                                        </div>
                                </div>
                        </div>
                </div>
                <?php
-               if (RPC_List::$services_count) {
+               if ($stats->server->ulined) {
                        $bg = "bg-success";
-               } ?> 
-               <div class="col-sm">
+
+                       /* honestly can't think of a case where there would actually be only one uline... but... well here we are, worrying over the small stuff =] */
+                       $user_noun = ($stats->user->ulined == 1) ? "user" : "users"; // use "users" even if 0, sounds better.
+                       $is_are = ($stats->user->ulined == 1) ? "is" : "are";
+                       $server_noun = ($stats->server->ulined == 1) ? "server" : "servers";
+                       $tooltip = "There $is_are " . $stats->user->ulined . " U-Lined $user_noun over " . $stats->server->ulined . " U-Lined $server_noun";
+               }
+               else
+                       $bg = "bg-warning";
+               ?> 
+               <div class="col-sm mb-3">
                        <div class="card text-center">
                                <div class="card-header <?php echo $bg; ?> text-white">
                                        <div class="row">
@@ -184,7 +209,7 @@ rpc_pop_lists();
                                                        <i class="fa fa-database fa-3x"> </i>
                                                </div>
                                                <div class="col">
-                                                       <h3 class="display-4"><?php echo RPC_List::$services_count; ?></h3>
+                                               <span data-toggle="tooltip" title="<?php echo $tooltip; ?>" style="border-bottom: 1px dotted #000000"><h3 class="display-4"><?php echo $stats->user->ulined; ?>/<?php echo $stats->server->ulined; ?></h3>
                                                </div>
                                        </div>
                                </div>
@@ -193,7 +218,7 @@ rpc_pop_lists();
                                                <div class="col">
                                                        <h6>Services Online</h6>
                                                </div>
-                                               <div class="col"> <a class="btn btn-secondary disabled" href="#">View</a></div>
+                                               <div class="col"> <a class="btn btn-primary" href="<?php echo BASE_URL."users/?servicesonly"; ?>">View</a></div>
                                        </div>
                                </div>
                                
@@ -204,4 +229,6 @@ rpc_pop_lists();
 
 <?php
 
+Hook::run(HOOKTYPE_OVERVIEW_CARD, $stats);
+
 require_once "footer.php";