import variables from 'config/variables'; import { PureComponent } from 'react'; import { MdAutoAwesome } from 'react-icons/md'; import { Header, Row, Content, Action, PreferencesWrapper } from 'components/Layout/Settings'; import { Radio, Dropdown, Checkbox } from 'components/Form/Settings'; import { TextField } from '@mui/material'; class WeatherOptions extends PureComponent { constructor() { super(); this.state = { location: localStorage.getItem('location') || '', windSpeed: localStorage.getItem('windspeed') !== 'true', }; } componentDidUpdate() { localStorage.setItem('location', this.state.location); } showReminder() { document.querySelector('.reminder-info').style.display = 'flex'; localStorage.setItem('showReminder', true); } changeLocation(e) { this.setState({ location: e.target.value, }); this.showReminder(); } render() { const weatherType = localStorage.getItem('weatherType'); const WEATHER_SECTION = 'modals.main.settings.sections.weather'; const WidgetType = () => { return ( this.forceUpdate()} items={[ { value: '1', text: variables.getMessage(`${WEATHER_SECTION}.options.basic`) }, { value: '2', text: variables.getMessage(`${WEATHER_SECTION}.options.standard`), }, { value: '3', text: variables.getMessage(`${WEATHER_SECTION}.options.expanded`), }, { value: '4', text: variables.getMessage(`${WEATHER_SECTION}.options.custom`) }, ]} /> ); }; const LocationSetting = () => { const getAuto = () => { this.setState({ location: variables.getMessage('modals.main.loading'), }); navigator.geolocation.getCurrentPosition( async (position) => { const data = await ( await fetch( `${variables.constants.API_URL}/gps?latitude=${position.coords.latitude}&longitude=${position.coords.longitude}`, ) ).json(); this.setState({ location: data[0].name, }); this.showReminder(); }, (error) => { // firefox requires this 2nd function console.log(error); }, { enableHighAccuracy: true, }, ); }; return ( this.changeLocation(e)} placeholder="London" varient="outlined" InputLabelProps={{ shrink: true }} /> {variables.getMessage(`${WEATHER_SECTION}.auto`)} ); }; const TemperatureFormat = () => { return ( ); }; const CustomOptions = () => { const weatherOptions = [ { name: 'weatherdescription', textKey: `${WEATHER_SECTION}.extra_info.show_description`, }, { name: 'cloudiness', textKey: `${WEATHER_SECTION}.extra_info.cloudiness`, }, { name: 'humidity', textKey: `${WEATHER_SECTION}.extra_info.humidity` }, { name: 'visibility', textKey: `${WEATHER_SECTION}.extra_info.visibility`, }, { name: 'windspeed', textKey: `${WEATHER_SECTION}.extra_info.wind_speed`, onChange: () => this.setState({ windSpeed: localStorage.getItem('windspeed') !== 'true' }), }, { name: 'windDirection', textKey: `${WEATHER_SECTION}.extra_info.wind_direction`, disabled: this.state.windSpeed, }, { name: 'atmosphericpressure', textKey: `${WEATHER_SECTION}.extra_info.atmospheric_pressure`, }, ]; return ( {weatherOptions.map((item) => ( ))} ); }; return ( <>
{/* https://stackoverflow.com/a/65328486 when using inputs it may defocus so we do the {} instead of <> */} {LocationSetting()} {weatherType === '4' && } ); } } export { WeatherOptions as default, WeatherOptions };