diff --git a/djangocms_alias/admin.py b/djangocms_alias/admin.py index 0400bbb..35c3d74 100644 --- a/djangocms_alias/admin.py +++ b/djangocms_alias/admin.py @@ -1,5 +1,5 @@ from django import forms -from django.contrib import admin +from django.contrib import admin, messages from django.http import ( Http404, HttpRequest, @@ -173,3 +173,13 @@ def has_module_permission(self, request: HttpRequest) -> bool: """Hides admin class in admin site overview""" return False + + def delete_model(self, request: HttpRequest, obj: AliasContent): + if obj.alias.contents.filter(language=obj.language).count() == 1: + message = _("Draft deleted. A new empty draft will be created automatically if needed.") + self.message_user(request, message, level=messages.WARNING) + + return super().delete_model( + request=request, + obj=obj, + ) diff --git a/djangocms_alias/models.py b/djangocms_alias/models.py index 1bd9793..71f6973 100644 --- a/djangocms_alias/models.py +++ b/djangocms_alias/models.py @@ -302,11 +302,6 @@ def get_absolute_url(self): def get_template(self): return 'djangocms_alias/alias_content.html' - @transaction.atomic - def delete(self, *args, **kwargs): - super().delete(*args, **kwargs) - self.alias.cms_plugins.filter(language=self.language).delete() - @transaction.atomic def populate(self, replaced_placeholder=None, replaced_plugin=None, plugins=None): if not replaced_placeholder and not replaced_plugin: