From f3846d3d58b88d459c135d9aefc3b46b05730430 Mon Sep 17 00:00:00 2001 From: Alex Cui Date: Sat, 5 Jun 2021 00:53:45 +0800 Subject: [PATCH] Squashed commit of the following: commit 34f97dbcffbd032d08abc6f351a95c4a28418cf9 Author: Alex Cui Date: Sat Jun 5 00:52:22 2021 +0800 Modified files commit b0f9630623bf843762b4ef4b1c75379fef0e0c39 Merge: 433c0e1 a72614d Author: Alex Cui Date: Sat Jun 5 00:51:46 2021 +0800 Merge remote-tracking branch 'remotes/llk/develop' into sync-llk commit 433c0e16586807f5714a32200730fda8d268c72f Merge: 546cc5f 18d5dfc Author: Alex Cui Date: Sat Jun 5 00:15:22 2021 +0800 Merge branch 'master' into sync-llk commit a72614d00f5b50dbf99a28ef918734b58c3465a0 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Jun 2 23:40:23 2021 -0700 3.23.1 commit 0f5cb709a1835aca162a67b4860fa9ace53af70e Merge: 0bfbe0a 5831e8b Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Jun 2 23:39:16 2021 -0700 Merge pull request #197 from LLK/csc-gz Fix automated builds commit 5831e8bfa129f89c0964a7df5b9b6e4a54dd502c Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Jun 2 21:38:02 2021 -0700 update handling of context vars on CircleCI commit 24d704a0012390238f12442fd7377fcfb1eca04b Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Jun 2 22:21:01 2021 -0700 update to electron-builder@22.11.5 commit 1c4aa2b7555218f98f9c7efb4d2db54a3773fa0a Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Jun 2 22:43:07 2021 -0700 use Node 14 on CircleCI commit 0bfbe0a263c038f346cb530b3282f4b057542be8 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Jun 2 11:14:12 2021 -0700 3.23.0 commit 4f99e91e51083b69ad3c503d5ab1fb10faa12119 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Jun 2 11:13:25 2021 -0700 bump scratch-gui to scratch-desktop-v3.23.0 commit cf4d0bea138857dec2489e88c920ce58b6cb4a46 Merge: 0a6aad3 fedb21f Author: DD Liu Date: Tue Jun 1 15:12:03 2021 -0400 Merge pull request #196 from fsih/updateUploadComment Update comment to reflect camera upload feature removal commit fedb21f39179e85af8cda13e0cb44b78717c1d45 Author: DD Liu Date: Tue Jun 1 13:46:19 2021 -0400 Update comment commit 0a6aad3e867059e18d88373cf8718d4654a42e8d Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu May 6 11:50:24 2021 -0700 3.22.0 commit 2a6893d58eb10aa572cd08dbb1159343a39343e5 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu May 6 11:49:46 2021 -0700 add release instructions to README.md commit 1c75d4d2fab98906935f4ec02c83984b61af6537 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu May 6 11:46:31 2021 -0700 bump scratch-gui to scratch-desktop-v3.22.0 commit 8a3bb14b6261f800ddfa7c73fbae9ba4d509c5d9 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Mar 31 15:38:58 2021 -0700 3.21.0 commit b16c221bcc2cf9f7566a2e69e8ba52f80ca49e50 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Mar 31 15:38:39 2021 -0700 bump scratch-gui to scratch-desktop-v3.21.0 commit 419ece9efe8fcc9e109f0d59faf5571466fd4112 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Mar 3 18:48:48 2021 -0800 3.20.1 commit f5ff9d6a40a3b99d2d4d40fa9434a15e12f21bd1 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Mar 3 18:48:40 2021 -0800 bump scratch-gui for 3.20.1 commit 712a6a22c1be34bcd4d38bda01bf62125aa287ed Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Mar 2 10:34:15 2021 -0800 3.20.0 commit 0b882673396fa57c1e4071ed3d425cb32a9f6b4e Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Mar 2 10:34:08 2021 -0800 bump scratch-gui for 3.20.0 commit e566df37154ae1970a4a3de49c75fb6aa1c346f3 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Jan 28 14:46:53 2021 -0800 3.19.2 commit 35f9001eec1c77a049ebfa219cff27251d329239 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Jan 28 14:13:21 2021 -0800 build APPX for both 32-bit and 64-bit Previous APPX packages were 32-bit by default. At some point this switched to 64-bit by default, but I didn't notice because the APPX release was blocked at the time. This change enables both, which seems ideal the MS Store will choose the right build for a given client. commit bcc821d3eaf9bccc1f9b8960119e0c081a309c41 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Jan 28 11:18:05 2021 -0800 3.19.1 commit 603d92685671653f8c5f0f7e4e790d02e468c25a Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Jan 28 11:17:53 2021 -0800 Use ${productName} in privacy policy window title commit 9d5dab22a8641cdd30bdd8f058efa299fae35301 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Jan 26 14:47:04 2021 -0800 3.19.0 commit de64af99f37b6363bb6c414d881144432b0e3fad Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Jan 26 14:46:53 2021 -0800 bump scratch-gui for 3.19.0 commit c8c9ae51f4b689f59f27dcc9636ad8a67e4cdbe1 Merge: 0b8ce6c 728d705 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Jan 26 14:25:44 2021 -0800 Merge pull request #166 from cwillisf/fix-telemetry-modal Fix telemetry modal commit 728d705b1ac6768c47c89a8297cf77c838f7f977 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Jan 26 14:17:22 2021 -0800 fix merge & rearrange components to satisfy lint commit 3d0963fbd7687f976d2f8ff984ef4cd1360a9775 Merge: c110b13 0b8ce6c Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Jan 26 12:39:58 2021 -0800 Merge branch 'develop' into fix-telemetry-modal commit 0b8ce6cc00413eb4442a3b28ff9b007c59342c41 Merge: d8f289f 7f8d0d7 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Jan 26 12:03:58 2021 -0800 Merge pull request #171 from cwillisf/privacy-policy Show privacy policy inside app commit 7f8d0d7084c0f960a4ad9da814b27cbdebeb57bc Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Dec 15 15:28:39 2020 -0800 remove now-unused clearDidOptIn commit bcc9ff5c1e00b447ab4e7987e8e2e7d65482231a Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Dec 15 15:25:03 2020 -0800 avoid IPC sendSync in render() commit c110b13affc12cf6cf9443bda943caa25eb1471a Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Dec 9 14:02:08 2020 -0800 clarify HOC names and move props to match Previously the two HOCs in app.jsx were named according to their place in the component structure, which didn't provide any information about their functionality or meaning. Now they are named according to the components they wrap, which should help with future maintenance in that it will guide which props belong in each. commit 6e840825ccddf1f0d29ef441ff3306fee9643d5f Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Dec 2 14:24:58 2020 -0800 apply feedback from design team commit d56a3c58101a92625bd21ab155aae855fdeda823 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Dec 2 14:03:57 2020 -0800 keep telemetry modal state in sync with main process commit afb29bfdefa4c811a50112f5a3758e663b5122b4 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Nov 18 15:34:01 2020 -0800 use openTelemetryModal instead of showTelemetryModal commit 25072c00463cfaf151334506c81e3548b935abf6 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Nov 17 15:02:47 2020 -0800 pass about menu items to GUI commit 6c00bb1539f35745ed582d64e44566f8d4ba2d59 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Nov 17 16:13:18 2020 -0800 add telemetry reset instructions to README.md commit 19a47ecde87f7cdfe07d86569cd1f919ffef7e3f Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Nov 17 15:55:30 2020 -0800 split HOC in two: one inside AppStateHOC, one out `ScratchDesktopOuterComponent` is now responsible for `showTelemetryModal` which only works if it comes from outside the `AppStateHOC` since it's used in the `AppStateHOC` constructor. The outer component also handles a few static props, like `isScratchDesktop`. `ScratchDesktopInnerComponent` handles everything else, most notably anything that interacts with the state established by `AppStateHOC`. commit d8f289f35a8c216f37054932b660eb638daf1fb5 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Oct 28 15:54:01 2020 -0700 3.18.1 commit bf420cb7647d849763a862f34efb75512515120c Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Oct 28 15:47:58 2020 -0700 fix fetch script for new library schema commit 9c3cfef44373eb659699f6016abc650718d7d3d0 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Oct 28 14:47:34 2020 -0700 3.18.0 commit 421a21cca1e9cc13f11677803768eaffe15f63ce Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Oct 28 14:47:25 2020 -0700 bump scratch-gui for v3.18.0 commit b053b5ce2ebd8b1f79b23b6b5bd272a1d770fbda Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Fri Oct 16 11:34:36 2020 -0700 3.17.1 commit 24ddb8aa9c8c36fd6caf78d4d17ff96cec9a4c3c Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Fri Oct 16 11:21:45 2020 -0700 bump scratch-gui for v3.17.1 commit 4f5a14afeb6089aa0b468a0f92471270e74dae89 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Fri Oct 9 16:50:57 2020 -0700 3.17.0 commit d455547ef1a7626bc0ac8a26371edca361125d0f Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Fri Oct 9 16:50:23 2020 -0700 update to scratch-gui#scratch-desktop-v3.17.0 includes svg-renderer on* hotfix commit 4fe9e5b703b548cc72d590209001fe71ce2c3001 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Oct 7 18:23:50 2020 -0700 fix lint: long lines commit 10b2bae67084351a58b6699714cdb3d4255dbc9e Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Oct 7 18:17:54 2020 -0700 update privacy policy to October 5, 2020 copy commit 371bd60a7db615962e973813e9b6195a79fee9a5 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Oct 6 14:34:04 2020 -0700 move ReactDOM.render() into index.js This also means we no longer need to disable eslint's "no-unused-expressions" rule for each route in index.js commit 73819d8eb7ed540c1101c5124b3537a092e1fdb3 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Oct 6 14:34:04 2020 -0700 view built-in privacy policy from telemetry dialog commit ca7eeb9b7aebd0e992ea613841ed06368fe97956 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Oct 6 14:34:03 2020 -0700 add privacy policy link to 'about' dialog commit fb26baeac10683d01c4fdae565090839caf932fb Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Oct 6 14:34:03 2020 -0700 app.jsx cleanup commit 3b1dd4e008e822269e49379863fb72582a5bdedc Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Oct 6 14:34:01 2020 -0700 open external links in system browser commit 8fc98e1c37096ddf27e441941fba9a55a7ef11ca Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Oct 6 14:34:01 2020 -0700 add new window for privacy policy commit 93a94d82533863bd5f85c23e4cdc2fa6a319e6f8 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Oct 6 14:34:01 2020 -0700 move About window styling into a CSS file commit 6b1d93fc93fa66147a7e9d00d5ba6befac8c76af Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Sep 30 09:33:31 2020 -0700 3.16.1 commit 34db5ceaacd415d99fb7c5d0f164335f55995ed9 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Sep 30 09:32:51 2020 -0700 during webpack, find modules using require.resolve This means the module will be found whether linked (as with `npm link`) or not. commit d3fddbe31766c9869b68d0b084b38453c0bdae59 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Sep 29 15:38:27 2020 -0700 3.16.0 commit a6ed3adc86b20766fe19c6f4498903105c6b1786 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Sep 29 15:38:18 2020 -0700 update to scratch-gui#scratch-desktop-v3.16.0 commit b05c2c16024b243413214201c65f398e9a41c545 Merge: 0c5993c 0fa4c4b Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Sep 29 13:56:30 2020 -0700 Merge pull request #150 from cwillisf/load-project-from-cli-attempt-2 Support loading project file from command line (attempt 2) commit 0c5993c8416d9bdd436c71b6c7be344ab4ab914f Merge: ac69356 8091648 Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Sep 24 13:04:41 2020 -0700 Merge pull request #137 from cwillisf/redo-rename Revert "Revert "Merge pull request #131 from cwillisf/rename-to-scratch commit 809164880337ed722d5fb84195def89851b765d8 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Sep 17 12:07:08 2020 -0700 use 'Scratch 3' for external product name also tweak artifact names to get the "3" part from the version number commit 7c6e8a97ccbdb8e1df146611ae8e176c28c71810 Merge: 8578d60 ac69356 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Sep 16 16:08:27 2020 -0700 Merge branch 'develop' into redo-rename commit ac6935660a94aa381431ee462dedd13f9d476a1a Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Sep 16 16:04:23 2020 -0700 update README.md for scratch-gui build changes commit 0fa4c4b2ed88e6e3532ecc3914ecb2e1492af8ab Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Sep 15 14:52:08 2020 -0700 handle initial project load errors commit a9933242e0daa417fd9ccb2492b33f83f77d5954 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Sep 15 14:32:36 2020 -0700 use project state system to load initial project commit 05e8b26a34d1a749b174660c6b9afef3cd5c6de6 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Fri Sep 4 13:26:34 2020 -0700 WIP: actually load project from command line Doing it this way works for the initial load but overrides later actions like File -> New. commit e2f39580dfe2c9c961f9d93511ef9b851623edf6 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Sep 3 17:01:22 2020 -0700 make command line args available to render process commit 25243b0542dd6f13c3ae87814f3b988a9206f840 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Sep 3 16:11:01 2020 -0700 npm i --save-dev minimist commit cca18b6d672332034f86805244feee4f47e86c32 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Sep 3 16:55:44 2020 -0700 fix paths for CopyWebpackPlugin These files are no longer listed as dependencies of scratch-desktop so we need to reach into scratch-gui to get them. We should find a better solution but this will work for now. commit e0fb2d4c5364bb225b33e2a842c20520b5ca6b8a Merge: 6d503f2 61fa1d5 Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Sep 3 15:37:04 2020 -0700 Merge pull request #148 from cwillisf/no-package-deps remove rebuild-deps script, package-deps.json commit 61fa1d580b7fceb56b49fd0e64c6b0e11115fe55 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Sep 3 13:04:11 2020 -0700 rebuild package-lock.json now that scratch-gui PR is merged commit 307027a8730edce6e9f188893b13c86e9d9b9450 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Sep 1 12:01:53 2020 -0700 remove rebuild-deps script, package-deps.json These are unnecessary if scratch-gui lists its build dependencies in `dependencies` instead of `devDependencies`. commit 6d503f2d9568a30fd9d98b4a3ad675eb2d45b148 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Aug 27 10:54:01 2020 -0700 3.15.0 commit e872ae7d54ce75c2679d0e3447804049f093f8a0 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Aug 27 10:53:25 2020 -0700 update scratch-* dependencies commit 48d151cce8ba608dfedc96313dcca707f8372464 Merge: a9cfad8 e9e3f06 Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Aug 27 10:41:09 2020 -0700 Merge pull request #143 from cwillisf/fix-mas-file-overwrite fix MAS file overwrite by deleting existing file commit e9e3f06289bbfb98cf6b88499069ff8b337d755d Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Mon Aug 24 20:20:37 2020 -0700 save files more safely (temp then move) commit 75589099f1d632a3771b24fdc4f6201f70f434a1 Author: Christopher Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Fri Aug 21 13:58:35 2020 -0700 fix MAS file overwrite by deleting existing file From the code comments: If the file exists the browser will first download to a temp file then rename to the userChosenPath. The MAS sandbox allows accessing userChosenPath but not the temp file, so overwriting fails on MAS. Deleting the file first could be considered risky but works around the sandbox problem. Security bookmarks might work to fix the problem but they're only supported by async showSaveDialog. Since we need to use showSaveDialogSync (see WARNING below) this workaround might be the best option. commit a9cfad8df8c32a6a9cda4c0afa6716e844f05c11 Merge: 5773d5b 3244272 Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Mon Aug 24 13:33:50 2020 -0700 Merge pull request #138 from cwillisf/webpack-build-gui Use scratch-gui source instead of its build output commit 5773d5b17c4694e50395a445395f0980cc8a9d41 Merge: 1c18c98 c811ade Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Fri Aug 21 07:40:27 2020 -0700 Merge pull request #134 from cwillisf/allow-dev-tools-in-release-builds allow opening dev tools in release builds commit 324427226e962a0d35ee35794eecf425b43d1647 Author: Christopher Willis-Ford Date: Fri Aug 14 13:48:05 2020 -0700 reduce webpack output on CI commit 1c18c98282efd5e9c14ddad8a6419a62145d77b0 Author: Christopher Willis-Ford Date: Fri Aug 14 13:13:26 2020 -0700 3.14.0 commit a26ec04491953ac6c3b5108adebd4e0a73b619c5 Author: Christopher Willis-Ford Date: Fri Aug 14 12:01:56 2020 -0700 print a warning if rebuild-deps changes deps commit ea650178cd1046dc68fb71402134f92b66ac8fc0 Merge: fa53127 d1195c5 Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Thu Aug 13 15:12:37 2020 -0700 Merge pull request #139 from cwillisf/link-dns-override make Scratch Link connections work w/o DNS commit d1195c53323e99ceed49ad17979f1cea7edf9335 Author: Christopher Willis-Ford Date: Wed Aug 12 15:54:13 2020 -0700 make Scratch Link connections work w/o DNS This effectively hardcodes `device-manager.scratch.mit.edu` to `127.0.0.1` within Scratch Desktop. Note that using "host-rules" instead of "host-resolver-rules" doesn't work: it results in ERR_CERT_COMMON_NAME_INVALID because the browser expects Scratch Link's certificate to list "127.0.0.1" as its host name. Using "host-resolver-rules" means that the IP is used for the connection only, and not for certificate validation. See here for more details: https://www.electronjs.org/docs/api/command-line-switches#--host-rulesrules https://www.electronjs.org/docs/api/command-line-switches#--host-resolver-rulesrules commit 0e1c90afeb7c6d1eb4cf0491a447909e46e67f01 Author: Christopher Willis-Ford Date: Tue Aug 11 19:14:39 2020 -0700 write configs to files in dist/ for debugging purposes commit f6a336af20da7f974795da27122b8a607f9f726e Author: Christopher Willis-Ford Date: Tue Aug 11 19:01:58 2020 -0700 update library paths commit f3b8251408d348577f177626a1489ca326361011 Author: Christopher Willis-Ford Date: Tue Aug 11 16:21:14 2020 -0700 build scratch-gui from source instead of using its build output commit 78d75dc3cf24d723732f41c810cb60b7b7dffddf Author: Christopher Willis-Ford Date: Tue Aug 11 16:22:13 2020 -0700 assume direct control of webpack config Instead of overriding rules we don't want by matching the test exactly, we now explicitly delete rules we don't want before adding any of our custom rules. commit b50870a992971491844e2058a62bab9985e1ce7f Author: Christopher Willis-Ford Date: Mon Aug 10 18:50:14 2020 -0700 npm run rebuild-deps commit 6f7f6bb6747b95ba4a94ba6f728af72ab1eba9fc Author: Christopher Willis-Ford Date: Mon Aug 10 18:46:26 2020 -0700 add script to merge scratch-gui deps This is in preparation for having webpack build scratch-gui source instead of consuming its build output. This script merges the dependencies listed in package-deps.json with those listed in scratch-gui's package.json, using the package-deps.json version in case of conflict, then writes the result into the `devDependencies` section of scratch-desktop's package.json. commit fa5312721a3bea94655e08302d8fd123e89a4458 Author: Christopher Willis-Ford Date: Tue Aug 4 11:04:28 2020 -0700 3.13.1 commit c811ade1a29f7fe6d6f6fb2987df69a7328d20b9 Author: Christopher Willis-Ford Date: Thu Jul 30 10:38:43 2020 -0700 allow opening dev tools in release builds commit 5ce37f75109740535bf183f647db88b099e1a890 Merge: 8f4cab5 0817fdd Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Aug 4 10:55:46 2020 -0700 Merge pull request #136 from cwillisf/undo-rename Revert "Merge pull request #131 from cwillisf/rename-to-scratch" commit 8578d603114d37718f7d81fb0061bb7ffe67d202 Author: Christopher Willis-Ford Date: Tue Aug 4 10:43:27 2020 -0700 Revert "Revert "Merge pull request #131 from cwillisf/rename-to-scratch"" This reverts commit 0817fddce1dbae9aefffab17b3bab959bd95890e. commit 0817fddce1dbae9aefffab17b3bab959bd95890e Author: Christopher Willis-Ford Date: Tue Aug 4 10:41:32 2020 -0700 Revert "Merge pull request #131 from cwillisf/rename-to-scratch" This reverts commit 71cc32e5bf6278c0c5e133697de235c3c2a7a97f, reversing changes made to 43daa269df721b64df8a1f8d2b54598a092f3631. commit 8f4cab598e6cc5d54fe1fd9692036d2d7732cc03 Merge: e0dd256 b17f1a6 Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Mon Aug 3 13:35:45 2020 -0700 Merge pull request #130 from LLK/circleci Add automated CircleCI builds commit b17f1a6d8ff0a664fa8cc395ab67e3275b14e186 Author: Christopher Willis-Ford Date: Mon Aug 3 13:18:40 2020 -0700 add comments based on code review feedback commit f49216f1987d97dcdd1a9e5ee6fc9606475ee9d2 Author: Christopher Willis-Ford Date: Fri Jul 31 17:47:36 2020 -0700 work around electron-userland/electron-builder#5016 commit b5b432786a9be1f943fbb96cbd4207cbb4f2d417 Author: Christopher Willis-Ford Date: Fri Jul 31 15:10:10 2020 -0700 replace Code-to-Learn certs with Scratch Foundation certs commit 686ba5bf0ccd23919bfedc3ca9495eeefd66d6bb Author: Christopher Willis-Ford Date: Thu Jul 30 08:40:19 2020 -0700 3.13.0 commit 7053eed00f64e459fc14fc0b3350ac1c110d4902 Merge: 025ad1b e0dd256 Author: Christopher Willis-Ford Date: Wed Jul 29 14:30:47 2020 -0700 Merge branch 'develop' into circleci commit e0dd256c451425eddba3b7c5729a2b90be6412b8 Author: Christopher Willis-Ford Date: Wed Jul 29 14:27:02 2020 -0700 update scratch-gui to #scratch-desktop-v3.13.0 commit 025ad1b7a855a1f660bf3ad5b01405418cf92ea8 Merge: e69d541 71cc32e Author: Christopher Willis-Ford Date: Tue Jul 28 15:30:12 2020 -0700 Merge branch 'develop' into circleci commit 71cc32e5bf6278c0c5e133697de235c3c2a7a97f Merge: 43daa26 9716753 Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Tue Jul 28 15:24:55 2020 -0700 Merge pull request #131 from cwillisf/rename-to-scratch Rename to "Scratch" / "the Scratch app" commit e69d5414c65cacc3fcee88828a030abae0de40b1 Author: Christopher Willis-Ford Date: Mon Jul 27 11:54:03 2020 -0700 prepare CircleCI config for renaming app commit 97167537eb99ec6e10ec710d65a9f67705ac9466 Author: Christopher Willis-Ford Date: Mon Jul 27 11:31:40 2020 -0700 rename 'Scratch Desktop' to 'Scratch' / 'the Scratch app' commit 84f0701f410bb4f2cfbba369fc819c851d65ebd8 Author: Christopher Willis-Ford Date: Thu Jul 23 11:28:59 2020 -0700 override provisioning profile for mas-dev build commit b4ce74b00218c826c0cb13fcfd04d3188ba020eb Author: Christopher Willis-Ford Date: Mon Jul 13 13:14:15 2020 -0700 ZIP mas-dev commit 7c7ddd1e6cd00adb5cfad047dd57072f13af3cfc Author: Christopher Willis-Ford Date: Fri Jul 10 15:53:59 2020 -0700 build mas-dev on CircleCI commit 8868556cba5db8e0265aa402ea4e8454ba3f4da0 Author: Christopher Willis-Ford Date: Fri Jul 10 14:45:27 2020 -0700 win: unset context to fix environment size errors commit a4d8e3de36412446dd0bbb09bdbf7a9cf7e968cd Author: Christopher Willis-Ford Date: Fri Jul 10 14:32:47 2020 -0700 fix Windows executor settings commit 472cad21728d14bcf2307d71a40aeb13505ab744 Author: Christopher Willis-Ford Date: Mon Jun 29 12:23:22 2020 -0700 fix support for non-signed CI builds commit 62e23771dbc896fc940a3fa37ce900372766caf4 Author: Christopher Willis-Ford Date: Fri Jun 26 09:26:48 2020 -0700 win: set WIN_CSC_LINK to filename commit 000bff75ed69f280773aca370883468327dc9456 Author: Christopher Willis-Ford Date: Fri Jun 26 09:16:45 2020 -0700 support notarize with password or keychain commit 61251d111f24dea91e1c085f3b5361bcdb79ba9c Author: Christopher Willis-Ford Date: Fri Jun 26 08:22:27 2020 -0700 tell electron-builder not to publish CI builds commit 104317bff8828d95eeebae69e10264fc10491626 Author: Christopher Willis-Ford Date: Thu Jun 25 16:13:39 2020 -0700 build 'dist' for signed, 'distDev' for unsigned commit ed23e98d24a8878b2b655d83149a6ebc48eac346 Author: Christopher Willis-Ford Date: Thu Jun 25 16:01:48 2020 -0700 import provision profile commit 623050a19d8f961ca6b1febc4ab794be5d4c3926 Author: Christopher Willis-Ford Date: Thu Jun 25 15:58:45 2020 -0700 test early during automated builds commit 0d3f50e790e1ce28bffb90b562b4532c6afc2cbe Author: Christopher Willis-Ford Date: Thu Jun 25 15:30:21 2020 -0700 import code-signing certificates commit 98efe7610fb04b7272abee6a0761ed3532f11aa8 Author: Christopher Willis-Ford Date: Wed Jun 24 15:44:46 2020 -0700 work around electron-userland/electron-builder#4964 commit 9ca7f05bdb98c585e87eb84e2266ef53819cd46c Author: Christopher Willis-Ford Date: Wed Jun 24 15:15:25 2020 -0700 update CircleCI context name commit d08841382a7b79b3ea2ccab552af00a1245c0ffd Author: Christopher Willis-Ford Date: Fri Apr 3 19:02:26 2020 -0700 modularize npm scripts, support non-signed builds, ... commit 8cf475416c10338a5b4553c7f6e71335c6b461f3 Author: Christopher Willis-Ford Date: Fri Apr 3 15:27:25 2020 -0700 work around missing PATH for git-sh-setup on Windows commit 39dbd197d6644348e3068dd310554bea42c77a44 Author: Christopher Willis-Ford Date: Fri Apr 3 14:38:06 2020 -0700 cache the NPM cache, not node_modules The `npm ci` command removes `node_modules` anyway, so there's no point in caching it. commit 245a3ec0d78c1b487cdcba479f1d762e739c47b4 Author: Christopher Willis-Ford Date: Fri Apr 3 14:06:28 2020 -0700 put scratch-gui install into scratch-desktop postinstall commit 2cfca4c0ffacfa0d3a39b7fc646db1335085c709 Author: Christopher Willis-Ford Date: Tue Mar 31 17:28:02 2020 -0700 reference scratch-gui by branch, not tag Let package-lock.json take care of picking an exact commit. commit 1c7148607cb8913b5d6d18e5da481c7e65ee68ab Author: Christopher Willis-Ford Date: Tue Mar 31 16:52:36 2020 -0700 add CircleCI build config for macOS commit ff53e9822a746aa97fa5be56896f2aaf6ce60a44 Author: Christopher Willis-Ford Date: Mon Jan 13 19:11:56 2020 -0800 add CircleCI build config for Windows commit 43daa269df721b64df8a1f8d2b54598a092f3631 Author: Christopher Willis-Ford Date: Fri Jul 24 15:58:14 2020 -0700 fix scratch-gui dependency versions commit 546cc5fd152a4fc1e8e3084f1081d178f4161f4d Merge: f9011a2 9762bac Author: Alex Cui Date: Sat Jun 27 18:37:25 2020 +0800 Merge remote-tracking branch 'llk/develop' commit 9762bac510af91ddc022898174d8182eb24fa495 Author: Christopher Willis-Ford Date: Mon Jun 22 10:46:31 2020 -0700 3.12.0 commit c33abcba8455af0eea6baf7bbcaaadbf078e7a77 Author: DD Liu Date: Tue Jun 9 17:04:00 2020 -0400 Update CONTRIBUTING.md commit ba223fef2d2c867cfb0f4b994e9125870df0ea98 Author: Christopher Willis-Ford Date: Thu Jun 4 00:55:21 2020 -0700 3.11.1 commit bc8ca72434c6f87e0d430b830361c5d11f9deb28 Author: Christopher Willis-Ford Date: Wed Jun 3 17:23:53 2020 -0700 3.11.0 commit 05e6b277930f442d9373a24643ad267890d47807 Author: Christopher Willis-Ford Date: Wed Jun 3 17:22:23 2020 -0700 bump scratch-gui dependency commit c36c5c90f4378a4360096fe6d725605bd656fdb1 Author: Christopher Willis-Ford Date: Wed Jun 3 16:33:49 2020 -0700 use 32-bit Electron for NSIS installer Use 'nsis:ia32' instead of just 'nsis' for the Windows direct-download build. This means we explicitly request a 32-bit build rather than allowing electron-builder to default; the default is currently to make a 64-bit build. resolves #114 commit 6d9ab116bb40e564fcefbb87f1955a2e0ab15179 Merge: 0404f9a 8f23ef1 Author: Chris Willis-Ford <7019101+cwillisf@users.noreply.github.com> Date: Wed Jun 3 16:09:03 2020 -0700 Merge pull request #120 from cwillisf/electron-8 Electron 8 & fix App Store submission commit 8f23ef1f64e49dd26b45dba6c0cc076ad86f9ac2 Author: Christopher Willis-Ford Date: Fri May 22 16:25:59 2020 -0700 3.10.4 commit 7192ffe878a0fb3165446095e3efdf4ce3a33eea Author: Christopher Willis-Ford Date: Fri May 22 16:18:58 2020 -0700 fix MAS build (!!!) apparently the `com.apple.security.app-sandbox` entitlement and the `hardenedRuntime: true` setting are mututally exclusive with `electron-builder`, so the hardened runtime is now only used by non-MAS builds ('mac' but not 'mas' or 'mas-dev') commit 1bc9f570cd1faf1b0a1399d7a478541bafabf512 Author: Christopher Willis-Ford Date: Fri May 22 16:16:56 2020 -0700 allow non-notarized mac build for testing Skipping notarization isn't strictly wrong, but needs a big warning since the build probably won't run on Catalina. commit 73a2d3e015ffce96c5f227c3f735ba4b449656ab Author: Christopher Willis-Ford Date: Fri May 22 16:16:22 2020 -0700 allow reusing render process / fix deprecation warning commit 3cdcb199bd60e13386031b552f5c4b4ca50f0c76 Author: Christopher Willis-Ford Date: Fri May 22 15:19:28 2020 -0700 add settings for mas-dev build commit 229c42469d25693728bd43561ad5152a4029165e Author: Christopher Willis-Ford Date: Wed May 20 17:05:00 2020 -0700 use minilog for logging, like scratch-gui commit 5abc787f1bd9425cd445bd99038fe0e9343131b9 Author: Christopher Willis-Ford Date: Wed May 13 17:19:05 2020 -0700 3.10.3 commit 53f7c5f57700a4b225dce11d306cdc8db7b8c891 Author: Christopher Willis-Ford Date: Wed May 13 17:32:30 2020 -0700 swap MAS and DMG build order commit 89193bc6af0dc7b175b16d6f2e94c4bdadccaffe Author: Christopher Willis-Ford Date: Wed May 13 17:14:14 2020 -0700 add entitlements suggested by Electron Hopefully these will help solve the crash that Mac App Store reviewers are encountering... commit 5a1526c1e5c2ae7d37c450a85f47a01cdce5d443 Author: Christopher Willis-Ford Date: Wed May 13 14:12:10 2020 -0700 update all dependencies, resolve npm audit alerts minor code changes required for uuid, eslint-config-scratch, and uglifyjs-webpack-plugin commit cd805d1cd406677c8d67006bb7ab44025ed052a7 Author: Christopher Willis-Ford Date: Mon May 11 13:14:56 2020 -0700 update to electron@^8.2.5 commit 0404f9ac7ea81cb78c8c528cdf1b975c17970398 Author: Christopher Willis-Ford Date: Tue Apr 28 15:53:23 2020 -0700 3.10.2 commit 8a62c4adf1926664ecf3bb9844bf9338a968d5e7 Author: Christopher Willis-Ford Date: Tue Apr 28 15:33:45 2020 -0700 use scratch-gui#scratch-desktop@v3.10.2 commit 8245ffb1de92bb6a17fdeb1c2436930ca9af6a1c Author: Christopher Willis-Ford Date: Mon Mar 30 18:18:31 2020 -0700 3.10.1 commit 7a813c8779043ab83a5407664828928bb9ecd936 Author: Christopher Willis-Ford Date: Mon Mar 30 12:12:34 2020 -0700 bring back entitlements.mas.inherit.plist This seems to be necessary to work around an issue: https://github.com/electron/electron-osx-sign/issues/192 commit fdd7a8463f0b50fc9195347e985e481ce6729ec6 Author: Christopher Willis-Ford Date: Mon Mar 30 18:09:03 2020 -0700 fix makeFullUrl for file:// on Windows commit 33a17879b229f2f439c6f2440f5cee13556ee4c7 Author: Christopher Willis-Ford Date: Thu Mar 26 18:10:11 2020 -0700 3.10.0 commit dd6f9eb91c77654086640358f131ff0274313edf Author: Christopher Willis-Ford Date: Thu Mar 26 18:10:07 2020 -0700 update scratch-gui to scratch-desktop-v3.10.0 commit a67499c33ea9a38cb26c54d0ed0739882f4eea9e Merge: 8222b71 7ee12dc Author: Chris Willis-Ford Date: Wed Mar 18 11:10:48 2020 -0700 Merge pull request #111 from cwillisf/fix-macos-camera-and-mic macOS: request camera & microphone permissions on demand commit 7ee12dcdd8cc69b419f9ce181252738eed97578d Author: Christopher Willis-Ford Date: Tue Mar 17 18:59:03 2020 -0700 don't `return await` commit 6e1bfc33f3d95da60b57bd95d7e3eb9a5ca8af88 Author: Christopher Willis-Ford Date: Tue Mar 17 16:15:46 2020 -0700 only call systemPreferences.askForMediaAccess if it exists commit 74968704c8ed8bf81f2c650553f0d8a086c61852 Author: Christopher Willis-Ford Date: Thu Mar 12 17:17:56 2020 -0700 improve user experience around mic/camera permission - ask for permission when trying to use a feature, not on startup - if permission is denied, explain the consequence and provide a hint for fixing it commit b26c0b6bd3c6d1d87bc13b65e3022854bffb5c21 Author: Christopher Willis-Ford Date: Thu Mar 12 14:23:35 2020 -0700 fix npm run dist:dir commit af73790306711ddc489a8fdb5be8419eecaa3970 Author: Christopher Willis-Ford Date: Mon Mar 9 15:45:07 2020 -0700 macOS: request camera and microphone access Note `audio-input` and `camera` were already in `entitlements.plist` Supporting changes: - Add `allow-jit` entitlement since documentation says it's needed. - Only use sandbox for MAS build, not for non-MAS macOS build. NOTE: both still use the hardened runtime, as required on Catalina. - Remove `entitlements.inherit.plist` since it matches default settings. - Add to `electron-builder.yaml` English descriptions for why the app requests access to the microphone and camera. I'm not yet sure if there's a way to localize these. - Minor tweaks in `electron-builder.yaml`. commit 8222b715a7d177ae4a2744e0e54cc36d96c38a2b Author: Christopher Willis-Ford Date: Tue Mar 17 18:54:56 2020 -0700 fix lint from TitledHOC changes commit b72aab359bdd53fab68685d6c93109f81cb05d3c Author: Christopher Willis-Ford Date: Fri Feb 28 12:00:02 2020 -0800 3.9.0 commit 85ce509434b13c49e9c06d4bf8c86b00178dfe7a Merge: 9981328 d1c47e8 Author: Chris Willis-Ford Date: Wed Feb 5 12:57:18 2020 -0800 Merge pull request #98 from cwillisf/dark-dev-dont-hang work around startup hang in dev on Win10 dark mode commit 998132876e5d9350b8b283a9bd6f091395795ca6 Merge: 88b1da1 af029b6 Author: Chris Willis-Ford Date: Wed Feb 5 09:08:45 2020 -0800 Merge pull request #101 from cwillisf/fix-telemetry-modal Fix telemetry modal commit af029b69376b2fe296af440362c6ada68e043c99 Author: Christopher Willis-Ford Date: Mon Jan 27 16:01:08 2020 -0800 fix telemetry modal commit d1c47e8bd0ee12d5ad88933059a0e1cd9af9fabb Author: Christopher Willis-Ford Date: Mon Jan 27 13:42:07 2020 -0800 work around startup hang in dev on Win10 dark mode Also, add a few improvements to the way DevTools extensions get installed. commit 88b1da15339d2930e5fc2f5a11c8a56dd0f1ae8d Merge: 5f5f24e 5c2303a Author: Chris Willis-Ford Date: Fri Jan 24 11:19:28 2020 -0800 Merge pull request #96 from cwillisf/notarize-mac-build Notarize macOS build commit 5f5f24e722bb1152557e9018d7a6aa8839f4934f Author: Christopher Willis-Ford Date: Thu Jan 16 18:05:41 2020 -0800 fix unwanted menu bar on Windows commit 0b6652cde395b0c64d3268967650a75fcf1f90ef Author: Christopher Willis-Ford Date: Thu Jan 16 15:55:04 2020 -0800 fix save & quit dialogs for Electron 6 API changes commit 5c2303a9b5c6b87d08f32e83c80a08e2ad9c30d7 Author: Christopher Willis-Ford Date: Tue Jan 14 14:10:22 2020 -0800 bubble errors out from electron-builder-wrapper commit ccaca91bea65e0e75fc7c609487d9eb027c8edfc Author: Christopher Willis-Ford Date: Thu Jan 16 12:35:37 2020 -0800 fix code signing step for non-Store macOS build commit 9c9d7c6979445d38728dc8260cad5b66f8987b4a Author: Christopher Willis-Ford Date: Thu Jan 16 11:47:25 2020 -0800 notarize non-MAS macOS build (required for 10.15) commit 6a33d411c13fbbb2ac2705dce50188a76d3404bf Author: Christopher Willis-Ford Date: Thu Jan 16 08:41:54 2020 -0800 enable hardened runtime for macOS builds commit 9b224115a53c2a946a0edc3707c8b4b06e72ff6b Author: Christopher Willis-Ford Date: Thu Jan 16 08:16:23 2020 -0800 fix infinite load screen introduced with Electron 6 changes commit 99040d1771c7bfd9f413de7d0371a8f7e547ac92 Merge: 0752628 6aa3e01 Author: Chris Willis-Ford Date: Wed Jan 15 15:38:07 2020 -0800 Merge pull request #95 from cwillisf/fix-mas-electron-6 Fix mas electron 6 commit 6aa3e013ec2b13fe6f6b13030f8fa9cae20ec789 Author: Christopher Willis-Ford Date: Wed Jan 15 15:15:22 2020 -0800 fix MAS build: add inherited entitlements commit 434781e89b643e08b0a992f847ca32d6dff1ab33 Author: Christopher Willis-Ford Date: Wed Jan 15 15:00:10 2020 -0800 fix MAS build: update to electron-builder@^22 We switched to Electron 6 for the MAS private API patch, but electron-builder 20.x doesn't correctly support building Electron 6 for MAS. A fix was introduced in version 22.0.0 of electron-builder. See also: electron-userland/electron-builder/pull/4154 commit 075262823bc96c8762ec7f1513c337f34920012b Author: Christopher Willis-Ford Date: Wed Jan 15 14:10:02 2020 -0800 3.8.0 commit c6bdd4345545ec9f47babcf7a903d0e6671f33e1 Author: Christopher Willis-Ford Date: Wed Jan 15 11:33:31 2020 -0800 3.8.0-rc.1 commit 1f9001b158e7d54838b97f5ece5db3b4765b8b96 Merge: 0c23c38 4f28d86 Author: Chris Willis-Ford Date: Wed Jan 15 11:28:25 2020 -0800 Merge pull request #94 from cwillisf/electron-6 upgrade to electron@^6.1.7 with MAS patch commit 4f28d86e7067f87c91d600d46fe1a75807efb88c Author: Christopher Willis-Ford Date: Mon Dec 16 12:59:40 2019 -0500 upgrade to electron@^6.1.7 with MAS patch This version of Electron includes a patch which: - removes the use of some private APIs which were causing Electron apps to be rejected by the Mac App Store, but - might cause degraded performance on Mac. commit 0c23c3899ea7cd6d282131069cd9024249026596 Merge: d3b269e aa46450 Author: Chris Willis-Ford Date: Wed Jan 15 10:50:43 2020 -0800 Merge pull request #84 from LLK/dependabot/npm_and_yarn/react-dom-16.2.1 Bump react-dom from 16.2.0 to 16.2.1 commit d3b269e4b2bb8c2e93c0c055efa9a33a2c3b887c Merge: 56f8a27 aa3c1ab Author: Chris Willis-Ford Date: Wed Jan 15 10:46:24 2020 -0800 Merge pull request #93 from LLK/paulkaplan-patch-2 Support 3.0 library syntax when fetching assets commit 56f8a2784884e28d3ad2837b30e14983b591a22c Merge: 96953c4 f11e1c4 Author: Chris Willis-Ford Date: Wed Jan 15 10:44:11 2020 -0800 Merge pull request #83 from LLK/paulkaplan-patch-1 Use dist path for library JSON files of GUI commit aa3c1abbc0c246eaced424a5714db456e16c0276 Author: Paul Kaplan Date: Tue Jan 14 11:28:27 2020 -0500 Support 3.0 library syntax when fetching assets Fixes https://github.com/LLK/scratch-desktop/issues/92 commit 96953c4acd7aa281ed9cb1bc88de978ed553a710 Author: Christopher Willis-Ford Date: Tue Nov 26 13:46:27 2019 -0800 3.7.0 commit ba6e15a6246797235eb3f3a3437cb576ca21119b Author: Christopher Willis-Ford Date: Mon Nov 25 18:33:35 2019 -0800 3.7.0-rc.1 commit e32fae831f43f2d8ffc6937a8bdf7af0e25c4c0d Author: Christopher Willis-Ford Date: Mon Nov 25 18:32:46 2019 -0800 let npm update package-lock.json ...in the hopes that npm will finally stop trying to change it. commit 19196c39d483319a0a887ebbe33da9cfd93fab35 Merge: 33993cb 43f7cd5 Author: Benjamin Wheeler Date: Mon Nov 18 14:49:46 2019 -0500 Merge pull request #74 from benjiwheeler/manage-title DesktopHOC manages project title, rather than wrapping with TitledHOC commit 33993cb61d3ea91d82e57e6b924b8282a9c6313b Author: Christopher Willis-Ford Date: Wed Nov 13 12:04:23 2019 -0800 add GitHub templates commit aa46450e740ab14f072cc29d59f2f80fb68be537 Author: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri Nov 1 23:03:52 2019 +0000 Bump react-dom from 16.2.0 to 16.2.1 Bumps [react-dom](https://github.com/facebook/react/tree/HEAD/packages/react-dom) from 16.2.0 to 16.2.1. - [Release notes](https://github.com/facebook/react/releases) - [Changelog](https://github.com/facebook/react/blob/master/CHANGELOG.md) - [Commits](https://github.com/facebook/react/commits/HEAD/packages/react-dom) Signed-off-by: dependabot[bot] commit f11e1c4279793d639f24782b200a6e92a7442f4c Author: Paul Kaplan Date: Fri Nov 1 11:12:17 2019 -0400 Use dist path for library JSON files of GUI In conjunction with https://github.com/LLK/scratch-gui/pull/5277, since we removed /src from the published gui files commit 43f7cd5028d48f9c01a43b947b68305cfe5c15d9 Author: Ben Wheeler Date: Mon Oct 28 21:56:37 2019 -0400 add canEditTitle and projectTitle props commit f9e77bc508f9274d146486c799f10ca64894c765 Author: Ben Wheeler Date: Sat Sep 14 23:13:18 2019 -0400 ScratchDesktopHOC manages project title, rather than wrapping with TitledHOC commit de6a271311649275dde9571f72dfe6c6a4cd9b45 Merge: 0bf03a2 c327bc3 Author: Chris Willis-Ford Date: Thu Sep 26 09:55:41 2019 -0700 Merge pull request #76 from cwillisf/skip-signing-appx Skip signing appx commit 0bf03a21999a0faca99dda52dae404b78bb7b8c5 Merge: 9ec118e 1df51fa Author: Chris Willis-Ford Date: Mon Sep 16 12:57:57 2019 -0700 Merge pull request #77 from cwillisf/better-project-save-detection Better project save detection commit 1df51faa95d614745f5a0afb45edc55d338e15ce Author: Christopher Willis-Ford Date: Mon Sep 16 11:23:11 2019 -0700 detect project save based on content type Also, if saving a file is canceled, only try to cancel project save telemetry if the save was a project save. Also also, don't skip showing the save dialog just because a file doesn't have an extension. Instead, just skip trying to determine filters for the extension in this case. commit c327bc3de43001c68b197536300589aef081cb91 Author: Christopher Willis-Ford Date: Mon Sep 16 09:24:21 2019 -0700 Add comments to electron-builder-wrapper.js commit 9ef9d8fce38fa430d0fd9a3ca03e940419b26645 Author: apple502j <33279053+apple502j@users.noreply.github.com> Date: Fri Sep 13 22:29:21 2019 +0900 Check extension before setting title commit d077e79a8a300b23e4074c66af7d9af14f554444 Author: Christopher Willis-Ford Date: Wed Sep 11 18:46:28 2019 -0700 skip code signing for AppX builds commit 9ec118ea483cad0a1e2c811813e3e947e95d5fcb Author: Christopher Willis-Ford Date: Tue Sep 10 12:46:29 2019 -0700 3.6.0 commit a013abd92591980cc48ea4eba5730b912343dd04 Author: Christopher Willis-Ford Date: Thu Sep 5 13:10:17 2019 -0700 3.6.0-rc.2 commit e80b6a27a5a6a56ebbe10d10e2ddce62afb2d9ef Author: Christopher Willis-Ford Date: Thu Aug 29 12:38:48 2019 -0700 3.6.0-rc.1 commit d121556de087ba4e06b2437f9702b87d9f281612 Author: Christopher Willis-Ford Date: Thu Aug 29 12:18:10 2019 -0700 update dependencies commit 5c1e85044d096f589a385bb9a47099d74eabd772 Author: Christopher Willis-Ford Date: Wed Aug 28 12:26:10 2019 -0700 3.5.2 commit 76dc35cf52e7444b24ee197b9ef7b2e8923099dc Merge: 740872d d960057 Author: Chris Willis-Ford Date: Tue Aug 6 12:43:45 2019 -0700 Merge pull request #67 from cwillisf/telemetry-platform telemetry: add 'platform' and improve 'version' commit d9600572608ca1fbb1273d5c4e32cc3ef58a73c1 Author: Christopher Willis-Ford Date: Mon Aug 5 15:43:22 2019 -0700 telemetry: add 'platform' and improve 'version' commit 740872d14aa58111a327be40a8bc6d9ab529dc94 Author: Christopher Willis-Ford Date: Mon Aug 5 15:19:48 2019 -0700 fix lint problems commit ddd1156deaf9b03061e9893064d822ac89e86367 Author: Christopher Willis-Ford Date: Mon Aug 5 15:14:13 2019 -0700 update dependencies to fix eslint exception commit 232f2f4310da949d9b8e33d7c5f3d71309d547b3 Author: Christopher Willis-Ford Date: Mon Aug 5 14:57:29 2019 -0700 fix "about" window in dev mode commit 8b2cdb0086a4ba1d8da471f1d2fb52acb04e3b61 Author: Christopher Willis-Ford Date: Wed Jul 31 13:25:05 2019 -0700 3.5.1 commit 6e8c842e4e61c0ac34724a700c2746730a82d9d2 Author: Christopher Willis-Ford Date: Tue Jul 30 16:43:00 2019 -0700 fix provisioning profile for new app store submissions commit 53f20c3d61731a4c014502df0126bf59277ba446 Author: Christopher Willis-Ford Date: Mon Jul 29 15:22:49 2019 -0700 add "quick start" instructions for scratch-gui commit 1b8d9796c92eb1b007b3a7c121a13501383e98b5 Author: Christopher Willis-Ford Date: Mon Jul 29 12:28:05 2019 -0700 3.5.0 commit 43e49463658f160343692d9aa1374edce3a263cb Author: Christopher Willis-Ford Date: Sun Jul 28 18:41:43 2019 -0700 3.5.0-rc.2 commit 53812d79c7201472bd4e42f3cc81d4f73890a89b Author: Christopher Willis-Ford Date: Sun Jul 28 18:40:58 2019 -0700 fix "about" window in packaged context commit 8dcbbfe5c9a27eef846f6c32c6d261b4bfa86a03 Merge: 7121d09 9746fc1 Author: Chris Willis-Ford Date: Sun Jul 28 17:38:04 2019 -0700 Merge pull request #66 from cwillisf/about-window About window commit 9746fc1dee1c209fdf9381ae6e13eba1d445d2a1 Author: Christopher Willis-Ford Date: Sun Jul 28 17:32:14 2019 -0700 add content to "about" window commit 3cba6fea38a3b42300e242ae6dc6a0cb8f8c9d0d Author: Christopher Willis-Ford Date: Sun Jul 28 15:23:38 2019 -0700 add support for an "about" window commit 7121d0980fce49cbb5e77d8b949493a6730c505d Author: Christopher Willis-Ford Date: Sat Jul 27 14:55:06 2019 -0700 3.5.0-rc.1 commit b452eba14264089f955b048c7a86b6b56cec3649 Merge: 1de581d 68bb1f4 Author: Chris Willis-Ford Date: Fri Jul 26 23:47:00 2019 -0700 Merge pull request #60 from cwillisf/show-loading-screen-sooner Show main window ASAP, even if it's just a loading screen commit 68bb1f4acc7d0f414427d59f5226b7c2a3799d2b Author: Christopher Willis-Ford Date: Thu Jul 25 18:46:31 2019 -0700 apply Scratch 3.0 color and font styles to loading screen commit 1de581d01d7148f8dc89ea65d17298523692edc0 Author: Christopher Willis-Ford Date: Thu Jul 25 10:55:25 2019 -0700 allow per-machine/per-user choice in Windows installer commit 79fd12f2964663f9806c55d9e099424940fcc5bc Merge: 414a1f0 00175f5 Author: Chris Willis-Ford Date: Wed Jul 24 11:56:17 2019 -0700 Merge pull request #64 from cwillisf/fix-telemetry-more More telemetry fixes (plus project title editing) commit 00175f521d9624bf88ab16be8a1d2acfda3ad129 Author: Christopher Willis-Ford Date: Wed Jul 17 17:16:18 2019 -0700 set project title from save file name commit f57320e718af026b2a55e12756c608ed057bc65d Author: Christopher Willis-Ford Date: Thu Jul 11 16:15:01 2019 -0700 Show splash screen ASAP, load render JS async commit 5b028a1d3d91f8037de02a776efb913fca3619ce Author: Christopher Willis-Ford Date: Wed Jul 17 13:28:22 2019 -0700 correctly format code metadata in telemetry events commit 414a1f0cfde418855ed70d47d7dcb94168fbf818 Author: Christopher Willis-Ford Date: Wed Jul 17 16:56:56 2019 -0700 move index.js to app.jsx and add new index.js shim Note that the code inside app.jsx is exactly what used to be in index.js so this change causes no functional difference and just represents preparation for upcoming changes. It simplifies at least two upcoming changes: one wants the app code to be in a different file and the other is simplified by JSX syntax. commit ee55d2b16f9ecc72fbf1610bdfadad42981e2e26 Author: Christopher Willis-Ford Date: Thu Jul 11 16:16:12 2019 -0700 Fix line endings for electron-webpack.json5 commit d34f94b55d7b58e725a0e3ae51f84ab9fa94ef15 Merge: bfb4710 02b06b2 Author: Chris Willis-Ford Date: Wed Jul 10 08:51:43 2019 -0700 Merge pull request #58 from cwillisf/fix-telemetry-init fix telemetry init and enforce queue length limit commit bfb47102127b65a2d86f9c61ef601d78d96ddac2 Author: Christopher Willis-Ford Date: Tue Jul 9 16:31:44 2019 -0700 Update dependencies including Electron 4.2.0 -> 4.2.6 commit 02b06b29a4541795b02922bdbfec95c7d29baef0 Author: Christopher Willis-Ford Date: Tue Jul 9 13:59:39 2019 -0700 fix telemetry init and enforce queue length limit commit f3346944a6d62d7dc15f899c2355d94d54367dc7 Author: Christopher Willis-Ford Date: Tue Jul 9 11:29:17 2019 -0700 add 'npm run watch-gui', similar to build-gui commit 723e70104e45fafd512a5b46ac666d03a91c32b9 Author: Christopher Willis-Ford Date: Tue Jun 25 13:27:45 2019 -0700 3.4.0 commit cdfdbbfba401067f0af49fd7daf125764c877c9e Author: Christopher Willis-Ford Date: Mon Jun 24 14:28:46 2019 -0700 3.4.0-rc.3 commit 91e16c2ab5340375a7fa22a632214736a50f9c25 Author: Christopher Willis-Ford Date: Mon Jun 24 14:26:53 2019 -0700 fix scripts/fetchMediaLibraryAssets.js missing some sprite assets Assets which are referenced by a sprite but not referenced by the sound, costume, or backdrop libraries were being missed by previous versions. I also removed the default parameter to several methods in order to reduce the likelihood of similar mistakes in the future. commit 7b13482bc660e593c3611d1c6a48a8bd257b1123 Author: Christopher Willis-Ford Date: Mon Jun 24 12:41:25 2019 -0700 improve scripts/build-gui.js error reporting, compatibility commit 25597be1f8654f2a46f320ef4b07919b1fe44769 Author: Christopher Willis-Ford Date: Mon Jun 24 11:45:54 2019 -0700 3.4.0-rc.2 commit d79811d8423a4b13b5ef443cd896d8fa8d87ce7d Author: Christopher Willis-Ford Date: Mon Jun 24 11:35:12 2019 -0700 make build-gui script work on all platforms commit 48964e616e5955dafc8af9671af92cba967bd9c6 Author: Christopher Willis-Ford Date: Sun Jun 9 22:28:37 2019 -0700 3.4.0-rc.1 commit a8cbb4859960196d20a8b6d0937f49803ca867cc Author: Christopher Willis-Ford Date: Wed May 22 18:51:23 2019 -0700 3.3.0 commit 59288c1660cda7a49b1415a7885859ca657a00e8 Author: Christopher Willis-Ford Date: Thu May 16 20:23:47 2019 -0700 3.3.0-rc.2 commit d37de9555db675faf67fdfb014a66cde57e1016b Author: Christopher Willis-Ford Date: Thu May 16 20:23:30 2019 -0700 Document scratch-gui STATIC_PATH build parameter commit e3899019977068cbfa004c2472342136290d8223 Author: Christopher Willis-Ford Date: Thu May 16 12:52:19 2019 -0700 3.3.0-rc.1 commit b597ce1cd68c27b1699f0a9c1ac9b7c53f3c0dad Author: Christopher Willis-Ford Date: Mon May 13 17:24:50 2019 -0700 update dependencies commit b315581b7daeb984085eb9a049417d410a7d6dc5 Merge: 4bd7204 b5d01b8 Author: Chris Willis-Ford Date: Wed Apr 10 11:34:33 2019 -0700 Merge pull request #42 from dlech/patch-1 README: use jsonc code formatting commit b5d01b875bfd3146d1bd46b7bcfb501e96604b8a Author: David Lechner Date: Tue Apr 9 15:22:50 2019 -0500 README: use jsonc code formatting jsonc allows comments, so it will make the ugly red highlighting go away when the README is viewed on GitHub. commit 4bd7204c6350b59fb8cb9bfdc7aba23d1163a618 Author: Andrew Sliwinski Date: Wed Mar 6 12:59:58 2019 -0500 Update package.json commit b5d2a87bace994fad6b32b32fb57f379ae5626e5 Author: Andrew Sliwinski Date: Wed Mar 6 12:59:41 2019 -0500 Update TRADEMARK commit f44872434fb7e80c3e87b8a4d4d375c96b08d3c6 Author: Andrew Sliwinski Date: Wed Mar 6 12:59:20 2019 -0500 Update LICENSE commit 96cd6d5490fbb281dfac0ba81786cda4563fc202 Author: Christopher Willis-Ford Date: Tue Jan 8 11:32:20 2019 -0800 1.2.1 commit 94822649f845379ae7e2cb2b1b26076a53d77efa Merge: 521c32d d93cd7a Author: Chris Willis-Ford Date: Thu Jan 10 20:27:28 2019 -0800 Merge pull request #27 from cwillisf/native-save-dialog Override browser save dialog with a native save dialog commit d93cd7ae33935a3e1e6d88f1e13cf3d4011fe736 Author: Christopher Willis-Ford Date: Tue Jan 8 15:37:37 2019 -0800 Remember last save location commit 1113ba0c18182943252c83a80f3a7d32edb9ee0b Author: Christopher Willis-Ford Date: Tue Jan 8 11:23:55 2019 -0800 Support more file types in save dialog override commit c0b8752fdc3167c447115dabd28c737e674e4e9f Author: Christopher Willis-Ford Date: Mon Jan 7 15:17:28 2019 -0800 Override 'will-download' event to use native save window commit 521c32dd5df0dc94a5be4fe1b6dd48efdbd9b134 Author: Christopher Willis-Ford Date: Tue Jan 8 14:02:19 2019 -0800 npm upgrade commit 05bc41389f5306c8d3ee090b8db4e8799b11e855 Author: Christopher Willis-Ford Date: Tue Jan 8 14:35:50 2019 -0800 Autodetect electron version for @babel/preset-env commit 530857a99ba85b4ab69f0eda3cf727abf884d47e Author: Christopher Willis-Ford Date: Fri Dec 28 12:17:56 2018 -0800 Document the NSIS signed installer build process commit bd76e5464323c48e9803831d8dc8d46654dab4f5 Author: Christopher Willis-Ford Date: Fri Dec 28 04:47:06 2018 -0800 1.2.0 commit eea135e52beade4bbdc17c946c6689f2e63439cb Author: Christopher Willis-Ford Date: Fri Dec 28 00:21:12 2018 -0800 npm upgrade commit f9764d8fc6cc0e15dec6428d3455b8436fde9fc6 Author: Christopher Willis-Ford Date: Thu Dec 27 15:29:57 2018 -0800 Further simplify and consolidate webpack config commit ba91c89d6251e3e0af70368ab444a2b9a10c7e23 Author: Christopher Willis-Ford Date: Thu Dec 27 12:18:04 2018 -0800 Add dev instructions to README.md commit a7519d167de51c79650ea3cb018c3c5656c60370 Merge: 80ed0db 87d9a5e Author: Paul Kaplan Date: Thu Dec 27 15:01:38 2018 -0500 Merge pull request #20 from LLK/fix-mac-shortcuts Include menu with default keyboard shortcuts to allow mac to work commit 80ed0db606e37b957043de0eaddd4fd80557190e Merge: 9560798 9c7acee Author: Chris Willis-Ford Date: Thu Dec 27 11:20:23 2018 -0800 Merge pull request #19 from benjiwheeler/external-windows attempt to open _blank link targets in OS's default browser, not electron commit 9560798c8d5b5501a9acd79cf6c3ef840ac9ec4b Author: Christopher Willis-Ford Date: Thu Dec 27 11:05:04 2018 -0800 Specify scratch-desktop branch of scratch-gui This should go back to a version number once we merge the GUI's scratch-desktop branch into its develop branch. commit 87d9a5e4488285a2493b66f50342c3fb782d7396 Author: Paul Kaplan Date: Thu Dec 27 13:49:26 2018 -0500 Include menu with default keyboard shortcuts to allow mac to work commit 9c7aceea70037eb4861d6b96197ded57cbd4e4a4 Author: Ben Wheeler Date: Fri Dec 21 11:58:18 2018 -0500 attempt to open _blank link targets in OS's default browser, not electron commit a866327656d892074ced093d17f66df18cea833e Author: Christopher Willis-Ford Date: Fri Dec 21 12:50:07 2018 -0800 1.1.1 commit 4c838c01be3fccf3bc327b74da930de9ab9e270b Author: Christopher Willis-Ford Date: Fri Dec 21 12:38:09 2018 -0800 Revert "Add last-resort hook to stop link navigation" This reverts commit c8f6b38df2e125f5cd0b65f4e0340a948bec178c. It caused the menus (like File -> Save) not to work. commit 897a9d26bc53a42b5a3fcce334aeb44937bb46e5 Merge: be95f54 4848d75 Author: Chris Willis-Ford Date: Fri Dec 21 12:01:27 2018 -0800 Merge pull request #18 from cwillisf/telemetry Implement telemetry client commit 4848d7548a0c5bc5a42502679d28a437646ead9f Author: Christopher Willis-Ford Date: Fri Dec 21 10:34:06 2018 -0800 Add version field to telemetry events commit 22dd1821f4e2cbbfea840d6e206e1a4964f9edce Author: Christopher Willis-Ford Date: Fri Dec 21 02:42:08 2018 -0800 Supply defaults for telemetry event fields commit 34d96bf49cac8dad894678e66d5f8c987a6d70b3 Author: Christopher Willis-Ford Date: Fri Dec 21 01:44:58 2018 -0800 Add onProjectTelemetryEvent handler for GUI commit 77b8a13d6439ce5415b58c8c8da528255d918ff4 Author: Christopher Willis-Ford Date: Thu Dec 20 23:48:52 2018 -0800 Populate telemetry events commit 6486201bf931e398bf621de3da6068e9917d5c94 Author: Christopher Willis-Ford Date: Thu Dec 20 23:24:57 2018 -0800 Improve appWillClose() reliability commit 64da5dff27226414f7d13f6f350259f0ed99b5dd Author: Christopher Willis-Ford Date: Thu Dec 20 23:03:20 2018 -0800 Hook up telemetry opt-in/out modal commit 30cafbf50874f02947b437f56b4d0dedab7575e9 Author: Christopher Willis-Ford Date: Thu Dec 20 22:11:54 2018 -0800 Enable telemetry persistence commit f46fd1d7e37febb924bd94b89a1034596e6835d6 Author: Christopher Willis-Ford Date: Thu Dec 20 19:30:06 2018 -0800 npm install -D electron-store commit 64c2755c707d6811d3592fdf2391df050da44bd7 Author: Christopher Willis-Ford Date: Tue Dec 4 18:30:16 2018 -0800 First draft telemetry client To do: queue and client ID persistence commit 66a664b243ab1fa8d2755851ede6e7347259f7b7 Author: Christopher Willis-Ford Date: Mon Dec 3 15:43:11 2018 -0800 npm install -D nets uuid commit be95f54ffe241ed9c582001f39a9409efa3d489c Author: Christopher Willis-Ford Date: Fri Dec 21 11:27:35 2018 -0800 Tweak webpack config for consistency, avoid OOM crash commit 5517f9a184847df9997ccc0b275b69ccacf3d1f3 Author: Christopher Willis-Ford Date: Fri Dec 21 03:21:28 2018 -0800 Set isScratchDesktop commit c238d121ea226a7ce99311bcf5da6354eac7b703 Merge: 505d7cc 0f9a52f Author: Chris Willis-Ford Date: Mon Dec 17 11:34:47 2018 -0800 Merge pull request #16 from cwillisf/store-prep Store prep commit 0f9a52f34dc4cb59b6c1e8db2307a1dd6562049c Author: Christopher Willis-Ford Date: Fri Dec 14 15:05:43 2018 -0800 1.0.3 commit c8f6b38df2e125f5cd0b65f4e0340a948bec178c Author: Christopher Willis-Ford Date: Fri Dec 14 14:27:10 2018 -0800 Add last-resort hook to stop link navigation Links which cause the browser to navigate to another page should be removed or disabled in Scratch Desktop to prevent Electron from navigating away from the editor. If we miss disabling or removing such a link, this last-resort hook will disable navigation after the user clicks a link. commit 6bf5d4a41abdcc96162b3fa3c8310b96285d1feb Author: Christopher Willis-Ford Date: Fri Dec 14 13:03:48 2018 -0800 Improve main window behavior and code readability - Closing behavior on Mac is now consistent with other platforms - The main window is not shown until ready - Minor code reorg to separate concerns and improve readability commit 1145c44915113c2432b2c5195dfd4d69d6b10eec Author: Christopher Willis-Ford Date: Fri Dec 14 11:01:22 2018 -0800 1.0.2 commit efaa2d957d72070a61a30d8babae01215b332eae Author: Christopher Willis-Ford Date: Fri Dec 14 09:53:42 2018 -0800 Don't apply entitlements to the Mac DevID build commit f90534e09c905824fe69a30e647a94112b1ad9cc Author: Christopher Willis-Ford Date: Fri Dec 14 00:44:45 2018 -0800 1.0.1 commit 34cc1b58323584e191790638c32d102f70dbeb8c Author: Christopher Willis-Ford Date: Thu Dec 13 21:17:02 2018 -0800 MAS: fix embedded provisioning profile commit fe9c6e17cbdfeaa1c540f0ea9111b0c5bf644624 Author: Christopher Willis-Ford Date: Thu Dec 13 19:50:36 2018 -0800 Add screenshot commit 40d0812a0c8efaa3bc1800e9a2af8773b727f409 Author: Christopher Willis-Ford Date: Thu Dec 13 19:18:50 2018 -0800 Fix AppX publisher info commit ce1844ad0a9c19ee4c8def00a25660f8602eed17 Author: Christopher Willis-Ford Date: Thu Dec 13 18:20:39 2018 -0800 Fix Microsoft Store logo size commit b083252b50433cab07430b573c7ad3561262201f Author: Christopher Willis-Ford Date: Thu Dec 13 18:13:04 2018 -0800 Fix order of asset fetch & webpack build commit 54110ad6eb38245932a0c3d41aad8cd1578b1964 Author: Christopher Willis-Ford Date: Thu Dec 13 18:12:33 2018 -0800 Corrected location of AppX logos commit 28474afddbf76d147898533f8a45c761ca2ebea7 Author: Christopher Willis-Ford Date: Thu Dec 13 17:50:29 2018 -0800 Fix wide AppX icon commit faf75a8cfc7b96d6a4416cb6a4db95b365173476 Author: Christopher Willis-Ford Date: Thu Dec 13 17:39:52 2018 -0800 Fix AppX app identity commit 7b55741ead181c50d2d264264f327a15f2084e85 Author: Christopher Willis-Ford Date: Thu Dec 13 17:36:49 2018 -0800 Add AppX icons commit 6537e1f931116ee415d119412694f00c8dc7d0c6 Author: Christopher Willis-Ford Date: Thu Dec 13 02:05:00 2018 -0800 Configure store and non-store builds for Mac & Win commit 356b4475b672d7ab69103fa0624b00f4bbd01609 Author: Christopher Willis-Ford Date: Thu Dec 13 10:32:09 2018 -0800 Add icon commit 2068dc50bba1e4890472cad7057fe0ec1ad05e1e Author: Christopher Willis-Ford Date: Thu Dec 13 02:03:59 2018 -0800 Update package name and version commit 505d7cc7e7860d5c61e45d135aa3add08c5681db Merge: c9bcd14 64a06d5 Author: Chris Willis-Ford Date: Thu Dec 13 10:38:21 2018 -0800 Merge pull request #11 from cwillisf/fix-quit-confirmation Fix quit confirmation commit 64a06d5b8f1259facb42c0b1349811b8e0389a80 Author: Christopher Willis-Ford Date: Wed Dec 12 17:10:41 2018 -0800 Obey scratch-gui's onbeforeunload result The `scratch-gui` project saver uses `onbeforeunload` to request confirmation before navigating away from an unsaved project. Unfortunately Electron suppresses the confirmation dialog that browsers would normally display. Instead, Electron offers a `will-prevent-unload` event in the main process: this event fires when `onbeforeunload` requests a confirmation dialog. This change adds a handler for `will-prevent-unload` which displays a quit confirmation dialog so that the overall behavior is similar to what happens in a regular browser. commit fcf629ba1cc40137dd4c16fd76330ce210ea9033 Author: Christopher Willis-Ford Date: Wed Dec 12 17:07:04 2018 -0800 Let scratch-gui handle 'onbeforeunload' commit c9bcd14015ed15f14d666ddc986998941248259d Author: Christopher Willis-Ford Date: Wed Dec 12 09:05:19 2018 -0800 Add source-map-loader commit 69f48aefb826c5f88e6370433f0e427ba7776a1c Author: Christopher Willis-Ford Date: Tue Dec 4 23:00:21 2018 -0800 npm upgrade commit d2d670436064d61c5784d31c277e1f50ce2883bf Author: Christopher Willis-Ford Date: Mon Dec 3 15:39:39 2018 -0800 Let npm reformat package-lock.json Recent versions of `npm` record sub-dependency version ranges differently, though the actual modules installed have not changed. I'm separating this into its own commit so it doesn't make other changes harder to see. commit 046c6188f917afa85441ccc8d09788dbce1e7333 Author: Christopher Willis-Ford Date: Thu Nov 8 15:05:19 2018 -0800 Don't import scratch-gui internals commit 4767897f4bd3f7fe080ac0f7b2abc61065525240 Author: Christopher Willis-Ford Date: Wed Oct 31 15:57:04 2018 -0700 only import electron-devtools-installer in dev mode commit eff882c92813f95becce7d5885672acd56b6dc3f Author: Christopher Willis-Ford Date: Wed Oct 31 15:40:27 2018 -0700 use rimraf and mkdirp to ensure clean builds commit f761193c5f331e42e72afc26cd730a8884761711 Author: Christopher Willis-Ford Date: Wed Oct 31 15:19:13 2018 -0700 set productName to "Scratch Desktop 3.0" commit 4771e849ea5843a06c699fd627a67f4bd68328a6 Author: Christopher Willis-Ford Date: Wed Oct 31 15:02:01 2018 -0700 add repository field to package.json commit d1acf29f517d9b6c61e1a5cb46652015b53f3e00 Merge: 0c8a186 cb08521 Author: Christopher Willis-Ford Date: Wed Oct 31 14:52:34 2018 -0700 Merge branch 'electron-webpack' into develop commit cb0852101e704588936d3d54f0f01a93e055d275 Author: Christopher Willis-Ford Date: Wed Oct 24 15:00:03 2018 -0700 Load default project on startup commit 78e6831cbb78ff4662039a19b0c692ded89f622a Author: Christopher Willis-Ford Date: Mon Oct 22 18:59:36 2018 -0700 Add `ElectronStorageHelper` to load bundled assets commit 071ba28fc8fb4bf31a5f2107f21c1bcb329ce6cd Author: Christopher Willis-Ford Date: Mon Oct 22 17:21:13 2018 -0700 Fix static assets path commit 914f883c65f73b399e2e2d8f0397dac98887b2b6 Author: Christopher Willis-Ford Date: Mon Oct 22 12:36:01 2018 -0700 Eliminate redundant `index.js`->`index.jsx` shim commit 53e8723086a7a6581ea2af044b1938af4dd85cb5 Author: Christopher Willis-Ford Date: Fri Oct 19 17:45:45 2018 -0700 Fix build with/without `npm ln`, match scratch-gui Match the versions of Webpack, Babel, and related plugins as used in scratch-gui. That plus a few other tweaks means that this repository builds the same with or without `npm ln scratch-gui`, and also means that all syntax used in scratch-gui should build the same here. commit 42cba6414e283bd0cdc9fc4d26cc27c5afbd248f Author: Christopher Willis-Ford Date: Fri Oct 19 14:30:23 2018 -0700 Add media library assets, fetch script commit 146a6f0de0a40b5432fda6813ba4a163d366504d Author: Christopher Willis-Ford Date: Thu Oct 18 19:03:56 2018 -0700 Override settings for minify and Babel commit 25c0954b9423a57fedba244321efbabcfe219f5f Author: Christopher Willis-Ford Date: Wed Oct 17 17:22:34 2018 -0700 Update electron-webpack and webpack The old version of webpack takes a long time and then runs out of memory when I add media library assets in `src/static`. The new version handles it OK. commit 99b172d8936d263ad676cd2343be968539d540fc Author: Christopher Willis-Ford Date: Sat Oct 13 01:26:58 2018 -0700 Add React dev tools commit 1de7228a8c0592b57bd0736f9987b117ec0464e6 Author: Christopher Willis-Ford Date: Sat Oct 13 01:09:45 2018 -0700 Tell Babel to target Electron 3.0.2; enable chunk splitting commit 751406722dc9564ee2d9112461d58b88263e3629 Author: Christopher Willis-Ford Date: Fri Oct 12 23:03:16 2018 -0700 eslint: Switch src/ env from shared to node commit 606f28ae43d23eb9134b9ac36d184129247c7db9 Author: Christopher Willis-Ford Date: Thu Sep 27 14:43:04 2018 -0700 Upgrade to electron@^3.0.2 commit 97db496efc726704a805dc71d2e6ac835d91fd54 Author: Christopher Willis-Ford Date: Thu Sep 27 12:51:53 2018 -0700 Fix lint rules for src/renderer/ commit 4a8bac49ddde86fdc711708e473550d6dfd2ea86 Author: Christopher Willis-Ford Date: Thu Sep 27 12:44:30 2018 -0700 Copy static assets from GUI, load GUI from dist/ commit c6a229f57f77cdaf6b23fb636ba9b56c487bb389 Author: Christopher Willis-Ford Date: Thu Sep 27 12:13:26 2018 -0700 Webpack config fixups including react-intl commit 3785f7070ebe7f5108e6b36d47a11e42870af2b1 Author: Christopher Willis-Ford Date: Wed Sep 26 18:16:35 2018 -0700 Get scratch-gui working, kinda, sorta... CSS isn't loaded and it takes a LONG time to compile, but it does load the GUI. It also requires using `npm ln` for `scratch-gui`. commit 6adb950ef6684aad5a36a9791ef145075213ae24 Author: Christopher Willis-Ford Date: Wed Sep 26 12:54:08 2018 -0700 Add React, Redux, and related deps commit 13391df515db79aebf2245b9a18b441d7eda2ac9 Author: Christopher Willis-Ford Date: Wed Sep 19 15:15:02 2018 -0700 Use eslint-config-scratch commit 6145b0b9a1ed3d7957e71e53aaf2ebf78f938803 Author: Christopher Willis-Ford Date: Wed Sep 26 12:11:46 2018 -0700 Convert to use npm instead of yarn, rename app commit 0c8a1864552af9ec7ef9baf1653a654c83884a6e Author: Christopher Willis-Ford Date: Thu Sep 6 11:45:37 2018 -0700 Add electron and stub start script commit 876f185f53a7414d79eefd5ef7e7b5c3f6344a21 Author: Christopher Willis-Ford Date: Thu Sep 6 11:20:27 2018 -0700 Initial commit commit 09ae10e82e728047aed5e7341c4a555398fee33d Author: develar Date: Tue Aug 21 09:21:54 2018 +0200 chore: update deps commit 3f9dee45ab2c7d921cc560c768e8794ee5bc77b4 Author: develar Date: Tue May 8 09:05:40 2018 +0200 chore: update deps commit 135f9f34b48e6097260ea382a39126495fb50ab7 Author: develar Date: Tue Apr 3 08:31:29 2018 +0200 chore: update deps Close #29 commit f5fdcfb44252d00b035b680a12efe022f81d5376 Author: develar Date: Sun Mar 18 17:41:03 2018 +0100 chore: update deps commit 118f6a18663c9b18a812a267e5c21e2dda0f3334 Author: develar Date: Tue Feb 20 08:50:38 2018 +0100 chore: update electron-webpack to 1.13.0 commit a6ef4b77fa78f4156c8ba5a94f31af2fb1923e57 Author: suvichak Date: Tue Feb 20 14:44:26 2018 +0700 fix: pin webpack-sources version until upstream bug not fixed "original.line and original.column are not numbers" when using NPM #14 commit 0cf4baedc7b5360cbe41338de294ff4187cdaf3c Author: Sooraj V Nair Date: Tue Feb 20 12:12:35 2018 +0530 chore: updated to electron v1.8.2 (#24) commit 539f24655d37c37c272dea9650adb4874f0717d6 Author: Vladimir Krivosheev Date: Tue Feb 6 15:25:55 2018 +0100 chore: update electron to 1.7.12 commit 71215e3311a5dc967f13c5425f224f5bf8fbc15d Author: Ryan Date: Tue Feb 6 08:24:35 2018 -0600 fix: imports for url & path which were breaking the app (#21) commit 427ff959db05527b368158084c55263ebab9e37f Author: hacker112 Date: Mon Feb 5 11:13:41 2018 +0100 fix: Make sure that index.html can be found in paths with hashtag (#20) commit 0f0ec413af42174600b35d19762edd11f7c423e2 Author: Vladimir Krivosheev Date: Tue Jan 30 03:35:45 2018 -0800 chore: update deps commit 0d76369d937d1ed21d4c8d9781c724fdb3268d02 Author: Zachary Snow Date: Tue Jan 30 12:29:14 2018 +0100 chore: Updated package.json devDependencies to newest versions. (#17) commit 283fd52ac72cb215b47d58db4833b5569292e973 Author: develar Date: Fri Oct 27 10:08:24 2017 +0200 chore: update electron-webpack to 1.10.1 commit 62a052925d683e1abe46179d7e505b6712d2d414 Merge: 2c93dc0 a4ed640 Author: Greg Holguin Date: Sun Oct 15 09:43:41 2017 -0500 Merge pull request #7 from piggyslasher/patch-1 Update CURL installation instructions commit a4ed6407bba506647298d02026fa4ed81010964c Author: Vik Ramanujam Date: Sat Oct 14 19:56:46 2017 +0530 Update CURL installation instructions Just notify people that it's going to write to the current folder. Otherwise they might forget and pollute their project directory like I did! commit 2c93dc047a549a1b5abb88add2d2a2492adc5f18 Author: develar Date: Fri Oct 6 18:47:15 2017 +0200 chore: update electron-webpack to 1.8.0 commit 2cc0d0c32f252eb83a1bd3a5868cfe1af93b80aa Author: develar Date: Fri Oct 6 09:39:00 2017 +0200 fix: use ELECTRON_WEBPACK_WDS_PORT env instead of hardcoded webpack-dev-server port number Focus main window if dev tool window opened on start commit f1310556fba3fb57a43d0b3539a8f2ae58f027bf Author: develar Date: Fri Oct 6 09:34:35 2017 +0200 chore: update deps commit 87437f7c26b12e8e5756e6b9f8b9a2045114ae3c Merge: 10afade a38efb3 Author: SimulatedGREG Date: Mon Oct 2 17:09:47 2017 -0700 Merge branch 'master' of github.com:electron-userland/electron-webpack-quick-start commit 10afade1bc8b25554ec906fa2bc01ca1aabf0228 Author: SimulatedGREG Date: Mon Oct 2 17:09:37 2017 -0700 update landingpage to remove extraneous logs, drop -- for yarn script commit a38efb36044a71abdba2cc362ab84dc5cead4e62 Author: develar Date: Sat Sep 9 13:22:28 2017 +0200 chore: update deps commit cfff20c4e1e262c1e71f3b6efd89bdb8461a3d18 Author: Vladimir Krivosheev Date: Mon Sep 4 18:16:59 2017 +0200 chore: fix "minimum" spelling commit de40d4cafcc1ef07e0b73d01f623363646bfb93f Author: Vladimir Krivosheev Date: Mon Sep 4 17:15:40 2017 +0200 chore: fix "Necessary" spelling commit a10c1752b7932db542d2411e8f7aa58de4a03112 Author: SimulatedGREG Date: Tue Aug 29 16:35:30 2017 -0500 new welcome page commit 70562a0c514a4ee3dcdbe1284bc3fe268ff70ac7 Author: SimulatedGREG Date: Mon Aug 28 00:33:31 2017 -0500 update repoLink on readme commit 3226e592dde6f2aac0211826a46e240d68d5a673 Author: SimulatedGREG Date: Sun Aug 27 18:06:26 2017 -0500 readme update commit 8079e165a8ffd5c0fb2aeb8f1d7ffdfaec01d9ac Author: SimulatedGREG Date: Sun Aug 27 16:50:19 2017 -0500 add .yarnclean, readme update commit 27a73f068d84dd582bacfabba2d82557c4629f83 Author: SimulatedGREG Date: Sun Aug 27 16:42:01 2017 -0500 update wording of dev scripts commit 031385cd4e7346f3b2deceb47f865037d93c59a6 Author: SimulatedGREG Date: Sun Aug 27 16:07:17 2017 -0500 update strip-components option in tar commit 3d5732301858d8ce734d7dafb1631c3b3719838c Author: SimulatedGREG Date: Sun Aug 27 15:58:13 2017 -0500 add readme commit 3a5914f7038c22721b7a63760a3c4a1e8c310688 Author: SimulatedGREG Date: Sun Aug 27 14:50:22 2017 -0500 update .gitignore, remove index.ejs, add code comments to main process commit 4f2531e10c5fa38b38e8acc9fd31a23aa48ade0b Author: SimulatedGREG Date: Sun Aug 27 14:15:38 2017 -0500 :tada: initial commit --- .circleci/config.yml | 242 +++++++++++++++++++++ .gitattributes | 1 + electron-builder.yaml | 2 +- electron-webpack.json5 | 4 +- package.json | 32 +-- scripts/afterSign.js | 16 +- scripts/electron-builder-wrapper.js | 157 +++++++++++-- scripts/fetchMediaLibraryAssets.js | 13 +- src/main/ScratchDesktopTelemetry.js | 5 + src/main/argv.js | 23 ++ src/main/index.js | 168 ++++++++++++-- src/renderer/ScratchDesktopAppStateHOC.jsx | 53 +++++ src/renderer/ScratchDesktopGUIHOC.jsx | 175 +++++++++++++++ src/renderer/about.css | 39 ++++ src/renderer/about.jsx | 46 ++-- src/renderer/app.jsx | 123 +---------- src/renderer/index.html | 2 +- src/renderer/index.js | 29 ++- src/renderer/privacy.css | 14 ++ src/renderer/privacy.jsx | 235 ++++++++++++++++++++ src/renderer/showPrivacyPolicy.js | 13 ++ webpack.main.additions.js | 11 - webpack.main.js | 16 ++ webpack.makeConfig.js | 100 +++++++-- webpack.renderer.js | 39 ++++ 25 files changed, 1305 insertions(+), 253 deletions(-) create mode 100644 .circleci/config.yml create mode 100644 src/main/argv.js create mode 100644 src/renderer/ScratchDesktopAppStateHOC.jsx create mode 100644 src/renderer/ScratchDesktopGUIHOC.jsx create mode 100644 src/renderer/about.css create mode 100644 src/renderer/privacy.css create mode 100644 src/renderer/privacy.jsx create mode 100644 src/renderer/showPrivacyPolicy.js delete mode 100644 webpack.main.additions.js create mode 100644 webpack.main.js create mode 100644 webpack.renderer.js diff --git a/.circleci/config.yml b/.circleci/config.yml new file mode 100644 index 0000000..6befc9a --- /dev/null +++ b/.circleci/config.yml @@ -0,0 +1,242 @@ +version: 2.1 +workflows: + macos: + jobs: + - build_for_macos: + context: scratch-desktop-and-link + windows: + jobs: + - build_for_windows: + context: scratch-desktop-and-link +orbs: + windows: circleci/windows@2.4.0 +aliases: + # condition to indicate whether or not we should sign this build + - &should_sign + or: + - equal: [ develop, << pipeline.git.branch >> ] + - equal: [ main, << pipeline.git.branch >> ] + - equal: [ master, << pipeline.git.branch >> ] + # clear large environment variables from the "scratch-desktop-and-link" context + # this helps when a program (like NPM) encounters errors with a large environment + - &clear_context + CSC_MACOS: "" + MAC_PROVISION_PROFILE: "" + SDM_CERT: "" + SDM_CERT_CA_BUNDLE: "" + SDM_CERT_KEY: "" + WIN_CSC_LINK: "" +jobs: + build_for_macos: + macos: + # CircleCI's Xcode 11.1.0 image is the last of their images to be based on macOS 10.14 + # I've had trouble building for earlier versions of macOS on Catalina but it's unclear whether that was due to + # Catalina or the version of Xcode. We should investigate this further. + xcode: 11.1.0 + steps: + - checkout + - npm_install: + npmCacheDir: ~/.npm + - run: + name: Test + command: npm run test + - when: + condition: + *should_sign + steps: + - run: + name: Import CI context + command: | + set -e + function decodeToFile () { + if [ -z "$1" ]; then + echo "Missing or invalid filename" + return 1 + fi + if [ -z "$2" ]; then + echo "Missing environment variable contents for file: $1" + return 2 + fi + echo "$2" | base64 --decode > "$1" + } + decodeToFile embedded.provisionprofile "${MAC_PROVISION_PROFILE}" + decodeToFile mas-dev.provisionprofile "${MAC_DEV_PROVISION_PROFILE}" + decodeToFile macos-certs-scratch-foundation.p12.gz "${CSC_MACOS_GZ}" + decodeToFile apple-dev-cert.p12 "${MAC_DEV_CERT}" + gunzip macos-certs-scratch-foundation.p12.gz + security -v create-keychain -p circleci circleci.keychain + security -v default-keychain -s circleci.keychain + security -v import macos-certs-scratch-foundation.p12 -k circleci.keychain -P "${CSC_MACOS_PASSWORD}" -T /usr/bin/codesign -T /usr/bin/productbuild + security -v import apple-dev-cert.p12 -k circleci.keychain -P "${MAC_DEV_CERT_PASSWORD}" -T /usr/bin/codesign -T /usr/bin/productbuild + security -v unlock-keychain -p circleci circleci.keychain + # "set-key-partition-list" prints extensive not-so-useful output and adding "-q" (even multiple times) doesn't suppress it. + # The "grep -v" at the end of this line suppresses all of that so any errors or warnings might be more visible. + security -v set-key-partition-list -S apple-tool:,apple:,codesign: -s -k circleci circleci.keychain | grep -v '^ 0x' + security -v set-keychain-settings -lut 600 circleci.keychain + security -v find-identity circleci.keychain + rm macos-certs-scratch-foundation.p12 apple-dev-cert.p12 + - restore_cache: + # Caching Homebrew's files (see the save_cache step below) means that Homebrew doesn't have to update as + # much. The Homebrew update can take several minutes without this, but with the cache it tends to take less + # than a minute most of the time. The cache will expire periodically and be replaced by a more up-to-date + # cache, which should effectively cap the amount of updating that Homebrew needs to do on top of the cache. + name: Restore Homebrew cache + key: homebrew-cache-v1 + - run: + name: Work around electron-userland/electron-builder#4964 + command: | + brew install go go-bindata + git -C ~ clone https://github.com/develar/app-builder.git + git -C ~/app-builder checkout b85740334fec875f5dd8dcd22eb1f729599109db + make --directory=~/app-builder build + ln -sfv ~/app-builder/dist/app-builder_darwin_amd64/app-builder ./node_modules/app-builder-bin/mac/ + - run: + name: Upgrade to Node 14 + command: brew install node@14 + - save_cache: + name: Save Homebrew cache + paths: + - ~/Library/Caches/Homebrew + - /usr/local/Homebrew + key: homebrew-cache-v1 + - build + - run: + name: Move DMG to artifacts directory + command: | + mkdir -p Artifacts/ + mv -v dist/Scratch*.dmg Artifacts/ + - when: + condition: + *should_sign + steps: + - run: + name: Zip MAS-Dev to artifacts directory + # If you use `zip` for this it will throw away some metadata (resource forks?) and + # the app will crash on startup with "EXC_CRASH (Code Signature Invalid)". + # To preserve that metadata, use `ditto` instead. + # See also: https://stackoverflow.com/a/22370486 + command: | + NPM_APP_VERSION="`node -pe "require('./package.json').version"`" + cd dist/mas-dev + ditto -v -c -k --sequesterRsrc --keepParent --zlibCompressionLevel 9 \ + Scratch*.app ../../Artifacts/mas-dev-${NPM_APP_VERSION}.zip + - run: + name: Move PKG to artifacts directory + command: | + mv -v dist/mas/Scratch*.pkg Artifacts/ + - store_artifacts: + path: Artifacts/ + build_for_windows: + executor: windows/default + steps: + - run: + # work around https://github.com/appveyor/ci/issues/2420 which seems to affect CircleCI too + # see also https://circleci.com/docs/2.0/env-vars/#using-parameters-and-bash-environment + name: Work around git-sh-setup issue + shell: bash + command: | + echo 'Adding libexec/git-core to PATH...' + echo 'For more details see https://github.com/appveyor/ci/issues/2420' + echo 'export PATH="$PATH:/c/Program Files/Git/mingw64/libexec/git-core"' >> $BASH_ENV + - run: + # nvm for Windows doesn't accept partial version numbers, so specify exact :( + name: Upgrade to Node 14.17.0 + command: | + nvm install 14.17.0 + nvm use 14.17.0 + - checkout + - npm_install: + npmCacheDir: "C:/Users/circleci/AppData/Roaming/npm-cache" + - run: + name: Test + command: npm run test + environment: *clear_context + - when: + condition: + *should_sign + steps: + - run: + name: Import CI context + shell: bash + command: | + set -e + function decodeToFile () { + if [ -z "$1" ]; then + echo "Missing or invalid filename" + return 1 + fi + if [ -z "$2" ]; then + echo "Missing environment variable contents for file: $1" + return 2 + fi + echo "$2" | base64 --decode > "$1" + } + decodeToFile ~/codesign.pfx "${WIN_CSC_LINK}" + - run: + # In theory this should be unnecessary: the electron-builder documentation says that WIN_CSC_LINK can + # be a base64-encoded certificate, which is what's in the CI context. In practice that leads to an + # signtool.exe finding the certificate but not the key, for reasons I haven't been able to understand. + # Also, because of the non-standard user configuration on CircleCI's Windows VM, attempting to import + # a certificate into the user's certificate store ("Cert:/LocalUser/My") will fail. Instead, this code + # imports the PFX into the machine certificate store. That usually requires Administrator permissions, + # but on CircleCI's setup it works just fine. See also: https://github.com/ShabadOS/desktop/issues/265 + # and https://github.com/ShabadOS/desktop/pull/266 + name: Add CSC to machine store + shell: powershell + command: | + $securePassword = (ConvertTo-SecureString -String $env:WIN_CSC_KEY_PASSWORD -AsPlainText -Force) + Import-PfxCertificate -FilePath ~/codesign.pfx -Password $securePassword -CertStoreLocation "Cert:/LocalMachine/My" + - build + - run: + name: Move Windows build products to artifacts directory + shell: bash + command: | + mkdir -p Artifacts/ + mv dist/{Scratch*.appx,Scratch*.exe} Artifacts/ + - store_artifacts: + path: Artifacts/ +commands: + npm_install: + description: Run 'npm install' with caching + parameters: + npmCacheDir: + type: string + description: NPM cache directory (`npm config cache get`) - usually either ~/.npm or %AppData%/npm-cache + steps: + - restore_cache: + keys: + - npm-cache-{{ arch }}-{{ checksum "package-lock.json" }} + - run: + name: Install node_modules + shell: bash # harmless on macOS, required on Windows to work around git-sh-setup issue + # --prefer-offline "will make npm skip any conditional requests (304 checks) for stale cache data, and only + # hit the network if something is missing from the cache" + command: npm ci --prefer-offline + environment: *clear_context + - save_cache: + paths: + - << parameters.npmCacheDir >> + key: npm-cache-{{ arch }}-{{ checksum "package-lock.json" }} + build: + steps: + - when: + condition: + *should_sign + steps: + - run: + command: npm run dist + no_output_timeout: 30m # macOS notarization can take longer than the default 10 minutes + environment: + # blank big variables to avoid crash on Windows + <<: *clear_context + # let Windows know where to get the PFX (ignored on non-Windows builds) + WIN_CSC_LINK: ~/codesign.pfx + # blank CIRCLE_BUILD_NUM to work around electron-userland/electron-builder#5016 + CIRCLE_BUILD_NUM: "" + - unless: + condition: + *should_sign + steps: + - run: + command: npm run distDev + environment: *clear_context diff --git a/.gitattributes b/.gitattributes index c49fe81..4e6bb68 100644 --- a/.gitattributes +++ b/.gitattributes @@ -7,6 +7,7 @@ # File types which we know are binary # Prefer LF for most file types +*.css text eol=lf *.htm text eol=lf *.html text eol=lf *.js text eol=lf diff --git a/electron-builder.yaml b/electron-builder.yaml index 0224edc..0501880 100644 --- a/electron-builder.yaml +++ b/electron-builder.yaml @@ -5,7 +5,7 @@ copyright: Copyright © 2019-2020 Clip Team. compression: normal directories: buildResources: buildResources - output: dist/ + output: dist win: target: [ zip, nsis ] linux: diff --git a/electron-webpack.json5 b/electron-webpack.json5 index 29051a5..4d59a7e 100644 --- a/electron-webpack.json5 +++ b/electron-webpack.json5 @@ -1,9 +1,9 @@ { "main": { - "webpackConfig": "webpack.main.additions.js" + "webpackConfig": "webpack.main.js" }, "renderer": { "template": "src/renderer/index.html", - "webpackConfig": "webpack.renderer.additions.js" + "webpackConfig": "webpack.renderer.js" } } diff --git a/package.json b/package.json index c159228..0e96cef 100644 --- a/package.json +++ b/package.json @@ -8,17 +8,20 @@ }, "version": "3.0.0", "license": "AGPL-3.0", - "scripts": { - "start": "node --max-old-space-size=4096 node_modules/electron-webpack/out/cli.js dev --bail --display-error-details --env.minify=false", - "build-gui": "node ./scripts/run-in-gui.js build", - "watch-gui": "node ./scripts/run-in-gui.js watch", - "clean": "rimraf ./dist/ ./static/assets/", - "compile": "rimraf ./dist/ && node --max-old-space-size=4096 node_modules/electron-webpack/out/cli.js --bail --display-error-details --env.minify=false", + "scripts": { + "clean": "rimraf ./dist ./static/assets", + "start": "mkdirp ./dist && electron-webpack dev --bail --display-error-details --env.minify=false --no-progress", + "compile": "mkdirp ./dist && electron-webpack --bail --display-error-details --env.minify=false --no-progress", "fetch": "rimraf ./static/assets/ && mkdirp ./static/assets/ && node ./scripts/fetchMediaLibraryAssets.js", - "dist": "yarn run build-gui && yarn run fetch && yarn run compile -p && node ./scripts/electron-builder-wrapper.js", - "builder": "node ./scripts/electron-builder-wrapper.js", - "dist:dir": "yarn run dist -- --dir -c.compression=store -c.mac.identity=null", - "lint": "eslint --cache --color --ext .jsx,.js ." + "build": "yarn run build:dev", + "build:dev": "yarn run compile && yarn run doBuild -- --mode=dev", + "build:dir": "yarn run compile && yarn run doBuild -- --mode=dir", + "build:dist": "yarn run compile && yarn run doBuild -- --mode=dist", + "doBuild": "node ./scripts/electron-builder-wrapper.js", + "dist": "yarn run clean && yarn run compile && yarn run fetch && yarn run doBuild -- --mode=dist", + "distDev": "yarn run clean && yarn run compile && yarn run fetch && yarn run doBuild -- --mode=dev", + "test": "yarn run test:lint", + "test:lint": "eslint --cache --color --ext .jsx,.js ." }, "repository": { "type": "git", @@ -41,7 +44,7 @@ "clipcc-gui": "latest", "copy-webpack-plugin": "^5.1.1", "electron": "^8.2.5", - "electron-builder": "^22.6.0", + "electron-builder": "^22.11.5", "electron-devtools-installer": "^3.0.0", "electron-notarize": "^0.3.0", "electron-store": "^5.1.1", @@ -50,19 +53,20 @@ "eslint-config-scratch": "^6.0.0", "eslint-plugin-import": "^2.20.0", "eslint-plugin-react": "^7.20.0", + "fs-extra": "^9.0.1", "intl": "1.2.5", "lodash.bindall": "^4.4.0", "lodash.defaultsdeep": "^4.6.1", "minilog": "^3.1.0", + "minimist": "^1.2.5", "mkdirp": "^1.0.4", "nets": "^3.2.0", "react": "16.2.0", "react-dom": "16.2.1", - "react-intl": "2.8.0", + "react-intl": "2.9.0", "react-redux": "5.0.7", - "redux": "3.5.2", + "redux": "3.7.2", "rimraf": "^3.0.2", - "source-map-loader": "^0.2.4", "uuid": "^8.0.0", "webpack": "^4.43.0" }, diff --git a/scripts/afterSign.js b/scripts/afterSign.js index af01eb1..fbe4fb0 100644 --- a/scripts/afterSign.js +++ b/scripts/afterSign.js @@ -6,10 +6,10 @@ const notarizeMacBuild = async function (context) { if (!process.env.AC_USERNAME) { console.error([ - 'Notarizing the macOS build requires an Apple ID.', - 'Please set the environment variable AC_USERNAME.', - 'Make sure your keychain has an item for "Application Loader: your@apple.id"', - 'This build will not run on newer versions of macOS!' + 'This build is not notarized and will not run on newer versions of macOS!', + 'Notarizing the macOS build requires an Apple ID. To notarize future builds:', + '* Set the environment variable AC_USERNAME to your@apple.id and', + '* Either set AC_PASSWORD or ensure your keychain has an item for "Application Loader: your@apple.id"' ].join('\n')); return; } @@ -17,7 +17,11 @@ const notarizeMacBuild = async function (context) { const appleId = process.env.AC_USERNAME; const appleIdKeychainItem = `Application Loader: ${appleId}`; - console.log(`Notarizing with Apple ID "${appleId}" and keychain item "${appleIdKeychainItem}"`); + if (process.env.AC_PASSWORD) { + console.log(`Notarizing with Apple ID "${appleId}" and a password`); + } else { + console.log(`Notarizing with Apple ID "${appleId}" and keychain item "${appleIdKeychainItem}"`); + } const {appOutDir} = context; const productFilename = context.packager.appInfo.productFilename; @@ -25,7 +29,7 @@ const notarizeMacBuild = async function (context) { appBundleId: appId, appPath: `${appOutDir}/${productFilename}.app`, appleId, - appleIdPassword: `@keychain:${appleIdKeychainItem}` + appleIdPassword: process.env.AC_PASSWORD || `@keychain:${appleIdKeychainItem}` }); }; diff --git a/scripts/electron-builder-wrapper.js b/scripts/electron-builder-wrapper.js index a7128a2..f3b6e1a 100644 --- a/scripts/electron-builder-wrapper.js +++ b/scripts/electron-builder-wrapper.js @@ -7,6 +7,7 @@ */ const {spawnSync} = require('child_process'); +const fs = require('fs'); /** * Strip any code signing configuration (CSC) from a set of environment variables. @@ -38,20 +39,38 @@ const getPlatformFlag = function () { /** * Run `electron-builder` once to build one or more target(s). - * @param {string} targetGroup - the target(s) to build in this pass. - * If the `targetGroup` is `'nsis'` then the environment must contain code-signing config (CSC_* or WIN_CSC_*). - * If the `targetGroup` is `'appx'` then code-signing config will be stripped from the environment if present. + * @param {object} wrapperConfig - overall configuration object for the wrapper script. + * @param {object} target - the target to build in this call. + * If the `target.name` is `'nsis'` then the environment must contain code-signing config (CSC_* or WIN_CSC_*). + * If the `target.name` is `'appx'` then code-signing config will be stripped from the environment if present. */ -const runBuilder = function (targetGroup) { - // the appx build fails if CSC_* or WIN_CSC_* variables are set - const shouldStripCSC = (targetGroup === 'appx'); +const runBuilder = function (wrapperConfig, target) { + // the AppX build fails if CSC_* or WIN_CSC_* variables are set + const shouldStripCSC = (target.name.indexOf('appx') === 0) || (!wrapperConfig.doSign); const childEnvironment = shouldStripCSC ? stripCSC(process.env) : process.env; - //if ((targetGroup === 'nsis') && !(childEnvironment.CSC_LINK || childEnvironment.WIN_CSC_LINK)) { - // throw new Error(`NSIS build requires CSC_LINK or WIN_CSC_LINK`); - //} + if (wrapperConfig.doSign && + (target.name.indexOf('nsis') === 0) && + !(childEnvironment.CSC_LINK || childEnvironment.WIN_CSC_LINK)) { + throw new Error(`Signing NSIS build requires CSC_LINK or WIN_CSC_LINK`); + } const platformFlag = getPlatformFlag(); - const customArgs = process.argv.slice(2); // remove `node` and `this-script.js` - const allArgs = [platformFlag, targetGroup, ...customArgs]; + let allArgs = [platformFlag, target.name]; + if (target.platform === 'darwin') { + allArgs.push(`--c.mac.type=${wrapperConfig.mode === 'dist' ? 'distribution' : 'development'}`); + if (target.name === 'mas-dev') { + allArgs.push('--c.mac.provisioningProfile=mas-dev.provisionprofile'); + } + if (wrapperConfig.doSign) { + // really this is "notarize only if we also sign" + allArgs.push('--c.afterSign=scripts/afterSign.js'); + } else { + allArgs.push('--c.mac.identity=null'); + } + } + if (!wrapperConfig.doPackage) { + allArgs.push('--dir', '--c.compression=store'); + } + allArgs = allArgs.concat(wrapperConfig.builderArgs); console.log(`running electron-builder with arguments: ${allArgs}`); const result = spawnSync('electron-builder', allArgs, { env: childEnvironment, @@ -70,30 +89,126 @@ const runBuilder = function (targetGroup) { }; /** - * @returns {Array.} - the default list of target groups on this platform. Each item in the array represents - * one call to `runBuilder` for one or more build target(s). + * @param {object} wrapperConfig - overall configuration object for the wrapper script. + * @returns {Array.} - the default list of targets on this platform. Each item in the array represents one + * call to `runBuilder` for exactly one build target. In theory electron-builder can build two or more targets at the + * same time but doing so limits has unwanted side effects on both macOS and Windows (see function body). */ -const calculateTargets = function () { +const calculateTargets = function (wrapperConfig) { + const masDevProfile = 'mas-dev.provisionprofile'; + const availableTargets = { + macAppStore: { + name: 'mas', + platform: 'darwin' + }, + macAppStoreDev: { + name: 'mas-dev', + platform: 'darwin' + }, + macDirectDownload: { + name: 'dmg', + platform: 'darwin' + }, + microsoftStore: { + name: 'appx:ia32 appx:x64', + platform: 'win32' + }, + windowsDirectDownload: { + name: 'nsis:ia32', + platform: 'win32' + } + }; + const targets = []; switch (process.platform) { case 'win32': // run in two passes so we can skip signing the appx //return ['nsis:ia32', 'appx']; return ['zip', 'nsis']; + /* + // Run in two passes so we can skip signing the AppX for distribution through the MS Store. + targets.push(availableTargets.microsoftStore); + targets.push(availableTargets.windowsDirectDownload); + break; + */ case 'darwin': // Running 'dmg' and 'mas' in the same pass causes electron-builder to skip signing the non-MAS app copy. - // Running them as separate passes means they both get signed. + // Running them as separate passes means they can both get signed. // Seems like a bug in electron-builder... // Running the 'mas' build first means that its output is available while we wait for 'dmg' notarization. // Add 'mas-dev' here to test a 'mas'-like build locally. You'll need a Mac Developer provisioning profile. return ['zip', 'mas', 'dmg']; + /* + // Add macAppStoreDev here to test a MAS-like build locally. You'll need a Mac Developer provisioning profile. + if (fs.existsSync(masDevProfile)) { + targets.push(availableTargets.macAppStoreDev); + } else { + console.log(`skipping target "${availableTargets.macAppStoreDev.name}": ${masDevProfile} missing`); + } + if (wrapperConfig.doSign) { + targets.push(availableTargets.macAppStore); + } else { + // electron-builder doesn't seem to support this configuration even if mac.type is "development" + console.log(`skipping target "${availableTargets.macAppStore.name}" because code-signing is disabled`); + } + targets.push(availableTargets.macDirectDownload); + break; + */ case 'linux': return ['zip', 'deb', 'rpm']; + default: + throw new Error(`Could not determine targets for platform: ${process.platform}`); + } + //return targets; +}; + +const parseArgs = function () { + const scriptArgs = process.argv.slice(2); // remove `node` and `this-script.js` + const builderArgs = []; + let mode = 'dev'; // default + + for (const arg of scriptArgs) { + const modeSplit = arg.split(/--mode(\s+|=)/); + if (modeSplit.length === 3) { + mode = modeSplit[2]; + } else { + builderArgs.push(arg); + } + } + + let doPackage; + let doSign; + + switch (mode) { + case 'dev': + doPackage = true; + doSign = false; + break; + case 'dir': + doPackage = false; + doSign = false; + break; + case 'dist': + doPackage = true; + doSign = true; + } + + return { + builderArgs, + doPackage, // false = build to directory + doSign, + mode + }; +}; + +const main = function () { + const wrapperConfig = parseArgs(); + + // TODO: allow user to specify targets? We could theoretically build NSIS on Mac, for example. + wrapperConfig.targets = calculateTargets(wrapperConfig); + + for (const target of wrapperConfig.targets) { + runBuilder(wrapperConfig, target); } - throw new Error(`Could not determine targets for platform: ${process.platform}`); }; -// TODO: allow user to specify targets? We could theoretically build NSIS on Mac, for example. -const targets = calculateTargets(); -for (const targetGroup of targets) { - runBuilder(targetGroup); -} +main(); diff --git a/scripts/fetchMediaLibraryAssets.js b/scripts/fetchMediaLibraryAssets.js index b729fc6..a9dd2bc 100644 --- a/scripts/fetchMediaLibraryAssets.js +++ b/scripts/fetchMediaLibraryAssets.js @@ -48,16 +48,11 @@ const collectAssets = function (dest) { collectSimple(libraries.costumes, dest, 'Costume'); collectSimple(libraries.sounds, dest, 'Sound'); libraries.sprites.forEach(sprite => { - if (sprite.md5) { - dest.add(sprite.md5); - } else { - console.warn(`Sprite has no MD5 property:\n${describe(sprite)}`); - } - if (sprite.json.costumes) { - collectSimple(sprite.json.costumes, dest, `Costume for sprite ${sprite.name}`); + if (sprite.costumes) { + collectSimple(sprite.costumes, dest, `Costume for sprite ${sprite.name}`); } - if (sprite.json.sounds) { - collectSimple(sprite.json.sounds, dest, `Sound for sprite ${sprite.name}`); + if (sprite.sounds) { + collectSimple(sprite.sounds, dest, `Sound for sprite ${sprite.name}`); } }); return dest; diff --git a/src/main/ScratchDesktopTelemetry.js b/src/main/ScratchDesktopTelemetry.js index ec27205..906a7d4 100644 --- a/src/main/ScratchDesktopTelemetry.js +++ b/src/main/ScratchDesktopTelemetry.js @@ -90,6 +90,11 @@ class ScratchDesktopTelemetry { // make a singleton so it's easy to share across both Electron processes const scratchDesktopTelemetrySingleton = new ScratchDesktopTelemetry(); +// `handle` works with `invoke` +ipcMain.handle('getTelemetryDidOptIn', () => + scratchDesktopTelemetrySingleton.didOptIn +); +// `on` works with `sendSync` (and `send`) ipcMain.on('getTelemetryDidOptIn', event => { event.returnValue = scratchDesktopTelemetrySingleton.didOptIn; }); diff --git a/src/main/argv.js b/src/main/argv.js new file mode 100644 index 0000000..25be323 --- /dev/null +++ b/src/main/argv.js @@ -0,0 +1,23 @@ +import minimist from 'minimist'; + +// inspired by yargs' process-argv +export const isElectronApp = () => !!process.versions.electron; +export const isElectronBundledApp = () => isElectronApp() && !process.defaultApp; + +export const parseAndTrimArgs = argv => { + // bundled Electron app: ignore 1 from "my-app arg1 arg2" + // unbundled Electron app: ignore 2 from "electron main/index.js arg1 arg2" + // node.js app: ignore 2 from "node src/index.js arg1 arg2" + const ignoreCount = isElectronBundledApp() ? 1 : 2; + + const parsed = minimist(argv); + + // ignore arguments AFTER parsing to handle cases like "electron --inspect=42 my.js arg1 arg2" + parsed._ = parsed._.slice(ignoreCount); + + return parsed; +}; + +const argv = parseAndTrimArgs(process.argv); + +export default argv; diff --git a/src/main/index.js b/src/main/index.js index f7bf66d..0a97190 100644 --- a/src/main/index.js +++ b/src/main/index.js @@ -1,17 +1,21 @@ -import {BrowserWindow, Menu, app, dialog, ipcMain, systemPreferences, globalShortcut} from 'electron'; -import fs from 'fs'; +import {BrowserWindow, Menu, app, dialog, ipcMain, shell, systemPreferences} from 'electron'; +import fs from 'fs-extra'; import path from 'path'; import {URL} from 'url'; +import {promisify} from 'util'; +import argv from './argv'; import {getFilterForExtension} from './FileFilters'; import telemetry from './ScratchDesktopTelemetry'; import MacOSMenu from './MacOSMenu'; import log from '../common/log.js'; +import {productName, version} from '../../package.json'; // suppress deprecation warning; this will be the default in Electron 9 app.allowRendererProcessReuse = true; -telemetry.appWasOpened(); +// suppress deprecation warning; this will be the default in Electron 9 +app.allowRendererProcessReuse = true; global.sharedObject = { argv: process.argv @@ -22,9 +26,29 @@ const defaultSize = {width: 1280, height: 800}; // good for MAS screenshots const isDevelopment = process.env.NODE_ENV !== 'production'; +const devToolKey = ((process.platform === 'darwin') ? + { // macOS: command+option+i + alt: true, // option + control: false, + meta: true, // command + shift: false, + code: 'KeyI' + } : { // Windows: control+shift+i + alt: false, + control: true, + meta: false, // Windows key + shift: true, + code: 'KeyI' + } +); + // global window references prevent them from being garbage-collected const _windows = {}; +// enable connecting to Scratch Link even if we DNS / Internet access is not available +// this must happen BEFORE the app ready event! +app.commandLine.appendSwitch('host-resolver-rules', 'MAP device-manager.scratch.mit.edu 127.0.0.1'); + const displayPermissionDeniedWarning = (browserWindow, permissionType) => { let title; let message; @@ -160,8 +184,30 @@ const createWindow = ({search = null, url = 'index.html', ...browserWindowOption webContents.session.setPermissionRequestHandler(handlePermissionRequest); + webContents.on('before-input-event', (event, input) => { + if (input.code === devToolKey.code && + input.alt === devToolKey.alt && + input.control === devToolKey.control && + input.meta === devToolKey.meta && + input.shift === devToolKey.shift && + input.type === 'keyDown' && + !input.isAutoRepeat && + !input.isComposing) { + event.preventDefault(); + webContents.openDevTools({mode: 'detach', activate: true}); + } + }); + + webContents.on('new-window', (event, newWindowUrl) => { + shell.openExternal(newWindowUrl); + event.preventDefault(); + }); + const fullUrl = makeFullUrl(url, search); window.loadURL(fullUrl); + window.once('ready-to-show', () => { + webContents.send('ready-to-show'); + }); return window; }; @@ -172,7 +218,18 @@ const createAboutWindow = () => { height: 400, parent: _windows.main, search: 'route=about', - title: 'About ClipCC' + title: `About ${productName}` + }); + return window; +}; + +const createPrivacyWindow = () => { + const window = createWindow({ + width: _windows.main.width * 0.8, + height: _windows.main.height * 0.8, + parent: _windows.main, + search: 'route=privacy', + title: `${productName} Privacy Policy` }); return window; }; @@ -189,13 +246,13 @@ const createMainWindow = () => { const window = createWindow({ width: defaultSize.width, height: defaultSize.height, - title: 'ClipCC 3' + title: `${productName} ${version}` // something like "Scratch 3.14" }); const webContents = window.webContents; - webContents.session.on('will-download', (ev, item) => { - const isProjectSave = getIsProjectSave(item); - const itemPath = item.getFilename(); + webContents.session.on('will-download', (willDownloadEvent, downloadItem) => { + const isProjectSave = getIsProjectSave(downloadItem); + const itemPath = downloadItem.getFilename(); const baseName = path.basename(itemPath); const extName = path.extname(baseName); const options = { @@ -206,22 +263,51 @@ const createMainWindow = () => { options.filters = [getFilterForExtension(extNameNoDot)]; } const userChosenPath = dialog.showSaveDialogSync(window, options); + // this will be falsy if the user canceled the save if (userChosenPath) { + const userBaseName = path.basename(userChosenPath); + const tempPath = path.join(app.getPath('temp'), userBaseName); + // WARNING: `setSavePath` on this item is only valid during the `will-download` event. Calling the async // version of `showSaveDialog` means the event will finish before we get here, so `setSavePath` will be // ignored. For that reason we need to call `showSaveDialogSync` above. - item.setSavePath(userChosenPath); - if (isProjectSave) { - const newProjectTitle = path.basename(userChosenPath, extName); - webContents.send('setTitleFromSave', {title: newProjectTitle}); - - // "setTitleFromSave" will set the project title but GUI has already reported the telemetry event - // using the old title. This call lets the telemetry client know that the save was actually completed - // and the event should be committed to the event queue with this new title. - telemetry.projectSaveCompleted(newProjectTitle); - } + downloadItem.setSavePath(tempPath); + + downloadItem.on('done', async (doneEvent, doneState) => { + try { + if (doneState !== 'completed') { + // The download was canceled or interrupted. Cancel the telemetry event and delete the file. + throw new Error(`save ${doneState}`); // "save cancelled" or "save interrupted" + } + await fs.move(tempPath, userChosenPath, {overwrite: true}); + if (isProjectSave) { + const newProjectTitle = path.basename(userChosenPath, extName); + webContents.send('setTitleFromSave', {title: newProjectTitle}); + + // "setTitleFromSave" will set the project title but GUI has already reported the telemetry + // event using the old title. This call lets the telemetry client know that the save was + // actually completed and the event should be committed to the event queue with this new title. + telemetry.projectSaveCompleted(newProjectTitle); + } + } catch (e) { + if (isProjectSave) { + telemetry.projectSaveCanceled(); + } + // don't clean up until after the message box to allow troubleshooting / recovery + await dialog.showMessageBox(window, { + type: 'error', + message: `Save failed:\n${userChosenPath}`, + detail: e.message + }); + fs.exists(tempPath).then(exists => { + if (exists) { + fs.unlink(tempPath); + } + }); + } + }); } else { - item.cancel(); + downloadItem.cancel(); if (isProjectSave) { telemetry.projectSaveCanceled(); } @@ -281,6 +367,14 @@ if (process.platform === 'win32') { // create main BrowserWindow when electron is ready app.on('ready', () => { + protocol.interceptFileProtocol('file', (request, callback) => { + const filePath = request.url.replace('file://', ''); + const url = request.url.includes('static/assets') ? path.normalize(`${__dirname}/${filePath}`) : filePath; + console.log(request.url, url); + callback({ path: url }); + }, err => { + if (err) console.error('Failed to register protocol'); + }); if (isDevelopment) { import('electron-devtools-installer').then(importedModule => { const {default: installExtension, ...devToolsExtensions} = importedModule; @@ -313,8 +407,44 @@ app.on('ready', () => { globalShortcut.register('CommandOrControl+Alt+D', () => { _windows.main.webContents.openDevTools({mode: 'detach', activate: true}); }); + + _windows.privacy = createPrivacyWindow(); + _windows.privacy.on('close', event => { + event.preventDefault(); + _windows.privacy.hide(); + }); }); ipcMain.on('open-about-window', () => { _windows.about.show(); }); + +ipcMain.on('open-privacy-policy-window', () => { + _windows.privacy.show(); +}); + +// start loading initial project data before the GUI needs it so the load seems faster +const initialProjectDataPromise = (async () => { + if (argv._.length === 0) { + // no command line argument means no initial project data + return; + } + if (argv._.length > 1) { + log.warn(`Expected 1 command line argument but received ${argv._.length}.`); + } + const projectPath = argv._[argv._.length - 1]; + try { + const projectData = await promisify(fs.readFile)(projectPath, null); + return projectData; + } catch (e) { + dialog.showMessageBox(_windows.main, { + type: 'error', + title: 'Failed to load project', + message: `Could not load project from file:\n${projectPath}`, + detail: e.message + }); + } + // load failed: initial project data undefined +})(); // IIFE + +ipcMain.handle('get-initial-project-data', () => initialProjectDataPromise); diff --git a/src/renderer/ScratchDesktopAppStateHOC.jsx b/src/renderer/ScratchDesktopAppStateHOC.jsx new file mode 100644 index 0000000..13a7905 --- /dev/null +++ b/src/renderer/ScratchDesktopAppStateHOC.jsx @@ -0,0 +1,53 @@ +import {ipcRenderer} from 'electron'; +import bindAll from 'lodash.bindall'; +import React from 'react'; + +/** + * Higher-order component to add desktop logic to AppStateHOC. + * @param {Component} WrappedComponent - an AppStateHOC-like component to wrap. + * @returns {Component} - a component similar to AppStateHOC with desktop-specific logic added. + */ +const ScratchDesktopAppStateHOC = function (WrappedComponent) { + class ScratchDesktopAppStateComponent extends React.Component { + constructor (props) { + super(props); + bindAll(this, [ + 'handleTelemetryModalOptIn', + 'handleTelemetryModalOptOut' + ]); + this.state = { + // use `sendSync` because this should be set before first render + telemetryDidOptIn: ipcRenderer.sendSync('getTelemetryDidOptIn') + }; + } + handleTelemetryModalOptIn () { + ipcRenderer.send('setTelemetryDidOptIn', true); + ipcRenderer.invoke('getTelemetryDidOptIn').then(telemetryDidOptIn => { + this.setState({telemetryDidOptIn}); + }); + } + handleTelemetryModalOptOut () { + ipcRenderer.send('setTelemetryDidOptIn', false); + ipcRenderer.invoke('getTelemetryDidOptIn').then(telemetryDidOptIn => { + this.setState({telemetryDidOptIn}); + }); + } + render () { + const shouldShowTelemetryModal = (typeof ipcRenderer.sendSync('getTelemetryDidOptIn') !== 'boolean'); + + return (); + } + } + + return ScratchDesktopAppStateComponent; +}; + +export default ScratchDesktopAppStateHOC; diff --git a/src/renderer/ScratchDesktopGUIHOC.jsx b/src/renderer/ScratchDesktopGUIHOC.jsx new file mode 100644 index 0000000..2ace94d --- /dev/null +++ b/src/renderer/ScratchDesktopGUIHOC.jsx @@ -0,0 +1,175 @@ +import {ipcRenderer, remote} from 'electron'; +import bindAll from 'lodash.bindall'; +import omit from 'lodash.omit'; +import PropTypes from 'prop-types'; +import React from 'react'; +import {connect} from 'react-redux'; +import GUIComponent from 'clipcc-gui/src/components/gui/gui.jsx'; + +import { + LoadingStates, + onFetchedProjectData, + onLoadedProject, + defaultProjectId, + requestNewProject, + requestProjectUpload, + setProjectId +} from 'clipcc-gui/src/reducers/project-state'; +import { + openLoadingProject, + closeLoadingProject, + openTelemetryModal +} from 'clipcc-gui/src/reducers/modals'; + +import ElectronStorageHelper from '../common/ElectronStorageHelper'; + +import showPrivacyPolicy from './showPrivacyPolicy'; + +/** + * Higher-order component to add desktop logic to the GUI. + * @param {Component} WrappedComponent - a GUI-like component to wrap. + * @returns {Component} - a component similar to GUI with desktop-specific logic added. + */ +const ScratchDesktopGUIHOC = function (WrappedComponent) { + class ScratchDesktopGUIComponent extends React.Component { + constructor (props) { + super(props); + bindAll(this, [ + 'handleProjectTelemetryEvent', + 'handleSetTitleFromSave', + 'handleStorageInit', + 'handleUpdateProjectTitle' + ]); + this.props.onLoadingStarted(); + ipcRenderer.invoke('get-initial-project-data').then(initialProjectData => { + const hasInitialProject = initialProjectData && (initialProjectData.length > 0); + this.props.onHasInitialProject(hasInitialProject, this.props.loadingState); + if (!hasInitialProject) { + this.props.onLoadingCompleted(); + return; + } + this.props.vm.loadProject(initialProjectData).then( + () => { + this.props.onLoadingCompleted(); + this.props.onLoadedProject(this.props.loadingState, true); + }, + e => { + this.props.onLoadingCompleted(); + this.props.onLoadedProject(this.props.loadingState, false); + remote.dialog.showMessageBox(remote.getCurrentWindow(), { + type: 'error', + title: 'Failed to load project', + message: 'Invalid or corrupt project file.', + detail: e.message + }); + + // this effectively sets the default project ID + // TODO: maybe setting the default project ID should be implicit in `requestNewProject` + this.props.onHasInitialProject(false, this.props.loadingState); + + // restart as if we didn't have an initial project to load + this.props.onRequestNewProject(); + } + ); + }); + } + componentDidMount () { + ipcRenderer.on('setTitleFromSave', this.handleSetTitleFromSave); + } + componentWillUnmount () { + ipcRenderer.removeListener('setTitleFromSave', this.handleSetTitleFromSave); + } + handleClickAbout () { + ipcRenderer.send('open-about-window'); + } + handleProjectTelemetryEvent (event, metadata) { + ipcRenderer.send(event, metadata); + } + handleSetTitleFromSave (event, args) { + this.handleUpdateProjectTitle(args.title); + } + handleStorageInit (storageInstance) { + storageInstance.addHelper(new ElectronStorageHelper(storageInstance)); + } + handleUpdateProjectTitle (newTitle) { + this.setState({projectTitle: newTitle}); + } + render () { + const childProps = omit(this.props, Object.keys(ScratchDesktopGUIComponent.propTypes)); + + return ( this.handleClickAbout() + }, + { + title: 'Privacy Policy', + onClick: () => showPrivacyPolicy() + }, + { + title: 'Data Settings', + onClick: () => this.props.onTelemetrySettingsClicked() + } + ]} + onProjectTelemetryEvent={this.handleProjectTelemetryEvent} + onShowPrivacyPolicy={showPrivacyPolicy} + onStorageInit={this.handleStorageInit} + onUpdateProjectTitle={this.handleUpdateProjectTitle} + + // allow passed-in props to override any of the above + {...childProps} + />); + } + } + + ScratchDesktopGUIComponent.propTypes = { + loadingState: PropTypes.oneOf(LoadingStates), + onFetchedInitialProjectData: PropTypes.func, + onHasInitialProject: PropTypes.func, + onLoadedProject: PropTypes.func, + onLoadingCompleted: PropTypes.func, + onLoadingStarted: PropTypes.func, + onRequestNewProject: PropTypes.func, + onTelemetrySettingsClicked: PropTypes.func, + // using PropTypes.instanceOf(VM) here will cause prop type warnings due to VM mismatch + vm: GUIComponent.WrappedComponent.propTypes.vm + }; + const mapStateToProps = state => { + const loadingState = state.scratchGui.projectState.loadingState; + return { + loadingState: loadingState, + vm: state.scratchGui.vm + }; + }; + const mapDispatchToProps = dispatch => ({ + onLoadingStarted: () => dispatch(openLoadingProject()), + onLoadingCompleted: () => dispatch(closeLoadingProject()), + onHasInitialProject: (hasInitialProject, loadingState) => { + if (hasInitialProject) { + // emulate sb-file-uploader + return dispatch(requestProjectUpload(loadingState)); + } + + // `createProject()` might seem more appropriate but it's not a valid state transition here + // setting the default project ID is a valid transition from NOT_LOADED and acts like "create new" + return dispatch(setProjectId(defaultProjectId)); + }, + onFetchedInitialProjectData: (projectData, loadingState) => + dispatch(onFetchedProjectData(projectData, loadingState)), + onLoadedProject: (loadingState, loadSuccess) => { + const canSaveToServer = false; + return dispatch(onLoadedProject(loadingState, canSaveToServer, loadSuccess)); + }, + onRequestNewProject: () => dispatch(requestNewProject(false)), + onTelemetrySettingsClicked: () => dispatch(openTelemetryModal()) + }); + + return connect(mapStateToProps, mapDispatchToProps)(ScratchDesktopGUIComponent); +}; + +export default ScratchDesktopGUIHOC; diff --git a/src/renderer/about.css b/src/renderer/about.css new file mode 100644 index 0000000..43f9ce7 --- /dev/null +++ b/src/renderer/about.css @@ -0,0 +1,39 @@ +html, body { + background-color: #4D97FF; + color: white; + font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; + font-weight: bolder; +} + +a:active, a:hover, a:link, a:visited { + color: currentColor; +} + +a:active, a:hover { + filter: brightness(0.9); +} + +.aboutBox { + margin: 0; + position: absolute; + top: 50%; + left: 50%; + transform: translate(-50%, -50%); +} + +.aboutLogo { + max-width: 10rem; + max-height: 10rem; +} + +.aboutText { + margin: 1.5rem; +} + +.aboutDetails { + font-size: x-small; +} + +.aboutFooter { + font-size: small; +} diff --git a/src/renderer/about.jsx b/src/renderer/about.jsx index 8906fe3..204b829 100644 --- a/src/renderer/about.jsx +++ b/src/renderer/about.jsx @@ -1,43 +1,29 @@ import React from 'react'; -import ReactDOM from 'react-dom'; import {productName, version} from '../../package.json'; import logo from '../icon/ScratchDesktop.svg'; +import styles from './about.css'; -// TODO: localization? const AboutElement = () => ( -
+
{`${productName}
-

{productName}

-
Version {version}
- - { - ['Electron', 'Chrome'].map(component => { - const componentVersion = process.versions[component.toLowerCase()]; - return ; - }) - } -
{component}{componentVersion}
+
+

{productName}

+ Version {version} + + { + ['Electron', 'Chrome', 'Node'].map(component => { + const componentVersion = process.versions[component.toLowerCase()]; + return ; + }) + } +
{component}{componentVersion}
+
); -const appTarget = document.getElementById('app'); -ReactDOM.render(, appTarget); +export default ; diff --git a/src/renderer/app.jsx b/src/renderer/app.jsx index 81d3a7f..7e55fa3 100644 --- a/src/renderer/app.jsx +++ b/src/renderer/app.jsx @@ -1,132 +1,23 @@ -import {ipcRenderer, shell, remote} from 'electron'; -import fs from 'fs'; -import bindAll from 'lodash.bindall'; import React from 'react'; -import ReactDOM from 'react-dom'; import {compose} from 'redux'; import GUI, {AppStateHOC} from 'clipcc-gui'; -import ElectronStorageHelper from '../common/ElectronStorageHelper'; - +import ScratchDesktopAppStateHOC from './ScratchDesktopAppStateHOC.jsx'; +import ScratchDesktopGUIHOC from './ScratchDesktopGUIHOC.jsx'; import styles from './app.css'; -const defaultProjectId = 0; -const externalProjectId = -1; - -// override window.open so that it uses the OS's default browser, not an electron browser -window.open = function (url, target) { - if (target === '_blank') { - shell.openExternal(url); - } -}; -// Register "base" page view -// analytics.pageview('/'); - const appTarget = document.getElementById('app'); -appTarget.className = styles.app || 'app'; // TODO -document.body.appendChild(appTarget); +appTarget.className = styles.app || 'app'; GUI.setAppElement(appTarget); -const ScratchDesktopHOC = function (WrappedComponent) { - class ScratchDesktopComponent extends React.Component { - constructor (props) { - super(props); - bindAll(this, [ - 'handleProjectTelemetryEvent', - 'handleSetTitleFromSave', - 'handleStorageInit', - 'handleTelemetryModalOptIn', - 'handleTelemetryModalOptOut', - 'handleUpdateProjectTitle', - 'handleVmInit', - 'handleRef' - ]); - this.state = { - projectTitle: null - }; - } - componentDidMount () { - ipcRenderer.on('setTitleFromSave', this.handleSetTitleFromSave); - } - componentWillUnmount () { - ipcRenderer.removeListener('setTitleFromSave', this.handleSetTitleFromSave); - } - handleClickLogo () { - ipcRenderer.send('open-about-window'); - } - handleProjectTelemetryEvent (event, metadata) { - ipcRenderer.send(event, metadata); - } - handleSetTitleFromSave (event, args) { - this.handleUpdateProjectTitle(args.title); - } - handleStorageInit (storageInstance) { - storageInstance.addHelper(new ElectronStorageHelper(storageInstance)); - } - handleTelemetryModalOptIn () { - ipcRenderer.send('setTelemetryDidOptIn', true); - } - handleTelemetryModalOptOut () { - ipcRenderer.send('setTelemetryDidOptIn', false); - } - handleUpdateProjectTitle (newTitle) { - this.setState({projectTitle: newTitle}); - } - handleVmInit (vm) { - const argv = remote.getGlobal('sharedObject').argv; - if (argv.length > 1 && argv[1]) { - this.gui.props.onLoadingStarted(); - fs.readFile(argv[1], (err, data) => { - if (err) { - this.gui.props.onLoadingFinished(this.gui.props.loadingState, false); - } else { - vm.loadProject(data) - .then(() => { - this.gui.props.onLoadingFinished(this.gui.props.loadingState, true); - }) - .catch(error => { - console.warn(error); - this.gui.props.onLoadingFinished(this.gui.props.loadingState, false); - }); - } - }); - } - } - handleRef (gui) { - this.gui = gui; - } - render () { - const shouldLoadExternalProject = remote.getGlobal('sharedObject').argv.length > 1; - const shouldShowTelemetryModal = (typeof ipcRenderer.sendSync('getTelemetryDidOptIn') !== 'boolean'); - return (); - } - } - - return ScratchDesktopComponent; -}; - // note that redux's 'compose' function is just being used as a general utility to make // the hierarchy of HOC constructor calls clearer here; it has nothing to do with redux's // ability to compose reducers. const WrappedGui = compose( - ScratchDesktopHOC, - AppStateHOC + ScratchDesktopAppStateHOC, + AppStateHOC, + ScratchDesktopGUIHOC )(GUI); -ReactDOM.render(, appTarget); +export default ; diff --git a/src/renderer/index.html b/src/renderer/index.html index a9665fa..7efeb1d 100644 --- a/src/renderer/index.html +++ b/src/renderer/index.html @@ -20,6 +20,6 @@ -

Scratch Desktop is loading...

+

Scratch is loading...

diff --git a/src/renderer/index.js b/src/renderer/index.js index 49915ad..c0609b7 100644 --- a/src/renderer/index.js +++ b/src/renderer/index.js @@ -1,12 +1,33 @@ -// this is an async import so that it doesn't block the first render -// index.html contains a loading/splash screen which will display while this import loads +// This file does async imports of the heavy JSX, especially app.jsx, to avoid blocking the first render. +// The main index.html just contains a loading/splash screen which will display while this import loads. + +import {ipcRenderer} from 'electron'; + +import ReactDOM from 'react-dom'; + +ipcRenderer.on('ready-to-show', () => { + // Start without any element in focus, otherwise the first link starts with focus and shows an orange box. + // We shouldn't disable that box or the focus behavior in case someone wants or needs to navigate that way. + // This seems like a hack... maybe there's some better way to do avoid any element starting with focus? + document.activeElement.blur(); +}); const route = new URLSearchParams(window.location.search).get('route') || 'app'; +let routeModulePromise; switch (route) { case 'app': - import('./app.jsx'); // eslint-disable-line no-unused-expressions + routeModulePromise = import('./app.jsx'); break; case 'about': - import('./about.jsx'); // eslint-disable-line no-unused-expressions + routeModulePromise = import('./about.jsx'); + break; +case 'privacy': + routeModulePromise = import('./privacy.jsx'); break; } + +routeModulePromise.then(routeModule => { + const appTarget = document.getElementById('app'); + const routeElement = routeModule.default; + ReactDOM.render(routeElement, appTarget); +}); diff --git a/src/renderer/privacy.css b/src/renderer/privacy.css new file mode 100644 index 0000000..a40fb4f --- /dev/null +++ b/src/renderer/privacy.css @@ -0,0 +1,14 @@ +html, body { + background-color: #4D97FF; + color: white; + font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; + font-weight: normal; + line-height: 150%; +} + +.privacyBox { + background-color: white; + color: #575e75; + margin: 3rem; + padding: 2rem 3rem; +} diff --git a/src/renderer/privacy.jsx b/src/renderer/privacy.jsx new file mode 100644 index 0000000..ac7aaf0 --- /dev/null +++ b/src/renderer/privacy.jsx @@ -0,0 +1,235 @@ +import React from 'react'; + +import styles from './privacy.css'; + +const PrivacyElement = () => ( +
+

Privacy Policy

+ The Scratch Privacy Policy was last updated: October 5, 2020 +

+ The Scratch Foundation (“Scratch”, “we” or “us”) understands how + important privacy is to our community. We wrote this Privacy Policy to explain what Personal Information + (“Information”) we collect through our offline editor (the “Scratch App”), how we use, process, and share it, and what we're doing to keep it safe. It + also tells you about your rights and choices with respect to your Personal Information, and how you can contact us if you have any questions or concerns. +

+

What Information Does Scratch Collect About Me?

+

+ For the purpose of this Privacy Policy, “Information” means any information relating to an + identified or identifiable individual. The Scratch App automatically collects and stores locally the + following Information through its telemetry system: the title of your project in text form, language + setting, time zone and events related to your use of the Scratch App (namely when the Scratch App was + opened and closed, if a project file has been loaded or saved, or if a new project is created). If you + choose to turn on the telemetry sharing feature, the Scratch App will transmit this information to Scratch. + Projects created in the Scratch App are not transmitted to or accessible by Scratch. +

+

How Does Scratch Use My Information?

+

We use this Information for the following purposes:

+
    +
  • + Analytics and Improving the Scratch App - We use the Information to analyze use of the Scratch + App and to enhance your learning experience on the Scratch App. +
  • +
  • + Academic and Scientific Research - We de-identify and aggregate Information for statistical + analysis in the context of scientific and academic research. For example, to help us understand how + people learn through the Scratch App and how we can enhance learning tools for young people. The + results of such research are shared with educators and researchers through conferences, journals, and + other academic or scientific publications. You can find out more on our Research page. +
  • +
  • + Legal - We may use your Information to enforce our Terms of Use, to defend our legal rights, and to comply with our legal obligations and internal + policies. We may do this by analyzing your use of the Scratch App. +
  • +
+

What Are The Legal Grounds For Processing Your Information?

+

+ If you are located in the European Economic Area, the United Kingdom or Switzerland, we only process your + Information based on a valid legal ground. A “legal ground” is a reason that justifies our use + of your Information. In this case, we or a third party have a legitimate interest in using your Information + (if you choose to allow the Scratch App to send the Scratch team your Information) to create, analyze and + share your aggregated or de-identified Information for research purposes, to analyze and enhance your + learning experience on the Scratch App and otherwise ensure and improve the safety, security, and + performance of the Scratch App. We only rely on our or a third party’s legitimate interests to process your + Information when these interests are not overridden by your rights and interests. +

+

How Does Scratch Share My Information?

+

+ We disclose information that we collect through the Scratch App to third parties in the following + circumstances: +

+
    +
  • + Service Providers - To third parties who provide services such as website hosting, data + analysis, Information technology and related infrastructure provisions, customer service, email + delivery, and other services. +
  • +
  • + Academic and Scientific Research - To research institutions, such as the Massachusetts Institute + of Technology (MIT), to learn about how our users learn through the Scratch App and develop new + learning tools. The results of this research or the statistical analysis may be shared through + conferences, journals, and other publications. +
  • +
  • + Merger - To a potential or actual acquirer, successor, or assignee as part of any + reorganization, merger, sale, joint venture, assignment, transfer, or other disposition of all or any + portion of our organization or assets. You will have the opportunity to opt out of any such transfer if + the new entity's planned processing of your Information differs materially from that set forth in + this Privacy Policy. +
  • +
  • + Legal - If required to do so by law or in the good faith belief that such action is appropriate: + (a) under applicable law, including laws outside your country of residence; (b) to comply with legal + process; (c) to respond to requests from public and government authorities, such as school, school + districts, and law enforcement, including public and government authorities outside your country of + residence; (d) to enforce our terms and conditions; (e) to protect our operations or those of any of + our affiliates; (f) to protect our rights, privacy, safety, or property, and/or that of our affiliates, + you, or others; and (g) to allow us to pursue available remedies or limit the damages that we may + sustain. +
  • +
+

Children and Student Privacy

+

+ The Scratch Foundation is a 501(c)(3) nonprofit organization. As such, the Children's Online Privacy + Protection Act (COPPA) does not apply to Scratch. Nevertheless, Scratch takes children's privacy + seriously. Scratch collects only minimal information from its users, and only uses and discloses + information to provide the services and for limited other purposes, such as research, as described in this + Privacy Policy. +

+

+ Scratch does not collect information from a student's education record, as defined by the Family + Educational Rights and Privacy Act (FERPA). Scratch does not disclose information of students to any third + parties except as described in this Privacy Policy. +

+

Your Data Protection Rights (EEA)

+

+ If you are located in the European Economic Area, the United Kingdom or Switzerland, you have certain + rights in relation to your Information: +

+
    +
  • + Access, Correction and Data Portability - You may ask for an overview of the Information we + process about you and to receive a copy of your Information. You also have the right to request to + correct incomplete, inaccurate or outdated Information. To the extent required by applicable law, you + may request us to provide your Information to another company. +
  • +
  • + Objection – You may object to (this means “ask us to stop”) any use of your + Information that is not (i) processed to comply with a legal obligation, (ii) necessary to do what is + provided in a contract between Scratch and you, or (iii) if we have a compelling reason to do so (such + as, to ensure safety and security in our online community). If you do object, we will work with you to + find a reasonable solution. +
  • +
  • + Deletion - You may also request the deletion of your Information, as permitted under applicable + law. This applies, for instance, where your Information is outdated or the processing is not necessary + or is unlawful; where you withdraw your consent to our processing based on such consent; or where you + have objected to our processing. In some situations, we may need to retain your Information due to + legal obligations or for litigation purposes. If you want to have all of your Information removed from + our servers, please contact help@scratch.mit.edu for assistance. +
  • +
  • + Restriction Of Processing - You may request that we restrict processing of your Information + while we are processing a request relating to (i) the accuracy of your Information, (ii) the lawfulness + of the processing of your Information, or (iii) our legitimate interests to process this Information. + You may also request that we restrict processing of your Information if you wish to use the Information + for litigation purposes. +
  • +
  • + Withdrawal Of Consent – Where we rely on consent for the processing of your Information, you + have the right to withdraw it at any time and free of charge. When you do so, this will not affect the + lawfulness of the processing before your consent withdrawal. +
  • +
+

+ In addition to the above-mentioned rights, you also have the right to lodge a complaint with a competent + supervisory authority subject to applicable law. However, there are exceptions and limitations to each of + these rights. We may, for example, refuse to act on a request if the request is manifestly unfounded or + excessive, or if the request is likely to adversely affect the rights and freedoms of others, prejudice the + execution or enforcement of the law, interfere with pending or future litigation, or infringe applicable + law. To submit a request to exercise your rights, please contact help@scratch.mit.edu for assistance. +

+

Data Retention

+

+ We take measures to delete your Information or keep it in a form that does not allow you to be identified + when this Information is no longer necessary for the purposes for which we process it, unless we are + required by law to keep this Information for a longer period. When determining the retention period, we + take into account various criteria, such as the type of services requested by or provided to you, the + nature and length of our relationship with you, possible re-enrollment with our services, the impact on the + services we provide to you if we delete some Information from or about you, mandatory retention periods + provided by law and the statute of limitations. +

+

How Does Scratch Protect My Information?

+

+ Scratch has in place administrative, physical, and technical procedures that are intended to protect the + Information we collect on the Scratch App against accidental or unlawful destruction, accidental loss, + unauthorized alteration, unauthorized disclosure or access, misuse, and any other unlawful form of + processing of the Information. However, as effective as these measures are, no security system is + impenetrable. We cannot completely guarantee the security of our databases, nor can we guarantee that the + Information you supply will not be intercepted while being transmitted to us over the Internet. +

+

International Data Transfer

+

+ We may transfer your Information to countries other than the country where you are located, including to + the U.S. (where our Scratch servers are located) or any other country in which we or our service providers + maintain facilities. If you are located in the European Economic Area, the United Kingdom or Switzerland, + or other regions with laws governing data collection and use that may differ from U.S. law, please note + that we may transfer your Information to a country and jurisdiction that does not have the same data + protection laws as your jurisdiction. We apply appropriate safeguards to the Information processed and + transferred on our behalf. Please contact us for more information on the safeguards used. +

+

Notifications Of Changes To The Privacy Policy

+

+ We review our Privacy Policy on a periodic basis, and we may modify our policies as appropriate. We will + notify you of any material changes. We encourage you to review our Privacy Policy on a regular basis. The + “Last Updated” date at the top of this page indicates when this Privacy Policy was last + revised. Your continued use of the Scratch App following these changes means that you accept the revised + Privacy Policy. +

+

Contact Us

+

+ The Scratch Foundation is the entity responsible for the processing of your Information. If you have any + questions about this Privacy Policy, or if you would like to exercise your rights to your Information, you + may contact us at help@scratch.mit.edu or via mail at: +

+
+
Scratch Foundation
+
ATTN: Privacy Policy
+
+
201 South Street
+ Boston, MA 02111 +
+
+
+); + +export default ; diff --git a/src/renderer/showPrivacyPolicy.js b/src/renderer/showPrivacyPolicy.js new file mode 100644 index 0000000..5f4371c --- /dev/null +++ b/src/renderer/showPrivacyPolicy.js @@ -0,0 +1,13 @@ +import {ipcRenderer} from 'electron'; + +const showPrivacyPolicy = event => { + if (event) { + // Probably a click on a link; don't actually follow the link in the `href` attribute. + event.preventDefault(); + } + // tell the main process to open the privacy policy window + ipcRenderer.send('open-privacy-policy-window'); + return false; +}; + +export default showPrivacyPolicy; diff --git a/webpack.main.additions.js b/webpack.main.additions.js deleted file mode 100644 index 96a8ceb..0000000 --- a/webpack.main.additions.js +++ /dev/null @@ -1,11 +0,0 @@ -const path = require('path'); - -const makeConfig = require('./webpack.makeConfig.js'); - -module.exports = makeConfig({ - name: 'main', - useReact: false, - babelPaths: [ - path.resolve(__dirname, 'src', 'main') - ] -}); diff --git a/webpack.main.js b/webpack.main.js new file mode 100644 index 0000000..776071a --- /dev/null +++ b/webpack.main.js @@ -0,0 +1,16 @@ +const path = require('path'); + +const makeConfig = require('./webpack.makeConfig.js'); + +module.exports = defaultConfig => + makeConfig( + defaultConfig, + { + name: 'main', + useReact: false, + disableDefaultRulesForExtensions: ['js'], + babelPaths: [ + path.resolve(__dirname, 'src', 'main') + ] + } + ); diff --git a/webpack.makeConfig.js b/webpack.makeConfig.js index 0e1db69..3218786 100644 --- a/webpack.makeConfig.js +++ b/webpack.makeConfig.js @@ -1,17 +1,23 @@ const childProcess = require('child_process'); +const fs = require('fs'); +const path = require('path'); +const util = require('util'); const electronPath = require('electron'); const webpack = require('webpack'); +const merge = require('webpack-merge'); + +// PostCss +const autoprefixer = require('autoprefixer'); +const postcssVars = require('postcss-simple-vars'); +const postcssImport = require('postcss-import'); const isProduction = (process.env.NODE_ENV === 'production'); const electronVersion = childProcess.execSync(`${electronPath} --version`, {encoding: 'utf8'}).trim(); console.log(`Targeting Electron ${electronVersion}`); // eslint-disable-line no-console -const makeConfig = function (options) { - // eslint-disable-next-line no-console - console.log(`Module "${options.name}" building in production mode? ${isProduction}`); - +const makeConfig = function (defaultConfig, options) { const babelOptions = { // Explicitly disable babelrc so we don't catch various config in much lower dependencies. babelrc: false, @@ -33,30 +39,68 @@ const makeConfig = function (options) { }]); } - return { + // TODO: consider adjusting these rules instead of discarding them in at least some cases + if (options.disableDefaultRulesForExtensions) { + defaultConfig.module.rules = defaultConfig.module.rules.filter(rule => { + if (!(rule.test instanceof RegExp)) { + // currently we don't support overriding other kinds of rules + return true; + } + // disable default rules for any file extension listed here + // we will handle these files in some other way (see below) + // OR we want to avoid any processing at all (such as with fonts) + const shouldDisable = options.disableDefaultRulesForExtensions.some( + ext => rule.test.test(`test.${ext}`) + ); + const statusWord = shouldDisable ? 'Discarding' : 'Keeping'; + console.log(`${options.name}: ${statusWord} electron-webpack default rule for ${rule.test}`); + return !shouldDisable; + }); + } + + const config = merge.smart(defaultConfig, { devtool: 'cheap-module-eval-source-map', mode: isProduction ? 'production' : 'development', module: { rules: [ - // Override the *.js defaults from electron-webpack - // The test/include/exclude must match the defaults exactly for webpack-merge to do the override - { - test: /\.js$/, - exclude: /(node_modules|bower_components)/, - loader: 'babel-loader', - options: babelOptions - }, - // Add a new rule for the other files we want to run through babel { test: sourceFileTest, include: options.babelPaths, loader: 'babel-loader', options: babelOptions }, + { // coped from scratch-gui + test: /\.css$/, + use: [{ + loader: 'style-loader' + }, { + loader: 'css-loader', + options: { + modules: true, + importLoaders: 1, + localIdentName: '[name]_[local]_[hash:base64:5]', + camelCase: true + } + }, { + loader: 'postcss-loader', + options: { + ident: 'postcss', + plugins: function () { + return [ + postcssImport, + postcssVars, + autoprefixer + ]; + } + } + }] + }, { - test: sourceFileTest, - loader: 'source-map-loader', - enforce: 'pre' + test: /\.(svg|png|wav|gif|jpg)$/, + loader: 'file-loader', + options: { + outputPath: 'static/assets/' + } } ] }, @@ -67,9 +111,27 @@ const makeConfig = function (options) { ].concat(options.plugins || []), resolve: { cacheWithContext: false, - symlinks: false + symlinks: false, + alias: { + // act like scratch-gui has this line in its package.json: + // "browser": "./src/index.js" + 'clipcc-gui$': path.resolve(__dirname, 'node_modules', 'clipcc-gui', 'src', 'index.js') + } } - }; + }); + + // If we're not on CI, enable Webpack progress output + // Note that electron-webpack enables this by default, so use '--no-progress' to avoid double-adding this plugin + if (!process.env.CI) { + config.plugins.push(new webpack.ProgressPlugin()); + } + + fs.writeFileSync( + `dist/webpack.${options.name}.js`, + `module.exports = ${util.inspect(config, {depth: null})};\n` + ); + + return config; }; module.exports = makeConfig; diff --git a/webpack.renderer.js b/webpack.renderer.js new file mode 100644 index 0000000..86bd9ca --- /dev/null +++ b/webpack.renderer.js @@ -0,0 +1,39 @@ +const path = require('path'); + +const CopyWebpackPlugin = require('copy-webpack-plugin'); + +const makeConfig = require('./webpack.makeConfig.js'); + +const getModulePath = moduleName => path.dirname(require.resolve(`${moduleName}/package.json`)); + +module.exports = defaultConfig => + makeConfig( + defaultConfig, + { + name: 'renderer', + useReact: true, + disableDefaultRulesForExtensions: ['js', 'jsx', 'css', 'svg', 'png', 'wav', 'gif', 'jpg', 'ttf'], + babelPaths: [ + path.resolve(__dirname, 'src', 'renderer'), + /node_modules[\\/]+scratch-[^\\/]+[\\/]+src/, + /node_modules[\\/]+clipcc-[^\\/]+[\\/]+src/, + /node_modules[\\/]+pify/, + /node_modules[\\/]+@vernier[\\/]+godirect/ + ], + plugins: [ + new CopyWebpackPlugin([{ + from: path.join(getModulePath('clipcc-blocks'), 'media'), + to: 'static/blocks-media' + }]), + new CopyWebpackPlugin([{ + from: 'extension-worker.{js,js.map}', + context: path.join(getModulePath('clipcc-vm'), 'dist', 'web') + }]), + new CopyWebpackPlugin([{ + from: path.join(getModulePath('clipcc-gui'), 'src', 'lib', 'libraries', '*.json'), + to: 'static/libraries', + flatten: true + }]) + ] + } + );