File "index.js"

Full path: /home/webcknlt/admissiontell.com/wp-content/plugins/generateblocks/src/extend/inspector-control/controls/responsive-tabs/index.js
File size: 2.36 B (2.36 KB bytes)
MIME-type: text/x-java
Charset: utf-8

Download   Open   Edit   Advanced Editor &nnbsp; Back

import { __ } from '@wordpress/i18n';
import { Button, Tooltip } from '@wordpress/components';
import { Icon, desktop, tablet, mobile } from '@wordpress/icons';
import { memo, useCallback, useEffect } from '@wordpress/element';
import { useDeviceType } from '../../../../hooks';
import './editor.scss';
import compatibleRender from '../../../../utils/compatible-render';

function DeviceButton( { deviceKey, label, isActive, onClick, icon } ) {
	return (
		<Tooltip text={ label }>
			<Button isPressed={ isActive } onClick={ () => onClick( deviceKey ) }>
				<Icon icon={ icon } />
			</Button>
		</Tooltip>
	);
}

const MemoizedDeviceButton = memo( DeviceButton );

const devices = [
	{
		key: 'Desktop',
		label: __( 'Show options for all devices', 'generateblocks' ),
		icon: desktop,
	},
	{
		key: 'Tablet',
		label: __( 'Show options for tablet devices', 'generateblocks' ),
		icon: tablet,
	},
	{
		key: 'Mobile',
		label: __( 'Show options for mobile devices', 'generateblocks' ),
		icon: mobile,
	},
];

function ResponsiveTabButtons() {
	const [ deviceType, setDeviceType ] = useDeviceType();
	const onClickDeviceButton = useCallback( setDeviceType, [] );

	return (
		<>
			{ devices && devices.map( ( device ) => (
				<MemoizedDeviceButton
					key={ device.key }
					deviceKey={ device.key }
					label={ device.label }
					isActive={ deviceType === device.key }
					icon={ device.icon }
					onClick={ onClickDeviceButton }
				/>
			) ) }
		</>
	);
}

function ResponsiveTabs() {
	useEffect( () => {
		const BlockInspectorControls = document.querySelector( '.block-editor-block-inspector' );
		const ResponsiveTabsElement = document.querySelector( '.gb-responsive-tabs' );

		if ( ! BlockInspectorControls || ResponsiveTabsElement ) {
			return;
		}

		const panelHeader = document.querySelector( '.interface-complementary-area-header' );
		const panelHeaderHeight = panelHeader ? `${ panelHeader.offsetHeight }px` : 0;
		const buttonWrapper = document.createElement( 'div' );
		buttonWrapper.classList.add( 'gb-responsive-tabs' );
		buttonWrapper.style.top = panelHeaderHeight;
		BlockInspectorControls.prepend( buttonWrapper );

		compatibleRender(
			document.querySelector( '.gb-responsive-tabs' ),
			<ResponsiveTabButtons />
		);

		return () => {
			if ( ! buttonWrapper ) {
				return;
			}

			buttonWrapper.remove();
		};
	}, [] );

	return null;
}

export default memo( ResponsiveTabs );