#-*- coding:utf-8 -*-
import base64
import os
import re
import urllib.request as urllib2
from ..base import *
css = ''
eudict_download_mp3 = True
@register([u'欧路词典', u'eudict'])
class Eudict(WebService):
    def __init__(self):
        super(Eudict, self).__init__()
    def _get_from_api(self):
        url = 'http://dict.eudic.net/mdicts/en/{}'.format(self.quote_word)
        try:
            result = {}
            html = self.get_response(url, timeout=5)
            soup = parse_html(html)
            def _get_from_element(dict, key, soup, tag, id=None, class_=None):
                baseURL = 'http://dict.eudic.net/'
                # element = soup.find(tag, id=id, class_=class_)  # bs4
                if id:
                    element = soup.find(tag, {"id": id})
                if class_:
                    element = soup.find(tag, {"class": class_})
                if element:
                    dict[key] = str(element)
                    dict[key] = re.sub(r'href="/', 'href="' + baseURL,
                                       dict[key])
                    dict[key] = re.sub(r'声明:.*。', '', dict[key])
                    dict[key] = dict[key]
                return dict
            def _sentence_audio(soup, tag, class_):
                el_list = soup.findAll(tag, {'class': class_})
                if el_list:
                    url = 'https://api.frdic.com/api/v2/speech/speakweb?langid=ting&voicename={0}&txt=QYN{1}'
                    maps = []
                    for element in el_list:
                        # 例句
                        i_str = str(element)
                        m = element.find('div', {'class': 'content'})
                        if m:
                            # i_str = str(m)
                            # 声音
                            sound = url.format(
                                element.get('source'),
                                urllib2.quote(
                                    base64.b64encode(m.text.encode('utf-8'))))
                            maps.append([sound, i_str])
                my_str = ''
                for i, e in enumerate(maps):
                    i_str = e[1]
                    sound = e[0]
                    mp3 = self._fld_mp3(sound)
                    my_str = my_str + '
' + i_str + ' ' + mp3 + ''
                return my_str
            result = _get_from_element(
                result, 'phonitic', soup, 'span', class_='Phonitic')
            result = _get_from_element(
                result, 'fccf', soup, 'div', id='FCChild')  # 西汉-汉西词典
            result = _get_from_element(
                result, 'example', soup, 'div', id='LJChild')  # 西语例句库
            result = _get_from_element(
                result, 'syn', soup, 'div', id='SYNChild')  # 近义、反义、派生词典
            result = _get_from_element(
                result, 'ff', soup, 'div', id='FFChild')  # 西西词典
            result['oexample'] = _sentence_audio(
                soup, 'div', class_='lj_item')  # 原声例句
            return self.cache_this(result)
        except Exception as e:
            return {}
    def _fld_mp3(self, audio_url):
        if eudict_download_mp3 and audio_url:
            filename = get_hex_name('eudict', audio_url, 'mp3')
            if os.path.exists(filename) or self.net_download(
                    filename, audio_url):
                return self.get_anki_label(filename, 'audio')
        return ''
    @export([u'真人发音', u'Real person pronounciation'])
    def fld_sound(self):
        url = 'https://api.frdic.com/api/v2/speech/speakweb?langid=es&txt=QYN{word}'.format(
            word=urllib2.quote(base64.b64encode(self.word.encode('utf-8'))))
        filename = get_hex_name(self.unique.lower(), url, 'mp3')
        if os.path.exists(filename) or self.net_download(filename, url):
            return self.get_anki_label(filename, 'audio')
        return ''
    @export('PHON')
    def fld_phonetic(self):
        return self._get_field('phonitic')
    @export([u'英汉-汉英词典', u'English-chinese/Chinese-english'])
    @with_styles(need_wrap_css=True, cssfile='_eudict.css')
    def fld_fccf(self):
        return self._get_field('fccf')
    @export([u'英语例句库', u'English examples'])
    @with_styles(need_wrap_css=True, cssfile='_eudict.css')
    def fld_example(self):
        return self._get_field('example')
    @export([u'近义词词典', u'Synonyms'])
    def fld_syn(self):
        return self._get_field('syn')
    @export([u'英英词典', u'English-english'])
    @with_styles(need_wrap_css=True, cssfile='_eudict.css')
    def fld_ff(self):
        return self._get_field('ff')
    @export([u'原声例句', u'Original examples'])
    @with_styles(need_wrap_css=True, cssfile='_eudict.css')
    def fld_oexample(self):
        return self._get_field('oexample')