mirror of
https://github.com/Piwigo/Piwigo.git
synced 2026-06-01 20:04:51 +02:00
fixes #2411 disable 3xl and 4xl by default
- Add 3XL and 4XL sizes to defaults but keep them disabled by default - Update admin restore default derivatives resets sizes and clears cache - Update migration 177 => updates existing installs: set 3XL/4XL as disabled
This commit is contained in:
@@ -355,10 +355,12 @@ WHERE param = \''.$row['param'].'\'
|
||||
// restore default derivatives settings
|
||||
if ('sizes' == $page['section'] and isset($_GET['action']) and 'restore_settings' == $_GET['action'])
|
||||
{
|
||||
ImageStdParams::set_and_save( ImageStdParams::get_default_sizes() );
|
||||
pwg_query('DELETE FROM '.CONFIG_TABLE.' WHERE param = \'disabled_derivatives\'');
|
||||
ImageStdParams::restore_default();
|
||||
clear_derivative_cache();
|
||||
|
||||
// reset conf
|
||||
load_conf_from_db();
|
||||
|
||||
$template->assign(
|
||||
array(
|
||||
'save_success' => l10n('Your configuration settings are saved'),
|
||||
@@ -569,7 +571,7 @@ switch ($page['section'])
|
||||
|
||||
// derivatives = multiple size
|
||||
$enabled = ImageStdParams::get_defined_type_map();
|
||||
$disabled = @unserialize(@$conf['disabled_derivatives']);
|
||||
$disabled = safe_unserialize(ImageStdParams::get_disabled_type_map());
|
||||
if ($disabled === false)
|
||||
{
|
||||
$disabled = array();
|
||||
|
||||
@@ -134,7 +134,7 @@ if (count($errors) == 0)
|
||||
ImageStdParams::$quality = intval($_POST['resize_quality']);
|
||||
|
||||
$enabled = ImageStdParams::get_defined_type_map();
|
||||
$disabled = @unserialize( @$conf['disabled_derivatives'] );
|
||||
$disabled = safe_unserialize(ImageStdParams::get_disabled_type_map());
|
||||
if ($disabled === false)
|
||||
{
|
||||
$disabled = array();
|
||||
@@ -228,16 +228,7 @@ if (count($errors) == 0)
|
||||
}
|
||||
|
||||
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);
|
||||
ImageStdParams::set_and_save_disabled($disabled);
|
||||
|
||||
if (count($changed_types))
|
||||
{
|
||||
|
||||
@@ -1105,7 +1105,7 @@ function get_optimal_dimensions_for_representative()
|
||||
global $conf;
|
||||
|
||||
$enabled = ImageStdParams::get_defined_type_map();
|
||||
$disabled = @unserialize(@$conf['disabled_derivatives']);
|
||||
$disabled = safe_unserialize(ImageStdParams::get_disabled_type_map());
|
||||
if ($disabled === false)
|
||||
{
|
||||
$disabled = array();
|
||||
|
||||
@@ -57,11 +57,15 @@ final class ImageStdParams
|
||||
IMG_SQUARE, IMG_THUMB, IMG_XXSMALL, IMG_XSMALL, IMG_SMALL,
|
||||
IMG_MEDIUM, IMG_LARGE, IMG_XLARGE, IMG_XXLARGE, IMG_3XLARGE, IMG_4XLARGE
|
||||
);
|
||||
/** @var string[] */
|
||||
private static $disabled_types_by_default = array(IMG_3XLARGE, IMG_4XLARGE);
|
||||
/** @var DerivativeParams[] */
|
||||
private static $all_type_map = array();
|
||||
/** @var DerivativeParams[] */
|
||||
private static $type_map = array();
|
||||
/** @var DerivativeParams[] */
|
||||
private static $disabled_type_map = array();
|
||||
/** @var DerivativeParams[] */
|
||||
private static $undefined_type_map = array();
|
||||
/** @var WatermarkParams */
|
||||
private static $watermark;
|
||||
@@ -94,6 +98,18 @@ final class ImageStdParams
|
||||
return self::$type_map;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return DerivativeParams[]
|
||||
*/
|
||||
static function get_disabled_type_map()
|
||||
{
|
||||
if (count(self::$disabled_type_map))
|
||||
{
|
||||
return self::$disabled_type_map;
|
||||
}
|
||||
return conf_get_param('disabled_derivatives', array());
|
||||
}
|
||||
|
||||
/**
|
||||
* @return DerivativeParams[]
|
||||
*/
|
||||
@@ -161,7 +177,8 @@ final class ImageStdParams
|
||||
else
|
||||
{
|
||||
self::$watermark = new WatermarkParams();
|
||||
self::$type_map = self::get_default_sizes();
|
||||
self::$type_map = self::get_enabled_default_sizes();
|
||||
self::$disabled_type_map = self::get_disabled_default_sizes();
|
||||
self::save();
|
||||
}
|
||||
self::build_maps();
|
||||
@@ -199,6 +216,39 @@ final class ImageStdParams
|
||||
'c' => self::$custom,
|
||||
) );
|
||||
conf_update_param('derivatives', addslashes($ser) );
|
||||
|
||||
self::save_disabled();
|
||||
}
|
||||
|
||||
/**
|
||||
* Saves the disabled configuration in database.
|
||||
*/
|
||||
static function save_disabled()
|
||||
{
|
||||
if (count(self::$disabled_type_map) > 0)
|
||||
{
|
||||
$disabled = addslashes(serialize(self::$disabled_type_map));
|
||||
conf_update_param('disabled_derivatives', $disabled);
|
||||
}
|
||||
else
|
||||
{
|
||||
$query='DELETE FROM '.CONFIG_TABLE.' WHERE param = \'disabled_derivatives\'';
|
||||
pwg_query($query);
|
||||
}
|
||||
}
|
||||
|
||||
static function set_and_save_disabled($map)
|
||||
{
|
||||
self::$disabled_type_map = $map;
|
||||
self::save_disabled();
|
||||
}
|
||||
|
||||
static function restore_default()
|
||||
{
|
||||
self::$type_map = self::get_enabled_default_sizes();
|
||||
self::$disabled_type_map = self::get_disabled_default_sizes();
|
||||
self::save();
|
||||
self::build_maps();
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -227,6 +277,29 @@ final class ImageStdParams
|
||||
return $arr;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return DerivativeParams[]
|
||||
*/
|
||||
static function get_enabled_default_sizes()
|
||||
{
|
||||
$default_sizes = self::get_default_sizes();
|
||||
foreach (self::$disabled_types_by_default as $type)
|
||||
{
|
||||
unset($default_sizes[$type]);
|
||||
}
|
||||
return $default_sizes;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return DerivativeParams[]
|
||||
*/
|
||||
static function get_disabled_default_sizes()
|
||||
{
|
||||
$all = self::get_default_sizes();
|
||||
$disabled_sizes = array_intersect_key($all, array_flip(self::$disabled_types_by_default));
|
||||
return $disabled_sizes;
|
||||
}
|
||||
|
||||
/**
|
||||
* Compute 'apply_watermark'
|
||||
*
|
||||
|
||||
+11
-40
@@ -11,54 +11,25 @@ if (!defined('PHPWG_ROOT_PATH'))
|
||||
die('Hacking attempt!');
|
||||
}
|
||||
|
||||
global $conf;
|
||||
$upgrade_description = 'Add 3XL and 4XL sizes (disabled by default)';
|
||||
|
||||
load_conf_from_db();
|
||||
|
||||
$upgrade_description = 'Add 3XL and 4XL sizes';
|
||||
|
||||
//Get predefined image sizes
|
||||
$derivatives = unserialize($conf['derivatives']);
|
||||
|
||||
//get default sizes from derivative_std_params
|
||||
$default_sizes = ImageStdParams::get_default_sizes();
|
||||
|
||||
//Get 3XL and 4XL from default values
|
||||
$default_derivative_3XL = $default_sizes['3xlarge'];
|
||||
$default_derivative_4XL = $default_sizes['4xlarge'];
|
||||
// set new derivatives to add
|
||||
$new_derivatives = array(IMG_3XLARGE, IMG_4XLARGE);
|
||||
|
||||
//We need to make sure that a user hasn't redefined the XXL size bigger than the default 3XL
|
||||
//Get xxl size
|
||||
$xxl = $derivatives['d']['xxlarge'];
|
||||
$xxl_height = $xxl->sizing->ideal_size[0];
|
||||
$xxl_width = $xxl->sizing->ideal_size[1];
|
||||
// get current disabled derivative_std_params
|
||||
$disabled_derivatives = safe_unserialize(ImageStdParams::get_disabled_type_map());
|
||||
|
||||
//get 3xl size
|
||||
$triple_xl_height = $default_sizes['3xlarge']->sizing->ideal_size[0];
|
||||
$triple_xl_width = $default_sizes['3xlarge']->sizing->ideal_size[1];
|
||||
// get the new derivative_std_params and merge with current disabled derivative_std_params
|
||||
$new_disabled_derivatives = array_intersect_key($default_sizes, array_flip($new_derivatives));
|
||||
$disabled = array_merge($disabled_derivatives, $new_disabled_derivatives);
|
||||
|
||||
//Get 4xl size
|
||||
$quad_xl_height = $default_sizes['3xlarge']->sizing->ideal_size[0];
|
||||
$quad_xl_width = $default_sizes['3xlarge']->sizing->ideal_size[1];
|
||||
|
||||
//Set 3XL and 4xl size to be bigger than XXL if needed
|
||||
if ($triple_xl_height < $xxl_height or $triple_xl_width < $xxl_width)
|
||||
{
|
||||
$new_3xl_height = ceil($xxl_height*1.5);
|
||||
$new_3xl_width = ceil($xxl_width*1.5);
|
||||
|
||||
$default_sizes['3xlarge']->sizing->ideal_size[0] = $new_3xl_height;
|
||||
$default_sizes['3xlarge']->sizing->ideal_size[1] = $new_3xl_width;
|
||||
|
||||
$default_sizes['4xlarge']->sizing->ideal_size[0] = ceil($new_3xl_width*1.5);
|
||||
$default_sizes['4xlarge']->sizing->ideal_size[1] = ceil($new_3xl_width*1.5);
|
||||
}
|
||||
|
||||
//Add new 3xl and 4xl to derivatives sizes config
|
||||
$derivatives['d'][IMG_3XLARGE] = $default_sizes['3xlarge'];
|
||||
$derivatives['d'][IMG_4XLARGE] = $default_sizes['4xlarge'];
|
||||
|
||||
// Save derivative new settings
|
||||
ImageStdParams::set_and_save($derivatives['d']);
|
||||
// set and set new derivative_std_params in disabled list
|
||||
ImageStdParams::set_and_save_disabled($disabled);
|
||||
|
||||
echo "\n".$upgrade_description."\n";
|
||||
?>
|
||||
Reference in New Issue
Block a user