From 8a27802452f433b1399842f20e6bfb6fab4ee6d4 Mon Sep 17 00:00:00 2001 From: Tobias Date: Mon, 27 May 2019 13:23:45 +0200 Subject: [PATCH] enhance radio button internal checks with dedicated functions --- .../dnb-ui-lib/src/components/radio/Radio.js | 20 +++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/packages/dnb-ui-lib/src/components/radio/Radio.js b/packages/dnb-ui-lib/src/components/radio/Radio.js index 4862056e583..079e5989480 100644 --- a/packages/dnb-ui-lib/src/components/radio/Radio.js +++ b/packages/dnb-ui-lib/src/components/radio/Radio.js @@ -123,7 +123,7 @@ export default class Radio extends Component { onKeyDownHandler = event => { // only have key support if there is only a single radio - if (typeof this.context.value === 'undefined' && !this.props.group) { + if (this.isInNoGroup()) { switch (keycode(event)) { case 'enter': this.onChangeHandler(event) @@ -151,11 +151,6 @@ export default class Radio extends Component { } const value = event.target.value const checked = !this.state.checked - // only support on change if there is either: - // 1. context group usage - // 2. or a single, no group usage - const isContextGroupOrSingle = - typeof this.context.value !== 'undefined' && !this.props.group // delay in case we have a if (this.isPlainGroup()) { @@ -163,20 +158,29 @@ export default class Radio extends Component { this.setState( { checked, _listenForPropChanges: false }, () => - isContextGroupOrSingle && this.callOnChange({ value, checked }) + this.isContextGroupOrSingle() && + this.callOnChange({ value, checked }) ) }, 1) // in case we have a false "hasContext" but a "group", then we have to use a delay, to overwrite the uncrontrolled state } else { this.setState( { checked, _listenForPropChanges: false }, () => - isContextGroupOrSingle && this.callOnChange({ value, checked }) + this.isContextGroupOrSingle() && + this.callOnChange({ value, checked }) ) } } + // only support on change if there is either: + // 1. context group usage + // 2. or a single, no group usage + isContextGroupOrSingle = () => + typeof this.context.value !== 'undefined' && !this.props.group isPlainGroup = () => typeof this.context.value === 'undefined' && this.props.group + isInNoGroup = () => + typeof this.context.value === 'undefined' && !this.props.group onClickHandler = event => { if (String(this.props.readOnly) === 'true') {