2021-12-14 18:32:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2007-07-16 14:36:29 +00:00
|
|
|
|
2023-01-10 22:44:09 +00:00
|
|
|
namespace Shimmie2;
|
|
|
|
|
2023-12-31 01:10:03 +00:00
|
|
|
use MicroHTML\HTMLElement;
|
|
|
|
|
2024-06-21 17:29:26 +00:00
|
|
|
use function MicroHTML\{A, joinHTML, TABLE, TR, TD, INPUT, emptyHTML, DIV, BR, META, LINK};
|
2023-12-31 01:10:03 +00:00
|
|
|
|
2023-12-31 01:20:36 +00:00
|
|
|
class ViewPostTheme extends Themelet
|
2019-05-28 16:59:38 +00:00
|
|
|
{
|
2024-01-15 14:23:00 +00:00
|
|
|
public function display_meta_headers(Image $image): void
|
2019-05-28 16:59:38 +00:00
|
|
|
{
|
|
|
|
global $page;
|
2010-05-28 01:07:33 +00:00
|
|
|
|
2024-06-21 17:29:26 +00:00
|
|
|
$h_metatags = str_replace(" ", ", ", $image->get_tag_list());
|
|
|
|
$page->add_html_header(META(["name" => "keywords", "content" => $h_metatags]));
|
|
|
|
$page->add_html_header(META(["property" => "og:title", "content" => $h_metatags]));
|
|
|
|
$page->add_html_header(META(["property" => "og:type", "content" => "article"]));
|
|
|
|
$page->add_html_header(META(["property" => "og:image", "content" => make_http($image->get_thumb_link())]));
|
|
|
|
$page->add_html_header(META(["property" => "og:url", "content" => make_http(make_link("post/view/{$image->id}"))]));
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2018-11-05 19:17:42 +00:00
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
2019-05-28 16:59:38 +00:00
|
|
|
* Build a page showing $image and some info about it
|
2024-01-20 14:10:59 +00:00
|
|
|
*
|
|
|
|
* @param HTMLElement[] $editor_parts
|
2019-05-28 16:59:38 +00:00
|
|
|
*/
|
2024-01-20 14:10:59 +00:00
|
|
|
public function display_page(Image $image, array $editor_parts): void
|
2019-05-28 16:59:38 +00:00
|
|
|
{
|
|
|
|
global $page;
|
2020-10-26 15:13:47 +00:00
|
|
|
$page->set_title("Post {$image->id}: ".$image->get_tag_list());
|
2019-05-28 16:59:38 +00:00
|
|
|
$page->set_heading(html_escape($image->get_tag_list()));
|
2023-01-30 21:35:38 +00:00
|
|
|
$page->add_block(new Block("Post {$image->id}", $this->build_navigation($image), "left", 0, "Navigationleft"));
|
2021-02-09 06:39:04 +00:00
|
|
|
$page->add_block(new Block(null, $this->build_info($image, $editor_parts), "main", 20, "ImageInfo"));
|
2019-05-28 16:59:38 +00:00
|
|
|
//$page->add_block(new Block(null, $this->build_pin($image), "main", 11));
|
2020-02-04 01:12:50 +00:00
|
|
|
|
|
|
|
$query = $this->get_query();
|
2024-08-31 16:05:18 +00:00
|
|
|
if (!$this->is_ordered_search()) {
|
2024-06-21 17:29:26 +00:00
|
|
|
$page->add_html_header(LINK(["id" => "nextlink", "rel" => "next", "href" => make_link("post/next/{$image->id}", $query)]));
|
|
|
|
$page->add_html_header(LINK(["id" => "prevlink", "rel" => "previous", "href" => make_link("post/prev/{$image->id}", $query)]));
|
2024-01-04 19:21:55 +00:00
|
|
|
}
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2007-07-16 14:36:29 +00:00
|
|
|
|
2024-01-19 18:57:02 +00:00
|
|
|
/**
|
|
|
|
* @param HTMLElement[] $parts
|
|
|
|
*/
|
|
|
|
public function display_admin_block(Page $page, array $parts): void
|
2019-05-28 16:59:38 +00:00
|
|
|
{
|
|
|
|
if (count($parts) > 0) {
|
2024-01-20 14:10:59 +00:00
|
|
|
$page->add_block(new Block("Post Controls", DIV(["class" => "post_controls"], joinHTML("", $parts)), "left", 50));
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
|
|
|
}
|
2008-06-14 11:36:19 +00:00
|
|
|
|
2021-03-14 23:43:50 +00:00
|
|
|
protected function get_query(): ?string
|
2020-02-04 01:15:25 +00:00
|
|
|
{
|
2019-05-28 16:59:38 +00:00
|
|
|
if (isset($_GET['search'])) {
|
2023-12-24 21:12:59 +00:00
|
|
|
$query = "search=".url_escape($_GET['search']);
|
2019-05-28 16:59:38 +00:00
|
|
|
} else {
|
|
|
|
$query = null;
|
|
|
|
}
|
2020-02-04 01:12:50 +00:00
|
|
|
return $query;
|
|
|
|
}
|
2009-01-04 19:18:37 +00:00
|
|
|
|
2024-01-04 19:21:55 +00:00
|
|
|
/**
|
|
|
|
* prev/next only work for default-ordering searches - if the user
|
|
|
|
* has specified a custom order, we can't show prev/next.
|
|
|
|
*/
|
|
|
|
protected function is_ordered_search(): bool
|
|
|
|
{
|
2024-08-31 16:05:18 +00:00
|
|
|
if (isset($_GET['search'])) {
|
2024-01-04 19:21:55 +00:00
|
|
|
$tags = Tag::explode($_GET['search']);
|
2024-08-31 16:05:18 +00:00
|
|
|
foreach ($tags as $tag) {
|
|
|
|
if (preg_match("/^order[=:]/", $tag) == 1) {
|
2024-01-04 19:21:55 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2023-12-31 01:10:03 +00:00
|
|
|
protected function build_pin(Image $image): HTMLElement
|
2020-02-04 01:12:50 +00:00
|
|
|
{
|
|
|
|
$query = $this->get_query();
|
2024-08-31 16:05:18 +00:00
|
|
|
if ($this->is_ordered_search()) {
|
2024-01-04 19:21:55 +00:00
|
|
|
return A(["href" => make_link()], "Index");
|
|
|
|
} else {
|
|
|
|
return joinHTML(" | ", [
|
|
|
|
A(["href" => make_link("post/prev/{$image->id}", $query), "id" => "prevlink"], "Prev"),
|
|
|
|
A(["href" => make_link()], "Index"),
|
|
|
|
A(["href" => make_link("post/next/{$image->id}", $query), "id" => "nextlink"], "Next"),
|
|
|
|
]);
|
|
|
|
}
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2007-07-16 14:36:29 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
protected function build_navigation(Image $image): string
|
|
|
|
{
|
|
|
|
$h_pin = $this->build_pin($image);
|
|
|
|
$h_search = "
|
2024-02-12 11:11:14 +00:00
|
|
|
<p><form action='".search_link()."' method='GET'>
|
|
|
|
<input type='hidden' name='q' value='post/list'>
|
2023-12-26 12:53:46 +00:00
|
|
|
<input type='search' name='search' placeholder='Search' class='autocomplete_tags'>
|
2007-07-16 14:36:29 +00:00
|
|
|
<input type='submit' value='Find' style='display: none;'>
|
|
|
|
</form>
|
2012-02-09 14:38:32 +00:00
|
|
|
";
|
2007-07-16 14:36:29 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
return "$h_pin<br>$h_search";
|
|
|
|
}
|
2007-07-16 14:36:29 +00:00
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
|
|
|
* @param HTMLElement[] $editor_parts
|
|
|
|
*/
|
|
|
|
protected function build_info(Image $image, array $editor_parts): HTMLElement
|
2019-05-28 16:59:38 +00:00
|
|
|
{
|
|
|
|
global $user;
|
2007-07-16 14:36:29 +00:00
|
|
|
|
2019-05-28 16:59:38 +00:00
|
|
|
if (count($editor_parts) == 0) {
|
2023-12-31 01:10:03 +00:00
|
|
|
return emptyHTML($image->is_locked() ? "[Post Locked]" : "");
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2008-12-16 05:29:48 +00:00
|
|
|
|
2024-08-31 16:05:18 +00:00
|
|
|
if (
|
2019-07-09 14:10:21 +00:00
|
|
|
(!$image->is_locked() || $user->can(Permissions::EDIT_IMAGE_LOCK)) &&
|
|
|
|
$user->can(Permissions::EDIT_IMAGE_TAG)
|
2019-05-28 16:59:38 +00:00
|
|
|
) {
|
2023-12-31 01:10:03 +00:00
|
|
|
$editor_parts[] = TR(TD(
|
|
|
|
["colspan" => 4],
|
|
|
|
INPUT(["class" => "view", "type" => "button", "value" => "Edit", "onclick" => "clearViewMode()"]),
|
|
|
|
INPUT(["class" => "edit", "type" => "submit", "value" => "Set"])
|
|
|
|
));
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2023-12-31 01:10:03 +00:00
|
|
|
|
|
|
|
return SHM_SIMPLE_FORM(
|
|
|
|
"post/set",
|
|
|
|
INPUT(["type" => "hidden", "name" => "image_id", "value" => $image->id]),
|
|
|
|
TABLE(
|
|
|
|
[
|
|
|
|
"class" => "image_info form",
|
|
|
|
],
|
|
|
|
...$editor_parts,
|
|
|
|
),
|
|
|
|
);
|
2019-05-28 16:59:38 +00:00
|
|
|
}
|
2007-07-16 14:36:29 +00:00
|
|
|
}
|