Example #1
1
 public function gerar(Boleto $boleto)
 {
     $PDF = new FPDF("P", 'mm', 'A4');
     $PDF->AddPage();
     $PDF->SetFont('Arial', '', 8);
     $PDF->Ln();
     //Select Arial bold 8
     $PDF->SetFont('Arial', 'B', 6);
     $PDF->Cell(190, 4, utf8_decode("Instrução de Impressão:"), '', 1, 'C');
     $PDF->Cell(190, 4, utf8_decode("Imprimir em impressora jato de tinta (ink jet) ou laser em qualidade normal. (Não use modo econômico)."), '', 1, 'C');
     $PDF->Cell(190, 4, utf8_decode("Utilize folha A4 (210 x 297 mm) ou carta (216 x 279 mm) - Corte na linha indicada:"), '', 1, 'C');
     $PDF->Ln();
     $PDF->SetFont('Arial', 'B', 6);
     $PDF->Cell(190, 2, 'Recibo do Sacado', '', 1, 'R');
     $PDF->SetFont('Arial', '', 12);
     $PDF->Cell(190, 2, '--------------------------------------------------------------------------------------------------------------------------------------', '', 0, 'L');
     $PDF->Ln();
     $PDF->Ln(15);
     $PDF->SetFont('Arial', '', 9);
     $PDF->Cell(50, 10, '', 'B', 0, 'L');
     $PDF->Image(Gerador::getDirImages() . $boleto->getBanco()->getLogomarca(), 10, 43, 40, 10);
     //Select Arial italic 8
     $PDF->SetFont('Arial', 'B', 14);
     $PDF->Cell(20, 10, $boleto->getBanco()->getCodigoComDigitoVerificador(), 'LBR', 0, 'C');
     $PDF->SetFont('Arial', 'B', 9);
     $PDF->Cell(120, 10, $boleto->gerarLinhaDigitavel(), 'B', 1, 'R');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(85, 3, 'Cedente', 'LR', 0, 'L');
     $PDF->Cell(30, 3, utf8_decode('Agência/Código do Cedente'), 'R', 0, 'L');
     $PDF->Cell(15, 3, utf8_decode('Espécie'), 'R', 0, 'L');
     $PDF->Cell(20, 3, 'Quantidade', 'R', 0, 'L');
     $PDF->Cell(40, 3, utf8_decode('Carteira/Nosso número'), '', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(85, 5, utf8_decode($boleto->getSacado()->getNome()), 'BLR', 0, 'L');
     $PDF->Cell(30, 5, $boleto->getCedente()->getAgenciaComDv() . " / " . $boleto->getCedente()->getContaComDv(), 'BR', 0, 'L');
     $PDF->Cell(15, 5, $boleto->getBanco()->getEspecie(), 'BR', 0, 'L');
     $PDF->Cell(20, 5, "001", 'BR', 0, 'L');
     $PDF->Cell(40, 5, $boleto->getCarteiraENossoNumeroComDigitoVerificador(), 'B', 1, 'R');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(60, 3, utf8_decode('Número do Documento'), 'LR', 0, 'L');
     $PDF->Cell(35, 3, 'CPF/CNPJ', 'R', 0, 'L');
     $PDF->Cell(35, 3, 'Vencimento', 'R', 0, 'L');
     $PDF->Cell(60, 3, 'Valor Documento', 'L', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(60, 5, $boleto->getNossoNumero(), 'BLR', 0, 'L');
     $PDF->Cell(35, 5, $boleto->getCedente()->getCpfCnpj(), 'BR', 0, 'L');
     $PDF->Cell(35, 5, $boleto->getDataVencimento()->format('d/m/Y'), 'BR', 0, 'L');
     $PDF->Cell(60, 5, $boleto->getValorBoleto(), 'B', 1, 'R');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(33, 3, '(-)Desconto/Abatimentos', 'LR', 0, 'L');
     $PDF->Cell(32, 3, utf8_decode('(-)Outras deduções'), 'R', 0, 'L');
     $PDF->Cell(32, 3, '(+)Mora/Multa', 'R', 0, 'L');
     $PDF->Cell(33, 3, utf8_decode('(+)Outros acréscimos'), '', 0, 'L');
     $PDF->Cell(60, 3, '(*)Valor Cobrado', 'L', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(33, 5, '', 'BLR', 0, 'L');
     $PDF->Cell(32, 5, '', 'BR', 0, 'L');
     $PDF->Cell(32, 5, '', 'BR', 0, 'L');
     $PDF->Cell(33, 5, '', 'BR', 0, 'L');
     $PDF->Cell(60, 5, '', 'B', 1, 'R');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(190, 3, 'Sacado', 'L', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(190, 5, utf8_decode($boleto->getSacado()->getNome()), 'L', 1, 'L');
     $PDF->Cell(190, 5, utf8_decode($boleto->getSacado()->getTipoLogradouro() . " " . $boleto->getSacado()->getEnderecoLogradouro() . ", " . $boleto->getSacado()->getNumeroLogradouro()), 'L', 1, 'L');
     $PDF->Cell(190, 5, utf8_decode($boleto->getSacado()->getCidade() . " - " . $boleto->getSacado()->getUf() . " - CEP: " . $boleto->getSacado()->getCep()), 'BL', 1, 'L');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(170, 3, utf8_decode('Instruções'), '', 0, 'L');
     $PDF->Cell(20, 3, utf8_decode('Autênticação Mecânica'), '', 1, 'R');
     $PDF->SetFont('Arial', '', 7);
     foreach ($boleto->getInstrucoes() as $instrucao) {
         $PDF->Cell(190, 5, utf8_decode($instrucao), '', 1, 'L');
     }
     $PDF->Ln();
     $PDF->SetFont('Arial', 'B', 6);
     $PDF->Cell(190, 2, 'Corte na linha pontilhada', '', 1, 'R');
     $PDF->SetFont('Arial', '', 12);
     $PDF->Cell(190, 2, '--------------------------------------------------------------------------------------------------------------------------------------', '', 0, 'L');
     $PDF->Ln(10);
     $PDF->Cell(50, 10, '', 'B', 0, 'L');
     $PDF->Image(Gerador::getDirImages() . $boleto->getBanco()->getLogomarca(), 10, 130, 40, 10);
     //Select Arial italic 8
     $PDF->SetFont('Arial', 'B', 14);
     $PDF->Cell(20, 10, $boleto->getBanco()->getCodigoComDigitoVerificador(), 'LBR', 0, 'C');
     $PDF->SetFont('Arial', 'B', 9);
     $PDF->Cell(120, 10, $boleto->gerarLinhaDigitavel(), 'B', 1, 'R');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(130, 3, 'Local Pagamento', 'LR', 0, 'L');
     $PDF->Cell(60, 3, 'Vencimento', '', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(130, 5, utf8_decode($boleto->getBanco()->getLocalPagamento()), 'BLR', 0, 'L');
     $PDF->Cell(60, 5, $boleto->getDataVencimento()->format('d/m/Y'), 'B', 1, 'R');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(130, 3, 'Cedente', 'LR', 0, 'L');
     $PDF->Cell(60, 3, utf8_decode('Agência/Código cedente'), '', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(130, 5, utf8_decode($boleto->getCedente()->getNome()), 'BLR', 0, 'L');
     $PDF->Cell(60, 5, $boleto->getCedente()->getAgenciaComDv() . " / " . $boleto->getCedente()->getContaComDv(), 'B', 1, 'R');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(28, 3, 'Data Documento', 'LR', 0, 'L');
     $PDF->Cell(40, 3, utf8_decode('Número do Documento'), 'R', 0, 'L');
     $PDF->Cell(20, 3, utf8_decode('Espécie doc.'), 'R', 0, 'L');
     $PDF->Cell(20, 3, 'Aceite', 'R', 0, 'L');
     $PDF->Cell(22, 3, 'Data processamento', '', 0, 'L');
     $PDF->Cell(60, 3, utf8_decode('Carteira / Nosso número'), 'L', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(28, 5, $boleto->getDataDocumento()->format('d/m/Y'), 'BLR', 0, 'L');
     $PDF->Cell(40, 5, $boleto->getNumeroDocumento(), 'BR', 0, 'L');
     $PDF->Cell(20, 5, $boleto->getBanco()->getEspecieDocumento(), 'BR', 0, 'L');
     $PDF->Cell(20, 5, "", 'BR', 0, 'L');
     $PDF->Cell(22, 5, $boleto->getDataProcessamento()->format('d/m/Y'), 'BR', 0, 'L');
     $PDF->Cell(60, 5, $boleto->getCarteiraENossoNumeroComDigitoVerificador(), 'B', 1, 'R');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(28, 3, 'Uso do Banco', 'LR', 0, 'L');
     $PDF->Cell(25, 3, 'Carteira', 'R', 0, 'L');
     $PDF->Cell(15, 3, utf8_decode('Espécie'), 'R', 0, 'L');
     $PDF->Cell(40, 3, 'Quantidade', 'R', 0, 'L');
     $PDF->Cell(22, 3, '(x)Valor', '', 0, 'L');
     $PDF->Cell(60, 3, '(=)Valor Documento', 'L', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(28, 5, '05/05/2014', 'BLR', 0, 'L');
     $PDF->Cell(25, 5, $boleto->getBanco()->getCarteira(), 'BR', 0, 'L');
     $PDF->Cell(15, 5, $boleto->getBanco()->getEspecie(), 'BR', 0, 'L');
     $PDF->Cell(40, 5, "001", 'BR', 0, 'L');
     $PDF->Cell(22, 5, '', 'BR', 0, 'L');
     $PDF->Cell(60, 5, $boleto->getValorBoleto(), 'B', 1, 'R');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(130, 3, utf8_decode('Instruções'), 'L', 0, 'L');
     $PDF->Cell(60, 3, '(-)Desconto/Abatimentos', 'L', 1, 'L');
     $l = 0;
     for ($i = 0; $i < 4; $i++) {
         $instrucao = isset($boleto->getInstrucoes()[$i]) ? $boleto->getInstrucoes()[$i] : null;
         $l++;
         $PDF->Cell(130, 5, utf8_decode($instrucao), 'L', 0, 'L');
         if (1 == $l) {
             $PDF->Cell(60, 5, '', 'LB', 1, 'R');
         } else {
             if (2 == $l) {
                 $PDF->SetFont('Arial', '', 6);
                 $PDF->Cell(60, 3, utf8_decode('(-)Outras deduções'), 'L', 1, 'L');
             } else {
                 if (3 == $l) {
                     $PDF->Cell(60, 5, '', 'LB', 1, 'R');
                 } else {
                     if (4 == $l) {
                         $PDF->SetFont('Arial', '', 6);
                         $PDF->Cell(60, 3, '(+)Mora/Multa', 'L', 1, 'L');
                     }
                 }
             }
         }
     }
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(130, 5, '', 'L', 0, 'L');
     $PDF->Cell(60, 5, '', 'LB', 1, 'R');
     $PDF->Cell(130, 3, '', 'L', 0, 'L');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(60, 3, utf8_decode('(+)Outros acréscimos'), 'L', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(130, 5, '', 'L', 0, 'L');
     $PDF->Cell(60, 5, '', 'LB', 1, 'R');
     $PDF->Cell(130, 3, '', 'L', 0, 'L');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(60, 3, '(=)Valor cobrado', 'L', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(130, 5, '', 'LB', 0, 'L');
     $PDF->Cell(60, 5, '', 'LB', 1, 'R');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(190, 3, 'Sacado', 'L', 1, 'L');
     $PDF->SetFont('Arial', '', 7);
     $PDF->Cell(190, 5, utf8_decode($boleto->getSacado()->getNome()), 'L', 1, 'L');
     $PDF->Cell(190, 5, utf8_decode($boleto->getSacado()->getTipoLogradouro() . " " . $boleto->getSacado()->getEnderecoLogradouro() . ", " . $boleto->getSacado()->getNumeroLogradouro()), 'L', 1, 'L');
     $PDF->Cell(190, 5, utf8_decode($boleto->getSacado()->getCidade() . " - " . $boleto->getSacado()->getUf() . " - CEP: " . $boleto->getSacado()->getCep()), 'BL', 1, 'L');
     $PDF->SetFont('Arial', '', 6);
     $PDF->Cell(170, 3, 'Sacador/Avalista', '', 0, 'L');
     $PDF->Cell(20, 3, utf8_decode('Autênticação Mecânica - Ficha de Compensação'), '', 1, 'R');
     $this->fbarcode($boleto->getLinha(), $PDF);
     $PDF->Ln(10);
     $PDF->SetY(260);
     $PDF->SetFont('Arial', 'B', 6);
     $PDF->Cell(190, 2, 'Corte na linha pontilhada', '', 1, 'R');
     $PDF->SetFont('Arial', '', 12);
     $PDF->Cell(190, 2, '--------------------------------------------------------------------------------------------------------------------------------------', '', 0, 'L');
     return $PDF;
 }
 /**
  * @param Certificado $certificado
  * @throws \Exception
  */
 public function crearPdf(Certificado $certificado)
 {
     $empleado = new Empleado($certificado->cedula_empleado);
     //echo print_r($empleado);
     //$empleado = new Empleado();
     $pdf = new FPDF('P', 'cm', 'Letter');
     //$pdf = new FPDF_Protection();
     //$pdf->SetProtection(array('print'));
     $pdf->AddPage();
     $pdf->SetMargins(3, 3, 2);
     $pdf->SetAutoPageBreak(true, 1);
     $pdf->SetLineWidth(1.5);
     $pdf->SetFont('Arial');
     $pdf->Image(realpath(__DIR__ . '/../../../../assets/images/logo.png'), 14, 0.3, 5, 'PNG');
     $pdf->SetFont('Arial', '', 6);
     $pdf->Cell(17.5, 6, $certificado->id, 0, 2, 'R');
     $pdf->SetFont('Arial', '', 12);
     $pdf->Ln(0);
     $pdf->Cell(0, 0, 'Valledupar, ' . $this->formatFecha($certificado->fecha), 0, 2, 'L');
     $pdf->Ln(2);
     $pdf->Cell(0, 0, 'EL DEPARTAMENTO DE TALENTO HUMANO', 0, 2, 'C');
     $pdf->Ln(1);
     $pdf->Cell(0, 0, utf8_decode('DE LÁCTEOS DEL CESAR S.A.'), 0, 2, 'C');
     $pdf->Ln(2);
     $pdf->SetFont('Arial', 'B');
     $pdf->Cell(0, 0, 'CERTIFICA:', 0, 2, 'C');
     $pdf->Ln(2);
     $pdf->SetFont('Arial');
     $contratoEmpleado = $empleado->getContrato();
     $salario = '.';
     if ($certificado->tipo == 2) {
         $salario = ', devengando un salario básico mensual de $' . number_format($contratoEmpleado->salario) . '.';
     }
     if ($certificado->tipo == 3) {
         $salario = ', devengando un salario promedio mensual de $' . number_format($contratoEmpleado->salarioPromedio(), 0, '', '.') . '.';
     }
     $labora = 'labora';
     $feca_contratacion = "desde el " . $this->formatFecha($contratoEmpleado->fecha_ingreso);
     if ($contratoEmpleado->getEstado() == 'retirado') {
         $labora = 'laboró';
         $feca_contratacion .= ', hasta el ' . $this->formatFecha($contratoEmpleado->fecha_retiro);
     } else {
         $feca_contratacion = ' mediante contrato ' . $contratoEmpleado->getTipo() . ', ' . $feca_contratacion;
     }
     $pdf->MultiCell(0, 0.6, utf8_decode('Que el señor(a) ' . strtoupper($empleado->nombres . ' ' . $empleado->apellido1 . ' ' . $empleado->apellido2 . ' ') . 'con cédula de ciudadanía ' . $empleado->cedula . ", {$labora} en esta compañía en el cargo de " . $contratoEmpleado->getCargo()->nombre . ', ' . $feca_contratacion . $salario), 0, 'J', false);
     $pdf->Ln(2);
     $pdf->Cell(0, 0, utf8_decode('Esta certificación se expide a solicitud del interesado.'), 0, 2);
     $pdf->Ln(5);
     $pdf->Image(realpath(__DIR__ . '/../../../../assets/images/Firma.png'), 8, 19, 7, 'PNG');
     $pdf->SetFont('Arial', 'B');
     $pdf->Cell(0, 0, 'MAYRA ALEJANDRA CARO DAZA', 0, 2, 'C');
     $pdf->Ln(0.5);
     $pdf->SetFont('Arial');
     $pdf->Cell(0, 0, 'Jefe de Talento Humano', 0, 2, 'C');
     $pdf->Image(realpath(__DIR__ . '/../../../../assets/images/Pie.JPG'), 1, 25.5, 19, 'JPG');
     $pdf->Output($certificado->id . '.pdf', 'I');
     return true;
 }