0
0
mirror of https://github.com/wagtail/wagtail.git synced 2024-12-01 11:41:20 +01:00
wagtail/wagtail/telepath.py
2022-03-17 17:19:59 +00:00

77 lines
1.7 KiB
Python

from django import forms
from telepath import Adapter, AdapterRegistry, JSContextBase # noqa
from wagtail.admin.staticfiles import versioned_static
class WagtailJSContextBase(JSContextBase):
@property
def base_media(self):
return forms.Media(
js=[
versioned_static(self.telepath_js_path),
]
)
class WagtailAdapterRegistry(AdapterRegistry):
js_context_base_class = WagtailJSContextBase
registry = WagtailAdapterRegistry(
telepath_js_path="wagtailadmin/js/telepath/telepath.js"
)
JSContext = registry.js_context_class
def register(adapter, cls):
registry.register(adapter, cls)
def adapter(js_constructor, base=Adapter):
"""
Allows a class to implement its adapting logic with a `js_args()` method on the class itself.
This just helps reduce the amount of code you have to write.
For example:
@adapter('wagtail.mywidget')
class MyWidget():
...
def js_args(self):
return [
self.foo,
]
Is equivalent to:
class MyWidget():
...
class MyWidgetAdapter(Adapter):
js_constructor = 'wagtail.mywidget'
def js_args(self, obj):
return [
self.foo,
]
"""
def _wrapper(cls):
ClassAdapter = type(
cls.__name__ + "Adapter",
(base,),
{
"js_constructor": js_constructor,
"js_args": lambda self, obj: obj.js_args(),
},
)
register(ClassAdapter(), cls)
return cls
return _wrapper