case 'SearchunsubAction':
case 'SearchsubsAction':
case 'SearchSubForm':
+ case 'SearchSubMenu':
case 'SearchUnsubForm':
+ case 'SearchSubTrackCommand':
+ case 'SearchSubTrackOffCommand':
+ case 'SearchSubTrackingCommand':
+ case 'SearchSubUntrackCommand':
include_once $dir.'/'.strtolower($cls).'.php';
return false;
default:
$m->connect('search/:search/unsubscribe',
array('action' => 'searchunsub'),
array('search' => Router::REGEX_TAG));
-
$m->connect(':nickname/search-subscriptions',
array('action' => 'searchsubs'),
array('nickname' => Nickname::DISPLAY_FMT));
* or Sphinx search backends.
*
* @param Notice $notice
- * @param string $search
+ * @param string $search
* @return boolean
*/
function matchSearch(Notice $notice, $search)
*
* @return boolean hook return
*/
-
function onEndSubGroupNav($widget)
{
$action = $widget->out;
}
/**
- * Add a count of mirrored feeds into a user's profile sidebar stats.
+ * Replace the built-in stub track commands with ones that control
+ * search subscriptions.
*
- * @param Profile $profile
- * @param array $stats
- * @return boolean hook return value
+ * @param CommandInterpreter $cmd
+ * @param string $arg
+ * @param User $user
+ * @param Command $result
+ * @return boolean hook result
*/
- function onProfileStats($profile, &$stats)
+ function onEndInterpretCommand($cmd, $arg, $user, &$result)
{
- $cur = common_current_user();
- if (!empty($cur) && $cur->id == $profile->id) {
- $searchsub = new SearchSub();
- $searchsub ->profile_id = $profile->id;
- $entry = array(
- 'id' => 'searchsubs',
- 'label' => _m('Search subscriptions'),
- 'link' => common_local_url('searchsubs', array('nickname' => $profile->nickname)),
- 'value' => $searchsub->count(),
- );
+ if ($result instanceof TrackCommand) {
+ $result = new SearchSubTrackCommand($user, $arg);
+ return false;
+ } else if ($result instanceof TrackOffCommand) {
+ $result = new SearchSubTrackOffCommand($user);
+ return false;
+ } else if ($result instanceof TrackingCommand) {
+ $result = new SearchSubTrackingCommand($user);
+ return false;
+ } else if ($result instanceof UntrackCommand) {
+ $result = new SearchSubUntrackCommand($user, $arg);
+ return false;
+ } else {
+ return true;
+ }
+ }
- $insertAt = count($stats);
- foreach ($stats as $i => $row) {
- if ($row['id'] == 'groups') {
- // Slip us in after them.
- $insertAt = $i + 1;
- break;
- }
+ function onHelpCommandMessages($cmd, &$commands)
+ {
+ // TRANS: Help message for IM/SMS command "track <word>"
+ $commands["track <word>"] = _m('COMMANDHELP', "Start following notices matching the given search query.");
+ // TRANS: Help message for IM/SMS command "untrack <word>"
+ $commands["untrack <word>"] = _m('COMMANDHELP', "Stop following notices matching the given search query.");
+ // TRANS: Help message for IM/SMS command "track off"
+ $commands["track off"] = _m('COMMANDHELP', "Disable all tracked search subscriptions.");
+ // TRANS: Help message for IM/SMS command "untrack all"
+ $commands["untrack all"] = _m('COMMANDHELP', "Disable all tracked search subscriptions.");
+ // TRANS: Help message for IM/SMS command "tracks"
+ $commands["tracks"] = _m('COMMANDHELP', "List all your search subscriptions.");
+ // TRANS: Help message for IM/SMS command "tracking"
+ $commands["tracking"] = _m('COMMANDHELP', "List all your search subscriptions.");
+ }
+
+ function onEndDefaultLocalNav($menu, $user)
+ {
+ $user = common_current_user();
+
+ if (!empty($user)) {
+ $searches = SearchSub::forProfile($user->getProfile());
+
+ if (!empty($searches) && count($searches) > 0) {
+ $searchSubMenu = new SearchSubMenu($menu->out, $user, $searches);
+ // TRANS: Sub menu for searches.
+ $menu->submenu(_m('MENU','Searches'), $searchSubMenu);
}
- array_splice($stats, $insertAt, 0, array($entry));
}
+
return true;
}
}