mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-10 14:26:34 +00:00
33d38a4081
- Added local pairing signals - Remove slash ending from keystorePath - Implemented localPairingState. Fixed sync new device workflow. - Error message view design update - Moved local pairing status to devices service - ConnectionString automatic validation - Async inputConnectionString - Added all installation properties to model. Minor renaming. - Removed emoji and color customization - Show display name, colorhash and color in device being synced - Add timeout to pairing server - Add device type Fix `DeviceSyncingView` sizing. Fix `inputConnectionString` async task slot.
78 lines
1.9 KiB
QML
78 lines
1.9 KiB
QML
import QtQuick 2.14
|
|
|
|
import StatusQ.Core 0.1
|
|
import StatusQ.Core.Theme 0.1
|
|
import StatusQ.Controls 0.1
|
|
|
|
StatusInput {
|
|
id: root
|
|
|
|
// TODO: Use https://github.com/status-im/status-desktop/issues/6136
|
|
|
|
enum Mode {
|
|
WriteMode,
|
|
ReadMode
|
|
}
|
|
|
|
property int mode: StatusSyncCodeInput.Mode.WriteMode
|
|
property bool readOnly: false
|
|
|
|
QtObject {
|
|
id: d
|
|
readonly property bool writeMode: root.mode === StatusSyncCodeInput.Mode.WriteMode
|
|
}
|
|
|
|
label: d.writeMode ? qsTr("Paste sync code") : qsTr("Sync code")
|
|
input.edit.readOnly: root.readOnly
|
|
input.placeholderText: d.writeMode ? qsTr("eg. %1").arg("0x2Ef19") : ""
|
|
input.font: Theme.palette.monoFont.name
|
|
input.placeholderFont: root.input.font
|
|
|
|
input.rightComponent: {
|
|
switch (root.mode) {
|
|
case StatusSyncCodeInput.Mode.WriteMode:
|
|
return root.valid ? validCodeIconComponent
|
|
: pasteButtonComponent
|
|
case StatusSyncCodeInput.Mode.ReadMode:
|
|
return copyButtonComponent
|
|
}
|
|
}
|
|
|
|
Component {
|
|
id: copyButtonComponent
|
|
|
|
StatusButton {
|
|
size: StatusBaseButton.Size.Tiny
|
|
text: qsTr("Copy")
|
|
onClicked: {
|
|
root.input.edit.selectAll();
|
|
root.input.edit.copy();
|
|
root.input.edit.deselect();
|
|
}
|
|
}
|
|
}
|
|
|
|
Component {
|
|
id: pasteButtonComponent
|
|
|
|
StatusButton {
|
|
size: StatusBaseButton.Size.Tiny
|
|
enabled: !root.readOnly && root.input.edit.canPaste
|
|
text: qsTr("Paste")
|
|
onClicked: {
|
|
root.input.edit.selectAll();
|
|
root.input.edit.paste();
|
|
}
|
|
}
|
|
}
|
|
|
|
Component {
|
|
id: validCodeIconComponent
|
|
|
|
StatusIcon {
|
|
icon: "tiny/checkmark"
|
|
color: Theme.palette.successColor1
|
|
}
|
|
}
|
|
}
|