import api from '../../../api'
import { Route } from 'react-router-dom'
import BundleColumnError from '../../../components/bundle_column_error'
import Bundle from './bundle'
import { me } from '../../../initial_state'

export default class WrappedRoute extends PureComponent {
  static propTypes = {
    component: PropTypes.func.isRequired,
    page: PropTypes.func.isRequired,
    content: PropTypes.node,
    componentParams: PropTypes.object,
    publicRoute: PropTypes.bool,
  }

  static defaultProps = {
    componentParams: {},
  }

  renderComponent = ({ match }) => {
    const {
      component,
      content,
      componentParams,
      page: Page
    } = this.props

    return (
      <Bundle fetchComponent={component} error={this.renderError}>
        {Component =>
          (
            <Page params={match.params} {...componentParams}>
              <Component params={match.params} {...componentParams}>
                {content}
              </Component>
            </Page>
          )
        }
      </Bundle>
    )
  }

  renderError = (props) => {
    return <BundleColumnError {...props} />
  }

  render() {
    const {
      component: Component,
      content,
      publicRoute,
      ...rest
    } = this.props

    // : todo :
    // api().get('/api/v1/accounts/verify_credentials')
    // .then((res) => {
    //   console.log("res:", res)
    // })
    // .catch((err) => {
    //   console.log("err:", err)
    // })

    if (!publicRoute && !me) {
      const actualUrl = encodeURIComponent(this.props.computedMatch.url)
      return <Route path={this.props.path} component={() => {
        window.location.href = `/auth/sign_in?redirect_uri=${actualUrl}`
        return null
      }} />
    }

    return <Route {...rest} render={this.renderComponent} />
  }
}