Support downloading of multiple photos.

This commit adds a contextmenu entry to download a single and multiple
photos via selection. So far, not for guests.
This commit is contained in:
Nils Asmussen 2016-08-21 14:27:51 +02:00
parent 9088c1ed2c
commit 47ed1775c9
4 changed files with 53 additions and 0 deletions

View File

@ -61,6 +61,7 @@ final class Admin extends Access {
// $_GET functions // $_GET functions
case 'Album::getArchive': self::getAlbumArchiveAction(); break; case 'Album::getArchive': self::getAlbumArchiveAction(); break;
case 'Photo::getArchive': self::getPhotoArchiveAction(); break;
case 'Photo::getPhoto': self::getPhotoFileAction(); break; case 'Photo::getPhoto': self::getPhotoFileAction(); break;
} }
@ -341,6 +342,15 @@ final class Admin extends Access {
} }
private static function getPhotoArchiveAction() {
Validator::required(isset($_GET['photoIDs']), __METHOD__);
$photo = new Photo($_GET['photoIDs']);
$photo->getArchive();
}
private static function getPhotoFileAction() { private static function getPhotoFileAction() {
Validator::required(isset($_GET['photoID']), __METHOD__); Validator::required(isset($_GET['photoID']), __METHOD__);

View File

@ -948,6 +948,33 @@ final class Photo {
} }
/**
* Starts a download of photos.
* @return resource|boolean Sends a ZIP-file or returns false on failure.
*/
public function getArchive() {
// Check dependencies
Validator::required(isset($this->photoIDs), __METHOD__);
// Call plugins
Plugins::get()->activate(__METHOD__, 0, func_get_args());
$archive = new Archive('Photos');
$query = Database::prepare(Database::get(), 'SELECT title, url FROM ? WHERE id IN (?)', array(LYCHEE_TABLE_PHOTOS, $this->photoIDs));
if (!$archive->addPhotos('', $query)) return false;
$archive->send();
// Call plugins
Plugins::get()->activate(__METHOD__, 1, func_get_args());
return true;
}
/** /**
* Sets the title of a photo. * Sets the title of a photo.
* @return boolean Returns true when successful. * @return boolean Returns true when successful.

View File

@ -244,6 +244,7 @@ contextMenu.photo = function(photoID, e) {
// in order to keep the selection // in order to keep the selection
let items = [ let items = [
{ title: build.iconic('cloud-download') + 'Download', fn: () => photo.getPhoto(photoID) },
{ title: build.iconic('star') + 'Star', fn: () => photo.setStar([ photoID ]) }, { title: build.iconic('star') + 'Star', fn: () => photo.setStar([ photoID ]) },
{ title: build.iconic('tag') + 'Tags', fn: () => photo.editTags([ photoID ]) }, { title: build.iconic('tag') + 'Tags', fn: () => photo.editTags([ photoID ]) },
{ }, { },
@ -268,6 +269,7 @@ contextMenu.photoMulti = function(photoIDs, e) {
// in order to keep the selection and multiselect // in order to keep the selection and multiselect
let items = [ let items = [
{ title: build.iconic('cloud-download') + 'Download All', fn: () => photo.getArchive(photoIDs) },
{ title: build.iconic('star') + 'Star All', fn: () => photo.setStar(photoIDs) }, { title: build.iconic('star') + 'Star All', fn: () => photo.setStar(photoIDs) },
{ title: build.iconic('tag') + 'Tag All', fn: () => photo.editTags(photoIDs) }, { title: build.iconic('tag') + 'Tag All', fn: () => photo.editTags(photoIDs) },
{ }, { },

View File

@ -647,6 +647,20 @@ photo.getPhoto = function(photoID) {
} }
photo.getArchive = function(photoIDs) {
let link
let url = `${ api.path }?function=Photo::getArchive&photoIDs=${ photoIDs.join(',') }`
if (location.href.indexOf('index.html')>0) link = location.href.replace(location.hash, '').replace('index.html', url)
else link = location.href.replace(location.hash, '') + url
if (lychee.publicMode===true) link += `&password=${ encodeURIComponent(password.value) }`
location.href = link
}
photo.getDirectLink = function() { photo.getDirectLink = function() {
let url = '' let url = ''