X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=encode.php;h=fd00b975c601d33dd1705f4fafbf23faf33d19ee;hb=332683184a73f7c141132c20c715cd731687f835;hp=a4c458758e5c010e7c0c06081b5a34ce4f3105b0;hpb=848c8a4d215f9cce1db0a7d37e733b5959b8210f;p=wfpl.git
diff --git a/encode.php b/encode.php
index a4c4587..fd00b97 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,151 @@ 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