1
|
|
|
<?php |
2
|
|
|
|
3
|
|
|
declare(strict_types=1); |
4
|
|
|
|
5
|
|
|
namespace Gbbs\NfeCalculos; |
6
|
|
|
|
7
|
|
|
use Gbbs\NfeCalculos\Exception\InvalidCSTException; |
8
|
|
|
use Gbbs\NfeCalculos\Exception\NotImplementedCSTException; |
9
|
|
|
|
10
|
|
|
class PIS |
11
|
|
|
{ |
12
|
|
|
public $CST; |
13
|
|
|
public $vBC; |
14
|
|
|
public $pPIS; |
15
|
|
|
public $vPIS; |
16
|
|
|
public $qBCProd; |
17
|
|
|
public $vAliqProd; |
18
|
|
|
} |
19
|
|
|
|
20
|
|
|
/** |
21
|
|
|
* @param PIS $PIS |
22
|
|
|
* @return PIS |
23
|
|
|
* @throws NotImplementedCSTException|InvalidCSTException |
24
|
|
|
*/ |
25
|
|
|
function calcularPIS(PIS $PIS): PIS |
26
|
|
|
{ |
27
|
|
|
$adValorem = [ |
28
|
5 |
|
'01', '02', '49', '50', '51', '52', '53', '54', '55', '56', '60', '61', '62', |
29
|
|
|
'63', '64', '65', '66', '67', '70', '71', '72', '73', '74', '75', '98' |
30
|
|
|
]; |
31
|
5 |
|
$zerado = ['08']; |
32
|
5 |
|
$isento = ['99']; |
33
|
5 |
|
$notImplemented = ['03', '04', '05', '06', '07', '09']; |
34
|
|
|
|
35
|
5 |
|
if (in_array($PIS->CST, $adValorem, true)) { |
36
|
1 |
|
return adValoremPIS($PIS); |
37
|
|
|
} |
38
|
4 |
|
if (in_array($PIS->CST, $zerado, true)) { |
39
|
1 |
|
return zeradoPIS($PIS); |
40
|
|
|
} |
41
|
3 |
|
if (in_array($PIS->CST, $isento, true)) { |
42
|
1 |
|
return isentoPIS($PIS); |
43
|
|
|
} |
44
|
2 |
|
if (in_array($PIS->CST, $notImplemented, true)) { |
45
|
1 |
|
throw new NotImplementedCSTException($PIS->CST); |
46
|
|
|
} |
47
|
1 |
|
throw new InvalidCSTException($PIS->CST); |
48
|
|
|
} |
49
|
|
|
|
50
|
|
|
/** |
51
|
|
|
* @param PIS $PIS |
52
|
|
|
* @return PIS |
53
|
|
|
*/ |
54
|
|
|
function adValoremPIS(PIS $PIS): PIS |
55
|
|
|
{ |
56
|
1 |
|
$pPIS = 0.65; |
57
|
1 |
|
$calculado = new PIS(); |
58
|
1 |
|
$calculado->CST = $PIS->CST; |
59
|
1 |
|
$calculado->vBC = $PIS->vBC; |
60
|
1 |
|
$calculado->pPIS = $pPIS; |
61
|
1 |
|
$calculado->vPIS = $PIS->vBC * ($pPIS / 100); |
62
|
1 |
|
return $calculado; |
63
|
|
|
} |
64
|
|
|
|
65
|
|
|
/** |
66
|
|
|
* @param PIS $PIS |
67
|
|
|
* @return PIS |
68
|
|
|
*/ |
69
|
|
|
function isentoPIS($PIS): PIS |
70
|
|
|
{ |
71
|
1 |
|
$calculado = new PIS(); |
72
|
1 |
|
$calculado->CST = $PIS->CST; |
73
|
1 |
|
$calculado->vBC = 0.0; |
74
|
1 |
|
$calculado->pPIS = 0.0; |
75
|
1 |
|
$calculado->vPIS = 0.0; |
76
|
1 |
|
return $calculado; |
77
|
|
|
} |
78
|
|
|
|
79
|
|
|
/** |
80
|
|
|
* @param PIS $PIS |
81
|
|
|
* @return PIS |
82
|
|
|
*/ |
83
|
|
|
function zeradoPIS($PIS): PIS |
84
|
|
|
{ |
85
|
1 |
|
$calculado = new PIS(); |
86
|
1 |
|
$calculado->CST = $PIS->CST; |
87
|
1 |
|
return $calculado; |
88
|
|
|
} |
89
|
|
|
|