mlpnlp Table Sorter

mlpnlp の正誤表をページ番号順にソートする

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램을 설치해야 합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

// ==UserScript==
// @name         mlpnlp Table Sorter
// @namespace    https://github.com/kyunashige/mlpnlp-table-sorter
// @version      0.3
// @description  mlpnlp の正誤表をページ番号順にソートする
// @author       kyuna
// @match        https://github.com/mlpnlp/mlpnlp
// @license      MIT
// @supportURL   https://github.com/kyunashige/mlpnlp-table-sorter/issues
// @grant        none
// ==/UserScript==

(() => {
  "use strict";
  /**
   * fetch correct/incorrect table
   */
  const $ = document.querySelector.bind(document);
  const coricTable = $("#readme > div > article > table > tbody");
  // console.log(toString.call(coricTable));
  /**
   * sort by PageNo
   */
  const rows = Array.prototype.slice.call(
    coricTable.getElementsByTagName("tr")
  );
  const getPageNo = (row) => {
    return parseInt(row.cells[2].innerText.match(/\d+/g)[0]);
  };
  rows.sort((a, b) => {
    return getPageNo(a) - getPageNo(b);
  });
  /**
   * create table
   */
  const tbody = $("tbody");
  for (const row of rows) {
    tbody.appendChild(row);
  }
  /**
   * replace table
   */
  $("#readme > div > article > table").appendChild(tbody);
})();