so = new so_orgchart(); } /** * Lista todas as organizações do Organograma. * @return array Lista de organizações. * @access public */ function listOrganization() { $result = $this->so->getOrganizations(); $this->disconnect_all(); return $result; } /** * Adiciona uma organização. * @param array $params Uma array contendo os parâmetros necessários para adicionar uma organização (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function addOrganization($params) { $result = $this->so->addOrganization($params['nome'], $params['descricao'], $params['url_imagem'], $params['ativa']); $this->disconnect_all(); return $result; } /** * Atualiza uma organização. * @param array $params Uma array contendo os parâmetros da organização que serão modificados (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function updateOrganization($params) { $result = $this->so->updateOrganization($params['nome'], $params['descricao'], $params['url_imagem'], $params['ativa'], $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Remove uma organização. * @param array $params Uma array contendo o ID da organização que será excluída (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function removeOrganization($params) { $result = $this->so->removeOrganization($params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Lista os possíveis status dos funcionários. * @param array $params Uma array contendo o ID da organização de onde os status dos empregados serão listados (Ajax). * @return array Lista dos possíveis status dos empregados. * @access public */ function listEmployeeStatus($params) { $result = $this->so->getEmployeeStatus($params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Adiciona um Status de funcionário. * @param array $params Uma array contendo os parâmetros necessários para adicionar um status de funcionário (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function addEmployeeStatus($params) { $result = $this->so->addEmployeeStatus($params['organizacao_id'], $params['descricao'], $params['exibir']); $this->disconnect_all(); return $result; } /** * Atualiza um Status de funcionário. * @param array $params Uma array contendo os parâmetros do status de funcionário que podem ser alterados (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function updateEmployeeStatus($params) { $result = $this->so->updateEmployeeStatus($params['funcionario_status_id'], $params['organizacao_id'], $params['descricao'], $params['exibir']); $this->disconnect_all(); return $result; } /** * Remove um Status de funcionário. * @param array $params Uma array contendo a organização e o ID do status de funcionário que será excluído (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function removeEmployeeStatus($params) { $result = $this->so->removeEmployeeStatus($params['funcionario_status_id'], $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Lista as possíveis categorias de uma organização. * @param array $params Uma array contendo o ID da organização de onde as categorias serão listadas (Ajax). * @return array Lista dos possíveis categorias. * @access public */ function listEmployeeCategory($params) { $result = $this->so->getEmployeeCategory($params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Adiciona uma categoria. * @param array $params Uma array contendo os parâmetros necessários para adicionar uma categoria (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function addEmployeeCategory($params) { $result = $this->so->addEmployeeCategory($params['organizacao_id'], $params['descricao']); $this->disconnect_all(); return $result; } /** * Atualiza uma categoria. * @param array $params Uma array contendo os parâmetros da categoria que podem ser alterados (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function updateEmployeeCategory($params) { $result = $this->so->updateEmployeeCategory($params['funcionario_categoria_id'], $params['organizacao_id'], $params['descricao']); $this->disconnect_all(); return $result; } /** * Remove uma categoria. * @param array $params Uma array contendo o ID da categoria que será excluída e de sua organização (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function removeEmployeeCategory($params) { $result = $this->so->removeEmployeeCategory($params['funcionario_categoria_id'], $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Lista os possíveis cargos de uma organização. * @param array $params Uma array contendo o ID da organização de onde os cargos serão listados (Ajax). * @return array Lista dos possíveis cargos. * @access public */ function listJobTitle($params) { $result = $this->so->getJobTitle($params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Adiciona um cargo. * @param array $params Uma array contendo os parâmetros necessários para adicionar um cargo (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function addJobTitle($params) { $result = $this->so->addJobTitle($params['organizacao_id'], $params['descricao']); $this->disconnect_all(); return $result; } /** * Atualiza um cargo. * @param array $params Uma array contendo os parâmetros do cargo que podem ser alterados (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function updateJobTitle($params) { $result = $this->so->updateJobTitle($params['cargo_id'], $params['organizacao_id'], $params['descricao']); $this->disconnect_all(); return $result; } /** * Remove um cargo. * @param array $params Uma array contendo o ID do cargo que será excluído e de sua organização (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function removeJobTitle($params) { $result = $this->so->removeJobTitle($params['cargo_id'], $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Lista os possíveis status de área. * @param array $params Uma array contendo o ID da organização de onde os status de área serão listados (Ajax). * @return array Lista dos possíveis status de área. * @access public */ function listAreaStatus($params) { $result = $this->so->getAreaStatus($params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Adiciona um status de área. * @param array $params Uma array contendo os parâmetros necessários para adicionar um status de área (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function addAreaStatus($params) { $result = $this->so->addAreaStatus($params['organizacao_id'], $params['descricao'], $params['nivel']); $this->disconnect_all(); return $result; } /** * Atualiza um status de área. * @param array $params Uma array contendo os parâmetros do status de área que podem ser alterados (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function updateAreaStatus($params) { $result = $this->so->updateAreaStatus($params['area_status_id'], $params['organizacao_id'], $params['descricao'], $params['nivel']); $this->disconnect_all(); return $result; } /** * Remove um status de área. * @param array $params Uma array contendo o ID do status de área que será excluído e de sua organização (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function removeAreaStatus($params) { $result = $this->so->removeAreaStatus($params['area_status_id'], $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Lista os centros de custo de uma organização. * @param array $params Uma array contendo o ID da organização dos centros de custo (Ajax). * @return array Lista dos centros de custo de uma organização. * @access public */ function listCostCenter($params) { $result = $this->so->getCostCenter($params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Adiciona um centro de custo. * @param array $params Uma array contendo os parâmetros necessários para adicionar um centro de custo (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function addCostCenter($params) { $result = $this->so->addCostCenter($params['organizacao_id'], $params['nm_centro_custo'], $params['descricao'], $params['grupo']); $this->disconnect_all(); return $result; } /** * Atualiza um centro de custo. * @param array $params Uma array contendo os parâmetros do centro de custo que podem ser alterados (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function updateCostCenter($params) { $result = $this->so->updateCostCenter($params['organizacao_id'], $params['nm_centro_custo'], $params['descricao'], $params['grupo'], $params['centro_custo_id']); $this->disconnect_all(); return $result; } /** * Remove um centro de custo. * @param array $params Uma array contendo o ID do centro de custo que será excluído e de sua organização (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function removeCostCenter($params) { $result = $this->so->removeCostCenter($params['centro_custo_id'], $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Lista as localidades de uma organização. * @param array $params Uma array contendo o ID da organização das localidades (Ajax). * @return array Lista das localidades de uma organização. * @access public */ function listLocal($params) { $result = $this->so->getLocal($params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Adiciona uma localidade. * @param array $params Uma array contendo os parâmetros necessários para adicionar uma localidade (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function addLocal($params) { $result = $this->so->addLocal($params['organizacao_id'], $this->_nullReplace($params['centro_custo_id']), $params['descricao']); $this->disconnect_all(); return $result; } /** * Atualiza uma localidade. * @param array $params Uma array contendo os parâmetros da localidade que podem ser alterados (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function updateLocal($params) { $result = $this->so->updateLocal($params['organizacao_id'], $this->_nullReplace($params['centro_custo_id']), $params['descricao'], $params['localidade_id']); $this->disconnect_all(); return $result; } /** * Remove uma localidade. * @param array $params Uma array contendo o ID da localidade que será excluída e de sua organização (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function removeLocal($params) { $result = $this->so->removeLocal($params['localidade_id'], $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Lista os funcionários de uma área. * @param array $params Uma array contendo o ID da organização dos funcionários e de uma área desta organização (Ajax). * @return array Lista dos funcionários de uma área. * @access public */ function listAreaEmployee($params) { $result = $this->so->getAreaEmployee($params['area_id'], $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Lista de funcionários que satisfazem um determinados critério de busca. * @param array $params Uma array contendo o ID da organização dos funcionários e o critério de busca (Ajax). * @return array Lista das localidades de uma organização. * @access public */ function searchEmployee($params) { if (!ereg('^([[:alnum:] ]+)$', $params['search_term'])) die(serialize("Parametro de busca inválido")); $result = $this->so->searchEmployee($params['search_term'], $params['organizacao_id']); $this->disconnect_all(); usort($result, create_function('$a,$b', 'return strcasecmp($a[\'funcionario_id_desc\'],$b[\'funcionario_id_desc\']);')); return $result; } /** * Adiciona um funcionário. * @param array $params Uma array contendo os parâmetros necessários para adicionar um funcionário (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function addEmployee($params) { $result = $this->so->addEmployee($params['funcionario_id'], $params['organizacao_id'], $params['area_id'], $this->_nullReplace($params['centro_custo_id']), $params['localidade_id'], $params['funcionario_status_id'], $this->_nullReplace($params['cargo_id']), $this->_nullReplace($params['nivel']), $this->_nullReplace($params['funcionario_categoria_id'])); $this->disconnect_all(); return $result; } /** * Atualiza funcionário. * @param array $params Uma array contendo os parâmetros do funcionário que podem ser alterados (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function updateEmployee($params) { $result = $this->so->updateEmployee($params['funcionario_id'], $params['organizacao_id'], $params['area_id'], $this->_nullReplace($params['centro_custo_id']), $params['localidade_id'], $params['funcionario_status_id'], $this->_nullReplace($params['cargo_id']), $this->_nullReplace($params['nivel']), $this->_nullReplace($params['funcionario_categoria_id'])); $this->disconnect_all(); return $result; } /** * Remove um funcionário. * @param array $params Uma array contendo o ID do funcionário que será excluído e de sua organização (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function removeEmployee($params) { $result = $this->so->removeEmployee($params['funcionario_id'], $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Lista as áreas de uma organização. * @param array $params Uma array contendo o ID da organização das áreas (Ajax). * @return array Lista das áreas de uma organização. * @access public */ function listArea($params) { $result = $this->so->getArea($params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Lista, hierarquicamente, as áreas de uma organização. * @param array $params Uma array contendo o ID da organização das áreas (Ajax). * @return array Lista hierárquica das áreas de uma organização. * @access public */ function listHierarchicalArea($params) { $result = $this->so->getHierarchicalArea($params['organizacao_id'], null, 0); $this->disconnect_all(); return $result; } /** * Adiciona uma área. * @param array $params Uma array contendo os parâmetros necessários para adicionar uma área (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function addArea($params) { $result = $this->so->addArea($params['centro_custo_id'], $params['organizacao_id'], $params['area_status_id'], $this->_nullReplace($params['substituto_funcionario_id']), $this->_nullReplace($params['titular_funcionario_id']), $this->_nullReplace($params['superior_area_id']), $params['sigla'], $params['descricao'], $params['ativa'], $this->_nullReplace($params['auxiliar_funcionario_id'])); $this->disconnect_all(); return $result; } /** * Atualiza uma área. * @param array $params Uma array contendo os parâmetros da área que podem ser alterados (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function updateArea($params) { $result = $this->so->updateArea($params['centro_custo_id'], $params['organizacao_id'], $params['area_status_id'], $this->_nullReplace($params['substituto_funcionario_id']), $this->_nullReplace($params['titular_funcionario_id']), $this->_nullReplace($params['superior_area_id']), $params['sigla'], $params['descricao'], $params['ativa'], $this->_nullReplace($params['auxiliar_funcionario_id']), $params['area_id']); $this->disconnect_all(); return $result; } /** * Remove uma área. * @param array $params Uma array contendo o ID da área que será excluído e de sua organização (Ajax). * @return bool TRUE se a ação foi concluída com êxito e FALSE caso contrário. * @access public */ function removeArea($params) { $result = $this->so->removeArea($params['area_id'], $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Busca informações sobre um funcionário. * @param array $params Uma array contendo o ID do funcionário cujas informações serão extraídas e de sua organização (Ajax). * @return array Informações sobre o funcionário. * @access public */ function getEmployeeInfo($params) { $result = $this->so->getEmployeeInfo((int) $params['funcionario_id'], (int) $params['organizacao_id']); $this->disconnect_all(); return $result; } /** * Busca informações sobre uma área. * @param array $params Uma array contendo o ID da área cujas informações serão extraídas e de sua organização (Ajax). * @return array Informações sobre a área. * @access public */ function getAreaInfo($params) { $result = $this->so->getAreaInfo((int) $params['area_id'], (int) $params['organizacao_id']); $this->disconnect_all(); return $result; } } ?>