| 
							
							
							
						 |  |  | @@ -1,5 +1,5 @@ | 
		
	
		
			
				|  |  |  |  | /* | 
		
	
		
			
				|  |  |  |  | * Copyright (c) 2018-2019 Albert S. <mail at quitesimple dot org> | 
		
	
		
			
				|  |  |  |  |  * Copyright (c) 2018-2020 Albert S. <mail at quitesimple dot org> | 
		
	
		
			
				|  |  |  |  |  * | 
		
	
		
			
				|  |  |  |  |  * Permission to use, copy, modify, and distribute this software for any | 
		
	
		
			
				|  |  |  |  |  * purpose with or without fee is hereby granted, provided that the above | 
		
	
	
		
			
				
					
					|  |  |  | @@ -13,22 +13,23 @@ | 
		
	
		
			
				|  |  |  |  |  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | 
		
	
		
			
				|  |  |  |  |  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | 
		
	
		
			
				|  |  |  |  |  */ | 
		
	
		
			
				|  |  |  |  | #include <QProcess> | 
		
	
		
			
				|  |  |  |  | #include <QProcessEnvironment> | 
		
	
		
			
				|  |  |  |  | #include <QClipboard> | 
		
	
		
			
				|  |  |  |  | #include <QDate> | 
		
	
		
			
				|  |  |  |  | #include <QDebug> | 
		
	
		
			
				|  |  |  |  | #include <QDesktopServices> | 
		
	
		
			
				|  |  |  |  | #include <QDirIterator> | 
		
	
		
			
				|  |  |  |  | #include <QFileIconProvider> | 
		
	
		
			
				|  |  |  |  | #include <QHeaderView> | 
		
	
		
			
				|  |  |  |  | #include <QIcon> | 
		
	
		
			
				|  |  |  |  | #include <QKeySequence> | 
		
	
		
			
				|  |  |  |  | #include <QLabel> | 
		
	
		
			
				|  |  |  |  | #include <QDate> | 
		
	
		
			
				|  |  |  |  | #include <QHeaderView> | 
		
	
		
			
				|  |  |  |  | #include <QDesktopServices> | 
		
	
		
			
				|  |  |  |  | #include <QFileIconProvider> | 
		
	
		
			
				|  |  |  |  | #include <QDebug> | 
		
	
		
			
				|  |  |  |  | #include <QMenu> | 
		
	
		
			
				|  |  |  |  | #include <QClipboard> | 
		
	
		
			
				|  |  |  |  | #include <QProcess> | 
		
	
		
			
				|  |  |  |  | #include <QProcessEnvironment> | 
		
	
		
			
				|  |  |  |  | #include <QScrollArea> | 
		
	
		
			
				|  |  |  |  | #include "window.h" | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | #include "entryprovider.h" | 
		
	
		
			
				|  |  |  |  | #include "window.h" | 
		
	
		
			
				|  |  |  |  | Window::Window(EntryProvider &entryProvider, SettingsProvider &configProvider) | 
		
	
		
			
				|  |  |  |  | { | 
		
	
		
			
				|  |  |  |  | 	this->entryProvider = &entryProvider; | 
		
	
	
		
			
				
					
					|  |  |  | @@ -43,13 +44,12 @@ Window::Window(EntryProvider &entryProvider, SettingsProvider &configProvider) | 
		
	
		
			
				|  |  |  |  | 	calculationResultLabel.setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding); | 
		
	
		
			
				|  |  |  |  | 	calculationResultLabel.setAlignment(Qt::AlignCenter); | 
		
	
		
			
				|  |  |  |  | 	calculationResultLabel.setContextMenuPolicy(Qt::ContextMenuPolicy::CustomContextMenu); | 
		
	
		
			
				|  |  |  |  | 	connect(&calculationResultLabel, &QLabel::customContextMenuRequested, this, &Window::showCalculationResultContextMenu); | 
		
	
		
			
				|  |  |  |  | 	connect(&calculationResultLabel, &QLabel::customContextMenuRequested, this, | 
		
	
		
			
				|  |  |  |  | 			&Window::showCalculationResultContextMenu); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | Window::~Window() | 
		
	
		
			
				|  |  |  |  | { | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | void Window::initFromConfig() | 
		
	
	
		
			
				
					
					|  |  |  | @@ -198,7 +198,6 @@ void Window::addCalcResult(const QString &expression) | 
		
	
		
			
				|  |  |  |  | 	calculationResultLabel.setText(labelText); | 
		
	
		
			
				|  |  |  |  | 	calculationResultLabel.setVisible(true); | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	QFont currentFont = calculationResultLabel.font(); | 
		
	
		
			
				|  |  |  |  | 	int calculatedPointSize = currentFont.pointSize(); | 
		
	
		
			
				|  |  |  |  | 	QFontMetrics fm(currentFont); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -268,11 +267,11 @@ void Window::keyReleaseEvent(QKeyEvent *event) | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  | 	QWidget::keyReleaseEvent(event); | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  | void Window::keyPressEvent(QKeyEvent *event) | 
		
	
		
			
				|  |  |  |  | { | 
		
	
		
			
				|  |  |  |  | 	bool closeWindow = ((event->modifiers() & Qt::ControlModifier && event->key() == Qt::Key_Q) || event->key() == Qt::Key_Escape); | 
		
	
		
			
				|  |  |  |  | 	bool closeWindow = | 
		
	
		
			
				|  |  |  |  | 		((event->modifiers() & Qt::ControlModifier && event->key() == Qt::Key_Q) || event->key() == Qt::Key_Escape); | 
		
	
		
			
				|  |  |  |  | 	if(closeWindow) | 
		
	
		
			
				|  |  |  |  | 	{ | 
		
	
		
			
				|  |  |  |  | 		this->closeWindow(); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -294,7 +293,8 @@ void Window::keyPressEvent(QKeyEvent *event) | 
		
	
		
			
				|  |  |  |  | 		QKeySequence seq(event->key()); | 
		
	
		
			
				|  |  |  |  | 		QString key = seq.toString().toLower(); | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 		auto it = std::find_if(buttonsInGrid.begin(), buttonsInGrid.end(), [&key](const EntryPushButton *y) { return y->getShortcutKey() == key; }); | 
		
	
		
			
				|  |  |  |  | 		auto it = std::find_if(buttonsInGrid.begin(), buttonsInGrid.end(), | 
		
	
		
			
				|  |  |  |  | 							   [&key](const EntryPushButton *y) { return y->getShortcutKey() == key; }); | 
		
	
		
			
				|  |  |  |  | 		if(it != buttonsInGrid.end()) | 
		
	
		
			
				|  |  |  |  | 		{ | 
		
	
		
			
				|  |  |  |  | 			buttonClick(**it); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -324,6 +324,7 @@ void Window::filterGridFor(QString filter) | 
		
	
		
			
				|  |  |  |  | 			int currow = 0; | 
		
	
		
			
				|  |  |  |  | 			int curcol = 0; | 
		
	
		
			
				|  |  |  |  | 			int i = 1; | 
		
	
		
			
				|  |  |  |  | 			const int MAX_COLS = this->settingsProvider->getMaxCols(); | 
		
	
		
			
				|  |  |  |  | 			for(EntryPushButton *button : this->systemEntryButtons) | 
		
	
		
			
				|  |  |  |  | 			{ | 
		
	
		
			
				|  |  |  |  | 				if(button->getName().contains(filter, Qt::CaseInsensitive)) | 
		
	
	
		
			
				
					
					|  |  |  | @@ -335,7 +336,7 @@ void Window::filterGridFor(QString filter) | 
		
	
		
			
				|  |  |  |  | 					} | 
		
	
		
			
				|  |  |  |  | 					grid->addWidget(button, currow, curcol++); | 
		
	
		
			
				|  |  |  |  | 					this->buttonsInGrid.append(button); | 
		
	
		
			
				|  |  |  |  | 					if(curcol == 3) | 
		
	
		
			
				|  |  |  |  | 					if(curcol == MAX_COLS) | 
		
	
		
			
				|  |  |  |  | 					{ | 
		
	
		
			
				|  |  |  |  | 						curcol = 0; | 
		
	
		
			
				|  |  |  |  | 						++currow; | 
		
	
	
		
			
				
					
					|  |  |  | @@ -343,15 +344,11 @@ void Window::filterGridFor(QString filter) | 
		
	
		
			
				|  |  |  |  | 				} | 
		
	
		
			
				|  |  |  |  | 			} | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  | 	else | 
		
	
		
			
				|  |  |  |  | 	{ | 
		
	
		
			
				|  |  |  |  | 		populateGrid(this->userEntryButtons); | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | } | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | EntryPushButton *Window::createEntryButton(const EntryConfig &entry) | 
		
	
	
		
			
				
					
					|  |  |  | @@ -370,7 +367,6 @@ void Window::lineEditReturnPressed() | 
		
	
		
			
				|  |  |  |  | 		return; | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	if(buttonsInGrid.length() > 0 && this->lineEdit->text().length() > 0) | 
		
	
		
			
				|  |  |  |  | 	{ | 
		
	
		
			
				|  |  |  |  | 		buttonClick(*buttonsInGrid[0]); | 
		
	
	
		
			
				
					
					|  |  |  | @@ -401,7 +397,6 @@ bool Window::eventFilter(QObject *obj, QEvent *event) | 
		
	
		
			
				|  |  |  |  | 				return true; | 
		
	
		
			
				|  |  |  |  | 			} | 
		
	
		
			
				|  |  |  |  | 		} | 
		
	
		
			
				|  |  |  |  |  | 
		
	
		
			
				|  |  |  |  | 	} | 
		
	
		
			
				|  |  |  |  | 	return QObject::eventFilter(obj, event); | 
		
	
		
			
				|  |  |  |  | } | 
		
	
	
		
			
				
					
					|  |  |  |   |