Reddit - Load 'Continue this thread' inline

Changes 'Continue this thread' links to insert the linked comments into the current page

当前为 2015-07-16 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Reddit - Load 'Continue this thread' inline
  3. // @description Changes 'Continue this thread' links to insert the linked comments into the current page
  4. // @author James Skinner <spiralx@gmail.com> (http://github.com/spiralx)
  5. // @namespace http://spiralx.org/
  6. // @version 1.0.0
  7. // @icon 
  8. // @icon64 
  9. // @match *://*.reddit.com/r/*/comments/*
  10. // @grant GM_addStyle
  11. // @grant GM_getResourceText
  12. // @grant GM_getResourceURL
  13. // @run-at document-start
  14. // @resource spinner 
  15. // @resource expand 
  16. // @resource css data:text/css;utf8,.deepthread a { font-size: 0.9rem; min-height: 15px } .deepthread a img { display: inline-block; position: relative; top: 1px; margin-right: 4px; visibility: visible }
  17. // @require https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.js
  18. // @require https://greasyfork.org/scripts/7602-mutation-observer/code/mutation-observer.js
  19. // ==/UserScript==
  20.  
  21. /* jshint asi: true, esnext: true */
  22. /* global jQuery, MutationSummary, GM_addStyle, GM_getResourceText, GM_getResourceURL */
  23.  
  24. ; (function($) {
  25. 'use strict';
  26.  
  27. // --------------------------------------------------------------------
  28.  
  29. function processSummary(summary, options, func) {
  30. try {
  31. if (typeof options === 'function') {
  32. func = options
  33. options = {}
  34. }
  35. else if (typeof options === 'string') {
  36. options = { msg: options }
  37. }
  38.  
  39. if (options.msg) {
  40. console.info(options.msg, summary.added.length)
  41. }
  42.  
  43. func($(summary.added))
  44. }
  45. catch (ex) {
  46. console.error(ex)
  47. }
  48. }
  49.  
  50.  
  51. // --------------------------------------------------------------------
  52.  
  53. let observer = new MutationSummary({
  54. callback(summaries) {
  55. processSummary(summaries[0], 'Added %d continue links', processSpans)
  56. },
  57. rootNode: document.body,
  58. queries: [
  59. { element: 'span.deepthread' }
  60. ]
  61. })
  62.  
  63.  
  64. // --------------------------------------------------------------------
  65.  
  66. function processSpans($spans) {
  67. $spans
  68. .children('a')
  69. .prepend(`<img src="${GM_getResourceURL('expand')}">`)
  70. .one('click', continueThisThreadClicked)
  71. }
  72.  
  73.  
  74. function continueThisThreadClicked(event) {
  75. let $a = $(this),
  76. href = $a.prop('href'),
  77. $span = $a.parent()
  78.  
  79. // console.info(href)
  80.  
  81. $span
  82. .removeClass('deepthread')
  83. .html(`<img src="${GM_getResourceURL('spinner')}">`)
  84.  
  85. $.get(href, function(data) {
  86. let $page = $(data),
  87. $child = $('.nestedlisting > .comment > .child', $page)
  88.  
  89. $span
  90. .parentsUntil('.comment')
  91. .last()
  92. .replaceWith($child)
  93. })
  94.  
  95. return false
  96. }
  97.  
  98. GM_addStyle(GM_getResourceText('css'))
  99.  
  100. })(jQuery)
  101.  
  102. jQuery.noConflict()