Add user counts for each trust level to admin dashboard

This commit is contained in:
Neil Lalonde 2013-03-15 18:08:46 -04:00
parent 1d9764d8fc
commit d9cdde9aa7
10 changed files with 99 additions and 10 deletions

View File

@ -36,3 +36,21 @@ Handlebars.registerHelper('sumLast', function(property, numDays) {
return sum; return sum;
} }
}); });
/**
Return the count of users at the given trust level.
@method valueAtTrustLevel
@for Handlebars
**/
Handlebars.registerHelper('valueAtTrustLevel', function(property, trustLevel) {
var data = Ember.Handlebars.get(this, property);
if( data ) {
var item = data.find( function(d, i, arr) { return parseInt(d.x,10) === parseInt(trustLevel,10); } );
if( item ) {
return item.y;
} else {
return 0;
}
}
});

View File

@ -38,12 +38,27 @@
</p> </p>
</div> </div>
<div class="dashboard-stats totals">
<div class="dashboard-stats">
{{i18n admin.dashboard.total_users}}: <strong>{{#unless loading}}{{ totalUsers }}{{/unless}}</strong><br/>
</div>
<div class="dashboard-stats trust-levels">
<table class="table table-condensed table-hover"> <table class="table table-condensed table-hover">
<tr> <thead>
<td class="title">{{i18n admin.dashboard.total_users}}</td> <tr>
<td class="value">{{#unless loading}}{{ totalUsers }}{{/unless}}</td> <th>&nbsp;</th>
</tr> <th>0</th>
<th>1</th>
<th>2</th>
<th>3</th>
<th>4</th>
<th>5</th>
</tr>
</thead>
{{#unless loading}}
{{ render 'admin_report_trust_levels' users_by_trust_level }}
{{/unless}}
</table> </table>
</div> </div>

View File

@ -0,0 +1,9 @@
<tr>
<td class="title">{{title}}</td>
<td class="value">{{valueAtTrustLevel data 0}}</td>
<td class="value">{{valueAtTrustLevel data 1}}</td>
<td class="value">{{valueAtTrustLevel data 2}}</td>
<td class="value">{{valueAtTrustLevel data 3}}</td>
<td class="value">{{valueAtTrustLevel data 4}}</td>
<td class="value">{{valueAtTrustLevel data 5}}</td>
</tr>

View File

@ -0,0 +1,4 @@
Discourse.AdminReportTrustLevelsView = Discourse.View.extend({
templateName: 'admin/templates/reports/trust_levels_report',
tagName: 'tbody'
});

View File

@ -332,6 +332,10 @@ table {
border-top: none; border-top: none;
} }
} }
&.trust-levels {
margin-top: 0px;
}
} }

View File

@ -1,8 +1,9 @@
class Admin::DashboardController < Admin::AdminController class Admin::DashboardController < Admin::AdminController
def index def index
render_json_dump({ render_json_dump({
reports: ['visits', 'signups', 'topics', 'posts', 'flags'].map { |type| Report.find(type) }, reports: ['visits', 'signups', 'topics', 'posts', 'flags', 'users_by_trust_level'].map { |type| Report.find(type) },
total_users: User.count total_users: User.count
}.merge( }.merge(
SiteSetting.version_checks? ? {version_check: DiscourseUpdates.check_version} : {} SiteSetting.version_checks? ? {version_check: DiscourseUpdates.check_version} : {}

View File

@ -80,6 +80,15 @@ class Report
end end
end end
def self.report_users_by_trust_level(report)
report.data = []
fetch report do
User.counts_by_trust_level.each do |level, count|
report.data << {x: level.to_i, y: count}
end
end
end
private private

View File

@ -462,6 +462,10 @@ class User < ActiveRecord::Base
where('created_at > ?', since).group('date(created_at)').order('date(created_at)').count where('created_at > ?', since).group('date(created_at)').order('date(created_at)').count
end end
def self.counts_by_trust_level
group('trust_level').count
end
protected protected
def cook def cook

View File

@ -271,6 +271,10 @@ en:
title: "Flags" title: "Flags"
xaxis: "Day" xaxis: "Day"
yaxis: "Number of flags" yaxis: "Number of flags"
users_by_trust_level:
title: "Users per Trust Level"
xaxis: "Trust Level"
yaxis: "Number of Users"
site_settings: site_settings:
default_locale: "The default language of this Discourse instance (ISO 639-1 Code)" default_locale: "The default language of this Discourse instance (ISO 639-1 Code)"

View File

@ -4,7 +4,6 @@ describe Report do
describe 'visits report' do describe 'visits report' do
let(:report) { Report.find('visits', cache: false) } let(:report) { Report.find('visits', cache: false) }
context "no visits" do context "no visits" do
@ -24,10 +23,7 @@ describe Report do
it "returns a report with data" do it "returns a report with data" do
report.data.should be_present report.data.should be_present
end end
end end
end end
[:signup, :topic, :post, :flag].each do |arg| [:signup, :topic, :post, :flag].each do |arg|
@ -58,6 +54,31 @@ describe Report do
end end
end end
describe 'users by trust level report' do
let(:report) { Report.find('users_by_trust_level', cache: false) }
context "no users" do
it "returns an empty report" do
report.data.should be_blank
end
end
context "with users at different trust levels" do
before do
3.times { Fabricate(:user, trust_level: TrustLevel.levels[:new]) }
2.times { Fabricate(:user, trust_level: TrustLevel.levels[:regular]) }
Fabricate(:user, trust_level: TrustLevel.levels[:moderator])
end
it "returns a report with data" do
report.data.should be_present
report.data.find {|d| d[:x] == TrustLevel.levels[:new]} [:y].should == 3
report.data.find {|d| d[:x] == TrustLevel.levels[:regular]}[:y].should == 2
report.data.find {|d| d[:x] == TrustLevel.levels[:moderator]}[:y].should == 1
end
end
end
describe '#fetch' do describe '#fetch' do
context 'signups' do context 'signups' do
let(:report) { Report.find('signups', cache: true) } let(:report) { Report.find('signups', cache: true) }