Skip to content

Commit

Permalink
[PresidenciaPTBridge]: Support multiple sections (#2082)
Browse files Browse the repository at this point in the history
  • Loading branch information
somini committed May 9, 2021
1 parent 63ebf5c commit e79a02a
Showing 1 changed file with 49 additions and 17 deletions.
66 changes: 49 additions & 17 deletions bridges/PresidenciaPTBridge.php
Expand Up @@ -2,8 +2,32 @@
class PresidenciaPTBridge extends BridgeAbstract {
const NAME = 'Presidência da República Portuguesa';
const URI = 'https://www.presidencia.pt';
const DESCRIPTION = 'Presidência da República Portuguesa | Mensagens';
const DESCRIPTION = 'Presidência da República Portuguesa';
const MAINTAINER = 'somini';
const PARAMETERS = array(
'Section' => array(
'/atualidade/noticias' => array(
'name' => 'Notícias',
'type' => 'checkbox',
'defaultValue' => 'checked',
),
'/atualidade/mensagens' => array(
'name' => 'Mensagens',
'type' => 'checkbox',
'defaultValue' => 'checked',
),
'/atualidade/atividade-legislativa' => array(
'name' => 'Atividade Legislativa',
'type' => 'checkbox',
'defaultValue' => 'checked',
),
'/atualidade/notas-informativas' => array(
'name' => 'Notas Informativas',
'type' => 'checkbox',
'defaultValue' => 'checked',
)
)
);

const PT_MONTH_NAMES = array(
'janeiro',
Expand All @@ -19,27 +43,35 @@ class PresidenciaPTBridge extends BridgeAbstract {
'novembro',
'dezembro');

public function getIcon(){
return 'https://www.presidencia.pt/Theme/favicon/apple-touch-icon.png';
}

public function collectData() {
$html = getSimpleHTMLDOM($this->getURI() . '/atualidade/mensagens')
or returnServerError('Could not load content');
foreach(array_keys($this->getParameters()['Section']) as $k) {
Debug::log('Key: ' . var_export($k, true));
if($this->getInput($k)) {
$html = getSimpleHTMLDOMCached($this->getURI() . $k);

foreach($html->find('#atualidade-list article.card-block') as $element) {
$item = array();
foreach($html->find('#atualidade-list article.card-block') as $element) {
$item = array();

$link = $element->find('a', 0);
$etitle = $link->find('h2', 0);
$edts = $element->find('p', 1);
$edt = html_entity_decode($edts->innertext, ENT_HTML5);
$link = $element->find('a', 0);
$etitle = $element->find('.content-box h2', 0);
$edts = $element->find('p', 1);
$edt = html_entity_decode($edts->innertext, ENT_HTML5);

$item['title'] = $etitle->innertext;
$item['uri'] = self::URI . $link->href;
$item['description'] = $element;
$item['timestamp'] = str_ireplace(
array_map(function($name) { return ' de ' . $name . ' de '; }, self::PT_MONTH_NAMES),
array_map(function($num) { return sprintf('-%02d-', $num); }, range(1, sizeof(self::PT_MONTH_NAMES))),
$edt);
$item['title'] = strip_tags($etitle->innertext);
$item['uri'] = self::URI . $link->href;
$item['description'] = $element;
$item['timestamp'] = str_ireplace(
array_map(function($name) { return ' de ' . $name . ' de '; }, self::PT_MONTH_NAMES),
array_map(function($num) { return sprintf('-%02d-', $num); }, range(1, sizeof(self::PT_MONTH_NAMES))),
$edt);

$this->items[] = $item;
$this->items[] = $item;
}
}
}
}
}

0 comments on commit e79a02a

Please sign in to comment.