106 lines
3.1 KiB
Ruby
106 lines
3.1 KiB
Ruby
module StatisticsHelper
|
|
|
|
def statistics_data
|
|
[
|
|
{
|
|
key: 'users',
|
|
name: t('statistics.sections.users'),
|
|
entries: user_statistics
|
|
},
|
|
{
|
|
key: 'exercises',
|
|
name: t('statistics.sections.exercises'),
|
|
entries: exercise_statistics
|
|
},
|
|
{
|
|
key: 'request_for_comments',
|
|
name: t('statistics.sections.request_for_comments'),
|
|
entries: rfc_statistics
|
|
}
|
|
]
|
|
end
|
|
|
|
def user_statistics
|
|
[
|
|
{
|
|
key: 'internal_users',
|
|
name: t('activerecord.models.internal_user.other'),
|
|
data: InternalUser.count,
|
|
url: internal_users_path
|
|
},
|
|
{
|
|
key: 'external_users',
|
|
name: t('activerecord.models.external_user.other'),
|
|
data: ExternalUser.count,
|
|
url: external_users_path
|
|
},
|
|
{
|
|
key: 'currently_active',
|
|
name: t('statistics.entries.users.currently_active'),
|
|
data: ExternalUser.joins(:submissions)
|
|
.where(['submissions.created_at >= ?', DateTime.now - 5.minutes])
|
|
.distinct('external_users.id').count
|
|
}
|
|
]
|
|
end
|
|
|
|
def exercise_statistics
|
|
[
|
|
{
|
|
key: 'exercises',
|
|
name: t('activerecord.models.exercise.other'),
|
|
data: Exercise.count,
|
|
url: exercises_path
|
|
},
|
|
{
|
|
key: 'average_submissions',
|
|
name: t('statistics.entries.exercises.average_number_of_submissions'),
|
|
data: Submission.count / Exercise.count
|
|
},
|
|
{
|
|
key: 'execution_environments',
|
|
name: t('activerecord.models.execution_environment.other'),
|
|
data: ExecutionEnvironment.count,
|
|
url: execution_environments_path
|
|
},
|
|
{
|
|
key: 'exercise_collections',
|
|
name: t('activerecord.models.exercise_collection.other'),
|
|
data: ExerciseCollection.count,
|
|
url: exercise_collections_path
|
|
}
|
|
]
|
|
end
|
|
|
|
def rfc_statistics
|
|
[
|
|
{
|
|
key: 'rfcs',
|
|
name: t('activerecord.models.request_for_comment.other'),
|
|
data: RequestForComment.count,
|
|
url: request_for_comments_path
|
|
},
|
|
{
|
|
key: 'percent_solved',
|
|
name: t('statistics.entries.request_for_comments.percent_solved'),
|
|
data: (100.0 / RequestForComment.count * RequestForComment.where(solved: true).count).round(1),
|
|
unit: '%',
|
|
url: request_for_comments_path + '?q%5Bsolved_not_eq%5D=0'
|
|
},
|
|
{
|
|
key: 'percent_unsolved',
|
|
name: t('statistics.entries.request_for_comments.percent_unsolved'),
|
|
data: (100.0 / RequestForComment.count * RequestForComment.where(solved: false).count).round(1),
|
|
unit: '%',
|
|
url: request_for_comments_path + '?q%5Bsolved_not_eq%5D=1'
|
|
},
|
|
{
|
|
key: 'comments',
|
|
name: t('activerecord.models.comment.other'),
|
|
data: Comment.count
|
|
},
|
|
]
|
|
end
|
|
|
|
end
|