mirror of
https://github.com/inventree/InvenTree.git
synced 2025-04-30 12:36:45 +00:00
added settings actions
This commit is contained in:
parent
bf0129788d
commit
35d2259edf
@ -2,13 +2,35 @@
|
|||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from django.contrib import admin
|
from django.contrib import admin
|
||||||
|
from django.apps import apps
|
||||||
|
|
||||||
import plugin.models as models
|
import plugin.models as models
|
||||||
|
|
||||||
|
|
||||||
|
def plugin_update(queryset, new_status: bool):
|
||||||
|
for model in queryset:
|
||||||
|
model.active = new_status
|
||||||
|
model.save(no_reload=True)
|
||||||
|
|
||||||
|
app = apps.get_app_config('plugin')
|
||||||
|
app.reload_plugins()
|
||||||
|
|
||||||
|
|
||||||
|
@admin.action(description='Activate plugin(s)')
|
||||||
|
def plugin_activate(modeladmin, request, queryset):
|
||||||
|
plugin_update(queryset, True)
|
||||||
|
|
||||||
|
|
||||||
|
@admin.action(description='Deactivate plugin(s)')
|
||||||
|
def plugin_deactivate(modeladmin, request, queryset):
|
||||||
|
plugin_update(queryset, False)
|
||||||
|
|
||||||
|
|
||||||
class PluginConfigAdmin(admin.ModelAdmin):
|
class PluginConfigAdmin(admin.ModelAdmin):
|
||||||
"""Custom admin with restricted id fields"""
|
"""Custom admin with restricted id fields"""
|
||||||
readonly_fields = ["key", "name", ]
|
readonly_fields = ["key", "name", ]
|
||||||
|
list_display = ['key', 'name', 'active', ]
|
||||||
|
actions = [plugin_activate, plugin_deactivate, ]
|
||||||
|
|
||||||
|
|
||||||
admin.site.register(models.PluginConfig, PluginConfigAdmin)
|
admin.site.register(models.PluginConfig, PluginConfigAdmin)
|
||||||
|
@ -55,9 +55,12 @@ class PluginConfig(models.Model):
|
|||||||
|
|
||||||
def save(self, force_insert=False, force_update=False, *args, **kwargs):
|
def save(self, force_insert=False, force_update=False, *args, **kwargs):
|
||||||
"""extend save method to reload plugins if the 'active' status changes"""
|
"""extend save method to reload plugins if the 'active' status changes"""
|
||||||
|
reload = kwargs.pop('no_reload', False) # check if no_reload flag is set
|
||||||
|
|
||||||
ret = super().save(force_insert, force_update, *args, **kwargs)
|
ret = super().save(force_insert, force_update, *args, **kwargs)
|
||||||
app = apps.get_app_config('plugin')
|
app = apps.get_app_config('plugin')
|
||||||
|
|
||||||
|
if not reload:
|
||||||
if self.active is False and self.__org_active is True:
|
if self.active is False and self.__org_active is True:
|
||||||
app.reload_plugins()
|
app.reload_plugins()
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user