1
0
mirror of https://github.com/vcmi/vcmi.git synced 2024-12-12 10:03:53 +02:00
vcmi/mapeditor/mapsettings/translations.cpp

200 lines
6.0 KiB
C++

/*
* translations.cpp, part of VCMI engine
*
* Authors: listed in file AUTHORS in main folder
*
* License: GNU General Public License v2.0 or later
* Full text of license available in license.txt file, in main folder
*
*/
#include "StdInc.h"
#include "translations.h"
#include "ui_translations.h"
#include "../../lib/Languages.h"
#include "../../lib/CGeneralTextHandler.h"
#include "../../lib/mapObjects/CGObjectInstance.h"
#include "../../lib/VCMI_Lib.h"
void Translations::cleanupRemovedItems(CMap & map)
{
std::set<std::string> existingObjects{"map", "header"};
for(auto object : map.objects)
existingObjects.insert(object->instanceName);
for(auto & translations : map.translations.Struct())
{
JsonNode updateTranslations;
for(auto & s : translations.second.Struct())
{
for(auto part : QString::fromStdString(s.first).split('.'))
{
if(existingObjects.count(part.toStdString()))
{
updateTranslations.Struct()[s.first] = s.second;
break;
}
}
}
translations.second = updateTranslations;
}
}
void Translations::cleanupRemovedItems(CMap & map, const std::string & pattern)
{
for(auto & translations : map.translations.Struct())
{
JsonNode updateTranslations;
for(auto & s : translations.second.Struct())
{
if(s.first.find(pattern) == std::string::npos)
updateTranslations.Struct()[s.first] = s.second;
}
translations.second = updateTranslations;
}
}
Translations::Translations(CMapHeader & mh, QWidget *parent) :
QDialog(parent),
ui(new Ui::Translations),
mapHeader(mh)
{
setAttribute(Qt::WA_DeleteOnClose, true);
ui->setupUi(this);
//fill languages list
std::set<int> indexFoundLang;
int foundLang = -1;
ui->languageSelect->blockSignals(true);
for(auto & language : Languages::getLanguageList())
{
ui->languageSelect->addItem(QString("%1 (%2)").arg(QString::fromStdString(language.nameEnglish), QString::fromStdString(language.nameNative)));
ui->languageSelect->setItemData(ui->languageSelect->count() - 1, QVariant(QString::fromStdString(language.identifier)));
if(mapHeader.translations.Struct().count(language.identifier) && !mapHeader.translations[language.identifier].Struct().empty())
indexFoundLang.insert(ui->languageSelect->count() - 1);
if(language.identifier == VLC->generaltexth->getPreferredLanguage())
foundLang = ui->languageSelect->count() - 1;
}
ui->languageSelect->blockSignals(false);
if(foundLang >= 0 && !indexFoundLang.empty() && !indexFoundLang.count(foundLang))
{
foundLang = *indexFoundLang.begin();
mapPreferredLanguage = ui->languageSelect->itemData(foundLang).toString().toStdString();
}
if(foundLang >= 0)
ui->languageSelect->setCurrentIndex(foundLang);
if(mapPreferredLanguage.empty())
mapPreferredLanguage = VLC->generaltexth->getPreferredLanguage();
}
Translations::~Translations()
{
mapHeader.registerMapStrings();
delete ui;
}
void Translations::fillTranslationsTable(const std::string & language)
{
Translations::cleanupRemovedItems(dynamic_cast<CMap&>(mapHeader));
auto & translation = mapHeader.translations[language];
ui->translationsTable->blockSignals(true);
ui->translationsTable->setRowCount(0);
ui->translationsTable->setRowCount(translation.Struct().size());
int i = 0;
for(auto & s : translation.Struct())
{
auto textLines = QString::fromStdString(s.second.String());
textLines = textLines.replace('\n', "\\n");
auto * wId = new QTableWidgetItem(QString::fromStdString(s.first));
auto * wText = new QTableWidgetItem(textLines);
wId->setFlags(wId->flags() & ~Qt::ItemIsEditable);
wText->setFlags(wId->flags() | Qt::ItemIsEditable);
ui->translationsTable->setItem(i, 0, wId);
ui->translationsTable->setItem(i++, 1, wText);
}
ui->translationsTable->resizeColumnToContents(0);
ui->translationsTable->blockSignals(false);
}
void Translations::on_languageSelect_currentIndexChanged(int index)
{
auto language = ui->languageSelect->currentData().toString().toStdString();
bool hasLanguage = mapHeader.translations.Struct().count(language);
ui->supportedCheck->blockSignals(true);
ui->supportedCheck->setChecked(hasLanguage);
ui->supportedCheck->blockSignals(false);
ui->translationsTable->setEnabled(hasLanguage);
if(hasLanguage)
fillTranslationsTable(language);
else
ui->translationsTable->setRowCount(0);
}
void Translations::on_supportedCheck_toggled(bool checked)
{
auto language = ui->languageSelect->currentData().toString().toStdString();
auto & translation = mapHeader.translations[language];
bool hasRecord = !translation.Struct().empty();
if(checked)
{
//copy from default language
translation = mapHeader.translations[mapPreferredLanguage];
fillTranslationsTable(language);
ui->translationsTable->setEnabled(true);
}
else
{
bool canRemove = language != mapPreferredLanguage;
if(!canRemove)
{
QMessageBox::information(this, tr("Remove translation"), tr("Default language cannot be removed"));
}
else if(hasRecord)
{
auto sure = QMessageBox::question(this, tr("Remove translation"), tr("All existing text records for this language will be removed. Continue?"));
canRemove = sure != QMessageBox::No;
}
if(!canRemove)
{
ui->supportedCheck->blockSignals(true);
ui->supportedCheck->setChecked(true);
ui->supportedCheck->blockSignals(false);
return;
}
ui->translationsTable->blockSignals(true);
ui->translationsTable->setRowCount(0);
translation.clear();
ui->translationsTable->blockSignals(false);
ui->translationsTable->setEnabled(false);
}
}
void Translations::on_translationsTable_itemChanged(QTableWidgetItem * item)
{
assert(item->column() == 1);
auto language = ui->languageSelect->currentData().toString().toStdString();
auto & translation = mapHeader.translations[language];
assert(!translation.isNull());
auto textId = ui->translationsTable->item(item->row(), 0)->text().toStdString();
assert(!textId.empty());
if(textId.empty())
return;
auto textLines = item->text();
textLines = textLines.replace("\\n", "\n");
translation[textId].String() = textLines.toStdString();
}