This is a sciter.js package designed for in-app analytics.
The primary goal is to track user interactions within the application to gain insights that help enhance the overall user experience. By analyzing user behavior, we can optimize the app's functionality and design to better meet user needs.
Two types of events are recorded:
- events that are triggered by user actions (e.g. clicking a button)
- events that are triggered by the application (e.g. a page is loaded)
The following application analytics providers have been implemented:
- git clone the repository
- install packages
npm install - install the latest sciter sdk
npm run install-sdk - update the mixpanel project token or amplitude api key in
main.htm - start the demo
npm run scapp
- A recent version of Node.js
node(tested with 22 LTS) and its package managernpm.- On Windows download and run the installer
- On Linux check the installation guide
You can either add it to your project using npm or by copying the src directory.
- install package
npm install sciter-analytics
- add the
srcdir to your project
// using npm import Mixpanel from "node_modules/sciter-analytics/src/mixpanel.js"; import Amplitude from "node_modules/sciter-analytics/src/amplitude.js"; // copying src import Mixpanel from "src/mixpanel.js"; import Amplitude from "src/amplitude.js";const mixpanel = new Mixpanel({ // project token token: "c557e826f1a76aaa4ed02e4681f95ae4", // user unique id userId: Utils.uuid(), debug: true, }); // add user properties mixpanel.properties({ // reserved properties $name: "John Doe", $email: "john.doe@test.com", // custom properties address: "Some street", birthday: "1987-02-11", }); // log event mixpanel.event("App started"); // watch for event mixpanel.watch("focus", "plaintext", "plaintext focused"); // send data mixpanel.send();const amplitude = new Amplitude({ apikey: "0fad02b65a75f270c199db6b920fbf92", userId: Utils.randomStr(10), debug: true, eventProperties: { appName: "Sciter analytics", appRelease: "debug", }, }); amplitude.event("Start app"); // watch app close amplitude.watch("closerequest", undefined, "App close request"); // watch app install click amplitude.watch("click", "#installApp1", "Install app", { appName: "app 1", }); amplitude.watch("click", "#installApp2", "Install app", { appName: "app 2", }); amplitude.watch("click", "#installApp3", "Install app", { appName: "app 3", });- implement generic tracking class? and make conversion on server to mixpanel specific?
- implement proxy because we will be stuck if we plan to stop using mixpanel
- distinguish between users using the same ip - user account, computer name is not possible
- what to do when we have no user id? ask mixpanel to create it or we create it? if yes, how do we get it from mixpanel?
- mixpanel - what happens if id is not passed in constructor?
- add auto-send option