summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2025-09-04 21:57:49 +0200
committerCarl Hetherington <cth@carlh.net>2025-09-04 23:16:55 +0200
commit323146ee516476d76de5b56fdbc08747bf832825 (patch)
tree5a0ce013fbe13008ec011d56e648c2f484d4f36d /src
parentb09d636b86252ad5beda782edc613fa3449cd7b0 (diff)
Revert "Remove timing selection from DKDM dialog." (#3017).
This reverts commit ce01ccc1aa871d299ad96683055c4e06a355efb9. Turns out there are quite a few people and pieces of software who care about this.
Diffstat (limited to 'src')
-rw-r--r--src/lib/dkdm_recipient.cc15
-rw-r--r--src/lib/dkdm_recipient.h4
-rw-r--r--src/wx/dkdm_dialog.cc14
-rw-r--r--src/wx/dkdm_dialog.h2
-rw-r--r--src/wx/dkdm_output_panel.cc4
5 files changed, 30 insertions, 9 deletions
diff --git a/src/lib/dkdm_recipient.cc b/src/lib/dkdm_recipient.cc
index 6e86d7b93..8b44bb25f 100644
--- a/src/lib/dkdm_recipient.cc
+++ b/src/lib/dkdm_recipient.cc
@@ -24,6 +24,7 @@
#include "dkdm_recipient.h"
#include "film.h"
#include "kdm_with_metadata.h"
+#include <boost/date_time/posix_time/posix_time.hpp>
using std::make_shared;
@@ -36,7 +37,9 @@ KDMWithMetadataPtr
kdm_for_dkdm_recipient (
shared_ptr<const Film> film,
boost::filesystem::path cpl,
- DKDMRecipient const& recipient
+ DKDMRecipient const& recipient,
+ boost::posix_time::ptime valid_from,
+ boost::posix_time::ptime valid_to
)
{
if (!recipient.recipient()) {
@@ -48,17 +51,17 @@ kdm_for_dkdm_recipient (
throw InvalidSignerError();
}
- auto start = signer->leaf().not_before();
- start.add_days(1);
- auto end = signer->leaf().not_after();
- end.add_days(-1);
+ auto const valid_from_local = dcp::LocalTime(valid_from);
+ auto const valid_to_local = dcp::LocalTime(valid_to);
- auto const decrypted_kdm = film->make_kdm(cpl, start, end);
+ auto const decrypted_kdm = film->make_kdm(cpl, valid_from_local, valid_to_local);
auto const kdm = decrypted_kdm.encrypt(signer, recipient.recipient().get(), {}, dcp::Formulation::MODIFIED_TRANSITIONAL_1, true, 0);
dcp::NameFormat::Map name_values;
name_values['f'] = kdm.content_title_text();
name_values['r'] = recipient.name;
+ name_values['b'] = valid_from_local.date() + " " + valid_from_local.time_of_day(true, false);
+ name_values['e'] = valid_to_local.date() + " " + valid_to_local.time_of_day(true, false);
name_values['i'] = kdm.cpl_id();
return make_shared<KDMWithMetadata>(name_values, CinemaID(0), recipient.emails, kdm);
diff --git a/src/lib/dkdm_recipient.h b/src/lib/dkdm_recipient.h
index cf0474354..221e371cc 100644
--- a/src/lib/dkdm_recipient.h
+++ b/src/lib/dkdm_recipient.h
@@ -49,6 +49,8 @@ KDMWithMetadataPtr
kdm_for_dkdm_recipient (
std::shared_ptr<const Film> film,
boost::filesystem::path cpl,
- DKDMRecipient const& recipient
+ DKDMRecipient const& recipient,
+ boost::posix_time::ptime valid_from,
+ boost::posix_time::ptime valid_to
);
diff --git a/src/wx/dkdm_dialog.cc b/src/wx/dkdm_dialog.cc
index 050651c15..f8afa3d71 100644
--- a/src/wx/dkdm_dialog.cc
+++ b/src/wx/dkdm_dialog.cc
@@ -24,6 +24,7 @@
#include "dkdm_dialog.h"
#include "dkdm_output_panel.h"
#include "kdm_cpl_panel.h"
+#include "kdm_timing_panel.h"
#include "recipients_panel.h"
#include "static_text.h"
#include "wx_util.h"
@@ -80,6 +81,14 @@ DKDMDialog::DKDMDialog (wxWindow* parent, shared_ptr<const Film> film)
_recipients = new RecipientsPanel (this);
left->Add (_recipients, 1, wxEXPAND | wxBOTTOM, DCPOMATIC_SIZER_Y_GAP);
+ /* Sub-heading: Timing */
+ /// TRANSLATORS: translate the word "Timing" here; do not include the "KDM|" prefix
+ h = new StaticText (this, S_("KDM|Timing"));
+ h->SetFont (subheading_font);
+ right->Add (h);
+ _timing = new KDMTimingPanel (this);
+ right->Add (_timing);
+
/* Sub-heading: CPL */
h = new StaticText (this, _("CPL"));
h->SetFont (subheading_font);
@@ -114,6 +123,7 @@ DKDMDialog::DKDMDialog (wxWindow* parent, shared_ptr<const Film> film)
_recipients->RecipientsChanged.connect (boost::bind(&DKDMDialog::setup_sensitivity, this));
_output->MethodChanged.connect(boost::bind(&DKDMDialog::setup_sensitivity, this));
+ _timing->TimingChanged.connect (boost::bind(&DKDMDialog::setup_sensitivity, this));
_make->Bind (wxEVT_BUTTON, boost::bind(&DKDMDialog::make_clicked, this));
_cpl->Changed.connect(boost::bind(&DKDMDialog::setup_sensitivity, this));
@@ -130,7 +140,7 @@ DKDMDialog::setup_sensitivity ()
{
_recipients->setup_sensitivity ();
_output->setup_sensitivity ();
- _make->Enable(!_recipients->recipients().empty() && _cpl->has_selected() && _output->method_selected());
+ _make->Enable(!_recipients->recipients().empty() && _timing->valid() && _cpl->has_selected() && _output->method_selected());
}
@@ -153,7 +163,7 @@ DKDMDialog::make_clicked ()
list<KDMWithMetadataPtr> kdms;
try {
for (auto i: _recipients->recipients()) {
- auto p = kdm_for_dkdm_recipient(film, _cpl->cpl(), i);
+ auto p = kdm_for_dkdm_recipient(film, _cpl->cpl(), i, _timing->from(), _timing->until());
if (p) {
kdms.push_back (p);
}
diff --git a/src/wx/dkdm_dialog.h b/src/wx/dkdm_dialog.h
index fb3dbf903..4a47d961f 100644
--- a/src/wx/dkdm_dialog.h
+++ b/src/wx/dkdm_dialog.h
@@ -30,6 +30,7 @@ LIBDCP_ENABLE_WARNINGS
class DKDMOutputPanel;
class Film;
class KDMCPLPanel;
+class KDMTimingPanel;
class RecipientsPanel;
class ScreensPanel;
struct CPLSummary;
@@ -47,6 +48,7 @@ private:
std::weak_ptr<const Film> _film;
RecipientsPanel* _recipients;
+ KDMTimingPanel* _timing;
KDMCPLPanel* _cpl;
DKDMOutputPanel* _output;
wxButton* _make;
diff --git a/src/wx/dkdm_output_panel.cc b/src/wx/dkdm_output_panel.cc
index 643987f26..3c14d1643 100644
--- a/src/wx/dkdm_output_panel.cc
+++ b/src/wx/dkdm_output_panel.cc
@@ -67,10 +67,14 @@ DKDMOutputPanel::DKDMOutputPanel(wxWindow* parent)
titles['f'] = wx_to_std(_("film name"));
titles['r'] = wx_to_std(_("recipient name"));
titles['i'] = wx_to_std(_("CPL ID"));
+ titles['b'] = wx_to_std(_("from date/time"));
+ titles['e'] = wx_to_std(_("to date/time"));
dcp::NameFormat::Map ex;
ex['f'] = "Bambi";
ex['r'] = "Pathé";
ex['i'] = "1234-5678";
+ ex['b'] = "2012/03/15 12:30";
+ ex['e'] = "2012/03/22 02:30";
_filename_format = new NameFormatEditor(this, Config::instance()->dkdm_filename_format(), titles, ex, ".xml");
table->Add(_filename_format->panel(), 1, wxEXPAND);