Current File : /home/resuelf/www/wp-content/plugins/really-simple-ssl/settings/src/Onboarding/Onboarding.js
import { useEffect } from "@wordpress/element";
import { __ } from '@wordpress/i18n';
import Icon from "../utils/Icon";
import Placeholder from '../Placeholder/Placeholder';
import useFields from "../Settings/FieldsData";
import useOnboardingData from "./OnboardingData";
import OnboardingControls from "./OnboardingControls";
import StepEmail from "./StepEmail";
import StepConfig from "./StepConfig";
import StepFeatures from "./StepFeatures";
import StepPlugins from "./StepPlugins";
import StepPro from "./StepPro";
import DOMPurify from 'dompurify';
const Onboarding = ({isModal}) => {
    const { fetchFieldsData, fieldsLoaded} = useFields();
    const {
        getSteps,
        error,
        networkwide,
        sslEnabled,
        dataLoaded,
        processing,
        currentStep,
        currentStepIndex,
        setCurrentStepIndex,
        networkActivationStatus,
        networkProgress,
        activateSSLNetworkWide,
    } = useOnboardingData();

    useEffect( () => {
        if (networkwide && networkActivationStatus==='main_site_activated') {
            //run networkwide activation with a delay
            setTimeout( () => {
                activateSSLNetworkWide();
            }, 1000);
        }
    }, [networkActivationStatus, networkProgress])

    useEffect(() => {
        if ( !fieldsLoaded ) {
            fetchFieldsData();
        }
    }, []);


    useEffect( () => {
        const run = async () => {
            await getSteps(false);
            if ( dataLoaded && sslEnabled && currentStepIndex===0) {
                setCurrentStepIndex(1)
            }
        }
        run();
    }, [])

    if (error){
        return (
            <Placeholder lines="3" error={error}></Placeholder>
        )
    }
    let processingClass = '';//processing ? 'rsssl-processing' : '';
    //get 'other_host_type' field from fields

    return (
        <>
            { !dataLoaded &&
                <>
                    <div className="rsssl-onboarding-placeholder">
                        <ul>
                            <li><Icon name = "loading" color = 'grey' />{__("Fetching next step...", "really-simple-ssl")}</li>
                        </ul>
                        <Placeholder lines="3" ></Placeholder>
                    </div>
                </>
            }
            {
                dataLoaded &&
                    <div className={ processingClass+" rsssl-"+currentStep.id }>
                        { currentStep.id === 'activate_ssl' &&
                          <>
                              <StepConfig />
                          </>
                        }
                        { currentStep.id === 'features'&&
                            <>
                                <StepFeatures />
                            </>
                        }
                        { currentStep.id === 'email'&&
                            <>
                                <StepEmail />
                            </>
                        }

                        { currentStep.id === 'plugins' &&
                            <>
                                <StepPlugins />
                            </>
                        }

                        { currentStep.id === 'pro' &&
                            <>
                                <StepPro />
                            </>
                        }

                        { !isModal &&
                            <OnboardingControls isModal={false}/>
                        }
                    </div>
            }
        </>
    )
}

export default Onboarding;