Passed
Push — master ( cbeb6d...052d75 )
by Esteban De La Fuente
11:37 queued 03:06
created

DocumentoRenderer   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 84
Duplicated Lines 0 %

Test Coverage

Coverage 76.47%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 16
dl 0
loc 84
ccs 13
cts 17
cp 0.7647
rs 10
c 1
b 0
f 0
wmc 5

4 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 3 1
A renderFromXml() 0 8 1
A getRenderer() 0 9 2
A renderFromDocumento() 0 17 1
1
<?php
2
3
declare(strict_types=1);
4
5
/**
6
 * LibreDTE: Biblioteca PHP (Núcleo).
7
 * Copyright (C) LibreDTE <https://www.libredte.cl>
8
 *
9
 * Este programa es software libre: usted puede redistribuirlo y/o modificarlo
10
 * bajo los términos de la Licencia Pública General Affero de GNU publicada
11
 * por la Fundación para el Software Libre, ya sea la versión 3 de la Licencia,
12
 * o (a su elección) cualquier versión posterior de la misma.
13
 *
14
 * Este programa se distribuye con la esperanza de que sea útil, pero SIN
15
 * GARANTÍA ALGUNA; ni siquiera la garantía implícita MERCANTIL o de APTITUD
16
 * PARA UN PROPÓSITO DETERMINADO. Consulte los detalles de la Licencia Pública
17
 * General Affero de GNU para obtener una información más detallada.
18
 *
19
 * Debería haber recibido una copia de la Licencia Pública General Affero de
20
 * GNU junto a este programa.
21
 *
22
 * En caso contrario, consulte <http://www.gnu.org/licenses/agpl.html>.
23
 */
24
25
namespace libredte\lib\Core\Sii\Dte\Documento\Renderer;
26
27
use libredte\lib\Core\Service\ArrayDataProvider;
28
use libredte\lib\Core\Service\DataProviderInterface;
29
use libredte\lib\Core\Sii\Dte\Documento\AbstractDocumento;
30
use libredte\lib\Core\Sii\Dte\Documento\Builder\DocumentoFactory;
31
32
/**
33
 * Renderizador de la representación gráfica de un DTE.
34
 */
35
class DocumentoRenderer
36
{
37
    /**
38
     * Listado de renderizadores disponibles (ya cargados).
39
     *
40
     * @var array
41
     */
42
    private array $renderers = [];
43
44
    /**
45
     * Proveedor de datos.
46
     *
47
     * @var DataProviderInterface
48
     */
49
    protected DataProviderInterface $dataProvider;
50
51
    /**
52
     * Constructor de la clase.
53
     *
54
     * @param ?DataProviderInterface $dataProvider Proveedor de datos.
55
     */
56 98
    public function __construct(?DataProviderInterface $dataProvider = null)
57
    {
58 98
        $this->dataProvider = $dataProvider ?? new ArrayDataProvider();
59
    }
60
61
    /**
62
     * Renderiza el documento a partir de los datos en formato XML.
63
     *
64
     * @param string $data Datos en formato XML del DTE.
65
     * @param array $options Opciones para el renderizado.
66
     * @return string
67
     */
68
    public function renderFromXml(
69
        string $data,
70
        array $options = []
71
    ): string {
72
        $factory = new DocumentoFactory($this->dataProvider);
73
        $documento = $factory->createFromXml($data);
74
75
        return $this->renderFromDocumento($documento, $options);
76
    }
77
78
    /**
79
     * Renderiza el documento a partir de la instancia del documento.
80
     *
81
     * @param AbstractDocumento $documento Instancia del DTE.
82
     * @param array $options Opciones para el renderizado.
83
     * @return string
84
     */
85 98
    public function renderFromDocumento(
86
        AbstractDocumento $documento,
87
        array $options = []
88
    ): string {
89
        // Opciones por defecto para el renderizado.
90 98
        $options = array_merge([
91 98
            'renderer' => RendererEstandar::class,
92 98
        ], $options);
93
94
        // Crear el renderizador de los datos del DTE.
95 98
        $renderer = $this->getRenderer($options['renderer']);
96
97
        // Renderizar el documento.
98 98
        $data = $renderer->render($documento, $options);
99
100
        // Entregar los datos renderizados.
101 98
        return $data;
102
    }
103
104
    /**
105
     * Obtener el objeto que se encarga de la renderización del documento.
106
     *
107
     * @param string $render Clase del renderizador que se debe utilizar.
108
     * @return AbstractRenderer
109
     */
110 98
    private function getRenderer(string $renderer): AbstractRenderer
111
    {
112
        // Si no existe el renderizador se crea.
113 98
        if (!isset($this->renderers[$renderer])) {
114 98
            $this->renderers[$renderer] = new $renderer($this->dataProvider);
115
        }
116
117
        // Entregar el renderizador solicitado.
118 98
        return $this->renderers[$renderer];
119
    }
120
}
121