Replace QWebEngineView-based start page with a rich native Qt panel that
fetches items directly from the Silo REST API. QWebEngineView is not
available on conda-forge for Qt6.
Start panel features:
- Database Items list with search (from SiloClient.list_items)
- Recent Files list from FreeCAD preferences
- Real-time Activity Feed via SSE (SiloEventListener)
- Context menu: Open in Create, Open in Browser, Copy Part Number
- Open in Browser button (QDesktopServices)
- Catppuccin Mocha dark theme styling
URL scheme support:
- handle_kindred_url() function for kindred://item/{part_number} URLs
- Startup hook in InitGui.py for cold-start URL arguments
Closes #167
98 lines
2.9 KiB
Python
98 lines
2.9 KiB
Python
"""Kindred Silo Workbench - Item database integration for Kindred Create."""
|
|
|
|
import os
|
|
|
|
import FreeCAD
|
|
import FreeCADGui
|
|
|
|
FreeCAD.Console.PrintMessage("Kindred Silo InitGui.py loading...\n")
|
|
|
|
|
|
class SiloWorkbench(FreeCADGui.Workbench):
|
|
"""Kindred Silo workbench for item database integration."""
|
|
|
|
MenuText = "Kindred Silo"
|
|
ToolTip = "Item database and part management for Kindred Create"
|
|
Icon = ""
|
|
|
|
def __init__(self):
|
|
# Resolve icon relative to this file so it works regardless of install location
|
|
icon_path = os.path.join(
|
|
os.path.dirname(os.path.abspath(__file__)), "resources", "icons", "silo.svg"
|
|
)
|
|
if os.path.exists(icon_path):
|
|
self.__class__.Icon = icon_path
|
|
|
|
def Initialize(self):
|
|
"""Called when workbench is first activated."""
|
|
import silo_commands
|
|
|
|
# Register Silo as a file origin in the unified origin system
|
|
try:
|
|
import silo_origin
|
|
|
|
silo_origin.register_silo_origin()
|
|
except Exception as e:
|
|
FreeCAD.Console.PrintWarning(f"Could not register Silo origin: {e}\n")
|
|
|
|
# Silo menu provides admin/management commands.
|
|
# File operations (New/Open/Save) are handled by the standard File
|
|
# toolbar via the origin system -- no separate Silo toolbar needed.
|
|
self.menu_commands = [
|
|
"Silo_Info",
|
|
"Silo_BOM",
|
|
"Silo_TagProjects",
|
|
"Silo_SetStatus",
|
|
"Silo_Rollback",
|
|
"Separator",
|
|
"Silo_Settings",
|
|
"Silo_Auth",
|
|
"Silo_StartPanel",
|
|
"Silo_Diag",
|
|
]
|
|
|
|
self.appendMenu("Silo", self.menu_commands)
|
|
|
|
def Activated(self):
|
|
"""Called when workbench is activated."""
|
|
FreeCAD.Console.PrintMessage("Kindred Silo workbench activated\n")
|
|
FreeCADGui.runCommand("Silo_StartPanel", 0)
|
|
|
|
def Deactivated(self):
|
|
pass
|
|
|
|
def GetClassName(self):
|
|
return "Gui::PythonWorkbench"
|
|
|
|
|
|
FreeCADGui.addWorkbench(SiloWorkbench())
|
|
FreeCAD.Console.PrintMessage("Silo workbench registered\n")
|
|
|
|
# Override the Start page with Silo-aware version (must happen before
|
|
# the C++ StartLauncher fires at ~100ms after GUI init)
|
|
try:
|
|
import silo_start
|
|
|
|
silo_start.register()
|
|
except Exception as e:
|
|
FreeCAD.Console.PrintWarning(f"Silo Start page override failed: {e}\n")
|
|
|
|
|
|
# Handle kindred:// URLs passed as command-line arguments on cold start.
|
|
# Delayed to run after the GUI is fully initialised and the Silo addon has
|
|
# loaded its client/sync objects.
|
|
def _handle_startup_urls():
|
|
"""Process any kindred:// URLs passed as command-line arguments."""
|
|
import sys
|
|
|
|
from silo_commands import handle_kindred_url
|
|
|
|
for arg in sys.argv[1:]:
|
|
if arg.startswith("kindred://"):
|
|
handle_kindred_url(arg)
|
|
|
|
|
|
from PySide import QtCore
|
|
|
|
QtCore.QTimer.singleShot(500, _handle_startup_urls)
|