/* harmony export */ __webpack_require__.d(__webpack_exports__, { /* harmony export */ "Z": () => (__WEBPACK_DEFAULT_EXPORT__) /* harmony export */ }); /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7294); /* harmony import */ var react_proptype_conditional_require__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(6494); /* harmony import */ var uuid__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(8721); /* harmony import */ var lodash_isequal__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(9886); /* harmony import */ var lodash_isequal__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(lodash_isequal__WEBPACK_IMPORTED_MODULE_2__); /* harmony import */ var _PSSnippet__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(366); /* harmony import */ var _PSSnippet__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_PSSnippet__WEBPACK_IMPORTED_MODULE_3__); function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); } function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } /* global _ps */ var PSClickWrap = /*#__PURE__*/function (_React$Component) { _inheritsLoose(PSClickWrap, _React$Component); function PSClickWrap(props) { var _this; _this = _React$Component.call(this, props) || this; _defineProperty(_assertThisInitialized(_this), "_isMounted", false); _this.createClickWrap = _this.createClickWrap.bind(_assertThisInitialized(_this)); _this.state = { clickwrapGroupKey: null, dynamicGroup: false }; _this.propsEventMap = { onAll: 'all', onSent: 'sent', onRetrieved: 'retrieved', onSet: 'set', onSetSignerId: 'set:signer_id', onValid: 'valid', onInvalid: 'invalid', onChecked: 'checked', onUnchecked: 'unchecked', onRendered: 'rendered', onDisplayed: 'displayed', onScrolledContract: 'scrolled:contract', onScrolled: 'scrolled', onError: 'error' }; var _this$props = _this.props, accessId = _this$props.accessId, backupScriptURL = _this$props.backupScriptURL, debug = _this$props.debug, disableSending = _this$props.disableSending, dynamic = _this$props.dynamic, injectSnippetOnly = _this$props.injectSnippetOnly, oversized = _this$props.oversized, psScriptUrl = _this$props.psScriptUrl, signerId = _this$props.signerId, testMode = _this$props.testMode; if (!_PSSnippet__WEBPACK_IMPORTED_MODULE_3___default().isSnippetLoaded(psScriptUrl, backupScriptURL)) { _PSSnippet__WEBPACK_IMPORTED_MODULE_3___default().injectSnippet(psScriptUrl, backupScriptURL); } if (debug) { _ps.debug = true; } if (injectSnippetOnly) return _assertThisInitialized(_this); _ps('create', accessId, { test_mode: testMode, disable_sending: disableSending, dynamic: dynamic, signer_id: signerId, oversized: oversized }); _ps('set', 'client_library', 'react-sdk'); _ps('set', 'client_version', "2.15.0"); return _this; } var _proto = PSClickWrap.prototype; _proto.componentDidMount = function componentDidMount() { var injectSnippetOnly = this.props.injectSnippetOnly; this._isMounted = true; if (injectSnippetOnly) return; this.createClickWrap(); }; _proto.componentDidUpdate = function componentDidUpdate(prevProps) { var _this$props2 = this.props, acceptanceLanguage = _this$props2.acceptanceLanguage, clickWrapStyle = _this$props2.clickWrapStyle, customData = _this$props2.customData, filter = _this$props2.filter, groupKey = _this$props2.groupKey, injectSnippetOnly = _this$props2.injectSnippetOnly, renderData = _this$props2.renderData, signerId = _this$props2.signerId, snapshotLocation = _this$props2.snapshotLocation; var _this$state = this.state, clickwrapGroupKey = _this$state.clickwrapGroupKey, dynamicGroup = _this$state.dynamicGroup; var _psLoadedValidGroup = _ps && _ps.getByKey && typeof _ps.getByKey === 'function' && clickwrapGroupKey && _ps.getByKey(clickwrapGroupKey); if (injectSnippetOnly) return; if (clickWrapStyle !== prevProps.clickWrapStyle && !dynamicGroup && _psLoadedValidGroup) { _ps.getByKey(clickwrapGroupKey).site.set('style', clickWrapStyle); _ps.getByKey(clickwrapGroupKey).retrieveHTML(); } if (!lodash_isequal__WEBPACK_IMPORTED_MODULE_2___default()(customData, prevProps.customData)) { _ps('set', 'custom_data', customData); } if (acceptanceLanguage !== prevProps.acceptanceLanguage) { _ps('set', 'acceptance_language', acceptanceLanguage); } if (!lodash_isequal__WEBPACK_IMPORTED_MODULE_2___default()(renderData, prevProps.renderData)) { if (clickWrapStyle && _psLoadedValidGroup) { _ps.getByKey(clickwrapGroupKey).site.set('style', clickWrapStyle); } _ps(clickwrapGroupKey + ":retrieveHTML", renderData); } if (signerId !== prevProps.signerId) { if (clickWrapStyle && _psLoadedValidGroup) { _ps.getByKey(clickwrapGroupKey).site.set('style', clickWrapStyle); } _ps('set', 'signer_id', signerId); } if (snapshotLocation !== prevProps.snapshotLocation) { _ps('set', 'snapshot_location', snapshotLocation); } if (clickWrapStyle !== prevProps.clickWrapStyle && dynamicGroup) { this.createClickWrap(); } if (filter !== prevProps.filter) { this.createClickWrap(); } if (groupKey !== prevProps.groupKey && !dynamicGroup) { this.createClickWrap(); if (_psLoadedValidGroup) _ps.getByKey(clickwrapGroupKey).retrieveHTML(); } }; _proto.componentWillUnmount = function componentWillUnmount() { this._isMounted = false; var _this$props3 = this.props, injectSnippetOnly = _this$props3.injectSnippetOnly, groupKey = _this$props3.groupKey; if (injectSnippetOnly) return; if (_ps && _ps.getByKey && typeof _ps.getByKey === 'function' && _ps.getByKey(groupKey)) { if (_ps.getByKey(groupKey).rendered) { _ps.getByKey(groupKey).rendered = false; } _ps.getByKey(groupKey).resetData(); } this.unregisterEventListeners(); }; _proto.registerEventListener = function registerEventListener(eventProp, groupKey) { var _this2 = this; var eventCallbackFn = function eventCallbackFn() { var shouldFireListener = false; for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } args.forEach(function (arg) { // We need to check the context variable and see if it matches the groupKey, if it does -> fire the event (context argument position varies) if (arg && arg.get && arg.get('key') && arg.get('key') === groupKey) { shouldFireListener = true; // Else we should check if the context is for the entire site, and as such the context variable is a Site object. } else if (arg && arg.toString() === '[object Site]') { shouldFireListener = true; } }); if (shouldFireListener) { var _this2$props; (_this2$props = _this2.props)[eventProp].apply(_this2$props, args); } }; // In order to handle unregistration of event listeners, we override the toString function to identify the // function by a UUID rather than the default toString of a function. var newEventListenerID = (0,uuid__WEBPACK_IMPORTED_MODULE_4__/* ["default"] */ .Z)(); eventCallbackFn.toString = function () { return newEventListenerID; }; _ps.on(this.propsEventMap[eventProp], eventCallbackFn); return eventCallbackFn.toString(); }; _proto.registerEventListeners = function registerEventListeners(groupKey) { var _this3 = this; var eventListeners = {}; Object.keys(this.propsEventMap).forEach(function (eventProp) { if (_this3.props[eventProp]) { eventListeners[_this3.propsEventMap[eventProp]] = _this3.registerEventListener(eventProp, groupKey); } }); // Store event listeners in state so we can unregister them later on unmount if (this._isMounted) { this.setState({ eventListeners: eventListeners }); } }; _proto.unregisterEventListeners = function unregisterEventListeners() { var _this4 = this; if (this.state.eventListeners) { Object.keys(this.state.eventListeners).forEach(function (event) { var eventUUID = _this4.state.eventListeners[event]; // In order to unregister the event, we must create a fake function (typeof passed to _ps.off must be a function), // that returns the UUID we want to unregister. var fakeEventListener = function fakeEventListener() { return eventUUID; }; fakeEventListener.toString = function () { return eventUUID; }; _ps.off(event, fakeEventListener); }); } }; _proto.createClickWrap = function createClickWrap() { var _this5 = this; var _this$props4 = this.props, acceptanceLanguage = _this$props4.acceptanceLanguage, clickWrapStyle = _this$props4.clickWrapStyle, customData = _this$props4.customData, confirmationEmail = _this$props4.confirmationEmail, confirmationEmailSubject = _this$props4.confirmationEmailSubject, containerId = _this$props4.containerId, displayAll = _this$props4.displayAll, displayImmediately = _this$props4.displayImmediately, filter = _this$props4.filter, forceScroll = _this$props4.forceScroll, groupKey = _this$props4.groupKey, injectSnippetOnly = _this$props4.injectSnippetOnly, renderData = _this$props4.renderData, signerIdSelector = _this$props4.signerIdSelector, snapshotLocation = _this$props4.snapshotLocation, allowDisagreed = _this$props4.allowDisagreed; var options = _extends({}, allowDisagreed !== undefined && { allow_disagreed: allowDisagreed }, acceptanceLanguage !== undefined && { acceptance_language: acceptanceLanguage }, { auto_run: displayImmediately }, confirmationEmail !== undefined && { confirmation_email: confirmationEmail }, confirmationEmailSubject !== undefined && { confirmation_email_subject: confirmationEmailSubject }, { container_selector: containerId, display_all: displayAll }, filter !== undefined && { filter: filter }, forceScroll !== undefined && { force_scroll: forceScroll }, renderData !== undefined && { render_data: renderData }, signerIdSelector !== undefined && { signer_id_selector: signerIdSelector }, clickWrapStyle !== undefined && { style: clickWrapStyle }); if (injectSnippetOnly) return; if (groupKey && this._isMounted) { this.setState({ clickwrapGroupKey: groupKey, dynamicGroup: false }); } var isDynamic = !groupKey; var eventCallback = function eventCallback(err, group) { if (group) { var key = groupKey || group.get('key'); var state = { clickwrapGroupKey: key }; if (isDynamic) state.dynamicGroup = true; if (_this5._isMounted) { _this5.setState(state); } if (!isDynamic) group.render(); _this5.registerEventListeners(key); } }; if (customData) { _ps('set', 'custom_data', customData); } if (snapshotLocation) { _ps('set', 'snapshot_location', snapshotLocation); } if (groupKey) { _ps('load', groupKey, _extends({}, options, { event_callback: eventCallback })); } else _ps('load', _extends({}, options, { event_callback: eventCallback })); }; _proto.render = function render() { var containerId = this.props.containerId; return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("div", { id: containerId }); }; return PSClickWrap; }(react__WEBPACK_IMPORTED_MODULE_0__.Component); PSClickWrap.FILTER_OR_GROUPKEY_REQUIRED_ERROR_MESSAGE = 'PSClickWrap Error: You must provide either a groupKey or filter prop in order to use the PactSafe ClickWrap component!'; PSClickWrap.MUST_PROVIDE_RENDER_DATA_ERROR_MESSAGE = 'PSClickWrap Error: You must provide a renderData prop when passing down the dynamic prop'; PSClickWrap.MUST_PROVIDE_SIGNER_ID_OR_SIGNER_ID_SELECTOR = 'PSClickWrap Error: You must provide either a signer ID or a signer ID selector'; PSClickWrap.MUST_SET_ALLOW_DISAGREED = 'PSClickWrap Error: You must set allowDisagreed as true to make onInvalid work'; PSClickWrap.propTypes = false ? 0 : {}; PSClickWrap.defaultProps = { psScriptUrl: '//vault.pactsafe.io/ps.min.js', backupScriptURL: '//d3l1mqnl5xpsuc.cloudfront.net/ps.min.js', containerId: 'ps-clickwrap', displayImmediately: true, disableSending: false, displayAll: true, dynamic: false, testMode: false, oversized: false }; /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (PSClickWrap);//# sourceURL=[module] //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"3744.js","mappings":";;;;;;;;;;AAAA,sBAAsB,sEAAsE,gBAAgB,sBAAsB,OAAO,2BAA2B,0BAA0B,yDAAyD,iCAAiC,kBAAkB;AAC1S,wCAAwC,uBAAuB,yFAAyF;AACxJ,gDAAgD,0DAA0D,2CAA2C;AACrJ,iCAAiC,0GAA0G,iBAAiB,aAAa;AACzK,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,+DAA+D,sCAAsC,0BAA0B,+CAA+C,yCAAyC,uEAAuE;AACnU;AAC0B;AACS;AAC2B;AAC1B;AACC;AACD;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,iEAAyB;AAClC,MAAM,+DAAuB;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,qDAAO;AAChB;AACA;AACA;AACA;AACA;AACA,SAAS,qDAAO;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0EAA0E,aAAa;AACvF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,yDAAM;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B;AAC7B;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC;AACvC;AACA,OAAO;AACP,MAAM,4BAA4B;AAClC;AACA,KAAK;AACL;AACA;AACA;AACA,wBAAwB,gDAAmB;AAC3C;AACA,KAAK;AACL;AACA;AACA,CAAC,CAAC,4CAAe;AACjB;AACA;AACA;AACA;AACA,wBAAwB,MAAqC,GAAG,CAsD/D,CAAC;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iEAAe,WAAW","sources":["webpack://mtgavaformreact/./node_modules/@pactsafe/pactsafe-react-sdk/es/PSClickWrap.js?ae8b"],"sourcesContent":["function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (typeof input !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (typeof res !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\n/* global _ps */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport isRequiredIf from 'react-proptype-conditional-require';\nimport { v4 as uuidv4 } from 'uuid';\nimport isEqual from 'lodash.isequal';\nimport PSSnippet from './PSSnippet';\nvar PSClickWrap = /*#__PURE__*/function (_React$Component) {\n  _inheritsLoose(PSClickWrap, _React$Component);\n  function PSClickWrap(props) {\n    var _this;\n    _this = _React$Component.call(this, props) || this;\n    _defineProperty(_assertThisInitialized(_this), \"_isMounted\", false);\n    _this.createClickWrap = _this.createClickWrap.bind(_assertThisInitialized(_this));\n    _this.state = {\n      clickwrapGroupKey: null,\n      dynamicGroup: false\n    };\n    _this.propsEventMap = {\n      onAll: 'all',\n      onSent: 'sent',\n      onRetrieved: 'retrieved',\n      onSet: 'set',\n      onSetSignerId: 'set:signer_id',\n      onValid: 'valid',\n      onInvalid: 'invalid',\n      onChecked: 'checked',\n      onUnchecked: 'unchecked',\n      onRendered: 'rendered',\n      onDisplayed: 'displayed',\n      onScrolledContract: 'scrolled:contract',\n      onScrolled: 'scrolled',\n      onError: 'error'\n    };\n    var _this$props = _this.props,\n      accessId = _this$props.accessId,\n      backupScriptURL = _this$props.backupScriptURL,\n      debug = _this$props.debug,\n      disableSending = _this$props.disableSending,\n      dynamic = _this$props.dynamic,\n      injectSnippetOnly = _this$props.injectSnippetOnly,\n      oversized = _this$props.oversized,\n      psScriptUrl = _this$props.psScriptUrl,\n      signerId = _this$props.signerId,\n      testMode = _this$props.testMode;\n    if (!PSSnippet.isSnippetLoaded(psScriptUrl, backupScriptURL)) {\n      PSSnippet.injectSnippet(psScriptUrl, backupScriptURL);\n    }\n    if (debug) {\n      _ps.debug = true;\n    }\n    if (injectSnippetOnly) return _assertThisInitialized(_this);\n    _ps('create', accessId, {\n      test_mode: testMode,\n      disable_sending: disableSending,\n      dynamic: dynamic,\n      signer_id: signerId,\n      oversized: oversized\n    });\n    _ps('set', 'client_library', 'react-sdk');\n    _ps('set', 'client_version', \"2.15.0\");\n    return _this;\n  }\n  var _proto = PSClickWrap.prototype;\n  _proto.componentDidMount = function componentDidMount() {\n    var injectSnippetOnly = this.props.injectSnippetOnly;\n    this._isMounted = true;\n    if (injectSnippetOnly) return;\n    this.createClickWrap();\n  };\n  _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n    var _this$props2 = this.props,\n      acceptanceLanguage = _this$props2.acceptanceLanguage,\n      clickWrapStyle = _this$props2.clickWrapStyle,\n      customData = _this$props2.customData,\n      filter = _this$props2.filter,\n      groupKey = _this$props2.groupKey,\n      injectSnippetOnly = _this$props2.injectSnippetOnly,\n      renderData = _this$props2.renderData,\n      signerId = _this$props2.signerId,\n      snapshotLocation = _this$props2.snapshotLocation;\n    var _this$state = this.state,\n      clickwrapGroupKey = _this$state.clickwrapGroupKey,\n      dynamicGroup = _this$state.dynamicGroup;\n    var _psLoadedValidGroup = _ps && _ps.getByKey && typeof _ps.getByKey === 'function' && clickwrapGroupKey && _ps.getByKey(clickwrapGroupKey);\n    if (injectSnippetOnly) return;\n    if (clickWrapStyle !== prevProps.clickWrapStyle && !dynamicGroup && _psLoadedValidGroup) {\n      _ps.getByKey(clickwrapGroupKey).site.set('style', clickWrapStyle);\n      _ps.getByKey(clickwrapGroupKey).retrieveHTML();\n    }\n    if (!isEqual(customData, prevProps.customData)) {\n      _ps('set', 'custom_data', customData);\n    }\n    if (acceptanceLanguage !== prevProps.acceptanceLanguage) {\n      _ps('set', 'acceptance_language', acceptanceLanguage);\n    }\n    if (!isEqual(renderData, prevProps.renderData)) {\n      if (clickWrapStyle && _psLoadedValidGroup) {\n        _ps.getByKey(clickwrapGroupKey).site.set('style', clickWrapStyle);\n      }\n      _ps(clickwrapGroupKey + \":retrieveHTML\", renderData);\n    }\n    if (signerId !== prevProps.signerId) {\n      if (clickWrapStyle && _psLoadedValidGroup) {\n        _ps.getByKey(clickwrapGroupKey).site.set('style', clickWrapStyle);\n      }\n      _ps('set', 'signer_id', signerId);\n    }\n    if (snapshotLocation !== prevProps.snapshotLocation) {\n      _ps('set', 'snapshot_location', snapshotLocation);\n    }\n    if (clickWrapStyle !== prevProps.clickWrapStyle && dynamicGroup) {\n      this.createClickWrap();\n    }\n    if (filter !== prevProps.filter) {\n      this.createClickWrap();\n    }\n    if (groupKey !== prevProps.groupKey && !dynamicGroup) {\n      this.createClickWrap();\n      if (_psLoadedValidGroup) _ps.getByKey(clickwrapGroupKey).retrieveHTML();\n    }\n  };\n  _proto.componentWillUnmount = function componentWillUnmount() {\n    this._isMounted = false;\n    var _this$props3 = this.props,\n      injectSnippetOnly = _this$props3.injectSnippetOnly,\n      groupKey = _this$props3.groupKey;\n    if (injectSnippetOnly) return;\n    if (_ps && _ps.getByKey && typeof _ps.getByKey === 'function' && _ps.getByKey(groupKey)) {\n      if (_ps.getByKey(groupKey).rendered) {\n        _ps.getByKey(groupKey).rendered = false;\n      }\n      _ps.getByKey(groupKey).resetData();\n    }\n    this.unregisterEventListeners();\n  };\n  _proto.registerEventListener = function registerEventListener(eventProp, groupKey) {\n    var _this2 = this;\n    var eventCallbackFn = function eventCallbackFn() {\n      var shouldFireListener = false;\n      for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n        args[_key] = arguments[_key];\n      }\n      args.forEach(function (arg) {\n        // We need to check the context variable and see if it matches the groupKey, if it does -> fire the event (context argument position varies)\n        if (arg && arg.get && arg.get('key') && arg.get('key') === groupKey) {\n          shouldFireListener = true;\n          // Else we should check if the context is for the entire site, and as such the context variable is a Site object.\n        } else if (arg && arg.toString() === '[object Site]') {\n          shouldFireListener = true;\n        }\n      });\n      if (shouldFireListener) {\n        var _this2$props;\n        (_this2$props = _this2.props)[eventProp].apply(_this2$props, args);\n      }\n    };\n    // In order to handle unregistration of event listeners, we override the toString function to identify the\n    // function by a UUID rather than the default toString of a function.\n    var newEventListenerID = uuidv4();\n    eventCallbackFn.toString = function () {\n      return newEventListenerID;\n    };\n    _ps.on(this.propsEventMap[eventProp], eventCallbackFn);\n    return eventCallbackFn.toString();\n  };\n  _proto.registerEventListeners = function registerEventListeners(groupKey) {\n    var _this3 = this;\n    var eventListeners = {};\n    Object.keys(this.propsEventMap).forEach(function (eventProp) {\n      if (_this3.props[eventProp]) {\n        eventListeners[_this3.propsEventMap[eventProp]] = _this3.registerEventListener(eventProp, groupKey);\n      }\n    });\n    // Store event listeners in state so we can unregister them later on unmount\n    if (this._isMounted) {\n      this.setState({\n        eventListeners: eventListeners\n      });\n    }\n  };\n  _proto.unregisterEventListeners = function unregisterEventListeners() {\n    var _this4 = this;\n    if (this.state.eventListeners) {\n      Object.keys(this.state.eventListeners).forEach(function (event) {\n        var eventUUID = _this4.state.eventListeners[event];\n        // In order to unregister the event, we must create a fake function (typeof passed to _ps.off must be a function),\n        // that returns the UUID we want to unregister.\n        var fakeEventListener = function fakeEventListener() {\n          return eventUUID;\n        };\n        fakeEventListener.toString = function () {\n          return eventUUID;\n        };\n        _ps.off(event, fakeEventListener);\n      });\n    }\n  };\n  _proto.createClickWrap = function createClickWrap() {\n    var _this5 = this;\n    var _this$props4 = this.props,\n      acceptanceLanguage = _this$props4.acceptanceLanguage,\n      clickWrapStyle = _this$props4.clickWrapStyle,\n      customData = _this$props4.customData,\n      confirmationEmail = _this$props4.confirmationEmail,\n      confirmationEmailSubject = _this$props4.confirmationEmailSubject,\n      containerId = _this$props4.containerId,\n      displayAll = _this$props4.displayAll,\n      displayImmediately = _this$props4.displayImmediately,\n      filter = _this$props4.filter,\n      forceScroll = _this$props4.forceScroll,\n      groupKey = _this$props4.groupKey,\n      injectSnippetOnly = _this$props4.injectSnippetOnly,\n      renderData = _this$props4.renderData,\n      signerIdSelector = _this$props4.signerIdSelector,\n      snapshotLocation = _this$props4.snapshotLocation,\n      allowDisagreed = _this$props4.allowDisagreed;\n    var options = _extends({}, allowDisagreed !== undefined && {\n      allow_disagreed: allowDisagreed\n    }, acceptanceLanguage !== undefined && {\n      acceptance_language: acceptanceLanguage\n    }, {\n      auto_run: displayImmediately\n    }, confirmationEmail !== undefined && {\n      confirmation_email: confirmationEmail\n    }, confirmationEmailSubject !== undefined && {\n      confirmation_email_subject: confirmationEmailSubject\n    }, {\n      container_selector: containerId,\n      display_all: displayAll\n    }, filter !== undefined && {\n      filter: filter\n    }, forceScroll !== undefined && {\n      force_scroll: forceScroll\n    }, renderData !== undefined && {\n      render_data: renderData\n    }, signerIdSelector !== undefined && {\n      signer_id_selector: signerIdSelector\n    }, clickWrapStyle !== undefined && {\n      style: clickWrapStyle\n    });\n    if (injectSnippetOnly) return;\n    if (groupKey && this._isMounted) {\n      this.setState({\n        clickwrapGroupKey: groupKey,\n        dynamicGroup: false\n      });\n    }\n    var isDynamic = !groupKey;\n    var eventCallback = function eventCallback(err, group) {\n      if (group) {\n        var key = groupKey || group.get('key');\n        var state = {\n          clickwrapGroupKey: key\n        };\n        if (isDynamic) state.dynamicGroup = true;\n        if (_this5._isMounted) {\n          _this5.setState(state);\n        }\n        if (!isDynamic) group.render();\n        _this5.registerEventListeners(key);\n      }\n    };\n    if (customData) {\n      _ps('set', 'custom_data', customData);\n    }\n    if (snapshotLocation) {\n      _ps('set', 'snapshot_location', snapshotLocation);\n    }\n    if (groupKey) {\n      _ps('load', groupKey, _extends({}, options, {\n        event_callback: eventCallback\n      }));\n    } else _ps('load', _extends({}, options, {\n      event_callback: eventCallback\n    }));\n  };\n  _proto.render = function render() {\n    var containerId = this.props.containerId;\n    return /*#__PURE__*/React.createElement(\"div\", {\n      id: containerId\n    });\n  };\n  return PSClickWrap;\n}(React.Component);\nPSClickWrap.FILTER_OR_GROUPKEY_REQUIRED_ERROR_MESSAGE = 'PSClickWrap Error: You must provide either a groupKey or filter prop in order to use the PactSafe ClickWrap component!';\nPSClickWrap.MUST_PROVIDE_RENDER_DATA_ERROR_MESSAGE = 'PSClickWrap Error: You must provide a renderData prop when passing down the dynamic prop';\nPSClickWrap.MUST_PROVIDE_SIGNER_ID_OR_SIGNER_ID_SELECTOR = 'PSClickWrap Error: You must provide either a signer ID or a signer ID selector';\nPSClickWrap.MUST_SET_ALLOW_DISAGREED = 'PSClickWrap Error: You must set allowDisagreed as true to make onInvalid work';\nPSClickWrap.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  acceptanceLanguage: PropTypes.string,\n  accessId: isRequiredIf(PropTypes.string, function (props) {\n    return !props.hasOwnProperty('injectSnippetOnly');\n  }),\n  clickWrapStyle: PropTypes.oneOf(['full', 'scroll', 'checkbox', 'combined', 'embedded']),\n  confirmationEmail: PropTypes.bool,\n  confirmationEmailSubject: PropTypes.string,\n  customData: PropTypes.object,\n  disableSending: PropTypes.bool,\n  displayAll: PropTypes.bool,\n  displayImmediately: PropTypes.bool,\n  dynamic: PropTypes.bool,\n  containerId: PropTypes.string,\n  filter: isRequiredIf(PropTypes.string, function (props) {\n    return !props.hasOwnProperty('groupKey') && !props.hasOwnProperty('injectSnippetOnly');\n  }, PSClickWrap.FILTER_OR_GROUPKEY_REQUIRED_ERROR_MESSAGE),\n  forceScroll: PropTypes.bool,\n  groupKey: isRequiredIf(PropTypes.string, function (props) {\n    return !props.hasOwnProperty('filter') && !props.hasOwnProperty('injectSnippetOnly');\n  }, PSClickWrap.FILTER_OR_GROUPKEY_REQUIRED_ERROR_MESSAGE),\n  injectSnippetOnly: PropTypes.bool,\n  psScriptUrl: PropTypes.string,\n  backupScriptURL: PropTypes.string,\n  oversized: PropTypes.bool,\n  renderData: isRequiredIf(PropTypes.object, function (props) {\n    return props.hasOwnProperty('dynamic') && props.dynamic === true;\n  }, PSClickWrap.MUST_PROVIDE_RENDER_DATA_ERROR_MESSAGE),\n  signerIdSelector: isRequiredIf(PropTypes.string, function (props) {\n    return !props.hasOwnProperty('signerId') && !props.hasOwnProperty('injectSnippetOnly');\n  }, PSClickWrap.MUST_PROVIDE_SIGNER_ID_OR_SIGNER_ID_SELECTOR),\n  signerId: isRequiredIf(PropTypes.string, function (props) {\n    return !props.hasOwnProperty('signerIdSelector') && !props.hasOwnProperty('injectSnippetOnly');\n  }, PSClickWrap.MUST_PROVIDE_SIGNER_ID_OR_SIGNER_ID_SELECTOR),\n  snapshotLocation: PropTypes.string,\n  testMode: PropTypes.bool,\n  allowDisagreed: isRequiredIf(PropTypes.bool, function (props) {\n    return props.hasOwnProperty('onInvalid');\n  }, PSClickWrap.MUST_SET_ALLOW_DISAGREED),\n  debug: PropTypes.bool,\n  onAll: PropTypes.func,\n  onSent: PropTypes.func,\n  onRetrieved: PropTypes.func,\n  onSet: PropTypes.func,\n  onSetSignerId: PropTypes.func,\n  onValid: PropTypes.func,\n  onInvalid: PropTypes.func,\n  onChecked: PropTypes.func,\n  onUnchecked: PropTypes.func,\n  onRendered: PropTypes.func,\n  onDisplayed: PropTypes.func,\n  onScrolledContract: PropTypes.func,\n  onScrolled: PropTypes.func,\n  onError: PropTypes.func\n} : {};\nPSClickWrap.defaultProps = {\n  psScriptUrl: '//vault.pactsafe.io/ps.min.js',\n  backupScriptURL: '//d3l1mqnl5xpsuc.cloudfront.net/ps.min.js',\n  containerId: 'ps-clickwrap',\n  displayImmediately: true,\n  disableSending: false,\n  displayAll: true,\n  dynamic: false,\n  testMode: false,\n  oversized: false\n};\nexport default PSClickWrap;"],"names":[],"sourceRoot":""} //# sourceURL=webpack-internal:///3744