您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Changes 'Continue this thread' links to insert the linked comments into the current page
当前为
- // ==UserScript==
- // @name Reddit - Load 'Continue this thread' inline
- // @description Changes 'Continue this thread' links to insert the linked comments into the current page
- // @author James Skinner <spiralx@gmail.com> (http://github.com/spiralx)
- // @namespace http://spiralx.org/
- // @version 1.2.0
- // @icon 
- // @icon64 
- // @match *://*.reddit.com/r/*/comments/*
- // @grant GM_addStyle
- // @grant GM_getResourceURL
- // @run-at document-end
- // @resource expand 
- // @require https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.js
- // @require https://greasyfork.org/scripts/7602-mutation-observer/code/mutation-observer.js
- // ==/UserScript==
- /* jshint asi: true, esnext: true */
- /* global jQuery, MutationSummary, GM_addStyle, GM_getResourceURL */
- ; (function($) {
- 'use strict';
- // --------------------------------------------------------------------
- const units = (v, s) => `${v}${s}`
- $.fn.spinner = function(options) {
- options = Object.assign({}, $.fn.spinner.defaults, options)
- const $spinner = $('<div class="pulsar-horizontal"></div>')
- .css({
- padding: units(options.size * 0.25, 'px'),
- height: units(options.size, 'px')
- })
- const total_duration = (options.steps + 1) * options.step_duration
- for (let i = 0; i < options.steps; i++) {
- const delay = i * options.step_duration
- $('<div></div>')
- .css({
- width: units(options.size, 'px'),
- height: units(options.size, 'px'),
- backgroundColor: options.colour,
- animationDuration: units(total_duration, 's'),
- animationDelay: units(delay, 's')
- })
- .appendTo($spinner)
- }
- if (options.replace) {
- this.empty()
- }
- return this.append($spinner)
- }
- $.fn.spinner.defaults = {
- replace: false,
- steps: 3,
- size: 16,
- colour: 'white',
- step_duration: 0.4
- }
- // --------------------------------------------------------------------
- function processSpans($spans) {
- $spans.children('a')
- .one('click', continueThisThreadClicked)
- $spans.parent()
- .css('padding', '0px')
- $spans.prev()
- .remove()
- }
- function continueThisThreadClicked(event) {
- /* jshint -W040 */
- this.hostname = location.hostname
- let $a = $(this),
- href = this.href,
- $target = $a.parent()
- $target.spinner({ colour: '#28f', size: 24, step_duration: 0.25, replace: true })
- $.get(href, function(data) {
- const $child = $('.nestedlisting > .comment > .child', $(data))
- .css('margin-left', '0px')
- $target
- .parentsUntil('.child')
- .replaceWith($child)
- })
- return false
- }
- // --------------------------------------------------------------------
- const observer = new MutationSummary({
- callback(summaries) {
- let $spans = $(summaries[0].added)
- // console.log(`Added ${$spans.length} spans`)
- processSpans($spans)
- },
- rootNode: document.body,
- queries: [
- { element: 'span.deepthread' }
- ]
- })
- processSpans($('span.deepthread')) // To process spans in the HTML source
- // --------------------------------------------------------------------
- GM_addStyle(`
- .deepthread {
- display: block;
- padding: 0;
- }
- .deepthread:after {
- visibility: hidden;
- }
- .deepthread a {
- display: inline-block;
- background: transparent url(${GM_getResourceURL('expand')}) no-repeat center left;
- padding-left: 36px;
- height: 40px;
- line-height: 40px;
- font-size: 1.4rem;
- vertical-align: middle;
- }
- .pulsar-horizontal {
- display: inline-block;
- }
- .pulsar-horizontal > div {
- display: inline-block;
- border-radius: 100%;
- animation-name: pulsing;
- animation-timing-function: ease-in-out;
- animation-iteration-count: infinite;
- animation-fill-mode: both;
- }
- @keyframes pulsing {
- 0%, 100% {
- transform: scale(0);
- opacity: 0.5;
- }
- 50% {
- transform: scale(1);
- opacity: 1;
- }
- }
- `)
- })(jQuery)
- jQuery.noConflict()