From d50d081c85a07014af1b490fcb67700bdbe9b963 Mon Sep 17 00:00:00 2001 From: CJ Cenizal Date: Wed, 22 Mar 2017 12:06:42 -0700 Subject: [PATCH] Refactor KuiButton and KuiButtonIcon type prop to emphasize passing string literals instead of enums. --- .../button/__snapshots__/button.test.js.snap | 26 +++--- .../__snapshots__/link_button.test.js.snap | 26 +++--- ui_framework/components/button/button.js | 87 +++++++++++-------- ui_framework/components/button/button.test.js | 15 ++-- .../button/button_icon/button_icon.js | 28 +++--- .../button/button_icon/button_icon.test.js | 10 +-- .../components/button/link_button.test.js | 15 ++-- .../components/button/submit_button.test.js | 8 +- .../doc_site/src/views/button/button_basic.js | 4 +- .../src/views/button/button_danger.js | 4 +- .../src/views/button/button_elements.js | 6 +- .../doc_site/src/views/button/button_group.js | 8 +- .../src/views/button/button_group_united.js | 14 +-- .../src/views/button/button_hollow.js | 4 +- .../src/views/button/button_loading.js | 6 +- .../src/views/button/button_primary.js | 4 +- .../src/views/button/button_with_icon.js | 24 ++--- .../src/views/button/buttons_in_tool_bar.js | 12 +-- 18 files changed, 162 insertions(+), 139 deletions(-) diff --git a/ui_framework/components/button/__snapshots__/button.test.js.snap b/ui_framework/components/button/__snapshots__/button.test.js.snap index 28b1c59bf466e..41936abf127af 100644 --- a/ui_framework/components/button/__snapshots__/button.test.js.snap +++ b/ui_framework/components/button/__snapshots__/button.test.js.snap @@ -56,17 +56,7 @@ exports[`KuiButton Props icon is rendered without children 1`] = ` `; -exports[`KuiButton Props isDisabled sets the disabled attribute 1`] = ` - -`; - -exports[`KuiButton Props isIconOnRight moves the icon to the right 1`] = ` +exports[`KuiButton Props iconPosition moves the icon to the right 1`] = ` +`; + exports[`KuiButton Props isLoading doesn't render the icon prop 1`] = ` @@ -100,7 +100,7 @@ exports[`KuiButton Props isLoading renders a spinner 1`] = ` > diff --git a/ui_framework/components/button/__snapshots__/link_button.test.js.snap b/ui_framework/components/button/__snapshots__/link_button.test.js.snap index dd0d5698fcf88..e50e913e415dd 100644 --- a/ui_framework/components/button/__snapshots__/link_button.test.js.snap +++ b/ui_framework/components/button/__snapshots__/link_button.test.js.snap @@ -66,17 +66,7 @@ exports[`KuiLinkButton Props icon is rendered without children 1`] = ` `; -exports[`KuiLinkButton Props isDisabled sets the disabled attribute 1`] = ` - - - -`; - -exports[`KuiLinkButton Props isIconOnRight moves the icon to the right 1`] = ` +exports[`KuiLinkButton Props iconPosition moves the icon to the right 1`] = ` `; +exports[`KuiLinkButton Props isDisabled sets the disabled attribute 1`] = ` + + + +`; + exports[`KuiLinkButton Props isLoading doesn't render the icon prop 1`] = ` @@ -110,7 +110,7 @@ exports[`KuiLinkButton Props isLoading renders a spinner 1`] = ` > diff --git a/ui_framework/components/button/button.js b/ui_framework/components/button/button.js index 308e27d6e021b..77d945497b281 100644 --- a/ui_framework/components/button/button.js +++ b/ui_framework/components/button/button.js @@ -8,7 +8,12 @@ import keyMirror from 'keymirror'; import { KuiButtonIcon } from './button_icon/button_icon'; const commonPropTypes = { - type: PropTypes.string, + type: PropTypes.oneOf([ + 'basic', + 'hollow', + 'danger', + 'primary', + ]), testSubject: PropTypes.string, isDisabled: PropTypes.bool, onClick: PropTypes.func, @@ -16,22 +21,36 @@ const commonPropTypes = { className: PropTypes.string, }; +const nonVoidPropTypes = { + icon: PropTypes.node, + iconPosition: PropTypes.oneOf([ + 'left', + 'right', + ]), + children: PropTypes.node, + isLoading: PropTypes.bool, +}; + +const nonVoidDefaultProps = { + iconPosition: 'left', +}; + const getIcon = props => ( props.isLoading - ? + ? : props.icon ); const getClassName = (props, icon) => { const typeToClassNameMap = { - [KuiButton.TYPE.BASIC]: 'kuiButton--basic', - [KuiButton.TYPE.HOLLOW]: 'kuiButton--hollow', - [KuiButton.TYPE.DANGER]: 'kuiButton--danger', - [KuiButton.TYPE.PRIMARY]: 'kuiButton--primary', + basic: 'kuiButton--basic', + hollow: 'kuiButton--hollow', + danger: 'kuiButton--danger', + primary: 'kuiButton--primary', }; return classNames('kuiButton', props.className, { - [typeToClassNameMap[KuiButton.TYPE[props.type]]]: props.type, + [typeToClassNameMap[props.type]]: props.type, 'kuiButton--iconText': icon, }); }; @@ -41,18 +60,23 @@ const getChildren = (props, icon) => { // correctly. const wrappedChildren = props.children ? {props.children} : undefined; - return props.isIconOnRight - ? ( - - {wrappedChildren} - {icon} - - ) : ( - - {icon} - {wrappedChildren} - - ); + switch(props.iconPosition) { + case 'left': + return ( + + {icon} + {wrappedChildren} + + ); + + case 'right': + return ( + + {wrappedChildren} + {icon} + + ); + } }; const getOnClick = props => ( @@ -82,13 +106,14 @@ const KuiButton = props => { }; KuiButton.propTypes = { - icon: PropTypes.node, - isIconOnRight: PropTypes.bool, - children: PropTypes.node, - isLoading: PropTypes.bool, + ...nonVoidPropTypes, ...commonPropTypes, }; +KuiButton.defaultProps = { + ...nonVoidDefaultProps, +}; + const KuiLinkButton = props => { const icon = getIcon(props); const children = getChildren(props, icon); @@ -108,13 +133,14 @@ const KuiLinkButton = props => { KuiLinkButton.propTypes = { href: PropTypes.string, target: PropTypes.string, - icon: PropTypes.node, - isIconOnRight: PropTypes.bool, - children: PropTypes.node, - isLoading: PropTypes.bool, + ...nonVoidPropTypes, ...commonPropTypes, }; +KuiLinkButton.defaultProps = { + ...nonVoidDefaultProps, +}; + const KuiSubmitButton = props => { const commonProps = getCommonProps(props); @@ -132,13 +158,6 @@ KuiSubmitButton.propTypes = { ...commonPropTypes, }; -KuiButton.TYPE = KuiSubmitButton.TYPE = KuiLinkButton.TYPE = keyMirror({ - BASIC: null, - HOLLOW: null, - DANGER: null, - PRIMARY: null, -}); - export { KuiButton, KuiLinkButton, diff --git a/ui_framework/components/button/button.test.js b/ui_framework/components/button/button.test.js index 252c8942e6a75..09520a1e40513 100644 --- a/ui_framework/components/button/button.test.js +++ b/ui_framework/components/button/button.test.js @@ -26,7 +26,7 @@ describe('KuiButton', () => { describe('basic', () => { test('renders the basic class', () => { const $button = render( - + ); expect($button) @@ -37,7 +37,7 @@ describe('KuiButton', () => { describe('hollow', () => { test('renders the hollow class', () => { const $button = render( - + ); expect($button) @@ -48,7 +48,7 @@ describe('KuiButton', () => { describe('danger', () => { test('renders the danger class', () => { const $button = render( - + ); expect($button) @@ -59,7 +59,7 @@ describe('KuiButton', () => { describe('primary', () => { test('renders the primary class', () => { const $button = render( - + ); expect($button) @@ -101,10 +101,13 @@ describe('KuiButton', () => { }); }); - describe('isIconOnRight', () => { + describe('iconPosition', () => { test('moves the icon to the right', () => { const $button = shallow( - + Hello ); diff --git a/ui_framework/components/button/button_icon/button_icon.js b/ui_framework/components/button/button_icon/button_icon.js index f210adcedd7d6..376fe664069dd 100644 --- a/ui_framework/components/button/button_icon/button_icon.js +++ b/ui_framework/components/button/button_icon/button_icon.js @@ -7,15 +7,15 @@ import keyMirror from 'keymirror'; const KuiButtonIcon = props => { const typeToClassNameMap = { - [KuiButtonIcon.TYPE.CREATE]: 'fa-plus', - [KuiButtonIcon.TYPE.DELETE]: 'fa-trash', - [KuiButtonIcon.TYPE.PREVIOUS]: 'fa-chevron-left', - [KuiButtonIcon.TYPE.NEXT]: 'fa-chevron-right', - [KuiButtonIcon.TYPE.LOADING]: 'fa-spinner fa-spin', + create: 'fa-plus', + delete: 'fa-trash', + previous: 'fa-chevron-left', + next: 'fa-chevron-right', + loading: 'fa-spinner fa-spin', }; const iconClasses = classNames('kuiButton__icon kuiIcon', props.className, { - [typeToClassNameMap[KuiButtonIcon.TYPE[props.type]]]: props.type, + [typeToClassNameMap[props.type]]: props.type, }); return ( @@ -23,16 +23,14 @@ const KuiButtonIcon = props => { ); }; -KuiButtonIcon.TYPE = keyMirror({ - CREATE: null, - DELETE: null, - PREVIOUS: null, - NEXT: null, - LOADING: null, -}); - KuiButtonIcon.propTypes = { - type: PropTypes.string, + type: PropTypes.oneOf([ + 'create', + 'delete', + 'previous', + 'next', + 'loading', + ]), className: PropTypes.string, }; diff --git a/ui_framework/components/button/button_icon/button_icon.test.js b/ui_framework/components/button/button_icon/button_icon.test.js index 5887c58112f01..c3a0c3174b805 100644 --- a/ui_framework/components/button/button_icon/button_icon.test.js +++ b/ui_framework/components/button/button_icon/button_icon.test.js @@ -26,7 +26,7 @@ describe('KuiButtonIcon', () => { describe('create', () => { test('renders the create class', () => { const $buttonIcon = render( - + ); expect($buttonIcon) @@ -37,7 +37,7 @@ describe('KuiButtonIcon', () => { describe('delete', () => { test('renders the delete class', () => { const $buttonIcon = render( - + ); expect($buttonIcon) @@ -48,7 +48,7 @@ describe('KuiButtonIcon', () => { describe('previous', () => { test('renders the previous class', () => { const $buttonIcon = render( - + ); expect($buttonIcon) @@ -59,7 +59,7 @@ describe('KuiButtonIcon', () => { describe('next', () => { test('renders the next class', () => { const $buttonIcon = render( - + ); expect($buttonIcon) @@ -70,7 +70,7 @@ describe('KuiButtonIcon', () => { describe('loading', () => { test('renders the loading class', () => { const $buttonIcon = render( - + ); expect($buttonIcon) diff --git a/ui_framework/components/button/link_button.test.js b/ui_framework/components/button/link_button.test.js index 6a645962577e1..44c1764e7e47e 100644 --- a/ui_framework/components/button/link_button.test.js +++ b/ui_framework/components/button/link_button.test.js @@ -26,7 +26,7 @@ describe('KuiLinkButton', () => { describe('basic', () => { test('renders the basic class', () => { const $button = render( - + ); expect($button) @@ -37,7 +37,7 @@ describe('KuiLinkButton', () => { describe('hollow', () => { test('renders the hollow class', () => { const $button = render( - + ); expect($button) @@ -48,7 +48,7 @@ describe('KuiLinkButton', () => { describe('danger', () => { test('renders the danger class', () => { const $button = render( - + ); expect($button) @@ -59,7 +59,7 @@ describe('KuiLinkButton', () => { describe('primary', () => { test('renders the primary class', () => { const $button = render( - + ); expect($button) @@ -101,10 +101,13 @@ describe('KuiLinkButton', () => { }); }); - describe('isIconOnRight', () => { + describe('iconPosition', () => { test('moves the icon to the right', () => { const $button = shallow( - + Hello ); diff --git a/ui_framework/components/button/submit_button.test.js b/ui_framework/components/button/submit_button.test.js index 58c7c82052410..4de1dfffdb3e3 100644 --- a/ui_framework/components/button/submit_button.test.js +++ b/ui_framework/components/button/submit_button.test.js @@ -26,7 +26,7 @@ describe('KuiSubmitButton', () => { describe('basic', () => { test('renders the basic class', () => { const $button = render( - + ); expect($button) @@ -37,7 +37,7 @@ describe('KuiSubmitButton', () => { describe('hollow', () => { test('renders the hollow class', () => { const $button = render( - + ); expect($button) @@ -48,7 +48,7 @@ describe('KuiSubmitButton', () => { describe('danger', () => { test('renders the danger class', () => { const $button = render( - + ); expect($button) @@ -59,7 +59,7 @@ describe('KuiSubmitButton', () => { describe('primary', () => { test('renders the primary class', () => { const $button = render( - + ); expect($button) diff --git a/ui_framework/doc_site/src/views/button/button_basic.js b/ui_framework/doc_site/src/views/button/button_basic.js index 948c3b806f9c7..de9c8ac3f7bc5 100644 --- a/ui_framework/doc_site/src/views/button/button_basic.js +++ b/ui_framework/doc_site/src/views/button/button_basic.js @@ -7,7 +7,7 @@ import { export default () => (
window.alert('Button clicked')} > Basic button @@ -16,7 +16,7 @@ export default () => (
Basic button, disabled diff --git a/ui_framework/doc_site/src/views/button/button_danger.js b/ui_framework/doc_site/src/views/button/button_danger.js index 4c96bc23cea6f..e6c9fc17cd123 100644 --- a/ui_framework/doc_site/src/views/button/button_danger.js +++ b/ui_framework/doc_site/src/views/button/button_danger.js @@ -6,14 +6,14 @@ import { export default () => (
- + Danger button
Danger button, disabled diff --git a/ui_framework/doc_site/src/views/button/button_elements.js b/ui_framework/doc_site/src/views/button/button_elements.js index 7eaad1ab41188..4470a5790e308 100644 --- a/ui_framework/doc_site/src/views/button/button_elements.js +++ b/ui_framework/doc_site/src/views/button/button_elements.js @@ -8,7 +8,7 @@ import { export default () => (
- + Button element @@ -18,7 +18,7 @@ export default () => ( e.preventDefault(); window.alert('Submit'); }}> - + Submit input element @@ -26,7 +26,7 @@ export default () => (   diff --git a/ui_framework/doc_site/src/views/button/button_group.js b/ui_framework/doc_site/src/views/button/button_group.js index fb21142da88f1..36bf80bc7e292 100644 --- a/ui_framework/doc_site/src/views/button/button_group.js +++ b/ui_framework/doc_site/src/views/button/button_group.js @@ -8,15 +8,15 @@ import { export default () => (
- + Cancel - + Duplicate - + Save @@ -24,7 +24,7 @@ export default () => (
- + Button group with one button diff --git a/ui_framework/doc_site/src/views/button/button_group_united.js b/ui_framework/doc_site/src/views/button/button_group_united.js index 84c041055d599..af05596ae636f 100644 --- a/ui_framework/doc_site/src/views/button/button_group_united.js +++ b/ui_framework/doc_site/src/views/button/button_group_united.js @@ -9,15 +9,15 @@ import { export default () => (
- + Option A - + Option B - + Option C @@ -26,13 +26,13 @@ export default () => ( } + type="basic" + icon={} /> } + type="basic" + icon={} />
diff --git a/ui_framework/doc_site/src/views/button/button_hollow.js b/ui_framework/doc_site/src/views/button/button_hollow.js index d78100ce906bb..8780b4eac789c 100644 --- a/ui_framework/doc_site/src/views/button/button_hollow.js +++ b/ui_framework/doc_site/src/views/button/button_hollow.js @@ -6,14 +6,14 @@ import { export default () => (
- + Hollow button
Hollow button, disabled diff --git a/ui_framework/doc_site/src/views/button/button_loading.js b/ui_framework/doc_site/src/views/button/button_loading.js index f40b045a65714..f27b1d7f8631e 100644 --- a/ui_framework/doc_site/src/views/button/button_loading.js +++ b/ui_framework/doc_site/src/views/button/button_loading.js @@ -34,7 +34,7 @@ export default class LoadingButton extends Component { return (
} + icon={} isLoading={this.state.isLoading} isDisabled={this.state.isLoading} > diff --git a/ui_framework/doc_site/src/views/button/button_primary.js b/ui_framework/doc_site/src/views/button/button_primary.js index 0ab7584a9f046..3b7b0bc894c50 100644 --- a/ui_framework/doc_site/src/views/button/button_primary.js +++ b/ui_framework/doc_site/src/views/button/button_primary.js @@ -6,14 +6,14 @@ import { export default () => (
- + Primary button
Primary button, disabled diff --git a/ui_framework/doc_site/src/views/button/button_with_icon.js b/ui_framework/doc_site/src/views/button/button_with_icon.js index 847b6ddc1e85e..1039953f73c15 100644 --- a/ui_framework/doc_site/src/views/button/button_with_icon.js +++ b/ui_framework/doc_site/src/views/button/button_with_icon.js @@ -8,8 +8,8 @@ import { export default () => (
} + type="primary" + icon={} > Create @@ -17,8 +17,8 @@ export default () => (
} + type="danger" + icon={} > Delete @@ -26,8 +26,8 @@ export default () => (
} + type="basic" + icon={} > Previous @@ -35,9 +35,9 @@ export default () => (
} - isIconOnRight + type="basic" + icon={} + iconPosition='right' > Next @@ -45,8 +45,8 @@ export default () => (
} + type="basic" + icon={} > Loading @@ -54,7 +54,7 @@ export default () => (
} />
diff --git a/ui_framework/doc_site/src/views/button/buttons_in_tool_bar.js b/ui_framework/doc_site/src/views/button/buttons_in_tool_bar.js index 5ea2a2c834786..66c8cf599e582 100644 --- a/ui_framework/doc_site/src/views/button/buttons_in_tool_bar.js +++ b/ui_framework/doc_site/src/views/button/buttons_in_tool_bar.js @@ -6,34 +6,34 @@ import { export default () => (
- + Basic button Basic button, disabled - + Primary button Primary button, disabled - + Danger button Danger button, disabled