X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=encode.php;h=94e88d7237a08a367cece6499020563e9b829cd3;hb=80e481467af047ea61c31edc3527cb8cbf9894a5;hp=ab2c2715ad1767dec0f157de69043ebd56e7465b;hpb=409b78be52f7a934a0cbfe0d927b7e0b42d60ec4;p=wfpl.git
diff --git a/encode.php b/encode.php
index ab2c271..94e88d7 100644
--- a/encode.php
+++ b/encode.php
@@ -2,21 +2,18 @@
# Copyright (C) 2005 Jason Woofenden
#
-# This file is part of wfpl.
-#
-# wfpl is free software; you can redistribute it and/or modify it under the
-# terms of the GNU Lesser General Public License as published by the Free
-# Software Foundation; either version 2.1 of the License, or (at your option)
-# any later version.
-#
-# wfpl is distributed in the hope that it will be useful, but WITHOUT ANY
-# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
-# FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
-# more details.
-#
-# You should have received a copy of the GNU Lesser General Public License
-# along with wfpl; if not, write to the Free Software Foundation, Inc., 51
-# Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see
+#
+# Example:
~foo.htmlbr~
+function enc_htmlbr($str) { + $str = enc_html($str); + $str = str_replace("\n", "~foo.htmlbrtab~
+function enc_htmlbrtab($str) { + $str = enc_htmlbr($str); + $space_to_nbsp = create_function('$matches', 'return str_repeat(\' \', strlen($matches[0]) * 2);'); + $str = preg_replace_callback("|^ *|m", $space_to_nbsp, $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,19 +97,39 @@ 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. # # Example: function enc_checked($str) { - if($str == 'Yes') { + if($str && $str !== 'No' && $str !== 'False' && $str !== 'false') { return '" checked="checked'; } else { return ''; } } +# checkboxe values are stored in the db and handled in php as 0 or 1. When you +# want it displayed as "Yes" or "No" use this: +# Example: (displaying values from a form submission) Over 60?: ~over_60.yesno~ +function enc_yesno($str) { + if($str && $str !== 'No' && $str !== 'False' && $str !== 'false') { + return 'Yes'; + } else { + return 'No'; + } +} + + # add a tab at the begining of each non-empty line function enc_tab($str) { $lines = explode("\n", $str); @@ -89,4 +145,164 @@ function enc_tab($str) { return substr($out, 0, -1); } +function enc_upper($str) { + return strtoupper($str); +} + +# pass date in the form 2008-05-23 +# ercodes date as 05/23/2008 +function enc_mmddyyyy($yyyy_mm_dd) { + if($yyyy_mm_dd == '') { + return ''; + } + if(strlen($yyyy_mm_dd) != 10) { + return date('m/d/Y'); + } + return substr($yyyy_mm_dd, 5, 2) . '/' . substr($yyyy_mm_dd, 8, 2) . '/' . substr($yyyy_mm_dd, 0, 4); +} + +function enc_mmddyyyyhhmm($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