[ 10 => [ [ 'income' => 3500, 'rate' => 0, 'constant' => 0 ], [ 'income' => 18500, 'rate' => 3.1, 'constant' => 0 ], [ 'income' => 33500, 'rate' => 5.25, 'constant' => 465 ], [ 'income' => 33500, 'rate' => 5.70, 'constant' => 1252.50 ], ], 20 => [ [ 'income' => 8000, 'rate' => 0, 'constant' => 0 ], [ 'income' => 38000, 'rate' => 3.1, 'constant' => 0 ], [ 'income' => 68000, 'rate' => 5.25, 'constant' => 930 ], [ 'income' => 68000, 'rate' => 5.70, 'constant' => 2505 ], ], ], 20170601 => [ 10 => [ [ 'income' => 3000, 'rate' => 0, 'constant' => 0 ], [ 'income' => 18000, 'rate' => 3.1, 'constant' => 0 ], [ 'income' => 33000, 'rate' => 5.25, 'constant' => 465 ], [ 'income' => 33000, 'rate' => 5.70, 'constant' => 1252.50 ], ], 20 => [ [ 'income' => 7500, 'rate' => 0, 'constant' => 0 ], [ 'income' => 37500, 'rate' => 3.1, 'constant' => 0 ], [ 'income' => 67500, 'rate' => 5.25, 'constant' => 930 ], [ 'income' => 67500, 'rate' => 5.70, 'constant' => 2505 ], ], ], 20150101 => [ 10 => [ [ 'income' => 3000, 'rate' => 0, 'constant' => 0 ], [ 'income' => 18000, 'rate' => 2.7, 'constant' => 0 ], [ 'income' => 18000, 'rate' => 4.6, 'constant' => 405 ], ], 20 => [ [ 'income' => 6000, 'rate' => 0, 'constant' => 0 ], [ 'income' => 36000, 'rate' => 2.7, 'constant' => 0 ], [ 'income' => 36000, 'rate' => 4.6, 'constant' => 810 ], ], ], 20140101 => [ 10 => [ [ 'income' => 3000, 'rate' => 0, 'constant' => 0 ], [ 'income' => 18000, 'rate' => 2.7, 'constant' => 0 ], [ 'income' => 18000, 'rate' => 4.8, 'constant' => 405 ], ], 20 => [ [ 'income' => 6000, 'rate' => 0, 'constant' => 0 ], [ 'income' => 36000, 'rate' => 2.7, 'constant' => 0 ], [ 'income' => 36000, 'rate' => 4.8, 'constant' => 810 ], ], ], 20130101 => [ 10 => [ [ 'income' => 3000, 'rate' => 0, 'constant' => 0 ], [ 'income' => 18000, 'rate' => 3.0, 'constant' => 0 ], [ 'income' => 18000, 'rate' => 4.9, 'constant' => 450 ], ], 20 => [ [ 'income' => 6000, 'rate' => 0, 'constant' => 0 ], [ 'income' => 36000, 'rate' => 3.0, 'constant' => 0 ], [ 'income' => 36000, 'rate' => 4.9, 'constant' => 900 ], ], ], 20060101 => [ 10 => [ [ 'income' => 3000, 'rate' => 0, 'constant' => 0 ], [ 'income' => 18000, 'rate' => 3.5, 'constant' => 0 ], [ 'income' => 33000, 'rate' => 6.25, 'constant' => 525 ], [ 'income' => 33000, 'rate' => 6.45, 'constant' => 1462.50 ], ], 20 => [ [ 'income' => 6000, 'rate' => 0, 'constant' => 0 ], [ 'income' => 36000, 'rate' => 3.5, 'constant' => 0 ], [ 'income' => 66000, 'rate' => 6.25, 'constant' => 1050 ], [ 'income' => 66000, 'rate' => 6.45, 'constant' => 2925 ], ], ], ]; var $state_options = [ 20060101 => [ 'allowance' => 2250, ], ]; var $state_ui_options = [ 20060101 => [ 'wage_base' => 14000, 'new_employer_rate' => 2.7 ], ]; function getStateAnnualTaxableIncome() { $annual_income = $this->getAnnualTaxableIncome(); $state_allowance = $this->getStateAllowanceAmount(); $income = bcsub( $annual_income, $state_allowance ); Debug::text( 'State Annual Taxable Income: ' . $income, __FILE__, __LINE__, __METHOD__, 10 ); return $income; } function getStateAllowanceAmount() { $retarr = $this->getDataFromRateArray( $this->getDate(), $this->state_options ); if ( $retarr == false ) { return false; } $allowance_arr = $retarr['allowance']; $retval = bcmul( $this->getStateAllowance(), $allowance_arr ); Debug::text( 'State Allowance Amount: ' . $retval, __FILE__, __LINE__, __METHOD__, 10 ); return $retval; } function _getStateTaxPayable() { $annual_income = $this->getStateAnnualTaxableIncome(); $retval = 0; if ( $annual_income > 0 ) { $rate = $this->getData()->getStateRate( $annual_income ); $state_constant = $this->getData()->getStateConstant( $annual_income ); $state_rate_income = $this->getData()->getStateRatePreviousIncome( $annual_income ); $retval = bcadd( bcmul( bcsub( $annual_income, $state_rate_income ), $rate ), $state_constant ); //$retval = bcadd( bcmul( $annual_income, $rate ), $state_constant ); } if ( $retval < 0 ) { $retval = 0; } Debug::text( 'State Annual Tax Payable: ' . $retval, __FILE__, __LINE__, __METHOD__, 10 ); return $retval; } } ?>