3 * MediaWiki Widgets – SearchInputWidget class.
5 * @copyright 2011-2015 MediaWiki Widgets Team and others; see AUTHORS.txt
6 * @license The MIT License (MIT); see LICENSE.txt
8 namespace MediaWiki\Widget
;
11 * Search input widget.
13 class SearchInputWidget
extends TitleInputWidget
{
15 protected $pushPending = false;
16 protected $performSearchOnClick = true;
17 protected $validateTitle = false;
18 protected $highlightFirst = false;
19 protected $dataLocation = 'header';
22 * @param array $config Configuration options
23 * @param int|null $config['pushPending'] Whether the input should be visually marked as
24 * "pending", while requesting suggestions (default: true)
25 * @param boolean|null $config['performSearchOnClick'] If true, the script will start a search
26 * whenever a user hits a suggestion. If false, the text of the suggestion is inserted into the
27 * text field only (default: true)
28 * @param string $config['dataLocation'] Where the search input field will be
29 * used (header or content, default: header)
31 public function __construct( array $config = [] ) {
32 $config = array_merge( [
40 parent
::__construct( $config );
42 // Properties, which are ignored in PHP and just shipped back to JS
43 if ( isset( $config['pushPending'] ) ) {
44 $this->pushPending
= $config['pushPending'];
47 if ( isset( $config['performSearchOnClick'] ) ) {
48 $this->performSearchOnClick
= $config['performSearchOnClick'];
51 if ( $config['dataLocation'] ) {
52 // identifies the location of the search bar for tracking purposes
53 $this->dataLocation
= $config['dataLocation'];
57 $this->addClasses( [ 'mw-widget-searchInputWidget' ] );
60 protected function getJavaScriptClassName() {
61 return 'mw.widgets.SearchInputWidget';
64 public function getConfig( &$config ) {
65 $config['pushPending'] = $this->pushPending
;
66 $config['performSearchOnClick'] = $this->performSearchOnClick
;
67 if ( $this->dataLocation
) {
68 $config['dataLocation'] = $this->dataLocation
;
70 return parent
::getConfig( $config );