From 2448ed41c9b6f98b140e142a1f508a3e85970a3d Mon Sep 17 00:00:00 2001 From: csisoap <33269526+csisoap@users.noreply.github.com> Date: Tue, 9 Mar 2021 13:15:48 +0700 Subject: [PATCH] [ReutersBridge] Add new wireitem template type (#2006) and retain the list of parameters --- bridges/ReutersBridge.php | 47 ++++++++++++++++++++++++++------------- 1 file changed, 31 insertions(+), 16 deletions(-) diff --git a/bridges/ReutersBridge.php b/bridges/ReutersBridge.php index cb6b4e38..e3e2f103 100644 --- a/bridges/ReutersBridge.php +++ b/bridges/ReutersBridge.php @@ -21,7 +21,8 @@ class ReutersBridge extends BridgeAbstract * Wireitem template types allowed in the final story output */ const ALLOWED_TEMPLATE_TYPES = array( - 'story' + 'story', + 'headlines' ); const PARAMETERS = array( @@ -127,9 +128,20 @@ class ReutersBridge extends BridgeAbstract $authorlist = $first['story']['authors']; $category = $first['story']['channel']['name']; $image_list = $first['story']['images']; + + $content_detail = array( + 'content' => $this->handleArticleContent($article_content), + 'author' => $this->handleAuthorName($authorlist), + 'category' => $category, + 'images' => $this->handleImage($image_list), + ); + return $content_detail; + } + + private function handleImage($images) { $img_placeholder = ''; - foreach($image_list as $image) { // Add more image to article. + foreach($images as $image) { // Add more image to article. $image_url = $image['url']; $image_caption = $image['caption']; $img = ""; @@ -138,21 +150,29 @@ class ReutersBridge extends BridgeAbstract $img_placeholder = $img_placeholder . $figure; } + return $img_placeholder; + } + + private function handleAuthorName($authors) { $author = ''; $counter = 0; - foreach ($authorlist as $data) { + foreach ($authors as $data) { //Formatting author's name. $counter++; $name = $data['name']; - if ($counter == count($authorlist)) { + if ($counter == count($authors)) { $author = $author . $name; } else { $author = $author . "$name, "; } } + return $author; + } + + private function handleArticleContent($contents) { $description = ''; - foreach ($article_content as $content) { + foreach ($contents as $content) { $data; if(isset($content['content'])) { $data = $content['content']; @@ -185,13 +205,7 @@ class ReutersBridge extends BridgeAbstract } } - $content_detail = array( - 'content' => $description, - 'author' => $author, - 'category' => $category, - 'images' => $img_placeholder, - ); - return $content_detail; + return $description; } public function getName() { @@ -216,10 +230,11 @@ class ReutersBridge extends BridgeAbstract $processedData = $this->processData($reuters_wireitems); // Merge all articles from Editor's Highlight section into existing array of templates. - $top_section = reset($reuters_wireitems); - if ($top_section['wireitem_type'] == 'headlines') { - $top_articles = $top_section['templates'][1]['headlines']; - $processedData = array_merge($top_articles, $processedData); + $top_section = reset($processedData); + if ($top_section['type'] == 'headlines') { + $top_section = array_shift($processedData); + $articles = $top_section['headlines']; + $processedData = array_merge($articles, $processedData); } foreach ($processedData as $story) {