HEX
Server: nginx/1.18.0
System: Linux vps-9dcdb12e 5.15.0-176-generic #186-Ubuntu SMP Fri Mar 13 11:01:42 UTC 2026 x86_64
User: ubuntu (1000)
PHP: 8.1.2-1ubuntu2.24
Disabled: exec,passthru,shell_exec,system,proc_open,popen,curl_exec,curl_multi_exec,parse_ini_file,show_source
Upload Files
File: /var/www/goautomatic.pl/wp-content/plugins/latepoint/blocks/controls/BoxShadowControl.js
import { __ } from '@wordpress/i18n';
import React from "react";
import { Dropdown, RangeControl, ColorIndicator, ColorPicker, Button } from '@wordpress/components';

const BoxShadowControl = ({ shadowAttribute, attributes, setAttributes }) => {
    const shadowString = attributes[shadowAttribute] || '';
    const [x, y, blur, spread, color] = shadowString.split(' ');

    const shadowValues = {
        x: x || '',
        y: y || '',
        blur: blur || '',
        spread: spread || '',
        color: color || '',
    };

    const handleBoxShadowChange = (key, value) => {
        const newShadow = { ...shadowValues, [key]: value };
        const shadowString = `${newShadow.x} ${newShadow.y} ${newShadow.blur} ${newShadow.spread} ${newShadow.color}`.trim();
        setAttributes({ [shadowAttribute]: shadowString });
    };

    const renderColorPicker = () => (
        <ColorPicker
            color={shadowValues.color || ''}
            onChangeComplete={(value) => handleBoxShadowChange('color', value.hex)}
            disableAlpha
        />
    );

    const getValue = (value = '') => (value ? parseInt(value) : null);

    return (
        <>
            <div className="lb-boxshadow-actions">
                <Button
                    className="latepoint-block-reset"
                    onClick={() => setAttributes({ [shadowAttribute]: "" })}
                    isSmall
                    disabled={!shadowString}
                    icon="dashicon dashicons dashicons-image-rotate"
                />
            </div>
            <RangeControl
                label={__('Horizontal')}
                value={getValue(shadowValues.x)}
                onChange={(value) => handleBoxShadowChange('x', `${value}px`)}
                min={-100}
                max={100}
            />
            <RangeControl
                label={__('Vertical')}
                value={getValue(shadowValues.y)}
                onChange={(value) => handleBoxShadowChange('y', `${value}px`)}
                min={-100}
                max={100}
            />
            <RangeControl
                label={__('Blur')}
                value={getValue(shadowValues.blur)}
                onChange={(value) => handleBoxShadowChange('blur', `${value}px`)}
                min={0}
                max={100}
            />
            <RangeControl
                label={__('Spread')}
                value={getValue(shadowValues.spread)}
                onChange={(value) => handleBoxShadowChange('spread', `${value}px`)}
                min={-100}
                max={100}
            />
            <Dropdown
                className="lb-color-settings-dropdown"
                renderToggle={({ isOpen, onToggle }) => (
                    <div className="lb-row lb-color-settings-w">
                        <div className="lb-label">{__('Color')}</div>
                        <Button onClick={onToggle} aria-expanded={isOpen}>
                            <ColorIndicator className="lb-color-indicator" colorValue={shadowValues.color || ''} />
                        </Button>
                    </div>
                )}
                renderContent={renderColorPicker}
            />
        </>
    );
};

export default BoxShadowControl;