152 lines
6.9 KiB
HTML
152 lines
6.9 KiB
HTML
{% load static %}
|
|
{% load file_filters %}
|
|
{% load i18n %}
|
|
<div class="card shadow-sm">
|
|
<div class="card-header bg-white border-bottom d-flex justify-content-between align-items-center">
|
|
<h5 class="card-title mb-0 text-primary">{% trans "Documents" %}</h5>
|
|
<button
|
|
type="button"
|
|
class="btn bg-primary-theme text-white btn-sm"
|
|
data-bs-toggle="modal"
|
|
data-bs-target="#documentUploadModal"
|
|
>
|
|
<i class="fas fa-plus me-2"></i>{% trans "Upload Document" %}
|
|
</button>
|
|
</div>
|
|
|
|
<!-- Document Upload Modal -->
|
|
<div class="modal fade" id="documentUploadModal" tabindex="-1" aria-labelledby="documentUploadModalLabel" aria-hidden="true">
|
|
<div class="modal-dialog modal-dialog-centered">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h5 class="modal-title" id="documentUploadModalLabel">{% trans "Upload Document" %}</h5>
|
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
|
|
</div>
|
|
|
|
<form
|
|
method="post"
|
|
enctype="multipart/form-data"
|
|
hx-post="{% url 'document_upload' application.id %}"
|
|
hx-target="#documents-pane"
|
|
hx-select="#documents-pane"
|
|
hx-swap="outerHTML"
|
|
hx-on::after-request="bootstrap.Modal.getInstance(document.getElementById('documentUploadModal')).hide()"
|
|
>
|
|
{% csrf_token %}
|
|
<div class="modal-body">
|
|
<div class="mb-3">
|
|
<label for="documentType" class="form-label">{% trans "Document Type" %}</label>
|
|
<select name="document_type" id="documentType" class="form-select">
|
|
<option value="resume">{% trans "Resume" %}</option>
|
|
<option value="cover_letter">{% trans "Cover Letter" %}</option>
|
|
<option value="portfolio">{% trans "Portfolio" %}</option>
|
|
<option value="certificate">{% trans "Certificate" %}</option>
|
|
<option value="id_proof">{% trans "ID Proof" %}</option>
|
|
<option value="other">{% trans "Other" %}</option>
|
|
</select>
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label for="documentFile" class="form-label">{% trans "File" %}</label>
|
|
<input
|
|
type="file"
|
|
name="file"
|
|
id="documentFile"
|
|
class="form-control"
|
|
required
|
|
>
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label for="documentDescription" class="form-label">{% trans "Description" %}</label>
|
|
<textarea
|
|
name="description"
|
|
id="documentDescription"
|
|
rows="3"
|
|
class="form-control"
|
|
placeholder="{% trans "Optional description..." %}"
|
|
></textarea>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="modal-footer">
|
|
<button type="button" class="btn btn-outline-secondary" data-bs-dismiss="modal">{% trans "Cancel" %}</button>
|
|
<button type="submit" class="btn btn-main-action">
|
|
<i class="fas fa-upload me-2"></i>{% trans "Upload" %}
|
|
</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Documents List -->
|
|
<div class="card-body" id="document-list-container">
|
|
{% if documents %}
|
|
{% for document in documents %}
|
|
<div class="d-flex justify-content-between align-items-center p-3 border-bottom hover-bg-light">
|
|
<div class="d-flex align-items-center">
|
|
<i class="fas fa-file text-primary me-3"></i>
|
|
<div>
|
|
<div class="fw-medium text-dark">{{ document.get_document_type_display }}</div>
|
|
<div class="small text-muted">{{ document.file.name|filename }}</div>
|
|
{% if document.description %}
|
|
<div class="small text-muted">{{ document.description }}</div>
|
|
{% endif %}
|
|
<div class="small text-muted">
|
|
{% trans "Uploaded by" %} {{ document.uploaded_by.get_full_name|default:document.uploaded_by.username }} {% trans "on" %} {{ document.created_at|date:"M d, Y" }}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="d-flex align-items-center">
|
|
<a
|
|
href="{% url 'document_download' document.id %}"
|
|
class="btn btn-sm btn-outline-primary me-2"
|
|
title="{% trans "Download" %}"
|
|
>
|
|
<i class="fas fa-download"></i>
|
|
</a>
|
|
|
|
{% if user.is_superuser or application.job.assigned_to == user %}
|
|
<button
|
|
type="button"
|
|
class="btn btn-sm btn-outline-danger"
|
|
onclick="confirmDelete({{ document.id }}, '{{ document.file.name|filename|default:"Document" }}')"
|
|
title="{% trans "Delete" %}"
|
|
>
|
|
<i class="fas fa-trash"></i>
|
|
</button>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
{% endfor %}
|
|
{% else %}
|
|
<div class="text-center py-5 text-muted">
|
|
<i class="fas fa-file-alt fa-3x mb-3"></i>
|
|
<p class="mb-2">{% trans "No documents uploaded yet." %}</p>
|
|
<p class="small">{% trans "Click \"Upload Document\" to add files for this application." %}</p>
|
|
</div>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
|
|
<style>
|
|
.hover-bg-light:hover {
|
|
background-color: #f8f9fa;
|
|
transition: background-color 0.2s ease;
|
|
}
|
|
</style>
|
|
|
|
<script>
|
|
function confirmDelete(documentId, fileName) {
|
|
var deletePrefix = "{% trans "Are you sure you want to delete" %}";
|
|
if (confirm(deletePrefix + ' "' + fileName + '"?')) {
|
|
htmx.ajax('POST', `{% url 'document_delete' 0 %}`.replace('0', documentId), {
|
|
target: '#document-list-container',
|
|
swap: 'innerHTML'
|
|
});
|
|
}
|
|
}
|
|
</script>
|