fix(StatusPopupMenu): Refactoring
This commit is contained in:
parent
f49190e47b
commit
e3bfdc0f09
|
@ -10,6 +10,7 @@ type
|
|||
IconName
|
||||
IconColor
|
||||
SubItems
|
||||
HasSubItems
|
||||
|
||||
QtObject:
|
||||
type
|
||||
|
@ -39,7 +40,8 @@ QtObject:
|
|||
ModelRole.ImageSource.int:"imageSource",
|
||||
ModelRole.IconName.int:"iconName",
|
||||
ModelRole.IconColor.int:"iconColor",
|
||||
ModelRole.SubItems.int:"subItems"
|
||||
ModelRole.SubItems.int:"subItems",
|
||||
ModelRole.HasSubItems.int:"hasSubItems"
|
||||
}.toTable
|
||||
|
||||
method data(self: Model, index: QModelIndex, role: int): QVariant =
|
||||
|
@ -65,6 +67,8 @@ QtObject:
|
|||
result = newQVariant(item.iconColor)
|
||||
of ModelRole.SubItems:
|
||||
result = newQVariant(item.subItems)
|
||||
of ModelRole.HasSubItems:
|
||||
result = newQVariant(not isNil(item.subItems) and item.subItems.rowCount(nil) > 0)
|
||||
|
||||
proc setItems*(self: Model, items: seq[Item]) =
|
||||
self.beginResetModel()
|
||||
|
|
|
@ -29,16 +29,16 @@ class CommunityScreenComponents(Enum):
|
|||
COMMUNITY_HEADER_BUTTON = "mainWindow_communityHeader_StatusChatInfoButton"
|
||||
COMMUNITY_HEADER_NAME_TEXT= "community_ChatInfo_Name_Text"
|
||||
COMMUNITY_CREATE_CHANNEL_OR_CAT_BUTTON = "mainWindow_createChannelOrCategoryBtn_StatusBaseText"
|
||||
COMMUNITY_CREATE_CHANNEL_MENU_ITEM = "create_channel_StatusMenuItemDelegate"
|
||||
COMMUNITY_CREATE_CATEGORY_MENU_ITEM = "create_category_StatusMenuItemDelegate"
|
||||
COMMUNITY_EDIT_CATEGORY_MENU_ITEM = "edit_сategory_StatusMenuItemDelegate"
|
||||
COMMUNITY_DELETE_CATEGORY_MENU_ITEM = "delete_сategory_StatusMenuItemDelegate"
|
||||
COMMUNITY_CREATE_CHANNEL_MENU_ITEM = "create_channel_StatusMenuItem"
|
||||
COMMUNITY_CREATE_CATEGORY_MENU_ITEM = "create_category_StatusMenuItem"
|
||||
COMMUNITY_EDIT_CATEGORY_MENU_ITEM = "edit_сategory_StatusMenuItem"
|
||||
COMMUNITY_DELETE_CATEGORY_MENU_ITEM = "delete_сategory_StatusMenuItem"
|
||||
COMMUNITY_CONFIRM_DELETE_CATEGORY_BUTTON = "confirmDeleteCategoryButton_StatusButton"
|
||||
CHAT_IDENTIFIER_CHANNEL_ICON = "mainWindow_chatInfoBtnInHeader_StatusChatInfoButton"
|
||||
CHAT_MORE_OPTIONS_BUTTON = "chat_moreOptions_menuButton"
|
||||
EDIT_CHANNEL_MENU_ITEM = "edit_Channel_StatusMenuItemDelegate"
|
||||
EDIT_CHANNEL_MENU_ITEM = "edit_Channel_StatusMenuItem"
|
||||
COMMUNITY_COLUMN_VIEW = "mainWindow_communityColumnView_CommunityColumnView"
|
||||
DELETE_CHANNEL_MENU_ITEM = "delete_Channel_StatusMenuItemDelegate"
|
||||
DELETE_CHANNEL_MENU_ITEM = "delete_Channel_StatusMenuItem"
|
||||
DELETE_CHANNEL_CONFIRMATION_DIALOG_DELETE_BUTTON = "delete_Channel_ConfirmationDialog_DeleteButton"
|
||||
NOT_CATEGORIZED_CHAT_LIST = "mainWindow_communityColumnView_statusChatList"
|
||||
COMMUNITY_CHAT_LIST_CATEGORIES = "communityChatListCategories_Repeater"
|
||||
|
|
|
@ -22,12 +22,12 @@ class MainScreenComponents(Enum):
|
|||
PUBLIC_CHAT_ICON = "mainWindow_public_chat_icon_StatusIcon"
|
||||
CHAT_NAVBAR_ICON = "navBarListView_Chat_navbar_StatusNavBarTabButton"
|
||||
COMMUNITY_PORTAL_BUTTON = "navBarListView_Communities_Portal_navbar_StatusNavBarTabButton"
|
||||
JOIN_PUBLIC_CHAT = "join_public_chat_StatusMenuItemDelegate"
|
||||
JOIN_PUBLIC_CHAT = "join_public_chat_StatusMenuItem"
|
||||
SETTINGS_BUTTON = "navBarListView_Settings_navbar_StatusNavBarTabButton"
|
||||
WALLET_BUTTON = "wallet_navbar_wallet_icon_StatusIcon"
|
||||
START_CHAT_BTN = "mainWindow_startChat"
|
||||
CHAT_LIST = "chatList"
|
||||
MARK_AS_READ_BUTTON = "mark_as_Read_StatusMenuItemDelegate"
|
||||
MARK_AS_READ_BUTTON = "mark_as_Read_StatusMenuItem"
|
||||
COMMUNITY_NAVBAR_BUTTONS = "navBarListView_All_Community_Buttons"
|
||||
SECURE_SEEDPHRASE_BANNER = "secureSeedPhrase_Banner"
|
||||
CONNECTION_INFO_BANNER = "connectionInfo_Banner"
|
||||
|
|
|
@ -22,10 +22,10 @@ mainWindow_emptyChatPanelImage = {"container": statusDesktop_mainWindow, "object
|
|||
mainWindow_RighPanel= {"container": statusDesktop_mainWindow, "type": "ColumnLayout", "objectName": "mainRightView", "visible": True}
|
||||
|
||||
# User Status Profile Menu
|
||||
userContextmenu_AlwaysActiveButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuAlwaysOnlineAction", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
userContextmenu_InActiveButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuInactiveAction", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
userContextmenu_AutomaticButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuAutomaticAction", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
userContextMenu_ViewMyProfileAction = {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusViewMyProfileAction", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
userContextmenu_AlwaysActiveButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuAlwaysOnlineAction", "type": "StatusMenuItem", "visible": True}
|
||||
userContextmenu_InActiveButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuInactiveAction", "type": "StatusMenuItem", "visible": True}
|
||||
userContextmenu_AutomaticButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuAutomaticAction", "type": "StatusMenuItem", "visible": True}
|
||||
userContextMenu_ViewMyProfileAction = {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusViewMyProfileAction", "type": "StatusMenuItem", "visible": True}
|
||||
|
||||
# popups
|
||||
modal_Close_Button = {"container": statusDesktop_mainWindow_overlay, "objectName": "modalCloseButtonRectangle", "type": "Rectangle", "visible": True}
|
||||
|
@ -38,7 +38,7 @@ mainWindow_public_chat_icon_StatusIcon = {"container": statusDesktop_mainWindow,
|
|||
chatList_Repeater = {"container": statusDesktop_mainWindow, "objectName": "chatListItems", "type": "Repeater"}
|
||||
chatList = {"container": statusDesktop_mainWindow, "objectName": "ContactsColumnView_chatList", "type": "StatusChatList"}
|
||||
mainWindow_startChat = {"checkable": True, "container": statusDesktop_mainWindow, "objectName": "startChatButton", "type": "StatusIconTabButton"}
|
||||
join_public_chat_StatusMenuItemDelegate = {"checkable": False, "container": statusDesktop_mainWindow_overlay, "enabled": True, "text": "Join public chat", "type": "StatusMenuItemDelegate", "unnamed": 1, "visible": True}
|
||||
join_public_chat_StatusMenuItem = {"checkable": False, "container": statusDesktop_mainWindow_overlay, "enabled": True, "text": "Join public chat", "type": "StatusMenuItem", "unnamed": 1, "visible": True}
|
||||
chatView_messageInput = {"container": statusDesktop_mainWindow, "objectName": "messageInputField", "type": "TextArea", "visible": True}
|
||||
chatView_StatusChatInfoButton = {"container": statusDesktop_mainWindow, "objectName": "chatInfoBtnInHeader", "type": "StatusChatInfoButton", "visible": True}
|
||||
chatInfoButton_Pin_Text = {"container": chatView_StatusChatInfoButton, "objectName": "StatusChatInfo_pinText", "type": "StatusBaseText", "visible": True}
|
||||
|
|
|
@ -135,9 +135,9 @@ backup_seed_phrase_popup_ConfirmStoringSeedPhrasePanel_storeCheck = {"container"
|
|||
backup_seed_phrase_popup_BackupSeedModal_completeAndDeleteSeedPhraseButton = {"container": statusDesktop_mainWindow_overlay, "objectName": "BackupSeedModal_completeAndDeleteSeedPhraseButton", "type": "StatusButton", "visible": True}
|
||||
|
||||
# User Status Profile Menu
|
||||
userContextmenu_AlwaysActiveButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuAlwaysOnlineAction", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
userContextmenu_InActiveButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuInactiveAction", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
userContextmenu_AutomaticButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuAutomaticAction", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
userContextmenu_AlwaysActiveButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuAlwaysOnlineAction", "type": "StatusMenuItem", "visible": True}
|
||||
userContextmenu_InActiveButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuInactiveAction", "type": "StatusMenuItem", "visible": True}
|
||||
userContextmenu_AutomaticButton= {"container": statusDesktop_mainWindow_overlay, "objectName": "userStatusMenuAutomaticAction", "type": "StatusMenuItem", "visible": True}
|
||||
|
||||
# Change Password Menu
|
||||
change_password_menu_current_password = {"container": statusDesktop_mainWindow_overlay, "objectName": "passwordViewCurrentPassword", "type": "StatusPasswordInput", "visible": True}
|
||||
|
|
|
@ -5,14 +5,14 @@ mainWindow_communityColumnView_CommunityColumnView = {"container": statusDesktop
|
|||
mainWindow_communityHeader_StatusChatInfoButton = {"container": statusDesktop_mainWindow, "objectName": "communityHeaderButton", "type": "StatusChatInfoButton", "visible": True}
|
||||
community_ChatInfo_Name_Text = {"container": mainWindow_communityHeader_StatusChatInfoButton, "objectName": "statusChatInfoButtonNameText", "type": "StatusBaseText", "visible": True}
|
||||
mainWindow_createChannelOrCategoryBtn_StatusBaseText = {"container": statusDesktop_mainWindow, "objectName": "createChannelOrCategoryBtn", "type": "StatusBaseText", "visible": True}
|
||||
create_channel_StatusMenuItemDelegate = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "createCommunityChannelBtn", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
create_category_StatusMenuItemDelegate = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "createCommunityCategoryBtn", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
edit_сategory_StatusMenuItemDelegate = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "editCategoryMenuItem", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
delete_сategory_StatusMenuItemDelegate = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "deleteCategoryMenuItem", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
create_channel_StatusMenuItem = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "createCommunityChannelBtn", "type": "StatusMenuItem", "visible": True}
|
||||
create_category_StatusMenuItem = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "createCommunityCategoryBtn", "type": "StatusMenuItem", "visible": True}
|
||||
edit_сategory_StatusMenuItem = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "editCategoryMenuItem", "type": "StatusMenuItem", "visible": True}
|
||||
delete_сategory_StatusMenuItem = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "deleteCategoryMenuItem", "type": "StatusMenuItem", "visible": True}
|
||||
confirmDeleteCategoryButton_StatusButton = {"container": statusDesktop_mainWindow, "objectName": "confirmDeleteCategoryButton", "type": "StatusButton"}
|
||||
chat_moreOptions_menuButton = {"container": statusDesktop_mainWindow, "objectName": "chatToolbarMoreOptionsButton", "type": "StatusFlatRoundButton", "visible": True}
|
||||
edit_Channel_StatusMenuItemDelegate = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "editChannelMenuItem", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
delete_Channel_StatusMenuItemDelegate = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "deleteOrLeaveMenuItem", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
edit_Channel_StatusMenuItem = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "editChannelMenuItem", "type": "StatusMenuItem", "visible": True}
|
||||
delete_Channel_StatusMenuItem = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "deleteOrLeaveMenuItem", "type": "StatusMenuItem", "visible": True}
|
||||
mainWindow_communityColumnView_statusChatList = {"container": mainWindow_communityColumnView_CommunityColumnView, "objectName": "statusChatListAndCategoriesChatList", "type": "StatusChatList"}
|
||||
mainWindow_chatInfoBtnInHeader_StatusChatInfoButton = {"container": statusDesktop_mainWindow, "objectName": "chatInfoBtnInHeader", "type": "StatusChatInfoButton", "visible": True}
|
||||
communityChatListCategories_Repeater = {"container": statusDesktop_mainWindow, "objectName": "communityChatListCategories", "type": "Repeater"}
|
||||
|
|
|
@ -7,7 +7,7 @@ chatView_lastChatText_Text = {"container": chatView_chatLogView_lastMsg_MessageV
|
|||
chatView_editMessageInputComponent = {"container": statusDesktop_mainWindow, "objectName": "editMessageInput", "type": "StatusChatInput", "visible": True}
|
||||
chatView_editMessageInputTextArea = {"container": chatView_editMessageInputComponent, "objectName": "messageInputField", "type": "TextArea", "visible": True}
|
||||
chatButtonsPanelConfirmDeleteMessageButton_StatusButton = {"container": statusDesktop_mainWindow_overlay, "objectName": "chatButtonsPanelConfirmDeleteMessageButton", "type": "StatusButton"}
|
||||
mark_as_Read_StatusMenuItemDelegate = {"container": statusDesktop_mainWindow_overlay, "objectName": "chatMarkAsReadMenuItem", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
mark_as_Read_StatusMenuItem = {"container": statusDesktop_mainWindow_overlay, "objectName": "chatMarkAsReadMenuItem", "type": "StatusMenuItem", "visible": True}
|
||||
chat_Input_Stickers_Button = {"container": statusDesktop_mainWindow, "objectName": "statusChatInputStickersButton", "type": "StatusFlatRoundButton", "visible": True}
|
||||
chatView_SuggestionBoxPanel ={"container": statusDesktop_mainWindow, "objectName": "suggestionsBox", "type": "SuggestionBoxPanel"}
|
||||
chatView_suggestion_ListView ={"container": chatView_SuggestionBoxPanel, "objectName": "suggestionBoxList", "type": "StatusListView"}
|
||||
|
@ -22,9 +22,9 @@ chatView_unfurledLinkComponent_linkImage = {"container": chatView_log, "objectNa
|
|||
chatView_LinksMessageView_enableBtn = {"container": chatView_log, "objectName": "LinksMessageView_enableBtn", "type": "StatusFlatButton", "visible": True}
|
||||
|
||||
# More options menu
|
||||
clearHistoryMenuItem = {"container": statusDesktop_mainWindow_overlay, "objectName": "clearHistoryMenuItem", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
editNameAndImageMenuItem = {"container": statusDesktop_mainWindow_overlay, "objectName": "editNameAndImageMenuItem", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
leaveChatMenuItem = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "deleteOrLeaveMenuItem", "type": "StatusMenuItemDelegate", "visible": True}
|
||||
clearHistoryMenuItem = {"container": statusDesktop_mainWindow_overlay, "objectName": "clearHistoryMenuItem", "type": "StatusMenuItem", "visible": True}
|
||||
editNameAndImageMenuItem = {"container": statusDesktop_mainWindow_overlay, "objectName": "editNameAndImageMenuItem", "type": "StatusMenuItem", "visible": True}
|
||||
leaveChatMenuItem = {"container": statusDesktop_mainWindow_overlay, "enabled": True, "objectName": "deleteOrLeaveMenuItem", "type": "StatusMenuItem", "visible": True}
|
||||
|
||||
# group chat edit popup
|
||||
groupChatEdit_main = {"container": statusDesktop_mainWindow_overlay, "objectName": "groupChatEdit_main", "type": "StatusDialog", "visible": True}
|
||||
|
|
|
@ -70,8 +70,8 @@ mainWallet_Add_Account_Popup_Footer_Add_Account = {"container": mainWallet_Add_A
|
|||
# saved address view
|
||||
mainWallet_Saved_Addreses_Add_Buttton = {"container": statusDesktop_mainWindow, "objectName": "addNewAddressBtn", "type": "StatusButton"}
|
||||
mainWallet_Saved_Addreses_List = {"container": statusDesktop_mainWindow, "objectName": "SavedAddressesView_savedAddresses", "type": "StatusListView"}
|
||||
mainWallet_Saved_Addreses_More_Edit = {"container": statusDesktop_mainWindow, "objectName": "editroot", "type": "StatusMenuItemDelegate"}
|
||||
mainWallet_Saved_Addreses_More_Delete = {"container": statusDesktop_mainWindow, "objectName": "deleteSavedAddress", "type": "StatusMenuItemDelegate"}
|
||||
mainWallet_Saved_Addreses_More_Edit = {"container": statusDesktop_mainWindow, "objectName": "editroot", "type": "StatusMenuItem"}
|
||||
mainWallet_Saved_Addreses_More_Delete = {"container": statusDesktop_mainWindow, "objectName": "deleteSavedAddress", "type": "StatusMenuItem"}
|
||||
mainWallet_Saved_Addreses_More_Confirm_Delete = {"container": statusDesktop_mainWindow, "objectName": "confirmDeleteSavedAddress", "type": "StatusButton"}
|
||||
|
||||
# saved address add popup
|
||||
|
|
|
@ -116,19 +116,19 @@ Rectangle {
|
|||
}
|
||||
}
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
popupMenu: StatusMenu {
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Invite People")
|
||||
icon.name: "share-ios"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("View Community")
|
||||
icon.name: "group"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Edit Community")
|
||||
icon.name: "edit"
|
||||
enabled: false
|
||||
|
@ -136,10 +136,10 @@ Rectangle {
|
|||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Leave Community")
|
||||
icon.name: "arrow-left"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -201,33 +201,7 @@ Column {
|
|||
badge.visible: model.hasNotification
|
||||
badge.border.color: hovered ? Theme.palette.statusBadge.hoverBorderColor : Theme.palette.statusBadge.borderColor
|
||||
badge.border.width: 2
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Invite People")
|
||||
icon.name: "share-ios"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("View Community")
|
||||
icon.name: "group"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Edit Community")
|
||||
icon.name: "edit"
|
||||
enabled: false
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Leave Community")
|
||||
icon.name: "arrow-left"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
}
|
||||
}
|
||||
popupMenu: communityPopupMenu
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -284,33 +258,7 @@ Column {
|
|||
badge.visible: model.hasNotification
|
||||
badge.border.color: hovered ? Theme.palette.statusBadge.hoverBorderColor : Theme.palette.statusBadge.borderColor
|
||||
badge.border.width: 2
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Invite People")
|
||||
icon.name: "share-ios"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("View Community")
|
||||
icon.name: "group"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Edit Community")
|
||||
icon.name: "edit"
|
||||
enabled: false
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Leave Community")
|
||||
icon.name: "arrow-left"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
}
|
||||
}
|
||||
popupMenu: communityPopupMenu
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -372,33 +320,7 @@ Column {
|
|||
badge.visible: model.hasNotification
|
||||
badge.border.color: hovered ? Theme.palette.statusBadge.hoverBorderColor : Theme.palette.statusBadge.borderColor
|
||||
badge.border.width: 2
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Invite People")
|
||||
icon.name: "share-ios"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("View Community")
|
||||
icon.name: "group"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Edit Community")
|
||||
icon.name: "edit"
|
||||
enabled: false
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Leave Community")
|
||||
icon.name: "arrow-left"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
}
|
||||
}
|
||||
popupMenu: communityPopupMenu
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -465,33 +387,38 @@ Column {
|
|||
badge.visible: model.hasNotification
|
||||
badge.border.color: hovered ? Theme.palette.statusBadge.hoverBorderColor : Theme.palette.statusBadge.borderColor
|
||||
badge.border.width: 2
|
||||
popupMenu: communityPopupMenu
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
Component {
|
||||
id: communityPopupMenu
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Invite People")
|
||||
icon.name: "share-ios"
|
||||
}
|
||||
StatusMenu {
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("View Community")
|
||||
icon.name: "group"
|
||||
}
|
||||
StatusAction {
|
||||
text: qsTr("Invite People")
|
||||
icon.name: "share-ios"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Edit Community")
|
||||
icon.name: "edit"
|
||||
enabled: false
|
||||
}
|
||||
StatusAction {
|
||||
text: qsTr("View Community")
|
||||
icon.name: "group"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
StatusAction {
|
||||
text: qsTr("Edit Community")
|
||||
icon.name: "edit"
|
||||
enabled: false
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
text: qsTr("Leave Community")
|
||||
icon.name: "arrow-left"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
}
|
||||
}
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusAction {
|
||||
text: qsTr("Leave Community")
|
||||
icon.name: "arrow-left"
|
||||
type: StatusAction.Type.Danger
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -70,11 +70,6 @@ Column {
|
|||
onClicked: modalWithHeaderPopupMenu.open()
|
||||
}
|
||||
|
||||
StatusButton {
|
||||
text: "Spellchecking menu"
|
||||
onClicked: spellMenu.open()
|
||||
}
|
||||
|
||||
StatusButton {
|
||||
text: "Modal with Editable Title"
|
||||
onClicked: editTitleModal.open()
|
||||
|
@ -336,21 +331,20 @@ Column {
|
|||
anchors.centerIn: parent
|
||||
header.title: "helloworld.eth"
|
||||
header.subTitle: "Basic address"
|
||||
header.popupMenu: StatusPopupMenu {
|
||||
header.popupMenu: StatusMenu {
|
||||
id: popupMenu
|
||||
Repeater {
|
||||
|
||||
StatusMenuInstantiator {
|
||||
model: dummyAccountsModel
|
||||
delegate: Loader {
|
||||
sourceComponent: popupMenu.delegate
|
||||
onLoaded: {
|
||||
item.action.text = model.name
|
||||
item.action.assetSettings.name = model.iconName
|
||||
menu: popupMenu
|
||||
delegate: StatusAction {
|
||||
text: model.name
|
||||
assetSettings.name: model.iconName
|
||||
onTriggered: {
|
||||
popupMenu.dismiss()
|
||||
}
|
||||
}
|
||||
}
|
||||
onMenuItemClicked: {
|
||||
popupMenu.dismiss()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -407,12 +401,14 @@ Column {
|
|||
hasFloatingButtons: true
|
||||
advancedHeaderComponent: StatusFloatingButtonsSelector {
|
||||
id: floatingHeader
|
||||
|
||||
model: dummyAccountsModel
|
||||
|
||||
delegate: Rectangle {
|
||||
width: button.width
|
||||
height: button.height
|
||||
radius: 8
|
||||
visible: visibleIndices.includes(index)
|
||||
visible: floatingHeader.visibleIndices.includes(index)
|
||||
color: Theme.palette.statusAppLayout.backgroundColor
|
||||
StatusButton {
|
||||
id: button
|
||||
|
@ -431,29 +427,23 @@ Column {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
popupMenuDelegate: StatusListItem {
|
||||
implicitWidth: 272
|
||||
title: name
|
||||
onClicked: floatingHeader.itemSelected(index)
|
||||
visible: !visibleIndices.includes(index)
|
||||
onClicked: floatingHeader.selectItem(index)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
ListModel {
|
||||
id: dummyAccountsModel
|
||||
ListElement{name: "Account 1"; iconName: "filled-account"; emoji: "🥑"}
|
||||
ListElement{name: "Account 2"; iconName: "filled-account"}
|
||||
ListElement{name: "Account 1"; iconName: "filled-account"; emoji: "🥑" }
|
||||
ListElement{name: "Account 2"; iconName: "filled-account"; emoji: "🚀" }
|
||||
ListElement{name: "Account 3"; iconName: "filled-account"}
|
||||
ListElement{name: "Account 4"; iconName: "filled-account"}
|
||||
ListElement{name: "Account 5"; iconName: "filled-account"}
|
||||
ListElement{name: "Account 6"; iconName: "filled-account"}
|
||||
ListElement{name: "Account 7"; iconName: "filled-account"}
|
||||
}
|
||||
|
||||
StatusSpellcheckingMenuItems {
|
||||
id: spellMenu
|
||||
anchors.centerIn: parent
|
||||
suggestions: ["suggestion1", "suggestion2", "suggestion3", "suggestion4"]
|
||||
}
|
||||
}
|
||||
|
|
|
@ -81,28 +81,28 @@ StatusSectionLayout {
|
|||
contextMenu.openHandler = originalOpenHandler
|
||||
contextMenu.popup(-contextMenu.width + menuButton.width, menuButton.height + 4)
|
||||
}
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: contextMenu
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Mute Chat"
|
||||
icon.name: "notification"
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Mark as Read"
|
||||
icon.name: "checkmark-circle"
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Clear History"
|
||||
icon.name: "close-circle"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Leave Chat"
|
||||
icon.name: "arrow-left"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -210,7 +210,7 @@ StatusSectionLayout {
|
|||
}
|
||||
}
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
popupMenu: StatusMenu {
|
||||
|
||||
property string chatId
|
||||
|
||||
|
@ -218,34 +218,34 @@ StatusSectionLayout {
|
|||
chatId = id
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "View Profile"
|
||||
icon.name: "group-chat"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Mute chat"
|
||||
icon.name: "notification"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Mark as Read"
|
||||
icon.name: "checkmark-circle"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Clear history"
|
||||
icon.name: "close-circle"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Delete chat"
|
||||
icon.name: "delete"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -113,8 +113,23 @@ StatusSectionLayout {
|
|||
}
|
||||
StatusSearchLocationMenu {
|
||||
id: searchPopupMenu
|
||||
searchPopup: searchPopup
|
||||
locationModel: Models.optionsModel
|
||||
|
||||
onResetSearchSelection: {
|
||||
searchPopup.resetSearchSelection()
|
||||
}
|
||||
|
||||
onSetSearchSelection: {
|
||||
searchPopup.setSearchSelection(text,
|
||||
secondaryText,
|
||||
imageSource,
|
||||
isIdenticon,
|
||||
iconName,
|
||||
iconColor,
|
||||
isUserIcon,
|
||||
colorId,
|
||||
colorHash)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -134,21 +149,21 @@ StatusSectionLayout {
|
|||
chatInfoButton.asset.color: Theme.palette.miscColor6
|
||||
chatInfoButton.onClicked: { chatInfoButtonClicked(); }
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
popupMenu: StatusMenu {
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Create channel"
|
||||
icon.name: "channel"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Create category"
|
||||
icon.name: "channel-category"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Invite people"
|
||||
icon.name: "share-ios"
|
||||
}
|
||||
|
@ -178,7 +193,7 @@ StatusSectionLayout {
|
|||
|
||||
showCategoryActionButtons: true
|
||||
|
||||
categoryPopupMenu: StatusPopupMenu {
|
||||
categoryPopupMenu: StatusMenu {
|
||||
|
||||
property string categoryId
|
||||
|
||||
|
@ -186,72 +201,72 @@ StatusSectionLayout {
|
|||
categoryId = id
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Mute Category"
|
||||
icon.name: "notification"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Mark as Read"
|
||||
icon.name: "checkmark-circle"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Edit Category"
|
||||
icon.name: "edit"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Delete Category"
|
||||
icon.name: "delete"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
}
|
||||
}
|
||||
|
||||
chatListPopupMenu: StatusPopupMenu {
|
||||
chatListPopupMenu: StatusMenu {
|
||||
|
||||
property string chatId
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Mute chat"
|
||||
icon.name: "notification"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Mark as Read"
|
||||
icon.name: "checkmark-circle"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Clear history"
|
||||
icon.name: "close-circle"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Delete chat"
|
||||
icon.name: "delete"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
}
|
||||
}
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
StatusMenuItem {
|
||||
popupMenu: StatusMenu {
|
||||
StatusAction {
|
||||
text: "Create channel"
|
||||
icon.name: "channel"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Create category"
|
||||
icon.name: "channel-category"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Invite people"
|
||||
icon.name: "share-ios"
|
||||
}
|
||||
|
|
|
@ -22,6 +22,7 @@ QtObject {
|
|||
active: false
|
||||
position: 0
|
||||
isCategory: false
|
||||
hasSubItems: false
|
||||
subItems: []
|
||||
}
|
||||
ListElement {
|
||||
|
@ -40,6 +41,7 @@ QtObject {
|
|||
active: false
|
||||
position: 1
|
||||
isCategory: false
|
||||
hasSubItems: false
|
||||
subItems: []
|
||||
}
|
||||
ListElement {
|
||||
|
@ -59,6 +61,7 @@ QtObject {
|
|||
active: true
|
||||
position: 2
|
||||
isCategory: false
|
||||
hasSubItems: false
|
||||
subItems: []
|
||||
}
|
||||
ListElement {
|
||||
|
@ -77,6 +80,7 @@ QtObject {
|
|||
active: false
|
||||
position: 3
|
||||
isCategory: false
|
||||
hasSubItems: false
|
||||
subItems: []
|
||||
}
|
||||
ListElement {
|
||||
|
@ -95,6 +99,7 @@ QtObject {
|
|||
active: false
|
||||
position: 4
|
||||
isCategory: false
|
||||
hasSubItems: false
|
||||
subItems: []
|
||||
}
|
||||
ListElement {
|
||||
|
@ -113,6 +118,7 @@ QtObject {
|
|||
active: false
|
||||
position: 5
|
||||
isCategory: false
|
||||
hasSubItems: false
|
||||
subItems: []
|
||||
}
|
||||
}
|
||||
|
@ -133,6 +139,7 @@ QtObject {
|
|||
active: false
|
||||
position: 0
|
||||
isCategory: true
|
||||
hasSubItems: false
|
||||
subItems: []
|
||||
}
|
||||
ListElement {
|
||||
|
@ -149,6 +156,7 @@ QtObject {
|
|||
active: false
|
||||
position: 0
|
||||
isCategory: false
|
||||
hasSubItems: false
|
||||
subItems: []
|
||||
}
|
||||
ListElement {
|
||||
|
@ -165,6 +173,7 @@ QtObject {
|
|||
active: true
|
||||
position: 1
|
||||
isCategory: true
|
||||
hasSubItems: true
|
||||
subItems: [
|
||||
ListElement {
|
||||
itemId: "x012340002"
|
||||
|
@ -210,6 +219,7 @@ QtObject {
|
|||
active: false
|
||||
position: 2
|
||||
isCategory: true
|
||||
hasSubItems: true
|
||||
subItems: [
|
||||
ListElement {
|
||||
itemId: "x012340005"
|
||||
|
@ -357,6 +367,8 @@ QtObject {
|
|||
imageSource: ""
|
||||
iconName: "chat"
|
||||
iconColor: ""
|
||||
isIdenticon: false
|
||||
hasSubItems: true
|
||||
subItems: [
|
||||
ListElement {
|
||||
value: "sub_item_1_1"
|
||||
|
@ -373,12 +385,23 @@ QtObject {
|
|||
iconName: ""
|
||||
iconColor: ""
|
||||
}]}
|
||||
ListElement {
|
||||
value: "item_1"
|
||||
title: "No submenu"
|
||||
imageSource: ""
|
||||
iconName: "airdrop"
|
||||
isIdenticon: false
|
||||
hasSubItems: false
|
||||
subItems: []
|
||||
}
|
||||
ListElement {
|
||||
value: "item_2"
|
||||
title: "Community item";
|
||||
imageSource: "qrc:/demoapp/data/profile-image-1.jpeg"
|
||||
iconName: ""
|
||||
iconColor: ""
|
||||
isIdenticon: false
|
||||
hasSubItems: true
|
||||
subItems: [
|
||||
ListElement {
|
||||
value: "sub_item_2_1"
|
||||
|
@ -407,6 +430,8 @@ QtObject {
|
|||
imageSource: "";
|
||||
iconName: "info"
|
||||
iconColor: ""
|
||||
isIdenticon: false
|
||||
hasSubItems: true
|
||||
subItems: [
|
||||
ListElement {
|
||||
value: "sub_item_3_1"
|
||||
|
@ -421,6 +446,8 @@ QtObject {
|
|||
imageSource: "";
|
||||
iconName: ""
|
||||
iconColor: "red"
|
||||
isIdenticon: false
|
||||
hasSubItems: true
|
||||
subItems: [
|
||||
ListElement {
|
||||
value: "sub_item_4_1"
|
||||
|
|
|
@ -312,7 +312,7 @@ StatusWindow {
|
|||
}
|
||||
StatusListSectionHeadline { text: "StatusQ.Popup" }
|
||||
StatusNavigationListItem {
|
||||
title: "StatusPopupMenu"
|
||||
title: "StatusMenu"
|
||||
selected: viewLoader.source.toString().includes(title)
|
||||
onClicked: mainPageView.page(title);
|
||||
}
|
||||
|
|
|
@ -18,21 +18,21 @@ GridLayout {
|
|||
chatInfoButton.asset.name: "qrc:/demoapp/data/profile-image-1.jpeg"
|
||||
chatInfoButton.asset.color: Theme.palette.miscColor6
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
popupMenu: StatusMenu {
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Create channel"
|
||||
icon.name: "channel"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Create category"
|
||||
icon.name: "channel-category"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Invite people"
|
||||
icon.name: "share-ios"
|
||||
}
|
||||
|
|
|
@ -249,7 +249,7 @@ ColumnLayout {
|
|||
implicitWidth: customHeaderText.width * 2
|
||||
|
||||
border.width: 2
|
||||
color: Theme.palette.statusPopupMenu.hoverBackgroundColor
|
||||
color: Theme.palette.statusMenu.hoverBackgroundColor
|
||||
|
||||
StatusBaseText {
|
||||
id: customHeaderText
|
||||
|
@ -263,7 +263,7 @@ ColumnLayout {
|
|||
implicitWidth: customHeaderText.width * 2
|
||||
|
||||
border.width: 2
|
||||
color: Theme.palette.statusPopupMenu.hoverBackgroundColor
|
||||
color: Theme.palette.statusMenu.hoverBackgroundColor
|
||||
|
||||
StatusBaseText {
|
||||
id: customFooter
|
||||
|
|
|
@ -2,11 +2,15 @@ import QtQuick 2.14
|
|||
import QtQuick.Layouts 1.14
|
||||
import QtQuick.Controls 2.13
|
||||
|
||||
import Qt.labs.qmlmodels 1.0
|
||||
|
||||
import StatusQ.Core 0.1
|
||||
import StatusQ.Core.Theme 0.1
|
||||
import StatusQ.Controls 0.1
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
import "../demoapp/data" 1.0
|
||||
|
||||
GridLayout {
|
||||
columns: 1
|
||||
columnSpacing: 5
|
||||
|
@ -22,8 +26,8 @@ GridLayout {
|
|||
onClicked: complexMenu.popup()
|
||||
}
|
||||
|
||||
|
||||
StatusButton {
|
||||
id: customPopupButton
|
||||
text: "Menu with custom images and icons"
|
||||
onClicked: customMenu.popup()
|
||||
}
|
||||
|
@ -33,103 +37,124 @@ GridLayout {
|
|||
onClicked: differentFontMenu.popup()
|
||||
}
|
||||
|
||||
StatusButton {
|
||||
text: "StatusSearchLocationMenu"
|
||||
onClicked: searchPopupMenu.popup()
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusSearchLocationMenu {
|
||||
id: searchPopupMenu
|
||||
locationModel: Models.optionsModel
|
||||
}
|
||||
}
|
||||
|
||||
StatusMenu {
|
||||
id: simpleMenu
|
||||
StatusMenuItem {
|
||||
|
||||
StatusAction {
|
||||
text: "One"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Two"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Three"
|
||||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: complexMenu
|
||||
subMenuItemIcons: [{ icon: 'info' }]
|
||||
hideDisabledItems: false
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "One"
|
||||
assetSettings.name: "info"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Two"
|
||||
assetSettings.name: "info"
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
text: "Three"
|
||||
StatusMenu {
|
||||
title: "Two"
|
||||
assetSettings.name: "info"
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
title: "Four"
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "One"
|
||||
assetSettings.name: "info"
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Three"
|
||||
assetSettings.name: "info"
|
||||
}
|
||||
}
|
||||
|
||||
StatusAction {
|
||||
text: "Disabled"
|
||||
assetSettings.name: "info"
|
||||
enabled: false
|
||||
}
|
||||
|
||||
StatusAction {
|
||||
text: "Danger"
|
||||
type: StatusAction.Type.Danger
|
||||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: customMenu
|
||||
|
||||
subMenuItemIcons: [
|
||||
{ icon: "chat" },
|
||||
{
|
||||
source: "qrc:/demoapp/data/profile-image-1.jpeg"
|
||||
},
|
||||
{
|
||||
isLetterIdenticon: true,
|
||||
color: "red"
|
||||
}
|
||||
]
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Anywhere"
|
||||
}
|
||||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusPopupMenu {
|
||||
title: "Chat"
|
||||
StatusMenu {
|
||||
title: "Chat"
|
||||
assetSettings.name: "chat"
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "vitalik.eth"
|
||||
assetSettings.isImage: true
|
||||
assetSettings.imgIsIdenticon: true
|
||||
assetSettings.name: "
|
||||
CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2ImYgiNITTlTdG1nUZ5a92VITQxITFiJmIIjSE0htAYQrMHAAD//+wwFVpz+yqXAAAAAElFTkSuQmCC"
|
||||
assetSettings.imgIsIdenticon: true
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Pascal"
|
||||
assetSettings.isImage: true
|
||||
assetSettings.name: "qrc:/demoapp/data/profile-image-1.jpeg"
|
||||
ringSettings.ringSpecModel:
|
||||
ListModel {
|
||||
ListElement { colorId: 13; segmentLength: 5 }
|
||||
ListElement { colorId: 31; segmentLength: 5 }
|
||||
ListElement { colorId: 10; segmentLength: 1 }
|
||||
ListElement { colorId: 2; segmentLength: 5 }
|
||||
ListElement { colorId: 26; segmentLength: 2 }
|
||||
ListElement { colorId: 19; segmentLength: 4 }
|
||||
ListElement { colorId: 28; segmentLength: 3 }
|
||||
}
|
||||
ringSettings.distinctiveColors: Theme.palette.identiconRingColors
|
||||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
title: "Cryptokitties"
|
||||
assetSettings.isImage: true
|
||||
assetSettings.name: "qrc:/demoapp/data/profile-image-1.jpeg"
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "welcome"
|
||||
assetSettings.name: "channel"
|
||||
assetSettings.color: Theme.palette.directColor1
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "support"
|
||||
assetSettings.name: "channel"
|
||||
assetSettings.color: Theme.palette.directColor1
|
||||
|
@ -137,37 +162,39 @@ CExPynn1gWf9bx498P7/nzPcxEzGExhBdJGYihtAYQlO+tUZvqrPbqeudo5iJGEJjCE15a3VtodH3q2I
|
|||
|
||||
StatusMenuHeadline { text: "Public" }
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "news"
|
||||
assetSettings.name: "channel"
|
||||
assetSettings.color: Theme.palette.directColor1
|
||||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
title: "Another community"
|
||||
assetSettings.isLetterIdenticon: true
|
||||
assetSettings.color: "red"
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "welcome"
|
||||
assetSettings.isLetterIdenticon: true
|
||||
assetSettings.bgColor: "red"
|
||||
assetSettings.color: "blue"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: differentFontMenu
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Bold"
|
||||
fontSettings.bold: true
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "Italic"
|
||||
fontSettings.italic: true
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: "16px"
|
||||
fontSettings.pixelSize: 16
|
||||
}
|
|
@ -40,27 +40,18 @@ Column {
|
|||
label: "Some label"
|
||||
model: commmonModel
|
||||
|
||||
selectMenu.delegate: StatusMenuItemDelegate {
|
||||
statusPopupMenu: select
|
||||
action: StatusMenuItem {
|
||||
assetSettings.name: "filled-account"
|
||||
text: name
|
||||
onTriggered: {
|
||||
selectedItem.text = name
|
||||
}
|
||||
menuDelegate: StatusAction {
|
||||
assetSettings.name: "filled-account"
|
||||
text: name
|
||||
onTriggered: {
|
||||
selectedItem.text = name
|
||||
}
|
||||
}
|
||||
|
||||
selectedItemComponent: Item {
|
||||
selectedItemComponent: StatusBaseText {
|
||||
id: selectedItem
|
||||
anchors.fill: parent
|
||||
property string text: ""
|
||||
|
||||
StatusBaseText {
|
||||
text: selectedItem.text
|
||||
anchors.centerIn: parent
|
||||
color: Theme.palette.directColor1
|
||||
}
|
||||
Layout.alignment: Qt.AlignCenter
|
||||
color: Theme.palette.directColor1
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -61,7 +61,7 @@
|
|||
<file>pages/StatusMacNotificationPage.qml</file>
|
||||
<file>pages/StatusPasswordStrengthIndicatorPage.qml</file>
|
||||
<file>pages/StatusPinInputPage.qml</file>
|
||||
<file>pages/StatusPopupMenuPage.qml</file>
|
||||
<file>pages/StatusMenuPage.qml</file>
|
||||
<file>pages/StatusSelectPage.qml</file>
|
||||
<file>pages/StatusTabBarButtonPage.qml</file>
|
||||
<file>pages/StatusTabBarIconButtonPage.qml</file>
|
||||
|
|
|
@ -238,7 +238,7 @@ Item {
|
|||
anchors.top: btn.bottom
|
||||
anchors.topMargin: 4
|
||||
visible: false
|
||||
color: Theme.palette.statusPopupMenu.backgroundColor
|
||||
color: Theme.palette.statusMenu.backgroundColor
|
||||
radius: 8
|
||||
layer.enabled: true
|
||||
layer.effect: DropShadow {
|
||||
|
@ -281,7 +281,7 @@ Item {
|
|||
id: header
|
||||
width: content.itemWidth
|
||||
height: searchInput.height + 24
|
||||
color: Theme.palette.statusPopupMenu.backgroundColor
|
||||
color: Theme.palette.statusMenu.backgroundColor
|
||||
z: 3 // Above delegate (z=1) and above section.delegate (z = 2)
|
||||
|
||||
StatusInput {
|
||||
|
|
|
@ -19,7 +19,7 @@ Loader {
|
|||
|
||||
property StatusIdenticonRingSettings ringSettings: StatusIdenticonRingSettings {
|
||||
initalAngleRad: 0
|
||||
ringPxSize: Math.max(1.5, root.asset.width/ 24.0)
|
||||
ringPxSize: root.asset.ringPxSize
|
||||
distinctiveColors: Theme.palette.identiconRingColors
|
||||
}
|
||||
|
||||
|
@ -28,9 +28,12 @@ Loader {
|
|||
|
||||
Component {
|
||||
id: roundedImage
|
||||
|
||||
Item {
|
||||
width: root.asset.width
|
||||
height: root.asset.height
|
||||
|
||||
|
||||
StatusRoundedImage {
|
||||
id: statusRoundImage
|
||||
width: parent.width
|
||||
|
|
|
@ -367,7 +367,7 @@ Item {
|
|||
anchors.fill: parent
|
||||
anchors.margins: 8
|
||||
visible: (root.sortedList.count > 0)
|
||||
color: Theme.palette.statusPopupMenu.backgroundColor
|
||||
color: Theme.palette.statusMenu.backgroundColor
|
||||
radius: 8
|
||||
layer.enabled: true
|
||||
layer.effect: DropShadow {
|
||||
|
|
|
@ -32,7 +32,7 @@ QC.Popup {
|
|||
closePolicy: QC.Popup.CloseOnPressOutside | QC.Popup.CloseOnEscape
|
||||
background: Rectangle {
|
||||
id: border
|
||||
color: Theme.palette.statusPopupMenu.backgroundColor
|
||||
color: Theme.palette.statusMenu.backgroundColor
|
||||
radius: 8
|
||||
border.color: "transparent"
|
||||
layer.enabled: true
|
||||
|
|
|
@ -7,6 +7,8 @@ import StatusQ.Components 0.1
|
|||
import StatusQ.Controls 0.1
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
import SortFilterProxyModel 0.2
|
||||
|
||||
/*!
|
||||
\qmltype StatusModalFloatingButtonsSelector
|
||||
\inherits Row
|
||||
|
@ -40,7 +42,7 @@ import StatusQ.Popups 0.1
|
|||
For a list of components available see StatusQ.
|
||||
*/
|
||||
Row {
|
||||
id: floatingButtons
|
||||
id: root
|
||||
|
||||
/*!
|
||||
\qmlproperty repeater
|
||||
|
@ -63,7 +65,7 @@ Row {
|
|||
Can be used to assign delegate to the popupmenu
|
||||
\endqml
|
||||
*/
|
||||
property alias popupMenuDelegate: popupMenuSelectionRepeater.delegate
|
||||
property alias popupMenuDelegate: popupMenuSelectionInstantiator.delegate
|
||||
|
||||
/*!
|
||||
\qmlproperty model
|
||||
|
@ -87,9 +89,9 @@ Row {
|
|||
*/
|
||||
property int currentIndex: 0
|
||||
|
||||
function itemSelected(index) {
|
||||
visibleIndices = [0,1,index]
|
||||
floatingButtons.currentIndex = index
|
||||
function selectItem(index) {
|
||||
visibleIndices = [0, 1, visibleIndices.length + index]
|
||||
root.currentIndex = index
|
||||
popupMenu.close()
|
||||
}
|
||||
|
||||
|
@ -97,16 +99,29 @@ Row {
|
|||
spacing: 12
|
||||
clip: true
|
||||
|
||||
SortFilterProxyModel {
|
||||
id: menuModel
|
||||
|
||||
sourceModel: root.model
|
||||
|
||||
filters: [
|
||||
ExpressionFilter {
|
||||
enabled: root.visibleIndices.length > 0
|
||||
expression: !root.visibleIndices.includes(index)
|
||||
}
|
||||
]
|
||||
}
|
||||
|
||||
Repeater {
|
||||
id: itemSelectionRepeater
|
||||
model: floatingButtons.model
|
||||
model: root.model
|
||||
}
|
||||
|
||||
Rectangle {
|
||||
width: button.width
|
||||
height: button.height
|
||||
radius: 8
|
||||
visible: floatingButtons.model.count > 3
|
||||
visible: root.model.count > 3
|
||||
color: Theme.palette.statusAppLayout.backgroundColor
|
||||
StatusButton {
|
||||
id: button
|
||||
|
@ -118,7 +133,7 @@ Row {
|
|||
normalColor: Theme.palette.baseColor3
|
||||
asset.name: "more"
|
||||
asset.bgColor: "transparent"
|
||||
onClicked: popupMenu.popup(parent.x, y + height + 8)
|
||||
onClicked: popupMenu.popup(parent.x + 4, y + height + 4)
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -128,15 +143,14 @@ Row {
|
|||
Layout.fillWidth: true
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: popupMenu
|
||||
width: layout.width
|
||||
ColumnLayout {
|
||||
id: layout
|
||||
Repeater {
|
||||
id: popupMenuSelectionRepeater
|
||||
model: floatingButtons.model
|
||||
}
|
||||
width: implicitWidth
|
||||
|
||||
StatusMenuInstantiator {
|
||||
id: popupMenuSelectionInstantiator
|
||||
model: menuModel
|
||||
menu: popupMenu
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -42,7 +42,7 @@ ItemDelegate {
|
|||
|
||||
background: Rectangle {
|
||||
color: root.highlighted
|
||||
? Theme.palette.statusPopupMenu.hoverBackgroundColor
|
||||
? Theme.palette.statusMenu.hoverBackgroundColor
|
||||
: "transparent"
|
||||
|
||||
MouseArea {
|
||||
|
|
|
@ -196,14 +196,14 @@ Item {
|
|||
anchors.topMargin: 4
|
||||
visible: ((seedSuggestionsList.count > 0) && seedWordInput.input.edit.activeFocus)
|
||||
Rectangle {
|
||||
id: statusPopupMenuBackgroundContent
|
||||
id: statusMenuBackgroundContent
|
||||
anchors.fill: parent
|
||||
color: Theme.palette.statusPopupMenu.backgroundColor
|
||||
color: Theme.palette.statusMenu.backgroundColor
|
||||
radius: 8
|
||||
layer.enabled: true
|
||||
layer.effect: DropShadow {
|
||||
anchors.fill: parent
|
||||
source: statusPopupMenuBackgroundContent
|
||||
source: statusMenuBackgroundContent
|
||||
horizontalOffset: 0
|
||||
verticalOffset: 4
|
||||
radius: 12
|
||||
|
|
|
@ -22,6 +22,7 @@ Item {
|
|||
readonly property int labelMargin: 7
|
||||
property var model
|
||||
property alias selectMenu: selectMenu
|
||||
property alias menuDelegate: menuInstantiator.delegate
|
||||
property color bgColorHover: bgColor
|
||||
// TODO: Fix the indirect handling of children
|
||||
property alias selectedItemComponent: selectedItemContainer.children
|
||||
|
@ -53,10 +54,9 @@ Item {
|
|||
}
|
||||
|
||||
Rectangle {
|
||||
property bool hovered: false
|
||||
id: inputRectangle
|
||||
height: selectedItemContainer.implicitHeight
|
||||
color: hovered ? bgColorHover : bgColor
|
||||
height: Math.max(56, selectedItemContainer.implicitHeight)
|
||||
color: mouseArea.containsMouse ? bgColorHover : bgColor
|
||||
radius: 8
|
||||
anchors.top: root.hasLabel ? inputLabel.bottom : parent.top
|
||||
anchors.topMargin: root.hasLabel ? root.labelMargin : 0
|
||||
|
@ -103,26 +103,31 @@ Item {
|
|||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: selectMenu
|
||||
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutsideParent
|
||||
width: parent.width
|
||||
|
||||
Repeater {
|
||||
id: menuItems
|
||||
model: root.model
|
||||
StatusMenuInstantiator {
|
||||
id: menuInstantiator
|
||||
|
||||
property int zeroItemsViewHeight
|
||||
delegate: selectMenu.delegate
|
||||
onItemAdded: {
|
||||
|
||||
menu: selectMenu
|
||||
model: root.model
|
||||
|
||||
onObjectAdded: {
|
||||
root.zeroItemsView.visible = false
|
||||
root.zeroItemsView.height = 0
|
||||
}
|
||||
onItemRemoved: {
|
||||
|
||||
onObjectRemoved: {
|
||||
if (count === 0) {
|
||||
root.zeroItemsView.visible = true
|
||||
root.zeroItemsView.height = zeroItemsViewHeight
|
||||
}
|
||||
}
|
||||
|
||||
Component.onCompleted: {
|
||||
zeroItemsViewHeight = root.zeroItemsView.height
|
||||
root.zeroItemsView.visible = count === 0
|
||||
|
@ -152,12 +157,6 @@ Item {
|
|||
anchors.fill: inputRectangle
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
hoverEnabled: true
|
||||
onEntered: {
|
||||
inputRectangle.hovered = true
|
||||
}
|
||||
onExited: {
|
||||
inputRectangle.hovered = false
|
||||
}
|
||||
onClicked: {
|
||||
if (selectMenu.opened) {
|
||||
selectMenu.close()
|
||||
|
|
|
@ -34,4 +34,7 @@ QtObject {
|
|||
property bool isImage: false
|
||||
property int imgStatus
|
||||
property bool imgIsIdenticon: false
|
||||
|
||||
// ring settings hints
|
||||
readonly property real ringPxSize: Math.max(1.5, root.width / 24.0)
|
||||
}
|
||||
|
|
|
@ -55,8 +55,9 @@ QtObject {
|
|||
/*!
|
||||
\qmlproperty real StatusIdenticonRingSettings::initalAngleRad
|
||||
This property provides the initial angle, in radians, the identicon ring will start rendering the line.
|
||||
Defaults to 0.
|
||||
*/
|
||||
property real initalAngleRad
|
||||
property real initalAngleRad: 0
|
||||
|
||||
/*!
|
||||
\qmlproperty real StatusIdenticonRingSettings::ringPxSize
|
||||
|
|
|
@ -3,6 +3,7 @@ import StatusQ.Core.Theme 0.1
|
|||
|
||||
QtObject {
|
||||
id: root
|
||||
|
||||
property int width
|
||||
property int height
|
||||
property bool isIdenticon: false
|
||||
|
@ -28,7 +29,7 @@ QtObject {
|
|||
|
||||
readonly property StatusIdenticonRingSettings ringSettings: StatusIdenticonRingSettings {
|
||||
initalAngleRad: 0
|
||||
ringPxSize: Math.max(1.5, root.width / 24.0)
|
||||
ringPxSize: root.assetSettings.ringPxSize
|
||||
ringSpecModel: root.showRing ? root.colorHash : undefined
|
||||
distinctiveColors: Theme.palette.identiconRingColors
|
||||
}
|
||||
|
|
|
@ -126,7 +126,7 @@ ThemePalette {
|
|||
property color backgroundColor: baseColor3
|
||||
}
|
||||
|
||||
property QtObject statusPopupMenu: QtObject {
|
||||
property QtObject statusMenu: QtObject {
|
||||
property color backgroundColor: baseColor2
|
||||
property color hoverBackgroundColor: directColor7
|
||||
property color separatorColor: directColor7
|
||||
|
|
|
@ -124,7 +124,7 @@ ThemePalette {
|
|||
property color backgroundColor: white
|
||||
}
|
||||
|
||||
property QtObject statusPopupMenu: QtObject {
|
||||
property QtObject statusMenu: QtObject {
|
||||
property color backgroundColor: white
|
||||
property color hoverBackgroundColor: baseColor2
|
||||
property color separatorColor: baseColor2
|
||||
|
|
|
@ -213,7 +213,7 @@ QtObject {
|
|||
property color hoverBackgroundColor
|
||||
}
|
||||
|
||||
property QtObject statusPopupMenu: QtObject {
|
||||
property QtObject statusMenu: QtObject {
|
||||
property color backgroundColor
|
||||
property color hoverBackgroundColor
|
||||
property color separatorColor
|
||||
|
|
|
@ -0,0 +1,42 @@
|
|||
import QtQuick 2.13
|
||||
import QtQuick.Controls 2.13
|
||||
|
||||
import StatusQ.Core 0.1
|
||||
import StatusQ.Core.Theme 0.1
|
||||
|
||||
Action {
|
||||
id: root
|
||||
|
||||
enum Type {
|
||||
Normal,
|
||||
Danger
|
||||
}
|
||||
|
||||
property int type: StatusAction.Type.Normal
|
||||
|
||||
property StatusAssetSettings assetSettings: StatusAssetSettings {
|
||||
width: 18
|
||||
height: 18
|
||||
rotation: 0
|
||||
isLetterIdenticon: false
|
||||
imgIsIdenticon: false
|
||||
color: root.icon.color
|
||||
name: root.icon.name
|
||||
}
|
||||
|
||||
property StatusFontSettings fontSettings: StatusFontSettings {}
|
||||
|
||||
property StatusIdenticonRingSettings ringSettings: StatusIdenticonRingSettings {
|
||||
initalAngleRad: 0
|
||||
ringPxSize: root.assetSettings.ringPxSize
|
||||
distinctiveColors: Theme.palette.identiconRingColors
|
||||
}
|
||||
|
||||
icon.color: {
|
||||
if (!root.enabled)
|
||||
return Theme.palette.baseColor1
|
||||
if (type === StatusAction.Type.Danger)
|
||||
return Theme.palette.dangerColor1
|
||||
return Theme.palette.primaryColor1
|
||||
}
|
||||
}
|
|
@ -0,0 +1,111 @@
|
|||
import QtQuick 2.13
|
||||
import QtQuick.Controls 2.13
|
||||
import QtGraphicalEffects 1.13
|
||||
|
||||
import StatusQ.Core 0.1
|
||||
import StatusQ.Core.Theme 0.1
|
||||
import StatusQ.Components 0.1
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
/*!
|
||||
To create menu elements from a model, use Instantiator:
|
||||
|
||||
\qml
|
||||
StatusMenu {
|
||||
id: myMenu
|
||||
|
||||
StatusMenuInstantiator {
|
||||
model: myModel
|
||||
menu: myMenu
|
||||
delegate: StatusAction {
|
||||
text: model.text
|
||||
assetSettings.name: model.iconName
|
||||
onTriggered: {
|
||||
popupMenu.dismiss()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
\endqml
|
||||
*/
|
||||
|
||||
Menu {
|
||||
id: root
|
||||
|
||||
readonly property color defaultIconColor: Theme.palette.primaryColor1
|
||||
|
||||
property StatusAssetSettings assetSettings: StatusAssetSettings {
|
||||
width: 18
|
||||
height: 18
|
||||
rotation: 0
|
||||
isLetterIdenticon: false
|
||||
isImage: false
|
||||
color: root.defaultIconColor
|
||||
}
|
||||
|
||||
property StatusFontSettings fontSettings: StatusFontSettings {}
|
||||
|
||||
property StatusIdenticonRingSettings ringSettings: StatusIdenticonRingSettings {
|
||||
ringPxSize: root.assetSettings.ringPxSize
|
||||
distinctiveColors: Theme.palette.identiconRingColors
|
||||
}
|
||||
|
||||
property bool hideDisabledItems: true
|
||||
|
||||
property var openHandler
|
||||
property var closeHandler
|
||||
|
||||
signal menuItemClicked(int menuIndex)
|
||||
|
||||
dim: false
|
||||
closePolicy: Popup.CloseOnPressOutside | Popup.CloseOnEscape
|
||||
topPadding: 8
|
||||
bottomPadding: 8
|
||||
bottomMargin: 16
|
||||
|
||||
onOpened: {
|
||||
if (typeof openHandler === "function") {
|
||||
openHandler()
|
||||
}
|
||||
}
|
||||
|
||||
onClosed: {
|
||||
if (typeof closeHandler === "function") {
|
||||
closeHandler()
|
||||
}
|
||||
}
|
||||
|
||||
delegate: StatusMenuItem {
|
||||
visible: root.hideDisabledItems ? enabled : true
|
||||
height: visible ? implicitHeight : 0
|
||||
}
|
||||
|
||||
contentItem: StatusListView {
|
||||
currentIndex: root.currentIndex
|
||||
implicitHeight: contentHeight
|
||||
implicitWidth: contentWidth
|
||||
interactive: contentHeight > availableHeight
|
||||
model: root.contentModel
|
||||
}
|
||||
|
||||
background: Rectangle {
|
||||
id: backgroundContent
|
||||
implicitWidth: 176
|
||||
color: Theme.palette.statusMenu.backgroundColor
|
||||
radius: 8
|
||||
layer.enabled: true
|
||||
layer.effect: DropShadow {
|
||||
width: backgroundContent.width
|
||||
height: backgroundContent.height
|
||||
x: backgroundContent.x
|
||||
visible: backgroundContent.visible
|
||||
source: backgroundContent
|
||||
horizontalOffset: 0
|
||||
verticalOffset: 4
|
||||
radius: 12
|
||||
samples: 25
|
||||
spread: 0.2
|
||||
color: Theme.palette.dropShadow
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,27 @@
|
|||
import QtQuick 2.14
|
||||
import QtQuick.Controls 2.14
|
||||
import QtQml.Models 2.14
|
||||
|
||||
Instantiator {
|
||||
id: root
|
||||
|
||||
property Menu menu
|
||||
|
||||
onObjectAdded: {
|
||||
if (object instanceof Menu)
|
||||
menu.addMenu(object)
|
||||
else if (object instanceof Action)
|
||||
menu.addAction(object)
|
||||
else
|
||||
menu.addItem(object)
|
||||
}
|
||||
|
||||
onObjectRemoved: {
|
||||
if (object instanceof Menu)
|
||||
menu.removeMenu(object)
|
||||
else if (object instanceof Action)
|
||||
menu.removeAction(object)
|
||||
else
|
||||
menu.removeItem(object)
|
||||
}
|
||||
}
|
|
@ -1,25 +1,171 @@
|
|||
import QtQuick 2.13
|
||||
import QtQuick.Controls 2.13
|
||||
|
||||
import StatusQ.Core 0.1
|
||||
import StatusQ.Core.Theme 0.1
|
||||
import StatusQ.Components 0.1
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
Action {
|
||||
id: statusMenuItem
|
||||
MenuItem {
|
||||
id: root
|
||||
|
||||
enum Type {
|
||||
Normal,
|
||||
Danger
|
||||
implicitWidth: parent ? parent.width : 0
|
||||
implicitHeight: 38
|
||||
objectName: action ? action.objectName : "StatusMenuItemDelegate"
|
||||
|
||||
spacing: 4
|
||||
horizontalPadding: 8
|
||||
|
||||
QtObject {
|
||||
id: d
|
||||
|
||||
readonly property bool isSubMenu: !!root.subMenu
|
||||
readonly property bool isStatusSubMenu: isSubMenu && (root.subMenu instanceof StatusMenu)
|
||||
readonly property bool subMenuOpened: isSubMenu && root.subMenu.opened
|
||||
readonly property bool hasAction: !!root.action
|
||||
readonly property bool isStatusAction: d.hasAction && (root.action instanceof StatusAction)
|
||||
readonly property bool isStatusDangerAction: d.isStatusAction && root.action.type === StatusAction.Type.Danger
|
||||
|
||||
readonly property StatusAssetSettings originalAssetSettings: d.isStatusSubMenu && root.subMenu.assetSettings
|
||||
? root.subMenu.assetSettings
|
||||
: d.isStatusAction && root.action.assetSettings
|
||||
? root.action.assetSettings
|
||||
: d.defaultAssetSettings
|
||||
|
||||
readonly property StatusAssetSettings assetSettings: StatusAssetSettings {
|
||||
|
||||
// overriden properties
|
||||
readonly property int letterSize: 11
|
||||
|
||||
//icon
|
||||
readonly property string name: d.originalAssetSettings.name
|
||||
readonly property url source: d.originalAssetSettings.source
|
||||
readonly property real width: d.originalAssetSettings.width
|
||||
readonly property real height: d.originalAssetSettings.height
|
||||
readonly property color color: d.originalAssetSettings.color
|
||||
readonly property color hoverColor: d.originalAssetSettings.hoverColor
|
||||
readonly property color disabledColor: d.originalAssetSettings.disabledColor
|
||||
readonly property int rotation: d.originalAssetSettings.rotation
|
||||
readonly property bool isLetterIdenticon: d.originalAssetSettings.isLetterIdenticon
|
||||
readonly property int charactersLen: d.originalAssetSettings.charactersLen
|
||||
readonly property string emoji: d.originalAssetSettings.emoji
|
||||
readonly property string emojiSize: d.originalAssetSettings.emojiSize
|
||||
|
||||
//icon b
|
||||
readonly property real bgWidth: d.originalAssetSettings.bgWidth
|
||||
readonly property real bgHeight: d.originalAssetSettings.bgHeight
|
||||
readonly property int bgRadius: d.originalAssetSettings.bgRadius
|
||||
readonly property color bgColor: d.originalAssetSettings.bgColor
|
||||
|
||||
//image
|
||||
readonly property bool isImage: d.originalAssetSettings.isImage
|
||||
readonly property int imgStatus: d.originalAssetSettings.imgStatus
|
||||
readonly property bool imgIsIdenticon: d.originalAssetSettings.imgIsIdenticon
|
||||
|
||||
// crop
|
||||
readonly property rect cropRect: d.originalAssetSettings.cropRect
|
||||
}
|
||||
|
||||
readonly property StatusFontSettings fontSettings: d.isStatusSubMenu
|
||||
? root.subMenu.fontSettings
|
||||
: d.isStatusAction
|
||||
? root.action.fontSettings
|
||||
: d.defaultFontSettings
|
||||
|
||||
readonly property StatusIdenticonRingSettings ringSettings: d.isStatusSubMenu
|
||||
? root.subMenu.ringSettings
|
||||
: d.isStatusAction
|
||||
? root.action.ringSettings
|
||||
: d.defaultRingSettings
|
||||
|
||||
|
||||
readonly property StatusAssetSettings defaultAssetSettings: StatusAssetSettings {
|
||||
width: 18
|
||||
height: 18
|
||||
rotation: 0
|
||||
// Link to standard Qt properties. Not because it's a good idea,
|
||||
// but because it we use it in some places and it will make refactor easier.
|
||||
name: d.isSubMenu ? "" : root.action.icon.name
|
||||
source: d.isSubMenu ? "" : root.action.icon.source
|
||||
color: d.isSubMenu ? "" : root.action.icon.color
|
||||
}
|
||||
|
||||
readonly property StatusFontSettings defaultFontSettings: StatusFontSettings {
|
||||
pixelSize: 13
|
||||
bold: false
|
||||
italic: false
|
||||
}
|
||||
|
||||
readonly property StatusIdenticonRingSettings defaultRingSettings: StatusIdenticonRingSettings {
|
||||
ringPxSize: d.assetSettings.ringPxSize
|
||||
distinctiveColors: Theme.palette.identiconRingColors
|
||||
}
|
||||
}
|
||||
icon.color: "transparent"
|
||||
property int type: StatusMenuItem.Type.Normal
|
||||
property real iconRotation: 0
|
||||
property StatusAssetSettings assetSettings: StatusAssetSettings {
|
||||
width: 16
|
||||
|
||||
indicator: Item {
|
||||
x: root.mirrored ? root.width - width - root.rightPadding : root.leftPadding
|
||||
y: root.topPadding + (root.availableHeight - height) / 2
|
||||
|
||||
implicitWidth: 24
|
||||
implicitHeight: 24
|
||||
visible: d.assetSettings.isLetterIdenticon
|
||||
|| d.assetSettings.isImage
|
||||
|| !!d.assetSettings.name
|
||||
|
||||
StatusSmartIdenticon {
|
||||
anchors.centerIn: parent
|
||||
active: parent.visible
|
||||
name: root.text
|
||||
asset: d.assetSettings
|
||||
ringSettings: d.ringSettings
|
||||
}
|
||||
}
|
||||
|
||||
contentItem: StatusBaseText {
|
||||
readonly property real arrowPadding: root.spacing + (root.subMenu && root.arrow ? root.arrow.width : 0)
|
||||
readonly property real indicatorPadding: root.spacing + (root.indicator.visible ? root.indicator.width : 0)
|
||||
|
||||
leftPadding: !root.mirrored ? indicatorPadding : arrowPadding
|
||||
rightPadding: root.mirrored ? indicatorPadding : arrowPadding
|
||||
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
|
||||
text: root.text
|
||||
color: !root.enabled ? Theme.palette.baseColor1
|
||||
: d.isStatusDangerAction ? Theme.palette.dangerColor1 : Theme.palette.directColor1
|
||||
|
||||
font.pixelSize: d.fontSettings.pixelSize
|
||||
font.bold: d.fontSettings.bold
|
||||
font.italic: d.fontSettings.italic
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
|
||||
arrow: StatusIcon {
|
||||
id: arrowIcon
|
||||
x: root.mirrored ? root.leftPadding : root.width - width - root.rightPadding
|
||||
y: root.topPadding + (root.availableHeight - height) / 2
|
||||
|
||||
height: 16
|
||||
color: "transparent"
|
||||
isLetterIdenticon: false
|
||||
imgIsIdenticon: false
|
||||
name: statusMenuItem.icon.name
|
||||
visible: d.isSubMenu
|
||||
icon: "next"
|
||||
color: Theme.palette.directColor1
|
||||
}
|
||||
|
||||
property StatusFontSettings fontSettings: StatusFontSettings {}
|
||||
background: Rectangle {
|
||||
color: {
|
||||
if (!root.hovered && !d.subMenuOpened)
|
||||
return "transparent"
|
||||
if (d.isStatusDangerAction)
|
||||
return Theme.palette.dangerColor3;
|
||||
return Theme.palette.statusMenu.hoverBackgroundColor;
|
||||
}
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
anchors.fill: parent
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
acceptedButtons: Qt.NoButton
|
||||
hoverEnabled: root.enabled
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,193 +0,0 @@
|
|||
import QtQuick 2.13
|
||||
import QtQuick.Controls 2.13
|
||||
|
||||
import StatusQ.Core 0.1
|
||||
import StatusQ.Core.Theme 0.1
|
||||
import StatusQ.Components 0.1
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
MenuItem {
|
||||
id: statusPopupMenuItem
|
||||
implicitWidth: parent ? parent.width : 0
|
||||
implicitHeight: action.enabled ? 34 : 0
|
||||
objectName: action.objectName
|
||||
|
||||
property int subMenuIndex
|
||||
property var statusPopupMenu: null
|
||||
|
||||
Component.onCompleted: {
|
||||
if (!!subMenu) {
|
||||
subMenuIndex = statusPopupMenu.menuItemCount
|
||||
statusPopupMenu.menuItemCount += 1
|
||||
}
|
||||
}
|
||||
|
||||
action: StatusMenuItem {
|
||||
onTriggered: { statusPopupMenu.menuItemClicked(statusPopupMenuItem.subMenuIndex); }
|
||||
}
|
||||
|
||||
Component {
|
||||
id: indicatorComponent
|
||||
Item {
|
||||
implicitWidth: 24
|
||||
implicitHeight: 24
|
||||
StatusIcon {
|
||||
anchors.centerIn: parent
|
||||
width: {
|
||||
let width = statusPopupMenuItem.action && statusPopupMenuItem.action.assetSettings.width
|
||||
return !!width ? width : 18
|
||||
}
|
||||
rotation: !!statusPopupMenuItem.action.iconRotation ? statusPopupMenuItem.action.iconRotation : 0
|
||||
icon: {
|
||||
if (statusPopupMenuItem.subMenu && !!statusPopupMenu.subMenuItemIcons[statusPopupMenuItem.subMenuIndex] &&
|
||||
statusPopupMenu.subMenuItemIcons[statusPopupMenuItem.subMenuIndex].icon.toString() !== "") {
|
||||
return statusPopupMenu.subMenuItemIcons[statusPopupMenuItem.subMenuIndex].icon;
|
||||
} else if (!!statusPopupMenuItem.action && statusPopupMenuItem.action.assetSettings.name !== "") {
|
||||
return statusPopupMenuItem.action.assetSettings.name;
|
||||
} else if (!!statusPopupMenuItem.action.assetSettings && statusPopupMenuItem.action.assetSettings.name !== "") {
|
||||
return statusPopupMenuItem.action.assetSettings.name;
|
||||
} else {
|
||||
return "";
|
||||
}
|
||||
}
|
||||
color: {
|
||||
let c = !!statusPopupMenuItem.action.assetSettings && statusPopupMenuItem.action.assetSettings.color
|
||||
|
||||
if (!Qt.colorEqual(c, "transparent")) {
|
||||
return c
|
||||
}
|
||||
switch (statusPopupMenuItem.action.type) {
|
||||
case StatusMenuItem.Type.Danger:
|
||||
return Theme.palette.dangerColor1
|
||||
default:
|
||||
return Theme.palette.primaryColor1
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Component {
|
||||
id: statusLetterIdenticonCmp
|
||||
Item {
|
||||
implicitWidth: 24
|
||||
implicitHeight: 24
|
||||
|
||||
StatusLetterIdenticon {
|
||||
anchors.centerIn: parent
|
||||
width: 16
|
||||
height: 16
|
||||
color: {
|
||||
let subMenuItemIcon = statusPopupMenu.subMenuItemIcons[statusPopupMenuItem.subMenuIndex]
|
||||
return subMenuItemIcon && subMenuItemIcon.color ? subMenuItemIcon.color : statusPopupMenuItem.action.assetSettings.bgColor
|
||||
}
|
||||
name: statusPopupMenuItem.text
|
||||
letterSize: 11
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Component {
|
||||
id: statusRoundImageCmp
|
||||
|
||||
Item {
|
||||
implicitWidth: 24
|
||||
implicitHeight: 24
|
||||
StatusRoundedImage {
|
||||
anchors.centerIn: parent
|
||||
width: statusPopupMenuItem.action.assetSettings.width
|
||||
height: statusPopupMenuItem.action.assetSettings.height
|
||||
image.source: statusPopupMenuItem.subMenu ?
|
||||
statusPopupMenu.subMenuItemIcons[statusPopupMenuItem.subMenuIndex].source :
|
||||
statusPopupMenuItem.action.assetSettings.name
|
||||
border.width: (statusPopupMenuItem.subMenu && statusPopupMenu.subMenuItemIcons[statusPopupMenuItem.subMenuIndex].isIdenticon) ||
|
||||
statusPopupMenuItem.action.assetSettings.imgIsIdenticon ? 1 : 0
|
||||
border.color: Theme.palette.directColor7
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
indicator: Loader {
|
||||
sourceComponent: {
|
||||
let subMenuItemIcon = statusPopupMenu.subMenuItemIcons && statusPopupMenu.subMenuItemIcons[parent.subMenuIndex]
|
||||
|
||||
if ((parent.subMenu && subMenuItemIcon && statusPopupMenu.subMenuItemIcons[parent.subMenuIndex].source) ||
|
||||
statusPopupMenuItem.action.assetSettings && !!statusPopupMenuItem.action.assetSettings.name.toString()
|
||||
&& statusPopupMenuItem.action.assetSettings.isImage) {
|
||||
return statusRoundImageCmp
|
||||
}
|
||||
|
||||
return (parent.subMenu && subMenuItemIcon && subMenuItemIcon.isLetterIdenticon) ||
|
||||
(statusPopupMenuItem.action.assetSettings && statusPopupMenuItem.action.assetSettings.isLetterIdenticon) ?
|
||||
statusLetterIdenticonCmp : indicatorComponent
|
||||
}
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: 8
|
||||
active: {
|
||||
if (enabled) {
|
||||
let hasIconSettings = !!statusPopupMenuItem.action.assetSettings.name ||
|
||||
(statusPopupMenuItem.action.assetSettings &&
|
||||
(!!statusPopupMenuItem.action.assetSettings.name || !!statusPopupMenuItem.action.assetSettings.isLetterIdenticon))
|
||||
|
||||
let hasImageSettings = statusPopupMenuItem.action.assetSettings && !!statusPopupMenuItem.action.assetSettings.name.toString()
|
||||
|
||||
return enabled && (parent.subMenu && !!statusPopupMenu.subMenuItemIcons[parent.subMenuIndex]) || hasIconSettings || hasImageSettings
|
||||
}
|
||||
return false
|
||||
}
|
||||
}
|
||||
|
||||
contentItem: StatusBaseText {
|
||||
anchors.left: statusPopupMenuItem.indicator.right
|
||||
anchors.right: arrowIcon.visible ? arrowIcon.left : arrowIcon.right
|
||||
anchors.rightMargin: 8
|
||||
anchors.leftMargin: 4
|
||||
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
|
||||
text: statusPopupMenuItem.text
|
||||
color: {
|
||||
switch (statusPopupMenuItem.action.type) {
|
||||
case StatusMenuItem.Type.Danger:
|
||||
return Theme.palette.dangerColor1
|
||||
default:
|
||||
return Theme.palette.directColor1
|
||||
}
|
||||
}
|
||||
font.pixelSize: !!statusPopupMenuItem.action.fontSettings ? statusPopupMenuItem.action.fontSettings.pixelSize : 13
|
||||
font.bold: !!statusPopupMenuItem.action.fontSettings ? statusPopupMenuItem.action.fontSettings.bold : false
|
||||
font.italic: !!statusPopupMenuItem.action.fontSettings ? statusPopupMenuItem.action.fontSettings.italic : false
|
||||
elide: Text.ElideRight
|
||||
visible: statusPopupMenuItem.action.enabled
|
||||
}
|
||||
|
||||
arrow: StatusIcon {
|
||||
id: arrowIcon
|
||||
anchors.verticalCenter: parent.verticalCenter
|
||||
anchors.right: parent.right
|
||||
anchors.rightMargin: 8
|
||||
height: 16
|
||||
visible: statusPopupMenuItem.subMenu
|
||||
icon: "next"
|
||||
color: Theme.palette.directColor1
|
||||
}
|
||||
|
||||
background: Rectangle {
|
||||
color: {
|
||||
if (statusPopupMenuItem.hovered) {
|
||||
return statusPopupMenuItem.action.type === StatusMenuItem.Type.Danger ? Theme.palette.dangerColor3 : Theme.palette.statusPopupMenu.hoverBackgroundColor
|
||||
}
|
||||
return "transparent"
|
||||
}
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
id: sensor
|
||||
anchors.fill: parent
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
hoverEnabled: statusPopupMenuItem.action.enabled
|
||||
onPressed: mouse.accepted = false
|
||||
}
|
||||
}
|
|
@ -8,6 +8,6 @@ MenuSeparator {
|
|||
contentItem: Rectangle {
|
||||
implicitWidth: 176
|
||||
implicitHeight: 1
|
||||
color: Theme.palette.statusPopupMenu.separatorColor
|
||||
color: Theme.palette.statusMenu.separatorColor
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,77 +0,0 @@
|
|||
import QtQuick 2.13
|
||||
import QtQuick.Controls 2.13
|
||||
import QtGraphicalEffects 1.13
|
||||
|
||||
import StatusQ.Core 0.1
|
||||
import StatusQ.Core.Theme 0.1
|
||||
import StatusQ.Components 0.1
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
|
||||
Menu {
|
||||
id: root
|
||||
closePolicy: Popup.CloseOnPressOutside | Popup.CloseOnEscape
|
||||
topPadding: 8
|
||||
bottomPadding: 8
|
||||
bottomMargin: 16
|
||||
|
||||
property int menuItemCount: 0
|
||||
property var subMenuItemIcons: []
|
||||
|
||||
property var openHandler
|
||||
property var closeHandler
|
||||
|
||||
dim: false
|
||||
|
||||
signal menuItemClicked(int menuIndex)
|
||||
|
||||
onOpened: {
|
||||
if (typeof openHandler === "function") {
|
||||
openHandler()
|
||||
}
|
||||
}
|
||||
|
||||
onClosed: {
|
||||
if (typeof closeHandler === "function") {
|
||||
closeHandler()
|
||||
}
|
||||
}
|
||||
|
||||
delegate: StatusMenuItemDelegate {
|
||||
statusPopupMenu: root
|
||||
}
|
||||
|
||||
contentItem: StatusListView {
|
||||
currentIndex: root.currentIndex
|
||||
implicitHeight: contentHeight
|
||||
interactive: contentHeight > availableHeight
|
||||
model: root.contentModel
|
||||
}
|
||||
|
||||
background: Item {
|
||||
id: statusPopupMenuBackground
|
||||
implicitWidth: 176
|
||||
|
||||
Rectangle {
|
||||
id: statusPopupMenuBackgroundContent
|
||||
implicitWidth: statusPopupMenuBackground.width
|
||||
implicitHeight: statusPopupMenuBackground.height
|
||||
color: Theme.palette.statusPopupMenu.backgroundColor
|
||||
radius: 8
|
||||
layer.enabled: true
|
||||
layer.effect: DropShadow {
|
||||
width: statusPopupMenuBackgroundContent.width
|
||||
height: statusPopupMenuBackgroundContent.height
|
||||
x: statusPopupMenuBackgroundContent.x
|
||||
visible: statusPopupMenuBackgroundContent.visible
|
||||
source: statusPopupMenuBackgroundContent
|
||||
horizontalOffset: 0
|
||||
verticalOffset: 4
|
||||
radius: 12
|
||||
samples: 25
|
||||
spread: 0.2
|
||||
color: Theme.palette.dropShadow
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -2,153 +2,163 @@ import QtQuick 2.14
|
|||
import QtQml 2.14
|
||||
import QtQuick.Controls 2.14
|
||||
|
||||
import Qt.labs.qmlmodels 1.0
|
||||
|
||||
import StatusQ.Core 0.1
|
||||
import StatusQ.Core.Theme 0.1
|
||||
import StatusQ.Popups 0.1
|
||||
import StatusQ.Controls 0.1
|
||||
import StatusQ.Core.Utils 0.1 as StatusQUtils
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: root
|
||||
dim: false
|
||||
|
||||
property var searchPopup
|
||||
property var locationModel
|
||||
readonly property int numDefaultItems: 2
|
||||
|
||||
signal itemClicked(string firstLevelItemValue, string secondLevelItemValue)
|
||||
|
||||
StatusMenuItem {
|
||||
signal resetSearchSelection()
|
||||
|
||||
signal setSearchSelection(string text,
|
||||
string secondaryText,
|
||||
string imageSource,
|
||||
string isIdenticon,
|
||||
string iconName,
|
||||
string iconColor,
|
||||
var isUserIcon,
|
||||
int colorId,
|
||||
string colorHash)
|
||||
|
||||
function processTriggeredMenuItem(title,
|
||||
parentImageSource,
|
||||
parentIsIdenticon,
|
||||
parentIconName,
|
||||
parentIdenticonColoe) {
|
||||
root.resetSearchSelection()
|
||||
let menuItem = root.menuAt(root.currentIndex)
|
||||
|
||||
root.setSearchSelection(menuItem.title,
|
||||
"",
|
||||
menuItem.parentImageSource,
|
||||
menuItem.parentIsIdenticon,
|
||||
menuItem.parentIconName,
|
||||
menuItem.parentIdenticonColor)
|
||||
|
||||
//TODO fix error "QML StatusMenu: cannot find any window to open popup in."
|
||||
root.dismiss()
|
||||
}
|
||||
|
||||
StatusAction {
|
||||
text: qsTr("Anywhere")
|
||||
onTriggered: {
|
||||
searchPopup.resetSearchSelection();
|
||||
root.resetSearchSelection();
|
||||
root.itemClicked("", "");
|
||||
}
|
||||
}
|
||||
|
||||
StatusMenuSeparator { }
|
||||
//Dummy item to keep seperator in right position
|
||||
MenuItem { implicitHeight: 0.00001 }
|
||||
Instantiator {
|
||||
|
||||
StatusMenuInstantiator {
|
||||
model: root.locationModel
|
||||
delegate: Loader {
|
||||
sourceComponent: (!!model.subItems && model.subItems.count > 0) ? subMenus : subMenuItemComponent
|
||||
onLoaded: {
|
||||
if (!!model.subItems && model.subItems.count > 0) {
|
||||
item.parentValue = model.value
|
||||
item.title = model.title;
|
||||
item.subItemsModel = model.subItems;
|
||||
item.parentIconName = model.iconName;
|
||||
item.parentImageSource = model.imageSource;
|
||||
item.parentIdenticonColor = !!model.iconColor ? model.iconColor : Theme.palette.primaryColor1;
|
||||
root.subMenuItemIcons.push({
|
||||
source: model.imageSource,
|
||||
icon: model.iconName,
|
||||
isIdenticon: model.isIdenticon,
|
||||
color: model.iconColor,
|
||||
isLetterIdenticon: !model.imageSource && !model.iconName
|
||||
});
|
||||
root.insertMenu(index + numDefaultItems, item);
|
||||
} else {
|
||||
item.value = model.value
|
||||
item.text = model.title;
|
||||
item.assetSettings.name = !!model.imageSource ? !!model.imageSource : model.iconName;
|
||||
item.assetSettings.color = model.iconColor;
|
||||
item.assetSettings.isImage = !!model.imageSource;
|
||||
item.assetSettings.isLetterIdenticon = !model.imageSource && !model.iconName
|
||||
item.assetSettings.imgIsIdenticon = model.isIdenticon;
|
||||
root.insertItem(index + numDefaultItems, item);
|
||||
menu: root
|
||||
|
||||
delegate: DelegateChooser {
|
||||
role: "hasSubItems"
|
||||
|
||||
DelegateChoice {
|
||||
roleValue: false
|
||||
delegate: StatusSearchPopupMenuItem {
|
||||
text: model.title
|
||||
assetSettings.name: !!model.imageSource ? !!model.imageSource : model.iconName
|
||||
assetSettings.isImage: !!model.imageSource
|
||||
assetSettings.isLetterIdenticon: !model.imageSource && !model.iconName
|
||||
assetSettings.imgIsIdenticon: model.isIdenticon
|
||||
onTriggered: {
|
||||
root.resetSearchSelection()
|
||||
root.setSearchSelection(text,
|
||||
"",
|
||||
"",
|
||||
assetSettings.isIdenticon,
|
||||
assetSettings.name,
|
||||
assetSettings.color)
|
||||
root.itemClicked(model.value, "")
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
onObjectRemoved: { root.removeItem(root.takeItem(index + numDefaultItems)); }
|
||||
}
|
||||
|
||||
Component {
|
||||
id: subMenuItemComponent
|
||||
StatusSearchPopupMenuItem {
|
||||
onTriggered: {
|
||||
searchPopup.resetSearchSelection()
|
||||
searchPopup.setSearchSelection(text,
|
||||
"",
|
||||
"",
|
||||
assetSettings.isIdenticon,
|
||||
assetSettings.name,
|
||||
assetSettings.color)
|
||||
root.itemClicked(value, "")
|
||||
}
|
||||
}
|
||||
}
|
||||
DelegateChoice {
|
||||
roleValue: true
|
||||
delegate: StatusMenu {
|
||||
id: subMenuDelegate
|
||||
|
||||
Component {
|
||||
id: subMenus
|
||||
StatusPopupMenu {
|
||||
id: menu
|
||||
dim: false
|
||||
property var subItemsModel
|
||||
property string parentValue
|
||||
property string parentIconName
|
||||
property string parentImageSource
|
||||
property string parentIdenticonColor
|
||||
property string parentIsIdenticon
|
||||
Repeater {
|
||||
id: menuLoader
|
||||
model: menu.subItemsModel
|
||||
property string parentValue: menu.parentValue
|
||||
property string parentTitleText: menu.title
|
||||
property string parentIconName: menu.parentIconName
|
||||
property string parentImageSource: menu.parentImageSource
|
||||
property string parentIdenticonColor: menu.parentIdenticonColor
|
||||
property string parentIsIdenticon: menu.parentIsIdenticon
|
||||
Loader {
|
||||
id: subMenuLoader
|
||||
sourceComponent: StatusSearchPopupMenuItem {
|
||||
value: model.value
|
||||
text: model.text
|
||||
assetSettings.isImage: !!model.imageSource
|
||||
assetSettings.name: !!StatusQUtils.Emoji.iconSource(model.imageSource) ?
|
||||
StatusQUtils.Emoji.iconSource(model.imageSource) : model.imageSource
|
||||
assetSettings.color: model.isUserIcon ? Theme.palette.userCustomizationColors[model.colorId] : model.iconColor
|
||||
assetSettings.bgColor: model.iconColor
|
||||
assetSettings.charactersLen: model.isUserIcon ? 2 : 1
|
||||
ringSettings.ringSpecModel: model.colorHash
|
||||
onTriggered: {
|
||||
searchPopup.resetSearchSelection()
|
||||
if (menuLoader.parentTitleText === "Chat") {
|
||||
searchPopup.setSearchSelection(model.text,
|
||||
"",
|
||||
model.imageSource,
|
||||
model.isIdenticon,
|
||||
model.iconName,
|
||||
model.iconColor,
|
||||
model.isUserIcon,
|
||||
model.colorId,
|
||||
model.colorHash.toJson())
|
||||
} else {
|
||||
searchPopup.setSearchSelection(menuLoader.parentTitleText,
|
||||
model.text,
|
||||
menuLoader.parentImageSource,
|
||||
menuLoader.parentIsIdenticon,
|
||||
menuLoader.parentIconName,
|
||||
menuLoader.parentIdenticonColor)
|
||||
readonly property var subItemsModel: model.subItems
|
||||
readonly property string parentValue: model.value
|
||||
readonly property string parentIconName: model.iconName
|
||||
readonly property string parentImageSource: model.imageSource
|
||||
readonly property string parentIdenticonColor: !!model.iconColor ? model.iconColor : defaultIconColor
|
||||
readonly property bool parentIsIdenticon: model.isIdenticon
|
||||
|
||||
title: model.title
|
||||
assetSettings.name: !!model.iconName ? model.iconName : model.imageSource
|
||||
assetSettings.color: !!model.iconColor ? model.iconColor : defaultIconColor
|
||||
assetSettings.isImage: !!model.imageSource
|
||||
assetSettings.imgIsIdenticon: model.isIdenticon
|
||||
assetSettings.isLetterIdenticon: !model.imageSource && !model.iconName
|
||||
|
||||
StatusMenuInstantiator {
|
||||
id: menuLoader
|
||||
|
||||
readonly property string parentValue: subMenuDelegate.parentValue
|
||||
readonly property string parentTitleText: subMenuDelegate.title
|
||||
readonly property string parentIconName: subMenuDelegate.parentIconName
|
||||
readonly property string parentImageSource: subMenuDelegate.parentImageSource
|
||||
readonly property string parentIdenticonColor: subMenuDelegate.parentIdenticonColor
|
||||
readonly property string parentIsIdenticon: subMenuDelegate.parentIsIdenticon
|
||||
|
||||
menu: subMenuDelegate
|
||||
model: subMenuDelegate.subItemsModel
|
||||
|
||||
delegate: StatusSearchPopupMenuItem {
|
||||
value: model.value
|
||||
text: model.text
|
||||
assetSettings.isImage: !!model.imageSource
|
||||
assetSettings.name: !!StatusQUtils.Emoji.iconSource(model.imageSource) ?
|
||||
StatusQUtils.Emoji.iconSource(model.imageSource) : model.imageSource
|
||||
assetSettings.color: model.isUserIcon ? Theme.palette.userCustomizationColors[model.colorId] : model.iconColor
|
||||
assetSettings.bgColor: model.iconColor
|
||||
assetSettings.charactersLen: model.isUserIcon ? 2 : 1
|
||||
ringSettings.ringSpecModel: model.colorHash
|
||||
onTriggered: {
|
||||
root.resetSearchSelection()
|
||||
if (menuLoader.parentTitleText === "Chat") {
|
||||
root.setSearchSelection(model.text,
|
||||
"",
|
||||
model.imageSource,
|
||||
model.isIdenticon,
|
||||
model.iconName,
|
||||
model.iconColor,
|
||||
model.isUserIcon,
|
||||
model.colorId,
|
||||
model.colorHash.toJson())
|
||||
} else {
|
||||
root.setSearchSelection(menuLoader.parentTitleText,
|
||||
model.text,
|
||||
menuLoader.parentImageSource,
|
||||
menuLoader.parentIsIdenticon,
|
||||
menuLoader.parentIconName,
|
||||
menuLoader.parentIdenticonColor,
|
||||
"",
|
||||
-1,
|
||||
"")
|
||||
}
|
||||
root.itemClicked(subMenuDelegate.parentValue, value)
|
||||
root.dismiss()
|
||||
}
|
||||
root.itemClicked(menuLoader.parentValue, value)
|
||||
root.dismiss()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
onMenuItemClicked: {
|
||||
searchPopup.resetSearchSelection()
|
||||
let menuItem = root.menuAt(root.currentIndex)
|
||||
searchPopup.setSearchSelection(menuItem.title,
|
||||
"",
|
||||
menuItem.parentImageSource,
|
||||
menuItem.parentIsIdenticon,
|
||||
menuItem.parentIconName,
|
||||
menuItem.parentIdenticonColor)
|
||||
root.itemClicked(menuItem.parentValue, "")
|
||||
//TODO fix error "QML StatusPopupMenu: cannot find any window to open popup in."
|
||||
root.dismiss()
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -4,61 +4,16 @@ import QtQuick.Layouts 1.12
|
|||
import StatusQ.Components 0.1
|
||||
import StatusQ.Core 0.1
|
||||
import StatusQ.Core.Theme 0.1
|
||||
import StatusQ.Controls 0.1
|
||||
|
||||
MenuItem {
|
||||
StatusAction {
|
||||
id: root
|
||||
implicitHeight: 38
|
||||
|
||||
property string value: ""
|
||||
|
||||
property StatusAssetSettings assetSettings: StatusAssetSettings {
|
||||
height: 16
|
||||
width: 16
|
||||
isImage: (name.toString() !== "")
|
||||
isLetterIdenticon: (name.toString() === "")
|
||||
color: (name === "channel") ? Theme.palette.directColor1 : "transparent"
|
||||
letterSize: charactersLen > 1 ? 8 : 11
|
||||
imgIsIdenticon: false
|
||||
}
|
||||
|
||||
property alias ringSettings: identicon.ringSettings
|
||||
|
||||
background: Rectangle {
|
||||
color: root.hovered ? Theme.palette.statusPopupMenu.hoverBackgroundColor : "transparent"
|
||||
}
|
||||
|
||||
contentItem: RowLayout {
|
||||
anchors.left: parent.left
|
||||
anchors.leftMargin: 12
|
||||
Item {
|
||||
Layout.preferredWidth: root.assetSettings.width
|
||||
Layout.preferredHeight: root.assetSettings.height
|
||||
Layout.alignment: Qt.AlignVCenter
|
||||
StatusSmartIdenticon {
|
||||
id: identicon
|
||||
anchors.centerIn: parent
|
||||
asset: root.assetSettings
|
||||
name: root.text
|
||||
ringSettings: root.ringSettings
|
||||
}
|
||||
}
|
||||
StatusBaseText {
|
||||
Layout.fillWidth: true
|
||||
Layout.alignment: Qt.AlignVCenter
|
||||
text: root.text
|
||||
color: Theme.palette.directColor1
|
||||
font.pixelSize: 13
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
Item {
|
||||
Layout.fillWidth: true
|
||||
}
|
||||
}
|
||||
MouseArea {
|
||||
id: sensor
|
||||
anchors.fill: parent
|
||||
hoverEnabled: true
|
||||
cursorShape: Qt.PointingHandCursor
|
||||
onPressed: mouse.accepted = false
|
||||
}
|
||||
assetSettings.isImage: assetSettings.name.toString() !== ""
|
||||
assetSettings.isLetterIdenticon: assetSettings.name.toString() === ""
|
||||
assetSettings.color: assetSettings.name === "channel" ? Theme.palette.directColor1 : icon.color
|
||||
assetSettings.letterSize: assetSettings.charactersLen > 1 ? 8 : 11
|
||||
assetSettings.imgIsIdenticon: false
|
||||
}
|
||||
|
|
|
@ -1,107 +0,0 @@
|
|||
import QtQuick 2.14
|
||||
import QtQuick.Controls 2.14
|
||||
|
||||
import StatusQ.Core 0.1
|
||||
import StatusQ.Core.Theme 0.1
|
||||
|
||||
|
||||
StatusPopupMenu {
|
||||
id: root
|
||||
|
||||
property alias suggestions: suggestionsMenu.model
|
||||
|
||||
signal addToUserDict()
|
||||
signal disableSpellchecking()
|
||||
|
||||
Column {
|
||||
|
||||
Repeater {
|
||||
id: suggestionsMenu
|
||||
|
||||
delegate: MenuItem {
|
||||
id: variants
|
||||
implicitWidth: parent ? parent.width : 0
|
||||
implicitHeight: 38
|
||||
contentItem: StatusBaseText {
|
||||
rightPadding: 8
|
||||
leftPadding: 4
|
||||
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
|
||||
text: modelData
|
||||
color: Theme.palette.directColor1
|
||||
font.pixelSize: 13
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
|
||||
background: Rectangle {
|
||||
color: variants.hovered ? Theme.palette.statusPopupMenu.hoverBackgroundColor
|
||||
: "transparent"
|
||||
}
|
||||
|
||||
onTriggered: {
|
||||
root.menuItemClicked(index)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
StatusMenuSeparator { visible: !!suggestionsMenu.model && suggestionsMenu.model.length !== 0}
|
||||
|
||||
MenuItem {
|
||||
id: ignoreWord
|
||||
implicitWidth: parent ? parent.width : 0
|
||||
implicitHeight: 38
|
||||
contentItem: StatusBaseText {
|
||||
rightPadding: 8
|
||||
leftPadding: 4
|
||||
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
|
||||
text: qsTr("Add to dictionary")
|
||||
color: Theme.palette.directColor1
|
||||
font.pixelSize: 13
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
|
||||
background: Rectangle {
|
||||
color: ignoreWord.hovered ? Theme.palette.statusPopupMenu.hoverBackgroundColor
|
||||
: "transparent"
|
||||
}
|
||||
|
||||
onTriggered: {
|
||||
root.addToUserDict()
|
||||
}
|
||||
}
|
||||
|
||||
MenuItem {
|
||||
id: disableSpellchecking
|
||||
implicitWidth: parent ? parent.width : 0
|
||||
implicitHeight: 38
|
||||
contentItem: StatusBaseText {
|
||||
rightPadding: 8
|
||||
leftPadding: 4
|
||||
|
||||
horizontalAlignment: Text.AlignLeft
|
||||
verticalAlignment: Text.AlignVCenter
|
||||
|
||||
text: qsTr("Disable Spellchecking")
|
||||
color: Theme.palette.directColor1
|
||||
font.pixelSize: 13
|
||||
elide: Text.ElideRight
|
||||
}
|
||||
|
||||
|
||||
background: Rectangle {
|
||||
color: disableSpellchecking.hovered ? Theme.palette.statusPopupMenu.hoverBackgroundColor
|
||||
: "transparent"
|
||||
}
|
||||
|
||||
onTriggered: {
|
||||
root.disableSpellchecking()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -1,9 +1,10 @@
|
|||
module StatusQ.Popups
|
||||
|
||||
StatusMenuSeparator 0.1 StatusMenuSeparator.qml
|
||||
StatusPopupMenu 0.1 StatusPopupMenu.qml
|
||||
StatusAction 0.1 StatusAction.qml
|
||||
StatusMenu 0.1 StatusMenu.qml
|
||||
StatusMenuItem 0.1 StatusMenuItem.qml
|
||||
StatusMenuItemDelegate 0.1 StatusMenuItemDelegate.qml
|
||||
StatusMenuInstantiator 0.1 StatusMenuInstantiator.qml
|
||||
StatusMenuHeadline 0.1 StatusMenuHeadline.qml
|
||||
StatusModal 0.1 StatusModal.qml
|
||||
StatusStackModal 0.1 StatusStackModal.qml
|
||||
|
@ -12,5 +13,4 @@ StatusSearchPopup 0.1 StatusSearchPopup.qml
|
|||
StatusModalDivider 0.1 StatusModalDivider.qml
|
||||
StatusSearchPopupMenuItem 0.1 StatusSearchPopupMenuItem.qml
|
||||
StatusSearchLocationMenu 0.1 StatusSearchLocationMenu.qml
|
||||
StatusSpellcheckingMenuItems 0.1 StatusSpellcheckingMenuItems.qml
|
||||
StatusColorDialog 0.1 StatusColorDialog.qml
|
||||
|
|
|
@ -51,6 +51,9 @@
|
|||
<file>assets/fonts/RobotoMono/RobotoMono-SemiBoldItalic.ttf</file>
|
||||
<file>assets/fonts/RobotoMono/RobotoMono-Thin.ttf</file>
|
||||
<file>assets/fonts/RobotoMono/RobotoMono-ThinItalic.ttf</file>
|
||||
<file>assets/img/icons/statuses/automatic.svg</file>
|
||||
<file>assets/img/icons/statuses/inactive.svg</file>
|
||||
<file>assets/img/icons/statuses/online.svg</file>
|
||||
<file>assets/img/icons/bigger/browser.svg</file>
|
||||
<file>assets/img/icons/bigger/network.svg</file>
|
||||
<file>assets/img/icons/bigger/pause.svg</file>
|
||||
|
|
Before Width: | Height: | Size: 270 B After Width: | Height: | Size: 270 B |
Before Width: | Height: | Size: 186 B After Width: | Height: | Size: 186 B |
Before Width: | Height: | Size: 186 B After Width: | Height: | Size: 186 B |
|
@ -158,16 +158,15 @@
|
|||
<file>StatusQ/Popups/qmldir</file>
|
||||
<file>StatusQ/Popups/StatusColorDialog.qml</file>
|
||||
<file>StatusQ/Popups/StatusMenuHeadline.qml</file>
|
||||
<file>StatusQ/Popups/StatusAction.qml</file>
|
||||
<file>StatusQ/Popups/StatusMenuItem.qml</file>
|
||||
<file>StatusQ/Popups/StatusMenuItemDelegate.qml</file>
|
||||
<file>StatusQ/Popups/StatusMenuSeparator.qml</file>
|
||||
<file>StatusQ/Popups/StatusModal.qml</file>
|
||||
<file>StatusQ/Popups/StatusModalDivider.qml</file>
|
||||
<file>StatusQ/Popups/StatusPopupMenu.qml</file>
|
||||
<file>StatusQ/Popups/StatusMenu.qml</file>
|
||||
<file>StatusQ/Popups/StatusSearchLocationMenu.qml</file>
|
||||
<file>StatusQ/Popups/StatusSearchPopup.qml</file>
|
||||
<file>StatusQ/Popups/StatusSearchPopupMenuItem.qml</file>
|
||||
<file>StatusQ/Popups/StatusSpellcheckingMenuItems.qml</file>
|
||||
<file>StatusQ/Popups/StatusStackModal.qml</file>
|
||||
<file>StatusQ/qmldir</file>
|
||||
<file>StatusQ/Components/StatusListPickerProxies.qml</file>
|
||||
|
@ -193,5 +192,6 @@
|
|||
<file>StatusQ/Core/StatusProfileImageSettings.qml</file>
|
||||
<file>StatusQ/Core/StatusRollArea.qml</file>
|
||||
<file>StatusQ/Popups/Dialog/StatusDialogBackground.qml</file>
|
||||
<file>StatusQ/Popups/StatusMenuInstantiator.qml</file>
|
||||
</qresource>
|
||||
</RCC>
|
||||
|
|
|
@ -9,7 +9,7 @@ import shared.popups 1.0
|
|||
|
||||
import utils 1.0
|
||||
|
||||
// TODO: replace with StatusPopupMenu
|
||||
// TODO: replace with StatusMenu
|
||||
PopupMenu {
|
||||
id: browserSettingsMenu
|
||||
|
||||
|
|
|
@ -12,7 +12,7 @@ import utils 1.0
|
|||
|
||||
import "../stores"
|
||||
|
||||
// TODO: replace with StatusPopupMenu
|
||||
// TODO: replace with StatusMenu
|
||||
Popup {
|
||||
id: popup
|
||||
|
||||
|
|
|
@ -8,7 +8,7 @@ import utils 1.0
|
|||
|
||||
import "../stores"
|
||||
|
||||
// TODO: replace with StatusPopupMenu
|
||||
// TODO: replace with StatusMenu
|
||||
PopupMenu {
|
||||
id: downloadMenu
|
||||
|
||||
|
|
|
@ -8,7 +8,7 @@ import utils 1.0
|
|||
|
||||
import "../stores"
|
||||
|
||||
// TODO: replace with StatusPopupMenu
|
||||
// TODO: replace with StatusMenu
|
||||
PopupMenu {
|
||||
id: favoritePopupMenu
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ StatusListView {
|
|||
header: Rectangle {
|
||||
visible: root.isHeaderVisible
|
||||
z: 3 // Above delegate (z=1) and above section.delegate (z = 2)
|
||||
color: Theme.palette.statusPopupMenu.backgroundColor
|
||||
color: Theme.palette.statusMenu.backgroundColor
|
||||
width: root.width
|
||||
height: root.isHeaderVisible ? columnHeader.implicitHeight + 2 * columnHeader.anchors.topMargin : 0
|
||||
ColumnLayout {
|
||||
|
|
|
@ -109,7 +109,7 @@ StackLayout {
|
|||
|
||||
implicitHeight: 1
|
||||
visible: root.editable
|
||||
color: Theme.palette.statusPopupMenu.separatorColor
|
||||
color: Theme.palette.statusMenu.separatorColor
|
||||
}
|
||||
|
||||
RowLayout {
|
||||
|
|
|
@ -35,10 +35,10 @@ StatusModal {
|
|||
|
||||
onClicked: contextMenu.popup(-contextMenu.width+width, height + 4)
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: contextMenu
|
||||
width: 230
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
icon.name: "download"
|
||||
text: qsTr("Access existing community")
|
||||
onTriggered: {
|
||||
|
|
|
@ -11,7 +11,7 @@ import shared.controls.chat.menuItems 1.0
|
|||
import "../popups"
|
||||
import "../popups/community"
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: root
|
||||
|
||||
property string currentFleet: ""
|
||||
|
@ -53,7 +53,7 @@ StatusPopupMenu {
|
|||
onTriggered: root.displayProfilePopup(root.chatId)
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: root.amIChatAdmin ? qsTr("Add / remove from group") : qsTr("Add to group")
|
||||
icon.name: "add-to-dm"
|
||||
enabled: (root.chatType === Constants.chatType.privateGroupChat)
|
||||
|
@ -64,7 +64,7 @@ StatusPopupMenu {
|
|||
visible: root.chatType === Constants.chatType.oneToOne || root.chatType === Constants.chatType.privateGroupChat
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
objectName: "editNameAndImageMenuItem"
|
||||
text: qsTr("Edit name and image")
|
||||
icon.name: "edit_pencil"
|
||||
|
@ -98,7 +98,7 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
objectName: "chatMarkAsReadMenuItem"
|
||||
text: qsTr("Mark as Read")
|
||||
icon.name: "checkmark-circle"
|
||||
|
@ -108,32 +108,32 @@ StatusPopupMenu {
|
|||
}
|
||||
|
||||
//TODO uncomment when implemented
|
||||
// StatusPopupMenu {
|
||||
// StatusMenu {
|
||||
// title: qsTr("Fetch messages")
|
||||
// enabled: (root.chatType === Constants.chatType.oneToOne ||
|
||||
// root.chatType === Constants.chatType.privateGroupChat)
|
||||
// StatusMenuItem {
|
||||
// StatusAction {
|
||||
// text: "Last 24 hours"
|
||||
// onTriggered: {
|
||||
// root.fetchMoreMessages();
|
||||
// }
|
||||
// }
|
||||
|
||||
// StatusMenuItem {
|
||||
// StatusAction {
|
||||
// text: "Last 2 days"
|
||||
// onTriggered: {
|
||||
|
||||
// }
|
||||
// }
|
||||
|
||||
// StatusMenuItem {
|
||||
// StatusAction {
|
||||
// text: "Last 3 days"
|
||||
// onTriggered: {
|
||||
|
||||
// }
|
||||
// }
|
||||
|
||||
// StatusMenuItem {
|
||||
// StatusAction {
|
||||
// text: "Last 7 days"
|
||||
// onTriggered: {
|
||||
|
||||
|
@ -141,7 +141,7 @@ StatusPopupMenu {
|
|||
// }
|
||||
// }
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
objectName: "clearHistoryMenuItem"
|
||||
text: qsTr("Clear History")
|
||||
icon.name: "close-circle"
|
||||
|
@ -150,7 +150,7 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
objectName: "editChannelMenuItem"
|
||||
text: qsTr("Edit Channel")
|
||||
icon.name: "edit"
|
||||
|
@ -188,7 +188,7 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Download")
|
||||
enabled: localAccountSensitiveSettings.downloadChannelMessagesEnabled
|
||||
icon.name: "download"
|
||||
|
@ -199,7 +199,7 @@ StatusPopupMenu {
|
|||
visible: deleteOrLeaveMenuItem.enabled
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
objectName: "deleteOrLeaveMenuItem"
|
||||
id: deleteOrLeaveMenuItem
|
||||
text: {
|
||||
|
@ -216,7 +216,7 @@ StatusPopupMenu {
|
|||
icon.name: root.chatType === Constants.chatType.oneToOne || root.isCommunityChat ? "delete" : "arrow-left"
|
||||
icon.width: root.chatType === Constants.chatType.oneToOne || root.isCommunityChat ? 18 : 14
|
||||
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
onTriggered: {
|
||||
if (root.chatType === Constants.chatType.privateGroupChat) {
|
||||
root.leaveChat(root.chatId);
|
||||
|
|
|
@ -167,7 +167,7 @@ Item {
|
|||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: adminPopupMenu
|
||||
enabled: communityData.amISectionAdmin
|
||||
|
||||
|
@ -175,14 +175,14 @@ Item {
|
|||
|
||||
onClosed: adminPopupMenu.showInviteButton = false
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
objectName: "createCommunityChannelBtn"
|
||||
text: qsTr("Create channel")
|
||||
icon.name: "channel"
|
||||
onTriggered: Global.openPopup(createChannelPopup)
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
objectName: "createCommunityCategoryBtn"
|
||||
text: qsTr("Create category")
|
||||
icon.name: "channel-category"
|
||||
|
@ -193,7 +193,7 @@ Item {
|
|||
visible: invitePeopleBtn.enabled
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: invitePeopleBtn
|
||||
text: qsTr("Invite people")
|
||||
icon.name: "share-ios"
|
||||
|
@ -253,15 +253,15 @@ Item {
|
|||
categoryId: id
|
||||
})
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
StatusMenuItem {
|
||||
popupMenu: StatusMenu {
|
||||
StatusAction {
|
||||
text: qsTr("Create channel")
|
||||
icon.name: "channel"
|
||||
enabled: communityData.amISectionAdmin
|
||||
onTriggered: Global.openPopup(createChannelPopup)
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Create category")
|
||||
icon.name: "channel-category"
|
||||
enabled: communityData.amISectionAdmin
|
||||
|
@ -270,7 +270,7 @@ Item {
|
|||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Invite people")
|
||||
icon.name: "share-ios"
|
||||
enabled: communityData.canManageUsers
|
||||
|
@ -282,7 +282,7 @@ Item {
|
|||
}
|
||||
}
|
||||
|
||||
categoryPopupMenu: StatusPopupMenu {
|
||||
categoryPopupMenu: StatusMenu {
|
||||
|
||||
property var categoryItem
|
||||
|
||||
|
@ -297,7 +297,7 @@ Item {
|
|||
categoryItem = obj
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: categoryItem.muted ? qsTr("Unmute category") : qsTr("Mute category")
|
||||
icon.name: "notification"
|
||||
onTriggered: {
|
||||
|
@ -309,7 +309,7 @@ Item {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
objectName: "editCategoryMenuItem"
|
||||
enabled: communityData.amISectionAdmin
|
||||
text: qsTr("Edit Category")
|
||||
|
@ -328,12 +328,12 @@ Item {
|
|||
visible: communityData.amISectionAdmin
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
objectName: "deleteCategoryMenuItem"
|
||||
enabled: communityData.amISectionAdmin
|
||||
text: qsTr("Delete Category")
|
||||
icon.name: "delete"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
onTriggered: {
|
||||
Global.openPopup(deleteCategoryConfirmationDialogComponent, {
|
||||
title: qsTr("Delete %1 category").arg(categoryItem.name),
|
||||
|
|
|
@ -27,9 +27,11 @@ Item {
|
|||
|
||||
width: parent.width
|
||||
height: 64
|
||||
|
||||
Rectangle {
|
||||
anchors.fill: root
|
||||
color: sensor.containsMouse ? Theme.palette.statusSelect.menuItemHoverBackgroundColor : Theme.palette.statusSelect.menuItemBackgroundColor
|
||||
color: sensor.containsMouse ? Theme.palette.statusSelect.menuItemHoverBackgroundColor
|
||||
: Theme.palette.statusSelect.menuItemBackgroundColor
|
||||
}
|
||||
|
||||
MouseArea {
|
||||
|
|
|
@ -269,11 +269,9 @@ Item {
|
|||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: accountsPopup
|
||||
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutsideParent
|
||||
width: parent.width + Style.current.bigPadding
|
||||
dim: false
|
||||
|
||||
SortFilterProxyModel {
|
||||
id: proxyModel
|
||||
|
@ -285,46 +283,40 @@ Item {
|
|||
}
|
||||
}
|
||||
|
||||
Column {
|
||||
width: parent.width
|
||||
Repeater {
|
||||
objectName: "LoginView_AccountsRepeater"
|
||||
model: proxyModel
|
||||
|
||||
Repeater {
|
||||
objectName: "LoginView_AccountsRepeater"
|
||||
width: parent.width
|
||||
height: parent.height
|
||||
model: proxyModel
|
||||
|
||||
delegate: AccountMenuItemPanel {
|
||||
label: model.username
|
||||
image: model.thumbnailImage
|
||||
colorId: model.colorId
|
||||
colorHash: model.colorHash
|
||||
keycardCreatedAccount: model.keycardCreatedAccount
|
||||
onClicked: {
|
||||
d.resetLogin()
|
||||
accountsPopup.close()
|
||||
const realIndex = proxyModel.mapToSource(index)
|
||||
root.startupStore.setSelectedLoginAccountByIndex(realIndex)
|
||||
}
|
||||
delegate: AccountMenuItemPanel {
|
||||
label: model.username
|
||||
image: model.thumbnailImage
|
||||
colorId: model.colorId
|
||||
colorHash: model.colorHash
|
||||
keycardCreatedAccount: model.keycardCreatedAccount
|
||||
onClicked: {
|
||||
d.resetLogin()
|
||||
accountsPopup.close()
|
||||
const realIndex = proxyModel.mapToSource(index)
|
||||
root.startupStore.setSelectedLoginAccountByIndex(realIndex)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
AccountMenuItemPanel {
|
||||
label: qsTr("Add new user")
|
||||
asset.name: "add"
|
||||
onClicked: {
|
||||
accountsPopup.close()
|
||||
root.startupStore.doTertiaryAction()
|
||||
}
|
||||
AccountMenuItemPanel {
|
||||
label: qsTr("Add new user")
|
||||
asset.name: "add"
|
||||
onClicked: {
|
||||
accountsPopup.close()
|
||||
root.startupStore.doTertiaryAction()
|
||||
}
|
||||
}
|
||||
|
||||
AccountMenuItemPanel {
|
||||
label: qsTr("Add existing Status user")
|
||||
asset.name: "wallet"
|
||||
onClicked: {
|
||||
accountsPopup.close()
|
||||
root.startupStore.doQuaternaryAction()
|
||||
}
|
||||
AccountMenuItemPanel {
|
||||
label: qsTr("Add existing Status user")
|
||||
asset.name: "wallet"
|
||||
onClicked: {
|
||||
accountsPopup.close()
|
||||
root.startupStore.doQuaternaryAction()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -41,27 +41,27 @@ Item {
|
|||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: selectMenu
|
||||
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutsideParent
|
||||
width: parent.width
|
||||
clip: true
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: d.sendAlertsText
|
||||
onTriggered: {
|
||||
root.sendAlertsClicked()
|
||||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: d.deliverQuietlyText
|
||||
onTriggered: {
|
||||
root.deliverQuietlyClicked()
|
||||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: d.turnOffText
|
||||
onTriggered: {
|
||||
root.turnOffClicked()
|
||||
|
|
|
@ -49,7 +49,7 @@ Item {
|
|||
toggleVisibleClicked(chainId, address)
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: contextMenu
|
||||
Action {
|
||||
icon.name: "admin"
|
||||
|
|
|
@ -151,7 +151,7 @@ Item {
|
|||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: derivedAddressPopup
|
||||
width: _internal.popupWidth
|
||||
contentItem: Column {
|
||||
|
@ -234,7 +234,7 @@ Item {
|
|||
background: Rectangle {
|
||||
implicitWidth: stackLayout.width
|
||||
implicitHeight: stackLayout.height
|
||||
color: Theme.palette.statusPopupMenu.backgroundColor
|
||||
color: Theme.palette.statusMenu.backgroundColor
|
||||
radius: 8
|
||||
}
|
||||
}
|
||||
|
|
|
@ -95,7 +95,7 @@ StatusSelect {
|
|||
titleText.color: Theme.palette.indirectColor1
|
||||
}
|
||||
}
|
||||
selectMenu.delegate: StatusListItem {
|
||||
menuDelegate: StatusListItem {
|
||||
id: defaultListItem
|
||||
title: model.name
|
||||
asset.name: model.iconName
|
||||
|
|
|
@ -366,7 +366,7 @@ Item {
|
|||
changeAppSectionBySectionId(model.id)
|
||||
}
|
||||
|
||||
popupMenu: StatusPopupMenu {
|
||||
popupMenu: StatusMenu {
|
||||
id: communityContextMenu
|
||||
|
||||
property var chatCommunitySectionModule
|
||||
|
@ -379,7 +379,7 @@ Item {
|
|||
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Invite People")
|
||||
icon.name: "share-ios"
|
||||
enabled: model.canManageUsers
|
||||
|
@ -390,7 +390,7 @@ Item {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("View Community")
|
||||
icon.name: "group-chat"
|
||||
onTriggered: Global.openPopup(communityProfilePopup, {
|
||||
|
@ -402,10 +402,10 @@ Item {
|
|||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Leave Community")
|
||||
icon.name: "arrow-left"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
onTriggered: communityContextMenu.chatCommunitySectionModule.leaveCommunity()
|
||||
}
|
||||
}
|
||||
|
|
|
@ -41,7 +41,7 @@ Item {
|
|||
|
||||
StatusSearchLocationMenu {
|
||||
id: searchPopupMenu
|
||||
searchPopup: searchPopup
|
||||
|
||||
locationModel: appSearch.store.locationMenuModel
|
||||
|
||||
onItemClicked: {
|
||||
|
@ -50,6 +50,22 @@ Item {
|
|||
if(searchPopup.searchText !== "")
|
||||
searchMessages(searchPopup.searchText)
|
||||
}
|
||||
|
||||
onResetSearchSelection: {
|
||||
searchPopup.resetSearchSelection()
|
||||
}
|
||||
|
||||
onSetSearchSelection: {
|
||||
searchPopup.setSearchSelection(text,
|
||||
secondaryText,
|
||||
imageSource,
|
||||
isIdenticon,
|
||||
iconName,
|
||||
iconColor,
|
||||
isUserIcon,
|
||||
colorId,
|
||||
colorHash)
|
||||
}
|
||||
}
|
||||
|
||||
StatusSearchPopup {
|
||||
|
|
|
@ -88,7 +88,7 @@ StatusListItem {
|
|||
}
|
||||
]
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: editDeleteMenu
|
||||
property string contactName
|
||||
property string contactAddress
|
||||
|
@ -104,7 +104,7 @@ StatusListItem {
|
|||
contactAddress = "";
|
||||
storeFavourite = false;
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Edit")
|
||||
objectName: "editroot"
|
||||
assetSettings.name: "pencil-outline"
|
||||
|
@ -119,9 +119,9 @@ StatusListItem {
|
|||
}
|
||||
}
|
||||
StatusMenuSeparator { }
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Delete")
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
assetSettings.name: "delete"
|
||||
objectName: "deleteSavedAddress"
|
||||
onTriggered: {
|
||||
|
|
|
@ -247,20 +247,20 @@ Item {
|
|||
}
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: imageEditMenu
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Upload a file")
|
||||
icon.name: "download"
|
||||
iconRotation: 180
|
||||
assetSettings.name: "download"
|
||||
assetSettings.rotation: 180
|
||||
onTriggered: Global.openChangeProfilePicPopup(editButton.tempIcon)
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Remove image")
|
||||
type: StatusMenuItem.Danger
|
||||
icon.name: "delete"
|
||||
type: StatusAction.Danger
|
||||
assetSettings.name: "delete"
|
||||
onTriggered: root.icon = ""
|
||||
}
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@ import QtQuick 2.14
|
|||
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
property bool muted: false
|
||||
|
||||
text: muted ? qsTr("Unmute Chat") : qsTr("Mute Chat")
|
||||
|
|
|
@ -2,7 +2,7 @@ import QtQuick 2.14
|
|||
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Send Contact Request")
|
||||
icon.name: "add-contact"
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@ import QtQuick 2.14
|
|||
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Send Message")
|
||||
icon.name: "chat"
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@ import QtQuick 2.14
|
|||
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("View Profile")
|
||||
icon.name: "profile"
|
||||
}
|
||||
|
|
|
@ -54,7 +54,7 @@ Row {
|
|||
contactContextMenu.popup(-contactContextMenu.width+menuButton.width, menuButton.height + 4)
|
||||
}
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: contactContextMenu
|
||||
|
||||
onClosed: {
|
||||
|
@ -67,10 +67,10 @@ Row {
|
|||
|
||||
StatusMenuSeparator {}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Decline and block")
|
||||
icon.name: "cancel"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
onTriggered: root.blockClicked()
|
||||
}
|
||||
}
|
||||
|
|
|
@ -97,7 +97,7 @@ StatusFloatingButtonsSelector {
|
|||
asset.bgColor: Theme.palette.indirectColor1
|
||||
onClicked: {
|
||||
changeSelectedAccount(model, index)
|
||||
root.itemSelected(index)
|
||||
root.selectItem(index)
|
||||
}
|
||||
visible: !root.visibleIndices.includes(index) && d.isWalletTypeAccepted(walletType, index)
|
||||
}
|
||||
|
|
|
@ -10,7 +10,7 @@ import shared.panels 1.0
|
|||
import StatusQ.Components 0.1
|
||||
import StatusQ.Popups 0.1
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: root
|
||||
|
||||
property var store
|
||||
|
@ -29,7 +29,7 @@ StatusPopupMenu {
|
|||
StatusMenuSeparator {
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
objectName: "userStatusViewMyProfileAction"
|
||||
text: qsTr("View My Profile")
|
||||
icon.name: "profile"
|
||||
|
@ -42,14 +42,14 @@ StatusPopupMenu {
|
|||
StatusMenuSeparator {
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: alwaysOnlineAction
|
||||
objectName: "userStatusMenuAlwaysOnlineAction"
|
||||
text: qsTr("Always online")
|
||||
icon.name: Style.svg("statuses/online")
|
||||
assetSettings.isImage: true
|
||||
icon.width: 12
|
||||
icon.height: 12
|
||||
assetSettings.name: "statuses/online"
|
||||
assetSettings.width: 12
|
||||
assetSettings.height: 12
|
||||
assetSettings.color: "transparent"
|
||||
fontSettings.bold: root.store.userProfileInst.currentUserStatus === Constants.currentUserStatus.alwaysOnline
|
||||
onTriggered: {
|
||||
store.setCurrentUserStatus(Constants.currentUserStatus.alwaysOnline)
|
||||
|
@ -57,14 +57,14 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: inactiveAction
|
||||
objectName: "userStatusMenuInactiveAction"
|
||||
text: qsTr("Inactive")
|
||||
icon.name: Style.svg("statuses/inactive")
|
||||
assetSettings.isImage: true
|
||||
icon.width: 12
|
||||
icon.height: 12
|
||||
assetSettings.name: "statuses/inactive"
|
||||
assetSettings.width: 12
|
||||
assetSettings.height: 12
|
||||
assetSettings.color: "transparent"
|
||||
fontSettings.bold: root.store.userProfileInst.currentUserStatus === Constants.currentUserStatus.inactive
|
||||
onTriggered: {
|
||||
store.setCurrentUserStatus(Constants.currentUserStatus.inactive)
|
||||
|
@ -72,12 +72,12 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: automaticAction
|
||||
objectName: "userStatusMenuAutomaticAction"
|
||||
text: qsTr("Set status automatically")
|
||||
icon.name: Style.svg("statuses/automatic")
|
||||
assetSettings.isImage: true
|
||||
assetSettings.name: "statuses/automatic"
|
||||
assetSettings.color: "transparent"
|
||||
fontSettings.bold: root.store.userProfileInst.currentUserStatus === Constants.currentUserStatus.automatic
|
||||
onTriggered: {
|
||||
store.setCurrentUserStatus(Constants.currentUserStatus.automatic)
|
||||
|
|
|
@ -385,7 +385,7 @@ Pane {
|
|||
highlighted: moreMenu.opened
|
||||
onClicked: moreMenu.popup(-moreMenu.width + width, height + 4)
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: moreMenu
|
||||
width: 230
|
||||
|
||||
|
@ -398,7 +398,7 @@ Pane {
|
|||
popup => popup.closed.connect(d.reload))
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Verify Identity")
|
||||
icon.name: "checkmark-circle"
|
||||
enabled: d.isContact && !d.isBlocked &&
|
||||
|
@ -410,7 +410,7 @@ Pane {
|
|||
popup => popup.accepted.connect(d.reload))
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("ID Request Pending...")
|
||||
icon.name: "checkmark-circle"
|
||||
enabled: d.isContact && !d.isBlocked && !d.isTrusted && d.isVerificationRequestSent
|
||||
|
@ -420,7 +420,7 @@ Pane {
|
|||
popup => popup.closed.connect(d.reload))
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Rename")
|
||||
icon.name: "edit_pencil"
|
||||
onTriggered: {
|
||||
|
@ -429,7 +429,7 @@ Pane {
|
|||
"%1 (%2)".arg(d.userDisplayName).arg(Utils.getElidedCompressedPk(root.publicKey)))
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Reverse Contact Rejection")
|
||||
icon.name: "refresh"
|
||||
enabled: d.contactDetails.removed
|
||||
|
@ -439,7 +439,7 @@ Pane {
|
|||
d.reload()
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Copy Link to Profile")
|
||||
icon.name: "copy"
|
||||
onTriggered: {
|
||||
|
@ -447,7 +447,7 @@ Pane {
|
|||
root.profileStore.copyToClipboard(d.linkToProfile)
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Unblock User")
|
||||
icon.name: "remove-circle"
|
||||
enabled: d.isBlocked
|
||||
|
@ -457,10 +457,10 @@ Pane {
|
|||
}
|
||||
}
|
||||
StatusMenuSeparator {}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Mark as Untrustworthy")
|
||||
icon.name: "warning"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
enabled: d.contactDetails.trustStatus === Constants.trustStatus.unknown
|
||||
onTriggered: {
|
||||
moreMenu.close()
|
||||
|
@ -471,7 +471,7 @@ Pane {
|
|||
d.reload()
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Remove Untrustworthy Mark")
|
||||
icon.name: "warning"
|
||||
enabled: d.contactDetails.trustStatus === Constants.trustStatus.untrustworthy
|
||||
|
@ -481,30 +481,30 @@ Pane {
|
|||
d.reload()
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Remove Identity Verification")
|
||||
icon.name: "warning"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
enabled: d.isContact && d.isTrusted
|
||||
onTriggered: {
|
||||
moreMenu.close()
|
||||
removeVerificationConfirmationDialog.open()
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Remove Contact")
|
||||
icon.name: "remove-contact"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
enabled: d.isContact && !d.isBlocked
|
||||
onTriggered: {
|
||||
moreMenu.close()
|
||||
removeContactConfirmationDialog.open()
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Cancel Contact Request")
|
||||
icon.name: "cancel"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
enabled: !d.isContact && d.isContactRequestSent && !d.contactDetails.removed
|
||||
onTriggered: {
|
||||
moreMenu.close()
|
||||
|
@ -512,10 +512,10 @@ Pane {
|
|||
d.reload()
|
||||
}
|
||||
}
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Block User")
|
||||
icon.name: "cancel"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
enabled: !d.isBlocked
|
||||
onTriggered: {
|
||||
moreMenu.close()
|
||||
|
|
|
@ -15,7 +15,7 @@ import shared.status 1.0
|
|||
import shared.controls.chat 1.0
|
||||
import shared.controls.chat.menuItems 1.0
|
||||
|
||||
StatusPopupMenu {
|
||||
StatusMenu {
|
||||
id: root
|
||||
|
||||
property var store
|
||||
|
@ -196,7 +196,7 @@ StatusPopupMenu {
|
|||
visible: !root.isEmoji && !root.hideEmojiPicker && !pinnedPopup
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: copyImageAction
|
||||
text: qsTr("Copy image")
|
||||
onTriggered: {
|
||||
|
@ -209,7 +209,7 @@ StatusPopupMenu {
|
|||
enabled: root.isRightClickOnImage && !root.pinnedPopup
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: downloadImageAction
|
||||
text: qsTr("Download image")
|
||||
onTriggered: {
|
||||
|
@ -247,7 +247,7 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Verify Identity")
|
||||
icon.name: "checkmark-circle"
|
||||
enabled: root.isProfile && !root.isMe && root.isContact
|
||||
|
@ -260,7 +260,7 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: isVerificationRequestSent ||
|
||||
root.incomingVerificationStatus === Constants.verificationStatus.verified ?
|
||||
qsTr("ID Request Pending....") :
|
||||
|
@ -281,7 +281,7 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Rename")
|
||||
icon.name: "edit_pencil"
|
||||
enabled: root.isProfile && !root.isMe
|
||||
|
@ -292,7 +292,7 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
text: qsTr("Unblock User")
|
||||
icon.name: "remove-circle"
|
||||
enabled: root.isProfile && !root.isMe && root.isBlockedContact
|
||||
|
@ -303,16 +303,16 @@ StatusPopupMenu {
|
|||
visible: blockMenuItem.enabled || markUntrustworthyMenuItem.enabled || removeUntrustworthyMarkMenuItem.enabled
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: markUntrustworthyMenuItem
|
||||
text: qsTr("Mark as Untrustworthy")
|
||||
icon.name: "warning"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
enabled: root.isProfile && !root.isMe && root.userTrustIsUnknown
|
||||
onTriggered: root.store.contactsStore.markUntrustworthy(root.selectedUserPublicKey)
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: removeUntrustworthyMarkMenuItem
|
||||
text: qsTr("Remove Untrustworthy Mark")
|
||||
icon.name: "warning"
|
||||
|
@ -320,16 +320,16 @@ StatusPopupMenu {
|
|||
onTriggered: root.store.contactsStore.removeTrustStatus(root.selectedUserPublicKey)
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: blockMenuItem
|
||||
text: qsTr("Block User")
|
||||
icon.name: "cancel"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
enabled: root.isProfile && !root.isMe && !root.isBlockedContact
|
||||
onTriggered: Global.blockContactRequested(root.selectedUserPublicKey, root.selectedUserDisplayName)
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: replyToMenuItem
|
||||
text: qsTr("Reply to")
|
||||
icon.name: "chat"
|
||||
|
@ -344,7 +344,7 @@ StatusPopupMenu {
|
|||
!root.isRightClickOnImage)
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: editMessageAction
|
||||
text: qsTr("Edit message")
|
||||
onTriggered: {
|
||||
|
@ -360,7 +360,7 @@ StatusPopupMenu {
|
|||
!root.isRightClickOnImage
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: copyMessageIdAction
|
||||
text: qsTr("Copy Message Id")
|
||||
icon.name: "chat"
|
||||
|
@ -371,7 +371,7 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: pinAction
|
||||
text: {
|
||||
if (root.pinnedMessage) {
|
||||
|
@ -428,7 +428,7 @@ StatusPopupMenu {
|
|||
pinAction.enabled)
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: deleteMessageAction
|
||||
enabled: root.isMyMessage &&
|
||||
!root.isProfile &&
|
||||
|
@ -450,10 +450,10 @@ StatusPopupMenu {
|
|||
}
|
||||
}
|
||||
icon.name: "delete"
|
||||
type: StatusMenuItem.Type.Danger
|
||||
type: StatusAction.Type.Danger
|
||||
}
|
||||
|
||||
StatusMenuItem {
|
||||
StatusAction {
|
||||
id: jumpToAction
|
||||
enabled: root.pinnedPopup && !root.isProfile
|
||||
text: qsTr("Jump to")
|
||||
|
|
Loading…
Reference in New Issue