mirror of
https://github.com/inventree/InvenTree
synced 2024-08-30 18:33:04 +00:00
urls as own mixin
This commit is contained in:
parent
8220ccb385
commit
dc70b5ef11
@ -40,6 +40,43 @@ class SettingsMixin:
|
|||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
class UrlsMixin:
|
||||||
|
"""Mixin that enables urls for the plugin"""
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__()
|
||||||
|
|
||||||
|
self.add_mixin('urls')
|
||||||
|
self.urls = self.setup_urls()
|
||||||
|
|
||||||
|
def setup_urls(self):
|
||||||
|
"""
|
||||||
|
setup url endpoints for this plugin
|
||||||
|
"""
|
||||||
|
if self.urlpatterns:
|
||||||
|
return self.urlpatterns
|
||||||
|
return None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def base_url(self):
|
||||||
|
return f'{settings.PLUGIN_URL}/{self.plugin_name()}/'
|
||||||
|
|
||||||
|
@property
|
||||||
|
def urlpatterns(self):
|
||||||
|
"""
|
||||||
|
retruns the urlpatterns for this plugin
|
||||||
|
"""
|
||||||
|
if self.has_urls:
|
||||||
|
return url(f'^{self.plugin_name()}/', include(self.urls), name=self.plugin_name())
|
||||||
|
return None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def has_urls(self):
|
||||||
|
"""
|
||||||
|
does this plugin use custom urls
|
||||||
|
"""
|
||||||
|
return bool(self.urls)
|
||||||
|
|
||||||
|
|
||||||
class IntegrationPlugin(plugin.InvenTreePlugin):
|
class IntegrationPlugin(plugin.InvenTreePlugin):
|
||||||
"""
|
"""
|
||||||
The IntegrationPlugin class is used to integrate with 3rd party software
|
The IntegrationPlugin class is used to integrate with 3rd party software
|
||||||
@ -49,8 +86,6 @@ class IntegrationPlugin(plugin.InvenTreePlugin):
|
|||||||
self.add_mixin('base')
|
self.add_mixin('base')
|
||||||
super().__init__()
|
super().__init__()
|
||||||
|
|
||||||
self.urls = self.setup_urls()
|
|
||||||
|
|
||||||
def add_mixin(self, key: str):
|
def add_mixin(self, key: str):
|
||||||
if not hasattr(self, 'mixins'):
|
if not hasattr(self, 'mixins'):
|
||||||
self.mixins = {}
|
self.mixins = {}
|
||||||
|
Loading…
Reference in New Issue
Block a user