]> ruin.nu Git - hbs.git/blobdiff - bs/bsview.cpp
some changes
[hbs.git] / bs / bsview.cpp
index 7ad7e19b64e661502b4baf0af9d901a21dff51d2..5ae770305468a68475a8c3b62b03ad02c4eed9d0 100644 (file)
  *                                                                         *
  ***************************************************************************/
 
-#include "bcview.h"
+#include "bsview.h"
 
-#include "bcmainview.h"
-#include "scanview.h"
-#include "ui/infoview.h"
-#include "tickview.h"
+//standard library
+#include <iostream>
+#include <map>
+#include <vector>
+#include <string>
+
+using namespace std;
 
 //QT includes
 #include <qlistview.h>
 #include <qwidgetstack.h>
 
-BcView::BcView(QWidget *parent, BcDoc *doc) : QSplitter(parent)
+#include "battlesum.h"
+#include "scanview.h"
+#include "ui/infoview.h"
+#include "tickview.h"
+#include "fleetview.h"
+#include "fleet.h"
+
+BSView::BSView(QWidget *parent, BSDoc *doc) : QSplitter(parent)
 {
   /** connect doc with the view*/
-  connect(doc, SIGNAL(documentChanged()), this, SLOT(slotDocumentChanged()));
+       connect(doc, SIGNAL(documentChanged()), this, SLOT(slotDocumentChanged()));
        
+       m_doc = doc;
        
        m_LeftSplit = new QSplitter(QSplitter::Vertical, this);
        m_RightSplit = new QSplitter(QSplitter::Vertical, this);
 
        //setting up the listview
        m_NumberView = new QListView(m_LeftSplit);
+       m_NumberView->setRootIsDecorated(true);  
        m_NumberView->addColumn("Name");
        m_NumberView->addColumn("Number");
        m_NumberView->addColumn("ETA");
-       addBattle("test");
+       //addBattle("NO BATTLES");
 
+       
+       
+       connect(m_NumberView, SIGNAL(expanded(QListViewItem*)), SLOT(slotItemExpanded(QListViewItem*)));
+       connect(m_NumberView, SIGNAL(collapsed(QListViewItem*)), SLOT(slotItemCollapsed(QListViewItem*)));
+       
        m_InfoView = new InfoView(m_LeftSplit);
+
+       vector<QString> raceNames;
+       const map<string, vector<int> >& races = Fleet::Races();
+       for(map<string, vector<int> >::const_iterator i = races.begin(); i != races.end(); ++i)
+       {
+               raceNames.push_back(i->first.c_str());
+       }
+       m_InfoView->setRaces(raceNames);
        
        //the right side
        m_TickView = new TickView(m_RightSplit);
        m_FleetViews = new QWidgetStack(m_RightSplit);
        m_ScanView = new ScanView(m_RightSplit);
        
-       //the widget stack
-       m_BcMainView = new BcMainView();
-       m_FleetViews->addWidget(m_BcMainView, 0);
+       Fleet fl1;
+       //fl1.setRace(tr("Terran").latin1());
+       fl1.setRace("Terran");
+       Fleet fl2;
+       fl2.setRace(tr("Generic").latin1());
 
+       //the widget stack
+       m_BattleSum = new BattleSum();
+       m_FleetViews->addWidget(m_BattleSum, 0);
+       m_FleetView = new FleetView(fl1, true, true);
+       m_FleetViews->addWidget(m_FleetView, 1);
+       m_GenericFleetView = new FleetView(fl2, true, false);
+       m_FleetViews->addWidget(m_GenericFleetView, 2);
        //m_FleetViews->raiseWidget(0);
        connect(m_NumberView, SIGNAL(selectionChanged(QListViewItem *)), SLOT(slotFleetSelection(QListViewItem *))); 
 }
 
-BcView::~BcView()
+BSView::~BSView()
 {
 }
 
-void BcView::addBattle(QString name)
+//////////////////////////////////////////////////////////////////////////
+//
+void BSView::addBattle(QString name)
 {
-       QListViewItem *battle = new QListViewItem(m_NumberView, name);
-       (void) new QListViewItem(battle, "Defenders");
-       (void) new QListViewItem(battle, "Attackers");
+       QListViewItem* battle = new QListViewItem(m_NumberView, name);
+       QListViewItem* def = new QListViewItem(battle, tr("Friendly"),"", "","1");
+       (void) new QListViewItem(battle, tr("Hostile"),"", "","2");
+       (void) new QListViewItem(def, tr("Home Planet"), "","","1");
 }
 
-void BcView::slotDocumentChanged()
+///////////////////////////////////////////////////////////////////////////////
+//
+/***This function clears the listview and then iterates through the battles
+ * and recreates the listview hierarchy.
+ */
+void BSView::slotDocumentChanged()
 {
-  //TODO update the view
+       m_NumberView->clear();
+       
+       const map<QString, map<QString, map<QString, Fleet> > >& battles = m_doc->battles();    
+
+       for (map<QString, map<QString, map<QString, Fleet> > >::const_iterator i = battles.begin(); i != battles.end(); ++i)
+       {
+               QString b = (*i).first;
+               QListViewItem* battle = new QListViewItem(m_NumberView, b);
+               battle->setOpen(m_TreeExpanded[b]["--"]);
+                       
+
+               for (map<QString, map<QString, Fleet> >::const_iterator j = i->second.begin(); j != i->second.end(); ++j)
+               {
+                       QString g = (*j).first;
+                       QListViewItem* group = new QListViewItem(battle, g);
+                       int groupShips = 0;
+                       group->setOpen(m_TreeExpanded[b][g]);
 
+                       for (map<QString, Fleet>::const_iterator k = j->second.begin(); k != j->second.end(); ++k)
+                       {       
+                               int ships = k->second.NumberOfShips();
+                               groupShips += ships;
+                               (void) new QListViewItem(group, (*k).first, QString("%1").arg(ships), QString("%1").arg(k->second.ETA()));
+                       }
+                       group->setText(1, QString("%1").arg(groupShips));
+               }
+       }
 }
-/** No descriptions */
-void BcView::slotFleetSelection(QListViewItem *lvi){
+
+//////////////////////////////////////////////////////////////////////////////
+//
+void BSView::slotFleetSelection(QListViewItem *lvi)
+{
+       //cout << lvi->parent()->text(2).toLocal8bit() << endl;
+//     for (int i = 0; i < 5; i++)
+//             cout << lvi->text(i).local8Bit() << endl;
+       
+
        if (lvi->parent() == '\0')
        {
                m_FleetViews->raiseWidget(0);
        }
        else if (lvi->parent()->parent() == '\0')
        {
-               m_FleetViews->raiseWidget(1);
+//                     m_FleetView->slotHomePlanet(false);
+               if (lvi->text(0) == tr("Friendly"))
+               {
+//                     m_FleetView->slotAttacker(false);
+               }
+               else
+               {
+//                     m_FleetView->slotAttacker(true);
+               }
+               m_FleetViews->raiseWidget(2);
+               
+       }
+       else
+       {
+               bool home = false;
+               bool friendly = false;
+               QString fleet = lvi->text(0);
+               QString group = lvi->parent()->text(0);
+               QString battle = lvi->parent()->parent()->text(0);
+               if ( group == tr("Friendly"))
+               {
+                       friendly = true;
+                       if ( fleet == tr("Home Planet"))
+                       {
+                               home = true;
+                       }
+               }
+               Fleet fl = m_doc->specificFleet(battle, group, fleet);
+               m_InfoView->setRace(fl.Race().c_str());
+               m_InfoView->setFleetName(fleet);
+               m_InfoView->setEta(fl.ETA());
+               if (fl.Race() == tr("Generic").latin1())
+               {
+                       m_GenericFleetView->viewFleet(fl, friendly);
+                       m_FleetViews->raiseWidget(2);
+
+               }
+               else 
+               {
+                       if (fl.Race() == m_FleetView->fleet().Race() &&
+                       m_FleetView->isHome() == home)
+                       {
+                               m_FleetView->viewFleet(fl, friendly);
+                       }
+                       else
+                       {
+                               m_FleetViews->removeWidget(m_FleetView);
+                               m_FleetView = new FleetView(fl, friendly, home);
+                               m_FleetViews->addWidget(m_FleetView, 1);
+                       }
+                       m_FleetViews->raiseWidget(1);
+               }
+       }
+}
+
+//////////////////////////////////////////////////////////////////////////
+//
+void BSView::slotItemExpanded(QListViewItem *lvi)
+{
+       if (lvi->parent() == '\0')
+       {
+               m_TreeExpanded[lvi->text(0)]["--"] = true;
+       }
+       else if (lvi->parent()->parent() == '\0')
+       {
+               m_TreeExpanded[lvi->parent()->text(0)][lvi->text(0)] = true;    
+       }
+}
+
+//////////////////////////////////////////////////////////////////////////
+//
+void BSView::slotItemCollapsed(QListViewItem *lvi)
+{
+       if (lvi->parent() == '\0')
+       {
+               m_TreeExpanded[lvi->text(0)]["--"] = false;
+       }
+       else if (lvi->parent()->parent() == '\0')
+       {
+               m_TreeExpanded[lvi->parent()->text(0)][lvi->text(0)] = false;   
        }
-       
 }
+