Jump to content

Module:GS pay: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
Update source
Updated for 2022
Line 11: Line 11:
local WIGIncrease = {}
local WIGIncrease = {}


-- UPDATE THESE. Last Update: 2021
-- UPDATE THESE. Last Update: 2022
-- https://www.opm.gov/policy-data-oversight/pay-leave/salaries-wages/salary-tables/pdf/2021/GS.pdf
-- https://www.opm.gov/policy-data-oversight/pay-leave/salaries-wages/salary-tables/pdf/2022/GS.pdf
--For GS [Grade] Step 1 pay
--For GS [Grade] Step 1 pay
stepOnePay[3] = 24216
stepOnePay[3] = 24749
stepOnePay[4] = 27184
stepOnePay[4] = 27782
stepOnePay[5] = 30414
stepOnePay[5] = 31083
stepOnePay[6] = 33903
stepOnePay[6] = 34649
stepOnePay[7] = 37674
stepOnePay[7] = 38503
stepOnePay[8] = 41723
stepOnePay[8] = 42641
stepOnePay[9] = 46083
stepOnePay[9] = 47097
stepOnePay[10] = 50748
stepOnePay[10] = 51864
stepOnePay[11] = 55756
stepOnePay[11] = 56983
stepOnePay[12] = 66829
stepOnePay[12] = 68299
stepOnePay[13] = 79468
stepOnePay[13] = 81216
stepOnePay[14] = 93907
stepOnePay[14] = 95973
stepOnePay[15] = 110460
stepOnePay[15] = 112890
-- Within Grade increase for GS [Grade]
-- Within Grade increase for GS [Grade]
WIGIncrease[3] = 807
WIGIncrease[3] = 825
WIGIncrease[4] = 906
WIGIncrease[4] = 926
WIGIncrease[5] = 1014
WIGIncrease[5] = 1036
WIGIncrease[6] = 1130
WIGIncrease[6] = 1155
WIGIncrease[7] = 1256
WIGIncrease[7] = 1283
WIGIncrease[8] = 1391
WIGIncrease[8] = 1421
WIGIncrease[9] = 1536
WIGIncrease[9] = 1570
WIGIncrease[10] = 1692
WIGIncrease[10] = 1729
WIGIncrease[11] = 1859
WIGIncrease[11] = 1899
WIGIncrease[12] = 2228
WIGIncrease[12] = 2277
WIGIncrease[13] = 2649
WIGIncrease[13] = 2707
WIGIncrease[14] = 3130
WIGIncrease[14] = 3199
WIGIncrease[15] = 3682
WIGIncrease[15] = 3763
-- GS1 Pay Table (because it has inconsistent WIG)
-- GS1 Pay Table (because it has inconsistent WIG)
GSOnePay[1] = 19738
GSOnePay[1] = 20172
GSOnePay[2] = 20400
GSOnePay[2] = 20849
GSOnePay[3] = 21056
GSOnePay[3] = 21519
GSOnePay[4] = 21709
GSOnePay[4] = 22187
GSOnePay[5] = 22365
GSOnePay[5] = 22857
GSOnePay[6] = 22749
GSOnePay[6] = 23249
GSOnePay[7] = 23398
GSOnePay[7] = 23913
GSOnePay[8] = 24052
GSOnePay[8] = 24581
GSOnePay[9] = 24078
GSOnePay[9] = 24608
GSOnePay[10] = 24690
GSOnePay[10] = 25234
-- GS2 Pay Table (because it has inconsistent WIG}
-- GS2 Pay Table (because it has inconsistent WIG}
GSTwoPay[1] = 22194
GSTwoPay[1] = 22682
GSTwoPay[2] = 22722
GSTwoPay[2] = 23222
GSTwoPay[3] = 23457
GSTwoPay[3] = 23973
GSTwoPay[4] = 24078
GSTwoPay[4] = 24608
GSTwoPay[5] = 24349
GSTwoPay[5] = 24886
GSTwoPay[6] = 25065
GSTwoPay[6] = 25618
GSTwoPay[7] = 25781
GSTwoPay[7] = 26350
GSTwoPay[8] = 26497
GSTwoPay[8] = 27082
GSTwoPay[9] = 27213
GSTwoPay[9] = 27814
GSTwoPay[10] = 27929
GSTwoPay[10] = 28546


-- Base pay calculation
-- Base pay calculation

Revision as of 15:53, 1 January 2022

--
-- This module implements {{GS pay}}
-- There are 150 cells in the GS Pay table. This LUA reduces the amount of
--   manual input needed to 46
--

local p = {}
local stepOnePay = {}
local GSOnePay = {}
local GSTwoPay = {}
local WIGIncrease = {}

-- UPDATE THESE. Last Update: 2022
-- https://www.opm.gov/policy-data-oversight/pay-leave/salaries-wages/salary-tables/pdf/2022/GS.pdf
	--For GS [Grade] Step 1 pay
	stepOnePay[3] = 24749
	stepOnePay[4] = 27782
	stepOnePay[5] = 31083
	stepOnePay[6] = 34649
	stepOnePay[7] = 38503
	stepOnePay[8] = 42641
	stepOnePay[9] = 47097
	stepOnePay[10] = 51864
	stepOnePay[11] = 56983
	stepOnePay[12] = 68299
	stepOnePay[13] = 81216
	stepOnePay[14] = 95973
	stepOnePay[15] = 112890
	-- Within Grade increase for GS [Grade]
	WIGIncrease[3] = 825
	WIGIncrease[4] = 926
	WIGIncrease[5] = 1036
	WIGIncrease[6] = 1155
	WIGIncrease[7] = 1283
	WIGIncrease[8] = 1421
	WIGIncrease[9] = 1570
	WIGIncrease[10] = 1729
	WIGIncrease[11] = 1899
	WIGIncrease[12] = 2277
	WIGIncrease[13] = 2707
	WIGIncrease[14] = 3199
	WIGIncrease[15] = 3763
	-- GS1 Pay Table (because it has inconsistent WIG)
	GSOnePay[1] = 20172
	GSOnePay[2] = 20849
	GSOnePay[3] = 21519
	GSOnePay[4] = 22187
	GSOnePay[5] = 22857
	GSOnePay[6] = 23249
	GSOnePay[7] = 23913
	GSOnePay[8] = 24581
	GSOnePay[9] = 24608
	GSOnePay[10] = 25234
	-- GS2 Pay Table (because it has inconsistent WIG}
	GSTwoPay[1] = 22682
	GSTwoPay[2] = 23222
	GSTwoPay[3] = 23973
	GSTwoPay[4] = 24608
	GSTwoPay[5] = 24886
	GSTwoPay[6] = 25618
	GSTwoPay[7] = 26350
	GSTwoPay[8] = 27082
	GSTwoPay[9] = 27814
	GSTwoPay[10] = 28546

-- Base pay calculation
function p.basePay(grade, step)
	-- For Step 1 pay for all grades
	if step == nil then
		if grade > 2 then
			-- Returns the Step 1 Pay for [grade]
			return stepOnePay[grade]
		elseif grade == 1 then
			-- Returns GS1 Step 1
			return GSOnePay[1]
		else
			-- Returns GS2 Step 1
			return GSTwoPay[1]
		end
	-- For grades where step is specified
	else
		if grade > 2 then
			-- Calculate GS [grade #], Step [step #] pay
			local pay = stepOnePay[grade] + (WIGIncrease[grade] * (step - 1))
			return pay
		elseif grade == 1 then
			return GSOnePay[step]
		else
			return GSTwoPay[step]
		end
	end
end
	
-- 'Main' function
function p.get(frame)
	-- Error checking
	if frame.args[1] == nil then
		if frame.args[2] == nil then
			return
		end
	else
		-- Grab the basic pay number based on inputs
		return p.basePay(tonumber(frame.args[1]), tonumber(frame.args[2]))
	end
end
	
return p