Skip to content

Instantly share code, notes, and snippets.

@rmkane
Last active April 17, 2020 00:31
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save rmkane/049a399501377586171f59e740482257 to your computer and use it in GitHub Desktop.
Save rmkane/049a399501377586171f59e740482257 to your computer and use it in GitHub Desktop.
Userscript : Gundam Build Divers - Episode Staff Translator
// ==UserScript==
// @name Gundam Build Divers - Episode Staff Translator
// @namespace net.gundam-bd.story
// @version 1.0.1
// @description Translates episode personel information
// @author rmkane
// @match http://www.gundam-bd.net/story/*
// @resource JQUERY_MODAL https://cdnjs.cloudflare.com/ajax/libs/jquery-modal/0.9.2/jquery.modal.min.css
// @require https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.0/jquery.min.js
// @require https://cdnjs.cloudflare.com/ajax/libs/jquery-modal/0.9.2/jquery.modal.min.js
// @grant GM_addStyle
// @grant GM_getResourceText
// @grant GM_log
// ==/UserScript==
(function() {
/* global $ */
'use strict';
const modalSelector = '#ep-info-modal';
const closeButtonImgData = '';
GM_addStyle(GM_getResourceText ('JQUERY_MODAL') + [
`${modalSelector} > p {`,
` font-family: "GBDB", sans-serif;`,
` color: #000;`,
`}`,
`${modalSelector} > p > h1 {`,
` font-weight: bold;`,
` text-align: center;`,
` margin: 0.25em 0 0.5em 0;`,
' font-size: 1.67em;',
`}`,
`${modalSelector} > p > table {`,
` border: 2px solid #59D7D9;`,
` border-collapse: collapse;`,
` width: 100%;`,
` height: 100%;`,
`}`,
`${modalSelector} > p > table th,`,
`${modalSelector} > p > table td {`,
` padding: 0.5em;`,
`}`,
`${modalSelector} > p > table tbody td:first-child {`,
` vertical-align: top;`,
`}`,
/* Colors */
`${modalSelector} > p > table thead th {`,
` background: #59D7D9;`,
`}`,
`${modalSelector} > p > table tbody tr:nth-child(even) {`,
` background: #D6FCFC;`,
`}`,
`${modalSelector} a.close-modal {`,
` background-image: url('${closeButtonImgData}')`,
`}`
].join(''));
const keyDict = {
"脚本" : "Script",
"絵コンテ" : "Storyboard",
"演出" : "Director",
"キャラクター作画監督" : "Character Designers",
"メカ作画監督" : "Mechanical Designers"
};
const personelDict = {
"阿部宗孝" : "Munetaka Abe",
"阿久津潤一" : "Junichi Akutsu",
"海老川兼武" : "Kanetake Ebikawa",
"形部一平" : "Ippei Gyōbu",
"羽原信義" : "Nobuyoshi Habara",
"樋口達人" : "Tatsuto Higuchi",
"平岡雅樹" : "Masaki Hiraoka",
"イムガヒ" : "Im Ga-hee",
"石垣純哉" : "Junya Ishigaki",
"石井久美" : "Kumi Ishii",
"イシノアツオ" : "Atsuo Ishino",
"川原智弘" : "Tomohiro Kawahara",
"木村秀彬" : "Hideakira Kimura",
"小林寛" : "Hiroshi Kobayashi",
"小暮昌広" : "Masahiro Kogure",
"小谷杏子" : "Kyoko Kotani",
"児谷直樹" : "Naoki Kotani",
"小谷野竜成" : "Tatsunari Koyano",
"久藤瞬" : "Shun Kudō",
"久壽米木信弥" : "Shinya Kusumegi",
"松田寛" : "Hiroshi Matsuda",
"森木靖泰" : "Yasuhiro Moriki",
"むらせまいこ" : "Shūkō Murase",
"むとうやすゆき" : "Yasuyuki Mutō",
"中原れい" : "Rei Nakahara",
"中本尚子" : "Naoko Nakamoto",
"西澤晋" : "Susumu Nishizawa",
"重田智" : "Susumu Nishizawa",
"野崎真一" : "Shinichi Nozaki",
"大張正己" : "Masami Ōbari",
"大貫健一" : "Kenichi Ohnuki",
"大河原邦男" : "Kunio Okawara",
"大久保朋" : "Tomo Ōkubo",
"大槻敦史" : "Atsushi Ōtsuki",
"大嶋博之" : "Hiroyuki Oshima",
"斉藤香" : "Kaori Saito",
"斉藤哲人": "Tetsuhito Saito",
"斎藤哲人" : "Tetsuhito Saito",
"島田フミカネ" : "Humikane Shimada",
"しんぼくたろう" : "Takuro Shinbo",
"しんぼ たくろう" : "Takuro Shinbo",
"鈴木勘太" : "Kanta Suzuki",
"大籠之仁" : "Norihito Takahashi",
"高見明男" : "Akio Takami",
"高瀬健一" : "Kenichi Takase",
"寺岡巌" : "Iwao Teraoka",
"寺岡賢司" : "Kenji Teraoka",
"寺島慎也" : "Shinya Terashima",
"鳥羽聡" : "Satoshi Toba",
"戸井田珠里" : "Shuri Toida",
"富野由悠季" : "Yoshiyuki Tomino",
"宇田早輝子" : "Sakiko Uda",
"鷲尾直広" : "Naohiro Washio",
"綿田慎也" : "Shinya Watada",
"山田靖智" : "Yasunori Yamada",
"山根理宏" : "Masahiro Yamane",
"山崎克之" : "Katsuyuki Yamazaki",
"柳瀬敬之" : "Takayuki Yanase",
"ヤスカワショウゴ" : "Shogo Yasukawa",
"矢立肇" : "Hajime Yatate"
};
let staffText = $('.c-story-box__staff p').text();
let episodeInfo = staffText.split('/').reduce((obj, pair) => {
let tokens = pair.split(/\s*:\s*/);
return Object.assign(obj, {
[ keyDict[tokens[0]] ] : tokens[1].split('、').map(name => personelDict[name] ? personelDict[name] : name)
});
}, {});
// Create, add, and show the modal
$('<div>', { id : 'ep-info-modal', class : 'modal' })
.append($('<p>')
.append($('<h1>', { text : 'Episode Staff' }))
.append(buildTable(episodeInfo)))
.append($('<a>', { href : '#', rel : 'modal:close', text : 'Close' }))
.appendTo('body')
.modal('show');
/**
* Constructs a table element containing staff information.
* @param {object} info - The episode staff information
* @returns {HTMLTableElement} returns a jQuery-wrapped table element.
*/
function buildTable(info) {
let fields = ['Role', 'Personel'];
let entries = Object.entries(info);
return $('<table>')
.append($('<thead>').append($('<tr>').append(fields.map(th => $('<th>').text(th)))))
.append('<tbody>').append(entries.map(pair => $('<tr>')
.append($('<td>', { text : pair[0] }))
.append($('<td>', { html : pair[1].join('<br>') }))));
}
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment