fix(ProfileShowcase): Add live preview support in the profile view (#13972)
* fix(ProfileShowcase): Add live preview support in the profile view * Update ui/imports/shared/views/profile/ProfileShowcaseView.qml Co-authored-by: Lukáš Tinkl <lukast@status.im> --------- Co-authored-by: Lukáš Tinkl <lukast@status.im>
This commit is contained in:
parent
e5567d06f4
commit
3a3c3204fa
|
@ -44,6 +44,10 @@ SettingsContentBase {
|
||||||
property string displayName: descriptionPanel.displayName.text
|
property string displayName: descriptionPanel.displayName.text
|
||||||
property string bio: descriptionPanel.bio.text
|
property string bio: descriptionPanel.bio.text
|
||||||
property url profileLargeImage: profileHeader.previewIcon
|
property url profileLargeImage: profileHeader.previewIcon
|
||||||
|
property var socialLinks: priv.showcaseModels.socialLinksVisibleModel
|
||||||
|
property var communitiesModel: priv.showcaseModels.communitiesVisibleModel
|
||||||
|
property var accountsModel: priv.showcaseModels.accountsVisibleModel
|
||||||
|
property var collectiblesModel: priv.showcaseModels.collectiblesVisibleModel
|
||||||
}
|
}
|
||||||
|
|
||||||
enum TabIndex {
|
enum TabIndex {
|
||||||
|
@ -322,6 +326,8 @@ SettingsContentBase {
|
||||||
contactsStore: root.contactsStore
|
contactsStore: root.contactsStore
|
||||||
networkConnectionStore: root.networkConnectionStore
|
networkConnectionStore: root.networkConnectionStore
|
||||||
onClosed: destroy()
|
onClosed: destroy()
|
||||||
|
dirtyValues: root.dirtyValues
|
||||||
|
dirty: root.dirty
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,9 @@ StatusDialog {
|
||||||
property var contactsStore
|
property var contactsStore
|
||||||
property var networkConnectionStore
|
property var networkConnectionStore
|
||||||
|
|
||||||
|
property var dirtyValues: ({})
|
||||||
|
property bool dirty: false
|
||||||
|
|
||||||
width: 640
|
width: 640
|
||||||
padding: 0
|
padding: 0
|
||||||
|
|
||||||
|
@ -27,5 +30,7 @@ StatusDialog {
|
||||||
contactsStore: root.contactsStore
|
contactsStore: root.contactsStore
|
||||||
networkConnectionStore: root.networkConnectionStore
|
networkConnectionStore: root.networkConnectionStore
|
||||||
onCloseRequested: root.close()
|
onCloseRequested: root.close()
|
||||||
|
dirtyValues: root.dirtyValues
|
||||||
|
dirty: root.dirty
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -611,6 +611,9 @@ Pane {
|
||||||
walletStore: root.walletStore
|
walletStore: root.walletStore
|
||||||
networkConnectionStore: root.networkConnectionStore
|
networkConnectionStore: root.networkConnectionStore
|
||||||
|
|
||||||
|
livePreview: root.dirty
|
||||||
|
livePreviewValues: root.dirtyValues
|
||||||
|
|
||||||
onCloseRequested: root.closeRequested()
|
onCloseRequested: root.closeRequested()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ import QtQuick 2.15
|
||||||
import QtQuick.Controls 2.15
|
import QtQuick.Controls 2.15
|
||||||
import QtQuick.Layouts 1.15
|
import QtQuick.Layouts 1.15
|
||||||
|
|
||||||
|
import StatusQ 0.1
|
||||||
import StatusQ.Core 0.1
|
import StatusQ.Core 0.1
|
||||||
import StatusQ.Core.Theme 0.1
|
import StatusQ.Core.Theme 0.1
|
||||||
import StatusQ.Controls 0.1
|
import StatusQ.Controls 0.1
|
||||||
|
@ -26,14 +27,17 @@ Control {
|
||||||
property var walletStore
|
property var walletStore
|
||||||
property var networkConnectionStore
|
property var networkConnectionStore
|
||||||
|
|
||||||
|
property bool livePreview: false
|
||||||
|
property var livePreviewValues: ({})
|
||||||
|
|
||||||
signal closeRequested()
|
signal closeRequested()
|
||||||
|
|
||||||
onVisibleChanged: if (visible) profileStore.requestProfileShowcase(publicKey)
|
onVisibleChanged: if (visible && !livePreview) profileStore.requestProfileShowcase(publicKey)
|
||||||
|
|
||||||
horizontalPadding: readOnly ? 20 : 40 // smaller in settings/preview
|
horizontalPadding: readOnly ? 20 : 40 // smaller in settings/preview
|
||||||
topPadding: Style.current.bigPadding
|
topPadding: Style.current.bigPadding
|
||||||
|
|
||||||
QtObject {
|
StatusQUtils.QObject {
|
||||||
id: d
|
id: d
|
||||||
|
|
||||||
readonly property string copyLiteral: qsTr("Copy")
|
readonly property string copyLiteral: qsTr("Copy")
|
||||||
|
@ -41,6 +45,66 @@ Control {
|
||||||
readonly property var timer: Timer {
|
readonly property var timer: Timer {
|
||||||
id: timer
|
id: timer
|
||||||
}
|
}
|
||||||
|
|
||||||
|
readonly property var communitiesModel: root.livePreview ? liveCommunitiesModel
|
||||||
|
: communitiesStoreModel
|
||||||
|
readonly property var accountsModel: root.livePreview ? root.livePreviewValues.accountsModel
|
||||||
|
: accountsStoreModel
|
||||||
|
readonly property var collectiblesModel: root.livePreview ? root.livePreviewValues.collectiblesModel
|
||||||
|
: collectiblesStoreModel
|
||||||
|
// TODO: add dirty values to the livePreviewValues once assets are supported
|
||||||
|
// readonly property assetsModel: root.livePreview ? root.livePreviewValues.assetsModel
|
||||||
|
// : root.profileStore.profileShowcaseAssetsModel
|
||||||
|
readonly property var assetsModel: root.profileStore.profileShowcaseAssetsModel
|
||||||
|
readonly property var socialLinksModel: root.livePreview ? root.livePreviewValues.socialLinksModel
|
||||||
|
: root.profileStore.socialLinksModel
|
||||||
|
SortFilterProxyModel {
|
||||||
|
id: liveCommunitiesModel
|
||||||
|
sourceModel: root.livePreviewValues.communitiesModel
|
||||||
|
proxyRoles: [
|
||||||
|
FastExpressionRole {
|
||||||
|
name: "membersCount"
|
||||||
|
expression: model.members.count
|
||||||
|
expectedRoles: ["members"]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
SortFilterProxyModel {
|
||||||
|
id: communitiesStoreModel
|
||||||
|
sourceModel: root.profileStore.profileShowcaseCommunitiesModel
|
||||||
|
filters: [
|
||||||
|
ValueFilter {
|
||||||
|
roleName: "showcaseVisibility"
|
||||||
|
value: Constants.ShowcaseVisibility.NoOne
|
||||||
|
inverted: true
|
||||||
|
},
|
||||||
|
ValueFilter {
|
||||||
|
roleName: "loading"
|
||||||
|
value: false
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
SortFilterProxyModel {
|
||||||
|
id: accountsStoreModel
|
||||||
|
sourceModel: root.profileStore.profileShowcaseAccountsModel
|
||||||
|
filters: ValueFilter {
|
||||||
|
roleName: "showcaseVisibility"
|
||||||
|
value: Constants.ShowcaseVisibility.NoOne
|
||||||
|
inverted: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
SortFilterProxyModel {
|
||||||
|
id: collectiblesStoreModel
|
||||||
|
sourceModel: root.profileStore.profileShowcaseCollectiblesModel
|
||||||
|
filters: ValueFilter {
|
||||||
|
roleName: "showcaseVisibility"
|
||||||
|
value: Constants.ShowcaseVisibility.NoOne
|
||||||
|
inverted: true
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
background: StatusDialogBackground {
|
background: StatusDialogBackground {
|
||||||
|
@ -79,20 +143,7 @@ Control {
|
||||||
cellWidth: (width-rightMargin)/2
|
cellWidth: (width-rightMargin)/2
|
||||||
cellHeight: cellWidth/2
|
cellHeight: cellWidth/2
|
||||||
visible: count
|
visible: count
|
||||||
model: SortFilterProxyModel {
|
model: d.communitiesModel
|
||||||
sourceModel: root.profileStore.profileShowcaseCommunitiesModel
|
|
||||||
filters: [
|
|
||||||
ValueFilter {
|
|
||||||
roleName: "showcaseVisibility"
|
|
||||||
value: Constants.ShowcaseVisibility.NoOne
|
|
||||||
inverted: true
|
|
||||||
},
|
|
||||||
ValueFilter {
|
|
||||||
roleName: "loading"
|
|
||||||
value: false
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
ScrollBar.vertical: StatusScrollBar { }
|
ScrollBar.vertical: StatusScrollBar { }
|
||||||
delegate: StatusListItem { // TODO custom delegate
|
delegate: StatusListItem { // TODO custom delegate
|
||||||
width: GridView.view.cellWidth - Style.current.smallPadding
|
width: GridView.view.cellWidth - Style.current.smallPadding
|
||||||
|
@ -149,14 +200,7 @@ Control {
|
||||||
id: accountsView
|
id: accountsView
|
||||||
spacing: Style.current.halfPadding
|
spacing: Style.current.halfPadding
|
||||||
visible: count
|
visible: count
|
||||||
model: SortFilterProxyModel {
|
model: d.accountsModel
|
||||||
sourceModel: root.profileStore.profileShowcaseAccountsModel
|
|
||||||
filters: ValueFilter {
|
|
||||||
roleName: "showcaseVisibility"
|
|
||||||
value: Constants.ShowcaseVisibility.NoOne
|
|
||||||
inverted: true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
delegate: StatusListItem {
|
delegate: StatusListItem {
|
||||||
id: accountDelegate
|
id: accountDelegate
|
||||||
property bool saved: {
|
property bool saved: {
|
||||||
|
@ -253,14 +297,7 @@ Control {
|
||||||
cellHeight: cellWidth
|
cellHeight: cellWidth
|
||||||
visible: count
|
visible: count
|
||||||
// TODO Issue #11637: Dedicated controller for user's list of collectibles (no watch-only entries)
|
// TODO Issue #11637: Dedicated controller for user's list of collectibles (no watch-only entries)
|
||||||
model: SortFilterProxyModel {
|
model: d.collectiblesModel
|
||||||
sourceModel: root.profileStore.profileShowcaseCollectiblesModel
|
|
||||||
filters: ValueFilter {
|
|
||||||
roleName: "showcaseVisibility"
|
|
||||||
value: Constants.ShowcaseVisibility.NoOne
|
|
||||||
inverted: true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ScrollBar.vertical: StatusScrollBar { }
|
ScrollBar.vertical: StatusScrollBar { }
|
||||||
delegate: StatusRoundedImage {
|
delegate: StatusRoundedImage {
|
||||||
width: GridView.view.cellWidth - Style.current.smallPadding
|
width: GridView.view.cellWidth - Style.current.smallPadding
|
||||||
|
@ -347,7 +384,7 @@ Control {
|
||||||
cellHeight: cellWidth/2.5
|
cellHeight: cellWidth/2.5
|
||||||
visible: count
|
visible: count
|
||||||
model: SortFilterProxyModel {
|
model: SortFilterProxyModel {
|
||||||
sourceModel: root.profileStore.profileShowcaseAssetsModel
|
sourceModel: d.assetsModel
|
||||||
filters: ValueFilter {
|
filters: ValueFilter {
|
||||||
roleName: "showcaseVisibility"
|
roleName: "showcaseVisibility"
|
||||||
value: Constants.ShowcaseVisibility.NoOne
|
value: Constants.ShowcaseVisibility.NoOne
|
||||||
|
|
Loading…
Reference in New Issue