diff --git a/l10n_us_hr_payroll/data/state/wi_wisconsin.xml b/l10n_us_hr_payroll/data/state/wi_wisconsin.xml
index 0fdb3c86..0af07950 100644
--- a/l10n_us_hr_payroll/data/state/wi_wisconsin.xml
+++ b/l10n_us_hr_payroll/data/state/wi_wisconsin.xml
@@ -37,6 +37,17 @@
+
+ US WI Wisconsin SIT Deduction Rate
+ us_wi_sit_deduction_rate
+
+
+
+ False
+
+
+
+
US WI Wisconsin SIT Tax Rate
us_wi_sit_tax_rate
diff --git a/l10n_us_hr_payroll/models/state/wi_wisconsin.py b/l10n_us_hr_payroll/models/state/wi_wisconsin.py
index c1d53bbb..cc818680 100644
--- a/l10n_us_hr_payroll/models/state/wi_wisconsin.py
+++ b/l10n_us_hr_payroll/models/state/wi_wisconsin.py
@@ -29,15 +29,41 @@ def wi_wisconsin_state_income_withholding(payslip, categories, worked_days, inpu
additional = payslip.contract_id.us_payroll_config_value('state_income_tax_additional_withholding')
exemptions = payslip.contract_id.us_payroll_config_value('wi_wt4_sit_exemptions')
exemption_amt = payslip.rule_parameter('us_wi_sit_exemption_rate')
- tax_table = payslip.rule_parameter('us_wi_sit_tax_rate')[filing_status]
+ # deduction_table introduced in 2022
+ deduction_table = payslip.rule_parameter('us_wi_sit_deduction_rate')
+ if deduction_table:
+ deduction_table = deduction_table[filing_status]
+ # tax_table simplified in 2022
+ tax_table = payslip.rule_parameter('us_wi_sit_tax_rate')
+ if isinstance(tax_table, dict):
+ tax_table = tax_table[filing_status]
- taxable_income = wage * pay_periods
+ taxable_income = wage * pay_periods # (a)
+ if deduction_table:
+ deduction = 0.0
+ last_wage_cap = 0.0
+ last_deduction = 0.0
+ last_rate = 0.0
+ for row in deduction_table:
+ wage_cap, deduction, rate = row
+ if taxable_income <= wage_cap:
+ if last_rate:
+ deduction = last_deduction - ((taxable_income - last_wage_cap) * last_rate / 100.0)
+ break
+ last_wage_cap, last_deduction, last_rate = row
+ taxable_income -= deduction # (b)
+
+ taxable_income -= exemption_amt * exemptions # (c)
+
+ if taxable_income <= 0.0:
+ return 0.0, 0.0
+
withholding = 0.0
last = 0.0
for row in tax_table:
amt, rate, flat_fee = row
if taxable_income <= float(amt):
- withholding = (((taxable_income - last) * (rate / 100)) + flat_fee) - (exemptions * exemption_amt)
+ withholding = (((taxable_income - last) * (rate / 100)) + flat_fee)
break
last = amt