Hooking topic_notification_list into a new action?

Started by samborabora, August 28, 2014, 06:36:14 PM

Previous topic - Next topic

samborabora

I'm trying to hook the topic_notification_list into an action that is separate from the profile-view action and template. I appreciate there is a lot of stuff in the profile pages that pertain to the topic notification list, and therefore I'm interested in taking as much from it along as possible. To my knowledge, it should be, in theory, possible to display any topic notifications the current user has in a different action using the hooks, as long as the arrays that build the notifications are there as well, I'm just a little confused exactly where everything should go. I've cloned the profile templates into my new action like so:

index.php
$actionArray = array(
'mytopics' => array('Mytopics.php', 'MyTopics'),


Mytopics.php in Sources
<?php

/**
 * Simple Machines Forum (SMF)
 *
 * @package SMF
 * @author Simple Machines http://www.simplemachines.org
 * @copyright 2011 Simple Machines
 * @license http://www.simplemachines.org/about/smf/license.php BSD
 *
 * @version 2.0
 */

if (!defined('SMF'))
die('Hacking attempt...');

/* This file has the primary job of showing and editing people's profiles.
It also allows the user to change some of their or another's preferences,
and such things.  It uses the following functions:

void ModifyProfile(array errors = none)
// !!!

void loadCustomFields(int id_member, string area)
// !!!

*/

// Allow the change or view of profiles...
function mytopics($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;

// Don't reload this as we may have processed error strings.
if (empty($post_errors))
loadLanguage('Profile');
loadTemplate('Mytopics');

require_once($sourcedir '/Subs-Menu.php');

// Did we get the user by name...
if (isset($_REQUEST['user']))
$memberResult loadMemberData($_REQUEST['user'], true'profile');
// ... or by id_member?
elseif (!empty($_REQUEST['u']))
$memberResult loadMemberData((int) $_REQUEST['u'], false'profile');
// If it was just ?action=profile, edit your own profile.
else
$memberResult loadMemberData($user_info['id'], false'profile');

// Check if loadMemberData() has returned a valid result.
if (!is_array($memberResult))
fatal_lang_error('not_a_user'false);

// If all went well, we have a valid member ID!
list ($memID) = $memberResult;
$context['id_member'] = $memID;
$cur_profile $user_profile[$memID];

// Let's have some information about this member ready, too.
loadMemberContext($memID);
$context['member'] = $memberContext[$memID];

// Is this the profile of the user himself or herself?
$context['user']['is_owner'] = $memID == $user_info['id'];

/* Define all the sections within the profile area!
We start by defining the permission required - then SMF takes this and turns it into the relevant context ;)
Possible fields:
For Section:
string $title: Section title.
array $areas: Array of areas within this section.

For Areas:
string $label: Text string that will be used to show the area in the menu.
string $file: Optional text string that may contain a file name that's needed for inclusion in order to display the area properly.
string $custom_url: Optional href for area.
string $function: Function to execute for this section.
bool $enabled: Should area be shown?
string $sc: Session check validation to do on save - note without this save will get unset - if set.
bool $hidden: Does this not actually appear on the menu?
bool $password: Whether to require the user's password in order to save the data in the area.
array $subsections: Array of subsections, in order of appearance.
array $permission: Array of permissions to determine who can access this area. Should contain arrays $own and $any.
*/
$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',
),
),
'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'),
),
'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] == && $cur_profile['warning'] && $context['user']['is_owner'] && !empty($modSettings['warning_show']),
'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'] != && !in_array(1explode(','$cur_profile['additional_groups']))),
'sc' => 'post',
'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',
'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',
'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',
'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',
'permission' => array(
'own' => array('profile_extra_any''profile_extra_own'),
'any' => array('profile_extra_any'),
),
),
// Without profile_extra_own, settings are accessible from the PM section.
'pmprefs' => array(
'label' => $txt['pmprefs'],
'file' => 'Profile-Modify.php',
'function' => 'pmprefs',
'enabled' => allowedTo(array('profile_extra_own''profile_extra_any')),
'sc' => 'post',
'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',
'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',
'subsections' => array(
'buddies' => array($txt['editBuddies']),
'followers' => array($txt['Followers']),
'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',
'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] == && (!$context['user']['is_owner'] || $context['user']['is_admin']),
'file' => 'Profile-Actions.php',
'function' => 'issueWarning',
'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'] != && !in_array(1explode(','$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',
'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',
'select' => 'summary',
'permission' => array(
'own' => array(),
'any' => array('moderate_forum'),
),
),
),
),
);

// Let them modify profile areas easily.
call_integration_hook('integrate_profile_areas', array(&$profile_areas));

// Do some cleaning ready for the menu function.
$context['password_areas'] = array();
$current_area = isset($_REQUEST['area']) ? $_REQUEST['area'] : '';

foreach ($profile_areas as $section_id => $section)
{
// Do a bit of spring cleaning so to speak.
foreach ($section['areas'] as $area_id => $area)
{
// If it said no permissions that meant it wasn't valid!
if (empty($area['permission'][$context['user']['is_owner'] ? 'own' 'any']))
$profile_areas[$section_id]['areas'][$area_id]['enabled'] = false;
// Otherwise pick the right set.
else
$profile_areas[$section_id]['areas'][$area_id]['permission'] = $area['permission'][$context['user']['is_owner'] ? 'own' 'any'];

// Password required - only if not on OpenID.
if (!empty($area['password']))
$context['password_areas'][] = $area_id;
}
}

// Is there an updated message to show?
if (isset($_GET['updated']))
$context['profile_updated'] = $txt['profile_updated_own'];

// Set a few options for the menu.
$menuOptions = array(
'disable_url_session_check' => true,
'current_area' => $current_area,
'extra_url_parameters' => array(
'u' => $context['id_member'],
),
);

// Actually create the menu!
$profile_include_data createMenu($profile_areas$menuOptions);

// No menu means no access.
if (!$profile_include_data && (!$user_info['is_guest'] || validateSession()))
fatal_lang_error('no_access'false);

// Make a note of the Unique ID for this menu.
$context['profile_menu_id'] = $context['max_menu_id'];
$context['profile_menu_name'] = 'menu_data_' $context['profile_menu_id'];

// Set the selected item - now it's been validated.
$current_area $profile_include_data['current_area'];
$context['menu_item_selected'] = $current_area;

// Before we go any further, let's work on the area we've said is valid. Note this is done here just in case we every compromise the menu function in error!
$context['completed_save'] = false;
$security_checks = array();
$found_area false;
foreach ($profile_areas as $section_id => $section)
{
// Do a bit of spring cleaning so to speak.
foreach ($section['areas'] as $area_id => $area)
{
// Is this our area?
if ($current_area == $area_id)
{
// This can't happen - but is a security check.
if ((isset($section['enabled']) && $section['enabled'] == false) || (isset($area['enabled']) && $area['enabled'] == false))
fatal_lang_error('no_access'false);

// Are we saving data in a valid area?
if (isset($area['sc']) && isset($_REQUEST['save']))
{
$security_checks['session'] = $area['sc'];
$context['completed_save'] = true;
}

// Does this require session validating?
if (!empty($area['validate']))
$security_checks['validate'] = true;

// Permissions for good measure.
if (!empty($profile_include_data['permission']))
$security_checks['permission'] = $profile_include_data['permission'];

// Either way got something.
$found_area true;
}
}
}

// Oh dear, some serious security lapse is going on here... we'll put a stop to that!
if (!$found_area)
fatal_lang_error('no_access'false);

// Release this now.
unset($profile_areas);

// Now the context is setup have we got any security checks to carry out additional to that above?
if (isset($security_checks['session']))
checkSession($security_checks['session']);
if (isset($security_checks['validate']))
validateSession();
if (isset($security_checks['permission']))
isAllowedTo($security_checks['permission']);

// File to include?
if (isset($profile_include_data['file']))
require_once($sourcedir '/' $profile_include_data['file']);

// Make sure that the area function does exist!
if (!isset($profile_include_data['function']) || !function_exists($profile_include_data['function']))
{
destroyMenu();
fatal_lang_error('no_access'false);
}

// Build the link tree.
$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],
);

// Set the template for this area and add the profile layer.
$context['sub_template'] = $profile_include_data['function'];
$context['template_layers'][] = 'profile';

// All the subactions that require a user password in order to validate.
$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 we're in wireless then we have a cut down template...
if (WIRELESS && $context['sub_template'] == 'summary' && WIRELESS_PROTOCOL != 'wap')
$context['sub_template'] = WIRELESS_PROTOCOL '_profile';

// These will get populated soon!
$post_errors = array();
$profile_vars = array();

// Right - are we saving - if so let's save the old data first.
if ($context['completed_save'])
{
// If it's someone elses profile then validate the session.
if (!$context['user']['is_owner'])
validateSession();

// Clean up the POST variables.
$_POST htmltrim__recursive($_POST);
$_POST htmlspecialchars__recursive($_POST);

if ($check_password)
{
// If we're using OpenID try to revalidate.
if (!empty($user_settings['openid_uri']))
{
require_once($sourcedir '/Subs-OpenID.php');
smf_openID_revalidate();
}
else
{
// You didn't even enter a password!
if (trim($_POST['oldpasswrd']) == '')
$post_errors[] = 'no_password';

// Since the password got modified due to all the $_POST cleaning, lets undo it so we can get the correct password
$_POST['oldpasswrd'] = un_htmlspecialchars($_POST['oldpasswrd']);

// Does the integration want to check passwords?
$good_password in_array(truecall_integration_hook('integrate_verify_password', array($cur_profile['member_name'], $_POST['oldpasswrd'], false)), true);

// Bad password!!!
if (!$good_password && $user_info['passwd'] != sha1(strtolower($cur_profile['member_name']) . $_POST['oldpasswrd']))
$post_errors[] = 'bad_password';

// Warn other elements not to jump the gun and do custom changes!
if (in_array('bad_password'$post_errors))
$context['password_auth_failed'] = true;
}
}

// Change the IP address in the database.
if ($context['user']['is_owner'])
$profile_vars['member_ip'] = $user_info['ip'];

// Now call the sub-action function...
if ($current_area == 'activateaccount')
{
if (empty($post_errors))
activateAccount($memID);
}
elseif ($current_area == 'deleteaccount')
{
if (empty($post_errors))
{
deleteAccount2($profile_vars$post_errors$memID);
redirectexit();
}
}
elseif ($current_area == 'groupmembership' && empty($post_errors))
{
$msg groupMembership2($profile_vars$post_errors$memID);

// Whatever we've done, we have nothing else to do here...
redirectexit('action=profile' . ($context['user']['is_owner'] ? '' ';u=' $memID) . ';area=groupmembership' . (!empty($msg) ? ';msg=' $msg ''));
}
// Authentication changes?
elseif ($current_area == 'authentication')
{
authentication($memIDtrue);
}
elseif (in_array($current_area, array('account''forumprofile''theme''pmprefs')))
saveProfileFields();
else
{
$force_redirect true;
// Ensure we include this.
require_once($sourcedir '/Profile-Modify.php');
saveProfileChanges($profile_vars$post_errors$memID);
}

// There was a problem, let them try to re-enter.
if (!empty($post_errors))
{
// Load the language file so we can give a nice explanation of the errors.
loadLanguage('Errors');
$context['post_errors'] = $post_errors;
}
elseif (!empty($profile_vars))
{
// If we've changed the password, notify any integration that may be listening in.
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);

// What if this is the newest member?
if ($modSettings['latestMember'] == $memID)
updateStats('member');
elseif (isset($profile_vars['real_name']))
updateSettings(array('memberlist_updated' => time()));

// If the member changed his/her birthdate, update calendar statistics.
if (isset($profile_vars['birthdate']) || isset($profile_vars['real_name']))
updateSettings(array(
'calendar_updated' => time(),
));

// Anything worth logging?
if (!empty($context['log_changes']) && !empty($modSettings['modlog_enabled']))
{
$log_changes = array();
foreach ($context['log_changes'] as $k => $v)
$log_changes[] = array(
'action' => $k,
'id_log' => 2,
'log_time' => time(),
'id_member' => $memID,
'ip' => $user_info['ip'],
'extra' => serialize(array_merge($v, array('applicator' => $user_info['id']))),
);
$smcFunc['db_insert']('',
'{db_prefix}log_actions',
array(
'action' => 'string''id_log' => 'int''log_time' => 'int''id_member' => 'int''ip' => 'string-16',
'extra' => 'string-65534',
),
$log_changes,
array('id_action')
);
}

// Have we got any post save functions to execute?
if (!empty($context['profile_execute_on_save']))
foreach ($context['profile_execute_on_save'] as $saveFunc)
$saveFunc();

// Let them know it worked!
$context['profile_updated'] = $context['user']['is_owner'] ? $txt['profile_updated_own'] : sprintf($txt['profile_updated_else'], $cur_profile['member_name']);

// Invalidate any cached data.
cache_put_data('member_data-profile-' $memIDnull0);
}
}

// Have some errors for some reason?
if (!empty($post_errors))
{
// Set all the errors so the template knows what went wrong.
foreach ($post_errors as $error_type)
$context['modify_error'][$error_type] = true;
}
// If it's you then we should redirect upon save.
elseif (!empty($profile_vars) && $context['user']['is_owner'])
redirectexit('action=profile;area=' $current_area ';updated');
elseif (!empty($force_redirect))
redirectexit('action=profile' . ($context['user']['is_owner'] ? '' ';u=' $memID) . ';area=' $current_area);

// Call the appropriate subaction function.
$profile_include_data['function']($memID);

// Set the page title if it's not already set...
if (!isset($context['page_title']))
$context['page_title'] = $txt['profile'] . (isset($txt[$current_area]) ? ' - ' $txt[$current_area] : '');
}

// Load any custom fields for this area... no area means load all, 'summary' loads all public ones.
function loadCustomFields($memID$area 'summary')
{
global $context$txt$user_profile$smcFunc$user_info$settings$scripturl;

// Get the right restrictions in place...
$where 'active = 1';
if (!allowedTo('admin_forum') && $area != 'register')
{
// If it's the owner they can see two types of private fields, regardless.
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}';

// Load all the relevant fields - and data.
$request $smcFunc['db_query']('''
SELECT
col_name, field_name, field_desc, field_type, field_length, field_options,
default_value, bbc, enclose, placement
FROM {db_prefix}custom_fields
WHERE ' 
$where,
array(
'area' => $area,
)
);
$context['custom_fields'] = array();
while ($row $smcFunc['db_fetch_assoc']($request))
{
// Shortcut.
$exists $memID && isset($user_profile[$memID], $user_profile[$memID]['options'][$row['col_name']]);
$value $exists $user_profile[$memID]['options'][$row['col_name']] : '';

// If this was submitted already then make the value the posted version.
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] : '';
}

// HTML for the input form.
$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'] != 'maxlength="' $row['field_length'] . '"' '') . ' size="' . ($row['field_length'] == || $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>';
}

// Parse BBCode
if ($row['bbc'])
$output_html parse_bbc($output_html);
elseif($row['field_type'] == 'textarea')
// Allow for newlines at least
$output_html strtr($output_html, array("\n" => '<br />'));

// Enclosing the user input within some other text?
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,
);
}
$smcFunc['db_free_result']($request);
}

?>

and MyTopics.Template.php in themes:
<?php
/**
 * Simple Machines Forum (SMF)
 *
 * @package SMF
 * @author Simple Machines
 * @copyright 2011 Simple Machines
 * @license http://www.simplemachines.org/about/smf/license.php BSD
 *
 * @version 2.0
 */

// Template for the profile side bar - goes before any other profile template.
function template_profile_above()
{
global $context$settings$options$scripturl$modSettings$txt;

echo '
<script type="text/javascript" src="'
$settings['default_theme_url'], '/scripts/profile.js"></script>
'
;

// Prevent Chrome from auto completing fields when viewing/editing other members profiles
if ($context['browser']['is_chrome'] && !$context['user']['is_owner'])
echo '
<script type="text/javascript"><!-- // --><![CDATA[
disableAutoComplete();
// ]]></script>'
;

/*
// If an error occurred while trying to save previously, give the user a clue!
if (!empty($context['post_errors']) && $context['section'] !== 'forumprofile')
echo '
', template_error_message();

// If the profile was update successfully, let the user know this.
if (!empty($context['profile_updated']) && $section['section'] !== 'forumprofile')
echo '
<div id="profile_success">
', $context['profile_updated'], '
</div>'
*/
;
}

// Template for closing off table started in profile_above.
function template_profile_below()
{
echo '
'
;
}

// This template displays users details without any option to edit them.
function template_summary()
{
global $context$settings$options$txt$scripturl$modSettings;

// The main containing header.
/*echo '

<input type="hidden" name="notify_announcements" value="0" />
<label for="notify_announcements"><input type="checkbox" id="notify_announcements" name="notify_announcements"', !empty($context['member']['notify_announcements']) ? ' checked="checked"' : '', ' class="input_check" /> ', $txt['notify_important_email'], '</label><br />';*/

// More notification options.
echo '
<div id="icon_title" class="profile" style="float: left;">
<h2 class="proftit">My Topics</h2>
 <h3 class="description">/ Subscribed topics</h3>
</div>
<div style="float: right; padding-top: 5px; color: #aaa;">
<input type="hidden" name="default_options[auto_notify]" value="0" />
<label for="auto_notify"><input disabled="true" type="checkbox" id="auto_notify" name="default_options[auto_notify]" value="1"'
, !empty($context['member']['options']['auto_notify']) ? ' checked="checked"' ''' class="input_check"  /> Automatically subscribe to topics</label></div>
<br />'
;

if (empty($modSettings['disallow_sendBody']))
echo '
<input type="hidden" name="notify_send_body" value="0" />
<label for="notify_send_body"><input type="checkbox" id="notify_send_body" name="notify_send_body"'
, !empty($context['member']['notify_send_body']) ? ' checked="checked"' ''' class="input_check" /> '$txt['notify_send_body'], '</label><br />';

echo '
<br />
<label for="notify_regularity">'
$txt['notify_regularity'], ':</label>
<select name="notify_regularity" id="notify_regularity">
<option value="0"'
$context['member']['notify_regularity'] == ' selected="selected"' '''>'$txt['notify_regularity_instant'], '</option>
<option value="1"'
$context['member']['notify_regularity'] == ' selected="selected"' '''>'$txt['notify_regularity_first_only'], '</option>
<option value="2"'
$context['member']['notify_regularity'] == ' selected="selected"' '''>'$txt['notify_regularity_daily'], '</option>
<option value="3"'
$context['member']['notify_regularity'] == ' selected="selected"' '''>'$txt['notify_regularity_weekly'], '</option>
</select>
<br /><br />
<label for="notify_types">'
$txt['notify_send_types'], ':</label>
<select name="notify_types" id="notify_types">
<option value="1"'
$context['member']['notify_types'] == ' selected="selected"' '''>'$txt['notify_send_type_everything'], '</option>
<option value="2"'
$context['member']['notify_types'] == ' selected="selected"' '''>'$txt['notify_send_type_everything_own'], '</option>
<option value="3"'
$context['member']['notify_types'] == ' selected="selected"' '''>'$txt['notify_send_type_only_replies'], '</option>
<option value="4"'
$context['member']['notify_types'] == ' selected="selected"' '''>'$txt['notify_send_type_nothing'], '</option>
</select><br class="clear" />

<div>
<input id="notify_submit" type="submit" value="'
$txt['notify_save'], '" class="button_submit floatright" />
<input type="hidden" name="'
$context['session_var'], '" value="'$context['session_id'], '" />
<input type="hidden" name="u" value="'
$context['id_member'], '" />
<input type="hidden" name="sa" value="'
$context['menu_item_selected'], '" />
</div><br class="clear" />
</form>
</div>
<span class="botslice"><span></span></span>
</div></div>
<br />'
;

template_show_list('topic_notification_list');

echo '
<br />'
;
}

?>

As you can see, I have brought along the option to tick notifications on and off, as was in the original notifications part of the profile subaction, I'm just not entirely sure why the topic notifications aren't loading, even though I have the relevant code copied over into the new action source. Any suggestions as to how I could attempt to get this to display would be MOST appreciated!!

Advertisement: