미디어위키:Common.js: 두 판 사이의 차이

잔글편집 요약 없음
잔글편집 요약 없음
 
(같은 사용자의 중간 판 17개는 보이지 않습니다)
25번째 줄: 25번째 줄:
     });
     });


     function startDeletion(element, originalString, finalString, delay, deleteSpeed) {
$(function () {
         var currentString = originalString;
     $("i.mw-typing").each(function () {
         var step = 0;
         var $el = $(this);
         var maxSteps = Math.ceil(originalString.length / deleteSpeed) + 3;
         var original = $el.text().trim();
         var intervalId = setInterval(function() {
         var speed = parseInt($el.attr("data-speed"), 10) || 50;
             step++;
        var goal = $el.attr("data-goal");
             if (step <= maxSteps) {
         var delay = parseInt($el.attr("data-delay"), 10) || 0;
                 var charsToReplace = Math.min(deleteSpeed, currentString.length);
 
                 var indices = [];
        if (goal && goal.trim().length > 0) {
                for (var i = 0; i < currentString.length; i++) {
             $el.text(original);
                    if (currentString.charAt(i) !== '█') {
 
                         indices.push(i);
             function startDeleting() {
                     };
                 var i = original.length;
                 };
                 function deleteStep() {
                 for (var i = 0; i < charsToReplace && indices.length > 0; i++) {
                    if (i > 0) {
                    var randomIndex = Math.floor(Math.random() * indices.length);
                        i--;
                    var charIndex = indices[randomIndex];
                        $el.text(original.slice(0, i));
                    currentString = currentString.substring(0, charIndex) + '█' + currentString.substring(charIndex + 1);
                        setTimeout(deleteStep, speed);
                     indices.splice(randomIndex, 1);
                    } else {
                 };
                         typeGoal();
                 if (currentString.replace(/█/g, '').length < 5) {
                     }
                    currentString = currentString.replace(/[^█]/g, '█');
                 }
                };
 
                element.textContent = currentString;
                 var j = 0;
            } else if (step === maxSteps + 1) {
                function typeGoal() {
                element.textContent = finalString.substring(0, 3) || '';
                    if (j < goal.length) {
             } else if (step === maxSteps + 2) {
                        $el.text($el.text() + goal.charAt(j));
                 element.textContent = finalString;
                        j++;
                 clearInterval(intervalId);
                        setTimeout(typeGoal, speed);
            };
                     }
        }, delay);
                 }
    };
 
    var sdrElements = document.querySelectorAll('i[string-deleter-replacer]');
                 deleteStep();
    sdrElements.forEach(function(element) {
            }
        var originalString = element.textContent.trim();
 
        var finalString = element.getAttribute('result');
            setTimeout(startDeleting, delay);
        var delay = parseInt(element.getAttribute('delete-delay'));
 
        var deleteSpeed = parseInt(element.getAttribute('delete-speed'));
        } else {
        startDeletion(element, originalString, finalString, delay, deleteSpeed);
            $el.text("");
 
             function startTyping() {
                 var k = 0;
                 function typeOriginal() {
                    if (k < original.length) {
                        $el.text($el.text() + original.charAt(k));
                        k++;
                        setTimeout(typeOriginal, speed);
                    }
                }
                typeOriginal();
            }
 
            setTimeout(startTyping, delay);
        }
     });
     });
});
});
});

2026년 1월 2일 (금) 21:51 기준 최신판

/* 이 자바스크립트 설정은 모든 문서, 모든 사용자에게 적용됩니다. */
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);
        }
    });

$(function () {
    $("i.mw-typing").each(function () {
        var $el = $(this);
        var original = $el.text().trim();
        var speed = parseInt($el.attr("data-speed"), 10) || 50;
        var goal = $el.attr("data-goal");
        var delay = parseInt($el.attr("data-delay"), 10) || 0;

        if (goal && goal.trim().length > 0) {
            $el.text(original);

            function startDeleting() {
                var i = original.length;
                function deleteStep() {
                    if (i > 0) {
                        i--;
                        $el.text(original.slice(0, i));
                        setTimeout(deleteStep, speed);
                    } else {
                        typeGoal();
                    }
                }

                var j = 0;
                function typeGoal() {
                    if (j < goal.length) {
                        $el.text($el.text() + goal.charAt(j));
                        j++;
                        setTimeout(typeGoal, speed);
                    }
                }

                deleteStep();
            }

            setTimeout(startDeleting, delay);

        } else {
            $el.text("");

            function startTyping() {
                var k = 0;
                function typeOriginal() {
                    if (k < original.length) {
                        $el.text($el.text() + original.charAt(k));
                        k++;
                        setTimeout(typeOriginal, speed);
                    }
                }
                typeOriginal();
            }

            setTimeout(startTyping, delay);
        }
    });
});





});