HEX
Server: Apache
System: Linux a16-asgard6.hospedagemuolhost.com.br 5.14.0-570.52.1.el9_6.x86_64 #1 SMP PREEMPT_DYNAMIC Wed Oct 15 06:39:08 EDT 2025 x86_64
User: maoristu4c3dbd03 (1436)
PHP: 8.1.33
Disabled: NONE
Upload Files
File: /home/maoristu4c3dbd03/www/wp-content/plugins/really-simple-ssl/settings/src/Page.js
import {useEffect} from "@wordpress/element";
import Header from "./Header";
import DashboardPage from "./Dashboard/DashboardPage";
import Menu from "./Menu/Menu";
import Settings from "./Settings/Settings";
import Notices from "./Settings/Notices";
import Modal from "./Modal/Modal";
import PagePlaceholder from './Placeholder/PagePlaceholder';
import OnboardingModal from "./Onboarding/OnboardingModal";
import getAnchor from "./utils/getAnchor";
import useFields from "./Settings/FieldsData";
import useMenu from "./Menu/MenuData";

const Page = (props) => {
    const {error, fields, changedFields, fetchFieldsData, updateFieldsData, fieldsLoaded} = useFields();
    const {selectedMainMenuItem, fetchMenuData } = useMenu();


    useEffect( () => {
        if ( fieldsLoaded ) {
            fetchMenuData(fields);
            window.addEventListener('hashchange', (e) => {
                fetchMenuData(fields);
            });
        }
    }, [fields] );

    useEffect( () => {
        let subMenuItem = getAnchor('menu');
        const run = async () => {
            await updateFieldsData(subMenuItem);
        }
        run();
    }, [changedFields] );

    useEffect( () => {
        let subMenuItem = getAnchor('menu');
        const run = async () => {
            await fetchFieldsData(subMenuItem);
        }
        run();
    }, [] );


    if (error) {
        return (
            <>
                <PagePlaceholder error={error}></PagePlaceholder>
            </>
        )
    }
    return (
        <div className="rsssl-wrapper">
            <OnboardingModal />
            {!fieldsLoaded && <PagePlaceholder></PagePlaceholder>}
            <Modal/>
            {fieldsLoaded &&
                (
                    <>
                        <Header />
                        <div className={"rsssl-content-area rsssl-grid rsssl-" + selectedMainMenuItem}>
                            { selectedMainMenuItem !== 'dashboard' &&
                               <>
                                   <Menu />
                                   <Settings/>
                                   <Notices className="rsssl-wizard-notices"/>
                               </>

                            }
                            { selectedMainMenuItem === 'dashboard' &&
                                <DashboardPage />
                            }
                        </div>
                    </>
                )
            }
        </div>
    );

}
export default Page