mirror of
https://github.com/WordPress/WordPress.git
synced 2024-11-17 16:15:24 +01:00
8614d14887
We decided to split the media webpack config into it's own file. The main webpack config then combines this file with the packages config. Include vendor scripts by copying them. We copy the minified files if they are available. If they aren't available we minify the original files ourselves. Props omarreiss, herregroen, gziolo, youknowriad, netweb, adamsilverstein. Merges [43719] to trunk. See #45065. Built from https://develop.svn.wordpress.org/trunk@44112 git-svn-id: http://core.svn.wordpress.org/trunk@43942 1a063a9b-81f0-0310-95a4-ce76da25c4cd
1176 lines
46 KiB
JavaScript
1176 lines
46 KiB
JavaScript
this["wp"] = this["wp"] || {}; this["wp"]["element"] =
|
|
/******/ (function(modules) { // webpackBootstrap
|
|
/******/ // The module cache
|
|
/******/ var installedModules = {};
|
|
/******/
|
|
/******/ // The require function
|
|
/******/ function __webpack_require__(moduleId) {
|
|
/******/
|
|
/******/ // Check if module is in cache
|
|
/******/ if(installedModules[moduleId]) {
|
|
/******/ return installedModules[moduleId].exports;
|
|
/******/ }
|
|
/******/ // Create a new module (and put it into the cache)
|
|
/******/ var module = installedModules[moduleId] = {
|
|
/******/ i: moduleId,
|
|
/******/ l: false,
|
|
/******/ exports: {}
|
|
/******/ };
|
|
/******/
|
|
/******/ // Execute the module function
|
|
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
|
/******/
|
|
/******/ // Flag the module as loaded
|
|
/******/ module.l = true;
|
|
/******/
|
|
/******/ // Return the exports of the module
|
|
/******/ return module.exports;
|
|
/******/ }
|
|
/******/
|
|
/******/
|
|
/******/ // expose the modules object (__webpack_modules__)
|
|
/******/ __webpack_require__.m = modules;
|
|
/******/
|
|
/******/ // expose the module cache
|
|
/******/ __webpack_require__.c = installedModules;
|
|
/******/
|
|
/******/ // define getter function for harmony exports
|
|
/******/ __webpack_require__.d = function(exports, name, getter) {
|
|
/******/ if(!__webpack_require__.o(exports, name)) {
|
|
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
|
|
/******/ }
|
|
/******/ };
|
|
/******/
|
|
/******/ // define __esModule on exports
|
|
/******/ __webpack_require__.r = function(exports) {
|
|
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
|
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
|
/******/ }
|
|
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
|
/******/ };
|
|
/******/
|
|
/******/ // create a fake namespace object
|
|
/******/ // mode & 1: value is a module id, require it
|
|
/******/ // mode & 2: merge all properties of value into the ns
|
|
/******/ // mode & 4: return value when already ns object
|
|
/******/ // mode & 8|1: behave like require
|
|
/******/ __webpack_require__.t = function(value, mode) {
|
|
/******/ if(mode & 1) value = __webpack_require__(value);
|
|
/******/ if(mode & 8) return value;
|
|
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
|
|
/******/ var ns = Object.create(null);
|
|
/******/ __webpack_require__.r(ns);
|
|
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
|
|
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
|
|
/******/ return ns;
|
|
/******/ };
|
|
/******/
|
|
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
|
/******/ __webpack_require__.n = function(module) {
|
|
/******/ var getter = module && module.__esModule ?
|
|
/******/ function getDefault() { return module['default']; } :
|
|
/******/ function getModuleExports() { return module; };
|
|
/******/ __webpack_require__.d(getter, 'a', getter);
|
|
/******/ return getter;
|
|
/******/ };
|
|
/******/
|
|
/******/ // Object.prototype.hasOwnProperty.call
|
|
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
|
|
/******/
|
|
/******/ // __webpack_public_path__
|
|
/******/ __webpack_require__.p = "";
|
|
/******/
|
|
/******/
|
|
/******/ // Load entry module and return exports
|
|
/******/ return __webpack_require__(__webpack_require__.s = "./node_modules/@wordpress/element/build-module/index.js");
|
|
/******/ })
|
|
/************************************************************************/
|
|
/******/ ({
|
|
|
|
/***/ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js":
|
|
/*!*******************************************************************!*\
|
|
!*** ./node_modules/@babel/runtime/helpers/esm/defineProperty.js ***!
|
|
\*******************************************************************/
|
|
/*! exports provided: default */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return _defineProperty; });
|
|
function _defineProperty(obj, key, value) {
|
|
if (key in obj) {
|
|
Object.defineProperty(obj, key, {
|
|
value: value,
|
|
enumerable: true,
|
|
configurable: true,
|
|
writable: true
|
|
});
|
|
} else {
|
|
obj[key] = value;
|
|
}
|
|
|
|
return obj;
|
|
}
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/@babel/runtime/helpers/esm/objectSpread.js":
|
|
/*!*****************************************************************!*\
|
|
!*** ./node_modules/@babel/runtime/helpers/esm/objectSpread.js ***!
|
|
\*****************************************************************/
|
|
/*! exports provided: default */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return _objectSpread; });
|
|
/* harmony import */ var _defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./defineProperty */ "./node_modules/@babel/runtime/helpers/esm/defineProperty.js");
|
|
|
|
function _objectSpread(target) {
|
|
for (var i = 1; i < arguments.length; i++) {
|
|
var source = arguments[i] != null ? arguments[i] : {};
|
|
var ownKeys = Object.keys(source);
|
|
|
|
if (typeof Object.getOwnPropertySymbols === 'function') {
|
|
ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function (sym) {
|
|
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
}));
|
|
}
|
|
|
|
ownKeys.forEach(function (key) {
|
|
Object(_defineProperty__WEBPACK_IMPORTED_MODULE_0__["default"])(target, key, source[key]);
|
|
});
|
|
}
|
|
|
|
return target;
|
|
}
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js":
|
|
/*!****************************************************************************!*\
|
|
!*** ./node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js ***!
|
|
\****************************************************************************/
|
|
/*! exports provided: default */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return _objectWithoutProperties; });
|
|
/* harmony import */ var _objectWithoutPropertiesLoose__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./objectWithoutPropertiesLoose */ "./node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js");
|
|
|
|
function _objectWithoutProperties(source, excluded) {
|
|
if (source == null) return {};
|
|
var target = Object(_objectWithoutPropertiesLoose__WEBPACK_IMPORTED_MODULE_0__["default"])(source, excluded);
|
|
var key, i;
|
|
|
|
if (Object.getOwnPropertySymbols) {
|
|
var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
|
|
|
|
for (i = 0; i < sourceSymbolKeys.length; i++) {
|
|
key = sourceSymbolKeys[i];
|
|
if (excluded.indexOf(key) >= 0) continue;
|
|
if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
|
|
target[key] = source[key];
|
|
}
|
|
}
|
|
|
|
return target;
|
|
}
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js":
|
|
/*!*********************************************************************************!*\
|
|
!*** ./node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js ***!
|
|
\*********************************************************************************/
|
|
/*! exports provided: default */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return _objectWithoutPropertiesLoose; });
|
|
function _objectWithoutPropertiesLoose(source, excluded) {
|
|
if (source == null) return {};
|
|
var target = {};
|
|
var sourceKeys = Object.keys(source);
|
|
var key, i;
|
|
|
|
for (i = 0; i < sourceKeys.length; i++) {
|
|
key = sourceKeys[i];
|
|
if (excluded.indexOf(key) >= 0) continue;
|
|
target[key] = source[key];
|
|
}
|
|
|
|
return target;
|
|
}
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/@babel/runtime/helpers/esm/typeof.js":
|
|
/*!***********************************************************!*\
|
|
!*** ./node_modules/@babel/runtime/helpers/esm/typeof.js ***!
|
|
\***********************************************************/
|
|
/*! exports provided: default */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return _typeof; });
|
|
function _typeof2(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof2(obj); }
|
|
|
|
function _typeof(obj) {
|
|
if (typeof Symbol === "function" && _typeof2(Symbol.iterator) === "symbol") {
|
|
_typeof = function _typeof(obj) {
|
|
return _typeof2(obj);
|
|
};
|
|
} else {
|
|
_typeof = function _typeof(obj) {
|
|
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : _typeof2(obj);
|
|
};
|
|
}
|
|
|
|
return _typeof(obj);
|
|
}
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/@wordpress/element/build-module/index.js":
|
|
/*!***************************************************************!*\
|
|
!*** ./node_modules/@wordpress/element/build-module/index.js ***!
|
|
\***************************************************************/
|
|
/*! exports provided: renderToString, RawHTML, Children, cloneElement, Component, createContext, createElement, createRef, forwardRef, Fragment, isValidElement, StrictMode, concatChildren, switchChildrenNodeName, createPortal, findDOMNode, render, unmountComponentAtNode, isEmptyElement */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony import */ var _react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./react */ "./node_modules/@wordpress/element/build-module/react.js");
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Children", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["Children"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "cloneElement", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["cloneElement"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Component", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["Component"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "createContext", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["createContext"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "createElement", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["createElement"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "createRef", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["createRef"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "forwardRef", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["forwardRef"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Fragment", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["Fragment"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isValidElement", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["isValidElement"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StrictMode", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["StrictMode"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "concatChildren", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["concatChildren"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "switchChildrenNodeName", function() { return _react__WEBPACK_IMPORTED_MODULE_0__["switchChildrenNodeName"]; });
|
|
|
|
/* harmony import */ var _react_platform__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./react-platform */ "./node_modules/@wordpress/element/build-module/react-platform.js");
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "createPortal", function() { return _react_platform__WEBPACK_IMPORTED_MODULE_1__["createPortal"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "findDOMNode", function() { return _react_platform__WEBPACK_IMPORTED_MODULE_1__["findDOMNode"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "render", function() { return _react_platform__WEBPACK_IMPORTED_MODULE_1__["render"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "unmountComponentAtNode", function() { return _react_platform__WEBPACK_IMPORTED_MODULE_1__["unmountComponentAtNode"]; });
|
|
|
|
/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./utils */ "./node_modules/@wordpress/element/build-module/utils.js");
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isEmptyElement", function() { return _utils__WEBPACK_IMPORTED_MODULE_2__["isEmptyElement"]; });
|
|
|
|
/* harmony import */ var _serialize__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./serialize */ "./node_modules/@wordpress/element/build-module/serialize.js");
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "renderToString", function() { return _serialize__WEBPACK_IMPORTED_MODULE_3__["default"]; });
|
|
|
|
/* harmony import */ var _raw_html__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./raw-html */ "./node_modules/@wordpress/element/build-module/raw-html.js");
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RawHTML", function() { return _raw_html__WEBPACK_IMPORTED_MODULE_4__["default"]; });
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/@wordpress/element/build-module/raw-html.js":
|
|
/*!******************************************************************!*\
|
|
!*** ./node_modules/@wordpress/element/build-module/raw-html.js ***!
|
|
\******************************************************************/
|
|
/*! exports provided: default */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return RawHTML; });
|
|
/* harmony import */ var _babel_runtime_helpers_esm_objectSpread__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/objectSpread */ "./node_modules/@babel/runtime/helpers/esm/objectSpread.js");
|
|
/* harmony import */ var _babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/esm/objectWithoutProperties */ "./node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js");
|
|
/* harmony import */ var _react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./react */ "./node_modules/@wordpress/element/build-module/react.js");
|
|
|
|
|
|
|
|
/**
|
|
* External dependencies
|
|
*/
|
|
|
|
/**
|
|
* Component used as equivalent of Fragment with unescaped HTML, in cases where
|
|
* it is desirable to render dangerous HTML without needing a wrapper element.
|
|
* To preserve additional props, a `div` wrapper _will_ be created if any props
|
|
* aside from `children` are passed.
|
|
*
|
|
* @param {string} props.children HTML to render.
|
|
*
|
|
* @return {WPElement} Dangerously-rendering element.
|
|
*/
|
|
|
|
function RawHTML(_ref) {
|
|
var children = _ref.children,
|
|
props = Object(_babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__["default"])(_ref, ["children"]);
|
|
|
|
// The DIV wrapper will be stripped by serializer, unless there are
|
|
// non-children props present.
|
|
return Object(_react__WEBPACK_IMPORTED_MODULE_2__["createElement"])('div', Object(_babel_runtime_helpers_esm_objectSpread__WEBPACK_IMPORTED_MODULE_0__["default"])({
|
|
dangerouslySetInnerHTML: {
|
|
__html: children
|
|
}
|
|
}, props));
|
|
}
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/@wordpress/element/build-module/react-platform.js":
|
|
/*!************************************************************************!*\
|
|
!*** ./node_modules/@wordpress/element/build-module/react-platform.js ***!
|
|
\************************************************************************/
|
|
/*! exports provided: createPortal, findDOMNode, render, unmountComponentAtNode */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react-dom */ "react-dom");
|
|
/* harmony import */ var react_dom__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react_dom__WEBPACK_IMPORTED_MODULE_0__);
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "createPortal", function() { return react_dom__WEBPACK_IMPORTED_MODULE_0__["createPortal"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "findDOMNode", function() { return react_dom__WEBPACK_IMPORTED_MODULE_0__["findDOMNode"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "render", function() { return react_dom__WEBPACK_IMPORTED_MODULE_0__["render"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "unmountComponentAtNode", function() { return react_dom__WEBPACK_IMPORTED_MODULE_0__["unmountComponentAtNode"]; });
|
|
|
|
/**
|
|
* External dependencies
|
|
*/
|
|
|
|
/**
|
|
* Creates a portal into which a component can be rendered.
|
|
*
|
|
* @see https://github.com/facebook/react/issues/10309#issuecomment-318433235
|
|
*
|
|
* @param {Component} component Component
|
|
* @param {Element} target DOM node into which element should be rendered
|
|
*/
|
|
|
|
|
|
/**
|
|
* Finds the dom node of a React component
|
|
*
|
|
* @param {Component} component component's instance
|
|
* @param {Element} target DOM node into which element should be rendered
|
|
*/
|
|
|
|
|
|
/**
|
|
* Renders a given element into the target DOM node.
|
|
*
|
|
* @param {WPElement} element Element to render
|
|
* @param {Element} target DOM node into which element should be rendered
|
|
*/
|
|
|
|
|
|
/**
|
|
* Removes any mounted element from the target DOM node.
|
|
*
|
|
* @param {Element} target DOM node in which element is to be removed
|
|
*/
|
|
|
|
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/@wordpress/element/build-module/react.js":
|
|
/*!***************************************************************!*\
|
|
!*** ./node_modules/@wordpress/element/build-module/react.js ***!
|
|
\***************************************************************/
|
|
/*! exports provided: Children, cloneElement, Component, createContext, createElement, createRef, forwardRef, Fragment, isValidElement, StrictMode, concatChildren, switchChildrenNodeName */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "concatChildren", function() { return concatChildren; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "switchChildrenNodeName", function() { return switchChildrenNodeName; });
|
|
/* harmony import */ var _babel_runtime_helpers_esm_objectSpread__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/objectSpread */ "./node_modules/@babel/runtime/helpers/esm/objectSpread.js");
|
|
/* harmony import */ var _babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/esm/objectWithoutProperties */ "./node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js");
|
|
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react */ "react");
|
|
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_2__);
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Children", function() { return react__WEBPACK_IMPORTED_MODULE_2__["Children"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "cloneElement", function() { return react__WEBPACK_IMPORTED_MODULE_2__["cloneElement"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Component", function() { return react__WEBPACK_IMPORTED_MODULE_2__["Component"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "createContext", function() { return react__WEBPACK_IMPORTED_MODULE_2__["createContext"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "createElement", function() { return react__WEBPACK_IMPORTED_MODULE_2__["createElement"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "createRef", function() { return react__WEBPACK_IMPORTED_MODULE_2__["createRef"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "forwardRef", function() { return react__WEBPACK_IMPORTED_MODULE_2__["forwardRef"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Fragment", function() { return react__WEBPACK_IMPORTED_MODULE_2__["Fragment"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "isValidElement", function() { return react__WEBPACK_IMPORTED_MODULE_2__["isValidElement"]; });
|
|
|
|
/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StrictMode", function() { return react__WEBPACK_IMPORTED_MODULE_2__["StrictMode"]; });
|
|
|
|
/* harmony import */ var lodash__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! lodash */ "lodash");
|
|
/* harmony import */ var lodash__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(lodash__WEBPACK_IMPORTED_MODULE_3__);
|
|
|
|
|
|
|
|
/**
|
|
* External dependencies
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
* Creates a copy of an element with extended props.
|
|
*
|
|
* @param {WPElement} element Element
|
|
* @param {?Object} props Props to apply to cloned element
|
|
*
|
|
* @return {WPElement} Cloned element.
|
|
*/
|
|
|
|
|
|
/**
|
|
* A base class to create WordPress Components (Refs, state and lifecycle hooks)
|
|
*/
|
|
|
|
|
|
/**
|
|
* Creates a context object containing two components: a provider and consumer.
|
|
*
|
|
* @param {Object} defaultValue A default data stored in the context.
|
|
*
|
|
* @return {Object} Context object.
|
|
*/
|
|
|
|
|
|
/**
|
|
* Returns a new element of given type. Type can be either a string tag name or
|
|
* another function which itself returns an element.
|
|
*
|
|
* @param {?(string|Function)} type Tag name or element creator
|
|
* @param {Object} props Element properties, either attribute
|
|
* set to apply to DOM node or values to
|
|
* pass through to element creator
|
|
* @param {...WPElement} children Descendant elements
|
|
*
|
|
* @return {WPElement} Element.
|
|
*/
|
|
|
|
|
|
/**
|
|
* Returns an object tracking a reference to a rendered element via its
|
|
* `current` property as either a DOMElement or Element, dependent upon the
|
|
* type of element rendered with the ref attribute.
|
|
*
|
|
* @return {Object} Ref object.
|
|
*/
|
|
|
|
|
|
/**
|
|
* Component enhancer used to enable passing a ref to its wrapped component.
|
|
* Pass a function argument which receives `props` and `ref` as its arguments,
|
|
* returning an element using the forwarded ref. The return value is a new
|
|
* component which forwards its ref.
|
|
*
|
|
* @param {Function} forwarder Function passed `props` and `ref`, expected to
|
|
* return an element.
|
|
*
|
|
* @return {WPComponent} Enhanced component.
|
|
*/
|
|
|
|
|
|
/**
|
|
* A component which renders its children without any wrapping element.
|
|
*/
|
|
|
|
|
|
/**
|
|
* Checks if an object is a valid WPElement
|
|
*
|
|
* @param {Object} objectToCheck The object to be checked.
|
|
*
|
|
* @return {boolean} true if objectToTest is a valid WPElement and false otherwise.
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
* Concatenate two or more React children objects.
|
|
*
|
|
* @param {...?Object} childrenArguments Array of children arguments (array of arrays/strings/objects) to concatenate.
|
|
*
|
|
* @return {Array} The concatenated value.
|
|
*/
|
|
|
|
function concatChildren() {
|
|
for (var _len = arguments.length, childrenArguments = new Array(_len), _key = 0; _key < _len; _key++) {
|
|
childrenArguments[_key] = arguments[_key];
|
|
}
|
|
|
|
return childrenArguments.reduce(function (memo, children, i) {
|
|
react__WEBPACK_IMPORTED_MODULE_2__["Children"].forEach(children, function (child, j) {
|
|
if (child && 'string' !== typeof child) {
|
|
child = Object(react__WEBPACK_IMPORTED_MODULE_2__["cloneElement"])(child, {
|
|
key: [i, j].join()
|
|
});
|
|
}
|
|
|
|
memo.push(child);
|
|
});
|
|
return memo;
|
|
}, []);
|
|
}
|
|
/**
|
|
* Switches the nodeName of all the elements in the children object.
|
|
*
|
|
* @param {?Object} children Children object.
|
|
* @param {string} nodeName Node name.
|
|
*
|
|
* @return {?Object} The updated children object.
|
|
*/
|
|
|
|
function switchChildrenNodeName(children, nodeName) {
|
|
return children && react__WEBPACK_IMPORTED_MODULE_2__["Children"].map(children, function (elt, index) {
|
|
if (Object(lodash__WEBPACK_IMPORTED_MODULE_3__["isString"])(elt)) {
|
|
return Object(react__WEBPACK_IMPORTED_MODULE_2__["createElement"])(nodeName, {
|
|
key: index
|
|
}, elt);
|
|
}
|
|
|
|
var _elt$props = elt.props,
|
|
childrenProp = _elt$props.children,
|
|
props = Object(_babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__["default"])(_elt$props, ["children"]);
|
|
|
|
return Object(react__WEBPACK_IMPORTED_MODULE_2__["createElement"])(nodeName, Object(_babel_runtime_helpers_esm_objectSpread__WEBPACK_IMPORTED_MODULE_0__["default"])({
|
|
key: index
|
|
}, props), childrenProp);
|
|
});
|
|
}
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/@wordpress/element/build-module/serialize.js":
|
|
/*!*******************************************************************!*\
|
|
!*** ./node_modules/@wordpress/element/build-module/serialize.js ***!
|
|
\*******************************************************************/
|
|
/*! exports provided: hasPrefix, renderElement, renderNativeComponent, renderComponent, renderAttributes, renderStyle, default */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "hasPrefix", function() { return hasPrefix; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "renderElement", function() { return renderElement; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "renderNativeComponent", function() { return renderNativeComponent; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "renderComponent", function() { return renderComponent; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "renderAttributes", function() { return renderAttributes; });
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "renderStyle", function() { return renderStyle; });
|
|
/* harmony import */ var _babel_runtime_helpers_esm_objectSpread__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/esm/objectSpread */ "./node_modules/@babel/runtime/helpers/esm/objectSpread.js");
|
|
/* harmony import */ var _babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/esm/objectWithoutProperties */ "./node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js");
|
|
/* harmony import */ var _babel_runtime_helpers_esm_typeof__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/esm/typeof */ "./node_modules/@babel/runtime/helpers/esm/typeof.js");
|
|
/* harmony import */ var lodash__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! lodash */ "lodash");
|
|
/* harmony import */ var lodash__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(lodash__WEBPACK_IMPORTED_MODULE_3__);
|
|
/* harmony import */ var _wordpress_escape_html__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @wordpress/escape-html */ "@wordpress/escape-html");
|
|
/* harmony import */ var _wordpress_escape_html__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_wordpress_escape_html__WEBPACK_IMPORTED_MODULE_4__);
|
|
/* harmony import */ var _react__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./react */ "./node_modules/@wordpress/element/build-module/react.js");
|
|
/* harmony import */ var _raw_html__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./raw-html */ "./node_modules/@wordpress/element/build-module/raw-html.js");
|
|
|
|
|
|
|
|
|
|
/**
|
|
* Parts of this source were derived and modified from fast-react-render,
|
|
* released under the MIT license.
|
|
*
|
|
* https://github.com/alt-j/fast-react-render
|
|
*
|
|
* Copyright (c) 2016 Andrey Morozov
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
|
|
/**
|
|
* External dependencies
|
|
*/
|
|
|
|
/**
|
|
* WordPress dependencies
|
|
*/
|
|
|
|
|
|
/**
|
|
* Internal dependencies
|
|
*/
|
|
|
|
|
|
|
|
|
|
var _createContext = Object(_react__WEBPACK_IMPORTED_MODULE_5__["createContext"])(),
|
|
Provider = _createContext.Provider,
|
|
Consumer = _createContext.Consumer;
|
|
/**
|
|
* Valid attribute types.
|
|
*
|
|
* @type {Set}
|
|
*/
|
|
|
|
|
|
var ATTRIBUTES_TYPES = new Set(['string', 'boolean', 'number']);
|
|
/**
|
|
* Element tags which can be self-closing.
|
|
*
|
|
* @type {Set}
|
|
*/
|
|
|
|
var SELF_CLOSING_TAGS = new Set(['area', 'base', 'br', 'col', 'command', 'embed', 'hr', 'img', 'input', 'keygen', 'link', 'meta', 'param', 'source', 'track', 'wbr']);
|
|
/**
|
|
* Boolean attributes are attributes whose presence as being assigned is
|
|
* meaningful, even if only empty.
|
|
*
|
|
* See: https://html.spec.whatwg.org/multipage/common-microsyntaxes.html#boolean-attributes
|
|
* Extracted from: https://html.spec.whatwg.org/multipage/indices.html#attributes-3
|
|
*
|
|
* Object.keys( [ ...document.querySelectorAll( '#attributes-1 > tbody > tr' ) ]
|
|
* .filter( ( tr ) => tr.lastChild.textContent.indexOf( 'Boolean attribute' ) !== -1 )
|
|
* .reduce( ( result, tr ) => Object.assign( result, {
|
|
* [ tr.firstChild.textContent.trim() ]: true
|
|
* } ), {} ) ).sort();
|
|
*
|
|
* @type {Set}
|
|
*/
|
|
|
|
var BOOLEAN_ATTRIBUTES = new Set(['allowfullscreen', 'allowpaymentrequest', 'allowusermedia', 'async', 'autofocus', 'autoplay', 'checked', 'controls', 'default', 'defer', 'disabled', 'formnovalidate', 'hidden', 'ismap', 'itemscope', 'loop', 'multiple', 'muted', 'nomodule', 'novalidate', 'open', 'playsinline', 'readonly', 'required', 'reversed', 'selected', 'typemustmatch']);
|
|
/**
|
|
* Enumerated attributes are attributes which must be of a specific value form.
|
|
* Like boolean attributes, these are meaningful if specified, even if not of a
|
|
* valid enumerated value.
|
|
*
|
|
* See: https://html.spec.whatwg.org/multipage/common-microsyntaxes.html#enumerated-attribute
|
|
* Extracted from: https://html.spec.whatwg.org/multipage/indices.html#attributes-3
|
|
*
|
|
* Object.keys( [ ...document.querySelectorAll( '#attributes-1 > tbody > tr' ) ]
|
|
* .filter( ( tr ) => /^("(.+?)";?\s*)+/.test( tr.lastChild.textContent.trim() ) )
|
|
* .reduce( ( result, tr ) => Object.assign( result, {
|
|
* [ tr.firstChild.textContent.trim() ]: true
|
|
* } ), {} ) ).sort();
|
|
*
|
|
* Some notable omissions:
|
|
*
|
|
* - `alt`: https://blog.whatwg.org/omit-alt
|
|
*
|
|
* @type {Set}
|
|
*/
|
|
|
|
var ENUMERATED_ATTRIBUTES = new Set(['autocapitalize', 'autocomplete', 'charset', 'contenteditable', 'crossorigin', 'decoding', 'dir', 'draggable', 'enctype', 'formenctype', 'formmethod', 'http-equiv', 'inputmode', 'kind', 'method', 'preload', 'scope', 'shape', 'spellcheck', 'translate', 'type', 'wrap']);
|
|
/**
|
|
* Set of CSS style properties which support assignment of unitless numbers.
|
|
* Used in rendering of style properties, where `px` unit is assumed unless
|
|
* property is included in this set or value is zero.
|
|
*
|
|
* Generated via:
|
|
*
|
|
* Object.entries( document.createElement( 'div' ).style )
|
|
* .filter( ( [ key ] ) => (
|
|
* ! /^(webkit|ms|moz)/.test( key ) &&
|
|
* ( e.style[ key ] = 10 ) &&
|
|
* e.style[ key ] === '10'
|
|
* ) )
|
|
* .map( ( [ key ] ) => key )
|
|
* .sort();
|
|
*
|
|
* @type {Set}
|
|
*/
|
|
|
|
var CSS_PROPERTIES_SUPPORTS_UNITLESS = new Set(['animation', 'animationIterationCount', 'baselineShift', 'borderImageOutset', 'borderImageSlice', 'borderImageWidth', 'columnCount', 'cx', 'cy', 'fillOpacity', 'flexGrow', 'flexShrink', 'floodOpacity', 'fontWeight', 'gridColumnEnd', 'gridColumnStart', 'gridRowEnd', 'gridRowStart', 'lineHeight', 'opacity', 'order', 'orphans', 'r', 'rx', 'ry', 'shapeImageThreshold', 'stopOpacity', 'strokeDasharray', 'strokeDashoffset', 'strokeMiterlimit', 'strokeOpacity', 'strokeWidth', 'tabSize', 'widows', 'x', 'y', 'zIndex', 'zoom']);
|
|
/**
|
|
* Returns true if the specified string is prefixed by one of an array of
|
|
* possible prefixes.
|
|
*
|
|
* @param {string} string String to check.
|
|
* @param {string[]} prefixes Possible prefixes.
|
|
*
|
|
* @return {boolean} Whether string has prefix.
|
|
*/
|
|
|
|
function hasPrefix(string, prefixes) {
|
|
return prefixes.some(function (prefix) {
|
|
return string.indexOf(prefix) === 0;
|
|
});
|
|
}
|
|
/**
|
|
* Returns true if the given prop name should be ignored in attributes
|
|
* serialization, or false otherwise.
|
|
*
|
|
* @param {string} attribute Attribute to check.
|
|
*
|
|
* @return {boolean} Whether attribute should be ignored.
|
|
*/
|
|
|
|
function isInternalAttribute(attribute) {
|
|
return 'key' === attribute || 'children' === attribute;
|
|
}
|
|
/**
|
|
* Returns the normal form of the element's attribute value for HTML.
|
|
*
|
|
* @param {string} attribute Attribute name.
|
|
* @param {*} value Non-normalized attribute value.
|
|
*
|
|
* @return {string} Normalized attribute value.
|
|
*/
|
|
|
|
|
|
function getNormalAttributeValue(attribute, value) {
|
|
switch (attribute) {
|
|
case 'style':
|
|
return renderStyle(value);
|
|
}
|
|
|
|
return value;
|
|
}
|
|
/**
|
|
* Returns the normal form of the element's attribute name for HTML.
|
|
*
|
|
* @param {string} attribute Non-normalized attribute name.
|
|
*
|
|
* @return {string} Normalized attribute name.
|
|
*/
|
|
|
|
|
|
function getNormalAttributeName(attribute) {
|
|
switch (attribute) {
|
|
case 'htmlFor':
|
|
return 'for';
|
|
|
|
case 'className':
|
|
return 'class';
|
|
}
|
|
|
|
return attribute.toLowerCase();
|
|
}
|
|
/**
|
|
* Returns the normal form of the style property name for HTML.
|
|
*
|
|
* - Converts property names to kebab-case, e.g. 'backgroundColor' → 'background-color'
|
|
* - Leaves custom attributes alone, e.g. '--myBackgroundColor' → '--myBackgroundColor'
|
|
* - Converts vendor-prefixed property names to -kebab-case, e.g. 'MozTransform' → '-moz-transform'
|
|
*
|
|
* @param {string} property Property name.
|
|
*
|
|
* @return {string} Normalized property name.
|
|
*/
|
|
|
|
|
|
function getNormalStylePropertyName(property) {
|
|
if (Object(lodash__WEBPACK_IMPORTED_MODULE_3__["startsWith"])(property, '--')) {
|
|
return property;
|
|
}
|
|
|
|
if (hasPrefix(property, ['ms', 'O', 'Moz', 'Webkit'])) {
|
|
return '-' + Object(lodash__WEBPACK_IMPORTED_MODULE_3__["kebabCase"])(property);
|
|
}
|
|
|
|
return Object(lodash__WEBPACK_IMPORTED_MODULE_3__["kebabCase"])(property);
|
|
}
|
|
/**
|
|
* Returns the normal form of the style property value for HTML. Appends a
|
|
* default pixel unit if numeric, not a unitless property, and not zero.
|
|
*
|
|
* @param {string} property Property name.
|
|
* @param {*} value Non-normalized property value.
|
|
*
|
|
* @return {*} Normalized property value.
|
|
*/
|
|
|
|
|
|
function getNormalStylePropertyValue(property, value) {
|
|
if (typeof value === 'number' && 0 !== value && !CSS_PROPERTIES_SUPPORTS_UNITLESS.has(property)) {
|
|
return value + 'px';
|
|
}
|
|
|
|
return value;
|
|
}
|
|
/**
|
|
* Serializes a React element to string.
|
|
*
|
|
* @param {WPElement} element Element to serialize.
|
|
* @param {?Object} context Context object.
|
|
* @param {?Object} legacyContext Legacy context object.
|
|
*
|
|
* @return {string} Serialized element.
|
|
*/
|
|
|
|
|
|
function renderElement(element, context) {
|
|
var legacyContext = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
|
|
if (null === element || undefined === element || false === element) {
|
|
return '';
|
|
}
|
|
|
|
if (Array.isArray(element)) {
|
|
return renderChildren(element, context, legacyContext);
|
|
}
|
|
|
|
switch (Object(_babel_runtime_helpers_esm_typeof__WEBPACK_IMPORTED_MODULE_2__["default"])(element)) {
|
|
case 'string':
|
|
return Object(_wordpress_escape_html__WEBPACK_IMPORTED_MODULE_4__["escapeHTML"])(element);
|
|
|
|
case 'number':
|
|
return element.toString();
|
|
}
|
|
|
|
var type = element.type,
|
|
props = element.props;
|
|
|
|
switch (type) {
|
|
case _react__WEBPACK_IMPORTED_MODULE_5__["StrictMode"]:
|
|
case _react__WEBPACK_IMPORTED_MODULE_5__["Fragment"]:
|
|
return renderChildren(props.children, context, legacyContext);
|
|
|
|
case _raw_html__WEBPACK_IMPORTED_MODULE_6__["default"]:
|
|
var children = props.children,
|
|
wrapperProps = Object(_babel_runtime_helpers_esm_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_1__["default"])(props, ["children"]);
|
|
|
|
return renderNativeComponent(Object(lodash__WEBPACK_IMPORTED_MODULE_3__["isEmpty"])(wrapperProps) ? null : 'div', Object(_babel_runtime_helpers_esm_objectSpread__WEBPACK_IMPORTED_MODULE_0__["default"])({}, wrapperProps, {
|
|
dangerouslySetInnerHTML: {
|
|
__html: children
|
|
}
|
|
}), context, legacyContext);
|
|
}
|
|
|
|
switch (Object(_babel_runtime_helpers_esm_typeof__WEBPACK_IMPORTED_MODULE_2__["default"])(type)) {
|
|
case 'string':
|
|
return renderNativeComponent(type, props, context, legacyContext);
|
|
|
|
case 'function':
|
|
if (type.prototype && typeof type.prototype.render === 'function') {
|
|
return renderComponent(type, props, context, legacyContext);
|
|
}
|
|
|
|
return renderElement(type(props, legacyContext), context, legacyContext);
|
|
}
|
|
|
|
switch (type && type.$$typeof) {
|
|
case Provider.$$typeof:
|
|
return renderChildren(props.children, props.value, legacyContext);
|
|
|
|
case Consumer.$$typeof:
|
|
return renderElement(props.children(context || type._currentValue), context, legacyContext);
|
|
}
|
|
|
|
return '';
|
|
}
|
|
/**
|
|
* Serializes a native component type to string.
|
|
*
|
|
* @param {?string} type Native component type to serialize, or null if
|
|
* rendering as fragment of children content.
|
|
* @param {Object} props Props object.
|
|
* @param {?Object} context Context object.
|
|
* @param {?Object} legacyContext Legacy context object.
|
|
*
|
|
* @return {string} Serialized element.
|
|
*/
|
|
|
|
function renderNativeComponent(type, props, context) {
|
|
var legacyContext = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
|
|
var content = '';
|
|
|
|
if (type === 'textarea' && props.hasOwnProperty('value')) {
|
|
// Textarea children can be assigned as value prop. If it is, render in
|
|
// place of children. Ensure to omit so it is not assigned as attribute
|
|
// as well.
|
|
content = renderChildren(props.value, context, legacyContext);
|
|
props = Object(lodash__WEBPACK_IMPORTED_MODULE_3__["omit"])(props, 'value');
|
|
} else if (props.dangerouslySetInnerHTML && typeof props.dangerouslySetInnerHTML.__html === 'string') {
|
|
// Dangerous content is left unescaped.
|
|
content = props.dangerouslySetInnerHTML.__html;
|
|
} else if (typeof props.children !== 'undefined') {
|
|
content = renderChildren(props.children, context, legacyContext);
|
|
}
|
|
|
|
if (!type) {
|
|
return content;
|
|
}
|
|
|
|
var attributes = renderAttributes(props);
|
|
|
|
if (SELF_CLOSING_TAGS.has(type)) {
|
|
return '<' + type + attributes + '/>';
|
|
}
|
|
|
|
return '<' + type + attributes + '>' + content + '</' + type + '>';
|
|
}
|
|
/**
|
|
* Serializes a non-native component type to string.
|
|
*
|
|
* @param {Function} Component Component type to serialize.
|
|
* @param {Object} props Props object.
|
|
* @param {?Object} context Context object.
|
|
* @param {?Object} legacyContext Legacy context object.
|
|
*
|
|
* @return {string} Serialized element
|
|
*/
|
|
|
|
function renderComponent(Component, props, context) {
|
|
var legacyContext = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
|
|
var instance = new Component(props, legacyContext);
|
|
|
|
if (typeof instance.getChildContext === 'function') {
|
|
Object.assign(legacyContext, instance.getChildContext());
|
|
}
|
|
|
|
var html = renderElement(instance.render(), context, legacyContext);
|
|
return html;
|
|
}
|
|
/**
|
|
* Serializes an array of children to string.
|
|
*
|
|
* @param {Array} children Children to serialize.
|
|
* @param {?Object} context Context object.
|
|
* @param {?Object} legacyContext Legacy context object.
|
|
*
|
|
* @return {string} Serialized children.
|
|
*/
|
|
|
|
function renderChildren(children, context) {
|
|
var legacyContext = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
|
|
var result = '';
|
|
children = Object(lodash__WEBPACK_IMPORTED_MODULE_3__["castArray"])(children);
|
|
|
|
for (var i = 0; i < children.length; i++) {
|
|
var child = children[i];
|
|
result += renderElement(child, context, legacyContext);
|
|
}
|
|
|
|
return result;
|
|
}
|
|
/**
|
|
* Renders a props object as a string of HTML attributes.
|
|
*
|
|
* @param {Object} props Props object.
|
|
*
|
|
* @return {string} Attributes string.
|
|
*/
|
|
|
|
|
|
function renderAttributes(props) {
|
|
var result = '';
|
|
|
|
for (var key in props) {
|
|
var attribute = getNormalAttributeName(key);
|
|
|
|
if (!Object(_wordpress_escape_html__WEBPACK_IMPORTED_MODULE_4__["isValidAttributeName"])(attribute)) {
|
|
continue;
|
|
}
|
|
|
|
var value = getNormalAttributeValue(key, props[key]); // If value is not of serializeable type, skip.
|
|
|
|
if (!ATTRIBUTES_TYPES.has(Object(_babel_runtime_helpers_esm_typeof__WEBPACK_IMPORTED_MODULE_2__["default"])(value))) {
|
|
continue;
|
|
} // Don't render internal attribute names.
|
|
|
|
|
|
if (isInternalAttribute(key)) {
|
|
continue;
|
|
}
|
|
|
|
var isBooleanAttribute = BOOLEAN_ATTRIBUTES.has(attribute); // Boolean attribute should be omitted outright if its value is false.
|
|
|
|
if (isBooleanAttribute && value === false) {
|
|
continue;
|
|
}
|
|
|
|
var isMeaningfulAttribute = isBooleanAttribute || hasPrefix(key, ['data-', 'aria-']) || ENUMERATED_ATTRIBUTES.has(attribute); // Only write boolean value as attribute if meaningful.
|
|
|
|
if (typeof value === 'boolean' && !isMeaningfulAttribute) {
|
|
continue;
|
|
}
|
|
|
|
result += ' ' + attribute; // Boolean attributes should write attribute name, but without value.
|
|
// Mere presence of attribute name is effective truthiness.
|
|
|
|
if (isBooleanAttribute) {
|
|
continue;
|
|
}
|
|
|
|
if (typeof value === 'string') {
|
|
value = Object(_wordpress_escape_html__WEBPACK_IMPORTED_MODULE_4__["escapeAttribute"])(value);
|
|
}
|
|
|
|
result += '="' + value + '"';
|
|
}
|
|
|
|
return result;
|
|
}
|
|
/**
|
|
* Renders a style object as a string attribute value.
|
|
*
|
|
* @param {Object} style Style object.
|
|
*
|
|
* @return {string} Style attribute value.
|
|
*/
|
|
|
|
function renderStyle(style) {
|
|
// Only generate from object, e.g. tolerate string value.
|
|
if (!Object(lodash__WEBPACK_IMPORTED_MODULE_3__["isPlainObject"])(style)) {
|
|
return style;
|
|
}
|
|
|
|
var result;
|
|
|
|
for (var property in style) {
|
|
var value = style[property];
|
|
|
|
if (null === value || undefined === value) {
|
|
continue;
|
|
}
|
|
|
|
if (result) {
|
|
result += ';';
|
|
} else {
|
|
result = '';
|
|
}
|
|
|
|
var normalName = getNormalStylePropertyName(property);
|
|
var normalValue = getNormalStylePropertyValue(property, value);
|
|
result += normalName + ':' + normalValue;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
/* harmony default export */ __webpack_exports__["default"] = (renderElement);
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ "./node_modules/@wordpress/element/build-module/utils.js":
|
|
/*!***************************************************************!*\
|
|
!*** ./node_modules/@wordpress/element/build-module/utils.js ***!
|
|
\***************************************************************/
|
|
/*! exports provided: isEmptyElement */
|
|
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
|
|
|
"use strict";
|
|
__webpack_require__.r(__webpack_exports__);
|
|
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isEmptyElement", function() { return isEmptyElement; });
|
|
/* harmony import */ var lodash__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! lodash */ "lodash");
|
|
/* harmony import */ var lodash__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(lodash__WEBPACK_IMPORTED_MODULE_0__);
|
|
/**
|
|
* External dependencies
|
|
*/
|
|
|
|
/**
|
|
* Checks if the provided WP element is empty.
|
|
*
|
|
* @param {*} element WP element to check.
|
|
* @return {boolean} True when an element is considered empty.
|
|
*/
|
|
|
|
var isEmptyElement = function isEmptyElement(element) {
|
|
if (Object(lodash__WEBPACK_IMPORTED_MODULE_0__["isNumber"])(element)) {
|
|
return false;
|
|
}
|
|
|
|
if (Object(lodash__WEBPACK_IMPORTED_MODULE_0__["isString"])(element) || Object(lodash__WEBPACK_IMPORTED_MODULE_0__["isArray"])(element)) {
|
|
return !element.length;
|
|
}
|
|
|
|
return !element;
|
|
};
|
|
|
|
|
|
/***/ }),
|
|
|
|
/***/ "@wordpress/escape-html":
|
|
/*!*********************************************!*\
|
|
!*** external {"this":["wp","escapeHtml"]} ***!
|
|
\*********************************************/
|
|
/*! no static exports found */
|
|
/***/ (function(module, exports) {
|
|
|
|
(function() { module.exports = this["wp"]["escapeHtml"]; }());
|
|
|
|
/***/ }),
|
|
|
|
/***/ "lodash":
|
|
/*!*************************!*\
|
|
!*** external "lodash" ***!
|
|
\*************************/
|
|
/*! no static exports found */
|
|
/***/ (function(module, exports) {
|
|
|
|
(function() { module.exports = this["lodash"]; }());
|
|
|
|
/***/ }),
|
|
|
|
/***/ "react":
|
|
/*!************************!*\
|
|
!*** external "React" ***!
|
|
\************************/
|
|
/*! no static exports found */
|
|
/***/ (function(module, exports) {
|
|
|
|
(function() { module.exports = this["React"]; }());
|
|
|
|
/***/ }),
|
|
|
|
/***/ "react-dom":
|
|
/*!***************************!*\
|
|
!*** external "ReactDOM" ***!
|
|
\***************************/
|
|
/*! no static exports found */
|
|
/***/ (function(module, exports) {
|
|
|
|
(function() { module.exports = this["ReactDOM"]; }());
|
|
|
|
/***/ })
|
|
|
|
/******/ });
|
|
//# sourceMappingURL=element.js.map
|