Initial commit
This commit is contained in:
1
wp-includes/blocks/cover/style.min.css
vendored
Normal file
1
wp-includes/blocks/cover/style.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
1
wp-includes/blocks/image/view.min.js
vendored
Normal file
1
wp-includes/blocks/image/view.min.js
vendored
Normal file
@ -0,0 +1 @@
|
||||
import*as t from"@wordpress/interactivity";var e={d:(t,n)=>{for(var o in n)e.o(n,o)&&!e.o(t,o)&&Object.defineProperty(t,o,{enumerable:!0,get:n[o]})},o:(t,e)=>Object.prototype.hasOwnProperty.call(t,e)};const n=(t=>{var n={};return e.d(n,t),n})({getContext:()=>t.getContext,getElement:()=>t.getElement,store:()=>t.store});let o,r,i=!1,l=0;const{state:a,actions:c,callbacks:s}=(0,n.store)("core/image",{state:{currentImage:{},get overlayOpened(){return a.currentImage.currentSrc},get roleAttribute(){return a.overlayOpened?"dialog":null},get ariaModal(){return a.overlayOpened?"true":null},get enlargedSrc(){return a.currentImage.uploadedSrc||""},get imgStyles(){return a.overlayOpened&&`${a.currentImage.imgStyles?.replace(/;$/,"")}; object-fit:cover;`}},actions:{showLightbox(){const t=(0,n.getContext)();t.imageRef?.complete&&(a.scrollTopReset=document.documentElement.scrollTop,a.scrollLeftReset=document.documentElement.scrollLeft,t.currentSrc=t.imageRef.currentSrc,o=t.imageRef,r=t.buttonRef,a.currentImage=t,a.overlayEnabled=!0,s.setOverlayStyles())},hideLightbox(){a.overlayEnabled&&(setTimeout((function(){r.focus({preventScroll:!0}),a.currentImage={},o=null,r=null}),450),a.showClosingAnimation=!0,a.overlayEnabled=!1)},handleKeydown(t){if(a.overlayEnabled){if("Tab"===t.key){t.preventDefault();const{ref:e}=(0,n.getElement)();e.querySelector("button").focus()}"Escape"===t.key&&c.hideLightbox()}},handleTouchMove(t){a.overlayEnabled&&t.preventDefault()},handleTouchStart(){i=!0},handleTouchEnd(){l=Date.now(),i=!1},handleScroll(){a.overlayOpened&&!i&&Date.now()-l>450&&window.scrollTo(a.scrollLeftReset,a.scrollTopReset)}},callbacks:{setOverlayStyles(){if(!o)return;let{naturalWidth:t,naturalHeight:e,offsetWidth:n,offsetHeight:r}=o,{x:i,y:l}=o.getBoundingClientRect();const c=t/e;let s=n/r;if("contain"===a.currentImage.scaleAttr)if(c>s){const t=n/c;l+=(r-t)/2,r=t}else{const t=r*c;i+=(n-t)/2,n=t}s=n/r;let g=parseFloat("none"!==a.currentImage.targetWidth?a.currentImage.targetWidth:t),u=parseFloat("none"!==a.currentImage.targetHeight?a.currentImage.targetHeight:e),d=g/u,h=g,m=u,p=g,f=u;if(c.toFixed(2)!==d.toFixed(2)){if(c>d){const t=g/c;u-t>g?(u=t,g=t*c):u=g/c}else{const t=u*c;g-t>u?(g=t,u=t/c):g=u*c}p=g,f=u,d=g/u,s>d?(h=g,m=h/s):(m=u,h=m*s)}(n>p||r>f)&&(p=n,f=r);let w=0;window.innerWidth>480?w=80:window.innerWidth>1920&&(w=160);const y=Math.min(window.innerWidth-w,p),b=Math.min(window.innerHeight-80,f);s>y/b?(p=y,f=p/s):(f=b,p=f*s);const x=n/p,v=g*(p/h),A=u*(f/m);a.overlayStyles=`\n\t\t\t\t:root {\n\t\t\t\t\t--wp--lightbox-initial-top-position: ${l}px;\n\t\t\t\t\t--wp--lightbox-initial-left-position: ${i}px;\n\t\t\t\t\t--wp--lightbox-container-width: ${p+1}px;\n\t\t\t\t\t--wp--lightbox-container-height: ${f+1}px;\n\t\t\t\t\t--wp--lightbox-image-width: ${v}px;\n\t\t\t\t\t--wp--lightbox-image-height: ${A}px;\n\t\t\t\t\t--wp--lightbox-scale: ${x};\n\t\t\t\t\t--wp--lightbox-scrollbar-width: ${window.innerWidth-document.documentElement.clientWidth}px;\n\t\t\t\t}\n\t\t\t`},setButtonStyles(){const t=(0,n.getContext)(),{ref:e}=(0,n.getElement)();t.imageRef=e;const{naturalWidth:o,naturalHeight:r,offsetWidth:i,offsetHeight:l}=e;if(0===o||0===r)return;const a=e.parentElement,c=e.parentElement.clientWidth;let s=e.parentElement.clientHeight;const g=a.querySelector("figcaption");if(g){const t=window.getComputedStyle(g);["absolute","fixed"].includes(t.position)||(s=s-g.offsetHeight-parseFloat(t.marginTop)-parseFloat(t.marginBottom))}const u=s-l,d=c-i;if("contain"===t.scaleAttr){const e=o/r;if(e>=i/l){const n=i/e;t.imageButtonTop=(l-n)/2+u+16,t.imageButtonRight=d+16}else{const n=l*e;t.imageButtonTop=u+16,t.imageButtonRight=(i-n)/2+d+16}}else t.imageButtonTop=u+16,t.imageButtonRight=d+16},setOverlayFocus(){if(a.overlayEnabled){const{ref:t}=(0,n.getElement)();t.focus()}},initTriggerButton(){const t=(0,n.getContext)(),{ref:e}=(0,n.getElement)();t.buttonRef=e}}},{lock:!0});
|
1
wp-includes/blocks/navigation/style.min.css
vendored
Normal file
1
wp-includes/blocks/navigation/style.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
1
wp-includes/blocks/navigation/view.min.js
vendored
Normal file
1
wp-includes/blocks/navigation/view.min.js
vendored
Normal file
@ -0,0 +1 @@
|
||||
import*as e from"@wordpress/interactivity";var t={d:(e,n)=>{for(var o in n)t.o(n,o)&&!t.o(e,o)&&Object.defineProperty(e,o,{enumerable:!0,get:n[o]})},o:(e,t)=>Object.prototype.hasOwnProperty.call(e,t)};const n=(e=>{var n={};return t.d(n,e),n})({getContext:()=>e.getContext,getElement:()=>e.getElement,store:()=>e.store}),o=["a[href]",'input:not([disabled]):not([type="hidden"]):not([aria-hidden])',"select:not([disabled]):not([aria-hidden])","textarea:not([disabled]):not([aria-hidden])","button:not([disabled]):not([aria-hidden])","[contenteditable]",'[tabindex]:not([tabindex^="-"])'];document.addEventListener("click",(()=>{}));const{state:l,actions:c}=(0,n.store)("core/navigation",{state:{get roleAttribute(){return"overlay"===(0,n.getContext)().type&&l.isMenuOpen?"dialog":null},get ariaModal(){return"overlay"===(0,n.getContext)().type&&l.isMenuOpen?"true":null},get ariaLabel(){const e=(0,n.getContext)();return"overlay"===e.type&&l.isMenuOpen?e.ariaLabel:null},get isMenuOpen(){return Object.values(l.menuOpenedBy).filter(Boolean).length>0},get menuOpenedBy(){const e=(0,n.getContext)();return"overlay"===e.type?e.overlayOpenedBy:e.submenuOpenedBy}},actions:{openMenuOnHover(){const{type:e,overlayOpenedBy:t}=(0,n.getContext)();"submenu"===e&&0===Object.values(t||{}).filter(Boolean).length&&c.openMenu("hover")},closeMenuOnHover(){const{type:e,overlayOpenedBy:t}=(0,n.getContext)();"submenu"===e&&0===Object.values(t||{}).filter(Boolean).length&&c.closeMenu("hover")},openMenuOnClick(){const e=(0,n.getContext)(),{ref:t}=(0,n.getElement)();e.previousFocus=t,c.openMenu("click")},closeMenuOnClick(){c.closeMenu("click"),c.closeMenu("focus")},openMenuOnFocus(){c.openMenu("focus")},toggleMenuOnClick(){const e=(0,n.getContext)(),{ref:t}=(0,n.getElement)();window.document.activeElement!==t&&t.focus();const{menuOpenedBy:o}=l;o.click||o.focus?(c.closeMenu("click"),c.closeMenu("focus")):(e.previousFocus=t,c.openMenu("click"))},handleMenuKeydown(e){const{type:t,firstFocusableElement:o,lastFocusableElement:u}=(0,n.getContext)();if(l.menuOpenedBy.click){if("Escape"===e?.key)return c.closeMenu("click"),void c.closeMenu("focus");"overlay"===t&&"Tab"===e.key&&(e.shiftKey&&window.document.activeElement===o?(e.preventDefault(),u.focus()):e.shiftKey||window.document.activeElement!==u||(e.preventDefault(),o.focus()))}},handleMenuFocusout(e){const{modal:t,type:o}=(0,n.getContext)();(null===e.relatedTarget||!t?.contains(e.relatedTarget)&&e.target!==window.document.activeElement&&"submenu"===o)&&(c.closeMenu("click"),c.closeMenu("focus"))},openMenu(e="click"){const{type:t}=(0,n.getContext)();l.menuOpenedBy[e]=!0,"overlay"===t&&document.documentElement.classList.add("has-modal-open")},closeMenu(e="click"){const t=(0,n.getContext)();l.menuOpenedBy[e]=!1,l.isMenuOpen||(t.modal?.contains(window.document.activeElement)&&t.previousFocus?.focus(),t.modal=null,t.previousFocus=null,"overlay"===t.type&&document.documentElement.classList.remove("has-modal-open"))}},callbacks:{initMenu(){const e=(0,n.getContext)(),{ref:t}=(0,n.getElement)();if(l.isMenuOpen){const n=t.querySelectorAll(o);e.modal=t,e.firstFocusableElement=n[0],e.lastFocusableElement=n[n.length-1]}},focusFirstElement(){const{ref:e}=(0,n.getElement)();if(l.isMenuOpen){const t=e.querySelectorAll(o);t?.[0]?.focus()}}}},{lock:!0});
|
1
wp-includes/blocks/social-links/style.min.css
vendored
Normal file
1
wp-includes/blocks/social-links/style.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
2
wp-includes/js/dist/interactivity.min.js
vendored
Normal file
2
wp-includes/js/dist/interactivity.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
584
wp-includes/js/twemoji.js
Normal file
584
wp-includes/js/twemoji.js
Normal file
File diff suppressed because one or more lines are too long
5
wp-includes/js/wp-emoji-release.min.js
vendored
Normal file
5
wp-includes/js/wp-emoji-release.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
304
wp-includes/js/wp-emoji.js
Normal file
304
wp-includes/js/wp-emoji.js
Normal file
@ -0,0 +1,304 @@
|
||||
/**
|
||||
* wp-emoji.js is used to replace emoji with images in browsers when the browser
|
||||
* doesn't support emoji natively.
|
||||
*
|
||||
* @output wp-includes/js/wp-emoji.js
|
||||
*/
|
||||
|
||||
( function( window, settings ) {
|
||||
/**
|
||||
* Replaces emoji with images when browsers don't support emoji.
|
||||
*
|
||||
* @since 4.2.0
|
||||
* @access private
|
||||
*
|
||||
* @class
|
||||
*
|
||||
* @see Twitter Emoji library
|
||||
* @link https://github.com/twitter/twemoji
|
||||
*
|
||||
* @return {Object} The wpEmoji parse and test functions.
|
||||
*/
|
||||
function wpEmoji() {
|
||||
var MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver,
|
||||
|
||||
// Compression and maintain local scope.
|
||||
document = window.document,
|
||||
|
||||
// Private.
|
||||
twemoji, timer,
|
||||
loaded = false,
|
||||
count = 0,
|
||||
ie11 = window.navigator.userAgent.indexOf( 'Trident/7.0' ) > 0;
|
||||
|
||||
/**
|
||||
* Detect if the browser supports SVG.
|
||||
*
|
||||
* @since 4.6.0
|
||||
* @private
|
||||
*
|
||||
* @see Modernizr
|
||||
* @link https://github.com/Modernizr/Modernizr/blob/master/feature-detects/svg/asimg.js
|
||||
*
|
||||
* @return {boolean} True if the browser supports svg, false if not.
|
||||
*/
|
||||
function browserSupportsSvgAsImage() {
|
||||
if ( !! document.implementation.hasFeature ) {
|
||||
return document.implementation.hasFeature( 'http://www.w3.org/TR/SVG11/feature#Image', '1.1' );
|
||||
}
|
||||
|
||||
// document.implementation.hasFeature is deprecated. It can be presumed
|
||||
// if future browsers remove it, the browser will support SVGs as images.
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Runs when the document load event is fired, so we can do our first parse of
|
||||
* the page.
|
||||
*
|
||||
* Listens to all the DOM mutations and checks for added nodes that contain
|
||||
* emoji characters and replaces those with twitter emoji images.
|
||||
*
|
||||
* @since 4.2.0
|
||||
* @private
|
||||
*/
|
||||
function load() {
|
||||
if ( loaded ) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Ensure twemoji is available on the global window before proceeding.
|
||||
if ( typeof window.twemoji === 'undefined' ) {
|
||||
// Break if waiting for longer than 30 seconds.
|
||||
if ( count > 600 ) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Still waiting.
|
||||
window.clearTimeout( timer );
|
||||
timer = window.setTimeout( load, 50 );
|
||||
count++;
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
twemoji = window.twemoji;
|
||||
loaded = true;
|
||||
|
||||
// Initialize the mutation observer, which checks all added nodes for
|
||||
// replaceable emoji characters.
|
||||
if ( MutationObserver ) {
|
||||
new MutationObserver( function( mutationRecords ) {
|
||||
var i = mutationRecords.length,
|
||||
addedNodes, removedNodes, ii, node;
|
||||
|
||||
while ( i-- ) {
|
||||
addedNodes = mutationRecords[ i ].addedNodes;
|
||||
removedNodes = mutationRecords[ i ].removedNodes;
|
||||
ii = addedNodes.length;
|
||||
|
||||
/*
|
||||
* Checks if an image has been replaced by a text element
|
||||
* with the same text as the alternate description of the replaced image.
|
||||
* (presumably because the image could not be loaded).
|
||||
* If it is, do absolutely nothing.
|
||||
*
|
||||
* Node type 3 is a TEXT_NODE.
|
||||
*
|
||||
* @link https://developer.mozilla.org/en-US/docs/Web/API/Node/nodeType
|
||||
*/
|
||||
if (
|
||||
ii === 1 && removedNodes.length === 1 &&
|
||||
addedNodes[0].nodeType === 3 &&
|
||||
removedNodes[0].nodeName === 'IMG' &&
|
||||
addedNodes[0].data === removedNodes[0].alt &&
|
||||
'load-failed' === removedNodes[0].getAttribute( 'data-error' )
|
||||
) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Loop through all the added nodes.
|
||||
while ( ii-- ) {
|
||||
node = addedNodes[ ii ];
|
||||
|
||||
// Node type 3 is a TEXT_NODE.
|
||||
if ( node.nodeType === 3 ) {
|
||||
if ( ! node.parentNode ) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if ( ie11 ) {
|
||||
/*
|
||||
* IE 11's implementation of MutationObserver is buggy.
|
||||
* It unnecessarily splits text nodes when it encounters a HTML
|
||||
* template interpolation symbol ( "{{", for example ). So, we
|
||||
* join the text nodes back together as a work-around.
|
||||
*
|
||||
* Node type 3 is a TEXT_NODE.
|
||||
*/
|
||||
while( node.nextSibling && 3 === node.nextSibling.nodeType ) {
|
||||
node.nodeValue = node.nodeValue + node.nextSibling.nodeValue;
|
||||
node.parentNode.removeChild( node.nextSibling );
|
||||
}
|
||||
}
|
||||
|
||||
node = node.parentNode;
|
||||
}
|
||||
|
||||
if ( test( node.textContent ) ) {
|
||||
parse( node );
|
||||
}
|
||||
}
|
||||
}
|
||||
} ).observe( document.body, {
|
||||
childList: true,
|
||||
subtree: true
|
||||
} );
|
||||
}
|
||||
|
||||
parse( document.body );
|
||||
}
|
||||
|
||||
/**
|
||||
* Tests if a text string contains emoji characters.
|
||||
*
|
||||
* @since 4.3.0
|
||||
*
|
||||
* @memberOf wp.emoji
|
||||
*
|
||||
* @param {string} text The string to test.
|
||||
*
|
||||
* @return {boolean} Whether the string contains emoji characters.
|
||||
*/
|
||||
function test( text ) {
|
||||
// Single char. U+20E3 to detect keycaps. U+00A9 "copyright sign" and U+00AE "registered sign" not included.
|
||||
var single = /[\u203C\u2049\u20E3\u2122\u2139\u2194-\u2199\u21A9\u21AA\u2300\u231A\u231B\u2328\u2388\u23CF\u23E9-\u23F3\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB-\u25FE\u2600-\u2604\u260E\u2611\u2614\u2615\u2618\u261D\u2620\u2622\u2623\u2626\u262A\u262E\u262F\u2638\u2639\u263A\u2648-\u2653\u2660\u2663\u2665\u2666\u2668\u267B\u267F\u2692\u2693\u2694\u2696\u2697\u2699\u269B\u269C\u26A0\u26A1\u26AA\u26AB\u26B0\u26B1\u26BD\u26BE\u26C4\u26C5\u26C8\u26CE\u26CF\u26D1\u26D3\u26D4\u26E9\u26EA\u26F0-\u26F5\u26F7-\u26FA\u26FD\u2702\u2705\u2708-\u270D\u270F\u2712\u2714\u2716\u271D\u2721\u2728\u2733\u2734\u2744\u2747\u274C\u274E\u2753\u2754\u2755\u2757\u2763\u2764\u2795\u2796\u2797\u27A1\u27B0\u27BF\u2934\u2935\u2B05\u2B06\u2B07\u2B1B\u2B1C\u2B50\u2B55\u3030\u303D\u3297\u3299]/,
|
||||
// Surrogate pair range. Only tests for the second half.
|
||||
pair = /[\uDC00-\uDFFF]/;
|
||||
|
||||
if ( text ) {
|
||||
return pair.test( text ) || single.test( text );
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Parses any emoji characters into Twemoji images.
|
||||
*
|
||||
* - When passed an element the emoji characters are replaced inline.
|
||||
* - When passed a string the emoji characters are replaced and the result is
|
||||
* returned.
|
||||
*
|
||||
* @since 4.2.0
|
||||
*
|
||||
* @memberOf wp.emoji
|
||||
*
|
||||
* @param {HTMLElement|string} object The element or string to parse.
|
||||
* @param {Object} args Additional options for Twemoji.
|
||||
*
|
||||
* @return {HTMLElement|string} A string where all emoji are now image tags of
|
||||
* emoji. Or the element that was passed as the first argument.
|
||||
*/
|
||||
function parse( object, args ) {
|
||||
var params;
|
||||
|
||||
/*
|
||||
* If the browser has full support, twemoji is not loaded or our
|
||||
* object is not what was expected, we do not parse anything.
|
||||
*/
|
||||
if ( settings.supports.everything || ! twemoji || ! object ||
|
||||
( 'string' !== typeof object && ( ! object.childNodes || ! object.childNodes.length ) ) ) {
|
||||
|
||||
return object;
|
||||
}
|
||||
|
||||
// Compose the params for the twitter emoji library.
|
||||
args = args || {};
|
||||
params = {
|
||||
base: browserSupportsSvgAsImage() ? settings.svgUrl : settings.baseUrl,
|
||||
ext: browserSupportsSvgAsImage() ? settings.svgExt : settings.ext,
|
||||
className: args.className || 'emoji',
|
||||
callback: function( icon, options ) {
|
||||
// Ignore some standard characters that TinyMCE recommends in its character map.
|
||||
switch ( icon ) {
|
||||
case 'a9':
|
||||
case 'ae':
|
||||
case '2122':
|
||||
case '2194':
|
||||
case '2660':
|
||||
case '2663':
|
||||
case '2665':
|
||||
case '2666':
|
||||
return false;
|
||||
}
|
||||
|
||||
if ( settings.supports.everythingExceptFlag &&
|
||||
! /^1f1(?:e[6-9a-f]|f[0-9a-f])-1f1(?:e[6-9a-f]|f[0-9a-f])$/.test( icon ) && // Country flags.
|
||||
! /^(1f3f3-fe0f-200d-1f308|1f3f4-200d-2620-fe0f)$/.test( icon ) // Rainbow and pirate flags.
|
||||
) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return ''.concat( options.base, icon, options.ext );
|
||||
},
|
||||
attributes: function() {
|
||||
return {
|
||||
role: 'img'
|
||||
};
|
||||
},
|
||||
onerror: function() {
|
||||
if ( twemoji.parentNode ) {
|
||||
this.setAttribute( 'data-error', 'load-failed' );
|
||||
twemoji.parentNode.replaceChild( document.createTextNode( twemoji.alt ), twemoji );
|
||||
}
|
||||
},
|
||||
doNotParse: function( node ) {
|
||||
if (
|
||||
node &&
|
||||
node.className &&
|
||||
typeof node.className === 'string' &&
|
||||
node.className.indexOf( 'wp-exclude-emoji' ) !== -1
|
||||
) {
|
||||
// Do not parse this node. Emojis will not be replaced in this node and all sub-nodes.
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
};
|
||||
|
||||
if ( typeof args.imgAttr === 'object' ) {
|
||||
params.attributes = function() {
|
||||
return args.imgAttr;
|
||||
};
|
||||
}
|
||||
|
||||
return twemoji.parse( object, params );
|
||||
}
|
||||
|
||||
/**
|
||||
* Initialize our emoji support, and set up listeners.
|
||||
*/
|
||||
if ( settings ) {
|
||||
if ( settings.DOMReady ) {
|
||||
load();
|
||||
} else {
|
||||
settings.readyCallback = load;
|
||||
}
|
||||
}
|
||||
|
||||
return {
|
||||
parse: parse,
|
||||
test: test
|
||||
};
|
||||
}
|
||||
|
||||
window.wp = window.wp || {};
|
||||
|
||||
/**
|
||||
* @namespace wp.emoji
|
||||
*/
|
||||
window.wp.emoji = new wpEmoji();
|
||||
|
||||
} )( window, window._wpemojiSettings );
|
Reference in New Issue
Block a user