You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdepim/kalarm/lib/checkbox.cpp

134 lines
3.5 KiB

/*
* checkbox.cpp - check box with read-only option
* Program: kalarm
* Copyright (c) 2002, 2003 by David Jarvie <software@astrojar.org.uk>
*
* 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.
*/
#include "checkbox.moc"
CheckBox::CheckBox(TQWidget* tqparent, const char* name)
: TQCheckBox(tqparent, name),
mFocusPolicy(focusPolicy()),
mFocusWidget(0),
mReadOnly(false)
{ }
CheckBox::CheckBox(const TQString& text, TQWidget* tqparent, const char* name)
: TQCheckBox(text, tqparent, name),
mFocusPolicy(focusPolicy()),
mFocusWidget(0),
mReadOnly(false)
{ }
/******************************************************************************
* Set the read-only status. If read-only, the checkbox can be toggled by the
* application, but not by the user.
*/
void CheckBox::setReadOnly(bool ro)
{
if ((int)ro != (int)mReadOnly)
{
mReadOnly = ro;
setFocusPolicy(ro ? TQWidget::NoFocus : mFocusPolicy);
if (ro)
clearFocus();
}
}
/******************************************************************************
* Specify a widget to receive focus when the checkbox is clicked on.
*/
void CheckBox::setFocusWidget(TQWidget* w, bool enable)
{
mFocusWidget = w;
mFocusWidgetEnable = enable;
if (w)
connect(this, TQT_SIGNAL(clicked()), TQT_SLOT(slotClicked()));
else
disconnect(this, TQT_SIGNAL(clicked()), this, TQT_SLOT(slotClicked()));
}
/******************************************************************************
* Called when the checkbox is clicked.
* If it is now checked, focus is transferred to any specified focus widget.
*/
void CheckBox::slotClicked()
{
if (mFocusWidget && isChecked())
{
if (mFocusWidgetEnable)
mFocusWidget->setEnabled(true);
mFocusWidget->setFocus();
}
}
/******************************************************************************
* Event handlers to intercept events if in read-only mode.
* Any events which could change the checkbox state are discarded.
*/
void CheckBox::mousePressEvent(TQMouseEvent* e)
{
if (mReadOnly)
{
// Swallow up the event if it's the left button
if (e->button() == TQt::LeftButton)
return;
}
TQCheckBox::mousePressEvent(e);
}
void CheckBox::mouseReleaseEvent(TQMouseEvent* e)
{
if (mReadOnly)
{
// Swallow up the event if it's the left button
if (e->button() == TQt::LeftButton)
return;
}
TQCheckBox::mouseReleaseEvent(e);
}
void CheckBox::mouseMoveEvent(TQMouseEvent* e)
{
if (!mReadOnly)
TQCheckBox::mouseMoveEvent(e);
}
void CheckBox::keyPressEvent(TQKeyEvent* e)
{
if (mReadOnly)
switch (e->key())
{
case TQt::Key_Up:
case TQt::Key_Left:
case TQt::Key_Right:
case TQt::Key_Down:
// Process keys which shift the focus
break;
default:
return;
}
TQCheckBox::keyPressEvent(e);
}
void CheckBox::keyReleaseEvent(TQKeyEvent* e)
{
if (!mReadOnly)
TQCheckBox::keyReleaseEvent(e);
}