2 # Show a form for creating or editing a sequence
4 require './postgresql-lib.pl';
6 &can_edit_db($in{'db'}) || &error($text{'dbase_ecannot'});
7 $access{'edonly'} && &error($text{'dbase_ecannot'});
8 $access{'seqs'} || &error($text{'seq_ecannot'});
12 $str = &sequence_structure($in{'db'}, $in{'seq'});
15 $str = { 'increment_by' => 1,
18 $desc = "<tt>$in{'db'}</tt>";
19 &ui_print_header($desc, $in{'seq'} ? $text{'seq_title2'}
20 : $text{'seq_title1'}, "");
22 print &ui_form_start("save_seq.cgi", "post");
23 print &ui_hidden("db", $in{'db'}),"\n";
24 print &ui_hidden("old", $in{'seq'}),"\n";
25 print &ui_table_start($text{'seq_header1'}, undef, 2);
28 print &ui_table_row($text{'seq_name'},
29 $in{'seq'} ? "<tt>$in{'seq'}</tt>"
30 : &ui_textbox("name", $str->{'name'}, 20));
33 print &ui_table_row($text{'seq_last'},
34 $in{'seq'} && &supports_sequences() == 1 ?
35 &ui_opt_textbox("last", undef, 20, &text('seq_leave', $str->{'last_value'}))
36 : &ui_textbox("last", $str->{'last_value'}, 20));
39 print &ui_table_row($text{'seq_min'},
40 &ui_opt_textbox("min", $str->{'min_value'}, 20, $text{'seq_none'}));
41 print &ui_table_row($text{'seq_max'},
42 &ui_opt_textbox("max", $str->{'max_value'}, 20, $text{'seq_none'}));
45 print &ui_table_row($text{'seq_inc'},
46 &ui_textbox("inc", $str->{'increment_by'}, 5));
49 print &ui_table_row($text{'seq_cache'},
50 !$in{'seq'} ? &ui_opt_textbox("cache", undef, 5, $text{'default'})
51 : &ui_textbox("cache", $str->{'cache_value'}, 5));
53 # Wrap at end of cycle
54 print &ui_table_row($text{'seq_cycle'},
55 &ui_yesno_radio("cycle",
56 $str->{'is_cycled'} eq 't' || $str->{'is_cycled'} eq '1' ? 1 : 0));
58 print &ui_table_end();
60 print &ui_form_end([ [ "save", $text{'save'} ],
61 [ "delete", $text{'delete'} ] ]);
64 print &ui_form_end([ [ "create", $text{'create'} ] ]);
67 &ui_print_footer("edit_dbase.cgi?db=$in{'db'}", $text{'dbase_return'},
68 "", $text{'index_return'});