## Page View Tracking If you want to track which page/url in your webapp is the most frequently viewed one, you can use this feature. It will automatically send events containing url information when the page is visited. To turn it on: ```javascript Analytics.autoTrack('pageView', { // REQUIRED, turn on/off the auto tracking enable: true, // OPTIONAL, the event name, by default is 'pageView' eventName: 'pageView', // OPTIONAL, the attributes of the event, you can either pass an object or a function // which allows you to define dynamic attributes attributes: { attr: 'attr' }, // when using function // attributes: () => { // const attr = somewhere(); // return { // myAttr: attr // } // }, // OPTIONAL, by default is 'multiPageApp' // you need to change it to 'SPA' if your app is a single-page app like React type: 'multiPageApp', // OPTIONAL, the service provider, by default is the Amazon Pinpoint provider: 'AWSPinpoint', // OPTIONAL, to get the current page url getUrl: () => { // the default function return window.location.origin + window.location.pathname; } }); ``` ## Page Event Tracking If you want to track user interactions with elements on the page, you can use this feature. All you need to do is attach the specified selectors to your dom element and turn on the auto tracking. To turn it on: ```javascript Analytics.autoTrack('event', { // REQUIRED, turn on/off the auto tracking enable: true, // OPTIONAL, events you want to track, by default is 'click' events: ['click'], // OPTIONAL, the prefix of the selectors, by default is 'data-amplify-analytics-' // in order to avoid collision with the user agent, according to https://www.w3schools.com/tags/att_global_data.asp // always put 'data' as the first prefix selectorPrefix: 'data-amplify-analytics-', // OPTIONAL, the service provider, by default is the Amazon Pinpoint provider: 'AWSPinpoint', // OPTIONAL, the default attributes of the event, you can either pass an object or a function // which allows you to define dynamic attributes attributes: { attr: 'attr' } // when using function // attributes: () => { // const attr = somewhere(); // return { // myAttr: attr // } // } }); ``` For example: ```html