public function removeFilesAction()
 {
     $this->_helper->layout->setLayout('ajax');
     $request = $this->_request;
     if ($request->isPost()) {
         $data = $request->getPost();
         $documentos = new Application_Model_Documentos();
         echo json_encode($documentos->removeFiles($data['names']));
     }
 }
 public function editAction()
 {
     $request = $this->getRequest();
     $cid = $request->getParam('cid');
     $id = $request->getParam('id');
     $model = new Application_Model_Propostas();
     $modelCliente = new Application_Model_Clientes();
     $documentos = new Application_Model_Documentos();
     $form = new Application_Form_Proposta();
     if (!in_array(CURRENT_USER_ROLE, array('Corretor', 'Financeiro'))) {
         $users = new Application_Model_Usuarios();
         $db = Zend_Db_Table::getDefaultAdapter();
         $result = $db->fetchAll($users->selectAll());
         $options = array();
         $required = new Zend_Validate_NotEmpty();
         $required->setType($required->getType() | Zend_Validate_NotEmpty::STRING | Zend_Validate_NotEmpty::ZERO);
         foreach ($result as $key => $value) {
             $options[$value['id']] = $value['nome'] . ' - ' . $value['role'];
         }
         $form->addElement('select', 'created_user_id', array('label' => 'Usuário', 'title' => 'Mude usuário responsável pela proposta', 'required' => true, 'filters' => array('StringTrim'), 'class' => 'form-control', 'multiOptions' => $options, 'validators' => array($required), 'decorators' => $form->setColSize(4)));
     }
     if ($request->isPost() && $form->isValid($request->getPost())) {
         $data = $request->getPost();
         if ($id == 0) {
             unset($data['id']);
             if ($model->insert($data)) {
                 $this->_FlashMessenger->setNamespace($this->_controllerName)->addMessage('Proposta adicionada com sucesso!');
                 $this->view->message_type = 'alert-success';
                 $this->redirect($this->_controllerName . '/edit/id/' . $model->lastInserId() . '/cid/' . $cid);
             }
         } else {
             if ($model->update($id, $data)) {
                 $this->view->messages = array('Atualziado com sucesso!');
                 $this->view->message_type = 'alert-success';
             } else {
                 $this->view->messages = array('Sem alterações!');
                 $this->view->message_type = 'alert-info';
             }
         }
     } else {
         $dataProposta = $model->selectById($id);
         // Verificando se ja existe uma proposta
         if ($dataProposta) {
             $data = $dataProposta;
             if (!empty($data['dados_extras'])) {
                 $dadosExtras = json_decode($data['dados_extras'], true);
                 $data = array_merge($data, $dadosExtras);
                 unset($data['dados_extras']);
             }
         } else {
             $data = $modelCliente->selectById($cid);
             $dadosExtras = json_decode($data['dados_cliente'], true);
             $data = array_merge($data, $dadosExtras);
             // removendo id de quem criou a ficha do cliente
             $data['created_user_id'] = CURRENT_USER_ID;
         }
     }
     $model->lockRow($data['id'], CURRENT_USER_ID, 1);
     // Verifica se esta bloquedo
     $is_locked = $this->_acl_model->checkLocked($data['locked'], $data['locked_by']);
     if ($is_locked) {
         $this->view->messages = array('Item bloqueado para edição');
         $this->view->hide = true;
         $this->view->form = '';
         return false;
     }
     // Verifica sem tem permissão pra acessar o conteudo.
     $is_autorized = $this->_acl_model->autorized($data['created_user_id'], $this->_ids);
     if (!$is_autorized) {
         $this->view->messages = array('Sem permissão de acesso');
         $this->view->barTitle = 'Editando Proposta';
         $this->view->form = '';
         return false;
     }
     // Pega Condições de pagamento
     $condicoes = $model->selectCondicoesPagamento($id);
     if ($condicoes) {
         $this->view->sinal = $condicoes['sinal'];
         $this->view->parcelas = json_decode($condicoes['parcelas'], true);
     }
     // Pega todos os arquivos relacinados ao cliente
     $this->view->anexos = $documentos->readDir(PUBLIC_PATH . DIRECTORY_SEPARATOR . 'uploads', $id);
     $this->view->documentos = $documentos;
     $this->view->barTitle = "Editando Proposta :: " . $data['nome'];
     $this->view->form = $form;
     $this->view->data = $data;
     $form->populate($data);
 }
 public function cargararchivoAction()
 {
     $idcurso = $this->_request->idcurso;
     $iddocpadre = $this->_request->iddocpadre;
     $titulo = $this->getRequest()->getParam('txtnombre');
     $documento = new Application_Model_Documentos();
     $ruta = $documento->obternerruta($iddocpadre);
     $upload = new Zend_File_Transfer_Adapter_Http();
     //        $upload = new Zend_File_Transfer();
     $upload->addValidator('FilesSize', false, array('min' => '10kB', 'max' => '4MB'));
     //$upload->addValidator('Extension', false, 'jpg,png,pdf');
     $upload->setDestination("main/documentos/" . $idcurso . $ruta);
     try {
         // upload received file(s)
         $name = $upload->getFileName('filee');
         $tamano = $upload->getFileSize('filee');
         $accion = $documento->buscarNombreArchivobyIdDocuPadre($iddocpadre, $titulo);
         if ($accion == 0) {
             $documento->registrarArchivo($idcurso, NULL, $name, NULL, $titulo, $iddocpadre, $tamano);
             $upload->receive();
         } else {
             return $this->_redirect("http://www.google.com");
         }
         //             $extension = pathinfo($name, PATHINFO_EXTENSION);
         //
         //             $renameFile = $idusuario.'.'.$extension;
         //             $fullFilePath = 'main/'.$renameFile;
         //             $fullFilePath = 'main/'.$name;
         // Rename uploaded file using Zend Framework
         //             $filterFileRename = new Zend_Filter_File_Rename(array('target' => $fullFilePath, 'overwrite' => true));
         //             $filterFileRename -> filter($name);
         //             $usuario->actualizarFoto($idusuario, $fullFilePath);
     } catch (Zend_File_Transfer_Exception $e) {
         return $this->_redirect("http://www.google.com");
     }
     return $this->_redirect('docente/documentos?idcurso=' . $idcurso . '&iddocpadre=' . $iddocpadre);
 }