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/Settings/Settings.js
import { useState} from "@wordpress/element";
import Placeholder from "../Placeholder/Placeholder";
import {in_array} from "../utils/lib";
import SettingsGroup from "./SettingsGroup";
import Help from "./Help";
import useFields from "./FieldsData";
import useMenu from "../Menu/MenuData";
import { __ } from '@wordpress/i18n';
import useLetsEncryptData from "../LetsEncrypt/letsEncryptData";

/**
 * Renders the selected settings
 *
 */
const Settings = () => {
    const [noticesExpanded, setNoticesExpanded] = useState(true);
    const {progress, fieldsLoaded, saveFields, fields, nextButtonDisabled} = useFields();
    const {subMenuLoaded, subMenu, selectedSubMenuItem, selectedMainMenuItem, nextMenuItem, previousMenuItem} = useMenu();
    const {setRefreshTests} = useLetsEncryptData();

    const toggleNotices = () => {
        setNoticesExpanded(!noticesExpanded);
    }

    const isTestsOnlyMenu = () => {
        const { menu_items: menuItems } = subMenu;
        for (const menuItem of menuItems ) {
            if (menuItem.id===selectedSubMenuItem && menuItem.tests_only ) {
               return true;
            }
        }
       return false;
    }

    const saveData = async (isSaveAndContinueButton) => {
        if ( !isSaveAndContinueButton && isTestsOnlyMenu() ) {
            setRefreshTests(true);
        } else {
            await saveFields(true, true);
        }
    }

    const { menu_items: menuItems } = subMenu;
    if ( !subMenuLoaded || !fieldsLoaded || menuItems.length===0 ) {
        return(
            <div className="cmplz-wizard-settings cmplz-column-2">
                <div className="cmplz-grid-item">
                    <div className="cmplz-grid-item-content">
                        <div className="cmplz-settings-block-intro"><Placeholder lines="3"></Placeholder></div>
                    </div>
                </div>
                <div className="cmplz-grid-item-footer"></div>
            </div>
        )
    }

    let selectedFields = fields.filter(field => field.menu_id === selectedSubMenuItem);
    let groups = [];
    for (const selectedField of selectedFields){
        if ( !in_array(selectedField.group_id, groups) ){
            groups.push(selectedField.group_id);
        }
    }

    //convert progress notices to an array useful for the help blocks
    let notices = [];
    for (const notice of progress.notices){
        let noticeIsLinkedToField = false;

        //notices that are linked to a field. Only in case of warnings.
        if ( notice.show_with_options && notice.output.icon === 'warning') {
            let noticeFields = selectedFields.filter(field => notice.show_with_options.includes(field.id));
            noticeIsLinkedToField = noticeFields.length>0;
        }
        //notices that are linked to a menu id.
        if ( noticeIsLinkedToField || notice.menu_id === selectedSubMenuItem ) {
            let help = {};
            help.title = notice.output.title ? notice.output.title : false;
            help.label = notice.output.label;
            help.id = notice.id;
            help.text = notice.output.msg;
            help.url = notice.output.url;
            help.linked_field = notice.show_with_option;
            notices.push(help);
        }
    }

    //help items belonging to a field
    //if field is hidden, hide the notice as well
    for (const notice of selectedFields.filter(field => field.help && !field.conditionallyDisabled)){
        let help = notice.help;
        //check if the notices array already includes this help item
        let existingNotices = notices.filter(noticeItem => noticeItem.id && noticeItem.id===help.id);
        if ( existingNotices.length===0) {
            // if (!help.id ) help['id'] = notice.id;
            notices.push(notice.help);
        }
    }
    let continueLink = nextButtonDisabled ? `#${selectedMainMenuItem}/${selectedSubMenuItem}` : `#${selectedMainMenuItem}/${nextMenuItem}`;
    // let btnSaveText = isTestsOnlyMenu() ? __('Refresh', 'really-simple-ssl') : __('Save', 'really-simple-ssl');
    let btnSaveText = __('Save', 'really-simple-ssl');
    for (const menuItem of menuItems ) {
        if (menuItem.id===selectedSubMenuItem && menuItem.tests_only ) {
            btnSaveText = __('Refresh', 'really-simple-ssl');
        }
    }
    return (
        <>
            <div className="rsssl-wizard-settings">
                { groups.map((group, i) =>
                    <SettingsGroup key={i} index={i} group={group} fields={selectedFields}/>)
                }
                <div className="rsssl-grid-item-footer">
                    {/*This will be shown only if current step is not the first one*/}
                    { selectedSubMenuItem !== menuItems[0].id &&
                        <a className="button button-secondary" href={`#${selectedMainMenuItem}/${previousMenuItem}`} >
                            { __('Previous', 'complianz-gdpr') }
                        </a>
                    }
                    <button
                        className="button button-primary"
                        onClick={ ( e ) => saveData(false) }>
                        { btnSaveText }
                    </button>
                    {/*This will be shown only if current step is not the last one*/}
                    { selectedSubMenuItem !== menuItems[menuItems.length-1].id &&
                        <>
                            <a disabled={nextButtonDisabled} className="button button-primary" href={continueLink} onClick={ ( e ) => saveData(true) }>
                                { __( 'Save and Continue', 'complianz-gdpr' ) }
                            </a>
                        </>
                    }
                </div>
            </div>
            <div className="rsssl-wizard-help">
                <div className="rsssl-help-header">
                    <div className="rsssl-help-title rsssl-h4">
                        {__("Notifications", "really-simple-ssl")}
                    </div>
                    <div className="rsssl-help-control" onClick={ () => toggleNotices() }>
                        {!noticesExpanded && __("Expand all","really-simple-ssl")}
                        {noticesExpanded && __("Collapse all","really-simple-ssl")}
                    </div>
                </div>
                {notices.map((field, i) => <Help key={i} noticesExpanded={noticesExpanded} index={i} help={field} fieldId={field.id}/>)}
            </div>


        </>


    )

}
export default Settings