mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-27 15:57:08 -05:00
Merge pull request #455 from PhenomRetroShare/Add_CopyRSTreeWidgetHeaderContextMenuToItemContextMenu
Copy RsTreeWidget Header ContextMenu to Item ContextMenu.
This commit is contained in:
commit
fea4159b86
@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QMenu>
|
#include <QMenu>
|
||||||
|
#include <QWidgetAction>
|
||||||
|
|
||||||
#include "IdDialog.h"
|
#include "IdDialog.h"
|
||||||
#include "ui_IdDialog.h"
|
#include "ui_IdDialog.h"
|
||||||
@ -225,8 +226,8 @@ IdDialog::IdDialog(QWidget *parent) :
|
|||||||
ui->splitter->setSizes(sizes);*/
|
ui->splitter->setSizes(sizes);*/
|
||||||
|
|
||||||
/* Add filter types */
|
/* Add filter types */
|
||||||
QMenu *idTWHMenu = new QMenu(tr("Show"), this);
|
QMenu *idTWHMenu = new QMenu(tr("Show Items"), this);
|
||||||
ui->idTreeWidget->addHeaderContextMenuMenu(idTWHMenu);
|
ui->idTreeWidget->addContextMenuMenu(idTWHMenu);
|
||||||
|
|
||||||
QActionGroup *idTWHActionGroup = new QActionGroup(this);
|
QActionGroup *idTWHActionGroup = new QActionGroup(this);
|
||||||
QAction *idTWHAction = new QAction(QIcon(),tr("All"), this);
|
QAction *idTWHAction = new QAction(QIcon(),tr("All"), this);
|
||||||
@ -2069,7 +2070,7 @@ void IdDialog::loadRequest(const TokenQueue * queue, const TokenRequest &req)
|
|||||||
|
|
||||||
void IdDialog::IdListCustomPopupMenu( QPoint )
|
void IdDialog::IdListCustomPopupMenu( QPoint )
|
||||||
{
|
{
|
||||||
QMenu contextMnu( this );
|
QMenu *contextMenu = new QMenu(this);
|
||||||
|
|
||||||
|
|
||||||
std::list<RsGxsId> own_identities ;
|
std::list<RsGxsId> own_identities ;
|
||||||
@ -2129,16 +2130,42 @@ void IdDialog::IdListCustomPopupMenu( QPoint )
|
|||||||
++n_is_not_a_contact ;
|
++n_is_not_a_contact ;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(root_node_present) // don't show menu if some of the root nodes are present
|
if(!root_node_present) // don't show menu if some of the root nodes are present
|
||||||
return ;
|
{
|
||||||
|
|
||||||
if(!one_item_owned_by_you)
|
if(!one_item_owned_by_you)
|
||||||
{
|
{
|
||||||
|
QWidget *widget = new QWidget(contextMenu);
|
||||||
|
widget->setStyleSheet( ".QWidget{background-color: qlineargradient(x1:0, y1:0, x2:0, y2:1,stop:0 #FEFEFE, stop:1 #E8E8E8); border: 1px solid #CCCCCC;}");
|
||||||
|
|
||||||
|
// create menu header
|
||||||
|
QHBoxLayout *hbox = new QHBoxLayout(widget);
|
||||||
|
hbox->setMargin(0);
|
||||||
|
hbox->setSpacing(6);
|
||||||
|
|
||||||
|
QLabel *iconLabel = new QLabel(widget);
|
||||||
|
QPixmap pix = QPixmap(":/images/user/friends24.png").scaledToHeight(QFontMetricsF(iconLabel->font()).height()*1.5);
|
||||||
|
iconLabel->setPixmap(pix);
|
||||||
|
iconLabel->setMaximumSize(iconLabel->frameSize().height() + pix.height(), pix.width());
|
||||||
|
hbox->addWidget(iconLabel);
|
||||||
|
|
||||||
|
QLabel *textLabel = new QLabel("<strong>" + ui->titleBarLabel->text() + "</strong>", widget);
|
||||||
|
hbox->addWidget(textLabel);
|
||||||
|
|
||||||
|
QSpacerItem *spacerItem = new QSpacerItem(40, 20, QSizePolicy::Expanding, QSizePolicy::Minimum);
|
||||||
|
hbox->addItem(spacerItem);
|
||||||
|
|
||||||
|
widget->setLayout(hbox);
|
||||||
|
|
||||||
|
QWidgetAction *widgetAction = new QWidgetAction(this);
|
||||||
|
widgetAction->setDefaultWidget(widget);
|
||||||
|
contextMenu->addAction(widgetAction);
|
||||||
|
|
||||||
if(n_selected_items == 1) // if only one item is selected, allow to chat with this item
|
if(n_selected_items == 1) // if only one item is selected, allow to chat with this item
|
||||||
{
|
{
|
||||||
if(own_identities.size() <= 1)
|
if(own_identities.size() <= 1)
|
||||||
{
|
{
|
||||||
QAction *action = contextMnu.addAction(QIcon(":/images/chat_24.png"), tr("Chat with this person"), this, SLOT(chatIdentity()));
|
QAction *action = contextMenu->addAction(QIcon(":/images/chat_24.png"), tr("Chat with this person"), this, SLOT(chatIdentity()));
|
||||||
|
|
||||||
if(own_identities.empty())
|
if(own_identities.empty())
|
||||||
action->setEnabled(false) ;
|
action->setEnabled(false) ;
|
||||||
@ -2147,7 +2174,7 @@ void IdDialog::IdListCustomPopupMenu( QPoint )
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
QMenu *mnu = contextMnu.addMenu(QIcon(":/images/chat_24.png"),tr("Chat with this person as...")) ;
|
QMenu *mnu = contextMenu->addMenu(QIcon(":/images/chat_24.png"),tr("Chat with this person as...")) ;
|
||||||
|
|
||||||
for(std::list<RsGxsId>::const_iterator it=own_identities.begin();it!=own_identities.end();++it)
|
for(std::list<RsGxsId>::const_iterator it=own_identities.begin();it!=own_identities.end();++it)
|
||||||
{
|
{
|
||||||
@ -2166,40 +2193,42 @@ void IdDialog::IdListCustomPopupMenu( QPoint )
|
|||||||
}
|
}
|
||||||
|
|
||||||
// always allow to send messages
|
// always allow to send messages
|
||||||
contextMnu.addAction(QIcon(":/images/mail_new.png"), tr("Send message"), this, SLOT(sendMsg()));
|
contextMenu->addAction(QIcon(":/images/mail_new.png"), tr("Send message"), this, SLOT(sendMsg()));
|
||||||
|
|
||||||
contextMnu.addSeparator();
|
contextMenu->addSeparator();
|
||||||
|
|
||||||
if(n_is_a_contact == 0)
|
if(n_is_a_contact == 0)
|
||||||
contextMnu.addAction(QIcon(), tr("Add to Contacts"), this, SLOT(addtoContacts()));
|
contextMenu->addAction(QIcon(), tr("Add to Contacts"), this, SLOT(addtoContacts()));
|
||||||
|
|
||||||
if(n_is_not_a_contact == 0)
|
if(n_is_not_a_contact == 0)
|
||||||
contextMnu.addAction(QIcon(":/images/cancel.png"), tr("Remove from Contacts"), this, SLOT(removefromContacts()));
|
contextMenu->addAction(QIcon(":/images/cancel.png"), tr("Remove from Contacts"), this, SLOT(removefromContacts()));
|
||||||
|
|
||||||
contextMnu.addSeparator();
|
contextMenu->addSeparator();
|
||||||
|
|
||||||
if(n_positive_reputations == 0) // only unban when all items are banned
|
if(n_positive_reputations == 0) // only unban when all items are banned
|
||||||
contextMnu.addAction(QIcon(":/images/vote_up.png"), tr("Set positive opinion"), this, SLOT(positivePerson()));
|
contextMenu->addAction(QIcon(":/images/vote_up.png"), tr("Set positive opinion"), this, SLOT(positivePerson()));
|
||||||
|
|
||||||
if(n_neutral_reputations == 0) // only unban when all items are banned
|
if(n_neutral_reputations == 0) // only unban when all items are banned
|
||||||
contextMnu.addAction(QIcon(":/images/vote_neutral.png"), tr("Set neutral opinion"), this, SLOT(neutralPerson()));
|
contextMenu->addAction(QIcon(":/images/vote_neutral.png"), tr("Set neutral opinion"), this, SLOT(neutralPerson()));
|
||||||
|
|
||||||
if(n_negative_reputations == 0)
|
if(n_negative_reputations == 0)
|
||||||
contextMnu.addAction(QIcon(":/images/vote_down.png"), tr("Set negative opinion"), this, SLOT(negativePerson()));
|
contextMenu->addAction(QIcon(":/images/vote_down.png"), tr("Set negative opinion"), this, SLOT(negativePerson()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if(one_item_owned_by_you && n_selected_items==1)
|
if(one_item_owned_by_you && n_selected_items==1)
|
||||||
{
|
{
|
||||||
contextMnu.addSeparator();
|
contextMenu->addSeparator();
|
||||||
|
|
||||||
contextMnu.addAction(ui->editIdentity);
|
contextMenu->addAction(ui->editIdentity);
|
||||||
contextMnu.addAction(ui->removeIdentity);
|
contextMenu->addAction(ui->removeIdentity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
contextMnu.addSeparator();
|
contextMenu = ui->idTreeWidget->createStandardContextMenu(contextMenu);
|
||||||
|
|
||||||
contextMnu.exec(QCursor::pos());
|
contextMenu->exec(QCursor::pos());
|
||||||
|
delete contextMenu;
|
||||||
}
|
}
|
||||||
|
|
||||||
void IdDialog::chatIdentity()
|
void IdDialog::chatIdentity()
|
||||||
|
@ -140,7 +140,7 @@ FriendList::FriendList(QWidget *parent) :
|
|||||||
mActionSortByState = new QAction(tr("Sort by state"), this);
|
mActionSortByState = new QAction(tr("Sort by state"), this);
|
||||||
mActionSortByState->setCheckable(true);
|
mActionSortByState->setCheckable(true);
|
||||||
connect(mActionSortByState, SIGNAL(toggled(bool)), this, SLOT(sortByState(bool)));
|
connect(mActionSortByState, SIGNAL(toggled(bool)), this, SLOT(sortByState(bool)));
|
||||||
ui->peerTreeWidget->addHeaderContextMenuAction(mActionSortByState);
|
ui->peerTreeWidget->addContextMenuAction(mActionSortByState);
|
||||||
|
|
||||||
/* Set sort */
|
/* Set sort */
|
||||||
sortByColumn(COLUMN_NAME, Qt::AscendingOrder);
|
sortByColumn(COLUMN_NAME, Qt::AscendingOrder);
|
||||||
@ -282,9 +282,9 @@ void FriendList::peerTreeWidgetCustomPopupMenu()
|
|||||||
{
|
{
|
||||||
QTreeWidgetItem *c = getCurrentPeer();
|
QTreeWidgetItem *c = getCurrentPeer();
|
||||||
|
|
||||||
QMenu contextMnu(this);
|
QMenu *contextMenu = new QMenu(this);
|
||||||
|
|
||||||
QWidget *widget = new QWidget(&contextMnu);
|
QWidget *widget = new QWidget(contextMenu);
|
||||||
widget->setStyleSheet( ".QWidget{background-color: qlineargradient(x1:0, y1:0, x2:0, y2:1,stop:0 #FEFEFE, stop:1 #E8E8E8); border: 1px solid #CCCCCC;}");
|
widget->setStyleSheet( ".QWidget{background-color: qlineargradient(x1:0, y1:0, x2:0, y2:1,stop:0 #FEFEFE, stop:1 #E8E8E8); border: 1px solid #CCCCCC;}");
|
||||||
|
|
||||||
// create menu header
|
// create menu header
|
||||||
@ -293,8 +293,9 @@ void FriendList::peerTreeWidgetCustomPopupMenu()
|
|||||||
hbox->setSpacing(6);
|
hbox->setSpacing(6);
|
||||||
|
|
||||||
QLabel *iconLabel = new QLabel(widget);
|
QLabel *iconLabel = new QLabel(widget);
|
||||||
iconLabel->setPixmap(QPixmap(":/images/user/friends24.png"));
|
QPixmap pix = QPixmap(":/images/user/friends24.png").scaledToHeight(QFontMetricsF(iconLabel->font()).height()*1.5);
|
||||||
iconLabel->setMaximumSize(iconLabel->frameSize().height() + 24, 24);
|
iconLabel->setPixmap(pix);
|
||||||
|
iconLabel->setMaximumSize(iconLabel->frameSize().height() + pix.height(), pix.width());
|
||||||
hbox->addWidget(iconLabel);
|
hbox->addWidget(iconLabel);
|
||||||
|
|
||||||
QLabel *textLabel = new QLabel("<strong>RetroShare</strong>", widget);
|
QLabel *textLabel = new QLabel("<strong>RetroShare</strong>", widget);
|
||||||
@ -307,7 +308,7 @@ void FriendList::peerTreeWidgetCustomPopupMenu()
|
|||||||
|
|
||||||
QWidgetAction *widgetAction = new QWidgetAction(this);
|
QWidgetAction *widgetAction = new QWidgetAction(this);
|
||||||
widgetAction->setDefaultWidget(widget);
|
widgetAction->setDefaultWidget(widget);
|
||||||
contextMnu.addAction(widgetAction);
|
contextMenu->addAction(widgetAction);
|
||||||
|
|
||||||
// create menu entries
|
// create menu entries
|
||||||
if (c)
|
if (c)
|
||||||
@ -337,23 +338,23 @@ void FriendList::peerTreeWidgetCustomPopupMenu()
|
|||||||
{
|
{
|
||||||
bool standard = c->data(COLUMN_DATA, ROLE_STANDARD).toBool();
|
bool standard = c->data(COLUMN_DATA, ROLE_STANDARD).toBool();
|
||||||
|
|
||||||
contextMnu.addAction(QIcon(IMAGE_MSG), tr("Send message to whole group"), this, SLOT(msgfriend()));
|
contextMenu->addAction(QIcon(IMAGE_MSG), tr("Send message to whole group"), this, SLOT(msgfriend()));
|
||||||
contextMnu.addSeparator();
|
contextMenu->addSeparator();
|
||||||
contextMnu.addAction(QIcon(IMAGE_EDIT), tr("Edit Group"), this, SLOT(editGroup()));
|
contextMenu->addAction(QIcon(IMAGE_EDIT), tr("Edit Group"), this, SLOT(editGroup()));
|
||||||
|
|
||||||
QAction *action = contextMnu.addAction(QIcon(IMAGE_REMOVE), tr("Remove Group"), this, SLOT(removeGroup()));
|
QAction *action = contextMenu->addAction(QIcon(IMAGE_REMOVE), tr("Remove Group"), this, SLOT(removeGroup()));
|
||||||
action->setDisabled(standard);
|
action->setDisabled(standard);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case TYPE_GPG:
|
case TYPE_GPG:
|
||||||
{
|
{
|
||||||
contextMnu.addAction(QIcon(IMAGE_CHAT), tr("Chat"), this, SLOT(chatfriendproxy()));
|
contextMenu->addAction(QIcon(IMAGE_CHAT), tr("Chat"), this, SLOT(chatfriendproxy()));
|
||||||
contextMnu.addAction(QIcon(IMAGE_MSG), tr("Send message"), this, SLOT(msgfriend()));
|
contextMenu->addAction(QIcon(IMAGE_MSG), tr("Send message"), this, SLOT(msgfriend()));
|
||||||
|
|
||||||
contextMnu.addSeparator();
|
contextMenu->addSeparator();
|
||||||
|
|
||||||
contextMnu.addAction(QIcon(IMAGE_FRIENDINFO), tr("Details"), this, SLOT(configurefriend()));
|
contextMenu->addAction(QIcon(IMAGE_FRIENDINFO), tr("Details"), this, SLOT(configurefriend()));
|
||||||
contextMnu.addAction(QIcon(IMAGE_DENYFRIEND), tr("Deny"), this, SLOT(removefriend()));
|
contextMenu->addAction(QIcon(IMAGE_DENYFRIEND), tr("Deny"), this, SLOT(removefriend()));
|
||||||
|
|
||||||
if(mShowGroups)
|
if(mShowGroups)
|
||||||
{
|
{
|
||||||
@ -375,7 +376,7 @@ void FriendList::peerTreeWidgetCustomPopupMenu()
|
|||||||
if (std::find(groupIt->peerIds.begin(), groupIt->peerIds.end(), gpgId) == groupIt->peerIds.end()) {
|
if (std::find(groupIt->peerIds.begin(), groupIt->peerIds.end(), gpgId) == groupIt->peerIds.end()) {
|
||||||
if (parent) {
|
if (parent) {
|
||||||
if (addToGroupMenu == NULL) {
|
if (addToGroupMenu == NULL) {
|
||||||
addToGroupMenu = new QMenu(tr("Add to group"), &contextMnu);
|
addToGroupMenu = new QMenu(tr("Add to group"), contextMenu);
|
||||||
}
|
}
|
||||||
QAction* addToGroupAction = new QAction(GroupDefs::name(*groupIt), addToGroupMenu);
|
QAction* addToGroupAction = new QAction(GroupDefs::name(*groupIt), addToGroupMenu);
|
||||||
addToGroupAction->setData(QString::fromStdString(groupIt->id.toStdString()));
|
addToGroupAction->setData(QString::fromStdString(groupIt->id.toStdString()));
|
||||||
@ -384,7 +385,7 @@ void FriendList::peerTreeWidgetCustomPopupMenu()
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (moveToGroupMenu == NULL) {
|
if (moveToGroupMenu == NULL) {
|
||||||
moveToGroupMenu = new QMenu(tr("Move to group"), &contextMnu);
|
moveToGroupMenu = new QMenu(tr("Move to group"), contextMenu);
|
||||||
}
|
}
|
||||||
QAction* moveToGroupAction = new QAction(GroupDefs::name(*groupIt), moveToGroupMenu);
|
QAction* moveToGroupAction = new QAction(GroupDefs::name(*groupIt), moveToGroupMenu);
|
||||||
moveToGroupAction->setData(QString::fromStdString(groupIt->id.toStdString()));
|
moveToGroupAction->setData(QString::fromStdString(groupIt->id.toStdString()));
|
||||||
@ -395,7 +396,7 @@ void FriendList::peerTreeWidgetCustomPopupMenu()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
QMenu *groupsMenu = contextMnu.addMenu(QIcon(IMAGE_GROUP16), tr("Groups"));
|
QMenu *groupsMenu = contextMenu->addMenu(QIcon(IMAGE_GROUP16), tr("Groups"));
|
||||||
groupsMenu->addAction(QIcon(IMAGE_EXPAND), tr("Create new group"), this, SLOT(createNewGroup()));
|
groupsMenu->addAction(QIcon(IMAGE_EXPAND), tr("Create new group"), this, SLOT(createNewGroup()));
|
||||||
|
|
||||||
if (addToGroupMenu || moveToGroupMenu || foundGroup) {
|
if (addToGroupMenu || moveToGroupMenu || foundGroup) {
|
||||||
@ -427,40 +428,43 @@ void FriendList::peerTreeWidgetCustomPopupMenu()
|
|||||||
|
|
||||||
case TYPE_SSL:
|
case TYPE_SSL:
|
||||||
{
|
{
|
||||||
contextMnu.addAction(QIcon(IMAGE_CHAT), tr("Chat"), this, SLOT(chatfriendproxy()));
|
contextMenu->addAction(QIcon(IMAGE_CHAT), tr("Chat"), this, SLOT(chatfriendproxy()));
|
||||||
contextMnu.addAction(QIcon(IMAGE_MSG), tr("Send message"), this, SLOT(msgfriend()));
|
contextMenu->addAction(QIcon(IMAGE_MSG), tr("Send message"), this, SLOT(msgfriend()));
|
||||||
|
|
||||||
contextMnu.addSeparator();
|
contextMenu->addSeparator();
|
||||||
|
|
||||||
contextMnu.addAction(QIcon(IMAGE_FRIENDINFO), tr("Details"), this, SLOT(configurefriend()));
|
contextMenu->addAction(QIcon(IMAGE_FRIENDINFO), tr("Details"), this, SLOT(configurefriend()));
|
||||||
|
|
||||||
if (type == TYPE_GPG || type == TYPE_SSL) {
|
if (type == TYPE_GPG || type == TYPE_SSL) {
|
||||||
contextMnu.addAction(QIcon(IMAGE_EXPORTFRIEND), tr("Recommend this Friend to..."), this, SLOT(recommendfriend()));
|
contextMenu->addAction(QIcon(IMAGE_EXPORTFRIEND), tr("Recommend this Friend to..."), this, SLOT(recommendfriend()));
|
||||||
}
|
}
|
||||||
|
|
||||||
contextMnu.addAction(QIcon(IMAGE_CONNECT), tr("Attempt to connect"), this, SLOT(connectfriend()));
|
contextMenu->addAction(QIcon(IMAGE_CONNECT), tr("Attempt to connect"), this, SLOT(connectfriend()));
|
||||||
|
|
||||||
contextMnu.addAction(QIcon(IMAGE_COPYLINK), tr("Copy certificate link"), this, SLOT(copyFullCertificate()));
|
contextMenu->addAction(QIcon(IMAGE_COPYLINK), tr("Copy certificate link"), this, SLOT(copyFullCertificate()));
|
||||||
|
|
||||||
|
|
||||||
//this is a SSL key
|
//this is a SSL key
|
||||||
contextMnu.addAction(QIcon(IMAGE_REMOVEFRIEND), tr("Remove Friend Node"), this, SLOT(removefriend()));
|
contextMenu->addAction(QIcon(IMAGE_REMOVEFRIEND), tr("Remove Friend Node"), this, SLOT(removefriend()));
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
contextMnu.addSeparator();
|
contextMenu->addSeparator();
|
||||||
|
|
||||||
QAction *action = contextMnu.addAction(QIcon(IMAGE_PASTELINK), tr("Paste certificate link"), this, SLOT(pastePerson()));
|
QAction *action = contextMenu->addAction(QIcon(IMAGE_PASTELINK), tr("Paste certificate link"), this, SLOT(pastePerson()));
|
||||||
if (RSLinkClipboard::empty(RetroShareLink::TYPE_CERTIFICATE))
|
if (RSLinkClipboard::empty(RetroShareLink::TYPE_CERTIFICATE))
|
||||||
action->setDisabled(true);
|
action->setDisabled(true);
|
||||||
|
|
||||||
contextMnu.addAction(QIcon(IMAGE_EXPAND), tr("Expand all"), ui->peerTreeWidget, SLOT(expandAll()));
|
contextMenu->addAction(QIcon(IMAGE_EXPAND), tr("Expand all"), ui->peerTreeWidget, SLOT(expandAll()));
|
||||||
contextMnu.addAction(QIcon(IMAGE_COLLAPSE), tr("Collapse all"), ui->peerTreeWidget, SLOT(collapseAll()));
|
contextMenu->addAction(QIcon(IMAGE_COLLAPSE), tr("Collapse all"), ui->peerTreeWidget, SLOT(collapseAll()));
|
||||||
|
|
||||||
contextMnu.exec(QCursor::pos());
|
contextMenu = ui->peerTreeWidget->createStandardContextMenu(contextMenu);
|
||||||
|
|
||||||
|
contextMenu->exec(QCursor::pos());
|
||||||
|
delete contextMenu;
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendList::createNewGroup()
|
void FriendList::createNewGroup()
|
||||||
@ -2284,16 +2288,16 @@ void FriendList::addPeerToExpand(const std::string &gpgId)
|
|||||||
|
|
||||||
void FriendList::createDisplayMenu()
|
void FriendList::createDisplayMenu()
|
||||||
{
|
{
|
||||||
QMenu *displayMenu = new QMenu(tr("Show"), this);
|
QMenu *displayMenu = new QMenu(tr("Show Items"), this);
|
||||||
connect(displayMenu, SIGNAL(aboutToShow()), this, SLOT(updateMenu()));
|
connect(displayMenu, SIGNAL(aboutToShow()), this, SLOT(updateMenu()));
|
||||||
|
|
||||||
displayMenu->addAction(ui->actionHideOfflineFriends);
|
displayMenu->addAction(ui->actionHideOfflineFriends);
|
||||||
displayMenu->addAction(ui->actionShowState);
|
displayMenu->addAction(ui->actionShowState);
|
||||||
displayMenu->addAction(ui->actionShowGroups);
|
displayMenu->addAction(ui->actionShowGroups);
|
||||||
|
|
||||||
ui->peerTreeWidget->addHeaderContextMenuMenu(displayMenu);
|
ui->peerTreeWidget->addContextMenuMenu(displayMenu);
|
||||||
ui->peerTreeWidget->addHeaderContextMenuAction(ui->actionExportFriendlist);
|
ui->peerTreeWidget->addContextMenuAction(ui->actionExportFriendlist);
|
||||||
ui->peerTreeWidget->addHeaderContextMenuAction(ui->actionImportFriendlist);
|
ui->peerTreeWidget->addContextMenuAction(ui->actionImportFriendlist);
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendList::updateMenu()
|
void FriendList::updateMenu()
|
||||||
|
@ -108,7 +108,7 @@ FriendSelectionWidget::FriendSelectionWidget(QWidget *parent)
|
|||||||
mActionSortByState = new QAction(tr("Sort by state"), this);
|
mActionSortByState = new QAction(tr("Sort by state"), this);
|
||||||
mActionSortByState->setCheckable(true);
|
mActionSortByState->setCheckable(true);
|
||||||
connect(mActionSortByState, SIGNAL(toggled(bool)), this, SLOT(sortByState(bool)));
|
connect(mActionSortByState, SIGNAL(toggled(bool)), this, SLOT(sortByState(bool)));
|
||||||
ui->friendList->addHeaderContextMenuAction(mActionSortByState);
|
ui->friendList->addContextMenuAction(mActionSortByState);
|
||||||
|
|
||||||
/* initialize list */
|
/* initialize list */
|
||||||
ui->friendList->setColumnCount(COLUMN_COUNT);
|
ui->friendList->setColumnCount(COLUMN_COUNT);
|
||||||
@ -808,16 +808,16 @@ void FriendSelectionWidget::addContextMenuAction(QAction *action)
|
|||||||
|
|
||||||
void FriendSelectionWidget::contextMenuRequested(const QPoint &/*pos*/)
|
void FriendSelectionWidget::contextMenuRequested(const QPoint &/*pos*/)
|
||||||
{
|
{
|
||||||
QMenu contextMenu(this);
|
QMenu *contextMenu = new QMenu(this);
|
||||||
|
|
||||||
if (mListModus == MODUS_CHECK) {
|
if (mListModus == MODUS_CHECK) {
|
||||||
contextMenu.addAction(QIcon(), tr("Mark all"), this, SLOT(selectAll()));
|
contextMenu->addAction(QIcon(), tr("Mark all"), this, SLOT(selectAll()));
|
||||||
contextMenu.addAction(QIcon(), tr("Mark none"), this, SLOT(deselectAll()));
|
contextMenu->addAction(QIcon(), tr("Mark none"), this, SLOT(deselectAll()));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!mContextMenuActions.isEmpty()) {
|
if (!mContextMenuActions.isEmpty()) {
|
||||||
bool addSeparator = false;
|
bool addSeparator = false;
|
||||||
if (!contextMenu.isEmpty()) {
|
if (!contextMenu->isEmpty()) {
|
||||||
// Check for visible action
|
// Check for visible action
|
||||||
foreach (QAction *action, mContextMenuActions) {
|
foreach (QAction *action, mContextMenuActions) {
|
||||||
if (action->isVisible()) {
|
if (action->isVisible()) {
|
||||||
@ -828,17 +828,19 @@ void FriendSelectionWidget::contextMenuRequested(const QPoint &/*pos*/)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (addSeparator) {
|
if (addSeparator) {
|
||||||
contextMenu.addSeparator();
|
contextMenu->addSeparator();
|
||||||
}
|
}
|
||||||
|
|
||||||
contextMenu.addActions(mContextMenuActions);
|
contextMenu->addActions(mContextMenuActions);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (contextMenu.isEmpty()) {
|
contextMenu = ui->friendList->createStandardContextMenu(contextMenu);
|
||||||
return;
|
|
||||||
|
if (!contextMenu->isEmpty()) {
|
||||||
|
contextMenu->exec(QCursor::pos());
|
||||||
}
|
}
|
||||||
|
|
||||||
contextMenu.exec(QCursor::pos());
|
delete contextMenu;
|
||||||
}
|
}
|
||||||
|
|
||||||
void FriendSelectionWidget::itemDoubleClicked(QTreeWidgetItem *item, int /*column*/)
|
void FriendSelectionWidget::itemDoubleClicked(QTreeWidgetItem *item, int /*column*/)
|
||||||
|
@ -18,13 +18,16 @@
|
|||||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor,
|
||||||
* Boston, MA 02110-1301, USA.
|
* Boston, MA 02110-1301, USA.
|
||||||
****************************************************************/
|
****************************************************************/
|
||||||
|
|
||||||
#include <QPainter>
|
|
||||||
#include <QMouseEvent>
|
|
||||||
#include <QHeaderView>
|
|
||||||
#include <QMenu>
|
|
||||||
|
|
||||||
#include "RSTreeWidget.h"
|
#include "RSTreeWidget.h"
|
||||||
|
|
||||||
|
#include <QHBoxLayout>
|
||||||
|
#include <QHeaderView>
|
||||||
|
#include <QLabel>
|
||||||
|
#include <QMenu>
|
||||||
|
#include <QMouseEvent>
|
||||||
|
#include <QPainter>
|
||||||
|
#include <QWidgetAction>
|
||||||
|
|
||||||
#include "gui/settings/rsharesettings.h"
|
#include "gui/settings/rsharesettings.h"
|
||||||
|
|
||||||
RSTreeWidget::RSTreeWidget(QWidget *parent) : QTreeWidget(parent)
|
RSTreeWidget::RSTreeWidget(QWidget *parent) : QTreeWidget(parent)
|
||||||
@ -164,21 +167,54 @@ void RSTreeWidget::setColumnCustomizable(int column, bool customizable)
|
|||||||
mColumnCustomizable[column] = customizable;
|
mColumnCustomizable[column] = customizable;
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSTreeWidget::addHeaderContextMenuAction(QAction *action)
|
void RSTreeWidget::addContextMenuAction(QAction *action)
|
||||||
{
|
{
|
||||||
mHeaderContextMenuActions.push_back(action);
|
mContextMenuActions.push_back(action);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSTreeWidget::addHeaderContextMenuMenu(QMenu *menu)
|
void RSTreeWidget::addContextMenuMenu(QMenu *menu)
|
||||||
{
|
{
|
||||||
mHeaderContextMenuMenus.push_back(menu);
|
mContextMenuMenus.push_back(menu);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSTreeWidget::headerContextMenuRequested(const QPoint &pos)
|
QMenu *RSTreeWidget::createStandardContextMenu(QMenu *contextMenu)
|
||||||
{
|
{
|
||||||
QMenu contextMenu(this);
|
if (!contextMenu){
|
||||||
|
contextMenu = new QMenu(this);
|
||||||
|
contextMenu->addSeparator();
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!mContextMenuActions.isEmpty() || mEnableColumnCustomize ||!mContextMenuActions.isEmpty() || !mContextMenuMenus.isEmpty()) {
|
||||||
|
QWidget *widget = new QWidget(contextMenu);
|
||||||
|
widget->setStyleSheet( ".QWidget{background-color: qlineargradient(x1:0, y1:0, x2:0, y2:1,stop:0 #FEFEFE, stop:1 #E8E8E8); border: 1px solid #CCCCCC;}");
|
||||||
|
|
||||||
|
// create menu header
|
||||||
|
QHBoxLayout *hbox = new QHBoxLayout(widget);
|
||||||
|
hbox->setMargin(0);
|
||||||
|
hbox->setSpacing(6);
|
||||||
|
|
||||||
|
QLabel *iconLabel = new QLabel(widget);
|
||||||
|
QPixmap pix = QPixmap(":/images/settings.png").scaledToHeight(QFontMetricsF(iconLabel->font()).height()*1.5);
|
||||||
|
iconLabel->setPixmap(pix);
|
||||||
|
iconLabel->setMaximumSize(iconLabel->frameSize().height() + pix.height(), pix.width());
|
||||||
|
hbox->addWidget(iconLabel);
|
||||||
|
|
||||||
|
QLabel *textLabel = new QLabel("<strong>" + tr("Tree View Options") + "</strong>", widget);
|
||||||
|
hbox->addWidget(textLabel);
|
||||||
|
|
||||||
|
QSpacerItem *spacerItem = new QSpacerItem(40, 20, QSizePolicy::Expanding, QSizePolicy::Minimum);
|
||||||
|
hbox->addItem(spacerItem);
|
||||||
|
|
||||||
|
widget->setLayout(hbox);
|
||||||
|
|
||||||
|
QWidgetAction *widgetAction = new QWidgetAction(this);
|
||||||
|
widgetAction->setDefaultWidget(widget);
|
||||||
|
contextMenu->addAction(widgetAction);
|
||||||
|
}
|
||||||
|
|
||||||
if (mEnableColumnCustomize) {
|
if (mEnableColumnCustomize) {
|
||||||
|
QMenu *headerMenu = contextMenu->addMenu(QIcon(),tr("Show Headers"));
|
||||||
|
|
||||||
QTreeWidgetItem *item = headerItem();
|
QTreeWidgetItem *item = headerItem();
|
||||||
int columnCount = item->columnCount();
|
int columnCount = item->columnCount();
|
||||||
for (int column = 0; column < columnCount; ++column) {
|
for (int column = 0; column < columnCount; ++column) {
|
||||||
@ -186,18 +222,18 @@ void RSTreeWidget::headerContextMenuRequested(const QPoint &pos)
|
|||||||
if (it != mColumnCustomizable.end() && *it == false) {
|
if (it != mColumnCustomizable.end() && *it == false) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
QAction *action = contextMenu.addAction(QIcon(), item->text(column), this, SLOT(columnVisible()));
|
QAction *action = headerMenu->addAction(QIcon(), item->text(column), this, SLOT(columnVisible()));
|
||||||
action->setCheckable(true);
|
action->setCheckable(true);
|
||||||
action->setData(column);
|
action->setData(column);
|
||||||
action->setChecked(!isColumnHidden(column));
|
action->setChecked(!isColumnHidden(column));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!mHeaderContextMenuActions.isEmpty()) {
|
if (!mContextMenuActions.isEmpty()) {
|
||||||
bool addSeparator = false;
|
bool addSeparator = false;
|
||||||
if (!contextMenu.isEmpty()) {
|
if (!contextMenu->isEmpty()) {
|
||||||
// Check for visible action
|
// Check for visible action
|
||||||
foreach (QAction *action, mHeaderContextMenuActions) {
|
foreach (QAction *action, mContextMenuActions) {
|
||||||
if (action->isVisible()) {
|
if (action->isVisible()) {
|
||||||
addSeparator = true;
|
addSeparator = true;
|
||||||
break;
|
break;
|
||||||
@ -206,24 +242,31 @@ void RSTreeWidget::headerContextMenuRequested(const QPoint &pos)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (addSeparator) {
|
if (addSeparator) {
|
||||||
contextMenu.addSeparator();
|
contextMenu->addSeparator();
|
||||||
}
|
}
|
||||||
|
|
||||||
contextMenu.addActions(mHeaderContextMenuActions);
|
contextMenu->addActions(mContextMenuActions);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!mHeaderContextMenuMenus.isEmpty()) {
|
if (!mContextMenuMenus.isEmpty()) {
|
||||||
foreach(QMenu *menu, mHeaderContextMenuMenus) {
|
foreach(QMenu *menu, mContextMenuMenus) {
|
||||||
contextMenu.addSeparator();
|
contextMenu->addSeparator();
|
||||||
contextMenu.addMenu(menu);
|
contextMenu->addMenu(menu);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (contextMenu.isEmpty()) {
|
return contextMenu;
|
||||||
|
}
|
||||||
|
|
||||||
|
void RSTreeWidget::headerContextMenuRequested(const QPoint &pos)
|
||||||
|
{
|
||||||
|
QMenu *contextMenu = createStandardContextMenu(NULL);
|
||||||
|
if (contextMenu->isEmpty()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
contextMenu.exec(mapToGlobal(pos));
|
contextMenu->exec(mapToGlobal(pos));
|
||||||
|
delete contextMenu;
|
||||||
}
|
}
|
||||||
|
|
||||||
void RSTreeWidget::columnVisible()
|
void RSTreeWidget::columnVisible()
|
||||||
|
@ -46,9 +46,11 @@ public:
|
|||||||
void resort();
|
void resort();
|
||||||
|
|
||||||
// Add QAction to context menu (action won't be deleted)
|
// Add QAction to context menu (action won't be deleted)
|
||||||
void addHeaderContextMenuAction(QAction *action);
|
void addContextMenuAction(QAction *action);
|
||||||
// Add QMenu to context menu (menu won't be deleted)
|
// Add QMenu to context menu (menu won't be deleted)
|
||||||
void addHeaderContextMenuMenu(QMenu *menu);
|
void addContextMenuMenu(QMenu *menu);
|
||||||
|
// Get Default context menu (Columns choice and menus added)
|
||||||
|
QMenu *createStandardContextMenu(QMenu *menu);
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void signalMouseMiddleButtonClicked(QTreeWidgetItem *item);
|
void signalMouseMiddleButtonClicked(QTreeWidgetItem *item);
|
||||||
@ -70,8 +72,8 @@ private:
|
|||||||
bool mEnableColumnCustomize;
|
bool mEnableColumnCustomize;
|
||||||
quint32 mSettingsVersion;
|
quint32 mSettingsVersion;
|
||||||
QMap<int, bool> mColumnCustomizable;
|
QMap<int, bool> mColumnCustomizable;
|
||||||
QList<QAction*> mHeaderContextMenuActions;
|
QList<QAction*> mContextMenuActions;
|
||||||
QList<QMenu*> mHeaderContextMenuMenus;
|
QList<QMenu*> mContextMenuMenus;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user