Warning: fopen(/www/sites/update.greasyfork.icu/index/store/temp/4c4efdc23173aefdf58d13ed51a6b5a2.js): failed to open stream: No space left on device in /www/sites/update.greasyfork.icu/index/scriptControl.php on line 65
// ==UserScript==
// @name 네이버 카페 게시물 실제 아이디 클립보드 복사
// @namespace 네이버 카페 게시물 실제 아이디 클립보드 복사
// @grant GM_setClipboard
// @match *://*cafe.naver.com/*
// @exclude *://cafe.naver.com/ca-fe/*
// @version 0.5
// @description 네이버 카페 게시물의 작성자 아이디를 버튼을 통해 클립보드로 복사하고, 복사된 아이디를 표시합니다. 닉네임 옆에 "(아이디)" 텍스트를 추가합니다. 블로그 가기 버튼과 블로그 구독 버튼을 추가하고 아이콘을 표시합니다.
// @icon 
// @author mickey90427
// @downloadURL https://update.greasyfork.icu/scripts/468224/%EB%84%A4%EC%9D%B4%EB%B2%84%20%EC%B9%B4%ED%8E%98%20%EA%B2%8C%EC%8B%9C%EB%AC%BC%20%EC%8B%A4%EC%A0%9C%20%EC%95%84%EC%9D%B4%EB%94%94%20%ED%81%B4%EB%A6%BD%EB%B3%B4%EB%93%9C%20%EB%B3%B5%EC%82%AC.user.js
// @updateURL https://update.greasyfork.icu/scripts/468224/%EB%84%A4%EC%9D%B4%EB%B2%84%20%EC%B9%B4%ED%8E%98%20%EA%B2%8C%EC%8B%9C%EB%AC%BC%20%EC%8B%A4%EC%A0%9C%20%EC%95%84%EC%9D%B4%EB%94%94%20%ED%81%B4%EB%A6%BD%EB%B3%B4%EB%93%9C%20%EB%B3%B5%EC%82%AC.meta.js
// ==/UserScript==
(function () {
// 버튼 클릭 시 아이디 복사 함수
function copyWriterId() {
const writerId = this.getAttribute('data-writer-id');
GM_setClipboard(writerId);
showCopiedText(writerId);
}
// '블로그 가기' 버튼 클릭 시 블로그로 이동하는 함수
function goToBlog() {
const writerId = this.getAttribute('data-writer-id');
const blogUrl = `https://blog.naver.com/${writerId}`;
window.open(blogUrl, '_blank');
}
// '블로그 구독' 버튼 클릭 시 블로그 구독 주소를 열어주는 함수
function subscribeToBlog() {
const writerId = this.getAttribute('data-writer-id');
const rssUrl = `https://rss.blog.naver.com/${writerId}.xml`;
window.open(rssUrl, '_blank');
}
// 이메일 복사 함수
function copyWriterEmail() {
const writerId = this.getAttribute('data-writer-id');
const email = `${writerId}@naver.com`;
GM_setClipboard(email);
showCopiedText(email);
}
// 복사된 아이디 표시 함수
function showCopiedText(writerId) {
const textElement = document.createElement('div');
textElement.className = 'copied-text';
textElement.textContent = `복사됨 : ${writerId}`;
document.querySelector('.article_info').appendChild(textElement);
setTimeout(() => {
textElement.remove();
}, 1000);
}
// MutationObserver 콜백 함수
function observeMutation(mutations) {
mutations.forEach((mutation) => {
// 노드 추가일 경우
if (mutation.type === 'childList' && mutation.addedNodes.length > 0) {
const addedNode = mutation.addedNodes[0];
// 추가된 노드가 작성자 정보 버튼을 포함하고 있는지 확인
if (addedNode.querySelector('.article_header')) {
const writerInfoButton = addedNode.querySelector('[id^="writerInfo"]');
const writerId = writerInfoButton.id.replace("writerInfo", "");
// 버튼 추가
const nickLevelElement = addedNode.querySelector('.nick_level');
const button = document.createElement('button');
button.className = 'copy-button';
button.innerHTML = `
아이디 복사
`;
button.setAttribute('data-writer-id', writerId);
button.addEventListener('click', copyWriterId);
const emailButton = document.createElement('button');
emailButton.className = 'email-button';
emailButton.innerHTML = `
이메일 복사
`;
emailButton.setAttribute('data-writer-id', writerId);
emailButton.addEventListener('click', copyWriterEmail);
const blogButton = document.createElement('button');
blogButton.className = 'blog-button';
blogButton.innerHTML = `
블로그 가기
`;
blogButton.setAttribute('data-writer-id', writerId);
blogButton.addEventListener('click', goToBlog);
const subscribeButton = document.createElement('button');
subscribeButton.className = 'subscribe-button';
subscribeButton.innerHTML = `
블로그 구독
`;
subscribeButton.setAttribute('data-writer-id', writerId);
subscribeButton.addEventListener('click', subscribeToBlog);
// 버튼을 담을 컨테이너 추가
const buttonContainer = document.createElement('div');
buttonContainer.className = 'button-container';
buttonContainer.appendChild(button);
buttonContainer.appendChild(emailButton);
buttonContainer.appendChild(blogButton);
buttonContainer.appendChild(subscribeButton);
nickLevelElement.insertAdjacentElement('afterend', buttonContainer);
// 닉네임 수정
const nicknameButton = addedNode.querySelector('.nickname');
const nicknameText = nicknameButton.textContent.trim();
nicknameButton.textContent = `${nicknameText} (${writerId})`;
// 스타일 수정
buttonContainer.style.marginLeft = '0px';
nicknameButton.style.marginRight = '0px';
nicknameButton.style.paddingRight = '0px';
}
}
});
}
// 스타일 추가
const style = document.createElement('style');
style.textContent = `
.copy-button, .email-button, .blog-button, .subscribe-button {
display: inline-flex;
align-items: center;
font-size: 12px;
font-weight: bold;
padding: 2px 6px;
border-radius: 4px;
color: #fff;
border: none;
cursor: pointer;
transition: background-color 0.3s;
margin: 0 2px;
}
.copy-button {
background-color: #4CAF50;
}
.copy-button:hover {
background-color: #45A049;
}
.email-button {
background-color: #2196F3;
}
.email-button:hover {
background-color: #1E88E5;
}
.blog-button {
background-color: #FF9800;
}
.blog-button:hover {
background-color: #F57C00;
}
.subscribe-button {
background-color: #FF5722;
}
.subscribe-button:hover {
background-color: #F4511E;
}
.copy-icon, .email-icon, .blog-icon, .rss-icon {
width: 16px;
height: 16px;
fill: currentColor;
margin-right: 4px;
}
.copied-text {
margin-top: 8px;
font-size: 12px;
color: #666;
}
`;
document.head.appendChild(style);
// MutationObserver 생성
const observer = new MutationObserver(observeMutation);
observer.observe(document.body, {
childList: true,
subtree: true,
});
})();