161 lines
9.6 KiB
HTML
161 lines
9.6 KiB
HTML
{% extends BASE_TEMPLATE %}
|
|
{% load i18n %}
|
|
{% load static %}
|
|
{% block customMetaTag %}<meta name="csrf-token" content="{{ csrf_token }}">{% endblock %}
|
|
{% block customCSS %}
|
|
<link rel="stylesheet"
|
|
type="text/css"
|
|
href="{% static 'css/appt-common.css' %}" />
|
|
<link rel="stylesheet"
|
|
type="text/css"
|
|
href="{% static 'css/app_admin/admin.css' %}" />
|
|
{% endblock %}
|
|
{% block title %}{{ page_title }}{% endblock %}
|
|
{% block content %}
|
|
<section class="content content-wrapper">
|
|
<div class="container">
|
|
<div class="calendar-wrapper">
|
|
<div id="calendar" class="calendarbox"></div>
|
|
<div id="event-list-container" class="event-list-container"></div>
|
|
</div>
|
|
{% include 'modal/event_details_modal.html' %}
|
|
{% include 'modal/error_modal.html' %}
|
|
<div class="messages" style="margin: 20px 0">
|
|
{% if messages %}
|
|
{% for message in messages %}
|
|
<div class="alert alert-dismissible {% if message.tags %} alert- {% if message.level == DEFAULT_MESSAGE_LEVELS.ERROR %} danger {% else %} {{ message.tags }} {% endif %} {% endif %}"
|
|
role="alert">{{ message }}</div>
|
|
{% endfor %}
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
</section>
|
|
<div id="customContextMenu"
|
|
style="display: none;
|
|
position: absolute;
|
|
z-index: 1000">
|
|
<a id="newAppointmentOption"
|
|
class="btn btn-sm btn-phoenix-success rounded-pill me-1 mb-1"
|
|
href="#">{{ _("New Appointment") }}</a>
|
|
</div>
|
|
{% include 'modal/confirm_modal.html' %}
|
|
{% endblock %}
|
|
{% block customJS %}
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.30.1/moment.js"
|
|
integrity="sha512-3CuraBvy05nIgcoXjVN33mACRyI89ydVHg7y/HMN9wcTVbHeur0SeBzweSd/rxySapO7Tmfu68+JlKkLTnDFNg=="
|
|
crossorigin="anonymous"
|
|
referrerpolicy="no-referrer"></script>
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment-timezone/0.5.45/moment-timezone-with-data.min.js"
|
|
integrity="sha512-t/mY3un180WRfsSkWy4Yi0tAxEDGcY2rAEx873hb5BrkvLA0QLk54+SjfYgFBBoCdJDV1H86M8uyZdJhAOHeyA=="
|
|
crossorigin="anonymous"
|
|
referrerpolicy="no-referrer"></script>
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/fullcalendar/6.1.10/index.global.min.js"
|
|
integrity="sha512-JCQkxdym6GmQ+AFVioDUq8dWaWN6tbKRhRyHvYZPupQ6DxpXzkW106FXS1ORgo/m3gxtt5lHRMqSdm2OfPajtg=="
|
|
crossorigin="anonymous"
|
|
referrerpolicy="no-referrer"></script>
|
|
<script>
|
|
const timezone = "{{ timezone }}";
|
|
const locale = "{{ locale }}";
|
|
const availableSlotsAjaxURL = "{% url 'appointment:available_slots_ajax' %}";
|
|
const requestNextAvailableSlotURLTemplate = "{% url 'appointment:request_next_available_slot' service_id=0 %}";
|
|
const deleteAppointmentURLTemplate = "{% url 'appointment:delete_appointment_ajax' %}";
|
|
const getNonWorkingDaysURL = "{% url 'appointment:get_non_working_days_ajax' %}";
|
|
const serviceId = "{{ service.id }}";
|
|
const serviceDuration = parseInt("{{ service.duration.total_seconds }}") / 60;
|
|
let appointments = {{ appointments|safe }};
|
|
const fetchServiceListForStaffURL = "{% url 'appointment:fetch_service_list_for_staff' %}";
|
|
const fetchStaffListURL = "{% url 'appointment:fetch_staff_list' %}";
|
|
const updateApptMinInfoURL = "{% url 'appointment:update_appt_min_info' %}";
|
|
const updateApptDateURL = "{% url 'appointment:update_appt_date_time' %}";
|
|
const validateApptDateURL = "{% url 'appointment:validate_appointment_date' %}";
|
|
const isUserStaffAdminURL = "{% url 'appointment:is_user_staff_admin' %}";
|
|
const isUserSuperUser = "{{ is_superuser }}" === "True";
|
|
</script>
|
|
<script>
|
|
{# Text for translation #}
|
|
const confirmDeletionTitleTxt = "{% trans 'Confirm Deletion' %}";
|
|
const confirmDeletionTxt = "{% trans 'Are you sure you want to delete this appointment?' %}";
|
|
const deleteBtnTxt = "{% trans 'Delete' %}";
|
|
const eventsOnTxt = "{% trans 'Events on' %}";
|
|
const noEventTxt = "{% trans 'No events for this day.' %}";
|
|
const newEventTxt = "{% trans 'New Event' %}";
|
|
const successTxt = "{% trans 'Success' %}";
|
|
const errorTxt = "{% trans 'Error' %}";
|
|
const updateApptErrorTitleTxt = "{% trans 'Error: Unable to delete appointment.' %}";
|
|
const apptNotFoundTxt = "{% trans 'Appointment not found.' %}";
|
|
const notStaffMemberTxt = "{% trans "You're not a staff member. Can't perform this action !" %}";
|
|
const noServiceOfferedTxt = "{% trans "You don't offer any service. Add new service from your profile." %}";
|
|
const noStaffMemberTxt = "{% trans "No staff members found." %}";
|
|
</script>
|
|
<script src="{% static 'js/modal/error_modal.js' %}"></script>
|
|
<script src="{% static 'js/app_admin/staff_index.js' %}"></script>
|
|
<script src="{% static 'js/modal/show_modal.js' %}"></script>
|
|
<script src="{% static 'js/js-utils.js' %}"></script>
|
|
<script>
|
|
function createCommonInputFields(appointment, servicesDropdown, isEditMode, defaultStartTime, staffDropdown) {
|
|
const startTimeValue = isEditMode ? moment(appointment.start_time).format('HH:mm:ss') : defaultStartTime;
|
|
const disabledAttribute = isEditMode ? '' : 'disabled';
|
|
|
|
let superuserInputField = '';
|
|
if (isUserSuperUser) {
|
|
superuserInputField = `
|
|
<div class="flex-container-appt">
|
|
<label class="form-label">{% trans 'Staff Member' %}:</label>
|
|
${staffDropdown.outerHTML}
|
|
</div>
|
|
`;
|
|
}
|
|
|
|
return `
|
|
${superuserInputField}
|
|
<div class="flex-container-appt">
|
|
<label class="form-label">{% trans 'Service Name' %}:</label>
|
|
${servicesDropdown.outerHTML}
|
|
</div>
|
|
<label class="form-label" for="clientName">{% trans 'Client Name' %}:</label>
|
|
<input type="text" name="clientName" class="form-control form-control-sm" value="${appointment.client_name || ''}" ${disabledAttribute} id="clientName" placeholder="">
|
|
<label class="form-label" for="clientEmail">{% trans 'Client Email' %}:</label>
|
|
<input type="email" name="clientEmail" class="form-control form-control-sm" value="${appointment.client_email || ''}" ${disabledAttribute} id="clientEmail" placeholder="">
|
|
<span id="emailError" style="display:none;"></span>
|
|
<label class="form-label" for="clientPhone">{% trans 'Phone Number' %}:</label>
|
|
<input type="tel" name="clientPhone" class="form-control form-control-sm" value="${appointment.client_phone || ''}" ${disabledAttribute} id="clientPhone" placeholder="+9665********">
|
|
<label class="form-label" for="clientAddress">{% trans 'Client address' %}:</label>
|
|
<input type="text" name="clientAddress" class="form-control form-control-sm" value="${appointment.client_address || ''}" ${disabledAttribute} id="clientAddress" placeholder="">
|
|
<div class="flex-container-appt">
|
|
<label class="form-check-label" for="want_reminder">{% trans 'Wants reminder' %}:</label>
|
|
<input class="form-check-input" type="checkbox" name="want_reminder" id="want_reminder" value="true" ${appointment.want_reminder ? 'checked' : ''} ${disabledAttribute}>
|
|
</div>
|
|
<label class="form-label" for="additional_info">{% trans 'Additional Information' %}:</label>
|
|
<input class="form-control form-control-sm" type="text" name="additional_info" value="${appointment.additional_info || ''}" ${disabledAttribute} placeholder="{% trans 'Client wants this and that' %}" id="additional_info">
|
|
<div class="flex-container-appt">
|
|
<label class="form-label" for="startTime">{% trans 'Start time' %}:</label>
|
|
<input class="form-control form-control-sm" type="time" name="startTime" value="${startTimeValue}" ${disabledAttribute}>
|
|
</div>
|
|
`;
|
|
}
|
|
|
|
function generateModalContent(appointment, servicesDropdown, isEditMode, staffDropdown) {
|
|
const startTimeValue = moment(appointment.start_time).format('HH:mm:ss');
|
|
const commonInputs = createCommonInputFields(appointment, servicesDropdown, isEditMode, startTimeValue, staffDropdown);
|
|
return `
|
|
${commonInputs}
|
|
<div class="flex-container-appt">
|
|
<label class="form-label" for="endTime">{% trans 'End time' %}:</label>
|
|
<input class="form-control form-control-sm" type="time" name="endTime" value="${moment(appointment.end_time).format('HH:mm:ss')}" ${!isEditMode ? 'disabled' : ''}>
|
|
</div>
|
|
`;
|
|
}
|
|
|
|
function prepareCreateAppointmentModalContent(servicesDropdown, staffDropdown, defaultStartTime, formattedDate) {
|
|
const appointment = {client_name: '', client_email: '', client_phone: '', client_address: ''};
|
|
const commonInputs = createCommonInputFields(appointment, servicesDropdown, true, defaultStartTime, staffDropdown);
|
|
|
|
return `
|
|
${commonInputs}
|
|
<label for="date" style="display: none"></label>
|
|
<input type="hidden" name="date" value="${formattedDate}" class="datepicker">
|
|
`;
|
|
}
|
|
</script>
|
|
{% endblock %}
|