Lompat ke isi

MediaWiki:Common.js: Perbedaan antara revisi

Dari Mippedia bahasa Indonesia, ensiklopedia umum
Tidak ada ringkasan suntingan
Tanda: Suntingan perangkat seluler Suntingan peramban seluler
Tidak ada ringkasan suntingan
Tanda: Suntingan perangkat seluler Suntingan peramban seluler
Baris 38: Baris 38:




/* 1. Script Ucapan Selamat Berdasarkan Waktu */
/* 1. Script Ucapan Selamat Berdasarkan Waktu - POSISI DI ATAS JUDUL */
$(document).ready(function() {
$(document).ready(function() {
     if (mw.config.get('wgIsMainPage') || (mw.config.get('wgIsArticle') && mw.config.get('wgNamespaceNumber') === 0)) {
     if (mw.config.get('wgIsMainPage') || (mw.config.get('wgIsArticle') && mw.config.get('wgNamespaceNumber') === 0)) {
Baris 51: Baris 51:
         else { ucapan = "Selamat Malam"; icon = "🌙"; }
         else { ucapan = "Selamat Malam"; icon = "🌙"; }


         var greetingHtml = '<div id="site-greeting" style="font-size: 0.85em; color: #72777d; margin-top: 5px;">' + icon + ' ' + ucapan + ', Sobat Mippedia!</div>';
        // Styling: dikasih sedikit jarak (margin-bottom) biar gak nempel banget ke judul
         var greetingHtml = '<div id="site-greeting" style="font-size: 0.9em; color: #72777d; margin-bottom: 8px; font-style: italic;">' + icon + ' ' + ucapan + ', Sobat Mippedia!</div>';
          
          
         // Tempel di bawah judul atau heading
         // Target Penempelan di ATAS Judul
         if ($('.page-heading').length) {
        if ($('.section-heading').length) {
             $('.page-heading').append(greetingHtml); // Untuk Mobile
            // Untuk beberapa versi Minerva yang pake section-heading
         } else {
            $('.section-heading').first().before(greetingHtml);
             $('#firstHeading').append(greetingHtml); // Untuk Desktop
         } else if ($('.page-heading').length) {
            // Target utama Minerva (Mobile)
             $('.page-heading').before(greetingHtml);
         } else if ($('#firstHeading').length) {
            // Target utama Vector (Desktop)
             $('#firstHeading').before(greetingHtml);
         }
         }
     }
     }

Revisi per 9 April 2026 20.14

/* Script Estimasi Waktu Baca - Spesialis Mobile (Minerva) & Desktop */
$(document).ready(function() {
    // Hanya jalan di halaman artikel asli
    if (mw.config.get('wgIsArticle') && mw.config.get('wgAction') === 'view' && mw.config.get('wgNamespaceNumber') === 0) {
        
        function hitungWaktuBaca() {
            // Ambil teks dari konten utama
            var content = $('#mw-content-text').text();
            
            // Hitung jumlah kata (asumsi rata-rata orang baca 200 kata per menit)
            var wordsPerMinute = 200;
            var textLength = content.split(/\s+/).length; // Pecah berdasarkan spasi
            var readingTime = Math.ceil(textLength / wordsPerMinute);
            
            // Bikin elemen tampilannya
            var icon = '🕒'; // Emoji jam biar simpel dan ringan
            var label = (readingTime <= 1) ? 'Kurang dari 1 menit' : readingTime + ' menit';
            
            var html = '<div id="reading-time-auto" style="font-size: 0.9em; color: #54595d; margin-bottom: 15px; display: flex; align-items: center; font-family: sans-serif;">';
            html += '<span style="margin-right: 5px;">' + icon + '</span>';
            html += '<span>Estimasi waktu baca: <b>' + label + '</b></span>';
            html += '</div>';

            // PENEMPELAN TARGET:
            // Di Minerva (HP), judul biasanya ada di .page-heading
            // Di Vector (Desktop), judul ada di #firstHeading
            if ($('.page-heading').length) {
                $('.page-heading').after(html); // Target Mobile
            } else if ($('#firstHeading').length) {
                $('#firstHeading').after(html); // Target Desktop
            }
        }

        // Jalankan fungsi
        hitungWaktuBaca();
    }
});


/* 1. Script Ucapan Selamat Berdasarkan Waktu - POSISI DI ATAS JUDUL */
$(document).ready(function() {
    if (mw.config.get('wgIsMainPage') || (mw.config.get('wgIsArticle') && mw.config.get('wgNamespaceNumber') === 0)) {
        var date = new Date();
        var hour = date.getHours();
        var ucapan = "";
        var icon = "";

        if (hour >= 5 && hour < 11) { ucapan = "Selamat Pagi"; icon = "🌅"; }
        else if (hour >= 11 && hour < 15) { ucapan = "Selamat Siang"; icon = "☀️"; }
        else if (hour >= 15 && hour < 18) { ucapan = "Selamat Sore"; icon = "🌇"; }
        else { ucapan = "Selamat Malam"; icon = "🌙"; }

        // Styling: dikasih sedikit jarak (margin-bottom) biar gak nempel banget ke judul
        var greetingHtml = '<div id="site-greeting" style="font-size: 0.9em; color: #72777d; margin-bottom: 8px; font-style: italic;">' + icon + ' ' + ucapan + ', Sobat Mippedia!</div>';
        
        // Target Penempelan di ATAS Judul
        if ($('.section-heading').length) {
             // Untuk beberapa versi Minerva yang pake section-heading
            $('.section-heading').first().before(greetingHtml);
        } else if ($('.page-heading').length) {
            // Target utama Minerva (Mobile)
            $('.page-heading').before(greetingHtml);
        } else if ($('#firstHeading').length) {
            // Target utama Vector (Desktop)
            $('#firstHeading').before(greetingHtml);
        }
    }
});

/* 2. Script Tombol Back to Top (Spesial Mobile) */
$(document).ready(function() {
    // Bikin tombolnya lewat JS biar gak ribet edit CSS/HTML
    var btnHtml = '<div id="backToTop" style="display:none; position:fixed; bottom:80px; right:20px; z-index:9999; background:#36c; color:#fff; width:45px; height:45px; border-radius:50%; text-align:center; line-height:45px; font-size:24px; cursor:pointer; box-shadow: 0 4px 6px rgba(0,0,0,0.3); opacity: 0.8;">↑</div>';
    $('body').append(btnHtml);

    // Fungsi munculin tombol pas di-scroll
    $(window).scroll(function() {
        if ($(this).scrollTop() > 300) {
            $('#backToTop').fadeIn();
        } else {
            $('#backToTop').fadeOut();
        }
    });

    // Fungsi pas tombol diklik
    $('#backToTop').click(function() {
        $('html, body').animate({scrollTop: 0}, 600);
        return false;
    });
});