diff options
author | Cash Costello <cash.costello@gmail.com> | 2010-10-31 20:03:50 +0000 |
---|---|---|
committer | Cash Costello <cash.costello@gmail.com> | 2010-10-31 20:03:50 +0000 |
commit | 243e836190128b14e1c5aa53b6d01b6771b19d8c (patch) | |
tree | 7e426606f124790c6ec31dc5da0c7f09a41dcc67 | |
parent | 92ec25ec441330323e4fcbdfa33ebcf900420097 (diff) | |
download | elgg-243e836190128b14e1c5aa53b6d01b6771b19d8c.tar.gz elgg-243e836190128b14e1c5aa53b6d01b6771b19d8c.tar.bz2 |
First cut at a album sorting interface
-rw-r--r-- | actions/sortalbum.php | 18 | ||||
-rw-r--r-- | languages/en.php | 6 | ||||
-rw-r--r-- | pages/sortalbum.php | 38 | ||||
-rw-r--r-- | pages/viewalbum.php | 3 | ||||
-rw-r--r-- | start.php | 8 | ||||
-rw-r--r-- | views/default/tidypics/css.php | 20 | ||||
-rw-r--r-- | views/default/tidypics/sort.php | 54 |
7 files changed, 146 insertions, 1 deletions
diff --git a/actions/sortalbum.php b/actions/sortalbum.php new file mode 100644 index 000000000..1aa0e052f --- /dev/null +++ b/actions/sortalbum.php @@ -0,0 +1,18 @@ +<?php +/** + * Sorting album action - takes a comma separated list of image guids + */ + +$album_guid = get_input('album_guid'); +$album = get_entity($album_guid); +if (!$album) { + +} + +$guids = get_input('guids'); +$guids = explode(',', $guids); + +$album->setImageList($guids); + +system_message(sprintf(elgg_echo('tidypics:album:sorted'), $album->title)); +forward($album->getURL());
\ No newline at end of file diff --git a/languages/en.php b/languages/en.php index 2bb18d959..b2c88b27c 100644 --- a/languages/en.php +++ b/languages/en.php @@ -49,6 +49,7 @@ $english = array( 'tidypics:stats' => 'Stats', 'tidypics:nophotosingroup' => 'This groups does not have any photos yet', 'tidypics:upgrade' => 'Upgrade', + 'tidypics:sort' => 'Sorting the %s album', 'flickr:setup' => 'Flickr Setup', 'flickr:usernamesetup' => 'Please enter your Flickr username here:', @@ -97,6 +98,7 @@ $english = array( 'album:addpix' => "Add photos to album", 'album:edit' => "Edit album", 'album:delete' => "Delete album", + 'album:sort' => "Sort album", 'image:edit' => "Edit image", 'image:delete' => "Delete image", @@ -116,6 +118,9 @@ $english = array( 'tidypics:uploader:filedesc' => 'Image files (jpeg, png, gif)', 'tidypics:uploader:instructs' => 'There are three easy steps for adding photos to your album using this uploader: choosing, uploading, and describing them. If you do not have Flash, there is also a <a href="%s">basic uploader</a> available.', 'tidypics:uploader:basic' => 'You can upload up to 10 photos at a time (%s MB maximum per photo)', + + 'tidypics:sort:instruct' => 'Sort the album photos by dragging and dropping the images. Then click the save button.', + //views 'image:total' => "Images in album:", @@ -195,6 +200,7 @@ The photo can be viewed here: %s", 'album:delete:confirm' => "Are you sure you want to delete this album?", 'album:created' => "Your new album has been created.", 'tidypics:settings:save:ok' => 'Successfully saved the Tidypics plugin settings', + 'tidypics:album:sorted' => 'The album %s is sorted', 'tidypics:upgrade:success' => 'Upgrade of Tidypics a success', diff --git a/pages/sortalbum.php b/pages/sortalbum.php new file mode 100644 index 000000000..0bbd8159e --- /dev/null +++ b/pages/sortalbum.php @@ -0,0 +1,38 @@ +<?php +/** + * Tidypics Album Sort Page + * + * This displays a listing of all the photos so that they can be sorted + */ + +// if this page belongs to a closed group, prevent anyone outside group from seeing +if (is_callable('group_gatekeeper')) { + group_gatekeeper(); +} + +// get the album entity +$album_guid = (int) get_input('guid'); +$album = get_entity($album_guid); + +// panic if we can't get it +if (!$album) { + forward(); +} + +// container should always be set, but just in case +if ($album->container_guid) { + set_page_owner($album->container_guid); +} else { + set_page_owner($album->owner_guid); +} + +$owner = page_owner_entity(); + +$title = sprintf(elgg_echo('tidypics:sort'), $album->title); + +$content = elgg_view_title($title); +$content .= elgg_view('tidypics/sort', array('album' => $album)); + +$body = elgg_view_layout('two_column_left_sidebar', '', $content); + +page_draw($title, $body); diff --git a/pages/viewalbum.php b/pages/viewalbum.php index fe3c5bc62..870596769 100644 --- a/pages/viewalbum.php +++ b/pages/viewalbum.php @@ -54,6 +54,9 @@ if (can_write_to_container(0, $album->container_guid)) { add_submenu_item( elgg_echo('album:addpix'), $CONFIG->wwwroot . 'pg/photos/upload/' . $album_guid, 'photos'); + add_submenu_item( elgg_echo('album:sort'), + $CONFIG->wwwroot . 'pg/photos/sort/' . $album_guid, + 'photos'); add_submenu_item( elgg_echo('album:edit'), $CONFIG->wwwroot . 'pg/photos/edit/' . $album_guid, 'photos'); @@ -257,6 +257,13 @@ function tidypics_page_handler($page) { include($CONFIG->pluginspath . "tidypics/pages/viewalbum.php"); break; + case "sort": //sort a photo album + if (isset($page[1])) { + set_input('guid', $page[1]); + } + include($CONFIG->pluginspath . "tidypics/pages/sortalbum.php"); + break; + case "new": //create new album if (isset($page[1])) { set_input('username', $page[1]); @@ -532,6 +539,7 @@ register_action("tidypics/upload", false, $CONFIG->pluginspath . "tidypics/actio register_action("tidypics/ajax_upload", true, $CONFIG->pluginspath . "tidypics/actions/ajax_upload.php"); register_action("tidypics/ajax_upload_complete", true, $CONFIG->pluginspath . "tidypics/actions/ajax_upload_complete.php"); register_action("tidypics/addalbum", false, $CONFIG->pluginspath. "tidypics/actions/addalbum.php"); +register_action("tidypics/sortalbum", false, $CONFIG->pluginspath. "tidypics/actions/sortalbum.php"); register_action("tidypics/edit", false, $CONFIG->pluginspath. "tidypics/actions/edit.php"); register_action("tidypics/delete", false, $CONFIG->pluginspath. "tidypics/actions/delete.php"); register_action("tidypics/edit_multi", false, $CONFIG->pluginspath. "tidypics/actions/edit_multi.php"); diff --git a/views/default/tidypics/css.php b/views/default/tidypics/css.php index f7dd256a1..abcdc86a9 100644 --- a/views/default/tidypics/css.php +++ b/views/default/tidypics/css.php @@ -384,4 +384,22 @@ float: right; .uploadifyError { border: 2px solid #FBCBBC; background-color: #FDE5DD; -}
\ No newline at end of file +} + +#tidypics_album_sort { +padding:0; +margin:0; +} + +#tidypics_album_sort li { +float:left; +margin:3px; +width:161px; +height:161px; +} + +#tidypics_album_sort img { +border:1px solid #dedede; +padding:4px; +} + diff --git a/views/default/tidypics/sort.php b/views/default/tidypics/sort.php new file mode 100644 index 000000000..66dd8a999 --- /dev/null +++ b/views/default/tidypics/sort.php @@ -0,0 +1,54 @@ +<?php +/** + * Album sorting view + */ + +$album = $vars['album']; +$image_guids = $album->getImageList(); + +// create submission form +$body = elgg_view('input/hidden', array('internalname' => 'guids')); +$body .= elgg_view('input/hidden', array('internalname' => 'album_guid', 'value' => $album->guid)); +$body .= elgg_view('input/submit', array('value' => elgg_echo('save'))); +?> +<div class="contentWrapper"> + <div> + <?php echo elgg_echo('tidypics:sort:instruct'); ?> + </div> + <?php + $params = array( + 'internalid' => 'tidypics_sort_form', + 'action' => "{$vars['url']}action/tidypics/sortalbum", + 'body' => $body, + ); + echo elgg_view('input/form', $params); + ?> + + <ul id="tidypics_album_sort"> + <?php + foreach ($image_guids as $image_guid) { + $image = get_entity($image_guid); + $url = "{$vars['url']}pg/photos/thumbnail/$image_guid/small/"; + echo "<li id=\"$image_guid\"><img src=\"$url\" /></li>"; + } + ?> + </ul> + <div class="clearfloat"></div> +</div> + +<script type="text/javascript"> +$("#tidypics_album_sort").sortable( + { + opacity: 0.7, + revert: true, + scroll: true + } +); +$('#tidypics_sort_form').submit(function() { + var tidypics_guids = []; + $("#tidypics_album_sort li").each(function(index) { + tidypics_guids.push($(this).attr('id')); + }); + $('input[name="guids"]').val(tidypics_guids.toString()); +}); +</script>
\ No newline at end of file |