123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813 |
- <?php
- if (!defined('SMF'))
- die('Hacking attempt...');
- function ModifyProfile($post_errors = array())
- {
- global $txt, $scripturl, $user_info, $context, $sourcedir, $user_profile, $cur_profile;
- global $modSettings, $memberContext, $profile_vars, $smcFunc, $post_errors, $options, $user_settings;
-
- if (empty($post_errors))
- loadLanguage('Profile+Drafts');
- loadTemplate('Profile');
- require_once($sourcedir . '/Subs-Menu.php');
-
- if (isset($_REQUEST['user']))
- $memberResult = loadMemberData($_REQUEST['user'], true, 'profile');
-
- elseif (!empty($_REQUEST['u']))
- $memberResult = loadMemberData((int) $_REQUEST['u'], false, 'profile');
-
- else
- $memberResult = loadMemberData($user_info['id'], false, 'profile');
-
- if (!is_array($memberResult))
- fatal_lang_error('not_a_user', false);
-
- list ($memID) = $memberResult;
- $context['id_member'] = $memID;
- $cur_profile = $user_profile[$memID];
-
- loadMemberContext($memID);
- $context['member'] = $memberContext[$memID];
-
- $context['user']['is_owner'] = $memID == $user_info['id'];
-
- $profile_areas = array(
- 'info' => array(
- 'title' => $txt['profileInfo'],
- 'areas' => array(
- 'summary' => array(
- 'label' => $txt['summary'],
- 'file' => 'Profile-View.php',
- 'function' => 'summary',
- 'permission' => array(
- 'own' => 'profile_view_own',
- 'any' => 'profile_view_any',
- ),
- ),
- 'statistics' => array(
- 'label' => $txt['statPanel'],
- 'file' => 'Profile-View.php',
- 'function' => 'statPanel',
- 'permission' => array(
- 'own' => 'profile_view_own',
- 'any' => 'profile_view_any',
- ),
- ),
- 'showposts' => array(
- 'label' => $txt['showPosts'],
- 'file' => 'Profile-View.php',
- 'function' => 'showPosts',
- 'subsections' => array(
- 'messages' => array($txt['showMessages'], array('profile_view_own', 'profile_view_any')),
- 'topics' => array($txt['showTopics'], array('profile_view_own', 'profile_view_any')),
- 'attach' => array($txt['showAttachments'], array('profile_view_own', 'profile_view_any')),
- ),
- 'permission' => array(
- 'own' => 'profile_view_own',
- 'any' => 'profile_view_any',
- ),
- ),
- 'showdrafts' => array(
- 'label' => $txt['drafts_show'],
- 'file' => 'Drafts.php',
- 'function' => 'showProfileDrafts',
- 'enabled' => !empty($modSettings['drafts_enabled']) && $context['user']['is_owner'],
- 'permission' => array(
- 'own' => 'profile_view_own',
- 'any' => array(),
- ),
- ),
- 'permissions' => array(
- 'label' => $txt['showPermissions'],
- 'file' => 'Profile-View.php',
- 'function' => 'showPermissions',
- 'permission' => array(
- 'own' => 'manage_permissions',
- 'any' => 'manage_permissions',
- ),
- ),
- 'tracking' => array(
- 'label' => $txt['trackUser'],
- 'file' => 'Profile-View.php',
- 'function' => 'tracking',
- 'subsections' => array(
- 'activity' => array($txt['trackActivity'], 'moderate_forum'),
- 'ip' => array($txt['trackIP'], 'moderate_forum'),
- 'edits' => array($txt['trackEdits'], 'moderate_forum'),
- 'logins' => array($txt['trackLogins'], array('profile_view_own', 'moderate_forum')),
- ),
- 'permission' => array(
- 'own' => 'moderate_forum',
- 'any' => 'moderate_forum',
- ),
- ),
- 'viewwarning' => array(
- 'label' => $txt['profile_view_warnings'],
- 'enabled' => in_array('w', $context['admin_features']) && $modSettings['warning_settings'][0] == 1 && $cur_profile['warning'] && (!empty($modSettings['warning_show']) && ($context['user']['is_owner'] || $modSettings['warning_show'] == 2)),
- 'file' => 'Profile-View.php',
- 'function' => 'viewWarning',
- 'permission' => array(
- 'own' => 'profile_view_own',
- 'any' => 'issue_warning',
- ),
- ),
- ),
- ),
- 'edit_profile' => array(
- 'title' => $txt['profileEdit'],
- 'areas' => array(
- 'account' => array(
- 'label' => $txt['account'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'account',
- 'enabled' => $context['user']['is_admin'] || ($cur_profile['id_group'] != 1 && !in_array(1, explode(',', $cur_profile['additional_groups']))),
- 'sc' => 'post',
- 'token' => 'profile-ac%u',
- 'password' => true,
- 'permission' => array(
- 'own' => array('profile_identity_any', 'profile_identity_own', 'manage_membergroups'),
- 'any' => array('profile_identity_any', 'manage_membergroups'),
- ),
- ),
- 'forumprofile' => array(
- 'label' => $txt['forumprofile'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'forumProfile',
- 'sc' => 'post',
- 'token' => 'profile-fp%u',
- 'permission' => array(
- 'own' => array('profile_extra_any', 'profile_extra_own', 'profile_title_own', 'profile_title_any'),
- 'any' => array('profile_extra_any', 'profile_title_any'),
- ),
- ),
- 'theme' => array(
- 'label' => $txt['theme'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'theme',
- 'sc' => 'post',
- 'token' => 'profile-th%u',
- 'permission' => array(
- 'own' => array('profile_extra_any', 'profile_extra_own'),
- 'any' => array('profile_extra_any'),
- ),
- ),
- 'authentication' => array(
- 'label' => $txt['authentication'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'authentication',
- 'enabled' => !empty($modSettings['enableOpenID']) || !empty($cur_profile['openid_uri']),
- 'sc' => 'post',
- 'token' => 'profile-au%u',
- 'hidden' => empty($modSettings['enableOpenID']) && empty($cur_profile['openid_uri']),
- 'password' => true,
- 'permission' => array(
- 'own' => array('profile_identity_any', 'profile_identity_own'),
- 'any' => array('profile_identity_any'),
- ),
- ),
- 'notification' => array(
- 'label' => $txt['notification'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'notification',
- 'sc' => 'post',
- 'token' => 'profile-nt%u',
- 'permission' => array(
- 'own' => array('profile_extra_any', 'profile_extra_own'),
- 'any' => array('profile_extra_any'),
- ),
- ),
-
- 'pmprefs' => array(
- 'label' => $txt['pmprefs'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'pmprefs',
- 'enabled' => allowedTo(array('profile_extra_own', 'profile_extra_any')),
- 'sc' => 'post',
- 'token' => 'profile-pm%u',
- 'permission' => array(
- 'own' => array('pm_read'),
- 'any' => array('profile_extra_any'),
- ),
- ),
- 'ignoreboards' => array(
- 'label' => $txt['ignoreboards'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'ignoreboards',
- 'enabled' => !empty($modSettings['allow_ignore_boards']),
- 'sc' => 'post',
- 'token' => 'profile-ib%u',
- 'permission' => array(
- 'own' => array('profile_extra_any', 'profile_extra_own'),
- 'any' => array('profile_extra_any'),
- ),
- ),
- 'lists' => array(
- 'label' => $txt['editBuddyIgnoreLists'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'editBuddyIgnoreLists',
- 'enabled' => !empty($modSettings['enable_buddylist']) && $context['user']['is_owner'],
- 'sc' => 'post',
- 'token' => 'profile-bl%u',
- 'subsections' => array(
- 'buddies' => array($txt['editBuddies']),
- 'ignore' => array($txt['editIgnoreList']),
- ),
- 'permission' => array(
- 'own' => array('profile_extra_any', 'profile_extra_own'),
- 'any' => array(),
- ),
- ),
- 'groupmembership' => array(
- 'label' => $txt['groupmembership'],
- 'file' => 'Profile-Modify.php',
- 'function' => 'groupMembership',
- 'enabled' => !empty($modSettings['show_group_membership']) && $context['user']['is_owner'],
- 'sc' => 'request',
- 'token' => 'profile-gm%u',
- 'token_type' => 'request',
- 'permission' => array(
- 'own' => array('profile_view_own'),
- 'any' => array('manage_membergroups'),
- ),
- ),
- ),
- ),
- 'profile_action' => array(
- 'title' => $txt['profileAction'],
- 'areas' => array(
- 'sendpm' => array(
- 'label' => $txt['profileSendIm'],
- 'custom_url' => $scripturl . '?action=pm;sa=send',
- 'permission' => array(
- 'own' => array(),
- 'any' => array('pm_send'),
- ),
- ),
- 'issuewarning' => array(
- 'label' => $txt['profile_issue_warning'],
- 'enabled' => in_array('w', $context['admin_features']) && $modSettings['warning_settings'][0] == 1 && (!$context['user']['is_owner'] || $context['user']['is_admin']),
- 'file' => 'Profile-Actions.php',
- 'function' => 'issueWarning',
- 'token' => 'profile-iw%u',
- 'enabled' => !$context['user']['is_owner'],
- 'permission' => array(
- 'own' => array('issue_warning'),
- 'any' => array('issue_warning'),
- ),
- ),
- 'banuser' => array(
- 'label' => $txt['profileBanUser'],
- 'custom_url' => $scripturl . '?action=admin;area=ban;sa=add',
- 'enabled' => $cur_profile['id_group'] != 1 && !in_array(1, explode(',', $cur_profile['additional_groups'])),
- 'permission' => array(
- 'own' => array(),
- 'any' => array('manage_bans'),
- ),
- ),
- 'subscriptions' => array(
- 'label' => $txt['subscriptions'],
- 'file' => 'Profile-Actions.php',
- 'function' => 'subscriptions',
- 'enabled' => !empty($modSettings['paid_enabled']),
- 'permission' => array(
- 'own' => array('profile_view_own'),
- 'any' => array('moderate_forum'),
- ),
- ),
- 'deleteaccount' => array(
- 'label' => $txt['deleteAccount'],
- 'file' => 'Profile-Actions.php',
- 'function' => 'deleteAccount',
- 'sc' => 'post',
- 'token' => 'profile-da%u',
- 'password' => true,
- 'permission' => array(
- 'own' => array('profile_remove_any', 'profile_remove_own'),
- 'any' => array('profile_remove_any'),
- ),
- ),
- 'activateaccount' => array(
- 'file' => 'Profile-Actions.php',
- 'function' => 'activateAccount',
- 'sc' => 'get',
- 'token' => 'profile-aa%u',
- 'select' => 'summary',
- 'permission' => array(
- 'own' => array(),
- 'any' => array('moderate_forum'),
- ),
- ),
- ),
- ),
- );
-
- call_integration_hook('integrate_profile_areas', array(&$profile_areas));
-
- $context['password_areas'] = array();
- $current_area = isset($_REQUEST['area']) ? $_REQUEST['area'] : '';
- foreach ($profile_areas as $section_id => $section)
- {
-
- foreach ($section['areas'] as $area_id => $area)
- {
-
- if (empty($area['permission'][$context['user']['is_owner'] ? 'own' : 'any']))
- $profile_areas[$section_id]['areas'][$area_id]['enabled'] = false;
-
- else
- $profile_areas[$section_id]['areas'][$area_id]['permission'] = $area['permission'][$context['user']['is_owner'] ? 'own' : 'any'];
-
- if (!empty($area['password']))
- $context['password_areas'][] = $area_id;
- }
- }
-
- if (isset($_GET['updated']))
- $context['profile_updated'] = $txt['profile_updated_own'];
-
- $menuOptions = array(
- 'disable_url_session_check' => true,
- 'current_area' => $current_area,
- 'extra_url_parameters' => array(
- 'u' => $context['id_member'],
- ),
- );
-
- $profile_include_data = createMenu($profile_areas, $menuOptions);
-
- if (!$profile_include_data && (!$user_info['is_guest'] || validateSession()))
- fatal_lang_error('no_access', false);
-
- $context['profile_menu_id'] = $context['max_menu_id'];
- $context['profile_menu_name'] = 'menu_data_' . $context['profile_menu_id'];
-
- $current_area = $profile_include_data['current_area'];
- $context['menu_item_selected'] = $current_area;
-
- $context['completed_save'] = false;
- $context['do_preview'] = isset($_REQUEST['preview_signature']);
- $security_checks = array();
- $found_area = false;
- foreach ($profile_areas as $section_id => $section)
- {
-
- foreach ($section['areas'] as $area_id => $area)
- {
-
- if ($current_area == $area_id)
- {
-
- if ((isset($section['enabled']) && $section['enabled'] == false) || (isset($area['enabled']) && $area['enabled'] == false))
- fatal_lang_error('no_access', false);
-
- if (isset($area['sc']) && (isset($_REQUEST['save']) || $context['do_preview']))
- {
- $security_checks['session'] = $area['sc'];
- $context['completed_save'] = true;
- }
-
- if (!empty($area['token']))
- {
- $security_checks[isset($_REQUEST['save']) ? 'validateToken' : 'needsToken'] = $area['token'];
- $token_name = $area['token'] !== true ? str_replace('%u', $context['id_member'], $area['token']) : 'profile-u' . $context['id_member'];
- $token_type = isset($area['token_type']) && in_array($area['token_type'], array('request', 'post', 'get')) ? $area['token_type'] : 'post';
- }
-
- if (!empty($area['validate']) || (isset($_REQUEST['save']) && !$context['user']['is_owner']))
- $security_checks['validate'] = true;
-
- if (!empty($profile_include_data['permission']))
- $security_checks['permission'] = $profile_include_data['permission'];
-
- $found_area = true;
- }
- }
- }
-
- if (!$found_area)
- fatal_lang_error('no_access', false);
-
- unset($profile_areas);
-
- if (isset($security_checks['validateToken']))
- validateToken($token_name, $token_type);
- if (isset($security_checks['session']))
- checkSession($security_checks['session']);
- if (isset($security_checks['validate']))
- validateSession();
- if (isset($security_checks['permission']))
- isAllowedTo($security_checks['permission']);
-
- if (isset($security_checks['needsToken']) || isset($security_checks['validateToken']))
- {
- createToken($token_name, $token_type);
- $context['token_check'] = $token_name;
- }
-
- if (isset($profile_include_data['file']))
- require_once($sourcedir . '/' . $profile_include_data['file']);
-
- if (!isset($profile_include_data['function']) || !function_exists($profile_include_data['function']))
- {
- destroyMenu();
- fatal_lang_error('no_access', false);
- }
-
- $context['linktree'][] = array(
- 'url' => $scripturl . '?action=profile' . ($memID != $user_info['id'] ? ';u=' . $memID : ''),
- 'name' => sprintf($txt['profile_of_username'], $context['member']['name']),
- );
- if (!empty($profile_include_data['label']))
- $context['linktree'][] = array(
- 'url' => $scripturl . '?action=profile' . ($memID != $user_info['id'] ? ';u=' . $memID : '') . ';area=' . $profile_include_data['current_area'],
- 'name' => $profile_include_data['label'],
- );
- if (!empty($profile_include_data['current_subsection']) && $profile_include_data['subsections'][$profile_include_data['current_subsection']][0] != $profile_include_data['label'])
- $context['linktree'][] = array(
- 'url' => $scripturl . '?action=profile' . ($memID != $user_info['id'] ? ';u=' . $memID : '') . ';area=' . $profile_include_data['current_area'] . ';sa=' . $profile_include_data['current_subsection'],
- 'name' => $profile_include_data['subsections'][$profile_include_data['current_subsection']][0],
- );
-
- $context['sub_template'] = $profile_include_data['function'];
- $context['template_layers'][] = 'profile';
-
- $check_password = $context['user']['is_owner'] && in_array($profile_include_data['current_area'], $context['password_areas']);
- $context['require_password'] = $check_password && empty($user_settings['openid_uri']);
-
- if (WIRELESS && $context['sub_template'] == 'summary' && WIRELESS_PROTOCOL != 'wap')
- $context['sub_template'] = WIRELESS_PROTOCOL . '_profile';
-
- $post_errors = array();
- $profile_vars = array();
-
- if ($context['completed_save'])
- {
-
- $_POST = htmltrim__recursive($_POST);
- $_POST = htmlspecialchars__recursive($_POST);
- if ($check_password)
- {
-
- if (!empty($user_settings['openid_uri']))
- {
- require_once($sourcedir . '/Subs-OpenID.php');
- smf_openID_revalidate();
- }
- else
- {
-
- if (trim($_POST['oldpasswrd']) == '')
- $post_errors[] = 'no_password';
-
- $_POST['oldpasswrd'] = un_htmlspecialchars($_POST['oldpasswrd']);
-
- $good_password = in_array(true, call_integration_hook('integrate_verify_password', array($cur_profile['member_name'], $_POST['oldpasswrd'], false)), true);
-
- if (!$good_password && $user_info['passwd'] != sha1(strtolower($user_profile[$memID]['member_name']) . un_htmlspecialchars(stripslashes($_POST['oldpasswrd']))))
- $post_errors[] = 'bad_password';
-
- if (in_array('bad_password', $post_errors))
- $context['password_auth_failed'] = true;
- }
- }
-
- if ($context['user']['is_owner'])
- $profile_vars['member_ip'] = $user_info['ip'];
-
- if ($current_area == 'activateaccount')
- {
- if (empty($post_errors))
- activateAccount($memID);
- }
- elseif ($current_area == 'deleteaccount')
- {
- if (empty($post_errors))
- {
- deleteAccount2($memID);
- redirectexit();
- }
- }
- elseif ($current_area == 'groupmembership' && empty($post_errors))
- {
- $msg = groupMembership2($profile_vars, $post_errors, $memID);
-
- redirectexit('action=profile' . ($context['user']['is_owner'] ? '' : ';u=' . $memID) . ';area=groupmembership' . (!empty($msg) ? ';msg=' . $msg : ''));
- }
-
- elseif ($current_area == 'authentication')
- {
- authentication($memID, true);
- }
- elseif (in_array($current_area, array('account', 'forumprofile', 'theme', 'pmprefs')))
- saveProfileFields();
- else
- {
- $force_redirect = true;
-
- require_once($sourcedir . '/Profile-Modify.php');
- saveProfileChanges($profile_vars, $post_errors, $memID);
- }
- call_integration_hook('integrate_profile_save', array($profile_vars, $post_errors, $memID));
-
- if (!empty($post_errors))
- {
-
- loadLanguage('Errors');
- $context['post_errors'] = $post_errors;
- }
- elseif (!empty($profile_vars))
- {
-
- if (isset($profile_vars['passwd']))
- call_integration_hook('integrate_reset_pass', array($cur_profile['member_name'], $cur_profile['member_name'], $_POST['passwrd2']));
- updateMemberData($memID, $profile_vars);
-
- if ($modSettings['latestMember'] == $memID)
- updateStats('member');
- elseif (isset($profile_vars['real_name']))
- updateSettings(array('memberlist_updated' => time()));
-
- if (isset($profile_vars['birthdate']) || isset($profile_vars['real_name']))
- updateSettings(array(
- 'calendar_updated' => time(),
- ));
-
- if (!empty($context['log_changes']) && !empty($modSettings['modlog_enabled']))
- {
- $log_changes = array();
- require_once($sourcedir . '/Logging.php');
- foreach ($context['log_changes'] as $k => $v)
- $log_changes[] = array(
- 'action' => $k,
- 'log_type' => 'user',
- 'extra' => array_merge($v, array(
- 'applicator' => $user_info['id'],
- 'member_affected' => $memID,
- )),
- );
- logActions($log_changes);
- }
-
- if (!empty($context['profile_execute_on_save']))
- foreach ($context['profile_execute_on_save'] as $saveFunc)
- $saveFunc();
-
- $context['profile_updated'] = $context['user']['is_owner'] ? $txt['profile_updated_own'] : sprintf($txt['profile_updated_else'], $cur_profile['member_name']);
-
- cache_put_data('member_data-profile-' . $memID, null, 0);
- }
- }
-
- if (!empty($post_errors))
- {
-
- foreach ($post_errors as $error_type)
- $context['modify_error'][$error_type] = true;
- }
-
- elseif (!empty($profile_vars) && $context['user']['is_owner'] && !$context['do_preview'])
- redirectexit('action=profile;area=' . $current_area . ';updated');
- elseif (!empty($force_redirect))
- redirectexit('action=profile' . ($context['user']['is_owner'] ? '' : ';u=' . $memID) . ';area=' . $current_area);
-
- $profile_include_data['function']($memID);
-
- if (!isset($context['page_title']))
- $context['page_title'] = $txt['profile'] . (isset($txt[$current_area]) ? ' - ' . $txt[$current_area] : '');
- }
- function loadCustomFields($memID, $area = 'summary')
- {
- global $context, $txt, $user_profile, $smcFunc, $user_info, $settings, $scripturl;
-
- $where = 'active = 1';
- if (!allowedTo('admin_forum') && $area != 'register')
- {
-
- if ($memID == $user_info['id'])
- $where .= $area == 'summary' ? ' AND private < 3' : ' AND (private = 0 OR private = 2)';
- else
- $where .= $area == 'summary' ? ' AND private < 2' : ' AND private = 0';
- }
- if ($area == 'register')
- $where .= ' AND show_reg != 0';
- elseif ($area != 'summary')
- $where .= ' AND show_profile = {string:area}';
-
- $request = $smcFunc['db_query']('', '
- SELECT
- col_name, field_name, field_desc, field_type, show_reg, field_length, field_options,
- default_value, bbc, enclose, placement
- FROM {db_prefix}custom_fields
- WHERE ' . $where,
- array(
- 'area' => $area,
- )
- );
- $context['custom_fields'] = array();
- $context['custom_fields_required'] = false;
- while ($row = $smcFunc['db_fetch_assoc']($request))
- {
-
- $exists = $memID && isset($user_profile[$memID], $user_profile[$memID]['options'][$row['col_name']]);
- $value = $exists ? $user_profile[$memID]['options'][$row['col_name']] : '';
-
- if (isset($_POST['customfield']) && isset($_POST['customfield'][$row['col_name']]))
- {
- $value = $smcFunc['htmlspecialchars']($_POST['customfield'][$row['col_name']]);
- if (in_array($row['field_type'], array('select', 'radio')))
- $value = ($options = explode(',', $row['field_options'])) && isset($options[$value]) ? $options[$value] : '';
- }
-
- $output_html = $value;
- if ($row['field_type'] == 'check')
- {
- $true = (!$exists && $row['default_value']) || $value;
- $input_html = '<input type="checkbox" name="customfield[' . $row['col_name'] . ']" ' . ($true ? 'checked="checked"' : '') . ' class="input_check" />';
- $output_html = $true ? $txt['yes'] : $txt['no'];
- }
- elseif ($row['field_type'] == 'select')
- {
- $input_html = '<select name="customfield[' . $row['col_name'] . ']"><option value="-1"></option>';
- $options = explode(',', $row['field_options']);
- foreach ($options as $k => $v)
- {
- $true = (!$exists && $row['default_value'] == $v) || $value == $v;
- $input_html .= '<option value="' . $k . '"' . ($true ? ' selected="selected"' : '') . '>' . $v . '</option>';
- if ($true)
- $output_html = $v;
- }
- $input_html .= '</select>';
- }
- elseif ($row['field_type'] == 'radio')
- {
- $input_html = '<fieldset>';
- $options = explode(',', $row['field_options']);
- foreach ($options as $k => $v)
- {
- $true = (!$exists && $row['default_value'] == $v) || $value == $v;
- $input_html .= '<label for="customfield_' . $row['col_name'] . '_' . $k . '"><input type="radio" name="customfield[' . $row['col_name'] . ']" class="input_radio" id="customfield_' . $row['col_name'] . '_' . $k . '" value="' . $k . '" ' . ($true ? 'checked="checked"' : '') . ' />' . $v . '</label><br />';
- if ($true)
- $output_html = $v;
- }
- $input_html .= '</fieldset>';
- }
- elseif ($row['field_type'] == 'text')
- {
- $input_html = '<input type="text" name="customfield[' . $row['col_name'] . ']" ' . ($row['field_length'] != 0 ? 'maxlength="' . $row['field_length'] . '"' : '') . ' size="' . ($row['field_length'] == 0 || $row['field_length'] >= 50 ? 50 : ($row['field_length'] > 30 ? 30 : ($row['field_length'] > 10 ? 20 : 10))) . '" value="' . $value . '" class="input_text" />';
- }
- else
- {
- @list ($rows, $cols) = @explode(',', $row['default_value']);
- $input_html = '<textarea name="customfield[' . $row['col_name'] . ']" ' . (!empty($rows) ? 'rows="' . $rows . '"' : '') . ' ' . (!empty($cols) ? 'cols="' . $cols . '"' : '') . '>' . $value . '</textarea>';
- }
-
- if ($row['bbc'])
- $output_html = parse_bbc($output_html);
- elseif($row['field_type'] == 'textarea')
-
- $output_html = strtr($output_html, array("\n" => '<br />'));
-
- if (!empty($row['enclose']) && !empty($output_html))
- $output_html = strtr($row['enclose'], array(
- '{SCRIPTURL}' => $scripturl,
- '{IMAGES_URL}' => $settings['images_url'],
- '{DEFAULT_IMAGES_URL}' => $settings['default_images_url'],
- '{INPUT}' => $output_html,
- ));
- $context['custom_fields'][] = array(
- 'name' => $row['field_name'],
- 'desc' => $row['field_desc'],
- 'type' => $row['field_type'],
- 'input_html' => $input_html,
- 'output_html' => $output_html,
- 'placement' => $row['placement'],
- 'colname' => $row['col_name'],
- 'value' => $value,
- 'show_reg' => $row['show_reg'],
- );
- $context['custom_fields_required'] = $context['custom_fields_required'] || $row['show_reg'];
- }
- $smcFunc['db_free_result']($request);
- call_integration_hook('integrate_load_custom_profile_fields', array($memID, $area));
- }
- ?>
|