mirror of https://github.com/procxx/kepka.git
				
				
				
			Fix crashes in filter chats list editing.
This commit is contained in:
		
							parent
							
								
									455d113955
								
							
						
					
					
						commit
						36b9911995
					
				|  | @ -44,12 +44,7 @@ public: | ||||||
| 
 | 
 | ||||||
| 	QString generateName() override; | 	QString generateName() override; | ||||||
| 	QString generateShortName() override; | 	QString generateShortName() override; | ||||||
| 	void paintEntityUserpicLeft( | 	PaintRoundImageCallback generatePaintUserpicCallback() override; | ||||||
| 		Painter &p, |  | ||||||
| 		int x, |  | ||||||
| 		int y, |  | ||||||
| 		int outerWidth, |  | ||||||
| 		int size) override; |  | ||||||
| 
 | 
 | ||||||
| private: | private: | ||||||
| 	[[nodiscard]] Flag flag() const; | 	[[nodiscard]] Flag flag() const; | ||||||
|  | @ -144,13 +139,11 @@ QString TypeRow::generateShortName() { | ||||||
| 	return generateName(); | 	return generateName(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void TypeRow::paintEntityUserpicLeft( | PaintRoundImageCallback TypeRow::generatePaintUserpicCallback() { | ||||||
| 		Painter &p, | 	const auto flag = this->flag(); | ||||||
| 		int x, | 	return [=](Painter &p, int x, int y, int outerWidth, int size) { | ||||||
| 		int y, | 		PaintFilterChatsTypeIcon(p, flag, x, y, outerWidth, size); | ||||||
| 		int outerWidth, | 	}; | ||||||
| 		int size) { |  | ||||||
| 	PaintFilterChatsTypeIcon(p, flag(), x, y, outerWidth, size); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Flag TypeRow::flag() const { | Flag TypeRow::flag() const { | ||||||
|  |  | ||||||
|  | @ -345,13 +345,12 @@ void ManageFiltersPrepare::SetupBox( | ||||||
| 	AddSubsectionTitle(content, tr::lng_filters_subtitle()); | 	AddSubsectionTitle(content, tr::lng_filters_subtitle()); | ||||||
| 
 | 
 | ||||||
| 	const auto rows = box->lifetime().make_state<std::vector<FilterRow>>(); | 	const auto rows = box->lifetime().make_state<std::vector<FilterRow>>(); | ||||||
|  | 	const auto rowsCount = box->lifetime().make_state<rpl::variable<int>>(); | ||||||
| 	const auto find = [=](not_null<FilterRowButton*> button) { | 	const auto find = [=](not_null<FilterRowButton*> button) { | ||||||
| 		const auto i = ranges::find(*rows, button, &FilterRow::button); | 		const auto i = ranges::find(*rows, button, &FilterRow::button); | ||||||
| 		Assert(i != end(*rows)); | 		Assert(i != end(*rows)); | ||||||
| 		return &*i; | 		return &*i; | ||||||
| 	}; | 	}; | ||||||
| 	const auto countNonRemoved = [=] { |  | ||||||
| 	}; |  | ||||||
| 	const auto showLimitReached = [=] { | 	const auto showLimitReached = [=] { | ||||||
| 		const auto removed = ranges::count_if(*rows, &FilterRow::removed); | 		const auto removed = ranges::count_if(*rows, &FilterRow::removed); | ||||||
| 		if (rows->size() < kFiltersLimit + removed) { | 		if (rows->size() < kFiltersLimit + removed) { | ||||||
|  | @ -393,6 +392,7 @@ void ManageFiltersPrepare::SetupBox( | ||||||
| 				crl::guard(button, doneCallback))); | 				crl::guard(button, doneCallback))); | ||||||
| 		}); | 		}); | ||||||
| 		rows->push_back({ button, filter }); | 		rows->push_back({ button, filter }); | ||||||
|  | 		*rowsCount = rows->size(); | ||||||
| 
 | 
 | ||||||
| 		wrap->resizeToWidth(content->width()); | 		wrap->resizeToWidth(content->width()); | ||||||
| 	}; | 	}; | ||||||
|  | @ -462,8 +462,14 @@ void ManageFiltersPrepare::SetupBox( | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	using namespace rpl::mappers; | 	using namespace rpl::mappers; | ||||||
| 	emptyAbout->toggleOn(suggested->value() | rpl::map(_1 == 0)); | 	auto showSuggestions = rpl::combine( | ||||||
| 	nonEmptyAbout->toggleOn(suggested->value() | rpl::map(_1 > 0)); | 		suggested->value(), | ||||||
|  | 		rowsCount->value() | ||||||
|  | 	) | rpl::map(_1 > 0 && _2 < kFiltersLimit); | ||||||
|  | 	emptyAbout->toggleOn(rpl::duplicate( | ||||||
|  | 		showSuggestions | ||||||
|  | 	) | rpl::map(!_1)); | ||||||
|  | 	nonEmptyAbout->toggleOn(std::move(showSuggestions)); | ||||||
| 
 | 
 | ||||||
| 	const auto prepareGoodIdsForNewFilters = [=] { | 	const auto prepareGoodIdsForNewFilters = [=] { | ||||||
| 		const auto &list = session->data().chatsFilters().list(); | 		const auto &list = session->data().chatsFilters().list(); | ||||||
|  |  | ||||||
|  | @ -484,24 +484,17 @@ QString PeerListRow::generateShortName() { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| PaintRoundImageCallback PeerListRow::generatePaintUserpicCallback() { | PaintRoundImageCallback PeerListRow::generatePaintUserpicCallback() { | ||||||
|  | 	const auto saved = _isSavedMessagesChat; | ||||||
|  | 	const auto peer = this->peer(); | ||||||
| 	return [=](Painter &p, int x, int y, int outerWidth, int size) { | 	return [=](Painter &p, int x, int y, int outerWidth, int size) { | ||||||
| 		paintEntityUserpicLeft(p, x, y, outerWidth, size); | 		if (saved) { | ||||||
|  | 			Ui::EmptyUserpic::PaintSavedMessages(p, x, y, outerWidth, size); | ||||||
|  | 		} else { | ||||||
|  | 			peer->paintUserpicLeft(p, x, y, outerWidth, size); | ||||||
|  | 		} | ||||||
| 	}; | 	}; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void PeerListRow::paintEntityUserpicLeft( |  | ||||||
| 		Painter &p, |  | ||||||
| 		int x, |  | ||||||
| 		int y, |  | ||||||
| 		int outerWidth, |  | ||||||
| 		int size) { |  | ||||||
| 	if (_isSavedMessagesChat) { |  | ||||||
| 		Ui::EmptyUserpic::PaintSavedMessages(p, x, y, outerWidth, size); |  | ||||||
| 	} else { |  | ||||||
| 		peer()->paintUserpicLeft(p, x, y, outerWidth, size); |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void PeerListRow::invalidatePixmapsCache() { | void PeerListRow::invalidatePixmapsCache() { | ||||||
| 	if (_checkbox) { | 	if (_checkbox) { | ||||||
| 		_checkbox->invalidateCache(); | 		_checkbox->invalidateCache(); | ||||||
|  | @ -571,8 +564,8 @@ void PeerListRow::paintUserpic( | ||||||
| 		paintDisabledCheckUserpic(p, st, x, y, outerWidth); | 		paintDisabledCheckUserpic(p, st, x, y, outerWidth); | ||||||
| 	} else if (_checkbox) { | 	} else if (_checkbox) { | ||||||
| 		_checkbox->paint(p, x, y, outerWidth); | 		_checkbox->paint(p, x, y, outerWidth); | ||||||
| 	} else { | 	} else if (const auto callback = generatePaintUserpicCallback()) { | ||||||
| 		paintEntityUserpicLeft(p, x, y, outerWidth, st.photoSize); | 		callback(p, x, y, outerWidth, st.photoSize); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -87,7 +87,8 @@ public: | ||||||
| 
 | 
 | ||||||
| 	[[nodiscard]] virtual QString generateName(); | 	[[nodiscard]] virtual QString generateName(); | ||||||
| 	[[nodiscard]] virtual QString generateShortName(); | 	[[nodiscard]] virtual QString generateShortName(); | ||||||
| 	[[nodiscard]] PaintRoundImageCallback generatePaintUserpicCallback(); | 	[[nodiscard]] virtual auto generatePaintUserpicCallback() | ||||||
|  | 		-> PaintRoundImageCallback; | ||||||
| 
 | 
 | ||||||
| 	void setCustomStatus(const QString &status); | 	void setCustomStatus(const QString &status); | ||||||
| 	void clearCustomStatus(); | 	void clearCustomStatus(); | ||||||
|  | @ -207,13 +208,6 @@ protected: | ||||||
| 
 | 
 | ||||||
| 	explicit PeerListRow(PeerListRowId id); | 	explicit PeerListRow(PeerListRowId id); | ||||||
| 
 | 
 | ||||||
| 	virtual void paintEntityUserpicLeft( |  | ||||||
| 		Painter &p, |  | ||||||
| 		int x, |  | ||||||
| 		int y, |  | ||||||
| 		int outerWidth, |  | ||||||
| 		int size); |  | ||||||
| 
 |  | ||||||
| private: | private: | ||||||
| 	void createCheckbox( | 	void createCheckbox( | ||||||
| 		const style::RoundImageCheckbox &st, | 		const style::RoundImageCheckbox &st, | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue