Welcome to the Scribe repository! This project provides an end-to-end solution for collecting, training, and simulating human-like mouse movements in the browser. It consists of:
- A data collection UI for recording user mouse movements.
- A machine learning model to train and test the collected data.
- A Puppeteer plugin that utilizes the trained model to produce human-like mouse movements.
The ui
folder hosts the web interface for collecting mouse movement data from users.
The model
folder contains the necessary scripts for training a model on the collected mouse movement data and testing the model's output.
The puppeteer-scribe
folder contains a Puppeteer plugin that integrates a trained model to control mouse movements in automated browser tasks. This plugin sends start and end coordinates to a server (hosting the trained model), receives the generated path, and moves the cursor smoothly along the predicted trajectory.
- Clone the repository:
git clone https://github.com/sameelarif/scribe.git cd scribe
- Install Dependencies
pip install -r model/requirements.txt
The data I personally collected can be downloaded from Kaggle: https://www.kaggle.com/datasets/sameelarif/mouse-movement-between-ui-elements.
If you'd like, you can run the data collection UI to collect your own data or add it to the existing dataset. To start the data collection interface:
cd ui
# Install dependencies
npm i
# Run the Next.js server
npm run start
After starting the web server, open it in your browser and use it to record your mouse movement data.
Download the dataset to the model
directory, and rename the DATA_FILE
variable from train.py
to your data file's name. To start the training:
python train.py
The model will output to model/models
, which you can use to power puppeteer-scribe
.
The puppeteer-scribe
folder contains an example of how one would integrate the model into a browser environment. The logic can be forked and edited to support Playwright, selenium, or any other web automation library.
To use the plugin, move your saved model's file into the model
folder. You don't need to replace previous model versions as the server will automatically pick the most recent file.
Assuming you already have dependencies installed, as previously shown, you can run the server:
cd puppeteer-scribe
# Run the server
python server/server.py
In another terminal window, you can run the test script:
# Install dependencies
npm i
# Run the test file from `examples`
npm test <test-name>
If you'd like to contribute, please create a pull request with a description of your changes. Your contributions will be merged as soon as they are approved.
This work is licensed under a Creative Commons Attribution-NonCommercial 4.0 International License. To view a copy of this license, visit http://creativecommons.org/licenses/by-nc/4.0/.
If you would like to use this project for commercial reasons, please contact me at me@sameel.dev
.