(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":";;;;;;AAAA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAAAA,QAAA,GAAAC,OAAA,CAAAC,OAAA,GAOmB,YAAW;EAC7B;AACD;AACA;AACA;AACA;EACC,IAAAC,IAAA,GAA+BC,EAAE,CAACC,WAAW,IAAID,EAAE,CAACE,MAAM;IAAlDC,kBAAkB,GAAAJ,IAAA,CAAlBI,kBAAkB;EAC1B,IAAAC,cAAA,GAAiFJ,EAAE,CAACK,UAAU;IAAtFC,aAAa,GAAAF,cAAA,CAAbE,aAAa;IAAEC,SAAS,GAAAH,cAAA,CAATG,SAAS;IAAEC,IAAI,GAAAJ,cAAA,CAAJI,IAAI;IAAEC,SAAS,GAAAL,cAAA,CAATK,SAAS;IAAEC,yBAAyB,GAAAN,cAAA,CAAzBM,yBAAyB;;EAE5E;AACD;AACA;AACA;AACA;EACC,IAAAC,qBAAA,GAA8BC,+BAA+B;IAArDC,OAAO,GAAAF,qBAAA,CAAPE,OAAO;IAAEC,QAAQ,GAAAH,qBAAA,CAARG,QAAQ;;EAEzB;EACA;AACD;AACA;AACA;AACA;AACA;AACA;EACC,IAAMC,GAAG,GAAG;IAEX;AACF;AACA;AACA;AACA;AACA;AACA;IACEC,kBAAkB,WAAlBA,kBAAkBA,CAAA,EAAG;MACpB,OAAO;QACNC,UAAU,EAAE;UACXC,IAAI,EAAE,QAAQ;UACdpB,OAAO,EAAEgB,QAAQ,CAACG;QACnB,CAAC;QACDE,iBAAiB,EAAE;UAClBD,IAAI,EAAE,QAAQ;UACdpB,OAAO,EAAEgB,QAAQ,CAACK;QACnB,CAAC;QACDC,gBAAgB,EAAE;UACjBF,IAAI,EAAE,QAAQ;UACdpB,OAAO,EAAEgB,QAAQ,CAACM;QACnB,CAAC;QACDC,kBAAkB,EAAE;UACnBH,IAAI,EAAE,QAAQ;UACdpB,OAAO,EAAEgB,QAAQ,CAACO;QACnB,CAAC;QACDC,qBAAqB,EAAE;UACtBJ,IAAI,EAAE,QAAQ;UACdpB,OAAO,EAAEgB,QAAQ,CAACQ;QACnB,CAAC;QACDC,eAAe,EAAE;UAChBL,IAAI,EAAE,QAAQ;UACdpB,OAAO,EAAEgB,QAAQ,CAACS;QACnB,CAAC;QACDC,iBAAiB,EAAE;UAClBN,IAAI,EAAE,QAAQ;UACdpB,OAAO,EAAEgB,QAAQ,CAACU;QACnB;MACD,CAAC;IACF,CAAC;IAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;IACEC,eAAe,WAAfA,eAAeA,CAAEC,KAAK,EAAEC,QAAQ,EAAEC,WAAW,EAAEC,kBAAkB,EAAG;MAAE;MACrE,oBACCC,KAAA,CAAAC,aAAA,CAACxB,SAAS;QAACyB,SAAS,EAAGH,kBAAkB,CAACI,aAAa,CAAEP,KAAM,CAAG;QAACQ,KAAK,EAAGrB,OAAO,CAACsB;MAAe,gBACjGL,KAAA,CAAAC,aAAA,CAACvB,IAAI;QAAC4B,GAAG,EAAG,CAAG;QAACC,KAAK,EAAC,YAAY;QAACL,SAAS,EAAG,sCAAwC;QAACM,OAAO,EAAC;MAAe,gBAC9GR,KAAA,CAAAC,aAAA,CAACtB,SAAS,qBACTqB,KAAA,CAAAC,aAAA,CAACzB,aAAa;QACbiC,KAAK,EAAG1B,OAAO,CAAC2B,IAAM;QACtBC,KAAK,EAAGf,KAAK,CAACgB,UAAU,CAACzB,UAAY;QACrC0B,OAAO,EAAGf,WAAa;QACvBgB,QAAQ,EAAG,SAAXA,QAAQA,CAAKH,KAAK;UAAA,OAAMd,QAAQ,CAACkB,eAAe,CAAE,YAAY,EAAEJ,KAAM,CAAC;QAAA;MAAE,CACzE,CACS,CAAC,eACZX,KAAA,CAAAC,aAAA,CAACtB,SAAS,qBACTqB,KAAA,CAAAC,aAAA,CAACzB,aAAa;QACbiC,KAAK,EAAG1B,OAAO,CAACiC,MAAQ;QACxBL,KAAK,EAAGf,KAAK,CAACgB,UAAU,CAACvB,iBAAmB;QAC5CwB,OAAO,EACN,CACC;UAAEJ,KAAK,EAAE1B,OAAO,CAACkC,IAAI;UAAEN,KAAK,EAAE;QAAO,CAAC,EACtC;UAAEF,KAAK,EAAE1B,OAAO,CAACmC,KAAK;UAAEP,KAAK,EAAE;QAAQ,CAAC,EACxC;UAAEF,KAAK,EAAE1B,OAAO,CAACoC,MAAM;UAAER,KAAK,EAAE;QAAS,CAAC,EAC1C;UAAEF,KAAK,EAAE1B,OAAO,CAACqC,MAAM;UAAET,KAAK,EAAE;QAAS,CAAC,CAE3C;QACDG,QAAQ,EAAG,SAAXA,QAAQA,CAAKH,KAAK;UAAA,OAAMd,QAAQ,CAACkB,eAAe,CAAE,mBAAmB,EAAEJ,KAAM,CAAC;QAAA;MAAE,CAChF,CACS,CACN,CAAC,eACPX,KAAA,CAAAC,aAAA,CAACvB,IAAI;QAAC4B,GAAG,EAAG,CAAG;QAACC,KAAK,EAAC,YAAY;QAACL,SAAS,EAAG,sCAAwC;QAACM,OAAO,EAAC;MAAe,gBAC9GR,KAAA,CAAAC,aAAA,CAACtB,SAAS,qBACTqB,KAAA,CAAAC,aAAA,CAACrB,yBAAyB;QACzB6B,KAAK,EAAG1B,OAAO,CAACsC,WAAa;QAC7BV,KAAK,EAAGf,KAAK,CAACgB,UAAU,CAACvB,iBAAiB,KAAK,MAAM,GAAG,EAAE,GAAGO,KAAK,CAACgB,UAAU,CAACtB,gBAAkB;QAChGgC,GAAG,EAAG,CAAG;QACTC,QAAQ,EAAG3B,KAAK,CAACgB,UAAU,CAACvB,iBAAiB,KAAK,MAAQ;QAC1DyB,QAAQ,EAAG,SAAXA,QAAQA,CAAKH,KAAK;UAAA,OAAMd,QAAQ,CAACkB,eAAe,CAAE,kBAAkB,EAAEJ,KAAM,CAAC;QAAA,CAAE;QAC/Ea,oBAAoB;MAAA,CACpB,CACS,CAAC,eACZxB,KAAA,CAAAC,aAAA,CAACtB,SAAS,qBACTqB,KAAA,CAAAC,aAAA,CAACrB,yBAAyB;QACzBkC,QAAQ,EAAG,SAAXA,QAAQA,CAAKH,KAAK;UAAA,OAAMd,QAAQ,CAACkB,eAAe,CAAE,oBAAoB,EAAEJ,KAAM,CAAC;QAAA,CAAE;QACjFF,KAAK,EAAG1B,OAAO,CAAC0C,aAAe;QAC/BH,GAAG,EAAG,CAAG;QACTE,oBAAoB;QACpBb,KAAK,EAAGf,KAAK,CAACgB,UAAU,CAACrB;MAAoB,CAAE,CACtC,CACN,CAAC,eAEPS,KAAA,CAAAC,aAAA;QAAKC,SAAS,EAAC;MAA8C,gBAC5DF,KAAA,CAAAC,aAAA;QAAKC,SAAS,EAAC;MAA+C,GAAGnB,OAAO,CAAC2C,MAAa,CAAC,eACvF1B,KAAA,CAAAC,aAAA,CAAC5B,kBAAkB;QAClBsD,iCAAiC;QACjCC,WAAW;QACXC,SAAS,EAAG,KAAO;QACnB3B,SAAS,EAAGH,kBAAkB,CAAC+B,kBAAkB,CAAElC,KAAK,CAACgB,UAAU,CAACvB,iBAAkB,CAAG;QACzF0C,aAAa,EAAG,CACf;UACCpB,KAAK,EAAEf,KAAK,CAACgB,UAAU,CAACpB,qBAAqB;UAC7CsB,QAAQ,EAAE,SAAVA,QAAQA,CAAIH,KAAK;YAAA,OAAMd,QAAQ,CAACkB,eAAe,CAAE,uBAAuB,EAAEJ,KAAM,CAAC;UAAA;UACjFF,KAAK,EAAE1B,OAAO,CAACiD;QAChB,CAAC,EACD;UACCrB,KAAK,EAAEf,KAAK,CAACgB,UAAU,CAAClB,iBAAiB;UACzCoB,QAAQ,EAAE,SAAVA,QAAQA,CAAIH,KAAK;YAAA,OAAMd,QAAQ,CAACkB,eAAe,CAAE,mBAAmB,EAAEJ,KAAM,CAAC;UAAA;UAC7EF,KAAK,EAAE1B,OAAO,CAACiC;QAChB,CAAC,EACD;UACCL,KAAK,EAAEf,KAAK,CAACgB,UAAU,CAACnB,eAAe;UACvCqB,QAAQ,EAAE,SAAVA,QAAQA,CAAIH,KAAK;YAAA,OAAMd,QAAQ,CAACkB,eAAe,CAAE,iBAAiB,EAAEJ,KAAM,CAAC;UAAA;UAC3EF,KAAK,EAAE1B,OAAO,CAACkD;QAChB,CAAC;MACC,CAAE,CAAC,eACPjC,KAAA,CAAAC,aAAA;QAAKC,SAAS,EAAC;MAAoE,GAChFnB,OAAO,CAACmD,mBACN,CACD,CACK,CAAC;IAEd;EACD,CAAC;EAED,OAAOjD,GAAG;AACX,CAAC,CAAG,CAAC","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 (