X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=metaform.php;h=a4a7872b66c945c698ea7ad4c38bac1f229f1693;hb=fb2d0e47e11293f8b2a98d13a76d19b6e6a4f77d;hp=c20515e340e805de25e6c09d5059e3cc1fa2ee45;hpb=3698f739c8155069451c61085ab925250c592e42;p=wfpl.git diff --git a/metaform.php b/metaform.php index c20515e..a4a7872 100644 --- a/metaform.php +++ b/metaform.php @@ -1,58 +1,143 @@ . + + +# 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 + '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)'), + 'password' => array('password', 'oneline', 'varchar(200)'), 'textarea' => array('textarea', 'unix', 'text'), - 'pulldown' => array('pulldown', 'options', 'int'), - 'checkbox' => array('checkbox', 'yesno', 'int'), - 'yesno' => array('checkbox', 'yesno', 'int'), + 'html' => array('html', 'unix', 'text'), + 'pulldown' => array('pulldown', 'options', 'varchar(100)'), + 'radio' => array('radio', 'oneline', 'varchar(200)'), + 'checkbox' => array('checkbox', 'bool', 'int(1)'), + 'yesno' => array('checkbox', 'yesno', 'varchar(3)'), + 'delete' => array('checkbox', 'yesno', 'n/a'), + 'image' => array('image', 'oneline', 'varchar(120)'), + 'thumb' => array('image', 'oneline', 'varchar(240)'), 'submit' => array('submit', 'oneline', 'n/a') ); -if(isset($_REQUEST['form_name'])) { - $GLOBALS['form_name'] = $_REQUEST['form_name']; -} else { - $GLOBALS['form_name'] = 'some_form'; -} - -if(isset($_REQUEST['fields'])) { - if(isset($_REQUEST['download_sql'])) { - download_sql(); - exit(); - } elseif(isset($_REQUEST['download_php'])) { - download_php(); - exit(); - } elseif(isset($_REQUEST['download_template'])) { - download_template(); - exit(); - } elseif(isset($_REQUEST['download_email'])) { - download_email(); - exit(); - } else { - tem_set('message', "Sorry... couldn't tell which button you pressed"); - # fall through +function list_available_types() { + ksort($GLOBALS['types']); + foreach($GLOBALS['types'] as $key => $value) { + tem_set('type', $key); + tem_show('types'); + tem_show('types_sep'); + } +} + + +function metaform() { + if(isset($_REQUEST['singular'])) { + $GLOBALS['file_name'] = format_varname($_REQUEST['file_name']); + $GLOBALS['table_name'] = format_varname($_REQUEST['table_name']); + $GLOBALS['plural'] = format_oneline($_REQUEST['plural']); + # backwards compatibility: + if(isset($_REQUEST['form_name'])) { + $GLOBALS['file_name'] = $GLOBALS['table_name'] = $GLOBALS['plural'] = format_varname($_REQUEST['form_name']); + } + tem_set('file_name', $GLOBALS['file_name']); + tem_set('table_name', $GLOBALS['table_name']); + tem_set('plural', $GLOBALS['plural']); + + $GLOBALS['singular'] = format_oneline($_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_pass'] = format_yesno($_REQUEST['opt_pass']); + tem_set('opt_pass', $GLOBALS['opt_pass']); + } + + 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']); + # fall through + } else { + die("Sorry... couldn't tell which button you pressed"); + } } -} else { - tem_output('code/wfpl/metaform/main.html'); + + + set_form_action(); + tem_load('code/wfpl/metaform/main.html'); + list_available_types(); + tem_output(); } + function field_input($type) { return $GLOBALS['types'][$type][0]; } function field_format($type) { return $GLOBALS['types'][$type][1]; } function field_sql($type) { return $GLOBALS['types'][$type][2]; } function get_fields() { + # no sense in doing all this so many times + if(isset($GLOBALS['gotten_fields'])) { + return $GLOBALS['gotten_fields']; + } + $fields_str = unix_newlines($_REQUEST['fields']); - $ret = array(); + $GLOBALS['gotten_fields'] = array(); $fields_str = rtrim($fields_str); $fields = split("\n", $fields_str); foreach($fields as $field) { @@ -62,102 +147,395 @@ function get_fields() { $input = field_input($type); $format = field_format($type); $sql = field_sql($type); - $ret[] = array($name, $type, $input, $format, $sql, $options); + $GLOBALS['gotten_fields'][] = array($name, $type, $input, $format, $sql, $options); } - return $ret; + return $GLOBALS['gotten_fields']; } -function download_headers() { - header('Content-type: application/octet-stream'); - header('Content-disposition: download'); # is this correct? does it do anything? +# this one, that you're using to create forms +function set_form_action() { + $action = ereg_replace('.*/', '', $_SERVER['REQUEST_URI']); + if($action == '') $action = './'; + tem_set('form_action', $action); +} + +# perfect HTTP headers for viewing created files +function view_headers() { + header('Content-type: text/plain'); } -function download_sql() { - tem_load('code/wfpl/metaform/template.sql'); - tem_set('form_name', $GLOBALS['form_name']); +function make_sql() { + $tem = new tem(); + $tem->load('code/wfpl/metaform/template.sql'); + $tem->set('table_name', $GLOBALS['table_name']); $fields = get_fields(); foreach($fields as $field) { list($name, $type, $input, $format, $sql) = $field; if($sql != 'n/a') { - tem_set('name', $name); - tem_set('type', $sql); - if($sql == 'int') { - tem_set('default', '0'); + $tem->set('name', $name); + $tem->set('type', $sql); + 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->set('default', '""'); } - tem_sub('column'); + $tem->show('column'); } } - download_headers(); - tem_output(); + view_headers(); + return $tem->run(); +} + +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 != 'image' && $input != 'checkbox' && $input != 'radio') { + return $name; + } + } + + return false; +} + -function download_template() { - tem_load('code/wfpl/metaform/template.html'); - tem_set('form_name', $GLOBALS['form_name']); +# pass false if you want to exclude the and tag etc. +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('file_name', $GLOBALS['file_name']); + $tem->set('table_name', $GLOBALS['table_name']); + $tem->set('singular', $GLOBALS['singular']); + $tem->set('plural', $GLOBALS['plural']); $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', $name); # fixme - tem_sub($input); - } - tem_set('name', 'save'); - tem_set('caption', 'Save'); - tem_sub('submit'); - download_headers(); - tem_output(); + $tem->set('name', $name); + $tem->set('caption', format_caption($name)); + $tem->show($input); + if($input != 'hidden') { + $tem->show('row'); + } + + if($input == 'image' && !$uploads_output_already) { + $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->show('replace_textarea'); + } + + if($GLOBALS['opt_display'] == 'Yes') { + switch($input) { + case 'image': + $tem->show('display_image'); + break; + case 'checkbox': + $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(show_in_listing($type, $input, $format, $sql)) { + if($format == 'bool' || $format == 'yesno') { + $tem->set('listing_enc', 'yesno'); + $tem->show('listing_value_enc'); + } elseif($input == 'date') { + $tem->set('listing_enc', 'mmddyyyy'); + $tem->show('listing_value_enc'); + } elseif($type == 'thumb') { + $tem->show('listing_value_thumb'); + } else { + $tem->set('listing_enc', 'html'); + $tem->show('listing_value_enc'); + } + + if($GLOBALS['opt_display'] != 'Yes') { + $tem->show('opt_display_a_else'); + } + $tem->show('listing_head_col'); + $tem->show('listing_row_col'); + } + } + } + + if($GLOBALS['opt_db'] == 'Yes') { + $tem->show('opt_db_1'); + $tem->show('opt_db_2'); + } 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'); + } + + if($GLOBALS['opt_email'] == 'Yes' && $GLOBALS['opt_db'] != 'Yes') { + $tem->set('name', 'send'); + $tem->set('caption', 'Send'); + } else { + $tem->set('name', 'save'); + $tem->set('caption', 'Save'); + } + $tem->show('submit'); + $tem->show('row'); + + $tem->show('form'); + + if($has_html_editors) { + $tem->show('html_editor_headers'); + } + + if($whole_file) { + return $tem->run(); + } else { + return $tem->get('form'); + } +} + +function view_html() { + view_headers(); + 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; + } + if($type == 'image') { + return false; + } + + return true; +} -function download_php() { - tem_load('code/wfpl/metaform/template.php'); - tem_set('form_name', $GLOBALS['form_name']); +function make_php() { + $has_html_editors = false; + $tem = new tem(); + $tem->load('code/wfpl/metaform/template.php'); + $tem->set('file_name', $GLOBALS['file_name']); + $tem->set('table_name', $GLOBALS['table_name']); + $tem->set('singular', $GLOBALS['singular']); + $tem->set('plural', $GLOBALS['plural']); $fields = get_fields(); $db_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; if($input != 'submit') { - tem_set('format', $format); - tem_set('name', $name); - tem_set('db_field', ''); # we don't want to use the value from last time + $tem->set('format', $format); + $tem->set('name', $name); + $tem->set('db_field', ''); # we don't want to use the value from last time if($sql != 'n/a') { - tem_sub('db_field'); if($db_fields != '') $db_fields .= ','; $db_fields .= $name; } - tem_sub('formats'); - if(!$always_field and $input != 'checkbox' and $input != 'radio') { - $always_field = $name; + if($input == 'image') { + if($type == 'thumb') { + $tem->show('thumb_settings'); + $tem->show('thumb_upload_params'); + $tem->show('thumb_w_h'); + } + $tem->show('image_settings'); + $tem->show('image_upload'); + if(!$image_included_yet) { + $tem->show('image_include'); + $tem->show('upload_max'); + $tem->show('upload_settings'); + $image_included_yet = true; + } + } else { + if($input == 'html') { + $has_html_editors = true; + } elseif($input == 'pulldown') { + $tem->show('pulldowns'); + $tem->show('pulldown_format_extra'); + } + $tem->show('formats'); + } + } + + 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); - download_headers(); - tem_output(); + + if($has_html_editors) { + $tem->show('show_extra_headers'); + } + + $tem->set('always_field', $always_field); + $tem->set('db_fields', $db_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'); + } + if($GLOBALS['opt_db'] == 'Yes') { + $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') { + $this_domain = $_SERVER['HTTP_HOST']; + if(substr($this_domain, -2) == '.l') { + $this_domain = substr($this_domain, 0, -1) . 'com'; + } + $tem->set('this_domain', $this_domain); + $tem->show('opt_email_1'); + $tem->show('opt_email_2'); + } + if($GLOBALS['opt_pass'] == 'Yes') { + $tem->show('opt_pass'); + } + 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); + $url = str_replace('jasonwoof.l', 'jasonwoof.com', $url); # so that code generated on Jason's home computer will display a publically accessible link. + return $url; +} + +function view_php() { + view_headers(); + echo make_php(); +} -function download_email() { - tem_load('code/wfpl/metaform/template.email.txt'); - tem_set('form_name', $GLOBALS['form_name']); +function make_email() { + $tem = new tem(); + $tem->load('code/wfpl/metaform/template.email.txt'); + $tem->set('file_name', $GLOBALS['file_name']); + $tem->set('table_name', $GLOBALS['table_name']); + $tem->set('singular', $GLOBALS['singular']); + $tem->set('plural', $GLOBALS['plural']); $fields = get_fields(); foreach($fields as $field) { list($name, $type, $input, $format, $sql) = $field; - tem_set('name', $name); - tem_set('caption', $name); # fixme - tem_sub('fields'); + $tem->set('name', $name); + $tem->set('caption', $name); # fixme + if($type == 'textarea') { + $tem->show('multi_line'); + } elseif($type == 'checkbox') { + $tem->show('checkbox'); + } else { + $tem->show('normal'); + } + $tem->show('fields'); } - download_headers(); + return $tem->run(); +} + +function make_htaccess() { + $tem = new tem(); + $tem->set('form', $GLOBALS['file_name']); + return $tem->run('code/wfpl/metaform/htaccess'); +} + +function view_email() { + view_headers(); + echo make_email(); +} + +function preview() { + tem_load('code/wfpl/metaform/preview.html'); + tem_set('file_name', $GLOBALS['file_name']); + tem_set('table_name', $GLOBALS['table_name']); + tem_set('singular', $GLOBALS['singular']); + tem_set('plural', $GLOBALS['plural']); + tem_set('fields', $_REQUEST['fields']); + $preview_tem = new tem(); + $preview_tem->load_str(make_html(false)); + if($GLOBALS['opt_db'] == 'Yes') { + $preview_tem->show('new_msg'); + } + $fields = get_fields(); + foreach($fields as $field) { + list($name, $type, $input, $format, $sql) = $field; + if($type == 'pulldown') { + pulldown($name, array('option 1', 'option 2', 'option 3')); + } + } + $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(); } -?> +function download_tar() { + $name = $GLOBALS['file_name']; + $data = array( + ".htaccess" => make_htaccess(), + #"run.php ->" => 'code/wfpl/run.php', + "style.css" => read_whole_file('code/wfpl/metaform/style.css'), + "$name.html" => make_html(), + "$name.php" => make_php()); + if($GLOBALS['opt_db'] == 'Yes') { + $data["$name.sql"] = make_sql(); + } + if($GLOBALS['opt_email'] == 'Yes') { + $data["$name.email.txt"] = make_email(); + } + make_tar($name, $data); +} + + +metaform(); +exit();