Server IP : 85.214.239.14 / Your IP : 216.73.216.9 Web Server : Apache/2.4.62 (Debian) System : Linux h2886529.stratoserver.net 4.9.0 #1 SMP Mon Sep 30 15:36:27 MSK 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.18 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : OFF | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : OFF Directory : /var/www/wordpress/wp-content/plugins/really-simple-ssl/settings/src/Settings/Host/ |
Upload File : |
import { useState, useEffect, memo } from "@wordpress/element"; import { ThemeProvider } from '@mui/material/styles'; import useFields from "../FieldsData"; import AutoCompleteControl from "../AutoComplete/AutoCompleteControl"; import useHostData from "./HostData"; import { __ } from "@wordpress/i18n"; import autoCompleteSharedTheme from "../../utils/autoCompleteTheme"; const Host = ({ field, showDisabledWhenSaving = true }) => { const { updateField, setChangedField, saveFields, handleNextButtonDisabled } = useFields(); const [disabled, setDisabled] = useState(false); const { fetchHosts, hosts, hostsLoaded } = useHostData(); useEffect(() => { if (!hostsLoaded) { fetchHosts(); } }, []); useEffect(() => { handleNextButtonDisabled(disabled); }, [disabled]); const onChangeHandler = async (fieldValue) => { if (showDisabledWhenSaving) { setDisabled(true); } updateField(field.id, fieldValue); setChangedField(field.id, fieldValue); await saveFields(true, false); setDisabled(false); }; let loadedHosts = hostsLoaded ? hosts : []; let options = []; let item = { label: __('Optional - Select your hosting provider.', 'really-simple-ssl'), value: '', }; if (field.value.length === 0) { options.push(item); } for (let key in loadedHosts) { if (loadedHosts.hasOwnProperty(key)) { let item = {}; item.label = loadedHosts[key].name; item.value = key; options.push(item); } } return ( <ThemeProvider theme={autoCompleteSharedTheme}> <AutoCompleteControl className="rsssl-select" field={field} label={field.label} onChange={(fieldValue) => onChangeHandler(fieldValue)} value={field.value} options={options} disabled={disabled} /> </ThemeProvider> ); }; export default memo(Host);