mNo edit summary
mNo edit summary
Line 16: Line 16:
     local tables = 'Commendations'
     local tables = 'Commendations'
     local fields = 'Commendation, COUNT(*)'
     local fields = 'Commendation, COUNT(*)'
    -- optional parameters are grouped in one table
 
    -- you can omit any or all of them, except join if you use more than one table
     local args = {
     local args = {
        --where = '',
        --join = 'table1.fieldA = table2.fieldB,table2.fieldC=table3.fieldD, etc.',
         groupBy = 'Commendation',
         groupBy = 'Commendation',
        --having = 'table1.fieldG="some value", etc.',
        --orderBy = 'table2.fieldF, etc.',
        --limit = some number,
        --offset = some number,
     }
     }
     local results = cargo.query( tables, fields, args )
     local results = cargo.query( tables, fields, args )
    local groups = {}
   
    for r = 1, #results do
        local r = results[r]
        groups[r.Commendation] = r["COUNT(*)"]
    end
   
     for k, r in pairs(x) do
     for k, r in pairs(x) do
         table.insert(t, "<tr>")
         table.insert(t, "<tr>")
         for k2, r2 in pairs(r) do
         for k2, v in pairs(r) do
            local g = groups[v]
             table.insert(t, "<td>")
             table.insert(t, "<td>")
           
                table.insert(t, v .. "=" .. g)           
             table.insert(t, "</td>")
             table.insert(t, "</td>")
         end
         end
         table.insert(t, "</tr>")
         table.insert(t, "</tr>")
    end
    for r = 1, #results do
        local result = results[r]
        table.insert(t, result.Commendation .. " = " .. result["COUNT(*)"])
     end
     end
     return table.concat(t, '')
     return table.concat(t, '')

Revision as of 19:46, 8 November 2022

Documentation for this module may be created at Module:Commendations/doc

local p = {}
local cargo = mw.ext.cargo

local x = 
{
    { "", "", "Hero of the Federation", "", "" },
    { "M.I. Bronze Star", "M.I. Cross", "Medal of Valour", "Legion of Merit", "M.I. Silver Star" },
    { "Superior Command Commendation", "Distinguished Service Commendation", "Veterans Commendation", "Prisoner of War Commendation", "Emergency First Aid Commendation" },
    { "Professional Development Commendation", "Meritorious Service Commendation", "Good Conduct Commendation", "Humitarian Aid Commendation", "M.I. Reconnaissance Commendation" },
    { "Combat Commendation", "PsyOps Accomplishment Commendation", "Medical Accomplishment Commendation", "Engineering Accomplishment Commendation", "Purple Heart" },
    { "", "", "Veteran's Ribbon", "", "" }
}

function p.Main( frame )
    local t = {}
    local tables = 'Commendations'
    local fields = 'Commendation, COUNT(*)'

    local args = {
        groupBy = 'Commendation',
    }

    local results = cargo.query( tables, fields, args )
    local groups = {}
    
    for r = 1, #results do
        local r = results[r]
        groups[r.Commendation] = r["COUNT(*)"]
    end
    
    for k, r in pairs(x) do
        table.insert(t, "<tr>")
        for k2, v in pairs(r) do
            local g = groups[v]
            table.insert(t, "<td>")
                table.insert(t, v .. "=" .. g)            
            table.insert(t, "</td>")
        end
        table.insert(t, "</tr>")
    end
    return table.concat(t, '')
end

return p


Categories: