X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=metaform.php;h=ecde564b46b0f50fc9573bc9d9b3ba934336bd07;hb=48bc8c7ca2448555a225b5996effcc9d41bdcfed;hp=a473bbca4a2eb5fff215e70c24fdc9bb6fa55af7;hpb=7add2ea3f61e40c5f0f5539ac6e02533c9390db4;p=wfpl.git diff --git a/metaform.php b/metaform.php index a473bbc..ecde564 100644 --- a/metaform.php +++ b/metaform.php @@ -2,21 +2,18 @@ # Copyright (C) 2006 Jason Woofenden # -# This file is part of wfpl. -# -# wfpl is free software; you can redistribute it and/or modify it under the -# terms of the GNU Lesser General Public License as published by the Free -# Software Foundation; either version 2.1 of the License, or (at your option) -# any later version. -# -# wfpl is distributed in the hope that it will be useful, but WITHOUT ANY -# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS -# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for -# more details. -# -# You should have received a copy of the GNU Lesser General Public License -# along with wfpl; if not, write to the Free Software Foundation, Inc., 51 -# Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . # This file writes the code for you (sql, php, html, email) to handle a form. @@ -29,14 +26,18 @@ require_once('code/wfpl/format.php'); # see code/wfpl/metaform/template.html for the html templates for these elements $GLOBALS['types'] = array( # type input format sql + 'varname' => array('textbox', 'varname', 'varchar(50)'), 'name' => array('textbox', 'oneline', 'varchar(200)'), 'textbox' => array('textbox', 'oneline', 'varchar(200)'), 'int' => array('textbox', 'int', 'int'), + 'decimal' => array('textbox', 'decimal', 'decimal(12,12)'), 'bigint' => array('textbox', 'int', 'varchar(100)'), # up to 100 digits, stored as a string + 'zip' => array('textbox', 'zip', 'varchar(20)'), 'email' => array('textbox', 'email', 'varchar(100)'), 'phone' => array('textbox', 'phone', 'varchar(32)'), 'state' => array('states', 'oneline', 'varchar(2)'), 'money' => array('textbox', 'money', 'varchar(32)'), + 'date' => array('date', 'mdy_to_ymd', 'char(10)'), 'dollars' => array('textbox', 'dollars', 'varchar(32)'), 'url' => array('textbox', 'url', 'varchar(200)'), 'hidden' => array('hidden', 'unix', 'varchar(200)'), @@ -45,33 +46,38 @@ $GLOBALS['types'] = array( 'html' => array('html', 'unix', 'text'), 'pulldown' => array('pulldown', 'options', 'varchar(100)'), 'radio' => array('radio', 'oneline', 'varchar(200)'), - 'leftcheck' => array('leftcheck', 'yesno', 'varchar(3)'), - 'checkbox' => array('checkbox', 'yesno', 'varchar(3)'), - 'yesno' => array('checkbox', 'yesno', 'varchar(3)'), + 'checkbox' => array('leftcheck', 'bool', 'int(1)'), + 'rightcheck' => array('checkbox', 'bool', 'int(1)'), + 'rightyesno' => array('checkbox', 'yesno', 'varchar(3)'), + 'yesno' => array('leftcheck', 'yesno', 'varchar(3)'), 'delete' => array('checkbox', 'yesno', 'n/a'), 'image' => array('image', 'oneline', 'varchar(200)'), 'submit' => array('submit', 'oneline', 'n/a') ); function list_available_types() { - $types = ''; + ksort($GLOBALS['types']); foreach($GLOBALS['types'] as $key => $value) { - if($types) { - $types .= ', '; - } - $types .= $key; + tem_set('type', $key); + tem_show('types'); + tem_show('types_sep'); } - tem_set('available_types', $types); } function metaform() { if(isset($_REQUEST['form_name'])) { - $GLOBALS['form_name'] = ereg_replace('[^a-z0-9_-]', '', $_REQUEST['form_name']); + $GLOBALS['form_name'] = format_varname($_REQUEST['form_name']); + $GLOBALS['singular'] = format_varname($_REQUEST['singular']); + tem_set('singular', $GLOBALS['singular']); $GLOBALS['opt_email'] = format_yesno($_REQUEST['opt_email']); tem_set('opt_email', $GLOBALS['opt_email']); $GLOBALS['opt_db'] = format_yesno($_REQUEST['opt_db']); tem_set('opt_db', $GLOBALS['opt_db']); + $GLOBALS['opt_listing'] = format_yesno($_REQUEST['opt_listing']); + tem_set('opt_listing', $GLOBALS['opt_listing']); + $GLOBALS['opt_display'] = format_yesno($_REQUEST['opt_display']); + tem_set('opt_display', $GLOBALS['opt_display']); $GLOBALS['opt_http_pass'] = format_yesno($_REQUEST['opt_http_pass']); tem_set('opt_http_pass', $GLOBALS['opt_http_pass']); } else { @@ -108,8 +114,9 @@ function metaform() { set_form_action(); + tem_load('code/wfpl/metaform/main.html'); list_available_types(); - tem_output('code/wfpl/metaform/main.html'); + tem_output(); } @@ -164,12 +171,14 @@ function make_sql() { if($sql != 'n/a') { $tem->set('name', $name); $tem->set('type', $sql); - if($sql == 'int') { + if(substr($sql, 0, 3) == 'int' || substr($sql, 0, 7) == 'decimal') { $tem->set('default', '0'); + } elseif($format == 'yesno') { + $tem->set('default', '"No"'); } else { $tem->set('default', '""'); } - $tem->sub('column'); + $tem->show('column'); } } view_headers(); @@ -180,6 +189,19 @@ function view_sql() { view_headers(); echo make_sql(); } + +# always_field is a form field that always submits (unlike say, checkboxes). It's used to detect if the form has submitted or not. +function find_always_field($fields) { + foreach($fields as $field) { + list($name, $type, $input, $format, $sql) = $field; + if($input != 'submit' && $input != 'checkbox' && $input != 'radio') { + return $name; + } + } + + return false; +} + # pass false if you want to exclude the and tag etc. @@ -189,31 +211,79 @@ function make_html($whole_file = true) { $tem = new tem(); $tem->load('code/wfpl/metaform/template.html'); $tem->set('form_name', $GLOBALS['form_name']); + $tem->set('singular', $GLOBALS['singular']); $fields = get_fields(); + $tem->set('always_field', find_always_field($fields)); foreach($fields as $field) { list($name, $type, $input, $format, $sql) = $field; $tem->set('name', $name); $tem->set('caption', format_caption($name)); - $tem->sub($input); + $tem->show($input); if($input != 'hidden') { - $tem->sub('row'); + $tem->show('row'); } + if($input == 'image' && !$uploads_output_already) { - $tem->sub('uploads'); + $tem->show('uploads'); $tem->set('enctype_attr', '" enctype="multipart/form-data'); $uploads_output_already = true; } elseif($input == 'html') { $has_html_editors = true; $tem->set('html_field_name', $name); - $tem->sub('replace_textarea'); + $tem->show('replace_textarea'); + } + + if($GLOBALS['opt_display'] == 'Yes') { + switch($input) { + case 'checkbox': + case 'leftcheck': + $tem->show('display_yesno'); + break; + case 'date': + $tem->show('display_date'); + break; + case 'textarea': + $tem->show('display_multiline'); + break; + case 'html': + $tem->show('display_html'); + break; + default: + $tem->show('display_short'); + } + $tem->show('display_row'); + } + + if($GLOBALS['opt_listing'] == 'Yes') { + if($GLOBALS['opt_display'] != 'Yes') { + $tem->show('opt_display_a_else'); + } + if(show_in_listing($type, $input, $format, $sql)) { + if($format == 'bool' || $format == 'yesno') { + $tem->set('listing_enc', 'yesno'); + } elseif($input == 'date') { + $tem->set('listing_enc', 'mmddyyyy'); + } + $tem->show('listing_head_col'); + $tem->show('listing_row_col'); + } } } if($GLOBALS['opt_db'] == 'Yes') { - $tem->sub('opt_db_1'); - $tem->sub('opt_db_2'); + $tem->show('opt_db_1'); + $tem->show('opt_db_2'); } else { - $tem->sub('opt_db_1_else'); + $tem->show('opt_db_1_else'); + } + + if($GLOBALS['opt_listing'] == 'Yes') { + $tem->show('opt_listing_1'); + } + + if($GLOBALS['opt_display'] == 'Yes') { + $tem->show('opt_display_1'); + $tem->show('opt_display_2'); } if($GLOBALS['opt_email'] == 'Yes' && $GLOBALS['opt_db'] != 'Yes') { @@ -223,13 +293,13 @@ function make_html($whole_file = true) { $tem->set('name', 'save'); $tem->set('caption', 'Save'); } - $tem->sub('submit'); - $tem->sub('row'); + $tem->show('submit'); + $tem->show('row'); - $tem->sub('form'); + $tem->show('form'); if($has_html_editors) { - $tem->sub('html_editor_headers'); + $tem->show('html_editor_headers'); } if($whole_file) { @@ -244,15 +314,29 @@ function view_html() { echo make_html(); } +function show_in_listing($type, $input, $format, $sql) { + switch($input) { + case 'submit': + case 'hidden': + case 'password': + case 'textarea': + case 'html': + return false; + default: + return true; + } +} + function make_php() { $tem = new tem(); $tem->load('code/wfpl/metaform/template.php'); $tem->set('form_name', $GLOBALS['form_name']); + $tem->set('singular', $GLOBALS['singular']); $fields = get_fields(); $db_fields = ''; $php_fields = ''; - $always_field = false; + $always_field = find_always_field($fields); $image_included_yet = false; foreach($fields as $field) { list($name, $type, $input, $format, $sql) = $field; @@ -267,46 +351,61 @@ function make_php() { $php_fields .= '$' . $name; } if($input == 'image') { - $tem->sub('image_upload'); - $tem->sub('image_db'); + $tem->show('image_upload'); + $tem->show('image_db'); if(!$image_included_yet) { - $tem->sub('image_include'); - $tem->sub('upload_max'); - $tem->sub('upload_settings'); + $tem->show('image_include'); + $tem->show('upload_max'); + $tem->show('upload_settings'); $image_included_yet = true; } } else { if($input == 'pulldown') { - $tem->sub('pulldowns'); - $tem->sub('pulldown_format_extra'); + $tem->show('pulldowns'); + $tem->show('pulldown_format_extra'); } - $tem->sub('formats'); + $tem->show('formats'); } - $tem->sub('tem_sets'); - if(!$always_field and $input != 'checkbox' and $input != 'radio') { - $always_field = $name; + $tem->show('tem_sets'); + } + + if($GLOBALS['opt_listing'] == 'Yes') { + if(show_in_listing($type, $input, $format, $sql)) { + $tem->show('listing_fields_1'); + $tem->show('listing_fields_2'); } } } - # always_field is a form field that always submits (unlike say, checkboxes). It's used to detect if the form has submitted or not. + $tem->set('always_field', $always_field); $tem->set('db_fields', $db_fields); $tem->set('php_fields', $php_fields); $tem->set('metaform_url', edit_url()); + if($GLOBALS['opt_listing'] == 'Yes') { + $tem->show('opt_listing_1'); + $tem->show('opt_listing_2'); + } + if($GLOBALS['opt_display'] == 'Yes') { + $tem->show('opt_display_1'); + $tem->show('opt_display_2'); + } else { + $tem->show('opt_display_1_else'); + $tem->show('opt_display_2_else'); + } if($GLOBALS['opt_db'] == 'Yes') { - $tem->sub('opt_db_1'); - $tem->sub('opt_db_2'); - $tem->sub('opt_db_3'); - $tem->sub('opt_db_4'); - $tem->sub('opt_db_5'); + $tem->show('opt_db_1'); + $tem->show('opt_db_2'); + $tem->show('opt_db_3'); + $tem->show('opt_db_4'); + $tem->show('opt_db_5'); } if($GLOBALS['opt_email'] == 'Yes') { - $tem->sub('opt_email_1'); - $tem->sub('opt_email_2'); + $tem->show('opt_email_1'); + $tem->show('opt_email_2'); } if($GLOBALS['opt_http_pass'] == 'Yes') { - $tem->sub('opt_http_pass_1'); - $tem->sub('opt_http_pass_2'); + $tem->show('opt_http_pass_1'); + $tem->show('opt_http_pass_2'); } return $tem->run(); } @@ -337,10 +436,13 @@ function make_email() { $tem->set('name', $name); $tem->set('caption', $name); # fixme if($type == 'textarea') { - $tem->sub('multi_line'); + $tem->show('multi_line'); + } elseif($type == 'checkbox') { + $tem->show('checkbox'); } else { - $tem->sub('fields'); + $tem->show('normal'); } + $tem->show('fields'); } return $tem->run(); } @@ -364,7 +466,7 @@ function preview() { $preview_tem = new tem(); $preview_tem->load_str(make_html(false)); if($GLOBALS['opt_db'] == 'Yes') { - $preview_tem->sub('new_msg'); + $preview_tem->show('new_msg'); } $fields = get_fields(); foreach($fields as $field) { @@ -375,7 +477,9 @@ function preview() { } $preview = $preview_tem->run(); unset($preview_tem); + $preview = ereg_replace('type="submit"', 'type="submit" disabled="disabled"', $preview); tem_set('preview', $preview); + tem_show('hiddens'); set_form_action(); tem_output(); } @@ -394,7 +498,7 @@ function download_tar() { if($GLOBALS['opt_email'] == 'Yes') { $data["$name.email.txt"] = make_email(); } - make_wfpl_tar($name, $data); + make_tar($name, $data); }