mirror of
https://github.com/ElvishArtisan/rivendell.git
synced 2025-05-21 23:29:34 +02:00
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:
parent
ae5d20cbe9
commit
38ef094ba3
@ -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.
|
||||||
|
@ -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;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user