UNPKG

@segment/consent-manager

Version:

Drop-in consent management plugin for analytics.js

144 lines 15.7 kB
import EventEmitter from 'events'; import React from 'react'; import Banner from './banner'; import PreferenceDialog from './preference-dialog'; import CancelDialog from './cancel-dialog'; import { ADVERTISING_CATEGORIES, FUNCTIONAL_CATEGORIES } from './categories'; var emitter = new EventEmitter(); export function openDialog() { emitter.emit('openDialog'); } function normalizeDestinations(destinations) { var marketingDestinations = []; var advertisingDestinations = []; var functionalDestinations = []; var _loop_1 = function (destination) { if (ADVERTISING_CATEGORIES.find(function (c) { return c === destination.category; })) { advertisingDestinations.push(destination); } else if (FUNCTIONAL_CATEGORIES.find(function (c) { return c === destination.category; })) { functionalDestinations.push(destination); } else { // Fallback to marketing marketingDestinations.push(destination); } }; for (var _i = 0, destinations_1 = destinations; _i < destinations_1.length; _i++) { var destination = destinations_1[_i]; _loop_1(destination); } return { marketingDestinations: marketingDestinations, advertisingDestinations: advertisingDestinations, functionalDestinations: functionalDestinations }; } var Container = function (props) { var _a = React.useState(false || (props.workspaceAddedNewDestinations && props.defaultDestinationBehavior === 'ask')), isDialogOpen = _a[0], toggleDialog = _a[1]; var _b = React.useState(true), showBanner = _b[0], toggleBanner = _b[1]; var _c = React.useState(false), isCancelling = _c[0], toggleCancel = _c[1]; var banner = React.useRef(null); var preferenceDialog = React.useRef(null); var cancelDialog = React.useRef(null); var _d = normalizeDestinations(props.destinations), marketingDestinations = _d.marketingDestinations, advertisingDestinations = _d.advertisingDestinations, functionalDestinations = _d.functionalDestinations; var onAcceptAll = function () { var truePreferences = Object.keys(props.preferences).reduce(function (acc, category) { acc[category] = true; return acc; }, {}); props.setPreferences(truePreferences); return props.saveConsent(); }; var onDenyAll = function () { var falsePreferences = Object.keys(props.preferences).reduce(function (acc, category) { acc[category] = false; return acc; }, {}); props.setPreferences(falsePreferences); return props.saveConsent(); }; var onClose = function () { if (props.closeBehavior === undefined || props.closeBehavior === 'dismiss') { return toggleBanner(false); } if (props.closeBehavior === 'accept') { toggleBanner(false); return onAcceptAll(); } if (props.closeBehavior === 'deny') { toggleBanner(false); return onDenyAll(); } // closeBehavior is a custom function var customClosePreferences = props.closeBehavior(props.preferences); props.setPreferences(customClosePreferences); props.saveConsent(); return toggleBanner(false); }; var showDialog = function () { return toggleDialog(true); }; var handleBodyClick = function (e) { // Do nothing if no new implicit consent needs to be saved if (!props.isConsentRequired || !props.implyConsentOnInteraction || props.newDestinations.length === 0) { return; } // Ignore propogated clicks from inside the consent manager if ((banner.current && banner.current.contains(e.target)) || (preferenceDialog.current && preferenceDialog.current.contains(e.target)) || (cancelDialog.current && cancelDialog.current.contains(e.target)) || 'subContentBtn' === e.target.id) { return; } // Accept all consent on page interaction. if (!isDialogOpen && props.implyConsentOnInteraction) { onAcceptAll(); } }; React.useEffect(function () { emitter.on('openDialog', showDialog); if (props.isConsentRequired && props.implyConsentOnInteraction) { document.body.addEventListener('click', handleBodyClick, false); } return function () { emitter.removeListener('openDialog', showDialog); document.body.removeEventListener('click', handleBodyClick, false); }; }); React.useEffect(function () { if (isDialogOpen) { props.resetPreferences(); } }, [isDialogOpen]); var handleCategoryChange = function (category, value) { var _a; props.setPreferences((_a = {}, _a[category] = value, _a)); }; var handleSave = function () { toggleDialog(false); props.saveConsent(undefined, false); }; var handleCancel = function () { // Only show the cancel confirmation if there's unconsented destinations if (props.newDestinations.length > 0) { toggleCancel(true); } else { toggleDialog(false); props.resetPreferences(); } }; var handleCancelBack = function () { toggleCancel(false); }; var handleCancelConfirm = function () { toggleCancel(false); toggleDialog(false); props.resetPreferences(); }; return (React.createElement(React.Fragment, null, showBanner && props.isConsentRequired && props.newDestinations.length > 0 && (React.createElement(Banner, { innerRef: function (current) { return (banner = { current: current }); }, onClose: onClose, onChangePreferences: function () { return toggleDialog(true); }, content: props.bannerContent, subContent: props.bannerSubContent, actionsBlock: props.bannerActionsBlock, textColor: props.bannerTextColor, backgroundColor: props.bannerBackgroundColor, onAcceptAll: onAcceptAll, onDenyAll: onDenyAll, hideCloseButton: props.bannerHideCloseButton, asModal: props.bannerAsModal })), isDialogOpen && (React.createElement(PreferenceDialog, { customCategories: props.customCategories, destinations: props.destinations, preferences: props.preferences, innerRef: function (current) { return (preferenceDialog = { current: current }); }, onCancel: handleCancel, onSave: handleSave, onChange: handleCategoryChange, marketingDestinations: marketingDestinations, advertisingDestinations: advertisingDestinations, functionalDestinations: functionalDestinations, marketingAndAnalytics: props.preferences.marketingAndAnalytics, advertising: props.preferences.advertising, functional: props.preferences.functional, title: props.preferencesDialogTitle, content: props.preferencesDialogContent, preferencesDialogTemplate: props.preferencesDialogTemplate })), isCancelling && (React.createElement(CancelDialog, { innerRef: function (current) { return (cancelDialog = { current: current }); }, onBack: handleCancelBack, onConfirm: handleCancelConfirm, title: props.cancelDialogTitle, content: props.cancelDialogContent, preferencesDialogTemplate: props.preferencesDialogTemplate })))); }; export default Container; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container.js","sourceRoot":"","sources":["../../src/consent-manager/container.tsx"],"names":[],"mappings":"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"}