From e6c73a1fe3e9f9ff00aca8928f857117a240c0d3 Mon Sep 17 00:00:00 2001 From: Joseph Date: Mon, 16 Nov 2020 17:33:48 +0000 Subject: [PATCH] [FlickrBridge] Add filter by media and sort by options (#1758) --- bridges/FlickrBridge.php | 110 +++++++++++++++++++++++++++++++++++---- 1 file changed, 100 insertions(+), 10 deletions(-) diff --git a/bridges/FlickrBridge.php b/bridges/FlickrBridge.php index cb9db722..feab191a 100644 --- a/bridges/FlickrBridge.php +++ b/bridges/FlickrBridge.php @@ -20,6 +20,27 @@ class FlickrBridge extends BridgeAbstract { 'required' => true, 'title' => 'Insert keyword', 'exampleValue' => 'bird' + ), + 'media' => array( + 'name' => 'Media', + 'type' => 'list', + 'values' => array( + 'All (Photos & videos)' => 'all', + 'Photos' => 'photos', + 'Videos' => 'videos', + ), + 'defaultValue' => 'all', + ), + 'sort' => array( + 'name' => 'Sort By', + 'type' => 'list', + 'values' => array( + 'Relevance' => 'relevance', + 'Date uploaded' => 'date-posted-desc', + 'Date taken' => 'date-taken-desc', + 'Interesting' => 'interestingness-desc', + ), + 'defaultValue' => 'relevance', ) ), 'By username' => array( @@ -29,30 +50,60 @@ class FlickrBridge extends BridgeAbstract { 'required' => true, 'title' => 'Insert username (as shown in the address bar)', 'exampleValue' => 'flickr' + ), + 'media' => array( + 'name' => 'Media', + 'type' => 'list', + 'values' => array( + 'All (Photos & videos)' => 'all', + 'Photos' => 'photos', + 'Videos' => 'videos', + ), + 'defaultValue' => 'all', + ), + 'sort' => array( + 'name' => 'Sort By', + 'type' => 'list', + 'values' => array( + 'Relevance' => 'relevance', + 'Date uploaded' => 'date-posted-desc', + 'Date taken' => 'date-taken-desc', + 'Interesting' => 'interestingness-desc', + ), + 'defaultValue' => 'date-posted-desc', ) ) ); - public function collectData(){ + private $username = ''; + + public function collectData() { switch($this->queriedContext) { case 'Explore': $filter = 'photo-lite-models'; - $html = getSimpleHTMLDOM(self::URI . 'explore') + $html = getSimpleHTMLDOM($this->getURI()) or returnServerError('Could not request Flickr.'); break; case 'By keyword': $filter = 'photo-lite-models'; - $html = getSimpleHTMLDOM(self::URI . 'search/?q=' . urlencode($this->getInput('q')) . '&s=rec') + $html = getSimpleHTMLDOM($this->getURI()) or returnServerError('No results for this query.'); break; case 'By username': - $filter = 'photo-models'; - $html = getSimpleHTMLDOM(self::URI . 'photos/' . urlencode($this->getInput('u'))) + //$filter = 'photo-models'; + $filter = 'photo-lite-models'; + $html = getSimpleHTMLDOM($this->getURI()) or returnServerError('Requested username can\'t be found.'); + + $this->username = $this->getInput('u'); + + if ($html->find('span.search-pill-name', 0)) { + $this->username = $html->find('span.search-pill-name', 0)->plaintext; + } break; default: @@ -64,7 +115,6 @@ class FlickrBridge extends BridgeAbstract { $photo_models = $this->getPhotoModels($model_json, $filter); foreach($photo_models as $model) { - $item = array(); /* Author name depends on scope. On a keyword search the @@ -72,12 +122,12 @@ class FlickrBridge extends BridgeAbstract { * the author is part of the owner data. */ if(array_key_exists('username', $model)) { - $item['author'] = $model['username']; + $item['author'] = urldecode($model['username']); } elseif (array_key_exists('owner', reset($model_json)[0])) { - $item['author'] = reset($model_json)[0]['owner']['username']; + $item['author'] = urldecode(reset($model_json)[0]['owner']['username']); } - $item['title'] = (array_key_exists('title', $model) ? $model['title'] : 'Untitled'); + $item['title'] = urldecode((array_key_exists('title', $model) ? $model['title'] : 'Untitled')); $item['uri'] = self::URI . 'photo.gne?id=' . $model['id']; $description = (array_key_exists('description', $model) ? $model['description'] : ''); @@ -87,7 +137,7 @@ class FlickrBridge extends BridgeAbstract { . '">

' - . $description + . urldecode($description) . '

'; $item['enclosures'] = $this->extractEnclosures($model); @@ -98,6 +148,46 @@ class FlickrBridge extends BridgeAbstract { } + public function getURI() { + + switch($this->queriedContext) { + case 'Explore': + return self::URI . 'explore'; + break; + case 'By keyword': + return self::URI . 'search/?q=' . urlencode($this->getInput('q')) + . '&sort=' . $this->getInput('sort') . '&media=' . $this->getInput('media'); + break; + case 'By username': + return self::URI . 'search/?user_id=' . urlencode($this->getInput('u')) + . '&sort=' . $this->getInput('sort') . '&media=' . $this->getInput('media'); + break; + + default: + return parent::getURI(); + } + } + + public function getName() { + + switch($this->queriedContext) { + case 'Explore': + return 'Explore - ' . self::NAME; + break; + case 'By keyword': + return $this->getInput('q') . ' - keyword - ' . self::NAME; + break; + case 'By username': + return $this->username . ' - ' . self::NAME; + break; + + default: + return parent::getName(); + } + + return parent::getName(); + } + private function extractJsonModel($html) { // Find SCRIPT containing JSON data