Proyectos de Subversion LeadersLinked - Backend

Rev

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

Rev Autor Línea Nro. Línea
3468 eleazar 1
<?php
1709 eleazar 2
$acl            = $this->viewModel()->getRoot()->getVariable('acl');
3
$currentUser    = $this->currentUserHelper();
4
$roleName       = $currentUser->getUserTypeId();
5
 
7957 eleazar 6
$routeIndex = $this->url('recruitment-and-selection/interview/form');
7961 eleazar 7
$routeAdd = $this->url('recruitment-and-selection/interview/form/add', ['vacancy_uuid' => 'UUID_PLACEHOLDER']);
3573 eleazar 8
$routeVacancy = $this->url('recruitment-and-selection/interview/vacancy', ['vacancy_uuid' => 'UUID_PLACEHOLDER']);
4367 eleazar 9
$routeType = $this->url('recruitment-and-selection/interview/type', ['candidate_uuid' => 'UUID_PLACEHOLDER']);
1877 eleazar 10
 
1827 eleazar 11
$allowAdd = $acl->isAllowed($roleName, 'recruitment-and-selection/interview/form/add') ? 1 : 0;
3533 eleazar 12
$allowEdit = $acl->isAllowed($roleName, 'recruitment-and-selection/interview/form/edit') ? 1 : 0;
13
$allowDelete = $acl->isAllowed($roleName, 'recruitment-and-selection/interview/form/delete') ? 1 : 0;
3534 eleazar 14
$allowReport = $acl->isAllowed($roleName, 'recruitment-and-selection/interview/report') ? 1 : 0;
1709 eleazar 15
$this->headLink()->appendStylesheet($this->basePath('plugins/nprogress/nprogress.css'));
16
$this->inlineScript()->appendFile($this->basePath('plugins/nprogress/nprogress.js'));
17
 
18
 
19
$this->inlineScript()->appendFile($this->basePath('plugins/bootbox/bootbox.min.js'));
20
 
21
 
1885 eleazar 22
$this->inlineScript()->appendFile($this->basePath('plugins/ckeditor/ckeditor.js'));
1709 eleazar 23
$this->inlineScript()->appendFile($this->basePath('plugins/jquery-validation/jquery.validate.js'));
24
$this->inlineScript()->appendFile($this->basePath('plugins/jquery-validation/additional-methods.js'));
25
$this->inlineScript()->appendFile($this->basePath('plugins/jquery-validation/localization/messages_es.js'));
26
 
27
$this->headLink()->appendStylesheet($this->basePath('plugins/datatables-bs4/css/dataTables.bootstrap4.min.css'));
28
$this->headLink()->appendStylesheet($this->basePath('plugins/datatables-responsive/css/responsive.bootstrap4.min.css'));
29
 
30
$this->inlineScript()->appendFile($this->basePath('plugins/datatables/jquery.dataTables.min.js'));
31
$this->inlineScript()->appendFile($this->basePath('plugins/datatables-bs4/js/dataTables.bootstrap4.min.js'));
32
$this->inlineScript()->appendFile($this->basePath('plugins/datatables-responsive/js/dataTables.responsive.min.js'));
33
$this->inlineScript()->appendFile($this->basePath('plugins/datatables-responsive/js/responsive.bootstrap4.min.js'));
34
 
35
$this->inlineScript()->appendFile($this->basePath('plugins/jquery-validation/jquery.validate.js'));
36
$this->inlineScript()->appendFile($this->basePath('plugins/jquery-validation/additional-methods.js'));
37
$this->inlineScript()->appendFile($this->basePath('plugins/jquery-validation/localization/messages_es.js'));
38
 
39
$this->headLink()->appendStylesheet($this->basePath('plugins/bootstrap4-toggle/css/bootstrap4-toggle.min.css'));
40
$this->inlineScript()->appendFile($this->basePath('plugins/bootstrap4-toggle/js/bootstrap4-toggle.min.js'));
41
 
42
$this->inlineScript()->appendFile($this->basePath('plugins/bootstrap-confirmation/dist/bootstrap-confirmation.js'));
43
$this->headLink()->appendStylesheet($this->basePath('plugins/bootstrap-checkbox/awesome-bootstrap-checkbox.css'));
44
 
45
$this->inlineScript()->appendFile($this->basePath('plugins/moment/moment-with-locales.min.js'));
46
$this->headLink()->appendStylesheet($this->basePath('plugins/bootstrap-datetimepicker/css/bootstrap-datetimepicker.css'));
47
$this->inlineScript()->appendFile($this->basePath('plugins/bootstrap-datetimepicker/js/bootstrap-datetimepicker.min.js'));
48
 
1887 eleazar 49
 
2746 eleazar 50
$this->inlineScript()->appendFile($this->basePath('plugins/select2/js/select2.js'));
51
$this->inlineScript()->appendFile($this->basePath('plugins/select2/js/i18n/es.js'));
52
$this->headLink()->appendStylesheet($this->basePath('plugins/select2/css/select2.css'));
53
 
1887 eleazar 54
$this->headLink()->appendStylesheet($this->basePath('plugins/select2-bootstrap4-theme/select2-bootstrap4.css'));
1709 eleazar 55
 
2052 eleazar 56
// JsRender //
57
$this->inlineScript()->appendFile($this->basePath('plugins/jsrender/jsrender.min.js'));
1709 eleazar 58
 
4158 eleazar 59
$status_acepted = \LeadersLinked\Model\RecruitmentSelectionInterview::STATUS_ACCEPTED;
4157 eleazar 60
$status_rejected = \LeadersLinked\Model\RecruitmentSelectionInterview::STATUS_REJECTED;
2510 eleazar 61
 
62
$points_0 = \LeadersLinked\Model\RecruitmentSelectionInterview::POINTS_0;
63
$points_1 = \LeadersLinked\Model\RecruitmentSelectionInterview::POINTS_1;
64
$points_2 = \LeadersLinked\Model\RecruitmentSelectionInterview::POINTS_2;
65
$points_3 = \LeadersLinked\Model\RecruitmentSelectionInterview::POINTS_3;
66
$points_4 = \LeadersLinked\Model\RecruitmentSelectionInterview::POINTS_4;
67
 
68
 
69
 
1709 eleazar 70
$this->headStyle()->captureStart();
71
echo <<<CSS
72
 
73
CSS;
74
$this->headStyle()->captureEnd();
75
 
76
$this->inlineScript()->captureStart();
77
echo <<<JS
78
 
79
jQuery( document ).ready(function( $ ) {
3535 eleazar 80
    var allowDelete = $allowDelete;
81
    var allowEdit = $allowEdit;
82
    var allowReport = $allowReport;
1877 eleazar 83
    $.validator.setDefaults({
2015 eleazar 84
        debug: true,
85
        highlight: function(element) {
86
            $(element).addClass('is-invalid');
87
        },
88
        unhighlight: function(element) {
89
            $(element).removeClass('is-invalid');
90
        },
91
        errorElement: 'span',
92
        errorClass: 'error invalid-feedback',
93
        errorPlacement: function(error, element) {
94
            if(element.parent('.btn-file').length) {
95
                error.insertAfter(element.parent().parent());
96
            } else if(element.parent('.toggle').length) {
97
                error.insertAfter(element.parent().parent());
98
            } else {
99
                error.insertAfter(element.parent());
1709 eleazar 100
            }
2015 eleazar 101
        }
102
    });
3468 eleazar 103
 
2015 eleazar 104
    $.fn.showFormErrorValidator = function(fieldname, errors) {
105
        var field = $(fieldname);
106
        if(field) {
107
            $(field).addClass('is-invalid');
1709 eleazar 108
 
2015 eleazar 109
            var error = $('<span id="' + fieldname +'-error" class="error invalid-feedback">' + errors + '</div>');
3468 eleazar 110
 
2015 eleazar 111
            if(element.parent('.btn-file').length) {
112
                error.insertAfter(element.parent().parent());
113
            } else if(element.parent('.toggle').length) {
114
                error.insertAfter(element.parent().parent());
115
            } else {
116
                error.insertAfter(element.parent());
1709 eleazar 117
            }
2015 eleazar 118
        }
119
    };
1827 eleazar 120
 
3468 eleazar 121
    var gridTable = $('#gridTable').dataTable({
122
        'processing': true,
123
        'serverSide': true,
124
        'searching': true,
125
        'order': [
126
            [0, 'asc']
127
        ],
128
        'ordering': true,
129
        'ordenable': true,
130
        'responsive': true,
131
        'select': false,
132
        'paging': true,
133
        'pagingType': 'simple_numbers',
134
        'ajax': {
135
            'url': '$routeIndex',
136
            'type': 'get',
137
            'beforeSend': function(request) {
138
                NProgress.start();
139
            },
140
            'dataFilter': function(response) {
141
                var response = jQuery.parseJSON(response);
142
                var json = {};
143
                json.recordsTotal = 0;
144
                json.recordsFiltered = 0;
145
                json.data = [];
146
                if (response.success) {
147
                    json.recordsTotal = response.data.total;
148
                    json.recordsFiltered = response.data.total;
149
                    json.data = response.data.items;
150
                } else {
151
                    $.fn.showError(response.data)
152
                }
153
                return JSON.stringify(json);
154
                gridTable.api().ajax.reload(null, false);
155
            }
156
        },
157
        'language': {
158
            'sProcessing': 'LABEL_DATATABLE_SPROCESSING',
159
            'sLengthMenu': 'LABEL_DATATABLE_SLENGTHMENU',
160
            'sZeroRecords': 'LABEL_DATATABLE_SZERORECORDS',
161
            'sEmptyTable': 'LABEL_DATATABLE_SEMPTYTABLE',
162
            'sInfo': 'LABEL_DATATABLE_SINFO',
163
            'sInfoEmpty': 'LABEL_DATATABLE_SINFOEMPTY',
164
            'sInfoFiltered': 'LABEL_DATATABLE_SINFOFILTERED',
165
            'sInfoPostFix': '',
166
            'sSearch': 'LABEL_DATATABLE_SSEARCH',
167
            'sUrl': '',
168
            'sInfoThousands': ',',
169
            'sLoadingRecords': 'LABEL_DATATABLE_SLOADINGRECORDS',
170
            'oPaginate': {
171
                'sFirst': 'LABEL_DATATABLE_SFIRST',
172
                'sLast': 'LABEL_DATATABLE_SLAST',
173
                'sNext': 'LABEL_DATATABLE_SNEXT',
174
                'sPrevious': 'LABEL_DATATABLE_SPREVIOUS'
175
            },
176
            'oAria': {
177
                'sSortAscending': ': LABEL_DATATABLE_SSORTASCENDING',
178
                'sSortDescending': ':LABEL_DATATABLE_SSORTDESCENDING'
179
            },
180
        },
181
        'drawCallback': function(settings) {
182
            NProgress.done();
183
            $('button.btn-delete').confirmation({
184
                rootSelector: 'button.btn-delete',
185
                title: 'LABEL_ARE_YOU_SURE',
186
                singleton: true,
187
                btnOkLabel: 'LABEL_YES',
188
                btnCancelLabel: 'LABEL_NO',
189
                onConfirm: function(value) {
190
                    action = $(this).data('href');
191
                    NProgress.start();
192
                    $.ajax({
193
                        'dataType': 'json',
194
                        'accept': 'application/json',
195
                        'method': 'post',
196
                        'url': action,
197
                    }).done(function(response) {
198
                        if (response['success']) {
199
                            $.fn.showSuccess(response['data']);
200
                            gridTable.api().ajax.reload(null, false);
201
                        } else {
202
                            $.fn.showError(response['data']);
203
                        }
204
                    }).fail(function(jqXHR, textStatus, errorThrown) {
205
                        $.fn.showError(textStatus);
206
                    }).always(function() {
207
                        NProgress.done();
208
                    });
209
                },
210
            });
211
        },
3551 eleazar 212
        'aoColumns': [
213
            {
3544 eleazar 214
                'mDataProp': function(data, type, row) {
215
                    return data.first_name + ' ' + data.last_name
216
                }
3468 eleazar 217
            },
3552 eleazar 218
            {
219
                'mDataProp': 'email'
220
            },
3468 eleazar 221
            {
4032 eleazar 222
                'mDataProp': function(data, type, row){
223
                    switch(data.type) {
4033 eleazar 224
                        case 'r':
4032 eleazar 225
                            return 'LABEL_HUMAN_RESOURCE'
226
                        case 'b':
4034 eleazar 227
                            return 'LABEL_BOSS_INTERVIEW'
4032 eleazar 228
                        default:
229
                            return data.type
230
                    }
231
                }
3561 eleazar 232
            },
233
            {
3888 eleazar 234
                'mDataProp': 'vacancy'
3882 eleazar 235
            },
236
            {
3956 eleazar 237
                'mDataProp': function(data, type, row) {
3965 eleazar 238
                    let ldate = new Date(Date.parse(data.last_date + " 00:00:00")) ;
3967 eleazar 239
                    return ldate.getDate() + "/" + String(ldate.getMonth() + 1).padStart(2, '0') + "/" + ldate.getFullYear();
3956 eleazar 240
                }
3953 eleazar 241
            },
242
            {
3468 eleazar 243
                'mDataProp': 'actions'
244
            },
245
        ],
3558 eleazar 246
        'columnDefs': [
247
            {
3468 eleazar 248
                'targets': 0,
249
                'className': 'text-vertical-middle',
250
            },
3957 eleazar 251
 
3468 eleazar 252
            {
253
                'targets': -1,
254
                'orderable': false,
255
                'render': function(data, type, row) {
256
                    s = '';
257
                    if (allowEdit) {
258
                        s = s + '<button class="btn btn-primary btn-edit" data-href="' + data['link_edit'] + '" data-toggle="tooltip" title="LABEL_EDIT"><i class="fa fa-pencil"></i> LABEL_EDIT </button>&nbsp;';
259
                    }
260
                    if (allowDelete) {
261
                        s = s + '<button class="btn btn-danger btn-delete" data-href="' + data['link_delete'] + '" data-toggle="tooltip" title="LABEL_DELETE"><i class="fa fa-trash"></i> LABEL_DELETE </button>&nbsp;';
262
                    }
263
                    if (allowReport) {
264
                        s = s + '<a class="btn btn-default btn-pdf" href="' + data['link_report'] + '" target="_blank" data-toggle="tooltip" title="LABEL_PDF"><i class="fa fa-file-o"></i> LABEL_PDF </button>&nbsp;';
265
                    }
266
                    return s;
267
                }
268
            }
269
        ],
270
    });
271
 
2523 eleazar 272
    function getContent() {
2897 eleazar 273
        return $('[data-competency-behavior]').map(
2523 eleazar 274
            function (idx, td) {
2895 eleazar 275
                const competencyUuid = $(td).data('competency-uuid');
276
                const behaviorUuid = $(td).data('behavior-uuid');
2523 eleazar 277
                const textarea = $(td).find('textarea');
278
                const select = $(td).find('select');
2521 eleazar 279
 
2523 eleazar 280
                return {
2895 eleazar 281
                    competencyUuid: competencyUuid,
3468 eleazar 282
                    behaviorUuid : behaviorUuid,
2523 eleazar 283
                    comment: textarea.val(),
284
                    evaluation: select.val(),
285
                }
286
            }
287
        ).get()
288
    }
289
 
2537 eleazar 290
    var validator = $('#form-interview').validate({
1877 eleazar 291
        debug: true,
292
        onclick: false,
293
        onkeyup: false,
294
        ignore: [],
2534 eleazar 295
        rules: {},
1877 eleazar 296
        submitHandler: function(form) {
297
            $.ajax({
298
                'dataType': 'json',
299
                'accept': 'application/json',
300
                'method': 'post',
7962 eleazar 301
                'url': $('#form-interview').attr('action').replaceAll('UUID_PLACEHOLDER', $('#vacancy_uuid').val()),
2523 eleazar 302
                'data': {
2571 eleazar 303
                    content: JSON.stringify(getContent()),
2523 eleazar 304
                    candidate_uuid: $('#candidate_uuid').val(),
2686 eleazar 305
                    points: $('#points').val(),
2744 eleazar 306
                    comment: $('#comment').val(),
2749 eleazar 307
                    status: $('#status').val(),
2523 eleazar 308
                }
1877 eleazar 309
            }).done(function(response) {
310
                NProgress.start();
311
                if (response['success']) {
312
                    $.fn.showSuccess(response['data']);
3468 eleazar 313
                    $('#main').hide();
3454 eleazar 314
                    $('#interview').hide();
8675 eleazar 315
                    gridTable.fnDraw();
1877 eleazar 316
                } else {
317
                    validator.resetForm();
318
                    if (jQuery.type(response['data']) == 'string') {
319
                        $.fn.showError(response['data']);
320
                    } else {
321
                        $.each(response['data'], function(fieldname, errors) {
2531 eleazar 322
                            $.fn.showFormErrorValidator('#interview #' + fieldname, errors);
1877 eleazar 323
                        });
324
                    }
325
                }
326
            }).fail(function(jqXHR, textStatus, errorThrown) {
327
                $.fn.showError(textStatus);
328
            }).always(function() {
329
                NProgress.done();
330
            });
331
            return false;
332
        },
333
        invalidHandler: function(form, validator) {}
334
    });
1709 eleazar 335
 
2015 eleazar 336
    $('body').on('click', 'button.btn-add', function(e) {
3631 eleazar 337
        $('#form-interview').attr('action', "$routeAdd")
3644 eleazar 338
        $('#candidate_uuid').prop('disabled', false);
339
        $('#vacancy_uuid').prop('disabled', false);
340
        $('#vacancy_uuid').change();
7954 eleazar 341
        $('#candidate_uuid').change();
8768 eleazar 342
        $('#filter_vacancy_uuid').change();
3631 eleazar 343
 
2015 eleazar 344
        e.preventDefault();
3631 eleazar 345
 
2015 eleazar 346
        NProgress.start();
347
        $.ajax({
348
            'dataType': 'json',
349
            'accept': 'application/json',
350
            'method': 'get',
3631 eleazar 351
            'url': $(this).data('url'),
2015 eleazar 352
        }).done(function(response) {
353
            if (response['success']) {
2237 eleazar 354
                var data = response.data
4159 eleazar 355
                $("#form-interview #comment").val('');
356
                $('#form-interview #status').val('$status_acepted');
357
                $("#form-interview #points").val('$points_0');
3466 eleazar 358
                $("#content").hide();
8677 eleazar 359
                $("#main").show();
360
                validator.resetForm();
8676 eleazar 361
                $('#custom-tabs #custom-tabs-general-tab').tab('show');
8768 eleazar 362
 
363
                $('#interview').show();
1877 eleazar 364
            } else {
2015 eleazar 365
                $.fn.showError(response['data']);
1877 eleazar 366
            }
2015 eleazar 367
        }).fail(function(jqXHR, textStatus, errorThrown) {
368
            $.fn.showError(textStatus);
369
        }).always(function() {
370
            NProgress.done();
1877 eleazar 371
        });
2015 eleazar 372
    });
2785 eleazar 373
 
374
    $('body').on('click', 'button.btn-edit', function(e) {
3604 eleazar 375
        var url = $(this).data('href');
2785 eleazar 376
        e.preventDefault();
377
        NProgress.start();
378
        $.ajax({
379
            'dataType': 'json',
380
            'accept': 'application/json',
381
            'method': 'get',
2807 eleazar 382
            'url': url,
2785 eleazar 383
        }).done(function(response) {
384
            if (response['success']) {
385
                var data = response.data
3635 eleazar 386
                $('#vacancy_uuid').val(data['vacancy']['uuid']);
3642 eleazar 387
                $('#vacancy_uuid').prop('disabled', true);
3640 eleazar 388
                $('#candidate_uuid').html('');
389
                var option = $('<option />')
390
                    .val(data['candidate']['uuid'])
391
                    .text(data['candidate']['first_name'] + ' ' + data['candidate']['last_name']);
392
                $('#candidate_uuid').append(option).prop('disabled', true);
3633 eleazar 393
                $("#form-interview #comment").val(data['interview']['comment']);
394
                $('#form-interview #status').val(data['interview']['status']);
395
                $("#form-interview #points").val(data['interview']['points']);
2785 eleazar 396
                $("#competencies-job").html($("#competenciesTemplate").render(data))
2887 eleazar 397
                data.interview.content.forEach(obj => {
2896 eleazar 398
                    $('#textarea-' + obj.competencyUuid + '-' + obj.behaviorUuid).val(obj.comment);
399
                    $('#select-' + obj.competencyUuid + '-' + obj.behaviorUuid).val(obj.evaluation);
2887 eleazar 400
                })
2808 eleazar 401
                $("#form-interview").attr('action', url)
3468 eleazar 402
                $("#content").hide();
403
                $("#main").show()
2785 eleazar 404
            } else {
405
                $.fn.showError(response['data']);
406
            }
407
        }).fail(function(jqXHR, textStatus, errorThrown) {
408
            $.fn.showError(textStatus);
409
        }).always(function() {
410
            NProgress.done();
411
        });
412
    });
2788 eleazar 413
 
414
    $('button.btn-delete').confirmation({
2887 eleazar 415
        rootSelector: 'button.btn-delete',
416
        title: 'LABEL_ARE_YOU_SURE',
417
        singleton: true,
418
        btnOkLabel: 'LABEL_YES',
419
        btnCancelLabel: 'LABEL_NO',
420
        onConfirm: function (value) {
421
            action = $(this).data('href');
422
            NProgress.start();
423
            $.ajax({
424
                'dataType': 'json',
425
                'accept': 'application/json',
426
                'method': 'post',
427
                'url': $(this).data('url'),
428
            }).done(function (response) {
429
                if (response['success']) {
430
                    $.fn.showSuccess(response['data']);
3468 eleazar 431
                    gridTable.api().ajax.reload(null, false);
2887 eleazar 432
                } else {
433
                    $.fn.showError(response['data']);
434
                }
435
            }).fail(function (jqXHR, textStatus, errorThrown) {
436
                $.fn.showError(textStatus);
437
            }).always(function () {
438
                NProgress.done();
2788 eleazar 439
            });
2887 eleazar 440
        },
441
    });
3468 eleazar 442
 
4363 eleazar 443
 
7968 eleazar 444
    $('#filter_vacancy_uuid').change(function (e) {
4363 eleazar 445
        e.preventDefault();
446
 
447
        var uuid = e.target.value;
448
 
449
        gridTable.api().ajax.url("$routeIndex" + "/" + uuid);
450
        gridTable.api().ajax.reload(null, false);
451
    })
452
 
2015 eleazar 453
    $('body').on('click', 'button.btn-cancel', function(e) {
454
        e.preventDefault();
2521 eleazar 455
        $('#main').show();
2015 eleazar 456
        $('#row-form').hide();
457
        $('#div-listing').show();
458
    });
3468 eleazar 459
 
7967 eleazar 460
    $('#form-filter #filter_vacancy_uuid').change(function(e) {
2015 eleazar 461
        e.preventDefault();
3468 eleazar 462
        gridTable.api().ajax.reload(null, false);
2015 eleazar 463
    })
3468 eleazar 464
 
2525 eleazar 465
     /**
466
     * Clicked cancel new/edit Form
467
     */
468
    $('button.btn-edit-cancel').click(function(e) {
469
        e.preventDefault();
3468 eleazar 470
        $("#content").show();
471
        $("#main").hide();
2525 eleazar 472
    });
473
    /**
474
     * Clicked save and continue new Form
475
     */
476
    $('button.btn-form-save-continue').click(function(e) {
477
        e.preventDefault();
4162 eleazar 478
        $('#form-interview #form-continue').val('1')
2540 eleazar 479
        $('#form-interview').submit();
2525 eleazar 480
    });
481
    /**
482
     * Clicked save and close new/edit Form
483
     */
484
    $('button.btn-form-save-close').click(function(e) {
485
        e.preventDefault();
4162 eleazar 486
        $('#form-interview #form-continue').val('0')
3468 eleazar 487
        $("#content").show();
488
        $("#main").hide();
2540 eleazar 489
        $('#form-interview').submit();
4157 eleazar 490
        gridTable.api().ajax.reload(null, false);
2525 eleazar 491
    });
3120 eleazar 492
 
3571 eleazar 493
    $('#vacancy_uuid').on('change', function (event) {
7954 eleazar 494
        $('#candidate_uuid').change();
6227 eleazar 495
        $('#candidate_uuid').html('');
3571 eleazar 496
        var uuid = event.target.value;
3463 eleazar 497
 
3571 eleazar 498
        $.ajax({
499
            'dataType': 'json',
500
            'accept': 'application/json',
501
            'method': 'get',
502
            'url':  String('$routeVacancy').replaceAll('UUID_PLACEHOLDER', uuid),
503
        }).done(function (response) {
504
            var data = response.data
3590 eleazar 505
            $('#job-description').html($('#job-description-template').render(data));
3589 eleazar 506
            $("#competencies-job").html($("#competenciesTemplate").render(data))
3571 eleazar 507
            data.candidates.forEach(function (candidate) {
508
                var option = $('<option />')
509
                    .val(candidate.uuid)
510
                    .text(candidate.first_name)
511
                    .data('addUrl', candidate.add_url)
512
                    .data('editUrl', candidate.edit_url)
513
                    .data('deleteUrl', candidate.delete_url)
514
                    .data('reportUrl', candidate.report_url)
2038 eleazar 515
 
3571 eleazar 516
                $('#candidate_uuid').append(option);
517
            });
518
        })
7954 eleazar 519
 
3571 eleazar 520
    });
2052 eleazar 521
 
4365 eleazar 522
    $('#candidate_uuid').on('change', function(event){
523
 
524
        var uuid = event.target.value;
525
 
526
        $.ajax({
527
            'dataType' : 'json',
528
            'accept' : 'aplication/json',
529
            'method' : 'get',
4367 eleazar 530
            'url': String('$routeType').replaceAll('UUID_PLACEHOLDER', uuid),
4371 eleazar 531
        }).done(function (response) {
4369 eleazar 532
            $('#interview').html(response.data);
8743 eleazar 533
            $('#main').fnDraw();
4365 eleazar 534
        })
535
    })
536
 
3571 eleazar 537
   $('#vacancy_uuid').change();
7954 eleazar 538
   $('#candidate_uuid').change();
4364 eleazar 539
   $('#filter_vacancy_uuid').change();
2785 eleazar 540
 
3341 eleazar 541
});
1709 eleazar 542
JS;
543
$this->inlineScript()->captureEnd();
544
?>
545
 
3468 eleazar 546
 
3460 eleazar 547
<!-- Content Header (Page header) -->
548
<section class="main-header">
549
	<div class="container-fluid">
550
    	<div class="row mb-2">
551
        	<div class="col-sm-12">
552
            	<h1>LABEL_INTERVIEW</h1>
553
			</div>
554
		</div>
555
	</div><!-- /.container-fluid -->
556
</section>
1709 eleazar 557
 
3460 eleazar 558
<section id="content">
559
    <div class="container-fluid">
560
        <div class="row">
561
            <div class="col-12">
562
                <div class="card">
563
                    <div class="card-header">
4346 eleazar 564
                    <div class="col-md-6 col-sm-12">
565
                                        <div class="form-group">
566
                                        <label for="vacancy_uuid">LABEL_VACANCIES</label>
4347 eleazar 567
                                            <select id="filter_vacancy_uuid" name="vacancy_uuid" class="form-control">
4346 eleazar 568
                                                <?php foreach($this->vacancies as $vacancy): ?>
569
                                                    <option value="<?= $vacancy->uuid ?>"><?= $vacancy->name ?></option>
570
                                                <?php endforeach; ?>
571
                                            </select>
572
                                        </div>
573
                                    </div>
3460 eleazar 574
                        <?php echo $this->form()->closeTag($form); ?>
575
                    </div>
576
                    <div class="card-body">
577
                        <table id="gridTable" class="table   table-hover">
578
                            <thead>
579
                            <tr>
580
                                <th>LABEL_FIRST_NAME</th>
581
                                <th>LABEL_EMAIL</th>
3547 eleazar 582
                                <th>LABEL_TYPE_INTERVIEW</th>
3882 eleazar 583
                                <th>LABEL_VACANCIES</th>
3953 eleazar 584
                                <th>LABEL_LAST_DATE</th>
3460 eleazar 585
                                <th>LABEL_ACTIONS</th>
586
                            </tr>
587
                            </thead>
588
                            <tbody>
589
                            </tbody>
590
                        </table>
591
                    </div>
592
                    <div class="card-footer clearfix">
593
                        <div style="float:right;">
594
                            <button id="add-button" type="button" class="btn btn-primary btn-add"><i class="fa fa-plus"></i> LABEL_ADD </button>
595
                        </div>
596
                    </div>
597
                </div>
598
            </div>
599
        </div>
600
    </div>
601
</section>
602
 
3459 eleazar 603
<section id="main" style="display: none;">
3451 eleazar 604
	<div class="container-fluid">
4165 eleazar 605
 
4162 eleazar 606
        	<div class="row p-2">
607
            	<div class="col-12">
608
                    <?php
609
                        $form->setAttributes([
610
                            'method' => 'post',
611
                            'name' => 'form-interview',
612
                            'id' => 'form-interview',
613
                            'action' => $routeAdd
614
                        ]);
615
                        $form->prepare();
616
                        echo $this->form()->openTag($form);
617
                    ?>
618
	    		    	<div class="card">
619
                            <ul class="nav nav-tabs" id="custom-tabs" role="tablist">
620
                                <li class="nav-item" role="presentation">
621
                                    <a class="nav-link active" id="custom-tabs-general-tab" data-toggle="tab" href="#custom-tabs-general" role="tab" aria-controls="custom-tabs-general" aria-selected="true">LABEL_GENERAL</a>
622
                                </li>
623
                                <li class="nav-item" role="presentation">
624
                                    <a class="nav-link" id="custom-tabs-compentencies-tab" data-toggle="tab" href="#custom-tabs-compentencies" role="tab" aria-controls="custom-tabs-compentencies" aria-selected="false">LABEL_COMPETENCIES</a>
625
                                </li>
626
                                <li class="nav-item" role="presentation">
8738 eleazar 627
                                    <a class="nav-link" id="custom-tabs-psicotecnic-tab" data-toggle="tab" href="#custom-tabs-psicotecnic" role="tab" aria-controls="custom-tabs-psicotecnic" aria-selected="false">LABEL_PSYCOTECNIC</a>
628
                                </li>
629
                                <li class="nav-item" role="presentation">
4162 eleazar 630
                                    <a class="nav-link" id="custom-tabs-evaluation-tab" data-toggle="tab" href="#custom-tabs-evaluation" role="tab" aria-controls="custom-tabs-evaluation" aria-selected="false">LABEL_CONCLUTION</a>
631
                                </li>
632
                            </ul>
3459 eleazar 633
 
4162 eleazar 634
	    		    		<div class="tab-content">
635
                                <div class="tab-pane fade show active" id="custom-tabs-general" role="tabpanel" aria-labelledby="custom-tabs-general-tab">
636
                                <div class="row">
637
                                    <div class="col-md-6 col-sm-12">
638
                                        <div class="form-group">
639
                                        <label for="vacancy_uuid">LABEL_VACANCIES</label>
640
                                            <select id="vacancy_uuid" name="vacancy_uuid" class="form-control">
641
                                                <?php foreach($this->vacancies as $vacancy): ?>
642
                                                    <option value="<?= $vacancy->uuid ?>"><?= $vacancy->name ?></option>
643
                                                <?php endforeach; ?>
644
                                            </select>
645
                                        </div>
3459 eleazar 646
                                    </div>
4162 eleazar 647
                                    <div class="col-md-6 col-sm-12">
648
                                        <div class="form-group">
649
                                            <label for="candidate_uuid">LABEL_CANDIDATES</label>
650
                                            <select id="candidate_uuid" name="candidate_uuid" class="form-control">
651
                                            </select>
652
                                        </div>
3482 eleazar 653
                                    </div>
4162 eleazar 654
 
3481 eleazar 655
                                </div>
656
 
8327 eleazar 657
                                <div class="p-2">
8326 eleazar 658
                                        <h5 id="interview"></h5>
659
                                        <div id="job-description"></div>
660
                                    </div>
3459 eleazar 661
                                </div>
4162 eleazar 662
                                <div class="tab-pane fade" id="custom-tabs-compentencies" role="tabpanel" aria-labelledby="custom-tabs-compentencies-tab">
663
                                    <div class="row p-2">
664
                                       <div class="col-md-12 col-sm-12 col-xs-12" id="competencies-job" style="margin-top: 1px;">
665
                                       </div>
666
                                    </div>
667
                                </div>
8738 eleazar 668
                                <div class="tab-pane fade" id="custom-tabs-psicotecnic" role="tabpanel" aria-labelledby="custom-tabs-psicotecnic-tab">
669
                                    <div class="row p-2">
670
                                       <div class="col-md-12 col-sm-12 col-xs-12" id="competencies-job" style="margin-top: 1px;">
671
                                       </div>
672
                                    </div>
673
                                </div>
4162 eleazar 674
                                <div class="tab-pane fade" id="custom-tabs-evaluation" role="tabpanel" aria-labelledby="custom-tabs-evaluation-tab">
675
                                    <div class="row p-2">
676
                                        <div class="col-12">
677
                                            <div class="form-group">
678
                                                <?php
679
                                                $element = $form->get('comment');
680
                                                $element->setOptions(['label' => 'LABEL_COMMENT']);
681
                                                $element->setAttributes(['class' => 'form-control']);
682
                                                echo $this->formLabel($element);
683
                                                echo $this->formText($element);
684
                                                ?>
685
                                            </div>
686
                                            <div class="form-group">
687
                                                <?php
688
                                                $element = $form->get('points');
689
                                                $element->setAttributes(['class' => 'form-control']);
690
                                                $element->setOptions(['label' => 'LABEL_EVALUATION']);
691
                                                echo $this->formLabel($element);
692
                                                echo $this->formSelect($element);
693
                                                ?>
694
                                            </div>
695
                                            <div class="form-group">
696
                                                <?php
697
                                                $element = $form->get('status');
698
                                                $element->setAttributes(['class' => 'form-control']);
699
                                                $element->setOptions(['label' => 'LABEL_STATUS']);
700
                                                echo $this->formLabel($element);
701
                                                echo $this->formSelect($element);
702
                                                ?>
703
                                            </div>
3459 eleazar 704
                                        </div>
705
                                    </div>
706
                                </div>
4162 eleazar 707
                                <div class="card-footer clearfix">
4372 eleazar 708
                                    <button type="submit" style="display:none;" form="form-main" class="btn btn-info btn-form-save-continue">LABEL_SAVE & LABEL_CONTINUE</button>
4162 eleazar 709
                                    <button type="button" class="btn btn-primary btn-form-save-close">LABEL_SAVE & LABEL_CLOSE</button>
710
                                    <button type="button" class="btn btn-secondary btn-edit-cancel">LABEL_CANCEL</button>
711
                                </div>
712
                           	</div>
713
                        </div>
714
                    <?php echo $this->form()->closeTag($form); ?>
715
                </div>
3062 eleazar 716
            </div>
4165 eleazar 717
 
2015 eleazar 718
 	</div>
719
</section>
2052 eleazar 720
 
721
<script id="job-description-template" type="text/x-jsrender">
8326 eleazar 722
    <div class="card">
723
        <div class="card-body">
2052 eleazar 724
            <h5 class="card-title">{{:job_description.name}}</h5>
725
            <p class="card-text">{{:vacancy.description}}</p>
2214 eleazar 726
            <p class="card-text">{{:job_description.objectives}}</p>
727
            <p class="card-text">{{:job_description.functions}}</p>
8278 eleazar 728
        </div>
729
    </div>
2061 eleazar 730
</script>
731
 
3459 eleazar 732
<script id="competenciesTemplate" type="text/x-jsrender">
733
<table class="table table-bordered" id="panel-{{:slug_section}}">
3649 eleazar 734
 
3459 eleazar 735
    <tbody>
736
        {{for job_description.competencies}}
737
            <tr>
8733 eleazar 738
               <td colspan="2" class="text-left">{{:competency_name}} - {{:competency_type_name}}</td>
3459 eleazar 739
            </tr>
740
 
741
            {{for behaviors}}
742
                <tr>
743
                    <td colspan="2">
3649 eleazar 744
                        <table class="table table-bordered">
745
                        <thead>
3459 eleazar 746
                            <tr>
3652 eleazar 747
                               <th style="width: 20%;">LABEL_CONDUCT</th>
3649 eleazar 748
                               <th style="width: 60%;">LABEL_COMMENT</th>
749
                               <th style="width: 20%;">LABEL_EVALUATION</th>
750
                            </tr>
751
                        </thead>
4090 eleazar 752
                            <tr data-competency-behavior data-competency-uuid="{{:competency_uuid}}" data-behavior-uuid="{{:uuid}}">
753
                                <td class="text-left" style="width: 20%;">
3459 eleazar 754
                                    {{:description}}
755
                                </td>
4089 eleazar 756
                                <td style="width: 60%;">
3459 eleazar 757
 
758
                                    <textarea
759
                                        id="textarea-{{:competency_uuid}}-{{:uuid}}"
760
                                        class="form-control"
761
                                    ></textarea>
3473 eleazar 762
                                </td>
4090 eleazar 763
                                <td style="width: 20%;">
764
 
4069 eleazar 765
                                    <select class="form-control" id="select-{{:competency_uuid}}-{{:uuid}}">
4219 eleazar 766
                                        <option value="<?= $points_0 ?>"><?= '0%' ?></option>
767
                                        <option value="<?= $points_1 ?>"><?= '25%' ?></option>
768
                                        <option value="<?= $points_2 ?>"><?= '50%' ?></option>
769
                                        <option value="<?= $points_3 ?>"><?= '75%' ?></option>
770
                                        <option value="<?= $points_4 ?>"><?= '100%' ?></option>
4090 eleazar 771
                                    </select>
3459 eleazar 772
                                </td>
773
                            </tr>
774
                        </table>
775
                    </td>
776
                </tr>
777
            {{/for}}
778
        {{/for}}
779
    </tbody>
780
</table>
3468 eleazar 781
</script>