2021-01-17 Fred Gleason <fredg@paravelsystems.com>

* Added static 'RDCartFilter::phraseFilter()',
	'RDCartFilter::groupFilter()' and 'RDCartFilter::typeFilter()'
	methods.
	* Refactored 'RDCartDialog' to use the model-based API.

Signed-off-by: Fred Gleason <fredg@paravelsystems.com>
This commit is contained in:
Fred Gleason 2021-01-17 10:04:19 -05:00
parent a94a47e38d
commit df749a0f70
18 changed files with 407 additions and 976 deletions

View File

@ -20808,3 +20808,8 @@
of 'int'. of 'int'.
2021-01-15 Fred Gleason <fredg@paravelsystems.com> 2021-01-15 Fred Gleason <fredg@paravelsystems.com>
* Commented out removed slots in 'rdairplay/list_log.cpp'. * Commented out removed slots in 'rdairplay/list_log.cpp'.
2021-01-17 Fred Gleason <fredg@paravelsystems.com>
* Added static 'RDCartFilter::phraseFilter()',
'RDCartFilter::groupFilter()' and 'RDCartFilter::typeFilter()'
methods.
* Refactored 'RDCartDialog' to use the model-based API.

View File

@ -1251,19 +1251,19 @@ barvu</translation>
</message> </message>
<message> <message>
<source>Cart Filter:</source> <source>Cart Filter:</source>
<translation>Filtr vozíku:</translation> <translation type="obsolete">Filtr vozíku:</translation>
</message> </message>
<message> <message>
<source>&amp;Search</source> <source>&amp;Search</source>
<translation>&amp;Hledat</translation> <translation type="obsolete">&amp;Hledat</translation>
</message> </message>
<message> <message>
<source>C&amp;lear</source> <source>C&amp;lear</source>
<translation>S&amp;mazat</translation> <translation type="obsolete">S&amp;mazat</translation>
</message> </message>
<message> <message>
<source>Group:</source> <source>Group:</source>
<translation>Skupina:</translation> <translation type="obsolete">Skupina:</translation>
</message> </message>
<message> <message>
<source>NUMBER</source> <source>NUMBER</source>
@ -1321,19 +1321,19 @@ barvu</translation>
</message> </message>
<message> <message>
<source>ALL</source> <source>ALL</source>
<translation>VŠE</translation> <translation type="obsolete">VŠE</translation>
</message> </message>
<message> <message>
<source>Show Only First</source> <source>Show Only First</source>
<translation>Ukázat pouze první </translation> <translation type="obsolete">Ukázat pouze první </translation>
</message> </message>
<message> <message>
<source>Matches</source> <source>Matches</source>
<translation>Shody</translation> <translation type="obsolete">Shody</translation>
</message> </message>
<message> <message>
<source>Scheduler Code:</source> <source>Scheduler Code:</source>
<translation>Kódy rozvrhovače:</translation> <translation type="obsolete">Kódy rozvrhovače:</translation>
</message> </message>
<message> <message>
<source>Load From <source>Load From
@ -1369,53 +1369,13 @@ ze &amp;souboru</translation>
<source>Importing</source> <source>Importing</source>
<translation>Zavádí se</translation> <translation>Zavádí se</translation>
</message> </message>
<message>
<source>Number</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Length</source> <source>Length</source>
<translation type="unfinished">Délka</translation> <translation type="obsolete">Délka</translation>
</message>
<message>
<source>Title</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Artist</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Group</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Composer</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Conductor</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Client</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Agency</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>User Def</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Start</source>
<translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>End</source> <source>End</source>
<translation type="unfinished">Konec</translation> <translation type="obsolete">Konec</translation>
</message> </message>
<message> <message>
<source>Open Audio File</source> <source>Open Audio File</source>

View File

@ -1247,19 +1247,19 @@ setzen</translation>
</message> </message>
<message> <message>
<source>Cart Filter:</source> <source>Cart Filter:</source>
<translation>Cart Filter:</translation> <translation type="obsolete">Cart Filter:</translation>
</message> </message>
<message> <message>
<source>&amp;Search</source> <source>&amp;Search</source>
<translation>&amp;Suchen</translation> <translation type="obsolete">&amp;Suchen</translation>
</message> </message>
<message> <message>
<source>C&amp;lear</source> <source>C&amp;lear</source>
<translation>&amp;Löschen</translation> <translation type="obsolete">&amp;Löschen</translation>
</message> </message>
<message> <message>
<source>Group:</source> <source>Group:</source>
<translation>Gruppe:</translation> <translation type="obsolete">Gruppe:</translation>
</message> </message>
<message> <message>
<source>NUMBER</source> <source>NUMBER</source>
@ -1317,19 +1317,15 @@ senden</translation>
</message> </message>
<message> <message>
<source>ALL</source> <source>ALL</source>
<translation>ALLE</translation> <translation type="obsolete">ALLE</translation>
</message> </message>
<message> <message>
<source>Show Only First</source> <source>Show Only First</source>
<translation>Zeige nur erste</translation> <translation type="obsolete">Zeige nur erste</translation>
</message> </message>
<message> <message>
<source>Matches</source> <source>Matches</source>
<translation>Treffer</translation> <translation type="obsolete">Treffer</translation>
</message>
<message>
<source>Scheduler Code:</source>
<translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>Load From <source>Load From
@ -1360,53 +1356,13 @@ senden</translation>
<source>Importing</source> <source>Importing</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Number</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Length</source> <source>Length</source>
<translation type="unfinished">Länge</translation> <translation type="obsolete">Länge</translation>
</message>
<message>
<source>Title</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Artist</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Group</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Composer</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Conductor</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Client</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Agency</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>User Def</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Start</source>
<translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>End</source> <source>End</source>
<translation type="unfinished">Ende</translation> <translation type="obsolete">Ende</translation>
</message> </message>
<message> <message>
<source>Open Audio File</source> <source>Open Audio File</source>

View File

@ -1243,15 +1243,15 @@ Color</translation>
</message> </message>
<message> <message>
<source>Cart Filter:</source> <source>Cart Filter:</source>
<translation>Filtrar:</translation> <translation type="obsolete">Filtrar:</translation>
</message> </message>
<message> <message>
<source>C&amp;lear</source> <source>C&amp;lear</source>
<translation>&amp;Limpiar</translation> <translation type="obsolete">&amp;Limpiar</translation>
</message> </message>
<message> <message>
<source>Group:</source> <source>Group:</source>
<translation>Grupo:</translation> <translation type="obsolete">Grupo:</translation>
</message> </message>
<message> <message>
<source>NUMBER</source> <source>NUMBER</source>
@ -1299,7 +1299,7 @@ Color</translation>
</message> </message>
<message> <message>
<source>ALL</source> <source>ALL</source>
<translation>TODAS</translation> <translation type="obsolete">TODAS</translation>
</message> </message>
<message> <message>
<source>GROUP</source> <source>GROUP</source>
@ -1313,7 +1313,7 @@ Color</translation>
</message> </message>
<message> <message>
<source>&amp;Search</source> <source>&amp;Search</source>
<translation>&amp;Buscar</translation> <translation type="obsolete">&amp;Buscar</translation>
</message> </message>
<message> <message>
<source>Please Wait...</source> <source>Please Wait...</source>
@ -1321,15 +1321,15 @@ Color</translation>
</message> </message>
<message> <message>
<source>Show Only First</source> <source>Show Only First</source>
<translation>Mostrar los primeros</translation> <translation type="obsolete">Mostrar los primeros</translation>
</message> </message>
<message> <message>
<source>Matches</source> <source>Matches</source>
<translation>resultados</translation> <translation type="obsolete">resultados</translation>
</message> </message>
<message> <message>
<source>Scheduler Code:</source> <source>Scheduler Code:</source>
<translation>Cód. Programac.:</translation> <translation type="obsolete">Cód. Programac.:</translation>
</message> </message>
<message> <message>
<source>Load From <source>Load From
@ -1360,53 +1360,13 @@ Color</translation>
<source>Importing</source> <source>Importing</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Number</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Length</source> <source>Length</source>
<translation type="unfinished">Longitud</translation> <translation type="obsolete">Longitud</translation>
</message>
<message>
<source>Title</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Artist</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Group</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Composer</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Conductor</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Client</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Agency</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>User Def</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Start</source>
<translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>End</source> <source>End</source>
<translation type="unfinished">Final</translation> <translation type="obsolete">Final</translation>
</message> </message>
<message> <message>
<source>Open Audio File</source> <source>Open Audio File</source>

View File

@ -1136,22 +1136,6 @@ La Couleur</translation>
<source>Please Wait...</source> <source>Please Wait...</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Cart Filter:</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>&amp;Search</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>C&amp;lear</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Group:</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Send to <source>Send to
&amp;Editor</source> &amp;Editor</source>
@ -1165,22 +1149,6 @@ La Couleur</translation>
<source>&amp;Cancel</source> <source>&amp;Cancel</source>
<translation type="unfinished">&amp;Annuler</translation> <translation type="unfinished">&amp;Annuler</translation>
</message> </message>
<message>
<source>ALL</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Scheduler Code:</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Show Only First</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Matches</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Load From <source>Load From
&amp;File</source> &amp;File</source>
@ -1210,53 +1178,13 @@ La Couleur</translation>
<source>Imported from</source> <source>Imported from</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Number</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Length</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Title</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Artist</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Group</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Composer</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Conductor</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Client</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Agency</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>User Def</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Start</source> <source>Start</source>
<translation type="unfinished">Début</translation> <translation type="obsolete">Début</translation>
</message> </message>
<message> <message>
<source>End</source> <source>End</source>
<translation type="unfinished">Fin</translation> <translation type="obsolete">Fin</translation>
</message> </message>
<message> <message>
<source>Open Audio File</source> <source>Open Audio File</source>

View File

@ -1247,19 +1247,19 @@ farge</translation>
</message> </message>
<message> <message>
<source>Cart Filter:</source> <source>Cart Filter:</source>
<translation>Korgfilter:</translation> <translation type="obsolete">Korgfilter:</translation>
</message> </message>
<message> <message>
<source>&amp;Search</source> <source>&amp;Search</source>
<translation>&amp;Søk</translation> <translation type="obsolete">&amp;Søk</translation>
</message> </message>
<message> <message>
<source>C&amp;lear</source> <source>C&amp;lear</source>
<translation>&amp;Tøm</translation> <translation type="obsolete">&amp;Tøm</translation>
</message> </message>
<message> <message>
<source>Group:</source> <source>Group:</source>
<translation>Gruppe:</translation> <translation type="obsolete">Gruppe:</translation>
</message> </message>
<message> <message>
<source>NUMBER</source> <source>NUMBER</source>
@ -1316,19 +1316,7 @@ farge</translation>
</message> </message>
<message> <message>
<source>ALL</source> <source>ALL</source>
<translation>ALLE</translation> <translation type="obsolete">ALLE</translation>
</message>
<message>
<source>Show Only First</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Matches</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Scheduler Code:</source>
<translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>Load From <source>Load From
@ -1359,53 +1347,13 @@ farge</translation>
<source>Importing</source> <source>Importing</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Number</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Length</source> <source>Length</source>
<translation type="unfinished">Lengd</translation> <translation type="obsolete">Lengd</translation>
</message>
<message>
<source>Title</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Artist</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Group</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Composer</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Conductor</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Client</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Agency</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>User Def</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Start</source>
<translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>End</source> <source>End</source>
<translation type="unfinished">Slutten</translation> <translation type="obsolete">Slutten</translation>
</message> </message>
<message> <message>
<source>Open Audio File</source> <source>Open Audio File</source>

View File

@ -1247,19 +1247,19 @@ farge</translation>
</message> </message>
<message> <message>
<source>Cart Filter:</source> <source>Cart Filter:</source>
<translation>Korgfilter:</translation> <translation type="obsolete">Korgfilter:</translation>
</message> </message>
<message> <message>
<source>&amp;Search</source> <source>&amp;Search</source>
<translation>&amp;Søk</translation> <translation type="obsolete">&amp;Søk</translation>
</message> </message>
<message> <message>
<source>C&amp;lear</source> <source>C&amp;lear</source>
<translation>&amp;Tøm</translation> <translation type="obsolete">&amp;Tøm</translation>
</message> </message>
<message> <message>
<source>Group:</source> <source>Group:</source>
<translation>Gruppe:</translation> <translation type="obsolete">Gruppe:</translation>
</message> </message>
<message> <message>
<source>NUMBER</source> <source>NUMBER</source>
@ -1316,19 +1316,7 @@ farge</translation>
</message> </message>
<message> <message>
<source>ALL</source> <source>ALL</source>
<translation>ALLE</translation> <translation type="obsolete">ALLE</translation>
</message>
<message>
<source>Show Only First</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Matches</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Scheduler Code:</source>
<translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>Load From <source>Load From
@ -1359,53 +1347,13 @@ farge</translation>
<source>Importing</source> <source>Importing</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Number</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Length</source> <source>Length</source>
<translation type="unfinished">Lengd</translation> <translation type="obsolete">Lengd</translation>
</message>
<message>
<source>Title</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Artist</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Group</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Composer</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Conductor</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Client</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Agency</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>User Def</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Start</source>
<translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>End</source> <source>End</source>
<translation type="unfinished">Slutten</translation> <translation type="obsolete">Slutten</translation>
</message> </message>
<message> <message>
<source>Open Audio File</source> <source>Open Audio File</source>

View File

@ -1247,19 +1247,19 @@ Cor</translation>
</message> </message>
<message> <message>
<source>Cart Filter:</source> <source>Cart Filter:</source>
<translation>Filtro:</translation> <translation type="obsolete">Filtro:</translation>
</message> </message>
<message> <message>
<source>&amp;Search</source> <source>&amp;Search</source>
<translation>&amp;Procurar</translation> <translation type="obsolete">&amp;Procurar</translation>
</message> </message>
<message> <message>
<source>C&amp;lear</source> <source>C&amp;lear</source>
<translation>&amp;Limpar</translation> <translation type="obsolete">&amp;Limpar</translation>
</message> </message>
<message> <message>
<source>Group:</source> <source>Group:</source>
<translation>Grupo:</translation> <translation type="obsolete">Grupo:</translation>
</message> </message>
<message> <message>
<source>NUMBER</source> <source>NUMBER</source>
@ -1317,19 +1317,7 @@ Cor</translation>
</message> </message>
<message> <message>
<source>ALL</source> <source>ALL</source>
<translation>TODOS</translation> <translation type="obsolete">TODOS</translation>
</message>
<message>
<source>Show Only First</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Matches</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Scheduler Code:</source>
<translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>Load From <source>Load From
@ -1360,53 +1348,13 @@ Cor</translation>
<source>Importing</source> <source>Importing</source>
<translation type="unfinished"></translation> <translation type="unfinished"></translation>
</message> </message>
<message>
<source>Number</source>
<translation type="unfinished"></translation>
</message>
<message> <message>
<source>Length</source> <source>Length</source>
<translation type="unfinished">Duração</translation> <translation type="obsolete">Duração</translation>
</message>
<message>
<source>Title</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Artist</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Group</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Composer</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Conductor</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Client</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Agency</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>User Def</source>
<translation type="unfinished"></translation>
</message>
<message>
<source>Start</source>
<translation type="unfinished"></translation>
</message> </message>
<message> <message>
<source>End</source> <source>End</source>
<translation type="unfinished">Fim</translation> <translation type="obsolete">Fim</translation>
</message> </message>
<message> <message>
<source>Open Audio File</source> <source>Open Audio File</source>

View File

@ -2,7 +2,7 @@
// //
// A widget to select a Rivendell Cart. // A widget to select a Rivendell Cart.
// //
// (C) Copyright 2002-2020 Fred Gleason <fredg@paravelsystems.com> // (C) Copyright 2002-2021 Fred Gleason <fredg@paravelsystems.com>
// //
// This program is free software; you can redistribute it and/or modify // 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 // it under the terms of the GNU General Public License version 2 as
@ -21,51 +21,32 @@
#include <stdlib.h> #include <stdlib.h>
#include <stdio.h> #include <stdio.h>
#include <qapplication.h> #include <QApplication>
#include <qfiledialog.h> #include <QFileDialog>
#include <qmessagebox.h> #include <QMessageBox>
#include "rdapplication.h" #include "rdapplication.h"
#include "rdaudioimport.h" #include "rdaudioimport.h"
#include "rdcart_dialog.h" #include "rdcart_dialog.h"
#include "rdcart_search_text.h"
#include "rdconf.h" #include "rdconf.h"
#include "rddb.h" #include "rddb.h"
#include "rdescape_string.h" #include "rdescape_string.h"
#include "rdgroup.h" #include "rdgroup.h"
#include "rdprofile.h" #include "rdprofile.h"
#include "rdsettings.h" #include "rdsettings.h"
#include "rdtextvalidator.h"
#include "rdwavefile.h" #include "rdwavefile.h"
//
// Icons
//
#include "../icons/play.xpm"
#include "../icons/rml5.xpm"
RDCartDialog::RDCartDialog(QString *filter,QString *group,QString *schedcode, RDCartDialog::RDCartDialog(QString *filter,QString *group,QString *schedcode,
const QString &caption,QWidget *parent) const QString &caption,bool user_is_admin,
QWidget *parent)
: RDDialog(parent) : RDDialog(parent)
{ {
cart_caption=caption; cart_caption=caption;
//
// Fix the Window Size
//
setMinimumWidth(sizeHint().width());
setMinimumHeight(sizeHint().height());
cart_cartnum=NULL; cart_cartnum=NULL;
cart_type=RDCart::All; cart_type=RDCart::All;
cart_group=group;
cart_schedcode=schedcode;
if(cart_schedcode->isNull()) {
*cart_schedcode=tr("ALL");
}
cart_temp_allowed=NULL; cart_temp_allowed=NULL;
cart_filter_mode=rda->station()->filterMode(); cart_filter_mode=rda->station()->filterMode();
if(filter==NULL) { if(filter==NULL) {
cart_filter=new QString(); cart_filter=new QString();
local_filter=true; local_filter=true;
@ -79,17 +60,6 @@ RDCartDialog::RDCartDialog(QString *filter,QString *group,QString *schedcode,
setWindowTitle(caption+" - "+tr("Select Cart")); setWindowTitle(caption+" - "+tr("Select Cart"));
//
// Create Icons
//
cart_playout_map=new QPixmap(play_xpm);
cart_macro_map=new QPixmap(rml5_xpm);
//
// Text Validator
//
RDTextValidator *validator=new RDTextValidator(this,"validator",true);
// //
// Progress Dialog // Progress Dialog
// //
@ -107,122 +77,38 @@ RDCartDialog::RDCartDialog(QString *filter,QString *group,QString *schedcode,
cart_busy_dialog=new RDBusyDialog(this); cart_busy_dialog=new RDBusyDialog(this);
// //
// Filter Selector // Cart Filter
// //
cart_filter_edit=new QLineEdit(this); cart_cart_filter=new RDCartFilter(this);
cart_filter_edit->setValidator(validator); cart_cart_filter->setUserIsAdmin(user_is_admin);
cart_filter_label=new QLabel(cart_filter_edit,tr("Cart Filter:"),this); connect(rda,SIGNAL(userChanged()),cart_cart_filter,SLOT(changeUser()));
cart_filter_label->setAlignment(Qt::AlignRight|Qt::AlignVCenter);
cart_filter_label->setFont(labelFont());
connect(cart_filter_edit,SIGNAL(textChanged(const QString &)),
this,SLOT(filterChangedData(const QString &)));
//
// Filter Search Button
//
cart_search_button=new QPushButton(this);
cart_search_button->setText(tr("&Search"));
cart_search_button->setFont(buttonFont());
connect(cart_search_button,SIGNAL(clicked()),this,SLOT(filterSearchedData()));
//
// Filter Clear Button
//
cart_clear_button=new QPushButton(this);
cart_clear_button->setText(tr("C&lear"));
cart_clear_button->setFont(buttonFont());
connect(cart_clear_button,SIGNAL(clicked()),this,SLOT(filterClearedData()));
//
// Group Code Selector
//
cart_group_box=new RDComboBox(this);
cart_group_label=new QLabel(cart_group_box,tr("Group:"),this);
cart_group_label->setAlignment(Qt::AlignRight|Qt::AlignVCenter);
cart_group_label->setFont(labelFont());
connect(cart_group_box,SIGNAL(activated(const QString &)),
this,SLOT(groupActivatedData(const QString &)));
//
// Scheduler Code Selector
//
cart_schedcode_box=new RDComboBox(this);
cart_schedcode_label=
new QLabel(cart_schedcode_box,tr("Scheduler Code:"),this);
cart_schedcode_label->setAlignment(Qt::AlignRight|Qt::AlignVCenter);
cart_schedcode_label->setFont(labelFont());
connect(cart_schedcode_box,SIGNAL(activated(const QString &)),
this,SLOT(schedcodeActivatedData(const QString &)));
//
// Search Limit Checkbox
//
cart_limit_box=new QCheckBox(this);
cart_limit_box->setChecked(true);
cart_limit_label=
new QLabel(cart_limit_box,tr("Show Only First")+
QString().sprintf(" %d ",
RD_LIMITED_CART_SEARCH_QUANTITY)+tr("Matches"),this);
cart_limit_label->setAlignment(Qt::AlignLeft|Qt::AlignVCenter);
cart_limit_label->setFont(labelFont());
connect(cart_limit_box,SIGNAL(stateChanged(int)),
this,SLOT(limitChangedData(int)));
// //
// Cart List // Cart List
// //
cart_cart_list=new RDListView(this); cart_cart_view=new QTableView(this);
cart_cart_list->setSelectionMode(Q3ListView::Single); cart_cart_view->setSelectionBehavior(QAbstractItemView::SelectRows);
cart_cart_list->setAllColumnsShowFocus(true); cart_cart_view->setSelectionMode(QAbstractItemView::SingleSelection);
cart_cart_list->setItemMargin(5); cart_cart_view->setShowGrid(false);
connect(cart_cart_list,SIGNAL(clicked(Q3ListViewItem *)), cart_cart_view->setSortingEnabled(false);
this,SLOT(clickedData(Q3ListViewItem *))); cart_cart_view->setWordWrap(false);
connect(cart_cart_list, cart_cart_model=new RDLibraryModel(this);
SIGNAL(doubleClicked(Q3ListViewItem *,const QPoint &,int)), cart_cart_model->setFont(font());
this, cart_cart_model->setPalette(palette());
SLOT(doubleClickedData(Q3ListViewItem *,const QPoint &,int))); cart_cart_view->setModel(cart_cart_model);
cart_cart_label=new QLabel(cart_cart_list,"Carts",this); connect(cart_cart_filter,SIGNAL(filterChanged(const QString &)),
cart_cart_label->setFont(labelFont()); cart_cart_model,SLOT(setFilterSql(const QString &)));
cart_cart_list->addColumn(""); connect(cart_cart_model,SIGNAL(modelReset()),this,SLOT(modelResetData()));
cart_cart_list->setColumnAlignment(0,Qt::AlignHCenter);
cart_cart_list->addColumn(tr("Number")); connect(cart_cart_model,SIGNAL(rowCountChanged(int)),
cart_cart_list->setColumnAlignment(1,Qt::AlignHCenter); cart_cart_filter,SLOT(setMatchCount(int)));
connect(cart_cart_view,SIGNAL(doubleClicked(const QModelIndex &)),
cart_cart_list->addColumn(tr("Length")); this,SLOT(cartDoubleClickedData(const QModelIndex &)));
cart_cart_list->setColumnAlignment(2,Qt::AlignRight); connect(cart_cart_view->selectionModel(),
cart_cart_list->setColumnSortType(2,RDListView::TimeSort); SIGNAL(selectionChanged(const QItemSelection &,const QItemSelection &)),
this,
cart_cart_list->addColumn(tr("Title"),200); SLOT(selectionChangedData(const QItemSelection &,
cart_cart_list->setColumnAlignment(3,Qt::AlignLeft); const QItemSelection &)));
cart_cart_list->setColumnWidthMode(3,Q3ListView::Manual);
cart_cart_list->addColumn(tr("Artist"));
cart_cart_list->setColumnAlignment(4,Qt::AlignLeft);
cart_cart_list->addColumn(tr("Group"));
cart_cart_list->setColumnAlignment(5,Qt::AlignLeft);
cart_cart_list->addColumn(tr("Composer"));
cart_cart_list->setColumnAlignment(6,Qt::AlignLeft);
cart_cart_list->addColumn(tr("Conductor"));
cart_cart_list->setColumnAlignment(7,Qt::AlignLeft);
cart_cart_list->addColumn(tr("Client"));
cart_cart_list->setColumnAlignment(8,Qt::AlignLeft);
cart_cart_list->addColumn(tr("Agency"));
cart_cart_list->setColumnAlignment(9,Qt::AlignLeft);
cart_cart_list->addColumn(tr("User Def"));
cart_cart_list->setColumnAlignment(10,Qt::AlignLeft);
cart_cart_list->addColumn(tr("Start"));
cart_cart_list->setColumnAlignment(11,Qt::AlignLeft);
cart_cart_list->addColumn(tr("End"));
cart_cart_list->setColumnAlignment(12,Qt::AlignLeft);
// //
// Audition Player // Audition Player
@ -272,32 +158,42 @@ RDCartDialog::RDCartDialog(QString *filter,QString *group,QString *schedcode,
cart_cancel_button=new QPushButton(tr("&Cancel"),this); cart_cancel_button=new QPushButton(tr("&Cancel"),this);
cart_cancel_button->setFont(buttonFont()); cart_cancel_button->setFont(buttonFont());
connect(cart_cancel_button,SIGNAL(clicked()),this,SLOT(cancelData())); connect(cart_cancel_button,SIGNAL(clicked()),this,SLOT(cancelData()));
cart_cart_model->setFilterSql(cart_cart_filter->filterSql());
//
// Fix the Window Size
//
setMinimumWidth(sizeHint().width());
setMinimumHeight(sizeHint().height());
cart_cart_filter->changeUser();
} }
RDCartDialog::~RDCartDialog() RDCartDialog::~RDCartDialog()
{ {
if(local_filter) { delete cart_cart_filter;
delete cart_filter; delete cart_cart_model;
} delete cart_cart_view;
if(cart_player!=NULL) { if(cart_player!=NULL) {
delete cart_player; delete cart_player;
} }
delete cart_playout_map;
delete cart_macro_map;
} }
QSize RDCartDialog::sizeHint() const QSize RDCartDialog::sizeHint() const
{ {
return QSize(640,400); return QSize(cart_cart_filter->sizeHint().width(),400);
} }
int RDCartDialog::exec(int *cartnum,RDCart::Type type,QString *svcname, int RDCartDialog::exec(int *cartnum,RDCart::Type type,QString *svcname,
int svc_quan,const QString &username, int svc_quan,const QString &username,
const QString &passwd,bool *temp_allowed) const QString &passwd,bool *temp_allowed)
{ {
LoadState(); LoadState();
cart_cart_filter->setShowCartType(type);
cart_cartnum=cartnum; cart_cartnum=cartnum;
cart_type=type; cart_type=type;
cart_service=svcname; cart_service=svcname;
@ -334,102 +230,33 @@ int RDCartDialog::exec(int *cartnum,RDCart::Type type,QString *svcname,
} }
break; break;
} }
if(*cart_cartnum==0) { cart_ok_button->setEnabled(false);
cart_ok_button->setDisabled(true);
}
switch(cart_filter_mode) {
case RDStation::FilterAsynchronous:
cart_search_button->setDefault(true);
break;
case RDStation::FilterSynchronous: if(cart_cartnum!=NULL) {
cart_ok_button->setDefault(true); QModelIndex index=cart_cart_model->cartRow(*cart_cartnum);
cart_search_button->hide(); cart_cart_view->selectRow(index.row());
} }
BuildGroupList();
cart_filter_edit->setText(*cart_filter);
RefreshCarts();
RDListViewItem *item=(RDListViewItem *)cart_cart_list->firstChild();
while(item!=NULL) {
if(item->text(1).toInt()==*cartnum) {
cart_cart_list->setSelected(item,true);
cart_cart_list->ensureItemVisible(item);
clickedData(item);
return QDialog::exec();
}
item=(RDListViewItem *)item->nextSibling();
}
cart_filter_edit->setFocus();
return QDialog::exec(); return QDialog::exec();
} }
void RDCartDialog::modelResetData()
{
cart_cart_view->resizeColumnsToContents();
if(cart_cartnum!=NULL) {
QModelIndex index=cart_cart_model->cartRow(*cart_cartnum);
cart_cart_view->selectRow(index.row());
}
}
QSizePolicy RDCartDialog::sizePolicy() const QSizePolicy RDCartDialog::sizePolicy() const
{ {
return QSizePolicy(QSizePolicy::Fixed,QSizePolicy::Fixed); return QSizePolicy(QSizePolicy::Fixed,QSizePolicy::Fixed);
} }
void RDCartDialog::filterChangedData(const QString &str)
{
cart_search_button->setEnabled(true);
switch(cart_filter_mode) {
case RDStation::FilterSynchronous:
filterSearchedData();
break;
case RDStation::FilterAsynchronous:
break;
}
}
void RDCartDialog::filterSearchedData()
{
if(cart_filter_edit->text().isEmpty()) {
cart_clear_button->setDisabled(true);
}
else {
cart_clear_button->setEnabled(true);
}
RefreshCarts();
}
void RDCartDialog::filterClearedData()
{
cart_filter_edit->clear();
filterChangedData("");
}
void RDCartDialog::groupActivatedData(const QString &group)
{
filterChangedData("");
if(cart_group!=NULL) {
*cart_group=group;
}
}
void RDCartDialog::schedcodeActivatedData(const QString &schedcode)
{
filterChangedData("");
if(cart_schedcode!=NULL) {
*cart_schedcode=schedcode;
}
if(cart_schedcode!=NULL) {
*cart_schedcode=schedcode;
}
}
void RDCartDialog::limitChangedData(int state)
{
filterChangedData("");
}
void RDCartDialog::clickedData(Q3ListViewItem *item) void RDCartDialog::clickedData(Q3ListViewItem *item)
{ {
RDListViewItem *i=(RDListViewItem *)item; RDListViewItem *i=(RDListViewItem *)item;
@ -447,30 +274,51 @@ void RDCartDialog::clickedData(Q3ListViewItem *item)
} }
void RDCartDialog::doubleClickedData(Q3ListViewItem *,const QPoint &,int) void RDCartDialog::cartDoubleClickedData(const QModelIndex &index)
{ {
okData(); okData();
} }
void RDCartDialog::selectionChangedData(const QItemSelection &before,
const QItemSelection &after)
{
QModelIndexList rows=cart_cart_view->selectionModel()->selectedRows();
cart_ok_button->setEnabled(rows.size()==1);
}
void RDCartDialog::editorData() void RDCartDialog::editorData()
{ {
RDListViewItem *item=(RDListViewItem *)cart_cart_list->currentItem(); QModelIndexList rows=cart_cart_view->selectionModel()->selectedRows();
if(item==NULL) {
if(rows.size()!=1) {
return; return;
} }
unsigned cartnum=cart_cart_model->cartNumber(rows.first());
QString sql; QString sql;
RDSqlQuery *q; RDSqlQuery *q;
sql=QString().sprintf("select CUTS.CUT_NAME,CUTS.LENGTH,CART.GROUP_NAME,\ sql=QString("select ")+
CART.TITLE,CART.ARTIST,CART.ALBUM,CART.YEAR,\ "CUTS.CUT_NAME,"+ // 00
CART.LABEL,CART.CLIENT,CART.AGENCY,CART.COMPOSER,\ "CUTS.LENGTH,"+ // 01
CART.PUBLISHER,CART.USER_DEFINED \ "CART.GROUP_NAME,"+ // 02
from CUTS left join CART \ "CART.TITLE,"+ // 03
on CUTS.CART_NUMBER=CART.NUMBER \ "CART.ARTIST,"+ // 04
where (CUTS.CART_NUMBER=%u)&&(CUTS.LENGTH>0)", "CART.ALBUM,"+ // 05
item->text(1).toUInt()); "CART.YEAR,"+ // 06
"CART.LABEL,"+ // 07
"CART.CLIENT,"+ // 08
"CART.AGENCY,"+ // 09
"CART.COMPOSER,"+ // 10
"CART.PUBLISHER,"+ // 11
"CART.USER_DEFINED "+ // 12
"from CUTS left join CART "+
"on CUTS.CART_NUMBER=CART.NUMBER where "+
QString().sprintf("(CUTS.CART_NUMBER=%u)&&",cartnum)+
"(CUTS.LENGTH>0)";
q=new RDSqlQuery(sql); q=new RDSqlQuery(sql);
if(!q->first()) { if(!q->first()) {
delete q; delete q;
@ -478,7 +326,7 @@ void RDCartDialog::editorData()
} }
QString cmd=rda->station()->editorPath(); QString cmd=rda->station()->editorPath();
cmd.replace("%f",RDCut::pathName(q->value(0).toString())); cmd.replace("%f",RDCut::pathName(q->value(0).toString()));
cmd.replace("%n",QString().sprintf("%06u",item->text(1).toUInt())); cmd.replace("%n",QString().sprintf("%06u",cartnum));
cmd.replace("%h",QString().sprintf("%d",q->value(1).toInt())); cmd.replace("%h",QString().sprintf("%d",q->value(1).toInt()));
cmd.replace("%g",q->value(2).toString()); cmd.replace("%g",q->value(2).toString());
cmd.replace("%t",q->value(3).toString()); cmd.replace("%t",q->value(3).toString());
@ -586,22 +434,21 @@ void RDCartDialog::loadFileData()
void RDCartDialog::okData() void RDCartDialog::okData()
{ {
RDListViewItem *item=(RDListViewItem *)cart_cart_list->currentItem(); QModelIndexList rows=cart_cart_view->selectionModel()->selectedRows();
if(item==NULL) {
return; if(rows.size()==1) {
SaveState();
if(cart_player!=NULL) {
cart_player->stop();
}
*cart_filter=cart_cart_filter->filterText();
*cart_cartnum=cart_cart_model->cartNumber(rows.first());
if(cart_temp_allowed!=NULL) {
*cart_temp_allowed=false;
}
} }
SaveState();
if(cart_player!=NULL) {
cart_player->stop();
}
if(!local_filter) {
*cart_filter=cart_filter_edit->text();
}
*cart_cartnum=item->text(1).toInt();
if(cart_temp_allowed!=NULL) {
*cart_temp_allowed=false;
}
done(0); done(0);
} }
@ -618,34 +465,20 @@ void RDCartDialog::cancelData()
void RDCartDialog::resizeEvent(QResizeEvent *e) void RDCartDialog::resizeEvent(QResizeEvent *e)
{ {
cart_filter_label->setGeometry(10,10,85,20); int w=size().width();
int h=size().height();
cart_search_button->setGeometry(size().width()-160,5,70,30); cart_cart_filter->setGeometry(0,0,w,cart_cart_filter->sizeHint().height());
cart_clear_button->setGeometry(size().width()-80,5,70,30);
cart_group_box->setGeometry(100,40,150,20);
cart_group_label->setGeometry(10,40,85,20);
cart_schedcode_box->setGeometry(390,40,150,20);
cart_schedcode_label->setGeometry(280,40,105,20);
cart_limit_box->setGeometry(100,72,15,15);
cart_limit_label->setGeometry(120,70,300,20);
cart_cart_label->setGeometry(15,90,100,20);
cart_cart_list->setGeometry(10,110,size().width()-20,size().height()-180);
cart_editor_button->setGeometry(235,size().height()-60,80,50);
cart_file_button->setGeometry(325,size().height()-60,80,50);
cart_ok_button->setGeometry(size().width()-180,size().height()-60,80,50);
cart_cancel_button->setGeometry(size().width()-90,size().height()-60,80,50);
switch(cart_filter_mode) {
case RDStation::FilterAsynchronous:
cart_filter_edit->setGeometry(100,10,size().width()-280,20);
break;
case RDStation::FilterSynchronous: cart_cart_view->setGeometry(10,cart_cart_filter->sizeHint().height(),
cart_filter_edit->setGeometry(100,10,size().width()-200,20); w-20,h-cart_cart_filter->sizeHint().height()-70);
break; cart_editor_button->setGeometry(235,h-60,80,50);
} cart_file_button->setGeometry(325,h-60,80,50);
cart_ok_button->setGeometry(w-180,h-60,80,50);
cart_cancel_button->setGeometry(w-90,h-60,80,50);
if(cart_player!=NULL) { if(cart_player!=NULL) {
cart_player->playButton()->setGeometry(10,size().height()-60,80,50); cart_player->playButton()->setGeometry(10,h-60,80,50);
cart_player->stopButton()->setGeometry(100,size().height()-60,80,50); cart_player->stopButton()->setGeometry(100,h-60,80,50);
} }
} }
@ -659,213 +492,6 @@ void RDCartDialog::closeEvent(QCloseEvent *e)
} }
void RDCartDialog::RefreshCarts()
{
QString sql;
RDSqlQuery *q;
RDListViewItem *l;
cart_cart_list->clear();
QString group=cart_group_box->currentText();
if(group==QString(tr("ALL"))) {
group="";
}
QString schedcode=cart_schedcode_box->currentText();
if(schedcode==QString(tr("ALL"))) {
schedcode="";
}
if(cart_type==RDCart::All) {
sql=QString("select ")+
"CART.NUMBER,"+ // 00
"CART.TITLE,"+ // 01
"CART.ARTIST,"+ // 02
"CART.CLIENT,"+ // 03
"CART.AGENCY,"+ // 04
"CART.USER_DEFINED,"+ // 05
"CART.COMPOSER,"+ // 06
"CART.CONDUCTOR,"+ // 07
"CART.START_DATETIME,"+ // 08
"CART.END_DATETIME,"+ // 09
"CART.TYPE,"+ // 10
"CART.FORCED_LENGTH,"+ // 11
"CART.GROUP_NAME,"+ // 12
"GROUPS.COLOR "+ // 13
"from CART left join GROUPS "+
"on CART.GROUP_NAME=GROUPS.NAME "+
GetSearchFilter(cart_filter_edit->text(),group,schedcode);
}
else {
sql=QString("select ")+
"CART.NUMBER,"+ // 00
"CART.TITLE,"+ // 01
"CART.ARTIST,"+ // 02
"CART.CLIENT,"+ // 03
"CART.AGENCY,"+ // 04
"CART.USER_DEFINED,"+ // 05
"CART.COMPOSER,"+ // 06
"CART.CONDUCTOR,"+ // 07
"CART.START_DATETIME,"+ // 08
"CART.END_DATETIME,"+ // 09
"CART.TYPE,"+ // 10
"CART.FORCED_LENGTH,"+ // 11
"CART.GROUP_NAME,"+ // 12
"GROUPS.COLOR "+ // 13
"from CART left join GROUPS "+
"on CART.GROUP_NAME=GROUPS.NAME "+
GetSearchFilter(cart_filter_edit->text(),group,schedcode)+"&&"+
QString().sprintf("(TYPE=%d)",cart_type);
}
if(cart_limit_box->isChecked()) {
sql+=QString().sprintf(" limit %d",RD_LIMITED_CART_SEARCH_QUANTITY);
}
q=new RDSqlQuery(sql);
int step=0;
int count=0;
cart_progress_dialog->setMaximum(q->size()/RDCART_DIALOG_STEP_SIZE);
cart_progress_dialog->setValue(0);
while(q->next()) {
l=new RDListViewItem(cart_cart_list);
l->setId(q->value(10).toUInt());
switch((RDCart::Type)q->value(10).toUInt()) {
case RDCart::Audio:
l->setPixmap(0,*cart_playout_map);
break;
case RDCart::Macro:
l->setPixmap(0,*cart_macro_map);
break;
default:
break;
}
l->setText(1,QString().sprintf("%06d",q->value(0).toUInt())); // Number
l->setText(2,RDGetTimeLength(q->value(11).toInt(),false,true)); // Length
l->setText(3,q->value(1).toString()); // Title
l->setText(4,q->value(2).toString()); // Artist
l->setText(5,q->value(12).toString()); // Group
l->setText(6,q->value(6).toString()); // Composer
l->setText(7,q->value(7).toString()); // Conductor
l->setTextColor(5,q->value(13).toString(),QFont::Bold);
l->setText(8,q->value(3).toString()); // Client
l->setText(9,q->value(4).toString()); // Agency
l->setText(10,q->value(5).toString()); // User Defined
if(!q->value(8).toDate().isNull()) {
l->setText(11,q->value(8).toDate().toString("MM/dd/yyyy")); // Start Date
}
if(!q->value(10).toDate().isNull()) {
l->setText(12,q->value(9).toDate().toString("MM/dd/yyyy")); // End Date
}
else {
l->setText(12,"TFN");
}
if(count++>RDCART_DIALOG_STEP_SIZE) {
cart_progress_dialog->setValue(++step);
count=0;
QApplication::processEvents(QEventLoop::ExcludeUserInputEvents);
}
}
cart_progress_dialog->reset();
delete q;
cart_search_button->setDisabled(true);
}
void RDCartDialog::BuildGroupList()
{
QString sql;
RDSqlQuery *q;
//
// Groups
//
cart_group_box->clear();
cart_group_box->insertItem(tr("ALL"));
sql="select GROUP_NAME from AUDIO_PERMS";
if(cart_service_quan>0) {
sql+=" where ";
for(int i=0;i<cart_service_quan;i++) {
if(!cart_service[i].isEmpty()) {
sql+=QString("(SERVICE_NAME=\"")+
RDEscapeString(cart_service[i])+"\")||";
}
}
sql=sql.left(sql.length()-2);
}
sql+=" order by GROUP_NAME";
q=new RDSqlQuery(sql);
while(q->next()) {
cart_group_box->insertItem(q->value(0).toString(),true);
}
delete q;
//
// Preselect Group
//
if(cart_group!=NULL) {
for(int i=0;i<cart_group_box->count();i++) {
if(*cart_group==cart_group_box->text(i)) {
cart_group_box->setCurrentItem(i);
break;
}
}
}
//
// Scheduler Codes
//
cart_schedcode_box->clear();
cart_schedcode_box->insertItem(tr("ALL"));
sql="select CODE from SCHED_CODES";
q=new RDSqlQuery(sql);
while(q->next()) {
cart_schedcode_box->insertItem(q->value(0).toString());
}
delete q;
//
// Preselect Scheduler Code
//
if(cart_schedcode!=NULL) {
for(int i=0;i<cart_schedcode_box->count();i++) {
if(*cart_schedcode==cart_schedcode_box->text(i)) {
cart_schedcode_box->setCurrentItem(i);
break;
}
}
}
}
QString RDCartDialog::GetSearchFilter(const QString &filter,
const QString &group,
const QString &schedcode)
{
QString sql;
RDSqlQuery *q;
QString sched="";
if(schedcode!=tr("ALL")) {
sched=schedcode;
}
QString search=RDCartSearchText(filter,group,sched,false);
//
// Excluded Groups
//
sql=QString().sprintf("select NAME from GROUPS where ");
for(int i=1;i<cart_group_box->count();i++) {
sql+=QString("(NAME!=\"")+RDEscapeString(cart_group_box->text(i))+"\")&&";
}
sql=sql.left(sql.length()-2);
q=new RDSqlQuery(sql);
while(q->next()) {
search+=QString("&&(GROUP_NAME!=\"")+
RDEscapeString(q->value(0).toString())+"\")";
}
delete q;
return search;
}
QString RDCartDialog::StateFile() { QString RDCartDialog::StateFile() {
bool home_found = false; bool home_found = false;
QString home = RDGetHomeDir(&home_found); QString home = RDGetHomeDir(&home_found);
@ -887,9 +513,8 @@ void RDCartDialog::LoadState()
RDProfile *p=new RDProfile(); RDProfile *p=new RDProfile();
p->setSource(state_file); p->setSource(state_file);
bool value_read = false; cart_cart_filter->
cart_limit_box->setChecked(p->boolValue("RDCartDialog", "LimitSearch", true, &value_read)); setLimitSearch(p->boolValue("RDCartDialog","LimitSearch",true));
delete p; delete p;
} }
@ -907,7 +532,7 @@ void RDCartDialog::SaveState()
return; return;
} }
fprintf(f,"[RDCartDialog]\n"); fprintf(f,"[RDCartDialog]\n");
if(cart_limit_box->isChecked()) { if(cart_cart_filter->limitSearch()) {
fprintf(f,"LimitSearch=Yes\n"); fprintf(f,"LimitSearch=Yes\n");
} }
else { else {

View File

@ -2,7 +2,7 @@
// //
// A widget to select a Rivendell Cart. // A widget to select a Rivendell Cart.
// //
// (C) Copyright 2002-2020 Fred Gleason <fredg@paravelsystems.com> // (C) Copyright 2002-2021 Fred Gleason <fredg@paravelsystems.com>
// //
// This program is free software; you can redistribute it and/or modify // 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 // it under the terms of the GNU General Public License version 2 as
@ -21,17 +21,18 @@
#ifndef RDCART_DIALOG_H #ifndef RDCART_DIALOG_H
#define RDCART_DIALOG_H #define RDCART_DIALOG_H
#include <qcheckbox.h> #include <QCheckBox>
#include <qlabel.h> #include <QLabel>
#include <qlineedit.h> #include <QLineEdit>
#include <qprogressdialog.h> #include <QProgressDialog>
#include <qpushbutton.h> #include <QPushButton>
#include <QTableView>
#include <rdbusydialog.h> #include <rdbusydialog.h>
#include <rdcart.h> #include <rdcart.h>
#include <rdcombobox.h>
#include <rddialog.h> #include <rddialog.h>
#include <rdlistviewitem.h> #include <rdcartfilter.h>
#include <rdlibrarymodel.h>
#include <rdsimpleplayer.h> #include <rdsimpleplayer.h>
#define RDCART_DIALOG_STEP_SIZE 1000 #define RDCART_DIALOG_STEP_SIZE 1000
@ -41,7 +42,7 @@ class RDCartDialog : public RDDialog
Q_OBJECT Q_OBJECT
public: public:
RDCartDialog(QString *filter,QString *group,QString *schedcode, RDCartDialog(QString *filter,QString *group,QString *schedcode,
const QString &caption,QWidget *parent=0); const QString &caption,bool user_is_admin,QWidget *parent=0);
~RDCartDialog(); ~RDCartDialog();
QSize sizeHint() const; QSize sizeHint() const;
QSizePolicy sizePolicy() const; QSizePolicy sizePolicy() const;
@ -52,14 +53,11 @@ class RDCartDialog : public RDDialog
bool *temp_allowed=NULL); bool *temp_allowed=NULL);
private slots: private slots:
void filterChangedData(const QString &); void modelResetData();
void filterSearchedData();
void filterClearedData();
void groupActivatedData(const QString &group);
void schedcodeActivatedData(const QString &schedcode);
void limitChangedData(int state);
void clickedData(Q3ListViewItem *item); void clickedData(Q3ListViewItem *item);
void doubleClickedData(Q3ListViewItem *,const QPoint &,int); void cartDoubleClickedData(const QModelIndex &index);
void selectionChangedData(const QItemSelection &before,
const QItemSelection &after);
void editorData(); void editorData();
void loadFileData(); void loadFileData();
void okData(); void okData();
@ -70,37 +68,20 @@ class RDCartDialog : public RDDialog
void closeEvent(QCloseEvent *e); void closeEvent(QCloseEvent *e);
private: private:
void RefreshCarts();
void BuildGroupList();
QString GetSearchFilter(const QString &filter,const QString &group,
const QString &schedcode);
QString StateFile(); QString StateFile();
void LoadState(); void LoadState();
void SaveState(); void SaveState();
int *cart_cartnum; int *cart_cartnum;
QLabel *cart_cart_label; RDCartFilter *cart_cart_filter;
RDListView *cart_cart_list; QTableView *cart_cart_view;
QLabel *cart_filter_label; RDLibraryModel *cart_cart_model;
QLineEdit *cart_filter_edit;
QLabel *cart_limit_label;
QCheckBox *cart_limit_box;
QPushButton *cart_ok_button; QPushButton *cart_ok_button;
QPushButton *cart_cancel_button; QPushButton *cart_cancel_button;
QPushButton *cart_search_button;
QPushButton *cart_clear_button;
QPushButton *cart_editor_button; QPushButton *cart_editor_button;
QPushButton *cart_file_button; QPushButton *cart_file_button;
QLabel *cart_group_label;
RDComboBox *cart_group_box;
QLabel *cart_schedcode_label;
RDComboBox *cart_schedcode_box;
QString *cart_filter; QString *cart_filter;
QString *cart_group;
QString *cart_schedcode;
bool local_filter; bool local_filter;
RDCart::Type cart_type; RDCart::Type cart_type;
QPixmap *cart_playout_map;
QPixmap *cart_macro_map;
QString *cart_service; QString *cart_service;
int cart_service_quan; int cart_service_quan;
RDStation::FilterMode cart_filter_mode; RDStation::FilterMode cart_filter_mode;

View File

@ -28,6 +28,9 @@
RDCartFilter::RDCartFilter(QWidget *parent) RDCartFilter::RDCartFilter(QWidget *parent)
: RDWidget(parent) : RDWidget(parent)
{ {
d_show_cart_type=RDCart::All;
d_user_is_admin=false;
d_filter_edit=new QLineEdit(this); d_filter_edit=new QLineEdit(this);
d_filter_label=new QLabel(d_filter_edit,tr("Filter:"),this); d_filter_label=new QLabel(d_filter_edit,tr("Filter:"),this);
d_filter_label->setFont(labelFont()); d_filter_label->setFont(labelFont());
@ -117,23 +120,23 @@ RDCartFilter::RDCartFilter(QWidget *parent)
// //
// Show Audio Carts Checkbox // Show Audio Carts Checkbox
// //
d_showaudio_box=new QCheckBox(this); d_showaudio_check=new QCheckBox(this);
d_showaudio_box->setChecked(true); d_showaudio_check->setChecked(true);
d_showaudio_label=new QLabel(d_showaudio_box,tr("Show Audio Carts"),this); d_showaudio_label=new QLabel(d_showaudio_check,tr("Show Audio Carts"),this);
d_showaudio_label->setFont(labelFont()); d_showaudio_label->setFont(labelFont());
d_showaudio_label->setAlignment(Qt::AlignVCenter|Qt::AlignLeft); d_showaudio_label->setAlignment(Qt::AlignVCenter|Qt::AlignLeft);
connect(d_showaudio_box,SIGNAL(stateChanged(int)), connect(d_showaudio_check,SIGNAL(stateChanged(int)),
this,SLOT(checkChangedData(int))); this,SLOT(checkChangedData(int)));
// //
// Show Macro Carts Checkbox // Show Macro Carts Checkbox
// //
d_showmacro_box=new QCheckBox(this); d_showmacro_check=new QCheckBox(this);
d_showmacro_box->setChecked(true); d_showmacro_check->setChecked(true);
d_showmacro_label=new QLabel(d_showmacro_box,tr("Show Macro Carts"),this); d_showmacro_label=new QLabel(d_showmacro_check,tr("Show Macro Carts"),this);
d_showmacro_label->setFont(labelFont()); d_showmacro_label->setFont(labelFont());
d_showmacro_label->setAlignment(Qt::AlignVCenter|Qt::AlignLeft); d_showmacro_label->setAlignment(Qt::AlignVCenter|Qt::AlignLeft);
connect(d_showmacro_box,SIGNAL(stateChanged(int)), connect(d_showmacro_check,SIGNAL(stateChanged(int)),
this,SLOT(checkChangedData(int))); this,SLOT(checkChangedData(int)));
// //
@ -223,8 +226,27 @@ void RDCartFilter::saveConfig(FILE *f) const
QString RDCartFilter::filterSql(const QStringList &and_fields) const QString RDCartFilter::filterSql(const QStringList &and_fields) const
{ {
QString sql=""; QString sql=" where ";
QString type_filter=GetTypeFilter(); sql+=RDCartFilter::typeFilter(d_showaudio_check->isChecked(),
d_showmacro_check->isChecked(),
d_show_cart_type);
// sql+=RDCartFilter::phraseFilter(d_filter_edit->text().trimmed(),true);
QStringList groups;
for(int i=0;i<d_group_box->count();i++) {
groups.push_back(d_group_box->text(i));
}
sql+=RDCartFilter::groupFilter(d_group_box->currentText(),groups);
sql=sql.left(sql.length()-2); // Remove the final "&&"
sql+="order by CART.NUMBER ";
if(d_showmatches_box->isChecked()) {
sql+=QString().sprintf("limit %d ",RD_LIMITED_CART_SEARCH_QUANTITY);
}
// printf("FILTER SQL: %s\n",sql.toUtf8().constData());
return sql;
/*
if(type_filter.isEmpty()) { if(type_filter.isEmpty()) {
return QString("where CART.NUMBER=0 "); return QString("where CART.NUMBER=0 ");
@ -238,11 +260,16 @@ QString RDCartFilter::filterSql(const QStringList &and_fields) const
schedcodes << d_codes2_box->currentText(); schedcodes << d_codes2_box->currentText();
} }
if(d_group_box->currentText()==QString(tr("ALL"))) { if(d_group_box->currentText()==QString(tr("ALL"))) {
sql=RDAllCartSearchText(d_filter_edit->text(),schedcodes, if(d_user_is_admin) {
rda->user()->name(),true)+" "+type_filter; // sql=" where ";
}
else {
sql+=RDAllCartSearchText(d_filter_edit->text(),schedcodes,
rda->user()->name(),true)+" "+type_filter;
}
} }
else { else {
sql=RDCartSearchText(d_filter_edit->text(),d_group_box->currentText(), sql+=RDCartSearchText(d_filter_edit->text(),d_group_box->currentText(),
schedcodes,true)+" "+type_filter; schedcodes,true)+" "+type_filter;
} }
for(int i=0;i<and_fields.size();i++) { for(int i=0;i<and_fields.size();i++) {
@ -257,6 +284,7 @@ QString RDCartFilter::filterSql(const QStringList &and_fields) const
// printf("SQL: %s\n",sql.toUtf8().constData()); // printf("SQL: %s\n",sql.toUtf8().constData());
return sql; return sql;
*/
} }
@ -284,6 +312,61 @@ bool RDCartFilter::dragEnabled() const
} }
RDCart::Type RDCartFilter::showCartType() const
{
return d_show_cart_type;
}
void RDCartFilter::setShowCartType(RDCart::Type type)
{
if(type!=d_show_cart_type) {
if(type==RDCart::All) {
d_showaudio_check->show();
d_showaudio_label->show();
d_showmacro_check->show();
d_showmacro_label->show();
}
else {
d_showaudio_check->hide();
d_showaudio_label->hide();
d_showmacro_check->hide();
d_showmacro_label->hide();
}
d_show_cart_type=type;
emit filterChanged(filterSql());
}
}
bool RDCartFilter::limitSearch() const
{
return d_showmatches_box->isChecked();
}
void RDCartFilter::setLimitSearch(bool state)
{
d_showmatches_box->setChecked(state);
}
bool RDCartFilter::userIsAdmin() const
{
return d_user_is_admin;
}
void RDCartFilter::setUserIsAdmin(bool state)
{
if(state!=d_user_is_admin) {
d_user_is_admin=state;
changeUser();
}
}
void RDCartFilter::setFilterText(const QString &str) void RDCartFilter::setFilterText(const QString &str)
{ {
d_filter_edit->setText(str); d_filter_edit->setText(str);
@ -315,8 +398,14 @@ void RDCartFilter::changeUser()
d_group_box->clear(); d_group_box->clear();
d_group_box->insertItem(tr("ALL")); d_group_box->insertItem(tr("ALL"));
sql=QString("select GROUP_NAME from USER_PERMS where ")+ if(d_user_is_admin) {
"USER_NAME=\""+RDEscapeString(rda->user()->name())+"\" order by GROUP_NAME"; sql=QString("select NAME from GROUPS order by NAME ");
}
else {
sql=QString("select GROUP_NAME from USER_PERMS where ")+
"USER_NAME=\""+RDEscapeString(rda->user()->name())+"\" "+
"order by GROUP_NAME";
}
q=new RDSqlQuery(sql); q=new RDSqlQuery(sql);
while(q->next()) { while(q->next()) {
d_group_box->insertItem(q->value(0).toString()); d_group_box->insertItem(q->value(0).toString());
@ -424,30 +513,101 @@ void RDCartFilter::resizeEvent(QResizeEvent *e)
d_allowdrag_label->setGeometry(580,66,130,20); d_allowdrag_label->setGeometry(580,66,130,20);
d_allowdrag_box->setGeometry(560,68,15,15); d_allowdrag_box->setGeometry(560,68,15,15);
d_showaudio_label->setGeometry(90,66,130,20); d_showaudio_label->setGeometry(90,66,130,20);
d_showaudio_box->setGeometry(70,68,15,15); d_showaudio_check->setGeometry(70,68,15,15);
d_showmacro_label->setGeometry(250,66,130,20); d_showmacro_label->setGeometry(250,66,130,20);
d_showmacro_box->setGeometry(230,68,15,15); d_showmacro_check->setGeometry(230,68,15,15);
d_shownotes_label->setGeometry(410,66,130,20); d_shownotes_label->setGeometry(410,66,130,20);
d_shownotes_box->setGeometry(390,68,15,15); d_shownotes_box->setGeometry(390,68,15,15);
} }
QString RDCartFilter::GetTypeFilter() const QString RDCartFilter::phraseFilter(const QString &phrase, bool incl_cuts)
{ {
QString type_filter; QString sql="";
if(d_showaudio_box->isChecked()) { if(phrase.isEmpty()) {
if(d_showmacro_box->isChecked()) { sql=" &&";
type_filter="&& ((TYPE=1)||(TYPE=2)||(TYPE=3))";
}
else {
type_filter="&& ((TYPE=1)||(TYPE=3))";
}
} }
else { else {
if(d_showmacro_box->isChecked()) { sql+=QString(" (")+
type_filter="&& (TYPE=2)"; "(CART.TITLE like \"%%\")||"+
"(CART.ARTIST like \"%%\")||"+
"(CART.CLIENT like \"%%\")||"+
"(CART.AGENCY like \"%%\")||"+
"(CART.ALBUM like \"%%\")||"+
"(CART.LABEL like \"%%\")||"+
"(CART.NUMBER like \"%%\")||"+
"(CART.PUBLISHER like \"%%\")||"+
"(CART.COMPOSER like \"%%\")||"+
"(CART.CONDUCTOR like \"%%\")||"+
"(CART.SONG_ID like \"%%\")||"+
"(CART.USER_DEFINED like \"%%\")";
if(incl_cuts) {
sql+=QString("||(CUTS.ISCI like \"%%\")")+
"||(CUTS.ISRC like \"%%\")"+
"||(CUTS.DESCRIPTION like \"%%\")"+
"||(CUTS.OUTCUE like \"%%\")";
} }
sql+=") &&";
} }
return type_filter;
return sql;
}
QString RDCartFilter::groupFilter(const QString &group,
const QStringList &groups)
{
QString sql=" (";
if(group==tr("ALL")) {
for(int i=1;i<groups.size();i++) {
sql+="(CART.GROUP_NAME=\""+RDEscapeString(groups.at(i))+"\")||";
}
sql=sql.left(sql.length()-2);
}
else {
sql+="CART.GROUP_NAME=\""+RDEscapeString(group)+"\"";
}
sql+=") &&";
return sql;
}
QString RDCartFilter::typeFilter(bool incl_audio,bool incl_macro,
RDCart::Type mask)
{
QString sql;
switch(mask) {
case RDCart::Audio:
sql="((CART.TYPE=1)||(CART.TYPE=3)) &&";
break;
case RDCart::Macro:
sql="(CART.TYPE=2) &&";
break;
case RDCart::All:
if(incl_audio) {
if(incl_macro) {
sql="((CART.TYPE=1)||(CART.TYPE=2)||(CART.TYPE=3)) &&";
}
else {
sql="((CART.TYPE=1)||(CART.TYPE=3)) &&";
}
}
else {
if(incl_macro) {
sql="(CART.TYPE=2) &&";
}
else {
sql="(CART.TYPE=0) &&"; // NEVER matches!
}
}
break;
}
return sql;
} }

View File

@ -46,6 +46,15 @@ class RDCartFilter : public RDWidget
QString selectedGroup() const; QString selectedGroup() const;
QString selectedSchedCode() const; QString selectedSchedCode() const;
bool dragEnabled() const; bool dragEnabled() const;
RDCart::Type showCartType() const;
void setShowCartType(RDCart::Type type);
bool limitSearch() const;
void setLimitSearch(bool state);
bool userIsAdmin() const;
void setUserIsAdmin(bool state);
static QString phraseFilter(const QString &phrase,bool incl_cuts);
static QString groupFilter(const QString &group,const QStringList &groups);
static QString typeFilter(bool incl_audio,bool incl_macro,RDCart::Type mask);
public slots: public slots:
void setFilterText(const QString &str); void setFilterText(const QString &str);
@ -71,7 +80,6 @@ class RDCartFilter : public RDWidget
void resizeEvent(QResizeEvent *e); void resizeEvent(QResizeEvent *e);
private: private:
QString GetTypeFilter() const;
QLineEdit *d_filter_edit; QLineEdit *d_filter_edit;
QLabel *d_filter_label; QLabel *d_filter_label;
QComboBox *d_group_box; QComboBox *d_group_box;
@ -86,16 +94,17 @@ class RDCartFilter : public RDWidget
QPushButton *d_clear_button; QPushButton *d_clear_button;
QCheckBox *d_allowdrag_box; QCheckBox *d_allowdrag_box;
QLabel *d_allowdrag_label; QLabel *d_allowdrag_label;
QCheckBox *d_showaudio_box; QCheckBox *d_showaudio_check;
QLabel *d_showaudio_label; QLabel *d_showaudio_label;
QCheckBox *d_showmacro_box; QCheckBox *d_showmacro_check;
QLabel *d_shownotes_label; QLabel *d_shownotes_label;
QCheckBox *d_shownotes_box; QCheckBox *d_shownotes_box;
QLabel *d_showmatches_label; QLabel *d_showmatches_label;
QCheckBox *d_showmatches_box; QCheckBox *d_showmatches_box;
QLabel *d_showmacro_label; QLabel *d_showmacro_label;
RDCart::Type d_show_cart_type;
QString d_default_group; QString d_default_group;
bool d_user_is_admin;
}; };

View File

@ -401,6 +401,7 @@ void RDLibraryModel::refreshRow(const QModelIndex &index)
{ {
if(isCart(index)) { if(isCart(index)) {
updateCartLine(index.row()); updateCartLine(index.row());
emit dataChanged(index,createIndex(index.row(),columnCount(),0));
} }
} }
@ -411,6 +412,7 @@ void RDLibraryModel::refreshCart(unsigned cartnum)
for(int i=0;i<d_texts.size();i++) { for(int i=0;i<d_texts.size();i++) {
if(d_texts.at(i).at(0).toString()==cartnum_str) { if(d_texts.at(i).at(0).toString()==cartnum_str) {
updateCartLine(i); updateCartLine(i);
emit dataChanged(createIndex(i,0,0),createIndex(i,columnCount(),0));
} }
} }
} }
@ -460,6 +462,7 @@ void RDLibraryModel::updateModel(const QString &filter_sql)
sql=sqlFields()+ sql=sqlFields()+
filter_sql; filter_sql;
printf("SQL: %s\n",sql.toUtf8().constData());
beginResetModel(); beginResetModel();
d_texts.clear(); d_texts.clear();
d_cart_numbers.clear(); d_cart_numbers.clear();

View File

@ -138,7 +138,7 @@ MainWidget::MainWidget(RDConfig *config,RDWidget *parent)
// Cart Dialog // Cart Dialog
// //
admin_cart_dialog=new RDCartDialog(&admin_filter,&admin_group, admin_cart_dialog=new RDCartDialog(&admin_filter,&admin_group,
&admin_schedcode,"RDAdmin",this); &admin_schedcode,"RDAdmin",true,this);
// //
// User Labels // User Labels

View File

@ -339,7 +339,7 @@ MainWidget::MainWidget(RDConfig *config,QWidget *parent)
// Cart Picker // Cart Picker
// //
rdcart_dialog=new RDCartDialog(&air_add_filter,&air_add_group, rdcart_dialog=new RDCartDialog(&air_add_filter,&air_add_group,
&air_add_schedcode,"RDAirPlay",this); &air_add_schedcode,"RDAirPlay",false,this);
// //
// Wall Clock // Wall Clock

View File

@ -91,7 +91,7 @@ MainWidget::MainWidget(RDConfig *c,QWidget *parent)
// Dialogs // Dialogs
// //
panel_cart_dialog=new RDCartDialog(&panel_filter,&panel_group, panel_cart_dialog=new RDCartDialog(&panel_filter,&panel_group,
&panel_schedcode,"RDCartSlots",this); &panel_schedcode,"RDCartSlots",false,this);
panel_slot_dialog=new RDSlotDialog(tr("RDCartSlots"),this); panel_slot_dialog=new RDSlotDialog(tr("RDCartSlots"),this);
panel_cue_dialog=new RDCueEditDialog(rda->cae(),rda->station()->cueCard(), panel_cue_dialog=new RDCueEditDialog(rda->cae(),rda->station()->cueCard(),
rda->station()->cuePort(), rda->station()->cuePort(),

View File

@ -330,7 +330,7 @@ MainWidget::MainWidget(RDConfig *c,QWidget *parent)
// Cart Picker // Cart Picker
// //
catch_cart_dialog=new RDCartDialog(&catch_filter,&catch_group, catch_cart_dialog=new RDCartDialog(&catch_filter,&catch_group,
&catch_schedcode,"RDCatch",this); &catch_schedcode,"RDCatch",false,this);
// //
// Cart List // Cart List

View File

@ -46,7 +46,7 @@ EditLogLine::EditLogLine(RDLogLine *line,QString *filter,QString *group,
// Cart Picker // Cart Picker
// //
edit_cart_dialog=new RDCartDialog(edit_filter,edit_group,edit_schedcode, edit_cart_dialog=new RDCartDialog(edit_filter,edit_group,edit_schedcode,
"RDLogEdit",this); "RDLogEdit",false,this);
// //
// Overlap Box // Overlap Box