Merge pull request #368 from benjycui/feature-button

chore: replace `button` tag with `Button` component
This commit is contained in:
偏右 2015-10-09 15:47:14 +08:00
commit 88f6be5855
54 changed files with 180 additions and 147 deletions

View File

@ -8,10 +8,11 @@
````jsx ````jsx
var Affix = antd.Affix; var Affix = antd.Affix;
var Button = antd.Button;
React.render( React.render(
<Affix> <Affix>
<button className="ant-btn ant-btn-primary">固定在顶部</button> <Button type="primary">固定在顶部</Button>
</Affix> </Affix>
, document.getElementById('components-affix-demo-basic')); , document.getElementById('components-affix-demo-basic'));
```` ````

View File

@ -8,10 +8,11 @@
````jsx ````jsx
var Affix = antd.Affix; var Affix = antd.Affix;
var Button = antd.Button;
React.render( React.render(
<Affix offset={75}> <Affix offset={75}>
<button className="ant-btn ant-btn-primary">固定在距离顶部 75px 的位置</button> <Button type="primary">固定在距离顶部 75px 的位置</Button>
</Affix> </Affix>
, document.getElementById('components-affix-demo-offset')); , document.getElementById('components-affix-demo-offset'));
```` ````

View File

@ -1,25 +0,0 @@
# 菜单按钮
- order: 5
**注**: 下拉按钮的 icon 大小统一成 **10px**
> 更多交互,详见 [Dropdown 下拉菜单](http://ant.design/components/dropdown/)。
---
````jsx
var Icon = antd.Icon;
React.render(
<div className="nico-insert-code">
<button className="ant-btn ant-btn-primary ant-btn-menu">
<span>菜单按钮</span>
<Icon type="down" />
</button>
<button className="ant-btn ant-btn-ghost ant-btn-circle ant-btn-menu">
<Icon type="down" />
</button>
</div>
, document.getElementById('components-button-demo-menu'));
````

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var Checkbox = antd.Checkbox; var Checkbox = antd.Checkbox;
var Button = antd.Button;
var container = document.getElementById('components-checkbox-demo-controller'); var container = document.getElementById('components-checkbox-demo-controller');
var App = React.createClass({ var App = React.createClass({
@ -30,15 +31,15 @@ var App = React.createClass({
</label> </label>
</p> </p>
<p> <p>
<button className="ant-btn ant-btn-primary ant-btn-sm" <Button type="primary" size="sm"
onClick={this.toggleChecked}> onClick={this.toggleChecked}>
{!this.state.checked ? "选中":"取消"} {!this.state.checked ? "选中":"取消"}
</button> </Button>
<button style={{'marginLeft': '10px'}} <Button style={{'marginLeft': '10px'}}
className="ant-btn ant-btn-primary ant-btn-sm" type="primary" size="sm"
onClick={this.toggleDisable}> onClick={this.toggleDisable}>
{!this.state.disabled ? "不可用":"可用"} {!this.state.disabled ? "不可用":"可用"}
</button> </Button>
</p> </p>
</div>; </div>;
}, },

View File

@ -9,6 +9,7 @@
````jsx ````jsx
var Menu = antd.Menu; var Menu = antd.Menu;
var Dropdown = antd.Dropdown; var Dropdown = antd.Dropdown;
var Button = antd.Button;
var Icon = antd.Icon; var Icon = antd.Icon;
var menu = <Menu> var menu = <Menu>
@ -25,9 +26,9 @@ var menu = <Menu>
React.render( React.render(
<Dropdown overlay={menu}> <Dropdown overlay={menu}>
<button className="ant-btn ant-btn-menu"> <Button>
某按钮 <Icon type="down" /> 某按钮 <Icon type="down" />
</button> </Button>
</Dropdown> </Dropdown>
, document.getElementById('components-dropdown-demo-basic')); , document.getElementById('components-dropdown-demo-basic'));
```` ````

View File

@ -9,6 +9,7 @@
````jsx ````jsx
var Menu = antd.Menu; var Menu = antd.Menu;
var Dropdown = antd.Dropdown; var Dropdown = antd.Dropdown;
var Button = antd.Button;
var Icon = antd.Icon; var Icon = antd.Icon;
var onSelect = function ({key}){ var onSelect = function ({key}){
alert('选中了菜单' + key); alert('选中了菜单' + key);
@ -22,9 +23,9 @@ var menu = <Menu onSelect={onSelect}>
React.render( React.render(
<Dropdown overlay={menu}> <Dropdown overlay={menu}>
<button className="ant-btn ant-btn-menu"> <Button>
鼠标移入,点击菜单 <Icon type="down" /> 鼠标移入,点击菜单 <Icon type="down" />
</button> </Button>
</Dropdown> </Dropdown>
, document.getElementById('components-dropdown-demo-event')); , document.getElementById('components-dropdown-demo-event'));
```` ````

View File

@ -9,6 +9,7 @@
````jsx ````jsx
var Menu = antd.Menu; var Menu = antd.Menu;
var Dropdown = antd.Dropdown; var Dropdown = antd.Dropdown;
var Button = antd.Button;
var Icon = antd.Icon; var Icon = antd.Icon;
var menu = <Menu> var menu = <Menu>
@ -24,9 +25,9 @@ var menu = <Menu>
React.render( React.render(
<Dropdown overlay={menu}> <Dropdown overlay={menu}>
<button className="ant-btn ant-btn-menu"> <Button>
鼠标移入 <Icon type="down" /> 鼠标移入 <Icon type="down" />
</button> </Button>
</Dropdown> </Dropdown>
, document.getElementById('components-dropdown-demo-item')); , document.getElementById('components-dropdown-demo-item'));
```` ````

View File

@ -9,6 +9,7 @@
````jsx ````jsx
var Menu = antd.Menu; var Menu = antd.Menu;
var Dropdown = antd.Dropdown; var Dropdown = antd.Dropdown;
var Button = antd.Button;
var Icon = antd.Icon; var Icon = antd.Icon;
var menu = <Menu> var menu = <Menu>
@ -24,14 +25,14 @@ var menu = <Menu>
React.render(<div> React.render(<div>
<Dropdown overlay={menu} trigger="click"> <Dropdown overlay={menu} trigger="click">
<button className="ant-btn ant-btn-primary ant-btn-menu"> <Button type="primary">
点击触发 <Icon type="down" /> 点击触发 <Icon type="down" />
</button> </Button>
</Dropdown> </Dropdown>
<Dropdown overlay={menu}> <Dropdown overlay={menu}>
<button className="ant-btn ant-btn-menu"> <Button>
鼠标移入 <Icon type="down" /> 鼠标移入 <Icon type="down" />
</button> </Button>
</Dropdown> </Dropdown>
</div>, document.getElementById('components-dropdown-demo-trigger')); </div>, document.getElementById('components-dropdown-demo-trigger'));
```` ````

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var EnterAnimation = antd.EnterAnimation; var EnterAnimation = antd.EnterAnimation;
var Button = antd.Button;
var Test = React.createClass({ var Test = React.createClass({
getInitialState() { getInitialState() {
@ -24,7 +25,7 @@ var Test = React.createClass({
return ( return (
<div> <div>
<div style={{marginBottom: 20}}> <div style={{marginBottom: 20}}>
<button className="ant-btn ant-btn-primary" onClick={this.onClick}>切换</button> <Button type="primary" onClick={this.onClick}>切换</Button>
</div> </div>
<EnterAnimation> <EnterAnimation>
{this.state.show ? {this.state.show ?

View File

@ -9,6 +9,7 @@
````jsx ````jsx
var EnterAnimation = antd.EnterAnimation; var EnterAnimation = antd.EnterAnimation;
var Button = antd.Button;
var Test = React.createClass({ var Test = React.createClass({
getInitialState() { getInitialState() {
@ -33,7 +34,7 @@ var Test = React.createClass({
return ( return (
<div> <div>
<div style={{marginBottom: 20}}> <div style={{marginBottom: 20}}>
<button className="ant-btn ant-btn-primary" onClick={this.onClick}>切换</button> <Button type="primary" onClick={this.onClick}>切换</Button>
</div> </div>
<EnterAnimation enter={this.state.enter} leave={this.state.leave}> <EnterAnimation enter={this.state.enter} leave={this.state.leave}>
{this.state.show ? <div key='enter-data'> {this.state.show ? <div key='enter-data'>

View File

@ -9,6 +9,7 @@
````jsx ````jsx
var EnterAnimation = antd.EnterAnimation; var EnterAnimation = antd.EnterAnimation;
var Button = antd.Button;
var Test = React.createClass({ var Test = React.createClass({
getInitialState() { getInitialState() {
@ -40,7 +41,7 @@ var Test = React.createClass({
return ( return (
<div> <div>
<div style={{marginBottom: 20}}> <div style={{marginBottom: 20}}>
<button className="ant-btn ant-btn-primary" onClick={this.onClick}>切换</button> <Button type="primary" onClick={this.onClick}>切换</Button>
</div> </div>
<EnterAnimation enter={this.state.enter} leave={this.state.leave}> <EnterAnimation enter={this.state.enter} leave={this.state.leave}>
{this.state.show ? {this.state.show ?

View File

@ -13,6 +13,7 @@ var Option = Select.Option;
var Checkbox = antd.Checkbox; var Checkbox = antd.Checkbox;
var Radio = antd.Radio; var Radio = antd.Radio;
var RadioGroup = antd.Radio.Group; var RadioGroup = antd.Radio.Group;
var Button = antd.Button;
var Test = React.createClass({ var Test = React.createClass({
getInitialState() { getInitialState() {
@ -43,7 +44,7 @@ var Test = React.createClass({
return ( return (
<div> <div>
<div style={{marginBottom: 20, textAlign: 'center'}}> <div style={{marginBottom: 20, textAlign: 'center'}}>
<button className="ant-btn ant-btn-primary" onClick={this.onClick}>切换</button> <Button type="primary" onClick={this.onClick}>切换</Button>
</div> </div>
<EnterAnimation enter={this.state.enter} leave={this.state.leave} component='form' className="ant-form-horizontal"> <EnterAnimation enter={this.state.enter} leave={this.state.leave} component='form' className="ant-form-horizontal">
{this.state.show ? <div key='from'> {this.state.show ? <div key='from'>
@ -85,7 +86,7 @@ var Test = React.createClass({
</div> </div>
<div className="row"> <div className="row">
<div className="col-16 col-offset-6"> <div className="col-16 col-offset-6">
<input type="submit" className="ant-btn ant-btn-primary" value="确 定" /> <Button type="primary">确定</Button>
</div> </div>
</div> </div>
</div> : null} </div> : null}

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var EnterAnimation = antd.EnterAnimation; var EnterAnimation = antd.EnterAnimation;
var Button = antd.Button;
var Test = React.createClass({ var Test = React.createClass({
getInitialState() { getInitialState() {
@ -34,7 +35,7 @@ var Test = React.createClass({
return ( return (
<div> <div>
<div style={{marginBottom: 20}}> <div style={{marginBottom: 20}}>
<button className="ant-btn ant-btn-primary" onClick={this.onClick}>切换</button> <Button type="primary" onClick={this.onClick}>切换</Button>
</div> </div>
<EnterAnimation enter={this.state.enter} leave={this.state.leave}> <EnterAnimation enter={this.state.enter} leave={this.state.leave}>
{this.state.show ? <div key='a'> {this.state.show ? <div key='a'>

View File

@ -9,6 +9,7 @@
````jsx ````jsx
var EnterAnimation = antd.EnterAnimation; var EnterAnimation = antd.EnterAnimation;
var Button = antd.Button;
var Test = React.createClass({ var Test = React.createClass({
getInitialState() { getInitialState() {
@ -35,7 +36,7 @@ var Test = React.createClass({
return ( return (
<div> <div>
<div style={{marginBottom: 20}}> <div style={{marginBottom: 20}}>
<button className="ant-btn ant-btn-primary" onClick={this.onClick}>切换</button> <Button type="primary" onClick={this.onClick}>切换</Button>
</div> </div>
<EnterAnimation enter={this.state.enter} leave={this.state.leave}> <EnterAnimation enter={this.state.enter} leave={this.state.leave}>
{this.state.show ? <div key='enter-data'> {this.state.show ? <div key='enter-data'>

View File

@ -16,6 +16,7 @@
var Checkbox = antd.Checkbox; var Checkbox = antd.Checkbox;
var Radio = antd.Radio; var Radio = antd.Radio;
var RadioGroup = antd.Radio.Group; var RadioGroup = antd.Radio.Group;
var Button = antd.Button;
React.render( React.render(
<form className="ant-form-horizontal"> <form className="ant-form-horizontal">
@ -56,7 +57,7 @@ React.render(
</div> </div>
<div className="row"> <div className="row">
<div className="col-16 col-offset-6"> <div className="col-16 col-offset-6">
<input type="submit" className="ant-btn ant-btn-primary" value="确 定" /> <Button type="primary">确定</Button>
</div> </div>
</div> </div>
</form> </form>

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var Checkbox = antd.Checkbox; var Checkbox = antd.Checkbox;
var Button = antd.Button;
React.render( React.render(
<form className="ant-form-inline"> <form className="ant-form-inline">
@ -24,7 +25,7 @@ React.render(
<Checkbox /> 记住我 <Checkbox /> 记住我
</label> </label>
</div> </div>
<input type="submit" className="ant-btn ant-btn-primary" value="登 录" /> <Button type="primary">登录</Button>
</form> </form>
, document.getElementById('components-form-demo-inline-form')); , document.getElementById('components-form-demo-inline-form'));
```` ````

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var InputNumber = antd.InputNumber; var InputNumber = antd.InputNumber;
var Button = antd.Button;
var Test = React.createClass({ var Test = React.createClass({
getInitialState() { getInitialState() {
@ -24,7 +25,7 @@ var Test = React.createClass({
return <div> return <div>
<InputNumber min={1} max={10} disabled={this.state.disabled} defaultValue={3} /> <InputNumber min={1} max={10} disabled={this.state.disabled} defaultValue={3} />
<div style={{marginTop: 20}}> <div style={{marginTop: 20}}>
<button onClick={this.toggle} className="ant-btn ant-btn-primary">Toggle disabled</button> <Button onClick={this.toggle} type="primary">Toggle disabled</Button>
</div> </div>
</div>; </div>;
} }

View File

@ -7,13 +7,14 @@
--- ---
````jsx ````jsx
var Button = antd.Button;
var message = antd.message; var message = antd.message;
var success = function() { var success = function() {
message.success('这是一条成功的提示,并将于10秒后消失', 10); message.success('这是一条成功的提示,并将于10秒后消失', 10);
}; };
React.render(<button className="ant-btn ant-btn-primary" onClick={success}>自定义时长提示</button> React.render(<Button type="primary" onClick={success}>自定义时长提示</Button>
, document.getElementById('components-message-demo-duration')); , document.getElementById('components-message-demo-duration'));
```` ````

View File

@ -7,12 +7,13 @@
--- ---
````jsx ````jsx
var Button = antd.Button;
var message = antd.message; var message = antd.message;
var error = function() { var error = function() {
message.error('这是一条失败的提示这是一条失败的提示这是一条失败的提示'); message.error('这是一条失败的提示这是一条失败的提示这是一条失败的提示');
}; };
React.render(<button className="ant-btn ant-btn-primary" onClick={error}>显示失败提示</button> React.render(<Button type="primary" onClick={error}>显示失败提示</Button>
, document.getElementById('components-message-demo-error')); , document.getElementById('components-message-demo-error'));
```` ````

View File

@ -7,12 +7,13 @@
--- ---
````jsx ````jsx
var Button = antd.Button;
var message = antd.message; var message = antd.message;
var info = function() { var info = function() {
message.info('这是一条普通的提醒'); message.info('这是一条普通的提醒');
}; };
React.render(<button className="ant-btn ant-btn-primary" onClick={info}>显示普通提醒</button> React.render(<Button type="primary" onClick={info}>显示普通提醒</Button>
, document.getElementById('components-message-demo-info')); , document.getElementById('components-message-demo-info'));
```` ````

View File

@ -7,14 +7,15 @@
--- ---
````jsx ````jsx
var message = antd.message; var Button = antd.Button;
var message = antd.message;
var success = function() { var success = function() {
var hide = message.loading('正在执行中...', 0); var hide = message.loading('正在执行中...', 0);
// 异步手动移除 // 异步手动移除
setTimeout(hide, 2500); setTimeout(hide, 2500);
}; };
React.render(<button className="ant-btn" onClick={success}>显示加载中...</button> React.render(<Button onClick={success}>显示加载中...</Button>
, document.getElementById('components-message-demo-loading')); , document.getElementById('components-message-demo-loading'));
```` ````

View File

@ -7,13 +7,14 @@
--- ---
````jsx ````jsx
var message = antd.message; var Button = antd.Button;
var message = antd.message;
var success = function() { var success = function() {
message.success('这是一条成功的提示'); message.success('这是一条成功的提示');
}; };
React.render(<button className="ant-btn ant-btn-primary" onClick={success}>显示成功提示</button> React.render(<Button type="primary" onClick={success}>显示成功提示</Button>
, document.getElementById('components-message-demo-success')); , document.getElementById('components-message-demo-success'));
```` ````

View File

@ -1,6 +1,7 @@
import React from 'react'; import React from 'react';
import Dialog from './index'; import Dialog from './index';
import Icon from '../iconfont'; import Icon from '../iconfont';
import {Button} from '../button';
export default function (props) { export default function (props) {
let div = document.createElement('div'); let div = document.createElement('div');
@ -71,18 +72,18 @@ export default function (props) {
<div className="ant-confirm-content">{props.content}</div> <div className="ant-confirm-content">{props.content}</div>
</div>; </div>;
let footer = <div className="ant-confirm-btns"> let footer = <div className="ant-confirm-btns">
<button type="button" className="ant-btn-default ant-btn ant-btn-lg" onClick={onCancel}> </button> <Button size="lg" onClick={onCancel}> </Button>
<button type="button" className="ant-btn-primary ant-btn ant-btn-lg" onClick={onOk}> </button> <Button type="primary" size="lg" onClick={onOk}> </Button>
</div>; </div>;
if (props.okCancel) { if (props.okCancel) {
footer = <div className="ant-confirm-btns"> footer = <div className="ant-confirm-btns">
<button type="button" className="ant-btn-default ant-btn ant-btn-lg" onClick={onCancel}> </button> <Button size="lg" onClick={onCancel}> </Button>
<button type="button" className="ant-btn-primary ant-btn ant-btn-lg" onClick={onOk}> </button> <Button type="primary" size="lg" onClick={onOk}> </Button>
</div>; </div>;
} else { } else {
footer = <div className="ant-confirm-btns"> footer = <div className="ant-confirm-btns">
<button type="button" className="ant-btn-primary ant-btn ant-btn-lg" onClick={onOk}>知道了</button> <Button type="primary" size="lg" onClick={onOk}>知道了</Button>
</div>; </div>;
} }

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var Modal = antd.Modal; var Modal = antd.Modal;
var Button = antd.Button;
var App = React.createClass({ var App = React.createClass({
getInitialState() { getInitialState() {
@ -32,7 +33,7 @@ var App = React.createClass({
}, },
render() { render() {
return <div> return <div>
<button className="ant-btn ant-btn-primary" onClick={this.showModal}>显示对话框</button> <Button type="primary" onClick={this.showModal}>显示对话框</Button>
<Modal title="第一个 Modal" visible={this.state.visible} <Modal title="第一个 Modal" visible={this.state.visible}
confirmLoading={this.state.confirmLoading} onOk={this.handleOk} onCancel={this.handleCancel}> confirmLoading={this.state.confirmLoading} onOk={this.handleOk} onCancel={this.handleCancel}>
<p>对话框的内容</p> <p>对话框的内容</p>

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var confirm = antd.Modal.confirm; var confirm = antd.Modal.confirm;
var Button = antd.Button;
function showConfirm(){ function showConfirm(){
confirm({ confirm({
@ -24,7 +25,7 @@ function showConfirm(){
} }
React.render( React.render(
<button className="ant-btn" onClick={showConfirm}> <Button onClick={showConfirm}>
确认对话框 确认对话框
</button>, document.getElementById('components-modal-demo-confirm-promise')); </Button>, document.getElementById('components-modal-demo-confirm-promise'));
```` ````

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var confirm = antd.Modal.confirm; var confirm = antd.Modal.confirm;
var Button = antd.Button;
function showConfirm(){ function showConfirm(){
confirm({ confirm({
@ -21,7 +22,7 @@ function showConfirm(){
} }
React.render( React.render(
<button className="ant-btn" onClick={showConfirm}> <Button onClick={showConfirm}>
确认对话框 确认对话框
</button>, document.getElementById('components-modal-demo-confirm')); </Button>, document.getElementById('components-modal-demo-confirm'));
```` ````

View File

@ -8,6 +8,8 @@
````jsx ````jsx
var Modal = antd.Modal; var Modal = antd.Modal;
var Button = antd.Button;
var ModalText = '对话框的内容'; var ModalText = '对话框的内容';
var Test = React.createClass({ var Test = React.createClass({
@ -40,7 +42,7 @@ var Test = React.createClass({
}, },
render() { render() {
return <div> return <div>
<button className="ant-btn ant-btn-primary" onClick={this.showModal}>显示对话框</button> <Button type="primary" onClick={this.showModal}>显示对话框</Button>
<Modal title="对话框标题" <Modal title="对话框标题"
visible={this.state.visible} visible={this.state.visible}
onOk={this.handleOk} onOk={this.handleOk}

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var Modal = antd.Modal; var Modal = antd.Modal;
var Button = antd.Button;
var Test = React.createClass({ var Test = React.createClass({
getInitialState: function() { getInitialState: function() {
@ -32,17 +33,17 @@ var Test = React.createClass({
}, },
render() { render() {
return <div> return <div>
<button className="ant-btn ant-btn-primary" onClick={this.showModal}> <Button type="primary" onClick={this.showModal}>
显示对话框 显示对话框
</button> </Button>
<Modal ref="modal" <Modal ref="modal"
visible={this.state.visible} visible={this.state.visible}
title="对话框标题" onOk={this.handleOk} onCancel={this.handleCancel} title="对话框标题" onOk={this.handleOk} onCancel={this.handleCancel}
footer={[ footer={[
<button key="back" className="ant-btn ant-btn-lg" onClick={this.handleCancel}>返 回</button>, <Button key="back" size="lg" onClick={this.handleCancel}>返 回</Button>,
<button key="submit" className={'ant-btn ant-btn-primary ant-btn-lg ' + (this.state.loading?'ant-btn-loading':'')} onClick={this.handleOk}> <Button key="submit" type="primary" size="lg" loading={this.state.loading} onClick={this.handleOk}>
提 交 提 交
</button> </Button>
]}> ]}>
<p>对话框的内容</p> <p>对话框的内容</p>
<p>对话框的内容</p> <p>对话框的内容</p>

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var Modal = antd.Modal; var Modal = antd.Modal;
var Button = antd.Button;
function info() { function info() {
Modal.info({ Modal.info({
@ -37,9 +38,9 @@ function error() {
} }
React.render(<div> React.render(<div>
<button className="ant-btn" onClick={info}>信息提示</button> <Button onClick={info}>信息提示</Button>
<button className="ant-btn" onClick={success}>成功提示</button> <Button onClick={success}>成功提示</Button>
<button className="ant-btn" onClick={error}>失败提示</button> <Button onClick={error}>失败提示</Button>
</div>, document.getElementById('components-modal-demo-info')); </div>, document.getElementById('components-modal-demo-info'));
```` ````

View File

@ -2,6 +2,7 @@ import React from 'react';
import Dialog from 'rc-dialog'; import Dialog from 'rc-dialog';
import { Dom } from 'rc-util'; import { Dom } from 'rc-util';
import confirm from './confirm'; import confirm from './confirm';
import { Button } from '../button';
function noop() { function noop() {
} }
@ -73,16 +74,16 @@ let AntModal = React.createClass({
}, },
render() { render() {
let loadingClass = this.state.confirmLoading ? ' ant-btn-loading' : '';
let props = this.props; let props = this.props;
let defaultFooter = [ let defaultFooter = [
<button key="cancel" type="button" className="ant-btn ant-btn-lg" onClick={this.handleCancel}> </button>, <Button key="cancel" size="lg" onClick={this.handleCancel}> </Button>,
<button key="confirm" <Button key="confirm"
type="button" type="primary"
className={'ant-btn ant-btn-primary ant-btn-lg' + loadingClass} size="lg"
loading={this.state.confirmLoading}
onClick={this.handleOk}> onClick={this.handleOk}>
</button> </Button>
]; ];
let footer = props.footer || defaultFooter; let footer = props.footer || defaultFooter;
let visible = this.state.visible; let visible = this.state.visible;

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var notification = antd.Notification; var notification = antd.Notification;
var Button = antd.Button;
var openNotification = function() { var openNotification = function() {
notification.open({ notification.open({
@ -18,7 +19,7 @@ var openNotification = function() {
React.render( React.render(
<div> <div>
<button className='ant-btn ant-btn-primary' onClick={openNotification}>打开通知提醒框</button> <Button type="primary" onClick={openNotification}>打开通知提醒框</Button>
</div>, </div>,
document.getElementById('components-notification-demo-basic')); document.getElementById('components-notification-demo-basic'));
```` ````

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var notification = antd.Notification; var notification = antd.Notification;
var Button = antd.Button;
var openNotification = function() { var openNotification = function() {
var args = { var args = {
@ -19,6 +20,6 @@ var openNotification = function() {
}; };
React.render( React.render(
<button className='ant-btn ant-btn-primary' onClick={openNotification}>打开通知提醒框</button> <Button type="primary" onClick={openNotification}>打开通知提醒框</Button>
, document.getElementById('components-notification-demo-duration')); , document.getElementById('components-notification-demo-duration'));
```` ````

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var notification = antd.Notification; var notification = antd.Notification;
var Button = antd.Button;
var close = function() { var close = function() {
console.log("我被默认的关闭按钮关闭了!"); console.log("我被默认的关闭按钮关闭了!");
@ -24,7 +25,7 @@ var openNotification = function() {
React.render( React.render(
<div> <div>
<button className='ant-btn ant-btn-primary' onClick={openNotification}>打开通知提醒框</button> <Button type="primary" onClick={openNotification}>打开通知提醒框</Button>
</div>, </div>,
document.getElementById('components-notification-demo-onclose')); document.getElementById('components-notification-demo-onclose'));
```` ````

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var notification = antd.Notification; var notification = antd.Notification;
var Button = antd.Button;
var close = function(){ var close = function(){
console.log('我被默认的关闭按钮关闭了!'); console.log('我被默认的关闭按钮关闭了!');
@ -19,9 +20,9 @@ var openNotification = function() {
// 隐藏提醒框 // 隐藏提醒框
notification.close(key); notification.close(key);
}; };
var btn = <button className="ant-btn ant-btn-primary ant-btn-sm" onClick={btnClick}> var btn = <Button type="primary" size="sm" onClick={btnClick}>
自定义关闭按钮并触发回调函数 自定义关闭按钮并触发回调函数
</button>; </Button>;
notification.open({ notification.open({
message: "这是标题", message: "这是标题",
description: "这是提示框的文案这是提示框示框的文案这是提示是提示框的文案这是提示框的文案", description: "这是提示框的文案这是提示框示框的文案这是提示是提示框的文案这是提示框的文案",
@ -33,7 +34,7 @@ var openNotification = function() {
React.render( React.render(
<div> <div>
<button className="ant-btn ant-btn-primary" onClick={openNotification}>打开通知提醒框</button> <Button type="primary" onClick={openNotification}>打开通知提醒框</Button>
</div>, </div>,
document.getElementById('components-notification-demo-with-btn')); document.getElementById('components-notification-demo-with-btn'));
```` ````

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var notification = antd.Notification; var notification = antd.Notification;
var Button = antd.Button;
var openNotificationWithIcon = function(type) { var openNotificationWithIcon = function(type) {
return function(){ return function(){
@ -19,10 +20,10 @@ var openNotificationWithIcon = function(type) {
}; };
React.render(<div> React.render(<div>
<button className="ant-btn" onClick={openNotificationWithIcon('success')}>成功</button> <Button onClick={openNotificationWithIcon('success')}>成功</Button>
<button className="ant-btn" onClick={openNotificationWithIcon('info')}>消息</button> <Button onClick={openNotificationWithIcon('info')}>消息</Button>
<button className="ant-btn" onClick={openNotificationWithIcon('warn')}>警告</button> <Button onClick={openNotificationWithIcon('warn')}>警告</Button>
<button className="ant-btn" onClick={openNotificationWithIcon('error')}>错误</button> <Button onClick={openNotificationWithIcon('error')}>错误</Button>
</div> </div>
, document.getElementById('components-notification-demo-with-icon')); , document.getElementById('components-notification-demo-with-icon'));
```` ````

View File

@ -1,6 +1,7 @@
import React from 'react'; import React from 'react';
import Tooltip from 'rc-tooltip'; import Tooltip from 'rc-tooltip';
import Icon from '../iconfont'; import Icon from '../iconfont';
import { Button } from '../button';
const prefixCls = 'ant-popover'; const prefixCls = 'ant-popover';
export default React.createClass({ export default React.createClass({
@ -47,8 +48,8 @@ export default React.createClass({
</p> </p>
<div className={prefixCls + '-buttons'}> <div className={prefixCls + '-buttons'}>
<button onClick={this.cancel} className="ant-btn ant-btn-sm"> </button> <Button onClick={this.cancel} size="sm"> </Button>
<button onClick={this.confirm} className="ant-btn ant-btn-primary ant-btn-sm"> </button> <Button onClick={this.confirm} type="primary" size="sm"> </Button>
</div> </div>
</div> </div>
</div>; </div>;

View File

@ -8,6 +8,8 @@
````jsx ````jsx
var Popover = antd.Popover; var Popover = antd.Popover;
var Button = antd.Button;
var content = <div> var content = <div>
<p>内容</p> <p>内容</p>
<p>内容</p> <p>内容</p>
@ -15,7 +17,7 @@ var content = <div>
React.render( React.render(
<Popover overlay={content} title="标题"> <Popover overlay={content} title="标题">
<button className="ant-btn ant-btn-primary">弹出卡片</button> <Button type="primary">弹出卡片</Button>
</Popover> </Popover>
, document.getElementById('components-popover-demo-basic')); , document.getElementById('components-popover-demo-basic'));
```` ````

View File

@ -8,6 +8,8 @@
````jsx ````jsx
var Popover = antd.Popover; var Popover = antd.Popover;
var Button = antd.Button;
var text = <span>标题</span>; var text = <span>标题</span>;
var content = <div> var content = <div>
<p>内容</p> <p>内容</p>
@ -16,16 +18,16 @@ var content = <div>
React.render(<div> React.render(<div>
<Popover placement="left" title={text} overlay={content}> <Popover placement="left" title={text} overlay={content}>
<button className="ant-btn"></button> <Button></Button>
</Popover> </Popover>
<Popover placement="top" title={text} overlay={content}> <Popover placement="top" title={text} overlay={content}>
<button className="ant-btn"></button> <Button></Button>
</Popover> </Popover>
<Popover placement="bottom" title={text} overlay={content}> <Popover placement="bottom" title={text} overlay={content}>
<button className="ant-btn"></button> <Button></Button>
</Popover> </Popover>
<Popover placement="right" title={text} overlay={content}> <Popover placement="right" title={text} overlay={content}>
<button className="ant-btn"></button> <Button></Button>
</Popover> </Popover>
</div>, document.getElementById('components-popover-demo-placement')); </div>, document.getElementById('components-popover-demo-placement'));
```` ````

View File

@ -8,6 +8,8 @@
````jsx ````jsx
var Popover = antd.Popover; var Popover = antd.Popover;
var Button = antd.Button;
var content = <div> var content = <div>
<p>内容</p> <p>内容</p>
<p>内容</p> <p>内容</p>
@ -15,13 +17,13 @@ var content = <div>
React.render(<div> React.render(<div>
<Popover overlay={content} title="标题" trigger="hover"> <Popover overlay={content} title="标题" trigger="hover">
<button className="ant-btn">移入</button> <Button>移入</Button>
</Popover> </Popover>
<Popover overlay={content} title="标题" trigger="focus"> <Popover overlay={content} title="标题" trigger="focus">
<a href="javascript:;" className="ant-btn">聚焦</a> <Button>聚焦</Button>
</Popover> </Popover>
<Popover overlay={content} title="标题" trigger="click"> <Popover overlay={content} title="标题" trigger="click">
<button className="ant-btn">点击</button> <Button>点击</Button>
</Popover> </Popover>
</div>, document.getElementById('components-popover-demo-triggertype')); </div>, document.getElementById('components-popover-demo-triggertype'));
```` ````

View File

@ -8,6 +8,8 @@
````jsx ````jsx
var ProgressCircle = antd.Progress.Circle; var ProgressCircle = antd.Progress.Circle;
var Button = antd.Button;
var ButtonGroup = antd.ButtonGroup;
var Icon = antd.Icon; var Icon = antd.Icon;
var MyProgress = React.createClass({ var MyProgress = React.createClass({
@ -33,14 +35,14 @@ var MyProgress = React.createClass({
render() { render() {
return <div> return <div>
<ProgressCircle percent={this.state.percent} /> <ProgressCircle percent={this.state.percent} />
<div className="ant-btn-group"> <ButtonGroup>
<button className="ant-btn ant-btn-ghost" onClick={this.decline}> <Button type="ghost" onClick={this.decline}>
<Icon type="minus" /> <Icon type="minus" />
</button> </Button>
<button className="ant-btn ant-btn-ghost" onClick={this.increase}> <Button type="ghost" onClick={this.increase}>
<Icon type="plus" /> <Icon type="plus" />
</button> </Button>
</div> </ButtonGroup>
</div>; </div>;
} }
}); });

View File

@ -8,6 +8,8 @@
````jsx ````jsx
var Progress = antd.Progress.Line; var Progress = antd.Progress.Line;
var Button = antd.Button;
var ButtonGroup = antd.ButtonGroup;
var Icon = antd.Icon; var Icon = antd.Icon;
var MyProgress = React.createClass({ var MyProgress = React.createClass({
@ -33,14 +35,14 @@ var MyProgress = React.createClass({
render() { render() {
return <div> return <div>
<Progress percent={this.state.percent} /> <Progress percent={this.state.percent} />
<div className="ant-btn-group"> <ButtonGroup>
<button className="ant-btn ant-btn-ghost" onClick={this.decline}> <Button type="ghost" onClick={this.decline}>
<Icon type="minus" /> <Icon type="minus" />
</button> </Button>
<button className="ant-btn ant-btn-ghost" onClick={this.increase}> <Button type="ghost" onClick={this.increase}>
<Icon type="plus" /> <Icon type="plus" />
</button> </Button>
</div> </ButtonGroup>
</div>; </div>;
} }
}); });

View File

@ -8,6 +8,7 @@ Radio 不可用。
````jsx ````jsx
var Radio = antd.Radio; var Radio = antd.Radio;
var Button = antd.Button;
function toggleDisabled() { function toggleDisabled() {
disabled = !disabled; disabled = !disabled;
@ -30,9 +31,9 @@ var App = React.createClass({
<br /> <br />
<Radio defaultChecked={true} disabled={this.state.disabled}>不可用</Radio> <Radio defaultChecked={true} disabled={this.state.disabled}>不可用</Radio>
<div style={{marginTop: 20}}> <div style={{marginTop: 20}}>
<button className="ant-btn ant-btn-primary" onClick={this.toggleDisabled}> <Button type="primary" onClick={this.toggleDisabled}>
Toggle disabled Toggle disabled
</button> </Button>
</div> </div>
</div>; </div>;
} }

View File

@ -15,6 +15,7 @@
````jsx ````jsx
var Steps = antd.Steps; var Steps = antd.Steps;
var Step = Steps.Step; var Step = Steps.Step;
var Button = antd.Button;
var container = document.getElementById('components-steps-demo-step-next'); var container = document.getElementById('components-steps-demo-step-next');
var array = Array.apply(null, Array(Math.floor(Math.random() * 3) + 3)); var array = Array.apply(null, Array(Math.floor(Math.random() * 3) + 3));
var steps = array.map(function(item, i) { var steps = array.map(function(item, i) {
@ -47,7 +48,7 @@ var App = React.createClass({
{steps.map((s, i) => <Step key={i} title={s.title} description={s.description} />)} {steps.map((s, i) => <Step key={i} title={s.title} description={s.description} />)}
</Steps> </Steps>
<div> <div>
<button className='ant-btn' onClick={this.next}>下一步</button> <Button onClick={this.next}>下一步</Button>
</div> </div>
</div> </div>
); );

View File

@ -8,6 +8,7 @@ Switch 失效状态。
````jsx ````jsx
var Switch = antd.Switch; var Switch = antd.Switch;
var Button = antd.Button;
var container = document.getElementById('components-switch-demo-disabled'); var container = document.getElementById('components-switch-demo-disabled');
var Test = React.createClass({ var Test = React.createClass({
@ -26,7 +27,7 @@ var Test = React.createClass({
<Switch disabled={this.state.disabled} /> <Switch disabled={this.state.disabled} />
<br /> <br />
<br /> <br />
<button className="ant-btn ant-btn-primary" onClick={this.toggle}>Toggle disabled</button> <Button type="primary" onClick={this.toggle}>Toggle disabled</Button>
</div>; </div>;
} }
}); });

View File

@ -10,6 +10,7 @@
````jsx ````jsx
var Table = antd.Table; var Table = antd.Table;
var Button = antd.Button;
var columns = [{ var columns = [{
title: '姓名', title: '姓名',
@ -85,13 +86,13 @@ var Test = React.createClass({
render() { render() {
return <div> return <div>
<Table columns={columns} dataSource={this.state.dataSource} /> <Table columns={columns} dataSource={this.state.dataSource} />
<button className="ant-btn ant-btn-primary" onClick={this.refresh}> <Button type="primary" onClick={this.refresh}>
重新加载数据 重新加载数据
</button> </Button>
&nbsp; &nbsp;
<button className="ant-btn" onClick={this.changeAndRefresh}> <Button onClick={this.changeAndRefresh}>
加载 city=hz 的数据 加载 city=hz 的数据
</button> </Button>
</div>; </div>;
} }
}); });

View File

@ -8,6 +8,8 @@
````jsx ````jsx
var Table = antd.Table; var Table = antd.Table;
var Button = antd.Button;
var columns = [{ var columns = [{
title: '姓名', title: '姓名',
dataIndex: 'name', dataIndex: 'name',
@ -73,9 +75,9 @@ var App = React.createClass({
render() { render() {
return <div> return <div>
<Table columns={columns} dataSource={this.state.data} /> <Table columns={columns} dataSource={this.state.data} />
<button className="ant-btn" onClick={this.handleClick1}>加载本地数据1</button> <Button onClick={this.handleClick1}>加载本地数据1</Button>
&nbsp; &nbsp;
<button className="ant-btn" onClick={this.handleClick2}>加载本地数据2</button> <Button onClick={this.handleClick2}>加载本地数据2</Button>
</div>; </div>;
} }
}) })

View File

@ -9,6 +9,7 @@
````jsx ````jsx
var Upload = antd.Upload; var Upload = antd.Upload;
var message = antd.message; var message = antd.message;
var Button = antd.Button;
var Icon = antd.Icon; var Icon = antd.Icon;
var props = { var props = {
@ -28,9 +29,9 @@ var props = {
React.render( React.render(
<Upload {...props}> <Upload {...props}>
<button type="button" className="ant-btn ant-btn-ghost"> <Button type="ghost">
<Icon type="upload" /> 点击上传 <Icon type="upload" /> 点击上传
</button> </Button>
</Upload> </Upload>
, document.getElementById('components-upload-demo-basic')); , document.getElementById('components-upload-demo-basic'));
```` ````

View File

@ -8,6 +8,7 @@
````jsx ````jsx
var Upload = antd.Upload; var Upload = antd.Upload;
var Button = antd.Button;
var Icon = antd.Icon; var Icon = antd.Icon;
var props = { var props = {
@ -33,9 +34,9 @@ var props = {
React.render( React.render(
<Upload {...props}> <Upload {...props}>
<button type="button" className="ant-btn ant-btn-ghost"> <Button type="ghost">
<Icon type="upload" /> 点击上传 <Icon type="upload" /> 点击上传
</button> </Button>
</Upload> </Upload>
, document.getElementById('components-upload-demo-defaultfilelist')); , document.getElementById('components-upload-demo-defaultfilelist'));
```` ````

View File

@ -14,6 +14,7 @@
````jsx ````jsx
var Upload = antd.Upload; var Upload = antd.Upload;
var Button = antd.Button;
var Icon = antd.Icon; var Icon = antd.Icon;
var fileList = [{ var fileList = [{
uid: -1, uid: -1,
@ -63,9 +64,9 @@ var MyUpload = React.createClass({
multiple: true multiple: true
}; };
return <Upload {...props} fileList={this.state.fileList}> return <Upload {...props} fileList={this.state.fileList}>
<button type="button" className="ant-btn ant-btn-ghost"> <Button type="ghost">
<Icon type="upload" /> 点击上传 <Icon type="upload" /> 点击上传
</button> </Button>
</Upload>; </Upload>;
} }
}); });

View File

@ -9,6 +9,7 @@
````jsx ````jsx
var Upload = antd.Upload; var Upload = antd.Upload;
var message = antd.message; var message = antd.message;
var Button = antd.Button;
var Icon = antd.Icon; var Icon = antd.Icon;
var props = { var props = {
@ -28,9 +29,9 @@ var props = {
React.render( React.render(
<Upload {...props}> <Upload {...props}>
<button type="button" className="ant-btn ant-btn-ghost"> <Button type="ghost">
<Icon type="upload" /> 点击上传 <Icon type="upload" /> 点击上传
</button> </Button>
</Upload> </Upload>
, document.getElementById('components-upload-demo-multiple')); , document.getElementById('components-upload-demo-multiple'));
```` ````

View File

@ -17,6 +17,7 @@ var Select = antd.Select;
var Option = Select.Option; var Option = Select.Option;
var Radio = antd.Radio; var Radio = antd.Radio;
var RadioGroup = antd.Radio.Group; var RadioGroup = antd.Radio.Group;
var Button = antd.Button;
function cx(classNames) { function cx(classNames) {
if (typeof classNames === 'object') { if (typeof classNames === 'object') {
@ -146,7 +147,7 @@ var Form = React.createClass({
var status = this.state.status; var status = this.state.status;
return ( return (
<form onSubmit={this.handleSubmit} className="ant-form-horizontal"> <form className="ant-form-horizontal">
<Validation ref="validation" onValidate={this.handleValidate}> <Validation ref="validation" onValidate={this.handleValidate}>
<div className="ant-form-item"> <div className="ant-form-item">
<label className="col-7" htmlFor="name" required>用户名:</label> <label className="col-7" htmlFor="name" required>用户名:</label>
@ -249,9 +250,9 @@ var Form = React.createClass({
<div className="ant-form-item"> <div className="ant-form-item">
<div className="col-offset-7 col-12"> <div className="col-offset-7 col-12">
<button type="submit" className="ant-btn ant-btn-primary">确 定</button> <Button type="primary" onClick={this.handleSubmit}>确 定</Button>
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;
<a href="#" className="ant-btn" onClick={this.handleReset}>重 置</a> <Button onClick={this.handleReset}>重 置</Button>
</div> </div>
</div> </div>
</Validation> </Validation>

View File

@ -11,6 +11,7 @@
````jsx ````jsx
var Validation = antd.Validation; var Validation = antd.Validation;
var Validator = Validation.Validator; var Validator = Validation.Validator;
var Button = antd.Button;
function cx(classNames) { function cx(classNames) {
if (typeof classNames === 'object') { if (typeof classNames === 'object') {
@ -150,7 +151,7 @@ var Form = React.createClass({
var status = this.state.status; var status = this.state.status;
return ( return (
<form onSubmit={this.handleSubmit} className="ant-form-horizontal"> <form className="ant-form-horizontal">
<Validation ref="validation" onValidate={this.handleValidate}> <Validation ref="validation" onValidate={this.handleValidate}>
<div className="ant-form-item"> <div className="ant-form-item">
@ -189,9 +190,9 @@ var Form = React.createClass({
<div className="ant-form-item"> <div className="ant-form-item">
<div className="col-offset-6 col-12"> <div className="col-offset-6 col-12">
<button type="submit" className="ant-btn ant-btn-primary">确 定</button> <Button type="primary" onClick={this.handleSubmit}>确 定</Button>
&nbsp;&nbsp;&nbsp; &nbsp;&nbsp;&nbsp;
<a href="#" className="ant-btn" onClick={this.handleReset}>重 置</a> <Button onClick={this.handleReset}>重 置</Button>
</div> </div>
</div> </div>
</Validation> </Validation>

View File

@ -72,12 +72,6 @@
} }
} }
&-menu {
> .@{iconfont-css-prefix} {
.iconfont-size-under-12px(10px);
}
}
&-group { &-group {
.btn-group(@btn-prefix-cls); .btn-group(@btn-prefix-cls);
} }

View File

@ -1,4 +1,5 @@
@dropdown-prefix-cls: ant-dropdown; @import "../mixins/index";
@dropdown-prefix-cls: ~"@{css-prefix}dropdown";
.@{dropdown-prefix-cls} { .@{dropdown-prefix-cls} {
position: absolute; position: absolute;
@ -13,6 +14,11 @@
&-wrap { &-wrap {
position: relative; position: relative;
.@{btn-prefix-cls} > .@{iconfont-css-prefix}-down {
.iconfont-size-under-12px(10px);
}
.anticon-down:before { .anticon-down:before {
transition: transform 0.2s ease; transition: transform 0.2s ease;
} }