@workday/canvas-kit-react
Version:
The parent module that contains all Workday Canvas Kit React components
17 lines (16 loc) • 1.22 kB
JavaScript
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
import { BaseButton } from './BaseButton';
import { createComponent } from '@workday/canvas-kit-react/common';
export const Button = createComponent('button')({
displayName: 'Button',
Component: ({ children, icon, colors, iconPosition, shouldMirrorIcon, shouldMirrorIconInRTL, size = 'medium', ...elemProps }, ref, Element) => {
const baseIconPosition = iconPosition
? iconPosition
: icon
? children
? 'start'
: 'only'
: undefined;
return (_jsxs(BaseButton, { as: Element, ref: ref, size: size, icon: icon, colors: colors, iconPosition: baseIconPosition, ...elemProps, children: [icon && baseIconPosition === 'start' && (_jsx(BaseButton.Icon, { size: size, icon: icon, shouldMirrorIcon: shouldMirrorIcon, shouldMirrorIconInRTL: shouldMirrorIconInRTL })), children && _jsx(BaseButton.Label, { children: children }), icon && baseIconPosition && ['only', 'end'].includes(baseIconPosition) && (_jsx(BaseButton.Icon, { size: size, icon: icon, shouldMirrorIcon: shouldMirrorIcon, shouldMirrorIconInRTL: shouldMirrorIconInRTL }))] }));
},
});