removed exception list handling from separate dialog. Use a different tab instead
svn path=/trunk/KDE/kdebase/workspace/; revision=1017451
This commit is contained in:
parent
ffb68de1ac
commit
1b7acbc6bb
2 changed files with 53 additions and 40 deletions
|
@ -1,5 +1,5 @@
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
// nitrogenexceptionlistdialog.cpp
|
// NitrogenExceptionListWidget.cpp
|
||||||
// -------------------
|
// -------------------
|
||||||
//
|
//
|
||||||
// Copyright (c) 2009 Hugo Pereira Da Costa <hugo.pereira@free.fr>
|
// Copyright (c) 2009 Hugo Pereira Da Costa <hugo.pereira@free.fr>
|
||||||
|
@ -28,34 +28,27 @@
|
||||||
#include <KMessageBox>
|
#include <KMessageBox>
|
||||||
|
|
||||||
#include "nitrogenexceptiondialog.h"
|
#include "nitrogenexceptiondialog.h"
|
||||||
#include "nitrogenexceptionlistdialog.h"
|
#include "nitrogenexceptionlistwidget.h"
|
||||||
#include "nitrogenexceptionlistdialog.moc"
|
#include "nitrogenexceptionlistwidget.moc"
|
||||||
|
|
||||||
//__________________________________________________________
|
//__________________________________________________________
|
||||||
namespace Nitrogen
|
namespace Nitrogen
|
||||||
{
|
{
|
||||||
|
|
||||||
//__________________________________________________________
|
//__________________________________________________________
|
||||||
NitrogenExceptionListDialog::NitrogenExceptionListDialog( QWidget* parent, NitrogenConfiguration default_configuration ):
|
NitrogenExceptionListWidget::NitrogenExceptionListWidget( QWidget* parent, NitrogenConfiguration default_configuration ):
|
||||||
KDialog( parent ),
|
QWidget( parent ),
|
||||||
default_configuration_( default_configuration )
|
default_configuration_( default_configuration )
|
||||||
{
|
{
|
||||||
|
|
||||||
// define buttons
|
|
||||||
setButtons( Ok|Cancel );
|
|
||||||
|
|
||||||
// main widget
|
|
||||||
QWidget* widget = new QWidget( this );
|
|
||||||
setMainWidget( widget );
|
|
||||||
|
|
||||||
// layout
|
// layout
|
||||||
QHBoxLayout* h_layout = new QHBoxLayout();
|
QHBoxLayout* h_layout = new QHBoxLayout();
|
||||||
h_layout->setMargin(0);
|
h_layout->setMargin(4);
|
||||||
h_layout->setSpacing(5);
|
h_layout->setSpacing(4);
|
||||||
widget->setLayout( h_layout );
|
setLayout( h_layout );
|
||||||
|
|
||||||
// list
|
// list
|
||||||
h_layout->addWidget( list_ = new QTreeView( widget ) );
|
h_layout->addWidget( list_ = new QTreeView( this ) );
|
||||||
_list().setAllColumnsShowFocus( true );
|
_list().setAllColumnsShowFocus( true );
|
||||||
_list().setRootIsDecorated( false );
|
_list().setRootIsDecorated( false );
|
||||||
_list().setSortingEnabled( false );
|
_list().setSortingEnabled( false );
|
||||||
|
@ -71,23 +64,23 @@ namespace Nitrogen
|
||||||
|
|
||||||
v_layout->addWidget( up_button_ = new KPushButton(
|
v_layout->addWidget( up_button_ = new KPushButton(
|
||||||
KIcon( "arrow-up", icon_loader ),
|
KIcon( "arrow-up", icon_loader ),
|
||||||
i18n("Move &Up"), widget ) );
|
i18n("Move &Up"), this ) );
|
||||||
|
|
||||||
v_layout->addWidget( down_button_ = new KPushButton(
|
v_layout->addWidget( down_button_ = new KPushButton(
|
||||||
KIcon( "arrow-down", icon_loader ),
|
KIcon( "arrow-down", icon_loader ),
|
||||||
i18n("Move &Down"), widget ) );
|
i18n("Move &Down"), this ) );
|
||||||
|
|
||||||
v_layout->addWidget( add_button_ = new KPushButton(
|
v_layout->addWidget( add_button_ = new KPushButton(
|
||||||
KIcon( "list-add", icon_loader ),
|
KIcon( "list-add", icon_loader ),
|
||||||
i18n("&Add"), widget ) );
|
i18n("&Add"), this ) );
|
||||||
|
|
||||||
v_layout->addWidget( remove_button_ = new KPushButton(
|
v_layout->addWidget( remove_button_ = new KPushButton(
|
||||||
KIcon( "list-remove", icon_loader ),
|
KIcon( "list-remove", icon_loader ),
|
||||||
i18n("&Remove"), widget ) );
|
i18n("&Remove"), this ) );
|
||||||
|
|
||||||
v_layout->addWidget( edit_button_ = new KPushButton(
|
v_layout->addWidget( edit_button_ = new KPushButton(
|
||||||
KIcon( "edit-rename", icon_loader ),
|
KIcon( "edit-rename", icon_loader ),
|
||||||
i18n("&Edit"), widget ) );
|
i18n("&Edit"), this ) );
|
||||||
|
|
||||||
v_layout->addStretch();
|
v_layout->addStretch();
|
||||||
|
|
||||||
|
@ -101,7 +94,6 @@ namespace Nitrogen
|
||||||
connect( &_list(), SIGNAL( clicked( const QModelIndex& ) ), SLOT( _toggle( const QModelIndex& ) ) );
|
connect( &_list(), SIGNAL( clicked( const QModelIndex& ) ), SLOT( _toggle( const QModelIndex& ) ) );
|
||||||
connect( _list().selectionModel(), SIGNAL( selectionChanged(const QItemSelection &, const QItemSelection &) ), SLOT( _updateButtons() ) );
|
connect( _list().selectionModel(), SIGNAL( selectionChanged(const QItemSelection &, const QItemSelection &) ), SLOT( _updateButtons() ) );
|
||||||
|
|
||||||
resize( 500, 250 );
|
|
||||||
_updateButtons();
|
_updateButtons();
|
||||||
_resizeColumns();
|
_resizeColumns();
|
||||||
|
|
||||||
|
@ -109,14 +101,14 @@ namespace Nitrogen
|
||||||
}
|
}
|
||||||
|
|
||||||
//__________________________________________________________
|
//__________________________________________________________
|
||||||
void NitrogenExceptionListDialog::setExceptions( const NitrogenExceptionList& exceptions )
|
void NitrogenExceptionListWidget::setExceptions( const NitrogenExceptionList& exceptions )
|
||||||
{
|
{
|
||||||
_model().set( NitrogenExceptionModel::List( exceptions.begin(), exceptions.end() ) );
|
_model().set( NitrogenExceptionModel::List( exceptions.begin(), exceptions.end() ) );
|
||||||
_resizeColumns();
|
_resizeColumns();
|
||||||
}
|
}
|
||||||
|
|
||||||
//__________________________________________________________
|
//__________________________________________________________
|
||||||
NitrogenExceptionList NitrogenExceptionListDialog::exceptions( void ) const
|
NitrogenExceptionList NitrogenExceptionListWidget::exceptions( void ) const
|
||||||
{
|
{
|
||||||
|
|
||||||
NitrogenExceptionModel::List exceptions( _model().get() );
|
NitrogenExceptionModel::List exceptions( _model().get() );
|
||||||
|
@ -128,7 +120,7 @@ namespace Nitrogen
|
||||||
}
|
}
|
||||||
|
|
||||||
//__________________________________________________________
|
//__________________________________________________________
|
||||||
void NitrogenExceptionListDialog::_updateButtons( void )
|
void NitrogenExceptionListWidget::_updateButtons( void )
|
||||||
{
|
{
|
||||||
|
|
||||||
bool has_selection( !_list().selectionModel()->selectedRows().empty() );
|
bool has_selection( !_list().selectionModel()->selectedRows().empty() );
|
||||||
|
@ -142,7 +134,7 @@ namespace Nitrogen
|
||||||
|
|
||||||
|
|
||||||
//_______________________________________________________
|
//_______________________________________________________
|
||||||
void NitrogenExceptionListDialog::_add( void )
|
void NitrogenExceptionListWidget::_add( void )
|
||||||
{
|
{
|
||||||
|
|
||||||
// map dialog
|
// map dialog
|
||||||
|
@ -166,12 +158,13 @@ namespace Nitrogen
|
||||||
}
|
}
|
||||||
|
|
||||||
_resizeColumns();
|
_resizeColumns();
|
||||||
|
emit changed();
|
||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//_______________________________________________________
|
//_______________________________________________________
|
||||||
void NitrogenExceptionListDialog::_edit( void )
|
void NitrogenExceptionListWidget::_edit( void )
|
||||||
{
|
{
|
||||||
|
|
||||||
// retrieve selection
|
// retrieve selection
|
||||||
|
@ -188,27 +181,37 @@ namespace Nitrogen
|
||||||
if( dialog.exec() == QDialog::Rejected ) return;
|
if( dialog.exec() == QDialog::Rejected ) return;
|
||||||
NitrogenException new_exception = dialog.exception();
|
NitrogenException new_exception = dialog.exception();
|
||||||
|
|
||||||
if( !_checkException( new_exception ) ) return;
|
// check if exception was changed
|
||||||
*&exception = new_exception;
|
if( exception == new_exception ) return;
|
||||||
|
|
||||||
|
// check new exception validity
|
||||||
|
if( !_checkException( new_exception ) ) return;
|
||||||
|
|
||||||
|
// asign new exception
|
||||||
|
*&exception = new_exception;
|
||||||
_resizeColumns();
|
_resizeColumns();
|
||||||
|
emit changed();
|
||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//_______________________________________________________
|
//_______________________________________________________
|
||||||
void NitrogenExceptionListDialog::_remove( void )
|
void NitrogenExceptionListWidget::_remove( void )
|
||||||
{
|
{
|
||||||
|
|
||||||
|
// shoud use a konfirmation dialog
|
||||||
|
if( KMessageBox::questionYesNo( this, i18n("Remove selected exception ?") ) == KMessageBox::No ) return;
|
||||||
|
|
||||||
// remove
|
// remove
|
||||||
_model().remove( _model().get( _list().selectionModel()->selectedRows() ) );
|
_model().remove( _model().get( _list().selectionModel()->selectedRows() ) );
|
||||||
_resizeColumns();
|
_resizeColumns();
|
||||||
|
emit changed();
|
||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//_______________________________________________________
|
//_______________________________________________________
|
||||||
void NitrogenExceptionListDialog::_toggle( const QModelIndex& index )
|
void NitrogenExceptionListWidget::_toggle( const QModelIndex& index )
|
||||||
{
|
{
|
||||||
|
|
||||||
if( !index.isValid() ) return;
|
if( !index.isValid() ) return;
|
||||||
|
@ -219,10 +222,13 @@ namespace Nitrogen
|
||||||
exception.setEnabled( !exception.enabled() );
|
exception.setEnabled( !exception.enabled() );
|
||||||
_model().add( exception );
|
_model().add( exception );
|
||||||
|
|
||||||
|
emit changed();
|
||||||
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//_______________________________________________________
|
//_______________________________________________________
|
||||||
void NitrogenExceptionListDialog::_up( void )
|
void NitrogenExceptionListWidget::_up( void )
|
||||||
{
|
{
|
||||||
|
|
||||||
NitrogenExceptionModel::List selection( _model().get( _list().selectionModel()->selectedRows() ) );
|
NitrogenExceptionModel::List selection( _model().get( _list().selectionModel()->selectedRows() ) );
|
||||||
|
@ -261,12 +267,13 @@ namespace Nitrogen
|
||||||
for( NitrogenExceptionModel::List::const_iterator iter = selected_exceptions.begin(); iter != selected_exceptions.end(); iter++ )
|
for( NitrogenExceptionModel::List::const_iterator iter = selected_exceptions.begin(); iter != selected_exceptions.end(); iter++ )
|
||||||
{ _list().selectionModel()->select( _model().index( *iter ), QItemSelectionModel::Select|QItemSelectionModel::Rows ); }
|
{ _list().selectionModel()->select( _model().index( *iter ), QItemSelectionModel::Select|QItemSelectionModel::Rows ); }
|
||||||
|
|
||||||
|
emit changed();
|
||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//_______________________________________________________
|
//_______________________________________________________
|
||||||
void NitrogenExceptionListDialog::_down( void )
|
void NitrogenExceptionListWidget::_down( void )
|
||||||
{
|
{
|
||||||
|
|
||||||
NitrogenExceptionModel::List selection( _model().get( _list().selectionModel()->selectedRows() ) );
|
NitrogenExceptionModel::List selection( _model().get( _list().selectionModel()->selectedRows() ) );
|
||||||
|
@ -307,12 +314,13 @@ namespace Nitrogen
|
||||||
for( NitrogenExceptionModel::List::const_iterator iter = selected_exceptions.begin(); iter != selected_exceptions.end(); iter++ )
|
for( NitrogenExceptionModel::List::const_iterator iter = selected_exceptions.begin(); iter != selected_exceptions.end(); iter++ )
|
||||||
{ _list().selectionModel()->select( _model().index( *iter ), QItemSelectionModel::Select|QItemSelectionModel::Rows ); }
|
{ _list().selectionModel()->select( _model().index( *iter ), QItemSelectionModel::Select|QItemSelectionModel::Rows ); }
|
||||||
|
|
||||||
|
emit changed();
|
||||||
return;
|
return;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//_______________________________________________________
|
//_______________________________________________________
|
||||||
void NitrogenExceptionListDialog::_resizeColumns( void ) const
|
void NitrogenExceptionListWidget::_resizeColumns( void ) const
|
||||||
{
|
{
|
||||||
_list().resizeColumnToContents( NitrogenExceptionModel::ENABLED );
|
_list().resizeColumnToContents( NitrogenExceptionModel::ENABLED );
|
||||||
_list().resizeColumnToContents( NitrogenExceptionModel::TYPE );
|
_list().resizeColumnToContents( NitrogenExceptionModel::TYPE );
|
||||||
|
@ -320,7 +328,7 @@ namespace Nitrogen
|
||||||
}
|
}
|
||||||
|
|
||||||
//_______________________________________________________
|
//_______________________________________________________
|
||||||
bool NitrogenExceptionListDialog::_checkException( NitrogenException& exception )
|
bool NitrogenExceptionListWidget::_checkException( NitrogenException& exception )
|
||||||
{
|
{
|
||||||
|
|
||||||
while( !exception.regExp().isValid() )
|
while( !exception.regExp().isValid() )
|
|
@ -1,7 +1,7 @@
|
||||||
#ifndef _NitrogenExceptionListDialog_h_
|
#ifndef _NitrogenExceptionListWidget_h_
|
||||||
#define _NitrogenExceptionListDialog_h_
|
#define _NitrogenExceptionListWidget_h_
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
// nitrogenexceptionlistdialog.h
|
// NitrogenExceptionListWidget.h
|
||||||
// -------------------
|
// -------------------
|
||||||
//
|
//
|
||||||
// Copyright (c) 2009 Hugo Pereira Da Costa <hugo.pereira@free.fr>
|
// Copyright (c) 2009 Hugo Pereira Da Costa <hugo.pereira@free.fr>
|
||||||
|
@ -36,7 +36,7 @@
|
||||||
namespace Nitrogen
|
namespace Nitrogen
|
||||||
{
|
{
|
||||||
|
|
||||||
class NitrogenExceptionListDialog: public KDialog
|
class NitrogenExceptionListWidget: public QWidget
|
||||||
{
|
{
|
||||||
|
|
||||||
//! Qt meta object
|
//! Qt meta object
|
||||||
|
@ -45,7 +45,7 @@ namespace Nitrogen
|
||||||
public:
|
public:
|
||||||
|
|
||||||
//! constructor
|
//! constructor
|
||||||
NitrogenExceptionListDialog( QWidget*, NitrogenConfiguration default_configuration = NitrogenConfiguration() );
|
NitrogenExceptionListWidget( QWidget* = 0, NitrogenConfiguration default_configuration = NitrogenConfiguration() );
|
||||||
|
|
||||||
//! set exceptions
|
//! set exceptions
|
||||||
void setExceptions( const NitrogenExceptionList& );
|
void setExceptions( const NitrogenExceptionList& );
|
||||||
|
@ -53,6 +53,11 @@ namespace Nitrogen
|
||||||
//! get exceptions
|
//! get exceptions
|
||||||
NitrogenExceptionList exceptions( void ) const;
|
NitrogenExceptionList exceptions( void ) const;
|
||||||
|
|
||||||
|
signals:
|
||||||
|
|
||||||
|
//! emited when list is changed
|
||||||
|
void changed( void );
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
//! list
|
//! list
|
Loading…
Reference in a new issue