import 'core-js/modules/es.array.map'
import 'core-js/modules/es.map'
import 'core-js/modules/es.object.create'
import 'core-js/modules/es.object.define-property'
import 'core-js/modules/es.object.set-prototype-of'
import 'core-js/modules/es.promise'
import 'core-js/modules/es.set'
import 'core-js/modules/es.symbol'
import 'core-js/modules/web.dom-collections.iterator'
import 'url-polyfill'
import { StrictMode, lazy } from 'react'
import { createRoot, hydrateRoot } from 'react-dom/client'
import { BrowserRouter } from 'react-router-dom'
import { HelmetProvider } from 'react-helmet-async'

import { VisitorProvider } from './ui/VisitorContext'
import { me } from './api'

const Juick = lazy(() => import('./App'))
const props = window.__PROPS__ ? JSON.parse(decodeURIComponent(escape(atob(window.__PROPS__)))) : {}

function ready(fn) {
    if (document.readyState != 'loading') {
        fn()
    } else {
        document.addEventListener('DOMContentLoaded', fn)
    }
}

ready(async () => {
    let visitor
    try {
        visitor = (await me()).data
    } catch (e) {
        visitor = undefined
    }
    const JuickApp = () => (
        <StrictMode>
            <HelmetProvider>
                <VisitorProvider auth={visitor}>
                    <BrowserRouter>
                        <Juick {...props} />
                    </BrowserRouter>
                </VisitorProvider>
            </HelmetProvider>
        </StrictMode>
    )
    let root = document.getElementById('app')
    if (window.__PROPS__) {
        hydrateRoot(root, <JuickApp />)
    } else {
        createRoot(root).render(<JuickApp />)
    }
})