import React, { FC, useState } from "react"; import Title from "../../core/Title"; import Icons from "../../icons"; import BbPressImage from "../../images/bbpress.svg"; import { toBoolean, isBbPressInstalled, isBbPressLoaded, getNonce, getAjaxNonce, } from "../../Helpers"; type Props = { handleSingleIntegration: any; store: any; setStore: any; }; const BbPress: FC = ({ handleSingleIntegration, store, setStore }) => { const [installed, setInstall] = useState(isBbPressInstalled()); const [loaded, setLoad] = useState(isBbPressLoaded()); const [loader, setLoader] = useState(false); const [collapse, setCollapse] = useState( toBoolean(localStorage.getItem("ect_bbpress_integration_collapse")) ); const handleCollapse = (value) => { setCollapse(value); localStorage.setItem("ect_bbpress_integration_collapse", value); }; const handleStatus = (e): void => { setStore({ ...store, integrations: { ...store.integrations, [e.target.name]: e.target.checked, }, }); if (!collapse && e.target.checked) { setCollapse(true); } }; const handlePluginInstall = (e) => { e.preventDefault(); setLoader(true); wp.ajax.send("wp_ajax_install_plugin", { data: { _ajax_nonce: getAjaxNonce(), slug: "bbpress", }, success() { setLoader(false); setInstall(true); }, error() { setInstall(false); }, }); }; const handlePluginActive = (e) => { e.preventDefault(); setLoader(true); wp.ajax.send("active_plugin", { data: { nonce: getNonce(), slug: "bbpress", }, success() { setLoader(false); setLoad(true); }, error() { setLoad(true); setLoader(false); }, }); }; return ( <>
BbPress Logo
<h3>bbPress</h3> <span>New</span> {!installed && (
{Icons.info_icon} Please install BbPress first!
)} {installed && !loaded && (
{Icons.info_icon} Please activate BbPress first!
)} {installed && loaded && toBoolean( store?.integrations?.bbpress && store.integrations.bbpress.toString() ) &&

Turnstile is enabled for

} {collapse ? ( <> {!installed || !loaded ? ( <>
  • BbPress Topic
  • BbPress Reply
) : ( <>
{" "}
)} ) : null} {collapse ? ( ) : ( )}
{installed && loaded && ( )} {!installed && (
handlePluginInstall(e)}> {loader ? ( ) : ( )}
)} {installed && !loaded && (
handlePluginActive(e)}> {loader ? ( ) : ( )}
)}
); }; export default BbPress;