import QtQuick 2.15 import QtQuick.Controls 2.15 import QtQuick.Layouts 1.15 import StatusQ.Controls 0.1 import StatusQ.Core 0.1 import StatusQ.Core.Theme 0.1 import StatusQ.Components 0.1 import AppLayouts.Onboarding.stores 1.0 import AppLayouts.Onboarding.shared 1.0 import utils 1.0 Item { id: root property StartupStore startupStore QtObject { id: d property int counter: Constants.onboarding.profileFetching.timeout // NOTE: This block can be removed when fetching backup is optimized // https://github.com/status-im/status-go/issues/5022 readonly property bool minimumWaitingTimePassed: (Constants.onboarding.profileFetching.timeout - counter) > 30000 readonly property bool fetching: root.startupStore.currentStartupState.stateType === Constants.startupState.profileFetching || !d.minimumWaitingTimePassed readonly property string fetchingDataText: qsTr("Fetching data...") readonly property string continueText: qsTr("Continue") } onStateChanged: { if (root.state === Constants.startupState.profileFetching) { d.counter = Constants.onboarding.profileFetching.timeout } } ColumnLayout { anchors.centerIn: parent spacing: Theme.bigPadding ProfileFetchingAnimation { id: loadingAnimation Layout.alignment: Qt.AlignHCenter state: root.state } StatusBaseText { id: title visible: text.length > 0 Layout.alignment: Qt.AlignHCenter font.weight: Font.Bold font.pixelSize: Constants.onboarding.profileFetching.titleFontSize } ListView { Layout.preferredWidth: 345 Layout.alignment: Qt.AlignCenter implicitHeight: contentItem.childrenRect.height clip: true spacing: 8 model: root.startupStore.fetchingDataModel delegate: Item { width: ListView.view.width height: 32 StatusIcon { id: icon anchors.left: parent.left anchors.verticalCenter: parent.verticalCenter width: 20 height: 20 color: Theme.palette.baseColor1 icon: model.icon } StatusBaseText { id: entity anchors.left: icon.right anchors.right: indicator.visible? indicator.left : loaded.left anchors.leftMargin: 16 anchors.verticalCenter: parent.verticalCenter leftPadding: 4 font.pixelSize: Constants.onboarding.profileFetching.entityFontSize text: { switch(model.entity) { case Constants.onboarding.profileFetching.entity.profile: return qsTr("Profile details") case Constants.onboarding.profileFetching.entity.contacts: return qsTr("Contacts") case Constants.onboarding.profileFetching.entity.communities: return qsTr("Community membership") case Constants.onboarding.profileFetching.entity.settings: return qsTr("Settings") case Constants.onboarding.profileFetching.entity.keypairs: return qsTr("Key pairs") case Constants.onboarding.profileFetching.entity.watchOnlyAccounts: return qsTr("Watched addresses") } } } StatusLoadingIndicator { id: indicator anchors.right: parent.right anchors.verticalCenter: parent.verticalCenter visible: model.totalMessages === 0 } StatusBaseText { id: loaded anchors.right: parent.right anchors.verticalCenter: parent.verticalCenter visible: !indicator.visible rightPadding: 4 font.pixelSize: Constants.onboarding.profileFetching.entityProgressFontSize color: Theme.palette.baseColor1 text: "%1/%2".arg(model.loadedMessages).arg(model.totalMessages) } StatusProgressBar { id: progress anchors.top: entity.bottom anchors.left: entity.left anchors.right: parent.right anchors.topMargin: 4 height: 3 from: 0 to: model.totalMessages value: model.loadedMessages backgroundColor: Theme.palette.baseColor5 backgroundBorderColor: backgroundColor fillColor: { if (model.totalMessages > 0 && model.totalMessages === model.loadedMessages) return Theme.palette.successColor1 return Theme.palette.primaryColor1 } } } ScrollBar.vertical: ScrollBar {} } StatusButton { id: button Layout.alignment: Qt.AlignHCenter focus: true enabled: !d.fetching Timer { id: timer interval: 1000 running: d.fetching repeat: true onTriggered: { d.counter = d.counter - 1000 // decrease 1000 ms if (d.counter == 0) { root.startupStore.doPrimaryAction() } } } onClicked: { root.startupStore.doPrimaryAction() } } Item { Layout.fillWidth: true Layout.fillHeight: true } } states: [ State { name: Constants.startupState.profileFetching when: d.fetching PropertyChanges { target: title text: d.fetchingDataText } PropertyChanges { target: button text: { let date = new Date(0) date.setTime(date.getTime() + d.counter) return Qt.formatTime(date, "m:ss") } } PropertyChanges { target: d counter: Constants.onboarding.profileFetching.timeout } }, State { name: Constants.startupState.profileFetchingTimeout when: root.startupStore.currentStartupState.stateType === Constants.startupState.profileFetchingTimeout PropertyChanges { target: title text: d.fetchingDataText } PropertyChanges { target: button text: d.continueText } }, State { name: Constants.startupState.profileFetchingSuccess when: root.startupStore.currentStartupState.stateType === Constants.startupState.profileFetchingSuccess PropertyChanges { target: title text: d.fetchingDataText } PropertyChanges { target: button text: d.continueText } } ] }