3 # Copyright (C) 2005 Jason Woofenden
5 # This file is part of wfpl.
7 # wfpl is free software; you can redistribute it and/or modify it under the
8 # terms of the GNU Lesser General Public License as published by the Free
9 # Software Foundation; either version 2.1 of the License, or (at your option)
12 # wfpl is distributed in the hope that it will be useful, but WITHOUT ANY
13 # WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14 # FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
17 # You should have received a copy of the GNU Lesser General Public License
18 # along with wfpl; if not, write to the Free Software Foundation, Inc., 51
19 # Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22 # This file contains basic encodings. These are used by the encoder. You can
23 # specify any template tag to be encoded with this syntax: ~variable.encoding~
25 # this example: <p>~foo.html~</p>
26 # will encode foo (using enc_html()) before displaying it, so that characters
27 # such as < will display properly.
30 function enc_jsdq($str) {
32 $str = str_replace("\n", "\\n", $str);
33 return str_replace("\r", "\\r", $str);
36 # encode for putting within double-quotes in SQL
37 function enc_sql($str) {
38 $str = str_replace("\\", "\\\\", $str);
39 $str = str_replace('"', "\\\"", $str);
43 # Encode for output in html. does nothing with whitespace
45 # Example: <p>~foo.html~</p>
46 function enc_html($str) {
47 $str = str_replace('&', '&', $str);
48 $str = str_replace('<', '<', $str);
49 $str = str_replace('>', '>', $str);
53 # Encode for output in html. Convert newlines to <br />
55 # Example: <p>~foo.html~</p>
56 function enc_htmlbr($str) {
57 $str = enc_html($str);
58 $str = str_replace("\n", "<br />\n", $str);
62 # Encode for output in html. Spaces converted to
64 # Example: <option value="12">~foo.htmlnbsp~</option>
65 function enc_htmlnbsp($str) {
66 $str = enc_html($str);
67 $str = str_replace(' ', ' ', $str);
74 # Example: <input name="foo" value="~foo.attr~">
75 function enc_attr($str) {
76 $str = str_replace('&', '&', $str);
77 $str = str_replace('"', '"', $str);
83 # Example: <a href="http://example.com?foo=~foo.url_val.attr~">http://example.com?foo=~foo.url_val~</a>
84 function enc_url_val($str) {
85 return rawurlencode($str);
89 function enc_url_path($str) {
90 $str = rawurlencode($str);
91 $str = str_replace('%2F', '/', $str);
96 # This is a hack to work around html's stupid syntax for checkboxes.
98 # Place the template marker just before a " somewhere.
100 # Example: <input type="checkbox" name="foo~foo.checked~">
101 function enc_checked($str) {
103 return '" checked="checked';
109 # add a tab at the begining of each non-empty line
110 function enc_tab($str) {
111 $lines = explode("\n", $str);
113 foreach($lines as $line) {
120 # remove the extra newline added above
121 return substr($out, 0, -1);
124 function enc_upper($str) {
125 return strtoupper($str);
128 # pass date in the form 2008-05-23
129 # ercodes date as 05/23/2008
130 function enc_mmddyyyy($yyyy_mm_dd) {
131 if(strlen($yyyy_mm_dd) != 10) {
132 return date('m/d/Y');
134 return substr($yyyy_mm_dd, 5, 2) . '/' . substr($yyyy_mm_dd, 8, 2) . '/' . substr($yyyy_mm_dd, 0, 4);
137 function enc_mmddyyyyhhmm($seconds) {
138 return date('m/d/Y g:ia', (int)$seconds);
144 define('PULLDOWN_ARRAY', 0); define('PULLDOWN_HASH', 1); define('PULLDOWN_2D', 2);
146 function pulldown_options_to_2d($options, $keys_from) {
147 # convert other types of input to value=>display hash
150 $new_options = array();
151 foreach($options as $value => $display) {
152 $new_options[] = array($value, $display);
156 $new_options = array();
157 foreach($options as $opt) {
158 $new_options[] = array($opt, $opt);
166 die('pulldown_options_to_2d(): unknown value: "' . print_r($keys_from) . '" passed in $keys_from parameter');
171 # call this function before you run() the template so enc_options() knows what
176 # name: the name of the html control
178 # options: an array of options to display in the pulldown/selectbox
180 # keys_from: Set to one of:
181 # PULLDOWN_ARRAY: (default) values of $options are displayd and posted
182 # PULLDOWN_HASH: values of $options are display, keys are posted
183 # PULLDOWN_2D: $options is a 2 dimensional array.
184 # $options[0][1] is displayed, $options[0][0] is posted.
185 # $options[1][1] is displayed, $options[1][0] is posted.
187 # multiple: UNTESTED set to true for multiple-select boxes.
189 function pulldown($name, $options, $keys_from = PULLDOWN_ARRAY, $multiple = false) {
190 $options = pulldown_options_to_2d($options, $keys_from);
191 $GLOBALS[$name . '_options'] = array();
192 $GLOBALS[$name . '_options']['options'] = $options;
193 $GLOBALS[$name . '_options']['multiple'] = $multiple;
196 # output a bunch of <option> tags
197 function enc_options($values, $name) {
198 if(!isset($GLOBALS[$name . '_options'])) {
199 die('pulldown() must be called before this template can be run. See code/wfpl/encode.php');
201 if($GLOBALS[$name . '_options']['multiple']) { # FIXME test this
202 $values = explode(', ', $values);
204 return encode_options($values, $GLOBALS[$name . '_options']['options'], PULLDOWN_2D);
207 # use this function along with a special template to generate the html for pulldowns and multiple select boxes.
211 # selected: can be a string or (for multiple-selects) an array
213 # options, keys_from: see documentation for pulldown() above
214 function encode_options($selected, $options, $keys_from) {
215 if(!is_array($selected)) {
216 $selected = array($selected);
219 if($keys_from != PULLDOWN_2D) {
220 $options = pulldown_options_to_2d($options, $keys_from);
224 foreach($options as $valdisp) {
225 list($value, $display) = $valdisp;
228 if(in_array($value, $selected)) {
229 $out .= ' selected="selected"';
232 if($value !== $display) {
234 $out .= enc_attr($value);
240 $out .= enc_htmlnbsp($display);
242 $out .= "</option>\n";
248 $GLOBALS['wfpl_states_assoc'] = array("AL" => "Alabama", "AK" => "Alaska", "AZ" => "Arizona", "AR" => "Arkansas", "CA" => "California", "CO" => "Colorado", "CT" => "Connecticut", "DE" => "Delaware", "FL" => "Florida", "GA" => "Georgia", "HI" => "Hawaii", "ID" => "Idaho", "IL" => "Illinois", "IN" => "Indiana", "IA" => "Iowa", "KS" => "Kansas", "KY" => "Kentucky", "LA" => "Louisiana", "ME" => "Maine", "MD" => "Maryland", "MA" => "Massachusetts", "MI" => "Michigan", "MN" => "Minnesota", "MS" => "Mississippi", "MO" => "Missouri", "MT" => "Montana", "NE" => "Nebraska", "NV" => "Nevada", "NH" => "New Hampshire", "NJ" => "New Jersey", "NM" => "New Mexico", "NY" => "New York", "NC" => "North Carolina", "ND" => "North Dakota", "OH" => "Ohio", "OK" => "Oklahoma", "OR" => "Oregon", "PA" => "Pennsylvania", "RI" => "Rhode Island", "SC" => "South Carolina", "SD" => "South Dakota", "TN" => "Tennessee", "TX" => "Texas", "UT" => "Utah", "VT" => "Vermont", "VA" => "Virginia", "WA" => "Washington", "DC" => "Washington, DC", "WV" => "West Virginia", "WI" => "Wisconsin", "WY" => "Wyoming");
251 function enc_states($str) {
254 return encode_options($str, $GLOBALS['wfpl_states_assoc'], PULLDOWN_HASH);
257 $GLOBALS['wfpl_provinces_assoc'] = array("AB" => "Alberta", "BC" => "British Columbia", "MB" => "Manitoba", "NF" => "Newfoundland", "NB" => "New Brunswick", "NS" => "Nova Scotia", "NT" => "Northwest Territories", "NU" => "Nunavut", "ON" => "Ontario", "PE" => "Prince Edward Island", "QC" => "Quebec", "SK" => "Saskatchewan", "YT" => "Yukon Territory");
260 function enc_provinces($str) {
263 return encode_options($str, $GLOBALS['wfpl_provinces_assoc'], PULLDOWN_HASH);
266 # returns "odd", then "even", then "odd" etc.
267 function enc_evenodd($values, $name) {
268 if(!isset($GLOBALS['wfpl_even_odds'])) {
269 $GLOBALS['wfpl_even_odds'] = array();
272 if($GLOBALS['wfpl_even_odds'][$name]) {
273 $GLOBALS['wfpl_even_odds'][$name] = false;
276 $GLOBALS['wfpl_even_odds'][$name] = true;