diff options
author | Pierre Schmitz <pierre@archlinux.de> | 2015-12-20 09:00:55 +0100 |
---|---|---|
committer | Pierre Schmitz <pierre@archlinux.de> | 2015-12-20 09:00:55 +0100 |
commit | a2190ac74dd4d7080b12bab90e552d7aa81209ef (patch) | |
tree | 8b31f38de9882d18df54cf8d9e0de74167a094eb /vendor/oojs/oojs-ui/php/layouts/ActionFieldLayout.php | |
parent | 15e69f7b20b6596b9148030acce5b59993b95a45 (diff) | |
parent | 257401d8b2cf661adf36c84b0e3fd1cf85e33c22 (diff) |
Merge branch 'mw-1.26'
Diffstat (limited to 'vendor/oojs/oojs-ui/php/layouts/ActionFieldLayout.php')
-rw-r--r-- | vendor/oojs/oojs-ui/php/layouts/ActionFieldLayout.php | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/vendor/oojs/oojs-ui/php/layouts/ActionFieldLayout.php b/vendor/oojs/oojs-ui/php/layouts/ActionFieldLayout.php new file mode 100644 index 00000000..bf908184 --- /dev/null +++ b/vendor/oojs/oojs-ui/php/layouts/ActionFieldLayout.php @@ -0,0 +1,55 @@ +<?php + +namespace OOUI; + +/** + * Layout made of a field, button and optional label. + */ +class ActionFieldLayout extends FieldLayout { + + /** + * Button widget to be laid out. + * + * @var Widget + */ + protected $buttonWidget; + + /** + * @param Widget $fieldWidget Field widget + * @param ButtonWidget $buttonWidget Field widget + * @param array $config Configuration options + */ + public function __construct( $fieldWidget, $buttonWidget = false, array $config = array() ) { + // Allow passing positional parameters inside the config array + if ( is_array( $fieldWidget ) && isset( $fieldWidget['fieldWidget'] ) ) { + $config = $fieldWidget; + $fieldWidget = $config['fieldWidget']; + $buttonWidget = $config['buttonWidget']; + } + + // Parent constructor + parent::__construct( $fieldWidget, $config ); + + // Properties + $this->buttonWidget = $buttonWidget; + $this->button = new Tag( 'div' ); + $this->input = new Tag( 'div' ); + + // Initialization + $this->addClasses( array( 'oo-ui-actionFieldLayout' ) ); + $this->button + ->addClasses( array( 'oo-ui-actionFieldLayout-button' ) ) + ->appendContent( $this->buttonWidget ); + $this->input + ->addClasses( array( 'oo-ui-actionFieldLayout-input' ) ) + ->appendContent( $this->fieldWidget ); + $this->field + ->clearContent() + ->appendContent( $this->input, $this->button ); + } + + public function getConfig( &$config ) { + $config['buttonWidget'] = $this->buttonWidget; + return parent::getConfig( $config ); + } +} |