import React from 'react'; export const registerUmamiScript = (url, websiteId, dataDomain) => { if (url && websiteId && dataDomain) { const head = document.getElementsByTagName('head')[0] const script = document.createElement('script') script.type = 'text/javascript'; script.src = url; script.async = 'async' script.defer = 'defer' script.setAttribute('data-auto-track', 'false') script.setAttribute('data-domains', dataDomain) script.setAttribute('data-website-id', websiteId) head.appendChild(script); } } export default (url, title, referrer, websiteId, skipPageView) => { skipPageView = skipPageView || false React.useEffect(() => { if (!skipPageView && window.umami && import.meta.env.MODE !== 'development') { try { const umami = window.umami const dict = {} if (title) { dict.title = title } if (referrer) { dict.referrer = referrer } if (websiteId) { dict.websiteId = websiteId } umami.track(props => ({ ...props, url: url, ...dict })) } catch (err) { console.warn && console.warn(err.message) } } }, [url, title, referrer, websiteId, skipPageView]) const trackEvent = (eventValue) => { try { const umami = window.umami umami.track(eventValue) } catch (err) { console.warn && console.warn(err.message) } } return trackEvent }