Viewing File: /home/omtekel/www/wp-content/upgrade/backup/widget.tar
SizeFilterWidget.php 0000666 00000004510 15133501667 0010514 0 ustar 00 <?php
namespace MediaWiki\Widget;
use OOUI\LabelWidget;
use OOUI\RadioSelectInputWidget;
use OOUI\TextInputWidget;
/**
* Select and input widget.
*
* @copyright 2011-2018 MediaWiki Widgets Team and others; see AUTHORS.txt
* @license MIT
*/
class SizeFilterWidget extends \OOUI\Widget {
/** @var array */
protected $config;
/** @var LabelWidget */
protected $label;
/** @var RadioSelectInputWidget */
protected $radioselectinput;
/** @var TextInputWidget */
protected $textinput;
/**
* RadioSelectInputWidget and a TextInputWidget to set minimum or maximum byte size
*
* @param array $config Configuration options
* - array $config['textinput'] Configuration for the TextInputWidget
* - array $config['radioselectinput'] Configuration for the RadioSelectWidget
* - bool $config['selectMin'] Whether to select 'min', false would select 'max'
*/
public function __construct( array $config = [] ) {
// Configuration initialization
$config = array_merge( [
'selectMin' => true,
'textinput' => [],
'radioselectinput' => []
], $config );
$config['textinput'] = array_merge( [
'type' => 'number'
], $config['textinput'] );
$config['radioselectinput'] = array_merge( [ 'options' => [
[
'data' => 'min',
'label' => wfMessage( 'minimum-size' )->text()
],
[
'data' => 'max',
'label' => wfMessage( 'maximum-size' )->text()
]
] ], $config['radioselectinput'] );
// Parent constructor
parent::__construct( $config );
// Properties
$this->config = $config;
$this->radioselectinput = new RadioSelectInputWidget( $config[ 'radioselectinput'] );
$this->textinput = new TextInputWidget( $config[ 'textinput' ] );
$this->label = new LabelWidget( [ 'label' => wfMessage( 'pagesize' )->text() ] );
// Initialization
$this->radioselectinput->setValue( $config[ 'selectMin' ] ? 'min' : 'max' );
$this
->addClasses( [ 'mw-widget-sizeFilterWidget' ] )
->appendContent( $this->radioselectinput, $this->textinput, $this->label );
}
protected function getJavaScriptClassName() {
return 'mw.widgets.SizeFilterWidget';
}
public function getConfig( &$config ) {
$config['textinput'] = $this->config['textinput'];
$config['radioselectinput'] = $this->config['radioselectinput'];
$config['selectMin'] = $this->config['selectMin'];
return parent::getConfig( $config );
}
}
TagMultiselectWidget.php 0000666 00000005551 15133501667 0011370 0 ustar 00 <?php
namespace MediaWiki\Widget;
use OOUI\MultilineTextInputWidget;
/**
* Base class for widgets to select multiple users, titles,
* namespaces, etc.
*
* @copyright 2017 MediaWiki Widgets Team and others; see AUTHORS.txt
* @license MIT
*/
class TagMultiselectWidget extends \OOUI\Widget {
/** @var array */
protected $selectedArray;
/** @var string|null */
protected $inputName;
/** @var string|null */
protected $inputPlaceholder;
/** @var array */
protected $input;
/** @var int|null */
protected $tagLimit;
/** @var bool */
protected $allowArbitrary;
/** @var string[]|null */
protected $allowedValues;
/**
* @param array $config Configuration options
* - array $config['default'] Array of items to use as preset data
* - string $config['name'] Name attribute (used in forms)
* - string $config['placeholder'] Placeholder message for input
* - array $config['input'] Config options for the input widget
* - int $config['tagLimit'] Maximum number of selected items
* - bool $config['allowArbitrary'] Allow data items not present in the menu.
* - array $config['allowedValues'] Allowed items
*/
public function __construct( array $config = [] ) {
parent::__construct( $config );
// Properties
$this->selectedArray = $config['default'] ?? [];
$this->inputName = $config['name'] ?? null;
$this->inputPlaceholder = $config['placeholder'] ?? null;
$this->input = $config['input'] ?? [];
$this->tagLimit = $config['tagLimit'] ?? null;
$this->allowArbitrary = $config['allowArbitrary'] ?? false;
$this->allowedValues = $config['allowedValues'] ?? null;
$textarea = new MultilineTextInputWidget( array_merge( [
'name' => $this->inputName,
'value' => implode( "\n", $this->selectedArray ),
'rows' => min( $this->tagLimit, 10 ) ?? 10,
'classes' => [
'mw-widgets-tagMultiselectWidget-multilineTextInputWidget'
],
], $this->input ) );
$pending = new PendingTextInputWidget();
$this->appendContent( $textarea, $pending );
$this->addClasses( [ 'mw-widgets-tagMultiselectWidget' ] );
}
public function getConfig( &$config ) {
if ( $this->selectedArray !== null ) {
$config['selected'] = $this->selectedArray;
}
if ( $this->inputName !== null ) {
$config['name'] = $this->inputName;
}
if ( $this->inputPlaceholder !== null ) {
$config['placeholder'] = $this->inputPlaceholder;
}
if ( $this->input !== null ) {
$config['input'] = $this->input;
}
if ( $this->tagLimit !== null ) {
$config['tagLimit'] = $this->tagLimit;
}
if ( $this->allowArbitrary !== null ) {
$config['allowArbitrary'] = $this->allowArbitrary;
}
if ( $this->allowedValues !== null ) {
$config['allowedValues'] = $this->allowedValues;
}
$config['$overlay'] = true;
return parent::getConfig( $config );
}
protected function getJavaScriptClassName() {
return 'mw.widgets.TagMultiselectWidget';
}
}
Back to Directory
File Manager