django-components/docs/reference/extension_hooks.md
Juro Oravec 46e524e37d
refactor: Add Node metadata (#1229)
* refactor: `Slot.source` replaced with `Slot.fill_node`, new `Component.node` property, and `slot_node` available in `on_slot_rendered()` hook.

* refactor: fix windows path error in tests
2025-06-03 12:58:48 +02:00

8.2 KiB

Extension hooks

Overview of all the extension hooks available in Django Components.

Read more on Extensions.

Hooks

::: django_components.extension.ComponentExtension.on_component_class_created options: heading_level: 3 show_root_heading: true show_signature: true separate_signature: true show_symbol_type_heading: false show_symbol_type_toc: false show_if_no_docstring: true show_labels: false

Available data:

name type description
component_cls Type[Component] The created Component class

::: django_components.extension.ComponentExtension.on_component_class_deleted options: heading_level: 3 show_root_heading: true show_signature: true separate_signature: true show_symbol_type_heading: false show_symbol_type_toc: false show_if_no_docstring: true show_labels: false

Available data:

name type description
component_cls Type[Component] The to-be-deleted Component class

::: django_components.extension.ComponentExtension.on_component_data options: heading_level: 3 show_root_heading: true show_signature: true separate_signature: true show_symbol_type_heading: false show_symbol_type_toc: false show_if_no_docstring: true show_labels: false

Available data:

name type description
component Component The Component instance that is being rendered
component_cls Type[Component] The Component class
component_id str The unique identifier for this component instance
context_data Dict Deprecated. Use template_data instead. Will be removed in v1.0.
css_data Dict Dictionary of CSS data from Component.get_css_data()
js_data Dict Dictionary of JavaScript data from Component.get_js_data()
template_data Dict Dictionary of template data from Component.get_template_data()

::: django_components.extension.ComponentExtension.on_component_input options: heading_level: 3 show_root_heading: true show_signature: true separate_signature: true show_symbol_type_heading: false show_symbol_type_toc: false show_if_no_docstring: true show_labels: false

Available data:

name type description
args List List of positional arguments passed to the component
component Component The Component instance that received the input and is being rendered
component_cls Type[Component] The Component class
component_id str The unique identifier for this component instance
context Context The Django template Context object
kwargs Dict Dictionary of keyword arguments passed to the component
slots Dict[str, Slot] Dictionary of slot definitions

::: django_components.extension.ComponentExtension.on_component_registered options: heading_level: 3 show_root_heading: true show_signature: true separate_signature: true show_symbol_type_heading: false show_symbol_type_toc: false show_if_no_docstring: true show_labels: false

Available data:

name type description
component_cls Type[Component] The registered Component class
name str The name the component was registered under
registry ComponentRegistry The registry the component was registered to

::: django_components.extension.ComponentExtension.on_component_rendered options: heading_level: 3 show_root_heading: true show_signature: true separate_signature: true show_symbol_type_heading: false show_symbol_type_toc: false show_if_no_docstring: true show_labels: false

Available data:

name type description
component Component The Component instance that is being rendered
component_cls Type[Component] The Component class
component_id str The unique identifier for this component instance
result str The rendered component

::: django_components.extension.ComponentExtension.on_component_unregistered options: heading_level: 3 show_root_heading: true show_signature: true separate_signature: true show_symbol_type_heading: false show_symbol_type_toc: false show_if_no_docstring: true show_labels: false

Available data:

name type description
component_cls Type[Component] The unregistered Component class
name str The name the component was registered under
registry ComponentRegistry The registry the component was unregistered from

::: django_components.extension.ComponentExtension.on_registry_created options: heading_level: 3 show_root_heading: true show_signature: true separate_signature: true show_symbol_type_heading: false show_symbol_type_toc: false show_if_no_docstring: true show_labels: false

Available data:

name type description
registry ComponentRegistry The created ComponentRegistry instance

::: django_components.extension.ComponentExtension.on_registry_deleted options: heading_level: 3 show_root_heading: true show_signature: true separate_signature: true show_symbol_type_heading: false show_symbol_type_toc: false show_if_no_docstring: true show_labels: false

Available data:

name type description
registry ComponentRegistry The to-be-deleted ComponentRegistry instance

::: django_components.extension.ComponentExtension.on_slot_rendered options: heading_level: 3 show_root_heading: true show_signature: true separate_signature: true show_symbol_type_heading: false show_symbol_type_toc: false show_if_no_docstring: true show_labels: false

Available data:

name type description
component Component The Component instance that contains the {% slot %} tag
component_cls Type[Component] The Component class that contains the {% slot %} tag
component_id str The unique identifier for this component instance
result SlotResult The rendered result of the slot
slot Slot The Slot instance that was rendered
slot_is_default bool Whether the slot is default
slot_is_required bool Whether the slot is required
slot_name str The name of the {% slot %} tag
slot_node SlotNode The node instance of the {% slot %} tag

Objects

::: django_components.extension.OnComponentClassCreatedContext options: heading_level: 3 show_if_no_docstring: true

::: django_components.extension.OnComponentClassDeletedContext options: heading_level: 3 show_if_no_docstring: true

::: django_components.extension.OnComponentDataContext options: heading_level: 3 show_if_no_docstring: true

::: django_components.extension.OnComponentInputContext options: heading_level: 3 show_if_no_docstring: true

::: django_components.extension.OnComponentRegisteredContext options: heading_level: 3 show_if_no_docstring: true

::: django_components.extension.OnComponentUnregisteredContext options: heading_level: 3 show_if_no_docstring: true

::: django_components.extension.OnRegistryCreatedContext options: heading_level: 3 show_if_no_docstring: true

::: django_components.extension.OnRegistryDeletedContext options: heading_level: 3 show_if_no_docstring: true