(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);throw new Error("Cannot find module '"+o+"'")}var f=n[o]={exports:{}};t[o][0].call(f.exports,function(e){var n=t[o][1][e];return s(n?n:e)},f,f.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o 0) { var fn = queue.shift(); fn(); } } }, true); return function nextTick(fn) { queue.push(fn); window.postMessage('process-tick', '*'); }; } return function nextTick(fn) { setTimeout(fn, 0); }; })(); process.title = 'browser'; process.browser = true; process.env = {}; process.argv = []; function noop() {} process.on = noop; process.addListener = noop; process.once = noop; process.off = noop; process.removeListener = noop; process.removeAllListeners = noop; process.emit = noop; process.binding = function (name) { throw new Error('process.binding is not supported'); } // TODO(shtylman) process.cwd = function () { return '/' }; process.chdir = function (dir) { throw new Error('process.chdir is not supported'); }; },{}],2:[function(require,module,exports){ /* object-assign (c) Sindre Sorhus @license MIT */ 'use strict'; /* eslint-disable no-unused-vars */ var getOwnPropertySymbols = Object.getOwnPropertySymbols; var hasOwnProperty = Object.prototype.hasOwnProperty; var propIsEnumerable = Object.prototype.propertyIsEnumerable; function toObject(val) { if (val === null || val === undefined) { throw new TypeError('Object.assign cannot be called with null or undefined'); } return Object(val); } function shouldUseNative() { try { if (!Object.assign) { return false; } // Detect buggy property enumeration order in older V8 versions. // https://bugs.chromium.org/p/v8/issues/detail?id=4118 var test1 = new String('abc'); // eslint-disable-line no-new-wrappers test1[5] = 'de'; if (Object.getOwnPropertyNames(test1)[0] === '5') { return false; } // https://bugs.chromium.org/p/v8/issues/detail?id=3056 var test2 = {}; for (var i = 0; i < 10; i++) { test2['_' + String.fromCharCode(i)] = i; } var order2 = Object.getOwnPropertyNames(test2).map(function (n) { return test2[n]; }); if (order2.join('') !== '0123456789') { return false; } // https://bugs.chromium.org/p/v8/issues/detail?id=3056 var test3 = {}; 'abcdefghijklmnopqrst'.split('').forEach(function (letter) { test3[letter] = letter; }); if (Object.keys(Object.assign({}, test3)).join('') !== 'abcdefghijklmnopqrst') { return false; } return true; } catch (err) { // We don't expect any of the above to throw, but better to be safe. return false; } } module.exports = shouldUseNative() ? Object.assign : function (target, source) { var from; var to = toObject(target); var symbols; for (var s = 1; s < arguments.length; s++) { from = Object(arguments[s]); for (var key in from) { if (hasOwnProperty.call(from, key)) { to[key] = from[key]; } } if (getOwnPropertySymbols) { symbols = getOwnPropertySymbols(from); for (var i = 0; i < symbols.length; i++) { if (propIsEnumerable.call(from, symbols[i])) { to[symbols[i]] = from[symbols[i]]; } } } } return to; }; },{}],3:[function(require,module,exports){ (function (process){ /** * Copyright (c) 2013-present, Facebook, Inc. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ 'use strict'; var printWarning = function() {}; if (process.env.NODE_ENV !== 'production') { var ReactPropTypesSecret = require('./lib/ReactPropTypesSecret'); var loggedTypeFailures = {}; var has = require('./lib/has'); printWarning = function(text) { var message = 'Warning: ' + text; if (typeof console !== 'undefined') { console.error(message); } try { // --- Welcome to debugging React --- // This error was thrown as a convenience so that you can use this stack // to find the callsite that caused this warning to fire. throw new Error(message); } catch (x) { /**/ } }; } /** * Assert that the values match with the type specs. * Error messages are memorized and will only be shown once. * * @param {object} typeSpecs Map of name to a ReactPropType * @param {object} values Runtime values that need to be type-checked * @param {string} location e.g. "prop", "context", "child context" * @param {string} componentName Name of the component for error messages. * @param {?Function} getStack Returns the component stack. * @private */ function checkPropTypes(typeSpecs, values, location, componentName, getStack) { if (process.env.NODE_ENV !== 'production') { for (var typeSpecName in typeSpecs) { if (has(typeSpecs, typeSpecName)) { var error; // Prop type validation may throw. In case they do, we don't want to // fail the render phase where it didn't fail before. So we log it. // After these have been cleaned up, we'll let them throw. try { // This is intentionally an invariant that gets caught. It's the same // behavior as without this statement except with a better message. if (typeof typeSpecs[typeSpecName] !== 'function') { var err = Error( (componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' + 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' + 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.' ); err.name = 'Invariant Violation'; throw err; } error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret); } catch (ex) { error = ex; } if (error && !(error instanceof Error)) { printWarning( (componentName || 'React class') + ': type specification of ' + location + ' `' + typeSpecName + '` is invalid; the type checker ' + 'function must return `null` or an `Error` but returned a ' + typeof error + '. ' + 'You may have forgotten to pass an argument to the type checker ' + 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' + 'shape all require an argument).' ); } if (error instanceof Error && !(error.message in loggedTypeFailures)) { // Only monitor this failure once because there tends to be a lot of the // same error. loggedTypeFailures[error.message] = true; var stack = getStack ? getStack() : ''; printWarning( 'Failed ' + location + ' type: ' + error.message + (stack != null ? stack : '') ); } } } } } /** * Resets warning cache when testing. * * @private */ checkPropTypes.resetWarningCache = function() { if (process.env.NODE_ENV !== 'production') { loggedTypeFailures = {}; } } module.exports = checkPropTypes; }).call(this,require("hmr7eR")) },{"./lib/ReactPropTypesSecret":7,"./lib/has":8,"hmr7eR":1}],4:[function(require,module,exports){ /** * Copyright (c) 2013-present, Facebook, Inc. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ 'use strict'; var ReactPropTypesSecret = require('./lib/ReactPropTypesSecret'); function emptyFunction() {} function emptyFunctionWithReset() {} emptyFunctionWithReset.resetWarningCache = emptyFunction; module.exports = function() { function shim(props, propName, componentName, location, propFullName, secret) { if (secret === ReactPropTypesSecret) { // It is still safe when called from React. return; } var err = new Error( 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' + 'Use PropTypes.checkPropTypes() to call them. ' + 'Read more at http://fb.me/use-check-prop-types' ); err.name = 'Invariant Violation'; throw err; }; shim.isRequired = shim; function getShim() { return shim; }; // Important! // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`. var ReactPropTypes = { array: shim, bigint: shim, bool: shim, func: shim, number: shim, object: shim, string: shim, symbol: shim, any: shim, arrayOf: getShim, element: shim, elementType: shim, instanceOf: getShim, node: shim, objectOf: getShim, oneOf: getShim, oneOfType: getShim, shape: getShim, exact: getShim, checkPropTypes: emptyFunctionWithReset, resetWarningCache: emptyFunction }; ReactPropTypes.PropTypes = ReactPropTypes; return ReactPropTypes; }; },{"./lib/ReactPropTypesSecret":7}],5:[function(require,module,exports){ (function (process){ /** * Copyright (c) 2013-present, Facebook, Inc. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ 'use strict'; var ReactIs = require('react-is'); var assign = require('object-assign'); var ReactPropTypesSecret = require('./lib/ReactPropTypesSecret'); var has = require('./lib/has'); var checkPropTypes = require('./checkPropTypes'); var printWarning = function() {}; if (process.env.NODE_ENV !== 'production') { printWarning = function(text) { var message = 'Warning: ' + text; if (typeof console !== 'undefined') { console.error(message); } try { // --- Welcome to debugging React --- // This error was thrown as a convenience so that you can use this stack // to find the callsite that caused this warning to fire. throw new Error(message); } catch (x) {} }; } function emptyFunctionThatReturnsNull() { return null; } module.exports = function(isValidElement, throwOnDirectAccess) { /* global Symbol */ var ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator; var FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec. /** * Returns the iterator method function contained on the iterable object. * * Be sure to invoke the function with the iterable as context: * * var iteratorFn = getIteratorFn(myIterable); * if (iteratorFn) { * var iterator = iteratorFn.call(myIterable); * ... * } * * @param {?object} maybeIterable * @return {?function} */ function getIteratorFn(maybeIterable) { var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]); if (typeof iteratorFn === 'function') { return iteratorFn; } } /** * Collection of methods that allow declaration and validation of props that are * supplied to React components. Example usage: * * var Props = require('ReactPropTypes'); * var MyArticle = React.createClass({ * propTypes: { * // An optional string prop named "description". * description: Props.string, * * // A required enum prop named "category". * category: Props.oneOf(['News','Photos']).isRequired, * * // A prop named "dialog" that requires an instance of Dialog. * dialog: Props.instanceOf(Dialog).isRequired * }, * render: function() { ... } * }); * * A more formal specification of how these methods are used: * * type := array|bool|func|object|number|string|oneOf([...])|instanceOf(...) * decl := ReactPropTypes.{type}(.isRequired)? * * Each and every declaration produces a function with the same signature. This * allows the creation of custom validation functions. For example: * * var MyLink = React.createClass({ * propTypes: { * // An optional string or URI prop named "href". * href: function(props, propName, componentName) { * var propValue = props[propName]; * if (propValue != null && typeof propValue !== 'string' && * !(propValue instanceof URI)) { * return new Error( * 'Expected a string or an URI for ' + propName + ' in ' + * componentName * ); * } * } * }, * render: function() {...} * }); * * @internal */ var ANONYMOUS = '<>'; // Important! // Keep this list in sync with production version in `./factoryWithThrowingShims.js`. var ReactPropTypes = { array: createPrimitiveTypeChecker('array'), bigint: createPrimitiveTypeChecker('bigint'), bool: createPrimitiveTypeChecker('boolean'), func: createPrimitiveTypeChecker('function'), number: createPrimitiveTypeChecker('number'), object: createPrimitiveTypeChecker('object'), string: createPrimitiveTypeChecker('string'), symbol: createPrimitiveTypeChecker('symbol'), any: createAnyTypeChecker(), arrayOf: createArrayOfTypeChecker, element: createElementTypeChecker(), elementType: createElementTypeTypeChecker(), instanceOf: createInstanceTypeChecker, node: createNodeChecker(), objectOf: createObjectOfTypeChecker, oneOf: createEnumTypeChecker, oneOfType: createUnionTypeChecker, shape: createShapeTypeChecker, exact: createStrictShapeTypeChecker, }; /** * inlined Object.is polyfill to avoid requiring consumers ship their own * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is */ /*eslint-disable no-self-compare*/ function is(x, y) { // SameValue algorithm if (x === y) { // Steps 1-5, 7-10 // Steps 6.b-6.e: +0 != -0 return x !== 0 || 1 / x === 1 / y; } else { // Step 6.a: NaN == NaN return x !== x && y !== y; } } /*eslint-enable no-self-compare*/ /** * We use an Error-like object for backward compatibility as people may call * PropTypes directly and inspect their output. However, we don't use real * Errors anymore. We don't inspect their stack anyway, and creating them * is prohibitively expensive if they are created too often, such as what * happens in oneOfType() for any type before the one that matched. */ function PropTypeError(message, data) { this.message = message; this.data = data && typeof data === 'object' ? data: {}; this.stack = ''; } // Make `instanceof Error` still work for returned errors. PropTypeError.prototype = Error.prototype; function createChainableTypeChecker(validate) { if (process.env.NODE_ENV !== 'production') { var manualPropTypeCallCache = {}; var manualPropTypeWarningCount = 0; } function checkType(isRequired, props, propName, componentName, location, propFullName, secret) { componentName = componentName || ANONYMOUS; propFullName = propFullName || propName; if (secret !== ReactPropTypesSecret) { if (throwOnDirectAccess) { // New behavior only for users of `prop-types` package var err = new Error( 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' + 'Use `PropTypes.checkPropTypes()` to call them. ' + 'Read more at http://fb.me/use-check-prop-types' ); err.name = 'Invariant Violation'; throw err; } else if (process.env.NODE_ENV !== 'production' && typeof console !== 'undefined') { // Old behavior for people using React.PropTypes var cacheKey = componentName + ':' + propName; if ( !manualPropTypeCallCache[cacheKey] && // Avoid spamming the console because they are often not actionable except for lib authors manualPropTypeWarningCount < 3 ) { printWarning( 'You are manually calling a React.PropTypes validation ' + 'function for the `' + propFullName + '` prop on `' + componentName + '`. This is deprecated ' + 'and will throw in the standalone `prop-types` package. ' + 'You may be seeing this warning due to a third-party PropTypes ' + 'library. See https://fb.me/react-warning-dont-call-proptypes ' + 'for details.' ); manualPropTypeCallCache[cacheKey] = true; manualPropTypeWarningCount++; } } } if (props[propName] == null) { if (isRequired) { if (props[propName] === null) { return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required ' + ('in `' + componentName + '`, but its value is `null`.')); } return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required in ' + ('`' + componentName + '`, but its value is `undefined`.')); } return null; } else { return validate(props, propName, componentName, location, propFullName); } } var chainedCheckType = checkType.bind(null, false); chainedCheckType.isRequired = checkType.bind(null, true); return chainedCheckType; } function createPrimitiveTypeChecker(expectedType) { function validate(props, propName, componentName, location, propFullName, secret) { var propValue = props[propName]; var propType = getPropType(propValue); if (propType !== expectedType) { // `propValue` being instance of, say, date/regexp, pass the 'object' // check, but we can offer a more precise error message here rather than // 'of type `object`'. var preciseType = getPreciseType(propValue); return new PropTypeError( 'Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + preciseType + '` supplied to `' + componentName + '`, expected ') + ('`' + expectedType + '`.'), {expectedType: expectedType} ); } return null; } return createChainableTypeChecker(validate); } function createAnyTypeChecker() { return createChainableTypeChecker(emptyFunctionThatReturnsNull); } function createArrayOfTypeChecker(typeChecker) { function validate(props, propName, componentName, location, propFullName) { if (typeof typeChecker !== 'function') { return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside arrayOf.'); } var propValue = props[propName]; if (!Array.isArray(propValue)) { var propType = getPropType(propValue); return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an array.')); } for (var i = 0; i < propValue.length; i++) { var error = typeChecker(propValue, i, componentName, location, propFullName + '[' + i + ']', ReactPropTypesSecret); if (error instanceof Error) { return error; } } return null; } return createChainableTypeChecker(validate); } function createElementTypeChecker() { function validate(props, propName, componentName, location, propFullName) { var propValue = props[propName]; if (!isValidElement(propValue)) { var propType = getPropType(propValue); return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement.')); } return null; } return createChainableTypeChecker(validate); } function createElementTypeTypeChecker() { function validate(props, propName, componentName, location, propFullName) { var propValue = props[propName]; if (!ReactIs.isValidElementType(propValue)) { var propType = getPropType(propValue); return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement type.')); } return null; } return createChainableTypeChecker(validate); } function createInstanceTypeChecker(expectedClass) { function validate(props, propName, componentName, location, propFullName) { if (!(props[propName] instanceof expectedClass)) { var expectedClassName = expectedClass.name || ANONYMOUS; var actualClassName = getClassName(props[propName]); return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + actualClassName + '` supplied to `' + componentName + '`, expected ') + ('instance of `' + expectedClassName + '`.')); } return null; } return createChainableTypeChecker(validate); } function createEnumTypeChecker(expectedValues) { if (!Array.isArray(expectedValues)) { if (process.env.NODE_ENV !== 'production') { if (arguments.length > 1) { printWarning( 'Invalid arguments supplied to oneOf, expected an array, got ' + arguments.length + ' arguments. ' + 'A common mistake is to write oneOf(x, y, z) instead of oneOf([x, y, z]).' ); } else { printWarning('Invalid argument supplied to oneOf, expected an array.'); } } return emptyFunctionThatReturnsNull; } function validate(props, propName, componentName, location, propFullName) { var propValue = props[propName]; for (var i = 0; i < expectedValues.length; i++) { if (is(propValue, expectedValues[i])) { return null; } } var valuesString = JSON.stringify(expectedValues, function replacer(key, value) { var type = getPreciseType(value); if (type === 'symbol') { return String(value); } return value; }); return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of value `' + String(propValue) + '` ' + ('supplied to `' + componentName + '`, expected one of ' + valuesString + '.')); } return createChainableTypeChecker(validate); } function createObjectOfTypeChecker(typeChecker) { function validate(props, propName, componentName, location, propFullName) { if (typeof typeChecker !== 'function') { return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside objectOf.'); } var propValue = props[propName]; var propType = getPropType(propValue); if (propType !== 'object') { return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an object.')); } for (var key in propValue) { if (has(propValue, key)) { var error = typeChecker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret); if (error instanceof Error) { return error; } } } return null; } return createChainableTypeChecker(validate); } function createUnionTypeChecker(arrayOfTypeCheckers) { if (!Array.isArray(arrayOfTypeCheckers)) { process.env.NODE_ENV !== 'production' ? printWarning('Invalid argument supplied to oneOfType, expected an instance of array.') : void 0; return emptyFunctionThatReturnsNull; } for (var i = 0; i < arrayOfTypeCheckers.length; i++) { var checker = arrayOfTypeCheckers[i]; if (typeof checker !== 'function') { printWarning( 'Invalid argument supplied to oneOfType. Expected an array of check functions, but ' + 'received ' + getPostfixForTypeWarning(checker) + ' at index ' + i + '.' ); return emptyFunctionThatReturnsNull; } } function validate(props, propName, componentName, location, propFullName) { var expectedTypes = []; for (var i = 0; i < arrayOfTypeCheckers.length; i++) { var checker = arrayOfTypeCheckers[i]; var checkerResult = checker(props, propName, componentName, location, propFullName, ReactPropTypesSecret); if (checkerResult == null) { return null; } if (checkerResult.data && has(checkerResult.data, 'expectedType')) { expectedTypes.push(checkerResult.data.expectedType); } } var expectedTypesMessage = (expectedTypes.length > 0) ? ', expected one of type [' + expectedTypes.join(', ') + ']': ''; return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`' + expectedTypesMessage + '.')); } return createChainableTypeChecker(validate); } function createNodeChecker() { function validate(props, propName, componentName, location, propFullName) { if (!isNode(props[propName])) { return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a ReactNode.')); } return null; } return createChainableTypeChecker(validate); } function invalidValidatorError(componentName, location, propFullName, key, type) { return new PropTypeError( (componentName || 'React class') + ': ' + location + ' type `' + propFullName + '.' + key + '` is invalid; ' + 'it must be a function, usually from the `prop-types` package, but received `' + type + '`.' ); } function createShapeTypeChecker(shapeTypes) { function validate(props, propName, componentName, location, propFullName) { var propValue = props[propName]; var propType = getPropType(propValue); if (propType !== 'object') { return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.')); } for (var key in shapeTypes) { var checker = shapeTypes[key]; if (typeof checker !== 'function') { return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker)); } var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret); if (error) { return error; } } return null; } return createChainableTypeChecker(validate); } function createStrictShapeTypeChecker(shapeTypes) { function validate(props, propName, componentName, location, propFullName) { var propValue = props[propName]; var propType = getPropType(propValue); if (propType !== 'object') { return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.')); } // We need to check all keys in case some are required but missing from props. var allKeys = assign({}, props[propName], shapeTypes); for (var key in allKeys) { var checker = shapeTypes[key]; if (has(shapeTypes, key) && typeof checker !== 'function') { return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker)); } if (!checker) { return new PropTypeError( 'Invalid ' + location + ' `' + propFullName + '` key `' + key + '` supplied to `' + componentName + '`.' + '\nBad object: ' + JSON.stringify(props[propName], null, ' ') + '\nValid keys: ' + JSON.stringify(Object.keys(shapeTypes), null, ' ') ); } var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret); if (error) { return error; } } return null; } return createChainableTypeChecker(validate); } function isNode(propValue) { switch (typeof propValue) { case 'number': case 'string': case 'undefined': return true; case 'boolean': return !propValue; case 'object': if (Array.isArray(propValue)) { return propValue.every(isNode); } if (propValue === null || isValidElement(propValue)) { return true; } var iteratorFn = getIteratorFn(propValue); if (iteratorFn) { var iterator = iteratorFn.call(propValue); var step; if (iteratorFn !== propValue.entries) { while (!(step = iterator.next()).done) { if (!isNode(step.value)) { return false; } } } else { // Iterator will provide entry [k,v] tuples rather than values. while (!(step = iterator.next()).done) { var entry = step.value; if (entry) { if (!isNode(entry[1])) { return false; } } } } } else { return false; } return true; default: return false; } } function isSymbol(propType, propValue) { // Native Symbol. if (propType === 'symbol') { return true; } // falsy value can't be a Symbol if (!propValue) { return false; } // 19.4.3.5 Symbol.prototype[@@toStringTag] === 'Symbol' if (propValue['@@toStringTag'] === 'Symbol') { return true; } // Fallback for non-spec compliant Symbols which are polyfilled. if (typeof Symbol === 'function' && propValue instanceof Symbol) { return true; } return false; } // Equivalent of `typeof` but with special handling for array and regexp. function getPropType(propValue) { var propType = typeof propValue; if (Array.isArray(propValue)) { return 'array'; } if (propValue instanceof RegExp) { // Old webkits (at least until Android 4.0) return 'function' rather than // 'object' for typeof a RegExp. We'll normalize this here so that /bla/ // passes PropTypes.object. return 'object'; } if (isSymbol(propType, propValue)) { return 'symbol'; } return propType; } // This handles more types than `getPropType`. Only used for error messages. // See `createPrimitiveTypeChecker`. function getPreciseType(propValue) { if (typeof propValue === 'undefined' || propValue === null) { return '' + propValue; } var propType = getPropType(propValue); if (propType === 'object') { if (propValue instanceof Date) { return 'date'; } else if (propValue instanceof RegExp) { return 'regexp'; } } return propType; } // Returns a string that is postfixed to a warning about an invalid type. // For example, "undefined" or "of type array" function getPostfixForTypeWarning(value) { var type = getPreciseType(value); switch (type) { case 'array': case 'object': return 'an ' + type; case 'boolean': case 'date': case 'regexp': return 'a ' + type; default: return type; } } // Returns class name of the object, if any. function getClassName(propValue) { if (!propValue.constructor || !propValue.constructor.name) { return ANONYMOUS; } return propValue.constructor.name; } ReactPropTypes.checkPropTypes = checkPropTypes; ReactPropTypes.resetWarningCache = checkPropTypes.resetWarningCache; ReactPropTypes.PropTypes = ReactPropTypes; return ReactPropTypes; }; }).call(this,require("hmr7eR")) },{"./checkPropTypes":3,"./lib/ReactPropTypesSecret":7,"./lib/has":8,"hmr7eR":1,"object-assign":2,"react-is":11}],6:[function(require,module,exports){ (function (process){ /** * Copyright (c) 2013-present, Facebook, Inc. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ if (process.env.NODE_ENV !== 'production') { var ReactIs = require('react-is'); // By explicitly using `prop-types` you are opting into new development behavior. // http://fb.me/prop-types-in-prod var throwOnDirectAccess = true; module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess); } else { // By explicitly using `prop-types` you are opting into new production behavior. // http://fb.me/prop-types-in-prod module.exports = require('./factoryWithThrowingShims')(); } }).call(this,require("hmr7eR")) },{"./factoryWithThrowingShims":4,"./factoryWithTypeCheckers":5,"hmr7eR":1,"react-is":11}],7:[function(require,module,exports){ /** * Copyright (c) 2013-present, Facebook, Inc. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ 'use strict'; var ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED'; module.exports = ReactPropTypesSecret; },{}],8:[function(require,module,exports){ module.exports = Function.call.bind(Object.prototype.hasOwnProperty); },{}],9:[function(require,module,exports){ (function (process){ /** @license React v16.13.1 * react-is.development.js * * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ 'use strict'; if (process.env.NODE_ENV !== "production") { (function() { 'use strict'; // The Symbol used to tag the ReactElement-like types. If there is no native Symbol // nor polyfill, then a plain number is used for performance. var hasSymbol = typeof Symbol === 'function' && Symbol.for; var REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for('react.element') : 0xeac7; var REACT_PORTAL_TYPE = hasSymbol ? Symbol.for('react.portal') : 0xeaca; var REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for('react.fragment') : 0xeacb; var REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for('react.strict_mode') : 0xeacc; var REACT_PROFILER_TYPE = hasSymbol ? Symbol.for('react.profiler') : 0xead2; var REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for('react.provider') : 0xeacd; var REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for('react.context') : 0xeace; // TODO: We don't use AsyncMode or ConcurrentMode anymore. They were temporary // (unstable) APIs that have been removed. Can we remove the symbols? var REACT_ASYNC_MODE_TYPE = hasSymbol ? Symbol.for('react.async_mode') : 0xeacf; var REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for('react.concurrent_mode') : 0xeacf; var REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for('react.forward_ref') : 0xead0; var REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for('react.suspense') : 0xead1; var REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for('react.suspense_list') : 0xead8; var REACT_MEMO_TYPE = hasSymbol ? Symbol.for('react.memo') : 0xead3; var REACT_LAZY_TYPE = hasSymbol ? Symbol.for('react.lazy') : 0xead4; var REACT_BLOCK_TYPE = hasSymbol ? Symbol.for('react.block') : 0xead9; var REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for('react.fundamental') : 0xead5; var REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for('react.responder') : 0xead6; var REACT_SCOPE_TYPE = hasSymbol ? Symbol.for('react.scope') : 0xead7; function isValidElementType(type) { return typeof type === 'string' || typeof type === 'function' || // Note: its typeof might be other than 'symbol' or 'number' if it's a polyfill. type === REACT_FRAGMENT_TYPE || type === REACT_CONCURRENT_MODE_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || typeof type === 'object' && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_RESPONDER_TYPE || type.$$typeof === REACT_SCOPE_TYPE || type.$$typeof === REACT_BLOCK_TYPE); } function typeOf(object) { if (typeof object === 'object' && object !== null) { var $$typeof = object.$$typeof; switch ($$typeof) { case REACT_ELEMENT_TYPE: var type = object.type; switch (type) { case REACT_ASYNC_MODE_TYPE: case REACT_CONCURRENT_MODE_TYPE: case REACT_FRAGMENT_TYPE: case REACT_PROFILER_TYPE: case REACT_STRICT_MODE_TYPE: case REACT_SUSPENSE_TYPE: return type; default: var $$typeofType = type && type.$$typeof; switch ($$typeofType) { case REACT_CONTEXT_TYPE: case REACT_FORWARD_REF_TYPE: case REACT_LAZY_TYPE: case REACT_MEMO_TYPE: case REACT_PROVIDER_TYPE: return $$typeofType; default: return $$typeof; } } case REACT_PORTAL_TYPE: return $$typeof; } } return undefined; } // AsyncMode is deprecated along with isAsyncMode var AsyncMode = REACT_ASYNC_MODE_TYPE; var ConcurrentMode = REACT_CONCURRENT_MODE_TYPE; var ContextConsumer = REACT_CONTEXT_TYPE; var ContextProvider = REACT_PROVIDER_TYPE; var Element = REACT_ELEMENT_TYPE; var ForwardRef = REACT_FORWARD_REF_TYPE; var Fragment = REACT_FRAGMENT_TYPE; var Lazy = REACT_LAZY_TYPE; var Memo = REACT_MEMO_TYPE; var Portal = REACT_PORTAL_TYPE; var Profiler = REACT_PROFILER_TYPE; var StrictMode = REACT_STRICT_MODE_TYPE; var Suspense = REACT_SUSPENSE_TYPE; var hasWarnedAboutDeprecatedIsAsyncMode = false; // AsyncMode should be deprecated function isAsyncMode(object) { { if (!hasWarnedAboutDeprecatedIsAsyncMode) { hasWarnedAboutDeprecatedIsAsyncMode = true; // Using console['warn'] to evade Babel and ESLint console['warn']('The ReactIs.isAsyncMode() alias has been deprecated, ' + 'and will be removed in React 17+. Update your code to use ' + 'ReactIs.isConcurrentMode() instead. It has the exact same API.'); } } return isConcurrentMode(object) || typeOf(object) === REACT_ASYNC_MODE_TYPE; } function isConcurrentMode(object) { return typeOf(object) === REACT_CONCURRENT_MODE_TYPE; } function isContextConsumer(object) { return typeOf(object) === REACT_CONTEXT_TYPE; } function isContextProvider(object) { return typeOf(object) === REACT_PROVIDER_TYPE; } function isElement(object) { return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE; } function isForwardRef(object) { return typeOf(object) === REACT_FORWARD_REF_TYPE; } function isFragment(object) { return typeOf(object) === REACT_FRAGMENT_TYPE; } function isLazy(object) { return typeOf(object) === REACT_LAZY_TYPE; } function isMemo(object) { return typeOf(object) === REACT_MEMO_TYPE; } function isPortal(object) { return typeOf(object) === REACT_PORTAL_TYPE; } function isProfiler(object) { return typeOf(object) === REACT_PROFILER_TYPE; } function isStrictMode(object) { return typeOf(object) === REACT_STRICT_MODE_TYPE; } function isSuspense(object) { return typeOf(object) === REACT_SUSPENSE_TYPE; } exports.AsyncMode = AsyncMode; exports.ConcurrentMode = ConcurrentMode; exports.ContextConsumer = ContextConsumer; exports.ContextProvider = ContextProvider; exports.Element = Element; exports.ForwardRef = ForwardRef; exports.Fragment = Fragment; exports.Lazy = Lazy; exports.Memo = Memo; exports.Portal = Portal; exports.Profiler = Profiler; exports.StrictMode = StrictMode; exports.Suspense = Suspense; exports.isAsyncMode = isAsyncMode; exports.isConcurrentMode = isConcurrentMode; exports.isContextConsumer = isContextConsumer; exports.isContextProvider = isContextProvider; exports.isElement = isElement; exports.isForwardRef = isForwardRef; exports.isFragment = isFragment; exports.isLazy = isLazy; exports.isMemo = isMemo; exports.isPortal = isPortal; exports.isProfiler = isProfiler; exports.isStrictMode = isStrictMode; exports.isSuspense = isSuspense; exports.isValidElementType = isValidElementType; exports.typeOf = typeOf; })(); } }).call(this,require("hmr7eR")) },{"hmr7eR":1}],10:[function(require,module,exports){ /** @license React v16.13.1 * react-is.production.min.js * * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. */ 'use strict';var b="function"===typeof Symbol&&Symbol.for,c=b?Symbol.for("react.element"):60103,d=b?Symbol.for("react.portal"):60106,e=b?Symbol.for("react.fragment"):60107,f=b?Symbol.for("react.strict_mode"):60108,g=b?Symbol.for("react.profiler"):60114,h=b?Symbol.for("react.provider"):60109,k=b?Symbol.for("react.context"):60110,l=b?Symbol.for("react.async_mode"):60111,m=b?Symbol.for("react.concurrent_mode"):60111,n=b?Symbol.for("react.forward_ref"):60112,p=b?Symbol.for("react.suspense"):60113,q=b? Symbol.for("react.suspense_list"):60120,r=b?Symbol.for("react.memo"):60115,t=b?Symbol.for("react.lazy"):60116,v=b?Symbol.for("react.block"):60121,w=b?Symbol.for("react.fundamental"):60117,x=b?Symbol.for("react.responder"):60118,y=b?Symbol.for("react.scope"):60119; function z(a){if("object"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d; exports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return"object"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t}; exports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p}; exports.isValidElementType=function(a){return"string"===typeof a||"function"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||"object"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z; },{}],11:[function(require,module,exports){ (function (process){ 'use strict'; if (process.env.NODE_ENV === 'production') { module.exports = require('./cjs/react-is.production.min.js'); } else { module.exports = require('./cjs/react-is.development.js'); } }).call(this,require("hmr7eR")) },{"./cjs/react-is.development.js":9,"./cjs/react-is.production.min.js":10,"hmr7eR":1}],12:[function(require,module,exports){ "use strict"; var _education = _interopRequireDefault(require("../../../js/integrations/gutenberg/modules/education.js")); var _common = _interopRequireDefault(require("../../../js/integrations/gutenberg/modules/common.js")); var _themesPanel = _interopRequireDefault(require("../../../js/integrations/gutenberg/modules/themes-panel.js")); var _containerStyles = _interopRequireDefault(require("../../../js/integrations/gutenberg/modules/container-styles.js")); var _backgroundStyles = _interopRequireDefault(require("../../../js/integrations/gutenberg/modules/background-styles.js")); var _buttonStyles = _interopRequireDefault(require("../../../js/integrations/gutenberg/modules/button-styles.js")); var _advancedSettings = _interopRequireDefault(require("../../../js/integrations/gutenberg/modules/advanced-settings.js")); var _fieldStyles = _interopRequireDefault(require("../../../js/integrations/gutenberg/modules/field-styles.js")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } /* jshint es3: false, esversion: 6 */ /** * Gutenberg editor block for Lite. * * @since 1.8.8 */ var WPForms = window.WPForms || {}; WPForms.FormSelector = WPForms.FormSelector || function () { /** * Public functions and properties. * * @since 1.8.8 * * @type {Object} */ var app = { /** * Common module object. * * @since 1.8.8 * * @type {Object} */ common: {}, /** * Panel modules objects. * * @since 1.8.8 * * @type {Object} */ panels: {}, /** * Start the engine. * * @since 1.8.8 */ init: function init() { app.education = _education.default; app.common = _common.default; app.panels.themes = _themesPanel.default; app.panels.container = _containerStyles.default; app.panels.background = _backgroundStyles.default; app.panels.button = _buttonStyles.default; app.panels.advanced = _advancedSettings.default; app.panels.field = _fieldStyles.default; var blockOptions = { panels: app.panels, getThemesPanel: app.panels.themes.getThemesPanel, getFieldStyles: app.panels.field.getFieldStyles, getContainerStyles: app.panels.container.getContainerStyles, getBackgroundStyles: app.panels.background.getBackgroundStyles, getButtonStyles: app.panels.button.getButtonStyles, getCommonAttributes: app.getCommonAttributes, setStylesHandlers: app.getStyleHandlers(), education: app.education }; // Initialize Advanced Settings module. app.panels.advanced.init(app.common); // Initialize block. app.common.init(blockOptions); }, /** * Get style handlers. * * @since 1.8.8 * * @return {Object} Style handlers. */ getCommonAttributes: function getCommonAttributes() { return _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, app.panels.field.getBlockAttributes()), app.panels.container.getBlockAttributes()), app.panels.background.getBlockAttributes()), app.panels.button.getBlockAttributes()); }, /** * Get style handlers. * * @since 1.8.8 * * @return {Object} Style handlers. */ getStyleHandlers: function getStyleHandlers() { return { 'background-image': app.panels.background.setContainerBackgroundImage, 'background-position': app.panels.background.setContainerBackgroundPosition, 'background-repeat': app.panels.background.setContainerBackgroundRepeat, 'background-width': app.panels.background.setContainerBackgroundWidth, 'background-height': app.panels.background.setContainerBackgroundHeight, 'background-color': app.panels.background.setBackgroundColor, 'background-url': app.panels.background.setBackgroundUrl }; } }; // Provide access to public functions/properties. return app; }(); // Initialize. WPForms.FormSelector.init(); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_education","_interopRequireDefault","require","_common","_themesPanel","_containerStyles","_backgroundStyles","_buttonStyles","_advancedSettings","_fieldStyles","e","__esModule","default","_typeof","o","Symbol","iterator","constructor","prototype","ownKeys","r","t","Object","keys","getOwnPropertySymbols","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","_toPropertyKey","value","configurable","writable","i","_toPrimitive","toPrimitive","call","TypeError","String","Number","WPForms","window","FormSelector","app","common","panels","init","education","themes","themesPanel","container","containerStyles","background","backgroundStyles","button","buttonStyles","advanced","advancedSettings","field","fieldStyles","blockOptions","getThemesPanel","getFieldStyles","getContainerStyles","getBackgroundStyles","getButtonStyles","getCommonAttributes","setStylesHandlers","getStyleHandlers","getBlockAttributes","setContainerBackgroundImage","setContainerBackgroundPosition","setContainerBackgroundRepeat","setContainerBackgroundWidth","setContainerBackgroundHeight","setBackgroundColor","setBackgroundUrl"],"sources":["fake_1a1c65d8.js"],"sourcesContent":["/* jshint es3: false, esversion: 6 */\n\nimport education from '../../../js/integrations/gutenberg/modules/education.js';\nimport common from '../../../js/integrations/gutenberg/modules/common.js';\nimport themesPanel from '../../../js/integrations/gutenberg/modules/themes-panel.js';\nimport containerStyles from '../../../js/integrations/gutenberg/modules/container-styles.js';\nimport backgroundStyles from '../../../js/integrations/gutenberg/modules/background-styles.js';\nimport buttonStyles from '../../../js/integrations/gutenberg/modules/button-styles.js';\nimport advancedSettings from '../../../js/integrations/gutenberg/modules/advanced-settings.js';\nimport fieldStyles from '../../../js/integrations/gutenberg/modules/field-styles.js';\n\n/**\n * Gutenberg editor block for Lite.\n *\n * @since 1.8.8\n */\nconst WPForms = window.WPForms || {};\n\nWPForms.FormSelector = WPForms.FormSelector || ( function() {\n\t/**\n\t * Public functions and properties.\n\t *\n\t * @since 1.8.8\n\t *\n\t * @type {Object}\n\t */\n\tconst app = {\n\t\t/**\n\t\t * Common module object.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @type {Object}\n\t\t */\n\t\tcommon: {},\n\n\t\t/**\n\t\t * Panel modules objects.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @type {Object}\n\t\t */\n\t\tpanels: {},\n\n\t\t/**\n\t\t * Start the engine.\n\t\t *\n\t\t * @since 1.8.8\n\t\t */\n\t\tinit() {\n\t\t\tapp.education = education;\n\t\t\tapp.common = common;\n\t\t\tapp.panels.themes = themesPanel;\n\t\t\tapp.panels.container = containerStyles;\n\t\t\tapp.panels.background = backgroundStyles;\n\t\t\tapp.panels.button = buttonStyles;\n\t\t\tapp.panels.advanced = advancedSettings;\n\t\t\tapp.panels.field = fieldStyles;\n\n\t\t\tconst blockOptions = {\n\t\t\t\tpanels: app.panels,\n\t\t\t\tgetThemesPanel: app.panels.themes.getThemesPanel,\n\t\t\t\tgetFieldStyles: app.panels.field.getFieldStyles,\n\t\t\t\tgetContainerStyles: app.panels.container.getContainerStyles,\n\t\t\t\tgetBackgroundStyles: app.panels.background.getBackgroundStyles,\n\t\t\t\tgetButtonStyles: app.panels.button.getButtonStyles,\n\t\t\t\tgetCommonAttributes: app.getCommonAttributes,\n\t\t\t\tsetStylesHandlers: app.getStyleHandlers(),\n\t\t\t\teducation: app.education,\n\t\t\t};\n\n\t\t\t// Initialize Advanced Settings module.\n\t\t\tapp.panels.advanced.init( app.common );\n\n\t\t\t// Initialize block.\n\t\t\tapp.common.init( blockOptions );\n\t\t},\n\n\t\t/**\n\t\t * Get style handlers.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @return {Object} Style handlers.\n\t\t */\n\t\tgetCommonAttributes() {\n\t\t\treturn {\n\t\t\t\t...app.panels.field.getBlockAttributes(),\n\t\t\t\t...app.panels.container.getBlockAttributes(),\n\t\t\t\t...app.panels.background.getBlockAttributes(),\n\t\t\t\t...app.panels.button.getBlockAttributes(),\n\t\t\t};\n\t\t},\n\n\t\t/**\n\t\t * Get style handlers.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @return {Object} Style handlers.\n\t\t */\n\t\tgetStyleHandlers() {\n\t\t\treturn {\n\t\t\t\t'background-image': app.panels.background.setContainerBackgroundImage,\n\t\t\t\t'background-position': app.panels.background.setContainerBackgroundPosition,\n\t\t\t\t'background-repeat': app.panels.background.setContainerBackgroundRepeat,\n\t\t\t\t'background-width': app.panels.background.setContainerBackgroundWidth,\n\t\t\t\t'background-height': app.panels.background.setContainerBackgroundHeight,\n\t\t\t\t'background-color': app.panels.background.setBackgroundColor,\n\t\t\t\t'background-url': app.panels.background.setBackgroundUrl,\n\t\t\t};\n\t\t},\n\t};\n\n\t// Provide access to public functions/properties.\n\treturn app;\n}() );\n\n// Initialize.\nWPForms.FormSelector.init();\n"],"mappings":"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","ignoreList":[]} },{"../../../js/integrations/gutenberg/modules/advanced-settings.js":13,"../../../js/integrations/gutenberg/modules/background-styles.js":15,"../../../js/integrations/gutenberg/modules/button-styles.js":16,"../../../js/integrations/gutenberg/modules/common.js":17,"../../../js/integrations/gutenberg/modules/container-styles.js":18,"../../../js/integrations/gutenberg/modules/education.js":19,"../../../js/integrations/gutenberg/modules/field-styles.js":20,"../../../js/integrations/gutenberg/modules/themes-panel.js":21}],13:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; /* global wpforms_gutenberg_form_selector */ /* jshint es3: false, esversion: 6 */ /** * @param strings.custom_css * @param strings.custom_css_notice * @param strings.copy_paste_settings * @param strings.copy_paste_notice */ /** * Gutenberg editor block. * * Advanced Settings module. * * @since 1.8.8 */ var _default = exports.default = function ($) { /** * WP core components. * * @since 1.8.8 */ var addFilter = wp.hooks.addFilter; var createHigherOrderComponent = wp.compose.createHigherOrderComponent; var Fragment = wp.element.Fragment; var _ref = wp.blockEditor || wp.editor, InspectorAdvancedControls = _ref.InspectorAdvancedControls; var TextareaControl = wp.components.TextareaControl; /** * Localized data aliases. * * @since 1.8.8 */ var _wpforms_gutenberg_fo = wpforms_gutenberg_form_selector, strings = _wpforms_gutenberg_fo.strings; /** * Public functions and properties. * * @since 1.8.8 * * @type {Object} */ var app = { /** * Initialize module. * * @since 1.8.8 * * @param {Object} commonModule Common module. */ init: function init(commonModule) { app.common = commonModule; app.hooks(); app.events(); }, /** * Hooks. * * @since 1.8.8 */ hooks: function hooks() { addFilter('editor.BlockEdit', 'editorskit/custom-advanced-control', app.withAdvancedControls); }, /** * Events. * * @since 1.8.8 */ events: function events() { $(document).on('focus click', 'textarea', app.copyPasteFocus); }, /** * Copy / Paste Style Settings textarea focus event. * * @since 1.8.8 */ copyPasteFocus: function copyPasteFocus() { var $input = $(this); if ($input.siblings('label').text() === strings.copy_paste_settings) { // Select all text, so it's easier to copy and paste value. $input.select(); } }, /** * Get fields. * * @since 1.8.8 * * @param {Object} props Block properties. * * @return {Object} Inspector advanced controls JSX code. */ getFields: function getFields(props) { var _props$attributes; // Proceed only for WPForms block and when form ID is set. if ((props === null || props === void 0 ? void 0 : props.name) !== 'wpforms/form-selector' || !(props !== null && props !== void 0 && (_props$attributes = props.attributes) !== null && _props$attributes !== void 0 && _props$attributes.formId)) { return null; } // Common event handlers. var handlers = app.common.getSettingsFieldsHandlers(props); return /*#__PURE__*/React.createElement(InspectorAdvancedControls, null, /*#__PURE__*/React.createElement("div", { className: app.common.getPanelClass(props) + ' advanced' }, /*#__PURE__*/React.createElement(TextareaControl, { className: "wpforms-gutenberg-form-selector-custom-css", label: strings.custom_css, rows: "5", spellCheck: "false", value: props.attributes.customCss, onChange: function onChange(value) { return handlers.attrChange('customCss', value); } }), /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-legend", dangerouslySetInnerHTML: { __html: strings.custom_css_notice } }), /*#__PURE__*/React.createElement(TextareaControl, { className: "wpforms-gutenberg-form-selector-copy-paste-settings", label: strings.copy_paste_settings, rows: "4", spellCheck: "false", value: props.attributes.copyPasteJsonValue, onChange: function onChange(value) { return handlers.pasteSettings(value); } }), /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-legend", dangerouslySetInnerHTML: { __html: strings.copy_paste_notice } }))); }, /** * Add controls on Advanced Settings Panel. * * @param {Function} BlockEdit Block edit component. * * @return {Function} BlockEdit Modified block edit component. */ withAdvancedControls: createHigherOrderComponent(function (BlockEdit) { return function (props) { return /*#__PURE__*/React.createElement(Fragment, null, /*#__PURE__*/React.createElement(BlockEdit, props), app.getFields(props)); }; }, 'withAdvancedControls') }; // Provide access to public functions/properties. return app; }(jQuery); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_default","exports","default","$","addFilter","wp","hooks","createHigherOrderComponent","compose","Fragment","element","_ref","blockEditor","editor","InspectorAdvancedControls","TextareaControl","components","_wpforms_gutenberg_fo","wpforms_gutenberg_form_selector","strings","app","init","commonModule","common","events","withAdvancedControls","document","on","copyPasteFocus","$input","siblings","text","copy_paste_settings","select","getFields","props","_props$attributes","name","attributes","formId","handlers","getSettingsFieldsHandlers","React","createElement","className","getPanelClass","label","custom_css","rows","spellCheck","value","customCss","onChange","attrChange","dangerouslySetInnerHTML","__html","custom_css_notice","copyPasteJsonValue","pasteSettings","copy_paste_notice","BlockEdit","jQuery"],"sources":["advanced-settings.js"],"sourcesContent":["/* global wpforms_gutenberg_form_selector */\n/* jshint es3: false, esversion: 6 */\n\n/**\n * @param strings.custom_css\n * @param strings.custom_css_notice\n * @param strings.copy_paste_settings\n * @param strings.copy_paste_notice\n */\n\n/**\n * Gutenberg editor block.\n *\n * Advanced Settings module.\n *\n * @since 1.8.8\n */\nexport default ( function( $ ) {\n\t/**\n\t * WP core components.\n\t *\n\t * @since 1.8.8\n\t */\n\tconst { addFilter } = wp.hooks;\n\tconst { createHigherOrderComponent } = wp.compose;\n\tconst { Fragment }\t= wp.element;\n\tconst { InspectorAdvancedControls } = wp.blockEditor || wp.editor;\n\tconst { TextareaControl } = wp.components;\n\n\t/**\n\t * Localized data aliases.\n\t *\n\t * @since 1.8.8\n\t */\n\tconst { strings } = wpforms_gutenberg_form_selector;\n\n\t/**\n\t * Public functions and properties.\n\t *\n\t * @since 1.8.8\n\t *\n\t * @type {Object}\n\t */\n\tconst app = {\n\t\t/**\n\t\t * Initialize module.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {Object} commonModule Common module.\n\t\t */\n\t\tinit( commonModule ) {\n\t\t\tapp.common = commonModule;\n\n\t\t\tapp.hooks();\n\t\t\tapp.events();\n\t\t},\n\n\t\t/**\n\t\t * Hooks.\n\t\t *\n\t\t * @since 1.8.8\n\t\t */\n\t\thooks() {\n\t\t\taddFilter(\n\t\t\t\t'editor.BlockEdit',\n\t\t\t\t'editorskit/custom-advanced-control',\n\t\t\t\tapp.withAdvancedControls\n\t\t\t);\n\t\t},\n\n\t\t/**\n\t\t * Events.\n\t\t *\n\t\t * @since 1.8.8\n\t\t */\n\t\tevents() {\n\t\t\t$( document )\n\t\t\t\t.on( 'focus click', 'textarea', app.copyPasteFocus );\n\t\t},\n\n\t\t/**\n\t\t * Copy / Paste Style Settings textarea focus event.\n\t\t *\n\t\t * @since 1.8.8\n\t\t */\n\t\tcopyPasteFocus() {\n\t\t\tconst $input = $( this );\n\n\t\t\tif ( $input.siblings( 'label' ).text() === strings.copy_paste_settings ) {\n\t\t\t\t// Select all text, so it's easier to copy and paste value.\n\t\t\t\t$input.select();\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Get fields.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {Object} props Block properties.\n\t\t *\n\t\t * @return {Object} Inspector advanced controls JSX code.\n\t\t */\n\t\tgetFields( props ) {\n\t\t\t// Proceed only for WPForms block and when form ID is set.\n\t\t\tif ( props?.name !== 'wpforms/form-selector' || ! props?.attributes?.formId ) {\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\t// Common event handlers.\n\t\t\tconst handlers = app.common.getSettingsFieldsHandlers( props );\n\n\t\t\treturn (\n\t\t\t\t<InspectorAdvancedControls>\n\t\t\t\t\t<div className={ app.common.getPanelClass( props ) + ' advanced' }>\n\t\t\t\t\t\t<TextareaControl\n\t\t\t\t\t\t\tclassName=\"wpforms-gutenberg-form-selector-custom-css\"\n\t\t\t\t\t\t\tlabel={ strings.custom_css }\n\t\t\t\t\t\t\trows=\"5\"\n\t\t\t\t\t\t\tspellCheck=\"false\"\n\t\t\t\t\t\t\tvalue={ props.attributes.customCss }\n\t\t\t\t\t\t\tonChange={ ( value ) => handlers.attrChange( 'customCss', value ) }\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<div className=\"wpforms-gutenberg-form-selector-legend\" dangerouslySetInnerHTML={ { __html: strings.custom_css_notice } }></div>\n\t\t\t\t\t\t<TextareaControl\n\t\t\t\t\t\t\tclassName=\"wpforms-gutenberg-form-selector-copy-paste-settings\"\n\t\t\t\t\t\t\tlabel={ strings.copy_paste_settings }\n\t\t\t\t\t\t\trows=\"4\"\n\t\t\t\t\t\t\tspellCheck=\"false\"\n\t\t\t\t\t\t\tvalue={ props.attributes.copyPasteJsonValue }\n\t\t\t\t\t\t\tonChange={ ( value ) => handlers.pasteSettings( value ) }\n\t\t\t\t\t\t/>\n\t\t\t\t\t\t<div className=\"wpforms-gutenberg-form-selector-legend\" dangerouslySetInnerHTML={ { __html: strings.copy_paste_notice } }></div>\n\t\t\t\t\t</div>\n\t\t\t\t</InspectorAdvancedControls>\n\t\t\t);\n\t\t},\n\n\t\t/**\n\t\t * Add controls on Advanced Settings Panel.\n\t\t *\n\t\t * @param {Function} BlockEdit Block edit component.\n\t\t *\n\t\t * @return {Function} BlockEdit Modified block edit component.\n\t\t */\n\t\twithAdvancedControls: createHigherOrderComponent(\n\t\t\t( BlockEdit ) => {\n\t\t\t\treturn ( props ) => {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<Fragment>\n\t\t\t\t\t\t\t<BlockEdit { ...props } />\n\t\t\t\t\t\t\t{ app.getFields( props ) }\n\t\t\t\t\t\t</Fragment>\n\t\t\t\t\t);\n\t\t\t\t};\n\t\t\t},\n\t\t\t'withAdvancedControls'\n\t\t),\n\t};\n\n\t// Provide access to public functions/properties.\n\treturn app;\n}( jQuery ) );\n"],"mappings":"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","ignoreList":[]} },{}],14:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _propTypes = _interopRequireDefault(require("prop-types")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } /* global wpforms_gutenberg_form_selector */ /* jshint es3: false, esversion: 6 */ /** * @param strings.remove_image */ /** * React component for the background preview. * * @since 1.8.8 * * @param {Object} props Component props. * @param {Object} props.attributes Block attributes. * @param {Function} props.onRemoveBackground Function to remove the background. * @param {Function} props.onPreviewClicked Function to handle the preview click. * * @return {Object} React component. */ var BackgroundPreview = function BackgroundPreview(_ref) { var attributes = _ref.attributes, onRemoveBackground = _ref.onRemoveBackground, onPreviewClicked = _ref.onPreviewClicked; var Button = wp.components.Button; var _wpforms_gutenberg_fo = wpforms_gutenberg_form_selector, strings = _wpforms_gutenberg_fo.strings; return /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-background-preview" }, /*#__PURE__*/React.createElement("style", null, "\n\t\t\t\t\t.wpforms-gutenberg-form-selector-background-preview-image {\n\t\t\t\t\t\t--wpforms-background-url: ".concat(attributes.backgroundUrl, ";\n\t\t\t\t\t}\n\t\t\t\t")), /*#__PURE__*/React.createElement("input", { className: "wpforms-gutenberg-form-selector-background-preview-image", onClick: onPreviewClicked, tabIndex: 0, type: "button", onKeyDown: function onKeyDown(event) { if (event.key === 'Enter' || event.key === ' ') { onPreviewClicked(); } } }), /*#__PURE__*/React.createElement(Button, { isSecondary: true, className: "is-destructive", onClick: onRemoveBackground }, strings.remove_image)); }; BackgroundPreview.propTypes = { attributes: _propTypes.default.object.isRequired, onRemoveBackground: _propTypes.default.func.isRequired, onPreviewClicked: _propTypes.default.func.isRequired }; var _default = exports.default = BackgroundPreview; //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcHJvcFR5cGVzIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJCYWNrZ3JvdW5kUHJldmlldyIsIl9yZWYiLCJhdHRyaWJ1dGVzIiwib25SZW1vdmVCYWNrZ3JvdW5kIiwib25QcmV2aWV3Q2xpY2tlZCIsIkJ1dHRvbiIsIndwIiwiY29tcG9uZW50cyIsIl93cGZvcm1zX2d1dGVuYmVyZ19mbyIsIndwZm9ybXNfZ3V0ZW5iZXJnX2Zvcm1fc2VsZWN0b3IiLCJzdHJpbmdzIiwiUmVhY3QiLCJjcmVhdGVFbGVtZW50IiwiY2xhc3NOYW1lIiwiY29uY2F0IiwiYmFja2dyb3VuZFVybCIsIm9uQ2xpY2siLCJ0YWJJbmRleCIsInR5cGUiLCJvbktleURvd24iLCJldmVudCIsImtleSIsImlzU2Vjb25kYXJ5IiwicmVtb3ZlX2ltYWdlIiwicHJvcFR5cGVzIiwiUHJvcFR5cGVzIiwib2JqZWN0IiwiaXNSZXF1aXJlZCIsImZ1bmMiLCJfZGVmYXVsdCIsImV4cG9ydHMiXSwic291cmNlcyI6WyJiYWNrZ3JvdW5kLXByZXZpZXcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZ2xvYmFsIHdwZm9ybXNfZ3V0ZW5iZXJnX2Zvcm1fc2VsZWN0b3IgKi9cbi8qIGpzaGludCBlczM6IGZhbHNlLCBlc3ZlcnNpb246IDYgKi9cblxuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcblxuLyoqXG4gKiBAcGFyYW0gc3RyaW5ncy5yZW1vdmVfaW1hZ2VcbiAqL1xuXG4vKipcbiAqIFJlYWN0IGNvbXBvbmVudCBmb3IgdGhlIGJhY2tncm91bmQgcHJldmlldy5cbiAqXG4gKiBAc2luY2UgMS44LjhcbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gICBwcm9wcyAgICAgICAgICAgICAgICAgICAgQ29tcG9uZW50IHByb3BzLlxuICogQHBhcmFtIHtPYmplY3R9ICAgcHJvcHMuYXR0cmlidXRlcyAgICAgICAgIEJsb2NrIGF0dHJpYnV0ZXMuXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBwcm9wcy5vblJlbW92ZUJhY2tncm91bmQgRnVuY3Rpb24gdG8gcmVtb3ZlIHRoZSBiYWNrZ3JvdW5kLlxuICogQHBhcmFtIHtGdW5jdGlvbn0gcHJvcHMub25QcmV2aWV3Q2xpY2tlZCAgIEZ1bmN0aW9uIHRvIGhhbmRsZSB0aGUgcHJldmlldyBjbGljay5cbiAqXG4gKiBAcmV0dXJuIHtPYmplY3R9IFJlYWN0IGNvbXBvbmVudC5cbiAqL1xuY29uc3QgQmFja2dyb3VuZFByZXZpZXcgPSAoIHsgYXR0cmlidXRlcywgb25SZW1vdmVCYWNrZ3JvdW5kLCBvblByZXZpZXdDbGlja2VkIH0gKSA9PiB7XG5cdGNvbnN0IHsgQnV0dG9uIH0gPSB3cC5jb21wb25lbnRzO1xuXHRjb25zdCB7IHN0cmluZ3MgfSA9IHdwZm9ybXNfZ3V0ZW5iZXJnX2Zvcm1fc2VsZWN0b3I7XG5cblx0cmV0dXJuIChcblx0XHQ8ZGl2IGNsYXNzTmFtZT1cIndwZm9ybXMtZ3V0ZW5iZXJnLWZvcm0tc2VsZWN0b3ItYmFja2dyb3VuZC1wcmV2aWV3XCI+XG5cdFx0XHQ8c3R5bGU+XG5cdFx0XHRcdHsgYFxuXHRcdFx0XHRcdC53cGZvcm1zLWd1dGVuYmVyZy1mb3JtLXNlbGVjdG9yLWJhY2tncm91bmQtcHJldmlldy1pbWFnZSB7XG5cdFx0XHRcdFx0XHQtLXdwZm9ybXMtYmFja2dyb3VuZC11cmw6ICR7IGF0dHJpYnV0ZXMuYmFja2dyb3VuZFVybCB9O1xuXHRcdFx0XHRcdH1cblx0XHRcdFx0YCB9XG5cdFx0XHQ8L3N0eWxlPlxuXHRcdFx0PGlucHV0XG5cdFx0XHRcdGNsYXNzTmFtZT1cIndwZm9ybXMtZ3V0ZW5iZXJnLWZvcm0tc2VsZWN0b3ItYmFja2dyb3VuZC1wcmV2aWV3LWltYWdlXCJcblx0XHRcdFx0b25DbGljaz17IG9uUHJldmlld0NsaWNrZWQgfVxuXHRcdFx0XHR0YWJJbmRleD17IDAgfVxuXHRcdFx0XHR0eXBlPVwiYnV0dG9uXCJcblx0XHRcdFx0b25LZXlEb3duPXtcblx0XHRcdFx0XHQoIGV2ZW50ICkgPT4ge1xuXHRcdFx0XHRcdFx0aWYgKCBldmVudC5rZXkgPT09ICdFbnRlcicgfHwgZXZlbnQua2V5ID09PSAnICcgKSB7XG5cdFx0XHRcdFx0XHRcdG9uUHJldmlld0NsaWNrZWQoKTtcblx0XHRcdFx0XHRcdH1cblx0XHRcdFx0XHR9XG5cdFx0XHRcdH1cblx0XHRcdD5cblx0XHRcdDwvaW5wdXQ+XG5cdFx0XHQ8QnV0dG9uXG5cdFx0XHRcdGlzU2Vjb25kYXJ5XG5cdFx0XHRcdGNsYXNzTmFtZT1cImlzLWRlc3RydWN0aXZlXCJcblx0XHRcdFx0b25DbGljaz17IG9uUmVtb3ZlQmFja2dyb3VuZCB9XG5cdFx0XHQ+XG5cdFx0XHRcdHsgc3RyaW5ncy5yZW1vdmVfaW1hZ2UgfVxuXHRcdFx0PC9CdXR0b24+XG5cdFx0PC9kaXY+XG5cdCk7XG59O1xuXG5CYWNrZ3JvdW5kUHJldmlldy5wcm9wVHlwZXMgPSB7XG5cdGF0dHJpYnV0ZXM6IFByb3BUeXBlcy5vYmplY3QuaXNSZXF1aXJlZCxcblx0b25SZW1vdmVCYWNrZ3JvdW5kOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxuXHRvblByZXZpZXdDbGlja2VkOiBQcm9wVHlwZXMuZnVuYy5pc1JlcXVpcmVkLFxufTtcblxuZXhwb3J0IGRlZmF1bHQgQmFja2dyb3VuZFByZXZpZXc7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUdBLElBQUFBLFVBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUFtQyxTQUFBRCx1QkFBQUUsQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUhuQztBQUNBOztBQUlBO0FBQ0E7QUFDQTs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxJQUFNRyxpQkFBaUIsR0FBRyxTQUFwQkEsaUJBQWlCQSxDQUFBQyxJQUFBLEVBQStEO0VBQUEsSUFBeERDLFVBQVUsR0FBQUQsSUFBQSxDQUFWQyxVQUFVO0lBQUVDLGtCQUFrQixHQUFBRixJQUFBLENBQWxCRSxrQkFBa0I7SUFBRUMsZ0JBQWdCLEdBQUFILElBQUEsQ0FBaEJHLGdCQUFnQjtFQUM3RSxJQUFRQyxNQUFNLEdBQUtDLEVBQUUsQ0FBQ0MsVUFBVSxDQUF4QkYsTUFBTTtFQUNkLElBQUFHLHFCQUFBLEdBQW9CQywrQkFBK0I7SUFBM0NDLE9BQU8sR0FBQUYscUJBQUEsQ0FBUEUsT0FBTztFQUVmLG9CQUNDQyxLQUFBLENBQUFDLGFBQUE7SUFBS0MsU0FBUyxFQUFDO0VBQW9ELGdCQUNsRUYsS0FBQSxDQUFBQyxhQUFBLGtJQUFBRSxNQUFBLENBR2dDWixVQUFVLENBQUNhLGFBQWEsNkJBR2pELENBQUMsZUFDUkosS0FBQSxDQUFBQyxhQUFBO0lBQ0NDLFNBQVMsRUFBQywwREFBMEQ7SUFDcEVHLE9BQU8sRUFBR1osZ0JBQWtCO0lBQzVCYSxRQUFRLEVBQUcsQ0FBRztJQUNkQyxJQUFJLEVBQUMsUUFBUTtJQUNiQyxTQUFTLEVBQ1IsU0FEREEsU0FBU0EsQ0FDTkMsS0FBSyxFQUFNO01BQ1osSUFBS0EsS0FBSyxDQUFDQyxHQUFHLEtBQUssT0FBTyxJQUFJRCxLQUFLLENBQUNDLEdBQUcsS0FBSyxHQUFHLEVBQUc7UUFDakRqQixnQkFBZ0IsQ0FBQyxDQUFDO01BQ25CO0lBQ0Q7RUFDQSxDQUVLLENBQUMsZUFDUk8sS0FBQSxDQUFBQyxhQUFBLENBQUNQLE1BQU07SUFDTmlCLFdBQVc7SUFDWFQsU0FBUyxFQUFDLGdCQUFnQjtJQUMxQkcsT0FBTyxFQUFHYjtFQUFvQixHQUU1Qk8sT0FBTyxDQUFDYSxZQUNILENBQ0osQ0FBQztBQUVSLENBQUM7QUFFRHZCLGlCQUFpQixDQUFDd0IsU0FBUyxHQUFHO0VBQzdCdEIsVUFBVSxFQUFFdUIsa0JBQVMsQ0FBQ0MsTUFBTSxDQUFDQyxVQUFVO0VBQ3ZDeEIsa0JBQWtCLEVBQUVzQixrQkFBUyxDQUFDRyxJQUFJLENBQUNELFVBQVU7RUFDN0N2QixnQkFBZ0IsRUFBRXFCLGtCQUFTLENBQUNHLElBQUksQ0FBQ0Q7QUFDbEMsQ0FBQztBQUFDLElBQUFFLFFBQUEsR0FBQUMsT0FBQSxDQUFBL0IsT0FBQSxHQUVhQyxpQkFBaUIiLCJpZ25vcmVMaXN0IjpbXX0= },{"prop-types":6}],15:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _backgroundPreview = _interopRequireDefault(require("./background-preview.js")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } /* global wpforms_gutenberg_form_selector */ /* jshint es3: false, esversion: 6 */ /** * @param strings.background_styles * @param strings.bottom_center * @param strings.bottom_left * @param strings.bottom_right * @param strings.center_center * @param strings.center_left * @param strings.center_right * @param strings.choose_image * @param strings.image_url * @param strings.media_library * @param strings.no_repeat * @param strings.repeat_x * @param strings.repeat_y * @param strings.select_background_image * @param strings.select_image * @param strings.stock_photo * @param strings.tile * @param strings.top_center * @param strings.top_left * @param strings.top_right */ /** * Gutenberg editor block. * * Background styles panel module. * * @since 1.8.8 */ var _default = exports.default = function () { /** * WP core components. * * @since 1.8.8 */ var _ref = wp.blockEditor || wp.editor, PanelColorSettings = _ref.PanelColorSettings; var _wp$components = wp.components, SelectControl = _wp$components.SelectControl, PanelBody = _wp$components.PanelBody, Flex = _wp$components.Flex, FlexBlock = _wp$components.FlexBlock, __experimentalUnitControl = _wp$components.__experimentalUnitControl, TextControl = _wp$components.TextControl, Button = _wp$components.Button; /** * Localized data aliases. * * @since 1.8.8 */ var _wpforms_gutenberg_fo = wpforms_gutenberg_form_selector, strings = _wpforms_gutenberg_fo.strings, defaults = _wpforms_gutenberg_fo.defaults; /** * Public functions and properties. * * @since 1.8.8 * * @type {Object} */ var app = { /** * Get block attributes. * * @since 1.8.8 * * @return {Object} Block attributes. */ getBlockAttributes: function getBlockAttributes() { return { backgroundImage: { type: 'string', default: defaults.backgroundImage }, backgroundPosition: { type: 'string', default: defaults.backgroundPosition }, backgroundRepeat: { type: 'string', default: defaults.backgroundRepeat }, backgroundSizeMode: { type: 'string', default: defaults.backgroundSizeMode }, backgroundSize: { type: 'string', default: defaults.backgroundSize }, backgroundWidth: { type: 'string', default: defaults.backgroundWidth }, backgroundHeight: { type: 'string', default: defaults.backgroundHeight }, backgroundColor: { type: 'string', default: defaults.backgroundColor }, backgroundUrl: { type: 'string', default: defaults.backgroundUrl } }; }, /** * Get Background Styles panel JSX code. * * @since 1.8.8 * * @param {Object} props Block properties. * @param {Object} handlers Block handlers. * @param {Object} formSelectorCommon Block properties. * @param {Object} stockPhotos Stock Photos module. * @param {Object} uiState UI state. * * @return {Object} Field styles JSX code. */ getBackgroundStyles: function getBackgroundStyles(props, handlers, formSelectorCommon, stockPhotos, uiState) { // eslint-disable-line max-lines-per-function, complexity var isNotDisabled = uiState.isNotDisabled; var isProEnabled = uiState.isProEnabled; var showBackgroundPreview = uiState.showBackgroundPreview; var setShowBackgroundPreview = uiState.setShowBackgroundPreview; var lastBgImage = uiState.lastBgImage; var setLastBgImage = uiState.setLastBgImage; var tabIndex = isNotDisabled ? 0 : -1; var cssClass = formSelectorCommon.getPanelClass(props) + (isNotDisabled ? '' : ' wpforms-gutenberg-panel-disabled'); return /*#__PURE__*/React.createElement(PanelBody, { className: cssClass, title: strings.background_styles }, /*#__PURE__*/React.createElement("div", { // eslint-disable-line jsx-a11y/no-static-element-interactions className: "wpforms-gutenberg-form-selector-panel-body", onClick: function onClick(event) { if (isNotDisabled) { return; } event.stopPropagation(); if (!isProEnabled) { return formSelectorCommon.education.showProModal('background', strings.background_styles); } formSelectorCommon.education.showLicenseModal('background', strings.background_styles, 'background-styles'); }, onKeyDown: function onKeyDown(event) { if (isNotDisabled) { return; } event.stopPropagation(); if (!isProEnabled) { return formSelectorCommon.education.showProModal('background', strings.background_styles); } formSelectorCommon.education.showLicenseModal('background', strings.background_styles, 'background-styles'); } }, /*#__PURE__*/React.createElement(Flex, { gap: 4, align: "flex-start", className: 'wpforms-gutenberg-form-selector-flex', justify: "space-between" }, /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(SelectControl, { label: strings.image, tabIndex: tabIndex, value: props.attributes.backgroundImage, options: [{ label: strings.none, value: 'none' }, { label: strings.media_library, value: 'library' }, { label: strings.stock_photo, value: 'stock' }], onChange: function onChange(value) { return app.setContainerBackgroundImageWrapper(props, handlers, value, lastBgImage, setLastBgImage); } })), /*#__PURE__*/React.createElement(FlexBlock, null, (props.attributes.backgroundImage !== 'none' || !isNotDisabled) && /*#__PURE__*/React.createElement(SelectControl, { label: strings.position, value: props.attributes.backgroundPosition, tabIndex: tabIndex, options: [{ label: strings.top_left, value: 'top left' }, { label: strings.top_center, value: 'top center' }, { label: strings.top_right, value: 'top right' }, { label: strings.center_left, value: 'center left' }, { label: strings.center_center, value: 'center center' }, { label: strings.center_right, value: 'center right' }, { label: strings.bottom_left, value: 'bottom left' }, { label: strings.bottom_center, value: 'bottom center' }, { label: strings.bottom_right, value: 'bottom right' }], disabled: props.attributes.backgroundImage === 'none' && isNotDisabled, onChange: function onChange(value) { return handlers.styleAttrChange('backgroundPosition', value); } }))), (props.attributes.backgroundImage !== 'none' || !isNotDisabled) && /*#__PURE__*/React.createElement(Flex, { gap: 4, align: "flex-start", className: 'wpforms-gutenberg-form-selector-flex', justify: "space-between" }, /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(SelectControl, { label: strings.repeat, tabIndex: tabIndex, value: props.attributes.backgroundRepeat, options: [{ label: strings.no_repeat, value: 'no-repeat' }, { label: strings.tile, value: 'repeat' }, { label: strings.repeat_x, value: 'repeat-x' }, { label: strings.repeat_y, value: 'repeat-y' }], disabled: props.attributes.backgroundImage === 'none' && isNotDisabled, onChange: function onChange(value) { return handlers.styleAttrChange('backgroundRepeat', value); } })), /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(SelectControl, { label: strings.size, tabIndex: tabIndex, value: props.attributes.backgroundSizeMode, options: [{ label: strings.dimensions, value: 'dimensions' }, { label: strings.cover, value: 'cover' }], disabled: props.attributes.backgroundImage === 'none' && isNotDisabled, onChange: function onChange(value) { return app.handleSizeFromDimensions(props, handlers, value); } }))), (props.attributes.backgroundSizeMode === 'dimensions' && props.attributes.backgroundImage !== 'none' || !isNotDisabled) && /*#__PURE__*/React.createElement(Flex, { gap: 4, align: "flex-start", className: 'wpforms-gutenberg-form-selector-flex', justify: "space-between" }, /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(__experimentalUnitControl, { label: strings.width, tabIndex: tabIndex, value: props.attributes.backgroundWidth, isUnitSelectTabbable: isNotDisabled, onChange: function onChange(value) { return app.handleSizeFromWidth(props, handlers, value); } })), /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(__experimentalUnitControl, { label: strings.height, tabIndex: tabIndex, value: props.attributes.backgroundHeight, isUnitSelectTabbable: isNotDisabled, onChange: function onChange(value) { return app.handleSizeFromHeight(props, handlers, value); } }))), (!showBackgroundPreview || props.attributes.backgroundUrl === 'url()') && (props.attributes.backgroundImage === 'library' && /*#__PURE__*/React.createElement(Flex, { gap: 4, align: "flex-start", className: 'wpforms-gutenberg-form-selector-flex', justify: "space-between" }, /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(Button, { isSecondary: true, tabIndex: tabIndex, className: 'wpforms-gutenberg-form-selector-media-library-button', onClick: app.openMediaLibrary.bind(null, props, handlers, setShowBackgroundPreview) }, strings.choose_image))) || props.attributes.backgroundImage === 'stock' && /*#__PURE__*/React.createElement(Flex, { gap: 4, align: "flex-start", className: 'wpforms-gutenberg-form-selector-flex', justify: "space-between" }, /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(Button, { isSecondary: true, tabIndex: tabIndex, className: 'wpforms-gutenberg-form-selector-media-library-button', onClick: stockPhotos === null || stockPhotos === void 0 ? void 0 : stockPhotos.openModal.bind(null, props, handlers, 'bg-styles', setShowBackgroundPreview) }, strings.choose_image)))), (showBackgroundPreview && props.attributes.backgroundImage !== 'none' || props.attributes.backgroundUrl !== 'url()') && /*#__PURE__*/React.createElement(Flex, { gap: 4, align: "flex-start", className: 'wpforms-gutenberg-form-selector-flex', justify: "space-between" }, /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(_backgroundPreview.default, { attributes: props.attributes, onRemoveBackground: function onRemoveBackground() { app.onRemoveBackground(setShowBackgroundPreview, handlers, setLastBgImage); }, onPreviewClicked: function onPreviewClicked() { if (props.attributes.backgroundImage === 'library') { return app.openMediaLibrary(props, handlers, setShowBackgroundPreview); } return stockPhotos === null || stockPhotos === void 0 ? void 0 : stockPhotos.openModal(props, handlers, 'bg-styles', setShowBackgroundPreview); } })), /*#__PURE__*/React.createElement(TextControl, { label: strings.image_url, tabIndex: tabIndex, value: props.attributes.backgroundImage !== 'none' && props.attributes.backgroundUrl, className: 'wpforms-gutenberg-form-selector-image-url', onChange: function onChange(value) { return handlers.styleAttrChange('backgroundUrl', value); }, onLoad: function onLoad(value) { return props.attributes.backgroundImage !== 'none' && handlers.styleAttrChange('backgroundUrl', value); } }))), /*#__PURE__*/React.createElement(Flex, { gap: 4, align: "flex-start", className: 'wpforms-gutenberg-form-selector-flex', justify: "space-between" }, /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-control-label" }, strings.colors), /*#__PURE__*/React.createElement(PanelColorSettings, { __experimentalIsRenderedInSidebar: true, enableAlpha: true, showTitle: false, tabIndex: tabIndex, className: "wpforms-gutenberg-form-selector-color-panel", colorSettings: [{ value: props.attributes.backgroundColor, onChange: function onChange(value) { if (!isNotDisabled) { return; } handlers.styleAttrChange('backgroundColor', value); }, label: strings.background }] }))))); }, /** * Open media library modal and handle image selection. * * @since 1.8.8 * * @param {Object} props Block properties. * @param {Object} handlers Block handlers. * @param {Function} setShowBackgroundPreview Set show background preview. */ openMediaLibrary: function openMediaLibrary(props, handlers, setShowBackgroundPreview) { var frame = wp.media({ title: strings.select_background_image, multiple: false, library: { type: 'image' }, button: { text: strings.select_image } }); frame.on('select', function () { var attachment = frame.state().get('selection').first().toJSON(); var setAttr = {}; var attribute = 'backgroundUrl'; if (attachment.url) { var value = "url(".concat(attachment.url, ")"); setAttr[attribute] = value; props.setAttributes(setAttr); handlers.styleAttrChange('backgroundUrl', value); setShowBackgroundPreview(true); } }); frame.open(); }, /** * Set container background image. * * @since 1.8.8 * * @param {HTMLElement} container Container element. * @param {string} value Value. * * @return {boolean} True if the value was set, false otherwise. */ setContainerBackgroundImage: function setContainerBackgroundImage(container, value) { if (value === 'none') { container.style.setProperty("--wpforms-background-url", 'url()'); } return true; }, /** * Set container background image. * * @since 1.8.8 * * @param {Object} props Block properties. * @param {Object} handlers Block event handlers. * @param {string} value Value. * @param {string} lastBgImage Last background image. * @param {Function} setLastBgImage Set last background image. */ setContainerBackgroundImageWrapper: function setContainerBackgroundImageWrapper(props, handlers, value, lastBgImage, setLastBgImage) { if (value === 'none') { setLastBgImage(props.attributes.backgroundUrl); props.attributes.backgroundUrl = 'url()'; handlers.styleAttrChange('backgroundUrl', 'url()'); } else if (lastBgImage) { props.attributes.backgroundUrl = lastBgImage; handlers.styleAttrChange('backgroundUrl', lastBgImage); } handlers.styleAttrChange('backgroundImage', value); }, /** * Set container background position. * * @since 1.8.8 * * @param {HTMLElement} container Container element. * @param {string} value Value. * * @return {boolean} True if the value was set, false otherwise. */ setContainerBackgroundPosition: function setContainerBackgroundPosition(container, value) { container.style.setProperty("--wpforms-background-position", value); return true; }, /** * Set container background repeat. * * @since 1.8.8 * * @param {HTMLElement} container Container element. * @param {string} value Value. * * @return {boolean} True if the value was set, false otherwise. */ setContainerBackgroundRepeat: function setContainerBackgroundRepeat(container, value) { container.style.setProperty("--wpforms-background-repeat", value); return true; }, /** * Handle real size from dimensions. * * @since 1.8.8 * * @param {Object} props Block properties. * @param {Object} handlers Block handlers. * @param {string} value Value. */ handleSizeFromDimensions: function handleSizeFromDimensions(props, handlers, value) { if (value === 'cover') { props.attributes.backgroundSize = 'cover'; handlers.styleAttrChange('backgroundWidth', props.attributes.backgroundWidth); handlers.styleAttrChange('backgroundHeight', props.attributes.backgroundHeight); handlers.styleAttrChange('backgroundSizeMode', 'cover'); handlers.styleAttrChange('backgroundSize', 'cover'); } else { props.attributes.backgroundSize = 'dimensions'; handlers.styleAttrChange('backgroundSizeMode', 'dimensions'); handlers.styleAttrChange('backgroundSize', props.attributes.backgroundWidth + ' ' + props.attributes.backgroundHeight); } }, /** * Handle real size from width. * * @since 1.8.8 * * @param {Object} props Block properties. * @param {Object} handlers Block handlers. * @param {string} value Value. */ handleSizeFromWidth: function handleSizeFromWidth(props, handlers, value) { props.attributes.backgroundSize = value + ' ' + props.attributes.backgroundHeight; props.attributes.backgroundWidth = value; handlers.styleAttrChange('backgroundSize', value + ' ' + props.attributes.backgroundHeight); handlers.styleAttrChange('backgroundWidth', value); }, /** * Handle real size from height. * * @since 1.8.8 * * @param {Object} props Block properties. * @param {Object} handlers Block handlers. * @param {string} value Value. */ handleSizeFromHeight: function handleSizeFromHeight(props, handlers, value) { props.attributes.backgroundSize = props.attributes.backgroundWidth + ' ' + value; props.attributes.backgroundHeight = value; handlers.styleAttrChange('backgroundSize', props.attributes.backgroundWidth + ' ' + value); handlers.styleAttrChange('backgroundHeight', value); }, /** * Set container background width. * * @since 1.8.8 * * @param {HTMLElement} container Container element. * @param {string} value Value. * * @return {boolean} True if the value was set, false otherwise. */ setContainerBackgroundWidth: function setContainerBackgroundWidth(container, value) { container.style.setProperty("--wpforms-background-width", value); return true; }, /** * Set container background height. * * @since 1.8.8 * * @param {HTMLElement} container Container element. * @param {string} value Value. * * @return {boolean} True if the value was set, false otherwise. */ setContainerBackgroundHeight: function setContainerBackgroundHeight(container, value) { container.style.setProperty("--wpforms-background-height", value); return true; }, /** * Set container background url. * * @since 1.8.8 * * @param {HTMLElement} container Container element. * @param {string} value Value. * * @return {boolean} True if the value was set, false otherwise. */ setBackgroundUrl: function setBackgroundUrl(container, value) { container.style.setProperty("--wpforms-background-url", value); return true; }, /** * Set container background color. * * @since 1.8.8 * * @param {HTMLElement} container Container element. * @param {string} value Value. * * @return {boolean} True if the value was set, false otherwise. */ setBackgroundColor: function setBackgroundColor(container, value) { container.style.setProperty("--wpforms-background-color", value); return true; }, _showBackgroundPreview: function _showBackgroundPreview(props) { return props.attributes.backgroundImage !== 'none' && props.attributes.backgroundUrl && props.attributes.backgroundUrl !== 'url()'; }, /** * Remove background image. * * @since 1.8.8 * * @param {Function} setShowBackgroundPreview Set show background preview. * @param {Object} handlers Block handlers. * @param {Function} setLastBgImage Set last background image. */ onRemoveBackground: function onRemoveBackground(setShowBackgroundPreview, handlers, setLastBgImage) { setShowBackgroundPreview(false); handlers.styleAttrChange('backgroundUrl', 'url()'); setLastBgImage(''); } }; return app; }(); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_backgroundPreview","_interopRequireDefault","require","e","__esModule","default","_default","exports","_ref","wp","blockEditor","editor","PanelColorSettings","_wp$components","components","SelectControl","PanelBody","Flex","FlexBlock","__experimentalUnitControl","TextControl","Button","_wpforms_gutenberg_fo","wpforms_gutenberg_form_selector","strings","defaults","app","getBlockAttributes","backgroundImage","type","backgroundPosition","backgroundRepeat","backgroundSizeMode","backgroundSize","backgroundWidth","backgroundHeight","backgroundColor","backgroundUrl","getBackgroundStyles","props","handlers","formSelectorCommon","stockPhotos","uiState","isNotDisabled","isProEnabled","showBackgroundPreview","setShowBackgroundPreview","lastBgImage","setLastBgImage","tabIndex","cssClass","getPanelClass","React","createElement","className","title","background_styles","onClick","event","stopPropagation","education","showProModal","showLicenseModal","onKeyDown","gap","align","justify","label","image","value","attributes","options","none","media_library","stock_photo","onChange","setContainerBackgroundImageWrapper","position","top_left","top_center","top_right","center_left","center_center","center_right","bottom_left","bottom_center","bottom_right","disabled","styleAttrChange","repeat","no_repeat","tile","repeat_x","repeat_y","size","dimensions","cover","handleSizeFromDimensions","width","isUnitSelectTabbable","handleSizeFromWidth","height","handleSizeFromHeight","isSecondary","openMediaLibrary","bind","choose_image","openModal","onRemoveBackground","onPreviewClicked","image_url","onLoad","colors","__experimentalIsRenderedInSidebar","enableAlpha","showTitle","colorSettings","background","frame","media","select_background_image","multiple","library","button","text","select_image","on","attachment","state","get","first","toJSON","setAttr","attribute","url","concat","setAttributes","open","setContainerBackgroundImage","container","style","setProperty","setContainerBackgroundPosition","setContainerBackgroundRepeat","setContainerBackgroundWidth","setContainerBackgroundHeight","setBackgroundUrl","setBackgroundColor","_showBackgroundPreview"],"sources":["background-styles.js"],"sourcesContent":["/* global wpforms_gutenberg_form_selector */\n/* jshint es3: false, esversion: 6 */\n\nimport BackgroundPreview from './background-preview.js';\n\n/**\n * @param strings.background_styles\n * @param strings.bottom_center\n * @param strings.bottom_left\n * @param strings.bottom_right\n * @param strings.center_center\n * @param strings.center_left\n * @param strings.center_right\n * @param strings.choose_image\n * @param strings.image_url\n * @param strings.media_library\n * @param strings.no_repeat\n * @param strings.repeat_x\n * @param strings.repeat_y\n * @param strings.select_background_image\n * @param strings.select_image\n * @param strings.stock_photo\n * @param strings.tile\n * @param strings.top_center\n * @param strings.top_left\n * @param strings.top_right\n */\n\n/**\n * Gutenberg editor block.\n *\n * Background styles panel module.\n *\n * @since 1.8.8\n */\nexport default ( function() {\n\t/**\n\t * WP core components.\n\t *\n\t * @since 1.8.8\n\t */\n\tconst { PanelColorSettings } = wp.blockEditor || wp.editor;\n\tconst { SelectControl, PanelBody, Flex, FlexBlock, __experimentalUnitControl, TextControl, Button } = wp.components;\n\n\t/**\n\t * Localized data aliases.\n\t *\n\t * @since 1.8.8\n\t */\n\tconst { strings, defaults } = wpforms_gutenberg_form_selector;\n\n\t/**\n\t * Public functions and properties.\n\t *\n\t * @since 1.8.8\n\t *\n\t * @type {Object}\n\t */\n\tconst app = {\n\n\t\t/**\n\t\t * Get block attributes.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @return {Object} Block attributes.\n\t\t */\n\t\tgetBlockAttributes() {\n\t\t\treturn {\n\t\t\t\tbackgroundImage: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.backgroundImage,\n\t\t\t\t},\n\t\t\t\tbackgroundPosition: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.backgroundPosition,\n\t\t\t\t},\n\t\t\t\tbackgroundRepeat: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.backgroundRepeat,\n\t\t\t\t},\n\t\t\t\tbackgroundSizeMode: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.backgroundSizeMode,\n\t\t\t\t},\n\t\t\t\tbackgroundSize: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.backgroundSize,\n\t\t\t\t},\n\t\t\t\tbackgroundWidth: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.backgroundWidth,\n\t\t\t\t},\n\t\t\t\tbackgroundHeight: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.backgroundHeight,\n\t\t\t\t},\n\t\t\t\tbackgroundColor: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.backgroundColor,\n\t\t\t\t},\n\t\t\t\tbackgroundUrl: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.backgroundUrl,\n\t\t\t\t},\n\t\t\t};\n\t\t},\n\n\t\t/**\n\t\t * Get Background Styles panel JSX code.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {Object} props              Block properties.\n\t\t * @param {Object} handlers           Block handlers.\n\t\t * @param {Object} formSelectorCommon Block properties.\n\t\t * @param {Object} stockPhotos        Stock Photos module.\n\t\t * @param {Object} uiState            UI state.\n\t\t *\n\t\t * @return {Object} Field styles JSX code.\n\t\t */\n\t\tgetBackgroundStyles( props, handlers, formSelectorCommon, stockPhotos, uiState ) { // eslint-disable-line max-lines-per-function, complexity\n\t\t\tconst isNotDisabled = uiState.isNotDisabled;\n\t\t\tconst isProEnabled = uiState.isProEnabled;\n\t\t\tconst showBackgroundPreview = uiState.showBackgroundPreview;\n\t\t\tconst setShowBackgroundPreview = uiState.setShowBackgroundPreview;\n\t\t\tconst lastBgImage = uiState.lastBgImage;\n\t\t\tconst setLastBgImage = uiState.setLastBgImage;\n\t\t\tconst tabIndex = isNotDisabled ? 0 : -1;\n\t\t\tconst cssClass = formSelectorCommon.getPanelClass( props ) + ( isNotDisabled ? '' : ' wpforms-gutenberg-panel-disabled' );\n\n\t\t\treturn (\n\t\t\t\t<PanelBody className={ cssClass } title={ strings.background_styles }>\n\t\t\t\t\t<div // eslint-disable-line jsx-a11y/no-static-element-interactions\n\t\t\t\t\t\tclassName=\"wpforms-gutenberg-form-selector-panel-body\"\n\t\t\t\t\t\tonClick={ ( event ) => {\n\t\t\t\t\t\t\tif ( isNotDisabled ) {\n\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tevent.stopPropagation();\n\n\t\t\t\t\t\t\tif ( ! isProEnabled ) {\n\t\t\t\t\t\t\t\treturn formSelectorCommon.education.showProModal( 'background', strings.background_styles );\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tformSelectorCommon.education.showLicenseModal( 'background', strings.background_styles, 'background-styles' );\n\t\t\t\t\t\t} }\n\t\t\t\t\t\tonKeyDown={ ( event ) => {\n\t\t\t\t\t\t\tif ( isNotDisabled ) {\n\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tevent.stopPropagation();\n\n\t\t\t\t\t\t\tif ( ! isProEnabled ) {\n\t\t\t\t\t\t\t\treturn formSelectorCommon.education.showProModal( 'background', strings.background_styles );\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tformSelectorCommon.education.showLicenseModal( 'background', strings.background_styles, 'background-styles' );\n\t\t\t\t\t\t} }\n\t\t\t\t\t>\n\t\t\t\t\t\t<Flex gap={ 4 } align=\"flex-start\" className={ 'wpforms-gutenberg-form-selector-flex' } justify=\"space-between\">\n\t\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t\t<SelectControl\n\t\t\t\t\t\t\t\t\tlabel={ strings.image }\n\t\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\t\tvalue={ props.attributes.backgroundImage }\n\t\t\t\t\t\t\t\t\toptions={ [\n\t\t\t\t\t\t\t\t\t\t{ label: strings.none, value: 'none' },\n\t\t\t\t\t\t\t\t\t\t{ label: strings.media_library, value: 'library' },\n\t\t\t\t\t\t\t\t\t\t{ label: strings.stock_photo, value: 'stock' },\n\t\t\t\t\t\t\t\t\t] }\n\t\t\t\t\t\t\t\t\tonChange={ ( value ) => app.setContainerBackgroundImageWrapper( props, handlers, value, lastBgImage, setLastBgImage ) }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t\t{ ( props.attributes.backgroundImage !== 'none' || ! isNotDisabled ) && (\n\t\t\t\t\t\t\t\t\t<SelectControl\n\t\t\t\t\t\t\t\t\t\tlabel={ strings.position }\n\t\t\t\t\t\t\t\t\t\tvalue={ props.attributes.backgroundPosition }\n\t\t\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\t\t\toptions={ [\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.top_left, value: 'top left' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.top_center, value: 'top center' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.top_right, value: 'top right' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.center_left, value: 'center left' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.center_center, value: 'center center' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.center_right, value: 'center right' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.bottom_left, value: 'bottom left' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.bottom_center, value: 'bottom center' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.bottom_right, value: 'bottom right' },\n\t\t\t\t\t\t\t\t\t\t] }\n\t\t\t\t\t\t\t\t\t\tdisabled={ ( props.attributes.backgroundImage === 'none' && isNotDisabled ) }\n\t\t\t\t\t\t\t\t\t\tonChange={ ( value ) => handlers.styleAttrChange( 'backgroundPosition', value ) }\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t</Flex>\n\t\t\t\t\t\t{ ( props.attributes.backgroundImage !== 'none' || ! isNotDisabled ) && (\n\t\t\t\t\t\t\t<Flex gap={ 4 } align=\"flex-start\" className={ 'wpforms-gutenberg-form-selector-flex' } justify=\"space-between\">\n\t\t\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t\t\t<SelectControl\n\t\t\t\t\t\t\t\t\t\tlabel={ strings.repeat }\n\t\t\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\t\t\tvalue={ props.attributes.backgroundRepeat }\n\t\t\t\t\t\t\t\t\t\toptions={ [\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.no_repeat, value: 'no-repeat' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.tile, value: 'repeat' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.repeat_x, value: 'repeat-x' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.repeat_y, value: 'repeat-y' },\n\t\t\t\t\t\t\t\t\t\t] }\n\t\t\t\t\t\t\t\t\t\tdisabled={ ( props.attributes.backgroundImage === 'none' && isNotDisabled ) }\n\t\t\t\t\t\t\t\t\t\tonChange={ ( value ) => handlers.styleAttrChange( 'backgroundRepeat', value ) }\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t\t\t<SelectControl\n\t\t\t\t\t\t\t\t\t\tlabel={ strings.size }\n\t\t\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\t\t\tvalue={ props.attributes.backgroundSizeMode }\n\t\t\t\t\t\t\t\t\t\toptions={ [\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.dimensions, value: 'dimensions' },\n\t\t\t\t\t\t\t\t\t\t\t{ label: strings.cover, value: 'cover' },\n\t\t\t\t\t\t\t\t\t\t] }\n\t\t\t\t\t\t\t\t\t\tdisabled={ ( props.attributes.backgroundImage === 'none' && isNotDisabled ) }\n\t\t\t\t\t\t\t\t\t\tonChange={ ( value ) => app.handleSizeFromDimensions( props, handlers, value ) }\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t\t</Flex>\n\t\t\t\t\t\t) }\n\t\t\t\t\t\t{ ( ( props.attributes.backgroundSizeMode === 'dimensions' && props.attributes.backgroundImage !== 'none' ) || ! isNotDisabled ) && (\n\t\t\t\t\t\t\t<Flex gap={ 4 } align=\"flex-start\" className={ 'wpforms-gutenberg-form-selector-flex' } justify=\"space-between\">\n\t\t\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t\t\t<__experimentalUnitControl\n\t\t\t\t\t\t\t\t\t\tlabel={ strings.width }\n\t\t\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\t\t\tvalue={ props.attributes.backgroundWidth }\n\t\t\t\t\t\t\t\t\t\tisUnitSelectTabbable={ isNotDisabled }\n\t\t\t\t\t\t\t\t\t\tonChange={ ( value ) => app.handleSizeFromWidth( props, handlers, value ) }\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t\t\t<__experimentalUnitControl\n\t\t\t\t\t\t\t\t\t\tlabel={ strings.height }\n\t\t\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\t\t\tvalue={ props.attributes.backgroundHeight }\n\t\t\t\t\t\t\t\t\t\tisUnitSelectTabbable={ isNotDisabled }\n\t\t\t\t\t\t\t\t\t\tonChange={ ( value ) => app.handleSizeFromHeight( props, handlers, value ) }\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t\t</Flex>\n\t\t\t\t\t\t) }\n\t\t\t\t\t\t{ ( ! showBackgroundPreview || props.attributes.backgroundUrl === 'url()' ) && (\n\t\t\t\t\t\t\t( props.attributes.backgroundImage === 'library' && (\n\t\t\t\t\t\t\t\t<Flex gap={ 4 } align=\"flex-start\" className={ 'wpforms-gutenberg-form-selector-flex' } justify=\"space-between\">\n\t\t\t\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t\t\tisSecondary\n\t\t\t\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\t\t\t\tclassName={ 'wpforms-gutenberg-form-selector-media-library-button' }\n\t\t\t\t\t\t\t\t\t\t\tonClick={ app.openMediaLibrary.bind( null, props, handlers, setShowBackgroundPreview ) }\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t{ strings.choose_image }\n\t\t\t\t\t\t\t\t\t\t</Button>\n\t\t\t\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t\t\t</Flex>\n\t\t\t\t\t\t\t) ) || ( props.attributes.backgroundImage === 'stock' && (\n\t\t\t\t\t\t\t\t<Flex gap={ 4 } align=\"flex-start\" className={ 'wpforms-gutenberg-form-selector-flex' } justify=\"space-between\">\n\t\t\t\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t\t\tisSecondary\n\t\t\t\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\t\t\t\tclassName={ 'wpforms-gutenberg-form-selector-media-library-button' }\n\t\t\t\t\t\t\t\t\t\t\tonClick={ stockPhotos?.openModal.bind( null, props, handlers, 'bg-styles', setShowBackgroundPreview ) }\n\t\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t\t{ strings.choose_image }\n\t\t\t\t\t\t\t\t\t\t</Button>\n\t\t\t\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t\t\t</Flex>\n\t\t\t\t\t\t\t) )\n\t\t\t\t\t\t) }\n\t\t\t\t\t\t{ ( ( showBackgroundPreview && props.attributes.backgroundImage !== 'none' ) || props.attributes.backgroundUrl !== 'url()' ) && (\n\t\t\t\t\t\t\t<Flex gap={ 4 } align=\"flex-start\" className={ 'wpforms-gutenberg-form-selector-flex' } justify=\"space-between\">\n\t\t\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t\t\t<div>\n\t\t\t\t\t\t\t\t\t\t<BackgroundPreview\n\t\t\t\t\t\t\t\t\t\t\tattributes={ props.attributes }\n\t\t\t\t\t\t\t\t\t\t\tonRemoveBackground={\n\t\t\t\t\t\t\t\t\t\t\t\t() => {\n\t\t\t\t\t\t\t\t\t\t\t\t\tapp.onRemoveBackground( setShowBackgroundPreview, handlers, setLastBgImage );\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\tonPreviewClicked={ () => {\n\t\t\t\t\t\t\t\t\t\t\t\tif ( props.attributes.backgroundImage === 'library' ) {\n\t\t\t\t\t\t\t\t\t\t\t\t\treturn app.openMediaLibrary( props, handlers, setShowBackgroundPreview );\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\treturn stockPhotos?.openModal( props, handlers, 'bg-styles', setShowBackgroundPreview );\n\t\t\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t<TextControl\n\t\t\t\t\t\t\t\t\t\tlabel={ strings.image_url }\n\t\t\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\t\t\tvalue={ props.attributes.backgroundImage !== 'none' && props.attributes.backgroundUrl }\n\t\t\t\t\t\t\t\t\t\tclassName={ 'wpforms-gutenberg-form-selector-image-url' }\n\t\t\t\t\t\t\t\t\t\tonChange={ ( value ) => handlers.styleAttrChange( 'backgroundUrl', value ) }\n\t\t\t\t\t\t\t\t\t\tonLoad={ ( value ) => props.attributes.backgroundImage !== 'none' && handlers.styleAttrChange( 'backgroundUrl', value ) }\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t\t</Flex>\n\t\t\t\t\t\t) }\n\t\t\t\t\t\t<Flex gap={ 4 } align=\"flex-start\" className={ 'wpforms-gutenberg-form-selector-flex' } justify=\"space-between\">\n\t\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t\t<div className=\"wpforms-gutenberg-form-selector-control-label\">{ strings.colors }</div>\n\t\t\t\t\t\t\t\t<PanelColorSettings\n\t\t\t\t\t\t\t\t\t__experimentalIsRenderedInSidebar\n\t\t\t\t\t\t\t\t\tenableAlpha\n\t\t\t\t\t\t\t\t\tshowTitle={ false }\n\t\t\t\t\t\t\t\t\ttabIndex={ tabIndex }\n\t\t\t\t\t\t\t\t\tclassName=\"wpforms-gutenberg-form-selector-color-panel\"\n\t\t\t\t\t\t\t\t\tcolorSettings={ [\n\t\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t\tvalue: props.attributes.backgroundColor,\n\t\t\t\t\t\t\t\t\t\t\tonChange: ( value ) => {\n\t\t\t\t\t\t\t\t\t\t\t\tif ( ! isNotDisabled ) {\n\t\t\t\t\t\t\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\t\t\t\t\t\thandlers.styleAttrChange( 'backgroundColor', value );\n\t\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t\t\tlabel: strings.background,\n\t\t\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t\t] }\n\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t</Flex>\n\t\t\t\t\t</div>\n\t\t\t\t</PanelBody>\n\t\t\t);\n\t\t},\n\n\t\t/**\n\t\t * Open media library modal and handle image selection.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {Object}   props                    Block properties.\n\t\t * @param {Object}   handlers                 Block handlers.\n\t\t * @param {Function} setShowBackgroundPreview Set show background preview.\n\t\t */\n\t\topenMediaLibrary( props, handlers, setShowBackgroundPreview ) {\n\t\t\tconst frame = wp.media( {\n\t\t\t\ttitle: strings.select_background_image,\n\t\t\t\tmultiple: false,\n\t\t\t\tlibrary: {\n\t\t\t\t\ttype: 'image',\n\t\t\t\t},\n\t\t\t\tbutton: {\n\t\t\t\t\ttext: strings.select_image,\n\t\t\t\t},\n\t\t\t} );\n\n\t\t\tframe.on( 'select', () => {\n\t\t\t\tconst attachment = frame.state().get( 'selection' ).first().toJSON();\n\t\t\t\tconst setAttr = {};\n\t\t\t\tconst attribute = 'backgroundUrl';\n\n\t\t\t\tif ( attachment.url ) {\n\t\t\t\t\tconst value = `url(${ attachment.url })`;\n\n\t\t\t\t\tsetAttr[ attribute ] = value;\n\n\t\t\t\t\tprops.setAttributes( setAttr );\n\n\t\t\t\t\thandlers.styleAttrChange( 'backgroundUrl', value );\n\n\t\t\t\t\tsetShowBackgroundPreview( true );\n\t\t\t\t}\n\t\t\t} );\n\n\t\t\tframe.open();\n\t\t},\n\n\t\t/**\n\t\t * Set container background image.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {HTMLElement} container Container element.\n\t\t * @param {string}      value     Value.\n\t\t *\n\t\t * @return {boolean} True if the value was set, false otherwise.\n\t\t */\n\t\tsetContainerBackgroundImage( container, value ) {\n\t\t\tif ( value === 'none' ) {\n\t\t\t\tcontainer.style.setProperty( `--wpforms-background-url`, 'url()' );\n\t\t\t}\n\n\t\t\treturn true;\n\t\t},\n\n\t\t/**\n\t\t * Set container background image.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {Object}   props          Block properties.\n\t\t * @param {Object}   handlers       Block event handlers.\n\t\t * @param {string}   value          Value.\n\t\t * @param {string}   lastBgImage    Last background image.\n\t\t * @param {Function} setLastBgImage Set last background image.\n\t\t */\n\t\tsetContainerBackgroundImageWrapper( props, handlers, value, lastBgImage, setLastBgImage ) {\n\t\t\tif ( value === 'none' ) {\n\t\t\t\tsetLastBgImage( props.attributes.backgroundUrl );\n\t\t\t\tprops.attributes.backgroundUrl = 'url()';\n\n\t\t\t\thandlers.styleAttrChange( 'backgroundUrl', 'url()' );\n\t\t\t} else if ( lastBgImage ) {\n\t\t\t\tprops.attributes.backgroundUrl = lastBgImage;\n\t\t\t\thandlers.styleAttrChange( 'backgroundUrl', lastBgImage );\n\t\t\t}\n\n\t\t\thandlers.styleAttrChange( 'backgroundImage', value );\n\t\t},\n\n\t\t/**\n\t\t * Set container background position.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {HTMLElement} container Container element.\n\t\t * @param {string}      value     Value.\n\t\t *\n\t\t * @return {boolean} True if the value was set, false otherwise.\n\t\t */\n\t\tsetContainerBackgroundPosition( container, value ) {\n\t\t\tcontainer.style.setProperty( `--wpforms-background-position`, value );\n\n\t\t\treturn true;\n\t\t},\n\n\t\t/**\n\t\t * Set container background repeat.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {HTMLElement} container Container element.\n\t\t * @param {string}      value     Value.\n\t\t *\n\t\t * @return {boolean} True if the value was set, false otherwise.\n\t\t */\n\t\tsetContainerBackgroundRepeat( container, value ) {\n\t\t\tcontainer.style.setProperty( `--wpforms-background-repeat`, value );\n\n\t\t\treturn true;\n\t\t},\n\n\t\t/**\n\t\t * Handle real size from dimensions.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {Object} props    Block properties.\n\t\t * @param {Object} handlers Block handlers.\n\t\t * @param {string} value    Value.\n\t\t */\n\t\thandleSizeFromDimensions( props, handlers, value ) {\n\t\t\tif ( value === 'cover' ) {\n\t\t\t\tprops.attributes.backgroundSize = 'cover';\n\n\t\t\t\thandlers.styleAttrChange( 'backgroundWidth', props.attributes.backgroundWidth );\n\t\t\t\thandlers.styleAttrChange( 'backgroundHeight', props.attributes.backgroundHeight );\n\t\t\t\thandlers.styleAttrChange( 'backgroundSizeMode', 'cover' );\n\t\t\t\thandlers.styleAttrChange( 'backgroundSize', 'cover' );\n\t\t\t} else {\n\t\t\t\tprops.attributes.backgroundSize = 'dimensions';\n\n\t\t\t\thandlers.styleAttrChange( 'backgroundSizeMode', 'dimensions' );\n\t\t\t\thandlers.styleAttrChange( 'backgroundSize', props.attributes.backgroundWidth + ' ' + props.attributes.backgroundHeight );\n\t\t\t}\n\t\t},\n\n\t\t/**\n\t\t * Handle real size from width.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {Object} props    Block properties.\n\t\t * @param {Object} handlers Block handlers.\n\t\t * @param {string} value    Value.\n\t\t */\n\t\thandleSizeFromWidth( props, handlers, value ) {\n\t\t\tprops.attributes.backgroundSize = value + ' ' + props.attributes.backgroundHeight;\n\t\t\tprops.attributes.backgroundWidth = value;\n\n\t\t\thandlers.styleAttrChange( 'backgroundSize', value + ' ' + props.attributes.backgroundHeight );\n\t\t\thandlers.styleAttrChange( 'backgroundWidth', value );\n\t\t},\n\n\t\t/**\n\t\t * Handle real size from height.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {Object} props    Block properties.\n\t\t * @param {Object} handlers Block handlers.\n\t\t * @param {string} value    Value.\n\t\t */\n\t\thandleSizeFromHeight( props, handlers, value ) {\n\t\t\tprops.attributes.backgroundSize = props.attributes.backgroundWidth + ' ' + value;\n\t\t\tprops.attributes.backgroundHeight = value;\n\n\t\t\thandlers.styleAttrChange( 'backgroundSize', props.attributes.backgroundWidth + ' ' + value );\n\t\t\thandlers.styleAttrChange( 'backgroundHeight', value );\n\t\t},\n\n\t\t/**\n\t\t * Set container background width.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {HTMLElement} container Container element.\n\t\t * @param {string}      value     Value.\n\t\t *\n\t\t * @return {boolean} True if the value was set, false otherwise.\n\t\t */\n\t\tsetContainerBackgroundWidth( container, value ) {\n\t\t\tcontainer.style.setProperty( `--wpforms-background-width`, value );\n\n\t\t\treturn true;\n\t\t},\n\n\t\t/**\n\t\t * Set container background height.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {HTMLElement} container Container element.\n\t\t * @param {string}      value     Value.\n\t\t *\n\t\t * @return {boolean} True if the value was set, false otherwise.\n\t\t */\n\t\tsetContainerBackgroundHeight( container, value ) {\n\t\t\tcontainer.style.setProperty( `--wpforms-background-height`, value );\n\n\t\t\treturn true;\n\t\t},\n\n\t\t/**\n\t\t * Set container background url.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {HTMLElement} container Container element.\n\t\t * @param {string}      value     Value.\n\t\t *\n\t\t * @return {boolean} True if the value was set, false otherwise.\n\t\t */\n\t\tsetBackgroundUrl( container, value ) {\n\t\t\tcontainer.style.setProperty( `--wpforms-background-url`, value );\n\n\t\t\treturn true;\n\t\t},\n\n\t\t/**\n\t\t * Set container background color.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {HTMLElement} container Container element.\n\t\t * @param {string}      value     Value.\n\t\t *\n\t\t * @return {boolean} True if the value was set, false otherwise.\n\t\t */\n\t\tsetBackgroundColor( container, value ) {\n\t\t\tcontainer.style.setProperty( `--wpforms-background-color`, value );\n\n\t\t\treturn true;\n\t\t},\n\n\t\t_showBackgroundPreview( props ) {\n\t\t\treturn props.attributes.backgroundImage !== 'none' &&\n\t\t\t\tprops.attributes.backgroundUrl &&\n\t\t\t\tprops.attributes.backgroundUrl !== 'url()';\n\t\t},\n\n\t\t/**\n\t\t * Remove background image.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {Function} setShowBackgroundPreview Set show background preview.\n\t\t * @param {Object}   handlers                 Block handlers.\n\t\t * @param {Function} setLastBgImage           Set last background image.\n\t\t */\n\t\tonRemoveBackground( setShowBackgroundPreview, handlers, setLastBgImage ) {\n\t\t\tsetShowBackgroundPreview( false );\n\t\t\thandlers.styleAttrChange( 'backgroundUrl', 'url()' );\n\t\t\tsetLastBgImage( '' );\n\t\t},\n\t};\n\n\treturn app;\n}() );\n"],"mappings":"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","ignoreList":[]} },{"./background-preview.js":14}],16:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; /* global wpforms_gutenberg_form_selector */ /* jshint es3: false, esversion: 6 */ /** * @param strings.border_radius * @param strings.border_size * @param strings.button_color_notice * @param strings.button_styles * @param strings.dashed * @param strings.solid */ /** * Gutenberg editor block. * * Button styles panel module. * * @since 1.8.8 */ var _default = exports.default = function () { /** * WP core components. * * @since 1.8.8 */ var _ref = wp.blockEditor || wp.editor, PanelColorSettings = _ref.PanelColorSettings; var _wp$components = wp.components, SelectControl = _wp$components.SelectControl, PanelBody = _wp$components.PanelBody, Flex = _wp$components.Flex, FlexBlock = _wp$components.FlexBlock, __experimentalUnitControl = _wp$components.__experimentalUnitControl; /** * Localized data aliases. * * @since 1.8.8 */ var _wpforms_gutenberg_fo = wpforms_gutenberg_form_selector, strings = _wpforms_gutenberg_fo.strings, defaults = _wpforms_gutenberg_fo.defaults; // noinspection UnnecessaryLocalVariableJS /** * Public functions and properties. * * @since 1.8.8 * * @type {Object} */ var app = { /** * Get block attributes. * * @since 1.8.8 * * @return {Object} Block attributes. */ getBlockAttributes: function getBlockAttributes() { return { buttonSize: { type: 'string', default: defaults.buttonSize }, buttonBorderStyle: { type: 'string', default: defaults.buttonBorderStyle }, buttonBorderSize: { type: 'string', default: defaults.buttonBorderSize }, buttonBorderRadius: { type: 'string', default: defaults.buttonBorderRadius }, buttonBackgroundColor: { type: 'string', default: defaults.buttonBackgroundColor }, buttonTextColor: { type: 'string', default: defaults.buttonTextColor }, buttonBorderColor: { type: 'string', default: defaults.buttonBorderColor } }; }, /** * Get Button styles JSX code. * * @since 1.8.8 * * @param {Object} props Block properties. * @param {Object} handlers Block event handlers. * @param {Object} sizeOptions Size selector options. * @param {Object} formSelectorCommon Form selector common object. * * @return {Object} Button styles JSX code. */ getButtonStyles: function getButtonStyles(props, handlers, sizeOptions, formSelectorCommon) { // eslint-disable-line max-lines-per-function return /*#__PURE__*/React.createElement(PanelBody, { className: formSelectorCommon.getPanelClass(props), title: strings.button_styles }, /*#__PURE__*/React.createElement(Flex, { gap: 4, align: "flex-start", className: 'wpforms-gutenberg-form-selector-flex', justify: "space-between" }, /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(SelectControl, { label: strings.size, value: props.attributes.buttonSize, options: sizeOptions, onChange: function onChange(value) { return handlers.styleAttrChange('buttonSize', value); } })), /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(SelectControl, { label: strings.border, value: props.attributes.buttonBorderStyle, options: [{ label: strings.none, value: 'none' }, { label: strings.solid, value: 'solid' }, { label: strings.dashed, value: 'dashed' }, { label: strings.dotted, value: 'dotted' }], onChange: function onChange(value) { return handlers.styleAttrChange('buttonBorderStyle', value); } }))), /*#__PURE__*/React.createElement(Flex, { gap: 4, align: "flex-start", className: 'wpforms-gutenberg-form-selector-flex', justify: "space-between" }, /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(__experimentalUnitControl, { label: strings.border_size, value: props.attributes.buttonBorderStyle === 'none' ? '' : props.attributes.buttonBorderSize, min: 0, disabled: props.attributes.buttonBorderStyle === 'none', onChange: function onChange(value) { return handlers.styleAttrChange('buttonBorderSize', value); }, isUnitSelectTabbable: true })), /*#__PURE__*/React.createElement(FlexBlock, null, /*#__PURE__*/React.createElement(__experimentalUnitControl, { onChange: function onChange(value) { return handlers.styleAttrChange('buttonBorderRadius', value); }, label: strings.border_radius, min: 0, isUnitSelectTabbable: true, value: props.attributes.buttonBorderRadius }))), /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-color-picker" }, /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-control-label" }, strings.colors), /*#__PURE__*/React.createElement(PanelColorSettings, { __experimentalIsRenderedInSidebar: true, enableAlpha: true, showTitle: false, className: formSelectorCommon.getColorPanelClass(props.attributes.buttonBorderStyle), colorSettings: [{ value: props.attributes.buttonBackgroundColor, onChange: function onChange(value) { return handlers.styleAttrChange('buttonBackgroundColor', value); }, label: strings.background }, { value: props.attributes.buttonBorderColor, onChange: function onChange(value) { return handlers.styleAttrChange('buttonBorderColor', value); }, label: strings.border }, { value: props.attributes.buttonTextColor, onChange: function onChange(value) { return handlers.styleAttrChange('buttonTextColor', value); }, label: strings.text }] }), /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-legend wpforms-button-color-notice" }, strings.button_color_notice))); } }; return app; }(); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_default","exports","default","_ref","wp","blockEditor","editor","PanelColorSettings","_wp$components","components","SelectControl","PanelBody","Flex","FlexBlock","__experimentalUnitControl","_wpforms_gutenberg_fo","wpforms_gutenberg_form_selector","strings","defaults","app","getBlockAttributes","buttonSize","type","buttonBorderStyle","buttonBorderSize","buttonBorderRadius","buttonBackgroundColor","buttonTextColor","buttonBorderColor","getButtonStyles","props","handlers","sizeOptions","formSelectorCommon","React","createElement","className","getPanelClass","title","button_styles","gap","align","justify","label","size","value","attributes","options","onChange","styleAttrChange","border","none","solid","dashed","dotted","border_size","min","disabled","isUnitSelectTabbable","border_radius","colors","__experimentalIsRenderedInSidebar","enableAlpha","showTitle","getColorPanelClass","colorSettings","background","text","button_color_notice"],"sources":["button-styles.js"],"sourcesContent":["/* global wpforms_gutenberg_form_selector */\n/* jshint es3: false, esversion: 6 */\n\n/**\n * @param strings.border_radius\n * @param strings.border_size\n * @param strings.button_color_notice\n * @param strings.button_styles\n * @param strings.dashed\n * @param strings.solid\n */\n\n/**\n * Gutenberg editor block.\n *\n * Button styles panel module.\n *\n * @since 1.8.8\n */\nexport default ( ( function() {\n\t/**\n\t * WP core components.\n\t *\n\t * @since 1.8.8\n\t */\n\tconst { PanelColorSettings } = wp.blockEditor || wp.editor;\n\tconst { SelectControl, PanelBody, Flex, FlexBlock, __experimentalUnitControl } = wp.components;\n\n\t/**\n\t * Localized data aliases.\n\t *\n\t * @since 1.8.8\n\t */\n\tconst { strings, defaults } = wpforms_gutenberg_form_selector;\n\n\t// noinspection UnnecessaryLocalVariableJS\n\t/**\n\t * Public functions and properties.\n\t *\n\t * @since 1.8.8\n\t *\n\t * @type {Object}\n\t */\n\tconst app = {\n\n\t\t/**\n\t\t * Get block attributes.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @return {Object} Block attributes.\n\t\t */\n\t\tgetBlockAttributes() {\n\t\t\treturn {\n\t\t\t\tbuttonSize: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.buttonSize,\n\t\t\t\t},\n\t\t\t\tbuttonBorderStyle: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.buttonBorderStyle,\n\t\t\t\t},\n\t\t\t\tbuttonBorderSize: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.buttonBorderSize,\n\t\t\t\t},\n\t\t\t\tbuttonBorderRadius: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.buttonBorderRadius,\n\t\t\t\t},\n\t\t\t\tbuttonBackgroundColor: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.buttonBackgroundColor,\n\t\t\t\t},\n\t\t\t\tbuttonTextColor: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.buttonTextColor,\n\t\t\t\t},\n\t\t\t\tbuttonBorderColor: {\n\t\t\t\t\ttype: 'string',\n\t\t\t\t\tdefault: defaults.buttonBorderColor,\n\t\t\t\t},\n\t\t\t};\n\t\t},\n\n\t\t/**\n\t\t * Get Button styles JSX code.\n\t\t *\n\t\t * @since 1.8.8\n\t\t *\n\t\t * @param {Object} props              Block properties.\n\t\t * @param {Object} handlers           Block event handlers.\n\t\t * @param {Object} sizeOptions        Size selector options.\n\t\t * @param {Object} formSelectorCommon Form selector common object.\n\t\t *\n\t\t * @return {Object}  Button styles JSX code.\n\t\t */\n\t\tgetButtonStyles( props, handlers, sizeOptions, formSelectorCommon ) { // eslint-disable-line max-lines-per-function\n\t\t\treturn (\n\t\t\t\t<PanelBody className={ formSelectorCommon.getPanelClass( props ) } title={ strings.button_styles }>\n\t\t\t\t\t<Flex gap={ 4 } align=\"flex-start\" className={ 'wpforms-gutenberg-form-selector-flex' } justify=\"space-between\">\n\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t<SelectControl\n\t\t\t\t\t\t\t\tlabel={ strings.size }\n\t\t\t\t\t\t\t\tvalue={ props.attributes.buttonSize }\n\t\t\t\t\t\t\t\toptions={ sizeOptions }\n\t\t\t\t\t\t\t\tonChange={ ( value ) => handlers.styleAttrChange( 'buttonSize', value ) }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t<SelectControl\n\t\t\t\t\t\t\t\tlabel={ strings.border }\n\t\t\t\t\t\t\t\tvalue={ props.attributes.buttonBorderStyle }\n\t\t\t\t\t\t\t\toptions={\n\t\t\t\t\t\t\t\t\t[\n\t\t\t\t\t\t\t\t\t\t{ label: strings.none, value: 'none' },\n\t\t\t\t\t\t\t\t\t\t{ label: strings.solid, value: 'solid' },\n\t\t\t\t\t\t\t\t\t\t{ label: strings.dashed, value: 'dashed' },\n\t\t\t\t\t\t\t\t\t\t{ label: strings.dotted, value: 'dotted' },\n\t\t\t\t\t\t\t\t\t]\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tonChange={ ( value ) => handlers.styleAttrChange( 'buttonBorderStyle', value ) }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t</Flex>\n\t\t\t\t\t<Flex gap={ 4 } align=\"flex-start\" className={ 'wpforms-gutenberg-form-selector-flex' } justify=\"space-between\">\n\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t<__experimentalUnitControl\n\t\t\t\t\t\t\t\tlabel={ strings.border_size }\n\t\t\t\t\t\t\t\tvalue={ props.attributes.buttonBorderStyle === 'none' ? '' : props.attributes.buttonBorderSize }\n\t\t\t\t\t\t\t\tmin={ 0 }\n\t\t\t\t\t\t\t\tdisabled={ props.attributes.buttonBorderStyle === 'none' }\n\t\t\t\t\t\t\t\tonChange={ ( value ) => handlers.styleAttrChange( 'buttonBorderSize', value ) }\n\t\t\t\t\t\t\t\tisUnitSelectTabbable\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t\t<FlexBlock>\n\t\t\t\t\t\t\t<__experimentalUnitControl\n\t\t\t\t\t\t\t\tonChange={ ( value ) => handlers.styleAttrChange( 'buttonBorderRadius', value ) }\n\t\t\t\t\t\t\t\tlabel={ strings.border_radius }\n\t\t\t\t\t\t\t\tmin={ 0 }\n\t\t\t\t\t\t\t\tisUnitSelectTabbable\n\t\t\t\t\t\t\t\tvalue={ props.attributes.buttonBorderRadius } />\n\t\t\t\t\t\t</FlexBlock>\n\t\t\t\t\t</Flex>\n\n\t\t\t\t\t<div className=\"wpforms-gutenberg-form-selector-color-picker\">\n\t\t\t\t\t\t<div className=\"wpforms-gutenberg-form-selector-control-label\">{ strings.colors }</div>\n\t\t\t\t\t\t<PanelColorSettings\n\t\t\t\t\t\t\t__experimentalIsRenderedInSidebar\n\t\t\t\t\t\t\tenableAlpha\n\t\t\t\t\t\t\tshowTitle={ false }\n\t\t\t\t\t\t\tclassName={ formSelectorCommon.getColorPanelClass( props.attributes.buttonBorderStyle ) }\n\t\t\t\t\t\t\tcolorSettings={ [\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tvalue: props.attributes.buttonBackgroundColor,\n\t\t\t\t\t\t\t\t\tonChange: ( value ) => handlers.styleAttrChange( 'buttonBackgroundColor', value ),\n\t\t\t\t\t\t\t\t\tlabel: strings.background,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tvalue: props.attributes.buttonBorderColor,\n\t\t\t\t\t\t\t\t\tonChange: ( value ) => handlers.styleAttrChange( 'buttonBorderColor', value ),\n\t\t\t\t\t\t\t\t\tlabel: strings.border,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\tvalue: props.attributes.buttonTextColor,\n\t\t\t\t\t\t\t\t\tonChange: ( value ) => handlers.styleAttrChange( 'buttonTextColor', value ),\n\t\t\t\t\t\t\t\t\tlabel: strings.text,\n\t\t\t\t\t\t\t\t},\n\t\t\t\t\t\t\t] } />\n\t\t\t\t\t\t<div className=\"wpforms-gutenberg-form-selector-legend wpforms-button-color-notice\">\n\t\t\t\t\t\t\t{ strings.button_color_notice }\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</PanelBody>\n\t\t\t);\n\t\t},\n\t};\n\n\treturn app;\n} )() );\n"],"mappings":"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","ignoreList":[]} },{}],17:[function(require,module,exports){ "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; } function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); } function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; } /* global jconfirm, wpforms_gutenberg_form_selector, Choices, JSX, DOM, WPFormsUtils */ /* jshint es3: false, esversion: 6 */ /** * @param strings.copy_paste_error * @param strings.error_message * @param strings.form_edit * @param strings.form_entries * @param strings.form_keywords * @param strings.form_select * @param strings.form_selected * @param strings.form_settings * @param strings.label_styles * @param strings.other_styles * @param strings.page_break * @param strings.panel_notice_head * @param strings.panel_notice_link * @param strings.panel_notice_link_text * @param strings.panel_notice_text * @param strings.show_description * @param strings.show_title * @param strings.sublabel_hints * @param strings.form_not_available_message * @param urls.entries_url * @param urls.form_url * @param window.wpforms_choicesjs_config * @param wpforms_education.upgrade_bonus * @param wpforms_gutenberg_form_selector.block_empty_url * @param wpforms_gutenberg_form_selector.block_preview_url * @param wpforms_gutenberg_form_selector.get_started_url * @param wpforms_gutenberg_form_selector.is_full_styling * @param wpforms_gutenberg_form_selector.is_modern_markup * @param wpforms_gutenberg_form_selector.logo_url * @param wpforms_gutenberg_form_selector.wpforms_guide */ /** * Gutenberg editor block. * * Common module. * * @since 1.8.8 */ var _default = exports.default = function (document, window, $) { /** * WP core components. * * @since 1.8.8 */ var _wp = wp, _wp$serverSideRender = _wp.serverSideRender, ServerSideRender = _wp$serverSideRender === void 0 ? wp.components.ServerSideRender : _wp$serverSideRender; var _wp$element = wp.element, createElement = _wp$element.createElement, Fragment = _wp$element.Fragment, createInterpolateElement = _wp$element.createInterpolateElement; var registerBlockType = wp.blocks.registerBlockType; var _ref = wp.blockEditor || wp.editor, InspectorControls = _ref.InspectorControls, PanelColorSettings = _ref.PanelColorSettings, useBlockProps = _ref.useBlockProps; var _wp$components = wp.components, SelectControl = _wp$components.SelectControl, ToggleControl = _wp$components.ToggleControl, PanelBody = _wp$components.PanelBody, Placeholder = _wp$components.Placeholder; var __ = wp.i18n.__; var _wp$element2 = wp.element, useState = _wp$element2.useState, useEffect = _wp$element2.useEffect; /** * Localized data aliases. * * @since 1.8.8 */ var _wpforms_gutenberg_fo = wpforms_gutenberg_form_selector, strings = _wpforms_gutenberg_fo.strings, defaults = _wpforms_gutenberg_fo.defaults, sizes = _wpforms_gutenberg_fo.sizes, urls = _wpforms_gutenberg_fo.urls, isPro = _wpforms_gutenberg_fo.isPro, isLicenseActive = _wpforms_gutenberg_fo.isLicenseActive, isAdmin = _wpforms_gutenberg_fo.isAdmin; var defaultStyleSettings = defaults; // noinspection JSUnusedLocalSymbols /** * WPForms Education script. * * @since 1.8.8 */ var WPFormsEducation = window.WPFormsEducation || {}; // eslint-disable-line no-unused-vars /** * List of forms. * * The default value is localized in FormSelector.php. * * @since 1.8.4 * * @type {Object} */ var formList = wpforms_gutenberg_form_selector.forms; /** * Blocks runtime data. * * @since 1.8.1 * * @type {Object} */ var blocks = {}; /** * Whether it is needed to trigger server rendering. * * @since 1.8.1 * * @type {boolean} */ var triggerServerRender = true; /** * Popup container. * * @since 1.8.3 * * @type {Object} */ var $popup = {}; /** * Track fetch status. * * @since 1.8.4 * * @type {boolean} */ var isFetching = false; /** * Elements holder. * * @since 1.8.8 * * @type {Object} */ var el = {}; /** * Common block attributes. * * @since 1.8.8 * * @type {Object} */ var commonAttributes = { clientId: { type: 'string', default: '' }, formId: { type: 'string', default: defaultStyleSettings.formId }, displayTitle: { type: 'boolean', default: defaultStyleSettings.displayTitle }, displayDesc: { type: 'boolean', default: defaultStyleSettings.displayDesc }, preview: { type: 'boolean' }, theme: { type: 'string', default: defaultStyleSettings.theme }, themeName: { type: 'string', default: defaultStyleSettings.themeName }, labelSize: { type: 'string', default: defaultStyleSettings.labelSize }, labelColor: { type: 'string', default: defaultStyleSettings.labelColor }, labelSublabelColor: { type: 'string', default: defaultStyleSettings.labelSublabelColor }, labelErrorColor: { type: 'string', default: defaultStyleSettings.labelErrorColor }, pageBreakColor: { type: 'string', default: defaultStyleSettings.pageBreakColor }, customCss: { type: 'string', default: defaultStyleSettings.customCss }, copyPasteJsonValue: { type: 'string', default: defaultStyleSettings.copyPasteJsonValue } }; /** * Handlers for custom styles settings, defined outside this module. * * @since 1.8.8 * * @type {Object} */ var customStylesHandlers = {}; /** * Dropdown timeout. * * @since 1.8.8 * * @type {number} */ var dropdownTimeout; /** * Whether copy-paste content was generated on edit. * * @since 1.9.1 * * @type {boolean} */ var isCopyPasteGeneratedOnEdit = false; /** * Whether the background is selected. * * @since 1.9.3 * * @type {boolean} */ var backgroundSelected = false; /** * Public functions and properties. * * @since 1.8.1 * * @type {Object} */ var app = { /** * Panel modules. * * @since 1.8.8 * * @type {Object} */ panels: {}, /** * Start the engine. * * @since 1.8.1 * * @param {Object} blockOptions Block options. */ init: function init(blockOptions) { el.$window = $(window); app.panels = blockOptions.panels; app.education = blockOptions.education; app.initDefaults(blockOptions); app.registerBlock(blockOptions); app.initJConfirm(); $(app.ready); }, /** * Document ready. * * @since 1.8.1 */ ready: function ready() { app.events(); }, /** * Events. * * @since 1.8.1 */ events: function events() { el.$window.on('wpformsFormSelectorEdit', _.debounce(app.blockEdit, 250)).on('wpformsFormSelectorFormLoaded', app.formLoaded); }, /** * Init jConfirm. * * @since 1.8.8 */ initJConfirm: function initJConfirm() { // jquery-confirm defaults. jconfirm.defaults = { closeIcon: false, backgroundDismiss: false, escapeKey: true, animationBounce: 1, useBootstrap: false, theme: 'modern', boxWidth: '400px', animateFromElement: false }; }, /** * Get a fresh list of forms via REST-API. * * @since 1.8.4 * * @see https://developer.wordpress.org/block-editor/reference-guides/packages/packages-api-fetch/ */ getForms: function getForms() { return _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime().mark(function _callee() { return _regeneratorRuntime().wrap(function _callee$(_context) { while (1) switch (_context.prev = _context.next) { case 0: if (!isFetching) { _context.next = 2; break; } return _context.abrupt("return"); case 2: // Set the flag to true indicating a fetch is in progress. isFetching = true; _context.prev = 3; _context.next = 6; return wp.apiFetch({ path: wpforms_gutenberg_form_selector.route_namespace + 'forms/', method: 'GET', cache: 'no-cache' }); case 6: formList = _context.sent; _context.next = 12; break; case 9: _context.prev = 9; _context.t0 = _context["catch"](3); // eslint-disable-next-line no-console console.error(_context.t0); case 12: _context.prev = 12; isFetching = false; return _context.finish(12); case 15: case "end": return _context.stop(); } }, _callee, null, [[3, 9, 12, 15]]); }))(); }, /** * Open builder popup. * * @since 1.6.2 * * @param {string} clientID Block Client ID. */ openBuilderPopup: function openBuilderPopup(clientID) { if ($.isEmptyObject($popup)) { var _parent = $('#wpwrap'); var canvasIframe = $('iframe[name="editor-canvas"]'); var isFseMode = Boolean(canvasIframe.length); var tmpl = isFseMode ? canvasIframe.contents().find('#wpforms-gutenberg-popup') : $('#wpforms-gutenberg-popup'); _parent.after(tmpl); $popup = _parent.siblings('#wpforms-gutenberg-popup'); } var url = wpforms_gutenberg_form_selector.get_started_url, $iframe = $popup.find('iframe'); app.builderCloseButtonEvent(clientID); $iframe.attr('src', url); $popup.fadeIn(); }, /** * Close button (inside the form builder) click event. * * @since 1.8.3 * * @param {string} clientID Block Client ID. */ builderCloseButtonEvent: function builderCloseButtonEvent(clientID) { $popup.off('wpformsBuilderInPopupClose').on('wpformsBuilderInPopupClose', function (e, action, formId, formTitle) { if (action !== 'saved' || !formId) { return; } // Insert a new block when a new form is created from the popup to update the form list and attributes. var newBlock = wp.blocks.createBlock('wpforms/form-selector', { formId: formId.toString() // Expects string value, make sure we insert string. }); // eslint-disable-next-line camelcase formList = [{ ID: formId, post_title: formTitle }]; // Insert a new block. wp.data.dispatch('core/block-editor').removeBlock(clientID); wp.data.dispatch('core/block-editor').insertBlocks(newBlock); }); }, /** * Register block. * * @since 1.8.1 * * @param {Object} blockOptions Additional block options. */ // eslint-disable-next-line max-lines-per-function registerBlock: function registerBlock(blockOptions) { registerBlockType('wpforms/form-selector', { title: strings.title, description: strings.description, icon: app.getIcon(), keywords: strings.form_keywords, category: 'widgets', attributes: app.getBlockAttributes(), supports: { customClassName: app.hasForms() }, example: { attributes: { preview: true } }, // eslint-disable-next-line max-lines-per-function,complexity edit: function edit(props) { var attributes = props.attributes; var formOptions = app.getFormOptions(); var handlers = app.getSettingsFieldsHandlers(props); var _useState = useState(isPro && isLicenseActive), _useState2 = _slicedToArray(_useState, 1), isNotDisabled = _useState2[0]; // eslint-disable-line react-hooks/rules-of-hooks var _useState3 = useState(isPro), _useState4 = _slicedToArray(_useState3, 1), isProEnabled = _useState4[0]; // eslint-disable-line react-hooks/rules-of-hooks, no-unused-vars var _useState5 = useState(blockOptions.panels.background._showBackgroundPreview(props)), _useState6 = _slicedToArray(_useState5, 2), showBackgroundPreview = _useState6[0], setShowBackgroundPreview = _useState6[1]; // eslint-disable-line react-hooks/rules-of-hooks var _useState7 = useState(''), _useState8 = _slicedToArray(_useState7, 2), lastBgImage = _useState8[0], setLastBgImage = _useState8[1]; // eslint-disable-line react-hooks/rules-of-hooks var uiState = { isNotDisabled: isNotDisabled, isProEnabled: isProEnabled, showBackgroundPreview: showBackgroundPreview, setShowBackgroundPreview: setShowBackgroundPreview, lastBgImage: lastBgImage, setLastBgImage: setLastBgImage }; useEffect(function () { // eslint-disable-line react-hooks/rules-of-hooks if (attributes.formId) { setShowBackgroundPreview(props.attributes.backgroundImage !== 'none' && props.attributes.backgroundUrl && props.attributes.backgroundUrl !== 'url()'); } }, [backgroundSelected, props.attributes.backgroundImage, props.attributes.backgroundUrl]); // eslint-disable-line react-hooks/exhaustive-deps // Get block properties. var blockProps = useBlockProps(); // eslint-disable-line react-hooks/rules-of-hooks, no-unused-vars // Store block clientId in attributes. if (!attributes.clientId || !app.isClientIdAttrUnique(props)) { // We just want the client ID to update once. // The block editor doesn't have a fixed block ID, so we need to get it on the initial load, but only once. props.setAttributes({ clientId: props.clientId }); } // Main block settings. var jsx = [app.jsxParts.getMainSettings(attributes, handlers, formOptions)]; // Block preview picture. if (!app.hasForms()) { jsx.push(app.jsxParts.getEmptyFormsPreview(props)); return /*#__PURE__*/React.createElement("div", blockProps, jsx); } var sizeOptions = app.getSizeOptions(); // Show placeholder when form is not available (trashed, deleted etc.). if (attributes && attributes.formId && app.isFormAvailable(attributes.formId) === false) { // Block placeholder (form selector). jsx.push(app.jsxParts.getBlockPlaceholder(props.attributes, handlers, formOptions)); return /*#__PURE__*/React.createElement("div", blockProps, jsx); } // Form style settings & block content. if (attributes.formId) { // Subscribe to block events. app.maybeSubscribeToBlockEvents(props, handlers, blockOptions); jsx.push(app.jsxParts.getStyleSettings(props, handlers, sizeOptions, blockOptions, uiState), app.jsxParts.getBlockFormContent(props)); if (!isCopyPasteGeneratedOnEdit) { handlers.updateCopyPasteContent(); isCopyPasteGeneratedOnEdit = true; } el.$window.trigger('wpformsFormSelectorEdit', [props]); return /*#__PURE__*/React.createElement("div", blockProps, jsx); } // Block preview picture. if (attributes.preview) { jsx.push(app.jsxParts.getBlockPreview()); return /*#__PURE__*/React.createElement("div", blockProps, jsx); } // Block placeholder (form selector). jsx.push(app.jsxParts.getBlockPlaceholder(props.attributes, handlers, formOptions)); return /*#__PURE__*/React.createElement("div", blockProps, jsx); }, save: function save() { return null; } }); }, /** * Init default style settings. * * @since 1.8.1 * @since 1.8.8 Added blockOptions parameter. * * @param {Object} blockOptions Additional block options. */ initDefaults: function initDefaults() { var blockOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; commonAttributes = _objectSpread(_objectSpread({}, commonAttributes), blockOptions.getCommonAttributes()); customStylesHandlers = blockOptions.setStylesHandlers; ['formId', 'copyPasteJsonValue'].forEach(function (key) { return delete defaultStyleSettings[key]; }); }, /** * Check if the site has forms. * * @since 1.8.3 * * @return {boolean} Whether site has at least one form. */ hasForms: function hasForms() { return formList.length > 0; }, /** * Check if form is available to be previewed. * * @since 1.8.9 * * @param {number} formId Form ID. * * @return {boolean} Whether form is available. */ isFormAvailable: function isFormAvailable(formId) { return formList.find(function (_ref2) { var ID = _ref2.ID; return ID === Number(formId); }) !== undefined; }, /** * Set triggerServerRender flag. * * @since 1.8.8 * * @param {boolean} $flag The value of the triggerServerRender flag. */ setTriggerServerRender: function setTriggerServerRender($flag) { triggerServerRender = Boolean($flag); }, /** * Maybe subscribe to block events. * * @since 1.8.8 * * @param {Object} subscriberProps Subscriber block properties. * @param {Object} subscriberHandlers Subscriber block event handlers. * @param {Object} subscriberBlockOptions Subscriber block options. */ maybeSubscribeToBlockEvents: function maybeSubscribeToBlockEvents(subscriberProps, subscriberHandlers, subscriberBlockOptions) { var id = subscriberProps.clientId; // Unsubscribe from block events. // This is needed to avoid multiple subscriptions when the block is re-rendered. el.$window.off('wpformsFormSelectorDeleteTheme.' + id).off('wpformsFormSelectorUpdateTheme.' + id).off('wpformsFormSelectorSetTheme.' + id); // Subscribe to block events. el.$window.on('wpformsFormSelectorDeleteTheme.' + id, app.subscriberDeleteTheme(subscriberProps, subscriberBlockOptions)).on('wpformsFormSelectorUpdateTheme.' + id, app.subscriberUpdateTheme(subscriberProps, subscriberBlockOptions)).on('wpformsFormSelectorSetTheme.' + id, app.subscriberSetTheme(subscriberProps, subscriberBlockOptions)); }, /** * Block event `wpformsFormSelectorDeleteTheme` handler. * * @since 1.8.8 * * @param {Object} subscriberProps Subscriber block properties * @param {Object} subscriberBlockOptions Subscriber block options. * * @return {Function} Event handler. */ subscriberDeleteTheme: function subscriberDeleteTheme(subscriberProps, subscriberBlockOptions) { return function (e, themeSlug, triggerProps) { var _subscriberProps$attr, _subscriberBlockOptio; if (subscriberProps.clientId === triggerProps.clientId) { return; } if ((subscriberProps === null || subscriberProps === void 0 || (_subscriberProps$attr = subscriberProps.attributes) === null || _subscriberProps$attr === void 0 ? void 0 : _subscriberProps$attr.theme) !== themeSlug) { return; } if (!(subscriberBlockOptions !== null && subscriberBlockOptions !== void 0 && (_subscriberBlockOptio = subscriberBlockOptions.panels) !== null && _subscriberBlockOptio !== void 0 && _subscriberBlockOptio.themes)) { return; } // Reset theme to default one. subscriberBlockOptions.panels.themes.setBlockTheme(subscriberProps, 'default'); }; }, /** * Block event `wpformsFormSelectorDeleteTheme` handler. * * @since 1.8.8 * * @param {Object} subscriberProps Subscriber block properties * @param {Object} subscriberBlockOptions Subscriber block options. * * @return {Function} Event handler. */ subscriberUpdateTheme: function subscriberUpdateTheme(subscriberProps, subscriberBlockOptions) { return function (e, themeSlug, themeData, triggerProps) { var _subscriberProps$attr2, _subscriberBlockOptio2; if (subscriberProps.clientId === triggerProps.clientId) { return; } if ((subscriberProps === null || subscriberProps === void 0 || (_subscriberProps$attr2 = subscriberProps.attributes) === null || _subscriberProps$attr2 === void 0 ? void 0 : _subscriberProps$attr2.theme) !== themeSlug) { return; } if (!(subscriberBlockOptions !== null && subscriberBlockOptions !== void 0 && (_subscriberBlockOptio2 = subscriberBlockOptions.panels) !== null && _subscriberBlockOptio2 !== void 0 && _subscriberBlockOptio2.themes)) { return; } // Reset theme to default one. subscriberBlockOptions.panels.themes.setBlockTheme(subscriberProps, themeSlug); }; }, /** * Block event `wpformsFormSelectorSetTheme` handler. * * @since 1.8.8 * * @param {Object} subscriberProps Subscriber block properties * @param {Object} subscriberBlockOptions Subscriber block options. * * @return {Function} Event handler. */ subscriberSetTheme: function subscriberSetTheme(subscriberProps, subscriberBlockOptions) { // noinspection JSUnusedLocalSymbols return function (e, block, themeSlug, triggerProps) { var _subscriberBlockOptio3; // eslint-disable-line no-unused-vars if (subscriberProps.clientId === triggerProps.clientId) { return; } if (!(subscriberBlockOptions !== null && subscriberBlockOptions !== void 0 && (_subscriberBlockOptio3 = subscriberBlockOptions.panels) !== null && _subscriberBlockOptio3 !== void 0 && _subscriberBlockOptio3.themes)) { return; } // Set theme. app.onSetTheme(subscriberProps); }; }, /** * Block JSX parts. * * @since 1.8.1 * * @type {Object} */ jsxParts: { /** * Get main settings JSX code. * * @since 1.8.1 * * @param {Object} attributes Block attributes. * @param {Object} handlers Block event handlers. * @param {Object} formOptions Form selector options. * * @return {JSX.Element} Main setting JSX code. */ getMainSettings: function getMainSettings(attributes, handlers, formOptions) { // eslint-disable-line max-lines-per-function if (!app.hasForms()) { return app.jsxParts.printEmptyFormsNotice(attributes.clientId); } return /*#__PURE__*/React.createElement(InspectorControls, { key: "wpforms-gutenberg-form-selector-inspector-main-settings" }, /*#__PURE__*/React.createElement(PanelBody, { className: "wpforms-gutenberg-panel wpforms-gutenberg-panel-form-settings", title: strings.form_settings }, /*#__PURE__*/React.createElement(SelectControl, { label: strings.form_selected, value: attributes.formId, options: formOptions, onChange: function onChange(value) { return handlers.attrChange('formId', value); } }), attributes.formId ? /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("p", { className: "wpforms-gutenberg-form-selector-actions" }, /*#__PURE__*/React.createElement("a", { href: urls.form_url.replace('{ID}', attributes.formId), rel: "noreferrer", target: "_blank" }, strings.form_edit), isPro && isLicenseActive && /*#__PURE__*/React.createElement(React.Fragment, null, "\xA0\xA0|\xA0\xA0", /*#__PURE__*/React.createElement("a", { href: urls.entries_url.replace('{ID}', attributes.formId), rel: "noreferrer", target: "_blank" }, strings.form_entries))), /*#__PURE__*/React.createElement(ToggleControl, { label: strings.show_title, checked: attributes.displayTitle, onChange: function onChange(value) { return handlers.attrChange('displayTitle', value); } }), /*#__PURE__*/React.createElement(ToggleControl, { label: strings.show_description, checked: attributes.displayDesc, onChange: function onChange(value) { return handlers.attrChange('displayDesc', value); } })) : null, /*#__PURE__*/React.createElement("p", { className: "wpforms-gutenberg-panel-notice" }, /*#__PURE__*/React.createElement("strong", null, strings.panel_notice_head), strings.panel_notice_text, /*#__PURE__*/React.createElement("a", { href: strings.panel_notice_link, rel: "noreferrer", target: "_blank" }, strings.panel_notice_link_text)))); }, /** * Print empty forms notice. * * @since 1.8.3 * * @param {string} clientId Block client ID. * * @return {JSX.Element} Field styles JSX code. */ printEmptyFormsNotice: function printEmptyFormsNotice(clientId) { return /*#__PURE__*/React.createElement(InspectorControls, { key: "wpforms-gutenberg-form-selector-inspector-main-settings" }, /*#__PURE__*/React.createElement(PanelBody, { className: "wpforms-gutenberg-panel", title: strings.form_settings }, /*#__PURE__*/React.createElement("p", { className: "wpforms-gutenberg-panel-notice wpforms-warning wpforms-empty-form-notice", style: { display: 'block' } }, /*#__PURE__*/React.createElement("strong", null, __('You haven’t created a form, yet!', 'wpforms-lite')), __('What are you waiting for?', 'wpforms-lite')), /*#__PURE__*/React.createElement("button", { type: "button", className: "get-started-button components-button is-secondary", onClick: function onClick() { app.openBuilderPopup(clientId); } }, __('Get Started', 'wpforms-lite')))); }, /** * Get Label styles JSX code. * * @since 1.8.1 * * @param {Object} props Block properties. * @param {Object} handlers Block event handlers. * @param {Object} sizeOptions Size selector options. * * @return {Object} Label styles JSX code. */ getLabelStyles: function getLabelStyles(props, handlers, sizeOptions) { return /*#__PURE__*/React.createElement(PanelBody, { className: app.getPanelClass(props), title: strings.label_styles }, /*#__PURE__*/React.createElement(SelectControl, { label: strings.size, value: props.attributes.labelSize, className: "wpforms-gutenberg-form-selector-fix-bottom-margin", options: sizeOptions, onChange: function onChange(value) { return handlers.styleAttrChange('labelSize', value); } }), /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-color-picker" }, /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-control-label" }, strings.colors), /*#__PURE__*/React.createElement(PanelColorSettings, { __experimentalIsRenderedInSidebar: true, enableAlpha: true, showTitle: false, className: "wpforms-gutenberg-form-selector-color-panel", colorSettings: [{ value: props.attributes.labelColor, onChange: function onChange(value) { return handlers.styleAttrChange('labelColor', value); }, label: strings.label }, { value: props.attributes.labelSublabelColor, onChange: function onChange(value) { return handlers.styleAttrChange('labelSublabelColor', value); }, label: strings.sublabel_hints.replace('&', '&') }, { value: props.attributes.labelErrorColor, onChange: function onChange(value) { return handlers.styleAttrChange('labelErrorColor', value); }, label: strings.error_message }] }))); }, /** * Get Page Indicator styles JSX code. * * @since 1.8.7 * * @param {Object} props Block properties. * @param {Object} handlers Block event handlers. * * @return {Object} Page Indicator styles JSX code. */ getPageIndicatorStyles: function getPageIndicatorStyles(props, handlers) { // eslint-disable-line complexity var hasPageBreak = app.hasPageBreak(formList, props.attributes.formId); var hasRating = app.hasRating(formList, props.attributes.formId); if (!hasPageBreak && !hasRating) { return null; } var label = ''; if (hasPageBreak && hasRating) { label = "".concat(strings.page_break, " / ").concat(strings.rating); } else if (hasPageBreak) { label = strings.page_break; } else if (hasRating) { label = strings.rating; } return /*#__PURE__*/React.createElement(PanelBody, { className: app.getPanelClass(props), title: strings.other_styles }, /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-color-picker" }, /*#__PURE__*/React.createElement("div", { className: "wpforms-gutenberg-form-selector-control-label" }, strings.colors), /*#__PURE__*/React.createElement(PanelColorSettings, { __experimentalIsRenderedInSidebar: true, enableAlpha: true, showTitle: false, className: "wpforms-gutenberg-form-selector-color-panel", colorSettings: [{ value: props.attributes.pageBreakColor, onChange: function onChange(value) { return handlers.styleAttrChange('pageBreakColor', value); }, label: label }] }))); }, /** * Get style settings JSX code. * * @since 1.8.1 * * @param {Object} props Block properties. * @param {Object} handlers Block event handlers. * @param {Object} sizeOptions Size selector options. * @param {Object} blockOptions Block options loaded from external modules. * @param {Object} uiState UI state. * * @return {Object} Inspector controls JSX code. */ getStyleSettings: function getStyleSettings(props, handlers, sizeOptions, blockOptions, uiState) { return /*#__PURE__*/React.createElement(InspectorControls, { key: "wpforms-gutenberg-form-selector-style-settings" }, blockOptions.getThemesPanel(props, app, blockOptions.stockPhotos), blockOptions.getFieldStyles(props, handlers, sizeOptions, app), app.jsxParts.getLabelStyles(props, handlers, sizeOptions), blockOptions.getButtonStyles(props, handlers, sizeOptions, app), blockOptions.getContainerStyles(props, handlers, app, uiState), blockOptions.getBackgroundStyles(props, handlers, app, blockOptions.stockPhotos, uiState), app.jsxParts.getPageIndicatorStyles(props, handlers)); }, /** * Get block content JSX code. * * @since 1.8.1 * * @param {Object} props Block properties. * * @return {JSX.Element} Block content JSX code. */ getBlockFormContent: function getBlockFormContent(props) { if (triggerServerRender) { return /*#__PURE__*/React.createElement(ServerSideRender, { key: "wpforms-gutenberg-form-selector-server-side-renderer", block: "wpforms/form-selector", attributes: props.attributes }); } var clientId = props.clientId; var block = app.getBlockContainer(props); // In the case of empty content, use server side renderer. // This happens when the block is duplicated or converted to a reusable block. if (!(block !== null && block !== void 0 && block.innerHTML)) { triggerServerRender = true; return app.jsxParts.getBlockFormContent(props); } blocks[clientId] = blocks[clientId] || {}; blocks[clientId].blockHTML = block.innerHTML; blocks[clientId].loadedFormId = props.attributes.formId; return /*#__PURE__*/React.createElement(Fragment, { key: "wpforms-gutenberg-form-selector-fragment-form-html" }, /*#__PURE__*/React.createElement("div", { dangerouslySetInnerHTML: { __html: blocks[clientId].blockHTML } })); }, /** * Get block preview JSX code. * * @since 1.8.1 * * @return {JSX.Element} Block preview JSX code. */ getBlockPreview: function getBlockPreview() { return /*#__PURE__*/React.createElement(Fragment, { key: "wpforms-gutenberg-form-selector-fragment-block-preview" }, /*#__PURE__*/React.createElement("img", { src: wpforms_gutenberg_form_selector.block_preview_url, style: { width: '100%' }, alt: "" })); }, /** * Get block empty JSX code. * * @since 1.8.3 * * @param {Object} props Block properties. * @return {JSX.Element} Block empty JSX code. */ getEmptyFormsPreview: function getEmptyFormsPreview(props) { var clientId = props.clientId; return /*#__PURE__*/React.createElement(Fragment, { key: "wpforms-gutenberg-form-selector-fragment-block-empty" }, /*#__PURE__*/React.createElement("div", { className: "wpforms-no-form-preview" }, /*#__PURE__*/React.createElement("img", { src: wpforms_gutenberg_form_selector.block_empty_url, alt: "" }), /*#__PURE__*/React.createElement("p", null, createInterpolateElement(__('You can use WPForms to build contact forms, surveys, payment forms, and more with just a few clicks.', 'wpforms-lite'), { b: /*#__PURE__*/React.createElement("strong", null) })), /*#__PURE__*/React.createElement("button", { type: "button", className: "get-started-button components-button is-primary", onClick: function onClick() { app.openBuilderPopup(clientId); } }, __('Get Started', 'wpforms-lite')), /*#__PURE__*/React.createElement("p", { className: "empty-desc" }, createInterpolateElement(__('Need some help? Check out our comprehensive guide.', 'wpforms-lite'), { // eslint-disable-next-line jsx-a11y/anchor-has-content a: /*#__PURE__*/React.createElement("a", { href: wpforms_gutenberg_form_selector.wpforms_guide, target: "_blank", rel: "noopener noreferrer" }) })), /*#__PURE__*/React.createElement("div", { id: "wpforms-gutenberg-popup", className: "wpforms-builder-popup" }, /*#__PURE__*/React.createElement("iframe", { src: "about:blank", width: "100%", height: "100%", id: "wpforms-builder-iframe", title: "WPForms Builder Popup" })))); }, /** * Get block placeholder (form selector) JSX code. * * @since 1.8.1 * * @param {Object} attributes Block attributes. * @param {Object} handlers Block event handlers. * @param {Object} formOptions Form selector options. * * @return {JSX.Element} Block placeholder JSX code. */ getBlockPlaceholder: function getBlockPlaceholder(attributes, handlers, formOptions) { var isFormNotAvailable = attributes.formId && !app.isFormAvailable(attributes.formId); return /*#__PURE__*/React.createElement(Placeholder, { key: "wpforms-gutenberg-form-selector-wrap", className: "wpforms-gutenberg-form-selector-wrap" }, /*#__PURE__*/React.createElement("img", { src: wpforms_gutenberg_form_selector.logo_url, alt: "" }), isFormNotAvailable && /*#__PURE__*/React.createElement("p", { style: { textAlign: 'center', marginTop: '0' } }, strings.form_not_available_message), /*#__PURE__*/React.createElement(SelectControl, { key: "wpforms-gutenberg-form-selector-select-control", value: attributes.formId, options: formOptions, onChange: function onChange(value) { return handlers.attrChange('formId', value); } })); } }, /** * Determine if the form has a Page Break field. * * @since 1.8.7 * * @param {Object} forms The forms' data object. * @param {number|string} formId Form ID. * * @return {boolean} True when the form has a Page Break field, false otherwise. */ hasPageBreak: function hasPageBreak(forms, formId) { var _JSON$parse; var currentForm = forms.find(function (form) { return parseInt(form.ID, 10) === parseInt(formId, 10); }); if (!currentForm.post_content) { return false; } var fields = (_JSON$parse = JSON.parse(currentForm.post_content)) === null || _JSON$parse === void 0 ? void 0 : _JSON$parse.fields; return Object.values(fields).some(function (field) { return field.type === 'pagebreak'; }); }, hasRating: function hasRating(forms, formId) { var _JSON$parse2; var currentForm = forms.find(function (form) { return parseInt(form.ID, 10) === parseInt(formId, 10); }); if (!currentForm.post_content || !isPro || !isLicenseActive) { return false; } var fields = (_JSON$parse2 = JSON.parse(currentForm.post_content)) === null || _JSON$parse2 === void 0 ? void 0 : _JSON$parse2.fields; return Object.values(fields).some(function (field) { return field.type === 'rating'; }); }, /** * Get Style Settings panel class. * * @since 1.8.1 * * @param {Object} props Block properties. * @param {string} panel Panel name. * * @return {string} Style Settings panel class. */ getPanelClass: function getPanelClass(props) { var panel = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; var cssClass = 'wpforms-gutenberg-panel wpforms-block-settings-' + props.clientId; if (!app.isFullStylingEnabled()) { cssClass += ' disabled_panel'; } // Restrict styling panel for non-admins. if (!(isAdmin || panel === 'themes')) { cssClass += ' wpforms-gutenberg-panel-restricted'; } return cssClass; }, /** * Get color panel settings CSS class. * * @since 1.8.8 * * @param {string} borderStyle Border style value. * * @return {string} Style Settings panel class. */ getColorPanelClass: function getColorPanelClass(borderStyle) { var cssClass = 'wpforms-gutenberg-form-selector-color-panel'; if (borderStyle === 'none') { cssClass += ' wpforms-gutenberg-form-selector-border-color-disabled'; } return cssClass; }, /** * Determine whether the full styling is enabled. * * @since 1.8.1 * * @return {boolean} Whether the full styling is enabled. */ isFullStylingEnabled: function isFullStylingEnabled() { return wpforms_gutenberg_form_selector.is_modern_markup && wpforms_gutenberg_form_selector.is_full_styling; }, /** * Determine whether the block has lead forms enabled. * * @since 1.9.0 * * @param {Object} block Gutenberg block * * @return {boolean} Whether the block has lead forms enabled */ isLeadFormsEnabled: function isLeadFormsEnabled(block) { if (!block) { return false; } var $form = $(block.querySelector('.wpforms-container')); return $form.hasClass('wpforms-lead-forms-container'); }, /** * Get block container DOM element. * * @since 1.8.1 * * @param {Object} props Block properties. * * @return {Element} Block container. */ getBlockContainer: function getBlockContainer(props) { var blockSelector = "#block-".concat(props.clientId, " > div"); var block = document.querySelector(blockSelector); // For FSE / Gutenberg plugin, we need to take a look inside the iframe. if (!block) { var editorCanvas = document.querySelector('iframe[name="editor-canvas"]'); block = editorCanvas === null || editorCanvas === void 0 ? void 0 : editorCanvas.contentWindow.document.querySelector(blockSelector); } return block; }, /** * Get form container in Block Editor. * * @since 1.9.3 * * @param {number} formId Form ID. * * @return {Element|null} Form container. */ getFormBlock: function getFormBlock(formId) { // First, try to find the iframe for blocks version 3. var editorCanvas = document.querySelector('iframe[name="editor-canvas"]'); // If the iframe is found, try to find the form. return (editorCanvas === null || editorCanvas === void 0 ? void 0 : editorCanvas.contentWindow.document.querySelector("#wpforms-".concat(formId))) || $("#wpforms-".concat(formId)); }, /** * Update CSS variable(s) value(s) of the given attribute for given container on the preview. * * @since 1.8.8 * * @param {string} attribute Style attribute: field-size, label-size, button-size, etc. * @param {string} value Property new value. * @param {Element} container Form container. * @param {Object} props Block properties. */ updatePreviewCSSVarValue: function updatePreviewCSSVarValue(attribute, value, container, props) { // eslint-disable-line complexity, max-lines-per-function if (!container || !attribute) { return; } var property = attribute.replace(/[A-Z]/g, function (letter) { return "-".concat(letter.toLowerCase()); }); if (typeof customStylesHandlers[property] === 'function') { customStylesHandlers[property](container, value); return; } switch (property) { case 'field-size': case 'label-size': case 'button-size': case 'container-shadow-size': for (var key in sizes[property][value]) { container.style.setProperty("--wpforms-".concat(property, "-").concat(key), sizes[property][value][key]); } break; case 'field-border-style': if (value === 'none') { app.toggleFieldBorderNoneCSSVarValue(container, true); } else { app.toggleFieldBorderNoneCSSVarValue(container, false); container.style.setProperty("--wpforms-".concat(property), value); } break; case 'button-background-color': app.maybeUpdateAccentColor(props.attributes.buttonBorderColor, value, container); value = app.maybeSetButtonAltBackgroundColor(value, props.attributes.buttonBorderColor, container); app.maybeSetButtonAltTextColor(props.attributes.buttonTextColor, value, props.attributes.buttonBorderColor, container); container.style.setProperty("--wpforms-".concat(property), value); break; case 'button-border-color': app.maybeUpdateAccentColor(value, props.attributes.buttonBackgroundColor, container); app.maybeSetButtonAltTextColor(props.attributes.buttonTextColor, props.attributes.buttonBackgroundColor, value, container); container.style.setProperty("--wpforms-".concat(property), value); break; case 'button-text-color': app.maybeSetButtonAltTextColor(value, props.attributes.buttonBackgroundColor, props.attributes.buttonBorderColor, container); container.style.setProperty("--wpforms-".concat(property), value); break; default: container.style.setProperty("--wpforms-".concat(property), value); container.style.setProperty("--wpforms-".concat(property, "-spare"), value); } }, /** * Set/unset field border vars in case of border-style is none. * * @since 1.8.8 * * @param {Object} container Form container. * @param {boolean} set True when set, false when unset. */ toggleFieldBorderNoneCSSVarValue: function toggleFieldBorderNoneCSSVarValue(container, set) { var cont = container.querySelector('form'); if (set) { cont.style.setProperty('--wpforms-field-border-style', 'solid'); cont.style.setProperty('--wpforms-field-border-size', '1px'); cont.style.setProperty('--wpforms-field-border-color', 'transparent'); return; } cont.style.setProperty('--wpforms-field-border-style', null); cont.style.setProperty('--wpforms-field-border-size', null); cont.style.setProperty('--wpforms-field-border-color', null); }, /** * Maybe set the button's alternative background color. * * @since 1.8.8 * * @param {string} value Attribute value. * @param {string} buttonBorderColor Button border color. * @param {Object} container Form container. * * @return {string|*} New background color. */ maybeSetButtonAltBackgroundColor: function maybeSetButtonAltBackgroundColor(value, buttonBorderColor, container) { // Setting css property value to child `form` element overrides the parent property value. var form = container.querySelector('form'); form.style.setProperty('--wpforms-button-background-color-alt', value); if (WPFormsUtils.cssColorsUtils.isTransparentColor(value)) { return WPFormsUtils.cssColorsUtils.isTransparentColor(buttonBorderColor) ? defaultStyleSettings.buttonBackgroundColor : buttonBorderColor; } return value; }, /** * Maybe set the button's alternative text color. * * @since 1.8.8 * * @param {string} value Attribute value. * @param {string} buttonBackgroundColor Button background color. * @param {string} buttonBorderColor Button border color. * @param {Object} container Form container. */ maybeSetButtonAltTextColor: function maybeSetButtonAltTextColor(value, buttonBackgroundColor, buttonBorderColor, container) { var form = container.querySelector('form'); var altColor = null; value = value.toLowerCase(); if (WPFormsUtils.cssColorsUtils.isTransparentColor(value) || value === buttonBackgroundColor || WPFormsUtils.cssColorsUtils.isTransparentColor(buttonBackgroundColor) && value === buttonBorderColor) { altColor = WPFormsUtils.cssColorsUtils.getContrastColor(buttonBackgroundColor); } container.style.setProperty("--wpforms-button-text-color-alt", value); form.style.setProperty("--wpforms-button-text-color-alt", altColor); }, /** * Maybe update accent color. * * @since 1.8.8 * * @param {string} color Color value. * @param {string} buttonBackgroundColor Button background color. * @param {Object} container Form container. */ maybeUpdateAccentColor: function maybeUpdateAccentColor(color, buttonBackgroundColor, container) { // Setting css property value to child `form` element overrides the parent property value. var form = container.querySelector('form'); // Fallback to default color if the border color is transparent. color = WPFormsUtils.cssColorsUtils.isTransparentColor(color) ? defaultStyleSettings.buttonBackgroundColor : color; if (WPFormsUtils.cssColorsUtils.isTransparentColor(buttonBackgroundColor)) { form.style.setProperty('--wpforms-button-background-color-alt', 'rgba( 0, 0, 0, 0 )'); form.style.setProperty('--wpforms-button-background-color', color); } else { container.style.setProperty('--wpforms-button-background-color-alt', buttonBackgroundColor); form.style.setProperty('--wpforms-button-background-color-alt', null); form.style.setProperty('--wpforms-button-background-color', null); } }, /** * Get settings fields event handlers. * * @since 1.8.1 * * @param {Object} props Block properties. * * @return {Object} Object that contains event handlers for the settings fields. */ getSettingsFieldsHandlers: function getSettingsFieldsHandlers(props) { // eslint-disable-line max-lines-per-function return { /** * Field style attribute change event handler. * * @since 1.8.1 * * @param {string} attribute Attribute name. * @param {string} value New attribute value. */ styleAttrChange: function styleAttrChange(attribute, value) { var block = app.getBlockContainer(props), container = block.querySelector("#wpforms-".concat(props.attributes.formId)), setAttr = {}; // Unset the color means setting the transparent color. if (attribute.includes('Color')) { value = value !== null && value !== void 0 ? value : 'rgba( 0, 0, 0, 0 )'; } app.updatePreviewCSSVarValue(attribute, value, container, props); setAttr[attribute] = value; app.setBlockRuntimeStateVar(props.clientId, 'prevAttributesState', props.attributes); props.setAttributes(setAttr); triggerServerRender = false; this.updateCopyPasteContent(); app.panels.themes.updateCustomThemeAttribute(attribute, value, props); this.maybeToggleDropdown(props, attribute); // Trigger event for developers. el.$window.trigger('wpformsFormSelectorStyleAttrChange', [block, props, attribute, value]); }, /** * Handles the toggling of the dropdown menu's visibility. * * @since 1.8.8 * * @param {Object} props The block properties. * @param {string} attribute The name of the attribute being changed. */ maybeToggleDropdown: function maybeToggleDropdown(props, attribute) { var _this = this; // eslint-disable-line no-shadow var formId = props.attributes.formId; var menu = document.querySelector("#wpforms-form-".concat(formId, " .choices__list.choices__list--dropdown")); var classicMenu = document.querySelector("#wpforms-form-".concat(formId, " .wpforms-field-select-style-classic select")); if (attribute === 'fieldMenuColor') { if (menu) { menu.classList.add('is-active'); menu.parentElement.classList.add('is-open'); } else { this.showClassicMenu(classicMenu); } clearTimeout(dropdownTimeout); dropdownTimeout = setTimeout(function () { var toClose = document.querySelector("#wpforms-form-".concat(formId, " .choices__list.choices__list--dropdown")); if (toClose) { toClose.classList.remove('is-active'); toClose.parentElement.classList.remove('is-open'); } else { _this.hideClassicMenu(document.querySelector("#wpforms-form-".concat(formId, " .wpforms-field-select-style-classic select"))); } }, 5000); } else if (menu) { menu.classList.remove('is-active'); } else { this.hideClassicMenu(classicMenu); } }, /** * Shows the classic menu. * * @since 1.8.8 * * @param {Object} classicMenu The classic menu. */ showClassicMenu: function showClassicMenu(classicMenu) { if (!classicMenu) { return; } classicMenu.size = 2; classicMenu.style.cssText = 'padding-top: 40px; padding-inline-end: 0; padding-inline-start: 0; position: relative;'; classicMenu.querySelectorAll('option').forEach(function (option) { option.style.cssText = 'border-left: 1px solid #8c8f94; border-right: 1px solid #8c8f94; padding: 0 10px; z-index: 999999; position: relative;'; }); classicMenu.querySelector('option:last-child').style.cssText = 'border-bottom-left-radius: 4px; border-bottom-right-radius: 4px; padding: 0 10px; border-left: 1px solid #8c8f94; border-right: 1px solid #8c8f94; border-bottom: 1px solid #8c8f94; z-index: 999999; position: relative;'; }, /** * Hides the classic menu. * * @since 1.8.8 * * @param {Object} classicMenu The classic menu. */ hideClassicMenu: function hideClassicMenu(classicMenu) { if (!classicMenu) { return; } classicMenu.size = 0; classicMenu.style.cssText = 'padding-top: 0; padding-inline-end: 24px; padding-inline-start: 12px; position: relative;'; classicMenu.querySelectorAll('option').forEach(function (option) { option.style.cssText = 'border: none;'; }); }, /** * Field regular attribute change event handler. * * @since 1.8.1 * * @param {string} attribute Attribute name. * @param {string} value New attribute value. */ attrChange: function attrChange(attribute, value) { var setAttr = {}; setAttr[attribute] = value; app.setBlockRuntimeStateVar(props.clientId, 'prevAttributesState', props.attributes); props.setAttributes(setAttr); triggerServerRender = true; this.updateCopyPasteContent(); }, /** * Update content of the "Copy/Paste" fields. * * @since 1.8.1 */ updateCopyPasteContent: function updateCopyPasteContent() { var content = {}; var atts = wp.data.select('core/block-editor').getBlockAttributes(props.clientId); for (var key in defaultStyleSettings) { content[key] = atts[key]; } props.setAttributes({ copyPasteJsonValue: JSON.stringify(content) }); }, /** * Paste settings handler. * * @since 1.8.1 * * @param {string} value New attribute value. */ pasteSettings: function pasteSettings(value) { value = value.trim(); var pasteAttributes = app.parseValidateJson(value); if (!pasteAttributes) { if (value) { wp.data.dispatch('core/notices').createErrorNotice(strings.copy_paste_error, { id: 'wpforms-json-parse-error' }); } this.updateCopyPasteContent(); return; } pasteAttributes.copyPasteJsonValue = value; var themeSlug = app.panels.themes.maybeCreateCustomThemeFromAttributes(pasteAttributes); app.setBlockRuntimeStateVar(props.clientId, 'prevAttributesState', props.attributes); props.setAttributes(pasteAttributes); app.panels.themes.setBlockTheme(props, themeSlug); triggerServerRender = false; } }; }, /** * Parse and validate JSON string. * * @since 1.8.1 * * @param {string} value JSON string. * * @return {boolean|object} Parsed JSON object OR false on error. */ parseValidateJson: function parseValidateJson(value) { if (typeof value !== 'string') { return false; } var atts; try { atts = JSON.parse(value.trim()); } catch (error) { atts = false; } return atts; }, /** * Get WPForms icon DOM element. * * @since 1.8.1 * * @return {DOM.element} WPForms icon DOM element. */ getIcon: function getIcon() { return createElement('svg', { width: 20, height: 20, viewBox: '0 0 612 612', className: 'dashicon' }, createElement('path', { fill: 'currentColor', d: 'M544,0H68C30.445,0,0,30.445,0,68v476c0,37.556,30.445,68,68,68h476c37.556,0,68-30.444,68-68V68 C612,30.445,581.556,0,544,0z M464.44,68L387.6,120.02L323.34,68H464.44z M288.66,68l-64.26,52.02L147.56,68H288.66z M544,544H68 V68h22.1l136,92.14l79.9-64.6l79.56,64.6l136-92.14H544V544z M114.24,263.16h95.88v-48.28h-95.88V263.16z M114.24,360.4h95.88 v-48.62h-95.88V360.4z M242.76,360.4h255v-48.62h-255V360.4L242.76,360.4z M242.76,263.16h255v-48.28h-255V263.16L242.76,263.16z M368.22,457.3h129.54V408H368.22V457.3z' })); }, /** * Get WPForms blocks. * * @since 1.8.8 * * @return {Array} Blocks array. */ getWPFormsBlocks: function getWPFormsBlocks() { var wpformsBlocks = wp.data.select('core/block-editor').getBlocks(); return wpformsBlocks.filter(function (props) { return props.name === 'wpforms/form-selector'; }); }, /** * Get WPForms blocks. * * @since 1.8.8 * * @param {Object} props Block properties. * * @return {Object} Block attributes. */ isClientIdAttrUnique: function isClientIdAttrUnique(props) { var wpformsBlocks = app.getWPFormsBlocks(); for (var key in wpformsBlocks) { // Skip the current block. if (wpformsBlocks[key].clientId === props.clientId) { continue; } if (wpformsBlocks[key].attributes.clientId === props.attributes.clientId) { return false; } } return true; }, /** * Get block attributes. * * @since 1.8.1 * * @return {Object} Block attributes. */ getBlockAttributes: function getBlockAttributes() { return commonAttributes; }, /** * Get block runtime state variable. * * @since 1.8.8 * * @param {string} clientId Block client ID. * @param {string} varName Block runtime variable name. * * @return {*} Block runtime state variable value. */ getBlockRuntimeStateVar: function getBlockRuntimeStateVar(clientId, varName) { var _blocks$clientId; return (_blocks$clientId = blocks[clientId]) === null || _blocks$clientId === void 0 ? void 0 : _blocks$clientId[varName]; }, /** * Set block runtime state variable value. * * @since 1.8.8 * * @param {string} clientId Block client ID. * @param {string} varName Block runtime state key. * @param {*} value State variable value. * * @return {boolean} True on success. */ setBlockRuntimeStateVar: function setBlockRuntimeStateVar(clientId, varName, value) { // eslint-disable-line complexity if (!clientId || !varName) { return false; } blocks[clientId] = blocks[clientId] || {}; blocks[clientId][varName] = value; // Prevent referencing to object. if (_typeof(value) === 'object' && !Array.isArray(value) && value !== null) { blocks[clientId][varName] = _objectSpread({}, value); } return true; }, /** * Get form selector options. * * @since 1.8.1 * * @return {Array} Form options. */ getFormOptions: function getFormOptions() { var formOptions = formList.map(function (value) { return { value: value.ID, label: value.post_title }; }); formOptions.unshift({ value: '', label: strings.form_select }); return formOptions; }, /** * Get size selector options. * * @since 1.8.1 * * @return {Array} Size options. */ getSizeOptions: function getSizeOptions() { return [{ label: strings.small, value: 'small' }, { label: strings.medium, value: 'medium' }, { label: strings.large, value: 'large' }]; }, /** * Event `wpformsFormSelectorEdit` handler. * * @since 1.8.1 * * @param {Object} e Event object. * @param {Object} props Block properties. */ blockEdit: function blockEdit(e, props) { var block = app.getBlockContainer(props); if (!(block !== null && block !== void 0 && block.dataset)) { return; } app.initLeadFormSettings(block); }, /** * Init Lead Form Settings panels. * * @since 1.8.1 * * @param {Element} block Block element. * @param {Object} block.dataset Block element. */ initLeadFormSettings: function initLeadFormSettings(block) { var _block$dataset; if (!app.isFullStylingEnabled()) { return; } if (!(block !== null && block !== void 0 && (_block$dataset = block.dataset) !== null && _block$dataset !== void 0 && _block$dataset.block)) { return; } var clientId = block.dataset.block; var $panel = $(".wpforms-block-settings-".concat(clientId)); var isLeadFormsEnabled = app.isLeadFormsEnabled(block); if (isLeadFormsEnabled) { $panel.addClass('disabled_panel').find('.wpforms-gutenberg-panel-notice.wpforms-lead-form-notice').css('display', 'block'); $panel.find('.wpforms-gutenberg-panel-notice.wpforms-use-modern-notice').css('display', 'none'); return; } $panel.removeClass('disabled_panel').removeClass('wpforms-lead-forms-enabled').find('.wpforms-gutenberg-panel-notice.wpforms-lead-form-notice').css('display', 'none'); $panel.find('.wpforms-gutenberg-panel-notice.wpforms-use-modern-notice').css('display', null); }, /** * Event `wpformsFormSelectorFormLoaded` handler. * * @since 1.8.1 * * @param {Object} e Event object. */ formLoaded: function formLoaded(e) { app.initLeadFormSettings(e.detail.block); app.updateAccentColors(e.detail); app.loadChoicesJS(e.detail); app.initRichTextField(e.detail.formId); app.initRepeaterField(e.detail.formId); $(e.detail.block).off('click').on('click', app.blockClick); }, /** * Click on the block event handler. * * @since 1.8.1 * * @param {Object} e Event object. */ blockClick: function blockClick(e) { app.initLeadFormSettings(e.currentTarget); }, /** * Update accent colors of some fields in GB block in Modern Markup mode. * * @since 1.8.1 * * @param {Object} detail Event details object. */ updateAccentColors: function updateAccentColors(detail) { var _window$WPForms; if (!wpforms_gutenberg_form_selector.is_modern_markup || !((_window$WPForms = window.WPForms) !== null && _window$WPForms !== void 0 && _window$WPForms.FrontendModern) || !(detail !== null && detail !== void 0 && detail.block)) { return; } var $form = $(detail.block.querySelector("#wpforms-".concat(detail.formId))), FrontendModern = window.WPForms.FrontendModern; FrontendModern.updateGBBlockPageIndicatorColor($form); FrontendModern.updateGBBlockIconChoicesColor($form); FrontendModern.updateGBBlockRatingColor($form); }, /** * Init Modern style Dropdown fields (