diff options
author | vdigital <vdigital@piwigo.org> | 2008-07-14 21:42:40 +0000 |
---|---|---|
committer | vdigital <vdigital@piwigo.org> | 2008-07-14 21:42:40 +0000 |
commit | df29ffbde72e88635f454d5d6d84c5a7209460f3 (patch) | |
tree | 0a35be2731fe75fe86e11adad6f0147f180956d8 /admin | |
parent | b7709eae0dcb81df9eb668407b64f2cde38ba1f0 (diff) |
Feature template-extension based on 2006 chrisaga's idea.
chrisaga wrote: "If you want to make some template customization without building a brand new
template, you should use ..."
git-svn-id: http://piwigo.org/svn/trunk@2434 68402e56-0260-453c-a942-63ccdbb3a9ee
Diffstat (limited to 'admin')
-rw-r--r-- | admin/extend_for_templates.php | 213 | ||||
-rw-r--r-- | admin/template/yoga/admin.tpl | 1 | ||||
-rw-r--r-- | admin/template/yoga/admin/extend_for_templates.tpl | 34 | ||||
-rw-r--r-- | admin/template/yoga/theme/admin/themeconf.inc.php | 1 |
4 files changed, 249 insertions, 0 deletions
diff --git a/admin/extend_for_templates.php b/admin/extend_for_templates.php new file mode 100644 index 000000000..c6319368a --- /dev/null +++ b/admin/extend_for_templates.php @@ -0,0 +1,213 @@ +<?php +// +-----------------------------------------------------------------------+ +// | Piwigo - a PHP based picture gallery | +// +-----------------------------------------------------------------------+ +// | Copyright(C) 2008 Piwigo Team http://piwigo.org | +// | Copyright(C) 2003-2008 PhpWebGallery Team http://phpwebgallery.net | +// | Copyright(C) 2002-2003 Pierrick LE GALL http://le-gall.net/pierrick | +// +-----------------------------------------------------------------------+ +// | This program is free software; you can redistribute it and/or modify | +// | it under the terms of the GNU General Public License as published by | +// | the Free Software Foundation | +// | | +// | This program is distributed in the hope that it will be useful, but | +// | WITHOUT ANY WARRANTY; without even the implied warranty of | +// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | +// | General Public License for more details. | +// | | +// | You should have received a copy of the GNU General Public License | +// | along with this program; if not, write to the Free Software | +// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, | +// | USA. | +// +-----------------------------------------------------------------------+ + +/** + * Define replacement conditions for each template from template-extension + * (template called "replacer"). + * + * "original template" from ./template/yoga (or any other than yoga) + * will be replaced by a "replacer" if the replacer is linked to this "original template" + * (and optionally, when the requested URL contains an "optional URL keyword"). + * + * "Optional URL keywords" are those you can find after the module name in URLs. + * + * Therefore "Optional URL keywords" can be an active "permalink" + * (see permalinks in our documentation for further explanation). + */ + +// +-----------------------------------------------------------------------+ +// | functions | +// +-----------------------------------------------------------------------+ + +/** + * returns a list of templates currently available in template-extension + * + * Each .tpl file is extracted from template-extension. + * + * @return array + */ +function get_extents($start='') +{ + if ($start == '') { $start = './template-extension'; } + $dir = opendir($start); + $extents = array(); + + while (($file = readdir($dir)) !== false) + { + if ( $file == '.' or $file == '..' or $file == '.svn') continue; + $path = $start . '/' . $file; + if (is_dir($path)) + { + $extents = array_merge($extents, get_extents($path)); + } + elseif ( !is_link($path) and file_exists($path) + and strripos($path,'.tpl') > 0 ) + { + $extents[] = substr($path, 21); + } + } + return $extents; +} +// +-----------------------------------------------------------------------+ +// initialization | +// +-----------------------------------------------------------------------+ + +if (!defined('PHPWG_ROOT_PATH')) { die('Hacking attempt!'); } +include_once(PHPWG_ROOT_PATH.'admin/include/functions.php'); +check_status(ACCESS_ADMINISTRATOR); + +$tpl_extension = isset($conf['extents_for_templates']) ? + unserialize($conf['extents_for_templates']) : array(); +$new_extensions = get_extents(); + +/* Selective URLs keyword */ +$relevant_parameters = array( + '----------', + 'category', + 'favorites', + 'most_visited', + 'best_rated', + 'recent_pics', + 'recent_cats', + 'created-monthly-calendar', + 'posted-monthly-calendar', + 'search', + 'flat', + 'list',); /* <=> Random */ + $query = ' +SELECT permalink + FROM '.CATEGORIES_TABLE.' + WHERE permalink IS NOT NULL +'; + +/* Add active permalinks */ +$permalinks = array_from_query($query, 'permalink'); +$relevant_parameters = array_merge($relevant_parameters, $permalinks); + +/* Link all supported templates to their respective handle */ +$eligible_templates = array( + '----------' => 'N/A', + 'about.tpl' => 'about', + 'identification.tpl' => 'identification', + 'mainpage_categories.tpl' => 'index_category', + 'thumbnails.tpl' => 'index_thumbnails', + 'redirect.tpl' => 'redirect', + 'menubar.tpl' => 'menubar', + 'header.tpl' => 'header', + 'footer.tpl' => 'tail', + 'index.tpl' => 'index', + 'nbm.tpl' => 'nbm', + 'notification.tpl' => 'notification', + 'picture_content.tpl' => 'default_content', + 'slideshow.tpl' => 'picture', /* => slideshow is missing */ + 'picture.tpl' => 'picture', + 'popuphelp.tpl' => 'popuphelp', + 'profile.tpl' => 'profile', + 'profile_content.tpl' => 'profile_content', + 'register.tpl' => 'register', + 'search.tpl' => 'search', + 'search_rules.tpl' => 'search_rules', + 'tags.tpl' => 'tags', + 'upload.tpl' => 'upload',); + $flip_templates = array_flip($eligible_templates); +// +-----------------------------------------------------------------------+ +// | selected templates | +// +-----------------------------------------------------------------------+ + +if (isset($_POST['submit']) and !is_adviser()) +{ + $replacements = array(); + $i = 0; + while (isset($_POST['reptpl'][$i])) + { + $newtpl = $_POST['reptpl'][$i]; + $original = $_POST['original'][$i]; + $handle = $eligible_templates[$original]; + $url_keyword = $_POST['url'][$i]; + if ($url_keyword == '----------') $url_keyword = 'N/A'; + if ($handle != 'N/A') + { + $replacements[$newtpl] = array($handle, $url_keyword); + } + $i++; + } + $conf['extents_for_templates'] = serialize($replacements); + $tpl_extension = $replacements; + /* ecrire la nouvelle conf */ + $query = " +UPDATE ".CONFIG_TABLE." + SET value = '". $conf['extents_for_templates'] ."' +WHERE param = 'extents_for_templates';"; + if (pwg_query($query)) + { + array_push($page['infos'], + l10n('Templates recorded.')); + } +} + +// +-----------------------------------------------------------------------+ +// | template init | +// +-----------------------------------------------------------------------+ + +/* Clearing (remove old extents, add new ones) */ +foreach ($tpl_extension as $file => $conditions) +{ + if ( !in_array($file,$new_extensions) ) unset($tpl_extension[$file]); + else $new_extensions = array_diff($new_extensions,array($file)); +} +foreach ($new_extensions as $file) +{ + $tpl_extension[$file] = array('N/A' => 'N/A'); +} + +$template->set_filenames(array('extend_for_templates' + => 'admin/extend_for_templates.tpl')); + +$base_url = PHPWG_ROOT_PATH.'admin.php?page=extend_for_templates'; + +$template->assign( + array( + 'U_HELP' => get_root_url().'popuphelp.php?page=extend_for_templates', + )); +ksort($tpl_extension); +foreach ($tpl_extension as $file => $conditions) +{ + $handle = $conditions[0]; + $url_keyword = $conditions[1]; + { + $template->append('extents', + array( + 'replacer' => $file, + 'url_parameter' => $relevant_parameters, + 'original_tpl' => array_keys($eligible_templates), + 'selected_tpl' => $flip_templates[$handle], + 'selected_url' => $url_keyword,) + ); + } +} +// +-----------------------------------------------------------------------+ +// | html code display | +// +-----------------------------------------------------------------------+ + +$template->assign_var_from_handle('ADMIN_CONTENT', 'extend_for_templates'); +?>
\ No newline at end of file diff --git a/admin/template/yoga/admin.tpl b/admin/template/yoga/admin.tpl index 1c5c13035..e0d44a17e 100644 --- a/admin/template/yoga/admin.tpl +++ b/admin/template/yoga/admin.tpl @@ -23,6 +23,7 @@ <ul> <li><a href="{$U_CONFIG_GENERAL}">{'conf_general'|@translate}</a></li> <li><a href="{$U_CONFIG_DISPLAY}">{'conf_display'|@translate}</a></li> + <li><a href="{$U_CONFIG_EXTENTS}">{'conf_extents'|@translate}</a></li> </ul> </dd> </dl> diff --git a/admin/template/yoga/admin/extend_for_templates.tpl b/admin/template/yoga/admin/extend_for_templates.tpl new file mode 100644 index 000000000..fdac49b7d --- /dev/null +++ b/admin/template/yoga/admin/extend_for_templates.tpl @@ -0,0 +1,34 @@ +{* $Id$ *} +<div class="titrePage"><h2>{'extend_for_templates'|@translate}</h2> +</div> +{if isset($extents)} +<h4>{'Replacement of original templates'|@translate}</h4> +<form method="post" name="extend_for_templates" id="extend_for_templates" action="{$F_ACTION}"> + <table class="table2"> + <tr class="throw"> + <th>{'Replacers'|@translate}</th> + <th>{'Original templates'|@translate}</th> + <th>{'Optional URL keyword'|@translate}</th> + </tr> + {foreach from=$extents item=tpl name=extent_loop} + <tr class="{if $smarty.foreach.extent_loop.index is odd}row1{else}row2{/if}"> + <td> + <input type="hidden" name=reptpl[] value="{$tpl.replacer}" /> + {$tpl.replacer} + </td> + <td> + {html_options name=original[] output=$tpl.original_tpl values=$tpl.original_tpl selected=$tpl.selected_tpl} + </td> + <td> + {html_options name=url[] output=$tpl.url_parameter values=$tpl.url_parameter selected=$tpl.selected_url} + </td> + </tr> + {/foreach} + </table> + {if !is_adviser()} + <p> + <input class="submit" type="submit" value="{'Submit'|@translate}" name="submit" /> + </p> + {/if} +</form> +{/if}
\ No newline at end of file diff --git a/admin/template/yoga/theme/admin/themeconf.inc.php b/admin/template/yoga/theme/admin/themeconf.inc.php index 9629b274f..e3b6fc63e 100644 --- a/admin/template/yoga/theme/admin/themeconf.inc.php +++ b/admin/template/yoga/theme/admin/themeconf.inc.php @@ -8,6 +8,7 @@ function selected_admin_menu() { switch ($_GET['page']) { case 'configuration': + case 'extend_for_templates': return 1; case 'site_manager': case 'site_update': |