2016-03-19 06:57:51 +13:00
|
|
|
|
|
|
|
|
|
|
|
#include "toonzqt/tmessageviewer.h"
|
|
|
|
#include "toonzqt/dvdialog.h"
|
|
|
|
#include <QVBoxLayout>
|
|
|
|
#include <QPushButton>
|
|
|
|
#include <QListView>
|
|
|
|
#include <QStandardItemModel>
|
|
|
|
#include <QSortFilterProxyModel>
|
|
|
|
#include <QCheckBox>
|
|
|
|
#include <QLabel>
|
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
namespace {
|
2016-03-19 06:57:51 +13:00
|
|
|
|
|
|
|
QIcon gRedIcon;
|
|
|
|
QIcon gGreenIcon;
|
|
|
|
QIcon gYellowIcon;
|
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
|
|
|
|
2016-06-29 18:17:12 +12:00
|
|
|
class MyQListView final : public QListView {
|
2016-03-19 06:57:51 +13:00
|
|
|
public:
|
2016-06-15 18:43:10 +12:00
|
|
|
MyQListView(QWidget *parent) : QListView(parent) {}
|
2016-03-19 06:57:51 +13:00
|
|
|
|
|
|
|
protected:
|
2016-06-19 20:06:29 +12:00
|
|
|
void rowsInserted(const QModelIndex &parent, int start, int end) override {
|
2016-06-15 18:43:10 +12:00
|
|
|
QListView::rowsInserted(parent, start, end);
|
|
|
|
scrollToBottom();
|
|
|
|
}
|
2016-03-19 06:57:51 +13:00
|
|
|
};
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------------
|
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
} // namespace
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-29 18:17:12 +12:00
|
|
|
class MySortFilterProxyModel final : public QSortFilterProxyModel {
|
2016-03-19 06:57:51 +13:00
|
|
|
public:
|
2016-06-15 18:43:10 +12:00
|
|
|
MySortFilterProxyModel(QObject *parent) : QSortFilterProxyModel(parent) {}
|
|
|
|
|
2016-06-20 14:23:05 +12:00
|
|
|
bool filterAcceptsRow(int sourceRow,
|
|
|
|
const QModelIndex &sourceParent) const override {
|
2016-06-15 18:43:10 +12:00
|
|
|
TMessageViewer *v = dynamic_cast<TMessageViewer *>(parent());
|
|
|
|
assert(v);
|
|
|
|
|
|
|
|
QIcon ic = ((QStandardItemModel *)sourceModel())->item(sourceRow)->icon();
|
|
|
|
if (ic.cacheKey() == gGreenIcon.cacheKey())
|
|
|
|
return v->m_greenCheck->isChecked();
|
|
|
|
else if (ic.cacheKey() == gYellowIcon.cacheKey())
|
|
|
|
return v->m_yellowCheck->isChecked();
|
|
|
|
else if (ic.cacheKey() == gRedIcon.cacheKey())
|
|
|
|
return v->m_redCheck->isChecked();
|
|
|
|
else
|
|
|
|
return true;
|
|
|
|
}
|
2016-03-19 06:57:51 +13:00
|
|
|
};
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------------
|
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
void TMessageViewer::onClicked(bool) {
|
|
|
|
TMessageRepository::instance()->clear();
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
/*return;
|
|
|
|
static int count=0;
|
|
|
|
count++;
|
|
|
|
DVGui::MsgBox((count%3)==1?INFORMATION:(count%3)==2?WARNING:CRITICAL,
|
|
|
|
"messaggio "+QString::number(count));*/
|
2016-03-19 06:57:51 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
//-----------------------------------------------------------
|
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
void TMessageViewer::refreshFilter(int) { m_proxyModel->invalidate(); }
|
2016-03-19 06:57:51 +13:00
|
|
|
|
|
|
|
//---------------------------------------------------
|
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
void TMessageRepository::clear() { m_sim->clear(); }
|
2016-03-19 06:57:51 +13:00
|
|
|
|
|
|
|
//---------------------------------------------------
|
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
TMessageRepository::TMessageRepository() : m_sim(new QStandardItemModel()) {}
|
2016-03-19 06:57:51 +13:00
|
|
|
|
|
|
|
//---------------------------------------------------
|
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
TMessageRepository *TMessageRepository::instance() {
|
|
|
|
static TMessageRepository *theObject = 0;
|
|
|
|
if (theObject == 0) {
|
|
|
|
theObject = new TMessageRepository();
|
|
|
|
bool ret =
|
|
|
|
connect(TMsgCore::instance(), SIGNAL(sendMessage(int, const QString &)),
|
|
|
|
theObject, SLOT(messageReceived(int, const QString &)));
|
|
|
|
assert(ret);
|
|
|
|
// TMsgCore::instance()->getConnectionName();
|
|
|
|
}
|
|
|
|
return theObject;
|
2016-03-19 06:57:51 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------
|
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
void TMessageRepository::messageReceived(int type, const QString &message) {
|
|
|
|
if (gRedIcon.isNull()) {
|
2017-08-18 19:24:14 +12:00
|
|
|
gRedIcon = QIcon(":Resources/tmsg_error.svg");
|
|
|
|
gYellowIcon = QIcon(":Resources/tmsg_warning.svg");
|
|
|
|
gGreenIcon = QIcon(":Resources/tmsg_info.svg");
|
2016-06-15 18:43:10 +12:00
|
|
|
}
|
|
|
|
|
|
|
|
switch (type) {
|
|
|
|
case DVGui::INFORMATION:
|
|
|
|
m_sim->appendRow(new QStandardItem(gGreenIcon, message));
|
|
|
|
break;
|
|
|
|
case DVGui::WARNING:
|
|
|
|
m_sim->appendRow(new QStandardItem(gYellowIcon, message));
|
|
|
|
break;
|
|
|
|
case DVGui::CRITICAL:
|
|
|
|
m_sim->appendRow(new QStandardItem(gRedIcon, message));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (type == DVGui::CRITICAL ||
|
|
|
|
(type == DVGui::WARNING && !TMessageViewer::isTMsgVisible()))
|
|
|
|
DVGui::MsgBoxInPopup(DVGui::MsgType(type), message);
|
2016-03-19 06:57:51 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------
|
|
|
|
|
2016-04-19 19:32:17 +12:00
|
|
|
std::vector<TMessageViewer *> TMessageViewer::m_tmsgViewers;
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
bool TMessageViewer::isTMsgVisible() {
|
|
|
|
for (int i = 0; i < (int)m_tmsgViewers.size(); i++)
|
|
|
|
if (m_tmsgViewers[i]->isVisible()) return true;
|
|
|
|
return false;
|
2016-03-19 06:57:51 +13:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------
|
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
TMessageViewer::TMessageViewer(QWidget *parent) : QFrame(parent) {
|
|
|
|
m_tmsgViewers.push_back(this);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
bool ret = true;
|
|
|
|
setFrameStyle(QFrame::StyledPanel);
|
|
|
|
setObjectName("OnePixelMarginFrame");
|
|
|
|
QVBoxLayout *vLayout = new QVBoxLayout();
|
|
|
|
vLayout->setMargin(0);
|
|
|
|
QFrame *fr = new QFrame();
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
QHBoxLayout *hLayout = new QHBoxLayout();
|
|
|
|
hLayout->setMargin(0);
|
|
|
|
fr->setLayout(hLayout);
|
|
|
|
fr->setFixedHeight(24);
|
2017-12-01 01:26:47 +13:00
|
|
|
fr->setStyleSheet("background-color: rgb(210,210,210); color: black;");
|
2016-06-15 18:43:10 +12:00
|
|
|
hLayout->addSpacing(4);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2017-12-01 01:26:47 +13:00
|
|
|
hLayout->addWidget(new QLabel(tr("Display: ")));
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
m_redCheck = new QCheckBox(tr("Errors"));
|
|
|
|
m_redCheck->setChecked(true);
|
|
|
|
ret = ret && connect(m_redCheck, SIGNAL(stateChanged(int)),
|
|
|
|
SLOT(refreshFilter(int)));
|
|
|
|
hLayout->addWidget(m_redCheck);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
m_yellowCheck = new QCheckBox(tr("Warnings"));
|
|
|
|
m_yellowCheck->setChecked(true);
|
|
|
|
ret = ret && connect(m_yellowCheck, SIGNAL(stateChanged(int)),
|
|
|
|
SLOT(refreshFilter(int)));
|
|
|
|
hLayout->addWidget(m_yellowCheck);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2017-12-01 17:54:44 +13:00
|
|
|
m_greenCheck = new QCheckBox(tr("Info"));
|
2016-06-15 18:43:10 +12:00
|
|
|
m_greenCheck->setChecked(true);
|
|
|
|
ret = ret && connect(m_greenCheck, SIGNAL(stateChanged(int)),
|
|
|
|
SLOT(refreshFilter(int)));
|
|
|
|
hLayout->addWidget(m_greenCheck);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
hLayout->addStretch();
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
QPushButton *pb = new QPushButton(tr(" Clear "));
|
|
|
|
ret = ret && connect(pb, SIGNAL(clicked(bool)), SLOT(onClicked(bool)));
|
|
|
|
hLayout->addWidget(pb);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
hLayout->addSpacing(4);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
vLayout->addWidget(fr);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
MyQListView *lv = new MyQListView(this);
|
|
|
|
lv->setAlternatingRowColors(true);
|
|
|
|
lv->setEditTriggers(QAbstractItemView::NoEditTriggers);
|
|
|
|
lv->setAutoScroll(true);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
m_proxyModel = new MySortFilterProxyModel(this);
|
|
|
|
m_proxyModel->setDynamicSortFilter(true);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
m_proxyModel->setSourceModel(TMessageRepository::instance()->getModel());
|
|
|
|
lv->setModel(m_proxyModel);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
vLayout->addWidget(lv);
|
|
|
|
setLayout(vLayout);
|
2016-03-19 06:57:51 +13:00
|
|
|
|
2016-06-15 18:43:10 +12:00
|
|
|
assert(ret);
|
2016-03-19 06:57:51 +13:00
|
|
|
}
|