raspisms/templates/phone/list.php

221 lines
9.3 KiB
PHP
Raw Normal View History

2019-11-12 05:16:59 +01:00
<?php
//Template dashboard
$this->render('incs/head', ['title' => 'Phones - Show All'])
?>
<div id="wrapper">
<?php
$this->render('incs/nav', ['page' => 'phones'])
2019-11-12 05:16:59 +01:00
?>
<div id="page-wrapper">
<div class="container-fluid">
<!-- Page Heading -->
<div class="row">
<div class="col-lg-12">
<h1 class="page-header">
Dashboard <small>Téléphones</small>
</h1>
<ol class="breadcrumb">
<li>
<i class="fa fa-dashboard"></i> <a href="<?php echo \descartes\Router::url('Dashboard', 'show'); ?>">Dashboard</a>
</li>
<li class="active">
<i class="fa fa-phone"></i> Téléphones
</li>
</ol>
</div>
</div>
<!-- /.row -->
<div class="row">
<div class="col-lg-12">
<div class="panel panel-default">
<div class="panel-heading">
<h3 class="panel-title"><i class="fa fa-phone fa-fw"></i> Liste des téléphones</h3>
</div>
<div class="panel-body">
<form method="GET">
<div class="table-responsive">
<table class="table table-bordered table-hover table-striped datatable" id="table-phones">
<thead>
<tr>
<th>ID</th>
<th>Nom</th>
2023-02-05 23:11:58 +01:00
<th>Priorité</th>
2021-02-04 16:44:13 +01:00
<th>Type de téléphone</th>
<th>Callbacks</th>
2023-02-04 01:45:59 +01:00
<th>Limites</th>
<th class="checkcolumn"><input type="checkbox" id="check-all"/></th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
<div>
<div class="col-xs-6 no-padding">
<a class="btn btn-success" href="<?php echo \descartes\Router::url('Phone', 'add'); ?>"><span class="fa fa-plus"></span> Ajouter un téléphone</a>
2020-02-21 04:07:33 +01:00
</div>
<div class="text-right col-xs-6 no-padding">
<strong>Action pour la séléction :</strong>
<button class="btn btn-default" type="submit" formaction="<?php echo \descartes\Router::url('Phone', 'update_status', ['csrf' => $_SESSION['csrf']]); ?>"><span class="fa fa-refresh"></span> Rafraichir le status</button>
2023-02-04 01:15:36 +01:00
<button class="btn btn-default" type="submit" formaction="<?php echo \descartes\Router::url('Phone', 'edit'); ?>"><span class="fa fa-edit"></span> Modifier</button>
<button class="btn btn-default btn-confirm" type="submit" formaction="<?php echo \descartes\Router::url('Phone', 'delete', ['csrf' => $_SESSION['csrf']]); ?>"><span class="fa fa-trash-o"></span> Supprimer</button>
2019-11-12 05:16:59 +01:00
</div>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<script>
jQuery(document).ready(function ()
{
jQuery('.datatable').DataTable({
"pageLength": 25,
"lengthMenu": [[25, 50, 100, 1000, 10000, -1], [25, 50, 100, 1000, 10000, "All"]],
"language": {
"url": HTTP_PWD + "/assets/js/datatables/french.json",
},
"columnDefs": [{
'targets': 'checkcolumn',
'orderable': false,
}],
"ajax": {
'url': '<?php echo \descartes\Router::url('Phone', 'list_json'); ?>',
'dataSrc': 'data',
},
"columns" : [
{data: 'id', render: jQuery.fn.dataTable.render.text()},
{
data: 'name',
render: function (data, type, row, meta) {
html = jQuery.fn.dataTable.render.text().display(data)
switch (row.status)
{
case 'available':
html += ' - <span class="text-success">Disponible</span>'
break;
case 'unavailable':
html += ' - <span class="text-danger">Indisponible</span>'
break;
case 'no_credit':
html += ' - <span class="text-warning">Plus de crédit</span>'
break;
}
return html
},
},
2023-02-05 23:11:58 +01:00
{data: 'priority', render: jQuery.fn.dataTable.render.text()},
2021-01-14 03:25:58 +01:00
{data: 'adapter', render: jQuery.fn.dataTable.render.text()},
{
data: '_',
render: function (data, type, row, meta) {
2021-08-28 02:07:30 +02:00
var html = '';
if (row.callback_reception) {
2021-08-28 02:07:30 +02:00
html += '<div class="bold">Réception d\'un SMS : </div>';
html += '<div><code>' + jQuery.fn.dataTable.render.text().display(row.callback_reception) + '</code></div>';
html += '<br/>';
}
if (row.callback_status) {
2021-08-28 02:07:30 +02:00
html += '<div class="bold">Changement de statut d\'un SMS : </div>';
html += '<div><code>' + jQuery.fn.dataTable.render.text().display(row.callback_status) + '</code></div>';
html += '<br/>';
}
2021-03-24 00:22:17 +01:00
2021-03-24 00:22:17 +01:00
if (row.callback_inbound_call) {
2021-08-28 02:07:30 +02:00
html += '<div class="bold">Notification d\'appel entrant : </div>';
html += '<div><code>' + jQuery.fn.dataTable.render.text().display(row.callback_inbound_call) + '</code></div>';
html += '<br/>';
2021-03-24 00:22:17 +01:00
}
if (row.callback_end_call) {
2021-08-28 02:07:30 +02:00
html += '<div class="bold">Notification de fin d\'appel : </div>';
html += '<div><code>' + jQuery.fn.dataTable.render.text().display(row.callback_end_call) + '</code></div>';
2021-03-24 00:22:17 +01:00
}
return html;
},
},
2023-02-04 01:45:59 +01:00
{
data: 'limits',
render: function (limits) {
if (!limits.length)
{
return 'Pas de limites.';
}
var html = '';
for (limit of limits)
{
switch (limit.startpoint)
{
case "today" :
var startpoint = 'Par jour';
break;
case "-24 hours" :
var startpoint = '24 heures glissantes';
break;
case "this week midnight" :
var startpoint = 'Cette semaine';
break;
case "-7 days" :
var startpoint = '7 jours glissants';
break;
case "this week midnight -1 week" :
var startpoint = 'Ces deux dernières semaines';
break;
case "-14 days" :
var startpoint = '14 jours glissants';
break;
case "this month midnight" :
var startpoint = 'Ce mois';
break;
case "-1 month" :
var startpoint = '1 mois glissant';
break;
case "-28 days" :
var startpoint = '28 jours glissants';
break;
case "-30 days" :
var startpoint = '30 jours glissants';
break;
case "-31 days" :
var startpoint = '31 jours glissants';
break;
default :
var startpoint = 'Inconnu'
}
html += '<div><span class="bold">' + jQuery.fn.dataTable.render.text().display(startpoint) + ' : </span>' + jQuery.fn.dataTable.render.text().display(limit.volume) + '</div>';
}
return html;
},
},
{
data: 'id',
render: function (data, type, row, meta) {
return '<input name="ids[]" type="checkbox" value="' + data + '">';
},
},
],
"deferRender": true
});
});
2019-11-12 05:16:59 +01:00
</script>
<?php
$this->render('incs/footer');