[GithubIssueBridge] fix comments number + code simplification
Signed-off-by: Pierre Mazière <pierre.maziere@gmx.com>
This commit is contained in:
parent
7c840093db
commit
0fea61a470
1 changed files with 10 additions and 7 deletions
|
@ -3,7 +3,7 @@ class GithubIssueBridge extends BridgeAbstract{
|
||||||
|
|
||||||
public $maintainer = 'Pierre Mazière';
|
public $maintainer = 'Pierre Mazière';
|
||||||
public $name = 'Github Issue';
|
public $name = 'Github Issue';
|
||||||
public $uri = '';
|
public $uri = 'https://github.com/';
|
||||||
public $description = 'Returns the issues or comments of an issue of a github project';
|
public $description = 'Returns the issues or comments of an issue of a github project';
|
||||||
|
|
||||||
public $parameters=array(
|
public $parameters=array(
|
||||||
|
@ -29,11 +29,13 @@ class GithubIssueBridge extends BridgeAbstract{
|
||||||
);
|
);
|
||||||
|
|
||||||
public function collectData(){
|
public function collectData(){
|
||||||
$uri = 'https://github.com/'.$this->getInput('u').'/'.$this->getInput('p').'/issues/'.($this->getInput('i')?$this->getInput('i'):'');
|
$uri = $this->uri.$this->getInput('u').'/'.$this->getInput('p')
|
||||||
|
.'/issues/'.$this->getInput('i');
|
||||||
$html = $this->getSimpleHTMLDOM($uri)
|
$html = $this->getSimpleHTMLDOM($uri)
|
||||||
or $this->returnServerError('No results for Github Issue '.$this->getInput('i').' in project '.$this->getInput('u').'/'.$this->getInput('p'));
|
or $this->returnServerError('No results for Github Issue '.$this->getInput('i').' in project '.$this->getInput('u').'/'.$this->getInput('p'));
|
||||||
|
|
||||||
if($this->getInput('i')){
|
switch($this->queriedContext){
|
||||||
|
case 'Issue Comments':
|
||||||
foreach($html->find('.js-comment-container') as $comment){
|
foreach($html->find('.js-comment-container') as $comment){
|
||||||
|
|
||||||
$item = array();
|
$item = array();
|
||||||
|
@ -48,19 +50,20 @@ class GithubIssueBridge extends BridgeAbstract{
|
||||||
|
|
||||||
$this->items[]=$item;
|
$this->items[]=$item;
|
||||||
}
|
}
|
||||||
}else{
|
break;
|
||||||
|
case 'Project Issues':
|
||||||
foreach($html->find('.js-active-navigation-container .js-navigation-item') as $issue){
|
foreach($html->find('.js-active-navigation-container .js-navigation-item') as $issue){
|
||||||
$item=array();
|
$item=array();
|
||||||
$info=$issue->find('.opened-by',0);
|
$info=$issue->find('.opened-by',0);
|
||||||
$item['author']=$info->find('a',0)->plaintext;
|
$item['author']=$info->find('a',0)->plaintext;
|
||||||
$item['timestamp']=strtotime($info->find('relative-time',0)->getAttribute('datetime'));
|
$item['timestamp']=strtotime($info->find('relative-time',0)->getAttribute('datetime'));
|
||||||
$item['title']=$issue->find('.js-navigation-open',0)->plaintext;
|
$item['title']=$issue->find('.js-navigation-open',0)->plaintext;
|
||||||
$comments=$issue->firstChild()->firstChild()
|
$comments=$issue->find('.col-5',0)->plaintext;
|
||||||
->nextSibling()->nextSibling()->nextSibling()->plaintext;
|
|
||||||
$item['content']='Comments: '.($comments?$comments:'0');
|
$item['content']='Comments: '.($comments?$comments:'0');
|
||||||
$item['uri']='https://github.com'.$issue->find('.js-navigation-open',0)->getAttribute('href');
|
$item['uri']=$this->uri.$issue->find('.js-navigation-open',0)->getAttribute('href');
|
||||||
$this->items[]=$item;
|
$this->items[]=$item;
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue