Rllmuk Put Edit Link Under Your Own Posts

Replace the Quote link under your own posts with an Edit link

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

You will need to install an extension such as Tampermonkey to install this script.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name        Rllmuk Put Edit Link Under Your Own Posts
// @description Replace the Quote link under your own posts with an Edit link
// @namespace   https://github.com/insin/greasemonkey/
// @version     5
// @match       https://rllmukforum.com/index.php?/topic/*
// @match       https://www.rllmukforum.com/index.php?/topic/*
// ==/UserScript==

void function TopicPage() {
  let $loggedInUserLink = document.querySelector('#elUserNav a.ipsUserPhoto')
  if (!$loggedInUserLink) {
    return
  }

  const POST_SELECTOR = 'article.ipsComment'
  const USER_ID_RE = /profile\/(\d+)/

  let currentUserId = USER_ID_RE.exec($loggedInUserLink.href)[1]

  function processPost($post) {
    let $userLink = $post.querySelector('.cAuthorPane_author a')
    let userId = USER_ID_RE.exec($userLink.href)[1]
    if (userId !== currentUserId) {
      return
    }
    let $quoteLink = $post.querySelector('a[data-action="quoteComment"]')
    let $editLink = $post.querySelector('a[data-action="editComment"], a[href$="&do=edit"]')
    $quoteLink.replaceWith($editLink.cloneNode(true))
  }

  function processPosts(context = document) {
    context.querySelectorAll(POST_SELECTOR).forEach(processPost)
  }

  // Process initial posts
  processPosts()

  // Watch for posts being replaced when paging
  new MutationObserver(mutations =>
    mutations.forEach(mutation => {
      if (mutation.oldValue == 'true') {
        processPosts()
      }
    })
  ).observe(document.querySelector('div.cTopic'), {
    attributes: true,
    attributeFilter: ['animating'],
    attributeOldValue: true,
  })

  // Watch for new posts being loaded into the current page
  new MutationObserver(mutations => {
    mutations.forEach(mutation =>
      mutation.addedNodes.forEach($addedNode => {
        if ($addedNode.matches(POST_SELECTOR)) {
          processPost($addedNode)
        }
      })
    )
  }).observe(document.querySelector('#elPostFeed > form'), {
    childList: true,
  })
}()