/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /*************************************************************************** * textedit.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 "textedit.h" #include <QPalette> #include <stdio.h> #include "common.h" TextEdit::TextEdit(QDomNode &node, MacroWindow *macrowindow) : QTextEdit(), 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()), this, SLOT(changed())); installEventFilter(this); // Detect keyboard input. } void TextEdit::changed() { QPalette palette; 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))); } setPalette(palette); } QString TextEdit::getValue() { return QTextEdit::toPlainText(); } void TextEdit::setValue(QString value, QString source) { if(isUserSource(source)) emit wasChanged(); setText(value); setInitialValue(value); } bool TextEdit::eventFilter(QObject *, QEvent *event) { if (event->type() == QEvent::KeyPress) { QKeyEvent *keyEvent = static_cast<QKeyEvent *>(event); if(keyEvent->text() != "") emit wasChanged(); } return false; } void TextEdit::connectFrom(const char *signal, const QObject *receiver, const char *method) { connect(this, signal, receiver, method); } void TextEdit::connectTo(const QObject *sender, const char *signal, const char *method) { connect(sender, signal, this, method); } bool TextEdit::setKeyboardFocus() { setFocus(); return true; } void TextEdit::setVisibility(bool visible) { setVisible(visible); } void TextEdit::enable() { setEnabled(true); } void TextEdit::disable() { setEnabled(false); } bool TextEdit::isDisabled() { return isEnabled() == false; }