로그인하고 있지 않습니다. 편집하면 당신의 IP 주소가 공개적으로 기록됩니다. 계정을 만들고 로그인하면 편집 시 사용자 이름만 보이며, 위키 이용에 여러 가지 편의가 주어집니다.스팸 방지 검사입니다. 이것을 입력하지 마세요!=== 리버티 스킨용 사용자 정의 내비게이션 바 === 리버티 스킨에서 기존의 아이콘을 제거하거나 새로운 아이콘을 추가할 수 있습니다. 아래 스크립트는 드롭다운 메뉴나 내비게이션 바의 링크만 추가할 수 있으며, 드롭다운 메뉴 자체를 추가하는 기능은 추후 작성할 예정입니다. {{{icon|[[파일:Ambox warning pn.svg|25px]]}}} 이 스크립트는 현재 고정된 URL만 정의할 수 있습니다. 랜덤 한자 문서처럼 URL이 랜덤으로 변동하는 것을 지원하려면 스크립트를 별도로 작성하셔야 합니다. [[사:하늘/custom-navbar.js]] 파일을 참조하시면 됩니다. 이 스크립트를 실행시키기 위해서는 JSON 파일이 필요합니다. 우선 [[특수:내사용자문서/custom-navbar-data.json]] 파일을 아래와 같은 형식으로 작성합니다. JSON 파일이기에 주석은 사용할 수 없다는 점에 유의해주세요. {{숨김 시작|title= 리버티 스킨용 사용자 정의 내비게이션 바 JSON 데이터 파일 예시|bg=#eee}} <syntaxhighlight lang="json"> { "explanation" : { "addList 양식" : "[(font-awesome 아이콘 클래스명), (표시될 링크 이름), (링크 주소), (링크 타이틀-title) ]", "dropList" : "기존에 있는 삭제할 링크 목록", "addList" : "추가할 메뉴 목록", "addDropdown": "추가할 드랍다운 메뉴 목록 (현재 미지원)" }, "dropList": ["map", "menuWatch"], "addList": { "user" : [ ["fa-star", " 공작실 ", "/wiki/사용자:Utolee90/공작실", "내 작업물"], ["fa-font", " 영한사전 ", "/wiki/시리즈:모두의 영한사전", ""] ], "board": [ ["fa-globe", " 큰숲백과 ", "https://bigforest.miraheze.org/", "큰숲백과"] ], "tools": [], "help": [ ["fa-code", "사용자 JS", "/wiki/도움말:사용자 자바스크립트", "사용자 자바스크립트 도움말"], ["fa-code", "사용자 CSS", "/wiki/도움말:사용자 CSS", "사용자 CSS 도움말"] ], "new": [ ["fa-file", "큰숲백과 문서", "/wiki/큰숲백과", "큰숲백과 문서"] ] }, "addDropdown": { "head": [], "navList": [] } } </syntaxhighlight> {{숨김 끝}} 다음에 아래 코드를 [[특수:내사용자문서/liberty.js]]에 집어넣으면 작동이 완료됩니다. <syntaxhighlight lang="javascript"> /* 리버티 스킨 네비게이션 사용자 아이콘 */ mw.loader.load('//librewiki.net/index.php?title=사용자:Utolee90/custom-navbar.js&action=raw&ctype=text/javascript'); </syntaxhighlight> 아래는 이 스크립트의 원본입니다. {{숨김 시작|title= 리버티 스킨용 사용자 정의 내비게이션 바 자바스크립트 부분|bg=#eee}} <syntaxhighlight lang="javascript"> // 원본 : 사용자:하늘/custom-navbar.js, 수정 : 사용자:Utolee90 // custom-navbar-data 불러오기 -> navBarData 형식으로 값이 호출됨. var dataPageName = "User:" + mw.config.get().wgUserName + "/custom-navbar-data.json"; // custom-navbar-data 파일이름 // json 파일 RAW 데이터를 얻기 위해서 필요 function getRaw(title) { var raw; $.ajax({ async: false, url: location.origin + mw.util.getUrl(title || mw.title, { action: 'raw' }), success: function (data) { raw = data; } }); return raw; } // 아이템 추가 var libreNavLogin = {}; // json 파일 파싱 libreNavLogin.navBarData = JSON.parse(getRaw(dataPageName)); // 제거할 메뉴 : 메뉴 타이틀명 libreNavLogin.titleMap2 = { "RC": "위키의 최근 바뀐 목록 [alt-shift-r]", // 최근 바뀜 메뉴 "random": "무작위로 선택된 문서 불러오기 [alt-shift-x]", // 임의 문서 메뉴 "map": "https://maps.librewiki.net/", // 리브레 맵스 메뉴 "board": "게시판", // 게시판 메뉴(드롭다운) "wikiBoard": "https://bbs.librewiki.net/", // 위키 게시판(하위 링크) "freeBoard": "https://bbs.librewiki.net/freeboard", //자유 게시판(하위 링크) "tools": "도구", // 도구(드롭다운) "special": "특수:특수문서", // 특수문서(하위링크) "upload": "특수:올리기", // 업로드(하위 링크) "help": "도움말", // 도움말(드롭다운) "summary": "리브레_위키:도움말", // 위키 도움말(하위 링크) "syntax": "도움말:위키_문법", // 위키 문법(하위 링크) "Tex": "도움말:TeX_문법", // TeX 문법(하위 링크) "menuMy": "내 사용자 문서 [alt-shift-.]", // 내 사용자 문서 "menuEcho": "당신의 알림", // 알림 (사용자 메뉴) "menuContribution": "내 기여 목록 [alt-shift-y]", // 내 기여 목록 "menuTalk": "내 토론 문서 [alt-shift-n]", // 내 토론 문서 "menuWatch": "주시문서에 대한 바뀜 목록 [alt-shift-l]", // 주시문서 목록 "menuSettings": "사용자 환경 설정", // 환경 설정 }; // 아이템 생성 방법 libreNavLogin.createItem = function(icon, title, url, desc, isMenu=false) { var a = document.createElement('a'); // 링크 추가 var iconHTML = document.createElement('span'); // icon 추가 iconHTML.className = "fa "+icon; iconHTML.style.color = isMenu? 'inherit' :'#373a3c'; // 색상 변경 iconHTML.style.fontSize = isMenu? 'inherit' : '0.9em'; // 사이즈 변경 iconHTML.style.padding = '0.2em 0'; // 아이콘 여백 조정 a.className = isMenu? "nav-link" : "dropdown-item", a.href = url, a.innerHTML = isMenu? '<span class="hide-title">'+title+'</span>':title, a.title = desc; // icon이 빈 값이 아닐 때 아이콘 추가 if (icon != '' && icon !=undefined) { a.prepend(iconHTML); } return a; }; // 신규 아이콘 추가 함수 libreNavLogin.addMenuItem = function(icon, name, url, desc, part) { var node = this.createItem(icon, name, url, desc, part === 'new'); // 아이템 생성 switch(part) { case 'user' : { // 사용자 메뉴 document.getElementsByClassName('dropdown-divider')[0].before(node); break; } case 'board': { // 게시판 document.querySelector('.navbar-fixed-top a.nav-link[title="게시판"]').nextElementSibling.appendChild(node) break; } case 'tools': { // 도구 document.querySelector('.navbar-fixed-top a.nav-link[title="도구"]').nextElementSibling.appendChild(node) break; } case 'help': { // 도움말 document.querySelector('.navbar-fixed-top a.nav-link[title="도움말"]').nextElementSibling.appendChild(node) break; } case 'new': { // 신규 메뉴 var menuLi = document.createElement('li'); menuLi.classList.add('nav-item'); menuLi.appendChild(node); document.querySelector('.navbar-fixed-top ul.navbar-nav').appendChild(menuLi); break; } case 'dropdown': { // 신규 드롭다운. 지원 예정. } } }; // 기존 아이콘 제거 함수 libreNavLogin.removeItem = function(name) { var Selector = '.navbar-fixed-top a[title="' + name + '"]'; // 타이틀 이름을 가진 링크. 사이드이펙트 방지를 위해 navbar-fixed-top 속성 추가. document.querySelector(Selector).remove(); }; // 아이템 설정. libreNavLogin.setNavItems = function() { // 메뉴 추가 - navBarData.addList 오브젝트 사용 for (typical in this.navBarData.addList) { for (const item of this.navBarData.addList[typical]) { this.addMenuItem(item[0], item[1], item[2], item[3], typical); } } // 기존에 있는 메뉴 제거하는 과정 for (const key in this.titleMap2) { // titleMap2에서 key값 추출 if (this.navBarData.dropList.indexOf(key)>-1) { this.removeItem(this.titleMap2[key]); } } // 메뉴 앞의 알림버튼 지우기 여부 if (this.navBarData.dropList.indexOf('echo')>-1) { document.querySelector('#pt-notifications-notice').remove(); } // 로그아웃 버튼 지우기 여부 if(this.navBarData.dropList.indexOf('logout')>-1) { document.querySelector('.hide-logout.logout-btn').remove(); } }; // 아이템 세팅 완료 libreNavLogin.setNavItems(); </syntaxhighlight> {{숨김 끝}} 요약: 리브레 위키에서의 모든 기여는 크리에이티브 커먼즈 저작자표시-동일조건변경허락 3.0 라이선스로 배포됩니다(자세한 내용에 대해서는 리브레 위키:저작권 문서를 읽어주세요). 만약 여기에 동의하지 않는다면 문서를 저장하지 말아 주세요. 글이 직접 작성되었거나 호환되는 라이선스인지 확인해주세요. 리그베다 위키, 나무위키, 오리위키, 구스위키, 디시위키 및 CCL 미적용 사이트 등에서 글을 가져오실 때는 본인이 문서의 유일한 기여자여야 하고, 만약 본인이 문서의 유일한 기여자라는 증거가 없다면 그 문서는 불시에 삭제될 수 있습니다. 취소 편집 도움말 (새 창에서 열림) | () [] [[]] {{}} {{{}}} · <!-- --> · [[분류:]] · [[파일:]] · [[미디어:]] · #넘겨주기 [[]] · {{ㅊ|}} · <onlyinclude></onlyinclude> · <includeonly></includeonly> · <noinclude></noinclude> · <br /> · <ref></ref> · {{각주}} · {|class="wikitable" · |- · rowspan=""| · colspan=""| · |} {{lang|}} · {{llang||}} · {{인용문|}} · {{인용문2|}} · {{유튜브|}} · {{다음팟|}} · {{니코|}} · {{토막글}} {{삭제|}} · {{특정판삭제|}}(이유를 적지 않을 경우 기각될 가능성이 높습니다. 반드시 이유를 적어주세요.) {{#expr:}} · {{#if:}} · {{#ifeq:}} · {{#iferror:}} · {{#ifexist:}} · {{#switch:}} · {{#time:}} · {{#timel:}} · {{#titleparts:}} __NOTOC__ · __FORCETOC__ · __TOC__ · {{PAGENAME}} · {{SITENAME}} · {{localurl:}} · {{fullurl:}} · {{ns:}} –(대시) ‘’(작은따옴표) “”(큰따옴표) ·(가운뎃점) …(말줄임표) ‽(물음느낌표) 〈〉(홑화살괄호) 《》(겹화살괄호) ± − × ÷ ≈ ≠ ∓ ≤ ≥ ∞ ¬ ¹ ² ³ ⁿ ¼ ½ ¾ § € £ ₩ ¥ ¢ † ‡ • ← → ↔ ‰ °C µ(마이크로) Å °(도) ′(분) ″(초) Α α Β β Γ γ Δ δ Ε ε Ζ ζ Η η Θ θ Ι ι Κ κ Λ λ Μ μ(뮤) Ν ν Ξ ξ Ο ο Π π Ρ ρ Σ σ ς Τ τ Υ υ Φ φ Χ χ Ψ ψ Ω ω · Ά ά Έ έ Ή ή Ί ί Ό ό Ύ ύ Ώ ώ · Ϊ ϊ Ϋ ϋ · ΐ ΰ Æ æ Đ(D with stroke) đ Ð(eth) ð ı Ł ł Ø ø Œ œ ß Þ þ · Á á Ć ć É é Í í Ĺ ĺ Ḿ ḿ Ń ń Ó ó Ŕ ŕ Ś ś Ú ú Ý ý Ź ź · À à È è Ì ì Ǹ ǹ Ò ò Ù ù · İ Ż ż ·  â Ĉ ĉ Ê ê Ĝ ĝ Ĥ ĥ Î î Ĵ ĵ Ô ô Ŝ ŝ Û û · Ä ä Ë ë Ï ï Ö ö Ü ü Ÿ ÿ · ǘ ǜ ǚ ǖ · caron/háček: Ǎ ǎ Č č Ď ď Ě ě Ǐ ǐ Ľ ľ Ň ň Ǒ ǒ Ř ř Š š Ť ť Ǔ ǔ Ž ž · breve: Ă ă Ğ ğ Ŏ ŏ Ŭ ŭ · Ā ā Ē ē Ī ī Ō ō Ū ū · à ã Ñ ñ Õ õ · Å å Ů ů · Ą ą Ę ę · Ç ç Ş ş Ţ ţ · Ő ő Ű ű · Ș ș Ț ț