131ed6b23e60291fdc56ef1f7edc85511fc3dded
[kivitendo-erp.git] / SL / Controller / Draft.pm
1 package SL::Controller::Draft;
2
3 use strict;
4
5 use parent qw(SL::Controller::Base);
6
7 use SL::Helper::Flash qw(flash);
8 use SL::Locale::String qw(t8);
9 use SL::Request;
10 use SL::DB::Draft;
11 use SL::DBUtils qw(selectall_hashref_query);
12 use YAML;
13 use List::Util qw(max);
14
15 use Rose::Object::MakeMethods::Generic (
16  scalar => [ qw() ],
17  'scalar --get_set_init' => [ qw(module submodule draft) ],
18 );
19
20 __PACKAGE__->run_before('check_auth');
21
22 my %allowed_modules = map { $_ => "bin/mozilla/$_.pl" } qw(is ir ar ap gl);
23
24 #
25 # actions
26 #
27
28 sub action_draft_dialog {
29   my ($self) = @_;
30   $self->js
31     ->dialog->open({
32       html   => $self->dialog_html,
33       id     => 'save_draft',
34       dialog => {
35         title => t8('Drafts'),
36       },
37     })
38     ->render;
39 }
40
41 sub action_save {
42   my ($self) = @_;
43
44   my $id          = $::form->{id};
45   my $description = $::form->{description} or die 'need description';
46   my $form        = $self->_build_form;
47
48   my $draft = SL::DB::Manager::Draft->find_by_or_create(id => $id);
49
50   $draft->id($self->module . '-' . $self->submodule . '-' . Common::unique_id()) unless $draft->id;
51
52   $draft->assign_attributes(
53     module      => $self->module,
54     submodule   => $self->submodule,
55     description => $description,
56     form        => YAML::Dump($form),
57     employee_id => SL::DB::Manager::Employee->current->id,
58   );
59
60   $self->draft($draft);
61
62   if (!$draft->save) {
63     flash('error', t8('There was an error saving the draft'));
64     $self->js
65       ->html('#save_draft', $self->dialog_html)
66       ->render;
67   } else {
68     $self->js
69       ->flash('info', t8("Draft saved."))
70       ->dialog->close('#save_draft')
71       ->render;
72   }
73 }
74
75 sub action_load {
76   my ($self) = @_;
77
78   if (!$allowed_modules{ $self->draft->module }) {
79     $::form->error(t8('Unknown module: #1', $self->draft->module));
80   } else {
81     package main;
82     require $allowed_modules{ $self->draft->module };
83   }
84
85
86   my $params = delete $::form->{form};
87   my $new_form = YAML::Load($self->draft->form);
88   $::form->{$_} = $new_form->{$_} for keys %$new_form;
89   $::form->{"draft_$_"} = $self->draft->$_ for qw(id description);
90
91   if ($params && 'HASH' eq ref $params) {
92     $::form->{$_} = $params->{$_} for keys %$params;
93   }
94   $::form->{transdate} = DateTime->today_local->to_kivitendo if !$::form->{transdate};
95   $::form->{gldate}    = $::form->{transdate} if !$::form->{gldate};
96   $::form->{script} = $self->draft->module . '.pl';
97   ::update();
98 }
99
100 sub action_delete {
101   my ($self) = @_;
102
103   $self->module($self->draft->module);
104   $self->submodule($self->draft->submodule);
105
106   if (!$self->draft->delete) {
107     flash('error', t8('There was an error deleting the draft'));
108     $self->js
109       ->html('#save_draft', $self->dialog_html)
110       ->render;
111   } else {
112     flash('info', t8('Draft deleted'));
113
114     $self->js
115       ->html('#save_draft', $self->dialog_html)
116       ->render;
117   }
118 }
119
120 #
121 # helpers
122 #
123
124 sub _build_form {
125   my $last_index = max map { /form\[(\d+)\]/ ? $1 : 0 } keys %$::form;
126   my $new_form = {};
127
128   for my $i (0..$last_index) {
129     SL::Request::_store_value($new_form, $::form->{"form[$i][name]"}, $::form->{"form[$i][value]"});
130   }
131
132   return $new_form;
133 }
134
135 sub draft_list {
136   my ($self) = @_;
137
138   my $result = selectall_hashref_query($::form, $::form->get_standard_dbh, <<SQL, $self->module, $self->submodule);
139     SELECT d.*, date(d.itime) AS date, e.name AS employee_name
140     FROM drafts d
141     LEFT JOIN employee e ON d.employee_id = e.id
142     WHERE (d.module = ?) AND (d.submodule = ?)
143     ORDER BY d.itime
144 SQL
145 }
146
147 sub dialog_html {
148   my ($self) = @_;
149
150   $self->render('drafts/form', { layout => 0, output => 0 },
151     drafts_list => $self->draft_list
152   )
153 }
154
155 sub init_module {
156   $::form->{module}      or die 'need module';
157 }
158
159 sub init_submodule {
160   $::form->{submodule}   or die 'need submodule';
161 }
162
163 sub init_draft {
164   SL::DB::Manager::Draft->find_by(id => $::form->{id}) or die t8('Could not load this draft');
165 }
166
167 sub check_auth {
168   $::auth->assert('vendor_invoice_edit | invoice_edit | ap_transactions | ar_transactions');
169 }
170
171 1;
172
173 __END__
174
175 =encoding utf-8
176
177 =head1 NAME
178
179 SL::Controller::Draft
180
181 =head1 DESCRIPTION
182
183 Encapsulates the old draft mechanism. Use and improvement are discuraged as
184 long as the storage is not upgrade safe.
185
186 =head1 TODO
187
188   - optional popup on entry
189
190 =head1 AUTHOR
191
192 Sven Schöling E<lt>s.schoeling@linet-services.deE<gt>
193
194 =cut