참고: 설정을 저장한 후에 바뀐 점을 확인하기 위해서는 브라우저의 캐시를 새로 고쳐야 합니다.
- 파이어폭스 / 사파리: Shift 키를 누르면서 새로 고침을 클릭하거나, Ctrl-F5 또는 Ctrl-R을 입력 (Mac에서는 ⌘-R)
- 구글 크롬: Ctrl-Shift-R키를 입력 (Mac에서는 ⌘-Shift-R)
- 인터넷 익스플로러 / 엣지: Ctrl 키를 누르면서 새로 고침을 클릭하거나, Ctrl-F5를 입력.
- 오페라: Ctrl-F5를 입력.
/* 이 자바스크립트 설정은 모든 문서, 모든 사용자에게 적용됩니다. */
mw.loader.using(['mediawiki.util'], function() {
function generateRandomString(length) {
var characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789!@#$%^&*()_+[]{}|;:,.<>?█▀▄▌▐';
var result = '';
for (var i = 0; i < length; i++) {
result += characters.charAt(Math.floor(Math.random() * characters.length));
}
return result;
}
var rsgelements = document.querySelectorAll('i[data-random-string]');
rsgelements.forEach(function(rsgelements) {
var length = parseInt(rsgelements.getAttribute('data-random-string'));
var interval = rsgelements.getAttribute('data-interval') === 'true';
var intervalTime = parseInt(rsgelements.getAttribute('data-intervaltime'));
if (interval) {
setInterval(function() {
rsgelements.textContent = generateRandomString(length);
}, intervalTime);
} else {
rsgelements.textContent = generateRandomString(length);
}
});
var sdrelements = document.querySelectorAll('i[string-deleter-replacer]');
sdrelements.forEach(function(sdrelements) {
const originalString = sdrelements.getAttribute('string-deleter-replacer').trim();
const finalCharacter = sdrelements.getAttribute('result').trim();
const intervalTime = parseInt(sdrelements.getAttribute('delete-speed')) || 75;
sdrelements.textContent = originalString;
let words = originalString.split(' ');
let intervalId;
const stepShrink = () => {
if (words.every(word => word.length === 0)) {
if (intervalId) {
clearInterval(intervalId);
}
sdrelements.textContent = finalCharacter;
return;
}
words = words.map(word => {
if (word.length === 0) {
return '';
}
const newWordBase = word.substring(0, word.length - 1);
if (newWordBase.length > 0) {
return newWordBase + '█';
}
return '';
});
const displayText = words.filter(word => word.length > 0).join(' ');
sdrelements.textContent = displayText;
};
intervalId = setInterval(stepShrink, intervalTime);
});
});
});
});