mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/InputBox
synced 2024-11-14 18:55:16 +00:00
9767ef7f08
For search-style inputboxes, if you have `searchfilter=foo` as a parameter, it will append `foo` after the search term. This is useful for leveraging search filters in custom search boxes without exposing it to the user. Bug: T147951 Change-Id: Ie23ce220ff9657c38fe5b41195e297ca7cebf7f1
91 lines
2.2 KiB
PHP
91 lines
2.2 KiB
PHP
<?php
|
|
/**
|
|
* Hooks for InputBox extension
|
|
*
|
|
* @file
|
|
* @ingroup Extensions
|
|
*/
|
|
|
|
// InputBox hooks
|
|
class InputBoxHooks {
|
|
// Initialization
|
|
public static function register( Parser &$parser ) {
|
|
// Register the hook with the parser
|
|
$parser->setHook( 'inputbox', [ 'InputBoxHooks', 'render' ] );
|
|
|
|
// Continue
|
|
return true;
|
|
}
|
|
|
|
// Prepend prefix to wpNewTitle if necessary
|
|
public static function onSpecialPageBeforeExecute( $special, $subPage ) {
|
|
$request = $special->getRequest();
|
|
$prefix = $request->getText( 'prefix', '' );
|
|
$title = $request->getText( 'wpNewTitle', '' );
|
|
$search = $request->getText( 'search', '' );
|
|
$searchfilter = $request->getText( 'searchfilter', '' );
|
|
if ( $special->getName() == 'Movepage' && $prefix !== '' && $title !== '' ) {
|
|
$request->setVal( 'wpNewTitle', $prefix . $title );
|
|
$request->unsetVal( 'prefix' );
|
|
}
|
|
if ( $special->getName() == 'Search' && $searchfilter !== '' ) {
|
|
$request->setVal( 'search', $search . ' ' . $searchfilter );
|
|
}
|
|
return true;
|
|
}
|
|
|
|
// Render the input box
|
|
public static function render( $input, $args, Parser $parser ) {
|
|
// Create InputBox
|
|
$inputBox = new InputBox( $parser );
|
|
|
|
// Configure InputBox
|
|
$inputBox->extractOptions( $parser->replaceVariables( $input ) );
|
|
|
|
// Return output
|
|
return $inputBox->render();
|
|
}
|
|
|
|
/**
|
|
* <inputbox type=create...> sends requests with action=edit, and
|
|
* possibly a &prefix=Foo. So we pick that up here, munge prefix
|
|
* and title together, and redirect back out to the real page
|
|
* @param $output OutputPage
|
|
* @param $article Article
|
|
* @param $title Title
|
|
* @param $user User
|
|
* @param $request WebRequest
|
|
* @param $wiki MediaWiki
|
|
* @return bool
|
|
*/
|
|
public static function onMediaWikiPerformAction(
|
|
$output,
|
|
$article,
|
|
$title,
|
|
$user,
|
|
$request,
|
|
$wiki
|
|
) {
|
|
if ( $wiki->getAction( $request ) !== 'edit' ){
|
|
// not our problem
|
|
return true;
|
|
}
|
|
if ( $request->getText( 'prefix', '' ) === '' ){
|
|
// Fine
|
|
return true;
|
|
}
|
|
|
|
$params = $request->getValues();
|
|
$title = $params['prefix'];
|
|
if ( isset( $params['title'] ) ) {
|
|
$title .= $params['title'];
|
|
}
|
|
unset( $params['prefix'] );
|
|
$params['title'] = $title;
|
|
|
|
global $wgScript;
|
|
$output->redirect( wfAppendQuery( $wgScript, $params ), '301' );
|
|
return false;
|
|
}
|
|
}
|