Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 16547 | Rev 16561 | 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');
15760 anderson 32
 
16047 anderson 33
    var ctxchartProgressByDay = document.getElementById("chartProgressByDay").getContext("2d");
15857 anderson 34
 
16560 anderson 35
 
36
 
37
 
38
    //Dbujando la tabla con jrender
39
    $.fn.renderCompetencies = function() {
40
 
41
        if(competencies_selected.length > 0) {
42
 
43
             $('#div-competencies').html($('#competencyTemplate').render(competencies_selected, {
44
                getCompetencyType: (uuid) => competency_types.filter((item) => item.uuid == uuid ? item : false)[0],
45
                getCompetency: (uuid) => competencies.filter((item) => item.uuid == uuid ? item : false)[0],
46
                getBehavior: (uuid) => behaviors.filter((item) => item.uuid == uuid ? item : false)[0]
47
            }));
48
        } else {
49
 
50
 
51
             $('#div-competencies').empty();
52
        }
53
    }
54
 
55
 
56
 
57
 
58
 
59
 
15857 anderson 60
    // draw empty chart
16047 anderson 61
    var chartProgressByDay = new Chart(ctxchartProgressByDay, {
16236 anderson 62
        type: 'line',
15857 anderson 63
        data: {
16218 anderson 64
            labels: [],
15857 anderson 65
            datasets: [
66
                {
16232 anderson 67
                	label : 'LABEL_CONTACT_PROGRESS_BY_DAY',
16090 anderson 68
         			backgroundColor: '#E69090',
69
                    borderColor: '#E69090',
70
                    borderWidth: 1,
71
                    fill: false,
16221 anderson 72
                    data : []
16090 anderson 73
              	},
15857 anderson 74
            ]
75
        },
76
        options: {
77
            tooltips: {
78
                mode: 'index',
79
                intersect: false
15760 anderson 80
            },
15857 anderson 81
            scales: {
82
                yAxes: [{
83
                    ticks: {
84
                        beginAtZero:true
15760 anderson 85
                    }
15857 anderson 86
                }]
87
            }
88
        }
89
    });
16047 anderson 90
 
91
    $.fn.reload = function() {
92
        NProgress.start();
93
        $.ajax({
94
            'dataType'  : 'json',
95
            'accept'    : 'application/json',
96
            'method'    : 'get',
97
            'url'       : '$routeOverview',
98
            'data'      :  {
99
                'startDate' : startDate,
100
                'endDate' : endDate
101
            },
102
        }).done(function(response) {
16221 anderson 103
            if(response['success']) {
16537 anderson 104
                console.log(response.data[0]);
16219 anderson 105
                chartProgressByDay.data.labels = response.data.added_on;
16220 anderson 106
                chartProgressByDay.data.datasets[0].data = response.data.total_by_day;
16221 anderson 107
                chartProgressByDay.update();
16031 anderson 108
            }else{
16183 anderson 109
                $.fn.showError(response);
16031 anderson 110
            }
15987 anderson 111
        }).fail(function( jqXHR, textStatus, errorThrown) {
112
            $.fn.showError(textStatus);
113
        }).always(function() {
114
            NProgress.done();
15872 anderson 115
        });
15987 anderson 116
        return false;
15872 anderson 117
    }
118
 
16028 anderson 119
    $('#filterdate').daterangepicker({
120
        maxDate: new Date(),
121
        locale: {
122
            format: 'DD/MM/YYYY',
123
            applyLabel: 'Aplicar',
124
            cancelLabel: 'Cancelar',
125
            daysOfWeek: ['Do', 'Lu','Ma', 'Mi', 'Ju', 'Vi', 'Sa'],
126
            monthNames: ['Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo',
127
                'Junio',
128
                'Agosto',
129
                'Septiembre',
130
                'Octubre',
131
                'Noviembre',
132
                'Diciembre'
133
            ],
134
        }
135
    });
136
 
16381 anderson 137
    //Datatable
138
 
16435 anderson 139
    $('#gridTable').dataTable({
16420 anderson 140
        'processing': true,
141
        'serverSide': true,
16436 anderson 142
        'searching': true,
143
        'order': [[ 0, 'asc' ]],
144
        'ordering':  true,
145
        'ordenable' : true,
146
        'responsive': true,
147
        'select' : false,
148
        'paging': true,
149
        'pagingType': 'simple_numbers',
16439 anderson 150
        'ajax': {
16441 anderson 151
            'url' : '$routeOverview',
152
            'type' : 'get',
153
            'beforeSend': function (request) {
154
                NProgress.start();
155
            },
16460 anderson 156
            'dataFilter': function(response) {
157
                var response = jQuery.parseJSON( response );
16458 anderson 158
 
16460 anderson 159
                var json                = {};
160
                json.recordsTotal       = 0;
161
                json.recordsFiltered    = 0;
162
                json.data               = [];
16441 anderson 163
 
16460 anderson 164
                if(response.success) {
16482 anderson 165
                    json.recordsTotal       = response.data.total;
166
                    json.recordsFiltered    = response.data.total;
16540 anderson 167
                    json.data               = response.items;
16460 anderson 168
                } else {
169
                    $.fn.showError(response.data)
170
                }
171
                return JSON.stringify( json );
172
            }
16441 anderson 173
        },
16461 anderson 174
        // 'drawCallback': function( settings ) {
175
        //         NProgress.done();
176
        // },
16441 anderson 177
        'aoColumns': [
16532 anderson 178
            { 'mDataProp': "first_name"},
16502 anderson 179
            { 'mDataProp': "last_name" },
16441 anderson 180
            { 'mDataProp': "email" },
181
            { 'mDataProp': "total_by_day" },
182
            { 'mDataProp': "added_on" },
16413 anderson 183
         ]
16421 anderson 184
 
16412 anderson 185
    });
16411 anderson 186
 
16029 anderson 187
    $('#filterdate').on('apply.daterangepicker', function(ev, picker) {
188
        startDate = picker.startDate.format('YYYY-MM-DD');
189
        endDate =picker.endDate.format('YYYY-MM-DD');
16237 anderson 190
 
191
        $.ajax({
192
            'dataType'  : 'json',
193
            'accept'    : 'application/json',
194
            'method'    : 'post',
195
            'url'       :  '$routeOverview',
196
            'data'      :  {
197
                'startDate' : startDate,
198
                'endDate' : endDate
199
            },
200
            'processData': false,
201
            'contentType': false,
202
            success: function (response) {
203
                console.log('enviado');
204
            }
205
        });
16029 anderson 206
        $.fn.reload();
207
    });
208
 
15875 anderson 209
    $.fn.reload();
15873 anderson 210
 
15857 anderson 211
});
15760 anderson 212
JS;
213
$this->inlineScript()->captureEnd();
214
?>
215
 
216
 
217
 
15857 anderson 218
<section class="content">
15759 anderson 219
    <div class="container-fluid">
220
        <div class="row">
15857 anderson 221
            <div class="col-12" id="row-list">
15759 anderson 222
                <div class="card">
223
                    <div class="card-header">
16543 anderson 224
                        <h2>LABEL_DAILY_PROGRESS_CHART</h2>
15857 anderson 225
                        <div class="form-group">
15859 anderson 226
                            <label>LABEL_DATE_RANGE</label>
15857 anderson 227
 
228
                            <div class="input-group">
229
                                <div class="input-group-prepend">
230
                                    <span class="input-group-text"><i class="far fa-calendar"></i></span>
231
                                </div>
232
                                <input type="text" class="form-control float-right" name="filterdate" id="filterdate">
233
                            </div>
234
                            <!-- /.input group -->
235
                        </div>
15759 anderson 236
                    </div>
237
                    <div class="card-body">
15857 anderson 238
                        <div class="row">
16450 anderson 239
                            <div class="col-lg-12 col-12 chart">
15988 anderson 240
                                <canvas id="chartProgressByDay" style="min-height: 250px; height: 250px; max-height: 250px; max-width: 100%;"></canvas>
15857 anderson 241
                            </div>
16448 anderson 242
                        </div>
15759 anderson 243
                    </div>
244
                </div>
245
            </div>
16424 anderson 246
        </div>
16450 anderson 247
</section>
16376 anderson 248
 
16560 anderson 249
 
250
<script id="job-description-template" type="text/x-jsrender">
251
    <div class="card">
252
        <div class="card-body">
253
            <h4 class="text-center">{{:form}}</h4>
254
            <table class="table table-bordered">
255
                <tr>
256
                    <th>LABEL_LAST_DATE</th>
257
                    <th>LABEL_TYPE</th>
258
                </tr>
259
                <tr>
260
                    <td>{{:last_date}}</td>
261
                    <td>{{:type}}</td>
262
                </tr>
263
 
264
                <tr>
265
                    <th>LABEL_SUPERVISOR</th>
266
                    <th>LABEL_EMPLOYEE</th>
267
                </tr>
268
                <tr>
269
                    <td>{{:supervisor}}</td>
270
                    <td>{{:employee}}</td>
271
                </tr>
272
            </table>
273
            <br/>
274
 
275
            <p class="card-text"><b>LABEL_OBJECTIVES</b></p>
276
            <p class="card-text">{{:objectives}}</p>
277
            <p class="card-text"><b>LABEL_FUNCTIONS</b></p>
278
            <p class="card-text">{{:functions}}</p>
279
 
280
        </div>
281
    </div>
282
</script>
283
 
284
<!-- <section class="content">
16450 anderson 285
    <div class="container-fluid">
16399 anderson 286
        <div class="row">
287
            <div class="col-12" id="row-list">
288
                <div class="card">
289
                    <div class="card-header">
16546 anderson 290
                        <h2>LABEL_CONTACT_JOURNAL_PROGRESS</h2>
16399 anderson 291
                        <div class="form-group">
292
                        </div>
293
                    </div>
294
                    <div class="card-body">
295
                        <div class="row">
296
                            <div class="col-lg-12 col-12 chart">
16451 anderson 297
                                <table id="gridTable" class="table table-striped table-hover">
16399 anderson 298
                                    <thead>
299
                                        <tr>
16547 anderson 300
                                            <th>LABEL_FIRST_NAME</th>
301
                                            <th>LABEL_LAST_NAME</th>
302
                                            <th>LABEL_EMAIL</th>
303
                                            <th>LABEL_ADDED</th>
304
                                            <th>LABEL_ADDED_DATE</th>
16399 anderson 305
                                        </tr>
306
                                    </thead>
16451 anderson 307
                                </table>
16399 anderson 308
                            </div>
309
                        </div>
310
                    </div>
311
                </div>
312
            </div>
313
        </div>
16560 anderson 314
</section> -->