diff --git a/passbook/core/templates/user/settings.html b/passbook/core/templates/user/settings.html
index edbcc4928..5e752f935 100644
--- a/passbook/core/templates/user/settings.html
+++ b/passbook/core/templates/user/settings.html
@@ -17,7 +17,9 @@
diff --git a/passbook/core/views/user.py b/passbook/core/views/user.py
index bb575ee8e..4bc02b27f 100644
--- a/passbook/core/views/user.py
+++ b/passbook/core/views/user.py
@@ -1,4 +1,6 @@
"""passbook core user views"""
+from typing import Any, Dict
+
from django.contrib.auth.mixins import LoginRequiredMixin
from django.contrib.messages.views import SuccessMessageMixin
from django.urls import reverse_lazy
@@ -6,6 +8,7 @@ from django.utils.translation import gettext as _
from django.views.generic import UpdateView
from passbook.core.forms.users import UserDetailForm
+from passbook.flows.models import Flow, FlowDesignation
class UserSettingsView(SuccessMessageMixin, LoginRequiredMixin, UpdateView):
@@ -19,3 +22,11 @@ class UserSettingsView(SuccessMessageMixin, LoginRequiredMixin, UpdateView):
def get_object(self):
return self.request.user
+
+ def get_context_data(self, **kwargs: Dict[str, Any]) -> Dict[str, Any]:
+ kwargs = super().get_context_data(**kwargs)
+ unenrollment_flow = Flow.with_policy(
+ self.request, designation=FlowDesignation.UNRENOLLMENT
+ )
+ kwargs["unenrollment_enabled"] = bool(unenrollment_flow)
+ return kwargs