You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
{{ message }}
This repository was archived by the owner on Jun 20, 2024. It is now read-only.
To use this library as a web app, import the usage_html.dart library and
instantiate the AnalyticsHtml class.
For Flutter apps
Flutter applications can use the AnalyticsIO version of this library. They will need
to specify the documents directory in the constructor in order to tell the library where
to save the analytics preferences:
To use this library as a command-line app, import the usage_io.dart library
and instantiate the AnalyticsIO class.
Note, for CLI apps, the usage library will send analytics pings asynchronously.
This is useful in that it doesn't block the app generally. It does have one
side-effect, in that outstanding asynchronous requests will block termination
of the VM until that request finishes. So, for short-lived CLI tools, pinging
Google Analytics can cause the tool to pause for several seconds before it
terminates. This is often undesired - gathering analytics information shouldn't
negatively effect the tool's UX.
One solution to this is to use the waitForLastPing({Duration timeout}) method
on the analytics object. This will wait until all outstanding analytics requests
have completed, or until the specified duration has elapsed. So, CLI apps can do
something like:
You can use this library in an opt-in manner or an opt-out one. It defaults to
opt-out - data will be sent to Google Analytics unless the user explicitly
opts-out. The mode can be adjusted by changing the value of the
Analytics.analyticsOpt field.
Opt-out In opt-out mode, if the user does not explicitly opt-out of collecting
analytics, the usage library will send usage data.
Opt-in In opt-in mode, no data will be sent until the user explicitly opt-in
to collection. This includes screen views, events, timing information, and exceptions.
Other info
For both classes, you need to provide a Google Analytics tracking ID, the
application name, and the application version.
Note: This library is intended for use with the Google Analytics application /
mobile app style tracking IDs (as opposed to the web site style tracking IDs).
For more information, please see the Google Analytics Measurement Protocol
Policy.
Contributing
Tests can be run using pub run test.
About
A Google Analytics wrapper for command-line, web, and Flutter apps.