// list_sas_resources.cpp // // List SAS Resources. // // (C) Copyright 2002-2018 Fred Gleason // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License version 2 as // published by the Free Software Foundation. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public // License along with this program; if not, write to the Free Software // Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. // #include #include #include #include #include #include #include #include #include #include #include ListSasResources::ListSasResources(RDMatrix *matrix,int size,QWidget *parent) : QDialog(parent) { setModal(true); QString sql; QString str; list_matrix=matrix; list_size=size; setWindowTitle("RDAdmin - "+tr("SAS Switches")); // // Fix the Window Size // setMinimumWidth(sizeHint().width()); setMaximumWidth(sizeHint().width()); setMinimumHeight(sizeHint().height()); setMaximumHeight(sizeHint().height()); // // Create Fonts // QFont bold_font=QFont("Helvetica",12,QFont::Bold); bold_font.setPixelSize(12); QFont font=QFont("Helvetica",12,QFont::Normal); font.setPixelSize(12); // // Resources List Box // list_list_view=new Q3ListView(this); list_list_view-> setGeometry(10,24,sizeHint().width()-20,sizeHint().height()-94); QLabel *label= new QLabel(list_list_view,list_table,this); label->setFont(bold_font); label->setGeometry(14,5,85,19); list_list_view->setAllColumnsShowFocus(true); list_list_view->setItemMargin(5); list_list_view->addColumn(tr("GPIO LINE")); list_list_view->setColumnAlignment(0,Qt::AlignHCenter); list_list_view->addColumn(tr("CONSOLE")); list_list_view->setColumnAlignment(1,Qt::AlignHCenter); list_list_view->addColumn(tr("SOURCE")); list_list_view->setColumnAlignment(2,Qt::AlignHCenter); list_list_view->addColumn(tr("OPTO/RELAY")); list_list_view->setColumnAlignment(3,Qt::AlignHCenter); connect(list_list_view, SIGNAL(doubleClicked(Q3ListViewItem *,const QPoint &,int)), this, SLOT(doubleClickedData(Q3ListViewItem *,const QPoint &,int))); // // Edit Button // QPushButton *button=new QPushButton(this); button->setGeometry(10,sizeHint().height()-60,80,50); button->setFont(bold_font); button->setText(tr("&Edit")); connect(button,SIGNAL(clicked()),this,SLOT(editData())); // // Ok Button // button=new QPushButton(this); button->setGeometry(sizeHint().width()-180,sizeHint().height()-60,80,50); button->setDefault(true); button->setFont(bold_font); button->setText(tr("&OK")); connect(button,SIGNAL(clicked()),this,SLOT(okData())); // // Cancel Button // button=new QPushButton(this); button->setGeometry(sizeHint().width()-90,sizeHint().height()-60, 80,50); button->setFont(bold_font); button->setText(tr("&Cancel")); connect(button,SIGNAL(clicked()),this,SLOT(cancelData())); // // Load Values // RefreshList(); } QSize ListSasResources::sizeHint() const { return QSize(400,250); } QSizePolicy ListSasResources::sizePolicy() const { return QSizePolicy(QSizePolicy::Fixed,QSizePolicy::Fixed); } void ListSasResources::editData() { int engine_num=-1; int device_num=-1; int relay_num=-1; Q3ListViewItem *item=list_list_view->selectedItem(); if(item==NULL) { return; } if(!item->text(1).isEmpty()) { engine_num=item->text(1).toInt(); } if(!item->text(2).isEmpty()) { device_num=item->text(2).toInt(); } if(!item->text(3).isEmpty()) { relay_num=item->text(3).toInt(); } EditSasResource *dialog= new EditSasResource(&engine_num,&device_num,&relay_num,this); if(dialog->exec()==0) { if(engine_num>=0) { item->setText(1,QString().sprintf("%d",engine_num)); } else { item->setText(1,""); } if(device_num>=0) { item->setText(2,QString().sprintf("%d",device_num)); } else { item->setText(2,""); } if(relay_num>=0) { item->setText(3,QString().sprintf("%d",relay_num)); } else { item->setText(3,""); } } delete dialog; } void ListSasResources::doubleClickedData(Q3ListViewItem *item, const QPoint &pt,int col) { editData(); } void ListSasResources::okData() { QString sql; RDSqlQuery *q; int engine_num=-1; int device_num=-1; int surface_num=-1; int relay_num=-1; Q3ListViewItem *item=list_list_view->firstChild(); while(item!=NULL) { engine_num=-1; device_num=-1; surface_num=-1; relay_num=-1; if(!item->text(1).isEmpty()) { engine_num=item->text(1).toInt(); } if(!item->text(2).isEmpty()) { device_num=item->text(2).toInt(); } if(!item->text(3).isEmpty()) { relay_num=item->text(3).toInt(); } sql=QString("select ID from VGUEST_RESOURCES where" )+ "(STATION_NAME=\""+RDEscapeString(list_matrix->station())+"\")&&"+ QString().sprintf("(MATRIX_NUM=%d)&&",list_matrix->matrix())+ QString().sprintf("(NUMBER=%d)",item->text(0).toInt()); q=new RDSqlQuery(sql); if(q->first()) { sql=QString("update VGUEST_RESOURCES set ")+ QString().sprintf("ENGINE_NUM=%d,",engine_num)+ QString().sprintf("DEVICE_NUM=%d,",device_num)+ QString().sprintf("SURFACE_NUM=%d,",surface_num)+ QString().sprintf("RELAY_NUM=%d where ",relay_num)+ "(STATION_NAME=\""+RDEscapeString(list_matrix->station())+"\")&&"+ QString().sprintf("(MATRIX_NUM=%d)&&",list_matrix->matrix())+ QString().sprintf("(NUMBER=%d)",item->text(0).toInt()); } else { sql=QString("insert into VGUEST_RESOURCES set ")+ "STATION_NAME=\""+RDEscapeString(list_matrix->station())+"\","+ QString().sprintf("MATRIX_NUM=%d,",list_matrix->matrix())+ QString().sprintf("NUMBER=%d,",item->text(0).toInt())+ QString().sprintf("ENGINE_NUM=%d,",engine_num)+ QString().sprintf("DEVICE_NUM=%d,",device_num)+ QString().sprintf("SURFACE_NUM=%d,",surface_num)+ QString().sprintf("RELAY_NUM=%d",relay_num); } q=new RDSqlQuery(sql); delete q; item=item->nextSibling(); } done(0); } void ListSasResources::cancelData() { done(-1); } void ListSasResources::RefreshList() { QString sql; RDSqlQuery *q; RDSqlQuery *q1; Q3ListViewItem *item; int n=1; int gpis; // // Populate Resource Records // sql=QString("select GPIS from MATRICES where ")+ "(STATION_NAME=\""+RDEscapeString(list_matrix->station())+"\")&&"+ QString().sprintf("(MATRIX=%d)",list_matrix->matrix()); q=new RDSqlQuery(sql); if(!q->first()) { delete q; return; } gpis=q->value(0).toInt(); delete q; for(int i=0;istation())+"\")&&"+ QString().sprintf("(MATRIX_NUM=%d)&&",list_matrix->matrix())+ QString().sprintf("(NUMBER=%d)",i+1); q=new RDSqlQuery(sql); if(!q->first()) { sql=QString("insert into VGUEST_RESOURCES set ")+ QString().sprintf("NUMBER=%d,",i+1)+ "STATION_NAME=\""+RDEscapeString(list_matrix->station())+"\","+ QString().sprintf("MATRIX_NUM=%d",list_matrix->matrix()); q1=new RDSqlQuery(sql); delete q1; } delete q; } sql=QString("select ")+ "NUMBER,"+ "ENGINE_NUM,"+ "DEVICE_NUM,"+ "RELAY_NUM "+ "from VGUEST_RESOURCES where "+ "(STATION_NAME=\""+RDEscapeString(list_matrix->station())+"\")&&"+ QString().sprintf("(MATRIX_NUM=%d)",list_matrix->matrix())+ "order by NUMBER"; q=new RDSqlQuery(sql); list_list_view->clear(); while(q->next()) { while(q->value(0).toInt()>n) { item=new Q3ListViewItem(list_list_view); item->setText(0,QString().sprintf("%03d",n++)); } item=new Q3ListViewItem(list_list_view); item->setText(0,QString().sprintf("%03d",q->value(0).toInt())); if(q->value(1).toInt()>=0) { item->setText(1,QString().sprintf("%d",q->value(1).toInt())); } if(q->value(2).toInt()>=0) { item->setText(2,QString().sprintf("%d",q->value(2).toInt())); } if(q->value(3).toInt()>=0) { item->setText(3,QString().sprintf("%d",q->value(3).toInt())); } n++; } for(int i=n;i<(list_size+1);i++) { item=new Q3ListViewItem(list_list_view); item->setText(0,QString().sprintf("%03d",i)); } delete q; }