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/block.php

99 lines
2.3 KiB
PHP
Raw Normal View History

2021-12-14 18:32:47 +00:00
<?php
declare(strict_types=1);
2014-04-29 01:33:03 -04:00
namespace Shimmie2;
2009-07-19 08:38:13 +01:00
/**
2014-04-29 01:33:03 -04:00
* Class Block
*
* A basic chunk of a page.
*/
class Block
{
/**
* The block's title.
*/
public ?string $header;
2012-03-12 04:39:04 +00:00
/**
* The content of the block.
*/
public ?string $body;
2012-03-12 04:39:04 +00:00
/**
* Where the block should be placed. The default theme supports
* "main" and "left", other themes can add their own areas.
*/
public string $section;
2012-03-12 04:39:04 +00:00
/**
* How far down the section the block should appear, higher
* numbers appear lower. The scale is 0-100 by convention,
2020-01-26 23:12:48 +00:00
* though any number will work.
*/
public int $position;
/**
* A unique ID for the block.
*/
public string $id;
2012-03-12 04:39:04 +00:00
/**
* Should this block count as content for the sake of
* the 404 handler
*/
public bool $is_content = true;
public function __construct(?string $header = null, string|\MicroHTML\HTMLElement|null $body = null, string $section = "main", int $position = 50, ?string $id = null)
{
$this->header = $header;
2022-10-28 01:45:35 +01:00
$this->body = (string)$body;
$this->section = $section;
$this->position = $position;
2017-08-24 10:17:39 +01:00
if (is_null($id)) {
$id = (empty($header) ? md5($this->body ?? '') : $header) . $section;
}
$str_id = preg_replace_ex('/[^\w-]/', '', str_replace(' ', '_', $id));
$this->id = $str_id;
}
2012-03-12 04:39:04 +00:00
/**
* Get the HTML for this block.
*/
2023-11-11 21:49:12 +00:00
public function get_html(bool $hidable = false): string
{
$h = $this->header;
$b = $this->body;
$i = $this->id;
$html = "<section id='$i'>";
$h_toggler = $hidable ? " shm-toggler" : "";
if (!empty($h)) {
$html .= "<h3 data-toggle-sel='#$i' class='$h_toggler'>$h</h3>";
}
if (!empty($b)) {
$html .= "<div class='blockbody'>$b</div>";
}
$html .= "</section>\n";
return $html;
}
}
2009-07-19 08:38:13 +01:00
/**
2014-04-29 01:33:03 -04:00
* Class NavBlock
*
2009-07-19 08:38:13 +01:00
* A generic navigation block with a link to the main page.
*
* Used because "new NavBlock()" is easier than "new Block('Navigation', ..."
2014-04-29 01:33:03 -04:00
*
*/
class NavBlock extends Block
{
public function __construct()
{
parent::__construct("Navigation", "<a href='".make_link()."'>Index</a>", "left", 0);
}
}