haikal/templates/administration/staff_index.html
Marwan Alwali 48d70dc084 update
2025-02-07 06:46:12 +03:00

164 lines
9.0 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;">
<ul>
<li id="newAppointmentOption"><a href="#">{{ _("New Appointment")}}</a></li>
</ul>
</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>{% trans 'Staff Member' %}:</label>
${staffDropdown.outerHTML}
</div>
`;
}
return `
${superuserInputField}
<div class="flex-container-appt">
<label>{% trans 'Service Name' %}:</label>
${servicesDropdown.outerHTML}
</div>
<label for="clientName">{% trans 'Client Name' %}:</label>
<input type="text" name="clientName" value="${appointment.client_name || ''}" ${disabledAttribute} id="clientName" placeholder="John Doe">
<label for="clientEmail">{% trans 'Client Email' %}:</label>
<input type="email" name="clientEmail" value="${appointment.client_email || ''}" ${disabledAttribute} id="clientEmail" placeholder="john.doe@example.com">
<span id="emailError" style="display:none;"></span>
<label for="clientPhone">{% trans 'Phone Number' %}:</label>
<input type="tel" name="clientPhone" value="${appointment.client_phone || ''}" ${disabledAttribute} id="clientPhone" placeholder="+12392350799">
<label for="clientAddress">{% trans 'Client address' %}:</label>
<input type="text" name="clientAddress" value="${appointment.client_address || ''}" ${disabledAttribute} id="clientAddress" placeholder="Naples, Florida">
<div class="flex-container-appt">
<label for="want_reminder">{% trans 'Wants reminder' %}:</label>
<input type="checkbox" name="want_reminder" id="want_reminder" value="true" ${appointment.want_reminder ? 'checked' : ''} ${disabledAttribute}>
</div>
<label for="additional_info">{% trans 'Additional Information' %}:</label>
<input 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 for="startTime">{% trans 'Start time' %}:</label>
<input 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 for="endTime">{% trans 'End time' %}:</label>
<input 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}">
`;
}
</script>
{% endblock %}