diff options
Diffstat (limited to 'Swift/QtUI/UserSearch/UserSearchDelegate.cpp')
| -rw-r--r-- | Swift/QtUI/UserSearch/UserSearchDelegate.cpp | 106 | 
1 files changed, 45 insertions, 61 deletions
diff --git a/Swift/QtUI/UserSearch/UserSearchDelegate.cpp b/Swift/QtUI/UserSearch/UserSearchDelegate.cpp index ff3e766..812c1c3 100644 --- a/Swift/QtUI/UserSearch/UserSearchDelegate.cpp +++ b/Swift/QtUI/UserSearch/UserSearchDelegate.cpp @@ -6,11 +6,14 @@  #include <QPen>  #include <QPainter> +#include <QStyleOptionViewItem> +#include <QModelIndex> +#include <QFontMetrics>  #include "Swift/QtUI/UserSearch/UserSearchDelegate.h"  //#include "Swift/QtUI/Roster/GroupItemDelegate.h" -//#include "Swift/QtUI/MUCSearch/MUCSearchItem.h" -//#include "Swift/QtUI/MUCSearch/MUCSearchRoomItem.h" +#include <Swift/Controllers/Chat/UserSearchController.h> +#include <Swift/QtUI/UserSearch/UserSearchModel.h>  //#include "Swift/QtUI/MUCSearch/MUCSearchServiceItem.h"  namespace Swift { @@ -23,64 +26,45 @@ UserSearchDelegate::~UserSearchDelegate() {  } -// QSize MUCSearchDelegate::sizeHint(const QStyleOptionViewItem& option, const QModelIndex& index ) const { -// 	// MUCSearchItem* item = static_cast<MUCSearchItem*>(index.internalPointer()); -// 	// if (item && dynamic_cast<MUCSearchMUCItem*>(item)) { -// 	// 	return mucSizeHint(option, index); -// 	// } else if (item && dynamic_cast<MUCSearchGroupItem*>(item)) { -// 	// 	return groupDelegate_->sizeHint(option, index); -// 	// } -// 	return QStyledItemDelegate::sizeHint(option, index); -// } - -// QSize MUCSearchDelegate::mucSizeHint(const QStyleOptionViewItem& /*option*/, const QModelIndex& /*index*/ ) const { -// 	QFontMetrics nameMetrics(common_.nameFont); -// 	QFontMetrics statusMetrics(common_.detailFont); -// 	int sizeByText = 2 * common_.verticalMargin + nameMetrics.height() + statusMetrics.height(); -// 	return QSize(150, sizeByText); -// } - -// void MUCSearchDelegate::paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const { -// 	MUCSearchItem* item = static_cast<MUCSearchItem*>(index.internalPointer()); -// 	if (item && dynamic_cast<MUCSearchMUCItem*>(item)) { -// 		paintMUC(painter, option, dynamic_cast<MUCSearchMUCItem*>(item)); -// 	} else if (item && dynamic_cast<MUCSearchGroupItem*>(item)) { -// 		MUCSearchGroupItem* group = dynamic_cast<MUCSearchGroupItem*>(item); -// 		groupDelegate_->paint(painter, option, group->data(Qt::DisplayRole).toString(), group->rowCount(), option.state & QStyle::State_Open); -// 	} else { -// 		QStyledItemDelegate::paint(painter, option, index); -// 	} -// } - -// void MUCSearchDelegate::paintMUC(QPainter* painter, const QStyleOptionViewItem& option, MUCSearchMUCItem* item) const { -// 	painter->save(); -// 	QRect fullRegion(option.rect); -// 	if ( option.state & QStyle::State_Selected ) { -// 		painter->fillRect(fullRegion, option.palette.highlight()); -// 		painter->setPen(option.palette.highlightedText().color()); -// 	} else { -// 		QColor nameColor = item->data(Qt::TextColorRole).value<QColor>(); -// 		painter->setPen(QPen(nameColor)); -// 	} - -// 	QFontMetrics nameMetrics(common_.nameFont); -// 	painter->setFont(common_.nameFont); -// 	int extraFontWidth = nameMetrics.width("H"); -// 	int leftOffset = common_.horizontalMargin * 2 + extraFontWidth / 2; -// 	QRect textRegion(fullRegion.adjusted(leftOffset, 0, 0, 0)); - -// 	int nameHeight = nameMetrics.height() + common_.verticalMargin; -// 	QRect nameRegion(textRegion.adjusted(0, common_.verticalMargin, 0, 0)); - -// 	painter->drawText(nameRegion, Qt::AlignTop, item->data(Qt::DisplayRole).toString()); - -// 	painter->setFont(common_.detailFont); -// 	painter->setPen(QPen(QColor(160,160,160))); - -// 	QRect detailRegion(textRegion.adjusted(0, nameHeight, 0, 0)); -// 	painter->drawText(detailRegion, Qt::AlignTop, item->data(DetailTextRole).toString()); - -// 	painter->restore(); -// } +QSize UserSearchDelegate::sizeHint(const QStyleOptionViewItem& /*option*/, const QModelIndex& /*index*/ ) const { +	//UserSearchItem* item = static_cast<UserSearchItem*>(index.internalPointer()); +	QFontMetrics nameMetrics(common_.nameFont); +	QFontMetrics statusMetrics(common_.detailFont); +	int sizeByText = 2 * common_.verticalMargin + nameMetrics.height() + statusMetrics.height(); +	return QSize(150, sizeByText); +} + +void UserSearchDelegate::paint(QPainter* painter,	const QStyleOptionViewItem& option, const QModelIndex& index) const { +	UserSearchResult* item = static_cast<UserSearchResult*>(index.internalPointer()); +	painter->save(); +	QRect fullRegion(option.rect); +	if (option.state & QStyle::State_Selected) { +		painter->fillRect(fullRegion, option.palette.highlight()); +		painter->setPen(option.palette.highlightedText().color()); +	} +	else { +		QColor nameColor = UserSearchModel::data(item, Qt::TextColorRole).value<QColor> (); +		painter->setPen(QPen(nameColor)); +	} + +	QFontMetrics nameMetrics(common_.nameFont); +	painter->setFont(common_.nameFont); +	int extraFontWidth = nameMetrics.width("H"); +	int leftOffset = common_.horizontalMargin * 2 + extraFontWidth / 2; +	QRect textRegion(fullRegion.adjusted(leftOffset, 0, 0, 0)); + +	int nameHeight = nameMetrics.height() + common_.verticalMargin; +	QRect nameRegion(textRegion.adjusted(0, common_.verticalMargin, 0, 0)); + +	painter->drawText(nameRegion, Qt::AlignTop, UserSearchModel::data(item, Qt::DisplayRole).toString()); + +	painter->setFont(common_.detailFont); +	painter->setPen(QPen(QColor(160, 160, 160))); + +	QRect detailRegion(textRegion.adjusted(0, nameHeight, 0, 0)); +	painter->drawText(detailRegion, Qt::AlignTop, UserSearchModel::data(item, UserSearchModel::DetailTextRole).toString()); + +	painter->restore(); +}  }  | 
 Swift