diff --git a/.idea/kotlinc.xml b/.idea/kotlinc.xml
index 217e5c51fbf..fdf8d994a65 100644
--- a/.idea/kotlinc.xml
+++ b/.idea/kotlinc.xml
@@ -1,6 +1,6 @@
-
+
\ No newline at end of file
diff --git a/mobile/src/foss/java/org/openhab/habdroid/ui/MapViewHelper.kt b/mobile/src/foss/java/org/openhab/habdroid/ui/MapViewHelper.kt
index 93eea32672e..258eb519488 100644
--- a/mobile/src/foss/java/org/openhab/habdroid/ui/MapViewHelper.kt
+++ b/mobile/src/foss/java/org/openhab/habdroid/ui/MapViewHelper.kt
@@ -13,7 +13,6 @@
package org.openhab.habdroid.ui
-import android.content.DialogInterface
import android.location.Location
import android.os.Bundle
import android.os.Handler
@@ -83,6 +82,7 @@ object MapViewHelper {
}
override fun bindAfterDataSaverCheck(widget: Widget) {
+ super.bindAfterDataSaverCheck(widget)
handler.post {
mapView.applyPositionAndLabel(
boundWidget?.item,
diff --git a/mobile/src/foss/res/layout/widgetlist_mapitem.xml b/mobile/src/foss/res/layout/widgetlist_mapitem.xml
index 8adee74c587..7720685abac 100644
--- a/mobile/src/foss/res/layout/widgetlist_mapitem.xml
+++ b/mobile/src/foss/res/layout/widgetlist_mapitem.xml
@@ -1,39 +1,15 @@
-
-
-
-
-
-
-
+
diff --git a/mobile/src/full/res/layout/widgetlist_mapitem.xml b/mobile/src/full/res/layout/widgetlist_mapitem.xml
index 46c2d11b994..d5157573a3d 100644
--- a/mobile/src/full/res/layout/widgetlist_mapitem.xml
+++ b/mobile/src/full/res/layout/widgetlist_mapitem.xml
@@ -2,39 +2,15 @@
-
-
-
-
-
-
-
+
diff --git a/mobile/src/main/java/org/openhab/habdroid/ui/WidgetAdapter.kt b/mobile/src/main/java/org/openhab/habdroid/ui/WidgetAdapter.kt
index 9591a724ddd..30e33175979 100644
--- a/mobile/src/main/java/org/openhab/habdroid/ui/WidgetAdapter.kt
+++ b/mobile/src/main/java/org/openhab/habdroid/ui/WidgetAdapter.kt
@@ -35,6 +35,7 @@ import android.widget.Button
import android.widget.ImageView
import android.widget.LinearLayout
import android.widget.TextView
+import androidx.annotation.CallSuper
import androidx.annotation.LayoutRes
import androidx.annotation.StringRes
import androidx.annotation.VisibleForTesting
@@ -426,7 +427,7 @@ class WidgetAdapter(
) : ViewHolder(initData, layoutResId, compactModeLayoutResId) {
protected val labelView: TextView = itemView.findViewById(R.id.widgetlabel)
protected val valueView: TextView? = itemView.findViewById(R.id.widgetvalue)
- private val iconView: WidgetImageView = itemView.findViewById(R.id.widgeticon)
+ protected val iconView: WidgetImageView = itemView.findViewById(R.id.widgeticon)
protected var boundWidget: Widget? = null
private set
@@ -453,16 +454,17 @@ class WidgetAdapter(
initData: ViewHolderInitData,
@LayoutRes layoutResId: Int,
@LayoutRes compactModeLayoutResId: Int = layoutResId
- ) : ViewHolder(initData, layoutResId, compactModeLayoutResId) {
- protected var boundWidget: Widget? = null
- private set
+ ) : LabeledItemBaseViewHolder(initData, layoutResId, compactModeLayoutResId) {
protected val widgetContentView: View = itemView.findViewById(R.id.widget_content)
private val dataSaverView: View = itemView.findViewById(R.id.data_saver)
private val dataSaverButton: Button = itemView.findViewById(R.id.data_saver_button)
private val dataSaverHint: TextView = itemView.findViewById(R.id.data_saver_hint)
override fun bind(widget: Widget) {
- boundWidget = widget
+ super.bind(widget)
+ val showLabelAndIcon = widget.label.isNotEmpty()
+ labelView.isVisible = showLabelAndIcon
+ iconView.isVisible = showLabelAndIcon
if (!showDataSaverPlaceholderIfNeeded(widget, canBindWithoutDataTransfer(widget))) {
bindAfterDataSaverCheck(widget)
}
@@ -486,6 +488,7 @@ class WidgetAdapter(
Widget.Type.Webview -> R.string.widget_type_webview
Widget.Type.Video -> R.string.widget_type_video
Widget.Type.Chart -> R.string.widget_type_chart
+ Widget.Type.Mapview -> R.string.widget_type_mapview
else -> throw IllegalArgumentException("Cannot show data saver hint for ${widget.type}")
}
@@ -1462,48 +1465,23 @@ class WidgetAdapter(
}
abstract class AbstractMapViewHolder(initData: ViewHolderInitData) :
- LabeledItemBaseViewHolder(initData, R.layout.widgetlist_mapitem) {
+ HeavyDataViewHolder(initData, R.layout.widgetlist_mapitem) {
private val hasPositions
get() = boundWidget?.item?.state?.asLocation != null || boundWidget?.item?.members?.isNotEmpty() == true
- protected val baseMapView: View = itemView.findViewById(R.id.mapview)
+ protected val baseMapView: View = itemView.findViewById(R.id.widget_content)
private val emptyView: LinearLayout = itemView.findViewById(android.R.id.empty)
- private val dataSaverView: View = itemView.findViewById(R.id.data_saver)
- private val dataSaverButton: Button = itemView.findViewById(R.id.data_saver_button)
- private val dataSaverHint: TextView = itemView.findViewById(R.id.data_saver_hint)
override fun bind(widget: Widget) {
super.bind(widget)
baseMapView.adjustForWidgetHeight(widget, 5)
- handleDataSaver(false)
+ emptyView.isVisible = !hasPositions
}
- private fun handleDataSaver(overrideDataSaver: Boolean) {
- val widget = boundWidget ?: return
- val dataSaverActive = !itemView.context.determineDataUsagePolicy(connection).canDoLargeTransfers &&
- !overrideDataSaver
-
- dataSaverView.isVisible = dataSaverActive && hasPositions
- baseMapView.isVisible = !dataSaverView.isVisible && hasPositions
- emptyView.isVisible = !dataSaverView.isVisible && !hasPositions
-
- if (dataSaverActive) {
- dataSaverButton.setOnClickListener {
- handleDataSaver(true)
- }
-
- dataSaverHint.text = itemView.context.getString(
- R.string.data_saver_hint,
- widget.label.orDefaultIfEmpty(itemView.context.getString(R.string.widget_type_mapview))
- )
- } else {
- dataSaverButton.setOnClickListener(null)
- bindAfterDataSaverCheck(widget)
- }
- }
-
- fun handleDataUsagePolicyChange() {
- boundWidget?.let { bind(it) }
+ @CallSuper
+ override fun bindAfterDataSaverCheck(widget: Widget) {
+ emptyView.isVisible = !hasPositions
+ baseMapView.isVisible = hasPositions
}
override fun handleRowClick() {
@@ -1511,8 +1489,6 @@ class WidgetAdapter(
openPopup()
}
}
-
- protected abstract fun bindAfterDataSaverCheck(widget: Widget)
protected abstract fun openPopup()
}
diff --git a/mobile/src/main/res/layout/widgetlist_chartitem.xml b/mobile/src/main/res/layout/widgetlist_chartitem.xml
index 2d96714f465..b458ce5911b 100644
--- a/mobile/src/main/res/layout/widgetlist_chartitem.xml
+++ b/mobile/src/main/res/layout/widgetlist_chartitem.xml
@@ -1,20 +1,31 @@
-
-
+
+
+ android:descendantFocusability="blocksDescendants">
+
+
+
+
+
+
-
-
+
diff --git a/mobile/src/main/res/layout/widgetlist_icontext_for_heavy_data.xml b/mobile/src/main/res/layout/widgetlist_icontext_for_heavy_data.xml
new file mode 100644
index 00000000000..1e6a674d3ab
--- /dev/null
+++ b/mobile/src/main/res/layout/widgetlist_icontext_for_heavy_data.xml
@@ -0,0 +1,29 @@
+
+
+
+
+
+
+
+
diff --git a/mobile/src/main/res/layout/widgetlist_imageitem.xml b/mobile/src/main/res/layout/widgetlist_imageitem.xml
index ea6b3725943..3486c830690 100644
--- a/mobile/src/main/res/layout/widgetlist_imageitem.xml
+++ b/mobile/src/main/res/layout/widgetlist_imageitem.xml
@@ -1,11 +1,14 @@
-
+
+
-
+
diff --git a/mobile/src/main/res/layout/widgetlist_videoitem.xml b/mobile/src/main/res/layout/widgetlist_videoitem.xml
index ed961cb4a9d..c05ef5fcdff 100644
--- a/mobile/src/main/res/layout/widgetlist_videoitem.xml
+++ b/mobile/src/main/res/layout/widgetlist_videoitem.xml
@@ -1,11 +1,14 @@
-
+
+
-
+
diff --git a/mobile/src/main/res/layout/widgetlist_videomjpegitem.xml b/mobile/src/main/res/layout/widgetlist_videomjpegitem.xml
index fb2afac0ef3..ecafd9dcb28 100644
--- a/mobile/src/main/res/layout/widgetlist_videomjpegitem.xml
+++ b/mobile/src/main/res/layout/widgetlist_videomjpegitem.xml
@@ -1,11 +1,14 @@
-
+
+
-
+
diff --git a/mobile/src/main/res/layout/widgetlist_webitem.xml b/mobile/src/main/res/layout/widgetlist_webitem.xml
index 7d978fbcbc2..0ac41bba8c7 100644
--- a/mobile/src/main/res/layout/widgetlist_webitem.xml
+++ b/mobile/src/main/res/layout/widgetlist_webitem.xml
@@ -1,16 +1,14 @@
-
-
+
+
+
-
+