'password' => array('password', 'oneline', 'varchar(200)'),
'textarea' => array('textarea', 'unix', 'text'),
'html' => array('html', 'unix', 'text'),
- 'pulldown' => array('pulldown', 'options', 'int'),
+ '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)'),
'delete' => array('checkbox', 'yesno', 'n/a'),
tem_set('opt_email', $GLOBALS['opt_email']);
$GLOBALS['opt_db'] = format_yesno($_REQUEST['opt_db']);
tem_set('opt_db', $GLOBALS['opt_db']);
+ $GLOBALS['opt_http_pass'] = format_yesno($_REQUEST['opt_http_pass']);
+ tem_set('opt_http_pass', $GLOBALS['opt_http_pass']);
} else {
$GLOBALS['form_name'] = 'some_form';
}
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) {
$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'];
}
# this one, that you're using to create forms
foreach($fields as $field) {
list($name, $type, $input, $format, $sql) = $field;
$tem->set('name', $name);
- $tem->set('caption', $name); # fixme
+ $tem->set('caption', format_caption($name));
$tem->sub($input);
if($input != 'hidden') {
$tem->sub('row');
if($GLOBALS['opt_db'] == 'Yes') {
$tem->sub('opt_db_1');
+ $tem->sub('opt_db_2');
} else {
$tem->sub('opt_db_1_else');
}
- $tem->set('name', 'save');
- $tem->set('caption', 'Save');
+
+ 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->sub('submit');
$tem->sub('row');
+
$tem->sub('form');
if($has_html_editors) {
$image_included_yet = true;
}
} else {
+ if($input == 'pulldown') {
+ $tem->sub('pulldowns');
+ $tem->sub('pulldown_format_extra');
+ }
$tem->sub('formats');
- $tem->sub('tem_sets');
}
+ $tem->sub('tem_sets');
if(!$always_field and $input != 'checkbox' and $input != 'radio') {
$always_field = $name;
}
$tem->sub('opt_email_1');
$tem->sub('opt_email_2');
}
+ if($GLOBALS['opt_http_pass'] == 'Yes') {
+ $tem->sub('opt_http_pass_1');
+ $tem->sub('opt_http_pass_2');
+ }
return $tem->run();
}
$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 make_htaccess() {
$tem = new tem();
$tem->set('form', $GLOBALS['form_name']);
- return $tem->run('code/wfpl/metaform/template.htaccess');
+ return $tem->run('code/wfpl/metaform/htaccess');
}
function view_email() {
tem_set('form_name', $GLOBALS['form_name']);
tem_set('fields', $_REQUEST['fields']);
$preview_tem = new tem();
- $preview = $preview_tem->run(make_html(false));
+ $preview_tem->load_str(make_html(false));
+ if($GLOBALS['opt_db'] == 'Yes') {
+ $preview_tem->sub('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);
tem_set('preview', $preview);
set_form_action();
$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.sql" => make_sql(),
"$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();
}