MediaWiki:Common.js: Perbedaan antara revisi
Tampilan
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. | // 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 ($('.page-heading').length) { | if ($('.section-heading').length) { | ||
$('.page-heading'). | // Untuk beberapa versi Minerva yang pake section-heading | ||
} else { | $('.section-heading').first().before(greetingHtml); | ||
$('#firstHeading'). | } 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;
});
});