Skip to content

Commit

Permalink
Merge pull request react-bootstrap#403 from stefanfisk/modal-style
Browse files Browse the repository at this point in the history
[added] bsStyle prop support for Modal to set the header color
  • Loading branch information
mtscout6 committed Feb 25, 2015
2 parents 0501216 + 13f395d commit 1ed8d50
Show file tree
Hide file tree
Showing 6 changed files with 28 additions and 5 deletions.
2 changes: 1 addition & 1 deletion docs/examples/ModalContained.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
var ContainedModal = React.createClass({
render: function() {
return (
<Modal {...this.props} title='Contained Modal' animation>
<Modal {...this.props} bsStyle="primary" title='Contained Modal' animation>
<div className="modal-body">
Elit est explicabo ipsum eaque dolorem blanditiis doloribus sed id ipsam, beatae, rem fuga id earum? Inventore et facilis obcaecati.
</div>
Expand Down
2 changes: 1 addition & 1 deletion docs/examples/ModalOverlayMixin.js
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ var CustomModalTrigger = React.createClass({
}

return (
<Modal title="Modal heading" onRequestHide={this.handleToggle}>
<Modal bsStyle="primary" title="Modal heading" onRequestHide={this.handleToggle}>
<div className="modal-body">
This modal is controlled by our custom trigger component.
</div>
Expand Down
1 change: 1 addition & 0 deletions docs/examples/ModalStatic.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ function handleHide() {
var modalInstance = (
<div className="static-modal">
<Modal title="Modal title"
bsStyle="primary"
backdrop={false}
animation={false}
container={mountNode}
Expand Down
2 changes: 1 addition & 1 deletion docs/examples/ModalTrigger.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
var MyModal = React.createClass({
render: function() {
return (
<Modal {...this.props} title="Modal heading" animation={false}>
<Modal {...this.props} bsStyle="primary" title="Modal heading" animation={false}>
<div className="modal-body">
<h4>Text in a modal</h4>
<p>Duis mollis, est non commodo luctus, nisi erat porttitor ligula.</p>
Expand Down
13 changes: 11 additions & 2 deletions src/Modal.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ var Modal = React.createClass({
onClick={this.props.backdrop === true ? this.handleBackdropClick : null}
ref="modal">
<div className={classSet(dialogClasses)}>
<div className="modal-content">
<div className="modal-content" style={{overflow: 'hidden'}}>
{this.props.title ? this.renderHeader() : null}
{this.props.children}
</div>
Expand Down Expand Up @@ -97,8 +97,17 @@ var Modal = React.createClass({
);
}

var style = this.props.bsStyle;
var classes = {
'modal-header': true
};
classes['bg-' + style] = style;
classes['text-' + style] = style;

var className = classSet(classes);

return (
<div className="modal-header">
<div className={className}>
{closeButton}
{this.renderTitle()}
</div>
Expand Down
13 changes: 13 additions & 0 deletions test/ModalSpec.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -85,4 +85,17 @@ describe('Modal', function () {
assert.ok(dialog.className.match(/\bmodal-sm\b/));
});

it('Should pass bsStyle to the header', function () {
var noOp = function () {};
var instance = ReactTestUtils.renderIntoDocument(
<Modal bsStyle='danger' title="Title" onRequestHide={noOp}>
<strong>Message</strong>
</Modal>
);

var header = instance.getDOMNode().getElementsByClassName('modal-header')[0];
assert.ok(header.className.match(/\bbg-danger\b/));
assert.ok(header.className.match(/\btext-danger\b/));
});

});

0 comments on commit 1ed8d50

Please sign in to comment.