2007-04-16 11:58:25 +00:00
|
|
|
<?php
|
2014-04-29 05:33:03 +00:00
|
|
|
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
2014-04-29 05:33:03 +00:00
|
|
|
* Class Block
|
|
|
|
*
|
|
|
|
* A basic chunk of a page.
|
2007-12-06 11:01:18 +00:00
|
|
|
*/
|
2007-04-16 11:58:25 +00:00
|
|
|
class Block {
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
2014-04-27 19:33:57 +00:00
|
|
|
* The block's title.
|
2009-07-19 07:38:13 +00:00
|
|
|
*
|
2014-04-26 09:01:49 +00:00
|
|
|
* @var string
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-24 08:36:05 +00:00
|
|
|
public $header;
|
2012-03-12 04:39:04 +00:00
|
|
|
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
2014-04-27 22:59:01 +00:00
|
|
|
* The content of the block.
|
2009-07-19 07:38:13 +00:00
|
|
|
*
|
2014-04-26 09:01:49 +00:00
|
|
|
* @var string
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-24 08:36:05 +00:00
|
|
|
public $body;
|
2012-03-12 04:39:04 +00:00
|
|
|
|
2015-10-26 13:20:09 +00:00
|
|
|
/**
|
2009-07-19 07:38:13 +00:00
|
|
|
* Where the block should be placed. The default theme supports
|
2014-04-27 19:33:57 +00:00
|
|
|
* "main" and "left", other themes can add their own areas.
|
2009-07-19 07:38:13 +00:00
|
|
|
*
|
2014-04-26 09:01:49 +00:00
|
|
|
* @var string
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-24 08:36:05 +00:00
|
|
|
public $section;
|
2012-03-12 04:39:04 +00:00
|
|
|
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
|
|
|
* How far down the section the block should appear, higher
|
|
|
|
* numbers appear lower. The scale is 0-100 by convention,
|
|
|
|
* though any number or string will work.
|
|
|
|
*
|
2014-04-26 09:01:49 +00:00
|
|
|
* @var int
|
2009-07-19 07:38:13 +00:00
|
|
|
*/
|
2014-04-24 08:36:05 +00:00
|
|
|
public $position;
|
2007-04-16 11:58:25 +00:00
|
|
|
|
2012-03-12 04:39:04 +00:00
|
|
|
/**
|
2014-04-27 19:33:57 +00:00
|
|
|
* A unique ID for the block.
|
|
|
|
*
|
|
|
|
* @var string
|
2012-03-12 04:39:04 +00:00
|
|
|
*/
|
2014-04-24 08:36:05 +00:00
|
|
|
public $id;
|
2012-03-12 04:39:04 +00:00
|
|
|
|
2017-08-24 09:17:24 +00:00
|
|
|
/**
|
|
|
|
* Should this block count as content for the sake of
|
|
|
|
* the 404 handler
|
|
|
|
*
|
|
|
|
* @var boolean
|
|
|
|
*/
|
|
|
|
public $is_content = true;
|
|
|
|
|
2014-04-26 09:01:49 +00:00
|
|
|
/**
|
|
|
|
* Construct a block.
|
|
|
|
*
|
|
|
|
* @param string $header
|
|
|
|
* @param string $body
|
|
|
|
* @param string $section
|
|
|
|
* @param int $position
|
2014-04-27 19:33:57 +00:00
|
|
|
* @param null|int $id A unique ID for the block (generated automatically if null).
|
2014-04-26 09:01:49 +00:00
|
|
|
*/
|
2012-03-12 04:39:04 +00:00
|
|
|
public function __construct($header, $body, /*string*/ $section="main", /*int*/ $position=50, $id=null) {
|
2007-04-16 11:58:25 +00:00
|
|
|
$this->header = $header;
|
|
|
|
$this->body = $body;
|
2007-06-30 01:19:11 +00:00
|
|
|
$this->section = $section;
|
|
|
|
$this->position = $position;
|
2015-10-26 13:20:09 +00:00
|
|
|
$this->id = preg_replace('/[^\w]/', '',str_replace(' ', '_', is_null($id) ? (is_null($header) ? md5($body) : $header) . $section : $id));
|
2012-03-12 04:39:04 +00:00
|
|
|
}
|
|
|
|
|
2014-04-26 09:01:49 +00:00
|
|
|
/**
|
|
|
|
* Get the HTML for this block.
|
|
|
|
*
|
|
|
|
* @param bool $hidable
|
|
|
|
* @return string
|
|
|
|
*/
|
2012-03-12 04:39:04 +00:00
|
|
|
public function get_html($hidable=false) {
|
|
|
|
$h = $this->header;
|
|
|
|
$b = $this->body;
|
|
|
|
$i = $this->id;
|
|
|
|
$html = "<section id='$i'>";
|
|
|
|
$h_toggler = $hidable ? " shm-toggler" : "";
|
2012-03-19 19:00:25 +00:00
|
|
|
if(!empty($h)) $html .= "<h3 data-toggle-sel='#$i' class='$h_toggler'>$h</h3>";
|
|
|
|
if(!empty($b)) $html .= "<div class='blockbody'>$b</div>";
|
2012-03-12 15:06:07 +00:00
|
|
|
$html .= "</section>\n";
|
2012-03-12 04:39:04 +00:00
|
|
|
return $html;
|
2007-04-16 11:58:25 +00:00
|
|
|
}
|
|
|
|
}
|
2007-12-04 22:24:58 +00:00
|
|
|
|
2007-12-06 11:01:18 +00:00
|
|
|
|
2009-07-19 07:38:13 +00:00
|
|
|
/**
|
2014-04-29 05:33:03 +00:00
|
|
|
* Class NavBlock
|
|
|
|
*
|
2009-07-19 07:38:13 +00: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 05:33:03 +00:00
|
|
|
*
|
2007-12-06 11:01:18 +00:00
|
|
|
*/
|
2007-12-04 22:24:58 +00:00
|
|
|
class NavBlock extends Block {
|
2008-08-23 12:05:24 +00:00
|
|
|
public function __construct() {
|
|
|
|
parent::__construct("Navigation", "<a href='".make_link()."'>Index</a>", "left", 0);
|
2007-12-04 22:24:58 +00:00
|
|
|
}
|
|
|
|
}
|