HEX
Server: Apache
System: Linux www 5.10.0-10-amd64 #1 SMP Debian 5.10.84-1 (2021-12-08) x86_64
User: root (0)
PHP: 8.2.1
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals
Upload Files
File: /mnt/drbd/www/edenhouse/wp-content/plugins/essential-blocks/blocks/number-counter/src/inspector.js
/**
 * WordPress dependencies
 */
import { __ } from "@wordpress/i18n";
import { InspectorControls, MediaUpload } from "@wordpress/block-editor";
import {
    PanelBody,
    ToggleControl,
    TextControl,
    SelectControl,
    BaseControl,
    TabPanel,
    Button,
    ButtonGroup,
    __experimentalDivider as Divider,
} from "@wordpress/components";
import { select } from "@wordpress/data";

/**
 * Internal dependencies
 */

import objAttributes from "./attributes";

const {
    // objAttributes,
    ColorControl,
    ResponsiveDimensionsControl,
    ResponsiveRangeController,
    TypographyDropdown,
    BackgroundControl,
    BorderShadowControl,
    GradientColorControl,
    ImageAvatar,
    faIcons,
    EBIconPicker,
    AdvancedControls,
} = window.EBControls;

import {
    SEPARATOR_OPTIONS,
    LAYOUT_OPTIONS,
    MEDIA_TYPES,
    ICON_IMAGE_BG_TYPES,
    MEDIA_ALIGNMENTS_ON_FLEX_COLUMN,
    MEDIA_ALIGNMENTS_ON_FLEX_ROW,
    CONTENTS_ALIGNMENTS_ON_FLEX_ROW,
    sizeUnitTypes,
    imgHeightUnits,
    LAYOUT_TYPES,
    HEADER_TAGS,
    CONTENTS_ALIGNMENTS,
    // HOVER_EFFECT,
} from "./constants";

import {
    typoPrefix_numPrefix,
    typoPrefix_numSuffix,
    typoPrefix_number,
    typoPrefix_title,
} from "./constants/typographyPrefixConstants";

import {
    wrapperMargin,
    wrapperPadding,

    //
    mediaBgPadding,
    mediaBgMargin,
    mediaBgRadius,
} from "./constants/dimensionsConstants";
import { WrapBg } from "./constants/backgroundsConstants";
import { wrpBdShadow } from "./constants/borderShadowConstants";
import {
    rgNumTitle,
    rgNumPrefix,
    rgNumSuffix,

    //
    mediaIconSize,
    mediaImageWidth,
    mediaImageHeight,
    mediaContentGap,
} from "./constants/rangeNames";

const Inspector = (props) => {
    const { attributes, setAttributes } = props;
    const {
        // responsive control attributes ⬇
        resOption,

        // counter settings attributes ⬇
        startValue,
        target,
        counterPrefix,
        counterSuffix,
        duration,
        isShowSeparator,
        separastorSelectLabel,
        layoutLabel,

        // counter color attributes ⬇
        titleColor,
        numberColor,
        numPrefixColor,
        numSuffixColor,

        //
        //
        layoutPreset,

        //
        rootFlexDirection,
        contentAlignment,
        mediaAlignSelf,
        contentsAlignSelf,

        //
        media,
        selectedIcon,
        iconColor,
        useIconBg,
        iconBgType,
        iconBgColor,
        iconBgGradient,
        imageUrl,
        imageId,
        isMediaImgHeightAuto,
        counterTitleLevel,
        titleLevel,
    } = attributes;

    const handleSeparatorChange = (separastorSelectLabel) => {
        switch (separastorSelectLabel) {
            case "Default":
                setAttributes({ separator: "," });
                break;

            case "Dot":
                setAttributes({ separator: "." });
                break;

            case "Space":
                setAttributes({ separator: " " });
                break;
        }
        setAttributes({ separastorSelectLabel });
    };

    const handleLayoutChange = (layoutLabel) => {
        switch (layoutLabel) {
            case "Default":
                setAttributes({ wrapperFlexDirection: "column" });
                break;

            case "Reverse":
                setAttributes({ wrapperFlexDirection: "column-reverse" });
                break;
        }
        setAttributes({ layoutLabel });
    };

    const handlePresetChange = (layoutPreset) => {
        switch (layoutPreset) {
            case "preset1":
                setAttributes({
                    rootFlexDirection: "column",
                    contentAlignment: "center",
                    mediaAlignSelf: "center",
                });
                break;

            case "preset2":
                setAttributes({
                    rootFlexDirection: "column-reverse",
                    contentAlignment: "center",
                    mediaAlignSelf: "center",
                });
                break;

            case "preset3":
                setAttributes({
                    rootFlexDirection: "row",
                    contentAlignment: "left",
                    mediaAlignSelf: "flex-start",
                });
                break;

            case "preset4":
                setAttributes({
                    rootFlexDirection: "row-reverse",
                    contentAlignment: "right",
                    mediaAlignSelf: "flex-start",
                });
                break;
        }
        setAttributes({ layoutPreset });
    };

    const resRequiredProps = {
        setAttributes,
        resOption,
        attributes,
        objAttributes,
    };

    return (
        <InspectorControls key="controls">
            <div className="eb-panel-control">
                <TabPanel
                    className="eb-parent-tab-panel"
                    activeClass="active-tab"
                    // onSelect={onSelect}
                    tabs={[
                        {
                            name: "general",
                            title: "General",
                            className: "eb-tab general",
                        },
                        {
                            name: "styles",
                            title: "Style",
                            className: "eb-tab styles",
                        },
                        {
                            name: "advance",
                            title: "Advanced",
                            className: "eb-tab advance",
                        },
                    ]}
                >
                    {(tab) => (
                        <div className={"eb-tab-controls" + tab.name}>
                            {tab.name === "general" && (
                                <>
                                    <PanelBody
                                    // initialOpen={false}
                                    >
                                        <BaseControl
                                            id="eb-infobox-image-icon"
                                            label={__(
                                                "Media Options",
                                                "essential-blocks"
                                            )}
                                        >
                                            <ButtonGroup id="eb-infobox-image-icon">
                                                {MEDIA_TYPES.map(
                                                    (value, index) => (
                                                        <Button
                                                            key={index}
                                                            isSecondary={
                                                                media !== value
                                                            }
                                                            isPrimary={
                                                                media === value
                                                            }
                                                            onClick={() =>
                                                                setAttributes({
                                                                    media: value,
                                                                })
                                                            }
                                                        >
                                                            {value}
                                                        </Button>
                                                    )
                                                )}
                                            </ButtonGroup>
                                        </BaseControl>
                                    </PanelBody>

                                    {media !== "none" && (
                                        <>
                                            <PanelBody
                                            // initialOpen={false}
                                            >
                                                <SelectControl
                                                    label={__(
                                                        "Layout Preset ",
                                                        "essential-blocks"
                                                    )}
                                                    value={layoutPreset}
                                                    options={LAYOUT_TYPES}
                                                    onChange={
                                                        handlePresetChange
                                                    }
                                                />

                                                <ResponsiveRangeController
                                                    baseLabel={__(
                                                        "Media & content spacing",
                                                        "Infobox"
                                                    )}
                                                    controlName={
                                                        mediaContentGap
                                                    }
                                                    resRequiredProps={
                                                        resRequiredProps
                                                    }
                                                    min={0}
                                                    max={500}
                                                    step={1}
                                                    noUnits
                                                />
                                            </PanelBody>
                                        </>
                                    )}

                                    <PanelBody
                                        title={__(
                                            "Counter Settings",
                                            "essential-blocks"
                                        )}
                                    // initialOpen={false}
                                    >
                                        <BaseControl id="eb-counter-start-value">
                                            <TextControl
                                                label={__(
                                                    "Starting Number",
                                                    "essential-blocks"
                                                )}
                                                value={startValue}
                                                type="number"
                                                onChange={(value) =>
                                                    !/[\-\.]/.test(value) &&
                                                    setAttributes({
                                                        startValue: value,
                                                    })
                                                }
                                            />
                                        </BaseControl>
                                        <BaseControl id="eb-counter-end-value">
                                            <TextControl
                                                label={__(
                                                    "Ending Number",
                                                    "essential-blocks"
                                                )}
                                                value={target}
                                                type="number"
                                                onChange={(value) =>
                                                    !/[\-\.]/.test(value) &&
                                                    setAttributes({
                                                        target: value,
                                                    })
                                                }
                                            />
                                        </BaseControl>
                                        <BaseControl id="eb-counter-duration">
                                            <TextControl
                                                label={__(
                                                    "Animation Duration",
                                                    "essential-blocks"
                                                )}
                                                value={duration}
                                                type="number"
                                                onChange={(value) =>
                                                    !/[\-\.]/.test(value) &&
                                                    setAttributes({
                                                        duration: value,
                                                    })
                                                }
                                            />
                                        </BaseControl>
                                        <BaseControl id="eb-counter-prefix">
                                            <TextControl
                                                label={__(
                                                    "Number Prefix",
                                                    "essential-blocks"
                                                )}
                                                value={counterPrefix}
                                                onChange={(counterPrefix) =>
                                                    setAttributes({
                                                        counterPrefix,
                                                    })
                                                }
                                            />
                                        </BaseControl>
                                        <BaseControl id="eb-counter-suffix">
                                            <TextControl
                                                label={__(
                                                    "Number Suffix",
                                                    "essential-blocks"
                                                )}
                                                value={counterSuffix}
                                                onChange={(counterSuffix) =>
                                                    setAttributes({
                                                        counterSuffix,
                                                    })
                                                }
                                            />
                                        </BaseControl>

                                        <SelectControl
                                            label={__(
                                                "Content layouts",
                                                "essential-blocks"
                                            )}
                                            options={LAYOUT_OPTIONS}
                                            value={layoutLabel}
                                            onChange={(value) =>
                                                handleLayoutChange(value)
                                            }
                                        />

                                        <ToggleControl
                                            label={__(
                                                "Thousand Separator",
                                                "essential-blocks"
                                            )}
                                            checked={isShowSeparator}
                                            onChange={() =>
                                                setAttributes({
                                                    isShowSeparator: !isShowSeparator,
                                                })
                                            }
                                        />

                                        {isShowSeparator && (
                                            <SelectControl
                                                label={__(
                                                    "Separator",
                                                    "essential-blocks"
                                                )}
                                                options={SEPARATOR_OPTIONS}
                                                value={separastorSelectLabel}
                                                onChange={(value) =>
                                                    handleSeparatorChange(value)
                                                }
                                            />
                                        )}
                                    </PanelBody>
                                    <PanelBody>
                                        <BaseControl
                                            label={__(
                                                "Counter Title Level",
                                                "essential-blocks"
                                            )}
                                            id="eb-advance-heading-alignment"
                                        >
                                            <ButtonGroup className="eb-advance-heading-alignment eb-html-tag-buttongroup">
                                                {HEADER_TAGS.map(
                                                    (item, key) => (
                                                        <Button
                                                            key={key}
                                                            // isLarge
                                                            isPrimary={
                                                                counterTitleLevel ===
                                                                item.value
                                                            }
                                                            isSecondary={
                                                                counterTitleLevel !==
                                                                item.value
                                                            }
                                                            onClick={() =>
                                                                setAttributes({
                                                                    counterTitleLevel:
                                                                        item.value,
                                                                })
                                                            }
                                                        >
                                                            {item.label}
                                                        </Button>
                                                    )
                                                )}
                                            </ButtonGroup>
                                        </BaseControl>
                                        <Divider />
                                        <BaseControl
                                            label={__(
                                                "Title Level",
                                                "essential-blocks"
                                            )}
                                            id="eb-advance-heading-alignment"
                                        >
                                            <ButtonGroup className="eb-advance-heading-alignment eb-html-tag-buttongroup">
                                                {HEADER_TAGS.map(
                                                    (item, key) => (
                                                        <Button
                                                            key={key}
                                                            // isLarge
                                                            isPrimary={
                                                                titleLevel ===
                                                                item.value
                                                            }
                                                            isSecondary={
                                                                titleLevel !==
                                                                item.value
                                                            }
                                                            onClick={() =>
                                                                setAttributes({
                                                                    titleLevel:
                                                                        item.value,
                                                                })
                                                            }
                                                        >
                                                            {item.label}
                                                        </Button>
                                                    )
                                                )}
                                            </ButtonGroup>
                                        </BaseControl>
                                    </PanelBody>
                                </>
                            )}
                            {tab.name === "styles" && (
                                <>
                                    {media !== "none" && (
                                        <PanelBody
                                            title={__(
                                                "Media",
                                                "essential-blocks"
                                            )}
                                        >
                                            {media === "icon" && (
                                                <>
                                                    <EBIconPicker
                                                        value={selectedIcon}
                                                        onChange={(icon) =>
                                                            setAttributes({
                                                                selectedIcon: icon,
                                                            })
                                                        }
                                                    />

                                                    {selectedIcon && (
                                                        <ResponsiveRangeController
                                                            baseLabel={__(
                                                                "Icon Size",
                                                                "essential-blocks"
                                                            )}
                                                            controlName={
                                                                mediaIconSize
                                                            }
                                                            resRequiredProps={
                                                                resRequiredProps
                                                            }
                                                            min={8}
                                                            max={200}
                                                            step={1}
                                                        />
                                                    )}

                                                    <ColorControl
                                                        label={__(
                                                            "Color",
                                                            "essential-blocks"
                                                        )}
                                                        color={iconColor}
                                                        onChange={(iconColor) =>
                                                            setAttributes({
                                                                iconColor,
                                                            })
                                                        }
                                                    />

                                                    <ResponsiveDimensionsControl
                                                        resRequiredProps={
                                                            resRequiredProps
                                                        }
                                                        controlName={
                                                            mediaBgPadding
                                                        }
                                                        baseLabel="Padding"
                                                    />

                                                    <ToggleControl
                                                        label={__(
                                                            "Use Background",
                                                            "essential-blocks"
                                                        )}
                                                        checked={useIconBg}
                                                        onChange={() =>
                                                            setAttributes({
                                                                useIconBg: !useIconBg,
                                                            })
                                                        }
                                                    />

                                                    {useIconBg && (
                                                        <>
                                                            <BaseControl
                                                                label={__(
                                                                    "Background Type",
                                                                    "essential-blocks"
                                                                )}
                                                            >
                                                                <ButtonGroup id="eb-infobox-infobox-background">
                                                                    {ICON_IMAGE_BG_TYPES.map(
                                                                        (
                                                                            {
                                                                                value,
                                                                                label,
                                                                            },
                                                                            index
                                                                        ) => (
                                                                            <Button
                                                                                key={
                                                                                    index
                                                                                }
                                                                                isPrimary={
                                                                                    iconBgType ===
                                                                                    value
                                                                                }
                                                                                isSecondary={
                                                                                    iconBgType !==
                                                                                    value
                                                                                }
                                                                                onClick={() =>
                                                                                    setAttributes(
                                                                                        {
                                                                                            iconBgType: value,
                                                                                        }
                                                                                    )
                                                                                }
                                                                            >
                                                                                {
                                                                                    label
                                                                                }
                                                                            </Button>
                                                                        )
                                                                    )}
                                                                </ButtonGroup>
                                                            </BaseControl>

                                                            {iconBgType ===
                                                                "fill" && (
                                                                    <ColorControl
                                                                        label={__(
                                                                            "Background Color",
                                                                            "essential-blocks"
                                                                        )}
                                                                        color={
                                                                            iconBgColor
                                                                        }
                                                                        onChange={(
                                                                            iconBgColor
                                                                        ) =>
                                                                            setAttributes(
                                                                                {
                                                                                    iconBgColor,
                                                                                }
                                                                            )
                                                                        }
                                                                    />
                                                                )}

                                                            {iconBgType ===
                                                                "gradient" && (
                                                                    <PanelBody
                                                                        title={__(
                                                                            "Gradient",
                                                                            "essential-blocks"
                                                                        )}
                                                                    // initialOpen={false}
                                                                    >
                                                                        <GradientColorControl
                                                                            gradientColor={
                                                                                iconBgGradient
                                                                            }
                                                                            onChange={(
                                                                                iconBgGradient
                                                                            ) =>
                                                                                setAttributes(
                                                                                    {
                                                                                        iconBgGradient,
                                                                                    }
                                                                                )
                                                                            }
                                                                        />
                                                                    </PanelBody>
                                                                )}
                                                        </>
                                                    )}
                                                </>
                                            )}

                                            {media === "image" && !imageUrl && (
                                                <MediaUpload
                                                    onSelect={({ id, url }) =>
                                                        setAttributes({
                                                            imageUrl: url,
                                                            imageId: id,
                                                        })
                                                    }
                                                    type="image"
                                                    value={imageId}
                                                    render={({ open }) => {
                                                        return (
                                                            <Button
                                                                className="eb-background-control-inspector-panel-img-btn components-button"
                                                                label={__(
                                                                    "Upload Image",
                                                                    "essential-blocks"
                                                                )}
                                                                icon="format-image"
                                                                onClick={open}
                                                            />
                                                        );
                                                    }}
                                                />
                                            )}

                                            {media === "image" && imageUrl && (
                                                <>
                                                    <ImageAvatar
                                                        imageUrl={imageUrl}
                                                        onDeleteImage={() =>
                                                            setAttributes({
                                                                imageUrl: null,
                                                            })
                                                        }
                                                    />
                                                    <ResponsiveRangeController
                                                        baseLabel={__(
                                                            "Image Width",
                                                            "essential-blocks"
                                                        )}
                                                        controlName={
                                                            mediaImageWidth
                                                        }
                                                        resRequiredProps={
                                                            resRequiredProps
                                                        }
                                                        units={sizeUnitTypes}
                                                        min={0}
                                                        max={500}
                                                        step={1}
                                                    />
                                                    <ToggleControl
                                                        label={__(
                                                            "Auto Image Height",
                                                            "essential-blocks"
                                                        )}
                                                        checked={
                                                            isMediaImgHeightAuto
                                                        }
                                                        onChange={() =>
                                                            setAttributes({
                                                                isMediaImgHeightAuto: !isMediaImgHeightAuto,
                                                            })
                                                        }
                                                    />

                                                    {!isMediaImgHeightAuto && (
                                                        <>
                                                            <ResponsiveRangeController
                                                                baseLabel={__(
                                                                    "Image Height",
                                                                    "essential-blocks"
                                                                )}
                                                                controlName={
                                                                    mediaImageHeight
                                                                }
                                                                resRequiredProps={
                                                                    resRequiredProps
                                                                }
                                                                units={
                                                                    imgHeightUnits
                                                                }
                                                                min={0}
                                                                max={500}
                                                                step={1}
                                                            />
                                                        </>
                                                    )}
                                                </>
                                            )}

                                            <Divider />

                                            <ResponsiveDimensionsControl
                                                forBorderRadius
                                                resRequiredProps={
                                                    resRequiredProps
                                                }
                                                controlName={mediaBgRadius}
                                                baseLabel="Border Radius"
                                            />

                                            <ResponsiveDimensionsControl
                                                resRequiredProps={
                                                    resRequiredProps
                                                }
                                                controlName={mediaBgMargin}
                                                baseLabel="Margin"
                                            />
                                        </PanelBody>
                                    )}

                                    <PanelBody
                                        title={__(
                                            "Alignments",
                                            "essential-blocks"
                                        )}
                                    >
                                        {media !== "none" && (
                                            <>
                                                {(rootFlexDirection === "row" ||
                                                    rootFlexDirection ===
                                                    "row-reverse") && (
                                                        <>
                                                            <BaseControl
                                                                id="eb-infobox-alignments"
                                                                label="Media Vertical alignments"
                                                            >
                                                                <ButtonGroup id="eb-infobox-alignments">
                                                                    {MEDIA_ALIGNMENTS_ON_FLEX_ROW.map(
                                                                        (
                                                                            {
                                                                                value,
                                                                                label,
                                                                            },
                                                                            index
                                                                        ) => (
                                                                            <Button
                                                                                key={
                                                                                    index
                                                                                }
                                                                                isSecondary={
                                                                                    mediaAlignSelf !==
                                                                                    value
                                                                                }
                                                                                isPrimary={
                                                                                    mediaAlignSelf ===
                                                                                    value
                                                                                }
                                                                                onClick={() =>
                                                                                    setAttributes(
                                                                                        {
                                                                                            mediaAlignSelf: value,
                                                                                        }
                                                                                    )
                                                                                }
                                                                            >
                                                                                {
                                                                                    label
                                                                                }
                                                                            </Button>
                                                                        )
                                                                    )}
                                                                </ButtonGroup>
                                                            </BaseControl>

                                                            <BaseControl
                                                                id="eb-infobox-alignments"
                                                                label="Content Vertical alignments"
                                                            >
                                                                <ButtonGroup id="eb-infobox-alignments">
                                                                    {CONTENTS_ALIGNMENTS_ON_FLEX_ROW.map(
                                                                        (
                                                                            {
                                                                                value,
                                                                                label,
                                                                            },
                                                                            index
                                                                        ) => (
                                                                            <Button
                                                                                key={
                                                                                    index
                                                                                }
                                                                                isSecondary={
                                                                                    contentsAlignSelf !==
                                                                                    value
                                                                                }
                                                                                isPrimary={
                                                                                    contentsAlignSelf ===
                                                                                    value
                                                                                }
                                                                                onClick={() =>
                                                                                    setAttributes(
                                                                                        {
                                                                                            contentsAlignSelf: value,
                                                                                        }
                                                                                    )
                                                                                }
                                                                            >
                                                                                {
                                                                                    label
                                                                                }
                                                                            </Button>
                                                                        )
                                                                    )}
                                                                </ButtonGroup>
                                                            </BaseControl>
                                                        </>
                                                    )}

                                                {(rootFlexDirection ===
                                                    "column" ||
                                                    rootFlexDirection ===
                                                    "column-reverse") && (
                                                        <BaseControl
                                                            id="eb-infobox-alignments"
                                                            label="Media alignments"
                                                        >
                                                            <ButtonGroup id="eb-infobox-alignments">
                                                                {MEDIA_ALIGNMENTS_ON_FLEX_COLUMN.map(
                                                                    (
                                                                        {
                                                                            value,
                                                                            label,
                                                                        },
                                                                        index
                                                                    ) => (
                                                                        <Button
                                                                            key={
                                                                                index
                                                                            }
                                                                            isSecondary={
                                                                                mediaAlignSelf !==
                                                                                value
                                                                            }
                                                                            isPrimary={
                                                                                mediaAlignSelf ===
                                                                                value
                                                                            }
                                                                            onClick={() =>
                                                                                setAttributes(
                                                                                    {
                                                                                        mediaAlignSelf: value,
                                                                                    }
                                                                                )
                                                                            }
                                                                        >
                                                                            {label}
                                                                        </Button>
                                                                    )
                                                                )}
                                                            </ButtonGroup>
                                                        </BaseControl>
                                                    )}
                                            </>
                                        )}

                                        <BaseControl
                                            id="eb-infobox-alignments"
                                            label="Contents alignments"
                                        >
                                            <ButtonGroup id="eb-infobox-alignments">
                                                {CONTENTS_ALIGNMENTS.map(
                                                    (
                                                        { value, label },
                                                        index
                                                    ) => (
                                                        <Button
                                                            key={index}
                                                            isSecondary={
                                                                contentAlignment !==
                                                                value
                                                            }
                                                            isPrimary={
                                                                contentAlignment ===
                                                                value
                                                            }
                                                            onClick={() =>
                                                                setAttributes({
                                                                    contentAlignment: value,
                                                                })
                                                            }
                                                        >
                                                            {label}
                                                        </Button>
                                                    )
                                                )}
                                            </ButtonGroup>
                                        </BaseControl>
                                    </PanelBody>

                                    <PanelBody
                                        title={__("Number", "essential-blocks")}
                                    >
                                        <TypographyDropdown
                                            baseLabel="Typography"
                                            typographyPrefixConstant={
                                                typoPrefix_number
                                            }
                                            resRequiredProps={resRequiredProps}
                                        />

                                        <ColorControl
                                            label={__(
                                                "Color",
                                                "essential-blocks"
                                            )}
                                            color={numberColor}
                                            onChange={(numberColor) =>
                                                setAttributes({ numberColor })
                                            }
                                        />
                                    </PanelBody>

                                    <PanelBody
                                        title={__("Title", "essential-blocks")}
                                    >
                                        <TypographyDropdown
                                            baseLabel="Typography"
                                            typographyPrefixConstant={
                                                typoPrefix_title
                                            }
                                            resRequiredProps={resRequiredProps}
                                        />

                                        <ColorControl
                                            label={__(
                                                "Color",
                                                "essential-blocks"
                                            )}
                                            color={titleColor}
                                            onChange={(titleColor) =>
                                                setAttributes({ titleColor })
                                            }
                                        />
                                    </PanelBody>

                                    <PanelBody
                                        title={__(
                                            "Number prefix",
                                            "essential-blocks"
                                        )}
                                        initialOpen={false}
                                    >
                                        <TypographyDropdown
                                            baseLabel="Typography"
                                            typographyPrefixConstant={
                                                typoPrefix_numPrefix
                                            }
                                            resRequiredProps={resRequiredProps}
                                        />

                                        <ColorControl
                                            label={__(
                                                "Color",
                                                "essential-blocks"
                                            )}
                                            color={numPrefixColor}
                                            onChange={(numPrefixColor) =>
                                                setAttributes({
                                                    numPrefixColor,
                                                })
                                            }
                                        />
                                    </PanelBody>

                                    <PanelBody
                                        title={__(
                                            "Number Suffix",
                                            "essential-blocks"
                                        )}
                                        initialOpen={false}
                                    >
                                        <TypographyDropdown
                                            baseLabel="Typography"
                                            typographyPrefixConstant={
                                                typoPrefix_numSuffix
                                            }
                                            resRequiredProps={resRequiredProps}
                                        />

                                        <ColorControl
                                            label={__(
                                                "Color",
                                                "essential-blocks"
                                            )}
                                            color={numSuffixColor}
                                            onChange={(numSuffixColor) =>
                                                setAttributes({
                                                    numSuffixColor,
                                                })
                                            }
                                        />
                                    </PanelBody>

                                    <PanelBody
                                        title={__(
                                            "Spacing",
                                            "essential-blocks"
                                        )}
                                        initialOpen={false}
                                    >
                                        <ResponsiveRangeController
                                            baseLabel={__(
                                                "Number & Title",
                                                "Number-counter"
                                            )}
                                            controlName={rgNumTitle}
                                            resRequiredProps={resRequiredProps}
                                            max={100}
                                        />
                                        <ResponsiveRangeController
                                            baseLabel={__(
                                                "Number & Prefix",
                                                "Number-counter"
                                            )}
                                            controlName={rgNumPrefix}
                                            resRequiredProps={resRequiredProps}
                                            max={100}
                                        />
                                        <ResponsiveRangeController
                                            baseLabel={__(
                                                "Number & Suffix",
                                                "Number-counter"
                                            )}
                                            controlName={rgNumSuffix}
                                            resRequiredProps={resRequiredProps}
                                            max={100}
                                        />
                                    </PanelBody>
                                </>
                            )}
                            {tab.name === "advance" && (
                                <>
                                    <PanelBody
                                        title={__(
                                            "Margin Padding",
                                            "essential-blocks"
                                        )}
                                    >
                                        <ResponsiveDimensionsControl
                                            resRequiredProps={resRequiredProps}
                                            controlName={wrapperMargin}
                                            baseLabel="Margin"
                                        />
                                        <ResponsiveDimensionsControl
                                            resRequiredProps={resRequiredProps}
                                            controlName={wrapperPadding}
                                            baseLabel="Padding"
                                        />
                                    </PanelBody>

                                    <PanelBody
                                        title={__(
                                            "Background",
                                            "essential-blocks"
                                        )}
                                        initialOpen={false}
                                    >
                                        <BackgroundControl
                                            controlName={WrapBg}
                                            resRequiredProps={resRequiredProps}
                                        />
                                    </PanelBody>

                                    <PanelBody
                                        title={__("Border & Shadow")}
                                        initialOpen={false}
                                    >
                                        <BorderShadowControl
                                            controlName={wrpBdShadow}
                                            resRequiredProps={resRequiredProps}
                                        />
                                    </PanelBody>

                                    <AdvancedControls
                                        attributes={attributes}
                                        setAttributes={setAttributes}
                                    />
                                </>
                            )}
                        </div>
                    )}
                </TabPanel>
            </div>
        </InspectorControls>
    );
};
export default Inspector;