#!/usr/bin/env python3
"""Crée la fiche produit WooCommerce brouillon pour le module amflags."""

from __future__ import annotations

import json
import sys
import uuid
from pathlib import Path

ROOT = Path(__file__).resolve().parents[1]
sys.path.insert(0, str(ROOT / "scripts"))

from article_studio.config import load_config
from article_studio.wp_client import _request, upload_media

ASSETS = ROOT / "exports" / "amflags-product"
ZIP_PATH = ASSETS / "amflags-1.0.0.zip"

PRODUCT_NAME = "Module PrestaShop badges produits personnalisés AM Flags"
SLUG = "module-prestashop-badges-produits-personnalises-am-flags"
SKU = "amflags-1.0.0"

SHORT_DESCRIPTION = (
    "Créez des badges produits sur mesure (texte multilingue, couleurs personnalisables) "
    "et assignez-les à vos fiches produits. Affichage automatique sur les miniatures du catalogue."
)

DESCRIPTION_HTML = """<h2>Valorisez votre catalogue avec des badges produits 100 % personnalisés</h2>
<p>Vous souhaitez mettre en avant vos best-sellers, nouveautés, promotions ou arguments de vente directement sur les miniatures produits ? Ce module PrestaShop répond à ce besoin.</p>
<p>Le module <strong>AM Flags</strong> est simple à prendre en main : aucune compétence technique requise pour créer vos étiquettes et les associer à vos produits.</p>
<p>La configuration initiale prend quelques minutes : créez vos badges, choisissez les couleurs, puis cochez-les sur chaque fiche produit.</p>

<h2>Gestionnaire de badges professionnel</h2>
<p>Vous pouvez créer et gérer autant de badges que nécessaire depuis le back-office :</p>
<ul>
<li>titres <strong>multilingues</strong> pour chaque langue active de la boutique,</li>
<li>couleur du texte et couleur de fond via sélecteur visuel,</li>
<li>ordre d'affichage configurable (champ position),</li>
<li>aperçu en temps réel dans l'interface d'administration,</li>
<li>assignation multiple par produit (plusieurs badges par fiche),</li>
<li>intégration native au système de flags PrestaShop (hook <code>actionProductFlagsModifier</code>).</li>
</ul>

<h2>Affichage catalogue optimisé</h2>
<p>Les badges s'affichent automatiquement sur les <strong>miniatures produits</strong> (listes catégories, grilles, page d'accueil) aux côtés des labels natifs (promo, nouveau, pack…).</p>
<p>Idéal pour le merchandising visuel : mode, déco, alimentaire, marketplace — toute boutique voulant structurer ses messages sans modifier le code.</p>

<h2>Performances et compatibilité</h2>
<ul>
<li>cache par requête pour limiter les requêtes SQL,</li>
<li>requêtes groupées sur les listes multi-produits,</li>
<li>fallback de langue si une traduction manque,</li>
<li>compatible PrestaShop <strong>1.7 à 8</strong> (toutes versions mineures),</li>
<li>installation plug &amp; play : tables créées automatiquement à l'installation.</li>
</ul>

<h2>Snippet thème fourni</h2>
<p>Pour afficher les couleurs personnalisées sur tous les thèmes, un micro-override du template <code>product-flags.tpl</code> est documenté (ajout de l'attribut <code>style</code> sur le &lt;li&gt; du flag). Indispensable sur Classic et Warehouse ; déjà intégré sur les thèmes personnalisés du développeur.</p>

<h2>Cas d'usage</h2>
<ul>
<li>« Best-seller », « Exclusivité web », « -30 % »</li>
<li>« Made in France », « Éco-responsable », « Bio »</li>
<li>« Collection été », « Précommande », « Stock limité »</li>
</ul>

<h2>Conclusion</h2>
<p>Le module <strong>AM Flags</strong> vous fait gagner du temps sur le merchandising catalogue : badges visuels, multilingues et personnalisables, sans développement spécifique.</p>
<p>Installation en un clic, interface intuitive, et livraison immédiate du fichier ZIP après achat.</p>"""

YOAST_TITLE = "Module PrestaShop badges produits AM Flags - Étiquettes multilingues"
YOAST_METADESC = (
    "Module PrestaShop pour créer des badges produits personnalisés (multilingue, couleurs). "
    "Affichage sur miniatures catalogue. Compatible PS 1.7 à 8."
)
YOAST_FOCUS = "Module PrestaShop badges produits"

VARIATIONS = [
    ("6 mois", "49.97"),
    ("12 mois (25% d'économie)", "87.4475"),
    ("24 mois (54% d'économie)", "97.9412"),
]

IMAGE_FILES = [
    ("amflags-featured.png", "Module PrestaShop AM Flags - badges produits personnalisés", True),
    ("amflags-admin-badges.png", "Back-office AM Flags - gestion des badges", False),
    ("amflags-frontend-catalog.png", "Front-office - badges sur miniatures produits", False),
    ("amflags-product-assignment.png", "Assignation des badges sur fiche produit", False),
]


def post_json(base_url: str, user: str, password: str, path: str, payload: dict) -> dict:
    url = f"{base_url.rstrip('/')}{path}"
    _, data = _request(
        "POST",
        url,
        user,
        password,
        data=json.dumps(payload).encode("utf-8"),
        headers={"Content-Type": "application/json"},
    )
    return data


def put_json(base_url: str, user: str, password: str, path: str, payload: dict) -> dict:
    url = f"{base_url.rstrip('/')}{path}"
    _, data = _request(
        "PUT",
        url,
        user,
        password,
        data=json.dumps(payload).encode("utf-8"),
        headers={"Content-Type": "application/json"},
    )
    return data


def main() -> None:
    cfg = load_config()
    base = cfg.wp_base_url
    user = cfg.wp_user
    pwd = cfg.wp_application_password.replace(" ", "")

    print("Upload des images…")
    image_ids: list[int] = []
    featured_id: int | None = None
    for filename, alt, is_featured in IMAGE_FILES:
        path = ASSETS / filename
        media = upload_media(base, user, pwd, path, alt_text=alt, title=alt)
        mid = int(media["id"])
        image_ids.append(mid)
        if is_featured:
            featured_id = mid
        print(f"  media {mid}: {filename}")

    print("Upload du ZIP…")
    zip_media = upload_media(
        base,
        user,
        pwd,
        ZIP_PATH,
        alt_text="Module PrestaShop AM Flags v1.0.0",
        title="amflags-1.0.0",
    )
    zip_url = zip_media.get("source_url") or zip_media.get("guid", {}).get("rendered", "")
    print(f"  zip URL: {zip_url}")

    print("Création du produit variable (brouillon)…")
    product_payload = {
        "name": PRODUCT_NAME,
        "slug": SLUG,
        "type": "variable",
        "status": "draft",
        "catalog_visibility": "visible",
        "description": DESCRIPTION_HTML,
        "short_description": SHORT_DESCRIPTION,
        "sku": SKU,
        "virtual": True,
        "downloadable": True,
        "downloads": [
            {
                "id": str(uuid.uuid4()),
                "name": "amflags-1.0.0",
                "file": zip_url,
            }
        ],
        "download_limit": -1,
        "download_expiry": -1,
        "tax_status": "taxable",
        "manage_stock": False,
        "categories": [{"id": 714}],
        "tags": [
            {"name": "prestashop"},
            {"name": "module prestashop"},
            {"name": "module"},
            {"name": "badges produits"},
            {"name": "étiquettes produits"},
        ],
        "images": [{"id": i} for i in image_ids],
        "attributes": [
            {
                "id": 2,
                "position": 0,
                "visible": True,
                "variation": True,
                "options": [v[0] for v in VARIATIONS],
            },
            {
                "id": 3,
                "position": 1,
                "visible": False,
                "variation": False,
                "options": ["Conversions"],
            },
        ],
        "default_attributes": [
            {"id": 2, "name": "Durée du SAV et des mises à jour", "option": "6 mois"},
        ],
        "meta_data": [
            {"key": "_yoast_wpseo_title", "value": YOAST_TITLE},
            {"key": "_yoast_wpseo_metadesc", "value": YOAST_METADESC},
            {"key": "_yoast_wpseo_focuskw", "value": YOAST_FOCUS},
            {"key": "_yoast_wpseo_primary_product_cat", "value": "714"},
            {"key": "_amlicence_lm_enabled", "value": "yes"},
            {"key": "_amlicence_lm_activation_slots", "value": "1"},
            {"key": "_amlicence_lm_expiry_months", "value": "0"},
        ],
    }

    product = post_json(base, user, pwd, "/wp-json/wc/v3/products", product_payload)
    product_id = int(product["id"])
    print(f"Produit créé: id={product_id}")

    print("Création des variations…")
    for option, price in VARIATIONS:
        var_payload = {
            "regular_price": price,
            "virtual": True,
            "downloadable": True,
            "downloads": product_payload["downloads"],
            "attributes": [
                {
                    "id": 2,
                    "name": "Durée du SAV et des mises à jour",
                    "option": option,
                }
            ],
            "meta_data": [
                {"key": "_amlicence_lm_enabled", "value": "yes"},
                {"key": "_amlicence_lm_activation_slots", "value": "1"},
                {"key": "_amlicence_lm_expiry_months", "value": "0"},
            ],
        }
        var = post_json(
            base,
            user,
            pwd,
            f"/wp-json/wc/v3/products/{product_id}/variations",
            var_payload,
        )
        print(f"  variation {var['id']}: {option} → {price} €")

    print("Mise à jour ACF (meta WooCommerce) et image à la une…")
    changelog = (
        "<h3>Version 1.0.0 — 20/05/2026</h3><ul>"
        "<li>Première version commerciale</li>"
        "<li>CRUD badges multilingues avec couleurs</li>"
        "<li>Assignation sur fiche produit</li>"
        "<li>Affichage sur miniatures via hook natif</li></ul>"
    )
    put_json(
        base,
        user,
        pwd,
        f"/wp-json/wc/v3/products/{product_id}",
        {
            "meta_data": [
                {"key": "cms", "value": ["PrestaShop"]},
                {"key": "versions", "value": "v1.7 à v8 toutes versions"},
                {"key": "langues_du_module", "value": ["FR", "EN"]},
                {"key": "derniere_mise_a_jour", "value": "20260520"},
                {"key": "version_du_module__theme", "value": "V1.0.0"},
                {"key": "niveau", "value": "Simple d'utilisation"},
                {"key": "documentation", "value": "1"},
                {"key": "changelog", "value": changelog},
            ]
        },
    )
    try:
        put_json(
            base,
            user,
            pwd,
            f"/wp-json/wp/v2/product/{product_id}",
            {"excerpt": SHORT_DESCRIPTION, "featured_media": featured_id},
        )
        print("  excerpt + featured_media OK")
    except RuntimeError as e:
        print(f"  Avertissement WP: {e}")

    edit_url = f"{base}/wp-admin/post.php?post={product_id}&action=edit"
    print("\n--- Terminé ---")
    print(f"ID produit : {product_id}")
    print(f"Slug       : {SLUG}")
    print(f"Édition BO : {edit_url}")
    print(f"Aperçu     : {base}/produit/{SLUG}/?preview=true")


if __name__ == "__main__":
    main()
