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/pricing-table/src/deprecated.js
/**
 * WordPress dependencies
 */
import { useBlockProps } from "@wordpress/block-editor";
const { EBDisplayIcon, sanitizeURL } = window.EBControls;
import attributes from "./attributes";
const { omit } = lodash;

const deprecated = [
    {
        attributes: {
            ...omit({ ...attributes }, ['showFeatureIcon'])
        },
        supports: {
            align: ["wide", "full"],
        },
        save: ({ attributes }) => {
            const {
                blockId,
                pricingStyle,
                title,
                showSubtitle,
                subtitle,
                showHeaderIcon,
                headerIcon,
                mainPrice,
                showOnSale,
                salePrice,
                priceCurrency,
                currencyPlacement,
                pricePeriod,
                periodSeparator,
                hideFeatures,
                features,
                showButton,
                buttonIcon,
                buttonIconPosition,
                buttonText,
                buttonURL,
                contentAlign,
                showRibbon,
                ribbonStyle,
                classHook,
                ribbonAlignHorizontal = "right",
                ribbonAlignVertical = "top",
                newWindow,
                showFeatureLine = true,
                showBlockContent
            } = attributes;

            if (!showBlockContent) {
                return
            }

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

            return (
                <div {...useBlockProps.save()}>
                    <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}${showRibbon
                                        ? 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">
                                                    <h2 className="eb-pricing-title">{title}</h2>
                                                    {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={link}>
                                                                                    <EBDisplayIcon
                                                                                        className={`eb-pricebox-icon`}
                                                                                        icon={icon}
                                                                                        style={{ color: color }}
                                                                                    />
                                                                                    <span className="eb-pricebox-feature-text">
                                                                                        {text}
                                                                                    </span>
                                                                                </a>
                                                                            ) : (
                                                                                <>
                                                                                    <EBDisplayIcon
                                                                                        className={`eb-pricebox-icon`}
                                                                                        icon={icon}
                                                                                        style={{ color: color }}
                                                                                    />
                                                                                    <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={buttonURL == '#' ? '' : buttonURL}
                                                                {...(newWindow && { target: "_blank" })}
                                                                className="eb-pricing-button"
                                                            >
                                                                {buttonIconPosition === "left" && (
                                                                    <EBDisplayIcon icon={buttonIcon} />
                                                                )}
                                                                <span className="eb-button-text">{buttonText}</span>
                                                                {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">
                                                <h2 className="eb-pricing-title">{title}</h2>
                                                {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={link}>
                                                                            <EBDisplayIcon
                                                                                className={`eb-pricebox-icon`}
                                                                                icon={icon}
                                                                                style={{ color: color }}
                                                                            />
                                                                            <span className="eb-pricebox-feature-text">
                                                                                {text}
                                                                            </span>
                                                                        </a>
                                                                    ) : (
                                                                        <>
                                                                            <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={buttonURL == '#' ? '' : buttonURL}
                                                            {...(newWindow && { target: "_blank" })}
                                                            className="eb-pricing-button"
                                                        >
                                                            {buttonIconPosition === "left" && (
                                                                <EBDisplayIcon icon={buttonIcon} />
                                                            )}
                                                            <span className="eb-button-text">{buttonText}</span>
                                                            {buttonIconPosition === "right" && (
                                                                <EBDisplayIcon icon={buttonIcon} />
                                                            )}
                                                        </a>
                                                    </div>
                                                </div>
                                            )}
                                        </>
                                    )}
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
                // edit view end
            );
        },
    },
    {
        attributes: { ...attributes },
        supports: {
            align: ["wide", "full"],
        },
        save: ({ attributes }) => {
            const {
                blockId,
                pricingStyle,
                title,
                showSubtitle,
                subtitle,
                showHeaderIcon,
                headerIcon,
                mainPrice,
                showOnSale,
                salePrice,
                priceCurrency,
                currencyPlacement,
                pricePeriod,
                periodSeparator,
                hideFeatures,
                features,
                showButton,
                buttonIcon,
                buttonIconPosition,
                buttonText,
                buttonURL,
                contentAlign,
                showRibbon,
                ribbonStyle,
                classHook,
                ribbonAlignHorizontal = "right",
                ribbonAlignVertical = "top",
                newWindow,
                showFeatureLine = true,
                showBlockContent
            } = attributes;

            if (!showBlockContent) {
                return
            }

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

            return (
                <div {...useBlockProps.save()}>
                    <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}${showRibbon
                                        ? 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">
                                                    <h2 className="eb-pricing-title">{title}</h2>
                                                    {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={link}>
                                                                                    <EBDisplayIcon
                                                                                        className={`eb-pricebox-icon`}
                                                                                        icon={icon}
                                                                                        style={{ color: color }}
                                                                                    />
                                                                                    <span className="eb-pricebox-feature-text">
                                                                                        {text}
                                                                                    </span>
                                                                                </a>
                                                                            ) : (
                                                                                <>
                                                                                    <EBDisplayIcon
                                                                                        className={`eb-pricebox-icon`}
                                                                                        icon={icon}
                                                                                        style={{ color: color }}
                                                                                    />
                                                                                    <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={buttonURL == '#' ? '' : buttonURL}
                                                                {...(newWindow && { target: "_blank" })}
                                                                className="eb-pricing-button"
                                                            >
                                                                {buttonIconPosition === "left" && (
                                                                    <EBDisplayIcon icon={buttonIcon} />
                                                                )}
                                                                <span className="eb-button-text">{buttonText}</span>
                                                                {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">
                                                <h2 className="eb-pricing-title">{title}</h2>
                                                {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={link}>
                                                                            <EBDisplayIcon
                                                                                className={`eb-pricebox-icon`}
                                                                                icon={icon}
                                                                                style={{ color: color }}
                                                                            />
                                                                            <span className="eb-pricebox-feature-text">
                                                                                {text}
                                                                            </span>
                                                                        </a>
                                                                    ) : (
                                                                        <>
                                                                            <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={buttonURL == '#' ? '' : buttonURL}
                                                            {...(newWindow && { target: "_blank" })}
                                                            className="eb-pricing-button"
                                                        >
                                                            {buttonIconPosition === "left" && (
                                                                <EBDisplayIcon icon={buttonIcon} />
                                                            )}
                                                            <span className="eb-button-text">{buttonText}</span>
                                                            {buttonIconPosition === "right" && (
                                                                <EBDisplayIcon icon={buttonIcon} />
                                                            )}
                                                        </a>
                                                    </div>
                                                </div>
                                            )}
                                        </>
                                    )}
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
                // edit view end
            );
        },
    },
    {
        attributes: { ...attributes },
        supports: {
            align: ["wide", "full"],
        },
        save: ({ attributes }) => {
            const {
                blockId,
                pricingStyle,
                title,
                showSubtitle,
                subtitle,
                showHeaderIcon,
                headerIcon,
                mainPrice,
                showOnSale,
                salePrice,
                priceCurrency,
                currencyPlacement,
                pricePeriod,
                periodSeparator,
                hideFeatures,
                features,
                showButton,
                buttonIcon,
                buttonIconPosition,
                buttonText,
                buttonURL,
                contentAlign,
                showRibbon,
                ribbonStyle,
                classHook,
                ribbonAlignHorizontal = "right",
                ribbonAlignVertical = "top",
                newWindow,
                showFeatureLine = true,
            } = attributes;

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

            return (
                <div {...useBlockProps.save()}>
                    <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}${showRibbon
                                        ? 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">
                                                    <h2 className="eb-pricing-title">{title}</h2>
                                                    {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)}>
                                                                                    <EBDisplayIcon
                                                                                        className={`eb-pricebox-icon`}
                                                                                        icon={icon}
                                                                                        style={{ color: color }}
                                                                                    />
                                                                                    <span className="eb-pricebox-feature-text">
                                                                                        {text}
                                                                                    </span>
                                                                                </a>
                                                                            ) : (
                                                                                <>
                                                                                    <EBDisplayIcon
                                                                                        className={`eb-pricebox-icon`}
                                                                                        icon={icon}
                                                                                        style={{ color: color }}
                                                                                    />
                                                                                    <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)}
                                                                {...(newWindow && { target: "_blank" })}
                                                                className="eb-pricing-button"
                                                            >
                                                                {buttonIconPosition === "left" && (
                                                                    <EBDisplayIcon icon={buttonIcon} />
                                                                )}
                                                                <span className="eb-button-text">{buttonText}</span>
                                                                {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">
                                                <h2 className="eb-pricing-title">{title}</h2>
                                                {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)}>
                                                                            <EBDisplayIcon
                                                                                className={`eb-pricebox-icon`}
                                                                                icon={icon}
                                                                                style={{ color: color }}
                                                                            />
                                                                            <span className="eb-pricebox-feature-text">
                                                                                {text}
                                                                            </span>
                                                                        </a>
                                                                    ) : (
                                                                        <>
                                                                            <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)}
                                                            {...(newWindow && { target: "_blank" })}
                                                            className="eb-pricing-button"
                                                        >
                                                            {buttonIconPosition === "left" && (
                                                                <EBDisplayIcon icon={buttonIcon} />
                                                            )}
                                                            <span className="eb-button-text">{buttonText}</span>
                                                            {buttonIconPosition === "right" && (
                                                                <EBDisplayIcon icon={buttonIcon} />
                                                            )}
                                                        </a>
                                                    </div>
                                                </div>
                                            )}
                                        </>
                                    )}
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
                // edit view end
            );
        },
    },
    {
        attributes: { ...attributes },
        supports: {
            align: ["wide", "full"],
        },
        // migrate({ buttonURL }) {
        //     return {
        //         buttonURL: buttonURL == '#' ? '' : buttonURL
        //     }
        // },
        save: ({ attributes }) => {
            const {
                blockId,
                pricingStyle,
                title,
                showSubtitle,
                subtitle,
                showHeaderIcon,
                headerIcon,
                mainPrice,
                showOnSale,
                salePrice,
                priceCurrency,
                currencyPlacement,
                pricePeriod,
                periodSeparator,
                hideFeatures,
                features,
                showButton,
                buttonIcon,
                buttonIconPosition,
                buttonText,
                buttonURL,
                contentAlign,
                showRibbon,
                ribbonStyle,
                classHook,
                ribbonAlignHorizontal = "right",
                ribbonAlignVertical = "top",
                newWindow,
                showFeatureLine = true,
            } = attributes;

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

            return (
                <div {...useBlockProps.save()}>
                    <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}${showRibbon
                                        ? 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">
                                                    <h2 className="eb-pricing-title">{title}</h2>
                                                    {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)}>
                                                                                    <EBDisplayIcon
                                                                                        className={`eb-pricebox-icon`}
                                                                                        icon={icon}
                                                                                    />
                                                                                    <span className="eb-pricebox-feature-text">
                                                                                        {text}
                                                                                    </span>
                                                                                </a>
                                                                            ) : (
                                                                                <>
                                                                                    <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)}
                                                                {...(newWindow && { target: "_blank" })}
                                                                className="eb-pricing-button"
                                                            >
                                                                {buttonIconPosition === "left" && (
                                                                    <EBDisplayIcon icon={buttonIcon} />
                                                                )}
                                                                <span className="eb-button-text">{buttonText}</span>
                                                                {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">
                                                <h2 className="eb-pricing-title">{title}</h2>
                                                {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)}>
                                                                            <EBDisplayIcon
                                                                                className={`eb-pricebox-icon`}
                                                                                icon={icon}
                                                                            />
                                                                            <span className="eb-pricebox-feature-text">
                                                                                {text}
                                                                            </span>
                                                                        </a>
                                                                    ) : (
                                                                        <>
                                                                            <EBDisplayIcon
                                                                                className={`eb-pricebox-icon`}
                                                                                icon={icon}
                                                                            />
                                                                            <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)}
                                                            {...(newWindow && { target: "_blank" })}
                                                            className="eb-pricing-button"
                                                        >
                                                            {buttonIconPosition === "left" && (
                                                                <EBDisplayIcon icon={buttonIcon} />
                                                            )}
                                                            <span className="eb-button-text">{buttonText}</span>
                                                            {buttonIconPosition === "right" && (
                                                                <EBDisplayIcon icon={buttonIcon} />
                                                            )}
                                                        </a>
                                                    </div>
                                                </div>
                                            )}
                                        </>
                                    )}
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
                // edit view end
            );
        },
    },
    {
        attributes: { ...attributes },
        supports: {
            align: ["wide", "full"],
        },
        save: ({ attributes }) => {
            const {
                blockId,
                pricingStyle,
                title,
                showSubtitle,
                subtitle,
                showHeaderIcon,
                headerIcon,
                mainPrice,
                showOnSale,
                salePrice,
                priceCurrency,
                currencyPlacement,
                pricePeriod,
                periodSeparator,
                hideFeatures,
                features,
                showButton,
                buttonIcon,
                buttonIconPosition,
                buttonText,
                buttonURL,
                contentAlign,
                showRibbon,
                ribbonStyle,
                classHook,
                ribbonAlignHorizontal = "right",
                ribbonAlignVertical = "top",
                newWindow,
                showFeatureLine = true,
            } = attributes;

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

            return (
                <div {...useBlockProps.save()}>
                    <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}${showRibbon
                                        ? 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}>
                                                        <span className="icon">
                                                            <i className={headerIcon}></i>
                                                        </span>
                                                    </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">
                                                    <h2 className="eb-pricing-title">{title}</h2>
                                                    {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)}>
                                                                                    <span
                                                                                        className={`eb-pricebox-icon ${icon}`}
                                                                                        style={{ color: color }}
                                                                                    />
                                                                                    <span className="eb-pricebox-feature-text">
                                                                                        {text}
                                                                                    </span>
                                                                                </a>
                                                                            ) : (
                                                                                <>
                                                                                    <span
                                                                                        className={`eb-pricebox-icon ${icon}`}
                                                                                        style={{ color: color }}
                                                                                    />
                                                                                    <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)}
                                                                {...(newWindow && { target: "_blank" })}
                                                                className="eb-pricing-button"
                                                            >
                                                                {buttonIconPosition === "left" && (
                                                                    <i className={buttonIcon}></i>
                                                                )}
                                                                <span className="eb-button-text">{buttonText}</span>
                                                                {buttonIconPosition === "right" && (
                                                                    <i className={buttonIcon}></i>
                                                                )}
                                                            </a>
                                                        </div>
                                                    </div>
                                                )}
                                            </div>
                                        </>
                                    )}

                                    {pricingStyle !== "style-4" && (
                                        <>
                                            {showHeaderIcon && (
                                                <div className="eb-pricing-icon" data-icon={headerIcon}>
                                                    <span className="icon">
                                                        <i className={headerIcon}></i>
                                                    </span>
                                                </div>
                                            )}
                                            <div className="eb-pricing-header">
                                                <h2 className="eb-pricing-title">{title}</h2>
                                                {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)}>
                                                                                <span
                                                                                    className={`eb-pricebox-icon ${icon}`}
                                                                                    style={{ color: color }}
                                                                                />
                                                                                <span className="eb-pricebox-feature-text">
                                                                                    {text}
                                                                                </span>
                                                                            </a>
                                                                        ) : (
                                                                            <>
                                                                                <span
                                                                                    className={`eb-pricebox-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)}
                                                            {...(newWindow && { target: "_blank" })}
                                                            className="eb-pricing-button"
                                                        >
                                                            {buttonIconPosition === "left" && (
                                                                <i className={buttonIcon}></i>
                                                            )}
                                                            <span className="eb-button-text">{buttonText}</span>
                                                            {buttonIconPosition === "right" && (
                                                                <i className={buttonIcon}></i>
                                                            )}
                                                        </a>
                                                    </div>
                                                </div>
                                            )}
                                        </>
                                    )}
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
                // edit view end
            );
        },
    },
    {
        attributes: { ...attributes },
        supports: {
            align: ["wide", "full"],
        },
        save: ({ attributes }) => {
            const {
                blockId,
                pricingStyle,
                title,
                showSubtitle,
                subtitle,
                showHeaderIcon,
                headerIcon,
                mainPrice,
                showOnSale,
                salePrice,
                priceCurrency,
                currencyPlacement,
                pricePeriod,
                periodSeparator,
                hideFeatures,
                features,
                showButton,
                buttonIcon,
                buttonIconPosition,
                buttonText,
                buttonURL,
                contentAlign,
                showRibbon,
                ribbonStyle,
                classHook,
            } = attributes;

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

            return (
                <div {...useBlockProps.save()}>
                    <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}`}>
                                    <div className="eb-pricing-item-overlay"></div>
                                    {showHeaderIcon && (
                                        <div className="eb-pricing-icon" data-icon={headerIcon}>
                                            <span className="icon">
                                                <i className={headerIcon}></i>
                                            </span>
                                        </div>
                                    )}
                                    <div className="eb-pricing-header">
                                        <h2 className="eb-pricing-title">{title}</h2>
                                        {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">
                                                    {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)}>
                                                                        <span
                                                                            className={`eb-pricebox-icon ${icon}`}
                                                                            style={{ color: color }}
                                                                        />
                                                                        <span className="eb-pricebox-feature-text">
                                                                            {text}
                                                                        </span>
                                                                    </a>
                                                                ) : (
                                                                    <>
                                                                        <span
                                                                            className={`eb-pricebox-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" && (
                                                        <i className={buttonIcon}></i>
                                                    )}
                                                    <span className="eb-button-text">{buttonText}</span>
                                                    {buttonIconPosition === "right" && (
                                                        <i className={buttonIcon}></i>
                                                    )}
                                                </a>
                                            </div>
                                        </div>
                                    )}
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
                // edit view end
            );
        },
    },
    {
        attributes: {
            ...attributes,
        },
        supports: {
            align: ["wide", "full"],
        },
        save: ({ attributes }) => {
            const {
                blockId,
                pricingStyle,
                title,
                showSubtitle,
                subtitle,
                showHeaderIcon,
                headerIcon,
                mainPrice,
                showOnSale,
                salePrice,
                priceCurrency,
                currencyPlacement,
                pricePeriod,
                periodSeparator,
                hideFeatures,
                features,
                showButton,
                buttonIcon,
                buttonIconPosition,
                buttonText,
                buttonURL,
                contentAlign,
                showRibbon,
                ribbonStyle,
            } = attributes;

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

            return (
                <div {...useBlockProps.save()}>
                    <div
                        className={`${blockId} eb-pricing-wrapper eb-pricing-content-${contentAlign}`}
                    >
                        <div className={`eb-pricing ${pricingStyle}`}>
                            <div className={`eb-pricing-item${ribbonClass}`}>
                                <div className="eb-pricing-item-overlay"></div>
                                {showHeaderIcon && (
                                    <div className="eb-pricing-icon" data-icon={headerIcon}>
                                        <span className="icon">
                                            <i className={headerIcon}></i>
                                        </span>
                                    </div>
                                )}
                                <div className="eb-pricing-header">
                                    <h2 className="eb-pricing-title">{title}</h2>
                                    {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">
                                                {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)}>
                                                                    <span
                                                                        className={`eb-pricebox-icon ${icon}`}
                                                                        style={{ color: color }}
                                                                    />
                                                                    <span className="eb-pricebox-feature-text">
                                                                        {text}
                                                                    </span>
                                                                </a>
                                                            ) : (
                                                                <>
                                                                    <span
                                                                        className={`eb-pricebox-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" && (
                                                    <i className={buttonIcon}></i>
                                                )}
                                                <span className="eb-button-text">{buttonText}</span>
                                                {buttonIconPosition === "right" && (
                                                    <i className={buttonIcon}></i>
                                                )}
                                            </a>
                                        </div>
                                    </div>
                                )}
                            </div>
                        </div>
                    </div>
                </div>
                // edit view end
            );
        },
    },
    {
        attributes: {
            ...attributes,
            hideFeatures: {
                type: "boolean",
                default: false,
            },
        },
        save: ({ attributes }) => {
            const {
                blockId,
                pricingStyle,
                title,
                showSubtitle,
                subtitle,
                showHeaderIcon,
                headerIcon,
                mainPrice,
                showOnSale,
                salePrice,
                priceCurrency,
                currencyPlacement,
                pricePeriod,
                periodSeparator,
                features,
                showButton,
                buttonIcon,
                buttonIconPosition,
                buttonText,
                buttonURL,
                contentAlign,
                showRibbon,
                ribbonStyle,
            } = attributes;

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

            return (
                <div {...useBlockProps.save()}>
                    <div
                        className={`${blockId} eb-pricing-wrapper eb-pricing-content-${contentAlign}`}
                    >
                        <div className={`eb-pricing ${pricingStyle}`}>
                            <div className={`eb-pricing-item${ribbonClass}`}>
                                <div className="eb-pricing-item-overlay"></div>
                                {showHeaderIcon && (
                                    <div className="eb-pricing-icon" data-icon={headerIcon}>
                                        <span className="icon">
                                            <i className={headerIcon}></i>
                                        </span>
                                    </div>
                                )}
                                <div className="eb-pricing-header">
                                    <h2 className="eb-pricing-title">{title}</h2>
                                    {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>
                                )}
                                <div className="eb-pricing-body">
                                    <ul className="eb-pricebox-features">
                                        {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)}>
                                                            <span
                                                                className={`eb-pricebox-icon ${icon}`}
                                                                style={{ color: color }}
                                                            />
                                                            <span className="eb-pricebox-feature-text">
                                                                {text}
                                                            </span>
                                                        </a>
                                                    ) : (
                                                        <>
                                                            <span
                                                                className={`eb-pricebox-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" && (
                                                    <i className={buttonIcon}></i>
                                                )}
                                                <span className="eb-button-text">{buttonText}</span>
                                                {buttonIconPosition === "right" && (
                                                    <i className={buttonIcon}></i>
                                                )}
                                            </a>
                                        </div>
                                    </div>
                                )}
                            </div>
                        </div>
                    </div>
                </div>
                // edit view end
            );
        },
    },
    {
        attributes: { ...attributes },
        save: ({ attributes }) => {
            const {
                blockId,
                pricingStyle,
                title,
                showSubtitle,
                subtitle,
                showHeaderIcon,
                headerIcon,
                mainPrice,
                showOnSale,
                salePrice,
                priceCurrency,
                currencyPlacement,
                pricePeriod,
                periodSeparator,
                features,
                showButton,
                buttonIcon,
                buttonIconPosition,
                buttonText,
                buttonURL,
                contentAlign,
                showRibbon,
                ribbonStyle,
            } = attributes;

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

            return (
                <div {...useBlockProps.save()}>
                    <div className={`${blockId} eb-pricing-content-${contentAlign}`}>
                        <div className={`eb-pricing ${pricingStyle}`}>
                            <div className={`eb-pricing-item${ribbonClass}`}>
                                <div className="eb-pricing-item-overlay"></div>
                                {showHeaderIcon && (
                                    <div className="eb-pricing-icon" data-icon={headerIcon}>
                                        <span className="icon">
                                            <i className={headerIcon}></i>
                                        </span>
                                    </div>
                                )}
                                <div className="eb-pricing-header">
                                    <h2 className="eb-pricing-title">{title}</h2>
                                    {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>
                                )}
                                <div className="eb-pricing-body">
                                    <ul className="eb-pricebox-features">
                                        {features.map(({ icon, text, color, clickable, link }) => (
                                            <li
                                                className="eb-pricebox-feature-item"
                                                data-icon={icon}
                                                data-color={color}
                                                data-clickable={clickable}
                                                data-link={link}
                                            >
                                                {clickable && link ? (
                                                    <a href={sanitizeURL(link)}>
                                                        <span
                                                            className={`eb-pricebox-icon ${icon}`}
                                                            style={{ color: color }}
                                                        />
                                                        <span className="eb-pricebox-feature-text">
                                                            {text}
                                                        </span>
                                                    </a>
                                                ) : (
                                                    <>
                                                        <span
                                                            className={`eb-pricebox-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" && (
                                                    <i className={buttonIcon}></i>
                                                )}
                                                <span className="eb-button-text">{buttonText}</span>
                                                {buttonIconPosition === "right" && (
                                                    <i className={buttonIcon}></i>
                                                )}
                                            </a>
                                        </div>
                                    </div>
                                )}
                            </div>
                        </div>
                    </div>
                </div>
                // edit view end
            );
        },
    },
];

export default deprecated;