/* -*- 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;
}