Skip to main content

JupyterLab extension to show the js logs from the browser dev tools console

Project description

jupyterlab-js-logs

Extension status Github Actions Status lite-badge Binder

JupyterLab extension to show the console logs from the browser dev tools console.

https://github.com/user-attachments/assets/8d907bf6-8363-4b67-8431-22fca19f7d1e

Requirements

  • JupyterLab >= 2.0

Motivation

The main purpose for this extension is to provide a way to surface the console logs from the browser dev tools console in the JupyterLab interface. Especially for users that are not familiar with the browser dev tools, this extension can be very useful to debug and understand the logs generated by the JavaScript code running in the browser.

Settings

The extension exposes two settings in JupyterLab Settings Editor (JS Logs):

  • defaultLevel: default log level when opening the JS Logs panel. Default: info.
  • showLevelChangeMessages: whether to show metadata messages when log level changes. Default: false.

Extension point: log entry actions

This package provides an ILogEntryActionRegistry token for adding user-triggered actions to log rows in the JS Logs panel.

Actions are only executed when a user clicks a button. The extension does not automatically send log data anywhere.

Notes:

  • Action id must be unique across all registered actions.
  • register(...) returns a disposable you can call to remove the action.
  • Buttons are rendered inline in each matching log row (at the right side of the row content).
  • Actions can optionally provide an icon (for example from @jupyterlab/ui-components).
  • execute(message) receives { source, entryIndex, level, timestamp, output }.
  • This extension ships with a default Copy action on log rows as an example consumer of this API.
import {
  JupyterFrontEnd,
  JupyterFrontEndPlugin
} from '@jupyterlab/application';
import { ILogEntryActionRegistry } from 'jupyterlab-js-logs';

const plugin: JupyterFrontEndPlugin<void> = {
  id: 'my-log-actions',
  autoStart: true,
  requires: [ILogEntryActionRegistry],
  activate: (_app: JupyterFrontEnd, actions: ILogEntryActionRegistry) => {
    actions.register({
      id: 'my-actions:copy-log-context',
      label: 'Copy Context',
      caption: 'Run a custom action with this log entry',
      isVisible: message => ['error', 'critical'].includes(message.level),
      execute: message => {
        // Use the selected row context in your integration.
        console.log('Selected log entry:', message);
      }
    });
  }
};

Install

jupyter labextension install jupyterlab-js-logs

Contributing

This extension was bootstrapped from the custom-log-console example contributed by Carlos Herrero, from the jupyterlab-extension-examples repository.

Install

The jlpm command is JupyterLab's pinned version of yarn that is installed with JupyterLab. You may use yarn or npm in lieu of jlpm below.

# Clone the repo to your local environment
# Move to jupyterlab-js-logs directory

# Install dependencies
jlpm
# Build Typescript source
jlpm build
# Link your development version of the extension with JupyterLab
jupyter labextension install .
# Rebuild Typescript source after making changes
jlpm build
# Rebuild JupyterLab after making any changes
jupyter lab build

You can watch the source directory and run JupyterLab in watch mode to watch for changes in the extension's source and automatically rebuild the extension and application.

# Watch the source directory in another terminal tab
jlpm watch
# Run jupyterlab in watch mode in one terminal tab
jupyter lab --watch

Now every change will be built locally and bundled into JupyterLab. Be sure to refresh your browser page after saving file changes to reload the extension (note: you'll need to wait for webpack to finish, which can take 10s+ at times).

Uninstall

jupyter labextension uninstall jupyterlab-js-logs

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

jupyterlab_js_logs-1.3.0.tar.gz (100.2 kB view details)

Uploaded Source

Built Distribution

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

jupyterlab_js_logs-1.3.0-py3-none-any.whl (24.0 kB view details)

Uploaded Python 3

File details

Details for the file jupyterlab_js_logs-1.3.0.tar.gz.

File metadata

  • Download URL: jupyterlab_js_logs-1.3.0.tar.gz
  • Upload date:
  • Size: 100.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for jupyterlab_js_logs-1.3.0.tar.gz
Algorithm Hash digest
SHA256 cdaf53322341ecd0b2b4f31a1949b05b637b6cab86d2ea23419262382359688e
MD5 f72b54713dab7b93d956d3cfdda79fff
BLAKE2b-256 339f405ca432e227638e0078c34d2b560bbb477500d5b8072a524ebf0f6bf371

See more details on using hashes here.

File details

Details for the file jupyterlab_js_logs-1.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for jupyterlab_js_logs-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ffc68c985dc39056aa21082ab7a2f6ab33e3dfc040cca28cc456407f8db2b0d8
MD5 48abb4572c4f483142889918b8bf392c
BLAKE2b-256 355e9dc91e0dfb72384d7ed3129c546e9e227070511f39570549a1ebcaaafa59

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