HEX
Server: Apache
System: Linux scp1.abinfocom.com 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: confeduphaar (1010)
PHP: 8.1.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: /home/confeduphaar/public_html/wp-content/plugins/essential-blocks/src/blocks/accordion/src/save.js
/**
 * WordPress dependencies
 */
import { InnerBlocks } from "@wordpress/block-editor";
import { BlockProps } from "@essential-blocks/controls";

const Save = ({ attributes }) => {
    const {
        blockId,
        classHook,
        accordionType,
        displayIcon,
        tabIcon,
        expandedIcon,
        transitionDuration,
        accordionLists,
        titleOrientation,
    } = attributes;

    const allNotClickable = accordionLists?.every(
        (item) => item.clickable === false,
    );
    const defaultImageUrl =
        EssentialBlocksLocalize?.image_url + "/image-placeholder.jpg";

    const accordionTypeClass =
        accordionType === "image"
            ? " eb-accordion-type-image"
            : accordionType === "horizontal"
            ? " eb-accordion-type-horizontal"
            : "";
    const orientationClass =
        accordionType === "horizontal"
            ? titleOrientation === "bottom-top"
                ? " eb-accordion-bottom-top"
                : " eb-accordion-top-bottom"
            : "";

    return (
        <BlockProps.Save attributes={attributes}>
            <div
                className={`eb-parent-wrapper eb-parent-${blockId} ${classHook}`}
            >
                <div
                    className={`eb-accordion-container ${blockId}${accordionTypeClass}${orientationClass}`}
                    data-accordion-type={accordionType || "toggle"}
                    data-tab-icon={displayIcon ? tabIcon : ""}
                    data-expanded-icon={displayIcon ? expandedIcon : ""}
                    data-transition-duration={
                        transitionDuration
                            ? Number(transitionDuration) * 1000
                            : 500
                    }
                >
                    <div className="eb-accordion-inner">
                        <InnerBlocks.Content />
                    </div>
                    {accordionType === "image" && (
                        <div className="eb-accordion-image-container">
                            <img
                                src={
                                    (allNotClickable && accordionLists[0]?.imageUrl || "")
                                }
                                alt={
                                    (allNotClickable &&
                                        accordionLists[0]?.imageAlt) ||
                                    ""
                                }
                            />
                        </div>
                    )}
                </div>
            </div>
        </BlockProps.Save>
    );
};

export default Save;