mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
API Add buttonTooltop to PopoverField and fix critical positioning issue
This commit is contained in:
parent
d9537eb76b
commit
6b06fd9f2d
9
admin/client/dist/js/bundle.js
vendored
9
admin/client/dist/js/bundle.js
vendored
@ -2378,12 +2378,13 @@ var n=o(this,(t.__proto__||Object.getPrototypeOf(t)).call(this,e))
|
|||||||
return n.handleShow=n.handleShow.bind(n),n.handleHide=n.handleHide.bind(n),n.state={showing:!1},n}return a(t,e),s(t,[{key:"handleShow",value:function n(){this.setState({showing:!0})}},{key:"handleHide",
|
return n.handleShow=n.handleShow.bind(n),n.handleHide=n.handleHide.bind(n),n.state={showing:!1},n}return a(t,e),s(t,[{key:"handleShow",value:function n(){this.setState({showing:!0})}},{key:"handleHide",
|
||||||
value:function i(){this.setState({showing:!1})}},{key:"render",value:function l(){var e=this.getPlacement(),t=u["default"].createElement(c.Popover,{id:this.props.id+"_Popover",className:"fade in popover-"+e,
|
value:function i(){this.setState({showing:!1})}},{key:"render",value:function l(){var e=this.getPlacement(),t=u["default"].createElement(c.Popover,{id:this.props.id+"_Popover",className:"fade in popover-"+e,
|
||||||
title:this.props.data.popoverTitle},this.props.children),n=["btn","btn-secondary"]
|
title:this.props.data.popoverTitle},this.props.children),n=["btn","btn-secondary"]
|
||||||
return this.state.showing&&n.push("btn--no-focus"),this.props.title||n.push("font-icon-dot-3 btn--no-text btn--icon-xl"),u["default"].createElement(c.OverlayTrigger,{rootClose:!0,trigger:"click",container:this,
|
this.state.showing&&n.push("btn--no-focus"),this.props.title||n.push("font-icon-dot-3 btn--no-text btn--icon-xl")
|
||||||
placement:e,overlay:t,onEnter:this.handleShow,onExited:this.handleHide},u["default"].createElement("button",{id:this.props.id,type:"button",className:n.join(" ")},this.props.title))}},{key:"getPlacement",
|
var i={id:this.props.id,type:"button",className:n.join(" ")}
|
||||||
value:function d(){var e=this.props.data.placement
|
return this.props.data.buttonTooltip&&(i.title=this.props.data.buttonTooltip),u["default"].createElement(c.OverlayTrigger,{rootClose:!0,trigger:"click",placement:e,overlay:t,onEnter:this.handleShow,onExited:this.handleHide
|
||||||
|
},u["default"].createElement("button",i,this.props.title))}},{key:"getPlacement",value:function d(){var e=this.props.data.placement
|
||||||
return e||"bottom"}}]),t}(f["default"])
|
return e||"bottom"}}]),t}(f["default"])
|
||||||
p.propTypes={id:u["default"].PropTypes.string,title:u["default"].PropTypes.any,data:u["default"].PropTypes.oneOfType([u["default"].PropTypes.array,u["default"].PropTypes.shape({popoverTitle:u["default"].PropTypes.string,
|
p.propTypes={id:u["default"].PropTypes.string,title:u["default"].PropTypes.any,data:u["default"].PropTypes.oneOfType([u["default"].PropTypes.array,u["default"].PropTypes.shape({popoverTitle:u["default"].PropTypes.string,
|
||||||
placement:u["default"].PropTypes.oneOf(["top","right","bottom","left"])})])},t["default"]=p},function(e,t,n){"use strict"
|
buttonTooltip:u["default"].PropTypes.string,placement:u["default"].PropTypes.oneOf(["top","right","bottom","left"])})])},t["default"]=p},function(e,t,n){"use strict"
|
||||||
function i(e){return e&&e.__esModule?e:{"default":e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function o(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called")
|
function i(e){return e&&e.__esModule?e:{"default":e}}function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function o(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called")
|
||||||
|
|
||||||
|
|
||||||
|
@ -44,13 +44,23 @@ class PopoverField extends SilverStripeComponent {
|
|||||||
if (!this.props.title) {
|
if (!this.props.title) {
|
||||||
buttonClasses.push('font-icon-dot-3 btn--no-text btn--icon-xl');
|
buttonClasses.push('font-icon-dot-3 btn--no-text btn--icon-xl');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const buttonProps = {
|
||||||
|
id: this.props.id,
|
||||||
|
type: 'button',
|
||||||
|
className: buttonClasses.join(' '),
|
||||||
|
};
|
||||||
|
if (this.props.data.buttonTooltip) {
|
||||||
|
buttonProps.title = this.props.data.buttonTooltip;
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<OverlayTrigger rootClose trigger="click" container={this}
|
<OverlayTrigger rootClose trigger="click"
|
||||||
placement={placement} overlay={overlay}
|
placement={placement} overlay={overlay}
|
||||||
onEnter={this.handleShow}
|
onEnter={this.handleShow}
|
||||||
onExited={this.handleHide}
|
onExited={this.handleHide}
|
||||||
>
|
>
|
||||||
<button id={this.props.id} type="button" className={buttonClasses.join(' ')}>
|
<button {...buttonProps}>
|
||||||
{this.props.title}
|
{this.props.title}
|
||||||
</button>
|
</button>
|
||||||
</OverlayTrigger>
|
</OverlayTrigger>
|
||||||
@ -75,6 +85,7 @@ PopoverField.propTypes = {
|
|||||||
React.PropTypes.array,
|
React.PropTypes.array,
|
||||||
React.PropTypes.shape({
|
React.PropTypes.shape({
|
||||||
popoverTitle: React.PropTypes.string,
|
popoverTitle: React.PropTypes.string,
|
||||||
|
buttonTooltip: React.PropTypes.string,
|
||||||
placement: React.PropTypes.oneOf(['top', 'right', 'bottom', 'left']),
|
placement: React.PropTypes.oneOf(['top', 'right', 'bottom', 'left']),
|
||||||
}),
|
}),
|
||||||
]),
|
]),
|
||||||
|
@ -17,6 +17,7 @@ is represented by a button.
|
|||||||
* `title` (any): The title to display on the button to open the popover, if left blank it will display an ellipsis icon.
|
* `title` (any): The title to display on the button to open the popover, if left blank it will display an ellipsis icon.
|
||||||
* `data` (object) (required): Extra data that helps define this field uniquely.
|
* `data` (object) (required): Extra data that helps define this field uniquely.
|
||||||
* `popoverTitle` (string): The title to appear for the popover.
|
* `popoverTitle` (string): The title to appear for the popover.
|
||||||
|
* `buttonTooltip` (string): Title for button tooltip.
|
||||||
* `placement` (string): Where the popover will appear in relation to the button, options available are:
|
* `placement` (string): Where the popover will appear in relation to the button, options available are:
|
||||||
* top
|
* top
|
||||||
* right
|
* right
|
||||||
|
@ -38,6 +38,13 @@ class PopoverField extends FieldGroup
|
|||||||
*/
|
*/
|
||||||
protected $placement = 'bottom';
|
protected $placement = 'bottom';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tooltip to put on button
|
||||||
|
*
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $buttonTooltip = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get popup title
|
* Get popup title
|
||||||
*
|
*
|
||||||
@ -60,6 +67,24 @@ class PopoverField extends FieldGroup
|
|||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getButtonTooltip()
|
||||||
|
{
|
||||||
|
return $this->buttonTooltip;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $text
|
||||||
|
* @return $this
|
||||||
|
*/
|
||||||
|
public function setButtonTooltip($text)
|
||||||
|
{
|
||||||
|
$this->buttonTooltip = $text;
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get popup placement
|
* Get popup placement
|
||||||
*
|
*
|
||||||
@ -91,6 +116,7 @@ class PopoverField extends FieldGroup
|
|||||||
|
|
||||||
$schema['data']['popoverTitle'] = $this->getPopoverTitle();
|
$schema['data']['popoverTitle'] = $this->getPopoverTitle();
|
||||||
$schema['data']['placement'] = $this->getPlacement();
|
$schema['data']['placement'] = $this->getPlacement();
|
||||||
|
$schema['data']['buttonTooltip'] = $this->getButtonTooltip();
|
||||||
|
|
||||||
return $schema;
|
return $schema;
|
||||||
}
|
}
|
||||||
|
@ -295,6 +295,7 @@ class FormSchemaTest extends SapphireTest {
|
|||||||
'placement' => 'bottom',
|
'placement' => 'bottom',
|
||||||
'tag' => 'div',
|
'tag' => 'div',
|
||||||
'legend' => null,
|
'legend' => null,
|
||||||
|
'buttonTooltip' => null,
|
||||||
],
|
],
|
||||||
'validation' => [],
|
'validation' => [],
|
||||||
'children' => [
|
'children' => [
|
||||||
|
Loading…
Reference in New Issue
Block a user