forked from facebook/react-native
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Convert DefaultDevLoadingView.java->.kt
Summary: # Changelog: [Internal] - As in the title. Differential Revision: D60286594
- Loading branch information
1 parent
4b8f055
commit 8860409
Showing
3 changed files
with
131 additions
and
158 deletions.
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
156 changes: 0 additions & 156 deletions
156
...roid/src/main/java/com/facebook/react/devsupport/DefaultDevLoadingViewImplementation.java
This file was deleted.
Oops, something went wrong.
125 changes: 125 additions & 0 deletions
125
...ndroid/src/main/java/com/facebook/react/devsupport/DefaultDevLoadingViewImplementation.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,125 @@ | ||
/* | ||
* Copyright (c) Meta Platforms, Inc. and affiliates. | ||
* | ||
* This source code is licensed under the MIT license found in the | ||
* LICENSE file in the root directory of this source tree. | ||
*/ | ||
|
||
package com.facebook.react.devsupport | ||
|
||
import android.content.Context | ||
import android.graphics.Rect | ||
import android.view.Gravity | ||
import android.view.LayoutInflater | ||
import android.view.ViewGroup | ||
import android.view.WindowManager | ||
import android.widget.PopupWindow | ||
import android.widget.TextView | ||
import com.facebook.common.logging.FLog | ||
import com.facebook.react.R | ||
import com.facebook.react.bridge.UiThreadUtil | ||
import com.facebook.react.common.ReactConstants | ||
import com.facebook.react.devsupport.interfaces.DevLoadingViewManager | ||
import java.util.Locale | ||
|
||
/** | ||
* Default implementation of Dev Loading View Manager to display loading messages on top of the | ||
* screen. All methods are thread safe. | ||
*/ | ||
public class DefaultDevLoadingViewImplementation( | ||
private val reactInstanceDevHelper: ReactInstanceDevHelper | ||
) : DevLoadingViewManager { | ||
private var devLoadingView: TextView? = null | ||
private var devLoadingPopup: PopupWindow? = null | ||
|
||
override fun showMessage(message: String) { | ||
if (!isEnabled) { | ||
return | ||
} | ||
UiThreadUtil.runOnUiThread { showInternal(message) } | ||
} | ||
|
||
override fun updateProgress(status: String?, done: Int?, total: Int?) { | ||
if (!isEnabled) { | ||
return | ||
} | ||
UiThreadUtil.runOnUiThread { | ||
val message = StringBuilder() | ||
message.append(status ?: "Loading") | ||
if (done != null && total != null && total > 0) { | ||
message.append(String.format(Locale.getDefault(), " %.1f%%", done.toFloat() / total * 100)) | ||
} | ||
message.append("\u2026") // `...` character | ||
devLoadingView?.text = message | ||
} | ||
} | ||
|
||
public override fun hide() { | ||
if (!isEnabled) { | ||
return | ||
} | ||
UiThreadUtil.runOnUiThread { hideInternal() } | ||
} | ||
|
||
private fun showInternal(message: String) { | ||
if (devLoadingPopup?.isShowing == true) { | ||
// already showing | ||
return | ||
} | ||
val currentActivity = reactInstanceDevHelper.currentActivity | ||
if (currentActivity == null) { | ||
FLog.e( | ||
ReactConstants.TAG, | ||
"Unable to display loading message because react " + "activity isn't available") | ||
return | ||
} | ||
|
||
// PopupWindow#showAtLocation uses absolute screen position. In order for | ||
// loading view to be placed below status bar (if the status bar is present) we need to pass | ||
// an appropriate Y offset. | ||
try { | ||
val rectangle = Rect() | ||
currentActivity.window.decorView.getWindowVisibleDisplayFrame(rectangle) | ||
val topOffset = rectangle.top | ||
val inflater = | ||
currentActivity.getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater | ||
devLoadingView = inflater.inflate(R.layout.dev_loading_view, null) as TextView | ||
devLoadingView!!.text = message | ||
val popup = | ||
PopupWindow( | ||
devLoadingView, | ||
ViewGroup.LayoutParams.MATCH_PARENT, | ||
ViewGroup.LayoutParams.WRAP_CONTENT) | ||
popup.isTouchable = false | ||
popup.showAtLocation(currentActivity.window.decorView, Gravity.NO_GRAVITY, 0, topOffset) | ||
|
||
devLoadingPopup = popup | ||
// TODO T164786028: Find out the root cause of the BadTokenException exception here | ||
} catch (e: WindowManager.BadTokenException) { | ||
FLog.e( | ||
ReactConstants.TAG, | ||
"Unable to display loading message because react " + | ||
"activity isn't active, message: " + | ||
message) | ||
} | ||
} | ||
|
||
private fun hideInternal() { | ||
if (devLoadingPopup?.isShowing == true) { | ||
devLoadingPopup!!.dismiss() | ||
devLoadingPopup = null | ||
devLoadingView = null | ||
} | ||
} | ||
|
||
private val context: Context? | ||
get() = reactInstanceDevHelper.currentActivity | ||
|
||
public companion object { | ||
private var isEnabled = true | ||
|
||
public fun setDevLoadingEnabled(enabled: Boolean) { | ||
isEnabled = enabled | ||
} | ||
} | ||
} |