2024-02-08 Fred Gleason <fredg@paravelsystems.com>

* Added 'RDTimeEdit::Mode' enumeration.
	* Added 'RDTimeEdit::mode()', 'RDTimeEdit::setMode()',
	'RDTimeEdit::length()' and 'RDTimeEdit::setLength()' methods.
	* Fixed a regression in rdlibrary(1) that caused the 'Forced Length'
	control in the 'Edit Cart' dialog to be misformatted when the
	system was configured to use 12 hour time format.

Signed-off-by: Fred Gleason <fredg@paravelsystems.com>
This commit is contained in:
Fred Gleason 2024-02-08 10:04:46 -05:00
parent ae5d20cbe9
commit 38ef094ba3
5 changed files with 95 additions and 49 deletions

View File

@ -24645,3 +24645,10 @@
2024-02-07 Fred Gleason <fredg@paravelsystems.com> 2024-02-07 Fred Gleason <fredg@paravelsystems.com>
* Added the option to provision users from an existing RSS feed * Added the option to provision users from an existing RSS feed
to the 'Add RSS Feed' dialog in rdadmin(1). to the 'Add RSS Feed' dialog in rdadmin(1).
2024-02-08 Fred Gleason <fredg@paravelsystems.com>
* Added 'RDTimeEdit::Mode' enumeration.
* Added 'RDTimeEdit::mode()', 'RDTimeEdit::setMode()',
'RDTimeEdit::length()' and 'RDTimeEdit::setLength()' methods.
* Fixed a regression in rdlibrary(1) that caused the 'Forced Length'
control in the 'Edit Cart' dialog to be misformatted when the
system was configured to use 12 hour time format.

View File

@ -2,7 +2,7 @@
// //
// A QTimeEdit with tenth-second precision. // A QTimeEdit with tenth-second precision.
// //
// (C) Copyright 2003-2021 Fred Gleason <fredg@paravelsystems.com> // (C) Copyright 2003-2024 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
@ -27,6 +27,7 @@
RDTimeEdit::RDTimeEdit(QWidget *parent) RDTimeEdit::RDTimeEdit(QWidget *parent)
: QTimeEdit(parent) : QTimeEdit(parent)
{ {
d_mode=RDTimeEdit::TimeMode;
d_show_hours=true; d_show_hours=true;
d_show_tenths=false; d_show_tenths=false;
d_step_enabled=StepDownEnabled|StepUpEnabled; d_step_enabled=StepDownEnabled|StepUpEnabled;
@ -37,6 +38,19 @@ RDTimeEdit::RDTimeEdit(QWidget *parent)
} }
RDTimeEdit::Mode RDTimeEdit::mode() const
{
return d_mode;
}
void RDTimeEdit::setMode(Mode mode)
{
d_mode=mode;
SetFormat();
}
bool RDTimeEdit::showHours() const bool RDTimeEdit::showHours() const
{ {
return d_show_hours; return d_show_hours;
@ -73,6 +87,18 @@ bool RDTimeEdit::isReadOnly() const
} }
int RDTimeEdit::length() const
{
return QTime(0,0,0).msecsTo(time());
}
void RDTimeEdit::setLength(int msec)
{
setTime(QTime(0,0,0).addMSecs(100*(msec/100)));
}
void RDTimeEdit::setReadOnly(bool state) void RDTimeEdit::setReadOnly(bool state)
{ {
if(d_read_only!=state) { if(d_read_only!=state) {
@ -206,48 +232,60 @@ QAbstractSpinBox::StepEnabled RDTimeEdit::stepEnabled() const
void RDTimeEdit::SetFormat() void RDTimeEdit::SetFormat()
{ {
if(rda->system()->showTwelveHourTime()) { if(d_mode==RDTimeEdit::TimeMode) {
if(d_show_tenths) { if(rda->system()->showTwelveHourTime()) {
if(d_show_hours) { if(d_show_tenths) {
setDisplayFormat(RD_TWELVE_HOUR_TENTHS_FORMAT); if(d_show_hours) {
d_width_variance=1; setDisplayFormat(RD_TWELVE_HOUR_TENTHS_FORMAT);
d_width_variance=1;
}
else {
setDisplayFormat(RD_OFFSET_TENTHS_FORMAT);
d_width_variance=0;
}
} }
else { else {
setDisplayFormat(RD_OFFSET_TENTHS_FORMAT); if(d_show_hours) {
d_width_variance=0; setDisplayFormat(RD_TWELVE_HOUR_FORMAT);
d_width_variance=0;
}
else {
setDisplayFormat(RD_OFFSET_FORMAT);
d_width_variance=0;
}
} }
} }
else { else {
if(d_show_hours) { if(d_show_tenths) {
setDisplayFormat(RD_TWELVE_HOUR_FORMAT); if(d_show_hours) {
d_width_variance=0; setDisplayFormat(RD_TWENTYFOUR_HOUR_TENTHS_FORMAT);
d_width_variance=0;
}
else {
setDisplayFormat(RD_OFFSET_TENTHS_FORMAT);
d_width_variance=0;
}
} }
else { else {
setDisplayFormat(RD_OFFSET_FORMAT); if(d_show_hours) {
d_width_variance=0; setDisplayFormat(RD_TWENTYFOUR_HOUR_FORMAT);
d_width_variance=0;
}
else {
setDisplayFormat(RD_OFFSET_FORMAT);
d_width_variance=0;
}
} }
} }
} }
else { if(d_mode==RDTimeEdit::LengthMode) {
if(d_show_tenths) { if(d_show_tenths) {
if(d_show_hours) { setDisplayFormat(RD_OFFSET_TENTHS_FORMAT);
setDisplayFormat(RD_TWENTYFOUR_HOUR_TENTHS_FORMAT); d_width_variance=0;
d_width_variance=0;
}
else {
setDisplayFormat(RD_OFFSET_TENTHS_FORMAT);
d_width_variance=0;
}
} }
else { else {
if(d_show_hours) { setDisplayFormat(RD_OFFSET_FORMAT);
setDisplayFormat(RD_TWENTYFOUR_HOUR_FORMAT); d_width_variance=0;
d_width_variance=0;
}
else {
setDisplayFormat(RD_OFFSET_FORMAT);
d_width_variance=0;
}
} }
} }
} }

View File

@ -2,7 +2,7 @@
// //
// A QTimeEdit with tenth-second precision. // A QTimeEdit with tenth-second precision.
// //
// (C) Copyright 2003-2021 Fred Gleason <fredg@paravelsystems.com> // (C) Copyright 2003-2024 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
@ -28,15 +28,20 @@ class RDTimeEdit : public QTimeEdit
{ {
Q_OBJECT Q_OBJECT
public: public:
enum Mode {TimeMode=0,LengthMode=1};
RDTimeEdit(QWidget *parent=0); RDTimeEdit(QWidget *parent=0);
Mode mode() const;
void setMode(Mode mode);
bool showHours() const; bool showHours() const;
void setShowHours(bool state); void setShowHours(bool state);
bool showTenths() const; bool showTenths() const;
void setShowTenths(bool state); void setShowTenths(bool state);
bool isReadOnly() const; bool isReadOnly() const;
int length() const;
public slots: public slots:
void setReadOnly(bool state); void setLength(int msec);
void setReadOnly(bool state);
protected: protected:
QValidator::State validate(QString &input,int &pos) const; QValidator::State validate(QString &input,int &pos) const;
@ -51,6 +56,7 @@ class RDTimeEdit : public QTimeEdit
int d_width_variance; int d_width_variance;
QAbstractSpinBox::StepEnabled d_step_enabled; QAbstractSpinBox::StepEnabled d_step_enabled;
bool d_read_only; bool d_read_only;
Mode d_mode;
}; };

View File

@ -191,6 +191,7 @@ int EditEvent::exec(int line)
edit_grace_bgroup->button(2)->setChecked(true); edit_grace_bgroup->button(2)->setChecked(true);
graceClickedData(2); graceClickedData(2);
edit_grace_edit->setTime(QTime(0,0,0).addMSecs(edit_logline->graceTime())); edit_grace_edit->setTime(QTime(0,0,0).addMSecs(edit_logline->graceTime()));
edit_grace_edit->setLength(edit_logline->graceTime());
break; break;
} }
edit_transtype_box->setCurrentIndex((int)edit_logline->transType()); edit_transtype_box->setCurrentIndex((int)edit_logline->transType());
@ -389,8 +390,7 @@ void EditEvent::okData()
break; break;
case 2: case 2:
edit_logline-> edit_logline->setGraceTime(edit_grace_edit->length());
setGraceTime(QTime(0,0,0).msecsTo(edit_grace_edit->time()));
break; break;
} }
} }

View File

@ -2,7 +2,7 @@
// //
// Edit a Rivendell Cart // Edit a Rivendell Cart
// //
// (C) Copyright 2002-2022 Fred Gleason <fredg@paravelsystems.com> // (C) Copyright 2002-2024 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
@ -181,8 +181,9 @@ EditCart::EditCart(const QList<unsigned> &cartnums,QString *path,bool new_cart,
// Cart Forced Length // Cart Forced Length
// //
rdcart_controls.forced_length_edit=new RDTimeEdit(this); rdcart_controls.forced_length_edit=new RDTimeEdit(this);
rdcart_controls.forced_length_edit->setGeometry(530,36,85,21);
rdcart_controls.forced_length_edit->setShowTenths(true); rdcart_controls.forced_length_edit->setShowTenths(true);
rdcart_controls.forced_length_edit->setMode(RDTimeEdit::LengthMode);
rdcart_controls.forced_length_edit->setGeometry(530,36,85,21);
rdcart_forced_length_ledit=new QLineEdit(this); rdcart_forced_length_ledit=new QLineEdit(this);
rdcart_forced_length_ledit->setGeometry(535,36,80,21); rdcart_forced_length_ledit->setGeometry(535,36,80,21);
rdcart_forced_length_ledit->hide(); rdcart_forced_length_ledit->hide();
@ -581,8 +582,7 @@ EditCart::EditCart(const QList<unsigned> &cartnums,QString *path,bool new_cart,
rdcart_average_length_edit-> rdcart_average_length_edit->
setText(RDGetTimeLength(rdcart_cart->averageLength())); setText(RDGetTimeLength(rdcart_cart->averageLength()));
} }
rdcart_controls.forced_length_edit-> rdcart_controls.forced_length_edit->setLength(rdcart_cart->forcedLength());
setTime(QTime(0,0,0).addMSecs(rdcart_cart->forcedLength()));
rdcart_forced_length_ledit-> rdcart_forced_length_ledit->
setText(rdcart_controls.forced_length_edit->time().toString("hh:mm:ss")); setText(rdcart_controls.forced_length_edit->time().toString("hh:mm:ss"));
rdcart_controls.title_edit->setText(rdcart_cart->title()); rdcart_controls.title_edit->setText(rdcart_cart->title());
@ -792,13 +792,12 @@ void EditCart::okData()
rdcart_cart->calculateAverageLength(&rdcart_length_deviation); rdcart_cart->calculateAverageLength(&rdcart_length_deviation);
rdcart_cart->setLengthDeviation(rdcart_length_deviation); rdcart_cart->setLengthDeviation(rdcart_length_deviation);
rdcart_cart->updateLength(rdcart_controls.enforce_length_box->isChecked(), rdcart_cart->updateLength(rdcart_controls.enforce_length_box->isChecked(),
QTime(0,0,0).msecsTo(rdcart_controls. rdcart_controls.forced_length_edit->length());
forced_length_edit->time()));
rdcart_cart-> rdcart_cart->
setAverageLength(RDSetTimeLength(rdcart_average_length_edit->text())); setAverageLength(RDSetTimeLength(rdcart_average_length_edit->text()));
if(rdcart_controls.enforce_length_box->isChecked()) { if(rdcart_controls.enforce_length_box->isChecked()) {
rdcart_cart-> rdcart_cart->
setForcedLength(QTime(0,0,0).msecsTo(rdcart_controls.forced_length_edit->time())); setForcedLength(rdcart_controls.forced_length_edit->length());
rdcart_cart->setEnforceLength(true); rdcart_cart->setEnforceLength(true);
} }
else { else {
@ -825,8 +824,6 @@ void EditCart::okData()
rdcart_cart->setConductor(rdcart_controls.conductor_edit->text()); rdcart_cart->setConductor(rdcart_controls.conductor_edit->text());
rdcart_cart->setComposer(rdcart_controls.composer_edit->text()); rdcart_cart->setComposer(rdcart_controls.composer_edit->text());
rdcart_cart->setUserDefined(rdcart_controls.user_defined_edit->text()); rdcart_cart->setUserDefined(rdcart_controls.user_defined_edit->text());
// rdcart_cart->
// setUsageCode((RDCart::UsageCode)rdcart_usage_box->currentIndex());
rdcart_cart-> rdcart_cart->
setUsageCode((RDCart::UsageCode)rdcart_usage_box-> setUsageCode((RDCart::UsageCode)rdcart_usage_box->
itemData(rdcart_usage_box->currentIndex()).toInt()); itemData(rdcart_usage_box->currentIndex()).toInt());
@ -910,8 +907,7 @@ void EditCart::cancelData()
rdcart_cart->setForcedLength(len); rdcart_cart->setForcedLength(len);
} }
rdcart_cart->updateLength(rdcart_controls.enforce_length_box->isChecked(), rdcart_cart->updateLength(rdcart_controls.enforce_length_box->isChecked(),
QTime(0,0,0).msecsTo(rdcart_controls. rdcart_controls.forced_length_edit->length());
forced_length_edit->time()));
} }
done(false); done(false);
} }
@ -923,8 +919,7 @@ void EditCart::forcedLengthData(bool state)
rdcart_controls.forced_length_edit->setEnabled(state); rdcart_controls.forced_length_edit->setEnabled(state);
if(state) { if(state) {
rdcart_controls.forced_length_edit-> rdcart_controls.forced_length_edit->
setTime(QTime(0,0,0). setLength(RDSetTimeLength(rdcart_average_length_edit->text()));
addMSecs(RDSetTimeLength(rdcart_average_length_edit->text())));
} }
} }
@ -958,8 +953,8 @@ void EditCart::closeEvent(QCloseEvent *e)
bool EditCart::ValidateLengths() bool EditCart::ValidateLengths()
{ {
return rdcart_cart->validateLengths(QTime(0,0,0). return rdcart_cart->
msecsTo(rdcart_controls.forced_length_edit->time())); validateLengths(rdcart_controls.forced_length_edit->length());
} }