Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision f65440cb

Von Moritz Bunkus vor etwa 4 Jahren hinzugefügt

  • ID f65440cb9d28d4862facc50858bd25fa138cb211
  • Vorgänger cd274d3f
  • Nachfolger 92f6fae1

Order-Controller: Workflow Verkaufsauftrag → Verkaufsangebot

Unterschiede anzeigen:

SL/Controller/Order.pm
);
}
# workflow from sales order to sales quotation
sub action_sales_quotation {
$_[0]->workflow_sales_quotation();
}
# workflow from sales quotation to sales order
sub action_sales_order {
$_[0]->workflow_sales_or_purchase_order();
......
return $errors;
}
sub workflow_sales_quotation {
my ($self) = @_;
# always save
my $errors = $self->save();
if (scalar @{ $errors }) {
$self->js->flash('error', $_) for @{ $errors };
return $self->js->render();
}
my $destination_type = sales_quotation_type();
$self->order(SL::DB::Order->new_from($self->order, destination_type => $destination_type));
$self->{converted_from_oe_id} = delete $::form->{id};
# set item ids to new fake id, to identify them as new items
foreach my $item (@{$self->order->items_sorted}) {
$item->{new_fake_id} = join('_', 'new', Time::HiRes::gettimeofday(), int rand 1000000000000);
}
# change form type
$::form->{type} = $destination_type;
$self->type($self->init_type);
$self->cv ($self->init_cv);
$self->check_auth;
$self->recalc();
$self->get_unalterable_data();
$self->pre_render();
# trigger rendering values for second row as hidden, because they
# are loaded only on demand. So we need to keep the values from the
# source.
$_->{render_second_row} = 1 for @{ $self->order->items_sorted };
$self->render(
'order/form',
title => $self->get_title_for('edit'),
%{$self->{template_args}}
);
}
sub workflow_sales_or_purchase_order {
my ($self) = @_;
......
action => [
t8('Workflow'),
],
action => [
t8('Save and Quotation'),
submit => [ '#order_form', { action => "Order/sales_quotation" } ],
only_if => (any { $self->type eq $_ } (sales_order_type())),
],
action => [
t8('Save and Sales Order'),
submit => [ '#order_form', { action => "Order/sales_order" } ],
......
=item * credit limit
=item * more workflows (quotation, rfq)
=item * more workflows (rfq)
=item * price sources: little symbols showing better price / better discount
SL/DB/Order.pm
{ from => 'purchase_order', to => 'purchase_order', abbr => 'popo' },
{ from => 'sales_order', to => 'purchase_order', abbr => 'sopo' },
{ from => 'purchase_order', to => 'sales_order', abbr => 'poso' },
{ from => 'sales_order', to => 'sales_quotation', abbr => 'sosq' },
);
my $from_to = (grep { $_->{from} eq $source->type && $_->{to} eq $destination_type} @from_tos)[0];
croak("Cannot convert from '" . $source->type . "' to '" . $destination_type . "'") if !$from_to;
......
if ( $is_abbr_any->(qw(soso)) ) {
$args{periodic_invoices_config} = $source->periodic_invoices_config->clone_and_reset if $source->periodic_invoices_config;
}
if ( $is_abbr_any->(qw(sosq)) ) {
$args{ordnumber} = undef;
$args{quonumber} = undef;
$args{reqdate} = DateTime->today_local->next_workday();
}
# Custom shipto addresses (the ones specific to the sales/purchase
# record and not to the customer/vendor) are only linked from

Auch abrufbar als: Unified diff