MIG l10n_us_ar_hr_payroll for 12.0. Changed variables names to match Arkansas Tax Form. Added abbreviations for partners in manifest.

This commit is contained in:
David Frick
2019-08-14 16:19:53 -04:00
parent be5d75c18f
commit 6d2d6f4f46
6 changed files with 45 additions and 46 deletions

View File

@@ -4,13 +4,13 @@
'license': 'AGPL-3', 'license': 'AGPL-3',
'category': 'Localization', 'category': 'Localization',
'depends': ['l10n_us_hr_payroll'], 'depends': ['l10n_us_hr_payroll'],
'version': '11.0.2019.0.0', 'version': '12.0.2019.0.0',
'description': """ 'description': """
USA::Arkansas Payroll Rules. USA - Arkansas Payroll Rules.
================================== ==================================
* Contribution register and partner for Arkansas Department of Financial Administration - Income Tax Withholding * Contribution register and partner for Arkansas Department of Financial Administration (ADFA) - Income Tax Withholding
* Contribution register and partner for Arkansas Department of Workforce Solutions - Unemployment * Contribution register and partner for Arkansas Department of Workforce Solutions (ADWS) - Unemployment
* Contract level Arkansas Exemptions * Contract level Arkansas Exemptions
* Company level Arkansas Unemployment Rate * Company level Arkansas Unemployment Rate
* Salary Structure for Arkansas * Salary Structure for Arkansas

View File

@@ -3,12 +3,12 @@
<!-- PARTNERS --> <!-- PARTNERS -->
<record id="res_partner_ar_dws_unemp" model="res.partner"> <record id="res_partner_ar_dws_unemp" model="res.partner">
<field name="name"> Arkansas Department of Workforce Solutions - Unemployment Tax</field> <field name="name">Arkansas Department of Workforce Solutions - Unemployment Tax</field>
<field name="supplier">1</field> <field name="supplier">1</field>
<field eval="0" name="customer"/> <field eval="0" name="customer"/>
</record> </record>
<record id="res_partner_ar_dfa_withhold" model="res.partner"> <record id="res_partner_ar_dfa_withhold" model="res.partner">
<field name="name">Arkansas Department of Financial Administration- Income Tax Withholding</field> <field name="name">Arkansas Department of Financial Administration - Income Tax Withholding</field>
<field name="supplier">1</field> <field name="supplier">1</field>
<field eval="0" name="customer"/> <field eval="0" name="customer"/>
</record> </record>
@@ -16,7 +16,7 @@
<!-- CONTRIBUTION REGISTERS --> <!-- CONTRIBUTION REGISTERS -->
<record id="contrib_register_ar_dws_unemp" model="hr.contribution.register"> <record id="contrib_register_ar_dws_unemp" model="hr.contribution.register">
<field name="name">Arkansas Unemployment</field> <field name="name">Arkansas Unemployment</field>
<field name="note"> Arkansas Department of Workforce Solutions - Unemployment</field> <field name="note">Arkansas Department of Workforce Solutions - Unemployment</field>
<field name="partner_id" ref="res_partner_ar_dws_unemp"/> <field name="partner_id" ref="res_partner_ar_dws_unemp"/>
</record> </record>
<record id="contrib_register_ar_dfa_withhold" model="hr.contribution.register"> <record id="contrib_register_ar_dfa_withhold" model="hr.contribution.register">

View File

@@ -11,7 +11,7 @@
<field name="amount_select">code</field> <field name="amount_select">code</field>
<field name="amount_python_compute"> <field name="amount_python_compute">
rate = payslip.dict.get_rate('US_AR_UNEMP') rate = payslip.dict.get_rate('US_AR_UNEMP')
year = int(payslip.dict.date_to[:4]) year = payslip.dict.date_to.year
ytd = payslip.sum('WAGE_US_AR_UNEMP', str(year) + '-01-01', str(year+1) + '-01-01') ytd = payslip.sum('WAGE_US_AR_UNEMP', str(year) + '-01-01', str(year+1) + '-01-01')
ytd += contract.external_wages ytd += contract.external_wages
remaining = rate.wage_limit_year - ytd remaining = rate.wage_limit_year - ytd
@@ -52,15 +52,15 @@ if result_rate == 0.0:
<field name="name">EE: US-AR Income Tax Withholding</field> <field name="name">EE: US-AR Income Tax Withholding</field>
<field name="code">EE_US_AR_INC_WITHHOLD</field> <field name="code">EE_US_AR_INC_WITHHOLD</field>
<field name="condition_select">python</field> <field name="condition_select">python</field>
<field name="condition_python">result = not (contract.ar_w4_texarkana_exemption or contract.ar_w4_tax_exempt)</field> <field name="condition_python">result = not (contract.ar_ar4ec_texarkana_exemption or contract.ar_ar4ec_tax_exempt)</field>
<field name="amount_select">code</field> <field name="amount_select">code</field>
<field name="amount_python_compute"> <field name="amount_python_compute">
wages = categories.GROSS wages = categories.GROSS
annual_gross_pay = 0.00 annual_gross_pay = 0.00
allowance_amt = contract.ar_w4_allowances * 26.00 allowance_amt = contract.ar_ar4ec_allowances * 26.00
schedule_pay = contract.schedule_pay schedule_pay = contract.schedule_pay
standard_deduction = 2200 standard_deduction = 2200
additional_withholding = contract.ar_w4_additional_wh additional_withholding = contract.ar_ar4ec_additional_wh
if contract.w4_filing_status == 'married': if contract.w4_filing_status == 'married':
standard_deduction = standard_deduction * 2 standard_deduction = standard_deduction * 2

View File

@@ -4,7 +4,7 @@ from odoo import models, fields, api
class USARHrContract(models.Model): class USARHrContract(models.Model):
_inherit = 'hr.contract' _inherit = 'hr.contract'
ar_w4_allowances = fields.Integer(string='Arkansas W-4 allowances', default=0) ar_ar4ec_allowances = fields.Integer(string='Arkansas AR-4EC Allowances', default=0)
ar_w4_additional_wh = fields.Float(string="Arkansas Additional Withholding", default=0.0) ar_ar4ec_additional_wh = fields.Float(string="Arkansas AR-4EC Additional Withholding", default=0.0)
ar_w4_tax_exempt = fields.Boolean(string="Tax Exempt") ar_ar4ec_tax_exempt = fields.Boolean(string="Arkansas AR-4EC Tax Exempt")
ar_w4_texarkana_exemption = fields.Boolean(string="Texarkana Exemption") ar_ar4ec_texarkana_exemption = fields.Boolean(string="Arkansas AR-4EC Texarkana Exemption")

View File

@@ -1,5 +1,4 @@
from odoo.addons.l10n_us_hr_payroll.tests.test_us_payslip import TestUsPayslip, process_payslip from odoo.addons.l10n_us_hr_payroll.tests.test_us_payslip import TestUsPayslip, process_payslip
from odoo.addons.l10n_us_hr_payroll.models.l10n_us_hr_payroll import USHrContract
class TestUsARPayslip(TestUsPayslip): class TestUsARPayslip(TestUsPayslip):
@@ -31,17 +30,17 @@ class TestUsARPayslip(TestUsPayslip):
process_payslip(payslip) process_payslip(payslip)
# Make a new payslip, this one will have maximums # Make a new payslip, this one will have maximums
remaining_AR_UNEMP_wages = self.AR_UNEMP_MAX_WAGE - salary if (self.AR_UNEMP_MAX_WAGE - 2*salary < salary) \ remaining_ar_unemp_wages = self.AR_UNEMP_MAX_WAGE - salary if (self.AR_UNEMP_MAX_WAGE - 2*salary < salary) \
else salary else salary
# We reached the cap of 10000.0 in the first payslip. # We reached the cap of 10000.0 in the first payslip.
self.assertEqual(0.0, remaining_AR_UNEMP_wages) self.assertEqual(0.0, remaining_ar_unemp_wages)
self._log('2019 Arkansas tax second payslip weekly:') self._log('2019 Arkansas tax second payslip weekly:')
payslip = self._createPayslip(employee, '2019-02-01', '2019-02-28') payslip = self._createPayslip(employee, '2019-02-01', '2019-02-28')
payslip.compute_sheet() payslip.compute_sheet()
cats = self._getCategories(payslip) cats = self._getCategories(payslip)
self.assertPayrollEqual(cats['WAGE_US_AR_UNEMP'], remaining_AR_UNEMP_wages) self.assertPayrollEqual(cats['WAGE_US_AR_UNEMP'], remaining_ar_unemp_wages)
self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], remaining_AR_UNEMP_wages * self.AR_UNEMP) self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], remaining_ar_unemp_wages * self.AR_UNEMP)
def test_taxes_with_state_exempt(self): def test_taxes_with_state_exempt(self):
salary = 50000.0 salary = 50000.0
@@ -52,7 +51,7 @@ class TestUsARPayslip(TestUsPayslip):
salary, salary,
struct_id=self.ref('l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'), struct_id=self.ref('l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'),
) )
contract.ar_w4_tax_exempt = tax_exempt contract.ar_ar4ec_tax_exempt = tax_exempt
self._log('2019 Arkansas exempt tax first payslip weekly:') self._log('2019 Arkansas exempt tax first payslip weekly:')
payslip = self._createPayslip(employee, '2019-01-01', '2019-01-31') payslip = self._createPayslip(employee, '2019-01-01', '2019-01-31')
@@ -73,7 +72,7 @@ class TestUsARPayslip(TestUsPayslip):
contract = self._createContract(employee, contract = self._createContract(employee,
salary, salary,
struct_id=self.ref('l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee')) struct_id=self.ref('l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'))
contract.ar_w4_texarkana_exemption = texarkana_exemption contract.ar_ar4ec_texarkana_exemption = texarkana_exemption
self._log('2019 Arkansas tax first payslip:') self._log('2019 Arkansas tax first payslip:')
payslip = self._createPayslip(employee, '2019-01-01', '2019-01-31') payslip = self._createPayslip(employee, '2019-01-01', '2019-01-31')
@@ -99,8 +98,8 @@ class TestUsARPayslip(TestUsPayslip):
wages, wages,
struct_id=self.ref('l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'), struct_id=self.ref('l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'),
schedule_pay=schedule_pay) schedule_pay=schedule_pay)
contract.ar_w4_additional_wh = 0.0 contract.ar_ar4ec_additional_wh = 0.0
contract.ar_w4_allowances = exemptions contract.ar_ar4ec_allowances = exemptions
self.assertEqual(contract.schedule_pay, 'monthly') self.assertEqual(contract.schedule_pay, 'monthly')
@@ -114,7 +113,7 @@ class TestUsARPayslip(TestUsPayslip):
# TODO: change to hand the test_ar_amt already be divided by pay periods # TODO: change to hand the test_ar_amt already be divided by pay periods
self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods)) self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods))
contract.ar_w4_additional_wh = additional_wh contract.ar_ar4ec_additional_wh = additional_wh
payslip.compute_sheet() payslip.compute_sheet()
cats = self._getCategories(payslip) cats = self._getCategories(payslip)
@@ -137,8 +136,8 @@ class TestUsARPayslip(TestUsPayslip):
struct_id=self.ref( struct_id=self.ref(
'l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'), 'l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'),
schedule_pay=schedule_pay) schedule_pay=schedule_pay)
contract.ar_w4_additional_wh = 0.0 contract.ar_ar4ec_additional_wh = 0.0
contract.ar_w4_allowances = exemptions contract.ar_ar4ec_allowances = exemptions
self.assertEqual(contract.schedule_pay, 'monthly') self.assertEqual(contract.schedule_pay, 'monthly')
@@ -151,7 +150,7 @@ class TestUsARPayslip(TestUsPayslip):
self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], cats['WAGE_US_AR_UNEMP'] * self.AR_UNEMP) self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], cats['WAGE_US_AR_UNEMP'] * self.AR_UNEMP)
self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods)) self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods))
contract.ar_w4_additional_wh = additional_wh contract.ar_ar4ec_additional_wh = additional_wh
payslip.compute_sheet() payslip.compute_sheet()
cats = self._getCategories(payslip) cats = self._getCategories(payslip)
self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods) - additional_wh) self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods) - additional_wh)
@@ -160,7 +159,7 @@ class TestUsARPayslip(TestUsPayslip):
# Make a new payslip, this one will have maximums # Make a new payslip, this one will have maximums
remaining_AR_UNEMP_wages = self.AR_UNEMP_MAX_WAGE - wages if (self.AR_UNEMP_MAX_WAGE - 2 * wages < wages) \ remaining_ar_unemp_wages = self.AR_UNEMP_MAX_WAGE - wages if (self.AR_UNEMP_MAX_WAGE - 2 * wages < wages) \
else wages else wages
self._log('2019 Arkansas tax second payslip weekly:') self._log('2019 Arkansas tax second payslip weekly:')
@@ -168,8 +167,8 @@ class TestUsARPayslip(TestUsPayslip):
payslip.compute_sheet() payslip.compute_sheet()
cats = self._getCategories(payslip) cats = self._getCategories(payslip)
self.assertPayrollEqual(cats['WAGE_US_AR_UNEMP'], remaining_AR_UNEMP_wages) self.assertPayrollEqual(cats['WAGE_US_AR_UNEMP'], remaining_ar_unemp_wages)
self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], remaining_AR_UNEMP_wages * self.AR_UNEMP) self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], remaining_ar_unemp_wages * self.AR_UNEMP)
def test_over_fifty_thousand(self): def test_over_fifty_thousand(self):
wages = 10000.00 # 10000.00 monthly is over 50,000 annually. wages = 10000.00 # 10000.00 monthly is over 50,000 annually.
@@ -186,8 +185,8 @@ class TestUsARPayslip(TestUsPayslip):
struct_id=self.ref( struct_id=self.ref(
'l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'), 'l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'),
schedule_pay=schedule_pay) schedule_pay=schedule_pay)
contract.ar_w4_additional_wh = 0.0 contract.ar_ar4ec_additional_wh = 0.0
contract.ar_w4_allowances = exemptions contract.ar_ar4ec_allowances = exemptions
self.assertEqual(contract.schedule_pay, 'monthly') self.assertEqual(contract.schedule_pay, 'monthly')
@@ -200,7 +199,7 @@ class TestUsARPayslip(TestUsPayslip):
self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], cats['WAGE_US_AR_UNEMP'] * self.AR_UNEMP) self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], cats['WAGE_US_AR_UNEMP'] * self.AR_UNEMP)
self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods)) self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods))
contract.ar_w4_additional_wh = additional_wh contract.ar_ar4ec_additional_wh = additional_wh
payslip.compute_sheet() payslip.compute_sheet()
cats = self._getCategories(payslip) cats = self._getCategories(payslip)
self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods) - additional_wh) self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods) - additional_wh)
@@ -209,7 +208,7 @@ class TestUsARPayslip(TestUsPayslip):
# Make a new payslip, this one will have maximums # Make a new payslip, this one will have maximums
remaining_AR_UNEMP_wages = self.AR_UNEMP_MAX_WAGE - wages if (self.AR_UNEMP_MAX_WAGE - 2 * wages < wages) \ remaining_ar_unemp_wages = self.AR_UNEMP_MAX_WAGE - wages if (self.AR_UNEMP_MAX_WAGE - 2 * wages < wages) \
else wages else wages
self._log('2019 Arkansas tax second payslip weekly:') self._log('2019 Arkansas tax second payslip weekly:')
@@ -217,8 +216,8 @@ class TestUsARPayslip(TestUsPayslip):
payslip.compute_sheet() payslip.compute_sheet()
cats = self._getCategories(payslip) cats = self._getCategories(payslip)
self.assertPayrollEqual(cats['WAGE_US_AR_UNEMP'], remaining_AR_UNEMP_wages) self.assertPayrollEqual(cats['WAGE_US_AR_UNEMP'], remaining_ar_unemp_wages)
self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], remaining_AR_UNEMP_wages * self.AR_UNEMP) self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], remaining_ar_unemp_wages * self.AR_UNEMP)
def test_married(self): def test_married(self):
wages = 5500.00 wages = 5500.00
@@ -237,8 +236,8 @@ class TestUsARPayslip(TestUsPayslip):
struct_id=self.ref( struct_id=self.ref(
'l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'), 'l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'),
schedule_pay=schedule_pay) schedule_pay=schedule_pay)
contract.ar_w4_additional_wh = additional_wh contract.ar_ar4ec_additional_wh = additional_wh
contract.ar_w4_allowances = exemptions contract.ar_ar4ec_allowances = exemptions
contract.w4_filing_status = w4_filing_status contract.w4_filing_status = w4_filing_status
self.assertEqual(contract.w4_filing_status, 'married') self.assertEqual(contract.w4_filing_status, 'married')
@@ -269,8 +268,8 @@ class TestUsARPayslip(TestUsPayslip):
struct_id=self.ref( struct_id=self.ref(
'l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'), 'l10n_us_ar_hr_payroll.hr_payroll_salary_structure_us_ar_employee'),
schedule_pay=schedule_pay) schedule_pay=schedule_pay)
contract.ar_w4_additional_wh = 0 contract.ar_ar4ec_additional_wh = 0
contract.ar_w4_allowances = exemptions contract.ar_ar4ec_allowances = exemptions
contract.w4_filling_status = w4_filling_status contract.w4_filling_status = w4_filling_status
self.assertEqual(contract.w4_filling_status, 'single') self.assertEqual(contract.w4_filling_status, 'single')
@@ -284,7 +283,7 @@ class TestUsARPayslip(TestUsPayslip):
self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], cats['WAGE_US_AR_UNEMP'] * self.AR_UNEMP) self.assertPayrollEqual(cats['ER_US_AR_UNEMP'], cats['WAGE_US_AR_UNEMP'] * self.AR_UNEMP)
self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods)) self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods))
contract.ar_w4_additional_wh = additional_wh contract.ar_ar4ec_additional_wh = additional_wh
payslip.compute_sheet() payslip.compute_sheet()
cats = self._getCategories(payslip) cats = self._getCategories(payslip)
self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods) - additional_wh) self.assertPayrollEqual(cats['EE_US_AR_INC_WITHHOLD'], -(test_ar_amt / pay_periods) - additional_wh)

View File

@@ -10,10 +10,10 @@
<data> <data>
<xpath expr="//group[@name='state_filing']" position="inside"> <xpath expr="//group[@name='state_filing']" position="inside">
<group string="Arkansas" name="ar"> <group string="Arkansas" name="ar">
<field name="ar_w4_allowances" string="Allowances"/> <field name="ar_ar4ec_allowances" string="Allowances"/>
<field name="ar_w4_additional_wh" string="Additional Withholding"/> <field name="ar_ar4ec_additional_wh" string="Additional Withholding"/>
<field name="ar_w4_tax_exempt" string="Tax Exempt"/> <field name="ar_ar4ec_tax_exempt" string="Tax Exempt"/>
<field name="ar_w4_texarkana_exemption" string="Texarkana Exemption"/> <field name="ar_ar4ec_texarkana_exemption" string="Texarkana Exemption"/>
</group> </group>
</xpath> </xpath>
</data> </data>