HEX
Server: Apache
System: Linux scp1.abinfocom.com 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: confeduphaar (1010)
PHP: 8.1.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: /home/confeduphaar/www/wp-content/plugins/essential-blocks/src/blocks/flipbox/src/inspector.js
/**
 * WordPress dependencies
 */
import { __ } from "@wordpress/i18n";
import { applyFilters } from "@wordpress/hooks";
import {
    PanelRow,
    SelectControl,
    Button,
    TextControl,
    RangeControl,
    ToggleControl,
    ButtonGroup,
    BaseControl,
} from "@wordpress/components";

/*
 * Internal dependencies
 */
import {
    BUTTON_STYLES,
    FLIPBOX_SIDES,
    FLIPBOX_TYPE,
    ICON_POSITIONS,
    ICON_TYPE,
    LINK_TYPE,
    FRONT_IMAGE_UNITS,
    CONTENT_POSITION,
    FLIP_MODE,
    FRONT_IMG_ATTR,
    BACK_IMG_ATTR,
    HEADER_TAGS,
} from "./constants";

import {
    ImageAvatar,
    BorderShadowControl,
    getButtonClasses,
    ResponsiveDimensionsControl,
    ResponsiveRangeController,
    TypographyDropdown,
    ColorControl,
    BackgroundControl,
    DynamicInputControl,
    EBIconPicker,
    InspectorPanel,
    ImageComponent,
    EBTextControl,
} from "@essential-blocks/controls";

import {
    flipboxFrontWrapper,
    flipboxBackWrapper,
} from "./constants/backgroundsConstants";
import {
    dimensionsMargin,
    dimensionsPadding,
    buttonPadding,
    frontIconMargin,
    frontIconPadding,
    backIconMargin,
    backIconPadding,
    frontTitlePadding,
    backTitlePadding,
    frontContentPadding,
    backContentPadding,
    frontImgPadding,
    backImgPadding,
    frontItemPadding,
    backItemPadding,
    backImgMargin,
    frontImgMargin,
} from "./constants/dimensionsNames";
import {
    borderShadow,
    borderShadowBtn,
    borderShadowFrontIcon,
    borderShadowBackIcon,
    frontImageBorder,
    backImageBorder,
} from "./constants/borderShadowConstants";
import {
    typoPrefix_title,
    typoPrefix_content,
} from "./constants/typographyPrefixConstants";
import {
    boxHeightAttr,
    boxWidthAttr,
    boxFrontIconSizeAttr,
    boxBackIconSizeAttr,
    buttonIconSizeAttr,
    frontImgSizeAttr,
    backImgSizeAttr,
    frontImgRadiusAttr,
    backImgRadiusAttr,
    frontImgHeightAttr,
    backImgHeightAttr,
} from "./constants/rangeNames";

const Inspector = ({ attributes, setAttributes }) => {
    const {
        resOption,
        flipType,
        selectedSide,
        frontIconOrImage,
        frontIcon,
        frontImageUrl,
        frontImageAlt,
        frontImageId,
        backIconOrImage,
        backIcon,
        backImageUrl,
        backImageId,
        showFrontTitle,
        frontTitle,
        showFrontContent,
        frontContent,
        showBackTitle,
        backTitle,
        showBackContent,
        backContent,
        linkType,
        buttonText,
        buttonIcon,
        buttonIconPos,
        link,
        frontTitleColor,
        backTitleColor,
        frontContentColor,
        backContentColor,
        frontIconColor,
        backIconColor,
        buttonStyle,
        buttonBackground,
        buttonColor,
        frontIconBackground,
        backIconBackground,
        transitionSpeed,
        displayButtonIcon,
        contentPosition,
        linkOpenNewTab,
        flipMode,
        isMouseLeaveOn,
        frontTitleTag,
        backTitleTag,
    } = attributes;

    // Genereate different button styles
    const handleButtonStyle = (newStyle) => {
        const buttonStyle = newStyle;
        const buttonClasses = getButtonClasses(newStyle);

        setAttributes({ buttonStyle, buttonClasses });
    };

    return (
        <>
            <InspectorPanel
                advancedControlProps={{
                    marginPrefix: dimensionsMargin,
                    paddingPrefix: dimensionsPadding,
                    borderPrefix: borderShadow,
                    hasMargin: true,
                    hasBackground: false,
                }}
            >
                <InspectorPanel.General>
                    <InspectorPanel.PanelBody
                        title={__("Selected Side", "essential-blocks")}
                        initialOpen={true}
                    >
                        <BaseControl>
                            <ButtonGroup id="eb-flipbox-sides">
                                {FLIPBOX_SIDES.map((item, index) => (
                                    <Button
                                        key={index}
                                        isPrimary={selectedSide === item.value}
                                        isSecondary={
                                            selectedSide !== item.value
                                        }
                                        onClick={() =>
                                            setAttributes({
                                                selectedSide: item.value,
                                            })
                                        }
                                    >
                                        {item.label}
                                    </Button>
                                ))}
                            </ButtonGroup>
                        </BaseControl>
                    </InspectorPanel.PanelBody>
                    <InspectorPanel.PanelBody
                        title={__("Flipbox Settings", "essential-blocks")}
                        initialOpen={true}
                    >
                        <SelectControl
                            label={__("Flip Mode", "essential-blocks")}
                            value={flipMode}
                            options={applyFilters(
                                "eb_flipbox_modes",
                                FLIP_MODE,
                            )}
                            onChange={(selected) =>
                                setAttributes({
                                    flipMode: selected,
                                })
                            }
                            help={
                                flipMode === "click"
                                    ? __(
                                        "Click mode only available in frontend.",
                                        "essential-blocks",
                                    )
                                    : ""
                            }
                        />
                        {"click" === flipMode && (
                            <ToggleControl
                                label={__(
                                    "Use Mouse Leave when click mode on",
                                    "essential-blocks",
                                )}
                                checked={isMouseLeaveOn}
                                onChange={() => {
                                    setAttributes({
                                        isMouseLeaveOn: !isMouseLeaveOn,
                                    });
                                }}
                            />
                        )}
                        <BaseControl
                            label={__("Alignment", "essential-blocks")}
                            id="eb-button-group-alignment"
                        >
                            <ButtonGroup id="eb-button-group-alignment">
                                {CONTENT_POSITION.map((item, index) => (
                                    <Button
                                        key={index}
                                        isPrimary={
                                            contentPosition === item.value
                                        }
                                        isSecondary={
                                            contentPosition !== item.value
                                        }
                                        onClick={() =>
                                            setAttributes({
                                                contentPosition: item.value,
                                            })
                                        }
                                    >
                                        {item.label}
                                    </Button>
                                ))}
                            </ButtonGroup>
                        </BaseControl>
                        <ResponsiveRangeController
                            baseLabel={__("Box Height", "essential-blocks")}
                            controlName={boxHeightAttr}
                            min={0}
                            max={1000}
                            step={1}
                            noUnits
                        />
                        <ResponsiveRangeController
                            baseLabel={__("Box Width", "essential-blocks")}
                            controlName={boxWidthAttr}
                            min={0}
                            max={600}
                            step={1}
                            noUnits
                        />
                        <SelectControl
                            label={__("Flipbox Type", "essential-blocks")}
                            value={flipType}
                            options={FLIPBOX_TYPE}
                            onChange={(newStyle) =>
                                setAttributes({
                                    flipType: newStyle,
                                })
                            }
                        />

                        <RangeControl
                            label={__(
                                "Transition Speed(millisecond)",
                                "essential-blocks",
                            )}
                            value={transitionSpeed}
                            onChange={(newValue) => {
                                let transitionSpeed = newValue;
                                setAttributes({
                                    transitionSpeed,
                                });
                            }}
                            min={0}
                            max={5000}
                            step={500}
                        />

                        {selectedSide === "front" && (
                            <>
                                <BaseControl
                                    label={__("Icon Type", "essential-blocks")}
                                    id="eb-flipbox-icon-type"
                                >
                                    <ButtonGroup id="eb-flipbox-icon-type">
                                        {ICON_TYPE.map((item, index) => (
                                            <Button
                                                key={index}
                                                isPrimary={
                                                    frontIconOrImage ===
                                                    item.value
                                                }
                                                isSecondary={
                                                    frontIconOrImage !==
                                                    item.value
                                                }
                                                onClick={() =>
                                                    setAttributes({
                                                        frontIconOrImage:
                                                            item.value,
                                                    })
                                                }
                                            >
                                                {item.label}
                                            </Button>
                                        ))}
                                    </ButtonGroup>
                                </BaseControl>
                            </>
                        )}

                        {selectedSide === "back" && (
                            <>
                                <BaseControl
                                    label={__("Icon Type", "essential-blocks")}
                                    id="eb-flipbox-icon-type"
                                >
                                    <ButtonGroup id="eb-flipbox-icon-type">
                                        {ICON_TYPE.map((item, index) => (
                                            <Button
                                                key={index}
                                                isPrimary={
                                                    backIconOrImage ===
                                                    item.value
                                                }
                                                isSecondary={
                                                    backIconOrImage !==
                                                    item.value
                                                }
                                                onClick={() =>
                                                    setAttributes({
                                                        backIconOrImage:
                                                            item.value,
                                                    })
                                                }
                                            >
                                                {item.label}
                                            </Button>
                                        ))}
                                    </ButtonGroup>
                                </BaseControl>
                            </>
                        )}
                    </InspectorPanel.PanelBody>
                    {selectedSide === "front" &&
                        frontIconOrImage === "icon" && (
                            <InspectorPanel.PanelBody
                                title={__(
                                    "Front Icon Settings",
                                    "essential-blocks",
                                )}
                                initialOpen={false}
                            >
                                <>
                                    <EBIconPicker
                                        value={frontIcon}
                                        onChange={(frontIcon) =>
                                            setAttributes({
                                                frontIcon,
                                            })
                                        }
                                        title={__(
                                            "Select Front Icon",
                                            "essential-blocks",
                                        )}
                                    />
                                    {frontIcon && (
                                        <ResponsiveRangeController
                                            baseLabel={__(
                                                "Icon Size",
                                                "essential-blocks",
                                            )}
                                            controlName={boxFrontIconSizeAttr}
                                            min={8}
                                            max={100}
                                        />
                                    )}
                                </>
                            </InspectorPanel.PanelBody>
                        )}
                    {selectedSide === "front" &&
                        frontIconOrImage === "image" && (
                            <ImageComponent.GeneralTab
                                label={__(
                                    "Front Image Settings",
                                    "essential-blocks",
                                )}
                                imageAttrProps={FRONT_IMG_ATTR}
                                attrPrefix="front"
                            />
                        )}
                    {selectedSide === "back" && backIconOrImage === "icon" && (
                        <InspectorPanel.PanelBody
                            title={__("Back Icon Settings", "essential-blocks")}
                            initialOpen={false}
                        >
                            <>
                                <EBIconPicker
                                    value={backIcon}
                                    onChange={(backIcon) =>
                                        setAttributes({
                                            backIcon,
                                        })
                                    }
                                    title={__(
                                        "Select Back Icon",
                                        "essential-blocks",
                                    )}
                                />
                                {backIcon && (
                                    <ResponsiveRangeController
                                        baseLabel={__(
                                            "Icon Size",
                                            "essential-blocks",
                                        )}
                                        controlName={boxBackIconSizeAttr}
                                        min={8}
                                        max={100}
                                    />
                                )}
                            </>
                        </InspectorPanel.PanelBody>
                    )}
                    {selectedSide === "back" && backIconOrImage === "image" && (
                        <>
                            <ImageComponent.GeneralTab
                                label={__(
                                    "Back Image Settings",
                                    "essential-blocks",
                                )}
                                imageAttrProps={BACK_IMG_ATTR}
                                attrPrefix="back"
                            />
                        </>
                    )}
                    <InspectorPanel.PanelBody
                        title={__("Flipbox Content", "essential-blocks")}
                        initialOpen={false}
                    >
                        {selectedSide === "front" && (
                            <>
                                <ToggleControl
                                    label={__(
                                        "Show Title?",
                                        "essential-blocks",
                                    )}
                                    checked={showFrontTitle}
                                    onChange={() => {
                                        setAttributes({
                                            showFrontTitle: !showFrontTitle,
                                        });
                                    }}
                                />

                                {showFrontTitle && (
                                    <>
                                        <DynamicInputControl
                                            label={__(
                                                "Front Title",
                                                "essential-blocks",
                                            )}
                                            attrName="frontTitle"
                                            inputValue={frontTitle}
                                            setAttributes={setAttributes}
                                            onChange={(text) =>
                                                setAttributes({
                                                    frontTitle: text,
                                                })
                                            }
                                        />

                                        <BaseControl
                                            label={__(
                                                "Title Tag",
                                                "essential-blocks",
                                            )}
                                        >
                                            <ButtonGroup>
                                                {HEADER_TAGS.map(
                                                    (header, index) => (
                                                        <Button
                                                            key={index}
                                                            isSecondary={
                                                                frontTitleTag !==
                                                                header.value
                                                            }
                                                            isPrimary={
                                                                frontTitleTag ===
                                                                header.value
                                                            }
                                                            onClick={() =>
                                                                setAttributes({
                                                                    frontTitleTag:
                                                                        header.value,
                                                                })
                                                            }
                                                        >
                                                            {header.label}
                                                        </Button>
                                                    ),
                                                )}
                                            </ButtonGroup>
                                        </BaseControl>
                                    </>
                                )}
                                <ToggleControl
                                    label={__(
                                        "Show Content?",
                                        "essential-blocks",
                                    )}
                                    checked={showFrontContent}
                                    onChange={() => {
                                        setAttributes({
                                            showFrontContent: !showFrontContent,
                                        });
                                    }}
                                />
                                {showFrontContent && (
                                    <DynamicInputControl
                                        label={__(
                                            "Front Content",
                                            "essential-blocks",
                                        )}
                                        attrName="frontContent"
                                        inputValue={frontContent}
                                        setAttributes={setAttributes}
                                        onChange={(text) =>
                                            setAttributes({
                                                frontContent: text,
                                            })
                                        }
                                        isTextarea={true}
                                    />
                                )}
                            </>
                        )}
                        {selectedSide === "back" && (
                            <>
                                <ToggleControl
                                    label={__(
                                        "Show Title?",
                                        "essential-blocks",
                                    )}
                                    checked={showBackTitle}
                                    onChange={() => {
                                        setAttributes({
                                            showBackTitle: !showBackTitle,
                                        });
                                    }}
                                />
                                {showBackTitle && (
                                    <>
                                        <DynamicInputControl
                                            label={__(
                                                "Back Title",
                                                "essential-blocks",
                                            )}
                                            attrName="backTitle"
                                            inputValue={backTitle}
                                            setAttributes={setAttributes}
                                            onChange={(text) =>
                                                setAttributes({
                                                    backTitle: text,
                                                })
                                            }
                                        />
                                        <BaseControl
                                            label={__(
                                                "Title Tag",
                                                "essential-blocks",
                                            )}
                                        >
                                            <ButtonGroup>
                                                {HEADER_TAGS.map(
                                                    (header, index) => (
                                                        <Button
                                                            key={index}
                                                            isSecondary={
                                                                backTitleTag !==
                                                                header.value
                                                            }
                                                            isPrimary={
                                                                backTitleTag ===
                                                                header.value
                                                            }
                                                            onClick={() =>
                                                                setAttributes({
                                                                    backTitleTag:
                                                                        header.value,
                                                                })
                                                            }
                                                        >
                                                            {header.label}
                                                        </Button>
                                                    ),
                                                )}
                                            </ButtonGroup>
                                        </BaseControl>
                                    </>
                                )}
                                <ToggleControl
                                    label={__(
                                        "Show Content?",
                                        "essential-blocks",
                                    )}
                                    checked={showBackContent}
                                    onChange={() => {
                                        setAttributes({
                                            showBackContent: !showBackContent,
                                        });
                                    }}
                                />
                                {showBackContent && (
                                    <DynamicInputControl
                                        label={__(
                                            "Back Content",
                                            "essential-blocks",
                                        )}
                                        attrName="backContent"
                                        inputValue={backContent}
                                        setAttributes={setAttributes}
                                        onChange={(text) =>
                                            setAttributes({ backContent: text })
                                        }
                                        isTextarea={true}
                                    />
                                )}
                            </>
                        )}
                    </InspectorPanel.PanelBody>
                    <InspectorPanel.PanelBody
                        title={__("Link Settings", "essential-blocks")}
                        initialOpen={false}
                    >
                        <PanelRow>
                            <em>
                                {__(
                                    "Note: Link settings will only work on back side.",
                                    "essential-blocks",
                                )}
                            </em>
                        </PanelRow>
                        <BaseControl
                            label={__("Link Type", "essential-blocks")}
                            id="eb-flipbox-link-type"
                        >
                            <ButtonGroup id="eb-flipbox-link-type">
                                {LINK_TYPE.map((item, index) => (
                                    <Button
                                        key={index}
                                        isPrimary={linkType === item.value}
                                        isSecondary={linkType !== item.value}
                                        onClick={() => {
                                            setAttributes({
                                                linkType: item.value,
                                            }),
                                                handleButtonStyle(buttonStyle);
                                        }}
                                    >
                                        {item.label}
                                    </Button>
                                ))}
                            </ButtonGroup>
                        </BaseControl>
                        <EBTextControl
                            label={__("Link", "essential-blocks")}
                            fieldType="url"
                            value={link || ''}
                            onChange={(text) =>
                                setAttributes({
                                    link: text,
                                })
                            }
                            placeholder="https://example.com"
                            help={__(
                                "Enter a valid URL.",
                                "essential-blocks"
                            )}
                            showValidation={true}
                            enableSecurity={true}
                        />
                        <ToggleControl
                            label={__("Open in New Tab", "essential-blocks")}
                            checked={linkOpenNewTab}
                            onChange={() =>
                                setAttributes({
                                    linkOpenNewTab: !linkOpenNewTab,
                                })
                            }
                        />

                        {linkType === "button" && (
                            <>
                                <TextControl
                                    label={__(
                                        "Button Text",
                                        "essential-blocks",
                                    )}
                                    value={buttonText}
                                    onChange={(newText) =>
                                        setAttributes({
                                            buttonText: newText,
                                        })
                                    }
                                />
                                <SelectControl
                                    label={__(
                                        "Button Style",
                                        "essential-blocks",
                                    )}
                                    value={buttonStyle}
                                    options={BUTTON_STYLES}
                                    onChange={(newStyle) =>
                                        handleButtonStyle(newStyle)
                                    }
                                />
                            </>
                        )}
                    </InspectorPanel.PanelBody>
                </InspectorPanel.General>
                <InspectorPanel.Style>
                    <InspectorPanel.PanelBody>
                        <BaseControl
                            label={__("Selected Side", "essential-blocks")}
                        >
                            <ButtonGroup id="eb-flipbox-sides">
                                {FLIPBOX_SIDES.map((item, index) => (
                                    <Button
                                        key={index}
                                        isPrimary={selectedSide === item.value}
                                        isSecondary={
                                            selectedSide !== item.value
                                        }
                                        onClick={() =>
                                            setAttributes({
                                                selectedSide: item.value,
                                            })
                                        }
                                    >
                                        {item.label}
                                    </Button>
                                ))}
                            </ButtonGroup>
                        </BaseControl>
                    </InspectorPanel.PanelBody>
                    <InspectorPanel.PanelBody
                        title={__("Flipbox Style", "essential-blocks")}
                        initialOpen={true}
                    >
                        {selectedSide === "front" && (
                            <>
                                <ColorControl
                                    label={__(
                                        "Front Title",
                                        "essential-blocks",
                                    )}
                                    color={frontTitleColor}
                                    attributeName={"frontTitleColor"}
                                />
                                <ResponsiveDimensionsControl
                                    controlName={frontTitlePadding}
                                    baseLabel={__(
                                        "Front Title Padding",
                                        "essential-blocks",
                                    )}
                                />
                                <ColorControl
                                    label={__(
                                        "Front Content",
                                        "essential-blocks",
                                    )}
                                    color={frontContentColor}
                                    attributeName={"frontContentColor"}
                                />
                                <ResponsiveDimensionsControl
                                    controlName={frontContentPadding}
                                    baseLabel={__(
                                        "Padding",
                                        "essential-blocks",
                                    )}
                                />
                                <BaseControl>
                                    <h3 className="eb-control-title">
                                        {__(
                                            "Front Side Background",
                                            "essential-blocks",
                                        )}
                                    </h3>
                                </BaseControl>
                                <BackgroundControl
                                    controlName={flipboxFrontWrapper}
                                />
                                <ResponsiveDimensionsControl
                                    controlName={frontItemPadding}
                                    baseLabel={__(
                                        "Items Padding",
                                        "essential-blocks",
                                    )}
                                />
                            </>
                        )}

                        {selectedSide === "back" && (
                            <>
                                <ColorControl
                                    label={__(
                                        "Back Title Color",
                                        "essential-blocks",
                                    )}
                                    color={backTitleColor}
                                    attributeName={"backTitleColor"}
                                />
                                <ResponsiveDimensionsControl
                                    controlName={backTitlePadding}
                                    baseLabel={__(
                                        "Back Title Padding",
                                        "essential-blocks",
                                    )}
                                />
                                <ColorControl
                                    label={__(
                                        "Back Content Color",
                                        "essential-blocks",
                                    )}
                                    color={backContentColor}
                                    attributeName={"backContentColor"}
                                />
                                <ResponsiveDimensionsControl
                                    controlName={backContentPadding}
                                    baseLabel={__(
                                        "Padding",
                                        "essential-blocks",
                                    )}
                                />
                                <BaseControl>
                                    <h3 className="eb-control-title">
                                        {__(
                                            "Back Side Background",
                                            "essential-blocks",
                                        )}
                                    </h3>
                                </BaseControl>
                                <BackgroundControl
                                    controlName={flipboxBackWrapper}
                                />
                                <ResponsiveDimensionsControl
                                    controlName={backItemPadding}
                                    baseLabel={__(
                                        "Items Padding",
                                        "essential-blocks",
                                    )}
                                />
                            </>
                        )}
                    </InspectorPanel.PanelBody>
                    {selectedSide === "front" &&
                        frontIconOrImage === "icon" && (
                            <InspectorPanel.PanelBody
                                title={__(
                                    "Front Icon Style",
                                    "essential-blocks",
                                )}
                                initialOpen={false}
                            >
                                <>
                                    {frontIcon && (
                                        <>
                                            <ColorControl
                                                label={__(
                                                    "Icon Color",
                                                    "essential-blocks",
                                                )}
                                                color={frontIconColor}
                                                attributeName={"frontIconColor"}
                                            />

                                            <ColorControl
                                                label={__(
                                                    "Icon Background",
                                                    "essential-blocks",
                                                )}
                                                color={frontIconBackground}
                                                attributeName={
                                                    "frontIconBackground"
                                                }
                                            />

                                            <BaseControl>
                                                <h3 className="eb-control-title">
                                                    {__(
                                                        "Margin & Padding",
                                                        "essential-blocks",
                                                    )}
                                                </h3>
                                            </BaseControl>
                                            <ResponsiveDimensionsControl
                                                className="frontIconMargin"
                                                controlName={frontIconMargin}
                                                baseLabel={__(
                                                    "Margin",
                                                    "essential-blocks",
                                                )}
                                            />
                                            <ResponsiveDimensionsControl
                                                className="frontIconPadding"
                                                controlName={frontIconPadding}
                                                baseLabel={__(
                                                    "Padding",
                                                    "essential-blocks",
                                                )}
                                            />
                                            <BaseControl>
                                                <h3 className="eb-control-title">
                                                    {__(
                                                        "Border",
                                                        "essential-blocks",
                                                    )}
                                                </h3>
                                            </BaseControl>
                                            <BorderShadowControl
                                                controlName={
                                                    borderShadowFrontIcon
                                                }
                                                noShadow
                                            />
                                        </>
                                    )}
                                </>
                            </InspectorPanel.PanelBody>
                        )}
                    {selectedSide === "front" &&
                        frontIconOrImage === "image" && (
                            <ImageComponent.StyleTab
                                label={__(
                                    "Front Image Style",
                                    "essential-blocks",
                                )}
                                imageAttrProps={FRONT_IMG_ATTR}
                                attrPrefix="front"
                                border={frontImageBorder}
                                padding={frontImgPadding}
                                margin={frontImgMargin}
                                hasWidth={false}
                                hasHeight={false}
                                useImageSize={true}
                                imageSize={frontImgSizeAttr}
                                hasRadius={true}
                                radius={frontImgRadiusAttr}
                            />
                        )}
                    {selectedSide === "back" && backIconOrImage === "icon" && (
                        <InspectorPanel.PanelBody
                            title={__("Back Icon Style", "essential-blocks")}
                            initialOpen={false}
                        >
                            <>
                                {backIcon && (
                                    <>
                                        <ColorControl
                                            label={__(
                                                "Icon Color",
                                                "essential-blocks",
                                            )}
                                            color={backIconColor}
                                            attributeName={"backIconColor"}
                                        />

                                        <ColorControl
                                            label={__(
                                                "Icon Background",
                                                "essential-blocks",
                                            )}
                                            color={backIconBackground}
                                            attributeName={"backIconBackground"}
                                        />

                                        <BaseControl>
                                            <h3 className="eb-control-title">
                                                {__(
                                                    "Margin & Padding",
                                                    "essential-blocks",
                                                )}
                                            </h3>
                                        </BaseControl>
                                        <ResponsiveDimensionsControl
                                            className="backIconMargin"
                                            controlName={backIconMargin}
                                            baseLabel={__(
                                                "Margin",
                                                "essential-blocks",
                                            )}
                                        />
                                        <ResponsiveDimensionsControl
                                            className="backIconPadding"
                                            controlName={backIconPadding}
                                            baseLabel={__(
                                                "Padding",
                                                "essential-blocks",
                                            )}
                                        />
                                        <BaseControl>
                                            <h3 className="eb-control-title">
                                                {__(
                                                    "Border",
                                                    "essential-blocks",
                                                )}
                                            </h3>
                                        </BaseControl>
                                        <BorderShadowControl
                                            controlName={borderShadowBackIcon}
                                            noShadow
                                        />
                                    </>
                                )}
                            </>
                        </InspectorPanel.PanelBody>
                    )}
                    {selectedSide === "back" && backIconOrImage === "image" && (
                        <ImageComponent.StyleTab
                            label={__("Back Image Style", "essential-blocks")}
                            imageAttrProps={BACK_IMG_ATTR}
                            attrPrefix="back"
                            border={backImageBorder}
                            padding={backImgPadding}
                            margin={backImgMargin}
                            hasWidth={false}
                            hasHeight={false}
                            useImageSize={true}
                            imageSize={backImgSizeAttr}
                            hasRadius={true}
                            radius={backImgRadiusAttr}
                        />
                    )}
                    <InspectorPanel.PanelBody
                        title={__("Typography", "essential-blocks")}
                        initialOpen={false}
                    >
                        <TypographyDropdown
                            baseLabel={__("Title", "essential-blocks")}
                            typographyPrefixConstant={typoPrefix_title}
                        />

                        <TypographyDropdown
                            baseLabel={__("Content", "essential-blocks")}
                            typographyPrefixConstant={typoPrefix_content}
                        />
                    </InspectorPanel.PanelBody>
                    {linkType === "button" && buttonStyle === "custom" && (
                        <InspectorPanel.PanelBody
                            title={__("Button Style", "essential-blocks")}
                        >
                            <>
                                <ColorControl
                                    label={__("Background", "essential-blocks")}
                                    color={buttonBackground}
                                    attributeName={"buttonBackground"}
                                />
                                <ColorControl
                                    label={__("Color", "essential-blocks")}
                                    color={buttonColor}
                                    attributeName={"buttonColor"}
                                />
                                <ResponsiveRangeController
                                    baseLabel={__(
                                        "Button Size",
                                        "essential-blocks",
                                    )}
                                    controlName={buttonIconSizeAttr}
                                    min={20}
                                    max={600}
                                />
                                <BaseControl>
                                    <h3 className="eb-control-title">
                                        {__("Padding", "essential-blocks")}
                                    </h3>
                                </BaseControl>
                                <ResponsiveDimensionsControl
                                    className="forWrapperPadding"
                                    controlName={buttonPadding}
                                    baseLabel={__(
                                        "Padding",
                                        "essential-blocks",
                                    )}
                                />
                                <BaseControl>
                                    <h3 className="eb-control-title">
                                        {__(
                                            "Border & Shadow",
                                            "essential-blocks",
                                        )}
                                    </h3>
                                </BaseControl>
                                <BorderShadowControl
                                    controlName={borderShadowBtn}
                                />
                                <BaseControl>
                                    <h3 className="eb-control-title">
                                        {__("Button Icon", "essential-blocks")}
                                    </h3>
                                </BaseControl>
                                <ToggleControl
                                    label={__(
                                        "Display Button Icon",
                                        "essential-blocks",
                                    )}
                                    checked={displayButtonIcon}
                                    onChange={() =>
                                        setAttributes({
                                            displayButtonIcon:
                                                !displayButtonIcon,
                                        })
                                    }
                                />
                                {displayButtonIcon && (
                                    <EBIconPicker
                                        value={buttonIcon}
                                        onChange={(buttonIcon) =>
                                            setAttributes({
                                                buttonIcon,
                                            })
                                        }
                                        title={__(
                                            "Select Icon",
                                            "essential-blocks",
                                        )}
                                    />
                                )}
                                {displayButtonIcon && buttonIcon && (
                                    <>
                                        <BaseControl
                                            label={__(
                                                "Icon Position",
                                                "essential-blocks",
                                            )}
                                            id="eb-flipbox-icon-pos"
                                        >
                                            <ButtonGroup id="eb-flipbox-icon-pos">
                                                {ICON_POSITIONS.map(
                                                    (item, index) => (
                                                        <Button
                                                            key={index}
                                                            style={{
                                                                zIndex: 0,
                                                            }} // ? Add this style to fix icon list and primary button issue
                                                            // isLarge
                                                            isSecondary={
                                                                buttonIconPos !==
                                                                item.value
                                                            }
                                                            isPrimary={
                                                                buttonIconPos ===
                                                                item.value
                                                            }
                                                            onClick={() =>
                                                                setAttributes({
                                                                    buttonIconPos:
                                                                        item.value,
                                                                })
                                                            }
                                                        >
                                                            {item.label}
                                                        </Button>
                                                    ),
                                                )}
                                            </ButtonGroup>
                                        </BaseControl>
                                    </>
                                )}
                            </>
                        </InspectorPanel.PanelBody>
                    )}
                </InspectorPanel.Style>
            </InspectorPanel>
        </>
    );
};

export default Inspector;