「MediaWiki:Common.js」の版間の差分

提供:WikiNebula
ナビゲーションに移動 検索に移動
編集の要約なし
編集の要約なし
 
(同じ利用者による、間の28版が非表示)
31行目: 31行目:
         "nebula_switch: 閲覧モードでないため、入れ替えは行いません"
         "nebula_switch: 閲覧モードでないため、入れ替えは行いません"
       );
       );
  }else{
    var uri = new URL(window.location.href);
    if (is_view_mode(uri)){
      if (document.getElementById("nebula_switch")){
        uri.searchParams.append("nebula_switch", "");
        document.getElementsByClassName("mw-parser-output")[0].innerHTML
        += "<h2>お知らせ:この記事は、「男女逆にして」表示できます</h2>"
        + "<p>WikiNebula では、女性に対して向けられるべきではないような"
        + "差別や冷遇が、男性に対しては現実に起きてしまっていることを、"
        + "記事として取り上げています。</p>"
        + "<p>そのため、 WikiNebula には、男性が経験するこの種の"
        + "差別や女尊男卑を理解しやすくするために、"
        + "男女の立場を入れ替えて表示する「男女入れ替えスイッチ」"
        + "の機能があります。</p>"
        + "<p>現在、男女入れ替えスイッチが無効になっています。"
        + "有効にするには、<a href='" + uri.toString() +"'>こちら</a>を"
        + "クリックしてください</p>";
      }
    }
   }
   }


88行目: 107行目:
     content_node.innerHTML =  
     content_node.innerHTML =  
       "<h1>エラー: 男女入れ替えスイッチでエラー</h1>" + message
       "<h1>エラー: 男女入れ替えスイッチでエラー</h1>" + message
    throw new Error("nebula_switch: " + message);
   }
   }


   function nebula_run(doc){
   function nebula_run(doc){
    var content_node
    = document.getElementsByClassName("mw-parser-output")[0];
     Array.from(doc.children[0].children).forEach(function(tag){
     Array.from(doc.children[0].children).forEach(function(tag){
       if (tag.tagName.toLowerCase() == "replace"){
       if (tag.tagName.toLowerCase() == "replace"){
         if (!(
         var is_syntax_error = !(
             tag.childNodes[0].nodeName == "#text"
             tag.childNodes[0].nodeName == "#text"
           && tag.childNodes[1].nodeName.toLowerCase() == "to"
           && tag.childNodes[1].nodeName.toLowerCase() == "to"
           && tag.childNodes[2].nodeName == "#text"
           && tag.childNodes[2].nodeName == "#text"
         )){
          && tag.childNodes.length == 3
         );
        if (is_syntax_error){
          nebula_write_error(
            "次のreplace タグが構文エラーです。<br>"
            + "<code>" + code_escape(tag.outerHTML) + "</code>"
          );
        }
        var before = code_unescape(tag.childNodes[0].nodeValue);
        var after  = code_unescape(tag.childNodes[2].nodeValue);
       
        content_node.innerHTML
        = content_node.innerHTML.replaceAll(before, after);
 
      }
 
      if (tag.tagName.toLowerCase() == "swap"){
        var is_syntax_error = !(
            tag.childNodes[0].nodeName == "#text"
          && tag.childNodes[1].nodeName.toLowerCase() == "for"
          && tag.childNodes[2].nodeName == "#text"
          && tag.childNodes.length == 3
        );
        if (is_syntax_error){
           nebula_write_error(
           nebula_write_error(
             "次のreplace タグが構文エラーです。<br>"
             "次のreplace タグが構文エラーです。<br>"
103行目: 148行目:
           );
           );
         }
         }
         var replace_before
         var A = code_unescape(tag.childNodes[0].nodeValue);
        = code_unescape(tag.childNodes[0].nodeValue);
         var B = code_unescape(tag.childNodes[2].nodeValue);
         var replace_after
       
        = code_unescape(tag.childNodes[2].nodeValue);
        content_node.innerHTML
        = swap_string(content_node.innerHTML, A, B);
 
       }
       }
     });
     });
    var uri = new URL(window.location.href);
    uri.searchParams.delete("nebula_switch");
    content_node.innerHTML
    += "<h2>お知らせ:この記事は、「男女逆にして」表示されています</h2>"
    + "<p>WikiNebula では、女性に対して向けられるべきではないような"
    + "差別や冷遇が、男性に対しては現実に起きてしまっていることを、"
    + "記事として取り上げています。</p>"
    + "<p>そのため、 WikiNebula には、男性が経験するこの種の"
    + "差別や女尊男卑を理解しやすくするために、"
    + "男女の立場を入れ替えて表示する「男女入れ替えスイッチ」"
    + "の機能があります。</p>"
    + "<p>現在、男女入れ替えスイッチが有効になっています。"
    + "無効にするには、<a href='" + uri.toString() +"'>こちら</a>を"
    + "クリックしてください</p>";
   }
   }
     function code_escape(code){
     function code_escape(code){
118行目: 181行目:
     function code_unescape(code){
     function code_unescape(code){
       var textarea = document.createElement("textarea");
       var textarea = document.createElement("textarea");
       textarea.innrHTML = code;
       textarea.innerHTML = code;
       return textarea.innerText;
       return textarea.innerText;
     }
     }
    function swap_string(input_string, x, y) {
      // xとyを正規表現の特殊文字からエスケープする
      x = x.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
      y = y.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
      // xとyを入れ替える
      var regex = new RegExp('(' + x + '|' + y + ')', 'g');
      var result = input_string.replace(regex, function(match) {
        return match === x ? y : x;
      });
      return result;
    }


my_switch();
my_switch();

2024年5月2日 (木) 14:20時点における最新版

/* ここにあるすべてのJavaScriptは、すべてのページ読み込みですべての利用者に対して読み込まれます */

function my_switch(){
  var uri = new URL(window.location.href);
  var is_switched = uri.searchParams.get("nebula_switch") != null;
  if (is_switched){
    console.log("nebula_switch: 入れ替え後のページです");

    if (is_view_mode(uri)){
      console.log("nebula_switch: 閲覧モードです");

      var parser = new Switch_parser();
      if (parser.parse(document.getElementById("nebula_switch"))){
        if (parser.tag_exists){
          console.log(
            "nebula_switch: 入れ替えタグの解析に成功しました"
          );

          nebula_run(parser.doc);
        }else{
          console.log("nebula_switch: 入れ替えタグがありません");
        }
      }else{
        console.log("nebula_switch: 入れ替えタグが異常です");
        nebula_write_error(parser.failed_message);
      }
      
      
    }else
      console.log(
        "nebula_switch: 閲覧モードでないため、入れ替えは行いません"
      );
  }else{
    var uri = new URL(window.location.href);
    if (is_view_mode(uri)){
      if (document.getElementById("nebula_switch")){
        uri.searchParams.append("nebula_switch", "");
        document.getElementsByClassName("mw-parser-output")[0].innerHTML
        += "<h2>お知らせ:この記事は、「男女逆にして」表示できます</h2>"
        + "<p>WikiNebula では、女性に対して向けられるべきではないような" 
        + "差別や冷遇が、男性に対しては現実に起きてしまっていることを、"
        + "記事として取り上げています。</p>"
        + "<p>そのため、 WikiNebula には、男性が経験するこの種の" 
        + "差別や女尊男卑を理解しやすくするために、"
        + "男女の立場を入れ替えて表示する「男女入れ替えスイッチ」"
        + "の機能があります。</p>"
        + "<p>現在、男女入れ替えスイッチが無効になっています。"
        + "有効にするには、<a href='" + uri.toString() +"'>こちら</a>を"
        + "クリックしてください</p>";
      }
    }
  }

}

  function is_view_mode(uri){
    var view_tab = document.getElementById("ca-view");
    if (view_tab)
      var is_view_mode_selected
        = view_tab.classList.contains("selected");
    else
      var is_view_mode_selected = false;
    var is_not_ve_edit_mode = uri.searchParams.get("veaction") == null;
    return is_view_mode_selected && is_not_ve_edit_mode;
  }

  // ES5 なので class 構文は使えない・・・
  function Switch_parser(){
    if (this === null) throw new TypeError();
  }
  Switch_parser.prototype = {
    constructor: Switch_parser,
    parse: function(switch_tag){
      // パース成功の真偽値を返却する
      
      if (switch_tag == null){
        this.tag_exists = false;
        return true;
      }
      this.tag_exists = true;
      
      if (!window.DOMParser){
        this.failed_message = "DOMParser が有効ではありません。"
        + "お使いのブラウザで DOMParser を有効にしてください。";
        return false;
      }
      
      var dom_parser = new DOMParser();
      var doc = dom_parser.parseFromString(
        "<root>" + switch_tag.innerText + "</root>", "text/xml"
      );
      var parser_error = doc.querySelector("parsererror");
      if (parser_error){
        this.failed_message = "入れ替えタグに構文エラーがありました\n"
        + parser_error.innerHTML;
        return false;
      }
      this.doc = doc;
      return true;

    }
  };

  function nebula_write_error(message){
    var content_node = 
      document.getElementsByClassName("mw-parser-output")[0];
    content_node.innerHTML = 
      "<h1>エラー: 男女入れ替えスイッチでエラー</h1>" + message
    throw new Error("nebula_switch: " + message);
  }

  function nebula_run(doc){
    var content_node
    = document.getElementsByClassName("mw-parser-output")[0];
    Array.from(doc.children[0].children).forEach(function(tag){
      if (tag.tagName.toLowerCase() == "replace"){
        var is_syntax_error = !(
             tag.childNodes[0].nodeName == "#text"
          && tag.childNodes[1].nodeName.toLowerCase() == "to"
          && tag.childNodes[2].nodeName == "#text"
          && tag.childNodes.length == 3
        );
        if (is_syntax_error){
          nebula_write_error(
            "次のreplace タグが構文エラーです。<br>"
            + "<code>" + code_escape(tag.outerHTML) + "</code>"
          );
        }
        var before = code_unescape(tag.childNodes[0].nodeValue);
        var after  = code_unescape(tag.childNodes[2].nodeValue);
        
        content_node.innerHTML
        = content_node.innerHTML.replaceAll(before, after);

      }

      if (tag.tagName.toLowerCase() == "swap"){
        var is_syntax_error = !(
             tag.childNodes[0].nodeName == "#text"
          && tag.childNodes[1].nodeName.toLowerCase() == "for"
          && tag.childNodes[2].nodeName == "#text"
          && tag.childNodes.length == 3
        );
        if (is_syntax_error){
          nebula_write_error(
            "次のreplace タグが構文エラーです。<br>"
            + "<code>" + code_escape(tag.outerHTML) + "</code>"
          );
        }
        var A = code_unescape(tag.childNodes[0].nodeValue);
        var B = code_unescape(tag.childNodes[2].nodeValue);
        
        content_node.innerHTML
        = swap_string(content_node.innerHTML, A, B);

      }
    });

    var uri = new URL(window.location.href);
    uri.searchParams.delete("nebula_switch");
    content_node.innerHTML
    += "<h2>お知らせ:この記事は、「男女逆にして」表示されています</h2>"
    + "<p>WikiNebula では、女性に対して向けられるべきではないような" 
    + "差別や冷遇が、男性に対しては現実に起きてしまっていることを、"
    + "記事として取り上げています。</p>"
    + "<p>そのため、 WikiNebula には、男性が経験するこの種の" 
    + "差別や女尊男卑を理解しやすくするために、"
    + "男女の立場を入れ替えて表示する「男女入れ替えスイッチ」"
    + "の機能があります。</p>"
    + "<p>現在、男女入れ替えスイッチが有効になっています。"
    + "無効にするには、<a href='" + uri.toString() +"'>こちら</a>を"
    + "クリックしてください</p>";

  }
    function code_escape(code){
      var textarea = document.createElement("textarea");
      textarea.innerText = code;
      return textarea.innerHTML;
    }

    function code_unescape(code){
      var textarea = document.createElement("textarea");
      textarea.innerHTML = code;
      return textarea.innerText;
    }

    function swap_string(input_string, x, y) {
      // xとyを正規表現の特殊文字からエスケープする
      x = x.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
      y = y.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');

      // xとyを入れ替える
      var regex = new RegExp('(' + x + '|' + y + ')', 'g');
      var result = input_string.replace(regex, function(match) {
        return match === x ? y : x;
      });

      return result;
    }


my_switch();