Merge branch 'project_activities'

This commit is contained in:
Dmitriy Zaporozhets 2012-01-05 20:16:41 +02:00
commit 70efc014e9
7 changed files with 105 additions and 30 deletions

View file

@ -675,14 +675,14 @@ body.project-page h2.icon.loading {
a.project-update.titled { a.project-update.titled {
position: relative; position: relative;
padding-right: 310px !important; padding-left: 235px !important;
.right-block { .title-block {
padding: 10px; padding: 10px;
width: 280px; width: 205px;
background: #f5f5f5; background: #f5f5f5;
position: absolute; position: absolute;
right: 0; left: 0;
top: 0; top: 0;
} }
} }

View file

@ -45,6 +45,14 @@ class Note < ActiveRecord::Base
def notify_author def notify_author
@notify_author ||= false @notify_author ||= false
end end
def target
if noteable_type == "Commit"
project.commit(noteable_id)
else
noteable
end
end
end end
# == Schema Information # == Schema Information
# #

View file

@ -117,9 +117,9 @@ class Repository
commits.sort! do |x, y| commits.sort! do |x, y|
y.committed_date <=> x.committed_date y.committed_date <=> x.committed_date
end[0..n] end
commits commits[0..n]
end end
def commits_since(date) def commits_since(date)

View file

@ -1,15 +1,81 @@
%a.project-update{:href => dashboard_feed_path(project, update)} - if update.kind_of?(Note)
= image_tag gravatar_icon(update.author_email), :class => "left", :width => 40 %a.project-update.titled{:href => dashboard_feed_path(project, update)}
%span.update-title = image_tag gravatar_icon(update.author_email), :class => "left", :width => 40
= dashboard_feed_title(update) %span.update-title
%span.update-author = dashboard_feed_title(update)
%strong= update.author_name %span.update-author
authored %strong= update.author_name
= time_ago_in_words(update.created_at) = time_ago_in_words(update.created_at)
ago ago
.right - noteable = update.target
- klass = update.class.to_s.split("::").last.downcase - if noteable.kind_of?(MergeRequest)
%span.tag{ :class => klass }= klass .title-block
- if update.kind_of?(Commit) %span.update-title
%span.tag.commit= update.head.name %span.commit.tag
Merge Request #
= noteable.id
%span.update-author
%span= noteable.source_branch
&rarr;
%span= noteable.target_branch
- elsif noteable.kind_of?(Issue)
.title-block
%span.update-title
%span.commit.tag
Issue #
= noteable.id
%span.update-author
.left= truncate noteable.title
- elsif noteable.kind_of?(Commit)
.title-block
%span.update-title
%span.commit.tag
commit
%span.update-author
.left= truncate noteable.id
- else
.title-block
%span.update-title
%span.commit.tag
Project Wall
%span.update-author
\...
- elsif update.kind_of?(MergeRequest)
%a.project-update.titled{:href => project_merge_request_path(project, update)}
= image_tag gravatar_icon(update.author_email), :class => "left", :width => 40
%span.update-title
Opened merge request
%span.update-author
%strong= update.author_name
= time_ago_in_words(update.created_at)
ago
.title-block
%span.update-title
%span.commit.tag
Merge Request #
= update.id
%span.update-author
%span= update.source_branch
&rarr;
%span= update.target_branch
- elsif update.kind_of?(Issue)
%a.project-update.titled{:href => dashboard_feed_path(project, update)}
= image_tag gravatar_icon(update.author_email), :class => "left", :width => 40
%span.update-title
Created new Issue
%span.update-author
%strong= update.author_name
= time_ago_in_words(update.created_at)
ago
.title-block
%span.update-title
%span.commit.tag
Issue #
= update.id
%span.update-author
.left= truncate update.title

View file

@ -13,9 +13,9 @@
authored authored
= time_ago_in_words(update.created_at) = time_ago_in_words(update.created_at)
ago ago
.right-block .title-block
%span.update-title %span.update-title
%span.commit.tag= update.head.name %span.commit.tag= update.head.name
%span.update-author %span.update-author
.right= truncate update.commit.id .left= truncate update.commit.id

View file

@ -78,13 +78,14 @@ describe "Projects" do
current_path.should == project_path(@project) current_path.should == project_path(@project)
end end
it "should beahave like activities page" do # TODO: replace with real one
within ".project-update" do #it "should beahave like activities page" do
page.should have_content("master") #within ".project-update" do
page.should have_content(@project.commit.author.name) #page.should have_content("master")
page.should have_content(@project.commit.safe_message) #page.should have_content(@project.commit.author.name)
end #page.should have_content(@project.commit.safe_message)
end #end
#end
end end
describe "GET /projects/team" do describe "GET /projects/team" do

View file

@ -28,7 +28,7 @@ describe "Repository" do
end end
it "should show commits list" do it "should show commits list" do
page.all(:css, ".project-update").size.should == 20 page.all(:css, ".project-update").size.should == @project.repo.branches.size
end end
end end