-
-
Notifications
You must be signed in to change notification settings - Fork 2.9k
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
[New Arch] Android Fabric #3204
Open
yungblud
wants to merge
61
commits into
TheWidlarzGroup:master
Choose a base branch
from
react-native-yeouido:feature/newarch-android
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from all commits
Commits
Show all changes
61 commits
Select commit
Hold shift + click to select a range
0aceefb
feat: :zap: added gitignore
yungblud 649b2e9
feat: :zap: turn on newarch enabled on example app
yungblud 5c371bb
feat: :zap: setup example app new arch
yungblud 8782d7a
feat: :zap: setup android example app for fabric android
yungblud 6bd2489
feat: :zap: setup kotlin
yungblud d851d56
feat: :zap: migrate to fabric
yungblud ddcb252
refactor: js to ts
jiyong1 37c5a02
chore: update pacakge
jiyong1 43a8645
fabric support for js
jiyong1 8ba7950
feat: :zap: added gitignore
yungblud 68320b0
feat: modified seek, headers
yungblud 153186d
fix: fixed drm headers type android
yungblud 797f527
chore: modified type
yungblud ace7e55
feat: modified package json
yungblud 70afe83
refactor: remove legacy video js
yungblud dbec302
fix: fixed android fabric include isssue
yungblud 92448ba
feat: modified seek, headers
yungblud 5db9e7e
fix: fixed drm headers type android
yungblud 63f4131
refactor: refactored properties
yungblud 20842fb
feat: replaced null to map
yungblud f3948a5
feat: temporarily remove put array on event callback parameter (codeg…
yungblud dcee4ff
fix: fix selected props typo
jiyong1 b8b6f53
fix: add useExternalGetLicense field
yungblud 54f4fdc
feat: changed prop name
yungblud 310b4e2
fix: fixed drmType value
yungblud 80f56ca
fix: upgrade deprecated kotlin plugin
jiyong1 e53ad84
fix: add onDropViewInstance method
jiyong1 0df0282
fix: fixed endTime
yungblud 33e9144
feat: video seek param update
jiyong1 ebae8eb
feat: video seek event android
jiyong1 4ac3550
fix: fixed codegen types
yungblud 52c1527
feat: added finished
yungblud 80b61d7
feat: modified drmType, selected audio, text type oldarch
yungblud 781b9b6
fix: fixed finished
yungblud 894cce3
chore: added .npmignore on android
yungblud 3cfaf81
chore: modified npm files
yungblud 3ad51a6
chore: removed publishConfig
yungblud aac3350
Merge remote-tracking branch 'upstream/master' into feature/newarch-a…
yungblud dc1529a
feat: implemented Fabric android video event emitter
yungblud 95a3b4c
feat: modified handling props src header array for Fabric types
yungblud 06accdf
Merge branch 'master' into feature/newarch-android
yungblud 490b56a
fix: fixed typescript
yungblud 0b554b3
chore: removed unusing VideoView
yungblud fe890b5
chore: lint fix
yungblud 5cb06e5
chore: modified tsconfig.json
yungblud dbca3ec
chore: modified Podfile.lock
yungblud 72de90c
fix: fixed VideoEventEmitter with fabric
yungblud 9bfe250
feat: modified typescripts
yungblud f105bf5
feat: modified android events
yungblud 9945637
fix: synced build.gradle Fabric example
yungblud 03b0ab2
feat: modified react exo player android
yungblud 7863d9c
fix: fixed basic example metro.config.js
yungblud 61cb62e
fix: fixed VideoEventEmitter import class, metadata array
yungblud 58bf621
chore: modified tsconfig.json
yungblud b57185d
feat: implemented receiveCommand
yungblud 32eb9d2
feat: removed unnecessary VideoResizeMode.ts
yungblud b3a1857
refactor: refactored on timed metadata event
yungblud de4bfa6
chore: removed unnecessary import
yungblud 3f12e34
feat: modified codegen naming property of selected video track
yungblud a813592
feat: modified package.json main property
yungblud 52a56a0
Merge remote-tracking branch 'upstream/master' into feature/newarch-a…
yungblud File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
504 changes: 504 additions & 0 deletions
504
android/src/fabric/java/com/brentvatne/exoplayer/ReactExoplayerViewManager.kt
Large diffs are not rendered by default.
Oops, something went wrong.
363 changes: 363 additions & 0 deletions
363
android/src/fabric/java/com/brentvatne/exoplayer/VideoEventEmitter.java
Large diffs are not rendered by default.
Oops, something went wrong.
22 changes: 22 additions & 0 deletions
22
android/src/fabric/java/com/brentvatne/exoplayer/events/OnAudioFocusChangedEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnAudioFocusChangedEvent(viewTag: Int, private val hasFocus: Boolean): Event<OnAudioFocusChangedEvent>(viewTag) { | ||
private val EVENT_PROP_HAS_AUDIO_FOCUS = "hasAudioFocus" | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnAudioFocusChanged" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
val event = Arguments.createMap() | ||
event.putBoolean(EVENT_PROP_HAS_AUDIO_FOCUS, hasFocus) | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), event) | ||
} | ||
} |
48 changes: 48 additions & 0 deletions
48
android/src/fabric/java/com/brentvatne/exoplayer/events/OnAudioTracksEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.brentvatne.common.api.Track | ||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.bridge.WritableArray | ||
import com.facebook.react.bridge.WritableMap | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnAudioTracksEvent(viewTag: Int, private val audioTracks: ArrayList<Track>) : Event<OnAudioTracksEvent>(viewTag) { | ||
private val EVENT_PROP_AUDIO_TRACKS = "audioTracks" | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnAudioTracks" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), arrayToObject(EVENT_PROP_AUDIO_TRACKS, audioTracksToArray(audioTracks))) | ||
} | ||
|
||
fun arrayToObject(field: String?, array: WritableArray?): WritableMap? { | ||
val event = Arguments.createMap() | ||
// @todo: temporarily remove put array on event callback parameter (codegen issue) | ||
// event.putArray(field!!, array) | ||
return event | ||
} | ||
|
||
fun audioTracksToArray(audioTracks: java.util.ArrayList<Track>?): WritableArray? { | ||
val waAudioTracks = Arguments.createArray() | ||
if (audioTracks != null) { | ||
for (i in audioTracks.indices) { | ||
val format = audioTracks[i] | ||
val audioTrack = Arguments.createMap() | ||
audioTrack.putInt("index", i) | ||
audioTrack.putString("title", if (format.title != null) format.title else "") | ||
audioTrack.putString("type", if (format.mimeType != null) format.mimeType else "") | ||
audioTrack.putString("language", if (format.language != null) format.language else "") | ||
audioTrack.putInt("bitrate", format.bitrate) | ||
audioTrack.putBoolean("selected", format.isSelected) | ||
waAudioTracks.pushMap(audioTrack) | ||
} | ||
} | ||
return waAudioTracks | ||
} | ||
} |
22 changes: 22 additions & 0 deletions
22
android/src/fabric/java/com/brentvatne/exoplayer/events/OnPlaybackRateChangeEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnPlaybackRateChangeEvent(viewTag: Int, private val rate: Float): Event<OnPlaybackRateChangeEvent>(viewTag) { | ||
private val EVENT_PROP_PLAYBACK_RATE = "playbackRate" | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnPlaybackRateChange" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
val event = Arguments.createMap() | ||
event.putDouble(EVENT_PROP_PLAYBACK_RATE, rate.toDouble()) | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), event) | ||
} | ||
} |
19 changes: 19 additions & 0 deletions
19
android/src/fabric/java/com/brentvatne/exoplayer/events/OnReadyForDisplayEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnReadyForDisplayEvent(viewTag: Int) : Event<OnReadyForDisplayEvent>(viewTag) { | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnReadyForDisplay" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), Arguments.createMap()) | ||
} | ||
} |
21 changes: 21 additions & 0 deletions
21
android/src/fabric/java/com/brentvatne/exoplayer/events/OnReceiveAdEventEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnReceiveAdEventEvent(viewTag: Int, private val event: String): Event<OnReceiveAdEventEvent>(viewTag) { | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnReceiveAdEventEvent" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
val map = Arguments.createMap() | ||
map.putString("event", event) | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), map) | ||
} | ||
} |
47 changes: 47 additions & 0 deletions
47
android/src/fabric/java/com/brentvatne/exoplayer/events/OnTextTracksEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.brentvatne.common.api.Track | ||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.bridge.WritableArray | ||
import com.facebook.react.bridge.WritableMap | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnTextTracksEvent(viewTag: Int, private val textTracks: ArrayList<Track>) : Event<OnTextTracksEvent>(viewTag) { | ||
private val EVENT_PROP_TEXT_TRACKS = "textTracks" | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnTextTracks" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), arrayToObject(EVENT_PROP_TEXT_TRACKS, textTracksToArray(textTracks))) | ||
} | ||
|
||
fun arrayToObject(field: String?, array: WritableArray?): WritableMap? { | ||
val event = Arguments.createMap() | ||
// @todo: temporarily remove put array on event callback parameter (codegen issue) | ||
// event.putArray(field!!, array) | ||
return event | ||
} | ||
|
||
fun textTracksToArray(textTracks: ArrayList<Track>?): WritableArray? { | ||
val waTextTracks = Arguments.createArray() | ||
if (textTracks != null) { | ||
for (i in textTracks.indices) { | ||
val format = textTracks[i] | ||
val textTrack = Arguments.createMap() | ||
textTrack.putInt("index", i) | ||
textTrack.putString("title", if (format.title != null) format.title else "") | ||
textTrack.putString("type", if (format.mimeType != null) format.mimeType else "") | ||
textTrack.putString("language", if (format.language != null) format.language else "") | ||
textTrack.putBoolean("selected", format.isSelected) | ||
waTextTracks.pushMap(textTrack) | ||
} | ||
} | ||
return waTextTracks | ||
} | ||
} |
30 changes: 30 additions & 0 deletions
30
android/src/fabric/java/com/brentvatne/exoplayer/events/OnTimedMetadataEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import androidx.media3.common.Metadata | ||
import androidx.media3.extractor.metadata.emsg.EventMessage | ||
import androidx.media3.extractor.metadata.id3.Id3Frame | ||
import androidx.media3.extractor.metadata.id3.TextInformationFrame | ||
import com.brentvatne.common.api.TimedMetadata | ||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
import java.util.ArrayList | ||
|
||
class OnTimedMetadataEvent(viewTag: Int, private val metadata: ArrayList<TimedMetadata>): Event<OnTimedMetadataEvent>(viewTag) { | ||
private val EVENT_PROP_TIMED_METADATA = "metadata" | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnTimedMetadata" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
|
||
val event = Arguments.createMap() | ||
// @todo: temporarily remove put array on event callback parameter (codegen issue) | ||
// event.putArray(EVENT_PROP_TIMED_METADATA, metadataArray) | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), event) | ||
} | ||
} |
19 changes: 19 additions & 0 deletions
19
android/src/fabric/java/com/brentvatne/exoplayer/events/OnVideoAudioBecomingNoisyEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnVideoAudioBecomingNoisyEvent(viewTag: Int): Event<OnVideoAudioBecomingNoisyEvent>(viewTag) { | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnVideoAudioBecomingNoisy" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), Arguments.createMap()) | ||
} | ||
} |
34 changes: 34 additions & 0 deletions
34
android/src/fabric/java/com/brentvatne/exoplayer/events/OnVideoBandwidthUpdateEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnVideoBandwidthUpdateEvent( | ||
viewTag: Int, | ||
private val bitRateEstimate: Double, | ||
private val height: Int, | ||
private val width: Int, | ||
private val id: String | ||
) : Event<OnVideoBandwidthUpdateEvent>(viewTag) { | ||
private val EVENT_PROP_BITRATE = "bitrate" | ||
private val EVENT_PROP_WIDTH = "width" | ||
private val EVENT_PROP_HEIGHT = "height" | ||
private val EVENT_PROP_TRACK_ID = "trackId" | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnVideoBandwidthUpdate" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
val event = Arguments.createMap() | ||
event.putDouble(EVENT_PROP_BITRATE, bitRateEstimate) | ||
event.putInt(EVENT_PROP_WIDTH, width) | ||
event.putInt(EVENT_PROP_HEIGHT, height) | ||
event.putString(EVENT_PROP_TRACK_ID, id) | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), event) | ||
} | ||
} |
22 changes: 22 additions & 0 deletions
22
android/src/fabric/java/com/brentvatne/exoplayer/events/OnVideoBufferEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,22 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnVideoBufferEvent(viewTag: Int, private val isBuffering: Boolean) : Event<OnVideoBufferEvent>(viewTag) { | ||
private val EVENT_PROP_IS_BUFFERING = "isBuffering" | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnVideoBuffer" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
val event = Arguments.createMap() | ||
event.putBoolean(EVENT_PROP_IS_BUFFERING, isBuffering) | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), event) | ||
} | ||
} |
19 changes: 19 additions & 0 deletions
19
android/src/fabric/java/com/brentvatne/exoplayer/events/OnVideoEndEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnVideoEndEvent(viewTag: Int): Event<OnVideoEndEvent>(viewTag) { | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnVideoEnd" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), Arguments.createMap()) | ||
} | ||
} |
46 changes: 46 additions & 0 deletions
46
android/src/fabric/java/com/brentvatne/exoplayer/events/OnVideoErrorEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
import java.io.PrintWriter | ||
import java.io.StringWriter | ||
|
||
class OnVideoErrorEvent( | ||
viewTag: Int, | ||
private val errorString: String, | ||
private val exception: Exception, | ||
private val errorCode: String | ||
): Event<OnVideoErrorEvent>(viewTag) { | ||
private val EVENT_PROP_ERROR = "error" | ||
private val EVENT_PROP_ERROR_STRING = "errorString" | ||
private val EVENT_PROP_ERROR_EXCEPTION = "errorException" | ||
private val EVENT_PROP_ERROR_TRACE = "errorStackTrace" | ||
private val EVENT_PROP_ERROR_CODE = "errorCode" | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnVideoErrorEvent" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
// Prepare stack trace | ||
|
||
// Prepare stack trace | ||
val sw = StringWriter() | ||
val pw = PrintWriter(sw) | ||
exception.printStackTrace(pw) | ||
val stackTrace = sw.toString() | ||
|
||
val error = Arguments.createMap() | ||
error.putString(EVENT_PROP_ERROR_STRING, errorString) | ||
error.putString(EVENT_PROP_ERROR_EXCEPTION, exception.toString()) | ||
error.putString(EVENT_PROP_ERROR_CODE, errorCode) | ||
error.putString(EVENT_PROP_ERROR_TRACE, stackTrace) | ||
val event = Arguments.createMap() | ||
event.putMap(EVENT_PROP_ERROR, error) | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), event) | ||
} | ||
} |
19 changes: 19 additions & 0 deletions
19
...src/fabric/java/com/brentvatne/exoplayer/events/OnVideoFullscreenPlayerDidDismissEvent.kt
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package com.brentvatne.exoplayer.events | ||
|
||
import com.facebook.react.bridge.Arguments | ||
import com.facebook.react.uimanager.events.Event | ||
import com.facebook.react.uimanager.events.RCTEventEmitter | ||
|
||
class OnVideoFullscreenPlayerDidDismissEvent(viewTag: Int): Event<OnVideoFullscreenPlayerDidDismissEvent>(viewTag) { | ||
override fun getEventName(): String { | ||
return EVENT_NAME | ||
} | ||
|
||
companion object { | ||
const val EVENT_NAME = "topOnVideoFullscreenPlayerDidDismiss" | ||
} | ||
|
||
override fun dispatch(rctEventEmitter: RCTEventEmitter?) { | ||
rctEventEmitter?.receiveEvent(viewTag, getEventName(), Arguments.createMap()) | ||
} | ||
} |
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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.
Is it possible to ensure these event are correctly sent when we uses old architecture ?
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.
Yep, this event will not be used on old architecture.
For old arch, we use
android/src/oldarch/java/com/brentvatne/exoplayer/VideoEventEmitter.java