-
Notifications
You must be signed in to change notification settings - Fork 25
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
chore: add support to set screen name to all event #181
base: main
Are you sure you want to change the base?
chore: add support to set screen name to all event #181
Conversation
@@ -68,6 +68,8 @@ public class PostHog private constructor( | |||
private var isIdentifiedLoaded: Boolean = false | |||
private var isPersonProcessingLoaded: Boolean = false | |||
|
|||
private lateinit var currentScreen: String |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think this approach leaves room for too many false positives.
eg I call screen(x)
for screen X, but I don't call screen(y)
for screen Y, when events are captured in the screen y
, the screen name is x
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think a better approach would be using https://github.com/PostHog/posthog-android/blob/main/posthog-android/src/main/java/com/posthog/android/internal/PostHogActivityLifecycleCallbackIntegration.kt
So we can cache the current Activity
based on the screen's lifecycle and infer the name from it.
If screen
is called either manually, it has precedence over the current activity.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see, you are correct. The problem with using PostHogActivityLifecycleCallbackIntegration.kt
is that we would have to add method signature in PostHogInterface
, and i dont know if it make sense.
see theses changes
thisames@7d4a6f5
do you think this make sense?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we should add a new concept to the SDK that allows enriching the event after being captured, for example, an event processor.
I will make an example and you can expand from there
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you, you made it much easier for me. I will update this PR with the changes and then you check and give me the ok, if it works I will do the unit tests
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Another option is to use the super properties for the screen name
posthog-android/posthog/src/main/java/com/posthog/PostHog.kt
Lines 783 to 802 in 3a0ede8
public override fun register( | |
key: String, | |
value: Any, | |
) { | |
if (!isEnabled()) { | |
return | |
} | |
if (ALL_INTERNAL_KEYS.contains(key)) { | |
config?.logger?.log("Key: $key is reserved for internal use.") | |
return | |
} | |
getPreferences().setValue(key, value) | |
} | |
public override fun unregister(key: String) { | |
if (!isEnabled()) { | |
return | |
} | |
getPreferences().remove(key) | |
} |
both would work the same
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I prefer the solution with processors, it's working well
@marandaneto ready for review |
api generated 😅 |
💡 Motivation and Context
#119
💚 How did you test it?
The tests have been updated to include checks for the new $screen_name property in any event.
I tested it manually and analyse the props in dashboard.
📝 Checklist