Module:Grand Slam Track
Appearance
p = {}
local P_POINTINTIME = 'P585'
local P_PARTICIPANTOF = 'P1344'
local P_SPORTSDISCIPLINE = 'P2416'
local P_COMPETITIONCLASS = 'P2094'
local P_RANK = 'P1352'
local P_RACETIME = 'P2781'
local P_ENDCAUSE = 'P1534'
local Q_SHORTSPRINTS = 'Q133805007'
local Q_LONGSPRINTS = 'Q133805012'
local Q_SHORTHURDLES = 'Q133805023'
local Q_LONGHURDLES = 'Q133805093'
local Q_SHORTDISTANCE = 'Q133805111'
local Q_LONGDISTANCE = 'Q133805125'
local Q_DNS = 'Q1210382'
local Q_DNF = 'Q1210380'
local Q_DQ = 'Q1229261'
local slams = {'Q133804597'} -- in chronological order
local function toOrdinal(n)
n = math.floor(n)
local lastTwo = n % 100
if lastTwo >= 11 and lastTwo <= 13 then
return tostring(n) .. "th"
end
local last = n % 10
if last == 1 then
return n .. "st"
elseif last == 2 then
return n .. "nd"
elseif last == 3 then
return n .. "rd"
else
return n .. "th"
end
end
p.gst = function(frame)
local qid = frame.args[1]
local ent = mw.wikibase.getEntity(qid)
local participantOfClaims = ent['claims'][P_PARTICIPANTOF] or {}
local output = ''
output = output .. '|-\n'
output = output .. '!scope="col" | Slam !!scope="col" | Race group !!scope="col" | Event !!scope="col" | <abbr title="Place">Pl.</abbr> !!scope="col" | Time\n'
local slamSet = {}
for _, slamQid in ipairs(slams) do
slamSet[slamQid] = true
end
for i, pc in ipairs(participantOfClaims) do
local mainsnak = pc.mainsnak
-- mw.logObject(mw.wikibase.renderSnak(pc['mainsnak']))
if mainsnak.snaktype == 'value' and slamSet[mainsnak.datavalue.value.id] and pc['qualifiers'] then
local qs = pc['qualifiers']
output = output .. '|-\n'
output = output .. '| '
-- Slam
output = output .. 'rowspan=2| '
output = output .. '[[' .. mw.wikibase.renderSnak(pc['mainsnak']) .. ']]'
output = output .. ' || '
-- Race group
output = output .. 'rowspan=2| '
if qs[P_COMPETITIONCLASS] then
local cc = mw.wikibase.renderSnak(qs[P_COMPETITIONCLASS][1])
output = output .. cc:sub(1, 1):upper() .. cc:sub(2)
end
output = output .. '\n'
-- Place dupe fix
if qs[P_RACETIME] and qs[P_RACETIME][2] and qs[P_RANK] and qs[P_RANK][1] and not qs[P_RANK][2] and not qs[P_ENDCAUSE] then
qs[P_RANK][2] = qs[P_RANK][1]
end
-- End cause dupe fix
if qs[P_RACETIME] and qs[P_RACETIME][1] and qs[P_RACETIME][1]['snaktype'] == 'novalue' and not qs[P_RACETIME][2] then
qs[P_RACETIME][2] = qs[P_RACETIME][1]
end
for j = 1,2 do
-- Event
output = output .. '| '
if qs[P_SPORTSDISCIPLINE] and qs[P_SPORTSDISCIPLINE][j] then
output = output .. mw.wikibase.renderSnak(qs[P_SPORTSDISCIPLINE][j]):gsub("metres", "m")
end
output = output .. ' || '
-- Place
if qs[P_RANK] and qs[P_RANK][j] then
output = output .. toOrdinal(tonumber(mw.wikibase.renderSnak(qs[P_RANK][j])))
end
output = output .. ' || '
-- Time
if qs[P_RACETIME] and qs[P_RACETIME][j] then
local timeStr = mw.wikibase.renderSnak(qs[P_RACETIME][j]):gsub(" second", "")
if timeStr == 'no value' and qs[P_ENDCAUSE] then
local endCauseIdx = 1
if j == 2 and qs[P_ENDCAUSE][2] then endCauseIdx = 2 end
local endCause = qs[P_ENDCAUSE][endCauseIdx]['datavalue']['value']['id']
if endCause == Q_DNS then timeStr = 'DNS' end
if endCause == Q_DNF then timeStr = 'DNF' end
if endCause == Q_DQ then timeStr = 'DQ' end
end
local seconds = tonumber(timeStr)
if seconds and seconds >= 60 then
local minutes = math.floor(seconds / 60)
local remainingSeconds = seconds % 60
-- Format with leading zero for seconds if needed
output = output .. string.format("%d:%05.2f", minutes, remainingSeconds)
else
output = output .. timeStr
end
end
output = output .. '\n|-\n'
end
end
end
output = output .. '|}'
return output
end
return p