diff --git a/storybook/pages/PinnedMessagesPopupPage.qml b/storybook/pages/PinnedMessagesPopupPage.qml
index a71204ef21..82b0c8ad1b 100644
--- a/storybook/pages/PinnedMessagesPopupPage.qml
+++ b/storybook/pages/PinnedMessagesPopupPage.qml
@@ -22,81 +22,61 @@ SplitView {
Logs { id: logs }
QtObject {
- id: mockMessageStore
- property var messages: [
- {
- messageId: "msg1",
- senderId: "user1",
- senderDisplayName: "Alice",
- senderOptionalName: "",
- senderIsEnsVerified: false,
- senderIcon: "",
- amISender: false,
- senderIsAdded: false,
- senderTrustStatus: Constants.trustStatus.unknown,
- messageText: "This is a pinned message",
- unparsedText: "This is a pinned message",
- messageImage: "",
- messageTimestamp: 1621234567,
- messageOutgoingStatus: "",
- resendError: "",
- messageContentType: Constants.messageContentType.messageType,
- pinnedMessage: true,
- messagePinnedBy: "user2",
- reactionsModel: [],
- linkPreviewModel: null,
- messageAttachments: "",
- transactionParams: null,
- emojiReactionsModel: null,
- responseToMessageWithId: "",
- quotedMessageText: "",
- quotedMessageFrom: "",
- quotedMessageContentType: Constants.messageContentType.messageType,
- quotedMessageDeleted: false,
- album: [],
- albumCount: 0,
- quotedMessageAlbumMessageImages: [],
- quotedMessageAlbumImagesCount: 0
- },
- {
- messageId: "msg2",
- senderId: "user2",
- senderDisplayName: "Bob",
- senderOptionalName: "",
- senderIsEnsVerified: false,
- senderIcon: "",
- amISender: false,
- senderIsAdded: false,
- senderTrustStatus: Constants.trustStatus.unknown,
- messageText: "Another pinned message",
- unparsedText: "Another pinned message",
- messageImage: "",
- messageTimestamp: 1621234568,
- messageOutgoingStatus: "",
- resendError: "",
- messageContentType: Constants.messageContentType.messageType,
- pinnedMessage: true,
- messagePinnedBy: "user1",
- reactionsModel: [],
- linkPreviewModel: null,
- messageAttachments: "",
- transactionParams: null,
- emojiReactionsModel: null,
- responseToMessageWithId: "",
- quotedMessageText: "",
- quotedMessageFrom: "",
- quotedMessageContentType: Constants.messageContentType.messageType,
- quotedMessageDeleted: false,
- album: [],
- albumCount: 0,
- quotedMessageAlbumMessageImages: [],
- quotedMessageAlbumImagesCount: 0
+ id: d_msg
+
+ readonly property var messagesModel: ListModel {
+ ListElement {
+ timestamp: 1656937930123
+ senderId: "zq123456789"
+ senderDisplayName: "simon"
+ profileImage: "
+ nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2ImYgiNITTlTdG1nUZ5a92VITQxITFiJmIIjSE0htAYQrMHAAD//+wwFVpz+yqXAAAAAElFTkSuQmCC"
+ contentType: StatusMessage.ContentType.Text
+ message: "Hello, this is awesome! Feels like decentralized Discord! And it even supports HTML markup, like bold, italics or underline"
+ isContact: true
+ isAReply: false
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Verified
+ outgoingStatus: StatusMessage.OutgoingStatus.Delivered
}
- ]
+ ListElement {
+ timestamp: 1657937930135
+ senderId: "zqABCDEFG"
+ senderDisplayName: "Mark Cuban"
+ contentType: StatusMessage.ContentType.Text
+ message: "I know a lot of you really seem to get off or be validated by arguing with strangers online but please know it's a complete waste of your time and energy"
+ isContact: false
+ isAReply: false
+ trustIndicator: StatusContactVerificationIcons.TrustedType.Untrustworthy
+ outgoingStatus: StatusMessage.OutgoingStatus.Delivered
+ }
+ ListElement {
+ timestamp: 1667937930159
+ senderId: "zqdeadbeef"
+ senderDisplayName: "replicator.stateofus.eth"
+ contentType: StatusMessage.ContentType.Text
+ message: "Test reply; the original text above should have a horizontal gradient mask"
+ isContact: true
+ isAReply: true
+ trustIndicator: StatusContactVerificationIcons.TrustedType.None
+ outgoingStatus: StatusMessage.OutgoingStatus.Delivered
+ }
+ }
+ readonly property var colorHash: ListModel {
+ ListElement { colorId: 13; segmentLength: 5 }
+ ListElement { colorId: 31; segmentLength: 5 }
+ ListElement { colorId: 10; segmentLength: 1 }
+ }
+ }
+
+ QtObject {
+ id: mockMessageStore
+ // redo it, use first message as pinned message from d_msg.messagesModel the one whose timestamp is 1656937930123
+ property ListModel pinnedMessagesModel: ListModel {
+ }
function getMessageByIndexAsJson(index) {
- if (index >= 0 && index < messages.length) {
- return JSON.stringify(messages[index])
+ if (index >= 0 && index < pinnedMessagesModel.count) {
+ return JSON.stringify(pinnedMessagesModel.get(index))
}
return "{}"
}
@@ -153,8 +133,45 @@ SplitView {
spacing: 10
Button {
- text: "Open Pinned Messages Popup"
+ text: "Open Empty Pinned Messages Popup"
onClicked: {
+ mockMessageStore.pinnedMessagesModel.clear()
+ pinnedMessagesPopup.messageToPin = ""
+ pinnedMessagesPopup.open()
+ }
+ }
+
+ Button {
+ text: "Open Pinned Messages Popup (2 messages)"
+ onClicked: {
+ mockMessageStore.pinnedMessagesModel.clear()
+ mockMessageStore.pinnedMessagesModel.append(d_msg.messagesModel.get(0))
+ mockMessageStore.pinnedMessagesModel.append(d_msg.messagesModel.get(1))
+ pinnedMessagesPopup.messageToPin = ""
+ pinnedMessagesPopup.open()
+ }
+ }
+
+ Button {
+ text: "Open Full Pinned Messages Popup (3 messages)"
+ onClicked: {
+ mockMessageStore.pinnedMessagesModel.clear()
+ mockMessageStore.pinnedMessagesModel.append(d_msg.messagesModel.get(0))
+ mockMessageStore.pinnedMessagesModel.append(d_msg.messagesModel.get(1))
+ mockMessageStore.pinnedMessagesModel.append(d_msg.messagesModel.get(2))
+ pinnedMessagesPopup.messageToPin = ""
+ pinnedMessagesPopup.open()
+ }
+ }
+
+ Button {
+ text: "Open Unpin Messages Popup (3 messages + messageToPin)"
+ onClicked: {
+ mockMessageStore.pinnedMessagesModel.clear()
+ mockMessageStore.pinnedMessagesModel.append(d_msg.messagesModel.get(0))
+ mockMessageStore.pinnedMessagesModel.append(d_msg.messagesModel.get(1))
+ mockMessageStore.pinnedMessagesModel.append(d_msg.messagesModel.get(2))
+ pinnedMessagesPopup.messageToPin = "This is a message to pin"
pinnedMessagesPopup.open()
}
}
@@ -163,8 +180,8 @@ SplitView {
PinnedMessagesPopup {
id: pinnedMessagesPopup
store: mockRootStore
- messageStore: mockMessageStore
- pinnedMessagesModel: mockMessageStore.messages
+ messageStore: d_msg
+ pinnedMessagesModel: mockMessageStore.pinnedMessagesModel
chatId: "chat1"
property var chatContentModule: QtObject {
@@ -173,7 +190,7 @@ SplitView {
property bool canPost: true
property bool canView: true
}
- property var pinnedMessagesModel: mockMessageStore.messages
+ property var pinnedMessagesModel: mockMessageStore.pinnedMessagesModel
}
property var usersStore: QtObject {
@@ -219,72 +236,6 @@ SplitView {
controls: ColumnLayout {
spacing: 16
-
- Button {
- text: "Add Pinned Message"
- onClicked: {
- mockMessageStore.messages.push({
- messageId: "msg" + (mockMessageStore.messages.length + 1),
- senderId: "user" + (mockMessageStore.messages.length + 1),
- senderDisplayName: "User " + (mockMessageStore.messages.length + 1),
- senderOptionalName: "",
- senderIsEnsVerified: false,
- senderIcon: "",
- amISender: false,
- senderIsAdded: false,
- senderTrustStatus: Constants.trustStatus.unknown,
- messageText: "New pinned message " + (mockMessageStore.messages.length + 1),
- unparsedText: "New pinned message " + (mockMessageStore.messages.length + 1),
- messageImage: "",
- messageTimestamp: Date.now() / 1000,
- messageOutgoingStatus: "",
- resendError: "",
- messageContentType: Constants.messageContentType.messageType,
- pinnedMessage: true,
- messagePinnedBy: "user1",
- reactionsModel: [],
- linkPreviewModel: null,
- messageAttachments: "",
- transactionParams: null,
- emojiReactionsModel: null,
- responseToMessageWithId: "",
- quotedMessageText: "",
- quotedMessageFrom: "",
- quotedMessageContentType: Constants.messageContentType.messageType,
- quotedMessageDeleted: false,
- album: [],
- albumCount: 0,
- quotedMessageAlbumMessageImages: [],
- quotedMessageAlbumImagesCount: 0
- })
- pinnedMessagesPopup.pinnedMessagesModel = mockMessageStore.messages
- }
- }
-
- Button {
- text: "Clear Pinned Messages"
- onClicked: {
- mockMessageStore.messages = []
- pinnedMessagesPopup.pinnedMessagesModel = mockMessageStore.messages
- }
- }
-
- CheckBox {
- id: isPinActionAvailableCheckBox
- text: "Is Pin Action Available"
- checked: true
- onCheckedChanged: {
- pinnedMessagesPopup.isPinActionAvailable = checked
- }
- }
-
- TextField {
- id: messageToPinInput
- placeholderText: "Message to pin"
- onTextChanged: {
- pinnedMessagesPopup.messageToPin = text
- }
- }
}
}
}