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/pricing-table/src/edit.js
/**
 * WordPress dependencies
 */
import { __ } from "@wordpress/i18n";
import { useEffect, memo } from "@wordpress/element";
import {
    BlockControls,
    AlignmentToolbar,
} from "@wordpress/block-editor";

/**
 * Internal dependencies
 */
import Inspector from "./inspector";
import Style from "./style";
import { PricingTableIcon } from "./icon";
import { Templates } from './templates/templates'
import defaultAttributes from "./attributes"
import {
    DynamicInputValueHandler,
    EBDisplayIcon,
    sanitizeURL,
    BlockProps,
    BrowseTemplate,
    withBlockContext
} from "@essential-blocks/controls";

const Edit = (props) => {
    const {
        attributes,
        isSelected,
        setAttributes
    } = props;
    const {
        blockId,
        blockMeta,
        // responsive control attribute ⬇
        resOption,
        pricingStyle,
        title,
        showSubtitle,
        subtitle,
        showHeaderIcon,
        headerIcon,
        mainPrice,
        showOnSale,
        salePrice,
        priceCurrency,
        currencyPlacement,
        pricePeriod,
        periodSeparator,
        hideFeatures,
        features,
        showButton,
        buttonIcon,
        buttonIconPosition,
        buttonText,
        buttonURL,
        contentAlign,
        ribbonStyle,
        classHook,
        ribbonAlignHorizontal,
        ribbonAlignVertical,
        showFeatureLine,
        showRibbon,
        showBlockContent,
        showFeatureIcon,
        titleTagName
    } = attributes;

    // you must declare this variable
    const enhancedProps = {
        ...props,
        blockPrefix: 'eb-pricing',
        style: <Style {...props} />
    };

    useEffect(() => {
        if (features.length > 0) return;

        const defaultFeatures = [
            {
                icon: "fas fa-check",
                text: "Unlimited Calls",
                color: "var(--eb-global-primary-color)",
                clickable: "false",
                link: "",
            },
            {
                icon: "fas fa-check",
                text: "Free Hosting",
                color: "var(--eb-global-primary-color)",
                clickable: "false",
                link: "",
            },
            {
                icon: "fas fa-check",
                text: "500MB Free Storage",
                color: "var(--eb-global-primary-color)",
                clickable: "false",
                link: "",
            },
            {
                icon: "fas fa-check",
                text: "24/7 Support",
                color: "var(--eb-global-primary-color)",
                clickable: "false",
                link: "",
            },
        ];

        setAttributes({ features: defaultFeatures });
    }, []);

    // ribbon Class
    const ribbonClass = showRibbon ? ` featured ${ribbonStyle}` : "";

    const TitleTagName = titleTagName;

    return (
        <>
            <BlockControls>
                <AlignmentToolbar
                    value={contentAlign}
                    onChange={(contentAlign) => setAttributes({ contentAlign: contentAlign || "center" })}
                />
            </BlockControls>
            {isSelected && showBlockContent && <Inspector attributes={attributes} setAttributes={setAttributes} />}
            <BlockProps.Edit {...enhancedProps}>

                <BrowseTemplate
                    {...props}
                    Icon={PricingTableIcon}
                    title={"Pricing Table"}
                    description={"Choose a template for the Pricing Table or start blank."}
                    patterns={Templates}
                />

                {showBlockContent && (
                    <>
                        <div
                            className={`eb-parent-wrapper eb-parent-${blockId} ${classHook}`}
                        >
                            <div
                                className={`${blockId} eb-pricing-wrapper eb-pricing-content-${contentAlign}`}
                            >
                                <div className={`eb-pricing ${pricingStyle} `}>
                                    <div
                                        className={`eb-pricing-item${ribbonClass} ${ribbonStyle !== "ribbon-1"
                                            ? ribbonAlignHorizontal
                                            : ribbonAlignVertical
                                            }`}
                                    >
                                        <div className="eb-pricing-item-overlay"></div>

                                        {pricingStyle == "style-4" && (
                                            <>
                                                <div className="eb-pricing-top">
                                                    {showHeaderIcon && (
                                                        <div
                                                            className="eb-pricing-icon"
                                                            data-icon={headerIcon}
                                                        >
                                                            <EBDisplayIcon className={`icon`} icon={headerIcon} />
                                                        </div>
                                                    )}
                                                    <div className="eb-pricing-tag">
                                                        <span className="price-tag">
                                                            <span
                                                                className={`original-price${showOnSale === true
                                                                    ? " line-through"
                                                                    : ""
                                                                    }`}
                                                                data-price={mainPrice}
                                                            >
                                                                {currencyPlacement ===
                                                                    "left" && (
                                                                        <span className="price-currency">
                                                                            {priceCurrency}
                                                                        </span>
                                                                    )}
                                                                {mainPrice}
                                                                {currencyPlacement ===
                                                                    "right" && (
                                                                        <span className="price-currency">
                                                                            {priceCurrency}
                                                                        </span>
                                                                    )}
                                                            </span>

                                                            {showOnSale && (
                                                                <>
                                                                    <span
                                                                        className="sale-price"
                                                                        data-sale-price={
                                                                            salePrice
                                                                        }
                                                                    >
                                                                        {currencyPlacement ===
                                                                            "left" && (
                                                                                <span className="price-currency">
                                                                                    {
                                                                                        priceCurrency
                                                                                    }
                                                                                </span>
                                                                            )}
                                                                        {salePrice}
                                                                        {currencyPlacement ===
                                                                            "right" && (
                                                                                <span className="price-currency">
                                                                                    {
                                                                                        priceCurrency
                                                                                    }
                                                                                </span>
                                                                            )}
                                                                    </span>
                                                                </>
                                                            )}
                                                        </span>
                                                        <span
                                                            className="price-period"
                                                            data-period-separator={
                                                                periodSeparator
                                                            }
                                                            data-price-period={
                                                                pricePeriod
                                                            }
                                                        >
                                                            {periodSeparator}{" "}
                                                            {pricePeriod}
                                                        </span>
                                                    </div>
                                                    <div className="eb-pricing-header">
                                                        <TitleTagName className="eb-pricing-title">
                                                            {title}
                                                        </TitleTagName>
                                                        {showSubtitle && (
                                                            <span className="eb-pricing-subtitle">
                                                                {subtitle}
                                                            </span>
                                                        )}
                                                    </div>
                                                </div>

                                                <div className="eb-pricing-bottom">
                                                    {hideFeatures !== true && (
                                                        <div className="eb-pricing-body">
                                                            <ul
                                                                className={`eb-pricebox-features ${showFeatureLine
                                                                    ? ""
                                                                    : "no-border"
                                                                    }`}
                                                            >
                                                                {features.map(
                                                                    (
                                                                        {
                                                                            icon,
                                                                            text,
                                                                            color,
                                                                            clickable,
                                                                            link,
                                                                        },
                                                                        index
                                                                    ) => (
                                                                        <li
                                                                            key={index}
                                                                            className="eb-pricebox-feature-item"
                                                                            data-icon={
                                                                                icon
                                                                            }
                                                                            data-color={
                                                                                color
                                                                            }
                                                                            data-clickable={
                                                                                clickable
                                                                            }
                                                                            data-link={
                                                                                link
                                                                            }
                                                                        >
                                                                            {clickable &&
                                                                                link ? (
                                                                                <a
                                                                                    href={
                                                                                        sanitizeURL(link)
                                                                                    }
                                                                                >
                                                                                    {showFeatureIcon && (
                                                                                        <EBDisplayIcon
                                                                                            className={`eb-pricebox-icon`}
                                                                                            icon={icon}
                                                                                        />
                                                                                    )}
                                                                                    <span className="eb-pricebox-feature-text">
                                                                                        {
                                                                                            text
                                                                                        }
                                                                                    </span>
                                                                                </a>
                                                                            ) : (
                                                                                <>
                                                                                    {showFeatureIcon && (
                                                                                        <EBDisplayIcon
                                                                                            className={`eb-pricebox-icon`}
                                                                                            icon={icon}
                                                                                        />
                                                                                    )}
                                                                                    <span className="eb-pricebox-feature-text">
                                                                                        {
                                                                                            text
                                                                                        }
                                                                                    </span>
                                                                                </>
                                                                            )}
                                                                        </li>
                                                                    )
                                                                )}
                                                            </ul>
                                                        </div>
                                                    )}

                                                    {showButton && (
                                                        <div
                                                            className="eb-pricing-footer"
                                                            data-icon={buttonIcon}
                                                        >
                                                            <div className="eb-pricing-button-wrapper">
                                                                <a
                                                                    href={sanitizeURL(buttonURL)}
                                                                    className="eb-pricing-button"
                                                                >
                                                                    {buttonIconPosition ===
                                                                        "left" && (
                                                                            <EBDisplayIcon icon={buttonIcon} />
                                                                        )}
                                                                    <DynamicInputValueHandler
                                                                        value={
                                                                            buttonText
                                                                        }
                                                                        tagName="span"
                                                                        className="eb-button-text"
                                                                        onChange={(
                                                                            buttonText
                                                                        ) =>
                                                                            setAttributes(
                                                                                {
                                                                                    buttonText,
                                                                                }
                                                                            )
                                                                        }
                                                                        readOnly={true}
                                                                    />
                                                                    {buttonIconPosition ===
                                                                        "right" && (
                                                                            <EBDisplayIcon icon={buttonIcon} />
                                                                        )}
                                                                </a>
                                                            </div>
                                                        </div>
                                                    )}
                                                </div>
                                            </>
                                        )}

                                        {
                                            pricingStyle !== "style-4" && (
                                                <>
                                                    {showHeaderIcon && (
                                                        <div
                                                            className="eb-pricing-icon"
                                                            data-icon={headerIcon}
                                                        >
                                                            <EBDisplayIcon className={`icon`} icon={headerIcon} />
                                                        </div>
                                                    )}
                                                    <div className="eb-pricing-header">
                                                        <TitleTagName className="eb-pricing-title">
                                                            {title}
                                                        </TitleTagName>
                                                        {showSubtitle && (
                                                            <span className="eb-pricing-subtitle">
                                                                {subtitle}
                                                            </span>
                                                        )}
                                                    </div>
                                                    {pricingStyle !== "style-3" && (
                                                        <div className="eb-pricing-tag">
                                                            <span className="price-tag">
                                                                <span
                                                                    className={`original-price${showOnSale === true
                                                                        ? " line-through"
                                                                        : ""
                                                                        }`}
                                                                    data-price={mainPrice}
                                                                >
                                                                    {currencyPlacement ===
                                                                        "left" && (
                                                                            <span className="price-currency">
                                                                                {priceCurrency}
                                                                            </span>
                                                                        )}
                                                                    {mainPrice}
                                                                    {currencyPlacement ===
                                                                        "right" && (
                                                                            <span className="price-currency">
                                                                                {priceCurrency}
                                                                            </span>
                                                                        )}
                                                                </span>

                                                                {showOnSale && (
                                                                    <>
                                                                        <span
                                                                            className="sale-price"
                                                                            data-sale-price={
                                                                                salePrice
                                                                            }
                                                                        >
                                                                            {currencyPlacement ===
                                                                                "left" && (
                                                                                    <span className="price-currency">
                                                                                        {
                                                                                            priceCurrency
                                                                                        }
                                                                                    </span>
                                                                                )}
                                                                            {salePrice}
                                                                            {currencyPlacement ===
                                                                                "right" && (
                                                                                    <span className="price-currency">
                                                                                        {
                                                                                            priceCurrency
                                                                                        }
                                                                                    </span>
                                                                                )}
                                                                        </span>
                                                                    </>
                                                                )}
                                                            </span>
                                                            <span
                                                                className="price-period"
                                                                data-period-separator={
                                                                    periodSeparator
                                                                }
                                                                data-price-period={
                                                                    pricePeriod
                                                                }
                                                            >
                                                                {periodSeparator}{" "}
                                                                {pricePeriod}
                                                            </span>
                                                        </div>
                                                    )
                                                    }

                                                    {
                                                        hideFeatures !== true && (
                                                            <div className="eb-pricing-body">
                                                                <ul
                                                                    className={`eb-pricebox-features ${showFeatureLine
                                                                        ? ""
                                                                        : "no-border"
                                                                        }`}
                                                                >
                                                                    {features.map(
                                                                        (
                                                                            {
                                                                                icon,
                                                                                text,
                                                                                color,
                                                                                clickable,
                                                                                link,
                                                                            },
                                                                            index
                                                                        ) => (
                                                                            <li
                                                                                key={index}
                                                                                className="eb-pricebox-feature-item"
                                                                                data-icon={icon}
                                                                                data-color={
                                                                                    color
                                                                                }
                                                                                data-clickable={
                                                                                    clickable
                                                                                }
                                                                                data-link={link}
                                                                            >
                                                                                {clickable &&
                                                                                    link ? (
                                                                                    <a
                                                                                        href={sanitizeURL(link)}
                                                                                    >
                                                                                        {showFeatureIcon && (
                                                                                            <EBDisplayIcon
                                                                                                className={`eb-pricebox-icon`}
                                                                                                icon={icon}
                                                                                                style={{ color: color }}
                                                                                            />
                                                                                        )}

                                                                                        <span className="eb-pricebox-feature-text">
                                                                                            {
                                                                                                text
                                                                                            }
                                                                                        </span>
                                                                                    </a>
                                                                                ) : (
                                                                                    <>
                                                                                        {showFeatureIcon && (
                                                                                            <EBDisplayIcon
                                                                                                className={`eb-pricebox-icon`}
                                                                                                icon={icon}
                                                                                                style={{ color: color }}
                                                                                            />
                                                                                        )}

                                                                                        <span className="eb-pricebox-feature-text">
                                                                                            {
                                                                                                text
                                                                                            }
                                                                                        </span>
                                                                                    </>
                                                                                )}
                                                                            </li>
                                                                        )
                                                                    )}
                                                                </ul>
                                                            </div>
                                                        )
                                                    }

                                                    {
                                                        pricingStyle === "style-3" && (
                                                            <div className="eb-pricing-tag">
                                                                <span className="price-tag">
                                                                    <span
                                                                        className={`original-price${showOnSale === true
                                                                            ? " line-through"
                                                                            : ""
                                                                            }`}
                                                                        data-price={mainPrice}
                                                                    >
                                                                        {currencyPlacement ===
                                                                            "left" && (
                                                                                <span className="price-currency">
                                                                                    {priceCurrency}
                                                                                </span>
                                                                            )}
                                                                        {mainPrice}
                                                                        {currencyPlacement ===
                                                                            "right" && (
                                                                                <span className="price-currency">
                                                                                    {priceCurrency}
                                                                                </span>
                                                                            )}
                                                                    </span>

                                                                    {showOnSale && (
                                                                        <>
                                                                            <span
                                                                                className="sale-price"
                                                                                data-sale-price={
                                                                                    salePrice
                                                                                }
                                                                            >
                                                                                {currencyPlacement ===
                                                                                    "left" && (
                                                                                        <span className="price-currency">
                                                                                            {
                                                                                                priceCurrency
                                                                                            }
                                                                                        </span>
                                                                                    )}
                                                                                {salePrice}
                                                                                {currencyPlacement ===
                                                                                    "right" && (
                                                                                        <span className="price-currency">
                                                                                            {
                                                                                                priceCurrency
                                                                                            }
                                                                                        </span>
                                                                                    )}
                                                                            </span>
                                                                        </>
                                                                    )}
                                                                </span>
                                                                <span
                                                                    className="price-period"
                                                                    data-period-separator={
                                                                        periodSeparator
                                                                    }
                                                                    data-price-period={
                                                                        pricePeriod
                                                                    }
                                                                >
                                                                    {periodSeparator}{" "}
                                                                    {pricePeriod}
                                                                </span>
                                                            </div>
                                                        )}
                                                    {showButton && (
                                                        <div
                                                            className="eb-pricing-footer"
                                                            data-icon={buttonIcon}
                                                        >
                                                            <div className="eb-pricing-button-wrapper">
                                                                <a
                                                                    href={sanitizeURL(buttonURL)}
                                                                    className="eb-pricing-button"
                                                                >
                                                                    {buttonIconPosition ===
                                                                        "left" && (
                                                                            <EBDisplayIcon icon={buttonIcon} />
                                                                        )}
                                                                    <DynamicInputValueHandler
                                                                        value={buttonText}
                                                                        tagName="span"
                                                                        className="eb-button-text"
                                                                        onChange={(
                                                                            buttonText
                                                                        ) =>
                                                                            setAttributes({
                                                                                buttonText,
                                                                            })
                                                                        }
                                                                        readOnly={true}
                                                                    />
                                                                    {buttonIconPosition ===
                                                                        "right" && (
                                                                            <EBDisplayIcon icon={buttonIcon} />
                                                                        )}
                                                                </a>
                                                            </div>
                                                        </div>
                                                    )}
                                                </>
                                            )
                                        }
                                    </div >
                                </div >
                            </div >
                        </div >
                    </>
                )}
            </BlockProps.Edit >
        </>
    );
};

export default memo(withBlockContext(defaultAttributes)(Edit))