diff options
Diffstat (limited to 'www/wiki/includes/widget/SearchInputWidget.php')
-rw-r--r-- | www/wiki/includes/widget/SearchInputWidget.php | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/www/wiki/includes/widget/SearchInputWidget.php b/www/wiki/includes/widget/SearchInputWidget.php new file mode 100644 index 00000000..6fed7942 --- /dev/null +++ b/www/wiki/includes/widget/SearchInputWidget.php @@ -0,0 +1,72 @@ +<?php + +namespace MediaWiki\Widget; + +/** + * Search input widget. + * + * @copyright 2011-2015 MediaWiki Widgets Team and others; see AUTHORS.txt + * @license MIT + */ +class SearchInputWidget extends TitleInputWidget { + + protected $pushPending = false; + protected $performSearchOnClick = true; + protected $validateTitle = false; + protected $highlightFirst = false; + protected $dataLocation = 'header'; + + /** + * @param array $config Configuration options + * - int|null $config['pushPending'] Whether the input should be visually marked as + * "pending", while requesting suggestions (default: false) + * - bool|null $config['performSearchOnClick'] If true, the script will start a search + * whenever a user hits a suggestion. If false, the text of the suggestion is inserted into + * the text field only (default: true) + * - string $config['dataLocation'] Where the search input field will be + * used (header or content, default: header) + */ + public function __construct( array $config = [] ) { + $config = array_merge( [ + 'maxLength' => null, + 'icon' => 'search', + ], $config ); + + parent::__construct( $config ); + + // Properties, which are ignored in PHP and just shipped back to JS + if ( isset( $config['pushPending'] ) ) { + $this->pushPending = $config['pushPending']; + } + + if ( isset( $config['performSearchOnClick'] ) ) { + $this->performSearchOnClick = $config['performSearchOnClick']; + } + + if ( isset( $config['dataLocation'] ) ) { + // identifies the location of the search bar for tracking purposes + $this->dataLocation = $config['dataLocation']; + } + + // Initialization + $this->addClasses( [ 'mw-widget-searchInputWidget' ] ); + } + + protected function getInputElement( $config ) { + return ( new \OOUI\Tag( 'input' ) )->setAttributes( [ 'type' => 'search' ] ); + } + + protected function getJavaScriptClassName() { + return 'mw.widgets.SearchInputWidget'; + } + + public function getConfig( &$config ) { + $config['pushPending'] = $this->pushPending; + $config['performSearchOnClick'] = $this->performSearchOnClick; + if ( $this->dataLocation ) { + $config['dataLocation'] = $this->dataLocation; + } + $config['$overlay'] = true; + return parent::getConfig( $config ); + } +} |