참고: 설정을 저장한 후에 바뀐 점을 확인하기 위해서는 브라우저의 캐시를 새로 고쳐야 합니다.
- 파이어폭스 / 사파리: Shift 키를 누르면서 새로 고침을 클릭하거나, Ctrl-F5 또는 Ctrl-R을 입력 (Mac에서는 ⌘-R)
- 구글 크롬: Ctrl-Shift-R키를 입력 (Mac에서는 ⌘-Shift-R)
- 인터넷 익스플로러 / 엣지: Ctrl 키를 누르면서 새로 고침을 클릭하거나, Ctrl-F5를 입력.
- 오페라: Ctrl-F5를 입력.
/*
* written By. LiteHell and modified by Utolee90
* Warning : This script uses localStorage of your browser so BREADCUMB WILL BE DELETED IF YOU CLEAR STORAGE DATA FROM YOUR BROWSER.
*/
if (mw.config.exists("wgIsArticle") && mw.config.exists("wgPageName") && mw.config.exists("wgArticlePath")) {
var conf = mw.config.get(["wgIsArticle", "wgPageName", "wgArticlePath"]);
mw.loader.load('oojs-ui'), mw.loader.load('mediawiki.notification');
if (conf.wgIsArticle) {
var itemName = "pageBreadcumbs";
function initStorageIfRequired() {
if (localStorage.getItem(itemName) == null)
localStorage.setItem(itemName, "[]");
}
function setStorage(value) {
initStorageIfRequired();
localStorage.setItem(itemName, JSON.stringify(value.slice(-20)));
}
function getStorage() {
initStorageIfRequired();
return JSON.parse(localStorage.getItem(itemName));
}
function makeBreadBar(arr, active) {
var ol = document.createElement("ol");
ol.style.display = 'inline-block';
ol.style.margin = '0.5em',
ol.className = "breadcrumb";
$(ol).append('<li id="cleanBreads" style=""><a href="javascript:(function(){})();" style="color: red;"><span class="fa fa-trash"></span></a></li>');
ol.querySelector('li#cleanBreads > a').addEventListener("click", function() {
OO.ui.confirm("진짜로 빵가루를 전부 다 청소할까요?").done(function(confirmed) {
if (confirmed) {
localStorage.setItem(itemName, "[]");
mw.notification.autoHideSeconds = {'short': 1.5};
mw.notify('강제 새로고침하면 지워져 있을겁니다. :)');
}
});
});
// 최근 10개만 역순으로 제작. 중복이 있으면 제외
var limitCnt = 10;
var newArr = [];
var j = 0;
while (newArr.length < Math.min(limitCnt, arr.length) && j <= arr.length - 1) {
if (newArr.indexOf(arr[arr.length - 1 - j]) == -1) {
newArr.push(arr[arr.length - 1 - j]);
}
j++;
}
for (var i = 0; i < newArr.length; i++) {
var now = newArr[i];
var li = document.createElement("li");
if (now == active) {
li.className = "active";
li.textContent = now;
} else {
var anchor = document.createElement("a");
anchor.href = conf.wgArticlePath.replace('$1', now);
anchor.title = now;
anchor.textContent = now;
li.appendChild(anchor);
}
ol.appendChild(li);
}
return ol;
}
var articles = getStorage();
if (articles.length == 0 || (articles.length != 0 && articles[articles.length - 1] != conf.wgPageName)) articles.push(conf.wgPageName);
setStorage(articles, conf.wgPageName);
var breadbar = makeBreadBar(articles, conf.wgPageName);
var headerAds = document.querySelector(".header-ads");
headerAds.parentNode.insertBefore(breadbar, headerAds); // 광고 위에 삽입하기
}
}