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

잔글편집 요약 없음
잔글편집 요약 없음
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]');
39번째 줄: 39번째 줄:
                 if (intervalId) {
                 if (intervalId) {
                     clearInterval(intervalId);
                     clearInterval(intervalId);
                 }
                 };
                 sdrelements.textContent = finalCharacter;
                 sdrelements.textContent = finalCharacter;
                 return;
                 return;
             }
             };
 
             words = words.map(word => {
             words = words.map(word => {
                 if (word.length === 0) {
                 if (word.length === 0) {
                     return '';
                     return '';
                 }
                 };
 
                 const newWordBase = word.substring(0, word.length - 1);
                 const newWordBase = word.substring(0, word.length - 1);
                 if (newWordBase.length > 0) {
                 if (newWordBase.length > 0) {
                     return newWordBase + '█';
                     return newWordBase + '█';
                 }
                 };
               
                 return '';
                 return '';
             });
             });
             const displayText = words.filter(word => word.length > 0).join(' ');
             const displayText = words.filter(word => word.length > 0).join(' ');
             sdrelements.textContent = displayText;
             sdrelements.textContent = displayText;
            };
        };
          
         intervalId = setInterval(stepShrink, intervalTime);
            intervalId = setInterval(stepShrink, intervalTime);
        });
    });
 
 
     });
     });
});
});

2025년 11월 16일 (일) 12:46 판

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