2021-12-14 18:32:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2023-01-10 22:44:09 +00:00
|
|
|
|
|
|
|
namespace Shimmie2;
|
|
|
|
|
2024-01-05 02:03:41 +00:00
|
|
|
use MicroHTML\HTMLElement;
|
2024-01-05 04:06:19 +00:00
|
|
|
|
2024-01-05 02:03:41 +00:00
|
|
|
use function MicroHTML\INPUT;
|
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
|
|
|
* @phpstan-type NoteHistory array{image_id:int,note_id:int,review_id:int,user_name:string,note:string,date:string}
|
|
|
|
* @phpstan-type Note array{id:int,x1:int,y1:int,height:int,width:int,note:string}
|
|
|
|
*/
|
2019-05-28 17:59:38 +01:00
|
|
|
class NotesTheme extends Themelet
|
|
|
|
{
|
2024-01-05 02:03:41 +00:00
|
|
|
public function note_button(int $image_id): HTMLElement
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2024-01-05 04:06:19 +00:00
|
|
|
return SHM_SIMPLE_FORM("", INPUT(["type" => "button", "value" => "Add Note", "onclick" => "addNewNote()"]));
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2024-01-05 02:03:41 +00:00
|
|
|
public function request_button(int $image_id): HTMLElement
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2024-01-05 02:03:41 +00:00
|
|
|
return SHM_SIMPLE_FORM(
|
2024-01-05 04:06:19 +00:00
|
|
|
"note/add_request",
|
|
|
|
INPUT(["type" => "hidden", "name" => "image_id", "value" => $image_id]),
|
|
|
|
INPUT(["type" => "submit", "value" => "Add Note Request"]),
|
2024-01-05 02:03:41 +00:00
|
|
|
);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2024-01-05 02:03:41 +00:00
|
|
|
public function nuke_notes_button(int $image_id): HTMLElement
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2024-01-05 02:03:41 +00:00
|
|
|
return SHM_SIMPLE_FORM(
|
2024-01-05 04:06:19 +00:00
|
|
|
"note/nuke_notes",
|
|
|
|
INPUT(["type" => "hidden", "name" => "image_id", "value" => $image_id]),
|
|
|
|
INPUT(["type" => "submit", "value" => "Nuke Notes", "onclick" => "return confirm_action('Are you sure?')"]),
|
2024-01-05 02:03:41 +00:00
|
|
|
);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2024-01-05 02:03:41 +00:00
|
|
|
public function nuke_requests_button(int $image_id): HTMLElement
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2024-01-05 02:03:41 +00:00
|
|
|
return SHM_SIMPLE_FORM(
|
2024-01-05 04:06:19 +00:00
|
|
|
"note/nuke_requests",
|
|
|
|
INPUT(["type" => "hidden", "name" => "image_id", "value" => $image_id]),
|
|
|
|
INPUT(["type" => "submit", "value" => "Nuke Requests", "onclick" => "return confirm_action('Are you sure?')"]),
|
2024-01-05 02:03:41 +00:00
|
|
|
);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2016-05-18 14:36:50 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
// check action POST on form
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
|
|
|
* @param Note[] $recovered_notes
|
|
|
|
*/
|
2024-02-21 11:13:09 +00:00
|
|
|
public function display_note_system(Page $page, int $image_id, array $recovered_notes, bool $adminOptions, bool $editOptions): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
$to_json = [];
|
|
|
|
foreach ($recovered_notes as $note) {
|
|
|
|
$to_json[] = [
|
2024-01-05 02:03:41 +00:00
|
|
|
'image_id' => $image_id,
|
2019-05-28 17:59:38 +01:00
|
|
|
'x1' => $note["x1"],
|
|
|
|
'y1' => $note["y1"],
|
|
|
|
'height' => $note["height"],
|
|
|
|
'width' => $note["width"],
|
2024-01-05 02:03:41 +00:00
|
|
|
'note' => $note["note"],
|
2019-05-28 17:59:38 +01:00
|
|
|
'note_id' => $note["id"],
|
|
|
|
];
|
|
|
|
}
|
2024-01-05 02:03:41 +00:00
|
|
|
$page->add_html_header("<script type='text/javascript'>
|
2024-02-20 00:22:25 +00:00
|
|
|
window.notes = ".\Safe\json_encode($to_json).";
|
2024-01-05 02:03:41 +00:00
|
|
|
window.notes_image_id = $image_id;
|
|
|
|
window.notes_admin = ".($adminOptions ? "true" : "false").";
|
2024-02-21 11:13:09 +00:00
|
|
|
window.notes_edit = ".($editOptions ? "true" : "false").";
|
2024-01-05 02:03:41 +00:00
|
|
|
</script>");
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2016-05-18 14:36:50 +01:00
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
2024-01-20 20:48:47 +00:00
|
|
|
* @param array<Image> $images
|
2024-01-20 14:10:59 +00:00
|
|
|
*/
|
|
|
|
public function display_note_list(array $images, int $pageNumber, int $totalPages): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
|
|
|
$pool_images = '';
|
2024-01-20 20:48:47 +00:00
|
|
|
foreach ($images as $image) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$thumb_html = $this->build_thumb_html($image);
|
2009-11-24 14:07:18 +00:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$pool_images .= '<span class="thumb">'.
|
|
|
|
' <a href="$image_link">'.$thumb_html.'</a>'.
|
|
|
|
'</span>';
|
|
|
|
}
|
|
|
|
$this->display_paginator($page, "note/list", null, $pageNumber, $totalPages);
|
2016-05-18 14:36:50 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$page->set_title("Notes");
|
|
|
|
$page->set_heading("Notes");
|
|
|
|
$page->add_block(new Block("Notes", $pool_images, "main", 20));
|
|
|
|
}
|
2009-11-24 14:07:18 +00:00
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
2024-01-20 20:48:47 +00:00
|
|
|
* @param array<Image> $images
|
2024-01-20 14:10:59 +00:00
|
|
|
*/
|
|
|
|
public function display_note_requests(array $images, int $pageNumber, int $totalPages): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
2016-05-18 14:36:50 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$pool_images = '';
|
2024-01-20 20:48:47 +00:00
|
|
|
foreach ($images as $image) {
|
2019-05-28 17:59:38 +01:00
|
|
|
$thumb_html = $this->build_thumb_html($image);
|
|
|
|
$pool_images .= '<span class="thumb">'.
|
|
|
|
' <a href="$image_link">'.$thumb_html.'</a>'.
|
|
|
|
'</span>';
|
|
|
|
}
|
|
|
|
$this->display_paginator($page, "requests/list", null, $pageNumber, $totalPages);
|
2009-11-24 14:07:18 +00:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$page->set_title("Note Requests");
|
|
|
|
$page->set_heading("Note Requests");
|
|
|
|
$page->add_block(new Block("Note Requests", $pool_images, "main", 20));
|
|
|
|
}
|
2009-11-24 14:07:18 +00:00
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
|
|
|
* @param NoteHistory[] $histories
|
|
|
|
*/
|
2021-03-14 23:43:50 +00:00
|
|
|
private function get_history(array $histories): string
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $user;
|
2016-05-18 14:36:50 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$html = "<table id='poolsList' class='zebra'>".
|
|
|
|
"<thead><tr>".
|
2020-10-26 10:22:03 -05:00
|
|
|
"<th>Post</th>".
|
2019-05-28 17:59:38 +01:00
|
|
|
"<th>Note</th>".
|
|
|
|
"<th>Body</th>".
|
|
|
|
"<th>Updater</th>".
|
|
|
|
"<th>Date</th>";
|
2009-11-24 14:07:18 +00:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
if (!$user->is_anonymous()) {
|
|
|
|
$html .= "<th>Action</th>";
|
|
|
|
}
|
2016-05-18 14:36:50 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$html .= "</tr></thead>".
|
|
|
|
"<tbody>";
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
foreach ($histories as $history) {
|
|
|
|
$image_link = "<a href='".make_link("post/view/".$history['image_id'])."'>".$history['image_id']."</a>";
|
|
|
|
$history_link = "<a href='".make_link("note/history/".$history['note_id'])."'>".$history['note_id'].".".$history['review_id']."</a>";
|
|
|
|
$user_link = "<a href='".make_link("user/".$history['user_name'])."'>".$history['user_name']."</a>";
|
|
|
|
$revert_link = "<a href='".make_link("note/revert/".$history['note_id']."/".$history['review_id'])."'>Revert</a>";
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$html .= "<tr>".
|
|
|
|
"<td>".$image_link."</td>".
|
|
|
|
"<td>".$history_link."</td>".
|
|
|
|
"<td style='text-align:left;'>".$history['note']."</td>".
|
|
|
|
"<td>".$user_link."</td>".
|
|
|
|
"<td>".autodate($history['date'])."</td>";
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
if (!$user->is_anonymous()) {
|
|
|
|
$html .= "<td>".$revert_link."</td>";
|
|
|
|
}
|
|
|
|
}
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$html .= "</tr></tbody></table>";
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
return $html;
|
|
|
|
}
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
|
|
|
* @param NoteHistory[] $histories
|
|
|
|
*/
|
|
|
|
public function display_histories(array $histories, int $pageNumber, int $totalPages): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$html = $this->get_history($histories);
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$page->set_title("Note Updates");
|
|
|
|
$page->set_heading("Note Updates");
|
|
|
|
$page->add_block(new Block("Note Updates", $html, "main", 10));
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->display_paginator($page, "note/updated", null, $pageNumber, $totalPages);
|
|
|
|
}
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
|
|
|
* @param NoteHistory[] $histories
|
|
|
|
*/
|
|
|
|
public function display_history(array $histories, int $pageNumber, int $totalPages): void
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
|
|
|
global $page;
|
|
|
|
|
|
|
|
$html = $this->get_history($histories);
|
|
|
|
|
|
|
|
$page->set_title("Note History");
|
|
|
|
$page->set_heading("Note History");
|
|
|
|
$page->add_block(new Block("Note History", $html, "main", 10));
|
2014-03-30 13:26:48 +01:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
$this->display_paginator($page, "note/updated", null, $pageNumber, $totalPages);
|
|
|
|
}
|
2019-08-02 15:05:49 -05:00
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
public function get_help_html(): string
|
2019-08-02 15:05:49 -05:00
|
|
|
{
|
2020-10-26 10:22:03 -05:00
|
|
|
return '<p>Search for posts with notes.</p>
|
2019-08-02 15:05:49 -05:00
|
|
|
<div class="command_example">
|
|
|
|
<pre>note=noted</pre>
|
2020-10-26 10:22:03 -05:00
|
|
|
<p>Returns posts with a note matching "noted".</p>
|
2020-10-24 23:46:32 +01:00
|
|
|
</div>
|
2019-08-02 15:05:49 -05:00
|
|
|
<div class="command_example">
|
|
|
|
<pre>notes>0</pre>
|
2020-10-26 10:22:03 -05:00
|
|
|
<p>Returns posts with 1 or more notes.</p>
|
2019-08-02 15:05:49 -05:00
|
|
|
</div>
|
|
|
|
<p>Can use <, <=, >, >=, or =.</p>
|
|
|
|
<div class="command_example">
|
|
|
|
<pre>notes_by=username</pre>
|
2020-10-26 10:22:03 -05:00
|
|
|
<p>Returns posts with note(s) by "username".</p>
|
2019-08-02 15:05:49 -05:00
|
|
|
</div>
|
|
|
|
<div class="command_example">
|
|
|
|
<pre>notes_by_user_id=123</pre>
|
2020-10-26 10:22:03 -05:00
|
|
|
<p>Returns posts with note(s) by user 123.</p>
|
2019-08-02 15:05:49 -05:00
|
|
|
</div>
|
|
|
|
';
|
|
|
|
}
|
2014-04-26 03:56:06 -04:00
|
|
|
}
|