위키낱말사전:JavaScript & CSS
이 문서는 한국어 위키낱말사전에 쓰이는 다음의 자바스크립트 및 포맷에 관한 문제점 및 개선책을 위해 마련되었습니다. «Monobook»은 화면 구성을 위하여 쓰이는데, 사용자의 취향에 따라 바꿀 수 있습니다. 반면에 «Common»은 한국어 위키낱말사전의 모든 사용자에게 적용됩니다.
p-cactions
- MediaWiki:Monobook.css
- 화면 맨 위의 위키낱말사전, 토론, 편집... 따위를 나타내는 칸.
#p-cactions li { padding-top: 2px !important; background-color: #F1F1F1; } #p-cactions li.selected a { padding-top: 2px !important; background-color: #EEEEEE; }
- 문제점: 웹브라우저에 따라 달리 나타나며 칸의 크기 조절이 까다롭다.
#p-cactions li a -> #p-cactions li {...} --아흔(A-heun) 2008년 4월 19일 (토) 09:10 (UTC)
category pages
- MediaWiki:Common.css
- '분류'가 카테고리 페이지 첫머리에 나타나지 않도록 제거.
- 참조: 미디어위키 메시지
.ns-14 * h1.firstHeading { display: none !important; }
- 잘못된 스크립트: «.ns-15»을 같이 넣어서는 안된다.
InterProject
- MediaWiki:Common.js
- 위키프로젝트(백과, 책, 공용)으로 링크시키기
- 아래의 영어 위키낱말사전의 스크립트는 완벽하지 않은 것으로 보인다.
function Projectlinks() { var elements = new Array(); var spans = document.getElementsByTagName('span'); // filter for projectlinks for (var i=0, j=0; i<spans.length; i++) { if (spans[i].className == 'interProject') { elements[j] = spans[i].getElementsByTagName('a')[0]; j++; } } // sort alphabetically function sortbylabel(a,b) { // get labels a = a.innerHTML.replace(/^.*<a[^>]*>(.*)<\/a>.*$/i,'$1'); b = b.innerHTML.replace(/^.*<a[^>]*>(.*)<\/a>.*$/i,'$1'); // return sort order if (a < b) return -1; if (a > b) return 1; return 0; } elements.sort(sortbylabel); // create navbox var sidebar_style = "background-color: #FFFFFC; color: #000000; font-size: 10pt;"; var links_description = "위키백과에 수록된 낱말"; if (j) { var plheader = document.createElement('h5'); plheader.appendChild(document.createTextNode('위키 프로젝트')); var plbox = document.createElement('div'); plbox.setAttribute('class','pBody'); plbox.setAttribute("title", links_description); var pllist = document.createElement('ul'); for (var i=0; i<elements.length; i++) { var plitem = document.createElement('li'); plitem.appendChild(elements[i]); pllist.appendChild(plitem); } plbox.appendChild(plheader); plbox.appendChild(pllist); plbox.setAttribute("style", sidebar_style); document.getElementById("p-tb").appendChild(plbox); } } addOnloadHook(Projectlinks);
- 아래의 스크립트는 독일어 낱말사전 (참조: Bug 708)
function $(ID) { return document.getElementById(ID); } document.write('<style type="text/css">#interProject, #sisterProjects {display: none; speak: none;} #p-tb .pBody {padding-right: 0;}<\/style>'); function iProject() { if ($("interProject")) { var iProject = $("interProject").innerHTML; var interProject = document.createElement("div"); var interProjectstyle = "margin-top: .1em; background-color:#006398;; font-size:10pt;"; var interProjectdescription = "위키프로젝트의 낱말로 인터 링크 시키기" interProject.setAttribute("style", interProjectstyle) interProject.setAttribute("title", interProjectdescription) interProject.innerHTML = '<h5>위키 프로젝트<a href="/wiki/위키낱말사전:위키 프로젝트"><\/a><\/h5><div class="pBody" style = "background-color:#EEF9FF; font-size:10pt;">'+iProject+'<\/div>'; $("p-tb").appendChild(interProject); } } addOnloadHook(iProject);
- 문제점: 등록 사용자와 비등록 사용자에 따라 링크가 화면에 보이기도 하고 안 보이기도 한다. 이 경우에는 캐시에 문제가 있기 때문이며 대개 몇일 뒤에 이 문제가 사라진다.
- 태그 <a href="/wiki/위키낱말사전:위키 프로젝트"></a>는 portlet 색깔 때문에 달리 조정.
- 보기: 한국어, Korean --아흔(A-heun) 2008년 4월 19일 (토) 09:58 (UTC)
자유게시판 바탕색
다음 스크립은 토론 페이지인 자유게시판의 바탕색을 토론 문서 바탕색인 연노랑으로 바꿉니다.
function WiktionaryTalkpage() { if(document.title.search && (document.title.search("위키낱말사전:자유게시판") != -1 )) document.body.className = "ns-1"; } addOnloadHook(WiktionaryTalkpage);
Pagecounter.js
- Programmer: w:de:User:LeonWeber
- 수록된 문서를 편집자가 검토하였는지 점검하는 스크립.
var disable_counter = 0; var counter_factor = 500; function pgcounter_setup() { if(disable_counter == 0) { var url = window.location.href; if(Math.floor(Math.random()*counter_factor)==42) // the probability thing { if(wgIsArticle==true || wgArticleId==0) { var pgcountNs = wgCanonicalNamespace; if(wgCanonicalNamespace=="") { pgcountNs = "0"; } var cnt_url = "http://pgcount.wikimedia.de/index.png?ns=" + pgcountNs + "&title=" + encodeURI(wgTitle) + "&factor=" + counter_factor + "&wiki=dewiki"; var img = new Image(); img.src = cnt_url; } } } } pgcounter_setup();
h1.firstHeading display none
body.page-위키낱말사전_대문 h1.firstHeading { display: none !important; } body.page-위키낱말사전_자유게시판 h1.firstHeading { display: none !important; }
« 위키낱말사전_자유게시판 »은 이 트릭이 통하지 않는 것으로 보인다. --아흔(A-heun) (토론) 2008년 8월 15일 (금) 12:35 (UTC)
/* 대문 제목 숨기기 */ var mpTitle = "위키낱말사전:대문"; var isMainPage = (document.title.substr(0, document.title.lastIndexOf(" - ")) == mpTitle); var isDiff = (document.location.search && (document.location.search.indexOf("diff=") != -1 || document.location.search.indexOf("oldid=") != -1)); if (isMainPage && !isDiff) { document.write('<style type="text/css">/*<![CDATA[*/ #lastmod, #siteSub, #contentSub, h1.firstHeading { display: none !important; } /*]]>*/</style>'); } /* 자유게시판 제목 숨기기 */ var bbTitle = "위키낱말사전:자유게시판"; var isBulletinboard = (document.title.substr(0, document.title.lastIndexOf(" - ")) == bbTitle); var isDiff = (document.location.search && (document.location.search.indexOf("diff=") != -1 || document.location.search.indexOf("oldid=") != -1)); if (isBulletinboard && !isDiff) { document.write('<style type="text/css">/*<![CDATA[*/ #lastmod, #siteSub, #contentSub, h1.firstHeading { display: none !important; } /*]]>*/</style>'); }
- 다른 트릭 (현재)
function WiktionaryTalkpage() { if(document.title.search && (document.title.search("위키낱말사전:자유게시판") != -1 || document.title.search("위키낱말사전:게시판") != -1 || document.title.search("위키낱말사전:한글 맷돌") != -1)) { document.body.className = "ns-1"; document.write('<style type="text/css">/*<![CDATA[*/ #lastmod, #siteSub, #contentSub, h1.firstHeading { display: none !important; } /*]]>*/</style>'); } } addOnloadHook(WiktionaryTalkpage);
Pdf 파일에 icon 붙이기
- 영어 위키백과 w:en:MediaWiki:Common.css
- 필요할 경우 MediaWiki:Common.css에 추가. --아흔(A-heun) (토론) 2008년 8월 15일 (금) 12:44 (UTC)
#bodyContent a[href$=".pdf"].external, #bodyContent a[href*=".pdf?"].external, #bodyContent a[href*=".pdf#"].external, #bodyContent a[href$=".PDF"].external, #bodyContent a[href*=".PDF?"].external, #bodyContent a[href*=".PDF#"].external { background: url(http://upload.wikimedia.org/wikipedia/commons/thumb/2/23/Icons-mini-file_acrobat.gif/15px-Icons-mini-file_acrobat.gif) center right no-repeat; padding-right: 1em; }
IP 방문자 설문 조사
- 이 스크립은 현재 영어, 독일어, 이탈리아어 낱말사전에서 실험 중
- 목적은 IP 방문자에게 낱말사전에 수록된 문서의 질에 대한 설문 조사
- 독일어 낱말사전의 스크립은 IP 방문자와 등록 사용자를 세분화 시킨 것
var fb_comment_url = wgScript+ "?title=Wiktionary:Feedback"+ "&action=edit§ion=new"+ "&preload=Wiktionary:Feedback%2Fpreload"+ "&editintro=Wiktionary:Feedback%2Fintro"+ "&preloadtitle="+ encodeURIComponent("[[:"+wgPageName.replace('_', ' ')+"]]"); var pn= wgPageName.replace(/_/g,' '); var fb_thanks = "감사합니다!"; // 감사의 말 var fb_comment = "의견이 있으세요?"; // 댓글 var fb_questions = new Array(); fb_questions[0] = ["이 낱말의 내용은", ['우수한 편', '괜찮은 편', '부족한 편', '틀린 점이 있음', '나쁜 편',] // 추가 질문 가능 ]; var fb_options; var fb_text; var fb_sent = false; var fb_sent2= false; function fb_init(){ var index = Math.floor(Math.random()*(fb_questions.length)); fb_text = fb_questions[index][0]; fb_options = fb_questions[index][1]; fb_buildBox(); } function fb_buildBox(){ var sidebar = document.getElementById('column-one'); if(!sidebar) return false; var list = newNode('ul',{'id':'fb_list'}); for(var i=0;i<fb_options.length;i++){ list.appendChild( newNode('li', newNode('a',{'click':fb_click,'id':""+i},fb_options[i]) ) ); } sidebar.insertBefore( newNode('div',{'class':"portlet",'id':"p-feedb"}, newNode('a',{'name':"feedback"}), newNode('h5',"feedback"), newNode('div',{'class':"pBody"}, newNode('p',{'style':'font-size: 90%'},fb_text), list, newNode('p',{'style':'font-size: 80%'}, newNode('a',{'href':fb_comment_url},fb_comment) ) ) ), document.getElementById('p-search').nextSibling ); } $(fb_init); function fb_click(e){ var fb = false; var fbi = false; try{ fb = e.target.childNodes[0].nodeValue; fbi = e.target.getAttribute('id'); }catch(e){ try{ fb = window.event.srcElement.childNodes[0].nodeValue; fbi = window.event.srcElement.getAttribute('id'); } catch(e){ }} if(fb){ fb_send(fb); fb_send2(fb,fbi); } var list = document.getElementById('fb_list'); list.parentNode.insertBefore( newNode('p',fb_thanks),list ); list.parentNode.removeChild(list); return false; } //Send to ~cmackenzie -> 서버에서 설문 집계 function fb_send(string){ if(fb_sent) return false; fb_sent=true; var wiki = wgServer.replace(/https?:\/\/([^\.]*)\.([^\.]*)\.org/,"$1$2").replace(/pedia$/,''); var page = wgPageName; if(wgPageName == 'Special:Search'){ var sb = document.getElementById('lsearchbox'); if(sb) page+='/'+sb.value; } var url = "http://tools.wikimedia.de/~cmackenzie/feedback.php"+ "?fb_wiki="+wiki+ "&fb_page="+encodeURI(page)+ "&fb_revid="+encodeURI(wgCurRevisionId)+ "&fb_comment="+encodeURI(string); document.body.appendChild( newNode('iframe',{'src':url,'style':'display:none'}) ); } //Send to ~daveross -> 서버에서 설문 집계 function fb_send2(string,indx){ if(fb_sent2) return false; fb_sent2 =true; var lang = wgServer.replace(/^https?:\/\/([^\.]*).*$/,"$1"); var wiki = wgServer.replace(/https?:\/\/[^\.]*\.([^\.]*)\.org/,"$1"); var page = wgPageName; if(wgPageName == 'Special:Search'){ var sb = document.getElementById('lsearchbox'); if(sb) page+='/'+sb.value; } var url = 'http://tools.wikimedia.de/~daveross/feedback.php' + '?mode=submit' + '&lang='+encodeURI(lang) + '&wiki='+encodeURI(wiki) + '&page='+encodeURI(page) + '&revid='+encodeURI(wgCurRevisionId) + '&comment='+encodeURI(string) + '&comment_index='+encodeURI(indx*1+1); document.body.appendChild( newNode('iframe',{'src':url,'style':'display:none'}) ); } /* DOM abbreviation function */ function newNode(tagname){ var node = document.createElement(tagname); for( var i=1;i<arguments.length;i++ ){ if(typeof arguments[i] == 'string'){ //Text node.appendChild( document.createTextNode(arguments[i]) ); }else if(typeof arguments[i] == 'object'){ if(arguments[i].nodeName){ //If it is a DOM Node node.appendChild(arguments[i]); }else{ //Attributes (hopefully) for(var j in arguments[i]){ if(j == 'class'){ //Classname different because... node.className = arguments[i][j]; }else if(j == 'style'){ //Style is special node.style.cssText = arguments[i][j]; }else if(typeof arguments[i][j] == 'function'){ //Basic event handlers try{ node.addEventListener(j,arguments[i][j],false); //W3C }catch(e){try{ node.attachEvent('on'+j,arguments[i][j],"Language"); //MSIE }catch(e){ node['on'+j]=arguments[i][j]; }}; //Legacy }else{ node.setAttribute(j,arguments[i][j]); //Normal attributes } } } } } return node; }
검토 버전
- «검토 버전 (Stable versions)»은 현재 독일어 위키백과에서 전면적으로 실시하고 있다. 독일어 위키낱말사전은 자바 스크립으로 실험 중.
- 문제점: 스크립을 쓰지 않고 서버에서 관리가 되도록 하기 위해서는 MediaZilla에 신청하여 허가를 받아야 한다.
--아흔(A-heun) (토론) 2008년 8월 15일 (금) 13:36 (UTC)
Portlet Links
- 프로그래머: 미상
- Mediawiki:Common.js (필요하면 추가)
- Portlet 을 나름대로 바꾸고자 할 때
function addPortletLink(portlet, href, text, id, tooltip, accesskey, nextnode) { var node = document.getElementById(portlet); if ( !node ) return null; node = node.getElementsByTagName( "ul" )[0]; if ( !node ) return null; var link = document.createElement( "a" ); link.appendChild( document.createTextNode( text ) ); link.href = href; var item = document.createElement( "li" ); item.appendChild( link ); if ( id ) item.id = id; if ( accesskey ) { link.setAttribute( "accesskey", accesskey ); tooltip += " ["+accesskey+"]"; } if ( tooltip ) { link.setAttribute( "title", tooltip ); } if ( accesskey && tooltip ) { updateTooltipAccessKeys( new Array( link ) ); } if ( nextnode && nextnode.parentNode == node ) node.insertBefore( item, nextnode ); else node.appendChild( item ); return item; }
Searchbox
- Mediawiki:Common.css (필요하면 추가)
- 찾기 상자의 버튼 조절
#search-box .searchboxGoButton { display: none; } #search-box .searchboxSearchButton { position: relative; left: -5px; } #search-box table { background-color: transparent; }
Imagemap inline
- Mediawiki:common.css
- 문제점1: 그림에 링크를 거는 태그 «Imagemap»을 쓸 경우 같은 줄에 글을 계속 쓸 수가 없다. 때문에 «.imagemap-inline »으로 이 문제를 해결한다. 결과가 그리 신통치 않은 것으로 보인다.
- 문제점2: Imagemap을 쓸 경우 «position: absolute»를 제외하고 layer 조절이 불가능하다.