[ 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/define property getters */ 8 /******/ !function() { 9 /******/ // define getter functions for harmony exports 10 /******/ __webpack_require__.d = function(exports, definition) { 11 /******/ for(var key in definition) { 12 /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { 13 /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); 14 /******/ } 15 /******/ } 16 /******/ }; 17 /******/ }(); 18 /******/ 19 /******/ /* webpack/runtime/hasOwnProperty shorthand */ 20 /******/ !function() { 21 /******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } 22 /******/ }(); 23 /******/ 24 /******/ /* webpack/runtime/make namespace object */ 25 /******/ !function() { 26 /******/ // define __esModule on exports 27 /******/ __webpack_require__.r = function(exports) { 28 /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { 29 /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); 30 /******/ } 31 /******/ Object.defineProperty(exports, '__esModule', { value: true }); 32 /******/ }; 33 /******/ }(); 34 /******/ 35 /************************************************************************/ 36 var __webpack_exports__ = {}; 37 // ESM COMPAT FLAG 38 __webpack_require__.r(__webpack_exports__); 39 40 // EXPORTS 41 __webpack_require__.d(__webpack_exports__, { 42 "store": function() { return /* reexport */ store; } 43 }); 44 45 // NAMESPACE OBJECT: ./node_modules/@wordpress/annotations/build-module/store/selectors.js 46 var selectors_namespaceObject = {}; 47 __webpack_require__.r(selectors_namespaceObject); 48 __webpack_require__.d(selectors_namespaceObject, { 49 "__experimentalGetAllAnnotationsForBlock": function() { return __experimentalGetAllAnnotationsForBlock; }, 50 "__experimentalGetAnnotations": function() { return __experimentalGetAnnotations; }, 51 "__experimentalGetAnnotationsForBlock": function() { return __experimentalGetAnnotationsForBlock; }, 52 "__experimentalGetAnnotationsForRichText": function() { return __experimentalGetAnnotationsForRichText; } 53 }); 54 55 // NAMESPACE OBJECT: ./node_modules/@wordpress/annotations/build-module/store/actions.js 56 var actions_namespaceObject = {}; 57 __webpack_require__.r(actions_namespaceObject); 58 __webpack_require__.d(actions_namespaceObject, { 59 "__experimentalAddAnnotation": function() { return __experimentalAddAnnotation; }, 60 "__experimentalRemoveAnnotation": function() { return __experimentalRemoveAnnotation; }, 61 "__experimentalRemoveAnnotationsBySource": function() { return __experimentalRemoveAnnotationsBySource; }, 62 "__experimentalUpdateAnnotationRange": function() { return __experimentalUpdateAnnotationRange; } 63 }); 64 65 ;// CONCATENATED MODULE: external ["wp","richText"] 66 var external_wp_richText_namespaceObject = window["wp"]["richText"]; 67 ;// CONCATENATED MODULE: external ["wp","i18n"] 68 var external_wp_i18n_namespaceObject = window["wp"]["i18n"]; 69 ;// CONCATENATED MODULE: ./node_modules/@wordpress/annotations/build-module/store/constants.js 70 /** 71 * The identifier for the data store. 72 * 73 * @type {string} 74 */ 75 const STORE_NAME = 'core/annotations'; 76 77 ;// CONCATENATED MODULE: ./node_modules/@wordpress/annotations/build-module/format/annotation.js 78 /** 79 * WordPress dependencies 80 */ 81 82 83 const FORMAT_NAME = 'core/annotation'; 84 const ANNOTATION_ATTRIBUTE_PREFIX = 'annotation-text-'; 85 /** 86 * Internal dependencies 87 */ 88 89 90 /** 91 * Applies given annotations to the given record. 92 * 93 * @param {Object} record The record to apply annotations to. 94 * @param {Array} annotations The annotation to apply. 95 * @return {Object} A record with the annotations applied. 96 */ 97 98 function applyAnnotations(record) { 99 let annotations = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; 100 annotations.forEach(annotation => { 101 let { 102 start, 103 end 104 } = annotation; 105 106 if (start > record.text.length) { 107 start = record.text.length; 108 } 109 110 if (end > record.text.length) { 111 end = record.text.length; 112 } 113 114 const className = ANNOTATION_ATTRIBUTE_PREFIX + annotation.source; 115 const id = ANNOTATION_ATTRIBUTE_PREFIX + annotation.id; 116 record = (0,external_wp_richText_namespaceObject.applyFormat)(record, { 117 type: FORMAT_NAME, 118 attributes: { 119 className, 120 id 121 } 122 }, start, end); 123 }); 124 return record; 125 } 126 /** 127 * Removes annotations from the given record. 128 * 129 * @param {Object} record Record to remove annotations from. 130 * @return {Object} The cleaned record. 131 */ 132 133 function removeAnnotations(record) { 134 return removeFormat(record, 'core/annotation', 0, record.text.length); 135 } 136 /** 137 * Retrieves the positions of annotations inside an array of formats. 138 * 139 * @param {Array} formats Formats with annotations in there. 140 * @return {Object} ID keyed positions of annotations. 141 */ 142 143 function retrieveAnnotationPositions(formats) { 144 const positions = {}; 145 formats.forEach((characterFormats, i) => { 146 characterFormats = characterFormats || []; 147 characterFormats = characterFormats.filter(format => format.type === FORMAT_NAME); 148 characterFormats.forEach(format => { 149 let { 150 id 151 } = format.attributes; 152 id = id.replace(ANNOTATION_ATTRIBUTE_PREFIX, ''); 153 154 if (!positions.hasOwnProperty(id)) { 155 positions[id] = { 156 start: i 157 }; 158 } // Annotations refer to positions between characters. 159 // Formats refer to the character themselves. 160 // So we need to adjust for that here. 161 162 163 positions[id].end = i + 1; 164 }); 165 }); 166 return positions; 167 } 168 /** 169 * Updates annotations in the state based on positions retrieved from RichText. 170 * 171 * @param {Array} annotations The annotations that are currently applied. 172 * @param {Array} positions The current positions of the given annotations. 173 * @param {Object} actions 174 * @param {Function} actions.removeAnnotation Function to remove an annotation from the state. 175 * @param {Function} actions.updateAnnotationRange Function to update an annotation range in the state. 176 */ 177 178 179 function updateAnnotationsWithPositions(annotations, positions, _ref) { 180 let { 181 removeAnnotation, 182 updateAnnotationRange 183 } = _ref; 184 annotations.forEach(currentAnnotation => { 185 const position = positions[currentAnnotation.id]; // If we cannot find an annotation, delete it. 186 187 if (!position) { 188 // Apparently the annotation has been removed, so remove it from the state: 189 // Remove... 190 removeAnnotation(currentAnnotation.id); 191 return; 192 } 193 194 const { 195 start, 196 end 197 } = currentAnnotation; 198 199 if (start !== position.start || end !== position.end) { 200 updateAnnotationRange(currentAnnotation.id, position.start, position.end); 201 } 202 }); 203 } 204 205 const annotation = { 206 name: FORMAT_NAME, 207 title: (0,external_wp_i18n_namespaceObject.__)('Annotation'), 208 tagName: 'mark', 209 className: 'annotation-text', 210 attributes: { 211 className: 'class', 212 id: 'id' 213 }, 214 215 edit() { 216 return null; 217 }, 218 219 __experimentalGetPropsForEditableTreePreparation(select, _ref2) { 220 let { 221 richTextIdentifier, 222 blockClientId 223 } = _ref2; 224 return { 225 annotations: select(STORE_NAME).__experimentalGetAnnotationsForRichText(blockClientId, richTextIdentifier) 226 }; 227 }, 228 229 __experimentalCreatePrepareEditableTree(_ref3) { 230 let { 231 annotations 232 } = _ref3; 233 return (formats, text) => { 234 if (annotations.length === 0) { 235 return formats; 236 } 237 238 let record = { 239 formats, 240 text 241 }; 242 record = applyAnnotations(record, annotations); 243 return record.formats; 244 }; 245 }, 246 247 __experimentalGetPropsForEditableTreeChangeHandler(dispatch) { 248 return { 249 removeAnnotation: dispatch(STORE_NAME).__experimentalRemoveAnnotation, 250 updateAnnotationRange: dispatch(STORE_NAME).__experimentalUpdateAnnotationRange 251 }; 252 }, 253 254 __experimentalCreateOnChangeEditableValue(props) { 255 return formats => { 256 const positions = retrieveAnnotationPositions(formats); 257 const { 258 removeAnnotation, 259 updateAnnotationRange, 260 annotations 261 } = props; 262 updateAnnotationsWithPositions(annotations, positions, { 263 removeAnnotation, 264 updateAnnotationRange 265 }); 266 }; 267 } 268 269 }; 270 271 ;// CONCATENATED MODULE: ./node_modules/@wordpress/annotations/build-module/format/index.js 272 /** 273 * WordPress dependencies 274 */ 275 276 /** 277 * Internal dependencies 278 */ 279 280 281 const { 282 name: format_name, 283 ...settings 284 } = annotation; 285 (0,external_wp_richText_namespaceObject.registerFormatType)(format_name, settings); 286 287 ;// CONCATENATED MODULE: external ["wp","hooks"] 288 var external_wp_hooks_namespaceObject = window["wp"]["hooks"]; 289 ;// CONCATENATED MODULE: external ["wp","data"] 290 var external_wp_data_namespaceObject = window["wp"]["data"]; 291 ;// CONCATENATED MODULE: ./node_modules/@wordpress/annotations/build-module/block/index.js 292 /** 293 * WordPress dependencies 294 */ 295 296 297 /** 298 * Internal dependencies 299 */ 300 301 302 /** 303 * Adds annotation className to the block-list-block component. 304 * 305 * @param {Object} OriginalComponent The original BlockListBlock component. 306 * @return {Object} The enhanced component. 307 */ 308 309 const addAnnotationClassName = OriginalComponent => { 310 return (0,external_wp_data_namespaceObject.withSelect)((select, _ref) => { 311 let { 312 clientId, 313 className 314 } = _ref; 315 316 const annotations = select(STORE_NAME).__experimentalGetAnnotationsForBlock(clientId); 317 318 return { 319 className: annotations.map(annotation => { 320 return 'is-annotated-by-' + annotation.source; 321 }).concat(className).filter(Boolean).join(' ') 322 }; 323 })(OriginalComponent); 324 }; 325 326 (0,external_wp_hooks_namespaceObject.addFilter)('editor.BlockListBlock', 'core/annotations', addAnnotationClassName); 327 328 ;// CONCATENATED MODULE: external "lodash" 329 var external_lodash_namespaceObject = window["lodash"]; 330 ;// CONCATENATED MODULE: ./node_modules/@wordpress/annotations/build-module/store/reducer.js 331 /** 332 * External dependencies 333 */ 334 335 /** 336 * Filters an array based on the predicate, but keeps the reference the same if 337 * the array hasn't changed. 338 * 339 * @param {Array} collection The collection to filter. 340 * @param {Function} predicate Function that determines if the item should stay 341 * in the array. 342 * @return {Array} Filtered array. 343 */ 344 345 function filterWithReference(collection, predicate) { 346 const filteredCollection = collection.filter(predicate); 347 return collection.length === filteredCollection.length ? collection : filteredCollection; 348 } 349 /** 350 * Verifies whether the given annotations is a valid annotation. 351 * 352 * @param {Object} annotation The annotation to verify. 353 * @return {boolean} Whether the given annotation is valid. 354 */ 355 356 357 function isValidAnnotationRange(annotation) { 358 return (0,external_lodash_namespaceObject.isNumber)(annotation.start) && (0,external_lodash_namespaceObject.isNumber)(annotation.end) && annotation.start <= annotation.end; 359 } 360 /** 361 * Reducer managing annotations. 362 * 363 * @param {Object} state The annotations currently shown in the editor. 364 * @param {Object} action Dispatched action. 365 * 366 * @return {Array} Updated state. 367 */ 368 369 370 function annotations() { 371 var _state$blockClientId; 372 373 let state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; 374 let action = arguments.length > 1 ? arguments[1] : undefined; 375 376 switch (action.type) { 377 case 'ANNOTATION_ADD': 378 const blockClientId = action.blockClientId; 379 const newAnnotation = { 380 id: action.id, 381 blockClientId, 382 richTextIdentifier: action.richTextIdentifier, 383 source: action.source, 384 selector: action.selector, 385 range: action.range 386 }; 387 388 if (newAnnotation.selector === 'range' && !isValidAnnotationRange(newAnnotation.range)) { 389 return state; 390 } 391 392 const previousAnnotationsForBlock = (_state$blockClientId = state === null || state === void 0 ? void 0 : state[blockClientId]) !== null && _state$blockClientId !== void 0 ? _state$blockClientId : []; 393 return { ...state, 394 [blockClientId]: [...previousAnnotationsForBlock, newAnnotation] 395 }; 396 397 case 'ANNOTATION_REMOVE': 398 return (0,external_lodash_namespaceObject.mapValues)(state, annotationsForBlock => { 399 return filterWithReference(annotationsForBlock, annotation => { 400 return annotation.id !== action.annotationId; 401 }); 402 }); 403 404 case 'ANNOTATION_UPDATE_RANGE': 405 return (0,external_lodash_namespaceObject.mapValues)(state, annotationsForBlock => { 406 let hasChangedRange = false; 407 const newAnnotations = annotationsForBlock.map(annotation => { 408 if (annotation.id === action.annotationId) { 409 hasChangedRange = true; 410 return { ...annotation, 411 range: { 412 start: action.start, 413 end: action.end 414 } 415 }; 416 } 417 418 return annotation; 419 }); 420 return hasChangedRange ? newAnnotations : annotationsForBlock; 421 }); 422 423 case 'ANNOTATION_REMOVE_SOURCE': 424 return (0,external_lodash_namespaceObject.mapValues)(state, annotationsForBlock => { 425 return filterWithReference(annotationsForBlock, annotation => { 426 return annotation.source !== action.source; 427 }); 428 }); 429 } 430 431 return state; 432 } 433 /* harmony default export */ var reducer = (annotations); 434 435 ;// CONCATENATED MODULE: ./node_modules/rememo/es/rememo.js 436 437 438 var LEAF_KEY, hasWeakMap; 439 440 /** 441 * Arbitrary value used as key for referencing cache object in WeakMap tree. 442 * 443 * @type {Object} 444 */ 445 LEAF_KEY = {}; 446 447 /** 448 * Whether environment supports WeakMap. 449 * 450 * @type {boolean} 451 */ 452 hasWeakMap = typeof WeakMap !== 'undefined'; 453 454 /** 455 * Returns the first argument as the sole entry in an array. 456 * 457 * @param {*} value Value to return. 458 * 459 * @return {Array} Value returned as entry in array. 460 */ 461 function arrayOf( value ) { 462 return [ value ]; 463 } 464 465 /** 466 * Returns true if the value passed is object-like, or false otherwise. A value 467 * is object-like if it can support property assignment, e.g. object or array. 468 * 469 * @param {*} value Value to test. 470 * 471 * @return {boolean} Whether value is object-like. 472 */ 473 function isObjectLike( value ) { 474 return !! value && 'object' === typeof value; 475 } 476 477 /** 478 * Creates and returns a new cache object. 479 * 480 * @return {Object} Cache object. 481 */ 482 function createCache() { 483 var cache = { 484 clear: function() { 485 cache.head = null; 486 }, 487 }; 488 489 return cache; 490 } 491 492 /** 493 * Returns true if entries within the two arrays are strictly equal by 494 * reference from a starting index. 495 * 496 * @param {Array} a First array. 497 * @param {Array} b Second array. 498 * @param {number} fromIndex Index from which to start comparison. 499 * 500 * @return {boolean} Whether arrays are shallowly equal. 501 */ 502 function isShallowEqual( a, b, fromIndex ) { 503 var i; 504 505 if ( a.length !== b.length ) { 506 return false; 507 } 508 509 for ( i = fromIndex; i < a.length; i++ ) { 510 if ( a[ i ] !== b[ i ] ) { 511 return false; 512 } 513 } 514 515 return true; 516 } 517 518 /** 519 * Returns a memoized selector function. The getDependants function argument is 520 * called before the memoized selector and is expected to return an immutable 521 * reference or array of references on which the selector depends for computing 522 * its own return value. The memoize cache is preserved only as long as those 523 * dependant references remain the same. If getDependants returns a different 524 * reference(s), the cache is cleared and the selector value regenerated. 525 * 526 * @param {Function} selector Selector function. 527 * @param {Function} getDependants Dependant getter returning an immutable 528 * reference or array of reference used in 529 * cache bust consideration. 530 * 531 * @return {Function} Memoized selector. 532 */ 533 /* harmony default export */ function rememo(selector, getDependants ) { 534 var rootCache, getCache; 535 536 // Use object source as dependant if getter not provided 537 if ( ! getDependants ) { 538 getDependants = arrayOf; 539 } 540 541 /** 542 * Returns the root cache. If WeakMap is supported, this is assigned to the 543 * root WeakMap cache set, otherwise it is a shared instance of the default 544 * cache object. 545 * 546 * @return {(WeakMap|Object)} Root cache object. 547 */ 548 function getRootCache() { 549 return rootCache; 550 } 551 552 /** 553 * Returns the cache for a given dependants array. When possible, a WeakMap 554 * will be used to create a unique cache for each set of dependants. This 555 * is feasible due to the nature of WeakMap in allowing garbage collection 556 * to occur on entries where the key object is no longer referenced. Since 557 * WeakMap requires the key to be an object, this is only possible when the 558 * dependant is object-like. The root cache is created as a hierarchy where 559 * each top-level key is the first entry in a dependants set, the value a 560 * WeakMap where each key is the next dependant, and so on. This continues 561 * so long as the dependants are object-like. If no dependants are object- 562 * like, then the cache is shared across all invocations. 563 * 564 * @see isObjectLike 565 * 566 * @param {Array} dependants Selector dependants. 567 * 568 * @return {Object} Cache object. 569 */ 570 function getWeakMapCache( dependants ) { 571 var caches = rootCache, 572 isUniqueByDependants = true, 573 i, dependant, map, cache; 574 575 for ( i = 0; i < dependants.length; i++ ) { 576 dependant = dependants[ i ]; 577 578 // Can only compose WeakMap from object-like key. 579 if ( ! isObjectLike( dependant ) ) { 580 isUniqueByDependants = false; 581 break; 582 } 583 584 // Does current segment of cache already have a WeakMap? 585 if ( caches.has( dependant ) ) { 586 // Traverse into nested WeakMap. 587 caches = caches.get( dependant ); 588 } else { 589 // Create, set, and traverse into a new one. 590 map = new WeakMap(); 591 caches.set( dependant, map ); 592 caches = map; 593 } 594 } 595 596 // We use an arbitrary (but consistent) object as key for the last item 597 // in the WeakMap to serve as our running cache. 598 if ( ! caches.has( LEAF_KEY ) ) { 599 cache = createCache(); 600 cache.isUniqueByDependants = isUniqueByDependants; 601 caches.set( LEAF_KEY, cache ); 602 } 603 604 return caches.get( LEAF_KEY ); 605 } 606 607 // Assign cache handler by availability of WeakMap 608 getCache = hasWeakMap ? getWeakMapCache : getRootCache; 609 610 /** 611 * Resets root memoization cache. 612 */ 613 function clear() { 614 rootCache = hasWeakMap ? new WeakMap() : createCache(); 615 } 616 617 // eslint-disable-next-line jsdoc/check-param-names 618 /** 619 * The augmented selector call, considering first whether dependants have 620 * changed before passing it to underlying memoize function. 621 * 622 * @param {Object} source Source object for derivation. 623 * @param {...*} extraArgs Additional arguments to pass to selector. 624 * 625 * @return {*} Selector result. 626 */ 627 function callSelector( /* source, ...extraArgs */ ) { 628 var len = arguments.length, 629 cache, node, i, args, dependants; 630 631 // Create copy of arguments (avoid leaking deoptimization). 632 args = new Array( len ); 633 for ( i = 0; i < len; i++ ) { 634 args[ i ] = arguments[ i ]; 635 } 636 637 dependants = getDependants.apply( null, args ); 638 cache = getCache( dependants ); 639 640 // If not guaranteed uniqueness by dependants (primitive type or lack 641 // of WeakMap support), shallow compare against last dependants and, if 642 // references have changed, destroy cache to recalculate result. 643 if ( ! cache.isUniqueByDependants ) { 644 if ( cache.lastDependants && ! isShallowEqual( dependants, cache.lastDependants, 0 ) ) { 645 cache.clear(); 646 } 647 648 cache.lastDependants = dependants; 649 } 650 651 node = cache.head; 652 while ( node ) { 653 // Check whether node arguments match arguments 654 if ( ! isShallowEqual( node.args, args, 1 ) ) { 655 node = node.next; 656 continue; 657 } 658 659 // At this point we can assume we've found a match 660 661 // Surface matched node to head if not already 662 if ( node !== cache.head ) { 663 // Adjust siblings to point to each other. 664 node.prev.next = node.next; 665 if ( node.next ) { 666 node.next.prev = node.prev; 667 } 668 669 node.next = cache.head; 670 node.prev = null; 671 cache.head.prev = node; 672 cache.head = node; 673 } 674 675 // Return immediately 676 return node.val; 677 } 678 679 // No cached value found. Continue to insertion phase: 680 681 node = { 682 // Generate the result from original function 683 val: selector.apply( null, args ), 684 }; 685 686 // Avoid including the source object in the cache. 687 args[ 0 ] = null; 688 node.args = args; 689 690 // Don't need to check whether node is already head, since it would 691 // have been returned above already if it was 692 693 // Shift existing head down list 694 if ( cache.head ) { 695 cache.head.prev = node; 696 node.next = cache.head; 697 } 698 699 cache.head = node; 700 701 return node.val; 702 } 703 704 callSelector.getDependants = getDependants; 705 callSelector.clear = clear; 706 clear(); 707 708 return callSelector; 709 } 710 711 ;// CONCATENATED MODULE: ./node_modules/@wordpress/annotations/build-module/store/selectors.js 712 /** 713 * External dependencies 714 */ 715 716 717 /** 718 * Shared reference to an empty array for cases where it is important to avoid 719 * returning a new array reference on every invocation, as in a connected or 720 * other pure component which performs `shouldComponentUpdate` check on props. 721 * This should be used as a last resort, since the normalized data should be 722 * maintained by the reducer result in state. 723 * 724 * @type {Array} 725 */ 726 727 const EMPTY_ARRAY = []; 728 /** 729 * Returns the annotations for a specific client ID. 730 * 731 * @param {Object} state Editor state. 732 * @param {string} clientId The ID of the block to get the annotations for. 733 * 734 * @return {Array} The annotations applicable to this block. 735 */ 736 737 const __experimentalGetAnnotationsForBlock = rememo((state, blockClientId) => { 738 var _state$blockClientId; 739 740 return ((_state$blockClientId = state === null || state === void 0 ? void 0 : state[blockClientId]) !== null && _state$blockClientId !== void 0 ? _state$blockClientId : []).filter(annotation => { 741 return annotation.selector === 'block'; 742 }); 743 }, (state, blockClientId) => { 744 var _state$blockClientId2; 745 746 return [(_state$blockClientId2 = state === null || state === void 0 ? void 0 : state[blockClientId]) !== null && _state$blockClientId2 !== void 0 ? _state$blockClientId2 : EMPTY_ARRAY]; 747 }); 748 function __experimentalGetAllAnnotationsForBlock(state, blockClientId) { 749 var _state$blockClientId3; 750 751 return (_state$blockClientId3 = state === null || state === void 0 ? void 0 : state[blockClientId]) !== null && _state$blockClientId3 !== void 0 ? _state$blockClientId3 : EMPTY_ARRAY; 752 } 753 /** 754 * Returns the annotations that apply to the given RichText instance. 755 * 756 * Both a blockClientId and a richTextIdentifier are required. This is because 757 * a block might have multiple `RichText` components. This does mean that every 758 * block needs to implement annotations itself. 759 * 760 * @param {Object} state Editor state. 761 * @param {string} blockClientId The client ID for the block. 762 * @param {string} richTextIdentifier Unique identifier that identifies the given RichText. 763 * @return {Array} All the annotations relevant for the `RichText`. 764 */ 765 766 const __experimentalGetAnnotationsForRichText = rememo((state, blockClientId, richTextIdentifier) => { 767 var _state$blockClientId4; 768 769 return ((_state$blockClientId4 = state === null || state === void 0 ? void 0 : state[blockClientId]) !== null && _state$blockClientId4 !== void 0 ? _state$blockClientId4 : []).filter(annotation => { 770 return annotation.selector === 'range' && richTextIdentifier === annotation.richTextIdentifier; 771 }).map(annotation => { 772 const { 773 range, 774 ...other 775 } = annotation; 776 return { ...range, 777 ...other 778 }; 779 }); 780 }, (state, blockClientId) => { 781 var _state$blockClientId5; 782 783 return [(_state$blockClientId5 = state === null || state === void 0 ? void 0 : state[blockClientId]) !== null && _state$blockClientId5 !== void 0 ? _state$blockClientId5 : EMPTY_ARRAY]; 784 }); 785 /** 786 * Returns all annotations in the editor state. 787 * 788 * @param {Object} state Editor state. 789 * @return {Array} All annotations currently applied. 790 */ 791 792 function __experimentalGetAnnotations(state) { 793 return (0,external_lodash_namespaceObject.flatMap)(state, annotations => { 794 return annotations; 795 }); 796 } 797 798 ;// CONCATENATED MODULE: ./node_modules/uuid/dist/esm-browser/rng.js 799 // Unique ID creation requires a high quality random # generator. In the browser we therefore 800 // require the crypto API and do not support built-in fallback to lower quality random number 801 // generators (like Math.random()). 802 var getRandomValues; 803 var rnds8 = new Uint8Array(16); 804 function rng() { 805 // lazy load so that environments that need to polyfill have a chance to do so 806 if (!getRandomValues) { 807 // getRandomValues needs to be invoked in a context where "this" is a Crypto implementation. Also, 808 // find the complete implementation of crypto (msCrypto) on IE11. 809 getRandomValues = typeof crypto !== 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto) || typeof msCrypto !== 'undefined' && typeof msCrypto.getRandomValues === 'function' && msCrypto.getRandomValues.bind(msCrypto); 810 811 if (!getRandomValues) { 812 throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported'); 813 } 814 } 815 816 return getRandomValues(rnds8); 817 } 818 ;// CONCATENATED MODULE: ./node_modules/uuid/dist/esm-browser/regex.js 819 /* harmony default export */ var regex = (/^(?:[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}|00000000-0000-0000-0000-000000000000)$/i); 820 ;// CONCATENATED MODULE: ./node_modules/uuid/dist/esm-browser/validate.js 821 822 823 function validate(uuid) { 824 return typeof uuid === 'string' && regex.test(uuid); 825 } 826 827 /* harmony default export */ var esm_browser_validate = (validate); 828 ;// CONCATENATED MODULE: ./node_modules/uuid/dist/esm-browser/stringify.js 829 830 /** 831 * Convert array of 16 byte values to UUID string format of the form: 832 * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX 833 */ 834 835 var byteToHex = []; 836 837 for (var i = 0; i < 256; ++i) { 838 byteToHex.push((i + 0x100).toString(16).substr(1)); 839 } 840 841 function stringify(arr) { 842 var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0; 843 // Note: Be careful editing this code! It's been tuned for performance 844 // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434 845 var uuid = (byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]).toLowerCase(); // Consistency check for valid UUID. If this throws, it's likely due to one 846 // of the following: 847 // - One or more input array values don't map to a hex octet (leading to 848 // "undefined" in the uuid) 849 // - Invalid input values for the RFC `version` or `variant` fields 850 851 if (!esm_browser_validate(uuid)) { 852 throw TypeError('Stringified UUID is invalid'); 853 } 854 855 return uuid; 856 } 857 858 /* harmony default export */ var esm_browser_stringify = (stringify); 859 ;// CONCATENATED MODULE: ./node_modules/uuid/dist/esm-browser/v4.js 860 861 862 863 function v4(options, buf, offset) { 864 options = options || {}; 865 var rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved` 866 867 rnds[6] = rnds[6] & 0x0f | 0x40; 868 rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided 869 870 if (buf) { 871 offset = offset || 0; 872 873 for (var i = 0; i < 16; ++i) { 874 buf[offset + i] = rnds[i]; 875 } 876 877 return buf; 878 } 879 880 return esm_browser_stringify(rnds); 881 } 882 883 /* harmony default export */ var esm_browser_v4 = (v4); 884 ;// CONCATENATED MODULE: ./node_modules/@wordpress/annotations/build-module/store/actions.js 885 /** 886 * External dependencies 887 */ 888 889 /** 890 * @typedef WPAnnotationRange 891 * 892 * @property {number} start The offset where the annotation should start. 893 * @property {number} end The offset where the annotation should end. 894 */ 895 896 /** 897 * Adds an annotation to a block. 898 * 899 * The `block` attribute refers to a block ID that needs to be annotated. 900 * `isBlockAnnotation` controls whether or not the annotation is a block 901 * annotation. The `source` is the source of the annotation, this will be used 902 * to identity groups of annotations. 903 * 904 * The `range` property is only relevant if the selector is 'range'. 905 * 906 * @param {Object} annotation The annotation to add. 907 * @param {string} annotation.blockClientId The blockClientId to add the annotation to. 908 * @param {string} annotation.richTextIdentifier Identifier for the RichText instance the annotation applies to. 909 * @param {WPAnnotationRange} annotation.range The range at which to apply this annotation. 910 * @param {string} [annotation.selector="range"] The way to apply this annotation. 911 * @param {string} [annotation.source="default"] The source that added the annotation. 912 * @param {string} [annotation.id] The ID the annotation should have. Generates a UUID by default. 913 * 914 * @return {Object} Action object. 915 */ 916 917 function __experimentalAddAnnotation(_ref) { 918 let { 919 blockClientId, 920 richTextIdentifier = null, 921 range = null, 922 selector = 'range', 923 source = 'default', 924 id = esm_browser_v4() 925 } = _ref; 926 const action = { 927 type: 'ANNOTATION_ADD', 928 id, 929 blockClientId, 930 richTextIdentifier, 931 source, 932 selector 933 }; 934 935 if (selector === 'range') { 936 action.range = range; 937 } 938 939 return action; 940 } 941 /** 942 * Removes an annotation with a specific ID. 943 * 944 * @param {string} annotationId The annotation to remove. 945 * 946 * @return {Object} Action object. 947 */ 948 949 function __experimentalRemoveAnnotation(annotationId) { 950 return { 951 type: 'ANNOTATION_REMOVE', 952 annotationId 953 }; 954 } 955 /** 956 * Updates the range of an annotation. 957 * 958 * @param {string} annotationId ID of the annotation to update. 959 * @param {number} start The start of the new range. 960 * @param {number} end The end of the new range. 961 * 962 * @return {Object} Action object. 963 */ 964 965 function __experimentalUpdateAnnotationRange(annotationId, start, end) { 966 return { 967 type: 'ANNOTATION_UPDATE_RANGE', 968 annotationId, 969 start, 970 end 971 }; 972 } 973 /** 974 * Removes all annotations of a specific source. 975 * 976 * @param {string} source The source to remove. 977 * 978 * @return {Object} Action object. 979 */ 980 981 function __experimentalRemoveAnnotationsBySource(source) { 982 return { 983 type: 'ANNOTATION_REMOVE_SOURCE', 984 source 985 }; 986 } 987 988 ;// CONCATENATED MODULE: ./node_modules/@wordpress/annotations/build-module/store/index.js 989 /** 990 * WordPress dependencies 991 */ 992 993 /** 994 * Internal dependencies 995 */ 996 997 998 999 1000 /** 1001 * Module Constants 1002 */ 1003 1004 1005 /** 1006 * Store definition for the annotations namespace. 1007 * 1008 * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/data/README.md#createReduxStore 1009 * 1010 * @type {Object} 1011 */ 1012 1013 const store = (0,external_wp_data_namespaceObject.createReduxStore)(STORE_NAME, { 1014 reducer: reducer, 1015 selectors: selectors_namespaceObject, 1016 actions: actions_namespaceObject 1017 }); 1018 (0,external_wp_data_namespaceObject.register)(store); 1019 1020 ;// CONCATENATED MODULE: ./node_modules/@wordpress/annotations/build-module/index.js 1021 /** 1022 * Internal dependencies 1023 */ 1024 1025 1026 1027 1028 (window.wp = window.wp || {}).annotations = __webpack_exports__; 1029 /******/ })() 1030 ;
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 |