+#
+# actions for pictures
+#
+
+sub action_ajax_add_picture {
+ my ($self) = @_;
+
+ $self->picture(SL::DB::RequirementSpecPicture->new);
+ $self->render('requirement_spec_text_block/_picture_form', { layout => 0 });
+}
+
+sub action_ajax_edit_picture {
+ my ($self) = @_;
+
+ $self->text_block($self->picture->text_block);
+ $self->render('requirement_spec_text_block/_picture_form', { layout => 0 });
+}
+
+sub action_ajax_create_picture {
+ my ($self, %params) = @_;
+
+ my $attributes = $::form->{ $::form->{form_prefix} } || die "Missing attributes";
+ $attributes->{picture_file_name} = ((($::form->{ATTACHMENTS} || {})->{ $::form->{form_prefix} } || {})->{picture_content} || {})->{filename};
+ my @errors = $self->picture(SL::DB::RequirementSpecPicture->new(%{ $attributes }))->validate;
+
+ return $self->js->error(@errors)->render($self) if @errors;
+
+ $self->picture->save;
+
+ $self->text_block($self->picture->text_block);
+ my $html = $self->render('requirement_spec_text_block/_text_block_picture', { output => 0 }, picture => $self->picture);
+
+ $self->invalidate_version
+ ->dialog->close('#jqueryui_popup_dialog')
+ ->append('#text-block-' . $self->text_block->id . '-pictures', $html)
+ ->show('#text-block-' . $self->text_block->id . '-pictures')
+ ->render($self);
+}
+
+sub action_ajax_update_picture {
+ my ($self) = @_;
+
+ my $attributes = $::form->{ $::form->{form_prefix} } || die "Missing attributes";
+
+ if (!$attributes->{picture_content}) {
+ delete $attributes->{picture_content};
+ } else {
+ $attributes->{picture_file_name} = ((($::form->{ATTACHMENTS} || {})->{ $::form->{form_prefix} } || {})->{picture_content} || {})->{filename};
+ }
+
+ $self->picture->assign_attributes(%{ $attributes });
+ my @errors = $self->picture->validate;
+
+ return $self->js->error(@errors)->render($self) if @errors;
+
+ $self->picture->save;
+
+ $self->text_block($self->picture->text_block);
+ my $html = $self->render('requirement_spec_text_block/_text_block_picture', { output => 0 }, picture => $self->picture);
+
+ $self->invalidate_version
+ ->dialog->close('#jqueryui_popup_dialog')
+ ->replaceWith('#text-block-picture-' . $self->picture->id, $html)
+ ->show('#text-block-' . $self->text_block->id . '-pictures')
+ ->render($self);
+}
+
+sub action_ajax_delete_picture {
+ my ($self) = @_;
+
+ $self->picture->delete;
+ $self->text_block(SL::DB::RequirementSpecTextBlock->new(id => $self->picture->text_block_id)->load);
+
+ $self->invalidate_version
+ ->remove('#text-block-picture-' . $self->picture->id)
+ ->action_if(!@{ $self->text_block->pictures }, 'hide', '#text-block-' . $self->text_block->id . '-pictures')
+ ->render($self);
+}
+
+sub action_ajax_download_picture {
+ my ($self) = @_;
+
+ $self->send_file(\$self->picture->{picture_content}, type => $self->picture->picture_content_type, name => $self->picture->picture_file_name);
+}
+
+sub action_ajax_copy_picture {
+ my ($self, %params) = @_;
+
+ SL::Clipboard->new->copy($self->picture);
+ SL::ClientJS->new->render($self);
+}
+
+sub action_ajax_paste_picture {
+ my ($self, %params) = @_;
+
+ my $copied = SL::Clipboard->new->get_entry(qr/^RequirementSpecPicture$/);
+ if (!$copied) {
+ return SL::ClientJS->new
+ ->error(t8("The clipboard does not contain anything that can be pasted here."))
+ ->render($self);
+ }
+
+ $self->text_block($self->picture->text_block); # Save text block via the picture the user clicked on
+
+ $self->paste_picture($copied);
+}
+
+sub action_reorder_pictures {
+ my ($self) = @_;
+
+ SL::DB::RequirementSpecPicture->reorder_list(@{ $::form->{picture_id} || [] });
+
+ $self->render(\'', { type => 'json' });
+}
+