Passed
Pull Request — master (#14)
by
unknown
02:43
created

FormasDePago   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 28
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 17
c 1
b 0
f 0
dl 0
loc 28
ccs 18
cts 18
cp 1
rs 10
wmc 4

2 Methods

Rating   Name   Duplication   Size   Complexity  
A catalogName() 0 3 1
A create() 0 17 3
1
<?php
2
3
declare(strict_types=1);
4
5
namespace PhpCfdi\SatCatalogos\CFDI40;
6
7
use PhpCfdi\SatCatalogos\Common\AbstractCatalogIdentifiable;
8
use PhpCfdi\SatCatalogos\Common\EntryIdentifiable;
9
use PhpCfdi\SatCatalogos\Repository;
10
11
/**
12
 * Catálogo de FormasDePago
13
 * @method FormaDePago obtain(string $id)
14
 */
15
class FormasDePago extends AbstractCatalogIdentifiable
16
{
17 1
    protected function catalogName(): string
18
    {
19 1
        return Repository::CFDI_40_FORMAS_PAGO;
20
    }
21
22
    /**
23
     * @param array<string, mixed> $data
24
     * @return FormaDePago
25
     */
26 1
    public function create(array $data): EntryIdentifiable
27
    {
28 1
        return new FormaDePago(
29 1
            $data['id'],
30 1
            $data['texto'],
31 1
            (bool) $data['es_bancarizado'],
32 1
            (bool) $data['requiere_numero_operacion'],
33 1
            (bool) $data['permite_banco_ordenante_rfc'],
34 1
            (bool) $data['permite_cuenta_ordenante'],
35 1
            (string) $data['patron_cuenta_ordenante'],
36 1
            (bool) $data['permite_banco_beneficiario_rfc'],
37 1
            (bool) $data['permite_cuenta_beneficiario'],
38 1
            (string) $data['patron_cuenta_beneficiario'],
39 1
            (bool) $data['permite_tipo_cadena_pago'],
40 1
            (bool) $data['requiere_banco_ordenante_nombre_ext'],
41 1
            ($data['vigencia_desde']) ? strtotime($data['vigencia_desde']) : 0,
42 1
            ($data['vigencia_hasta']) ? strtotime($data['vigencia_hasta']) : 0
43
        );
44
    }
45
}
46