Skip to main content

Japper

Project description

logo

Japper: A framework for building Jupyter-based web applications

Japper is a framework for building Jupyter-based web applications. It is designed to be a lightweight, flexible, and extensible framework that can be used to build a wide range of web applications.

Note: This project is still in the early stages of development, and the documentation is a work in progress. Please check back later for updates.

Why Japper?

Problems with Jupyter-based web applications development

Jupyter is a popular open-source web application that provides a rich set of tools for building interactive web applications. However, building Jupyter-based web applications can be challenging for several reasons:

  • Time-consuming setup and configuration
    • Setting up a development environment for Jupyter-based web applications can be time-consuming and error-prone.
    • Managing dependencies and environment can be difficult, especially when working with multiple projects.
    • Test and deployment can be complex.
  • Limited frontend capabilities and extensibility of ipywidgets
    • Jupyter provides a rich set of tools for building interactive web applications, but it has limited frontend capabilities and extensibility.
    • Building custom components and plugins can be challenging.
  • Lack of debugging and error handling
    • Jupyter provides limited support for debugging and error handling, making it difficult to diagnose and fix issues.
  • Lack of architectural guidance
    • There is no architectural guidance, making it difficult to build scalable and maintainable web applications.

Solutions provided by Japper

Japper is a framework for building Jupyter-based web applications easily and quickly. Here are some of the key features:

  • Command-line interface for creating and managing Japper projects
  • Create a new Japper project with pre-configured templates to get started quickly
  • Manage dependencies and environment with a simple configuration file
  • Build and run development and production versions using Docker
  • Deploy to Docker registry or Kubernetes with a single command
  • Automatically generate documentation for your Japper project
  • Vue.js-based frontend for building interactive web applications utilizing ipyvuetify
    • Provide a rich set of components and utilities for building web applications
    • Support for custom components and plugins
  • Improved debugging and error handling
    • Support for logging and error handling
  • Guided Model-View-Presenter (MVP) architectural pattern
    • Support for building scalable and maintainable web applications
    • Support for building reusable components and plugins

Getting started

To get started with Japper, you can install it using pip:

pip install japper

Note that Japper currently support Linux and MacOS only.

Once installed, you can run japper commands from the command line.

japper

Japper Forge

Japper Forge is a web-based tool that allows you to create and manage Japper projects. You can access Japper Forge by running the following command:

japper forge

This will start a web server, and Japper Forge will automatically open in your web browser.

Japper CLI

You can create a new Japper project using the japper command-line interface:

japper init

This will create a new Japper project with pre-configured templates to get you started quickly.

Enter the project directory after creating the project:

cd <project_name>

To run the development version of your Japper project, you can use the japper run dev command:

japper run dev

This will start a development server, and you can open your Japper project in a web browser. By default, the development server will run on port 8888. (You can visit http://localhost:8888 in your web browser to see your Japper project.)

To build and run the production version of your Japper project, you can use the japper run prod command:

japper run prod

This will build a production version of your Japper project and run it using Docker.

To deploy your Japper project to a Docker registry, you can use the japper deploy registry command:

japper deploy registry

This will build a production version of your Japper project and deploy it to a Docker registry. Japper will ask you for the Docker registry URL and other configurations.

To generate documentation for your Japper project, you can use the japper doc command:

japper doc

This will generate documentation for your Japper project using pydoc3. You can find the documentation in the docs folder

Documentation

To be added

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

japper-0.0.24.tar.gz (2.4 MB view details)

Uploaded Source

Built Distribution

japper-0.0.24-py3-none-any.whl (2.5 MB view details)

Uploaded Python 3

File details

Details for the file japper-0.0.24.tar.gz.

File metadata

  • Download URL: japper-0.0.24.tar.gz
  • Upload date:
  • Size: 2.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.2

File hashes

Hashes for japper-0.0.24.tar.gz
Algorithm Hash digest
SHA256 2c6d4b742cd3e57c59ab06507c1b562e331f993cd917793a87340b6a3fd05cda
MD5 d6e2946b81e459957ac0b908f355805e
BLAKE2b-256 414f9881e4cc3fc4c8fdb295f7c9666404f84acaca89d7529f4942091251c61e

See more details on using hashes here.

File details

Details for the file japper-0.0.24-py3-none-any.whl.

File metadata

  • Download URL: japper-0.0.24-py3-none-any.whl
  • Upload date:
  • Size: 2.5 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.2

File hashes

Hashes for japper-0.0.24-py3-none-any.whl
Algorithm Hash digest
SHA256 8b8b09b44b83b78811e159342cc683d1fb3c9d82797f55b016078ebb21894b2b
MD5 0e400d91e893bdf98e70b4bf9f3e23fc
BLAKE2b-256 822c0c32858e7f7d3ded0a0837a706fae96fe9d410e3011a3e5146d9a3a1ab77

See more details on using hashes here.

Supported by

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