mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-24 21:39:24 +00:00
UtilsStore creaed, isChatKey method moved
This commit is contained in:
parent
c8d2e39329
commit
14226af5a0
@ -19,6 +19,7 @@ Page {
|
||||
id: root
|
||||
|
||||
property SharedStores.RootStore sharedRootStore
|
||||
property SharedStores.UtilsStore utilsStore
|
||||
property ChatStores.RootStore rootStore
|
||||
property ChatStores.CreateChatPropertiesStore createChatPropertiesStore
|
||||
property var emojiPopup: null
|
||||
@ -59,7 +60,9 @@ Page {
|
||||
Layout.fillHeight: true
|
||||
Layout.leftMargin: Theme.halfPadding
|
||||
Layout.rightMargin: Theme.halfPadding
|
||||
|
||||
rootStore: root.rootStore
|
||||
utilsStore: root.utilsStore
|
||||
|
||||
function createChat() {
|
||||
if (model.count === 0) {
|
||||
|
@ -7,11 +7,14 @@ import StatusQ.Components 0.1
|
||||
|
||||
import "private"
|
||||
|
||||
import shared.stores 1.0
|
||||
import utils 1.0
|
||||
|
||||
MembersSelectorBase {
|
||||
id: root
|
||||
|
||||
property UtilsStore utilsStore
|
||||
|
||||
limitReached: model.count >= membersLimit - 1 // -1 because creator is not on the list of members when creating chat
|
||||
|
||||
function cleanup() {
|
||||
@ -69,7 +72,7 @@ MembersSelectorBase {
|
||||
|
||||
value = Utils.dropUserLinkPrefix(value.trim())
|
||||
|
||||
if (Utils.isChatKey(value)) {
|
||||
if (root.utilsStore.isChatKey(value)) {
|
||||
processContact(value)
|
||||
return
|
||||
}
|
||||
|
@ -60,6 +60,8 @@ Item {
|
||||
currencyStore: appMain.currencyStore
|
||||
}
|
||||
|
||||
readonly property SharedStores.UtilsStore utilsStore: SharedStores.UtilsStore {}
|
||||
|
||||
readonly property AppStores.RootStore rootStore: AppStores.RootStore {}
|
||||
readonly property ProfileStores.ProfileSectionStore profileSectionStore: rootStore.profileSectionStore
|
||||
readonly property ProfileStores.ProfileStore profileStore: profileSectionStore.profileStore
|
||||
@ -633,6 +635,7 @@ Item {
|
||||
|
||||
sourceComponent: AppSearch {
|
||||
store: appMain.rootStore.appSearchStore
|
||||
utilsStore: appMain.utilsStore
|
||||
onClosed: appSearch.active = false
|
||||
}
|
||||
}
|
||||
@ -1578,6 +1581,7 @@ Item {
|
||||
|
||||
sourceComponent: CreateChatView {
|
||||
sharedRootStore: appMain.sharedRootStore
|
||||
utilsStore: appMain.utilsStore
|
||||
rootStore: ChatStores.RootStore {
|
||||
contactsStore: appMain.rootStore.contactStore
|
||||
currencyStore: appMain.currencyStore
|
||||
|
@ -1,5 +1,5 @@
|
||||
import QtQuick 2.13
|
||||
import QtQuick.Controls 2.13
|
||||
import QtQuick 2.15
|
||||
import QtQuick.Controls 2.15
|
||||
|
||||
import StatusQ.Core 0.1
|
||||
import StatusQ.Core.Backpressure 0.1
|
||||
@ -11,11 +11,13 @@ import utils 1.0
|
||||
import AppLayouts.stores 1.0
|
||||
|
||||
Item {
|
||||
id: appSearch
|
||||
id: root
|
||||
|
||||
property AppSearchStore store
|
||||
property UtilsStore utilsStore
|
||||
|
||||
readonly property var searchMessages: Backpressure.debounce(searchPopup, 400, function (value) {
|
||||
appSearch.store.searchMessages(value)
|
||||
root.store.searchMessages(value)
|
||||
})
|
||||
property alias opened: searchPopup.opened
|
||||
|
||||
@ -30,7 +32,7 @@ Item {
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: appSearch.store.locationMenuModel
|
||||
target: root.store.locationMenuModel
|
||||
function onModelAboutToBeReset() {
|
||||
while (searchPopupMenu.takeItem(searchPopupMenu.numDefaultItems)) {
|
||||
// Delete the item right after the default items
|
||||
@ -40,7 +42,7 @@ Item {
|
||||
}
|
||||
|
||||
Connections {
|
||||
target: appSearch.store.appSearchModule
|
||||
target: root.store.appSearchModule
|
||||
function onAppSearchCompleted() {
|
||||
searchPopup.loading = false
|
||||
}
|
||||
@ -49,10 +51,10 @@ Item {
|
||||
StatusSearchLocationMenu {
|
||||
id: searchPopupMenu
|
||||
|
||||
locationModel: appSearch.store.locationMenuModel
|
||||
locationModel: root.store.locationMenuModel
|
||||
|
||||
onItemClicked: {
|
||||
appSearch.store.setSearchLocation(firstLevelItemValue, secondLevelItemValue)
|
||||
root.store.setSearchLocation(firstLevelItemValue, secondLevelItemValue)
|
||||
searchPopup.forceActiveFocus()
|
||||
if(searchPopup.searchText !== "")
|
||||
searchMessages(searchPopup.searchText)
|
||||
@ -80,7 +82,7 @@ Item {
|
||||
noResultsLabel: qsTr("No results")
|
||||
defaultSearchLocationText: qsTr("Anywhere")
|
||||
searchOptionsPopupMenu: searchPopupMenu
|
||||
searchResults: appSearch.store.resultModel
|
||||
searchResults: root.store.resultModel
|
||||
formatTimestampFn: function (ts) {
|
||||
return LocaleUtils.formatDateTime(parseInt(ts, 10))
|
||||
}
|
||||
@ -97,18 +99,18 @@ Item {
|
||||
}
|
||||
onClosed: {
|
||||
searchPopupMenu.dismiss();
|
||||
appSearch.closed();
|
||||
root.closed();
|
||||
}
|
||||
onResetSearchLocationClicked: {
|
||||
searchPopup.resetSearchSelection();
|
||||
appSearch.store.setSearchLocation("", "")
|
||||
root.store.setSearchLocation("", "")
|
||||
searchMessages(searchPopup.searchText)
|
||||
}
|
||||
onOpened: {
|
||||
searchPopup.resetSearchSelection();
|
||||
appSearch.store.prepareLocationMenuModel()
|
||||
root.store.prepareLocationMenuModel()
|
||||
|
||||
const jsonObj = appSearch.store.getSearchLocationObject()
|
||||
const jsonObj = root.store.getSearchLocationObject()
|
||||
|
||||
if (!jsonObj) {
|
||||
return
|
||||
@ -117,7 +119,7 @@ Item {
|
||||
let obj = JSON.parse(jsonObj)
|
||||
if (obj.location === "" || (obj.location !== "" && !obj.subLocation)) {
|
||||
if(obj.subLocation === "") {
|
||||
appSearch.store.setSearchLocation("", "")
|
||||
root.store.setSearchLocation("", "")
|
||||
} else {
|
||||
searchPopup.setSearchSelection(obj.subLocation.text,
|
||||
"",
|
||||
@ -126,7 +128,7 @@ Item {
|
||||
obj.subLocation.iconName,
|
||||
obj.subLocation.identiconColor)
|
||||
|
||||
appSearch.store.setSearchLocation("", obj.subLocation.value)
|
||||
root.store.setSearchLocation("", obj.subLocation.value)
|
||||
}
|
||||
} else {
|
||||
if (obj.location.title === "Chat" && !!obj.subLocation) {
|
||||
@ -140,7 +142,7 @@ Item {
|
||||
obj.subLocation.colorId,
|
||||
obj.subLocation.colorHash)
|
||||
|
||||
appSearch.store.setSearchLocation(obj.location.value, obj.subLocation.value)
|
||||
root.store.setSearchLocation(obj.location.value, obj.subLocation.value)
|
||||
} else {
|
||||
searchPopup.setSearchSelection(obj.location.title,
|
||||
obj.subLocation.text,
|
||||
@ -149,16 +151,16 @@ Item {
|
||||
obj.location.iconName,
|
||||
obj.location.identiconColor)
|
||||
|
||||
appSearch.store.setSearchLocation(obj.location.value, obj.subLocation.value)
|
||||
root.store.setSearchLocation(obj.location.value, obj.subLocation.value)
|
||||
}
|
||||
}
|
||||
}
|
||||
onResultItemClicked: {
|
||||
searchPopup.close()
|
||||
appSearch.store.resultItemClicked(itemId)
|
||||
root.store.resultItemClicked(itemId)
|
||||
}
|
||||
acceptsTitleClick: function (titleId) {
|
||||
return Utils.isChatKey(titleId)
|
||||
return root.utilsStore.isChatKey(titleId)
|
||||
}
|
||||
onResultItemTitleClicked: Global.openProfilePopup(titleId, searchPopup)
|
||||
}
|
||||
|
18
ui/imports/shared/stores/UtilsStore.qml
Normal file
18
ui/imports/shared/stores/UtilsStore.qml
Normal file
@ -0,0 +1,18 @@
|
||||
import QtQml 2.15
|
||||
|
||||
import utils 1.0
|
||||
|
||||
QtObject {
|
||||
id: root
|
||||
|
||||
readonly property QtObject _d: QtObject {
|
||||
id: d
|
||||
|
||||
property var globalUtilsInst: globalUtils
|
||||
}
|
||||
|
||||
function isChatKey(value) {
|
||||
return (Utils.startsWith0x(value) && Utils.isHex(value) && value.length === 132)
|
||||
|| d.globalUtilsInst.isCompressedPubKey(value)
|
||||
}
|
||||
}
|
@ -7,3 +7,4 @@ MetricsStore 1.0 MetricsStore.qml
|
||||
NetworkConnectionStore 1.0 NetworkConnectionStore.qml
|
||||
PermissionsStore 1.0 PermissionsStore.qml
|
||||
RootStore 1.0 RootStore.qml
|
||||
UtilsStore 1.0 UtilsStore.qml
|
||||
|
Loading…
x
Reference in New Issue
Block a user