// ==UserScript==
// @name RSS+ : Show Site All RSS
// @name:zh RSS+ : 显示当前网站所有的 RSS
// @name:zh-CN RSS+ : 显示当前网站所有的 RSS
// @name:zh-TW RSS+ : 顯示當前網站所有的 RSS
// @description Show Site All RSS.
// @description:zh 显示当前网站所有的 RSS
// @description:zh-CN 显示当前网站所有的 RSS
// @description:zh-TW 顯示當前網站所有的 RSS
// @date 2018.09.16
// @modified 2019.04.26
// @version 0.4.2
// @icon http://www.inoreader.com/favicon.ico
// @author Wizos
// @namespace https://blog.wizos.me
// @supportURL wizos@qq.com
// @contributionURL https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=wizos@qq.com&item_name=Greasy+Fork+donation
// @contributionAmount 2
// @include *
// @match http://*/*
// @match https://*/*
// @grant GM_xmlhttpRequest
// @grant GM_setClipboard
// @grant GM_notification
// @grant GM_addStyle
// @grant GM_getValue
// @grant GM_setValue
// @grant unsafeWindow
// @noframes
// @run-at document-end
// @downloadURL none
// ==/UserScript==
// 2019.04.26_0.4.2 1.修复默认圆圈状态下宽度太宽,导致遮挡下层页面事件触发的问题。2.将icon由字体改为svg形式,修复部分站点无法显示icon的问题。3.优化RSS没有title时的默认名称。
// 2018.11.10_0.4.1 关闭发现RSS后的h5通知
// 2018.10.29_0.4 1.在无法链接服务器时也能展示本地的RSS;2.针对开启 Content-Security-Policy 的网站直接展示本地的RSS;3.发现RSS后,进行h5通知
// 2018.10.23_0.4 1.增加识别为 wordpress 站点时,尝试使用/feed后缀;2.增加多语言支持
// 2018-10-16_0.3 1.改为iframe方式显示,兼容性更好;2.改为post方式传递页面地址;
// 2018-10-14_0.2 第一版 RSS+ 成型;
// 2018.09.16_0.1 在 RSS+Atom Feed Subscribe Button Generator 脚本基础上增加连接后端获取feed的方式;
if(location.href.match(/api\.wizos\.me/i)){
return;
}
var feeds = [];
var feedsMap = {};
var zhcn = {
"no_title":"无名称",
"copied":"已复制",
"copy" : "复制",
"copy_succeeded" : "复制成功",
"follow" : "订阅",
"found":"发现 ",
"feed": " 个订阅源",
"click_the_number_to_view":"点击右下角的数字查看",
"close": "关闭"
};
var zh = zhcn;
var zhtw = {
"no_title":"無名稱",
"copied":"已複製",
"copy" : "複製",
"copy_succeeded" : "複製成功",
"follow" : "訂閱",
"found":"發現 ",
"feed": " 個訂閱源",
"click_the_number_to_view":"點擊右下角的數位查看",
"close": "關閉"
};
var en = {
"no_title":"NO TITILE",
"copied":"copied",
"copy" : "copy",
"copy_succeeded" : "copy succeeded",
"follow" : "follow",
"found":"found ",
"feed": " feed",
"click_the_number_to_view":"click on the number in the lower right corner to view it",
"close": "close"
};
var languages = {};
languages.zhcn = zhcn;
languages.zhtw = zhtw;
languages.zh = zh;
languages.en = en;
var language = navigator.language.replace('-',"").toLowerCase();
var lang = languages[language];
if( !lang ){
lang = languages.en;
}
setTimeout(function(){
if(location.href.match(/github\.com/i)){
show();
}else{
showWithCloudFeeds( location.href );
}
},0);
function showWithCloudFeeds(url) {
var ajax = new XMLHttpRequest();
ajax.onreadystatechange = function() {
//console.log("当前状态A:" + ajax.readyState + "," + ajax.status );
if ( ajax.readyState != 4 ) {
return;
}
if( ajax.status == 200 ){
var obj = JSON.parse(ajax.responseText);
show(obj.feeds);
}else{
show();
}
};
ajax.open("POST", "https://api.wizos.me/find.php", true);
var data = new FormData();
data.append("url",url);
data.append("user","wizos");
ajax.send( data );
}
function show(cloudFeeds) {
getKnowFeeds();
getUnknownFeeds();
if (cloudFeeds != null) {
console.log("云端有feeds");
console.log(cloudFeeds);
cloudFeeds.forEach(element => {
addRSS(element.title, element.link, element.type);
});
}
render(feeds);
}
function addRSS(title, link, type) {
// console.log("添加新的RSS:" + title + "," + link);
var feed = {};
feed.title = title;
feed.link = link.toLowerCase().replace(/(\/$)/g,"");
// 放重复
if (!feedsMap[feed.link]) {
//如果能查找到,证明数组元素重复了
feedsMap[feed.link] = 1;
feeds.push(feed);
}
}
// 获取在
的元素中,已经声明为RSS的链接
function getKnowFeeds() {
var linkElems = document.getElementsByTagName("link");
var link;
for (var i = 0, l = linkElems.length; i < l; i++) {
link = linkElems[i];
if (!link) continue;
var linkhref = link.href;
var linktype = link.type;
var linktitle = document.title;
if (link.title) {
linktitle = link.title;
}
if (linktype && linktype.match(/.*\/(rss|atom)\+xml?$/i)) {
addRSS(linktitle, linkhref);
} else if (linktype && linktype.match(/^text\/xml$/i)) {
addRSS(linktitle, linkhref);
}
}
}
function getUnknownFeeds() {
var link;
if (!document.links) {
document.links = document.getElementsByTagName("a");
}
var links = document.links;
for (var a = 0, len = links.length; a < len; a++) {
link = links[a];
var linkhref = link.href;
var linktitle = document.title;
if (link.title) {
linktitle = link.title;
} else if (link.innerText) {
linktitle = link.innerText;
}
// console.log("检查RSS:" + linkhref + " , " + link.title);
if (
linkhref.match(/^rss:/) ||linkhref.match( /^(https|http|ftp|feed).*([\.\/]rss([\.\/]xml|\.aspx|\.jsp|\/)?$|\/node\/feed$|\/feed(\.xml|\/$|$)|\/rss\/[a-z0-9]+$|[?&;](rss|xml)=|[?&;]feed=rss[0-9.]*$|[?&;]action=rss_rc$|feeds\.feedburner\.com\/[\w\W]+$)/i)) {
addRSS(linktitle, linkhref);
} else if ( linkhref.match(/^(https|http|ftp|feed).*\/atom(\.xml|\.aspx|\.jsp|\/)?$|[?&;]feed=atom[0-9.]*$/i ) ) { // atom
addRSS(linktitle, linkhref);
} else if (
linkhref.match(
/^(https|http|ftp|feed).*(\/feeds?\/[^.\/]*\.xml$|.*\/index\.xml$|feed\/msgs\.xml(\?num=\d+)?$)/i
)
) {
addRSS(linktitle, linkhref);
} else if (linkhref.match(/^(https|http|ftp|feed).*\.rdf$/i)) {
addRSS(linktitle, linkhref);
} else if (linkhref.match(/^feed:\/\//i)) {
addRSS(linktitle, linkhref);
} else if (linkhref.match(/^(https|http):\/\/feed\./i)) {
addRSS(linktitle, linkhref);
} else if (linkhref.match(/(bitcron\.com|typecho\.org)/i)) {
checkFeed( document.location.protocol + '//' + document.domain );
break;
}
}
if ( feeds.length != 0 ){
return;
}
var headlinks = document.querySelectorAll("head > link");
for (var i = 0, len = headlinks.length; i < len; i++) {
link = headlinks[i];
if(link.href.match(/(wp-content)/i)){
checkFeed( document.location.protocol + '//' + document.domain );
break;
}
}
}
var wp_feed_suffix = ['/?feed=rss2','/?feed=rss','/feed'];
function checkFeed(href) {
checkFeed2("HEAD",href,wp_feed_suffix.pop() );
}
function checkFeed2(method,href,flag) {
method = arguments[0] ? arguments[0] : "HEAD";
flag = arguments[2] ? arguments[2] : wp_feed_suffix.pop();
console.log("函数:" + flag + ",网址:" + href + ",后缀:" + flag );
if( !flag){
return;
}
// console.log("函数:" + flag + ",网址:" + href + ",后缀:" + flag );
var ajax = new XMLHttpRequest();
ajax.onreadystatechange = function() {
console.log("返回结果:" + ajax.readyState + ",状态:" + ajax.status );
if( ajax.readyState == 4 ) {
if( ajax.status == 200 ){
addRSS(document.title, href + flag);
} else if( ajax.status == 405 ){
checkFeed2("GET",href,flag);
} else{
checkFeed(href);
}
}
};
ajax.open(method, href + flag, false);
ajax.send();
}
function render(feeds) {
if (!feeds || feeds.length <= 0) {
console.log("该页没有发现feed");
return;
}
var rss_plus_html = "";
var element, tips, desc;
for (var i = 0; i < feeds.length; i++) {
element = feeds[i];
tips = "";
desc = "";
// console.log("feed信息:" + element.title + element.link);
if (!element.title) {
element.title = lang.no_title;
}
if (element.follows) {
tips = " - " + element.follows + "人订阅";
}
if (element.update) {
tips += " - " + element.update + "更新";
}
if (element.desc) {
desc = ' title="' + element.desc + '"';
}
rss_plus_html +=
' | ';
rss_plus_html +=
'';
rss_plus_html +=
' |
';
}
var rss_count_badge_html =
'' +
feeds.length +
"
";
var rss_feed_list_html =
'' + icon_logo + lang.found +'' +
feeds.length +
'' + lang.feed +' -【RSS+】
';
rss_feed_list_html +=
'
";
var styleEl = document.createElement("style");
styleEl.innerHTML = styleHtml;
// 安装 RSS Plus Box 和 RSS Plus Frame
var rssPlusDiv = document.createElement("div");
rssPlusDiv.setAttribute("id", "rss-plus");
var rssPlusWrapDiv = document.createElement("div");
rssPlusWrapDiv.setAttribute("id", "rss-plus-wrap");
rssPlusWrapDiv.innerHTML = '';
var rssPlusWrapStyle = document.createElement("style");
rssPlusWrapStyle.innerHTML = '#rss-plus-wrap{position:fixed;bottom:5px;right:5px;z-index:9999;width:30px;height:30px;}iframe{max-width: 100%!important;margin:0px !important;}';
rssPlusDiv.insertBefore(rssPlusWrapDiv,rssPlusDiv.firstChild);
rssPlusDiv.insertBefore(rssPlusWrapStyle, rssPlusWrapDiv);
//var head = document.getElementsByTagName("head");
//if (head && head[0]) head = head[0];
var body = document.getElementsByTagName("body");
if (body && body[0]) body = body[0];
insertAfter(rssPlusDiv, body.lastChild);
// body.insertBefore(rssPlusBoxDiv, body.firstChild);
var rssPlusBoxDiv = document.createElement("div");
rssPlusBoxDiv.setAttribute("id", "RSSPlusBox");
rssPlusBoxDiv.innerHTML = rss_count_badge_html + rss_feed_list_html;
var frameBody = rpJSFrame.window.document.getElementsByTagName("body");
if (frameBody && frameBody[0]) frameBody = frameBody[0];
frameBody.insertBefore(rssPlusBoxDiv, frameBody.firstChild);
frameBody.insertBefore(styleEl, frameBody.firstChild);
var rpFeedBadgeDiv = rpJSFrame.window.document.getElementById("rp-feed-badge");
var rpCloseDiv = rpJSFrame.window.document.getElementById("rp-close-btn");
addEventHandler(rpCloseDiv, "click", function() {
rpJSFrame.window.document.getElementById("rp-feed-list").style.display = "none";
rpJSFrame.window.document.getElementById("rp-feed-badge").style.display = "block";
rssPlusWrapDiv.style.width = rpJSFrame.window.document.getElementById("rp-feed-badge").offsetWidth + "px";
rssPlusWrapDiv.style.height = rpJSFrame.window.document.getElementById("rp-feed-badge").offsetHeight + "px";
});
addEventHandler(rpFeedBadgeDiv, "click", function() {
rpJSFrame.window.document.getElementById("rp-feed-list").style.display = "block";
rpJSFrame.window.document.getElementById("rp-feed-badge").style.display = "none";
rssPlusWrapDiv.style.width = rpJSFrame.window.document.getElementById("RSSPlusBox").offsetWidth + "px";
rssPlusWrapDiv.style.height = rpJSFrame.window.document.getElementById("RSSPlusBox").offsetHeight + "px";
});
var copyFeedLinkButtons = rpJSFrame.window.document.getElementsByClassName("rp-copy-feed-link");
var followFeedLinkButtons = rpJSFrame.window.document.getElementsByClassName("rp-follow-feed-link");
for (i = 0; i < copyFeedLinkButtons.length; i++) {
addEventHandler(copyFeedLinkButtons[i], "click", function() {
copyFeedLink(this.getAttribute("index"));
});
}
for (i = 0; i < followFeedLinkButtons.length; i++) {
addEventHandler(followFeedLinkButtons[i], "click", function() {
followFeedLink(this.getAttribute("index"));
});
}
}
function notification(size) {
GM_notification({
title: lang.found + " " + size + " " + lang.feed,
text: lang.click_the_number_to_view,
timeout: 3000
});
}
function copyFeedLink(index) {
GM_setClipboard(feeds[index].link);
GM_notification({
text: lang.copied + ": " + feeds[index].link,
title: lang.copy_succeeded,
timeout: 2000
});
}
function followFeedLink(index) {
// [feedly]https://feedly.com/i/subscription/feed%2Fhttp%3A%2F%2Ffeeds.howtogeek.com%2FHowToGeek
// [inoreader]http://www.inoreader.com/?add_feed=https%3A%2F%2Fwww.howtogeek.com%2Ffeed%2F
// [NewsBlur]http://www.newsblur.com/?url=https%3A%2F%2Ffeeds.howtogeek.com%2FHowToGeek
// [theoldreader]https://theoldreader.com/feeds/subscribe?url=https://api.izgq.net/weibo/rss/1197161814
window.open("https://www.inoreader.com/?add_feed=" + feeds[index].link, "_blank");
}
function addEventHandler(target, eventName, eventHandler, scope) {
var f = scope? function() {
eventHandler.apply(scope, arguments);
}
: eventHandler;
if (target.addEventListener) {
target.addEventListener(eventName, f, true);
} else if (target.attachEvent) {
target.attachEvent("on" + eventName, f);
}
return f;
}
function setupJsIframe(){
var jsIframeDiv = document.createElement("div");
jsIframeDiv.setAttribute("id", "RSSPlusFrame");
jsIframeDiv.innerHTML = '';
var body = document.getElementsByTagName("body");
if (body && body[0]) body = body[0];
insertAfter(jsIframeDiv, body.lastChild);
}
// source: https://blog.csdn.net/liuyingshuai_blog/article/details/54580633?utm_source=copy
function insertAfter(newElement,targetElement){
var parent=targetElement.parentNode;
if(parent.lastChild==targetElement){
parent.appendChild(newElement);
}else{
parent.insertBefore(newElement,targetElement.nextSibling);
}
}
var icon_logo = '';
var icon_close = '';
var styleHtml =
'body {margin: 0px;}#RSSPlusBox { position:fixed;z-index:99999;bottom:0px; right:0px; }div.feed-title { font-weight: bold;font-size:0.8rem; cursor: pointer;}div.feed-tips,div.feed-tips a { font-size: 0.75rem; color: rgb(158, 158, 158);}.card-title {}.rp-card-extra { position:absolute;right:16px;top:1px;}.rp-table-body { max-height: 400px; height: auto; overflow-x: hidden;}.table-footer { position: fixed; bottom: 0 ; padding-left: 10px; width: 100%; background-color: #fff;}.table-footer a { color: #ed3f14;}.support-box { height: 28px; line-height: 28px;}#rp-feed-list{display:none;z-index:23333;box-shadow: 1px 1px 2px 2px #4242426b; width:600px;max-height:460px;} #rp-feed-badge{width: 28px; height: 28px; line-height: 28px; border-radius: 14px; float: right;cursor: pointer;z-index:23333;}#rp-feed-badge:hover{border-color:#e9eaec}.badge{ top:-17px; left: -6%; width: 26px; height: 26px; line-height: 26px; border-radius: 13px;}.rp-card:hover{-webkit-box-shadow:0 1px 6px rgba(0,0,0,.2);box-shadow:0 1px 6px rgba(0,0,0,.2);border-color:#eee}.rp-card{background:#fff;border-radius:4px;font-size:14px;position:relative;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.rp-card-bordered:hover{border-color:#e9eaec}.rp-card-bordered{border:1px solid #dddee1;border-color:#e9eaec}.rp-mark-count{font-weight:bold;color: #ed3f14;}.rp-badge-count{position:relative;display:inline-block;width: 26px;height: 26px;line-height: 26px;border-radius: 15px;min-width: 20px;background:#4b5979;border: 1px solid transparent;color: #fff;text-align: center;font-size: 12px;white-space: nowrap;-webkit-transform-origin: -10% center;-ms-transform-origin: -10% center;transform-origin: -10% center;z-index: 10;-webkit-box-shadow: 0 0 0 1px #fff;box-shadow: 0 0 0 1px #fff;}.rp-badge-count a,.rp-badge-count a:hover{color:#fff}.rp-card-head{border-bottom:1px solid #e9eaec;padding:10px 16px;line-height:1}.rp-tooltip{display:inline-block}.rp-tooltip-rel{display:inline-block;position:relative}.rp-btn{display:inline-block;margin-bottom:0;font-weight:400;text-align:center;vertical-align:middle;-ms-touch-action:manipulation;touch-action:manipulation;cursor:pointer;background-image:none;border:1px solid transparent;white-space:nowrap;line-height:1.5;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding:6px 15px;font-size:12px;border-radius:4px;-webkit-transition:color .2s linear,background-color .2s linear,border .2s linear,-webkit-box-shadow .2s linear;transition:color .2s linear,background-color .2s linear,border .2s linear,-webkit-box-shadow .2s linear;transition:color .2s linear,background-color .2s linear,border .2s linear,box-shadow .2s linear;transition:color .2s linear,background-color .2s linear,border .2s linear,box-shadow .2s linear,-webkit-box-shadow .2s linear;color:#495060;background-color:#f7f7f7;border-color:#dddee1}.rp-btn>.rp-icon{line-height:1}.rp-btn,.rp-btn:active,.rp-btn:focus{outline:0}.rp-btn:not([disabled]):hover{text-decoration:none}.rp-btn:not([disabled]):active{outline:0}.rp-btn.disabled,.rp-btn[disabled]{cursor:not-allowed}.rp-btn.disabled>*,.rp-btn[disabled]>*{pointer-events:none}.rp-btn>a:only-child{color:currentColor}.rp-btn>a:only-child:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:0 0}.rp-btn:hover{color:#6d7380;background-color:#f9f9f9;border-color:#e4e5e7}.rp-btn:hover>a:only-child{color:currentColor}.rp-btn:hover>a:only-child:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:0 0}.rp-btn.active,.rp-btn:active{color:#454c5b;background-color:#ebebeb;border-color:#ebebeb}.rp-btn.active>a:only-child,.rp-btn:active>a:only-child{color:currentColor}.rp-btn.active>a:only-child:after,.rp-btn:active>a:only-child:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:0 0}.rp-btn.disabled,.rp-btn.disabled.active,.rp-btn.disabled:active,.rp-btn.disabled:focus,.rp-btn.disabled:hover,.rp-btn[disabled],.rp-btn[disabled].active,.rp-btn[disabled]:active,.rp-btn[disabled]:focus,.rp-btn[disabled]:hover,fieldset[disabled] .rp-btn,fieldset[disabled] .rp-btn.active,fieldset[disabled] .rp-btn:active,fieldset[disabled] .rp-btn:focus,fieldset[disabled] .rp-btn:hover{color:#bbbec4;background-color:#f7f7f7;border-color:#dddee1}.rp-btn.disabled.active>a:only-child,.rp-btn.disabled:active>a:only-child,.rp-btn.disabled:focus>a:only-child,.rp-btn.disabled:hover>a:only-child,.rp-btn.disabled>a:only-child,.rp-btn[disabled].active>a:only-child,.rp-btn[disabled]:active>a:only-child,.rp-btn[disabled]:focus>a:only-child,.rp-btn[disabled]:hover>a:only-child,.rp-btn[disabled]>a:only-child,fieldset[disabled] .rp-btn.active>a:only-child,fieldset[disabled] .rp-btn:active>a:only-child,fieldset[disabled] .rp-btn:focus>a:only-child,fieldset[disabled] .rp-btn:hover>a:only-child,fieldset[disabled] .rp-btn>a:only-child{color:currentColor}.rp-btn.disabled.active>a:only-child:after,.rp-btn.disabled:active>a:only-child:after,.rp-btn.disabled:focus>a:only-child:after,.rp-btn.disabled:hover>a:only-child:after,.rp-btn.disabled>a:only-child:after,.rp-btn[disabled].active>a:only-child:after,.rp-btn[disabled]:active>a:only-child:after,.rp-btn[disabled]:focus>a:only-child:after,.rp-btn[disabled]:hover>a:only-child:after,.rp-btn[disabled]>a:only-child:after,fieldset[disabled] .rp-btn.active>a:only-child:after,fieldset[disabled] .rp-btn:active>a:only-child:after,fieldset[disabled] .rp-btn:focus>a:only-child:after,fieldset[disabled] .rp-btn:hover>a:only-child:after,fieldset[disabled] .rp-btn>a:only-child:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:0 0}.rp-btn:hover{color:#57a3f3;background-color:#fff;border-color:#57a3f3}.rp-btn:hover>a:only-child{color:currentColor}.rp-btn:hover>a:only-child:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:0 0}.rp-btn.active,.rp-btn:active{color:#2b85e4;background-color:#fff;border-color:#2b85e4}.rp-btn.active>a:only-child,.rp-btn:active>a:only-child{color:currentColor}.rp-btn.active>a:only-child:after,.rp-btn:active>a:only-child:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:0 0}.rp-btn:focus{-webkit-box-shadow:0 0 0 2px rgba(45,140,240,.2);box-shadow:0 0 0 2px rgba(45,140,240,.2)}.rp-btn-long{width:100%}.rp-btn>.rp-icon+span,.rp-btn>span+.rp-icon{margin-left:4px}.rp-table{width:inherit;max-height:280px;max-width:100%;overflow:auto;color:#495060;font-size:12px;background-color:#fff;-webkit-box-sizing:border-box;box-sizing:border-box}.rp-table:before{content:"";width:100%;height:1px;position:absolute;left:0;bottom:0;background-color:#dddee1;z-index:1}.rp-table:after{content:"";width:1px;height:100%;position:absolute;top:0;right:0;background-color:#dddee1;z-index:3}.rp-table-body{overflow:auto}.rp-table td,.rp-table th{min-width:0;height:48px;-webkit-box-sizing:border-box;box-sizing:border-box;text-align:left;text-overflow:ellipsis;vertical-align:middle;border-bottom:1px solid #e9eaec}.rp-table th{height:40px;white-space:nowrap;overflow:hidden;background-color:#f8f8f9}.rp-table td{background-color:#fff;-webkit-transition:background-color .2s ease-in-out;transition:background-color .2s ease-in-out}//.rp-table-cell span{display:none}.rp-table-cell{display:inline-block;word-wrap:normal;vertical-align:middle}.rp-table-cell{padding-top:5px; padding-bottom:5px; padding-left:18px;padding-right:18px;overflow:hidden;text-overflow:ellipsis;white-space:normal;word-break:break-all;-webkit-box-sizing:border-box;box-sizing:border-box}td.rp-table-column-center,th.rp-table-column-center{text-align:center}td.rp-table-column-right,th.rp-table-column-right{text-align:right}.rp-table table{table-layout:fixed;width: 100%;}.rp-btn-primary{color:#fff;background-color:#2d8cf0;border-color:#2d8cf0;margin:5px;}.rp-btn-primary>a:only-child{color:currentColor}.rp-btn-primary>a:only-child:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:0 0}.rp-btn-primary:hover{color:#fff;background-color:#57a3f3;border-color:#57a3f3}.rp-btn-primary:hover>a:only-child{color:currentColor}.rp-btn-primary:hover>a:only-child:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:0 0}.rp-btn-primary.active,.rp-btn-primary:active{color:#f2f2f2;background-color:#2b85e4;border-color:#2b85e4}.rp-btn-primary.active>a:only-child,.rp-btn-primary:active>a:only-child{color:currentColor}.rp-btn-primary.active>a:only-child:after,.rp-btn-primary:active>a:only-child:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:0 0}.rp-btn-primary.disabled,.rp-btn-primary.disabled.active,.rp-btn-primary.disabled:active,.rp-btn-primary.disabled:focus,.rp-btn-primary.disabled:hover,.rp-btn-primary[disabled],.rp-btn-primary[disabled].active,.rp-btn-primary[disabled]:active,.rp-btn-primary[disabled]:focus,.rp-btn-primary[disabled]:hover,fieldset[disabled] .rp-btn-primary,fieldset[disabled] .rp-btn-primary.active,fieldset[disabled] .rp-btn-primary:active,fieldset[disabled] .rp-btn-primary:focus,fieldset[disabled] .rp-btn-primary:hover{color:#bbbec4;background-color:#f7f7f7;border-color:#dddee1}.rp-btn-primary.disabled.active>a:only-child,.rp-btn-primary.disabled:active>a:only-child,.rp-btn-primary.disabled:focus>a:only-child,.rp-btn-primary.disabled:hover>a:only-child,.rp-btn-primary.disabled>a:only-child,.rp-btn-primary[disabled].active>a:only-child,.rp-btn-primary[disabled]:active>a:only-child,.rp-btn-primary[disabled]:focus>a:only-child,.rp-btn-primary[disabled]:hover>a:only-child,.rp-btn-primary[disabled]>a:only-child,fieldset[disabled] .rp-btn-primary.active>a:only-child,fieldset[disabled] .rp-btn-primary:active>a:only-child,fieldset[disabled] .rp-btn-primary:focus>a:only-child,fieldset[disabled] .rp-btn-primary:hover>a:only-child,fieldset[disabled] .rp-btn-primary>a:only-child{color:currentColor}.rp-btn-primary.disabled.active>a:only-child:after,.rp-btn-primary.disabled:active>a:only-child:after,.rp-btn-primary.disabled:focus>a:only-child:after,.rp-btn-primary.disabled:hover>a:only-child:after,.rp-btn-primary.disabled>a:only-child:after,.rp-btn-primary[disabled].active>a:only-child:after,.rp-btn-primary[disabled]:active>a:only-child:after,.rp-btn-primary[disabled]:focus>a:only-child:after,.rp-btn-primary[disabled]:hover>a:only-child:after,.rp-btn-primary[disabled]>a:only-child:after,fieldset[disabled] .rp-btn-primary.active>a:only-child:after,fieldset[disabled] .rp-btn-primary:active>a:only-child:after,fieldset[disabled] .rp-btn-primary:focus>a:only-child:after,fieldset[disabled] .rp-btn-primary:hover>a:only-child:after,fieldset[disabled] .rp-btn-primary>a:only-child:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:0 0}.rp-btn-primary.active,.rp-btn-primary:active,.rp-btn-primary:hover{color:#fff}.rp-btn-primary:focus{-webkit-box-shadow:0 0 0 2px rgba(45,140,240,.2);box-shadow:0 0 0 2px rgba(45,140,240,.2)}.rp-btn-group:not(.rp-btn-group-vertical) .rp-btn-primary:not(:first-child):not(:last-child){border-right-color:#2b85e4;border-left-color:#2b85e4}.rp-btn-group:not(.rp-btn-group-vertical) .rp-btn-primary:first-child:not(:last-child){border-right-color:#2b85e4}.rp-btn-group:not(.rp-btn-group-vertical) .rp-btn-primary:first-child:not(:last-child)[disabled]{border-right-color:#dddee1}.rp-btn-group:not(.rp-btn-group-vertical) .rp-btn-primary+.rp-btn,.rp-btn-group:not(.rp-btn-group-vertical) .rp-btn-primary:last-child:not(:first-child){border-left-color:#2b85e4}.rp-btn-group:not(.rp-btn-group-vertical) .rp-btn-primary+.rp-btn[disabled],.rp-btn-group:not(.rp-btn-group-vertical) .rp-btn-primary:last-child:not(:first-child)[disabled]{border-left-color:#dddee1}.rp-btn-group-vertical .rp-btn-primary:not(:first-child):not(:last-child){border-top-color:#2b85e4;border-bottom-color:#2b85e4}.rp-btn-group-vertical .rp-btn-primary:first-child:not(:last-child){border-bottom-color:#2b85e4}.rp-btn-group-vertical .rp-btn-primary:first-child:not(:last-child)[disabled]{border-top-color:#dddee1}.rp-btn-group-vertical .rp-btn-primary+.rp-btn,.rp-btn-group-vertical .rp-btn-primary:last-child:not(:first-child){border-top-color:#2b85e4}.rp-btn-group-vertical .rp-btn-primary+.rp-btn[disabled],.rp-btn-group-vertical .rp-btn-primary:last-child:not(:first-child)[disabled]{border-bottom-color:#dddee1}#card-tips{margin-top: 5px;}.rp-btn-small {padding: 2px 7px;font-size: 12px;border-radius: 3px;';