Total ui-lib conversion
authorJamie Cameron <jcameron@webmin.com>
Sat, 19 Jan 2008 23:12:34 +0000 (23:12 +0000)
committerJamie Cameron <jcameron@webmin.com>
Sat, 19 Jan 2008 23:12:34 +0000 (23:12 +0000)
procmail/CHANGELOG
procmail/edit_env.cgi
procmail/edit_inc.cgi
procmail/edit_recipe.cgi
procmail/lang/en
procmail/manual_form.cgi

index 14cb8d8..54332e5 100644 (file)
@@ -1,2 +1,4 @@
 ---- Changes since 1.270 ----
 Added a button for deleting multiple recipes at once.
+---- Changes since 1.390 ----
+Converted all code to use the new Webmin UI library, for a more consistent look.
index 63e2d9e..b6479ca 100755 (executable)
@@ -13,41 +13,29 @@ else {
        $env = $conf[$in{'idx'}];
        }
 
-print "<form action=save_env.cgi>\n";
-print "<input type=hidden name=new value='$in{'new'}'>\n";
-print "<input type=hidden name=idx value='$in{'idx'}'>\n";
+print &ui_form_start("save_env.cgi");
+print &ui_hidden("new", $in{'new'});
+print &ui_hidden("idx", $in{'idx'});
+print &ui_table_start($text{'env_header'}, "width=100%", 2);
 
-print "<table border width=100%>\n";
-print "<tr $tb> <td><b>$text{'env_header'}</b></td> </tr>\n";
-print "<tr $cb> <td><table width=100%>\n";
+# Variable name
+print &ui_table_row($text{'env_name'},
+       &ui_textbox("name", $env->{'name'}, 60));
 
-print "<tr> <td><b>$text{'env_name'}</b></td>\n";
-printf "<td><input name=name size=60 value='%s'></td> </tr>\n",
-       &html_escape($env->{'name'});
-
-print "<tr> <td valign=top><b>$text{'env_value'}</b></td>\n";
-if ($env->{'value'} =~ /\n/) {
-       print "<td><textarea name=value rows=4 cols=60>",
-               &html_escape($env->{'value'}),"</textarea></td> </tr>\n";
-       }
-else {
-       printf "<td><input name=value size=60 value='%s'></td> </tr>\n",
-               &html_escape($env->{'value'});
-       }
-
-print "</table></td></tr></table>\n";
+# Value or values
+print &ui_table_row($text{'env_value'},
+       $env->{'value'} =~ /\n/ ? &ui_textarea("value", $env->{'value'}, 4, 60)
+                               : &ui_textbox("value", $env->{'value'}, 60));
 
 # Show save buttons
-print "<table width=100%><tr>\n";
+print &ui_table_end();
 if ($in{'new'}) {
-       print "<td><input type=submit value='$text{'create'}'></td>\n";
+       print &ui_form_end([ [ undef, $text{'create'} ] ]);
        }
 else {
-       print "<td><input type=submit value='$text{'save'}'></td>\n";
-       print "<td align=right><input type=submit name=delete ",
-             "value='$text{'delete'}'></td>\n";
+       print &ui_form_end([ [ undef, $text{'save'} ],
+                            [ 'delete', $text{'delete'} ] ]);
        }
-print "</tr></table></form>\n";
 
 &ui_print_footer("", $text{'index_return'});
 
index 3c08f25..dc09eca 100755 (executable)
@@ -13,31 +13,25 @@ else {
        $inc = $conf[$in{'idx'}];
        }
 
-print "<form action=save_inc.cgi>\n";
-print "<input type=hidden name=new value='$in{'new'}'>\n";
-print "<input type=hidden name=idx value='$in{'idx'}'>\n";
+print &ui_form_start("save_inc.cgi");
+print &ui_hidden("new", $in{'new'});
+print &ui_hidden("idx", $in{'idx'});
+print &ui_table_start($text{'inc_header'}, "width=100%", 2);
 
-print "<table border width=100%>\n";
-print "<tr $tb> <td><b>$text{'inc_header'}</b></td> </tr>\n";
-print "<tr $cb> <td><table width=100%>\n";
-
-print "<tr> <td><b>$text{'inc_inc'}</b></td>\n";
-printf "<td><input name=inc size=60 value='%s'> %s</td> </tr>\n",
-       &html_escape($inc->{'include'}), &file_chooser_button("inc");
-
-print "</table></td></tr></table>\n";
+# Included file
+print &ui_table_row($text{'inc_inc'},
+       &ui_textbox("inc", $inc->{'include'}, 60)." ".
+       &file_chooser_button("inc"));
 
 # Show save buttons
-print "<table width=100%><tr>\n";
+print &ui_table_end();
 if ($in{'new'}) {
-       print "<td><input type=submit value='$text{'create'}'></td>\n";
+       print &ui_form_end([ [ undef, $text{'create'} ] ]);
        }
 else {
-       print "<td><input type=submit value='$text{'save'}'></td>\n";
-       print "<td align=right><input type=submit name=delete ",
-             "value='$text{'delete'}'></td>\n";
+       print &ui_form_end([ [ undef, $text{'save'} ],
+                            [ 'delete', $text{'delete'} ] ]);
        }
-print "</tr></table></form>\n";
 
 &ui_print_footer("", $text{'index_return'});
 
index 4de5a96..c82ee8f 100755 (executable)
@@ -15,111 +15,84 @@ else {
        $block++ if (defined($rec->{'block'}));
        }
 
-print "<form action=save_recipe.cgi>\n";
-print "<input type=hidden name=new value='$in{'new'}'>\n";
-print "<input type=hidden name=idx value='$in{'idx'}'>\n";
-print "<input type=hidden name=before value='$in{'before'}'>\n";
-print "<input type=hidden name=after value='$in{'after'}'>\n";
-print "<input type=hidden name=block value='$block'>\n";
-
-# Show action section
-print "<table border width=100%>\n";
-print "<tr $tb> <td><b>$text{'edit_header1'}</b></td> </tr>\n";
-print "<tr $cb> <td><table width=100%>\n";
+print &ui_form_start("save_recipe.cgi");
+print &ui_hidden("new", $in{'new'});
+print &ui_hidden("idx", $in{'idx'});
+print &ui_hidden("before", $in{'before'});
+print &ui_hidden("after", $in{'after'});
+print &ui_hidden("block", $block);
+print &ui_table_start($text{'edit_header1'}, "width=100%", 2);
 
 if ($block) {
        # Start of a conditional block
        local @lines = split(/\n/, $rec->{'block'});
        local $r = @lines > 5 ? 10 : 5;
-       print "<tr> <td valign=top><b>$text{'edit_block'}</b></td>\n";
-       print "<td colspan=3><textarea name=bdata rows=$r cols=80>",
-               $rec->{'block'},"</textarea></td> </tr>\n";
+       print &ui_table_row($text{'edit_block'},
+               &ui_textarea("bdata", $rec->{'block'}, $r, 80));
        }
 else {
        # Simple action
        ($t, $a) = &parse_action($rec);
-       print "<tr> <td><b>$text{'edit_action'}</b></td>\n";
-       print "<td colspan=3><select name=amode>\n";
-       foreach $i (0, 2, 1, 3, 4, 6) {
-               printf "<option value=%d %s>%s\n",
-                       $i, $t == $i ? "selected" : "", $text{"edit_amode_$i"};
-               }
-       print "</select>\n";
-       printf "<input name=action size=40 value='%s'></td> </tr>\n",
-               &html_escape($t == 6 ? $rec->{'action'} : $a);
+       print &ui_table_row($text{'edit_action'},
+               &ui_select("amode", $t,
+                  [ map { [ $_, $text{"edit_amode_".$_} ] }
+                        (0, 2, 1, 3, 4, 6) ])." ".
+               &ui_textbox("action", $t == 6 ? $rec->{'action'} : $a, 40));
        }
 
-print "<tr> <td colspan=4><table>\n";
-$i = 0;
+# Action options
+@grid = ( );
 foreach $f (@known_flags) {
-       print "<tr>\n" if ($i%2 == 0);
-       print "<td width=50% nowrap>\n";
-       printf "<input type=checkbox name=flag value=%s %s> %s\n",
-               $f, &indexof($f, @{$rec->{'flags'}}) >= 0 ? "checked" : "",
-               $text{"edit_flag_$f"};
-       print "</td>\n";
-       print "</tr>\n" if ($i%2 == 1);
-       $i++;
+       push(@grid, &ui_checkbox("flag", $f, $text{"edit_flag_$f"},
+                                &indexof($f, @{$rec->{'flags'}}) >= 0));
        }
-print "</table></td> </tr>\n";
+print &ui_table_row(undef, &ui_grid_table(\@grid, 2, 100), 2);
 
+# Lock file
 $ldef = $rec->{'lockfile'} ? 0 :
        defined($rec->{'lockfile'}) ? 2 : 1;
-print "<tr> <td><b>$text{'edit_lockfile'}</b></td> <td colspan=3>\n";
-printf "<input type=radio name=lockfile_def value=1 %s> %s\n",
-       $ldef == 1 ? "checked" : "", $text{'edit_none'};
-printf "<input type=radio name=lockfile_def value=2 %s> %s\n",
-       $ldef == 2 ? "checked" : "", $text{'default'};
-printf "<input type=radio name=lockfile_def value=0 %s> %s\n",
-       $ldef == 0 ? "checked" : "", $text{'edit_lock'};
-printf "<input name=lockfile size=40 value='%s'></td> </tr>\n",
-       &html_escape($rec->{'lockfile'});
+print &ui_table_row($text{'edit_lockfile'},
+       &ui_radio("lockfile_def", $ldef,
+                 [ [ 1, $text{'edit_none'} ],
+                   [ 2, $text{'default'} ],
+                   [ 0, $text{'edit_lock'}." ".
+                        &ui_textbox("lockfile", $rec->{'lockfile'}, 40) ] ]));
 
-print "</table></td></tr></table><br>\n";
+print &ui_table_end();
 
 # Show conditions section
-print "<table border width=100%>\n";
-print "<tr $tb> <td><b>$text{'edit_header2'}</b></td> </tr>\n";
-print "<tr $cb> <td>\n";
-
-print "$text{'edit_conddesc'}<p>\n";
+print &ui_table_start($text{'edit_header2'}, "width=100%", 2);
+print &ui_table_row(undef, $text{'edit_conddesc'}, 2);
 
+$ctable = &ui_columns_start([ $text{'edit_ctype'}, $text{'edit_cvalue'} ], 100);
 $i = 0;
 foreach $c (@{$rec->{'conds'}}, [ '-' ], [ '-' ] ) {
-       print "<select name=cmode_$i>\n";
-       printf "<option value='-' %s>&nbsp;\n",
-               $c->[0] eq '-' ? "selected" : "";
-       printf "<option value='' %s> %s\n",
-               $c->[0] eq '' ? "selected" : "", $text{'edit_cmode_re'};
-       printf "<option value='!' %s> %s\n",
-               $c->[0] eq '!' ? "selected" : "", $text{'edit_cmode_nre'};
-       printf "<option value='\$' %s> %s\n",
-               $c->[0] eq '$' ? "selected" : "", $text{'edit_cmode_shell'};
-       printf "<option value='?' %s> %s\n",
-               $c->[0] eq '?' ? "selected" : "", $text{'edit_cmode_exit'};
-       printf "<option value='<' %s> %s\n",
-               $c->[0] eq '<' ? "selected" : "", $text{'edit_cmode_lt'};
-       printf "<option value='>' %s> %s\n",
-               $c->[0] eq '>' ? "selected" : "", $text{'edit_cmode_gt'};
-       print "</select>\n";
-       printf "<input name=cond_$i size=60 value='%s'><br>\n",
-               &html_escape($c->[1]);
+       $ctable .= &ui_columns_row([
+               &ui_select("cmode_$i", $c->[0],
+                  [ [ '-', '&nbsp;' ],
+                    [ '', $text{'edit_cmode_re'} ],
+                    [ '!', $text{'edit_cmode_nre'} ],
+                    [ '$', $text{'edit_cmode_shell'} ],
+                    [ '?', $text{'edit_cmode_exit'} ],
+                    [ '<', $text{'edit_cmode_lt'} ],
+                    [ '>', $text{'edit_cmode_gt'} ] ]),
+               &ui_textbox("cond_$i", $c->[1], 60, 0, undef,
+                           "style='width:100%'"),
+               ]);
        $i++;
        }
-
-print "</td></tr></table>\n";
+$ctable .= &ui_columns_end();
+print &ui_table_row(undef, $ctable, 2);
+print &ui_table_end();
 
 # Show save buttons
-print "<table width=100%><tr>\n";
 if ($in{'new'}) {
-       print "<td><input type=submit value='$text{'create'}'></td>\n";
+       print &ui_form_end([ [ undef, $text{'create'} ] ]);
        }
 else {
-       print "<td><input type=submit value='$text{'save'}'></td>\n";
-       print "<td align=right><input type=submit name=delete ",
-             "value='$text{'delete'}'></td>\n";
+       print &ui_form_end([ [ undef, $text{'save'} ],
+                            [ 'delete', $text{'delete'} ] ]);
        }
-print "</tr></table></form>\n";
 
 &ui_print_footer("", $text{'index_return'});
 
index b9f7dda..76c9ae9 100644 (file)
@@ -68,6 +68,8 @@ edit_cmode_gt=Mail is bigger than
 edit_conddesc=For the above action to be carried out, all the conditions below must match. If there are no conditions, the action will always be executed.
 edit_none=None
 edit_lock=Specific file
+edit_ctype=Condition type
+edit_cvalue=Regular expression or command
 
 save_err=Failed to save action
 save_eaction_0=Missing file to append to
index ea3dbd9..8a96475 100755 (executable)
@@ -6,13 +6,12 @@ require './procmail-lib.pl';
 &ui_print_header(undef, $text{'manual_title'}, "");
 
 print &text('manual_desc', "<tt>$procmailrc</tt>"),"<p>\n";
-print "<form action=manual_save.cgi method=post enctype=multipart/form-data>\n";
-print "<textarea name=data rows=20 cols=80>";
-open(FILE, $procmailrc);
-while(<FILE>) { print &html_escape($_); }
-close(FILE);
-print "</textarea><br>\n";
-print "<input type=submit value='$text{'save'}'>\n";
+print &ui_form_start("manual_save.cgi", "form-data");
+print &ui_table_start(undef, undef, 2);
+$data = &read_file_contents($procmailrc);
+print &ui_table_row(undef, &ui_textarea("data", $data, 20, 80), 2);
+print &ui_table_end();
+print &ui_form_end([ [ undef, $text{'save'} ] ]);
 
 &ui_print_footer("", $text{'index_return'});