PageRenderTime 36ms CodeModel.GetById 16ms RepoModel.GetById 0ms app.codeStats 1ms

/wp-content/plugins/s2member/includes/classes/custom-reg-fields.inc.php

https://gitlab.com/Gashler/dp
PHP | 552 lines | 412 code | 63 blank | 77 comment | 129 complexity | d30472d6442bee7e7e3738dee3fc3f94 MD5 | raw file
  1. <?php
  2. /**
  3. * Custom Registration/Profile Fields for s2Member.
  4. *
  5. * Copyright: © 2009-2011
  6. * {@link http://www.websharks-inc.com/ WebSharks, Inc.}
  7. * (coded in the USA)
  8. *
  9. * Released under the terms of the GNU General Public License.
  10. * You should have received a copy of the GNU General Public License,
  11. * along with this software. In the main directory, see: /licensing/
  12. * If not, see: {@link http://www.gnu.org/licenses/}.
  13. *
  14. * @package s2Member\Custom_Reg_Fields
  15. * @since 3.5
  16. */
  17. if(realpath(__FILE__) === realpath($_SERVER["SCRIPT_FILENAME"]))
  18. exit("Do not access this file directly.");
  19. if(!class_exists("c_ws_plugin__s2member_custom_reg_fields"))
  20. {
  21. /**
  22. * Custom Registration/Profile Fields for s2Member.
  23. *
  24. * @package s2Member\Custom_Reg_Fields
  25. * @since 3.5
  26. */
  27. class c_ws_plugin__s2member_custom_reg_fields
  28. {
  29. /**
  30. * Generates all Custom Fields.
  31. *
  32. * @package s2Member\Custom_Reg_Fields
  33. * @since 3.5
  34. *
  35. * @param str $_function Function calling upon this routine.
  36. * @param array $_field The Field array of configuration options.
  37. * @param str $_name_prefix The `name=""` attribute prefix.
  38. * @param str $_id_prefix The `id=""` attribute prefix.
  39. * @param str $_classes Optional. String of space separated classes that will go inside the Field's `class=""` attribute.
  40. * @param str $_styles Optional. String of CSS styles that will go inside the Field's `style=""` attribute.
  41. * @param str|int $_tabindex. Optional numeric tabindex for the `tabindex=""` attribute.
  42. * @param str $_attrs Optional. Some additional Field attributes and values.
  43. * @param array $_submission Optional. But should be passed in with any submission data related to this Field. For instance, you might pass in ``$_POST``.
  44. * @param str|array $_value Optional. The value of this Field, either by default, or from the ``$_submission`` array.
  45. * @param str $_editable_context Optional. One of `profile|profile-view|registration`.
  46. * @return str The resulting Custom Field, in HTML format.
  47. */
  48. public static function custom_field_gen($_function = FALSE, $_field = FALSE, $_name_prefix = FALSE, $_id_prefix = FALSE, $_classes = FALSE, $_styles = FALSE, $_tabindex = FALSE, $_attrs = FALSE, $_submission = FALSE, $_value = FALSE, $_editable_context = FALSE)
  49. {
  50. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  51. do_action("ws_plugin__s2member_before_custom_field_gen", get_defined_vars());
  52. unset /* Unset defined __refs, __v. */($__refs, $__v);
  53. if(!($gen = "") && $_function && is_array($field = $_field) && !empty($field["type"]) && !empty($field["id"]) && $_name_prefix && $_id_prefix)
  54. {
  55. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  56. do_action("ws_plugin__s2member_during_custom_field_gen_before", get_defined_vars());
  57. unset /* Unset defined __refs, __v. */($__refs, $__v);
  58. $field_var = preg_replace("/[^a-z0-9]/i", "_", strtolower($field["id"]));
  59. $field_id_class = preg_replace("/_/", "-", $field_var);
  60. $name_suffix = (preg_match("/\[$/", $_name_prefix)) ? ']' : '';
  61. $field_name = trim($_name_prefix.$field_var.$name_suffix);
  62. $common = /* Common attributes. */ '';
  63. $common .= ' name="'.esc_attr($field_name).'"';
  64. $common .= ' id="'.esc_attr($_id_prefix.$field_id_class).'"';
  65. $common .= ((!empty($field["required"]) && $field["required"] === "yes") ? ' aria-required="true"' : '');
  66. $common .= ((strlen($_tabindex)) ? ' tabindex="'.esc_attr($_tabindex).'"' : /* No tabindex if empty. */ '');
  67. $common .= (( /* Certain data expected? */!empty($field["expected"])) ? ' data-expected="'.esc_attr($field["expected"]).'"' : '');
  68. $common .= (($_editable_context === "profile-view" || ($_editable_context === "profile" && !empty($field["editable"]) && strpos($field["editable"], "no") === 0)) ? ' disabled="disabled"' : '');
  69. $common .= (($_classes || !empty($field["classes"])) ? ' class="'.esc_attr(trim($_classes.((!empty($field["classes"])) ? ' '.$field["classes"] : ''))).'"' : '');
  70. $common .= (($_styles || !empty($field["styles"])) ? ' style="'.esc_attr(trim($_styles.((!empty($field["styles"])) ? ' '.$field["styles"] : ''))).'"' : '');
  71. $common .= (($_attrs || !empty($field["attrs"])) ? ' '.trim($_attrs.((!empty($field["attrs"])) ? ' '.$field["attrs"] : '')) : '');
  72. if($field["type"] === "text")
  73. {
  74. if($_editable_context === "profile-view")
  75. $gen = esc_html((string)$_value);
  76. else // Else handle normally.
  77. {
  78. $gen = '<input type="text" maxlength="100" autocomplete="off"';
  79. $gen .= ' value="'.format_to_edit((!$_submission && isset($field["deflt"]) && strlen((string)$field["deflt"])) ? (string)$field["deflt"] : (string)$_value).'"';
  80. $gen .= $common.' />';
  81. }
  82. }
  83. else if($field["type"] === "textarea")
  84. {
  85. if($_editable_context === "profile-view")
  86. $gen = nl2br(esc_html((string)$_value));
  87. else // Else handle normally.
  88. {
  89. $gen = '<textarea rows="3"'.$common.'>';
  90. $gen .= format_to_edit((!$_submission && isset($field["deflt"]) && strlen((string)$field["deflt"])) ? (string)$field["deflt"] : (string)$_value);
  91. $gen .= '</textarea>';
  92. }
  93. }
  94. else if($field["type"] === "select" && !empty($field["options"]))
  95. {
  96. if($_editable_context === "profile-view")
  97. {
  98. foreach(preg_split("/[\r\n\t]+/", $field["options"]) as $option_line)
  99. {
  100. list($option_value, $option_label, $option_default) = c_ws_plugin__s2member_utils_strings::trim_deep(preg_split("/\|/", trim($option_line)));
  101. if($option_value === (string)$_value)
  102. {
  103. $gen = $option_label;
  104. break;
  105. }
  106. }
  107. }
  108. else // Else handle normally.
  109. {
  110. $gen = '<select'.$common.'>';
  111. $selected_default_option = false;
  112. foreach(preg_split("/[\r\n\t]+/", $field["options"]) as $option_line)
  113. {
  114. list($option_value, $option_label, $option_default) = c_ws_plugin__s2member_utils_strings::trim_deep(preg_split("/\|/", trim($option_line)));
  115. $gen .= '<option value="'.esc_attr($option_value).'"'.(((($option_default && !$_submission) || ($option_value === (string)$_value && !$selected_default_option)) && ($selected_default_option = true)) ? ' selected="selected"' : '').'>'.$option_label.'</option>';
  116. }
  117. $gen .= '</select>';
  118. }
  119. }
  120. else if($field["type"] === "selects" && !empty($field["options"]))
  121. {
  122. if($_editable_context === "profile-view")
  123. {
  124. foreach(preg_split("/[\r\n\t]+/", $field["options"]) as $option_line)
  125. {
  126. list($option_value, $option_label, $option_default) = c_ws_plugin__s2member_utils_strings::trim_deep(preg_split("/\|/", trim($option_line)));
  127. if(in_array($option_value, (array)$_value))
  128. $gen .= $option_label.", ";
  129. }
  130. $gen = c_ws_plugin__s2member_utils_strings::trim($gen, 0, ",");
  131. }
  132. else // Else handle normally.
  133. {
  134. $common = preg_replace('/ name\="(.+?)"/', ' name="$1[]"', $common);
  135. $common = preg_replace('/ style\="(.+?)"/', ' style="height:auto; $1"', $common);
  136. $gen = '<select multiple="multiple" size="3"'.$common.'>';
  137. foreach(preg_split("/[\r\n\t]+/", $field["options"]) as $option_line)
  138. {
  139. list($option_value, $option_label, $option_default) = c_ws_plugin__s2member_utils_strings::trim_deep(preg_split("/\|/", trim($option_line)));
  140. $gen .= '<option value="'.esc_attr($option_value).'"'.((($option_default && !$_submission) || in_array($option_value, (array)$_value)) ? ' selected="selected"' : '').'>'.$option_label.'</option>';
  141. }
  142. $gen .= '</select>';
  143. }
  144. }
  145. else if($field["type"] === "checkbox" && !empty($field["label"]))
  146. {
  147. if($_editable_context === "profile-view")
  148. $gen = ((string)$_value) ? "yes" : "no";
  149. else // Else handle normally.
  150. {
  151. $gen = '<input type="checkbox" value="1"';
  152. $gen .= (((string)$_value) ? ' checked="checked"' : '');
  153. $gen .= $common.' /><label for="'.esc_attr($_id_prefix.$field_id_class).'" style="display:inline !important; margin:0 !important;">'.$field["label"].'</label>';
  154. }
  155. }
  156. else if($field["type"] === "pre_checkbox" && !empty($field["label"]))
  157. {
  158. if($_editable_context === "profile-view")
  159. $gen = ((string)$_value) ? "yes" : "no";
  160. else // Else handle normally.
  161. {
  162. $gen = '<input type="checkbox" value="1"';
  163. $gen .= ((!$_submission || (string)$_value) ? ' checked="checked"' : '');
  164. $gen .= $common.' /><label for="'.esc_attr($_id_prefix.$field_id_class).'" style="display:inline !important; margin:0 !important;">'.$field["label"].'</label>';
  165. }
  166. }
  167. else if($field["type"] === "checkboxes" && !empty($field["options"]))
  168. {
  169. if($_editable_context === "profile-view")
  170. {
  171. foreach(preg_split("/[\r\n\t]+/", $field["options"]) as $i => $option_line)
  172. {
  173. list($option_value, $option_label, $option_default) = c_ws_plugin__s2member_utils_strings::trim_deep(preg_split("/\|/", trim($option_line)));
  174. if(in_array($option_value, (array)$_value))
  175. $gen .= $option_label.", ";
  176. }
  177. $gen = c_ws_plugin__s2member_utils_strings::trim($gen, 0, ",");
  178. }
  179. else // Else handle normally.
  180. {
  181. $common = preg_replace('/ name\="(.+?)"/', ' name="$1[]"', $common);
  182. $sep = apply_filters("ws_plugin__s2member_custom_field_gen_checkboxes_sep", "&nbsp;&nbsp;", get_defined_vars());
  183. $opl = apply_filters("ws_plugin__s2member_custom_field_gen_checkboxes_opl", "ws-plugin--s2member-custom-reg-field-op-l", get_defined_vars());
  184. foreach(preg_split("/[\r\n\t]+/", $field["options"]) as $i => $option_line)
  185. {
  186. $common_i = preg_replace('/ id\="(.+?)"/', ' id="$1---'.($i).'"', $common);
  187. list($option_value, $option_label, $option_default) = c_ws_plugin__s2member_utils_strings::trim_deep(preg_split("/\|/", trim($option_line)));
  188. $gen .= ($i > 0) ? $sep : ''; // Separators can be filtered above.
  189. $gen .= '<input type="checkbox" value="'.esc_attr($option_value).'"';
  190. $gen .= ((($option_default && !$_submission) || in_array($option_value, (array)$_value)) ? ' checked="checked"' : '');
  191. $gen .= $common_i.' /><label for="'.esc_attr($_id_prefix.$field_id_class."-".$i).'" class="'.esc_attr($opl).'" style="display:inline !important; margin:0 !important;">'.$option_label.'</label>';
  192. }
  193. }
  194. }
  195. else if($field["type"] === "radios" && !empty($field["options"]))
  196. {
  197. if($_editable_context === "profile-view")
  198. {
  199. foreach(preg_split("/[\r\n\t]+/", $field["options"]) as $i => $option_line)
  200. {
  201. list($option_value, $option_label, $option_default) = c_ws_plugin__s2member_utils_strings::trim_deep(preg_split("/\|/", trim($option_line)));
  202. if($option_value === (string)$_value)
  203. {
  204. $gen = $option_label;
  205. break;
  206. }
  207. }
  208. }
  209. else // Else handle normally.
  210. {
  211. $sep = apply_filters("ws_plugin__s2member_custom_field_gen_radios_sep", "&nbsp;&nbsp;", get_defined_vars());
  212. $opl = apply_filters("ws_plugin__s2member_custom_field_gen_radios_opl", "ws-plugin--s2member-custom-reg-field-op-l", get_defined_vars());
  213. foreach(preg_split("/[\r\n\t]+/", $field["options"]) as $i => $option_line)
  214. {
  215. $common_i = preg_replace('/ id\="(.+?)"/', ' id="$1---'.($i).'"', $common);
  216. list($option_value, $option_label, $option_default) = c_ws_plugin__s2member_utils_strings::trim_deep(preg_split("/\|/", trim($option_line)));
  217. $gen .= ($i > 0) ? $sep : ''; // Separators can be filtered above.
  218. $gen .= '<input type="radio" value="'.esc_attr($option_value).'"';
  219. $gen .= ((($option_default && !$_submission) || $option_value === (string)$_value) ? ' checked="checked"' : '');
  220. $gen .= $common_i.' /><label for="'.esc_attr($_id_prefix.$field_id_class."-".$i).'" class="'.esc_attr($opl).'" style="display:inline !important; margin:0 !important;">'.$option_label.'</label>';
  221. }
  222. }
  223. }
  224. else // Default to a text field input type when nothing matches.
  225. {
  226. if($_editable_context === "profile-view")
  227. $gen = esc_html((string)$_value);
  228. else // Else handle normally.
  229. {
  230. $gen = '<input type="text" maxlength="100" autocomplete="off"';
  231. $gen .= ' value="'.format_to_edit((!$_submission && isset($field["deflt"]) && strlen((string)$field["deflt"])) ? (string)$field["deflt"] : (string)$_value).'"';
  232. $gen .= $common.' />';
  233. }
  234. }
  235. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  236. do_action("ws_plugin__s2member_during_custom_field_gen_after", get_defined_vars());
  237. unset /* Unset defined __refs, __v. */($__refs, $__v);
  238. }
  239. return apply_filters("ws_plugin__s2member_custom_field_gen", $gen, get_defined_vars());
  240. }
  241. /**
  242. * Determines which Custom Fields apply to a specific Level.
  243. *
  244. * @package s2Member\Custom_Reg_Fields
  245. * @since 3.5
  246. *
  247. * @param str|int $_level Optional. Defaults to the current User's Access Level number.
  248. * You can either pass in a numeric Level number, or the string `auto-detection`.
  249. * @param str $_editable_context Optional. One of `profile|profile-view|registration`.
  250. * @return array Array of Custom Field IDs applicable.
  251. */
  252. public static function custom_fields_configured_at_level($_level = "auto-detection", $_editable_context = FALSE)
  253. {
  254. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  255. do_action("ws_plugin__s2member_before_custom_fields_configured_at_level", get_defined_vars());
  256. unset /* Unset defined __refs, __v. */($__refs, $__v);
  257. $level = ($_level === "auto-detection") ? c_ws_plugin__s2member_user_access::user_access_level() : $_level;
  258. if($_level === "auto-detection" && $level < 0 && ($reg_cookies = c_ws_plugin__s2member_register_access::reg_cookies_ok()) && extract($reg_cookies) && preg_match($GLOBALS["WS_PLUGIN__"]["s2member"]["c"]["membership_item_number_w_level_regex"], $item_number, $m) && !empty($m[1]) && is_numeric($m[1]))
  259. $level = /* A numeric Membership Level # . */ $m[1];
  260. $level = ($level !== "any" && (!is_numeric($level) || $level < 0)) ? 0 : /* Default. */ $level;
  261. if(($level === "any" || (is_numeric($level) && $level >= 0)) && $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_fields"])
  262. {
  263. foreach(json_decode($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_fields"], true) as $field)
  264. if($level === "any" || $field["levels"] === "all" || in_array($level, preg_split("/[;,]+/", preg_replace("/[^0-9;,]/", "", $field["levels"]))))
  265. if(empty($_editable_context) || $_editable_context === "administrative" || ($_editable_context === "registration" && $field["editable"] !== "no-always-invisible" && $field["editable"] !== "yes-invisible") || (($_editable_context === "profile" || $_editable_context === "profile-view") && $field["editable"] !== "no-invisible" && $field["editable"] !== "no-always-invisible"))
  266. $configured[] = /* Add this to the array. */ $field["id"];
  267. }
  268. return apply_filters("ws_plugin__s2member_custom_fields_configured_at_level", ((!empty($configured)) ? $configured : array()), get_defined_vars());
  269. }
  270. /**
  271. * Adds Custom Fields to: `/wp-signup.php`.
  272. *
  273. * For Multisite Blog Farms.
  274. *
  275. * @package s2Member\Custom_Reg_Fields
  276. * @since 3.5
  277. *
  278. * @attaches-to ``add_action("signup_extra_fields");``
  279. *
  280. * @return null
  281. *
  282. * @todo Optimize with ``empty()``.
  283. */
  284. public static function ms_custom_registration_fields()
  285. {
  286. do_action("ws_plugin__s2member_before_ms_custom_registration_fields", get_defined_vars());
  287. if /* Must be Main Site of a Network. */(is_multisite() && is_main_site())
  288. {
  289. $_p = (!empty($_POST)) ? c_ws_plugin__s2member_utils_strings::trim_deep(stripslashes_deep($_POST)) : array();
  290. echo '<input type="hidden" name="ws_plugin__s2member_registration" value="'.esc_attr(wp_create_nonce("ws-plugin--s2member-registration")).'" />'."\n";
  291. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  292. do_action("ws_plugin__s2member_during_ms_custom_registration_fields_before", get_defined_vars());
  293. unset /* Unset defined __refs, __v. */($__refs, $__v);
  294. if($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_names"])
  295. {
  296. echo '<div class="ws-plugin--s2member-custom-reg-field-divider-section"></div>'."\n";
  297. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  298. do_action("ws_plugin__s2member_during_ms_custom_registration_fields_before_first_name", get_defined_vars());
  299. unset /* Unset defined __refs, __v. */($__refs, $__v);
  300. echo '<label for="ws-plugin--s2member-custom-reg-field-first-name">'._x("First Name", "s2member-front", "s2member").' *</label>'."\n";
  301. echo '<input type="text" aria-required="true" maxlength="100" autocomplete="off" name="ws_plugin__s2member_custom_reg_field_first_name" id="ws-plugin--s2member-custom-reg-field-first-name" class="ws-plugin--s2member-custom-reg-field" value="'.esc_attr($_p["ws_plugin__s2member_custom_reg_field_first_name"]).'" />'."\n";
  302. echo '<br />'."\n";
  303. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  304. do_action("ws_plugin__s2member_during_ms_custom_registration_fields_after_first_name", get_defined_vars());
  305. unset /* Unset defined __refs, __v. */($__refs, $__v);
  306. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  307. do_action("ws_plugin__s2member_during_ms_custom_registration_fields_before_last_name", get_defined_vars());
  308. unset /* Unset defined __refs, __v. */($__refs, $__v);
  309. echo '<label for="ws-plugin--s2member-custom-reg-field-last-name">'._x("Last Name", "s2member-front", "s2member").' *</label>'."\n";
  310. echo '<input type="text" aria-required="true" maxlength="100" autocomplete="off" name="ws_plugin__s2member_custom_reg_field_last_name" id="ws-plugin--s2member-custom-reg-field-last-name" class="ws-plugin--s2member-custom-reg-field" value="'.esc_attr($_p["ws_plugin__s2member_custom_reg_field_last_name"]).'" />'."\n";
  311. echo '<br />'."\n";
  312. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  313. do_action("ws_plugin__s2member_during_ms_custom_registration_fields_after_last_name", get_defined_vars());
  314. unset /* Unset defined __refs, __v. */($__refs, $__v);
  315. }
  316. if($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_fields"])
  317. if($fields_applicable = c_ws_plugin__s2member_custom_reg_fields::custom_fields_configured_at_level("auto-detection", "registration"))
  318. foreach(json_decode($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_fields"], true) as $field)
  319. {
  320. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  321. do_action("ws_plugin__s2member_during_ms_custom_registration_fields_before_custom_fields", get_defined_vars());
  322. unset /* Unset defined __refs, __v. */($__refs, $__v);
  323. if /* Field applicable? */(in_array($field["id"], $fields_applicable))
  324. {
  325. $field_var = preg_replace("/[^a-z0-9]/i", "_", strtolower($field["id"]));
  326. $field_id_class = preg_replace("/_/", "-", $field_var);
  327. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  328. if(apply_filters("ws_plugin__s2member_during_ms_custom_registration_fields_during_custom_fields_display", true, get_defined_vars()))
  329. {
  330. if /* Starts a new section? */(!empty($field["section"]) && $field["section"] === "yes")
  331. echo '<div class="ws-plugin--s2member-custom-reg-field-divider-section'.((!empty($field["sectitle"])) ? '-title' : '').'">'.((!empty($field["sectitle"])) ? $field["sectitle"] : '').'</div>';
  332. echo '<label for="ws-plugin--s2member-custom-reg-field-'.esc_attr($field_id_class).'"'.((preg_match("/^(checkbox|pre_checkbox)$/", $field["type"])) ? ' style="display:none;"' : '').'>'.$field["label"].(($field["required"] === "yes") ? ' *' : '').'</label>'.((preg_match("/^(checkbox|pre_checkbox)$/", $field["type"])) ? '<br />' : '')."\n";
  333. echo c_ws_plugin__s2member_custom_reg_fields::custom_field_gen(__FUNCTION__, $field, "ws_plugin__s2member_custom_reg_field_", "ws-plugin--s2member-custom-reg-field-", "ws-plugin--s2member-custom-reg-field", "", "", "", $_p, $_p["ws_plugin__s2member_custom_reg_field_".$field_var], "registration");
  334. echo '<br />'."\n";
  335. }
  336. unset /* Unset defined __refs, __v. */($__refs, $__v);
  337. }
  338. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  339. do_action("ws_plugin__s2member_during_ms_custom_registration_fields_after_custom_fields", get_defined_vars());
  340. unset /* Unset defined __refs, __v. */($__refs, $__v);
  341. }
  342. if($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_opt_in"] && c_ws_plugin__s2member_list_servers::list_servers_integrated())
  343. {
  344. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  345. do_action("ws_plugin__s2member_during_ms_custom_registration_fields_before_opt_in", get_defined_vars());
  346. unset /* Unset defined __refs, __v. */($__refs, $__v);
  347. echo '<label for="ws-plugin--s2member-custom-reg-field-opt-in">'."\n";
  348. echo '<input type="checkbox" name="ws_plugin__s2member_custom_reg_field_opt_in" id="ws-plugin--s2member-custom-reg-field-opt-in" class="ws-plugin--s2member-custom-reg-field" value="1"'.(((empty($_p) && $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_opt_in"] == 1) || $_p["ws_plugin__s2member_custom_reg_field_opt_in"]) ? ' checked="checked"' : '').' />'."\n";
  349. echo $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_opt_in_label"]."\n";
  350. echo '</label>'."\n";
  351. echo '<br />'."\n";
  352. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  353. do_action("ws_plugin__s2member_during_ms_custom_registration_fields_after_opt_in", get_defined_vars());
  354. unset /* Unset defined __refs, __v. */($__refs, $__v);
  355. }
  356. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  357. do_action("ws_plugin__s2member_during_ms_custom_registration_fields_after", get_defined_vars());
  358. unset /* Unset defined __refs, __v. */($__refs, $__v);
  359. }
  360. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  361. do_action("ws_plugin__s2member_after_ms_custom_registration_fields", get_defined_vars());
  362. unset /* Unset defined __refs, __v. */($__refs, $__v);
  363. return /* Return for uniformity. */;
  364. }
  365. /**
  366. * Adds Custom Fields to: `/wp-login.php?action=register`.
  367. *
  368. * @package s2Member\Custom_Reg_Fields
  369. * @since 3.5
  370. *
  371. * @attaches-to ``add_action("register_form");``
  372. *
  373. * @return null
  374. *
  375. * @todo Optimize with ``empty()``.
  376. */
  377. public static function custom_registration_fields()
  378. {
  379. do_action("ws_plugin__s2member_before_custom_registration_fields", get_defined_vars());
  380. $_p = (!empty($_POST)) ? c_ws_plugin__s2member_utils_strings::trim_deep(stripslashes_deep($_POST)) : array();
  381. echo '<input type="hidden" name="ws_plugin__s2member_registration" value="'.esc_attr(wp_create_nonce("ws-plugin--s2member-registration")).'" />'."\n";
  382. $tabindex = /* Incremented tabindex starting with 20. */ 20;
  383. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  384. do_action("ws_plugin__s2member_during_custom_registration_fields_before", get_defined_vars());
  385. unset /* Unset defined __refs, __v. */($__refs, $__v);
  386. if($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_password"])
  387. {
  388. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  389. do_action("ws_plugin__s2member_during_custom_registration_fields_before_user_pass", get_defined_vars());
  390. unset /* Unset defined __refs, __v. */($__refs, $__v);
  391. echo '<p>'."\n";
  392. echo '<label for="ws-plugin--s2member-custom-reg-field-user-pass1" title="'.esc_attr(_x("Please type your Password twice to confirm.", "s2member-front", "s2member")).'">'."\n";
  393. echo '<span>'._x("Password (please type it twice)", "s2member-front", "s2member").' *</span><br />'."\n";
  394. echo '<input type="password" aria-required="true" maxlength="100" autocomplete="off" name="ws_plugin__s2member_custom_reg_field_user_pass1" id="ws-plugin--s2member-custom-reg-field-user-pass1" class="ws-plugin--s2member-custom-reg-field" value="'.format_to_edit($_p["ws_plugin__s2member_custom_reg_field_user_pass1"]).'" tabindex="'.esc_attr(($tabindex = $tabindex + 10)).'" />'."\n";
  395. echo '</label>'."\n";
  396. echo '<label for="ws-plugin--s2member-custom-reg-field-user-pass2" title="'.esc_attr(_x("Please type your Password twice to confirm.", "s2member-front", "s2member")).'">'."\n";
  397. echo '<input type="password" maxlength="100" autocomplete="off" name="ws_plugin__s2member_custom_reg_field_user_pass2" id="ws-plugin--s2member-custom-reg-field-user-pass2" class="ws-plugin--s2member-custom-reg-field" value="'.format_to_edit($_p["ws_plugin__s2member_custom_reg_field_user_pass2"]).'" tabindex="'.esc_attr(($tabindex = $tabindex + 10)).'" />'."\n";
  398. echo '</label>'."\n";
  399. echo '<div id="ws-plugin--s2member-custom-reg-field-user-pass-strength" class="ws-plugin--s2member-password-strength"><em>'._x("password strength indicator", "s2member-front", "s2member").'</em></div>'."\n";
  400. echo '</p>'."\n";
  401. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  402. do_action("ws_plugin__s2member_during_custom_registration_fields_after_user_pass", get_defined_vars());
  403. unset /* Unset defined __refs, __v. */($__refs, $__v);
  404. }
  405. if($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_names"])
  406. {
  407. echo '<div class="ws-plugin--s2member-custom-reg-field-divider-section"></div>'."\n";
  408. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  409. do_action("ws_plugin__s2member_during_custom_registration_fields_before_first_name", get_defined_vars());
  410. unset /* Unset defined __refs, __v. */($__refs, $__v);
  411. echo '<p>'."\n";
  412. echo '<label for="ws-plugin--s2member-custom-reg-field-first-name">'."\n";
  413. echo '<span>'._x("First Name", "s2member-front", "s2member").' *</span><br />'."\n";
  414. echo '<input type="text" aria-required="true" maxlength="100" autocomplete="off" name="ws_plugin__s2member_custom_reg_field_first_name" id="ws-plugin--s2member-custom-reg-field-first-name" class="ws-plugin--s2member-custom-reg-field" value="'.esc_attr($_p["ws_plugin__s2member_custom_reg_field_first_name"]).'" tabindex="'.esc_attr(($tabindex = $tabindex + 10)).'" />'."\n";
  415. echo '</label>'."\n";
  416. echo '</p>'."\n";
  417. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  418. do_action("ws_plugin__s2member_during_custom_registration_fields_after_first_name", get_defined_vars());
  419. unset /* Unset defined __refs, __v. */($__refs, $__v);
  420. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  421. do_action("ws_plugin__s2member_during_custom_registration_fields_before_last_name", get_defined_vars());
  422. unset /* Unset defined __refs, __v. */($__refs, $__v);
  423. echo '<p>'."\n";
  424. echo '<label for="ws-plugin--s2member-custom-reg-field-last-name">'."\n";
  425. echo '<span>'._x("Last Name", "s2member-front", "s2member").' *</span><br />'."\n";
  426. echo '<input type="text" aria-required="true" maxlength="100" autocomplete="off" name="ws_plugin__s2member_custom_reg_field_last_name" id="ws-plugin--s2member-custom-reg-field-last-name" class="ws-plugin--s2member-custom-reg-field" value="'.esc_attr($_p["ws_plugin__s2member_custom_reg_field_last_name"]).'" tabindex="'.esc_attr(($tabindex = $tabindex + 10)).'" />'."\n";
  427. echo '</label>'."\n";
  428. echo '</p>'."\n";
  429. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  430. do_action("ws_plugin__s2member_during_custom_registration_fields_after_last_name", get_defined_vars());
  431. unset /* Unset defined __refs, __v. */($__refs, $__v);
  432. }
  433. if($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_fields"])
  434. if($fields_applicable = c_ws_plugin__s2member_custom_reg_fields::custom_fields_configured_at_level("auto-detection", "registration"))
  435. {
  436. $tabindex = /* Start tabindex at +9 ( +1 below ). */ $tabindex + 9;
  437. foreach(json_decode($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_fields"], true) as $field)
  438. {
  439. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  440. do_action("ws_plugin__s2member_during_custom_registration_fields_before_custom_fields", get_defined_vars());
  441. unset /* Unset defined __refs, __v. */($__refs, $__v);
  442. if /* Field applicable? */(in_array($field["id"], $fields_applicable))
  443. {
  444. $field_var = preg_replace("/[^a-z0-9]/i", "_", strtolower($field["id"]));
  445. $field_id_class = preg_replace("/_/", "-", $field_var);
  446. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  447. if(apply_filters("ws_plugin__s2member_during_custom_registration_fields_during_custom_fields_display", true, get_defined_vars()))
  448. {
  449. if /* Starts a new section? */(!empty($field["section"]) && $field["section"] === "yes")
  450. echo '<div class="ws-plugin--s2member-custom-reg-field-divider-section'.((!empty($field["sectitle"])) ? '-title' : '').'">'.((!empty($field["sectitle"])) ? $field["sectitle"] : '').'</div>';
  451. echo '<p>'."\n";
  452. echo '<label for="ws-plugin--s2member-custom-reg-field-'.esc_attr($field_id_class).'">'."\n";
  453. echo '<span'.((preg_match("/^(checkbox|pre_checkbox)$/", $field["type"])) ? ' style="display:none;"' : '').'>'.$field["label"].(($field["required"] === "yes") ? ' *' : '').'</span></label>'.((preg_match("/^(checkbox|pre_checkbox)$/", $field["type"])) ? '' : '<br />')."\n";
  454. echo c_ws_plugin__s2member_custom_reg_fields::custom_field_gen(__FUNCTION__, $field, "ws_plugin__s2member_custom_reg_field_", "ws-plugin--s2member-custom-reg-field-", "ws-plugin--s2member-custom-reg-field", "", ($tabindex = $tabindex + 1), "", $_p, $_p["ws_plugin__s2member_custom_reg_field_".$field_var], "registration");
  455. echo '</p>'."\n";
  456. }
  457. unset /* Unset defined __refs, __v. */($__refs, $__v);
  458. }
  459. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  460. do_action("ws_plugin__s2member_during_custom_registration_fields_after_custom_fields", get_defined_vars());
  461. unset /* Unset defined __refs, __v. */($__refs, $__v);
  462. }
  463. }
  464. if($GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_opt_in"] && c_ws_plugin__s2member_list_servers::list_servers_integrated())
  465. {
  466. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  467. do_action("ws_plugin__s2member_during_custom_registration_fields_before_opt_in", get_defined_vars());
  468. unset /* Unset defined __refs, __v. */($__refs, $__v);
  469. echo '<p>'."\n";
  470. echo '<label for="ws-plugin--s2member-custom-reg-field-opt-in">'."\n";
  471. echo '<input type="checkbox" name="ws_plugin__s2member_custom_reg_field_opt_in" id="ws-plugin--s2member-custom-reg-field-opt-in" class="ws-plugin--s2member-custom-reg-field" value="1"'.(((empty($_p) && $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_opt_in"] == 1) || $_p["ws_plugin__s2member_custom_reg_field_opt_in"]) ? ' checked="checked"' : '').' tabindex="'.esc_attr(($tabindex = $tabindex + 10)).'" />'."\n";
  472. echo $GLOBALS["WS_PLUGIN__"]["s2member"]["o"]["custom_reg_opt_in_label"]."\n";
  473. echo '</label>'."\n";
  474. echo '</p>'."\n";
  475. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  476. do_action("ws_plugin__s2member_during_custom_registration_fields_after_opt_in", get_defined_vars());
  477. unset /* Unset defined __refs, __v. */($__refs, $__v);
  478. }
  479. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  480. do_action("ws_plugin__s2member_during_custom_registration_fields_after", get_defined_vars());
  481. unset /* Unset defined __refs, __v. */($__refs, $__v);
  482. foreach(array_keys(get_defined_vars())as$__v)$__refs[$__v]=&$$__v;
  483. do_action("ws_plugin__s2member_after_custom_registration_fields", get_defined_vars());
  484. unset /* Unset defined __refs, __v. */($__refs, $__v);
  485. return /* Return for uniformity. */;
  486. }
  487. }
  488. }
  489. ?>