Moved out NumberInput to separate module.
This commit is contained in:
		
							parent
							
								
									225380044e
								
							
						
					
					
						commit
						26b72fedc7
					
				
					 5 changed files with 89 additions and 59 deletions
				
			
		|  | @ -202,6 +202,8 @@ PRIVATE | ||||||
|     ui/widgets/input_fields.h |     ui/widgets/input_fields.h | ||||||
|     ui/widgets/labels.cpp |     ui/widgets/labels.cpp | ||||||
|     ui/widgets/labels.h |     ui/widgets/labels.h | ||||||
|  |     ui/widgets/fields/number_input.cpp | ||||||
|  |     ui/widgets/fields/number_input.h | ||||||
|     ui/widgets/fields/password_input.cpp |     ui/widgets/fields/password_input.cpp | ||||||
|     ui/widgets/fields/password_input.h |     ui/widgets/fields/password_input.h | ||||||
|     ui/widgets/fields/time_part_input.cpp |     ui/widgets/fields/time_part_input.cpp | ||||||
|  |  | ||||||
							
								
								
									
										49
									
								
								ui/widgets/fields/number_input.cpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										49
									
								
								ui/widgets/fields/number_input.cpp
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,49 @@ | ||||||
|  | // This file is part of Desktop App Toolkit,
 | ||||||
|  | // a set of libraries for developing nice desktop applications.
 | ||||||
|  | //
 | ||||||
|  | // For license and copyright information please follow this link:
 | ||||||
|  | // https://github.com/desktop-app/legal/blob/master/LEGAL
 | ||||||
|  | //
 | ||||||
|  | #include "ui/widgets/fields/number_input.h" | ||||||
|  | 
 | ||||||
|  | namespace Ui { | ||||||
|  | 
 | ||||||
|  | NumberInput::NumberInput( | ||||||
|  | 	QWidget *parent, | ||||||
|  | 	const style::InputField &st, | ||||||
|  | 	rpl::producer<QString> placeholder, | ||||||
|  | 	const QString &value, | ||||||
|  | 	int limit) | ||||||
|  | : MaskedInputField(parent, st, std::move(placeholder), value) | ||||||
|  | , _limit(limit) { | ||||||
|  | 	if (!value.toInt() || (limit > 0 && value.toInt() > limit)) { | ||||||
|  | 		setText(QString()); | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void NumberInput::correctValue( | ||||||
|  | 		const QString &was, | ||||||
|  | 		int wasCursor, | ||||||
|  | 		QString &now, | ||||||
|  | 		int &nowCursor) { | ||||||
|  | 	QString newText; | ||||||
|  | 	newText.reserve(now.size()); | ||||||
|  | 	auto newPos = nowCursor; | ||||||
|  | 	for (auto i = 0, l = int(now.size()); i < l; ++i) { | ||||||
|  | 		if (now.at(i).isDigit()) { | ||||||
|  | 			newText.append(now.at(i)); | ||||||
|  | 		} else if (i < nowCursor) { | ||||||
|  | 			--newPos; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	if (!newText.toInt()) { | ||||||
|  | 		newText = QString(); | ||||||
|  | 		newPos = 0; | ||||||
|  | 	} else if (_limit > 0 && newText.toInt() > _limit) { | ||||||
|  | 		newText = was; | ||||||
|  | 		newPos = wasCursor; | ||||||
|  | 	} | ||||||
|  | 	setCorrectedText(now, nowCursor, newText, newPos); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | } // namespace Ui
 | ||||||
							
								
								
									
										38
									
								
								ui/widgets/fields/number_input.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								ui/widgets/fields/number_input.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,38 @@ | ||||||
|  | // This file is part of Desktop App Toolkit,
 | ||||||
|  | // a set of libraries for developing nice desktop applications.
 | ||||||
|  | //
 | ||||||
|  | // For license and copyright information please follow this link:
 | ||||||
|  | // https://github.com/desktop-app/legal/blob/master/LEGAL
 | ||||||
|  | //
 | ||||||
|  | #pragma once | ||||||
|  | 
 | ||||||
|  | #include "ui/widgets/input_fields.h" | ||||||
|  | 
 | ||||||
|  | namespace style { | ||||||
|  | struct InputField; | ||||||
|  | } // namespace style
 | ||||||
|  | 
 | ||||||
|  | namespace Ui { | ||||||
|  | 
 | ||||||
|  | class NumberInput final : public MaskedInputField { | ||||||
|  | public: | ||||||
|  | 	NumberInput( | ||||||
|  | 		QWidget *parent, | ||||||
|  | 		const style::InputField &st, | ||||||
|  | 		rpl::producer<QString> placeholder, | ||||||
|  | 		const QString &value, | ||||||
|  | 		int limit); | ||||||
|  | 
 | ||||||
|  | protected: | ||||||
|  | 	void correctValue( | ||||||
|  | 		const QString &was, | ||||||
|  | 		int wasCursor, | ||||||
|  | 		QString &now, | ||||||
|  | 		int &nowCursor) override; | ||||||
|  | 
 | ||||||
|  | private: | ||||||
|  | 	int _limit = 0; | ||||||
|  | 
 | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | } // namespace Ui
 | ||||||
|  | @ -4349,44 +4349,6 @@ void MaskedInputField::onCursorPositionChanged(int oldPosition, int position) { | ||||||
| 	_oldcursor = position; | 	_oldcursor = position; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| NumberInput::NumberInput( |  | ||||||
| 	QWidget *parent, |  | ||||||
| 	const style::InputField &st, |  | ||||||
| 	rpl::producer<QString> placeholder, |  | ||||||
| 	const QString &value, |  | ||||||
| 	int limit) |  | ||||||
| : MaskedInputField(parent, st, std::move(placeholder), value) |  | ||||||
| , _limit(limit) { |  | ||||||
| 	if (!value.toInt() || (limit > 0 && value.toInt() > limit)) { |  | ||||||
| 		setText(QString()); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void NumberInput::correctValue( |  | ||||||
| 		const QString &was, |  | ||||||
| 		int wasCursor, |  | ||||||
| 		QString &now, |  | ||||||
| 		int &nowCursor) { |  | ||||||
| 	QString newText; |  | ||||||
| 	newText.reserve(now.size()); |  | ||||||
| 	auto newPos = nowCursor; |  | ||||||
| 	for (auto i = 0, l = int(now.size()); i < l; ++i) { |  | ||||||
| 		if (now.at(i).isDigit()) { |  | ||||||
| 			newText.append(now.at(i)); |  | ||||||
| 		} else if (i < nowCursor) { |  | ||||||
| 			--newPos; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	if (!newText.toInt()) { |  | ||||||
| 		newText = QString(); |  | ||||||
| 		newPos = 0; |  | ||||||
| 	} else if (_limit > 0 && newText.toInt() > _limit) { |  | ||||||
| 		newText = was; |  | ||||||
| 		newPos = wasCursor; |  | ||||||
| 	} |  | ||||||
| 	setCorrectedText(now, nowCursor, newText, newPos); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| HexInput::HexInput( | HexInput::HexInput( | ||||||
| 	QWidget *parent, | 	QWidget *parent, | ||||||
| 	const style::InputField &st, | 	const style::InputField &st, | ||||||
|  |  | ||||||
|  | @ -718,27 +718,6 @@ private: | ||||||
| 
 | 
 | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| class NumberInput : public MaskedInputField { |  | ||||||
| public: |  | ||||||
| 	NumberInput( |  | ||||||
| 		QWidget *parent, |  | ||||||
| 		const style::InputField &st, |  | ||||||
| 		rpl::producer<QString> placeholder, |  | ||||||
| 		const QString &value, |  | ||||||
| 		int limit); |  | ||||||
| 
 |  | ||||||
| protected: |  | ||||||
| 	void correctValue( |  | ||||||
| 		const QString &was, |  | ||||||
| 		int wasCursor, |  | ||||||
| 		QString &now, |  | ||||||
| 		int &nowCursor) override; |  | ||||||
| 
 |  | ||||||
| private: |  | ||||||
| 	int _limit = 0; |  | ||||||
| 
 |  | ||||||
| }; |  | ||||||
| 
 |  | ||||||
| class HexInput : public MaskedInputField { | class HexInput : public MaskedInputField { | ||||||
| public: | public: | ||||||
| 	HexInput(QWidget *parent, const style::InputField &st, rpl::producer<QString> placeholder, const QString &val); | 	HexInput(QWidget *parent, const style::InputField &st, rpl::producer<QString> placeholder, const QString &val); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 23rd
						23rd