Qt handles the "..." for too long table rows. Remove this functionality from Transact...
[novacoin.git] / src / qt / addressbookdialog.cpp
index 4f99a3c..6d53ee8 100644 (file)
 AddressBookDialog::AddressBookDialog(Mode mode, QWidget *parent) :
     QDialog(parent),
     ui(new Ui::AddressBookDialog),
-    model(0)
+    model(0),
+    mode(mode)
 {
     ui->setupUi(this);
-
     switch(mode)
     {
     case ForSending:
         connect(ui->receiveTableView, SIGNAL(doubleClicked(QModelIndex)), this, SLOT(on_buttonBox_accepted()));
         connect(ui->sendTableView, SIGNAL(doubleClicked(QModelIndex)), this, SLOT(on_buttonBox_accepted()));
-        break;
-    case ForEditing:
-        connect(ui->receiveTableView, SIGNAL(doubleClicked(QModelIndex)), this, SLOT(on_editButton_clicked()));
-        connect(ui->sendTableView, SIGNAL(doubleClicked(QModelIndex)), this, SLOT(on_editButton_clicked()));
+        ui->sendTableView->setFocus();
         break;
     }
+
+    connect(ui->tabWidget, SIGNAL(currentChanged(int)), this, SLOT(selectionChanged()));
 }
 
 AddressBookDialog::~AddressBookDialog()
@@ -46,6 +45,7 @@ void AddressBookDialog::setModel(AddressTableModel *model)
     receive_model->setFilterRole(AddressTableModel::TypeRole);
     receive_model->setFilterFixedString(AddressTableModel::Receive);
     ui->receiveTableView->setModel(receive_model);
+    ui->receiveTableView->sortByColumn(0, Qt::AscendingOrder);
 
     // Send filter
     QSortFilterProxyModel *send_model = new QSortFilterProxyModel(this);
@@ -54,6 +54,7 @@ void AddressBookDialog::setModel(AddressTableModel *model)
     send_model->setFilterRole(AddressTableModel::TypeRole);
     send_model->setFilterFixedString(AddressTableModel::Send);
     ui->sendTableView->setModel(send_model);
+    ui->sendTableView->sortByColumn(0, Qt::AscendingOrder);
 
     // Set column widths
     ui->receiveTableView->horizontalHeader()->resizeSection(
@@ -64,12 +65,23 @@ void AddressBookDialog::setModel(AddressTableModel *model)
             AddressTableModel::Address, 320);
     ui->sendTableView->horizontalHeader()->setResizeMode(
             AddressTableModel::Label, QHeaderView::Stretch);
+
+    connect(ui->receiveTableView->selectionModel(), SIGNAL(selectionChanged(QItemSelection,QItemSelection)),
+            this, SLOT(selectionChanged()));
+    connect(ui->sendTableView->selectionModel(), SIGNAL(selectionChanged(QItemSelection,QItemSelection)),
+            this, SLOT(selectionChanged()));
+
+    if(mode == ForSending)
+    {
+        // Auto-select first row when in sending mode
+        ui->sendTableView->selectRow(0);
+    }
 }
 
 void AddressBookDialog::setTab(int tab)
 {
     ui->tabWidget->setCurrentIndex(tab);
-    on_tabWidget_currentChanged(tab);
+    selectionChanged();
 }
 
 QTableView *AddressBookDialog::getCurrentTable()
@@ -99,30 +111,6 @@ void AddressBookDialog::on_copyToClipboard_clicked()
     }
 }
 
-void AddressBookDialog::on_editButton_clicked()
-{
-    QModelIndexList indexes = getCurrentTable()->selectionModel()->selectedRows();
-    if(indexes.isEmpty())
-    {
-        return;
-    }
-    // Map selected index to source address book model
-    QAbstractProxyModel *proxy_model = static_cast<QAbstractProxyModel*>(getCurrentTable()->model());
-    QModelIndex selected = proxy_model->mapToSource(indexes.at(0));
-
-    // Double click also triggers edit button
-    EditAddressDialog dlg(
-            ui->tabWidget->currentIndex() == SendingTab ?
-            EditAddressDialog::EditSendingAddress :
-            EditAddressDialog::EditReceivingAddress);
-    dlg.setModel(model);
-    dlg.loadRow(selected.row());
-    if(dlg.exec())
-    {
-        dlg.saveCurrentRow();
-    }
-}
-
 void AddressBookDialog::on_newAddressButton_clicked()
 {
     EditAddressDialog dlg(
@@ -130,24 +118,7 @@ void AddressBookDialog::on_newAddressButton_clicked()
             EditAddressDialog::NewSendingAddress :
             EditAddressDialog::NewReceivingAddress);
     dlg.setModel(model);
-    if(dlg.exec())
-    {
-        dlg.saveCurrentRow();
-    }
-}
-
-void AddressBookDialog::on_tabWidget_currentChanged(int index)
-{
-    // Enable/disable buttons based on selected tab
-    switch(index)
-    {
-    case SendingTab:
-        ui->deleteButton->setEnabled(true);
-        break;
-    case ReceivingTab:
-        ui->deleteButton->setEnabled(false);
-        break;
-    }
+    dlg.exec();
 }
 
 void AddressBookDialog::on_deleteButton_clicked()
@@ -180,3 +151,27 @@ void AddressBookDialog::on_buttonBox_accepted()
     }
 }
 
+void AddressBookDialog::selectionChanged()
+{
+    // Set button states based on selected tab and selection
+    QTableView *table = getCurrentTable();
+
+    if(table->selectionModel()->hasSelection())
+    {
+        switch(ui->tabWidget->currentIndex())
+        {
+        case SendingTab:
+            ui->deleteButton->setEnabled(true);
+            break;
+        case ReceivingTab:
+            ui->deleteButton->setEnabled(false);
+            break;
+        }
+        ui->copyToClipboard->setEnabled(true);
+    }
+    else
+    {
+        ui->deleteButton->setEnabled(false);
+        ui->copyToClipboard->setEnabled(false);
+    }
+}