mirror of
https://github.com/thekiwismarthome/shopping-list-manager.git
synced 2026-05-01 11:46:30 +00:00
Update catalog_loader.py
This commit is contained in:
@@ -1 +1,61 @@
|
|||||||
|
|
||||||
|
"""Product catalog loader for Shopping List Manager."""
|
||||||
|
import json
|
||||||
|
import logging
|
||||||
|
import os
|
||||||
|
from typing import List, Dict, Any
|
||||||
|
|
||||||
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
def load_product_catalog(component_path: str, country_code: str = "NZ") -> List[Dict[str, Any]]:
|
||||||
|
"""Load product catalog from JSON file.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
component_path: Path to the component directory
|
||||||
|
country_code: Country code (e.g., 'NZ', 'AU', 'US')
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
List of product dictionaries
|
||||||
|
"""
|
||||||
|
# Try country-specific catalog first
|
||||||
|
if country_code:
|
||||||
|
country_file = os.path.join(
|
||||||
|
component_path, "data", f"products_catalog_{country_code.lower()}.json"
|
||||||
|
)
|
||||||
|
if os.path.exists(country_file):
|
||||||
|
catalog_file = country_file
|
||||||
|
_LOGGER.debug("Using country-specific product catalog: %s", country_code)
|
||||||
|
else:
|
||||||
|
_LOGGER.warning(
|
||||||
|
"No country-specific catalog found for %s",
|
||||||
|
country_code
|
||||||
|
)
|
||||||
|
return []
|
||||||
|
else:
|
||||||
|
return []
|
||||||
|
|
||||||
|
try:
|
||||||
|
with open(catalog_file, "r", encoding="utf-8") as f:
|
||||||
|
data = json.load(f)
|
||||||
|
|
||||||
|
_LOGGER.info(
|
||||||
|
"Loaded product catalog version %s for region %s",
|
||||||
|
data.get("version", "unknown"),
|
||||||
|
data.get("region", "default")
|
||||||
|
)
|
||||||
|
|
||||||
|
products = data.get("products", [])
|
||||||
|
_LOGGER.info("Loaded %d products from catalog", len(products))
|
||||||
|
|
||||||
|
return products
|
||||||
|
|
||||||
|
except FileNotFoundError:
|
||||||
|
_LOGGER.error("Product catalog file not found: %s", catalog_file)
|
||||||
|
return []
|
||||||
|
except json.JSONDecodeError as err:
|
||||||
|
_LOGGER.error("Failed to parse product catalog file: %s", err)
|
||||||
|
return []
|
||||||
|
except Exception as err:
|
||||||
|
_LOGGER.error("Unexpected error loading product catalog: %s", err)
|
||||||
|
return []
|
||||||
|
|||||||
Reference in New Issue
Block a user