source: trunk/admin/themes/default/template/batch_manager_global.tpl @ 29249

Last change on this file since 29249 was 29249, checked in by mistic100, 10 years ago

create a mini jquery plugin for sliders on batch manager + async load

File size: 28.6 KB
Line 
1{include file='include/datepicker.inc.tpl' load_mode='async'}
2{include file='include/colorbox.inc.tpl' load_mode='async'}
3{include file='include/add_album.inc.tpl' load_mode='async'}
4
5{combine_script id='common' load='footer' path='admin/themes/default/js/common.js'}
6
7{combine_script id='jquery.ui.slider' require='jquery.ui' load='async' path='themes/default/js/ui/minified/jquery.ui.slider.min.js'}
8{combine_css path="themes/default/js/ui/theme/jquery.ui.slider.css"}
9{combine_script id='doubleSlider' load='async' require='jquery.ui.slider' path='admin/themes/default/js/doubleSlider.js'}
10
11{combine_script id='LocalStorageCache' load='footer' path='admin/themes/default/js/LocalStorageCache.js'}
12
13{assign var="selectizeTheme" value=($themeconf.name=='roma')|ternary:'dark':'default'}
14{combine_script id='jquery.selectize' load='footer' path='themes/default/js/plugins/selectize.min.js'}
15{combine_css id='jquery.selectize' path="themes/default/js/plugins/selectize.`$selectizeTheme`.css"}
16
17{combine_script id='jquery.progressBar' load='async' path='themes/default/js/plugins/jquery.progressbar.min.js'}
18{combine_script id='jquery.ajaxmanager' load='async' path='themes/default/js/plugins/jquery.ajaxmanager.js'}
19
20{combine_script id='batchManagerGlobal' load='async' require='jquery,datepicker,jquery.colorbox,addAlbum,doubleSlider' path='admin/themes/default/js/batchManagerGlobal.js'}
21
22{footer_script}
23var lang = {
24        Cancel: '{'Cancel'|translate|escape:'javascript'}',
25        AreYouSure: "{'Are you sure?'|translate|escape:'javascript'}"
26};
27
28jQuery(document).ready(function() {
29
30  {* <!-- TAGS --> *}
31  var tagsCache = new TagsCache({
32    serverKey: '{$CACHE_KEYS.tags}',
33    serverId: '{$CACHE_KEYS._hash}',
34    rootUrl: '{$ROOT_URL}'
35  });
36
37  tagsCache.selectize(jQuery('[data-selectize=tags]'), { lang: {
38    'Add': '{'Create'|translate}'
39  }});
40
41  {* <!-- CATEGORIES --> *}
42  window.categoriesCache = new CategoriesCache({
43    serverKey: '{$CACHE_KEYS.categories}',
44    serverId: '{$CACHE_KEYS._hash}',
45    rootUrl: '{$ROOT_URL}'
46  });
47
48  categoriesCache.selectize(jQuery('[data-selectize=categories]'), {
49    filter: function(categories, options) {
50      if (this.name == 'dissociate') {
51        var filtered = jQuery.grep(categories, function(cat) {
52          return !cat.dir;
53        });
54
55        if (filtered.length > 0) {
56          jQuery('.albumDissociate').show();
57          options.default = filtered[0].id;
58        }
59
60        return filtered;
61      }
62      else {
63        return categories;
64      }
65    }
66  });
67
68});
69
70var nb_thumbs_page = {$nb_thumbs_page};
71var nb_thumbs_set = {$nb_thumbs_set};
72var applyOnDetails_pattern = "{'on the %d selected photos'|@translate}";
73var all_elements = [{if !empty($all_elements)}{','|@implode:$all_elements}{/if}];
74
75var selectedMessage_pattern = "{'%d of %d photos selected'|@translate}";
76var selectedMessage_none = "{'No photo selected, %d photos in current set'|@translate}";
77var selectedMessage_all = "{'All %d photos are selected'|@translate}";
78
79$(document).ready(function() {
80  function checkPermitAction() {
81    var nbSelected = 0;
82    if ($("input[name=setSelected]").is(':checked')) {
83      nbSelected = nb_thumbs_set;
84    }
85    else {
86      nbSelected = $(".thumbnails input[type=checkbox]").filter(':checked').length;
87    }
88
89    if (nbSelected == 0) {
90      $("#permitAction").hide();
91      $("#forbidAction").show();
92    }
93    else {
94      $("#permitAction").show();
95      $("#forbidAction").hide();
96    }
97
98    $("#applyOnDetails").text(
99      sprintf(
100        applyOnDetails_pattern,
101        nbSelected
102      )
103    );
104
105    // display the number of currently selected photos in the "Selection" fieldset
106    if (nbSelected == 0) {
107      $("#selectedMessage").text(
108        sprintf(
109          selectedMessage_none,
110          nb_thumbs_set
111        )
112      );
113    }
114    else if (nbSelected == nb_thumbs_set) {
115      $("#selectedMessage").text(
116        sprintf(
117          selectedMessage_all,
118          nb_thumbs_set
119        )
120      );
121    }
122    else {
123      $("#selectedMessage").text(
124        sprintf(
125          selectedMessage_pattern,
126          nbSelected,
127          nb_thumbs_set
128        )
129      );
130    }
131  }
132
133  $("[id^=action_]").hide();
134
135  $("select[name=selectAction]").change(function () {
136    $("[id^=action_]").hide();
137    $("#action_"+$(this).prop("value")).show();
138
139    if ($(this).val() != -1) {
140      $("#applyActionBlock").show();
141    }
142    else {
143      $("#applyActionBlock").hide();
144    }
145  });
146
147  $(".wrap1 label").click(function (event) {
148    $("input[name=setSelected]").prop('checked', false);
149
150    var wrap2 = $(this).children(".wrap2");
151    var checkbox = $(this).children("input[type=checkbox]");
152
153    checkbox.triggerHandler("shclick",event);
154
155    if ($(checkbox).is(':checked')) {
156      $(wrap2).addClass("thumbSelected");
157    }
158    else {
159      $(wrap2).removeClass('thumbSelected');
160    }
161
162    checkPermitAction();
163  });
164
165  $("#selectAll").click(function () {
166    $("input[name=setSelected]").prop('checked', false);
167    selectPageThumbnails();
168    checkPermitAction();
169    return false;
170  });
171
172  function selectPageThumbnails() {
173    $(".thumbnails label").each(function() {
174      var wrap2 = $(this).children(".wrap2");
175      var checkbox = $(this).children("input[type=checkbox]");
176
177      $(checkbox).prop('checked', true);
178      $(wrap2).addClass("thumbSelected");
179    });
180  }
181
182  $("#selectNone").click(function () {
183    $("input[name=setSelected]").prop('checked', false);
184
185    $(".thumbnails label").each(function() {
186      var wrap2 = $(this).children(".wrap2");
187      var checkbox = $(this).children("input[type=checkbox]");
188
189      $(checkbox).prop('checked', false);
190      $(wrap2).removeClass("thumbSelected");
191    });
192    checkPermitAction();
193    return false;
194  });
195
196  $("#selectInvert").click(function () {
197    $("input[name=setSelected]").prop('checked', false);
198
199    $(".thumbnails label").each(function() {
200      var wrap2 = $(this).children(".wrap2");
201      var checkbox = $(this).children("input[type=checkbox]");
202
203      $(checkbox).prop('checked', !$(checkbox).is(':checked'));
204
205      if ($(checkbox).is(':checked')) {
206        $(wrap2).addClass("thumbSelected");
207      }
208      else {
209        $(wrap2).removeClass('thumbSelected');
210      }
211    });
212    checkPermitAction();
213    return false;
214  });
215
216  $("#selectSet").click(function () {
217    selectPageThumbnails();
218    $("input[name=setSelected]").prop('checked', true);
219    checkPermitAction();
220    return false;
221  });
222
223
224  jQuery('#applyAction').click(function() {
225                var action = jQuery('[name="selectAction"]').val();
226                if (action == 'delete_derivatives') {
227                        var d_count = $('#action_delete_derivatives input[type=checkbox]').filter(':checked').length
228                                , e_count = $('input[name="setSelected"]').is(':checked') ? nb_thumbs_set : $('.thumbnails input[type=checkbox]').filter(':checked').length;
229                        if (d_count*e_count > 500)
230                                return confirm(lang.AreYouSure);
231                }
232
233                if (action != 'generate_derivatives'
234                        || derivatives.finished() )
235                {
236                        return true;
237                }
238
239                jQuery('.bulkAction').hide();
240
241                var queuedManager = jQuery.manageAjax.create('queued', {
242                        queue: true,
243                        cacheResponse: false,
244                        maxRequests: 1
245                });
246
247                derivatives.elements = [];
248                if (jQuery('input[name="setSelected"]').is(':checked'))
249                        derivatives.elements = all_elements;
250                else
251                        jQuery('.thumbnails input[type=checkbox]').each(function() {
252                                if (jQuery(this).is(':checked')) {
253                                        derivatives.elements.push(jQuery(this).val());
254                                }
255                        });
256
257                jQuery('#applyActionBlock').hide();
258                jQuery('select[name="selectAction"]').hide();
259                jQuery('#regenerationMsg').show();
260
261                progress();
262                getDerivativeUrls();
263                return false;
264  });
265
266  checkPermitAction();
267
268  jQuery("select[name=filter_prefilter]").change(function() {
269    jQuery("#empty_caddie").toggle(jQuery(this).val() == "caddie");
270    jQuery("#duplicates_options").toggle(jQuery(this).val() == "duplicates");
271  });
272});
273
274{*<!-- sliders config -->*}
275var sliders = {
276  widths: {
277    values: [{$dimensions.widths}],
278    selected: {
279      min: {$dimensions.selected.min_width},
280      max: {$dimensions.selected.max_width},
281    },
282    text: '{'between %d and %d pixels'|translate|escape:'javascript'}'
283  },
284
285  heights: {
286    values: [{$dimensions.heights}],
287    selected: {
288      min: {$dimensions.selected.min_height},
289      max: {$dimensions.selected.max_height},
290    },
291    text: '{'between %d and %d pixels'|translate|escape:'javascript'}'
292  },
293
294  ratios: {
295    values: [{$dimensions.ratios}],
296    selected: {
297      min: {$dimensions.selected.min_ratio},
298      max: {$dimensions.selected.max_ratio},
299    },
300    text: '{'between %.2f and %.2f'|translate|escape:'javascript'}'
301  },
302
303  filesizes: {
304    values: [{$filesize.list}],
305    selected: {
306      min: {$filesize.selected.min},
307      max: {$filesize.selected.max},
308    },
309    text: '{'between %s and %s MB'|translate|escape:'javascript'}'
310  }
311};
312
313{/footer_script}
314
315<div id="batchManagerGlobal">
316
317<h2>{'Batch Manager'|@translate}</h2>
318
319  <form action="{$F_ACTION}" method="post">
320  <input type="hidden" name="start" value="{$START}">
321
322  <fieldset>
323    <legend>{'Filter'|@translate}</legend>
324
325    <ul id="filterList">
326      <li id="filter_prefilter" {if !isset($filter.prefilter)}style="display:none"{/if}>
327        <a href="#" class="removeFilter" title="{'remove this filter'|@translate}"><span>[x]</span></a>
328        <input type="checkbox" name="filter_prefilter_use" class="useFilterCheckbox" {if isset($filter.prefilter)}checked="checked"{/if}>
329        {'Predefined filter'|@translate}
330        <select name="filter_prefilter">
331          {foreach from=$prefilters item=prefilter}
332          <option value="{$prefilter.ID}" {if isset($filter.prefilter) && $filter.prefilter eq $prefilter.ID}selected="selected"{/if}>{$prefilter.NAME}</option>
333          {/foreach}
334        </select>
335        <a id="empty_caddie" href="admin.php?page=batch_manager&amp;action=empty_caddie" style="{if !isset($filter.prefilter) or $filter.prefilter ne 'caddie'}display:none{/if}">{'Empty caddie'|translate}</a>
336
337        <span id="duplicates_options" style="{if !isset($filter.prefilter) or $filter.prefilter ne 'duplicates'}display:none{/if}">
338          {'based on'|translate}
339          <input type="checkbox" checked="checked" disabled="disabled"> {'file name'|translate}
340          <label><input type="checkbox" name="filter_duplicates_date" {if isset($filter.duplicates_date) or (isset($filter.prefilter) and $filter.prefilter ne 'duplicates')}checked="checked"{/if}> {'date & time'|translate}</label>
341          <label><input type="checkbox" name="filter_duplicates_dimensions" {if isset($filter.duplicates_dimensions)}checked="checked"{/if}> {'width & height'|translate}</label>
342        </span>
343      </li>
344
345      <li id="filter_category" {if !isset($filter.category)}style="display:none"{/if}>
346        <a href="#" class="removeFilter" title="remove this filter"><span>[x]</span></a>
347        <input type="checkbox" name="filter_category_use" class="useFilterCheckbox" {if isset($filter.category)}checked="checked"{/if}>
348        {'Album'|@translate}
349        <select data-selectize="categories" data-value="{$filter_category_selected|@json_encode|escape:html}"
350          data-default="first" name="filter_category" style="width:400px"></select>
351        <label><input type="checkbox" name="filter_category_recursive" {if isset($filter.category_recursive)}checked="checked"{/if}> {'include child albums'|@translate}</label>
352      </li>
353
354      <li id="filter_tags" {if !isset($filter.tags)}style="display:none"{/if}>
355        <a href="#" class="removeFilter" title="remove this filter"><span>[x]</span></a>
356        <input type="checkbox" name="filter_tags_use" class="useFilterCheckbox" {if isset($filter.tags)}checked="checked"{/if}>
357        {'Tags'|@translate}
358        <select data-selectize="tags" data-value="{$filter_tags|@json_encode|escape:html}"
359          placeholder="{'Type in a search term'|translate}"
360          name="filter_tags[]" multiple style="width:400px;"></select>
361        <label><span><input type="radio" name="tag_mode" value="AND" {if !isset($filter.tag_mode) or $filter.tag_mode eq 'AND'}checked="checked"{/if}> {'All tags'|@translate}</span></label>
362        <label><span><input type="radio" name="tag_mode" value="OR" {if isset($filter.tag_mode) and $filter.tag_mode eq 'OR'}checked="checked"{/if}> {'Any tag'|@translate}</span></label>
363      </li>
364
365      <li id="filter_level" {if !isset($filter.level)}style="display:none"{/if}>
366        <a href="#" class="removeFilter" title="remove this filter"><span>[x]</span></a>
367        <input type="checkbox" name="filter_level_use" class="useFilterCheckbox" {if isset($filter.level)}checked="checked"{/if}>
368        {'Privacy level'|@translate}
369        <select name="filter_level" size="1">
370          {html_options options=$filter_level_options selected=$filter_level_options_selected}
371        </select>
372        <label><input type="checkbox" name="filter_level_include_lower" {if isset($filter.level_include_lower)}checked="checked"{/if}> {'include photos with lower privacy level'|@translate}</label>
373      </li>
374
375      <li id="filter_dimension" {if !isset($filter.dimension)}style="display:none"{/if}>
376        <a href="#" class="removeFilter" title="remove this filter"><span>[x]</span></a>
377        <input type="checkbox" name="filter_dimension_use" class="useFilterCheckbox" {if isset($filter.dimension)}checked="checked"{/if}>
378        {'Dimensions'|translate}
379
380        <blockquote>
381          <div data-slider="widths">
382            {'Width'|translate} <span class="slider-info">{'between %d and %d pixels'|translate:$dimensions.selected.min_width:$dimensions.selected.max_width}</span>
383            | <a class="slider-choice" data-min="{$dimensions.bounds.min_width}" data-max="{$dimensions.bounds.max_width}">{'Reset'|translate}</a>
384            <div class="slider-slider"></div>
385
386            <input type="hidden" data-input="min" name="filter_dimension_min_width" value="{$dimensions.selected.min_width}">
387            <input type="hidden" data-input="max" name="filter_dimension_max_width" value="{$dimensions.selected.max_width}">
388          </div>
389
390          <div data-slider="heights">
391            {'Height'|translate} <span class="slider-info">{'between %d and %d pixels'|translate:$dimensions.selected.min_height:$dimensions.selected.max_height}</span>
392            | <a class="slider-choice" data-min="{$dimensions.bounds.min_height}" data-max="{$dimensions.bounds.max_height}">{'Reset'|translate}</a>
393            <div class="slider-slider"></div>
394           
395            <input type="hidden" data-input="min" name="filter_dimension_min_height" value="{$dimensions.selected.min_height}">
396            <input type="hidden" data-input="max" name="filter_dimension_max_height" value="{$dimensions.selected.max_height}">
397          </div>
398
399          <div data-slider="ratios">
400            {'Ratio'|translate} ({'Width'|@translate}/{'Height'|@translate}) <span class="slider-info">{'between %.2f and %.2f'|translate:$dimensions.selected.min_ratio:$dimensions.selected.max_ratio}</span>
401            {if isset($dimensions.ratio_portrait)}| <a class="slider-choice" data-min="{$dimensions.ratio_portrait.min}" data-max="{$dimensions.ratio_portrait.max}">{'Portrait'|translate}</a>{/if}
402            {if isset($dimensions.ratio_square)}| <a class="slider-choice" data-min="{$dimensions.ratio_square.min}" data-max="{$dimensions.ratio_square.max}">{'square'|translate}</a>{/if}
403            {if isset($dimensions.ratio_landscape)}| <a class="slider-choice" data-min="{$dimensions.ratio_landscape.min}" data-max="{$dimensions.ratio_landscape.max}">{'Landscape'|translate}</a>{/if}
404            {if isset($dimensions.ratio_panorama)}| <a class="slider-choice" data-min="{$dimensions.ratio_panorama.min}" data-max="{$dimensions.ratio_panorama.max}">{'Panorama'|translate}</a>{/if}
405            | <a class="slider-choice" data-min="{$dimensions.bounds.min_ratio}" data-max="{$dimensions.bounds.max_ratio}">{'Reset'|translate}</a>
406            <div class="slider-slider"></div>
407
408            <input type="hidden" data-input="min" name="filter_dimension_min_ratio" value="{$dimensions.selected.min_ratio}">
409            <input type="hidden" data-input="max" name="filter_dimension_max_ratio" value="{$dimensions.selected.max_ratio}">
410          </div>
411        </blockquote>
412      </li>
413
414                        <li id="filter_search"{if !isset($filter.search)} style="display:none"{/if}>
415                                <a href="#" class="removeFilter" title="remove this filter"><span>[x]</span></a>
416                                <input type="checkbox" name="filter_search_use" class="useFilterCheckbox"{if isset($filter.search)} checked="checked"{/if}>
417                                {'Search'|@translate}
418                                <input name="q" size=40 value="{$filter.search.q|stripslashes|htmlspecialchars}">
419                                {combine_script id='core.scripts' load='async' path='themes/default/js/scripts.js'}
420                                <a href="admin/popuphelp.php?page=quick_search" onclick="popuphelp(this.href);return false;" title="{'Help'|@translate}"><span class="icon-help-circled"></span></a>
421                        </li>
422
423      <li id="filter_filesize" {if !isset($filter.filesize)}style="display:none"{/if}>
424        <a href="#" class="removeFilter" title="remove this filter"><span>[x]</span></a>
425        <input type="checkbox" name="filter_filesize_use" class="useFilterCheckbox" {if isset($filter.filesize)}checked="checked"{/if}>
426        {'Filesize'|translate}
427
428        <blockquote>
429          <div data-slider="filesizes">
430            <span class="slider-info">{'between %s and %s MB'|translate:$filesize.selected.min:$filesize.selected.max}</span>
431            | <a class="slider-choice" data-min="{$filesize.bounds.min}" data-max="{$filesize.bounds.max}">{'Reset'|translate}</a>
432            <div class="slider-slider"></div>
433
434            <input type="hidden" data-input="min" name="filter_filesize_min" value="{$filesize.selected.min}">
435            <input type="hidden" data-input="max" name="filter_filesize_max" value="{$filesize.selected.max}">
436          </div>
437        </blockquote>
438      </li>
439    </ul>
440
441    <p class="actionButtons">
442      <select id="addFilter">
443        <option value="-1">{'Add a filter'|@translate}</option>
444        <option disabled="disabled">------------------</option>
445        <option value="filter_prefilter" {if isset($filter.prefilter)}disabled="disabled"{/if}>{'Predefined filter'|@translate}</option>
446        <option value="filter_category" {if isset($filter.category)}disabled="disabled"{/if}>{'Album'|@translate}</option>
447        <option value="filter_tags" {if isset($filter.tags)}disabled="disabled"{/if}>{'Tags'|@translate}</option>
448        <option value="filter_level" {if isset($filter.level)}disabled="disabled"{/if}>{'Privacy level'|@translate}</option>
449        <option value="filter_dimension" {if isset($filter.dimension)}disabled="disabled"{/if}>{'Dimensions'|@translate}</option>
450        <option value="filter_filesize" {if isset($filter.filesize)}disabled="disabled"{/if}>{'Filesize'|@translate}</option>
451                                <option value="filter_search"{if isset($filter.search)} disabled="disabled"{/if}>{'Search'|@translate}</option>
452      </select>
453      <a id="removeFilters">{'Remove all filters'|@translate}</a>
454    </p>
455
456    <p class="actionButtons" id="applyFilterBlock">
457      <input id="applyFilter" class="submit" type="submit" value="{'Refresh photo set'|@translate}" name="submitFilter">
458    </p>
459
460  </fieldset>
461
462  <fieldset>
463
464    <legend>{'Selection'|@translate}</legend>
465
466  {if !empty($thumbnails)}
467  <p id="checkActions">
468    {'Select:'|@translate}
469{if $nb_thumbs_set > $nb_thumbs_page}
470    <a href="#" id="selectAll">{'The whole page'|@translate}</a>,
471    <a href="#" id="selectSet">{'The whole set'|@translate}</a>,
472{else}
473    <a href="#" id="selectAll">{'All'|@translate}</a>,
474{/if}
475    <a href="#" id="selectNone">{'None'|@translate}</a>,
476    <a href="#" id="selectInvert">{'Invert'|@translate}</a>
477
478    <span id="selectedMessage"></span>
479
480    <input type="checkbox" name="setSelected" style="display:none" {if count($selection) == $nb_thumbs_set}checked="checked"{/if}>
481  </p>
482
483        <ul class="thumbnails">
484                {html_style}
485UL.thumbnails SPAN.wrap2{ldelim}
486  width: {$thumb_params->max_width()+2}px;
487}
488UL.thumbnails SPAN.wrap2 {ldelim}
489  height: {$thumb_params->max_height()+25}px;
490}
491                {/html_style}
492                {foreach from=$thumbnails item=thumbnail}
493                {assign var='isSelected' value=$thumbnail.id|@in_array:$selection}
494                <li>
495                        <span class="wrap1">
496                                <label>
497                                        <input type="checkbox" name="selection[]" value="{$thumbnail.id}" {if $isSelected}checked="checked"{/if}>
498                                        <span class="wrap2{if $isSelected} thumbSelected{/if}">
499                                        <div class="actions"><a href="{$thumbnail.FILE_SRC}" class="preview-box">{'Zoom'|@translate}</a> &middot; <a href="{$thumbnail.U_EDIT}" target="_blank">{'Edit'|@translate}</a></div>
500                                                {if $thumbnail.level > 0}
501                                                <em class="levelIndicatorB">{'Level %d'|@sprintf:$thumbnail.level|@translate}</em>
502                                                <em class="levelIndicatorF" title="{'Who can see these photos?'|@translate} : ">{'Level %d'|@sprintf:$thumbnail.level|@translate}</em>
503                                                {/if}
504                                                <img src="{$thumbnail.thumb->get_url()}" alt="{$thumbnail.file}" title="{$thumbnail.TITLE|@escape:'html'}" {$thumbnail.thumb->get_size_htm()}>
505                                        </span>
506                                </label>
507                        </span>
508                </li>
509                {/foreach}
510        </ul>
511
512  {if !empty($navbar) }
513  <div style="clear:both;">
514
515    <div style="float:left">
516    {include file='navigation_bar.tpl'|@get_extent:'navbar'}
517    </div>
518
519    <div style="float:right;margin-top:10px;">{'display'|@translate}
520      <a href="{$U_DISPLAY}&amp;display=20">20</a>
521      &middot; <a href="{$U_DISPLAY}&amp;display=50">50</a>
522      &middot; <a href="{$U_DISPLAY}&amp;display=100">100</a>
523      &middot; <a href="{$U_DISPLAY}&amp;display=all">{'all'|@translate}</a>
524      {'photos per page'|@translate}
525    </div>
526  </div>
527  {/if}
528
529  {else}
530  <div>{'No photo in the current set.'|@translate}</div>
531  {/if}
532  </fieldset>
533
534  <fieldset id="action">
535
536    <legend>{'Action'|@translate}</legend>
537      <div id="forbidAction"{if count($selection) != 0} style="display:none"{/if}>{'No photo selected, no action possible.'|@translate}</div>
538      <div id="permitAction"{if count($selection) == 0} style="display:none"{/if}>
539
540    <select name="selectAction">
541      <option value="-1">{'Choose an action'|@translate}</option>
542      <option disabled="disabled">------------------</option>
543      <option value="delete" class="icon-trash">{'Delete selected photos'|@translate}</option>
544      <option value="associate">{'Associate to album'|@translate}</option>
545      <option value="move">{'Move to album'|@translate}</option>
546      <option value="dissociate" class="albumDissociate" style="display:none">{'Dissociate from album'|@translate}</option>
547      <option value="add_tags">{'Add tags'|@translate}</option>
548  {if !empty($associated_tags)}
549      <option value="del_tags">{'remove tags'|@translate}</option>
550  {/if}
551      <option value="author">{'Set author'|@translate}</option>
552      <option value="title">{'Set title'|@translate}</option>
553      <option value="date_creation">{'Set creation date'|@translate}</option>
554      <option value="level" class="icon-lock">{'Who can see these photos?'|@translate}</option>
555      <option value="metadata">{'Synchronize metadata'|@translate}</option>
556  {if ($IN_CADDIE)}
557      <option value="remove_from_caddie">{'Remove from caddie'|@translate}</option>
558  {else}
559      <option value="add_to_caddie">{'Add to caddie'|@translate}</option>
560  {/if}
561                <option value="delete_derivatives">{'Delete multiple size images'|@translate}</option>
562                <option value="generate_derivatives">{'Generate multiple size images'|@translate}</option>
563  {if !empty($element_set_global_plugins_actions)}
564    {foreach from=$element_set_global_plugins_actions item=action}
565      <option value="{$action.ID}">{$action.NAME}</option>
566    {/foreach}
567  {/if}
568    </select>
569
570    <!-- delete -->
571    <div id="action_delete" class="bulkAction">
572    <p><label><input type="checkbox" name="confirm_deletion" value="1"> {'Are you sure?'|@translate}</label></p>
573    </div>
574
575    <!-- associate -->
576    <div id="action_associate" class="bulkAction">
577      <select data-selectize="categories" data-default="first" name="associate" style="width:400px"></select>
578      <br>{'... or '|@translate}
579      <a href="#" data-add-album="associate" title="{'create a new album'|@translate}">{'create a new album'|@translate}</a>
580    </div>
581
582    <!-- move -->
583    <div id="action_move" class="bulkAction">
584      <select data-selectize="categories" data-default="first" name="move" style="width:400px"></select>
585      <br>{'... or '|@translate}
586      <a href="#" data-add-album="move" title="{'create a new album'|@translate}">{'create a new album'|@translate}</a>
587    </div>
588
589
590    <!-- dissociate -->
591    <div id="action_dissociate" class="bulkAction albumDissociate" style="display:none">
592      <select data-selectize="categories" placeholder="{'Type in a search term'|translate}"
593        name="dissociate" style="width:400px"></select>
594    </div>
595
596
597    <!-- add_tags -->
598    <div id="action_add_tags" class="bulkAction">
599      <select data-selectize="tags" data-create="true" placeholder="{'Type in a search term'|translate}"
600        name="add_tags[]" multiple style="width:400px;"></select>
601    </div>
602
603    <!-- del_tags -->
604    <div id="action_del_tags" class="bulkAction">
605{if !empty($associated_tags)}
606      <select data-selectize="tags" name="del_tags[]" multiple style="width:400px;"
607        placeholder="{'Type in a search term'|translate}">
608      {foreach from=$associated_tags item=tag}
609        <option value="{$tag.id}">{$tag.name}</option>
610      {/foreach}
611      </select>
612{/if}
613    </div>
614
615    <!-- author -->
616    <div id="action_author" class="bulkAction">
617    <label><input type="checkbox" name="remove_author"> {'remove author'|@translate}</label><br>
618    {assign var='authorDefaultValue' value='Type here the author name'|@translate}
619<input type="text" class="large" name="author" value="{$authorDefaultValue}" onfocus="this.value=(this.value=='{$authorDefaultValue|@escape:javascript}') ? '' : this.value;" onblur="this.value=(this.value=='') ? '{$authorDefaultValue|@escape:javascript}' : this.value;">
620    </div>
621
622    <!-- title -->
623    <div id="action_title" class="bulkAction">
624    <label><input type="checkbox" name="remove_title"> {'remove title'|@translate}</label><br>
625    {assign var='titleDefaultValue' value='Type here the title'|@translate}
626<input type="text" class="large" name="title" value="{$titleDefaultValue}" onfocus="this.value=(this.value=='{$titleDefaultValue|@escape:javascript}') ? '' : this.value;" onblur="this.value=(this.value=='') ? '{$titleDefaultValue|@escape:javascript}' : this.value;">
627    </div>
628
629    <!-- date_creation -->
630    <div id="action_date_creation" class="bulkAction">
631      <label><input type="checkbox" name="remove_date_creation"> {'remove creation date'|@translate}</label><br>
632      <div id="set_date_creation">
633        <input type="hidden" name="date_creation" value="{$DATE_CREATION}">
634        <label>
635          <i class="icon-calendar"></i>
636          <input type="text" data-datepicker="date_creation" readonly>
637        </label>
638      </div>
639    </div>
640
641    <!-- level -->
642    <div id="action_level" class="bulkAction">
643        <select name="level" size="1">
644          {html_options options=$level_options selected=$level_options_selected}
645        </select>
646    </div>
647
648    <!-- metadata -->
649    <div id="action_metadata" class="bulkAction">
650    </div>
651
652                <!-- generate derivatives -->
653                <div id="action_generate_derivatives" class="bulkAction">
654                        <a href="javascript:selectGenerateDerivAll()">{'All'|@translate}</a>,
655                        <a href="javascript:selectGenerateDerivNone()">{'None'|@translate}</a>
656                        <br>
657                        {foreach from=$generate_derivatives_types key=type item=disp}
658                                <label><input type="checkbox" name="generate_derivatives_type[]" value="{$type}"> {$disp}</label>
659                        {/foreach}
660                </div>
661
662                <!-- delete derivatives -->
663                <div id="action_delete_derivatives" class="bulkAction">
664                        <a href="javascript:selectDelDerivAll()">{'All'|@translate}</a>,
665                        <a href="javascript:selectDelDerivNone()">{'None'|@translate}</a>
666                        <br>
667                        {foreach from=$del_derivatives_types key=type item=disp}
668                                <label><input type="checkbox" name="del_derivatives_type[]" value="{$type}"> {$disp}</label>
669                        {/foreach}
670                </div>
671
672    <!-- progress bar -->
673    <div id="regenerationMsg" class="bulkAction" style="display:none">
674      <p id="regenerationText" style="margin-bottom:10px;">{'Generate multiple size images'|@translate}</p>
675      <span class="progressBar" id="progressBar"></span>
676      <input type="hidden" name="regenerateSuccess" value="0">
677      <input type="hidden" name="regenerateError" value="0">
678    </div>
679
680    <!-- plugins -->
681{if !empty($element_set_global_plugins_actions)}
682  {foreach from=$element_set_global_plugins_actions item=action}
683    <div id="action_{$action.ID}" class="bulkAction">
684    {if !empty($action.CONTENT)}{$action.CONTENT}{/if}
685    </div>
686  {/foreach}
687{/if}
688
689    <p id="applyActionBlock" style="display:none" class="actionButtons">
690      <input id="applyAction" class="submit" type="submit" value="{'Apply action'|@translate}" name="submit"> <span id="applyOnDetails"></span></p>
691
692    </div> <!-- #permitAction -->
693  </fieldset>
694
695  </form>
696
697</div> <!-- #batchManagerGlobal -->
Note: See TracBrowser for help on using the repository browser.