Heray-Was-Here
Server : LiteSpeed
System : Linux uk-fast-web1372.main-hosting.eu 4.18.0-553.121.1.lve.el8.x86_64 #1 SMP Thu Apr 30 16:40:41 UTC 2026 x86_64
User : u390967363 ( 390967363)
PHP Version : 8.2.30
Disable Function : system, exec, shell_exec, passthru, mysql_list_dbs, ini_alter, dl, symlink, link, chgrp, leak, popen, apache_child_terminate, virtual, mb_send_mail
Directory :  /home/u390967363/public_html/wp-content/themes/blocksy/static/js/editor/components/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/u390967363/public_html/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

Hry