mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-11 14:54:48 +00:00
a8eed304c0
Implement the UI part of Profile/Settings/Showcase: - Communities/Accounts/Collectibles/Assets tabs - drag and drop of items between "hidden" and "in showcase" sections - ability to set individual items' visibility - persistency (showcase saved across restarts), not exposed yet due to missing backend API Closes #9936
46 lines
1.7 KiB
QML
46 lines
1.7 KiB
QML
import QtQuick 2.15
|
|
|
|
import utils 1.0
|
|
|
|
import AppLayouts.Profile.controls 1.0
|
|
|
|
ProfileShowcasePanel {
|
|
id: root
|
|
|
|
settingsKey: "collectibles"
|
|
keyRole: "id"
|
|
roleNames: ["id", "name", "description", "collectionName", "backgroundColor", "imageUrl"]
|
|
filterFunc: (modelData) => !showcaseModel.hasItem(modelData.id)
|
|
hiddenPlaceholderBanner: qsTr("Collectibles here will show on your profile")
|
|
showcasePlaceholderBanner: qsTr("Collectibles here will be hidden from your profile")
|
|
|
|
draggableDelegateComponent: CollectibleShowcaseDelegate {
|
|
Drag.keys: ["x-status-draggable-showcase-item-hidden"]
|
|
showcaseObj: modelData
|
|
dragParent: dragParentData
|
|
visualIndex: visualIndexData
|
|
onShowcaseVisibilityRequested: {
|
|
var tmpObj = Object()
|
|
root.roleNames.forEach(role => tmpObj[role] = showcaseObj[role])
|
|
tmpObj.showcaseVisibility = value
|
|
showcaseModel.append(tmpObj)
|
|
showcaseVisibility = Constants.ShowcaseVisibility.NoOne // reset
|
|
}
|
|
}
|
|
showcaseDraggableDelegateComponent: CollectibleShowcaseDelegate {
|
|
Drag.keys: ["x-status-draggable-showcase-item"]
|
|
showcaseObj: modelData
|
|
dragParent: dragParentData
|
|
visualIndex: visualIndexData
|
|
dragAxis: Drag.YAxis
|
|
showcaseVisibility: !!modelData ? modelData.showcaseVisibility : Constants.ShowcaseVisibility.NoOne
|
|
onShowcaseVisibilityRequested: {
|
|
if (value === Constants.ShowcaseVisibility.NoOne) {
|
|
showcaseModel.remove(visualIndex)
|
|
} else {
|
|
showcaseModel.setProperty(visualIndex, "showcaseVisibility", value)
|
|
}
|
|
}
|
|
}
|
|
}
|