An example project to show how to run 🤗 Transformers in an Electron application.
-
Clone the repo and enter the project directory:
git clone https://github.com/xenova/transformers.js.git cd transformers.js/examples/electron/
-
Install the necessary dependencies:
npm install
-
Run the application:
npm run start
After a few seconds, a new window should pop up on your screen!
All source code can be found in ./src/
:
-
index.js
- Serves as the entry point for the application's main process. When an Electron app is launched, this is the first file that gets executed, and it is responsible for setting up the main process of the application. You will need to restart the application after editing this file for your changes to take effect. -
preload.js
- Used to preload scripts and modules in a renderer process before any other scripts run. In our case, we use thecontextBridge
API to expose therun
function to the renderer, which runs the model in the background. You will need to restart the application after editing this file for your changes to take effect. -
model.js
- Contains all the logic for loading the model and running predictions. You will need to restart the application after editing this file for your changes to take effect. -
client.js
- Handles interaction with the interface, as well as communication between the renderer thread (UI) and the worker thread (processing). To see changes made to this file made while editing, simply refresh the window (Ctrl + R or "View" → "Reload"). -
index.html
,index.css
- The user interface which is displayed to the user. To see changes made to this file made while editing, simply refresh the window (Ctrl + R or "View" → "Reload").