X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2Fcust_location.pm;h=aad25a4a7e261ee665b3fa703ee2316bf5f16c12;hb=3c635a0ac2bf4c3f78044cd5e510e2d287f50389;hp=c1408270206436e9071c9a362ab6380e26499f68;hpb=d72d57ec3b5c9f8d0115f84c02943994d93436ca;p=freeside.git diff --git a/FS/FS/cust_location.pm b/FS/FS/cust_location.pm index c14082702..aad25a4a7 100644 --- a/FS/FS/cust_location.pm +++ b/FS/FS/cust_location.pm @@ -281,10 +281,15 @@ sub replace { warn "Warning: passed city to replace when cust_main-no_city_in_address is configured" if $conf->exists('cust_main-no_city_in_address') && $self->get('city'); - # the following fields are immutable - foreach (qw(address1 address2 city state zip country)) { - if ( $self->$_ ne $old->$_ ) { - return "can't change cust_location field $_"; + # the following fields are immutable if this is a customer location. if + # it's a prospect location, then there are no active packages, no billing + # history, no taxes, and in general no reason to keep the old location + # around. + if ( $self->custnum ) { + foreach (qw(address1 address2 city state zip country)) { + if ( $self->$_ ne $old->$_ ) { + return "can't change cust_location field $_"; + } } }