__widgets as $pos => $w) { $serialized[] = ($w->serialize($pos)); } return base64_encode(serialize($serialized)); } public function create($id, $name, $callback, $append_callback = null, $desc = '') { $this->__widgets[$id] = new dcWidgetExt($id, $name, $callback, $desc); $this->__widgets[$id]->append_callback = $append_callback; return $this->__widgets[$id]; } public function append($widget) { if ($widget instanceof dcWidget) { if (is_callable($widget->append_callback)) { call_user_func($widget->append_callback, $widget); } $this->__widgets[] = $widget; } } public function isEmpty() { return count($this->__widgets) == 0; } public function elements($sorted = false) { if ($sorted) { uasort($this->__widgets, ['self', 'sort']); } return $this->__widgets; } public function __get($id) { if (!isset($this->__widgets[$id])) { return; } return $this->__widgets[$id]; } public function __wakeup() { foreach ($this->__widgets as $i => $w) { if (!($w instanceof dcWidget)) { unset($this->__widgets[$i]); } } } public static function loadArray($A, $widgets) { if (!($widgets instanceof self)) { return false; } uasort($A, ['self', 'arraySort']); $result = new self; foreach ($A as $v) { if ($widgets->{$v['id']} != null) { $w = clone $widgets->{$v['id']}; # Settings unset($v['id']); unset($v['order']); foreach ($v as $sid => $s) { $w->{$sid} = $s; } $result->append($w); } } return $result; } private static function arraySort($a, $b) { if ($a['order'] == $b['order']) { return 0; } return $a['order'] > $b['order'] ? 1 : -1; } private static function sort($a, $b) { $c = dcUtils::removeDiacritics(mb_strtolower($a->name())); $d = dcUtils::removeDiacritics(mb_strtolower($b->name())); if ($c == $d) { return 0; } return ($c < $d) ? -1 : 1; } } class dcWidget { private $id; private $name; private $desc; private $public_callback = null; public $append_callback = null; private $settings = []; public function serialize($order) { $values = []; foreach ($this->settings as $k => $v) { $values[$k] = $v['value']; } $values['id'] = $this->id; $values['order'] = $order; return $values; } public function __construct($id, $name, $callback, $desc = '') { $this->public_callback = $callback; $this->id = $id; $this->name = $name; $this->desc = $desc; } public function id() { return $this->id; } public function name() { return $this->name; } public function desc() { return $this->desc; } public function getCallback() { return $this->public_callback; } public function call($i = 0) { if (is_callable($this->public_callback)) { return call_user_func($this->public_callback, $this, $i); } return '
Callback not found for widget ' . $this->id . '
'; } /* Widget rendering tool --------------------------------------------------- */ public function renderDiv($content_only, $class, $attr, $content) { if ($content_only) { return $content; } $ret = '' . "\n"; return $ret; } public function renderTitle($title) { global $core; if (!$title) { return ''; } $wtscheme = $core->themes->moduleInfo($core->blog->settings->system->theme, 'widgettitleformat'); if (empty($wtscheme)) { $tplset = $core->themes->moduleInfo($core->blog->settings->system->theme, 'tplset'); if (empty($tplset) || $tplset == DC_DEFAULT_TPLSET) { // Use H2 for mustek based themes $wtscheme = '' . form::field([$iname, $wfid], 20, 255, [ 'default' => html::escapeHTML($s['value']), 'class' => 'maximal' . $class, 'extra_html' => 'lang="' . $core->auth->getInfo('user_lang') . '" spellcheck="true"' ]) . '
'; break; case 'textarea': $res .= '' . form::textarea([$iname, $wfid], 30, 8, [ 'default' => html::escapeHTML($s['value']), 'class' => 'maximal' . $class, 'extra_html' => 'lang="' . $core->auth->getInfo('user_lang') . '" spellcheck="true"' ]) . '
'; break; case 'check': $res .= '' . form::hidden([$iname], '0') . '
'; break; case 'radio': $res .= '' . ($s['title'] ? '
' : '');
if (!empty($s['options'])) {
foreach ($s['options'] as $k => $v) {
$res .= $k > 0 ? '
' : '';
$res .=
'';
}
}
$res .= '
' . form::combo([$iname, $wfid], $s['options'], $s['value'], $class) . '
'; break; } return $res; } } class dcWidgetExt extends dcWidget { const ALL_PAGES = 0; // Widget displayed on every page const HOME_ONLY = 1; // Widget displayed on home page only const EXCEPT_HOME = 2; // Widget displayed on every page but home page public function addTitle($title = '') { return $this->setting('title', __('Title (optional)') . ' :', $title); } public function addHomeOnly() { return $this->setting('homeonly', __('Display on:'), 0, 'combo', [__('All pages') => self::ALL_PAGES, __('Home page only') => self::HOME_ONLY, __('Except on home page') => self::EXCEPT_HOME]); } public function checkHomeOnly($type, $alt_not_home = 1, $alt_home = 0) { global $core; if (($this->homeonly == self::HOME_ONLY && !$core->url->isHome($type) && $alt_not_home) || ($this->homeonly == self::EXCEPT_HOME && ($core->url->isHome($type) || $alt_home ))) { return false; } return true; } public function addContentOnly($content_only = 0) { return $this->setting('content_only', __('Content only'), $content_only, 'check'); } public function addClass($class = '') { return $this->setting('class', __('CSS class:'), $class); } public function addOffline($offline = 0) { return $this->setting('offline', __('Offline'), $offline, 'check'); } }