Proyectos de Subversion LeadersLinked - Backend

Rev

Rev 16804 | Ir a la última revisión | | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
15461 efrain 1
<?php
2
 
3
$acl            = $this->viewModel()->getRoot()->getVariable('acl');
4
$currentUser    = $this->currentUserHelper();
5
$roleName       = $currentUser->getUserTypeId();
6
 
7
$routeDatatable = $this->url( 'activities-center/recruitment-and-selection');
8
 
9
 
10
$allowTakeaTest = $acl->isAllowed($roleName, 'activities-center/recruitment-and-selection/take-a-test') ? 1 : 0;
11
$allowReport =  $acl->isAllowed($roleName, 'activities-center/recruitment-and-selection/report') ? 1 : 0;
12
 
13
$this->headLink()->appendStylesheet($this->basePath('plugins/nprogress/nprogress.css'));
14
$this->inlineScript()->appendFile($this->basePath('plugins/nprogress/nprogress.js'));
15
 
16
 
17
$this->inlineScript()->appendFile($this->basePath('plugins/bootbox/bootbox.min.js'));
18
 
19
 
20
$this->inlineScript()->appendFile($this->basePath('plugins/bootstrap-maxlenght/bootstrap-maxlength.min.js'));
21
 
22
 
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
 
36
$this->inlineScript()->appendFile($this->basePath('plugins/jquery-validation/jquery.validate.js'));
37
$this->inlineScript()->appendFile($this->basePath('plugins/jquery-validation/additional-methods.js'));
38
$this->inlineScript()->appendFile($this->basePath('plugins/jquery-validation/localization/messages_es.js'));
39
 
40
$this->inlineScript()->appendFile($this->basePath('plugins/moment/moment-with-locales.min.js'));
41
//$this->headLink()->appendStylesheet($this->basePath('plugins/bootstrap-datetimepicker/css/bootstrap-datetimepicker.css'));
42
//$this->inlineScript()->appendFile($this->basePath('plugins/bootstrap-datetimepicker/js/bootstrap-datetimepicker.min.js'));
43
 
44
$this->inlineScript()->appendFile($this->basePath('plugins/bootstrap-datepicker/js/bootstrap-datepicker.js'));
45
$this->inlineScript()->appendFile($this->basePath('plugins/bootstrap-datepicker/js/bootstrap-datepicker.es.js'));
46
 
47
 
48
$this->headLink()->appendStylesheet($this->basePath('plugins/bootstrap-datepicker/css/bootstrap-datepicker.css'));
49
 
50
$this->headLink()->appendStylesheet($this->basePath('plugins/select2/css/select2.min.css'));
51
$this->headLink()->appendStylesheet($this->basePath('plugins/select2-bootstrap4-theme/select2-bootstrap4.min.css'));
52
$this->inlineScript()->appendFile($this->basePath('plugins/select2/js/select2.min.js'));
53
 
54
// JsRender //
55
$this->inlineScript()->appendFile($this->basePath('plugins/jsrender/jsrender.min.js'));
56
 
57
$this->headLink()->appendStylesheet($this->basePath('plugins/bootstrap4-toggle/css/bootstrap4-toggle.min.css'));
58
$this->inlineScript()->appendFile($this->basePath('plugins/bootstrap4-toggle/js/bootstrap4-toggle.min.js'));
59
 
60
$this->inlineScript()->appendFile($this->basePath('plugins/bootstrap-confirmation/dist/bootstrap-confirmation.js'));
61
$this->headLink()->appendStylesheet($this->basePath('plugins/bootstrap-checkbox/awesome-bootstrap-checkbox.css'));
62
 
63
 
64
$this->inlineScript()->appendFile($this->basePath('plugins/jquery-input-number/input-number-format.jquery.js'));
65
 
66
$this->inlineScript()->captureStart();
67
echo <<<JS
68
 
69
 
70
jQuery( document ).ready(function( $ ) {
71
 
72
    var allowTakeaTest = $allowTakeaTest;
73
    var allowReport = $allowReport
74
 
75
    var competencies_selected = new Array();
76
    var subordinates_selected = new Array();
77
 
78
    var competency_types = new Array();
79
    var competencies = new Array();
80
    var behaviors = new Array();
81
 
82
 
83
    $.fn.renderJobDescription = function(data) {
84
 
85
        $('#div-job-description').html($('#job-description-template').render(data));
86
    }
87
 
88
 
89
    $.fn.renderCompetencies = function() {
90
 
91
        if(competencies_selected.length > 0) {
92
 
93
             $('#div-competencies').html($('#competencyTemplate').render(competencies_selected, {
94
                getCompetencyType: (uuid) => competency_types.filter((item) => item.uuid == uuid ? item : false)[0],
95
                getCompetency: (uuid) => competencies.filter((item) => item.uuid == uuid ? item : false)[0],
96
                getBehavior: (uuid) => behaviors.filter((item) => item.uuid == uuid ? item : false)[0]
97
            }));
98
        } else {
99
 
100
 
101
             $('#div-competencies').empty();
102
        }
103
    }
104
 
105
 
106
 
107
    $.validator.setDefaults({
108
        debug: true,
109
        highlight: function(element) {
110
            $(element).addClass('is-invalid');
111
        },
112
        unhighlight: function(element) {
113
            $(element).removeClass('is-invalid');
114
        },
115
        errorElement: 'span',
116
        errorClass: 'error invalid-feedback',
117
        errorPlacement: function(error, element) {
118
            if(element.parent('.form-group').length) {
119
                error.insertAfter(element);
120
            } else if(element.parent('.toggle').length) {
121
                error.insertAfter(element.parent().parent());
122
            } else {
123
                error.insertAfter(element.parent());
124
            }
125
        }
126
    });
127
 
128
 
129
 
130
    $.fn.showFormErrorValidator = function(fieldname, errors) {
131
        var field = $(fieldname);
132
        if(field) {
133
            $(field).addClass('form-group-has-error');
134
 
135
            var error = $('<div id="' + fieldname +'-error" class="form-group-invalid-feedback">' + errors + '</div>');
136
            if(field.parent('.form-group').length) {
137
                error.insertAfter(field.parent());
138
            } else {
139
                error.insertAfter(field);
140
            }
141
        }
142
    };
143
 
144
 
145
 
146
        var gridTable = $('#gridTable').dataTable( {
147
            'processing': true,
148
            'serverSide': true,
149
            'searching': true,
150
            'search' : {
151
                'search' : '$search',
152
            },
153
 
154
            'order': [[ 1, 'asc' ]],
155
            'ordering':  true,
156
            'ordenable' : true,
157
            'responsive': true,
158
            'select' : false,
159
                'paging': true,
160
            'pagingType': 'simple_numbers',
161
            'lengthMenu': [ [10, 25, 50, -1], [10, 25, 50, 'All'] ],
162
 
163
                'ajax': {
164
                        'url' : '$routeDatatable',
165
                        'type' : 'get',
166
                'data': function ( d ) {
167
 
168
 
169
                },
170
                'beforeSend': function (request) {
171
                  NProgress.start();
172
                },
173
                'dataFilter': function(response) {
174
                    var response = jQuery.parseJSON( response );
175
 
176
                    var json                = {};
177
                    json.recordsTotal       = 0;
178
                    json.recordsFiltered    = 0;
179
                    json.data               = [];
180
 
181
                    if(response.success) {
182
                                               json.recordsTotal       = response.data.total;
183
                        json.recordsFiltered    = response.data.total;
184
                        json.data               = response.data.items;
185
                    } else {
186
                        $.fn.showError(response.data)
187
                    }
188
 
189
                    return JSON.stringify( json );
190
                }
191
                },
192
            'language' : {
193
                'sProcessing':     'LABEL_DATATABLE_SPROCESSING',
194
                'sLengthMenu':     'LABEL_DATATABLE_SLENGTHMENU',
195
                'sZeroRecords':    'LABEL_DATATABLE_SZERORECORDS',
196
                'sEmptyTable':     'LABEL_DATATABLE_SEMPTYTABLE',
197
                'sInfo':           'LABEL_DATATABLE_SINFO',
198
                'sInfoEmpty':      'LABEL_DATATABLE_SINFOEMPTY',
199
                'sInfoFiltered':   'LABEL_DATATABLE_SINFOFILTERED',
200
                'sInfoPostFix':    '',
201
                'sSearch':         'LABEL_DATATABLE_SSEARCH',
202
                'sUrl':            '',
203
                'sInfoThousands':  ',',
204
                'sLoadingRecords': 'LABEL_DATATABLE_SLOADINGRECORDS',
205
                'oPaginate': {
206
                    'sFirst':    'LABEL_DATATABLE_SFIRST',
207
                    'sLast':     'LABEL_DATATABLE_SLAST',
208
                    'sNext':     'LABEL_DATATABLE_SNEXT',
209
                    'sPrevious': 'LABEL_DATATABLE_SPREVIOUS'
210
                },
211
                'oAria': {
212
                    'sSortAscending':  ': LABEL_DATATABLE_SSORTASCENDING',
213
                    'sSortDescending': ':LABEL_DATATABLE_SSORTDESCENDING'
214
                },
215
            },
216
            'drawCallback': function( settings ) {
217
                NProgress.done();
218
                $('button.btn-delete').confirmation({
219
                    rootSelector: 'button.btn-delete',
220
                    title : 'LABEL_ARE_YOU_SURE',
221
                    singleton : true,
222
                    btnOkLabel: 'LABEL_YES',
223
                    btnCancelLabel: 'LABEL_NO',
224
                    onConfirm: function(value) {
225
                        action = $(this).data('href');
226
                        NProgress.start();
227
                        $.ajax({
228
                            'dataType'  : 'json',
229
                            'accept'    : 'application/json',
230
                            'method'    : 'post',
231
                            'url'       :  action,
232
                        }).done(function(response) {
233
                            if(response['success']) {
234
                                $.fn.showSuccess(response['data']);
235
                                gridTable.api().ajax.reload(null, false);
236
                            } else {
237
                                $.fn.showError(response['data']);
238
                            }
239
                        }).fail(function( jqXHR, textStatus, errorThrown) {
240
                            $.fn.showError(textStatus);
241
                        }).always(function() {
242
                            NProgress.done();
243
                        });
244
                    },
245
                });
246
 
247
 
248
            },
249
            'aoColumns': [
250
                { 'mDataProp': 'last_date' },
251
                { 'mDataProp': 'type' },
252
                { 'mDataProp': 'vacancy' },
253
                { 'mDataProp': 'candidate' },
254
                { 'mDataProp': 'status' },
255
 
256
            ],
257
            'columnDefs': [
258
                {
259
                    'targets': 1,
260
                    'render' : function ( data, type, row ) {
261
                        var s = row['type'];
262
 
263
                        if (allowTakeaTest && row['actions']['link_take_a_test']) {
264
 
265
                            s = s + '<br><button class="btn btn-default btn-take-the-test" data-href="' + row['actions']['link_take_a_test'] + '" data-toggle="tooltip" title="LABEL_PERFORMANCE_EVALUATION_TAKE_TEST"><i class="fa fa-pencil"></i> LABEL_PERFORMANCE_EVALUATION_TAKE_TEST </button>&nbsp;';
266
                        }
267
 
268
                        if (allowReport && row['actions']['link_pdf']) {
269
                            s = s + '<br><button class="btn btn-default btn-pdf" data-href="' + row['actions']['link_pdf'] + '" data-toggle="tooltip" title="LABEL_PDF"><i class="fa fa-pdf"></i> LABEL_PDF </button>&nbsp;';
270
                        }
271
 
272
                        return s;
273
 
274
 
275
                     }
276
                },
277
 
278
 
279
              ],
280
        });
281
 
282
 
283
 
284
    $('body').on('click', 'button.btn-save', function(e) {
285
        e.preventDefault();
286
 
287
        var ok = $('#comment').val().trim().length > 0
288
        $.each($('input.input-behavior-comment'), function(index, element) {
289
            ok = ok && $(element).val().trim().length > 0;
290
        });
291
 
292
        if(!ok) {
293
            $.fn.showError('ERROR_PERFORMANCE_SOMEONE_COMMENT_IS_EMPTY');
294
            return false;
295
        }
296
 
297
        bootbox.confirm({
298
            message: 'LABEL_RECRUITMENT_AND_SELECTION_TEST_IS_COMPLETED',
299
            buttons: {
300
                confirm: {
301
                    label: 'LABEL_YES',
302
                    className: 'btn-success'
303
                },
304
                cancel: {
305
                    label: 'LABEL_NO',
306
                    className: 'btn-warning'
307
                }
308
            },
309
            callback: function (result) {
310
                if(result) {
311
                    var data = new Array()
312
                    data['status'] = $('#status').val();
313
                    data['comment'] = $('#comment').val().trim();
314
                    data['points'] = $('#points').val();
315
                    $.each($('input.input-behavior-comment'), function(index, element) {
316
                        k = $(this).attr('name');
317
                        v = $(this).val().trim();
318
 
319
                        data[k] = v;
320
                    });
321
                    $.each($('input.input-behavior-level'), function(index, element) {
322
                        k = $(this).attr('name');
323
                        v = $(this).val();
324
 
325
                        data[k] = v;
326
                    });
327
 
328
 
329
 
330
                    var action = $('#form').attr('action');
331
                    $.ajax({
332
                        'dataType': 'json',
333
                        'accept': 'application/json',
334
                        'method': 'post',
335
                        'url': action,
336
                        'data' : $('#form').serialize()
337
                    }).done(function(response) {
338
                        if (response['success']) {
339
                            $('#row-test').hide();
340
                            $('#row-header').show();
341
                            $('#row-table').show();
342
 
343
                            gridTable.api().ajax.reload(null, false);
344
                        } else {
345
                            $.fn.showError(response['data']);
346
                        }
347
                    }).fail(function(jqXHR, textStatus, errorThrown) {
348
                        $.fn.showError(textStatus);
349
                    });
350
                }
351
            }
352
        });
353
 
354
 
355
    });
356
 
357
    $('body').on('click', 'button.btn-refresh', function(e) {
358
        e.preventDefault();
359
        gridTable.api().ajax.reload(null, false);
360
    });
361
 
362
 
363
   $('body').on('click', 'button.btn-pdf', function(e) {
364
        e.preventDefault();
365
        var action   = $(this).data('href');
366
 
367
 
368
        NProgress.start();
369
        $.ajax({
370
            'dataType'  : 'json',
371
            'method'    : 'get',
372
            'url'       :  action,
373
        }).done(function(response) {
374
            if(response['success']) {
375
                var anchor = window.document.createElement("a");
376
                anchor.href = 'data:application/octet-stream;charset=utf-8;base64,' + response['data']['content'] ;
377
                anchor.download = response['data']['basename'];
378
                document.body.appendChild(anchor);
379
                anchor.click();  // IE: "Access is denied"; see: https://connect.microsoft.com/IE/feedback/details/797361/ie-10-treats-blob-url-as-cross-origin-and-denies-access
380
                document.body.removeChild(anchor);
381
            } else {
382
                $.fn.showError(response['data']);
383
            }
384
        }).fail(function( jqXHR, textStatus, errorThrown) {
385
            $.fn.showError(textStatus);
386
        }).always(function() {
387
            NProgress.done();
388
        });
389
 
390
 
391
 
392
    });
393
 
394
    $('body').on('click', 'button.btn-cancel', function(e) {
395
        e.preventDefault();
396
 
397
        $('#row-test').hide();
398
        $('#row-header').show();
399
        $('#row-table').show();
400
 
401
    });
402
 
403
 
404
    $('body').on('click', 'button.btn-take-the-test', function(e) {
405
        e.preventDefault();
406
 
407
        var action   = $(this).data('href');
408
        $.getJSON(action, function(response) {
409
            if(response['success']) {
410
 
411
                $('#form').attr('action', action);
412
 
413
                behaviors = response['data']['behaviors'];
414
                competency_types = response['data']['competency_types'];
415
                competencies = response['data']['competencies'];
416
                competencies_selected = response['data']['competencies_selected'];
417
                subordinates_selected = response['data']['subordinates_selected'];
418
 
419
                $.fn.renderCompetencies();
420
 
421
 
422
                var data = {
423
                    name: response['data']['name'],
424
                    functions : response['data']['functions'],
425
                    objectives : response['data']['objectives'],
426
                    form : response['data']['form'],
427
                    type : response['data']['type'],
428
                    interviewer : response['data']['interviewer'],
429
                    candidate : response['data']['candidate'],
430
                    last_date : response['data']['last_date'],
431
                }
432
                $.fn.renderJobDescription(data);
433
 
434
 
435
 
436
                $('input.input-behavior-level').inputNumberFormat({decimal: 0});
437
                $('input.input-behavior-level').change(function(e) {
438
                    e.preventDefault();
439
 
440
                    var v = parseInt($(this).val());
441
                    if(isNaN(v)) {
442
                        $(this).val('0');
443
                    } else {
444
                        if(v > 100) {
445
                            $(this).val('100');
446
                        }
447
                    }
448
                });
449
 
450
 
451
                $('#comment').val('');
452
                $('#points').val('');
453
                $('#row-header').hide();
454
                $('#row-table').hide();
455
                $('#row-test').show();
456
 
457
 
458
            } else {
459
                $.fn.showError(response['data'])
460
            }
461
        }).fail(function( jqXHR, textStatus, errorThrown) {
462
                    $.fn.showError(textStatus);
463
                }).always(function() {
464
                    NProgress.done();
465
                });
466
 
467
 
468
    });
469
 
470
 
471
    $('#form #comment').maxlength({
472
        alwaysShow: true,
473
        validate: true
474
    });
475
 
476
 
477
 
478
    $('#points').inputNumberFormat({decimal: 0});
479
    $('#points').change(function(e) {
480
        e.preventDefault();
481
 
482
        var v = parseInt($(this).val());
483
        if(isNaN(v)) {
484
            $(this).val('0');
485
        } else {
486
            if(v > 100) {
487
                $(this).val('100');
488
            }
489
        }
490
    });
491
 
492
 
493
});
494
JS;
495
$this->inlineScript()->captureEnd();
496
?>
497
 
498
<!-- Content Header (Page header) -->
499
<section id="row-header" class="content-header">
500
    <div class="container-fluid">
501
        <div class="row mb-2">
502
            <div class="col-sm-12">
503
                <h1>LABEL_RECRUITMENT_AND_SELECTION</h1>
504
            </div>
505
        </div>
506
    </div>
507
    <!-- /.container-fluid -->
508
</section>
509
<section id="row-table" class="content">
510
    <div class="container-fluid" id="row-lists">
511
        <div class="row">
512
            <div class="col-12">
513
                <div class="card">
514
                    <div class="card-body">
515
                        <table id="gridTable" class="table   table-hover">
516
                            <thead>
517
                                <tr>
518
                                    <th style="width:15%">LABEL_LAST_DATE</th>
519
                                    <th style="width:35%">LABEL_TYPE</th>
520
                                    <th style="width:35%">LABEL_VACANCY</th>
521
                                    <th style="width:35%">LABEL_CANDIDATE</th>
522
 
523
                                    <th style="width:15%">LABEL_STATUS</th>
524
 
525
                                </tr>
526
                            </thead>
527
                            <tbody></tbody>
528
                        </table>
529
                    </div>
530
                    <div class="card-footer clearfix">
531
                        <div style="float:right;">
532
                            <button type="button" class="btn btn-info btn-refresh"><i class="fa fa-refresh"></i> LABEL_REFRESH </button>
533
                        </div>
534
                    </div>
535
                </div>
536
            </div>
537
        </div>
538
    </div>
539
</section>
540
 
541
 
542
<section id="row-test" style="display: none;">
543
        <div class="container-fluid">
544
        <div class="row p-2">
545
                <div class="col-12">
546
                   <?php
547
                       $form->setAttributes([
548
                           'method' => 'post',
549
                           'name' => 'form',
550
                           'id' => 'form',
551
                       ]);
552
                       $form->prepare();
553
                       echo $this->form()->openTag($form);
554
                   ?>
555
                        <div class="card">
556
                           <ul class="nav nav-tabs" id="custom-tabs" role="tablist">
557
                               <li class="nav-item" role="presentation">
558
                                   <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>
559
                               </li>
560
                               <li class="nav-item" role="presentation">
561
                                   <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>
562
                               </li>
563
                               <li class="nav-item" role="presentation">
564
                                   <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>
565
                               </li>
566
                           </ul>
567
                                <div class="tab-content">
568
                               <div class="tab-pane fade show active" id="custom-tabs-general" role="tabpanel" aria-labelledby="custom-tabs-general-tab">
569
 
570
                               <div class="p-2">
571
                                       <h5 id="interview"></h5>
572
                                       <div id="div-job-description"></div>
573
                                   </div>
574
                               </div>
575
                               <div class="tab-pane fade" id="custom-tabs-compentencies" role="tabpanel" aria-labelledby="custom-tabs-compentencies-tab">
576
                                   <div class="row p-2">
577
                                      <div class="col-md-12 col-sm-12 col-xs-12" id="div-competencies" style="margin-top: 1px;">
578
                                      </div>
579
                                   </div>
580
                               </div>
581
                               <div class="tab-pane fade" id="custom-tabs-evaluation" role="tabpanel" aria-labelledby="custom-tabs-evaluation-tab">
582
                                   <div class="row p-2">
583
                                       <div class="col-12">
584
                                           <div class="form-group">
585
                                               <?php
586
                                               $element = $form->get('comment');
587
                                               $element->setOptions(['label' => 'LABEL_COMMENT']);
588
                                               $element->setAttributes(['class' => 'form-control']);
589
                                               echo $this->formLabel($element);
590
                                               echo $this->formTextArea($element);
591
                                               ?>
592
                                           </div>
593
                                           <div class="form-group">
594
                                               <?php
595
                                               $element = $form->get('points');
596
                                               $element->setAttributes(['class' => 'form-control']);
597
                                               $element->setOptions(['label' => 'LABEL_EVALUATION']);
598
                                               echo $this->formLabel($element);
599
                                               echo $this->formNumber($element);
600
                                               ?>
601
                                           </div>
602
                                      		<div class="form-group">
603
                                               <?php
604
                                               $element = $form->get('status');
605
                                               $element->setOptions(['label' => 'LABEL_STATUS']);
606
                                               $element->setAttributes(['class' => 'form-control']);
607
                                               echo $this->formLabel($element);
608
                                               echo $this->formSelect($element);
609
                                               ?>
610
                                           </div>
611
                                       </div>
612
                                   </div>
613
                               </div>
614
                               <div class="card-footer clearfix">
615
                               	   <div class="text-right">
616
 
617
                                   	<button type="button" class="btn btn-primary btn-save">LABEL_SAVE</button>
618
                                   	<button type="button" class="btn btn-secondary btn-cancel">LABEL_CANCEL</button>
619
                               		</div>
620
                               </div>
621
                      		</div>
622
                       </div>
623
                   <?php echo $this->form()->closeTag($form); ?>
624
               </div>
625
           </div>
626
        </div>
627
</section>
628
 
629
<script id="job-description-template" type="text/x-jsrender">
630
    <div class="card">
631
        <div class="card-body">
632
            <h4 class="text-center">{{:form}}</h4>
633
            <table class="table table-bordered">
634
                <tr>
635
                    <th>LABEL_LAST_DATE</th>
636
                    <th>LABEL_TYPE</th>
637
                </tr>
638
                <tr>
639
                    <td>{{:last_date}}</td>
640
                    <td>{{:type}}</td>
641
                </tr>
642
 
643
                <tr>
644
                    <th>LABEL_INTERVIEWED_BY</th>
645
                    <th>LABEL_CANDIDATE</th>
646
                </tr>
647
                <tr>
648
                    <td>{{:interviewer}}</td>
649
                    <td>{{:candidate}}</td>
650
                </tr>
651
            </table>
652
            <br/>
653
 
654
            <p class="card-text"><b>LABEL_OBJECTIVES</b></p>
655
            <p class="card-text">{{:objectives}}</p>
656
            <p class="card-text"><b>LABEL_FUNCTIONS</b></p>
657
            <p class="card-text">{{:functions}}</p>
658
 
659
        </div>
660
    </div>
661
</script>
662
 
663
 
664
<script id="competencyTemplate" type="text/x-jsrender">
665
 <div class="panel panel-default panel-competency" id="panel-{{:uuid}}" data-competency="{{:uuid}}">
666
   <div class="panel-heading">
667
      <h4 class="panel-title" style="    font-size: 18px;">
668
         <a class="accordion-toggle" data-toggle="collapse" aria-expanded="true" data-parent="#panel-{{:uuid}}" href="#collapse-{{:uuid}}">
669
         <span class="section-name{{:uuid}}">
670
            {{:~getCompetencyType(competency_type_uuid).name}} - {{:~getCompetency(uuid).name}}
671
         </span>
672
         </a>
673
      </h4>
674
   </div>
675
   <div id="collapse-{{:uuid}}" class="panel-collapse in collapse show">
676
      <div class="panel-body">
677
         <div class="table-responsive">
678
            <table class="table table-bordered">
679
               <thead>
680
                  <tr>
681
                     <th style="width: 30%;">LABEL_ELEMENT</th>
682
                     <th style="width: 50%;">LABEL_TITLE</th>
683
                     <th style="width: 10%;">LABEL_LEVEL</th>
684
                     <th style="width: 10%;">LABEL_POINTS</th>
685
 
686
                  </tr>
687
               </thead>
688
               <tbody>
689
                  <tr>
690
                     <td class="text-left">LABEL_COMPETENCY</td>
691
                     <td class="text-left">{{:name}}</td>
692
                     <td>&nbsp;</td>
693
                     <td>&nbsp;</td>
694
 
695
                  </tr>
696
                  {{for behaviors}}
697
                  <tr >
698
                     <td class="text-left">--LABEL_BEHAVIOR</td>
699
                     <td class="text-left">
700
                       {{:~getBehavior(uuid).description}}
701
                     </td>
702
                     <td class="text-right">
703
                        {{:level}}
704
                     </td>
705
                     <td class="text-right">
706
                        <input type="number" class="form-control input-behavior-level " value="0" step="1" min="0" max="100" name="{{:competency_uuid}}-{{:uuid}}-points" id="{{:competency_uuid}}-{{:uuid}}-points" ></input>
707
                     </td>
708
 
709
                  </tr>
710
                  <tr >
711
                    <td colspan="4">
712
                     LABEL_COMMENT
713
                     <input type="text" class="form-control input-behavior-comment" value="" maxlength="128" name="{{:competency_uuid}}-{{:uuid}}-comment" id="{{:competency_uuid}}-{{:uuid}}-comment" ></input>
714
                    </td>
715
                  </tr >
716
 
717
                  {{/for}}
718
               </tbody>
719
            </table>
720
         </div>
721
      </div>
722
   </div>
723
</div>
724
</script>
725
 
726