mirror of
https://github.com/seigler/dash-docs
synced 2025-07-27 09:46:12 +00:00
more work on contributor list; merge contributors by name, use aliases from _config.yml
This commit is contained in:
parent
f2613a9d93
commit
1183de9fce
4 changed files with 79 additions and 0 deletions
|
@ -38,3 +38,8 @@ kramdown:
|
|||
coderay_tab_width: 4
|
||||
coderay_bold_every: 10
|
||||
coderay_css: style
|
||||
|
||||
aliases:
|
||||
s_nakamoto: Satoshi Nakamoto
|
||||
--author=Satoshi Nakamoto: Satoshi Nakamoto
|
||||
gavinandresen: Gavin Andresen
|
||||
|
|
55
_plugins/contributors.rb
Normal file
55
_plugins/contributors.rb
Normal file
|
@ -0,0 +1,55 @@
|
|||
require 'open-uri'
|
||||
require 'json'
|
||||
require 'aquarium'
|
||||
require 'yaml'
|
||||
|
||||
module Jekyll
|
||||
|
||||
class CategoryGenerator < Generator
|
||||
def fetch_contributors
|
||||
contributors = JSON.parse(open("http://github.com/api/v2/json/repos/show/bitcoin/bitcoin/contributors/anon").read)["contributors"]
|
||||
|
||||
contributors.map do |x|
|
||||
x['name'] = x['login'] unless x.has_key?('name')
|
||||
x['name'] = x['login'] if x['name'] == ""
|
||||
|
||||
x
|
||||
end
|
||||
end
|
||||
|
||||
def merge_contributors(contributors, aliases)
|
||||
contributors = contributors.map do |c|
|
||||
c['name'] = aliases[c['name']] if aliases.has_key?(c['name'])
|
||||
|
||||
c
|
||||
end
|
||||
|
||||
hoaoh = contributors.reduce({}) do |result, item|
|
||||
result.merge({ item['name'] => [item] }) { |key, old, new| old[0]['contributions'] += new[0]['contributions']; old }
|
||||
end
|
||||
|
||||
hoaoh.values.map { |sublist|
|
||||
sublist.reduce({}) do |merged,h|
|
||||
merged.merge(h) do |key,old,new| (key=='name' ? old : old+new) end
|
||||
end
|
||||
}.flatten
|
||||
end
|
||||
|
||||
def generate(site)
|
||||
@contributors = merge_contributors(fetch_contributors(), site.config['aliases']).sort_by{|c| - c['contributions']}
|
||||
@primary_devs = JSON.parse(open("http://github.com/api/v2/json/repos/show/bitcoin/bitcoin/collaborators").read)["collaborators"]
|
||||
|
||||
Aquarium::Aspects::Aspect.new :around, :invoking => :site_payload, :on_type => Site do |execution_point, site, *args|
|
||||
result = execution_point.proceed
|
||||
result['site']['project'] = {
|
||||
"primary_devs" => @primary_devs,
|
||||
"contributors" => @contributors
|
||||
}
|
||||
result
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
end
|
15
index.html
15
index.html
|
@ -14,6 +14,7 @@ ALERT:
|
|||
<li><a href="#news">News</a></li>
|
||||
<li><a href="#about">About</a></li>
|
||||
<li><a href="#features">Features</a></li>
|
||||
<li><a href="#contributors">Contributors</a></li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -208,4 +209,18 @@ ALERT:
|
|||
</div>
|
||||
|
||||
</section>
|
||||
|
||||
<section id="contributors">
|
||||
<h1>Contributors <small>ordered by number of commits</small></h1>
|
||||
|
||||
|
||||
<table class="unstyled">
|
||||
<tr>
|
||||
{% for c in site.project.contributors %}
|
||||
<td>{{ c.name }} ({{ c.contributions }})</td>
|
||||
{% cycle nil, nil, nil, nil, '</tr><tr>' %}
|
||||
{% endfor %}
|
||||
</tr>
|
||||
</table>
|
||||
</section>
|
||||
</div>
|
||||
|
|
|
@ -92,3 +92,7 @@ section {
|
|||
vertical-align: top;
|
||||
margin-right: 4px;
|
||||
}
|
||||
|
||||
table.unstyled td {
|
||||
border: none;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue