/* -*- 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 "common.h" LineEdit::LineEdit(QDomNode &node, MacroWindow *macrowindow) : QLineEdit(), Widget(node, macrowindow) { setCommonAttributes(this, node); QDomElement elem = node.toElement(); if(elem.hasAttribute("readonly")) { if(elem.attribute("readonly") == "true" || elem.attribute("readonly") == "1") { setReadOnly(true); } else if(elem.attribute("readonly") == "false" || elem.attribute("readonly") == "0") { setReadOnly(false); } else { printf("Unknown value of readonly: %s\n", elem.attribute("readonly").toStdString().c_str()); } } connect(this, SIGNAL(textChanged(QString)), this, SLOT(changed())); connect(this, SIGNAL(textEdited(QString)), this, SLOT(user_changed())); installEventFilter(this); // Detect keyboard input. } void LineEdit::changed() { QPalette palette; if(isEnabled()) { if(regexpValidator()) { if(luaValidator()) { // valid string palette.setBrush(QPalette::Base, QBrush(QColor(255, 255, 255))); } else { // invalid string palette.setBrush(QPalette::Base, QBrush(QColor(200, 230, 200))); } } else { // invalid string palette.setBrush(QPalette::Base, QBrush(QColor(230, 200, 200))); } } else { // valid string palette.setBrush(QPalette::Base, QBrush(QColor(255, 255, 255))); } setPalette(palette); } void LineEdit::user_changed() { emit wasChanged(); } QString LineEdit::getValue() { return text(); } void LineEdit::setValue(QString value, QString source) { if(isUserSource(source)) emit wasChanged(); if(text() == value) setText(value + " "); // Hack to make sure the textChanged signal is emitted. setText(value); setInitialValue(value); } void LineEdit::enable() { setEnabled(true); } void LineEdit::disable() { setEnabled(false); } bool LineEdit::isDisabled() { return isEnabled() == false; } void LineEdit::connectFrom(const char *signal, const QObject *receiver, const char *method) { connect(this, signal, receiver, method); } void LineEdit::connectTo(const QObject *sender, const char *signal, const char *method) { connect(sender, signal, this, method); } bool LineEdit::setKeyboardFocus() { setFocus(); return true; } void LineEdit::setVisibility(bool visible) { setVisible(visible); } #include <QCoreApplication> bool LineEdit::eventFilter(QObject *, QEvent *event) { if (event->type() == QEvent::KeyPress) { QKeyEvent *keyEvent = static_cast<QKeyEvent *>(event); if(keyEvent->key() == Qt::Key_Return) { QKeyEvent tabevent(QEvent::KeyPress, Qt::Key_Tab, Qt::NoModifier); QCoreApplication::sendEvent(this, &tabevent); } } return false; } void LineEdit::changeEvent(QEvent *event) { if(event->type() == QEvent::EnabledChange) { changed(); } }