mirror of
				https://github.com/ElvishArtisan/rivendell.git
				synced 2025-10-29 16:53:53 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			415 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			415 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // svc_rec.cpp
 | |
| //
 | |
| // Calendar widget.
 | |
| //
 | |
| //   (C) Copyright 2002-2018 Fred Gleason <fredg@paravelsystems.com>
 | |
| //
 | |
| //   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 <qwidget.h>
 | |
| #include <qstring.h>
 | |
| #include <qlabel.h>
 | |
| #include <QMouseEvent>
 | |
| #include <qpalette.h>
 | |
| 
 | |
| #include <rddb.h>
 | |
| #include <rdescape_string.h>
 | |
| 
 | |
| #include "svc_rec.h"
 | |
| 
 | |
| //
 | |
| // Global Classes
 | |
| //
 | |
| SvcRec::SvcRec(const QString &svcname,QWidget *parent)
 | |
|   :QWidget(parent)
 | |
| {
 | |
|   QString sql;
 | |
|   RDSqlQuery *q;
 | |
|   pick_service_name=svcname;
 | |
| 
 | |
|   //
 | |
|   // Generate Fonts
 | |
|   //
 | |
|   pick_day_font[0]=QFont("Helvetica",12,QFont::Normal);
 | |
|   pick_day_font[0].setPixelSize(12);
 | |
|   pick_day_font[1]=QFont("Helvetica",12,QFont::Bold);
 | |
|   pick_day_font[1].setPixelSize(12);
 | |
| 
 | |
|   //
 | |
|   // Generate Date Boundaries
 | |
|   //
 | |
|   QDate current_date=QDate::currentDate();
 | |
|   pick_high_year=current_date.year();
 | |
|   pick_low_year=pick_high_year;
 | |
|   sql=QString("select EVENT_DATETIME from ELR_LINES where ")+
 | |
|     "SERVICE_NAME=\""+RDEscapeString(svcname)+"\" "+
 | |
|     "order by EVENT_DATETIME";
 | |
|   q=new RDSqlQuery(sql);
 | |
|   if(q->first()) {
 | |
|     pick_low_year=q->value(0).toDate().year();
 | |
|   }
 | |
|   delete q;
 | |
| 
 | |
|   //
 | |
|   // Month
 | |
|   //
 | |
|   pick_month_box=new QComboBox(this);
 | |
|   pick_month_box->setGeometry(0,0,120,26);
 | |
|   for(int i=1;i<13;i++) {
 | |
|     pick_month_box->insertItem(QDate::longMonthName(i));
 | |
|   }
 | |
|   connect(pick_month_box,SIGNAL(activated(int)),
 | |
| 	  this,SLOT(monthActivatedData(int)));
 | |
| 
 | |
|   //
 | |
|   // Year
 | |
|   //
 | |
|   pick_year_box=new QComboBox(this);
 | |
|   pick_year_box->setGeometry(130,0,90,26);
 | |
|   for(int i=pick_low_year;i<(pick_high_year+1);i++) {
 | |
|     pick_year_box->insertItem(QString().sprintf("%04d",i));
 | |
|   }
 | |
|   connect(pick_year_box,SIGNAL(activated(int)),
 | |
| 	  this,SLOT(yearActivatedData(int)));
 | |
|   pick_year_spin=NULL;
 | |
| 
 | |
|   //
 | |
|   // Date Labels
 | |
|   //
 | |
|   QPalette weekend_palette=palette();
 | |
|   weekend_palette.setColor(QPalette::Active,QColorGroup::Background,
 | |
| 			   palette().color(QPalette::Active,
 | |
| 					   QColorGroup::Mid));
 | |
|   weekend_palette.setColor(QPalette::Inactive,QColorGroup::Background,
 | |
| 			   palette().color(QPalette::Active,
 | |
| 					   QColorGroup::Mid));
 | |
| 
 | |
|   QLabel *label=new QLabel(tr("Mo"),this);
 | |
|   label->setGeometry(SVC_REC_X_ORIGIN,30,30,30);
 | |
|   label->setFont(pick_day_font[1]);
 | |
|   label->setAlignment(Qt::AlignCenter);
 | |
| 
 | |
|   label=new QLabel(tr("Tu"),this);
 | |
|   label->setGeometry(SVC_REC_X_ORIGIN+SVC_REC_X_INTERVAL,
 | |
| 		     SVC_REC_Y_ORIGIN,30,30);
 | |
|   label->setFont(pick_day_font[1]);
 | |
|   label->setAlignment(Qt::AlignCenter);
 | |
| 
 | |
|   label=new QLabel(tr("We"),this);
 | |
|   label->setGeometry(SVC_REC_X_ORIGIN+SVC_REC_X_INTERVAL*2,
 | |
| 		     SVC_REC_Y_ORIGIN,30,30);
 | |
|   label->setFont(pick_day_font[1]);
 | |
|   label->setAlignment(Qt::AlignCenter);
 | |
| 
 | |
|   label=new QLabel(tr("Th"),this);
 | |
|   label->setGeometry(SVC_REC_X_ORIGIN+SVC_REC_X_INTERVAL*3,
 | |
| 		     SVC_REC_Y_ORIGIN,30,30);
 | |
|   label->setFont(pick_day_font[1]);
 | |
|   label->setAlignment(Qt::AlignCenter);
 | |
| 
 | |
|   label=new QLabel(tr("Fr"),this);
 | |
|   label->setGeometry(SVC_REC_X_ORIGIN+SVC_REC_X_INTERVAL*4,
 | |
| 		     SVC_REC_Y_ORIGIN,30,30);
 | |
|   label->setFont(pick_day_font[1]);
 | |
|   label->setAlignment(Qt::AlignCenter);
 | |
| 
 | |
|   label=new QLabel(tr("Sa"),this);
 | |
|   label->setGeometry(SVC_REC_X_ORIGIN+SVC_REC_X_INTERVAL*5,
 | |
| 		     SVC_REC_Y_ORIGIN,30,30);
 | |
|   label->setFont(pick_day_font[1]);
 | |
|   label->setAlignment(Qt::AlignCenter);
 | |
|   label->setPalette(weekend_palette);
 | |
| 
 | |
|   label=new QLabel(tr("Su"),this);
 | |
|   label->setGeometry(SVC_REC_X_ORIGIN+SVC_REC_X_INTERVAL*6,
 | |
| 		     SVC_REC_Y_ORIGIN,30,30);
 | |
|   label->setFont(pick_day_font[1]);
 | |
|   label->setAlignment(Qt::AlignCenter);
 | |
|   label->setPalette(weekend_palette);
 | |
| 
 | |
| 
 | |
|   for(int i=0;i<6;i++) {
 | |
|     for(int j=0;j<7;j++) {
 | |
|       pick_date_label[i][j]=new QLabel(this);
 | |
|       pick_date_label[i][j]->
 | |
| 	setGeometry(SVC_REC_X_ORIGIN+SVC_REC_X_INTERVAL*j,
 | |
| 		    SVC_REC_Y_ORIGIN+20+SVC_REC_Y_INTERVAL*i,30,30);
 | |
|       pick_date_label[i][j]->setAlignment(Qt::AlignCenter);
 | |
|     }
 | |
|   }
 | |
|   PrintDays();
 | |
|   setDate(current_date);
 | |
| }
 | |
| 
 | |
| 
 | |
| SvcRec::~SvcRec()
 | |
| {
 | |
| }
 | |
| 
 | |
| 
 | |
| QSize SvcRec::sizeHint() const
 | |
| {
 | |
|   return QSize(220,175);
 | |
| }
 | |
| 
 | |
| 
 | |
| QSizePolicy SvcRec::sizePolicy() const
 | |
| {
 | |
|   return QSizePolicy(QSizePolicy::Fixed,QSizePolicy::Fixed);
 | |
| }
 | |
| 
 | |
| 
 | |
| QString SvcRec::serviceName() const
 | |
| {
 | |
|   return pick_service_name;
 | |
| }
 | |
| 
 | |
| 
 | |
| QDate SvcRec::date() const
 | |
| {
 | |
|   return pick_date;
 | |
| }
 | |
| 
 | |
| 
 | |
| bool SvcRec::setDate(QDate date)
 | |
| {
 | |
|   if(!date.isValid()) {
 | |
|     date=QDate::currentDate();
 | |
|   }
 | |
|   if((date.year()<pick_low_year)||(date.year()>pick_high_year)) {
 | |
|     return false;
 | |
|   }
 | |
|   pick_date=date;
 | |
|   pick_month_box->setCurrentItem(date.month()-1);
 | |
|   if(pick_year_box!=NULL) {
 | |
|     pick_year_box->setCurrentItem(date.year()-pick_low_year);
 | |
|   }
 | |
|   else {
 | |
|     pick_year_spin->setValue(date.year());
 | |
|   }
 | |
|   GetActiveDays(date);
 | |
|   PrintDays();
 | |
|   return true;
 | |
| }
 | |
| 
 | |
| 
 | |
| bool SvcRec::dayActive(int day) const
 | |
| {
 | |
|   return pick_active_days[day-1];
 | |
| }
 | |
| 
 | |
| 
 | |
| void SvcRec::deleteDay()
 | |
| {
 | |
|   QString sql;
 | |
|   RDSqlQuery *q;
 | |
| 
 | |
|   sql=QString("delete from ELR_LINES where ")+
 | |
|     "SERVICE_NAME=\""+RDEscapeString(pick_service_name)+"\" && "+
 | |
|     "EVENT_DATETIME>=\""+date().toString("yyyy-MM-dd 00:00:00")+"\" && "+
 | |
|     "EVENT_DATETIME<\""+date().addDays(1).toString("yyyy-MM-dd 00:00:00")+"\"";
 | |
|   q=new RDSqlQuery(sql);
 | |
|   delete q;
 | |
|   GetActiveDays(pick_date);
 | |
|   PrintDays();
 | |
| }
 | |
| 
 | |
| 
 | |
| void SvcRec::monthActivatedData(int id)
 | |
| {
 | |
|   QDate date=QDate(pick_date.year(),id+1,1);
 | |
|   if(pick_date.day()<=date.daysInMonth()) {
 | |
|     pick_date=QDate(pick_date.year(),id+1,pick_date.day());
 | |
|   }
 | |
|   else {
 | |
|     pick_date=QDate(pick_date.year(),id+1,date.daysInMonth());
 | |
|   }
 | |
|   GetActiveDays(pick_date);
 | |
|   PrintDays();
 | |
| }
 | |
| 
 | |
| 
 | |
| void SvcRec::yearActivatedData(int id)
 | |
| {
 | |
|   QDate date=QDate(pick_low_year+pick_year_box->currentItem(),
 | |
| 		   pick_date.month(),1);
 | |
|   if(pick_date.day()<=date.daysInMonth()) {
 | |
|     pick_date=QDate(pick_low_year+pick_year_box->currentItem(),
 | |
| 		    pick_date.month(),pick_date.day());
 | |
|   }
 | |
|   else {
 | |
|     pick_date=QDate(pick_low_year+pick_year_box->currentItem(),
 | |
| 		    pick_date.month(),date.daysInMonth());
 | |
|   }
 | |
|   GetActiveDays(pick_date);
 | |
|   PrintDays();
 | |
| }
 | |
| 
 | |
| 
 | |
| void SvcRec::yearChangedData(int year)
 | |
| {
 | |
|   QDate date=QDate(pick_year_spin->value(),pick_date.month(),1);
 | |
|   if(pick_date.day()<=date.daysInMonth()) {
 | |
|     pick_date=QDate(pick_year_spin->value(),
 | |
| 		    pick_date.month(),pick_date.day());
 | |
|   }
 | |
|   else {
 | |
|     pick_date=QDate(pick_year_spin->value(),
 | |
| 		    pick_date.month(),date.daysInMonth());
 | |
|   }
 | |
|   GetActiveDays(pick_date);
 | |
|   PrintDays();
 | |
| }
 | |
| 
 | |
| 
 | |
| void SvcRec::mousePressEvent(QMouseEvent *e)
 | |
| {
 | |
|   if((e->pos().x()<SVC_REC_X_ORIGIN)||
 | |
|      (e->pos().x()>(SVC_REC_X_ORIGIN+SVC_REC_X_INTERVAL*7))||
 | |
|      (e->pos().y()<SVC_REC_Y_ORIGIN)||
 | |
|      (e->pos().y()>(SVC_REC_Y_ORIGIN+SVC_REC_Y_INTERVAL*7))) {
 | |
|     QWidget::mousePressEvent(e);
 | |
|     return;
 | |
|   }
 | |
|   int dow=(e->pos().x()-SVC_REC_X_ORIGIN)/SVC_REC_X_INTERVAL;
 | |
|   int week=(e->pos().y()-SVC_REC_Y_ORIGIN)/SVC_REC_Y_INTERVAL-1;
 | |
|   if((dow<0)||(dow>6)||(week<0)||(week>6)) {
 | |
|     return;
 | |
|   }
 | |
|   if(pick_date_label[week][dow]->text().isEmpty()) {
 | |
|     return;
 | |
|   }
 | |
|   pick_date=QDate(pick_date.year(),pick_date.month(),
 | |
| 		  pick_date_label[week][dow]->text().toInt());
 | |
|   PrintDays();
 | |
|   emit dateSelected(pick_date,pick_active_days[pick_date.day()-1]);
 | |
| }
 | |
| 
 | |
| 
 | |
| void SvcRec::PrintDays()
 | |
| {
 | |
|   QDate top_date;
 | |
| 
 | |
|   //
 | |
|   // Clear Days
 | |
|   //
 | |
|   QPalette weekend_palette=palette();
 | |
|   weekend_palette.setColor(QPalette::Active,QColorGroup::Background,
 | |
| 			   palette().color(QPalette::Active,
 | |
| 					   QColorGroup::Mid));
 | |
|   weekend_palette.setColor(QPalette::Inactive,QColorGroup::Background,
 | |
| 			   palette().color(QPalette::Active,
 | |
| 					   QColorGroup::Mid));
 | |
|   for(int i=0;i<6;i++) {
 | |
|     for(int j=0;j<5;j++) {
 | |
|       pick_date_label[i][j]->clear();
 | |
|       pick_date_label[i][j]->setPalette(palette());
 | |
|     }
 | |
|   }
 | |
|   for(int i=0;i<6;i++) {
 | |
|     for(int j=5;j<7;j++) {
 | |
|       pick_date_label[i][j]->clear();
 | |
|       pick_date_label[i][j]->setPalette(weekend_palette);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   //
 | |
|   // Get Top of Month
 | |
|   //
 | |
|   if(pick_year_box!=NULL) {
 | |
|     top_date=QDate(pick_low_year+pick_year_box->currentItem(),
 | |
| 		   pick_month_box->currentItem()+1,1);
 | |
|   }
 | |
|   else {
 | |
|     top_date=QDate(pick_year_spin->value(),pick_month_box->currentItem()+1,1);
 | |
|   }
 | |
| 
 | |
|   //
 | |
|   // Print Days
 | |
|   //
 | |
|   int dow_offset=top_date.dayOfWeek()-1;
 | |
|   for(int i=1;i<(top_date.daysInMonth()+1);i++) {
 | |
|     PrintDay(i,dow_offset);
 | |
|     if(pick_date.day()==i) {
 | |
|       SelectDay(i,dow_offset,true);
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| 
 | |
| void SvcRec::PrintDay(int day,int dow_offset)
 | |
| {
 | |
|   int slot=day+dow_offset-1;
 | |
|   int week=slot/7;
 | |
|   int dow=slot-7*week;
 | |
|   pick_date_label[week][dow]->setText(QString().sprintf("%d",day));
 | |
|   if(pick_active_days[day-1]) {
 | |
|     pick_date_label[week][dow]->setFont(pick_day_font[1]);
 | |
|   }
 | |
|   else {
 | |
|     pick_date_label[week][dow]->setFont(pick_day_font[0]);
 | |
|   }
 | |
| }
 | |
| 
 | |
| 
 | |
| void SvcRec::SelectDay(int day,int dow_offset,bool state)
 | |
| {
 | |
|   int slot=day+dow_offset-1;
 | |
|   int week=slot/7;
 | |
|   int dow=slot-7*week;
 | |
|   QPalette pal=palette();
 | |
|   if(state) {
 | |
|     pal.setColor(QPalette::Active,QColorGroup::Foreground,
 | |
| 		 palette().
 | |
| 		 color(QPalette::Active,QColorGroup::HighlightedText));
 | |
|     pal.setColor(QPalette::Active,QColorGroup::Background,
 | |
| 		 palette().color(QPalette::Active,QColorGroup::Highlight));
 | |
|     pal.setColor(QPalette::Inactive,QColorGroup::Foreground,
 | |
| 		 palette().
 | |
| 		 color(QPalette::Active,QColorGroup::HighlightedText));
 | |
|     pal.setColor(QPalette::Inactive,QColorGroup::Background,
 | |
| 		 palette().color(QPalette::Active,QColorGroup::Highlight));
 | |
|   }
 | |
|   else {
 | |
|     pal.setColor(QPalette::Active,QColorGroup::Foreground,
 | |
| 		 palette().color(QPalette::Active,QColorGroup::Text));
 | |
|     pal.setColor(QPalette::Active,QColorGroup::Background,
 | |
| 		 palette().color(QPalette::Active,QColorGroup::Background));
 | |
|     pal.setColor(QPalette::Inactive,QColorGroup::Foreground,
 | |
| 		 palette().color(QPalette::Active,QColorGroup::Text));
 | |
|     pal.setColor(QPalette::Inactive,QColorGroup::Background,
 | |
| 		 palette().color(QPalette::Active,QColorGroup::Background));
 | |
|   }
 | |
|   pick_date_label[week][dow]->setPalette(pal);
 | |
| }
 | |
| 
 | |
| 
 | |
| void SvcRec::GetActiveDays(const QDate &date)
 | |
| {
 | |
|   QString sql;
 | |
|   RDSqlQuery *q;
 | |
| 
 | |
|   for(int i=0;i<=date.daysInMonth();i++) {
 | |
|     sql=QString("select ID from ELR_LINES where ")+
 | |
|       "SERVICE_NAME=\""+RDEscapeString(pick_service_name)+"\" && "+
 | |
|       "(EVENT_DATETIME>=\""+date.toString("yyyy-MM")+QString().sprintf("-%02d 00:00:00\")&&",i+1)+
 | |
|       "(EVENT_DATETIME<=\""+date.toString("yyyy-MM")+QString().sprintf("-%02d 23:59:59\")",i+1);
 | |
|     q=new RDSqlQuery(sql);
 | |
|     pick_active_days[i]=q->first();
 | |
|     delete q;
 | |
|   }
 | |
| }
 | |
| 
 |