summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAndrea Diamantini <adjam7@gmail.com>2009-10-21 11:40:00 +0200
committerAndrea Diamantini <adjam7@gmail.com>2009-10-21 11:40:00 +0200
commitefc61986022afd05ddb8f2f5a9dfe2d3468b919a (patch)
treed8b885f439dca16fc7f4778359fdb2cd1777f504 /src
parentFixing merge due to recent changes in master (diff)
parentRemove pages actions from text actions (diff)
downloadrekonq-efc61986022afd05ddb8f2f5a9dfe2d3468b919a.tar.xz
Merge commit 'refs/merge-requests/1865' of git://gitorious.org/rekonq/mainline into ACTIONS
Diffstat (limited to 'src')
-rw-r--r--src/webview.cpp98
1 files changed, 54 insertions, 44 deletions
diff --git a/src/webview.cpp b/src/webview.cpp
index 2fe3775b..85ab0f21 100644
--- a/src/webview.cpp
+++ b/src/webview.cpp
@@ -145,7 +145,7 @@ void WebView::contextMenuEvent(QContextMenuEvent *event)
a = pageAction(QWebPage::CopyLinkToClipboard);
a->setIcon(KIcon("edit-copy"));
menu.addAction(a);
-
+
menu.addSeparator();
}
@@ -165,10 +165,11 @@ void WebView::contextMenuEvent(QContextMenuEvent *event)
a = pageAction(QWebPage::Copy);
a->setIcon(KIcon("edit-copy"));
a->setShortcut(KStandardShortcut::copy().primary());
- if(!result.isContentEditable()) // "Cut" "Copy Text" "Paste" is ugly. Don't add "text" with cut/paste
- a->setText(i18n("Copy Text"));
+ a->setText(i18n("Copy"));
+ if(!result.linkUrl().isEmpty())
+ a->setText(i18n("Copy Text")); //for link
else
- a->setText(i18n("Copy"));
+ a->setText(i18n("Copy"));
menu.addAction(a);
}
@@ -232,7 +233,7 @@ void WebView::contextMenuEvent(QContextMenuEvent *event)
a->setData(result.imageUrl());
connect(a, SIGNAL(triggered(Qt::MouseButtons, Qt::KeyboardModifiers)), this, SLOT(viewImage(Qt::MouseButtons, Qt::KeyboardModifiers)));
menu.addAction(a);
-
+
a = pageAction(QWebPage::DownloadImageToDisk);
a->setIcon(KIcon("document-save"));
menu.addAction(a);
@@ -244,10 +245,10 @@ void WebView::contextMenuEvent(QContextMenuEvent *event)
menu.addSeparator();
}
- // last (but not less) actions..
+ // Open url text in new tab/window
if(result.linkUrl().isEmpty())
{
- // page action
+
QString text = selectedText();
if (text.startsWith( QLatin1String("http://") )
|| text.startsWith( QLatin1String("https://") )
@@ -272,52 +273,61 @@ void WebView::contextMenuEvent(QContextMenuEvent *event)
a->setData(QUrl(text));
connect(a, SIGNAL(triggered(bool)), this, SLOT(openLinkInNewWindow()));
menu.addAction(a);
+
+ menu.addSeparator();
}
- else
- {
- menu.addAction(mainwindow->actionByName("new_tab"));
- menu.addAction(mainwindow->actionByName("new_window"));
- }
- menu.addSeparator();
- }
- QWebHistory *history = page()->history();
- if(history->canGoBack())
- {
- a = pageAction(QWebPage::Back);
- a->setIcon(KIcon("go-previous"));
- menu.addAction(a);
}
- if(history->canGoForward())
+ // page actions
+ if (!result.isContentSelected() && result.linkUrl().isEmpty())
{
- a = pageAction(QWebPage::Forward);
- a->setIcon(KIcon("go-next"));
- menu.addAction(a);
- }
- menu.addAction(mainwindow->actionByName("view_redisplay"));
+ // navigation
+ QWebHistory *history = page()->history();
+ if(history->canGoBack())
+ {
+ a = pageAction(QWebPage::Back);
+ a->setIcon(KIcon("go-previous"));
+ menu.addAction(a);
+ }
- KActionMenu *frameMenu = new KActionMenu(i18n("Current Frame"), this);
+ if(history->canGoForward())
+ {
+ a = pageAction(QWebPage::Forward);
+ a->setIcon(KIcon("go-next"));
+ menu.addAction(a);
+ }
- a = pageAction(QWebPage::OpenFrameInNewWindow);
- a->setText(i18n("Open in New Tab"));
- a->setIcon(KIcon("view-right-new"));
- frameMenu->addAction(a);
+ menu.addAction(mainwindow->actionByName("view_redisplay"));
- a = new KAction( KIcon("document-print-frame"), i18n("Print Frame"), this);
- connect(a, SIGNAL(triggered()), this, SLOT(printFrame()));
- frameMenu->addAction(a);
- menu.addAction(frameMenu);
+ menu.addAction(mainwindow->actionByName("new_tab"));
+ menu.addAction(mainwindow->actionByName("new_window"));
- // empty space actions
- if(result.linkUrl().isEmpty())
- {
menu.addSeparator();
- menu.addAction(mainwindow->actionByName(KStandardAction::name(KStandardAction::SaveAs)));
+ //Frame
+ a = pageAction(QWebPage::OpenFrameInNewWindow);
+ a->setText(i18n("Open Frame in New Tab"));
+ a->setIcon(KIcon("view-right-new"));
+ menu.addAction(a);
+
+ a = new KAction( KIcon("document-print-frame"), i18n("Print Frame"), this);
+ connect(a, SIGNAL(triggered()), this, SLOT(printFrame()));
+ menu.addAction(a);
+
+ menu.addSeparator();
+ //Page
+ a = pageAction(QWebPage::SelectAll);
+ a->setIcon(KIcon("edit-select-all"));
+ a->setShortcut(KStandardShortcut::selectAll().primary());
+ a->setText(i18n("Select All"));
+ menu.addAction(a);
+
+ menu.addAction(mainwindow->actionByName(KStandardAction::name(KStandardAction::SaveAs)));
menu.addAction(mainwindow->actionByName("page_source"));
+
menu.addAction(mainwindow->actionByName("add_to_favorites"));
QAction *addBookmarkAction = Application::bookmarkProvider()->actionByName("rekonq_add_bookmark");
menu.addAction(addBookmarkAction);
@@ -329,12 +339,12 @@ void WebView::contextMenuEvent(QContextMenuEvent *event)
a->setIcon(KIcon("view-process-all"));
menu.addAction(a);
}
- }
- if(mainwindow->isFullScreen())
- {
- menu.addSeparator();
- menu.addAction(mainwindow->actionByName("fullscreen"));
+ if(mainwindow->isFullScreen())
+ {
+ menu.addSeparator();
+ menu.addAction(mainwindow->actionByName("fullscreen"));
+ }
}
menu.exec(mapToGlobal(event->pos()));