사용자:Chugun/monobook.js
참고: 설정을 저장한 후에 바뀐 점을 확인하기 위해서는 브라우저의 캐시를 새로 고쳐야 합니다. 구글 크롬, 파이어폭스, 마이크로소프트 엣지, 사파리: ⇧ Shift 키를 누른 채 "새로 고침" 버튼을 클릭하십시오. 더 자세한 정보를 보려면 위키백과:캐시 무시하기 항목을 참고하십시오.
/*
*/
mw.loader.load('https://commons.wikimedia.org/w/index.php?title=MediaWiki:Gadget-contribsrange.js&action=raw&ctype=text/javascript');
if(!window.jkr2255)jkr2255={};
jkr2255.unWatchLink = "제거" ;
jkr2255.unWatchMessage = "주시 문서 목록을 새로 고침 하시겠습니까?";
mw.loader.load('https://ja.wikipedia.org/w/index.php?title=User:Jkr2255/unWatchList.js&action=raw&ctype=text/javascript');
/*
== 내 편집 이후의 변경 사항 ==
*/
document.write('<script type="text/javascript" src="'
+ 'http://en.wikipedia.org/w/index.php?title=Wikipedia:WikiProject_User_scripts/Scripts/Changes_since_I_last_edited'
+ '&action=raw&ctype=text/javascript&dontcountme=s"></script>');
/*
== [[:en:Wikipedia:WikiProject User scripts/Scripts/Add purge to tabs]] ==
서버 캐시를 새로 고치기 위한 purge 버튼 삽입
*/
document.write('<script type="text/javascript" src="'
+ 'http://en.wikipedia.org/w/index.php?title=Wikipedia:WikiProject_User_scripts/Scripts/Add_purge_to_tabs'
+ '&action=raw&ctype=text/javascript&dontcountme=s"></script>');
/*
== [[:en:Wikipedia:WikiProject_User_scripts/Scripts/Watchlist_since]] ==
주시 문서 목록에 '페이지 로드 이후의 바뀜' 삽입
*/
document.write('<script type="text/javascript" src="'
+ 'http://en.wikipedia.org/w/index.php?title=Wikipedia:WikiProject_User_scripts/Scripts/Watchlist_since'
+ '&action=raw&ctype=text/javascript&dontcountme=s"></script>');
var wikEdTranslations = {'ko': 'http://ko.wikipedia.org/w/index.php?title=User:IRTC1015/wikEd_international_ko.js&action=raw&ctype=text/javascript'};
document.write('<script type="text/javascript" src="http://en.wikipedia.org/w/index.php?action=raw&ctype=text/javascript&title=User:Cacycle/wikEd.user.js&dontcountme=s"></script>');
/* <pre><nowiki> */
/*
== Edittools ==
1차 출처는 [[mw:User:Alex Smotrov/edittools.js]], 2차 출처는 [[:en:MediaWiki:Edittools.js]], 3차 출처는 [[사용자:IRTC1015/customize.js]]
IRTC1015님이 편집하신 것을 내 입 맛에 맞게 수정.
*/
if (typeof (EditTools_set_focus) == 'undefined')
var EditTools_set_focus = true;
if (typeof (EditTools_set_focus_initially) == 'undefined')
var EditTools_set_focus_initially = EditTools_set_focus;
var EditTools =
{
charinsert : {
'Favorites': '<small>+</small> <br./> class=\"wikitable\" style=\"text-align:.center;\" style=\"text-align:.right;\" colspan=\"+\" rowspan=\"+\" <span.style=\"color:+;\">■</span> <span.style=\"color:+;\">●</span> <span.style=\"color:+;\"></span> {{JR.노선색|+}} {{일본.지하철.노선색|+}} {{일본.사철.노선색|+}} ŌōŪū ‘+’ {{·}}',
'Tonari': '{{인접정차역 |노선.=. |종별.=. |전역.=.[[+.역|]] |후역.=.[[+.역|]] |전방면.=.[[+.역|]].방면 |후방면.=.[[+.역|]].방면 |전색.=. |후색.=. {{인접정차역/열기}} {{인접정차역}} {{인접정차역/닫기|설명=+}} [[동일본.여객철도]] [[서일본.여객철도]] [[도쿄.지하철.(기업)|도쿄.메트로]] [[도쿄.지하철.선|+호선]] [[오사카.시.교통국.지하철.선|고속.전기.궤도.+호선]] <span.style=\"color:+;\">■</span> {{JR.노선색|+}} {{일본.지하철.노선색|+}} {{일본.사철.노선색|+}} {{·}}',
'Shapes': '○ ● ◎ □ ■ – — · … ‘+’ “+” 〈+〉 《+》 「+」 『+』 ° ″ ′ ≈ ≠ ≤ ≥ ± − × ÷ ← → § ~ | ¡¿†‡↔↑↓•¶ # ¹²³⁴₁₂₃₄½⅓⅔¼¾⅛⅜⅝⅞∞ «+» ¤₩฿₵¢₡₢$₫₯€₠₣ƒ₴₭₤ℳ₥₦№₧₰£៛₨₪৳₮₩¥ ♠♣♥♦ m² m³',
'Templates': '{\{+}} {\{풀기:+}} {\{\{+}}} {\{\{+|}}} | {\{!}} {\{-}} {\{Nobr}} {\{Nowrap.시작}} {\{Nowrap.끝}} {\{·}} {\{•}} [+] [\[+]] {\{기본정렬:+}} [\[분류:+]] #넘겨주기.[\[+]] <del>+</del> <u>+</u> <sup>+</sup> <sub>+</sub> <code>+</code> <blockquote>+</blockquote> <ref>+</ref> <references./> <onlyinclude>+</onlyinclude> <includeonly>+</includeonly> <noinclude>+</noinclude> <nowiki>+</nowiki> ',
'Alphabets': 'ÁáĆćÉéÍíĹĺŃńÓóŔশÚúÝýŹź ÀàÈèÌìÒòÙù ÂâĈĉÊêĜĝĤĥÎîĴĵÔôŜŝÛûŴŵŶŷ ÄäËëÏïÖöÜüŸÿ ß ÃãẼẽĨĩÑñÕõŨũỸỹ ÇçĢģĶķĻļŅņŖŗŞşŢţ Đ đ Ů ů ǍǎČčĎďĚěǏǐĽľŇňǑǒŘřŠšŤťǓǔŽž ĀāĒēĪīŌōŪūȲȳǢǣ ǖǘǚǜ ĂăĔĕĞğĬĭŎŏŬŭ ĊċĖėĠġİıŻż ĄąĘęĮįǪǫŲų ḌḍḤḥḶḷḸḹṂṃṆṇṚṛṜṝṢṣṬṭ Ł ł ŐőŰű Ŀ ŀ Ħ ħ ÐðÞþ Œ œ ÆæØøÅå Ə ə {\{Unicode|+}}',
'Kanji': '駅 鉄 桜 崎 戸 塚 学 関 楽 研 辺 塩 横 渋 蔵 営 浅 黒 区',
},
charinsertDivider : "\240",
extraCSS : '\
#specialchars {\
margin-top: 15px;\
border-width: 1px;\
border-style: solid;\
border-color: #aaaaaa;\
padding: 2px;\
}\
#specialchars a {\
}\
#specialchars a:hover {\
}\
',
appendExtraCSS : function ()
{
mw.util.addCSS(EditTools.extraCSS);
},
cookieName : 'edittoolscharsubset',
createEditTools : function (placeholder)
{
var box = document.createElement("div");
box.id = "specialchars";
box.title = '';
//append user-defined sets
if (window.charinsertCustom)
for (id in charinsertCustom)
if (EditTools.charinsert[id]) EditTools.charinsert[id] += ' ' + charinsertCustom[id];
else EditTools.charinsert[id] = charinsertCustom[id];
//create drop-down select
var prevSubset = 0, curSubset = 0;
var sel = document.createElement('select'), id;
for (id in EditTools.charinsert)
sel.options[sel.options.length] = new Option(id, id);
sel.selectedIndex = 0;
sel.style.cssFloat = sel.style.styleFloat = 'left';
sel.style.marginRight = '5px';
sel.title = '';
sel.onchange = sel.onkeyup = selectSubset;
box.appendChild(sel);
//create "recall" switch
if (window.editToolsRecall) {
var recall = document.createElement('span');
recall.appendChild(document.createTextNode('↕')); // ↔
recall.onclick = function () {
sel.selectedIndex = prevSubset;
selectSubset();
}
with (recall.style) { cssFloat = styleFloat = 'left'; marginRight = '5px'; cursor = 'pointer'; }
box.appendChild(recall);
}
// load latest selection from cookies
try {
var cookieRe = new RegExp ("(?:^|;)\\s*" + EditTools.cookieName + "=(\\d+)\\s*(?:;|$)");
var m = cookieRe.exec(document.cookie);
if (m && m.length > 1 && parseInt(m[1]) < sel.options.length)
sel.selectedIndex = parseInt(m[1]);
} catch (err) { /* ignore */ }
placeholder.parentNode.replaceChild(box, placeholder);
selectSubset();
return;
function selectSubset ()
{
//remember previous (for "recall" button)
prevSubset = curSubset;
curSubset = sel.selectedIndex;
//save into cookies for persistence
try {
var expires = new Date ();
expires.setTime( expires.getTime() + 30 * 24 * 60 * 60 * 1000 ); // + 30 days
document.cookie = EditTools.cookieName + "=" + curSubset + ";path=/;expires=" + expires.toUTCString();
} catch (err) { /* ignore */ }
//hide other subsets
var pp = box.getElementsByTagName('p') ;
for (var i=0; i<pp.length; i++)
pp[i].style.display = 'none';
//show/create current subset
var id = sel.options[curSubset].value;
var p = document.getElementById(id);
if (!p){
p = document.createElement('p');
p.id = id;
if (id == 'Arabic' || id == 'Hebrew'){ p.style.fontSize = '120%'; p.dir = 'rtl'; }
EditTools.createTokens(p, EditTools.charinsert[id]);
box.appendChild(p);
}
p.style.display = 'inline';
}
},
createTokens : function (paragraph, str)
{
var tokens = str.split(' '), token, i, n;
for (i = 0; i < tokens.length; i++) {
token = tokens[i];
n = token.indexOf('+');
if (token == '' || token == '_')
addText(EditTools.charinsertDivider + ' ');
else if (token == '\n')
paragraph.appendChild(document.createElement('br'));
else if (token == '___')
paragraph.appendChild(document.createElement('hr'));
else if (token.charAt(token.length-1) == ':') // : at the end means just text
addBold(token);
else if (n == 0) // +<tag> -> <tag>+</tag>
addLink(token.substring(1), '</' + token.substring(2), token.substring(1));
else if (n > 0) // <tag>+</tag>
addLink(token.substring(0,n), token.substring(n+1));
else if (token.length > 2 && token.charCodeAt(0) > 127) //a string of insertable characters
for (var j=0; j < token.length; j++) addLink(token.charAt(j), '');
else
addLink(token, '');
}
return;
function addLink (tagOpen, tagClose, name)
{
var a = document.createElement('a');
tagOpen = tagOpen.replace(/\./g,' ');
tagClose = tagClose ? tagClose.replace(/_/g,' ') : '';
name = name || tagOpen + tagClose;
name = name.replace(/\\n/g,'');
a.appendChild(document.createTextNode(name));
a.href = "javascript:insertTags('" + tagOpen + "','" + tagClose + "','')";
paragraph.appendChild(a);
addText(' ');
}
function addBold (text)
{
var b = document.createElement('b');
b.appendChild(document.createTextNode(text.replace(/_/g,' ')));
paragraph.appendChild(b);
addText(' ');
}
function addText (txt)
{
paragraph.appendChild(document.createTextNode(txt));
}
},
enableForAllFields : function ()
{
if (typeof (insertTags) != 'function' || window.WikEdInsertTags) return;
// insertTags from the site-wide /skins-1.5/common/edit.js just inserts in the first
// textarea in the document. Evidently, that's not good if we have multiple textareas.
// My first idea was to simply add a hidden textarea as the first one, and redefine
// insertTags such that it copied first the last active textareas contents over to that hidden
// field, set the cursor or selection there, let the standard insertTags do its thing, and
// then copy the hidden field's text, cursor position and selection back to the currently
// active field. Unfortunately, that is just as complex as simply copying the whole code
// from wikibits to here and let it work on the right text field in the first place.
var texts = document.getElementsByTagName ('textarea');
for (var i = 0; i < texts.length; i++) {
addHandler (texts[i], 'focus', EditTools.registerTextField);
}
// While we're at it, also enable it for input fields
texts = document.getElementsByTagName ('input');
for (var i = 0; i < texts.length; i++) {
if (texts[i].type == 'text') addHandler (texts[i], 'focus', EditTools.registerTextField);
}
insertTags = EditTools.insertTags; // Redefine the global insertTags
},
last_active_textfield : null,
registerTextField : function (evt)
{
var e = evt || window.event;
var node = e.target || e.srcElement;
if (!node) return;
EditTools.last_active_textfield = node.id;
return true;
},
getTextArea : function ()
{
var txtarea = null;
if (EditTools.last_active_textfield && EditTools.last_active_textfield != "")
txtarea = document.getElementById (EditTools.last_active_textfield);
if (!txtarea) {
// Fallback option: old behaviour
if (document.editform) {
txtarea = document.editform.wpTextbox1;
} else {
// Some alternate form? Take the first one we can find
txtarea = document.getElementsByTagName ('textarea');
if (txtarea.length > 0) txtarea = txtarea[0]; else txtarea = null;
}
}
return txtarea;
},
insertTags : function (tagOpen, tagClose, sampleText)
{
var txtarea = EditTools.getTextArea ();
if (!txtarea) return;
var selText, isSample = false;
function checkSelectedText ()
{
if (!selText) {
selText = sampleText; isSample = true;
} else if (selText.charAt (selText.length - 1) == ' ') { // Exclude ending space char
selText = selText.substring (0, selText.length - 1);
tagClose += ' ';
}
}
if (document.selection && document.selection.createRange) { // IE/Opera
// Save window scroll position
var winScroll = 0;
if (document.documentElement && document.documentElement.scrollTop)
winScroll = document.documentElement.scrollTop;
else if (document.body)
winScroll = document.body.scrollTop;
// Get current selection
txtarea.focus();
var range = document.selection.createRange();
selText = range.text;
// Insert tags
checkSelectedText ();
range.text = tagOpen + selText + tagClose;
// Mark sample text as selected
if (isSample && range.moveStart) {
if (window.opera) tagClose = tagClose.replace (/\n/g, "");
range.moveStart( 'character', - tagClose.length - selText.length);
range.moveEnd ('character', - tagClose.length);
}
range.select ();
// Restore window scroll position
if (document.documentElement && document.documentElement.scrollTop)
document.documentElement.scrollTop = winScroll;
else if (document.body)
document.body.scrollTop = winScroll;
} else if (txtarea.selectionStart || txtarea.selectionStart == '0') { // Mozilla
// Save textarea scroll position
var textScroll = txtarea.scrollTop;
// Get current selection
txtarea.focus();
var startPos = txtarea.selectionStart;
var endPos = txtarea.selectionEnd;
selText = txtarea.value.substring (startPos, endPos);
// Insert tags
checkSelectedText ();
txtarea.value = txtarea.value.substring (0, startPos)
+ tagOpen + selText + tagClose
+ txtarea.value.substring (endPos);
// Set new selection
if (isSample) {
txtarea.selectionStart = startPos + tagOpen.length;
txtarea.selectionEnd = startPos + tagOpen.length + selText.length;
} else {
txtarea.selectionStart = startPos + tagOpen.length + selText.length + tagClose.length;
txtarea.selectionEnd = txtarea.selectionStart;
}
// Restore textarea scroll position
txtarea.scrollTop = textScroll;
}
}, // end insertTags
setup : function ()
{
var placeholder = document.getElementById("specialchars");
if (!placeholder) return; // has this already been run once?
EditTools.appendExtraCSS ();
EditTools.createEditTools (placeholder);
EditTools.enableForAllFields ();
}
}; // end EditTools
// Do not use addOnloadHook; it runs *before* the onload event fires. At that time, onclick or
// onfocus handlers may not yet be set up properly.
hookEvent ('load', EditTools.setup);
/*
== [[위키백과:도구/편집요약 상용구]] ==
*/
esEditSummaries = new Array(
/*
new Array('버튼 이름', '입력될 편집 요약', '툴팁으로 뜨는 설명(생략 가능)', '사소한 편집 여부(0/1 혹은 true/false, 생략 가능)', '상용구 넣기 전에 요약 지우기(0/1 혹은 true/false, 생략 가능)')
위와 같은 형식으로 새로운 버튼을 추가할 수 있습니다.
마지막 줄을 제외한 줄 끝에 쉼표가 들어가 있는지 확인해 주세요.
*/
new Array('넘겨', '넘겨주기', '다른 문서로의 넘겨주기로 바꿈'),
new Array('삭신', '+ㅆ', '삭제 신청 틀을 담'),
new Array('정리', '정리', '문서의 모양 및 구성을 정리함'),
new Array('토막', '+ㅌ', '토막글 틀을 담'),
new Array('Rev', '[[Special:Contributions/|]]([[User talk:|토론]])의 편집을 [[User:|]]의 마지막 버전으로 되돌림', '되돌림'),
new Array('Bot', '손봇의 도움을 받아 동음이의어 처리', '손봇질')
);
/* modified version of [[MediaWiki:Gadget-UTCLiveClock.js]] --[[사용자:PuzzletChung|Puzzlet Chung]] ([[사용자토론:PuzzletChung|토론]]) 2010년 4월 14일 (수) 20:27 (KST) */
/* bolder 제거, millisecond 추가, monobook에 맞게 수정 */
function localLiveClock()
{
if (typeof(LiveClockConfig)=='undefined') LiveClockConfig = {};
var portletId = LiveClockConfig.portletId || 'p-personal';
var nextNode = LiveClockConfig.nextNodeId ? document.getElementById(LiveClockConfig.nextNodeId) : undefined;
localLiveClock.node = mw.util.addPortletLink( portletId, mw.config.get('wgServer') + mw.config.get('wgScriptPath') + '/index.php?title=' + encodeURIComponent(mw.config.get('wgPageName')) + '&action=purge', '', 'localdate', undefined, undefined, nextNode );
if( !localLiveClock.node ) return;
// not vector: if (skin !== "vector") { //Looks bad on vector
// localLiveClock.node.style.fontSize = 'larger';
//}
showLocalTime();
}
$(localLiveClock);
function showLocalTime()
{
var dateNode = localLiveClock.node;
if( !dateNode ) {
return;
}
var now = new Date();
var hh = now.getHours();
var mm = now.getMinutes();
var ss = now.getSeconds();
var ll = now.getMilliseconds();
var time = ( hh < 10 ? '0' + hh : hh ) + ':' + ( mm < 10 ? '0' + mm : mm ) + ':' + ( ss < 10 ? '0' + ss : ss ) + ':' + (ll < 100 ? ( ll < 10 ? '00' + ll : '0' + ll ) : ll );
dateNode.firstChild.replaceChild( document.createTextNode( time ), dateNode.firstChild.firstChild );
window.setTimeout(showLocalTime, 23);
}
/* </nowiki></pre> */