MediaWiki:Common.js: Difference between revisions
Appearance
No edit summary Tags: Reverted Mobile edit Mobile web edit |
No edit summary Tags: Reverted Mobile edit Mobile web edit |
||
| Line 96: | Line 96: | ||
prop: 'imageinfo', | prop: 'imageinfo', | ||
iiprop: 'url', | iiprop: 'url', | ||
iiurlwidth: | iiurlwidth: 15, // Minta server MediaWiki render ukuran lebar 24px otomatis | ||
format: 'json' | format: 'json' | ||
}).done(function(data) { | }).done(function(data) { | ||
Revision as of 12:23, 29 May 2026
/* ==========================================================
🚀 MIPPEDIA DATA BUTTON ONLY (Otomatis - English Bridge Version)
Hanya memunculkan tombol jika data tersedia di pusat.
Mendukung pencarian otomatis ke Mippedia ID secara mandiri tanpa interwiki manual.
========================================================== */
$(document).ready(function() {
var pageName = mw.config.get('wgPageName').replace(/_/g, ' ');
var namespace = mw.config.get('wgNamespaceNumber');
var dataDomain = 'https://data.mippedia.org';
// Alamat API Mippedia Bahasa Indonesia
var indonesianWikiApi = 'https://id.mippedia.org/api.php';
// Jalankan hanya di namespace artikel resmi
if (namespace === 0) {
// Langkah 1: Tembak API Mippedia Indonesia untuk mencari padanan halaman paling relevan
$.ajax({
url: indonesianWikiApi,
data: {
action: 'query',
list: 'search',
srsearch: pageName, // Mencari padanan berdasarkan judul Inggris
srlimit: 1,
format: 'json',
origin: '*'
},
dataType: 'json',
success: function(wikiRes) {
var targetDataPage = pageName; // Fallback jika tidak ditemukan
if (wikiRes && wikiRes.query && wikiRes.query.search && wikiRes.query.search.length > 0) {
// Ketemu judul bahasa Indonesianya secara otomatis dari sistem search internal
targetDataPage = wikiRes.query.search[0].title;
}
// Format spasi menjadi underscore untuk validasi nama halaman MediaWiki
targetDataPage = targetDataPage.replace(/\s+/g, '_');
// Langkah 2: Cek langsung ke Mippedia Data menggunakan nama halaman Indonesia hasil pelacakan
$.ajax({
url: dataDomain + '/api.php',
data: {
action: 'query',
titles: targetDataPage,
format: 'json',
origin: '*'
},
dataType: 'jsonp',
success: function(res) {
if (res && res.query && res.query.pages) {
var pages = res.query.pages;
var isExist = false;
for (var id in pages) {
if (parseInt(id) > 0) {
isExist = true;
break;
}
}
// Jika data valid ditemukan di pusat, munculkan tombol melayang
if (isExist) {
injectFloatingDataBtn(targetDataPage, dataDomain);
}
}
}
});
},
error: function() {
// Jika server Wiki Indonesia down, langsung pakai nama asli Inggris-nya sebagai fallback akhir
var nativePage = pageName.replace(/\s+/g, '_');
$.ajax({
url: dataDomain + '/api.php',
data: { action: 'query', titles: nativePage, format: 'json', origin: '*' },
dataType: 'jsonp',
success: function(res) {
var pages = res.query.pages;
var isExist = false;
for (var id in pages) { if (parseInt(id) > 0) { isExist = true; break; } }
if (isExist) { injectFloatingDataBtn(nativePage, dataDomain); }
}
});
}
});
}
function injectFloatingDataBtn(name, domain) {
if ($('#mippedia-data-btn').length) return;
// Otak Cerdas Baru: Panggil API MediaWiki lokal buat nyari link image SVG yang valid
var api = new mw.Api();
api.get({
action: 'query',
titles: 'File:Locked_Data.svg',
prop: 'imageinfo',
iiprop: 'url',
iiurlwidth: 15, // Minta server MediaWiki render ukuran lebar 24px otomatis
format: 'json'
}).done(function(data) {
var imageUrl = '';
try {
var pages = data.query.pages;
for (var id in pages) {
if (pages[id].imageinfo && pages[id].imageinfo[0]) {
// Dapat URL render resmi berformat PNG/SVG yang didukung browser!
imageUrl = pages[id].imageinfo[0].thumburl || pages[id].imageinfo[0].url;
}
}
} catch (e) {
imageUrl = '';
}
// Jika gagal dapet gambar, pakai fallback ikon dasar murni teks atau kosongan
if (!imageUrl) return;
var $btn = $('<a>', {
id: 'mippedia-data-btn',
href: domain + '/wiki/' + encodeURIComponent(name),
target: '_blank',
style: 'position: absolute; right: 15px; top: -5px; z-index: 1000; text-decoration: none; display: inline-block; transition: transform 0.2s;',
html: $('<img>', {
src: imageUrl,
alt: 'Data Icon',
style: 'height: 24px; width: 24px; display: block; vertical-align: middle;'
})
});
// Efek hover interaktif
$btn.hover(
function() { $(this).css('transform', 'scale(1.15)'); },
function() { $(this).css('transform', 'scale(1.0)'); }
);
// Target penempatan tombol aksi di Minerva mobile / Desktop skin
var $target = $('.page-actions-menu, .mw-editsection-visualeditor, #ca-edit, .minerva__tab-container').first();
if ($target.length) {
$target.css('position', 'relative').append($btn);
} else {
// Fallback aman agar tidak nabrak teks judul halaman utama
$('#firstHeading').css('position', 'relative').append($btn);
$btn.css('top', '5px');
}
});
}
});