231 lines
7.3 KiB
QML
Raw Normal View History

2020-07-03 12:54:27 -04:00
import QtQuick 2.13
import QtQuick.Controls 2.13
import QtQuick.Layouts 1.13
import "../../../../imports"
import "../../../../shared"
2020-09-17 18:42:59 +02:00
import "../../../../shared/status"
2020-07-03 12:54:27 -04:00
Item {
id: syncContainer
2020-07-03 15:46:06 -04:00
property bool isSyncing: false
2020-07-03 12:54:27 -04:00
width: 200
height: 200
Layout.fillHeight: true
Layout.fillWidth: true
StyledText {
id: sectionTitle
//% "Devices"
text: qsTrId("devices")
2020-07-03 12:54:27 -04:00
anchors.left: parent.left
anchors.leftMargin: 24
anchors.top: parent.top
anchors.topMargin: 24
font.weight: Font.Bold
font.pixelSize: 20
}
Item {
id: firstTimeSetup
anchors.left: syncContainer.left
2020-07-03 15:46:06 -04:00
anchors.leftMargin: Style.current.padding
2020-07-03 12:54:27 -04:00
anchors.top: sectionTitle.bottom
2020-07-03 15:46:06 -04:00
anchors.topMargin: Style.current.padding
2020-07-03 12:54:27 -04:00
anchors.right: syncContainer.right
2020-07-03 15:46:06 -04:00
anchors.rightMargin: Style.current.padding
2020-12-06 18:15:51 -04:00
visible: !profileModel.devices.isSetup
2020-07-03 12:54:27 -04:00
StyledText {
id: deviceNameLbl
//% "Please set a name for your device."
text: qsTrId("pairing-please-set-a-name")
2020-07-03 12:54:27 -04:00
font.pixelSize: 14
}
Input {
id: deviceNameTxt
//% "Specify a name"
placeholderText: qsTrId("specify-name")
2020-07-03 12:54:27 -04:00
anchors.top: deviceNameLbl.bottom
2020-07-03 15:46:06 -04:00
anchors.topMargin: Style.current.padding
2020-07-03 12:54:27 -04:00
}
StyledButton {
anchors.top: deviceNameTxt.bottom
anchors.topMargin: 10
anchors.right: deviceNameTxt.right
//% "Continue"
label: qsTrId("continue")
2020-07-03 12:54:27 -04:00
disabled: deviceNameTxt.text === ""
2020-12-06 18:15:51 -04:00
onClicked : profileModel.devices.setName(deviceNameTxt.text.trim())
2020-07-03 12:54:27 -04:00
}
}
2020-07-03 15:46:06 -04:00
Item {
2020-07-03 20:42:44 -04:00
id: advertiseDeviceItem
2020-07-03 15:46:06 -04:00
anchors.left: syncContainer.left
anchors.leftMargin: Style.current.padding
anchors.top: sectionTitle.bottom
anchors.topMargin: Style.current.padding
anchors.right: syncContainer.right
anchors.rightMargin: Style.current.padding
2020-12-06 18:15:51 -04:00
visible: profileModel.devices.isSetup
2020-07-03 20:42:44 -04:00
height: childrenRect.height
2020-07-03 15:46:06 -04:00
Rectangle {
id: advertiseDevice
height: childrenRect.height
width: 500
anchors.left: parent.left
anchors.right: parent.right
2020-07-15 00:57:49 +02:00
color: Style.current.transparent
2020-07-03 15:46:06 -04:00
SVGImage {
id: advertiseImg
height: 32
width: 32
anchors.left: parent.left
fillMode: Image.PreserveAspectFit
source: "/app/img/messageActive.svg"
}
StyledText {
id: advertiseDeviceTitle
//% "Advertise device"
text: qsTrId("pair-this-device")
2020-07-03 15:46:06 -04:00
font.pixelSize: 18
font.weight: Font.Bold
color: Style.current.blue
anchors.left: advertiseImg.right
anchors.leftMargin: Style.current.padding
}
StyledText {
id: advertiseDeviceDesk
//% "Pair your devices to sync contacts and chats between them"
text: qsTrId("pair-this-device-description")
2020-07-03 15:46:06 -04:00
font.pixelSize: 14
anchors.top: advertiseDeviceTitle.bottom
anchors.topMargin: 6
anchors.left: advertiseImg.right
anchors.leftMargin: Style.current.padding
}
MouseArea {
cursorShape: Qt.PointingHandCursor
anchors.fill: parent
2020-12-06 18:15:51 -04:00
onClicked: profileModel.devices.advertise()
2020-07-03 15:46:06 -04:00
}
}
StyledText {
anchors.top: advertiseDevice.bottom
anchors.topMargin: Style.current.padding
//% "Learn more"
text: qsTrId("learn-more")
2020-07-03 15:46:06 -04:00
font.pixelSize: 16
color: Style.current.blue
anchors.left: parent.left
MouseArea {
cursorShape: Qt.PointingHandCursor
anchors.fill: parent
onClicked: appMain.openLink("https://status.im/user_guides/pairing_devices.html")
2020-07-03 15:46:06 -04:00
}
}
}
2020-07-03 20:42:44 -04:00
Item {
id: deviceListItem
anchors.left: syncContainer.left
anchors.leftMargin: Style.current.padding
anchors.top: advertiseDeviceItem.bottom
anchors.topMargin: Style.current.padding * 2
anchors.bottom: syncAllBtn.top
anchors.bottomMargin: Style.current.padding
anchors.right: syncContainer.right
anchors.rightMargin: Style.current.padding
2020-12-06 18:15:51 -04:00
visible: profileModel.devices.isSetup
2020-07-03 20:42:44 -04:00
StyledText {
id: deviceListLbl
2020-07-16 11:20:29 -04:00
//% "Paired devices"
text: qsTrId("paired-devices")
2020-07-03 20:42:44 -04:00
font.pixelSize: 16
font.weight: Font.Bold
}
ListView {
id: listView
anchors.bottom: parent.bottom
anchors.top: deviceListLbl.bottom
anchors.topMargin: Style.current.padding
spacing: 5
anchors.right: parent.right
anchors.left: parent.left
2020-07-03 20:42:44 -04:00
delegate: Item {
height: childrenRect.height
SVGImage {
id: enabledIcon
source: "/app/img/" + (devicePairedSwitch.checked ? "messageActive.svg" : "message.svg")
height: 24
width: 24
}
StyledText {
id: deviceItemLbl
text: {
let deviceId = model.installationId.split("-")[0].substr(0, 5)
2020-07-16 11:20:29 -04:00
//% "No info"
//% "you"
let labelText = `${model.name || qsTrId("pairing-no-info")} (${model.isUserDevice ? qsTrId("you") + ", ": ""}${deviceId})`;
2020-07-03 20:42:44 -04:00
return labelText;
}
elide: Text.ElideRight
font.pixelSize: 14
anchors.left: enabledIcon.right
anchors.leftMargin: Style.current.padding
}
2020-09-17 18:42:59 +02:00
StatusSwitch {
2020-07-03 20:42:44 -04:00
id: devicePairedSwitch
visible: !model.isUserDevice
checked: model.isEnabled
anchors.left: deviceItemLbl.right
anchors.leftMargin: Style.current.padding
anchors.top: deviceItemLbl.top
2020-12-06 18:15:51 -04:00
onClicked: profileModel.devices.enableInstallation(model.installationId, devicePairedSwitch)
2020-07-03 20:42:44 -04:00
}
}
2020-12-06 18:15:51 -04:00
model: profileModel.devices.list
2020-07-03 20:42:44 -04:00
}
}
2020-07-03 12:54:27 -04:00
StyledButton {
2020-07-03 15:46:06 -04:00
id: syncAllBtn
2020-07-03 12:54:27 -04:00
anchors.bottom: syncContainer.bottom
2020-07-03 15:46:06 -04:00
anchors.bottomMargin: Style.current.padding
anchors.horizontalCenter: parent.horizontalCenter
label: isSyncing ?
//% "Syncing..."
qsTrId("sync-in-progress") :
//% "Sync all devices"
qsTrId("sync-all-devices")
2020-07-03 15:46:06 -04:00
disabled: isSyncing
2020-07-03 12:54:27 -04:00
onClicked : {
2020-07-03 15:46:06 -04:00
isSyncing = true;
2020-12-06 18:15:51 -04:00
profileModel.devices.syncAll()
2020-07-03 15:46:06 -04:00
// Currently we don't know how long it takes, so we just disable for 10s, to avoid spamming
timer.setTimeout(function(){
isSyncing = false
}, 10000);
}
}
Timer {
id: timer
2020-07-03 12:54:27 -04:00
}
}