This repository has been archived on 2024-09-05. You can view files and clone it, but cannot push or open issues or pull requests.
shimmie2/core/microhtml.php

184 lines
4.8 KiB
PHP
Raw Normal View History

2023-07-05 16:33:38 -03:00
<?php
declare(strict_types=1);
namespace Shimmie2;
use MicroHTML\HTMLElement;
use function MicroHTML\{emptyHTML};
2023-07-05 16:33:38 -03:00
use function MicroHTML\A;
2024-06-11 15:02:52 +00:00
use function MicroHTML\CODE;
use function MicroHTML\DIV;
2023-07-05 16:33:38 -03:00
use function MicroHTML\FORM;
use function MicroHTML\INPUT;
use function MicroHTML\OPTION;
use function MicroHTML\P;
use function MicroHTML\SELECT;
use function MicroHTML\SPAN;
use function MicroHTML\{TABLE,THEAD,TFOOT,TR,TH,TD};
2023-07-05 16:33:38 -03:00
2024-02-11 11:34:09 +00:00
function SHM_FORM(string $target, bool $multipart = false, string $form_id = "", string $onsubmit = "", string $name = ""): HTMLElement
2023-07-05 16:33:38 -03:00
{
global $user;
$attrs = [
2023-11-11 21:49:12 +00:00
"action" => make_link($target),
2024-02-11 11:34:09 +00:00
"method" => 'POST'
2023-07-05 16:33:38 -03:00
];
if ($form_id) {
$attrs["id"] = $form_id;
}
if ($multipart) {
$attrs["enctype"] = 'multipart/form-data';
}
if ($onsubmit) {
$attrs["onsubmit"] = $onsubmit;
}
if ($name) {
$attrs["name"] = $name;
}
2024-02-11 11:34:09 +00:00
2023-07-05 16:33:38 -03:00
return FORM(
$attrs,
2024-02-11 11:34:09 +00:00
INPUT(["type" => "hidden", "name" => "auth_token", "value" => $user->get_auth_token()])
2023-07-05 16:33:38 -03:00
);
}
/**
* @param array<string|HTMLElement|null> $children
*/
function SHM_SIMPLE_FORM(string $target, ...$children): HTMLElement
2023-07-05 16:33:38 -03:00
{
$form = SHM_FORM($target);
$form->appendChild(emptyHTML(...$children));
return $form;
}
/**
* @param array<string, mixed> $args
*/
2023-11-11 21:49:12 +00:00
function SHM_SUBMIT(string $text, array $args = []): HTMLElement
2023-07-05 16:33:38 -03:00
{
$args["type"] = "submit";
$args["value"] = $text;
return INPUT($args);
}
/**
* @param array<string, mixed> $args
*/
2023-11-11 21:49:12 +00:00
function SHM_A(string $href, string|HTMLElement $text, string $id = "", string $class = "", array $args = []): HTMLElement
2023-07-05 16:33:38 -03:00
{
$args["href"] = make_link($href);
if ($id) {
$args["id"] = $id;
}
if ($class) {
$args["class"] = $class;
}
return A($args, $text);
}
function SHM_COMMAND_EXAMPLE(string $ex, string $desc): HTMLElement
{
return DIV(
2023-11-11 21:49:12 +00:00
["class" => "command_example"],
2024-06-11 15:02:52 +00:00
CODE($ex),
2023-07-05 16:33:38 -03:00
P($desc)
);
}
function SHM_USER_FORM(User $duser, string $target, string $title, HTMLElement $body, HTMLElement|string $foot): HTMLElement
2023-07-05 16:33:38 -03:00
{
if (is_string($foot)) {
2023-11-11 21:49:12 +00:00
$foot = TFOOT(TR(TD(["colspan" => "2"], INPUT(["type" => "submit", "value" => $foot]))));
2023-07-05 16:33:38 -03:00
}
return SHM_SIMPLE_FORM(
$target,
P(
2023-11-11 21:49:12 +00:00
INPUT(["type" => 'hidden', "name" => 'id', "value" => $duser->id]),
2023-07-05 16:33:38 -03:00
TABLE(
2023-11-11 21:49:12 +00:00
["class" => "form"],
THEAD(TR(TH(["colspan" => "2"], $title))),
2023-07-05 16:33:38 -03:00
$body,
$foot
)
)
);
}
/**
* Generates a <select> element and sets up the given options.
*
* @param string $name The name attribute of <select>.
* @param array<string|int, string> $options An array of pairs of parameters for <option> tags. First one is value, second one is text. Example: ('optionA', 'Choose Option A').
* @param array<string> $selected_options The values of options that should be pre-selected.
2023-07-05 16:33:38 -03:00
* @param bool $required Wether the <select> element is required.
* @param bool $multiple Wether the <select> element is multiple-choice.
* @param bool $empty_option Whether the first option should be an empty one.
* @param array<string, mixed> $attrs Additional attributes dict for <select>. Example: ["id"=>"some_id", "class"=>"some_class"].
2023-07-05 16:33:38 -03:00
*/
2023-11-11 21:49:12 +00:00
function SHM_SELECT(string $name, array $options, array $selected_options = [], bool $required = false, bool $multiple = false, bool $empty_option = false, array $attrs = []): HTMLElement
2023-07-05 16:33:38 -03:00
{
if ($required) {
$attrs["required"] = "";
}
if ($multiple) {
if (!str_ends_with($name, "[]")) {
$name = $name . "[]";
}
$attrs["multiple"] = "";
}
$attrs["name"] = $name;
$_options = [];
if ($empty_option) {
$_options[] = OPTION();
}
foreach ($options as $value => $text) {
$_options[] = SHM_OPTION((string)$value, (string)$text, in_array($value, $selected_options));
}
return SELECT($attrs, ...$_options);
}
2023-11-11 21:49:12 +00:00
function SHM_OPTION(string $value, string $text, bool $selected = false): HTMLElement
2023-07-05 16:33:38 -03:00
{
if ($selected) {
2023-11-11 21:49:12 +00:00
return OPTION(["value" => $value, "selected" => ""], $text);
2023-07-05 16:33:38 -03:00
}
2023-11-11 21:49:12 +00:00
return OPTION(["value" => $value], $text);
2023-07-05 16:33:38 -03:00
}
function SHM_POST_INFO(
string $title,
HTMLElement|string|null $view = null,
HTMLElement|string|null $edit = null,
string|null $link = null,
): HTMLElement {
2024-08-31 17:05:18 +01:00
if (!is_null($view) && !is_null($edit)) {
$show = emptyHTML(
SPAN(["class" => "view"], $view),
SPAN(["class" => "edit"], $edit),
);
2024-08-31 17:05:18 +01:00
} elseif (!is_null($edit)) {
$show = $edit;
2024-08-31 17:05:18 +01:00
} elseif (!is_null($view)) {
$show = $view;
} else {
$show = "???";
}
return TR(
2023-12-31 23:08:53 +00:00
["data-row" => $title],
TH(["width" => "50px"], $link ? A(["href" => $link], $title) : $title),
TD($show)
);
}