Software /
code /
prosody
Diff
plugins/mod_admin_shell.lua @ 12870:56397f3b58c1
mod_admin_shell: Sort MUC users by relation and JID
Suggested by MattJ, our resident UI expert :)
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Sun, 29 Jan 2023 21:37:13 +0100 |
parent | 12869:70ee82579076 |
child | 12871:885323e2a1ce |
line wrap: on
line diff
--- a/plugins/mod_admin_shell.lua Sun Jan 29 18:57:28 2023 +0100 +++ b/plugins/mod_admin_shell.lua Sun Jan 29 21:37:13 2023 +0100 @@ -1361,6 +1361,8 @@ return room_obj; end +local muc_util = module:require"muc/util"; + function def_env.muc:create(room_jid, config) local room_name, host = check_muc(room_jid); if not room_name then @@ -1406,17 +1408,29 @@ { title = "JID"; width = "75%"; key = "bare_jid" }; { title = "Nickname"; width = "25%"; key = "nick"; mapper = jid_resource }; }, self.session.width); - local total, displayed = 0, 0; - for nick_jid, occupant in room_obj:each_occupant() do - if total == 0 then - print(row()); + local occupants = array.collect(iterators.select(2, room_obj:each_occupant())); + local total = #occupants; + if filter then + occupants:filter(function(occupant) + return occupant.role == filter or jid_resource(occupant.nick):find(filter, 1, true); + end); + end + local displayed = #occupants; + occupants:sort(function(a, b) + if a.role ~= b.role then + return muc_util.valid_roles[a.role] > muc_util.valid_roles[b.role]; + else + return a.bare_jid < b.bare_jid; end - local nick = jid_resource(nick_jid); - if filter == nil or occupant.role == filter or nick:find(filter, 1, true) then - print(row(occupant)); - displayed = displayed + 1; - end - total = total + 1 + end); + + if displayed == 0 then + return true, ("%d out of %d occupant%s listed"):format(displayed, total, total ~= 1 and "s" or "") + end + + print(row()); + for _, occupant in ipairs(occupants) do + print(row(occupant)); end if total == displayed then @@ -1438,18 +1452,37 @@ { title = "JID"; width = "75%" }; { title = "Nickname"; width = "25%"; key = "reserved_nickname" }; }, self.session.width); - local total, displayed = 0, 0; + local affiliated = array(); for affiliated_jid, affiliation, affiliation_data in room_obj:each_affiliation() do - if total == 0 then - print(row()); + affiliated:push(setmetatable({ affiliation; affiliated_jid }, { __index = affiliation_data })); + end + + local total = #affiliated; + if filter then + affiliated:filter(function(affiliation) + return filter == affiliation[1] or filter == affiliation[2]; + end); + end + local displayed = #affiliated; + local aff_ranking = muc_util.valid_affiliations; + affiliated:sort(function(a, b) + if a[1] ~= b[1] then + return aff_ranking[a[1]] > aff_ranking[b[1]]; + else + return a[2] < b[2]; end - if filter == nil or affiliation == filter or affiliated_jid:find(filter, 1, true) then - print(row(setmetatable({ affiliation; affiliated_jid }, { __index = affiliation_data }))) - displayed = displayed + 1; - end - total = total + 1 + end); + + if displayed == 0 then + return true, ("%d out of %d affiliations%s listed"):format(displayed, total, total ~= 1 and "s" or "") end + print(row()); + for _, affiliation in ipairs(affiliated) do + print(row(affiliation)); + end + + if total == displayed then return true, ("%d affiliation%s listed"):format(total, total ~= 1 and "s" or "") else