Fix: don't display Intercom in Safe Apps (#2365)
* Check if current screen is the app view * Get app url from utils hook * Hook rename and updated effect dependency
This commit is contained in:
parent
e97d228429
commit
07465a0b29
|
@ -9,6 +9,7 @@ import { COOKIES_KEY } from 'src/logic/cookies/model/cookie'
|
|||
import { openCookieBanner } from 'src/logic/cookies/store/actions/openCookieBanner'
|
||||
import { cookieBannerOpen } from 'src/logic/cookies/store/selectors'
|
||||
import { loadFromCookie, saveCookie } from 'src/logic/cookies/utils'
|
||||
import { useSafeAppUrl } from 'src/logic/hooks/useSafeAppUrl'
|
||||
import { mainFontFamily, md, primary, screenSm } from 'src/theme/variables'
|
||||
import { loadGoogleAnalytics, removeCookies } from 'src/utils/googleAnalytics'
|
||||
import { closeIntercom, isIntercomLoaded, loadIntercom } from 'src/utils/intercom'
|
||||
|
@ -97,7 +98,7 @@ interface CookiesBannerFormProps {
|
|||
const CookiesBanner = (): ReactElement => {
|
||||
const classes = useStyles()
|
||||
const dispatch = useRef(useDispatch())
|
||||
|
||||
const { url: appUrl } = useSafeAppUrl()
|
||||
const [showAnalytics, setShowAnalytics] = useState(false)
|
||||
const [showIntercom, setShowIntercom] = useState(false)
|
||||
const [localNecessary, setLocalNecessary] = useState(true)
|
||||
|
@ -106,6 +107,12 @@ const CookiesBanner = (): ReactElement => {
|
|||
|
||||
const showBanner = useSelector(cookieBannerOpen)
|
||||
|
||||
useEffect(() => {
|
||||
if (appUrl) {
|
||||
setTimeout(closeIntercom, 50)
|
||||
}
|
||||
}, [appUrl])
|
||||
|
||||
useEffect(() => {
|
||||
async function fetchCookiesFromStorage() {
|
||||
const cookiesState = await loadFromCookie(COOKIES_KEY)
|
||||
|
@ -171,7 +178,7 @@ const CookiesBanner = (): ReactElement => {
|
|||
dispatch.current(openCookieBanner({ cookieBannerOpen: false }))
|
||||
}
|
||||
|
||||
if (showIntercom) {
|
||||
if (showIntercom && !appUrl) {
|
||||
loadIntercom()
|
||||
}
|
||||
|
||||
|
|
|
@ -0,0 +1,22 @@
|
|||
import { useLocation } from 'react-router-dom'
|
||||
import { useEffect, useState } from 'react'
|
||||
|
||||
type AppUrlReturnType = {
|
||||
url: string | null
|
||||
}
|
||||
|
||||
export const useSafeAppUrl = (): AppUrlReturnType => {
|
||||
const [url, setUrl] = useState<string | null>(null)
|
||||
const { search } = useLocation()
|
||||
|
||||
useEffect(() => {
|
||||
if (search !== url) {
|
||||
const query = new URLSearchParams(search)
|
||||
setUrl(query.get('appUrl'))
|
||||
}
|
||||
}, [search, url])
|
||||
|
||||
return {
|
||||
url,
|
||||
}
|
||||
}
|
|
@ -1,20 +1,14 @@
|
|||
import React from 'react'
|
||||
|
||||
import { useLocation } from 'react-router-dom'
|
||||
import { useSafeAppUrl } from 'src/logic/hooks/useSafeAppUrl'
|
||||
|
||||
import AppFrame from './components/AppFrame'
|
||||
import AppsList from './components/AppsList'
|
||||
|
||||
const useQuery = () => {
|
||||
return new URLSearchParams(useLocation().search)
|
||||
}
|
||||
|
||||
const Apps = (): React.ReactElement => {
|
||||
const query = useQuery()
|
||||
const appUrl = query.get('appUrl')
|
||||
const { url } = useSafeAppUrl()
|
||||
|
||||
if (appUrl) {
|
||||
return <AppFrame appUrl={appUrl} />
|
||||
if (url) {
|
||||
return <AppFrame appUrl={url} />
|
||||
} else {
|
||||
return <AppsList />
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue