From 0a44acdd8a4bc050b943e0d915f46b2db7e86250 Mon Sep 17 00:00:00 2001 From: plegall Date: Wed, 19 Jan 2011 14:51:03 +0000 Subject: feature 1062 added: ability to delete a single photo from its administration screen git-svn-id: http://piwigo.org/svn/trunk@8764 68402e56-0260-453c-a942-63ccdbb3a9ee --- admin/picture_modify.php | 63 ++++++++++++++++++++++-- admin/themes/default/template/picture_modify.tpl | 2 + 2 files changed, 60 insertions(+), 5 deletions(-) (limited to 'admin') diff --git a/admin/picture_modify.php b/admin/picture_modify.php index f2438454f..5c1d1186b 100644 --- a/admin/picture_modify.php +++ b/admin/picture_modify.php @@ -36,6 +36,58 @@ check_status(ACCESS_ADMINISTRATOR); check_input_parameter('image_id', $_GET, false, PATTERN_ID); check_input_parameter('cat_id', $_GET, false, PATTERN_ID); +// +-----------------------------------------------------------------------+ +// | delete photo | +// +-----------------------------------------------------------------------+ + +if (isset($_GET['delete'])) +{ + check_pwg_token(); + + delete_elements(array($_GET['image_id']), true); + + // where to redirect the user now? + // + // 1. if a category is available in the URL, use it + // 2. else use the first reachable linked category + // 3. redirect to gallery root + + if (isset($_GET['cat_id'])) + { + redirect( + make_index_url( + array( + 'category' => get_cat_info($_GET['cat_id']) + ) + ) + ); + } + + $query = ' +SELECT category_id + FROM '.IMAGE_CATEGORY_TABLE.' + WHERE image_id = '.$_GET['image_id'].' +;'; + + $authorizeds = array_diff( + array_from_query($query, 'category_id'), + explode(',', calculate_permissions($user['id'], $user['status'])) + ); + + foreach ($authorizeds as $category_id) + { + redirect( + make_index_url( + array( + 'category' => get_cat_info($category_id) + ) + ) + ); + } + + redirect(make_index_url()); +} + // +-----------------------------------------------------------------------+ // | synchronize metadata | // +-----------------------------------------------------------------------+ @@ -209,14 +261,15 @@ $template->set_filenames( ) ); +$admin_url_start = get_root_url().'admin.php?page=picture_modify'; +$admin_url_start.= '&image_id='.$_GET['image_id']; +$admin_url_start.= isset($_GET['cat_id']) ? '&cat_id='.$_GET['cat_id'] : ''; + $template->assign( array( 'tags' => $tags, - 'U_SYNC' => - get_root_url().'admin.php?page=picture_modify'. - '&image_id='.$_GET['image_id']. - (isset($_GET['cat_id']) ? '&cat_id='.$_GET['cat_id'] : ''). - '&sync_metadata=1', + 'U_SYNC' => $admin_url_start.'&sync_metadata=1', + 'U_DELETE' => $admin_url_start.'&delete=1&pwg_token='.get_pwg_token(), 'PATH'=>$row['path'], diff --git a/admin/themes/default/template/picture_modify.tpl b/admin/themes/default/template/picture_modify.tpl index d047b3233..5b47a554f 100644 --- a/admin/themes/default/template/picture_modify.tpl +++ b/admin/themes/default/template/picture_modify.tpl @@ -32,6 +32,8 @@ pwg_initialization_datepicker("#date_creation_day", "#date_creation_month", "#da {/if} {if !url_is_remote($PATH)}
  • {'synchronize'|@translate}
  • + +
  • {'delete photo'|@translate}
  • {/if} -- cgit v1.2.3