HEX
Server: Apache
System: Linux b5.s-host.com.ua 4.18.0-305.10.2.el7.x86_64 #1 SMP Fri Jul 23 21:00:55 UTC 2021 x86_64
User: unelbhzm (1470)
PHP: 8.0.18
Disabled: NONE
Upload Files
File: /sites/nuofama.com/wp-content/themes/blocksy/static/js/options/options/ct-radio.js
import { createElement, Component } from '@wordpress/element'
import classnames from 'classnames'
import { normalizeCondition, matchValuesWithCondition } from 'match-conditions'

const RadioInput = (props) => {
	const { inline = false } = props.option

	return (
		<div
			className="ct-radio-option"
			{...(inline ? { ['data-inline']: '' } : {})}
			{...(props.option.attr || {})}>
			{Object.keys(props.option.choices).map((choice) => (
				<label key={choice}>
					<input
						type="radio"
						checked={choice === props.value}
						onChange={() => props.onChange(choice)}
					/>

					{props.option.choices[choice]}
				</label>
			))}
		</div>
	)
}

const DefaultRadio = ({
	option,
	values,
	value,
	onChange,
	singleChoiceProps,
}) => {
	const { inline = false } = option

	let matchingChoices = Object.keys(option.choices).filter((choice) => {
		if (!option.conditions) {
			return true
		}

		if (!option.conditions[choice]) {
			return true
		}

		return matchValuesWithCondition(
			normalizeCondition(option.conditions[choice]),
			values
		)
	})

	let normalizedValue = matchingChoices.includes(value) ? value : option.value

	return (
		<ul
			className="ct-radio-option ct-buttons-group"
			{...(inline ? { ['data-inline']: '' } : {})}
			{...(option.attr || {})}>
			{matchingChoices.map((choice, index) => (
				<li
					className={classnames({
						active: choice === normalizedValue,
					})}
					onClick={() => onChange(choice)}
					key={choice}
					dangerouslySetInnerHTML={{
						__html: option.choices[choice],
					}}
					{...(singleChoiceProps ? singleChoiceProps(choice) : {})}
				/>
			))}
		</ul>
	)
}

const Radio = (props) => {
	const {
		option: { view },
	} = props

	if (view === 'radio') {
		return <RadioInput {...props} />
	}

	return <DefaultRadio {...props} />
}

export default Radio