2021-12-14 18:32:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2019-08-07 14:53:59 -05:00
|
|
|
|
2023-01-10 22:44:09 +00:00
|
|
|
namespace Shimmie2;
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
class Blotter extends Extension
|
|
|
|
{
|
2020-02-04 00:46:36 +00:00
|
|
|
/** @var BlotterTheme */
|
2021-03-14 23:43:50 +00:00
|
|
|
protected ?Themelet $theme;
|
2020-02-04 00:46:36 +00:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
public function onInitExt(InitExtEvent $event)
|
|
|
|
{
|
2019-11-03 17:19:37 +00:00
|
|
|
global $config;
|
|
|
|
$config->set_default_int("blotter_recent", 5);
|
|
|
|
$config->set_default_string("blotter_color", "FF0000");
|
|
|
|
$config->set_default_string("blotter_position", "subheading");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function onDatabaseUpgrade(DatabaseUpgradeEvent $event)
|
|
|
|
{
|
2020-10-29 00:57:58 +00:00
|
|
|
global $database;
|
2020-10-26 18:10:34 +00:00
|
|
|
|
2020-10-29 00:57:58 +00:00
|
|
|
if ($this->get_version("blotter_version") < 1) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$database->create_table("blotter", "
|
2020-10-26 18:10:34 +00:00
|
|
|
id SCORE_AIPK,
|
|
|
|
entry_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
|
|
entry_text TEXT NOT NULL,
|
2020-10-26 22:37:25 +00:00
|
|
|
important BOOLEAN NOT NULL DEFAULT FALSE
|
2020-10-26 18:10:34 +00:00
|
|
|
");
|
2019-05-28 17:59:38 +01:00
|
|
|
// Insert sample data:
|
|
|
|
$database->execute(
|
2019-11-27 11:22:46 +00:00
|
|
|
"INSERT INTO blotter (entry_date, entry_text, important) VALUES (now(), :text, :important)",
|
2020-10-26 18:10:34 +00:00
|
|
|
["text"=>"Installed the blotter extension!", "important"=>true]
|
2019-05-28 17:59:38 +01:00
|
|
|
);
|
|
|
|
log_info("blotter", "Installed tables for blotter extension.");
|
2020-10-29 00:57:58 +00:00
|
|
|
$this->set_version("blotter_version", 2);
|
2020-10-26 18:10:34 +00:00
|
|
|
}
|
2020-10-29 00:57:58 +00:00
|
|
|
if ($this->get_version("blotter_version") < 2) {
|
2020-10-26 18:10:34 +00:00
|
|
|
$database->standardise_boolean("blotter", "important");
|
2020-10-29 00:57:58 +00:00
|
|
|
$this->set_version("blotter_version", 2);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
|
|
|
}
|
2012-08-15 19:46:36 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
public function onSetupBuilding(SetupBuildingEvent $event)
|
|
|
|
{
|
2020-10-26 10:13:28 -05:00
|
|
|
$sb = $event->panel->create_new_block("Blotter");
|
2019-05-28 17:59:38 +01:00
|
|
|
$sb->add_int_option("blotter_recent", "<br />Number of recent entries to display: ");
|
|
|
|
$sb->add_text_option("blotter_color", "<br />Color of important updates: (ABCDEF format) ");
|
|
|
|
$sb->add_choice_option("blotter_position", ["Top of page" => "subheading", "In navigation bar" => "left"], "<br>Position: ");
|
|
|
|
}
|
2012-08-15 19:46:36 +01:00
|
|
|
|
2019-08-02 14:54:48 -05:00
|
|
|
public function onPageSubNavBuilding(PageSubNavBuildingEvent $event)
|
|
|
|
{
|
|
|
|
global $user;
|
2019-09-29 14:30:55 +01:00
|
|
|
if ($event->parent==="system") {
|
2019-09-29 19:00:51 +01:00
|
|
|
if ($user->can(Permissions::BLOTTER_ADMIN)) {
|
2019-08-02 14:54:48 -05:00
|
|
|
$event->add_nav_link("blotter", new Link('blotter/editor'), "Blotter Editor");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
public function onUserBlockBuilding(UserBlockBuildingEvent $event)
|
|
|
|
{
|
|
|
|
global $user;
|
2019-09-29 19:00:51 +01:00
|
|
|
if ($user->can(Permissions::BLOTTER_ADMIN)) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$event->add_link("Blotter Editor", make_link("blotter/editor"));
|
|
|
|
}
|
|
|
|
}
|
2012-08-15 19:46:36 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
public function onPageRequest(PageRequestEvent $event)
|
|
|
|
{
|
|
|
|
global $page, $database, $user;
|
2019-11-04 00:40:10 +00:00
|
|
|
if ($event->page_matches("blotter") && $event->count_args() > 0) {
|
2019-05-28 17:59:38 +01:00
|
|
|
switch ($event->get_arg(0)) {
|
|
|
|
case "editor":
|
|
|
|
/**
|
|
|
|
* Displays the blotter editor.
|
|
|
|
*/
|
2019-09-29 19:00:51 +01:00
|
|
|
if (!$user->can(Permissions::BLOTTER_ADMIN)) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->theme->display_permission_denied();
|
|
|
|
} else {
|
|
|
|
$entries = $database->get_all("SELECT * FROM blotter ORDER BY id DESC");
|
|
|
|
$this->theme->display_editor($entries);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case "add":
|
|
|
|
/**
|
|
|
|
* Adds an entry
|
|
|
|
*/
|
2019-09-29 19:00:51 +01:00
|
|
|
if (!$user->can(Permissions::BLOTTER_ADMIN) || !$user->check_auth_token()) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->theme->display_permission_denied();
|
|
|
|
} else {
|
|
|
|
$entry_text = $_POST['entry_text'];
|
|
|
|
if ($entry_text == "") {
|
|
|
|
die("No entry message!");
|
|
|
|
}
|
2020-10-26 18:10:34 +00:00
|
|
|
$important = isset($_POST['important']);
|
2019-05-28 17:59:38 +01:00
|
|
|
// Now insert into db:
|
|
|
|
$database->execute(
|
2019-11-27 11:22:46 +00:00
|
|
|
"INSERT INTO blotter (entry_date, entry_text, important) VALUES (now(), :text, :important)",
|
|
|
|
["text"=>$entry_text, "important"=>$important]
|
2019-05-28 17:59:38 +01:00
|
|
|
);
|
|
|
|
log_info("blotter", "Added Message: $entry_text");
|
2019-06-18 20:58:28 -05:00
|
|
|
$page->set_mode(PageMode::REDIRECT);
|
2019-05-28 17:59:38 +01:00
|
|
|
$page->set_redirect(make_link("blotter/editor"));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case "remove":
|
|
|
|
/**
|
|
|
|
* Removes an entry
|
|
|
|
*/
|
2019-09-29 19:00:51 +01:00
|
|
|
if (!$user->can(Permissions::BLOTTER_ADMIN) || !$user->check_auth_token()) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->theme->display_permission_denied();
|
|
|
|
} else {
|
|
|
|
$id = int_escape($_POST['id']);
|
2020-10-25 21:34:52 +00:00
|
|
|
$database->execute("DELETE FROM blotter WHERE id=:id", ["id"=>$id]);
|
2019-05-28 17:59:38 +01:00
|
|
|
log_info("blotter", "Removed Entry #$id");
|
2019-06-18 20:58:28 -05:00
|
|
|
$page->set_mode(PageMode::REDIRECT);
|
2019-05-28 17:59:38 +01:00
|
|
|
$page->set_redirect(make_link("blotter/editor"));
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case "list":
|
|
|
|
/**
|
|
|
|
* Displays all blotter entries
|
|
|
|
*/
|
|
|
|
$entries = $database->get_all("SELECT * FROM blotter ORDER BY id DESC");
|
|
|
|
$this->theme->display_blotter_page($entries);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Finally, display the blotter on whatever page we're viewing.
|
|
|
|
*/
|
|
|
|
$this->display_blotter();
|
|
|
|
}
|
2010-02-18 14:12:52 +00:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
private function display_blotter()
|
|
|
|
{
|
|
|
|
global $database, $config;
|
|
|
|
$limit = $config->get_int("blotter_recent", 5);
|
|
|
|
$sql = 'SELECT * FROM blotter ORDER BY id DESC LIMIT '.intval($limit);
|
|
|
|
$entries = $database->get_all($sql);
|
|
|
|
$this->theme->display_blotter($entries);
|
|
|
|
}
|
2010-02-18 14:12:52 +00:00
|
|
|
}
|