Skip to main content

A compact, theme-aware step progress bar component for FastHTML multi-step workflows.

Project description

cjm-fasthtml-step-progress

Install

pip install cjm_fasthtml_step_progress

Project Structure

nbs/
├── components/ (1)
│   └── progress_bar.ipynb  # Compact segmented progress bar for multi-step workflows.
└── core/ (2)
    ├── config.ipynb  # Configuration dataclass for the step progress bar component.
    └── models.ipynb  # Data models for the step progress bar component.

Total: 3 notebooks across 2 directories

Module Dependencies

graph LR
    components_progress_bar[components.progress_bar<br/>Progress Bar]
    core_config[core.config<br/>Config]
    core_models[core.models<br/>Models]

    components_progress_bar --> core_models
    components_progress_bar --> core_config

2 cross-module dependencies detected

CLI Reference

No CLI commands found in this project.

Module Overview

Detailed documentation for each module in the project:

Config (config.ipynb)

Configuration dataclass for the step progress bar component.

Import

from cjm_fasthtml_step_progress.core.config import (
    StepProgressConfig
)

Classes

@dataclass
class StepProgressConfig:
    "Rendering configuration for the step progress bar."
    
    height: int = 3  # Tailwind h-{value} scale (h-3 = 12px)
    track_bg: str = 'base_300'  # bg_dui attribute for unfilled track
    fill_bg: str = 'primary'  # bg_dui attribute for completed segments
    current_opacity: int = 60  # opacity % for current step segment
    border_radius: str = 'field'  # border_radius attribute (field/box/selector)
    separator_color: str = 'base_100'  # border_dui attribute for segment dividers
    show_tooltips: bool = True  # show step name tooltips on hover
    tooltip_position: str = 'top'  # tooltip_placement attribute (top/bottom/left/right)
    id: str = 'step-progress'  # HTML id for the progress bar container

Models (models.ipynb)

Data models for the step progress bar component.

Import

from cjm_fasthtml_step_progress.core.models import (
    StepInfo
)

Classes

@dataclass
class StepInfo:
    "Describes a single step in a multi-step workflow."
    
    title: str  # step name shown in tooltip on hover

Progress Bar (progress_bar.ipynb)

Compact segmented progress bar for multi-step workflows.

Import

from cjm_fasthtml_step_progress.components.progress_bar import (
    render_step_progress,
    create_step_progress_renderer
)

Functions

def _build_segment_fill_cls(
    idx: int,          # segment index
    current: int,      # current step index
    config: StepProgressConfig,  # rendering config
) -> str:              # combined CSS class string for the fill div
    "Build CSS classes for a segment's inner fill div."
def _build_segment(
    step: StepInfo,    # step descriptor
    idx: int,          # segment index
    current: int,      # current step index
    config: StepProgressConfig,  # rendering config
) -> FT:               # FastHTML element for one segment
    "Build a single progress bar segment."
def render_step_progress(
    steps: Sequence[StepInfo],              # ordered step definitions
    current_index: int,                     # 0-based index of the current step
    config: Optional[StepProgressConfig] = None,  # rendering config (defaults used if None)
) -> FT:                                    # the progress bar element
    "Render a compact segmented progress bar showing position in a multi-step workflow."
def create_step_progress_renderer(
    config: Optional[StepProgressConfig] = None,  # rendering config
) -> Callable:  # callable with signature (steps, current_index) -> FT
    "Create a progress renderer callback for StepFlow integration."

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

cjm_fasthtml_step_progress-0.0.4.tar.gz (9.9 kB view details)

Uploaded Source

Built Distribution

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

cjm_fasthtml_step_progress-0.0.4-py3-none-any.whl (11.4 kB view details)

Uploaded Python 3

File details

Details for the file cjm_fasthtml_step_progress-0.0.4.tar.gz.

File metadata

File hashes

Hashes for cjm_fasthtml_step_progress-0.0.4.tar.gz
Algorithm Hash digest
SHA256 92d63b6c5481ace4dc74c2a50e3d8e03da16d158a69797821f1913c34f79a359
MD5 52792f84bebb767c7ead268ea53ee897
BLAKE2b-256 374d4254635cb6f3bc359785250245838a88a5edcaf8fca944efb1c1c7b16bb8

See more details on using hashes here.

File details

Details for the file cjm_fasthtml_step_progress-0.0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for cjm_fasthtml_step_progress-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b0cb078241e99d28264290cfd4a1364f71554bbaa6b56b3b024db23a0833573c
MD5 4860713be189e7c3e197c0e7dbf38314
BLAKE2b-256 283a4ca6c49d13e6a00a5a0f84d17003a9bd2d7faa0e3b0cf5fe86cedeeb8357

See more details on using hashes here.

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