نکته: پس از ذخیرهکردن ممکن است برای دیدن تغییرات نیاز باشد که حافظهٔ نهانی مرورگر خود را پاک کنید.
- فایرفاکس / سافاری: کلید Shift را نگه دارید و روی دکمهٔ Reload کلیک کنید، یا کلیدهای Ctrl-F5 یا Ctrl-R را با هم فشار دهید (در رایانههای اپل مکینتاش کلیدهای ⌘-R)
- گوگل کروم: کلیدهای Ctrl+Shift+R را با هم فشار دهید (در رایانههای اپل مکینتاش کلیدهای ⌘-Shift-R)
- اینترنت اکسپلورر: کلید Ctrl را نگهدارید و روی دکمهٔ Refresh کلیک کنید، یا کلیدهای Ctrl-F5 را با هم فشار دهید
- اپرا: حافظهٔ نهانی مرورگر را از طریق منوی Tools → Preferences پاک کنید
/* Any JavaScript here will be loaded for all users on every page load. */ //<syntaxhighlight lang="javascript"> if ($.client.profile().name === 'msie') { importScript('MediaWiki:Common.js/IEFixes.js'); } /** Magic editintros **************************************************** * * Description: Adds editintros on disambiguation pages and BLP pages. * Maintainers: [[User:RockMFR]] */ function addEditIntro( name ) { $( '.mw-editsection, #ca-edit' ).find( 'a' ).each( function ( i, el ) { el.href = $( this ).attr( 'href' ) + '&editintro=' + name; } ); } if ( mw.config.get( 'wgNamespaceNumber' ) === 0 ) { $( function () { if ( document.getElementById( 'disambigbox' ) ) { addEditIntro( 'Template:Disambig_editintro' ); } } ); $( function () { var cats = mw.config.get('wgCategories'); if ( !cats ) { return; } if ( $.inArray( 'افراد زنده', cats ) !== -1 ) { addEditIntro( 'Template:BLP_editintro' ); } } ); } /** * @source www.mediawiki.org/wiki/Snippets/Load_JS_and_CSS_by_URL * @rev 5 */ // CSS var extraCSS = mw.util.getParamValue( 'withCSS' ); if ( extraCSS ) { if ( extraCSS.match( /^MediaWiki:[^&<>=%#]*\.css$/ ) ) { importStylesheet( extraCSS ); } else { mw.notify( 'Only pages from the MediaWiki namespace are allowed.', { title: 'Invalid withCSS value' } ); } } // JS var extraJS = mw.util.getParamValue( 'withJS' ); if ( extraJS ) { if ( extraJS.match( /^MediaWiki:[^&<>=%#]*\.js$/ ) ) { importScript( extraJS ); } else { mw.notify( 'Only pages from the MediaWiki namespace are allowed.', { title: 'Invalid withJS value' } ); } } /** * Opening preload.js to add interactive training keys */ if (mw.util.getParamValue( 'preload' )) { importScript("MediaWiki:Preloaded.js"); }; /** Collapsible tables ********************************************************* * * Description: Allows tables to be collapsed, showing only the header. See * [[Wikipedia:NavFrame]]. * Maintainers: [[User:R. Koot]] */ var autoCollapse = 2; var collapseCaption = "نهفتن"; var expandCaption = "نمایش"; function collapseTable( tableIndex ) { var Button = document.getElementById( "collapseButton" + tableIndex ); var Table = document.getElementById( "collapsibleTable" + tableIndex ); if ( !Table || !Button ) { return false; } var Rows = Table.rows; if ( Button.firstChild.data == collapseCaption ) { for ( var i = 1; i < Rows.length; i++ ) { Rows[i].style.display = "none"; } Button.firstChild.data = expandCaption; } else { for ( var i = 1; i < Rows.length; i++ ) { Rows[i].style.display = Rows[0].style.display; } Button.firstChild.data = collapseCaption; } } function createCollapseButtons() { var tableIndex = 0; var NavigationBoxes = {}; var Tables = document.getElementsByTagName( 'table' ); var i; function handleButtonLink( index, e ) { window.collapseTable( index ); e.preventDefault(); } for ( i = 0; i < Tables.length; i++ ) { if ( $( Tables[i] ).hasClass( 'collapsible' ) ) { /* only add button and increment count if there is a header row to work with */ var HeaderRow = Tables[i].getElementsByTagName( 'tr' )[0]; if ( !HeaderRow ) continue; var Header = HeaderRow.getElementsByTagName( 'th' )[0]; if ( !Header ) continue; NavigationBoxes[ tableIndex ] = Tables[i]; Tables[i].setAttribute( 'id', 'collapsibleTable' + tableIndex ); var Button = document.createElement( 'span' ); var ButtonLink = document.createElement( 'a' ); var ButtonText = document.createTextNode( collapseCaption ); Button.className = 'collapseButton'; /* Styles are declared in Common.css */ ButtonLink.style.color = Header.style.color; ButtonLink.setAttribute( 'id', 'collapseButton' + tableIndex ); ButtonLink.setAttribute( 'href', '#' ); $( ButtonLink ).on( 'click', $.proxy( handleButtonLink, ButtonLink, tableIndex ) ); ButtonLink.appendChild( ButtonText ); Button.appendChild( document.createTextNode( '[' ) ); Button.appendChild( ButtonLink ); Button.appendChild( document.createTextNode( ']' ) ); Header.insertBefore( Button, Header.firstChild ); tableIndex++; } } for ( i = 0; i < tableIndex; i++ ) { if ( $( NavigationBoxes[i] ).hasClass( 'collapsed' ) || ( tableIndex >= autoCollapse && $( NavigationBoxes[i] ).hasClass( 'autocollapse' ) ) ) { window.collapseTable( i ); } else if ( $( NavigationBoxes[i] ).hasClass ( 'innercollapse' ) ) { var element = NavigationBoxes[i]; while ((element = element.parentNode)) { if ( $( element ).hasClass( 'outercollapse' ) ) { window.collapseTable ( i ); break; } } } } } $(createCollapseButtons); /** Dynamic Navigation Bars (experimental) ************************************* * * Description: See [[Wikipedia:NavFrame]]. * Maintainers: UNMAINTAINED */ // set up the words in your language var NavigationBarHide = '[' + collapseCaption + ']'; var NavigationBarShow = '[' + expandCaption + ']'; // shows and hides content and picture (if available) of navigation bars // Parameters: // indexNavigationBar: the index of navigation bar to be toggled window.toggleNavigationBar = function ( indexNavigationBar, event ) { var NavToggle = document.getElementById( 'NavToggle' + indexNavigationBar ); var NavFrame = document.getElementById( 'NavFrame' + indexNavigationBar ); var NavChild; if ( !NavFrame || !NavToggle ) { return false; } /* if shown now */ if ( NavToggle.firstChild.data === NavigationBarHide ) { for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) { NavChild.style.display = 'none'; } } NavToggle.firstChild.data = NavigationBarShow; /* if hidden now */ } else if ( NavToggle.firstChild.data === NavigationBarShow ) { for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { if ( $( NavChild ).hasClass( 'NavContent' ) || $( NavChild ).hasClass( 'NavPic' ) ) { NavChild.style.display = 'block'; } } NavToggle.firstChild.data = NavigationBarHide; } event.preventDefault(); }; /* adds show/hide-button to navigation bars */ function createNavigationBarToggleButton() { var indexNavigationBar = 0; var NavFrame; var NavChild; /* iterate over all < div >-elements */ var divs = document.getElementsByTagName( 'div' ); for ( var i = 0; (NavFrame = divs[i]); i++ ) { /* if found a navigation bar */ if ( $( NavFrame ).hasClass( 'NavFrame' ) ) { indexNavigationBar++; var NavToggle = document.createElement( 'a' ); NavToggle.className = 'NavToggle'; NavToggle.setAttribute( 'id', 'NavToggle' + indexNavigationBar ); NavToggle.setAttribute( 'href', '#' ); $( NavToggle ).on( 'click', $.proxy( window.toggleNavigationBar, window, indexNavigationBar ) ); var isCollapsed = $( NavFrame ).hasClass( 'collapsed' ); /** * Check if any children are already hidden. This loop is here for backwards compatibility: * the old way of making NavFrames start out collapsed was to manually add style="display:none" * to all the NavPic/NavContent elements. Since this was bad for accessibility (no way to make * the content visible without JavaScript support), the new recommended way is to add the class * "collapsed" to the NavFrame itself, just like with collapsible tables. */ for ( NavChild = NavFrame.firstChild; NavChild != null && !isCollapsed; NavChild = NavChild.nextSibling ) { if ( $( NavChild ).hasClass( 'NavPic' ) || $( NavChild ).hasClass( 'NavContent' ) ) { if ( NavChild.style.display === 'none' ) { isCollapsed = true; } } } if ( isCollapsed ) { for ( NavChild = NavFrame.firstChild; NavChild != null; NavChild = NavChild.nextSibling ) { if ( $( NavChild ).hasClass( 'NavPic' ) || $( NavChild ).hasClass( 'NavContent' ) ) { NavChild.style.display = 'none'; } } } var NavToggleText = document.createTextNode( isCollapsed ? NavigationBarShow : NavigationBarHide ); NavToggle.appendChild( NavToggleText ); /* Find the NavHead and attach the toggle link (Must be this complicated because Moz's firstChild handling is borked) */ for( var j = 0; j < NavFrame.childNodes.length; j++ ) { if ( $( NavFrame.childNodes[j] ).hasClass( 'NavHead' ) ) { NavToggle.style.color = NavFrame.childNodes[j].style.color; NavFrame.childNodes[j].appendChild( NavToggle ); } } NavFrame.setAttribute( 'id', 'NavFrame' + indexNavigationBar ); } } } $(createNavigationBarToggleButton); // ============================== // Force IP to preview before saving changes. // Copyright Marc Mongenet, 2006 function forcePreview() { if (wgUserName != null) return; if (document.getElementById('editpage-copywarn')) { var saveButton = document.getElementById("wpSave"); var oldHTML = document.getElementById('editpage-copywarn').innerHTML; var newHTML = oldHTML + '<p style="width:100%;background-color:#FFE4E1;border:2px solid #700050; color:#000000; font-size:90%; padding:2px;"> با <a href="//fa.wikipedia.org/w/index.php?title=وپ:نام">نام کاربری </a> وارد شوید یا برای فعال شدن دکمه «صفحه ذخیره شود»، ابتدا از دکمه «پیش نمایش» استفاده کنید.</p>'; if (!saveButton) return; if (location.search.search(/&action=edit/) == -1) return; document.getElementById('editpage-copywarn').innerHTML = newHTML; saveButton.disabled = true; saveButton.style.fontWeight = "normal"; document.getElementById("wpPreview").style.fontWeight = "bold"; } } $(forcePreview); /** Main Page layout fixes ********************************************************* * * Description: Adds an additional link to the complete list of languages available. * Maintainers: [[User:AzaToth]], [[User:R. Koot]], [[User:Alex Smotrov]] */ if (wgPageName == 'صفحهٔ_اصلی' || wgPageName == 'بحث:صفحه_اصلی') $( function () { mw.util.addPortletLink('p-lang', '//meta.wikimedia.org/wiki/فهرست ویکیپدیاها', 'فهرست کامل', 'interwiki-completelist', 'فهرست کامل'); } ) /** * Fill upload with preloadOnEmpty **/ $(function () { if (mw.config.get('wgPageName') === 'ویژه:بارگذاری_پرونده' && $('#wpUploadDescription').val() === '') { if (location.href.indexOf('wpForReUpload') === -1) { $('#wpUploadDescription').val($('#preloadOnEmpty').text()); } $('#mw-upload-permitted p').each(function () { this.innerHTML = this.innerHTML.replace(/pdf[,،、] /, ''); }); } }); /** WikiMiniAtlas ******************************************************* * * Description: WikiMiniAtlas is a popup click and drag world map. * This script causes all of our coordinate links to display the WikiMiniAtlas popup button. * The script itself is located on meta because it is used by many projects. * See [[Meta:WikiMiniAtlas]] for more information. * Maintainers: [[User:Dschwen]] */ mw.loader.load("//meta.wikimedia.org/w/index.php?title=MediaWiki:Wikiminiatlas.js&action=raw&ctype=text/javascript&smaxage=21600&maxage=86400"); /** * redirect redlinks for not autoconfirmed users * and hides "new article wizard" edit buttons for them * + * redirect new page creation with non-standard on title */ $(function () { // طبق اجماع &oldid=11798574 برای کاربرهای زیر ۲۵ ویرایش if (mw.config.get('wgUserEditCount') < 25 && mw.config.get('wgNamespaceNumber') === 0) { $($('.noarticletext').length !== 0 ? '#ca-edit a' : '.new').each(function() { this.href = this.href + encodeURI("&preload=الگو:ایجاد+مقاله/استخوانبندی&editintro=الگو:ایجاد+مقاله/ادیتنوتیس&summary=ایجاد+یک+مقاله+نو+از+طریق+ایجادگر&nosummary=&prefix=&minor=&create=درست+کردن+مقاله+جدید&withJS=MediaWiki:Intro-Welcome-NewUsers.js"); }); importScript("MediaWiki:Gadget-signit.js"); } // این کد با بهبودهایی کوچک عنوان صفحه را اصلاح میکند var uri = new mw.Uri(); if ((mw.config.get('wgAction') === "edit") && (mw.config.get('wgNamespaceNumber') === 0) && (uri.query.redirected !== "1") && (uri.query.title !== undefined) && (uri.query.redlink === "1")) { var oldTitle = uri.query.title.replace(/( |%20)/g, '_'); var title = oldTitle; for (var i = 0; i < 10; i++) { title = title.replace(new RegExp('[' + '٠١٢٣٤٥٦٧٨٩'[i] + i + ']', 'g'), '۰۱۲۳۴۵۶۷۸۹'[i]); // replaces Arabic and Arabic-indic digits at once } title = title .replace(/[ىۍېي]/g, "ی") .replace(/[كﻙﻚڪ]/g, "ک") .replace(/[ہەھ]/g, "ه") .replace(/:(?=[^ _])/g, ': ') .replace(/([^ _])\(/, '$1 (') .replace(/([\.،«»\:؛\sزرذدواژؤإأآءةa-zA-Z])\u200c/g, '$1') .replace(/\u200c[ _]/g, ' ') .replace(/(\u200c*$|^\u200c*)/g, '') .replace(/[\u200dـ]/g, '') .replace(/\(\s(.*?)\s\)/g, '($1)') .replace(/\s{2,}/g, ' ') .replace(/(ۀ|هٓ)/g, 'ه') .replace(/,/g, '،') .replace(/ابهام ?زدایی/g, 'ابهامزدایی'); if (title !== oldTitle) { uri.query.title = title; uri.query.redirected = "1"; window.location.href = uri.toString(); } } }); /** * قراردادن فرمولهای ریاضی در سمت چپ مناسب برای ویکیهای راست به چپ */ $(function(){ $("img.tex, span.texhtml").each(function () { if ($(this).parent().text().trim() === $(this).text() && $(this).parent().is("p, dd")) { $(this).parent().css({ direction: 'ltr', padding: '1em 0' }); } }); }); /** * Source codes pages direction and and pre white-space */ if (wgNamespaceNumber == 2 || wgNamespaceNumber == 8 || wgNamespaceNumber == 4) { if (/\.(js|css|py)$/.test(wgPageName)) { mw.util.addCSS('.diff-addedline, .diff-deletedline, .diff-context { direction: ltr; } ' + '#wpTextbox1 { direction: ltr; }'); } } /*</pre> === ToggleImage === <pre>*/ // Adapted from French Wikipedia function toggleImage (group, remindex, shwindex) { $("#ImageGroupsGr" + group + "Im" + remindex).hide(); $("#ImageGroupsGr" + group + "Im" + shwindex).show(); } function ImageGroup() { $('div.ImageGroup').each(function(i, group) { var unitnode = $('div.ImageGroupUnits', group).get(0); if (unitnode == undefined) { return 1; } var units = jQuery(unitnode).children('.center'); var count = units.get().length; if (count <= 1) { return 1; } units.each(function(j, currentimage) { $(currentimage).attr('id', "ImageGroupsGr" + i + "Im" + j); var leftlink = jQuery('<a href="#" style="text-decoration:none" />'); var rightlink = jQuery('<a href="#" style="text-decoration:none" />'); if (j != 0) { leftlink.text('▶').click(function() { toggleImage(i, j, j - 1); return false; }); } if (j != count - 1) { rightlink.text('◀').click(function() { toggleImage(i, j, j + 1); return false; }); } jQuery('<div/>').css({ 'font-size' : '110%', 'font-weight' : 'bold' }) .append(leftlink) .append('<tt>(' + String(j+1).replace(/1/g, "۱").replace(/2/g, "۲").replace(/3/g, "۳").replace(/4/g, "۴").replace(/5/g, "۵").replace(/6/g, "۶").replace(/7/g, "۷").replace(/8/g, "۸").replace(/9/g, "۹").replace(/0/g, "۰") + ' از ' + String(count).replace(/1/g, "۱").replace(/2/g, "۲").replace(/3/g, "۳").replace(/4/g, "۴").replace(/5/g, "۵").replace(/6/g, "۶").replace(/7/g, "۷").replace(/8/g, "۸").replace(/9/g, "۹").replace(/0/g, "۰") + ')</tt>') .append(rightlink) .prependTo(jQuery(currentimage)); if (j != 0) { $(currentimage).hide().addClass('noprint'); } }); }); } $(ImageGroup); // Newbies are misusing wikilove instead using talk pages add new section // hiding WikiLove from not autoconfirmed users or without more than 100 edits if ($.inArray('autoconfirmed', mw.config.get('wgUserGroups')) === -1 || mw.config.get('wgUserEditCount') < 100) { mw.util.addCSS('#ca-wikilove { display: none; }'); } //Help Abuse Filter #106 to tag Recreated Pages which have delete log $(function () { if ($.inArray(mw.config.get('wgAction'), ['edit', 'submit']) !== -1 && $('.mw-warning-with-logexcerpt .mw-logline-delete').length !== 0) { $('#editform input[type=submit]').click(function () { $('#wpSummary').val($('#wpSummary').val() + ""); }); } });