This is a Chrome extension developed using React, TypeScript, and Vite. The extension allows users to upload and process various file types through a chatbot-like conversation system.
-
Upload and process different file types such as TXT, JS, PY, HTML, CSS, JSON, CSV, MD, TS, TSX, JSX, PDF, DOC, DOCX, XLS, and XLSX.
-
Automatic extraction of text content from PDF, Word, and Excel files. Chunked processing of large files to accommodate chatbot limitations.
-
Configurable chunk size for better control over the conversation flow.
-
Simulated conversation prompt generation based on the file context.
-
User-friendly interface for selecting files and monitoring the upload progress.
-
Supported on Google Chrome as a browser extension. Installation
Clone the repository:
git clone https://github.com/ariburaco/chatgpt-file-uploader
Navigate to the project directory: cd file-uploader-extension
-Install dependencies: pnpm install
-Start the dev env.: pnpm run build
-Open Google Chrome and go to chrome://extensions.
-Enable the "Developer mode" toggle.
-Click on the "Load unpacked" button.
-Select the dist directory from the project folder.
-The File Uploader extension should now be installed and visible in the extensions list.
Once the File Uploader extension is installed, you can use it to upload and process files. Follow these steps:
- When you navigate the chat.openai.com, you will see the
Upload File
button under the message box. - The File Uploader interface will open in a new tab.
- Specify the chunk size (number of characters per chunk) for processing large files.
- The file will be divided into chunks and sent to the chatbot-like conversation system for processing.
- The conversation prompts will be generated based on the file context and displayed in the chat.
- Wait for each chunk to be processed before proceeding to the next one.
- The interface will be cleared, and you can upload another file if needed.
The File Uploader extension provides a configuration option for the chunk size. By default, the chunk size is set to 500 characters. To change the chunk size, follow these steps:
- Locate the "Chunk Size" input field.
- Enter the desired chunk size value. (10.000 to 15.000 is a good range)
The File Uploader extension supports the following file types for upload and processing:
- TXT: Plain text files
- JS: JavaScript files
- PY: Python files
- HTML: HTML files
- CSS: CSS files
- JSON: JSON files
- CSV: Comma-separated values files
- MD: Markdown files
- TS: TypeScript files
- TSX: TypeScript JSX files
- JSX: JSX files
- PDF: PDF files
- DOC: Microsoft Word documents (DOC format)
- DOCX: Microsoft Word documents (DOCX format)
- XLS: Microsoft Excel spreadsheets (XLS format)
- XLSX: Microsoft
Bootstrapped with chrome-extension-boilerplate-react-vite
This boilerplate is made for creating chrome extensions using React and Typescript.
The focus was on improving the build speed and development experience with Vite.
- React 18
- TypeScript
- Tailwind CSS
- Jest
- React Testing Library
- Vite
- SASS
- ESLint
- Prettier
- Chrome Extension Manifest Version 3
- HMR(incomplete)
- Clone this repository.
- Change
name
anddescription
in package.json => Auto synchronize with manifest - Run
pnpm install
ornpm i
(check your node version >= 16) - Run
pnpm dev
ornpm run dev
- Load Extension on Chrome
- Open - Chrome browser
- Access - chrome://extensions
- Check - Developer mode
- Find - Load unpacked extension
- Select -
dist
folder in this project (after dev or build)
- If you want to build in production, Just run
pnpm build
ornpm run build
.
Jetbrains | Jackson Hong |
---|---|