HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux vm8 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: afleverb (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: //var/www/drakkar_site_dev/wp-content/themes/blocksy/static/js/editor/components/ToolsPanel.js
import { useState, createElement } from '@wordpress/element'
import classnames from 'classnames'

import { __experimentalGrid as Grid } from '@wordpress/components'

import ToolsPanelHeader from './ToolsPanel/ToolsPanelHeader'

const ToolsPanel = ({
	className,
	attributes,
	setAttributes,
	resetAll,
	items,
	label,
}) => {
	const idsWithValue = items.reduce(
		(result, group) => {
			return [
				...result,
				...group.items
					.filter((item) => item.hasValue())
					.map((item) => item.label),
			]
		},

		[]
	)

	const [temporarilyOpenedItems, setTemporarilyOpenedItems] = useState([])

	const selectedItems = [
		...new Set([...temporarilyOpenedItems, ...idsWithValue]),
	]

	return (
		<div className={classnames('ct-tools-panel', className)}>

			<ToolsPanelHeader
				label={label}
				resetAll={() => {
					setTemporarilyOpenedItems([])
					resetAll()
				}}
				items={items}
				selectedItems={selectedItems}
				attributes={attributes}
				setAttributes={setAttributes}
				onItemClick={(itemLabel) => {
					if (!selectedItems.includes(itemLabel)) {
						setTemporarilyOpenedItems([
							...temporarilyOpenedItems,
							itemLabel,
						])

						return
					}

					const item = items
						.reduce((acc, group) => [...acc, ...group.items], [])
						.find((item) => item.label === itemLabel)

					setTemporarilyOpenedItems(
						temporarilyOpenedItems.filter(
							(item) => item !== itemLabel
						)
					)

					item.reset()
				}}
			/>

			<div className="ct-tools-panel-items">
				{items
					.reduce((acc, group) => [...acc, ...group.items], [])
					.filter((item) => selectedItems.includes(item.label))
					.map((item) => {
						return item.render()
					})}
			</div>
		</div>
	)
}

export default ToolsPanel