X-Git-Url: https://git.heureux-cyclage.org/?a=blobdiff_plain;f=includes%2FAjaxFunctions.php;h=9e892f1abc52c8211d104c8bf5e42d1a1ab5fe7c;hb=968da62b1e5bca3d2b6dbf2461157a008c994de1;hp=8631b4e5733cd5ab05748b8dfc38ab680e03d322;hpb=ed8e8e58335db38a0ee0eedfc4d4417611dd645f;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/AjaxFunctions.php b/includes/AjaxFunctions.php index 8631b4e573..9e892f1abc 100644 --- a/includes/AjaxFunctions.php +++ b/includes/AjaxFunctions.php @@ -1,7 +1,12 @@ ucfirst( - $wgContLang->checkTitleEncoding( $wgContLang->recodeInput( js_unescape( $term ) ) ) - ) ); - - if ( strlen( str_replace( '_', '', $term ) )<3 ) - return; - - $db =& wfGetDB( DB_SLAVE ); - $res = $db->select( 'page', 'page_title', - array( 'page_namespace' => 0, - "page_title LIKE '". $db->strencode( $term) ."%'" ), - "wfSajaxSearch", - array( 'LIMIT' => $limit+1 ) - ); - - $r = ""; - - $i=0; - while ( ( $row = $db->fetchObject( $res ) ) && ( ++$i <= $limit ) ) { - $nt = Title::newFromDBkey( $row->page_title ); - $r .= '
  • ' . $l->makeKnownLinkObj( $nt ) . "
  • \n"; - } - if ( $i > $limit ) { - $more = '' . $l->makeKnownLink( $wgContLang->specialPage( "Allpages" ), - wfMsg('moredotdotdot'), - "namespace=0&from=" . wfUrlEncode ( $term ) ) . - ''; - } else { - $more = ''; - } - - $subtitlemsg = ( Title::newFromText($term) ? 'searchsubtitle' : 'searchsubtitleinvalid' ); - $subtitle = $wgOut->parse( wfMsg( $subtitlemsg, wfEscapeWikiText($term) ) ); #FIXME: parser is missing mTitle ! - - $term = urlencode( $term ); - $html = '
    ' - . wfMsg( 'hideresults' ) . '
    ' - . '

    '.wfMsg('search') - . '

    '. $subtitle . '

    " . wfMsg( 'articletitles', $term ) . "

    " - . ''.$more; - - $response = new AjaxResponse( $html ); - - $response->setCacheDuration( 30*60 ); - - return $response; -} - /** * Called for AJAX watch/unwatch requests. - * @param $pageID Integer ID of the page to be watched/unwatched + * @param $pagename Prefixed title string for page to watch/unwatch * @param $watch String 'w' to watch, 'u' to unwatch - * @return String '' or '' on successful watch or unwatch, respectively, or '' on error (invalid XML in case we want to add HTML sometime) + * @return String '' or '' on successful watch or unwatch, + * respectively, followed by an HTML message to display in the alert box; or + * '' on error */ -function wfAjaxWatch($pageID = "", $watch = "") { - if(wfReadOnly()) - return ''; // redirect to action=(un)watch, which will display the database lock message +function wfAjaxWatch($pagename = "", $watch = "") { + if(wfReadOnly()) { + // redirect to action=(un)watch, which will display the database lock + // message + return ''; + } - if(('w' !== $watch && 'u' !== $watch) || !is_numeric($pageID)) + if('w' !== $watch && 'u' !== $watch) { return ''; + } $watch = 'w' === $watch; - $pageID = intval($pageID); - $title = Title::newFromID($pageID); - if(!$title) + $title = Title::newFromDBkey($pagename); + if(!$title) { + // Invalid title return ''; + } $article = new Article($title); $watching = $title->userIsWatching(); if($watch) { if(!$watching) { - $dbw =& wfGetDB(DB_MASTER); + $dbw = wfGetDB(DB_MASTER); $dbw->begin(); - $article->doWatch(); + $ok = $article->doWatch(); $dbw->commit(); } } else { if($watching) { - $dbw =& wfGetDB(DB_MASTER); + $dbw = wfGetDB(DB_MASTER); $dbw->begin(); - $article->doUnwatch(); + $ok = $article->doUnwatch(); $dbw->commit(); } } - - return $watch ? '' : ''; -} - -/** - * Return a list of Editors currently editing the article. - * Based on an idea by Tim Starling. - * - * @author Ashar Voultoiz - * @author Tim Starling - */ -function wfAjaxShowEditors( $articleId, $username ) { - global $wgOut; - $articleId = intval($articleId); - - // Validate request - $title = Title::newFromID( $articleId ); - if( !($title) ) { return 'ERR: page id invalid'; } - - $user = User::newFromSession() ; - if( !$user ) { return 'ERR: user invalid'; } - - $username = $user->getName(); - if( !( $user->isLoggedIn() or User::isIP( $username ) ) ) { return 'ERR: user not found'; } - - - // When did the user started editing ? - $dbr =& wfGetDB(DB_SLAVE); - $userStarted = $dbr->selectField( 'editings', - 'editings_started', - array( - 'editings_user' => $username, - 'editings_page' => $title->getArticleID(), - ), - __METHOD__ - ); - - // He just started editing, assume NOW - if(!$userStarted) { $userStarted = $dbr->timestamp(); } - - # Either create a new entry or update the touched timestamp. - # This is done using a unique index on the database : - # `editings_page_started` (`editings_page`,`editings_user`,`editings_started`) - - $dbw =& wfGetDB(DB_MASTER); - $dbw->replace( 'editings', - array( 'editings_page', 'editings_user', 'editings_started' ), - array( - 'editings_page' => $title->getArticleID() , - 'editings_user' => $username, - 'editings_started' => $userStarted , - 'editings_touched' => $dbw->timestamp(), - ), __METHOD__ - ); - - // Now we get the list of all watching users - $dbr = & wfGetDB(DB_SLAVE); - $res = $dbr->select( 'editings', - array( 'editings_user','editings_started','editings_touched' ), - array( 'editings_page' => $title->getArticleID() ), - __METHOD__ - ); - - $l = new Linker(); - - $wikitext = ''; - $unix_now = wfTimestamp(TS_UNIX); - $first = 1; - while( $editor = $dbr->fetchObject( $res ) ) { - - // Check idling time - $idle = $unix_now - wfTimestamp( TS_UNIX, $editor->editings_touched ); - - global $wgAjaxShowEditorsTimeout ; - if( $idle >= $wgAjaxShowEditorsTimeout ) { - $dbw->delete('editings', - array( - 'editings_page' => $title->getArticleID(), - 'editings_user' => $editor->editings_user, - ), - __METHOD__ - ); - continue; // we will not show the user - } - - if( $first ) { $first = 0; } - else { $wikitext .= ' ~ '; } - - $since = wfTimestamp( TS_DB, $editor->editings_started ); - $wikitext .= $since; - - $wikitext .= ' ' . $l->makeLinkObj( - Title::makeTitle( NS_USER, $editor->editings_user ), - $editor->editings_user - ); - - - $wikitext .= ' ' . wfMsg( 'ajax-se-idling', ''.$idle.'' ); + // Something stopped the change + if( isset($ok) && !$ok ) { + return ''; + } + if( $watch ) { + return ''.wfMsgExt( 'addedwatchtext', array( 'parse' ), $title->getPrefixedText() ); + } else { + return ''.wfMsgExt( 'removedwatchtext', array( 'parse' ), $title->getPrefixedText() ); } - return $wikitext ; } -?>