mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-21 20:09:37 +00:00
feat(savedaddresses): make save addresses list as per design (without search logic)
Closes #13090
This commit is contained in:
parent
ff9062a1b0
commit
df8e74feec
@ -52,7 +52,7 @@ ColumnLayout {
|
||||
model: 12
|
||||
StatusLetterIdenticon {
|
||||
name: "A"
|
||||
color: Theme.palette.userCustomizationColors[index]
|
||||
letterIdenticonColor: Theme.palette.userCustomizationColors[index]
|
||||
letterSize: 16
|
||||
}
|
||||
}
|
||||
|
@ -394,7 +394,7 @@ ItemDelegate {
|
||||
height: root.icon.height
|
||||
emoji: root.hasEmoji ? root.icon.name : ""
|
||||
name: !root.hasEmoji ? root.icon.name : ""
|
||||
color: root.icon.color
|
||||
letterIdenticonColor: root.icon.color
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -12,8 +12,16 @@ Rectangle {
|
||||
property string emojiSize: Emoji.size.small
|
||||
property int letterSize: 21
|
||||
property int charactersLen: 1
|
||||
property color letterIdenticonColor: Theme.palette.miscColor5
|
||||
property bool useAcronymForLetterIdenticon: false
|
||||
|
||||
color: {
|
||||
if (root.useAcronymForLetterIdenticon) {
|
||||
return Qt.rgba(root.letterIdenticonColor.r, root.letterIdenticonColor.g, root.letterIdenticonColor.b, 0.2)
|
||||
}
|
||||
return root.letterIdenticonColor
|
||||
}
|
||||
|
||||
color: Theme.palette.miscColor5
|
||||
width: 40
|
||||
height: 40
|
||||
radius: width / 2
|
||||
@ -38,9 +46,30 @@ Rectangle {
|
||||
|
||||
font.weight: Font.Bold
|
||||
font.pixelSize: root.letterSize
|
||||
color: d.luminance(root.color) > 0.5 ? Qt.rgba(0, 0, 0, 0.5) : Qt.rgba(1, 1, 1, 0.7)
|
||||
color: {
|
||||
if (root.useAcronymForLetterIdenticon) {
|
||||
return root.letterIdenticonColor
|
||||
}
|
||||
return d.luminance(root.letterIdenticonColor) > 0.5 ? Qt.rgba(0, 0, 0, 0.5) : Qt.rgba(1, 1, 1, 0.7)
|
||||
}
|
||||
|
||||
text: {
|
||||
let parts = root.name.split(" ")
|
||||
if (root.useAcronymForLetterIdenticon && parts.length > 1) {
|
||||
let word = ""
|
||||
for (let i=0; i<root.charactersLen; i++) {
|
||||
if (i >= parts.length) {
|
||||
return word
|
||||
}
|
||||
|
||||
let shift = (parts[i].charAt(0) === "#") ||
|
||||
(parts[i].charAt(0) === "@")
|
||||
|
||||
word += parts[i].substring(shift, shift + 1).toUpperCase()
|
||||
}
|
||||
return word
|
||||
}
|
||||
|
||||
const shift = (root.name.charAt(0) === "#") ||
|
||||
(root.name.charAt(0) === "@")
|
||||
return root.name.substring(shift, shift + charactersLen).toUpperCase()
|
||||
|
@ -50,7 +50,7 @@ Control {
|
||||
implicitHeight: root.asset.width
|
||||
letterSize: 11
|
||||
visible: root.asset.isLetterIdenticon
|
||||
color: root.asset.color
|
||||
letterIdenticonColor: root.asset.color
|
||||
name: root.primaryText
|
||||
emoji: root.asset.emoji
|
||||
emojiSize: root.asset.emojiSize
|
||||
|
@ -109,12 +109,13 @@ Loader {
|
||||
objectName: "statusSmartIdenticonLetter"
|
||||
width: root.asset.width
|
||||
height: root.asset.height
|
||||
color: root.asset.color
|
||||
letterIdenticonColor: root.asset.color
|
||||
name: root.name
|
||||
emoji: root.asset.emoji
|
||||
emojiSize: root.asset.emojiSize
|
||||
letterSize: root.asset.letterSize
|
||||
charactersLen: root.asset.charactersLen
|
||||
useAcronymForLetterIdenticon: root.asset.useAcronymForLetterIdenticon
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -14,6 +14,7 @@ QtObject {
|
||||
property color disabledColor
|
||||
property int rotation
|
||||
property bool isLetterIdenticon
|
||||
property bool useAcronymForLetterIdenticon
|
||||
property int letterSize: emoji ? 11 : (charactersLen == 1 ? _oneLetterSize : _twoLettersSize)
|
||||
property int charactersLen: 1
|
||||
property string emoji
|
||||
|
@ -45,7 +45,7 @@ Row {
|
||||
StatusLetterIdenticon {
|
||||
width: statusImageWithTitle.asset.width
|
||||
height: statusImageWithTitle.asset.height
|
||||
color: statusImageWithTitle.asset.bgColor
|
||||
letterIdenticonColor: statusImageWithTitle.asset.bgColor
|
||||
name: statusImageWithTitle.title
|
||||
}
|
||||
}
|
||||
|
@ -41,7 +41,7 @@ Item {
|
||||
StatusQ.StatusLetterIdenticon {
|
||||
id: identicon
|
||||
anchors.horizontalCenter: parent.horizontalCenter
|
||||
color: Theme.palette.baseColor2
|
||||
letterIdenticonColor: Theme.palette.baseColor2
|
||||
identiconText.text: text.charAt(0)
|
||||
identiconText.color: Theme.palette.baseColor1
|
||||
visible: !bookmarkImage.visible && !addButton.visible
|
||||
|
@ -27,7 +27,6 @@ StatusListItem {
|
||||
property bool favourite: false
|
||||
property bool areTestNetworksEnabled: false
|
||||
property bool isSepoliaEnabled: false
|
||||
property var saveAddress: function (name, address, favourite, chainShortNames, ens) {}
|
||||
|
||||
signal openSendModal(string recipient)
|
||||
|
||||
@ -38,24 +37,36 @@ StatusListItem {
|
||||
subTitle: {
|
||||
if (ens.length > 0)
|
||||
return ens
|
||||
else
|
||||
return WalletUtils.colorizedChainPrefix(chainShortNames) + address
|
||||
else {
|
||||
return sensor.containsMouse ? WalletUtils.colorizedChainPrefix(root.chainShortNames) +
|
||||
Utils.richColorText(root.address, Theme.palette.directColor1)
|
||||
: root.chainShortNames + root.address
|
||||
}
|
||||
}
|
||||
|
||||
border.color: Theme.palette.baseColor5
|
||||
asset.name: d.favouriteEnabled ? (root.favourite ? "star-icon" : "favourite") : ""
|
||||
asset.color: root.favourite ? Theme.palette.pinColor1 : (showButtons ? Theme.palette.directColor1 : Theme.palette.baseColor1) // star icon color default
|
||||
asset.hoverColor: root.favourite ? "transparent": Theme.palette.directColor1 // star icon color on hover
|
||||
asset.bgColor: statusListItemIcon.hovered ? Theme.palette.primaryColor3 : "transparent" // icon outer background color
|
||||
asset.bgRadius: 8
|
||||
|
||||
asset {
|
||||
width: 40
|
||||
height: 40
|
||||
color: Utils.getColorForId(root.colorId)
|
||||
charactersLen: {
|
||||
let parts = root.name.split(" ")
|
||||
if (parts.length > 1) {
|
||||
return 2
|
||||
}
|
||||
return 1
|
||||
}
|
||||
isLetterIdenticon: true
|
||||
useAcronymForLetterIdenticon: true
|
||||
}
|
||||
|
||||
statusListItemIcon.hoverEnabled: true
|
||||
|
||||
onIconClicked: {
|
||||
root.saveAddress(root.name, root.address, !root.favourite, root.chainShortNames, root.ens)
|
||||
onClicked: {
|
||||
root.openSendModal(d.visibleAddress)
|
||||
}
|
||||
|
||||
statusListItemSubTitle.font.pixelSize: 13
|
||||
statusListItemSubTitle.customColor: !enabled ? Theme.palette.baseColor1 : Theme.palette.directColor1
|
||||
statusListItemComponentsSlot.spacing: 0
|
||||
property bool showButtons: sensor.containsMouse
|
||||
|
||||
@ -67,13 +78,6 @@ StatusListItem {
|
||||
}
|
||||
|
||||
components: [
|
||||
StatusRoundButton {
|
||||
icon.color: root.showButtons ? Theme.palette.directColor1 : Theme.palette.baseColor1
|
||||
type: StatusRoundButton.Type.Quinary
|
||||
radius: 8
|
||||
icon.name: "send"
|
||||
onClicked: openSendModal(d.visibleAddress)
|
||||
},
|
||||
StatusRoundButton {
|
||||
objectName: "savedAddressView_Delegate_menuButton_" + root.name
|
||||
visible: !!root.name
|
||||
@ -94,19 +98,6 @@ StatusListItem {
|
||||
);
|
||||
}
|
||||
|
||||
},
|
||||
StatusRoundButton {
|
||||
visible: !root.name
|
||||
icon.color: root.showButtons ? Theme.palette.directColor1 : Theme.palette.baseColor1
|
||||
type: StatusRoundButton.Type.Tertiary
|
||||
icon.name: "add"
|
||||
onClicked: {
|
||||
Global.openAddEditSavedAddressesPopup({
|
||||
addAddress: true,
|
||||
address: d.visibleAddress,
|
||||
ens: root.ens
|
||||
})
|
||||
}
|
||||
}
|
||||
]
|
||||
|
||||
@ -140,7 +131,7 @@ StatusListItem {
|
||||
contactEns = ""
|
||||
}
|
||||
StatusAction {
|
||||
text: qsTr("Edit")
|
||||
text: qsTr("Edit saved address")
|
||||
objectName: "editroot"
|
||||
assetSettings.name: "pencil-outline"
|
||||
onTriggered: {
|
||||
@ -156,7 +147,7 @@ StatusListItem {
|
||||
}
|
||||
}
|
||||
StatusAction {
|
||||
text: qsTr("Copy")
|
||||
text: qsTr("Copy address")
|
||||
objectName: "copySavedAddressAction"
|
||||
assetSettings.name: "copy"
|
||||
onTriggered: {
|
||||
@ -166,6 +157,14 @@ StatusListItem {
|
||||
store.copyToClipboard(root.ens)
|
||||
}
|
||||
}
|
||||
StatusAction {
|
||||
text: qsTr("Show address QR")
|
||||
objectName: "showQrSavedAddressAction"
|
||||
assetSettings.name: "qr"
|
||||
onTriggered: {
|
||||
console.warn("TODO: open qr popup...")
|
||||
}
|
||||
}
|
||||
StatusMenuSeparator { }
|
||||
|
||||
StatusAction {
|
||||
@ -211,7 +210,7 @@ StatusListItem {
|
||||
}
|
||||
StatusMenuSeparator { }
|
||||
StatusAction {
|
||||
text: qsTr("Delete")
|
||||
text: qsTr("Remove saved address")
|
||||
type: StatusAction.Type.Danger
|
||||
assetSettings.name: "delete"
|
||||
objectName: "deleteSavedAddress"
|
||||
|
@ -113,6 +113,16 @@ StatusDialog {
|
||||
d.chainShortNames = ""
|
||||
allNetworksModelCopy.setEnabledNetworks([])
|
||||
}
|
||||
|
||||
function submit(event) {
|
||||
if (!d.valid
|
||||
|| !d.dirty
|
||||
|| event !== undefined && event.key !== Qt.Key_Return && event.key !== Qt.Key_Enter)
|
||||
return
|
||||
|
||||
RootStore.createOrUpdateSavedAddress(d.name, d.address, d.ens, d.colorId, d.favourite, d.chainShortNames)
|
||||
root.close()
|
||||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
@ -155,6 +165,10 @@ StatusDialog {
|
||||
]
|
||||
input.clearable: true
|
||||
input.rightPadding: 16
|
||||
|
||||
onKeyPressed: {
|
||||
d.submit(event)
|
||||
}
|
||||
}
|
||||
|
||||
StatusInput {
|
||||
@ -234,6 +248,10 @@ StatusDialog {
|
||||
}
|
||||
}
|
||||
|
||||
onKeyPressed: {
|
||||
d.submit(event)
|
||||
}
|
||||
|
||||
property bool skipTextUpdate: false
|
||||
|
||||
function setPlainText(newText) {
|
||||
@ -395,8 +413,7 @@ StatusDialog {
|
||||
text: d.editMode? qsTr("Save") : qsTr("Add address")
|
||||
enabled: d.valid && d.dirty
|
||||
onClicked: {
|
||||
RootStore.createOrUpdateSavedAddress(d.name, d.address, d.ens, d.colorId, d.favourite, d.chainShortNames)
|
||||
root.close()
|
||||
d.submit()
|
||||
}
|
||||
objectName: "addSavedAddress"
|
||||
}
|
||||
|
@ -47,17 +47,40 @@ ColumnLayout {
|
||||
Layout.fillHeight: true
|
||||
}
|
||||
|
||||
SearchBox {
|
||||
Layout.fillWidth: true
|
||||
visible: listView.visible
|
||||
placeholderText: qsTr("Search for name, ENS or address")
|
||||
}
|
||||
|
||||
StatusListView {
|
||||
id: listView
|
||||
objectName: "SavedAddressesView_savedAddresses"
|
||||
Layout.fillWidth: true
|
||||
Layout.fillHeight: true
|
||||
spacing: 5
|
||||
Layout.topMargin: 16
|
||||
spacing: 8
|
||||
visible: count > 0
|
||||
|
||||
model: SortFilterProxyModel {
|
||||
sourceModel: RootStore.savedAddresses
|
||||
sorters: RoleSorter { roleName: "createdAt"; sortOrder: Qt.DescendingOrder }
|
||||
sorters: RoleSorter { roleName: "name"; sortOrder: Qt.AscendingOrder }
|
||||
}
|
||||
|
||||
section.property: "name"
|
||||
section.criteria: ViewSection.FirstCharacter
|
||||
section.delegate: Item {
|
||||
height: 34
|
||||
width: children.width
|
||||
StatusBaseText {
|
||||
anchors.left: parent.left
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
text: section.toUpperCase()
|
||||
color: Theme.palette.baseColor1
|
||||
font.pixelSize: 15
|
||||
}
|
||||
}
|
||||
|
||||
delegate: SavedAddressesDelegate {
|
||||
id: savedAddressDelegate
|
||||
objectName: "savedAddressView_Delegate_" + name
|
||||
|
Loading…
x
Reference in New Issue
Block a user