HEX
Server: Apache
System: Linux scp1.abinfocom.com 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: confeduphaar (1010)
PHP: 8.1.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: /home/confeduphaar/www/wp-content/plugins/essential-blocks/src/blocks/nft-gallery/src/frontend.js
import { render, useEffect, useState } from "@wordpress/element";

import Loading from "./template-components/loading";
import Items from "./template-components/items";
import Collections from "./template-components/collections";


const Content = (props) => {
    const {
        blockId,
        attributes,
        source
    } = props;

    const { settings } = attributes;

    const [nftData, setNftData] = useState({});
    const [nftError, setNftError] = useState({ status: false });
    const [loading, setLoading] = useState(true);

    useEffect(() => {
        setLoading(true);
        let data = new FormData();
        data.append("action", 'opensea_nft_collections');
        data.append("nft_nonce", EssentialBlocksLocalize.nft_nonce);
        data.append("nft_source", source);
        if (source === "opensea" && settings) {
            data.append("openseaType", settings.opensea.type);
            data.append("openseaCollectionSlug", settings.opensea.collectionSlug);
            data.append("openseaCollectionmWalletId", settings.opensea.collectionWalletId);
            data.append("openseaItemLimit", settings.opensea.itemLimit);
            data.append("openseaCollectionLimit", settings.opensea.collectionLimit);

            fetch(EssentialBlocksLocalize.ajax_url, {
                method: 'POST',
                body: data,
            }) // wrapped
                .then(res => res.text())
                .then(data => {
                    const response = JSON.parse(data);

                    if (response.success) {
                        setNftData(JSON.parse(response.data));
                        setLoading(false);
                        setNftError({
                            status: false,
                        });
                    }
                    else {
                        setLoading(false);
                        // removed error settings as we do not want to show anything in frontend if there is any API key error
                    }
                })
                .catch(err => console.log(err));
        }

    }, []);


    return (
        <>
            {loading && (
                <Loading attributes={attributes} />
            )}
            {!loading && (
                <>
                    {nftError.status && (
                        <span className="nft-error">{nftError.message}</span>
                    )}

                    {!nftError.status && (
                        <>
                            {settings.opensea.type === "items" && (
                                <Items
                                    data={nftData?.nfts}
                                    attributes={attributes}
                                />
                            )}

                            {settings.opensea.type === "collections" && (
                                <Collections
                                    data={nftData?.collections}
                                    attributes={attributes}
                                />
                            )}
                        </>
                    )}
                </>
            )}
        </>
    );
}

document.addEventListener("DOMContentLoaded", function (event) {
    let nftGallery = document.querySelectorAll(".eb-nft-gallery-wrapper");

    for (let i = 0; i < nftGallery.length; i++) {

        //Retrieve Data
        let blockId = nftGallery[i].getAttribute("data-id");
        let source = nftGallery[i].getAttribute("data-source");
        let attributes = nftGallery[i].getAttribute("data-attributes");

        const wrapper = document.querySelector(`.${blockId}`);

        render(
            <Content
                blockId={blockId}
                source={source}
                attributes={JSON.parse(attributes)}
            />,
            wrapper
        );
    }
});