Skip to content

Conversation

@fleming79
Copy link

@fleming79 fleming79 commented May 27, 2024

Replaces #3920.

Features:

  • Widgets can render anywhere the WidgetRenderer can be accessed (anywhere the global rendermime or clones work).
  • Correctly indicates when comms is disconnected.
  • Re-renders widgets when comms is restored.
  • Easier to manage and find widgets - the KernelWidgetManager.

Significant changes

  • The KernelWidgetManager is a single instance per kernel by the kernel ID.
  • The KernelWidgetManager stores and creates widgets.
  • The default rendermime will actively search for the [Kernel]WidgetManager that owns the widget model.
  • WidgetManager (not to be confused with KenelWidgetManager) has been re-purposed to track the renderers belonging to a session context and set the KernelWidgetManager when the kernel is loaded. WidgetManager informs the renderer that the [Kernel]WidgetManager is pending.
  • Re-rendering on demand.

Notebooks and Consoles can share widgets

image

When the notebook is closed ipwidgets takes over comms and re-renders the widget.

image

Shutting down the kernel breaks the connection (note the red paper clips)

image

Re-opening the notebook now gives a message

Model not found for this kernel: AppLayout(children=(HTML(value='<h1>Fictional World Weather</h1>', layout=Layout(grid_area='header', height='a…

image

@github-actions
Copy link

Binder 👈 Launch a binder notebook on branch fleming79/ipywidgets/per-kernel-widget-manager

@fleming79 fleming79 force-pushed the per-kernel-widget-manager branch from 34cfd36 to 23d9b2b Compare June 9, 2024 04:28
@fleming79 fleming79 force-pushed the per-kernel-widget-manager branch 2 times, most recently from 451f988 to 86b5b0e Compare November 3, 2024 09:33
@fleming79 fleming79 force-pushed the per-kernel-widget-manager branch 2 times, most recently from 119a5bf to fb8adbe Compare November 17, 2024 08:09
@fleming79 fleming79 changed the title DRAFT: Single widget manager per kernel Single widget manager per kernel Jun 2, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant