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
|
<%
# options example...
#
###
##req
##
# 'table' =>
#
# #? 'primary_key' => #required when the dbdef doesn't know...???
# #? 'fields' => []
#
###
##opt
###
# 'viewall_dir' => '', #'search' or 'browse', defaults to 'search'
# '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),
);
}
if ( $error ) {
$cgi->param('error', $error);
print $cgi->redirect(popurl(2). "$table.html?". $cgi->query_string );
} else {
print $cgi->redirect( popurl(3).
( $opt{'viewall_dir'} || 'search' ).
"/$table.html"
);
}
%>
|