1
0
mirror of https://github.com/tomahawk-player/tomahawk.git synced 2025-08-20 04:41:36 +02:00

* Added native MacLineEdit widget and used it in TomahawkWindow's toolbar.

This commit is contained in:
Christian Muehlhaeuser
2011-08-04 05:11:12 +02:00
parent 5fd8e2181d
commit 8c3ea50301
7 changed files with 262 additions and 14 deletions

View File

@@ -422,10 +422,12 @@ IF( APPLE )
SET( libSources ${libSources}
infosystem/infoplugins/mac/adium.mm
infosystem/infoplugins/mac/adiumplugin.cpp
widgets/maclineedit.mm
utils/tomahawkutils_mac.mm )
SET( libHeaders ${libHeaders}
infosystem/infoplugins/mac/adiumplugin.h )
infosystem/infoplugins/mac/adiumplugin.h
widgets/maclineedit.h )
SET( OS_SPECIFIC_LINK_LIBRARIES
${OS_SPECIFIC_LINK_LIBRARIES}

View File

@@ -67,4 +67,3 @@ SearchButton *SearchLineEdit::searchButton() const
{
return m_searchButton;
}

View File

@@ -33,6 +33,7 @@
class ClearButton;
class SearchButton;
class DLLEXPORT SearchLineEdit : public LineEdit
{
Q_OBJECT
@@ -47,7 +48,6 @@ private:
void init();
ClearButton *m_clearButton;
SearchButton *m_searchButton;
};
#endif // SEARCHLINEEDIT_H

View File

@@ -0,0 +1,82 @@
/* This file is part of Clementine.
Copyright 2010, David Sansome <me@davidsansome.com>
Clementine is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Clementine is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Clementine. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef MACLINEEDIT_H
#define MACLINEEDIT_H
#include <QMacCocoaViewContainer>
class SearchTargetWrapper;
class LineEditInterface {
public:
LineEditInterface(QWidget* widget) : widget_(widget) {}
QWidget* widget() const { return widget_; }
virtual ~LineEditInterface() {}
virtual void clear() { set_text(QString()); }
virtual void set_focus() = 0;
virtual QString text() const = 0;
virtual void set_text(const QString& text) = 0;
virtual QString hint() const = 0;
virtual void set_hint(const QString& hint) = 0;
virtual void clear_hint() = 0;
virtual void set_enabled(bool enabled) = 0;
protected:
QWidget* widget_;
};
class MacLineEdit : public QMacCocoaViewContainer, public LineEditInterface {
Q_OBJECT
Q_PROPERTY(QString hint READ hint WRITE set_hint);
public:
MacLineEdit(QWidget* parent = 0);
~MacLineEdit();
QString hint() const { return hint_; }
void set_hint(const QString& hint);
void clear_hint() { set_hint(QString()); }
void paintEvent(QPaintEvent* e);
void set_text(const QString&);
QString text() const;
void set_focus() {}
void set_enabled(bool enabled);
signals:
void textChanged(const QString& text);
void textEdited(const QString& text);
private:
// Called by NSSearchFieldCell when the text changes.
void TextChanged(const QString& text);
QString hint_;
friend class SearchTargetWrapper;
SearchTargetWrapper* wrapper_;
};
#endif // MACLINEEDIT_H

View File

@@ -0,0 +1,140 @@
/* This file is part of Clementine.
Copyright 2010, David Sansome <me@davidsansome.com>
Clementine is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Clementine is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with Clementine. If not, see <http://www.gnu.org/licenses/>.
*/
#include "maclineedit.h"
#import <Foundation/NSAutoreleasePool.h>
#include <QtDebug>
@interface SearchTarget : NSObject {
SearchTargetWrapper* wrapper_;
}
- (id) initWithWrapper: (SearchTargetWrapper*)wrapper;
- (void) action;
@end
class SearchTargetWrapper {
public:
explicit SearchTargetWrapper(NSSearchField* search, MacLineEdit* lineedit);
void TextChanged();
QString text() const;
void setText(const QString& text);
void SetHint(const QString& hint);
void SetEnabled(bool enabled);
private:
NSSearchField* search_;
SearchTarget* target_;
MacLineEdit* lineedit_;
};
@implementation SearchTarget
- (id) initWithWrapper: (SearchTargetWrapper*)wrapper {
wrapper_ = wrapper;
return self;
}
- (void) action {
wrapper_->TextChanged();
}
@end
SearchTargetWrapper::SearchTargetWrapper(NSSearchField* search, MacLineEdit* lineedit)
: search_(search),
lineedit_(lineedit) {
target_ = [[SearchTarget alloc] initWithWrapper:this];
[[search cell] setSendsWholeSearchString:true];
[[search cell] setTarget:target_];
[[search cell] setAction:@selector(action)];
}
void SearchTargetWrapper::TextChanged() {
NSString* text = [[search_ cell] stringValue];
lineedit_->TextChanged(QString::fromUtf8([text UTF8String]));
}
QString SearchTargetWrapper::text() const {
NSString* text = [[search_ cell] stringValue];
return QString::fromUtf8([text UTF8String]);
}
void SearchTargetWrapper::setText(const QString& text) {
NSString* t = [[NSString alloc] initWithUTF8String:text.toUtf8().constData()];
[[search_ cell] setStringValue:t];
[t release];
}
void SearchTargetWrapper::SetHint(const QString& hint) {
NSString* t = [[NSString alloc] initWithUTF8String:hint.toUtf8().constData()];
[[search_ cell] setPlaceholderString:t];
[t release];
}
void SearchTargetWrapper::SetEnabled(bool enabled) {
[search_ setEnabled:enabled];
}
MacLineEdit::MacLineEdit(QWidget* parent)
: QMacCocoaViewContainer(0, parent),
LineEditInterface(this) {
NSAutoreleasePool* pool = [[NSAutoreleasePool alloc] init];
NSSearchField* search = [[NSSearchField alloc] init];
setCocoaView(search);
wrapper_ = new SearchTargetWrapper(search, this);
[search release];
[pool release]; // Pool's closed.
}
MacLineEdit::~MacLineEdit() {
delete wrapper_;
}
void MacLineEdit::paintEvent(QPaintEvent* e) {
QMacCocoaViewContainer::paintEvent(e);
}
void MacLineEdit::TextChanged(const QString& text) {
emit textChanged(text);
emit textEdited(text);
}
QString MacLineEdit::text() const {
return wrapper_->text();
}
void MacLineEdit::set_text(const QString& text) {
wrapper_->setText(text);
}
void MacLineEdit::set_enabled(bool enabled) {
wrapper_->SetEnabled(enabled);
}
void MacLineEdit::set_hint(const QString& hint) {
wrapper_->SetHint(hint);
}

View File

@@ -65,6 +65,9 @@
#ifdef Q_OS_WIN32
#include <qtsparkle/Updater>
#endif
#ifdef Q_OS_MAC
#include "widgets/maclineedit.h"
#endif
#include "utils/logger.h"
@@ -210,35 +213,49 @@ TomahawkWindow::setupSideBar()
ui->splitter->setHandleWidth( 1 );
ui->actionShowOfflineSources->setChecked( TomahawkSettings::instance()->showOfflineSources() );
}
void
TomahawkWindow::setupToolBar()
{
m_searchBox = new QWidget();
m_searchWidget->setupUi( m_searchBox );
QToolBar* toolbar = addToolBar( "TomahawkToolbar" );
toolbar->setObjectName( "TomahawkToolbar" );
toolbar->setMovable( false );
toolbar->setFloatable( false );
toolbar->setIconSize( QSize( 32, 32 ) );
toolbar->setIconSize( QSize( 28, 28 ) );
toolbar->setToolButtonStyle( Qt::ToolButtonFollowStyle );
toolbar->installEventFilter( new WidgetDragFilter( toolbar ) );
toolbar->setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Minimum );
m_backAvailable = toolbar->addAction( QIcon( RESPATH "images/back.png" ), tr( "Back" ), ViewManager::instance(), SLOT( historyBack() ) );
m_backAvailable->setToolTip( tr( "Go back one page" ) );
m_forwardAvailable = toolbar->addAction( QIcon( RESPATH "images/forward.png" ), tr( "Forward" ), ViewManager::instance(), SLOT( historyForward() ) );
m_forwardAvailable->setToolTip( tr( "Go forward one page" ) );
m_searchBox = new QWidget( toolbar );
#ifdef Q_OS_MAC
QWidget *spacerWidget = new QWidget( this );
spacerWidget->setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Preferred );
spacerWidget->setVisible( true );
toolbar->addWidget( spacerWidget );
m_searchBox->setLayout( new QHBoxLayout() );
MacLineEdit* lineEdit = new MacLineEdit( m_searchBox );
lineEdit->setFixedSize( 256, 28 );
lineEdit->set_hint( tr( "Search" ) );
m_searchBox->layout()->addWidget( lineEdit );
connect( lineEdit, SIGNAL( textChanged( QString ) ), SLOT( onSearch( QString ) ) );
#else
m_searchWidget->setupUi( m_searchBox );
m_searchWidget->searchEdit->setStyleSheet( "QLineEdit { border: 1px solid gray; border-radius: 6px; margin-right: 2px; }" );
#ifdef Q_WS_MAC
m_searchWidget->searchEdit->setAttribute( Qt::WA_MacShowFocusRect, 0 );
connect( m_searchWidget->searchEdit, SIGNAL( returnPressed() ), SLOT( onFilterEdited() ) );
#endif
connect( m_searchWidget->searchEdit, SIGNAL( returnPressed() ), SLOT( onSearch() ) );
toolbar->addWidget( m_searchBox );
}
@@ -677,9 +694,16 @@ TomahawkWindow::checkForUpdates()
void
TomahawkWindow::onSearch()
TomahawkWindow::onSearch( const QString& search )
{
ViewManager::instance()->show( new SearchWidget( m_searchWidget->searchEdit->text(), this ) );
ViewManager::instance()->show( new SearchWidget( search, this ) );
}
void
TomahawkWindow::onFilterEdited()
{
onSearch( m_searchWidget->searchEdit->text() );
m_searchWidget->searchEdit->clear();
}

View File

@@ -93,7 +93,8 @@ private slots:
void onSipPluginAdded( SipPlugin* p );
void onSipPluginRemoved( SipPlugin* p );
void onSearch();
void onSearch( const QString& search );
void onFilterEdited();
void minimize();
void maximize();