From d69870717f9d62e6ec508fad469676d765ac213c Mon Sep 17 00:00:00 2001 From: marcin Date: Wed, 23 Jul 2014 12:39:35 +0200 Subject: [PATCH] https://trello.com/c/GZwvrma5/55-scrollable-lists-should-have-scrollbars-that-come-into-view-when-hovering-over-that-area-the-extreme-right-of-the-list --- bitmonero.pro.user | 2 +- components/DatePicker.qml | 30 -------------- components/Scroll.qml | 57 +++++++++++++++++++------- images/resize.png | Bin 0 -> 245 bytes images/resizeHovered.png | Bin 0 -> 233 bytes main.qml | 84 ++++++++++++++++++-------------------- pages/AddressBook.qml | 4 +- pages/Dashboard.qml | 4 +- pages/History.qml | 4 +- qml.qrc | 2 + tabs/Twitter.qml | 4 +- 11 files changed, 97 insertions(+), 94 deletions(-) create mode 100644 images/resize.png create mode 100644 images/resizeHovered.png diff --git a/bitmonero.pro.user b/bitmonero.pro.user index e31c9890..a3d58da4 100644 --- a/bitmonero.pro.user +++ b/bitmonero.pro.user @@ -1,6 +1,6 @@ - + ProjectExplorer.Project.ActiveTarget diff --git a/components/DatePicker.qml b/components/DatePicker.qml index 1f9d8f80..6a56f58d 100644 --- a/components/DatePicker.qml +++ b/components/DatePicker.qml @@ -179,22 +179,6 @@ Item { } } } - -// Rectangle { -// anchors.left: parent.left -// anchors.bottom: parent.bottom -// height: 3; width: 3 -// color: "#FFFFFF" -// visible: datePicker.expanded -// } - -// Rectangle { -// anchors.right: parent.right -// anchors.bottom: parent.bottom -// height: 3; width: 3 -// color: "#FFFFFF" -// visible: datePicker.expanded -// } } Rectangle { @@ -223,20 +207,6 @@ Item { height: 1 } -// Rectangle { -// anchors.left: parent.left -// anchors.top: parent.top -// height: 3; width: 3 -// color: "#FFFFFF" -// } - -// Rectangle { -// anchors.right: parent.right -// anchors.top: parent.top -// height: 3; width: 3 -// color: "#FFFFFF" -// } - Calendar { id: calendar anchors.left: parent.left diff --git a/components/Scroll.qml b/components/Scroll.qml index f0a3027e..25aeee8d 100644 --- a/components/Scroll.qml +++ b/components/Scroll.qml @@ -1,29 +1,56 @@ import QtQuick 2.0 -Rectangle { +Item { + id: scrollItem property var flickable - property int yPos: 0 + width: 15 + z: 1 function flickableContentYChanged() { if(flickable === undefined) return - var t = flickable.height - height - y = (flickable.contentY / (flickable.contentHeight - flickable.height)) * t + yPos + var t = flickable.height - scroll.height + scroll.y = (flickable.contentY / (flickable.contentHeight - flickable.height)) * t } - width: 15 - height: { - var t = (flickable.height * flickable.height) / flickable.contentHeight - return t < 20 ? 20 : t + MouseArea { + id: scrollArea + anchors.fill: parent + hoverEnabled: true } - z: 1; y: yPos - color: "#DBDBDB" - anchors.right: flickable.right - opacity: flickable.moving ? 0.5 : 0 - visible: flickable.contentHeight > flickable.height - Behavior on opacity { - NumberAnimation { duration: 100; easing.type: Easing.InQuad } + Rectangle { + id: scroll + + width: 15 + height: { + var t = (flickable.height * flickable.height) / flickable.contentHeight + return t < 20 ? 20 : t + } + y: 0; x: 0 + color: "#DBDBDB" + opacity: flickable.moving || handleArea.pressed || scrollArea.containsMouse ? 0.5 : 0 + visible: flickable.contentHeight > flickable.height + + Behavior on opacity { + NumberAnimation { duration: 100; easing.type: Easing.InQuad } + } + + MouseArea { + id: handleArea + anchors.fill: parent + drag.target: scroll + drag.axis: Drag.YAxis + drag.minimumY: 0 + drag.maximumY: flickable.height - height + propagateComposedEvents: true + + onPositionChanged: { + if(!pressed) return + var dy = scroll.y / (flickable.height - scroll.height) + flickable.contentY = (flickable.contentHeight - flickable.height) * dy + } + } } } diff --git a/images/resize.png b/images/resize.png new file mode 100644 index 0000000000000000000000000000000000000000..ecc0c8804b38df46c52c74164549b1f0cc01e1af GIT binary patch literal 245 zcmeAS@N?(olHy`uVBq!ia0vp^JRr=$1|-8uW1a&kmSQK*5Dp-y;YjHK@;M7UB8wRq zxP?HN@zUM8KR`j564!{5;QX|b^2DN42FH~Aq*MjB%%art{G#k)1?OP17kf7K0M&_s z)HxTWCYEI8=P86_=B6?jnClxE>l>P^t-N3XRN?FC;uxYaaq8*Qq74cHM=xmHbrjr^ zW*c#3$0X)YGt;k`x6fQSEosj=dx;a5J|r=eXKb{t`B*mN;nNL=E+@9PA3S__!2_!m g5(;;go{)IJC_Gl>P^t-N3XRN?69;uxYaaq8)vybKBg%#JVib6UkJ z37ogJ^FEhmeSu4wH^6>HlIe{IPQ5v-@_kIg)s5Y26^`Ujcw{``16K-<0i*u+YX@!} S+!zNmjKR~@&t;ucLK6V|y+slL literal 0 HcmV?d00001 diff --git a/main.qml b/main.qml index 3f4eb529..34f7a3d5 100644 --- a/main.qml +++ b/main.qml @@ -86,7 +86,6 @@ ApplicationWindow { height: 800 color: "#FFFFFF" flags: Qt.FramelessWindowHint | Qt.WindowSystemMenuHint | Qt.Window | Qt.WindowMinimizeButtonHint - onVisibilityChanged: visible = visibility !== Window.Minimized onWidthChanged: x -= 0 Component.onCompleted: { @@ -263,6 +262,46 @@ ApplicationWindow { } property int maxWidth: leftPanel.width + 655 + rightPanel.width + property int maxHeight: 700 + MouseArea { + hoverEnabled: true + anchors.right: parent.right + anchors.bottom: parent.bottom + height: 48 + width: 48 + + Rectangle { + anchors.fill: parent + color: parent.containsMouse || parent.pressed ? "#4A4949" : "transparent" + } + + Image { + anchors.centerIn: parent + source: parent.containsMouse || parent.pressed ? "images/resizeHovered.png" : + "images/resize.png" + } + + property int previousX: 0 + property int previousY: 0 + onPressed: { + previousX = mouseX + previousY = mouseY + } + + onPositionChanged: { + if(!pressed) return + var dx = previousX - mouseX + var dy = previousY - mouseY + + if(appWindow.width - dx > parent.maxWidth) + appWindow.width -= dx + else appWindow.width = parent.maxWidth + + if(appWindow.height - dy > parent.maxHeight) + appWindow.height -= dy + else appWindow.height = parent.maxHeight + } + } // MouseArea { // anchors.top: parent.top @@ -280,49 +319,6 @@ ApplicationWindow { // appWindow.width -= diff // else appWindow.width = parent.maxWidth // } -// } - -// MouseArea { -// anchors.left: parent.left -// anchors.top: parent.top -// anchors.bottom: parent.bottom -// anchors.topMargin: 30 -// anchors.bottomMargin: 3 -// cursorShape: Qt.SizeHorCursor -// width: 3 -// property int previousX: 0 -// property int maximumX: 0 -// onPressed: { -// var diff = appWindow.width - parent.maxWidth -// maximumX = appWindow.x + diff -// previousX = mouseX -// } -// onPositionChanged: { -// var diff = previousX - mouseX -// if(appWindow.x + diff < maximumX) { -// appWindow.width += diff -// appWindow.x -= diff -// } else { -// appWindow.width = parent.maxWidth -// appWindow.x = maximumX -// } -// } -// } - -// MouseArea { -// anchors.left: parent.left -// anchors.right: parent.right -// anchors.bottom: parent.bottom -// anchors.leftMargin: 3 -// anchors.rightMargin: 3 -// height: 3 -// cursorShape: Qt.SizeVerCursor -// property int previousY: 0 -// onPressed: previousY = mouseY -// onPositionChanged: { -// var diff = previousY - mouseY -// appWindow.height -= diff -// } // } TitleBar { diff --git a/pages/AddressBook.qml b/pages/AddressBook.qml index ab526709..73ea500f 100644 --- a/pages/AddressBook.qml +++ b/pages/AddressBook.qml @@ -178,9 +178,11 @@ Rectangle { Scroll { id: flickableScroll + anchors.right: table.right anchors.rightMargin: -14 + anchors.top: table.top + anchors.bottom: table.bottom flickable: table - yPos: table.y } AddressBookTable { diff --git a/pages/Dashboard.qml b/pages/Dashboard.qml index 13f72c18..88480c9a 100644 --- a/pages/Dashboard.qml +++ b/pages/Dashboard.qml @@ -130,9 +130,11 @@ Rectangle { Scroll { id: flickableScroll + anchors.right: table.right anchors.rightMargin: -14 + anchors.top: table.top + anchors.bottom: table.bottom flickable: table - yPos: table.y } DashboardTable { diff --git a/pages/History.qml b/pages/History.qml index 492b50e8..17eb130d 100644 --- a/pages/History.qml +++ b/pages/History.qml @@ -319,9 +319,11 @@ Rectangle { Scroll { id: flickableScroll + anchors.right: table.right anchors.rightMargin: -14 + anchors.top: table.top + anchors.bottom: table.bottom flickable: table - yPos: table.y } HistoryTable { diff --git a/qml.qrc b/qml.qrc index b0a0e6f2..bc40ee0d 100644 --- a/qml.qrc +++ b/qml.qrc @@ -78,5 +78,7 @@ images/moneroLogo2.png components/PrivacyLevelSmall.qml images/checkedVioletIcon.png + images/resize.png + images/resizeHovered.png diff --git a/tabs/Twitter.qml b/tabs/Twitter.qml index b8b55760..b3bded43 100644 --- a/tabs/Twitter.qml +++ b/tabs/Twitter.qml @@ -75,9 +75,11 @@ Item { Scroll { id: flickableScroll + anchors.right: listView.right anchors.rightMargin: -14 + anchors.top: listView.top + anchors.bottom: listView.bottom flickable: listView - yPos: listView.y } ListView {