165 lines
6.8 KiB
PHP
Executable file
165 lines
6.8 KiB
PHP
Executable file
<?php
|
|
/**
|
|
* @var array $available_providers
|
|
* @var array $available_services
|
|
* @var string $base_url
|
|
* @var string $date_format
|
|
* @var string $time_format
|
|
* @var string $first_weekday
|
|
* @var array $edit_appointment
|
|
* @var array $customers
|
|
* @var array $secretary_providers
|
|
* @var string $calendar_view
|
|
* @var string $timezones
|
|
* @var string $user_id
|
|
* @var string $user_email
|
|
* @var string $timezone
|
|
* @var string $role_slug
|
|
* @var array $privileges
|
|
*/
|
|
?>
|
|
|
|
<?php extend('layouts/backend/backend_layout') ?>
|
|
|
|
<?php section('styles') ?>
|
|
|
|
<link rel="stylesheet" type="text/css" href="<?= asset_url('/assets/vendor/fullcalendar/fullcalendar.min.css') ?>">
|
|
|
|
<?php section('styles') ?>
|
|
|
|
<?php section('scripts') ?>
|
|
|
|
<script src="<?= asset_url('assets/vendor/fullcalendar/fullcalendar.min.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/vendor/jquery-jeditable/jquery.jeditable.min.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/vendor/jquery-ui-timepicker-addon/jquery-ui-timepicker-addon.min.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/js/components/working_plan_exceptions_modal.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/js/pages/calendar/backend_calendar.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/js/pages/calendar/backend_calendar_default_view.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/js/pages/calendar/backend_calendar_table_view.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/js/pages/calendar/backend_calendar_google_sync.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/js/pages/calendar/backend_calendar_appointments_modal.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/js/pages/calendar/backend_calendar_unavailability_events_modal.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/js/pages/calendar/backend_calendar_api.js') ?>"></script>
|
|
<script>
|
|
var GlobalVariables = {
|
|
csrfToken: <?= json_encode($this->security->get_csrf_hash()) ?>,
|
|
baseUrl: <?= json_encode(config('base_url')) ?>,
|
|
dateFormat: <?= json_encode(setting('date_format')) ?>,
|
|
timeFormat: <?= json_encode(setting('time_format')) ?>,
|
|
firstWeekday: <?= json_encode(setting('first_weekday')) ?>,
|
|
timezones: <?= json_encode($timezones) ?>,
|
|
availableProviders: <?= json_encode($available_providers) ?>,
|
|
availableServices: <?= json_encode($available_services) ?>,
|
|
secretaryProviders: <?= json_encode($secretary_providers) ?>,
|
|
calendarView: <?= json_encode($calendar_view) ?>,
|
|
editAppointment: <?= json_encode($edit_appointment) ?>,
|
|
user: {
|
|
id: <?= session('user_id') ?>,
|
|
email: <?= json_encode(session('user_email')) ?>,
|
|
timezone: <?= json_encode(session('timezone')) ?>,
|
|
role_slug: <?= json_encode(session('role_slug')) ?>,
|
|
privileges: <?= json_encode($privileges) ?>
|
|
}
|
|
};
|
|
|
|
$(function () {
|
|
BackendCalendar.initialize(GlobalVariables.calendarView);
|
|
});
|
|
</script>
|
|
|
|
<?php section('scripts') ?>
|
|
|
|
<?php section('content') ?>
|
|
|
|
<div class="container-fluid backend-page" id="calendar-page">
|
|
<div class="row" id="calendar-toolbar">
|
|
<div id="calendar-filter" class="col-12 col-sm-5">
|
|
<div class="calendar-filter-items">
|
|
<select id="select-filter-item" class="form-control col"
|
|
data-tippy-content="<?= lang('select_filter_item_hint') ?>">
|
|
</select>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="calendar-actions" class="col-12 col-sm-7">
|
|
<?php if ((session('role_slug') == DB_SLUG_ADMIN || session('role_slug') == DB_SLUG_PROVIDER)
|
|
&& config('google_sync_feature') == TRUE): ?>
|
|
<button id="google-sync" class="btn btn-primary"
|
|
data-tippy-content="<?= lang('trigger_google_sync_hint') ?>">
|
|
<i class="fas fa-sync-alt"></i>
|
|
<span><?= lang('synchronize') ?></span>
|
|
</button>
|
|
|
|
<button id="enable-sync" class="btn btn-light" data-bs-toggle="button"
|
|
data-tippy-content="<?= lang('enable_appointment_sync_hint') ?>">
|
|
<i class="fas fa-calendar-alt me-2"></i>
|
|
<span><?= lang('enable_sync') ?></span>
|
|
</button>
|
|
<?php endif ?>
|
|
|
|
<?php if (can('add', PRIV_APPOINTMENTS)): ?>
|
|
<div class="btn-group">
|
|
<button class="btn btn-light" id="insert-appointment">
|
|
<i class="fas fa-plus-square me-2"></i>
|
|
<?= lang('appointment') ?>
|
|
</button>
|
|
|
|
<button class="btn btn-light dropdown-toggle" id="insert-dropdown" data-bs-toggle="dropdown">
|
|
<span class="caret"></span>
|
|
<span class="sr-only">Toggle Dropdown</span>
|
|
</button>
|
|
|
|
<div class="dropdown-menu">
|
|
<a class="dropdown-item" href="#" id="insert-unavailable">
|
|
<i class="fas fa-plus-square me-2"></i>
|
|
<?= lang('unavailable') ?>
|
|
</a>
|
|
<a class="dropdown-item" href="#" id="insert-working-plan-exception"
|
|
<?= session('role_slug') !== DB_SLUG_ADMIN ? 'hidden' : '' ?>>
|
|
<i class="fas fa-plus-square me-2"></i>
|
|
<?= lang('working_plan_exception') ?>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
<?php endif ?>
|
|
|
|
<button id="reload-appointments" class="btn btn-light"
|
|
data-tippy-content="<?= lang('reload_appointments_hint') ?>">
|
|
<i class="fas fa-sync-alt"></i>
|
|
</button>
|
|
|
|
<?php if ($calendar_view === 'default'): ?>
|
|
<a class="btn btn-light" href="<?= site_url('backend?view=table') ?>"
|
|
data-tippy-content="<?= lang('table') ?>">
|
|
<i class="fas fa-table"></i>
|
|
</a>
|
|
<?php endif ?>
|
|
|
|
<?php if ($calendar_view === 'table'): ?>
|
|
<a class="btn btn-light" href="<?= site_url('backend?view=default') ?>"
|
|
data-tippy-content="<?= lang('default') ?>">
|
|
<i class="fas fa-calendar-alt"></i>
|
|
</a>
|
|
<?php endif ?>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="calendar">
|
|
<!-- Dynamically Generated Content -->
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Page Components -->
|
|
|
|
<?php component('manage_appointment_modal', '', ['timezones' => $timezones]) ?>
|
|
|
|
<?php component('manage_appointment_modal') ?>
|
|
|
|
<?php component('manage_unavailable_modal') ?>
|
|
|
|
<?php component('select_google_calendar_modal') ?>
|
|
|
|
<?php component('working_plan_exceptions_modal') ?>
|
|
|
|
<?php section('content') ?>
|
|
|