@-posting

Link to posts in the same 4chan thread with "@".

이 스크립트를 설치하려면 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		@-posting
// @version		0.7.0.0
// @namespace	atposting
// @license		WTFPL
// @include		*://boards.4chan.org/*
// @run-at		document-end
// @grant		none
// @description Link to posts in the same 4chan thread with "@".
// ==/UserScript==

var updateTextChildren = function(node, callback) {
	for (var i = 0; i < node.childNodes.length; i++) {
		var cn = node.childNodes[i];
		if (cn.nodeType === 3) {
			callback(cn);
		};
	};
}

var twitterify = function(targets) {
	Array.prototype.forEach.call(targets, function(target) {
		updateTextChildren(target, function(x) {
			var html = x.nodeValue.replace(
				/#([a-zA-Z]+)/g,
				'<a href="https://archive.rebeccablacktech.com/g/?task=search&search_text=%23$1">#$1</a>'
			).replace(
				/@([0-9]+)/g,
				'<a href="#p$1" class="quotelink">@$1</a>'
			).replace(
				/Dear ([0-9]+)/g,
				'Dear <a href="#p$1" class="quotelink">$1</a>'
			);
			var span = document.createElement("span");
			span.innerHTML = html;
			x.parentNode.replaceChild(span, x);
		});
	});
};

var observer = new MutationObserver(function(mutations) {
	mutations.forEach(function(mutation) {
		twitterify(mutation.addedNodes);
	});
});

observer.observe(document.querySelector('.board .thread'), { attributes: true, childList: true });
twitterify(document.querySelectorAll('.postMessage'));