Forked from the package matomo by poitch.
A fully cross-platform wrap of the Matomo tracking client for Flutter, using the Matomo Tracking API.
As early as possible in your application, you need to configure the Matomo Tracker to pass the URL endpoint of your instance and your Site ID.
await MatomoTracker.instance.initialize(
siteId: siteId,
url: 'https://example.com/matomo.php',
);
If you need to use your own Visitor ID, you can pass it at the initialization of MatomoTracker as is:
await MatomoTracker.instance.initialize(
siteId: siteId,
url: 'https://example.com/matomo.php',
visitorId: '2589631479517535',
);
To track views simply add TraceableClientMixin
on your State
:
class MyHomePage extends StatefulWidget {
const MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> with TraceableClientMixin {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(widget.title),
),
body: Center(
child: Text('Hello World!'),
),
);
}
@override
String get traceName => 'Created HomePage'; // optional
@override
String get traceTitle => widget.title;
}
If you are in a StatelessWidget
you can use the TraceableWidget
widget:
class MyHomePage extends StatelessWidget {
const MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
Widget build(BuildContext context) {
return TraceableWidget(
traceName: 'Created HomePage', // optional
traceTitle: title,
child: Scaffold(
appBar: AppBar(
title: Text(title),
),
body: Center(
child: Text('Hello World!'),
),
),
);
}
}
You can also optionally call directly trackScreen
or trackScreenWithName
to track a view.
For tracking goals and, events call trackGoal
and trackEvent
respectively.
A value can be passed for events:
MatomoTracker.instance.trackEvent(
name: 'eventName',
action: 'eventAction',
eventValue: 18,
);
If your application uses authentication and you wish to have your visitors including their specific identity to Matomo, you can use the Visitor property userId with any unique identifier from your back-end, by calling the setVisitorUserId() method. Here's an example on how to do it with Firebase:
String userId = auth.currentUser?.email ?? auth.currentUser!.uid;
MatomoTracker.instance.setVisitorUserId(userId);
If you want to offer a way for the user to opt out of analytics, you can use the setOptOut()
call.
MatomoTracker.instance.setOptOut(optout: true);
If you want to track Visit or Action dimensions you can either use the trackDimensions
(if
it's a Visit level dimension) or provide data in the optional dimensions param of trackEvent
(if it's an Action level dimension):
MatomoTracker.instance.trackDimensions({
'dimension1': '0.0.1'
});
MatomoTracker.instance.trackEvent(
name: 'eventName',
action: 'eventAction',
eventValue: 18,
dimensions: {'dimension2':'guest-user'}
);
You can similarly track dimensions on Screen views with:
MatomoTracker.instance.trackScreenWithName(
widgetName: "Settings",
eventName: "screen_view",
dimensions: {'dimension1': '0.0.1'}
);
If you want to use cookieless tracking, you can use the cookieless
property in the initialize
method.
await MatomoTracker.instance.initialize(
siteId: siteId,
url: 'https://example.com/matomo.php',
cookieless: true,
);
When using cookieless tracking, neither the user_id nor the first_visit will be sent or saved locally.
Now the initialize()
method takes a LocalStorage? localStorage
instead of a SharedPreferences? prefs
as its parameter to override the persistent data implementation.
By default it will use an implementation of shared_preferences with the class SharedPrefsStorage
, but you can provide your own implementation of LocalStorage
to use a different package.
final myPrefs = await SharedPreferences.getInstance();
await MatomoTracker.instance.initialize(
siteId: siteId,
url: 'https://example.com/matomo.php',
prefs: myPrefs,
);
class MyLocalStorage implements LocalStorage {
MyLocalStorage();
// ...
}
final myStorage = MyLocalStorage();
await MatomoTracker.instance.initialize(
siteId: siteId,
url: 'https://example.com/matomo.php',
localStorage: myStorage,
);
Note that if you weren't using a custom instance of SharedPreferences
before, you don't need to change anything. The default behavior still works.
await MatomoTracker.instance.initialize(
siteId: siteId,
url: 'https://example.com/matomo.php',
);
Guillaume Roux |
Pierre Monier |
Jêrôme Poichet |
Marvin Möltgen |
Krille Fear |
Scolnet |
Null |
Null |
Meï |
Paula Petcu |
Chris Tomlinson |
Johann Schramm |
Lsaudon |
Null |
Lukas Lihotzki |
David Serrano Canales |