“MediaWiki:Common.css”与“MediaWiki:Common.js”:页面之间的差异

H萌娘,万物皆可H的百科全书!
(页面间差异)
跳到导航 跳到搜索
imported>=海豚=
无编辑摘要
 
imported>=海豚=
(撤销=海豚=讨论)的版本31942)
 
第1行: 第1行:
/* 放置于这里的CSS将应用于所有皮肤 */
/* eslint-disable no-var */
/*
/* eslint-disable no-magic-numbers */
由用户850710247liu制作 皮肤界面,参考Github添 了Emoji支持
/* global OO, mediaWiki, jQuery */
  *  更改后 同步到 [[MediaWiki:Gadget-GothicMoe.css]]
// <nowiki>
/这里 任何JavaScript将在全站
  *  请尊重版权,以下代码复制需 注明原自H萌娘,并且附上URL地址http://www.hmoegirl.com/MediaWiki:Common.js
* 版权协定:知识共享 署名-非商业性使用- 相同方式共享 3.0
*  loader模块 写法参见 https://www.mediawiki.org/wiki/ResourceLoader/Modules#mw.loader.load
  */
  */
/* 春季主题背景---画画的纱雾酱*/
"use strict";
body {
(function($, mw) { //使用匿名函数防止污染顶级变量
   opacity: 0.9;
   /* MediaViewer#populateStatsFromXhr 错误屏蔽 */
   background-image:url(https://www.hmoegirl.com/images/f/f4/%E6%AD%A3%E5%9C%A8%E7%94%BB%E7%94%BB%E7%9A%84%E7%BA%B1%E9%9B%BE.png);
   (function() {
   background-position:right 40% bottom 45%;
     var getResponseHeader = XMLHttpRequest.prototype.getResponseHeader;
    background-size:670px;
     XMLHttpRequest.prototype.getResponseHeader = function(name) {
    background-attachment:fixed;
       return ("\n" + this.getAllResponseHeaders().toLowerCase()).includes("\n" + name.toLowerCase() + ": ") ? getResponseHeader.call(this, name) : (console.debug('Refused to get unsafe header "' + name + '"\n', this, "\n", new Error().stack), null);
    background-repeat:no-repeat;
     };
}
    })();
/*全站样式*/
    //Extension:MultimediaViewer的半透明化修改,用于保持背景文字处于原位,本应修改插件达成的,暂时先用JavaScript应急处理下
body {
    function multimediaViewer() {
   font-size: 108%;
     var _scrollTo = window.scrollTo;
   -moz-hyphens: auto;
     var flag = location.hash !== "";
   -webkit-hyphens: auto;
     window.scrollTo = function scrollTo(x_option, y) {
   hyphens: auto;
       if (flag) {
}
         console.info("Prevent multimediaViewer called");
.mw-body-content {
       } else {
   line-height: 1.85;
         if (y === undefined) { _scrollTo(x_option); } else { _scrollTo(x_option, y); }
}
       }
.oo-ui-window-content {
     };
   font-size: 89.3%;
     setInterval(function() {
}
       $("a.image img[data-file-width], a.image img[data-file-height], .mw-mmv-filepage-buttons a.mw-mmv-view-expanded").not(".multimediaViewerScrollSet").each(function() {
.mw-label {
         this.addEventListener("click", function(e) {
   white-space: nowrap;
           if ($(e.target).closest(".TabLabelText")[0] || $(e.target).closest("a").closest(".mw-customtoggle")[0]) {
}
             e.preventDefault();
body .ui-dialog .ui-widget-header {
             e.stopPropagation();
   background: #f1f1f1 !important;
             e.stopImmediatePropagation();
}
             $($(e.target).closest(".TabLabelText")[0] || $(e.target).closest("a").closest(".mw-customtoggle")[0]).click();
body .ui-button {
             return false;
   box-shadow: 0 0 0 0 !important;
           }
}
           flag = true;
::selection {
         }, captureSupported ? {
   background: rgba(0,0,0,.1);
           capture: true,
   text-shadow: none;
         } : true);
}
         $(this).addClass("multimediaViewerScrollSet");
::-webkit-scrollbar {
       });
  height: 10px;
       if ($(".mw-mmv-close")[0]) {
  width: 10px;
         if (mw.config.get("wgMultimediaViewer") !== "on") {
}
           mw.config.set("wgMultimediaViewer", "on");
::-webkit-scrollbar-thumb {
           $(".mw-mmv-image").off("click")[0].addEventListener("click", function(e) {
  background: rgb(213, 213, 213);
             if ($(e.target).is("img")) {
  border-radius: 6px;
               window.open($(e.target).attr("src").replace(/(img\.moegirl\.org\/common\/)thumb\/([a-z\d]+\/[a-z\d]+\/)([^/]+)\/\d+px-\3/i, "$1$2$3"), "_blank").focus();
}
               e.preventDefault();
::-webkit-scrollbar-thumb:hover {
               e.stopPropagation();
  background: rgb(196, 196, 196);
               e.stopImmediatePropagation();
}
               return false;
/* 公告栏滚动Rollnews */
             } else if ($(e.target).closest(".error-box")[0]) { return; }
#scrollDiv {
             $(".mw-mmv-close").click();
   width: 100%;
           }, captureSupported ? {
   height: 25px;
             capture: true,
   line-height: 25px;
           } : true);
   overflow: hidden
         }
}
       } else if (mw.config.get("wgMultimediaViewer") === "on") {
#scrollDiv ul {
         flag = false;
   margin-left: 0!important;
         mw.config.set("wgMultimediaViewer", "off");
}
       }
#scrollDiv li {
      }, 137);
   background-color: rgb(245,245,245,0.3);
   height: 25px;
   padding-left: 0px;
   list-style: none;
}
#localNotice {
   background-color: rgb(245,245,245,0.3);
}
/* 侧边栏、顶部栏、页脚 */
.mw-body {
border-left: 1px solid #bbb;
border-bottom: 1px solid #bbb;
border-top: none;
border-right: none;
}
.mw-wiki-logo {
   background-image: url(https://www.hmoegirl.com/images/2/2b/Hmoegirl.png);
}
#p-personal {
   font-size: 17.5px;
   right: 1em;
}
div.vectorTabs {
   font-size: 16px;
   padding-top: 2px;
}
.vectorTabs #ca-unwatch.icon a, .vectorTabs #ca-watch.icon a, .vectorTabs #ca-wikilove.icon a {
   padding-top: 3.4em;
}
.vectorMenuCheckbox {
  height:110%;
}
   #content {
      margin-left: 214px;
    }
    }
   //Tabs
   function tabs() {
     var defaultStyle = {
       purple: {
         labelColor: " ", //anti check
         labelBackgroundColor: "#9070c0",
         labelBorderColor: "#b090e0 #7050a0 #9070c0 #b090e0",
         labelPadding: ".2em .3em .2em .3em",
         textBorderColor: "#9070c0",
         textBackgroundColor: "#f0edf5",
         textPadding: "1em",
       },
       green: {
         labelColor: " ",
         labelBackgroundColor: "#75c045",
         labelBorderColor: "#90d060 #60b030 #75c045 #90d060",
         labelPadding: ".2em .3em .2em .3em",
         textBorderColor: "#75c045 #60b030 #60b030 #75c045",
         textBackgroundColor: "#f5fffa",
         textPadding: "1em",
       },
       red: {
         labelColor: " ",
         labelBackgroundColor: "#FF0000",
         labelBorderColor: "#FF8888 #CC0000 #FF0000 #FF8888",
         labelPadding: ".2em .3em .2em .3em",
         textBorderColor: "#FF0000 #CC0000 #CC0000 #FF0000",
         textBackgroundColor: "#fffafa",
         textPadding: "1em",
       },
       blue: {
         labelColor: " ",
         labelBackgroundColor: "#5b8dd6",
         labelBorderColor: "#88abde #3379de #5b8dd6 #88abde",
         labelPadding: ".2em .3em .2em .3em",
         textBackgroundColor: "#f0f8ff",
         textBorderColor: "#5b8dd6 #3379de #3379de #5b8dd6",
         textPadding: "1em",
       },
       yellow: {
         labelColor: " ",
         labelBackgroundColor: "#ffe147",
         labelBorderColor: "#ffe977 #ffd813 #ffe147 #ffe977",
         labelPadding: ".2em .3em .2em .3em",
         textBackgroundColor: "#fffce8",
         textBorderColor: "#ffe147 #ffd813 #ffd813 #ffe147",
         textPadding: "1em",
       },
       orange: {
         labelColor: " ",
         labelBackgroundColor: "#ff9d42",
         labelBorderColor: "#ffac5d #ff820e #ff9d42 #ffac5d",
         labelPadding: ".2em .3em .2em .3em",
         textBackgroundColor: "#ffeedd",
         textBorderColor: "#ff9d42 #ff820e #ff820e #ff9d42",
         textPadding: "1em",
       },
       black: {
         labelColor: " ",
         labelBackgroundColor: "#7f7f7f",
         labelBorderColor: "#999999 #4c4c4c #7f7f7f #999999",
         labelPadding: ".2em .3em .2em .3em",
         textBackgroundColor: "#e5e5e5",
         textBorderColor: "#7f7f7f #4c4c4c #4c4c4c #7f7f7f",
         textPadding: "1em",
       },
     };
     $("body").addClass("tab");
     // A Class
     function StyleSheet() {}
     StyleSheet.prototype.getOwnPropertyNamesLength = function getOwnPropertyNamesLength() {
       return Object.getOwnPropertyNames(this).length;
     };
     String.prototype.toLowerFirstCase = function toLowerFirstCase() {
       return this[0].toLowerCase() + this.substring(1);
     };
     $(".Tabs").each(function() {
       if ($(this).children(".TabLabel")[0]) { return true; }
       var self = $(this),
         classList = Array.from(this.classList).filter(function(n) { return n in defaultStyle; }),
         data = $.extend({
           labelPadding: "2px",
           labelBorderColor: "#aaa",
           labelColor: "green",
           labelBackgroundColor: $("#content").css("background-color"),
           textPadding: "20px 30px",
           textBorderColor: "#aaa",
           textBackgroundColor: "white",
           defaultTab: 1,
         }, classList[0] ? defaultStyle[classList[0]] || {} : {}, this.dataset || {}),
         tabLabel = self.append('<div class="TabLabel"></div>').children(".TabLabel"),
         tabContent = self.append('<div class="TabContent"></div>').children(".TabContent"),
         labelPadding = data.labelPadding,
         labelColor = data.labelColor,
         styleSheet = {
           label: new StyleSheet(),
           text: new StyleSheet(),
         },
         defaultTab = parseInt(data.defaultTab);
       self.children(".Tab").each(function() {
         if ($(this).children(".TabLabelText").text().replace(/\s/g, "").length || $(this).children(".TabLabelText").children().length) {
           $(this).children(".TabLabelText").appendTo(tabLabel);
           $(this).children(".TabContentText").appendTo(self.children(".TabContent"));
         }
         $(this).remove();
       });
       if (isNaN(defaultTab) || defaultTab <= 0 || defaultTab > tabLabel.children(".TabLabelText").length) { defaultTab = 1; }
       tabLabel.children(".TabLabelText").on("click", function() {
         var label = $(this);
         label.addClass("selected").siblings().removeClass("selected").css({
           "border-color": "transparent",
           "background-color": "inherit",
         });
         tabContent.children(".TabContentText").eq(tabLabel.children(".TabLabelText").index(label)).addClass("selected").siblings().removeClass("selected").removeAttr("style");
         if (styleSheet.label.getOwnPropertyNamesLength()) { label.css(styleSheet.label); }
       }).eq(defaultTab - 1).click();
       if (labelPadding) { tabLabel.children(".TabLabelText").css("padding", labelPadding); }
       ["labelBorderColor", "labelBackgroundColor", "textPadding", "textBorderColor", "textBackgroundColor"].forEach(function(n) {
         var target = /^label/.test(n) ? "label" : "text",
           key = n.replace(target, "").toLowerFirstCase();
         styleSheet[target][key] = data[n];
       });
       if (labelColor) {
         styleSheet.label.borderTopColor = labelColor;


   .portal {
       } else if (styleSheet.label.borderColor) {
      background: transparent !important;
         styleSheet.label.borderTopColor = "green";
       }
       tabLabel.find(".selected").click();
       if (styleSheet.text.getOwnPropertyNamesLength()) { tabContent.css(styleSheet.text); }
       if (data.autoWidth === "yes") { self.css("display", "inline-block"); }
      });
    }
    }
 
   //子页面页顶链接
    #mw-panel {
    function subpage_links() {
      width: 200px !important;
      var links = mw.config.get("wgPageName").split("/"),
     border-right: 1px solid #bbb;
       link = "",
     background: rgb(254,254,254,0.95) !important;
       subpages = $(".subpages")[0] ? $(".subpages").remove().empty().text("<") : $('<span class="subpages"/>').text("<"),
     padding-left: 14px !important;
       length = links.length - 1,
   }
       index;
  
      if (mw.config.get("wgPageName").indexOf("Special: 移动页面") !== -1) { links.splice(0, 1); }
   #p-logo {
      for (index = 0; index < length; index++) {
     left: 0px;
       link += "/" + links[index];
      padding-left: 2px;
       subpages.append($("<a/>", {
   }
         text: " " + links[index],
 
         href: link,
   #p-logo a {
       }));
     padding-left: 40px;
       if (length - index > 1) { subpages.append(" |"); }
     left: 0px;
      }
     border-right: 1px solid #aaa;
      if (subpages.find("a")[0]) { $("#contentSub").prepend(subpages); }
   }
   #p-logo a:hover {
     opacity: 1.0;
   }
 
   #mw-head {
      background-color: rgb(254,254,254,0.94);
     opacity: 1.0;
     box-shadow: 0px 1px 2px #aaa;
     -webkit-transition-property: opacity !important;
     -moz-transition-property: opacity !important;
     -o-transition-property: opacity !important;
     -ms-transition-property: opacity !important;
     transition-property: opacity !important;
     -webkit-transition-duration: 0.5s !important;
      -moz-transition-duration: 0.5s !important;
      -o-transition-duration: 0.5s !important;
     -ms-transition-duration: 0.5s !important;
     transition-duration: 0.25s !important;
   }
div.vectorMenu {
   font-size: 92%;
}
 
   #mw-head:hover {
     opacity: 1.0 !important;
   }
 
   .uls-settings-trigger {
     display: none !important;
   }
 
   #left-navigation {
     margin-left: 233px !important;
    }
    }
#mw-page-base {
   //跨站重定向页顶链接
    height: 104px;
    function crossDomain_link() {
}
     var url = new mw.Uri(new mw.Uri().query.rdfrom);
#left-navigation,
     var link = url.query.title;
#right-navigation {
     var domain = url.host;
   margin-top: 60px;
     var crossDomain = $("<div/>");
}
     var anchor = $("<a/>");
#mw-head div.vectorMenu h4 {
     crossDomain.text("<");
   height: 1.9em;
     anchor.attr("href", url + "").text(link + "【来自 " + domain + "】");
   margin-bottom: 0;
     crossDomain.append(anchor);
   padding-top: 1.25em;
     $("#contentSub").prepend(crossDomain);
   padding-bottom: 0;
   padding-right: 0.5em;
}
#mw-panel div.portal {
   padding-bottom: 0.7em;
   padding-top: 0.4em;
}
#mw-panel #p-logo .mw-wiki-logo {
   width: 175px;
}
#mw-panel {
   font-size: 18.5px;
   width: 11.6rem;
}
   #mw-head li {
     background: transparent !important;
    }
    }
 
   //重复文件列表函数
  #mw-panel,#mw-head {
   function duplicatedFileList() {
      z-index: 2;
     if (window.location.href.indexOf("title") === -1) { window.location.replace("http://zh.moegirl.org/index.php?title=Special:ListDuplicatedFiles&limit=500&offset=0"); }
      line-height: 1.7 !important;
     $("#mw-content-text .mw-spcontent ol").attr("id",
     font-weight: 300 !important;
       "picOl");
     $("#picOl").before('<p id="picOlTitle">图片列表:</p>').after('<p id="MP3OlTitle">MP3列表:</p><ol start="1" id="MP3Ol"></ol>');
     $("#picOlTitle, #MP3OlTitle").hide();
     $("#picOl").find("[href$='.mp3'], [href$='.ogg']").parent().appendTo("#MP3Ol");
     if ($("#picOl").find("li").length) { $("#picOlTitle").show(); }
      if ($("#MP3Ol").find("li").length) { $("#MP3OlTitle").show(); }
      $(".mw-spcontent > p:nth-child(1), .mw-spcontent > p:nth-child(2), .mw-spcontent > p:nth-child(7)").hide();
    }
    }
 
   //编辑请求
#mw-panel .portal .body li {
   function editRequest() {
   line-height: 1.6em;
     var nsIds = mw.config.get("wgNamespaceIds"),
}
       nsId = mw.config.get("wgNamespaceNumber"),
   .mw-wiki-logo{
       ns = [];
      padding-left: 5px !important;
     for (var i in nsIds) {
      padding-top: 10px !important;
       if (nsIds[i] === nsId) { ns.push(i); }
      border: none !important;
     }
     if (!ns[0]) { return; }
     var page = mw.config.get("wgPageName"),
       talkns;
     for (var j = 0, l = ns.length; j < l; j++) {
       if (/^[A-Za-z0-9]+[ _]talk$/i.test(ns[j])) { return; }
       if (/^[a-zA-Z0-9]+$/.test(ns[j])) { talkns = ns[j] + "_talk:"; }
       page = page.replace(new RegExp("^" + ns[j] + ":", "i"), "");
     }
     var talkpage = talkns + page;
      var container = $("<div/>", {
       "class": "editRequest",
     });
     container.append("您虽然无权编辑本页面,但您可以点击右侧按钮在本页的讨论页提出编辑请求,让可以编辑的人代为编辑:");
      $("<span/>").addClass("newComment").text("提出编辑请求").on("click", function() {
       window.open("https://zh.moegirl.org/index.php?action=edit&preload=Template:编辑请求/comment&preloadtitle=编辑请求 - " + mw.config.get("wgUserName") + "&section=new&title=" + talkpage, "_blank");
     }).appendTo(container);
      $("#mw-content-text").children(".wikiEditor-ui:first, textarea[readonly]:first").before("<hr>").before(container);
    }
    }
.clear-div {
    //防滥用即将删除模板
    clear: both;
    function antiAbuseListener(textarea, event) {
}
     var filters = [
.uls-trigger{
       "{{ 即将删除",
    display: none;
       "{{ 即將刪除",
}
       "{{ 挂删",
div.vectorMenu div.menu {
       "{{模板: 即将删除",
   top: 2.8em;
       "{{ 模板: 即將刪除",
   width: 100%;
       "{{template: 即将删除",
   background-color: rgba(251,251,251,0.9);
       "{{template: 即將刪除",
   border: 1px solid #a7d7f9;
       "[[分类: 即将删除的页面",
   border-top: transparent;
       "[[分類: 即將刪除的頁面",
}
       "[[category: 即将删除的页面",
#mw-panel .portal .body li a:visited {
       "[[category: 即將刪除的頁 ",
  color: #0645ad;
       "{{文件 转移到萌娘共享",
}
       "{{ 文件轉移到萌娘共享",
#mw-head .portal .body li a:visited {
       "{{ 模板:文 件转移到萌娘共享",
  color: #0645ad;
       "{{ 模板: 文件轉移到萌娘共享",
}
       "{{template: 文件转移到萌娘共享",
#catlinks {
       "{{template: 文件轉移到萌娘共享",
background-color: rgba(251,251,251,0.3);
       "[[分类: 需要删除执行员删除的页面",
}
       "[[分類: 需要刪除執 員刪除的頁面",
.oo-ui-popupWidget-anchored-top {
       "[[category: 需要删除执 员删除的页 ",
   z-index: 10000;
       "[[category: 需要刪除執行員刪除的頁面",
}
     ];
#mp-banner {
     var text1 = textarea.value;
   margin: -1.7em;
     text1 = text1.replace(/<\/?(?:nowiki|noinclude)>/g, "");
   margin-top: -4.1em;
     text1 = text1.replace(/<(onlyinclude|includeonly)>.*?<\/\1>/g, "");
   background-image: url(https://www.hmoegirl.com/images/0/09/80468767.jpg);
     var text2 = textarea.value;
}
     text2 = text2.replace(/<\/?(?:onlyinclude|includeonly)>/g, "");
#footer {
     text2 = text2.replace(/<(nowiki|noinclude)>.*?<\/\1>/g, "");
   margin-left: 12.4em;
     var results = [];
   padding: 1.25em;
     for (var i = 0, l = filters.length; i < l; i++) {
}
       var regExp = new RegExp(filters[i].replace(/\[/g, "\\["), "i");
/* 谷歌翻译框调整*/
       if (regExp.test(text1) || regExp.test(text2)) { results.push(filters[i]); }
.goog-te-gadget {
     }
   margin-left: inherit!important;
     if (results.length > 0) {
   max-width: 95%!important;
       var messageDialog = new OO.ui.MessageDialog();
   background-color: transparent;
       var windowManager = new OO.ui.WindowManager();
}
       $("body").append(windowManager.$element);
/* 标题字型调整*/
       windowManager.addWindows([messageDialog]);
#firstHeading {
       messageDialog.title.$label.html("H萌娘提醒您<br>您 的编辑 包含禁止内容!");
   font-family: sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
       messageDialog.message.$label.html("<br>您提交的内容包含以下部分,被禁止提交:<br><br><ul>" + results.map(function(result) {
   font-weight: 500;
         return "<li>" + result + "</li>";
   padding-bottom: 6px;
       }).join("") + '</ul><br><br>如果您认为您的编辑无误,请在自 保存编辑内容后到<a target="_blank" rel="nofollow noreferrer noopener" class="external text" href="https://zh.moegirl.org/Talk:%E6%8F%90%E9%97%AE%E6%B1%82%E5%8A%A9%E5%8C%BA">提问求助区</a>提问。');
   font-variant: small-caps;
       windowManager.openWindow(messageDialog, {
   font-size: 170%;
         actions: [{
}
           action: "accept",
h2,
           label: "我知道了",
h3,
           flags: "primary",
h4,
         }],
h5,
       });
h6 {
       event.preventDefault();
     font-family: "roboto",sans-serif !important;
       event.stopImmediatePropagation();
color: #404040 !important;
       event.stopPropagation();
line-height: 1.8 !important;
       return false;
border-bottom-color: rgba(0, 0, 0, .1) !important;
     }
}
.mw-body-content h2 {
   font-weight: 540;
}
#siteSub {
   display: inline;
   font-size: 100%;
   font-weight: 400; /* 400 = normal */
   font-style: normal;
   text-align: right;
   padding-top: 11px;
   padding: 0.1em;
}
/* MW自带10em宽度,应该是留给测试链接的吧萌百没有就去掉 */
#p-personal ul {
   padding-left: 0;
}
/* 搜索框 */
#simpleSearch {
  max-width: 220px;
  background-image: none;
  padding: 0px 10px;
  opacity: 0.625;
  display: flex;
  align-items: center;
  transition: width 0.4s;
}
#simpleSearch:hover {
  border-color: var(--theme-color) !important;
}
#simpleSearch:focus-within {
  width: 240px;
}
#searchInput::-webkit-input-placeholder {
  color: var(--theme-color) !important;
}
#searchInput::input-placeholder {
  color: var(--theme-color) !important;
}
#simpleSearch #searchButton {
  right: 8px !important;
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E %3Cpath d='M505 442.7L405.3 343c-4.5-4.5-10.6-7-17-7H372c27.6-35.3 44-79.7 44-128C416 93.1 322.9 0 208 0S0 93.1 0 208s93.1 208 208 208c48.3 0 92.7-16.4 128-44v16.3c0 6.4 2.5 12.5 7 17l99.7 99.7c9.4 9.4 24.6 9.4 33.9 0l28.3-28.3c9.4-9.4 9.4-24.6.1-34zM208 336c-70.7 0-128-57.2-128-128 0-70.7 57.2-128 128-128 70.7 0 128 57.2 128 128 0 70.7-57.2 128-128 128z'%3E%3C/path%3E %3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E %3Cpath d='M505 442.7L405.3 343c-4.5-4.5-10.6-7-17-7H372c27.6-35.3 44-79.7 44-128C416 93.1 322.9 0 208 0S0 93.1 0 208s93.1 208 208 208c48.3 0 92.7-16.4 128-44v16.3c0 6.4 2.5 12.5 7 17l99.7 99.7c9.4 9.4 24.6 9.4 33.9 0l28.3-28.3c9.4-9.4 9.4-24.6.1-34zM208 336c-70.7 0-128-57.2-128-128 0-70.7 57.2-128 128-128 70.7 0 128 57.2 128 128 0 70.7-57.2 128-128 128z'%3E%3C/path%3E %3C/svg%3E");
  background-color: var(--theme-color) !important;
  background-image: none !important;
  background-color: var(--theme-color) !important;
  width: 20px !important;
  height: 20px !important;
  padding-block-start: 21px;
}
#simpleSearch:hover>#searchButton {
  animation: shake 0.4s 1 forwards;
}
 
#p-search {
   float: left;
   margin-right: 0.5em;
   margin-left: 0.6em;
   margin-top: 0.1em;
}
@keyframes shake {
  0%,
  50% {
   transform: rotate(5deg) scale(1.05);
  }
  25%,
  75% {
   transform: rotate(-5deg) scale(1.05);
  }
  100% {
   transform: rotate(0deg) scale(1.05);
  }
}
.oo-ui-actionFieldLayout-input {
   font-size: 95%;
}
/* 搜索界 */
.mw-search-results {
   max-width: 50em;
}
/* 编辑历史调整*/
#pagehistory li.selected {
   background-color: transparent;
}
/* 隐藏编辑提示修改和上传 文件 协议 */
div.sysop-show, p.sysop-show {
   display: none;
}
.mw-htmlform-field-Licenses{
   display: none;
}
/* 链接显示效果 */
a:hover {
  text-decoration: none;
  color: #2a4b8d;
}
a, a:visited {
   text-decoration: none;
   color: #3366cc;
}
.mw-body a.external:visited {
   color: #3366cc;
}
/* 斜体字右边距加大看以防止 字挤在一起 */
#mw-content-text i {
   margin-right: 3px;
}
/* Extension:MultimediaViewer的半透明化修改  */
.mw-mmv-overlay {
   position: fixed;
   top: 0;
   left: 0;
   right: 0;
   bottom: 0;
   background-color: rgba(0,0,0,0.8);
   opacity: 0.73;
}
body.mediawiki.mw-mmv-lightbox-open #mw-page-base,
body.mediawiki.mw-mmv-lightbox-open #mw-head-base,
body.mediawiki.mw-mmv-lightbox-open #mw-navigation,
body.mediawiki.mw-mmv-lightbox-open #content,
body.mediawiki.mw-mmv-lightbox-open #footer,
body.mediawiki.mw-mmv-lightbox-open #globalWrapper {
   display: inherit;
}
body.mediawiki.mw-mmv-lightbox-open > *  {
   display: inherit;
}
body.mediawiki.mw-mmv-lightbox-open > script,
body.mediawiki.mw-mmv-lightbox-open > style {
   display: none;
}
body.mediawiki.mw-mmv-lightbox-open {
   overflow: hidden;
}
body .mw-mmv-wrapper {
   position: fixed;
}
/* mutilmediaViewer 信息栏修复 */
.mw-mmv-image-metadata-column.mw-mmv-image-metadata-desc-column {
   width: 30%;
}
.mw-mmv-image-metadata-column.mw-mmv-image-metadata-links-column {
   width: 70%;
   max-width: 70%;
}
ul.mw-mmv-image-links li {
   float: left;
   padding: .3em 1em;
}
div.mw-mmv-image-desc-div,
div.mw-mmv-image-links-div{
   display:block
}
div.metadata-panel-is-closed .mw-mmv-image-links li.mw-mmv-license-li {
   height:inherit;
   line-height:inherit;
}
.mw-mmv-warning-visible .mw-mmv-download-dialog .mw-mmv-dialog-down-arrow {
   background-color: #ffffff;
}
.mw-mmv-warning-visible .mw-mmv-dialog-warning,
.mw-mmv-warning-visible .mw-mmv-download-attribution {
   display: none !important;
}
/* 通用圆角框 */
.common-box {
   padding: .2em .4em;
   border: 0.7px solid #ddd;
   -moz-border-radius: 10px;
   -webkit-border-radius: 10px;
   -khtml-border-radius: 10px;
   -o-border-radius: 10px;
   border-radius: 10px;
   background: rgba(250,250,250,0.65)!important;
}
/* 数据表格 */
.mw-datatable.TablePager {
   line-height: 1.7;
   width: 100%;
   table-layout: fixed;
   word-wrap: break-word;
}
/* 隐藏首页标题、空 、分类、讨论、查看源代码tab */
.page-Mainpage h1.firstHeading,
.page-Mainpage #siteSub,
.page-Mainpage #contentSub,
.page-Mainpage #ca-viewsource,
.page-Mainpage #siteNotice,
.page-Mainpage #ca-talk,
.page-Mainpage #catlinks,
.page-Mainpage #footer #footer-info
{
   display: none;
}
/* 黑幕模板配合CSS */
/* 把这几 单独拎出来写,否则会被Firefox合并到“.heimu a”这条规则,然后又被上 的“点过外链不变色”规则override */
span.heimu a.external,
span.heimu a.external:visited,
span.heimu a.extiw,
span.heimu a.extiw:visited {
   color: #252525;
}
.heimu,
.heimu a,
a .heimu,
.heimu a.new {
   background-color: #252525;
   color: #252525;
   text-shadow: none;
}
body:not(.heimu_toggle_on) .heimu:hover,
body:not(.heimu_toggle_on) .heimu:active,
body:not(.heimu_toggle_on) .heimu.off {
   transition: color .13s linear;
   color: white!important;
}
body:not(.heimu_toggle_on) .heimu:hover a,
body:not(.heimu_toggle_on) a:hover .heimu,
body:not(.heimu_toggle_on) .heimu.off a,
body:not(.heimu_toggle_on) a:hover .heimu.off {
   transition: color .13s linear;
   color: lightblue;
}
body:not(.heimu_toggle_on) .heimu.off .new,
body:not(.heimu_toggle_on) .heimu.off .new:hover,
body:not(.heimu_toggle_on) .new:hover .heimu.off,
body:not(.heimu_toggle_on) .heimu.off .new,
body:not(.heimu_toggle_on) .heimu.off .new:hover,
body:not(.heimu_toggle_on) .new:hover .heimu.off {
   transition: color .13s linear;
   color: #BA0000;
}
/* 隐藏目录 */
#toc:not(.toc-custom) {
  display: none;
}
/* 图片页隐藏媒体查看器 */
.mw-mmv-filepage-buttons .mw-mmv-view-expanded, .mw-mmv-filepage-buttons .mw-mmv-view-config {
   display: none;
}
/* 导航条(完全没有apple风格的apple风面包屑orz) 来源:http://www.jankoatwarpspeed.com/examples/breadcrumb/ */
#breadcrumb {
   background-image: url(//img.moegirl.org/breadcrumb/bc_bg.png);
   color: red;
   border: solid 1px #cacaca;
   border-radius: 10px;
   overflow: hidden;
}
#breadcrumb span {
   float: left;
   padding-left: 10px;
}
#breadcrumb a {
   display: block;
   background: url(//img.moegirl.org/breadcrumb/bc_separator.png) no-repeat right;
   padding-right: 15px;
   color: #454545;
}
#breadcrumb a:hover {
   color: #35acc5;
}
/* info类模板 */
.infoBox {
   margin: 0 auto;
   box-shadow: 0 1px 2px 0 rgba(0,0,0,.14), 0 1px 5px 0 rgba(0,0,0,.12), 0 2px 1px -2px rgba(0,0,0,.2);
}
.infobox1 {
  margin:0 auto;
  border-radius: 5px;
  overflow: hidden;
}
.infobox2 {
  margin-top: 0.4em ;
  margin-left: 1em;
  padding: 0.2em;
  float: right;
  clear: right;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
  border-radius: 4px;
  overflow: hidden;
  background: rgba(251,251,251,0.7);
}
.infobox3 {
  margin:0 auto;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 1px 2px rgba(0, 0, 0, 0.10);
  border-radius: 15px;
  overflow: hidden;
}
.infoBoxTitle {
   margin: 3px auto;
   padding: 0;
   text-align: center;
   font-weight: 700;
}
.infoBoxIcon {
   display: table-cell;
   padding: 2px 0 2px .5em;
   vertical-align: middle;
}
.infoBoxText {
   display: table-cell;
   padding: .25em .5em .25em 1.3em;
   width: 100%;
   vertical-align: middle;
}
.infoBoxContent new{
  padding: 0.6em;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
  border-radius: 5px;
  overflow: hidden;
  background: rgba(251,251,251,0.7);
}
.infoBoxContent {
   padding: 5px;
   border-left-width: 0;
   background: #fbfbfb;
}
.infoBoxBelow {
   margin: 0 auto;
   padding: 0;
   text-align: center;
}
/* 回到顶部 */
.backToTop {
   display: none;
   width: 20px;
   padding: 5px 0;
   background-color: #000;
   color: #fff;
   font-size: 12px;
   text-align: center;
   position: fixed;
   _position: absolute;
   right: 0;
   bottom: 100px;
   _bottom: "auto";
   cursor: pointer;
   opacity: .6;
   filter: Alpha(opacity=60);
   z-index: 73;
}
.mw-mmv-lightbox-open .backToTop {
   display: none !important;
}
/* 隐藏编辑页面中 返回顶部按钮 */
.page-Mainpage .backToTop,
.action-edit .backToTop,
.action-submit .backToTop {
  display: none !important;
}
/*  编辑 区样式 */
.my-buttons {
   padding: 0em .6em .3em .6em;
}
.my-buttons a {
   text-decoration: none;
   border: 1px #069 outset;
   padding: .1em;
}
.my-buttons a:hover,
.my-buttons a:active {
   border-style: inset;
}
#wpTextbox1.mw-editfont-monospace{
font-size: 93%;
height: 450px;
}
#msupload-container.start-loading{
display:none;
}
#msupload-dropzone {
   padding: 3px;
   height: 19px
   font-size: small;
}
.client-js .editButtons .editHelp {
   display: inline-block!important;
}
.oo-ui-buttonElement-frameless.oo-ui-labelElement:first-child {
   margin-left: .1em;
}
.ve-ui-mwSaveDialog-summaryLabel {
   display: none;
}
.wikiEditor-ui-toolbar {
   background-color: #f8f9fa!important;
   box-shadow: 0 2px 1px 0 rgba(0,0,0,0.1)!important;
   background-image: none!important;
}
.wikiEditor-ui-toolbar .sections .section {
   background-color: #f8f9fa!important;
   box-shadow: 0 2px 1px 0 rgba(0,0,0,0.1)!important;
}
#msupload-dropzone {
   box-shadow: 0 2px 1px 0 rgba(0,0,0,0.1)!important;
}
#msupload-container {
   position: absolute;
}
.wikiEditor-ui-toolbar .tabs {
   margin-left: 24px;
   border-left: 1px solid #c8ccd1;
}
.wikiEditor-ui-toolbar .tabs span.tab.tab-advanced {
   padding-left: 7px;
}
.tool-button.tool-active, .tool.tool-active.oo-ui-buttonElement-frameless.oo-ui-iconElement {
   outline: transparent;
   background-color: transparent;
   box-shadow: none;
}
.CodeMirror-gutter-elt{
   display: none;
}
.CodeMirror-gutters {
   display: none;
}
/* 解决pre不换 的问题 */
pre {
   white-space: pre-wrap; /* CSS-3 */
   white-space: -moz-pre-wrap; /* Mozilla, since 1999 */
   white-space: -pre-wrap; /* Opera 4-6 */
   white-space: -o-pre-wrap; /* Opera 7 */
   word-wrap: break-word; /* Internet Explorer 5.5+ */
}
/* 页面底部导航框(2011年8月16日引自中文维基)(所谓大家族模板) */
table.navbox {
   clear: both;
   margin: auto;
   box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.24);
   padding: 1px;
   text-align: center;
   width: 100%;
   font-size: 101%!important;
   line-height: 1.8;
}
table.navbox+table.navbox {
   margin-top: -1px;
}
.navbox-title,
.navbox-abovebelow,
table.navbox th {
   padding-left: 1em;
   padding-right: 1em;
   text-align: center;
}
.navbox-group {
   font-weight: 700;
   padding-left: 1em;
   padding-right: 1em;
   white-space: nowrap;
}
.navbox,
.navbox-subgroup {
   background: none repeat scroll 0 0 #fdfdfd;
}
.navbox-list {
   border-color: #fdfdfd;
}
.navbox-title,
table.navbox th {
   background: none repeat scroll 0 0 #a5e4a5;
}
.navbox-abovebelow,
.navbox-group,
.navbox-subgroup .navbox-title {
   background: none repeat scroll 0 0 #c0ecc0;
}
.navbox-subgroup .navbox-group,
.navbox-subgroup .navbox-abovebelow {
   background: none repeat scroll 0 0 #e6f6e6;
}
.navbox-even {
   background: none repeat scroll 0 0 #f5fcf5;
}
.navbox-odd {
   background: none repeat scroll 0 0 transparent;
}
.collapseButton {
   float: right;
   font-weight: 400;
   text-align: right;
   width: auto;
}
.navbox .collapseButton {
   width: 6em;
}
/* Fix by case : Rev 1327309 ([[Special:Permalink/1327309]])
   Address alignment issue of nested tabs in Navbox */
.navbox .TabLabel {
   text-align: left;
}
/* Tabs */
.tab .TabLabelText {
   border-top: 3px solid transparent;
   padding: 1px;
   background: #fff;
   border-left: 1px solid transparent;
   border-right: 1px solid transparent;
   cursor: pointer;
   flex: none;
}
.tab .TabLabel {
   z-index: 2;
   position: relative;
   -webkit-user-select: none;
   -moz-user-select: none;
   -ms-user-select: none;
   -o-user-select: none;
   user-select: none;
   display: flex;
   flex-wrap: wrap;
}
.tab .TabLabelText.selected {
   border-top: 3px solid green;
   padding: 1px;
   background: white;
   border-left: 1px solid #aaa;
   border-right: 1px solid #aaa;
}
.tab .TabContent {
   background: white;
   padding: 20px 30px;
   position: relative;
   z-index: 1;
   border: 1px solid #aaa;
}
.tab .TabContentText {
   display: none;
}
.tab .TabContentText.selected {
   display: block;
}
.Tabs .Tab {
   border-bottom: 1px solid #aaa;
}
.Tabs .Tab:first-child {
   border-top: 1px solid #aaa;
}
.Tabs .Tab .TabLabelText {
   padding: 7px;
}
.Tabs .Tab .TabContentText {
   padding: 3px;
}
/* 表格宽度 */
.wikitable {
   max-width: 100%;
}
/* 缩略图居中*/
.thumb.tcenter {
   float: none;
   clear: both;
   display: block;
   margin: 0 auto;
}
/* 图片外框圆角化 */
.thumbinner {
  box-shadow: #666 0 0.4px 1px!important;
  border-radius: 5px!important;
  overflow: hidden!important;
}
/* 图库样式 */
   .thumbimage {
     border: 0px !important;
    }
    }


    .thumbcaption {
    function antiAbuse(textarea, submitButton, form) {
      margin: 7px 0px !important;
     mw.loader.using(["oojs-ui"]).then(function() {
       if (submitButton) {
         submitButton.addEventListener("click", function(e) {
           antiAbuseListener(textarea, e);
         }, captureSupported ? {
           capture: true,
         } : true);
       }
       if (form) {
         form.addEventListener("submit", function(e) {
           antiAbuseListener(textarea, e);
         }, captureSupported ? {
           capture: true,
         } : true);
       }
      });
    }
    }
 
   /* 函数执行体 */
    .thumbimage:hover {
    $(function() {
      opacity: 0.9 !important;
     //Template:heimu在safari上的暴力workaround
     mw.loader.using("jquery.client", function() {
       if ($.client.profile().name === "safari") {
         $(".heimu").on("click", function() {
           $(this).toggleClass("off");
         });
       }
     });
     var copyRightsNameSpaces = [ // 以下为允许添加版权声明的名字空间列表
       0, // (主)
       4, // H萌娘
       8, // MediaWiki
       10, // Template
       12, // Help
       614, // R18
     ];
     //滚动公告
     autoScroll("#scrollDiv");
     //Extension:MultimediaViewer的半透明化修改
     if ($("img[srcset][data-file-width][data-file-height]")[0]) { multimediaViewer(); }
     // Add "mainpage" class to the body element
     if (mw.config.get("wgMainPageTitle") === mw.config.get("wgPageName") && mw.config.get("wgAction") === "view") { $("body").addClass("mainpage"); }
     //重复文件列表区分图片和音频
     if ($(".mw-special-ListDuplicatedFiles").length && $(".mw-spcontent > p").length > 1) { duplicatedFileList(); }
     //需要时载入对应的 scripts
     if (mw.config.get("wgAction") === "edit" || mw.config.get("wgAction") === "submit" || mw.config.get("wgCanonicalSpecialPageName") === "Search") { mw.loader.load("/index.php?title=MediaWiki:Common.js/edit.js&action=raw&ctype=text/javascript"); }
     // Tabs执行
     mw.hook('wikipage.content').add(function() { tabs(); });
     //子页面页顶链接
      if (mw.config.get("wgPageName").indexOf("/") !== -1 && (mw.config.get("wgNamespaceIds").special !== mw.config.get("wgNamespaceNumber") || mw.config.get("wgPageName").indexOf("Special:移动页面") !== -1) && !window._unsubpage) { subpage_links(); }
     //跨站重定向页顶链接
     mw.loader.using("mediawiki.Uri").then(function() {
       if (new mw.Uri().query.rdfrom && new mw.Uri(new mw.Uri().query.rdfrom).query.title && new mw.Uri(new mw.Uri().query.rdfrom).query.redirect === "no") { crossDomain_link(); }
     });
     //编辑请求
     if (["edit", "submit"].indexOf(mw.config.get("wgAction")) !== -1 && !$(".permissions-errors, #wpTextbox1[readonly]")[1] && mw.config.get("wgUserName")) { editRequest(); }
     //修复代码编辑器$.ucFirst引用错误
     $.extend({
       ucFirst: function(_s) {
         var s = _s + "";
         return s.charAt(0).toUpperCase() + s.substring(1);
       },
     });
     //注释内列表
     $(".reference-text > ul,.reference-text > ol").each(function() {
       if (this.parentElement.childNodes[0] === this) { $(this).addClass("listInRef"); }
     });
     //列表侧边距
     setInterval(function() {
       $(".mw-parser-output ul, .mw-parser-output ol").not(".margin-left-set").each(function() {
         if (/none.+none/i.test($(this).css("list-style")) || $(this).is(".gallery")) {
           if ($(this).parent().is("li") && $(this).parent().parent().is("ul,ol")) { $(this).css("margin-left", "1.2em"); } else { $(this).css("margin-left", "0.2em"); }
         } else if ($(this).is("ol")) {
           var l = $(this).children("li").length;
           if ($(this).attr("start")) { l += parseInt($(this).attr("start")); }
           $(this).css("margin-left", (l + "").length * 0.5 + 1.2 + "em");
         } else { $(this).css("margin-left", "1.2em"); }
         $(this).addClass("margin-left-set");
       });
     }, 200);
     //修正hash跳转错误
     if ($(".mw-collapsible")[0]) {
       mw.loader.using("jquery.makeCollapsible", function() {
         $(".mw-collapsible").makeCollapsible();
         var hash = location.hash;
         location.hash = "";
         location.hash = hash;
       });
     }
     //防滥用即将删除
     if (!mw.config.get("wgUserGroups").includes("sysop") && !mw.config.get("wgUserGroups").includes("patroller")) {
       setInterval(function() {
         if ($(".Wikiplus-InterBox")[0]) {
           var targetBox = $(".Wikiplus-InterBox");
           if (targetBox.data("isTrusted") !== true) {
             targetBox.data("isTrusted", true);
             targetBox.css("z-index", 100);
             antiAbuse($("#Wikiplus-Quickedit")[0], $("#Wikiplus-Quickedit-Submit")[0], undefined);
             var events = $._data($("#Wikiplus-Quickedit")[0], "events");
             if (events && events.keydown) {
               events.keydown.sort(function(a, b) {
                 return a.guid - b.guid;
               });
               events.keydown[0].handler = function(e) {
                 if (e.ctrlKey && e.which === 83) {
                   if (e.shiftKey) {
                     $("#Wikiplus-Quickedit-MinorEdit").click();
                   }
                   if (antiAbuseListener($("#Wikiplus-Quickedit")[0], e) !== false) {
                     $("#Wikiplus-Quickedit-Submit").click();
                     e.preventDefault();
                     e.stopPropagation();
                   }
                 }
               };
             }
           }
         }
         if ($("form#editform")[0]) {
           var targetForm = $("form#editform");
           if (targetForm.data("isTrusted") !== true) {
             targetForm.data("isTrusted", true);
             antiAbuse($("#wpTextbox1")[0], $("#wpSave")[0], targetForm[0]);
           }
         }
       }, 1000);
     }
   //R18警告
   function r18Warning() {
     var content = $('<div id="x18"><div id="x18Context"><div id="x18Title"><div id="x18Icon"></div></div><div class="x18Button"></div></div></div>');
     if (!window.localStorage.getItem('x18')) { //如果没有x18记录
       $('body').css('overflow', 'hidden'); //禁止滚屏
       $('#mw-content-text').css({
         'opacity': 0
       });
   //禁止偷看
       content.prependTo('body').find('.x18Button').append('<div id="x18Yes">是</div><div id="x18No" class="x18Button">否</div>')
         .end().find('#x18Title').append('你是否已年满十八岁?')
         .end().delay(400).queue(function() {
           $(this).css({
             'opacity': 1
           }); //显示警告信息
           $(this).dequeue();
         });
       $('#x18Yes').on('click', function() {
         window.localStorage.setItem('x18', true); //记录x18
         $('#mw-content-text').css('opacity', 1).removeAttr('style'); //显示内容
         $("#x18").remove(); //移除警告信息
         $('body').removeAttr('style'); //允许滚屏
       });
       $('#x18No').on('click', function() {
         window.location.replace(window.location.origin + '/' + mw.config.get('wgMainPageTitle')); //不给你看
       });
     } else $("#x18").remove(); //如果有x18记录
    }
    }
 
    $(function() {
   .dablink {
      tabs();
     margin: 14px 0px !important;
      r18Warning();
     font-weight: 300 !important;
    });
     font-size: 17.5px !important;
})();
   }
      //以下 代码必须 全部内容加载完成后才 正常工作
 
     $(window).on("load", function() {
   .ambox,.tmbox,.Note,.informationbox {
       // 语言对应
     margin: 5px 0px !important;
       $(".mw-helplink").each(function() {
     font-size: 18px !important;
         var linkHref = this.href;
     font-weight: 700 !important;
         if (linkHref.indexOf("/zh") !== linkHref.length - 3) { this.href += "/zh"; }
     line-height: 1.5 !important;
       });
     border: 1px dashed #aaa !important;
     });
     max-width: 550px !important;
    });
     font-weight: 300 !important;
})(jQuery, mediaWiki); //立即执行匿名函数并传递原始变量以防止冲突
    }
// </nowiki>
 
   .ambox td,.tmbox td {
     padding: 10px !important;
   }
 
   .ambox-text-small,.mbox-text,.Note td {
     font-size: 14px !important;
     font-weight: 300 !important;
     color: #000 !important;
   }
 
   .ambox-image,.mbox-image {
     display: none;
   }
 
   #request_for_deletion,.ambox-serious {
     background: rgba(255,0,0,0.1) !important;
     border: 1px dashed rgba(255,0,0,0.15) !important;
     color: #a00000 !important;
   }
 
   .tmbox-notice,.tmbox-move,.Note {
      background: rgba(150,75,0,0.1) !important;
      border: 1px dashed rgba(150,75,0,0.15) !important;
   }
 
   .informationbox {
     background: #fff !important;
     padding: 10px !important;
     font-size: 14px !important;
   }
 
   .editOptions {
     border: 0px !important;
   }
 
   .image img:hover {
     opacity: 0.85 !important;
   }
/* 用户页和讨论页没有分类 */
body.ns-1 #catlinks {
   display: none !important;
}
body.ns-2 #catlinks {
   display: none !important;
}
 
/* 仅手机版显示支持 */
.mobileonly {
   display: none !important;
}
/* 编辑请求 */
.editRequest {
   text-align: center;
    border: 1px solid #ddd;
   border-radius: 3px;
   margin:1em 2.5em;
   padding: 1em;
   background: white;
}
.editRequest .newComment {
   white-space: nowrap;
   background: #347bff;
   color: #fff;
   border: 1px solid #347bff;
   text-shadow: 0 1px rgba(0,0,0,0.1);
   font-family: inherit;
   font-size: 1em;
   min-width: 4em;
   max-width: 28.75em;
   padding: .5em 1em;
   margin: 0;
   border-radius: 2px;
   -webkit-box-sizing: border-box;
   -moz-box-sizing: border-box;
   box-sizing: border-box;
   -webkit-appearance: none;
   zoom: 1;
   vertical-align: middle;
   text-align: center;
   font-weight: bold;
   cursor: pointer;
}
/* 注释里的列表 */
.reference-text > ul.listInRef,
.reference-text > ol.listInRef {
   margin: -1.5em 0 0 2em;
}
/*
* Skeleton V2.0.4
* Copyright 2014, Dave Gamache
* www.getskeleton.com
* Free to use under the MIT license.
* http://www.opensource.org/licenses/mit-license.php
* 12/29/2014
*/
/* 以下内容已被萌百格式化,注释已被翻译 */
.container {
   position: relative;
   width: 100%;
   max-width: 960px;
   margin: 0 auto;
   padding: 0 20px;
   box-sizing: border-box;
}
.div,
.divs,
.column,
.columns {
   width: 100%;
   float: left;
   box-sizing: border-box;
}
/* 适用于屏幕像素宽度大于400px的设备 */
@media (min-width: 400px) {
   .container {
     width: 85%;
     padding: 0;
   }
}
/* 适用于屏幕像素宽度大于800px的设备 */
@media (min-width: 800px) {
   .container {
     width: 80%;
   }
   .div,
   .divs,
   .column,
   .columns {
     margin-left: .3%;
   }
   .div:first-child,
   .divs:first-child,
   .column:first-child,
   .columns:first-child {
     margin-left: 0;
   }
   .one.div,
   .one.divs {
     width: 100%;
     margin-left: 0;
   }
   .two.divs {
     width: 49.85%;
   }
   .three.divs {
     width: 33.1333333333%;
   }
   .four.divs {
     width: 24.775%;
   }
   .five.divs {
     width: 19.76%;
   }
   .six.divs {
     width: 16.4166666667%;
   }
   .seven.divs {
     width: 14.0285714286%;
   }
   .eight.divs {
     width: 12.2375%;
   }
   .nine.divs {
     width: 10.8444444444%;
   }
   .ten.divs {
     width: 9.73%;
   }
   .eleven.divs {
     width: 8.81818181818%;
   }
   .twelve.divs {
     width: 8.05833333333%;
   }
   .one.column,
   .one.columns {
     width: 8.05833333333%;
   }
   .two.columns {
     width: 16.4166666667%;
   }
   .three.columns {
     width: 24.775%;
   }
   .four.columns {
     width: 33.1333333333%;
   }
   .five.columns {
     width: 41.4916666667%;
   }
   .six.columns {
     width: 49.85%;
   }
   .seven.columns {
     width: 58.2083333333%;
   }
   .eight.columns {
     width: 66.5666666667%;
   }
   .nine.columns {
     width: 74.925%;
   }
   .ten.columns {
     width: 83.2833333333%;
   }
   .eleven.columns {
     width: 91.6416666667%;
   }
   .twelve.columns {
     width: 100%;
     margin-left: 0;
   }
   .one-third.column {
     width: 33.1333333333%;
   }
   .two-thirds.column {
     width: 66.5666666667%;
   }
   .one-half.column {
     width: 49.85%;
   }
   /* Offsets设置 */
   .offset-by-one.column,
   .offset-by-one.columns {
     margin-left: 8.66666666667%;
   }
   .offset-by-two.column,
   .offset-by-two.columns {
     margin-left: 17.3333333333%;
   }
   .offset-by-three.column,
   .offset-by-three.columns {
     margin-left: 26%;
   }
   .offset-by-four.column,
   .offset-by-four.columns {
     margin-left: 34.6666666667%;
   }
   .offset-by-five.column,
   .offset-by-five.columns {
     margin-left: 43.3333333333%;
   }
   .offset-by-six.column,
   .offset-by-six.columns {
     margin-left: 52%;
   }
   .offset-by-seven.column,
   .offset-by-seven.columns {
     margin-left: 60.6666666667%;
   }
   .offset-by-eight.column,
   .offset-by-eight.columns {
     margin-left: 69.3333333333%;
   }
   .offset-by-nine.column,
   .offset-by-nine.columns {
     margin-left: 78.0%;
   }
   .offset-by-ten.column,
   .offset-by-ten.columns {
     margin-left: 86.6666666667%;
   }
   .offset-by-eleven.column,
   .offset-by-eleven.columns {
      margin-left: 95.3333333333%;
   }
   .offset-by-one-third.column,
   .offset-by-one-third.columns {
     margin-left: 34.6666666667%;
   }
   .offset-by-two-thirds.column,
   .offset-by-two-thirds.columns {
     margin-left: 69.3333333333%;
   }
   .offset-by-one-half.column,
   .offset-by-one-half.columns {
     margin-left: 52%;
   }
}
/*
* 感谢{{萌百|User:Great Brightstar}}的贡献,源码来自[[special:diff/834104]]
以下 是原注释:
这里使用 font-feature-settings 属性会让使用“lang”标签的元素强制使用 OpenType 技术显示本地化的变体字(通过激活 locl 标签,即便浏览器本身不直接激活)。
* 如果你使用思源黑体(非 CN、JP、KO、TW 版)、Noto Sans CJK 显示文字的话就有可 看到效果。
* 关于上述这个 CSS 属性的用法,参阅:https://developer.mozilla.org/en-US/docs/Web/CSS/font-feature-settings 注意:此文引用的 OpenType Feature Tags list 同样需要关注。
* 如有任何问题请即刻禁用之
* Nbdd0121: 将原来的[lang]改为span[lang],这样就不会影响非{{lang}}的[lang]了 (e.g. #mw-content-text)
*/
span[lang] {
   font-family: initial;
   font-feature-settings: "locl" on;
   -webkit-font-feature-settings: "locl" on;
}
[style*="font"] span[lang] {
   font-family: inherit;
}
/* wikitable 的 caption */
.wikitable.mw-collapsible caption {
   border: 1px solid rgba(170, 170, 170, 0.37);
   border-bottom-width: 0;
   background-color: rgb(249,249,249);
}
.wikitable.mw-collapsible.mw-collapsed caption {
   border-bottom-width: 1px;
}
/* vectorMenu 的排序 */
div.vectorMenu ul {
   display: flex;
   flex-flow: column;
}
/* 分类页同开头的页面的列表不分段 */
.mw-category-group {
   -webkit-column-break-inside: avoid;
   page-break-inside: avoid;
   break-inside: avoid;
}
.mw-category-group:nth-child(1):nth-last-child(1),  /* 只有一个列表时 */
.mw-category-group:nth-child(1):nth-last-child(2),  /* 只有两个列表时 */
.mw-category-group:nth-child(2):nth-last-child(1) { /* 只有两个列表时 */
   -webkit-column-break-inside: auto;
   page-break-inside: auto;
   break-inside: auto;
}
/* Ruby 模板 */
rb[data-id="template-ruby"]::before {
   content: "";
}
rb[data-id="template-ruby"]::before,
.template-ruby-hidden {
   display: inline-block;
   width: 0;
   font-size: 0;
}
/* R18模板 */
#x18 {
   width: 100%;
   height: 100%;
   position: fixed;
   top: 0;
   background: rgba(0, 0, 0, 0.9);
   z-index: 999;
   opacity: 0;
}
#x18Context {
   position: relative;
   margin: 0 auto;
   margin-top: -40px;
   top: 50%;
   width: 240px;
   height: 80px;
   background: #444;
   color: white;
   border: solid 1px rgb(118, 195, 255);
   border-radius: 4px;
   box-shadow: 0 0 5px rgb(118, 195, 255);
   padding: 12px;
}
#x18Title {
   margin: 12px;
}
#x18Icon {
   position: relative;
   border: 8px solid transparent;
   border-left: 12px solid #fff;
   float: left;
   margin: 2px 0;
}
.x18Button {
   text-align: center;
}
.x18Button div {
   width: 72px;
    height: 20px;
   border-radius: 4px;
   padding: 4px;
   text-align: center;
   font-size: 11pt;
   display: inline-block;
   cursor: pointer;
   box-shadow: #777 0 0 22px inset;
}
.x18Button div:nth-child(2) {
   margin-left: 26px;
}
#x18Yes {
   background: rgb(57, 238, 0);
}
#x18No {
   background: rgb(238, 48, 0);
}

2020年3月23日 (一) 12:07的版本

/* eslint-disable no-var */
/* eslint-disable no-magic-numbers */
/* global OO, mediaWiki, jQuery */
// <nowiki>
/* 这里的任何JavaScript将在全站加载
 * 请尊重版权,以下代码复制需要注明原自H萌娘,并且附上URL地址http://www.hmoegirl.com/MediaWiki:Common.js
 * 版权协定:知识共享 署名-非商业性使用-相同方式共享 3.0
 *  loader模块 写法参见 https://www.mediawiki.org/wiki/ResourceLoader/Modules#mw.loader.load
 */
"use strict";
(function($, mw) { //使用匿名函数防止污染顶级变量
    /* MediaViewer#populateStatsFromXhr 错误屏蔽 */
    (function() {
        var getResponseHeader = XMLHttpRequest.prototype.getResponseHeader;
        XMLHttpRequest.prototype.getResponseHeader = function(name) {
            return ("\n" + this.getAllResponseHeaders().toLowerCase()).includes("\n" + name.toLowerCase() + ": ") ? getResponseHeader.call(this, name) : (console.debug('Refused to get unsafe header "' + name + '"\n', this, "\n", new Error().stack), null);
        };
    })();
    //Extension:MultimediaViewer的半透明化修改,用于保持背景文字处于原位,本应修改插件达成的,暂时先用JavaScript应急处理下
    function multimediaViewer() {
        var _scrollTo = window.scrollTo;
        var flag = location.hash !== "";
        window.scrollTo = function scrollTo(x_option, y) {
            if (flag) {
                console.info("Prevent multimediaViewer called");
            } else {
                if (y === undefined) { _scrollTo(x_option); } else { _scrollTo(x_option, y); }
            }
        };
        setInterval(function() {
            $("a.image img[data-file-width], a.image img[data-file-height], .mw-mmv-filepage-buttons a.mw-mmv-view-expanded").not(".multimediaViewerScrollSet").each(function() {
                this.addEventListener("click", function(e) {
                    if ($(e.target).closest(".TabLabelText")[0] || $(e.target).closest("a").closest(".mw-customtoggle")[0]) {
                        e.preventDefault();
                        e.stopPropagation();
                        e.stopImmediatePropagation();
                        $($(e.target).closest(".TabLabelText")[0] || $(e.target).closest("a").closest(".mw-customtoggle")[0]).click();
                        return false;
                    }
                    flag = true;
                }, captureSupported ? {
                    capture: true,
                } : true);
                $(this).addClass("multimediaViewerScrollSet");
            });
            if ($(".mw-mmv-close")[0]) {
                if (mw.config.get("wgMultimediaViewer") !== "on") {
                    mw.config.set("wgMultimediaViewer", "on");
                    $(".mw-mmv-image").off("click")[0].addEventListener("click", function(e) {
                        if ($(e.target).is("img")) {
                            window.open($(e.target).attr("src").replace(/(img\.moegirl\.org\/common\/)thumb\/([a-z\d]+\/[a-z\d]+\/)([^/]+)\/\d+px-\3/i, "$1$2$3"), "_blank").focus();
                            e.preventDefault();
                            e.stopPropagation();
                            e.stopImmediatePropagation();
                            return false;
                        } else if ($(e.target).closest(".error-box")[0]) { return; }
                        $(".mw-mmv-close").click();
                    }, captureSupported ? {
                        capture: true,
                    } : true);
                }
            } else if (mw.config.get("wgMultimediaViewer") === "on") {
                flag = false;
                mw.config.set("wgMultimediaViewer", "off");
            }
        }, 137);
    }
    //Tabs
    function tabs() {
        var defaultStyle = {
            purple: {
                labelColor: " ", //anti check
                labelBackgroundColor: "#9070c0",
                labelBorderColor: "#b090e0 #7050a0 #9070c0 #b090e0",
                labelPadding: ".2em .3em .2em .3em",
                textBorderColor: "#9070c0",
                textBackgroundColor: "#f0edf5",
                textPadding: "1em",
            },
            green: {
                labelColor: " ",
                labelBackgroundColor: "#75c045",
                labelBorderColor: "#90d060 #60b030 #75c045 #90d060",
                labelPadding: ".2em .3em .2em .3em",
                textBorderColor: "#75c045 #60b030 #60b030 #75c045",
                textBackgroundColor: "#f5fffa",
                textPadding: "1em",
            },
            red: {
                labelColor: " ",
                labelBackgroundColor: "#FF0000",
                labelBorderColor: "#FF8888 #CC0000 #FF0000 #FF8888",
                labelPadding: ".2em .3em .2em .3em",
                textBorderColor: "#FF0000 #CC0000 #CC0000 #FF0000",
                textBackgroundColor: "#fffafa",
                textPadding: "1em",
            },
            blue: {
                labelColor: " ",
                labelBackgroundColor: "#5b8dd6",
                labelBorderColor: "#88abde #3379de #5b8dd6 #88abde",
                labelPadding: ".2em .3em .2em .3em",
                textBackgroundColor: "#f0f8ff",
                textBorderColor: "#5b8dd6 #3379de #3379de #5b8dd6",
                textPadding: "1em",
            },
            yellow: {
                labelColor: " ",
                labelBackgroundColor: "#ffe147",
                labelBorderColor: "#ffe977 #ffd813 #ffe147 #ffe977",
                labelPadding: ".2em .3em .2em .3em",
                textBackgroundColor: "#fffce8",
                textBorderColor: "#ffe147 #ffd813 #ffd813 #ffe147",
                textPadding: "1em",
            },
            orange: {
                labelColor: " ",
                labelBackgroundColor: "#ff9d42",
                labelBorderColor: "#ffac5d #ff820e #ff9d42 #ffac5d",
                labelPadding: ".2em .3em .2em .3em",
                textBackgroundColor: "#ffeedd",
                textBorderColor: "#ff9d42 #ff820e #ff820e #ff9d42",
                textPadding: "1em",
            },
            black: {
                labelColor: " ",
                labelBackgroundColor: "#7f7f7f",
                labelBorderColor: "#999999 #4c4c4c #7f7f7f #999999",
                labelPadding: ".2em .3em .2em .3em",
                textBackgroundColor: "#e5e5e5",
                textBorderColor: "#7f7f7f #4c4c4c #4c4c4c #7f7f7f",
                textPadding: "1em",
            },
        };
        $("body").addClass("tab");
        // A Class
        function StyleSheet() {}
        StyleSheet.prototype.getOwnPropertyNamesLength = function getOwnPropertyNamesLength() {
            return Object.getOwnPropertyNames(this).length;
        };
        String.prototype.toLowerFirstCase = function toLowerFirstCase() {
            return this[0].toLowerCase() + this.substring(1);
        };
        $(".Tabs").each(function() {
            if ($(this).children(".TabLabel")[0]) { return true; }
            var self = $(this),
                classList = Array.from(this.classList).filter(function(n) { return n in defaultStyle; }),
                data = $.extend({
                    labelPadding: "2px",
                    labelBorderColor: "#aaa",
                    labelColor: "green",
                    labelBackgroundColor: $("#content").css("background-color"),
                    textPadding: "20px 30px",
                    textBorderColor: "#aaa",
                    textBackgroundColor: "white",
                    defaultTab: 1,
                }, classList[0] ? defaultStyle[classList[0]] || {} : {}, this.dataset || {}),
                tabLabel = self.append('<div class="TabLabel"></div>').children(".TabLabel"),
                tabContent = self.append('<div class="TabContent"></div>').children(".TabContent"),
                labelPadding = data.labelPadding,
                labelColor = data.labelColor,
                styleSheet = {
                    label: new StyleSheet(),
                    text: new StyleSheet(),
                },
                defaultTab = parseInt(data.defaultTab);
            self.children(".Tab").each(function() {
                if ($(this).children(".TabLabelText").text().replace(/\s/g, "").length || $(this).children(".TabLabelText").children().length) {
                    $(this).children(".TabLabelText").appendTo(tabLabel);
                    $(this).children(".TabContentText").appendTo(self.children(".TabContent"));
                }
                $(this).remove();
            });
            if (isNaN(defaultTab) || defaultTab <= 0 || defaultTab > tabLabel.children(".TabLabelText").length) { defaultTab = 1; }
            tabLabel.children(".TabLabelText").on("click", function() {
                var label = $(this);
                label.addClass("selected").siblings().removeClass("selected").css({
                    "border-color": "transparent",
                    "background-color": "inherit",
                });
                tabContent.children(".TabContentText").eq(tabLabel.children(".TabLabelText").index(label)).addClass("selected").siblings().removeClass("selected").removeAttr("style");
                if (styleSheet.label.getOwnPropertyNamesLength()) { label.css(styleSheet.label); }
            }).eq(defaultTab - 1).click();
            if (labelPadding) { tabLabel.children(".TabLabelText").css("padding", labelPadding); }
            ["labelBorderColor", "labelBackgroundColor", "textPadding", "textBorderColor", "textBackgroundColor"].forEach(function(n) {
                var target = /^label/.test(n) ? "label" : "text",
                    key = n.replace(target, "").toLowerFirstCase();
                styleSheet[target][key] = data[n];
            });
            if (labelColor) {
                styleSheet.label.borderTopColor = labelColor;

            } else if (styleSheet.label.borderColor) {
                styleSheet.label.borderTopColor = "green";
            }
            tabLabel.find(".selected").click();
            if (styleSheet.text.getOwnPropertyNamesLength()) { tabContent.css(styleSheet.text); }
            if (data.autoWidth === "yes") { self.css("display", "inline-block"); }
        });
    }
    //子页面页顶链接
    function subpage_links() {
        var links = mw.config.get("wgPageName").split("/"),
            link = "",
            subpages = $(".subpages")[0] ? $(".subpages").remove().empty().text("<") : $('<span class="subpages"/>').text("<"),
            length = links.length - 1,
            index;
        if (mw.config.get("wgPageName").indexOf("Special:移动页面") !== -1) { links.splice(0, 1); }
        for (index = 0; index < length; index++) {
            link += "/" + links[index];
            subpages.append($("<a/>", {
                text: " " + links[index],
                href: link,
            }));
            if (length - index > 1) { subpages.append(" |"); }
        }
        if (subpages.find("a")[0]) { $("#contentSub").prepend(subpages); }
    }
    //跨站重定向页顶链接
    function crossDomain_link() {
        var url = new mw.Uri(new mw.Uri().query.rdfrom);
        var link = url.query.title;
        var domain = url.host;
        var crossDomain = $("<div/>");
        var anchor = $("<a/>");
        crossDomain.text("<");
        anchor.attr("href", url + "").text(link + "【来自 " + domain + "】");
        crossDomain.append(anchor);
        $("#contentSub").prepend(crossDomain);
    }
    //重复文件列表函数
    function duplicatedFileList() {
        if (window.location.href.indexOf("title") === -1) { window.location.replace("http://zh.moegirl.org/index.php?title=Special:ListDuplicatedFiles&limit=500&offset=0"); }
        $("#mw-content-text .mw-spcontent ol").attr("id",
            "picOl");
        $("#picOl").before('<p id="picOlTitle">图片列表:</p>').after('<p id="MP3OlTitle">MP3列表:</p><ol start="1" id="MP3Ol"></ol>');
        $("#picOlTitle, #MP3OlTitle").hide();
        $("#picOl").find("[href$='.mp3'], [href$='.ogg']").parent().appendTo("#MP3Ol");
        if ($("#picOl").find("li").length) { $("#picOlTitle").show(); }
        if ($("#MP3Ol").find("li").length) { $("#MP3OlTitle").show(); }
        $(".mw-spcontent > p:nth-child(1), .mw-spcontent > p:nth-child(2), .mw-spcontent > p:nth-child(7)").hide();
    }
    //编辑请求
    function editRequest() {
        var nsIds = mw.config.get("wgNamespaceIds"),
            nsId = mw.config.get("wgNamespaceNumber"),
            ns = [];
        for (var i in nsIds) {
            if (nsIds[i] === nsId) { ns.push(i); }
        }
        if (!ns[0]) { return; }
        var page = mw.config.get("wgPageName"),
            talkns;
        for (var j = 0, l = ns.length; j < l; j++) {
            if (/^[A-Za-z0-9]+[ _]talk$/i.test(ns[j])) { return; }
            if (/^[a-zA-Z0-9]+$/.test(ns[j])) { talkns = ns[j] + "_talk:"; }
            page = page.replace(new RegExp("^" + ns[j] + ":", "i"), "");
        }
        var talkpage = talkns + page;
        var container = $("<div/>", {
            "class": "editRequest",
        });
        container.append("您虽然无权编辑本页面,但您可以点击右侧按钮在本页的讨论页提出编辑请求,让可以编辑的人代为编辑:");
        $("<span/>").addClass("newComment").text("提出编辑请求").on("click", function() {
            window.open("https://zh.moegirl.org/index.php?action=edit&preload=Template:编辑请求/comment&preloadtitle=编辑请求 - " + mw.config.get("wgUserName") + "&section=new&title=" + talkpage, "_blank");
        }).appendTo(container);
        $("#mw-content-text").children(".wikiEditor-ui:first, textarea[readonly]:first").before("<hr>").before(container);
    }
    //防滥用即将删除模板
    function antiAbuseListener(textarea, event) {
        var filters = [
            "{{即将删除",
            "{{即將刪除",
            "{{挂删",
            "{{模板:即将删除",
            "{{模板:即將刪除",
            "{{template:即将删除",
            "{{template:即將刪除",
            "[[分类:即将删除的页面",
            "[[分類:即將刪除的頁面",
            "[[category:即将删除的页面",
            "[[category:即將刪除的頁面",
            "{{文件转移到萌娘共享",
            "{{文件轉移到萌娘共享",
            "{{模板:文件转移到萌娘共享",
            "{{模板:文件轉移到萌娘共享",
            "{{template:文件转移到萌娘共享",
            "{{template:文件轉移到萌娘共享",
            "[[分类:需要删除执行员删除的页面",
            "[[分類:需要刪除執行員刪除的頁面",
            "[[category:需要删除执行员删除的页面",
            "[[category:需要刪除執行員刪除的頁面",
        ];
        var text1 = textarea.value;
        text1 = text1.replace(/<\/?(?:nowiki|noinclude)>/g, "");
        text1 = text1.replace(/<(onlyinclude|includeonly)>.*?<\/\1>/g, "");
        var text2 = textarea.value;
        text2 = text2.replace(/<\/?(?:onlyinclude|includeonly)>/g, "");
        text2 = text2.replace(/<(nowiki|noinclude)>.*?<\/\1>/g, "");
        var results = [];
        for (var i = 0, l = filters.length; i < l; i++) {
            var regExp = new RegExp(filters[i].replace(/\[/g, "\\["), "i");
            if (regExp.test(text1) || regExp.test(text2)) { results.push(filters[i]); }
        }
        if (results.length > 0) {
            var messageDialog = new OO.ui.MessageDialog();
            var windowManager = new OO.ui.WindowManager();
            $("body").append(windowManager.$element);
            windowManager.addWindows([messageDialog]);
            messageDialog.title.$label.html("H萌娘提醒您<br>您的编辑包含禁止内容!");
            messageDialog.message.$label.html("<br>您提交的内容包含以下部分,被禁止提交:<br><br><ul>" + results.map(function(result) {
                return "<li>" + result + "</li>";
            }).join("") + '</ul><br><br>如果您认为您的编辑无误,请在自行保存编辑内容后到<a target="_blank" rel="nofollow noreferrer noopener" class="external text" href="https://zh.moegirl.org/Talk:%E6%8F%90%E9%97%AE%E6%B1%82%E5%8A%A9%E5%8C%BA">提问求助区</a>提问。');
            windowManager.openWindow(messageDialog, {
                actions: [{
                    action: "accept",
                    label: "我知道了",
                    flags: "primary",
                }],
            });
            event.preventDefault();
            event.stopImmediatePropagation();
            event.stopPropagation();
            return false;
        }
    }

    function antiAbuse(textarea, submitButton, form) {
        mw.loader.using(["oojs-ui"]).then(function() {
            if (submitButton) {
                submitButton.addEventListener("click", function(e) {
                    antiAbuseListener(textarea, e);
                }, captureSupported ? {
                    capture: true,
                } : true);
            }
            if (form) {
                form.addEventListener("submit", function(e) {
                    antiAbuseListener(textarea, e);
                }, captureSupported ? {
                    capture: true,
                } : true);
            }
        });
    }
    /* 函数执行体 */
    $(function() {
        //Template:heimu在safari上的暴力workaround
        mw.loader.using("jquery.client", function() {
            if ($.client.profile().name === "safari") {
                $(".heimu").on("click", function() {
                    $(this).toggleClass("off");
                });
            }
        });
        var copyRightsNameSpaces = [ // 以下为允许添加版权声明的名字空间列表
            0, // (主)
            4, // H萌娘
            8, // MediaWiki
            10, // Template
            12, // Help
            614, // R18
        ];
        //滚动公告
        autoScroll("#scrollDiv");
        //Extension:MultimediaViewer的半透明化修改
        if ($("img[srcset][data-file-width][data-file-height]")[0]) { multimediaViewer(); }
        // Add "mainpage" class to the body element
        if (mw.config.get("wgMainPageTitle") === mw.config.get("wgPageName") && mw.config.get("wgAction") === "view") { $("body").addClass("mainpage"); }
        //重复文件列表区分图片和音频
        if ($(".mw-special-ListDuplicatedFiles").length && $(".mw-spcontent > p").length > 1) { duplicatedFileList(); }
        //需要时载入对应的 scripts
        if (mw.config.get("wgAction") === "edit" || mw.config.get("wgAction") === "submit" || mw.config.get("wgCanonicalSpecialPageName") === "Search") { mw.loader.load("/index.php?title=MediaWiki:Common.js/edit.js&action=raw&ctype=text/javascript"); }
        // Tabs执行
        mw.hook('wikipage.content').add(function() { tabs(); });
        //子页面页顶链接
        if (mw.config.get("wgPageName").indexOf("/") !== -1 && (mw.config.get("wgNamespaceIds").special !== mw.config.get("wgNamespaceNumber") || mw.config.get("wgPageName").indexOf("Special:移动页面") !== -1) && !window._unsubpage) { subpage_links(); }
        //跨站重定向页顶链接
        mw.loader.using("mediawiki.Uri").then(function() {
            if (new mw.Uri().query.rdfrom && new mw.Uri(new mw.Uri().query.rdfrom).query.title && new mw.Uri(new mw.Uri().query.rdfrom).query.redirect === "no") { crossDomain_link(); }
        });
        //编辑请求
        if (["edit", "submit"].indexOf(mw.config.get("wgAction")) !== -1 && !$(".permissions-errors, #wpTextbox1[readonly]")[1] && mw.config.get("wgUserName")) { editRequest(); }
        //修复代码编辑器$.ucFirst引用错误
        $.extend({
            ucFirst: function(_s) {
                var s = _s + "";
                return s.charAt(0).toUpperCase() + s.substring(1);
            },
        });
        //注释内列表
        $(".reference-text > ul,.reference-text > ol").each(function() {
            if (this.parentElement.childNodes[0] === this) { $(this).addClass("listInRef"); }
        });
        //列表侧边距
        setInterval(function() {
            $(".mw-parser-output ul, .mw-parser-output ol").not(".margin-left-set").each(function() {
                if (/none.+none/i.test($(this).css("list-style")) || $(this).is(".gallery")) {
                    if ($(this).parent().is("li") && $(this).parent().parent().is("ul,ol")) { $(this).css("margin-left", "1.2em"); } else { $(this).css("margin-left", "0.2em"); }
                } else if ($(this).is("ol")) {
                    var l = $(this).children("li").length;
                    if ($(this).attr("start")) { l += parseInt($(this).attr("start")); }
                    $(this).css("margin-left", (l + "").length * 0.5 + 1.2 + "em");
                } else { $(this).css("margin-left", "1.2em"); }
                $(this).addClass("margin-left-set");
            });
        }, 200);
        //修正hash跳转错误
        if ($(".mw-collapsible")[0]) {
            mw.loader.using("jquery.makeCollapsible", function() {
                $(".mw-collapsible").makeCollapsible();
                var hash = location.hash;
                location.hash = "";
                location.hash = hash;
            });
        }
        //防滥用即将删除
        if (!mw.config.get("wgUserGroups").includes("sysop") && !mw.config.get("wgUserGroups").includes("patroller")) {
            setInterval(function() {
                if ($(".Wikiplus-InterBox")[0]) {
                    var targetBox = $(".Wikiplus-InterBox");
                    if (targetBox.data("isTrusted") !== true) {
                        targetBox.data("isTrusted", true);
                        targetBox.css("z-index", 100);
                        antiAbuse($("#Wikiplus-Quickedit")[0], $("#Wikiplus-Quickedit-Submit")[0], undefined);
                        var events = $._data($("#Wikiplus-Quickedit")[0], "events");
                        if (events && events.keydown) {
                            events.keydown.sort(function(a, b) {
                                return a.guid - b.guid;
                            });
                            events.keydown[0].handler = function(e) {
                                if (e.ctrlKey && e.which === 83) {
                                    if (e.shiftKey) {
                                        $("#Wikiplus-Quickedit-MinorEdit").click();
                                    }
                                    if (antiAbuseListener($("#Wikiplus-Quickedit")[0], e) !== false) {
                                        $("#Wikiplus-Quickedit-Submit").click();
                                        e.preventDefault();
                                        e.stopPropagation();
                                    }
                                }
                            };
                        }
                    }
                }
                if ($("form#editform")[0]) {
                    var targetForm = $("form#editform");
                    if (targetForm.data("isTrusted") !== true) {
                        targetForm.data("isTrusted", true);
                        antiAbuse($("#wpTextbox1")[0], $("#wpSave")[0], targetForm[0]);
                    }
                }
            }, 1000);
        }
    //R18警告
    function r18Warning() {
        var content = $('<div id="x18"><div id="x18Context"><div id="x18Title"><div id="x18Icon"></div></div><div class="x18Button"></div></div></div>');
        if (!window.localStorage.getItem('x18')) { //如果没有x18记录
            $('body').css('overflow', 'hidden'); //禁止滚屏
            $('#mw-content-text').css({
                'opacity': 0
            }); 
     //禁止偷看
            content.prependTo('body').find('.x18Button').append('<div id="x18Yes">是</div><div id="x18No" class="x18Button">否</div>')
                .end().find('#x18Title').append('你是否已年满十八岁?')
                .end().delay(400).queue(function() {
                    $(this).css({
                        'opacity': 1
                    }); //显示警告信息
                    $(this).dequeue();
                });
            $('#x18Yes').on('click', function() {
                window.localStorage.setItem('x18', true); //记录x18
                $('#mw-content-text').css('opacity', 1).removeAttr('style'); //显示内容
                $("#x18").remove(); //移除警告信息
                $('body').removeAttr('style'); //允许滚屏
            });
            $('#x18No').on('click', function() {
                window.location.replace(window.location.origin + '/' + mw.config.get('wgMainPageTitle')); //不给你看
            });
        } else $("#x18").remove(); //如果有x18记录
    }
    $(function() {
        tabs();
        r18Warning();
    });
})();
        //以下代码必须在全部内容加载完成后才能正常工作
        $(window).on("load", function() {
            //语言对应
            $(".mw-helplink").each(function() {
                var linkHref = this.href;
                if (linkHref.indexOf("/zh") !== linkHref.length - 3) { this.href += "/zh"; }
            });
        });
    });
})(jQuery, mediaWiki); //立即执行匿名函数并传递原始变量以防止冲突
// </nowiki>