X-Git-Url: http://wagnertech.de/gitweb/gitweb.cgi/mfinanz.git/blobdiff_plain/49644f8f89ef5e337763ab013b8cdce6d28f4493..5723fbf943e494ce9ffd6f9fc44251eb04d3362c:/SL/DB/RequirementSpecTextBlock.pm diff --git a/SL/DB/RequirementSpecTextBlock.pm b/SL/DB/RequirementSpecTextBlock.pm index 1db862313..50851ad78 100644 --- a/SL/DB/RequirementSpecTextBlock.pm +++ b/SL/DB/RequirementSpecTextBlock.pm @@ -2,6 +2,10 @@ package SL::DB::RequirementSpecTextBlock; use strict; +use List::MoreUtils qw(any); +use Rose::DB::Object::Helpers; +use Rose::DB::Object::Util; + use SL::DB::MetaSetup::RequirementSpecTextBlock; use SL::DB::Manager::RequirementSpecTextBlock; use SL::DB::Helper::ActsAsList; @@ -11,6 +15,9 @@ __PACKAGE__->meta->initialize; __PACKAGE__->configure_acts_as_list(group_by => [qw(requirement_spec_id output_position)]); +__PACKAGE__->before_save(\ &_before_save_invalidate_requirement_spec_version); +__PACKAGE__->before_delete(\&_before_delete_invalidate_requirement_spec_version); + sub validate { my ($self) = @_; @@ -20,4 +27,26 @@ sub validate { return @errors; } +sub _before_save_invalidate_requirement_spec_version { + my ($self, %params) = @_; + + + return 1 if !$self->requirement_spec_id; + + my %changed_columns = map { $_ => 1 } (Rose::DB::Object::Helpers::dirty_columns($self)); + + $self->requirement_spec->invalidate_version + if !Rose::DB::Object::Util::is_in_db($self) || any { $changed_columns{$_} } qw(title text position output_position); + + return 1; +} + +sub _before_delete_invalidate_requirement_spec_version { + my ($self, %params) = @_; + + $self->requirement_spec->invalidate_version if $self->requirement_spec_id; + + return 1; +} + 1;