Feeder - Paste Upload

User script for uploading files from the clipboard in Feeder chat.

スクリプトをインストールするには、Tampermonkey, GreasemonkeyViolentmonkey のような拡張機能のインストールが必要です。

You will need to install an extension such as Tampermonkey to install this script.

スクリプトをインストールするには、TampermonkeyViolentmonkey のような拡張機能のインストールが必要です。

スクリプトをインストールするには、TampermonkeyUserscripts のような拡張機能のインストールが必要です。

このスクリプトをインストールするには、Tampermonkeyなどの拡張機能をインストールする必要があります。

このスクリプトをインストールするには、ユーザースクリプト管理ツールの拡張機能をインストールする必要があります。

(ユーザースクリプト管理ツールは設定済みなのでインストール!)

このスタイルをインストールするには、Stylusなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus などの拡張機能をインストールする必要があります。

このスタイルをインストールするには、Stylus tなどの拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

このスタイルをインストールするには、ユーザースタイル管理用の拡張機能をインストールする必要があります。

(ユーザースタイル管理ツールは設定済みなのでインストール!)

このスクリプトの質問や評価の投稿はこちら通報はこちらへお寄せください
// ==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();
})();