From f7bc47d1f6858ee880950522e32e99a0df31aecf Mon Sep 17 00:00:00 2001 From: patdenice Date: Sun, 17 Apr 2011 19:08:06 +0000 Subject: feature:2259 Add "Regenerate Websize Photos" action. git-svn-id: http://piwigo.org/svn/trunk@10454 68402e56-0260-453c-a942-63ccdbb3a9ee --- admin/batch_manager_global.php | 38 ++++-- .../default/template/batch_manager_global.tpl | 146 +++++++++++++-------- include/ws_functions.inc.php | 5 + 3 files changed, 129 insertions(+), 60 deletions(-) diff --git a/admin/batch_manager_global.php b/admin/batch_manager_global.php index 065fa318f..5b61bc9e8 100644 --- a/admin/batch_manager_global.php +++ b/admin/batch_manager_global.php @@ -43,6 +43,12 @@ foreach ($upload_form_config as $param_shortname => $param) $form_values[$param_shortname] = $conf[$param_name]; } +// User cache must not be regenerated during simultaneous ajax requests +if (!isset($user['need_update']) or !$user['need_update']) +{ + getuserdata($user['id'], true); +} + // +-----------------------------------------------------------------------+ // | Check Access and exit when user status is not ok | // +-----------------------------------------------------------------------+ @@ -409,12 +415,27 @@ SELECT id, path array_push($page['infos'], sprintf(l10n('%s thumbnails have been regenerated'), $_POST['regenerateSuccess'])); if ($_POST['regenerateError'] != '0') - array_push($page['warnings'], sprintf(l10n('%s thumbnails have been regenerated'), $_POST['regenerateError'])); + array_push($page['warnings'], sprintf(l10n('%s thumbnails can not be regenerated'), $_POST['regenerateError'])); + + $update_fields = array('thumb_maxwidth', 'thumb_maxheight', 'thumb_quality'); + } + + if ('regenerateWebsize' == $action) + { + if ($_POST['regenerateSuccess'] != '0') + array_push($page['infos'], sprintf(l10n('%s photos have been regenerated'), $_POST['regenerateSuccess'])); + + if ($_POST['regenerateError'] != '0') + array_push($page['warnings'], sprintf(l10n('%s photos can not be regenerated'), $_POST['regenerateError'])); + + $update_fields = array('websize_maxwidth', 'websize_maxheight', 'websize_quality'); + } + if (!empty($update_fields)) + { // Update configuration - $fields = array('thumb_maxwidth', 'thumb_maxheight', 'thumb_quality'); $updates = array(); - foreach ($fields as $field) + foreach ($update_fields as $field) { $value = null; if (!empty($_POST[$field])) @@ -450,11 +471,6 @@ SELECT id, path $updates ); } - function regenerateThumbnails_prefilter($content, $smarty) - { - return str_replace('{$thumbnail.TN_SRC}', '{$thumbnail.TN_SRC}?rand='.md5(uniqid(rand(), true)), $content); - } - $template->set_prefilter('batch_manager_global', 'regenerateThumbnails_prefilter'); $template->delete_compiled_templates(); } @@ -783,6 +799,12 @@ $template->assign( ) ); +function regenerateThumbnails_prefilter($content, $smarty) +{ + return str_replace('{$thumbnail.TN_SRC}', '{$thumbnail.TN_SRC}?rand='.md5(uniqid(rand(), true)), $content); +} +$template->set_prefilter('batch_manager_global', 'regenerateThumbnails_prefilter'); + trigger_action('loc_end_element_set_global'); //----------------------------------------------------------- sending html code diff --git a/admin/themes/default/template/batch_manager_global.tpl b/admin/themes/default/template/batch_manager_global.tpl index 1b922cd7e..66feb44e1 100644 --- a/admin/themes/default/template/batch_manager_global.tpl +++ b/admin/themes/default/template/batch_manager_global.tpl @@ -35,13 +35,8 @@ var selectedMessage_pattern = "{'%d of %d photos selected'|@translate}"; var selectedMessage_none = "{'No photo selected, %d photos in current set'|@translate}"; var selectedMessage_all = "{'All %d photos are selected'|@translate}"; var regenerateThumbnailsMessage = "{'Thumbnails generation in progress...'|@translate}"; +var regenerateWebsizeMessage = "{'Photos generation in progress...'|@translate}"; {literal} -var queuedManagerThumbnails = $.manageAjax.create('queued', { - queue: true, - cacheResponse: false, - maxRequests: 3 -}); - function str_repeat(i, m) { for (var o = []; m > 0; o[--m] = i); return o.join(''); @@ -327,55 +322,78 @@ $(document).ready(function() { }); jQuery('#applyAction').click(function() { - if (jQuery('[name="selectAction"]').val() == 'regenerateThumbnails') { - if (elements.length != 0) - return true; - - if (jQuery('input[name="setSelected"]').attr('checked')) - elements = all_elements; - else - jQuery('input[name="selection[]"]').each(function() { - if (jQuery(this).attr('checked')) { - elements.push(jQuery(this).val()); - } - }); - + if (elements.length != 0) + { + return true; + } + else if (jQuery('[name="selectAction"]').val() == 'regenerateThumbnails') + { + type = 'thumbnail'; + maxRequests = 3; maxwidth = jQuery('input[name="thumb_maxwidth"]').val(); maxheight = jQuery('input[name="thumb_maxheight"]').val(); - progressBar_max = elements.length; - todo = 0; - - jQuery('#thumb_config').hide(); - jQuery('#applyActionBlock').hide(); - jQuery('select[name="selectAction"]').hide(); - jQuery('#regenerationMsg').show(); - jQuery('#regenerationText').html(regenerateThumbnailsMessage); - jQuery('#progressBar').progressBar(0, { - max: progressBar_max, - textFormat: 'fraction', - boxImage: 'themes/default/images/progressbar.gif', - barImage: 'themes/default/images/progressbg_orange.gif' + regenerationText = regenerateThumbnailsMessage; + } + else if(jQuery('[name="selectAction"]').val() == 'regenerateWebsize') + { + type = 'websize'; + maxRequests = 1; + maxwidth = jQuery('input[name="websize_maxwidth"]').val(); + maxheight = jQuery('input[name="websize_maxheight"]').val(); + regenerationText = regenerateWebsizeMessage; + } + else return true; + + jQuery('.bulkAction').hide(); + jQuery('#regenerationText').html(regenerationText); + + var queuedManager = jQuery.manageAjax.create('queued', { + queue: true, + cacheResponse: false, + maxRequests: maxRequests + }); + + if (jQuery('input[name="setSelected"]').attr('checked')) + elements = all_elements; + else + jQuery('input[name="selection[]"]').each(function() { + if (jQuery(this).attr('checked')) { + elements.push(jQuery(this).val()); + } }); - for (i=0;i{'add to caddie'|@translate} {/if} + {if !empty($element_set_global_plugins_actions)} {foreach from=$element_set_global_plugins_actions item=action} @@ -640,7 +659,7 @@ jQuery(window).load(function() {
- +
@@ -656,8 +675,31 @@ jQuery(window).load(function() {
{'Maximum Width'|@translate} {'pixels'|@translate}
+ +
+

+ ! + {'Only photos with HD can be regenerated!'|@translate} +

+ + + + + + + + + + + + + + +
{'Maximum Width'|@translate} {'pixels'|@translate}
{'Maximum Height'|@translate} {'pixels'|@translate}
{'Image Quality'|@translate} %
+
+ -