mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-15 00:55:22 +00:00
839f2c6b21
* Feat: New showcase models for a contact * feat(ProfileShowcase): Integrate the new profile showcase backend * fix(Storybook): Fix ProfileShowcaseModelsPage * fix: fetch only requested profile showcase data Support PR for https://github.com/status-im/status-go/pull/4982 * feat: Load and validate profile showcase for a contact in two steps * fix: fetching criteria for profile showcase collectibles * fix: review fixes --------- Co-authored-by: Alex Jbanca <alexjb@status.im>
175 lines
4.9 KiB
QML
175 lines
4.9 KiB
QML
import QtQuick 2.15
|
|
import QtQuick.Controls 2.15
|
|
import QtQuick.Layouts 1.15
|
|
|
|
import StatusQ 0.1
|
|
import StatusQ.Core.Utils 0.1
|
|
|
|
import Storybook 1.0
|
|
|
|
import AppLayouts.Profile.helpers 1.0
|
|
|
|
import utils 1.0
|
|
|
|
Item {
|
|
id: root
|
|
|
|
ListModel {
|
|
id: communitiesModel
|
|
|
|
ListElement { showcaseKey: "1"; name: "Crypto Kitties"; showcaseVisibility: Constants.ShowcaseVisibility.IdVerifiedContacts; showcasePosition: 0 }
|
|
ListElement { showcaseKey: "2"; name: "Status" }
|
|
ListElement { showcaseKey: "3"; name: "Fun Stuff"; showcaseVisibility: Constants.ShowcaseVisibility.Contacts; showcasePosition: 9}
|
|
ListElement { showcaseKey: "4"; name: "Other Stuff" }
|
|
}
|
|
|
|
ListModel {
|
|
id: comboBoxModel
|
|
|
|
ListElement {
|
|
text: "verified"
|
|
value: Constants.ShowcaseVisibility.IdVerifiedContacts
|
|
}
|
|
ListElement {
|
|
text: "contacts"
|
|
value: Constants.ShowcaseVisibility.Contacts
|
|
}
|
|
ListElement {
|
|
text: "all"
|
|
value: Constants.ShowcaseVisibility.Everyone
|
|
}
|
|
}
|
|
|
|
ProfileShowcaseDirtyState {
|
|
id: dirtyState
|
|
|
|
sourceModel: communitiesModel
|
|
}
|
|
|
|
MovableModel {
|
|
id: movableModel
|
|
|
|
sourceModel: dirtyState.visibleModel
|
|
}
|
|
|
|
ColumnLayout {
|
|
anchors.fill: parent
|
|
|
|
Grid {
|
|
id: grid
|
|
Layout.fillWidth: true
|
|
Layout.fillHeight: true
|
|
Layout.margins: 10
|
|
|
|
rows: 2
|
|
columns: 2
|
|
|
|
spacing: 10
|
|
|
|
flow: Grid.TopToBottom
|
|
|
|
GenericListView {
|
|
width: grid.width / 2 - grid.spacing
|
|
height: 300
|
|
|
|
model: communitiesModel
|
|
label: "COMMUNITIES MODEL - Backend model"
|
|
}
|
|
|
|
GenericListView {
|
|
width: grid.width / 2 - grid.spacing
|
|
height: 300
|
|
|
|
model: dirtyState.writable_
|
|
label: "WRITABLE MODEL - Internal Model"
|
|
roles: ["showcaseKey", "showcaseVisibility", "showcasePosition", "name"]
|
|
}
|
|
|
|
GenericListView {
|
|
width: grid.width / 2 - grid.spacing
|
|
height: 300
|
|
|
|
model: movableModel
|
|
label: "IN SHOWCASE - output"
|
|
movable: true
|
|
roles: ["showcaseKey", "showcaseVisibility", "showcasePosition"]
|
|
|
|
onMoveRequested: {
|
|
movableModel.move(from, to)
|
|
dirtyState.changePosition(from, to);
|
|
}
|
|
|
|
insetComponent: RowLayout {
|
|
readonly property var topModel: model
|
|
|
|
RoundButton {
|
|
text: "❌"
|
|
onClicked: dirtyState.setVisibility(
|
|
model.showcaseKey,
|
|
Constants.ShowcaseVisibility.NoOne)
|
|
}
|
|
|
|
ComboBox {
|
|
model: comboBoxModel
|
|
|
|
onCurrentValueChanged: {
|
|
if (!completed || topModel.index < 0)
|
|
return
|
|
|
|
dirtyState.setVisibility(topModel.showcaseKey, currentValue)
|
|
}
|
|
|
|
property bool completed: false
|
|
|
|
Component.onCompleted: {
|
|
currentIndex = indexOfValue(topModel.showcaseVisibility)
|
|
completed = true
|
|
}
|
|
|
|
textRole: "text"
|
|
valueRole: "value"
|
|
}
|
|
}
|
|
}
|
|
|
|
GenericListView {
|
|
width: grid.width / 2 - grid.spacing
|
|
height: 300
|
|
|
|
model: dirtyState.hiddenModel
|
|
label: "HIDDEN - output"
|
|
|
|
roles: ["showcaseKey", "showcaseVisibility", "showcasePosition"]
|
|
|
|
insetComponent: Button {
|
|
text: "unhide"
|
|
|
|
onClicked: dirtyState.setVisibility(
|
|
model.showcaseKey,
|
|
Constants.ShowcaseVisibility.IdVerifiedContacts)
|
|
}
|
|
}
|
|
}
|
|
|
|
Button {
|
|
text: "SAVE"
|
|
onClicked: {
|
|
const toBeSaved = dirtyState.currentState()
|
|
|
|
for (let i = 0; i < communitiesModel.count; i++) {
|
|
const item = communitiesModel.get(i)
|
|
const found = toBeSaved.find((x) => x.showcaseKey === item.showcaseKey)
|
|
|
|
item.showcaseVisibility = !!found ? found.showcaseVisibility : Constants.ShowcaseVisibility.NoOne
|
|
item.showcasePosition = !!found ? found.showcasePosition : 0
|
|
}
|
|
}
|
|
|
|
Layout.alignment: Qt.AlignHCenter
|
|
Layout.margins: 10
|
|
}
|
|
}
|
|
}
|
|
|
|
// category: Models
|