1d2fdd7f6e707ebfdb8bb5c4121b4cf51d10c5ff
[kivitendo-erp.git] / SL / Controller / CsvImport / Shipto.pm
1 package SL::Controller::CsvImport::Shipto;
2
3 use strict;
4
5 use SL::Helper::Csv;
6
7 use parent qw(SL::Controller::CsvImport::Base);
8
9 use Rose::Object::MakeMethods::Generic
10 (
11  scalar => [ qw(table) ],
12 );
13
14 sub init_class {
15   my ($self) = @_;
16   $self->class('SL::DB::Shipto');
17 }
18
19 sub check_objects {
20   my ($self) = @_;
21
22   $self->controller->track_progress(phase => 'building data', progress => 0);
23
24   my $i;
25   my $num_data = scalar @{ $self->controller->data };
26   foreach my $entry (@{ $self->controller->data }) {
27     $self->controller->track_progress(progress => $i/$num_data * 100) if $i % 100 == 0;
28
29     $self->check_vc($entry, 'trans_id');
30     $entry->{object}->module('CT');
31   } continue {
32     $i++;
33   }
34
35   $self->add_info_columns({ header => $::locale->text('Customer/Vendor'), method => 'vc_name' });
36 }
37
38 sub get_duplicate_check_fields {
39   return {
40     shiptoname_and_shiptostreet => {
41       label     => $::locale->text('Name and Street'),
42       default   => 1,
43       maker     => sub {
44         my $o = shift;
45         return join(
46                  '--',
47                  $o->trans_id,
48                  map(
49                    { s/[\s,\.\-]//g; $_ }
50                    $o->shiptoname,
51                    $o->shiptostreet
52                  )
53         );
54       }
55     },
56
57     shiptoname => {
58       label     => $::locale->text('Name'),
59       default   => 1,
60       maker     => sub {
61         my $o = shift;
62         return join(
63                  '--',
64                  $o->trans_id,
65                  map(
66                    { s/[\s,\.\-]//g; $_ }
67                    $o->shiptoname
68                  )
69         );
70       }
71     },
72
73     shiptostreet => {
74       label     => $::locale->text('Street'),
75       default   => 1,
76       maker     => sub {
77         my $o = shift;
78         return join(
79                  '--',
80                  $o->trans_id,
81                  map(
82                    { s/[\s,\.\-]//g; $_ }
83                    $o->shiptostreet
84                  )
85         );
86       }
87     },
88   };
89 }
90
91 sub init_profile {
92   my ($self) = @_;
93
94   my $profile = $self->SUPER::init_profile;
95   delete @{$profile}{qw(module)};
96
97   return $profile;
98 }
99
100 sub setup_displayable_columns {
101   my ($self) = @_;
102
103   $self->SUPER::setup_displayable_columns;
104
105   $self->add_displayable_columns({ name => 'shiptocity',         description => $::locale->text('City')                          },
106                                  { name => 'shiptocontact',      description => $::locale->text('Contact')                       },
107                                  { name => 'shiptocountry',      description => $::locale->text('Country')                       },
108                                  { name => 'shiptodepartment_1', description => $::locale->text('Department 1')                  },
109                                  { name => 'shiptodepartment_2', description => $::locale->text('Department 2')                  },
110                                  { name => 'shiptoemail',        description => $::locale->text('E-mail')                        },
111                                  { name => 'shiptofax',          description => $::locale->text('Fax')                           },
112                                  { name => 'shiptoname',         description => $::locale->text('Name')                          },
113                                  { name => 'shiptophone',        description => $::locale->text('Phone')                         },
114                                  { name => 'shiptostreet',       description => $::locale->text('Street')                        },
115                                  { name => 'shiptozipcode',      description => $::locale->text('Zipcode')                       },
116                                  { name => 'trans_id',           description => $::locale->text('Customer/Vendor (database ID)') },
117                                  { name => 'customer',           description => $::locale->text('Customer (name)')               },
118                                  { name => 'customernumber',     description => $::locale->text('Customer Number')               },
119                                  { name => 'vendor',             description => $::locale->text('Vendor (name)')                 },
120                                  { name => 'vendornumber',       description => $::locale->text('Vendor Number')                 },
121                                 );
122 }
123
124 1;