/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /*************************************************************************** * lineedit.cc * * Fri Jul 13 12:38:45 CEST 2007 * Copyright 2007 Bent Bisballe Nyeng and Lars Bisballe Jensen * deva@aasimon.org and elsenator@gmail.com ****************************************************************************/ /* * This file is part of Pracro. * * Pracro 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. * * Pracro 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 Pracro; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. */ #include "lineedit.h" #include <stdio.h> #include <QCoreApplication> #include <QLineEdit> #include <QEvent> #include <QKeyEvent> #include "common.h" #include "debug.h" LineEdit::LineEdit(QDomNode &node, MacroWindow *macrowindow) : Widget(node, macrowindow) { lineedit = new QLineEdit(); widget = lineedit; setCommonAttributes(lineedit, node); QDomElement elem = node.toElement(); if(elem.hasAttribute("readonly")) { if(elem.attribute("readonly") == "true" || elem.attribute("readonly") == "1") { lineedit->setReadOnly(true); } else if(elem.attribute("readonly") == "false" || elem.attribute("readonly") == "0") { lineedit->setReadOnly(false); } else { printf("Unknown value of readonly: %s\n", elem.attribute("readonly").toStdString().c_str()); } } connect(lineedit, SIGNAL(textChanged(QString)), this, SLOT(changed())); connect(lineedit, SIGNAL(textEdited(QString)), this, SLOT(user_changed())); lineedit->installEventFilter(this); // Detect keyboard input. } LineEdit::~LineEdit() { // delete lineedit; } void LineEdit::changed() { emit eventOnChange(); } void LineEdit::user_changed() { emit eventOnChange(); emit wasChanged(); } QString LineEdit::value() { return lineedit->text(); } void LineEdit::setValue(QString value, QString source) { if(isUserSource(source)) emit wasChanged(); // Hack to make sure the textChanged signal is emitted. if(lineedit->text() == value) lineedit->setText(value + " "); lineedit->setText(value); // setInitialValue(value); } bool LineEdit::eventFilter(QObject *, QEvent *event) { if(event->type() == QEvent::KeyPress) { QKeyEvent *keyEvent = static_cast<QKeyEvent *>(event); if(keyEvent->key() == Qt::Key_Return || keyEvent->key() == Qt::Key_Enter) { QKeyEvent tabevent(QEvent::KeyPress, Qt::Key_Tab, Qt::NoModifier); QCoreApplication::sendEvent(lineedit, &tabevent); } } return false; } void LineEdit::changeEvent(QEvent *event) { if(event->type() == QEvent::EnabledChange) { changed(); } } void LineEdit::setWdgValid(bool valid) { DEBUG(lineedit, "Set valid(%s)\n", valid?"true":"false"); QPalette palette; if(valid) { // valid string palette.setBrush(QPalette::Base, QBrush(QColor(255, 255, 255))); } else { // invalid string palette.setBrush(QPalette::Base, QBrush(QColor(230, 200, 200))); } lineedit->setPalette(palette); }