X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=FS%2FFS%2Fmsgcat.pm;h=4f60109f3e2d45a417a0b5dad81e723c60c8cb53;hp=b512a813cf6ad27fa84a07e63b35394adff39e38;hb=48bade3f01a672f235d61a29ad0d0b792fc80eab;hpb=93d2608554affca0d1e49ab1469328960c75848e diff --git a/FS/FS/msgcat.pm b/FS/FS/msgcat.pm index b512a813c..4f60109f3 100644 --- a/FS/FS/msgcat.pm +++ b/FS/FS/msgcat.pm @@ -4,7 +4,7 @@ use strict; use vars qw( @ISA ); use Exporter; use FS::UID; -use FS::Record; +use FS::Record qw( qsearchs ); @ISA = qw(FS::Record); @@ -117,6 +117,38 @@ sub check { $self->SUPER::check } + +sub _upgrade_data { #class method + my( $class, %opts) = @_; + + eval "use FS::Setup;"; + die $@ if $@; + + #"repopulate_msgcat", false laziness w/FS::Setup::populate_msgcat + + my %messages = FS::Setup::msgcat_messages(); + + foreach my $msgcode ( keys %messages ) { + foreach my $locale ( keys %{$messages{$msgcode}} ) { + my %msgcat = ( + 'msgcode' => $msgcode, + 'locale' => $locale, + #'msg' => $messages{$msgcode}{$locale}, + ); + my $msgcat = qsearchs('msgcat', \%msgcat); + next if $msgcat; + + $msgcat = new FS::msgcat( { + %msgcat, + 'msg' => $messages{$msgcode}{$locale}, + } ); + my $error = $msgcat->insert; + die $error if $error; + } + } + +} + =back =head1 BUGS