您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
i,j,k 키를 눌러보세요
当前为
// ==UserScript== // @name 토끼 뷰어 // @name:ko 토끼 뷰어 // @name:en toki viewer // @description i,j,k 키를 눌러보세요 // @description:ko i,j,k 키를 눌러보세요 // @description:en press i to open // @version 231022190837 // @match https://*.net/comic/* // @match https://*.com/webtoon/* // @author nanikit // @namespace https://greatest.deepsurf.us/ko/users/713014-nanikit // @connect * // @grant GM_getResourceText // @grant GM_getValue // @grant GM_setValue // @grant GM_xmlhttpRequest // @grant unsafeWindow // @require https://cdn.jsdelivr.net/npm/[email protected]/require.js // @resource @stitches/react https://cdn.jsdelivr.net/npm/@stitches/[email protected]/dist/index.cjs // @resource fflate https://cdn.jsdelivr.net/npm/[email protected]/lib/browser.cjs // @resource jotai https://cdn.jsdelivr.net/npm/[email protected]/index.js // @resource jotai/react https://cdn.jsdelivr.net/npm/[email protected]/react.js // @resource jotai/react/utils https://cdn.jsdelivr.net/npm/[email protected]/react/utils.js // @resource jotai/utils https://cdn.jsdelivr.net/npm/[email protected]/utils.js // @resource jotai/vanilla https://cdn.jsdelivr.net/npm/[email protected]/vanilla.js // @resource jotai/vanilla/utils https://cdn.jsdelivr.net/npm/[email protected]/vanilla/utils.js // @resource react https://cdn.jsdelivr.net/npm/[email protected]/cjs/react.production.min.js // @resource react-dom https://cdn.jsdelivr.net/npm/[email protected]/cjs/react-dom.production.min.js // @resource scheduler https://cdn.jsdelivr.net/npm/[email protected]/cjs/scheduler.production.min.js // @resource vcv-inject-node-env data:,unsafeWindow.process=%7Benv:%7BNODE_ENV:%22production%22%7D%7D // @resource vim_comic_viewer https://greatest.deepsurf.us/scripts/417893-vim-comic-viewer/code/vim%20comic%20viewer.js?version=1268706 // ==/UserScript== "use strict"; define("main", (require, exports, module) => { var import_vim_comic_viewer = require("vim_comic_viewer"); async function main() { if (!location.origin.match(/manatoki|newtoki/)) { return; } const button = duplicateViewerButton(); try { const controller = await (0, import_vim_comic_viewer.initialize)({ source: comicSource }); button.addEventListener("click", async () => { await controller.toggleFullscreen(); }); } catch (error) { console.log(error); } } function duplicateViewerButton() { const bottomViewerButton = document.querySelector( ".main-footer .show_viewer" ); const myButton = bottomViewerButton.cloneNode(true); myButton.href = "#"; myButton.style.color = "blue"; bottomViewerButton.parentElement.insertBefore(myButton, bottomViewerButton); return myButton; } function comicSource() { registerEpisodeNavigator(); return getUrls(); } function registerEpisodeNavigator() { addEventListener("keydown", (event) => { const { ctrlKey, shiftKey, altKey } = event; if (ctrlKey || shiftKey || altKey || import_vim_comic_viewer.utils.isTyping(event)) { return; } switch (event.key) { case "h": case "ArrowLeft": document.getElementById("goPrevBtn")?.click?.(); break; case "l": case "ArrowRight": document.getElementById("goNextBtn")?.click?.(); break; case "m": document.querySelector(".view-good")?.scrollIntoView({ block: "center" }); break; } }); } function getUrls() { const imgs = document.querySelectorAll( "div.view-padding img" ); const urls = [...imgs].flatMap(getUrl); return urls; } function getUrl(image) { if (image.offsetParent === null) { return []; } const data = Object.values(image.dataset); return data.length ? data : [image.src]; } main(); }); define("tampermonkey_grants", function() { Object.assign(this.window, { GM, GM_getResourceText, GM_getValue, GM_setValue, GM_xmlhttpRequest, unsafeWindow }); }); requirejs.config({ deps: ["tampermonkey_grants"] }); for (const name of ["@stitches/react", "fflate", "jotai", "jotai/react", "jotai/react/utils", "jotai/utils", "jotai/vanilla", "jotai/vanilla/utils", "react", "react-dom", "scheduler", "vcv-inject-node-env", "vim_comic_viewer"]) { const body = GM_getResourceText(name); define(name, Function("require", "exports", "module", body)); } require(["main"], () => {}, console.error);