mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 09:56:37 +00:00 
			
		
		
		
	Merge branch 'master' into cc9cii
Conflicts: apps/opencs/model/settings/usersettings.cpp apps/opencs/view/world/dialoguesubview.cpp
This commit is contained in:
		
						commit
						740c8bc6f1
					
				
					 11 changed files with 409 additions and 190 deletions
				
			
		|  | @ -64,7 +64,7 @@ opencs_units (view/world | ||||||
|     table tablesubview scriptsubview util regionmapsubview tablebottombox creator genericcreator |     table tablesubview scriptsubview util regionmapsubview tablebottombox creator genericcreator | ||||||
|     cellcreator referenceablecreator referencecreator scenesubview |     cellcreator referenceablecreator referencecreator scenesubview | ||||||
|     infocreator scriptedit dialoguesubview previewsubview regionmap dragrecordtable nestedtable |     infocreator scriptedit dialoguesubview previewsubview regionmap dragrecordtable nestedtable | ||||||
|     dialoguespinbox |     dialoguespinbox recordbuttonbar | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
| opencs_units_noqt (view/world | opencs_units_noqt (view/world | ||||||
|  |  | ||||||
|  | @ -379,6 +379,14 @@ void CSMSettings::UserSettings::buildSettingModelDefaults() | ||||||
|                 " Other records are filterd out."); |                 " Other records are filterd out."); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     declareSection ("general-input", "General Input"); | ||||||
|  |     { | ||||||
|  |         Setting *cycle = createSetting (Type_CheckBox, "cycle", "Cyclic next/previous"); | ||||||
|  |         cycle->setDefaultValue ("false"); | ||||||
|  |         cycle->setToolTip ("When using next/previous functions at the last/first item of a " | ||||||
|  |             "list go to the first/last item"); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     { |     { | ||||||
|         /******************************************************************
 |         /******************************************************************
 | ||||||
|         * There are three types of values: |         * There are three types of values: | ||||||
|  |  | ||||||
|  | @ -47,6 +47,7 @@ void CSVDoc::SubView::setUniversalId (const CSMWorld::UniversalId& id) | ||||||
| { | { | ||||||
|     mUniversalId = id; |     mUniversalId = id; | ||||||
|     setWindowTitle (QString::fromUtf8(mUniversalId.toString().c_str())); |     setWindowTitle (QString::fromUtf8(mUniversalId.toString().c_str())); | ||||||
|  |     emit universalIdChanged (mUniversalId); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSVDoc::SubView::closeEvent (QCloseEvent *event) | void CSVDoc::SubView::closeEvent (QCloseEvent *event) | ||||||
|  |  | ||||||
|  | @ -68,6 +68,8 @@ namespace CSVDoc | ||||||
| 
 | 
 | ||||||
|             void updateSubViewIndicies (SubView *view = 0); |             void updateSubViewIndicies (SubView *view = 0); | ||||||
| 
 | 
 | ||||||
|  |             void universalIdChanged (const CSMWorld::UniversalId& universalId); | ||||||
|  | 
 | ||||||
|         protected slots: |         protected slots: | ||||||
| 
 | 
 | ||||||
|             void closeRequest(); |             void closeRequest(); | ||||||
|  |  | ||||||
|  | @ -17,8 +17,6 @@ | ||||||
| #include <QLineEdit> | #include <QLineEdit> | ||||||
| #include <QPlainTextEdit> | #include <QPlainTextEdit> | ||||||
| #include <QComboBox> | #include <QComboBox> | ||||||
| #include <QPushButton> |  | ||||||
| #include <QToolButton> |  | ||||||
| #include <QHeaderView> | #include <QHeaderView> | ||||||
| #include <QScrollBar> | #include <QScrollBar> | ||||||
| 
 | 
 | ||||||
|  | @ -40,6 +38,7 @@ | ||||||
| #include "util.hpp" | #include "util.hpp" | ||||||
| #include "tablebottombox.hpp" | #include "tablebottombox.hpp" | ||||||
| #include "nestedtable.hpp" | #include "nestedtable.hpp" | ||||||
|  | #include "recordbuttonbar.hpp" | ||||||
| /*
 | /*
 | ||||||
| ==============================NotEditableSubDelegate========================================== | ==============================NotEditableSubDelegate========================================== | ||||||
| */ | */ | ||||||
|  | @ -574,11 +573,6 @@ CSMWorld::CommandDispatcher& CSVWorld::SimpleDialogueSubView::getCommandDispatch | ||||||
|     return mCommandDispatcher; |     return mCommandDispatcher; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::string CSVWorld::SimpleDialogueSubView::getCurrentId() const |  | ||||||
| { |  | ||||||
|     return mCurrentId; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| CSVWorld::EditWidget& CSVWorld::SimpleDialogueSubView::getEditWidget() | CSVWorld::EditWidget& CSVWorld::SimpleDialogueSubView::getEditWidget() | ||||||
| { | { | ||||||
|     return *mEditWidget; |     return *mEditWidget; | ||||||
|  | @ -594,7 +588,6 @@ CSVWorld::SimpleDialogueSubView::SimpleDialogueSubView (const CSMWorld::Universa | ||||||
|     mEditWidget(0), |     mEditWidget(0), | ||||||
|     mMainLayout(NULL), |     mMainLayout(NULL), | ||||||
|     mTable(dynamic_cast<CSMWorld::IdTable*>(document.getData().getTableModel(id))), |     mTable(dynamic_cast<CSMWorld::IdTable*>(document.getData().getTableModel(id))), | ||||||
|     mUndoStack(document.getUndoStack()), |  | ||||||
|     mLocked(false), |     mLocked(false), | ||||||
|     mDocument(document), |     mDocument(document), | ||||||
|     mCommandDispatcher (document, CSMWorld::UniversalId::getParentType (id.getType())) |     mCommandDispatcher (document, CSMWorld::UniversalId::getParentType (id.getType())) | ||||||
|  | @ -602,7 +595,7 @@ CSVWorld::SimpleDialogueSubView::SimpleDialogueSubView (const CSMWorld::Universa | ||||||
|     connect(mTable, SIGNAL(dataChanged (const QModelIndex&, const QModelIndex&)), this, SLOT(dataChanged(const QModelIndex&))); |     connect(mTable, SIGNAL(dataChanged (const QModelIndex&, const QModelIndex&)), this, SLOT(dataChanged(const QModelIndex&))); | ||||||
|     connect(mTable, SIGNAL(rowsAboutToBeRemoved(const QModelIndex&, int, int)), this, SLOT(rowsAboutToBeRemoved(const QModelIndex&, int, int))); |     connect(mTable, SIGNAL(rowsAboutToBeRemoved(const QModelIndex&, int, int)), this, SLOT(rowsAboutToBeRemoved(const QModelIndex&, int, int))); | ||||||
| 
 | 
 | ||||||
|     changeCurrentId(id.getId()); |     updateCurrentId(); | ||||||
| 
 | 
 | ||||||
|     QWidget *mainWidget = new QWidget(this); |     QWidget *mainWidget = new QWidget(this); | ||||||
| 
 | 
 | ||||||
|  | @ -610,7 +603,7 @@ CSVWorld::SimpleDialogueSubView::SimpleDialogueSubView (const CSMWorld::Universa | ||||||
|     setWidget (mainWidget); |     setWidget (mainWidget); | ||||||
| 
 | 
 | ||||||
|     mEditWidget = new EditWidget(mainWidget, |     mEditWidget = new EditWidget(mainWidget, | ||||||
|             mTable->getModelIndex(mCurrentId, 0).row(), mTable, mCommandDispatcher, document, false); |             mTable->getModelIndex(getUniversalId().getId(), 0).row(), mTable, mCommandDispatcher, document, false); | ||||||
| 
 | 
 | ||||||
|     if (id.getType() == CSMWorld::UniversalId::Type_Referenceable) |     if (id.getType() == CSMWorld::UniversalId::Type_Referenceable) | ||||||
|     { |     { | ||||||
|  | @ -623,16 +616,16 @@ CSVWorld::SimpleDialogueSubView::SimpleDialogueSubView (const CSMWorld::Universa | ||||||
|     mMainLayout->addWidget(mEditWidget); |     mMainLayout->addWidget(mEditWidget); | ||||||
|     mEditWidget->setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding); |     mEditWidget->setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding); | ||||||
| 
 | 
 | ||||||
|     dataChanged(mTable->getModelIndex (mCurrentId, 0)); |     dataChanged(mTable->getModelIndex (getUniversalId().getId(), 0)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSVWorld::SimpleDialogueSubView::setEditLock (bool locked) | void CSVWorld::SimpleDialogueSubView::setEditLock (bool locked) | ||||||
| { | { | ||||||
|     if (!mEditWidget) // hack to indicate that mCurrentId is no longer valid
 |     if (!mEditWidget) // hack to indicate that getUniversalId().getId() is no longer valid
 | ||||||
|         return; |         return; | ||||||
| 
 | 
 | ||||||
|     mLocked = locked; |     mLocked = locked; | ||||||
|     QModelIndex currentIndex(mTable->getModelIndex(mCurrentId, 0)); |     QModelIndex currentIndex(mTable->getModelIndex(getUniversalId().getId(), 0)); | ||||||
| 
 | 
 | ||||||
|     if (currentIndex.isValid()) |     if (currentIndex.isValid()) | ||||||
|     { |     { | ||||||
|  | @ -647,7 +640,7 @@ void CSVWorld::SimpleDialogueSubView::setEditLock (bool locked) | ||||||
| 
 | 
 | ||||||
| void CSVWorld::SimpleDialogueSubView::dataChanged (const QModelIndex & index) | void CSVWorld::SimpleDialogueSubView::dataChanged (const QModelIndex & index) | ||||||
| { | { | ||||||
|     QModelIndex currentIndex(mTable->getModelIndex(mCurrentId, 0)); |     QModelIndex currentIndex(mTable->getModelIndex(getUniversalId().getId(), 0)); | ||||||
| 
 | 
 | ||||||
|     if (currentIndex.isValid() && |     if (currentIndex.isValid() && | ||||||
|             (index.parent().isValid() ? index.parent().row() : index.row()) == currentIndex.row()) |             (index.parent().isValid() ? index.parent().row() : index.row()) == currentIndex.row()) | ||||||
|  | @ -680,7 +673,7 @@ void CSVWorld::SimpleDialogueSubView::dataChanged (const QModelIndex & index) | ||||||
| 
 | 
 | ||||||
| void CSVWorld::SimpleDialogueSubView::rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end) | void CSVWorld::SimpleDialogueSubView::rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end) | ||||||
| { | { | ||||||
|     QModelIndex currentIndex(mTable->getModelIndex(mCurrentId, 0)); |     QModelIndex currentIndex(mTable->getModelIndex(getUniversalId().getId(), 0)); | ||||||
| 
 | 
 | ||||||
|     if (currentIndex.isValid() && currentIndex.row() >= start && currentIndex.row() <= end) |     if (currentIndex.isValid() && currentIndex.row() >= start && currentIndex.row() <= end) | ||||||
|     { |     { | ||||||
|  | @ -693,19 +686,10 @@ void CSVWorld::SimpleDialogueSubView::rowsAboutToBeRemoved(const QModelIndex &pa | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSVWorld::SimpleDialogueSubView::requestFocus (const std::string& id) | void CSVWorld::SimpleDialogueSubView::updateCurrentId() | ||||||
| { |  | ||||||
|     changeCurrentId(id); |  | ||||||
| 
 |  | ||||||
|     mEditWidget->remake(mTable->getModelIndex (id, 0).row()); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void CSVWorld::SimpleDialogueSubView::changeCurrentId (const std::string& newId) |  | ||||||
| { | { | ||||||
|     std::vector<std::string> selection; |     std::vector<std::string> selection; | ||||||
|     mCurrentId = std::string(newId); |     selection.push_back (getUniversalId().getId()); | ||||||
| 
 |  | ||||||
|     selection.push_back(mCurrentId); |  | ||||||
|     mCommandDispatcher.setSelection(selection); |     mCommandDispatcher.setSelection(selection); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -713,7 +697,7 @@ void CSVWorld::SimpleDialogueSubView::refreshNpcDialogue (int type, const std::s | ||||||
| { | { | ||||||
|     int typeColumn = mTable->findColumnIndex (CSMWorld::Columns::ColumnId_RecordType); |     int typeColumn = mTable->findColumnIndex (CSMWorld::Columns::ColumnId_RecordType); | ||||||
|     if (CSMWorld::UniversalId::Type_Npc |     if (CSMWorld::UniversalId::Type_Npc | ||||||
|                 != mTable->data(mTable->getModelIndex(mCurrentId, typeColumn), Qt::DisplayRole).toInt()) |                 != mTable->data(mTable->getModelIndex(getUniversalId().getId(), typeColumn), Qt::DisplayRole).toInt()) | ||||||
|     { |     { | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  | @ -722,13 +706,13 @@ void CSVWorld::SimpleDialogueSubView::refreshNpcDialogue (int type, const std::s | ||||||
|     int classColumn = mTable->findColumnIndex (CSMWorld::Columns::ColumnId_Class); |     int classColumn = mTable->findColumnIndex (CSMWorld::Columns::ColumnId_Class); | ||||||
| 
 | 
 | ||||||
|     if ((type == 0/*FIXME*/ && id == "") // skill or gmst changed
 |     if ((type == 0/*FIXME*/ && id == "") // skill or gmst changed
 | ||||||
|         || (id == mTable->data(mTable->getModelIndex(mCurrentId, raceColumn), |         || (id == mTable->data(mTable->getModelIndex(getUniversalId().getId(), raceColumn), | ||||||
|                                Qt::DisplayRole).toString().toUtf8().constData()) // race
 |                                Qt::DisplayRole).toString().toUtf8().constData()) // race
 | ||||||
|         || (id == mTable->data(mTable->getModelIndex(mCurrentId, classColumn), |         || (id == mTable->data(mTable->getModelIndex(getUniversalId().getId(), classColumn), | ||||||
|                                Qt::DisplayRole).toString().toUtf8().constData())) // class
 |                                Qt::DisplayRole).toString().toUtf8().constData())) // class
 | ||||||
|     { |     { | ||||||
|         int y = mEditWidget->verticalScrollBar()->value(); |         int y = mEditWidget->verticalScrollBar()->value(); | ||||||
|         mEditWidget->remake (mTable->getModelIndex(mCurrentId, 0).row()); |         mEditWidget->remake (mTable->getModelIndex(getUniversalId().getId(), 0).row()); | ||||||
|         mEditWidget->verticalScrollBar()->setValue(y); |         mEditWidget->verticalScrollBar()->setValue(y); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -738,171 +722,57 @@ CSVWorld::DialogueSubView::DialogueSubView (const CSMWorld::UniversalId& id, | ||||||
| : SimpleDialogueSubView (id, document) | : SimpleDialogueSubView (id, document) | ||||||
| { | { | ||||||
|     // bottom box
 |     // bottom box
 | ||||||
|     getMainLayout().addWidget (mBottom = new TableBottomBox (creatorFactory, document, id, this)); |     mBottom = new TableBottomBox (creatorFactory, document, id, this); | ||||||
| 
 | 
 | ||||||
|     mBottom->setSizePolicy(QSizePolicy::Ignored, QSizePolicy::Fixed); |     mBottom->setSizePolicy(QSizePolicy::Ignored, QSizePolicy::Fixed); | ||||||
| 
 | 
 | ||||||
|     connect(mBottom, SIGNAL(requestFocus(const std::string&)), this, SLOT(requestFocus(const std::string&))); |     connect (mBottom, SIGNAL (requestFocus (const std::string&)), | ||||||
|  |         this, SLOT (requestFocus (const std::string&))); | ||||||
| 
 | 
 | ||||||
|     // buttons
 |     // button bar
 | ||||||
|     QHBoxLayout *buttonsLayout = new QHBoxLayout; |     mButtons = new RecordButtonBar (id, getTable(), mBottom, | ||||||
|     QToolButton* prevButton = new QToolButton (this); |         &getCommandDispatcher(), this); | ||||||
|     prevButton->setIcon(QIcon(":/go-previous.png")); |  | ||||||
|     prevButton->setToolTip ("Switch to previous record"); |  | ||||||
|     QToolButton* nextButton = new QToolButton (this); |  | ||||||
|     nextButton->setIcon(QIcon(":/go-next.png")); |  | ||||||
|     nextButton->setToolTip ("Switch to next record"); |  | ||||||
|     buttonsLayout->addWidget(prevButton, 0); |  | ||||||
|     buttonsLayout->addWidget(nextButton, 1); |  | ||||||
|     buttonsLayout->addStretch(2); |  | ||||||
| 
 | 
 | ||||||
|     QToolButton* cloneButton = new QToolButton (this); |     // layout
 | ||||||
|     cloneButton->setIcon(QIcon(":/edit-clone.png")); |     getMainLayout().addWidget (mButtons); | ||||||
|     cloneButton->setToolTip ("Clone record"); |     getMainLayout().addWidget (mBottom); | ||||||
|     QToolButton* addButton = new QToolButton (this); |  | ||||||
|     addButton->setIcon(QIcon(":/add.png")); |  | ||||||
|     addButton->setToolTip ("Add new record"); |  | ||||||
|     QToolButton* deleteButton = new QToolButton (this); |  | ||||||
|     deleteButton->setIcon(QIcon(":/edit-delete.png")); |  | ||||||
|     deleteButton->setToolTip ("Delete record"); |  | ||||||
|     QToolButton* revertButton = new QToolButton (this); |  | ||||||
|     revertButton->setIcon(QIcon(":/edit-undo.png")); |  | ||||||
|     revertButton->setToolTip ("Revert record"); |  | ||||||
| 
 | 
 | ||||||
|     if (getTable().getFeatures() & CSMWorld::IdTable::Feature_Preview) |     // connections
 | ||||||
|     { |     connect (mButtons, SIGNAL (showPreview()), this, SLOT (showPreview())); | ||||||
|         QToolButton* previewButton = new QToolButton (this); |     connect (mButtons, SIGNAL (viewRecord()), this, SLOT (viewRecord())); | ||||||
|         previewButton->setIcon(QIcon(":/edit-preview.png")); |     connect (mButtons, SIGNAL (switchToRow (int)), this, SLOT (switchToRow (int))); | ||||||
|         previewButton->setToolTip ("Open a preview of this record"); |  | ||||||
|         buttonsLayout->addWidget(previewButton); |  | ||||||
|         connect(previewButton, SIGNAL(clicked()), this, SLOT(showPreview())); |  | ||||||
|     } |  | ||||||
| 
 | 
 | ||||||
|     if (getTable().getFeatures() & CSMWorld::IdTable::Feature_View) |     connect (this, SIGNAL (universalIdChanged (const CSMWorld::UniversalId&)), | ||||||
|     { |         mButtons, SLOT (universalIdChanged (const CSMWorld::UniversalId&))); | ||||||
|         QToolButton* viewButton = new QToolButton (this); |  | ||||||
|         viewButton->setIcon(QIcon(":/cell.png")); |  | ||||||
|         viewButton->setToolTip ("Open a scene view of the cell this record is located in"); |  | ||||||
|         buttonsLayout->addWidget(viewButton); |  | ||||||
|         connect(viewButton, SIGNAL(clicked()), this, SLOT(viewRecord())); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     buttonsLayout->addWidget(cloneButton); |  | ||||||
|     buttonsLayout->addWidget(addButton); |  | ||||||
|     buttonsLayout->addWidget(deleteButton); |  | ||||||
|     buttonsLayout->addWidget(revertButton); |  | ||||||
| 
 |  | ||||||
|     connect(nextButton, SIGNAL(clicked()), this, SLOT(nextId())); |  | ||||||
|     connect(prevButton, SIGNAL(clicked()), this, SLOT(prevId())); |  | ||||||
|     connect(cloneButton, SIGNAL(clicked()), this, SLOT(cloneRequest())); |  | ||||||
|     connect(revertButton, SIGNAL(clicked()), &getCommandDispatcher(), SLOT(executeRevert())); |  | ||||||
|     connect(deleteButton, SIGNAL(clicked()), &getCommandDispatcher(), SLOT(executeDelete())); |  | ||||||
| 
 |  | ||||||
|     connect(addButton, SIGNAL(clicked()), mBottom, SLOT(createRequest())); |  | ||||||
| 
 |  | ||||||
|     if(!mBottom->canCreateAndDelete()) |  | ||||||
|     { |  | ||||||
|         cloneButton->setDisabled (true); |  | ||||||
|         addButton->setDisabled (true); |  | ||||||
|         deleteButton->setDisabled (true); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     getMainLayout().addLayout (buttonsLayout); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSVWorld::DialogueSubView::cloneRequest() | void CSVWorld::DialogueSubView::setEditLock (bool locked) | ||||||
| { | { | ||||||
|     mBottom->cloneRequest (getCurrentId(), |     SimpleDialogueSubView::setEditLock (locked); | ||||||
|         static_cast<CSMWorld::UniversalId::Type> (getTable(). |     mButtons->setEditLock (locked); | ||||||
|         data (getTable().getModelIndex(getCurrentId(), 2)).toInt())); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSVWorld::DialogueSubView::prevId() | void CSVWorld::DialogueSubView::updateUserSetting (const QString& name, const QStringList& value) | ||||||
| { | { | ||||||
|     int newRow = getTable().getModelIndex (getCurrentId(), 0).row() - 1; |     SimpleDialogueSubView::updateUserSetting (name, value); | ||||||
| 
 |     mButtons->updateUserSetting (name, value); | ||||||
|     if (newRow < 0) |  | ||||||
|     { |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
|     while (newRow >= 0) |  | ||||||
|     { |  | ||||||
|         QModelIndex newIndex (getTable().index(newRow, 0)); |  | ||||||
| 
 |  | ||||||
|         if (!newIndex.isValid()) |  | ||||||
|         { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         CSMWorld::RecordBase::State state = static_cast<CSMWorld::RecordBase::State> (getTable().data (getTable().index (newRow, 1)).toInt()); |  | ||||||
|         if (!(state == CSMWorld::RecordBase::State_Deleted || state == CSMWorld::RecordBase::State_Erased)) |  | ||||||
|         { |  | ||||||
|             getEditWidget().remake (newRow); |  | ||||||
| 
 |  | ||||||
|             setUniversalId(CSMWorld::UniversalId (static_cast<CSMWorld::UniversalId::Type> (getTable().data (getTable().index (newRow, 2)).toInt()), |  | ||||||
|                                     getTable().data (getTable().index (newRow, 0)).toString().toUtf8().constData())); |  | ||||||
| 
 |  | ||||||
|             changeCurrentId(std::string (getTable().data (getTable().index (newRow, 0)).toString().toUtf8().constData())); |  | ||||||
| 
 |  | ||||||
|             getEditWidget().setDisabled (isLocked()); |  | ||||||
| 
 |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         --newRow; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void CSVWorld::DialogueSubView::nextId () |  | ||||||
| { |  | ||||||
|     int newRow = getTable().getModelIndex (getCurrentId(), 0).row() + 1; |  | ||||||
| 
 |  | ||||||
|     if (newRow >= getTable().rowCount()) |  | ||||||
|     { |  | ||||||
|         return; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     while (newRow < getTable().rowCount()) |  | ||||||
|     { |  | ||||||
|         QModelIndex newIndex (getTable().index(newRow, 0)); |  | ||||||
| 
 |  | ||||||
|         if (!newIndex.isValid()) |  | ||||||
|         { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         CSMWorld::RecordBase::State state = static_cast<CSMWorld::RecordBase::State> (getTable().data (getTable().index (newRow, 1)).toInt()); |  | ||||||
|         if (!(state == CSMWorld::RecordBase::State_Deleted)) |  | ||||||
|         { |  | ||||||
|             getEditWidget().remake(newRow); |  | ||||||
| 
 |  | ||||||
|             setUniversalId(CSMWorld::UniversalId (static_cast<CSMWorld::UniversalId::Type> (getTable().data (getTable().index (newRow, 2)).toInt()), |  | ||||||
|                                                   getTable().data (getTable().index (newRow, 0)).toString().toUtf8().constData())); |  | ||||||
| 
 |  | ||||||
|             changeCurrentId(std::string (getTable().data (getTable().index (newRow, 0)).toString().toUtf8().constData())); |  | ||||||
| 
 |  | ||||||
|             getEditWidget().setDisabled (isLocked()); |  | ||||||
| 
 |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
|         ++newRow; |  | ||||||
|     } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSVWorld::DialogueSubView::showPreview () | void CSVWorld::DialogueSubView::showPreview () | ||||||
| { | { | ||||||
|     QModelIndex currentIndex (getTable().getModelIndex (getCurrentId(), 0)); |     QModelIndex currentIndex (getTable().getModelIndex (getUniversalId().getId(), 0)); | ||||||
| 
 | 
 | ||||||
|     if (currentIndex.isValid() && |     if (currentIndex.isValid() && | ||||||
|         getTable().getFeatures() & CSMWorld::IdTable::Feature_Preview && |         getTable().getFeatures() & CSMWorld::IdTable::Feature_Preview && | ||||||
|         currentIndex.row() < getTable().rowCount()) |         currentIndex.row() < getTable().rowCount()) | ||||||
|     { |     { | ||||||
|         emit focusId(CSMWorld::UniversalId(CSMWorld::UniversalId::Type_Preview, getCurrentId()), ""); |         emit focusId(CSMWorld::UniversalId(CSMWorld::UniversalId::Type_Preview, getUniversalId().getId()), ""); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CSVWorld::DialogueSubView::viewRecord () | void CSVWorld::DialogueSubView::viewRecord () | ||||||
| { | { | ||||||
|     QModelIndex currentIndex (getTable().getModelIndex (getCurrentId(), 0)); |     QModelIndex currentIndex (getTable().getModelIndex (getUniversalId().getId(), 0)); | ||||||
| 
 | 
 | ||||||
|     if (currentIndex.isValid() && |     if (currentIndex.isValid() && | ||||||
|         currentIndex.row() < getTable().rowCount()) |         currentIndex.row() < getTable().rowCount()) | ||||||
|  | @ -913,3 +783,32 @@ void CSVWorld::DialogueSubView::viewRecord () | ||||||
|             emit focusId (params.first, params.second); |             emit focusId (params.first, params.second); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | void CSVWorld::DialogueSubView::switchToRow (int row) | ||||||
|  | { | ||||||
|  |     int idColumn = getTable().findColumnIndex (CSMWorld::Columns::ColumnId_Id); | ||||||
|  |     std::string id = getTable().data (getTable().index (row, idColumn)).toString().toUtf8().constData(); | ||||||
|  | 
 | ||||||
|  |     int typeColumn = getTable().findColumnIndex (CSMWorld::Columns::ColumnId_RecordType); | ||||||
|  |     CSMWorld::UniversalId::Type type = static_cast<CSMWorld::UniversalId::Type> ( | ||||||
|  |         getTable().data (getTable().index (row, typeColumn)).toInt()); | ||||||
|  | 
 | ||||||
|  |     setUniversalId (CSMWorld::UniversalId (type, id)); | ||||||
|  |     updateCurrentId(); | ||||||
|  | 
 | ||||||
|  |     getEditWidget().remake (row); | ||||||
|  | 
 | ||||||
|  |     int stateColumn = getTable().findColumnIndex (CSMWorld::Columns::ColumnId_Modification); | ||||||
|  |     CSMWorld::RecordBase::State state = static_cast<CSMWorld::RecordBase::State> ( | ||||||
|  |         getTable().data (getTable().index (row, stateColumn)).toInt()); | ||||||
|  | 
 | ||||||
|  |     getEditWidget().setDisabled (isLocked() || state==CSMWorld::RecordBase::State_Deleted); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSVWorld::DialogueSubView::requestFocus (const std::string& id) | ||||||
|  | { | ||||||
|  |     QModelIndex index = getTable().getModelIndex (id, 0); | ||||||
|  | 
 | ||||||
|  |     if (index.isValid()) | ||||||
|  |         switchToRow (index.row());     | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -175,16 +175,14 @@ namespace CSVWorld | ||||||
| 
 | 
 | ||||||
|     class SimpleDialogueSubView : public CSVDoc::SubView |     class SimpleDialogueSubView : public CSVDoc::SubView | ||||||
|     { |     { | ||||||
|         Q_OBJECT |             Q_OBJECT | ||||||
| 
 | 
 | ||||||
|         EditWidget* mEditWidget; |             EditWidget* mEditWidget; | ||||||
|         QVBoxLayout* mMainLayout; |             QVBoxLayout* mMainLayout; | ||||||
|         CSMWorld::IdTable* mTable; |             CSMWorld::IdTable* mTable; | ||||||
|         QUndoStack& mUndoStack; |             bool mLocked; | ||||||
|         std::string mCurrentId; |             const CSMDoc::Document& mDocument; | ||||||
|         bool mLocked; |             CSMWorld::CommandDispatcher mCommandDispatcher; | ||||||
|         const CSMDoc::Document& mDocument; |  | ||||||
|         CSMWorld::CommandDispatcher mCommandDispatcher; |  | ||||||
| 
 | 
 | ||||||
|         protected: |         protected: | ||||||
| 
 | 
 | ||||||
|  | @ -194,11 +192,9 @@ namespace CSVWorld | ||||||
| 
 | 
 | ||||||
|             CSMWorld::CommandDispatcher& getCommandDispatcher(); |             CSMWorld::CommandDispatcher& getCommandDispatcher(); | ||||||
| 
 | 
 | ||||||
|             std::string getCurrentId() const; |  | ||||||
| 
 |  | ||||||
|             EditWidget& getEditWidget(); |             EditWidget& getEditWidget(); | ||||||
| 
 | 
 | ||||||
|             void changeCurrentId(const std::string& newCurrent); |             void updateCurrentId(); | ||||||
| 
 | 
 | ||||||
|             bool isLocked() const; |             bool isLocked() const; | ||||||
|          |          | ||||||
|  | @ -213,35 +209,38 @@ namespace CSVWorld | ||||||
|             void dataChanged(const QModelIndex & index); |             void dataChanged(const QModelIndex & index); | ||||||
|             ///\brief we need to care for deleting currently edited record
 |             ///\brief we need to care for deleting currently edited record
 | ||||||
| 
 | 
 | ||||||
|             void requestFocus (const std::string& id); |  | ||||||
| 
 |  | ||||||
|             void rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end); |             void rowsAboutToBeRemoved(const QModelIndex &parent, int start, int end); | ||||||
| 
 | 
 | ||||||
|             void refreshNpcDialogue (int type, const std::string& id); |             void refreshNpcDialogue (int type, const std::string& id); | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|  |     class RecordButtonBar; | ||||||
|  | 
 | ||||||
|     class DialogueSubView : public SimpleDialogueSubView |     class DialogueSubView : public SimpleDialogueSubView | ||||||
|     { |     { | ||||||
|             Q_OBJECT |             Q_OBJECT | ||||||
|              |              | ||||||
|             TableBottomBox* mBottom; |             TableBottomBox* mBottom; | ||||||
|  |             RecordButtonBar *mButtons; | ||||||
| 
 | 
 | ||||||
|         public: |         public: | ||||||
| 
 | 
 | ||||||
|             DialogueSubView (const CSMWorld::UniversalId& id, CSMDoc::Document& document, |             DialogueSubView (const CSMWorld::UniversalId& id, CSMDoc::Document& document, | ||||||
|                 const CreatorFactoryBase& creatorFactory, bool sorting = false); |                 const CreatorFactoryBase& creatorFactory, bool sorting = false); | ||||||
| 
 | 
 | ||||||
|  |             virtual void setEditLock (bool locked); | ||||||
|  | 
 | ||||||
|  |             virtual void updateUserSetting (const QString& name, const QStringList& value); | ||||||
|  |              | ||||||
|         private slots: |         private slots: | ||||||
| 
 | 
 | ||||||
|             void cloneRequest(); |  | ||||||
| 
 |  | ||||||
|             void nextId(); |  | ||||||
| 
 |  | ||||||
|             void prevId(); |  | ||||||
| 
 |  | ||||||
|             void showPreview(); |             void showPreview(); | ||||||
| 
 | 
 | ||||||
|             void viewRecord(); |             void viewRecord(); | ||||||
|  | 
 | ||||||
|  |             void switchToRow (int row);             | ||||||
|  | 
 | ||||||
|  |             void requestFocus (const std::string& id); | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										207
									
								
								apps/opencs/view/world/recordbuttonbar.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										207
									
								
								apps/opencs/view/world/recordbuttonbar.cpp
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,207 @@ | ||||||
|  | 
 | ||||||
|  | #include "recordbuttonbar.hpp" | ||||||
|  | 
 | ||||||
|  | #include <QHBoxLayout> | ||||||
|  | #include <QToolButton> | ||||||
|  | 
 | ||||||
|  | #include "../../model/world/idtable.hpp" | ||||||
|  | #include "../../model/world/commanddispatcher.hpp" | ||||||
|  | 
 | ||||||
|  | #include "../../model/settings/usersettings.hpp" | ||||||
|  | 
 | ||||||
|  | #include "../world/tablebottombox.hpp" | ||||||
|  | 
 | ||||||
|  | void CSVWorld::RecordButtonBar::updateModificationButtons() | ||||||
|  | { | ||||||
|  |     bool createAndDeleteDisabled = !mBottom || !mBottom->canCreateAndDelete() || mLocked; | ||||||
|  | 
 | ||||||
|  |     mCloneButton->setDisabled (createAndDeleteDisabled); | ||||||
|  |     mAddButton->setDisabled (createAndDeleteDisabled); | ||||||
|  |     mDeleteButton->setDisabled (createAndDeleteDisabled); | ||||||
|  | 
 | ||||||
|  |     bool commandDisabled = !mCommandDispatcher || mLocked; | ||||||
|  |      | ||||||
|  |     mRevertButton->setDisabled (commandDisabled); | ||||||
|  |     mDeleteButton->setDisabled (commandDisabled); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSVWorld::RecordButtonBar::updatePrevNextButtons() | ||||||
|  | { | ||||||
|  |     int rows = mTable.rowCount(); | ||||||
|  |      | ||||||
|  |     if (rows<=1) | ||||||
|  |     { | ||||||
|  |         mPrevButton->setDisabled (true); | ||||||
|  |         mNextButton->setDisabled (true); | ||||||
|  |     } | ||||||
|  |     else if (CSMSettings::UserSettings::instance().settingValue ("general-input/cycle")=="true") | ||||||
|  |     { | ||||||
|  |         mPrevButton->setDisabled (false); | ||||||
|  |         mNextButton->setDisabled (false); | ||||||
|  |     } | ||||||
|  |     else | ||||||
|  |     { | ||||||
|  |         int row = mTable.getModelIndex (mId.getId(), 0).row(); | ||||||
|  | 
 | ||||||
|  |         mPrevButton->setDisabled (row<=0); | ||||||
|  |         mNextButton->setDisabled (row>=rows-1); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | CSVWorld::RecordButtonBar::RecordButtonBar (const CSMWorld::UniversalId& id, | ||||||
|  |     CSMWorld::IdTable& table, TableBottomBox *bottomBox, | ||||||
|  |     CSMWorld::CommandDispatcher *commandDispatcher, QWidget *parent) | ||||||
|  | : QWidget (parent), mId (id), mTable (table), mBottom (bottomBox), | ||||||
|  |   mCommandDispatcher (commandDispatcher), mLocked (false) | ||||||
|  | { | ||||||
|  |     QHBoxLayout *buttonsLayout = new QHBoxLayout; | ||||||
|  |     buttonsLayout->setContentsMargins (0, 0, 0, 0); | ||||||
|  | 
 | ||||||
|  |     // left section
 | ||||||
|  |     mPrevButton = new QToolButton (this); | ||||||
|  |     mPrevButton->setIcon(QIcon(":/go-previous.png")); | ||||||
|  |     mPrevButton->setToolTip ("Switch to previous record"); | ||||||
|  |     buttonsLayout->addWidget (mPrevButton, 0); | ||||||
|  |      | ||||||
|  |     mNextButton = new QToolButton (this); | ||||||
|  |     mNextButton->setIcon(QIcon(":/go-next.png")); | ||||||
|  |     mNextButton->setToolTip ("Switch to next record"); | ||||||
|  |     buttonsLayout->addWidget (mNextButton, 1); | ||||||
|  |      | ||||||
|  |     buttonsLayout->addStretch(2); | ||||||
|  | 
 | ||||||
|  |     // optional buttons of the right section
 | ||||||
|  |     if (mTable.getFeatures() & CSMWorld::IdTable::Feature_Preview) | ||||||
|  |     { | ||||||
|  |         QToolButton* previewButton = new QToolButton (this); | ||||||
|  |         previewButton->setIcon(QIcon(":/edit-preview.png")); | ||||||
|  |         previewButton->setToolTip ("Open a preview of this record"); | ||||||
|  |         buttonsLayout->addWidget(previewButton); | ||||||
|  |         connect (previewButton, SIGNAL(clicked()), this, SIGNAL (showPreview())); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     if (mTable.getFeatures() & CSMWorld::IdTable::Feature_View) | ||||||
|  |     { | ||||||
|  |         QToolButton* viewButton = new QToolButton (this); | ||||||
|  |         viewButton->setIcon(QIcon(":/cell.png")); | ||||||
|  |         viewButton->setToolTip ("Open a scene view of the cell this record is located in"); | ||||||
|  |         buttonsLayout->addWidget(viewButton); | ||||||
|  |         connect (viewButton, SIGNAL(clicked()), this, SIGNAL (viewRecord())); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     // right section
 | ||||||
|  |     mCloneButton = new QToolButton (this); | ||||||
|  |     mCloneButton->setIcon(QIcon(":/edit-clone.png")); | ||||||
|  |     mCloneButton->setToolTip ("Clone record"); | ||||||
|  |     buttonsLayout->addWidget(mCloneButton); | ||||||
|  |      | ||||||
|  |     mAddButton = new QToolButton (this); | ||||||
|  |     mAddButton->setIcon(QIcon(":/add.png")); | ||||||
|  |     mAddButton->setToolTip ("Add new record"); | ||||||
|  |     buttonsLayout->addWidget(mAddButton); | ||||||
|  |      | ||||||
|  |     mDeleteButton = new QToolButton (this); | ||||||
|  |     mDeleteButton->setIcon(QIcon(":/edit-delete.png")); | ||||||
|  |     mDeleteButton->setToolTip ("Delete record"); | ||||||
|  |     buttonsLayout->addWidget(mDeleteButton); | ||||||
|  |      | ||||||
|  |     mRevertButton = new QToolButton (this); | ||||||
|  |     mRevertButton->setIcon(QIcon(":/edit-undo.png")); | ||||||
|  |     mRevertButton->setToolTip ("Revert record"); | ||||||
|  |     buttonsLayout->addWidget(mRevertButton); | ||||||
|  |      | ||||||
|  |     setLayout (buttonsLayout); | ||||||
|  | 
 | ||||||
|  |     // connections
 | ||||||
|  |     if(mBottom && mBottom->canCreateAndDelete()) | ||||||
|  |     { | ||||||
|  |         connect (mAddButton, SIGNAL (clicked()), mBottom, SLOT (createRequest())); | ||||||
|  |         connect (mCloneButton, SIGNAL (clicked()), this, SLOT (cloneRequest())); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     connect (mNextButton, SIGNAL (clicked()), this, SLOT (nextId())); | ||||||
|  |     connect (mPrevButton, SIGNAL (clicked()), this, SLOT (prevId())); | ||||||
|  | 
 | ||||||
|  |     if (mCommandDispatcher) | ||||||
|  |     { | ||||||
|  |         connect (mRevertButton, SIGNAL (clicked()), mCommandDispatcher, SLOT (executeRevert())); | ||||||
|  |         connect (mDeleteButton, SIGNAL (clicked()), mCommandDispatcher, SLOT (executeDelete())); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     connect (&mTable, SIGNAL (rowsInserted (const QModelIndex&, int, int)), | ||||||
|  |         this, SLOT (rowNumberChanged (const QModelIndex&, int, int))); | ||||||
|  |     connect (&mTable, SIGNAL (rowsRemoved (const QModelIndex&, int, int)), | ||||||
|  |         this, SLOT (rowNumberChanged (const QModelIndex&, int, int))); | ||||||
|  |      | ||||||
|  |     updateModificationButtons(); | ||||||
|  |     updatePrevNextButtons(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSVWorld::RecordButtonBar::setEditLock (bool locked) | ||||||
|  | { | ||||||
|  |     mLocked = locked; | ||||||
|  |     updateModificationButtons(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSVWorld::RecordButtonBar::updateUserSetting (const QString& name, const QStringList& value) | ||||||
|  | { | ||||||
|  |     if (name=="general-input/cycle") | ||||||
|  |         updatePrevNextButtons(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSVWorld::RecordButtonBar::universalIdChanged (const CSMWorld::UniversalId& id) | ||||||
|  | { | ||||||
|  |     mId = id; | ||||||
|  |     updatePrevNextButtons(); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSVWorld::RecordButtonBar::cloneRequest() | ||||||
|  | { | ||||||
|  |     if (mBottom) | ||||||
|  |     { | ||||||
|  |         int typeColumn = mTable.findColumnIndex (CSMWorld::Columns::ColumnId_RecordType); | ||||||
|  | 
 | ||||||
|  |         QModelIndex typeIndex = mTable.getModelIndex (mId.getId(), typeColumn); | ||||||
|  |         CSMWorld::UniversalId::Type type = static_cast<CSMWorld::UniversalId::Type> ( | ||||||
|  |             mTable.data (typeIndex).toInt()); | ||||||
|  | 
 | ||||||
|  |         mBottom->cloneRequest (mId.getId(), type); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSVWorld::RecordButtonBar::nextId() | ||||||
|  | {     | ||||||
|  |     int newRow = mTable.getModelIndex (mId.getId(), 0).row() + 1; | ||||||
|  | 
 | ||||||
|  |     if (newRow >= mTable.rowCount()) | ||||||
|  |     { | ||||||
|  |         if (CSMSettings::UserSettings::instance().settingValue ("general-input/cycle") | ||||||
|  |             =="true") | ||||||
|  |             newRow = 0; | ||||||
|  |         else | ||||||
|  |             return; | ||||||
|  |     }     | ||||||
|  |      | ||||||
|  |     emit switchToRow (newRow); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSVWorld::RecordButtonBar::prevId() | ||||||
|  | { | ||||||
|  |     int newRow = mTable.getModelIndex (mId.getId(), 0).row() - 1; | ||||||
|  | 
 | ||||||
|  |     if (newRow < 0) | ||||||
|  |     { | ||||||
|  |         if (CSMSettings::UserSettings::instance().settingValue ("general-input/cycle") | ||||||
|  |             =="true") | ||||||
|  |             newRow = mTable.rowCount()-1; | ||||||
|  |         else | ||||||
|  |             return; | ||||||
|  |     } | ||||||
|  |      | ||||||
|  |     emit switchToRow (newRow); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | void CSVWorld::RecordButtonBar::rowNumberChanged (const QModelIndex& parent, int start, int end) | ||||||
|  | { | ||||||
|  |     updatePrevNextButtons(); | ||||||
|  | } | ||||||
							
								
								
									
										87
									
								
								apps/opencs/view/world/recordbuttonbar.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										87
									
								
								apps/opencs/view/world/recordbuttonbar.hpp
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,87 @@ | ||||||
|  | #ifndef CSV_WORLD_RECORDBUTTONBAR_H | ||||||
|  | #define CSV_WORLD_RECORDBUTTONBAR_H | ||||||
|  | 
 | ||||||
|  | #include <QWidget> | ||||||
|  | 
 | ||||||
|  | #include "../../model/world/universalid.hpp" | ||||||
|  | 
 | ||||||
|  | class QToolButton; | ||||||
|  | class QModelIndex; | ||||||
|  | 
 | ||||||
|  | namespace CSMWorld | ||||||
|  | { | ||||||
|  |     class IdTable; | ||||||
|  |     class CommandDispatcher; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | namespace CSVWorld | ||||||
|  | { | ||||||
|  |     class TableBottomBox; | ||||||
|  | 
 | ||||||
|  |     /// \brief Button bar for use in dialogue-type subviews
 | ||||||
|  |     ///
 | ||||||
|  |     /// Contains the following buttons:
 | ||||||
|  |     /// - next/prev
 | ||||||
|  |     /// - clone
 | ||||||
|  |     /// - add
 | ||||||
|  |     /// - delete
 | ||||||
|  |     /// - revert
 | ||||||
|  |     /// - preview (optional)
 | ||||||
|  |     /// - view (optional)
 | ||||||
|  |     class RecordButtonBar : public QWidget | ||||||
|  |     { | ||||||
|  |             Q_OBJECT | ||||||
|  | 
 | ||||||
|  |             CSMWorld::UniversalId mId; | ||||||
|  |             CSMWorld::IdTable& mTable; | ||||||
|  |             TableBottomBox *mBottom; | ||||||
|  |             CSMWorld::CommandDispatcher *mCommandDispatcher; | ||||||
|  |             QToolButton *mPrevButton; | ||||||
|  |             QToolButton *mNextButton; | ||||||
|  |             QToolButton *mCloneButton; | ||||||
|  |             QToolButton *mAddButton; | ||||||
|  |             QToolButton *mDeleteButton; | ||||||
|  |             QToolButton *mRevertButton; | ||||||
|  |             bool mLocked; | ||||||
|  | 
 | ||||||
|  |         private: | ||||||
|  | 
 | ||||||
|  |             void updateModificationButtons(); | ||||||
|  | 
 | ||||||
|  |             void updatePrevNextButtons(); | ||||||
|  |              | ||||||
|  |         public: | ||||||
|  | 
 | ||||||
|  |             RecordButtonBar (const CSMWorld::UniversalId& id, | ||||||
|  |                 CSMWorld::IdTable& table, TableBottomBox *bottomBox = 0, | ||||||
|  |                 CSMWorld::CommandDispatcher *commandDispatcher = 0, QWidget *parent = 0); | ||||||
|  | 
 | ||||||
|  |             void setEditLock (bool locked); | ||||||
|  | 
 | ||||||
|  |             void updateUserSetting (const QString& name, const QStringList& value); | ||||||
|  |              | ||||||
|  |         public slots: | ||||||
|  | 
 | ||||||
|  |             void universalIdChanged (const CSMWorld::UniversalId& id); | ||||||
|  | 
 | ||||||
|  |         private slots: | ||||||
|  | 
 | ||||||
|  |             void cloneRequest(); | ||||||
|  | 
 | ||||||
|  |             void nextId(); | ||||||
|  | 
 | ||||||
|  |             void prevId(); | ||||||
|  | 
 | ||||||
|  |             void rowNumberChanged (const QModelIndex& parent, int start, int end); | ||||||
|  |              | ||||||
|  |         signals: | ||||||
|  | 
 | ||||||
|  |             void showPreview(); | ||||||
|  | 
 | ||||||
|  |             void viewRecord(); | ||||||
|  | 
 | ||||||
|  |             void switchToRow (int row); | ||||||
|  |     }; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #endif | ||||||
|  | @ -174,6 +174,15 @@ namespace ESM | ||||||
|         endRecord(name); |         endRecord(name); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     void ESMWriter::writeFixedSizeString(const std::string &data, int size) | ||||||
|  |     { | ||||||
|  |         std::string string; | ||||||
|  |         if (!data.empty()) | ||||||
|  |             string = mEncoder ? mEncoder->getLegacyEnc(data) : data; | ||||||
|  |         string.resize(size); | ||||||
|  |         write(string.c_str(), string.size()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     void ESMWriter::writeHString(const std::string& data) |     void ESMWriter::writeHString(const std::string& data) | ||||||
|     { |     { | ||||||
|         if (data.size() == 0) |         if (data.size() == 0) | ||||||
|  |  | ||||||
|  | @ -120,6 +120,7 @@ public: | ||||||
|         void startSubRecord(const std::string& name); |         void startSubRecord(const std::string& name); | ||||||
|         void endRecord(const std::string& name); |         void endRecord(const std::string& name); | ||||||
|         void endRecord(uint32_t name); |         void endRecord(uint32_t name); | ||||||
|  |         void writeFixedSizeString(const std::string& data, int size); | ||||||
|         void writeHString(const std::string& data); |         void writeHString(const std::string& data); | ||||||
|         void writeHCString(const std::string& data); |         void writeHCString(const std::string& data); | ||||||
|         void writeName(const std::string& data); |         void writeName(const std::string& data); | ||||||
|  |  | ||||||
|  | @ -71,7 +71,13 @@ void ESM::Header::save (ESMWriter &esm) | ||||||
|     if (mFormat>0) |     if (mFormat>0) | ||||||
|         esm.writeHNT ("FORM", mFormat); |         esm.writeHNT ("FORM", mFormat); | ||||||
| 
 | 
 | ||||||
|     esm.writeHNT ("HEDR", mData, 300); |     esm.startSubRecord("HEDR"); | ||||||
|  |     esm.writeT(mData.version); | ||||||
|  |     esm.writeT(mData.type); | ||||||
|  |     esm.writeFixedSizeString(mData.author.toString(), 32); | ||||||
|  |     esm.writeFixedSizeString(mData.desc.toString(), 256); | ||||||
|  |     esm.writeT(mData.records); | ||||||
|  |     esm.endRecord("HEDR"); | ||||||
| 
 | 
 | ||||||
|     for (std::vector<Header::MasterData>::iterator iter = mMaster.begin(); |     for (std::vector<Header::MasterData>::iterator iter = mMaster.begin(); | ||||||
|          iter != mMaster.end(); ++iter) |          iter != mMaster.end(); ++iter) | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue