How to add Firebase custom events for analytics?

79,200

Solution 1

You can see it in console without any hacks, but it is pretty hidden there.

Go to Firebase Analytics -> Stream View -> Select Events -> Top events -> select_content -> there you go

My code:

Bundle params = new Bundle();
params.putString("invalid_url", urlPart);
mFirebaseAnalytics.logEvent("eventInvalidUrl", params);

Firebase Analytics Stream View

Solution 2

The custom parameters will not be shown. Only suggested events with suggested parameters are presented in dashboard.

To see the custom parameters, you have to link your project to Big Query (it's not free).

Also Firebase will not show information if the number of user is less than 10.

Solution 3

If you are still looking for answer, You need to add custom parameters into the event manually once in the dashboard Like this https://support.google.com/firebase/answer/7397304?hl=en&ref_topic=6317489 Actually there is no need to link BigQuery for this. But it will take several hours to show up custom parameter once you navigate inside the event.

Solution 4

In Firebase, As i know we have to log the events in < Key,value > pair and then need to log.

Like this :

bundle.putString("yourKey","yourValue");

For Example, I have put the Custom event in MyApp to get the AppOpen time as below.

    Bundle params = new Bundle();
    params.putString("open_time", TimeStampUtil.getTimeStamp(System.currentTimeMillis()));
    mFirebaseAnalytics.logEvent("app_open_time", params);

so, in above example i have create a custom event with name app_open_time and put the value with key as open_time.

Try in this way and for more info refer this : https://firebase.google.com/docs/analytics/android/events

Solution 5

Not only do you need to do what Muhammad Riyaz says, you also need to get your user count up above the "threshold". In my case, installing my app on a dozen simulator versions pushed my user count to 12, and voila, suddenly I have custom event parameter data in my Firebase dashboard.

Share:
79,200
joe
Author by

joe

Updated on July 09, 2022

Comments

  • joe
    joe almost 2 years

    I've seen some questions and answers about custom events for firebase analytics, but i just wanted to ask you a straight question so you can give me a straight answer :)

    So, this is my method for logging:

    @Override
    public void logFeatureSelectedEvent(String categoryName, String actionName, String labelName) {
        Bundle bundle = new Bundle();
        bundle.putString(EventTrackingKeys.EventTypes.CATEGORY, categoryName);
        bundle.putString(EventTrackingKeys.EventTypes.ACTION, actionName);
        bundle.putString(EventTrackingKeys.EventTypes.LABEL, labelName);
        mFirebaseAnalytics.logEvent(EventTrackingKeys.EventAnalyticTypes.FEATURE_SELECTED_EVENT, bundle);
    }
    

    with custom event/key names:

    String CATEGORY = "category";
    String ACTION = "action";
    String LABEL = "label";
    String FEATURE_SELECTED_EVENT = "feature_selected_event";
    

    So, in my firebase console I only get event name "feature_selected_event", without custom parameter names.. I've seen some answers that i should call setUserProperty() method and register that user property in the User Properties tab of Firebase Analytics. Is this the right way to implement that method? :

       @Override
    public void logFeatureSelectedEvent(String categoryName, String actionName, long value) {
        Bundle bundle = new Bundle();
        bundle.putString(EventTrackingKeys.EventTypes.CATEGORY, categoryName);
        bundle.putString(EventTrackingKeys.EventTypes.ACTION, actionName);
        bundle.putLong(EventTrackingKeys.EventTypes.VALUE, value);
        mFirebaseAnalytics.setUserProperty(EventTrackingKeys.EventTypes.CATEGORY, categoryName);
        mFirebaseAnalytics.setUserProperty(EventTrackingKeys.EventTypes.ACTION, actionName);
        mFirebaseAnalytics.setUserProperty(EventTrackingKeys.EventTypes.VALUE, value);
        mFirebaseAnalytics.logEvent(EventTrackingKeys.EventAnalyticTypes.FEATURE_SELECTED_EVENT, bundle);
    }
    
  • joe
    joe over 7 years
    Yep, but did you get that "open time" property in your firebase console? From my example, I "have feature_selected_event" and count that says how many time that event occurred, which is shown in console, but i can't see what are the values for "category", "action" and "label". I was searching for an answer and saw that i should add setUserProperty() method and register those properties in console.. but i'm not really sure how to use that method...
  • Uttam Panchasara
    Uttam Panchasara over 7 years
    No actually its not displayed in my app console too. may be its because its custom event.
  • TOP
    TOP over 7 years
    @joe see my answer
  • joe
    joe over 7 years
    Are you sure? That's also what i read somewhere, but what's the point of using setUserProperty() method and registering user properties in firebase console then?
  • UserName_Untold
    UserName_Untold over 7 years
    Will "app_open_time" be shown as the event name on the firebase console page like the other predefined event names like "app_remove" etc. What should be done if i want to show the custom event names on the console page?
  • Uttam Panchasara
    Uttam Panchasara over 7 years
    Yes @Rachana "app_open_time" shown as event name same as other default events. and as per Firebase Doc the values of the log event displays only if you have paid account, with the Free account user will only able to see the events times, count and user counts.
  • UserName_Untold
    UserName_Untold over 7 years
    But i have implemented the analytics for ios also and there the full names of events are shown. Meaning with whatever events we have logged the events the same are reflected on console page. why is that android does not have this? any idea
  • Uttam Panchasara
    Uttam Panchasara over 7 years
    I really don't have any idea about iOS firebase analytic but as i also have implemented analytic in android apps and custom events it only shows me event names.
  • Uttam Panchasara
    Uttam Panchasara over 7 years
    For accessing all the data(in your case the values part) that you log in Firebase Analytics.. you have to link firebase to use Google Big Query service that's not available for Free. stackoverflow.com/questions/38695326/…
  • MeLean
    MeLean about 6 years
    TimeStampUtil.getTimeStamp(System.currentTimeMillis()) could that be replaced with Server TimeStamp ?
  • Uttam Panchasara
    Uttam Panchasara about 6 years
    Yes you can add any timestamp
  • BekaBot
    BekaBot almost 6 years
    even though I had more than 10 users, Firebase did not show custom parameters' values, but it appeared when I had more event calls.
  • Daniel Wilson
    Daniel Wilson almost 5 years
    This is only from the last 30 mins, so there's no other way to capture or visualize events data with specific bundle details? This service appears to be utterly useless.
  • Ahmad Shahwaiz
    Ahmad Shahwaiz over 2 years
    use analytics.google to see events logged from firebase.
  • Tushar Mate
    Tushar Mate over 2 years
    I used the same method of logging events. I see very few real events while most of these are 'not set' type. This is as per analytics report of 700+ users in 2 days. Anybody knows why?