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-layers-mirror.js
import { Fragment, createElement } from '@wordpress/element'
import OptionsPanel from '../OptionsPanel'

const LayersMirror = ({ values, onChangeFor, value, option, onChange }) => {
	const wholeLayers = values[option.layers] || []

	const ourLayers = wholeLayers.filter(
		({ id, enabled }) => enabled && id === option.field
	)

	if (ourLayers.length === 0) {
		return null
	}

	return ourLayers.map((layer, index) => {
		let computedOptions = Object.keys(option['inner-options']).reduce(
			(all, optionId) => ({
				...all,
				[optionId]: {
					...option['inner-options'][optionId],
					label: option['inner-options'][optionId].label.replace(
						'INDEX ',
						ourLayers.length === 1 ? '' : `${index + 1} `
					),
				},
			}),
			{}
		)

		return (
			<OptionsPanel
				key={layer.__id || layer.id}
				onChange={(id, value) => {
					onChangeFor(
						option.layers,
						wholeLayers.map((l) =>
							l.__id !== layer.__id
								? l
								: {
										...l,
										[id]: value,
								  }
						)
					)
				}}
				options={computedOptions}
				value={layer}
			/>
		)
	})
}

LayersMirror.renderingConfig = { design: 'none' }

export default LayersMirror