A better offline editor for Scratch 3.
Go to file
2024-03-03 14:10:57 -06:00
.github Modernize macOS notarization and signing 2024-03-03 14:10:38 -06:00
art Media permissions, crash messages, packager importing 2023-08-18 02:51:05 -05:00
build Enable MAS build 2023-08-28 22:35:02 -05:00
debian Finish release automation scripts 2023-09-09 15:44:33 -05:00
docs Update translations 2024-02-24 11:55:41 -06:00
extensions@813d4384d0 Bump extensions from 9f6f908 to 813d438 (#941) 2024-03-03 13:20:39 -06:00
linux-files Update metainfo screenshot URLs again 2024-02-18 04:35:18 -06:00
release-automation Log when flipping fuses completes 2024-03-03 14:10:57 -06:00
scripts Update dependencies 2024-02-04 19:07:43 -06:00
src-main Allow iframes to register service workers 2024-02-28 20:14:52 -06:00
src-preload Fix "Customize in Addon Settings" block colors button 2024-02-05 11:04:34 -06:00
src-renderer Merge pull request #856 from TurboWarp/remove-legacy-data 2023-11-25 17:17:38 -06:00
src-renderer-webpack/editor Prevent interacting with other elements when prompt() reimpl. is open 2024-02-16 21:34:17 -06:00
store-listings Fix incorrect command in README 2024-02-17 17:49:40 -06:00
.browserslistrc Update browserslistrc to fix build 2022-12-30 21:32:03 -06:00
.gitignore Modernize macOS notarization and signing 2024-03-03 14:10:38 -06:00
.gitmodules Use new screenshots from TurboWarp/desktop-screenshots 2024-02-17 17:44:07 -06:00
changelog.md New tentative changelog 2024-02-05 01:16:52 -06:00
LICENSE Initial commit 2021-01-04 19:11:51 -06:00
package-lock.json Modernize macOS notarization and signing 2024-03-03 14:10:38 -06:00
package.json Modernize macOS notarization and signing 2024-03-03 14:10:38 -06:00
README.md Fix a lot of build script errors 2024-01-22 18:20:32 -06:00
webpack.config.js Update dependencies 2024-02-04 19:07:43 -06:00

TurboWarp Desktop

TurboWarp as a desktop app.

If you're looking for downloads, head to: https://desktop.turbowarp.org/

Licensed under the GPLv3.0. See LICENSE for more information.

Parts of this repository are based on LLK/scratch-desktop.

Website

The website source code is in the docs folder.

Development

We use submodules, so clone using:

git clone --recursive https://github.com/TurboWarp/desktop turbowarp-desktop

or run this after cloning:

git submodule init
git submodule update

Install dependencies using:

npm ci

Then fetch extra library, packager, and extension files using:

npm run fetch

Repeat the three previous sets of commands every time you pull changes from GitHub.

Due to the security requirements mandated by custom extensions existing, our desktop app is significantly more complicated than Scratch's.

  • src-main is what runs in Electron's main process. There is no build step; this code is included as-is. src-main/entrypoint.js is the entry point to the entire app.
  • src-renderer-webpack runs in an Electron renderer process to make the editor work. This is built by webpack as dist-renderer-webpack.
  • src-renderer also runs in an Electron renderer process, but without webpack. This is used for things like the privacy policy window.
  • src-preload runs as preload scripts in an Electron renderer process. They export glue functions to allow renderer and main to talk to each other in a somewhat controlled manner.
  • dist-library-files and dist-extensions contain additional static resources managed by npm run fetch

To build the webpack portions in src-renderer-webpack for development builds, run this:

npm run webpack:compile

You can also run this instead for source file changes to immediately trigger rebuilds:

npm run webpack:watch

Once you have everything compiled and fetched, you are ready to package it up for Electron. For development, start a development Electron instance with:

npm run electron:start

Linux note: The app icon won't work in the development version, but it will work in the packaged version.

We've found that development can work pretty well if you open two terminals side-by-side and run npm run webpack:watch in one and npm run electron:start in the other. You can refresh the windows with ctrl+R or cmd+R for renderer file changes to apply, and manually restart the app for main file changes to apply.

Final production-ready builds

The development version of the app will be larger and slower than the final release builds.

Build an optimized version of the webpack portions with:

npm run webpack:prod

Then to package up the final Electron binaries, use either our build script release-automation/build.js (see release-automation/README.md) or the electron-builder CLI. Either way the final builds are saved in the dist folder. Here are some examples using the electron-builder CLI directly:

# You can also do manual builds with electron-builder's CLI, for example:
# Windows installer
npx electron-builder --windows nsis --x64
# macOS DMG
npx electron-builder --mac dmg --universal
# Linux Debian
npx electron-builder --linux deb

You can typically only package for a certain operating system while on that operating system.

Advanced customizations

TurboWarp Desktop lets you configure custom JS and CSS without rebuilding the app.

Find TurboWarp Desktop's data path by using the list below or by clicking "?" in the top right corner, then "Desktop Settings", then "Open User Data", then opening the highlighted folder, or refer to this list:

  • Windows (except Microsoft Store): %APPDATA%/turbowarp-desktop
  • Microsoft Store: Open %LOCALAPPDATA%/Packages, find the folder with the word TurboWarpDesktop in it, then open LocalCache/Roaming/turbowarp-desktop
  • macOS (except Mac App Store): ~/Library/Application Support/turbowarp-desktop
  • Mac App Store: ~/Library/Containers/org.turbowarp.desktop/Data/Library/Application Support/turbowarp-desktop (note that the org.turbowarp.desktop part may appear as TurboWarp in Finder)
  • Linux (except Flatpak and Snap): ~/.config/turbowarp-desktop
  • Linux (Flatpak): ~/.var/app/org.turbowarp.TurboWarp/config/turbowarp-desktop
  • Linux (Snap): ~/snap/turbowarp-desktop/current/.config/turbowarp-desktop

Create the file userscript.js in this folder to configure custom JS. Create the file userstyle.css in this folder to configure custom CSS. Completely restart TurboWarp Desktop (including all windows) to apply.

Uninstall

See https://desktop.turbowarp.org/uninstall