50 lines
1.5 KiB
JavaScript
Raw Normal View History

2021-04-13 19:57:32 -05:00
import '../styles/globals.scss'
2021-10-26 15:49:37 -05:00
import { ApolloProvider, gql } from '@apollo/client'
2021-04-12 13:05:09 -05:00
import { Provider } from 'next-auth/client'
2021-05-20 16:32:59 -05:00
import { FundErrorModal, FundErrorProvider } from '../components/fund-error'
2021-05-24 19:08:56 -05:00
import { MeProvider } from '../components/me'
2021-07-15 15:49:13 -05:00
import PlausibleProvider from 'next-plausible'
import { LightningProvider } from '../components/lightning'
2021-09-10 13:55:36 -05:00
import { ItemActModal, ItemActProvider } from '../components/item-act'
2021-09-30 10:46:58 -05:00
import getApolloClient from '../lib/apollo'
2021-03-22 15:36:10 -05:00
2021-09-30 10:46:58 -05:00
function MyApp ({ Component, pageProps: { session, ...props } }) {
2021-10-26 15:49:37 -05:00
const client = getApolloClient()
/*
If we are on the client, we populate the apollo cache with the
ssr data
*/
if (typeof window !== 'undefined') {
const { apollo, data } = props
if (apollo) {
client.writeQuery({
query: gql`${apollo.query}`,
data: data,
variables: apollo.variables
})
}
}
2021-04-12 13:05:09 -05:00
return (
2021-07-15 15:49:13 -05:00
<PlausibleProvider domain='stacker.news' trackOutboundLinks>
2021-09-30 10:46:58 -05:00
<Provider session={session}>
2021-10-26 15:49:37 -05:00
<ApolloProvider client={client}>
<MeProvider>
<LightningProvider>
<FundErrorProvider>
<FundErrorModal />
2021-09-10 13:55:36 -05:00
<ItemActProvider>
<ItemActModal />
2021-09-30 10:46:58 -05:00
<Component {...props} />
2021-09-10 13:55:36 -05:00
</ItemActProvider>
</FundErrorProvider>
</LightningProvider>
</MeProvider>
</ApolloProvider>
</Provider>
2021-07-15 15:49:13 -05:00
</PlausibleProvider>
2021-04-12 13:05:09 -05:00
)
2021-03-22 15:36:10 -05:00
}
export default MyApp