. # 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'), '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') ); 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"); } } 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']); $GLOBALS['gotten_fields'] = array(); $fields_str = rtrim($fields_str); $fields = split("\n", $fields_str); foreach($fields as $field) { list($name, $type, $options) = split(' *', $field); if($options) $options = split(',', $options); if(!$type) $type = $name; $input = field_input($type); $format = field_format($type); $sql = field_sql($type); $GLOBALS['gotten_fields'][] = array($name, $type, $input, $format, $sql, $options); } return $GLOBALS['gotten_fields']; } # 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 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(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->show('column'); } } 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; } # 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', 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 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 = 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 if($sql != 'n/a') { if($db_fields != '') $db_fields .= ','; $db_fields .= $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'); } } } 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 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', format_caption($name)); if($type == 'textarea') { $tem->show('multi_line'); } elseif($type == 'checkbox') { $tem->show('checkbox'); } else { $tem->show('normal'); } $tem->show('fields'); } 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();