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_tab_width: 4
|
||||||
coderay_bold_every: 10
|
coderay_bold_every: 10
|
||||||
coderay_css: style
|
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="#news">News</a></li>
|
||||||
<li><a href="#about">About</a></li>
|
<li><a href="#about">About</a></li>
|
||||||
<li><a href="#features">Features</a></li>
|
<li><a href="#features">Features</a></li>
|
||||||
|
<li><a href="#contributors">Contributors</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -208,4 +209,18 @@ ALERT:
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</section>
|
</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>
|
</div>
|
||||||
|
|
|
@ -92,3 +92,7 @@ section {
|
||||||
vertical-align: top;
|
vertical-align: top;
|
||||||
margin-right: 4px;
|
margin-right: 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
table.unstyled td {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue