X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROGUI%2FHYDROGUI_InputPanel.cxx;h=f89653dbe2039ba7eadd9bce4077d48502704648;hb=7f56fcbfed23a9fd09b7ab87edd7ec742e2725e6;hp=a20c755bcfb3d782e399589d54e65d6deae0892f;hpb=a502bc91af765db8df39ed99c321af63631ec2c4;p=modules%2Fhydro.git diff --git a/src/HYDROGUI/HYDROGUI_InputPanel.cxx b/src/HYDROGUI/HYDROGUI_InputPanel.cxx index a20c755b..f89653db 100644 --- a/src/HYDROGUI/HYDROGUI_InputPanel.cxx +++ b/src/HYDROGUI/HYDROGUI_InputPanel.cxx @@ -1,12 +1,8 @@ -// Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE -// -// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, -// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS -// +// Copyright (C) 2014-2015 EDF-R&D // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either -// version 2.1 of the License. +// version 2.1 of the License, or (at your option) any later version. // // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of @@ -28,9 +24,9 @@ #include #include -#include +#include -HYDROGUI_InputPanel::HYDROGUI_InputPanel( HYDROGUI_Module* theModule, const QString& theTitle ) +HYDROGUI_InputPanel::HYDROGUI_InputPanel( HYDROGUI_Module* theModule, const QString& theTitle, bool doInitLayout ) : QDockWidget( theModule->application()->desktop() ), myModule( theModule ) { @@ -38,37 +34,41 @@ HYDROGUI_InputPanel::HYDROGUI_InputPanel( HYDROGUI_Module* theModule, const QStr setWindowTitle( theTitle ); setAllowedAreas( Qt::RightDockWidgetArea ); + QFrame* aFrame = new QFrame( this ); setWidget( aFrame ); QVBoxLayout* aLayout = new QVBoxLayout( aFrame ); myMainFrame = new QFrame( aFrame ); - QVBoxLayout* aMainLayout = new QVBoxLayout( myMainFrame ); + QBoxLayout* aMainLayout = new QVBoxLayout( myMainFrame ); aMainLayout->setMargin( 0 ); aMainLayout->setSpacing( 5 ); - - myStackedLayout = new QStackedLayout(); + + aLayout->addWidget( myMainFrame, 1 ); myBtnFrame = new QFrame( aFrame ); - activateWidget( myBtnFrame ); - - aLayout->addWidget( myMainFrame, 3 ); - aLayout->addLayout( myStackedLayout, 1 ); + aLayout->addWidget( myBtnFrame, 0 ); QHBoxLayout* aBtnsLayout = new QHBoxLayout( myBtnFrame ); aBtnsLayout->setMargin( 5 ); aBtnsLayout->setSpacing( 5 ); - myApply = new QPushButton( tr( "APPLY" ), myBtnFrame ); - myCancel = new QPushButton( tr( "CANCEL" ), myBtnFrame ); + myCancel = new QPushButton( tr( "CLOSE" ), myBtnFrame ); myHelp = new QPushButton( tr( "HELP" ), myBtnFrame ); - aBtnsLayout->addWidget( myApply, 0 ); - aBtnsLayout->addWidget( myCancel, 0 ); - aBtnsLayout->addStretch( 1 ); - aBtnsLayout->addWidget( myHelp, 0 ); + if ( doInitLayout ) { + myApplyAndClose = new QPushButton( tr( "APPLY_AND_CLOSE" ), myBtnFrame ); + myApply = new QPushButton( tr( "APPLY" ), myBtnFrame ); + + aBtnsLayout->addWidget( myApplyAndClose, 0 ); + aBtnsLayout->addWidget( myApply, 0 ); + aBtnsLayout->addWidget( myCancel, 0 ); + aBtnsLayout->addStretch( 1 ); + aBtnsLayout->addWidget( myHelp, 0 ); - connect( myApply, SIGNAL( clicked() ), this, SLOT( onApply() ) ); + connect( myApplyAndClose, SIGNAL( clicked() ), this, SLOT( onApplyAndClose() ) ); + connect( myApply, SIGNAL( clicked() ), this, SLOT( onApply() ) ); + } connect( myCancel, SIGNAL( clicked() ), this, SLOT( onCancel() ) ); connect( myHelp, SIGNAL( clicked() ), this, SLOT( onHelp() ) ); } @@ -82,6 +82,22 @@ HYDROGUI_Module* HYDROGUI_InputPanel::module() const return myModule; } +bool HYDROGUI_InputPanel::isApplyEnabled() const +{ + return myApply->isEnabled(); +} + +void HYDROGUI_InputPanel::setApplyEnabled( bool on ) +{ + myApplyAndClose->setEnabled( on ); + myApply->setEnabled( on ); +} + +void HYDROGUI_InputPanel::onApplyAndClose() +{ + emit panelApplyAndClose(); +} + void HYDROGUI_InputPanel::onApply() { emit panelApply(); @@ -94,12 +110,18 @@ void HYDROGUI_InputPanel::onCancel() void HYDROGUI_InputPanel::onHelp() { + emit panelHelp(); } -void HYDROGUI_InputPanel::addWidget( QWidget* theWidget ) +void HYDROGUI_InputPanel::closeEvent ( QCloseEvent * event ) +{ + emit panelCancel(); +} + +void HYDROGUI_InputPanel::addWidget( QWidget* theWidget, int theStretch ) { QBoxLayout* aMainLayout = dynamic_cast( myMainFrame->layout() ); - aMainLayout->addWidget( theWidget ); + aMainLayout->addWidget( theWidget, theStretch ); } void HYDROGUI_InputPanel::addLayout( QLayout* theLayout ) @@ -119,14 +141,7 @@ QFrame* HYDROGUI_InputPanel::mainFrame() const return myMainFrame; } -void HYDROGUI_InputPanel::activateWidget( QWidget* theWidget ) +QFrame* HYDROGUI_InputPanel::buttonFrame() const { - if (theWidget == 0) { - myStackedLayout->setCurrentIndex( 0 ); - } - else { - if ( myStackedLayout->indexOf( theWidget ) == -1 ) - myStackedLayout->addWidget( theWidget ); - myStackedLayout->setCurrentWidget( theWidget ); - } + return myBtnFrame; }