2020-03-25 16:11:44 +01:00
|
|
|
{% extends "base.html" %}
|
2020-08-23 12:07:04 +02:00
|
|
|
{% comment %}
|
|
|
|
SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
{% endcomment %}
|
2020-08-25 16:30:02 +02:00
|
|
|
{% load i18n perms %}
|
2020-08-23 00:03:10 +02:00
|
|
|
|
|
|
|
{# Use a fluid-width container #}
|
|
|
|
{% block containertype %}container-fluid{% endblock %}
|
2020-03-25 16:11:44 +01:00
|
|
|
|
|
|
|
{% block content %}
|
2020-08-23 00:03:10 +02:00
|
|
|
<div class="row mt-4">
|
|
|
|
<div class="col-xl-4">
|
|
|
|
{% block profile_info %}
|
2020-08-31 20:15:48 +02:00
|
|
|
<div class="card bg-light" id="card-infos">
|
2020-08-25 16:30:02 +02:00
|
|
|
<h4 class="card-header text-center">
|
|
|
|
{% if user_object %}
|
|
|
|
{% trans "Account #" %}{{ user_object.pk }}
|
|
|
|
{% elif club %}
|
|
|
|
Club {{ club.name }}
|
|
|
|
{% endif %}
|
|
|
|
</h4>
|
|
|
|
<div class="text-center">
|
|
|
|
{% if user_object %}
|
|
|
|
<a href="{% url 'member:user_update_pic' user_object.pk %}">
|
|
|
|
<img src="{{ user_object.note.display_image.url }}" class="img-thumbnail mt-2">
|
|
|
|
</a>
|
|
|
|
{% elif club %}
|
|
|
|
<a href="{% url 'member:club_update_pic' club.pk %}">
|
|
|
|
<img src="{{ club.note.display_image.url }}" class="img-thumbnail mt-2">
|
|
|
|
</a>
|
|
|
|
{% endif %}
|
|
|
|
</div>
|
2020-08-31 20:15:48 +02:00
|
|
|
{% if note.inactivity_reason %}
|
|
|
|
<div class="alert alert-danger polymorphic-add-choice">
|
|
|
|
{{ note.get_inactivity_reason_display }}
|
|
|
|
</div>
|
|
|
|
{% endif %}
|
2020-08-25 16:30:02 +02:00
|
|
|
<div class="card-body" id="profile_infos">
|
|
|
|
{% if user_object %}
|
|
|
|
{% include "member/includes/profile_info.html" %}
|
|
|
|
{% elif club %}
|
2020-08-25 15:39:57 +02:00
|
|
|
{% include "member/includes/club_info.html" %}
|
2020-08-25 16:30:02 +02:00
|
|
|
{% endif %}
|
|
|
|
</div>
|
|
|
|
<div class="card-footer">
|
|
|
|
{% if user_object %}
|
|
|
|
<a class="btn btn-sm btn-secondary" href="{% url 'member:user_update_profile' user_object.pk %}">
|
|
|
|
<i class="fa fa-edit"></i> {% trans 'Update Profile' %}
|
|
|
|
</a>
|
|
|
|
{% url 'member:user_detail' user_object.pk as user_profile_url %}
|
|
|
|
{% if request.path_info != user_profile_url %}
|
|
|
|
<a class="btn btn-sm btn-primary" href="{{ user_profile_url }}">{% trans 'View Profile' %}</a>
|
|
|
|
{% endif %}
|
|
|
|
{% elif club and not club.weiclub %}
|
|
|
|
{% if can_add_members %}
|
|
|
|
<a class="btn btn-sm btn-success" href="{% url 'member:club_add_member' club_pk=club.pk %}"
|
2020-08-31 20:15:48 +02:00
|
|
|
data-turbolinks="false"> {% trans "Add member" %}</a>
|
2020-08-25 16:30:02 +02:00
|
|
|
{% endif %}
|
|
|
|
{% if ".change_"|has_perm:club %}
|
|
|
|
<a class="btn btn-sm btn-secondary" href="{% url 'member:club_update' pk=club.pk %}"
|
2020-08-31 20:15:48 +02:00
|
|
|
data-turbolinks="false">
|
2020-08-25 16:30:02 +02:00
|
|
|
<i class="fa fa-edit"></i> {% trans 'Update Profile' %}
|
|
|
|
</a>
|
|
|
|
{% endif %}
|
|
|
|
{% url 'member:club_detail' club.pk as club_detail_url %}
|
|
|
|
{% if request.path_info != club_detail_url %}
|
|
|
|
<a class="btn btn-sm btn-primary" href="{{ club_detail_url }}">{% trans 'View Profile' %}</a>
|
|
|
|
{% endif %}
|
|
|
|
{% endif %}
|
2020-08-31 20:15:48 +02:00
|
|
|
{% if can_lock_note %}
|
|
|
|
<button class="btn btn-sm btn-danger" data-toggle="modal" data-target="#lock-note-modal">
|
2020-09-01 14:33:38 +02:00
|
|
|
<i class="fa fa-ban"></i> {% trans 'Lock note' %}
|
2020-08-31 20:15:48 +02:00
|
|
|
</button>
|
|
|
|
{% elif can_unlock_note %}
|
|
|
|
<button class="btn btn-sm btn-success" data-toggle="modal" data-target="#unlock-note-modal">
|
2020-09-01 14:33:38 +02:00
|
|
|
<i class="fa fa-check-circle"></i> {% trans 'Unlock note' %}
|
2020-08-31 20:15:48 +02:00
|
|
|
</button>
|
|
|
|
{% endif %}
|
2020-08-25 16:30:02 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2020-08-25 18:36:49 +02:00
|
|
|
{% endblock %}
|
2020-08-23 00:03:10 +02:00
|
|
|
</div>
|
|
|
|
<div class="col-xl-8">
|
2020-08-25 16:30:02 +02:00
|
|
|
{% block profile_content %}{% endblock %}
|
2020-03-25 16:11:44 +01:00
|
|
|
</div>
|
2020-08-31 20:15:48 +02:00
|
|
|
|
|
|
|
{# Popup to confirm the action of locking the note. Managed by a button #}
|
|
|
|
<div class="modal fade" id="lock-note-modal" tabindex="-1" role="dialog" aria-labelledby="lockNote"
|
|
|
|
aria-hidden="true">
|
|
|
|
<div class="modal-dialog" role="document">
|
|
|
|
<div class="modal-content">
|
|
|
|
<div class="modal-header">
|
|
|
|
<h5 class="modal-title" id="lockNote">{% trans "Lock note" %}</h5>
|
|
|
|
<button type="button" class="close btn-modal" data-dismiss="modal" aria-label="Close">
|
|
|
|
<span aria-hidden="true">×</span>
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
<div class="modal-body">
|
|
|
|
{% blocktrans trimmed %}
|
|
|
|
Are you sure you want to lock this note? This will prevent any transaction that would be performed,
|
|
|
|
until the note is unlocked.
|
|
|
|
{% endblocktrans %}
|
|
|
|
{% if can_force_lock %}
|
|
|
|
{% blocktrans trimmed %}
|
|
|
|
If you use the force mode, the user won't be able to unlock the note by itself.
|
|
|
|
{% endblocktrans %}
|
|
|
|
{% endif %}
|
|
|
|
</div>
|
|
|
|
<div class="modal-footer">
|
|
|
|
<button type="button" class="btn btn-secondary btn-modal" data-dismiss="modal">{% trans "Close" %}</button>
|
|
|
|
{% if can_force_lock %}
|
|
|
|
<button type="button" class="btn btn-danger btn-modal" onclick="lock_note(true, 'forced')">{% trans "Force mode" %}</button>
|
|
|
|
{% endif %}
|
|
|
|
<button type="button" class="btn btn-warning btn-modal" onclick="lock_note(true, 'manual')">{% trans "Lock note" %}</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
{# Popup to confirm the action of unlocking the note. Managed by a button #}
|
|
|
|
<div class="modal fade" id="unlock-note-modal" tabindex="-1" role="dialog" aria-labelledby="unlockNote"
|
|
|
|
aria-hidden="true">
|
|
|
|
<div class="modal-dialog" role="document">
|
|
|
|
<div class="modal-content">
|
|
|
|
<div class="modal-header">
|
|
|
|
<h5 class="modal-title" id="unlockNote">{% trans "Unlock note" %}</h5>
|
|
|
|
<button type="button" class="close btn-modal" data-dismiss="modal" aria-label="Close">
|
|
|
|
<span aria-hidden="true">×</span>
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
<div class="modal-body">
|
|
|
|
{% blocktrans trimmed %}
|
|
|
|
Are you sure you want to unlock this note? Transactions will be re-enabled.
|
|
|
|
{% endblocktrans %}
|
|
|
|
</div>
|
|
|
|
<div class="modal-footer">
|
|
|
|
<button type="button" class="btn btn-secondary btn-modal" data-dismiss="modal">{% trans "Close" %}</button>
|
|
|
|
<button type="button" class="btn btn-success btn-modal" onclick="lock_note(false, null)">{% trans "Unlock note" %}</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2020-08-23 00:03:10 +02:00
|
|
|
</div>
|
2020-03-25 16:11:44 +01:00
|
|
|
{% endblock %}
|
|
|
|
|
|
|
|
{% block extrajavascript %}
|
2020-08-23 00:03:10 +02:00
|
|
|
<script>
|
|
|
|
function refreshHistory() {
|
2020-08-31 20:15:48 +02:00
|
|
|
{% if user_object %}
|
|
|
|
$("#history_list").load("{% url 'member:user_detail' pk=user_object.pk %} #history_list");
|
|
|
|
$("#profile_infos").load("{% url 'member:user_detail' pk=user_object.pk %} #profile_infos");
|
|
|
|
{% else %}
|
|
|
|
$("#history_list").load("{% url 'member:club_detail' pk=club.pk %} #history_list");
|
|
|
|
$("#profile_infos").load("{% url 'member:club_detail' pk=club.pk %} #profile_infos");
|
|
|
|
{% endif %}
|
|
|
|
}
|
|
|
|
|
|
|
|
function lock_note(locked, mode) {
|
|
|
|
$("button.btn-modal").attr("disabled", "disabled");
|
|
|
|
$.ajax({
|
|
|
|
url: "/api/note/note/{{ note.pk }}/",
|
|
|
|
type: "PATCH",
|
|
|
|
dataType: "json",
|
|
|
|
headers: {
|
|
|
|
"X-CSRFTOKEN": CSRF_TOKEN
|
|
|
|
},
|
|
|
|
data: {
|
|
|
|
is_active: !locked,
|
|
|
|
inactivity_reason: mode,
|
|
|
|
resourcetype: "{% if user_object %}NoteUser{% else %}NoteClub{% endif %}"
|
|
|
|
}
|
|
|
|
}).done(function () {
|
|
|
|
$("#card-infos").load("#card-infos #card-infos", function () {
|
|
|
|
$(".modal").modal("hide");
|
|
|
|
$("button.btn-modal").removeAttr("disabled");
|
|
|
|
});
|
|
|
|
}).fail(function(xhr, textStatus, error) {
|
|
|
|
$(".modal").modal("hide");
|
|
|
|
$("button.btn-modal").removeAttr("disabled");
|
|
|
|
errMsg(xhr.responseJSON);
|
|
|
|
});
|
2020-08-23 00:03:10 +02:00
|
|
|
}
|
|
|
|
</script>
|
2020-09-01 14:33:38 +02:00
|
|
|
{% endblock %}
|