[PinterestBridge] Remove search (#1206)
* Remove getSearchResults() * Remove ''From search' from PARAMETERS array * Update getURI() and getName() * Update collectData() * Add '.rss' to URL in `collectData` instead of in `getURI`
This commit is contained in:
parent
7e6c58b67a
commit
41a8eb74a1
1 changed files with 13 additions and 77 deletions
|
@ -16,12 +16,6 @@ class PinterestBridge extends FeedExpander {
|
||||||
'name' => 'board',
|
'name' => 'board',
|
||||||
'required' => true
|
'required' => true
|
||||||
)
|
)
|
||||||
),
|
|
||||||
'From search' => array(
|
|
||||||
'q' => array(
|
|
||||||
'name' => 'Keyword',
|
|
||||||
'required' => true
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -30,16 +24,8 @@ class PinterestBridge extends FeedExpander {
|
||||||
}
|
}
|
||||||
|
|
||||||
public function collectData() {
|
public function collectData() {
|
||||||
switch($this->queriedContext) {
|
|
||||||
case 'By username and board':
|
|
||||||
$this->collectExpandableDatas($this->getURI() . '.rss');
|
$this->collectExpandableDatas($this->getURI() . '.rss');
|
||||||
$this->fixLowRes();
|
$this->fixLowRes();
|
||||||
break;
|
|
||||||
case 'From search':
|
|
||||||
default:
|
|
||||||
$html = getSimpleHTMLDOMCached($this->getURI());
|
|
||||||
$this->getSearchResults($html);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function fixLowRes() {
|
private function fixLowRes() {
|
||||||
|
@ -55,71 +41,21 @@ class PinterestBridge extends FeedExpander {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getSearchResults($html){
|
|
||||||
$json = json_decode($html->find('#jsInit1', 0)->innertext, true);
|
|
||||||
$results = $json['resourceDataCache'][0]['data']['results'];
|
|
||||||
|
|
||||||
foreach($results as $result) {
|
|
||||||
$item = array();
|
|
||||||
|
|
||||||
$item['uri'] = self::URI . $result['board']['url'];
|
|
||||||
|
|
||||||
// Some use regular titles, others provide 'advanced' infos, a few
|
|
||||||
// provide even less info. Thus we attempt multiple options.
|
|
||||||
$item['title'] = trim($result['title']);
|
|
||||||
|
|
||||||
if($item['title'] === '')
|
|
||||||
$item['title'] = trim($result['rich_summary']['display_name']);
|
|
||||||
|
|
||||||
if($item['title'] === '')
|
|
||||||
$item['title'] = trim($result['grid_description']);
|
|
||||||
|
|
||||||
$item['timestamp'] = strtotime($result['created_at']);
|
|
||||||
$item['username'] = $result['pinner']['username'];
|
|
||||||
$item['fullname'] = $result['pinner']['full_name'];
|
|
||||||
$item['avatar'] = $result['pinner']['image_small_url'];
|
|
||||||
$item['author'] = $item['username'] . ' (' . $item['fullname'] . ')';
|
|
||||||
$item['content'] = '<img align="left" style="margin: 2px 4px;" src="'
|
|
||||||
. htmlentities($item['avatar'])
|
|
||||||
. '" /><p><strong>'
|
|
||||||
. $item['username']
|
|
||||||
. '</strong><br>'
|
|
||||||
. $item['fullname']
|
|
||||||
. '</p><br><img src="'
|
|
||||||
. $result['images']['736x']['url']
|
|
||||||
. '" alt="" /><br><p>'
|
|
||||||
. $result['description']
|
|
||||||
. '</p>';
|
|
||||||
|
|
||||||
$item['enclosures'] = array($result['images']['orig']['url']);
|
|
||||||
|
|
||||||
$this->items[] = $item;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function getURI() {
|
public function getURI() {
|
||||||
switch($this->queriedContext) {
|
|
||||||
case 'By username and board':
|
if ($this->queriedContext === 'By username and board') {
|
||||||
$uri = self::URI . '/' . urlencode($this->getInput('u')) . '/' . urlencode($this->getInput('b'));// . '.rss';
|
return self::URI . '/' . urlencode($this->getInput('u')) . '/' . urlencode($this->getInput('b'));
|
||||||
break;
|
|
||||||
case 'From search':
|
|
||||||
$uri = self::URI . '/search/?q=' . urlencode($this->getInput('q'));
|
|
||||||
break;
|
|
||||||
default: return parent::getURI();
|
|
||||||
}
|
}
|
||||||
return $uri;
|
|
||||||
|
return parent::getURI();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getName() {
|
public function getName() {
|
||||||
switch($this->queriedContext) {
|
|
||||||
case 'By username and board':
|
if ($this->queriedContext === 'By username and board') {
|
||||||
$specific = $this->getInput('u') . ' - ' . $this->getInput('b');
|
return $this->getInput('u') . ' - ' . $this->getInput('b') . ' - ' . self::NAME;
|
||||||
break;
|
|
||||||
case 'From search':
|
|
||||||
$specific = $this->getInput('q');
|
|
||||||
break;
|
|
||||||
default: return parent::getName();
|
|
||||||
}
|
}
|
||||||
return $specific . ' - ' . self::NAME;
|
|
||||||
|
return parent::getName();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue