Rename Local Storage to DOM Storage. https://redmine.stoutner.com/issues/852
[PrivacyBrowserPC.git] / src / filters / MouseEventFilter.cpp
1 /*
2  * Copyright © 2022 Soren Stoutner <soren@stoutner.com>.
3  *
4  * This file is part of Privacy Browser PC <https://www.stoutner.com/privacy-browser-pc>.
5  *
6  * Privacy Browser PC is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * Privacy Browser PC is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Privacy Browser PC.  If not, see <http://www.gnu.org/licenses/>.
18  */
19
20 // Application headers.
21 #include "MouseEventFilter.h"
22
23 // Qt headers.
24 #include <QEvent>
25 #include <QMouseEvent>
26
27 // The primary constructor.
28 MouseEventFilter::MouseEventFilter() : QObject() {};
29
30 // Construct the class.
31 bool MouseEventFilter::eventFilter(QObject *objectPointer, QEvent *eventPointer)
32 {
33     // Only process mouse button press events.
34     if (eventPointer->type() == QEvent::MouseButtonPress)
35     {
36         // Tell the compiler to ignore the unused object pointer.
37         (void)objectPointer;
38
39         // Cast the event to a mouse event.
40         QMouseEvent *mouseEventPointer = static_cast<QMouseEvent *>(eventPointer);
41
42         // Run the command according to the button that was pushed.
43         switch (mouseEventPointer->button())
44         {
45             case (Qt::BackButton):
46                 // Tell the WebEngine to go back.
47                 emit mouseBack();
48
49                 // Consume the event.
50                 return true;
51
52             case (Qt::ForwardButton):
53                 // Tell the WebEngine to go forward.
54                 emit mouseForward();
55
56                 // Consume the event.
57                 return true;
58
59             default:
60                 // Do not consume the event.
61                 return false;
62         }
63     }
64
65     // Do not consume the event.
66     return false;
67 }