2023-02-21 23:48:49 +01:00
|
|
|
// SPDX-FileCopyrightText: Nheko Contributors
|
2021-03-14 02:45:20 +01:00
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
2021-03-26 01:20:13 +01:00
|
|
|
import QtQuick 2.12
|
|
|
|
import QtQuick.Controls 2.12
|
|
|
|
import QtQuick.Layouts 1.12
|
2021-05-13 10:57:04 +02:00
|
|
|
import im.nheko 1.0
|
2021-02-23 17:06:21 +01:00
|
|
|
|
2022-01-24 00:41:55 +01:00
|
|
|
ColumnLayout {
|
|
|
|
id: c
|
2023-06-02 01:45:24 +02:00
|
|
|
|
2023-06-02 01:29:05 +02:00
|
|
|
property color backgroundColor: palette.base
|
2022-01-24 00:41:55 +01:00
|
|
|
property alias color: labelC.color
|
2023-06-02 01:45:24 +02:00
|
|
|
property alias echoMode: input.echoMode
|
|
|
|
property alias font: input.font
|
|
|
|
property var hasClear: false
|
2022-01-24 00:41:55 +01:00
|
|
|
property alias label: labelC.text
|
|
|
|
property alias placeholderText: input.placeholderText
|
|
|
|
property alias selectByMouse: input.selectByMouse
|
2023-06-02 01:45:24 +02:00
|
|
|
property alias text: input.text
|
|
|
|
property alias textPadding: input.padding
|
2022-01-28 15:24:56 +01:00
|
|
|
|
2022-01-24 00:41:55 +01:00
|
|
|
signal accepted
|
|
|
|
signal editingFinished
|
2023-06-02 01:45:24 +02:00
|
|
|
signal textEdited
|
2022-01-24 00:41:55 +01:00
|
|
|
|
2022-03-30 04:30:09 +02:00
|
|
|
function clear() {
|
|
|
|
input.clear();
|
|
|
|
}
|
2023-06-02 01:45:24 +02:00
|
|
|
function forceActiveFocus() {
|
|
|
|
input.forceActiveFocus();
|
|
|
|
}
|
2022-03-30 04:30:09 +02:00
|
|
|
|
2022-01-24 00:41:55 +01:00
|
|
|
ToolTip.delay: Nheko.tooltipDelay
|
|
|
|
ToolTip.visible: hover.hovered
|
|
|
|
spacing: 0
|
|
|
|
|
2023-06-02 01:45:24 +02:00
|
|
|
onTextChanged: timer.restart()
|
|
|
|
|
|
|
|
Timer {
|
|
|
|
id: timer
|
|
|
|
|
|
|
|
interval: 350
|
|
|
|
|
|
|
|
onTriggered: editingFinished()
|
|
|
|
}
|
2022-01-24 00:41:55 +01:00
|
|
|
Item {
|
2023-06-02 01:45:24 +02:00
|
|
|
Layout.bottomMargin: Nheko.paddingSmall
|
2022-01-24 00:41:55 +01:00
|
|
|
Layout.fillWidth: true
|
|
|
|
Layout.margins: input.padding
|
2023-06-02 01:45:24 +02:00
|
|
|
Layout.preferredHeight: labelC.contentHeight
|
2022-01-24 00:41:55 +01:00
|
|
|
visible: labelC.text
|
|
|
|
z: 1
|
|
|
|
|
|
|
|
Label {
|
|
|
|
id: labelC
|
|
|
|
|
2023-06-02 01:29:05 +02:00
|
|
|
color: palette.text
|
2023-06-02 01:45:24 +02:00
|
|
|
enabled: false
|
|
|
|
font.letterSpacing: input.font.pixelSize * 0.02
|
2022-01-24 00:41:55 +01:00
|
|
|
font.pixelSize: input.font.pixelSize
|
|
|
|
font.weight: Font.DemiBold
|
|
|
|
state: labelC.text && (input.activeFocus == true || input.text) ? "focused" : ""
|
2023-06-02 01:45:24 +02:00
|
|
|
width: parent.width
|
|
|
|
y: contentHeight + input.padding + Nheko.paddingSmall
|
2022-01-24 00:41:55 +01:00
|
|
|
|
|
|
|
states: State {
|
|
|
|
name: "focused"
|
|
|
|
|
|
|
|
PropertyChanges {
|
2023-10-26 16:43:09 +02:00
|
|
|
labelC.y: 0
|
2022-01-24 00:41:55 +01:00
|
|
|
}
|
|
|
|
PropertyChanges {
|
2023-10-26 16:43:09 +02:00
|
|
|
input.opacity: 1
|
2022-01-24 00:41:55 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
transitions: Transition {
|
|
|
|
from: ""
|
|
|
|
reversible: true
|
2023-06-02 01:45:24 +02:00
|
|
|
to: "focused"
|
2022-01-24 00:41:55 +01:00
|
|
|
|
|
|
|
NumberAnimation {
|
2023-06-02 01:45:24 +02:00
|
|
|
alwaysRunToEnd: true
|
2022-01-24 00:41:55 +01:00
|
|
|
duration: 210
|
|
|
|
easing.type: Easing.InCubic
|
2023-06-02 01:45:24 +02:00
|
|
|
properties: "y"
|
|
|
|
target: labelC
|
2022-01-24 00:41:55 +01:00
|
|
|
}
|
|
|
|
NumberAnimation {
|
2023-06-02 01:45:24 +02:00
|
|
|
alwaysRunToEnd: true
|
2022-01-24 00:41:55 +01:00
|
|
|
duration: 210
|
|
|
|
easing.type: Easing.InCubic
|
2023-06-02 01:45:24 +02:00
|
|
|
properties: "opacity"
|
|
|
|
target: input
|
2022-01-24 00:41:55 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
TextField {
|
|
|
|
id: input
|
|
|
|
|
2023-06-02 01:45:24 +02:00
|
|
|
Layout.fillWidth: true
|
2022-01-24 00:41:55 +01:00
|
|
|
color: labelC.color
|
2022-04-23 01:59:40 +02:00
|
|
|
focus: true
|
2023-06-02 01:45:24 +02:00
|
|
|
opacity: labelC.text ? 0 : 1
|
2022-01-24 00:41:55 +01:00
|
|
|
|
|
|
|
background: Rectangle {
|
|
|
|
id: backgroundRect
|
|
|
|
|
|
|
|
color: labelC.text ? "transparent" : backgroundColor
|
|
|
|
}
|
|
|
|
|
2023-06-02 01:45:24 +02:00
|
|
|
onAccepted: c.accepted()
|
|
|
|
onEditingFinished: c.editingFinished()
|
|
|
|
onTextEdited: c.textEdited()
|
|
|
|
|
2023-01-07 03:43:32 +01:00
|
|
|
ImageButton {
|
2022-12-20 22:34:55 +01:00
|
|
|
id: clearText
|
2023-01-07 03:43:32 +01:00
|
|
|
|
2023-06-02 01:45:24 +02:00
|
|
|
focusPolicy: Qt.NoFocus
|
|
|
|
hoverEnabled: true
|
|
|
|
image: ":/icons/icons/ui/round-remove-button.svg"
|
2022-12-20 22:34:55 +01:00
|
|
|
visible: c.hasClear && searchField.text !== ''
|
2023-01-07 03:43:32 +01:00
|
|
|
|
2022-12-20 22:34:55 +01:00
|
|
|
onClicked: {
|
2023-06-02 01:45:24 +02:00
|
|
|
searchField.clear();
|
2022-12-20 22:34:55 +01:00
|
|
|
topBar.searchString = "";
|
|
|
|
}
|
2023-06-02 01:45:24 +02:00
|
|
|
|
2022-12-20 22:34:55 +01:00
|
|
|
anchors {
|
2023-01-07 03:43:32 +01:00
|
|
|
bottom: parent.bottom
|
2022-12-20 22:34:55 +01:00
|
|
|
right: parent.right
|
2023-01-07 03:43:32 +01:00
|
|
|
rightMargin: Nheko.paddingSmall
|
2023-06-02 01:45:24 +02:00
|
|
|
top: parent.top
|
2022-12-20 22:34:55 +01:00
|
|
|
}
|
|
|
|
}
|
2022-01-24 00:41:55 +01:00
|
|
|
}
|
2021-02-23 17:06:21 +01:00
|
|
|
Rectangle {
|
|
|
|
id: blueBar
|
|
|
|
|
2022-01-24 00:41:55 +01:00
|
|
|
Layout.fillWidth: true
|
2023-06-02 01:29:05 +02:00
|
|
|
color: palette.highlight
|
2023-10-26 16:43:09 +02:00
|
|
|
Layout.preferredHeight: 1
|
2021-03-14 01:24:26 +01:00
|
|
|
|
2021-02-23 17:06:21 +01:00
|
|
|
Rectangle {
|
|
|
|
id: blackBar
|
|
|
|
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2023-06-02 01:45:24 +02:00
|
|
|
anchors.top: parent.top
|
2023-06-02 01:29:05 +02:00
|
|
|
color: palette.text
|
2023-06-02 01:45:24 +02:00
|
|
|
height: parent.height * 2
|
|
|
|
width: 0
|
2021-03-14 01:24:26 +01:00
|
|
|
|
2021-02-23 17:06:21 +01:00
|
|
|
states: State {
|
2021-03-14 01:24:26 +01:00
|
|
|
name: "focused"
|
|
|
|
when: input.activeFocus == true
|
|
|
|
|
2021-02-23 17:06:21 +01:00
|
|
|
PropertyChanges {
|
2023-10-26 16:43:09 +02:00
|
|
|
blackBar.width: blueBar.width
|
2021-02-23 17:06:21 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
transitions: Transition {
|
|
|
|
from: ""
|
|
|
|
reversible: true
|
2023-06-02 01:45:24 +02:00
|
|
|
to: "focused"
|
2022-01-24 00:41:55 +01:00
|
|
|
|
2021-03-14 01:24:26 +01:00
|
|
|
NumberAnimation {
|
2023-06-02 01:45:24 +02:00
|
|
|
alwaysRunToEnd: true
|
2022-01-24 00:41:55 +01:00
|
|
|
duration: 310
|
|
|
|
easing.type: Easing.InCubic
|
2023-06-02 01:45:24 +02:00
|
|
|
properties: "width"
|
|
|
|
target: blackBar
|
2021-02-23 17:06:21 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-01-24 00:41:55 +01:00
|
|
|
HoverHandler {
|
|
|
|
id: hover
|
2023-06-02 01:45:24 +02:00
|
|
|
|
2022-01-24 00:41:55 +01:00
|
|
|
enabled: c.ToolTip.text
|
2021-03-14 01:24:26 +01:00
|
|
|
}
|
|
|
|
}
|