BigW Consortium Gitlab

Commit f1cf4921 by Dmitriy Zaporozhets

Improve contribution calendar on user page

* cache user contributions for day * ignore forks in calendar contribtuions
parent a3c2873f
...@@ -28,13 +28,10 @@ class UsersController < ApplicationController ...@@ -28,13 +28,10 @@ class UsersController < ApplicationController
def calendar def calendar
visible_projects = ProjectsFinder.new.execute(current_user) visible_projects = ProjectsFinder.new.execute(current_user)
calendar = Gitlab::CommitsCalendar.new(visible_projects, @user)
# Get user repositories and collect timestamps for commits
user_repositories = visible_projects.map(&:repository)
calendar = Gitlab::CommitsCalendar.new(user_repositories, @user)
@timestamps = calendar.timestamps @timestamps = calendar.timestamps
@starting_year = (Time.now - 1.year).strftime("%Y") @starting_year = calendar.starting_year
@starting_month = Date.today.strftime("%m").to_i @starting_month = calendar.starting_month
render 'calendar', layout: false render 'calendar', layout: false
end end
......
class ProjectContributions
attr_reader :project, :user
def initialize(project, user)
@project, @user = project, user
end
def commits_log
repository = project.repository
if !repository.exists? || repository.empty?
return {}
end
Rails.cache.fetch(cache_key) do
repository.commits_per_day_for_user(user)
end
end
def cache_key
"#{Date.today.to_s}-commits-log-#{project.id}-#{user.email}"
end
end
...@@ -2,15 +2,15 @@ module Gitlab ...@@ -2,15 +2,15 @@ module Gitlab
class CommitsCalendar class CommitsCalendar
attr_reader :timestamps attr_reader :timestamps
def initialize(repositories, user) def initialize(projects, user)
@timestamps = {} @timestamps = {}
date_timestamps = [] date_timestamps = []
repositories.select(&:exists?).reject(&:empty?).each do |raw_repository| projects.reject(&:forked?).each do |project|
commits_log = raw_repository.commits_per_day_for_user(user) date_timestamps << ProjectContributions.new(project, user).commits_log
date_timestamps << commits_log
end end
# Sumarrize commits from all projects per days
date_timestamps = date_timestamps.inject do |collection, date| date_timestamps = date_timestamps.inject do |collection, date|
collection.merge(date) { |k, old_v, new_v| old_v + new_v } collection.merge(date) { |k, old_v, new_v| old_v + new_v }
end end
...@@ -21,5 +21,13 @@ module Gitlab ...@@ -21,5 +21,13 @@ module Gitlab
@timestamps[timestamp] = commits if timestamp @timestamps[timestamp] = commits if timestamp
end end
end end
def starting_year
(Time.now - 1.year).strftime("%Y")
end
def starting_month
Date.today.strftime("%m").to_i
end
end end
end end
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment