summaryrefslogtreecommitdiff
path: root/www/wiki/includes/widget/SearchInputWidget.php
diff options
context:
space:
mode:
Diffstat (limited to 'www/wiki/includes/widget/SearchInputWidget.php')
-rw-r--r--www/wiki/includes/widget/SearchInputWidget.php72
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 );
+ }
+}