[improvement] GoodsAction: tsx (#2786)

This commit is contained in:
neverland
2019-02-18 20:59:38 +08:00
committed by GitHub
parent c372638036
commit b9d7143fb3
7 changed files with 116 additions and 80 deletions
-38
View File
@@ -1,38 +0,0 @@
import { use } from '../utils';
import Button from '../button';
import { emit, inherit } from '../utils/functional';
import { functionalRoute, routeProps } from '../mixins/router';
const [sfc, bem] = use('goods-action-big-btn');
function GoodsActionBigBtn(h, props, slots, ctx) {
const onClick = event => {
emit(ctx, 'click', event);
functionalRoute(ctx);
};
return (
<Button
square
class={bem()}
size="large"
loading={props.loading}
disabled={props.disabled}
type={props.primary ? 'danger' : 'warning'}
onClick={onClick}
{...inherit(ctx)}
>
{slots.default ? slots.default() : props.text}
</Button>
);
}
GoodsActionBigBtn.props = {
...routeProps,
text: String,
primary: Boolean,
loading: Boolean,
disabled: Boolean
};
export default sfc(GoodsActionBigBtn);
+54
View File
@@ -0,0 +1,54 @@
import { use } from '../utils';
import Button, { ButtonEvents } from '../button';
import { emit, inherit } from '../utils/functional';
import { functionalRoute, routeProps, RouteProps } from '../mixins/router';
// Types
import { CreateElement, RenderContext } from 'vue/types';
import { DefaultSlots } from '../utils/use/sfc';
export type GoodsActionBigBtnProps = RouteProps & {
text?: string;
primary?: boolean;
loading?: boolean;
disabled?: boolean;
};
const [sfc, bem] = use('goods-action-big-btn');
function GoodsActionBigBtn(
h: CreateElement,
props: GoodsActionBigBtnProps,
slots: DefaultSlots,
ctx: RenderContext<GoodsActionBigBtnProps>
) {
const onClick = (event: Event) => {
emit(ctx, 'click', event);
functionalRoute(ctx);
};
return (
<Button
square
class={bem()}
size="large"
loading={props.loading}
disabled={props.disabled}
type={props.primary ? 'danger' : 'warning'}
onClick={onClick}
{...inherit(ctx)}
>
{slots.default ? slots.default() : props.text}
</Button>
);
}
GoodsActionBigBtn.props = {
...routeProps,
text: String,
primary: Boolean,
loading: Boolean,
disabled: Boolean
};
export default sfc<GoodsActionBigBtnProps, ButtonEvents>(GoodsActionBigBtn);