Giter Site home page Giter Site logo

litang0908 / matomo-tracker Goto Github PK

View Code? Open in Web Editor NEW

This project forked from floating-dartists/matomo-tracker

0.0 0.0 0.0 806 KB

A fully cross-platform wrap of the Matomo tracking client for Flutter, using the Matomo API.

Home Page: https://pub.dev/packages/matomo_tracker

License: MIT License

Ruby 1.11% C++ 9.14% C 0.56% PHP 1.02% Objective-C 0.02% Java 0.06% Dart 78.91% Swift 0.66% HTML 0.73% CMake 7.43% Dockerfile 0.38%

matomo-tracker's Introduction

Matomo Tracker

Floating Dartists

Pub Version (including pre-releases) Matomo Integrations GitHub license Coverage Status

Forked from the package matomo by poitch.

A fully cross-platform wrap of the Matomo tracking client for Flutter, using the Matomo Tracking API.

Summary

Documentation

Supported Matomo Versions

This package (matomo_tracker v4.0.0) currently supports Matomo 3.X up to Matomo 5.X. We are planning to drop support for Matomo 3 in the next major release. You can expect for legacy properties to be annotated as deprecated in the next minor release.

Getting Started

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',
);

Note that this Visitor ID should not be confused with the User ID which is explained below!

Then, for TraceableClientMixin and TraceableWidget to work, you will have to add matomoObserver to your navigatorObservers:

MaterialApp(
    // ...
    navigatorObservers: [
        matomoObserver,
    ],
);

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 actionName => 'Created HomePage'; // optional

  @override
  String get path => '/home'; // optional
}

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(
      actionName: 'Created HomePage', // optional
      path: '/home', // optional
      child: Scaffold(
        appBar: AppBar(
          title: Text(title),
        ),
        body: Center(
          child: Text('Hello World!'),
        ),
      ),
    );
  }
}

You can also optionally call directly trackPageView or trackPageViewWithName to track a view.

For tracking goals and, events call trackGoal and trackEvent respectively.

A value can be passed for events:

MatomoTracker.instance.trackEvent(
    eventInfo: EventInfo(
        category: 'eventCategory',
        name: 'eventName',
        action: 'eventAction',
        value: 18,
    ),
);

Using userId

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);

Opting Out

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);

Using Dimensions

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(
    eventInfo: EventInfo(
        category: "eventCategory",
        action: "eventAction",
        name: "eventName",
        value: 18,
    ),
    dimensions: {'dimension2':'guest-user'}
);

You can similarly track dimensions on Screen views with:

MatomoTracker.instance.trackPageViewWithName(
    actionName: "Settings",
    path: "/settings",
    dimensions: {'dimension1': '0.0.1'}
);

The naming of the dimensions is important and explained in more detail in the documentation of trackDimensions.

Cookieless Tracking

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.

Dispatching

Actions logged are not send to Matomo immediately, but are queued for a configurable duration (defaulting to 10 seconds) before beeing send in batch. A user could terminate your app while there are still undispatched actions in the queue, which by default would be lost. The queue can be configured to be persistent so that such actions would then be send on the next app launch. See the DispatchSettings class for more configuration options.

await MatomoTracker.instance.initialize(
    siteId: siteId,
    url: 'https://example.com/matomo.php',
    dispatchSettings: const DispatchSettings.persistent(),
);

Migration Guide

v4.0.0

  • trackScreen was renamed to trackPageView and trackScreenWithName to trackPageViewWithName.
  • screenId and widgetId were renamed to pvId.
  • userId was renamed to uid.
  • traceName and widgetName were renamed to actionName.
  • traceTitle was renamed to eventName.
  • forcedId property has been removed as it was never used. You should rely on the user ID instead.
  • An object of type EventInfo has been added, it has the following properties: category, action, name and value, use it instead of passing the event name, action and value as separate parameters.
  • For TraceableClientMixin and TraceableWidget to work you will have to add the matomoObserver to your MaterialApp or WidgetsApp:
MaterialApp(
    // ...
    navigatorObservers: [
        matomoObserver,
    ],
);
  • MatomoEvent has been renamed to MatomoAction
  • trackPageView positional parameter context is now a named parameter
  • trackGoal positional parameter goalId is now a named parameter: id
  • trackDimensions positional parameter dimensions is now a named parameter
  • trackCartUpdate positional parameters trackingOrderItems, subTotal, taxAmount, shippingCost and discountAmount are now named parameters
  • trackOrder positional parameters orderId (now id), trackingOrderItems, revenue (also became a double), subTotal, taxAmount, shippingCost and discountAmount are now named parameters
  • trackOutlink positional parameter link is now a named required parameter (also changed the type to String)

v3.0.0

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.

Before

final myPrefs = await SharedPreferences.getInstance();

await MatomoTracker.instance.initialize(
    siteId: siteId,
    url: 'https://example.com/matomo.php',
    prefs: myPrefs,
);

After

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',
);

Contributors

TesteurManiak
Guillaume Roux
EPNW-Eric
Null
Pierre-Monier
Pierre Monier
poitch
Jêrôme Poichet
M123-dev
Marvin Möltgen
krille-chan
Krille-chan
scolnet
Scolnet
MeixDev
Meï
stefan01
Null
KawachenCofinpro
Null
petcupaula
Paula Petcu
CleverUnderDog
Null
luckyrat
Chris Tomlinson
JohannSchramm
Johann Schramm
lsaudon
Lsaudon
Bendix20
Null
hpoul
Herbert Poul
jainhitesh9998
Hitesh C
lukaslihotzki
Lukas Lihotzki
svprdga
David Serrano Canales

matomo-tracker's People

Contributors

testeurmaniak avatar epnw-eric avatar pierre-monier avatar poitch avatar github-actions[bot] avatar m123-dev avatar dependabot[bot] avatar krille-chan avatar scolnet avatar meixdev avatar kawachencofinpro avatar stefan01 avatar petcupaula avatar cleverunderdog avatar luckyrat avatar johannschramm avatar lsaudon avatar litang0908 avatar bendix20 avatar hpoul avatar jainhitesh9998 avatar julianbissekkou avatar lukaslihotzki avatar svprdga avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.