mirror of
https://github.com/mediacms-io/mediacms.git
synced 2026-03-09 06:27:21 -04:00
38 lines
1.2 KiB
HTML
38 lines
1.2 KiB
HTML
{% block messages %}
|
|
|
|
{% if messages %}
|
|
|
|
{% for message in messages %}
|
|
<div class="alert {{ message.tags }} alert-dismissible" role="alert">
|
|
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
|
|
<span aria-hidden="true">×</span>
|
|
</button>
|
|
{{ message }}
|
|
</div>
|
|
{% endfor %}
|
|
|
|
<script>
|
|
// This script is necessary because the React-based PageHeader component (which handles alert dismissal)
|
|
// is not mounted on all Django-rendered pages. This ensures the close button works globally.
|
|
document.addEventListener('DOMContentLoaded', function() {
|
|
var closeButtons = document.querySelectorAll('.alert .close');
|
|
closeButtons.forEach(function(btn) {
|
|
btn.addEventListener('click', function(e) {
|
|
var alert = this.closest('.alert');
|
|
if (alert) {
|
|
alert.classList.add('hiding');
|
|
setTimeout(function() {
|
|
if (alert.parentNode) {
|
|
alert.parentNode.removeChild(alert);
|
|
}
|
|
}, 400);
|
|
}
|
|
});
|
|
});
|
|
});
|
|
</script>
|
|
|
|
{% endif %}
|
|
|
|
{% endblock %}
|