/* * Copyright 2021 Michail Vourlakos * * This file is part of Latte-Dock * * Latte-Dock 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. * * Latte-Dock 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 this program. If not, see . * */ #include "viewsmodel.h" // local #include #include "../../screenpool.h" #include "../../data/genericdata.h" #include "../../data/screendata.h" // KDE #include #define TEMPIDDISPLAY "#" namespace Latte { namespace Settings { namespace Model { Views::Views(QObject *parent, Latte::Corona *corona) : QAbstractTableModel(parent), m_corona(corona) { initEdges(); initAlignments(); populateScreens(); } Views::~Views() { } bool Views::hasChangedData() const { return o_viewsTable != m_viewsTable; } int Views::rowCount() const { return m_viewsTable.rowCount(); } int Views::columnCount() { return LASTCOLUMN; } int Views::rowCount(const QModelIndex &parent) const { Q_UNUSED(parent); return m_viewsTable.rowCount(); } int Views::columnCount(const QModelIndex &parent) const { Q_UNUSED(parent); return columnCount(); } int Views::rowForId(const QString &id) const { return m_viewsTable.indexOf(id); } const Latte::Data::View &Views::at(const int &row) { return m_viewsTable[row]; } const Latte::Data::View Views::currentData(const QString &id) { if (!m_viewsTable.containsId(id)) { return Latte::Data::View(); } return m_viewsTable[id]; } const Latte::Data::View Views::originalData(const QString &id) { if (o_viewsTable.containsId(id)){ return o_viewsTable[id]; } return Latte::Data::View(); } const Latte::Data::ViewsTable &Views::currentViewsData() { return m_viewsTable; } const Latte::Data::ViewsTable &Views::originalViewsData() { return o_viewsTable; } int Views::sortingFactorForState(const Data::View &view) const { if (view.isActive) { return 1; } else if (view.state() == Data::View::IsCreated) { return 2; } //! temp case return 3; } int Views::sortingFactorForScreen(const Data::View &view) const { if (view.onPrimary) { return 1; } //! explicit screen return 2; } int Views::sortingFactorForEdge(const Data::View &view) const { if (view.edge == Plasma::Types::TopEdge) { return 1; } else if (view.edge == Plasma::Types::LeftEdge) { return 2; } else if (view.edge == Plasma::Types::BottomEdge) { return 3; } //! Right edge return 4; } int Views::sortingFactorForAlignment(const Data::View &view) const { if (view.alignment == Latte::Types::Top || view.alignment == Latte::Types::Left) { return 1; } else if (view.alignment == Latte::Types::Center) { return 2; } else if (view.alignment == Latte::Types::Bottom || view.alignment == Latte::Types::Right) { return 3; } //! Justify alignment return 4; } int Views::sortingFactorForSubContainments(const Data::View &view) const { return view.subcontainments.rowCount()+1; } QString Views::sortableText(const int &priority, const QString &text) const { QString numberPart; if (priority < 10) { numberPart = "00000" + QString::number(priority); } else if (priority < 100) { numberPart = "0000" + QString::number(priority); } else if (priority < 1000) { numberPart = "000" + QString::number(priority); } else if (priority < 10000) { numberPart = "00" + QString::number(priority); } else if (priority < 100000) { numberPart = "0" + QString::number(priority); } return (numberPart + text); } void Views::clear() { if (m_viewsTable.rowCount() > 0) { beginRemoveRows(QModelIndex(), 0, m_viewsTable.rowCount() - 1); m_viewsTable.clear(); endRemoveRows(); } } void Views::initEdges() { s_edges.clear(); int i=0; s_edges << Data::View(QString::number(Plasma::Types::TopEdge), i18nc("top edge", "Top")); s_edges[i].edge = Plasma::Types::TopEdge; s_edges[i].alignment = Latte::Types::Center; i++; s_edges << Data::View(QString::number(Plasma::Types::LeftEdge), i18nc("left edge", "Left")); s_edges[i].edge = Plasma::Types::LeftEdge; s_edges[i].alignment = Latte::Types::Center; i++; s_edges << Data::View(QString::number(Plasma::Types::BottomEdge), i18nc("bottom edge", "Bottom")); s_edges[i].edge = Plasma::Types::BottomEdge; s_edges[i].alignment = Latte::Types::Center; i++; s_edges << Data::View(QString::number(Plasma::Types::RightEdge), i18nc("right edge", "Right")); s_edges[i].edge = Plasma::Types::RightEdge; s_edges[i].alignment = Latte::Types::Center; } void Views::initAlignments() { s_horizontalAlignments.clear(); s_verticalAlignments.clear(); int i=0; // Left / Top s_horizontalAlignments << Data::View(QString::number(Latte::Types::Left), i18nc("left alignment", "Left")); s_horizontalAlignments[i].edge = Plasma::Types::BottomEdge; s_horizontalAlignments[i].alignment = Latte::Types::Left; s_verticalAlignments << Data::View(QString::number(Latte::Types::Top), i18nc("top alignment", "Top")); s_verticalAlignments[i].edge = Plasma::Types::LeftEdge; s_verticalAlignments[i].alignment = Latte::Types::Top; i++; // Center s_horizontalAlignments << Data::View(QString::number(Latte::Types::Center), i18nc("center alignment", "Center")); s_horizontalAlignments[i].edge = Plasma::Types::BottomEdge; s_horizontalAlignments[i].alignment = Latte::Types::Center; s_verticalAlignments << s_horizontalAlignments[1]; s_verticalAlignments[i].edge = Plasma::Types::LeftEdge; i++; // Right / Bottom s_horizontalAlignments << Data::View(QString::number(Latte::Types::Right), i18nc("right alignment", "Right")); s_horizontalAlignments[i].edge = Plasma::Types::BottomEdge; s_horizontalAlignments[i].alignment = Latte::Types::Right; s_verticalAlignments << Data::View(QString::number(Latte::Types::Bottom), i18nc("bottom alignment", "Bottom")); s_verticalAlignments[i].edge = Plasma::Types::LeftEdge; s_verticalAlignments[i].alignment = Latte::Types::Bottom; i++; // Justify s_horizontalAlignments << Data::View(QString::number(Latte::Types::Justify), i18nc("justify alignment", "Justify")); s_horizontalAlignments[i].edge = Plasma::Types::BottomEdge; s_horizontalAlignments[i].alignment = Latte::Types::Justify; s_verticalAlignments << s_horizontalAlignments[3]; s_verticalAlignments[i].edge = Plasma::Types::LeftEdge; } Data::ViewsTable Views::edgesChoices(const Data::View &view) const { Data::ViewsTable t_edges = s_edges; if (view.alignment == Latte::Types::Left) { t_edges[0].alignment = view.alignment; t_edges[1].alignment = Latte::Types::Top; t_edges[2].alignment = view.alignment; t_edges[3].alignment = Latte::Types::Top; } else if (view.alignment == Latte::Types::Top) { t_edges[0].alignment = Latte::Types::Left; t_edges[1].alignment = view.alignment; t_edges[2].alignment = Latte::Types::Left; t_edges[3].alignment = view.alignment; } else if (view.alignment == Latte::Types::Center || view.alignment == Latte::Types::Justify) { t_edges[0].alignment = view.alignment; t_edges[1].alignment = view.alignment; t_edges[2].alignment = view.alignment; t_edges[3].alignment = view.alignment; } else if (view.alignment == Latte::Types::Right) { t_edges[0].alignment = view.alignment; t_edges[1].alignment = Latte::Types::Bottom; t_edges[2].alignment = view.alignment; t_edges[3].alignment = Latte::Types::Bottom; } else if (view.alignment == Latte::Types::Bottom) { t_edges[0].alignment = Latte::Types::Right; t_edges[1].alignment = view.alignment; t_edges[2].alignment = Latte::Types::Right; t_edges[3].alignment = view.alignment; } t_edges[0].screenEdgeMargin = view.screenEdgeMargin; t_edges[1].screenEdgeMargin = view.screenEdgeMargin; t_edges[2].screenEdgeMargin = view.screenEdgeMargin; t_edges[3].screenEdgeMargin = view.screenEdgeMargin; return t_edges; } Data::ViewsTable Views::horizontalAlignmentChoices(const Data::View &view) const { Data::ViewsTable t_horizontalAlignments = s_horizontalAlignments; t_horizontalAlignments[0].edge = view.edge; t_horizontalAlignments[1].edge = view.edge; t_horizontalAlignments[2].edge = view.edge; t_horizontalAlignments[3].edge = view.edge; t_horizontalAlignments[0].screenEdgeMargin = view.screenEdgeMargin; t_horizontalAlignments[1].screenEdgeMargin = view.screenEdgeMargin; t_horizontalAlignments[2].screenEdgeMargin = view.screenEdgeMargin; t_horizontalAlignments[3].screenEdgeMargin = view.screenEdgeMargin; return t_horizontalAlignments; } Data::ViewsTable Views::verticalAlignmentChoices(const Data::View &view) const { Data::ViewsTable t_verticalAlignments = s_verticalAlignments; t_verticalAlignments[0].edge = view.edge; t_verticalAlignments[1].edge = view.edge; t_verticalAlignments[2].edge = view.edge; t_verticalAlignments[3].edge = view.edge; t_verticalAlignments[0].screenEdgeMargin = view.screenEdgeMargin; t_verticalAlignments[1].screenEdgeMargin = view.screenEdgeMargin; t_verticalAlignments[2].screenEdgeMargin = view.screenEdgeMargin; t_verticalAlignments[3].screenEdgeMargin = view.screenEdgeMargin; return t_verticalAlignments; } bool Views::containsCurrentName(const QString &name) const { return m_viewsTable.containsName(name); } void Views::resetData() { clear(); setOriginalData(o_viewsTable); } void Views::appendTemporaryView(const Latte::Data::View &view) { //int newRow = m_layoutsTable.sortedPosForName(layout.name); beginInsertRows(QModelIndex(), m_viewsTable.rowCount(), m_viewsTable.rowCount()); m_viewsTable.appendTemporaryView(view); endInsertRows(); emit rowsInserted(); } void Views::removeView(const QString &id) { int index = m_viewsTable.indexOf(id); if (index >= 0) { removeRows(index, 1); emit rowsRemoved(); } } bool Views::removeRows(int row, int count, const QModelIndex &parent) { Q_UNUSED(parent) int firstRow = row; int lastRow = row+count-1; if (count > 0 && m_viewsTable.rowExists(firstRow) && (m_viewsTable.rowExists(lastRow))) { beginRemoveRows(QModelIndex(), firstRow, lastRow); for(int i=0; i roles; roles << Qt::DisplayRole; roles << Qt::UserRole; roles << ISCHANGEDROLE; roles << ISACTIVEROLE; roles << HASCHANGEDVIEWROLE; for (int i=0; iviewForContainment(viewid); bool currentactivestate = (view != nullptr); if (currentactivestate != m_viewsTable[i].isActive) { m_viewsTable[i].isActive = currentactivestate; emit dataChanged(this->index(i, IDCOLUMN), this->index(i, SUBCONTAINMENTSCOLUMN), roles); } } } Latte::Data::Screen Views::screenData(const QString &viewId) const { int row = rowForId(viewId); if (row < 0) { return Latte::Data::Screen(); } QString primaryid = QString::number(m_corona->screenPool()->primaryScreenId()); QString explicitid = QString::number(m_viewsTable[row].screen); if (m_viewsTable[row].onPrimary && s_screens.containsId(primaryid)) { return s_screens[primaryid]; } else if (!m_viewsTable[row].onPrimary && s_screens.containsId(explicitid)) { return s_screens[explicitid]; } return Latte::Data::Screen(); } Latte::Data::ViewsTable Views::alteredViews() const { Latte::Data::ViewsTable views; for(int i=0; i roles; roles << Qt::DisplayRole; roles << Qt::UserRole; roles << ERRORSROLE; roles << WARNINGSROLE; emit dataChanged(this->index(0, IDCOLUMN), this->index(m_viewsTable.rowCount()-1, SUBCONTAINMENTSCOLUMN), roles); } void Views::populateScreens() { s_screens.clear(); Data::Screen primary(QString::number(Data::Screen::ONPRIMARYID), i18nc("primary screen", " - Follow Primary Screen - ")); primary.isActive = true; s_screens << primary; s_screens << m_corona->screenPool()->screensTable(); for (int i=1; iscreenPool()->isScreenActive(s_screens[i].id.toInt()); } } void Views::updateCurrentView(QString currentViewId, Latte::Data::View &view) { if (!m_viewsTable.containsId(currentViewId)) { return; } int currentrow = m_viewsTable.indexOf(currentViewId); m_viewsTable[currentrow] = view; QVector roles; roles << Qt::DisplayRole; roles << Qt::UserRole; roles << ISCHANGEDROLE; roles << ISACTIVEROLE; roles << HASCHANGEDVIEWROLE; roles << ISMOVEORIGINROLE; roles << ERRORSROLE; roles << WARNINGSROLE; emit dataChanged(this->index(currentrow, IDCOLUMN), this->index(currentrow, SUBCONTAINMENTSCOLUMN), roles); } void Views::setOriginalView(QString currentViewId, Latte::Data::View &view) { if (!m_viewsTable.containsId(currentViewId)) { return; } int currentrow = m_viewsTable.indexOf(currentViewId); o_viewsTable << view; m_viewsTable[currentrow] = view; QVector roles; roles << Qt::DisplayRole; roles << Qt::UserRole; roles << ISCHANGEDROLE; roles << ISACTIVEROLE; roles << HASCHANGEDVIEWROLE; emit dataChanged(this->index(currentrow, IDCOLUMN), this->index(currentrow, SUBCONTAINMENTSCOLUMN), roles); } void Views::setOriginalData(Latte::Data::ViewsTable &data) { clear(); beginInsertRows(QModelIndex(), 0, data.rowCount() - 1); o_viewsTable = data; m_viewsTable = data; endInsertRows(); emit rowsInserted(); } QVariant Views::headerData(int section, Qt::Orientation orientation, int role) const { if (orientation != Qt::Horizontal) { return QAbstractTableModel::headerData(section, orientation, role); } if (role == Qt::FontRole) { QFont font = qvariant_cast(QAbstractTableModel::headerData(section, orientation, role)); font.setBold(true); return font; } switch(section) { case IDCOLUMN: if (role == Qt::DisplayRole) { return QString("#"); } break; case NAMECOLUMN: if (role == Qt::DisplayRole) { return QString(i18n("Name")); } break; case SCREENCOLUMN: if (role == Qt::DisplayRole) { return QString(i18n("Screen")); } /* } else if (role == Qt::DecorationRole) { return QIcon::fromTheme("desktop"); }*/ break; case EDGECOLUMN: if (role == Qt::DisplayRole) { return QString(i18nc("screen edge", "Edge")); } /* } else if (role == Qt::DecorationRole) { return QIcon::fromTheme("transform-move"); }*/ break; case ALIGNMENTCOLUMN: if (role == Qt::DisplayRole) { return QString(i18n("Alignment")); } /*} else if (role == Qt::DecorationRole) { return QIcon::fromTheme("format-justify-center"); }*/ break; case SUBCONTAINMENTSCOLUMN: if (role == Qt::DisplayRole) { return QString(i18n("Includes")); } default: break; }; return QAbstractTableModel::headerData(section, orientation, role); } Qt::ItemFlags Views::flags(const QModelIndex &index) const { const int column = index.column(); const int row = index.row(); auto flags = QAbstractTableModel::flags(index); if (column == NAMECOLUMN || column == SCREENCOLUMN || column == EDGECOLUMN || column == ALIGNMENTCOLUMN) { flags |= Qt::ItemIsEditable; } return flags; } bool Views::setData(const QModelIndex &index, const QVariant &value, int role) { const int row = index.row(); const int column = index.column(); if (!m_viewsTable.rowExists(row) || column<0 || column >= SUBCONTAINMENTSCOLUMN) { return false; } QVector roles; roles << role; roles << ISCHANGEDROLE; roles << HASCHANGEDVIEWROLE; roles << SORTINGROLE; if (role != Qt::DisplayRole) { roles << Qt::DisplayRole; } //! specific roles to each independent cell switch (column) { case NAMECOLUMN: if (role == Qt::UserRole || role == Qt::EditRole) { if (m_viewsTable[row].name == value.toString()) { return false; } m_viewsTable[row].name = value.toString(); emit dataChanged(index, index, roles); } break; case SCREENCOLUMN: if (role == Qt::UserRole) { int screen = value.toString().toInt(); bool onprimary = (screen == Latte::Data::Screen::ONPRIMARYID); if ((m_viewsTable[row].onPrimary == onprimary) && (m_viewsTable[row].screen == screen)) { return false; } if (onprimary) { m_viewsTable[row].onPrimary = true; if (o_viewsTable.containsId(m_viewsTable[row].id)) { //! we need to update screen also in order to not show that there are changes even though //! they are not any m_viewsTable[row].screen = o_viewsTable[m_viewsTable[row].id].screen; } } else { m_viewsTable[row].onPrimary = false; m_viewsTable[row].screen = screen; } emit dataChanged(this->index(row, NAMECOLUMN), this->index(row, ALIGNMENTCOLUMN), roles); } break; case EDGECOLUMN: if (role == Qt::UserRole) { Plasma::Types::Location edge = static_cast(value.toString().toInt()); if (m_viewsTable[row].edge == edge) { return false; } Plasma::Types::Location previousEdge = m_viewsTable[row].edge; m_viewsTable[row].edge = edge; emit dataChanged(index, index, roles); bool previousFactor = isVertical(previousEdge); bool currentFactor = isVertical(edge); if (previousFactor != currentFactor) { if (m_viewsTable[row].alignment == Latte::Types::Left) { m_viewsTable[row].alignment = Latte::Types::Top; } else if (m_viewsTable[row].alignment == Latte::Types::Right) { m_viewsTable[row].alignment = Latte::Types::Bottom; } else if (m_viewsTable[row].alignment == Latte::Types::Top) { m_viewsTable[row].alignment = Latte::Types::Left; } else if (m_viewsTable[row].alignment == Latte::Types::Bottom) { m_viewsTable[row].alignment = Latte::Types::Right; } emit dataChanged(this->index(row, NAMECOLUMN), this->index(row, ALIGNMENTCOLUMN), roles); } return true; } break; case ALIGNMENTCOLUMN: if (role == Qt::UserRole) { int alignment = value.toString().toInt(); if (m_viewsTable[row].alignment == alignment) { return false; } m_viewsTable[row].alignment = static_cast(alignment); emit dataChanged(this->index(row, NAMECOLUMN), this->index(row, ALIGNMENTCOLUMN), roles); return true; } break; }; return false; } QVariant Views::data(const QModelIndex &index, int role) const { const int row = index.row(); int column = index.column(); //bool isNewLayout = !o_layoutsTable.containsId(m_layoutsTable[row].id); if (!m_viewsTable.rowExists(row)) { return QVariant{}; } bool isNewView = !o_viewsTable.containsId(m_viewsTable[row].id); QString origviewid = !isNewView ? m_viewsTable[row].id : ""; if (role == IDROLE) { return (m_viewsTable[row].state() == Data::View::IsCreated ? m_viewsTable[row].id : "#"); } else if (role == ISACTIVEROLE) { return m_viewsTable[row].isActive; } else if (role == CHOICESROLE) { if (column == SCREENCOLUMN) { QVariant screensVariant; Latte::Data::ScreensTable currentScreens = s_screens; if (!m_viewsTable[row].onPrimary && !currentScreens.containsId(QString::number(m_viewsTable[row].screen))) { Data::Screen explicitScr(QString::number(m_viewsTable[row].screen), i18nc("unknown screen", "Unknown : [%1]", explicitScr.id)); currentScreens.insertBasedOnId(explicitScr); } screensVariant.setValue(currentScreens); return screensVariant; } else if (column == EDGECOLUMN) { QVariant edgesVariant; edgesVariant.setValue(edgesChoices(m_viewsTable[row])); return edgesVariant; } else if (column == ALIGNMENTCOLUMN) { QVariant alignmentsVariant; if (isVertical(m_viewsTable[row].edge)) { alignmentsVariant.setValue(verticalAlignmentChoices(m_viewsTable[row])); } else { alignmentsVariant.setValue(horizontalAlignmentChoices(m_viewsTable[row])); } return alignmentsVariant; } } else if (role == HASCHANGEDVIEWROLE) { return (isNewView || (m_viewsTable[row] != o_viewsTable[origviewid])); } else if (role == SCREENROLE) { QVariant scrVariant; Latte::Data::Screen scrdata = screenData(m_viewsTable[row].id); scrVariant.setValue(scrdata); return scrVariant; } else if (role == VIEWROLE) { QVariant viewVariant; viewVariant.setValue(m_viewsTable[row]); return viewVariant; } else if (role == ISMOVEORIGINROLE) { return m_viewsTable[row].isMoveOrigin; } else if (role == ERRORSROLE) { return m_viewsTable[row].errors; } else if (role == WARNINGSROLE) { return m_viewsTable[row].warnings; } if (role == Qt::TextAlignmentRole && column != NAMECOLUMN){ return static_cast(Qt::AlignHCenter | Qt::AlignVCenter); } switch (column) { case IDCOLUMN: if (role == Qt::DisplayRole){ return (m_viewsTable[row].state() == Data::View::IsCreated ? m_viewsTable[row].id : "#"); } else if (role == Qt::UserRole) { return m_viewsTable[row].id; } else if (role == ISCHANGEDROLE) { return (isNewView || (m_viewsTable[row].id != o_viewsTable[origviewid].id)); } else if (role == SORTINGROLE) { int fsta = sortingFactorForState(m_viewsTable[row]); int fscr = sortingFactorForScreen(m_viewsTable[row]); int fedg = sortingFactorForEdge(m_viewsTable[row]); int fali = sortingFactorForAlignment(m_viewsTable[row]); int priority = (fsta * HIGHESTPRIORITY); return sortableText(priority, m_viewsTable[row].id); } break; case NAMECOLUMN: if (role == Qt::DisplayRole || role == Qt::UserRole || role == Qt::EditRole){ return m_viewsTable[row].name; } else if (role == ISCHANGEDROLE) { return (isNewView || (m_viewsTable[row].name != o_viewsTable[origviewid].name)); } else if (role == SORTINGROLE) { int fsta = sortingFactorForState(m_viewsTable[row]); int fscr = sortingFactorForScreen(m_viewsTable[row]); int fedg = sortingFactorForEdge(m_viewsTable[row]); int fali = sortingFactorForAlignment(m_viewsTable[row]); int priority = (fsta * HIGHESTPRIORITY); return sortableText(priority, m_viewsTable[row].name); } break; case SCREENCOLUMN: if (role == Qt::DisplayRole){ if (m_viewsTable[row].onPrimary) { return QString("Primary"); } else { QString scrId = QString::number(m_viewsTable[row].screen); if (s_screens.containsId(scrId)) { return s_screens[scrId].name; } else { return i18nc("unknown screen", "Unknown : [%1]", scrId); } } } else if (role == Qt::UserRole) { return m_viewsTable[row].onPrimary ? QString::number(Data::Screen::ONPRIMARYID) : QString::number(m_viewsTable[row].screen); } else if (role == ISCHANGEDROLE) { return (isNewView || (m_viewsTable[row].onPrimary != o_viewsTable[origviewid].onPrimary) || (!m_viewsTable[row].onPrimary && m_viewsTable[row].screen != o_viewsTable[origviewid].screen)); } else if (role == SORTINGROLE) { int fsta = sortingFactorForState(m_viewsTable[row]); int fscr = sortingFactorForScreen(m_viewsTable[row]); int fedg = sortingFactorForEdge(m_viewsTable[row]); int fali = sortingFactorForAlignment(m_viewsTable[row]); int priority = (fsta * HIGHESTPRIORITY) + (fscr * HIGHPRIORITY) + (fedg * MEDIUMPRIORITY) + (fali * NORMALPRIORITY); return priority; } break; case EDGECOLUMN: if (role == Qt::DisplayRole){ if (m_viewsTable[row].edge == Plasma::Types::BottomEdge) { return QString("Bottom"); } else if (m_viewsTable[row].edge == Plasma::Types::TopEdge) { return QString("Top"); } else if (m_viewsTable[row].edge == Plasma::Types::LeftEdge) { return QString("Left"); } else if (m_viewsTable[row].edge == Plasma::Types::RightEdge) { return QString("Right"); } return QString("Unknown"); } else if (role == Qt::UserRole) { return QString::number(m_viewsTable[row].edge); } else if (role == ISCHANGEDROLE) { return (isNewView || (m_viewsTable[row].edge != o_viewsTable[origviewid].edge)); } else if (role == SORTINGROLE) { int fsta = sortingFactorForState(m_viewsTable[row]); int fscr = sortingFactorForScreen(m_viewsTable[row]); int fedg = sortingFactorForEdge(m_viewsTable[row]); int fali = sortingFactorForAlignment(m_viewsTable[row]); int priority = (fsta * HIGHESTPRIORITY) + (fedg * HIGHPRIORITY) + (fscr * MEDIUMPRIORITY) + (fali * NORMALPRIORITY); return priority; } break; case ALIGNMENTCOLUMN: if (role == Qt::DisplayRole){ if (m_viewsTable[row].alignment == Latte::Types::Center) { return QString("Center"); } else if (m_viewsTable[row].alignment == Latte::Types::Left) { return QString("Left"); } else if (m_viewsTable[row].alignment == Latte::Types::Right) { return QString("Right"); } else if (m_viewsTable[row].alignment == Latte::Types::Top) { return QString("Top"); } else if (m_viewsTable[row].alignment == Latte::Types::Bottom) { return QString("Bottom"); } else if (m_viewsTable[row].alignment == Latte::Types::Justify) { return QString("Justify"); } return QString("Unknown"); } else if (role == Qt::UserRole) { return QString::number(m_viewsTable[row].alignment); } else if (role == ISCHANGEDROLE) { return (isNewView || (m_viewsTable[row].alignment != o_viewsTable[origviewid].alignment)); } else if (role == SORTINGROLE) { int fsta = sortingFactorForState(m_viewsTable[row]); int fscr = sortingFactorForScreen(m_viewsTable[row]); int fedg = sortingFactorForEdge(m_viewsTable[row]); int fali = sortingFactorForAlignment(m_viewsTable[row]); int priority = (fsta * HIGHESTPRIORITY) + (fali * HIGHPRIORITY) + (fscr * MEDIUMPRIORITY) + (fedg * NORMALPRIORITY); return priority; } break; case SUBCONTAINMENTSCOLUMN: if (role == Qt::DisplayRole){ if (m_viewsTable[row].subcontainments.rowCount()>0) { QString result = "{"; for (int i=0; i0) { result += " "; } result += (m_viewsTable[row].state() == Data::View::IsCreated ? m_viewsTable[row].subcontainments[i].id : TEMPIDDISPLAY); if (i