From f9b0e48738ec321955fbc7684baeb320e9def999 Mon Sep 17 00:00:00 2001 From: Vladislav Yashin Date: Sun, 30 Dec 2018 19:05:39 +0400 Subject: [PATCH 1/6] Fix incorrect time assignment in Redmine 4 --- app/views/issues/_open_date_field.html.erb | 4 ++-- app/views/issues/_open_date_field_bulk.html.erb | 4 ++-- lib/issue_open_date/hook_listener.rb | 2 +- lib/issue_open_date/patches/user_patch.rb | 14 +++++--------- 4 files changed, 10 insertions(+), 14 deletions(-) diff --git a/app/views/issues/_open_date_field.html.erb b/app/views/issues/_open_date_field.html.erb index fbcb1c2..3144320 100644 --- a/app/views/issues/_open_date_field.html.erb +++ b/app/views/issues/_open_date_field.html.erb @@ -9,10 +9,10 @@

<%= form.label :open_date %> - <%= form.date_select :open_date, default: User.current.issue_open_time , minute_step: 5 %> + <%= form.date_select :open_date, default: User.current.suggested_issue_open_time , minute_step: 5 %> - <%= form.time_select :open_date, default: User.current.issue_open_time , minute_step: 5, ignore_date: true %> + <%= form.time_select :open_date, default: User.current.suggested_issue_open_time , minute_step: 5, ignore_date: true %>

diff --git a/app/views/issues/_open_date_field_bulk.html.erb b/app/views/issues/_open_date_field_bulk.html.erb index e68ed56..ec48cba 100644 --- a/app/views/issues/_open_date_field_bulk.html.erb +++ b/app/views/issues/_open_date_field_bulk.html.erb @@ -9,10 +9,10 @@

<%= label_tag t('field_open_date') %> - <%= date_select :issue, :open_date, default: User.current.issue_open_time , minute_step: 5 %> + <%= date_select :issue, :open_date, default: User.current.suggested_issue_open_time , minute_step: 5 %> - <%= time_select :issue, :open_date, default: User.current.issue_open_time , minute_step: 5, ignore_date: true %> + <%= time_select :issue, :open_date, default: User.current.suggested_issue_open_time , minute_step: 5, ignore_date: true %>

diff --git a/lib/issue_open_date/hook_listener.rb b/lib/issue_open_date/hook_listener.rb index 82c9cfb..66cbcbd 100644 --- a/lib/issue_open_date/hook_listener.rb +++ b/lib/issue_open_date/hook_listener.rb @@ -21,7 +21,7 @@ def controller_issues_new_before_save(context = {}) def assign_issue_attributes(context) params, issue = context[:params].to_unsafe_h, context[:issue] Time.use_zone(User.current.time_zone || Time.now.localtime.utc_offset / 3600) do - issue.assign_attributes(params[:issue].slice(*(1..5).map { |i| "open_date(#{i}i)" })) + issue.update(params[:issue].slice(*(1..5).map { |i| "open_date(#{i}i)" })) end end end diff --git a/lib/issue_open_date/patches/user_patch.rb b/lib/issue_open_date/patches/user_patch.rb index 8951181..f917b61 100644 --- a/lib/issue_open_date/patches/user_patch.rb +++ b/lib/issue_open_date/patches/user_patch.rb @@ -3,17 +3,13 @@ def self.included(base) (1..5).each { |i| base.send(:safe_attributes, "issue_open_time(#{i}i)") } end - end -) -User.send(:prepend, - Module.new do - def issue_open_time + def suggested_issue_open_time time = - begin - tomorrow = Date.tomorrow - super ? super.change(year: tomorrow.year, month: tomorrow.month, day: tomorrow.day) : tomorrow.to_time - end + begin + tomorrow = Date.tomorrow + issue_open_time ? issue_open_time.change(year: tomorrow.year, month: tomorrow.month, day: tomorrow.day) : tomorrow.to_time + end time_zone ? time.to_datetime.change(offset: time_zone.formatted_offset) : time.to_datetime end end From f7ef54fbdd5f9a4c32e4807547836427377fcdd4 Mon Sep 17 00:00:00 2001 From: Vladislav Yashin Date: Fri, 11 Jan 2019 14:51:47 +0400 Subject: [PATCH 2/6] =?UTF-8?q?Don=E2=80=99t=20update=20issue=20open=20tim?= =?UTF-8?q?e=20when=20it=E2=80=99s=20not=20necessary?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lib/issue_open_date/hook_listener.rb | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lib/issue_open_date/hook_listener.rb b/lib/issue_open_date/hook_listener.rb index 66cbcbd..f6dc0d5 100644 --- a/lib/issue_open_date/hook_listener.rb +++ b/lib/issue_open_date/hook_listener.rb @@ -20,6 +20,8 @@ def controller_issues_new_before_save(context = {}) def assign_issue_attributes(context) params, issue = context[:params].to_unsafe_h, context[:issue] + return unless Setting.plugin_redmine_issue_open_date['freezed_statuses'].include?(issue.status_id.to_s) + Time.use_zone(User.current.time_zone || Time.now.localtime.utc_offset / 3600) do issue.update(params[:issue].slice(*(1..5).map { |i| "open_date(#{i}i)" })) end From 64bf05cf83e719e72677b9e5abdf95c52491cedf Mon Sep 17 00:00:00 2001 From: Vladislav Yashin Date: Tue, 29 Jan 2019 23:38:36 +0400 Subject: [PATCH 3/6] Fix double label --- app/views/issues/_open_date_field.html.erb | 1 - 1 file changed, 1 deletion(-) diff --git a/app/views/issues/_open_date_field.html.erb b/app/views/issues/_open_date_field.html.erb index 3144320..a90ffe2 100644 --- a/app/views/issues/_open_date_field.html.erb +++ b/app/views/issues/_open_date_field.html.erb @@ -7,7 +7,6 @@

- <%= form.label :open_date %> <%= form.date_select :open_date, default: User.current.suggested_issue_open_time , minute_step: 5 %> From b3fa812381b77f44a49bca10c5f772065c408f5d Mon Sep 17 00:00:00 2001 From: Vladislav Yashin Date: Thu, 19 Sep 2019 20:09:20 +0400 Subject: [PATCH 4/6] Use datetimepicker for input --- app/views/issues/_open_date_field.html.erb | 10 ++++---- assets/javascripts/issue_open_date.js | 8 +++++++ .../jquery.datetimepicker.full.min.js | 1 + .../stylesheets/jquery.datetimepicker.min.css | 1 + lib/issue_open_date/hook_listener.rb | 23 ------------------- lib/issue_open_date/patches/issue_patch.rb | 13 ++++++++++- 6 files changed, 28 insertions(+), 28 deletions(-) create mode 100644 assets/javascripts/issue_open_date.js create mode 100755 assets/javascripts/jquery.datetimepicker.full.min.js create mode 100755 assets/stylesheets/jquery.datetimepicker.min.css diff --git a/app/views/issues/_open_date_field.html.erb b/app/views/issues/_open_date_field.html.erb index a90ffe2..f15fc4f 100644 --- a/app/views/issues/_open_date_field.html.erb +++ b/app/views/issues/_open_date_field.html.erb @@ -1,5 +1,10 @@ <% if User.current.allowed_to?(:edit_issues, @project) && Setting.plugin_redmine_issue_open_date['freezed_statuses'].include?(issue.status_id.to_s) %> + <%= stylesheet_link_tag 'jquery.datetimepicker.min', plugin: 'redmine_issue_open_date' %> + <%= javascript_include_tag 'jquery.datetimepicker.full.min', plugin: 'redmine_issue_open_date' %> + <%= javascript_include_tag 'issue_open_date', plugin: 'redmine_issue_open_date' %> + +