2013-06-12 18:31:16 +03:00
|
|
|
<link rel="stylesheet" type="text/css"
|
|
|
|
href="<?php echo $base_url; ?>assets/css/libs/jquery/fullcalendar.css" />
|
|
|
|
|
|
|
|
<script type="text/javascript"
|
|
|
|
src="<?php echo $base_url; ?>assets/js/libs/jquery/fullcalendar.min.js"></script>
|
2013-06-18 19:06:34 +03:00
|
|
|
|
|
|
|
<script type="text/javascript"
|
|
|
|
src="<?php echo $base_url; ?>assets/js/libs/jquery/jquery-ui-timepicker-addon.js"></script>
|
2013-06-12 18:31:16 +03:00
|
|
|
|
|
|
|
<script type="text/javascript"
|
|
|
|
src="<?php echo $base_url; ?>assets/js/backend_calendar.js"></script>
|
|
|
|
|
|
|
|
<script type="text/javascript">
|
|
|
|
var GlobalVariables = {
|
|
|
|
'availableProviders' : <?php echo json_encode($available_providers); ?>,
|
|
|
|
'availableServices' : <?php echo json_encode($available_services); ?>,
|
2013-06-29 00:54:12 +03:00
|
|
|
'baseUrl' : <?php echo '"' . $base_url . '"'; ?>,
|
2013-07-10 16:57:24 +03:00
|
|
|
'bookAdvanceTimeout' : <?php echo $book_advance_timeout; ?>,
|
2013-09-26 19:06:57 +03:00
|
|
|
'editAppointment' : <?php echo json_encode($edit_appointment); ?>,
|
|
|
|
'customers' : <?php echo json_encode($customers); ?>,
|
2013-10-10 19:50:33 +03:00
|
|
|
'secretaryProviders' : <?php echo json_encode($secretary_providers); ?>,
|
2013-09-26 19:06:57 +03:00
|
|
|
'user' : {
|
|
|
|
'id' : <?php echo $user_id; ?>,
|
|
|
|
'email' : <?php echo '"' . $user_email . '"'; ?>,
|
|
|
|
'role_slug' : <?php echo '"' . $role_slug . '"'; ?>,
|
|
|
|
'privileges': <?php echo json_encode($privileges); ?>
|
|
|
|
}
|
2013-06-12 18:31:16 +03:00
|
|
|
};
|
|
|
|
|
2013-12-19 18:28:19 +02:00
|
|
|
var EALang = <?php echo json_encode($this->lang->language); ?>;
|
|
|
|
|
2013-06-12 18:31:16 +03:00
|
|
|
$(document).ready(function() {
|
|
|
|
BackendCalendar.initialize(true);
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<div id="calendar-page">
|
|
|
|
<div id="calendar-toolbar">
|
|
|
|
<div id="calendar-filter">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="select-filter-item">
|
|
|
|
<?php echo $this->lang->line('be_display_calendar'); ?>
|
|
|
|
</label>
|
|
|
|
<select id="select-filter-item"
|
|
|
|
title="<?php echo $this->lang->line('be_select_filter_item_hint'); ?>">
|
|
|
|
</select>
|
2013-06-12 18:31:16 +03:00
|
|
|
</div>
|
|
|
|
|
2013-06-19 22:29:00 +03:00
|
|
|
<div id="calendar-actions">
|
|
|
|
<div class="btn-group">
|
2013-10-11 18:58:46 +03:00
|
|
|
<?php //if ($privileges[PRIV_USERS]['edit'] == TRUE) { ?>
|
2013-10-27 14:53:51 +02:00
|
|
|
<?php if (($role_slug == DB_SLUG_ADMIN || $role_slug == DB_SLUG_PROVIDER)
|
2013-10-27 19:41:37 +02:00
|
|
|
&& $this->config->item('ea_google_sync_feature') == TRUE) { ?>
|
2013-06-19 22:29:00 +03:00
|
|
|
<button id="google-sync" class="btn btn-primary"
|
2013-12-19 18:28:19 +02:00
|
|
|
title="<?php echo $this->lang->line('be_trigger_google_sync_hint'); ?>">
|
2013-06-19 22:29:00 +03:00
|
|
|
<i class="icon-refresh icon-white"></i>
|
2013-12-19 18:28:19 +02:00
|
|
|
<span><?php echo $this->lang->line('be_synchronize'); ?></span>
|
2013-06-19 22:29:00 +03:00
|
|
|
</button>
|
|
|
|
|
|
|
|
<button id="enable-sync" class="btn" data-toggle="button"
|
2013-12-19 18:28:19 +02:00
|
|
|
title="<?php echo $this->lang->line('be_enable_appointment_sync_hint'); ?>">
|
2013-06-19 22:29:00 +03:00
|
|
|
<i class="icon-calendar"></i>
|
2013-12-19 18:28:19 +02:00
|
|
|
<span><?php echo $this->lang->line('be_enable_sync'); ?></span>
|
2013-06-19 22:29:00 +03:00
|
|
|
</button>
|
2013-09-26 19:06:57 +03:00
|
|
|
<?php } ?>
|
2013-06-24 12:52:23 +03:00
|
|
|
|
2013-12-19 18:28:19 +02:00
|
|
|
<button id="reload-appointments" class="btn"
|
|
|
|
title="<?php echo $this->lang->line('be_reload_appointments_hint'); ?>">
|
2013-06-24 12:52:23 +03:00
|
|
|
<i class="icon-repeat"></i>
|
2013-12-19 18:28:19 +02:00
|
|
|
<span><?php echo $this->lang->line('be_reload'); ?></span>
|
2013-06-24 12:52:23 +03:00
|
|
|
</button>
|
2013-06-19 22:29:00 +03:00
|
|
|
</div>
|
2013-06-18 19:06:34 +03:00
|
|
|
|
2013-09-26 19:06:57 +03:00
|
|
|
<?php if ($privileges[PRIV_APPOINTMENTS]['add'] == TRUE) { ?>
|
2013-06-19 22:29:00 +03:00
|
|
|
<div class="btn-group">
|
2013-09-26 19:06:57 +03:00
|
|
|
<button id="insert-appointment" class="btn btn-info"
|
2013-12-19 18:28:19 +02:00
|
|
|
title="<?php echo $this->lang->line('be_new_appointment_hint'); ?>">
|
2013-09-26 19:06:57 +03:00
|
|
|
<i class="icon-plus icon-white"></i>
|
2013-12-19 18:28:19 +02:00
|
|
|
<span><?php echo $this->lang->line('be_appointment'); ?></span>
|
2013-06-19 22:29:00 +03:00
|
|
|
</button>
|
|
|
|
|
|
|
|
<button id="insert-unavailable" class="btn"
|
2013-12-19 18:28:19 +02:00
|
|
|
title="<?php echo $this->lang->line('be_unavailable_periods_hint'); ?>">
|
2013-09-26 19:06:57 +03:00
|
|
|
<i class="icon-plus"></i>
|
2013-12-19 18:28:19 +02:00
|
|
|
<span><?php echo $this->lang->line('be_unavailable'); ?></span>
|
2013-06-19 22:29:00 +03:00
|
|
|
</button>
|
|
|
|
</div>
|
2013-09-26 19:06:57 +03:00
|
|
|
<?php } ?>
|
2013-06-12 18:31:16 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2013-07-09 17:46:48 +03:00
|
|
|
<div id="calendar"></div> <?php // Main calendar container ?>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
|
|
|
|
2013-11-22 18:19:52 +02:00
|
|
|
<?php
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// MANAGE APPOINTMENT
|
|
|
|
//
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
?>
|
2013-06-13 19:25:34 +03:00
|
|
|
<div id="manage-appointment" class="modal hide fade">
|
|
|
|
<div class="modal-header">
|
|
|
|
<button type="button" class="close" data-dismiss="modal"
|
|
|
|
aria-hidden="true">×</button>
|
2013-12-19 18:28:19 +02:00
|
|
|
<h3><?php echo $this->lang->line('be_edit_appointment_title'); ?></h3>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="modal-body">
|
2013-09-27 15:49:29 +03:00
|
|
|
<div class="modal-message alert" style="display: none;"></div>
|
|
|
|
|
2013-06-13 19:25:34 +03:00
|
|
|
<form class="form-horizontal">
|
|
|
|
<fieldset>
|
2013-12-19 18:28:19 +02:00
|
|
|
<legend><?php echo $this->lang->line('fe_appointment_details_title'); ?></legend>
|
2013-06-13 19:25:34 +03:00
|
|
|
|
2013-06-18 19:06:34 +03:00
|
|
|
<input id="appointment-id" type="hidden" />
|
|
|
|
|
2013-06-13 19:25:34 +03:00
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="select-service" class="control-label"><?php echo $this->lang->line('fe_service'); ?> *</label>
|
2013-06-13 19:25:34 +03:00
|
|
|
<div class="controls">
|
2013-11-23 21:10:31 +02:00
|
|
|
<select id="select-service" class="required span4">
|
|
|
|
<?php
|
|
|
|
// Group services by category, only if there is at least one service
|
|
|
|
// with a parent category.
|
|
|
|
foreach($available_services as $service) {
|
|
|
|
if ($service['category_id'] != NULL) {
|
|
|
|
$has_category = TRUE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($has_category) {
|
|
|
|
$grouped_services = array();
|
|
|
|
|
|
|
|
foreach($available_services as $service) {
|
|
|
|
if ($service['category_id'] != NULL) {
|
|
|
|
if (!isset($grouped_services[$service['category_name']])) {
|
|
|
|
$grouped_services[$service['category_name']] = array();
|
|
|
|
}
|
|
|
|
|
|
|
|
$grouped_services[$service['category_name']][] = $service;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// We need the uncategorized services at the end of the list so
|
|
|
|
// we will use another iteration only for the uncategorized services.
|
|
|
|
$grouped_services['uncategorized'] = array();
|
|
|
|
foreach($available_services as $service) {
|
|
|
|
if ($service['category_id'] == NULL) {
|
|
|
|
$grouped_services['uncategorized'][] = $service;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach($grouped_services as $key => $group) {
|
|
|
|
$group_label = ($key != 'uncategorized')
|
|
|
|
? $group[0]['category_name'] : 'Uncategorized';
|
|
|
|
|
|
|
|
if (count($group) > 0) {
|
|
|
|
echo '<optgroup label="' . $group_label . '">';
|
|
|
|
foreach($group as $service) {
|
|
|
|
echo '<option value="' . $service['id'] . '">'
|
|
|
|
. $service['name'] . '</option>';
|
|
|
|
}
|
|
|
|
echo '</optgroup>';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
foreach($available_services as $service) {
|
|
|
|
echo '<option value="' . $service['id'] . '">'
|
|
|
|
. $service['name'] . '</option>';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|
|
|
|
</select>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="select-provider" class="control-label"><?php echo $this->lang->line('fe_provider'); ?> *</label>
|
2013-06-13 19:25:34 +03:00
|
|
|
<div class="controls">
|
2013-11-22 18:19:52 +02:00
|
|
|
<select id="select-provider" class="required span4"></select>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="start-datetime" class="control-label"><?php echo $this->lang->line('be_start_date_time'); ?></label>
|
2013-06-13 19:25:34 +03:00
|
|
|
<div class="controls">
|
2013-06-18 19:06:34 +03:00
|
|
|
<input type="text" id="start-datetime" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="end-datetime" class="control-label"><?php echo $this->lang->line('be_start_date_time'); ?></label>
|
2013-06-18 19:06:34 +03:00
|
|
|
<div class="controls">
|
|
|
|
<input type="text" id="end-datetime" />
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
2013-11-24 17:45:44 +02:00
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="notes" class="control-label"><?php echo $this->lang->line('fe_notes'); ?></label>
|
2013-11-24 17:45:44 +02:00
|
|
|
<div class="controls">
|
|
|
|
<textarea id="appointment-notes" class="span4" rows="3"></textarea>
|
|
|
|
</div>
|
|
|
|
</div>
|
2013-06-13 19:25:34 +03:00
|
|
|
</fieldset>
|
|
|
|
|
2013-09-13 16:21:03 +03:00
|
|
|
<fieldset class="row-fluid">
|
2013-09-26 19:06:57 +03:00
|
|
|
<legend>
|
2013-12-19 18:28:19 +02:00
|
|
|
<?php echo $this->lang->line('fe_customer_details_title'); ?>
|
|
|
|
<button id="new-customer" class="btn btn-mini"
|
|
|
|
title="<?php echo $this->lang->line('be_clear_fields_add_existing_customer_hint'); ?>"
|
|
|
|
type="button"><?php echo $this->lang->line('be_new'); ?>
|
|
|
|
</button>
|
2013-09-26 19:06:57 +03:00
|
|
|
<button id="select-customer" class="btn btn-primary btn-mini"
|
2013-12-19 18:28:19 +02:00
|
|
|
title="<?php echo $this->lang->line('be_pick_existing_customer_hint'); ?>"
|
|
|
|
type="button"><?php echo $this->lang->line('be_select'); ?>
|
|
|
|
</button>
|
|
|
|
<input type="text" id="filter-existing-customers"
|
|
|
|
placeholder="<?php echo $this->lang->line('be_type_to_filter_customers'); ?>"
|
2013-09-26 19:06:57 +03:00
|
|
|
style="display: none;" class="input-medium"/>
|
|
|
|
<div id="existing-customers-list" style="display: none;"></div>
|
|
|
|
</legend>
|
2013-06-13 19:25:34 +03:00
|
|
|
|
2013-06-18 19:06:34 +03:00
|
|
|
<input id="customer-id" type="hidden" />
|
|
|
|
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="span5">
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="first-name" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_first_name'); ?> *</label>
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="controls">
|
2013-10-10 19:50:33 +03:00
|
|
|
<input type="text" id="first-name" class="required" />
|
2013-09-13 16:21:03 +03:00
|
|
|
</div>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
2013-09-13 16:21:03 +03:00
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="last-name" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_last_name'); ?>*</label>
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="controls">
|
|
|
|
<input type="text" id="last-name" class="required" />
|
|
|
|
</div>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
2013-09-13 16:21:03 +03:00
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="email" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_email'); ?>*</label>
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="controls">
|
|
|
|
<input type="text" id="email" class="required" />
|
|
|
|
</div>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
2013-09-13 16:21:03 +03:00
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="phone-number" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_phone_number'); ?>*</label>
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="controls">
|
|
|
|
<input type="text" id="phone-number" class="required" />
|
|
|
|
</div>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="span6">
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="address" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_address'); ?>
|
|
|
|
</label>
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="controls">
|
|
|
|
<input type="text" id="address" />
|
|
|
|
</div>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
2013-09-13 16:21:03 +03:00
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="city" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_city'); ?>
|
|
|
|
</label>
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="controls">
|
|
|
|
<input type="text" id="city" />
|
|
|
|
</div>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
2013-09-13 16:21:03 +03:00
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="zip-code" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_zip_code'); ?>
|
|
|
|
</label>
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="controls">
|
|
|
|
<input type="text" id="zip-code" />
|
|
|
|
</div>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
2013-11-24 17:45:44 +02:00
|
|
|
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="notes" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_notes'); ?></label>
|
2013-09-13 16:21:03 +03:00
|
|
|
<div class="controls">
|
2013-11-24 17:45:44 +02:00
|
|
|
<textarea id="customer-notes" rows="3"></textarea>
|
2013-09-13 16:21:03 +03:00
|
|
|
</div>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</fieldset>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="modal-footer">
|
2013-12-19 18:28:19 +02:00
|
|
|
<button id="save-appointment" class="btn btn-primary">
|
|
|
|
<?php echo $this->lang->line('be_save'); ?>
|
|
|
|
</button>
|
|
|
|
<button id="cancel-appointment" class="btn">
|
|
|
|
<?php echo $this->lang->line('fe_cancel'); ?>
|
|
|
|
</button>
|
2013-07-09 17:46:48 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2013-11-22 18:19:52 +02:00
|
|
|
<?php
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
//
|
|
|
|
// MANAGE UNAVAILALBE
|
|
|
|
//
|
|
|
|
// --------------------------------------------------------------------
|
|
|
|
?>
|
2013-07-09 17:46:48 +03:00
|
|
|
<div id="manage-unavailable" class="modal hide fade">
|
|
|
|
<div class="modal-header">
|
|
|
|
<button type="button" class="close" data-dismiss="modal"
|
|
|
|
aria-hidden="true">×</button>
|
2013-12-19 18:28:19 +02:00
|
|
|
<h3><?php echo $this->lang->line('be_new_unavailable_title'); ?></h3>
|
2013-09-26 19:06:57 +03:00
|
|
|
|
2013-07-09 17:46:48 +03:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="modal-body">
|
2013-09-27 15:49:29 +03:00
|
|
|
<div class="modal-message alert" style="display: none;"></div>
|
|
|
|
|
2013-07-09 17:46:48 +03:00
|
|
|
<form class="form-horizontal">
|
|
|
|
<fieldset>
|
|
|
|
<input id="unavailable-id" type="hidden" />
|
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="unavailable-start" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_start'); ?>
|
|
|
|
</label>
|
2013-07-09 17:46:48 +03:00
|
|
|
<div class="controls">
|
|
|
|
<input type="text" id="unavailable-start" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="unavailable-end" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_end'); ?>
|
|
|
|
</label>
|
2013-07-09 17:46:48 +03:00
|
|
|
<div class="controls">
|
|
|
|
<input type="text" id="unavailable-end" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="control-group">
|
2013-12-19 18:28:19 +02:00
|
|
|
<label for="unavailable-notes" class="control-label">
|
|
|
|
<?php echo $this->lang->line('fe_notes'); ?>
|
|
|
|
</label>
|
2013-07-09 17:46:48 +03:00
|
|
|
<div class="controls">
|
2013-11-23 21:10:31 +02:00
|
|
|
<textarea id="unavailable-notes" rows="3" class="span3"></textarea>
|
2013-07-09 17:46:48 +03:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</fieldset>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="modal-footer">
|
2013-12-19 18:28:19 +02:00
|
|
|
<button id="save-unavailable" class="btn btn-primary">
|
|
|
|
<?php echo $this->lang->line('be_save'); ?>
|
|
|
|
</button>
|
|
|
|
<button id="cancel-unavailable" class="btn">
|
|
|
|
<?php echo $this->lang->line('fe_cancel'); ?>
|
|
|
|
</button>
|
2013-06-13 19:25:34 +03:00
|
|
|
</div>
|
2013-06-12 18:31:16 +03:00
|
|
|
</div>
|