Lompat ke isi

MediaWiki:Common.js

Dari Mippedia Data
Revisi sejak 14 April 2026 23.30 oleh Admin (bicara | kontrib)

Catatan: Setelah menerbitkan, Anda mungkin perlu melewati tembolok peramban web Anda untuk melihat perubahan.

  • Firefox/Safari: Tekan dan tahan Shift sembari mengeklik Reload, atau tekan Ctrl-F5 atau Ctrl-R (⌘-R di Mac)
  • Google Chrome: Tekan Ctrl-Shift-R (⌘-Shift-R di Mac)
  • Edge: Tahan Ctrl sembari mengeklik Refresh, atau tekan Ctrl-F5
/* ==========================================================
   🧠 MIPPEDIA DATA OMNI-SCRIPT (PURE TEXT EDITION)
   ========================================================== */
(function() {
    $(document).ready(function() {
        var $descSection = $('#mip-desc-section');
        var $descBox = $('#mip-auto-description');
        var $voiceContainer = $('#mip-voice-container');
        var $voiceText = $('#mip-voice-text');
        
        if (!$descBox.length) return;

        var pageTitle = mw.config.get('wgPageName');
        
        var projects = [
            { id: 'id', name: 'Mippedia bahasa Indonesia', url: 'https://id.mippedia.org/api.php', base: 'https://id.mippedia.org/wiki/' },
            { id: 'en', name: 'Mippedia bahasa Inggris', url: 'https://en.mippedia.org/api.php', base: 'https://en.mippedia.org/wiki/' },
            { id: 'concise', name: 'Mippedia bahasa Indonesia ringkas', url: 'https://concise.mippedia.org/api.php', base: 'https://concise.mippedia.org/wiki/' }
        ];

        function speakText(text) {
            window.speechSynthesis.cancel();
            var msg = new SpeechSynthesisUtterance();
            msg.text = text;
            msg.lang = 'id-ID';
            msg.rate = 1.0;
            window.speechSynthesis.speak(msg);
        }

        function cleanExtract(text) {
            return text.replace(/\{\{[^}]+\}\}/g, '').replace(/\(\s*\)/g, '').replace(/\s\s+/g, ' ').trim();
        }

        function translateText(text, callback) {
            var translateUrl = "https://translate.googleapis.com/translate_a/single?client=gtx&sl=en&tl=id&dt=t&q=" + encodeURIComponent(text);
            $.ajax({ url: translateUrl, success: function(res) {
                var translated = "";
                res[0].forEach(function(s) { if (s[0]) translated += s[0]; });
                callback(translated);
            }, error: function() { callback(text); } });
        }

        function fetchDescription(index) {
            if (index >= projects.length) { $descSection.hide(); return; }

            var p = projects[index];
            $descBox.html('<div class="mip-loading-shimmer"></div>');
            $descSection.show();

            $.ajax({
                url: p.url,
                data: { action: 'query', prop: 'extracts', exintro: true, explaintext: true, titles: pageTitle, format: 'json', origin: '*' },
                dataType: 'json',
                success: function(data) {
                    var pages = data.query.pages;
                    var pageId = Object.keys(pages)[0];
                    
                    if (pageId != "-1") {
                        var extract = cleanExtract(pages[pageId].extract);
                        if (extract !== "") {
                            var sourceLink = p.base + encodeURIComponent(pageTitle);
                            
                            var renderUI = function(finalText, isTranslated) {
                                var html = '<div id="mip-text-content" style="margin-bottom: 12px;">' + finalText + '</div>' + 
                                           '<div style="font-size: 0.9em; color: #777;">Sumber Dari : <a href="' + sourceLink + '" target="_blank" style="color: #6a5acd; font-weight: bold; text-decoration: none;">' + p.name + ' ↗️</a>';
                                if (isTranslated) {
                                    html += '<br><span style="font-size: 0.85em; font-style: italic;">(Diterjemahkan secara otomatis)</span> ' +
                                            '<span id="mip-toggle-orig" style="color: #6a5acd; cursor: pointer; text-decoration: underline; margin-left: 5px;">Tampilkan versi asli</span>';
                                }
                                html += '</div>';
                                
                                $descBox.hide().html(html).fadeIn(400);
                                
                                // Tampilkan container teks suara
                                $voiceContainer.show();
                                $voiceText.off().on('click', function() { 
                                    speakText($('#mip-text-content').text()); 
                                });
                            };

                            if (p.id === 'en') {
                                translateText(extract, function(trans) { 
                                    renderUI(trans, true);
                                    $(document).off('click', '#mip-toggle-orig').on('click', '#mip-toggle-orig', function() {
                                        var $content = $('#mip-text-content');
                                        if ($(this).text() === 'Tampilkan versi asli') { $content.text(extract); $(this).text('Tampilkan terjemahan'); }
                                        else { $content.text(trans); $(this).text('Tampilkan versi asli'); }
                                    });
                                });
                            } else { renderUI(extract, false); }
                            return; 
                        }
                    }
                    fetchDescription(index + 1);
                }
            });
        }

        fetchDescription(0);

        // Style Shimmer tetap ada buat UX loading
        if ($('#mip-shimmer-style').length === 0) {
            $('<style id="mip-shimmer-style">').text(`
                .mip-loading-shimmer { height: 16px; width: 100%; background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%); background-size: 200% 100%; animation: mip-shimmer 1.5s infinite; border-radius: 4px; }
                @keyframes mip-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
            `).appendTo('head');
        }
    });
})();