Rivendellaudio/rdlogedit/edit_log.cpp
Fred Gleason 89b846f7d6 2014-08-14 Fred Gleason <fredg@paravelsystems.com>
* Fixed warnings in 'lib/rdaudioconvert.cpp'.
	* Fixed warnings in 'lib/rdaudioexport.cpp'.
	* Fixed warnings in 'lib/rdaudioimport.cpp'.
	* Fixed warnings in 'lib/rdcart_dialog.cpp'.
	* Fixed warnings in 'lib/rdconf.cpp'.
	* Fixed warnings in 'lib/rdcopyaudio.cpp'.
	* Fixed warnings in 'lib/rdescape_string.cpp'.
	* Fixed warnings in 'lib/rdevent_line.cpp'.
	* Fixed warnings in 'lib/rdfeed.cpp'.
	* Refactored 'RDOneShot' to use int values in 'lib/rdoneshot.cpp'
	and 'lib/rdoneshot.h'.
	* Fixed warnings in 'lib/rdpeaksexport.cpp'.
	* Fixed warnings in 'lib/rdtrimaudio.cpp'.
	* Fixed warnings in 'lib/rdwavefile.cpp'.
	* Fixed warnings in 'rdhpi/rdhpiplaystream.cpp'.
	* Fixed warnings in 'rdhpi/rdhpirecordstream.cpp'.
	* Fixed warnings in 'rdhpi/rdhpisoundcard.cpp'.
	* Fixed warnings in 'pam_rd/pam_rd.cpp'.
	* Fixed warnings in 'rdadmin/edit_rdairplay.cpp'.
	* Fixed warnings in 'rdairplay/list_log.cpp'.
	* Fixed warnings in 'rdairplay/log_play.cpp'.
	* Fixed warnings in 'rdairplay/pie_counter.cpp'.
	* Fixed warnings in 'rdairplay/rlm_host.cpp'.
	* Fixed warnings in 'rdcatchd/rdcatchd.cpp'.
	* Fixed warnings in 'rdlogedit/editlog.cpp'.
	* Fixed warnings in 'rdlogmanager/rdlogmanager.cpp'.
	* Fixed warnings in 'rdrepl/replfactory.h'.
	* Fixed warnings in 'ripcd/acu1p.cpp' and 'ripcd/acu1p.h'.
	* Fixed warnings in 'ripcd/bt16x2.cpp' and 'ripcd/bt16x2.h'.
	* Fixed warnings in 'ripcd/btss164.cpp' and 'ripcd/btss164.h'.
	* Fixed warnings in 'ripcd/btss42.cpp' and 'ripcd/btss42.h'.
	* Fixed warnings in 'ripcd/btss44.cpp' and 'ripcd/btss44.h'.
	* Fixed warnings in 'ripcd/btss82.cpp' and 'ripcd/btss82.h'.
	* Fixed warnings in 'ripcd/btsrc16.cpp' and 'ripcd/btsrc16.h'.
	* Fixed warnings in 'ripcd/btsrc8iii.cpp' and 'ripcd/btsrc8iii.h'.
	* Fixed warnings in 'ripcd/livewire_mcastgpio.cpp'.
	* Fixed warnings in 'ripcd/local_gpio.cpp' and 'ripcd/local_gpio.h'.
	* Fixed warnings in 'ripcd/sas64000gpi.cpp' and 'ripcd/sas64000gpi.h'.
	* Fixed warnings in 'ripcd/vguest.cpp' and 'ripcd/vguest.h'.
	* Fixed warnings in 'utils/rdhpiinfo/rdhpiinfo.cpp'
	* Fixed warnings in 'utils/rdgen/wavlib.cpp'
	* Fixed warnings in 'utils/rdimport/rdimport.cpp'
	* Fixed warnings in 'utils/rdsoftkeys/rdsoftkeys.cpp'
	* Fixed warnings in 'web/rdxport/export.cpp'
2014-08-14 19:08:38 -04:00

1742 lines
48 KiB
C++

// edit_log.cpp
//
// Edit a Rivendell Log
//
// (C) Copyright 2002-2008 Fred Gleason <fredg@paravelsystems.com>
//
// $Id: edit_log.cpp,v 1.91.6.10.2.2 2014/05/22 16:12:54 cvs Exp $
//
// 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 <math.h>
#include <qdialog.h>
#include <qstring.h>
#include <qlistbox.h>
#include <qtextedit.h>
#include <qlabel.h>
#include <qpainter.h>
#include <qevent.h>
#include <qmessagebox.h>
#include <qbuttongroup.h>
#include <rddb.h>
#include <rdcreate_log.h>
#include <rddebug.h>
#include <rdadd_log.h>
#include <rdtextvalidator.h>
#include <rdtextfile.h>
#include <rdlogedit_conf.h>
#include <rd.h>
#include <rdconf.h>
#include <rddatedialog.h>
#include <globals.h>
#include <add_meta.h>
#include <edit_log.h>
#include <edit_logline.h>
#include <edit_marker.h>
#include <edit_track.h>
#include <edit_chain.h>
//
// Icons
//
#include "../icons/play.xpm"
#include "../icons/rml5.xpm"
#include "../icons/marker.xpm"
#include "../icons/chain.xpm"
#include "../icons/track_cart.xpm"
#include "../icons/notemarker.xpm"
#include "../icons/music.xpm"
#include "../icons/mic16.xpm"
#include "../icons/traffic.xpm"
EditLog::EditLog(QString logname,vector<RDLogLine> *clipboard,
vector<QString> *new_logs,QWidget *parent,const char *name)
: QDialog(parent,name,true)
{
QString sql;
RDSqlQuery *q;
QStringList services_list;
edit_logname=logname;
edit_clipboard=clipboard;
edit_newlogs=new_logs;
edit_default_trans=RDLogLine::Play;
bool adding_allowed=rduser->addtoLog();
bool deleting_allowed=rduser->removefromLog();
bool editing_allowed=rduser->arrangeLog();
bool saveas_allowed=rduser->createLog();
setCaption(tr("Edit Log"));
//
// Config Data
//
edit_default_trans=rdlogedit_conf->defaultTransType();
edit_output_card=rdlogedit_conf->outputCard();
edit_output_port=rdlogedit_conf->outputPort();
edit_start_macro=rdlogedit_conf->startCart();
edit_end_macro=rdlogedit_conf->endCart();
//
// Fix the Window Size
//
setMinimumWidth(sizeHint().width());
setMinimumHeight(sizeHint().height());
//
// Create Fonts
//
QFont button_font=QFont("Helvetica",12,QFont::Bold);
button_font.setPixelSize(12);
QFont label_font=QFont("Helvetica",12,QFont::Bold);
label_font.setPixelSize(12);
QFont title_font=QFont("Helvetica",12,QFont::Normal);
title_font.setPixelSize(12);
QFont length_font=QFont("Helvetica",10,QFont::Bold);
length_font.setPixelSize(10);
//
// Create Icons
//
edit_playout_map=new QPixmap(play_xpm);
edit_macro_map=new QPixmap(rml5_xpm);
edit_marker_map=new QPixmap(marker_xpm);
edit_chain_map=new QPixmap(chain_xpm);
edit_track_cart_map=new QPixmap(track_cart_xpm);
edit_notemarker_map=new QPixmap(notemarker_xpm);
edit_music_map=new QPixmap(music_xpm);
edit_mic16_map=new QPixmap(mic16_xpm);
edit_traffic_map=new QPixmap(traffic_xpm);
//
// Text Validator
//
RDTextValidator *validator=new RDTextValidator(this,"validator");
//
// Log Header
//
edit_log=new RDLog(edit_logname,false);
//
// Log Events
//
edit_log_event=new RDLogEvent(RDLog::tableName(edit_logname));
edit_log_event->load(true);
//
// Log Name
//
edit_logname_label=new QLabel(logname,this,"edit_logname_label");
edit_logname_label->setBackgroundColor(QColor(lightGray));
edit_logname_label->setAlignment(AlignLeft|AlignVCenter);
edit_logname_label->setFont(title_font);
edit_logname_label_label=new QLabel(tr("Log Name:"),
this,"edit_logname_label_label");
edit_logname_label_label->setBackgroundColor(QColor(lightGray));
edit_logname_label_label->setFont(label_font);
edit_logname_label_label->setAlignment(AlignRight|AlignVCenter);
//
// Track Counts
//
edit_track_label=new QLabel(this,"edit_track_label");
edit_track_label->setBackgroundColor(QColor(lightGray));
edit_track_label->setAlignment(AlignLeft|AlignVCenter);
edit_track_label->setFont(title_font);
edit_track_label_label=new QLabel(tr("Tracks:"),
this,"edit_track_label_label");
edit_track_label_label->setBackgroundColor(QColor(lightGray));
edit_track_label_label->setFont(label_font);
edit_track_label_label->setAlignment(AlignRight|AlignVCenter);
//
// Log Origin
//
edit_origin_label=new QLabel(edit_log->originUser()+QString(" - ")+
edit_log->originDatetime().toString("MM/dd/yyyy - hh:mm:ss"),
this,"edit_origin_label");
edit_origin_label->setBackgroundColor(QColor(lightGray));
edit_origin_label->setAlignment(AlignLeft|AlignVCenter);
edit_origin_label->setFont(title_font);
edit_origin_label_label=new QLabel(tr("Origin:"),
this,"edit_origin_label_label");
edit_origin_label_label->setBackgroundColor(QColor(lightGray));
edit_origin_label_label->setFont(label_font);
edit_origin_label_label->setAlignment(AlignRight|AlignVCenter);
//
// Description
//
edit_description_edit=new QLineEdit(this,"edit_description_edit");
edit_description_edit->setValidator(validator);
connect(edit_description_edit,SIGNAL(textChanged(const QString &)),
this,SLOT(descriptionChangedData(const QString &)));
edit_description_label=new QLabel(edit_description_edit,tr("Description:"),
this,"edit_description_label");
edit_description_label->setFont(label_font);
edit_description_label->setAlignment(AlignRight|AlignVCenter);
//
// Purge Date
//
edit_purgedate_box=new QCheckBox(this,"edit_purgedate_box");
edit_purgedate_label=new QLabel(edit_purgedate_box,tr("Delete on"),
this,"edit_purgedate_label");
edit_purgedate_label->setFont(label_font);
edit_purgedate_label->setAlignment(AlignRight|AlignVCenter);
edit_purgedate_edit=new QDateEdit(this,"edit_purgedate_edit");
edit_purgedate_button=
new QPushButton(tr("Select"),this,"edit_purgedate_button");
edit_purgedate_button->setFont(label_font);
connect(edit_purgedate_box,SIGNAL(toggled(bool)),
edit_purgedate_edit,SLOT(setEnabled(bool)));
connect(edit_purgedate_box,SIGNAL(toggled(bool)),
edit_purgedate_button,SLOT(setEnabled(bool)));
connect(edit_purgedate_button,SIGNAL(clicked()),
this,SLOT(selectPurgeDateData()));
//
// Service
//
edit_service_box=new QComboBox(this,"edit_service_box");
edit_service_edit=new QLineEdit(this,"edit_service_edit");
edit_service_edit->setReadOnly(true);
edit_service_label=new QLabel(edit_service_box,tr("Service:"),
this,"edit_service_label");
edit_service_label->setFont(label_font);
edit_service_label->setAlignment(AlignRight|AlignVCenter);
connect(edit_service_box,SIGNAL(activated(const QString &)),
this,SLOT(serviceActivatedData(const QString &)));
//
// Auto Refresh
//
edit_autorefresh_box=new QComboBox(this,"edit_autorefresh_box");
edit_autorefresh_box->insertItem(tr("Yes"));
edit_autorefresh_box->insertItem(tr("No"));
edit_autorefresh_edit=new QLineEdit(this,"edit_autorefresh_edit");
edit_autorefresh_edit->setReadOnly(true);
edit_autorefresh_label=
new QLabel(edit_autorefresh_box,tr("Enable AutoRefresh:"),
this,"edit_autorefresh_label");
edit_autorefresh_label->setFont(label_font);
edit_autorefresh_label->setAlignment(AlignRight|AlignVCenter);
//
// Start Date
//
edit_startdate_edit=new QDateEdit(this,"edit_startdate_edit");
edit_startdate_label=new QLabel(edit_startdate_edit,tr("Start Date:"),this,
"edit_startdate_label");
edit_startdate_label->setFont(label_font);
edit_startdate_label->setAlignment(AlignRight|AlignVCenter);
connect(edit_startdate_edit,SIGNAL(valueChanged(const QDate &)),
this,SLOT(dateValueChangedData(const QDate &)));
//
// End Date
//
edit_enddate_edit=new QDateEdit(this,"edit_enddate_edit");
edit_enddate_label=new QLabel(edit_startdate_edit,tr("End Date:"),
this,"edit_enddate_label");
edit_enddate_label->setFont(label_font);
edit_enddate_label->setAlignment(AlignRight|AlignVCenter);
connect(edit_enddate_edit,SIGNAL(valueChanged(const QDate &)),
this,SLOT(dateValueChangedData(const QDate &)));
//
// Start Date Checkbox
//
edit_startdate_box=new QCheckBox(this,"edit_startdate_box");
connect(edit_startdate_box,SIGNAL(toggled(bool)),
this,SLOT(startDateEnabledData(bool)));
edit_startdate_box_label=new QLabel(edit_startdate_box,
tr("Start Date Enabled"),this);
edit_startdate_box_label->setFont(label_font);
edit_startdate_box_label->setAlignment(AlignLeft|AlignVCenter);
//
// End Date Checkbox
//
edit_enddate_box=new QCheckBox(this,"edit_enddate_box");
connect(edit_enddate_box,SIGNAL(toggled(bool)),
this,SLOT(endDateEnabledData(bool)));
edit_enddate_box_label=new QLabel(edit_enddate_box,tr("End Date Enabled"),
this);
edit_enddate_box_label->setFont(label_font);
edit_enddate_box_label->setAlignment(AlignLeft|AlignVCenter);
//
// Time Counter Section
//
edit_time_label=new QLabel(tr("Run Length"),this);
edit_time_label->setFont(label_font);
edit_time_label->setAlignment(AlignCenter);
//
// Stop Time Counter
//
edit_stoptime_edit=new QLineEdit(this,"edit_stoptime_edit");
edit_stoptime_label=new QLabel(edit_stoptime_edit,tr("Next Stop:"),this);
edit_stoptime_label->setFont(label_font);
edit_stoptime_label->setAlignment(AlignRight|AlignVCenter);
//
// End Time Counter
//
edit_endtime_edit=new QLineEdit(this,"edit_endtime_edit");
edit_endtime_label=new QLabel(edit_endtime_edit,tr("Log End:"),this);
edit_endtime_label->setFont(label_font);
edit_endtime_label->setAlignment(AlignRight|AlignVCenter);
//
// Log Event List
//
edit_log_list=new DropListView(this,"edit_log_list");
edit_log_list->setAllColumnsShowFocus(true);
edit_log_list->setSelectionMode(QListView::Extended);
edit_log_list->setItemMargin(5);
//edit_log_list->setSorting(-1);
edit_log_list->addColumn("");
edit_log_list->setColumnAlignment(0,Qt::AlignHCenter);
edit_log_list->addColumn(tr("TIME"));
edit_log_list->setColumnAlignment(1,Qt::AlignRight);
edit_log_list->addColumn(tr("TRANS"));
edit_log_list->setColumnAlignment(2,Qt::AlignHCenter);
edit_log_list->addColumn(tr("CART"));
edit_log_list->setColumnAlignment(3,Qt::AlignHCenter);
edit_log_list->addColumn(tr("GROUP"));
edit_log_list->setColumnAlignment(4,Qt::AlignHCenter);
edit_log_list->addColumn(tr("LENGTH"));
edit_log_list->setColumnAlignment(5,Qt::AlignRight);
edit_log_list->addColumn(tr("TITLE"));
edit_log_list->setColumnAlignment(6,Qt::AlignLeft);
edit_log_list->addColumn(tr("ARTIST"));
edit_log_list->setColumnAlignment(7,Qt::AlignLeft);
edit_log_list->addColumn(tr("CLIENT"));
edit_log_list->setColumnAlignment(8,Qt::AlignLeft);
edit_log_list->addColumn(tr("AGENCY"));
edit_log_list->setColumnAlignment(9,Qt::AlignLeft);
edit_log_list->addColumn(tr("LABEL"));
edit_log_list->setColumnAlignment(10,Qt::AlignHCenter);
edit_log_list->addColumn(tr("SOURCE"));
edit_log_list->setColumnAlignment(11,Qt::AlignHCenter);
edit_log_list->addColumn(tr("LINE ID"));
edit_log_list->setColumnAlignment(12,Qt::AlignHCenter);
edit_log_list->addColumn(tr("COUNT"));
edit_log_list->setColumnAlignment(13,Qt::AlignHCenter);
edit_log_list->setHardSortColumn(13);
edit_log_list->setColumnSortType(13,RDListView::LineSort);
if(editing_allowed) {
connect(edit_log_list,SIGNAL(doubleClicked(QListViewItem *)),
this,SLOT(doubleClickData(QListViewItem *)));
connect(edit_log_list,SIGNAL(cartDropped(int,RDLogLine *)),
this,SLOT(cartDroppedData(int,RDLogLine *)));
}
connect(edit_log_list,SIGNAL(clicked(QListViewItem *)),
this,SLOT(clickedData(QListViewItem *)));
connect(edit_log_list,SIGNAL(selectionChanged()),
this,SLOT(selectionChangedData()));
//
// Insert Cart Button
//
edit_cart_button=new QPushButton(this,"edit_cart_button");
edit_cart_button->setPalette(QPalette(backgroundColor(),QColor(lightGray)));
edit_cart_button->setFont(button_font);
edit_cart_button->setText(tr("Insert\nCart"));
connect(edit_cart_button,SIGNAL(clicked()),
this,SLOT(insertCartButtonData()));
//
// Insert Marker Button
//
edit_marker_button=new QPushButton(this,"edit_marker_button");
edit_marker_button->
setPalette(QPalette(backgroundColor(),QColor(lightGray)));
edit_marker_button->setFont(button_font);
edit_marker_button->setText(tr("Insert\nMeta"));
connect(edit_marker_button,SIGNAL(clicked()),
this,SLOT(insertMarkerButtonData()));
//
// Edit Button
//
edit_edit_button=new QPushButton(this,"edit_edit_button");
edit_edit_button->setPalette(QPalette(backgroundColor(),QColor(lightGray)));
edit_edit_button->setFont(button_font);
edit_edit_button->setText(tr("Edit"));
connect(edit_edit_button,SIGNAL(clicked()),this,SLOT(editButtonData()));
//
// Delete Button
//
edit_delete_button=new QPushButton(this,"edit_delete_button");
edit_delete_button->
setPalette(QPalette(backgroundColor(),QColor(lightGray)));
edit_delete_button->setFont(button_font);
edit_delete_button->setText(tr("Delete"));
connect(edit_delete_button,SIGNAL(clicked()),this,SLOT(deleteButtonData()));
//
// Up Button
//
edit_up_button=new RDTransportButton(RDTransportButton::Up,
this,"delete_button");
edit_up_button->setPalette(QPalette(backgroundColor(),QColor(lightGray)));
connect(edit_up_button,SIGNAL(clicked()),this,SLOT(upButtonData()));
//
// Down Button
//
edit_down_button=new RDTransportButton(RDTransportButton::Down,
this,"delete_button");
edit_down_button->setPalette(QPalette(backgroundColor(),QColor(lightGray)));
connect(edit_down_button,SIGNAL(clicked()),this,SLOT(downButtonData()));
//
// Cut Button
//
edit_cut_button=new QPushButton(this,"edit_cut_button");
edit_cut_button->setPalette(QPalette(backgroundColor(),QColor(lightGray)));
edit_cut_button->setFont(button_font);
edit_cut_button->setText(tr("Cut"));
connect(edit_cut_button,SIGNAL(clicked()),this,SLOT(cutButtonData()));
//
// Copy Button
//
edit_copy_button=new QPushButton(this,"edit_copy_button");
edit_copy_button->setPalette(QPalette(backgroundColor(),QColor(lightGray)));
edit_copy_button->setFont(button_font);
edit_copy_button->setText(tr("Copy"));
connect(edit_copy_button,SIGNAL(clicked()),this,SLOT(copyButtonData()));
//
// Paste Button
//
edit_paste_button=new QPushButton(this,"edit_paste_button");
edit_paste_button->setPalette(QPalette(backgroundColor(),QColor(lightGray)));
edit_paste_button->setFont(button_font);
edit_paste_button->setText(tr("Paste"));
connect(edit_paste_button,SIGNAL(clicked()),this,SLOT(pasteButtonData()));
//
// Save Button
//
edit_save_button=new QPushButton(this,"edit_save_button");
edit_save_button->setFont(button_font);
edit_save_button->setText(tr("&Save"));
connect(edit_save_button,SIGNAL(clicked()),this,SLOT(saveData()));
//
// SaveAs Button
//
edit_saveas_button=new QPushButton(this,"edit_saveas_button");
edit_saveas_button->setFont(button_font);
edit_saveas_button->setText(tr("Save\n&As"));
connect(edit_saveas_button,SIGNAL(clicked()),this,SLOT(saveasData()));
//
// Reports Button
//
edit_reports_button=new QPushButton(this,"edit_reports_button");
edit_reports_button->setFont(button_font);
edit_reports_button->setText(tr("&Reports"));
connect(edit_reports_button,SIGNAL(clicked()),this,SLOT(reportsData()));
//
// Cart Player
//
#ifdef WIN32
edit_player=NULL;
#else
edit_player=
new RDSimplePlayer(rdcae,rdripc,edit_output_card,edit_output_port,
edit_start_macro,edit_end_macro,this,"edit_player");
edit_player->playButton()->
setPalette(QPalette(backgroundColor(),QColor(lightGray)));
edit_player->stopButton()->
setPalette(QPalette(backgroundColor(),QColor(lightGray)));
edit_player->stopButton()->setOnColor(red);
#endif // WIN32
//
// Ok Button
//
edit_ok_button=new QPushButton(this,"edit_ok_button");
edit_ok_button->setDefault(true);
edit_ok_button->setFont(button_font);
edit_ok_button->setText(tr("&OK"));
connect(edit_ok_button,SIGNAL(clicked()),this,SLOT(okData()));
//
// Cancel Button
//
edit_cancel_button=new QPushButton(this,"edit_cancel_button");
edit_cancel_button->setFont(button_font);
edit_cancel_button->setText(tr("&Cancel"));
connect(edit_cancel_button,SIGNAL(clicked()),this,SLOT(cancelData()));
//
// Populate Data
//
edit_description_edit->setText(edit_log->description());
QDate purge_date=edit_log->purgeDate();
if(purge_date.isNull()) {
edit_purgedate_edit->setDate(QDate::currentDate().addMonths(1));
edit_purgedate_edit->setDisabled(true);
edit_purgedate_button->setDisabled(true);
}
else {
edit_purgedate_box->setChecked(true);
edit_purgedate_edit->setDate(purge_date);
}
if (rdstation_conf->broadcastSecurity() == RDStation::UserSec) {
services_list = rduser->services();
} else { // RDStation::HostSec
sql=QString("select NAME from SERVICES");
q=new RDSqlQuery(sql);
while(q->next()) {
services_list.append( q->value(0).toString() );
}
delete q;
}
int n=-1;
int ncounter=0;
QString service=edit_log->service();
for ( QStringList::Iterator it = services_list.begin();
it != services_list.end(); ++it ) {
edit_service_box->insertItem(*it);
if(*it==service) {
n=ncounter;
edit_service_edit->setText(*it);
}
ncounter++;
}
if(n>=0) {
edit_service_box->setCurrentItem(n);
}
if(edit_log->autoRefresh()) {
edit_autorefresh_box->setCurrentItem(0);
edit_autorefresh_edit->setText(tr("Yes"));
}
else {
edit_autorefresh_box->setCurrentItem(1);
edit_autorefresh_edit->setText(tr("No"));
}
if(!edit_log->startDate().isNull()) {
edit_startdate_box->setChecked(true);
edit_startdate_edit->setDate(edit_log->startDate());
}
else {
edit_startdate_edit->setDisabled(true);
edit_startdate_label->setDisabled(true);
edit_startdate_box->setChecked(false);
}
if(!edit_log->endDate().isNull()) {
edit_enddate_box->setChecked(true);
edit_enddate_edit->setDate(edit_log->endDate());
}
else {
edit_enddate_edit->setDisabled(true);
edit_enddate_label->setDisabled(true);
edit_enddate_box->setChecked(false);
}
RefreshList();
serviceActivatedData(edit_service_box->currentText());
edit_changed=false;
UpdateTracks();
//
// Set Control Perms
//
edit_description_edit->setReadOnly(!editing_allowed);
if(saveas_allowed) {
edit_service_edit->hide();
edit_autorefresh_edit->hide();
}
else {
edit_service_box->hide();
edit_autorefresh_box->hide();
}
if(!editing_allowed) {
if(edit_startdate_box->isChecked()) {
edit_startdate_edit->setRange(edit_startdate_edit->date(),
edit_startdate_edit->date());
}
if(edit_enddate_box->isChecked()) {
edit_enddate_edit->setRange(edit_enddate_edit->date(),
edit_enddate_edit->date());
}
}
edit_startdate_box->setEnabled(editing_allowed);
edit_enddate_box->setEnabled(editing_allowed);
edit_startdate_box->setEnabled(editing_allowed);
edit_enddate_box->setEnabled(editing_allowed);
edit_cart_button->setEnabled(adding_allowed&&editing_allowed);
edit_marker_button->setEnabled(adding_allowed&&editing_allowed);
edit_edit_button->setEnabled(editing_allowed&&editing_allowed);
edit_delete_button->setEnabled(deleting_allowed&&editing_allowed);
edit_up_button->setEnabled(editing_allowed);
edit_down_button->setEnabled(editing_allowed);
edit_cut_button->
setEnabled(adding_allowed&&deleting_allowed&&editing_allowed);
edit_copy_button->setEnabled(adding_allowed&&editing_allowed);
edit_paste_button->setEnabled(adding_allowed&&editing_allowed);
edit_saveas_button->setEnabled(saveas_allowed);
}
EditLog::~EditLog()
{
}
QSize EditLog::sizeHint() const
{
return QSize(800,600);
}
QSizePolicy EditLog::sizePolicy() const
{
return QSizePolicy(QSizePolicy::Fixed,QSizePolicy::Fixed);
}
void EditLog::descriptionChangedData(const QString &)
{
edit_changed=true;
}
void EditLog::selectPurgeDateData()
{
QDate date=edit_purgedate_edit->date();
RDDateDialog *d=new RDDateDialog(2008,QDate::currentDate().year()+5,this);
if(d->exec(&date)==0) {
edit_purgedate_edit->setDate(date);
edit_changed=true;
}
}
void EditLog::serviceActivatedData(const QString &svcname)
{
edit_changed=true;
edit_group_list.loadSvc(svcname);
if(!ValidateSvc()) {
QMessageBox::warning(this,tr("Invalid Carts"),
tr("This log contains one or more carts\nthat are invalid for the selected service!"));
}
}
void EditLog::startDateEnabledData(bool state)
{
if(state) {
edit_startdate_edit->setDate(QDate::currentDate());
}
edit_startdate_edit->setEnabled(state);
edit_startdate_label->setEnabled(state);
edit_changed=true;
}
void EditLog::endDateEnabledData(bool state)
{
if(state) {
edit_enddate_edit->setDate(QDate::currentDate());
}
edit_enddate_edit->setEnabled(state);
edit_enddate_label->setEnabled(state);
edit_changed=true;
}
void EditLog::dateValueChangedData(const QDate &)
{
edit_changed=true;
}
void EditLog::insertCartButtonData()
{
int line;
int id;
QListViewItem *item=SingleSelection();
if(item==NULL) {
return;
}
if((line=item->text(13).toInt())<0) {
line=0;
}
id=item->text(12).toInt();
edit_log_event->insert(line,1);
edit_log_event->logLine(line)->setTransType(edit_default_trans);
edit_log_event->logLine(line)->setFadeupGain(-3000);
edit_log_event->logLine(line)->setFadedownGain(-3000);
EditLogLine *edit=new EditLogLine(edit_log_event->logLine(line),
&edit_filter,&edit_group,
edit_service_box->currentText(),
&edit_group_list,edit_log_event,line,
this,"edit_logline");
int ret=edit->exec();
if(ret>=0) {
edit_log_event->refresh(line);
edit_changed=true;
}
else {
edit_log_event->remove(line,1);
delete edit;
return;
}
delete edit;
RefreshList();
SelectRecord(id);
UpdateSelection();
}
void EditLog::insertMarkerButtonData()
{
int line;
int id;
int ret;
EditMarker *edit_marker;
EditTrack *edit_track;
EditChain *edit_chain;
QListViewItem *item=SingleSelection();
if(item==NULL) {
return;
}
line=item->text(13).toInt();
id=item->text(12).toInt();
AddMeta *meta=new AddMeta(this,"add_meta_dialog");
switch((RDLogLine::Type)meta->exec()) {
case RDLogLine::Marker:
edit_log_event->insert(line,1);
edit_log_event->logLine(line)->setType(RDLogLine::Marker);
edit_marker=new EditMarker(edit_log_event->logLine(line),
this,"edit_marker");
ret=edit_marker->exec();
if(ret>=0) {
edit_log_event->refresh(line);
edit_changed=true;
}
else {
edit_log_event->remove(line,1);
}
delete edit_marker;
break;
case RDLogLine::Track:
edit_log_event->insert(line,1);
edit_log_event->logLine(line)->setType(RDLogLine::Track);
edit_log_event->logLine(line)->setTransType(RDLogLine::Segue);
edit_log_event->logLine(line)->setMarkerComment(tr("Voice Track"));
edit_track=new EditTrack(edit_log_event->logLine(line),
this,"edit_marker");
ret=edit_track->exec();
if(ret>=0) {
edit_log_event->refresh(line);
edit_changed=true;
}
else {
edit_log_event->remove(line,1);
}
delete edit_track;
break;
case RDLogLine::Chain:
edit_log_event->insert(line,1);
edit_log_event->logLine(line)->setType(RDLogLine::Chain);
edit_chain=new EditChain(edit_log_event->logLine(line),
this,"edit_marker");
ret=edit_chain->exec();
if(ret>=0) {
edit_log_event->refresh(line);
edit_changed=true;
}
else {
edit_log_event->remove(line,1);
}
delete edit_chain;
break;
default:
break;
}
RefreshList();
UpdateTracks();
SelectRecord(id);
UpdateSelection();
}
void EditLog::clickedData(QListViewItem *item)
{
#ifndef WIN32
RDListViewItem *rditem=SingleSelection();
if(rditem==NULL) {
edit_player->setCart(0);
return;
}
else {
edit_player->setCart(rditem->text(3).toUInt());
}
#endif // WIN32
}
void EditLog::selectionChangedData()
{
UpdateSelection();
}
void EditLog::doubleClickData(QListViewItem *item)
{
editButtonData();
}
void EditLog::editButtonData()
{
EditLogLine *edit_cart;
EditMarker *edit_marker;
EditTrack *edit_track;
EditChain *edit_chain;
RDListViewItem *item=SingleSelection();
if(item==NULL) {
return;
}
int id=item->text(12).toInt();
int line=item->text(13).toInt();
if(id==END_MARKER_ID) {
return;
}
switch(edit_log_event->logLine(line)->type()) {
case RDLogLine::Cart:
case RDLogLine::Macro:
edit_cart=new EditLogLine(edit_log_event->logLine(line),&
edit_filter,&edit_group,
edit_service_box->currentText(),
&edit_group_list,edit_log_event,line,
this,"edit_logline");
if(edit_cart->exec()>=0) {
edit_log_event->refresh(item->text(13).toInt());
edit_changed=true;
}
delete edit_cart;
break;
case RDLogLine::Marker:
edit_marker=new EditMarker(edit_log_event->logLine(line),
this,"edit_logline");
if(edit_marker->exec()>=0) {
edit_changed=true;
}
delete edit_marker;
break;
case RDLogLine::Track:
edit_track=new EditTrack(edit_log_event->logLine(line),
this,"edit_logline");
if(edit_track->exec()>=0) {
edit_changed=true;
}
delete edit_track;
break;
case RDLogLine::Chain:
edit_chain=new EditChain(edit_log_event->logLine(line),
this,"edit_logline");
if(edit_chain->exec()>=0) {
edit_changed=true;
}
delete edit_chain;
break;
default:
break;
}
RefreshList();
SelectRecord(id);
UpdateSelection();
}
void EditLog::deleteButtonData()
{
int count=0;
QListViewItem *next=edit_log_list->firstChild();
int line=0;
while(next!=NULL) {
if(edit_log_list->isSelected(next)) {
if(next->text(12).toInt()!=END_MARKER_ID) {
if(count==0) {
line=next->text(13).toInt();
}
count++;
}
}
next=next->nextSibling();
}
DeleteLines(line,count);
}
void EditLog::upButtonData()
{
QListViewItem *item=SingleSelection();
if((item==NULL)||(item->text(13).toInt()==0)||
(item->text(12).toInt()==END_MARKER_ID)) {
return;
}
int id=item->text(12).toInt();
sscanf((const char *)item->text(12),"%u",&id);
edit_log_event->move(item->text(13).toInt(),
item->text(13).toInt()-1);
edit_changed=true;
RefreshList();
SelectRecord(id);
UpdateSelection();
}
void EditLog::downButtonData()
{
QListViewItem *item=SingleSelection();
if((item==NULL)||(item->text(13).toInt()==(edit_log_list->childCount()-2))||
(item->text(12).toInt()==END_MARKER_ID)) {
return;
}
int id=item->text(12).toInt();
edit_log_event->move(item->text(13).toInt(),
item->text(13).toInt()+1);
edit_changed=true;
RefreshList();
SelectRecord(id);
UpdateSelection();
}
void EditLog::cutButtonData()
{
copyButtonData();
deleteButtonData();
UpdateTracks();
UpdateSelection();
}
void EditLog::copyButtonData()
{
QListViewItem *next=edit_log_list->firstChild();
edit_clipboard->clear();
while(next!=NULL) {
if((edit_log_list->isSelected(next))&&
(next->text(12).toInt()!=END_MARKER_ID)) {
edit_clipboard->
push_back(*edit_log_event->logLine(next->text(13).toInt()));
}
next=next->nextSibling();
}
}
void EditLog::pasteButtonData()
{
QListViewItem *item=SingleSelection();
if((item==NULL)||(edit_clipboard->size()==0)) {
return;
}
int line=item->text(13).toInt();
int id=item->text(12).toInt();
edit_log_event->insert(line,edit_clipboard->size());
for(unsigned i=0;i<edit_clipboard->size();i++) {
edit_clipboard->at(i).setId(edit_log_event->logLine(line+i)->id());
*edit_log_event->logLine(line+i)=edit_clipboard->at(i);
edit_log_event->logLine(line+i)->clearExternalData();
edit_log_event->logLine(line+i)->setSource(RDLogLine::Manual);
}
edit_changed=true;
RefreshList();
UpdateTracks();
SelectRecord(id);
UpdateSelection();
}
void EditLog::cartDroppedData(int line,RDLogLine *ll)
{
RDListViewItem *item=NULL;
bool appended=false;
if((line<0)||(line==edit_log_event->size())) {
line=edit_log_event->size();
appended=true;
}
if(ll->cartNumber()==0) { // Empty Cart
if(!appended) {
DeleteLines(line,1);
}
return;
}
edit_log_event->insert(line,1);
edit_log_event->setLogLine(line,ll);
edit_log_event->logLine(line)->setTransType(edit_default_trans);
edit_log_event->logLine(line)->setFadeupGain(-3000);
edit_log_event->logLine(line)->setFadedownGain(-3000);
edit_log_event->refresh(line);
edit_changed=true;
if(appended) {
item=(RDListViewItem *)edit_log_list->lastItem();
item->setText(13,QString().sprintf("%d",item->text(13).toInt()+1));
}
else {
item=(RDListViewItem *)edit_log_list->
findItem(QString().sprintf("%d",line),13);
item->setText(13,QString().sprintf("%d",item->text(13).toInt()+1));
while((item=(RDListViewItem *)item->nextSibling())!=NULL) {
item->setText(13,QString().sprintf("%d",item->text(13).toInt()+1));
}
}
item=new RDListViewItem(edit_log_list);
item->setText(13,QString().sprintf("%d",line));
RefreshLine(item);
edit_log_list->sort();
edit_log_list->clearSelection();
item->setSelected(true);
}
void EditLog::saveData()
{
if(!ValidateSvc()) {
if(QMessageBox::warning(this,tr("Invalid Carts"),
tr("The log contains carts that are disabled\nfor the selected service!\n\nDo you still want to save?"),QMessageBox::Yes,QMessageBox::No)==QMessageBox::No) {
return;
}
}
if(!DeleteTracks()) {
QMessageBox::warning(this,tr("RDLogEdit"),
tr("Unable to save log, audio deletion error!"));
return;
}
edit_log_event->save();
edit_changed=false;
edit_log->setAutoRefresh(edit_autorefresh_box->currentItem()==0);
edit_log->
setModifiedDatetime(QDateTime(QDate::currentDate(),QTime::currentTime()));
}
void EditLog::saveasData()
{
if(!ValidateSvc()) {
if(QMessageBox::warning(this,tr("Invalid Carts"),
tr("The log contains carts that are disabled\nfor the selected service!\n\nDo you still want to save?"),QMessageBox::Yes,QMessageBox::No)==QMessageBox::No) {
return;
}
}
QString logname;
QString svcname=edit_service_box->currentText();
RDSqlQuery *q;
QString sql;
RDAddLog *log=NULL;
if(rduser->createLog()) {
if (rdstation_conf->broadcastSecurity() == RDStation::UserSec) {
log=new RDAddLog(&logname,&svcname,NULL,tr("Add Log"),this,"add_log",
rduser);
} else { // RDStation::HostSec
log=new RDAddLog(&logname,&svcname,NULL,tr("Add Log"),this,"add_log");
}
if(log->exec()<0) {
return;
}
sql=QString().sprintf("insert into LOGS set \
NAME=\"%s\",TYPE=0,DESCRIPTION=\"%s log\",ORIGIN_USER=\"%s\",\
ORIGIN_DATETIME=NOW(),LINK_DATETIME=NOW(),SERVICE=\"%s\"",
(const char *)logname,
(const char *)logname,
(const char *)rdripc->user(),
(const char *)svcname);
q=new RDSqlQuery(sql);
if(!q->isActive()) {
QMessageBox::warning(this,tr("Log Exists"),tr("Log Already Exists!"));
delete q;
return;
}
delete q;
delete edit_log;
edit_newlogs->push_back(logname);
edit_log=new RDLog(logname,true);
QString logtable=logname;
logtable.replace(" ","_");
RDCreateLogTable(RDLog::tableName(logtable));
edit_log_event->setLogName(RDLog::tableName(logtable));
for(int i=0;i<edit_service_box->count();i++) {
if(edit_service_box->text(i)==svcname) {
edit_service_box->setCurrentItem(i);
}
}
SaveLog();
edit_logname_label->setText(logname);
edit_origin_label->
setText(edit_log->originUser()+QString(" - ")+
edit_log->originDatetime().toString("MM/dd/yyyy - hh:mm:ss"));
}
delete log;
RefreshList();
edit_changed=false;
edit_deleted_tracks.clear();
}
void EditLog::reportsData()
{
QDate start_date;
if(edit_startdate_box->isChecked()) {
start_date=edit_startdate_edit->date();
}
QDate end_date;
if(edit_enddate_box->isChecked()) {
end_date=edit_enddate_edit->date();
}
ListReports *lr=
new ListReports(edit_log->name(),edit_description_edit->text(),
edit_service_box->currentText(),start_date,end_date,
edit_autorefresh_box->currentItem()==0,
edit_log_event,this,"lr");
lr->exec();
delete lr;
}
void EditLog::okData()
{
if(!ValidateSvc()) {
if(QMessageBox::warning(this,tr("Invalid Carts"),
tr("The log contains carts that are disabled\nfor the selected service!\n\nDo you still want to save?"),QMessageBox::Yes,QMessageBox::No)==QMessageBox::No) {
return;
}
}
SaveLog();
DeleteTracks();
#ifndef WIN32
edit_player->stop();
#endif // WIN32
done(0);
}
void EditLog::cancelData()
{
if(edit_changed) {
switch(QMessageBox::question(this,
tr("RDLogEdit"),
tr("The log has been modified.\nDo you want to save your changes?"),
QMessageBox::Yes,QMessageBox::No,
QMessageBox::Cancel)) {
case QMessageBox::Yes:
if(!ValidateSvc()) {
QMessageBox::warning(this,tr("Invalid Carts"),
tr("The log contains carts that are disabled\nfor the selected service!"));
return;
}
SaveLog();
break;
case QMessageBox::Cancel:
case QMessageBox::NoButton:
return;
break;
}
}
#ifndef WIN32
edit_player->stop();
#endif // WIN32
done(1);
}
void EditLog::closeEvent(QCloseEvent *e)
{
cancelData();
}
void EditLog::resizeEvent(QResizeEvent *e)
{
edit_logname_label->setGeometry(155,11,size().width()-500,18);
edit_logname_label_label->setGeometry(70,11,80,18);
edit_origin_label->setGeometry(size().width()-300,11,200,18);
edit_origin_label_label->setGeometry(size().width()-345,11,40,18);
edit_track_label->setGeometry(size().width()-425,11,40,18);
edit_track_label_label->setGeometry(size().width()-510,11,80,18);
edit_description_edit->setGeometry(110,40,size().width()-390,20);
edit_description_label->setGeometry(10,40,95,20);
edit_purgedate_box->setGeometry(size().width()-255,42,15,15);
edit_purgedate_label->setGeometry(size().width()-240,40,60,20);
edit_purgedate_edit->setGeometry(size().width()-170,40,100,20);
edit_purgedate_button->setGeometry(size().width()-60,37,50,26);
edit_service_box->setGeometry(110,68,120,22);
edit_service_edit->setGeometry(110,68,120,22);
edit_service_label->setGeometry(10,68,95,22);
edit_autorefresh_box->setGeometry(180,94,50,22);
edit_autorefresh_edit->setGeometry(180,94,50,22);
edit_autorefresh_label->setGeometry(10,94,165,22);
edit_startdate_edit->setGeometry(315,68,100,22);
edit_startdate_label->setGeometry(240,68,70,22);
edit_enddate_edit->setGeometry(490,68,100,22);
edit_enddate_label->setGeometry(415,68,70,22);
edit_startdate_box->setGeometry(250,98,15,15);
edit_enddate_box->setGeometry(430,98,15,15);
edit_startdate_box_label->setGeometry(270,96,175,20);
edit_enddate_box_label->setGeometry(450,96,140,20);
edit_time_label->setGeometry(655,62,75,20);
edit_stoptime_label->setGeometry(625,82,65,18);
edit_stoptime_edit->setGeometry(695,82,60,18);
edit_endtime_label->setGeometry(625,102,65,18);
edit_endtime_edit->setGeometry(695,102,60,18);
edit_log_list->setGeometry(10,128,
size().width()-20,size().height()-258);
edit_cart_button->setGeometry(20,size().height()-125,80,50);
edit_marker_button->setGeometry(110,size().height()-125,80,50);
edit_edit_button->setGeometry(200,size().height()-125,80,50);
edit_delete_button->setGeometry(290,size().height()-125,80,50);
edit_up_button->setGeometry(390,size().height()-125,50,50);
edit_down_button->setGeometry(450,size().height()-125,50,50);
edit_cut_button->
setGeometry(size().width()-280,size().height()-125,80,50);
edit_copy_button->
setGeometry(size().width()-190,size().height()-125,80,50);
edit_paste_button->
setGeometry(size().width()-100,size().height()-125,80,50);
edit_save_button->setGeometry(10,size().height()-60,80,50);
edit_saveas_button->setGeometry(100,size().height()-60,80,50);
edit_reports_button->setGeometry(250,size().height()-60,80,50);
#ifndef WIN32
edit_player->playButton()->setGeometry(400,size().height()-60,80,50);
edit_player->stopButton()->setGeometry(490,size().height()-60,80,50);
#endif // WIN32
edit_ok_button->
setGeometry(size().width()-180,size().height()-60,80,50);
edit_cancel_button->setGeometry(size().width()-90,size().height()-60,80,50);
}
void EditLog::paintEvent(QPaintEvent *e)
{
QPainter *p=new QPainter(this);
p->fillRect(60,8,size().width()-120,24,QColor(lightGray));
p->fillRect(9,size().height()-130,size().width()-20,60,
QColor(lightGray));
p->setPen(black);
p->setBrush(black);
p->moveTo(624,70);
p->lineTo(760,70);
p->lineTo(760,124);
p->lineTo(624,124);
p->lineTo(624,70);
p->end();
delete p;
}
void EditLog::DeleteLines(int line,int count)
{
RDListViewItem *item=NULL;
RDListViewItem *next=NULL;
if(count>0) {
for(int i=line;i<(line+count);i++) {
if(edit_log_event->logLine(i)->source()==RDLogLine::Tracker) {
edit_deleted_tracks.
push_back(edit_log_event->logLine(i)->cartNumber());
}
}
item=(RDListViewItem *)edit_log_list->
findItem(QString().sprintf("%d",line),13);
for(int i=0;i<count;i++) {
next=(RDListViewItem *)item->nextSibling();
delete item;
item=next;
}
if(next!=NULL) {
next->setSelected(true);
}
edit_log_event->remove(line,count);
edit_changed=true;
RenumberList(line);
}
UpdateTracks();
UpdateSelection();
}
void EditLog::SaveLog()
{
edit_log->setDescription(edit_description_edit->text());
if(edit_purgedate_box->isChecked()) {
edit_log->setPurgeDate(edit_purgedate_edit->date());
}
else {
edit_log->setPurgeDate(QDate());
}
edit_log->setService(edit_service_box->currentText());
if(edit_startdate_box->isChecked()) {
edit_log->setStartDate(edit_startdate_edit->date());
}
else {
edit_log->setStartDate(QDate());
}
if(edit_enddate_box->isChecked()) {
edit_log->setEndDate(edit_enddate_edit->date());
}
else {
edit_log->setEndDate(QDate());
}
edit_log->setAutoRefresh(edit_autorefresh_box->currentItem()==0);
edit_log_event->save();
edit_log->
setModifiedDatetime(QDateTime(QDate::currentDate(),QTime::currentTime()));
}
void EditLog::RefreshLine(RDListViewItem *item)
{
int line=item->text(13).toInt();
if(line<0) {
return;
}
RDLogLine *logline=edit_log_event->logLine(line);
switch(logline->timeType()) {
case RDLogLine::Hard:
item->setText(1,QString("T")+edit_log_event->
logLine(line)->startTime(RDLogLine::Logged).
toString("hh:mm:ss.zzz").left(10));
break;
default:
if(logline->
startTime(RDLogLine::Logged).isNull()) {
item->setText(1,edit_log_event->
blockStartTime(line).
toString("hh:mm:ss.zzz").left(10));
}
else {
item->setText(1,edit_log_event->
logLine(line)->startTime(RDLogLine::Logged).
toString("hh:mm:ss.zzz").left(10));
}
break;
}
switch(logline->transType()) {
case RDLogLine::Play:
item->setText(2,tr("PLAY"));
item->setTextColor(2,item->textColor(1),QFont::Normal);
break;
case RDLogLine::Stop:
item->setText(2,tr("STOP"));
item->setTextColor(2,item->textColor(1),QFont::Normal);
break;
case RDLogLine::Segue:
item->setText(2,tr("SEGUE"));
if(logline->hasCustomTransition()) {
item->setTextColor(2,RD_CUSTOM_TRANSITION_COLOR,QFont::Bold);
}
else {
item->setTextColor(2,item->textColor(1),QFont::Normal);
}
break;
default:
break;
}
switch(logline->type()) {
case RDLogLine::Cart:
switch(logline->source()) {
case RDLogLine::Tracker:
item->setPixmap(0,*edit_track_cart_map);
break;
default:
item->setPixmap(0,*edit_playout_map);
break;
}
item->setText(3,QString().
sprintf("%06u",logline->cartNumber()));
if(logline->title().isEmpty()) {
item->setText(4,"");
item->setText(5,tr("[cart not found]"));
}
else {
item->setText(4,logline->groupName());
item->setTextColor(4,logline->groupColor(),QFont::Bold);
if((logline->source()!=RDLogLine::Tracker)||
logline->originUser().isEmpty()||
(!logline->originDateTime().isValid())) {
item->setText(6,logline->title());
}
else {
item->setText(6,QString().
sprintf("%s -- %s %s",
(const char *)logline->title(),
(const char *)logline->originUser(),
(const char *)logline->originDateTime().
toString("M/d hh:mm")));
}
}
item->
setText(5,RDGetTimeLength(logline->forcedLength(),false,false));
item->setText(7,logline->artist());
item->setText(8,logline->client());
item->setText(9,logline->agency());
break;
case RDLogLine::Macro:
item->setPixmap(0,*edit_macro_map);
item->setText(3,QString().
sprintf("%06u",logline->cartNumber()));
if(logline->title().isEmpty()) {
item->setText(4,"");
item->setText(6,tr("[cart not found]"));
}
else {
item->setText(4,logline->groupName());
item->setTextColor(4,logline->groupColor(),QFont::Bold);
item->setText(6,logline->title());
}
item->
setText(5,RDGetTimeLength(logline->forcedLength(),false,false));
item->setText(7,logline->artist());
item->setText(8,logline->client());
item->setText(9,logline->agency());
break;
case RDLogLine::Marker:
item->setPixmap(0,*edit_notemarker_map);
item->setText(3,tr("MARKER"));
item->setText(4,"");
item->setText(6,RDTruncateAfterWord(edit_log_event->
logLine(line)->markerComment(),5,true));
item->setText(10,logline->markerLabel());
break;
case RDLogLine::Track:
item->setPixmap(0,*edit_mic16_map);
item->setText(3,tr("TRACK"));
item->setText(4,"");
item->setText(6,RDTruncateAfterWord(edit_log_event->
logLine(line)->markerComment(),5,true));
break;
case RDLogLine::Chain:
item->setPixmap(0,*edit_chain_map);
item->setText(3,tr("LOG CHAIN"));
item->setText(4,"");
item->setText(6,logline->markerLabel());
item->setText(7,RDTruncateAfterWord(edit_log_event->
logLine(line)->markerComment(),5,true));
break;
case RDLogLine::MusicLink:
item->setPixmap(0,*edit_music_map);
item->setText(3,tr("LINK"));
item->setText(4,"");
item->setText(5,RDGetTimeLength(logline->linkLength(),false,false));
item->setText(6,tr("[music import]"));
break;
case RDLogLine::TrafficLink:
item->setPixmap(0,*edit_traffic_map);
item->setText(3,tr("LINK"));
item->setText(4,"");
item->setText(5,RDGetTimeLength(logline->linkLength(),false,false));
item->setText(6,tr("[traffic import]"));
break;
default:
break;
}
switch(logline->source()) {
case RDLogLine::Manual:
item->setText(11,tr("Manual"));
break;
case RDLogLine::Traffic:
item->setText(11,tr("Traffic"));
break;
case RDLogLine::Music:
item->setText(11,tr("Music"));
break;
case RDLogLine::Template:
item->setText(11,tr("RDLogManager"));
break;
case RDLogLine::Tracker:
item->setText(11,tr("Voice Tracker"));
break;
}
item->
setText(12,QString().sprintf("%d",logline->id()));
UpdateColor(item,logline);
}
void EditLog::RefreshList()
{
RDListViewItem *l;
edit_log_list->clear();
l=new RDListViewItem(edit_log_list);
l->setText(6,tr("--- end of log ---"));
l->setText(12,QString().sprintf("%d",END_MARKER_ID));
l->setText(13,QString().sprintf("%d",edit_log_event->size()));
for(int i=edit_log_event->size()-1;i>=0;i--) {
l=new RDListViewItem(edit_log_list);
l->setText(13,QString().sprintf("%d",i));
RefreshLine(l);
}
}
void EditLog::UpdateSelection()
{
RDListViewItem *rditem=SingleSelection();
if(rditem==NULL) { // Multiple items selected?
edit_endtime_edit->setText("");
edit_stoptime_label->setText(tr("Selected:"));
QListViewItem *next=edit_log_list->firstChild();
int start_line=-1;
int end_line=-1;
while(next!=NULL) {
if(edit_log_list->isSelected(next)) {
if((start_line<0)&&(next->text(12).toInt()!=END_MARKER_ID)) {
start_line=next->text(13).toInt();
}
if(next->text(12).toInt()!=END_MARKER_ID) {
end_line=next->text(13).toInt();
}
}
next=next->nextSibling();
}
if(start_line>=0) {
edit_stoptime_edit->setText(RDGetTimeLength(edit_log_event->
length(start_line,end_line+1),true,false));
}
return;
}
if(rditem->text(12).toInt()>0) {
edit_endtime_edit->setText(RDGetTimeLength(edit_log_event->
length(rditem->text(13).toInt(),edit_log_event->size()),true,false));
edit_stoptime_label->setText(tr("Next Stop:"));
int stoplen=edit_log_event->lengthToStop(rditem->text(13).toInt());
if(stoplen>=0) {
edit_stoptime_edit->setText(RDGetTimeLength(stoplen,true,false));
}
else {
edit_stoptime_edit->setText("");
}
}
else {
edit_endtime_edit->setText("");
edit_stoptime_edit->setText("");
}
}
bool EditLog::UpdateColor(RDListViewItem *item,RDLogLine *logline)
{
bool ret=true;
QDateTime now=QDateTime(QDate::currentDate(),QTime::currentTime());
switch(logline->type()) {
case RDLogLine::Cart:
switch(logline->validity(now)) {
case RDCart::AlwaysValid:
if(edit_group_list.isGroupValid(item->text(4))||
item->text(4).isEmpty()) {
item->setBackgroundColor(palette().color(QPalette::Active,
QColorGroup::Base));
}
else {
item->setBackgroundColor(RD_CART_INVALID_SERVICE_COLOR);
ret=false;
}
break;
case RDCart::ConditionallyValid:
item->setBackgroundColor(RD_CART_CONDITIONAL_COLOR);
break;
case RDCart::FutureValid:
item->setBackgroundColor(RD_CART_FUTURE_COLOR);
break;
case RDCart::EvergreenValid:
item->setBackgroundColor(RD_CART_EVERGREEN_COLOR);
break;
case RDCart::NeverValid:
item->setBackgroundColor(RD_CART_ERROR_COLOR);
item->setText(6,tr("[INVALID CART]"));
break;
}
break;
default:
if(edit_group_list.isGroupValid(item->text(4))||
item->text(4).isEmpty()) {
item->setBackgroundColor(palette().color(QPalette::Active,
QColorGroup::Base));
}
else {
item->setBackgroundColor(RD_CART_INVALID_SERVICE_COLOR);
ret=false;
}
break;
}
return ret;
}
void EditLog::RenumberList(int line)
{
QListViewItem *prev=NULL;
QListViewItem *item=edit_log_list->firstChild();
if(item==NULL) {
return;
}
for(int i=0;i<line;i++) {
item=item->nextSibling();
}
while(item!=NULL) {
item->setText(13,QString().sprintf("%d",line++));
prev=item;
item=item->nextSibling();
}
prev->setText(12,QString().sprintf("%d",END_MARKER_ID));
}
void EditLog::SelectRecord(int id)
{
QListViewItem *item=edit_log_list->firstChild();
while(item!=NULL) {
if(item->text(12).toInt()==id) {
edit_log_list->setSelected(item,true);
edit_log_list->ensureItemVisible(item);
return;
}
item=item->nextSibling();
}
}
RDListViewItem *EditLog::SingleSelection()
{
RDListViewItem *item=NULL;
RDListViewItem *next=(RDListViewItem *)edit_log_list->firstChild();
while(next!=NULL) {
if(edit_log_list->isSelected(next)) {
if(item==NULL) {
item=next;
}
else {
return NULL;
}
}
next=(RDListViewItem *)next->nextSibling();
}
return item;
}
bool EditLog::ValidateSvc()
{
RDLogLine *logline=NULL;
bool valid=true;
RDListViewItem *item=(RDListViewItem *)edit_log_list->firstChild();
while(item!=NULL) {
if((logline=edit_log_event->logLine(item->text(13).toInt()))!=NULL) {
valid&=UpdateColor(item,logline);
}
item=(RDListViewItem *)item->nextSibling();
}
return valid;
}
void EditLog::UpdateTracks()
{
unsigned markers=0;
unsigned tracks=0;
RDLogLine *logline;
for(int i=0;i<edit_log_event->size();i++) {
logline=edit_log_event->logLine(i);
if(logline->type()==RDLogLine::Track) {
markers++;
}
if(logline->source()==RDLogLine::Tracker) {
tracks++;
}
}
edit_track_label->
setText(QString().sprintf("%u / %u",tracks,markers+tracks));
}
bool EditLog::DeleteTracks()
{
RDCart *cart;
for(unsigned i=0;i<edit_deleted_tracks.size();i++) {
cart=new RDCart(edit_deleted_tracks[i]);
if(!cart->remove(rdstation_conf,rduser,log_config)) {
delete cart;
return false;
}
delete cart;
}
return true;
}