[ Index ] |
PHP Cross Reference of WordPress |
[Summary view] [Print] [Text view]
1 /******/ (function() { // webpackBootstrap 2 /******/ "use strict"; 3 /******/ // The require scope 4 /******/ var __webpack_require__ = {}; 5 /******/ 6 /************************************************************************/ 7 /******/ /* webpack/runtime/compat get default export */ 8 /******/ !function() { 9 /******/ // getDefaultExport function for compatibility with non-harmony modules 10 /******/ __webpack_require__.n = function(module) { 11 /******/ var getter = module && module.__esModule ? 12 /******/ function() { return module['default']; } : 13 /******/ function() { return module; }; 14 /******/ __webpack_require__.d(getter, { a: getter }); 15 /******/ return getter; 16 /******/ }; 17 /******/ }(); 18 /******/ 19 /******/ /* webpack/runtime/define property getters */ 20 /******/ !function() { 21 /******/ // define getter functions for harmony exports 22 /******/ __webpack_require__.d = function(exports, definition) { 23 /******/ for(var key in definition) { 24 /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { 25 /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); 26 /******/ } 27 /******/ } 28 /******/ }; 29 /******/ }(); 30 /******/ 31 /******/ /* webpack/runtime/hasOwnProperty shorthand */ 32 /******/ !function() { 33 /******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } 34 /******/ }(); 35 /******/ 36 /************************************************************************/ 37 var __webpack_exports__ = {}; 38 39 // EXPORTS 40 __webpack_require__.d(__webpack_exports__, { 41 "default": function() { return /* binding */ build_module; } 42 }); 43 44 ;// CONCATENATED MODULE: ./node_modules/@babel/runtime/helpers/esm/extends.js 45 function _extends() { 46 _extends = Object.assign || function (target) { 47 for (var i = 1; i < arguments.length; i++) { 48 var source = arguments[i]; 49 50 for (var key in source) { 51 if (Object.prototype.hasOwnProperty.call(source, key)) { 52 target[key] = source[key]; 53 } 54 } 55 } 56 57 return target; 58 }; 59 60 return _extends.apply(this, arguments); 61 } 62 ;// CONCATENATED MODULE: external ["wp","element"] 63 var external_wp_element_namespaceObject = window["wp"]["element"]; 64 ;// CONCATENATED MODULE: external ["wp","data"] 65 var external_wp_data_namespaceObject = window["wp"]["data"]; 66 ;// CONCATENATED MODULE: external ["wp","deprecated"] 67 var external_wp_deprecated_namespaceObject = window["wp"]["deprecated"]; 68 var external_wp_deprecated_default = /*#__PURE__*/__webpack_require__.n(external_wp_deprecated_namespaceObject); 69 ;// CONCATENATED MODULE: external "lodash" 70 var external_lodash_namespaceObject = window["lodash"]; 71 ;// CONCATENATED MODULE: external ["wp","compose"] 72 var external_wp_compose_namespaceObject = window["wp"]["compose"]; 73 ;// CONCATENATED MODULE: external ["wp","i18n"] 74 var external_wp_i18n_namespaceObject = window["wp"]["i18n"]; 75 ;// CONCATENATED MODULE: external ["wp","apiFetch"] 76 var external_wp_apiFetch_namespaceObject = window["wp"]["apiFetch"]; 77 var external_wp_apiFetch_default = /*#__PURE__*/__webpack_require__.n(external_wp_apiFetch_namespaceObject); 78 ;// CONCATENATED MODULE: external ["wp","url"] 79 var external_wp_url_namespaceObject = window["wp"]["url"]; 80 ;// CONCATENATED MODULE: external ["wp","components"] 81 var external_wp_components_namespaceObject = window["wp"]["components"]; 82 ;// CONCATENATED MODULE: external ["wp","blocks"] 83 var external_wp_blocks_namespaceObject = window["wp"]["blocks"]; 84 ;// CONCATENATED MODULE: ./node_modules/@wordpress/server-side-render/build-module/server-side-render.js 85 86 87 88 /** 89 * External dependencies 90 */ 91 92 /** 93 * WordPress dependencies 94 */ 95 96 97 98 99 100 101 102 103 function rendererPath(block) { 104 let attributes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; 105 let urlQueryArgs = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; 106 return (0,external_wp_url_namespaceObject.addQueryArgs)(`/wp/v2/block-renderer/$block}`, { 107 context: 'edit', 108 ...(null !== attributes ? { 109 attributes 110 } : {}), 111 ...urlQueryArgs 112 }); 113 } 114 115 function DefaultEmptyResponsePlaceholder(_ref) { 116 let { 117 className 118 } = _ref; 119 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, { 120 className: className 121 }, (0,external_wp_i18n_namespaceObject.__)('Block rendered as empty.')); 122 } 123 124 function DefaultErrorResponsePlaceholder(_ref2) { 125 let { 126 response, 127 className 128 } = _ref2; 129 const errorMessage = (0,external_wp_i18n_namespaceObject.sprintf)( // translators: %s: error message describing the problem 130 (0,external_wp_i18n_namespaceObject.__)('Error loading block: %s'), response.errorMsg); 131 return (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Placeholder, { 132 className: className 133 }, errorMessage); 134 } 135 136 function DefaultLoadingResponsePlaceholder(_ref3) { 137 let { 138 children, 139 showLoader 140 } = _ref3; 141 return (0,external_wp_element_namespaceObject.createElement)("div", { 142 style: { 143 position: 'relative' 144 } 145 }, showLoader && (0,external_wp_element_namespaceObject.createElement)("div", { 146 style: { 147 position: 'absolute', 148 top: '50%', 149 left: '50%', 150 marginTop: '-9px', 151 marginLeft: '-9px' 152 } 153 }, (0,external_wp_element_namespaceObject.createElement)(external_wp_components_namespaceObject.Spinner, null)), (0,external_wp_element_namespaceObject.createElement)("div", { 154 style: { 155 opacity: showLoader ? '0.3' : 1 156 } 157 }, children)); 158 } 159 160 function ServerSideRender(props) { 161 const { 162 attributes, 163 block, 164 className, 165 httpMethod = 'GET', 166 urlQueryArgs, 167 EmptyResponsePlaceholder = DefaultEmptyResponsePlaceholder, 168 ErrorResponsePlaceholder = DefaultErrorResponsePlaceholder, 169 LoadingResponsePlaceholder = DefaultLoadingResponsePlaceholder 170 } = props; 171 const isMountedRef = (0,external_wp_element_namespaceObject.useRef)(true); 172 const [showLoader, setShowLoader] = (0,external_wp_element_namespaceObject.useState)(false); 173 const fetchRequestRef = (0,external_wp_element_namespaceObject.useRef)(); 174 const [response, setResponse] = (0,external_wp_element_namespaceObject.useState)(null); 175 const prevProps = (0,external_wp_compose_namespaceObject.usePrevious)(props); 176 const [isLoading, setIsLoading] = (0,external_wp_element_namespaceObject.useState)(false); 177 178 function fetchData() { 179 if (!isMountedRef.current) { 180 return; 181 } 182 183 setIsLoading(true); 184 185 const sanitizedAttributes = attributes && (0,external_wp_blocks_namespaceObject.__experimentalSanitizeBlockAttributes)(block, attributes); // If httpMethod is 'POST', send the attributes in the request body instead of the URL. 186 // This allows sending a larger attributes object than in a GET request, where the attributes are in the URL. 187 188 189 const isPostRequest = 'POST' === httpMethod; 190 const urlAttributes = isPostRequest ? null : sanitizedAttributes !== null && sanitizedAttributes !== void 0 ? sanitizedAttributes : null; 191 const path = rendererPath(block, urlAttributes, urlQueryArgs); 192 const data = isPostRequest ? { 193 attributes: sanitizedAttributes !== null && sanitizedAttributes !== void 0 ? sanitizedAttributes : null 194 } : null; // Store the latest fetch request so that when we process it, we can 195 // check if it is the current request, to avoid race conditions on slow networks. 196 197 const fetchRequest = fetchRequestRef.current = external_wp_apiFetch_default()({ 198 path, 199 data, 200 method: isPostRequest ? 'POST' : 'GET' 201 }).then(fetchResponse => { 202 if (isMountedRef.current && fetchRequest === fetchRequestRef.current && fetchResponse) { 203 setResponse(fetchResponse.rendered); 204 } 205 }).catch(error => { 206 if (isMountedRef.current && fetchRequest === fetchRequestRef.current) { 207 setResponse({ 208 error: true, 209 errorMsg: error.message 210 }); 211 } 212 }).finally(() => { 213 if (isMountedRef.current && fetchRequest === fetchRequestRef.current) { 214 setIsLoading(false); 215 } 216 }); 217 return fetchRequest; 218 } 219 220 const debouncedFetchData = (0,external_wp_compose_namespaceObject.useDebounce)(fetchData, 500); // When the component unmounts, set isMountedRef to false. This will 221 // let the async fetch callbacks know when to stop. 222 223 (0,external_wp_element_namespaceObject.useEffect)(() => () => { 224 isMountedRef.current = false; 225 }, []); 226 (0,external_wp_element_namespaceObject.useEffect)(() => { 227 // Don't debounce the first fetch. This ensures that the first render 228 // shows data as soon as possible. 229 if (prevProps === undefined) { 230 fetchData(); 231 } else if (!(0,external_lodash_namespaceObject.isEqual)(prevProps, props)) { 232 debouncedFetchData(); 233 } 234 }); 235 /** 236 * Effect to handle showing the loading placeholder. 237 * Show it only if there is no previous response or 238 * the request takes more than one second. 239 */ 240 241 (0,external_wp_element_namespaceObject.useEffect)(() => { 242 if (!isLoading) { 243 return; 244 } 245 246 const timeout = setTimeout(() => { 247 setShowLoader(true); 248 }, 1000); 249 return () => clearTimeout(timeout); 250 }, [isLoading]); 251 const hasResponse = !!response; 252 const hasEmptyResponse = response === ''; 253 const hasError = response === null || response === void 0 ? void 0 : response.error; 254 255 if (isLoading) { 256 return (0,external_wp_element_namespaceObject.createElement)(LoadingResponsePlaceholder, _extends({}, props, { 257 showLoader: showLoader 258 }), hasResponse && (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, { 259 className: className 260 }, response)); 261 } 262 263 if (hasEmptyResponse || !hasResponse) { 264 return (0,external_wp_element_namespaceObject.createElement)(EmptyResponsePlaceholder, props); 265 } 266 267 if (hasError) { 268 return (0,external_wp_element_namespaceObject.createElement)(ErrorResponsePlaceholder, _extends({ 269 response: response 270 }, props)); 271 } 272 273 return (0,external_wp_element_namespaceObject.createElement)(external_wp_element_namespaceObject.RawHTML, { 274 className: className 275 }, response); 276 } 277 278 ;// CONCATENATED MODULE: ./node_modules/@wordpress/server-side-render/build-module/index.js 279 280 281 282 /** 283 * WordPress dependencies 284 */ 285 286 287 288 /** 289 * Internal dependencies 290 */ 291 292 293 /** 294 * Constants 295 */ 296 297 const EMPTY_OBJECT = {}; 298 const ExportedServerSideRender = (0,external_wp_data_namespaceObject.withSelect)(select => { 299 // FIXME: @wordpress/server-side-render should not depend on @wordpress/editor. 300 // It is used by blocks that can be loaded into a *non-post* block editor. 301 // eslint-disable-next-line @wordpress/data-no-store-string-literals 302 const coreEditorSelect = select('core/editor'); 303 304 if (coreEditorSelect) { 305 const currentPostId = coreEditorSelect.getCurrentPostId(); // For templates and template parts we use a custom ID format. 306 // Since they aren't real posts, we don't want to use their ID 307 // for server-side rendering. Since they use a string based ID, 308 // we can assume real post IDs are numbers. 309 310 if (currentPostId && typeof currentPostId === 'number') { 311 return { 312 currentPostId 313 }; 314 } 315 } 316 317 return EMPTY_OBJECT; 318 })(_ref => { 319 let { 320 urlQueryArgs = EMPTY_OBJECT, 321 currentPostId, 322 ...props 323 } = _ref; 324 const newUrlQueryArgs = (0,external_wp_element_namespaceObject.useMemo)(() => { 325 if (!currentPostId) { 326 return urlQueryArgs; 327 } 328 329 return { 330 post_id: currentPostId, 331 ...urlQueryArgs 332 }; 333 }, [currentPostId, urlQueryArgs]); 334 return (0,external_wp_element_namespaceObject.createElement)(ServerSideRender, _extends({ 335 urlQueryArgs: newUrlQueryArgs 336 }, props)); 337 }); 338 339 if (window && window.wp && window.wp.components) { 340 window.wp.components.ServerSideRender = (0,external_wp_element_namespaceObject.forwardRef)((props, ref) => { 341 external_wp_deprecated_default()('wp.components.ServerSideRender', { 342 version: '6.2', 343 since: '5.3', 344 alternative: 'wp.serverSideRender' 345 }); 346 return (0,external_wp_element_namespaceObject.createElement)(ExportedServerSideRender, _extends({}, props, { 347 ref: ref 348 })); 349 }); 350 } 351 352 /* harmony default export */ var build_module = (ExportedServerSideRender); 353 354 (window.wp = window.wp || {}).serverSideRender = __webpack_exports__["default"]; 355 /******/ })() 356 ;
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated: Wed Jan 22 01:00:02 2025 | Cross-referenced by PHPXref 0.7.1 |