Skip to main content

Un motor de concentración gamificado para la terminal.

Project description

🪴 Zen Focus: Gamificación y Enfoque Profundo (Deep Work)

PyPI version Open In Colab

Zen Focus es una librería de Python orientada a proteger la atención de desarrolladores, científicos de datos y estudiantes.

Cuando ejecutamos procesos de alta carga computacional (limpieza de DataFrames gigantes, entrenamiento de modelos, simulaciones estadísticas), los tiempos de espera nos hacen perder nuestro estado de Deep Work al abrir redes sociales. Zen Focus resuelve esto mediante gamificación visual en la terminal y un escudo de red a nivel del sistema operativo.


✨ Características Principales

  1. Gamificación Visual (POO): Arte ASCII interactivo que evoluciona en 5 fases proporcionalmente al avance de tu código o tiempo de sesión.
  2. Arquitectura Extensible: Motor basado en clases abstractas (TemaBase). Incluye temas predeterminados: PlantaFlor, Cohete, Edificio y Bebida.
  3. Escudo de Red (Context Manager): Modifica dinámicamente el archivo hosts (/etc/hosts o System32/drivers/etc/hosts) para bloquear sitios web distractores y restaura la conexión de forma segura al finalizar o en caso de error.
  4. Interfaz de Terminal (CLI): Integración nativa con rich para paneles en vivo que no inundan la consola.
  5. Decorador @con_progreso: Gamifica cualquier función Python sin modificar su código interno. El tema evoluciona mientras la función se ejecuta.
  6. Widgets Interactivos: Explora los temas en Jupyter Notebooks y Google Colab con controles interactivos de sliders y botones.

🚀 Instalación

Instala la última versión estable directamente desde PyPI:

pip install zen-focus rich

Para probar de inmediato sin configuraciones locales, haz clic en el botón de Open in Colab en la parte superior.


📖 Uso Básico

La librería puede usarse de varias maneras: integrada en scripts, como decorador, en sesiones dedicadas o en notebooks interactivos.

1. Gamificar un Script Largo

Importa un tema y hazlo evolucionar mientras tu código trabaja:

from zen_focus.temas import PlantaFlor
import time

mi_planta = PlantaFlor(nombre="Girasol Analítico")

# Simulamos el procesamiento de datos por lotes
for lote in range(5):
    time.sleep(1) # Reemplaza con tu lógica de código pesada
    mi_planta.evolucionar()
    print(mi_planta.renderizar())

2. Decorador @con_progreso

Gamifica funciones automáticamente con un simple decorador. Perfecto para entrenamientos de ML, procesamiento de datos y análisis científicos:

from zen_focus.decoradores import con_progreso
from zen_focus.temas import Cohete

@con_progreso(tema=Cohete("Análisis de datos"), pasos=3)
def pipeline_datos(df):
    df = df.dropna()           # Paso 1
    yield
    df = df[df['valor'] > 0]   # Paso 2
    yield
    resultado = df.sum()       # Paso 3
    return resultado

resultado = pipeline_datos(mi_df)

Sin yield (avance automático en background):

@con_progreso(tema=PlantaFlor("Entrenamiento"), retardo=1.0)
def entrenar_modelo(X_train, y_train):
    return modelo.fit(X_train, y_train)

3. Modo Deep Work (Con bloqueo de sitios)

Utiliza la clase SesionZen junto con el Escudo para bloquear distracciones. Nota: Este script requiere ser ejecutado con permisos de administrador (sudo) para modificar las rutas de red.

from zen_focus.motor import SesionZen
from zen_focus.escudo import Escudo
from zen_focus.temas import Cohete

# 1. Definimos las distracciones
distracciones = ["twitter.com", "instagram.com", "youtube.com"]

# 2. El Context Manager garantiza que el internet regrese a la normalidad
with Escudo(bloquear=distracciones) as mi_escudo:
    
    # 3. Configuramos la sesión y el tema
    mision = Cohete(mision="Apolo 11")
    sesion = SesionZen(minutos=25, escudo=mi_escudo, tema=mision)
    
    # 4. ¡Iniciamos el motor en la terminal!
    sesion.iniciar()

4. Widget Interactivo (Jupyter / Colab)

Explora y controla los temas interactivamente en notebooks:

from zen_focus.widgets import TemaWidget
from zen_focus.temas import PlantaFlor

# Crear y mostrar el widget
widget = TemaWidget(PlantaFlor("Mi Planta"))
widget.mostrar()

El widget incluye:

  • Slider de evolución: Controla el nivel del tema (1 a n)
  • Botón Evolucionar: Avanza un nivel (+)
  • Botón Penalizar: Retrocede un nivel (−)
  • Botón Reset: Reinicia a nivel 1
  • Vista en vivo: Arte ASCII actualizado dinámicamente

Requiere: pip install ipywidgets


🐳 Ejecución Local con Docker

Si deseas probar la interfaz completa y correr los tests automatizados en un entorno aislado sin modificar los permisos de red de tu máquina anfitriona, el proyecto incluye una configuración de Docker lista para usar.

Clona este repositorio y ejecuta:

docker compose up --build

Esto instalará la librería en modo editable, ejecutará las pruebas con pytest o levantará el panel interactivo directamente en el contenedor.


🏗️ Arquitectura y Extensión

Si deseas crear tus propios temas, simplemente hereda de la clase abstracta TemaBase:

from zen_focus.base import TemaBase

class MiTemaCustom(TemaBase):
    def evolucionar(self):
        ...
    def penalizar(self):
        ...
    def renderizar(self) -> str:
        ...

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

zen_focus-0.2.1.tar.gz (17.3 kB view details)

Uploaded Source

Built Distribution

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

zen_focus-0.2.1-py3-none-any.whl (19.1 kB view details)

Uploaded Python 3

File details

Details for the file zen_focus-0.2.1.tar.gz.

File metadata

  • Download URL: zen_focus-0.2.1.tar.gz
  • Upload date:
  • Size: 17.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for zen_focus-0.2.1.tar.gz
Algorithm Hash digest
SHA256 58349e44d431715de8cc32e0a46a4f4c03cc2f26c835405bdbff8aad83623c7c
MD5 f9f1caa368e410650ee7ee04ed458e2d
BLAKE2b-256 8d9cfd5ed4c4f1ca50d8408e0aad1c9f0f9cb8e58ba575d2c04b63e9f3543469

See more details on using hashes here.

File details

Details for the file zen_focus-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: zen_focus-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 19.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for zen_focus-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8f1e1e0d390f33d84802a71a7b7115d521a37d64f0b78023c6bc34e7cdc3674e
MD5 8be04dcf4774350f7de07103105475bd
BLAKE2b-256 6675d9685b868804c2318074e8265a2c404e14890fda4e5438a076c45b3c924b

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