Skip to content

Commit

Permalink
Fix copying meetings between types, allow empty copy of structured me…
Browse files Browse the repository at this point in the history
…etings
  • Loading branch information
oliverguenther committed Nov 23, 2023
1 parent 5a68e35 commit f1ff47a
Show file tree
Hide file tree
Showing 6 changed files with 42 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,14 @@
item.with_leading_visual_icon(icon: :pencil)
end if @meeting.editable?

menu.with_item(label: t(:button_copy),
href: copy_meeting_path(@meeting),
content_arguments: {
data: { turbo: false }
}) do |item|
item.with_leading_visual_icon(icon: :copy)
end

menu.with_item(label: t(:label_icalendar_download),
href: download_ics_meeting_path(@meeting)) do |item|
item.with_leading_visual_icon(icon: :download)
Expand Down
2 changes: 1 addition & 1 deletion modules/meeting/app/controllers/meetings_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -102,7 +102,7 @@ def copy
params[:copied_from_meeting_id] = @meeting.id
params[:copied_meeting_agenda_text] = @meeting.agenda.text if @meeting.agenda.present?
@meeting = @meeting.copy(author: User.current)
render action: 'new', project_id: @project
render action: 'new', project_id: @project, locals: { copy: true }
end

def destroy
Expand Down
4 changes: 4 additions & 0 deletions modules/meeting/app/views/meetings/_form.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,10 @@ See COPYRIGHT and LICENSE files for more details.
</span>
<p class="op-tile-block--description">
<%= t('meeting.types.structured_text') %>
<% if local_assigns[:copy] %>
<br/>
<strong><%= t('meeting.types.structured_text_copy') %></strong>
<% end %>
</p>
</div>
</div>
Expand Down
3 changes: 2 additions & 1 deletion modules/meeting/app/views/meetings/new.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -30,12 +30,13 @@ See COPYRIGHT and LICENSE files for more details.
<% html_title t(:label_meeting_new) %>
<%= toolbar title: t(:label_meeting_new) %>
<%= labelled_tabular_form_for @meeting,
as: :meeting,
url: {:controller => '/meetings', :action => 'create', :project_id => @project},
:html => {:id => 'meeting-form',
:data => { :controller => 'refresh-on-form-changes',
'refresh-on-form-changes-target': 'form',
'refresh-on-form-changes-turbo-stream-url-value': new_meeting_url }} do |f| -%>
<%= render :partial => 'form', :locals => {:f => f} %>
<%= render :partial => 'form', :locals => { f:, copy: local_assigns[:copy] } %>
<%= styled_button_tag t(:button_create), class: '-highlight' %>
<%= link_to t(:button_cancel), { :action => 'index', :project_id => @project },
class: 'button' %>
Expand Down
1 change: 1 addition & 0 deletions modules/meeting/config/locales/en.yml
Original file line number Diff line number Diff line change
Expand Up @@ -125,6 +125,7 @@ en:
classic_text: 'Organize your meeting in a formattable text agenda and protocol.'
structured: 'Dynamic'
structured_text: 'Organize your meeting as a list of agenda items, optionally linking them to a work package.'
structured_text_copy: 'Copying a meeting will currently not copy the associated meeting agenda items, just the details'
copied: "Copied from Meeting #%{id}"

notice_successful_notification: "Notification sent successfully"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,8 @@

let(:current_user) { user }
let(:new_page) { Pages::Meetings::New.new(project) }
let(:show_page) { Pages::StructuredMeeting::Show.new(StructuredMeeting.order(id: :asc).last) }
let(:meeting) { StructuredMeeting.order(id: :asc).last }
let(:show_page) { Pages::StructuredMeeting::Show.new(meeting) }

before do
login_as current_user
Expand Down Expand Up @@ -250,6 +251,30 @@
expect(page).to have_css('.flash', text: I18n.t('activerecord.errors.messages.error_conflict'))
end

it 'can copy the meeting (empty)' do
show_page.expect_toast(message: 'Successful creation')

# Can add and edit a single item
show_page.add_agenda_item do
fill_in 'Title', with: 'My agenda item'
fill_in 'Duration (min)', with: '25'
end

show_page.expect_agenda_item title: 'My agenda item'
show_page.cancel_add_form

click_button('op-meetings-header-action-trigger')
click_link 'Copy'

expect(page).to have_current_path "/meetings/#{meeting.id}/copy"

click_button 'Save'

expect(page).to have_text 'Your meeting is empty'
new_meeting = StructuredMeeting.last
expect(page).to have_current_path "/meetings/#{new_meeting.id}"
end

context 'with a work package reference to another' do
let!(:meeting) { create(:structured_meeting, project:, author: current_user) }
let!(:other_project) { create(:project) }
Expand Down

0 comments on commit f1ff47a

Please sign in to comment.