[ Index ] |
PHP Cross Reference of WordPress |
[Summary view] [Print] [Text view]
1 /******/ (function() { // webpackBootstrap 2 /******/ var __webpack_modules__ = ({ 3 4 /***/ 9756: 5 /***/ (function(module) { 6 7 /** 8 * Memize options object. 9 * 10 * @typedef MemizeOptions 11 * 12 * @property {number} [maxSize] Maximum size of the cache. 13 */ 14 15 /** 16 * Internal cache entry. 17 * 18 * @typedef MemizeCacheNode 19 * 20 * @property {?MemizeCacheNode|undefined} [prev] Previous node. 21 * @property {?MemizeCacheNode|undefined} [next] Next node. 22 * @property {Array<*>} args Function arguments for cache 23 * entry. 24 * @property {*} val Function result. 25 */ 26 27 /** 28 * Properties of the enhanced function for controlling cache. 29 * 30 * @typedef MemizeMemoizedFunction 31 * 32 * @property {()=>void} clear Clear the cache. 33 */ 34 35 /** 36 * Accepts a function to be memoized, and returns a new memoized function, with 37 * optional options. 38 * 39 * @template {Function} F 40 * 41 * @param {F} fn Function to memoize. 42 * @param {MemizeOptions} [options] Options object. 43 * 44 * @return {F & MemizeMemoizedFunction} Memoized function. 45 */ 46 function memize( fn, options ) { 47 var size = 0; 48 49 /** @type {?MemizeCacheNode|undefined} */ 50 var head; 51 52 /** @type {?MemizeCacheNode|undefined} */ 53 var tail; 54 55 options = options || {}; 56 57 function memoized( /* ...args */ ) { 58 var node = head, 59 len = arguments.length, 60 args, i; 61 62 searchCache: while ( node ) { 63 // Perform a shallow equality test to confirm that whether the node 64 // under test is a candidate for the arguments passed. Two arrays 65 // are shallowly equal if their length matches and each entry is 66 // strictly equal between the two sets. Avoid abstracting to a 67 // function which could incur an arguments leaking deoptimization. 68 69 // Check whether node arguments match arguments length 70 if ( node.args.length !== arguments.length ) { 71 node = node.next; 72 continue; 73 } 74 75 // Check whether node arguments match arguments values 76 for ( i = 0; i < len; i++ ) { 77 if ( node.args[ i ] !== arguments[ i ] ) { 78 node = node.next; 79 continue searchCache; 80 } 81 } 82 83 // At this point we can assume we've found a match 84 85 // Surface matched node to head if not already 86 if ( node !== head ) { 87 // As tail, shift to previous. Must only shift if not also 88 // head, since if both head and tail, there is no previous. 89 if ( node === tail ) { 90 tail = node.prev; 91 } 92 93 // Adjust siblings to point to each other. If node was tail, 94 // this also handles new tail's empty `next` assignment. 95 /** @type {MemizeCacheNode} */ ( node.prev ).next = node.next; 96 if ( node.next ) { 97 node.next.prev = node.prev; 98 } 99 100 node.next = head; 101 node.prev = null; 102 /** @type {MemizeCacheNode} */ ( head ).prev = node; 103 head = node; 104 } 105 106 // Return immediately 107 return node.val; 108 } 109 110 // No cached value found. Continue to insertion phase: 111 112 // Create a copy of arguments (avoid leaking deoptimization) 113 args = new Array( len ); 114 for ( i = 0; i < len; i++ ) { 115 args[ i ] = arguments[ i ]; 116 } 117 118 node = { 119 args: args, 120 121 // Generate the result from original function 122 val: fn.apply( null, args ), 123 }; 124 125 // Don't need to check whether node is already head, since it would 126 // have been returned above already if it was 127 128 // Shift existing head down list 129 if ( head ) { 130 head.prev = node; 131 node.next = head; 132 } else { 133 // If no head, follows that there's no tail (at initial or reset) 134 tail = node; 135 } 136 137 // Trim tail if we're reached max size and are pending cache insertion 138 if ( size === /** @type {MemizeOptions} */ ( options ).maxSize ) { 139 tail = /** @type {MemizeCacheNode} */ ( tail ).prev; 140 /** @type {MemizeCacheNode} */ ( tail ).next = null; 141 } else { 142 size++; 143 } 144 145 head = node; 146 147 return node.val; 148 } 149 150 memoized.clear = function() { 151 head = null; 152 tail = null; 153 size = 0; 154 }; 155 156 if ( false ) {} 157 158 // Ignore reason: There's not a clear solution to create an intersection of 159 // the function with additional properties, where the goal is to retain the 160 // function signature of the incoming argument and add control properties 161 // on the return value. 162 163 // @ts-ignore 164 return memoized; 165 } 166 167 module.exports = memize; 168 169 170 /***/ }) 171 172 /******/ }); 173 /************************************************************************/ 174 /******/ // The module cache 175 /******/ var __webpack_module_cache__ = {}; 176 /******/ 177 /******/ // The require function 178 /******/ function __webpack_require__(moduleId) { 179 /******/ // Check if module is in cache 180 /******/ var cachedModule = __webpack_module_cache__[moduleId]; 181 /******/ if (cachedModule !== undefined) { 182 /******/ return cachedModule.exports; 183 /******/ } 184 /******/ // Create a new module (and put it into the cache) 185 /******/ var module = __webpack_module_cache__[moduleId] = { 186 /******/ // no module.id needed 187 /******/ // no module.loaded needed 188 /******/ exports: {} 189 /******/ }; 190 /******/ 191 /******/ // Execute the module function 192 /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__); 193 /******/ 194 /******/ // Return the exports of the module 195 /******/ return module.exports; 196 /******/ } 197 /******/ 198 /************************************************************************/ 199 /******/ /* webpack/runtime/compat get default export */ 200 /******/ !function() { 201 /******/ // getDefaultExport function for compatibility with non-harmony modules 202 /******/ __webpack_require__.n = function(module) { 203 /******/ var getter = module && module.__esModule ? 204 /******/ function() { return module['default']; } : 205 /******/ function() { return module; }; 206 /******/ __webpack_require__.d(getter, { a: getter }); 207 /******/ return getter; 208 /******/ }; 209 /******/ }(); 210 /******/ 211 /******/ /* webpack/runtime/define property getters */ 212 /******/ !function() { 213 /******/ // define getter functions for harmony exports 214 /******/ __webpack_require__.d = function(exports, definition) { 215 /******/ for(var key in definition) { 216 /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { 217 /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); 218 /******/ } 219 /******/ } 220 /******/ }; 221 /******/ }(); 222 /******/ 223 /******/ /* webpack/runtime/hasOwnProperty shorthand */ 224 /******/ !function() { 225 /******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } 226 /******/ }(); 227 /******/ 228 /************************************************************************/ 229 var __webpack_exports__ = {}; 230 // This entry need to be wrapped in an IIFE because it need to be in strict mode. 231 !function() { 232 "use strict"; 233 234 // EXPORTS 235 __webpack_require__.d(__webpack_exports__, { 236 "default": function() { return /* binding */ build_module; } 237 }); 238 239 // UNUSED EXPORTS: attrs, fromMatch, next, regexp, replace, string 240 241 ;// CONCATENATED MODULE: external "lodash" 242 var external_lodash_namespaceObject = window["lodash"]; 243 // EXTERNAL MODULE: ./node_modules/memize/index.js 244 var memize = __webpack_require__(9756); 245 var memize_default = /*#__PURE__*/__webpack_require__.n(memize); 246 ;// CONCATENATED MODULE: ./node_modules/@wordpress/shortcode/build-module/index.js 247 /** 248 * External dependencies 249 */ 250 251 252 /** 253 * Shortcode attributes object. 254 * 255 * @typedef {Object} WPShortcodeAttrs 256 * 257 * @property {Object} named Object with named attributes. 258 * @property {Array} numeric Array with numeric attributes. 259 */ 260 261 /** 262 * Shortcode object. 263 * 264 * @typedef {Object} WPShortcode 265 * 266 * @property {string} tag Shortcode tag. 267 * @property {WPShortcodeAttrs} attrs Shortcode attributes. 268 * @property {string} content Shortcode content. 269 * @property {string} type Shortcode type: `self-closing`, 270 * `closed`, or `single`. 271 */ 272 273 /** 274 * @typedef {Object} WPShortcodeMatch 275 * 276 * @property {number} index Index the shortcode is found at. 277 * @property {string} content Matched content. 278 * @property {WPShortcode} shortcode Shortcode instance of the match. 279 */ 280 281 /** 282 * Find the next matching shortcode. 283 * 284 * @param {string} tag Shortcode tag. 285 * @param {string} text Text to search. 286 * @param {number} index Index to start search from. 287 * 288 * @return {?WPShortcodeMatch} Matched information. 289 */ 290 291 function next(tag, text) { 292 let index = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0; 293 const re = regexp(tag); 294 re.lastIndex = index; 295 const match = re.exec(text); 296 297 if (!match) { 298 return; 299 } // If we matched an escaped shortcode, try again. 300 301 302 if ('[' === match[1] && ']' === match[7]) { 303 return next(tag, text, re.lastIndex); 304 } 305 306 const result = { 307 index: match.index, 308 content: match[0], 309 shortcode: fromMatch(match) 310 }; // If we matched a leading `[`, strip it from the match and increment the 311 // index accordingly. 312 313 if (match[1]) { 314 result.content = result.content.slice(1); 315 result.index++; 316 } // If we matched a trailing `]`, strip it from the match. 317 318 319 if (match[7]) { 320 result.content = result.content.slice(0, -1); 321 } 322 323 return result; 324 } 325 /** 326 * Replace matching shortcodes in a block of text. 327 * 328 * @param {string} tag Shortcode tag. 329 * @param {string} text Text to search. 330 * @param {Function} callback Function to process the match and return 331 * replacement string. 332 * 333 * @return {string} Text with shortcodes replaced. 334 */ 335 336 function replace(tag, text, callback) { 337 return text.replace(regexp(tag), function (match, left, $3, attrs, slash, content, closing, right) { 338 // If both extra brackets exist, the shortcode has been properly 339 // escaped. 340 if (left === '[' && right === ']') { 341 return match; 342 } // Create the match object and pass it through the callback. 343 344 345 const result = callback(fromMatch(arguments)); // Make sure to return any of the extra brackets if they weren't used to 346 // escape the shortcode. 347 348 return result || result === '' ? left + result + right : match; 349 }); 350 } 351 /** 352 * Generate a string from shortcode parameters. 353 * 354 * Creates a shortcode instance and returns a string. 355 * 356 * Accepts the same `options` as the `shortcode()` constructor, containing a 357 * `tag` string, a string or object of `attrs`, a boolean indicating whether to 358 * format the shortcode using a `single` tag, and a `content` string. 359 * 360 * @param {Object} options 361 * 362 * @return {string} String representation of the shortcode. 363 */ 364 365 function string(options) { 366 return new shortcode(options).string(); 367 } 368 /** 369 * Generate a RegExp to identify a shortcode. 370 * 371 * The base regex is functionally equivalent to the one found in 372 * `get_shortcode_regex()` in `wp-includes/shortcodes.php`. 373 * 374 * Capture groups: 375 * 376 * 1. An extra `[` to allow for escaping shortcodes with double `[[]]` 377 * 2. The shortcode name 378 * 3. The shortcode argument list 379 * 4. The self closing `/` 380 * 5. The content of a shortcode when it wraps some content. 381 * 6. The closing tag. 382 * 7. An extra `]` to allow for escaping shortcodes with double `[[]]` 383 * 384 * @param {string} tag Shortcode tag. 385 * 386 * @return {RegExp} Shortcode RegExp. 387 */ 388 389 function regexp(tag) { 390 return new RegExp('\\[(\\[?)(' + tag + ')(?![\\w-])([^\\]\\/]*(?:\\/(?!\\])[^\\]\\/]*)*?)(?:(\\/)\\]|\\](?:([^\\[]*(?:\\[(?!\\/\\2\\])[^\\[]*)*)(\\[\\/\\2\\]))?)(\\]?)', 'g'); 391 } 392 /** 393 * Parse shortcode attributes. 394 * 395 * Shortcodes accept many types of attributes. These can chiefly be divided into 396 * named and numeric attributes: 397 * 398 * Named attributes are assigned on a key/value basis, while numeric attributes 399 * are treated as an array. 400 * 401 * Named attributes can be formatted as either `name="value"`, `name='value'`, 402 * or `name=value`. Numeric attributes can be formatted as `"value"` or just 403 * `value`. 404 * 405 * @param {string} text Serialised shortcode attributes. 406 * 407 * @return {WPShortcodeAttrs} Parsed shortcode attributes. 408 */ 409 410 const attrs = memize_default()(text => { 411 const named = {}; 412 const numeric = []; // This regular expression is reused from `shortcode_parse_atts()` in 413 // `wp-includes/shortcodes.php`. 414 // 415 // Capture groups: 416 // 417 // 1. An attribute name, that corresponds to... 418 // 2. a value in double quotes. 419 // 3. An attribute name, that corresponds to... 420 // 4. a value in single quotes. 421 // 5. An attribute name, that corresponds to... 422 // 6. an unquoted value. 423 // 7. A numeric attribute in double quotes. 424 // 8. A numeric attribute in single quotes. 425 // 9. An unquoted numeric attribute. 426 427 const pattern = /([\w-]+)\s*=\s*"([^"]*)"(?:\s|$)|([\w-]+)\s*=\s*'([^']*)'(?:\s|$)|([\w-]+)\s*=\s*([^\s'"]+)(?:\s|$)|"([^"]*)"(?:\s|$)|'([^']*)'(?:\s|$)|(\S+)(?:\s|$)/g; // Map zero-width spaces to actual spaces. 428 429 text = text.replace(/[\u00a0\u200b]/g, ' '); 430 let match; // Match and normalize attributes. 431 432 while (match = pattern.exec(text)) { 433 if (match[1]) { 434 named[match[1].toLowerCase()] = match[2]; 435 } else if (match[3]) { 436 named[match[3].toLowerCase()] = match[4]; 437 } else if (match[5]) { 438 named[match[5].toLowerCase()] = match[6]; 439 } else if (match[7]) { 440 numeric.push(match[7]); 441 } else if (match[8]) { 442 numeric.push(match[8]); 443 } else if (match[9]) { 444 numeric.push(match[9]); 445 } 446 } 447 448 return { 449 named, 450 numeric 451 }; 452 }); 453 /** 454 * Generate a Shortcode Object from a RegExp match. 455 * 456 * Accepts a `match` object from calling `regexp.exec()` on a `RegExp` generated 457 * by `regexp()`. `match` can also be set to the `arguments` from a callback 458 * passed to `regexp.replace()`. 459 * 460 * @param {Array} match Match array. 461 * 462 * @return {WPShortcode} Shortcode instance. 463 */ 464 465 function fromMatch(match) { 466 let type; 467 468 if (match[4]) { 469 type = 'self-closing'; 470 } else if (match[6]) { 471 type = 'closed'; 472 } else { 473 type = 'single'; 474 } 475 476 return new shortcode({ 477 tag: match[2], 478 attrs: match[3], 479 type, 480 content: match[5] 481 }); 482 } 483 /** 484 * Creates a shortcode instance. 485 * 486 * To access a raw representation of a shortcode, pass an `options` object, 487 * containing a `tag` string, a string or object of `attrs`, a string indicating 488 * the `type` of the shortcode ('single', 'self-closing', or 'closed'), and a 489 * `content` string. 490 * 491 * @param {Object} options Options as described. 492 * 493 * @return {WPShortcode} Shortcode instance. 494 */ 495 496 const shortcode = (0,external_lodash_namespaceObject.extend)(function (options) { 497 (0,external_lodash_namespaceObject.extend)(this, (0,external_lodash_namespaceObject.pick)(options || {}, 'tag', 'attrs', 'type', 'content')); 498 const attributes = this.attrs; // Ensure we have a correctly formatted `attrs` object. 499 500 this.attrs = { 501 named: {}, 502 numeric: [] 503 }; 504 505 if (!attributes) { 506 return; 507 } // Parse a string of attributes. 508 509 510 if ((0,external_lodash_namespaceObject.isString)(attributes)) { 511 this.attrs = attrs(attributes); // Identify a correctly formatted `attrs` object. 512 } else if ((0,external_lodash_namespaceObject.isEqual)(Object.keys(attributes), ['named', 'numeric'])) { 513 this.attrs = attributes; // Handle a flat object of attributes. 514 } else { 515 (0,external_lodash_namespaceObject.forEach)(attributes, (value, key) => { 516 this.set(key, value); 517 }); 518 } 519 }, { 520 next, 521 replace, 522 string, 523 regexp, 524 attrs, 525 fromMatch 526 }); 527 (0,external_lodash_namespaceObject.extend)(shortcode.prototype, { 528 /** 529 * Get a shortcode attribute. 530 * 531 * Automatically detects whether `attr` is named or numeric and routes it 532 * accordingly. 533 * 534 * @param {(number|string)} attr Attribute key. 535 * 536 * @return {string} Attribute value. 537 */ 538 get(attr) { 539 return this.attrs[(0,external_lodash_namespaceObject.isNumber)(attr) ? 'numeric' : 'named'][attr]; 540 }, 541 542 /** 543 * Set a shortcode attribute. 544 * 545 * Automatically detects whether `attr` is named or numeric and routes it 546 * accordingly. 547 * 548 * @param {(number|string)} attr Attribute key. 549 * @param {string} value Attribute value. 550 * 551 * @return {WPShortcode} Shortcode instance. 552 */ 553 set(attr, value) { 554 this.attrs[(0,external_lodash_namespaceObject.isNumber)(attr) ? 'numeric' : 'named'][attr] = value; 555 return this; 556 }, 557 558 /** 559 * Transform the shortcode into a string. 560 * 561 * @return {string} String representation of the shortcode. 562 */ 563 string() { 564 let text = '[' + this.tag; 565 (0,external_lodash_namespaceObject.forEach)(this.attrs.numeric, value => { 566 if (/\s/.test(value)) { 567 text += ' "' + value + '"'; 568 } else { 569 text += ' ' + value; 570 } 571 }); 572 (0,external_lodash_namespaceObject.forEach)(this.attrs.named, (value, name) => { 573 text += ' ' + name + '="' + value + '"'; 574 }); // If the tag is marked as `single` or `self-closing`, close the tag and 575 // ignore any additional content. 576 577 if ('single' === this.type) { 578 return text + ']'; 579 } else if ('self-closing' === this.type) { 580 return text + ' /]'; 581 } // Complete the opening tag. 582 583 584 text += ']'; 585 586 if (this.content) { 587 text += this.content; 588 } // Add the closing tag. 589 590 591 return text + '[/' + this.tag + ']'; 592 } 593 594 }); 595 /* harmony default export */ var build_module = (shortcode); 596 597 }(); 598 (window.wp = window.wp || {}).shortcode = __webpack_exports__["default"]; 599 /******/ })() 600 ;
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 |