source: trunk/workflow/js/orgchart/organization.js @ 8094

Revision 8094, 43.3 KB checked in by rafaelgobara, 11 years ago (diff)

Ticket #3423 - Rename das funcoes js que chamam o plugin que carrega usuarios

  • Property svn:executable set to *
Line 
1String.prototype.repeat = function(l)
2{
3        return new Array(l+1).join(this);
4};
5
6var workflowOrgchartAdminEmployeeInfoTimer = null;
7var workflowOrgchartAdminAreaInfoTimer = null;
8
9var CadastroAjax = Class.create();
10
11CadastroAjax.prototype =
12{
13        initialize: function()
14        {
15                this.name = '';
16                this.required = new Array();
17                this.tableHeader = new Array();
18                this.combo = new Array();
19        },
20
21        add: function()
22        {
23                for (var i = 0; i < this.required.length; i++)
24                {
25                        if ($F(this.required[i]) == '')
26                        {
27                                alert("Campo necessário ausente: " + $(this.required[i]).parentNode.parentNode.childNodes[0].childNodes[0].innerHTML);
28                                $(this.required[i]).focus();
29                                return;
30                        }
31                }
32                var cb = function(data)
33                {
34                        if (!handleError(data))
35                                return;
36
37                        /* update the screen info */
38                        if (this.name.toLowerCase() == "organization")
39                                listOrganizations();
40                        else
41                        {
42                                if ($('organizacao_id'))
43                                {
44                                        var index = $F('organizacao_id');
45                                        if (refreshAreas[index])
46                                                refreshAreas[index]();
47                                }
48                        }
49
50                        valid.deactivate();
51                };
52
53                return this.ajaxAction('add', cb, Form.serialize($('orgchartForm')));
54        },
55
56        update: function()
57        {
58                for (var i = 0; i < this.required.length; i++)
59                {
60                        if ($F(this.required[i]) == '')
61                        {
62                                alert("Campo necessário ausente: " + $(this.required[i]).parentNode.parentNode.childNodes[0].childNodes[0].innerHTML);
63                                $(this.required[i]).focus();
64                                return;
65                        }
66                }
67                var cb = function(data)
68                {
69                        if (!handleError(data))
70                                return;
71
72                        /* update the screen info */
73                        if (this.name.toLowerCase() == "organization")
74                                listOrganizations();
75                        else
76                        {
77                                if ($('organizacao_id'))
78                                {
79                                        var index = $F('organizacao_id');
80                                        if (refreshAreas[index])
81                                                refreshAreas[index]();
82                                }
83                        }
84
85                        valid.deactivate();
86                };
87
88                return this.ajaxAction('update', cb, Form.serialize($('orgchartForm')));
89        },
90
91        remove: function(params, linkRemove)
92        {
93
94                if (linkRemove.addClassName)
95                        linkRemove.addClassName('alerta');
96                if (confirm("Tem certeza que deseja excluir o registro selecionado?"))
97                {
98                        var cb = function(data)
99                        {
100                                if (!handleError(data))
101                                        return;
102
103                                /* update the screen info */
104                                if (this.name.toLowerCase() == "organization")
105                                        listOrganizations();
106                                else
107                                {
108                                        var index = $('organizacao_id') ? $F('organizacao_id') : params['organizacao_id'];
109                                        if (refreshAreas[index])
110                                                refreshAreas[index]();
111                                }
112
113                                if ($('lbContent'))
114                                        valid.deactivate();
115                        };
116                        return this.ajaxAction('remove', cb, $H(params).toQueryString());
117                }
118                else
119                        if (linkRemove.removeClassName)
120                                linkRemove.removeClassName('alerta');
121        },
122
123        list: function(callback, params)
124        {
125                return this.ajaxAction('list', callback, $H(params).toQueryString());
126        },
127
128        generateTable: function(params, displayArea)
129        {
130                tableHeader = this.tableHeader;
131                var tableResult = function(data)
132                {
133                        if (!handleError(data))
134                                return;
135
136                        if (data.length == 0)
137                        {
138                                displayArea.innerHTML += '<br/><br/><center><strong>Nenhum registro encontrado</strong></center>';
139                                return true;
140                        }
141
142                        for (var i = 0; i < data.length; i++)
143                        {
144                                data[i]['tr_attributes'] = new Array();
145                                data[i]['tr_attributes']['class'] = "linha" + i%2;;
146                                data[i]['tr_attributes']['className'] = "linha" + i%2;;
147                        }
148
149                        var tableAtributes = new Array();
150                        tableAtributes['id'] = this.name + 'List';
151                        tableAtributes['class'] = 'organizationList';
152                        tableAtributes['className'] = 'organizationList';
153                        displayArea.appendChild(constructTable(tableHeader, data, tableAtributes));
154                };
155                this.list(tableResult, params);
156        },
157
158        generateUpdateTable: function(params, displayArea)
159        {
160                tableHeader = this.tableHeader;
161                if (!tableHeader['actions'])
162                        tableHeader['actions'] = "Ações";
163                name = this.name.charAt(0).capitalize() + this.name.substr(1);
164                var tableResult = function(data)
165                {
166                        if (!handleError(data))
167                                return;
168
169                        if (data.length == 0)
170                        {
171                                //displayArea.innerHTML += '<br/><br/><center><strong>Nenhum registro encontrado</strong></center>';
172                                elem = document.createElement('div');
173                                elem.id = this.name.capitalize() + 'List';
174                                elem.innerHTML = '<br/><br/><center><strong>Nenhum registro encontrado</strong></center>';
175                                displayArea.appendChild(elem);
176                                return true;
177                        }
178
179                        for (var i = 0; i < data.length; i++)
180                        {
181                                var dataHash = new Hash();
182                                for (j in data[i])
183                                        if (typeof data[i][j] != "function")
184                                        {
185                                                dataHash[j] = data[i][j];
186                                                if ( dataHash[j] == null )
187                                                        dataHash[j] = '';
188                                        }
189
190                                for (j in tableHeader)
191                                        if (typeof tableHeader[j] != "function")
192                                                if (j != 'actions')
193                                                        data[i][j] = '<a href="#" onclick="obj' + name + '.fillForm(' + dataHash.customInspect() + '); return false;">' + data[i][j] + '</a>';
194
195                                data[i]['tr_attributes'] = new Array();
196                                data[i]['tr_attributes']['class'] = "linha" + i%2;
197                                data[i]['tr_attributes']['className'] = "linha" + i%2;
198                                data[i]['actions'] = '<a href="#" onclick="obj' + name + '.remove(' + dataHash.customInspect() + ' , this.parentNode.parentNode); return false;"><img border="0" width="16" height="16" src="workflow/templateFile.php?file=images/button_cancel.png" /></a>';
199                        }
200
201                        var tableAtributes = new Array();
202                        tableAtributes['id'] = this.name + 'List';
203                        tableAtributes['class'] = 'orgchartUpdateTable';
204                        tableAtributes['className'] = 'orgchartUpdateTable';
205                        displayArea.appendChild(constructTable(tableHeader, data, tableAtributes));
206                };
207                this.list(tableResult, params);
208        },
209
210        fillForm: function(dataHash)
211        {
212                dataHash = $H(dataHash);
213                dataHash.each(function(pair)
214                {
215                        var campo = $(pair.key);
216                        if (campo)
217                        {
218                                if ((campo.nodeName == "SELECT") && (pair.value == null))
219                                        campo.value = campo.firstChild.value;
220                                else
221                                        if (pair.value != null)
222                                                campo.value = pair.value;
223                        }
224                        else
225                                new Insertion.Bottom($('orgchartForm'), '<input type="hidden" name="' + pair.key + '" id="' + pair.key + '" value="' + pair.value + '" />');
226                });
227                if (!$('updateOrgchart'))
228                        new Insertion.Bottom($('orgchartForm'), '<input type="hidden" name="updateOrgchart" id="updateOrgchart" value="true" />');
229                var saveButton = $('inserir');
230                saveButton.innerHTML = "Salvar";
231                var name = this.name;
232                saveButton.onclick = function(){ eval('obj' + name.charAt(0).capitalize() + name.substr(1) + '.update();')};
233                var titleObject = $('modalTitle');
234                var title = titleObject.innerHTML.split(' ');
235                title[0] = "Atualizar";
236                titleObject.innerHTML = title.join(' ');
237                $('lightbox').scrollTop = 0;
238        },
239
240        generateComboBox: function(params, displayArea, includeNull, name, callback)
241        {
242                if (!name)
243                        name = this.combo['id'];
244               
245                combo = this.combo;
246
247                var comboResult = function(data)
248                {
249                        if (!handleError(data))
250                                return;
251
252                        var newFormat = new Array();
253                        if (includeNull)
254                                newFormat['NULL'] = "Nenhum";
255
256                        for (var i = 0; i < data.length; i++)
257                                newFormat[data[i][combo['id']]] = data[i][combo['name']];
258
259                        if ((newFormat.length > 0) || includeNull)
260                        {
261                                displayArea.innerHTML = constructSelectBox(name, newFormat);
262                        }
263                        else
264                        {
265                                displayArea.innerHTML = '<i>nenhum registro encontado</i><input type="hidden" id="' + name + '" value=""/>';
266                        }
267
268                        if (callback)
269                                callback();
270                };
271
272                this.list(comboResult, params);
273        },
274
275        ajaxAction: function(action, callback, params)
276        {
277                if (params == "")
278                        cExecute('$this.bo_orgchart.' + action + this.name.charAt(0).capitalize() + this.name.substr(1), callback);
279                else
280                        cExecute('$this.bo_orgchart.' + action + this.name.charAt(0).capitalize() + this.name.substr(1), callback, params);
281        }
282
283};
284
285var CadastroOrganization =
286{
287        name: 'organization',
288        required: new Array('nome', 'descricao', 'ativa'),
289        tableHeader: {'nome': 'Organização'},
290        combo: {'id': 'organizacao_id', 'name': 'nome'}
291};
292var objOrganization = new CadastroAjax();
293Object.extend(objOrganization, CadastroOrganization);
294
295var CadastroEmployeeStatus =
296{
297        name: 'employeeStatus',
298        required: new Array('descricao', 'exibir'),
299        tableHeader: {'descricao': 'Status de Funcionário'},
300        combo: {'id': 'funcionario_status_id', 'name': 'descricao'}
301};
302var objEmployeeStatus = new CadastroAjax();
303Object.extend(objEmployeeStatus, CadastroEmployeeStatus);
304
305var CadastroEmployeeCategory =
306{
307        name: 'employeeCategory',
308        required: new Array('organizacao_id', 'descricao'),
309        tableHeader: {'descricao': 'Nome'},
310        combo: {'id': 'funcionario_categoria_id', 'name': 'descricao'}
311};
312var objEmployeeCategory = new CadastroAjax();
313Object.extend(objEmployeeCategory, CadastroEmployeeCategory);
314
315var CadastroJobTitle =
316{
317        name: 'jobTitle',
318        required: new Array('organizacao_id', 'descricao'),
319        tableHeader: {'descricao': 'Nome'},
320        combo: {'id': 'cargo_id', 'name': 'descricao'}
321};
322var objJobTitle = new CadastroAjax();
323Object.extend(objJobTitle, CadastroJobTitle);
324
325var CadastroAreaStatus =
326{
327        name: 'areaStatus',
328        required: new Array('organizacao_id', 'descricao', 'nivel'),
329        tableHeader: {'descricao': 'Nome', 'nivel': 'Nível'},
330        combo: {'id': 'area_status_id', 'name': 'descricao'}
331};
332var objAreaStatus = new CadastroAjax();
333Object.extend(objAreaStatus, CadastroAreaStatus);
334
335var CadastroCostCenter =
336{
337        name: 'costCenter',
338        required: new Array('organizacao_id', 'nm_centro_custo', 'descricao', 'grupo'),
339        tableHeader: {'nm_centro_custo': 'Número', 'descricao': 'Nome', 'grupo': 'Grupo'},
340        combo: {'id': 'centro_custo_id', 'name': 'descricao'}
341};
342var objCostCenter = new CadastroAjax();
343Object.extend(objCostCenter, CadastroCostCenter);
344
345var CadastroLocal =
346{
347        name: 'local',
348        required: new Array('organizacao_id', 'descricao'),
349        tableHeader: {'descricao': 'Localidade'},
350        combo: {'id': 'localidade_id', 'name': 'descricao'}
351};
352var objLocal = new CadastroAjax();
353Object.extend(objLocal, CadastroLocal);
354
355var CadastroEmployee =
356{
357        name: 'employee',
358        required: new Array('funcionario_id', 'organizacao_id', 'funcionario_status_id', 'centro_custo_id', 'localidade_id', 'area_id'),
359        tableHeader: {'funcionario_id': 'Funcionário'},
360        combo: {'id': 'funcionario_id', 'name': 'funcionario_id'}
361};
362var objEmployee = new CadastroAjax();
363Object.extend(objEmployee, CadastroEmployee);
364
365var CadastroArea =
366{
367        name: 'area',
368        required: new Array('organizacao_id', 'area_status_id', 'centro_custo_id', 'superior_area_id', 'sigla', 'descricao', 'ativa'),
369        tableHeader: {'sigla': 'Área'},
370        combo: {'id': 'area_id', 'name': 'sigla'}
371};
372var objArea = new CadastroAjax();
373Object.extend(objArea, CadastroArea);
374
375var CadastroTelefone =
376{
377        name: 'telephones',
378        required: new Array('organizacao_id', 'descricao', 'numero'),
379        tableHeader: {'descricao': 'Descrição', 'numero': 'Telefones'},
380        combo: {'id': 'telefone_id', 'name': 'descricao'}
381};
382var objTelephones = new CadastroAjax();
383Object.extend(objTelephones, CadastroTelefone);
384
385var CadastroSubstituto =
386{
387        name: 'substitution',
388        required: new Array('organizacao_id', 'area_id', 'descricao', 'titular_funcionario_id', 'substituto_funcionario_id', 'data_inicio', 'data_fim'),
389        tableHeader: {'substituto_funcionario_id_desc': 'Nome', 'data_inicio': 'Data de início', 'data_fim': 'Data de término'},
390        combo: {}
391};
392var objSubstitution = new CadastroAjax();
393Object.extend(objSubstitution, CadastroSubstituto);
394
395
396function createOrganizationLayout(organizationID, organizationDiv)
397{
398        organizationDiv.innerHTML = '<div id="orgchartMenu_' + organizationID + '"></div>';
399        organizationDiv.innerHTML += '<div class="orgchartAreas" id="orgchartAreas_' + organizationID + '"></div>';
400        organizationDiv.innerHTML += '<div class="orgchartEmployees" id="orgchartEmployees_' + organizationID + '"></div>';
401        organizationDiv.innerHTML += '<div class="orgchartFooter"></div>';
402        organizationDiv.innerHTML += '<div id="employeeInfo" class="employeeInfo" style="display: none;"></div>';
403        organizationDiv.innerHTML += '<div id="areaInfo" class="employeeInfo" style="display: none;"></div>';
404
405        createOrganizationMenu(organizationID, $('orgchartMenu_' + organizationID));
406        loadOrganizationAreas(organizationID, $('orgchartAreas_' + organizationID));
407        lb_initialize();
408}
409
410function createOrganizationMenu(organizationID, div)
411{
412        var content  = '<ul class="horizontalMenu">';
413                content += '<li style="margin: 5px 5px 0 5px">Atualizar : <select name="atualizar" id="ddlAtualizar" onchange="loadAdds(this.value, ' + organizationID + ');">';
414                content += '<option></option>';
415                content += '<option value="loadAddEmployeeStatusUI">Status de Funcionário</option>';
416                content += '<option value="loadAddEmployeeCategoryUI">Categorias</option>';
417                content += '<option value="loadAddJobTitleUI">Cargos</option>';
418                content += '<option value="loadAddAreaStatusUI">Status de Área</option>';
419                content += '<option value="loadAddCostCenterUI">Centros de Custo</option>';
420                content += '<option value="loadAddLocalUI">Localidade</option>';
421                content += '<option value="loadAddAreaUI">Áreas</option>';
422                content += '<option value="loadAddEmployeeUI">Funcionários</option>';
423                content += '<option value="loadAddTelephoneUI">Telefones</option>';
424                content += '<option value="loadAddSubstitutionUI">Substituições</option>';
425                content += '</select></li>';
426                content += '<li><a><input type="text" name="search_term" id="search_term" onkeypress="if (((window.Event) ? event.which : event.keyCode) == 13) $(\'search_span_' + organizationID  + '\').onclick(); return true;" /> <span id="search_span_' + organizationID + '" onclick="tmp = $$(\'div#orgchartAreas_' + organizationID + ' a.destaque\'); if (tmp[0]) tmp[0].removeClassName(\'destaque\'); searchEmployee(' + organizationID + ', $(\'orgchartEmployees_' + organizationID + '\')); return false;">busca</span></a></li>';
427                content += '</ul>';
428                content += '<br/>';
429                content += '<br/>';
430
431        div.innerHTML = content;
432}
433
434function loadAdds(eventName, organizationID)
435{
436        if (eventName == '' || eventName == undefined || eventName == null)
437                return false;
438
439        window.settings = { functionName: eventName };
440
441        var b = document.createElement('button');
442            b.className = 'lbOn';
443
444        if (!$('overlay'))
445                addLightboxMarkup();
446       
447        var valid = new lightbox(b);
448                valid.activate();
449
450        window[settings.functionName](organizationID);
451}
452
453function loadOrganizationAreas(organizationID, div)
454{
455        var loadOrganizationAreasResult = function(data)
456        {
457                function recursivePrint(subdata)
458                {
459                        for (var i = 0; i < subdata.length; i++)
460                        {
461                                div.innerHTML += '<br />' + '&nbsp;&nbsp;&nbsp;&nbsp;'.repeat(subdata[i]['depth']) + '<a href="javascript:void(0)" id="area_' + subdata[i]['area_id'] + '" onmouseover="getAreaInfoTimer(event, ' + subdata[i]['area_id'] + ', ' + organizationID + '); return false;" onmouseout="hideAreaInfo(); return false;" onclick="tmp = $$(\'div#orgchartAreas_' + organizationID + ' a.destaque\'); if (tmp[0]) tmp[0].removeClassName(\'destaque\'); this.addClassName(\'destaque\'); loadAreaEmployees(' + organizationID + ', ' + subdata[i]['area_id'] + ', $(\'orgchartEmployees_' + organizationID + '\'))">' + subdata[i]['sigla'] + '</a>';
462                                if (subdata[i]['children'].length > 0)
463                                        recursivePrint(subdata[i]['children']);
464                        }
465                }
466
467                if (!handleError(data))
468                        return;
469
470                if (data.length == 0)
471                {
472                        div.innerHTML = "<br/><br/><center><strong>Nenhuma área cadastrada.</strong></center><br/><br/>";
473                        return;
474                }
475
476                div.innerHTML = "<center><strong>ÁREAS</strong></center>";
477                recursivePrint(data);
478                if (refreshEmployees[organizationID])
479                        refreshEmployees[organizationID]();
480        };
481
482        objArea.ajaxAction('listHierarchical', loadOrganizationAreasResult, $H({'organizacao_id': organizationID}).toQueryString());
483        refreshAreas[organizationID] = function(){objArea.ajaxAction('listHierarchical', loadOrganizationAreasResult, $H({'organizacao_id': organizationID}).toQueryString());};
484}
485
486function searchEmployee(organizationID, div)
487{
488        var searchEmployeeResult = function(data)
489        {
490                if (!handleError(data))
491                        return;
492
493                div.innerHTML = "";
494                if (data.length == 0)
495                {
496                        div.innerHTML = "<br/><br/><center><strong>Nenhum funcionário encontrado.</strong></center>";
497                        return;
498                }
499
500                var tableHeader = new Array();
501                tableHeader['funcionario_id_desc'] = 'Funcionário';
502                tableHeader['area_sigla'] = 'Área';
503                tableHeader['uid'] = 'UID';
504                tableHeader['actions'] = 'Ações';
505                for (var i = 0; i < data.length; i++)
506                {
507                        var dataHash = new Hash();
508                        for (j in data[i])
509                                if (typeof data[i][j] != "function")
510                                        dataHash[j] = data[i][j];
511
512                        data[i]['tr_attributes'] = new Array();
513                        data[i]['tr_attributes']['class'] = "linha" + i%2;
514                        data[i]['tr_attributes']['className'] = "linha" + i%2;
515                        data[i]['funcionario_id_desc'] = '<a href="javascript:void(0)" class="lbOn" onmouseover="getEmployeeInfoTimer(event, ' + data[i]['funcionario_id'] + ', ' + organizationID + '); return false;" onmouseout="hideEmployeeInfo(); return false;" onclick="loadAddEmployeeUI(' + organizationID + ', function(){objEmployee.fillForm(' + dataHash.customInspect() + ')}); $(\'addEmployeeLink\').parentNode.removeChild($(\'addEmployeeLink\')); return false;">' + data[i]['funcionario_id_desc'] + '</a>' + (data[i]['removed'] ? ' <font color="red">(inativo)</font>' : '');
516                        data[i]['actions'] = '<a href="#" onclick="objEmployee.remove({\'funcionario_id\': ' + data[i]['funcionario_id'] + ', \'organizacao_id\': ' + organizationID + '} , this.parentNode.parentNode); return false;"><img border="0" width="16" height="16" src="workflow/templateFile.php?file=images/button_cancel.png" /></a>';
517                }
518
519                var tableAtributes = new Array();
520                tableAtributes['class'] = 'employeeList';
521                tableAtributes['className'] = 'employeeList';
522                div.appendChild(constructTable(tableHeader, data, tableAtributes));
523                lb_initialize();
524        };
525
526        objEmployee.ajaxAction('search', searchEmployeeResult, $H({'organizacao_id': organizationID, 'search_term': $F('search_term')}).toQueryString());
527        refreshEmployees[organizationID] = function(){objEmployee.ajaxAction('search', searchEmployeeResult, $H({'organizacao_id': organizationID, 'search_term': $F('search_term')}).toQueryString());};
528}
529
530function loadAreaEmployees(organizationID, areaID, div)
531{
532        var loadAreaEmployeesResult = function(data)
533        {
534                if (!handleError(data))
535                        return;
536
537                var areaLink = $('area_' + areaID);
538                if (!areaLink.hasClassName('destaque'))
539                        areaLink.addClassName('destaque');
540
541                div.innerHTML = "";
542                if (data.length == 0)
543                {
544                        div.innerHTML = "<br/><br/><center><strong>Nenhum funcionário alocado nesta área.</strong></center>";
545                        return;
546                }
547
548                var tableHeader = new Array();
549                tableHeader['funcionario_id_desc'] = 'Funcionário';
550                tableHeader['uid'] = 'UID';
551                tableHeader['actions'] = 'Ações';
552
553                var complement;
554                for (var i = 0; i < data.length; i++)
555                {
556                        var dataHash = new Hash();
557                        for (j in data[i])
558                                if (typeof data[i][j] != "function")
559                                        dataHash[j] = data[i][j];
560
561                        // are you a chief ('titular' or 'substituto')?
562                        complement = '';
563                        if (data[i]['chief'])
564                                complement = ' <strong>(' + ((data[i]['chief'] == 1) ? 'Titular' : 'Substituto') + ')</strong>';
565
566                        data[i]['tr_attributes'] = new Array();
567                        data[i]['tr_attributes']['class'] = "linha" + i%2;
568                        data[i]['tr_attributes']['className'] = "linha" + i%2;
569                        data[i]['funcionario_id_desc'] = '<a href="javascript:void(0)" class="lbOn" onmouseover="getEmployeeInfoTimer(event, ' + data[i]['funcionario_id'] + ', ' + organizationID + '); return false;" onmouseout="hideEmployeeInfo(); return false;" onclick="loadAddEmployeeUI(' + organizationID + ', function(){objEmployee.fillForm(' + dataHash.customInspect() + ')}); $(\'addEmployeeLink\').parentNode.removeChild($(\'addEmployeeLink\')); return false;">' + data[i]['funcionario_id_desc'] + ' ' + complement + '</a>' + (data[i]['removed'] ? ' <font color="red">(inativo)</font>' : '');
570                        data[i]['actions'] = '<a href="#" onclick="objEmployee.remove({\'funcionario_id\': ' + data[i]['funcionario_id'] + ', \'organizacao_id\': ' + organizationID + '} , this.parentNode.parentNode); return false;"><img border="0" width="16" height="16" src="workflow/templateFile.php?file=images/button_cancel.png" /></a>';
571                        window.scrollTo(0,0);
572                }
573
574                var tableAtributes = new Array();
575                tableAtributes['class'] = 'employeeList';
576                tableAtributes['className'] = 'employeeList';
577                div.appendChild(constructTable(tableHeader, data, tableAtributes));
578
579                lb_initialize();
580        };
581
582        objEmployee.ajaxAction('listArea', loadAreaEmployeesResult, $H({'area_id': areaID, 'organizacao_id': organizationID}).toQueryString());
583        refreshEmployees[organizationID] = function(){objEmployee.ajaxAction('listArea', loadAreaEmployeesResult, $H({'area_id': areaID, 'organizacao_id': organizationID}).toQueryString());};
584}
585
586function loadAddEmployeeStatusUI(organizationID)
587{
588        var valoresSimNao = new Array();
589        valoresSimNao['S'] = 'Sim';
590        valoresSimNao['N'] = 'Não';
591
592        var content;
593        content = '<h2 id="modalTitle">Adicionar Status de Funcionário</h2>';
594        content += '<form name="orgchartForm" id="orgchartForm">';
595        content += '<input type="hidden" name="organizacao_id" id="organizacao_id" value="' + organizationID + '" />';
596        content += "<table>";
597        content += '<tr><td><label for="descricao">Nome</label></td><td><input type="text" name="descricao" id="descricao" size="30" /></td></tr>';
598        content += '<tr><td><label for="exibir">Exibir para o usuário</label></td><td>' + constructSelectBox('exibir', valoresSimNao) + '</td></tr>';
599        content += "</table>";
600        content += '</form>';
601        content += '<button id="inserir" onclick="objEmployeeStatus.add(); return false;">Inserir</button>';
602        content += '<button onclick="valid.deactivate(); return false;">Cancelar</button>';
603
604        var divLB = $('lbContent');
605        divLB.innerHTML = content;
606        //$('descricao').focus();
607        objEmployeeStatus.generateUpdateTable({'organizacao_id': organizationID}, divLB);
608}
609
610function loadAddEmployeeCategoryUI(organizationID)
611{
612        var content;
613        content = '<h2 id="modalTitle">Adicionar Categoria</h2>';
614        content += '<form name="orgchartForm" id="orgchartForm">';
615        content += '<input type="hidden" name="organizacao_id" id="organizacao_id" value="' + organizationID + '" />';
616        content += '<table>';
617        content += '<tr><td><label for="descricao">Nome</label></td><td><input type="text" name="descricao" id="descricao" size="30" /></td></tr>';
618        content += "</table>";
619        content += '</form>';
620        content += '<button id="inserir" onclick="objEmployeeCategory.add(); return false;">Inserir</button>';
621        content += '<button onclick="valid.deactivate(); return false;">Cancelar</button>';
622
623        var divLB = $('lbContent');
624        divLB.innerHTML = content;
625        //$('descricao').focus();
626        objEmployeeCategory.generateUpdateTable({'organizacao_id': organizationID}, divLB);
627}
628
629function loadAddJobTitleUI(organizationID)
630{
631        var content;
632        content = '<h2 id="modalTitle">Adicionar Cargos</h2>';
633        content += '<form name="orgchartForm" id="orgchartForm">';
634        content += '<input type="hidden" name="organizacao_id" id="organizacao_id" value="' + organizationID + '" />';
635        content += '<table>';
636        content += '<tr><td><label for="descricao">Nome</label></td><td><input type="text" name="descricao" id="descricao" size="30" /></td></tr>';
637        content += "</table>";
638        content += '</form>';
639        content += '<button id="inserir" onclick="objJobTitle.add(); return false;">Inserir</button>';
640        content += '<button onclick="valid.deactivate(); return false;">Cancelar</button>';
641
642        var divLB = $('lbContent');
643        divLB.innerHTML = content;
644        //$('descricao').focus();
645        objJobTitle.generateUpdateTable({'organizacao_id': organizationID}, divLB);
646}
647
648function loadAddAreaStatusUI(organizationID)
649{
650        var content;
651        content = '<h2 id="modalTitle">Adicionar Status de Área</h2>';
652        content += '<form name="orgchartForm" id="orgchartForm">';
653        content += '<input type="hidden" name="organizacao_id" id="organizacao_id" value="' + organizationID + '" />';
654        content += '<table>';
655        content += '<tr><td><label for="descricao">Nome</label></td><td><input type="text" name="descricao" id="descricao" size="30" /></td></tr>';
656        content += '<tr><td><label for="nivel">Nível</label></td><td><input type="text" name="nivel" id="nivel" size="3" /></td></tr>';
657        content += "</table>";
658        content += '</form>';
659        content += '<button id="inserir" onclick="objAreaStatus.add(); return false;">Inserir</button>';
660        content += '<button onclick="valid.deactivate(); return false;">Cancelar</button>';
661
662        var divLB = $('lbContent');
663        divLB.innerHTML = content;
664        //$('descricao').focus();
665        objAreaStatus.generateUpdateTable({'organizacao_id': organizationID}, divLB);
666}
667
668function loadAddCostCenterUI(organizationID)
669{
670        var content;
671        content = '<h2 id="modalTitle">Adicionar Centro de Custo</h2>';
672        content += '<form name="orgchartForm" id="orgchartForm">';
673        content += '<input type="hidden" name="organizacao_id" id="organizacao_id" value="' + organizationID + '" />';
674        content += "<table>";
675        content += '<tr><td><label for="nm_centro_custo">Número</label></td><td><input type="text" name="nm_centro_custo" id="nm_centro_custo" size="4" /></td></tr>';
676        content += '<tr><td><label for="descricao">Nome</label></td><td><input type="text" name="descricao" id="descricao" size="30" /></td></tr>';
677        content += '<tr><td><label for="grupo">Grupo</label></td><td><input type="text" name="grupo" id="grupo" size="10" /></td></tr>';
678        content += "</table>";
679        content += '</form>';
680        content += '<button id="inserir" onclick="objCostCenter.add(); return false;">Inserir</button>';
681        content += '<button onclick="valid.deactivate(); return false;">Cancelar</button>';
682
683        var divLB = $('lbContent');
684        divLB.innerHTML = content;
685        //$('nm_centro_custo').focus();
686        objCostCenter.generateUpdateTable({'organizacao_id': organizationID}, divLB);
687}
688
689function loadAddLocalUI(organizationID)
690{
691        var valoresSimNao = new Array();
692        valoresSimNao['S'] = 'Sim';
693        valoresSimNao['N'] = 'Não';
694
695        var content;
696        content = '<h2 id="modalTitle">Adicionar Localidade</h2>';
697        content += '<form name="orgchartForm" id="orgchartForm">';
698        content += '<input type="hidden" name="organizacao_id" id="organizacao_id" value="' + organizationID + '" />';
699        content += "<table>";
700        content += '<tr><td><label for="descricao">Nome</label></td><td><input type="text" name="descricao" id="descricao" size="30" /></td></tr>';
701
702        content += '<tr><td><label for="empresa">Empresa</label></td><td><input type="text" name="empresa" id="empresa" size="80" /></td></tr>';
703        content += '<tr><td><label for="endereco">Endereço</label></td><td><input type="text" name="endereco" id="endereco" size="80" /></td></tr>';
704        content += '<tr><td><label for="complemento">Complemento</label></td><td><input type="text" name="complemento" id="complemento" size="50" /></td></tr>';
705        content += '<tr><td><label for="cep">Cep</label></td><td><input type="text" name="cep" id="cep" size="10" /></td></tr>';
706        content += '<tr><td><label for="bairro">Bairro</label></td><td><input type="text" name="bairro" id="bairro" size="30" /></td></tr>';
707        content += '<tr><td><label for="cidade">Cidade</label></td><td><input type="text" name="cidade" id="cidade" size="50" /></td></tr>';
708        content += '<tr><td><label for="uf">UF</label></td><td><input type="text" name="uf" id="uf" size="2" maxlength="2" /></td></tr>';
709
710        content += '<tr><td><label for="centro_custo_id">Centro de Custo</label></td><td id="comboCentroCusto"><i>carregando</i></td></tr>';
711        content += '<tr><td><label for="externa">Externa à organização</label></td><td>' + constructSelectBox('externa', valoresSimNao) + '</td></tr>';
712        content += "</table>";
713        content += '</form>';
714        content += '<button id="inserir" onclick="objLocal.add(); return false;">Inserir</button>';
715        content += '<button onclick="valid.deactivate(); return false;">Cancelar</button>';
716
717        var divLB = $('lbContent');
718        divLB.innerHTML = content;
719        //$('descricao').focus();
720        objCostCenter.generateComboBox({'organizacao_id': organizationID}, $('comboCentroCusto'), true, null,
721                function()
722                {
723                        objLocal.generateUpdateTable({'organizacao_id': organizationID}, divLB);
724                }
725        );
726}
727
728function loadAddEmployeeUI(organizationID, callback)
729{
730        var content;
731        content = '<h2 id="modalTitle">Adicionar Funcionário</h2>';
732        content += '<form name="orgchartForm" id="orgchartForm">';
733        content += '<input type="hidden" name="organizacao_id" id="organizacao_id" value="' + organizationID + '" />';
734        content += "<table>";
735        content += '<tr><td><label for="funcionario_id_desc">Funcionário</label></td><td>';
736        content += '<input type="hidden" name="funcionario_id" id="funcionario_id" value="" />';
737        content += '<input type="input" name="funcionario_id_desc" id="funcionario_id_desc" value="" readonly="true" size="40" />';
738        content += '<a href="javascript:void(0)" onclick="openParticipantsWindow(\'funcionario_id\', \'uid=1&hidegroups=1\');" id="addEmployeeLink"><img border="0" width="16" height="16" src="workflow/templateFile.php?file=images/add_user.png" /></a>';
739        content += '</td></tr>';
740        content += '<tr><td><label for="funcionario_status_id">Status</label></td><td id="comboStatus"><i>carregando</i></td></tr>';
741        content += '<tr><td><label for="apelido">Apelido</label></td><td><input type="text" size="20" maxlength="20" name="apelido" id="apelido" value=""/></td></tr>';
742        content += '<tr><td><label for="funcionario_categoria_id">Categoria</label></td><td id="comboFuncionarioCategoria"><i>carregando</i></td></tr>';
743        content += '<tr><td><label for="cargo_id">Cargo</label></td><td id="comboCargo"><i>carregando</i></td></tr>';
744        content += '<tr><td><label for="funcao">Função</label></td><td><input type="text" size="50" maxlength="200" name="funcao" id="funcao" value=""/></td></tr>';
745        content += '<tr><td><label for="data_admissao">Data de admissão</label></td><td><input type="text" name="data_admissao" id="data_admissao" value="" size="15" onkeypress="return formatDateField(event, this);" /></td></tr>';
746        content += '<tr><td><label for="titulo">T&iacute;tulo</label></td><td><input type="text" size="30" name="titulo" id="titulo" value=""/></td></tr>';
747        content += '<tr><td><label for="nivel">Nível</label></td><td><input type="text" size="3" name="nivel" id="nivel"/></td></tr>';
748        content += '<tr><td><label for="area_id">Área</label></td><td id="comboArea"><i>carregando</i></td></tr>';
749        content += '<tr><td><label for="centro_custo_id">Centro de Custo</label></td><td id="comboCentroCusto"><i>carregando</i></td></tr>';
750        content += '<tr><td><label for="localidade_id">Localidade</label></td><td id="comboLocalidade"><i>carregando</i></td></tr>';
751        content += "</table>";
752        content += '</form>';
753        content += '<button id="inserir" onclick="objEmployee.add(); return false;">Inserir</button>';
754        content += '<button onclick="valid.deactivate(); return false;">Cancelar</button>';
755       
756        var divLB = $('lbContent');
757    divLB.innerHTML = content;
758
759    objEmployeeStatus.generateComboBox({'organizacao_id': organizationID}, $('comboStatus'), false, null,
760        function()
761        {
762            objEmployeeCategory.generateComboBox({'organizacao_id': organizationID}, $('comboFuncionarioCategoria'), true, null,
763                function()
764                {
765                    objJobTitle.generateComboBox({'organizacao_id': organizationID}, $('comboCargo'), true, null,
766                        function()
767                        {
768                            objArea.generateComboBox({'organizacao_id': organizationID}, $('comboArea'), false, null,
769                                function()
770                                {
771                                    objCostCenter.generateComboBox({'organizacao_id': organizationID}, $('comboCentroCusto'), true, null,
772                                        function()
773                                        {
774                                            objLocal.generateComboBox({'organizacao_id': organizationID}, $('comboLocalidade'), false, null, callback);
775                                        }
776                                    )
777                                }
778                            )
779                        }
780                    )
781                }
782            )
783        }
784    );
785}
786
787function loadAddAreaUI(organizationID)
788{
789        var valoresSimNao = new Array();
790        valoresSimNao['S'] = 'Sim';
791        valoresSimNao['N'] = 'Não';
792
793        var content;
794        content = '<h2 id="modalTitle">Adicionar Área</h2>';
795        content += '<form name="orgchartForm" id="orgchartForm">';
796        content += '<input type="hidden" name="organizacao_id" id="organizacao_id" value="' + organizationID + '" />';
797        content += "<table>";
798        content += '<tr><td><label for="sigla">Sigla</label></td><td><input type="text" name="sigla" id="sigla" size="15" /></td></tr>';
799        content += '<tr><td><label for="descricao">Nome</label></td><td><input type="text" name="descricao" id="descricao" size="30" /></td></tr>';
800        content += '<tr><td><label for="titular_funcionario_id">Titular</label></td><td>';
801        content += '<input type="hidden" name="titular_funcionario_id" id="titular_funcionario_id" value="" />';
802        content += '<input type="input" name="titular_funcionario_id_desc" id="titular_funcionario_id_desc" value="" readonly="true" size="40" />';
803        content += '<a href="javascript:void(0)" onclick="openParticipantsWindow(\'titular_funcionario_id\', \'uid=1&hidegroups=1\');"><img border="0" width="16" height="16" src="workflow/templateFile.php?file=images/add_user.png" /></a>';
804        content += ' <a href="javascript:void(0)" onclick="$(\'titular_funcionario_id\').value=\'\'; $(\'titular_funcionario_id_desc\').value=\'\'; return false;"><img border="0" width="16" height="16" src="workflow/templateFile.php?file=images/delete_user.png" /></a>';
805        content += '</td></tr>';
806        content += '<tr><td><label for="auxiliar_funcionario_id">Auxiliar Administrativo</label></td><td>';
807        content += '<input type="hidden" name="auxiliar_funcionario_id" id="auxiliar_funcionario_id" value="" />';
808        content += '<input type="input" name="auxiliar_funcionario_id_desc" id="auxiliar_funcionario_id_desc" value="" readonly="true" size="40" />';
809        content += '<a href="javascript:void(0)" onclick="openParticipantsWindow(\'auxiliar_funcionario_id\', \'uid=1&hidegroups=1\');"><img border="0" width="16" height="16" src="workflow/templateFile.php?file=images/add_user.png" /></a>';
810        content += ' <a href="javascript:void(0)" onclick="$(\'auxiliar_funcionario_id\').value=\'\'; $(\'auxiliar_funcionario_id_desc\').value=\'\'; return false;"><img border="0" width="16" height="16" src="workflow/templateFile.php?file=images/delete_user.png" /></a>';
811        content += '</td></tr>';
812        content += '<tr><td><label for="area_status_id">Status</label></td><td id="comboStatus"><i>carregando</i></td></tr>';
813        content += '<tr><td><label for="superior_area_id">Área Superior</label></td><td id="comboArea"><i>carregando</i></td></tr>';
814        content += '<tr><td><label for="centro_custo_id">Centro de Custo</label></td><td id="comboCentroCusto"><i>carregando</i></td></tr>';
815        content += '<tr><td><label for="ativa">Ativa</label></td><td>' + constructSelectBox('ativa', valoresSimNao) + '</td></tr>';
816        content += "</table>";
817        content += '</form>';
818        content += '<button id="inserir" onclick="objArea.add(); return false;">Inserir</button>';
819        content += '<button onclick="valid.deactivate(); return false;">Cancelar</button>';
820
821        var divLB = $('lbContent');
822        divLB.innerHTML = content;
823        $('sigla').focus();
824
825        objAreaStatus.generateComboBox({'organizacao_id': organizationID}, $('comboStatus'), false, null,
826                function()
827                {
828                        objArea.generateComboBox({'organizacao_id': organizationID}, $('comboArea'), true, 'superior_area_id',
829                                function()
830                                {
831                                        objCostCenter.generateComboBox({'organizacao_id': organizationID}, $('comboCentroCusto'), false, null,
832                                                function()
833                                                {
834                                                        objArea.generateUpdateTable({'organizacao_id': organizationID}, divLB);
835                                                }
836                                        )
837                                }
838                        )
839                }
840        );
841}
842
843function loadAddTelephoneUI(organizationID)
844{
845        var content;
846        content = '<h2 id="modalTitle">Adicionar Telefones da Organização</h2>';
847        content += '<form name="orgchartForm" id="orgchartForm">';
848        content += '<input type="hidden" name="organizacao_id" id="organizacao_id" value="' + organizationID + '" />';
849        content += '<table>';
850        content += '<tr><td><label for="descricao">Descrição</label></td><td><input type="text" name="descricao" id="descricao" size="50" /></td></tr>';
851        content += '<tr><td><label for="nivel">Telefones</label></td><td><input type="text" name="numero" id="numero" size="50" /></td></tr>';
852        content += "</table>";
853        content += '</form>';
854        content += '<button id="inserir" onclick="objTelephones.add(); return false;">Inserir</button>';
855        content += '<button onclick="valid.deactivate(); return false;">Cancelar</button>';
856
857        var divLB = $( 'lbContent' );
858        divLB.innerHTML = content;
859        //$( 'descricao' ).focus( );
860        objTelephones.generateUpdateTable( { 'organizacao_id' : organizationID }, divLB );
861}
862
863
864function loadAddSubstitutionUI(organizationID)
865{
866        var area_id = 'combo_area';
867        var content;
868
869        content  = '<h2 id="modalTitle">Adicionar Substituição</h2>';
870        content += '<form name="orgchartForm" id="orgchartForm">';
871        content += '<input type="hidden" name="organizacao_id" id="organizacao_id" value="' + organizationID + '" />';
872        content += "<table>";
873        content += '<tr><td><label for="area_id">Sigla</label>';
874        content += '<input type="hidden" name="area_id" id="area_id" value="" />';
875        content += '</td><td id="comboArea"><i>carregando</i></td></tr>';
876        content += '<tr><td><label for="descricao">Nome</label></td><td><input type="text" name="descricao" id="descricao" readonly="true" size="40" /></td></tr>';
877        content += '<tr><td><label for="titular_funcionario_id">Titular</label></td><td>';
878        content += '<input type="hidden" name="titular_funcionario_id" id="titular_funcionario_id" value="" readonly="true" />';
879        content += '<input type="input" name="titular_funcionario_id_desc" id="titular_funcionario_id_desc" value="" readonly="true" size="40" />';
880        content += '</td></tr>';
881        content += '<tr><td><label for="substituto_funcionario_id">Substituto</label></td><td>';
882        content += '<input type="hidden" name="substituto_funcionario_id" id="substituto_funcionario_id" value="" />';
883        content += '<input type="input" name="substituto_funcionario_id_desc" id="substituto_funcionario_id_desc" value="" readonly="true" size="40" />';
884        content += '<a href="javascript:void(0)" onclick="openParticipantsWindow(\'substituto_funcionario_id\', \'uid=1&hidegroups=1\');"><img border="0" width="16" height="16" src="workflow/templateFile.php?file=images/add_user.png" /></a>';
885        content += ' <a href="javascript:void(0)" onclick="$(\'substituto_funcionario_id\').value=\'\'; $(\'substituto_funcionario_id_desc\').value=\'\'; return false;"><img border="0" width="16" height="16" src="workflow/templateFile.php?file=images/delete_user.png" /></a>';
886        content += '</td></tr>';
887        content += '<tr><td><label for="data_inicio">Data de início</label></td><td><input type="text" name="data_inicio" id="data_inicio" size="15" onkeypress="return formatDateField(event, this);" /></td></tr>';
888        content += '<tr><td><label for="data_fim">Data de término</label></td><td><input type="text" name="data_fim" id="data_fim" size="15" onkeypress="return formatDateField(event, this);"/></td></tr>';
889        content += "</table>";
890        content += '</form>';
891        content += '<button id="inserir" onclick="objSubstitution.add(); return false;">Inserir</button>';
892        content += '<button onclick="valid.deactivate(); return false;">Cancelar</button>';
893
894        var divLB = $('lbContent');
895        divLB.innerHTML = content;
896
897        // function that must be called after loading areas on the combobox
898        var areas_callback = function () {
899
900                // every change on the combo box must query for area information
901                $(area_id).onchange = function () {
902                        if ($('SubstitutionList'))
903                                $('SubstitutionList').remove();
904                       
905                        var info_callback = function (data) {
906
907                                // just to be sure
908                                if (!data[0]) {
909                                        alert("Não foi possível encontrar os dados.");
910                                }
911
912                                // we received an empty response. Let's reset the form.
913                                if ((data[0]['area_id'] == '') || (data[0]['area_id'] == null)) {
914                                        alert('RESET');
915                                        $('area_id').value = '';
916                                        $('descricao').value = '';
917                                        $('titular_funcionario_id').value = '';
918                                        $('titular_funcionario_id_desc').value = '';
919                                }
920                                // fill the form
921                                else {
922                                        $('area_id').value = data[0]['area_id'];
923                                        $('descricao').value = data[0]['descricao'];
924                                        $('titular_funcionario_id').value = data[0]['titular_funcionario_id'];
925                                        $('titular_funcionario_id_desc').value = data[0]['titular_funcionario_id_desc'];
926                                }
927
928                                // get the list of substitutions
929                                objSubstitution.generateUpdateTable({'organizacao_id': organizationID, 'area_id': $(area_id).value}, divLB);
930                        }
931                        objArea.list(info_callback, {'organizacao_id': organizationID, 'area_id': $(area_id).value});
932
933                }
934        }
935        objArea.generateComboBox({'organizacao_id': organizationID}, $('comboArea'), true, area_id, areas_callback);
936}
937
938function getEmployeeInfoTimer(e, employeeID, organizationID)
939{
940        var div = $('employeeInfo');
941        div.style.left = (Event.pointerX(e) + 20) + 'px';
942        div.style.top = (Event.pointerY(e) + 14) + 'px';
943
944        if (workflowOrgchartAdminEmployeeInfoTimer != null)
945        {
946                workflowOrgchartAdminEmployeeInfoTimer = clearTimeout(workflowOrgchartAdminEmployeeInfoTimer);
947                workflowOrgchartAdminEmployeeInfoTimer = null;
948        }
949
950        workflowOrgchartAdminEmployeeInfoTimer = setTimeout('getEmployeeInfo(' + employeeID + ', ' + organizationID + ' )', 500);
951}
952
953function getEmployeeInfo(employeeID, organizationID)
954{
955        function resultGetEmployeeInfo(data)
956        {
957                if (workflowOrgchartAdminEmployeeInfoTimer == null)
958                        return;
959
960                workflowOrgchartAdminEmployeeInfoTimer = clearTimeout(workflowOrgchartAdminEmployeeInfoTimer);
961                workflowOrgchartAdminEmployeeInfoTimer = null;
962
963                var content = '';
964                content += '<table><tr><td valign="top">';
965                content += '<img src="workflow/showUserPicture.php?userID=' + employeeID + '"/>';
966                content += '</td><td valign="top" style="padding-left: 12px;">';
967                for (var i = 0; i < data['info'].length; i++)
968                        content += '<strong>' + data['info'][i]['name'] + '</strong>: ' + data['info'][i]['value'] + '<br/>';
969                content += '</td></tr></table>';
970                var pageYLimit = document.body.scrollTop + document.body.clientHeight;
971                var div = $('employeeInfo');
972                div.innerHTML = content;
973
974                if ((parseInt(div.style.top.replace(/px/g, '')) + div.getHeight()) > pageYLimit)
975                        div.style.top = (parseInt(div.style.top.replace(/px/g, '')) - (div.getHeight())) + 'px';
976
977                div.show();
978        }
979        cExecute('$this.bo_orgchart.getEmployeeInfo', resultGetEmployeeInfo, 'funcionario_id=' + employeeID + '&organizacao_id=' + organizationID);
980}
981
982function hideEmployeeInfo()
983{
984        if (workflowOrgchartAdminEmployeeInfoTimer != null)
985        {
986                workflowOrgchartAdminEmployeeInfoTimer = clearTimeout(workflowOrgchartAdminEmployeeInfoTimer);
987                workflowOrgchartAdminEmployeeInfoTimer = null;
988        }
989        $('employeeInfo').hide();
990}
991
992function getAreaInfoTimer(e, areaID, organizationID)
993{
994        var div = $('areaInfo');
995        div.style.left = (Event.pointerX(e) + 20) + 'px';
996        div.style.top = (Event.pointerY(e) + 14) + 'px';
997
998        if (workflowOrgchartAdminAreaInfoTimer != null)
999        {
1000                workflowOrgchartAdminAreaInfoTimer = clearTimeout(workflowOrgchartAdminAreaInfoTimer);
1001                workflowOrgchartAdminAreaInfoTimer = null;
1002        }
1003
1004        workflowOrgchartAdminAreaInfoTimer = setTimeout('getAreaInfo(' + areaID + ', ' + organizationID + ' )', 500);
1005}
1006
1007function getAreaInfo(areaID, organizationID)
1008{
1009        function resultGetAreaInfo(data)
1010        {
1011                if (workflowOrgchartAdminAreaInfoTimer == null)
1012                        return;
1013
1014                workflowOrgchartAdminAreaInfoTimer = clearTimeout(workflowOrgchartAdminAreaInfoTimer);
1015                workflowOrgchartAdminAreaInfoTimer = null;
1016
1017                var content = '';
1018                content += '<table><tr>';
1019                content += '<td valign="top" style="padding-left: 12px;">';
1020                for (var i = 0; i < data['info'].length; i++)
1021                        content += '<strong>' + data['info'][i]['name'] + '</strong>: ' + data['info'][i]['value'] + '<br/>';
1022                content += '</td></tr></table>';
1023                var pageYLimit = document.body.scrollTop + document.body.clientHeight;
1024                var div = $('areaInfo');
1025                div.innerHTML = content;
1026
1027                if ((parseInt(div.style.top.replace(/px/g, '')) + div.getHeight()) > pageYLimit)
1028                        div.style.top = (parseInt(div.style.top.replace(/px/g, '')) - (div.getHeight())) + 'px';
1029
1030                div.show();
1031        }
1032        cExecute('$this.bo_orgchart.getAreaInfo', resultGetAreaInfo, 'area_id=' + areaID + '&organizacao_id=' + organizationID);
1033}
1034
1035function hideAreaInfo()
1036{
1037        if (workflowOrgchartAdminAreaInfoTimer != null)
1038        {
1039                workflowOrgchartAdminAreaInfoTimer = clearTimeout(workflowOrgchartAdminAreaInfoTimer);
1040                workflowOrgchartAdminAreaInfoTimer = null;
1041        }
1042        $('areaInfo').hide();
1043}
Note: See TracBrowser for help on using the repository browser.