flutuate_mixpanel 1.1.8 flutuate_mixpanel: ^1.1.8 copied to clipboard
A Flutter plugin for use the Mixpanel API for Android devices.
import 'package:flutter/material.dart';
import 'dart:async';
import 'package:flutuate_mixpanel/flutuate_mixpanel.dart';
/// Set your Mixpanel token here before run the example app.
const YOUR_MIXPANEL_TOKEN = null;
void main(List<String> args) {
String mixpanelToken = args.isNotEmpty ? args[0] : YOUR_MIXPANEL_TOKEN;
print(mixpanelToken);
runApp(MyApp(mixpanelToken));
}
class MyApp extends StatefulWidget {
final String _mixpanelToken;
MyApp(this._mixpanelToken);
@override
_MyAppState createState() => _MyAppState(_mixpanelToken);
}
class _MyAppState extends State<MyApp> {
MixpanelAPI _mixpanel;
final String _mixpanelToken;
String _resultMessage = '';
_MyAppState(this._mixpanelToken);
@override
void initState() {
super.initState();
initPlatformState();
}
Future<void> initPlatformState() async {
if (!mounted) return;
}
@override
Widget build(BuildContext context) {
List<Widget> content;
if (_mixpanelToken == null || _mixpanelToken.isEmpty) {
content = [Text('Your Mixpanel Token was not informed')];
} else {
content = createButtons(context);
}
return MaterialApp(
home: Scaffold(
appBar: AppBar(
title: const Text('Flutuate.io Mixpanel Plugin Example'),
),
body: Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.start,
children: <Widget>[
Text(
_resultMessage,
key: Key('resultMessage'),
),
Column(
children: content,
),
],
),
),
),
);
}
List<Widget> createButtons(BuildContext context) {
return [
buttonGetInstance(context),
buttonTrackEvent(context),
buttonRegisterSuperProperties(context),
buttonGetDeviceInfo(context),
buttonGetDistinctId(context),
buttonReset(context),
buttonFlush(context),
];
}
Widget buttonGetInstance(BuildContext context) => ElevatedButton(
key: Key('getInstance'),
child: Text('Get an instance of Mixpanel plugin'),
onPressed: () => getInstance());
Widget buttonTrackEvent(BuildContext context) => ElevatedButton(
key: Key('trackEvent'),
child: Text('Track an event'),
onPressed: () => trackEvent());
Widget buttonRegisterSuperProperties(BuildContext context) => ElevatedButton(
key: Key('registerSuperProperties'),
child: Text('Register Super Properties'),
onPressed: () => registerSuperProperties());
Widget buttonReset(BuildContext context) => ElevatedButton(
key: Key('reset'), child: Text('Reset'), onPressed: () => reset());
Widget buttonGetDeviceInfo(BuildContext context) => ElevatedButton(
key: Key('getDeviceInfo'),
child: Text('Get device info'),
onPressed: () => getDeviceInfo());
Widget buttonGetDistinctId(BuildContext context) => ElevatedButton(
key: Key('getDistinctId'),
child: Text('Get distinct id'),
onPressed: () => getDistinctId());
Widget buttonFlush(BuildContext context) => ElevatedButton(
key: Key('flush'), child: Text('Flush'), onPressed: () => flush());
void getInstance() {
MixpanelAPI.getInstance(_mixpanelToken).then((mixpanel) {
_mixpanel = mixpanel;
setState(() {
_resultMessage = 'Instance created with success!';
});
});
}
void trackEvent() {
var properties = {'Button Pressed': 'A button was pressed'};
_mixpanel.track('Flutuate.io Mixpanel Plugin Event', properties);
setState(() {
_resultMessage = 'Event sent with success!';
});
}
void registerSuperProperties() {
var properties = {
'Plugin': 'flutuate_mixpanel',
};
_mixpanel.registerSuperProperties(properties);
setState(() {
_resultMessage = 'Register Super Properties with success!';
});
}
void reset() {
_mixpanel.reset();
}
void getDeviceInfo() async {
var devInfo = await _mixpanel.getDeviceInfo();
print(devInfo);
setState(() {
_resultMessage = devInfo.toString();
});
}
void getDistinctId() async {
var distinctId = await _mixpanel.getDistinctId();
print(distinctId);
setState(() {
_resultMessage = distinctId;
});
}
void flush() {
_mixpanel.flush();
setState(() {
_resultMessage = 'Flushed with success!';
});
}
}