Skip to content

Commit

Permalink
feature 2541 multisize
Browse files Browse the repository at this point in the history
- admin GUI for choosing derivative parameters + persistence

git-svn-id: http://piwigo.org/svn/trunk@12820 68402e56-0260-453c-a942-63ccdbb3a9ee
  • Loading branch information
rvelices committed Jan 1, 2012
1 parent ec82ebb commit 95a78ca
Show file tree
Hide file tree
Showing 9 changed files with 432 additions and 46 deletions.
1 change: 1 addition & 0 deletions admin.php
Expand Up @@ -165,6 +165,7 @@
'U_MAINTENANCE'=> $link_start.'maintenance',
'U_NOTIFICATION_BY_MAIL'=> $link_start.'notification_by_mail',
'U_CONFIG_GENERAL'=> $link_start.'configuration',
'U_CONFIG_DERIVATIVES'=> $link_start.'derivatives',
'U_CONFIG_DISPLAY'=> $conf_link.'default',
'U_CONFIG_EXTENTS'=> $link_start.'extend_for_templates',
'U_CONFIG_MENUBAR'=> $link_start.'menubar',
Expand Down
235 changes: 235 additions & 0 deletions admin/derivatives.php
@@ -0,0 +1,235 @@
<?php
// +-----------------------------------------------------------------------+
// | Piwigo - a PHP based photo gallery |
// +-----------------------------------------------------------------------+
// | Copyright(C) 2008-2011 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. |
// +-----------------------------------------------------------------------+

defined('PHPWG_ROOT_PATH') or trigger_error('Hacking attempt!', E_USER_ERROR);

$errors = array();

if ( isset($_POST['d']) )
{
$pderivatives = $_POST['d'];

// step 1 - sanitize HTML input
foreach($pderivatives as $type => &$pderivative)
{
if ($pderivative['must_square'] = ($type==IMG_SQUARE ? true : false))
{
$pderivative['h'] = $pderivative['w'];
$pderivative['minh'] = $pderivative['minw'] = $pderivative['w'];
$pderivative['crop'] = 100;
}
$pderivative['must_enable'] = ($type==IMG_SQUARE || $type==IMG_THUMB)? true : false;
$pderivative['enabled'] = isset($pderivative['enabled']) || $pderivative['must_enable'] ? true : false;
}
unset($pderivative);

// step 2 - check validity
$prev_w = $prev_h = 0;
foreach(ImageStdParams::get_all_types() as $type)
{
$pderivative = $pderivatives[$type];
if (!$pderivative['enabled'])
continue;

$v = intval($pderivative['w']);
if ($v<=0 || $v<=$prev_w)
{
$errors[$type]['w'] = '>'.$prev_w;
}
$v = intval($pderivative['h']);
if ($v<=0 || $v<=$prev_h)
{
$errors[$type]['h'] = '>'.$prev_h;
}
$v = intval($pderivative['crop']);
if ($v<0 || $v>100)
{
$errors[$type]['crop'] = '[0..100]';
}

if ($v!=0)
{
$v = intval($pderivative['minw']);
if ($v<0 || $v>intval($pderivative['w']))
{
$errors[$type]['minw'] = '[0..'.intval($pderivative['w']).']';
}
$v = intval($pderivative['minh']);
if ($v<0 || $v>intval($pderivative['h']))
{
$errors[$type]['minh'] = '[0..'.intval($pderivative['h']).']';
}
}

if (count($errors)==0)
{
$prev_w = intval($pderivative['w']);
$prev_h = intval($pderivative['h']);
}
}
// step 3 - save data
if (count($errors)==0)
{
$enabled = ImageStdParams::get_defined_type_map();
$disabled = @unserialize( @$conf['disabled_derivatives'] );
if ($disabled===false)
{
$disabled = array();
}
$changed_types = array();

foreach(ImageStdParams::get_all_types() as $type)
{
$pderivative = $pderivatives[$type];

if ($pderivative['enabled'])
{
$new_params = new DerivativeParams(
new SizingParams(
array($pderivative['w'],$pderivative['h']),
round($pderivative['crop'] / 100, 2),
array($pderivative['minw'],$pderivative['minh'])
)
);
if (isset($enabled[$type]))
{
$old_params = $enabled[$type];
$same = true;
if ( !size_equals($old_params->sizing->ideal_size, $new_params->sizing->ideal_size)
or $old_params->sizing->max_crop != $new_params->sizing->max_crop)
{
$same = false;
}

if ( $same && $new_params->sizing->max_crop != 0
&& !size_equals($old_params->sizing->min_size, $new_params->sizing->min_size) )
{
$same = false;
}

if (!$same)
{
$new_params->last_mod_time = time();
$changed_types[] = $type;
}
else
{
$new_params->last_mod_time = $old_params->last_mod_time;
}
$enabled[$type] = $new_params;
}
else
{// now enabled, before was disabled
$enabled[$type] = $new_params;
unset($disabled[$type]);
}
}
else
{// disabled
if (isset($enabled[$type]))
{// now disabled, before was enabled
$disabled[$type] = $enabled[$type];
unset($enabled[$type]);
}
}
}

$enabled_by = array(); // keys ordered by all types
foreach(ImageStdParams::get_all_types() as $type)
{
if (isset($enabled[$type]))
{
$enabled_by[$type] = $enabled[$type];
}
}
ImageStdParams::set_and_save($enabled_by);
if (count($disabled)==0)
{
$query='DELETE FROM '.CONFIG_TABLE.' WHERE param = \'disabled_derivatives\'';
pwg_query($query);
}
else
{
conf_update_param('disabled_derivatives', addslashes(serialize($disabled)) );
}
$conf['disabled_derivatives']=serialize($disabled);

if (count($changed_types))
{
clear_derivative_cache($changed_types);
}
}
else
{
$template->assign('derivatives', $pderivatives);
$template->assign('ferrors', $errors);
}
}

if (count($errors)==0)
{
$enabled = ImageStdParams::get_defined_type_map();
$disabled = @unserialize( @$conf['disabled_derivatives'] );
if ($disabled===false)
{
$disabled = array();
}

$tpl_vars = array();
foreach(ImageStdParams::get_all_types() as $type)
{
$tpl_var = array();

$tpl_var['must_square'] = ($type==IMG_SQUARE ? true : false);
$tpl_var['must_enable'] = ($type==IMG_SQUARE || $type==IMG_THUMB)? true : false;

if ($params=@$enabled[$type])
{
$tpl_var['enabled']=true;
}
else
{
$tpl_var['enabled']=false;
$params=@$disabled[$type];
}

if ($params)
{
list($tpl_var['w'],$tpl_var['h']) = $params->sizing->ideal_size;
if ( ($tpl_var['crop'] = round(100*$params->sizing->max_crop)) > 0)
{
list($tpl_var['minw'],$tpl_var['minh']) = $params->sizing->min_size;
}
else
{
$tpl_var['minw'] = $tpl_var['minh'] = "";
}
}
$tpl_vars[$type]=$tpl_var;
}
$template->assign('derivatives', $tpl_vars);
}

$template->set_filename('derivatives', 'derivatives.tpl');
$template->assign_var_from_handle('ADMIN_CONTENT', 'derivatives');
?>
24 changes: 18 additions & 6 deletions admin/include/functions.php
Expand Up @@ -2054,6 +2054,7 @@ function get_active_menu($menu_page)
return 4;

case 'configuration':
case 'derivatives':
case 'extend_for_templates':
case 'menubar':
case 'themes':
Expand Down Expand Up @@ -2247,23 +2248,34 @@ function get_admins($include_webmaster=true)
return array_from_query($query, 'user_id');
}

function clear_derivative_cache($type='all')
/** delete all derivative files for one or several types */
function clear_derivative_cache($types='all')
{
$pattern='#.*-';
if ($type == 'all')
if ($types == 'all')
{
$types = ImageStdParams::get_all_types();
$types[] = IMG_CUSTOM;
}
elseif (!is_array($types))
{
$types = array($types);
}

if (count($types)>1)
{
$type_urls = array();
foreach(ImageStdParams::get_all_types() as $dtype)
foreach($types as $dtype)
{
$type_urls[] = derivative_to_url($dtype);
}
$type_urls[] = derivative_to_url(IMG_CUSTOM);
$pattern .= '(' . implode('|',$type_urls) . ')';
}
else
{
$pattern .= derivative_to_url($type);
$pattern .= derivative_to_url($types[0]);
}

$pattern.='(_[a-zA-Z0-9]+)*\.[a-zA-Z0-9]{3,4}$#';
if ($contents = opendir(PHPWG_ROOT_PATH.PWG_DERIVATIVE_DIR))
{
Expand Down Expand Up @@ -2320,7 +2332,7 @@ function clear_derivative_cache_rec($path, $pattern)
unlink($path.'/index.htm');
}
clearstatcache();
rmdir($path);
@rmdir($path);
}
return $rmdir;
}
Expand Down
1 change: 1 addition & 0 deletions admin/themes/default/template/admin.tpl
Expand Up @@ -84,6 +84,7 @@ jQuery(document).ready(function(){ldelim}
<dd>
<ul>
<li><a href="{$U_CONFIG_GENERAL}">{'Options'|@translate}</a></li>
<li><a href="{$U_CONFIG_DERIVATIVES}">{'Derivatives'|@translate}</a></li>
<li><a href="{$U_CONFIG_MENUBAR}">{'Menu Management'|@translate}</a></li>
<li><a href="{$U_CONFIG_EXTENTS}">{'Templates'|@translate}</a></li>
<li><a href="{$U_CONFIG_LANGUAGES}">{'Languages'|@translate}</a></li>
Expand Down
79 changes: 79 additions & 0 deletions admin/themes/default/template/derivatives.tpl
@@ -0,0 +1,79 @@
<h2>{'Derivatives'|@translate}</h2>

{html_head}{literal}
<style type="text/css">
#derviativesForm .dError {
background-color: red;
color: yellow;
}

#derviativesForm .dErrorDesc {
}

#derviativesForm TABLE THEAD {
height: 3em;
}

#derviativesForm TABLE INPUT[type="text"] {
border: 0;
width: 5em;
}

</style>
{/literal}{/html_head}

<form method="post" id="derviativesForm">
<table class="table2">
<thead>
<tr>
<td></td>
<td>Enabled</td>
<td>{'Width'|@translate}</td>
<td>{'Height'|@translate}</td>
<td>{'Crop'|@translate} (%)</td>
<td>{'Min Width'|@translate}</td>
<td>{'Min Height'|@translate}</td>
</tr>
</thead>
{foreach from=$derivatives item=d key=type}
<tr>
<td>{$type|@translate}</td>
<td>
{if $d.must_enable}
x
{else}
<input type="checkbox" name="d[{$type}][enabled]" {if $d.enabled}checked="checked"{/if}>
{/if}
</td>
<td>
<input type="text" name="d[{$type}][w]" value="{$d.w}"{if isset($ferrors.$type.w)}class="dError"{/if}>
{if isset($ferrors.$type.w)}<span class="dErrorDesc" title="{$ferrors.$type.w}">!</span>{/if}
</td>
<td>{if !$d.must_square}
<input type="text" name="d[{$type}][h]" value="{$d.h}"{if isset($ferrors.$type.h)}class="dError"{/if}>
{if isset($ferrors.$type.h)}<span class="dErrorDesc" title="{$ferrors.$type.h}">!</span>{/if}
{/if}</td>
<td>{if !$d.must_square}
<input type="text" name="d[{$type}][crop]" value="{$d.crop}"{if isset($ferrors.$type.crop)}class="dError"{/if}>
{if isset($ferrors.$type.crop)}<span class="dErrorDesc" title="{$ferrors.$type.crop}">!</span>{/if}
{/if}</td>
<td>{if !$d.must_square}
<input type="text" name="d[{$type}][minw]" value="{$d.minw}"{if isset($ferrors.$type.minw)}class="dError"{/if}>
{if isset($ferrors.$type.minw)}<span class="dErrorDesc" title="{$ferrors.$type.minw}">!</span>{/if}
{/if}</td>
<td>{if !$d.must_square}
<input type="text" name="d[{$type}][minh]" value="{$d.minh}"{if isset($ferrors.$type.minh)}class="dError"{/if}>
{if isset($ferrors.$type.minh)}<span class="dErrorDesc" title="{$ferrors.$type.minh}">!</span>{/if}
{/if}</td>

</tr>
{/foreach}
</table>
<p><input type="submit" value="{'Submit'|@translate}"></p>
</form>

{footer_script}{literal}
jQuery(".dError").bind("focus", function () {
jQuery(this).removeClass("dError");
} );
{/literal}{/footer_script}

0 comments on commit 95a78ca

Please sign in to comment.