您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
User script for uploading files from the clipboard in Feeder chat.
- // ==UserScript==
- // @name Feeder - Paste Upload
- // @name:ja Feeder - 貼り付けてアップロード
- // @description User script for uploading files from the clipboard in Feeder chat.
- // @description:ja Feederチャットでクリップボードからファイルをアップロードするためのユーザースクリプトです。
- // @version 2.0.3
- // @icon 
- // @match https://*.x-feeder.info/*/
- // @exclude https://*.x-feeder.info/*/*/*
- // @namespace https://github.com/sqrtox/userscript-feeder-paste-upload
- // @author sqrtox
- // @license MIT
- // @grant unsafeWindow
- // ==/UserScript==
- "use strict";
- (() => {
- // src/utils/ElementIds.ts
- var ElementIds = {
- DropzoneArea: "picture_drop_zone_area",
- OpenDropzoneAreaButton: "post_picture",
- ImageSizeSelect: "frame_size",
- PostFormSingle: "post_form_single",
- PostFormMultiline: "post_form_multi"
- };
- // src/utils/getElement.ts
- var getElement = (id) => {
- const element = document.getElementById(id);
- if (!element) {
- throw new Error(`Element with id "${id}" not found`);
- }
- return element;
- };
- // src/utils/ImageSizes.ts
- var ImageSizes = {
- Original: "0",
- Small: "1",
- Medium: "2",
- Large: "3",
- ExtraLarge: "4",
- Largest: "5"
- };
- // src/utils/openDropzoneArea.ts
- var openDropzoneArea = () => {
- const dropzoneArea = getElement(ElementIds.DropzoneArea);
- const dropzoneAreaIsHidden = !dropzoneArea.style.display || dropzoneArea.style.display === "none";
- if (dropzoneAreaIsHidden) {
- const openDropzoneAreaButton = getElement(ElementIds.OpenDropzoneAreaButton);
- openDropzoneAreaButton.click();
- const imageSizeSelect = getElement(ElementIds.ImageSizeSelect);
- imageSizeSelect.value = ImageSizes.Original;
- }
- };
- // src/utils/getDropzone.ts
- var getDropzone = () => {
- const dropzone = unsafeWindow.Dropzone.instances[0];
- if (!dropzone) {
- throw new Error("Dropzone instance not found");
- }
- return dropzone;
- };
- // src/utils/handlePaste.ts
- var handlePaste = ({ clipboardData }) => {
- if (!clipboardData) {
- return;
- }
- const file = clipboardData.files[0];
- if (!file) {
- return;
- }
- openDropzoneArea();
- const dropzone = getDropzone();
- dropzone.addFile(file);
- };
- // src/utils/applyHandlePaste.ts
- var applyHandlePaste = () => {
- const postFormSingle = getElement(ElementIds.PostFormSingle);
- const postFormMultiline = getElement(ElementIds.PostFormMultiline);
- postFormSingle.addEventListener("paste", handlePaste);
- postFormMultiline.addEventListener("paste", handlePaste);
- };
- // src/index.ts
- applyHandlePaste();
- })();