wfview/settingswidget.cpp

1614 wiersze
51 KiB
C++

#include "settingswidget.h"
#include "ui_settingswidget.h"
#define setchk(a,b) quietlyUpdateCheckbox(a,b)
settingswidget::settingswidget(QWidget *parent) :
QWidget(parent),
ui(new Ui::settingswidget)
{
ui->setupUi(this);
createSettingsListItems();
populateComboBoxes();
}
settingswidget::~settingswidget()
{
delete ui;
}
// Startup:
void settingswidget::createSettingsListItems()
{
// Add items to the settings tab list widget
ui->settingsList->addItem("Radio Access"); // 0
ui->settingsList->addItem("User Interface"); // 1
ui->settingsList->addItem("Radio Settings"); // 2
ui->settingsList->addItem("Radio Server"); // 3
ui->settingsList->addItem("External Control"); // 4
ui->settingsList->addItem("DX Cluster"); // 5
ui->settingsList->addItem("Experimental"); // 6
//ui->settingsList->addItem("Audio Processing"); // 7
ui->settingsStack->setCurrentIndex(0);
}
void settingswidget::populateComboBoxes()
{
ui->baudRateCombo->blockSignals(true);
ui->baudRateCombo->insertItem(0, QString("115200"), 115200);
ui->baudRateCombo->insertItem(1, QString("57600"), 57600);
ui->baudRateCombo->insertItem(2, QString("38400"), 38400);
ui->baudRateCombo->insertItem(3, QString("28800"), 28800);
ui->baudRateCombo->insertItem(4, QString("19200"), 19200);
ui->baudRateCombo->insertItem(5, QString("9600"), 9600);
ui->baudRateCombo->insertItem(6, QString("4800"), 4800);
ui->baudRateCombo->insertItem(7, QString("2400"), 2400);
ui->baudRateCombo->insertItem(8, QString("1200"), 1200);
ui->baudRateCombo->insertItem(9, QString("300"), 300);
ui->baudRateCombo->blockSignals(false);
ui->meter2selectionCombo->blockSignals(true);
ui->meter2selectionCombo->addItem("None", meterNone);
ui->meter2selectionCombo->addItem("SWR", meterSWR);
ui->meter2selectionCombo->addItem("ALC", meterALC);
ui->meter2selectionCombo->addItem("Compression", meterComp);
ui->meter2selectionCombo->addItem("Voltage", meterVoltage);
ui->meter2selectionCombo->addItem("Current", meterCurrent);
ui->meter2selectionCombo->addItem("Center", meterCenter);
ui->meter2selectionCombo->addItem("TxRxAudio", meterAudio);
ui->meter2selectionCombo->addItem("RxAudio", meterRxAudio);
ui->meter2selectionCombo->addItem("TxAudio", meterTxMod);
ui->meter2selectionCombo->show();
ui->meter2selectionCombo->blockSignals(false);
ui->secondaryMeterSelectionLabel->show();
ui->audioRXCodecCombo->blockSignals(true);
ui->audioRXCodecCombo->addItem("LPCM 1ch 16bit", 4);
ui->audioRXCodecCombo->addItem("LPCM 1ch 8bit", 2);
ui->audioRXCodecCombo->addItem("uLaw 1ch 8bit", 1);
ui->audioRXCodecCombo->addItem("LPCM 2ch 16bit", 16);
ui->audioRXCodecCombo->addItem("uLaw 2ch 8bit", 32);
ui->audioRXCodecCombo->addItem("PCM 2ch 8bit", 8);
ui->audioRXCodecCombo->addItem("Opus 1ch", 64);
ui->audioRXCodecCombo->addItem("Opus 2ch", 128);
ui->audioRXCodecCombo->blockSignals(false);
ui->audioTXCodecCombo->blockSignals(true);
ui->audioTXCodecCombo->addItem("LPCM 1ch 16bit", 4);
ui->audioTXCodecCombo->addItem("LPCM 1ch 8bit", 2);
ui->audioTXCodecCombo->addItem("uLaw 1ch 8bit", 1);
ui->audioTXCodecCombo->addItem("Opus 1ch", 64);
ui->audioTXCodecCombo->blockSignals(false);
ui->controlPortTxt->setValidator(new QIntValidator(this));
}
// Updating Preferences:
void settingswidget::acceptPreferencesPtr(preferences *pptr)
{
if(pptr != NULL)
{
qDebug(logGui()) << "Accepting general preferences pointer into settings widget.";
prefs = pptr;
havePrefs = true;
}
}
void settingswidget::acceptUdpPreferencesPtr(udpPreferences *upptr)
{
if(upptr != NULL)
{
qDebug(logGui()) << "Accepting UDP preferences pointer into settings widget.";
udpPrefs = upptr;
haveUdpPrefs = true;
}
}
void settingswidget::acceptServerConfig(SERVERCONFIG *sc)
{
if(sc != NULL)
{
qDebug(logGui()) << "Accepting ServerConfig pointer into settings widget.";
serverConfig = sc;
haveServerConfig = true;
}
}
void settingswidget::copyClusterList(QList<clusterSettings> c)
{
this->clusters = c;
haveClusterList = true;
qDebug(logGui()) << "Updated settings widget clusters. Size of this->clusters: " << clusters.size();
setUItoClustersList();
}
void settingswidget::insertClusterOutputText(QString text)
{
ui->clusterOutputTextEdit->moveCursor(QTextCursor::End);
ui->clusterOutputTextEdit->insertPlainText(text);
ui->clusterOutputTextEdit->moveCursor(QTextCursor::End);
}
void settingswidget::setUItoClustersList()
{
if(haveClusterList)
{
int defaultCluster = 0;
int numClusters = clusters.size();
if(numClusters > 0)
{
ui->clusterServerNameCombo->blockSignals(true);
for (int f = 0; f < clusters.size(); f++)
{
ui->clusterServerNameCombo->addItem(clusters[f].server);
if (clusters[f].isdefault) {
defaultCluster = f;
}
}
ui->clusterServerNameCombo->blockSignals(false);
if (clusters.size() > defaultCluster)
{
ui->clusterServerNameCombo->setCurrentIndex(defaultCluster);
ui->clusterTcpPortLineEdit->blockSignals(true);
ui->clusterUsernameLineEdit->blockSignals(true);
ui->clusterPasswordLineEdit->blockSignals(true);
ui->clusterTimeoutLineEdit->blockSignals(true);
ui->clusterTcpPortLineEdit->setText(QString::number(clusters[defaultCluster].port));
ui->clusterUsernameLineEdit->setText(clusters[defaultCluster].userName);
ui->clusterPasswordLineEdit->setText(clusters[defaultCluster].password);
ui->clusterTimeoutLineEdit->setText(QString::number(clusters[defaultCluster].timeout));
ui->clusterTcpPortLineEdit->blockSignals(false);
ui->clusterUsernameLineEdit->blockSignals(false);
ui->clusterPasswordLineEdit->blockSignals(false);
ui->clusterTimeoutLineEdit->blockSignals(false);
}
} else {
// No clusters in the list
ui->clusterTcpPortLineEdit->setEnabled(false);
ui->clusterUsernameLineEdit->setEnabled(false);
ui->clusterPasswordLineEdit->setEnabled(false);
ui->clusterTimeoutLineEdit->setEnabled(false);
}
} else {
qCritical(logGui()) << "Called to update UI of cluster info without cluister list.";
}
}
void settingswidget::updateIfPrefs(int items)
{
prefIfItem pif;
if(items & (int)if_all)
{
items = 0xffffffff;
}
for(int i=1; i < (int)if_all; i = i << 1)
{
if(items & i)
{
qDebug(logGui()) << "Updating If pref" << (int)i;
pif = (prefIfItem)i;
updateIfPref(pif);
}
}
}
void settingswidget::updateRaPrefs(int items)
{
prefRaItem pra;
if(items & (int)ra_all)
{
items = 0xffffffff;
}
for(int i=1; i < (int)ra_all; i = i << 1)
{
if(items & i)
{
qDebug(logGui()) << "Updating Ra pref" << (int)i;
pra = (prefRaItem)i;
updateRaPref(pra);
}
}
}
void settingswidget::updateCtPrefs(int items)
{
prefCtItem pct;
if(items & (int)ct_all)
{
items = 0xffffffff;
}
for(int i=1; i < (int)ct_all; i = i << 1)
{
if(items & i)
{
qDebug(logGui()) << "Updating Ct pref" << (int)i;
pct = (prefCtItem)i;
updateCtPref(pct);
}
}
}
void settingswidget::updateServerConfigs(int items)
{
serverItems si;
if(items & (int)s_all)
{
items = 0xffffffff;
}
for(int i=1; i < (int)s_all; i = i << 1)
{
if(items & i)
{
qDebug(logGui()) << "Updating ServerConfig" << (int)i;
si = (serverItems)i;
updateServerConfig(si);
}
}
}
void settingswidget::updateLanPrefs(int items)
{
prefLanItem plan;
if(items & (int)l_all)
{
items = 0xffffffff;
}
for(int i=1; i < (int)l_all; i = i << 1)
{
if(items & i)
{
qDebug(logGui()) << "Updating Lan pref" << (int)i;
plan = (prefLanItem)i;
updateLanPref(plan);
}
}
}
void settingswidget::updateClusterPrefs(int items)
{
prefClusterItem pcl;
if(items & (int)cl_all)
{
items = 0xffffffff;
}
for(int i=1; i < (int)cl_all; i = i << 1)
{
if(items & i)
{
qDebug(logGui()) << "Updating Cluster pref" << (int)i;
pcl = (prefClusterItem)i;
updateClusterPref(pcl);
}
}
}
void settingswidget::updateIfPref(prefIfItem pif)
{
if(prefs==NULL)
return;
updatingUIFromPrefs = true;
switch(pif)
{
case if_useFullScreen:
quietlyUpdateCheckbox(ui->fullScreenChk, prefs->useFullScreen);
break;
case if_useSystemTheme:
quietlyUpdateCheckbox(ui->useSystemThemeChk, prefs->useSystemTheme);
break;
case if_drawPeaks:
// depreciated;
break;
case if_underlayMode:
updateUnderlayMode();
break;
case if_underlayBufferSize:
quietlyUpdateSlider(ui->underlayBufferSlider, prefs->underlayBufferSize);
break;
case if_wfAntiAlias:
quietlyUpdateCheckbox(ui->wfAntiAliasChk, prefs->wfAntiAlias);
break;
case if_wfInterpolate:
quietlyUpdateCheckbox(ui->wfInterpolateChk, prefs->wfInterpolate);
break;
case if_wftheme:
// Not handled in settings.
break;
case if_plotFloor:
// Not handled in settings.
break;
case if_plotCeiling:
// Not handled in settings.
break;
case if_stylesheetPath:
// No UI element for this.
break;
case if_wflength:
// Not handled in settings.
break;
case if_confirmExit:
// No UI element for this.
break;
case if_confirmPowerOff:
// No UI element for this.
break;
case if_meter2Type:
{
ui->meter2selectionCombo->blockSignals(true);
int m = ui->meter2selectionCombo->findData(prefs->meter2Type);
ui->meter2selectionCombo->setCurrentIndex(m);
ui->meter2selectionCombo->blockSignals(false);
break;
}
case if_clickDragTuningEnable:
quietlyUpdateCheckbox(ui->clickDragTuningEnableChk, prefs->clickDragTuningEnable);
break;
case if_currentColorPresetNumber:
ui->colorPresetCombo->blockSignals(true);
ui->colorPresetCombo->setCurrentIndex(prefs->currentColorPresetNumber);
ui->colorPresetCombo->blockSignals(false);
// activate? or done when prefs load? Maybe some of each?
// TODO
break;
default:
qWarning(logGui()) << "Did not understand if pref update item " << (int)pif;
break;
}
updatingUIFromPrefs = false;
}
void settingswidget::updateRaPref(prefRaItem pra)
{
if(prefs==NULL)
return;
updatingUIFromPrefs = true;
switch(pra)
{
case ra_radioCIVAddr:
// It may be possible to ignore this value at this time.
// TODO
if(prefs->radioCIVAddr == 0)
{
ui->rigCIVaddrHexLine->setText("auto");
ui->rigCIVaddrHexLine->setEnabled(false);
} else {
ui->rigCIVaddrHexLine->setEnabled(true);
ui->rigCIVaddrHexLine->setText(QString("%1").arg(prefs->radioCIVAddr, 2, 16));
}
break;
case ra_CIVisRadioModel:
quietlyUpdateCheckbox(ui->useCIVasRigIDChk, prefs->CIVisRadioModel);
break;
case ra_forceRTSasPTT:
quietlyUpdateCheckbox(ui->useRTSforPTTchk, prefs->forceRTSasPTT);
break;
case ra_polling_ms:
if(prefs->polling_ms == 0)
{
// Automatic
ui->pollingButtonGroup->blockSignals(true);
ui->autoPollBtn->setChecked(true);
ui->manualPollBtn->setChecked(false);
ui->pollingButtonGroup->blockSignals(false);
ui->pollTimeMsSpin->setEnabled(false);
} else {
// Manual
ui->pollingButtonGroup->blockSignals(true);
ui->autoPollBtn->setChecked(false);
ui->manualPollBtn->setChecked(true);
ui->pollingButtonGroup->blockSignals(false);
ui->pollTimeMsSpin->blockSignals(true);
ui->pollTimeMsSpin->setValue(prefs->polling_ms);
ui->pollTimeMsSpin->blockSignals(false);
ui->pollTimeMsSpin->setEnabled(true);
}
break;
case ra_serialPortRadio:
{
if(!haveSerialDevices)
{
qCritical(logGui()) << "Asked to show serial device without serial device list.";
break;
}
if(!prefs->serialPortRadio.isEmpty())
{
int serialIndex = -1;
if(prefs->serialPortRadio.toLower() == "auto")
{
serialIndex = ui->serialDeviceListCombo->findText(QString("Auto"));
} else {
serialIndex = ui->serialDeviceListCombo->findText(prefs->serialPortRadio);
}
if (serialIndex != -1) {
ui->serialDeviceListCombo->setCurrentIndex(serialIndex);
} else {
qWarning(logGui()) << "Cannot find serial port" << prefs->serialPortRadio << "mentioned in preferences inside the serial combo box.";
}
} else {
qDebug(logGui()) << "Serial port in prefs is blank";
}
break;
}
case ra_serialPortBaud:
ui->baudRateCombo->blockSignals(true);
ui->baudRateCombo->setCurrentIndex(ui->baudRateCombo->findData(prefs->serialPortBaud));
ui->baudRateCombo->blockSignals(false);
break;
case ra_virtualSerialPort:
{
if(!haveVspDevices)
{
qCritical(logGui()) << "Asked to select VSP device without VSP device list.";
break;
}
int vspIndex = ui->vspCombo->findText(prefs->virtualSerialPort);
if (vspIndex != -1) {
ui->vspCombo->setCurrentIndex(vspIndex);
} else {
// TODO: Are we sure this is a good idea?
if(!prefs->virtualSerialPort.isEmpty())
{
ui->vspCombo->addItem(prefs->virtualSerialPort);
ui->vspCombo->setCurrentIndex(ui->vspCombo->count() - 1);
}
}
break;
}
case ra_localAFgain:
// Not handled here.
break;
case ra_audioSystem:
ui->audioSystemCombo->blockSignals(true);
ui->audioSystemServerCombo->blockSignals(true);
ui->audioSystemCombo->setCurrentIndex(prefs->audioSystem);
ui->audioSystemServerCombo->setCurrentIndex(prefs->audioSystem);
ui->audioSystemServerCombo->blockSignals(false);
ui->audioSystemCombo->blockSignals(false);
break;
default:
qWarning(logGui()) << "Cannot update ra pref" << (int)pra;
}
updatingUIFromPrefs = false;
}
void settingswidget::updateCtPref(prefCtItem pct)
{
if(prefs==NULL)
return;
updatingUIFromPrefs = true;
switch(pct)
{
case ct_enablePTT:
quietlyUpdateCheckbox(ui->pttEnableChk, prefs->enablePTT);
break;
case ct_niceTS:
quietlyUpdateCheckbox(ui->tuningFloorZerosChk, prefs->niceTS);
break;
case ct_automaticSidebandSwitching:
quietlyUpdateCheckbox(ui->autoSSBchk, prefs->automaticSidebandSwitching);
break;
case ct_enableUSBControllers:
quietlyUpdateCheckbox(ui->enableUsbChk, prefs->enableUSBControllers);
break;
case ct_usbSensitivity:
// No UI element for this.
break;
default:
qWarning(logGui()) << "No UI element matches setting" << (int)pct;
break;
}
updatingUIFromPrefs = false;
}
void settingswidget::updateLanPref(prefLanItem plan)
{
if(prefs==NULL)
return;
updatingUIFromPrefs = true;
switch(plan)
{
case l_enableLAN:
quietlyUpdateRadiobutton(ui->lanEnableBtn, prefs->enableLAN);
break;
case l_enableRigCtlD:
quietlyUpdateCheckbox(ui->enableRigctldChk, prefs->enableRigCtlD);
break;
case l_rigCtlPort:
ui->rigctldPortTxt->setText(QString::number(prefs->rigCtlPort));
break;
case l_tcpPort:
ui->tcpServerPortTxt->setText(QString::number(prefs->tcpPort));
break;
case l_waterfallFormat:
ui->waterfallFormatCombo->blockSignals(true);
ui->waterfallFormatCombo->setCurrentIndex(prefs->waterfallFormat);
ui->waterfallFormatCombo->blockSignals(false);
break;
default:
qWarning(logGui()) << "Did not find matching preference for LAN ui update:" << (int)plan;
}
updatingUIFromPrefs = false;
}
void settingswidget::updateClusterPref(prefClusterItem pcl)
{
if(prefs==NULL)
return;
updatingUIFromPrefs = true;
switch(pcl)
{
case cl_clusterUdpEnable:
quietlyUpdateCheckbox(ui->clusterUdpEnable, prefs->clusterUdpEnable);
break;
case cl_clusterTcpEnable:
quietlyUpdateCheckbox(ui->clusterTcpEnable, prefs->clusterTcpEnable);
break;
case cl_clusterUdpPort:
ui->clusterUdpPortLineEdit->blockSignals(true);
ui->clusterUdpPortLineEdit->setText(QString::number(prefs->clusterUdpPort));
ui->clusterUdpPortLineEdit->blockSignals(false);
break;
case cl_clusterTcpServerName:
// Take this from the clusters list
break;
case cl_clusterTcpUserName:
// Take this from the clusters list
break;
case cl_clusterTcpPassword:
// Take this from the clusters list
break;
case cl_clusterTcpPort:
break;
case cl_clusterTimeout:
// Take this from the clusters list
break;
case cl_clusterSkimmerSpotsEnable:
quietlyUpdateCheckbox(ui->clusterSkimmerSpotsEnable, prefs->clusterSkimmerSpotsEnable);
break;
default:
qWarning(logGui()) << "Did not find matching UI element for cluster preference " << (int)pcl;
break;
}
updatingUIFromPrefs = false;
}
void settingswidget::updateServerConfig(serverItems si)
{
if(serverConfig == NULL)
{
qCritical(logGui()) << "serverConfig is NULL, cannot set preferences!";
return;
}
updatingUIFromPrefs = true;
switch(si)
{
case s_enabled:
quietlyUpdateCheckbox(ui->serverEnableCheckbox, serverConfig->enabled);
break;
case s_lan:
// Not used here
break;
case s_controlPort:
quietlyUpdateLineEdit(ui->serverControlPortText, QString::number(serverConfig->civPort));
break;
case s_civPort:
quietlyUpdateLineEdit(ui->serverCivPortText, QString::number(serverConfig->civPort));
break;
case s_audioPort:
quietlyUpdateLineEdit(ui->serverAudioPortText, QString::number(serverConfig->audioPort));
break;
case s_audioOutput:
break;
case s_audioInput:
break;
case s_resampleQuality:
// Not used here
break;
case s_baudRate:
// Not used here
break;
case s_users:
// This is fairly complex
populateServerUsers();
break;
case s_rigs:
// Not used here
break;
default:
qWarning(logGui()) << "Did not find matching UI element for ServerConfig " << (int)si;
}
updatingUIFromPrefs = false;
}
void settingswidget::updateUdpPrefs(int items)
{
udpPrefsItem upi;
if(items & (int)u_all)
{
items = 0xffffffff;
}
for(int i=1; i < (int)u_all; i = i << 1)
{
if(items & i)
{
qDebug(logGui()) << "Updating UDP preference " << i;
upi = (udpPrefsItem)i;
updateUdpPref(upi);
}
}
}
void settingswidget::updateUdpPref(udpPrefsItem upi)
{
updatingUIFromPrefs = true;
switch(upi)
{
case u_ipAddress:
ui->ipAddressTxt->blockSignals(true);
ui->ipAddressTxt->setEnabled(ui->lanEnableBtn->isChecked());
ui->ipAddressTxt->setText(udpPrefs->ipAddress);
ui->ipAddressTxt->blockSignals(false);
break;
case u_controlLANPort:
ui->controlPortTxt->blockSignals(true);
ui->controlPortTxt->setEnabled(ui->lanEnableBtn->isChecked());
ui->controlPortTxt->setText(QString("%1").arg(udpPrefs->controlLANPort));
ui->controlPortTxt->blockSignals(false);
break;
case u_serialLANPort:
// Not used in the UI.
break;
case u_audioLANPort:
// Not used in the UI.
break;
case u_username:
ui->usernameTxt->blockSignals(true);
ui->usernameTxt->setEnabled(ui->lanEnableBtn->isChecked());
ui->usernameTxt->setText(QString("%1").arg(udpPrefs->username));
ui->usernameTxt->blockSignals(false);
break;
case u_password:
ui->passwordTxt->blockSignals(true);
ui->passwordTxt->setEnabled(ui->lanEnableBtn->isChecked());
ui->passwordTxt->setText(QString("%1").arg(udpPrefs->password));
ui->passwordTxt->blockSignals(false);
break;
case u_clientName:
// Not used in the UI.
break;
case u_waterfallFormat:
ui->waterfallFormatCombo->blockSignals(true);
ui->waterfallFormatCombo->setCurrentIndex(prefs->waterfallFormat);
ui->waterfallFormatCombo->blockSignals(false);
break;
case u_halfDuplex:
ui->audioDuplexCombo->blockSignals(true);
ui->audioDuplexCombo->setCurrentIndex((int)udpPrefs->halfDuplex);
ui->audioDuplexCombo->blockSignals(false);
break;
default:
qWarning(logGui()) << "Did not find matching UI element for UDP pref item " << (int)upi;
break;
}
updatingUIFromPrefs = false;
}
void settingswidget::updateAllPrefs()
{
// DEPRECIATED
// Maybe make this a public convenience function
// Review all the preferences. This is intended to be called
// after new settings are loaded in.
// Not sure if we actually want to always assume we should load prefs.
updatingUIFromPrefs = true;
if(havePrefs)
{
updateIfPrefs((int)if_all);
updateRaPrefs((int)ra_all);
updateCtPrefs((int)ct_all);
updateClusterPrefs((int)cl_all);
updateLanPrefs((int)l_all);
}
if(haveUdpPrefs)
{
updateUdpPrefs((int)u_all);
}
updatingUIFromPrefs = false;
}
void settingswidget::updateAudioInputs(QStringList deviceList, int currentIndex, int chars)
{
// see wfmain::setAudioDevicesUI()
if(haveAudioInputs)
qDebug(logGui()) << "Reloading audio input list";
ui->audioInputCombo->blockSignals(true);
ui->audioInputCombo->clear();
ui->audioInputCombo->addItems(deviceList);
ui->audioInputCombo->setCurrentIndex(-1);
ui->audioInputCombo->setStyleSheet(QString("QComboBox QAbstractItemView {min-width: %1px;}").arg(chars + 30));
ui->audioInputCombo->blockSignals(false);
ui->audioInputCombo->setCurrentIndex(currentIndex);
haveAudioInputs = true;
}
void settingswidget::updateAudioOutputs(QStringList deviceList, int currentIndex, int chars)
{
if(haveAudioOutputs)
qDebug(logGui()) << "Reloading audio output list";
ui->audioOutputCombo->blockSignals(true);
ui->audioOutputCombo->clear();
ui->audioOutputCombo->addItems(deviceList);
ui->audioOutputCombo->setCurrentIndex(-1);
ui->audioOutputCombo->setStyleSheet(QString("QComboBox QAbstractItemView {min-width: %1px;}").arg(chars + 30));
ui->audioOutputCombo->blockSignals(false);
ui->audioOutputCombo->setCurrentIndex(currentIndex);
haveAudioOutputs = true;
}
void settingswidget::updateServerTXAudioOutputs(QStringList deviceList, int currentIndex, int chars)
{
if(haveServerAudioOutputs)
qDebug(logGui()) << "Reloading ServerTXAudioOutputs";
ui->serverTXAudioOutputCombo->blockSignals(true);
ui->serverTXAudioOutputCombo->clear();
ui->serverTXAudioOutputCombo->addItems(deviceList);
ui->serverTXAudioOutputCombo->setCurrentIndex(-1);
ui->serverTXAudioOutputCombo->setStyleSheet(QString("QComboBox QAbstractItemView {min-width: %1px;}").arg(chars + 30));
ui->serverTXAudioOutputCombo->setCurrentIndex(currentIndex);
ui->serverTXAudioOutputCombo->blockSignals(false);
haveServerAudioOutputs = true;
}
void settingswidget::updateServerRXAudioInputs(QStringList deviceList, int currentIndex, int chars)
{
if(haveServerAudioInputs)
qDebug(logGui()) << "Reloading ServerRXAudioInputs";
ui->serverRXAudioInputCombo->blockSignals(true);
ui->serverRXAudioInputCombo->clear();
ui->serverRXAudioInputCombo->addItems(deviceList);
ui->serverRXAudioInputCombo->setCurrentIndex(-1);
ui->serverRXAudioInputCombo->setStyleSheet(QString("QComboBox QAbstractItemView {min-width: %1px;}").arg(chars+30));
ui->serverRXAudioInputCombo->setCurrentIndex(currentIndex);
ui->serverRXAudioInputCombo->blockSignals(false);
haveServerAudioInputs = true;
}
void settingswidget::updateSerialPortList(QStringList deviceList, QVector<int> data)
{
if(deviceList.length() == data.length())
{
ui->serialDeviceListCombo->blockSignals(true);
ui->serialDeviceListCombo->addItem("Auto", 0);
for(int i=0; i < deviceList.length(); i++)
{
ui->serialDeviceListCombo->addItem(deviceList.at(i), data.at(i));
}
#if defined(Q_OS_LINUX) || defined(Q_OS_MAC) || defined(Q_OS_UNIX)
ui->serialDeviceListCombo->addItem("Manual...", 256);
#endif
ui->serialDeviceListCombo->blockSignals(false);
haveSerialDevices = true;
} else {
qCritical(logGui()) << "Cannot populate serial device list. Data of unequal length.";
}
}
void settingswidget::updateVSPList(QStringList deviceList, QVector<int> data)
{
// Do not supply "None" device, that is a UI thing and it is done here.
// Supply the complete filename
// TODO: Should we clear the list first?
if(deviceList.length() == data.length())
{
ui->vspCombo->blockSignals(true);
for(int i=0; i < deviceList.length(); i++)
{
ui->vspCombo->addItem(deviceList.at(i), data.at(i));
if (QFile::exists(deviceList.at(i))) {
auto* model = qobject_cast<QStandardItemModel*>(ui->vspCombo->model());
auto* item = model->item(ui->vspCombo->count() - 1);
item->setEnabled(false);
}
}
ui->serialDeviceListCombo->addItem("None", deviceList.size());
ui->vspCombo->blockSignals(false);
haveVspDevices = true;
} else {
qCritical(logGui()) << "Cannot populate serial device list. Data of unequal length.";
}
}
void settingswidget::updateModSourceList(QStringList deviceNames, QVector<rigInput> data)
{
ui->modInputCombo->blockSignals(true);
ui->modInputCombo->clear();
for(int i=0; i < deviceNames.length(); i++)
{
ui->modInputCombo->addItem(deviceNames.at(i), data.at(i));
}
ui->modInputCombo->blockSignals(false);
}
void settingswidget::updateDataModSourceList(QStringList deviceNames, QVector<rigInput> data)
{
ui->modInputDataCombo->blockSignals(true);
ui->modInputDataCombo->clear();
for(int i=0; i < deviceNames.length(); i++)
{
ui->modInputDataCombo->addItem(deviceNames.at(i), data.at(i));
}
ui->modInputDataCombo->blockSignals(false);
}
void settingswidget::populateServerUsers()
{
// Copy data from serverConfig.users into the server UI table
// We will assume the data are safe to use.
bool blank = false;
int row=0;
qDebug(logGui()) << "Adding server users. Size: " << serverConfig->users.size();
QList<SERVERUSER>::iterator user = serverConfig->users.begin();
while (user != serverConfig->users.end())
{
serverAddUserLine(user->username, user->password, user->userType);
if((user->username == "") && !blank)
blank = true;
row++;
user++;
}
if (row==1 && blank)
{
// There are no defined users. The only user present is the blank one.
// The button is disabled, but it may be enabled
// when the user enters valid information for a potential new
// user account.
ui->serverAddUserBtn->setEnabled(false);
}
}
void settingswidget::serverAddUserLine(const QString &user, const QString &pass, const int &type)
{
// migration TODO: Review these signals/slots
ui->serverUsersTable->blockSignals(true);
ui->serverUsersTable->insertRow(ui->serverUsersTable->rowCount());
ui->serverUsersTable->setItem(ui->serverUsersTable->rowCount() - 1, 0, new QTableWidgetItem());
ui->serverUsersTable->setItem(ui->serverUsersTable->rowCount() - 1, 1, new QTableWidgetItem());
ui->serverUsersTable->setItem(ui->serverUsersTable->rowCount() - 1, 2, new QTableWidgetItem());
ui->serverUsersTable->setItem(ui->serverUsersTable->rowCount() - 1, 3, new QTableWidgetItem());
QLineEdit* username = new QLineEdit();
username->setProperty("row", (int)ui->serverUsersTable->rowCount() - 1);
username->setProperty("col", (int)0);
username->setText(user);
connect(username, SIGNAL(editingFinished()), this, SLOT(onServerUserFieldChanged()));
ui->serverUsersTable->setCellWidget(ui->serverUsersTable->rowCount() - 1, 0, username);
QLineEdit* password = new QLineEdit();
password->setProperty("row", (int)ui->serverUsersTable->rowCount() - 1);
password->setProperty("col", (int)1);
password->setEchoMode(QLineEdit::PasswordEchoOnEdit);
password->setText(pass);
connect(password, SIGNAL(editingFinished()), this, SLOT(onServerUserFieldChanged()));
ui->serverUsersTable->setCellWidget(ui->serverUsersTable->rowCount() - 1, 1, password);
QComboBox* comboBox = new QComboBox();
comboBox->insertItems(0, { "Full User","Full with no TX","Monitor only" });
comboBox->setProperty("row", (int)ui->serverUsersTable->rowCount() - 1);
comboBox->setProperty("col", (int)2);
comboBox->setCurrentIndex(type);
connect(comboBox, SIGNAL(currentIndexChanged(int)), this, SLOT(onServerUserFieldChanged()));
ui->serverUsersTable->setCellWidget(ui->serverUsersTable->rowCount() - 1, 2, comboBox);
QPushButton* button = new QPushButton();
button->setText("Delete");
button->setProperty("row", (int)ui->serverUsersTable->rowCount() - 1);
button->setProperty("col", (int)3);
connect(button, SIGNAL(clicked()), this, SLOT(onServerUserFieldChanged()));
ui->serverUsersTable->setCellWidget(ui->serverUsersTable->rowCount() - 1, 3, button);
ui->serverUsersTable->blockSignals(false);
}
// Utility Functions:
void settingswidget::updateUnderlayMode()
{
quietlyUpdateRadiobutton(ui->underlayNone, false);
quietlyUpdateRadiobutton(ui->underlayPeakHold, false);
quietlyUpdateRadiobutton(ui->underlayPeakBuffer, false);
quietlyUpdateRadiobutton(ui->underlayAverageBuffer, false);
switch(prefs->underlayMode) {
case underlayNone:
quietlyUpdateRadiobutton(ui->underlayNone, true);
ui->underlayBufferSlider->setDisabled(true);
break;
case underlayPeakHold:
quietlyUpdateRadiobutton(ui->underlayPeakHold, true);
ui->underlayBufferSlider->setDisabled(true);
break;
case underlayPeakBuffer:
quietlyUpdateRadiobutton(ui->underlayPeakBuffer, true);
ui->underlayBufferSlider->setEnabled(true);
break;
case underlayAverageBuffer:
quietlyUpdateRadiobutton(ui->underlayAverageBuffer, true);
ui->underlayBufferSlider->setEnabled(true);
break;
default:
qWarning() << "Do not understand underlay mode: " << (unsigned int) prefs->underlayMode;
}
}
void settingswidget::quietlyUpdateSlider(QSlider *sl, int val)
{
sl->blockSignals(true);
if( (val >= sl->minimum()) && (val <= sl->maximum()) )
sl->setValue(val);
sl->blockSignals(false);
}
void settingswidget::quietlyUpdateSpinbox(QSpinBox *sb, int val)
{
sb->blockSignals(true);
if( (val >= sb->minimum()) && (val <= sb->maximum()) )
sb->setValue(val);
sb->blockSignals(false);
}
void settingswidget::quietlyUpdateCheckbox(QCheckBox *cb, bool isChecked)
{
cb->blockSignals(true);
cb->setChecked(isChecked);
cb->blockSignals(false);
}
void settingswidget::quietlyUpdateRadiobutton(QRadioButton *rb, bool isChecked)
{
rb->blockSignals(true);
rb->setChecked(isChecked);
rb->blockSignals(false);
}
void settingswidget::quietlyUpdateLineEdit(QLineEdit *le, const QString text)
{
le->blockSignals(true);
le->setText(text);
le->blockSignals(false);
}
// Resulting from User Interaction
void settingswidget::on_debugBtn_clicked()
{
qDebug(logGui()) << "Debug button pressed in settings widget.";
}
void settingswidget::on_settingsList_currentRowChanged(int currentRow)
{
ui->settingsStack->setCurrentIndex(currentRow);
}
void settingswidget::onServerUserFieldChanged()
{
if(!haveServerConfig) {
qCritical(logGui()) << "Do not have serverConfig, cannot edit users.";
return;
}
int row = sender()->property("row").toInt();
int col = sender()->property("col").toInt();
qDebug() << "Server User field col" << col << "row" << row << "changed";
// This is a new user line so add to serverUsersTable
if (serverConfig->users.length() <= row)
{
qInfo() << "Something bad has happened, serverConfig.users is shorter than table!";
}
else
{
if (col == 0)
{
QLineEdit* username = (QLineEdit*)ui->serverUsersTable->cellWidget(row, 0);
if (username->text() != serverConfig->users[row].username) {
serverConfig->users[row].username = username->text();
}
}
else if (col == 1)
{
QLineEdit* password = (QLineEdit*)ui->serverUsersTable->cellWidget(row, 1);
QByteArray pass;
passcode(password->text(), pass);
if (QString(pass) != serverConfig->users[row].password) {
serverConfig->users[row].password = pass;
}
}
else if (col == 2)
{
QComboBox* comboBox = (QComboBox*)ui->serverUsersTable->cellWidget(row, 2);
serverConfig->users[row].userType = comboBox->currentIndex();
}
else if (col == 3)
{
serverConfig->users.removeAt(row);
ui->serverUsersTable->setRowCount(0);
foreach(SERVERUSER user, serverConfig->users)
{
serverAddUserLine(user.username, user.password, user.userType);
}
}
if (row == ui->serverUsersTable->rowCount() - 1) {
ui->serverAddUserBtn->setEnabled(true);
}
}
}
void settingswidget::on_lanEnableBtn_clicked(bool checked)
{
// TODO: prefs.enableLAN = checked;
// TOTO? ui->connectBtn->setEnabled(true); // move to other side
ui->ipAddressTxt->setEnabled(checked);
ui->controlPortTxt->setEnabled(checked);
ui->usernameTxt->setEnabled(checked);
ui->passwordTxt->setEnabled(checked);
ui->audioRXCodecCombo->setEnabled(checked);
ui->audioTXCodecCombo->setEnabled(checked);
ui->audioSampleRateCombo->setEnabled(checked);
ui->rxLatencySlider->setEnabled(checked);
ui->txLatencySlider->setEnabled(checked);
ui->rxLatencyValue->setEnabled(checked);
ui->txLatencyValue->setEnabled(checked);
ui->audioOutputCombo->setEnabled(checked);
ui->audioInputCombo->setEnabled(checked);
ui->baudRateCombo->setEnabled(!checked);
ui->serialDeviceListCombo->setEnabled(!checked);
ui->serverRXAudioInputCombo->setEnabled(!checked);
ui->serverTXAudioOutputCombo->setEnabled(!checked);
ui->useRTSforPTTchk->setEnabled(!checked);
prefs->enableLAN = checked;
emit changedLanPref(l_enableLAN);
}
void settingswidget::on_serialEnableBtn_clicked(bool checked)
{
prefs->enableLAN = !checked;
ui->serialDeviceListCombo->setEnabled(checked);
ui->ipAddressTxt->setEnabled(!checked);
ui->controlPortTxt->setEnabled(!checked);
ui->usernameTxt->setEnabled(!checked);
ui->passwordTxt->setEnabled(!checked);
ui->audioRXCodecCombo->setEnabled(!checked);
ui->audioTXCodecCombo->setEnabled(!checked);
ui->audioSampleRateCombo->setEnabled(!checked);
ui->rxLatencySlider->setEnabled(!checked);
ui->txLatencySlider->setEnabled(!checked);
ui->rxLatencyValue->setEnabled(!checked);
ui->txLatencyValue->setEnabled(!checked);
ui->audioOutputCombo->setEnabled(!checked);
ui->audioInputCombo->setEnabled(!checked);
ui->baudRateCombo->setEnabled(checked);
ui->serialDeviceListCombo->setEnabled(checked);
ui->serverRXAudioInputCombo->setEnabled(checked);
ui->serverTXAudioOutputCombo->setEnabled(checked);
ui->useRTSforPTTchk->setEnabled(checked);
emit changedLanPref(l_enableLAN);
}
void settingswidget::on_autoSSBchk_clicked(bool checked)
{
prefs->automaticSidebandSwitching = checked;
emit changedCtPref(ct_automaticSidebandSwitching);
}
void settingswidget::on_useSystemThemeChk_clicked(bool checked)
{
prefs->useSystemTheme = checked;
emit changedIfPrefs(if_useSystemTheme);
}
void settingswidget::on_enableUsbChk_clicked(bool checked)
{
prefs->enableUSBControllers = checked;
ui->usbControllerBtn->setEnabled(checked);
ui->usbButtonsResetBtn->setEnabled(checked);
ui->usbCommandsResetBtn->setEnabled(checked);
ui->usbResetLbl->setVisible(checked);
emit changedCtPref(ct_enableUSBControllers);
}
void settingswidget::on_usbControllerBtn_clicked()
{
emit showUSBControllerSetup();
}
void settingswidget::on_autoPollBtn_clicked(bool checked)
{
if(checked)
{
prefs->polling_ms = 0;
emit changedRaPref(ra_polling_ms);
ui->pollTimeMsSpin->setEnabled(false);
}
}
void settingswidget::on_manualPollBtn_clicked(bool checked)
{
if(checked)
{
ui->pollTimeMsSpin->setEnabled(true);
prefs->polling_ms = ui->pollTimeMsSpin->value();
emit changedRaPref(ra_polling_ms);
} else {
// Do we need this...
// prefs.polling_ms = 0;
// emit changedRaPref(ra_polling_ms);
}
}
void settingswidget::on_pollTimeMsSpin_valueChanged(int val)
{
prefs->polling_ms = val;
emit changedRaPref(ra_polling_ms);
}
void settingswidget::on_serialDeviceListCombo_activated(const QString &arg1)
{
QString manualPort;
bool ok;
if(arg1==QString("Manual..."))
{
manualPort = QInputDialog::getText(this, tr("Manual port assignment"),
tr("Enter serial port assignment:"),
QLineEdit::Normal,
tr("/dev/device"), &ok);
if(manualPort.isEmpty() || !ok)
{
ui->serialDeviceListCombo->blockSignals(true);
ui->serialDeviceListCombo->setCurrentIndex(0);
ui->serialDeviceListCombo->blockSignals(false);
return;
} else {
prefs->serialPortRadio = manualPort;
qInfo(logGui()) << "Setting preferences to use manually-assigned serial port: " << manualPort;
ui->serialEnableBtn->setChecked(true);
emit changedRaPref(ra_serialPortRadio);
return;
}
}
if(arg1==QString("Auto"))
{
prefs->serialPortRadio = "auto";
qInfo(logGui()) << "Setting preferences to automatically find rig serial port.";
ui->serialEnableBtn->setChecked(true);
emit changedRaPref(ra_serialPortRadio);
return;
}
prefs->serialPortRadio = arg1;
qInfo(logGui()) << "Setting preferences to use manually-assigned serial port: " << arg1;
ui->serialEnableBtn->setChecked(true);
emit changedRaPref(ra_serialPortRadio);
}
void settingswidget::on_baudRateCombo_activated(int index)
{
bool ok = false;
quint32 baud = ui->baudRateCombo->currentData().toUInt(&ok);
if(ok)
{
prefs->serialPortBaud = baud;
qInfo(logGui()) << "Changed baud rate to" << baud << "bps. Press Save Settings to retain.";
emit changedRaPref(ra_serialPortBaud);
}
(void)index;
}
void settingswidget::on_vspCombo_activated(int index)
{
Q_UNUSED(index);
prefs->virtualSerialPort = ui->vspCombo->currentText();
emit changedRaPref(ra_virtualSerialPort);
}
void settingswidget::on_audioSystemCombo_currentIndexChanged(int value)
{
prefs->audioSystem = static_cast<audioType>(value);
ui->audioSystemServerCombo->blockSignals(true);
ui->audioSystemServerCombo->setCurrentIndex(value);
ui->audioSystemServerCombo->blockSignals(false);
emit changedRaPref(ra_audioSystem);
}
void settingswidget::on_audioSystemServerCombo_currentIndexChanged(int value)
{
prefs->audioSystem = static_cast<audioType>(value);
ui->audioSystemCombo->blockSignals(true);
ui->audioSystemCombo->setCurrentIndex(value);
ui->audioSystemCombo->blockSignals(false);
emit changedRaPref(ra_audioSystem);
}
void settingswidget::on_meter2selectionCombo_currentIndexChanged(int index)
{
prefs->meter2Type = static_cast<meterKind>(ui->meter2selectionCombo->itemData(index).toInt());
emit changedIfPref(if_meter2Type);
}
void settingswidget::on_tuningFloorZerosChk_clicked(bool checked)
{
prefs->niceTS = checked;
emit changedCtPref(ct_niceTS);
}
void settingswidget::on_fullScreenChk_clicked(bool checked)
{
prefs->useFullScreen = checked;
emit changedIfPref(if_useFullScreen);
}
void settingswidget::on_wfAntiAliasChk_clicked(bool checked)
{
prefs->wfAntiAlias = checked;
emit changedIfPref(if_wfAntiAlias);
}
void settingswidget::on_wfInterpolateChk_clicked(bool checked)
{
prefs->wfInterpolate = checked;
emit changedIfPref(if_wfInterpolate);
}
void settingswidget::on_underlayNone_clicked(bool checked)
{
if(checked)
{
prefs->underlayMode = underlayNone;
ui->underlayBufferSlider->setDisabled(true);
emit changedIfPref(if_underlayMode);
}
}
void settingswidget::on_underlayPeakHold_clicked(bool checked)
{
if(checked)
{
prefs->underlayMode = underlayPeakHold;
ui->underlayBufferSlider->setDisabled(true);
emit changedIfPref(if_underlayMode);
}
}
void settingswidget::on_underlayPeakBuffer_clicked(bool checked)
{
if(checked)
{
prefs->underlayMode = underlayPeakBuffer;
ui->underlayBufferSlider->setEnabled(true);
emit changedIfPref(if_underlayMode);
}
}
void settingswidget::on_underlayAverageBuffer_clicked(bool checked)
{
if(checked)
{
prefs->underlayMode = underlayAverageBuffer;
ui->underlayBufferSlider->setEnabled(true);
emit changedIfPref(if_underlayMode);
}
}
void settingswidget::on_underlayBufferSlider_valueChanged(int value)
{
prefs->underlayBufferSize = value;
emit changedIfPref(if_underlayBufferSize);
}
void settingswidget::on_pttEnableChk_clicked(bool checked)
{
prefs->enablePTT = checked;
emit changedCtPref(ct_enablePTT);
}
void settingswidget::on_clickDragTuningEnableChk_clicked(bool checked)
{
prefs->clickDragTuningEnable = checked;
emit changedIfPref(if_clickDragTuningEnable);
}
void settingswidget::on_enableRigctldChk_clicked(bool checked)
{
prefs->enableRigCtlD = checked;
emit changedLanPref(l_enableRigCtlD);
}
void settingswidget::on_rigctldPortTxt_editingFinished()
{
bool okconvert = false;
unsigned int port = ui->rigctldPortTxt->text().toUInt(&okconvert);
if (okconvert)
{
prefs->rigCtlPort = port;
emit changedLanPref(l_rigCtlPort);
}
}
void settingswidget::on_tcpServerPortTxt_editingFinished()
{
bool okconvert = false;
unsigned int port = ui->tcpServerPortTxt->text().toUInt(&okconvert);
if (okconvert)
{
prefs->tcpPort = port;
emit changedLanPref(l_tcpPort);
}
}
void settingswidget::on_clusterServerNameCombo_currentIndexChanged(int index)
{
if (index < 0)
return;
if(!haveClusterList)
qWarning(logGui()) << "Do not have cluster list yet. Editing may not work.";
QString text = ui->clusterServerNameCombo->currentText();
if (clusters.size() <= index)
{
qInfo(logGui) << "Adding Cluster server" << text;
clusterSettings c;
c.server = text;
clusters.append(c);
ui->clusterTcpPortLineEdit->setEnabled(true);
ui->clusterUsernameLineEdit->setEnabled(true);
ui->clusterPasswordLineEdit->setEnabled(true);
ui->clusterTimeoutLineEdit->setEnabled(true);
}
else {
qInfo(logGui) << "Editing Cluster server" << text;
clusters[index].server = text;
}
ui->clusterUsernameLineEdit->blockSignals(true);
ui->clusterPasswordLineEdit->blockSignals(true);
ui->clusterTimeoutLineEdit->blockSignals(true);
ui->clusterTcpPortLineEdit->setText(QString::number(clusters[index].port));
ui->clusterUsernameLineEdit->setText(clusters[index].userName);
ui->clusterPasswordLineEdit->setText(clusters[index].password);
ui->clusterTimeoutLineEdit->setText(QString::number(clusters[index].timeout));
ui->clusterUsernameLineEdit->blockSignals(false);
ui->clusterPasswordLineEdit->blockSignals(false);
ui->clusterTimeoutLineEdit->blockSignals(false);
for (int i = 0; i < clusters.size(); i++) {
if (i == index)
clusters[i].isdefault = true;
else
clusters[i].isdefault = false;
}
// For reference, here is what the code on the other side is basically doing:
// emit setClusterServerName(clusters[index].server);
// emit setClusterTcpPort(clusters[index].port);
// emit setClusterUserName(clusters[index].userName);
// emit setClusterPassword(clusters[index].password);
// emit setClusterTimeout(clusters[index].timeout);
// We are using the not-arrayed data in preferences
// to communicate the current cluster information:
prefs->clusterTcpServerName = clusters[index].server;
prefs->clusterTcpPort = clusters[index].port;
prefs->clusterTcpUserName = clusters[index].userName;
prefs->clusterTcpPassword = clusters[index].password;
prefs->clusterTimeout = clusters[index].timeout;
prefs->clusterTcpEnable = ui->clusterTcpEnable->isChecked();
emit changedClusterPrefs(cl_clusterTcpServerName |
cl_clusterTcpPort |
cl_clusterTcpUserName |
cl_clusterTcpPassword |
cl_clusterTimeout |
cl_clusterTcpEnable);
}
void settingswidget::on_clusterUdpEnable_clicked(bool checked)
{
prefs->clusterUdpEnable = checked;
emit changedClusterPref(cl_clusterUdpEnable);
}
void settingswidget::on_clusterTcpEnable_clicked(bool checked)
{
prefs->clusterTcpEnable = checked;
emit changedClusterPref(cl_clusterTcpEnable);
}
void settingswidget::on_clusterTcpSetNowBtn_clicked()
{
// Maybe this will be easier than "hit enter" ?
int index = ui->clusterServerNameCombo->currentIndex();
on_clusterServerNameCombo_currentIndexChanged(index);
}
void settingswidget::on_clusterServerNameCombo_currentTextChanged(const QString &text)
{
if (text.isEmpty()) {
int index = ui->clusterServerNameCombo->currentIndex();
ui->clusterServerNameCombo->removeItem(index);
clusters.removeAt(index);
if (clusters.size() == 0)
{
ui->clusterTcpPortLineEdit->setEnabled(false);
ui->clusterUsernameLineEdit->setEnabled(false);
ui->clusterPasswordLineEdit->setEnabled(false);
ui->clusterTimeoutLineEdit->setEnabled(false);
}
}
}
void settingswidget::on_clusterTcpPortLineEdit_editingFinished()
{
int index = ui->clusterServerNameCombo->currentIndex();
if (index < clusters.size())
{
clusters[index].port = ui->clusterTcpPortLineEdit->displayText().toInt();
//emit setClusterTcpPort(clusters[index].port);
prefs->clusterTcpPort = clusters[index].port;
emit changedClusterPref(cl_clusterTcpPort);
}
}
void settingswidget::on_clusterUsernameLineEdit_editingFinished()
{
int index = ui->clusterServerNameCombo->currentIndex();
if (index < clusters.size())
{
clusters[index].userName = ui->clusterUsernameLineEdit->text();
//emit setClusterUserName(clusters[index].userName);
prefs->clusterTcpUserName = clusters[index].userName;
emit changedClusterPref(cl_clusterTcpUserName);
}
}
void settingswidget::on_clusterPasswordLineEdit_editingFinished()
{
int index = ui->clusterServerNameCombo->currentIndex();
if (index < clusters.size())
{
clusters[index].password = ui->clusterPasswordLineEdit->text();
//emit setClusterPassword(clusters[index].password);
prefs->clusterTcpPassword = clusters[index].password;
emit changedClusterPref(cl_clusterTcpPassword);
}
}
void settingswidget::on_clusterTimeoutLineEdit_editingFinished()
{
int index = ui->clusterServerNameCombo->currentIndex();
if (index < clusters.size())
{
clusters[index].timeout = ui->clusterTimeoutLineEdit->displayText().toInt();
//emit setClusterTimeout(clusters[index].timeout);
prefs->clusterTimeout = clusters[index].timeout;
emit changedClusterPref(cl_clusterTimeout);
}
}
void settingswidget::on_clusterUdpPortLineEdit_editingFinished()
{
bool ok = false;
int p = ui->clusterUdpPortLineEdit->text().toInt(&ok);
if(ok)
{
prefs->clusterUdpPort = p;
emit changedClusterPref(cl_clusterUdpPort);
}
}
void settingswidget::on_clusterSkimmerSpotsEnable_clicked(bool checked)
{
prefs->clusterSkimmerSpotsEnable = checked;
emit changedClusterPref(cl_clusterSkimmerSpotsEnable);
}
void settingswidget::on_ipAddressTxt_textChanged(const QString &arg1)
{
udpPrefs->ipAddress = arg1;
emit changedUdpPref(u_ipAddress);
}
void settingswidget::on_usernameTxt_textChanged(const QString &arg1)
{
udpPrefs->username = arg1;
emit changedUdpPref(u_username);
}
void settingswidget::on_controlPortTxt_textChanged(const QString &arg1)
{
bool ok = false;
int port = arg1.toUInt(&ok);
if(ok)
{
udpPrefs->controlLANPort = port;
emit changedUdpPref(u_controlLANPort);
}
}
void settingswidget::on_passwordTxt_textChanged(const QString &arg1)
{
udpPrefs->password = arg1;
emit changedUdpPref(u_password);
}
void settingswidget::on_audioDuplexCombo_currentIndexChanged(int index)
{
udpPrefs->halfDuplex = (bool)index;
emit changedUdpPref(u_halfDuplex);
}
void settingswidget::on_audioOutputCombo_currentIndexChanged(int index)
{
emit changedAudioOutputCombo(index);
}
void settingswidget::on_audioInputCombo_currentIndexChanged(int index)
{
emit changedAudioInputCombo(index);
}
void settingswidget::on_serverRXAudioInputCombo_currentIndexChanged(int index)
{
emit changedServerRXAudioInputCombo(index);
}
void settingswidget::on_serverTXAudioOutputCombo_currentIndexChanged(int index)
{
emit changedServerTXAudioOutputCombo(index);
}
void settingswidget::on_serverEnableCheckbox_clicked(bool checked)
{
serverConfig->enabled = checked;
emit changedServerConfig(s_enabled);
}
void settingswidget::on_serverAddUserBtn_clicked()
{
if(!haveServerConfig)
{
qCritical(logGui()) << "Cannot modify users without valid serverConfig.";
return;
}
serverAddUserLine("", "", 0);
SERVERUSER user;
user.username = "";
user.password = "";
user.userType = 0;
serverConfig->users.append(user);
ui->serverAddUserBtn->setEnabled(false);
}