Metadata-Version: 2.4
Name: flowyml-notebook
Version: 1.2.0
Summary: Production-grade reactive notebook for FlowyML — the Jupyter replacement for ML pipelines
Project-URL: Homepage, https://github.com/UnicoLab/flowyml-notebook
Project-URL: Repository, https://github.com/UnicoLab/flowyml-notebook
Project-URL: Documentation, https://unicolab.github.io/flowyml-notebook/latest/
Project-URL: Changelog, https://github.com/UnicoLab/flowyml-notebook/blob/main/CHANGELOG.md
Project-URL: Bug Tracker, https://github.com/UnicoLab/flowyml-notebook/issues
Author-email: UnicoLab <support@unicolab.ai>
License: Apache-2.0
License-File: LICENSE
Keywords: dag,data-science,flowyml,jupyter-alternative,machine-learning,mlops,notebook,pipeline,reactive
Classifier: Development Status :: 3 - Alpha
Classifier: Framework :: Jupyter
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Scientific/Engineering :: Artificial Intelligence
Requires-Python: <4.0,>=3.10
Requires-Dist: fastapi>=0.100
Requires-Dist: flowyml>=1.8.0
Requires-Dist: httpx>=0.24
Requires-Dist: ipython>=8.0
Requires-Dist: numpy>=1.24
Requires-Dist: pandas>=2.0
Requires-Dist: pydantic>=2.0
Requires-Dist: python-multipart>=0.0.6
Requires-Dist: rich>=13.0
Requires-Dist: uvicorn[standard]>=0.23
Requires-Dist: websockets>=11.0
Provides-Extra: ai
Requires-Dist: google-generativeai>=0.3; extra == 'ai'
Requires-Dist: openai>=1.0; extra == 'ai'
Provides-Extra: all
Requires-Dist: duckdb>=0.9; extra == 'all'
Requires-Dist: google-generativeai>=0.3; extra == 'all'
Requires-Dist: mike>=2.0.0; extra == 'all'
Requires-Dist: mkdocs-material-extensions>=1.3.1; extra == 'all'
Requires-Dist: mkdocs-material>=9.4.0; extra == 'all'
Requires-Dist: mkdocs>=1.5.0; extra == 'all'
Requires-Dist: mkdocstrings[python]>=0.23.0; extra == 'all'
Requires-Dist: openai>=1.0; extra == 'all'
Requires-Dist: scikit-learn>=1.3; extra == 'all'
Requires-Dist: scipy>=1.11; extra == 'all'
Requires-Dist: sqlalchemy>=2.0; extra == 'all'
Provides-Extra: dev
Requires-Dist: pre-commit>=2.0.0; extra == 'dev'
Requires-Dist: pytest-cov>=4.0.0; extra == 'dev'
Requires-Dist: pytest-xdist>=3.5; extra == 'dev'
Requires-Dist: pytest>=7.0.0; extra == 'dev'
Requires-Dist: ruff>=0.1.0; extra == 'dev'
Provides-Extra: docs
Requires-Dist: mike>=2.0.0; extra == 'docs'
Requires-Dist: mkdocs-material-extensions>=1.3.1; extra == 'docs'
Requires-Dist: mkdocs-material>=9.4.0; extra == 'docs'
Requires-Dist: mkdocs>=1.5.0; extra == 'docs'
Requires-Dist: mkdocstrings[python]>=0.23.0; extra == 'docs'
Provides-Extra: exploration
Requires-Dist: scikit-learn>=1.3; extra == 'exploration'
Requires-Dist: scipy>=1.11; extra == 'exploration'
Provides-Extra: sql
Requires-Dist: duckdb>=0.9; extra == 'sql'
Requires-Dist: sqlalchemy>=2.0; extra == 'sql'
Description-Content-Type: text/markdown

# 🌊 FlowyML Notebook

<p align="center">
  <img src="assets/logo.png" width="350" alt="FlowyML Notebook Logo"/>
  <br>
  <em>The Reactive Notebook That Ships to Production</em>
  <br>
  <br>
  <a href="https://github.com/UnicoLab/flowyml-notebook/actions/workflows/UTESTS.yml"><img src="https://github.com/UnicoLab/flowyml-notebook/actions/workflows/UTESTS.yml/badge.svg" alt="Tests"></a>
  <a href="https://pypi.org/project/flowyml-notebook/"><img src="https://img.shields.io/pypi/v/flowyml-notebook" alt="PyPI Version"></a>
  <a href="https://www.python.org/downloads/"><img src="https://img.shields.io/badge/python-3.10+-blue.svg" alt="Python 3.10+"></a>
  <a href="LICENSE"><img src="https://img.shields.io/badge/license-Apache%202.0-blue.svg" alt="License"></a>
  <a href="https://unicolab.ai"><img src="https://img.shields.io/badge/UnicoLab-ai-red.svg" alt="UnicoLab"></a>
</p>

---

**FlowyML Notebook** is a **reactive, DAG-powered** notebook environment that replaces Jupyter for production ML workflows. Write pure Python cells, get **automatic dependency tracking**, and ship directly to pipelines, dashboards, and apps — without changing a single line of code.

<p align="center">
  <img src="docs/screenshots/notebook.png" alt="FlowyML Notebook — Full Editor View" width="100%"/>
  <br>
  <em>Reactive notebook editor with code cells, variable explorer, and full toolbar</em>
</p>

---

## 🚀 Why FlowyML Notebook?

| Feature | Jupyter | Deepnote | Marimo | **FlowyML Notebook** |
|---------|:-------:|:--------:|:------:|:--------------------:|
| **Reactive DAG Execution** | ❌ | ❌ | ✅ | ✅ |
| **Pure `.py` File Storage** | ❌ | ❌ | ✅ | ✅ |
| **Git-Native Collaboration** | ❌ | ⚠️ Cloud | ❌ | ✅ GitHub |
| **Pipeline Integration** | ❌ | ❌ | ❌ | ✅ FlowyML |
| **Reusable Recipes** | ❌ | ❌ | ❌ | ✅ |
| **One-Click Deploy** | ❌ | ⚠️ Cloud | ❌ | ✅ |
| **SQL First-Class** | ❌ | ✅ | ✅ | ✅ |
| **AI Assistant** | ❌ | ✅ | ❌ | ✅ |
| **Rich Data Explorer** | ❌ | ✅ | ✅ | ✅ |
| **App Mode** | ❌ | ❌ | ✅ | ✅ |
| **Self-Hosted** | ✅ | ❌ | ✅ | ✅ |

---

## ⚡ Quick Start

```bash
# Install the core package
pip install flowyml-notebook

# Or install with all ML & AI extensions
pip install "flowyml-notebook[all]"
```

```bash
fml-notebook dev    # 🔥 Hot-reload development mode
fml-notebook start  # 🚀 Production build
```

The browser opens automatically. You're ready to build.

---

## 🌟 Features

### 📊 Rich Data Exploration

Every DataFrame gets **automatic profiling** — statistics, distributions, correlations, quality checks, and ML-ready insights. No extra code needed.

<p align="center">
  <img src="docs/screenshots/pandas-display.png" alt="Data Exploration — Statistics" width="100%"/>
  <br>
  <em>Automatic DataFrame profiling with column statistics, type detection, and memory impact</em>
</p>

<p align="center">
  <img src="docs/screenshots/pandas-display2.png" alt="Data Exploration — Charts" width="100%"/>
  <br>
  <em>Interactive charts for every column — histograms, bar charts, and distribution analysis</em>
</p>

<p align="center">
  <img src="docs/screenshots/pangas-display3.png" alt="Data Exploration — Correlations" width="100%"/>
  <br>
  <em>Pearson correlation matrix with color-coded heatmap for quick feature analysis</em>
</p>

<p align="center">
  <img src="docs/screenshots/recommendations.png" alt="ML Insights — Recommendations" width="100%"/>
  <br>
  <em>Automated ML insights: outlier detection, scaling recommendations, and target variable suggestions</em>
</p>

---

### 🔄 Reactive DAG Engine

Cells are nodes in a **dependency graph**. Change a variable, and only dependent cells re-execute — automatically. Visualize the full pipeline with the built-in DAG view.

<p align="center">
  <img src="docs/screenshots/dag.png" alt="Pipeline DAG View" width="60%"/>
  <br>
  <em>Visual dependency graph showing data flow: imports → data_generation → analysis → exploration → summary</em>
</p>

---

### 🧾 Recipes — Reusable Code Templates

Stop rewriting boilerplate. **39 built-in recipes** across Core, Assets, Parallel, Observability, Evals, Data, ML, and Visualization categories. Drag into your notebook or click to insert.

<p align="center">
  <img src="docs/screenshots/recipies.png" alt="Recipes Panel" width="60%"/>
  <br>
  <em>Searchable recipe library with FlowyML Step, Pipeline, Conditional Branching, and more</em>
</p>

---

### 💬 Comments & Review

Collaborate directly in the notebook with **inline comments** and a review panel. Add notebook-level or cell-level annotations for team discussions.

<p align="center">
  <img src="docs/screenshots/comments.png" alt="Comments Panel" width="100%"/>
  <br>
  <em>Comments panel with threaded discussions, resolve/reply actions, and scatter plot output</em>
</p>

---

### 📄 Reports — One-Click Export

Generate beautiful **HTML or PDF reports** from your notebook. Optionally include source code cells alongside outputs. Preview in browser, then download.

<p align="center">
  <img src="docs/screenshots/reports.png" alt="Generate Report Dialog" width="50%"/>
  <br>
  <em>Report generation with HTML/PDF format selection, code inclusion toggle, and instant preview</em>
</p>

---

### 🌐 Publish as App

Turn any notebook into an **interactive web application** with one click. Choose layout (Linear, Grid, Tabs, Sidebar, Dashboard), theme, and cell visibility.

<p align="center">
  <img src="docs/screenshots/apps.png" alt="Publish as App Dialog" width="50%"/>
  <br>
  <em>Publish dialog with layout options, dark/light/auto theme, source code toggle, and per-cell visibility</em>
</p>

---

### 🚀 Production — Pipelines, Deploy & Assets

Ship notebooks directly to production. **Promote to pipeline**, deploy as API/Docker/Batch, track kernel assets (DataFrames, models), and connect to FlowyML infrastructure.

<table>
  <tr>
    <td width="50%" align="center">
      <img src="docs/screenshots/pipelines.png" alt="Pipelines Panel" width="100%"/>
      <br>
      <em>Pipeline promotion with quick actions and @step decorators</em>
    </td>
    <td width="50%" align="center">
      <img src="docs/screenshots/deploy.png" alt="Deploy Panel" width="100%"/>
      <br>
      <em>Deploy as API, Docker Container, or Batch Pipeline with infrastructure stacks</em>
    </td>
  </tr>
</table>

<p align="center">
  <img src="docs/screenshots/assets.png" alt="Assets Panel" width="50%"/>
  <br>
  <em>Kernel assets: tracked DataFrames with size, shape, and type metadata</em>
</p>

---

### 🤝 Git & Version Control

Full **GitHub integration** as the collaboration backend. Link a repository, branch, commit, and push — all from the notebook sidebar. No proprietary cloud needed.

<table>
  <tr>
    <td width="50%" align="center">
      <img src="docs/screenshots/github.png" alt="GitHub Integration" width="100%"/>
      <br>
      <em>Connect GitHub repository for team collaboration and versioning</em>
    </td>
    <td width="50%" align="center">
      <img src="docs/screenshots/snapshots.png" alt="History & Snapshots" width="100%"/>
      <br>
      <em>Save and browse notebook snapshots with cell-level diffs</em>
    </td>
  </tr>
</table>

---

### ⚙️ Environment & FlowyML Connection

Run **standalone** (Local Mode) or connect to a **FlowyML server** (Remote Mode) for experiment tracking, pipeline export, and deployment. Full runtime details at a glance.

<p align="center">
  <img src="docs/screenshots/flowy-connection.png" alt="Environment Panel" width="50%"/>
  <br>
  <em>Environment panel: Local/Remote connection, runtime info (Python 3.12, IPython, Reactive DAG engine)</em>
</p>

---

## 🛠️ CLI Reference

| Command | Description |
|---------|-------------|
| `fml-notebook dev` | 🔥 Launch with Vite hot reload |
| `fml-notebook start` | 🚀 Launch with production build |
| `fml-notebook run <file>` | ▶️ Execute a notebook headlessly |
| `fml-notebook export <file>` | 📦 Export as pipeline/HTML/PDF/Docker |
| `fml-notebook app <file>` | 🌐 Deploy as interactive web app |
| `fml-notebook list --server <URL>` | 📚 List notebooks on a server |

---

## 📚 Documentation

Visit **[FlowyML Notebook Docs](https://unicolab.github.io/flowyml-notebook/latest/)** for the complete guide:

- **[Getting Started](https://unicolab.github.io/flowyml-notebook/latest/getting-started)** — Install, launch, configure
- **[Features](https://unicolab.github.io/flowyml-notebook/latest/features)** — Complete feature inventory
- **[Architecture](https://unicolab.github.io/flowyml-notebook/latest/architecture)** — Reactive DAG engine internals
- **[Recipes](https://unicolab.github.io/flowyml-notebook/latest/recipes)** — Reusable cell templates
- **[Collaboration](https://unicolab.github.io/flowyml-notebook/latest/collaboration)** — GitHub-based team workflows
- **[Integration](https://unicolab.github.io/flowyml-notebook/latest/integration)** — FlowyML instance connections
- **[Data Exploration](https://unicolab.github.io/flowyml-notebook/latest/exploration)** — Rich DataFrame profiling
- **[API Reference](https://unicolab.github.io/flowyml-notebook/latest/api)** — CLI & Python API docs

---

## 🛠️ Development

```bash
git clone https://github.com/UnicoLab/flowyml-notebook.git
cd flowyml-notebook
make setup
make dev
```

| Target | Description |
|--------|-------------|
| `make setup` | 🔧 Install Python package + frontend deps |
| `make dev` | 🔥 Launch dev mode with hot reload |
| `make test` | 🧪 Run all tests |
| `make lint` | 🔍 Run Ruff linter |
| `make format` | ✨ Auto-format code |
| `make docs` | 📖 Build MkDocs documentation |
| `make docs-serve` | 👁️ Preview docs locally |
| `make pre-commit` | 🔒 Run pre-commit checks |
| `make release-dry-run` | 🏷️ Dry-run semantic release |
| `make clean` | 🧹 Remove build artifacts |

See [CONTRIBUTING.md](CONTRIBUTING.md) for the full contributor guide.

---

## 🤝 Community

- 📖 [Documentation](https://unicolab.github.io/flowyml-notebook/latest/)
- 🐛 [Bug Reports](https://github.com/UnicoLab/flowyml-notebook/issues)
- 💬 [Discussions](https://github.com/UnicoLab/flowyml-notebook/discussions)
- 📋 [Contributing Guide](CONTRIBUTING.md)
- 📜 [Changelog](CHANGELOG.md)
- 🔒 [Security Policy](SECURITY.md)
- 📝 [Code of Conduct](CODE_OF_CONDUCT.md)

---

## 📄 License

Licensed under the [Apache License 2.0](LICENSE).

<p align="center">
  <strong>Built with ❤️ by <a href="https://unicolab.ai">UnicoLab</a></strong>
</p>
