// @flow

import React, { useState } from 'react';
import { FormField } from 'component/common/form';
import Spinner from 'component/spinner';
import SUPPORTED_LANGUAGES from 'constants/supported_languages';
import { getDefaultLanguage } from 'util/default-languages';

type Props = {
  language: string,
  setLanguage: (string) => void,
  searchInLanguage: boolean,
  setSearchInLanguage: (boolean) => void,
};

function SettingLanguage(props: Props) {
  const { language, setLanguage, searchInLanguage, setSearchInLanguage } = props;

  const [previousLanguage, setPreviousLanguage] = useState(null);
  const languages = SUPPORTED_LANGUAGES;

  if (previousLanguage && language !== previousLanguage) {
    setPreviousLanguage(null);
  }

  function onLanguageChange(e) {
    const { value } = e.target;
    setPreviousLanguage(language || getDefaultLanguage());
    setLanguage(value);
  }

  return (
    <React.Fragment>
      <FormField
        name="language_select"
        type="select"
        label={__('Language')}
        onChange={onLanguageChange}
        value={language || getDefaultLanguage()}
        helper={__(
          'Multi-language support is brand new and incomplete. Switching your language may have unintended consequences, like glossolalia.'
        )}
      >
        {Object.entries(languages)
          .sort((a, b) => {
            const lhs = String(a[1]);
            const rhs = String(b[1]);
            if (lhs < rhs) return -1;
            if (lhs > rhs) return 1;
            return 0;
          })
          .map((language) => {
            const langKey = language[0];
            const langName = String(language[1]);
            return (
              <option key={langKey} value={langKey}>
                {langName}
              </option>
            );
          })}
      </FormField>
      {previousLanguage && <Spinner type="small" />}
      <FormField
        name="search-in-language"
        type="checkbox"
        label={__('Search only in this language by default')}
        checked={searchInLanguage}
        onChange={() => setSearchInLanguage(!searchInLanguage)}
      />
    </React.Fragment>
  );
}

export default SettingLanguage;