summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2021-01-16 08:59:22 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2021-01-19 12:42:47 -0800
commite1c269f54ccd075dff8abd70b10d27ca46b4365e (patch)
tree9ae87ae8291008cad4d06746fe4223707bd60406
parentf29534e07f82b3e7505cd657e8f9adf4dee44ce8 (diff)
downloadsubsurface-e1c269f54ccd075dff8abd70b10d27ca46b4365e.tar.gz
mobile/edit: fix broken screen repositioning
In commit 622e5aab69 ("mobile/cleanup: remove more noisy debug output") I had good intentions, but missed the fact that in order to access the 'verbose' variable from QML I needed to use manager.verboseEnabled. The resulting syntax error went unnoticed and broke the screen repositioning when the keyboard opens on mobile devices. Worse, I called a non existing method to do the logging of debug information. And to top it all off, when I fixed the positioning algorithm in commit 765c4f9704 ("mobile/UI: fix the logic to keep input visible"), I forgot to fix the near identical logic for the TextArea for the notes. Fail on so many levels. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--mobile-widgets/qml/DiveDetailsEdit.qml27
-rw-r--r--mobile-widgets/qml/SsrfTextField.qml4
2 files changed, 18 insertions, 13 deletions
diff --git a/mobile-widgets/qml/DiveDetailsEdit.qml b/mobile-widgets/qml/DiveDetailsEdit.qml
index b6b28360e..abaa54abb 100644
--- a/mobile-widgets/qml/DiveDetailsEdit.qml
+++ b/mobile-widgets/qml/DiveDetailsEdit.qml
@@ -788,21 +788,26 @@ Item {
selectByMouse: true
wrapMode: TextEdit.WrapAtWordBoundaryOrAnywhere
property bool firstTime: true
- property int visibleTop: detailsEditFlickable.contentY
- property int visibleBottom: visibleTop + detailsEditFlickable.height - 4 * Kirigami.Units.gridUnit
onPressed: waitForKeyboard.start()
onCursorRectangleChanged: {
- ensureVisible(y + cursorRectangle.y)
+ ensureVisible()
}
-
// ensure that the y coordinate is inside the visible part of the detailsEditFlickable (our flickable)
- function ensureVisible(yDest) {
- if (yDest > visibleBottom)
- detailsEditFlickable.contentY += yDest - visibleBottom
- if (yDest < visibleTop)
- detailsEditFlickable.contentY -= visibleTop - yDest
+ function ensureVisible() {
+ // make sure there's enough space for the TextArea above the keyboard and action button
+ // and that it's not too far up, either
+ var flickable = detailsEditFlickable
+ var positionInFlickable = txtNotes.mapToItem(flickable.contentItem, 0, 0)
+ var taY = positionInFlickable.y + cursorRectangle.y
+ if (manager.verboseEnabled)
+ manager.appendTextToLog("position check: lower edge of view is " +
+ (0 + flickable.contentY + flickable.height) +
+ " and text area is at " + taY)
+ if (taY > flickable.contentY + flickable.height - 4 * Kirigami.Units.gridUnit)
+ flickable.contentY = Math.max(0, 4 * Kirigami.Units.gridUnit + taY - flickable.height)
+ while (taY < flickable.contentY)
+ flickable.contentY -= 2 * Kirigami.Units.gridUnit
}
-
// give the OS enough time to actually resize the flickable
Timer {
id: waitForKeyboard
@@ -816,7 +821,7 @@ Item {
return
}
// make sure at least half the Notes field is visible
- txtNotes.ensureVisible(txtNotes.y + txtNotes.cursorRectangle.y)
+ txtNotes.ensureVisible()
}
}
}
diff --git a/mobile-widgets/qml/SsrfTextField.qml b/mobile-widgets/qml/SsrfTextField.qml
index 083235435..8f07f5ee1 100644
--- a/mobile-widgets/qml/SsrfTextField.qml
+++ b/mobile-widgets/qml/SsrfTextField.qml
@@ -65,8 +65,8 @@ Controls.TextField {
// make sure there's enough space for the input field above the keyboard and action button (and that it's not too far up, either)
var positionInFlickable = stf.mapToItem(flickable.contentItem, 0, 0)
var stfY = positionInFlickable.y
- if (verbose)
- manager.appendTextToLogFile("position check: lower edge of view is " + (0 + flickable.contentY + flickable.height) + " and text field is at " + stfY)
+ if (manager.verboseEnabebled)
+ manager.appendTextToLog("position check: lower edge of view is " + (0 + flickable.contentY + flickable.height) + " and text field is at " + stfY)
if (stfY + stf.height > flickable.contentY + flickable.height - 3 * Kirigami.Units.gridUnit || stfY < flickable.contentY)
flickable.contentY = Math.max(0, 3 * Kirigami.Units.gridUnit + stfY + stf.height - flickable.height)
}