Commit 1ea385625b481e405fbbffc2b2465553b20d90de
1 parent
26323046
Exists in
master
and in
4 other branches
Remove Commit & Tree decorators
Showing
2 changed files
with
0 additions
and
126 deletions
Show diff stats
app/decorators/commit_decorator.rb
... | ... | @@ -1,93 +0,0 @@ |
1 | -class CommitDecorator < ApplicationDecorator | |
2 | - decorates :commit | |
3 | - | |
4 | - # Returns a string describing the commit for use in a link title | |
5 | - # | |
6 | - # Example | |
7 | - # | |
8 | - # "Commit: Alex Denisov - Project git clone panel" | |
9 | - def link_title | |
10 | - "Commit: #{author_name} - #{title}" | |
11 | - end | |
12 | - | |
13 | - # Returns the commits title. | |
14 | - # | |
15 | - # Usually, the commit title is the first line of the commit message. | |
16 | - # In case this first line is longer than 80 characters, it is cut off | |
17 | - # after 70 characters and ellipses (`&hellp;`) are appended. | |
18 | - def title | |
19 | - title = safe_message | |
20 | - | |
21 | - return no_commit_message if title.blank? | |
22 | - | |
23 | - title_end = title.index(/\n/) | |
24 | - if (!title_end && title.length > 80) || (title_end && title_end > 80) | |
25 | - title[0..69] << "…".html_safe | |
26 | - else | |
27 | - title.split(/\n/, 2).first | |
28 | - end | |
29 | - end | |
30 | - | |
31 | - # Returns the commits description | |
32 | - # | |
33 | - # cut off, ellipses (`&hellp;`) are prepended to the commit message. | |
34 | - def description | |
35 | - description = safe_message | |
36 | - | |
37 | - title_end = description.index(/\n/) | |
38 | - if (!title_end && description.length > 80) || (title_end && title_end > 80) | |
39 | - "…".html_safe << description[70..-1] | |
40 | - else | |
41 | - description.split(/\n/, 2)[1].try(:chomp) | |
42 | - end | |
43 | - end | |
44 | - | |
45 | - # Returns a link to the commit author. If the author has a matching user and | |
46 | - # is a member of the current @project it will link to the team member page. | |
47 | - # Otherwise it will link to the author email as specified in the commit. | |
48 | - # | |
49 | - # options: | |
50 | - # avatar: true will prepend the avatar image | |
51 | - # size: size of the avatar image in px | |
52 | - def author_link(options = {}) | |
53 | - person_link(options.merge source: :author) | |
54 | - end | |
55 | - | |
56 | - # Just like #author_link but for the committer. | |
57 | - def committer_link(options = {}) | |
58 | - person_link(options.merge source: :committer) | |
59 | - end | |
60 | - | |
61 | - protected | |
62 | - | |
63 | - def no_commit_message | |
64 | - "--no commit message" | |
65 | - end | |
66 | - | |
67 | - # Private: Returns a link to a person. If the person has a matching user and | |
68 | - # is a member of the current @project it will link to the team member page. | |
69 | - # Otherwise it will link to the person email as specified in the commit. | |
70 | - # | |
71 | - # options: | |
72 | - # source: one of :author or :committer | |
73 | - # avatar: true will prepend the avatar image | |
74 | - # size: size of the avatar image in px | |
75 | - def person_link(options = {}) | |
76 | - source_name = send "#{options[:source]}_name".to_sym | |
77 | - source_email = send "#{options[:source]}_email".to_sym | |
78 | - text = if options[:avatar] | |
79 | - avatar = h.image_tag h.gravatar_icon(source_email, options[:size]), class: "avatar #{"s#{options[:size]}" if options[:size]}", width: options[:size], alt: "" | |
80 | - %Q{#{avatar} <span class="commit-#{options[:source]}-name">#{source_name}</span>} | |
81 | - else | |
82 | - source_name | |
83 | - end | |
84 | - | |
85 | - user = User.where('name like ? or email like ?', source_name, source_email).first | |
86 | - | |
87 | - if user.nil? | |
88 | - h.mail_to(source_email, text.html_safe, class: "commit-#{options[:source]}-link") | |
89 | - else | |
90 | - h.link_to(text.html_safe, h.user_path(user), class: "commit-#{options[:source]}-link") | |
91 | - end | |
92 | - end | |
93 | -end |
app/decorators/tree_decorator.rb
... | ... | @@ -1,33 +0,0 @@ |
1 | -class TreeDecorator < ApplicationDecorator | |
2 | - decorates :tree | |
3 | - | |
4 | - def breadcrumbs(max_links = 2) | |
5 | - if path | |
6 | - part_path = "" | |
7 | - parts = path.split("\/") | |
8 | - | |
9 | - yield('..', nil) if parts.count > max_links | |
10 | - | |
11 | - parts.each do |part| | |
12 | - part_path = File.join(part_path, part) unless part_path.empty? | |
13 | - part_path = part if part_path.empty? | |
14 | - | |
15 | - next unless parts.last(2).include?(part) if parts.count > max_links | |
16 | - yield(part, h.tree_join(ref, part_path)) | |
17 | - end | |
18 | - end | |
19 | - end | |
20 | - | |
21 | - def up_dir? | |
22 | - path.present? | |
23 | - end | |
24 | - | |
25 | - def up_dir_path | |
26 | - file = File.join(path, "..") | |
27 | - h.tree_join(ref, file) | |
28 | - end | |
29 | - | |
30 | - def readme | |
31 | - @readme ||= contents.find { |c| c.is_a?(Grit::Blob) and c.name =~ /^readme/i } | |
32 | - end | |
33 | -end |