X-Git-Url: https://jasonwoof.com/gitweb/?p=wfpl-cms.git;a=blobdiff_plain;f=admin_images.php;h=c2f4943fba53ec34f7a87362882d80ba4b0fff0e;hp=a8c8a9bbf29c5a2b8047926338e4d51728eebe10;hb=HEAD;hpb=059569fef59006c2ab9af689c582fc3e9b0d7e6e diff --git a/admin_images.php b/admin_images.php index a8c8a9b..c2f4943 100644 --- a/admin_images.php +++ b/admin_images.php @@ -1,242 +1,158 @@ true)); - return; - } - - # make sure there's something clickable - foreach($rows as &$row) { - if($row['name'] == '') { - $row['name'] = '--'; - } - } - tem_set('listings', array( - 'populated_listing' => true, - 'rows' => $rows)); - return true; + # default action: + return admin_images_main_listing(); } -function admin_images_main() { - if(!logged_in_as_admin()) { - $_REQUEST['url'] = this_url(); - return 'admin_login'; - } - - if(isset($_REQUEST['admin_images_id'])) { - return admin_images_display_main(); - } else { - return admin_images_edit_main(); - } +function admin_images_main_delete($id) { + $data = db_get_assoc('cms_images', 'image', 'where id=%i', $id); + if ($data) { + $src = enc_image_src($data['image']); + if ($src) { + $filenames = array($src); + foreach ($GLOBALS['wfpl_image_widths'] as $w) { + $filenames [] = substr($src, 0, -4) . 'w' . $w . substr($src, -4); + } + foreach ($filenames as $filename) { + if (file_exists($filename)) { + unlink($filename); + } + } + } + db_delete('cms_images', 'where id=%i', $id); + message('Image deleted.'); + } else { + message("Couldn't find image to delete. Maybe it's already been deleted?"); + } + return './admin_images'; } -function admin_images_display_main() { - $id = format_int($_REQUEST['admin_images_id']); - unset($_REQUEST['admin_images_id']); - if(!$id) { - message('Error: Broken link'); - return './admin_images'; - } - $data = db_get_assoc('cms_images', 'id,'.ADMIN_IMAGES_DB_FIELDS, 'where id=%i', $id); - if(!$data) { - message('Error: Image not found'); - return './admin_images'; - } - - # Find pages that have this image on it - if($data['image']) { - $references = db_get_assocs('cms_pages', 'title,filename', 'where content like "%%%s%%" order by concat(nav_title,title)', substr(enc_image_src($data['image']), 0, -4)); # FIXME test that this works for smaller images - if($references) { - $data['references'] = array( - 'data' => $references, - 'count' => count($references)); - } - } - - # display smaller versions with instructions and example code - $smaller == array(); - if($data['image'] && $data['sizes']) { - $big_src = enc_image_src($data['image']); - $row = explode("\n", $data['sizes']); - foreach($row as $max_hw) { - $max_hw = format_width_height($max_hw); - if($max_hw == '') { - continue; - } - list($max_width, $max_height) = explode('x', $max_hw); - $src = str_replace('.', "-$max_hw.", $big_src); - $dimensions = image_dimensions($src); - if($dimensions) { - list($width, $height) = explode('x', $dimensions); - } else { - $width = $max_width; - $height = $max_height; - } - - $smaller[] = array( - 'src' => $src, - 'max_width' => $max_width, - 'max_height' => $max_height, - 'width' => $width, - 'height' => $height); - } - } - if($smaller) { - $data['smaller'] = $smaller; - } else { - tem_set('no_sizes'); - } - - tem_set('display', $data); +function admin_images_main_listing() { + $sort_by = 'name'; + $sorts = array( + 'age' => 'created_at desc', + 'name' => "coalesce(nullif(name, ''), caption), created_at", + 'caption' => "coalesce(nullif(caption, ''), name), created_at" + ); + if (isset($_REQUEST['sort'])) { + foreach ($sorts as $s => $sql) { + if ($_REQUEST['sort'] == $s) { + $sort_by = $s; + break; + } + } + } + tem_set("sort_by_$sort_by"); + $listing_rows = db_get_assocs('cms_images', 'id,image,name,caption', 'order by ' . $sorts[$sort_by]); + tem_set('listings', $listing_rows); } -function admin_images_edit_main() { - $edit_id = format_int($_REQUEST['admin_images_edit_id']); - unset($_REQUEST['admin_images_edit_id']); - if($edit_id) { - # add hidden field for database id of row we're editing - tem_set('admin_images_edit_id', $edit_id); - tem_set('editing', 'show'); - tem_set('edit_msg', 'show'); - } - - $delete_id = format_int($_REQUEST['admin_images_delete_id']); - unset($_REQUEST['admin_images_delete_id']); - if($delete_id) { - db_delete('cms_images', 'where id=%i', $delete_id); - message('Image deleted.'); - - return './admin_images'; - } - - if(!$edit_id) { - if(!isset($_REQUEST['admin_images_new']) && !isset($_REQUEST['name'])) { - admin_images_display_listing(); - return; - } - - tem_set('new_msg', 'show'); - } - - if(isset($_POST['name'])) { - $data = admin_images_get_fields(); - - # save anything - # Note: If you change this to re-display the form in some cases, be sure to handle image uploads well (don't make them upload it again. - - # resize image as needed - if($data['image'] && $data['sizes']) { - $big_src = enc_image_src($data['image']); - $row = explode("\n", $data['sizes']); - foreach($row as $max_hw) { - $max_hw = format_width_height($max_hw); - if($max_hw == '') { - continue; - } - list($max_width, $max_height) = explode('x', $max_hw); - $src = str_replace('.', "-$max_hw.", $big_src); - if(($_FILES['image'] && $_FILES['image']['error'] == 0) || !file_exists($src)) { - imagemagick_convert($big_src, $src, "-geometry $max_hw", 'Resizing image'); - } - } - } - - # save to database - if($edit_id) { - db_update_assoc('cms_images', $data, 'where id=%i', $edit_id); - message('Image updated.'); - $saved_id = $edit_id; - } else { - db_insert_assoc('cms_images', $data); - message('Image saved.'); - $saved_id = db_auto_id(); - } - - # return user to display page where they can see instructions, etc - return "./admin_images?admin_images_id=$saved_id"; - - } elseif($edit_id) { - # we've recieved an edit id, but no data. So we grab the values to be edited from the database - $data = db_get_assoc('cms_images', ADMIN_IMAGES_DB_FIELDS, 'where id=%i', $edit_id); - } else { - # form not submitted, set default values: - $data = array('sizes' => '275x500'); - } - - tem_set('upload_max_filesize', upload_max_filesize()); - - tem_set('form', $data); +function admin_images_main_form($id = false) { + if($id) { + tem_set('id', $id); + } + + if(isset($_POST['name'])) { + $data = admin_images_get_fields(); + + # save anything + # Note: If you change this to re-display the form in some cases, be sure to handle image uploads well (don't make them upload it again.) + + # save to database + if($id) { + db_update_assoc('cms_images', $data, 'where id=%i', $id); + message('Image updated.'); + $saved_id = $id; + return "./admin_images"; + } else { + $data['created_at'] = time(); + db_insert_assoc('cms_images', $data); + message('Image saved. Next time you open a page editor, this image will be availble in the "Insert Image" dialog.'); + $saved_id = db_auto_id(); + return "./admin_images?sort=age"; + } + + } elseif($id) { + # we've recieved an edit id, but no data. So we grab the values to be edited from the database + $data = db_get_assoc('cms_images', ADMIN_IMAGES_DB_FIELDS, 'where id=%i', $id); + } else { + # form not submitted, set default values: + $data = array(); + } + + tem_set('upload_max_filesize', upload_max_filesize()); + + tem_set('form', $data); } - -?>