| ```mermaid | |
| sequenceDiagram | |
| participant UI as π§© +layout.svelte | |
| participant serverStore as ποΈ serverStore | |
| participant PropsSvc as βοΈ PropsService | |
| participant API as π llama-server | |
| Note over serverStore: State:<br/>props: ApiLlamaCppServerProps | null<br/>loading, error<br/>role: ServerRole | null (MODEL | ROUTER)<br/>fetchPromise (deduplication) | |
| %% βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| Note over UI,API: π INITIALIZATION | |
| %% βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| UI->>serverStore: fetch() | |
| activate serverStore | |
| alt fetchPromise exists (already fetching) | |
| serverStore-->>UI: return fetchPromise | |
| Note right of serverStore: Deduplicate concurrent calls | |
| end | |
| serverStore->>serverStore: loading = true | |
| serverStore->>serverStore: fetchPromise = new Promise() | |
| serverStore->>PropsSvc: fetch() | |
| PropsSvc->>API: GET /props | |
| API-->>PropsSvc: ApiLlamaCppServerProps | |
| Note right of API: {role, model_path, model_alias,<br/>modalities, default_generation_settings, ...} | |
| PropsSvc-->>serverStore: props | |
| serverStore->>serverStore: props = $state(data) | |
| serverStore->>serverStore: detectRole(props) | |
| Note right of serverStore: role = props.role === "router"<br/> ? ServerRole.ROUTER<br/> : ServerRole.MODEL | |
| serverStore->>serverStore: loading = false | |
| serverStore->>serverStore: fetchPromise = null | |
| deactivate serverStore | |
| %% βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| Note over UI,API: π COMPUTED GETTERS | |
| %% βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| Note over serverStore: Getters from props: | |
| rect rgb(240, 255, 240) | |
| Note over serverStore: defaultParams<br/>β props.default_generation_settings.params<br/>(temperature, top_p, top_k, etc.) | |
| end | |
| rect rgb(240, 255, 240) | |
| Note over serverStore: contextSize<br/>β props.default_generation_settings.n_ctx | |
| end | |
| rect rgb(255, 240, 240) | |
| Note over serverStore: isRouterMode<br/>β role === ServerRole.ROUTER | |
| end | |
| rect rgb(255, 240, 240) | |
| Note over serverStore: isModelMode<br/>β role === ServerRole.MODEL | |
| end | |
| %% βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| Note over UI,API: π RELATIONSHIPS | |
| %% βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| Note over serverStore: Used by: | |
| Note right of serverStore: - modelsStore: role detection, MODEL mode modalities<br/>- settingsStore: syncWithServerDefaults (defaultParams)<br/>- chatStore: contextSize for processing state<br/>- UI components: isRouterMode for conditional rendering | |
| %% βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| Note over UI,API: β ERROR HANDLING | |
| %% βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ | |
| Note over serverStore: getErrorMessage(): string | null<br/>Returns formatted error for UI display | |
| Note over serverStore: clear(): void<br/>Resets all state (props, error, loading, role) | |
| ``` | |