@segment/consent-manager
Version:
Drop-in consent management plugin for analytics.js
144 lines • 15.7 kB
JavaScript
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":"AAAA,OAAO,YAAY,MAAM,QAAQ,CAAA;AACjC,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,MAAM,MAAM,UAAU,CAAA;AAC7B,OAAO,gBAAgB,MAAM,qBAAqB,CAAA;AAClD,OAAO,YAAY,MAAM,iBAAiB,CAAA;AAC1C,OAAO,EAAE,sBAAsB,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAA;AAW5E,IAAM,OAAO,GAAG,IAAI,YAAY,EAAE,CAAA;AAClC,MAAM,UAAU,UAAU;IACxB,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;AAC5B,CAAC;AAsCD,SAAS,qBAAqB,CAAC,YAA2B;IACxD,IAAM,qBAAqB,GAAkB,EAAE,CAAA;IAC/C,IAAM,uBAAuB,GAAkB,EAAE,CAAA;IACjD,IAAM,sBAAsB,GAAkB,EAAE,CAAA;4BAErC,WAAW;QACpB,IAAI,sBAAsB,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,KAAK,WAAW,CAAC,QAAQ,EAA1B,CAA0B,CAAC,EAAE;YAChE,uBAAuB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;SAC1C;aAAM,IAAI,qBAAqB,CAAC,IAAI,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,KAAK,WAAW,CAAC,QAAQ,EAA1B,CAA0B,CAAC,EAAE;YACtE,sBAAsB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;SACzC;aAAM;YACL,wBAAwB;YACxB,qBAAqB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;SACxC;;IARH,KAA0B,UAAY,EAAZ,6BAAY,EAAZ,0BAAY,EAAZ,IAAY;QAAjC,IAAM,WAAW,qBAAA;gBAAX,WAAW;KASrB;IAED,OAAO,EAAE,qBAAqB,uBAAA,EAAE,uBAAuB,yBAAA,EAAE,sBAAsB,wBAAA,EAAE,CAAA;AACnF,CAAC;AAED,IAAM,SAAS,GAA6B,UAAA,KAAK;IACzC,IAAA,KAA+B,KAAK,CAAC,QAAQ,CACjD,KAAK,IAAI,CAAC,KAAK,CAAC,6BAA6B,IAAI,KAAK,CAAC,0BAA0B,KAAK,KAAK,CAAC,CAC7F,EAFM,YAAY,QAAA,EAAE,YAAY,QAEhC,CAAA;IACK,IAAA,KAA6B,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAhD,UAAU,QAAA,EAAE,YAAY,QAAwB,CAAA;IACjD,IAAA,KAA+B,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAnD,YAAY,QAAA,EAAE,YAAY,QAAyB,CAAA;IAE1D,IAAI,MAAM,GAAG,KAAK,CAAC,MAAM,CAAc,IAAI,CAAC,CAAA;IAC5C,IAAI,gBAAgB,GAAG,KAAK,CAAC,MAAM,CAAc,IAAI,CAAC,CAAA;IACtD,IAAI,YAAY,GAAG,KAAK,CAAC,MAAM,CAAc,IAAI,CAAC,CAAA;IAE5C,IAAA,KAIF,qBAAqB,CAAC,KAAK,CAAC,YAAY,CAAC,EAH3C,qBAAqB,2BAAA,EACrB,uBAAuB,6BAAA,EACvB,sBAAsB,4BACqB,CAAA;IAE7C,IAAM,WAAW,GAAG;QAClB,IAAM,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,UAAC,GAAG,EAAE,QAAQ;YAC1E,GAAG,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAA;YACpB,OAAO,GAAG,CAAA;QACZ,CAAC,EAAE,EAAE,CAAC,CAAA;QACN,KAAK,CAAC,cAAc,CAAC,eAAe,CAAC,CAAA;QACrC,OAAO,KAAK,CAAC,WAAW,EAAE,CAAA;IAC5B,CAAC,CAAA;IAED,IAAM,SAAS,GAAG;QAChB,IAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,UAAC,GAAG,EAAE,QAAQ;YAC3E,GAAG,CAAC,QAAQ,CAAC,GAAG,KAAK,CAAA;YACrB,OAAO,GAAG,CAAA;QACZ,CAAC,EAAE,EAAE,CAAC,CAAA;QAEN,KAAK,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAA;QACtC,OAAO,KAAK,CAAC,WAAW,EAAE,CAAA;IAC5B,CAAC,CAAA;IAED,IAAM,OAAO,GAAG;QACd,IAAI,KAAK,CAAC,aAAa,KAAK,SAAS,IAAI,KAAK,CAAC,aAAa,KAAK,SAAS,EAAE;YAC1E,OAAO,YAAY,CAAC,KAAK,CAAC,CAAA;SAC3B;QAED,IAAI,KAAK,CAAC,aAAa,KAAK,QAAQ,EAAE;YACpC,YAAY,CAAC,KAAK,CAAC,CAAA;YACnB,OAAO,WAAW,EAAE,CAAA;SACrB;QAED,IAAI,KAAK,CAAC,aAAa,KAAK,MAAM,EAAE;YAClC,YAAY,CAAC,KAAK,CAAC,CAAA;YACnB,OAAO,SAAS,EAAE,CAAA;SACnB;QAED,qCAAqC;QACrC,IAAM,sBAAsB,GAAG,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,CAAA;QACrE,KAAK,CAAC,cAAc,CAAC,sBAAsB,CAAC,CAAA;QAC5C,KAAK,CAAC,WAAW,EAAE,CAAA;QACnB,OAAO,YAAY,CAAC,KAAK,CAAC,CAAA;IAC5B,CAAC,CAAA;IAED,IAAM,UAAU,GAAG,cAAM,OAAA,YAAY,CAAC,IAAI,CAAC,EAAlB,CAAkB,CAAA;IAE3C,IAAM,eAAe,GAAG,UAAA,CAAC;QACvB,0DAA0D;QAC1D,IACE,CAAC,KAAK,CAAC,iBAAiB;YACxB,CAAC,KAAK,CAAC,yBAAyB;YAChC,KAAK,CAAC,eAAe,CAAC,MAAM,KAAK,CAAC,EAClC;YACA,OAAM;SACP;QAED,2DAA2D;QAC3D,IACE,CAAC,MAAM,CAAC,OAAO,IAAI,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YACrD,CAAC,gBAAgB,CAAC,OAAO,IAAI,gBAAgB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YACzE,CAAC,YAAY,CAAC,OAAO,IAAI,YAAY,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;YACjE,eAAe,KAAK,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/B;YACA,OAAM;SACP;QAED,0CAA0C;QAC1C,IAAI,CAAC,YAAY,IAAI,KAAK,CAAC,yBAAyB,EAAE;YACpD,WAAW,EAAE,CAAA;SACd;IACH,CAAC,CAAA;IAED,KAAK,CAAC,SAAS,CAAC;QACd,OAAO,CAAC,EAAE,CAAC,YAAY,EAAE,UAAU,CAAC,CAAA;QACpC,IAAI,KAAK,CAAC,iBAAiB,IAAI,KAAK,CAAC,yBAAyB,EAAE;YAC9D,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,eAAe,EAAE,KAAK,CAAC,CAAA;SAChE;QAED,OAAO;YACL,OAAO,CAAC,cAAc,CAAC,YAAY,EAAE,UAAU,CAAC,CAAA;YAChD,QAAQ,CAAC,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,eAAe,EAAE,KAAK,CAAC,CAAA;QACpE,CAAC,CAAA;IACH,CAAC,CAAC,CAAA;IAEF,KAAK,CAAC,SAAS,CAAC;QACd,IAAI,YAAY,EAAE;YAChB,KAAK,CAAC,gBAAgB,EAAE,CAAA;SACzB;IACH,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAA;IAElB,IAAM,oBAAoB,GAAG,UAAC,QAAgB,EAAE,KAAc;;QAC5D,KAAK,CAAC,cAAc;YAClB,GAAC,QAAQ,IAAG,KAAK;gBACjB,CAAA;IACJ,CAAC,CAAA;IAED,IAAM,UAAU,GAAG;QACjB,YAAY,CAAC,KAAK,CAAC,CAAA;QACnB,KAAK,CAAC,WAAW,CAAC,SAAS,EAAE,KAAK,CAAC,CAAA;IACrC,CAAC,CAAA;IAED,IAAM,YAAY,GAAG;QACnB,wEAAwE;QACxE,IAAI,KAAK,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;YACpC,YAAY,CAAC,IAAI,CAAC,CAAA;SACnB;aAAM;YACL,YAAY,CAAC,KAAK,CAAC,CAAA;YACnB,KAAK,CAAC,gBAAgB,EAAE,CAAA;SACzB;IACH,CAAC,CAAA;IAED,IAAM,gBAAgB,GAAG;QACvB,YAAY,CAAC,KAAK,CAAC,CAAA;IACrB,CAAC,CAAA;IAED,IAAM,mBAAmB,GAAG;QAC1B,YAAY,CAAC,KAAK,CAAC,CAAA;QACnB,YAAY,CAAC,KAAK,CAAC,CAAA;QACnB,KAAK,CAAC,gBAAgB,EAAE,CAAA;IAC1B,CAAC,CAAA;IAED,OAAO,CACL;QACG,UAAU,IAAI,KAAK,CAAC,iBAAiB,IAAI,KAAK,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,IAAI,CAC5E,oBAAC,MAAM,IACL,QAAQ,EAAE,UAAA,OAAO,IAAI,OAAA,CAAC,MAAM,GAAG,EAAE,OAAO,SAAA,EAAE,CAAC,EAAtB,CAAsB,EAC3C,OAAO,EAAE,OAAO,EAChB,mBAAmB,EAAE,cAAM,OAAA,YAAY,CAAC,IAAI,CAAC,EAAlB,CAAkB,EAC7C,OAAO,EAAE,KAAK,CAAC,aAAa,EAC5B,UAAU,EAAE,KAAK,CAAC,gBAAgB,EAClC,YAAY,EAAE,KAAK,CAAC,kBAAkB,EACtC,SAAS,EAAE,KAAK,CAAC,eAAe,EAChC,eAAe,EAAE,KAAK,CAAC,qBAAqB,EAC5C,WAAW,EAAE,WAAW,EACxB,SAAS,EAAE,SAAS,EACpB,eAAe,EAAE,KAAK,CAAC,qBAAqB,EAC5C,OAAO,EAAE,KAAK,CAAC,aAAa,GAC5B,CACH;QAEA,YAAY,IAAI,CACf,oBAAC,gBAAgB,IACf,gBAAgB,EAAE,KAAK,CAAC,gBAAgB,EACxC,YAAY,EAAE,KAAK,CAAC,YAAY,EAChC,WAAW,EAAE,KAAK,CAAC,WAAW,EAC9B,QAAQ,EAAE,UAAA,OAAO,IAAI,OAAA,CAAC,gBAAgB,GAAG,EAAE,OAAO,SAAA,EAAE,CAAC,EAAhC,CAAgC,EACrD,QAAQ,EAAE,YAAY,EACtB,MAAM,EAAE,UAAU,EAClB,QAAQ,EAAE,oBAAoB,EAC9B,qBAAqB,EAAE,qBAAqB,EAC5C,uBAAuB,EAAE,uBAAuB,EAChD,sBAAsB,EAAE,sBAAsB,EAC9C,qBAAqB,EAAE,KAAK,CAAC,WAAW,CAAC,qBAAqB,EAC9D,WAAW,EAAE,KAAK,CAAC,WAAW,CAAC,WAAW,EAC1C,UAAU,EAAE,KAAK,CAAC,WAAW,CAAC,UAAU,EACxC,KAAK,EAAE,KAAK,CAAC,sBAAsB,EACnC,OAAO,EAAE,KAAK,CAAC,wBAAwB,EACvC,yBAAyB,EAAE,KAAK,CAAC,yBAAyB,GAC1D,CACH;QAEA,YAAY,IAAI,CACf,oBAAC,YAAY,IACX,QAAQ,EAAE,UAAA,OAAO,IAAI,OAAA,CAAC,YAAY,GAAG,EAAE,OAAO,SAAA,EAAE,CAAC,EAA5B,CAA4B,EACjD,MAAM,EAAE,gBAAgB,EACxB,SAAS,EAAE,mBAAmB,EAC9B,KAAK,EAAE,KAAK,CAAC,iBAAiB,EAC9B,OAAO,EAAE,KAAK,CAAC,mBAAmB,EAClC,yBAAyB,EAAE,KAAK,CAAC,yBAAyB,GAC1D,CACH,CACA,CACJ,CAAA;AACH,CAAC,CAAA;AAED,eAAe,SAAS,CAAA"}