mirror of
https://github.com/scratchfoundation/scratch-desktop.git
synced 2025-01-09 22:22:34 -05:00
Hook up telemetry opt-in/out modal
This commit is contained in:
parent
30cafbf508
commit
64da5dff27
4 changed files with 32 additions and 5 deletions
|
@ -1,3 +1,5 @@
|
||||||
|
import {ipcMain} from 'electron';
|
||||||
|
|
||||||
import TelemetryClient from './telemetry/TelemetryClient';
|
import TelemetryClient from './telemetry/TelemetryClient';
|
||||||
|
|
||||||
const info = {
|
const info = {
|
||||||
|
@ -17,6 +19,13 @@ class ScratchDesktopTelemetry {
|
||||||
this._telemetryClient = new TelemetryClient();
|
this._telemetryClient = new TelemetryClient();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get didOptIn () {
|
||||||
|
return this._telemetryClient.didOptIn;
|
||||||
|
}
|
||||||
|
set didOptIn (value) {
|
||||||
|
this._telemetryClient.didOptIn = value;
|
||||||
|
}
|
||||||
|
|
||||||
appWasOpened () {
|
appWasOpened () {
|
||||||
this._telemetryClient.addEvent('app::open', info);
|
this._telemetryClient.addEvent('app::open', info);
|
||||||
}
|
}
|
||||||
|
@ -42,4 +51,14 @@ class ScratchDesktopTelemetry {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export default ScratchDesktopTelemetry;
|
// make a singleton so it's easy to share across both Electron processes
|
||||||
|
const scratchDesktopTelemetrySingleton = new ScratchDesktopTelemetry();
|
||||||
|
|
||||||
|
ipcMain.on('getTelemetryDidOptIn', event => {
|
||||||
|
event.returnValue = scratchDesktopTelemetrySingleton.didOptIn;
|
||||||
|
});
|
||||||
|
ipcMain.on('setTelemetryDidOptIn', (event, arg) => {
|
||||||
|
scratchDesktopTelemetrySingleton.didOptIn = arg;
|
||||||
|
});
|
||||||
|
|
||||||
|
export default scratchDesktopTelemetrySingleton;
|
||||||
|
|
|
@ -1,9 +1,8 @@
|
||||||
import {BrowserWindow, app, dialog} from 'electron';
|
import {BrowserWindow, app, dialog} from 'electron';
|
||||||
import * as path from 'path';
|
import * as path from 'path';
|
||||||
import {format as formatUrl} from 'url';
|
import {format as formatUrl} from 'url';
|
||||||
import ScratchDesktopTelemetry from './ScratchDesktopTelemetry';
|
import telemetry from './ScratchDesktopTelemetry';
|
||||||
|
|
||||||
const telemetry = new ScratchDesktopTelemetry();
|
|
||||||
telemetry.appWasOpened();
|
telemetry.appWasOpened();
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -132,7 +132,8 @@ class TelemetryClient {
|
||||||
* @type {boolean}
|
* @type {boolean}
|
||||||
*/
|
*/
|
||||||
get didOptIn () {
|
get didOptIn () {
|
||||||
return this._store.get('optIn', false);
|
// don't supply a default here: we want to track "opt out" separately from "undecided"
|
||||||
|
return this._store.get('optIn');
|
||||||
}
|
}
|
||||||
set didOptIn (value) {
|
set didOptIn (value) {
|
||||||
this._store.set('optIn', !!value);
|
this._store.set('optIn', !!value);
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
import {ipcRenderer} from 'electron';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import ReactDOM from 'react-dom';
|
import ReactDOM from 'react-dom';
|
||||||
import GUI, {AppStateHOC} from 'scratch-gui';
|
import GUI, {AppStateHOC} from 'scratch-gui';
|
||||||
|
@ -42,7 +43,14 @@ const onStorageInit = storageInstance => {
|
||||||
const guiProps = {
|
const guiProps = {
|
||||||
onStorageInit,
|
onStorageInit,
|
||||||
isScratchDesktop: true,
|
isScratchDesktop: true,
|
||||||
projectId: defaultProjectId
|
projectId: defaultProjectId,
|
||||||
|
showTelemetryModal: (typeof ipcRenderer.sendSync('getTelemetryDidOptIn')) !== 'boolean',
|
||||||
|
onTelemetryModalOptIn: () => {
|
||||||
|
ipcRenderer.send('setTelemetryDidOptIn', true);
|
||||||
|
},
|
||||||
|
onTelemetryModalOptOut: () => {
|
||||||
|
ipcRenderer.send('setTelemetryDidOptIn', false);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
const wrappedGui = React.createElement(WrappedGui, guiProps);
|
const wrappedGui = React.createElement(WrappedGui, guiProps);
|
||||||
ReactDOM.render(wrappedGui, appTarget);
|
ReactDOM.render(wrappedGui, appTarget);
|
||||||
|
|
Loading…
Reference in a new issue