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.5.tar.gz (17.5 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.5-py3-none-any.whl (19.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: zen_focus-0.2.5.tar.gz
  • Upload date:
  • Size: 17.5 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.5.tar.gz
Algorithm Hash digest
SHA256 225c74b4f140ed77740a2bc5e675838297cb95c69e2b6932d64c7d61db7376bb
MD5 e1a49fa362a86f8c0809bd94c3990cd7
BLAKE2b-256 402ad16eaf38a65f7a8ffa61186edac2774b86c26836be1a5ea1864099f5daf1

See more details on using hashes here.

File details

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

File metadata

  • Download URL: zen_focus-0.2.5-py3-none-any.whl
  • Upload date:
  • Size: 19.3 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.5-py3-none-any.whl
Algorithm Hash digest
SHA256 88eade8d588a295ab5f58a0022e1343eeae331aa980545403a5c026b6d075acb
MD5 84506b912fe26901668b9eb6f4b71d9d
BLAKE2b-256 bfef8e2f583fe606489efed2856de371eb1cb44cfaa56c402aff2167a00f7ac3

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