mirror of
https://github.com/alextselegidis/easyappointments.git
synced 2024-11-10 18:12:26 +03:00
199 lines
8.2 KiB
PHP
Executable file
199 lines
8.2 KiB
PHP
Executable file
<?php
|
|
/**
|
|
* @var string $timezones
|
|
* @var array $privileges
|
|
*/
|
|
?>
|
|
|
|
<?php extend('layouts/backend_layout') ?>
|
|
|
|
<?php section('content') ?>
|
|
|
|
<div class="container-fluid backend-page" id="customers-page">
|
|
<div class="row" id="customers">
|
|
<div id="filter-customers" class="filter-records col col-12 col-md-5">
|
|
<form class="mb-4">
|
|
<div class="input-group">
|
|
<input type="text" class="key form-control">
|
|
|
|
<div class="input-group-addon">
|
|
<div>
|
|
<button class="filter btn btn-outline-secondary" type="submit"
|
|
data-tippy-content="<?= lang('filter') ?>">
|
|
<i class="fas fa-search"></i>
|
|
</button>
|
|
<button class="clear btn btn-outline-secondary" type="button"
|
|
data-tippy-content="<?= lang('clear') ?>">
|
|
<i class="fas fa-redo-alt"></i>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
|
|
<h3><?= lang('customers') ?></h3>
|
|
<div class="results"></div>
|
|
</div>
|
|
|
|
<div class="record-details col-12 col-md-7">
|
|
<div class="btn-toolbar mb-4">
|
|
<div id="add-edit-delete-group" class="btn-group">
|
|
<?php if ($privileges[PRIV_CUSTOMERS]['add'] === TRUE): ?>
|
|
<button id="add-customer" class="btn btn-primary">
|
|
<i class="fas fa-plus-square me-2"></i>
|
|
<?= lang('add') ?>
|
|
</button>
|
|
<?php endif ?>
|
|
|
|
<?php if ($privileges[PRIV_CUSTOMERS]['edit'] === TRUE): ?>
|
|
<button id="edit-customer" class="btn btn-outline-secondary" disabled="disabled">
|
|
<i class="fas fa-edit me-2"></i>
|
|
<?= lang('edit') ?>
|
|
</button>
|
|
<?php endif ?>
|
|
|
|
<?php if ($privileges[PRIV_CUSTOMERS]['delete'] === TRUE): ?>
|
|
<button id="delete-customer" class="btn btn-outline-secondary" disabled="disabled">
|
|
<i class="fas fa-trash-alt me-2"></i>
|
|
<?= lang('delete') ?>
|
|
</button>
|
|
<?php endif ?>
|
|
</div>
|
|
|
|
<div id="save-cancel-group" class="btn-group" style="display:none;">
|
|
<button id="save-customer" class="btn btn-primary">
|
|
<i class="fas fa-check-square me-2"></i>
|
|
<?= lang('save') ?>
|
|
</button>
|
|
<button id="cancel-customer" class="btn btn-outline-secondary">
|
|
<i class="fas fa-ban me-2"></i>
|
|
<?= lang('cancel') ?>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
|
|
<input id="customer-id" type="hidden">
|
|
|
|
<div class="row">
|
|
<div class="col-12 col-md-6" style="margin-left: 0;">
|
|
<h3><?= lang('details') ?></h3>
|
|
|
|
<div id="form-message" class="alert" style="display:none;"></div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label" for="first-name">
|
|
<?= lang('first_name') ?>
|
|
<span class="text-danger">*</span>
|
|
</label>
|
|
<input id="first-name" class="form-control required">
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label" for="last-name">
|
|
<?= lang('last_name') ?>
|
|
<span class="text-danger">*</span>
|
|
</label>
|
|
<input id="last-name" class="form-control required">
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label" for="email">
|
|
<?= lang('email') ?>
|
|
<span class="text-danger">*</span>
|
|
</label>
|
|
<input id="email" class="form-control required">
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label" for="phone-number">
|
|
<?= lang('phone_number') ?>
|
|
<?= setting('require_phone_number') === '1' ? '<span class="text-danger">*</span>' : '' ?></label>
|
|
<input id="phone-number" class="form-control
|
|
<?= setting('require_phone_number') === '1' ? 'required' : '' ?>">
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label" for="address">
|
|
<?= lang('address') ?>
|
|
</label>
|
|
<input id="address" class="form-control">
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label" for="city">
|
|
<?= lang('city') ?>
|
|
|
|
</label>
|
|
<input id="city" class="form-control">
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label" for="zip-code">
|
|
<?= lang('zip_code') ?>
|
|
</label>
|
|
<input id="zip-code" class="form-control">
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label" for="language">
|
|
<?= lang('language') ?>
|
|
<span class="text-danger">*</span>
|
|
</label>
|
|
<select id="language" class="form-control required"></select>
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label" for="timezone">
|
|
<?= lang('timezone') ?>
|
|
<span class="text-danger">*</span>
|
|
</label>
|
|
<?php component('timezone_dropdown', 'id="timezone" class="form-control required"') ?>
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label" for="notes">
|
|
<?= lang('notes') ?>
|
|
</label>
|
|
<textarea id="notes" rows="4" class="form-control"></textarea>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-12 col-md-6">
|
|
<h3><?= lang('appointments') ?></h3>
|
|
<div id="customer-appointments" class="card bg-light border-light"></div>
|
|
<div id="appointment-details" class="card bg-light border-light d-none"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<?php section('content') ?>
|
|
|
|
<?php section('script') ?>
|
|
|
|
<script src="<?= asset_url('assets/vendor/jquery-ui-timepicker-addon/jquery-ui-timepicker-addon.min.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/js/pages/backend_customers_helper.js') ?>"></script>
|
|
<script src="<?= asset_url('assets/js/pages/backend_customers.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')) ?>,
|
|
timezones: <?= json_encode($timezones) ?>,
|
|
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 () {
|
|
BackendCustomers.initialize(true);
|
|
});
|
|
</script>
|
|
|
|
<?php section('script') ?>
|