Before using this plugin, make sure you can get the official Greenworks plugin to work to debug any basic issues. If you only need the ACEs of the official plugin, there's no need to use this plugin
Motivation
In developing a C3 game for Steam distribution, I found I needed more API calls than the official plugin, so using the official plugin as a template, I added the ACEs for the following Greenworks APIs: Cloud File, more Achievements and Stats, DLC.
Reporting Issues
Please use the github issue list to report issues.
Installing steam_appid.txt
See the official Greenworks plugin documentation for a description of where to install steam_appid.txt after export to nw.js (only needed during local dev work, once uploaded to steam, no longer needed.)
Exporting and overlay
When exporting to nw.js, add the command lines '--in-process-gpu --disable-direct-composition --enable-features=nw2' in the export dialog box for windows overlay to work on Windows. Mac OS overlay with Greenworks appears to be buggy, do not expect it to work.
General usage
The plugin generally follows this pattern: Call action (API call), wait for trigger (API callback), check expressions for data or error, depending on the trigger. Some data which are relatively static are always available in expressions (language, userID, etc. from the original plugin.) The others require an action call and trigger before using the data. [Technical aside, this is due to the Greenworks API being called on the DOM side vs render side, so each call requires a JS promise/resolve/reject call.]
Debugging
Some obvious things to check for which I have hit more than once myself:
Electron
[efc no longer under active development]
I am also using Electron to build the final executable, so added support for Electron. See Armaldio's excellent ElectronForConstruct for a description of the process/tool that they created to support Construct with Electron. Once setup, the tool will download greenworks binaries for the version of Electron being used. Very useful tool!
Mac
- Once released on Steam and users install, the steam_appid.txt file is no longer needed.
For more Mac tips see: https://github.com/greenheartgames/greenworks/issues/183
Further Development
If you _really_ need a specific existing Greenworks API added to the plugin for your game release, leave an issue in the comments and I will review. Note: the Greenworks API does not support Steamworks leaderboards (a conscious decision on part of the Greenworks developers.)