search.py 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. """
  4. UI/UX Pro Max Search - BM25 search engine for UI/UX style guides
  5. Usage: python search.py "<query>" [--domain <domain>] [--stack <stack>] [--max-results 3]
  6. python search.py "<query>" --design-system [-p "Project Name"]
  7. Domains: style, prompt, color, chart, landing, product, ux, typography
  8. Stacks: html-tailwind, react, nextjs
  9. """
  10. import argparse
  11. from core import CSV_CONFIG, AVAILABLE_STACKS, MAX_RESULTS, search, search_stack
  12. from design_system import generate_design_system
  13. def format_output(result):
  14. """Format results for Claude consumption (token-optimized)"""
  15. if "error" in result:
  16. return f"Error: {result['error']}"
  17. output = []
  18. if result.get("stack"):
  19. output.append(f"## UI Pro Max Stack Guidelines")
  20. output.append(f"**Stack:** {result['stack']} | **Query:** {result['query']}")
  21. else:
  22. output.append(f"## UI Pro Max Search Results")
  23. output.append(f"**Domain:** {result['domain']} | **Query:** {result['query']}")
  24. output.append(f"**Source:** {result['file']} | **Found:** {result['count']} results\n")
  25. for i, row in enumerate(result['results'], 1):
  26. output.append(f"### Result {i}")
  27. for key, value in row.items():
  28. value_str = str(value)
  29. if len(value_str) > 300:
  30. value_str = value_str[:300] + "..."
  31. output.append(f"- **{key}:** {value_str}")
  32. output.append("")
  33. return "\n".join(output)
  34. if __name__ == "__main__":
  35. parser = argparse.ArgumentParser(description="UI Pro Max Search")
  36. parser.add_argument("query", help="Search query")
  37. parser.add_argument("--domain", "-d", choices=list(CSV_CONFIG.keys()), help="Search domain")
  38. parser.add_argument("--stack", "-s", choices=AVAILABLE_STACKS, help="Stack-specific search (html-tailwind, react, nextjs)")
  39. parser.add_argument("--max-results", "-n", type=int, default=MAX_RESULTS, help="Max results (default: 3)")
  40. parser.add_argument("--json", action="store_true", help="Output as JSON")
  41. # Design system generation
  42. parser.add_argument("--design-system", "-ds", action="store_true", help="Generate complete design system recommendation")
  43. parser.add_argument("--project-name", "-p", type=str, default=None, help="Project name for design system output")
  44. parser.add_argument("--format", "-f", choices=["ascii", "markdown"], default="ascii", help="Output format for design system")
  45. args = parser.parse_args()
  46. # Design system takes priority
  47. if args.design_system:
  48. result = generate_design_system(args.query, args.project_name, args.format)
  49. print(result)
  50. # Stack search
  51. elif args.stack:
  52. result = search_stack(args.query, args.stack, args.max_results)
  53. if args.json:
  54. import json
  55. print(json.dumps(result, indent=2, ensure_ascii=False))
  56. else:
  57. print(format_output(result))
  58. # Domain search
  59. else:
  60. result = search(args.query, args.domain, args.max_results)
  61. if args.json:
  62. import json
  63. print(json.dumps(result, indent=2, ensure_ascii=False))
  64. else:
  65. print(format_output(result))