analytics_event 1.1.2
analytics_event: ^1.1.2 copied to clipboard
Code generator to simplify generating analytics tracking events. Turns stub methods into tracking calls for fire base analytics, google analytics, etc.
example/lib/example.dart
import 'package:analytics_event/analytics_event.dart';
import 'package:logging/logging.dart';
import 'package:logging_appenders/logging_appenders.dart';
part 'example.g.dart';
final _logger = Logger('example');
/// Create an abstract class which implements [AnalyticsEventStubs]
/// and has stub methods for all events you want to track.
abstract class Events implements AnalyticsEventStubs {
void trackAppLaunch({required String date});
void trackExample(String myRequiredParameter, {String withDefault = 'test'});
/// enums will be correctly transformed
/// i.e. 'action' will be 'launch', 'remove' or 'share'
void trackItem(ItemAction action);
void trackNullableItem(ItemAction? action);
}
enum ItemAction {
launch,
remove,
share,
}
/// A analytics service which is responsible for sending events to
/// your analytics provider (e.g. firebase analytics).
class AnalyticsService {
AnalyticsService();
// Instantiate the generated Events implementation.
late final Events events = _$Events(_trackEvent);
void _trackEvent(String event, Map<String, Object?> params) {
// Here you would send the event to your analytics service.
_logger.info('We have to track event $event with parameters: $params');
}
void dispose() => events.removeTracker(_trackEvent);
}
void main() {
PrintAppender.setupLogging();
final myAnalytics = AnalyticsService();
// Now you have a typesafe way to send events to your analytics service.
myAnalytics.events.trackAppLaunch(date: DateTime.now().toString());
myAnalytics.dispose();
}