Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 16588 | Rev 16590 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
15760 anderson 1
<?php
15759 anderson 2
 
16040 anderson 3
$routeOverview = $this->url('discovery-contacts/progress-by-day');
15760 anderson 4
$this->headLink()->appendStylesheet($this->basePath('plugins/nprogress/nprogress.css'));
5
$this->inlineScript()->appendFile($this->basePath('plugins/nprogress/nprogress.js'));
15857 anderson 6
$this->inlineScript()->appendFile($this->basePath('plugins/jsrender/jsrender.js'));
15760 anderson 7
 
15857 anderson 8
$this->headLink()->appendStylesheet($this->basePath('plugins/fontawesome-free/css/all.min.css'));
9
$this->headLink()->appendStylesheet($this->basePath('plugins/daterangepicker/daterangepicker.css'));
10
$this->inlineScript()->appendFile($this->basePath('plugins/moment/moment.min.js'));
11
$this->inlineScript()->appendFile($this->basePath('plugins/daterangepicker/daterangepicker.js'));
15760 anderson 12
 
16370 anderson 13
$this->headLink()->appendStylesheet($this->basePath('plugins/datatables-bs4/css/dataTables.bootstrap4.min.css'));
15760 anderson 14
 
16370 anderson 15
$this->inlineScript()->appendFile($this->basePath('plugins/datatables/jquery.dataTables.min.js'));
16
$this->inlineScript()->appendFile($this->basePath('plugins/datatables-bs4/js/dataTables.bootstrap4.min.js'));
17
 
18
 
15857 anderson 19
$this->inlineScript()->appendFile($this->basePath('plugins/chart.js/chart.js'));
20
$this->inlineScript()->appendFile($this->basePath('plugins/chartjs-plugin-datalabels/chartjs-plugin-datalabels.js'));
15760 anderson 21
 
22
echo <<<CSS
23
CSS;
24
$this->headStyle()->captureEnd();
25
 
26
$this->inlineScript()->captureStart();
27
echo <<<JS
15857 anderson 28
jQuery( document ).ready(function( $ ) {
15760 anderson 29
 
15857 anderson 30
    var startDate   = moment().format('YYYY-MM-DD');
31
    var endDate     = moment().format('YYYY-MM-DD');
16561 anderson 32
    var competencies_selected = new Array();
15760 anderson 33
 
16047 anderson 34
    var ctxchartProgressByDay = document.getElementById("chartProgressByDay").getContext("2d");
15857 anderson 35
 
16560 anderson 36
 
37
 
38
 
39
    //Dbujando la tabla con jrender
16563 anderson 40
    // $.fn.renderCompetencies = function() {
16560 anderson 41
 
16563 anderson 42
    //     if(competencies_selected.length > 0) {
16560 anderson 43
 
16563 anderson 44
    //          $('#div-competencies').html($('#competencyTemplate').render(competencies_selected, {
45
    //             getCompetencyType: (uuid) => competency_types.filter((item) => item.uuid == uuid ? item : false)[0],
46
    //             getCompetency: (uuid) => competencies.filter((item) => item.uuid == uuid ? item : false)[0],
47
    //             getBehavior: (uuid) => behaviors.filter((item) => item.uuid == uuid ? item : false)[0]
48
    //         }));
49
    //     } else {
16560 anderson 50
 
51
 
16563 anderson 52
    //          $('#div-competencies').empty();
53
    //     }
54
    // }
55
 
16569 anderson 56
 
16565 anderson 57
 
16560 anderson 58
 
59
 
60
 
61
 
62
 
63
 
16564 anderson 64
 
15857 anderson 65
    // draw empty chart
16047 anderson 66
    var chartProgressByDay = new Chart(ctxchartProgressByDay, {
16236 anderson 67
        type: 'line',
15857 anderson 68
        data: {
16218 anderson 69
            labels: [],
15857 anderson 70
            datasets: [
71
                {
16232 anderson 72
                	label : 'LABEL_CONTACT_PROGRESS_BY_DAY',
16090 anderson 73
         			backgroundColor: '#E69090',
74
                    borderColor: '#E69090',
75
                    borderWidth: 1,
76
                    fill: false,
16221 anderson 77
                    data : []
16090 anderson 78
              	},
15857 anderson 79
            ]
80
        },
81
        options: {
82
            tooltips: {
83
                mode: 'index',
84
                intersect: false
15760 anderson 85
            },
15857 anderson 86
            scales: {
87
                yAxes: [{
88
                    ticks: {
89
                        beginAtZero:true
15760 anderson 90
                    }
15857 anderson 91
                }]
92
            }
93
        }
94
    });
16047 anderson 95
 
96
    $.fn.reload = function() {
97
        NProgress.start();
98
        $.ajax({
99
            'dataType'  : 'json',
100
            'accept'    : 'application/json',
101
            'method'    : 'get',
102
            'url'       : '$routeOverview',
103
            'data'      :  {
104
                'startDate' : startDate,
105
                'endDate' : endDate
106
            },
107
        }).done(function(response) {
16221 anderson 108
            if(response['success']) {
16579 anderson 109
                console.log(response.items[0].demo);
16572 anderson 110
                var items = response.items;
16219 anderson 111
                chartProgressByDay.data.labels = response.data.added_on;
16220 anderson 112
                chartProgressByDay.data.datasets[0].data = response.data.total_by_day;
16221 anderson 113
                chartProgressByDay.update();
16569 anderson 114
 
115
 
16582 anderson 116
 
16569 anderson 117
 
118
 
119
                //Dibujamos la tabla
120
                var myTemplate = $.templates("#personTmpl");
121
 
16582 anderson 122
                response.items.forEach(item => {
123
                    console.log(item.demo);
124
                    var people = [
125
                        {
16585 anderson 126
                            name: item.demo
16582 anderson 127
                        }
128
                    ];
16583 anderson 129
                    var html = myTemplate.render(people);
16585 anderson 130
                    $("#peopleList").html(html);
16582 anderson 131
                });
16577 anderson 132
 
133
 
16583 anderson 134
 
16569 anderson 135
 
136
 
137
 
138
 
139
 
140
 
141
 
142
 
143
 
144
 
16031 anderson 145
            }else{
16183 anderson 146
                $.fn.showError(response);
16031 anderson 147
            }
15987 anderson 148
        }).fail(function( jqXHR, textStatus, errorThrown) {
149
            $.fn.showError(textStatus);
150
        }).always(function() {
151
            NProgress.done();
15872 anderson 152
        });
15987 anderson 153
        return false;
15872 anderson 154
    }
155
 
16028 anderson 156
    $('#filterdate').daterangepicker({
157
        maxDate: new Date(),
158
        locale: {
159
            format: 'DD/MM/YYYY',
160
            applyLabel: 'Aplicar',
161
            cancelLabel: 'Cancelar',
162
            daysOfWeek: ['Do', 'Lu','Ma', 'Mi', 'Ju', 'Vi', 'Sa'],
163
            monthNames: ['Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo',
164
                'Junio',
165
                'Agosto',
166
                'Septiembre',
167
                'Octubre',
168
                'Noviembre',
169
                'Diciembre'
170
            ],
171
        }
172
    });
173
 
16381 anderson 174
    //Datatable
175
 
16435 anderson 176
    $('#gridTable').dataTable({
16420 anderson 177
        'processing': true,
178
        'serverSide': true,
16436 anderson 179
        'searching': true,
180
        'order': [[ 0, 'asc' ]],
181
        'ordering':  true,
182
        'ordenable' : true,
183
        'responsive': true,
184
        'select' : false,
185
        'paging': true,
186
        'pagingType': 'simple_numbers',
16439 anderson 187
        'ajax': {
16441 anderson 188
            'url' : '$routeOverview',
189
            'type' : 'get',
190
            'beforeSend': function (request) {
191
                NProgress.start();
192
            },
16460 anderson 193
            'dataFilter': function(response) {
194
                var response = jQuery.parseJSON( response );
16458 anderson 195
 
16460 anderson 196
                var json                = {};
197
                json.recordsTotal       = 0;
198
                json.recordsFiltered    = 0;
199
                json.data               = [];
16441 anderson 200
 
16460 anderson 201
                if(response.success) {
16482 anderson 202
                    json.recordsTotal       = response.data.total;
203
                    json.recordsFiltered    = response.data.total;
16540 anderson 204
                    json.data               = response.items;
16460 anderson 205
                } else {
206
                    $.fn.showError(response.data)
207
                }
208
                return JSON.stringify( json );
209
            }
16441 anderson 210
        },
16461 anderson 211
        // 'drawCallback': function( settings ) {
212
        //         NProgress.done();
213
        // },
16441 anderson 214
        'aoColumns': [
16532 anderson 215
            { 'mDataProp': "first_name"},
16502 anderson 216
            { 'mDataProp': "last_name" },
16441 anderson 217
            { 'mDataProp': "email" },
218
            { 'mDataProp': "total_by_day" },
219
            { 'mDataProp': "added_on" },
16413 anderson 220
         ]
16421 anderson 221
 
16412 anderson 222
    });
16411 anderson 223
 
16029 anderson 224
    $('#filterdate').on('apply.daterangepicker', function(ev, picker) {
225
        startDate = picker.startDate.format('YYYY-MM-DD');
226
        endDate =picker.endDate.format('YYYY-MM-DD');
16237 anderson 227
 
228
        $.ajax({
229
            'dataType'  : 'json',
230
            'accept'    : 'application/json',
231
            'method'    : 'post',
232
            'url'       :  '$routeOverview',
233
            'data'      :  {
234
                'startDate' : startDate,
235
                'endDate' : endDate
236
            },
237
            'processData': false,
238
            'contentType': false,
239
            success: function (response) {
240
                console.log('enviado');
241
            }
242
        });
16029 anderson 243
        $.fn.reload();
244
    });
245
 
15875 anderson 246
    $.fn.reload();
15873 anderson 247
 
15857 anderson 248
});
15760 anderson 249
JS;
250
$this->inlineScript()->captureEnd();
251
?>
252
 
253
 
254
 
15857 anderson 255
<section class="content">
15759 anderson 256
    <div class="container-fluid">
257
        <div class="row">
15857 anderson 258
            <div class="col-12" id="row-list">
15759 anderson 259
                <div class="card">
260
                    <div class="card-header">
16543 anderson 261
                        <h2>LABEL_DAILY_PROGRESS_CHART</h2>
15857 anderson 262
                        <div class="form-group">
15859 anderson 263
                            <label>LABEL_DATE_RANGE</label>
15857 anderson 264
 
265
                            <div class="input-group">
266
                                <div class="input-group-prepend">
267
                                    <span class="input-group-text"><i class="far fa-calendar"></i></span>
268
                                </div>
269
                                <input type="text" class="form-control float-right" name="filterdate" id="filterdate">
270
                            </div>
271
                            <!-- /.input group -->
272
                        </div>
15759 anderson 273
                    </div>
274
                    <div class="card-body">
15857 anderson 275
                        <div class="row">
16450 anderson 276
                            <div class="col-lg-12 col-12 chart">
15988 anderson 277
                                <canvas id="chartProgressByDay" style="min-height: 250px; height: 250px; max-height: 250px; max-width: 100%;"></canvas>
15857 anderson 278
                            </div>
16448 anderson 279
                        </div>
15759 anderson 280
                    </div>
281
                </div>
282
            </div>
16424 anderson 283
        </div>
16450 anderson 284
</section>
16376 anderson 285
 
16567 anderson 286
<div id="peopleList"></div>
287
 
288
<script id="personTmpl" type="text/x-jsrender">
16588 anderson 289
    <section class="content">
290
        <div class="container-fluid">
291
            <div class="row">
292
                <div class="col-12" id="row-list">
293
                    <div class="card">
294
                        <div class="card-header">
295
                            <h2>LABEL_CONTACT_JOURNAL_PROGRESS</h2>
296
                            <div class="form-group">
297
                            </div>
298
                        </div>
299
                        <div class="card-body">
300
                            <div class="row">
301
                                <div class="col-lg-12 col-12 chart">
302
                                    <table class="table table-bordered ">
303
                                        <thead>
304
                                            <tr>
305
                                                <th>Usuarios</th>
306
                                                <th>{{:name}}</th>
307
                                            </tr>
308
                                        </thead>
309
                                        <tbody>
310
                                            <tr>
311
                                                <td></td>
312
                                            </tr>
313
                                        </tbody>
314
                                    </table>
315
                                </div>
316
                            </div>
317
                        </div>
318
                    </div>
319
                </div>
320
            </div>
16589 anderson 321
</div>
322
</div>
16588 anderson 323
        </section>
16563 anderson 324
</script>
16560 anderson 325
 
326
<!-- <section class="content">
16450 anderson 327
    <div class="container-fluid">
16399 anderson 328
        <div class="row">
329
            <div class="col-12" id="row-list">
330
                <div class="card">
331
                    <div class="card-header">
16546 anderson 332
                        <h2>LABEL_CONTACT_JOURNAL_PROGRESS</h2>
16399 anderson 333
                        <div class="form-group">
334
                        </div>
335
                    </div>
336
                    <div class="card-body">
337
                        <div class="row">
338
                            <div class="col-lg-12 col-12 chart">
16451 anderson 339
                                <table id="gridTable" class="table table-striped table-hover">
16399 anderson 340
                                    <thead>
341
                                        <tr>
16547 anderson 342
                                            <th>LABEL_FIRST_NAME</th>
343
                                            <th>LABEL_LAST_NAME</th>
344
                                            <th>LABEL_EMAIL</th>
345
                                            <th>LABEL_ADDED</th>
346
                                            <th>LABEL_ADDED_DATE</th>
16399 anderson 347
                                        </tr>
348
                                    </thead>
16451 anderson 349
                                </table>
16399 anderson 350
                            </div>
351
                        </div>
352
                    </div>
353
                </div>
354
            </div>
355
        </div>
16560 anderson 356
</section> -->