Proyectos de Subversion LeadersLinked - Backend

Rev

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