11 % # #? 'primary_key' => #required when the dbdef doesn't know...???
18 % # 'viewall_dir' => '', #'search' or 'browse', defaults to 'search'
20 % # 'redirect' => 'view/table.cgi?', # value of primary key is appended
22 % # 'edit_ext' => 'html', #defaults to 'html', you might want 'cgi' while the
23 % # #naming is still inconsistent
25 % # 'process_m2m' => { 'link_table' => 'link_table_name',
26 % # 'target_table' => 'target_table_name',
28 % # 'process_m2name' => { 'link_table' => 'link_table_name',
29 % # 'link_static' => { 'column' => 'value' },
30 % # 'num_col' => 'column', #if column name is different in
31 % # #link_table than source_table
32 % # 'name_col' => 'name_column',
33 % # 'names_list' => [ 'list', 'names' ],
38 % #false laziness w/edit.html
39 % my $table = $opt{'table'};
40 % my $class = "FS::$table";
41 % my $pkey = dbdef->table($table)->primary_key; #? $opt{'primary_key'} ||
42 % my $fields = $opt{'fields'}
43 % #|| [ grep { $_ ne $pkey } dbdef->table($table)->columns ];
44 % || [ fields($table) ];
46 % my $pkeyvalue = $cgi->param($pkey);
48 % my $old = qsearchs( $table, { $pkey => $pkeyvalue } ) if $pkeyvalue;
50 % my $new = $class->new( {
52 % $_, scalar($cgi->param($_));
58 % $error = $new->replace($old);
60 % $error = $new->insert;
61 % $pkeyvalue = $new->getfield($pkey);
64 % if ( !$error && $opt{'process_m2m'} ) {
65 % $error = $new->process_m2m( %{ $opt{'process_m2m'} },
66 % 'params' => scalar($cgi->Vars),
70 % if ( !$error && $opt{'process_m2name'} ) {
71 % $error = $new->process_m2name( %{ $opt{'process_m2name'} },
72 % 'params' => scalar($cgi->Vars),
79 % $cgi->param('error', $error);
80 % my $edit_ext = $opt{'edit_ext'} || 'html';
81 % print $cgi->redirect(popurl(2). "$table.$edit_ext?". $cgi->query_string );
82 % } elsif ( $opt{'redirect'} ) {
83 % print $cgi->redirect( $opt{'redirect'}. $pkeyvalue );
85 % print $cgi->redirect( popurl(3).
86 % ( $opt{'viewall_dir'} || 'search' ).