2019-02-24 10:47:29 +00:00
|
|
|
<?php
|
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
class AsahiShimbunAJWBridge extends BridgeAbstract
|
|
|
|
{
|
|
|
|
const NAME = 'Asahi Shimbun AJW';
|
|
|
|
const BASE_URI = 'http://www.asahi.com';
|
|
|
|
const URI = self::BASE_URI . '/ajw/';
|
|
|
|
const DESCRIPTION = 'Asahi Shimbun - Asia & Japan Watch';
|
|
|
|
const MAINTAINER = 'somini';
|
|
|
|
const PARAMETERS = [
|
|
|
|
[
|
|
|
|
'section' => [
|
|
|
|
'type' => 'list',
|
|
|
|
'name' => 'Section',
|
|
|
|
'values' => [
|
|
|
|
'Japan » Social Affairs' => 'japan/social',
|
|
|
|
'Japan » People' => 'japan/people',
|
|
|
|
'Japan » 3/11 Disaster' => 'japan/0311disaster',
|
|
|
|
'Japan » Sci & Tech' => 'japan/sci_tech',
|
|
|
|
'Politics' => 'politics',
|
|
|
|
'Business' => 'business',
|
|
|
|
'Culture » Style' => 'culture/style',
|
|
|
|
'Culture » Movies' => 'culture/movies',
|
|
|
|
'Culture » Manga & Anime' => 'culture/manga_anime',
|
|
|
|
'Asia » China' => 'asia_world/china',
|
|
|
|
'Asia » Korean Peninsula' => 'asia_world/korean_peninsula',
|
|
|
|
'Asia » Around Asia' => 'asia_world/around_asia',
|
|
|
|
'Asia » World' => 'asia_world/world',
|
|
|
|
'Opinion » Editorial' => 'opinion/editorial',
|
|
|
|
'Opinion » Vox Populi' => 'opinion/vox',
|
|
|
|
],
|
|
|
|
'defaultValue' => 'politics',
|
|
|
|
]
|
|
|
|
]
|
|
|
|
];
|
2019-02-24 10:47:29 +00:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
private function getSectionURI($section)
|
|
|
|
{
|
2022-07-09 08:13:07 +02:00
|
|
|
return $this->getURI() . $section . '/';
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2019-02-24 10:47:29 +00:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
public function collectData()
|
|
|
|
{
|
|
|
|
$html = getSimpleHTMLDOM($this->getSectionURI($this->getInput('section')));
|
2019-02-24 10:47:29 +00:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
foreach ($html->find('#MainInner li a') as $element) {
|
|
|
|
if ($element->parent()->class == 'HeadlineTopImage-S') {
|
|
|
|
Debug::log('Skip Headline, it is repeated below');
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$item = [];
|
2019-02-24 10:47:29 +00:00
|
|
|
|
2022-07-01 15:10:30 +02:00
|
|
|
$item['uri'] = self::BASE_URI . $element->href;
|
|
|
|
$e_lead = $element->find('span.Lead', 0);
|
|
|
|
if ($e_lead) {
|
|
|
|
$item['content'] = $e_lead->innertext;
|
|
|
|
$e_lead->outertext = '';
|
|
|
|
} else {
|
|
|
|
$item['content'] = $element->innertext;
|
|
|
|
}
|
|
|
|
$e_date = $element->find('span.EnDate', 0);
|
|
|
|
if ($e_date) {
|
|
|
|
$item['timestamp'] = strtotime($e_date->innertext);
|
|
|
|
$e_date->outertext = '';
|
|
|
|
}
|
|
|
|
$e_video = $element->find('span.EnVideo', 0);
|
|
|
|
if ($e_video) {
|
|
|
|
$e_video->outertext = '';
|
|
|
|
$element->innertext = "VIDEO: $element->innertext";
|
|
|
|
}
|
2022-10-04 20:23:49 +01:00
|
|
|
$e_title = $element->find('.title', 0);
|
|
|
|
if ($e_title) {
|
|
|
|
$item['title'] = $e_title->innertext;
|
|
|
|
} else {
|
|
|
|
$item['title'] = $element->innertext;
|
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
|
|
|
|
$this->items[] = $item;
|
|
|
|
}
|
|
|
|
}
|
2019-02-24 10:47:29 +00:00
|
|
|
}
|