'''
spiegel.de
'''

from calibre.web.feeds.news import BasicNewsRecipe

class Spiegel_int(BasicNewsRecipe):
    title = 'Spiegel Online International'
    __author__ = 'unkn0wn'
    description = "Daily news, analysis and opinion from Europe's leading newsmagazine and Germany's top news Web site"
    oldest_article = 7
    max_articles_per_feed = 100
    language = 'en_DE'
    no_stylesheets = True
    use_embedded_content = False
    encoding = 'utf-8'
    publisher = 'SPIEGEL ONLINE GmbH'
    category = 'news, politics, Germany'
    publication_type = 'magazine'
    remove_empty_feeds = True
    remove_attributes = ['style','height','width']
    ignore_duplicate_articles = {'url'}
    #favicon https://cdn.prod.www.spiegel.de/public/spon/images/icons/favicon.ico
    masthead_url = 'https://upload.wikimedia.org/wikipedia/commons/0/06/Logo-Der-Spiegel-de.png'

    conversion_options = {
        'comments': description, 'tags': category, 'language': language, 'publisher': publisher
    }
    
    def get_cover_url(self):
        soup = self.index_to_soup('https://www.spiegel.de/spiegel/print/')
        div = soup.find('div', attrs={'data-component':'MagazineImage'})
        citem = div.find('img', attrs={'data-src':True})['data-src'].replace('260', '800')
        return citem
    
    keep_only_tags = [dict(name='article')]
    
    remove_tags = [
        dict(name='section', attrs={'data-app-hidden':True}),
        dict(name='div', attrs={'data-issue-context-hidden':True}),
        dict(name='div', attrs={'data-area':'related_articles'}),
        dict(name='div', attrs={'data-component':'HTMLEmbed'}),
        dict(name=['footer', 'button', 'svg'])
    ]
    
    extra_css = '''
        time{font-size:small;}
        [data-area="quote"]{text-align:center; color:#404040;}
        #fig-c{font-size:small; text-align:center;}
    '''

    feeds = [
        ('World', 'https://www.spiegel.de/international/world/index.rss'),
        ('Europe', 'https://www.spiegel.de/international/europe/index.rss'),
        ('Germany', 'https://www.spiegel.de/international/germany/index.rss'),
        ('Business', 'https://www.spiegel.de/international/business/index.rss'),
        ('Zeitgeist', 'https://www.spiegel.de/international/zeitgeist/index.rss'),
        ('Tomorrow', 'https://www.spiegel.de/international/tomorrow/index.rss'),
        ('Others', 'http://www.spiegel.de/international/index.rss')
    ]
    
    def preprocess_html(self, soup):
        for img in soup.findAll('img', attrs={'data-src':True}):
            img['src'] = img['data-src']
        for fig in soup.findAll('figcaption'):
            fig['id'] = 'fig-c'
        return soup

calibre_most_common_ua = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/80.0.3987.87 Safari/537.36'