added site files
This commit is contained in:
parent
a6f70a6c78
commit
329148c253
253 changed files with 30486 additions and 0 deletions
275
EnlighterJS/Resources/github-buttons/GitHubButtons.MooTools.js
Normal file
275
EnlighterJS/Resources/github-buttons/GitHubButtons.MooTools.js
Normal file
|
@ -0,0 +1,275 @@
|
|||
/*!
|
||||
---
|
||||
name: GitHub-Buttons for MooTools, jQuery and PHP
|
||||
description: Unofficial GitHub Buttons based on https://github.com/mdo/github-buttons
|
||||
|
||||
license: Apache 2.0 License
|
||||
version: 2.5.0
|
||||
build: 54ff1b657e537f8107ee7373e0bfeeeb/May 6 2015
|
||||
|
||||
authors:
|
||||
- Andi Dittrich (author of MooTools/jQuery/PHP based versions)
|
||||
- Mark Otto (author of original github-buttons styles)
|
||||
|
||||
download: https://github.com/AndiDittrich/MooTools.GitHub-Buttons
|
||||
website: http://github-buttons.andidittrich.de
|
||||
demo: http://github-buttons.andidittrich.de
|
||||
|
||||
requires:
|
||||
- Core/1.4.5
|
||||
- More/Number.Format
|
||||
- More/Request.JSONP
|
||||
|
||||
provides: [GitHubButton]
|
||||
...
|
||||
*//*
|
||||
---
|
||||
name: GitHub-Buttons
|
||||
description: Unofficial GitHub Buttons inspired by https://github.com/mdo/github-buttons
|
||||
|
||||
license: Dual-Licensed under "The MIT License (X11)" and "Apache 2.0 License"
|
||||
|
||||
authors:
|
||||
- Andi Dittrich
|
||||
|
||||
requires:
|
||||
- Core/1.4.5
|
||||
- More/Number.Format
|
||||
- More/Request.JSONP
|
||||
|
||||
provides: [GitHubButton]
|
||||
...
|
||||
*/
|
||||
var GitHubButton = new Class({
|
||||
Implements: Options,
|
||||
|
||||
// contains the required html structure
|
||||
buttonContainer: null,
|
||||
|
||||
options: {
|
||||
// large or small button ?
|
||||
large: false,
|
||||
|
||||
// GitHub username
|
||||
owner: null,
|
||||
|
||||
// GitHub repository name
|
||||
repo: null,
|
||||
|
||||
// Button type (star, fork, watch, follow)
|
||||
type: 'star',
|
||||
|
||||
// custom button text
|
||||
text: null,
|
||||
|
||||
// enabled/disable counter - manual set the value
|
||||
count: true,
|
||||
|
||||
// enable/disable caching
|
||||
cache: true,
|
||||
|
||||
// cache lifetime in seconds (2h default)
|
||||
cacheLifetime: 7200,
|
||||
|
||||
// error text/count
|
||||
errorText: 'NA'
|
||||
},
|
||||
|
||||
initialize: function(options){
|
||||
this.setOptions(options);
|
||||
|
||||
// jsonp rest service url
|
||||
var url = 'https://api.github.com';
|
||||
|
||||
// create repo url
|
||||
var repoUrl = 'https://github.com/' + this.options.owner + '/' + this.options.repo + '/';
|
||||
var actionUrl = 'https://github.com/' + this.options.owner + '/';
|
||||
|
||||
// text to display
|
||||
var text = '-';
|
||||
|
||||
// response object selector
|
||||
var responseSelector = '';
|
||||
|
||||
// star, fork, follow, watch are supported
|
||||
switch (this.options.type){
|
||||
case 'star':
|
||||
url += '/repos/' + this.options.owner + '/' + this.options.repo;
|
||||
text = 'Star';
|
||||
actionUrl = repoUrl + 'stargazers';
|
||||
responseSelector = 'stargazers_count';
|
||||
break;
|
||||
|
||||
case 'fork':
|
||||
url += '/repos/' + this.options.owner + '/' + this.options.repo;
|
||||
text = 'Fork';
|
||||
actionUrl = repoUrl + 'network';
|
||||
responseSelector = 'forks_count';
|
||||
break;
|
||||
|
||||
case 'watch':
|
||||
url += '/repos/' + this.options.owner + '/' + this.options.repo;
|
||||
actionUrl += this.options.repo + '/watchers';
|
||||
text = 'Watchers';
|
||||
responseSelector = 'subscribers_count';
|
||||
break;
|
||||
|
||||
case 'follow':
|
||||
url += '/users/' + this.options.owner;
|
||||
text = 'Follow @' + this.options.owner;
|
||||
repoUrl = actionUrl;
|
||||
actionUrl += 'followers';
|
||||
responseSelector = 'followers';
|
||||
break;
|
||||
}
|
||||
|
||||
// create html structure
|
||||
// @see https://github.com/mdo/github-buttons/blob/master/github-btn.source.html
|
||||
// <span class="github-btn" id="github-btn">
|
||||
// <a class="gh-btn" id="gh-btn" href="#" target="_blank">
|
||||
// <span class="gh-ico"></span>
|
||||
// <span class="gh-text" id="gh-text"></span>
|
||||
// </a>
|
||||
// <a class="gh-count" id="gh-count" href="#" target="_blank"></a>
|
||||
// </span>
|
||||
|
||||
// create elements
|
||||
this.buttonContainer = new Element('div', {
|
||||
'class': 'github-btn ' + (this.options.large ? 'github-btn-large' : '')
|
||||
});
|
||||
var count = new Element('a', {
|
||||
'class': 'gh-count',
|
||||
href: actionUrl,
|
||||
target: '_blank'
|
||||
});
|
||||
var ico = new Element('span', {
|
||||
'class': 'gh-ico'
|
||||
});
|
||||
var txt = new Element('span', {
|
||||
'class': 'gh-text',
|
||||
text: (this.options.text ? this.options.text : text)
|
||||
});
|
||||
var button = new Element('a', {
|
||||
'class': 'gh-btn',
|
||||
href: repoUrl,
|
||||
target: '_blank'
|
||||
});
|
||||
|
||||
// create structure
|
||||
button.grab(ico).grab(txt);
|
||||
this.buttonContainer.grab(button).grab(count);
|
||||
|
||||
// which "count"-mode should be used ?
|
||||
if (typeof this.options.count == 'boolean'){
|
||||
// show count and request the data via JSONP ?
|
||||
if (this.options.count){
|
||||
// cache instance name
|
||||
var cacheName = 'GHB_' + this.options.type + '_' + this.options.owner + '_' + this.options.repo + '_' + responseSelector;
|
||||
|
||||
// cache version available ?
|
||||
if (this.options.cache === true){
|
||||
var cdata = this.retrieveItem(cacheName, this.options.cacheLifetime);
|
||||
|
||||
if (cdata){
|
||||
// update text
|
||||
count.set('text', cdata.format({group: '.'}));
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
// request data
|
||||
new Request.JSONP({
|
||||
// the rest service url
|
||||
url: url,
|
||||
|
||||
// jsonp callback get parameter
|
||||
// @see https://developer.github.com/v3/#json-p-callbacks
|
||||
callbackKey: 'callback',
|
||||
|
||||
// request complete handler
|
||||
onComplete: function(response){
|
||||
// valid reponse ? request limit not exceeeded ?
|
||||
if (response.data && response.data[responseSelector]){
|
||||
// extract count
|
||||
var cnt = response.data[responseSelector];
|
||||
|
||||
// update text
|
||||
count.set('text', cnt.format({group: '.'}));
|
||||
|
||||
// update cache
|
||||
if (this.options.cache === true){
|
||||
this.storeItem(cacheName, cnt);
|
||||
}
|
||||
|
||||
// set error text
|
||||
}else{
|
||||
count.set('text', this.options.errorText);
|
||||
}
|
||||
}.bind(this)
|
||||
}).send();
|
||||
}else{
|
||||
// hide counter
|
||||
count.setStyle('display', 'none');
|
||||
}
|
||||
|
||||
}else{
|
||||
// manually set the value
|
||||
count.set('text', this.options.count.format({group: '.'}));
|
||||
}
|
||||
},
|
||||
|
||||
// magic method to use class instance as element
|
||||
toElement: function(){
|
||||
return this.buttonContainer;
|
||||
},
|
||||
|
||||
// use local storage as cache
|
||||
storeItem: function(name, data){
|
||||
// generate storage data
|
||||
var d = JSON.encode({
|
||||
time: (new Date().getTime()),
|
||||
payload: data
|
||||
});
|
||||
|
||||
// try to use html5 features
|
||||
if (typeof(Storage) !== "undefined"){
|
||||
localStorage.setItem(name, d);
|
||||
}
|
||||
},
|
||||
|
||||
// use local storage as cache
|
||||
retrieveItem: function(name, cacheLifetime){
|
||||
// try to use html5 features
|
||||
if (typeof(Storage) !== "undefined"){
|
||||
// get item
|
||||
var ls = localStorage.getItem(name);
|
||||
|
||||
// available ?
|
||||
if (!ls){
|
||||
return null;
|
||||
}
|
||||
|
||||
// decode json serialized data
|
||||
ls = JSON.decode(ls);
|
||||
|
||||
// lifetime expired ?
|
||||
if (!ls.time || (ls.time + (cacheLifetime*1000)) < (new Date().getTime())){
|
||||
return null;
|
||||
}
|
||||
|
||||
// valid payload ?
|
||||
return (ls.payload ? ls.payload : null);
|
||||
}else{
|
||||
return null;
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
// Native Element extension - jQuery like usage
|
||||
(function(){
|
||||
Element.implement({
|
||||
GitHubButton: function(options){
|
||||
this.grab(new GitHubButton(options));
|
||||
}
|
||||
});
|
||||
})();
|
189
EnlighterJS/Resources/github-buttons/GitHubButtons.css
Normal file
189
EnlighterJS/Resources/github-buttons/GitHubButtons.css
Normal file
|
@ -0,0 +1,189 @@
|
|||
/*!
|
||||
---
|
||||
name: GitHub-Buttons for MooTools, jQuery and PHP
|
||||
description: Unofficial GitHub Buttons based on https://github.com/mdo/github-buttons
|
||||
|
||||
license: Apache 2.0 License
|
||||
version: 2.5.0
|
||||
build: 5dbc39345334d0b03ad0b90960943efb/May 6 2015
|
||||
|
||||
authors:
|
||||
- Andi Dittrich (author of MooTools/jQuery/PHP based versions)
|
||||
- Mark Otto (author of original github-buttons styles)
|
||||
|
||||
download: https://github.com/AndiDittrich/MooTools.GitHub-Buttons
|
||||
website: http://github-buttons.andidittrich.de
|
||||
demo: http://github-buttons.andidittrich.de
|
||||
|
||||
requires:
|
||||
- Core/1.4.5
|
||||
- More/Number.Format
|
||||
- More/Request.JSONP
|
||||
|
||||
provides: [GitHubButton]
|
||||
...
|
||||
*//*
|
||||
---
|
||||
description: GitHub-Buttons Styles - Improved for use within own pages
|
||||
|
||||
license: Apache 2.0 License
|
||||
|
||||
authors:
|
||||
- Mark Otto
|
||||
- github-buttons contributors (https://github.com/mdo/github-buttons)
|
||||
- Andi Dittrich
|
||||
...
|
||||
*/
|
||||
.github-btn {
|
||||
display: block;
|
||||
position: relative;
|
||||
height: 20px;
|
||||
font: bold 11px/14px "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.gh-btn,.gh-count,.gh-ico {
|
||||
float: left;
|
||||
}
|
||||
|
||||
.gh-btn,.gh-count {
|
||||
padding: 2px 5px 2px 4px;
|
||||
color: #333;
|
||||
text-decoration: none;
|
||||
text-shadow: 0 1px 0 #fff;
|
||||
white-space: nowrap;
|
||||
cursor: pointer;
|
||||
border-radius: 3px;
|
||||
}
|
||||
|
||||
.gh-btn {
|
||||
background-color: #e6e6e6;
|
||||
background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#fafafa),
|
||||
to(#eaeaea));
|
||||
background-image: -webkit-linear-gradient(#fafafa, #eaeaea);
|
||||
background-image: -moz-linear-gradient(top, #fafafa, #eaeaea);
|
||||
background-image: -ms-linear-gradient(#fafafa, #eaeaea);
|
||||
background-image: -o-linear-gradient(#fafafa, #eaeaea);
|
||||
background-image: linear-gradient(#fafafa, #eaeaea);
|
||||
background-repeat: no-repeat;
|
||||
border: 1px solid #d4d4d4;
|
||||
border-bottom-color: #bcbcbc;
|
||||
}
|
||||
|
||||
.gh-btn:hover,.gh-btn:focus,.gh-btn:active {
|
||||
color: #fff;
|
||||
text-decoration: none;
|
||||
text-shadow: 0 -1px 0 rgba(0, 0, 0, .25);
|
||||
border-color: #518cc6 #518cc6 #2a65a0;
|
||||
background-color: #3072b3;
|
||||
}
|
||||
|
||||
.gh-btn:hover,.gh-btn:focus {
|
||||
background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#599bdc),
|
||||
to(#3072b3));
|
||||
background-image: -webkit-linear-gradient(#599bdc, #3072b3);
|
||||
background-image: -moz-linear-gradient(top, #599bdc, #3072b3);
|
||||
background-image: -ms-linear-gradient(#599bdc, #3072b3);
|
||||
background-image: -o-linear-gradient(#599bdc, #3072b3);
|
||||
background-image: linear-gradient(#599bdc, #3072b3);
|
||||
}
|
||||
|
||||
.gh-btn:active {
|
||||
background-image: none;
|
||||
-webkit-box-shadow: inset 0 2px 5px rgba(0, 0, 0, .10);
|
||||
-moz-box-shadow: inset 0 2px 5px rgba(0, 0, 0, .10);
|
||||
box-shadow: inset 0 2px 5px rgba(0, 0, 0, .10);
|
||||
}
|
||||
|
||||
.gh-ico {
|
||||
width: 14px;
|
||||
height: 14px;
|
||||
margin-right: 4px;
|
||||
vertical-align: 3px;
|
||||
background-image:
|
||||
url();
|
||||
background-size: 28px 14px;
|
||||
background-repeat: no-repeat;
|
||||
background-position: 0 0;
|
||||
}
|
||||
|
||||
.gh-btn:hover .gh-ico,.gh-btn:focus .gh-ico,.gh-btn:active .gh-ico {
|
||||
background-position: -14px 0;
|
||||
}
|
||||
|
||||
.gh-count {
|
||||
position: relative;
|
||||
display: block;
|
||||
margin-left: 4px;
|
||||
background-color: #fafafa;
|
||||
border: 1px solid #d4d4d4;
|
||||
}
|
||||
|
||||
.gh-count:hover,.gh-count:focus {
|
||||
color: #4183C4;
|
||||
}
|
||||
|
||||
.gh-count:before,.gh-count:after {
|
||||
content: '';
|
||||
position: absolute;
|
||||
display: inline-block;
|
||||
width: 0;
|
||||
height: 0;
|
||||
border-color: transparent;
|
||||
border-style: solid;
|
||||
}
|
||||
|
||||
.gh-count:before {
|
||||
top: 50%;
|
||||
left: -3px;
|
||||
margin-top: -4px;
|
||||
border-width: 4px 4px 4px 0;
|
||||
border-right-color: #fafafa;
|
||||
}
|
||||
|
||||
.gh-count:after {
|
||||
top: 50%;
|
||||
left: -4px;
|
||||
z-index: -1;
|
||||
margin-top: -5px;
|
||||
border-width: 5px 5px 5px 0;
|
||||
border-right-color: #d4d4d4;
|
||||
}
|
||||
|
||||
.github-btn-large {
|
||||
height: 30px;
|
||||
}
|
||||
|
||||
.github-btn-large .gh-btn,.github-btn-large .gh-count {
|
||||
padding: 3px 10px 3px 8px;
|
||||
font-size: 16px;
|
||||
line-height: 22px;
|
||||
border-radius: 4px;
|
||||
}
|
||||
|
||||
.github-btn-large .gh-ico {
|
||||
width: 20px;
|
||||
height: 20px;
|
||||
background-size: 40px 20px;
|
||||
}
|
||||
|
||||
.github-btn-large .gh-btn:hover .gh-ico,.github-btn-large .gh-btn:focus .gh-ico,.github-btn-large .gh-btn:active .gh-ico
|
||||
{
|
||||
background-position: -20px 0;
|
||||
}
|
||||
|
||||
.github-btn-large .gh-count {
|
||||
margin-left: 6px;
|
||||
}
|
||||
|
||||
.github-btn-large .gh-count:before {
|
||||
left: -5px;
|
||||
margin-top: -6px;
|
||||
border-width: 6px 6px 6px 0;
|
||||
}
|
||||
|
||||
.github-btn-large .gh-count:after {
|
||||
left: -6px;
|
||||
margin-top: -7px;
|
||||
border-width: 7px 7px 7px 0;
|
||||
}
|
13
EnlighterJS/Resources/github-buttons/LICENSE.md
Normal file
13
EnlighterJS/Resources/github-buttons/LICENSE.md
Normal file
|
@ -0,0 +1,13 @@
|
|||
Copyright 2014 Mark Otto, 2014-2015 Andi Dittrich
|
||||
|
||||
Licensed under the Apache License, Version 2.0 (the "License");
|
||||
you may not use this file except in compliance with the License.
|
||||
You may obtain a copy of the License at
|
||||
|
||||
http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
||||
Unless required by applicable law or agreed to in writing, software
|
||||
distributed under the License is distributed on an "AS IS" BASIS,
|
||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
See the License for the specific language governing permissions and
|
||||
limitations under the License.
|
Loading…
Add table
Add a link
Reference in a new issue