您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Adds functionalities to InnerCircle
当前为
// ==UserScript== // @name InnerCircle Enhancement Suite // @namespace https://github.com/j3lte/ic-enhancement-suite // @version 0.3.6 // @description Adds functionalities to InnerCircle // @author j3lte // @match https://www.theinnercircle.co/* // @include https://www.theinnercircle.co/* // @icon https://raw.githubusercontent.com/j3lte/ic-enhancement-suite/master/ic_plus.png // @license MIT License https://raw.githubusercontent.com/j3lte/ic-enhancement-suite/master/LICENSE // @grant unsafeWindow // @date 01.26.2015 // ==/UserScript== function ic_FunctionWrapper() { // Define global version var version = '0.3.6'; var enhance_id = '_ic_enhance_options'; // Variables var win = window; var $ic; if (typeof unsafeWindow !== 'undefined') { win = unsafeWindow; } if (typeof unsafeWindow === 'undefined' ) { $ic = jQuery; } else { $ic = unsafeWindow.jQuery || jQuery } if (!win.console) { win.console = { log : function(){} }; } var defaults = { version : version, hideQuestionBlock : false, hideEmptyMatches : false, hideWelcomeForm : false, hideInviteForm : false, loadMemberOnHover : false, openInNew : false, nightMode : false }; var opts = defaults; var optionLabels = [ { identifier: 'option_hide_question', optionKey: 'hideQuestionBlock', label: 'Hide top question block (top middle)', enabled: true }, { identifier: 'option_hide_empty', optionKey: 'hideEmptyMatches', label: 'Hide matches widget when there are no matches (right)', enabled: true }, { identifier: 'option_hide_welcome', optionKey: 'hideWelcomeForm', label:'Hide welcome form (top left)', enabled: true }, { identifier: 'option_hide_invite', optionKey: 'hideInviteForm', label: 'Hide invite form (right)', enabled: true }, { identifier: 'option_load_hover', optionKey: 'loadMemberOnHover', label: 'Load members on hover (beta)', enabled: false }, { identifier: 'option_open_in_new', optionKey: 'openInNew', label: 'Open member links in a new window/tab', enabled: true }, { identifier: 'option_night_mode', optionKey: 'nightMode', label: 'Night mode', enabled: true } ]; function loadSettings() { if (win.localStorage) { if (win.localStorage[enhance_id]) { try { opts = JSON.parse(win.localStorage[enhance_id]); } catch (e) { opts = defaults; saveSettings(); } } else { opts = defaults; saveSettings(); } } else if ($ic.cookie('ic_enhance_options')) { try { opts = JSON.parse($ic.cookie('ic_enhance_options')); } catch (e) { opts = defaults; saveSettings(); } } } function saveSettings() { if (win.localStorage) { win.localStorage[enhance_id] = JSON.stringify(opts); } else if ($ic.cookie) { $ic.cookie('ic_enhance_options', JSON.stringify(opts), { path: '/' }); } } loadSettings(); var css = [ '/* ICES ENHANCEMENTS */', '#userBox { width: 158px; z-index:10000; padding: 2px; border: 1px solid #0099B0;position: fixed;left: 10px;top: 111px;font-size: 10px;background: #fff; }', '#userBox .profile_field { border: 0px solid #000; padding: 0px; line-height: 11px; clear: both; }', '#userBox .job_title { clear: both; color: #666; padding-bottom: 0; font-size: 10px; line-height: 11px; white-space: nowrap; overflow: hidden; border-top: 1px solid #CCC; border-bottom: 1px solid #CCC; }', '#userBox #user_photos { display: block; width: 158px; min-width: 1px; margin: 3px 0 3px 2px; }', '#userBox .rsTmb { width: 50px; margin: 0 2px 2px 0; }', '.close-user-box { cursor: pointer; }', '.google-link { position: absolute;background: rgba(255,255,255,0.3);left: 0;bottom: 0;width: 100%;text-align: center;color: #000;font-size: 10px;text-decoration: none; }', '#saveAndReloadOptions.disabled { opacity: 0.1; }', '.navigation a { padding: 8px 7px; }', '.navigation-icon img { margin-top: -4px; }', '#enhance_tabs label { color:#FFF; }', '.header .navigation a.ic_enhance_suite { padding: 0; margin-right: -9px; margin-left: 15px; }', '/* SCROLLBARS */', '::-webkit-scrollbar { width: 12px; }', '::-webkit-scrollbar-track { border-radius: 1px; -webkit-box-shadow: inset 0 0 4px rgba(0,0,0,0.5); }', '::-webkit-scrollbar-thumb { border-radius: 1px; -webkit-box-shadow: inset 0 0 4px rgba(0,0,0,0.5); }', '/* NIGHTMODE */', 'body.night .white { background-color: #302E31; }', 'body.night, .night .widget.white { background-color: #302E31; color: #fff; }', 'body.night h1 { background-image: url("/images/h1_white.png"); }', 'body.night h1, body.night h1 a, body.night .job_title, body.night .profile_field b { color:#fff; }', 'body.night .rsDefault, body.night .rsDefault .rsOverflow, body.night .rsDefault .rsSlide, body.night .rsDefault .rsVideoFrameHolder, body.night .rsDefault .rsThumbs { background-color: #323232; }', 'body.night .member_event_date, body.night .event_date, body.night .invites_count, body.night .my_trip_date { background-color: #0099B0; }', 'body.night .grey, body.night .message_accent { background-color: #151415; }', 'body.night .grey .free_corner { border-right: 15px solid #0099B0; }', 'body.night .grey .free_text { background-color: #0099B0; }', 'body.night .username, body.night a.username, body.night .spotname, body.night a.spotname { color: #FFFFFF; }', 'body.night .featured_box, body.night .interest_box, body.night .ui-tooltip { color: #FFF; }', 'body.night .nearby-block { border-top:0px solid #151415; }', 'body.night .widget, body.night .hotposts_container { color: #FFF; }', 'body.night .free_action { color: #151415; }', 'body.night .answer-label, body.night #answers-element label { background-color: #302E31; color: #FFF; }', 'body.night #answers-element label.answer-common { background-color: #0099B0; }', 'body.night .message, body.night .message_send, body.night .message_list, body.night .ui-dialog .ui-dialog-content, body.night .ui-tabs .ui-tabs-panel { background-color: #242124; }', 'body.night .panel-box { background-color: #302E31; }', 'body.night .double_user, body.night .single_user { background-color: #242124; }', 'body.night .ui-tabs .ui-tabs-panel, body.night .ui-tabs .ui-widget-header { background-color: #302E31; }', 'body.night .ui-tooltip { background-color: #0099B0; }', 'body.night .going_text { background: #302E31; }', 'body.night .map-users .double_user:nth-child(even) { background-color: #343034; }', 'body.night .map-users .double_user:nth-child(4n), body.night .map-users .double_user:nth-child(4n+3) { background-color: #343034; }', 'body.night .accordeon .ui-widget-content { border: 1px #151415 solid; background-color: #302E31; }', 'body.night input[type=text], body.night input[type=password], body.night textarea { background-color: #302E31; color: #FFF; }', 'body.night .activity_widget, body.night .circle_messages_widget, body.night .circle_activity_widget { background: #302E31!important; }', 'body.night .path_arrow { background-image: url(\'\') }', 'body.night .fancybox-skin { background: #363636; }', 'body.night #user_search_results { background-color: #302E31; color: #FFF; }', 'body.night .searchplace:hover, body.night .searchuser:hover, body.night .searchtrip:hover { background-color: #151415; }' ].join('\n'); if (typeof GM_addStyle !== 'undefined') { GM_addStyle(css); } else if (typeof PRO_addStyle !== 'undefined') { PRO_addStyle(css); } else if (typeof addStyle !== 'undefined') { addStyle(css); } else { var node = document.createElement('style'); node.type = 'text/css'; node.appendChild(document.createTextNode(css)); var heads = document.getElementsByTagName('head'); if (heads.length > 0) { heads[0].appendChild(node); } else { // no head yet, stick it whereever document.documentElement.appendChild(node); } } // Nightmode images var nightmode_img = { inplace_edit : { filename: 'edit', identifier: 'img.inplace_edit', replacement: '' }, ignore_off: { filename: 'ignore_off', identifier: '.ignore.ignore_icon.icon img', replacement: '' }, favorite_off: { filename: 'favorite_off', identifier: '.favorite.icon img', replacement: '' }, like: { filename: 'like', identifier: '.like.icon img', replacement: '' }, message: { filename: 'message', identifier: '.conversation.icon img', replacement: '' }, wink_off: { filename: 'wink_off', identifier: '.wink.icon img', replacement: '' }, report: { filename: 'report', identifier: '.report.feedback img', replacement: '' } }; // Body element var $body = $ic('body'); // Make sure nightmode is already set before we do all the checks (matter of speed) if (opts.nightMode) { $body.addClass('night'); } function replaceImg(img, revert) { $ic(img.identifier).each(function () { if ($ic(this).attr('src').indexOf(img.filename) !== -1 && !revert) { $ic(this).data('orig-src', $ic(this).attr('src')); $ic(this).attr('src',img.replacement); } else if (revert && $ic(this).data('orig-src')) { $ic(this).attr('src',$ic(this).data('orig-src')); } }); } function flipNightMode() { var keys = Object.keys(nightmode_img), i, img; if (opts.nightMode) { $body.addClass('night'); // replace all img with the white base64 version for (i = 0; i < keys.length; i++) { img = nightmode_img[keys[i]]; replaceImg(img); } } else if (!opts.nightMode && $body.hasClass('night')) { $body.removeClass('night'); for (i = 0; i < keys.length; i++) { img = nightmode_img[keys[i]]; replaceImg(img, true); } } } flipNightMode(); // $membox is used for the downloaded content var $memBox = $ic('<div />'); // Userbox is the box that is shown when a member is loaded var $userBox = $ic('<div id="userBox" style="display: none;" />'); $body.append($userBox); // Loader that is shown at the bottom right of the window var $loader = $ic('<div id="loader" style="opacity: 0.6; z-index: 10000; display: none; position: fixed; right: 20px;bottom: 0; width: 240px; height: 16px; background: #0099B0;text-align: center; color: #FFF; padding: 5px 0;"></div>'); $body.append($loader); function loader(message) { if (message) { $loader.text(message); if ($loader.is(':hidden')) { $loader.show(); } } else { $loader.hide(); } } // Regex to determine whether a link contains a member link var memLinkRegEx = /(http|https):\/\/www\.theinnercircle\.co\/member\/\d+/; var timer, ev, link, userBoxes = {}; // Loads the member page function loadMember(link) { loader('Loading member...'); $memBox.load(link, function(){ //callback after your data is in loaded into body. var userName = $memBox.find('.username').parent(); var jobTitle = $memBox.find('.job_title'); var thumbs = $memBox.find('#user_photos'); var profileFields = $memBox.find('.profile_field'); $userBox.html(''); $userBox.append(userName); $userBox.append(jobTitle); if (thumbs.find('.rsImg').length) { var h = Math.round(thumbs.find('.rsImg').length / 3) * 50; thumbs.css('height', h + 'px'); thumbs.find('.rsImg').each(function (){ if ($ic(this).data('rsbigimg')) { $ic(this).attr('href', $ic(this).data('rsbigimg')); } $ic(this).attr('target','_blank'); }); $userBox.append(thumbs); } $userBox.append(profileFields); $userBox.append('<span class="ui-button-icon-primary ui-icon ui-icon-closethick close-user-box" style="position: absolute; top: 0; right: 0;"></span>'); userBoxes[link] = $userBox.html(); link = null; loader(); $userBox.fadeIn(500); win.console.log('[IC Enhancement Suite] :: User shown'); }); } // Load member on hover if (opts.loadMemberOnHover){ $body.on('mouseover', 'a', function(event) { ev = event; // Only set timer if it has a target link, matches a member and is not equal to current member if (ev.currentTarget && ev.currentTarget.href && memLinkRegEx.test(ev.currentTarget.href) && (ev.currentTarget.href !== win.location.href) && ev.currentTarget.href.indexOf('#') === -1) { link = ev.currentTarget.href; if (typeof(userBoxes[link]) !== 'undefined' && userBoxes[link] !== null) { $userBox.html(userBoxes[link]); $userBox.show(); } else { loader('Loading member in 7s...'); timer = win.setTimeout(function() { // Execute when timer reached win.console.log('[IC Enhancement Suite] :: Loading user : ' + link); loadMember(link); timer = null; ev = null; }, 7000); } } }); $body.on('mouseout', 'a', function() { if (timer) { win.clearTimeout(timer); ev = null; } loader(); }); // Userbox clicks $body.on('click', '#userBox .username', open_new); $body.on('click','.close-user-box', function() { $userBox.hide(); }); } function open_new() { $ic(this).target = '_blank'; if ($ic(this).prop('href')) { win.open($ic(this).prop('href')); } else if ($ic(this).prop('src')) { win.open($ic(this).prop('src')); } if (timer) { win.clearTimeout(timer); ev = null; } return false; } function switchOpenInNew() { if (opts.openInNew) { $body.on('click', '.online_box a', open_new); $body.on('click', '.featured_box a', open_new); $body.on('click', '.interest_box a', open_new); $body.on('click', 'a.username', open_new); $body.on('click', '.activity_widget a.activity_pic, .activity_widget .activity_description a:first-child', open_new); } else { $body.off('click', '.online_box a', open_new); $body.off('click', '.featured_box a', open_new); $body.off('click', '.interest_box a', open_new); $body.off('click', 'a.username', open_new); $body.off('click', '.activity_widget a.activity_pic, .activity_widget .activity_description a:first-child', open_new); } } switchOpenInNew(); function switchHideElements() { if (opts.hideEmptyMatches && $ic('.potential_match').find('.match').length === 1 && $ic('.potential_match').find('.match').first().hasClass('match-last')) { console.log('[IC Enhancement Suite] :: No matches, hiding box'); $ic('.potential_match').hide(); } else { $ic('.potential_match').show(); } $ic('.nearby-block.question').css('display', (opts.hideQuestionBlock ? 'none' : 'block')); $ic('.widget.tutorial-welcome').css('display', (opts.hideWelcomeForm ? 'none' : 'block')); $ic('.widget.invite-form').css('display', (opts.hideInviteForm ? 'none' : 'block')); } switchHideElements(); // Open fancybox images originals $body.on('click','.fancybox-image', open_new); // Add 'Search with google' link to popup images $body.on('mouseover', '.fancybox-image', function(event) { ev = event; if ($ic(this).attr('src') && $ic(this).parent().find('.google-link').length === 0) { var href = $ic(this).attr('src'); var link = $ic('<a class="google-link" href="http://www.google.com/searchbyimage?image_url=' + encodeURIComponent(href) +'" target="_blank">Search with google</a>'); $ic(this).parent().append(link); } }); // Enhance Dialog (Options screen) $ic('.navigation').append('<a href="#" class="ic_enhance_suite navigation-icon navigation_tip" title="InnerCircle Enhancement Suite"><img src=""/></a>'); var $enhDialog = $ic('<div id="enhancedialog" title="Enhancements" class="dialog tabs-dialog" />'); function createEnhanceDialog() { var dialogContent = '<div id="enhance_tabs" class="tabs-no-padding">\n'; for (var i = 0; i < optionLabels.length; i++) { var opt = optionLabels[i]; if (opt.enabled) { dialogContent += ' <input type="checkbox" class="option_check" data-option="' + opt.optionKey + '" id="' + opt.identifier + '" name="' + opt.identifier + '" ' + (opts[opt.optionKey] ? 'checked="checked"' : '') + '>\n'; dialogContent += ' <label for="' + opt.identifier + '" class="optional">' + opt.label + '</label>\n'; dialogContent += ' <div class="clear"></div>\n'; } } // SUBMIT dialogContent += ' <dt></dt>\n'; dialogContent += ' <a href="#" id="saveAndReloadOptions" class="button">Close</a>\n'; dialogContent += '</div>'; $enhDialog.html(dialogContent); } $body.append($enhDialog); $enhDialog.dialog({ closeOnEscape: true, modal: true, autoOpen: false, width: 400 }); $ic('a.ic_enhance_suite').on('click', function (e){ e.preventDefault(); createEnhanceDialog(); $enhDialog.dialog('open'); }); function saveForm() { opts = { version : version }; $ic('.option_check').each(function () { var key = $ic(this).data('option'); opts[key] = $ic(this).is(':checked'); }); saveSettings(); } $body.on('click', '.option_check',function (){ saveForm(); var option = $ic(this).data('option'); switch(option) { case 'nightMode': flipNightMode(); break; case 'openInNew': switchOpenInNew(); break; case 'hideEmptyMatches': case 'hideQuestionBlock': case 'hideWelcomeForm': case 'hideInviteForm': switchHideElements(); break; } }); $body.on('click', '#saveAndReloadOptions',function (e){ e.preventDefault(); saveForm(); $enhDialog.dialog('close'); }); // Fix the inplace editor for profile editing (Need to debug this further) $ic('.inplace_view').each(function (){ var $this = $ic(this); var html = $this.html(); $this.html(html.replace('\n','<br /><br />')); }); // Make wall pics clickable $body.on('click', '.wall-pic', function (e) { var $target = $ic(e.currentTarget); if ($target.hasClass('wall-pic')) { // get href var $link = $target.find('a').first(); if ($link.attr('href')) { win.open($link.attr('href')); } } }); // DEBUG win.console.log('[IC Enhancement Suite] :: Succesfully loaded Suite, version ' + version); } var ic_ScriptObject = document.createElement('script'); ic_ScriptObject.textContent = '(' + ic_FunctionWrapper.toString() + ')();'; document.body.appendChild(ic_ScriptObject);