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

잔글편집 요약 없음
잔글편집 요약 없음
 
(같은 사용자의 중간 판 20개는 보이지 않습니다)
6번째 줄: 6번째 줄:
         for (var i = 0; i < length; i++) {
         for (var i = 0; i < length; i++) {
             result += characters.charAt(Math.floor(Math.random() * characters.length));
             result += characters.charAt(Math.floor(Math.random() * characters.length));
         }
         };
         return result;
         return result;
     }
     };


     var rsgelements = document.querySelectorAll('i[data-random-string]');
     var rsgelements = document.querySelectorAll('i[data-random-string]');
25번째 줄: 25번째 줄:
     });
     });


     var sdrelements = document.querySelectorAll('i[string-deleter-replacer]');
$(function () {
    sdrelements.forEach(function(sdrelements) {
     $("i.mw-typing").each(function () {
         const originalString = sdrelements.getAttribute('string-deleter-replacer').trim();
         var $el = $(this);
         const finalCharacter = sdrelements.getAttribute('result').trim();
        var original = $el.text().trim();
         const intervalTime = parseInt(sdrelements.getAttribute('delete-speed')) || 75;
         var speed = parseInt($el.attr("data-speed"), 10) || 50;
        var goal = $el.attr("data-goal");
         var delay = parseInt($el.attr("data-delay"), 10) || 0;


         sdrelements.textContent = originalString;
         if (goal && goal.trim().length > 0) {
        let words = originalString.split(' ');
            $el.text(original);
        let intervalId;
 
            function startDeleting() {
                var i = original.length;
                function deleteStep() {
                    if (i > 0) {
                        i--;
                        $el.text(original.slice(0, i));
                        setTimeout(deleteStep, speed);
                    } else {
                        typeGoal();
                    }
                }


        const stepShrink = () => {
                var j = 0;
            if (words.every(word => word.length === 0)) {
                function typeGoal() {
                if (intervalId) {
                    if (j < goal.length) {
                    clearInterval(intervalId);
                        $el.text($el.text() + goal.charAt(j));
                        j++;
                        setTimeout(typeGoal, speed);
                    }
                 }
                 }
                sdrelements.textContent = finalCharacter;
 
                 return;
                 deleteStep();
             }
             }


             words = words.map(word => {
             setTimeout(startDeleting, delay);
                if (word.length === 0) {
                    return '';
                }


                const newWordBase = word.substring(0, word.length - 1);
        } else {
            $el.text("");


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


             const displayText = words.filter(word => word.length > 0).join(' ');
             setTimeout(startTyping, delay);
            sdrelements.textContent = displayText;
         }
            };
       
            intervalId = setInterval(stepShrink, intervalTime);
         });
     });
     });
});




    });
});
});

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);
        }
    });
});





});