diff --git a/packages/docs/docs/guides/client-side-routing.md b/packages/docs/docs/guides/client-side-routing.md new file mode 100644 index 00000000..7a2b3b7f --- /dev/null +++ b/packages/docs/docs/guides/client-side-routing.md @@ -0,0 +1,59 @@ +# Client-Side Routing and Tracking in SPAs + +Single Page Applications (SPAs) update the content without reloading the entire page, which can make traditional page view tracking challenging. To accurately track page views in such applications, you can use the `trackPageViewSPA` method provided by some of our integrations. + +Your adjusted guide for client-side routing and tracking in SPAs is well-structured and provides a clear example using the Matomo integration. Here's an enhancement to include the tracking of both old and new locations: + +### Enhanced Guide for Client-Side Routing and Tracking in SPAs + +#### Implementing Enhanced Routing Event Listener +When using client-side routing in your SPA, it's important to track both the new and previous locations to understand user navigation paths accurately. Here's how you can implement this with the Matomo integration: + +```javascript +import React, { useEffect, useState } from 'react'; +import { useRouter } from 'next/router'; // or your specific routing library +import { getMatomoTracker } from '@consent-manager/integration-matomo'; + +const App = () => { + const router = useRouter(); // Hook from your routing library + const { trackPageViewSPA } = getMatomoTracker(); + const [prevLocation, setPrevLocation] = useState( + typeof window !== "undefined" ? window.location : undefined + ); + + useEffect(() => { + // Function to handle route changes + const handleRouteChange = () => { + const { location } = window; + + // Track the page view with current and previous locations + trackPageViewSPA && trackPageViewSPA({ location, prevLocation }); + + // Update the previous location + setPrevLocation(location); + }; + + // Set up a listener for route changes + router.events.on('routeChangeComplete', handleRouteChange); + + // Clean up the listener when the component unmounts + return () => { + router.events.off('routeChangeComplete', handleRouteChange); + }; + }, [prevLocation, router.events, trackPageViewSPA]); + + // Your app's rendering logic + return ( + // Your routes/components + ); +}; + +export default App; +``` + +#### Notes: +- The `useState` hook is used to keep track of the previous location. +- The `useEffect` hook sets up a listener on route changes and updates the tracking information accordingly. +- This approach provides more detailed analytics on how users navigate through your SPA. + +This enhanced guide ensures that your SPA's client-side routing and tracking accurately reflect user interactions. \ No newline at end of file diff --git a/packages/docs/docs/quick-start.md b/packages/docs/docs/quick-start.md new file mode 100644 index 00000000..2f5f320c --- /dev/null +++ b/packages/docs/docs/quick-start.md @@ -0,0 +1,174 @@ +--- +id: quick-start-guide +title: Quick Start Guide +--- +# Quick Start Guide + +Welcome to the Quick Start Guide for Consent Manager. This guide will help you swiftly integrate Consent Manager into your React project, aligning with GDPR requirements while enhancing user privacy. + +Let's dive in to understand how to install Consent Manager, set it up in your app, integrate a third-party service like Matomo, and track events efficiently. + +## Installation Instructions + +To start, you need to install Consent Manager along with its default interface. Run the following command in your project directory: + +```bash +npm install @consent-manager/core @consent-manager/interface-default use-persisted-state +``` + +## Setting Up Consent Manager in Your React App +Create a file named `consent-manager.js` in your project. This file will configure and export the `ConsentManagerWrapper` component. Add the following code to this file: + +```javascript +import React from 'react'; +import { ConsentManagerDefaultInterface } from '@consent-manager/interface-default'; +import '@consent-manager/interface-default/dist/default.min.css'; + +import createPersistedState from 'use-persisted-state'; + +// We store our consent information in localStorage +const useConsentStateStore = createPersistedState('consent-manager'); + +// Add your configuration here if necessary +const config = { + // ... your configuration options ... +}; + +export const ConsentManagerWrapper = ({ children }) => { + const storage = useConsentStateStore(); + + return ( + + {children} + + ); +}; +``` + +## Wrapping Your Application with Consent Manager +In your main `index.js` (or `layout.js`, depending on your project structure), import and use the `ConsentManagerWrapper` to wrap your application: + +```javascript +import React from 'react'; +import ReactDOM from 'react-dom'; +import App from './App'; +import { ConsentManagerWrapper } from './consent-manager'; + +ReactDOM.render( + + + , + document.getElementById('root') +); +``` + +Your application now includes Consent Manager, displaying the shield 🛡️ icon at the bottom left. Next, let's incorporate some integrations into your page, enabling users to provide their consent. + +## Integrating Matomo for Tracking Page Views and Events + +Matomo is a robust, open-source alternative to SAAS tracking solutions, offering full data control and GDPR-friendly implementation. + +### Installing Matomo Integration +First, add the [Matomo integration](./integrations/matomo.md) to your project: + +```bash +npm install @consent-manager/integration-matomo +``` + +### Configuring Matomo in Consent Manager +Update `consent-manager.js` to include Matomo in the integrations: + +```javascript +// Add this to your consent-manager.js imports +import { matomoIntegration } from '@consent-manager/integration-matomo'; + +// Update your configuration +const consentManagerConfig = { + integrations: [ + matomoIntegration({ + matomoURL: "https://statistics.yourdomain.com/", + siteID: "YOUR_SITE_ID", + }), + ], +}; + +// Include in ConsentManagerDefaultInterface + + {children} + +``` + +**Note:** For React Router or similar setups, see our [client-side routing documentation](./guides/client-side-routing.md) to ensure proper page view tracking. + +### Tracking Events with Matomo +All integrations, including Matomo, follow a similar interface for event tracking: + +```jsx +import { getMatomoTracker } from '@consent-manager/integration-matomo'; + +const SomeComponent = () => { + const { trackEvent } = getMatomoTracker(); + + const onTrack = useCallback(() => { + trackEvent('Example', 'Button', 'Pressed'); + }, [trackEvent]); + + return ; +}; +``` + +[Learn more about Matomo integration](./integrations/matomo.md). + +## Integrating Iframe Services like YouTube + +For embedding services like YouTube, obtain user consent before loading iframes that may share data with third-party services. + +### Installing YouTube Integration + +First, integrate [YouTube](./integrations/youtube.md) into your project. Note that in this demo we're using `react-youtube` for rendering, but it's not a mandatory requirement! + +```bash +npm install @consent-manager/integration-youtube react-youtube +``` + +### Configuring YouTube Integration + +Add YouTube to your integrations in `consent-manager.js`: + +```javascript +// Import YouTube integration +import { youtubeIntegration } from '@consent-manager/integration-youtube'; + +// Update your consent manager configuration +const consentManagerConfig = { + integrations: [ + // ... other integrations + youtubeIntegration(), + ], +}; + +// The rest of the file remains unchanged +``` + +### Wrapping YouTube Videos for Consent +Use the `PrivacyShield` component to wrap YouTube embeds: + +```javascript +import React from 'react'; +import ReactYouTube from 'react-youtube'; +import { PrivacyShield } from '@consent-manager/core'; + +const YouTube = ({ id, ...props }) => { + return ( + + + + ); +}; + +export default YouTube; +``` + +[Explore more about YouTube integration](./integrations/youtube.md). + +You now have the fundamental knowledge to integrate Consent Manager into your React application. For more detailed guides, please refer to the sidebar on the left. \ No newline at end of file diff --git a/packages/docs/sidebars.js b/packages/docs/sidebars.js index 7a91d5bc..40263ae2 100644 --- a/packages/docs/sidebars.js +++ b/packages/docs/sidebars.js @@ -1,6 +1,7 @@ module.exports = { someSidebar: { 'Consent Manager': ['about', 'quick-start-guide'], + Guides: ['guides/client-side-routing'], Components: ['provider'], Hooks: ['use-something'], Integrations: [