Merge pull request #348 from amnezia-vpn/bugfix/changed_textfield_border_hover_color

added border hover effect for textarea
This commit is contained in:
Nethius 2023-09-29 16:24:28 +03:00 committed by GitHub
commit ed1afa7549
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 100 additions and 49 deletions

View file

@ -9,71 +9,99 @@ Rectangle {
property alias textArea: textArea property alias textArea: textArea
property alias textAreaText: textArea.text property alias textAreaText: textArea.text
property string borderHoveredColor: "#494B50"
property string borderNormalColor: "#2C2D30"
property string borderFocusedColor: "#d7d8db"
height: 148 height: 148
color: "#1C1D21" color: "#1C1D21"
border.width: 1 border.width: 1
border.color: "#2C2D30" border.color: getBorderColor(borderNormalColor)
radius: 16 radius: 16
FlickableType { MouseArea {
id: fl id: parentMouse
interactive: false anchors.fill: parent
cursorShape: Qt.IBeamCursor
onClicked: textArea.forceActiveFocus()
hoverEnabled: true
anchors.top: parent.top FlickableType {
anchors.bottom: parent.bottom id: fl
contentHeight: textArea.implicitHeight interactive: false
TextArea {
id: textArea
width: parent.width anchors.top: parent.top
anchors.bottom: parent.bottom
contentHeight: textArea.implicitHeight
TextArea {
id: textArea
topPadding: 16 width: parent.width
leftPadding: 16
anchors.topMargin: 16
anchors.bottomMargin: 16
color: "#D7D8DB" topPadding: 16
selectionColor: "#633303" leftPadding: 16
selectedTextColor: "#D7D8DB" anchors.topMargin: 16
placeholderTextColor: "#878B91" anchors.bottomMargin: 16
font.pixelSize: 16 color: "#D7D8DB"
font.weight: Font.Medium selectionColor: "#633303"
font.family: "PT Root UI VF" selectedTextColor: "#D7D8DB"
placeholderTextColor: "#878B91"
placeholderText: root.placeholderText font.pixelSize: 16
text: root.text font.weight: Font.Medium
font.family: "PT Root UI VF"
onCursorVisibleChanged: { placeholderText: root.placeholderText
if (textArea.cursorVisible) { text: root.text
fl.interactive = true
} else { onCursorVisibleChanged: {
fl.interactive = false if (textArea.cursorVisible) {
fl.interactive = true
} else {
fl.interactive = false
}
}
wrapMode: Text.Wrap
MouseArea {
id: textAreaMouse
anchors.fill: parent
acceptedButtons: Qt.RightButton
hoverEnabled: true
onClicked: {
fl.interactive = true
contextMenu.open()
}
}
onFocusChanged: {
root.border.color = getBorderColor(borderNormalColor)
}
ContextMenuType {
id: contextMenu
textObj: textArea
} }
} }
}
wrapMode: Text.Wrap onPressed: {
root.border.color = getBorderColor(borderFocusedColor)
}
MouseArea { onExited: {
anchors.fill: parent root.border.color = getBorderColor(borderNormalColor)
acceptedButtons: Qt.RightButton }
onClicked: {
fl.interactive = true
contextMenu.open()
}
}
ContextMenuType { onEntered: {
id: contextMenu root.border.color = getBorderColor(borderHoveredColor)
textObj: textArea
}
} }
} }
//todo make whole background clickable, with code below we lose ability to select text by mouse
// MouseArea { function getBorderColor(noneFocusedColor) {
// anchors.fill: parent return textArea.focus ? root.borderFocusedColor : noneFocusedColor
// cursorShape: Qt.IBeamCursor }
// onClicked: textArea.forceActiveFocus()
// }
} }

View file

@ -30,6 +30,7 @@ Item {
property string backgroundColor: "#1c1d21" property string backgroundColor: "#1c1d21"
property string backgroundDisabledColor: "transparent" property string backgroundDisabledColor: "transparent"
property string bgBorderHoveredColor: "#494B50"
implicitWidth: content.implicitWidth implicitWidth: content.implicitWidth
implicitHeight: content.implicitHeight implicitHeight: content.implicitHeight
@ -44,7 +45,7 @@ Item {
Layout.preferredHeight: input.implicitHeight Layout.preferredHeight: input.implicitHeight
color: root.enabled ? root.backgroundColor : root.backgroundDisabledColor color: root.enabled ? root.backgroundColor : root.backgroundDisabledColor
radius: 16 radius: 16
border.color: textField.focus ? root.borderFocusedColor : root.borderColor border.color: getBackgroundBorderColor(root.borderColor)
border.width: 1 border.width: 1
Behavior on border.color { Behavior on border.color {
@ -102,12 +103,17 @@ Item {
anchors.fill: parent anchors.fill: parent
acceptedButtons: Qt.RightButton acceptedButtons: Qt.RightButton
onClicked: contextMenu.open() onClicked: contextMenu.open()
enabled: true
} }
ContextMenuType { ContextMenuType {
id: contextMenu id: contextMenu
textObj: textField textObj: textField
} }
onFocusChanged: {
backgroud.border.color = getBackgroundBorderColor(root.borderColor)
}
} }
} }
@ -149,11 +155,28 @@ Item {
MouseArea { MouseArea {
anchors.fill: root anchors.fill: root
cursorShape: Qt.PointingHandCursor cursorShape: Qt.IBeamCursor
hoverEnabled: true
onPressed: function(mouse) { onPressed: function(mouse) {
textField.forceActiveFocus() textField.forceActiveFocus()
mouse.accepted = false mouse.accepted = false
backgroud.border.color = getBackgroundBorderColor(root.borderColor)
}
onEntered: {
backgroud.border.color = getBackgroundBorderColor(bgBorderHoveredColor)
}
onExited: {
backgroud.border.color = getBackgroundBorderColor(root.borderColor)
} }
} }
function getBackgroundBorderColor(noneFocusedColor) {
return textField.focus ? root.borderFocusedColor : noneFocusedColor
}
} }