import React from 'react';
import { connect } from 'react-redux';
import PropTypes from 'prop-types';
import ImmutablePropTypes from 'react-immutable-proptypes';
import ImmutablePureComponent from 'react-immutable-pure-component';
import { Link } from 'react-router-dom';
import { List as ImmutableList } from 'immutable';
import { getSettings } from 'soapbox/actions/settings';
import { getSoapboxConfig } from 'soapbox/actions/soapbox';

const mapStateToProps = (state, props) => {
  const soapboxConfig = getSoapboxConfig(state);

  return {
    copyright: soapboxConfig.get('copyright'),
    navlinks: soapboxConfig.getIn(['navlinks', 'homeFooter'], ImmutableList()),
    locale: getSettings(state).get('locale'),
  };
};

export default @connect(mapStateToProps)
class Footer extends ImmutablePureComponent {

  static propTypes = {
    copyright: PropTypes.string,
    locale: PropTypes.string,
    navlinks: ImmutablePropTypes.list,
  }

  render() {
    const { copyright, locale, navlinks } = this.props;

    return (
      <div className='footer'>
        <div className='footer-container'>
          <div className='copyright'>
            <span>{copyright}</span>
          </div>
          <ul>
            {navlinks.map((link, i) => (
              <li key={i}>
                <Link to={link.get('url')}>
                  {link.getIn(['titleLocales', locale]) || link.get('title')}
                </Link>
              </li>
            ))}
          </ul>
        </div>
      </div>
    );
  }

}