// ==UserScript==
// @name hitomi.la_zh-TW
// @namespace hitomi.la TW
// @description 這是在 hitomi.la 網站上運作的腳本,主要是將網頁中的類型、語言、分類標籤和系列英語部分換成中文,以便於了解作品的資訊。
// @version 13.4
// @include *://hitomi.la/*
// @compatible chrome >=55
// @icon https://ltn.hitomi.la/apple-touch-icon-57x57.png
// ==/UserScript==
const TranslatioDataURL = "https://raw.githubusercontent.com/zxc129567142/hitomi.la_zh-TW/master/TranslatioData.min.json";
let topbar = {},
booktypes = {},
lang = {},
bookseries = {},
booktags = {},
// 修改 Daily 的值能夠改變更新翻譯數據的頻率
// 預設值 7
Daily = 7,
nowTime = (new Date).getTime(),
TimeD = 0,
url = location.pathname; // 變數 url 設成當前網址路徑部分
const tEng = {
// 將標題轉成網址格式
h3ToURL: str => {
str = str.toLowerCase();
return (str === "recently added") ? "index" : str // encodeURI(str).replace(/\./g, "%2E").replace(/\-/g, "%2D");
},
// 簡單判斷翻譯工作區
tocht: (chgThis, txt, cht) => {
if (chgThis.textContent.match(txt)) {
chgThis.title = txt;
chgThis.textContent = cht
}
},
// 用於 頂部分類類型
topbar: topbar_obj => {
const topbartext = topbar_obj.textContent;
if (topbar[topbartext]) {
topbar_obj.title = topbartext;
topbar_obj.textContent = topbar[topbartext];
}
},
//用於 頂部語言
//
//var lang = {
// lang_eng: {
// "cht": lang_cht,
// "url": lang_url
// },
//}
topbarLang: lang_obj => {
const toplangtext = lang_obj.textContent;
const h3 = document.querySelector("h3");
const Title_h3 = h3.getAttribute("title") || h3.textContent;
const weburl = url.match("\/(galleries|manga|anime|doujinshi|gamecg|cg)\/");
if (!lang[toplangtext]) {
console.log(toplangtext);
return false
}
const lang_url = lang[toplangtext].url;
// console.log(lang_obj.innerHTML.match(lang_url) , lang_obj.innerHTML === toplangtext);
const RegExpUrl = new RegExp((tEng.h3ToURL(Title_h3) === "index" && lang_url === "all") ? "^\/$" : "(" + tEng.h3ToURL(Title_h3) + "\-" + lang_url + ")", "g");
if (RegExpUrl.test(lang_obj.getAttribute("href")) || weburl) {
lang_obj.title = toplangtext + " \( " + lang_url + " \)";
lang_obj.textContent = lang[toplangtext].cht;
}
},
//用於 語言
lang: lang_obj => {
const langText = lang_obj.textContent;
if (lang[langText]) {
lang_obj.title = langText + " \(" + lang[langText].url + "\)";
lang_obj.textContent = lang[langText].cht;
return;
}
lang_obj.title = langText.toUpperCase();
},
//用於 類型
types: types_obj => {
const typeText = types_obj.textContent.replace(/(^\s+)|(\s+$)/g, "");
if (booktypes[typeText]) {
types_obj.title = typeText;
types_obj.textContent = booktypes[typeText];
return;
}
types_obj.title = typeText.toUpperCase();
},
//用於 系列
series: series_obj => {
const seriesText = series_obj.textContent;
if (bookseries[seriesText]) {
series_obj.title = seriesText;
series_obj.textContent = bookseries[seriesText];
return;
}
series_obj.title = seriesText.toUpperCase();
},
//用於 標籤
tags: tags_obj => {
const tagText = tags_obj.textContent;
if (booktags[tagText]) {
tags_obj.title = tagText;
tags_obj.textContent = booktags[tagText];
return;
}
tags_obj.title = tagText.toUpperCase();
}
};
(function () {
"use strict";
localStorage.setItem("hitomi.la_zh-TW", "loading");
// 只要有任何一個不存在就重新下載 json 檔
if (!localStorage.hasOwnProperty("LastUpdata") ||
!localStorage.hasOwnProperty("topbar") ||
!localStorage.hasOwnProperty("booktypes") ||
!localStorage.hasOwnProperty("lang") ||
!localStorage.hasOwnProperty("bookseries") ||
!localStorage.hasOwnProperty("booktags")) {
// 缺少
gtd(true);
} else {
// 完整
TimeD = (nowTime - localStorage.getItem("LastUpdata")) / 1000;
Daily = Daily * 24 * 3600;
if (TimeD > Daily) {
// 資訊完整 但 達到資料更新時間
gtd(true);
} else {
topbar = JSON.parse(localStorage.getItem("topbar"));
booktypes = JSON.parse(localStorage.getItem("booktypes"));
lang = JSON.parse(localStorage.getItem("lang"));
bookseries = JSON.parse(localStorage.getItem("bookseries"));
booktags = JSON.parse(localStorage.getItem("booktags"));
_TopBottom();
}
}
function gtd(autoUpdata) {
localStorage.setItem("LastUpdata", nowTime);
fetch(TranslatioDataURL + "?_=" + nowTime, {cache: "no-cache"})
.then(r => r.json())
.then(data => {
localStorage.setItem("topbar", JSON.stringify(data.topbar));
localStorage.setItem("booktypes", JSON.stringify(data.booktypes));
localStorage.setItem("lang", JSON.stringify(data.lang));
localStorage.setItem("bookseries", JSON.stringify(data.bookseries));
localStorage.setItem("booktags", JSON.stringify(data.booktags));
topbar = JSON.parse(localStorage.getItem("topbar"));
booktypes = JSON.parse(localStorage.getItem("booktypes"));
lang = JSON.parse(localStorage.getItem("lang"));
bookseries = JSON.parse(localStorage.getItem("bookseries"));
booktags = JSON.parse(localStorage.getItem("booktags"));
localStorage.setItem("nowSeriesNum", Object.keys(bookseries).length);
localStorage.setItem("nowTagsNum", Object.keys(booktags).length);
if (autoUpdata) {
console.log("資料更新成功");
_TopBottom();
} else {
console.log("手動資料更新成功");
$(".navbar nav").append("<div id=\"Notice\"><span>翻譯資料更新成功</span></div><style>#Notice{background-color:rgba(204, 255, 255, 0.9);border-radius:10px;border-top-right-radius:0;border-top-left-radius:0;position:fixed;top:-50px;left:50%;transform:translate(-50%,0);animation:Notice 1s linear}#Notice span{color:#666;display:block;font-weight:bold;margin:10px 63px}@keyframes Notice {0%{top:-50px}35%{top:0}85%{top:0}100%{top:-50px}}</style>");
}
})
.catch(e => {
console.log("資料取得失敗");
$(".navbar nav").append("<div id=\"Notice\"><span>資料取得失敗</span></div><style>#Notice{background-color:rgba(255, 204, 204, 0.9);border-radius:10px;border-top-right-radius:0;border-top-left-radius:0;position:fixed;top:-50px;left:50%;transform:translate(-50%,0);animation:Notice 2s linear}#Notice span{color:#666;display:block;font-weight:bold;margin:10px 63px}@keyframes Notice {0%{top:-50px}35%{top:0}85%{top:0}100%{top:-50px}}</style>");
throw new Error(e);
});
}
// 變數 LoadingStatus 0 為正在載入
// 1 為載入完成
// let LoadingStatus = 0;
// 是否在"全部系列"
let inallsatc = false;
// WaitLoad() 等待載入
function WaitLoad() {
const loader_content = $("#loader-content");
const gallery_content = $(".gallery-content");
if (loader_content.length == 1 || gallery_content.children().length === 0) {
if (loader_content.attr("style") == "display: none;" && gallery_content.children().length > 0) {
// 這是給搜尋頁面用的
window.setTimeout(()=>{RunTranslation();}, 150);
} else {
Timeout();
}
} else {
window.setTimeout(()=>{RunTranslation();}, 200);
}
}
// Timeout()
// 正規表達式 /all(tags|artists|series|characters)|reader/ (在字串中搜索"all"、"reader"字串)
// 若 hitomi.la 為"全部"和"閱讀"頁面則一百五十毫秒後呼叫 RunTranslation()
// 若是則二百五十毫秒後呼叫 WaitLoad()
function Timeout() {
// 變數 regex 用來儲存正規表示式
const regex = /all(tags|artists|series|characters)|reader/;
if (url.match(regex)) {
window.setTimeout(()=>{RunTranslation()}, 150);
} else {
window.setTimeout(()=>{WaitLoad()}, 250);
}
}
// RunTranslation()
// 依序呼叫 _ModifyCSS() _ADRemove() _HotKey()
let YouPosition;
function RunTranslation() {
document.querySelector(".navbar")
.insertAdjacentHTML("beforeend","<a id=\"TIMER\" style=\"color: rgb(255, 255, 255);font-weight: bold;\"></a>");
YouPosition = url.split("\/")[1].split(/\-|\./);
switch (YouPosition[0]) {
case "manga":
case "anime":
case "doujinshi":
case "gamecg":
case "cg":
case "galleries": {
console.log("========= 畫廊資訊區 =========");
setTimeout(() => {
_TranslationH3();
document.querySelectorAll(".tags")[1].parentElement.classList.add("relatedtags");
_TranslatioGalleries();
_TranslatioGalleriesInfo();
}, 50);
break;
}
case "reader": {
console.log("========= 畫廊閱讀區 =========");
setTimeout(() => {
_TranslationReader();
}, 10);
break;
}
case "alltags": {
console.log("========= 全部-標籤 =========");
_TranslationAll();
break;
}
case "allartists": {
console.log("========= 全部-畫家 =========");
_TranslationAll();
break;
}
case "allseries": {
console.log("========= 全部-系列 =========");
_TranslationAll();
_TranslationAllSeries();
break;
}
case "allcharacters": {
console.log("========= 全部-角色 =========");
_TranslationAll();
break;
}
case "search": {
console.log("========= 搜索區 =========");
setTimeout(() => {
_TranslationSearchH3();
_TranslatioGalleries();
_TranslationSearch();
_HotKey();
}, 10);
break;
}
default: {
console.log("========= ♥♥♥♥♥ =========");
setTimeout(() => {
_TranslationH3();
_TranslationOrderBy();
_TranslatioGalleries();
}, 10);
}
}
if (url.search("reader") < 0) _ModifyCSS();
_ADRemove();
if (url.search("search") < 0) _HotKey();
localStorage.setItem("hitomi.la_zh-TW", "success");
}
function _TopBottom() {
_TranslationTopInfo();
if (url.search("reader") < 0) {
const GreasyForkIcon = ""
const NeocitiesIcon = ""
$(".container").append("<style>div#lang-drop{width:135px;padding-top:13px;}ul#lang-list a{display:block}</style>");
$(".navbar>nav>ul").append("<li id=\"cht_help\"><a title=\"hitomi.la_zh-TW\">腳本問題 <img src=\"//ltn.hitomi.la/down-arrow.png\"></a><div id=\"cht_help_drop\"><ul id=\"cht_help_list\"><li><span>系列翻譯數:" + localStorage.getItem("nowSeriesNum") + "</span></li><li><span>標籤翻譯數:" + localStorage.getItem("nowTagsNum") + "</span></li><li><a id=\"update\">手動更新數據</a></li><li><a href=\"https://goo.gl/iurbA6\" target=\"_blank\">中文化問題</a></li><li><hr></li><li><a href=\"https://greasyfork.org/zh-TW/scripts/23864-hitomi-la-zh-tw\" target=\"_blank\"><img src='" + GreasyForkIcon + "' alt=\"greasyfork icon\" >Greasy Fork</a></li><li><a href=\"https://zxc129567142.neocities.org/hitomi_la_zh_tw/index.html\" target=\"_blank\"><img src='" + NeocitiesIcon + "'>Neocities</a></li></ul></div></li>");
$(".navbar>nav").append("<style>#cht_help_drop{display:none;position:absolute;margin:0px;padding:0px 15px;padding-top:13px;z-index:99999;background-color:#29313d;left:0px;right:0px;max-height:500px;width:155px;}#cht_help:hover #cht_help_drop{display:block;}#cht_help_list li{color:#aaa;display:block;position:relative;margin-bottom:10px;}#cht_help_list a,#cht_help_list span{color:inherit;display:block;padding:0px;text-decoration:none;text-transform:none;font-weight:normal;}#cht_help_list a{cursor:pointer;}#cht_help_list a:hover{color:#fff;font-weight:bold;}#cht_help_list span{cursor:default;}#cht_help_list img{vertical-align:middle;margin-right:5px;width:20px;}#cht_help_list svg{margin-right:5px;}</style>");
}
_TranslationBottomDonate();
$("#update").one('click', () => {
gtd(false);
});
Timeout();
}
//翻譯上方的導覽列
function _TranslationTopInfo() {
//頂部分類類型
$(".navbar a").each((i, v) => {
tEng.topbar(v);
});
//頂部語言
const lang = document.querySelector("li#lang>a")
if (lang){
if (lang.textContent.trim() === "language") lang.innerHTML = "語言 <img src='//ltn.hitomi.la/down-arrow.png'>";
}
const interval = setInterval(() => {
const lang_list = document.querySelectorAll("#lang-list a");
if (lang_list.length > 1) {
clearInterval(interval);
for (const item of lang_list) {
// console.log(item);
tEng.topbarLang(item);
}
}
}, 500 )
//頂部搜尋
if ($(".header-table").length > 0) {
$("button#search-button").text("搜尋");
let search_hint = "你可以使用組合條件 \"female:yuri -female:futanari\",此範例會尋找含有 \"yuri\" 但不含 \"futanari\"。"
search_hint += "\n當要輸入帶有空白的標籤使用 \"_\" 字符。"
search_hint += "\n更多範例:"
search_hint += "\n\"series:kantai_collection type:doujinshi female:big_breasts\",會尋找含有 \"系列:艦隊收藏\"、\"類型:同人誌\"、\"巨乳 ♀\" "
search_hint += "\n\"type:artistcg female:milf -male:yaoi language:chinese\",會尋找含有 \"類型:美術 CG\"、\"熟女 ♀\"、\"語言:中文\" 但不包含 \"男同(BL) ♂\" "
search_hint += "\n\"artist:andou_tomoya -type:gamecg series:love_live\",會尋找含有 \"畫家:Andou Tomoya\"、\"系列:Love Live\" 但不包含 \"類型:遊戲 CG\" "
$(".search-input#search").attr("title", search_hint);
}
}
//翻譯畫廊相關
function _TranslatioGalleries() {
//分類
const cata = {
"Series": "系列",
"Type": "類型",
"Language": "語言",
"Tags": "標籤",
"Group": "群組",
"Characters": "角色",
}
document.querySelectorAll("tr td:nth-of-type(1)").forEach(v => {
const text = v.textContent
switch (text) {
case "Series":
if (v.nextElementSibling.firstElementChild)
v.nextElementSibling.firstElementChild.className = "comma-list";
case "Type":
case "Language":
case "Tags":
case "Group":
case "Characters":
v.title = text;
v.textContent = cata[text];
break;
default: {
console.log("例外 分類: " + text);
}
}
});
//語言
document.querySelectorAll("tr:nth-of-type(3) td:nth-of-type(2) a")
.forEach(item => {
tEng.lang(item);
})
//類型
document.querySelectorAll("tr:nth-child(2) td:nth-child(2) a")
.forEach(item => {
tEng.types(item);
})
//系列
document.querySelectorAll("table .comma-list a")
.forEach(item => {
tEng.series(item);
})
//標籤
document.querySelectorAll(".relatedtags a")
.forEach(item => {
tEng.tags(item);
})
//當群組、系列、語言為"N/A"
document.querySelectorAll("tr:not(:last-of-type) td:nth-of-type(2)")
.forEach(item => {
tEng.tocht(item, "N/A", "無");
})
//當作者名為"N/A"
document.querySelectorAll("div.artist-list")
.forEach(item => {
tEng.tocht(item, "N/A", "無");
})
}
//翻譯畫廊資訊頁面
function _TranslatioGalleriesInfo() {
//資訊頁面作者名為"N/A"
document.querySelectorAll("h2")
.forEach(item => {
tEng.tocht(item, "N/A", "無");
})
//資訊頁面
document.querySelectorAll(".cover-column h1").forEach( item => {
switch (item.textContent) {
case "Download":
item.textContent = "下載"
break;
case "Read Online":
item.textContent = "線上閱讀"
break;
default:
break;
}
});
}
//翻譯h3標題
function _TranslationH3() {
//區塊h3標題
const h3 = document.querySelector("div.list-title h3")
switch (h3.textContent) {
case "Recently Added": {
tEng.tocht(h3, "Recently Added", "最近更新");
break;
}
case "Popular": {
tEng.tocht(h3, "Popular", "熱門度");
break;
}
case "Related Galleries": {
tEng.tocht(h3, "Related Galleries", "相關畫廊");
break;
}
default: {
console.log(h3.textContent);
}
}
}
//翻譯搜尋頁h3標題
function _TranslationSearchH3() {
//區塊h3標題
const h3 = $("div.list-title h3");
const engTxt = h3.text();
const chtTxt = engTxt.replace("Results", "個結果");
h3.attr("title", engTxt).text(chtTxt);
}
//翻譯搜尋頁
function _TranslationSearch() {
const pag_top = $(".page-top a")
if (pag_top.length === 0) {
const search_message = document.querySelector(".gallery-content .search-message");
if (search_message.textContent == "No results") search_message.textContent = "無結果";
return;
}
pag_top.one("click", () => {
setTimeout(function _Search() {
const loader_content = document.getElementById("loader-content");
if (!loader_content) return;
if (loader_content.style.display == "none" && $(".gallery-content").children().length > 0) {
_TranslatioGalleries();
_ModifyCSS();
_HotKey();
_TranslationSearch();
} else {
setTimeout(() => { _Search() }, 150);
}
}, 50);
});
}
//翻譯"全部"頁面
function _TranslationAll() {
//"全部"頁面大標題
let count = 0;
let satc = [
["tags", "artists", "series", "characters"],
["標籤", "畫家", "系列", "角色"]
],
atoz = ["123", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"],
allh3 = $("div.list-title h3");
inallsatc = true;
for (let S = 0; S < satc[0].length; S++) {
if (allh3.text().match(satc[0][S]) == satc[0][S]) {
for (let A = 0; A < atoz.length; A++) {
if (allh3.text().substr(-1) == atoz[A].substr(-1) && allh3.text().substr(0, 3) === "All") {
allh3.text("全部字首 " + atoz[A] + " 的" + satc[1][S]);
count++
}
}
}
}
console.log(count);
}
//翻譯"全部"系列
function _TranslationAllSeries() {
//"全部"系列
const ul_post = document.querySelectorAll("ul.posts a")
if (ul_post.length > 0 && url.search("allseries") > 0) {
ul_post.forEach(item => {
tEng.series(item);
});
}
}
//翻譯閱讀頁面
function _TranslationReader() {
document.querySelectorAll(".brand")
.forEach(item => {
tEng.tocht(item, "Gallery Info", "畫廊資訊");
});
document.querySelectorAll(".navbar-nav a")
.forEach((item)=>{
const itemText = item.textContent.trim()
const itemID = item.id
if (itemText === "Next") item.innerHTML = "<i class='icon-chevron-left icon-white'></i>下一頁";
if (itemText === "Prev") item.innerHTML = "上一頁<i class='icon-chevron-right icon-whitee'></i>";
if (itemText === "Fullscreen") item.innerHTML = "<i class='icon-fullscreen icon-white'></i>全螢幕";
if (itemText === "Full Spread") item.innerHTML = "<i class='icon-pause icon-white'></i>全頁";
if (itemText === "Single Page") item.innerHTML = "<i class='icon-stop icon-white'></i>單頁";
if (itemID === "fitVertical") item.innerHTML = "切合<i class='icon-resize-vertical icon-white'></i>";
if (itemID === "fitHorizontal") item.innerHTML = "切合<i class='icon-resize-horizontal icon-white'></i>";
});
document.querySelectorAll(".input-medium option")
.forEach(item => {
tEng.tocht(item, item.innerHTML, "第 " + item.value + " 頁");
});
}
//翻譯底部官方贊助
function _TranslationBottomDonate() {
//底部贊助
const donate = document.querySelector("div.donate");
if (!donate) return;
const donateHTML = donate.querySelectorAll(".rss-icon")
let cloneRSS = "";
if (donateHTML.length > 0) cloneRSS = donate.innerHTML.replace(donate.textContent, "");
if (donate.innerHTML.match("Donate BTC")) donate.innerHTML = cloneRSS + donate.textContent.replace("Donate BTC","贊助 BTC");
}
//翻譯排序方式
function _TranslationOrderBy() {
const header_option = document.querySelectorAll("div.header-sort-select option")
header_option.forEach(itme => {
tEng.tocht(itme, "Order by:", "排序方式");
tEng.tocht(itme, "Date Added", "日期");
tEng.tocht(itme, "Popularity", "熱門度");
});
}
//修改CSS
function _ModifyCSS() {
const container = $(".container")
container.append(
inallsatc?
"<style>h3{margin-top:5px;margin-bottom:5px;padding-left:0px;}div.top-content{padding-top:20px}.page-content ul{color:#d47972}</style>"
:
"<style>h3{margin-bottom:5px;padding-left:80px;}div.top-content{padding-top:15px}</style>"
);
$("div.gallery-info").find("tr").children("td:first-child").css("width", "50px");
const djContent = document.querySelectorAll("div.dj-content")
for (const content of djContent) {
}
$("div.dj-content").each((i, v) => {
const item = $(v)
const item_a = item.find("a").last()
if (item.parent().find("h1 a").attr("href") === item_a.attr("href")) {
item_a.css("display", "none");
}
item.find("li.hidden-list-item").removeClass("hidden-list-item");
item.find("tr td:first-child").css("width", "50px");
});
}
//額外-廣告
function _ADRemove() {
const els = document.querySelectorAll("div[class*='hitomi'],div[id*='hitomi'],div[style*='z-index'],div[style*='position'],iframe")
for (const el of els) el.remove();
}
// 額外-熱鍵
// 參考:Danbooru(https://danbooru.donmai.us/static/keyboard_shortcuts)
// 重複執行
function _HotKey() {
console.log("[_HotKey Init]");
let page = $("html"),
pagClass = "",
pageIndex = 0,
First_page = 1,
End_page = 0,
Scroll_Length = 50,
Break_HotKey = false;
let getEl, findEl, Next_pageIndex, Previous_pageIndex;
// 搜尋頁面有問題
// 搜尋頁面 : 其他頁面
pagClass = (url.search("search") > 0) ? ".page-top" : ".page-container"
const pag = document.querySelector(pagClass);
if (pag) {
getEl = pag.querySelectorAll("li");
findEl = [...getEl].filter((b) => b.childElementCount === 0 && b.textContent.search(/\d+/) === 0);
pageIndex = parseInt(findEl[0].textContent);
End_page = parseInt(pag.querySelector("li:last-child").textContent);
localStorage.setItem("pageIndex", pageIndex);
if(pageIndex < End_page) pag.querySelector(`a[href$='${pageIndex + 1}']`).classList.add("Next_pageIndex");
if(pageIndex > First_page) pag.querySelector(`a[href$='${(pageIndex - 1 === 1 && pagClass === ".page-container") ? decodeURI(location.pathname) : `${pageIndex - 1}`}']`).classList.add("Previous_pageIndex");
Next_pageIndex = pag.querySelector("a.Next_pageIndex");
Previous_pageIndex = pag.querySelector("a.Previous_pageIndex");
}
document.body.onkeyup = function (e) {
let _pI = parseInt(localStorage.getItem("pageIndex"))
if (document.querySelectorAll("#query-input:focus").length > 0) Break_HotKey = true;
switch (e.key) {
case "ContextMenu":
case "Control":
case "Shift":
case "Alt":
case "Tab":
case "Meta":
Break_HotKey = true;
return false;
case "D":
case "d":
case "ArrowRight": //下一頁
if (End_page > _pI && !Break_HotKey && Next_pageIndex) {
Next_pageIndex.click();
}
Break_HotKey = false;
break;
case "A":
case "a":
case "ArrowLeft": //上一頁
if (First_page < _pI && !Break_HotKey && Previous_pageIndex) {
Previous_pageIndex.click();
}
Break_HotKey = false;
break;
case "W":
case "w":
case "S":
case "s":
Scroll_Length = 50;
Break_HotKey = false;
break;
case "H":
case "h": //回首頁
if (!Break_HotKey) {
$("div#logo a")[0].click();
}
Break_HotKey = false;
break;
case "Q":
case "q": //搜索
if (!url.match("(\/reader\/)") && !Break_HotKey) {
page.stop().animate({
scrollTop: 0,
}, 200, "linear", () => {
$("#query-input").focus();
});
}
Break_HotKey = false;
break;
default:
Break_HotKey = false;
}
}
document.body.onkeydown = function (e) {
if (document.querySelectorAll("#query-input:focus").length > 0) Break_HotKey = true;
switch (e.key) {
case "ContextMenu":
case "Control":
case "Shift":
case "Alt":
case "Tab":
case "Meta":
Break_HotKey = true;
return false;
case "W":
case "w": //向上滾動
if (page.scrollTop() > 0 && !Break_HotKey) {
page.stop().animate({
scrollTop: page.scrollTop() - Scroll_Length,
}, 100, "linear");
Scroll_Length += 5;
} else { //網頁到頂
break;
}
Break_HotKey = false;
break;
case "S":
case "s": //向下滾動
if (page.scrollTop() + $(window).height() < page.outerHeight() && !Break_HotKey) {
page.stop().animate({
scrollTop: page.scrollTop() + Scroll_Length,
}, 100, "linear");
Scroll_Length += 5;
} else { //網頁到底
break;
}
Break_HotKey = false;
break;
default:
Break_HotKey = false;
}
};
}
})();