X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=metaform.php;h=82153945595e3d19b7e09ef8877477787bbbf0bb;hb=21c47e88810e97fe5b727c9c2689f64533bf6452;hp=82637970b03d73e18438d42e47c38699295abbf3;hpb=22d5fb7ab7d4ee86bd59e194387dca268bd577a1;p=wfpl.git diff --git a/metaform.php b/metaform.php index 8263797..8215394 100644 --- a/metaform.php +++ b/metaform.php @@ -22,23 +22,29 @@ # This file writes the code for you (sql, php, html, email) to handle a form. require_once('code/wfpl/template.php'); +require_once('code/wfpl/http.php'); require_once('code/wfpl/tar.php'); +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 'name' => array('textbox', 'oneline', 'varchar(200)'), 'textbox' => array('textbox', 'oneline', 'varchar(200)'), - 'int' => array('textbox', 'int', 'varchar(100)'), + 'int' => array('textbox', 'int', 'int'), + 'bigint' => array('textbox', 'int', 'varchar(100)'), # up to 100 digits, stored as a string 'email' => array('textbox', 'email', 'varchar(100)'), 'phone' => array('textbox', 'phone', 'varchar(32)'), + 'state' => array('states', 'oneline', 'varchar(2)'), 'money' => array('textbox', 'money', 'varchar(32)'), 'dollars' => array('textbox', 'dollars', 'varchar(32)'), 'url' => array('textbox', 'url', 'varchar(200)'), 'hidden' => array('hidden', 'unix', 'varchar(200)'), 'password' => array('password', 'oneline', 'varchar(200)'), 'textarea' => array('textarea', 'unix', 'text'), + 'html' => array('html', 'unix', 'text'), 'pulldown' => array('pulldown', 'options', 'int'), + 'radio' => array('radio', 'oneline', 'varchar(200)'), 'checkbox' => array('checkbox', 'yesno', 'varchar(3)'), 'yesno' => array('checkbox', 'yesno', 'varchar(3)'), 'delete' => array('checkbox', 'yesno', 'n/a'), @@ -46,43 +52,62 @@ $GLOBALS['types'] = array( 'submit' => array('submit', 'oneline', 'n/a') ); -if(isset($_REQUEST['form_name'])) { - $GLOBALS['form_name'] = ereg_replace('[^a-z0-9_-]', '', $_REQUEST['form_name']); -} else { - $GLOBALS['form_name'] = 'some_form'; +function list_available_types() { + $types = ''; + foreach($GLOBALS['types'] as $key => $value) { + if($types) { + $types .= ', '; + } + $types .= $key; + } + tem_set('available_types', $types); } -if(isset($_REQUEST['fields'])) { - if(isset($_REQUEST['view_sql'])) { - view_sql(); - exit(); - } elseif(isset($_REQUEST['view_php'])) { - view_php(); - exit(); - } elseif(isset($_REQUEST['view_template'])) { - view_template(); - exit(); - } elseif(isset($_REQUEST['view_email'])) { - view_email(); - exit(); - } elseif(isset($_REQUEST['download_tar'])) { - download_tar(); - exit(); - } elseif(isset($_REQUEST['preview'])) { - preview(); - exit(); - } elseif(isset($_REQUEST['edit'])) { - tem_set('fields', $_REQUEST['fields']); - tem_set('form_name', $GLOBALS['form_name']); - # fall through + +function metaform() { + if(isset($_REQUEST['form_name'])) { + $GLOBALS['form_name'] = ereg_replace('[^a-z0-9_-]', '', $_REQUEST['form_name']); + $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']); } else { - die("Sorry... couldn't tell which button you pressed"); + $GLOBALS['form_name'] = 'some_form'; + } + + if(isset($_REQUEST['fields'])) { + if(isset($_REQUEST['view_sql'])) { + view_sql(); + exit(); + } elseif(isset($_REQUEST['view_php'])) { + view_php(); + exit(); + } elseif(isset($_REQUEST['view_html'])) { + view_html(); + exit(); + } elseif(isset($_REQUEST['view_email'])) { + view_email(); + exit(); + } elseif(isset($_REQUEST['download_tar'])) { + download_tar(); + exit(); + } elseif(isset($_REQUEST['preview'])) { + preview(); + exit(); + } elseif(isset($_REQUEST['edit'])) { + tem_set('fields', $_REQUEST['fields']); + tem_set('form_name', $GLOBALS['form_name']); + # fall through + } else { + die("Sorry... couldn't tell which button you pressed"); + } } -} -set_form_action(); -tem_output('code/wfpl/metaform/main.html'); -exit(); + + set_form_action(); + list_available_types(); + tem_output('code/wfpl/metaform/main.html'); +} function field_input($type) { return $GLOBALS['types'][$type][0]; } @@ -150,8 +175,9 @@ function view_sql() { # pass false if you want to exclude the and tag etc. -function make_template($whole_file = true) { +function make_html($whole_file = true) { $uploads_output_already = false; + $has_html_editors = false; $tem = new tem(); $tem->load('code/wfpl/metaform/template.html'); $tem->set('form_name', $GLOBALS['form_name']); @@ -168,13 +194,28 @@ function make_template($whole_file = true) { $tem->sub('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'); } } + + if($GLOBALS['opt_db'] == 'Yes') { + $tem->sub('opt_db_1'); + } else { + $tem->sub('opt_db_1_else'); + } $tem->set('name', 'save'); $tem->set('caption', 'Save'); $tem->sub('submit'); $tem->sub('row'); $tem->sub('form'); + + if($has_html_editors) { + $tem->sub('html_editor_headers'); + } + if($whole_file) { return $tem->run(); } else { @@ -182,9 +223,9 @@ function make_template($whole_file = true) { } } -function view_template() { +function view_html() { view_headers(); - echo make_template(); + echo make_html(); } @@ -231,9 +272,30 @@ function make_php() { $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_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'); + } + if($GLOBALS['opt_email'] == 'Yes') { + $tem->sub('opt_email_1'); + $tem->sub('opt_email_2'); + } return $tem->run(); } +# make a URL for the edit page with all the fields filled in +function edit_url() { + $url = this_url(); + $url = ereg_replace('view_php=[^&]*', 'edit=yes', $url); + $url = ereg_replace('download_tar=[^&]*', 'edit=yes', $url); + $url = ereg_replace('/[a-z0-9_.]*\?', '/?', $url); + return $url; +} + function view_php() { view_headers(); echo make_php(); @@ -249,11 +311,21 @@ function make_email() { list($name, $type, $input, $format, $sql) = $field; $tem->set('name', $name); $tem->set('caption', $name); # fixme - $tem->sub('fields'); + if($type == 'textarea') { + $tem->sub('multi_line'); + } else { + $tem->sub('fields'); + } } return $tem->run(); } +function make_htaccess() { + $tem = new tem(); + $tem->set('form', $GLOBALS['form_name']); + return $tem->run('code/wfpl/metaform/template.htaccess'); +} + function view_email() { view_headers(); echo make_email(); @@ -261,26 +333,33 @@ function view_email() { function preview() { - $tem = new tem(); - $tem->load('code/wfpl/metaform/preview.html'); - $tem->set('form_name', $GLOBALS['form_name']); - $tem->set('fields', $_REQUEST['fields']); + tem_load('code/wfpl/metaform/preview.html'); + tem_set('form_name', $GLOBALS['form_name']); + tem_set('fields', $_REQUEST['fields']); $preview_tem = new tem(); - $preview = $preview_tem->run(make_template(false)); + $preview = $preview_tem->run(make_html(false)); unset($preview_tem); - $tem->set('preview', $preview); + tem_set('preview', $preview); set_form_action(); - $tem->output(); + tem_output(); } function download_tar() { $name = $GLOBALS['form_name']; $data = array( - "$name.html" => make_template(), + ".htaccess" => make_htaccess(), + "run.php ->" => 'code/wfpl/run.php', + "$name.html" => make_html(), "$name.sql" => make_sql(), - "$name.email.txt" => make_email(), "$name.php" => make_php()); + if($GLOBALS['opt_email'] == 'Yes') { + $data["$name.email.txt"] = make_email(); + } make_wfpl_tar($name, $data); } + +metaform(); +exit(); + ?>