X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=encode.php;h=ca33c5913c09aa32feb1178095befbb31207e529;hb=cabeae074fa4c0731c4374188c764398e4279f79;hp=a4c458758e5c010e7c0c06081b5a34ce4f3105b0;hpb=848c8a4d215f9cce1db0a7d37e733b5959b8210f;p=wfpl.git diff --git a/encode.php b/encode.php index a4c4587..ca33c59 100644 --- a/encode.php +++ b/encode.php @@ -27,6 +27,12 @@ # such as < will display properly. +function enc_jsdq($str) { + $str = enc_sql($str); + $str = str_replace("\n", "\\n", $str); + return str_replace("\r", "\\r", $str); +} + # encode for putting within double-quotes in SQL function enc_sql($str) { $str = str_replace("\\", "\\\\", $str); @@ -44,6 +50,24 @@ function enc_html($str) { return $str; } +# Encode for output in html. Convert newlines to
+# +# Example:

~foo.html~

+function enc_htmlbr($str) { + $str = enc_html($str); + $str = str_replace("\n", "
\n", $str); + return $str; +} + +# Encode for output in html. Spaces converted to   +# +# Example: +function enc_htmlnbsp($str) { + $str = enc_html($str); + $str = str_replace(' ', ' ', $str); + return $str; +} + # HTML attribute. # @@ -61,6 +85,14 @@ function enc_url_val($str) { return rawurlencode($str); } +# FIXME +function enc_url_path($str) { + $str = rawurlencode($str); + $str = str_replace('%2F', '/', $str); + return $str; +} + + # This is a hack to work around html's stupid syntax for checkboxes. # # Place the template marker just before a " somewhere. @@ -89,20 +121,136 @@ function enc_tab($str) { return substr($out, 0, -1); } +function enc_upper($str) { + return strtoupper($str); +} + +function enc_ddmmyyyyhhmm($seconds) { + return date('m/d/Y g:ia', (int)$seconds); +} + + + + +define('PULLDOWN_ARRAY', 0); define('PULLDOWN_HASH', 1); define('PULLDOWN_2D', 2); + +function pulldown_options_to_2d($options, $keys_from) { + # convert other types of input to value=>display hash + switch($keys_from) { + case PULLDOWN_HASH: + $new_options = array(); + foreach($options as $value => $display) { + $new_options[] = array($value, $display); + } + return $new_options; + case PULLDOWN_ARRAY: + $new_options = array(); + foreach($options as $opt) { + $new_options[] = array($opt, $opt); + } + return $new_options; + break; + case PULLDOWN_2D: + return $options; + break; + default: + die('pulldown_options_to_2d(): unknown value: "' . print_r($keys_from) . '" passed in $keys_from parameter'); + } +} + + +# call this function before you run() the template so enc_options() knows what +# to do +# +# Parameters: +# +# name: the name of the html control +# +# options: an array of options to display in the pulldown/selectbox +# +# keys_from: Set to one of: +# PULLDOWN_ARRAY: (default) values of $options are displayd and posted +# PULLDOWN_HASH: values of $options are display, keys are posted +# PULLDOWN_2D: $options is a 2 dimensional array. +# $options[0][1] is displayed, $options[0][0] is posted. +# $options[1][1] is displayed, $options[1][0] is posted. +# +# multiple: UNTESTED set to true for multiple-select boxes. + +function pulldown($name, $options, $keys_from = PULLDOWN_ARRAY, $multiple = false) { + $options = pulldown_options_to_2d($options, $keys_from); + $GLOBALS[$name . '_options'] = array(); + $GLOBALS[$name . '_options']['options'] = $options; + $GLOBALS[$name . '_options']['multiple'] = $multiple; +} + +# output a bunch of