// qtractorPluginForm.h
//
/****************************************************************************
   Copyright (C) 2005-2010, rncbc aka Rui Nuno Capela. All rights reserved.

   This program 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 2
   of the License, or (at your option) any later version.

   This program 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 this program; if not, write to the Free Software Foundation, Inc.,
   51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.

*****************************************************************************/

#ifndef __qtractorPluginForm_h
#define __qtractorPluginForm_h

#include "ui_qtractorPluginForm.h"

#include <QFrame>


// Forward declarations...
class qtractorPlugin;
class qtractorPluginParam;
class qtractorPluginParamWidget;

class qtractorSlider;

class QLabel;
class QCheckBox;
class QGridLayout;
class QDoubleSpinBox;


//----------------------------------------------------------------------------
// qtractorPluginForm -- UI wrapper form.

class qtractorPluginForm : public QWidget
{
	Q_OBJECT

public:

	// Constructor.
	qtractorPluginForm(QWidget *pParent = 0, Qt::WindowFlags wflags = 0);
	// Destructor.
	~qtractorPluginForm();

	void setPlugin(qtractorPlugin *pPlugin);
	qtractorPlugin *plugin() const;

	void setPreset(const QString& sPreset);
	QString preset() const;

	void updateCaption();
	void updateActivated();

	void updateParamValue(unsigned long iIndex, float fValue, bool bUpdate);
	void updateParamWidget(unsigned long iIndex);

	void activateForm();

	void refresh();
	void clear();

	void toggleEditor(bool bOn);

signals:

	// Change notification.
	void valueChanged(qtractorPluginParam *, float, bool);

protected slots:

	void changePresetSlot(const QString& sPreset);
	void loadPresetSlot(const QString& sPreset);
	void openPresetSlot();
	void savePresetSlot();
	void deletePresetSlot();
	void paramsSlot(bool bOn);
	void editSlot(bool bOn);
	void sendsSlot();
	void returnsSlot();
	void activateSlot(bool bOn);
	void valueChangeSlot(
		qtractorPluginParam *pParam, float fValue, bool bUpdate);

protected:

	void stabilize();

	// Show insert pseudo-plugin audio bus connections.
	void insertPluginBus(int iBusMode);

private:

	// The Qt-designer UI struct...
	Ui::qtractorPluginForm m_ui;

	// Instance variables...
	qtractorPlugin *m_pPlugin;
	QGridLayout *m_pGridLayout;
	QList<qtractorPluginParamWidget *> m_paramWidgets;
	int m_iDirtyCount;
	int m_iUpdate;
};


//----------------------------------------------------------------------------
// qtractorPluginParamWidget -- Plugin port widget.
//

class qtractorPluginParamWidget : public QFrame
{
	Q_OBJECT

public:

	// Constructor.
	qtractorPluginParamWidget(qtractorPluginParam *pParam,
		QWidget *pParent = NULL);

	// Main properties accessors.
	qtractorPluginParam *param() const
		{ return m_pParam; }

	// Refreshner-loader method.
	void refresh();

signals:

	// Change notification.
	void valueChanged(qtractorPluginParam *, float, bool);

protected slots:

	// Change slots.
	void checkBoxToggled(bool);
	void spinBoxValueChanged(const QString&);
	void sliderValueChanged(int);

protected:

	// Slider conversion methods.
	int   paramToSlider(float fValue) const;
	float sliderToParam(int iValue) const;

	// Spin-box decimals helper.
	int   paramDecs() const;

private:

	// Instance variables.
	qtractorPluginParam *m_pParam;

	// Some basic layout managers.
	QGridLayout    *m_pGridLayout;

	// Some possible managed widgets.
	QLabel         *m_pLabel;
	QCheckBox      *m_pCheckBox;
	qtractorSlider *m_pSlider;
	QDoubleSpinBox *m_pSpinBox;
	QLabel         *m_pDisplay;

	// Avoid cascaded intra-notifications.
	int m_iUpdate;
};


#endif	// __qtractorPluginForm_h


// end of qtractorPluginForm.h
