# SPDX-License-Identifier: AGPL-3.0-or-later
# lint: pylint
"""
DuckDuckGo Weather
~~~~~~~~~~~~~~~~~~
"""
from typing import TYPE_CHECKING
from json import loads
from urllib.parse import quote
from datetime import datetime
from flask_babel import gettext
from searx.engines.duckduckgo import fetch_traits  # pylint: disable=unused-import
from searx.engines.duckduckgo import get_ddg_lang
from searx.enginelib.traits import EngineTraits
if TYPE_CHECKING:
    import logging
    logger: logging.Logger
traits: EngineTraits
about = {
    "website": 'https://duckduckgo.com/',
    "wikidata_id": 'Q12805',
    "official_api_documentation": None,
    "use_official_api": True,
    "require_api_key": False,
    "results": "JSON",
}
send_accept_language_header = True
# engine dependent config
categories = ["others"]
URL = "https://duckduckgo.com/js/spice/forecast/{query}/{lang}"
def generate_condition_table(condition):
    res = ""
    res += f"
| {gettext('Condition')}" f" | {condition['summary']} | 
"
    res += (
        f"| {gettext('Temperature')}"
        f" | {f_to_c(condition['temperature'])}°C / {condition['temperature']}°F | 
"
    )
    res += (
        f"| {gettext('Feels like')} | {f_to_c(condition['apparentTemperature'])}°C / "
        f"{condition['apparentTemperature']}°F | 
"
    )
    res += (
        f"| {gettext('Wind')} | {condition['windBearing']}° — "
        f"{(condition['windSpeed'] * 1.6093440006147):.2f} km/h / {condition['windSpeed']} mph | 
"
    )
    res += f"| {gettext('Visibility')} | {condition['visibility']} km"
    res += f" | 
| {gettext('Humidity')} | {(condition['humidity'] * 100):.1f}% | 
"
    return res
def generate_day_table(day):
    res = ""
    res += (
        f"| {gettext('Min temp.')} | {f_to_c(day['temperatureLow'])}°C / "
        f"{day['temperatureLow']}°F | 
"
    )
    res += (
        f"| {gettext('Max temp.')} | {f_to_c(day['temperatureHigh'])}°C / "
        f"{day['temperatureHigh']}°F | 
"
    )
    res += f"| {gettext('UV index')} | {day['uvIndex']} | 
"
    res += (
        f"| {gettext('Sunrise')} | {datetime.fromtimestamp(day['sunriseTime']).strftime('%H:%M')} | 
"
    )
    res += (
        f"| {gettext('Sunset')} | {datetime.fromtimestamp(day['sunsetTime']).strftime('%H:%M')} | 
"
    )
    return res
def request(query, params):
    eng_region = traits.get_region(params['searxng_locale'], traits.all_locale)
    eng_lang = get_ddg_lang(traits, params['searxng_locale'])
    # !ddw paris :es-AR --> {'ad': 'es_AR', 'ah': 'ar-es', 'l': 'ar-es'}
    params['cookies']['ad'] = eng_lang
    params['cookies']['ah'] = eng_region
    params['cookies']['l'] = eng_region
    logger.debug("cookies: %s", params['cookies'])
    params["url"] = URL.format(query=quote(query), lang=eng_lang.split('_')[0])
    return params
def f_to_c(temperature):
    return "%.2f" % ((temperature - 32) / 1.8)
def response(resp):
    results = []
    if resp.text.strip() == "ddg_spice_forecast();":
        return []
    result = loads(resp.text[resp.text.find('\n') + 1 : resp.text.rfind('\n') - 2])
    current = result["currently"]
    title = result['flags']['ddg-location']
    infobox = f"{gettext('Current condition')}
"
    infobox += generate_condition_table(current)
    infobox += "
"
    last_date = None
    for time in result['hourly']['data']:
        current_time = datetime.fromtimestamp(time['time'])
        if last_date != current_time.date():
            if last_date is not None:
                infobox += ""
            infobox += f"{current_time.strftime('%Y-%m-%d')}
"
            infobox += ""
            for day in result['daily']['data']:
                if datetime.fromtimestamp(day['time']).date() == current_time.date():
                    infobox += generate_day_table(day)
            infobox += "
"
        last_date = current_time.date()
        infobox += f"| {current_time.strftime('%H:%M')} | 
"
        infobox += generate_condition_table(time)
    infobox += "
"
    results.append(
        {
            "infobox": title,
            "content": infobox,
        }
    )
    return results