UNPKG

@segment/consent-manager

Version:

Drop-in consent management plugin for analytics.js

163 lines 25.4 kB
var __makeTemplateObject = (this && this.__makeTemplateObject) || function (cooked, raw) { if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } return cooked; }; var __extends = (this && this.__extends) || (function () { var extendStatics = function (d, b) { extendStatics = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; return extendStatics(d, b); }; return function (d, b) { extendStatics(d, b); function __() { this.constructor = d; } d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); }; })(); import React, { PureComponent } from 'react'; import styled from '@emotion/styled'; import { css } from '@emotion/react'; import Dialog from './dialog'; import { DefaultButton, GreenButton } from './buttons'; var hideOnMobile = css(templateObject_1 || (templateObject_1 = __makeTemplateObject(["\n @media (max-width: 600px) {\n display: none;\n }\n"], ["\n @media (max-width: 600px) {\n display: none;\n }\n"]))); var TableScroll = styled('div')(templateObject_2 || (templateObject_2 = __makeTemplateObject(["\n overflow-x: auto;\n margin-top: 16px;\n"], ["\n overflow-x: auto;\n margin-top: 16px;\n"]))); var Table = styled('table')(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n border-collapse: collapse;\n font-size: 12px;\n"], ["\n border-collapse: collapse;\n font-size: 12px;\n"]))); var ColumnHeading = styled('th')(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n background: #f7f8fa;\n color: #1f4160;\n font-weight: 600;\n text-align: left;\n border-width: 2px;\n"], ["\n background: #f7f8fa;\n color: #1f4160;\n font-weight: 600;\n text-align: left;\n border-width: 2px;\n"]))); var RowHeading = styled('th')(templateObject_5 || (templateObject_5 = __makeTemplateObject(["\n font-weight: normal;\n text-align: left;\n"], ["\n font-weight: normal;\n text-align: left;\n"]))); var Row = styled('tr')(templateObject_6 || (templateObject_6 = __makeTemplateObject(["\n th,\n td {\n vertical-align: top;\n padding: 8px 12px;\n border: 1px solid rgba(67, 90, 111, 0.114);\n }\n td {\n border-top: none;\n }\n"], ["\n th,\n td {\n vertical-align: top;\n padding: 8px 12px;\n border: 1px solid rgba(67, 90, 111, 0.114);\n }\n td {\n border-top: none;\n }\n"]))); var InputCell = styled('td')(templateObject_7 || (templateObject_7 = __makeTemplateObject(["\n input {\n vertical-align: middle;\n }\n label {\n display: block;\n margin-bottom: 4px;\n white-space: nowrap;\n }\n td {\n border: none;\n vertical-align: middle;\n }\n"], ["\n input {\n vertical-align: middle;\n }\n label {\n display: block;\n margin-bottom: 4px;\n white-space: nowrap;\n }\n td {\n border: none;\n vertical-align: middle;\n }\n"]))); var PreferenceDialog = /** @class */ (function (_super) { __extends(PreferenceDialog, _super); function PreferenceDialog() { var _this = _super !== null && _super.apply(this, arguments) || this; _this.handleChange = function (e) { var onChange = _this.props.onChange; onChange(e.target.name, e.target.value === 'true'); }; _this.handleSubmit = function (e) { var _a = _this.props, onSave = _a.onSave, preferences = _a.preferences, marketingAndAnalytics = _a.marketingAndAnalytics, advertising = _a.advertising, functional = _a.functional, customCategories = _a.customCategories; e.preventDefault(); // Safe guard against browsers that don't prevent the // submission of invalid forms (Safari < 10.1) if (!customCategories && (marketingAndAnalytics === null || advertising === null || functional === null)) { return; } // Safe guard against custom categories being null if (customCategories && Object.keys(customCategories).some(function (category) { return preferences[category] === null; })) { return; } onSave(); }; return _this; } PreferenceDialog.prototype.render = function () { var _this = this; var _a = this.props, innerRef = _a.innerRef, onCancel = _a.onCancel, marketingDestinations = _a.marketingDestinations, advertisingDestinations = _a.advertisingDestinations, functionalDestinations = _a.functionalDestinations, marketingAndAnalytics = _a.marketingAndAnalytics, advertising = _a.advertising, functional = _a.functional, customCategories = _a.customCategories, destinations = _a.destinations, title = _a.title, content = _a.content, preferences = _a.preferences, preferencesDialogTemplate = _a.preferencesDialogTemplate; var _b = preferencesDialogTemplate, headings = _b.headings, checkboxes = _b.checkboxes, actionButtons = _b.actionButtons; var functionalInfo = preferencesDialogTemplate === null || preferencesDialogTemplate === void 0 ? void 0 : preferencesDialogTemplate.categories.find(function (c) { return c.key === 'functional'; }); var marketingInfo = preferencesDialogTemplate === null || preferencesDialogTemplate === void 0 ? void 0 : preferencesDialogTemplate.categories.find(function (c) { return c.key === 'marketing'; }); var advertisingInfo = preferencesDialogTemplate === null || preferencesDialogTemplate === void 0 ? void 0 : preferencesDialogTemplate.categories.find(function (c) { return c.key === 'advertising'; }); var essentialInfo = preferencesDialogTemplate === null || preferencesDialogTemplate === void 0 ? void 0 : preferencesDialogTemplate.categories.find(function (c) { return c.key === 'essential'; }); var buttons = (React.createElement("div", null, React.createElement(DefaultButton, { type: "button", onClick: onCancel }, actionButtons.cancelValue), React.createElement(GreenButton, { type: "submit" }, actionButtons.saveValue))); return (React.createElement(Dialog, { innerRef: innerRef, title: title, buttons: buttons, onCancel: onCancel, onSubmit: this.handleSubmit }, content, React.createElement(TableScroll, null, React.createElement(Table, null, React.createElement("thead", null, React.createElement(Row, null, React.createElement(ColumnHeading, { scope: "col" }, headings.allowValue), React.createElement(ColumnHeading, { scope: "col" }, headings.categoryValue), React.createElement(ColumnHeading, { scope: "col" }, headings.purposeValue), React.createElement(ColumnHeading, { scope: "col", css: hideOnMobile }, headings.toolsValue))), React.createElement("tbody", null, !customCategories && (React.createElement(React.Fragment, null, React.createElement(Row, null, React.createElement(InputCell, null, React.createElement("label", null, React.createElement("input", { type: "radio", name: "functional", value: "true", checked: functional === true, onChange: this.handleChange, "aria-label": "Allow functional tracking", required: true }), ' ', checkboxes.yesValue), React.createElement("label", null, React.createElement("input", { type: "radio", name: "functional", value: "false", checked: functional === false, onChange: this.handleChange, "aria-label": "Disallow functional tracking", required: true }), ' ', checkboxes.noValue)), React.createElement(RowHeading, { scope: "row" }, functionalInfo === null || functionalInfo === void 0 ? void 0 : functionalInfo.name), React.createElement("td", null, React.createElement("p", null, functionalInfo === null || functionalInfo === void 0 ? void 0 : functionalInfo.description), React.createElement("p", { css: hideOnMobile }, functionalInfo === null || functionalInfo === void 0 ? void 0 : functionalInfo.example)), React.createElement("td", { css: hideOnMobile }, functionalDestinations.map(function (d) { return d.name; }).join(', '))), React.createElement(Row, null, React.createElement(InputCell, null, React.createElement("label", null, React.createElement("input", { type: "radio", name: "marketingAndAnalytics", value: "true", checked: marketingAndAnalytics === true, onChange: this.handleChange, "aria-label": "Allow marketing and analytics tracking", required: true }), ' ', checkboxes.yesValue), React.createElement("label", null, React.createElement("input", { type: "radio", name: "marketingAndAnalytics", value: "false", checked: marketingAndAnalytics === false, onChange: this.handleChange, "aria-label": "Disallow marketing and analytics tracking", required: true }), ' ', checkboxes.noValue)), React.createElement(RowHeading, { scope: "row" }, marketingInfo === null || marketingInfo === void 0 ? void 0 : marketingInfo.name), React.createElement("td", null, React.createElement("p", null, marketingInfo === null || marketingInfo === void 0 ? void 0 : marketingInfo.description), React.createElement("p", { css: hideOnMobile }, marketingInfo === null || marketingInfo === void 0 ? void 0 : marketingInfo.example)), React.createElement("td", { css: hideOnMobile }, marketingDestinations.map(function (d) { return d.name; }).join(', '))), React.createElement(Row, null, React.createElement(InputCell, null, React.createElement("label", null, React.createElement("input", { type: "radio", name: "advertising", value: "true", checked: advertising === true, onChange: this.handleChange, "aria-label": "Allow advertising tracking", required: true }), ' ', checkboxes.yesValue), React.createElement("label", null, React.createElement("input", { type: "radio", name: "advertising", value: "false", checked: advertising === false, onChange: this.handleChange, "aria-label": "Disallow advertising tracking", required: true }), ' ', checkboxes.noValue)), React.createElement(RowHeading, { scope: "row" }, advertisingInfo === null || advertisingInfo === void 0 ? void 0 : advertisingInfo.name), React.createElement("td", null, React.createElement("p", null, advertisingInfo === null || advertisingInfo === void 0 ? void 0 : advertisingInfo.description), React.createElement("p", { css: hideOnMobile }, advertisingInfo === null || advertisingInfo === void 0 ? void 0 : advertisingInfo.example)), React.createElement("td", { css: hideOnMobile }, advertisingDestinations.map(function (d) { return d.name; }).join(', '))), React.createElement(Row, null, React.createElement("td", null, "N/A"), React.createElement(RowHeading, { scope: "row" }, essentialInfo === null || essentialInfo === void 0 ? void 0 : essentialInfo.name), React.createElement("td", null, React.createElement("p", null, essentialInfo === null || essentialInfo === void 0 ? void 0 : essentialInfo.description), React.createElement("p", null, essentialInfo === null || essentialInfo === void 0 ? void 0 : essentialInfo.example)), React.createElement("td", { css: hideOnMobile })))), customCategories && Object.entries(customCategories).map(function (_a) { var categoryName = _a[0], _b = _a[1], integrations = _b.integrations, purpose = _b.purpose; return (React.createElement(Row, { key: categoryName }, React.createElement(InputCell, null, preferences[categoryName] === 'N/A' ? (React.createElement("td", null, "N/A")) : (React.createElement(React.Fragment, null, React.createElement("label", null, React.createElement("input", { type: "radio", name: categoryName, value: "true", checked: preferences[categoryName] === true, onChange: _this.handleChange, "aria-label": "Allow \"" + categoryName + "\" tracking", required: true }), ' ', checkboxes.yesValue), React.createElement("label", null, React.createElement("input", { type: "radio", name: categoryName, value: "false", checked: preferences[categoryName] === false, onChange: _this.handleChange, "aria-label": "Disallow \"" + categoryName + "\" tracking", required: true }), ' ', checkboxes.noValue)))), React.createElement(RowHeading, { scope: "row" }, categoryName), React.createElement("td", null, React.createElement("p", null, purpose)), React.createElement("td", { css: hideOnMobile }, destinations .filter(function (d) { return integrations.includes(d.id); }) .map(function (d) { return d.name; }) .join(', ')))); })))))); }; PreferenceDialog.displayName = 'PreferenceDialog'; PreferenceDialog.defaultProps = { marketingAndAnalytics: null, advertising: null, functional: null }; return PreferenceDialog; }(PureComponent)); export default PreferenceDialog; var templateObject_1, templateObject_2, templateObject_3, templateObject_4, templateObject_5, templateObject_6, templateObject_7; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preference-dialog.js","sourceRoot":"","sources":["../../src/consent-manager/preference-dialog.tsx"],"names":[],"mappings":"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"}