Skip to main content

Shared frontend UI components for the SciTeX ecosystem

Project description

SciTeX UI (scitex-ui)

SciTeX

Full Documentation · uv pip install scitex-ui[all]

pypi python docs

tests cov


Problem and Solution

# Problem Solution
1 Every scitex workspace app duplicates panel-resize / design-tokens / React hooks -- drift + copy-paste Shared shell framework -- vanilla TS initShell as single source of truth; React usePanelResize / DataTable as optional app components; CSS design tokens shared via Django static
2 Live UI introspection means writing custom Playwright scripts -- common enough to deserve tooling MCP ui_inspect_element(selector) -- bbox, computed styles, text, attrs — for agent-driven UI debugging

Architecture

Each component ships with:

  • TypeScript source — framework-agnostic, vanilla DOM API
  • CSS styles — scoped via BEM-like class prefixes (stx-shell-*, stx-app-*)
  • Python metadata — version, file paths, descriptions
graph TB
    subgraph shell ["Shell (stx-shell-*) — Workspace Frame"]
        theme["ThemeProvider<br/>Light/Dark + Tokens"]
        appshell["AppShell<br/>Sidebar + Content"]
        statusbar["StatusBar<br/>L | C | R Sections"]
    end

    subgraph app ["App (stx-app-*) — In-App Components"]
        filebrowser["FileBrowser<br/>Tree Navigation"]
        pkgsidebar["PackageDocsSidebar<br/>Package Browser"]
    end

    base{{"BaseComponent<br/>Container + Events + Lifecycle"}}

    appshell -->|extends| base
    statusbar -->|extends| base
    filebrowser -->|extends| base
    pkgsidebar -->|extends| base

Figure 1. Component architecture. Shell components provide workspace framing (theme, layout, status bar). App components are reusable in-app widgets. All extend BaseComponent for shared container resolution, event dispatch, and lifecycle management.

Current Components

Category Component Prefix Description
Shell ThemeProvider stx-shell- Light/dark theme manager with semantic color tokens
Shell AppShell stx-shell- Workspace layout with collapsible sidebar and accent colors
Shell StatusBar stx-shell- Bottom status bar with left/center/right sections
App FileBrowser stx-app- Tree view for navigating file hierarchies
App PackageDocsSidebar stx-app- Navigable sidebar for Python package documentation

Table 1. Available UI components. Shell components provide workspace framing; App components are for in-app use. Each is registered in the Python metadata registry.

Installation

Requires Python >= 3.10.

pip install scitex-ui

Quick Start

Django Setup

Add scitex_ui to your INSTALLED_APPS:

INSTALLED_APPS = [
    # ...
    "scitex_ui",
]

Static assets are automatically discoverable by Django's AppDirectoriesFinder.

Python API

import scitex_ui

# List all registered components
for name in scitex_ui.list_components():
    meta = scitex_ui.get_component(name)
    print(f"{name} v{meta.version}{meta.description}")

# Get specific component metadata
sidebar = scitex_ui.get_component("package-docs-sidebar")
print(sidebar.ts_entry)   # TypeScript entry point
print(sidebar.css_file)   # CSS stylesheet path

TypeScript Usage

// Workspace shell
import { ThemeProvider } from "scitex_ui/ts/shell/theme-provider";
import { AppShell } from "scitex_ui/ts/shell/app-shell";
import { StatusBar } from "scitex_ui/ts/shell/status-bar";

const theme = new ThemeProvider();
const shell = new AppShell({
  container: "#app",
  accent: "writer",        // Preset accent color
  collapsible: true,
});
const statusBar = new StatusBar({ container: "#status" });

// In-app components
import { FileBrowser } from "scitex_ui/ts/app/file-browser";

const browser = new FileBrowser({
  container: "#files",
  onFileSelect: (node) => console.log(node.path),
});

Three Interfaces

Python API
Function Description
list_components() List all registered component names
get_component(name) Get metadata for a registered component
register_component(name, metadata) Register a new component
CLI Commands (planned)
scitex-ui --help              # Show help
scitex-ui list-components     # List registered components
scitex-ui version             # Show version
MCP Server (planned)

MCP (Model Context Protocol) tools for AI agents to discover and query available UI components.

Demo

The package ships runnable example pages under examples/ showing each component category in isolation:

Example What it shows
01_list_components.py Iterates the registry: prints every Shell + App component with its version, TS entry, and CSS path
02_workspace_components.py Mounts ThemeProvider + AppShell + StatusBar as a minimal workspace frame
flowchart LR
    subgraph Page ["Browser Page (#app)"]
        Theme[ThemeProvider<br/>tokens injected]
        Shell[AppShell<br/>sidebar + content]
        Bar[StatusBar<br/>L | C | R]
        FB[FileBrowser<br/>tree view]
    end
    Static[Django static<br/>scitex_ui/static/] --> Page
    Reg[(Python registry<br/>get_component)] --> Static
    style Theme fill:#4a90d9,stroke:#2c3e50,color:#fff
    style Shell fill:#4a90d9,stroke:#2c3e50,color:#fff
    style Bar  fill:#4a90d9,stroke:#2c3e50,color:#fff
    style FB   fill:#27ae60,stroke:#2c3e50,color:#fff

Figure 2. Demo. Components are discovered via the Python registry, then mounted in TypeScript against DOM containers. CSS is shipped as Django static assets.

# List every registered component
python examples/01_list_components.py

# Run the workspace-shell example (Django dev server)
python examples/02_workspace_components.py
# → open http://localhost:8000/ to see ThemeProvider + AppShell + StatusBar

Role in SciTeX Ecosystem

scitex-ui is the shared TypeScript + CSS component library for all SciTeX web applications. It provides the visual building blocks that maintain consistency across the cloud dashboard, workspace editor, and third-party apps.

scitex (orchestrator, templates, CLI, MCP)
  |-- scitex-app              -- runtime SDK for apps
  |-- scitex-ui (this package) -- TS + CSS component library
  |     |-- Shell (stx-shell-*) -- ThemeProvider, AppShell, StatusBar
  |     |-- App (stx-app-*)     -- FileBrowser, PackageDocsSidebar
  |     +-- Design tokens        -- spacing, typography, z-index, colors
  +-- figrecipe                -- reference app (consumes scitex-ui)

What this package owns:

  • Shell components (stx-shell-*): ThemeProvider, AppShell, StatusBar
  • App components (stx-app-*): FileBrowser, PackageDocsSidebar
  • Design token CSS: theme colors, spacing, typography, z-index primitives

What this package does NOT own:

  • Backend/runtime SDK -- see scitex-app
  • Orchestration, templates, CLI -- see scitex
  • App-specific logic -- each app (e.g., figrecipe) owns its own views

Part of SciTeX

scitex-ui is part of SciTeX. Install via the umbrella with pip install scitex[ui] to use as scitex.ui (Python) or scitex ui ... (CLI).

Four Freedoms for Research

  1. The freedom to run your research anywhere — your machine, your terms.
  2. The freedom to study how every step works — from raw data to final manuscript.
  3. The freedom to redistribute your workflows, not just your papers.
  4. The freedom to modify any module and share improvements with the community.

AGPL-3.0 — because we believe research infrastructure deserves the same freedoms as the software it runs on.


SciTeX

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

scitex_ui-0.5.0.tar.gz (8.0 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

scitex_ui-0.5.0-py3-none-any.whl (7.9 MB view details)

Uploaded Python 3

File details

Details for the file scitex_ui-0.5.0.tar.gz.

File metadata

  • Download URL: scitex_ui-0.5.0.tar.gz
  • Upload date:
  • Size: 8.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for scitex_ui-0.5.0.tar.gz
Algorithm Hash digest
SHA256 e37aec2486ad6dcadabeb7fa0304281f25c5a79cffd4460fba8b49a675f4d27e
MD5 be21d9b02ff121d181178915891a2f1b
BLAKE2b-256 1e0cb2cb65f451a7684f6a8643dfbeedc7d27194009023c33817c14c8436615d

See more details on using hashes here.

Provenance

The following attestation bundles were made for scitex_ui-0.5.0.tar.gz:

Publisher: pypi-publish-and-github-release-on-tag.yml on ywatanabe1989/scitex-ui

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file scitex_ui-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: scitex_ui-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 7.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for scitex_ui-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4d3f16dc823395e62dbd70f42739debfb58826f3681dbbdaf46ccf60237fda79
MD5 a52724a92bf8f0ff964c4cca2824b3d6
BLAKE2b-256 df5599fc6db15dded9c0dbcac35c10fdf565401ad3d712075eb0d1994fe22493

See more details on using hashes here.

Provenance

The following attestation bundles were made for scitex_ui-0.5.0-py3-none-any.whl:

Publisher: pypi-publish-and-github-release-on-tag.yml on ywatanabe1989/scitex-ui

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page