mirror of
https://github.com/e107inc/e107.git
synced 2025-01-17 20:58:30 +01:00
featurebox front-end - done, dynamic part and cleanup in progress
This commit is contained in:
parent
11d37fdc76
commit
c344133a74
@ -9,8 +9,8 @@
|
||||
* e107 Main
|
||||
*
|
||||
* $Source: /cvs_backup/e107_0.8/e107_handlers/e107_class.php,v $
|
||||
* $Revision: 1.89 $
|
||||
* $Date: 2009-12-08 17:21:32 $
|
||||
* $Revision: 1.90 $
|
||||
* $Date: 2009-12-09 18:33:43 $
|
||||
* $Author: secretr $
|
||||
*/
|
||||
|
||||
@ -1214,15 +1214,27 @@ class e107
|
||||
* @param string $id - file prefix, e.g. user for user_template.php
|
||||
* @param string|null $key
|
||||
* @param boolean $override see {@link getThemeInfo())
|
||||
*
|
||||
* @param boolean $merge merge theme with core templates, default is false
|
||||
* @return string|array
|
||||
*/
|
||||
public static function getCoreTemplate($id, $key = null, $override = true)
|
||||
public static function getCoreTemplate($id, $key = null, $override = true, $merge = false)
|
||||
{
|
||||
$reg_path = 'core/e107/templates/'.$id.($override ? '/ext' : '');
|
||||
$path = self::coreTemplatePath($id, $override);
|
||||
$id = str_replace('/', '_', $id);
|
||||
return self::_getTemplate($id, $key, $reg_path, $path);
|
||||
$ret = self::_getTemplate($id, $key, $reg_path, $path);
|
||||
if(!$merge || !$override || !is_array($ret))
|
||||
{
|
||||
return $ret;
|
||||
}
|
||||
|
||||
// merge
|
||||
$reg_path = 'core/e107/templates/'.$id;
|
||||
$path = self::coreTemplatePath($id, false);
|
||||
$id = str_replace('/', '_', $id);
|
||||
$ret_core = self::_getTemplate($id, $key, $reg_path, $path);
|
||||
|
||||
return (is_array($ret_core) ? array_merge($ret_core, $ret) : $ret);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -1247,15 +1259,27 @@ class e107
|
||||
* @param string $id - file prefix, e.g. calendar for calendar_template.php
|
||||
* @param string|null $key
|
||||
* @param boolean $override see {@link getThemeInfo())
|
||||
*
|
||||
* @param boolean $merge merge theme with plugin templates, default is false
|
||||
* @return string|array
|
||||
*/
|
||||
public static function getTemplate($plug_name, $id, $key = null, $override = true)
|
||||
public static function getTemplate($plug_name, $id, $key = null, $override = true, $merge = false)
|
||||
{
|
||||
$reg_path = 'plugin/'.$plug_name.'/templates/'.$id.($override ? '/ext' : '');
|
||||
$path = self::templatePath($plug_name, $id, $override);
|
||||
$id = str_replace('/', '_', $id);
|
||||
return self::_getTemplate($id, $key, $reg_path, $path);
|
||||
$ret = self::_getTemplate($id, $key, $reg_path, $path);
|
||||
if(!$merge || !$override || !is_array($ret))
|
||||
{
|
||||
return $ret;
|
||||
}
|
||||
|
||||
// merge
|
||||
$reg_path = 'plugin/'.$plug_name.'/templates/'.$id;
|
||||
$path = self::templatePath($plug_name, $id, false);
|
||||
$id = str_replace('/', '_', $id);
|
||||
$ret_plug = self::_getTemplate($id, $key, $reg_path, $path);
|
||||
|
||||
return (is_array($ret_plug) ? array_merge($ret_plug, $ret) : $ret);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -1263,22 +1287,30 @@ class e107
|
||||
* @param string $plugin_name
|
||||
* @param string $template_id [optional] if different from $plugin_name;
|
||||
* @param mixed $where true - current theme, 'admin' - admin theme, 'front' (default) - front theme
|
||||
* @param boolean $merge merge theme with core/plugin layouts, default is false
|
||||
* @return array
|
||||
*/
|
||||
public static function getLayouts($plugin_name, $template_id = '', $where = 'front', $filter_mask = '')
|
||||
public static function getLayouts($plugin_name, $template_id = '', $where = 'front', $filter_mask = '', $merge = false)
|
||||
{
|
||||
if(!$plugin_name) // Core template
|
||||
{
|
||||
$tmp = self::getCoreTemplate($template_id, null, $where);
|
||||
$tmp = self::getCoreTemplate($template_id, null, $where, $merge);
|
||||
}
|
||||
else // Plugin template
|
||||
{
|
||||
$id = (!$template_id) ? $plugin_name : $template_id;
|
||||
$tmp = self::getTemplate($plugin_name, $id, null, $where);
|
||||
$tmp = self::getTemplate($plugin_name, $id, null, $where, $merge);
|
||||
}
|
||||
|
||||
$templates = array();
|
||||
$filter_mask = $filter_mask ? explode(',', $filter_mask) : array();
|
||||
if(!$filter_mask)
|
||||
{
|
||||
$filter_mask = array();
|
||||
}
|
||||
elseif(!is_array($filter_mask))
|
||||
{
|
||||
$filter_mask = array($filter_mask);
|
||||
}
|
||||
foreach($tmp as $key => $val)
|
||||
{
|
||||
// Special key INFO in format aray('layout' => array(info))
|
||||
@ -1292,7 +1324,7 @@ class e107
|
||||
$match = false;
|
||||
foreach ($filter_mask as $mask)
|
||||
{
|
||||
if(strpos($key, $mask) === 0) //e.g. retrieve only keys starting with 'layout_'
|
||||
if(preg_match($mask, $key)) //e.g. retrieve only keys starting with 'layout_'
|
||||
{
|
||||
$match = true;
|
||||
break;
|
||||
@ -1300,9 +1332,9 @@ class e107
|
||||
}
|
||||
if(!$match) continue;
|
||||
}
|
||||
if(isset($val['__INFO__'][$key]))
|
||||
if(isset($tmp['__INFO__'][$key]))
|
||||
{
|
||||
$templates[$key] = defset($val['__INFO__'][$key]['title'], $val['__INFO__'][$key]['title']);
|
||||
$templates[$key] = defset($tmp['__INFO__'][$key]['title'], $tmp['__INFO__'][$key]['title']);
|
||||
continue;
|
||||
}
|
||||
$templates[$key] = implode(' ', array_map('ucfirst', explode('_', $key))); //TODO add LANS?
|
||||
|
@ -9,8 +9,8 @@
|
||||
* Form Handler
|
||||
*
|
||||
* $Source: /cvs_backup/e107_0.8/e107_handlers/form_handler.php,v $
|
||||
* $Revision: 1.93 $
|
||||
* $Date: 2009-11-28 15:34:46 $
|
||||
* $Revision: 1.94 $
|
||||
* $Date: 2009-12-09 18:33:41 $
|
||||
* $Author: secretr $
|
||||
*
|
||||
*/
|
||||
@ -130,7 +130,7 @@ class e_form
|
||||
$parms .= "&default=".rawurlencode($default);
|
||||
$parms .= "&multiple=FALSE";
|
||||
$parms .= "&label=-- ".$label." --";
|
||||
$parms .= "&subdirs=0";
|
||||
$parms .= "&subdirs=".varset($sc_parameters['subdirs'], 1);
|
||||
$parms .= '&width='.vartrue($sc_parameters['width'], 150).'px';
|
||||
if(vartrue($sc_parameters['height'])) $parms .= '&height='.$sc_parameters['height'].'px';
|
||||
//$parms .= "&tabindex=".$this->getNext();
|
||||
@ -1326,8 +1326,9 @@ class e_form
|
||||
$ilocation = vartrue($parms['id'], $location); // omit if same as plugin name
|
||||
$where = vartrue($parms['area'], 'front'); //default is 'front'
|
||||
$filter = varset($parms['filter']);
|
||||
$layouts = e107::getLayouts($location, $ilocation, $where, $filter);
|
||||
if(varset($parms['default']))
|
||||
$merge = vartrue($parms['merge']) ? true : false;
|
||||
$layouts = e107::getLayouts($location, $ilocation, $where, $filter, $merge);
|
||||
if(varset($parms['default']) && !isset($layouts['default']))
|
||||
{
|
||||
$layouts = array('default' => $parms['default']) + $layouts;
|
||||
}
|
||||
|
@ -1,20 +1,18 @@
|
||||
<?php
|
||||
/*
|
||||
+ ----------------------------------------------------------------------------+
|
||||
| e107 website system
|
||||
|
|
||||
| Copyright (C) 2008-2009 e107 Inc (e107.org)
|
||||
| http://e107.org
|
||||
|
|
||||
|
|
||||
| Released under the terms and conditions of the
|
||||
| GNU General Public License (http://gnu.org).
|
||||
|
|
||||
| $Source: /cvs_backup/e107_0.8/e107_plugins/featurebox/admin_config.php,v $
|
||||
| $Revision: 1.11 $
|
||||
| $Date: 2009-11-28 15:34:46 $
|
||||
| $Author: secretr $
|
||||
+----------------------------------------------------------------------------+
|
||||
* e107 website system
|
||||
*
|
||||
* Copyright (c) 2008-2009 e107 Inc (e107.org)
|
||||
* Released under the terms and conditions of the
|
||||
* GNU General Public License (http://www.gnu.org/licenses/gpl.txt)
|
||||
*
|
||||
* Featurebox administration
|
||||
*
|
||||
* $Source: /cvs_backup/e107_0.8/e107_plugins/featurebox/admin_config.php,v $
|
||||
* $Revision: 1.12 $
|
||||
* $Date: 2009-12-09 18:33:40 $
|
||||
* $Author: secretr $
|
||||
*
|
||||
*/
|
||||
require_once("../../class2.php");
|
||||
if (!getperms("P") || !plugInstalled('featurebox'))
|
||||
@ -23,7 +21,7 @@ if (!getperms("P") || !plugInstalled('featurebox'))
|
||||
exit;
|
||||
}
|
||||
|
||||
include_lan(e_PLUGIN."featurebox/languages/".e_LANGUAGE."_admin_featurebox.php");
|
||||
e107::includeLan(e_PLUGIN.'featurebox/languages/'.e_LANGUAGE.'_admin_featurebox.php');
|
||||
|
||||
class fb_admin extends e_admin_dispatcher
|
||||
{
|
||||
@ -69,15 +67,15 @@ class fb_category_ui extends e_admin_ui
|
||||
protected $perPage = 0; //no limit
|
||||
|
||||
protected $fields = array(
|
||||
'checkboxes' => array('title'=> '', 'type' => null, 'width' =>'5%', 'forced'=> TRUE, 'thclass'=>'center', 'class'=>'center first'),
|
||||
'fb_category_id' => array('title'=> LAN_ID, 'type' => 'number', 'data' => 'int', 'width' =>'5%', 'forced'=> TRUE),
|
||||
'fb_category_icon' => array('title'=> LAN_ICON, 'type' => 'icon', 'data' => 'str', 'width' => '5%', 'thclass' => 'center', 'class'=>'center'),
|
||||
'fb_category_title' => array('title'=> LAN_TITLE, 'type' => 'text', 'data' => 'str', 'width' => 'auto', 'validate' => 'str', 'rule' => '1-200', 'error' => 'String between 1-200 characters expected', 'help' => 'up to 200 characters', 'thclass' => 'left'),
|
||||
'fb_category_layout' => array('title'=> 'Render type', 'type' => 'templates', 'data' => 'str', 'width' => 'auto', 'thclass' => 'left', 'writeParms' => 'plugin=featurebox&location=layout&default=Default', 'filter' => true),
|
||||
'fb_category_random' => array('title'=> 'Random', 'type' => 'boolean', 'data' => 'int', 'width' => '5%', 'thclass' => 'center', 'class' => 'center', 'batch' => true, 'filter' => true),
|
||||
'fb_category_class' => array('title'=> LAN_VISIBILITY, 'type' => 'userclass', 'data' => 'int', 'width' => 'auto'),
|
||||
'fb_category_limit' => array('title'=> 'Limit', 'type' => 'number', 'data' => 'int', 'width' => '5%', 'thclass' => 'left', 'help' => 'number of items to be shown, 0 - show all'),
|
||||
'options' => array('title'=> LAN_OPTIONS, 'type' => null, 'width' => '10%', 'forced'=>TRUE, 'thclass' => 'center last', 'class' => 'center')
|
||||
'checkboxes' => array('title'=> '', 'type' => null, 'width' =>'5%', 'forced'=> TRUE, 'thclass'=>'center', 'class'=>'center first'),
|
||||
'fb_category_id' => array('title'=> LAN_ID, 'type' => 'number', 'data' => 'int', 'width' =>'5%', 'forced'=> TRUE),
|
||||
'fb_category_icon' => array('title'=> LAN_ICON, 'type' => 'icon', 'data' => 'str', 'width' => '5%', 'thclass' => 'center', 'class'=>'center'),
|
||||
'fb_category_title' => array('title'=> LAN_TITLE, 'type' => 'text', 'data' => 'str', 'width' => 'auto', 'validate' => 'str', 'rule' => '1-200', 'error' => 'String between 1-200 characters expected', 'help' => 'up to 200 characters', 'thclass' => 'left'),
|
||||
'fb_category_template' => array('title'=> 'Category template', 'type' => 'layouts', 'data' => 'str', 'width' => 'auto', 'thclass' => 'left', 'writeParms' => 'plugin=featurebox&id=featurebox_category&merge=1', 'filter' => true),
|
||||
'fb_category_random' => array('title'=> 'Random', 'type' => 'boolean', 'data' => 'int', 'width' => '5%', 'thclass' => 'center', 'class' => 'center', 'batch' => true, 'filter' => true),
|
||||
'fb_category_class' => array('title'=> LAN_VISIBILITY, 'type' => 'userclass', 'data' => 'int', 'width' => 'auto'),
|
||||
'fb_category_limit' => array('title'=> 'Limit', 'type' => 'number', 'data' => 'int', 'width' => '5%', 'thclass' => 'left', 'help' => 'number of items to be shown, 0 - show all'),
|
||||
'options' => array('title'=> LAN_OPTIONS, 'type' => null, 'width' => '10%', 'forced'=>TRUE, 'thclass' => 'center last', 'class' => 'center')
|
||||
);
|
||||
|
||||
/**
|
||||
@ -132,9 +130,9 @@ class fb_category_ui extends e_admin_ui
|
||||
{
|
||||
if($this->getModel()->getSqlErrorNumber() == 1062)
|
||||
{
|
||||
$templates = $this->getFieldAttr('fb_category_layout', 'writeParms', array());
|
||||
$templates = $this->getFieldAttr('fb_category_template', 'writeParms', array());
|
||||
$msg = e107::getMessage();
|
||||
$msg->error('Layout <strong>'.vartrue($templates[$new_data['fb_category_layout']], 'n/a').'</strong> is in use by another category. Layout should be unique per category. ');
|
||||
$msg->error('Layout <strong>'.vartrue($templates[$new_data['fb_category_template']], 'n/a').'</strong> is in use by another category. Layout should be unique per category. ');
|
||||
$msg->error($mod == 'create' ? LAN_CREATED_FAILED : LAN_UPDATED_FAILED);
|
||||
|
||||
return (!E107_DEBUG_LEVEL); // suppress messages (TRUE) only when not in debug mod
|
||||
@ -173,13 +171,9 @@ class fb_main_ui extends e_admin_ui
|
||||
'options' => array('title'=> LAN_OPTIONS, 'type' => null, 'forced'=>TRUE, 'width' => '10%', 'thclass' => 'center last', 'class' => 'center')
|
||||
);
|
||||
|
||||
// protected $fieldpref = array('checkboxes', 'comment_id', 'comment_item_id', 'comment_author_id', 'comment_author_name', 'comment_subject', 'comment_comment', 'comment_type', 'options');
|
||||
protected $fieldpref = array('checkboxes', 'fb_id', 'fb_category', 'fb_title', 'fb_template', 'fb_class', 'fb_order', 'options');
|
||||
|
||||
protected $prefs = array(
|
||||
'fb_active' => array('title'=> 'Allow submitting of fbs by:', 'type'=>'userclass'),
|
||||
'submit_question' => array('title'=> 'Allow submitting of Questions by:', 'type'=>'userclass'),
|
||||
'classic_look' => array('title'=> 'Use Classic Layout', 'type'=>'boolean')
|
||||
);
|
||||
protected $prefs = array();
|
||||
|
||||
|
||||
|
||||
@ -188,7 +182,7 @@ class fb_main_ui extends e_admin_ui
|
||||
$categories = array();
|
||||
if(e107::getDb()->db_Select('featurebox_category'))
|
||||
{
|
||||
$categories[0] = LAN_SELECT;
|
||||
//$categories[0] = LAN_SELECT;
|
||||
while ($row = e107::getDb()->db_Fetch())
|
||||
{
|
||||
$id = $row['fb_category_id'];
|
||||
|
@ -1,27 +1,48 @@
|
||||
<?php
|
||||
/*
|
||||
* Copyright (c) e107 Inc 2009 - e107.org, Licensed under GNU GPL (http://www.gnu.org/licenses/gpl.txt)
|
||||
* $Id: e_shortcode.php,v 1.2 2009-12-08 17:21:30 secretr Exp $
|
||||
* $Id: e_shortcode.php,v 1.3 2009-12-09 18:33:37 secretr Exp $
|
||||
*
|
||||
* Featurebox shortcode batch class - shortcodes available site-wide. ie. equivalent to multiple .sc files.
|
||||
*/
|
||||
|
||||
if (!defined('e107_INIT')) { exit; }
|
||||
|
||||
e107::includeLan(e_PLUGIN.'featurebox/languages/'.e_LANGUAGE.'_front_featurebox.php');
|
||||
|
||||
class featurebox_shortcodes // must match the plugin's folder name. ie. [PLUGIN_FOLDER]_shortcodes
|
||||
{
|
||||
/**
|
||||
* Available parameters (GET string format)
|
||||
* - cols (integer): number of items per column, default 1
|
||||
* - no_fill_empty (boolean): don't fill last column with empty items (if required), default 0
|
||||
* - tablestyle (string): mode to be used with <code>tablerender()</code>, default 'featurebox'
|
||||
* - notablestyle (null): if isset - disable <code>tablerender()</code>
|
||||
*
|
||||
* @param string $parm parameters
|
||||
* @param string $mod category template
|
||||
*/
|
||||
function sc_featurebox($parm, $mod = '')
|
||||
{
|
||||
// TODO cache
|
||||
if(!e107::isInstalled('featurebox')) //just in case
|
||||
{
|
||||
return '';
|
||||
}
|
||||
|
||||
if(!$mod)
|
||||
{
|
||||
$clayout = 'default';
|
||||
$ctemplate = 'default';
|
||||
}
|
||||
else
|
||||
{
|
||||
$clayout = $mod;
|
||||
$ctemplate = $mod;
|
||||
}
|
||||
|
||||
parse_str($parm, $parm);
|
||||
|
||||
$category = new plugin_featurebox_category();
|
||||
$category->loadByLayout($clayout);
|
||||
$category->loadByTemplate($ctemplate);
|
||||
if(!$category->hasData())
|
||||
{
|
||||
return '';
|
||||
@ -33,16 +54,15 @@ class featurebox_shortcodes // must match the plugin's folder name. ie. [PLUGIN_
|
||||
return '';
|
||||
}
|
||||
|
||||
$tmpl = e107::getTemplate('featurebox', 'layout/'.$category->get('fb_category_layout'));
|
||||
if(!$tmpl)
|
||||
{
|
||||
$tmpl = e107::getTemplate('featurebox', 'layout/default');
|
||||
}
|
||||
$tmpl = $this->getFboxTemplate($category);
|
||||
|
||||
$tp = e107::getParser();
|
||||
$ret = array();
|
||||
|
||||
$cols = intval(vartrue($parm['cols'], 1));
|
||||
$counter = 1;
|
||||
$col_counter = 1;
|
||||
$total = count($tree->getTree());
|
||||
foreach ($tree->getTree() as $id => $node)
|
||||
{
|
||||
$tmpl_item = e107::getTemplate('featurebox', 'featurebox', $node->get('fb_template'));
|
||||
@ -51,14 +71,133 @@ class featurebox_shortcodes // must match the plugin's folder name. ie. [PLUGIN_
|
||||
$tmpl_item = e107::getTemplate('featurebox', 'featurebox', 'default');
|
||||
}
|
||||
|
||||
$ret[] = $node->setParam('counter', $counter)
|
||||
// reset column counter
|
||||
if($col_counter > $cols)
|
||||
{
|
||||
$col_counter = 1;
|
||||
}
|
||||
|
||||
// add column start
|
||||
if(1 == $col_counter && vartrue($tmpl['col_start']))
|
||||
{
|
||||
$tmpl_item = $tmpl['col_start'].$tmpl_item;
|
||||
}
|
||||
|
||||
// there is more
|
||||
if(($total - $counter) > 0)
|
||||
{
|
||||
// add column end if column end reached
|
||||
if($cols == $col_counter && vartrue($tmpl['col_end']))
|
||||
{
|
||||
$tmpl_item .= $tmpl['col_end'];
|
||||
}
|
||||
// else add item separator
|
||||
else
|
||||
{
|
||||
$tmpl_item .= $ret['item_separator'];
|
||||
}
|
||||
}
|
||||
// no more items - clean & close
|
||||
else
|
||||
{
|
||||
$empty_cnt = $cols - $col_counter;
|
||||
if($empty_cnt > 0 && !isset($parm['no_fill_empty']))
|
||||
{
|
||||
// empty items fill
|
||||
for ($index = 1; $index <= $empty_cnt; $index++)
|
||||
{
|
||||
$tmpl_item .= $ret['item_separator'].varset($ret['item_empty'], '<div><!-- --></div>');
|
||||
}
|
||||
}
|
||||
// add column end
|
||||
$tmpl_item .= varset($tmpl['col_end']);
|
||||
}
|
||||
|
||||
$ret[$counter] = $node->setParam('counter', $counter)
|
||||
->setCategory($category)
|
||||
->toHTML($tmpl_item);
|
||||
|
||||
//$ret[] = $node->toHTML($tmpl_item);
|
||||
|
||||
$counter++;
|
||||
$col_counter++;
|
||||
}
|
||||
|
||||
return $tp->parseTemplate($tmpl['list_start'], true, $category).implode($ret['item_separator'], $ret).$tp->parseTemplate($tmpl['list_end'], true, $category);
|
||||
$ret = $tp->parseTemplate($tmpl['list_start'], true, $category).implode('', $ret).$tp->parseTemplate($tmpl['list_end'], true, $category);
|
||||
if(isset($parm['notablestyle']))
|
||||
{
|
||||
return $ret;
|
||||
}
|
||||
|
||||
return e107::getRender()->tablerender(FBLAN_01, $ret, vartrue($parm['tablestyle'], 'featurebox'), true);
|
||||
}
|
||||
|
||||
/**
|
||||
* Render featurebox navigation
|
||||
* Available parameters (GET string format)
|
||||
* - cols (integer): number of items per column, default 1
|
||||
* - no_fill_empty (boolean): don't fill last column with empty items (if required), default 0
|
||||
* - tablestyle (string): mode to be used with <code>tablerender()</code>, default 'featurebox'
|
||||
* - notablestyle (null): if isset - disable <code>tablerender()</code>
|
||||
*
|
||||
* @param string $parm parameters
|
||||
* @param string $mod category template
|
||||
*/
|
||||
function sc_featurebox_navigation($parm, $mod = '')
|
||||
{
|
||||
// TODO cache
|
||||
if(!e107::isInstalled('featurebox')) //just in case
|
||||
{
|
||||
return '';
|
||||
}
|
||||
|
||||
if(!$mod)
|
||||
{
|
||||
$ctemplate = 'default';
|
||||
}
|
||||
else
|
||||
{
|
||||
$ctemplate = $mod;
|
||||
}
|
||||
|
||||
parse_str($parm, $parm);
|
||||
|
||||
$category = new plugin_featurebox_category();
|
||||
$category->loadByTemplate($ctemplate);
|
||||
if(!$category->hasData())
|
||||
{
|
||||
return '';
|
||||
}
|
||||
|
||||
$tree = $category->getItemTree();
|
||||
if($tree->isEmpty())
|
||||
{
|
||||
return '';
|
||||
}
|
||||
|
||||
$tmpl = $this->getFboxTemplate($category);
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieve template array by category
|
||||
*
|
||||
* @param plugin_featurebox_category $category
|
||||
* @return array
|
||||
*/
|
||||
public function getFboxTemplate($category)
|
||||
{
|
||||
$tmpl = e107::getTemplate('featurebox', 'featurebox_category', $category->get('fb_category_template'), 'front');
|
||||
if(!$tmpl && e107::getTemplate('featurebox', 'featurebox_category', $category->get('fb_category_template'), false))
|
||||
{
|
||||
$tmpl = e107::getTemplate('featurebox', 'featurebox_category', $category->get('fb_category_template'), false); // plugin template
|
||||
}
|
||||
elseif(!$tmpl && e107::getTemplate('featurebox', 'featurebox_category', 'default'))
|
||||
{
|
||||
$tmpl = e107::getTemplate('featurebox', 'featurebox_category', 'default'); // theme/plugin default template
|
||||
}
|
||||
elseif(!$tmpl)
|
||||
{
|
||||
$tmpl = e107::getTemplate('featurebox', 'featurebox_category', 'default', false); //plugin default
|
||||
}
|
||||
return $tmpl;
|
||||
}
|
||||
}
|
||||
|
@ -9,8 +9,8 @@
|
||||
* Custom Featurebox install/uninstall/update routines
|
||||
*
|
||||
* $Source: /cvs_backup/e107_0.8/e107_plugins/featurebox/featurebox_setup.php,v $
|
||||
* $Revision: 1.3 $
|
||||
* $Date: 2009-12-08 17:21:31 $
|
||||
* $Revision: 1.4 $
|
||||
* $Date: 2009-12-09 18:33:40 $
|
||||
* $Author: secretr $
|
||||
*
|
||||
*/
|
||||
@ -34,7 +34,7 @@ class featurebox_setup
|
||||
$query = array();
|
||||
$query['fb_category_id'] = 0;
|
||||
$query['fb_category_title'] = 'General';
|
||||
$query['fb_category_layout'] = 'default';
|
||||
$query['fb_category_template'] = 'default';
|
||||
$query['fb_category_random'] = 0;
|
||||
$query['fb_category_class'] = e_UC_PUBLIC;
|
||||
$query['fb_category_limit'] = 1;
|
||||
@ -55,7 +55,7 @@ class featurebox_setup
|
||||
$query['fb_template'] = 'default';
|
||||
$query['fb_order'] = 0;
|
||||
$query['fb_image'] = '';
|
||||
$query['fb_imageurl'] = 0;
|
||||
$query['fb_imageurl'] = '';
|
||||
$status = e107::getDb('sql2')->db_Insert('featurebox', $query) ? E_MESSAGE_SUCCESS : E_MESSAGE_ERROR;
|
||||
}
|
||||
else
|
||||
|
@ -19,10 +19,10 @@ CREATE TABLE featurebox_category (
|
||||
`fb_category_id` tinyint(3) unsigned NOT NULL AUTO_INCREMENT,
|
||||
`fb_category_title` varchar(200) NOT NULL DEFAULT '',
|
||||
`fb_category_icon` varchar(255) NOT NULL DEFAULT '',
|
||||
`fb_category_layout` varchar(50) NOT NULL DEFAULT 'default',
|
||||
`fb_category_template` varchar(50) NOT NULL DEFAULT 'default',
|
||||
`fb_category_random` tinyint(1) unsigned NOT NULL DEFAULT '0',
|
||||
`fb_category_class` smallint(5) unsigned NOT NULL DEFAULT '0',
|
||||
`fb_category_limit` tinyint(3) unsigned NOT NULL DEFAULT '1',
|
||||
PRIMARY KEY (`fb_category_id`),
|
||||
UNIQUE KEY `fb_category_layout` (`fb_category_layout`)
|
||||
UNIQUE KEY `fb_category_template` (`fb_category_template`)
|
||||
) TYPE=MyISAM;
|
@ -73,7 +73,7 @@ sup { font-size:1em; vertical-align:top; }
|
||||
ul,ol { list-style:none; }
|
||||
|
||||
/* Tools */
|
||||
.no-display { display:none; }
|
||||
/*.no-display { display:none; }*/
|
||||
.no-margin { margin:0 !important; }
|
||||
.no-padding { padding:0 !important; }
|
||||
.no-bg { background:none !important; }
|
||||
@ -125,7 +125,7 @@ select, .tbox, .helpbox {
|
||||
background:#fff;
|
||||
font:12px arial, helvetica, sans-serif;
|
||||
}
|
||||
option { padding-right: 10px;}
|
||||
option { padding-left: 10px;}
|
||||
input.input-text, textarea, .tbox, .helpbox { padding:2px; }
|
||||
|
||||
select.tbox { min-height:17px; padding: 0px; /* setting the height of empty selects */ }
|
||||
|
@ -23,9 +23,9 @@
|
||||
.nowrap { white-space:nowrap; }
|
||||
|
||||
/* Core Icons */
|
||||
img.icon { border: 0 }
|
||||
img.icon { vertical-align: middle; border: 0 }
|
||||
img.icon.list { margin: 0px 5px 5px 0px }
|
||||
img.icon.action { vertical-align: middle }
|
||||
img.icon.action { }
|
||||
img.S16 { width: 16px; height: 16px }
|
||||
img.S32 { width: 32px; height: 32px }
|
||||
img.S64 { width: 64px; height: 64px }
|
||||
@ -75,7 +75,7 @@ sup { font-size:1em; vertical-align:top; }
|
||||
ul,ol { list-style:none; }
|
||||
|
||||
/* Tools */
|
||||
.no-display { display:none; }
|
||||
/*.no-display { display:none; }*/
|
||||
.no-margin { margin:0 !important; }
|
||||
.no-padding { padding:0 !important; }
|
||||
.no-bg { background:none !important; }
|
||||
@ -91,8 +91,70 @@ pre {
|
||||
word-wrap: break-word; /* Internet Explorer 5.5+ */
|
||||
}
|
||||
|
||||
/********** Page Loading Status default style */
|
||||
#loading-mask { color: #556B2F; font-size: 1.2em; font-weight:bold; position:absolute; text-align: center; padding: 0; margin: 0; background-color: transparent; }
|
||||
#loading-mask .loader { position: fixed; top: 40%; left: 50%; width: 200px; text-align: center; background: #F0F9E3 none repeat scroll 0 0; border: 2px solid #556B2F; font-weight: bold; padding: 10px 5px; margin-left: -100px; margin-top: 0; }
|
||||
#loading-mask img { margin: 10px auto; }
|
||||
|
||||
/********** Element Loading Status default style */
|
||||
.element-loading-mask { background-repeat: no-repeat; background-position: 50% 50%; background-color: #f5f5f5; }
|
||||
|
||||
/********** Auto complete default style */
|
||||
div.e-autocomplete {
|
||||
position:absolute;
|
||||
width:250px;
|
||||
background-color:white;
|
||||
border:1px solid #c0c0c0;
|
||||
margin:0;
|
||||
padding:0;
|
||||
}
|
||||
div.e-autocomplete ul {
|
||||
list-style-type:none;
|
||||
margin:0;
|
||||
padding:0;
|
||||
font-weight: bold; font-size: 11px
|
||||
}
|
||||
div.e-autocomplete ul li.selected { background-color: #f5f5f5;}
|
||||
div.e-autocomplete ul li {
|
||||
list-style-type:none;
|
||||
display:block;
|
||||
margin:0;
|
||||
padding: 5px;
|
||||
cursor:pointer;
|
||||
|
||||
}
|
||||
div.e-autocomplete ul li span.informal { font-weight: normal; font-size: 9px}
|
||||
|
||||
/********** Misc */
|
||||
.e-pointer { cursor: pointer; } /* Pointer Hand */
|
||||
.expand-container { padding: 10px; } /* Block with expandable items */
|
||||
.nextprev-bar { clear: both; padding: 5px; font-size: 14px; margin: 5px; border:1px solid #ddd; } /* Page NextPrev navigation block */
|
||||
|
||||
|
||||
/******** SyS Messages / Message text formatting */
|
||||
/* message boxes */
|
||||
.s-message { }
|
||||
|
||||
.s-message div.info,
|
||||
.s-message div.error,
|
||||
.s-message div.success,
|
||||
.s-message div.debug,
|
||||
.s-message div.warning { padding: 5px; margin-bottom: 10px; }
|
||||
|
||||
|
||||
.s-message div.info { background-color:#C1E0FF; border: 1px solid #3399FF; }
|
||||
.s-message div.error { background-color:#FFCECE; border: 1px solid #CC0000; }
|
||||
.s-message div.success { background-color:#DFFFDF; border: 1px solid #009900; }
|
||||
.s-message div.warning { background-color:#FFFFD5; border: 1px solid #FFCC00; }
|
||||
.s-message div.debug { background-color:#FFFFFF; border: 1px solid #EAEAEA; }
|
||||
|
||||
.s-message .s-message-title { height: 32px; background: 0 50% no-repeat; padding-left: 42px; font-size: 14px; font-weight: bold; line-height: 32px; }
|
||||
|
||||
.s-message div.info .s-message-title { background-image: url(images/messagebox_info.png); }
|
||||
.s-message div.error .s-message-title { background-image: url(images/messagebox_critical.png); }
|
||||
.s-message div.success .s-message-title { background-image: url(images/ok.png); }
|
||||
.s-message div.warning .s-message-title { background-image: url(images/messagebox_warning.png); }
|
||||
.s-message div.debug .s-message-title { background-image: url(images/messagebox_info.png); }
|
||||
|
||||
/* message text (overall) */
|
||||
.warning { color: #FF6600 }
|
||||
@ -100,3 +162,31 @@ pre {
|
||||
.error { color: #FF0000 }
|
||||
.info {}
|
||||
.required { color:red }
|
||||
|
||||
/* THEME SPECIFIC CSS *********************************************************************************************/
|
||||
/******** Page Base */
|
||||
.wrapper { width: 100%; }
|
||||
.header { padding: 20px 15px 0; }
|
||||
.header-content { border: 1px solid #DDDDDD}
|
||||
.page-body { padding: 20px 15px 0; }
|
||||
.footer {}
|
||||
legend { font-size: 14px; font-weight: bold; padding: 5px; }
|
||||
|
||||
/******** Block Elements */
|
||||
.block { border: 1px solid #DDDDDD; margin-bottom: 10px;}
|
||||
.block-text { padding: 10px 10px 10px; }
|
||||
.block h1.caption { padding: 5px 10px 5px; vertical-align: middle; }
|
||||
.block h2.caption, .block h4.caption { padding: 5px 10px 5px; border-bottom: 1px solid #DDDDDD; }
|
||||
|
||||
/******** Horizontal navigation ADMIN_NAV_ALT */
|
||||
.navigation { border: 1px solid #DDDDDD;}
|
||||
|
||||
/******** Layout */
|
||||
.main-table { width: 100%; border: 0 none; }
|
||||
.col-left { width: 220px; }
|
||||
.col-right { width: 220px;}
|
||||
.col-main { padding: 0 15px 0 15px;}
|
||||
.inner-wrapper { margin: 0 5px }
|
||||
|
||||
/******** Horizontal navigation ADMIN_NAV_ALT */
|
||||
.navigation { border: 1px solid #DDDDDD;}
|
||||
|
@ -62,11 +62,10 @@ function theme_head() {
|
||||
|
||||
function tablestyle($caption, $text, $mod) {
|
||||
global $style;
|
||||
$class = '';
|
||||
if(is_string($mod) && $mod == 'admin_help') $class = ' '.str_replace('_', '-', $mod);
|
||||
|
||||
switch($style) {
|
||||
|
||||
case 'admin_menu' :
|
||||
case 'menu' :
|
||||
echo '
|
||||
<div class="block">
|
||||
<h4 class="caption">'.$caption.'</h4>
|
||||
@ -75,32 +74,10 @@ function tablestyle($caption, $text, $mod) {
|
||||
';
|
||||
break;
|
||||
|
||||
case 'site_info' :
|
||||
echo '
|
||||
<div class="block'.$class.'">
|
||||
<h4 class="caption">'.$caption.'</h4>
|
||||
<div class="block-text">
|
||||
'.$text.'
|
||||
</div>
|
||||
</div>
|
||||
';
|
||||
break;
|
||||
|
||||
case 'admin_content':
|
||||
echo '
|
||||
<div class="block">
|
||||
<h2 class="caption">'.$caption.'</h2>
|
||||
<div class="block-text">
|
||||
'.$text.'
|
||||
</div>
|
||||
</div>
|
||||
';
|
||||
break;
|
||||
|
||||
default:
|
||||
echo '
|
||||
<div class="block">
|
||||
<h4>'.$caption.'</h4>
|
||||
<h1 class="caption">'.$caption.'</h1>
|
||||
<div class="block-text">
|
||||
'.$text.'
|
||||
</div>
|
||||
@ -110,8 +87,51 @@ function tablestyle($caption, $text, $mod) {
|
||||
}
|
||||
}
|
||||
|
||||
$HEADER['default'] = '';
|
||||
$FOOTER['default'] = '';
|
||||
$HEADER['default'] = '
|
||||
<div class="wrapper">
|
||||
<div class="header">
|
||||
<div class="header-content">
|
||||
BLANK HEADER
|
||||
</div>
|
||||
<div style="height: 20px;"><!-- --></div>
|
||||
<div class="navigation">
|
||||
<div id="main-nav">{SITELINKS}</div>
|
||||
<div class="clear"><!-- --></div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="page-body">
|
||||
<table class="main-table" cellpadding="0" cellspacing="0">
|
||||
<tr>
|
||||
|
||||
<td class="col-left">
|
||||
{SETSTYLE=menu}
|
||||
{MENU=1}
|
||||
</td>
|
||||
|
||||
<td>
|
||||
<div class="col-main">
|
||||
<div class="inner-wrapper">
|
||||
{SETSTYLE=content}
|
||||
{FEATUREBOX|blank_default=notablestyle}
|
||||
';
|
||||
$FOOTER['default'] = '
|
||||
</div>
|
||||
</div>
|
||||
</td>
|
||||
<td class="col-right">
|
||||
<div class="col-right">
|
||||
{SETSTYLE=menu}
|
||||
{MENU=2}
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
</div>
|
||||
<div class="footer">
|
||||
<!-- -->
|
||||
</div>
|
||||
</div>
|
||||
';
|
||||
|
||||
$HEADER['alternate'] = '';
|
||||
$FOOTER['alternate'] = '';
|
||||
|
Loading…
x
Reference in New Issue
Block a user