# 86 Viewport jump Compensation
* adds direct jump of viewport on related-data action (create/delete) * adds comment field to log.html as 'details'
This commit is contained in:
		
							parent
							
								
									7028672b93
								
							
						
					
					
						commit
						299923ef45
					
				@ -50,7 +50,7 @@
 | 
				
			|||||||
                <td class="align-middle">{{ deadline.comment }}</td>
 | 
					                <td class="align-middle">{{ deadline.comment }}</td>
 | 
				
			||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    {% if is_default_member and has_access  %}
 | 
					                    {% if is_default_member and has_access  %}
 | 
				
			||||||
                    <button data-form-url="{% url 'deadline-remove' deadline.id %}" class="btn btn-default btn-modal" title="{% trans 'Remove deadline' %}">
 | 
					                    <button data-form-url="{% url 'compensation:deadline-remove' obj.id deadline.id %}" class="btn btn-default btn-modal" title="{% trans 'Remove deadline' %}">
 | 
				
			||||||
                        {% fa5_icon 'trash' %}
 | 
					                        {% fa5_icon 'trash' %}
 | 
				
			||||||
                    </button>
 | 
					                    </button>
 | 
				
			||||||
                    {% endif %}
 | 
					                    {% endif %}
 | 
				
			||||||
 | 
				
			|||||||
@ -118,26 +118,27 @@
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <hr>
 | 
					    <hr>
 | 
				
			||||||
 | 
					    <div id="related_data">
 | 
				
			||||||
    <div class="row">
 | 
					        <div class="row">
 | 
				
			||||||
        <div class="col-sm-12 col-md-12 col-lg-6">
 | 
					            <div class="col-sm-12 col-md-12 col-lg-6">
 | 
				
			||||||
            {% include 'compensation/detail/compensation/includes/states-before.html' %}
 | 
					                {% include 'compensation/detail/compensation/includes/states-before.html' %}
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
 | 
					            <div class="col-sm-12 col-md-12 col-lg-6">
 | 
				
			||||||
 | 
					                {% include 'compensation/detail/compensation/includes/states-after.html' %}
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="col-sm-12 col-md-12 col-lg-6">
 | 
					        <div class="row">
 | 
				
			||||||
            {% include 'compensation/detail/compensation/includes/states-after.html' %}
 | 
					            <div class="col-sm-12 col-md-12 col-lg-6">
 | 
				
			||||||
 | 
					                {% include 'compensation/detail/compensation/includes/actions.html' %}
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
 | 
					            <div class="col-sm-12 col-md-12 col-lg-6">
 | 
				
			||||||
 | 
					                {% include 'compensation/detail/compensation/includes/deadlines.html' %}
 | 
				
			||||||
 | 
					            </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
    </div>
 | 
					        <div class="row">
 | 
				
			||||||
    <div class="row">
 | 
					            <div class="col-sm-12 col-md-12 col-lg-6">
 | 
				
			||||||
        <div class="col-sm-12 col-md-12 col-lg-6">
 | 
					                {% include 'compensation/detail/compensation/includes/documents.html' %}
 | 
				
			||||||
            {% include 'compensation/detail/compensation/includes/actions.html' %}
 | 
					            </div>
 | 
				
			||||||
        </div>
 | 
					 | 
				
			||||||
        <div class="col-sm-12 col-md-12 col-lg-6">
 | 
					 | 
				
			||||||
            {% include 'compensation/detail/compensation/includes/deadlines.html' %}
 | 
					 | 
				
			||||||
        </div>
 | 
					 | 
				
			||||||
    </div>
 | 
					 | 
				
			||||||
    <div class="row">
 | 
					 | 
				
			||||||
        <div class="col-sm-12 col-md-12 col-lg-6">
 | 
					 | 
				
			||||||
            {% include 'compensation/detail/compensation/includes/documents.html' %}
 | 
					 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -23,6 +23,7 @@ urlpatterns = [
 | 
				
			|||||||
    path('<id>/state/<state_id>/remove', state_remove_view, name='state-remove'),
 | 
					    path('<id>/state/<state_id>/remove', state_remove_view, name='state-remove'),
 | 
				
			||||||
    path('<id>/action/<action_id>/remove', action_remove_view, name='action-remove'),
 | 
					    path('<id>/action/<action_id>/remove', action_remove_view, name='action-remove'),
 | 
				
			||||||
    path('<id>/deadline/new', deadline_new_view, name="new-deadline"),
 | 
					    path('<id>/deadline/new', deadline_new_view, name="new-deadline"),
 | 
				
			||||||
 | 
					    path('<id>/deadline/<deadline_id>/remove', deadline_remove_view, name='deadline-remove'),
 | 
				
			||||||
    path('<id>/report', report_view, name='report'),
 | 
					    path('<id>/report', report_view, name='report'),
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    # Documents
 | 
					    # Documents
 | 
				
			||||||
 | 
				
			|||||||
@ -13,6 +13,7 @@ from intervention.models import Intervention
 | 
				
			|||||||
from konova.contexts import BaseContext
 | 
					from konova.contexts import BaseContext
 | 
				
			||||||
from konova.decorators import *
 | 
					from konova.decorators import *
 | 
				
			||||||
from konova.forms import RemoveModalForm, SimpleGeomForm
 | 
					from konova.forms import RemoveModalForm, SimpleGeomForm
 | 
				
			||||||
 | 
					from konova.models import Deadline
 | 
				
			||||||
from konova.sub_settings.context_settings import TAB_TITLE_IDENTIFIER
 | 
					from konova.sub_settings.context_settings import TAB_TITLE_IDENTIFIER
 | 
				
			||||||
from konova.utils.documents import get_document, remove_document
 | 
					from konova.utils.documents import get_document, remove_document
 | 
				
			||||||
from konova.utils.generators import generate_qr_code
 | 
					from konova.utils.generators import generate_qr_code
 | 
				
			||||||
@ -276,7 +277,8 @@ def new_document_view(request: HttpRequest, id: str):
 | 
				
			|||||||
    form = NewCompensationDocumentForm(request.POST or None, request.FILES or None, instance=comp, request=request)
 | 
					    form = NewCompensationDocumentForm(request.POST or None, request.FILES or None, instance=comp, request=request)
 | 
				
			||||||
    return form.process_request(
 | 
					    return form.process_request(
 | 
				
			||||||
        request,
 | 
					        request,
 | 
				
			||||||
        msg_success=_("Document added")
 | 
					        msg_success=_("Document added"),
 | 
				
			||||||
 | 
					        redirect_url=reverse("compensation:detail", args=(id,)) + "#related_data"
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -345,7 +347,8 @@ def state_new_view(request: HttpRequest, id: str):
 | 
				
			|||||||
    form = NewStateModalForm(request.POST or None, instance=comp, request=request)
 | 
					    form = NewStateModalForm(request.POST or None, instance=comp, request=request)
 | 
				
			||||||
    return form.process_request(
 | 
					    return form.process_request(
 | 
				
			||||||
        request,
 | 
					        request,
 | 
				
			||||||
        msg_success=_("State added")
 | 
					        msg_success=_("State added"),
 | 
				
			||||||
 | 
					        redirect_url=reverse("compensation:detail", args=(id,)) + "#related_data"
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -366,7 +369,8 @@ def action_new_view(request: HttpRequest, id: str):
 | 
				
			|||||||
    form = NewActionModalForm(request.POST or None, instance=comp, request=request)
 | 
					    form = NewActionModalForm(request.POST or None, instance=comp, request=request)
 | 
				
			||||||
    return form.process_request(
 | 
					    return form.process_request(
 | 
				
			||||||
        request,
 | 
					        request,
 | 
				
			||||||
        msg_success=_("Action added")
 | 
					        msg_success=_("Action added"),
 | 
				
			||||||
 | 
					        redirect_url=reverse("compensation:detail", args=(id,)) + "#related_data"
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -387,7 +391,31 @@ def deadline_new_view(request: HttpRequest, id: str):
 | 
				
			|||||||
    form = NewDeadlineModalForm(request.POST or None, instance=comp, request=request)
 | 
					    form = NewDeadlineModalForm(request.POST or None, instance=comp, request=request)
 | 
				
			||||||
    return form.process_request(
 | 
					    return form.process_request(
 | 
				
			||||||
        request,
 | 
					        request,
 | 
				
			||||||
        msg_success=_("Deadline added")
 | 
					        msg_success=_("Deadline added"),
 | 
				
			||||||
 | 
					        redirect_url=reverse("compensation:detail", args=(id,)) + "#related_data"
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@login_required
 | 
				
			||||||
 | 
					@default_group_required
 | 
				
			||||||
 | 
					@shared_access_required(Compensation, "id")
 | 
				
			||||||
 | 
					def deadline_remove_view(request: HttpRequest, id: str, deadline_id: str):
 | 
				
			||||||
 | 
					    """ Renders a form for removing deadlines from a compensation
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Args:
 | 
				
			||||||
 | 
					        request (HttpRequest): The incoming request
 | 
				
			||||||
 | 
					        id (str): The compensation's id
 | 
				
			||||||
 | 
					        deadline_id (str): The deadline's id
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Returns:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    """
 | 
				
			||||||
 | 
					    deadline = get_object_or_404(Deadline, id=deadline_id)
 | 
				
			||||||
 | 
					    form = RemoveModalForm(request.POST or None, instance=deadline, request=request)
 | 
				
			||||||
 | 
					    return form.process_request(
 | 
				
			||||||
 | 
					        request,
 | 
				
			||||||
 | 
					        msg_success=_("Deadline removed"),
 | 
				
			||||||
 | 
					        redirect_url=reverse("compensation:detail", args=(id,)) + "#related_data"
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -409,7 +437,8 @@ def state_remove_view(request: HttpRequest, id: str, state_id: str):
 | 
				
			|||||||
    form = RemoveModalForm(request.POST or None, instance=state, request=request)
 | 
					    form = RemoveModalForm(request.POST or None, instance=state, request=request)
 | 
				
			||||||
    return form.process_request(
 | 
					    return form.process_request(
 | 
				
			||||||
        request,
 | 
					        request,
 | 
				
			||||||
        msg_success=_("State removed")
 | 
					        msg_success=_("State removed"),
 | 
				
			||||||
 | 
					        redirect_url=reverse("compensation:detail", args=(id,)) + "#related_data"
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -431,7 +460,8 @@ def action_remove_view(request: HttpRequest, id: str, action_id: str):
 | 
				
			|||||||
    form = RemoveModalForm(request.POST or None, instance=action, request=request)
 | 
					    form = RemoveModalForm(request.POST or None, instance=action, request=request)
 | 
				
			||||||
    return form.process_request(
 | 
					    return form.process_request(
 | 
				
			||||||
        request,
 | 
					        request,
 | 
				
			||||||
        msg_success=_("Action removed")
 | 
					        msg_success=_("Action removed"),
 | 
				
			||||||
 | 
					        redirect_url=reverse("compensation:detail", args=(id,)) + "#related_data"
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -3,12 +3,15 @@
 | 
				
			|||||||
    <table class="table table-hover">
 | 
					    <table class="table table-hover">
 | 
				
			||||||
        <thead>
 | 
					        <thead>
 | 
				
			||||||
            <tr>
 | 
					            <tr>
 | 
				
			||||||
                <th scope="col">
 | 
					                <th scope="col" class="w-25">
 | 
				
			||||||
                    {% trans 'Timestamp' %}
 | 
					                    {% trans 'Timestamp' %}
 | 
				
			||||||
                </th>
 | 
					                </th>
 | 
				
			||||||
                <th scope="col">
 | 
					                <th scope="col">
 | 
				
			||||||
                    {% trans 'Action' %}
 | 
					                    {% trans 'Action' %}
 | 
				
			||||||
                </th>
 | 
					                </th>
 | 
				
			||||||
 | 
					                <th scope="col">
 | 
				
			||||||
 | 
					                    {% trans 'Details' %}
 | 
				
			||||||
 | 
					                </th>
 | 
				
			||||||
                <th scope="col">
 | 
					                <th scope="col">
 | 
				
			||||||
                    {% trans 'User' %}
 | 
					                    {% trans 'User' %}
 | 
				
			||||||
                </th>
 | 
					                </th>
 | 
				
			||||||
@ -23,6 +26,9 @@
 | 
				
			|||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    {{ entry.action_humanize}}
 | 
					                    {{ entry.action_humanize}}
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
 | 
					                <td>
 | 
				
			||||||
 | 
					                    {{ entry.comment|default_if_none:"-" }}
 | 
				
			||||||
 | 
					                </td>
 | 
				
			||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    {{entry.user}}
 | 
					                    {{entry.user}}
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user