summaryrefslogtreecommitdiff
path: root/httemplate/edit/process/elements/process.html
blob: 96d56875431707941930d7208b861ebb009743c2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
%
%
%  # options example...
%  # 
%  ###
%  ##req
%  ##
%  #
%  # 'table' => 
%  #
%  # #? 'primary_key' => #required when the dbdef doesn't know...???
%  # #? 'fields' => []
%  #
%  ###
%  ##opt
%  ###
%  #
%  # 'viewall_dir' => '', #'search' or 'browse', defaults to 'search'
%  # OR
%  # 'redirect'    => 'view/table.cgi?', # value of primary key is appended
%  #
%  # 'edit_ext' => 'html', #defaults to 'html', you might want 'cgi' while the
%  #                       #naming is still inconsistent
%  # 
%  # 'process_m2m' => { 'link_table'   => 'link_table_name',
%  #                    'target_table' => 'target_table_name',
%  #                  },
%  # 'process_m2name' => { 'link_table'   => 'link_table_name',
%  #                       'link_static' => { 'column' => 'value' },
%  #                       'num_col' => 'column', #if column name is different in
%  #                                              #link_table than source_table 
%  #                       'name_col' => 'name_column',
%  #                       'names_list' => [ 'list', 'names' ],
%  #                     },
%
%  my(%opt) = @_;
%
%  #false laziness w/edit.html
%  my $table = $opt{'table'};
%  my $class = "FS::$table";
%  my $pkey = dbdef->table($table)->primary_key; #? $opt{'primary_key'} || 
%  my $fields = $opt{'fields'}
%               #|| [ grep { $_ ne $pkey } dbdef->table($table)->columns ];
%               || [ fields($table) ];
%
%  my $pkeyvalue = $cgi->param($pkey);
%
%  my $old = qsearchs( $table, { $pkey => $pkeyvalue } ) if $pkeyvalue;
%
%  my $new = $class->new( {
%    map {
%      $_, scalar($cgi->param($_));
%    } @$fields
%  } );
%
%  my $error;
%  if ( $pkeyvalue ) {
%    $error = $new->replace($old);
%  } else {
%    $error = $new->insert;
%    $pkeyvalue = $new->getfield($pkey);
%  }
%
%  if ( !$error && $opt{'process_m2m'} ) {
%    $error = $new->process_m2m( %{ $opt{'process_m2m'} },
%                                'params' => scalar($cgi->Vars),
%                              );
%  }
%
%  if ( !$error && $opt{'process_m2name'} ) {
%    $error = $new->process_m2name( %{ $opt{'process_m2name'} },
%                                   'params' => scalar($cgi->Vars),
%                                 );
%  }
%
%  # XXX print?!?!
%
%  if ( $error ) {
%    $cgi->param('error', $error);
%    my $edit_ext = $opt{'edit_ext'} || 'html';
%    print $cgi->redirect(popurl(2). "$table.$edit_ext?". $cgi->query_string );
%  } elsif ( $opt{'redirect'} ) {
%    print $cgi->redirect( $opt{'redirect'}. $pkeyvalue );
%  } else { 
%    print $cgi->redirect( popurl(3).
%                          ( $opt{'viewall_dir'} || 'search' ).
%                          "/$table.html"
%                        );
%  }
%
%