%PDF- %PDF-
Direktori : /www/varak.net/wiki.varak.net/includes/widget/ |
Current File : /www/varak.net/wiki.varak.net/includes/widget/SearchInputWidget.php |
<?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 ); } }