HEX
Server: LiteSpeed
System: Linux server318.web-hosting.com 4.18.0-513.18.1.lve.el8.x86_64 #1 SMP Thu Feb 22 12:55:50 UTC 2024 x86_64
User: joyfejor (3859)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: /home/joyfejor/www/wp-content/plugins/extendify/src/Agent/components/ChatTools.jsx
import { Tooltip } from '@wordpress/components';
import { __ } from '@wordpress/i18n';
import { Icon, closeSmall } from '@wordpress/icons';
import classNames from 'classnames';
import { toolSelect } from '@agent/icons';
import { useWorkflowStore } from '@agent/state/workflows';

export const ChatTools = ({ disabled = false }) => {
	const { getWorkflowsByFeature, domToolEnabled, setDomToolEnabled } =
		useWorkflowStore();
	const domTool = getWorkflowsByFeature({ requires: ['block'] })?.length > 0;

	const handleClose = () => {
		window.dispatchEvent(new CustomEvent('extendify-agent:cancel-workflow'));
		setDomToolEnabled(!domToolEnabled);
	};

	if (!domTool) return null;
	return (
		<div className="flex items-center">
			<Tooltip
				text={
					domToolEnabled
						? __('Exit select mode', 'extendify-local')
						: __('Select Area to Edit', 'extendify-local')
				}>
				<button
					type="button"
					disabled={disabled}
					className={classNames(
						'm-0 flex items-center rounded border-0 px-1 py-0.5 leading-none disabled:opacity-50',
						{
							'bg-gray-300': domToolEnabled,
							'bg-gray-100 text-gray-900': !domToolEnabled,
							'hover:bg-gray-200': !disabled,
						},
					)}
					onClick={handleClose}>
					<Icon size={24} icon={toolSelect} />
					<span className="px-1">{__('Select', 'extendify-local')}</span>
					{domToolEnabled && (
						<Icon size={20} icon={closeSmall} className="fill-current" />
					)}
				</button>
			</Tooltip>
		</div>
	);
};