2021-12-14 18:32:47 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
2007-10-02 21:59:20 +00:00
|
|
|
|
2023-01-10 22:44:09 +00:00
|
|
|
namespace Shimmie2;
|
|
|
|
|
2023-06-29 02:50:32 -03:00
|
|
|
use MicroHTML\HTMLElement;
|
|
|
|
|
2023-06-29 14:44:57 -03:00
|
|
|
use function MicroHTML\emptyHTML;
|
2023-08-18 12:21:48 +01:00
|
|
|
use function MicroHTML\{A,P,TABLE,TD,TH,TR};
|
2023-06-29 02:50:32 -03:00
|
|
|
|
2019-05-28 17:59:38 +01:00
|
|
|
class RatingsTheme extends Themelet
|
|
|
|
{
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
2024-01-20 20:48:47 +00:00
|
|
|
* @param array<string, string> $ratings
|
2024-01-20 14:10:59 +00:00
|
|
|
* @param string[] $selected_options
|
|
|
|
*/
|
2023-06-29 02:50:32 -03:00
|
|
|
public function get_selection_rater_html(string $name = "rating", array $ratings = [], array $selected_options = []): HTMLElement
|
|
|
|
{
|
2023-07-04 19:20:43 -03:00
|
|
|
return SHM_SELECT($name, !empty($ratings) ? $ratings : Ratings::get_ratings_dict(), required: true, selected_options: $selected_options);
|
2023-06-29 02:50:32 -03:00
|
|
|
}
|
|
|
|
|
2024-03-28 01:47:03 +00:00
|
|
|
public function get_image_rater_html(int $image_id, string $rating, bool $can_rate): HTMLElement
|
2019-05-28 17:59:38 +01:00
|
|
|
{
|
2023-08-17 18:09:38 +01:00
|
|
|
return SHM_POST_INFO(
|
|
|
|
"Rating",
|
2023-11-11 21:49:12 +00:00
|
|
|
A(["href" => search_link(["rating=$rating"])], Ratings::rating_to_human($rating)),
|
2023-12-19 11:36:35 +00:00
|
|
|
$can_rate ? $this->get_selection_rater_html("rating", selected_options: [$rating]) : null
|
2023-08-17 18:09:38 +01:00
|
|
|
);
|
2019-05-28 17:59:38 +01:00
|
|
|
}
|
2007-11-04 08:16:41 +00:00
|
|
|
|
2024-03-28 01:47:03 +00:00
|
|
|
public function get_upload_specific_rater_html(string $suffix): HTMLElement
|
|
|
|
{
|
2024-04-12 02:55:32 +01:00
|
|
|
return TD($this->get_selection_rater_html(name:"rating{$suffix}", selected_options: ["?"]));
|
2024-03-28 01:47:03 +00:00
|
|
|
}
|
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
2024-01-20 20:48:47 +00:00
|
|
|
* @param array<string,string> $current_ratings
|
2024-01-20 14:10:59 +00:00
|
|
|
*/
|
2024-01-15 14:23:00 +00:00
|
|
|
public function display_form(array $current_ratings): void
|
2019-06-26 23:11:59 -05:00
|
|
|
{
|
2019-10-02 11:23:57 +01:00
|
|
|
global $page;
|
2019-06-26 23:11:59 -05:00
|
|
|
|
2023-07-04 19:20:43 -03:00
|
|
|
$table = TABLE(
|
2023-11-11 21:49:12 +00:00
|
|
|
["class" => "form"],
|
2023-06-29 14:44:57 -03:00
|
|
|
TR(TH("Change"), TD($this->get_selection_rater_html("rating_old", $current_ratings))),
|
|
|
|
TR(TH("To"), TD($this->get_selection_rater_html("rating_new"))),
|
2023-11-11 21:49:12 +00:00
|
|
|
TR(TD(["colspan" => "2"], SHM_SUBMIT("Update")))
|
2023-07-04 19:20:43 -03:00
|
|
|
);
|
2023-06-25 20:05:38 -03:00
|
|
|
|
2023-07-04 19:20:43 -03:00
|
|
|
$page->add_block(new Block("Update Ratings", SHM_SIMPLE_FORM("admin/update_ratings", $table)));
|
2019-06-26 23:11:59 -05:00
|
|
|
}
|
|
|
|
|
2024-01-20 14:10:59 +00:00
|
|
|
/**
|
|
|
|
* @param ImageRating[] $ratings
|
|
|
|
*/
|
2023-06-29 14:44:57 -03:00
|
|
|
public function get_help_html(array $ratings): HTMLElement
|
2019-08-02 15:05:49 -05:00
|
|
|
{
|
2023-07-04 19:20:43 -03:00
|
|
|
$rating_rows = [TR(TH("Name"), TH("Search Term"), TH("Abbreviation"))];
|
|
|
|
foreach ($ratings as $rating) {
|
|
|
|
$rating_rows[] = TR(TD($rating->name), TD($rating->search_term), TD($rating->code));
|
|
|
|
}
|
|
|
|
|
|
|
|
return emptyHTML(
|
2023-06-29 14:44:57 -03:00
|
|
|
P("Search for posts with one or more possible ratings."),
|
2023-07-04 19:20:43 -03:00
|
|
|
SHM_COMMAND_EXAMPLE(
|
|
|
|
"rating:" . $ratings[0]->search_term,
|
|
|
|
"Returns posts with the " . $ratings[0]->name . " rating."
|
2023-06-29 14:44:57 -03:00
|
|
|
),
|
|
|
|
P("Ratings can be abbreviated to a single letter as well."),
|
2023-07-04 19:20:43 -03:00
|
|
|
SHM_COMMAND_EXAMPLE(
|
|
|
|
"rating:" . $ratings[0]->code,
|
|
|
|
"Returns posts with the " . $ratings[0]->name . " rating."
|
2023-06-29 14:44:57 -03:00
|
|
|
),
|
|
|
|
P("If abbreviations are used, multiple ratings can be searched for."),
|
2023-07-04 19:20:43 -03:00
|
|
|
SHM_COMMAND_EXAMPLE(
|
|
|
|
"rating:" . $ratings[0]->code . $ratings[1]->code,
|
|
|
|
"Returns posts with the " . $ratings[0]->name . " or " . $ratings[1]->name . " rating."
|
2023-06-29 14:44:57 -03:00
|
|
|
),
|
2023-07-04 19:20:43 -03:00
|
|
|
P("Available ratings:"),
|
|
|
|
TABLE(...$rating_rows)
|
2023-06-29 14:44:57 -03:00
|
|
|
);
|
2019-08-14 09:07:45 -05:00
|
|
|
}
|
2019-10-02 11:23:57 +01:00
|
|
|
|
2023-06-25 20:05:38 -03:00
|
|
|
// This wasn't being used at all
|
|
|
|
|
|
|
|
/* public function get_user_options(User $user, array $selected_ratings, array $available_ratings): string
|
2019-06-26 23:11:59 -05:00
|
|
|
{
|
|
|
|
$html = "
|
|
|
|
<p>".make_form(make_link("user_admin/default_ratings"))."
|
|
|
|
<input type='hidden' name='id' value='$user->id'>
|
|
|
|
<table style='width: 300px;'>
|
|
|
|
<thead>
|
2020-10-26 10:13:28 -05:00
|
|
|
<tr><th colspan='2'></th></tr>
|
2019-06-26 23:11:59 -05:00
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
<tr><td>This controls the default rating search results will be filtered by, and nothing else. To override in your search results, add rating:* to your search.</td></tr>
|
|
|
|
<tr><td>
|
2023-07-04 19:20:43 -03:00
|
|
|
".SHM_SELECT("ratings", selected_options: $selected_ratings, multiple: true, options: $available_ratings)."
|
2019-06-26 23:11:59 -05:00
|
|
|
</td></tr>
|
|
|
|
</tbody>
|
|
|
|
<tfoot>
|
|
|
|
<tr><td><input type='submit' value='Save'></td></tr>
|
|
|
|
</tfoot>
|
|
|
|
</table>
|
|
|
|
</form>
|
|
|
|
";
|
|
|
|
return $html;
|
2023-06-25 20:05:38 -03:00
|
|
|
} */
|
2007-10-02 21:59:20 +00:00
|
|
|
}
|