Last active
April 17, 2020 00:31
-
-
Save rmkane/049a399501377586171f59e740482257 to your computer and use it in GitHub Desktop.
Userscript : Gundam Build Divers - Episode Staff Translator
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ==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